@replit/river 0.23.11 → 0.23.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (74) hide show
  1. package/dist/chunk-2FNLANTJ.js +327 -0
  2. package/dist/chunk-2FNLANTJ.js.map +1 -0
  3. package/dist/{chunk-3AW3IXVD.js → chunk-4PVU7J25.js} +1 -21
  4. package/dist/chunk-4PVU7J25.js.map +1 -0
  5. package/dist/{chunk-T6YEMFUF.js → chunk-4QZOW4DH.js} +2 -2
  6. package/dist/{chunk-MEHCOYKJ.js → chunk-ES4XO2XD.js} +2 -2
  7. package/dist/{chunk-MEHCOYKJ.js.map → chunk-ES4XO2XD.js.map} +1 -1
  8. package/dist/{chunk-ZSKCZYVU.js → chunk-KFTGQ3QC.js} +2 -2
  9. package/dist/chunk-KFTGQ3QC.js.map +1 -0
  10. package/dist/chunk-S4DUN7KK.js +455 -0
  11. package/dist/chunk-S4DUN7KK.js.map +1 -0
  12. package/dist/{chunk-HM7VDTDJ.js → chunk-SX6HI63Q.js} +2 -2
  13. package/dist/chunk-XM656KMN.js +408 -0
  14. package/dist/chunk-XM656KMN.js.map +1 -0
  15. package/dist/chunk-ZUKDZY54.js +271 -0
  16. package/dist/chunk-ZUKDZY54.js.map +1 -0
  17. package/dist/client-dd5c9dd0.d.ts +52 -0
  18. package/dist/codec/index.js +20 -2
  19. package/dist/codec/index.js.map +1 -1
  20. package/dist/{connection-261eee8f.d.ts → connection-39816c00.d.ts} +1 -1
  21. package/dist/{connection-c1eeb95d.d.ts → connection-40318f22.d.ts} +1 -1
  22. package/dist/{transport-c8f36f6d.d.ts → handshake-e428d1c8.d.ts} +91 -155
  23. package/dist/{index-60f03cb7.d.ts → index-ea74cdbb.d.ts} +1 -1
  24. package/dist/logging/index.d.cts +1 -1
  25. package/dist/logging/index.d.ts +1 -1
  26. package/dist/router/index.cjs +1 -1
  27. package/dist/router/index.cjs.map +1 -1
  28. package/dist/router/index.d.cts +8 -6
  29. package/dist/router/index.d.ts +8 -6
  30. package/dist/router/index.js +2 -2
  31. package/dist/server-ebf80863.d.ts +24 -0
  32. package/dist/{services-524bab79.d.ts → services-f406b3aa.d.ts} +3 -2
  33. package/dist/transport/impls/uds/client.cjs +222 -174
  34. package/dist/transport/impls/uds/client.cjs.map +1 -1
  35. package/dist/transport/impls/uds/client.d.cts +6 -5
  36. package/dist/transport/impls/uds/client.d.ts +6 -5
  37. package/dist/transport/impls/uds/client.js +6 -4
  38. package/dist/transport/impls/uds/client.js.map +1 -1
  39. package/dist/transport/impls/uds/server.cjs +252 -223
  40. package/dist/transport/impls/uds/server.cjs.map +1 -1
  41. package/dist/transport/impls/uds/server.d.cts +6 -5
  42. package/dist/transport/impls/uds/server.d.ts +6 -5
  43. package/dist/transport/impls/uds/server.js +8 -6
  44. package/dist/transport/impls/uds/server.js.map +1 -1
  45. package/dist/transport/impls/ws/client.cjs +224 -176
  46. package/dist/transport/impls/ws/client.cjs.map +1 -1
  47. package/dist/transport/impls/ws/client.d.cts +6 -5
  48. package/dist/transport/impls/ws/client.d.ts +6 -5
  49. package/dist/transport/impls/ws/client.js +6 -4
  50. package/dist/transport/impls/ws/client.js.map +1 -1
  51. package/dist/transport/impls/ws/server.cjs +206 -177
  52. package/dist/transport/impls/ws/server.cjs.map +1 -1
  53. package/dist/transport/impls/ws/server.d.cts +4 -3
  54. package/dist/transport/impls/ws/server.d.ts +4 -3
  55. package/dist/transport/impls/ws/server.js +8 -6
  56. package/dist/transport/impls/ws/server.js.map +1 -1
  57. package/dist/transport/index.cjs +170 -116
  58. package/dist/transport/index.cjs.map +1 -1
  59. package/dist/transport/index.d.cts +4 -2
  60. package/dist/transport/index.d.ts +4 -2
  61. package/dist/transport/index.js +14 -8
  62. package/dist/util/testHelpers.cjs +6 -8
  63. package/dist/util/testHelpers.cjs.map +1 -1
  64. package/dist/util/testHelpers.d.cts +5 -4
  65. package/dist/util/testHelpers.d.ts +5 -4
  66. package/dist/util/testHelpers.js +4 -5
  67. package/dist/util/testHelpers.js.map +1 -1
  68. package/package.json +1 -1
  69. package/dist/chunk-3AW3IXVD.js.map +0 -1
  70. package/dist/chunk-EOJMKMDO.js +0 -1372
  71. package/dist/chunk-EOJMKMDO.js.map +0 -1
  72. package/dist/chunk-ZSKCZYVU.js.map +0 -1
  73. /package/dist/{chunk-T6YEMFUF.js.map → chunk-4QZOW4DH.js.map} +0 -0
  74. /package/dist/{chunk-HM7VDTDJ.js.map → chunk-SX6HI63Q.js.map} +0 -0
@@ -0,0 +1,271 @@
1
+ import {
2
+ ProtocolError,
3
+ Transport
4
+ } from "./chunk-XM656KMN.js";
5
+ import {
6
+ defaultServerTransportOptions
7
+ } from "./chunk-2FNLANTJ.js";
8
+ import {
9
+ ControlMessageHandshakeRequestSchema,
10
+ PROTOCOL_VERSION,
11
+ coerceErrorString,
12
+ handshakeResponseMessage
13
+ } from "./chunk-ES4XO2XD.js";
14
+
15
+ // transport/server.ts
16
+ import { SpanStatusCode } from "@opentelemetry/api";
17
+ import { Value } from "@sinclair/typebox/value";
18
+ var ServerTransport = class extends Transport {
19
+ /**
20
+ * The options for this transport.
21
+ */
22
+ options;
23
+ /**
24
+ * Optional handshake options for the server.
25
+ */
26
+ handshakeExtensions;
27
+ /**
28
+ * A map of session handshake data for each session.
29
+ */
30
+ sessionHandshakeMetadata;
31
+ constructor(clientId, providedOptions) {
32
+ super(clientId, providedOptions);
33
+ this.options = {
34
+ ...defaultServerTransportOptions,
35
+ ...providedOptions
36
+ };
37
+ this.sessionHandshakeMetadata = /* @__PURE__ */ new WeakMap();
38
+ this.log?.info(`initiated server transport`, {
39
+ clientId: this.clientId,
40
+ protocolVersion: PROTOCOL_VERSION
41
+ });
42
+ }
43
+ extendHandshake(options) {
44
+ this.handshakeExtensions = options;
45
+ }
46
+ handleConnection(conn) {
47
+ if (this.getStatus() !== "open")
48
+ return;
49
+ this.log?.info(`new incoming connection`, {
50
+ ...conn.loggingMetadata,
51
+ clientId: this.clientId
52
+ });
53
+ let session = void 0;
54
+ const client = () => session?.to ?? "unknown";
55
+ const handshakeTimeout = setTimeout(() => {
56
+ if (!session) {
57
+ this.log?.warn(
58
+ `connection to ${client()} timed out waiting for handshake, closing`,
59
+ {
60
+ ...conn.loggingMetadata,
61
+ clientId: this.clientId,
62
+ connectedTo: client()
63
+ }
64
+ );
65
+ conn.telemetry?.span.setStatus({
66
+ code: SpanStatusCode.ERROR,
67
+ message: "handshake timeout"
68
+ });
69
+ conn.close();
70
+ }
71
+ }, this.options.sessionDisconnectGraceMs);
72
+ const buffer = [];
73
+ let receivedHandshakeMessage = false;
74
+ const handshakeHandler = (data) => {
75
+ if (receivedHandshakeMessage) {
76
+ buffer.push(data);
77
+ return;
78
+ }
79
+ receivedHandshakeMessage = true;
80
+ clearTimeout(handshakeTimeout);
81
+ void this.receiveHandshakeRequestMessage(data, conn).then(
82
+ (maybeSession) => {
83
+ if (!maybeSession) {
84
+ conn.close();
85
+ return;
86
+ }
87
+ session = maybeSession;
88
+ const dataHandler = (data2) => {
89
+ const parsed = this.parseMsg(data2, conn);
90
+ if (!parsed) {
91
+ conn.close();
92
+ return;
93
+ }
94
+ this.handleMsg(parsed, conn);
95
+ };
96
+ for (const data2 of buffer) {
97
+ dataHandler(data2);
98
+ }
99
+ conn.removeDataListener(handshakeHandler);
100
+ conn.addDataListener(dataHandler);
101
+ buffer.length = 0;
102
+ }
103
+ );
104
+ };
105
+ conn.addDataListener(handshakeHandler);
106
+ conn.addCloseListener(() => {
107
+ if (!session)
108
+ return;
109
+ this.log?.info(`connection to ${client()} disconnected`, {
110
+ ...conn.loggingMetadata,
111
+ clientId: this.clientId
112
+ });
113
+ this.onDisconnect(conn, session);
114
+ });
115
+ conn.addErrorListener((err) => {
116
+ conn.telemetry?.span.setStatus({
117
+ code: SpanStatusCode.ERROR,
118
+ message: "connection error"
119
+ });
120
+ if (!session)
121
+ return;
122
+ this.log?.warn(
123
+ `connection to ${client()} got an error: ${coerceErrorString(err)}`,
124
+ { ...conn.loggingMetadata, clientId: this.clientId }
125
+ );
126
+ });
127
+ }
128
+ async validateHandshakeMetadata(conn, session, rawMetadata, from) {
129
+ let parsedMetadata = {};
130
+ if (this.handshakeExtensions) {
131
+ if (!Value.Check(this.handshakeExtensions.schema, rawMetadata)) {
132
+ conn.telemetry?.span.setStatus({
133
+ code: SpanStatusCode.ERROR,
134
+ message: "malformed handshake meta"
135
+ });
136
+ const reason = "received malformed handshake metadata";
137
+ const responseMsg = handshakeResponseMessage(this.clientId, from, {
138
+ ok: false,
139
+ reason
140
+ });
141
+ conn.send(this.codec.toBuffer(responseMsg));
142
+ this.log?.warn(`received malformed handshake metadata from ${from}`, {
143
+ ...conn.loggingMetadata,
144
+ clientId: this.clientId,
145
+ validationErrors: [
146
+ ...Value.Errors(this.handshakeExtensions.schema, rawMetadata)
147
+ ]
148
+ });
149
+ this.protocolError(ProtocolError.HandshakeFailed, reason);
150
+ return false;
151
+ }
152
+ const previousParsedMetadata = session ? this.sessionHandshakeMetadata.get(session) : void 0;
153
+ parsedMetadata = await this.handshakeExtensions.validate(
154
+ rawMetadata,
155
+ previousParsedMetadata
156
+ );
157
+ if (parsedMetadata === false) {
158
+ const reason = "rejected by handshake handler";
159
+ conn.telemetry?.span.setStatus({
160
+ code: SpanStatusCode.ERROR,
161
+ message: reason
162
+ });
163
+ const responseMsg = handshakeResponseMessage(this.clientId, from, {
164
+ ok: false,
165
+ reason
166
+ });
167
+ conn.send(this.codec.toBuffer(responseMsg));
168
+ this.log?.warn(`rejected handshake from ${from}`, {
169
+ ...conn.loggingMetadata,
170
+ clientId: this.clientId
171
+ });
172
+ this.protocolError(ProtocolError.HandshakeFailed, reason);
173
+ return false;
174
+ }
175
+ }
176
+ return parsedMetadata;
177
+ }
178
+ async receiveHandshakeRequestMessage(data, conn) {
179
+ const parsed = this.parseMsg(data, conn);
180
+ if (!parsed) {
181
+ conn.telemetry?.span.setStatus({
182
+ code: SpanStatusCode.ERROR,
183
+ message: "non-transport message"
184
+ });
185
+ this.protocolError(
186
+ ProtocolError.HandshakeFailed,
187
+ "received non-transport message"
188
+ );
189
+ return false;
190
+ }
191
+ if (!Value.Check(ControlMessageHandshakeRequestSchema, parsed.payload)) {
192
+ conn.telemetry?.span.setStatus({
193
+ code: SpanStatusCode.ERROR,
194
+ message: "invalid handshake request"
195
+ });
196
+ const reason = "received invalid handshake msg";
197
+ const responseMsg2 = handshakeResponseMessage(this.clientId, parsed.from, {
198
+ ok: false,
199
+ reason
200
+ });
201
+ conn.send(this.codec.toBuffer(responseMsg2));
202
+ this.log?.warn(reason, {
203
+ ...conn.loggingMetadata,
204
+ clientId: this.clientId,
205
+ // safe to this.log metadata here as we remove the payload
206
+ // before passing it to user-land
207
+ transportMessage: parsed,
208
+ validationErrors: [
209
+ ...Value.Errors(ControlMessageHandshakeRequestSchema, parsed.payload)
210
+ ]
211
+ });
212
+ this.protocolError(
213
+ ProtocolError.HandshakeFailed,
214
+ "invalid handshake request"
215
+ );
216
+ return false;
217
+ }
218
+ const gotVersion = parsed.payload.protocolVersion;
219
+ if (gotVersion !== PROTOCOL_VERSION) {
220
+ conn.telemetry?.span.setStatus({
221
+ code: SpanStatusCode.ERROR,
222
+ message: "incorrect protocol version"
223
+ });
224
+ const reason = `incorrect version (got: ${gotVersion} wanted ${PROTOCOL_VERSION})`;
225
+ const responseMsg2 = handshakeResponseMessage(this.clientId, parsed.from, {
226
+ ok: false,
227
+ reason
228
+ });
229
+ conn.send(this.codec.toBuffer(responseMsg2));
230
+ this.log?.warn(
231
+ `received handshake msg with incompatible protocol version (got: ${gotVersion}, expected: ${PROTOCOL_VERSION})`,
232
+ { ...conn.loggingMetadata, clientId: this.clientId }
233
+ );
234
+ this.protocolError(ProtocolError.HandshakeFailed, reason);
235
+ return false;
236
+ }
237
+ const oldSession = this.sessions.get(parsed.from);
238
+ const parsedMetadata = await this.validateHandshakeMetadata(
239
+ conn,
240
+ oldSession,
241
+ parsed.payload.metadata,
242
+ parsed.from
243
+ );
244
+ if (parsedMetadata === false) {
245
+ return false;
246
+ }
247
+ const { session, isTransparentReconnect } = this.getOrCreateSession({
248
+ to: parsed.from,
249
+ conn,
250
+ sessionId: parsed.payload.sessionId,
251
+ propagationCtx: parsed.tracing
252
+ });
253
+ this.sessionHandshakeMetadata.set(session, parsedMetadata);
254
+ this.log?.debug(
255
+ `handshake from ${parsed.from} ok, responding with handshake success`,
256
+ conn.loggingMetadata
257
+ );
258
+ const responseMsg = handshakeResponseMessage(this.clientId, parsed.from, {
259
+ ok: true,
260
+ sessionId: session.id
261
+ });
262
+ conn.send(this.codec.toBuffer(responseMsg));
263
+ this.onConnect(conn, session, isTransparentReconnect);
264
+ return session;
265
+ }
266
+ };
267
+
268
+ export {
269
+ ServerTransport
270
+ };
271
+ //# sourceMappingURL=chunk-ZUKDZY54.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../transport/server.ts"],"sourcesContent":["import { SpanStatusCode } from '@opentelemetry/api';\nimport { ParsedMetadata } from '../router/context';\nimport { ServerHandshakeOptions } from '../router/handshake';\nimport {\n ControlMessageHandshakeRequestSchema,\n PROTOCOL_VERSION,\n TransportClientId,\n handshakeResponseMessage,\n} from './message';\nimport {\n ProvidedServerTransportOptions,\n ServerTransportOptions,\n defaultServerTransportOptions,\n} from './options';\nimport { Connection, Session } from './session';\nimport { Transport } from './transport';\nimport { coerceErrorString } from '../util/stringify';\nimport { Static } from '@sinclair/typebox';\nimport { Value } from '@sinclair/typebox/value';\nimport { ProtocolError } from './events';\n\nexport abstract class ServerTransport<\n ConnType extends Connection,\n> extends Transport<ConnType> {\n /**\n * The options for this transport.\n */\n protected options: ServerTransportOptions;\n\n /**\n * Optional handshake options for the server.\n */\n handshakeExtensions?: ServerHandshakeOptions;\n\n /**\n * A map of session handshake data for each session.\n */\n sessionHandshakeMetadata: WeakMap<Session<ConnType>, ParsedMetadata>;\n\n constructor(\n clientId: TransportClientId,\n providedOptions?: ProvidedServerTransportOptions,\n ) {\n super(clientId, providedOptions);\n this.options = {\n ...defaultServerTransportOptions,\n ...providedOptions,\n };\n this.sessionHandshakeMetadata = new WeakMap();\n this.log?.info(`initiated server transport`, {\n clientId: this.clientId,\n protocolVersion: PROTOCOL_VERSION,\n });\n }\n\n extendHandshake(options: ServerHandshakeOptions) {\n this.handshakeExtensions = options;\n }\n\n protected handleConnection(conn: ConnType) {\n if (this.getStatus() !== 'open') return;\n\n this.log?.info(`new incoming connection`, {\n ...conn.loggingMetadata,\n clientId: this.clientId,\n });\n\n let session: Session<ConnType> | undefined = undefined;\n const client = () => session?.to ?? 'unknown';\n\n // kill the conn after the grace period if we haven't received a handshake\n const handshakeTimeout = setTimeout(() => {\n if (!session) {\n this.log?.warn(\n `connection to ${client()} timed out waiting for handshake, closing`,\n {\n ...conn.loggingMetadata,\n clientId: this.clientId,\n connectedTo: client(),\n },\n );\n conn.telemetry?.span.setStatus({\n code: SpanStatusCode.ERROR,\n message: 'handshake timeout',\n });\n conn.close();\n }\n }, this.options.sessionDisconnectGraceMs);\n\n const buffer: Array<Uint8Array> = [];\n let receivedHandshakeMessage = false;\n\n const handshakeHandler = (data: Uint8Array) => {\n // if we've already received, just buffer the data\n if (receivedHandshakeMessage) {\n buffer.push(data);\n return;\n }\n\n receivedHandshakeMessage = true;\n clearTimeout(handshakeTimeout);\n\n void this.receiveHandshakeRequestMessage(data, conn).then(\n (maybeSession) => {\n if (!maybeSession) {\n conn.close();\n return;\n }\n\n session = maybeSession;\n\n // when we are done handshake sequence,\n // remove handshake listener and use the normal message listener\n const dataHandler = (data: Uint8Array) => {\n const parsed = this.parseMsg(data, conn);\n if (!parsed) {\n conn.close();\n return;\n }\n\n this.handleMsg(parsed, conn);\n };\n\n // process any data we missed\n for (const data of buffer) {\n dataHandler(data);\n }\n\n conn.removeDataListener(handshakeHandler);\n conn.addDataListener(dataHandler);\n buffer.length = 0;\n },\n );\n };\n\n conn.addDataListener(handshakeHandler);\n conn.addCloseListener(() => {\n if (!session) return;\n this.log?.info(`connection to ${client()} disconnected`, {\n ...conn.loggingMetadata,\n clientId: this.clientId,\n });\n this.onDisconnect(conn, session);\n });\n\n conn.addErrorListener((err) => {\n conn.telemetry?.span.setStatus({\n code: SpanStatusCode.ERROR,\n message: 'connection error',\n });\n if (!session) return;\n this.log?.warn(\n `connection to ${client()} got an error: ${coerceErrorString(err)}`,\n { ...conn.loggingMetadata, clientId: this.clientId },\n );\n });\n }\n\n private async validateHandshakeMetadata(\n conn: ConnType,\n session: Session<ConnType> | undefined,\n rawMetadata: Static<\n typeof ControlMessageHandshakeRequestSchema\n >['metadata'],\n from: TransportClientId,\n ): Promise<ParsedMetadata | false> {\n let parsedMetadata: ParsedMetadata = {};\n if (this.handshakeExtensions) {\n // check that the metadata that was sent is the correct shape\n if (!Value.Check(this.handshakeExtensions.schema, rawMetadata)) {\n conn.telemetry?.span.setStatus({\n code: SpanStatusCode.ERROR,\n message: 'malformed handshake meta',\n });\n const reason = 'received malformed handshake metadata';\n const responseMsg = handshakeResponseMessage(this.clientId, from, {\n ok: false,\n reason,\n });\n conn.send(this.codec.toBuffer(responseMsg));\n this.log?.warn(`received malformed handshake metadata from ${from}`, {\n ...conn.loggingMetadata,\n clientId: this.clientId,\n validationErrors: [\n ...Value.Errors(this.handshakeExtensions.schema, rawMetadata),\n ],\n });\n this.protocolError(ProtocolError.HandshakeFailed, reason);\n return false;\n }\n\n const previousParsedMetadata = session\n ? this.sessionHandshakeMetadata.get(session)\n : undefined;\n\n parsedMetadata = await this.handshakeExtensions.validate(\n rawMetadata,\n previousParsedMetadata,\n );\n\n // handler rejected the connection\n if (parsedMetadata === false) {\n const reason = 'rejected by handshake handler';\n conn.telemetry?.span.setStatus({\n code: SpanStatusCode.ERROR,\n message: reason,\n });\n const responseMsg = handshakeResponseMessage(this.clientId, from, {\n ok: false,\n reason,\n });\n conn.send(this.codec.toBuffer(responseMsg));\n this.log?.warn(`rejected handshake from ${from}`, {\n ...conn.loggingMetadata,\n clientId: this.clientId,\n });\n this.protocolError(ProtocolError.HandshakeFailed, reason);\n return false;\n }\n }\n\n return parsedMetadata;\n }\n\n async receiveHandshakeRequestMessage(\n data: Uint8Array,\n conn: ConnType,\n ): Promise<Session<ConnType> | false> {\n const parsed = this.parseMsg(data, conn);\n if (!parsed) {\n conn.telemetry?.span.setStatus({\n code: SpanStatusCode.ERROR,\n message: 'non-transport message',\n });\n this.protocolError(\n ProtocolError.HandshakeFailed,\n 'received non-transport message',\n );\n return false;\n }\n\n if (!Value.Check(ControlMessageHandshakeRequestSchema, parsed.payload)) {\n conn.telemetry?.span.setStatus({\n code: SpanStatusCode.ERROR,\n message: 'invalid handshake request',\n });\n const reason = 'received invalid handshake msg';\n const responseMsg = handshakeResponseMessage(this.clientId, parsed.from, {\n ok: false,\n reason,\n });\n conn.send(this.codec.toBuffer(responseMsg));\n this.log?.warn(reason, {\n ...conn.loggingMetadata,\n clientId: this.clientId,\n // safe to this.log metadata here as we remove the payload\n // before passing it to user-land\n transportMessage: parsed,\n validationErrors: [\n ...Value.Errors(ControlMessageHandshakeRequestSchema, parsed.payload),\n ],\n });\n this.protocolError(\n ProtocolError.HandshakeFailed,\n 'invalid handshake request',\n );\n return false;\n }\n\n // double check protocol version here\n const gotVersion = parsed.payload.protocolVersion;\n if (gotVersion !== PROTOCOL_VERSION) {\n conn.telemetry?.span.setStatus({\n code: SpanStatusCode.ERROR,\n message: 'incorrect protocol version',\n });\n\n const reason = `incorrect version (got: ${gotVersion} wanted ${PROTOCOL_VERSION})`;\n const responseMsg = handshakeResponseMessage(this.clientId, parsed.from, {\n ok: false,\n reason,\n });\n conn.send(this.codec.toBuffer(responseMsg));\n this.log?.warn(\n `received handshake msg with incompatible protocol version (got: ${gotVersion}, expected: ${PROTOCOL_VERSION})`,\n { ...conn.loggingMetadata, clientId: this.clientId },\n );\n this.protocolError(ProtocolError.HandshakeFailed, reason);\n return false;\n }\n\n const oldSession = this.sessions.get(parsed.from);\n const parsedMetadata = await this.validateHandshakeMetadata(\n conn,\n oldSession,\n parsed.payload.metadata,\n parsed.from,\n );\n\n if (parsedMetadata === false) {\n return false;\n }\n\n const { session, isTransparentReconnect } = this.getOrCreateSession({\n to: parsed.from,\n conn,\n sessionId: parsed.payload.sessionId,\n propagationCtx: parsed.tracing,\n });\n\n this.sessionHandshakeMetadata.set(session, parsedMetadata);\n\n this.log?.debug(\n `handshake from ${parsed.from} ok, responding with handshake success`,\n conn.loggingMetadata,\n );\n const responseMsg = handshakeResponseMessage(this.clientId, parsed.from, {\n ok: true,\n sessionId: session.id,\n });\n conn.send(this.codec.toBuffer(responseMsg));\n this.onConnect(conn, session, isTransparentReconnect);\n\n return session;\n }\n}\n"],"mappings":"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","names":["data","responseMsg"]}
@@ -0,0 +1,52 @@
1
+ import { C as Connection, T as Transport, j as ClientTransportOptions, L as LeakyBucketRateLimit, k as ClientHandshakeOptions, b as ProvidedClientTransportOptions, S as Session } from './handshake-e428d1c8.js';
2
+ import { c as TransportClientId } from './index-ea74cdbb.js';
3
+
4
+ declare abstract class ClientTransport<ConnType extends Connection> extends Transport<ConnType> {
5
+ /**
6
+ * The options for this transport.
7
+ */
8
+ protected options: ClientTransportOptions;
9
+ /**
10
+ * The map of reconnect promises for each client ID.
11
+ */
12
+ inflightConnectionPromises: Map<TransportClientId, Promise<ConnType>>;
13
+ retryBudget: LeakyBucketRateLimit;
14
+ /**
15
+ * A flag indicating whether the transport should automatically reconnect
16
+ * when a connection is dropped.
17
+ * Realistically, this should always be true for clients unless you are writing
18
+ * tests or a special case where you don't want to reconnect.
19
+ */
20
+ reconnectOnConnectionDrop: boolean;
21
+ /**
22
+ * Optional handshake options for this client.
23
+ */
24
+ handshakeExtensions?: ClientHandshakeOptions;
25
+ constructor(clientId: TransportClientId, providedOptions?: ProvidedClientTransportOptions);
26
+ extendHandshake(options: ClientHandshakeOptions): void;
27
+ protected handleConnection(conn: ConnType, to: TransportClientId): void;
28
+ receiveHandshakeResponseMessage(data: Uint8Array, conn: ConnType): Session<ConnType> | false;
29
+ /**
30
+ * Abstract method that creates a new {@link Connection} object.
31
+ * This should call {@link handleConnection} when the connection is created.
32
+ * The downstream client implementation needs to implement this.
33
+ *
34
+ * @param to The client ID of the node to connect to.
35
+ * @returns The new connection object.
36
+ */
37
+ protected abstract createNewOutgoingConnection(to: TransportClientId): Promise<ConnType>;
38
+ /**
39
+ * Manually attempts to connect to a client.
40
+ * @param to The client ID of the node to connect to.
41
+ */
42
+ connect(to: TransportClientId): Promise<void>;
43
+ protected deleteSession({ session, closeHandshakingConnection, handshakingConn, }: {
44
+ session: Session<ConnType>;
45
+ closeHandshakingConnection: boolean;
46
+ handshakingConn?: ConnType;
47
+ }): void;
48
+ protected sendHandshake(to: TransportClientId, conn: ConnType): Promise<boolean>;
49
+ close(): void;
50
+ }
51
+
52
+ export { ClientTransport as C };
@@ -1,7 +1,25 @@
1
1
  import {
2
- BinaryCodec,
3
2
  NaiveJsonCodec
4
- } from "../chunk-3AW3IXVD.js";
3
+ } from "../chunk-4PVU7J25.js";
4
+
5
+ // codec/binary.ts
6
+ import { decode, encode } from "@msgpack/msgpack";
7
+ var BinaryCodec = {
8
+ toBuffer(obj) {
9
+ return encode(obj, { ignoreUndefined: true });
10
+ },
11
+ fromBuffer: (buff) => {
12
+ try {
13
+ const res = decode(buff);
14
+ if (typeof res !== "object") {
15
+ return null;
16
+ }
17
+ return res;
18
+ } catch {
19
+ return null;
20
+ }
21
+ }
22
+ };
5
23
  export {
6
24
  BinaryCodec,
7
25
  NaiveJsonCodec
@@ -1 +1 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
1
+ {"version":3,"sources":["../../codec/binary.ts"],"sourcesContent":["import { decode, encode } from '@msgpack/msgpack';\nimport { Codec } from './types';\n\n/**\n * Binary codec, uses [msgpack](https://www.npmjs.com/package/@msgpack/msgpack) under the hood\n * @type {Codec}\n */\nexport const BinaryCodec: Codec = {\n toBuffer(obj) {\n return encode(obj, { ignoreUndefined: true });\n },\n fromBuffer: (buff: Uint8Array) => {\n try {\n const res = decode(buff);\n if (typeof res !== 'object') {\n return null;\n }\n\n return res;\n } catch {\n return null;\n }\n },\n};\n"],"mappings":";;;;;AAAA,SAAS,QAAQ,cAAc;AAOxB,IAAM,cAAqB;AAAA,EAChC,SAAS,KAAK;AACZ,WAAO,OAAO,KAAK,EAAE,iBAAiB,KAAK,CAAC;AAAA,EAC9C;AAAA,EACA,YAAY,CAAC,SAAqB;AAChC,QAAI;AACF,YAAM,MAAM,OAAO,IAAI;AACvB,UAAI,OAAO,QAAQ,UAAU;AAC3B,eAAO;AAAA,MACT;AAEA,aAAO;AAAA,IACT,QAAQ;AACN,aAAO;AAAA,IACT;AAAA,EACF;AACF;","names":[]}
@@ -1,4 +1,4 @@
1
- import { C as Connection } from './transport-c8f36f6d.js';
1
+ import { C as Connection } from './handshake-e428d1c8.js';
2
2
  import { W as WsLike } from './wslike-e0b32dd5.js';
3
3
 
4
4
  declare class WebSocketConnection extends Connection {
@@ -1,4 +1,4 @@
1
- import { C as Connection } from './transport-c8f36f6d.js';
1
+ import { C as Connection } from './handshake-e428d1c8.js';
2
2
  import { Socket } from 'node:net';
3
3
  import stream, { Transform, TransformCallback, TransformOptions } from 'node:stream';
4
4