openportal 0.1.1 → 0.1.2

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 (181) hide show
  1. package/package.json +1 -1
  2. package/web/.next/static/{A7pW-dtFIbPCSkvE8uenX → XI6khKkj1If5Kb4-eJQ2z}/_buildManifest.js +4 -9
  3. package/web/.next/static/chunks/{2e7bfb90c343ca96.js → 35cc9dbdc670c73c.js} +4 -4
  4. package/web/.next/static/chunks/4147ffc67a7b837c.css +1 -0
  5. package/web/.next/static/chunks/{21ab2574b84ad2d1.js → 52b90bc1740162c2.js} +2 -2
  6. package/web/.next/static/chunks/{9b265e2198b5525f.js → 8644d68bf325ff24.js} +3 -3
  7. package/web/.next/static/chunks/{03e1846335a31354.js → 9865709466b09f79.js} +3 -3
  8. package/web/.next/static/chunks/{c20ae04df8cc28be.js → 9ba9a5774c9421bd.js} +3 -3
  9. package/web/.next/static/chunks/{967a1e0002fe9ae6.js → b5caad256518cb33.js} +3 -3
  10. package/web/.next/static/chunks/{turbopack-27558c851386934e.js → turbopack-26af71e419c11487.js} +1 -1
  11. package/web/.next/static/chunks/{turbopack-f4c0881f9723f5a5.js → turbopack-4ad0df7330c00c8d.js} +1 -1
  12. package/web/.next/static/chunks/{turbopack-26688626142ac58f.js → turbopack-8e653f3ad3a8ed18.js} +1 -1
  13. package/web/.next/static/chunks/{turbopack-c40ec6674624f1d7.js → turbopack-d5098189d63fd7b8.js} +1 -1
  14. package/web/apps/web/.next/BUILD_ID +1 -1
  15. package/web/apps/web/.next/build-manifest.json +14 -24
  16. package/web/apps/web/.next/routes-manifest.json +0 -12
  17. package/web/apps/web/.next/server/chunks/[root-of-the-server]__f366ca98._.js +358 -0
  18. package/web/apps/web/.next/server/chunks/ssr/{[root-of-the-server]__dfeaf8cf._.js → [root-of-the-server]__1a54ba1e._.js} +3 -3
  19. package/web/apps/web/.next/server/middleware-build-manifest.js +12 -22
  20. package/web/apps/web/.next/server/next-font-manifest.js +1 -1
  21. package/web/apps/web/.next/server/next-font-manifest.json +0 -4
  22. package/web/apps/web/.next/server/pages/404.html +1 -1
  23. package/web/apps/web/.next/server/pages/500.html +1 -1
  24. package/web/apps/web/.next/server/pages/_app/build-manifest.json +3 -3
  25. package/web/apps/web/.next/server/pages/_app/client-build-manifest.json +1 -1
  26. package/web/apps/web/.next/server/pages/api/[[...slugs]].js +1 -2
  27. package/web/apps/web/.next/server/pages/api/[[...slugs]].js.nft.json +1 -1
  28. package/web/apps/web/.next/server/pages/index/build-manifest.json +3 -3
  29. package/web/apps/web/.next/server/pages/index/client-build-manifest.json +1 -1
  30. package/web/apps/web/.next/server/pages/index.html +1 -1
  31. package/web/apps/web/.next/server/pages/index.js.nft.json +1 -1
  32. package/web/apps/web/.next/server/pages/session/[id]/build-manifest.json +4 -4
  33. package/web/apps/web/.next/server/pages/session/[id]/client-build-manifest.json +1 -1
  34. package/web/apps/web/.next/server/pages/session/[id].html +1 -1
  35. package/web/apps/web/.next/server/pages/session/[id].js.nft.json +1 -1
  36. package/web/apps/web/.next/server/pages/settings/build-manifest.json +3 -3
  37. package/web/apps/web/.next/server/pages/settings/client-build-manifest.json +1 -1
  38. package/web/apps/web/.next/server/pages/settings.html +1 -1
  39. package/web/apps/web/.next/server/pages/settings.js.nft.json +1 -1
  40. package/web/apps/web/.next/server/pages-manifest.json +0 -2
  41. package/web/apps/web/package.json +1 -9
  42. package/web/.next/static/chunks/04d4692d75696297.css +0 -1
  43. package/web/.next/static/chunks/553710f60e2f2b11.js +0 -1
  44. package/web/.next/static/chunks/58acbbb4090e3362.js +0 -3
  45. package/web/.next/static/chunks/6ce1e2f08f961db5.js +0 -2
  46. package/web/.next/static/chunks/d316d63225992c76.js +0 -10
  47. package/web/.next/static/chunks/e0c97552ba7a9e3d.js +0 -1
  48. package/web/.next/static/chunks/fc9c4f2dabfb4e0e.css +0 -1
  49. package/web/.next/static/chunks/turbopack-1837909a677d116b.js +0 -3
  50. package/web/apps/web/.next/server/chunks/[root-of-the-server]__0f75905d._.js +0 -3
  51. package/web/apps/web/.next/server/chunks/[root-of-the-server]__89e85365._.js +0 -358
  52. package/web/apps/web/.next/server/chunks/[root-of-the-server]__ae1361d0._.js +0 -3
  53. package/web/apps/web/.next/server/pages/api/terminal/ws/pages-manifest.json +0 -3
  54. package/web/apps/web/.next/server/pages/api/terminal/ws.js +0 -5
  55. package/web/apps/web/.next/server/pages/api/terminal/ws.js.map +0 -5
  56. package/web/apps/web/.next/server/pages/api/terminal/ws.js.nft.json +0 -1
  57. package/web/apps/web/.next/server/pages/terminal/build-manifest.json +0 -20
  58. package/web/apps/web/.next/server/pages/terminal/client-build-manifest.json +0 -5
  59. package/web/apps/web/.next/server/pages/terminal/next-font-manifest.json +0 -11
  60. package/web/apps/web/.next/server/pages/terminal/pages-manifest.json +0 -3
  61. package/web/apps/web/.next/server/pages/terminal/react-loadable-manifest.json +0 -1
  62. package/web/apps/web/.next/server/pages/terminal.html +0 -1
  63. package/web/apps/web/.next/server/pages/terminal.js.map +0 -5
  64. package/web/apps/web/.next/server/pages/terminal.js.nft.json +0 -1
  65. package/web/node_modules/.bun/@socket.io+component-emitter@3.1.2/node_modules/@socket.io/component-emitter/lib/cjs/index.js +0 -176
  66. package/web/node_modules/.bun/@socket.io+component-emitter@3.1.2/node_modules/@socket.io/component-emitter/lib/cjs/package.json +0 -4
  67. package/web/node_modules/.bun/@socket.io+component-emitter@3.1.2/node_modules/@socket.io/component-emitter/package.json +0 -28
  68. package/web/node_modules/.bun/accepts@1.3.8/node_modules/accepts/index.js +0 -238
  69. package/web/node_modules/.bun/accepts@1.3.8/node_modules/accepts/package.json +0 -47
  70. package/web/node_modules/.bun/base64id@2.0.0/node_modules/base64id/lib/base64id.js +0 -103
  71. package/web/node_modules/.bun/base64id@2.0.0/node_modules/base64id/package.json +0 -13
  72. package/web/node_modules/.bun/cookie@0.7.2/node_modules/cookie/index.js +0 -335
  73. package/web/node_modules/.bun/cookie@0.7.2/node_modules/cookie/package.json +0 -44
  74. package/web/node_modules/.bun/cookie@1.1.1/node_modules/cookie/package.json +0 -47
  75. package/web/node_modules/.bun/cors@2.8.5/node_modules/cors/lib/index.js +0 -238
  76. package/web/node_modules/.bun/cors@2.8.5/node_modules/cors/package.json +0 -41
  77. package/web/node_modules/.bun/debug@4.3.7/node_modules/debug/package.json +0 -60
  78. package/web/node_modules/.bun/debug@4.3.7/node_modules/debug/src/browser.js +0 -271
  79. package/web/node_modules/.bun/debug@4.3.7/node_modules/debug/src/common.js +0 -274
  80. package/web/node_modules/.bun/debug@4.3.7/node_modules/debug/src/index.js +0 -10
  81. package/web/node_modules/.bun/debug@4.3.7/node_modules/debug/src/node.js +0 -263
  82. package/web/node_modules/.bun/engine.io-parser@5.2.3/node_modules/engine.io-parser/build/cjs/commons.js +0 -19
  83. package/web/node_modules/.bun/engine.io-parser@5.2.3/node_modules/engine.io-parser/build/cjs/decodePacket.js +0 -59
  84. package/web/node_modules/.bun/engine.io-parser@5.2.3/node_modules/engine.io-parser/build/cjs/encodePacket.js +0 -38
  85. package/web/node_modules/.bun/engine.io-parser@5.2.3/node_modules/engine.io-parser/build/cjs/index.js +0 -164
  86. package/web/node_modules/.bun/engine.io-parser@5.2.3/node_modules/engine.io-parser/build/cjs/package.json +0 -8
  87. package/web/node_modules/.bun/engine.io-parser@5.2.3/node_modules/engine.io-parser/package.json +0 -46
  88. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/engine.io.js +0 -54
  89. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/parser-v3/index.js +0 -424
  90. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/parser-v3/utf8.js +0 -187
  91. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/server.js +0 -786
  92. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/socket.js +0 -460
  93. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/transport.js +0 -117
  94. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/transports/index.js +0 -23
  95. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/transports/polling-jsonp.js +0 -41
  96. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/transports/polling.js +0 -332
  97. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/transports/websocket.js +0 -94
  98. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/transports/webtransport.js +0 -63
  99. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/transports-uws/index.js +0 -8
  100. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/transports-uws/polling.js +0 -364
  101. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/transports-uws/websocket.js +0 -73
  102. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/build/userver.js +0 -279
  103. package/web/node_modules/.bun/engine.io@6.6.4/node_modules/engine.io/package.json +0 -70
  104. package/web/node_modules/.bun/has-flag@4.0.0/node_modules/has-flag/index.js +0 -8
  105. package/web/node_modules/.bun/has-flag@4.0.0/node_modules/has-flag/package.json +0 -46
  106. package/web/node_modules/.bun/mime-db@1.52.0/node_modules/mime-db/db.json +0 -8519
  107. package/web/node_modules/.bun/mime-db@1.52.0/node_modules/mime-db/index.js +0 -12
  108. package/web/node_modules/.bun/mime-db@1.52.0/node_modules/mime-db/package.json +0 -60
  109. package/web/node_modules/.bun/mime-types@2.1.35/node_modules/mime-types/index.js +0 -188
  110. package/web/node_modules/.bun/mime-types@2.1.35/node_modules/mime-types/package.json +0 -44
  111. package/web/node_modules/.bun/ms@2.1.3/node_modules/ms/index.js +0 -162
  112. package/web/node_modules/.bun/ms@2.1.3/node_modules/ms/package.json +0 -38
  113. package/web/node_modules/.bun/negotiator@0.6.3/node_modules/negotiator/index.js +0 -82
  114. package/web/node_modules/.bun/negotiator@0.6.3/node_modules/negotiator/lib/charset.js +0 -169
  115. package/web/node_modules/.bun/negotiator@0.6.3/node_modules/negotiator/lib/encoding.js +0 -184
  116. package/web/node_modules/.bun/negotiator@0.6.3/node_modules/negotiator/lib/language.js +0 -179
  117. package/web/node_modules/.bun/negotiator@0.6.3/node_modules/negotiator/lib/mediaType.js +0 -294
  118. package/web/node_modules/.bun/negotiator@0.6.3/node_modules/negotiator/package.json +0 -42
  119. package/web/node_modules/.bun/object-assign@4.1.1/node_modules/object-assign/index.js +0 -90
  120. package/web/node_modules/.bun/object-assign@4.1.1/node_modules/object-assign/package.json +0 -42
  121. package/web/node_modules/.bun/socket.io-adapter@2.5.5/node_modules/socket.io-adapter/dist/cluster-adapter.js +0 -674
  122. package/web/node_modules/.bun/socket.io-adapter@2.5.5/node_modules/socket.io-adapter/dist/contrib/yeast.js +0 -55
  123. package/web/node_modules/.bun/socket.io-adapter@2.5.5/node_modules/socket.io-adapter/dist/in-memory-adapter.js +0 -394
  124. package/web/node_modules/.bun/socket.io-adapter@2.5.5/node_modules/socket.io-adapter/dist/index.js +0 -10
  125. package/web/node_modules/.bun/socket.io-adapter@2.5.5/node_modules/socket.io-adapter/package.json +0 -39
  126. package/web/node_modules/.bun/socket.io-parser@4.2.4/node_modules/socket.io-parser/build/cjs/binary.js +0 -88
  127. package/web/node_modules/.bun/socket.io-parser@4.2.4/node_modules/socket.io-parser/build/cjs/index.js +0 -321
  128. package/web/node_modules/.bun/socket.io-parser@4.2.4/node_modules/socket.io-parser/build/cjs/is-binary.js +0 -55
  129. package/web/node_modules/.bun/socket.io-parser@4.2.4/node_modules/socket.io-parser/build/cjs/package.json +0 -3
  130. package/web/node_modules/.bun/socket.io-parser@4.2.4/node_modules/socket.io-parser/package.json +0 -58
  131. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/client-dist/socket.io.esm.min.js +0 -7
  132. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/client-dist/socket.io.js +0 -4908
  133. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/client-dist/socket.io.min.js +0 -7
  134. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/client-dist/socket.io.msgpack.min.js +0 -7
  135. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/dist/broadcast-operator.js +0 -436
  136. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/dist/client.js +0 -268
  137. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/dist/index.js +0 -804
  138. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/dist/namespace.js +0 -581
  139. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/dist/parent-namespace.js +0 -88
  140. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/dist/socket-types.js +0 -11
  141. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/dist/socket.js +0 -977
  142. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/dist/typed-events.js +0 -81
  143. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/dist/uws.js +0 -136
  144. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/package.json +0 -85
  145. package/web/node_modules/.bun/socket.io@4.8.1/node_modules/socket.io/wrapper.mjs +0 -3
  146. package/web/node_modules/.bun/supports-color@7.2.0/node_modules/supports-color/index.js +0 -135
  147. package/web/node_modules/.bun/supports-color@7.2.0/node_modules/supports-color/package.json +0 -53
  148. package/web/node_modules/.bun/vary@1.1.2/node_modules/vary/index.js +0 -149
  149. package/web/node_modules/.bun/vary@1.1.2/node_modules/vary/package.json +0 -43
  150. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/index.js +0 -13
  151. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/lib/buffer-util.js +0 -131
  152. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/lib/constants.js +0 -12
  153. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/lib/event-target.js +0 -292
  154. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/lib/extension.js +0 -203
  155. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/lib/limiter.js +0 -55
  156. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/lib/permessage-deflate.js +0 -514
  157. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/lib/receiver.js +0 -704
  158. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/lib/sender.js +0 -497
  159. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/lib/stream.js +0 -159
  160. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/lib/subprotocol.js +0 -62
  161. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/lib/validation.js +0 -130
  162. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/lib/websocket-server.js +0 -540
  163. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/lib/websocket.js +0 -1338
  164. package/web/node_modules/.bun/ws@8.17.1/node_modules/ws/package.json +0 -69
  165. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/lib/buffer-util.js +0 -131
  166. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/lib/constants.js +0 -18
  167. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/lib/event-target.js +0 -292
  168. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/lib/extension.js +0 -203
  169. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/lib/limiter.js +0 -55
  170. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/lib/permessage-deflate.js +0 -528
  171. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/lib/receiver.js +0 -706
  172. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/lib/sender.js +0 -602
  173. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/lib/stream.js +0 -161
  174. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/lib/subprotocol.js +0 -62
  175. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/lib/validation.js +0 -152
  176. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/lib/websocket-server.js +0 -550
  177. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/lib/websocket.js +0 -1388
  178. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/package.json +0 -69
  179. package/web/node_modules/.bun/ws@8.18.3/node_modules/ws/wrapper.mjs +0 -8
  180. /package/web/.next/static/{A7pW-dtFIbPCSkvE8uenX → XI6khKkj1If5Kb4-eJQ2z}/_clientMiddlewareManifest.json +0 -0
  181. /package/web/.next/static/{A7pW-dtFIbPCSkvE8uenX → XI6khKkj1If5Kb4-eJQ2z}/_ssgManifest.js +0 -0
@@ -1,602 +0,0 @@
1
- /* eslint no-unused-vars: ["error", { "varsIgnorePattern": "^Duplex" }] */
2
-
3
- 'use strict';
4
-
5
- const { Duplex } = require('stream');
6
- const { randomFillSync } = require('crypto');
7
-
8
- const PerMessageDeflate = require('./permessage-deflate');
9
- const { EMPTY_BUFFER, kWebSocket, NOOP } = require('./constants');
10
- const { isBlob, isValidStatusCode } = require('./validation');
11
- const { mask: applyMask, toBuffer } = require('./buffer-util');
12
-
13
- const kByteLength = Symbol('kByteLength');
14
- const maskBuffer = Buffer.alloc(4);
15
- const RANDOM_POOL_SIZE = 8 * 1024;
16
- let randomPool;
17
- let randomPoolPointer = RANDOM_POOL_SIZE;
18
-
19
- const DEFAULT = 0;
20
- const DEFLATING = 1;
21
- const GET_BLOB_DATA = 2;
22
-
23
- /**
24
- * HyBi Sender implementation.
25
- */
26
- class Sender {
27
- /**
28
- * Creates a Sender instance.
29
- *
30
- * @param {Duplex} socket The connection socket
31
- * @param {Object} [extensions] An object containing the negotiated extensions
32
- * @param {Function} [generateMask] The function used to generate the masking
33
- * key
34
- */
35
- constructor(socket, extensions, generateMask) {
36
- this._extensions = extensions || {};
37
-
38
- if (generateMask) {
39
- this._generateMask = generateMask;
40
- this._maskBuffer = Buffer.alloc(4);
41
- }
42
-
43
- this._socket = socket;
44
-
45
- this._firstFragment = true;
46
- this._compress = false;
47
-
48
- this._bufferedBytes = 0;
49
- this._queue = [];
50
- this._state = DEFAULT;
51
- this.onerror = NOOP;
52
- this[kWebSocket] = undefined;
53
- }
54
-
55
- /**
56
- * Frames a piece of data according to the HyBi WebSocket protocol.
57
- *
58
- * @param {(Buffer|String)} data The data to frame
59
- * @param {Object} options Options object
60
- * @param {Boolean} [options.fin=false] Specifies whether or not to set the
61
- * FIN bit
62
- * @param {Function} [options.generateMask] The function used to generate the
63
- * masking key
64
- * @param {Boolean} [options.mask=false] Specifies whether or not to mask
65
- * `data`
66
- * @param {Buffer} [options.maskBuffer] The buffer used to store the masking
67
- * key
68
- * @param {Number} options.opcode The opcode
69
- * @param {Boolean} [options.readOnly=false] Specifies whether `data` can be
70
- * modified
71
- * @param {Boolean} [options.rsv1=false] Specifies whether or not to set the
72
- * RSV1 bit
73
- * @return {(Buffer|String)[]} The framed data
74
- * @public
75
- */
76
- static frame(data, options) {
77
- let mask;
78
- let merge = false;
79
- let offset = 2;
80
- let skipMasking = false;
81
-
82
- if (options.mask) {
83
- mask = options.maskBuffer || maskBuffer;
84
-
85
- if (options.generateMask) {
86
- options.generateMask(mask);
87
- } else {
88
- if (randomPoolPointer === RANDOM_POOL_SIZE) {
89
- /* istanbul ignore else */
90
- if (randomPool === undefined) {
91
- //
92
- // This is lazily initialized because server-sent frames must not
93
- // be masked so it may never be used.
94
- //
95
- randomPool = Buffer.alloc(RANDOM_POOL_SIZE);
96
- }
97
-
98
- randomFillSync(randomPool, 0, RANDOM_POOL_SIZE);
99
- randomPoolPointer = 0;
100
- }
101
-
102
- mask[0] = randomPool[randomPoolPointer++];
103
- mask[1] = randomPool[randomPoolPointer++];
104
- mask[2] = randomPool[randomPoolPointer++];
105
- mask[3] = randomPool[randomPoolPointer++];
106
- }
107
-
108
- skipMasking = (mask[0] | mask[1] | mask[2] | mask[3]) === 0;
109
- offset = 6;
110
- }
111
-
112
- let dataLength;
113
-
114
- if (typeof data === 'string') {
115
- if (
116
- (!options.mask || skipMasking) &&
117
- options[kByteLength] !== undefined
118
- ) {
119
- dataLength = options[kByteLength];
120
- } else {
121
- data = Buffer.from(data);
122
- dataLength = data.length;
123
- }
124
- } else {
125
- dataLength = data.length;
126
- merge = options.mask && options.readOnly && !skipMasking;
127
- }
128
-
129
- let payloadLength = dataLength;
130
-
131
- if (dataLength >= 65536) {
132
- offset += 8;
133
- payloadLength = 127;
134
- } else if (dataLength > 125) {
135
- offset += 2;
136
- payloadLength = 126;
137
- }
138
-
139
- const target = Buffer.allocUnsafe(merge ? dataLength + offset : offset);
140
-
141
- target[0] = options.fin ? options.opcode | 0x80 : options.opcode;
142
- if (options.rsv1) target[0] |= 0x40;
143
-
144
- target[1] = payloadLength;
145
-
146
- if (payloadLength === 126) {
147
- target.writeUInt16BE(dataLength, 2);
148
- } else if (payloadLength === 127) {
149
- target[2] = target[3] = 0;
150
- target.writeUIntBE(dataLength, 4, 6);
151
- }
152
-
153
- if (!options.mask) return [target, data];
154
-
155
- target[1] |= 0x80;
156
- target[offset - 4] = mask[0];
157
- target[offset - 3] = mask[1];
158
- target[offset - 2] = mask[2];
159
- target[offset - 1] = mask[3];
160
-
161
- if (skipMasking) return [target, data];
162
-
163
- if (merge) {
164
- applyMask(data, mask, target, offset, dataLength);
165
- return [target];
166
- }
167
-
168
- applyMask(data, mask, data, 0, dataLength);
169
- return [target, data];
170
- }
171
-
172
- /**
173
- * Sends a close message to the other peer.
174
- *
175
- * @param {Number} [code] The status code component of the body
176
- * @param {(String|Buffer)} [data] The message component of the body
177
- * @param {Boolean} [mask=false] Specifies whether or not to mask the message
178
- * @param {Function} [cb] Callback
179
- * @public
180
- */
181
- close(code, data, mask, cb) {
182
- let buf;
183
-
184
- if (code === undefined) {
185
- buf = EMPTY_BUFFER;
186
- } else if (typeof code !== 'number' || !isValidStatusCode(code)) {
187
- throw new TypeError('First argument must be a valid error code number');
188
- } else if (data === undefined || !data.length) {
189
- buf = Buffer.allocUnsafe(2);
190
- buf.writeUInt16BE(code, 0);
191
- } else {
192
- const length = Buffer.byteLength(data);
193
-
194
- if (length > 123) {
195
- throw new RangeError('The message must not be greater than 123 bytes');
196
- }
197
-
198
- buf = Buffer.allocUnsafe(2 + length);
199
- buf.writeUInt16BE(code, 0);
200
-
201
- if (typeof data === 'string') {
202
- buf.write(data, 2);
203
- } else {
204
- buf.set(data, 2);
205
- }
206
- }
207
-
208
- const options = {
209
- [kByteLength]: buf.length,
210
- fin: true,
211
- generateMask: this._generateMask,
212
- mask,
213
- maskBuffer: this._maskBuffer,
214
- opcode: 0x08,
215
- readOnly: false,
216
- rsv1: false
217
- };
218
-
219
- if (this._state !== DEFAULT) {
220
- this.enqueue([this.dispatch, buf, false, options, cb]);
221
- } else {
222
- this.sendFrame(Sender.frame(buf, options), cb);
223
- }
224
- }
225
-
226
- /**
227
- * Sends a ping message to the other peer.
228
- *
229
- * @param {*} data The message to send
230
- * @param {Boolean} [mask=false] Specifies whether or not to mask `data`
231
- * @param {Function} [cb] Callback
232
- * @public
233
- */
234
- ping(data, mask, cb) {
235
- let byteLength;
236
- let readOnly;
237
-
238
- if (typeof data === 'string') {
239
- byteLength = Buffer.byteLength(data);
240
- readOnly = false;
241
- } else if (isBlob(data)) {
242
- byteLength = data.size;
243
- readOnly = false;
244
- } else {
245
- data = toBuffer(data);
246
- byteLength = data.length;
247
- readOnly = toBuffer.readOnly;
248
- }
249
-
250
- if (byteLength > 125) {
251
- throw new RangeError('The data size must not be greater than 125 bytes');
252
- }
253
-
254
- const options = {
255
- [kByteLength]: byteLength,
256
- fin: true,
257
- generateMask: this._generateMask,
258
- mask,
259
- maskBuffer: this._maskBuffer,
260
- opcode: 0x09,
261
- readOnly,
262
- rsv1: false
263
- };
264
-
265
- if (isBlob(data)) {
266
- if (this._state !== DEFAULT) {
267
- this.enqueue([this.getBlobData, data, false, options, cb]);
268
- } else {
269
- this.getBlobData(data, false, options, cb);
270
- }
271
- } else if (this._state !== DEFAULT) {
272
- this.enqueue([this.dispatch, data, false, options, cb]);
273
- } else {
274
- this.sendFrame(Sender.frame(data, options), cb);
275
- }
276
- }
277
-
278
- /**
279
- * Sends a pong message to the other peer.
280
- *
281
- * @param {*} data The message to send
282
- * @param {Boolean} [mask=false] Specifies whether or not to mask `data`
283
- * @param {Function} [cb] Callback
284
- * @public
285
- */
286
- pong(data, mask, cb) {
287
- let byteLength;
288
- let readOnly;
289
-
290
- if (typeof data === 'string') {
291
- byteLength = Buffer.byteLength(data);
292
- readOnly = false;
293
- } else if (isBlob(data)) {
294
- byteLength = data.size;
295
- readOnly = false;
296
- } else {
297
- data = toBuffer(data);
298
- byteLength = data.length;
299
- readOnly = toBuffer.readOnly;
300
- }
301
-
302
- if (byteLength > 125) {
303
- throw new RangeError('The data size must not be greater than 125 bytes');
304
- }
305
-
306
- const options = {
307
- [kByteLength]: byteLength,
308
- fin: true,
309
- generateMask: this._generateMask,
310
- mask,
311
- maskBuffer: this._maskBuffer,
312
- opcode: 0x0a,
313
- readOnly,
314
- rsv1: false
315
- };
316
-
317
- if (isBlob(data)) {
318
- if (this._state !== DEFAULT) {
319
- this.enqueue([this.getBlobData, data, false, options, cb]);
320
- } else {
321
- this.getBlobData(data, false, options, cb);
322
- }
323
- } else if (this._state !== DEFAULT) {
324
- this.enqueue([this.dispatch, data, false, options, cb]);
325
- } else {
326
- this.sendFrame(Sender.frame(data, options), cb);
327
- }
328
- }
329
-
330
- /**
331
- * Sends a data message to the other peer.
332
- *
333
- * @param {*} data The message to send
334
- * @param {Object} options Options object
335
- * @param {Boolean} [options.binary=false] Specifies whether `data` is binary
336
- * or text
337
- * @param {Boolean} [options.compress=false] Specifies whether or not to
338
- * compress `data`
339
- * @param {Boolean} [options.fin=false] Specifies whether the fragment is the
340
- * last one
341
- * @param {Boolean} [options.mask=false] Specifies whether or not to mask
342
- * `data`
343
- * @param {Function} [cb] Callback
344
- * @public
345
- */
346
- send(data, options, cb) {
347
- const perMessageDeflate = this._extensions[PerMessageDeflate.extensionName];
348
- let opcode = options.binary ? 2 : 1;
349
- let rsv1 = options.compress;
350
-
351
- let byteLength;
352
- let readOnly;
353
-
354
- if (typeof data === 'string') {
355
- byteLength = Buffer.byteLength(data);
356
- readOnly = false;
357
- } else if (isBlob(data)) {
358
- byteLength = data.size;
359
- readOnly = false;
360
- } else {
361
- data = toBuffer(data);
362
- byteLength = data.length;
363
- readOnly = toBuffer.readOnly;
364
- }
365
-
366
- if (this._firstFragment) {
367
- this._firstFragment = false;
368
- if (
369
- rsv1 &&
370
- perMessageDeflate &&
371
- perMessageDeflate.params[
372
- perMessageDeflate._isServer
373
- ? 'server_no_context_takeover'
374
- : 'client_no_context_takeover'
375
- ]
376
- ) {
377
- rsv1 = byteLength >= perMessageDeflate._threshold;
378
- }
379
- this._compress = rsv1;
380
- } else {
381
- rsv1 = false;
382
- opcode = 0;
383
- }
384
-
385
- if (options.fin) this._firstFragment = true;
386
-
387
- const opts = {
388
- [kByteLength]: byteLength,
389
- fin: options.fin,
390
- generateMask: this._generateMask,
391
- mask: options.mask,
392
- maskBuffer: this._maskBuffer,
393
- opcode,
394
- readOnly,
395
- rsv1
396
- };
397
-
398
- if (isBlob(data)) {
399
- if (this._state !== DEFAULT) {
400
- this.enqueue([this.getBlobData, data, this._compress, opts, cb]);
401
- } else {
402
- this.getBlobData(data, this._compress, opts, cb);
403
- }
404
- } else if (this._state !== DEFAULT) {
405
- this.enqueue([this.dispatch, data, this._compress, opts, cb]);
406
- } else {
407
- this.dispatch(data, this._compress, opts, cb);
408
- }
409
- }
410
-
411
- /**
412
- * Gets the contents of a blob as binary data.
413
- *
414
- * @param {Blob} blob The blob
415
- * @param {Boolean} [compress=false] Specifies whether or not to compress
416
- * the data
417
- * @param {Object} options Options object
418
- * @param {Boolean} [options.fin=false] Specifies whether or not to set the
419
- * FIN bit
420
- * @param {Function} [options.generateMask] The function used to generate the
421
- * masking key
422
- * @param {Boolean} [options.mask=false] Specifies whether or not to mask
423
- * `data`
424
- * @param {Buffer} [options.maskBuffer] The buffer used to store the masking
425
- * key
426
- * @param {Number} options.opcode The opcode
427
- * @param {Boolean} [options.readOnly=false] Specifies whether `data` can be
428
- * modified
429
- * @param {Boolean} [options.rsv1=false] Specifies whether or not to set the
430
- * RSV1 bit
431
- * @param {Function} [cb] Callback
432
- * @private
433
- */
434
- getBlobData(blob, compress, options, cb) {
435
- this._bufferedBytes += options[kByteLength];
436
- this._state = GET_BLOB_DATA;
437
-
438
- blob
439
- .arrayBuffer()
440
- .then((arrayBuffer) => {
441
- if (this._socket.destroyed) {
442
- const err = new Error(
443
- 'The socket was closed while the blob was being read'
444
- );
445
-
446
- //
447
- // `callCallbacks` is called in the next tick to ensure that errors
448
- // that might be thrown in the callbacks behave like errors thrown
449
- // outside the promise chain.
450
- //
451
- process.nextTick(callCallbacks, this, err, cb);
452
- return;
453
- }
454
-
455
- this._bufferedBytes -= options[kByteLength];
456
- const data = toBuffer(arrayBuffer);
457
-
458
- if (!compress) {
459
- this._state = DEFAULT;
460
- this.sendFrame(Sender.frame(data, options), cb);
461
- this.dequeue();
462
- } else {
463
- this.dispatch(data, compress, options, cb);
464
- }
465
- })
466
- .catch((err) => {
467
- //
468
- // `onError` is called in the next tick for the same reason that
469
- // `callCallbacks` above is.
470
- //
471
- process.nextTick(onError, this, err, cb);
472
- });
473
- }
474
-
475
- /**
476
- * Dispatches a message.
477
- *
478
- * @param {(Buffer|String)} data The message to send
479
- * @param {Boolean} [compress=false] Specifies whether or not to compress
480
- * `data`
481
- * @param {Object} options Options object
482
- * @param {Boolean} [options.fin=false] Specifies whether or not to set the
483
- * FIN bit
484
- * @param {Function} [options.generateMask] The function used to generate the
485
- * masking key
486
- * @param {Boolean} [options.mask=false] Specifies whether or not to mask
487
- * `data`
488
- * @param {Buffer} [options.maskBuffer] The buffer used to store the masking
489
- * key
490
- * @param {Number} options.opcode The opcode
491
- * @param {Boolean} [options.readOnly=false] Specifies whether `data` can be
492
- * modified
493
- * @param {Boolean} [options.rsv1=false] Specifies whether or not to set the
494
- * RSV1 bit
495
- * @param {Function} [cb] Callback
496
- * @private
497
- */
498
- dispatch(data, compress, options, cb) {
499
- if (!compress) {
500
- this.sendFrame(Sender.frame(data, options), cb);
501
- return;
502
- }
503
-
504
- const perMessageDeflate = this._extensions[PerMessageDeflate.extensionName];
505
-
506
- this._bufferedBytes += options[kByteLength];
507
- this._state = DEFLATING;
508
- perMessageDeflate.compress(data, options.fin, (_, buf) => {
509
- if (this._socket.destroyed) {
510
- const err = new Error(
511
- 'The socket was closed while data was being compressed'
512
- );
513
-
514
- callCallbacks(this, err, cb);
515
- return;
516
- }
517
-
518
- this._bufferedBytes -= options[kByteLength];
519
- this._state = DEFAULT;
520
- options.readOnly = false;
521
- this.sendFrame(Sender.frame(buf, options), cb);
522
- this.dequeue();
523
- });
524
- }
525
-
526
- /**
527
- * Executes queued send operations.
528
- *
529
- * @private
530
- */
531
- dequeue() {
532
- while (this._state === DEFAULT && this._queue.length) {
533
- const params = this._queue.shift();
534
-
535
- this._bufferedBytes -= params[3][kByteLength];
536
- Reflect.apply(params[0], this, params.slice(1));
537
- }
538
- }
539
-
540
- /**
541
- * Enqueues a send operation.
542
- *
543
- * @param {Array} params Send operation parameters.
544
- * @private
545
- */
546
- enqueue(params) {
547
- this._bufferedBytes += params[3][kByteLength];
548
- this._queue.push(params);
549
- }
550
-
551
- /**
552
- * Sends a frame.
553
- *
554
- * @param {(Buffer | String)[]} list The frame to send
555
- * @param {Function} [cb] Callback
556
- * @private
557
- */
558
- sendFrame(list, cb) {
559
- if (list.length === 2) {
560
- this._socket.cork();
561
- this._socket.write(list[0]);
562
- this._socket.write(list[1], cb);
563
- this._socket.uncork();
564
- } else {
565
- this._socket.write(list[0], cb);
566
- }
567
- }
568
- }
569
-
570
- module.exports = Sender;
571
-
572
- /**
573
- * Calls queued callbacks with an error.
574
- *
575
- * @param {Sender} sender The `Sender` instance
576
- * @param {Error} err The error to call the callbacks with
577
- * @param {Function} [cb] The first callback
578
- * @private
579
- */
580
- function callCallbacks(sender, err, cb) {
581
- if (typeof cb === 'function') cb(err);
582
-
583
- for (let i = 0; i < sender._queue.length; i++) {
584
- const params = sender._queue[i];
585
- const callback = params[params.length - 1];
586
-
587
- if (typeof callback === 'function') callback(err);
588
- }
589
- }
590
-
591
- /**
592
- * Handles a `Sender` error.
593
- *
594
- * @param {Sender} sender The `Sender` instance
595
- * @param {Error} err The error
596
- * @param {Function} [cb] The first pending callback
597
- * @private
598
- */
599
- function onError(sender, err, cb) {
600
- callCallbacks(sender, err, cb);
601
- sender.onerror(err);
602
- }