woonplan-packages-redishelper 1.0.25 → 1.0.29
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 +77 -0
- package/dist/data.d.ts +6 -0
- package/dist/data.js +48 -0
- package/dist/getters.d.ts +5 -0
- package/dist/getters.js +41 -0
- package/dist/index.d.ts +3 -2
- package/dist/index.js +10 -19
- package/dist/setters.d.ts +5 -0
- package/dist/setters.js +21 -0
- package/dist/utils.d.ts +5 -0
- package/dist/utils.js +10 -0
- package/getters.ts +69 -0
- package/index.ts +8 -14
- package/package.json +1 -1
- package/setters.ts +17 -0
- package/utils.ts +8 -0
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 };
|
package/dist/getters.js
ADDED
|
@@ -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
|
-
|
|
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,19 +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
|
-
console.log('sendings message', channelname);
|
|
35
|
-
client.xadd.apply(client, __spreadArray([channelname, '*'], arrayOfKeysAndValues, false));
|
|
36
|
-
};
|
|
37
|
-
exports.sendMessageToStream = sendMessageToStream;
|
|
38
27
|
var listenForMessage = function (client, groupname, channelname, consumername, callback, lastId) {
|
|
39
28
|
if (lastId === void 0) { lastId = "$"; }
|
|
40
29
|
console.log("listening to ".concat(channelname, " as ").concat(consumername));
|
|
@@ -52,8 +41,10 @@ var listenForMessage = function (client, groupname, channelname, consumername, c
|
|
|
52
41
|
return;
|
|
53
42
|
messagedata[key] = keysandvalues[n + 1];
|
|
54
43
|
});
|
|
55
|
-
callback(messagedata).catch(function (error) {
|
|
44
|
+
callback(messagedata, id).catch(function (error) {
|
|
56
45
|
console.log(error);
|
|
46
|
+
// in case somebody was subscribed to the response;
|
|
47
|
+
(0, setters_1.publishMessageResponse)(client, id, '');
|
|
57
48
|
}).finally(function () {
|
|
58
49
|
// not sure yet? For now always acknowledge
|
|
59
50
|
client.xack(channelname, groupname, id).then(function () {
|
|
@@ -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 };
|
package/dist/setters.js
ADDED
|
@@ -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;
|
package/dist/utils.d.ts
ADDED
|
@@ -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, subscribeToMessageResponse } 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,17 +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
|
-
console.log( 'sendings message', channelname )
|
|
37
|
-
client.xadd( channelname, '*', ...arrayOfKeysAndValues )
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
34
|
const listenForMessage = ( client:Redis, groupname:string, channelname:string, consumername:string, callback:Function, lastId = "$" ) => {
|
|
43
35
|
console.log( `listening to ${channelname} as ${consumername}`)
|
|
44
36
|
client.xreadgroup('GROUP', groupname, consumername, 'COUNT', 1, 'BLOCK', 0, 'STREAMS', channelname, '>')
|
|
@@ -61,9 +53,11 @@ const listenForMessage = ( client:Redis, groupname:string, channelname:string, c
|
|
|
61
53
|
messagedata[key] = keysandvalues[n+1];
|
|
62
54
|
})
|
|
63
55
|
|
|
64
|
-
callback( messagedata ).catch(
|
|
56
|
+
callback( messagedata, id ).catch(
|
|
65
57
|
( error:Error ) => {
|
|
66
|
-
console.log( error );
|
|
58
|
+
console.log( error );
|
|
59
|
+
// in case somebody was subscribed to the response;
|
|
60
|
+
publishMessageResponse( client, id, '' );
|
|
67
61
|
}
|
|
68
62
|
).finally(()=>{
|
|
69
63
|
// not sure yet? For now always acknowledge
|
|
@@ -85,4 +79,4 @@ const listenForMessage = ( client:Redis, groupname:string, channelname:string, c
|
|
|
85
79
|
})
|
|
86
80
|
}
|
|
87
81
|
|
|
88
|
-
export { listenToStream, RedisMessage, sendMessageToStream }
|
|
82
|
+
export { listenToStream, RedisMessage, sendMessageToStream, publishMessageResponse, getOrRequestKey, subscribeToMessageResponse }
|
package/package.json
CHANGED
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 };
|