messaginghub-client
v3.4.1
Published
Simple Messaging Hub client.
Downloads
50
Keywords
Readme
messaging-hub-client-js
Simple BLiP Messaging Hub client for JavaScript
This is a work in progress
See more about BLiP Messaging Hub here
How to use
If you are using node.js (or webpack), simply install the messaginghub-client
package from the npm registry.
npm install --save messaginghub-client lime-transport-websocket
However, if you're building for the browser and using vanilla JavaScript, you can install the package via npm and then include the distribution script via a <script>
tag. Note also, that in order to use messaginghub-client
with this setting you must also install and use the lime-js
library:
<script src="./node_modules/lime-js/dist/lime.js" type="text/javascript"></script>
<script src="./node_modules/messaginghub-client/dist/messaginghub-client.js" type="text/javascript"></script>
<script src="./node_modules/lime-transport-websocket/WebSocketTransport.js" type="text/javascript"></script>
Or you can also use the script served by unpkg:
<script src="https://unpkg.com/lime-js" type="text/javascript"></script>
<script src="https://unpkg.com/messaginghub-client" type="text/javascript"></script>
<script src="https://unpkg.com/lime-transport-websocket" type="text/javascript"></script>
Instantiate the MessagingHub Client
import * as MessagingHub from 'messaginghub-client';
import * as WebSocketTransport from 'lime-transport-websocket'
let client = new MessagingHub.ClientBuilder()
.withIdentifier(IDENTIFIER)
.withAccessKey(ACCESS_KEY)
.withTransportFactory(() => new WebSocketTransport())
.build();
Transport packages
The MessagingHubClient class uses transport classes defined according to the Lime procotol specification from the lime-js package. There are a few official packages for Lime transport classes publicly available on NPM and on our Github, but we plan on building more transport classes for node.js and the browser:
In order to use these transport classes in your project you must also include their script files using either npm or unpkg (refer to the How to use section).
Connect
client.connectWithKey(identifier, key).then(/* handle connection */);
Sending
In order to ensure a connection is available and have no runtime exceptions, one must send messages only after the connection has been established, that is, all sending logic must be written inside the promise handler for the connection method, as shown in the examples below:
Sending messages
client.connectWithKey(identifier, key)
.then(function(session) {
// send a message to some user
var msg = { type: "application/json", content: "Hello, world", to: "[email protected]" };
client.sendMessage(msg);
});
Sending notifications
client.connectWithKey(identifier, key)
.then(function(session) {
// send a "received" notification to some user
var notification = { to: "[email protected]", event: Lime.NotificationEvent.RECEIVED };
client.sendNotification(notification);
});
Sending commands
client.connectWithKey(identifier, key)
.then(function(session) {
// send a message to some user
var command = { uri: "/ping", method: Lime.CommandMethod.GET };
client.sendCommand(command);
});
Receiving
Add receivers
client.addMessageReceiver("application/json", function(message) {
// do something
});
client.addNotificationReceiver("received", function(notification) {
// show something
});
Remove receivers
The client.addMessageReceiver and client.addNotificationReceiver methods return each a function which, when called, cancels the receiver subscription:
var removeJsonReceiver = client.addMessageReceiver("application/json", handleJson);
// ...
removeJsonReceiver();
Receiving command answers
Unlike messages and notifications, when command is sent, the response is received when the promise is complete. This response will contain information about the result of the execution of the command sent.
var command = { uri: "/ping", method: Lime.CommandMethod.GET };
client.sendCommand(command)
.then(function(response) {
// handle command repsonse
});
Contributing
For information on how to contribute to this package, please refer to our Contribution guidelines.