Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/basedwon/newk
Provides a flexible, transport-layer abstraction for various network protocols
https://github.com/basedwon/newk
nkn p2p pubsub transport
Last synced: about 1 month ago
JSON representation
Provides a flexible, transport-layer abstraction for various network protocols
- Host: GitHub
- URL: https://github.com/basedwon/newk
- Owner: basedwon
- License: mit
- Created: 2023-11-04T00:05:06.000Z (about 1 year ago)
- Default Branch: master
- Last Pushed: 2023-11-21T02:06:41.000Z (about 1 year ago)
- Last Synced: 2024-12-07T01:06:46.110Z (about 2 months ago)
- Topics: nkn, p2p, pubsub, transport
- Language: JavaScript
- Homepage:
- Size: 113 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: docs/contributing.md
- License: LICENSE
Awesome Lists containing this project
README
![Newk radioactive phone](docs/newk.png "Newk")
# Newk
> Weapon of Mass Decentralization
[![npm](https://img.shields.io/npm/v/newk?style=flat&logo=npm)](https://www.npmjs.com/package/newk)
[![pipeline](https://gitlab.com/basedwon/newk/badges/master/pipeline.svg)](https://gitlab.com/basedwon/newk/-/pipelines)
[![license](https://img.shields.io/npm/l/newk)](https://gitlab.com/basedwon/newk/-/blob/master/LICENSE)
[![downloads](https://img.shields.io/npm/dw/newk)](https://www.npmjs.com/package/newk)[![Gitlab](https://img.shields.io/badge/Gitlab%20-%20?logo=gitlab&color=%23383a40)](https://gitlab.com/basedwon/newk)
[![Github](https://img.shields.io/badge/Github%20-%20?logo=github&color=%23383a40)](https://github.com/basedwon/newk)
[![Twitter](https://img.shields.io/badge/@basdwon%20-%20?logo=twitter&color=%23383a40)](https://twitter.com/basdwon)
[![Discord](https://img.shields.io/badge/Basedwon%20-%20?logo=discord&color=%23383a40)](https://discordapp.com/users/basedwon)Provides a flexible, transport-layer abstraction for various network protocols. By utilizing a base transport class, `newk` allows for easy extension and customization of network communication patterns. It comes with an NKN (New Kind of Network) and memory bus transport implementation and supports message routing, publish/subscribe patterns, and basic message handling.
## Features
- Transport-layer abstraction with a base class for easy extension.
- Built-in NKN transport implementation for decentralized communication.
- Support for Pub/Sub mechanisms.
- Extendable with various decorators for additional functionality.
- Straightforward message routing.## Installation
```bash
npm install newk
```## Usage
Import the `Newk` class mixin from the package:
```js
import Newk from 'newk'
```
or
```js
const Newk = require('newk')
```### Initializing Newk
```js
// Initialize with options
const options = {
identifier: 'your-identifier',
transport: 'bus', // or 'nkn'
decorators: ['pubsub', 'encryption'],
// ... other options
}
const newk = await Newk.init(options, transportType)
```### Adding Routes
```js
newk.addRoute('action', handlerFunction)
newk.addRoutes(anObjectContainingMethods) // each method that starts with `on` is route
```### Sending and Dispatching Messages
```js
await newk.send(destination, payload, options)
await newk.dispatch(destination, messageType, data, options)
```### Subscription and Publishing
```js
await newk.subscribe(topic, metadata)
await newk.unsubscribe(topic)
await newk.publish(topic, payload)
await newk.broadcast(topic, messageType, data, options, excludeSelf)
```### Getting Subscribers
```js
await newk.getSubscribers(topic, metadata)
await newk.discover(topic, metadata, ...)
```### Handling Messages
The `onMessage` method is used to handle incoming messages:
```js
newk.onMessage((message) => {
// Handle the message
})
```### Connection Handling with NknConnect
To manage connections with `NknConnect`:
```js
const nknConnect = await NknConnect.init(options)
```You can use `onMessage`, `onConnect`, and `onWsError` methods to handle different connection events.
## Documentation
- [API Reference](/docs/api.md)
## Tests
In order to run the test suite, simply clone the repository and install its dependencies:
```bash
git clone https://gitlab.com/basedwon/newk.git
cd newk
npm install
```To run the tests:
```bash
npm test
```## Contributing
Thank you! Please see our [contributing guidelines](/docs/contributing.md) for details.
## Donations
If you find this project useful and want to help support further development, please send us some coin. We greatly appreciate any and all contributions. Thank you!
**Bitcoin (BTC):**
```
1JUb1yNFH6wjGekRUW6Dfgyg4J4h6wKKdF
```**Monero (XMR):**
```
46uV2fMZT3EWkBrGUgszJCcbqFqEvqrB4bZBJwsbx7yA8e2WBakXzJSUK8aqT4GoqERzbg4oKT2SiPeCgjzVH6VpSQ5y7KQ
```## License
Newk is [MIT licensed](https://gitlab.com/basedwon/newk/-/blob/master/LICENSE).