cry-ebus2 3.1.12 → 3.1.13
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/package.json +2 -1
- package/tsconfig.json +1 -1
- package/dist/EbusClientEvents.d.ts +0 -5
- package/dist/EbusClientEvents.d.ts.map +0 -1
- package/dist/EbusClientEvents.js +0 -3
- package/dist/EbusClientEvents.js.map +0 -1
- package/dist/EbusConfiguration.d.ts +0 -17
- package/dist/EbusConfiguration.d.ts.map +0 -1
- package/dist/EbusConfiguration.js +0 -3
- package/dist/EbusConfiguration.js.map +0 -1
- package/dist/EbusReject.d.ts +0 -11
- package/dist/EbusReject.d.ts.map +0 -1
- package/dist/EbusReject.js +0 -16
- package/dist/EbusReject.js.map +0 -1
- package/dist/EbusRejectReason.d.ts +0 -2
- package/dist/EbusRejectReason.d.ts.map +0 -1
- package/dist/EbusRejectReason.js +0 -3
- package/dist/EbusRejectReason.js.map +0 -1
- package/dist/EbusRequestOptions.d.ts +0 -8
- package/dist/EbusRequestOptions.d.ts.map +0 -1
- package/dist/EbusRequestOptions.js +0 -3
- package/dist/EbusRequestOptions.js.map +0 -1
- package/dist/EbusUnpackedResult.d.ts +0 -10
- package/dist/EbusUnpackedResult.d.ts.map +0 -1
- package/dist/EbusUnpackedResult.js +0 -23
- package/dist/EbusUnpackedResult.js.map +0 -1
- package/dist/block.d.ts +0 -2
- package/dist/block.d.ts.map +0 -1
- package/dist/block.js +0 -10
- package/dist/block.js.map +0 -1
- package/dist/broker.d.ts +0 -42
- package/dist/broker.d.ts.map +0 -1
- package/dist/broker.js +0 -292
- package/dist/broker.js.map +0 -1
- package/dist/client.d.ts +0 -2
- package/dist/client.d.ts.map +0 -1
- package/dist/client.js +0 -6
- package/dist/client.js.map +0 -1
- package/dist/clientBlocking.d.ts +0 -27
- package/dist/clientBlocking.d.ts.map +0 -1
- package/dist/clientBlocking.js +0 -177
- package/dist/clientBlocking.js.map +0 -1
- package/dist/clientNonBlocking.d.ts +0 -46
- package/dist/clientNonBlocking.d.ts.map +0 -1
- package/dist/clientNonBlocking.js +0 -264
- package/dist/clientNonBlocking.js.map +0 -1
- package/dist/consts.d.ts +0 -3
- package/dist/consts.d.ts.map +0 -1
- package/dist/consts.js +0 -20
- package/dist/consts.js.map +0 -1
- package/dist/deferredPromise.d.ts +0 -36
- package/dist/deferredPromise.d.ts.map +0 -1
- package/dist/deferredPromise.js +0 -59
- package/dist/deferredPromise.js.map +0 -1
- package/dist/delayWorker.d.ts +0 -10
- package/dist/delayWorker.d.ts.map +0 -1
- package/dist/delayWorker.js +0 -21
- package/dist/delayWorker.js.map +0 -1
- package/dist/echoWorker.d.ts +0 -6
- package/dist/echoWorker.d.ts.map +0 -1
- package/dist/echoWorker.js +0 -19
- package/dist/echoWorker.js.map +0 -1
- package/dist/errorWorker.d.ts +0 -11
- package/dist/errorWorker.d.ts.map +0 -1
- package/dist/errorWorker.js +0 -18
- package/dist/errorWorker.js.map +0 -1
- package/dist/index.d.ts +0 -19
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -34
- package/dist/index.js.map +0 -1
- package/dist/loadConfiguration.d.ts +0 -3
- package/dist/loadConfiguration.d.ts.map +0 -1
- package/dist/loadConfiguration.js +0 -13
- package/dist/loadConfiguration.js.map +0 -1
- package/dist/pub.d.ts +0 -11
- package/dist/pub.d.ts.map +0 -1
- package/dist/pub.js +0 -26
- package/dist/pub.js.map +0 -1
- package/dist/rejectWorker.d.ts +0 -11
- package/dist/rejectWorker.d.ts.map +0 -1
- package/dist/rejectWorker.js +0 -18
- package/dist/rejectWorker.js.map +0 -1
- package/dist/run/all.d.ts +0 -2
- package/dist/run/all.d.ts.map +0 -1
- package/dist/run/all.js +0 -15
- package/dist/run/all.js.map +0 -1
- package/dist/run/broker.d.mts +0 -2
- package/dist/run/broker.d.mts.map +0 -1
- package/dist/run/broker.mjs +0 -7
- package/dist/run/broker.mjs.map +0 -1
- package/dist/run/call.d.ts +0 -2
- package/dist/run/call.d.ts.map +0 -1
- package/dist/run/call.js +0 -78
- package/dist/run/call.js.map +0 -1
- package/dist/run/calling.d.ts +0 -2
- package/dist/run/calling.d.ts.map +0 -1
- package/dist/run/calling.js +0 -96
- package/dist/run/calling.js.map +0 -1
- package/dist/run/callingBurst.d.ts +0 -2
- package/dist/run/callingBurst.d.ts.map +0 -1
- package/dist/run/callingBurst.js +0 -43
- package/dist/run/callingBurst.js.map +0 -1
- package/dist/run/delay.d.mts +0 -2
- package/dist/run/delay.d.mts.map +0 -1
- package/dist/run/delay.mjs +0 -7
- package/dist/run/delay.mjs.map +0 -1
- package/dist/run/echo.d.mts +0 -2
- package/dist/run/echo.d.mts.map +0 -1
- package/dist/run/echo.mjs +0 -7
- package/dist/run/echo.mjs.map +0 -1
- package/dist/run/error.d.mts +0 -2
- package/dist/run/error.d.mts.map +0 -1
- package/dist/run/error.mjs +0 -7
- package/dist/run/error.mjs.map +0 -1
- package/dist/run/ping.d.mts +0 -2
- package/dist/run/ping.d.mts.map +0 -1
- package/dist/run/ping.mjs +0 -71
- package/dist/run/ping.mjs.map +0 -1
- package/dist/run/pub.d.ts +0 -2
- package/dist/run/pub.d.ts.map +0 -1
- package/dist/run/pub.js +0 -30
- package/dist/run/pub.js.map +0 -1
- package/dist/run/reject.d.ts +0 -2
- package/dist/run/reject.d.ts.map +0 -1
- package/dist/run/reject.js +0 -7
- package/dist/run/reject.js.map +0 -1
- package/dist/run/sub.d.ts +0 -2
- package/dist/run/sub.d.ts.map +0 -1
- package/dist/run/sub.js +0 -93
- package/dist/run/sub.js.map +0 -1
- package/dist/run/termimalCommands.d.ts +0 -33
- package/dist/run/termimalCommands.d.ts.map +0 -1
- package/dist/run/termimalCommands.js +0 -35
- package/dist/run/termimalCommands.js.map +0 -1
- package/dist/run/workers.d.ts +0 -2
- package/dist/run/workers.d.ts.map +0 -1
- package/dist/run/workers.js +0 -38
- package/dist/run/workers.js.map +0 -1
- package/dist/serialize.d.ts +0 -4
- package/dist/serialize.d.ts.map +0 -1
- package/dist/serialize.js +0 -34
- package/dist/serialize.js.map +0 -1
- package/dist/service.d.ts +0 -23
- package/dist/service.d.ts.map +0 -1
- package/dist/service.js +0 -112
- package/dist/service.js.map +0 -1
- package/dist/sleep.d.ts +0 -2
- package/dist/sleep.d.ts.map +0 -1
- package/dist/sleep.js +0 -10
- package/dist/sleep.js.map +0 -1
- package/dist/sub.d.ts +0 -24
- package/dist/sub.d.ts.map +0 -1
- package/dist/sub.js +0 -72
- package/dist/sub.js.map +0 -1
- package/dist/test/config.d.ts +0 -2
- package/dist/test/config.d.ts.map +0 -1
- package/dist/test/config.js +0 -25
- package/dist/test/config.js.map +0 -1
- package/dist/test/echo.d.ts +0 -2
- package/dist/test/echo.d.ts.map +0 -1
- package/dist/test/echo.js +0 -56
- package/dist/test/echo.js.map +0 -1
- package/dist/test/index.d.ts +0 -1
- package/dist/test/index.d.ts.map +0 -1
- package/dist/test/index.js +0 -47
- package/dist/test/index.js.map +0 -1
- package/dist/test/pack.d.ts +0 -2
- package/dist/test/pack.d.ts.map +0 -1
- package/dist/test/pack.js +0 -1446
- package/dist/test/pack.js.map +0 -1
- package/dist/test/performance.d.ts +0 -2
- package/dist/test/performance.d.ts.map +0 -1
- package/dist/test/performance.js +0 -46
- package/dist/test/performance.js.map +0 -1
- package/dist/test/pub.d.ts +0 -2
- package/dist/test/pub.d.ts.map +0 -1
- package/dist/test/pub.js +0 -59
- package/dist/test/pub.js.map +0 -1
- package/dist/test/pub2.d.ts +0 -2
- package/dist/test/pub2.d.ts.map +0 -1
- package/dist/test/pub2.js +0 -25
- package/dist/test/pub2.js.map +0 -1
- package/dist/test/reject.d.ts +0 -2
- package/dist/test/reject.d.ts.map +0 -1
- package/dist/test/reject.js +0 -35
- package/dist/test/reject.js.map +0 -1
- package/dist/test/services.d.ts +0 -2
- package/dist/test/services.d.ts.map +0 -1
- package/dist/test/services.js +0 -46
- package/dist/test/services.js.map +0 -1
- package/dist/test/stress.d.ts +0 -2
- package/dist/test/stress.d.ts.map +0 -1
- package/dist/test/stress.js +0 -28
- package/dist/test/stress.js.map +0 -1
- package/dist/test/timing.d.ts +0 -2
- package/dist/test/timing.d.ts.map +0 -1
- package/dist/test/timing.js +0 -70
- package/dist/test/timing.js.map +0 -1
- package/dist/types.d.ts +0 -23
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js +0 -28
- package/dist/types.js.map +0 -1
- package/dist/worker.d.ts +0 -27
- package/dist/worker.d.ts.map +0 -1
- package/dist/worker.js +0 -223
- package/dist/worker.js.map +0 -1
package/dist/service.js
DELETED
|
@@ -1,112 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Service = void 0;
|
|
4
|
-
const cry_helpers_1 = require("cry-helpers");
|
|
5
|
-
const types_js_1 = require("./types.js");
|
|
6
|
-
const prefixes = ["EBUS_BROKER", "EBUS"];
|
|
7
|
-
const log = new cry_helpers_1.Log(prefixes);
|
|
8
|
-
class Service {
|
|
9
|
-
constructor(socket, name, log) {
|
|
10
|
-
this.workers = new Map();
|
|
11
|
-
this.loads = new Map();
|
|
12
|
-
this.heartbeats = new Map();
|
|
13
|
-
this.requests = [];
|
|
14
|
-
this.socket = socket;
|
|
15
|
-
this.name = name;
|
|
16
|
-
this.log = log;
|
|
17
|
-
this.dispatched = 0;
|
|
18
|
-
}
|
|
19
|
-
async dispatchRequest(reqId, client, timeout, opts, req) {
|
|
20
|
-
this.requests.push([client, req, reqId, opts, (new Date().valueOf() + timeout)]);
|
|
21
|
-
await this.dispatchPending();
|
|
22
|
-
}
|
|
23
|
-
async dispatchReply(type, worker, client, ...rep) {
|
|
24
|
-
this.workers.set(worker.toString("hex"), worker);
|
|
25
|
-
let load = (this.loads.get(worker.toString("hex")) || 0) - 1;
|
|
26
|
-
if (load < 0)
|
|
27
|
-
load = 0;
|
|
28
|
-
this.loads.set(worker.toString("hex"), load);
|
|
29
|
-
this.printLoad();
|
|
30
|
-
await this.socket.send([client, null, types_js_1.Header.Client, type, ...rep]);
|
|
31
|
-
this.dispatchPending();
|
|
32
|
-
}
|
|
33
|
-
printLoad() {
|
|
34
|
-
let workers = [...this.workers.values()].map(w => w.toString("hex")).sort();
|
|
35
|
-
let loads = [...this.workers.values()].map(w => w.toString("hex")).sort();
|
|
36
|
-
if (workers.join() !== loads.join()) {
|
|
37
|
-
log.error(`broker services workers/loads mismatch ${workers} / ${loads}`);
|
|
38
|
-
}
|
|
39
|
-
log.trace(workers.map(w => `${w}:\x1b[31m${this.loads.get(w)}\x1b[0m`).join(", "));
|
|
40
|
-
}
|
|
41
|
-
async dispatchPending() {
|
|
42
|
-
// purge time-outed requests
|
|
43
|
-
let now = new Date().valueOf();
|
|
44
|
-
this.requests = this.requests.filter(([v1, v2, v3, v4, until]) => until >= now);
|
|
45
|
-
while (this.workers.size && this.requests.length) {
|
|
46
|
-
// find least loaded worker
|
|
47
|
-
let least = 999999;
|
|
48
|
-
let worker = undefined;
|
|
49
|
-
for (let [key, val] of this.workers.entries()) {
|
|
50
|
-
let load = this.loads.get(val.toString("hex")) || 0;
|
|
51
|
-
if (load < least) {
|
|
52
|
-
worker = val;
|
|
53
|
-
least = load;
|
|
54
|
-
}
|
|
55
|
-
;
|
|
56
|
-
}
|
|
57
|
-
if (!worker) {
|
|
58
|
-
log.info("no worker for " + this.name);
|
|
59
|
-
continue;
|
|
60
|
-
}
|
|
61
|
-
// const [key, worker] = this.workers.entries().next().value!
|
|
62
|
-
const [client, req, reqId, opts, until] = this.requests.shift();
|
|
63
|
-
//this.workers.delete(key)
|
|
64
|
-
this.dispatched++;
|
|
65
|
-
this.loads.set(worker.toString("hex"), (this.loads.get(worker.toString("hex")) || 0) + 1);
|
|
66
|
-
this.printLoad();
|
|
67
|
-
await this.socket.send([
|
|
68
|
-
worker,
|
|
69
|
-
null,
|
|
70
|
-
types_js_1.Header.Worker,
|
|
71
|
-
types_js_1.Message.Request,
|
|
72
|
-
client,
|
|
73
|
-
null,
|
|
74
|
-
reqId,
|
|
75
|
-
opts,
|
|
76
|
-
req,
|
|
77
|
-
]);
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
register(worker) {
|
|
81
|
-
this.log.status(`broker registered new worker for ${this.name}`, worker);
|
|
82
|
-
this.workers.set(worker.toString("hex"), worker);
|
|
83
|
-
this.loads.set(worker.toString("hex"), 0);
|
|
84
|
-
this.updateHeartbeat(worker);
|
|
85
|
-
this.dispatchPending();
|
|
86
|
-
}
|
|
87
|
-
deregister(worker) {
|
|
88
|
-
this.log.status(`broker deregistered worker for ${this.name}`, worker);
|
|
89
|
-
this.workers.delete(worker.toString("hex"));
|
|
90
|
-
this.heartbeats.delete(worker.toString("hex"));
|
|
91
|
-
this.loads.delete(worker.toString("hex"));
|
|
92
|
-
this.dispatchPending();
|
|
93
|
-
}
|
|
94
|
-
updateHeartbeat(worker) {
|
|
95
|
-
this.heartbeats.set(worker.toString("hex"), new Date().valueOf());
|
|
96
|
-
this.returnHeartbeatToWorker(worker);
|
|
97
|
-
this.dispatchPending();
|
|
98
|
-
}
|
|
99
|
-
async returnHeartbeatToWorker(worker) {
|
|
100
|
-
await this.socket.send([
|
|
101
|
-
worker,
|
|
102
|
-
null,
|
|
103
|
-
types_js_1.Header.Worker,
|
|
104
|
-
types_js_1.Message.Heartbeat,
|
|
105
|
-
null,
|
|
106
|
-
null,
|
|
107
|
-
null,
|
|
108
|
-
]);
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
exports.Service = Service;
|
|
112
|
-
//# sourceMappingURL=service.js.map
|
package/dist/service.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"service.js","sourceRoot":"","sources":["../src/service.ts"],"names":[],"mappings":"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"}
|
package/dist/sleep.d.ts
DELETED
package/dist/sleep.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sleep.d.ts","sourceRoot":"","sources":["../src/sleep.ts"],"names":[],"mappings":"AAAA,wBAAsB,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,GAAG,oBAOlD"}
|
package/dist/sleep.js
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.sleep = void 0;
|
|
4
|
-
async function sleep(msec, ret) {
|
|
5
|
-
return new Promise(resolve => setTimeout(() => {
|
|
6
|
-
resolve(ret);
|
|
7
|
-
}, msec));
|
|
8
|
-
}
|
|
9
|
-
exports.sleep = sleep;
|
|
10
|
-
//# sourceMappingURL=sleep.js.map
|
package/dist/sleep.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sleep.js","sourceRoot":"","sources":["../src/sleep.ts"],"names":[],"mappings":";;;AAAO,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;AAPD,sBAOC"}
|
package/dist/sub.d.ts
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
import { TypedEmitter } from "tiny-typed-emitter";
|
|
3
|
-
import { Subscriber } from "zeromq";
|
|
4
|
-
import { EbusConfiguration } from "./EbusConfiguration.js";
|
|
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.ts.map
|
package/dist/sub.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sub.d.ts","sourceRoot":"","sources":["../src/sub.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAA;AACnC,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAO1D,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.js
DELETED
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Sub = void 0;
|
|
4
|
-
const cry_helpers_1 = require("cry-helpers");
|
|
5
|
-
const tiny_typed_emitter_1 = require("tiny-typed-emitter");
|
|
6
|
-
const zeromq_1 = require("zeromq");
|
|
7
|
-
const loadConfiguration_js_1 = require("./loadConfiguration.js");
|
|
8
|
-
const serialize_js_1 = require("./serialize.js");
|
|
9
|
-
const prefixes = ["EBUS_SUB", "EBUS"];
|
|
10
|
-
const log = new cry_helpers_1.Log(prefixes);
|
|
11
|
-
class Sub extends tiny_typed_emitter_1.TypedEmitter {
|
|
12
|
-
constructor(config = {}) {
|
|
13
|
-
super();
|
|
14
|
-
this.configuration = (0, loadConfiguration_js_1.loadConfiguration)(prefixes, config);
|
|
15
|
-
this.address = this.configuration.pubAddress;
|
|
16
|
-
this.subscriptions = new Set();
|
|
17
|
-
}
|
|
18
|
-
async connect() {
|
|
19
|
-
if (this.sock && !this.sock.closed) {
|
|
20
|
-
try {
|
|
21
|
-
this.sock.close();
|
|
22
|
-
}
|
|
23
|
-
catch (_a) { }
|
|
24
|
-
}
|
|
25
|
-
this.sock = new zeromq_1.Subscriber;
|
|
26
|
-
this.sock.events.on("connect", () => this.onConnect());
|
|
27
|
-
this.sock.events.on("disconnect", () => this.onDisconnect());
|
|
28
|
-
this.sock.reconnectInterval = 100;
|
|
29
|
-
await this.sock.connect(this.address);
|
|
30
|
-
log.status("subscriber started on", this.address);
|
|
31
|
-
for await (let sub of this.subscriptions) {
|
|
32
|
-
await this.sock.subscribe(sub);
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
async subscribe(channel) {
|
|
36
|
-
this.subscriptions.add(channel);
|
|
37
|
-
if (this.sock)
|
|
38
|
-
await this.sock.subscribe(channel);
|
|
39
|
-
log.status("subscribed to ", channel);
|
|
40
|
-
}
|
|
41
|
-
async startReceiving() {
|
|
42
|
-
for (;;) {
|
|
43
|
-
await this.connect();
|
|
44
|
-
log.status("subscribe startReceiving()");
|
|
45
|
-
for await (const [channel, messagePacked] of this.sock) {
|
|
46
|
-
this.processMessage(messagePacked, channel);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
processMessage(messagePacked, channel) {
|
|
51
|
-
let message = (0, serialize_js_1.unpack)(messagePacked, {});
|
|
52
|
-
log.debug(`sub message received on ${channel}`, message);
|
|
53
|
-
this.emit("message", [channel.toString(), message]);
|
|
54
|
-
if (channel.toString() === "ebus/stop") {
|
|
55
|
-
log.status("sub closing because ebus went offline");
|
|
56
|
-
this.sock.close();
|
|
57
|
-
}
|
|
58
|
-
return message;
|
|
59
|
-
}
|
|
60
|
-
onConnect() {
|
|
61
|
-
log.status("subscriber connected");
|
|
62
|
-
this.emit("message", ["ebus/start", "connect"]);
|
|
63
|
-
this.emit("connect");
|
|
64
|
-
}
|
|
65
|
-
onDisconnect() {
|
|
66
|
-
log.status("subscriber disconnected");
|
|
67
|
-
this.emit("message", ["ebus/stop", "disconnect"]);
|
|
68
|
-
this.emit("disconnect");
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
exports.Sub = Sub;
|
|
72
|
-
//# sourceMappingURL=sub.js.map
|
package/dist/sub.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sub.js","sourceRoot":"","sources":["../src/sub.ts"],"names":[],"mappings":"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"}
|
package/dist/test/config.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/test/config.ts"],"names":[],"mappings":""}
|
package/dist/test/config.js
DELETED
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const chai_1 = require("chai");
|
|
4
|
-
const client_js_1 = require("../client.js");
|
|
5
|
-
const echoWorker_js_1 = require("../echoWorker.js");
|
|
6
|
-
const index_js_1 = require("../index.js");
|
|
7
|
-
describe('services', async function () {
|
|
8
|
-
this.timeout(4000);
|
|
9
|
-
process.env.ebus_server = "tcp://localhost";
|
|
10
|
-
process.env.ebus_port = "4444";
|
|
11
|
-
let broker = new index_js_1.Broker();
|
|
12
|
-
broker.start();
|
|
13
|
-
let worker = new echoWorker_js_1.EchoWorker();
|
|
14
|
-
worker.start();
|
|
15
|
-
let client = new client_js_1.Client();
|
|
16
|
-
it('should be at right port', async () => {
|
|
17
|
-
(0, chai_1.expect)(broker.configuration.address).to.match(/:4444$/);
|
|
18
|
-
(0, chai_1.expect)(worker.configuration.address).to.match(/:4444$/);
|
|
19
|
-
(0, chai_1.expect)(client.configuration.address).to.match(/:4444$/);
|
|
20
|
-
});
|
|
21
|
-
it('exists', () => {
|
|
22
|
-
process.exit();
|
|
23
|
-
});
|
|
24
|
-
});
|
|
25
|
-
//# sourceMappingURL=config.js.map
|
package/dist/test/config.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/test/config.ts"],"names":[],"mappings":";;AACA,+BAA8B;AAC9B,4CAAsC;AACtC,oDAA8C;AAC9C,0CAAkD;AAElD,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,iBAAM,EAAE,CAAA;IACzB,MAAM,CAAC,KAAK,EAAE,CAAA;IACd,IAAI,MAAM,GAAG,IAAI,0BAAU,EAAE,CAAA;IAC7B,MAAM,CAAC,KAAK,EAAE,CAAA;IACd,IAAI,MAAM,GAAG,IAAI,kBAAM,EAAE,CAAA;IAGzB,EAAE,CAAC,yBAAyB,EAAE,KAAK,IAAI,EAAE;QACrC,IAAA,aAAM,EAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QACvD,IAAA,aAAM,EAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QACvD,IAAA,aAAM,EAAC,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"}
|
package/dist/test/echo.d.ts
DELETED
package/dist/test/echo.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"echo.d.ts","sourceRoot":"","sources":["../../src/test/echo.ts"],"names":[],"mappings":""}
|
package/dist/test/echo.js
DELETED
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const chai_1 = require("chai");
|
|
4
|
-
const client_js_1 = require("../client.js");
|
|
5
|
-
const echoWorker_js_1 = require("../echoWorker.js");
|
|
6
|
-
const index_js_1 = require("../index.js");
|
|
7
|
-
describe('echo worker', async function () {
|
|
8
|
-
this.timeout(60000);
|
|
9
|
-
new index_js_1.Broker().start();
|
|
10
|
-
new echoWorker_js_1.EchoWorker().start();
|
|
11
|
-
new index_js_1.DelayWorker().start();
|
|
12
|
-
let client = new client_js_1.Client();
|
|
13
|
-
it('should return passed-in object', async () => {
|
|
14
|
-
let rep = await client.request("echo", {
|
|
15
|
-
delay: 50,
|
|
16
|
-
}, { receiveTimeout: 120000 });
|
|
17
|
-
(0, chai_1.expect)(rep === null || rep === void 0 ? void 0 : rep.delay).to.eq(50);
|
|
18
|
-
});
|
|
19
|
-
it('should return passed-in object zipped', async () => {
|
|
20
|
-
let rep = await client.request("delay", { delay: 50 }, { zip: true, receiveTimeout: 120000 });
|
|
21
|
-
(0, chai_1.expect)(rep === null || rep === void 0 ? void 0 : rep.delay).to.eq(50);
|
|
22
|
-
});
|
|
23
|
-
it('should return passed-in object raw', async () => {
|
|
24
|
-
let load = Buffer.from("ABC");
|
|
25
|
-
let rep = await client.request("echo", load, { raw: true });
|
|
26
|
-
(0, chai_1.expect)(rep === null || rep === void 0 ? void 0 : rep.toString()).to.eq("ABC");
|
|
27
|
-
});
|
|
28
|
-
it('should return passed-in object raw and zipped', async () => {
|
|
29
|
-
let load = Buffer.from("ABC");
|
|
30
|
-
let rep = await client.request("echo", load, { raw: true, zip: true });
|
|
31
|
-
(0, chai_1.expect)(Buffer.from(rep).toString()).to.eq("ABC");
|
|
32
|
-
});
|
|
33
|
-
it('should return unpacked object', async () => {
|
|
34
|
-
let load = Buffer.from("ABC");
|
|
35
|
-
let res = (await client.requestUpacked("echo", load, { raw: true, zip: true, }));
|
|
36
|
-
let rep = (0, index_js_1.unpack)(res.data, res.opts);
|
|
37
|
-
(0, chai_1.expect)(Buffer.from(rep).toString()).to.eq("ABC");
|
|
38
|
-
});
|
|
39
|
-
it('should accept externally prepacked object', async () => {
|
|
40
|
-
let load = { a: { b: 2 } };
|
|
41
|
-
let loadPrepacked = (0, index_js_1.pack)(load, { zip: true });
|
|
42
|
-
let rep = (await client.request("echo", loadPrepacked, { prepacked: true, zip: true, receiveTimeout: 30000 }));
|
|
43
|
-
(0, chai_1.expect)(rep.a.b).to.eq(2);
|
|
44
|
-
});
|
|
45
|
-
it('should accept externally prepacked object', async () => {
|
|
46
|
-
let load = { a: { b: 2 } };
|
|
47
|
-
let loadPrepacked = (0, index_js_1.pack)(load, { zip: true });
|
|
48
|
-
let res = (await client.requestUpacked("echo", loadPrepacked, { prepacked: true, zip: true, receiveTimeout: 30000 }));
|
|
49
|
-
let rep = (0, index_js_1.unpack)(res.data, res.opts);
|
|
50
|
-
(0, chai_1.expect)(rep.a.b).to.eq(2);
|
|
51
|
-
});
|
|
52
|
-
it('exists', () => {
|
|
53
|
-
process.exit();
|
|
54
|
-
});
|
|
55
|
-
});
|
|
56
|
-
//# sourceMappingURL=echo.js.map
|
package/dist/test/echo.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"echo.js","sourceRoot":"","sources":["../../src/test/echo.ts"],"names":[],"mappings":"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"}
|
package/dist/test/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
//# sourceMappingURL=index.d.ts.map
|
package/dist/test/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/test/index.ts"],"names":[],"mappings":""}
|
package/dist/test/index.js
DELETED
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// import { Broker } from "../broker"
|
|
3
|
-
// import { Client } from "../client"
|
|
4
|
-
// import { Worker } from "../worker"
|
|
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.js.map
|
package/dist/test/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/test/index.ts"],"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"}
|
package/dist/test/pack.d.ts
DELETED
package/dist/test/pack.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"pack.d.ts","sourceRoot":"","sources":["../../src/test/pack.ts"],"names":[],"mappings":""}
|