suanpan_node_sdk 2.2.4 → 2.2.5

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.
Files changed (123) hide show
  1. package/dist/api/index.d.ts +10 -10
  2. package/dist/api/index.js +56 -52
  3. package/dist/api/index.js.map +1 -1
  4. package/dist/core/common/constant.d.ts +6 -6
  5. package/dist/core/common/constant.js +50 -50
  6. package/dist/core/common/exec.d.ts +1 -1
  7. package/dist/core/common/exec.js +53 -53
  8. package/dist/core/common/log.d.ts +3 -3
  9. package/dist/core/common/log.js +15 -15
  10. package/dist/core/event/index.d.ts +6 -6
  11. package/dist/core/event/index.js +10 -10
  12. package/dist/core/logkit/index.d.ts +33 -33
  13. package/dist/core/logkit/index.js +125 -125
  14. package/dist/core/logkit/index.js.map +1 -1
  15. package/dist/core/message/channel.d.ts +7 -7
  16. package/dist/core/message/channel.js +2 -2
  17. package/dist/core/message/channelFactory.d.ts +4 -4
  18. package/dist/core/message/channelFactory.js +10 -10
  19. package/dist/core/message/index.d.ts +6 -6
  20. package/dist/core/message/index.js +22 -18
  21. package/dist/core/message/index.js.map +1 -1
  22. package/dist/core/message/message.d.ts +19 -19
  23. package/dist/core/message/message.js +59 -59
  24. package/dist/core/message/message.js.map +1 -1
  25. package/dist/core/message/messageBuilder.d.ts +12 -12
  26. package/dist/core/message/messageBuilder.js +50 -50
  27. package/dist/core/message/messageBuilder.js.map +1 -1
  28. package/dist/core/message/messageChain.d.ts +9 -9
  29. package/dist/core/message/messageChain.js +29 -29
  30. package/dist/core/message/messageListener.d.ts +4 -4
  31. package/dist/core/message/messageListener.js +11 -11
  32. package/dist/core/message/mq/index.d.ts +9 -9
  33. package/dist/core/message/mq/index.js +50 -50
  34. package/dist/core/message/mq/redis.d.ts +12 -12
  35. package/dist/core/message/mq/redis.js +101 -97
  36. package/dist/core/message/mq/redis.js.map +1 -1
  37. package/dist/core/parameter/commandArgs.d.ts +2 -2
  38. package/dist/core/parameter/commandArgs.js +22 -22
  39. package/dist/core/parameter/commandArgs.js.map +1 -1
  40. package/dist/core/parameter/environment.d.ts +86 -86
  41. package/dist/core/parameter/environment.js +103 -103
  42. package/dist/core/parameter/index.d.ts +7 -7
  43. package/dist/core/parameter/index.js +33 -33
  44. package/dist/core/script/script-babel/babel.d.ts +1 -1
  45. package/dist/core/script/script-babel/babel.js +23 -23
  46. package/dist/core/script/script-babel/plugin.d.ts +7 -7
  47. package/dist/core/script/script-babel/plugin.js +16 -16
  48. package/dist/core/script/script-constant.d.ts +36 -36
  49. package/dist/core/script/script-constant.js +70 -70
  50. package/dist/core/script/script-context.d.ts +1 -1
  51. package/dist/core/script/script-context.js +295 -295
  52. package/dist/core/script/script-front.d.ts +1 -1
  53. package/dist/core/script/script-front.js +201 -201
  54. package/dist/core/script/script-insert.d.ts +18 -18
  55. package/dist/core/script/script-insert.js +43 -43
  56. package/dist/core/script/script-manager.d.ts +74 -74
  57. package/dist/core/script/script-manager.js +261 -261
  58. package/dist/core/script/script-storage.d.ts +22 -22
  59. package/dist/core/script/script-storage.js +241 -241
  60. package/dist/core/script/script-support.d.ts +11 -11
  61. package/dist/core/script/script-support.js +140 -140
  62. package/dist/core/script/script-template.d.ts +1 -1
  63. package/dist/core/script/script-template.js +6 -6
  64. package/dist/core/service/port.d.ts +5 -5
  65. package/dist/core/service/port.js +53 -53
  66. package/dist/core/service/port.js.map +1 -1
  67. package/dist/core/storage/index.d.ts +5 -5
  68. package/dist/core/storage/index.js +21 -17
  69. package/dist/core/storage/index.js.map +1 -1
  70. package/dist/core/storage/minioStorage.d.ts +31 -28
  71. package/dist/core/storage/minioStorage.js +224 -209
  72. package/dist/core/storage/minioStorage.js.map +1 -1
  73. package/dist/core/storage/objectStorage.d.ts +23 -19
  74. package/dist/core/storage/objectStorage.js +3 -3
  75. package/dist/core/storage/ossStorage.d.ts +29 -26
  76. package/dist/core/storage/ossStorage.js +215 -193
  77. package/dist/core/storage/ossStorage.js.map +1 -1
  78. package/dist/core/storage/storageFlusher.d.ts +14 -14
  79. package/dist/core/storage/storageFlusher.js +54 -54
  80. package/dist/core/storage/storageLogger.d.ts +16 -16
  81. package/dist/core/storage/storageLogger.js +100 -100
  82. package/dist/core/storage/storageLogger.js.map +1 -1
  83. package/dist/core/storage/storagePath.d.ts +16 -16
  84. package/dist/core/storage/storagePath.js +49 -49
  85. package/dist/core/storage/wrapperStorage.d.ts +17 -17
  86. package/dist/core/storage/wrapperStorage.js +47 -47
  87. package/dist/core/storage/wrapperStorage.js.map +1 -1
  88. package/dist/core/utils/flusher.d.ts +18 -18
  89. package/dist/core/utils/flusher.js +66 -62
  90. package/dist/core/utils/flusher.js.map +1 -1
  91. package/dist/core/utils/http.d.ts +3 -3
  92. package/dist/core/utils/http.js +35 -35
  93. package/dist/core/utils/http.js.map +1 -1
  94. package/dist/core/utils/index.d.ts +57 -56
  95. package/dist/core/utils/index.js +247 -243
  96. package/dist/core/utils/index.js.map +1 -1
  97. package/dist/core/utils/number.d.ts +2 -2
  98. package/dist/core/utils/number.js +19 -19
  99. package/dist/core/utils/retry.d.ts +1 -1
  100. package/dist/core/utils/retry.js +34 -34
  101. package/dist/core/utils/retry.js.map +1 -1
  102. package/dist/core/utils/suanpan.d.ts +21 -20
  103. package/dist/core/utils/suanpan.js +103 -92
  104. package/dist/core/utils/suanpan.js.map +1 -1
  105. package/dist/core/web/app.d.ts +2 -2
  106. package/dist/core/web/app.js +38 -38
  107. package/dist/core/web/app.js.map +1 -1
  108. package/dist/core/web/server.d.ts +3 -3
  109. package/dist/core/web/server.js +64 -60
  110. package/dist/core/web/server.js.map +1 -1
  111. package/dist/main.d.ts +5 -5
  112. package/dist/main.js +28 -24
  113. package/dist/main.js.map +1 -1
  114. package/dist/types/conmonTypes.d.ts +21 -21
  115. package/dist/types/conmonTypes.js +16 -16
  116. package/dist/types/index.d.ts +3 -3
  117. package/dist/types/index.js +19 -15
  118. package/dist/types/index.js.map +1 -1
  119. package/dist/types/storageTypes.d.ts +59 -58
  120. package/dist/types/storageTypes.js +9 -9
  121. package/dist/types/streamTypes.d.ts +21 -21
  122. package/dist/types/streamTypes.js +2 -2
  123. package/package.json +1 -1
@@ -1,51 +1,51 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.MessageBuilder = void 0;
4
- const utils_1 = require("../utils");
5
- const message_1 = require("./message");
6
- const DEFAULT_MESSAGE_HEADERS = {
7
- requestId: '',
8
- extra: {},
9
- timestamp: 0
10
- };
11
- class MessageBuilder {
12
- static fromMessagePayload(message) {
13
- this._payload = message.payload;
14
- return this;
15
- }
16
- static fromMessageHeaders(message) {
17
- for (const [headerName, headerValue] of Object.entries(message.headers)) {
18
- this.setHeader(headerName, headerValue);
19
- }
20
- return this;
21
- }
22
- static withPayload(payload) {
23
- this._payload = payload;
24
- return this;
25
- }
26
- static setHeader(key, value) {
27
- this._headers[key] = value;
28
- return this;
29
- }
30
- static setHeaderIfAbsent(key, value) {
31
- if (!this._headers[key]) {
32
- this._headers[key] = value;
33
- }
34
- return this;
35
- }
36
- static build() {
37
- if (!this._payload) {
38
- throw new Error('payload must be passed in.');
39
- }
40
- if (!this._headers.requestId) {
41
- this._headers.requestId = utils_1.generateUUID().split('-').join('');
42
- }
43
- if (!this._headers.timestamp) {
44
- this._headers.timestamp = new Date().getTime();
45
- }
46
- return new message_1.Message(this._headers, this._payload);
47
- }
48
- }
49
- exports.MessageBuilder = MessageBuilder;
50
- MessageBuilder._headers = DEFAULT_MESSAGE_HEADERS;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.MessageBuilder = void 0;
4
+ const utils_1 = require("../utils");
5
+ const message_1 = require("./message");
6
+ const DEFAULT_MESSAGE_HEADERS = {
7
+ requestId: '',
8
+ extra: {},
9
+ timestamp: 0
10
+ };
11
+ class MessageBuilder {
12
+ static fromMessagePayload(message) {
13
+ this._payload = message.payload;
14
+ return this;
15
+ }
16
+ static fromMessageHeaders(message) {
17
+ for (const [headerName, headerValue] of Object.entries(message.headers)) {
18
+ this.setHeader(headerName, headerValue);
19
+ }
20
+ return this;
21
+ }
22
+ static withPayload(payload) {
23
+ this._payload = payload;
24
+ return this;
25
+ }
26
+ static setHeader(key, value) {
27
+ this._headers[key] = value;
28
+ return this;
29
+ }
30
+ static setHeaderIfAbsent(key, value) {
31
+ if (!this._headers[key]) {
32
+ this._headers[key] = value;
33
+ }
34
+ return this;
35
+ }
36
+ static build() {
37
+ if (!this._payload) {
38
+ throw new Error('payload must be passed in.');
39
+ }
40
+ if (!this._headers.requestId) {
41
+ this._headers.requestId = (0, utils_1.generateUUID)().split('-').join('');
42
+ }
43
+ if (!this._headers.timestamp) {
44
+ this._headers.timestamp = new Date().getTime();
45
+ }
46
+ return new message_1.Message(this._headers, this._payload);
47
+ }
48
+ }
49
+ exports.MessageBuilder = MessageBuilder;
50
+ MessageBuilder._headers = DEFAULT_MESSAGE_HEADERS;
51
51
  //# sourceMappingURL=messageBuilder.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"messageBuilder.js","sourceRoot":"","sources":["../../../src/core/message/messageBuilder.ts"],"names":[],"mappings":";;;AAAA,oCAAwC;AACxC,uCAAoD;AAGpD,MAAM,uBAAuB,GAAmB;IAC9C,SAAS,EAAE,EAAE;IACb,KAAK,EAAE,EAAE;IACT,SAAS,EAAE,CAAC;CACb,CAAC;AAEF,MAAa,cAAc;IAKzB,MAAM,CAAC,kBAAkB,CAAC,OAAgB;QACxC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC;QAChC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,kBAAkB,CAAC,OAAgB;QACxC,KAAK,MAAM,CAAC,UAAU,EAAE,WAAW,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YACvE,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;SACzC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,WAAW,CAAC,OAAmB;QACpC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,SAAS,CAAC,GAAW,EAAE,KAAa;QACzC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QAC3B,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,iBAAiB,CAAC,GAAW,EAAE,KAAa;QACjD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;YACvB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;SAC5B;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,KAAK;QACV,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;SAC/C;QAED,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE;YAC5B,IAAI,CAAC,QAAQ,CAAC,SAAS,GAAG,oBAAY,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SAC9D;QAED,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE;YAC5B,IAAI,CAAC,QAAQ,CAAC,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;SAChD;QAED,OAAO,IAAI,iBAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IACnD,CAAC;;AAhDH,wCAiDC;AA9CgB,uBAAQ,GAAG,uBAAuB,CAAC"}
1
+ {"version":3,"file":"messageBuilder.js","sourceRoot":"","sources":["../../../src/core/message/messageBuilder.ts"],"names":[],"mappings":";;;AAAA,oCAAwC;AACxC,uCAAoD;AAGpD,MAAM,uBAAuB,GAAmB;IAC9C,SAAS,EAAE,EAAE;IACb,KAAK,EAAE,EAAE;IACT,SAAS,EAAE,CAAC;CACb,CAAC;AAEF,MAAa,cAAc;IAKzB,MAAM,CAAC,kBAAkB,CAAC,OAAgB;QACxC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC;QAChC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,kBAAkB,CAAC,OAAgB;QACxC,KAAK,MAAM,CAAC,UAAU,EAAE,WAAW,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YACvE,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;SACzC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,WAAW,CAAC,OAAmB;QACpC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,SAAS,CAAC,GAAW,EAAE,KAAa;QACzC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QAC3B,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,iBAAiB,CAAC,GAAW,EAAE,KAAa;QACjD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;YACvB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;SAC5B;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,KAAK;QACV,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;SAC/C;QAED,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE;YAC5B,IAAI,CAAC,QAAQ,CAAC,SAAS,GAAG,IAAA,oBAAY,GAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SAC9D;QAED,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE;YAC5B,IAAI,CAAC,QAAQ,CAAC,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;SAChD;QAED,OAAO,IAAI,iBAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IACnD,CAAC;;AAhDH,wCAiDC;AA9CgB,uBAAQ,GAAG,uBAAuB,CAAC"}
@@ -1,9 +1,9 @@
1
- import type { Message } from './message';
2
- import type { OutPortsMap } from '../../types';
3
- import type { MessageChannel } from './channel';
4
- export declare class MessageChain {
5
- private message;
6
- private channel;
7
- constructor(message: Message, channel: MessageChannel);
8
- send(payload: OutPortsMap<any>): Promise<void>;
9
- }
1
+ import type { Message } from './message';
2
+ import type { OutPortsMap } from '../../types';
3
+ import type { MessageChannel } from './channel';
4
+ export declare class MessageChain {
5
+ private message;
6
+ private channel;
7
+ constructor(message: Message, channel: MessageChannel);
8
+ send(payload: OutPortsMap<any>): Promise<void>;
9
+ }
@@ -1,30 +1,30 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.MessageChain = void 0;
13
- const messageBuilder_1 = require("./messageBuilder");
14
- class MessageChain {
15
- constructor(message, channel) {
16
- this.message = message;
17
- this.channel = channel;
18
- }
19
- send(payload) {
20
- return __awaiter(this, void 0, void 0, function* () {
21
- const responseMessage = messageBuilder_1.MessageBuilder
22
- .fromMessageHeaders(this.message)
23
- .withPayload(payload)
24
- .build();
25
- yield this.channel.sendMessage(responseMessage);
26
- });
27
- }
28
- }
29
- exports.MessageChain = MessageChain;
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.MessageChain = void 0;
13
+ const messageBuilder_1 = require("./messageBuilder");
14
+ class MessageChain {
15
+ constructor(message, channel) {
16
+ this.message = message;
17
+ this.channel = channel;
18
+ }
19
+ send(payload) {
20
+ return __awaiter(this, void 0, void 0, function* () {
21
+ const responseMessage = messageBuilder_1.MessageBuilder
22
+ .fromMessageHeaders(this.message)
23
+ .withPayload(payload)
24
+ .build();
25
+ yield this.channel.sendMessage(responseMessage);
26
+ });
27
+ }
28
+ }
29
+ exports.MessageChain = MessageChain;
30
30
  //# sourceMappingURL=messageChain.js.map
@@ -1,4 +1,4 @@
1
- import type { MessageHandler } from './channel';
2
- export declare class MessageListener {
3
- static onMessage(handler: MessageHandler): void;
4
- }
1
+ import type { MessageHandler } from './channel';
2
+ export declare class MessageListener {
3
+ static onMessage(handler: MessageHandler): void;
4
+ }
@@ -1,12 +1,12 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.MessageListener = void 0;
4
- const mq_1 = require("./mq");
5
- class MessageListener {
6
- static onMessage(handler) {
7
- const messageChannel = new mq_1.RedisStreamChannel();
8
- messageChannel.subscribe(handler);
9
- }
10
- }
11
- exports.MessageListener = MessageListener;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.MessageListener = void 0;
4
+ const mq_1 = require("./mq");
5
+ class MessageListener {
6
+ static onMessage(handler) {
7
+ const messageChannel = new mq_1.RedisStreamChannel();
8
+ messageChannel.subscribe(handler);
9
+ }
10
+ }
11
+ exports.MessageListener = MessageListener;
12
12
  //# sourceMappingURL=messageListener.js.map
@@ -1,9 +1,9 @@
1
- import type { Message } from '../message';
2
- import type { MessageHandler, MessageChannel } from '../channel';
3
- export declare class RedisStreamChannel implements MessageChannel {
4
- private _client;
5
- constructor();
6
- receiveMessage(): Promise<Message>;
7
- subscribe(handler: MessageHandler): void;
8
- sendMessage(message: Message): Promise<void>;
9
- }
1
+ import type { Message } from '../message';
2
+ import type { MessageHandler, MessageChannel } from '../channel';
3
+ export declare class RedisStreamChannel implements MessageChannel {
4
+ private _client;
5
+ constructor();
6
+ receiveMessage(): Promise<Message>;
7
+ subscribe(handler: MessageHandler): void;
8
+ sendMessage(message: Message): Promise<void>;
9
+ }
@@ -1,51 +1,51 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.RedisStreamChannel = void 0;
13
- require("lodash");
14
- const redis_1 = require("./redis");
15
- const logkit_1 = require("../../logkit");
16
- const messageChain_1 = require("../messageChain");
17
- const event_1 = require("../../event");
18
- class RedisStreamChannel {
19
- constructor() {
20
- this._client = redis_1.RedisClient.Instance;
21
- }
22
- receiveMessage() {
23
- return new Promise((resolve, reject) => {
24
- this._client.once(event_1.MessageReachedEvent.NAME, (event) => {
25
- resolve(event.message);
26
- });
27
- });
28
- }
29
- subscribe(handler) {
30
- this._client.on(event_1.MessageReachedEvent.NAME, (event) => __awaiter(this, void 0, void 0, function* () {
31
- const requestMessage = event.message;
32
- const chain = new messageChain_1.MessageChain(requestMessage, this);
33
- try {
34
- yield handler(requestMessage, chain);
35
- }
36
- catch (e) {
37
- logkit_1.EventLogger.Instance.error(e);
38
- const errorResponse = requestMessage.toErrorResponseStream(e.message);
39
- yield this._client.sendMessage(errorResponse);
40
- }
41
- }));
42
- }
43
- sendMessage(message) {
44
- return __awaiter(this, void 0, void 0, function* () {
45
- const responseStream = message.toResponseStream();
46
- yield this._client.sendMessage(responseStream);
47
- });
48
- }
49
- }
50
- exports.RedisStreamChannel = RedisStreamChannel;
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.RedisStreamChannel = void 0;
13
+ require("lodash");
14
+ const redis_1 = require("./redis");
15
+ const logkit_1 = require("../../logkit");
16
+ const messageChain_1 = require("../messageChain");
17
+ const event_1 = require("../../event");
18
+ class RedisStreamChannel {
19
+ constructor() {
20
+ this._client = redis_1.RedisClient.Instance;
21
+ }
22
+ receiveMessage() {
23
+ return new Promise((resolve, reject) => {
24
+ this._client.once(event_1.MessageReachedEvent.NAME, (event) => {
25
+ resolve(event.message);
26
+ });
27
+ });
28
+ }
29
+ subscribe(handler) {
30
+ this._client.on(event_1.MessageReachedEvent.NAME, (event) => __awaiter(this, void 0, void 0, function* () {
31
+ const requestMessage = event.message;
32
+ const chain = new messageChain_1.MessageChain(requestMessage, this);
33
+ try {
34
+ yield handler(requestMessage, chain);
35
+ }
36
+ catch (e) {
37
+ logkit_1.EventLogger.Instance.error(e);
38
+ const errorResponse = requestMessage.toErrorResponseStream(e.message);
39
+ yield this._client.sendMessage(errorResponse);
40
+ }
41
+ }));
42
+ }
43
+ sendMessage(message) {
44
+ return __awaiter(this, void 0, void 0, function* () {
45
+ const responseStream = message.toResponseStream();
46
+ yield this._client.sendMessage(responseStream);
47
+ });
48
+ }
49
+ }
50
+ exports.RedisStreamChannel = RedisStreamChannel;
51
51
  //# sourceMappingURL=index.js.map
@@ -1,12 +1,12 @@
1
- /// <reference types="node" />
2
- import * as events from 'events';
3
- import type { ResponseStream } from '../../../types';
4
- export declare class RedisClient extends events.EventEmitter {
5
- private static _instance;
6
- static get Instance(): RedisClient;
7
- private _client;
8
- private constructor();
9
- private initMQClient;
10
- private _buildSendMessageOptions;
11
- sendMessage(responseStream: ResponseStream): Promise<void>;
12
- }
1
+ /// <reference types="node" />
2
+ import * as events from 'events';
3
+ import type { ResponseStream } from '../../../types';
4
+ export declare class RedisClient extends events.EventEmitter {
5
+ private static _instance;
6
+ static get Instance(): RedisClient;
7
+ private _client;
8
+ private constructor();
9
+ private initMQClient;
10
+ private _buildSendMessageOptions;
11
+ sendMessage(responseStream: ResponseStream): Promise<void>;
12
+ }
@@ -1,98 +1,102 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
- }) : (function(o, m, k, k2) {
6
- if (k2 === undefined) k2 = k;
7
- o[k2] = m[k];
8
- }));
9
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
- Object.defineProperty(o, "default", { enumerable: true, value: v });
11
- }) : function(o, v) {
12
- o["default"] = v;
13
- });
14
- var __importStar = (this && this.__importStar) || function (mod) {
15
- if (mod && mod.__esModule) return mod;
16
- var result = {};
17
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
- __setModuleDefault(result, mod);
19
- return result;
20
- };
21
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
22
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
23
- return new (P || (P = Promise))(function (resolve, reject) {
24
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
25
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
26
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
27
- step((generator = generator.apply(thisArg, _arguments || [])).next());
28
- });
29
- };
30
- var __importDefault = (this && this.__importDefault) || function (mod) {
31
- return (mod && mod.__esModule) ? mod : { "default": mod };
32
- };
33
- Object.defineProperty(exports, "__esModule", { value: true });
34
- exports.RedisClient = void 0;
35
- const events = __importStar(require("events"));
36
- const log_1 = __importDefault(require("../../common/log"));
37
- const utils_1 = require("../../utils");
38
- const message_1 = require("../message");
39
- const environment_1 = require("../../parameter/environment");
40
- const event_1 = require("../../event");
41
- const suanpan_mq_1 = require("suanpan-mq");
42
- class RedisClient extends events.EventEmitter {
43
- constructor() {
44
- super();
45
- this.initMQClient();
46
- }
47
- static get Instance() {
48
- if (!this._instance) {
49
- this._instance = new RedisClient();
50
- }
51
- return this._instance;
52
- }
53
- initMQClient() {
54
- if (!this._client) {
55
- this._client = new suanpan_mq_1.SPMQClient({ host: environment_1.Environment.mq.host, readWriteSeparation: true, port: environment_1.Environment.mq.port });
56
- const queue = environment_1.Environment.mq.receiveQueue;
57
- const callback = (qMessage) => __awaiter(this, void 0, void 0, function* () {
58
- if (qMessage.data) {
59
- const requestStream = qMessage.data;
60
- const message = message_1.Message.fromRequestStream(requestStream);
61
- this.emit(event_1.MessageReachedEvent.NAME, new event_1.MessageReachedEvent(message));
62
- }
63
- else {
64
- log_1.default.info(`Received queueMessage: ${JSON.stringify(qMessage)}`);
65
- log_1.default.info('Received message from the redis queue, but the data is empty.');
66
- }
67
- });
68
- // https://github.com/chylvina/AiLab/blob/58b7d302f5657042e8226cc3168dfee23dc35758/suanpan/stream/__init__.py#L118-L135
69
- const queueOption = { queue, callback, count: 1 };
70
- this._client.subscribeQueue(queueOption);
71
- }
72
- }
73
- _buildSendMessageOptions(responseStream) {
74
- const maxlen = environment_1.Environment.mq.sendQueueMaxLength;
75
- const trimImmediately = environment_1.Environment.mq.sendQueueTrimImmediately;
76
- return {
77
- queue: environment_1.Environment.mq.sendQueue,
78
- data: responseStream,
79
- maxlen: maxlen ? parseInt(maxlen) : 2000,
80
- trimImmediately: utils_1.isTrue(trimImmediately)
81
- };
82
- }
83
- sendMessage(responseStream) {
84
- return __awaiter(this, void 0, void 0, function* () {
85
- try {
86
- this.initMQClient();
87
- const sendOptions = this._buildSendMessageOptions(responseStream);
88
- yield this._client.sendMessage(sendOptions);
89
- }
90
- catch (e) {
91
- log_1.default.error(`send message failed, reason: ${e}`);
92
- throw e;
93
- }
94
- });
95
- }
96
- }
97
- exports.RedisClient = RedisClient;
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
26
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
27
+ return new (P || (P = Promise))(function (resolve, reject) {
28
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
29
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
30
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
31
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
32
+ });
33
+ };
34
+ var __importDefault = (this && this.__importDefault) || function (mod) {
35
+ return (mod && mod.__esModule) ? mod : { "default": mod };
36
+ };
37
+ Object.defineProperty(exports, "__esModule", { value: true });
38
+ exports.RedisClient = void 0;
39
+ const events = __importStar(require("events"));
40
+ const log_1 = __importDefault(require("../../common/log"));
41
+ const utils_1 = require("../../utils");
42
+ const message_1 = require("../message");
43
+ const environment_1 = require("../../parameter/environment");
44
+ const event_1 = require("../../event");
45
+ const suanpan_mq_1 = require("suanpan-mq");
46
+ class RedisClient extends events.EventEmitter {
47
+ static get Instance() {
48
+ if (!this._instance) {
49
+ this._instance = new RedisClient();
50
+ }
51
+ return this._instance;
52
+ }
53
+ constructor() {
54
+ super();
55
+ this.initMQClient();
56
+ }
57
+ initMQClient() {
58
+ if (!this._client) {
59
+ this._client = new suanpan_mq_1.SPMQClient({ host: environment_1.Environment.mq.host, readWriteSeparation: true, port: environment_1.Environment.mq.port });
60
+ const queue = environment_1.Environment.mq.receiveQueue;
61
+ const callback = (qMessage) => __awaiter(this, void 0, void 0, function* () {
62
+ if (qMessage.data) {
63
+ const requestStream = qMessage.data;
64
+ const message = message_1.Message.fromRequestStream(requestStream);
65
+ this.emit(event_1.MessageReachedEvent.NAME, new event_1.MessageReachedEvent(message));
66
+ }
67
+ else {
68
+ log_1.default.info(`Received queueMessage: ${JSON.stringify(qMessage)}`);
69
+ log_1.default.info('Received message from the redis queue, but the data is empty.');
70
+ }
71
+ });
72
+ // https://github.com/chylvina/AiLab/blob/58b7d302f5657042e8226cc3168dfee23dc35758/suanpan/stream/__init__.py#L118-L135
73
+ const queueOption = { queue, callback, count: 1 };
74
+ this._client.subscribeQueue(queueOption);
75
+ }
76
+ }
77
+ _buildSendMessageOptions(responseStream) {
78
+ const maxlen = environment_1.Environment.mq.sendQueueMaxLength;
79
+ const trimImmediately = environment_1.Environment.mq.sendQueueTrimImmediately;
80
+ return {
81
+ queue: environment_1.Environment.mq.sendQueue,
82
+ data: responseStream,
83
+ maxlen: maxlen ? parseInt(maxlen) : 2000,
84
+ trimImmediately: (0, utils_1.isTrue)(trimImmediately)
85
+ };
86
+ }
87
+ sendMessage(responseStream) {
88
+ return __awaiter(this, void 0, void 0, function* () {
89
+ try {
90
+ this.initMQClient();
91
+ const sendOptions = this._buildSendMessageOptions(responseStream);
92
+ yield this._client.sendMessage(sendOptions);
93
+ }
94
+ catch (e) {
95
+ log_1.default.error(`send message failed, reason: ${e}`);
96
+ throw e;
97
+ }
98
+ });
99
+ }
100
+ }
101
+ exports.RedisClient = RedisClient;
98
102
  //# sourceMappingURL=redis.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"redis.js","sourceRoot":"","sources":["../../../../src/core/message/mq/redis.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAiC;AACjC,2DAAsC;AAItC,uCAAqC;AACrC,wCAAqC;AACrC,6DAA0D;AAC1D,uCAAkD;AAClD,2CAAyH;AACzH,MAAa,WAAY,SAAQ,MAAM,CAAC,YAAY;IAalD;QACE,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAZM,MAAM,KAAK,QAAQ;QACxB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,IAAI,CAAC,SAAS,GAAG,IAAI,WAAW,EAAE,CAAC;SACpC;QACD,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IASO,YAAY;QAClB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YAEjB,IAAI,CAAC,OAAO,GAAG,IAAI,uBAAU,CAAC,EAAE,IAAI,EAAE,yBAAW,CAAC,EAAE,CAAC,IAAc,EAAE,mBAAmB,EAAE,IAAI,EAAE,IAAI,EAAE,yBAAW,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;YAE7H,MAAM,KAAK,GAAG,yBAAW,CAAC,EAAE,CAAC,YAAsB,CAAC;YAEpD,MAAM,QAAQ,GAA2B,CAAO,QAAsB,EAAE,EAAE;gBACxE,IAAI,QAAQ,CAAC,IAAI,EAAE;oBACjB,MAAM,aAAa,GAAG,QAAQ,CAAC,IAAqB,CAAC;oBACrD,MAAM,OAAO,GAAG,iBAAO,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC;oBACzD,IAAI,CAAC,IAAI,CAAC,2BAAmB,CAAC,IAAI,EAAE,IAAI,2BAAmB,CAAC,OAAO,CAAC,CAAC,CAAC;iBACvE;qBAAM;oBACL,aAAM,CAAC,IAAI,CAAC,0BAA0B,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;oBAClE,aAAM,CAAC,IAAI,CAAC,+DAA+D,CAAC,CAAC;iBAC9E;YACH,CAAC,CAAA,CAAC;YACF,uHAAuH;YACvH,MAAM,WAAW,GAA0B,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC;YAEzE,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;SAC1C;IACH,CAAC;IAEO,wBAAwB,CAAC,cAA8B;QAC7D,MAAM,MAAM,GAAG,yBAAW,CAAC,EAAE,CAAC,kBAA4B,CAAC;QAC3D,MAAM,eAAe,GAAG,yBAAW,CAAC,EAAE,CAAC,wBAAwB,CAAC;QAChE,OAAO;YACL,KAAK,EAAE,yBAAW,CAAC,EAAE,CAAC,SAAmB;YACzC,IAAI,EAAE,cAAc;YACpB,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI;YACxC,eAAe,EAAE,cAAM,CAAC,eAAe,CAAC;SACzC,CAAC;IACJ,CAAC;IAEK,WAAW,CAAC,cAA8B;;YAC9C,IAAI;gBACF,IAAI,CAAC,YAAY,EAAE,CAAC;gBACpB,MAAM,WAAW,GAAG,IAAI,CAAC,wBAAwB,CAAC,cAAc,CAAC,CAAC;gBAClE,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;aAC7C;YAAC,OAAO,CAAC,EAAE;gBACV,aAAM,CAAC,KAAK,CAAC,gCAAgC,CAAC,EAAE,CAAC,CAAC;gBAClD,MAAM,CAAC,CAAC;aACT;QACH,CAAC;KAAA;CACF;AA/DD,kCA+DC"}
1
+ {"version":3,"file":"redis.js","sourceRoot":"","sources":["../../../../src/core/message/mq/redis.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAiC;AACjC,2DAAsC;AAItC,uCAAqC;AACrC,wCAAqC;AACrC,6DAA0D;AAC1D,uCAAkD;AAClD,2CAAyH;AACzH,MAAa,WAAY,SAAQ,MAAM,CAAC,YAAY;IAI3C,MAAM,KAAK,QAAQ;QACxB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,IAAI,CAAC,SAAS,GAAG,IAAI,WAAW,EAAE,CAAC;SACpC;QACD,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAID;QACE,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YAEjB,IAAI,CAAC,OAAO,GAAG,IAAI,uBAAU,CAAC,EAAE,IAAI,EAAE,yBAAW,CAAC,EAAE,CAAC,IAAc,EAAE,mBAAmB,EAAE,IAAI,EAAE,IAAI,EAAE,yBAAW,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;YAE7H,MAAM,KAAK,GAAG,yBAAW,CAAC,EAAE,CAAC,YAAsB,CAAC;YAEpD,MAAM,QAAQ,GAA2B,CAAO,QAAsB,EAAE,EAAE;gBACxE,IAAI,QAAQ,CAAC,IAAI,EAAE;oBACjB,MAAM,aAAa,GAAG,QAAQ,CAAC,IAAqB,CAAC;oBACrD,MAAM,OAAO,GAAG,iBAAO,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC;oBACzD,IAAI,CAAC,IAAI,CAAC,2BAAmB,CAAC,IAAI,EAAE,IAAI,2BAAmB,CAAC,OAAO,CAAC,CAAC,CAAC;iBACvE;qBAAM;oBACL,aAAM,CAAC,IAAI,CAAC,0BAA0B,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;oBAClE,aAAM,CAAC,IAAI,CAAC,+DAA+D,CAAC,CAAC;iBAC9E;YACH,CAAC,CAAA,CAAC;YACF,uHAAuH;YACvH,MAAM,WAAW,GAA0B,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC;YAEzE,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;SAC1C;IACH,CAAC;IAEO,wBAAwB,CAAC,cAA8B;QAC7D,MAAM,MAAM,GAAG,yBAAW,CAAC,EAAE,CAAC,kBAA4B,CAAC;QAC3D,MAAM,eAAe,GAAG,yBAAW,CAAC,EAAE,CAAC,wBAAwB,CAAC;QAChE,OAAO;YACL,KAAK,EAAE,yBAAW,CAAC,EAAE,CAAC,SAAmB;YACzC,IAAI,EAAE,cAAc;YACpB,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI;YACxC,eAAe,EAAE,IAAA,cAAM,EAAC,eAAe,CAAC;SACzC,CAAC;IACJ,CAAC;IAEK,WAAW,CAAC,cAA8B;;YAC9C,IAAI;gBACF,IAAI,CAAC,YAAY,EAAE,CAAC;gBACpB,MAAM,WAAW,GAAG,IAAI,CAAC,wBAAwB,CAAC,cAAc,CAAC,CAAC;gBAClE,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;aAC7C;YAAC,OAAO,CAAC,EAAE;gBACV,aAAM,CAAC,KAAK,CAAC,gCAAgC,CAAC,EAAE,CAAC,CAAC;gBAClD,MAAM,CAAC,CAAC;aACT;QACH,CAAC;KAAA;CACF;AA/DD,kCA+DC"}
@@ -1,2 +1,2 @@
1
- import type { AnyJSON } from '../../types/index';
2
- export declare const argvs: AnyJSON<any>;
1
+ import type { AnyJSON } from '../../types/index';
2
+ export declare const argvs: AnyJSON<any>;