Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/haraka/haraka-plugin-redis
redis support for Haraka plugins
https://github.com/haraka/haraka-plugin-redis
haraka plugin redis
Last synced: about 2 months ago
JSON representation
redis support for Haraka plugins
- Host: GitHub
- URL: https://github.com/haraka/haraka-plugin-redis
- Owner: haraka
- License: mit
- Created: 2016-10-09T18:50:51.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2024-04-22T06:43:20.000Z (9 months ago)
- Last Synced: 2024-04-23T09:54:21.753Z (8 months ago)
- Topics: haraka, plugin, redis
- Language: JavaScript
- Homepage: https://www.npmjs.com/package/haraka-plugin-redis
- Size: 64.5 KB
- Stars: 3
- Watchers: 5
- Forks: 11
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# haraka-plugin-redis
[![Build Status][ci-img]][ci-url]
[![Code Climate][clim-img]][clim-url]Connects to a redis instance. By default it stores a `redis` connection handle at `server.notes.redis`. See below to get a custom DB handle attached to another database.
## Config
The `redis.ini` file has the following sections (defaults shown):
### [server]
```ini
; host=127.0.0.1
; port=6379
```### [pubsub]
```ini
; host=127.0.0.1
; port=6379
```Publish & Subscribe are DB agnostic and thus have no db setting. If host and port and not defined, they default to the same as [socket] settings.
### [opts]
```ini
; see https://github.com/redis/node-redis/blob/HEAD/docs/client-configuration.md
; database=0
; password=battery-horse-staple
```Options specified in `redis.ini[opts]` are applied to the server config, the pubsub config, AND the configurations of any plugins that inherit this plugin. This is ideal if the redis server requires a password. Specify it once in [opts]. If other redis connections need a different value (such as a unique DB), they must specify it. For plugins, all options are stored in the plugins `[redis]` section of its config file.
## Usage (shared redis)
Use redis in your plugin like so:
```js
if (server.notes.redis) {
server.notes.redis.hGetAll(...);
// or any other redis command
}
```## Publish/Subscribe Usage
In your plugin:
```js
exports.results_init = function (next, connection) {
this.redis_subscribe(connection, () => {
connection.notes.redis.on('pmessage', (pattern, channel, message) => {
this.do_something_with_message(message, ...)
})
next()
})
}
// be nice to redis and disconnect
exports.hook_disconnect = function (next, connection) {
this.redis_unsubscribe(connection)
}
```## Custom Usage
This variation lets your plugin establish its own Redis connection,
optionally with a redis db ID. All redis config options must be listed in your plugins config file in the [redis] section.```js
exports.register = function () {
this.inherits('redis')this.cfg = this.config.get('my-plugin.ini')
// populate plugin.cfg.redis with defaults from redis.ini
this.merge_redis_ini()// cluster aware redis connection(s)
this.register_hook('init_master', 'init_redis_plugin')
this.register_hook('init_child', 'init_redis_plugin')
}
```When a db ID is specified in the [redis] section of a redis inheriting plugin, log messages like these will be emitted when Haraka starts:
```
[INFO] [-] [redis] connected to redis://172.16.15.16:6379 v3.2.6
[INFO] [-] [limit] connected to redis://172.16.15.16:6379/1 v3.2.6
[INFO] [-] [karma] connected to redis://172.16.15.16:6379/2 v3.2.6
[INFO] [-] [known-senders] connected to redis://172.16.15.16:6379/3 v3.2.6
```Notice the database ID numbers appended to each plugins redis connection
message.[ci-img]: https://github.com/haraka/haraka-plugin-redis/actions/workflows/ci.yml/badge.svg
[ci-url]: https://github.com/haraka/haraka-plugin-redis/actions/workflows/ci.yml
[clim-img]: https://codeclimate.com/github/haraka/haraka-plugin-redis/badges/gpa.svg
[clim-url]: https://codeclimate.com/github/haraka/haraka-plugin-redis