@naylence/runtime 0.3.5-test.948 → 0.3.5-test.950
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/browser/index.cjs +33 -3
- package/dist/browser/index.mjs +33 -3
- package/dist/cjs/naylence/fame/connector/broadcast-channel-connector-factory.js +2 -0
- package/dist/cjs/naylence/fame/connector/broadcast-channel-listener.js +30 -1
- package/dist/cjs/version.js +2 -2
- package/dist/esm/naylence/fame/connector/broadcast-channel-connector-factory.js +2 -0
- package/dist/esm/naylence/fame/connector/broadcast-channel-listener.js +30 -1
- package/dist/esm/version.js +2 -2
- package/dist/node/index.cjs +33 -3
- package/dist/node/index.mjs +33 -3
- package/dist/node/node.cjs +33 -3
- package/dist/node/node.mjs +33 -3
- package/dist/types/version.d.ts +1 -1
- package/package.json +1 -1
package/dist/browser/index.cjs
CHANGED
|
@@ -98,12 +98,12 @@ installProcessEnvShim();
|
|
|
98
98
|
// --- END ENV SHIM ---
|
|
99
99
|
|
|
100
100
|
// This file is auto-generated during build - do not edit manually
|
|
101
|
-
// Generated from package.json version: 0.3.5-test.
|
|
101
|
+
// Generated from package.json version: 0.3.5-test.950
|
|
102
102
|
/**
|
|
103
103
|
* The package version, injected at build time.
|
|
104
104
|
* @internal
|
|
105
105
|
*/
|
|
106
|
-
const VERSION = '0.3.5-test.
|
|
106
|
+
const VERSION = '0.3.5-test.950';
|
|
107
107
|
|
|
108
108
|
/**
|
|
109
109
|
* Fame protocol specific error classes with WebSocket close codes and proper inheritance.
|
|
@@ -28976,6 +28976,8 @@ class BroadcastChannelConnectorFactory extends ConnectorFactory {
|
|
|
28976
28976
|
type: BROADCAST_CHANNEL_CONNECTOR_TYPE,
|
|
28977
28977
|
channelName: connectorConfig.channelName,
|
|
28978
28978
|
inboxCapacity: connectorConfig.inboxCapacity,
|
|
28979
|
+
localNodeId: connectorConfig.localNodeId,
|
|
28980
|
+
remoteNodeId: connectorConfig.remoteNodeId,
|
|
28979
28981
|
};
|
|
28980
28982
|
}
|
|
28981
28983
|
const config = {
|
|
@@ -30145,9 +30147,37 @@ class BroadcastChannelListener extends TransportListener {
|
|
|
30145
30147
|
});
|
|
30146
30148
|
return null;
|
|
30147
30149
|
}
|
|
30150
|
+
// Try to unwrap as transport frame first
|
|
30151
|
+
// Use wildcard for remoteNodeId since we don't know the sender's node ID yet
|
|
30152
|
+
let unwrapped = null;
|
|
30153
|
+
if (this._routingNode) {
|
|
30154
|
+
try {
|
|
30155
|
+
// First try to deserialize as transport frame
|
|
30156
|
+
const parsed = JSON.parse(new TextDecoder().decode(payload));
|
|
30157
|
+
if (parsed && typeof parsed === 'object' && 'v' in parsed && 'src' in parsed && 'dst' in parsed) {
|
|
30158
|
+
const frame = parsed;
|
|
30159
|
+
// Check if this frame is addressed to us (localNodeId)
|
|
30160
|
+
if (frame.dst === this._routingNode.id) {
|
|
30161
|
+
unwrapped = unwrapTransportFrame(payload, this._routingNode.id, '*');
|
|
30162
|
+
if (unwrapped) {
|
|
30163
|
+
logger$o.debug('broadcast_channel_listener_unwrapped_transport_frame', {
|
|
30164
|
+
sender_id: senderId,
|
|
30165
|
+
src: frame.src,
|
|
30166
|
+
dst: frame.dst,
|
|
30167
|
+
});
|
|
30168
|
+
}
|
|
30169
|
+
}
|
|
30170
|
+
}
|
|
30171
|
+
}
|
|
30172
|
+
catch {
|
|
30173
|
+
// Not a transport frame, continue with legacy format
|
|
30174
|
+
}
|
|
30175
|
+
}
|
|
30176
|
+
// Use unwrapped payload if available, otherwise use raw payload
|
|
30177
|
+
const envelopePayload = unwrapped ?? payload;
|
|
30148
30178
|
let envelope;
|
|
30149
30179
|
try {
|
|
30150
|
-
const decoded = new TextDecoder().decode(
|
|
30180
|
+
const decoded = new TextDecoder().decode(envelopePayload);
|
|
30151
30181
|
const parsed = JSON.parse(decoded);
|
|
30152
30182
|
envelope = core.deserializeEnvelope(parsed);
|
|
30153
30183
|
}
|
package/dist/browser/index.mjs
CHANGED
|
@@ -96,12 +96,12 @@ installProcessEnvShim();
|
|
|
96
96
|
// --- END ENV SHIM ---
|
|
97
97
|
|
|
98
98
|
// This file is auto-generated during build - do not edit manually
|
|
99
|
-
// Generated from package.json version: 0.3.5-test.
|
|
99
|
+
// Generated from package.json version: 0.3.5-test.950
|
|
100
100
|
/**
|
|
101
101
|
* The package version, injected at build time.
|
|
102
102
|
* @internal
|
|
103
103
|
*/
|
|
104
|
-
const VERSION = '0.3.5-test.
|
|
104
|
+
const VERSION = '0.3.5-test.950';
|
|
105
105
|
|
|
106
106
|
/**
|
|
107
107
|
* Fame protocol specific error classes with WebSocket close codes and proper inheritance.
|
|
@@ -28974,6 +28974,8 @@ class BroadcastChannelConnectorFactory extends ConnectorFactory {
|
|
|
28974
28974
|
type: BROADCAST_CHANNEL_CONNECTOR_TYPE,
|
|
28975
28975
|
channelName: connectorConfig.channelName,
|
|
28976
28976
|
inboxCapacity: connectorConfig.inboxCapacity,
|
|
28977
|
+
localNodeId: connectorConfig.localNodeId,
|
|
28978
|
+
remoteNodeId: connectorConfig.remoteNodeId,
|
|
28977
28979
|
};
|
|
28978
28980
|
}
|
|
28979
28981
|
const config = {
|
|
@@ -30143,9 +30145,37 @@ class BroadcastChannelListener extends TransportListener {
|
|
|
30143
30145
|
});
|
|
30144
30146
|
return null;
|
|
30145
30147
|
}
|
|
30148
|
+
// Try to unwrap as transport frame first
|
|
30149
|
+
// Use wildcard for remoteNodeId since we don't know the sender's node ID yet
|
|
30150
|
+
let unwrapped = null;
|
|
30151
|
+
if (this._routingNode) {
|
|
30152
|
+
try {
|
|
30153
|
+
// First try to deserialize as transport frame
|
|
30154
|
+
const parsed = JSON.parse(new TextDecoder().decode(payload));
|
|
30155
|
+
if (parsed && typeof parsed === 'object' && 'v' in parsed && 'src' in parsed && 'dst' in parsed) {
|
|
30156
|
+
const frame = parsed;
|
|
30157
|
+
// Check if this frame is addressed to us (localNodeId)
|
|
30158
|
+
if (frame.dst === this._routingNode.id) {
|
|
30159
|
+
unwrapped = unwrapTransportFrame(payload, this._routingNode.id, '*');
|
|
30160
|
+
if (unwrapped) {
|
|
30161
|
+
logger$o.debug('broadcast_channel_listener_unwrapped_transport_frame', {
|
|
30162
|
+
sender_id: senderId,
|
|
30163
|
+
src: frame.src,
|
|
30164
|
+
dst: frame.dst,
|
|
30165
|
+
});
|
|
30166
|
+
}
|
|
30167
|
+
}
|
|
30168
|
+
}
|
|
30169
|
+
}
|
|
30170
|
+
catch {
|
|
30171
|
+
// Not a transport frame, continue with legacy format
|
|
30172
|
+
}
|
|
30173
|
+
}
|
|
30174
|
+
// Use unwrapped payload if available, otherwise use raw payload
|
|
30175
|
+
const envelopePayload = unwrapped ?? payload;
|
|
30146
30176
|
let envelope;
|
|
30147
30177
|
try {
|
|
30148
|
-
const decoded = new TextDecoder().decode(
|
|
30178
|
+
const decoded = new TextDecoder().decode(envelopePayload);
|
|
30149
30179
|
const parsed = JSON.parse(decoded);
|
|
30150
30180
|
envelope = deserializeEnvelope(parsed);
|
|
30151
30181
|
}
|
|
@@ -40,6 +40,8 @@ class BroadcastChannelConnectorFactory extends connector_factory_js_1.ConnectorF
|
|
|
40
40
|
type: broadcast_channel_connector_js_1.BROADCAST_CHANNEL_CONNECTOR_TYPE,
|
|
41
41
|
channelName: connectorConfig.channelName,
|
|
42
42
|
inboxCapacity: connectorConfig.inboxCapacity,
|
|
43
|
+
localNodeId: connectorConfig.localNodeId,
|
|
44
|
+
remoteNodeId: connectorConfig.remoteNodeId,
|
|
43
45
|
};
|
|
44
46
|
}
|
|
45
47
|
const config = {
|
|
@@ -11,6 +11,7 @@ const broadcast_channel_connector_js_1 = require("./broadcast-channel-connector.
|
|
|
11
11
|
const grant_selection_policy_js_1 = require("./grant-selection-policy.js");
|
|
12
12
|
const bounded_async_queue_js_1 = require("../util/bounded-async-queue.js");
|
|
13
13
|
const broadcast_channel_connection_grant_js_1 = require("../grants/broadcast-channel-connection-grant.js");
|
|
14
|
+
const transport_frame_js_1 = require("./transport-frame.js");
|
|
14
15
|
const logger = (0, logging_js_1.getLogger)('naylence.fame.connector.broadcast_channel_listener');
|
|
15
16
|
const DEFAULT_CHANNEL = 'naylence-fabric';
|
|
16
17
|
const DEFAULT_INBOX_CAPACITY = 2048;
|
|
@@ -220,9 +221,37 @@ class BroadcastChannelListener extends transport_listener_js_1.TransportListener
|
|
|
220
221
|
});
|
|
221
222
|
return null;
|
|
222
223
|
}
|
|
224
|
+
// Try to unwrap as transport frame first
|
|
225
|
+
// Use wildcard for remoteNodeId since we don't know the sender's node ID yet
|
|
226
|
+
let unwrapped = null;
|
|
227
|
+
if (this._routingNode) {
|
|
228
|
+
try {
|
|
229
|
+
// First try to deserialize as transport frame
|
|
230
|
+
const parsed = JSON.parse(new TextDecoder().decode(payload));
|
|
231
|
+
if (parsed && typeof parsed === 'object' && 'v' in parsed && 'src' in parsed && 'dst' in parsed) {
|
|
232
|
+
const frame = parsed;
|
|
233
|
+
// Check if this frame is addressed to us (localNodeId)
|
|
234
|
+
if (frame.dst === this._routingNode.id) {
|
|
235
|
+
unwrapped = (0, transport_frame_js_1.unwrapTransportFrame)(payload, this._routingNode.id, '*');
|
|
236
|
+
if (unwrapped) {
|
|
237
|
+
logger.debug('broadcast_channel_listener_unwrapped_transport_frame', {
|
|
238
|
+
sender_id: senderId,
|
|
239
|
+
src: frame.src,
|
|
240
|
+
dst: frame.dst,
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
catch {
|
|
247
|
+
// Not a transport frame, continue with legacy format
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
// Use unwrapped payload if available, otherwise use raw payload
|
|
251
|
+
const envelopePayload = unwrapped ?? payload;
|
|
223
252
|
let envelope;
|
|
224
253
|
try {
|
|
225
|
-
const decoded = new TextDecoder().decode(
|
|
254
|
+
const decoded = new TextDecoder().decode(envelopePayload);
|
|
226
255
|
const parsed = JSON.parse(decoded);
|
|
227
256
|
envelope = (0, core_1.deserializeEnvelope)(parsed);
|
|
228
257
|
}
|
package/dist/cjs/version.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
// This file is auto-generated during build - do not edit manually
|
|
3
|
-
// Generated from package.json version: 0.3.5-test.
|
|
3
|
+
// Generated from package.json version: 0.3.5-test.950
|
|
4
4
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
5
|
exports.VERSION = void 0;
|
|
6
6
|
/**
|
|
7
7
|
* The package version, injected at build time.
|
|
8
8
|
* @internal
|
|
9
9
|
*/
|
|
10
|
-
exports.VERSION = '0.3.5-test.
|
|
10
|
+
exports.VERSION = '0.3.5-test.950';
|
|
@@ -37,6 +37,8 @@ export class BroadcastChannelConnectorFactory extends ConnectorFactory {
|
|
|
37
37
|
type: BROADCAST_CHANNEL_CONNECTOR_TYPE,
|
|
38
38
|
channelName: connectorConfig.channelName,
|
|
39
39
|
inboxCapacity: connectorConfig.inboxCapacity,
|
|
40
|
+
localNodeId: connectorConfig.localNodeId,
|
|
41
|
+
remoteNodeId: connectorConfig.remoteNodeId,
|
|
40
42
|
};
|
|
41
43
|
}
|
|
42
44
|
const config = {
|
|
@@ -7,6 +7,7 @@ import { BROADCAST_CHANNEL_CONNECTOR_TYPE, } from './broadcast-channel-connector
|
|
|
7
7
|
import { GrantSelectionContext, defaultGrantSelectionPolicy, } from './grant-selection-policy.js';
|
|
8
8
|
import { QueueFullError } from '../util/bounded-async-queue.js';
|
|
9
9
|
import { BROADCAST_CHANNEL_CONNECTION_GRANT_TYPE, broadcastChannelGrantToConnectorConfig, } from '../grants/broadcast-channel-connection-grant.js';
|
|
10
|
+
import { unwrapTransportFrame, } from './transport-frame.js';
|
|
10
11
|
const logger = getLogger('naylence.fame.connector.broadcast_channel_listener');
|
|
11
12
|
const DEFAULT_CHANNEL = 'naylence-fabric';
|
|
12
13
|
const DEFAULT_INBOX_CAPACITY = 2048;
|
|
@@ -216,9 +217,37 @@ export class BroadcastChannelListener extends TransportListener {
|
|
|
216
217
|
});
|
|
217
218
|
return null;
|
|
218
219
|
}
|
|
220
|
+
// Try to unwrap as transport frame first
|
|
221
|
+
// Use wildcard for remoteNodeId since we don't know the sender's node ID yet
|
|
222
|
+
let unwrapped = null;
|
|
223
|
+
if (this._routingNode) {
|
|
224
|
+
try {
|
|
225
|
+
// First try to deserialize as transport frame
|
|
226
|
+
const parsed = JSON.parse(new TextDecoder().decode(payload));
|
|
227
|
+
if (parsed && typeof parsed === 'object' && 'v' in parsed && 'src' in parsed && 'dst' in parsed) {
|
|
228
|
+
const frame = parsed;
|
|
229
|
+
// Check if this frame is addressed to us (localNodeId)
|
|
230
|
+
if (frame.dst === this._routingNode.id) {
|
|
231
|
+
unwrapped = unwrapTransportFrame(payload, this._routingNode.id, '*');
|
|
232
|
+
if (unwrapped) {
|
|
233
|
+
logger.debug('broadcast_channel_listener_unwrapped_transport_frame', {
|
|
234
|
+
sender_id: senderId,
|
|
235
|
+
src: frame.src,
|
|
236
|
+
dst: frame.dst,
|
|
237
|
+
});
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
catch {
|
|
243
|
+
// Not a transport frame, continue with legacy format
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
// Use unwrapped payload if available, otherwise use raw payload
|
|
247
|
+
const envelopePayload = unwrapped ?? payload;
|
|
219
248
|
let envelope;
|
|
220
249
|
try {
|
|
221
|
-
const decoded = new TextDecoder().decode(
|
|
250
|
+
const decoded = new TextDecoder().decode(envelopePayload);
|
|
222
251
|
const parsed = JSON.parse(decoded);
|
|
223
252
|
envelope = deserializeEnvelope(parsed);
|
|
224
253
|
}
|
package/dist/esm/version.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
// This file is auto-generated during build - do not edit manually
|
|
2
|
-
// Generated from package.json version: 0.3.5-test.
|
|
2
|
+
// Generated from package.json version: 0.3.5-test.950
|
|
3
3
|
/**
|
|
4
4
|
* The package version, injected at build time.
|
|
5
5
|
* @internal
|
|
6
6
|
*/
|
|
7
|
-
export const VERSION = '0.3.5-test.
|
|
7
|
+
export const VERSION = '0.3.5-test.950';
|
package/dist/node/index.cjs
CHANGED
|
@@ -14,12 +14,12 @@ var fastify = require('fastify');
|
|
|
14
14
|
var websocketPlugin = require('@fastify/websocket');
|
|
15
15
|
|
|
16
16
|
// This file is auto-generated during build - do not edit manually
|
|
17
|
-
// Generated from package.json version: 0.3.5-test.
|
|
17
|
+
// Generated from package.json version: 0.3.5-test.950
|
|
18
18
|
/**
|
|
19
19
|
* The package version, injected at build time.
|
|
20
20
|
* @internal
|
|
21
21
|
*/
|
|
22
|
-
const VERSION = '0.3.5-test.
|
|
22
|
+
const VERSION = '0.3.5-test.950';
|
|
23
23
|
|
|
24
24
|
/**
|
|
25
25
|
* Fame protocol specific error classes with WebSocket close codes and proper inheritance.
|
|
@@ -28718,6 +28718,8 @@ class BroadcastChannelConnectorFactory extends ConnectorFactory {
|
|
|
28718
28718
|
type: BROADCAST_CHANNEL_CONNECTOR_TYPE,
|
|
28719
28719
|
channelName: connectorConfig.channelName,
|
|
28720
28720
|
inboxCapacity: connectorConfig.inboxCapacity,
|
|
28721
|
+
localNodeId: connectorConfig.localNodeId,
|
|
28722
|
+
remoteNodeId: connectorConfig.remoteNodeId,
|
|
28721
28723
|
};
|
|
28722
28724
|
}
|
|
28723
28725
|
const config = {
|
|
@@ -36326,9 +36328,37 @@ class BroadcastChannelListener extends TransportListener {
|
|
|
36326
36328
|
});
|
|
36327
36329
|
return null;
|
|
36328
36330
|
}
|
|
36331
|
+
// Try to unwrap as transport frame first
|
|
36332
|
+
// Use wildcard for remoteNodeId since we don't know the sender's node ID yet
|
|
36333
|
+
let unwrapped = null;
|
|
36334
|
+
if (this._routingNode) {
|
|
36335
|
+
try {
|
|
36336
|
+
// First try to deserialize as transport frame
|
|
36337
|
+
const parsed = JSON.parse(new TextDecoder().decode(payload));
|
|
36338
|
+
if (parsed && typeof parsed === 'object' && 'v' in parsed && 'src' in parsed && 'dst' in parsed) {
|
|
36339
|
+
const frame = parsed;
|
|
36340
|
+
// Check if this frame is addressed to us (localNodeId)
|
|
36341
|
+
if (frame.dst === this._routingNode.id) {
|
|
36342
|
+
unwrapped = unwrapTransportFrame(payload, this._routingNode.id, '*');
|
|
36343
|
+
if (unwrapped) {
|
|
36344
|
+
logger$a.debug('broadcast_channel_listener_unwrapped_transport_frame', {
|
|
36345
|
+
sender_id: senderId,
|
|
36346
|
+
src: frame.src,
|
|
36347
|
+
dst: frame.dst,
|
|
36348
|
+
});
|
|
36349
|
+
}
|
|
36350
|
+
}
|
|
36351
|
+
}
|
|
36352
|
+
}
|
|
36353
|
+
catch {
|
|
36354
|
+
// Not a transport frame, continue with legacy format
|
|
36355
|
+
}
|
|
36356
|
+
}
|
|
36357
|
+
// Use unwrapped payload if available, otherwise use raw payload
|
|
36358
|
+
const envelopePayload = unwrapped ?? payload;
|
|
36329
36359
|
let envelope;
|
|
36330
36360
|
try {
|
|
36331
|
-
const decoded = new TextDecoder().decode(
|
|
36361
|
+
const decoded = new TextDecoder().decode(envelopePayload);
|
|
36332
36362
|
const parsed = JSON.parse(decoded);
|
|
36333
36363
|
envelope = core.deserializeEnvelope(parsed);
|
|
36334
36364
|
}
|
package/dist/node/index.mjs
CHANGED
|
@@ -13,12 +13,12 @@ import fastify from 'fastify';
|
|
|
13
13
|
import websocketPlugin from '@fastify/websocket';
|
|
14
14
|
|
|
15
15
|
// This file is auto-generated during build - do not edit manually
|
|
16
|
-
// Generated from package.json version: 0.3.5-test.
|
|
16
|
+
// Generated from package.json version: 0.3.5-test.950
|
|
17
17
|
/**
|
|
18
18
|
* The package version, injected at build time.
|
|
19
19
|
* @internal
|
|
20
20
|
*/
|
|
21
|
-
const VERSION = '0.3.5-test.
|
|
21
|
+
const VERSION = '0.3.5-test.950';
|
|
22
22
|
|
|
23
23
|
/**
|
|
24
24
|
* Fame protocol specific error classes with WebSocket close codes and proper inheritance.
|
|
@@ -28717,6 +28717,8 @@ class BroadcastChannelConnectorFactory extends ConnectorFactory {
|
|
|
28717
28717
|
type: BROADCAST_CHANNEL_CONNECTOR_TYPE,
|
|
28718
28718
|
channelName: connectorConfig.channelName,
|
|
28719
28719
|
inboxCapacity: connectorConfig.inboxCapacity,
|
|
28720
|
+
localNodeId: connectorConfig.localNodeId,
|
|
28721
|
+
remoteNodeId: connectorConfig.remoteNodeId,
|
|
28720
28722
|
};
|
|
28721
28723
|
}
|
|
28722
28724
|
const config = {
|
|
@@ -36325,9 +36327,37 @@ class BroadcastChannelListener extends TransportListener {
|
|
|
36325
36327
|
});
|
|
36326
36328
|
return null;
|
|
36327
36329
|
}
|
|
36330
|
+
// Try to unwrap as transport frame first
|
|
36331
|
+
// Use wildcard for remoteNodeId since we don't know the sender's node ID yet
|
|
36332
|
+
let unwrapped = null;
|
|
36333
|
+
if (this._routingNode) {
|
|
36334
|
+
try {
|
|
36335
|
+
// First try to deserialize as transport frame
|
|
36336
|
+
const parsed = JSON.parse(new TextDecoder().decode(payload));
|
|
36337
|
+
if (parsed && typeof parsed === 'object' && 'v' in parsed && 'src' in parsed && 'dst' in parsed) {
|
|
36338
|
+
const frame = parsed;
|
|
36339
|
+
// Check if this frame is addressed to us (localNodeId)
|
|
36340
|
+
if (frame.dst === this._routingNode.id) {
|
|
36341
|
+
unwrapped = unwrapTransportFrame(payload, this._routingNode.id, '*');
|
|
36342
|
+
if (unwrapped) {
|
|
36343
|
+
logger$a.debug('broadcast_channel_listener_unwrapped_transport_frame', {
|
|
36344
|
+
sender_id: senderId,
|
|
36345
|
+
src: frame.src,
|
|
36346
|
+
dst: frame.dst,
|
|
36347
|
+
});
|
|
36348
|
+
}
|
|
36349
|
+
}
|
|
36350
|
+
}
|
|
36351
|
+
}
|
|
36352
|
+
catch {
|
|
36353
|
+
// Not a transport frame, continue with legacy format
|
|
36354
|
+
}
|
|
36355
|
+
}
|
|
36356
|
+
// Use unwrapped payload if available, otherwise use raw payload
|
|
36357
|
+
const envelopePayload = unwrapped ?? payload;
|
|
36328
36358
|
let envelope;
|
|
36329
36359
|
try {
|
|
36330
|
-
const decoded = new TextDecoder().decode(
|
|
36360
|
+
const decoded = new TextDecoder().decode(envelopePayload);
|
|
36331
36361
|
const parsed = JSON.parse(decoded);
|
|
36332
36362
|
envelope = deserializeEnvelope(parsed);
|
|
36333
36363
|
}
|
package/dist/node/node.cjs
CHANGED
|
@@ -5478,12 +5478,12 @@ for (const [name, config] of Object.entries(SQLITE_PROFILES)) {
|
|
|
5478
5478
|
}
|
|
5479
5479
|
|
|
5480
5480
|
// This file is auto-generated during build - do not edit manually
|
|
5481
|
-
// Generated from package.json version: 0.3.5-test.
|
|
5481
|
+
// Generated from package.json version: 0.3.5-test.950
|
|
5482
5482
|
/**
|
|
5483
5483
|
* The package version, injected at build time.
|
|
5484
5484
|
* @internal
|
|
5485
5485
|
*/
|
|
5486
|
-
const VERSION = '0.3.5-test.
|
|
5486
|
+
const VERSION = '0.3.5-test.950';
|
|
5487
5487
|
|
|
5488
5488
|
/**
|
|
5489
5489
|
* Fame errors module - Fame protocol specific error classes
|
|
@@ -30679,6 +30679,8 @@ class BroadcastChannelConnectorFactory extends ConnectorFactory {
|
|
|
30679
30679
|
type: BROADCAST_CHANNEL_CONNECTOR_TYPE$1,
|
|
30680
30680
|
channelName: connectorConfig.channelName,
|
|
30681
30681
|
inboxCapacity: connectorConfig.inboxCapacity,
|
|
30682
|
+
localNodeId: connectorConfig.localNodeId,
|
|
30683
|
+
remoteNodeId: connectorConfig.remoteNodeId,
|
|
30682
30684
|
};
|
|
30683
30685
|
}
|
|
30684
30686
|
const config = {
|
|
@@ -32902,9 +32904,37 @@ class BroadcastChannelListener extends TransportListener {
|
|
|
32902
32904
|
});
|
|
32903
32905
|
return null;
|
|
32904
32906
|
}
|
|
32907
|
+
// Try to unwrap as transport frame first
|
|
32908
|
+
// Use wildcard for remoteNodeId since we don't know the sender's node ID yet
|
|
32909
|
+
let unwrapped = null;
|
|
32910
|
+
if (this._routingNode) {
|
|
32911
|
+
try {
|
|
32912
|
+
// First try to deserialize as transport frame
|
|
32913
|
+
const parsed = JSON.parse(new TextDecoder().decode(payload));
|
|
32914
|
+
if (parsed && typeof parsed === 'object' && 'v' in parsed && 'src' in parsed && 'dst' in parsed) {
|
|
32915
|
+
const frame = parsed;
|
|
32916
|
+
// Check if this frame is addressed to us (localNodeId)
|
|
32917
|
+
if (frame.dst === this._routingNode.id) {
|
|
32918
|
+
unwrapped = unwrapTransportFrame(payload, this._routingNode.id, '*');
|
|
32919
|
+
if (unwrapped) {
|
|
32920
|
+
logger$n.debug('broadcast_channel_listener_unwrapped_transport_frame', {
|
|
32921
|
+
sender_id: senderId,
|
|
32922
|
+
src: frame.src,
|
|
32923
|
+
dst: frame.dst,
|
|
32924
|
+
});
|
|
32925
|
+
}
|
|
32926
|
+
}
|
|
32927
|
+
}
|
|
32928
|
+
}
|
|
32929
|
+
catch {
|
|
32930
|
+
// Not a transport frame, continue with legacy format
|
|
32931
|
+
}
|
|
32932
|
+
}
|
|
32933
|
+
// Use unwrapped payload if available, otherwise use raw payload
|
|
32934
|
+
const envelopePayload = unwrapped ?? payload;
|
|
32905
32935
|
let envelope;
|
|
32906
32936
|
try {
|
|
32907
|
-
const decoded = new TextDecoder().decode(
|
|
32937
|
+
const decoded = new TextDecoder().decode(envelopePayload);
|
|
32908
32938
|
const parsed = JSON.parse(decoded);
|
|
32909
32939
|
envelope = core.deserializeEnvelope(parsed);
|
|
32910
32940
|
}
|
package/dist/node/node.mjs
CHANGED
|
@@ -5477,12 +5477,12 @@ for (const [name, config] of Object.entries(SQLITE_PROFILES)) {
|
|
|
5477
5477
|
}
|
|
5478
5478
|
|
|
5479
5479
|
// This file is auto-generated during build - do not edit manually
|
|
5480
|
-
// Generated from package.json version: 0.3.5-test.
|
|
5480
|
+
// Generated from package.json version: 0.3.5-test.950
|
|
5481
5481
|
/**
|
|
5482
5482
|
* The package version, injected at build time.
|
|
5483
5483
|
* @internal
|
|
5484
5484
|
*/
|
|
5485
|
-
const VERSION = '0.3.5-test.
|
|
5485
|
+
const VERSION = '0.3.5-test.950';
|
|
5486
5486
|
|
|
5487
5487
|
/**
|
|
5488
5488
|
* Fame errors module - Fame protocol specific error classes
|
|
@@ -30678,6 +30678,8 @@ class BroadcastChannelConnectorFactory extends ConnectorFactory {
|
|
|
30678
30678
|
type: BROADCAST_CHANNEL_CONNECTOR_TYPE$1,
|
|
30679
30679
|
channelName: connectorConfig.channelName,
|
|
30680
30680
|
inboxCapacity: connectorConfig.inboxCapacity,
|
|
30681
|
+
localNodeId: connectorConfig.localNodeId,
|
|
30682
|
+
remoteNodeId: connectorConfig.remoteNodeId,
|
|
30681
30683
|
};
|
|
30682
30684
|
}
|
|
30683
30685
|
const config = {
|
|
@@ -32901,9 +32903,37 @@ class BroadcastChannelListener extends TransportListener {
|
|
|
32901
32903
|
});
|
|
32902
32904
|
return null;
|
|
32903
32905
|
}
|
|
32906
|
+
// Try to unwrap as transport frame first
|
|
32907
|
+
// Use wildcard for remoteNodeId since we don't know the sender's node ID yet
|
|
32908
|
+
let unwrapped = null;
|
|
32909
|
+
if (this._routingNode) {
|
|
32910
|
+
try {
|
|
32911
|
+
// First try to deserialize as transport frame
|
|
32912
|
+
const parsed = JSON.parse(new TextDecoder().decode(payload));
|
|
32913
|
+
if (parsed && typeof parsed === 'object' && 'v' in parsed && 'src' in parsed && 'dst' in parsed) {
|
|
32914
|
+
const frame = parsed;
|
|
32915
|
+
// Check if this frame is addressed to us (localNodeId)
|
|
32916
|
+
if (frame.dst === this._routingNode.id) {
|
|
32917
|
+
unwrapped = unwrapTransportFrame(payload, this._routingNode.id, '*');
|
|
32918
|
+
if (unwrapped) {
|
|
32919
|
+
logger$n.debug('broadcast_channel_listener_unwrapped_transport_frame', {
|
|
32920
|
+
sender_id: senderId,
|
|
32921
|
+
src: frame.src,
|
|
32922
|
+
dst: frame.dst,
|
|
32923
|
+
});
|
|
32924
|
+
}
|
|
32925
|
+
}
|
|
32926
|
+
}
|
|
32927
|
+
}
|
|
32928
|
+
catch {
|
|
32929
|
+
// Not a transport frame, continue with legacy format
|
|
32930
|
+
}
|
|
32931
|
+
}
|
|
32932
|
+
// Use unwrapped payload if available, otherwise use raw payload
|
|
32933
|
+
const envelopePayload = unwrapped ?? payload;
|
|
32904
32934
|
let envelope;
|
|
32905
32935
|
try {
|
|
32906
|
-
const decoded = new TextDecoder().decode(
|
|
32936
|
+
const decoded = new TextDecoder().decode(envelopePayload);
|
|
32907
32937
|
const parsed = JSON.parse(decoded);
|
|
32908
32938
|
envelope = deserializeEnvelope(parsed);
|
|
32909
32939
|
}
|
package/dist/types/version.d.ts
CHANGED