Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mcollina/mqemitter
An Opinionated Message Queue with an emitter-style API
https://github.com/mcollina/mqemitter
Last synced: 6 days ago
JSON representation
An Opinionated Message Queue with an emitter-style API
- Host: GitHub
- URL: https://github.com/mcollina/mqemitter
- Owner: mcollina
- License: isc
- Created: 2014-02-27T15:44:15.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2024-07-24T10:14:54.000Z (6 months ago)
- Last Synced: 2024-12-27T09:05:30.274Z (13 days ago)
- Language: JavaScript
- Size: 104 KB
- Stars: 144
- Watchers: 5
- Forks: 18
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# MQEmitter
![ci](https://github.com/mcollina/mqemitter/workflows/ci/badge.svg)
[![Known Vulnerabilities](https://snyk.io/test/github/mcollina/mqemitter/badge.svg)](https://snyk.io/test/github/mcollina/mqemitter)
[![js-standard-style](https://img.shields.io/badge/code%20style-standard-brightgreen.svg?style=flat)](http://standardjs.com/)\
[![Dependencies Status](https://david-dm.org/mcollina/mqemitter/status.svg)](https://david-dm.org/mcollina/mqemitter)
[![devDependencies Status](https://david-dm.org/mcollina/mqemitter/dev-status.svg)](https://david-dm.org/mcollina/mqemitter?type=dev)\
[![NPM version](https://img.shields.io/npm/v/mqemitter.svg?style=flat)](https://www.npmjs.com/mqemitter)
[![NPM downloads](https://img.shields.io/npm/dm/mqemitter.svg?style=flat)](https://www.npmjs.com/mqemitter)An Opinionated Message Queue with an emitter-style API, but with callbacks.
If you need a multi process MQEmitter, check out the table below:
- [mqemitter-redis]: Redis-powered mqemitter
- [mqemitter-mongodb]: Mongodb based mqemitter
- [mqemitter-child-process]: Share the same mqemitter between a hierarchy of child processes
- [mqemitter-cs]: Expose a MQEmitter via a simple client/server protocol
- [mqemitter-p2p]: A P2P implementation of MQEmitter, based on HyperEmitter and a Merkle DAG
- [mqemitter-aerospike]: Aerospike mqemitter## Installation
```sh
npm install mqemitter
```## Examples
```js
const mq = require('mqemitter')
const emitter = mq({ concurrency: 5 })
const messageemitter.on('hello world', function (message, cb) {
// call callback when you are done
// do not pass any errors, the emitter cannot handle it.
cb()
})// topic is mandatory
message = { topic: 'hello world', payload: 'or any other fields' }
emitter.emit(message, function () {
// emitter will never return an error
})
```## API
- [new MQEmitter ([options])](#new-mqemitter-options)
- [emitter.emit (message, callback)](#emitteremit-message-callback)
- [emitter.on (topic, listener, [callback])](#emitteron-topic-listener-callback)
- [emitter.removeListener (topic, listener, [callback])](#emitterremovelistener-topic-listener-callback)
- [emitter.close (callback)](#emitterclose-callback)## new MQEmitter ([options])
- options ``
- `concurrency` `` maximum number of concurrent messages that can be on concurrent delivery. __Default__: `0`
- `wildcardOne` `` a char to use for matching exactly one _non-empty_ level word. __Default__: `+`
- `wildcardSome` `` a char to use for matching multiple level wildcards. __Default__: #`
- `matchEmptyLevels` `` If true then `wildcardOne` also matches an empty word. __Default__: `true`
- `separator` `` a separator character to use for separating words. __Default__: `/`Create a new MQEmitter class.
MQEmitter is the class and function exposed by this module.
It can be created by `MQEmitter()` or using `new MQEmitter()`.For more information on wildcards, see [this explanation](#wildcards) or [Qlobber](https://www.npmjs.com/qlobber).
## emitter.emit (message, callback)
- `message` ``
- `callback` `` `(error) => void`
- error `` | `null`Emit the given message, which must have a `topic` property, which can contain wildcards as defined on creation.
## emitter.on (topic, listener, [callback])
- `topic` ``
- `listener` `` `(message, done) => void`
- `callback` `` `() => void`Add the given listener to the passed topic. Topic can contain wildcards, as defined on creation.
The `listener` __must never error__ and `done` must not be called with an __`err`__ object.
`callback` will be called when the event subscribe is done correctly.
## emitter.removeListener (topic, listener, [callback])
The inverse of `on`.
## emitter.close (callback)
- `callback` `` `() => void`
Close the given emitter. After, all writes will return an error.
## Wildcards
__MQEmitter__ supports the use of wildcards: every topic is splitted according to `separator`.
The wildcard character `+` matches exactly _non-empty_ one word:
```js
const mq = require('mqemitter')
const emitter = mq()emitter.on('hello/+/world', function(message, cb) {
// will ONLY capture { topic: 'hello/my/world', 'something': 'more' }
console.log(message)
cb()
})
emitter.on('hello/+', function(message, cb) {
// will not be called
console.log(message)
cb()
})emitter.emit({ topic: 'hello/my/world', something: 'more' })
emitter.emit({ topic: 'hello//world', something: 'more' })
```The wildcard character `+` matches one word:
```js
const mq = require('mqemitter')
const emitter = mq({ matchEmptyLevels: true })emitter.on('hello/+/world', function(message, cb) {
// will capture { topic: 'hello/my/world', 'something': 'more' }
// and capture { topic: 'hello//world', 'something': 'more' }
console.log(message)
cb()
})emitter.on('hello/+', function(message, cb) {
// will not be called
console.log(message)
cb()
})emitter.emit({ topic: 'hello/my/world', something: 'more' })
emitter.emit({ topic: 'hello//world', something: 'more' })
```The wildcard character `#` matches zero or more words:
```js
const mq = require('mqemitter')
const emitter = mq()emitter.on('hello/#', function(message, cb) {
// this will print { topic: 'hello/my/world', 'something': 'more' }
console.log(message)
cb()
})emitter.on('#', function(message, cb) {
// this will print { topic: 'hello/my/world', 'something': 'more' }
console.log(message)
cb()
})emitter.on('hello/my/world/#', function(message, cb) {
// this will print { topic: 'hello/my/world', 'something': 'more' }
console.log(message)
cb()
})emitter.emit({ topic: 'hello/my/world', something: 'more' })
```Of course, you can mix `#` and `+` in the same subscription.
## LICENSE
MIT
[mqemitter-redis]: https://www.npmjs.com/mqemitter-redis
[mqemitter-mongodb]: https://www.npmjs.com/mqemitter-mongodb
[mqemitter-child-process]: https://www.npmjs.com/mqemitter-child-process
[mqemitter-cs]: https://www.npmjs.com/mqemitter-cs
[mqemitter-p2p]: https://www.npmjs.com/mqemitter-p2p
[mqemitter-aerospike]: https://www.npmjs.com/mqemitter-aerospike