@adapt-toolkit/sdk 0.4.0 → 0.5.1
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/dist/utilities/broker/broker.d.ts +2 -0
- package/dist/utilities/broker/broker.d.ts.map +1 -1
- package/dist/utilities/broker/broker.js +66 -13
- package/dist/utilities/broker/broker.js.map +1 -1
- package/dist/utilities/broker/broker_client.d.ts +4 -8
- package/dist/utilities/broker/broker_client.d.ts.map +1 -1
- package/dist/utilities/broker/broker_client.js +47 -38
- package/dist/utilities/broker/broker_client.js.map +1 -1
- package/dist/utilities/broker/pending_message_store.d.ts +5 -1
- package/dist/utilities/broker/pending_message_store.d.ts.map +1 -1
- package/dist/utilities/broker/pending_message_store.js +7 -4
- package/dist/utilities/broker/pending_message_store.js.map +1 -1
- package/dist/utilities/common/web_socket_client.d.ts +18 -1
- package/dist/utilities/common/web_socket_client.d.ts.map +1 -1
- package/dist/utilities/common/web_socket_client.js +144 -10
- package/dist/utilities/common/web_socket_client.js.map +1 -1
- package/dist/utilities/common/web_socket_connection.d.ts +7 -0
- package/dist/utilities/common/web_socket_connection.d.ts.map +1 -1
- package/dist/utilities/common/web_socket_connection.js +62 -2
- package/dist/utilities/common/web_socket_connection.js.map +1 -1
- package/dist/utilities/storage/storage_client.d.ts +3 -2
- package/dist/utilities/storage/storage_client.d.ts.map +1 -1
- package/dist/utilities/storage/storage_client.js +61 -41
- package/dist/utilities/storage/storage_client.js.map +1 -1
- package/dist/utilities/wrappers/wrappers/adapt_packet_wrapper.d.ts +1 -0
- package/dist/utilities/wrappers/wrappers/adapt_packet_wrapper.d.ts.map +1 -1
- package/dist/utilities/wrappers/wrappers/adapt_packet_wrapper.js +6 -0
- package/dist/utilities/wrappers/wrappers/adapt_packet_wrapper.js.map +1 -1
- package/dist/utilities/wrappers/wrappers/adapt_wrapper.d.ts +3 -0
- package/dist/utilities/wrappers/wrappers/adapt_wrapper.d.ts.map +1 -1
- package/dist/utilities/wrappers/wrappers/adapt_wrapper.js +28 -2
- package/dist/utilities/wrappers/wrappers/adapt_wrapper.js.map +1 -1
- package/dist/utilities/wrappers/wrappers/impl/adapt_packet_wrapper_impl.d.ts +1 -1
- package/dist/utilities/wrappers/wrappers/impl/adapt_packet_wrapper_impl.d.ts.map +1 -1
- package/dist/utilities/wrappers/wrappers/impl/adapt_packet_wrapper_impl.js +10 -4
- package/dist/utilities/wrappers/wrappers/impl/adapt_packet_wrapper_impl.js.map +1 -1
- package/dist/wasm/mufl-bindings.js +1 -1
- package/dist/wasm/mufl-bindings.wasm +0 -0
- package/package.json +2 -2
|
@@ -2,6 +2,12 @@ import { AsyncQueueAdapter } from './async_queue_adapter.js';
|
|
|
2
2
|
import WebSocket from 'isomorphic-ws';
|
|
3
3
|
import { WebSocketConnection, AdaptProtocolWSConnection } from './web_socket_connection.js';
|
|
4
4
|
import { logging } from './logger/logger.js';
|
|
5
|
+
export const NetworkTimings = {
|
|
6
|
+
RECONNECT_BASE_DELAY_MS: 500,
|
|
7
|
+
RECONNECT_MAX_DELAY_MS: 30_000,
|
|
8
|
+
HEARTBEAT_INTERVAL_MS: 10_000,
|
|
9
|
+
HEARTBEAT_TIMEOUT_MS: 35_000,
|
|
10
|
+
};
|
|
5
11
|
/*
|
|
6
12
|
This class is generic client for web socket connection. It connects to server via web socket, and create async queue to process messages from and to server
|
|
7
13
|
|
|
@@ -10,17 +16,22 @@ class GenericWebSocketClient {
|
|
|
10
16
|
server_address;
|
|
11
17
|
ws;
|
|
12
18
|
wsconnection;
|
|
19
|
+
#generation = 0;
|
|
20
|
+
#reconnect_attempts = 0;
|
|
21
|
+
#reconnect_timer;
|
|
22
|
+
#stopped = false;
|
|
13
23
|
_queue;
|
|
14
24
|
constructor(server_address, wsconnection) {
|
|
15
25
|
this._queue = new AsyncQueueAdapter(this.worker.bind(this));
|
|
16
26
|
this.server_address = server_address;
|
|
17
27
|
this.wsconnection = wsconnection;
|
|
18
|
-
this.ws = new wsconnection(new WebSocket(this.server_address));
|
|
19
|
-
this.queue.pause();
|
|
20
28
|
}
|
|
21
29
|
get queue() {
|
|
22
30
|
return this._queue;
|
|
23
31
|
}
|
|
32
|
+
get connected() {
|
|
33
|
+
return this.ws !== undefined && !this.ws.closed;
|
|
34
|
+
}
|
|
24
35
|
/**
|
|
25
36
|
* Async queue worker. Override this method in child class to create custom behavior of the worker
|
|
26
37
|
*
|
|
@@ -31,15 +42,99 @@ class GenericWebSocketClient {
|
|
|
31
42
|
cb();
|
|
32
43
|
}
|
|
33
44
|
ws_start() {
|
|
45
|
+
if (this.#stopped)
|
|
46
|
+
return;
|
|
47
|
+
if (this.#reconnect_timer) {
|
|
48
|
+
clearTimeout(this.#reconnect_timer);
|
|
49
|
+
this.#reconnect_timer = undefined;
|
|
50
|
+
}
|
|
34
51
|
logging.debug("Attempting to establish web socket connection with: ", this.server_address);
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
52
|
+
const generation = ++this.#generation;
|
|
53
|
+
let socket;
|
|
54
|
+
try {
|
|
55
|
+
socket = new WebSocket(this.server_address);
|
|
56
|
+
}
|
|
57
|
+
catch (e) {
|
|
58
|
+
logging.error("Failed to create web socket for ", this.server_address, ": ", e instanceof Error ? e.message : e);
|
|
59
|
+
this.#schedule_reconnect();
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
62
|
+
const connection = new this.wsconnection(socket);
|
|
63
|
+
this.ws = connection;
|
|
64
|
+
connection.on('open', () => {
|
|
65
|
+
if (generation !== this.#generation)
|
|
66
|
+
return;
|
|
67
|
+
this.#reconnect_attempts = 0;
|
|
68
|
+
this.queue.resume();
|
|
69
|
+
this.start_heartbeat();
|
|
70
|
+
this.on_open();
|
|
71
|
+
});
|
|
72
|
+
connection.on('close', (code, reason) => {
|
|
73
|
+
if (generation !== this.#generation)
|
|
74
|
+
return;
|
|
75
|
+
this.stop_heartbeat();
|
|
76
|
+
this.on_close(code, reason);
|
|
77
|
+
this.#schedule_reconnect();
|
|
78
|
+
});
|
|
79
|
+
connection.on('error', (error) => {
|
|
80
|
+
if (generation !== this.#generation)
|
|
81
|
+
return;
|
|
82
|
+
this.on_error(error);
|
|
83
|
+
});
|
|
84
|
+
connection.on('message', (data) => {
|
|
85
|
+
if (generation !== this.#generation)
|
|
86
|
+
return;
|
|
87
|
+
this.on_message(data);
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
#schedule_reconnect() {
|
|
91
|
+
if (this.#stopped || this.#reconnect_timer)
|
|
92
|
+
return;
|
|
93
|
+
const backoff = Math.min(NetworkTimings.RECONNECT_MAX_DELAY_MS, NetworkTimings.RECONNECT_BASE_DELAY_MS * 2 ** this.#reconnect_attempts);
|
|
94
|
+
this.#reconnect_attempts++;
|
|
95
|
+
const delay = Math.round(backoff * (0.75 + Math.random() * 0.5));
|
|
96
|
+
logging.debug("Scheduling web socket reconnect to ", this.server_address, " in ", delay, "ms");
|
|
97
|
+
this.#reconnect_timer = setTimeout(() => {
|
|
98
|
+
this.#reconnect_timer = undefined;
|
|
99
|
+
this.ws_start();
|
|
100
|
+
}, delay);
|
|
101
|
+
}
|
|
102
|
+
force_reconnect(reason) {
|
|
103
|
+
if (this.#stopped)
|
|
104
|
+
return;
|
|
105
|
+
logging.warning("Forcing web socket reconnect to ", this.server_address, ": ", reason);
|
|
106
|
+
const old = this.ws;
|
|
107
|
+
this.#generation++;
|
|
108
|
+
this.stop_heartbeat();
|
|
109
|
+
this.ws = undefined;
|
|
110
|
+
try {
|
|
111
|
+
old?.terminate();
|
|
112
|
+
}
|
|
113
|
+
catch (e) {
|
|
114
|
+
logging.debug("Error while terminating web socket: ", e instanceof Error ? e.message : e);
|
|
115
|
+
}
|
|
116
|
+
this.on_close(4000, Buffer.from(reason));
|
|
117
|
+
this.#schedule_reconnect();
|
|
42
118
|
}
|
|
119
|
+
stop() {
|
|
120
|
+
this.#stopped = true;
|
|
121
|
+
this.#generation++;
|
|
122
|
+
if (this.#reconnect_timer) {
|
|
123
|
+
clearTimeout(this.#reconnect_timer);
|
|
124
|
+
this.#reconnect_timer = undefined;
|
|
125
|
+
}
|
|
126
|
+
this.stop_heartbeat();
|
|
127
|
+
const old = this.ws;
|
|
128
|
+
this.ws = undefined;
|
|
129
|
+
try {
|
|
130
|
+
old?.close();
|
|
131
|
+
}
|
|
132
|
+
catch (e) {
|
|
133
|
+
logging.debug("Error while closing web socket: ", e instanceof Error ? e.message : e);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
start_heartbeat() { }
|
|
137
|
+
stop_heartbeat() { }
|
|
43
138
|
/**
|
|
44
139
|
* Override this method in child class to create 'open' event listener.
|
|
45
140
|
*/
|
|
@@ -48,10 +143,10 @@ class GenericWebSocketClient {
|
|
|
48
143
|
}
|
|
49
144
|
/**
|
|
50
145
|
* Override this method in child class to create 'close' event listener.
|
|
146
|
+
* Reconnection is scheduled by the base class; the override only needs to reset its own state.
|
|
51
147
|
*/
|
|
52
148
|
on_close(code, reason) {
|
|
53
149
|
this.queue.pause();
|
|
54
|
-
setTimeout(() => this.ws_start(), 1000);
|
|
55
150
|
}
|
|
56
151
|
/**
|
|
57
152
|
* Override this method in child class to create 'error' event listener.
|
|
@@ -73,8 +168,47 @@ export class WebSocketClient extends GenericWebSocketClient {
|
|
|
73
168
|
}
|
|
74
169
|
}
|
|
75
170
|
export class AdaptProtocolWebSocketClient extends GenericWebSocketClient {
|
|
171
|
+
heartbeat_enabled = false;
|
|
172
|
+
#heartbeat_timer;
|
|
76
173
|
constructor(server_address) {
|
|
77
174
|
super(server_address, AdaptProtocolWSConnection);
|
|
78
175
|
}
|
|
176
|
+
start_heartbeat() {
|
|
177
|
+
if (!this.heartbeat_enabled || !this.ws)
|
|
178
|
+
return;
|
|
179
|
+
this.stop_heartbeat();
|
|
180
|
+
const connection = this.ws;
|
|
181
|
+
connection.touch();
|
|
182
|
+
try {
|
|
183
|
+
connection.send_heartbeat_ping();
|
|
184
|
+
}
|
|
185
|
+
catch (e) {
|
|
186
|
+
logging.debug("Failed to send heartbeat ping: ", e instanceof Error ? e.message : e);
|
|
187
|
+
}
|
|
188
|
+
this.#heartbeat_timer = setInterval(() => {
|
|
189
|
+
if (this.ws !== connection) {
|
|
190
|
+
this.stop_heartbeat();
|
|
191
|
+
return;
|
|
192
|
+
}
|
|
193
|
+
if (Date.now() - connection.last_activity_ms > NetworkTimings.HEARTBEAT_TIMEOUT_MS) {
|
|
194
|
+
this.force_reconnect("no data received within heartbeat timeout");
|
|
195
|
+
return;
|
|
196
|
+
}
|
|
197
|
+
try {
|
|
198
|
+
connection.send_heartbeat_ping();
|
|
199
|
+
}
|
|
200
|
+
catch (e) {
|
|
201
|
+
logging.debug("Failed to send heartbeat ping: ", e instanceof Error ? e.message : e);
|
|
202
|
+
}
|
|
203
|
+
}, NetworkTimings.HEARTBEAT_INTERVAL_MS);
|
|
204
|
+
if (typeof this.#heartbeat_timer?.unref === 'function')
|
|
205
|
+
this.#heartbeat_timer.unref();
|
|
206
|
+
}
|
|
207
|
+
stop_heartbeat() {
|
|
208
|
+
if (this.#heartbeat_timer) {
|
|
209
|
+
clearInterval(this.#heartbeat_timer);
|
|
210
|
+
this.#heartbeat_timer = undefined;
|
|
211
|
+
}
|
|
212
|
+
}
|
|
79
213
|
}
|
|
80
214
|
//# sourceMappingURL=web_socket_client.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"web_socket_client.js","sourceRoot":"","sources":["../../../src/utilities/common/web_socket_client.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"web_socket_client.js","sourceRoot":"","sources":["../../../src/utilities/common/web_socket_client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAA;AAC5D,OAAO,SAAS,MAAM,eAAe,CAAA;AACrC,OAAO,EAAE,mBAAmB,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAA;AAG3F,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAE7C,MAAM,CAAC,MAAM,cAAc,GAAG;IAC1B,uBAAuB,EAAE,GAAG;IAC5B,sBAAsB,EAAE,MAAM;IAC9B,qBAAqB,EAAE,MAAM;IAC7B,oBAAoB,EAAE,MAAM;CAC/B,CAAA;AAED;;;EAGE;AACF,MAAM,sBAAsB;IACd,cAAc,CAAS;IACvB,EAAE,CAAK;IACjB,YAAY,CAA+B;IAE3C,WAAW,GAAW,CAAC,CAAA;IACvB,mBAAmB,GAAW,CAAC,CAAA;IAC/B,gBAAgB,CAAgC;IAChD,QAAQ,GAAY,KAAK,CAAA;IAEjB,MAAM,CAA+B;IAE7C,YAAY,cAAsB,EAAE,YAA2C;QAC3E,IAAI,CAAC,MAAM,GAAG,IAAI,iBAAiB,CAAY,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACvE,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;QACrC,IAAI,CAAC,YAAY,GAAG,YAAY,CAAA;IACpC,CAAC;IAED,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,EAAE,KAAK,SAAS,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAA;IACnD,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,CAAY,EAAE,EAAuB;QACxC,EAAE,EAAE,CAAC;IACT,CAAC;IAED,QAAQ;QACJ,IAAI,IAAI,CAAC,QAAQ;YACb,OAAM;QACV,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,YAAY,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;YACnC,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAA;QACrC,CAAC;QAED,OAAO,CAAC,KAAK,CAAC,sDAAsD,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;QAE3F,MAAM,UAAU,GAAG,EAAE,IAAI,CAAC,WAAW,CAAA;QAErC,IAAI,MAAiB,CAAA;QACrB,IAAI,CAAC;YACD,MAAM,GAAG,IAAI,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;QAC/C,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACT,OAAO,CAAC,KAAK,CAAC,kCAAkC,EAAE,IAAI,CAAC,cAAc,EAAE,IAAI,EAAE,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;YAChH,IAAI,CAAC,mBAAmB,EAAE,CAAA;YAC1B,OAAM;QACV,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAA;QAChD,IAAI,CAAC,EAAE,GAAG,UAAU,CAAA;QAEpB,UAAU,CAAC,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE;YACvB,IAAI,UAAU,KAAK,IAAI,CAAC,WAAW;gBAAE,OAAM;YAC3C,IAAI,CAAC,mBAAmB,GAAG,CAAC,CAAA;YAC5B,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAA;YACnB,IAAI,CAAC,eAAe,EAAE,CAAA;YACtB,IAAI,CAAC,OAAO,EAAE,CAAA;QAClB,CAAC,CAAC,CAAA;QACF,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,IAAY,EAAE,MAAc,EAAE,EAAE;YACpD,IAAI,UAAU,KAAK,IAAI,CAAC,WAAW;gBAAE,OAAM;YAC3C,IAAI,CAAC,cAAc,EAAE,CAAA;YACrB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAA;YAC3B,IAAI,CAAC,mBAAmB,EAAE,CAAA;QAC9B,CAAC,CAAC,CAAA;QACF,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAY,EAAE,EAAE;YACpC,IAAI,UAAU,KAAK,IAAI,CAAC,WAAW;gBAAE,OAAM;YAC3C,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;QACxB,CAAC,CAAC,CAAA;QACF,UAAU,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,IAAmB,EAAE,EAAE;YAC7C,IAAI,UAAU,KAAK,IAAI,CAAC,WAAW;gBAAE,OAAM;YAC3C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;QACzB,CAAC,CAAC,CAAA;IACN,CAAC;IAED,mBAAmB;QACf,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,gBAAgB;YACtC,OAAM;QACV,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CACpB,cAAc,CAAC,sBAAsB,EACrC,cAAc,CAAC,uBAAuB,GAAG,CAAC,IAAI,IAAI,CAAC,mBAAmB,CACzE,CAAA;QACD,IAAI,CAAC,mBAAmB,EAAE,CAAA;QAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,GAAG,CAAC,CAAC,CAAA;QAChE,OAAO,CAAC,KAAK,CAAC,qCAAqC,EAAE,IAAI,CAAC,cAAc,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,CAAA;QAC9F,IAAI,CAAC,gBAAgB,GAAG,UAAU,CAAC,GAAG,EAAE;YACpC,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAA;YACjC,IAAI,CAAC,QAAQ,EAAE,CAAA;QACnB,CAAC,EAAE,KAAK,CAAC,CAAA;IACb,CAAC;IAES,eAAe,CAAC,MAAc;QACpC,IAAI,IAAI,CAAC,QAAQ;YACb,OAAM;QACV,OAAO,CAAC,OAAO,CAAC,kCAAkC,EAAE,IAAI,CAAC,cAAc,EAAE,IAAI,EAAE,MAAM,CAAC,CAAA;QACtF,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE,CAAA;QACnB,IAAI,CAAC,WAAW,EAAE,CAAA;QAClB,IAAI,CAAC,cAAc,EAAE,CAAA;QACrB,IAAI,CAAC,EAAE,GAAG,SAAS,CAAA;QACnB,IAAI,CAAC;YACD,GAAG,EAAE,SAAS,EAAE,CAAA;QACpB,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACT,OAAO,CAAC,KAAK,CAAC,sCAAsC,EAAE,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QAC7F,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAA;QACxC,IAAI,CAAC,mBAAmB,EAAE,CAAA;IAC9B,CAAC;IAED,IAAI;QACA,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAA;QACpB,IAAI,CAAC,WAAW,EAAE,CAAA;QAClB,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,YAAY,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;YACnC,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAA;QACrC,CAAC;QACD,IAAI,CAAC,cAAc,EAAE,CAAA;QACrB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE,CAAA;QACnB,IAAI,CAAC,EAAE,GAAG,SAAS,CAAA;QACnB,IAAI,CAAC;YACD,GAAG,EAAE,KAAK,EAAE,CAAA;QAChB,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACT,OAAO,CAAC,KAAK,CAAC,kCAAkC,EAAE,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACzF,CAAC;IACL,CAAC;IAES,eAAe,KAAK,CAAC;IAErB,cAAc,KAAK,CAAC;IAE9B;;OAEG;IACH,OAAO;QACH,OAAO,CAAC,OAAO,CAAC,gIAAgI,CAAC,CAAA;IACrJ,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,IAAY,EAAE,MAAc;QACjC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAA;IACtB,CAAC;IAED;;OAEG;IACH,QAAQ,CAAC,CAAQ;QACb,OAAO,CAAC,OAAO,CAAC,iIAAiI,CAAC,CAAA;IACtJ,CAAC;IAED;;;OAGG;IACH,UAAU,CAAC,IAAmB;QAC1B,OAAO,CAAC,OAAO,CAAC,mIAAmI,CAAC,CAAA;IACxJ,CAAC;CAEJ;AAED,MAAM,OAAO,eAA2B,SAAQ,sBAA2D;IACvG,YAAY,cAAsB;QAC9B,KAAK,CAAC,cAAc,EAAE,mBAAmB,CAAC,CAAA;IAC9C,CAAC;CACJ;AAED,MAAM,OAAO,4BAAwC,SAAQ,sBAAwE;IAEvH,iBAAiB,GAAY,KAAK,CAAA;IAC5C,gBAAgB,CAAiC;IAEjD,YAAY,cAAsB;QAC9B,KAAK,CAAC,cAAc,EAAE,yBAAyB,CAAC,CAAC;IACrD,CAAC;IAEkB,eAAe;QAC9B,IAAI,CAAC,IAAI,CAAC,iBAAiB,IAAI,CAAC,IAAI,CAAC,EAAE;YACnC,OAAM;QACV,IAAI,CAAC,cAAc,EAAE,CAAA;QACrB,MAAM,UAAU,GAAG,IAAI,CAAC,EAAE,CAAA;QAC1B,UAAU,CAAC,KAAK,EAAE,CAAA;QAClB,IAAI,CAAC;YACD,UAAU,CAAC,mBAAmB,EAAE,CAAA;QACpC,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACT,OAAO,CAAC,KAAK,CAAC,iCAAiC,EAAE,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACxF,CAAC;QACD,IAAI,CAAC,gBAAgB,GAAG,WAAW,CAAC,GAAG,EAAE;YACrC,IAAI,IAAI,CAAC,EAAE,KAAK,UAAU,EAAE,CAAC;gBACzB,IAAI,CAAC,cAAc,EAAE,CAAA;gBACrB,OAAM;YACV,CAAC;YACD,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,UAAU,CAAC,gBAAgB,GAAG,cAAc,CAAC,oBAAoB,EAAE,CAAC;gBACjF,IAAI,CAAC,eAAe,CAAC,2CAA2C,CAAC,CAAA;gBACjE,OAAM;YACV,CAAC;YACD,IAAI,CAAC;gBACD,UAAU,CAAC,mBAAmB,EAAE,CAAA;YACpC,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACT,OAAO,CAAC,KAAK,CAAC,iCAAiC,EAAE,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;YACxF,CAAC;QACL,CAAC,EAAE,cAAc,CAAC,qBAAqB,CAAC,CAAA;QACxC,IAAI,OAAQ,IAAI,CAAC,gBAAwB,EAAE,KAAK,KAAK,UAAU;YAC1D,IAAI,CAAC,gBAAwB,CAAC,KAAK,EAAE,CAAA;IAC9C,CAAC;IAEkB,cAAc;QAC7B,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,aAAa,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;YACpC,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAA;QACrC,CAAC;IACL,CAAC;CACJ"}
|
|
@@ -5,6 +5,7 @@ declare class GenericWebSocketConnection<OnMessageType> {
|
|
|
5
5
|
constructor(socket: WebSocket);
|
|
6
6
|
send(data: any): void;
|
|
7
7
|
close(): void;
|
|
8
|
+
terminate(): void;
|
|
8
9
|
get closed(): boolean;
|
|
9
10
|
protected on_message(cb: (data: any) => void): void;
|
|
10
11
|
protected on_close(cb: (code: number, reason: string) => void): void;
|
|
@@ -20,8 +21,14 @@ declare class GenericWebSocketConnection<OnMessageType> {
|
|
|
20
21
|
export declare class WebSocketConnection extends GenericWebSocketConnection<any> {
|
|
21
22
|
}
|
|
22
23
|
export declare class AdaptProtocolWSConnection extends GenericWebSocketConnection<AdaptValue> {
|
|
24
|
+
#private;
|
|
23
25
|
constructor(socket: WebSocket);
|
|
26
|
+
get last_activity_ms(): number;
|
|
27
|
+
get heartbeat_received(): boolean;
|
|
28
|
+
touch(): void;
|
|
24
29
|
send(data: AdaptValue): void;
|
|
30
|
+
send_heartbeat_ping(): void;
|
|
31
|
+
private normalize;
|
|
25
32
|
private parse_and_validate;
|
|
26
33
|
on_message(cb: (data: AdaptValue) => void): void;
|
|
27
34
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"web_socket_connection.d.ts","sourceRoot":"","sources":["../../../src/utilities/common/web_socket_connection.ts"],"names":[],"mappings":"AACA,OAAO,SAAS,MAAM,eAAe,CAAA;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;
|
|
1
|
+
{"version":3,"file":"web_socket_connection.d.ts","sourceRoot":"","sources":["../../../src/utilities/common/web_socket_connection.ts"],"names":[],"mappings":"AACA,OAAO,SAAS,MAAM,eAAe,CAAA;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AAqBrC,cAAM,0BAA0B,CAAC,aAAa;IAC9B,SAAS,CAAC,MAAM,EAAE,SAAS;gBAAjB,MAAM,EAAE,SAAS;IAEvC,IAAI,CAAC,IAAI,EAAE,GAAG;IAId,KAAK;IAKL,SAAS;IAQT,IAAI,MAAM,IAAI,OAAO,CAEpB;IAED,SAAS,CAAC,UAAU,CAAC,EAAE,EAAE,CAAC,IAAI,EAAE,GAAG,KAAK,IAAI;IAM5C,SAAS,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,IAAI;IAM7D,SAAS,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI;IAM7C,SAAS,CAAC,OAAO,CAAC,EAAE,EAAE,MAAM,IAAI;IAMhC,OAAO,CAAC,qBAAqB,CAK5B;IAED,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC,IAAI,EAAE,aAAa,KAAK,IAAI,GAAG,IAAI;IAC7D,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,IAAI,GAAG,IAAI;IACpE,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,GAAG,IAAI;IACpD,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,IAAI,GAAG,IAAI;IACvC,EAAE,CAAC,CAAC,SAAS,aAAa,GAAG,KAAK,GAAG,SAAS,GAAG,MAAM,EACnD,CAAC,SACD,CAAC,CAAC,SAAS,SAAS,GAChB,SAAS,GACT,CAAC,CAAC,SAAS,MAAM,GACb,MAAM,GACN,SAAS,CAAC,CAAC,EAClB,KAAK,EAAE,SAAS,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,IAAI,GAAG,IAAI;CAIxF;AAED,qBAAa,mBAAoB,SAAQ,0BAA0B,CAAC,GAAG,CAAC;CAAI;AAE5E,qBAAa,yBAA0B,SAAQ,0BAA0B,CAAC,UAAU,CAAC;;gBAKrE,MAAM,EAAE,SAAS;IAI7B,IAAI,gBAAgB,IAAI,MAAM,CAE7B;IAED,IAAI,kBAAkB,IAAI,OAAO,CAEhC;IAED,KAAK;IAIL,IAAI,CAAC,IAAI,EAAE,UAAU;IAKrB,mBAAmB;YAIL,SAAS;IAevB,OAAO,CAAC,kBAAkB;IAkBjB,UAAU,CAAC,EAAE,EAAE,CAAC,IAAI,EAAE,UAAU,KAAK,IAAI;CAuBrD"}
|
|
@@ -1,5 +1,21 @@
|
|
|
1
1
|
import * as addon_wrapper from '../../wrapper/index.js';
|
|
2
2
|
import { AdaptProtocolError, AdaptProtocolErrorType } from './errors/adapt_protocol_error.js';
|
|
3
|
+
import { logging } from './logger/logger.js';
|
|
4
|
+
const HEARTBEAT_MAGIC = new Uint8Array([0x41, 0x44, 0x50, 0x54, 0x2d, 0x48, 0x42, 0x31]); // "ADPT-HB1"
|
|
5
|
+
const HEARTBEAT_PING_FRAME = new Uint8Array([...HEARTBEAT_MAGIC, 0x01]);
|
|
6
|
+
const HEARTBEAT_PONG_FRAME = new Uint8Array([...HEARTBEAT_MAGIC, 0x02]);
|
|
7
|
+
function heartbeat_frame_type(data) {
|
|
8
|
+
if (data.length !== HEARTBEAT_PING_FRAME.length)
|
|
9
|
+
return undefined;
|
|
10
|
+
for (let i = 0; i < HEARTBEAT_MAGIC.length; i++)
|
|
11
|
+
if (data[i] !== HEARTBEAT_MAGIC[i])
|
|
12
|
+
return undefined;
|
|
13
|
+
if (data[HEARTBEAT_MAGIC.length] === 0x01)
|
|
14
|
+
return 'ping';
|
|
15
|
+
if (data[HEARTBEAT_MAGIC.length] === 0x02)
|
|
16
|
+
return 'pong';
|
|
17
|
+
return undefined;
|
|
18
|
+
}
|
|
3
19
|
class GenericWebSocketConnection {
|
|
4
20
|
socket;
|
|
5
21
|
constructor(socket) {
|
|
@@ -12,6 +28,13 @@ class GenericWebSocketConnection {
|
|
|
12
28
|
if (this.socket.readyState != this.socket.CLOSED)
|
|
13
29
|
this.socket.close();
|
|
14
30
|
}
|
|
31
|
+
terminate() {
|
|
32
|
+
const socket = this.socket;
|
|
33
|
+
if (typeof socket.terminate === 'function')
|
|
34
|
+
socket.terminate();
|
|
35
|
+
else
|
|
36
|
+
this.close();
|
|
37
|
+
}
|
|
15
38
|
get closed() {
|
|
16
39
|
return this.socket.readyState === this.socket.CLOSED;
|
|
17
40
|
}
|
|
@@ -48,14 +71,28 @@ class GenericWebSocketConnection {
|
|
|
48
71
|
export class WebSocketConnection extends GenericWebSocketConnection {
|
|
49
72
|
}
|
|
50
73
|
export class AdaptProtocolWSConnection extends GenericWebSocketConnection {
|
|
74
|
+
#last_activity_ms = Date.now();
|
|
75
|
+
#heartbeat_received = false;
|
|
51
76
|
constructor(socket) {
|
|
52
77
|
super(socket);
|
|
53
78
|
}
|
|
79
|
+
get last_activity_ms() {
|
|
80
|
+
return this.#last_activity_ms;
|
|
81
|
+
}
|
|
82
|
+
get heartbeat_received() {
|
|
83
|
+
return this.#heartbeat_received;
|
|
84
|
+
}
|
|
85
|
+
touch() {
|
|
86
|
+
this.#last_activity_ms = Date.now();
|
|
87
|
+
}
|
|
54
88
|
send(data) {
|
|
55
89
|
const to_send = data.Serialize();
|
|
56
90
|
super.send(to_send);
|
|
57
91
|
}
|
|
58
|
-
|
|
92
|
+
send_heartbeat_ping() {
|
|
93
|
+
super.send(HEARTBEAT_PING_FRAME);
|
|
94
|
+
}
|
|
95
|
+
async normalize(data) {
|
|
59
96
|
if (data.data) {
|
|
60
97
|
data = data.data;
|
|
61
98
|
if (data.arrayBuffer)
|
|
@@ -67,6 +104,9 @@ export class AdaptProtocolWSConnection extends GenericWebSocketConnection {
|
|
|
67
104
|
if (!(data instanceof Uint8Array)) {
|
|
68
105
|
throw new AdaptProtocolError(AdaptProtocolErrorType.INVALID_MESSAGE, "Invalid type of the message. Expected subclass of Uint8Array, but observed: " + data);
|
|
69
106
|
}
|
|
107
|
+
return data;
|
|
108
|
+
}
|
|
109
|
+
parse_and_validate(data) {
|
|
70
110
|
let value;
|
|
71
111
|
try {
|
|
72
112
|
value = addon_wrapper.Protocol.GetProtocolContainer().ParseValue(Buffer.from(data));
|
|
@@ -87,7 +127,27 @@ export class AdaptProtocolWSConnection extends GenericWebSocketConnection {
|
|
|
87
127
|
}
|
|
88
128
|
on_message(cb) {
|
|
89
129
|
super.on_message(async (data) => {
|
|
90
|
-
|
|
130
|
+
try {
|
|
131
|
+
const bytes = await this.normalize(data);
|
|
132
|
+
this.touch();
|
|
133
|
+
const heartbeat = heartbeat_frame_type(bytes);
|
|
134
|
+
if (heartbeat) {
|
|
135
|
+
if (heartbeat === 'ping') {
|
|
136
|
+
this.#heartbeat_received = true;
|
|
137
|
+
try {
|
|
138
|
+
super.send(HEARTBEAT_PONG_FRAME);
|
|
139
|
+
}
|
|
140
|
+
catch (e) {
|
|
141
|
+
logging.debug("Failed to respond to heartbeat ping:", e instanceof Error ? e.message : e);
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
return;
|
|
145
|
+
}
|
|
146
|
+
cb(this.parse_and_validate(bytes));
|
|
147
|
+
}
|
|
148
|
+
catch (e) {
|
|
149
|
+
logging.error("Failed to process incoming web socket message:", e instanceof Error ? e.message : e);
|
|
150
|
+
}
|
|
91
151
|
});
|
|
92
152
|
}
|
|
93
153
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"web_socket_connection.js","sourceRoot":"","sources":["../../../src/utilities/common/web_socket_connection.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,aAAa,MAAM,wBAAwB,CAAA;AACvD,OAAO,EAAE,kBAAkB,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAA;
|
|
1
|
+
{"version":3,"file":"web_socket_connection.js","sourceRoot":"","sources":["../../../src/utilities/common/web_socket_connection.ts"],"names":[],"mappings":"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"}
|
|
@@ -10,19 +10,20 @@ export interface IAdaptWrapperStorageClientAPI {
|
|
|
10
10
|
receive_from_data_storage(message: AdaptValue): void;
|
|
11
11
|
register_callback_data_storage(cb: (message: AdaptValue) => void): void;
|
|
12
12
|
storage_client_ready(): void;
|
|
13
|
+
storage_connection_lost(): void;
|
|
13
14
|
}
|
|
14
15
|
export declare class StorageClient extends AdaptProtocolWebSocketClient<Event> {
|
|
15
16
|
#private;
|
|
16
17
|
adapt_wrapper: IAdaptWrapperStorageClientAPI;
|
|
17
18
|
constructor(address: string, wrapper: IAdaptWrapperStorageClientAPI);
|
|
18
19
|
start(): void;
|
|
20
|
+
on_open(): void;
|
|
21
|
+
on_error(error: Error): void;
|
|
19
22
|
on_message(data: AdaptValue): void;
|
|
20
23
|
on_close(): void;
|
|
21
24
|
messageFromWrapper(data: AdaptValue): void;
|
|
22
25
|
send_to_data_storage(msg: AdaptValue): void;
|
|
23
26
|
worker(e: Event, cb: async.ErrorCallback): void;
|
|
24
|
-
incoming_message_handler(task: Event): void;
|
|
25
|
-
on_storage_init(): void;
|
|
26
27
|
}
|
|
27
28
|
export {};
|
|
28
29
|
//# sourceMappingURL=storage_client.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"storage_client.d.ts","sourceRoot":"","sources":["../../../src/utilities/storage/storage_client.ts"],"names":[],"mappings":"AACA,OAAO,
|
|
1
|
+
{"version":3,"file":"storage_client.d.ts","sourceRoot":"","sources":["../../../src/utilities/storage/storage_client.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,4BAA4B,EAAW,MAAM,oBAAoB,CAAA;AAC1E,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,KAAK,SAAS,GAAG,oBAAoB,GAAG,qBAAqB,GAAG,kBAAkB,GAAG,mBAAmB,CAAA;AACxG,KAAK,KAAK,GAAG;IAAE,IAAI,EAAE,SAAS,CAAC;IAAC,IAAI,EAAE,UAAU,CAAA;CAAE,CAAA;AAGlD,MAAM,WAAW,6BAA6B;IAC1C,yBAAyB,CAAC,OAAO,EAAE,UAAU,GAAG,IAAI,CAAC;IACrD,8BAA8B,CAAC,EAAE,EAAE,CAAC,OAAO,EAAE,UAAU,KAAK,IAAI,GAAG,IAAI,CAAA;IACvE,oBAAoB,IAAI,IAAI,CAAA;IAC5B,uBAAuB,IAAI,IAAI,CAAA;CAClC;AACD,qBAAa,aAAc,SAAQ,4BAA4B,CAAC,KAAK,CAAC;;IAElE,aAAa,EAAE,6BAA6B,CAAC;gBAKjC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,6BAA6B;IAOnE,KAAK;IAII,OAAO;IAIP,QAAQ,CAAC,KAAK,EAAE,KAAK;IAI9B,UAAU,CAAC,IAAI,EAAE,UAAU,GAAG,IAAI;IAUzB,QAAQ,IAAI,IAAI;IAwBzB,kBAAkB,CAAC,IAAI,EAAE,UAAU;IAInC,oBAAoB,CAAC,GAAG,EAAE,UAAU;IAkBpC,MAAM,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,aAAa;CA0B3C"}
|
|
@@ -6,74 +6,94 @@ export class StorageClient extends AdaptProtocolWebSocketClient {
|
|
|
6
6
|
#pending_messages = [];
|
|
7
7
|
constructor(address, wrapper) {
|
|
8
8
|
super(address);
|
|
9
|
+
this.heartbeat_enabled = true;
|
|
9
10
|
this.adapt_wrapper = wrapper;
|
|
10
11
|
this.adapt_wrapper.register_callback_data_storage(this.messageFromWrapper.bind(this));
|
|
11
12
|
}
|
|
12
13
|
start() {
|
|
13
|
-
// "start" method of parent class creates web socket connection and adds event listeners to the following events: 'open', 'close', 'error', 'message'
|
|
14
14
|
this.ws_start();
|
|
15
15
|
}
|
|
16
|
+
on_open() {
|
|
17
|
+
logging.debug("Storage client opened web socket connection with data storage");
|
|
18
|
+
}
|
|
19
|
+
on_error(error) {
|
|
20
|
+
logging.error("[Storage client] Connection with data storage error: ", error.name, ' ', error.message);
|
|
21
|
+
}
|
|
16
22
|
on_message(data) {
|
|
17
23
|
logging.message_received('data_storage', 'storage_client', data);
|
|
24
|
+
if (Protocol.GetTypeId(data) === Protocol.MessageName.d2w_init) {
|
|
25
|
+
this.#handle_init(data);
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
18
28
|
this.queue.push({ kind: 'storage_message_in', data: data });
|
|
19
29
|
}
|
|
20
30
|
on_close() {
|
|
31
|
+
logging.debug("Storage client lost connection with data storage");
|
|
32
|
+
this.#storage_open = false;
|
|
21
33
|
this.queue.pause();
|
|
22
|
-
this.
|
|
23
|
-
|
|
34
|
+
this.adapt_wrapper.storage_connection_lost();
|
|
35
|
+
}
|
|
36
|
+
#handle_init(message) {
|
|
37
|
+
message.Destroy();
|
|
38
|
+
if (this.#storage_open) {
|
|
39
|
+
logging.debug("Ignoring repeated d2w_init on an already initialized connection");
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
this.#storage_open = true;
|
|
43
|
+
this.adapt_wrapper.storage_client_ready();
|
|
44
|
+
const pending = this.#pending_messages;
|
|
45
|
+
this.#pending_messages = [];
|
|
46
|
+
for (let i = pending.length - 1; i >= 0; i--) {
|
|
47
|
+
this.queue.unshift({ kind: 'storage_message_out', data: pending[i] });
|
|
48
|
+
}
|
|
24
49
|
}
|
|
25
50
|
// Adapt wrapper registers this method as a callback and than calls it on order to send data to data storage
|
|
26
51
|
messageFromWrapper(data) {
|
|
27
52
|
this.queue.push({ kind: 'adapt_message_in', data: data });
|
|
28
53
|
}
|
|
29
54
|
send_to_data_storage(msg) {
|
|
30
|
-
if (this.#storage_open)
|
|
55
|
+
if (!this.#storage_open || !this.ws) {
|
|
56
|
+
this.#pending_messages.push(msg);
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
try {
|
|
60
|
+
logging.message_sent('storage_client', 'data_storage', msg);
|
|
31
61
|
this.ws.send(msg);
|
|
32
|
-
|
|
62
|
+
}
|
|
63
|
+
catch (e) {
|
|
64
|
+
logging.error("[Storage client] Failed to send message to data storage: ", e instanceof Error ? e.message : e);
|
|
65
|
+
this.#storage_open = false;
|
|
33
66
|
this.#pending_messages.push(msg);
|
|
67
|
+
}
|
|
34
68
|
}
|
|
35
69
|
// =================================== worker and related methods ==============================================
|
|
36
70
|
worker(e, cb) {
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
71
|
+
try {
|
|
72
|
+
switch (e.kind) {
|
|
73
|
+
case 'storage_message_in': {
|
|
74
|
+
this.queue.push({ kind: 'adapt_message_out', data: e.data });
|
|
75
|
+
break;
|
|
76
|
+
}
|
|
77
|
+
case 'storage_message_out': {
|
|
78
|
+
this.send_to_data_storage(e.data);
|
|
79
|
+
break;
|
|
80
|
+
}
|
|
81
|
+
case 'adapt_message_in': {
|
|
82
|
+
this.queue.push({ kind: 'storage_message_out', data: e.data });
|
|
83
|
+
break;
|
|
84
|
+
}
|
|
85
|
+
case 'adapt_message_out': {
|
|
86
|
+
this.adapt_wrapper.receive_from_data_storage(e.data);
|
|
87
|
+
break;
|
|
88
|
+
}
|
|
53
89
|
}
|
|
54
90
|
}
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
incoming_message_handler(task) {
|
|
58
|
-
const message = task.data;
|
|
59
|
-
const message_type_id = Protocol.GetTypeId(message);
|
|
60
|
-
if (message_type_id === Protocol.MessageName.d2w_init) {
|
|
61
|
-
this.on_storage_init();
|
|
91
|
+
catch (e) {
|
|
92
|
+
logging.error(e instanceof Error ? e.message : e);
|
|
62
93
|
}
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
kind: 'adapt_message_out',
|
|
66
|
-
data: task.data
|
|
67
|
-
});
|
|
94
|
+
finally {
|
|
95
|
+
cb();
|
|
68
96
|
}
|
|
69
97
|
}
|
|
70
|
-
on_storage_init() {
|
|
71
|
-
this.#storage_open = true;
|
|
72
|
-
this.adapt_wrapper.storage_client_ready();
|
|
73
|
-
this.#pending_messages.forEach(message => this.queue.unshift({
|
|
74
|
-
kind: 'storage_message_out',
|
|
75
|
-
data: message
|
|
76
|
-
}));
|
|
77
|
-
}
|
|
78
98
|
}
|
|
79
99
|
//# sourceMappingURL=storage_client.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"storage_client.js","sourceRoot":"","sources":["../../../src/utilities/storage/storage_client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAClD,OAAO,
|
|
1
|
+
{"version":3,"file":"storage_client.js","sourceRoot":"","sources":["../../../src/utilities/storage/storage_client.ts"],"names":[],"mappings":"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"}
|
|
@@ -12,6 +12,7 @@ export declare class AdaptPacketWrapper {
|
|
|
12
12
|
get packet(): AdaptPacketContext;
|
|
13
13
|
add_client_message(messages: AdaptValue | AdaptValue[]): void;
|
|
14
14
|
flush_pending_messages_for(container_id: string): void;
|
|
15
|
+
create_registration_message(): AdaptValue;
|
|
15
16
|
set on_verify_request(new_value: any);
|
|
16
17
|
set on_return_data(new_value: any);
|
|
17
18
|
set on_transaction_failure(new_value: (errorMessage: string) => void);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"adapt_packet_wrapper.d.ts","sourceRoot":"","sources":["../../../../src/utilities/wrappers/wrappers/adapt_packet_wrapper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,uBAAuB,EAAE,MAAM,UAAU,CAAC;AACnF,OAAO,EAAE,yBAAyB,EAAE,MAAM,iDAAiD,CAAC;AAC5F,OAAO,EAAE,yBAAyB,EAAE,MAAM,iDAAiD,CAAC;AAE5F,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAMlD,qBAAa,kBAAkB;;gBAIf,MAAM,EAAE,kBAAkB,EAAE,MAAM,EAAE,yBAAyB,GAAG,yBAAyB,EAAE,aAAa,EAAE,YAAY,EAAE,QAAQ,EAAE,UAAU,EAAE,EAAE,SAAS,GAAE,OAAe;IAKtL,UAAU,CAAC,OAAO,EAAE,UAAU;IAI9B,IAAI,cAAc,qEAEjB;IAED,IAAI,YAAY,WAEf;IAED,IAAI,uBAAuB,eAE1B;IAED,IAAI,MAAM,uBAET;IAID,kBAAkB,CAAC,QAAQ,EAAE,UAAU,GAAG,UAAU,EAAE;IAKtD,0BAA0B,CAAC,YAAY,EAAE,MAAM;
|
|
1
|
+
{"version":3,"file":"adapt_packet_wrapper.d.ts","sourceRoot":"","sources":["../../../../src/utilities/wrappers/wrappers/adapt_packet_wrapper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,uBAAuB,EAAE,MAAM,UAAU,CAAC;AACnF,OAAO,EAAE,yBAAyB,EAAE,MAAM,iDAAiD,CAAC;AAC5F,OAAO,EAAE,yBAAyB,EAAE,MAAM,iDAAiD,CAAC;AAE5F,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAMlD,qBAAa,kBAAkB;;gBAIf,MAAM,EAAE,kBAAkB,EAAE,MAAM,EAAE,yBAAyB,GAAG,yBAAyB,EAAE,aAAa,EAAE,YAAY,EAAE,QAAQ,EAAE,UAAU,EAAE,EAAE,SAAS,GAAE,OAAe;IAKtL,UAAU,CAAC,OAAO,EAAE,UAAU;IAI9B,IAAI,cAAc,qEAEjB;IAED,IAAI,YAAY,WAEf;IAED,IAAI,uBAAuB,eAE1B;IAED,IAAI,MAAM,uBAET;IAID,kBAAkB,CAAC,QAAQ,EAAE,UAAU,GAAG,UAAU,EAAE;IAKtD,0BAA0B,CAAC,YAAY,EAAE,MAAM;IAK/C,2BAA2B,IAAI,UAAU;IAIzC,IAAW,iBAAiB,CAAC,SAAS,EAAE,GAAG,EAE1C;IAED,IAAW,cAAc,CAAC,SAAS,EAAE,GAAG,EAEvC;IAED,IAAW,sBAAsB,CAAC,SAAS,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,IAAI,EAE1E;IAGM,yBAAyB,CAAC,EAAE,EAAE,uBAAuB;CAI/D"}
|
|
@@ -33,6 +33,9 @@ export class AdaptPacketWrapper {
|
|
|
33
33
|
flush_pending_messages_for(container_id) {
|
|
34
34
|
this.#adapt_packet_wrapper_impl.flush_pending_messages_for(container_id);
|
|
35
35
|
}
|
|
36
|
+
create_registration_message() {
|
|
37
|
+
return this.#adapt_packet_wrapper_impl.create_registration_message();
|
|
38
|
+
}
|
|
36
39
|
set on_verify_request(new_value) {
|
|
37
40
|
this.#adapt_packet_wrapper_impl.on_verify_request = new_value;
|
|
38
41
|
}
|
|
@@ -55,6 +58,9 @@ __decorate([
|
|
|
55
58
|
__decorate([
|
|
56
59
|
log_fn_call(adapt_packet_wrapper_logger_proxy)
|
|
57
60
|
], AdaptPacketWrapper.prototype, "flush_pending_messages_for", null);
|
|
61
|
+
__decorate([
|
|
62
|
+
log_fn_call(adapt_packet_wrapper_logger_proxy)
|
|
63
|
+
], AdaptPacketWrapper.prototype, "create_registration_message", null);
|
|
58
64
|
__decorate([
|
|
59
65
|
Decorators.web_only_method
|
|
60
66
|
], AdaptPacketWrapper.prototype, "acceptVerificationRequest", null);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"adapt_packet_wrapper.js","sourceRoot":"","sources":["../../../../src/utilities/wrappers/wrappers/adapt_packet_wrapper.ts"],"names":[],"mappings":";;;;;;AAKA,OAAO,EAAC,sBAAsB,EAAC,MAAM,qCAAqC,CAAA;AAC1E,OAAO,EAAE,UAAU,EAAW,WAAW,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAGtF,MAAM,iCAAiC,GAAG,IAAI,WAAW,CAAC,sBAAsB,CAAC,CAAA;AACjF,MAAM,OAAO,kBAAkB;IAE3B,0BAA0B,CAAwB;IAElD,YAAY,MAA0B,EAAE,MAA6D,EAAE,aAA2B,EAAE,QAAsB,EAAE,YAAqB,KAAK;QAClL,IAAI,CAAC,0BAA0B,GAAG,IAAI,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;IAC3H,CAAC;IAGD,UAAU,CAAC,OAAmB;QAC1B,IAAI,CAAC,0BAA0B,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IACxD,CAAC;IAED,IAAI,cAAc;QACd,OAAO,IAAI,CAAC,0BAA0B,CAAC,cAAc,CAAA;IACzD,CAAC;IAED,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,0BAA0B,CAAC,YAAY,CAAC;IACxD,CAAC;IAED,IAAI,uBAAuB;QACvB,OAAO,IAAI,CAAC,0BAA0B,CAAC,uBAAuB,CAAC;IACnE,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,0BAA0B,CAAC,MAAM,CAAA;IACjD,CAAC;IAID,kBAAkB,CAAC,QAAmC;QAClD,OAAO,IAAI,CAAC,0BAA0B,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IACxE,CAAC;IAGD,0BAA0B,CAAC,YAAoB;QAC3C,IAAI,CAAC,0BAA0B,CAAC,0BAA0B,CAAC,YAAY,CAAC,CAAC;IAC7E,CAAC;IAED,IAAW,iBAAiB,CAAC,SAAc;QACvC,IAAI,CAAC,0BAA0B,CAAC,iBAAiB,GAAG,SAAS,CAAC;IAClE,CAAC;IAED,IAAW,cAAc,CAAC,SAAc;QACpC,IAAI,CAAC,0BAA0B,CAAC,cAAc,GAAG,SAAS,CAAC;IAC/D,CAAC;IAED,IAAW,sBAAsB,CAAC,SAAyC;QACvE,IAAI,CAAC,0BAA0B,CAAC,sBAAsB,GAAG,SAAS,CAAC;IACvE,CAAC;IAGM,yBAAyB,CAAC,EAA2B;QACxD,IAAI,CAAC,0BAA0B,CAAC,yBAAyB,CAAC,EAAE,CAAC,CAAC;IAClE,CAAC;CAEJ;
|
|
1
|
+
{"version":3,"file":"adapt_packet_wrapper.js","sourceRoot":"","sources":["../../../../src/utilities/wrappers/wrappers/adapt_packet_wrapper.ts"],"names":[],"mappings":";;;;;;AAKA,OAAO,EAAC,sBAAsB,EAAC,MAAM,qCAAqC,CAAA;AAC1E,OAAO,EAAE,UAAU,EAAW,WAAW,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAGtF,MAAM,iCAAiC,GAAG,IAAI,WAAW,CAAC,sBAAsB,CAAC,CAAA;AACjF,MAAM,OAAO,kBAAkB;IAE3B,0BAA0B,CAAwB;IAElD,YAAY,MAA0B,EAAE,MAA6D,EAAE,aAA2B,EAAE,QAAsB,EAAE,YAAqB,KAAK;QAClL,IAAI,CAAC,0BAA0B,GAAG,IAAI,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;IAC3H,CAAC;IAGD,UAAU,CAAC,OAAmB;QAC1B,IAAI,CAAC,0BAA0B,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IACxD,CAAC;IAED,IAAI,cAAc;QACd,OAAO,IAAI,CAAC,0BAA0B,CAAC,cAAc,CAAA;IACzD,CAAC;IAED,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,0BAA0B,CAAC,YAAY,CAAC;IACxD,CAAC;IAED,IAAI,uBAAuB;QACvB,OAAO,IAAI,CAAC,0BAA0B,CAAC,uBAAuB,CAAC;IACnE,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,0BAA0B,CAAC,MAAM,CAAA;IACjD,CAAC;IAID,kBAAkB,CAAC,QAAmC;QAClD,OAAO,IAAI,CAAC,0BAA0B,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IACxE,CAAC;IAGD,0BAA0B,CAAC,YAAoB;QAC3C,IAAI,CAAC,0BAA0B,CAAC,0BAA0B,CAAC,YAAY,CAAC,CAAC;IAC7E,CAAC;IAGD,2BAA2B;QACvB,OAAO,IAAI,CAAC,0BAA0B,CAAC,2BAA2B,EAAE,CAAC;IACzE,CAAC;IAED,IAAW,iBAAiB,CAAC,SAAc;QACvC,IAAI,CAAC,0BAA0B,CAAC,iBAAiB,GAAG,SAAS,CAAC;IAClE,CAAC;IAED,IAAW,cAAc,CAAC,SAAc;QACpC,IAAI,CAAC,0BAA0B,CAAC,cAAc,GAAG,SAAS,CAAC;IAC/D,CAAC;IAED,IAAW,sBAAsB,CAAC,SAAyC;QACvE,IAAI,CAAC,0BAA0B,CAAC,sBAAsB,GAAG,SAAS,CAAC;IACvE,CAAC;IAGM,yBAAyB,CAAC,EAA2B;QACxD,IAAI,CAAC,0BAA0B,CAAC,yBAAyB,CAAC,EAAE,CAAC,CAAC;IAClE,CAAC;CAEJ;AArDG;IADC,WAAW,CAAC,iCAAiC,CAAC;oDAG9C;AAoBD;IADC,WAAW,CAAC,iCAAiC,CAAC;4DAG9C;AAGD;IADC,WAAW,CAAC,iCAAiC,CAAC;oEAG9C;AAGD;IADC,WAAW,CAAC,iCAAiC,CAAC;qEAG9C;AAeM;IADN,UAAU,CAAC,eAAe;mEAG1B"}
|
|
@@ -42,6 +42,8 @@ declare namespace AdaptWrapperServices {
|
|
|
42
42
|
receive_from_broker: (message: AdaptValue) => void;
|
|
43
43
|
register_callback_broker: (cb: (message: AdaptValue) => void) => void;
|
|
44
44
|
broker_client_ready: () => void;
|
|
45
|
+
broker_connection_lost: () => void;
|
|
46
|
+
collect_registration_messages: () => AdaptValue[];
|
|
45
47
|
send_to_broker: (message: AdaptValue) => void;
|
|
46
48
|
extract_pending_transactions_for: (container_id: string) => AdaptValue[];
|
|
47
49
|
}
|
|
@@ -53,6 +55,7 @@ declare namespace AdaptWrapperServices {
|
|
|
53
55
|
receive_from_data_storage: (message: AdaptValue) => void;
|
|
54
56
|
register_callback_data_storage: (cb: (message: AdaptValue) => void) => void;
|
|
55
57
|
storage_client_ready: () => void;
|
|
58
|
+
storage_connection_lost: () => void;
|
|
56
59
|
send_to_storage: (message: AdaptValue) => void;
|
|
57
60
|
}
|
|
58
61
|
namespace MessageProcessor {
|