https://github.com/moscajs/aedes-persistence
In-memory implementation of an Aedes persistence, with abstract tests
https://github.com/moscajs/aedes-persistence
aedes
Last synced: about 2 months ago
JSON representation
In-memory implementation of an Aedes persistence, with abstract tests
- Host: GitHub
- URL: https://github.com/moscajs/aedes-persistence
- Owner: moscajs
- License: mit
- Created: 2015-11-29T10:44:11.000Z (over 9 years ago)
- Default Branch: main
- Last Pushed: 2025-03-26T13:48:35.000Z (2 months ago)
- Last Synced: 2025-03-28T11:06:09.122Z (2 months ago)
- Topics: aedes
- Language: JavaScript
- Size: 138 KB
- Stars: 13
- Watchers: 9
- Forks: 22
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# aedes-persistence

[](https://snyk.io/test/github/moscajs/aedes-persistence)
[](https://coveralls.io/github/moscajs/aedes-persistence?branch=master)
[](https://www.npmjs.com/package/aedes-persistence)
[](https://www.npmjs.com/package/aedes-persistence)The spec for an [Aedes](http://npm.im/aedes) persistence, with abstract
tests and a fast in-memory implementation.* [Install](#install)
* [API](#api)
* [Implement another persistence](#implement)
* [License](#license)
## Install
To install aedes-persistence, simply use npm:```
npm install aedes-persistence --save
```*
persistence()
*instance.storeRetained()
*instance.createRetainedStream()
*instance.createRetainedStreamCombi()
*instance.addSubscriptions()
*instance.removeSubscriptions()
*instance.subscriptionsByClient()
*instance.countOffline()
*instance.subscriptionsByTopic()
*instance.cleanSubscriptions()
*instance.outgoingEnqueue()
*instance.outgoingEnqueueCombi()
*instance.outgoingUpdate()
*instance.outgoingClearMessageId()
*instance.outgoingStream()
*instance.incomingStorePacket()
*instance.incomingGetPacket()
*instance.incomingDelPacket()
*instance.putWill()
*instance.getWill()
*instance.delWill()
*instance.streamWill()
*instance.getClientList()
*instance.destroy()
-------------------------------------------------------
### persistence([opts])Creates a new instance of a persistence, that is already ready to
operate. The default implementation is in-memory only.-------------------------------------------------------
### instance.storeRetained(packet, callback(err))Store a retained message, calls the callback when it was saved.
-------------------------------------------------------
### instance.createRetainedStream(pattern)Return a stream that will load all retained messages matching the given
pattern (according to the MQTT spec) asynchronously. Deprecated.-------------------------------------------------------
### instance.createRetainedStreamCombi(patterns)Return a stream that will load all retained messages matching given
patterns (according to the MQTT spec) asynchronously.-------------------------------------------------------
### instance.addSubscriptions(client, subscriptions, callback(err, client))Add the given offline subscriptions for the given
[Client](https://github.com/moscajs/aedes#client). The client __must__
have connected with `clean: false`, as this is not checked here.
This is called when a client issue a SUBSCRIBE packet.`subscriptions` is in the same format of the `subscribe` property in the
[SUBSCRIBE](https://github.com/mqttjs/mqtt-packet#subscribe) packet:```js
[{
topic: 'hello/world',
qos: 1,
}, {
topic: 'hello/#',
qos: 2,
}]
```-------------------------------------------------------
### instance.removeSubscriptions(client, subscriptions, callback(err, client))The inverse of [`addSubscriptions`](#addSubscriptions) but subscriptions is an array of topic names.
-------------------------------------------------------
### instance.subscriptionsByClient(client, callback(err, subscriptions, client))Returns all the offline subscriptions for the given client. Called when
a client with `clean: false` connects to restore its subscriptions.`subscriptions` is in the same format of the `subscribe` property in the
[SUBSCRIBE](https://github.com/mqttjs/mqtt-packet#subscribe) packet:```js
[{
topic: 'hello/world',
qos: 1,
}, {
topic: 'hello/#',
qos: 2,
}]
```-------------------------------------------------------
### instance.countOffline(cb(err, numOfSubscriptions, numOfClients))Returns the number of offline subscriptions and the number of offline
clients.-------------------------------------------------------
### instance.subscriptionsByTopic(pattern, callback(err, subscriptions))Returns all the offline subscriptions matching the given pattern. Called when
a PUBLISH with `qos: 1` or `qos: 2` is received.The subscriptions are in the format:
```js
{
clientId: client.id,
topic: sub.topic,
qos: sub.qos
}
```-------------------------------------------------------
### instance.cleanSubscriptions(client, callback(err, client))Removes all offline subscriptions for a given client.
-------------------------------------------------------
### instance.outgoingEnqueue(subscription, packet, callback(err))Enqueue a potentially offline delivery. `subscription` is one of the
objects returned by [`subscriptionsByTopic`](#subscriptionsByTopic). Deprecated.-------------------------------------------------------
### instance.outgoingEnqueueCombi(subscriptions, packet, callback(err))Enqueue a potentially offline delivery. `subscriptions` is the whole subscriptions
objects returned by [`subscriptionsByTopic`](#subscriptionsByTopic).-------------------------------------------------------
### instance.outgoingUpdate(client, packet, callback(err))Called before a (potentially) offline packet is delivered, the caller
should update the `packet.messageId` before updating.-------------------------------------------------------
### instance.outgoingClearMessageId(client, packet, callback(err, packet))Removes a packet with the given `messageId` (passing a PUBACK is ok)
from the persistence. Passes back original packet to the callback.-------------------------------------------------------
### instance.outgoingStream(client)Return a stream that will load all offline messages for the given client asynchronously.
-------------------------------------------------------
### instance.incomingStorePacket(client, packet, cb(err, packet))Store an incoming packet for the given client. Used for QoS 2.
-------------------------------------------------------
### instance.incomingGetPacket(client, packet, cb(err, packet))Retrieve an incoming packet with the same `messageId` for the given client. Used for QoS 2.
-------------------------------------------------------
### instance.incomingDelPacket(client, packet, cb(err, packet))Deletes incoming packet with the same `messageId` for the given client. Used for QoS 2.
-------------------------------------------------------
### instance.putWill(client, packet, cb(err))Stores the will of a client. Used to support multi-broker environments
and to not lose wills in case of a crash.-------------------------------------------------------
### instance.getWill(client, packet, cb(err))Retrieves the will of a client. Used to support multi-broker environments
and to not lose wills in case of a crash.-------------------------------------------------------
### instance.delWill(client, packet, cb(err))Removes the will of a client. Used to support multi-broker environments
and to not lose wills in case of a crash.-------------------------------------------------------
### instance.streamWill(brokers)Streams all the wills for the given brokers. The brokers are in the
format:```js
{
mybroker: {
brokerId: 'mybroker'
}
}
```-------------------------------------------------------
### instance.getClientList(topic)Returns a stream which has all the clientIds subscribed to the
specified topicDestroy current persistence. Use callback `cb(err)` to catch errors if any
## Implement another persistenceA persistence needs to pass all tests defined in
[./abstract.js](./abstract.js). You can import and use that test suite
in the following manner:```js
const test = require('tape').test
const myperst = require('./')
const abs = require('aedes-persistence/abstract')abs({
test: test,
persistence: myperst
})
```If you require some async stuff before returning, a callback is also
supported:```js
const test = require('tape').test
const myperst = require('./')
const abs = require('aedes-persistence/abstract')
const clean = require('./clean') // invented moduleabs({
test: test,
buildEmitter: require('mymqemitter'), // optional
persistence: function build (cb) {
clean(function (err) {
cb(err, myperst())
})
}
})
```## Collaborators
* [__Gnought__](https://github.com/gnought)
## License
MIT