Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hypersolution1/clearthru
This is a communication library that provides remote procedure calls (RPC) and events over websocket
https://github.com/hypersolution1/clearthru
communication nodejs promise rpc-library websocket
Last synced: about 17 hours ago
JSON representation
This is a communication library that provides remote procedure calls (RPC) and events over websocket
- Host: GitHub
- URL: https://github.com/hypersolution1/clearthru
- Owner: hypersolution1
- License: mit
- Created: 2018-07-13T02:45:56.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-10-29T16:14:04.000Z (2 months ago)
- Last Synced: 2024-12-13T07:54:55.922Z (27 days ago)
- Topics: communication, nodejs, promise, rpc-library, websocket
- Language: JavaScript
- Homepage:
- Size: 464 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# ClearThru
This is a communication library that provides remote procedure calls (RPC) and events over websocket.
## Features:
* Use Promises
* Wrap Js Classes (```extends clearthru.API```) server-side and expose its methods that will be callable from the client.
* Server Methods can instantiate new ```clearthru.API``` Objects that could be returned to the client. This allows scoped APIs in an Object-Oriented pattern.
* Scalable. Server could be shutted off and the client would keep its state and try to resume connection. On a successful connection, even with a new server instance, the client objects APIs will restore their context and resume normal operation.## Documentation
### Server
```javascript
//require the server
var clearthru = require('clearthru').server//Define an API
class MyAPI extends clearthru.API {
method2() {
}
}
// This register an object
clearthru.register(MyAPI)class Boot extends clearthru.API {
method1() {
return this.create("MyAPI")
}
}
// This register the bootstrap object
clearthru.bootstrap(Boot)...
//Create a http server
var server = http.createServer(app)
//Attach clearthru to the server
clearthru.attach(server, SECRETKEY)```
### Client
```javascript
// Require the client
var client = require('clearthru').client// Connect to the server
var boot = await client.init('ws://localhost:3082')
// boot is now mapped to an instance of Boot on the server// Call a method as a Promise
var api = await boot.method1()
// In this example, api will map to an instance of MyAPI on the serverawait api.method2()
```
## Connect/Express middleware
```javascript
// Server
var connect = require('connect')
var app = connect()
var clearthru = require("clearthru")
// Allow the browser to download the client script. URL: /clearthru-client
app.use(clearthru.browserClient())
``````html
var client = require('clearthru').client
//...
```
## Example
Look in the example folder. First, run ```npm install``` in the root folder and in example folder.
```bash
cd example
node svr.js # This will start a server demo
# Either you browse http://localhost:3082 or you run:
node cli.js # a client demo
```