@dxos/edge-client 0.7.5-main.9d26e3a → 0.7.5-main.e9bb01b

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.
@@ -69,6 +69,7 @@ function _ts_decorate(decorators, target, key, desc) {
69
69
  }
70
70
  var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/core/mesh/edge-client/src/edge-ws-connection.ts";
71
71
  var SIGNAL_KEEPALIVE_INTERVAL = 5e3;
72
+ var CLOUDFLARE_MESSAGE_LENGTH_LIMIT = 1024 * 1024;
72
73
  var EdgeWsConnection = class extends Resource {
73
74
  constructor(_identity, _connectionInfo, _callbacks) {
74
75
  super();
@@ -86,7 +87,7 @@ var EdgeWsConnection = class extends Resource {
86
87
  send(message) {
87
88
  invariant2(this._ws, void 0, {
88
89
  F: __dxlog_file2,
89
- L: 48,
90
+ L: 53,
90
91
  S: this,
91
92
  A: [
92
93
  "this._ws",
@@ -98,11 +99,25 @@ var EdgeWsConnection = class extends Resource {
98
99
  payload: protocol.getPayloadType(message)
99
100
  }, {
100
101
  F: __dxlog_file2,
101
- L: 49,
102
+ L: 54,
102
103
  S: this,
103
104
  C: (f, a) => f(...a)
104
105
  });
105
- this._ws.send(buf.toBinary(MessageSchema, message));
106
+ const encoded = buf.toBinary(MessageSchema, message);
107
+ if (encoded.byteLength >= CLOUDFLARE_MESSAGE_LENGTH_LIMIT) {
108
+ log.error("edge message dropped due to websocket message limit", {
109
+ byteLength: encoded.byteLength,
110
+ serviceId: message.serviceId,
111
+ payload: protocol.getPayloadType(message)
112
+ }, {
113
+ F: __dxlog_file2,
114
+ L: 57,
115
+ S: this,
116
+ C: (f, a) => f(...a)
117
+ });
118
+ return;
119
+ }
120
+ this._ws.send(encoded);
106
121
  }
107
122
  async _open() {
108
123
  this._ws = new WebSocket(this._connectionInfo.url.toString(), this._connectionInfo.protocolHeader ? [
@@ -112,7 +127,7 @@ var EdgeWsConnection = class extends Resource {
112
127
  if (this.isOpen) {
113
128
  log("connected", void 0, {
114
129
  F: __dxlog_file2,
115
- L: 61,
130
+ L: 75,
116
131
  S: this,
117
132
  C: (f, a) => f(...a)
118
133
  });
@@ -123,7 +138,7 @@ var EdgeWsConnection = class extends Resource {
123
138
  currentIdentity: this._identity
124
139
  }, {
125
140
  F: __dxlog_file2,
126
- L: 65,
141
+ L: 79,
127
142
  S: this,
128
143
  C: (f, a) => f(...a)
129
144
  });
@@ -133,7 +148,7 @@ var EdgeWsConnection = class extends Resource {
133
148
  if (this.isOpen) {
134
149
  log("disconnected while being open", void 0, {
135
150
  F: __dxlog_file2,
136
- L: 70,
151
+ L: 84,
137
152
  S: this,
138
153
  C: (f, a) => f(...a)
139
154
  });
@@ -147,7 +162,7 @@ var EdgeWsConnection = class extends Resource {
147
162
  info: event.message
148
163
  }, {
149
164
  F: __dxlog_file2,
150
- L: 76,
165
+ L: 90,
151
166
  S: this,
152
167
  C: (f, a) => f(...a)
153
168
  });
@@ -157,7 +172,7 @@ var EdgeWsConnection = class extends Resource {
157
172
  error: event.error
158
173
  }, {
159
174
  F: __dxlog_file2,
160
- L: 79,
175
+ L: 93,
161
176
  S: this,
162
177
  C: (f, a) => f(...a)
163
178
  });
@@ -169,7 +184,7 @@ var EdgeWsConnection = class extends Resource {
169
184
  event: event.type
170
185
  }, {
171
186
  F: __dxlog_file2,
172
- L: 87,
187
+ L: 101,
173
188
  S: this,
174
189
  C: (f, a) => f(...a)
175
190
  });
@@ -187,7 +202,7 @@ var EdgeWsConnection = class extends Resource {
187
202
  payload: protocol.getPayloadType(message)
188
203
  }, {
189
204
  F: __dxlog_file2,
190
- L: 97,
205
+ L: 111,
191
206
  S: this,
192
207
  C: (f, a) => f(...a)
193
208
  });
@@ -209,7 +224,7 @@ var EdgeWsConnection = class extends Resource {
209
224
  err
210
225
  }, {
211
226
  F: __dxlog_file2,
212
- L: 113,
227
+ L: 127,
213
228
  S: this,
214
229
  C: (f, a) => f(...a)
215
230
  });
@@ -218,7 +233,7 @@ var EdgeWsConnection = class extends Resource {
218
233
  _scheduleHeartbeats() {
219
234
  invariant2(this._ws, void 0, {
220
235
  F: __dxlog_file2,
221
- L: 118,
236
+ L: 132,
222
237
  S: this,
223
238
  A: [
224
239
  "this._ws",
@@ -238,7 +253,7 @@ var EdgeWsConnection = class extends Resource {
238
253
  void this._inactivityTimeoutCtx?.dispose();
239
254
  this._inactivityTimeoutCtx = new Context(void 0, {
240
255
  F: __dxlog_file2,
241
- L: 137
256
+ L: 151
242
257
  });
243
258
  scheduleTask(this._inactivityTimeoutCtx, () => {
244
259
  if (this.isOpen) {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/index.ts", "../../../src/edge-client.ts", "../../../src/edge-identity.ts", "../../../src/edge-ws-connection.ts", "../../../src/errors.ts", "../../../src/persistent-lifecycle.ts", "../../../src/utils.ts", "../../../src/auth.ts", "../../../src/edge-http-client.ts"],
4
- "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nexport * from '@dxos/protocols/buf/dxos/edge/messenger_pb';\n\nexport * from './edge-client';\nexport * from './defs';\nexport * from './protocol';\nexport * from './errors';\nexport * from './auth';\nexport * from './edge-http-client';\nexport * from './edge-identity';\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { Trigger, scheduleMicroTask, TriggerState } from '@dxos/async';\nimport { Resource, type Lifecycle } from '@dxos/context';\nimport { log, logInfo } from '@dxos/log';\nimport { type Message } from '@dxos/protocols/buf/dxos/edge/messenger_pb';\n\nimport { protocol } from './defs';\nimport { type EdgeIdentity, handleAuthChallenge } from './edge-identity';\nimport { EdgeWsConnection } from './edge-ws-connection';\nimport { EdgeConnectionClosedError, EdgeIdentityChangedError } from './errors';\nimport { PersistentLifecycle } from './persistent-lifecycle';\nimport { type Protocol } from './protocol';\nimport { getEdgeUrlWithProtocol } from './utils';\n\nconst DEFAULT_TIMEOUT = 10_000;\n\nexport type MessageListener = (message: Message) => void;\nexport type ReconnectListener = () => void;\n\nexport interface EdgeConnection extends Required<Lifecycle> {\n get info(): any;\n get identityKey(): string;\n get peerKey(): string;\n get isOpen(): boolean;\n get isConnected(): boolean;\n setIdentity(identity: EdgeIdentity): void;\n onMessage(listener: MessageListener): () => void;\n onReconnected(listener: ReconnectListener): () => void;\n send(message: Message): Promise<void>;\n}\n\nexport type MessengerConfig = {\n socketEndpoint: string;\n timeout?: number;\n protocol?: Protocol;\n disableAuth?: boolean;\n};\n\n/**\n * Messenger client for EDGE:\n * - While open, uses PersistentLifecycle to keep an open EdgeWsConnection, reconnecting on failures.\n * - Manages identity and re-create EdgeWsConnection when identity changes.\n * - Dispatches connection state and message notifications.\n */\nexport class EdgeClient extends Resource implements EdgeConnection {\n private readonly _persistentLifecycle = new PersistentLifecycle<EdgeWsConnection>({\n start: async () => this._connect(),\n stop: async (state: EdgeWsConnection) => this._disconnect(state),\n });\n\n private readonly _messageListeners = new Set<MessageListener>();\n private readonly _reconnectListeners = new Set<ReconnectListener>();\n\n private readonly _baseWsUrl: string;\n private readonly _baseHttpUrl: string;\n\n private _currentConnection?: EdgeWsConnection = undefined;\n private _ready = new Trigger();\n\n constructor(\n private _identity: EdgeIdentity,\n private readonly _config: MessengerConfig,\n ) {\n super();\n this._baseWsUrl = getEdgeUrlWithProtocol(_config.socketEndpoint, 'ws');\n this._baseHttpUrl = getEdgeUrlWithProtocol(_config.socketEndpoint, 'http');\n }\n\n @logInfo\n public get info() {\n return {\n open: this.isOpen,\n identity: this._identity.identityKey,\n device: this._identity.peerKey,\n };\n }\n\n get isConnected() {\n return Boolean(this._currentConnection) && this._ready.state === TriggerState.RESOLVED;\n }\n\n get identityKey() {\n return this._identity.identityKey;\n }\n\n get peerKey() {\n return this._identity.peerKey;\n }\n\n setIdentity(identity: EdgeIdentity) {\n if (identity.identityKey !== this._identity.identityKey || identity.peerKey !== this._identity.peerKey) {\n log('Edge identity changed', { identity, oldIdentity: this._identity });\n this._identity = identity;\n this._closeCurrentConnection(new EdgeIdentityChangedError());\n this._persistentLifecycle.scheduleRestart();\n }\n }\n\n public onMessage(listener: MessageListener): () => void {\n this._messageListeners.add(listener);\n return () => this._messageListeners.delete(listener);\n }\n\n public onReconnected(listener: () => void): () => void {\n this._reconnectListeners.add(listener);\n if (this._ready.state === TriggerState.RESOLVED) {\n // Microtask so that listener is always called asynchronously, no matter the state of the ready trigger\n // at the moment of registration.\n scheduleMicroTask(this._ctx, () => {\n if (this._reconnectListeners.has(listener)) {\n try {\n listener();\n } catch (error) {\n log.catch(error);\n }\n }\n });\n }\n return () => this._reconnectListeners.delete(listener);\n }\n\n /**\n * Open connection to messaging service.\n */\n protected override async _open() {\n log('opening...', { info: this.info });\n this._persistentLifecycle.open().catch((err) => {\n log.warn('Error while opening connection', { err });\n });\n }\n\n /**\n * Close connection and free resources.\n */\n protected override async _close() {\n log('closing...', { peerKey: this._identity.peerKey });\n this._closeCurrentConnection();\n await this._persistentLifecycle.close();\n }\n\n private async _connect(): Promise<EdgeWsConnection | undefined> {\n if (this._ctx.disposed) {\n return undefined;\n }\n\n const identity = this._identity;\n const path = `/ws/${identity.identityKey}/${identity.peerKey}`;\n const protocolHeader = this._config.disableAuth ? undefined : await this._createAuthHeader(path);\n if (this._identity !== identity) {\n log('identity changed during auth header request');\n return undefined;\n }\n\n const restartRequired = new Trigger();\n const url = new URL(path, this._baseWsUrl);\n log('Opening websocket', { url: url.toString(), protocolHeader });\n const connection = new EdgeWsConnection(\n identity,\n { url, protocolHeader },\n {\n onConnected: () => {\n if (this._isActive(connection)) {\n this._ready.wake();\n this._notifyReconnected();\n } else {\n log.verbose('connected callback ignored, because connection is not active');\n }\n },\n onRestartRequired: () => {\n if (this._isActive(connection)) {\n this._closeCurrentConnection();\n this._persistentLifecycle.scheduleRestart();\n } else {\n log.verbose('restart requested by inactive connection');\n }\n restartRequired.wake();\n },\n onMessage: (message) => {\n if (this._isActive(connection)) {\n this._notifyMessageReceived(message);\n } else {\n log.verbose('ignored a message on inactive connection', {\n from: message.source,\n type: message.payload?.typeUrl,\n });\n }\n },\n },\n );\n this._currentConnection = connection;\n\n await connection.open();\n // Race with restartRequired so that restart is not blocked by _connect execution.\n // Wait on ready to attempt a reconnect if it times out.\n await Promise.race([this._ready.wait({ timeout: this._config.timeout ?? DEFAULT_TIMEOUT }), restartRequired]);\n\n return connection;\n }\n\n private async _disconnect(state: EdgeWsConnection) {\n await state.close();\n }\n\n private _closeCurrentConnection(error: Error = new EdgeConnectionClosedError()) {\n this._currentConnection = undefined;\n this._ready.throw(error);\n this._ready.reset();\n }\n\n private _notifyReconnected() {\n for (const listener of this._reconnectListeners) {\n try {\n listener();\n } catch (err) {\n log.error('ws reconnect listener failed', { err });\n }\n }\n }\n\n private _notifyMessageReceived(message: Message) {\n for (const listener of this._messageListeners) {\n try {\n listener(message);\n } catch (err) {\n log.error('ws incoming message processing failed', { err, payload: protocol.getPayloadType(message) });\n }\n }\n }\n\n /**\n * Send message.\n * NOTE: The message is guaranteed to be delivered but the service must respond with a message to confirm processing.\n */\n public async send(message: Message): Promise<void> {\n if (this._ready.state !== TriggerState.RESOLVED) {\n log('waiting for websocket to become ready');\n await this._ready.wait({ timeout: this._config.timeout ?? DEFAULT_TIMEOUT });\n }\n\n if (!this._currentConnection) {\n throw new EdgeConnectionClosedError();\n }\n\n if (\n message.source &&\n (message.source.peerKey !== this._identity.peerKey || message.source.identityKey !== this.identityKey)\n ) {\n throw new EdgeIdentityChangedError();\n }\n\n this._currentConnection.send(message);\n }\n\n private async _createAuthHeader(path: string): Promise<string | undefined> {\n const httpUrl = new URL(path, this._baseHttpUrl);\n httpUrl.protocol = getEdgeUrlWithProtocol(this._baseWsUrl.toString(), 'http');\n const response = await fetch(httpUrl, { method: 'GET' });\n if (response.status === 401) {\n return encodePresentationWsAuthHeader(await handleAuthChallenge(response, this._identity));\n } else {\n log.warn('no auth challenge from edge', { status: response.status, statusText: response.statusText });\n return undefined;\n }\n }\n\n private _isActive = (connection: EdgeWsConnection) => connection === this._currentConnection;\n}\n\nconst encodePresentationWsAuthHeader = (encodedPresentation: Uint8Array): string => {\n // = and / characters are not allowed in the WebSocket subprotocol header.\n const encodedToken = Buffer.from(encodedPresentation).toString('base64').replace(/=*$/, '').replaceAll('/', '|');\n return `base64url.bearer.authorization.dxos.org.${encodedToken}`;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { invariant } from '@dxos/invariant';\nimport { schema } from '@dxos/protocols/proto';\nimport { type Presentation } from '@dxos/protocols/proto/dxos/halo/credentials';\n\nexport interface EdgeIdentity {\n peerKey: string;\n identityKey: string;\n /**\n * Returns credential presentation issued by the identity key.\n * Presentation must have the provided challenge.\n * Presentation may include ServiceAccess credentials.\n */\n presentCredentials({ challenge }: { challenge: Uint8Array }): Promise<Presentation>;\n}\n\nexport const handleAuthChallenge = async (failedResponse: Response, identity: EdgeIdentity): Promise<Uint8Array> => {\n invariant(failedResponse.status === 401);\n\n const headerValue = failedResponse.headers.get('Www-Authenticate');\n invariant(headerValue?.startsWith('VerifiablePresentation challenge='));\n\n const challenge = headerValue?.slice('VerifiablePresentation challenge='.length);\n invariant(challenge);\n\n const presentation = await identity.presentCredentials({ challenge: Buffer.from(challenge, 'base64') });\n return schema.getCodecForType('dxos.halo.credentials.Presentation').encode(presentation);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport WebSocket from 'isomorphic-ws';\n\nimport { scheduleTask, scheduleTaskInterval } from '@dxos/async';\nimport { Context, Resource } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { log, logInfo } from '@dxos/log';\nimport { buf } from '@dxos/protocols/buf';\nimport { MessageSchema, type Message } from '@dxos/protocols/buf/dxos/edge/messenger_pb';\n\nimport { protocol } from './defs';\nimport { type EdgeIdentity } from './edge-identity';\nimport { toUint8Array } from './protocol';\n\nconst SIGNAL_KEEPALIVE_INTERVAL = 5_000;\n\nexport type EdgeWsConnectionCallbacks = {\n onConnected: () => void;\n onMessage: (message: Message) => void;\n onRestartRequired: () => void;\n};\n\nexport class EdgeWsConnection extends Resource {\n private _inactivityTimeoutCtx: Context | undefined;\n private _ws: WebSocket | undefined;\n\n constructor(\n private readonly _identity: EdgeIdentity,\n private readonly _connectionInfo: { url: URL; protocolHeader?: string },\n private readonly _callbacks: EdgeWsConnectionCallbacks,\n ) {\n super();\n }\n\n @logInfo\n public get info() {\n return {\n open: this.isOpen,\n identity: this._identity.identityKey,\n device: this._identity.peerKey,\n };\n }\n\n public send(message: Message) {\n invariant(this._ws);\n log('sending...', { peerKey: this._identity.peerKey, payload: protocol.getPayloadType(message) });\n this._ws.send(buf.toBinary(MessageSchema, message));\n }\n\n protected override async _open() {\n this._ws = new WebSocket(\n this._connectionInfo.url.toString(),\n this._connectionInfo.protocolHeader ? [this._connectionInfo.protocolHeader] : [],\n );\n\n this._ws.onopen = () => {\n if (this.isOpen) {\n log('connected');\n this._callbacks.onConnected();\n this._scheduleHeartbeats();\n } else {\n log.verbose('connected after becoming inactive', { currentIdentity: this._identity });\n }\n };\n this._ws.onclose = () => {\n if (this.isOpen) {\n log('disconnected while being open');\n this._callbacks.onRestartRequired();\n }\n };\n this._ws.onerror = (event) => {\n if (this.isOpen) {\n log.warn('edge connection socket error', { error: event.error, info: event.message });\n this._callbacks.onRestartRequired();\n } else {\n log.verbose('error ignored on closed connection', { error: event.error });\n }\n };\n /**\n * https://developer.mozilla.org/en-US/docs/Web/API/MessageEvent/data\n */\n this._ws.onmessage = async (event) => {\n if (!this.isOpen) {\n log.verbose('message ignored on closed connection', { event: event.type });\n return;\n }\n if (event.data === '__pong__') {\n this._rescheduleHeartbeatTimeout();\n return;\n }\n const data = await toUint8Array(event.data);\n if (this.isOpen) {\n const message = buf.fromBinary(MessageSchema, data);\n log('received', { from: message.source, payload: protocol.getPayloadType(message) });\n this._callbacks.onMessage(message);\n }\n };\n }\n\n protected override async _close() {\n void this._inactivityTimeoutCtx?.dispose().catch(() => {});\n\n try {\n this._ws?.close();\n this._ws = undefined;\n } catch (err) {\n if (err instanceof Error && err.message.includes('WebSocket is closed before the connection is established.')) {\n return;\n }\n log.warn('Error closing websocket', { err });\n }\n }\n\n private _scheduleHeartbeats() {\n invariant(this._ws);\n scheduleTaskInterval(\n this._ctx,\n async () => {\n // TODO(mykola): use RFC6455 ping/pong once implemented in the browser?\n // Cloudflare's worker responds to this `without interrupting hibernation`. https://developers.cloudflare.com/durable-objects/api/websockets/#setwebsocketautoresponse\n this._ws?.send('__ping__');\n },\n SIGNAL_KEEPALIVE_INTERVAL,\n );\n this._ws.send('__ping__');\n this._rescheduleHeartbeatTimeout();\n }\n\n private _rescheduleHeartbeatTimeout() {\n if (!this.isOpen) {\n return;\n }\n void this._inactivityTimeoutCtx?.dispose();\n this._inactivityTimeoutCtx = new Context();\n scheduleTask(\n this._inactivityTimeoutCtx,\n () => {\n if (this.isOpen) {\n this._callbacks.onRestartRequired();\n }\n },\n 2 * SIGNAL_KEEPALIVE_INTERVAL,\n );\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nexport class EdgeConnectionClosedError extends Error {\n constructor() {\n super('Edge connection closed.');\n }\n}\n\nexport class EdgeIdentityChangedError extends Error {\n constructor() {\n super('Edge identity changed.');\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { DeferredTask, sleep, synchronized } from '@dxos/async';\nimport { cancelWithContext, LifecycleState, Resource } from '@dxos/context';\nimport { warnAfterTimeout } from '@dxos/debug';\nimport { log } from '@dxos/log';\n\nconst INIT_RESTART_DELAY = 100;\nconst DEFAULT_MAX_RESTART_DELAY = 5000;\n\nexport type PersistentLifecycleParams<T> = {\n /**\n * Create connection.\n * If promise resolves successfully, connection is considered established.\n */\n start: () => Promise<T | undefined>;\n\n /**\n * Reset connection to initial state.\n */\n stop: (state: T) => Promise<void>;\n\n /**\n * Called after successful start.\n */\n onRestart?: () => Promise<void>;\n\n /**\n * Maximum delay between restartion attempts.\n * Default: 5000ms\n */\n maxRestartDelay?: number;\n};\n\n/**\n * Handles restarts (e.g. persists connection).\n * Restarts are scheduled with exponential backoff.\n */\nexport class PersistentLifecycle<T> extends Resource {\n private readonly _start: () => Promise<T | undefined>;\n private readonly _stop: (state: T) => Promise<void>;\n private readonly _onRestart?: () => Promise<void>;\n private readonly _maxRestartDelay: number;\n\n private _currentContext: T | undefined = undefined;\n private _restartTask?: DeferredTask = undefined;\n private _restartAfter = 0;\n\n constructor({ start, stop, onRestart, maxRestartDelay = DEFAULT_MAX_RESTART_DELAY }: PersistentLifecycleParams<T>) {\n super();\n this._start = start;\n this._stop = stop;\n this._onRestart = onRestart;\n this._maxRestartDelay = maxRestartDelay;\n }\n\n @synchronized\n protected override async _open() {\n this._restartTask = new DeferredTask(this._ctx, async () => {\n try {\n await this._restart();\n } catch (err) {\n log.warn('Restart failed', { err });\n this._restartTask?.schedule();\n }\n });\n this._currentContext = await this._start().catch((err) => {\n log.warn('Start failed', { err });\n this._restartTask?.schedule();\n return undefined;\n });\n }\n\n protected override async _close() {\n await this._restartTask?.join();\n await this._stopCurrentContext();\n this._restartTask = undefined;\n }\n\n private async _restart() {\n log(`restarting in ${this._restartAfter}ms`, { state: this._lifecycleState });\n await this._stopCurrentContext();\n if (this._lifecycleState !== LifecycleState.OPEN) {\n return;\n }\n await cancelWithContext(this._ctx!, sleep(this._restartAfter));\n this._restartAfter = Math.min(Math.max(this._restartAfter * 2, INIT_RESTART_DELAY), this._maxRestartDelay);\n\n // May fail if the connection is not established.\n await warnAfterTimeout(5_000, 'Connection establishment takes too long', async () => {\n this._currentContext = await this._start();\n });\n\n this._restartAfter = 0;\n await this._onRestart?.();\n }\n\n private async _stopCurrentContext() {\n if (this._currentContext) {\n try {\n await this._stop(this._currentContext);\n } catch (err) {\n log.catch(err);\n }\n this._currentContext = undefined;\n }\n }\n\n /**\n * Scheduling restart should be done from outside.\n */\n @synchronized\n scheduleRestart() {\n if (this._lifecycleState !== LifecycleState.OPEN) {\n return;\n }\n this._restartTask!.schedule();\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nexport const getEdgeUrlWithProtocol = (baseUrl: string, protocol: 'http' | 'ws') => {\n const isSecure = baseUrl.startsWith('https') || baseUrl.startsWith('wss');\n const url = new URL(baseUrl);\n url.protocol = protocol + (isSecure ? 's' : '');\n return url.toString();\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { createCredential, signPresentation } from '@dxos/credentials';\nimport { type Signer } from '@dxos/crypto';\nimport { invariant } from '@dxos/invariant';\nimport { Keyring } from '@dxos/keyring';\nimport { PublicKey } from '@dxos/keys';\nimport { type Chain, type Credential } from '@dxos/protocols/proto/dxos/halo/credentials';\n\nimport type { EdgeIdentity } from './edge-identity';\n\n/**\n * Edge identity backed by a device key without a credential chain.\n */\nexport const createDeviceEdgeIdentity = async (signer: Signer, key: PublicKey): Promise<EdgeIdentity> => {\n return {\n identityKey: key.toHex(),\n peerKey: key.toHex(),\n presentCredentials: async ({ challenge }) => {\n return signPresentation({\n presentation: {\n credentials: [\n // Verifier requires at least one credential in the presentation to establish the subject.\n await createCredential({\n assertion: {\n '@type': 'dxos.halo.credentials.Auth',\n },\n issuer: key,\n subject: key,\n signer,\n }),\n ],\n },\n signer,\n signerKey: key,\n nonce: challenge,\n });\n },\n };\n};\n\n/**\n * Edge identity backed by a chain of credentials.\n */\nexport const createChainEdgeIdentity = async (\n signer: Signer,\n identityKey: PublicKey,\n peerKey: PublicKey,\n chain: Chain | undefined,\n credentials: Credential[],\n): Promise<EdgeIdentity> => {\n const credentialsToSign =\n credentials.length > 0\n ? credentials\n : [\n await createCredential({\n assertion: {\n '@type': 'dxos.halo.credentials.Auth',\n },\n issuer: identityKey,\n subject: identityKey,\n signer,\n chain,\n signingKey: peerKey,\n }),\n ];\n\n return {\n identityKey: identityKey.toHex(),\n peerKey: peerKey.toHex(),\n presentCredentials: async ({ challenge }) => {\n // TODO: make chain required after device invitation flow update release\n invariant(chain);\n return signPresentation({\n presentation: {\n credentials: credentialsToSign,\n },\n signer,\n nonce: challenge,\n signerKey: peerKey,\n chain,\n });\n },\n };\n};\n\n/**\n * Edge identity backed by a random ephemeral key without HALO.\n */\nexport const createEphemeralEdgeIdentity = async (): Promise<EdgeIdentity> => {\n const keyring = new Keyring();\n const key = await keyring.createKey();\n return createDeviceEdgeIdentity(keyring, key);\n};\n\n/**\n * Creates a HALO chain of credentials to act as an edge identity.\n */\nexport const createTestHaloEdgeIdentity = async (\n signer: Signer,\n identityKey: PublicKey,\n deviceKey: PublicKey,\n): Promise<EdgeIdentity> => {\n const deviceAdmission = await createCredential({\n assertion: {\n '@type': 'dxos.halo.credentials.AuthorizedDevice',\n deviceKey,\n identityKey,\n },\n issuer: identityKey,\n subject: deviceKey,\n signer,\n });\n return createChainEdgeIdentity(signer, identityKey, deviceKey, { credential: deviceAdmission }, [\n await createCredential({\n assertion: {\n '@type': 'dxos.halo.credentials.Auth',\n },\n issuer: identityKey,\n subject: identityKey,\n signer,\n }),\n ]);\n};\n\nexport const createStubEdgeIdentity = (): EdgeIdentity => {\n const identityKey = PublicKey.random();\n const deviceKey = PublicKey.random();\n return {\n identityKey: identityKey.toHex(),\n peerKey: deviceKey.toHex(),\n presentCredentials: async () => {\n throw new Error('Stub identity does not support authentication.');\n },\n };\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { sleep } from '@dxos/async';\nimport { Context } from '@dxos/context';\nimport { type PublicKey, type SpaceId } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport {\n EdgeCallFailedError,\n type EdgeHttpResponse,\n type GetNotarizationResponseBody,\n type PostNotarizationRequestBody,\n type JoinSpaceRequest,\n type JoinSpaceResponseBody,\n EdgeAuthChallengeError,\n type CreateAgentResponseBody,\n type CreateAgentRequestBody,\n type GetAgentStatusResponseBody,\n type RecoverIdentityRequest,\n type RecoverIdentityResponseBody,\n type UploadFunctionRequest,\n type UploadFunctionResponseBody,\n} from '@dxos/protocols';\n\nimport { type EdgeIdentity, handleAuthChallenge } from './edge-identity';\nimport { getEdgeUrlWithProtocol } from './utils';\n\nconst DEFAULT_RETRY_TIMEOUT = 1500;\nconst DEFAULT_RETRY_JITTER = 500;\nconst DEFAULT_MAX_RETRIES_COUNT = 3;\n\nexport class EdgeHttpClient {\n private readonly _baseUrl: string;\n\n private _edgeIdentity: EdgeIdentity | undefined;\n /**\n * Auth header is cached until receiving the next 401 from EDGE, at which point it gets refreshed.\n */\n private _authHeader: string | undefined;\n\n constructor(baseUrl: string) {\n this._baseUrl = getEdgeUrlWithProtocol(baseUrl, 'http');\n log('created', { url: this._baseUrl });\n }\n\n setIdentity(identity: EdgeIdentity) {\n if (this._edgeIdentity?.identityKey !== identity.identityKey || this._edgeIdentity?.peerKey !== identity.peerKey) {\n this._edgeIdentity = identity;\n this._authHeader = undefined;\n }\n }\n\n public createAgent(body: CreateAgentRequestBody, args?: EdgeHttpGetArgs): Promise<CreateAgentResponseBody> {\n return this._call('/agents/create', { ...args, method: 'POST', body });\n }\n\n public getAgentStatus(\n request: { ownerIdentityKey: PublicKey },\n args?: EdgeHttpGetArgs,\n ): Promise<GetAgentStatusResponseBody> {\n return this._call(`/users/${request.ownerIdentityKey.toHex()}/agent/status`, { ...args, method: 'GET' });\n }\n\n public getCredentialsForNotarization(spaceId: SpaceId, args?: EdgeHttpGetArgs): Promise<GetNotarizationResponseBody> {\n return this._call(`/spaces/${spaceId}/notarization`, { ...args, method: 'GET' });\n }\n\n public async notarizeCredentials(\n spaceId: SpaceId,\n body: PostNotarizationRequestBody,\n args?: EdgeHttpGetArgs,\n ): Promise<void> {\n await this._call(`/spaces/${spaceId}/notarization`, { ...args, body, method: 'POST' });\n }\n\n public async joinSpaceByInvitation(\n spaceId: SpaceId,\n body: JoinSpaceRequest,\n args?: EdgeHttpGetArgs,\n ): Promise<JoinSpaceResponseBody> {\n return this._call(`/spaces/${spaceId}/join`, { ...args, body, method: 'POST' });\n }\n\n public async recoverIdentity(\n body: RecoverIdentityRequest,\n args?: EdgeHttpGetArgs,\n ): Promise<RecoverIdentityResponseBody> {\n return this._call('/identity/recover', { ...args, body, method: 'POST' });\n }\n\n public async uploadFunction(\n pathParts: { spaceId: SpaceId; functionId?: string },\n body: UploadFunctionRequest,\n args?: EdgeHttpGetArgs,\n ): Promise<UploadFunctionResponseBody> {\n const path = ['functions', pathParts.spaceId, ...(pathParts.functionId ? [pathParts.functionId] : [])].join('/');\n return this._call(path, { ...args, body, method: 'PUT' });\n }\n\n private async _call<T>(path: string, args: EdgeHttpCallArgs): Promise<T> {\n const requestContext = args.context ?? new Context();\n const shouldRetry = createRetryHandler(args);\n const url = `${this._baseUrl}${path.startsWith('/') ? path.slice(1) : path}`;\n\n log.info('call', { method: args.method, path, request: args.body });\n\n let handledAuth = false;\n let authHeader = this._authHeader;\n while (true) {\n let processingError: EdgeCallFailedError;\n let retryAfterHeaderValue: number = Number.NaN;\n try {\n const request = createRequest(args, authHeader);\n const response = await fetch(url, request);\n\n retryAfterHeaderValue = Number(response.headers.get('Retry-After'));\n\n if (response.ok) {\n const body = (await response.json()) as EdgeHttpResponse<T>;\n if (body.success) {\n return body.data;\n }\n\n log.info('unsuccessful edge response', { path, body });\n\n if (body.errorData?.type === 'auth_challenge' && typeof body.errorData?.challenge === 'string') {\n processingError = new EdgeAuthChallengeError(body.errorData.challenge, body.errorData);\n } else {\n processingError = EdgeCallFailedError.fromUnsuccessfulResponse(response, body);\n }\n } else if (response.status === 401 && !handledAuth) {\n authHeader = await this._handleUnauthorized(response);\n handledAuth = true;\n continue;\n } else {\n processingError = EdgeCallFailedError.fromHttpFailure(response);\n }\n } catch (error: any) {\n processingError = EdgeCallFailedError.fromProcessingFailureCause(error);\n }\n\n if (processingError.isRetryable && (await shouldRetry(requestContext, retryAfterHeaderValue))) {\n log.info('retrying edge request', { path, processingError });\n } else {\n throw processingError;\n }\n }\n }\n\n private async _handleUnauthorized(response: Response) {\n if (!this._edgeIdentity) {\n log.warn('edge unauthorized response received before identity was set');\n throw EdgeCallFailedError.fromHttpFailure(response);\n }\n const challenge = await handleAuthChallenge(response, this._edgeIdentity);\n this._authHeader = encodeAuthHeader(challenge);\n log('auth header updated');\n return this._authHeader;\n }\n}\n\nconst createRetryHandler = (args: EdgeHttpCallArgs) => {\n if (!args.retry || args.retry.count < 1) {\n return async () => false;\n }\n let retries = 0;\n const maxRetries = args.retry.count ?? DEFAULT_MAX_RETRIES_COUNT;\n const baseTimeout = args.retry.timeout ?? DEFAULT_RETRY_TIMEOUT;\n const jitter = args.retry.jitter ?? DEFAULT_RETRY_JITTER;\n return async (ctx: Context, retryAfter: number) => {\n if (++retries > maxRetries || ctx.disposed) {\n return false;\n }\n\n if (retryAfter) {\n await sleep(retryAfter);\n } else {\n const timeout = baseTimeout + Math.random() * jitter;\n await sleep(timeout);\n }\n\n return true;\n };\n};\n\nexport type RetryConfig = {\n /**\n * A number of call retries, not counting the initial request.\n */\n count: number;\n /**\n * Delay before retries in ms.\n */\n timeout?: number;\n /**\n * A random amount of time before retrying to help prevent large bursts of requests.\n */\n jitter?: number;\n};\n\nexport type EdgeHttpGetArgs = { context?: Context; retry?: RetryConfig };\n\nexport type EdgeHttpPostArgs = { context?: Context; body?: any; retry?: RetryConfig };\n\ntype EdgeHttpCallArgs = {\n method: string;\n body?: any;\n context?: Context;\n retry?: RetryConfig;\n};\n\nconst createRequest = (args: EdgeHttpCallArgs, authHeader: string | undefined): RequestInit => {\n return {\n method: args.method,\n body: args.body && JSON.stringify(args.body),\n headers: authHeader ? { Authorization: authHeader } : undefined,\n };\n};\n\nconst encodeAuthHeader = (challenge: Uint8Array) => {\n const encodedChallenge = Buffer.from(challenge).toString('base64');\n return `VerifiablePresentation pb;base64,${encodedChallenge}`;\n};\n"],
5
- "mappings": "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",
6
- "names": ["Trigger", "scheduleMicroTask", "TriggerState", "Resource", "log", "logInfo", "invariant", "schema", "handleAuthChallenge", "failedResponse", "identity", "status", "headerValue", "headers", "get", "startsWith", "challenge", "slice", "length", "presentation", "presentCredentials", "Buffer", "from", "getCodecForType", "encode", "WebSocket", "scheduleTask", "scheduleTaskInterval", "Context", "Resource", "invariant", "log", "logInfo", "buf", "MessageSchema", "SIGNAL_KEEPALIVE_INTERVAL", "EdgeWsConnection", "Resource", "constructor", "_identity", "_connectionInfo", "_callbacks", "info", "open", "isOpen", "identity", "identityKey", "device", "peerKey", "send", "message", "invariant", "_ws", "log", "payload", "protocol", "getPayloadType", "buf", "toBinary", "MessageSchema", "_open", "WebSocket", "url", "toString", "protocolHeader", "onopen", "onConnected", "_scheduleHeartbeats", "verbose", "currentIdentity", "onclose", "onRestartRequired", "onerror", "event", "warn", "error", "onmessage", "type", "data", "_rescheduleHeartbeatTimeout", "toUint8Array", "fromBinary", "from", "source", "onMessage", "_close", "_inactivityTimeoutCtx", "dispose", "catch", "close", "undefined", "err", "Error", "includes", "scheduleTaskInterval", "_ctx", "Context", "scheduleTask", "logInfo", "EdgeConnectionClosedError", "Error", "constructor", "EdgeIdentityChangedError", "DeferredTask", "sleep", "synchronized", "cancelWithContext", "LifecycleState", "Resource", "warnAfterTimeout", "log", "INIT_RESTART_DELAY", "DEFAULT_MAX_RESTART_DELAY", "PersistentLifecycle", "constructor", "start", "stop", "onRestart", "maxRestartDelay", "_currentContext", "undefined", "_restartTask", "_restartAfter", "_start", "_stop", "_onRestart", "_maxRestartDelay", "_open", "_ctx", "_restart", "err", "warn", "schedule", "catch", "_close", "join", "_stopCurrentContext", "state", "_lifecycleState", "OPEN", "Math", "min", "max", "scheduleRestart", "getEdgeUrlWithProtocol", "baseUrl", "protocol", "isSecure", "startsWith", "url", "URL", "toString", "DEFAULT_TIMEOUT", "EdgeClient", "Resource", "constructor", "_identity", "_config", "_persistentLifecycle", "PersistentLifecycle", "start", "_connect", "stop", "state", "_disconnect", "_messageListeners", "Set", "_reconnectListeners", "_currentConnection", "undefined", "_ready", "Trigger", "_isActive", "connection", "_baseWsUrl", "getEdgeUrlWithProtocol", "socketEndpoint", "_baseHttpUrl", "info", "open", "isOpen", "identity", "identityKey", "device", "peerKey", "isConnected", "Boolean", "TriggerState", "RESOLVED", "setIdentity", "log", "oldIdentity", "_closeCurrentConnection", "EdgeIdentityChangedError", "scheduleRestart", "onMessage", "listener", "add", "delete", "onReconnected", "scheduleMicroTask", "_ctx", "has", "error", "catch", "_open", "err", "warn", "_close", "close", "disposed", "path", "protocolHeader", "disableAuth", "_createAuthHeader", "restartRequired", "url", "URL", "toString", "EdgeWsConnection", "onConnected", "wake", "_notifyReconnected", "verbose", "onRestartRequired", "message", "_notifyMessageReceived", "from", "source", "type", "payload", "typeUrl", "Promise", "race", "wait", "timeout", "EdgeConnectionClosedError", "throw", "reset", "protocol", "getPayloadType", "send", "httpUrl", "response", "fetch", "method", "status", "encodePresentationWsAuthHeader", "handleAuthChallenge", "statusText", "logInfo", "encodedPresentation", "encodedToken", "Buffer", "replace", "replaceAll", "createCredential", "signPresentation", "invariant", "Keyring", "PublicKey", "createDeviceEdgeIdentity", "signer", "key", "identityKey", "toHex", "peerKey", "presentCredentials", "challenge", "presentation", "credentials", "assertion", "issuer", "subject", "signerKey", "nonce", "createChainEdgeIdentity", "chain", "credentialsToSign", "length", "signingKey", "createEphemeralEdgeIdentity", "keyring", "createKey", "createTestHaloEdgeIdentity", "deviceKey", "deviceAdmission", "credential", "createStubEdgeIdentity", "random", "Error", "sleep", "Context", "log", "EdgeCallFailedError", "EdgeAuthChallengeError", "DEFAULT_RETRY_TIMEOUT", "DEFAULT_RETRY_JITTER", "DEFAULT_MAX_RETRIES_COUNT", "EdgeHttpClient", "constructor", "baseUrl", "_baseUrl", "getEdgeUrlWithProtocol", "log", "url", "setIdentity", "identity", "_edgeIdentity", "identityKey", "peerKey", "_authHeader", "undefined", "createAgent", "body", "args", "_call", "method", "getAgentStatus", "request", "ownerIdentityKey", "toHex", "getCredentialsForNotarization", "spaceId", "notarizeCredentials", "joinSpaceByInvitation", "recoverIdentity", "uploadFunction", "pathParts", "path", "functionId", "join", "requestContext", "context", "Context", "shouldRetry", "createRetryHandler", "startsWith", "slice", "info", "handledAuth", "authHeader", "processingError", "retryAfterHeaderValue", "Number", "NaN", "createRequest", "response", "fetch", "headers", "get", "ok", "json", "success", "data", "errorData", "type", "challenge", "EdgeAuthChallengeError", "EdgeCallFailedError", "fromUnsuccessfulResponse", "status", "_handleUnauthorized", "fromHttpFailure", "error", "fromProcessingFailureCause", "isRetryable", "warn", "handleAuthChallenge", "encodeAuthHeader", "retry", "count", "retries", "maxRetries", "baseTimeout", "timeout", "jitter", "ctx", "retryAfter", "disposed", "sleep", "Math", "random", "JSON", "stringify", "Authorization", "encodedChallenge", "Buffer", "from", "toString"]
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nexport * from '@dxos/protocols/buf/dxos/edge/messenger_pb';\n\nexport * from './edge-client';\nexport * from './defs';\nexport * from './protocol';\nexport * from './errors';\nexport * from './auth';\nexport * from './edge-http-client';\nexport * from './edge-identity';\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { Trigger, scheduleMicroTask, TriggerState } from '@dxos/async';\nimport { Resource, type Lifecycle } from '@dxos/context';\nimport { log, logInfo } from '@dxos/log';\nimport { type Message } from '@dxos/protocols/buf/dxos/edge/messenger_pb';\n\nimport { protocol } from './defs';\nimport { type EdgeIdentity, handleAuthChallenge } from './edge-identity';\nimport { EdgeWsConnection } from './edge-ws-connection';\nimport { EdgeConnectionClosedError, EdgeIdentityChangedError } from './errors';\nimport { PersistentLifecycle } from './persistent-lifecycle';\nimport { type Protocol } from './protocol';\nimport { getEdgeUrlWithProtocol } from './utils';\n\nconst DEFAULT_TIMEOUT = 10_000;\n\nexport type MessageListener = (message: Message) => void;\nexport type ReconnectListener = () => void;\n\nexport interface EdgeConnection extends Required<Lifecycle> {\n get info(): any;\n get identityKey(): string;\n get peerKey(): string;\n get isOpen(): boolean;\n get isConnected(): boolean;\n setIdentity(identity: EdgeIdentity): void;\n onMessage(listener: MessageListener): () => void;\n onReconnected(listener: ReconnectListener): () => void;\n send(message: Message): Promise<void>;\n}\n\nexport type MessengerConfig = {\n socketEndpoint: string;\n timeout?: number;\n protocol?: Protocol;\n disableAuth?: boolean;\n};\n\n/**\n * Messenger client for EDGE:\n * - While open, uses PersistentLifecycle to keep an open EdgeWsConnection, reconnecting on failures.\n * - Manages identity and re-create EdgeWsConnection when identity changes.\n * - Dispatches connection state and message notifications.\n */\nexport class EdgeClient extends Resource implements EdgeConnection {\n private readonly _persistentLifecycle = new PersistentLifecycle<EdgeWsConnection>({\n start: async () => this._connect(),\n stop: async (state: EdgeWsConnection) => this._disconnect(state),\n });\n\n private readonly _messageListeners = new Set<MessageListener>();\n private readonly _reconnectListeners = new Set<ReconnectListener>();\n\n private readonly _baseWsUrl: string;\n private readonly _baseHttpUrl: string;\n\n private _currentConnection?: EdgeWsConnection = undefined;\n private _ready = new Trigger();\n\n constructor(\n private _identity: EdgeIdentity,\n private readonly _config: MessengerConfig,\n ) {\n super();\n this._baseWsUrl = getEdgeUrlWithProtocol(_config.socketEndpoint, 'ws');\n this._baseHttpUrl = getEdgeUrlWithProtocol(_config.socketEndpoint, 'http');\n }\n\n @logInfo\n public get info() {\n return {\n open: this.isOpen,\n identity: this._identity.identityKey,\n device: this._identity.peerKey,\n };\n }\n\n get isConnected() {\n return Boolean(this._currentConnection) && this._ready.state === TriggerState.RESOLVED;\n }\n\n get identityKey() {\n return this._identity.identityKey;\n }\n\n get peerKey() {\n return this._identity.peerKey;\n }\n\n setIdentity(identity: EdgeIdentity) {\n if (identity.identityKey !== this._identity.identityKey || identity.peerKey !== this._identity.peerKey) {\n log('Edge identity changed', { identity, oldIdentity: this._identity });\n this._identity = identity;\n this._closeCurrentConnection(new EdgeIdentityChangedError());\n this._persistentLifecycle.scheduleRestart();\n }\n }\n\n public onMessage(listener: MessageListener): () => void {\n this._messageListeners.add(listener);\n return () => this._messageListeners.delete(listener);\n }\n\n public onReconnected(listener: () => void): () => void {\n this._reconnectListeners.add(listener);\n if (this._ready.state === TriggerState.RESOLVED) {\n // Microtask so that listener is always called asynchronously, no matter the state of the ready trigger\n // at the moment of registration.\n scheduleMicroTask(this._ctx, () => {\n if (this._reconnectListeners.has(listener)) {\n try {\n listener();\n } catch (error) {\n log.catch(error);\n }\n }\n });\n }\n return () => this._reconnectListeners.delete(listener);\n }\n\n /**\n * Open connection to messaging service.\n */\n protected override async _open() {\n log('opening...', { info: this.info });\n this._persistentLifecycle.open().catch((err) => {\n log.warn('Error while opening connection', { err });\n });\n }\n\n /**\n * Close connection and free resources.\n */\n protected override async _close() {\n log('closing...', { peerKey: this._identity.peerKey });\n this._closeCurrentConnection();\n await this._persistentLifecycle.close();\n }\n\n private async _connect(): Promise<EdgeWsConnection | undefined> {\n if (this._ctx.disposed) {\n return undefined;\n }\n\n const identity = this._identity;\n const path = `/ws/${identity.identityKey}/${identity.peerKey}`;\n const protocolHeader = this._config.disableAuth ? undefined : await this._createAuthHeader(path);\n if (this._identity !== identity) {\n log('identity changed during auth header request');\n return undefined;\n }\n\n const restartRequired = new Trigger();\n const url = new URL(path, this._baseWsUrl);\n log('Opening websocket', { url: url.toString(), protocolHeader });\n const connection = new EdgeWsConnection(\n identity,\n { url, protocolHeader },\n {\n onConnected: () => {\n if (this._isActive(connection)) {\n this._ready.wake();\n this._notifyReconnected();\n } else {\n log.verbose('connected callback ignored, because connection is not active');\n }\n },\n onRestartRequired: () => {\n if (this._isActive(connection)) {\n this._closeCurrentConnection();\n this._persistentLifecycle.scheduleRestart();\n } else {\n log.verbose('restart requested by inactive connection');\n }\n restartRequired.wake();\n },\n onMessage: (message) => {\n if (this._isActive(connection)) {\n this._notifyMessageReceived(message);\n } else {\n log.verbose('ignored a message on inactive connection', {\n from: message.source,\n type: message.payload?.typeUrl,\n });\n }\n },\n },\n );\n this._currentConnection = connection;\n\n await connection.open();\n // Race with restartRequired so that restart is not blocked by _connect execution.\n // Wait on ready to attempt a reconnect if it times out.\n await Promise.race([this._ready.wait({ timeout: this._config.timeout ?? DEFAULT_TIMEOUT }), restartRequired]);\n\n return connection;\n }\n\n private async _disconnect(state: EdgeWsConnection) {\n await state.close();\n }\n\n private _closeCurrentConnection(error: Error = new EdgeConnectionClosedError()) {\n this._currentConnection = undefined;\n this._ready.throw(error);\n this._ready.reset();\n }\n\n private _notifyReconnected() {\n for (const listener of this._reconnectListeners) {\n try {\n listener();\n } catch (err) {\n log.error('ws reconnect listener failed', { err });\n }\n }\n }\n\n private _notifyMessageReceived(message: Message) {\n for (const listener of this._messageListeners) {\n try {\n listener(message);\n } catch (err) {\n log.error('ws incoming message processing failed', { err, payload: protocol.getPayloadType(message) });\n }\n }\n }\n\n /**\n * Send message.\n * NOTE: The message is guaranteed to be delivered but the service must respond with a message to confirm processing.\n */\n public async send(message: Message): Promise<void> {\n if (this._ready.state !== TriggerState.RESOLVED) {\n log('waiting for websocket to become ready');\n await this._ready.wait({ timeout: this._config.timeout ?? DEFAULT_TIMEOUT });\n }\n\n if (!this._currentConnection) {\n throw new EdgeConnectionClosedError();\n }\n\n if (\n message.source &&\n (message.source.peerKey !== this._identity.peerKey || message.source.identityKey !== this.identityKey)\n ) {\n throw new EdgeIdentityChangedError();\n }\n\n this._currentConnection.send(message);\n }\n\n private async _createAuthHeader(path: string): Promise<string | undefined> {\n const httpUrl = new URL(path, this._baseHttpUrl);\n httpUrl.protocol = getEdgeUrlWithProtocol(this._baseWsUrl.toString(), 'http');\n const response = await fetch(httpUrl, { method: 'GET' });\n if (response.status === 401) {\n return encodePresentationWsAuthHeader(await handleAuthChallenge(response, this._identity));\n } else {\n log.warn('no auth challenge from edge', { status: response.status, statusText: response.statusText });\n return undefined;\n }\n }\n\n private _isActive = (connection: EdgeWsConnection) => connection === this._currentConnection;\n}\n\nconst encodePresentationWsAuthHeader = (encodedPresentation: Uint8Array): string => {\n // = and / characters are not allowed in the WebSocket subprotocol header.\n const encodedToken = Buffer.from(encodedPresentation).toString('base64').replace(/=*$/, '').replaceAll('/', '|');\n return `base64url.bearer.authorization.dxos.org.${encodedToken}`;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { invariant } from '@dxos/invariant';\nimport { schema } from '@dxos/protocols/proto';\nimport { type Presentation } from '@dxos/protocols/proto/dxos/halo/credentials';\n\nexport interface EdgeIdentity {\n peerKey: string;\n identityKey: string;\n /**\n * Returns credential presentation issued by the identity key.\n * Presentation must have the provided challenge.\n * Presentation may include ServiceAccess credentials.\n */\n presentCredentials({ challenge }: { challenge: Uint8Array }): Promise<Presentation>;\n}\n\nexport const handleAuthChallenge = async (failedResponse: Response, identity: EdgeIdentity): Promise<Uint8Array> => {\n invariant(failedResponse.status === 401);\n\n const headerValue = failedResponse.headers.get('Www-Authenticate');\n invariant(headerValue?.startsWith('VerifiablePresentation challenge='));\n\n const challenge = headerValue?.slice('VerifiablePresentation challenge='.length);\n invariant(challenge);\n\n const presentation = await identity.presentCredentials({ challenge: Buffer.from(challenge, 'base64') });\n return schema.getCodecForType('dxos.halo.credentials.Presentation').encode(presentation);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport WebSocket from 'isomorphic-ws';\n\nimport { scheduleTask, scheduleTaskInterval } from '@dxos/async';\nimport { Context, Resource } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { log, logInfo } from '@dxos/log';\nimport { buf } from '@dxos/protocols/buf';\nimport { MessageSchema, type Message } from '@dxos/protocols/buf/dxos/edge/messenger_pb';\n\nimport { protocol } from './defs';\nimport { type EdgeIdentity } from './edge-identity';\nimport { toUint8Array } from './protocol';\n\nconst SIGNAL_KEEPALIVE_INTERVAL = 5_000;\n\n/**\n * 1MB websocket message limit: https://developers.cloudflare.com/durable-objects/platform/limits/\n */\nconst CLOUDFLARE_MESSAGE_LENGTH_LIMIT = 1024 * 1024;\n\nexport type EdgeWsConnectionCallbacks = {\n onConnected: () => void;\n onMessage: (message: Message) => void;\n onRestartRequired: () => void;\n};\n\nexport class EdgeWsConnection extends Resource {\n private _inactivityTimeoutCtx: Context | undefined;\n private _ws: WebSocket | undefined;\n\n constructor(\n private readonly _identity: EdgeIdentity,\n private readonly _connectionInfo: { url: URL; protocolHeader?: string },\n private readonly _callbacks: EdgeWsConnectionCallbacks,\n ) {\n super();\n }\n\n @logInfo\n public get info() {\n return {\n open: this.isOpen,\n identity: this._identity.identityKey,\n device: this._identity.peerKey,\n };\n }\n\n public send(message: Message) {\n invariant(this._ws);\n log('sending...', { peerKey: this._identity.peerKey, payload: protocol.getPayloadType(message) });\n const encoded = buf.toBinary(MessageSchema, message);\n if (encoded.byteLength >= CLOUDFLARE_MESSAGE_LENGTH_LIMIT) {\n log.error('edge message dropped due to websocket message limit', {\n byteLength: encoded.byteLength,\n serviceId: message.serviceId,\n payload: protocol.getPayloadType(message),\n });\n return;\n }\n this._ws.send(encoded);\n }\n\n protected override async _open() {\n this._ws = new WebSocket(\n this._connectionInfo.url.toString(),\n this._connectionInfo.protocolHeader ? [this._connectionInfo.protocolHeader] : [],\n );\n\n this._ws.onopen = () => {\n if (this.isOpen) {\n log('connected');\n this._callbacks.onConnected();\n this._scheduleHeartbeats();\n } else {\n log.verbose('connected after becoming inactive', { currentIdentity: this._identity });\n }\n };\n this._ws.onclose = () => {\n if (this.isOpen) {\n log('disconnected while being open');\n this._callbacks.onRestartRequired();\n }\n };\n this._ws.onerror = (event) => {\n if (this.isOpen) {\n log.warn('edge connection socket error', { error: event.error, info: event.message });\n this._callbacks.onRestartRequired();\n } else {\n log.verbose('error ignored on closed connection', { error: event.error });\n }\n };\n /**\n * https://developer.mozilla.org/en-US/docs/Web/API/MessageEvent/data\n */\n this._ws.onmessage = async (event) => {\n if (!this.isOpen) {\n log.verbose('message ignored on closed connection', { event: event.type });\n return;\n }\n if (event.data === '__pong__') {\n this._rescheduleHeartbeatTimeout();\n return;\n }\n const data = await toUint8Array(event.data);\n if (this.isOpen) {\n const message = buf.fromBinary(MessageSchema, data);\n log('received', { from: message.source, payload: protocol.getPayloadType(message) });\n this._callbacks.onMessage(message);\n }\n };\n }\n\n protected override async _close() {\n void this._inactivityTimeoutCtx?.dispose().catch(() => {});\n\n try {\n this._ws?.close();\n this._ws = undefined;\n } catch (err) {\n if (err instanceof Error && err.message.includes('WebSocket is closed before the connection is established.')) {\n return;\n }\n log.warn('Error closing websocket', { err });\n }\n }\n\n private _scheduleHeartbeats() {\n invariant(this._ws);\n scheduleTaskInterval(\n this._ctx,\n async () => {\n // TODO(mykola): use RFC6455 ping/pong once implemented in the browser?\n // Cloudflare's worker responds to this `without interrupting hibernation`. https://developers.cloudflare.com/durable-objects/api/websockets/#setwebsocketautoresponse\n this._ws?.send('__ping__');\n },\n SIGNAL_KEEPALIVE_INTERVAL,\n );\n this._ws.send('__ping__');\n this._rescheduleHeartbeatTimeout();\n }\n\n private _rescheduleHeartbeatTimeout() {\n if (!this.isOpen) {\n return;\n }\n void this._inactivityTimeoutCtx?.dispose();\n this._inactivityTimeoutCtx = new Context();\n scheduleTask(\n this._inactivityTimeoutCtx,\n () => {\n if (this.isOpen) {\n this._callbacks.onRestartRequired();\n }\n },\n 2 * SIGNAL_KEEPALIVE_INTERVAL,\n );\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nexport class EdgeConnectionClosedError extends Error {\n constructor() {\n super('Edge connection closed.');\n }\n}\n\nexport class EdgeIdentityChangedError extends Error {\n constructor() {\n super('Edge identity changed.');\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { DeferredTask, sleep, synchronized } from '@dxos/async';\nimport { cancelWithContext, LifecycleState, Resource } from '@dxos/context';\nimport { warnAfterTimeout } from '@dxos/debug';\nimport { log } from '@dxos/log';\n\nconst INIT_RESTART_DELAY = 100;\nconst DEFAULT_MAX_RESTART_DELAY = 5000;\n\nexport type PersistentLifecycleParams<T> = {\n /**\n * Create connection.\n * If promise resolves successfully, connection is considered established.\n */\n start: () => Promise<T | undefined>;\n\n /**\n * Reset connection to initial state.\n */\n stop: (state: T) => Promise<void>;\n\n /**\n * Called after successful start.\n */\n onRestart?: () => Promise<void>;\n\n /**\n * Maximum delay between restartion attempts.\n * Default: 5000ms\n */\n maxRestartDelay?: number;\n};\n\n/**\n * Handles restarts (e.g. persists connection).\n * Restarts are scheduled with exponential backoff.\n */\nexport class PersistentLifecycle<T> extends Resource {\n private readonly _start: () => Promise<T | undefined>;\n private readonly _stop: (state: T) => Promise<void>;\n private readonly _onRestart?: () => Promise<void>;\n private readonly _maxRestartDelay: number;\n\n private _currentContext: T | undefined = undefined;\n private _restartTask?: DeferredTask = undefined;\n private _restartAfter = 0;\n\n constructor({ start, stop, onRestart, maxRestartDelay = DEFAULT_MAX_RESTART_DELAY }: PersistentLifecycleParams<T>) {\n super();\n this._start = start;\n this._stop = stop;\n this._onRestart = onRestart;\n this._maxRestartDelay = maxRestartDelay;\n }\n\n @synchronized\n protected override async _open() {\n this._restartTask = new DeferredTask(this._ctx, async () => {\n try {\n await this._restart();\n } catch (err) {\n log.warn('Restart failed', { err });\n this._restartTask?.schedule();\n }\n });\n this._currentContext = await this._start().catch((err) => {\n log.warn('Start failed', { err });\n this._restartTask?.schedule();\n return undefined;\n });\n }\n\n protected override async _close() {\n await this._restartTask?.join();\n await this._stopCurrentContext();\n this._restartTask = undefined;\n }\n\n private async _restart() {\n log(`restarting in ${this._restartAfter}ms`, { state: this._lifecycleState });\n await this._stopCurrentContext();\n if (this._lifecycleState !== LifecycleState.OPEN) {\n return;\n }\n await cancelWithContext(this._ctx!, sleep(this._restartAfter));\n this._restartAfter = Math.min(Math.max(this._restartAfter * 2, INIT_RESTART_DELAY), this._maxRestartDelay);\n\n // May fail if the connection is not established.\n await warnAfterTimeout(5_000, 'Connection establishment takes too long', async () => {\n this._currentContext = await this._start();\n });\n\n this._restartAfter = 0;\n await this._onRestart?.();\n }\n\n private async _stopCurrentContext() {\n if (this._currentContext) {\n try {\n await this._stop(this._currentContext);\n } catch (err) {\n log.catch(err);\n }\n this._currentContext = undefined;\n }\n }\n\n /**\n * Scheduling restart should be done from outside.\n */\n @synchronized\n scheduleRestart() {\n if (this._lifecycleState !== LifecycleState.OPEN) {\n return;\n }\n this._restartTask!.schedule();\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nexport const getEdgeUrlWithProtocol = (baseUrl: string, protocol: 'http' | 'ws') => {\n const isSecure = baseUrl.startsWith('https') || baseUrl.startsWith('wss');\n const url = new URL(baseUrl);\n url.protocol = protocol + (isSecure ? 's' : '');\n return url.toString();\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { createCredential, signPresentation } from '@dxos/credentials';\nimport { type Signer } from '@dxos/crypto';\nimport { invariant } from '@dxos/invariant';\nimport { Keyring } from '@dxos/keyring';\nimport { PublicKey } from '@dxos/keys';\nimport { type Chain, type Credential } from '@dxos/protocols/proto/dxos/halo/credentials';\n\nimport type { EdgeIdentity } from './edge-identity';\n\n/**\n * Edge identity backed by a device key without a credential chain.\n */\nexport const createDeviceEdgeIdentity = async (signer: Signer, key: PublicKey): Promise<EdgeIdentity> => {\n return {\n identityKey: key.toHex(),\n peerKey: key.toHex(),\n presentCredentials: async ({ challenge }) => {\n return signPresentation({\n presentation: {\n credentials: [\n // Verifier requires at least one credential in the presentation to establish the subject.\n await createCredential({\n assertion: {\n '@type': 'dxos.halo.credentials.Auth',\n },\n issuer: key,\n subject: key,\n signer,\n }),\n ],\n },\n signer,\n signerKey: key,\n nonce: challenge,\n });\n },\n };\n};\n\n/**\n * Edge identity backed by a chain of credentials.\n */\nexport const createChainEdgeIdentity = async (\n signer: Signer,\n identityKey: PublicKey,\n peerKey: PublicKey,\n chain: Chain | undefined,\n credentials: Credential[],\n): Promise<EdgeIdentity> => {\n const credentialsToSign =\n credentials.length > 0\n ? credentials\n : [\n await createCredential({\n assertion: {\n '@type': 'dxos.halo.credentials.Auth',\n },\n issuer: identityKey,\n subject: identityKey,\n signer,\n chain,\n signingKey: peerKey,\n }),\n ];\n\n return {\n identityKey: identityKey.toHex(),\n peerKey: peerKey.toHex(),\n presentCredentials: async ({ challenge }) => {\n // TODO: make chain required after device invitation flow update release\n invariant(chain);\n return signPresentation({\n presentation: {\n credentials: credentialsToSign,\n },\n signer,\n nonce: challenge,\n signerKey: peerKey,\n chain,\n });\n },\n };\n};\n\n/**\n * Edge identity backed by a random ephemeral key without HALO.\n */\nexport const createEphemeralEdgeIdentity = async (): Promise<EdgeIdentity> => {\n const keyring = new Keyring();\n const key = await keyring.createKey();\n return createDeviceEdgeIdentity(keyring, key);\n};\n\n/**\n * Creates a HALO chain of credentials to act as an edge identity.\n */\nexport const createTestHaloEdgeIdentity = async (\n signer: Signer,\n identityKey: PublicKey,\n deviceKey: PublicKey,\n): Promise<EdgeIdentity> => {\n const deviceAdmission = await createCredential({\n assertion: {\n '@type': 'dxos.halo.credentials.AuthorizedDevice',\n deviceKey,\n identityKey,\n },\n issuer: identityKey,\n subject: deviceKey,\n signer,\n });\n return createChainEdgeIdentity(signer, identityKey, deviceKey, { credential: deviceAdmission }, [\n await createCredential({\n assertion: {\n '@type': 'dxos.halo.credentials.Auth',\n },\n issuer: identityKey,\n subject: identityKey,\n signer,\n }),\n ]);\n};\n\nexport const createStubEdgeIdentity = (): EdgeIdentity => {\n const identityKey = PublicKey.random();\n const deviceKey = PublicKey.random();\n return {\n identityKey: identityKey.toHex(),\n peerKey: deviceKey.toHex(),\n presentCredentials: async () => {\n throw new Error('Stub identity does not support authentication.');\n },\n };\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { sleep } from '@dxos/async';\nimport { Context } from '@dxos/context';\nimport { type PublicKey, type SpaceId } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport {\n EdgeCallFailedError,\n type EdgeHttpResponse,\n type GetNotarizationResponseBody,\n type PostNotarizationRequestBody,\n type JoinSpaceRequest,\n type JoinSpaceResponseBody,\n EdgeAuthChallengeError,\n type CreateAgentResponseBody,\n type CreateAgentRequestBody,\n type GetAgentStatusResponseBody,\n type RecoverIdentityRequest,\n type RecoverIdentityResponseBody,\n type UploadFunctionRequest,\n type UploadFunctionResponseBody,\n} from '@dxos/protocols';\n\nimport { type EdgeIdentity, handleAuthChallenge } from './edge-identity';\nimport { getEdgeUrlWithProtocol } from './utils';\n\nconst DEFAULT_RETRY_TIMEOUT = 1500;\nconst DEFAULT_RETRY_JITTER = 500;\nconst DEFAULT_MAX_RETRIES_COUNT = 3;\n\nexport class EdgeHttpClient {\n private readonly _baseUrl: string;\n\n private _edgeIdentity: EdgeIdentity | undefined;\n /**\n * Auth header is cached until receiving the next 401 from EDGE, at which point it gets refreshed.\n */\n private _authHeader: string | undefined;\n\n constructor(baseUrl: string) {\n this._baseUrl = getEdgeUrlWithProtocol(baseUrl, 'http');\n log('created', { url: this._baseUrl });\n }\n\n setIdentity(identity: EdgeIdentity) {\n if (this._edgeIdentity?.identityKey !== identity.identityKey || this._edgeIdentity?.peerKey !== identity.peerKey) {\n this._edgeIdentity = identity;\n this._authHeader = undefined;\n }\n }\n\n public createAgent(body: CreateAgentRequestBody, args?: EdgeHttpGetArgs): Promise<CreateAgentResponseBody> {\n return this._call('/agents/create', { ...args, method: 'POST', body });\n }\n\n public getAgentStatus(\n request: { ownerIdentityKey: PublicKey },\n args?: EdgeHttpGetArgs,\n ): Promise<GetAgentStatusResponseBody> {\n return this._call(`/users/${request.ownerIdentityKey.toHex()}/agent/status`, { ...args, method: 'GET' });\n }\n\n public getCredentialsForNotarization(spaceId: SpaceId, args?: EdgeHttpGetArgs): Promise<GetNotarizationResponseBody> {\n return this._call(`/spaces/${spaceId}/notarization`, { ...args, method: 'GET' });\n }\n\n public async notarizeCredentials(\n spaceId: SpaceId,\n body: PostNotarizationRequestBody,\n args?: EdgeHttpGetArgs,\n ): Promise<void> {\n await this._call(`/spaces/${spaceId}/notarization`, { ...args, body, method: 'POST' });\n }\n\n public async joinSpaceByInvitation(\n spaceId: SpaceId,\n body: JoinSpaceRequest,\n args?: EdgeHttpGetArgs,\n ): Promise<JoinSpaceResponseBody> {\n return this._call(`/spaces/${spaceId}/join`, { ...args, body, method: 'POST' });\n }\n\n public async recoverIdentity(\n body: RecoverIdentityRequest,\n args?: EdgeHttpGetArgs,\n ): Promise<RecoverIdentityResponseBody> {\n return this._call('/identity/recover', { ...args, body, method: 'POST' });\n }\n\n public async uploadFunction(\n pathParts: { spaceId: SpaceId; functionId?: string },\n body: UploadFunctionRequest,\n args?: EdgeHttpGetArgs,\n ): Promise<UploadFunctionResponseBody> {\n const path = ['functions', pathParts.spaceId, ...(pathParts.functionId ? [pathParts.functionId] : [])].join('/');\n return this._call(path, { ...args, body, method: 'PUT' });\n }\n\n private async _call<T>(path: string, args: EdgeHttpCallArgs): Promise<T> {\n const requestContext = args.context ?? new Context();\n const shouldRetry = createRetryHandler(args);\n const url = `${this._baseUrl}${path.startsWith('/') ? path.slice(1) : path}`;\n\n log.info('call', { method: args.method, path, request: args.body });\n\n let handledAuth = false;\n let authHeader = this._authHeader;\n while (true) {\n let processingError: EdgeCallFailedError;\n let retryAfterHeaderValue: number = Number.NaN;\n try {\n const request = createRequest(args, authHeader);\n const response = await fetch(url, request);\n\n retryAfterHeaderValue = Number(response.headers.get('Retry-After'));\n\n if (response.ok) {\n const body = (await response.json()) as EdgeHttpResponse<T>;\n if (body.success) {\n return body.data;\n }\n\n log.info('unsuccessful edge response', { path, body });\n\n if (body.errorData?.type === 'auth_challenge' && typeof body.errorData?.challenge === 'string') {\n processingError = new EdgeAuthChallengeError(body.errorData.challenge, body.errorData);\n } else {\n processingError = EdgeCallFailedError.fromUnsuccessfulResponse(response, body);\n }\n } else if (response.status === 401 && !handledAuth) {\n authHeader = await this._handleUnauthorized(response);\n handledAuth = true;\n continue;\n } else {\n processingError = EdgeCallFailedError.fromHttpFailure(response);\n }\n } catch (error: any) {\n processingError = EdgeCallFailedError.fromProcessingFailureCause(error);\n }\n\n if (processingError.isRetryable && (await shouldRetry(requestContext, retryAfterHeaderValue))) {\n log.info('retrying edge request', { path, processingError });\n } else {\n throw processingError;\n }\n }\n }\n\n private async _handleUnauthorized(response: Response) {\n if (!this._edgeIdentity) {\n log.warn('edge unauthorized response received before identity was set');\n throw EdgeCallFailedError.fromHttpFailure(response);\n }\n const challenge = await handleAuthChallenge(response, this._edgeIdentity);\n this._authHeader = encodeAuthHeader(challenge);\n log('auth header updated');\n return this._authHeader;\n }\n}\n\nconst createRetryHandler = (args: EdgeHttpCallArgs) => {\n if (!args.retry || args.retry.count < 1) {\n return async () => false;\n }\n let retries = 0;\n const maxRetries = args.retry.count ?? DEFAULT_MAX_RETRIES_COUNT;\n const baseTimeout = args.retry.timeout ?? DEFAULT_RETRY_TIMEOUT;\n const jitter = args.retry.jitter ?? DEFAULT_RETRY_JITTER;\n return async (ctx: Context, retryAfter: number) => {\n if (++retries > maxRetries || ctx.disposed) {\n return false;\n }\n\n if (retryAfter) {\n await sleep(retryAfter);\n } else {\n const timeout = baseTimeout + Math.random() * jitter;\n await sleep(timeout);\n }\n\n return true;\n };\n};\n\nexport type RetryConfig = {\n /**\n * A number of call retries, not counting the initial request.\n */\n count: number;\n /**\n * Delay before retries in ms.\n */\n timeout?: number;\n /**\n * A random amount of time before retrying to help prevent large bursts of requests.\n */\n jitter?: number;\n};\n\nexport type EdgeHttpGetArgs = { context?: Context; retry?: RetryConfig };\n\nexport type EdgeHttpPostArgs = { context?: Context; body?: any; retry?: RetryConfig };\n\ntype EdgeHttpCallArgs = {\n method: string;\n body?: any;\n context?: Context;\n retry?: RetryConfig;\n};\n\nconst createRequest = (args: EdgeHttpCallArgs, authHeader: string | undefined): RequestInit => {\n return {\n method: args.method,\n body: args.body && JSON.stringify(args.body),\n headers: authHeader ? { Authorization: authHeader } : undefined,\n };\n};\n\nconst encodeAuthHeader = (challenge: Uint8Array) => {\n const encodedChallenge = Buffer.from(challenge).toString('base64');\n return `VerifiablePresentation pb;base64,${encodedChallenge}`;\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["Trigger", "scheduleMicroTask", "TriggerState", "Resource", "log", "logInfo", "invariant", "schema", "handleAuthChallenge", "failedResponse", "identity", "status", "headerValue", "headers", "get", "startsWith", "challenge", "slice", "length", "presentation", "presentCredentials", "Buffer", "from", "getCodecForType", "encode", "WebSocket", "scheduleTask", "scheduleTaskInterval", "Context", "Resource", "invariant", "log", "logInfo", "buf", "MessageSchema", "SIGNAL_KEEPALIVE_INTERVAL", "CLOUDFLARE_MESSAGE_LENGTH_LIMIT", "EdgeWsConnection", "Resource", "constructor", "_identity", "_connectionInfo", "_callbacks", "info", "open", "isOpen", "identity", "identityKey", "device", "peerKey", "send", "message", "invariant", "_ws", "log", "payload", "protocol", "getPayloadType", "encoded", "buf", "toBinary", "MessageSchema", "byteLength", "error", "serviceId", "_open", "WebSocket", "url", "toString", "protocolHeader", "onopen", "onConnected", "_scheduleHeartbeats", "verbose", "currentIdentity", "onclose", "onRestartRequired", "onerror", "event", "warn", "onmessage", "type", "data", "_rescheduleHeartbeatTimeout", "toUint8Array", "fromBinary", "from", "source", "onMessage", "_close", "_inactivityTimeoutCtx", "dispose", "catch", "close", "undefined", "err", "Error", "includes", "scheduleTaskInterval", "_ctx", "Context", "scheduleTask", "logInfo", "EdgeConnectionClosedError", "Error", "constructor", "EdgeIdentityChangedError", "DeferredTask", "sleep", "synchronized", "cancelWithContext", "LifecycleState", "Resource", "warnAfterTimeout", "log", "INIT_RESTART_DELAY", "DEFAULT_MAX_RESTART_DELAY", "PersistentLifecycle", "constructor", "start", "stop", "onRestart", "maxRestartDelay", "_currentContext", "undefined", "_restartTask", "_restartAfter", "_start", "_stop", "_onRestart", "_maxRestartDelay", "_open", "_ctx", "_restart", "err", "warn", "schedule", "catch", "_close", "join", "_stopCurrentContext", "state", "_lifecycleState", "OPEN", "Math", "min", "max", "scheduleRestart", "getEdgeUrlWithProtocol", "baseUrl", "protocol", "isSecure", "startsWith", "url", "URL", "toString", "DEFAULT_TIMEOUT", "EdgeClient", "Resource", "constructor", "_identity", "_config", "_persistentLifecycle", "PersistentLifecycle", "start", "_connect", "stop", "state", "_disconnect", "_messageListeners", "Set", "_reconnectListeners", "_currentConnection", "undefined", "_ready", "Trigger", "_isActive", "connection", "_baseWsUrl", "getEdgeUrlWithProtocol", "socketEndpoint", "_baseHttpUrl", "info", "open", "isOpen", "identity", "identityKey", "device", "peerKey", "isConnected", "Boolean", "TriggerState", "RESOLVED", "setIdentity", "log", "oldIdentity", "_closeCurrentConnection", "EdgeIdentityChangedError", "scheduleRestart", "onMessage", "listener", "add", "delete", "onReconnected", "scheduleMicroTask", "_ctx", "has", "error", "catch", "_open", "err", "warn", "_close", "close", "disposed", "path", "protocolHeader", "disableAuth", "_createAuthHeader", "restartRequired", "url", "URL", "toString", "EdgeWsConnection", "onConnected", "wake", "_notifyReconnected", "verbose", "onRestartRequired", "message", "_notifyMessageReceived", "from", "source", "type", "payload", "typeUrl", "Promise", "race", "wait", "timeout", "EdgeConnectionClosedError", "throw", "reset", "protocol", "getPayloadType", "send", "httpUrl", "response", "fetch", "method", "status", "encodePresentationWsAuthHeader", "handleAuthChallenge", "statusText", "logInfo", "encodedPresentation", "encodedToken", "Buffer", "replace", "replaceAll", "createCredential", "signPresentation", "invariant", "Keyring", "PublicKey", "createDeviceEdgeIdentity", "signer", "key", "identityKey", "toHex", "peerKey", "presentCredentials", "challenge", "presentation", "credentials", "assertion", "issuer", "subject", "signerKey", "nonce", "createChainEdgeIdentity", "chain", "credentialsToSign", "length", "signingKey", "createEphemeralEdgeIdentity", "keyring", "createKey", "createTestHaloEdgeIdentity", "deviceKey", "deviceAdmission", "credential", "createStubEdgeIdentity", "random", "Error", "sleep", "Context", "log", "EdgeCallFailedError", "EdgeAuthChallengeError", "DEFAULT_RETRY_TIMEOUT", "DEFAULT_RETRY_JITTER", "DEFAULT_MAX_RETRIES_COUNT", "EdgeHttpClient", "constructor", "baseUrl", "_baseUrl", "getEdgeUrlWithProtocol", "log", "url", "setIdentity", "identity", "_edgeIdentity", "identityKey", "peerKey", "_authHeader", "undefined", "createAgent", "body", "args", "_call", "method", "getAgentStatus", "request", "ownerIdentityKey", "toHex", "getCredentialsForNotarization", "spaceId", "notarizeCredentials", "joinSpaceByInvitation", "recoverIdentity", "uploadFunction", "pathParts", "path", "functionId", "join", "requestContext", "context", "Context", "shouldRetry", "createRetryHandler", "startsWith", "slice", "info", "handledAuth", "authHeader", "processingError", "retryAfterHeaderValue", "Number", "NaN", "createRequest", "response", "fetch", "headers", "get", "ok", "json", "success", "data", "errorData", "type", "challenge", "EdgeAuthChallengeError", "EdgeCallFailedError", "fromUnsuccessfulResponse", "status", "_handleUnauthorized", "fromHttpFailure", "error", "fromProcessingFailureCause", "isRetryable", "warn", "handleAuthChallenge", "encodeAuthHeader", "retry", "count", "retries", "maxRetries", "baseTimeout", "timeout", "jitter", "ctx", "retryAfter", "disposed", "sleep", "Math", "random", "JSON", "stringify", "Authorization", "encodedChallenge", "Buffer", "from", "toString"]
7
7
  }
@@ -1 +1 @@
1
- {"inputs":{"packages/core/mesh/edge-client/src/protocol.ts":{"bytes":10334,"imports":[{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/edge-client/src/defs.ts":{"bytes":1607,"imports":[{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"packages/core/mesh/edge-client/src/protocol.ts","kind":"import-statement","original":"./protocol"}],"format":"esm"},"packages/core/mesh/edge-client/src/edge-identity.ts":{"bytes":4069,"imports":[{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/protocols/proto","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/edge-client/src/edge-ws-connection.ts":{"bytes":18905,"imports":[{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"packages/core/mesh/edge-client/src/defs.ts","kind":"import-statement","original":"./defs"},{"path":"packages/core/mesh/edge-client/src/protocol.ts","kind":"import-statement","original":"./protocol"}],"format":"esm"},"packages/core/mesh/edge-client/src/errors.ts":{"bytes":1265,"imports":[],"format":"esm"},"packages/core/mesh/edge-client/src/persistent-lifecycle.ts":{"bytes":12584,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/edge-client/src/utils.ts":{"bytes":1451,"imports":[],"format":"esm"},"packages/core/mesh/edge-client/src/edge-client.ts":{"bytes":34295,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"packages/core/mesh/edge-client/src/defs.ts","kind":"import-statement","original":"./defs"},{"path":"packages/core/mesh/edge-client/src/edge-identity.ts","kind":"import-statement","original":"./edge-identity"},{"path":"packages/core/mesh/edge-client/src/edge-ws-connection.ts","kind":"import-statement","original":"./edge-ws-connection"},{"path":"packages/core/mesh/edge-client/src/errors.ts","kind":"import-statement","original":"./errors"},{"path":"packages/core/mesh/edge-client/src/persistent-lifecycle.ts","kind":"import-statement","original":"./persistent-lifecycle"},{"path":"packages/core/mesh/edge-client/src/utils.ts","kind":"import-statement","original":"./utils"}],"format":"esm"},"packages/core/mesh/edge-client/src/auth.ts":{"bytes":12314,"imports":[{"path":"@dxos/credentials","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keyring","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/edge-client/src/edge-http-client.ts":{"bytes":25302,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"packages/core/mesh/edge-client/src/edge-identity.ts","kind":"import-statement","original":"./edge-identity"},{"path":"packages/core/mesh/edge-client/src/utils.ts","kind":"import-statement","original":"./utils"}],"format":"esm"},"packages/core/mesh/edge-client/src/index.ts":{"bytes":1228,"imports":[{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"packages/core/mesh/edge-client/src/edge-client.ts","kind":"import-statement","original":"./edge-client"},{"path":"packages/core/mesh/edge-client/src/defs.ts","kind":"import-statement","original":"./defs"},{"path":"packages/core/mesh/edge-client/src/protocol.ts","kind":"import-statement","original":"./protocol"},{"path":"packages/core/mesh/edge-client/src/errors.ts","kind":"import-statement","original":"./errors"},{"path":"packages/core/mesh/edge-client/src/auth.ts","kind":"import-statement","original":"./auth"},{"path":"packages/core/mesh/edge-client/src/edge-http-client.ts","kind":"import-statement","original":"./edge-http-client"},{"path":"packages/core/mesh/edge-client/src/edge-identity.ts","kind":"import-statement","original":"./edge-identity"}],"format":"esm"},"packages/core/mesh/edge-client/src/testing/test-utils.ts":{"bytes":13201,"imports":[{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"packages/core/mesh/edge-client/src/defs.ts","kind":"import-statement","original":"../defs"},{"path":"packages/core/mesh/edge-client/src/protocol.ts","kind":"import-statement","original":"../protocol"}],"format":"esm"},"packages/core/mesh/edge-client/src/testing/index.ts":{"bytes":516,"imports":[{"path":"packages/core/mesh/edge-client/src/testing/test-utils.ts","kind":"import-statement","original":"./test-utils"}],"format":"esm"}},"outputs":{"packages/core/mesh/edge-client/dist/lib/browser/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":51425},"packages/core/mesh/edge-client/dist/lib/browser/index.mjs":{"imports":[{"path":"packages/core/mesh/edge-client/dist/lib/browser/chunk-ZWJXA37R.mjs","kind":"import-statement"},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/protocols/proto","kind":"import-statement","external":true},{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/credentials","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keyring","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true}],"exports":["EdgeClient","EdgeConnectionClosedError","EdgeHttpClient","EdgeIdentityChangedError","Protocol","createChainEdgeIdentity","createDeviceEdgeIdentity","createEphemeralEdgeIdentity","createStubEdgeIdentity","createTestHaloEdgeIdentity","getTypename","handleAuthChallenge","protocol","toUint8Array"],"entryPoint":"packages/core/mesh/edge-client/src/index.ts","inputs":{"packages/core/mesh/edge-client/src/index.ts":{"bytesInOutput":60},"packages/core/mesh/edge-client/src/edge-client.ts":{"bytesInOutput":9076},"packages/core/mesh/edge-client/src/edge-identity.ts":{"bytesInOutput":1150},"packages/core/mesh/edge-client/src/edge-ws-connection.ts":{"bytesInOutput":5580},"packages/core/mesh/edge-client/src/errors.ts":{"bytesInOutput":232},"packages/core/mesh/edge-client/src/persistent-lifecycle.ts":{"bytesInOutput":3547},"packages/core/mesh/edge-client/src/utils.ts":{"bytesInOutput":244},"packages/core/mesh/edge-client/src/auth.ts":{"bytesInOutput":2993},"packages/core/mesh/edge-client/src/edge-http-client.ts":{"bytesInOutput":6050}},"bytes":29920},"packages/core/mesh/edge-client/dist/lib/browser/testing/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":6741},"packages/core/mesh/edge-client/dist/lib/browser/testing/index.mjs":{"imports":[{"path":"packages/core/mesh/edge-client/dist/lib/browser/chunk-ZWJXA37R.mjs","kind":"import-statement"},{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true}],"exports":["DEFAULT_PORT","createTestEdgeWsServer"],"entryPoint":"packages/core/mesh/edge-client/src/testing/index.ts","inputs":{"packages/core/mesh/edge-client/src/testing/test-utils.ts":{"bytesInOutput":3466},"packages/core/mesh/edge-client/src/testing/index.ts":{"bytesInOutput":0}},"bytes":3683},"packages/core/mesh/edge-client/dist/lib/browser/chunk-ZWJXA37R.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":5676},"packages/core/mesh/edge-client/dist/lib/browser/chunk-ZWJXA37R.mjs":{"imports":[{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true}],"exports":["Protocol","getTypename","protocol","toUint8Array"],"inputs":{"packages/core/mesh/edge-client/src/protocol.ts":{"bytesInOutput":2600},"packages/core/mesh/edge-client/src/defs.ts":{"bytesInOutput":298}},"bytes":3106}}}
1
+ {"inputs":{"packages/core/mesh/edge-client/src/protocol.ts":{"bytes":10334,"imports":[{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/edge-client/src/defs.ts":{"bytes":1607,"imports":[{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"packages/core/mesh/edge-client/src/protocol.ts","kind":"import-statement","original":"./protocol"}],"format":"esm"},"packages/core/mesh/edge-client/src/edge-identity.ts":{"bytes":4069,"imports":[{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/protocols/proto","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/edge-client/src/edge-ws-connection.ts":{"bytes":20663,"imports":[{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"packages/core/mesh/edge-client/src/defs.ts","kind":"import-statement","original":"./defs"},{"path":"packages/core/mesh/edge-client/src/protocol.ts","kind":"import-statement","original":"./protocol"}],"format":"esm"},"packages/core/mesh/edge-client/src/errors.ts":{"bytes":1265,"imports":[],"format":"esm"},"packages/core/mesh/edge-client/src/persistent-lifecycle.ts":{"bytes":12584,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/edge-client/src/utils.ts":{"bytes":1451,"imports":[],"format":"esm"},"packages/core/mesh/edge-client/src/edge-client.ts":{"bytes":34295,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"packages/core/mesh/edge-client/src/defs.ts","kind":"import-statement","original":"./defs"},{"path":"packages/core/mesh/edge-client/src/edge-identity.ts","kind":"import-statement","original":"./edge-identity"},{"path":"packages/core/mesh/edge-client/src/edge-ws-connection.ts","kind":"import-statement","original":"./edge-ws-connection"},{"path":"packages/core/mesh/edge-client/src/errors.ts","kind":"import-statement","original":"./errors"},{"path":"packages/core/mesh/edge-client/src/persistent-lifecycle.ts","kind":"import-statement","original":"./persistent-lifecycle"},{"path":"packages/core/mesh/edge-client/src/utils.ts","kind":"import-statement","original":"./utils"}],"format":"esm"},"packages/core/mesh/edge-client/src/auth.ts":{"bytes":12314,"imports":[{"path":"@dxos/credentials","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keyring","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/edge-client/src/edge-http-client.ts":{"bytes":25302,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"packages/core/mesh/edge-client/src/edge-identity.ts","kind":"import-statement","original":"./edge-identity"},{"path":"packages/core/mesh/edge-client/src/utils.ts","kind":"import-statement","original":"./utils"}],"format":"esm"},"packages/core/mesh/edge-client/src/index.ts":{"bytes":1228,"imports":[{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"packages/core/mesh/edge-client/src/edge-client.ts","kind":"import-statement","original":"./edge-client"},{"path":"packages/core/mesh/edge-client/src/defs.ts","kind":"import-statement","original":"./defs"},{"path":"packages/core/mesh/edge-client/src/protocol.ts","kind":"import-statement","original":"./protocol"},{"path":"packages/core/mesh/edge-client/src/errors.ts","kind":"import-statement","original":"./errors"},{"path":"packages/core/mesh/edge-client/src/auth.ts","kind":"import-statement","original":"./auth"},{"path":"packages/core/mesh/edge-client/src/edge-http-client.ts","kind":"import-statement","original":"./edge-http-client"},{"path":"packages/core/mesh/edge-client/src/edge-identity.ts","kind":"import-statement","original":"./edge-identity"}],"format":"esm"},"packages/core/mesh/edge-client/src/testing/test-utils.ts":{"bytes":13201,"imports":[{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"packages/core/mesh/edge-client/src/defs.ts","kind":"import-statement","original":"../defs"},{"path":"packages/core/mesh/edge-client/src/protocol.ts","kind":"import-statement","original":"../protocol"}],"format":"esm"},"packages/core/mesh/edge-client/src/testing/index.ts":{"bytes":516,"imports":[{"path":"packages/core/mesh/edge-client/src/testing/test-utils.ts","kind":"import-statement","original":"./test-utils"}],"format":"esm"}},"outputs":{"packages/core/mesh/edge-client/dist/lib/browser/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":52199},"packages/core/mesh/edge-client/dist/lib/browser/index.mjs":{"imports":[{"path":"packages/core/mesh/edge-client/dist/lib/browser/chunk-ZWJXA37R.mjs","kind":"import-statement"},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/protocols/proto","kind":"import-statement","external":true},{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/credentials","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keyring","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true}],"exports":["EdgeClient","EdgeConnectionClosedError","EdgeHttpClient","EdgeIdentityChangedError","Protocol","createChainEdgeIdentity","createDeviceEdgeIdentity","createEphemeralEdgeIdentity","createStubEdgeIdentity","createTestHaloEdgeIdentity","getTypename","handleAuthChallenge","protocol","toUint8Array"],"entryPoint":"packages/core/mesh/edge-client/src/index.ts","inputs":{"packages/core/mesh/edge-client/src/index.ts":{"bytesInOutput":60},"packages/core/mesh/edge-client/src/edge-client.ts":{"bytesInOutput":9076},"packages/core/mesh/edge-client/src/edge-identity.ts":{"bytesInOutput":1150},"packages/core/mesh/edge-client/src/edge-ws-connection.ts":{"bytesInOutput":6056},"packages/core/mesh/edge-client/src/errors.ts":{"bytesInOutput":232},"packages/core/mesh/edge-client/src/persistent-lifecycle.ts":{"bytesInOutput":3547},"packages/core/mesh/edge-client/src/utils.ts":{"bytesInOutput":244},"packages/core/mesh/edge-client/src/auth.ts":{"bytesInOutput":2993},"packages/core/mesh/edge-client/src/edge-http-client.ts":{"bytesInOutput":6050}},"bytes":30396},"packages/core/mesh/edge-client/dist/lib/browser/testing/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":6741},"packages/core/mesh/edge-client/dist/lib/browser/testing/index.mjs":{"imports":[{"path":"packages/core/mesh/edge-client/dist/lib/browser/chunk-ZWJXA37R.mjs","kind":"import-statement"},{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true}],"exports":["DEFAULT_PORT","createTestEdgeWsServer"],"entryPoint":"packages/core/mesh/edge-client/src/testing/index.ts","inputs":{"packages/core/mesh/edge-client/src/testing/test-utils.ts":{"bytesInOutput":3466},"packages/core/mesh/edge-client/src/testing/index.ts":{"bytesInOutput":0}},"bytes":3683},"packages/core/mesh/edge-client/dist/lib/browser/chunk-ZWJXA37R.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":5676},"packages/core/mesh/edge-client/dist/lib/browser/chunk-ZWJXA37R.mjs":{"imports":[{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf","kind":"import-statement","external":true},{"path":"@dxos/protocols/buf/dxos/edge/messenger_pb","kind":"import-statement","external":true}],"exports":["Protocol","getTypename","protocol","toUint8Array"],"inputs":{"packages/core/mesh/edge-client/src/protocol.ts":{"bytesInOutput":2600},"packages/core/mesh/edge-client/src/defs.ts":{"bytesInOutput":298}},"bytes":3106}}}
@@ -115,6 +115,7 @@ function _ts_decorate(decorators, target, key, desc) {
115
115
  }
116
116
  var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/core/mesh/edge-client/src/edge-ws-connection.ts";
117
117
  var SIGNAL_KEEPALIVE_INTERVAL = 5e3;
118
+ var CLOUDFLARE_MESSAGE_LENGTH_LIMIT = 1024 * 1024;
118
119
  var EdgeWsConnection = class extends import_context2.Resource {
119
120
  constructor(_identity, _connectionInfo, _callbacks) {
120
121
  super();
@@ -132,7 +133,7 @@ var EdgeWsConnection = class extends import_context2.Resource {
132
133
  send(message) {
133
134
  (0, import_invariant2.invariant)(this._ws, void 0, {
134
135
  F: __dxlog_file2,
135
- L: 48,
136
+ L: 53,
136
137
  S: this,
137
138
  A: [
138
139
  "this._ws",
@@ -144,11 +145,25 @@ var EdgeWsConnection = class extends import_context2.Resource {
144
145
  payload: import_chunk_ANV2HBEH.protocol.getPayloadType(message)
145
146
  }, {
146
147
  F: __dxlog_file2,
147
- L: 49,
148
+ L: 54,
148
149
  S: this,
149
150
  C: (f, a) => f(...a)
150
151
  });
151
- this._ws.send(import_buf.buf.toBinary(import_messenger_pb.MessageSchema, message));
152
+ const encoded = import_buf.buf.toBinary(import_messenger_pb.MessageSchema, message);
153
+ if (encoded.byteLength >= CLOUDFLARE_MESSAGE_LENGTH_LIMIT) {
154
+ import_log2.log.error("edge message dropped due to websocket message limit", {
155
+ byteLength: encoded.byteLength,
156
+ serviceId: message.serviceId,
157
+ payload: import_chunk_ANV2HBEH.protocol.getPayloadType(message)
158
+ }, {
159
+ F: __dxlog_file2,
160
+ L: 57,
161
+ S: this,
162
+ C: (f, a) => f(...a)
163
+ });
164
+ return;
165
+ }
166
+ this._ws.send(encoded);
152
167
  }
153
168
  async _open() {
154
169
  this._ws = new import_isomorphic_ws.default(this._connectionInfo.url.toString(), this._connectionInfo.protocolHeader ? [
@@ -158,7 +173,7 @@ var EdgeWsConnection = class extends import_context2.Resource {
158
173
  if (this.isOpen) {
159
174
  (0, import_log2.log)("connected", void 0, {
160
175
  F: __dxlog_file2,
161
- L: 61,
176
+ L: 75,
162
177
  S: this,
163
178
  C: (f, a) => f(...a)
164
179
  });
@@ -169,7 +184,7 @@ var EdgeWsConnection = class extends import_context2.Resource {
169
184
  currentIdentity: this._identity
170
185
  }, {
171
186
  F: __dxlog_file2,
172
- L: 65,
187
+ L: 79,
173
188
  S: this,
174
189
  C: (f, a) => f(...a)
175
190
  });
@@ -179,7 +194,7 @@ var EdgeWsConnection = class extends import_context2.Resource {
179
194
  if (this.isOpen) {
180
195
  (0, import_log2.log)("disconnected while being open", void 0, {
181
196
  F: __dxlog_file2,
182
- L: 70,
197
+ L: 84,
183
198
  S: this,
184
199
  C: (f, a) => f(...a)
185
200
  });
@@ -193,7 +208,7 @@ var EdgeWsConnection = class extends import_context2.Resource {
193
208
  info: event.message
194
209
  }, {
195
210
  F: __dxlog_file2,
196
- L: 76,
211
+ L: 90,
197
212
  S: this,
198
213
  C: (f, a) => f(...a)
199
214
  });
@@ -203,7 +218,7 @@ var EdgeWsConnection = class extends import_context2.Resource {
203
218
  error: event.error
204
219
  }, {
205
220
  F: __dxlog_file2,
206
- L: 79,
221
+ L: 93,
207
222
  S: this,
208
223
  C: (f, a) => f(...a)
209
224
  });
@@ -215,7 +230,7 @@ var EdgeWsConnection = class extends import_context2.Resource {
215
230
  event: event.type
216
231
  }, {
217
232
  F: __dxlog_file2,
218
- L: 87,
233
+ L: 101,
219
234
  S: this,
220
235
  C: (f, a) => f(...a)
221
236
  });
@@ -233,7 +248,7 @@ var EdgeWsConnection = class extends import_context2.Resource {
233
248
  payload: import_chunk_ANV2HBEH.protocol.getPayloadType(message)
234
249
  }, {
235
250
  F: __dxlog_file2,
236
- L: 97,
251
+ L: 111,
237
252
  S: this,
238
253
  C: (f, a) => f(...a)
239
254
  });
@@ -255,7 +270,7 @@ var EdgeWsConnection = class extends import_context2.Resource {
255
270
  err
256
271
  }, {
257
272
  F: __dxlog_file2,
258
- L: 113,
273
+ L: 127,
259
274
  S: this,
260
275
  C: (f, a) => f(...a)
261
276
  });
@@ -264,7 +279,7 @@ var EdgeWsConnection = class extends import_context2.Resource {
264
279
  _scheduleHeartbeats() {
265
280
  (0, import_invariant2.invariant)(this._ws, void 0, {
266
281
  F: __dxlog_file2,
267
- L: 118,
282
+ L: 132,
268
283
  S: this,
269
284
  A: [
270
285
  "this._ws",
@@ -284,7 +299,7 @@ var EdgeWsConnection = class extends import_context2.Resource {
284
299
  void this._inactivityTimeoutCtx?.dispose();
285
300
  this._inactivityTimeoutCtx = new import_context2.Context(void 0, {
286
301
  F: __dxlog_file2,
287
- L: 137
302
+ L: 151
288
303
  });
289
304
  (0, import_async2.scheduleTask)(this._inactivityTimeoutCtx, () => {
290
305
  if (this.isOpen) {