crossws 0.2.3 → 0.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (66) hide show
  1. package/README.md +8 -9
  2. package/adapters/cloudflare-durable.d.ts +2 -0
  3. package/adapters/sse.d.ts +2 -0
  4. package/dist/adapters/bun.d.mts +25 -6
  5. package/dist/adapters/bun.d.ts +25 -6
  6. package/dist/adapters/bun.mjs +54 -62
  7. package/dist/adapters/cloudflare-durable.d.mts +20 -0
  8. package/dist/adapters/cloudflare-durable.d.ts +20 -0
  9. package/dist/adapters/cloudflare-durable.mjs +132 -0
  10. package/dist/adapters/cloudflare.d.mts +5 -5
  11. package/dist/adapters/cloudflare.d.ts +5 -5
  12. package/dist/adapters/cloudflare.mjs +56 -49
  13. package/dist/adapters/deno.d.mts +10 -3
  14. package/dist/adapters/deno.d.ts +10 -3
  15. package/dist/adapters/deno.mjs +54 -45
  16. package/dist/adapters/node.d.mts +4 -2
  17. package/dist/adapters/node.d.ts +4 -2
  18. package/dist/adapters/node.mjs +108 -71
  19. package/dist/adapters/sse.d.mts +12 -0
  20. package/dist/adapters/sse.d.ts +12 -0
  21. package/dist/adapters/sse.mjs +120 -0
  22. package/dist/adapters/uws.d.mts +45 -9
  23. package/dist/adapters/uws.d.ts +45 -9
  24. package/dist/adapters/uws.mjs +148 -124
  25. package/dist/index.d.mts +136 -4
  26. package/dist/index.d.ts +136 -4
  27. package/dist/index.mjs +1 -10
  28. package/dist/shared/crossws.B4sHId41.mjs +42 -0
  29. package/dist/shared/crossws.By9qWDAI.mjs +8 -0
  30. package/dist/shared/crossws.ChIJSJVK.d.mts +297 -0
  31. package/dist/shared/crossws.ChIJSJVK.d.ts +297 -0
  32. package/dist/shared/crossws.DTY7a69w.mjs +315 -0
  33. package/dist/shared/{crossws.a5db571c.mjs → crossws.YgHWLi0G.mjs} +284 -115
  34. package/dist/websocket/{index.d.mts → native.d.mts} +1 -1
  35. package/dist/websocket/{node.d.cts → native.d.ts} +1 -1
  36. package/dist/websocket/native.mjs +3 -0
  37. package/dist/websocket/node.d.mts +1 -1
  38. package/dist/websocket/node.d.ts +1 -1
  39. package/dist/websocket/node.mjs +1 -1
  40. package/dist/websocket/sse.d.mts +41 -0
  41. package/dist/websocket/sse.d.ts +41 -0
  42. package/dist/websocket/sse.mjs +127 -0
  43. package/package.json +78 -75
  44. package/dist/adapters/bun.cjs +0 -95
  45. package/dist/adapters/bun.d.cts +0 -17
  46. package/dist/adapters/cloudflare.cjs +0 -65
  47. package/dist/adapters/cloudflare.d.cts +0 -12
  48. package/dist/adapters/deno.cjs +0 -63
  49. package/dist/adapters/deno.d.cts +0 -15
  50. package/dist/adapters/node.cjs +0 -726
  51. package/dist/adapters/node.d.cts +0 -298
  52. package/dist/adapters/uws.cjs +0 -153
  53. package/dist/adapters/uws.d.cts +0 -19
  54. package/dist/index.cjs +0 -17
  55. package/dist/index.d.cts +0 -6
  56. package/dist/shared/crossws.2ed26345.cjs +0 -3931
  57. package/dist/shared/crossws.34cfc8d0.mjs +0 -139
  58. package/dist/shared/crossws.a2e5c71e.d.cts +0 -112
  59. package/dist/shared/crossws.a2e5c71e.d.mts +0 -112
  60. package/dist/shared/crossws.a2e5c71e.d.ts +0 -112
  61. package/dist/shared/crossws.c13afbe7.cjs +0 -146
  62. package/dist/websocket/index.cjs +0 -5
  63. package/dist/websocket/index.d.cts +0 -10
  64. package/dist/websocket/index.d.ts +0 -10
  65. package/dist/websocket/index.mjs +0 -3
  66. package/dist/websocket/node.cjs +0 -17
@@ -1,726 +0,0 @@
1
- 'use strict';
2
-
3
- require('stream');
4
- const websocket = require('../shared/crossws.2ed26345.cjs');
5
- const require$$0 = require('events');
6
- const require$$2 = require('http');
7
- const require$$1 = require('crypto');
8
- const types = require('../shared/crossws.c13afbe7.cjs');
9
- const index = require('../index.cjs');
10
- require('https');
11
- require('net');
12
- require('tls');
13
- require('url');
14
- require('zlib');
15
- require('buffer');
16
-
17
- function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e.default : e; }
18
-
19
- const require$$0__default = /*#__PURE__*/_interopDefaultCompat(require$$0);
20
- const require$$2__default = /*#__PURE__*/_interopDefaultCompat(require$$2);
21
- const require$$1__default = /*#__PURE__*/_interopDefaultCompat(require$$1);
22
-
23
- const { tokenChars } = websocket.validationExports;
24
-
25
- /**
26
- * Parses the `Sec-WebSocket-Protocol` header into a set of subprotocol names.
27
- *
28
- * @param {String} header The field value of the header
29
- * @return {Set} The subprotocol names
30
- * @public
31
- */
32
- function parse(header) {
33
- const protocols = new Set();
34
- let start = -1;
35
- let end = -1;
36
- let i = 0;
37
-
38
- for (i; i < header.length; i++) {
39
- const code = header.charCodeAt(i);
40
-
41
- if (end === -1 && tokenChars[code] === 1) {
42
- if (start === -1) start = i;
43
- } else if (
44
- i !== 0 &&
45
- (code === 0x20 /* ' ' */ || code === 0x09) /* '\t' */
46
- ) {
47
- if (end === -1 && start !== -1) end = i;
48
- } else if (code === 0x2c /* ',' */) {
49
- if (start === -1) {
50
- throw new SyntaxError(`Unexpected character at index ${i}`);
51
- }
52
-
53
- if (end === -1) end = i;
54
-
55
- const protocol = header.slice(start, end);
56
-
57
- if (protocols.has(protocol)) {
58
- throw new SyntaxError(`The "${protocol}" subprotocol is duplicated`);
59
- }
60
-
61
- protocols.add(protocol);
62
- start = end = -1;
63
- } else {
64
- throw new SyntaxError(`Unexpected character at index ${i}`);
65
- }
66
- }
67
-
68
- if (start === -1 || end !== -1) {
69
- throw new SyntaxError('Unexpected end of input');
70
- }
71
-
72
- const protocol = header.slice(start, i);
73
-
74
- if (protocols.has(protocol)) {
75
- throw new SyntaxError(`The "${protocol}" subprotocol is duplicated`);
76
- }
77
-
78
- protocols.add(protocol);
79
- return protocols;
80
- }
81
-
82
- var subprotocol$1 = { parse };
83
-
84
- /* eslint no-unused-vars: ["error", { "varsIgnorePattern": "^Duplex$" }] */
85
-
86
- const EventEmitter = require$$0__default;
87
- const http = require$$2__default;
88
- const { createHash } = require$$1__default;
89
-
90
- const extension = websocket.extension;
91
- const PerMessageDeflate = websocket.permessageDeflate;
92
- const subprotocol = subprotocol$1;
93
- const WebSocket = websocket.websocket;
94
- const { GUID, kWebSocket } = websocket.constants;
95
-
96
- const keyRegex = /^[+/0-9A-Za-z]{22}==$/;
97
-
98
- const RUNNING = 0;
99
- const CLOSING = 1;
100
- const CLOSED = 2;
101
-
102
- /**
103
- * Class representing a WebSocket server.
104
- *
105
- * @extends EventEmitter
106
- */
107
- class WebSocketServer extends EventEmitter {
108
- /**
109
- * Create a `WebSocketServer` instance.
110
- *
111
- * @param {Object} options Configuration options
112
- * @param {Boolean} [options.allowSynchronousEvents=false] Specifies whether
113
- * any of the `'message'`, `'ping'`, and `'pong'` events can be emitted
114
- * multiple times in the same tick
115
- * @param {Boolean} [options.autoPong=true] Specifies whether or not to
116
- * automatically send a pong in response to a ping
117
- * @param {Number} [options.backlog=511] The maximum length of the queue of
118
- * pending connections
119
- * @param {Boolean} [options.clientTracking=true] Specifies whether or not to
120
- * track clients
121
- * @param {Function} [options.handleProtocols] A hook to handle protocols
122
- * @param {String} [options.host] The hostname where to bind the server
123
- * @param {Number} [options.maxPayload=104857600] The maximum allowed message
124
- * size
125
- * @param {Boolean} [options.noServer=false] Enable no server mode
126
- * @param {String} [options.path] Accept only connections matching this path
127
- * @param {(Boolean|Object)} [options.perMessageDeflate=false] Enable/disable
128
- * permessage-deflate
129
- * @param {Number} [options.port] The port where to bind the server
130
- * @param {(http.Server|https.Server)} [options.server] A pre-created HTTP/S
131
- * server to use
132
- * @param {Boolean} [options.skipUTF8Validation=false] Specifies whether or
133
- * not to skip UTF-8 validation for text and close messages
134
- * @param {Function} [options.verifyClient] A hook to reject connections
135
- * @param {Function} [options.WebSocket=WebSocket] Specifies the `WebSocket`
136
- * class to use. It must be the `WebSocket` class or class that extends it
137
- * @param {Function} [callback] A listener for the `listening` event
138
- */
139
- constructor(options, callback) {
140
- super();
141
-
142
- options = {
143
- allowSynchronousEvents: false,
144
- autoPong: true,
145
- maxPayload: 100 * 1024 * 1024,
146
- skipUTF8Validation: false,
147
- perMessageDeflate: false,
148
- handleProtocols: null,
149
- clientTracking: true,
150
- verifyClient: null,
151
- noServer: false,
152
- backlog: null, // use default (511 as implemented in net.js)
153
- server: null,
154
- host: null,
155
- path: null,
156
- port: null,
157
- WebSocket,
158
- ...options
159
- };
160
-
161
- if (
162
- (options.port == null && !options.server && !options.noServer) ||
163
- (options.port != null && (options.server || options.noServer)) ||
164
- (options.server && options.noServer)
165
- ) {
166
- throw new TypeError(
167
- 'One and only one of the "port", "server", or "noServer" options ' +
168
- 'must be specified'
169
- );
170
- }
171
-
172
- if (options.port != null) {
173
- this._server = http.createServer((req, res) => {
174
- const body = http.STATUS_CODES[426];
175
-
176
- res.writeHead(426, {
177
- 'Content-Length': body.length,
178
- 'Content-Type': 'text/plain'
179
- });
180
- res.end(body);
181
- });
182
- this._server.listen(
183
- options.port,
184
- options.host,
185
- options.backlog,
186
- callback
187
- );
188
- } else if (options.server) {
189
- this._server = options.server;
190
- }
191
-
192
- if (this._server) {
193
- const emitConnection = this.emit.bind(this, 'connection');
194
-
195
- this._removeListeners = addListeners(this._server, {
196
- listening: this.emit.bind(this, 'listening'),
197
- error: this.emit.bind(this, 'error'),
198
- upgrade: (req, socket, head) => {
199
- this.handleUpgrade(req, socket, head, emitConnection);
200
- }
201
- });
202
- }
203
-
204
- if (options.perMessageDeflate === true) options.perMessageDeflate = {};
205
- if (options.clientTracking) {
206
- this.clients = new Set();
207
- this._shouldEmitClose = false;
208
- }
209
-
210
- this.options = options;
211
- this._state = RUNNING;
212
- }
213
-
214
- /**
215
- * Returns the bound address, the address family name, and port of the server
216
- * as reported by the operating system if listening on an IP socket.
217
- * If the server is listening on a pipe or UNIX domain socket, the name is
218
- * returned as a string.
219
- *
220
- * @return {(Object|String|null)} The address of the server
221
- * @public
222
- */
223
- address() {
224
- if (this.options.noServer) {
225
- throw new Error('The server is operating in "noServer" mode');
226
- }
227
-
228
- if (!this._server) return null;
229
- return this._server.address();
230
- }
231
-
232
- /**
233
- * Stop the server from accepting new connections and emit the `'close'` event
234
- * when all existing connections are closed.
235
- *
236
- * @param {Function} [cb] A one-time listener for the `'close'` event
237
- * @public
238
- */
239
- close(cb) {
240
- if (this._state === CLOSED) {
241
- if (cb) {
242
- this.once('close', () => {
243
- cb(new Error('The server is not running'));
244
- });
245
- }
246
-
247
- process.nextTick(emitClose, this);
248
- return;
249
- }
250
-
251
- if (cb) this.once('close', cb);
252
-
253
- if (this._state === CLOSING) return;
254
- this._state = CLOSING;
255
-
256
- if (this.options.noServer || this.options.server) {
257
- if (this._server) {
258
- this._removeListeners();
259
- this._removeListeners = this._server = null;
260
- }
261
-
262
- if (this.clients) {
263
- if (!this.clients.size) {
264
- process.nextTick(emitClose, this);
265
- } else {
266
- this._shouldEmitClose = true;
267
- }
268
- } else {
269
- process.nextTick(emitClose, this);
270
- }
271
- } else {
272
- const server = this._server;
273
-
274
- this._removeListeners();
275
- this._removeListeners = this._server = null;
276
-
277
- //
278
- // The HTTP/S server was created internally. Close it, and rely on its
279
- // `'close'` event.
280
- //
281
- server.close(() => {
282
- emitClose(this);
283
- });
284
- }
285
- }
286
-
287
- /**
288
- * See if a given request should be handled by this server instance.
289
- *
290
- * @param {http.IncomingMessage} req Request object to inspect
291
- * @return {Boolean} `true` if the request is valid, else `false`
292
- * @public
293
- */
294
- shouldHandle(req) {
295
- if (this.options.path) {
296
- const index = req.url.indexOf('?');
297
- const pathname = index !== -1 ? req.url.slice(0, index) : req.url;
298
-
299
- if (pathname !== this.options.path) return false;
300
- }
301
-
302
- return true;
303
- }
304
-
305
- /**
306
- * Handle a HTTP Upgrade request.
307
- *
308
- * @param {http.IncomingMessage} req The request object
309
- * @param {Duplex} socket The network socket between the server and client
310
- * @param {Buffer} head The first packet of the upgraded stream
311
- * @param {Function} cb Callback
312
- * @public
313
- */
314
- handleUpgrade(req, socket, head, cb) {
315
- socket.on('error', socketOnError);
316
-
317
- const key = req.headers['sec-websocket-key'];
318
- const version = +req.headers['sec-websocket-version'];
319
-
320
- if (req.method !== 'GET') {
321
- const message = 'Invalid HTTP method';
322
- abortHandshakeOrEmitwsClientError(this, req, socket, 405, message);
323
- return;
324
- }
325
-
326
- if (req.headers.upgrade.toLowerCase() !== 'websocket') {
327
- const message = 'Invalid Upgrade header';
328
- abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
329
- return;
330
- }
331
-
332
- if (!key || !keyRegex.test(key)) {
333
- const message = 'Missing or invalid Sec-WebSocket-Key header';
334
- abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
335
- return;
336
- }
337
-
338
- if (version !== 8 && version !== 13) {
339
- const message = 'Missing or invalid Sec-WebSocket-Version header';
340
- abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
341
- return;
342
- }
343
-
344
- if (!this.shouldHandle(req)) {
345
- abortHandshake(socket, 400);
346
- return;
347
- }
348
-
349
- const secWebSocketProtocol = req.headers['sec-websocket-protocol'];
350
- let protocols = new Set();
351
-
352
- if (secWebSocketProtocol !== undefined) {
353
- try {
354
- protocols = subprotocol.parse(secWebSocketProtocol);
355
- } catch (err) {
356
- const message = 'Invalid Sec-WebSocket-Protocol header';
357
- abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
358
- return;
359
- }
360
- }
361
-
362
- const secWebSocketExtensions = req.headers['sec-websocket-extensions'];
363
- const extensions = {};
364
-
365
- if (
366
- this.options.perMessageDeflate &&
367
- secWebSocketExtensions !== undefined
368
- ) {
369
- const perMessageDeflate = new PerMessageDeflate(
370
- this.options.perMessageDeflate,
371
- true,
372
- this.options.maxPayload
373
- );
374
-
375
- try {
376
- const offers = extension.parse(secWebSocketExtensions);
377
-
378
- if (offers[PerMessageDeflate.extensionName]) {
379
- perMessageDeflate.accept(offers[PerMessageDeflate.extensionName]);
380
- extensions[PerMessageDeflate.extensionName] = perMessageDeflate;
381
- }
382
- } catch (err) {
383
- const message =
384
- 'Invalid or unacceptable Sec-WebSocket-Extensions header';
385
- abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
386
- return;
387
- }
388
- }
389
-
390
- //
391
- // Optionally call external client verification handler.
392
- //
393
- if (this.options.verifyClient) {
394
- const info = {
395
- origin:
396
- req.headers[`${version === 8 ? 'sec-websocket-origin' : 'origin'}`],
397
- secure: !!(req.socket.authorized || req.socket.encrypted),
398
- req
399
- };
400
-
401
- if (this.options.verifyClient.length === 2) {
402
- this.options.verifyClient(info, (verified, code, message, headers) => {
403
- if (!verified) {
404
- return abortHandshake(socket, code || 401, message, headers);
405
- }
406
-
407
- this.completeUpgrade(
408
- extensions,
409
- key,
410
- protocols,
411
- req,
412
- socket,
413
- head,
414
- cb
415
- );
416
- });
417
- return;
418
- }
419
-
420
- if (!this.options.verifyClient(info)) return abortHandshake(socket, 401);
421
- }
422
-
423
- this.completeUpgrade(extensions, key, protocols, req, socket, head, cb);
424
- }
425
-
426
- /**
427
- * Upgrade the connection to WebSocket.
428
- *
429
- * @param {Object} extensions The accepted extensions
430
- * @param {String} key The value of the `Sec-WebSocket-Key` header
431
- * @param {Set} protocols The subprotocols
432
- * @param {http.IncomingMessage} req The request object
433
- * @param {Duplex} socket The network socket between the server and client
434
- * @param {Buffer} head The first packet of the upgraded stream
435
- * @param {Function} cb Callback
436
- * @throws {Error} If called more than once with the same socket
437
- * @private
438
- */
439
- completeUpgrade(extensions, key, protocols, req, socket, head, cb) {
440
- //
441
- // Destroy the socket if the client has already sent a FIN packet.
442
- //
443
- if (!socket.readable || !socket.writable) return socket.destroy();
444
-
445
- if (socket[kWebSocket]) {
446
- throw new Error(
447
- 'server.handleUpgrade() was called more than once with the same ' +
448
- 'socket, possibly due to a misconfiguration'
449
- );
450
- }
451
-
452
- if (this._state > RUNNING) return abortHandshake(socket, 503);
453
-
454
- const digest = createHash('sha1')
455
- .update(key + GUID)
456
- .digest('base64');
457
-
458
- const headers = [
459
- 'HTTP/1.1 101 Switching Protocols',
460
- 'Upgrade: websocket',
461
- 'Connection: Upgrade',
462
- `Sec-WebSocket-Accept: ${digest}`
463
- ];
464
-
465
- const ws = new this.options.WebSocket(null, undefined, this.options);
466
-
467
- if (protocols.size) {
468
- //
469
- // Optionally call external protocol selection handler.
470
- //
471
- const protocol = this.options.handleProtocols
472
- ? this.options.handleProtocols(protocols, req)
473
- : protocols.values().next().value;
474
-
475
- if (protocol) {
476
- headers.push(`Sec-WebSocket-Protocol: ${protocol}`);
477
- ws._protocol = protocol;
478
- }
479
- }
480
-
481
- if (extensions[PerMessageDeflate.extensionName]) {
482
- const params = extensions[PerMessageDeflate.extensionName].params;
483
- const value = extension.format({
484
- [PerMessageDeflate.extensionName]: [params]
485
- });
486
- headers.push(`Sec-WebSocket-Extensions: ${value}`);
487
- ws._extensions = extensions;
488
- }
489
-
490
- //
491
- // Allow external modification/inspection of handshake headers.
492
- //
493
- this.emit('headers', headers, req);
494
-
495
- socket.write(headers.concat('\r\n').join('\r\n'));
496
- socket.removeListener('error', socketOnError);
497
-
498
- ws.setSocket(socket, head, {
499
- allowSynchronousEvents: this.options.allowSynchronousEvents,
500
- maxPayload: this.options.maxPayload,
501
- skipUTF8Validation: this.options.skipUTF8Validation
502
- });
503
-
504
- if (this.clients) {
505
- this.clients.add(ws);
506
- ws.on('close', () => {
507
- this.clients.delete(ws);
508
-
509
- if (this._shouldEmitClose && !this.clients.size) {
510
- process.nextTick(emitClose, this);
511
- }
512
- });
513
- }
514
-
515
- cb(ws, req);
516
- }
517
- }
518
-
519
- var websocketServer = WebSocketServer;
520
-
521
- /**
522
- * Add event listeners on an `EventEmitter` using a map of <event, listener>
523
- * pairs.
524
- *
525
- * @param {EventEmitter} server The event emitter
526
- * @param {Object.<String, Function>} map The listeners to add
527
- * @return {Function} A function that will remove the added listeners when
528
- * called
529
- * @private
530
- */
531
- function addListeners(server, map) {
532
- for (const event of Object.keys(map)) server.on(event, map[event]);
533
-
534
- return function removeListeners() {
535
- for (const event of Object.keys(map)) {
536
- server.removeListener(event, map[event]);
537
- }
538
- };
539
- }
540
-
541
- /**
542
- * Emit a `'close'` event on an `EventEmitter`.
543
- *
544
- * @param {EventEmitter} server The event emitter
545
- * @private
546
- */
547
- function emitClose(server) {
548
- server._state = CLOSED;
549
- server.emit('close');
550
- }
551
-
552
- /**
553
- * Handle socket errors.
554
- *
555
- * @private
556
- */
557
- function socketOnError() {
558
- this.destroy();
559
- }
560
-
561
- /**
562
- * Close the connection when preconditions are not fulfilled.
563
- *
564
- * @param {Duplex} socket The socket of the upgrade request
565
- * @param {Number} code The HTTP response status code
566
- * @param {String} [message] The HTTP response body
567
- * @param {Object} [headers] Additional HTTP response headers
568
- * @private
569
- */
570
- function abortHandshake(socket, code, message, headers) {
571
- //
572
- // The socket is writable unless the user destroyed or ended it before calling
573
- // `server.handleUpgrade()` or in the `verifyClient` function, which is a user
574
- // error. Handling this does not make much sense as the worst that can happen
575
- // is that some of the data written by the user might be discarded due to the
576
- // call to `socket.end()` below, which triggers an `'error'` event that in
577
- // turn causes the socket to be destroyed.
578
- //
579
- message = message || http.STATUS_CODES[code];
580
- headers = {
581
- Connection: 'close',
582
- 'Content-Type': 'text/html',
583
- 'Content-Length': Buffer.byteLength(message),
584
- ...headers
585
- };
586
-
587
- socket.once('finish', socket.destroy);
588
-
589
- socket.end(
590
- `HTTP/1.1 ${code} ${http.STATUS_CODES[code]}\r\n` +
591
- Object.keys(headers)
592
- .map((h) => `${h}: ${headers[h]}`)
593
- .join('\r\n') +
594
- '\r\n\r\n' +
595
- message
596
- );
597
- }
598
-
599
- /**
600
- * Emit a `'wsClientError'` event on a `WebSocketServer` if there is at least
601
- * one listener for it, otherwise call `abortHandshake()`.
602
- *
603
- * @param {WebSocketServer} server The WebSocket server
604
- * @param {http.IncomingMessage} req The request object
605
- * @param {Duplex} socket The socket of the upgrade request
606
- * @param {Number} code The HTTP response status code
607
- * @param {String} message The HTTP response body
608
- * @private
609
- */
610
- function abortHandshakeOrEmitwsClientError(server, req, socket, code, message) {
611
- if (server.listenerCount('wsClientError')) {
612
- const err = new Error(message);
613
- Error.captureStackTrace(err, abortHandshakeOrEmitwsClientError);
614
-
615
- server.emit('wsClientError', err, socket, req);
616
- } else {
617
- abortHandshake(socket, code, message);
618
- }
619
- }
620
-
621
- const _WebSocketServer = /*@__PURE__*/websocket.getDefaultExportFromCjs(websocketServer);
622
-
623
- const node = types.defineWebSocketAdapter(
624
- (options = {}) => {
625
- const crossws = types.createCrossWS(options);
626
- const wss = options.wss || new _WebSocketServer({
627
- noServer: true,
628
- ...options.serverOptions
629
- });
630
- wss.on("connection", (ws, req) => {
631
- const peer = new NodePeer({ node: { ws, req, server: wss } });
632
- crossws.callHook("open", peer);
633
- ws.on("message", (data, isBinary) => {
634
- crossws.$callHook("node:message", peer, data, isBinary);
635
- if (Array.isArray(data)) {
636
- data = Buffer.concat(data);
637
- }
638
- crossws.callHook("message", peer, new types.Message(data, isBinary));
639
- });
640
- ws.on("error", (error) => {
641
- crossws.$callHook("node:error", peer, error);
642
- crossws.callHook("error", peer, new index.WSError(error));
643
- });
644
- ws.on("close", (code, reason) => {
645
- crossws.$callHook("node:close", peer, code, reason);
646
- crossws.callHook("close", peer, {
647
- code,
648
- reason: reason?.toString()
649
- });
650
- });
651
- ws.on("open", () => {
652
- crossws.$callHook("node:open", peer);
653
- });
654
- ws.on("ping", (data) => {
655
- crossws.$callHook("node:ping", peer, data);
656
- });
657
- ws.on("pong", (data) => {
658
- crossws.$callHook("node:pong", peer, data);
659
- });
660
- ws.on(
661
- "unexpected-response",
662
- (req2, res) => {
663
- crossws.$callHook("node:unexpected-response", peer, req2, res);
664
- }
665
- );
666
- ws.on("upgrade", (req2) => {
667
- crossws.$callHook("node:upgrade", peer, req2);
668
- });
669
- });
670
- wss.on("headers", function(outgoingHeaders, req) {
671
- const upgradeHeaders = req._upgradeHeaders;
672
- if (upgradeHeaders) {
673
- const _headers = new Headers(upgradeHeaders);
674
- for (const [key, value] of _headers) {
675
- outgoingHeaders.push(`${key}: ${value}`);
676
- }
677
- }
678
- });
679
- return {
680
- handleUpgrade: async (req, socket, head) => {
681
- const { headers } = await crossws.upgrade({
682
- url: req.url || "",
683
- headers: req.headers
684
- });
685
- req._upgradeHeaders = headers;
686
- wss.handleUpgrade(req, socket, head, (ws) => {
687
- wss.emit("connection", ws, req);
688
- });
689
- }
690
- };
691
- }
692
- );
693
- class NodePeer extends types.Peer {
694
- get id() {
695
- const socket = this.ctx.node.req.socket;
696
- if (!socket) {
697
- return void 0;
698
- }
699
- const headers = this.ctx.node.req.headers;
700
- let addr = headers["x-forwarded-for"] || socket.remoteAddress || "??";
701
- if (addr.includes(":")) {
702
- addr = `[${addr}]`;
703
- }
704
- const port = headers["x-forwarded-port"] || socket.remotePort || "??";
705
- return `${addr}:${port}`;
706
- }
707
- get url() {
708
- return this.ctx.node.req.url || "/";
709
- }
710
- get headers() {
711
- return this.ctx.node.req.headers;
712
- }
713
- get readyState() {
714
- return this.ctx.node.ws.readyState;
715
- }
716
- send(message, options) {
717
- this.ctx.node.ws.send(types.toBufferLike(message), {
718
- compress: options?.compress,
719
- binary: options?.binary,
720
- ...options
721
- });
722
- return 0;
723
- }
724
- }
725
-
726
- module.exports = node;