1.3.1 • Published 3 years ago
redis-config-manager v1.3.1
redis-config-manager 
A thin nodejs API wrapper for redis used to store JSON serialized strings under hash subkeys.
Features:
- Keeps your redis instance root namespace clean by storing everything under one hash key, with subkeys as your main identifier
- Handles the JSON encode/decode cycle internally
- Event emitters let you set listeners as needed for handling errors the way you want
- Uses node-redis module under the hood for its redis client
- Uses redis-mock for local testing without a redis instance
Requirements:
Tested on NodeJS 12.x and higher
Installation:
Go into your
yarn add redis-config-manager
or
npm install redis-config-manager
Example
See test/unit/rcm.spec.js for more examples.
const RedisConfigManager = require('redis-config-manager');
const source = {
    label: 'rando-name',            // generic name for this instance used in testing
    hashKey: 'rando-key-suffix',   // Suffix used in the hash key storing the data
    client: {
        host: '127.0.0.1',
        port: 6379
        // any other redis client-specific parameters
    },
};
const RCM = new RedisConfigManager(source);
await RCM.init();
await RCM.setConfig('foo',{bar:'quux'});Methods & Properties:
| Signature | Description | Returns | async/Promise | Deprecated | 
|---|---|---|---|---|
| .init() | Initialize the manager, redis connection, active keys, etc | Yes | ||
| .setConfig(key,value) | JSON serializes js object of valueand writes/overwrites the string hash subkey ofkey | Boolean true | Yes | |
| .getConfig(key) | If the string of keyis a valid subkey to the hash, will return the JSON.parse value of the string value stored | Object | Yes | |
| .getConfigs(keys) | Provided an array of strings via the keysargument, will return an array of results in matching order as the keys.  When a non-null value exists for a key, JSON.parse is attempted | Array | Yes | |
| .delConfig(key) | Attempts to delete string subkey of keyfrom the hash.  Missing keys produce no error | Boolean | Yes | |
| .hasConfigKey(key) | Checks the locally stored Set of .activeConfigKeysfor a existence of a key | Boolean | No | |
| .keyRefresh() | Forces a refresh of .activeConfigKeysoutside of the predefined refresh intervals | undefined | Yes | |
| .activeConfigKeys | Returns a Set of most recently refereshed key names | Set | No | 
source object properties
All are optional unless otherwise noted
| Property | Type | Required | Default | Description | Deprecated | 
|---|---|---|---|---|---|
| label | String | NO-LABEL RedisConfigManager Instance | Readable identifier for debugging. | ||
| hashKey | String | Yup | undefined | Suffix to prepended to hashKeyPrefix | |
| hashKeyPrefix | String | redis-config-manager: | Prefix for the hash key managed by this instance -- typically left as-is unless you have a pre-existing hash you want to use | ||
| fixtureData | Object | undefined | A simple/json-serializable object to be preloaded upon instantiation. See below for more detail. | ||
| listeners | Object | no-op&console | A key/function object for event listeners ofdebug,ready,error` | ||
| client | Object | {host:'127.0.0.1', port:6379} | Parameters for the node-redis client | ||
| client.module_override | Function | undefined | replaces built-in require('node_redis')(maybe a new branch, custom version you're using) | ||
| client.client_override | Function | undefined | Re-use an existing node_redisclient instance rather than using its own. (used during testing with redis-mock) | ||
| scanCount | String | 1000 | Number of subkeys scanned per HSCAN- see the count option for details | Deprecated in v1.2.x | |
| refreshInterval | Integer | 15000 | Number of milliseconds between key refreshes | 
Contributions & Development:
Install with dev packages and run yarn test or npm test
PRs are welcome.
###TODO: Write some todos.