woonplan-packages-redishelper 1.0.23 → 1.0.27

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/data.ts ADDED
@@ -0,0 +1,77 @@
1
+ import { Redis } from "ioredis"
2
+ import { getMessageReponseKey } from "./utils"
3
+ import { sendMessageToStream } from "./setters"
4
+ import { RedisMessage } from "."
5
+
6
+ const getOrRequestKey = ( client:Redis, key:string, service:string ) => new Promise((resolve, reject) => {
7
+ client.get( key )
8
+ .then(
9
+ ( result ) => {
10
+ if( result ) resolve( result );
11
+ if( !result ){
12
+ return requestAndWaitForKey( client, key, service )
13
+ }
14
+ }
15
+ )
16
+ .then(
17
+ (result) => resolve( result )
18
+ )
19
+ .catch(
20
+ (error) => {
21
+ console.log( error );
22
+ resolve( null )
23
+ }
24
+ )
25
+ })
26
+
27
+ const requestAndWaitForKey = (
28
+ client:Redis,
29
+ key:string,
30
+ service:string,
31
+ ) => new Promise((resolve, reject) => {
32
+ service = capitalizeFirstLetter( service );
33
+ // send message for list to be created and then block untill we have a list
34
+ client.xadd( `keyRequestedFrom${service}Service`, '*', 'key', key )
35
+
36
+ sendMessageToStream( client, `keyRequestedFrom${service}Service`, {
37
+ key : key
38
+ } as RedisMessage )
39
+ .then(
40
+ (messageid:string) => {
41
+ // subscribing to keyspace is an option, but it increases CPU usage. First trying this way
42
+ return subscribeToMessageResponse( client, messageid )
43
+ }
44
+ ).then(
45
+ (result) => resolve( result )
46
+ ).catch(
47
+ () => resolve( null )
48
+ )
49
+ })
50
+
51
+ const subscribeToMessageResponse = ( client:Redis, messageid:string ) => client.subscribe( getMessageReponseKey( messageid ) )
52
+
53
+ const publishMessageResponse = ( client:Redis, messageid:string, message:string ) => client.publish( getMessageReponseKey( messageid ), message )
54
+
55
+
56
+ const requestAndWaitForList = (
57
+ client:Redis,
58
+ service:string,
59
+ listname:string,
60
+ listsubject:string,
61
+ props = {}
62
+ ,{
63
+
64
+ }) => new Promise((resolve) => {
65
+ service = capitalizeFirstLetter( service );
66
+
67
+ // send message for list to be created and then block untill we have a list
68
+ client.xadd( `listRequestedFrom${service}Service`, '*', 'listname', listname, 'listsubject', listsubject, 'props', JSON.stringify( props ))
69
+ .then(
70
+ () => resolve( client.blmove( listname, listname, 'RIGHT', 'LEFT', 2) )
71
+ )
72
+ })
73
+
74
+ const capitalizeFirstLetter = (string:string) => string.charAt(0).toUpperCase() + string.slice(1)
75
+
76
+
77
+ export { getOrRequestKey, requestAndWaitForList, publishMessageResponse, subscribeToMessageResponse }
package/dist/data.d.ts ADDED
@@ -0,0 +1,6 @@
1
+ import { Redis } from "ioredis";
2
+ declare const getOrRequestKey: (client: Redis, key: string, service: string) => Promise<unknown>;
3
+ declare const subscribeToMessageResponse: (client: Redis, messageid: string) => Promise<number>;
4
+ declare const publishMessageResponse: (client: Redis, messageid: string, message: string) => Promise<number>;
5
+ declare const requestAndWaitForList: (client: Redis, service: string, listname: string, listsubject: string, props: {} | undefined, {}: {}) => Promise<unknown>;
6
+ export { getOrRequestKey, requestAndWaitForList, publishMessageResponse, subscribeToMessageResponse };
package/dist/data.js ADDED
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.subscribeToMessageResponse = exports.publishMessageResponse = exports.requestAndWaitForList = exports.getOrRequestKey = void 0;
4
+ var utils_1 = require("./utils");
5
+ var setters_1 = require("./setters");
6
+ var getOrRequestKey = function (client, key, service) { return new Promise(function (resolve, reject) {
7
+ client.get(key)
8
+ .then(function (result) {
9
+ if (result)
10
+ resolve(result);
11
+ if (!result) {
12
+ return requestAndWaitForKey(client, key, service);
13
+ }
14
+ })
15
+ .then(function (result) { return resolve(result); })
16
+ .catch(function (error) {
17
+ console.log(error);
18
+ resolve(null);
19
+ });
20
+ }); };
21
+ exports.getOrRequestKey = getOrRequestKey;
22
+ var requestAndWaitForKey = function (client, key, service) { return new Promise(function (resolve, reject) {
23
+ service = capitalizeFirstLetter(service);
24
+ // send message for list to be created and then block untill we have a list
25
+ client.xadd("keyRequestedFrom".concat(service, "Service"), '*', 'key', key);
26
+ (0, setters_1.sendMessageToStream)(client, "keyRequestedFrom".concat(service, "Service"), {
27
+ key: key
28
+ })
29
+ .then(function (messageid) {
30
+ // subscribing to keyspace is an option, but it increases CPU usage. First trying this way
31
+ return subscribeToMessageResponse(client, messageid);
32
+ }).then(function (result) { return resolve(result); }).catch(function () { return resolve(null); });
33
+ }); };
34
+ var subscribeToMessageResponse = function (client, messageid) { return client.subscribe((0, utils_1.getMessageReponseKey)(messageid)); };
35
+ exports.subscribeToMessageResponse = subscribeToMessageResponse;
36
+ var publishMessageResponse = function (client, messageid, message) { return client.publish((0, utils_1.getMessageReponseKey)(messageid), message); };
37
+ exports.publishMessageResponse = publishMessageResponse;
38
+ var requestAndWaitForList = function (client, service, listname, listsubject, props, _a) {
39
+ if (props === void 0) { props = {}; }
40
+ return new Promise(function (resolve) {
41
+ service = capitalizeFirstLetter(service);
42
+ // send message for list to be created and then block untill we have a list
43
+ client.xadd("listRequestedFrom".concat(service, "Service"), '*', 'listname', listname, 'listsubject', listsubject, 'props', JSON.stringify(props))
44
+ .then(function () { return resolve(client.blmove(listname, listname, 'RIGHT', 'LEFT', 2)); });
45
+ });
46
+ };
47
+ exports.requestAndWaitForList = requestAndWaitForList;
48
+ var capitalizeFirstLetter = function (string) { return string.charAt(0).toUpperCase() + string.slice(1); };
@@ -0,0 +1,5 @@
1
+ import { Redis } from "ioredis";
2
+ declare const getOrRequestKey: (client: Redis, key: string, service: string) => Promise<unknown>;
3
+ declare const subscribeToMessageResponse: (client: Redis, messageid: string) => Promise<number>;
4
+ declare const requestAndWaitForList: (client: Redis, service: string, listname: string, listsubject: string, props: {} | undefined, {}: {}) => Promise<unknown>;
5
+ export { getOrRequestKey, requestAndWaitForList, subscribeToMessageResponse };
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.subscribeToMessageResponse = exports.requestAndWaitForList = exports.getOrRequestKey = void 0;
4
+ var utils_1 = require("./utils");
5
+ var getOrRequestKey = function (client, key, service) { return new Promise(function (resolve, reject) {
6
+ client.get(key)
7
+ .then(function (result) {
8
+ if (result)
9
+ resolve(result);
10
+ if (!result) {
11
+ return requestAndWaitForKey(client, key, service);
12
+ }
13
+ })
14
+ .then(function (result) { return resolve(result); })
15
+ .catch(function (error) {
16
+ console.log(error);
17
+ resolve(null);
18
+ });
19
+ }); };
20
+ exports.getOrRequestKey = getOrRequestKey;
21
+ var requestAndWaitForKey = function (client, key, service) { return new Promise(function (resolve) {
22
+ service = capitalizeFirstLetter(service);
23
+ client.xadd("keyRequestedFrom".concat(service, "Service"), '*', 'key', key)
24
+ .then(function (messageid) {
25
+ // create a key to listen to, the key contains the message we just created;
26
+ return subscribeToMessageResponse(client, messageid);
27
+ }).then(function (result) { return resolve(result); }).catch(function () { return resolve(null); });
28
+ }); };
29
+ var subscribeToMessageResponse = function (client, messageid) { return client.subscribe((0, utils_1.getMessageReponseKey)(messageid)); };
30
+ exports.subscribeToMessageResponse = subscribeToMessageResponse;
31
+ var requestAndWaitForList = function (client, service, listname, listsubject, props, _a) {
32
+ if (props === void 0) { props = {}; }
33
+ return new Promise(function (resolve) {
34
+ service = capitalizeFirstLetter(service);
35
+ // send message for list to be created and then block untill we have a list
36
+ client.xadd("listRequestedFrom".concat(service, "Service"), '*', 'listname', listname, 'listsubject', listsubject, 'props', JSON.stringify(props))
37
+ .then(function () { return resolve(client.blmove(listname, listname, 'RIGHT', 'LEFT', 2)); });
38
+ });
39
+ };
40
+ exports.requestAndWaitForList = requestAndWaitForList;
41
+ var capitalizeFirstLetter = function (string) { return string.charAt(0).toUpperCase() + string.slice(1); };
package/dist/index.d.ts CHANGED
@@ -1,5 +1,6 @@
1
1
  import { Redis } from "ioredis";
2
2
  import { RedisMessage } from "./types";
3
+ import { sendMessageToStream, publishMessageResponse } from "./setters";
4
+ import { getOrRequestKey } from "./getters";
3
5
  declare const listenToStream: (client: Redis, groupname: string, channelname: string, consumername: string, callback: Function) => Promise<boolean>;
4
- declare const sendMessageToStream: (client: Redis, channelname: string, message: RedisMessage) => void;
5
- export { listenToStream, RedisMessage, sendMessageToStream };
6
+ export { listenToStream, RedisMessage, sendMessageToStream, publishMessageResponse, getOrRequestKey };
package/dist/index.js CHANGED
@@ -1,15 +1,11 @@
1
1
  "use strict";
2
- var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
3
- if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
4
- if (ar || !(i in from)) {
5
- if (!ar) ar = Array.prototype.slice.call(from, 0, i);
6
- ar[i] = from[i];
7
- }
8
- }
9
- return to.concat(ar || Array.prototype.slice.call(from));
10
- };
11
2
  Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.sendMessageToStream = exports.listenToStream = void 0;
3
+ exports.getOrRequestKey = exports.publishMessageResponse = exports.sendMessageToStream = exports.listenToStream = void 0;
4
+ var setters_1 = require("./setters");
5
+ Object.defineProperty(exports, "sendMessageToStream", { enumerable: true, get: function () { return setters_1.sendMessageToStream; } });
6
+ Object.defineProperty(exports, "publishMessageResponse", { enumerable: true, get: function () { return setters_1.publishMessageResponse; } });
7
+ var getters_1 = require("./getters");
8
+ Object.defineProperty(exports, "getOrRequestKey", { enumerable: true, get: function () { return getters_1.getOrRequestKey; } });
13
9
  var listenToStream = function (client, groupname, channelname, consumername, callback) { return new Promise(function (resolve, reject) {
14
10
  createGroup(client, groupname, channelname).then(function () {
15
11
  listenForMessage(client, groupname, channelname, consumername, callback);
@@ -22,18 +18,12 @@ var listenToStream = function (client, groupname, channelname, consumername, cal
22
18
  exports.listenToStream = listenToStream;
23
19
  var createGroup = function (client, groupname, channelname) { return new Promise(function (resolve, reject) {
24
20
  client.xgroup('CREATE', channelname, groupname, '$', 'MKSTREAM').then(function () { return resolve(true); }).catch(function (error) {
21
+ // group exists
25
22
  if (error.message.includes('BUSYGROUP'))
26
23
  return resolve(true);
27
24
  reject(error);
28
25
  });
29
26
  }); };
30
- var reduceArraysToArray = function (toArray, fromArray) { return toArray.concat(fromArray); };
31
- var redisMessageToArrayOfKeysAndValues = function (message) { return Object.keys(message).map(function (key) { return [key, message[key]]; }); };
32
- var sendMessageToStream = function (client, channelname, message) {
33
- var arrayOfKeysAndValues = redisMessageToArrayOfKeysAndValues(message).reduce(reduceArraysToArray, []);
34
- client.xadd.apply(client, __spreadArray([channelname, '*'], arrayOfKeysAndValues, false));
35
- };
36
- exports.sendMessageToStream = sendMessageToStream;
37
27
  var listenForMessage = function (client, groupname, channelname, consumername, callback, lastId) {
38
28
  if (lastId === void 0) { lastId = "$"; }
39
29
  console.log("listening to ".concat(channelname, " as ").concat(consumername));
@@ -51,7 +41,7 @@ var listenForMessage = function (client, groupname, channelname, consumername, c
51
41
  return;
52
42
  messagedata[key] = keysandvalues[n + 1];
53
43
  });
54
- callback(messagedata).catch(function (error) {
44
+ callback(messagedata, id).catch(function (error) {
55
45
  console.log(error);
56
46
  }).finally(function () {
57
47
  // not sure yet? For now always acknowledge
@@ -0,0 +1,5 @@
1
+ import { Redis } from "ioredis";
2
+ import { RedisMessage } from "./types";
3
+ declare const publishMessageResponse: (client: Redis, messageid: string, message: string) => Promise<number>;
4
+ declare const sendMessageToStream: (client: Redis, channelname: string, message: RedisMessage) => Promise<string>;
5
+ export { publishMessageResponse, sendMessageToStream };
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
3
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
4
+ if (ar || !(i in from)) {
5
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
6
+ ar[i] = from[i];
7
+ }
8
+ }
9
+ return to.concat(ar || Array.prototype.slice.call(from));
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.sendMessageToStream = exports.publishMessageResponse = void 0;
13
+ var utils_1 = require("./utils");
14
+ var publishMessageResponse = function (client, messageid, message) { return client.publish((0, utils_1.getMessageReponseKey)(messageid), message); };
15
+ exports.publishMessageResponse = publishMessageResponse;
16
+ var sendMessageToStream = function (client, channelname, message) {
17
+ var arrayOfKeysAndValues = (0, utils_1.redisMessageToArrayOfKeysAndValues)(message).reduce(utils_1.reduceArraysToArray, []);
18
+ console.log('sendings message', channelname);
19
+ return client.xadd.apply(client, __spreadArray([channelname, '*'], arrayOfKeysAndValues, false));
20
+ };
21
+ exports.sendMessageToStream = sendMessageToStream;
@@ -0,0 +1,5 @@
1
+ import { RedisMessage } from "./types";
2
+ declare const getMessageReponseKey: (messageid: string) => string;
3
+ declare const reduceArraysToArray: (toArray: any[], fromArray: []) => any[];
4
+ declare const redisMessageToArrayOfKeysAndValues: (message: RedisMessage) => any[];
5
+ export { getMessageReponseKey, redisMessageToArrayOfKeysAndValues, reduceArraysToArray };
package/dist/utils.js ADDED
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.reduceArraysToArray = exports.redisMessageToArrayOfKeysAndValues = exports.getMessageReponseKey = void 0;
4
+ var messagePrefix = "messageresponse";
5
+ var getMessageReponseKey = function (messageid) { return messagePrefix + messageid; };
6
+ exports.getMessageReponseKey = getMessageReponseKey;
7
+ var reduceArraysToArray = function (toArray, fromArray) { return toArray.concat(fromArray); };
8
+ exports.reduceArraysToArray = reduceArraysToArray;
9
+ var redisMessageToArrayOfKeysAndValues = function (message) { return Object.keys(message).map(function (key) { return [key, message[key]]; }); };
10
+ exports.redisMessageToArrayOfKeysAndValues = redisMessageToArrayOfKeysAndValues;
package/getters.ts ADDED
@@ -0,0 +1,69 @@
1
+ import { Redis } from "ioredis"
2
+ import { getMessageReponseKey } from "./utils"
3
+ const getOrRequestKey = ( client:Redis, key:string, service:string ) => new Promise((resolve, reject) => {
4
+ client.get( key )
5
+ .then(
6
+ ( result ) => {
7
+ if( result ) resolve( result );
8
+ if( !result ){
9
+ return requestAndWaitForKey( client, key, service )
10
+ }
11
+ }
12
+ )
13
+ .then(
14
+ (result) => resolve( result )
15
+ )
16
+ .catch(
17
+ (error) => {
18
+ console.log( error );
19
+ resolve( null )
20
+ }
21
+ )
22
+ })
23
+
24
+ const requestAndWaitForKey = (
25
+ client:Redis,
26
+ key:string,
27
+ service:string,
28
+ ) => new Promise((resolve) => {
29
+ service = capitalizeFirstLetter( service );
30
+
31
+ client.xadd( `keyRequestedFrom${service}Service`, '*', 'key', key )
32
+ .then(
33
+ (messageid:string) => {
34
+ // create a key to listen to, the key contains the message we just created;
35
+ return subscribeToMessageResponse( client, messageid )
36
+ }
37
+ ).then(
38
+ (result) => resolve( result )
39
+ ).catch(
40
+ () => resolve( null )
41
+ )
42
+ })
43
+
44
+
45
+ const subscribeToMessageResponse = ( client:Redis, messageid:string ) => client.subscribe( getMessageReponseKey( messageid ) )
46
+
47
+
48
+ const requestAndWaitForList = (
49
+ client:Redis,
50
+ service:string,
51
+ listname:string,
52
+ listsubject:string,
53
+ props = {}
54
+ ,{
55
+
56
+ }) => new Promise((resolve) => {
57
+ service = capitalizeFirstLetter( service );
58
+
59
+ // send message for list to be created and then block untill we have a list
60
+ client.xadd( `listRequestedFrom${service}Service`, '*', 'listname', listname, 'listsubject', listsubject, 'props', JSON.stringify( props ))
61
+ .then(
62
+ () => resolve( client.blmove( listname, listname, 'RIGHT', 'LEFT', 2) )
63
+ )
64
+ })
65
+
66
+ const capitalizeFirstLetter = (string:string) => string.charAt(0).toUpperCase() + string.slice(1)
67
+
68
+
69
+ export { getOrRequestKey, requestAndWaitForList, subscribeToMessageResponse }
package/index.ts CHANGED
@@ -1,5 +1,7 @@
1
1
  import { Redis } from "ioredis"
2
2
  import { RedisMessage } from "./types"
3
+ import { sendMessageToStream, publishMessageResponse } from "./setters"
4
+ import { getOrRequestKey } from "./getters"
3
5
 
4
6
  const listenToStream = ( client:Redis, groupname:string, channelname:string, consumername:string, callback:Function ):Promise<boolean> => new Promise((resolve,reject) => {
5
7
  createGroup( client, groupname, channelname ).then(
@@ -20,6 +22,7 @@ const createGroup = ( client:Redis, groupname:string, channelname:string ):Promi
20
22
  () => resolve( true )
21
23
  ).catch(
22
24
  ( error:Error ) => {
25
+ // group exists
23
26
  if( error.message.includes('BUSYGROUP'))
24
27
  return resolve( true );
25
28
 
@@ -28,16 +31,6 @@ const createGroup = ( client:Redis, groupname:string, channelname:string ):Promi
28
31
  )
29
32
  })
30
33
 
31
- const reduceArraysToArray = ( toArray:any[], fromArray:[] ) => toArray.concat( fromArray )
32
- const redisMessageToArrayOfKeysAndValues = ( message:RedisMessage ):any[] => Object.keys(message).map((key) => [ key, message[key]]);
33
-
34
- const sendMessageToStream = ( client:Redis, channelname:string, message:RedisMessage) => {
35
- const arrayOfKeysAndValues = redisMessageToArrayOfKeysAndValues( message ).reduce( reduceArraysToArray, [] );
36
- client.xadd( channelname, '*', ...arrayOfKeysAndValues )
37
- }
38
-
39
-
40
-
41
34
  const listenForMessage = ( client:Redis, groupname:string, channelname:string, consumername:string, callback:Function, lastId = "$" ) => {
42
35
  console.log( `listening to ${channelname} as ${consumername}`)
43
36
  client.xreadgroup('GROUP', groupname, consumername, 'COUNT', 1, 'BLOCK', 0, 'STREAMS', channelname, '>')
@@ -60,7 +53,7 @@ const listenForMessage = ( client:Redis, groupname:string, channelname:string, c
60
53
  messagedata[key] = keysandvalues[n+1];
61
54
  })
62
55
 
63
- callback( messagedata ).catch(
56
+ callback( messagedata, id ).catch(
64
57
  ( error:Error ) => {
65
58
  console.log( error );
66
59
  }
@@ -84,4 +77,4 @@ const listenForMessage = ( client:Redis, groupname:string, channelname:string, c
84
77
  })
85
78
  }
86
79
 
87
- export { listenToStream, RedisMessage, sendMessageToStream }
80
+ export { listenToStream, RedisMessage, sendMessageToStream, publishMessageResponse, getOrRequestKey }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "woonplan-packages-redishelper",
3
- "version": "1.0.23",
3
+ "version": "1.0.27",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -16,5 +16,8 @@
16
16
  "@types/ioredis": "^4.28.4",
17
17
  "@types/node": "^16.11.13",
18
18
  "typescript": "^4.2.3"
19
+ },
20
+ "dependencies": {
21
+ "@types/ioredis": "^4.28.5"
19
22
  }
20
23
  }
package/setters.ts ADDED
@@ -0,0 +1,17 @@
1
+
2
+ import { Redis } from "ioredis"
3
+ import { RedisMessage } from "./types"
4
+ import { getMessageReponseKey, redisMessageToArrayOfKeysAndValues, reduceArraysToArray } from "./utils"
5
+
6
+ const publishMessageResponse = ( client:Redis, messageid:string, message:string ) => client.publish( getMessageReponseKey( messageid ), message )
7
+
8
+
9
+ const sendMessageToStream = ( client:Redis, channelname:string, message:RedisMessage) => {
10
+ const arrayOfKeysAndValues = redisMessageToArrayOfKeysAndValues( message ).reduce( reduceArraysToArray, [] );
11
+ console.log( 'sendings message', channelname )
12
+ return client.xadd( channelname, '*', ...arrayOfKeysAndValues )
13
+ }
14
+
15
+
16
+
17
+ export { publishMessageResponse, sendMessageToStream }
package/utils.ts ADDED
@@ -0,0 +1,8 @@
1
+ import { RedisMessage } from "./types"
2
+ const messagePrefix:string = "messageresponse";
3
+
4
+ const getMessageReponseKey = ( messageid:string ) => messagePrefix + messageid
5
+ const reduceArraysToArray = ( toArray:any[], fromArray:[] ) => toArray.concat( fromArray )
6
+ const redisMessageToArrayOfKeysAndValues = ( message:RedisMessage ):any[] => Object.keys(message).map((key) => [ key, message[key]]);
7
+
8
+ export { getMessageReponseKey, redisMessageToArrayOfKeysAndValues, reduceArraysToArray };