@duckmind/dm-darwin-x64 0.32.9 → 0.33.1

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 (95) hide show
  1. package/dm +0 -0
  2. package/extensions/.dm-extensions.json +14 -65
  3. package/extensions/dm-9router-ext/README.md +142 -0
  4. package/extensions/dm-9router-ext/package.json +45 -0
  5. package/extensions/dm-9router-ext/src/index.ts +541 -0
  6. package/extensions/dm-9router-ext/tsconfig.json +17 -0
  7. package/extensions/dm-subagents/package-lock.json +3 -3
  8. package/extensions/dm-tasks/node_modules/.package-lock.json +3 -3
  9. package/extensions/dm-tasks/node_modules/typebox/build/type/script/mapping.d.mts +2 -2
  10. package/extensions/dm-tasks/node_modules/typebox/build/type/script/parser.d.mts +2 -2
  11. package/extensions/dm-tasks/node_modules/typebox/build/type/script/parser.mjs +2 -2
  12. package/extensions/dm-tasks/node_modules/typebox/build/type/types/number.d.mts +1 -1
  13. package/extensions/dm-tasks/node_modules/typebox/build/type/types/number.mjs +1 -1
  14. package/extensions/dm-tasks/node_modules/typebox/build/type/types/record.d.mts +1 -1
  15. package/extensions/dm-tasks/node_modules/typebox/package.json +1 -1
  16. package/extensions/dm-tasks/package-lock.json +3 -3
  17. package/package.json +1 -1
  18. package/theme/theme-alps.json +93 -0
  19. package/extensions/dm-chime/README.md +0 -11
  20. package/extensions/dm-chime/docs/protocols.md +0 -107
  21. package/extensions/dm-chime/index.ts +0 -205
  22. package/extensions/dm-chime/package.json +0 -33
  23. package/extensions/dm-phone/README.md +0 -24
  24. package/extensions/dm-phone/index.ts +0 -12
  25. package/extensions/dm-phone/node_modules/.package-lock.json +0 -29
  26. package/extensions/dm-phone/node_modules/ws/LICENSE +0 -20
  27. package/extensions/dm-phone/node_modules/ws/README.md +0 -548
  28. package/extensions/dm-phone/node_modules/ws/browser.js +0 -8
  29. package/extensions/dm-phone/node_modules/ws/index.js +0 -22
  30. package/extensions/dm-phone/node_modules/ws/lib/buffer-util.js +0 -131
  31. package/extensions/dm-phone/node_modules/ws/lib/constants.js +0 -19
  32. package/extensions/dm-phone/node_modules/ws/lib/event-target.js +0 -292
  33. package/extensions/dm-phone/node_modules/ws/lib/extension.js +0 -203
  34. package/extensions/dm-phone/node_modules/ws/lib/limiter.js +0 -55
  35. package/extensions/dm-phone/node_modules/ws/lib/permessage-deflate.js +0 -528
  36. package/extensions/dm-phone/node_modules/ws/lib/receiver.js +0 -760
  37. package/extensions/dm-phone/node_modules/ws/lib/sender.js +0 -607
  38. package/extensions/dm-phone/node_modules/ws/lib/stream.js +0 -161
  39. package/extensions/dm-phone/node_modules/ws/lib/subprotocol.js +0 -62
  40. package/extensions/dm-phone/node_modules/ws/lib/validation.js +0 -152
  41. package/extensions/dm-phone/node_modules/ws/lib/websocket-server.js +0 -562
  42. package/extensions/dm-phone/node_modules/ws/lib/websocket.js +0 -1407
  43. package/extensions/dm-phone/node_modules/ws/package.json +0 -70
  44. package/extensions/dm-phone/node_modules/ws/wrapper.mjs +0 -21
  45. package/extensions/dm-phone/package-lock.json +0 -66
  46. package/extensions/dm-phone/package.json +0 -35
  47. package/extensions/dm-phone/phone-session-pool.ts +0 -8
  48. package/extensions/dm-phone/public/app/attachments.js +0 -233
  49. package/extensions/dm-phone/public/app/autocomplete-controller.js +0 -81
  50. package/extensions/dm-phone/public/app/autocomplete.js +0 -135
  51. package/extensions/dm-phone/public/app/bindings.js +0 -178
  52. package/extensions/dm-phone/public/app/command-catalog.js +0 -76
  53. package/extensions/dm-phone/public/app/commands.js +0 -376
  54. package/extensions/dm-phone/public/app/constants.js +0 -60
  55. package/extensions/dm-phone/public/app/formatters.js +0 -131
  56. package/extensions/dm-phone/public/app/handlers.js +0 -442
  57. package/extensions/dm-phone/public/app/main.js +0 -6
  58. package/extensions/dm-phone/public/app/markdown.js +0 -105
  59. package/extensions/dm-phone/public/app/messages.js +0 -418
  60. package/extensions/dm-phone/public/app/sheet-actions.js +0 -113
  61. package/extensions/dm-phone/public/app/sheet-navigation.js +0 -19
  62. package/extensions/dm-phone/public/app/sheets-view.js +0 -287
  63. package/extensions/dm-phone/public/app/state.js +0 -95
  64. package/extensions/dm-phone/public/app/tool-rendering.js +0 -562
  65. package/extensions/dm-phone/public/app/transport.js +0 -176
  66. package/extensions/dm-phone/public/app/ui.js +0 -417
  67. package/extensions/dm-phone/public/app.js +0 -1
  68. package/extensions/dm-phone/public/icon.svg +0 -15
  69. package/extensions/dm-phone/public/index.html +0 -146
  70. package/extensions/dm-phone/public/manifest.webmanifest +0 -17
  71. package/extensions/dm-phone/public/styles.css +0 -1139
  72. package/extensions/dm-phone/public/sw.js +0 -78
  73. package/extensions/dm-phone/src/extension/duckmind-models.js +0 -264
  74. package/extensions/dm-phone/src/extension/phone-args.ts +0 -121
  75. package/extensions/dm-phone/src/extension/phone-paths.ts +0 -250
  76. package/extensions/dm-phone/src/extension/phone-quota.ts +0 -188
  77. package/extensions/dm-phone/src/extension/phone-runtime.ts +0 -154
  78. package/extensions/dm-phone/src/extension/phone-server-runtime.ts +0 -1217
  79. package/extensions/dm-phone/src/extension/phone-sessions.ts +0 -139
  80. package/extensions/dm-phone/src/extension/phone-static.ts +0 -30
  81. package/extensions/dm-phone/src/extension/phone-tailscale.ts +0 -148
  82. package/extensions/dm-phone/src/extension/phone-theme.ts +0 -85
  83. package/extensions/dm-phone/src/extension/register-phone-child-extension.ts +0 -112
  84. package/extensions/dm-phone/src/extension/register-phone-extension.ts +0 -106
  85. package/extensions/dm-phone/src/extension/types.ts +0 -73
  86. package/extensions/dm-phone/src/session-pool/parent-session-worker.ts +0 -882
  87. package/extensions/dm-phone/src/session-pool/session-pool.ts +0 -470
  88. package/extensions/dm-phone/src/session-pool/session-worker.ts +0 -739
  89. package/extensions/dm-phone/src/session-pool/types.ts +0 -111
  90. package/extensions/dm-phone/src/session-pool/utils.ts +0 -23
  91. package/extensions/dm-phone/test/duckmind-models.test.js +0 -147
  92. package/extensions/dm-thinking-timer/LICENSE +0 -21
  93. package/extensions/dm-thinking-timer/README.md +0 -7
  94. package/extensions/dm-thinking-timer/package.json +0 -20
  95. package/extensions/dm-thinking-timer/thinking-timer.ts +0 -250
@@ -1,562 +0,0 @@
1
- /* eslint no-unused-vars: ["error", { "varsIgnorePattern": "^Duplex$", "caughtErrors": "none" }] */
2
-
3
- 'use strict';
4
-
5
- const EventEmitter = require('events');
6
- const http = require('http');
7
- const { Duplex } = require('stream');
8
- const { createHash } = require('crypto');
9
-
10
- const extension = require('./extension');
11
- const PerMessageDeflate = require('./permessage-deflate');
12
- const subprotocol = require('./subprotocol');
13
- const WebSocket = require('./websocket');
14
- const { CLOSE_TIMEOUT, GUID, kWebSocket } = require('./constants');
15
-
16
- const keyRegex = /^[+/0-9A-Za-z]{22}==$/;
17
-
18
- const RUNNING = 0;
19
- const CLOSING = 1;
20
- const CLOSED = 2;
21
-
22
- /**
23
- * Class representing a WebSocket server.
24
- *
25
- * @extends EventEmitter
26
- */
27
- class WebSocketServer extends EventEmitter {
28
- /**
29
- * Create a `WebSocketServer` instance.
30
- *
31
- * @param {Object} options Configuration options
32
- * @param {Boolean} [options.allowSynchronousEvents=true] Specifies whether
33
- * any of the `'message'`, `'ping'`, and `'pong'` events can be emitted
34
- * multiple times in the same tick
35
- * @param {Boolean} [options.autoPong=true] Specifies whether or not to
36
- * automatically send a pong in response to a ping
37
- * @param {Number} [options.backlog=511] The maximum length of the queue of
38
- * pending connections
39
- * @param {Boolean} [options.clientTracking=true] Specifies whether or not to
40
- * track clients
41
- * @param {Number} [options.closeTimeout=30000] Duration in milliseconds to
42
- * wait for the closing handshake to finish after `websocket.close()` is
43
- * called
44
- * @param {Function} [options.handleProtocols] A hook to handle protocols
45
- * @param {String} [options.host] The hostname where to bind the server
46
- * @param {Number} [options.maxBufferedChunks=1048576] The maximum number of
47
- * buffered data chunks
48
- * @param {Number} [options.maxFragments=131072] The maximum number of message
49
- * fragments
50
- * @param {Number} [options.maxPayload=104857600] The maximum allowed message
51
- * size
52
- * @param {Boolean} [options.noServer=false] Enable no server mode
53
- * @param {String} [options.path] Accept only connections matching this path
54
- * @param {(Boolean|Object)} [options.perMessageDeflate=false] Enable/disable
55
- * permessage-deflate
56
- * @param {Number} [options.port] The port where to bind the server
57
- * @param {(http.Server|https.Server)} [options.server] A pre-created HTTP/S
58
- * server to use
59
- * @param {Boolean} [options.skipUTF8Validation=false] Specifies whether or
60
- * not to skip UTF-8 validation for text and close messages
61
- * @param {Function} [options.verifyClient] A hook to reject connections
62
- * @param {Function} [options.WebSocket=WebSocket] Specifies the `WebSocket`
63
- * class to use. It must be the `WebSocket` class or class that extends it
64
- * @param {Function} [callback] A listener for the `listening` event
65
- */
66
- constructor(options, callback) {
67
- super();
68
-
69
- options = {
70
- allowSynchronousEvents: true,
71
- autoPong: true,
72
- maxBufferedChunks: 1024 * 1024,
73
- maxFragments: 128 * 1024,
74
- maxPayload: 100 * 1024 * 1024,
75
- skipUTF8Validation: false,
76
- perMessageDeflate: false,
77
- handleProtocols: null,
78
- clientTracking: true,
79
- closeTimeout: CLOSE_TIMEOUT,
80
- verifyClient: null,
81
- noServer: false,
82
- backlog: null, // use default (511 as implemented in net.js)
83
- server: null,
84
- host: null,
85
- path: null,
86
- port: null,
87
- WebSocket,
88
- ...options
89
- };
90
-
91
- if (
92
- (options.port == null && !options.server && !options.noServer) ||
93
- (options.port != null && (options.server || options.noServer)) ||
94
- (options.server && options.noServer)
95
- ) {
96
- throw new TypeError(
97
- 'One and only one of the "port", "server", or "noServer" options ' +
98
- 'must be specified'
99
- );
100
- }
101
-
102
- if (options.port != null) {
103
- this._server = http.createServer((req, res) => {
104
- const body = http.STATUS_CODES[426];
105
-
106
- res.writeHead(426, {
107
- 'Content-Length': body.length,
108
- 'Content-Type': 'text/plain'
109
- });
110
- res.end(body);
111
- });
112
- this._server.listen(
113
- options.port,
114
- options.host,
115
- options.backlog,
116
- callback
117
- );
118
- } else if (options.server) {
119
- this._server = options.server;
120
- }
121
-
122
- if (this._server) {
123
- const emitConnection = this.emit.bind(this, 'connection');
124
-
125
- this._removeListeners = addListeners(this._server, {
126
- listening: this.emit.bind(this, 'listening'),
127
- error: this.emit.bind(this, 'error'),
128
- upgrade: (req, socket, head) => {
129
- this.handleUpgrade(req, socket, head, emitConnection);
130
- }
131
- });
132
- }
133
-
134
- if (options.perMessageDeflate === true) options.perMessageDeflate = {};
135
- if (options.clientTracking) {
136
- this.clients = new Set();
137
- this._shouldEmitClose = false;
138
- }
139
-
140
- this.options = options;
141
- this._state = RUNNING;
142
- }
143
-
144
- /**
145
- * Returns the bound address, the address family name, and port of the server
146
- * as reported by the operating system if listening on an IP socket.
147
- * If the server is listening on a pipe or UNIX domain socket, the name is
148
- * returned as a string.
149
- *
150
- * @return {(Object|String|null)} The address of the server
151
- * @public
152
- */
153
- address() {
154
- if (this.options.noServer) {
155
- throw new Error('The server is operating in "noServer" mode');
156
- }
157
-
158
- if (!this._server) return null;
159
- return this._server.address();
160
- }
161
-
162
- /**
163
- * Stop the server from accepting new connections and emit the `'close'` event
164
- * when all existing connections are closed.
165
- *
166
- * @param {Function} [cb] A one-time listener for the `'close'` event
167
- * @public
168
- */
169
- close(cb) {
170
- if (this._state === CLOSED) {
171
- if (cb) {
172
- this.once('close', () => {
173
- cb(new Error('The server is not running'));
174
- });
175
- }
176
-
177
- process.nextTick(emitClose, this);
178
- return;
179
- }
180
-
181
- if (cb) this.once('close', cb);
182
-
183
- if (this._state === CLOSING) return;
184
- this._state = CLOSING;
185
-
186
- if (this.options.noServer || this.options.server) {
187
- if (this._server) {
188
- this._removeListeners();
189
- this._removeListeners = this._server = null;
190
- }
191
-
192
- if (this.clients) {
193
- if (!this.clients.size) {
194
- process.nextTick(emitClose, this);
195
- } else {
196
- this._shouldEmitClose = true;
197
- }
198
- } else {
199
- process.nextTick(emitClose, this);
200
- }
201
- } else {
202
- const server = this._server;
203
-
204
- this._removeListeners();
205
- this._removeListeners = this._server = null;
206
-
207
- //
208
- // The HTTP/S server was created internally. Close it, and rely on its
209
- // `'close'` event.
210
- //
211
- server.close(() => {
212
- emitClose(this);
213
- });
214
- }
215
- }
216
-
217
- /**
218
- * See if a given request should be handled by this server instance.
219
- *
220
- * @param {http.IncomingMessage} req Request object to inspect
221
- * @return {Boolean} `true` if the request is valid, else `false`
222
- * @public
223
- */
224
- shouldHandle(req) {
225
- if (this.options.path) {
226
- const index = req.url.indexOf('?');
227
- const pathname = index !== -1 ? req.url.slice(0, index) : req.url;
228
-
229
- if (pathname !== this.options.path) return false;
230
- }
231
-
232
- return true;
233
- }
234
-
235
- /**
236
- * Handle a HTTP Upgrade request.
237
- *
238
- * @param {http.IncomingMessage} req The request object
239
- * @param {Duplex} socket The network socket between the server and client
240
- * @param {Buffer} head The first packet of the upgraded stream
241
- * @param {Function} cb Callback
242
- * @public
243
- */
244
- handleUpgrade(req, socket, head, cb) {
245
- socket.on('error', socketOnError);
246
-
247
- const key = req.headers['sec-websocket-key'];
248
- const upgrade = req.headers.upgrade;
249
- const version = +req.headers['sec-websocket-version'];
250
-
251
- if (req.method !== 'GET') {
252
- const message = 'Invalid HTTP method';
253
- abortHandshakeOrEmitwsClientError(this, req, socket, 405, message);
254
- return;
255
- }
256
-
257
- if (upgrade === undefined || upgrade.toLowerCase() !== 'websocket') {
258
- const message = 'Invalid Upgrade header';
259
- abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
260
- return;
261
- }
262
-
263
- if (key === undefined || !keyRegex.test(key)) {
264
- const message = 'Missing or invalid Sec-WebSocket-Key header';
265
- abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
266
- return;
267
- }
268
-
269
- if (version !== 13 && version !== 8) {
270
- const message = 'Missing or invalid Sec-WebSocket-Version header';
271
- abortHandshakeOrEmitwsClientError(this, req, socket, 400, message, {
272
- 'Sec-WebSocket-Version': '13, 8'
273
- });
274
- return;
275
- }
276
-
277
- if (!this.shouldHandle(req)) {
278
- abortHandshake(socket, 400);
279
- return;
280
- }
281
-
282
- const secWebSocketProtocol = req.headers['sec-websocket-protocol'];
283
- let protocols = new Set();
284
-
285
- if (secWebSocketProtocol !== undefined) {
286
- try {
287
- protocols = subprotocol.parse(secWebSocketProtocol);
288
- } catch (err) {
289
- const message = 'Invalid Sec-WebSocket-Protocol header';
290
- abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
291
- return;
292
- }
293
- }
294
-
295
- const secWebSocketExtensions = req.headers['sec-websocket-extensions'];
296
- const extensions = {};
297
-
298
- if (
299
- this.options.perMessageDeflate &&
300
- secWebSocketExtensions !== undefined
301
- ) {
302
- const perMessageDeflate = new PerMessageDeflate({
303
- ...this.options.perMessageDeflate,
304
- isServer: true,
305
- maxPayload: this.options.maxPayload
306
- });
307
-
308
- try {
309
- const offers = extension.parse(secWebSocketExtensions);
310
-
311
- if (offers[PerMessageDeflate.extensionName]) {
312
- perMessageDeflate.accept(offers[PerMessageDeflate.extensionName]);
313
- extensions[PerMessageDeflate.extensionName] = perMessageDeflate;
314
- }
315
- } catch (err) {
316
- const message =
317
- 'Invalid or unacceptable Sec-WebSocket-Extensions header';
318
- abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
319
- return;
320
- }
321
- }
322
-
323
- //
324
- // Optionally call external client verification handler.
325
- //
326
- if (this.options.verifyClient) {
327
- const info = {
328
- origin:
329
- req.headers[`${version === 8 ? 'sec-websocket-origin' : 'origin'}`],
330
- secure: !!(req.socket.authorized || req.socket.encrypted),
331
- req
332
- };
333
-
334
- if (this.options.verifyClient.length === 2) {
335
- this.options.verifyClient(info, (verified, code, message, headers) => {
336
- if (!verified) {
337
- return abortHandshake(socket, code || 401, message, headers);
338
- }
339
-
340
- this.completeUpgrade(
341
- extensions,
342
- key,
343
- protocols,
344
- req,
345
- socket,
346
- head,
347
- cb
348
- );
349
- });
350
- return;
351
- }
352
-
353
- if (!this.options.verifyClient(info)) return abortHandshake(socket, 401);
354
- }
355
-
356
- this.completeUpgrade(extensions, key, protocols, req, socket, head, cb);
357
- }
358
-
359
- /**
360
- * Upgrade the connection to WebSocket.
361
- *
362
- * @param {Object} extensions The accepted extensions
363
- * @param {String} key The value of the `Sec-WebSocket-Key` header
364
- * @param {Set} protocols The subprotocols
365
- * @param {http.IncomingMessage} req The request object
366
- * @param {Duplex} socket The network socket between the server and client
367
- * @param {Buffer} head The first packet of the upgraded stream
368
- * @param {Function} cb Callback
369
- * @throws {Error} If called more than once with the same socket
370
- * @private
371
- */
372
- completeUpgrade(extensions, key, protocols, req, socket, head, cb) {
373
- //
374
- // Destroy the socket if the client has already sent a FIN packet.
375
- //
376
- if (!socket.readable || !socket.writable) return socket.destroy();
377
-
378
- if (socket[kWebSocket]) {
379
- throw new Error(
380
- 'server.handleUpgrade() was called more than once with the same ' +
381
- 'socket, possibly due to a misconfiguration'
382
- );
383
- }
384
-
385
- if (this._state > RUNNING) return abortHandshake(socket, 503);
386
-
387
- const digest = createHash('sha1')
388
- .update(key + GUID)
389
- .digest('base64');
390
-
391
- const headers = [
392
- 'HTTP/1.1 101 Switching Protocols',
393
- 'Upgrade: websocket',
394
- 'Connection: Upgrade',
395
- `Sec-WebSocket-Accept: ${digest}`
396
- ];
397
-
398
- const ws = new this.options.WebSocket(null, undefined, this.options);
399
-
400
- if (protocols.size) {
401
- //
402
- // Optionally call external protocol selection handler.
403
- //
404
- const protocol = this.options.handleProtocols
405
- ? this.options.handleProtocols(protocols, req)
406
- : protocols.values().next().value;
407
-
408
- if (protocol) {
409
- headers.push(`Sec-WebSocket-Protocol: ${protocol}`);
410
- ws._protocol = protocol;
411
- }
412
- }
413
-
414
- if (extensions[PerMessageDeflate.extensionName]) {
415
- const params = extensions[PerMessageDeflate.extensionName].params;
416
- const value = extension.format({
417
- [PerMessageDeflate.extensionName]: [params]
418
- });
419
- headers.push(`Sec-WebSocket-Extensions: ${value}`);
420
- ws._extensions = extensions;
421
- }
422
-
423
- //
424
- // Allow external modification/inspection of handshake headers.
425
- //
426
- this.emit('headers', headers, req);
427
-
428
- socket.write(headers.concat('\r\n').join('\r\n'));
429
- socket.removeListener('error', socketOnError);
430
-
431
- ws.setSocket(socket, head, {
432
- allowSynchronousEvents: this.options.allowSynchronousEvents,
433
- maxBufferedChunks: this.options.maxBufferedChunks,
434
- maxFragments: this.options.maxFragments,
435
- maxPayload: this.options.maxPayload,
436
- skipUTF8Validation: this.options.skipUTF8Validation
437
- });
438
-
439
- if (this.clients) {
440
- this.clients.add(ws);
441
- ws.on('close', () => {
442
- this.clients.delete(ws);
443
-
444
- if (this._shouldEmitClose && !this.clients.size) {
445
- process.nextTick(emitClose, this);
446
- }
447
- });
448
- }
449
-
450
- cb(ws, req);
451
- }
452
- }
453
-
454
- module.exports = WebSocketServer;
455
-
456
- /**
457
- * Add event listeners on an `EventEmitter` using a map of <event, listener>
458
- * pairs.
459
- *
460
- * @param {EventEmitter} server The event emitter
461
- * @param {Object.<String, Function>} map The listeners to add
462
- * @return {Function} A function that will remove the added listeners when
463
- * called
464
- * @private
465
- */
466
- function addListeners(server, map) {
467
- for (const event of Object.keys(map)) server.on(event, map[event]);
468
-
469
- return function removeListeners() {
470
- for (const event of Object.keys(map)) {
471
- server.removeListener(event, map[event]);
472
- }
473
- };
474
- }
475
-
476
- /**
477
- * Emit a `'close'` event on an `EventEmitter`.
478
- *
479
- * @param {EventEmitter} server The event emitter
480
- * @private
481
- */
482
- function emitClose(server) {
483
- server._state = CLOSED;
484
- server.emit('close');
485
- }
486
-
487
- /**
488
- * Handle socket errors.
489
- *
490
- * @private
491
- */
492
- function socketOnError() {
493
- this.destroy();
494
- }
495
-
496
- /**
497
- * Close the connection when preconditions are not fulfilled.
498
- *
499
- * @param {Duplex} socket The socket of the upgrade request
500
- * @param {Number} code The HTTP response status code
501
- * @param {String} [message] The HTTP response body
502
- * @param {Object} [headers] Additional HTTP response headers
503
- * @private
504
- */
505
- function abortHandshake(socket, code, message, headers) {
506
- //
507
- // The socket is writable unless the user destroyed or ended it before calling
508
- // `server.handleUpgrade()` or in the `verifyClient` function, which is a user
509
- // error. Handling this does not make much sense as the worst that can happen
510
- // is that some of the data written by the user might be discarded due to the
511
- // call to `socket.end()` below, which triggers an `'error'` event that in
512
- // turn causes the socket to be destroyed.
513
- //
514
- message = message || http.STATUS_CODES[code];
515
- headers = {
516
- Connection: 'close',
517
- 'Content-Type': 'text/html',
518
- 'Content-Length': Buffer.byteLength(message),
519
- ...headers
520
- };
521
-
522
- socket.once('finish', socket.destroy);
523
-
524
- socket.end(
525
- `HTTP/1.1 ${code} ${http.STATUS_CODES[code]}\r\n` +
526
- Object.keys(headers)
527
- .map((h) => `${h}: ${headers[h]}`)
528
- .join('\r\n') +
529
- '\r\n\r\n' +
530
- message
531
- );
532
- }
533
-
534
- /**
535
- * Emit a `'wsClientError'` event on a `WebSocketServer` if there is at least
536
- * one listener for it, otherwise call `abortHandshake()`.
537
- *
538
- * @param {WebSocketServer} server The WebSocket server
539
- * @param {http.IncomingMessage} req The request object
540
- * @param {Duplex} socket The socket of the upgrade request
541
- * @param {Number} code The HTTP response status code
542
- * @param {String} message The HTTP response body
543
- * @param {Object} [headers] The HTTP response headers
544
- * @private
545
- */
546
- function abortHandshakeOrEmitwsClientError(
547
- server,
548
- req,
549
- socket,
550
- code,
551
- message,
552
- headers
553
- ) {
554
- if (server.listenerCount('wsClientError')) {
555
- const err = new Error(message);
556
- Error.captureStackTrace(err, abortHandshakeOrEmitwsClientError);
557
-
558
- server.emit('wsClientError', err, socket, req);
559
- } else {
560
- abortHandshake(socket, code, message, headers);
561
- }
562
- }