@luxonis/visualizer-protobuf 2.2.0 → 2.4.0
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/{communicator-DKKKAI0H.js → FoxgloveServer-tJZcJH5-.js} +1216 -174
- package/dist/apps/depthai-visualizer/src/components/Panel.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/components/Panel.js +4 -13
- package/dist/apps/depthai-visualizer/src/components/Panel.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/components/PanelToolbar.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/components/PanelToolbar.js +10 -11
- package/dist/apps/depthai-visualizer/src/components/PanelToolbar.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/connection/adapter.d.ts +4 -7
- package/dist/apps/depthai-visualizer/src/connection/adapter.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/connection/adapter.js +5 -5
- package/dist/apps/depthai-visualizer/src/connection/adapter.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/connection/communicator.d.ts +7 -13
- package/dist/apps/depthai-visualizer/src/connection/communicator.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/connection/communicator.js +5 -4
- package/dist/apps/depthai-visualizer/src/connection/communicator.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/connection/connection.d.ts +8 -13
- package/dist/apps/depthai-visualizer/src/connection/connection.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/connection/connection.js +19 -22
- package/dist/apps/depthai-visualizer/src/connection/connection.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/connection/foxglove-protocol.d.ts +6 -0
- package/dist/apps/depthai-visualizer/src/connection/foxglove-protocol.d.ts.map +1 -0
- package/dist/apps/depthai-visualizer/src/connection/foxglove-protocol.js +63 -0
- package/dist/apps/depthai-visualizer/src/connection/foxglove-protocol.js.map +1 -0
- package/dist/apps/depthai-visualizer/src/connection/webrtc/bridge.d.ts +2 -2
- package/dist/apps/depthai-visualizer/src/connection/webrtc/bridge.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/connection/webrtc/bridge.js +29 -49
- package/dist/apps/depthai-visualizer/src/connection/webrtc/bridge.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/connection/webrtc/{worker-utils.d.ts → handler.d.ts} +21 -21
- package/dist/apps/depthai-visualizer/src/connection/webrtc/handler.d.ts.map +1 -0
- package/dist/apps/depthai-visualizer/src/connection/webrtc/{worker-utils.js → handler.js} +46 -49
- package/dist/apps/depthai-visualizer/src/connection/webrtc/handler.js.map +1 -0
- package/dist/apps/depthai-visualizer/src/connection/webrtc/worker.js +1 -1
- package/dist/apps/depthai-visualizer/src/connection/webrtc/worker.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/connection/ws/worker.d.ts +16 -1
- package/dist/apps/depthai-visualizer/src/connection/ws/worker.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/connection/ws/worker.js +114 -2
- package/dist/apps/depthai-visualizer/src/connection/ws/worker.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/context/ConnectionsProvider.d.ts +1 -1
- package/dist/apps/depthai-visualizer/src/context/ConnectionsProvider.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/index.d.ts +1 -2
- package/dist/apps/depthai-visualizer/src/index.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/index.js +0 -1
- package/dist/apps/depthai-visualizer/src/index.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/messaging/deserialization/detections/detection.js +2 -2
- package/dist/apps/depthai-visualizer/src/messaging/deserialization/detections/detection.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/messaging/deserialization/detections/utils.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/messaging/deserialization/detections/utils.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/messaging/deserialization.js +5 -5
- package/dist/apps/depthai-visualizer/src/messaging/deserialization.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/messaging/utils.d.ts +7 -6
- package/dist/apps/depthai-visualizer/src/messaging/utils.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/messaging/utils.js +2 -2
- package/dist/apps/depthai-visualizer/src/messaging/utils.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/EncodedFrame.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/EncodedFrame.js +3 -0
- package/dist/apps/depthai-visualizer/src/protobuf.generated/EncodedFrame.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/ImageAnnotations.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/ImageAnnotations.js +3 -0
- package/dist/apps/depthai-visualizer/src/protobuf.generated/ImageAnnotations.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/ImgDetections.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/ImgDetections.js +3 -0
- package/dist/apps/depthai-visualizer/src/protobuf.generated/ImgDetections.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/ImgFrame.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/ImgFrame.js +3 -0
- package/dist/apps/depthai-visualizer/src/protobuf.generated/ImgFrame.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/PointCloudData.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/PointCloudData.js +3 -0
- package/dist/apps/depthai-visualizer/src/protobuf.generated/PointCloudData.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/SpatialImgDetections.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/SpatialImgDetections.js +3 -0
- package/dist/apps/depthai-visualizer/src/protobuf.generated/SpatialImgDetections.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/common.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/protobuf.generated/common.js +3 -0
- package/dist/apps/depthai-visualizer/src/protobuf.generated/common.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/utils/artificial-worker.d.ts +6 -6
- package/dist/apps/depthai-visualizer/src/utils/artificial-worker.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/utils/artificial-worker.js +10 -7
- package/dist/apps/depthai-visualizer/src/utils/artificial-worker.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/utils/callback-manager.d.ts +1 -1
- package/dist/apps/depthai-visualizer/src/utils/callback-manager.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/utils/callback-manager.js +5 -5
- package/dist/apps/depthai-visualizer/src/utils/callback-manager.js.map +1 -1
- package/dist/apps/depthai-visualizer/src/utils/compatibility.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/utils/metrics-manager.d.ts.map +1 -1
- package/dist/apps/depthai-visualizer/src/utils/metrics-manager.js +1 -0
- package/dist/apps/depthai-visualizer/src/utils/metrics-manager.js.map +1 -1
- package/dist/communicator-D9LSiWws.js +147 -0
- package/dist/foxglove-protocol-RBwoTi12.js +76 -0
- package/dist/{index-CE1LH59a.js → index--nzAFiZd.js} +4 -5
- package/dist/{index-BZjzIIuE.js → index-BB5d7Wdh.js} +4 -5
- package/dist/{index-D7I7neMi.js → index-BHaIc2C4.js} +4 -5
- package/dist/{index-SZgAiOi4.js → index-BVRwpAVC.js} +4 -5
- package/dist/{index-DbIgJEn4.js → index-BYSKaUpM.js} +4 -5
- package/dist/{index-B3F-eA-i.js → index-BmgfyPqg.js} +119 -140
- package/dist/{index-B4j3EVf8.js → index-BoC3cisy.js} +4 -5
- package/dist/{index-Cqzhj8jS.js → index-BozWkluR.js} +4 -5
- package/dist/{index-DleEaqya.js → index-Bt0NSrqQ.js} +4 -5
- package/dist/{index-Dai0K-_7.js → index-CDi1cz7Q.js} +4 -5
- package/dist/{index-1yvlF6NH.js → index-CPdu31YI.js} +4 -5
- package/dist/{index-FdS8KlrP.js → index-CeamuSdm.js} +4 -5
- package/dist/{index-Cmp_Tjng.js → index-CgejPf93.js} +5 -6
- package/dist/{index-C6m30paN.js → index-CqufTx2r.js} +4 -5
- package/dist/{index-MOg_zBJW.js → index-GlkMngOu.js} +4 -5
- package/dist/{index-D_AhdZqi.js → index-GvvAhoPF.js} +4 -5
- package/dist/{index-D0g7yNKD.js → index-KSDq22q_.js} +4 -5
- package/dist/{index-DkDTcHOl.js → index-q-pdHK_j.js} +4 -5
- package/dist/{index-BsdqQ862.js → index-tb3sDWD8.js} +4 -5
- package/dist/index.js +4 -5
- package/dist/worker-C6ruK-iB.js +150 -0
- package/dist/{worker-CMZIJlQN.js → worker-CXuTdrjS.js} +41 -39
- package/package.json +1 -1
- package/dist/apps/depthai-visualizer/src/connection/webrtc/worker-utils.d.ts.map +0 -1
- package/dist/apps/depthai-visualizer/src/connection/webrtc/worker-utils.js.map +0 -1
- package/dist/apps/depthai-visualizer/src/connection/ws/worker-utils.d.ts +0 -19
- package/dist/apps/depthai-visualizer/src/connection/ws/worker-utils.d.ts.map +0 -1
- package/dist/apps/depthai-visualizer/src/connection/ws/worker-utils.js +0 -128
- package/dist/apps/depthai-visualizer/src/connection/ws/worker-utils.js.map +0 -1
- package/dist/apps/depthai-visualizer/src/panels/CanvasPanel.d.ts +0 -12
- package/dist/apps/depthai-visualizer/src/panels/CanvasPanel.d.ts.map +0 -1
- package/dist/apps/depthai-visualizer/src/panels/CanvasPanel.js +0 -52
- package/dist/apps/depthai-visualizer/src/panels/CanvasPanel.js.map +0 -1
- package/dist/worker-DtDgSl3T.js +0 -11
- package/dist/worker-utils-BuUq1bP1.js +0 -1357
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ArtificialWorker } from "../../utils/artificial-worker.js";
|
|
2
|
-
import type {
|
|
3
|
-
export declare class WebRtcBridge extends ArtificialWorker<
|
|
2
|
+
import type { WorkerInputMessage, WorkerOutputMessage } from "../communicator.js";
|
|
3
|
+
export declare class WebRtcBridge extends ArtificialWorker<WorkerInputMessage, WorkerOutputMessage> {
|
|
4
4
|
#private;
|
|
5
5
|
constructor();
|
|
6
6
|
terminate(): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bridge.d.ts","sourceRoot":"","sources":["../../../../../../src/connection/webrtc/bridge.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"bridge.d.ts","sourceRoot":"","sources":["../../../../../../src/connection/webrtc/bridge.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AACpE,OAAO,KAAK,EACV,kBAAkB,EAClB,mBAAmB,EACpB,MAAM,oBAAoB,CAAC;AAM5B,qBAAa,YAAa,SAAQ,gBAAgB,CAAC,kBAAkB,EAAE,mBAAmB,CAAC;;;IAezE,SAAS,IAAI,IAAI;CAmKlC"}
|
|
@@ -2,7 +2,9 @@
|
|
|
2
2
|
// License, v2.0. If a copy of the MPL was not distributed with this
|
|
3
3
|
// file, You can obtain one at http://mozilla.org/MPL/2.0/
|
|
4
4
|
import { WebRtcClient, } from "@luxonis/remote-connection";
|
|
5
|
+
import { BinaryOpcode } from '@foxglove/ws-protocol';
|
|
5
6
|
import { ArtificialWorker } from "../../utils/artificial-worker.js";
|
|
7
|
+
import { parseFoxgloveMessage } from "../foxglove-protocol.js";
|
|
6
8
|
const MESSAGE_CHANNEL_NAME = "message";
|
|
7
9
|
const SYSTEM_CHANNEL_NAME = "system";
|
|
8
10
|
export class WebRtcBridge extends ArtificialWorker {
|
|
@@ -21,7 +23,7 @@ export class WebRtcBridge extends ArtificialWorker {
|
|
|
21
23
|
this.#worker.terminate();
|
|
22
24
|
}
|
|
23
25
|
#setupArtificialWorker() {
|
|
24
|
-
this.
|
|
26
|
+
this.addEventListenerFromMain("message", (event) => {
|
|
25
27
|
switch (event.data.type) {
|
|
26
28
|
case "open": {
|
|
27
29
|
if ("config" in event.data.data) {
|
|
@@ -37,15 +39,6 @@ export class WebRtcBridge extends ArtificialWorker {
|
|
|
37
39
|
this.terminate();
|
|
38
40
|
break;
|
|
39
41
|
}
|
|
40
|
-
case "send": {
|
|
41
|
-
this.#worker.postMessage({
|
|
42
|
-
kind: "rawSend",
|
|
43
|
-
data: {
|
|
44
|
-
message: event.data.data,
|
|
45
|
-
},
|
|
46
|
-
});
|
|
47
|
-
break;
|
|
48
|
-
}
|
|
49
42
|
case "call_service": {
|
|
50
43
|
this.#worker.postMessage({
|
|
51
44
|
kind: "serviceCall",
|
|
@@ -72,7 +65,7 @@ export class WebRtcBridge extends ArtificialWorker {
|
|
|
72
65
|
this.#handleMessages();
|
|
73
66
|
}
|
|
74
67
|
#handleWebRtc(client) {
|
|
75
|
-
client.on("error", (error) => console.error("WebRtc Client Failed", error));
|
|
68
|
+
client.on("error", (error) => { console.error("WebRtc Client Failed", error); });
|
|
76
69
|
client.on("connection_established", (connection) => {
|
|
77
70
|
connection.on("data_channel", (channel) => {
|
|
78
71
|
channel.on("close", () => {
|
|
@@ -89,43 +82,32 @@ export class WebRtcBridge extends ArtificialWorker {
|
|
|
89
82
|
ready: false,
|
|
90
83
|
},
|
|
91
84
|
});
|
|
92
|
-
this.
|
|
93
|
-
type: "close",
|
|
94
|
-
});
|
|
85
|
+
this.postMessageToMain({ type: "close", });
|
|
95
86
|
});
|
|
96
87
|
if (channel.label === MESSAGE_CHANNEL_NAME) {
|
|
97
88
|
this.#messageChannel = channel;
|
|
98
89
|
channel.on("message:binary", async (view) => {
|
|
99
|
-
const
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
: "other";
|
|
105
|
-
if (action === "message") {
|
|
106
|
-
const subscriptionId = view.getUint32(1);
|
|
107
|
-
const payload = new DataView(view.buffer, view.byteOffset + 1 + 4 + 8);
|
|
90
|
+
const message = parseFoxgloveMessage(view);
|
|
91
|
+
if (!message) {
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
94
|
+
if (message.op === BinaryOpcode.MESSAGE_DATA) {
|
|
108
95
|
this.#worker.postMessage({
|
|
109
96
|
kind: "genericMessage",
|
|
110
|
-
data: {
|
|
111
|
-
|
|
112
|
-
},
|
|
113
|
-
}, [payload.buffer]);
|
|
97
|
+
data: { message },
|
|
98
|
+
}, [message.data.buffer]);
|
|
114
99
|
}
|
|
115
100
|
else {
|
|
116
|
-
const callId = view.getUint32(1 + 4); // op-code + service-id
|
|
117
|
-
const encodingLength = view.getUint32(1 + 4 + 4); // op-code + service-id + call-id
|
|
118
|
-
const payload = new DataView(view.buffer, view.byteOffset + 1 + 4 + 4 + 4 + encodingLength); // op-code + service-id + call-id + encoding-length
|
|
119
101
|
this.#worker.postMessage({
|
|
120
102
|
kind: "systemMessage",
|
|
121
103
|
data: {
|
|
122
104
|
message: {
|
|
123
105
|
op: "serviceResponse",
|
|
124
|
-
callId,
|
|
125
|
-
data:
|
|
106
|
+
callId: message.callId,
|
|
107
|
+
data: message.data,
|
|
126
108
|
},
|
|
127
109
|
},
|
|
128
|
-
}, [
|
|
110
|
+
}, [message.data.buffer]);
|
|
129
111
|
}
|
|
130
112
|
});
|
|
131
113
|
}
|
|
@@ -138,20 +120,20 @@ export class WebRtcBridge extends ArtificialWorker {
|
|
|
138
120
|
});
|
|
139
121
|
});
|
|
140
122
|
}
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
123
|
+
if (channel.label === MESSAGE_CHANNEL_NAME || channel.label === SYSTEM_CHANNEL_NAME) {
|
|
124
|
+
this.#worker.postMessage({
|
|
125
|
+
kind: "connection",
|
|
126
|
+
data: {
|
|
127
|
+
channel: channel.label === MESSAGE_CHANNEL_NAME
|
|
128
|
+
? "message"
|
|
129
|
+
: "system",
|
|
130
|
+
ready: true,
|
|
131
|
+
},
|
|
132
|
+
});
|
|
133
|
+
}
|
|
150
134
|
if (this.#systemChannel?.raw.readyState === "open" &&
|
|
151
135
|
this.#messageChannel?.raw.readyState === "open") {
|
|
152
|
-
this.
|
|
153
|
-
type: "open",
|
|
154
|
-
});
|
|
136
|
+
this.postMessageToMain({ type: "open", });
|
|
155
137
|
}
|
|
156
138
|
});
|
|
157
139
|
connection.on("connection_closed", () => {
|
|
@@ -159,9 +141,7 @@ export class WebRtcBridge extends ArtificialWorker {
|
|
|
159
141
|
kind: "connection",
|
|
160
142
|
data: { channel: null, ready: false },
|
|
161
143
|
});
|
|
162
|
-
this.
|
|
163
|
-
type: "close",
|
|
164
|
-
});
|
|
144
|
+
this.postMessageToMain({ type: "close", });
|
|
165
145
|
});
|
|
166
146
|
});
|
|
167
147
|
}
|
|
@@ -178,7 +158,7 @@ export class WebRtcBridge extends ArtificialWorker {
|
|
|
178
158
|
break;
|
|
179
159
|
}
|
|
180
160
|
default: {
|
|
181
|
-
this.
|
|
161
|
+
this.postMessageToMain(event.data);
|
|
182
162
|
}
|
|
183
163
|
}
|
|
184
164
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bridge.js","sourceRoot":"","sources":["../../../../../../src/connection/webrtc/bridge.ts"],"names":[],"mappings":"AAAA,sEAAsE;AACtE,oEAAoE;AACpE,0DAA0D;AAE1D,OAAO,EACL,YAAY,GAGb,MAAM,4BAA4B,CAAC;
|
|
1
|
+
{"version":3,"file":"bridge.js","sourceRoot":"","sources":["../../../../../../src/connection/webrtc/bridge.ts"],"names":[],"mappings":"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"}
|
package/dist/apps/depthai-visualizer/src/connection/webrtc/{worker-utils.d.ts → handler.d.ts}
RENAMED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import type { Advertise,
|
|
2
|
-
import {
|
|
1
|
+
import type { Advertise, AdvertiseServices, ServiceCallPayload, Unadvertise, UnadvertiseServices } from "@foxglove/ws-protocol";
|
|
2
|
+
import { FoxgloveCommunicator, WorkerOutputMessage } from "../communicator";
|
|
3
3
|
type GenericMessage = {
|
|
4
4
|
subscriptionId: number;
|
|
5
5
|
data: DataView;
|
|
6
6
|
};
|
|
7
7
|
export type SystemMessage = Advertise | Unadvertise | AdvertiseServices | UnadvertiseServices | {
|
|
8
|
-
op:
|
|
8
|
+
op: "serviceResponse";
|
|
9
9
|
callId: number;
|
|
10
10
|
data: DataView;
|
|
11
11
|
};
|
|
@@ -15,43 +15,43 @@ type ServiceCallMessage = {
|
|
|
15
15
|
body?: Record<string, any>;
|
|
16
16
|
};
|
|
17
17
|
export type WebRtcWorkerInputMessage = {
|
|
18
|
-
kind:
|
|
18
|
+
kind: "genericMessage";
|
|
19
19
|
data: {
|
|
20
20
|
message: GenericMessage;
|
|
21
21
|
};
|
|
22
22
|
} | {
|
|
23
|
-
kind:
|
|
23
|
+
kind: "systemMessage";
|
|
24
24
|
data: {
|
|
25
25
|
message: SystemMessage;
|
|
26
26
|
};
|
|
27
27
|
} | {
|
|
28
|
-
kind:
|
|
28
|
+
kind: "connection";
|
|
29
29
|
data: {
|
|
30
|
-
channel:
|
|
30
|
+
channel: "message" | "system" | null;
|
|
31
31
|
ready: boolean;
|
|
32
32
|
};
|
|
33
33
|
} | {
|
|
34
|
-
kind:
|
|
34
|
+
kind: "serviceCall";
|
|
35
35
|
data: {
|
|
36
36
|
message: ServiceCallMessage;
|
|
37
37
|
};
|
|
38
38
|
} | {
|
|
39
|
-
kind:
|
|
39
|
+
kind: "rawSend";
|
|
40
40
|
data: {
|
|
41
41
|
message: {
|
|
42
|
-
channel:
|
|
42
|
+
channel: "system" | "message";
|
|
43
43
|
message: string | DataView;
|
|
44
44
|
};
|
|
45
45
|
};
|
|
46
46
|
} | {
|
|
47
|
-
kind:
|
|
47
|
+
kind: "subscribe";
|
|
48
48
|
data: {
|
|
49
49
|
message: {
|
|
50
50
|
topics: string[];
|
|
51
51
|
};
|
|
52
52
|
};
|
|
53
53
|
} | {
|
|
54
|
-
kind:
|
|
54
|
+
kind: "unsubscribe";
|
|
55
55
|
data: {
|
|
56
56
|
message: {
|
|
57
57
|
topics: string[];
|
|
@@ -59,27 +59,27 @@ export type WebRtcWorkerInputMessage = {
|
|
|
59
59
|
};
|
|
60
60
|
};
|
|
61
61
|
export type WebRtcWorkerOutputMessage = {
|
|
62
|
-
type:
|
|
62
|
+
type: "send";
|
|
63
63
|
data: {
|
|
64
|
-
channel:
|
|
64
|
+
channel: "message" | "system";
|
|
65
65
|
data: string | DataView;
|
|
66
66
|
};
|
|
67
67
|
};
|
|
68
68
|
export declare class WebRtcHandler extends FoxgloveCommunicator {
|
|
69
69
|
#private;
|
|
70
70
|
protected isReady(): boolean;
|
|
71
|
-
send(message:
|
|
72
|
-
sendWithTransfer(message:
|
|
71
|
+
send(message: WorkerOutputMessage): void;
|
|
72
|
+
sendWithTransfer(message: WorkerOutputMessage, transfer: ArrayBuffer[]): void;
|
|
73
73
|
subscribe(topics: string[]): void;
|
|
74
74
|
unsubscribe(topics: string[]): void;
|
|
75
|
-
sendServiceCallRequest(
|
|
76
|
-
handleRawSend(data: WebRtcWorkerOutputMessage[
|
|
75
|
+
sendServiceCallRequest(args: ServiceCallPayload): void;
|
|
76
|
+
handleRawSend(data: WebRtcWorkerOutputMessage["data"]): void;
|
|
77
77
|
handleConnection(data: (WebRtcWorkerInputMessage & {
|
|
78
|
-
kind:
|
|
79
|
-
})[
|
|
78
|
+
kind: "connection";
|
|
79
|
+
})["data"]): void;
|
|
80
80
|
handleGeneric(message: GenericMessage): void;
|
|
81
81
|
handleServiceCall(message: ServiceCallMessage): void;
|
|
82
82
|
handleSystem(message: SystemMessage): void;
|
|
83
83
|
}
|
|
84
84
|
export {};
|
|
85
|
-
//# sourceMappingURL=
|
|
85
|
+
//# sourceMappingURL=handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../../../../../src/connection/webrtc/handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,7 +2,8 @@
|
|
|
2
2
|
// License, v2.0. If a copy of the MPL was not distributed with this
|
|
3
3
|
// file, You can obtain one at http://mozilla.org/MPL/2.0/
|
|
4
4
|
import { recordToDataView } from "../../utils/encoding";
|
|
5
|
-
import { FoxgloveCommunicator } from "../communicator";
|
|
5
|
+
import { FoxgloveCommunicator, } from "../communicator";
|
|
6
|
+
import { makeServiceCallRequest } from "../foxglove-protocol";
|
|
6
7
|
export class WebRtcHandler extends FoxgloveCommunicator {
|
|
7
8
|
#subscriptionId = 0;
|
|
8
9
|
#messageReady = false;
|
|
@@ -17,76 +18,72 @@ export class WebRtcHandler extends FoxgloveCommunicator {
|
|
|
17
18
|
sendWithTransfer(message, transfer) {
|
|
18
19
|
self.postMessage(message, transfer);
|
|
19
20
|
}
|
|
20
|
-
#rawSubscribe(
|
|
21
|
-
const
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
21
|
+
#rawSubscribe(channelId) {
|
|
22
|
+
const subscriptionId = ++this.#subscriptionId;
|
|
23
|
+
const subscriptions = [{
|
|
24
|
+
id: subscriptionId,
|
|
25
|
+
channelId,
|
|
26
|
+
}];
|
|
25
27
|
self.postMessage({
|
|
26
|
-
type:
|
|
28
|
+
type: "send",
|
|
27
29
|
data: {
|
|
28
|
-
channel:
|
|
30
|
+
channel: "system",
|
|
29
31
|
data: recordToDataView({
|
|
30
|
-
op:
|
|
31
|
-
subscriptions
|
|
32
|
-
})
|
|
33
|
-
}
|
|
32
|
+
op: "subscribe",
|
|
33
|
+
subscriptions,
|
|
34
|
+
}),
|
|
35
|
+
},
|
|
34
36
|
});
|
|
35
|
-
return
|
|
37
|
+
return subscriptionId;
|
|
36
38
|
}
|
|
37
39
|
subscribe(topics) {
|
|
38
|
-
const
|
|
39
|
-
const
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
kind: channel.kind
|
|
47
|
-
});
|
|
48
|
-
}
|
|
40
|
+
const channels = this.getPublicChannels().filter(publicChannel => topics.includes(publicChannel.topic));
|
|
41
|
+
for (const channel of channels) {
|
|
42
|
+
const subscription = this.#rawSubscribe(channel.id);
|
|
43
|
+
this.#subscriptions.set(subscription, {
|
|
44
|
+
topic: channel.topic,
|
|
45
|
+
schema: channel.schemaName,
|
|
46
|
+
kind: channel.kind
|
|
47
|
+
});
|
|
49
48
|
}
|
|
50
49
|
}
|
|
51
|
-
#rawUnsubscribe(
|
|
50
|
+
#rawUnsubscribe(subscriptionId) {
|
|
52
51
|
self.postMessage({
|
|
53
|
-
type:
|
|
52
|
+
type: "send",
|
|
54
53
|
data: {
|
|
55
|
-
channel:
|
|
54
|
+
channel: "system",
|
|
56
55
|
data: recordToDataView({
|
|
57
|
-
op:
|
|
58
|
-
subscriptionIds
|
|
59
|
-
})
|
|
60
|
-
}
|
|
56
|
+
op: "unsubscribe",
|
|
57
|
+
subscriptionIds: [subscriptionId],
|
|
58
|
+
}),
|
|
59
|
+
},
|
|
61
60
|
});
|
|
62
61
|
}
|
|
63
62
|
unsubscribe(topics) {
|
|
64
63
|
const subscriptionIds = [...this.#subscriptions.entries()].filter(([_id, data]) => topics.includes(data.topic)).map(subscription => subscription[0]);
|
|
65
|
-
this.#rawUnsubscribe(subscriptionIds);
|
|
66
64
|
for (const subscriptionId of subscriptionIds) {
|
|
67
65
|
this.#subscriptions.delete(subscriptionId);
|
|
66
|
+
this.#rawUnsubscribe(subscriptionId);
|
|
68
67
|
}
|
|
69
68
|
}
|
|
70
|
-
sendServiceCallRequest(
|
|
69
|
+
sendServiceCallRequest(args) {
|
|
70
|
+
const data = makeServiceCallRequest(args);
|
|
71
71
|
self.postMessage({
|
|
72
|
-
type:
|
|
73
|
-
data: {
|
|
74
|
-
|
|
75
|
-
data: recordToDataView(request)
|
|
76
|
-
}
|
|
77
|
-
});
|
|
72
|
+
type: "send",
|
|
73
|
+
data: { channel: "message", data },
|
|
74
|
+
}, [data.buffer]);
|
|
78
75
|
}
|
|
79
76
|
handleRawSend(data) {
|
|
80
77
|
self.postMessage({
|
|
81
|
-
type:
|
|
82
|
-
data
|
|
78
|
+
type: "send",
|
|
79
|
+
data,
|
|
83
80
|
});
|
|
84
81
|
}
|
|
85
82
|
handleConnection(data) {
|
|
86
|
-
if (!data.channel || data.channel ===
|
|
83
|
+
if (!data.channel || data.channel === "message") {
|
|
87
84
|
this.#messageReady = data.ready;
|
|
88
85
|
}
|
|
89
|
-
if (!data.channel || data.channel ===
|
|
86
|
+
if (!data.channel || data.channel === "system") {
|
|
90
87
|
this.#systemReady = data.ready;
|
|
91
88
|
}
|
|
92
89
|
}
|
|
@@ -101,27 +98,27 @@ export class WebRtcHandler extends FoxgloveCommunicator {
|
|
|
101
98
|
}
|
|
102
99
|
handleSystem(message) {
|
|
103
100
|
switch (message.op) {
|
|
104
|
-
case
|
|
101
|
+
case "advertise": {
|
|
105
102
|
this.handleChannelsAdvertisement(message.channels);
|
|
106
103
|
break;
|
|
107
104
|
}
|
|
108
|
-
case
|
|
105
|
+
case "unadvertise": {
|
|
109
106
|
this.handleChannelsUnadvertisement(message.channelIds);
|
|
110
107
|
break;
|
|
111
108
|
}
|
|
112
|
-
case
|
|
109
|
+
case "advertiseServices": {
|
|
113
110
|
this.handleServicesAdvertisement(message.services);
|
|
114
111
|
break;
|
|
115
112
|
}
|
|
116
|
-
case
|
|
113
|
+
case "unadvertiseServices": {
|
|
117
114
|
this.handleServicesUnadvertisement(message.serviceIds);
|
|
118
115
|
break;
|
|
119
116
|
}
|
|
120
|
-
case
|
|
117
|
+
case "serviceResponse": {
|
|
121
118
|
this.handleServiceResponse(message);
|
|
122
119
|
break;
|
|
123
120
|
}
|
|
124
121
|
}
|
|
125
122
|
}
|
|
126
123
|
}
|
|
127
|
-
//# sourceMappingURL=
|
|
124
|
+
//# sourceMappingURL=handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handler.js","sourceRoot":"","sources":["../../../../../../src/connection/webrtc/handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
// This Source Code Form is subject to the terms of the Mozilla Public
|
|
2
2
|
// License, v2.0. If a copy of the MPL was not distributed with this
|
|
3
3
|
// file, You can obtain one at http://mozilla.org/MPL/2.0/
|
|
4
|
-
import { WebRtcHandler } from "./
|
|
4
|
+
import { WebRtcHandler } from "./handler.js";
|
|
5
5
|
const handler = new WebRtcHandler();
|
|
6
6
|
self.addEventListener("message", (event) => {
|
|
7
7
|
if (event.data.kind === 'genericMessage') {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker.js","sourceRoot":"","sources":["../../../../../../src/connection/webrtc/worker.ts"],"names":[],"mappings":"AAAA,sEAAsE;AACtE,oEAAoE;AACpE,0DAA0D;AAE1D,OAAO,EAAE,aAAa,EAA4B,MAAM,
|
|
1
|
+
{"version":3,"file":"worker.js","sourceRoot":"","sources":["../../../../../../src/connection/webrtc/worker.ts"],"names":[],"mappings":"AAAA,sEAAsE;AACtE,oEAAoE;AACpE,0DAA0D;AAE1D,OAAO,EAAE,aAAa,EAA4B,MAAM,cAAc,CAAC;AAEvE,MAAM,OAAO,GAAG,IAAI,aAAa,EAAE,CAAC;AAEpC,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC,KAA6C,EAAE,EAAE;IACjF,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK,gBAAgB,EAAE,CAAC;QACzC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACjD,CAAC;SAAM,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK,eAAe,EAAE,CAAC;QAC/C,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAChD,CAAC;SAAM,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK,aAAa,EAAE,CAAC;QAC7C,OAAO,CAAC,iBAAiB,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrD,CAAC;SAAM,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QACzC,OAAO,CAAC,aAAa,CAAC;YACpB,OAAO,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO;YACxC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO;SACtC,CAAC,CAAC;IACL,CAAC;SAAM,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK,WAAW,EAAE,CAAC;QAC3C,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACpD,CAAC;SAAM,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK,aAAa,EAAE,CAAC;QAC7C,OAAO,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACtD,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5C,CAAC;AACH,CAAC,CAAC,CAAA"}
|
|
@@ -1,2 +1,17 @@
|
|
|
1
|
-
|
|
1
|
+
import { ServiceCallPayload } from "@foxglove/ws-protocol";
|
|
2
|
+
import { FoxgloveCommunicator, WorkerInputMessage, WorkerOutputMessage } from "../communicator.js";
|
|
3
|
+
export declare class WsWorker extends FoxgloveCommunicator {
|
|
4
|
+
#private;
|
|
5
|
+
protected send(message: WorkerOutputMessage): void;
|
|
6
|
+
protected sendWithTransfer(message: WorkerOutputMessage, transfer: ArrayBuffer[]): void;
|
|
7
|
+
protected sendServiceCallRequest(request: ServiceCallPayload): void;
|
|
8
|
+
protected isReady(): boolean;
|
|
9
|
+
constructor(wsUrl: string);
|
|
10
|
+
subscribe(topics: string[]): void;
|
|
11
|
+
unsubscribe(topics: string[]): void;
|
|
12
|
+
callService(args: (WorkerInputMessage & {
|
|
13
|
+
type: "call_service";
|
|
14
|
+
})["data"]): void;
|
|
15
|
+
close(): void;
|
|
16
|
+
}
|
|
2
17
|
//# sourceMappingURL=worker.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker.d.ts","sourceRoot":"","sources":["../../../../../../src/connection/ws/worker.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"worker.d.ts","sourceRoot":"","sources":["../../../../../../src/connection/ws/worker.ts"],"names":[],"mappings":"AAMA,OAAO,EAAkB,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAG3E,OAAO,EAAE,oBAAoB,EAAmB,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAEpH,qBAAa,QAAS,SAAQ,oBAAoB;;IAKhD,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,mBAAmB,GAAG,IAAI;IAClD,SAAS,CAAC,gBAAgB,CAAC,OAAO,EAAE,mBAAmB,EAAE,QAAQ,EAAE,WAAW,EAAE,GAAG,IAAI;cAuCpE,sBAAsB,CAAC,OAAO,EAAE,kBAAkB,GAAG,IAAI;cAIzD,OAAO,IAAI,OAAO;gBAIlB,KAAK,EAAE,MAAM;IAkBzB,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI;IAYjC,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI;IAQ1B,WAAW,CAAC,IAAI,EAAE,CAAC,kBAAkB,GAAG;QAAE,IAAI,EAAE,cAAc,CAAA;KAAE,CAAC,CAAC,MAAM,CAAC,GAAG,IAAI;IAIzF,KAAK,IAAI,IAAI;CACrB"}
|
|
@@ -1,6 +1,118 @@
|
|
|
1
1
|
// This Source Code Form is subject to the terms of the Mozilla Public
|
|
2
2
|
// License, v2.0. If a copy of the MPL was not distributed with this
|
|
3
3
|
// file, You can obtain one at http://mozilla.org/MPL/2.0/
|
|
4
|
-
import {
|
|
5
|
-
|
|
4
|
+
import { Waterfall } from "hydrated-ws";
|
|
5
|
+
import { FoxgloveClient } from "@foxglove/ws-protocol";
|
|
6
|
+
import { FoxgloveCommunicator } from "../communicator.js";
|
|
7
|
+
export class WsWorker extends FoxgloveCommunicator {
|
|
8
|
+
#ws;
|
|
9
|
+
#client;
|
|
10
|
+
#subscriptions = new Map();
|
|
11
|
+
send(message) { self.postMessage(message); }
|
|
12
|
+
sendWithTransfer(message, transfer) { self.postMessage(message, transfer); }
|
|
13
|
+
#createWs(url, onReconnect) {
|
|
14
|
+
this.#ws = new Waterfall(url, FoxgloveClient.SUPPORTED_SUBPROTOCOL, {
|
|
15
|
+
connectionTimeout: 2000,
|
|
16
|
+
retryPolicy: (_attempt) => {
|
|
17
|
+
onReconnect();
|
|
18
|
+
return 1_000;
|
|
19
|
+
},
|
|
20
|
+
factory: (wsUrl) => {
|
|
21
|
+
const rawWs = new WebSocket(wsUrl, FoxgloveClient.SUPPORTED_SUBPROTOCOL);
|
|
22
|
+
rawWs.binaryType = "arraybuffer";
|
|
23
|
+
return rawWs;
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
#createClient() {
|
|
28
|
+
this.#client = new FoxgloveClient({ ws: this.#ws });
|
|
29
|
+
this.#client.on("open", () => { this.send({ type: "open" }); });
|
|
30
|
+
this.#client.on("close", () => { this.send({ type: "close" }); });
|
|
31
|
+
this.#client.on("error", (error) => { this.send({ type: "error", error }); });
|
|
32
|
+
this.#client.on("message", ({ subscriptionId, data }) => {
|
|
33
|
+
const subscription = this.#subscriptions.get(subscriptionId);
|
|
34
|
+
if (subscription) {
|
|
35
|
+
this.handleGenericMessage(subscription.topic, subscription.schema, data);
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
#handleMessages() {
|
|
40
|
+
this.#client.on("advertise", this.handleChannelsAdvertisement.bind(this));
|
|
41
|
+
this.#client.on("unadvertise", this.handleChannelsUnadvertisement.bind(this));
|
|
42
|
+
this.#client.on("advertiseServices", this.handleServicesAdvertisement.bind(this));
|
|
43
|
+
this.#client.on("unadvertiseServices", this.handleServicesUnadvertisement.bind(this));
|
|
44
|
+
this.#client.on("serviceCallResponse", this.handleServiceResponse.bind(this));
|
|
45
|
+
}
|
|
46
|
+
sendServiceCallRequest(request) {
|
|
47
|
+
this.#client.sendServiceCallRequest(request);
|
|
48
|
+
}
|
|
49
|
+
isReady() {
|
|
50
|
+
return this.#ws.readyState === this.#ws.OPEN;
|
|
51
|
+
}
|
|
52
|
+
;
|
|
53
|
+
constructor(wsUrl) {
|
|
54
|
+
super();
|
|
55
|
+
try {
|
|
56
|
+
this.#createWs(wsUrl, this.handleReconnect.bind(this));
|
|
57
|
+
this.#createClient();
|
|
58
|
+
this.#handleMessages();
|
|
59
|
+
}
|
|
60
|
+
catch (error) {
|
|
61
|
+
// try-catch is needed to catch `Mixed Content` errors in Chrome, where the client
|
|
62
|
+
// attempts to load `ws://` from `https://`. (Safari would catch these in `ws.onerror`
|
|
63
|
+
// but with `undefined` as an error.)
|
|
64
|
+
this.send({
|
|
65
|
+
type: "error",
|
|
66
|
+
error: error ?? { message: "Insecure WebSocket connection" }
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
subscribe(topics) {
|
|
71
|
+
const channels = this.getPublicChannels().filter(publicChannel => topics.includes(publicChannel.topic));
|
|
72
|
+
for (const channel of channels) {
|
|
73
|
+
const subscription = this.#client.subscribe(channel.id);
|
|
74
|
+
this.#subscriptions.set(subscription, {
|
|
75
|
+
topic: channel.topic,
|
|
76
|
+
schema: channel.schemaName,
|
|
77
|
+
kind: channel.kind
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
unsubscribe(topics) {
|
|
82
|
+
const subscriptionIds = [...this.#subscriptions.entries()].filter(([_id, data]) => topics.includes(data.topic)).map(subscription => subscription[0]);
|
|
83
|
+
for (const subscriptionId of subscriptionIds) {
|
|
84
|
+
this.#subscriptions.delete(subscriptionId);
|
|
85
|
+
this.#client.unsubscribe(subscriptionId);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
callService(args) {
|
|
89
|
+
super.callService(args);
|
|
90
|
+
}
|
|
91
|
+
close() { this.#client.close(); }
|
|
92
|
+
}
|
|
93
|
+
let wsWorker = null;
|
|
94
|
+
self.addEventListener('message', async (event) => {
|
|
95
|
+
const { type, data } = event.data;
|
|
96
|
+
if (type !== 'open' && !wsWorker) {
|
|
97
|
+
console.warn(`WS Worker Error: Requested ${type} before open`);
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
switch (type) {
|
|
101
|
+
case "open":
|
|
102
|
+
wsWorker = new WsWorker('wsUrl' in data ? data.wsUrl : '');
|
|
103
|
+
break;
|
|
104
|
+
case "close":
|
|
105
|
+
wsWorker.close();
|
|
106
|
+
break;
|
|
107
|
+
case "call_service":
|
|
108
|
+
wsWorker.callService(data);
|
|
109
|
+
break;
|
|
110
|
+
case 'subscribe':
|
|
111
|
+
wsWorker.subscribe(data);
|
|
112
|
+
break;
|
|
113
|
+
case 'unsubscribe':
|
|
114
|
+
wsWorker.unsubscribe(data);
|
|
115
|
+
break;
|
|
116
|
+
}
|
|
117
|
+
});
|
|
6
118
|
//# sourceMappingURL=worker.js.map
|