cry-ebus2 3.1.22 → 3.1.24

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 (261) hide show
  1. package/dist/EbusClientEvents.d.mts +5 -0
  2. package/dist/EbusClientEvents.d.mts.map +1 -0
  3. package/dist/EbusClientEvents.mjs +2 -0
  4. package/dist/EbusClientEvents.mjs.map +1 -0
  5. package/dist/EbusConfiguration.d.mts +17 -0
  6. package/dist/EbusConfiguration.d.mts.map +1 -0
  7. package/dist/EbusConfiguration.mjs +2 -0
  8. package/dist/EbusConfiguration.mjs.map +1 -0
  9. package/dist/EbusReject.d.mts +11 -0
  10. package/dist/EbusReject.d.mts.map +1 -0
  11. package/dist/EbusReject.mjs +12 -0
  12. package/dist/EbusReject.mjs.map +1 -0
  13. package/dist/EbusRejectReason.d.mts +2 -0
  14. package/dist/EbusRejectReason.d.mts.map +1 -0
  15. package/dist/EbusRejectReason.d.ts +1 -1
  16. package/dist/EbusRejectReason.d.ts.map +1 -1
  17. package/dist/EbusRejectReason.mjs +2 -0
  18. package/dist/EbusRejectReason.mjs.map +1 -0
  19. package/dist/EbusRequestOptions.d.mts +8 -0
  20. package/dist/EbusRequestOptions.d.mts.map +1 -0
  21. package/dist/EbusRequestOptions.mjs +2 -0
  22. package/dist/EbusRequestOptions.mjs.map +1 -0
  23. package/dist/EbusUnpackedResult.d.mts +10 -0
  24. package/dist/EbusUnpackedResult.d.mts.map +1 -0
  25. package/dist/EbusUnpackedResult.mjs +19 -0
  26. package/dist/EbusUnpackedResult.mjs.map +1 -0
  27. package/dist/block.d.mts +2 -0
  28. package/dist/block.d.mts.map +1 -0
  29. package/dist/block.mjs +6 -0
  30. package/dist/block.mjs.map +1 -0
  31. package/dist/broker.d.mts +42 -0
  32. package/dist/broker.d.mts.map +1 -0
  33. package/dist/broker.mjs +288 -0
  34. package/dist/broker.mjs.map +1 -0
  35. package/dist/client.d.mts +2 -0
  36. package/dist/client.d.mts.map +1 -0
  37. package/dist/client.mjs +2 -0
  38. package/dist/client.mjs.map +1 -0
  39. package/dist/clientBlocking.d.mts +27 -0
  40. package/dist/clientBlocking.d.mts.map +1 -0
  41. package/dist/clientBlocking.mjs +173 -0
  42. package/dist/clientBlocking.mjs.map +1 -0
  43. package/dist/clientNonBlocking.d.mts +46 -0
  44. package/dist/clientNonBlocking.d.mts.map +1 -0
  45. package/dist/clientNonBlocking.js +6 -6
  46. package/dist/clientNonBlocking.js.map +1 -1
  47. package/dist/clientNonBlocking.mjs +275 -0
  48. package/dist/clientNonBlocking.mjs.map +1 -0
  49. package/dist/consts.d.mts +3 -0
  50. package/dist/consts.d.mts.map +1 -0
  51. package/dist/consts.mjs +17 -0
  52. package/dist/consts.mjs.map +1 -0
  53. package/dist/deferredPromise.d.mts +36 -0
  54. package/dist/deferredPromise.d.mts.map +1 -0
  55. package/dist/deferredPromise.js +5 -4
  56. package/dist/deferredPromise.js.map +1 -1
  57. package/dist/deferredPromise.mjs +57 -0
  58. package/dist/deferredPromise.mjs.map +1 -0
  59. package/dist/delayWorker.d.mts +10 -0
  60. package/dist/delayWorker.d.mts.map +1 -0
  61. package/dist/delayWorker.mjs +17 -0
  62. package/dist/delayWorker.mjs.map +1 -0
  63. package/dist/echoWorker.d.mts +6 -0
  64. package/dist/echoWorker.d.mts.map +1 -0
  65. package/dist/echoWorker.js +1 -1
  66. package/dist/echoWorker.js.map +1 -1
  67. package/dist/echoWorker.mjs +15 -0
  68. package/dist/echoWorker.mjs.map +1 -0
  69. package/dist/errorWorker.d.mts +11 -0
  70. package/dist/errorWorker.d.mts.map +1 -0
  71. package/dist/errorWorker.mjs +14 -0
  72. package/dist/errorWorker.mjs.map +1 -0
  73. package/dist/index.d.mts +19 -0
  74. package/dist/index.d.mts.map +1 -0
  75. package/dist/index.mjs +16 -0
  76. package/dist/index.mjs.map +1 -0
  77. package/dist/loadConfiguration.d.mts +3 -0
  78. package/dist/loadConfiguration.d.mts.map +1 -0
  79. package/dist/loadConfiguration.mjs +9 -0
  80. package/dist/loadConfiguration.mjs.map +1 -0
  81. package/dist/pub.d.mts +11 -0
  82. package/dist/pub.d.mts.map +1 -0
  83. package/dist/pub.mjs +22 -0
  84. package/dist/pub.mjs.map +1 -0
  85. package/dist/rejectWorker.d.mts +11 -0
  86. package/dist/rejectWorker.d.mts.map +1 -0
  87. package/dist/rejectWorker.mjs +14 -0
  88. package/dist/rejectWorker.mjs.map +1 -0
  89. package/dist/run/all.d.mts +2 -0
  90. package/dist/run/all.d.mts.map +1 -0
  91. package/dist/run/all.mjs +13 -0
  92. package/dist/run/all.mjs.map +1 -0
  93. package/dist/run/broker.mjs +1 -1
  94. package/dist/run/broker.mjs.map +1 -1
  95. package/dist/run/call.d.mts +2 -0
  96. package/dist/run/call.d.mts.map +1 -0
  97. package/dist/run/call.js +4 -3
  98. package/dist/run/call.js.map +1 -1
  99. package/dist/run/call.mjs +77 -0
  100. package/dist/run/call.mjs.map +1 -0
  101. package/dist/run/calling.d.mts +2 -0
  102. package/dist/run/calling.d.mts.map +1 -0
  103. package/dist/run/calling.mjs +94 -0
  104. package/dist/run/calling.mjs.map +1 -0
  105. package/dist/run/callingBurst.d.mts +2 -0
  106. package/dist/run/callingBurst.d.mts.map +1 -0
  107. package/dist/run/callingBurst.mjs +41 -0
  108. package/dist/run/callingBurst.mjs.map +1 -0
  109. package/dist/run/delay.mjs +1 -1
  110. package/dist/run/delay.mjs.map +1 -1
  111. package/dist/run/echo.mjs +1 -1
  112. package/dist/run/echo.mjs.map +1 -1
  113. package/dist/run/error.mjs +1 -1
  114. package/dist/run/error.mjs.map +1 -1
  115. package/dist/run/ping.mjs +2 -2
  116. package/dist/run/ping.mjs.map +1 -1
  117. package/dist/run/pub.d.mts +2 -0
  118. package/dist/run/pub.d.mts.map +1 -0
  119. package/dist/run/pub.mjs +28 -0
  120. package/dist/run/pub.mjs.map +1 -0
  121. package/dist/run/reject.d.mts +2 -0
  122. package/dist/run/reject.d.mts.map +1 -0
  123. package/dist/run/reject.mjs +5 -0
  124. package/dist/run/reject.mjs.map +1 -0
  125. package/dist/run/sub.d.mts +2 -0
  126. package/dist/run/sub.d.mts.map +1 -0
  127. package/dist/run/sub.mjs +88 -0
  128. package/dist/run/sub.mjs.map +1 -0
  129. package/dist/run/termimalCommands.d.mts +33 -0
  130. package/dist/run/termimalCommands.d.mts.map +1 -0
  131. package/dist/run/termimalCommands.mjs +33 -0
  132. package/dist/run/termimalCommands.mjs.map +1 -0
  133. package/dist/run/workers.d.mts +2 -0
  134. package/dist/run/workers.d.mts.map +1 -0
  135. package/dist/run/workers.mjs +36 -0
  136. package/dist/run/workers.mjs.map +1 -0
  137. package/dist/serialize.d.mts +4 -0
  138. package/dist/serialize.d.mts.map +1 -0
  139. package/dist/serialize.mjs +26 -0
  140. package/dist/serialize.mjs.map +1 -0
  141. package/dist/service.d.mts +23 -0
  142. package/dist/service.d.mts.map +1 -0
  143. package/dist/service.mjs +108 -0
  144. package/dist/service.mjs.map +1 -0
  145. package/dist/sleep.d.mts +2 -0
  146. package/dist/sleep.d.mts.map +1 -0
  147. package/dist/sleep.mjs +6 -0
  148. package/dist/sleep.mjs.map +1 -0
  149. package/dist/sub.d.mts +24 -0
  150. package/dist/sub.d.mts.map +1 -0
  151. package/dist/sub.mjs +68 -0
  152. package/dist/sub.mjs.map +1 -0
  153. package/dist/test/config.d.mts +2 -0
  154. package/dist/test/config.d.mts.map +1 -0
  155. package/dist/test/config.mjs +23 -0
  156. package/dist/test/config.mjs.map +1 -0
  157. package/dist/test/echo.d.mts +2 -0
  158. package/dist/test/echo.d.mts.map +1 -0
  159. package/dist/test/echo.mjs +54 -0
  160. package/dist/test/echo.mjs.map +1 -0
  161. package/dist/test/index.d.mts +2 -0
  162. package/dist/test/index.d.mts.map +1 -0
  163. package/dist/test/index.mjs +47 -0
  164. package/dist/test/index.mjs.map +1 -0
  165. package/dist/test/pack.d.mts +2 -0
  166. package/dist/test/pack.d.mts.map +1 -0
  167. package/dist/test/pack.mjs +1444 -0
  168. package/dist/test/pack.mjs.map +1 -0
  169. package/dist/test/performance.d.mts +2 -0
  170. package/dist/test/performance.d.mts.map +1 -0
  171. package/dist/test/performance.mjs +44 -0
  172. package/dist/test/performance.mjs.map +1 -0
  173. package/dist/test/pub.d.mts +2 -0
  174. package/dist/test/pub.d.mts.map +1 -0
  175. package/dist/test/pub.mjs +57 -0
  176. package/dist/test/pub.mjs.map +1 -0
  177. package/dist/test/pub2.d.mts +2 -0
  178. package/dist/test/pub2.d.mts.map +1 -0
  179. package/dist/test/pub2.mjs +23 -0
  180. package/dist/test/pub2.mjs.map +1 -0
  181. package/dist/test/reject.d.mts +2 -0
  182. package/dist/test/reject.d.mts.map +1 -0
  183. package/dist/test/reject.mjs +33 -0
  184. package/dist/test/reject.mjs.map +1 -0
  185. package/dist/test/services.d.mts +2 -0
  186. package/dist/test/services.d.mts.map +1 -0
  187. package/dist/test/services.mjs +44 -0
  188. package/dist/test/services.mjs.map +1 -0
  189. package/dist/test/stress.d.mts +2 -0
  190. package/dist/test/stress.d.mts.map +1 -0
  191. package/dist/test/stress.mjs +26 -0
  192. package/dist/test/stress.mjs.map +1 -0
  193. package/dist/test/timing.d.mts +2 -0
  194. package/dist/test/timing.d.mts.map +1 -0
  195. package/dist/test/timing.mjs +68 -0
  196. package/dist/test/timing.mjs.map +1 -0
  197. package/dist/types.d.mts +23 -0
  198. package/dist/types.d.mts.map +1 -0
  199. package/dist/types.js +2 -2
  200. package/dist/types.js.map +1 -1
  201. package/dist/types.mjs +25 -0
  202. package/dist/types.mjs.map +1 -0
  203. package/dist/worker.d.mts +27 -0
  204. package/dist/worker.d.mts.map +1 -0
  205. package/dist/worker.mjs +219 -0
  206. package/dist/worker.mjs.map +1 -0
  207. package/package.json +15 -18
  208. package/src/{EbusReject.ts → EbusReject.mts} +1 -1
  209. package/src/{EbusUnpackedResult.ts → EbusUnpackedResult.mts} +3 -3
  210. package/src/{broker.ts → broker.mts} +6 -6
  211. package/src/{client.ts → client.mts} +1 -1
  212. package/src/{clientBlocking.ts → clientBlocking.mts} +8 -8
  213. package/src/{clientNonBlocking.ts → clientNonBlocking.mts} +9 -9
  214. package/src/{consts.ts → consts.mts} +1 -1
  215. package/src/{delayWorker.ts → delayWorker.mts} +3 -3
  216. package/src/{echoWorker.ts → echoWorker.mts} +3 -3
  217. package/src/{errorWorker.ts → errorWorker.mts} +3 -3
  218. package/src/index.mts +19 -0
  219. package/src/{loadConfiguration.ts → loadConfiguration.mts} +2 -2
  220. package/src/{pub.ts → pub.mts} +3 -3
  221. package/src/{rejectWorker.ts → rejectWorker.mts} +3 -3
  222. package/src/run/all.mts +14 -0
  223. package/src/run/broker.mts +1 -1
  224. package/src/run/{call.ts → call.mts} +7 -4
  225. package/src/run/{calling.ts → calling.mts} +2 -2
  226. package/src/run/{callingBurst.ts → callingBurst.mts} +2 -2
  227. package/src/run/delay.mts +1 -1
  228. package/src/run/echo.mts +1 -1
  229. package/src/run/error.mts +1 -1
  230. package/src/run/ping.mts +3 -3
  231. package/src/run/{pub.ts → pub.mts} +1 -1
  232. package/src/run/{reject.ts → reject.mts} +1 -1
  233. package/src/run/{sub.ts → sub.mts} +2 -2
  234. package/src/run/{workers.ts → workers.mts} +1 -1
  235. package/src/{serialize.ts → serialize.mts} +1 -1
  236. package/src/{service.ts → service.mts} +1 -1
  237. package/src/{sub.ts → sub.mts} +3 -3
  238. package/src/test/{config.ts → config.mts} +3 -3
  239. package/src/test/{echo.ts → echo.mts} +4 -4
  240. package/src/test/{pack.ts → pack.mts} +1 -1
  241. package/src/test/{performance.ts → performance.mts} +4 -4
  242. package/src/test/{pub.ts → pub.mts} +6 -6
  243. package/src/test/{pub2.ts → pub2.mts} +4 -4
  244. package/src/test/{reject.ts → reject.mts} +4 -4
  245. package/src/test/{services.ts → services.mts} +3 -3
  246. package/src/test/{stress.ts → stress.mts} +2 -2
  247. package/src/test/{timing.ts → timing.mts} +5 -5
  248. package/src/{worker.ts → worker.mts} +7 -7
  249. package/src/index.ts +0 -19
  250. package/src/run/all.ts +0 -14
  251. /package/src/{EbusClientEvents.ts → EbusClientEvents.mts} +0 -0
  252. /package/src/{EbusConfiguration.ts → EbusConfiguration.mts} +0 -0
  253. /package/src/{EbusRejectReason.ts → EbusRejectReason.mts} +0 -0
  254. /package/src/{EbusRequestOptions.ts → EbusRequestOptions.mts} +0 -0
  255. /package/src/{block.ts → block.mts} +0 -0
  256. /package/src/{deferredPromise.ts → deferredPromise.mts} +0 -0
  257. /package/src/run/{termimalCommands.ts → termimalCommands.mts} +0 -0
  258. /package/src/{sleep.ts → sleep.mts} +0 -0
  259. /package/src/src/{notepack.d.ts → notepack.d.mts} +0 -0
  260. /package/src/test/{index.ts → index.mts} +0 -0
  261. /package/src/{types.ts → types.mts} +0 -0
@@ -0,0 +1,108 @@
1
+ import { Log } from "cry-helpers";
2
+ import { Header, Message } from "./types.mjs";
3
+ const prefixes = ["EBUS_BROKER", "EBUS"];
4
+ const log = new Log(prefixes);
5
+ export class Service {
6
+ constructor(socket, name, log) {
7
+ this.workers = new Map();
8
+ this.loads = new Map();
9
+ this.heartbeats = new Map();
10
+ this.requests = [];
11
+ this.socket = socket;
12
+ this.name = name;
13
+ this.log = log;
14
+ this.dispatched = 0;
15
+ }
16
+ async dispatchRequest(reqId, client, timeout, opts, req) {
17
+ this.requests.push([client, req, reqId, opts, (new Date().valueOf() + timeout)]);
18
+ await this.dispatchPending();
19
+ }
20
+ async dispatchReply(type, worker, client, ...rep) {
21
+ this.workers.set(worker.toString("hex"), worker);
22
+ let load = (this.loads.get(worker.toString("hex")) || 0) - 1;
23
+ if (load < 0)
24
+ load = 0;
25
+ this.loads.set(worker.toString("hex"), load);
26
+ this.printLoad();
27
+ await this.socket.send([client, null, Header.Client, type, ...rep]);
28
+ this.dispatchPending();
29
+ }
30
+ printLoad() {
31
+ let workers = [...this.workers.values()].map(w => w.toString("hex")).sort();
32
+ let loads = [...this.workers.values()].map(w => w.toString("hex")).sort();
33
+ if (workers.join() !== loads.join()) {
34
+ log.error(`broker services workers/loads mismatch ${workers} / ${loads}`);
35
+ }
36
+ log.trace(workers.map(w => `${w}:\x1b[31m${this.loads.get(w)}\x1b[0m`).join(", "));
37
+ }
38
+ async dispatchPending() {
39
+ // purge time-outed requests
40
+ let now = new Date().valueOf();
41
+ this.requests = this.requests.filter(([v1, v2, v3, v4, until]) => until >= now);
42
+ while (this.workers.size && this.requests.length) {
43
+ // find least loaded worker
44
+ let least = 999999;
45
+ let worker = undefined;
46
+ for (let [key, val] of this.workers.entries()) {
47
+ let load = this.loads.get(val.toString("hex")) || 0;
48
+ if (load < least) {
49
+ worker = val;
50
+ least = load;
51
+ }
52
+ ;
53
+ }
54
+ if (!worker) {
55
+ log.info("no worker for " + this.name);
56
+ continue;
57
+ }
58
+ // const [key, worker] = this.workers.entries().next().value!
59
+ const [client, req, reqId, opts, until] = this.requests.shift();
60
+ //this.workers.delete(key)
61
+ this.dispatched++;
62
+ this.loads.set(worker.toString("hex"), (this.loads.get(worker.toString("hex")) || 0) + 1);
63
+ this.printLoad();
64
+ await this.socket.send([
65
+ worker,
66
+ null,
67
+ Header.Worker,
68
+ Message.Request,
69
+ client,
70
+ null,
71
+ reqId,
72
+ opts,
73
+ req,
74
+ ]);
75
+ }
76
+ }
77
+ register(worker) {
78
+ this.log.status(`broker registered new worker for ${this.name}`, worker);
79
+ this.workers.set(worker.toString("hex"), worker);
80
+ this.loads.set(worker.toString("hex"), 0);
81
+ this.updateHeartbeat(worker);
82
+ this.dispatchPending();
83
+ }
84
+ deregister(worker) {
85
+ this.log.status(`broker deregistered worker for ${this.name}`, worker);
86
+ this.workers.delete(worker.toString("hex"));
87
+ this.heartbeats.delete(worker.toString("hex"));
88
+ this.loads.delete(worker.toString("hex"));
89
+ this.dispatchPending();
90
+ }
91
+ updateHeartbeat(worker) {
92
+ this.heartbeats.set(worker.toString("hex"), new Date().valueOf());
93
+ this.returnHeartbeatToWorker(worker);
94
+ this.dispatchPending();
95
+ }
96
+ async returnHeartbeatToWorker(worker) {
97
+ await this.socket.send([
98
+ worker,
99
+ null,
100
+ Header.Worker,
101
+ Message.Heartbeat,
102
+ null,
103
+ null,
104
+ null,
105
+ ]);
106
+ }
107
+ }
108
+ //# sourceMappingURL=service.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service.mjs","sourceRoot":"","sources":["../src/service.mts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function sleep(msec: number, ret?: any): Promise<unknown>;
2
+ //# sourceMappingURL=sleep.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sleep.d.mts","sourceRoot":"","sources":["../src/sleep.mts"],"names":[],"mappings":"AAAA,wBAAsB,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,GAAG,oBAOlD"}
package/dist/sleep.mjs ADDED
@@ -0,0 +1,6 @@
1
+ export async function sleep(msec, ret) {
2
+ return new Promise(resolve => setTimeout(() => {
3
+ resolve(ret);
4
+ }, msec));
5
+ }
6
+ //# sourceMappingURL=sleep.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sleep.mjs","sourceRoot":"","sources":["../src/sleep.mts"],"names":[],"mappings":"AAAA,MAAM,CAAC,KAAK,UAAU,KAAK,CAAC,IAAY,EAAE,GAAS;IAC/C,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CACpC,GAAG,EAAE;QACD,OAAO,CAAC,GAAG,CAAC,CAAA;IAChB,CAAC,EACD,IAAI,CAAC,CACR,CAAC;AACN,CAAC"}
package/dist/sub.d.mts ADDED
@@ -0,0 +1,24 @@
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ import { TypedEmitter } from "tiny-typed-emitter";
3
+ import { Subscriber } from "zeromq";
4
+ import { EbusConfiguration } from "./EbusConfiguration.mjs";
5
+ export interface EbusSubscriptionEvent {
6
+ message: (message: [channel: string, message: any]) => void;
7
+ connect: () => void;
8
+ disconnect: () => void;
9
+ }
10
+ export declare class Sub extends TypedEmitter<EbusSubscriptionEvent> {
11
+ configuration: EbusConfiguration;
12
+ address: string;
13
+ sock: Subscriber;
14
+ interval: NodeJS.Timeout | undefined;
15
+ subscriptions: Set<string>;
16
+ constructor(config?: Partial<EbusConfiguration>);
17
+ private connect;
18
+ subscribe(channel: string): Promise<void>;
19
+ startReceiving(): Promise<never>;
20
+ private processMessage;
21
+ private onConnect;
22
+ private onDisconnect;
23
+ }
24
+ //# sourceMappingURL=sub.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sub.d.mts","sourceRoot":"","sources":["../src/sub.mts"],"names":[],"mappings":";AACA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAA;AACnC,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAA;AAO3D,MAAM,WAAW,qBAAqB;IAElC,OAAO,EAAE,CAAE,OAAO,EAAE,CAAC,OAAO,EAAC,MAAM,EAAE,OAAO,EAAC,GAAG,CAAC,KAAM,IAAI,CAAC;IAC5D,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,UAAU,EAAE,MAAM,IAAI,CAAC;CAC1B;AACD,qBAAa,GAAI,SAAQ,YAAY,CAAC,qBAAqB,CAAC;IAExD,aAAa,EAAE,iBAAiB,CAAA;IAChC,OAAO,EAAE,MAAM,CAAA;IACf,IAAI,EAAG,UAAU,CAAA;IACjB,QAAQ,EAAE,MAAM,CAAC,OAAO,GAAG,SAAS,CAAA;IACpC,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;gBAEd,MAAM,GAAE,OAAO,CAAC,iBAAiB,CAAM;YAOrC,OAAO;IAaf,SAAS,CAAC,OAAO,EAAE,MAAM;IAQzB,cAAc,IAAI,OAAO,CAAC,KAAK,CAAC;IAWtC,OAAO,CAAC,cAAc;IAWtB,OAAO,CAAC,SAAS;IAOjB,OAAO,CAAC,YAAY;CAKvB"}
package/dist/sub.mjs ADDED
@@ -0,0 +1,68 @@
1
+ import { Log } from "cry-helpers";
2
+ import { TypedEmitter } from "tiny-typed-emitter";
3
+ import { Subscriber } from "zeromq";
4
+ import { loadConfiguration } from "./loadConfiguration.mjs";
5
+ import { unpack } from "./serialize.mjs";
6
+ const prefixes = ["EBUS_SUB", "EBUS"];
7
+ const log = new Log(prefixes);
8
+ export class Sub extends TypedEmitter {
9
+ constructor(config = {}) {
10
+ super();
11
+ this.configuration = loadConfiguration(prefixes, config);
12
+ this.address = this.configuration.pubAddress;
13
+ this.subscriptions = new Set();
14
+ }
15
+ async connect() {
16
+ if (this.sock && !this.sock.closed) {
17
+ try {
18
+ this.sock.close();
19
+ }
20
+ catch (_a) { }
21
+ }
22
+ this.sock = new Subscriber;
23
+ this.sock.events.on("connect", () => this.onConnect());
24
+ this.sock.events.on("disconnect", () => this.onDisconnect());
25
+ this.sock.reconnectInterval = 100;
26
+ await this.sock.connect(this.address);
27
+ log.status("subscriber started on", this.address);
28
+ for await (let sub of this.subscriptions) {
29
+ await this.sock.subscribe(sub);
30
+ }
31
+ }
32
+ async subscribe(channel) {
33
+ this.subscriptions.add(channel);
34
+ if (this.sock)
35
+ await this.sock.subscribe(channel);
36
+ log.status("subscribed to ", channel);
37
+ }
38
+ async startReceiving() {
39
+ for (;;) {
40
+ await this.connect();
41
+ log.status("subscribe startReceiving()");
42
+ for await (const [channel, messagePacked] of this.sock) {
43
+ this.processMessage(messagePacked, channel);
44
+ }
45
+ }
46
+ }
47
+ processMessage(messagePacked, channel) {
48
+ let message = unpack(messagePacked, {});
49
+ log.debug(`sub message received on ${channel}`, message);
50
+ this.emit("message", [channel.toString(), message]);
51
+ if (channel.toString() === "ebus/stop") {
52
+ log.status("sub closing because ebus went offline");
53
+ this.sock.close();
54
+ }
55
+ return message;
56
+ }
57
+ onConnect() {
58
+ log.status("subscriber connected");
59
+ this.emit("message", ["ebus/start", "connect"]);
60
+ this.emit("connect");
61
+ }
62
+ onDisconnect() {
63
+ log.status("subscriber disconnected");
64
+ this.emit("message", ["ebus/stop", "disconnect"]);
65
+ this.emit("disconnect");
66
+ }
67
+ }
68
+ //# sourceMappingURL=sub.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sub.mjs","sourceRoot":"","sources":["../src/sub.mts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=config.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.mts","sourceRoot":"","sources":["../../src/test/config.mts"],"names":[],"mappings":""}
@@ -0,0 +1,23 @@
1
+ import { expect } from "chai";
2
+ import { Client } from "../client.mjs";
3
+ import { EchoWorker } from "../echoWorker.mjs";
4
+ import { Broker } from "../index.mjs";
5
+ describe('services', async function () {
6
+ this.timeout(4000);
7
+ process.env.ebus_server = "tcp://localhost";
8
+ process.env.ebus_port = "4444";
9
+ let broker = new Broker();
10
+ broker.start();
11
+ let worker = new EchoWorker();
12
+ worker.start();
13
+ let client = new Client();
14
+ it('should be at right port', async () => {
15
+ expect(broker.configuration.address).to.match(/:4444$/);
16
+ expect(worker.configuration.address).to.match(/:4444$/);
17
+ expect(client.configuration.address).to.match(/:4444$/);
18
+ });
19
+ it('exists', () => {
20
+ process.exit();
21
+ });
22
+ });
23
+ //# sourceMappingURL=config.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.mjs","sourceRoot":"","sources":["../../src/test/config.mts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAC9B,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAe,MAAM,cAAc,CAAC;AAEnD,QAAQ,CAAC,UAAU,EAAE,KAAK;IAEtB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;IAElB,OAAO,CAAC,GAAG,CAAC,WAAW,GAAG,iBAAiB,CAAA;IAC3C,OAAO,CAAC,GAAG,CAAC,SAAS,GAAG,MAAM,CAAA;IAE9B,IAAI,MAAM,GAAG,IAAI,MAAM,EAAE,CAAA;IACzB,MAAM,CAAC,KAAK,EAAE,CAAA;IACd,IAAI,MAAM,GAAG,IAAI,UAAU,EAAE,CAAA;IAC7B,MAAM,CAAC,KAAK,EAAE,CAAA;IACd,IAAI,MAAM,GAAG,IAAI,MAAM,EAAE,CAAA;IAGzB,EAAE,CAAC,yBAAyB,EAAE,KAAK,IAAI,EAAE;QACrC,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QACvD,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QACvD,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;IAC3D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;QACd,OAAO,CAAC,IAAI,EAAE,CAAA;IAClB,CAAC,CAAC,CAAA;AAEN,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=echo.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"echo.d.mts","sourceRoot":"","sources":["../../src/test/echo.mts"],"names":[],"mappings":""}
@@ -0,0 +1,54 @@
1
+ import { expect } from "chai";
2
+ import { Client } from "../client.mjs";
3
+ import { EchoWorker } from "../echoWorker.mjs";
4
+ import { Broker, DelayWorker, unpack, pack } from "../index.mjs";
5
+ describe('echo worker', async function () {
6
+ this.timeout(60000);
7
+ new Broker().start();
8
+ new EchoWorker().start();
9
+ new DelayWorker().start();
10
+ let client = new Client();
11
+ it('should return passed-in object', async () => {
12
+ let rep = await client.request("echo", {
13
+ delay: 50,
14
+ }, { receiveTimeout: 120000 });
15
+ expect(rep === null || rep === void 0 ? void 0 : rep.delay).to.eq(50);
16
+ });
17
+ it('should return passed-in object zipped', async () => {
18
+ let rep = await client.request("delay", { delay: 50 }, { zip: true, receiveTimeout: 120000 });
19
+ expect(rep === null || rep === void 0 ? void 0 : rep.delay).to.eq(50);
20
+ });
21
+ it('should return passed-in object raw', async () => {
22
+ let load = Buffer.from("ABC");
23
+ let rep = await client.request("echo", load, { raw: true });
24
+ expect(rep === null || rep === void 0 ? void 0 : rep.toString()).to.eq("ABC");
25
+ });
26
+ it('should return passed-in object raw and zipped', async () => {
27
+ let load = Buffer.from("ABC");
28
+ let rep = await client.request("echo", load, { raw: true, zip: true });
29
+ expect(Buffer.from(rep).toString()).to.eq("ABC");
30
+ });
31
+ it('should return unpacked object', async () => {
32
+ let load = Buffer.from("ABC");
33
+ let res = (await client.requestUpacked("echo", load, { raw: true, zip: true, }));
34
+ let rep = unpack(res.data, res.opts);
35
+ expect(Buffer.from(rep).toString()).to.eq("ABC");
36
+ });
37
+ it('should accept externally prepacked object', async () => {
38
+ let load = { a: { b: 2 } };
39
+ let loadPrepacked = pack(load, { zip: true });
40
+ let rep = (await client.request("echo", loadPrepacked, { prepacked: true, zip: true, receiveTimeout: 30000 }));
41
+ expect(rep.a.b).to.eq(2);
42
+ });
43
+ it('should accept externally prepacked object', async () => {
44
+ let load = { a: { b: 2 } };
45
+ let loadPrepacked = pack(load, { zip: true });
46
+ let res = (await client.requestUpacked("echo", loadPrepacked, { prepacked: true, zip: true, receiveTimeout: 30000 }));
47
+ let rep = unpack(res.data, res.opts);
48
+ expect(rep.a.b).to.eq(2);
49
+ });
50
+ it('exists', () => {
51
+ process.exit();
52
+ });
53
+ });
54
+ //# sourceMappingURL=echo.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"echo.mjs","sourceRoot":"","sources":["../../src/test/echo.mts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.mts","sourceRoot":"","sources":["../../src/test/index.mts"],"names":[],"mappings":""}
@@ -0,0 +1,47 @@
1
+ // import { Broker } from "../broker"
2
+ // import { Client } from "../client"
3
+ // import { Worker } from "../worker"
4
+ export {};
5
+ // async function sleep(msec: number) {
6
+ // return new Promise(resolve => setTimeout(resolve, msec))
7
+ // }
8
+ // class TeaWorker extends Worker {
9
+ // service = "tea"
10
+ // async process(msg: Buffer): Promise<string> {
11
+ // await sleep(Math.random() * 100)
12
+ // return msg.toString()
13
+ // }
14
+ // }
15
+ // class CoffeeWorker extends Worker {
16
+ // service = "coffee"
17
+ // async process(msgs: Buffer): Promise<string> {
18
+ // await sleep(Math.random() * 200)
19
+ // return msgs.toString()
20
+ // }
21
+ // }
22
+ // const broker = new Broker()
23
+ // const workers = [new TeaWorker(), /* new CoffeeWorker(), new TeaWorker() */]
24
+ // let client = new Client()
25
+ // async function main() {
26
+ // for (const worker of workers) worker.start()
27
+ // broker.start()
28
+ // /* Requests are issued in parallel. */
29
+ // await Promise.all([
30
+ // client.request("soda", "cola", { zip: true, receiveTimeout:1 } ),
31
+ // client.request("tea", "oolong", { zip: true }),
32
+ // client.request("tea", "sencha"),
33
+ // client.request("tea", "earl grey"),
34
+ // client.request("tea", "jasmine"),
35
+ // client.request("coffee", "cappuccino"),
36
+ // client.request("coffee", "latte"),
37
+ // client.request("coffee", "espresso"),
38
+ // client.request("coffee", "irish coffee"),
39
+ // ])
40
+ // for (const worker of workers) worker.stop()
41
+ // broker.stop()
42
+ // }
43
+ // main().catch(err => {
44
+ // console.error(err)
45
+ // process.exit(1)
46
+ // })
47
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sourceRoot":"","sources":["../../src/test/index.mts"],"names":[],"mappings":"AAAA,qCAAqC;AACrC,qCAAqC;AACrC,qCAAqC;;AAErC,uCAAuC;AACvC,+DAA+D;AAC/D,IAAI;AAEJ,mCAAmC;AACnC,sBAAsB;AAEtB,oDAAoD;AACpD,2CAA2C;AAC3C,gCAAgC;AAChC,QAAQ;AACR,IAAI;AAEJ,sCAAsC;AACtC,yBAAyB;AAEzB,qDAAqD;AACrD,2CAA2C;AAC3C,iCAAiC;AACjC,QAAQ;AACR,IAAI;AAEJ,8BAA8B;AAC9B,+EAA+E;AAE/E,4BAA4B;AAE5B,0BAA0B;AAC1B,mDAAmD;AACnD,qBAAqB;AAErB,6CAA6C;AAC7C,0BAA0B;AAC1B,4EAA4E;AAC5E,0DAA0D;AAC1D,2CAA2C;AAC3C,8CAA8C;AAC9C,4CAA4C;AAC5C,kDAAkD;AAClD,6CAA6C;AAC7C,gDAAgD;AAChD,oDAAoD;AACpD,SAAS;AAET,kDAAkD;AAClD,oBAAoB;AACpB,IAAI;AAEJ,wBAAwB;AACxB,yBAAyB;AACzB,sBAAsB;AACtB,KAAK"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=pack.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pack.d.mts","sourceRoot":"","sources":["../../src/test/pack.mts"],"names":[],"mappings":""}