Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/knowledgecode/messenger
Req/Rep Pub/Sub library for iframes and workers
https://github.com/knowledgecode/messenger
iframe pub pubsub rep req sub worker
Last synced: about 2 months ago
JSON representation
Req/Rep Pub/Sub library for iframes and workers
- Host: GitHub
- URL: https://github.com/knowledgecode/messenger
- Owner: knowledgecode
- License: mit
- Created: 2019-08-17T13:51:01.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-08T09:05:51.000Z (about 2 years ago)
- Last Synced: 2024-11-24T09:30:59.640Z (2 months ago)
- Topics: iframe, pub, pubsub, rep, req, sub, worker
- Language: JavaScript
- Homepage:
- Size: 79.1 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Messenger
Messenger is a `Req/Rep` `Pub/Sub` library for iframes and workers.
## Features
Allows messages to be exchanged between ...
- the main window and one or more iframes / workers.
- multiple iframes.
- multiple components.## Installation
via npm:
```shell
npm i @knowledgecode/messenger
```## Usage
```javascript
import { MessengerClient, MessengerServer } from '@knowledgecode/messenger';
```ES Modules:
```html
import { MessengerClient, MessengerServer } from '/path/to/esm/messenger.js';
```
Traditional:
```html
// It is provided with the global variable name "messenger".
const { MessengerClient, MessengerServer } = self.messenger;```
## Simple Example
main.js
```javascript
import { MessengerClient } from '/path/to/esm/messenger.js';const messenger = new MessengerClient();
const worker = new Worker('/path/to/worker.js');(async () => {
await messenger.connect('example', worker);const answer = await messenger.req('add', { x: 2, y: 3 });
console.log(answer); // => 5
messenger.send('close');
messenger.disconnect();
})();
```worker.js
```javascript
importScripts('/path/to/umd/messenger.js');const { MessengerServer } = self.messenger;
const messenger = new MessengerServer('example', self);messenger.bind('add', data => {
return data.x + data.y;
});messenger.bind('close', () => {
messenger.close();
// Close this worker.
self.close();
});
```## MessengerClient API
### `constructor()`
```javascript
const messenger = new MessengerClient();
```### `connect(name, [endpoint[, options]])`
- {**string**} name - unique name of the MessengerServer to connect to
- {**Object**} [endpoint] - an object that actually executes the `postMessage()`
- {**Object**} [options] - connection optionsThe `MessengerClient` must connect to a `MessengerServer` via `endpoint` before communication can begin. To identify the `MessengerServer` to connect to, pass the unique name of the `MessengerServer` as the first argument. The `endpoint` is the object that actually executes the `postMessage()`. If omitted, it is assumed that `self` is set. The `options` are connection options and members of this object are `targetOrigin` and `timeout` (msec). If the `timeout` is omitted, this method will wait forever for a successful connection.
```javascript
// To connect from the main window to a iframe.
const iframe = window.frames[0];await messenger.connect('iframe', iframe, { targetOrigin: '*', timeout: 1000 })
.catch(e => console.log(e));
``````javascript
// To connect from the main window to a worker.
const worker = new Worker('/path/to/worker.js');await messenger.connect('worker', worker, { timeout: 1000 })
.catch(e => console.log(e));
```### `disconnect()`
Disconnects from the server.
```javascript
messenger.disconnect();
```### `send(topic[, data])`
- {**string**} topic - topic name
- {**Object**} [data] - an object to sendSends a message (some object) to a topic. This method does not wait for any reply. A `MessengerServer` can receive the message if it is bound to the same topic name in advance.
```javascript
messenger.send('greeting', { hello: 'world' });
```### `req(topic[, data[, timeout]])`
- {**string**} topic - topic name
- {**Object**} [data] - an object to send
- {**number**} [timeout] - timeout (msec)Sends a message (some object) to a topic. This method waits for some reply unlike `send()`. If `timeout` (msec) is omitted, this method waits forever for some reply.
```javascript
const answer = await messenger.req('add', { x: 2, y: 3 })console.log(answer);
``````javascript
await messenger.req('add', { x: 2, y: 3 }, 5000)
.catch(e => console.log(e)); // Catch timeout error.
```### `subscribe(topic, listener)`
- {**string**} topic - topic name
- {**Function**} listener - a listener to receive published messagesSubscribes to messages on a topic.
```javascript
messenger.subscribe('news', data => console.log(data));
```### `unsubscribe(topic[, listener])`
Unsubscribes to messages on a topic. If listener is omitted, all listeners for the topic are cleared.
- {**string**} topic - topic name
- {**Function**} [listener] - a listener to receive published messages```javascript
const listener = data => console.log(data);
messenger.subscribe('news', listener);messenger.unsubscribe('news', listener);
```## MessengerServer API
### `constructor(name, [endpoint])`
- {**string**} name - unique name of the MessengerServer
- {**Object**} [endpoint] - an object that actually executes the `postMessage()````javascript
const messenger = new MessengerServer('server', self);
```The `name` is a unique name by which clients identify this MessengerServer. The `endpoint` is the object that actually executes the `postMessage()`. If omitted, it is assumed that `self` is set.
### `bind(topic, listener)`
- {**string**} topic - topic name
- {**Function**} listener - a listener to receive messagesBinds a listener to listen for messages on a topic. The topic names must be unique, no other listener than the first can bind on the same topic name. This method returns `true` or `false` as binding result.
```javascript
messenger.bind('greeting', data => console.log(data));messenger.bind('add', data => {
// Reply to client.
return data.x + data.y;
});
```### `publish(topic, data)`
- {**string**} topic - topic name
- {**Object**} data - an object to publishPublish a message (some object) to all subscribers on a topic. This method does not wait for reply from the subscribers, and also does not fail even there are no subscribers at all.
```javascript
messenger.publish('notification', 'The process completed successfully.');
```### `close()`
Closes all connections and shuts down the server.
```javascript
messenger.close();
```## Browser support
Chrome, Safari, Firefox, Edge
## License
MIT