diff --git a/bin/executor b/bin/executor index de6e49c..72bb3dd 100755 Binary files a/bin/executor and b/bin/executor differ diff --git a/dist/bundles/qualiteer-executor.mjs b/dist/bundles/qualiteer-executor.mjs index 7ab8231..d999cb7 100644 --- a/dist/bundles/qualiteer-executor.mjs +++ b/dist/bundles/qualiteer-executor.mjs @@ -11,4 +11,4 @@ import e from"node:path";import t from"fs";import s from"url";import r from"chil * @contributor David Ellis * @license MIT */ -var F=t,M=s,q=r.spawn,W=V;function V(e){e=e||{};var t,s,r=this,o=i,a=n,h={},c=!1,l={"User-Agent":"node-XMLHttpRequest",Accept:"*/*"},d=Object.assign({},l),p=["accept-charset","accept-encoding","access-control-request-headers","access-control-request-method","connection","content-length","content-transfer-encoding","cookie","cookie2","date","expect","host","keep-alive","origin","referer","te","trailer","transfer-encoding","upgrade","via"],u=["TRACE","TRACK","CONNECT"],f=!1,_=!1,m=!1,y={};this.UNSENT=0,this.OPENED=1,this.HEADERS_RECEIVED=2,this.LOADING=3,this.DONE=4,this.readyState=this.UNSENT,this.onreadystatechange=null,this.responseText="",this.responseXML="",this.status=null,this.statusText=null;this.open=function(e,t,s,r,i){if(this.abort(),_=!1,m=!1,!function(e){return e&&-1===u.indexOf(e)}(e))throw new Error("SecurityError: Request method not allowed");h={method:e,url:t.toString(),async:"boolean"!=typeof s||s,user:r||null,password:i||null},g(this.OPENED)},this.setDisableHeaderCheck=function(e){c=e},this.setRequestHeader=function(e,t){if(this.readyState!=this.OPENED)throw new Error("INVALID_STATE_ERR: setRequestHeader can only be called when state is OPEN");if(!function(e){return c||e&&-1===p.indexOf(e.toLowerCase())}(e))return console.warn('Refused to set unsafe header "'+e+'"'),!1;if(f)throw new Error("INVALID_STATE_ERR: send flag is true");return d[e]=t,!0},this.getResponseHeader=function(e){return"string"==typeof e&&this.readyState>this.OPENED&&s.headers[e.toLowerCase()]&&!_?s.headers[e.toLowerCase()]:null},this.getAllResponseHeaders=function(){if(this.readyState{e.unref()})),i&&t.write(i),t.end(),r.dispatchEvent("loadstart")}else{var k=".node-xmlhttprequest-content-"+process.pid,x=".node-xmlhttprequest-sync-"+process.pid;F.writeFileSync(x,"","utf8");for(var O="var http = require('http'), https = require('https'), fs = require('fs');var doRequest = http"+(c?"s":"")+".request;var options = "+JSON.stringify(v)+";var responseText = '';var req = doRequest(options, function(response) {response.setEncoding('utf8');response.on('data', function(chunk) { responseText += chunk;});response.on('end', function() {fs.writeFileSync('"+k+"', 'NODE-XMLHTTPREQUEST-STATUS:' + response.statusCode + ',' + responseText, 'utf8');fs.unlinkSync('"+x+"');});response.on('error', function(error) {fs.writeFileSync('"+k+"', 'NODE-XMLHTTPREQUEST-ERROR:' + JSON.stringify(error), 'utf8');fs.unlinkSync('"+x+"');});}).on('error', function(error) {fs.writeFileSync('"+k+"', 'NODE-XMLHTTPREQUEST-ERROR:' + JSON.stringify(error), 'utf8');fs.unlinkSync('"+x+"');});"+(i?"req.write('"+JSON.stringify(i).slice(1,-1).replace(/'/g,"\\'")+"');":"")+"req.end();",T=q(process.argv[0],["-e",O]);F.existsSync(x););if(r.responseText=F.readFileSync(k,"utf8"),T.stdin.end(),F.unlinkSync(k),r.responseText.match(/^NODE-XMLHTTPREQUEST-ERROR:/)){var N=r.responseText.replace(/^NODE-XMLHTTPREQUEST-ERROR:/,"");r.handleError(N,503)}else r.status=r.responseText.replace(/^NODE-XMLHTTPREQUEST-STATUS:([0-9]*),.*/,"$1"),r.responseText=r.responseText.replace(/^NODE-XMLHTTPREQUEST-STATUS:[0-9]*,(.*)/,"$1"),g(r.DONE)}}},this.handleError=function(e,t){this.status=t||0,this.statusText=e,this.responseText=e.stack,_=!0,g(this.DONE)},this.abort=function(){t&&(t.abort(),t=null),d=Object.assign({},l),this.responseText="",this.responseXML="",_=m=!0,this.readyState===this.UNSENT||this.readyState===this.OPENED&&!f||this.readyState===this.DONE||(f=!1,g(this.DONE)),this.readyState=this.UNSENT},this.addEventListener=function(e,t){e in y||(y[e]=[]),y[e].push(t)},this.removeEventListener=function(e,t){e in y&&(y[e]=y[e].filter((function(e){return e!==t})))},this.dispatchEvent=function(e){if("function"==typeof r["on"+e]&&(this.readyState===this.DONE?setImmediate((function(){r["on"+e]()})):r["on"+e]()),e in y)for(let t=0,s=y[e].length;t{4===t.readyState&&(200===t.status||1223===t.status?this.onLoad():this.setTimeoutFn((()=>{this.onError("number"==typeof t.status?t.status:0)}),0))},t.send(this.data)}catch(e){return void this.setTimeoutFn((()=>{this.onError(e)}),0)}"undefined"!=typeof document&&(this.index=z.requestsCount++,z.requests[this.index]=this)}onError(e){this.emitReserved("error",e,this.xhr),this.cleanup(!0)}cleanup(e){if(void 0!==this.xhr&&null!==this.xhr){if(this.xhr.onreadystatechange=G,e)try{this.xhr.abort()}catch(e){}"undefined"!=typeof document&&delete z.requests[this.index],this.xhr=null}}onLoad(){const e=this.xhr.responseText;null!==e&&(this.emitReserved("data",e),this.emitReserved("success"),this.cleanup())}abort(){this.cleanup()}}if(z.requestsCount=0,z.requests={},"undefined"!=typeof document)if("function"==typeof attachEvent)attachEvent("onunload",Y);else if("function"==typeof addEventListener){addEventListener("onpagehide"in k?"pagehide":"unload",Y,!1)}function Y(){for(let e in z.requests)z.requests.hasOwnProperty(e)&&z.requests[e].abort()}var K={exports:{}},X={BINARY_TYPES:["nodebuffer","arraybuffer","fragments"],EMPTY_BUFFER:Buffer.alloc(0),GUID:"258EAFA5-E914-47DA-95CA-C5AB0DC85B11",kForOnEventAttribute:Symbol("kIsForOnEventAttribute"),kListener:Symbol("kListener"),kStatusCode:Symbol("status-code"),kWebSocket:Symbol("websocket"),NOOP:()=>{}};const{EMPTY_BUFFER:J}=X;function Q(e,t){if(0===e.length)return J;if(1===e.length)return e[0];const s=Buffer.allocUnsafe(t);let r=0;for(let t=0;t{this.pending--,this[ie]()},this.concurrency=e||1/0,this.jobs=[],this.pending=0}add(e){this.jobs.push(e),this[ie]()}[ie](){if(this.pending!==this.concurrency&&this.jobs.length){const e=this.jobs.shift();this.pending++,e(this[re])}}};const oe=a,ae=K.exports,he=ne,{kStatusCode:ce}=X,le=Buffer.from([0,0,255,255]),de=Symbol("permessage-deflate"),pe=Symbol("total-length"),ue=Symbol("callback"),fe=Symbol("buffers"),_e=Symbol("error");let me;var ye=class{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,!me){const e=void 0!==this._options.concurrencyLimit?this._options.concurrencyLimit:10;me=new he(e)}}static get extensionName(){return"permessage-deflate"}offer(){const 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){const e=this._deflate[ue];this._deflate.close(),this._deflate=null,e&&e(new Error("The deflate stream was closed while data was being processed"))}}acceptAsServer(e){const 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 new 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){const t=e[0];if(!1===this._options.clientNoContextTakeover&&t.client_no_context_takeover)throw new 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 new 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 new Error(`Parameter "${t}" must have only a single value`);if(s=s[0],"client_max_window_bits"===t){if(!0!==s){const e=+s;if(!Number.isInteger(e)||e<8||e>15)throw new TypeError(`Invalid value for parameter "${t}": ${s}`);s=e}else if(!this._isServer)throw new TypeError(`Invalid value for parameter "${t}": ${s}`)}else if("server_max_window_bits"===t){const e=+s;if(!Number.isInteger(e)||e<8||e>15)throw new TypeError(`Invalid value for parameter "${t}": ${s}`);s=e}else{if("client_no_context_takeover"!==t&&"server_no_context_takeover"!==t)throw new Error(`Unknown parameter "${t}"`);if(!0!==s)throw new TypeError(`Invalid value for parameter "${t}": ${s}`)}e[t]=s}))})),e}decompress(e,t,s){me.add((r=>{this._decompress(e,t,((e,t)=>{r(),s(e,t)}))}))}compress(e,t,s){me.add((r=>{this._compress(e,t,((e,t)=>{r(),s(e,t)}))}))}_decompress(e,t,s){const r=this._isServer?"client":"server";if(!this._inflate){const e=`${r}_max_window_bits`,t="number"!=typeof this.params[e]?oe.Z_DEFAULT_WINDOWBITS:this.params[e];this._inflate=oe.createInflateRaw({...this._options.zlibInflateOptions,windowBits:t}),this._inflate[de]=this,this._inflate[pe]=0,this._inflate[fe]=[],this._inflate.on("error",ve),this._inflate.on("data",be)}this._inflate[ue]=s,this._inflate.write(e),t&&this._inflate.write(le),this._inflate.flush((()=>{const e=this._inflate[_e];if(e)return this._inflate.close(),this._inflate=null,void s(e);const i=ae.concat(this._inflate[fe],this._inflate[pe]);this._inflate._readableState.endEmitted?(this._inflate.close(),this._inflate=null):(this._inflate[pe]=0,this._inflate[fe]=[],t&&this.params[`${r}_no_context_takeover`]&&this._inflate.reset()),s(null,i)}))}_compress(e,t,s){const r=this._isServer?"server":"client";if(!this._deflate){const e=`${r}_max_window_bits`,t="number"!=typeof this.params[e]?oe.Z_DEFAULT_WINDOWBITS:this.params[e];this._deflate=oe.createDeflateRaw({...this._options.zlibDeflateOptions,windowBits:t}),this._deflate[pe]=0,this._deflate[fe]=[],this._deflate.on("data",ge)}this._deflate[ue]=s,this._deflate.write(e),this._deflate.flush(oe.Z_SYNC_FLUSH,(()=>{if(!this._deflate)return;let e=ae.concat(this._deflate[fe],this._deflate[pe]);t&&(e=e.slice(0,e.length-4)),this._deflate[ue]=null,this._deflate[pe]=0,this._deflate[fe]=[],t&&this.params[`${r}_no_context_takeover`]&&this._deflate.reset(),s(null,e)}))}};function ge(e){this[fe].push(e),this[pe]+=e.length}function be(e){this[pe]+=e.length,this[de]._maxPayload<1||this[pe]<=this[de]._maxPayload?this[fe].push(e):(this[_e]=new RangeError("Max payload size exceeded"),this[_e].code="WS_ERR_UNSUPPORTED_MESSAGE_LENGTH",this[_e][ce]=1009,this.removeListener("data",be),this.reset())}function ve(e){this[de]._inflate=null,e[ce]=1007,this[ue](e)}var Ee={exports:{}};const we=[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 Se(e){return e>=1e3&&e<=1014&&1004!==e&&1005!==e&&1006!==e||e>=3e3&&e<=4999}function ke(e){const t=e.length;let s=0;for(;s=t||128!=(192&e[s+1])||128!=(192&e[s+2])||224===e[s]&&128==(224&e[s+1])||237===e[s]&&160==(224&e[s+1]))return!1;s+=3}else{if(240!=(248&e[s]))return!1;if(s+3>=t||128!=(192&e[s+1])||128!=(192&e[s+2])||128!=(192&e[s+3])||240===e[s]&&128==(240&e[s+1])||244===e[s]&&e[s+1]>143||e[s]>244)return!1;s+=4}return!0}try{const e=require("utf-8-validate");Ee.exports={isValidStatusCode:Se,isValidUTF8:t=>t.length<150?ke(t):e(t),tokenChars:we}}catch(e){Ee.exports={isValidStatusCode:Se,isValidUTF8:ke,tokenChars:we}}const{Writable:xe}=o,Oe=ye,{BINARY_TYPES:Te,EMPTY_BUFFER:Ne,kStatusCode:Re,kWebSocket:Ce}=X,{concat:Le,toArrayBuffer:Ae,unmask:Be}=K.exports,{isValidStatusCode:Pe,isValidUTF8:Ie}=Ee.exports;var De=class extends xe{constructor(e={}){super(),this._binaryType=e.binaryType||Te[0],this._extensions=e.extensions||{},this._isServer=!!e.isServer,this._maxPayload=0|e.maxPayload,this._skipUTF8Validation=!!e.skipUTF8Validation,this[Ce]=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._state=0,this._loop=!1}_write(e,t,s){if(8===this._opcode&&0==this._state)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=s.length?t.set(this._buffers.shift(),r):(t.set(new Uint8Array(s.buffer,s.byteOffset,e),r),this._buffers[0]=s.slice(e)),e-=s.length}while(e>0);return t}startLoop(e){let t;this._loop=!0;do{switch(this._state){case 0:t=this.getInfo();break;case 1:t=this.getPayloadLength16();break;case 2:t=this.getPayloadLength64();break;case 3:this.getMask();break;case 4:t=this.getData(e);break;default:return void(this._loop=!1)}}while(this._loop);e(t)}getInfo(){if(this._bufferedBytes<2)return void(this._loop=!1);const e=this.consume(2);if(0!=(48&e[0]))return this._loop=!1,Ue(RangeError,"RSV2 and RSV3 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_2_3");const t=64==(64&e[0]);if(t&&!this._extensions[Oe.extensionName])return this._loop=!1,Ue(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");if(this._fin=128==(128&e[0]),this._opcode=15&e[0],this._payloadLength=127&e[1],0===this._opcode){if(t)return this._loop=!1,Ue(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");if(!this._fragmented)return this._loop=!1,Ue(RangeError,"invalid opcode 0",!0,1002,"WS_ERR_INVALID_OPCODE");this._opcode=this._fragmented}else if(1===this._opcode||2===this._opcode){if(this._fragmented)return this._loop=!1,Ue(RangeError,`invalid opcode ${this._opcode}`,!0,1002,"WS_ERR_INVALID_OPCODE");this._compressed=t}else{if(!(this._opcode>7&&this._opcode<11))return this._loop=!1,Ue(RangeError,`invalid opcode ${this._opcode}`,!0,1002,"WS_ERR_INVALID_OPCODE");if(!this._fin)return this._loop=!1,Ue(RangeError,"FIN must be set",!0,1002,"WS_ERR_EXPECTED_FIN");if(t)return this._loop=!1,Ue(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");if(this._payloadLength>125)return this._loop=!1,Ue(RangeError,`invalid payload length ${this._payloadLength}`,!0,1002,"WS_ERR_INVALID_CONTROL_PAYLOAD_LENGTH")}if(this._fin||this._fragmented||(this._fragmented=this._opcode),this._masked=128==(128&e[1]),this._isServer){if(!this._masked)return this._loop=!1,Ue(RangeError,"MASK must be set",!0,1002,"WS_ERR_EXPECTED_MASK")}else if(this._masked)return this._loop=!1,Ue(RangeError,"MASK must be clear",!0,1002,"WS_ERR_UNEXPECTED_MASK");if(126===this._payloadLength)this._state=1;else{if(127!==this._payloadLength)return this.haveLength();this._state=2}}getPayloadLength16(){if(!(this._bufferedBytes<2))return this._payloadLength=this.consume(2).readUInt16BE(0),this.haveLength();this._loop=!1}getPayloadLength64(){if(this._bufferedBytes<8)return void(this._loop=!1);const e=this.consume(8),t=e.readUInt32BE(0);return t>Math.pow(2,21)-1?(this._loop=!1,Ue(RangeError,"Unsupported WebSocket frame: payload length > 2^53 - 1",!1,1009,"WS_ERR_UNSUPPORTED_DATA_PAYLOAD_LENGTH")):(this._payloadLength=t*Math.pow(2,32)+e.readUInt32BE(4),this.haveLength())}haveLength(){if(this._payloadLength&&this._opcode<8&&(this._totalPayloadLength+=this._payloadLength,this._totalPayloadLength>this._maxPayload&&this._maxPayload>0))return this._loop=!1,Ue(RangeError,"Max payload size exceeded",!1,1009,"WS_ERR_UNSUPPORTED_MESSAGE_LENGTH");this._masked?this._state=3:this._state=4}getMask(){this._bufferedBytes<4?this._loop=!1:(this._mask=this.consume(4),this._state=4)}getData(e){let t=Ne;if(this._payloadLength){if(this._bufferedBytes7?this.controlMessage(t):this._compressed?(this._state=5,void this.decompress(t,e)):(t.length&&(this._messageLength=this._totalPayloadLength,this._fragments.push(t)),this.dataMessage())}decompress(e,t){this._extensions[Oe.extensionName].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)return t(Ue(RangeError,"Max payload size exceeded",!1,1009,"WS_ERR_UNSUPPORTED_MESSAGE_LENGTH"));this._fragments.push(s)}const r=this.dataMessage();if(r)return t(r);this.startLoop(t)}))}dataMessage(){if(this._fin){const e=this._messageLength,t=this._fragments;if(this._totalPayloadLength=0,this._messageLength=0,this._fragmented=0,this._fragments=[],2===this._opcode){let s;s="nodebuffer"===this._binaryType?Le(t,e):"arraybuffer"===this._binaryType?Ae(Le(t,e)):t,this.emit("message",s,!0)}else{const s=Le(t,e);if(!this._skipUTF8Validation&&!Ie(s))return this._loop=!1,Ue(Error,"invalid UTF-8 sequence",!0,1007,"WS_ERR_INVALID_UTF8");this.emit("message",s,!1)}}this._state=0}controlMessage(e){if(8===this._opcode)if(this._loop=!1,0===e.length)this.emit("conclude",1005,Ne),this.end();else{if(1===e.length)return Ue(RangeError,"invalid payload length 1",!0,1002,"WS_ERR_INVALID_CONTROL_PAYLOAD_LENGTH");{const t=e.readUInt16BE(0);if(!Pe(t))return Ue(RangeError,`invalid status code ${t}`,!0,1002,"WS_ERR_INVALID_CLOSE_CODE");const s=e.slice(2);if(!this._skipUTF8Validation&&!Ie(s))return Ue(Error,"invalid UTF-8 sequence",!0,1007,"WS_ERR_INVALID_UTF8");this.emit("conclude",t,s),this.end()}}else 9===this._opcode?this.emit("ping",e):this.emit("pong",e);this._state=0}};function Ue(e,t,s,r,i){const n=new e(s?`Invalid WebSocket frame: ${t}`:t);return Error.captureStackTrace(n,Ue),n.code=i,n[Re]=r,n}const{randomFillSync:je}=l,Fe=ye,{EMPTY_BUFFER:Me}=X,{isValidStatusCode:qe}=Ee.exports,{mask:We,toBuffer:Ve}=K.exports,$e=Buffer.alloc(4);class Ge{constructor(e,t){this._extensions=t||{},this._socket=e,this._firstFragment=!0,this._compress=!1,this._bufferedBytes=0,this._deflating=!1,this._queue=[]}static frame(e,t){const s=t.mask&&t.readOnly;let r=t.mask?6:2,i=e.length;e.length>=65536?(r+=8,i=127):e.length>125&&(r+=2,i=126);const n=Buffer.allocUnsafe(s?e.length+r:r);return n[0]=t.fin?128|t.opcode:t.opcode,t.rsv1&&(n[0]|=64),n[1]=i,126===i?n.writeUInt16BE(e.length,2):127===i&&(n.writeUInt32BE(0,2),n.writeUInt32BE(e.length,6)),t.mask?(je($e,0,4),n[1]|=128,n[r-4]=$e[0],n[r-3]=$e[1],n[r-2]=$e[2],n[r-1]=$e[3],s?(We(e,$e,n,r,e.length),[n]):(We(e,$e,e,0,e.length),[n,e])):[n,e]}close(e,t,s,r){let i;if(void 0===e)i=Me;else{if("number"!=typeof e||!qe(e))throw new TypeError("First argument must be a valid error code number");if(void 0!==t&&t.length){const s=Buffer.byteLength(t);if(s>123)throw new RangeError("The message must not be greater than 123 bytes");i=Buffer.allocUnsafe(2+s),i.writeUInt16BE(e,0),"string"==typeof t?i.write(t,2):i.set(t,2)}else i=Buffer.allocUnsafe(2),i.writeUInt16BE(e,0)}this._deflating?this.enqueue([this.doClose,i,s,r]):this.doClose(i,s,r)}doClose(e,t,s){this.sendFrame(Ge.frame(e,{fin:!0,rsv1:!1,opcode:8,mask:t,readOnly:!1}),s)}ping(e,t,s){const r=Ve(e);if(r.length>125)throw new RangeError("The data size must not be greater than 125 bytes");this._deflating?this.enqueue([this.doPing,r,t,Ve.readOnly,s]):this.doPing(r,t,Ve.readOnly,s)}doPing(e,t,s,r){this.sendFrame(Ge.frame(e,{fin:!0,rsv1:!1,opcode:9,mask:t,readOnly:s}),r)}pong(e,t,s){const r=Ve(e);if(r.length>125)throw new RangeError("The data size must not be greater than 125 bytes");this._deflating?this.enqueue([this.doPong,r,t,Ve.readOnly,s]):this.doPong(r,t,Ve.readOnly,s)}doPong(e,t,s,r){this.sendFrame(Ge.frame(e,{fin:!0,rsv1:!1,opcode:10,mask:t,readOnly:s}),r)}send(e,t,s){const r=Ve(e),i=this._extensions[Fe.extensionName];let n=t.binary?2:1,o=t.compress;if(this._firstFragment?(this._firstFragment=!1,o&&i&&i.params[i._isServer?"server_no_context_takeover":"client_no_context_takeover"]&&(o=r.length>=i._threshold),this._compress=o):(o=!1,n=0),t.fin&&(this._firstFragment=!0),i){const e={fin:t.fin,rsv1:o,opcode:n,mask:t.mask,readOnly:Ve.readOnly};this._deflating?this.enqueue([this.dispatch,r,this._compress,e,s]):this.dispatch(r,this._compress,e,s)}else this.sendFrame(Ge.frame(r,{fin:t.fin,rsv1:!1,opcode:n,mask:t.mask,readOnly:Ve.readOnly}),s)}dispatch(e,t,s,r){if(!t)return void this.sendFrame(Ge.frame(e,s),r);const i=this._extensions[Fe.extensionName];this._bufferedBytes+=e.length,this._deflating=!0,i.compress(e,s.fin,((t,i)=>{if(this._socket.destroyed){const e=new Error("The socket was closed while data was being compressed");"function"==typeof r&&r(e);for(let t=0;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(", ")},parse:function(e){const t=Object.create(null);let s,r,i=Object.create(null),n=!1,o=!1,a=!1,h=-1,c=-1,l=-1,d=0;for(;d0&&e.unshift(t),e.on("close",Zt),e.on("data",es),e.on("end",ts),e.on("error",ss),this._readyState=Ft.OPEN,this.emit("open")}emitClose(){if(!this._socket)return this._readyState=Ft.CLOSED,void this.emit("close",this._closeCode,this._closeMessage);this._extensions[vt.extensionName]&&this._extensions[vt.extensionName].cleanup(),this._receiver.removeAllListeners(),this._readyState=Ft.CLOSED,this.emit("close",this._closeCode,this._closeMessage)}close(e,t){if(this.readyState!==Ft.CLOSED){if(this.readyState===Ft.CONNECTING){const e="WebSocket was closed before the connection was established";return Vt(this,this._req,e)}this.readyState!==Ft.CLOSING?(this._readyState=Ft.CLOSING,this._sender.close(e,t,!this._isServer,(e=>{e||(this._closeFrameSent=!0,(this._closeFrameReceived||this._receiver._writableState.errorEmitted)&&this._socket.end())})),this._closeTimer=setTimeout(this._socket.destroy.bind(this._socket),3e4)):this._closeFrameSent&&(this._closeFrameReceived||this._receiver._writableState.errorEmitted)&&this._socket.end()}}ping(e,t,s){if(this.readyState===Ft.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");"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===Ft.OPEN?(void 0===t&&(t=!this._isServer),this._sender.ping(e||kt,t,s)):$t(this,e,s)}pong(e,t,s){if(this.readyState===Ft.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");"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===Ft.OPEN?(void 0===t&&(t=!this._isServer),this._sender.pong(e||kt,t,s)):$t(this,e,s)}send(e,t,s){if(this.readyState===Ft.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");if("function"==typeof t&&(s=t,t={}),"number"==typeof e&&(e=e.toString()),this.readyState!==Ft.OPEN)return void $t(this,e,s);const r={binary:"string"!=typeof e,mask:!this._isServer,compress:!0,fin:!0,...t};this._extensions[vt.extensionName]||(r.compress=!1),this._sender.send(e||kt,r,s)}terminate(){if(this.readyState!==Ft.CLOSED){if(this.readyState===Ft.CONNECTING){const e="WebSocket was closed before the connection was established";return Vt(this,this._req,e)}this._socket&&(this._readyState=Ft.CLOSING,this._socket.destroy())}}}function Mt(e,t,s,r){const i={protocolVersion:jt[1],maxPayload:104857600,skipUTF8Validation:!1,perMessageDeflate:!0,followRedirects:!1,maxRedirects:10,...r,createConnection:void 0,socketPath:void 0,hostname:void 0,protocol:void 0,timeout:void 0,method:void 0,host:void 0,path:void 0,port:void 0};if(!jt.includes(i.protocolVersion))throw new RangeError(`Unsupported protocol version: ${i.protocolVersion} (supported versions: ${jt.join(", ")})`);let n;if(t instanceof bt)n=t,e._url=t.href;else{try{n=new bt(t)}catch(e){throw new SyntaxError(`Invalid URL: ${t}`)}e._url=t}const o="wss:"===n.protocol,a="ws+unix:"===n.protocol;if("ws:"!==n.protocol&&!o&&!a)throw new SyntaxError('The URL\'s protocol must be one of "ws:", "wss:", or "ws+unix:"');if(a&&!n.pathname)throw new SyntaxError("The URL's pathname is empty");if(n.hash)throw new SyntaxError("The URL contains a fragment identifier");const h=o?443:80,c=yt(16).toString("base64"),l=o?ut.get:ft.get,d=new Set;let p;if(i.createConnection=o?Wt:qt,i.defaultPort=i.defaultPort||h,i.port=n.port||h,i.host=n.hostname.startsWith("[")?n.hostname.slice(1,-1):n.hostname,i.headers={"Sec-WebSocket-Version":i.protocolVersion,"Sec-WebSocket-Key":c,Connection:"Upgrade",Upgrade:"websocket",...i.headers},i.path=n.pathname+n.search,i.timeout=i.handshakeTimeout,i.perMessageDeflate&&(p=new vt(!0!==i.perMessageDeflate?i.perMessageDeflate:{},!1,i.maxPayload),i.headers["Sec-WebSocket-Extensions"]=Bt({[vt.extensionName]:p.offer()})),s.length){for(const e of s){if("string"!=typeof e||!Ut.test(e)||d.has(e))throw new SyntaxError("An invalid or duplicated subprotocol was specified");d.add(e)}i.headers["Sec-WebSocket-Protocol"]=s.join(",")}if(i.origin&&(i.protocolVersion<13?i.headers["Sec-WebSocket-Origin"]=i.origin:i.headers.Origin=i.origin),(n.username||n.password)&&(i.auth=`${n.username}:${n.password}`),a){const e=i.path.split(":");i.socketPath=e[0],i.path=e[1]}let u=e._req=l(i);i.timeout&&u.on("timeout",(()=>{Vt(e,u,"Opening handshake has timed out")})),u.on("error",(t=>{null===u||u.aborted||(u=e._req=null,e._readyState=Ft.CLOSING,e.emit("error",t),e.emitClose())})),u.on("response",(n=>{const o=n.headers.location,a=n.statusCode;if(o&&i.followRedirects&&a>=300&&a<400){if(++e._redirects>i.maxRedirects)return void Vt(e,u,"Maximum redirects exceeded");u.abort();const n=new bt(o,t);Mt(e,n,s,r)}else e.emit("unexpected-response",u,n)||Vt(e,u,`Unexpected server response: ${n.statusCode}`)})),u.on("upgrade",((t,s,r)=>{if(e.emit("upgrade",t),e.readyState!==Ft.CONNECTING)return;u=e._req=null;const n=gt("sha1").update(c+xt).digest("base64");if(t.headers["sec-websocket-accept"]!==n)return void Vt(e,s,"Invalid Sec-WebSocket-Accept header");const o=t.headers["sec-websocket-protocol"];let a;if(void 0!==o?d.size?d.has(o)||(a="Server sent an invalid subprotocol"):a="Server sent a subprotocol but none was requested":d.size&&(a="Server sent no subprotocol"),a)return void Vt(e,s,a);o&&(e._protocol=o);const h=t.headers["sec-websocket-extensions"];if(void 0!==h){if(!p){return void Vt(e,s,"Server sent a Sec-WebSocket-Extensions header but no extension was requested")}let t;try{t=Pt(h)}catch(t){return void Vt(e,s,"Invalid Sec-WebSocket-Extensions header")}const r=Object.keys(t);if(1!==r.length||r[0]!==vt.extensionName){return void Vt(e,s,"Server indicated an extension that was not requested")}try{p.accept(t[vt.extensionName])}catch(t){return void Vt(e,s,"Invalid Sec-WebSocket-Extensions header")}e._extensions[vt.extensionName]=p}e.setSocket(s,r,{maxPayload:i.maxPayload,skipUTF8Validation:i.skipUTF8Validation})}))}function qt(e){return e.path=e.socketPath,_t.connect(e)}function Wt(e){return e.path=void 0,e.servername||""===e.servername||(e.servername=_t.isIP(e.host)?"":e.host),mt.connect(e)}function Vt(e,t,s){e._readyState=Ft.CLOSING;const r=new Error(s);Error.captureStackTrace(r,Vt),t.setHeader?(t.abort(),t.socket&&!t.socket.destroyed&&t.socket.destroy(),t.once("abort",e.emitClose.bind(e)),e.emit("error",r)):(t.destroy(r),t.once("error",e.emit.bind(e,"error")),t.once("close",e.emitClose.bind(e)))}function $t(e,t,s){if(t){const s=It(t).length;e._socket?e._sender._bufferedBytes+=s:e._bufferedAmount+=s}if(s){s(new Error(`WebSocket is not open: readyState ${e.readyState} (${Dt[e.readyState]})`))}}function Gt(e,t){const s=this[Rt];s._closeFrameReceived=!0,s._closeMessage=t,s._closeCode=e,void 0!==s._socket[Rt]&&(s._socket.removeListener("data",es),process.nextTick(Qt,s._socket),1005===e?s.close():s.close(e,t))}function Ht(){this[Rt]._socket.resume()}function zt(e){const t=this[Rt];void 0!==t._socket[Rt]&&(t._socket.removeListener("data",es),process.nextTick(Qt,t._socket),t.close(e[Nt])),t.emit("error",e)}function Yt(){this[Rt].emitClose()}function Kt(e,t){this[Rt].emit("message",e,t)}function Xt(e){const t=this[Rt];t.pong(e,!t._isServer,Ct),t.emit("ping",e)}function Jt(e){this[Rt].emit("pong",e)}function Qt(e){e.resume()}function Zt(){const e=this[Rt];let t;this.removeListener("close",Zt),this.removeListener("data",es),this.removeListener("end",ts),e._readyState=Ft.CLOSING,this._readableState.endEmitted||e._closeFrameReceived||e._receiver._writableState.errorEmitted||null===(t=e._socket.read())||e._receiver.write(t),e._receiver.end(),this[Rt]=void 0,clearTimeout(e._closeTimer),e._receiver._writableState.finished||e._receiver._writableState.errorEmitted?e.emitClose():(e._receiver.on("error",Yt),e._receiver.on("finish",Yt))}function es(e){this[Rt]._receiver.write(e)||this.pause()}function ts(){const e=this[Rt];e._readyState=Ft.CLOSING,e._receiver.end(),this.end()}function ss(){const e=this[Rt];this.removeListener("error",ss),this.on("error",Ct),e&&(e._readyState=Ft.CLOSING,this.destroy())}Object.defineProperty(Ft,"CONNECTING",{enumerable:!0,value:Dt.indexOf("CONNECTING")}),Object.defineProperty(Ft.prototype,"CONNECTING",{enumerable:!0,value:Dt.indexOf("CONNECTING")}),Object.defineProperty(Ft,"OPEN",{enumerable:!0,value:Dt.indexOf("OPEN")}),Object.defineProperty(Ft.prototype,"OPEN",{enumerable:!0,value:Dt.indexOf("OPEN")}),Object.defineProperty(Ft,"CLOSING",{enumerable:!0,value:Dt.indexOf("CLOSING")}),Object.defineProperty(Ft.prototype,"CLOSING",{enumerable:!0,value:Dt.indexOf("CLOSING")}),Object.defineProperty(Ft,"CLOSED",{enumerable:!0,value:Dt.indexOf("CLOSED")}),Object.defineProperty(Ft.prototype,"CLOSED",{enumerable:!0,value:Dt.indexOf("CLOSED")}),["binaryType","bufferedAmount","extensions","protocol","readyState","url"].forEach((e=>{Object.defineProperty(Ft.prototype,e,{enumerable:!0})})),["open","error","close","message"].forEach((e=>{Object.defineProperty(Ft.prototype,`on${e}`,{enumerable:!0,get(){for(const t of this.listeners(e))if(t[Ot])return t[Tt];return null},set(t){for(const t of this.listeners(e))if(t[Ot]){this.removeListener(e,t);break}"function"==typeof t&&this.addEventListener(e,t,{[Ot]:!0})}})})),Ft.prototype.addEventListener=Lt,Ft.prototype.removeEventListener=At;const rs=Ft,is=process.nextTick,ns="undefined"!=typeof navigator&&"string"==typeof navigator.product&&"reactnative"===navigator.product.toLowerCase();const os={websocket:class extends C{constructor(e){super(e),this.supportsBinary=!e.forceBase64}get name(){return"websocket"}doOpen(){if(!this.check())return;const e=this.uri(),t=this.opts.protocols,s=ns?{}:x(this.opts,"agent","perMessageDeflate","pfx","key","passphrase","cert","ca","ciphers","rejectUnauthorized","localAddress","protocolVersion","origin","maxPayload","family","checkServerIdentity");this.opts.extraHeaders&&(s.headers=this.opts.extraHeaders);try{this.ws=new rs(e,t,s)}catch(e){return this.emitReserved("error",e)}this.ws.binaryType=this.socket.binaryType||"nodebuffer",this.addEventListeners()}addEventListeners(){this.ws.onopen=()=>{this.opts.autoUnref&&this.ws._socket.unref(),this.onOpen()},this.ws.onclose=e=>this.onClose({description:"websocket connection closed",context:e}),this.ws.onmessage=e=>this.onData(e.data),this.ws.onerror=e=>this.onError("websocket error",e)}write(e){this.writable=!1;for(let t=0;t{const t={};if(s.options&&(t.compress=s.options.compress),this.opts.perMessageDeflate){("string"==typeof e?Buffer.byteLength(e):e.length){this.writable=!0,this.emitReserved("drain")}),this.setTimeoutFn)}))}}doClose(){void 0!==this.ws&&(this.ws.close(),this.ws=null)}uri(){let e=this.query||{};const t=this.opts.secure?"wss":"ws";let s="";this.opts.port&&("wss"===t&&443!==Number(this.opts.port)||"ws"===t&&80!==Number(this.opts.port))&&(s=":"+this.opts.port),this.opts.timestampRequests&&(e[this.opts.timestampParam]=U()),this.supportsBinary||(e.b64=1);const r=j(e);return t+"://"+(-1!==this.opts.hostname.indexOf(":")?"["+this.opts.hostname+"]":this.opts.hostname)+s+this.opts.path+(r.length?"?"+r:"")}check(){return!!rs}},polling:class extends C{constructor(e){if(super(e),this.polling=!1,"undefined"!=typeof location){const t="https:"===location.protocol;let s=location.port;s||(s=t?"443":"80"),this.xd="undefined"!=typeof location&&e.hostname!==location.hostname||s!==e.port,this.xs=e.secure!==t}const t=e&&e.forceBase64;this.supportsBinary=H&&!t}get name(){return"polling"}doOpen(){this.poll()}pause(e){this.readyState="pausing";const t=()=>{this.readyState="paused",e()};if(this.polling||!this.writable){let e=0;this.polling&&(e++,this.once("pollComplete",(function(){--e||t()}))),this.writable||(e++,this.once("drain",(function(){--e||t()})))}else t()}poll(){this.polling=!0,this.doPoll(),this.emitReserved("poll")}onData(e){((e,t)=>{const s=e.split(w),r=[];for(let e=0;e{if("opening"===this.readyState&&"open"===e.type&&this.onOpen(),"close"===e.type)return this.onClose({description:"transport closed by the server"}),!1;this.onPacket(e)})),"closed"!==this.readyState&&(this.polling=!1,this.emitReserved("pollComplete"),"open"===this.readyState&&this.poll())}doClose(){const e=()=>{this.write([{type:"close"}])};"open"===this.readyState?e():this.once("open",e)}write(e){this.writable=!1,((e,t)=>{const s=e.length,r=new Array(s);let i=0;e.forEach(((e,n)=>{m(e,!1,(e=>{r[n]=e,++i===s&&t(r.join(w))}))}))})(e,(e=>{this.doWrite(e,(()=>{this.writable=!0,this.emitReserved("drain")}))}))}uri(){let e=this.query||{};const t=this.opts.secure?"https":"http";let s="";!1!==this.opts.timestampRequests&&(e[this.opts.timestampParam]=U()),this.supportsBinary||e.sid||(e.b64=1),this.opts.port&&("https"===t&&443!==Number(this.opts.port)||"http"===t&&80!==Number(this.opts.port))&&(s=":"+this.opts.port);const r=j(e);return t+"://"+(-1!==this.opts.hostname.indexOf(":")?"["+this.opts.hostname+"]":this.opts.hostname)+s+this.opts.path+(r.length?"?"+r:"")}request(e={}){return Object.assign(e,{xd:this.xd,xs:this.xs},this.opts),new z(this.uri(),e)}doWrite(e,t){const s=this.request({method:"POST",data:e});s.on("success",t),s.on("error",((e,t)=>{this.onError("xhr post error",e,t)}))}doPoll(){const e=this.request();e.on("data",this.onData.bind(this)),e.on("error",((e,t)=>{this.onError("xhr poll error",e,t)})),this.pollXhr=e}}},as=/^(?:(?![^:@]+:[^:@\/]*@)(http|https|ws|wss):\/\/)?((?:(([^:@]*)(?::([^:@]*))?)?@)?((?:[a-f0-9]{0,4}:){2,7}[a-f0-9]{0,4}|[^:\/?#]*)(?::(\d*))?)(((\/(?:[^?#](?![^?#\/]*\.[^?#\/.]+(?:[?#]|$)))*\/?)?([^?#\/]*))(?:\?([^#]*))?(?:#(.*))?)/,hs=["source","protocol","authority","userInfo","user","password","host","port","relative","path","directory","file","query","anchor"];function cs(e){const t=e,s=e.indexOf("["),r=e.indexOf("]");-1!=s&&-1!=r&&(e=e.substring(0,s)+e.substring(s,r).replace(/:/g,";")+e.substring(r,e.length));let i=as.exec(e||""),n={},o=14;for(;o--;)n[hs[o]]=i[o]||"";return-1!=s&&-1!=r&&(n.source=t,n.host=n.host.substring(1,n.host.length-1).replace(/;/g,":"),n.authority=n.authority.replace("[","").replace("]","").replace(/;/g,":"),n.ipv6uri=!0),n.pathNames=function(e,t){const s=/\/{2,9}/g,r=t.replace(s,"/").split("/");"/"!=t.substr(0,1)&&0!==t.length||r.splice(0,1);"/"==t.substr(t.length-1,1)&&r.splice(r.length-1,1);return r}(0,n.path),n.queryKey=function(e,t){const s={};return t.replace(/(?:^|&)([^&=]*)=?([^&]*)/g,(function(e,t,r){t&&(s[t]=r)})),s}(0,n.query),n}class ls extends S{constructor(e,t={}){super(),e&&"object"==typeof e&&(t=e,e=null),e?(e=cs(e),t.hostname=e.host,t.secure="https"===e.protocol||"wss"===e.protocol,t.port=e.port,e.query&&(t.query=e.query)):t.host&&(t.hostname=cs(t.host).host),N(this,t),this.secure=null!=t.secure?t.secure:"undefined"!=typeof location&&"https:"===location.protocol,t.hostname&&!t.port&&(t.port=this.secure?"443":"80"),this.hostname=t.hostname||("undefined"!=typeof location?location.hostname:"localhost"),this.port=t.port||("undefined"!=typeof location&&location.port?location.port:this.secure?"443":"80"),this.transports=t.transports||["polling","websocket"],this.readyState="",this.writeBuffer=[],this.prevBufferLen=0,this.opts=Object.assign({path:"/engine.io",agent:!1,withCredentials:!1,upgrade:!0,timestampParam:"t",rememberUpgrade:!1,rejectUnauthorized:!0,perMessageDeflate:{threshold:1024},transportOptions:{},closeOnBeforeunload:!0},t),this.opts.path=this.opts.path.replace(/\/$/,"")+"/","string"==typeof this.opts.query&&(this.opts.query=function(e){let t={},s=e.split("&");for(let e=0,r=s.length;e{this.transport&&(this.transport.removeAllListeners(),this.transport.close())}),!1),"localhost"!==this.hostname&&(this.offlineEventListener=()=>{this.onClose("transport close",{description:"network connection lost"})},addEventListener("offline",this.offlineEventListener,!1))),this.open()}createTransport(e){const t=Object.assign({},this.opts.query);t.EIO=4,t.transport=e,this.id&&(t.sid=this.id);const s=Object.assign({},this.opts.transportOptions[e],this.opts,{query:t,socket:this,hostname:this.hostname,secure:this.secure,port:this.port});return new os[e](s)}open(){let e;if(this.opts.rememberUpgrade&&ls.priorWebsocketSuccess&&-1!==this.transports.indexOf("websocket"))e="websocket";else{if(0===this.transports.length)return void this.setTimeoutFn((()=>{this.emitReserved("error","No transports available")}),0);e=this.transports[0]}this.readyState="opening";try{e=this.createTransport(e)}catch(e){return this.transports.shift(),void this.open()}e.open(),this.setTransport(e)}setTransport(e){this.transport&&this.transport.removeAllListeners(),this.transport=e,e.on("drain",this.onDrain.bind(this)).on("packet",this.onPacket.bind(this)).on("error",this.onError.bind(this)).on("close",(e=>this.onClose("transport close",e)))}probe(e){let t=this.createTransport(e),s=!1;ls.priorWebsocketSuccess=!1;const r=()=>{s||(t.send([{type:"ping",data:"probe"}]),t.once("packet",(e=>{if(!s)if("pong"===e.type&&"probe"===e.data){if(this.upgrading=!0,this.emitReserved("upgrading",t),!t)return;ls.priorWebsocketSuccess="websocket"===t.name,this.transport.pause((()=>{s||"closed"!==this.readyState&&(c(),this.setTransport(t),t.send([{type:"upgrade"}]),this.emitReserved("upgrade",t),t=null,this.upgrading=!1,this.flush())}))}else{const e=new Error("probe error");e.transport=t.name,this.emitReserved("upgradeError",e)}})))};function i(){s||(s=!0,c(),t.close(),t=null)}const n=e=>{const s=new Error("probe error: "+e);s.transport=t.name,i(),this.emitReserved("upgradeError",s)};function o(){n("transport closed")}function a(){n("socket closed")}function h(e){t&&e.name!==t.name&&i()}const c=()=>{t.removeListener("open",r),t.removeListener("error",n),t.removeListener("close",o),this.off("close",a),this.off("upgrading",h)};t.once("open",r),t.once("error",n),t.once("close",o),this.once("close",a),this.once("upgrading",h),t.open()}onOpen(){if(this.readyState="open",ls.priorWebsocketSuccess="websocket"===this.transport.name,this.emitReserved("open"),this.flush(),"open"===this.readyState&&this.opts.upgrade&&this.transport.pause){let e=0;const t=this.upgrades.length;for(;e{this.onClose("ping timeout")}),this.pingInterval+this.pingTimeout),this.opts.autoUnref&&this.pingTimeoutTimer.unref()}onDrain(){this.writeBuffer.splice(0,this.prevBufferLen),this.prevBufferLen=0,0===this.writeBuffer.length?this.emitReserved("drain"):this.flush()}flush(){if("closed"!==this.readyState&&this.transport.writable&&!this.upgrading&&this.writeBuffer.length){const e=this.getWritablePackets();this.transport.send(e),this.prevBufferLen=e.length,this.emitReserved("flush")}}getWritablePackets(){if(!(this.maxPayload&&"polling"===this.transport.name&&this.writeBuffer.length>1))return this.writeBuffer;let e=1;for(let s=0;s=57344?s+=3:(r++,s+=4);return s}(t):Math.ceil(1.33*(t.byteLength||t.size))),s>0&&e>this.maxPayload)return this.writeBuffer.slice(0,s);e+=2}var t;return this.writeBuffer}write(e,t,s){return this.sendPacket("message",e,t,s),this}send(e,t,s){return this.sendPacket("message",e,t,s),this}sendPacket(e,t,s,r){if("function"==typeof t&&(r=t,t=void 0),"function"==typeof s&&(r=s,s=null),"closing"===this.readyState||"closed"===this.readyState)return;(s=s||{}).compress=!1!==s.compress;const i={type:e,data:t,options:s};this.emitReserved("packetCreate",i),this.writeBuffer.push(i),r&&this.once("flush",r),this.flush()}close(){const e=()=>{this.onClose("forced close"),this.transport.close()},t=()=>{this.off("upgrade",t),this.off("upgradeError",t),e()},s=()=>{this.once("upgrade",t),this.once("upgradeError",t)};return"opening"!==this.readyState&&"open"!==this.readyState||(this.readyState="closing",this.writeBuffer.length?this.once("drain",(()=>{this.upgrading?s():e()})):this.upgrading?s():e()),this}onError(e){ls.priorWebsocketSuccess=!1,this.emitReserved("error",e),this.onClose("transport error",e)}onClose(e,t){"opening"!==this.readyState&&"open"!==this.readyState&&"closing"!==this.readyState||(this.clearTimeoutFn(this.pingTimeoutTimer),this.transport.removeAllListeners("close"),this.transport.close(),this.transport.removeAllListeners(),"function"==typeof removeEventListener&&removeEventListener("offline",this.offlineEventListener,!1),this.readyState="closed",this.id=null,this.emitReserved("close",e,t),this.writeBuffer=[],this.prevBufferLen=0)}filterUpgrades(e){const t=[];let s=0;const r=e.length;for(;s"function"==typeof ArrayBuffer.isView?ArrayBuffer.isView(e):e.buffer instanceof ArrayBuffer)(e))||us&&e instanceof Blob||fs&&e instanceof File}function ms(e,t){if(!e||"object"!=typeof e)return!1;if(Array.isArray(e)){for(let t=0,s=e.length;t0;case Es.ACK:case Es.BINARY_ACK:return Array.isArray(t)}}destroy(){this.reconstructor&&this.reconstructor.finishedReconstruction()}}class Ss{constructor(e){this.packet=e,this.buffers=[],this.reconPack=e}takeBinaryData(e){if(this.buffers.push(e),this.buffers.length===this.reconPack.attachments){const e=bs(this.reconPack,this.buffers);return this.finishedReconstruction(),e}return null}finishedReconstruction(){this.reconPack=null,this.buffers=[]}}var ks=Object.freeze({__proto__:null,protocol:5,get PacketType(){return Es},Encoder:class{constructor(e){this.replacer=e}encode(e){return e.type!==Es.EVENT&&e.type!==Es.ACK||!ms(e)?[this.encodeAsString(e)]:(e.type=e.type===Es.EVENT?Es.BINARY_EVENT:Es.BINARY_ACK,this.encodeAsBinary(e))}encodeAsString(e){let t=""+e.type;return e.type!==Es.BINARY_EVENT&&e.type!==Es.BINARY_ACK||(t+=e.attachments+"-"),e.nsp&&"/"!==e.nsp&&(t+=e.nsp+","),null!=e.id&&(t+=e.id),null!=e.data&&(t+=JSON.stringify(e.data,this.replacer)),t}encodeAsBinary(e){const t=ys(e),s=this.encodeAsString(t.packet),r=t.buffers;return r.unshift(s),r}},Decoder:ws});function xs(e,t,s){return e.on(t,s),function(){e.off(t,s)}}const Os=Object.freeze({connect:1,connect_error:1,disconnect:1,disconnecting:1,newListener:1,removeListener:1});class Ts extends S{constructor(e,t,s){super(),this.connected=!1,this.receiveBuffer=[],this.sendBuffer=[],this.ids=0,this.acks={},this.flags={},this.io=e,this.nsp=t,s&&s.auth&&(this.auth=s.auth),this.io._autoConnect&&this.open()}get disconnected(){return!this.connected}subEvents(){if(this.subs)return;const e=this.io;this.subs=[xs(e,"open",this.onopen.bind(this)),xs(e,"packet",this.onpacket.bind(this)),xs(e,"error",this.onerror.bind(this)),xs(e,"close",this.onclose.bind(this))]}get active(){return!!this.subs}connect(){return this.connected||(this.subEvents(),this.io._reconnecting||this.io.open(),"open"===this.io._readyState&&this.onopen()),this}open(){return this.connect()}send(...e){return e.unshift("message"),this.emit.apply(this,e),this}emit(e,...t){if(Os.hasOwnProperty(e))throw new Error('"'+e+'" is a reserved event name');t.unshift(e);const s={type:Es.EVENT,data:t,options:{}};if(s.options.compress=!1!==this.flags.compress,"function"==typeof t[t.length-1]){const e=this.ids++,r=t.pop();this._registerAckCallback(e,r),s.id=e}const r=this.io.engine&&this.io.engine.transport&&this.io.engine.transport.writable;return this.flags.volatile&&(!r||!this.connected)||(this.connected?(this.notifyOutgoingListeners(s),this.packet(s)):this.sendBuffer.push(s)),this.flags={},this}_registerAckCallback(e,t){const s=this.flags.timeout;if(void 0===s)return void(this.acks[e]=t);const r=this.io.setTimeoutFn((()=>{delete this.acks[e];for(let t=0;t{this.io.clearTimeoutFn(r),t.apply(this,[null,...e])}}packet(e){e.nsp=this.nsp,this.io._packet(e)}onopen(){"function"==typeof this.auth?this.auth((e=>{this.packet({type:Es.CONNECT,data:e})})):this.packet({type:Es.CONNECT,data:this.auth})}onerror(e){this.connected||this.emitReserved("connect_error",e)}onclose(e,t){this.connected=!1,delete this.id,this.emitReserved("disconnect",e,t)}onpacket(e){if(e.nsp===this.nsp)switch(e.type){case Es.CONNECT:if(e.data&&e.data.sid){const t=e.data.sid;this.onconnect(t)}else this.emitReserved("connect_error",new Error("It seems you are trying to reach a Socket.IO server in v2.x with a v3.x client, but they are not compatible (more information here: https://socket.io/docs/v3/migrating-from-2-x-to-3-0/)"));break;case Es.EVENT:case Es.BINARY_EVENT:this.onevent(e);break;case Es.ACK:case Es.BINARY_ACK:this.onack(e);break;case Es.DISCONNECT:this.ondisconnect();break;case Es.CONNECT_ERROR:this.destroy();const t=new Error(e.data.message);t.data=e.data.data,this.emitReserved("connect_error",t)}}onevent(e){const t=e.data||[];null!=e.id&&t.push(this.ack(e.id)),this.connected?this.emitEvent(t):this.receiveBuffer.push(Object.freeze(t))}emitEvent(e){if(this._anyListeners&&this._anyListeners.length){const t=this._anyListeners.slice();for(const s of t)s.apply(this,e)}super.emit.apply(this,e)}ack(e){const t=this;let s=!1;return function(...r){s||(s=!0,t.packet({type:Es.ACK,id:e,data:r}))}}onack(e){const t=this.acks[e.id];"function"==typeof t&&(t.apply(this,e.data),delete this.acks[e.id])}onconnect(e){this.id=e,this.connected=!0,this.emitBuffered(),this.emitReserved("connect")}emitBuffered(){this.receiveBuffer.forEach((e=>this.emitEvent(e))),this.receiveBuffer=[],this.sendBuffer.forEach((e=>{this.notifyOutgoingListeners(e),this.packet(e)})),this.sendBuffer=[]}ondisconnect(){this.destroy(),this.onclose("io server disconnect")}destroy(){this.subs&&(this.subs.forEach((e=>e())),this.subs=void 0),this.io._destroy(this)}disconnect(){return this.connected&&this.packet({type:Es.DISCONNECT}),this.destroy(),this.connected&&this.onclose("io client disconnect"),this}close(){return this.disconnect()}compress(e){return this.flags.compress=e,this}get volatile(){return this.flags.volatile=!0,this}timeout(e){return this.flags.timeout=e,this}onAny(e){return this._anyListeners=this._anyListeners||[],this._anyListeners.push(e),this}prependAny(e){return this._anyListeners=this._anyListeners||[],this._anyListeners.unshift(e),this}offAny(e){if(!this._anyListeners)return this;if(e){const t=this._anyListeners;for(let s=0;s0&&e.jitter<=1?e.jitter:0,this.attempts=0}Ns.prototype.duration=function(){var e=this.ms*Math.pow(this.factor,this.attempts++);if(this.jitter){var t=Math.random(),s=Math.floor(t*this.jitter*e);e=0==(1&Math.floor(10*t))?e-s:e+s}return 0|Math.min(e,this.max)},Ns.prototype.reset=function(){this.attempts=0},Ns.prototype.setMin=function(e){this.ms=e},Ns.prototype.setMax=function(e){this.max=e},Ns.prototype.setJitter=function(e){this.jitter=e};class Rs extends S{constructor(e,t){var s;super(),this.nsps={},this.subs=[],e&&"object"==typeof e&&(t=e,e=void 0),(t=t||{}).path=t.path||"/socket.io",this.opts=t,N(this,t),this.reconnection(!1!==t.reconnection),this.reconnectionAttempts(t.reconnectionAttempts||1/0),this.reconnectionDelay(t.reconnectionDelay||1e3),this.reconnectionDelayMax(t.reconnectionDelayMax||5e3),this.randomizationFactor(null!==(s=t.randomizationFactor)&&void 0!==s?s:.5),this.backoff=new Ns({min:this.reconnectionDelay(),max:this.reconnectionDelayMax(),jitter:this.randomizationFactor()}),this.timeout(null==t.timeout?2e4:t.timeout),this._readyState="closed",this.uri=e;const r=t.parser||ks;this.encoder=new r.Encoder,this.decoder=new r.Decoder,this._autoConnect=!1!==t.autoConnect,this._autoConnect&&this.open()}reconnection(e){return arguments.length?(this._reconnection=!!e,this):this._reconnection}reconnectionAttempts(e){return void 0===e?this._reconnectionAttempts:(this._reconnectionAttempts=e,this)}reconnectionDelay(e){var t;return void 0===e?this._reconnectionDelay:(this._reconnectionDelay=e,null===(t=this.backoff)||void 0===t||t.setMin(e),this)}randomizationFactor(e){var t;return void 0===e?this._randomizationFactor:(this._randomizationFactor=e,null===(t=this.backoff)||void 0===t||t.setJitter(e),this)}reconnectionDelayMax(e){var t;return void 0===e?this._reconnectionDelayMax:(this._reconnectionDelayMax=e,null===(t=this.backoff)||void 0===t||t.setMax(e),this)}timeout(e){return arguments.length?(this._timeout=e,this):this._timeout}maybeReconnectOnOpen(){!this._reconnecting&&this._reconnection&&0===this.backoff.attempts&&this.reconnect()}open(e){if(~this._readyState.indexOf("open"))return this;this.engine=new ls(this.uri,this.opts);const t=this.engine,s=this;this._readyState="opening",this.skipReconnect=!1;const r=xs(t,"open",(function(){s.onopen(),e&&e()})),i=xs(t,"error",(t=>{s.cleanup(),s._readyState="closed",this.emitReserved("error",t),e?e(t):s.maybeReconnectOnOpen()}));if(!1!==this._timeout){const e=this._timeout;0===e&&r();const s=this.setTimeoutFn((()=>{r(),t.close(),t.emit("error",new Error("timeout"))}),e);this.opts.autoUnref&&s.unref(),this.subs.push((function(){clearTimeout(s)}))}return this.subs.push(r),this.subs.push(i),this}connect(e){return this.open(e)}onopen(){this.cleanup(),this._readyState="open",this.emitReserved("open");const e=this.engine;this.subs.push(xs(e,"ping",this.onping.bind(this)),xs(e,"data",this.ondata.bind(this)),xs(e,"error",this.onerror.bind(this)),xs(e,"close",this.onclose.bind(this)),xs(this.decoder,"decoded",this.ondecoded.bind(this)))}onping(){this.emitReserved("ping")}ondata(e){this.decoder.add(e)}ondecoded(e){this.emitReserved("packet",e)}onerror(e){this.emitReserved("error",e)}socket(e,t){let s=this.nsps[e];return s||(s=new Ts(this,e,t),this.nsps[e]=s),s}_destroy(e){const t=Object.keys(this.nsps);for(const e of t){if(this.nsps[e].active)return}this._close()}_packet(e){const t=this.encoder.encode(e);for(let s=0;se())),this.subs.length=0,this.decoder.destroy()}_close(){this.skipReconnect=!0,this._reconnecting=!1,this.onclose("forced close"),this.engine&&this.engine.close()}disconnect(){return this._close()}onclose(e,t){this.cleanup(),this.backoff.reset(),this._readyState="closed",this.emitReserved("close",e,t),this._reconnection&&!this.skipReconnect&&this.reconnect()}reconnect(){if(this._reconnecting||this.skipReconnect)return this;const e=this;if(this.backoff.attempts>=this._reconnectionAttempts)this.backoff.reset(),this.emitReserved("reconnect_failed"),this._reconnecting=!1;else{const t=this.backoff.duration();this._reconnecting=!0;const s=this.setTimeoutFn((()=>{e.skipReconnect||(this.emitReserved("reconnect_attempt",e.backoff.attempts),e.skipReconnect||e.open((t=>{t?(e._reconnecting=!1,e.reconnect(),this.emitReserved("reconnect_error",t)):e.onreconnect()})))}),t);this.opts.autoUnref&&s.unref(),this.subs.push((function(){clearTimeout(s)}))}}onreconnect(){const e=this.backoff.attempts;this._reconnecting=!1,this.backoff.reset(),this.emitReserved("reconnect",e)}}const Cs={};function Ls(e,t){"object"==typeof e&&(t=e,e=void 0);const s=function(e,t="",s){let r=e;s=s||"undefined"!=typeof location&&location,null==e&&(e=s.protocol+"//"+s.host),"string"==typeof e&&("/"===e.charAt(0)&&(e="/"===e.charAt(1)?s.protocol+e:s.host+e),/^(https?|wss?):\/\//.test(e)||(e=void 0!==s?s.protocol+"//"+e:"https://"+e),r=cs(e)),r.port||(/^(http|ws)$/.test(r.protocol)?r.port="80":/^(http|ws)s$/.test(r.protocol)&&(r.port="443")),r.path=r.path||"/";const i=-1!==r.host.indexOf(":")?"["+r.host+"]":r.host;return r.id=r.protocol+"://"+i+":"+r.port+t,r.href=r.protocol+"://"+i+(s&&s.port===r.port?"":":"+r.port),r}(e,(t=t||{}).path||"/socket.io"),r=s.source,i=s.id,n=s.path,o=Cs[i]&&n in Cs[i].nsps;let a;return t.forceNew||t["force new connection"]||!1===t.multiplex||o?a=new Rs(r,t):(Cs[i]||(Cs[i]=new Rs(r,t)),a=Cs[i]),s.query&&!t.query&&(t.query=s.queryKey),a.socket(s.path,t)}Object.assign(Ls,{Manager:Rs,Socket:Ts,io:Ls,connect:Ls});var As="e";var Bs="jr",Ps="jc";const Is=e=>()=>e;const{default:Ds}=await import(e.resolve("executor.config.js")),Us=process.argv.slice(2),js=function(e){const t={...e};for(var s in t)"function"!=typeof t[s]&&(t[s]=Is(t[s]));return t}(Ds(Us)),Fs=new class{constructor(e,t,s={}){this.url=t.url(e)??process.env.QUALITEER_URL,this.jobId=t.jobId(e)??process.env.QUALITEER_JOB_ID,this.command=t.command(e)??process.env.QUALITEER_COMMAND,this.mode=As,this.buf={},this.buf.e="",this.buf.o="",this.spawn=s.spawn??this.spawn.bind(this),this.report=s.report??this.report.bind(this),this.onProcClose=s.onProcClose??this.onProcClose.bind(this),this.onClose=s.onClose??this.onClose.bind(this)}spawn(){const e=this.command,t=e.shift();this.proc=r.spawn(t,e),this.proc.stdout.setEncoding("utf8"),this.proc.stderr.setEncoding("utf8"),this.proc.stdout.on("data",(e=>this.report(e.toString(),"o"))),this.proc.stderr.on("data",(e=>this.report(e.toString(),"e"))),this.proc.on("close",this.onProcClose)}runJob(){const e=new Rs(this.url,{query:{mode:this.mode,jobId:this.jobId}});this.socket=e.socket("/"),this.socket.on("connect",this.spawn),this.socket.on("disconnect",this.onClose)}onClose(){console.log("Server disconnected, terminating process."),this.proc&&this.proc.kill("SIGKILL")}onProcClose(e){this.socket.emit(Ps,e),console.log(`Process finished with code ${e}`),this.socket.disconnect()}report(e,t){this.buf[t]+=e,this.buf[t].includes("\n")&&(this.buf[t].endsWith("\n")&&(this.buf[t]=this.buf[t].slice(0,-1)),this.socket.emit(Bs,this.buf[t]),"e"===t?console.error(`err: ${this.buf[t]}`):console.log(`out: ${this.buf[t]}`),this.buf[t]="")}}(Us,js);Fs.runJob(); +var F=t,M=s,q=r.spawn,W=V;function V(e){e=e||{};var t,s,r=this,o=i,a=n,h={},c=!1,l={"User-Agent":"node-XMLHttpRequest",Accept:"*/*"},d=Object.assign({},l),p=["accept-charset","accept-encoding","access-control-request-headers","access-control-request-method","connection","content-length","content-transfer-encoding","cookie","cookie2","date","expect","host","keep-alive","origin","referer","te","trailer","transfer-encoding","upgrade","via"],u=["TRACE","TRACK","CONNECT"],f=!1,_=!1,m=!1,y={};this.UNSENT=0,this.OPENED=1,this.HEADERS_RECEIVED=2,this.LOADING=3,this.DONE=4,this.readyState=this.UNSENT,this.onreadystatechange=null,this.responseText="",this.responseXML="",this.status=null,this.statusText=null;this.open=function(e,t,s,r,i){if(this.abort(),_=!1,m=!1,!function(e){return e&&-1===u.indexOf(e)}(e))throw new Error("SecurityError: Request method not allowed");h={method:e,url:t.toString(),async:"boolean"!=typeof s||s,user:r||null,password:i||null},g(this.OPENED)},this.setDisableHeaderCheck=function(e){c=e},this.setRequestHeader=function(e,t){if(this.readyState!=this.OPENED)throw new Error("INVALID_STATE_ERR: setRequestHeader can only be called when state is OPEN");if(!function(e){return c||e&&-1===p.indexOf(e.toLowerCase())}(e))return console.warn('Refused to set unsafe header "'+e+'"'),!1;if(f)throw new Error("INVALID_STATE_ERR: send flag is true");return d[e]=t,!0},this.getResponseHeader=function(e){return"string"==typeof e&&this.readyState>this.OPENED&&s.headers[e.toLowerCase()]&&!_?s.headers[e.toLowerCase()]:null},this.getAllResponseHeaders=function(){if(this.readyState{e.unref()})),i&&t.write(i),t.end(),r.dispatchEvent("loadstart")}else{var k=".node-xmlhttprequest-content-"+process.pid,x=".node-xmlhttprequest-sync-"+process.pid;F.writeFileSync(x,"","utf8");for(var O="var http = require('http'), https = require('https'), fs = require('fs');var doRequest = http"+(c?"s":"")+".request;var options = "+JSON.stringify(v)+";var responseText = '';var req = doRequest(options, function(response) {response.setEncoding('utf8');response.on('data', function(chunk) { responseText += chunk;});response.on('end', function() {fs.writeFileSync('"+k+"', 'NODE-XMLHTTPREQUEST-STATUS:' + response.statusCode + ',' + responseText, 'utf8');fs.unlinkSync('"+x+"');});response.on('error', function(error) {fs.writeFileSync('"+k+"', 'NODE-XMLHTTPREQUEST-ERROR:' + JSON.stringify(error), 'utf8');fs.unlinkSync('"+x+"');});}).on('error', function(error) {fs.writeFileSync('"+k+"', 'NODE-XMLHTTPREQUEST-ERROR:' + JSON.stringify(error), 'utf8');fs.unlinkSync('"+x+"');});"+(i?"req.write('"+JSON.stringify(i).slice(1,-1).replace(/'/g,"\\'")+"');":"")+"req.end();",T=q(process.argv[0],["-e",O]);F.existsSync(x););if(r.responseText=F.readFileSync(k,"utf8"),T.stdin.end(),F.unlinkSync(k),r.responseText.match(/^NODE-XMLHTTPREQUEST-ERROR:/)){var N=r.responseText.replace(/^NODE-XMLHTTPREQUEST-ERROR:/,"");r.handleError(N,503)}else r.status=r.responseText.replace(/^NODE-XMLHTTPREQUEST-STATUS:([0-9]*),.*/,"$1"),r.responseText=r.responseText.replace(/^NODE-XMLHTTPREQUEST-STATUS:[0-9]*,(.*)/,"$1"),g(r.DONE)}}},this.handleError=function(e,t){this.status=t||0,this.statusText=e,this.responseText=e.stack,_=!0,g(this.DONE)},this.abort=function(){t&&(t.abort(),t=null),d=Object.assign({},l),this.responseText="",this.responseXML="",_=m=!0,this.readyState===this.UNSENT||this.readyState===this.OPENED&&!f||this.readyState===this.DONE||(f=!1,g(this.DONE)),this.readyState=this.UNSENT},this.addEventListener=function(e,t){e in y||(y[e]=[]),y[e].push(t)},this.removeEventListener=function(e,t){e in y&&(y[e]=y[e].filter((function(e){return e!==t})))},this.dispatchEvent=function(e){if("function"==typeof r["on"+e]&&(this.readyState===this.DONE?setImmediate((function(){r["on"+e]()})):r["on"+e]()),e in y)for(let t=0,s=y[e].length;t{4===t.readyState&&(200===t.status||1223===t.status?this.onLoad():this.setTimeoutFn((()=>{this.onError("number"==typeof t.status?t.status:0)}),0))},t.send(this.data)}catch(e){return void this.setTimeoutFn((()=>{this.onError(e)}),0)}"undefined"!=typeof document&&(this.index=z.requestsCount++,z.requests[this.index]=this)}onError(e){this.emitReserved("error",e,this.xhr),this.cleanup(!0)}cleanup(e){if(void 0!==this.xhr&&null!==this.xhr){if(this.xhr.onreadystatechange=G,e)try{this.xhr.abort()}catch(e){}"undefined"!=typeof document&&delete z.requests[this.index],this.xhr=null}}onLoad(){const e=this.xhr.responseText;null!==e&&(this.emitReserved("data",e),this.emitReserved("success"),this.cleanup())}abort(){this.cleanup()}}if(z.requestsCount=0,z.requests={},"undefined"!=typeof document)if("function"==typeof attachEvent)attachEvent("onunload",Y);else if("function"==typeof addEventListener){addEventListener("onpagehide"in k?"pagehide":"unload",Y,!1)}function Y(){for(let e in z.requests)z.requests.hasOwnProperty(e)&&z.requests[e].abort()}var K={exports:{}},X={BINARY_TYPES:["nodebuffer","arraybuffer","fragments"],EMPTY_BUFFER:Buffer.alloc(0),GUID:"258EAFA5-E914-47DA-95CA-C5AB0DC85B11",kForOnEventAttribute:Symbol("kIsForOnEventAttribute"),kListener:Symbol("kListener"),kStatusCode:Symbol("status-code"),kWebSocket:Symbol("websocket"),NOOP:()=>{}};const{EMPTY_BUFFER:J}=X;function Q(e,t){if(0===e.length)return J;if(1===e.length)return e[0];const s=Buffer.allocUnsafe(t);let r=0;for(let t=0;t{this.pending--,this[ie]()},this.concurrency=e||1/0,this.jobs=[],this.pending=0}add(e){this.jobs.push(e),this[ie]()}[ie](){if(this.pending!==this.concurrency&&this.jobs.length){const e=this.jobs.shift();this.pending++,e(this[re])}}};const oe=a,ae=K.exports,he=ne,{kStatusCode:ce}=X,le=Buffer.from([0,0,255,255]),de=Symbol("permessage-deflate"),pe=Symbol("total-length"),ue=Symbol("callback"),fe=Symbol("buffers"),_e=Symbol("error");let me;var ye=class{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,!me){const e=void 0!==this._options.concurrencyLimit?this._options.concurrencyLimit:10;me=new he(e)}}static get extensionName(){return"permessage-deflate"}offer(){const 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){const e=this._deflate[ue];this._deflate.close(),this._deflate=null,e&&e(new Error("The deflate stream was closed while data was being processed"))}}acceptAsServer(e){const 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 new 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){const t=e[0];if(!1===this._options.clientNoContextTakeover&&t.client_no_context_takeover)throw new 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 new 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 new Error(`Parameter "${t}" must have only a single value`);if(s=s[0],"client_max_window_bits"===t){if(!0!==s){const e=+s;if(!Number.isInteger(e)||e<8||e>15)throw new TypeError(`Invalid value for parameter "${t}": ${s}`);s=e}else if(!this._isServer)throw new TypeError(`Invalid value for parameter "${t}": ${s}`)}else if("server_max_window_bits"===t){const e=+s;if(!Number.isInteger(e)||e<8||e>15)throw new TypeError(`Invalid value for parameter "${t}": ${s}`);s=e}else{if("client_no_context_takeover"!==t&&"server_no_context_takeover"!==t)throw new Error(`Unknown parameter "${t}"`);if(!0!==s)throw new TypeError(`Invalid value for parameter "${t}": ${s}`)}e[t]=s}))})),e}decompress(e,t,s){me.add((r=>{this._decompress(e,t,((e,t)=>{r(),s(e,t)}))}))}compress(e,t,s){me.add((r=>{this._compress(e,t,((e,t)=>{r(),s(e,t)}))}))}_decompress(e,t,s){const r=this._isServer?"client":"server";if(!this._inflate){const e=`${r}_max_window_bits`,t="number"!=typeof this.params[e]?oe.Z_DEFAULT_WINDOWBITS:this.params[e];this._inflate=oe.createInflateRaw({...this._options.zlibInflateOptions,windowBits:t}),this._inflate[de]=this,this._inflate[pe]=0,this._inflate[fe]=[],this._inflate.on("error",ve),this._inflate.on("data",be)}this._inflate[ue]=s,this._inflate.write(e),t&&this._inflate.write(le),this._inflate.flush((()=>{const e=this._inflate[_e];if(e)return this._inflate.close(),this._inflate=null,void s(e);const i=ae.concat(this._inflate[fe],this._inflate[pe]);this._inflate._readableState.endEmitted?(this._inflate.close(),this._inflate=null):(this._inflate[pe]=0,this._inflate[fe]=[],t&&this.params[`${r}_no_context_takeover`]&&this._inflate.reset()),s(null,i)}))}_compress(e,t,s){const r=this._isServer?"server":"client";if(!this._deflate){const e=`${r}_max_window_bits`,t="number"!=typeof this.params[e]?oe.Z_DEFAULT_WINDOWBITS:this.params[e];this._deflate=oe.createDeflateRaw({...this._options.zlibDeflateOptions,windowBits:t}),this._deflate[pe]=0,this._deflate[fe]=[],this._deflate.on("data",ge)}this._deflate[ue]=s,this._deflate.write(e),this._deflate.flush(oe.Z_SYNC_FLUSH,(()=>{if(!this._deflate)return;let e=ae.concat(this._deflate[fe],this._deflate[pe]);t&&(e=e.slice(0,e.length-4)),this._deflate[ue]=null,this._deflate[pe]=0,this._deflate[fe]=[],t&&this.params[`${r}_no_context_takeover`]&&this._deflate.reset(),s(null,e)}))}};function ge(e){this[fe].push(e),this[pe]+=e.length}function be(e){this[pe]+=e.length,this[de]._maxPayload<1||this[pe]<=this[de]._maxPayload?this[fe].push(e):(this[_e]=new RangeError("Max payload size exceeded"),this[_e].code="WS_ERR_UNSUPPORTED_MESSAGE_LENGTH",this[_e][ce]=1009,this.removeListener("data",be),this.reset())}function ve(e){this[de]._inflate=null,e[ce]=1007,this[ue](e)}var Ee={exports:{}};const we=[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 Se(e){return e>=1e3&&e<=1014&&1004!==e&&1005!==e&&1006!==e||e>=3e3&&e<=4999}function ke(e){const t=e.length;let s=0;for(;s=t||128!=(192&e[s+1])||128!=(192&e[s+2])||224===e[s]&&128==(224&e[s+1])||237===e[s]&&160==(224&e[s+1]))return!1;s+=3}else{if(240!=(248&e[s]))return!1;if(s+3>=t||128!=(192&e[s+1])||128!=(192&e[s+2])||128!=(192&e[s+3])||240===e[s]&&128==(240&e[s+1])||244===e[s]&&e[s+1]>143||e[s]>244)return!1;s+=4}return!0}try{const e=require("utf-8-validate");Ee.exports={isValidStatusCode:Se,isValidUTF8:t=>t.length<150?ke(t):e(t),tokenChars:we}}catch(e){Ee.exports={isValidStatusCode:Se,isValidUTF8:ke,tokenChars:we}}const{Writable:xe}=o,Oe=ye,{BINARY_TYPES:Te,EMPTY_BUFFER:Ne,kStatusCode:Re,kWebSocket:Ce}=X,{concat:Le,toArrayBuffer:Ae,unmask:Be}=K.exports,{isValidStatusCode:Pe,isValidUTF8:Ie}=Ee.exports;var De=class extends xe{constructor(e={}){super(),this._binaryType=e.binaryType||Te[0],this._extensions=e.extensions||{},this._isServer=!!e.isServer,this._maxPayload=0|e.maxPayload,this._skipUTF8Validation=!!e.skipUTF8Validation,this[Ce]=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._state=0,this._loop=!1}_write(e,t,s){if(8===this._opcode&&0==this._state)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=s.length?t.set(this._buffers.shift(),r):(t.set(new Uint8Array(s.buffer,s.byteOffset,e),r),this._buffers[0]=s.slice(e)),e-=s.length}while(e>0);return t}startLoop(e){let t;this._loop=!0;do{switch(this._state){case 0:t=this.getInfo();break;case 1:t=this.getPayloadLength16();break;case 2:t=this.getPayloadLength64();break;case 3:this.getMask();break;case 4:t=this.getData(e);break;default:return void(this._loop=!1)}}while(this._loop);e(t)}getInfo(){if(this._bufferedBytes<2)return void(this._loop=!1);const e=this.consume(2);if(0!=(48&e[0]))return this._loop=!1,Ue(RangeError,"RSV2 and RSV3 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_2_3");const t=64==(64&e[0]);if(t&&!this._extensions[Oe.extensionName])return this._loop=!1,Ue(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");if(this._fin=128==(128&e[0]),this._opcode=15&e[0],this._payloadLength=127&e[1],0===this._opcode){if(t)return this._loop=!1,Ue(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");if(!this._fragmented)return this._loop=!1,Ue(RangeError,"invalid opcode 0",!0,1002,"WS_ERR_INVALID_OPCODE");this._opcode=this._fragmented}else if(1===this._opcode||2===this._opcode){if(this._fragmented)return this._loop=!1,Ue(RangeError,`invalid opcode ${this._opcode}`,!0,1002,"WS_ERR_INVALID_OPCODE");this._compressed=t}else{if(!(this._opcode>7&&this._opcode<11))return this._loop=!1,Ue(RangeError,`invalid opcode ${this._opcode}`,!0,1002,"WS_ERR_INVALID_OPCODE");if(!this._fin)return this._loop=!1,Ue(RangeError,"FIN must be set",!0,1002,"WS_ERR_EXPECTED_FIN");if(t)return this._loop=!1,Ue(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");if(this._payloadLength>125)return this._loop=!1,Ue(RangeError,`invalid payload length ${this._payloadLength}`,!0,1002,"WS_ERR_INVALID_CONTROL_PAYLOAD_LENGTH")}if(this._fin||this._fragmented||(this._fragmented=this._opcode),this._masked=128==(128&e[1]),this._isServer){if(!this._masked)return this._loop=!1,Ue(RangeError,"MASK must be set",!0,1002,"WS_ERR_EXPECTED_MASK")}else if(this._masked)return this._loop=!1,Ue(RangeError,"MASK must be clear",!0,1002,"WS_ERR_UNEXPECTED_MASK");if(126===this._payloadLength)this._state=1;else{if(127!==this._payloadLength)return this.haveLength();this._state=2}}getPayloadLength16(){if(!(this._bufferedBytes<2))return this._payloadLength=this.consume(2).readUInt16BE(0),this.haveLength();this._loop=!1}getPayloadLength64(){if(this._bufferedBytes<8)return void(this._loop=!1);const e=this.consume(8),t=e.readUInt32BE(0);return t>Math.pow(2,21)-1?(this._loop=!1,Ue(RangeError,"Unsupported WebSocket frame: payload length > 2^53 - 1",!1,1009,"WS_ERR_UNSUPPORTED_DATA_PAYLOAD_LENGTH")):(this._payloadLength=t*Math.pow(2,32)+e.readUInt32BE(4),this.haveLength())}haveLength(){if(this._payloadLength&&this._opcode<8&&(this._totalPayloadLength+=this._payloadLength,this._totalPayloadLength>this._maxPayload&&this._maxPayload>0))return this._loop=!1,Ue(RangeError,"Max payload size exceeded",!1,1009,"WS_ERR_UNSUPPORTED_MESSAGE_LENGTH");this._masked?this._state=3:this._state=4}getMask(){this._bufferedBytes<4?this._loop=!1:(this._mask=this.consume(4),this._state=4)}getData(e){let t=Ne;if(this._payloadLength){if(this._bufferedBytes7?this.controlMessage(t):this._compressed?(this._state=5,void this.decompress(t,e)):(t.length&&(this._messageLength=this._totalPayloadLength,this._fragments.push(t)),this.dataMessage())}decompress(e,t){this._extensions[Oe.extensionName].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)return t(Ue(RangeError,"Max payload size exceeded",!1,1009,"WS_ERR_UNSUPPORTED_MESSAGE_LENGTH"));this._fragments.push(s)}const r=this.dataMessage();if(r)return t(r);this.startLoop(t)}))}dataMessage(){if(this._fin){const e=this._messageLength,t=this._fragments;if(this._totalPayloadLength=0,this._messageLength=0,this._fragmented=0,this._fragments=[],2===this._opcode){let s;s="nodebuffer"===this._binaryType?Le(t,e):"arraybuffer"===this._binaryType?Ae(Le(t,e)):t,this.emit("message",s,!0)}else{const s=Le(t,e);if(!this._skipUTF8Validation&&!Ie(s))return this._loop=!1,Ue(Error,"invalid UTF-8 sequence",!0,1007,"WS_ERR_INVALID_UTF8");this.emit("message",s,!1)}}this._state=0}controlMessage(e){if(8===this._opcode)if(this._loop=!1,0===e.length)this.emit("conclude",1005,Ne),this.end();else{if(1===e.length)return Ue(RangeError,"invalid payload length 1",!0,1002,"WS_ERR_INVALID_CONTROL_PAYLOAD_LENGTH");{const t=e.readUInt16BE(0);if(!Pe(t))return Ue(RangeError,`invalid status code ${t}`,!0,1002,"WS_ERR_INVALID_CLOSE_CODE");const s=e.slice(2);if(!this._skipUTF8Validation&&!Ie(s))return Ue(Error,"invalid UTF-8 sequence",!0,1007,"WS_ERR_INVALID_UTF8");this.emit("conclude",t,s),this.end()}}else 9===this._opcode?this.emit("ping",e):this.emit("pong",e);this._state=0}};function Ue(e,t,s,r,i){const n=new e(s?`Invalid WebSocket frame: ${t}`:t);return Error.captureStackTrace(n,Ue),n.code=i,n[Re]=r,n}const{randomFillSync:je}=l,Fe=ye,{EMPTY_BUFFER:Me}=X,{isValidStatusCode:qe}=Ee.exports,{mask:We,toBuffer:Ve}=K.exports,$e=Buffer.alloc(4);class Ge{constructor(e,t){this._extensions=t||{},this._socket=e,this._firstFragment=!0,this._compress=!1,this._bufferedBytes=0,this._deflating=!1,this._queue=[]}static frame(e,t){const s=t.mask&&t.readOnly;let r=t.mask?6:2,i=e.length;e.length>=65536?(r+=8,i=127):e.length>125&&(r+=2,i=126);const n=Buffer.allocUnsafe(s?e.length+r:r);return n[0]=t.fin?128|t.opcode:t.opcode,t.rsv1&&(n[0]|=64),n[1]=i,126===i?n.writeUInt16BE(e.length,2):127===i&&(n.writeUInt32BE(0,2),n.writeUInt32BE(e.length,6)),t.mask?(je($e,0,4),n[1]|=128,n[r-4]=$e[0],n[r-3]=$e[1],n[r-2]=$e[2],n[r-1]=$e[3],s?(We(e,$e,n,r,e.length),[n]):(We(e,$e,e,0,e.length),[n,e])):[n,e]}close(e,t,s,r){let i;if(void 0===e)i=Me;else{if("number"!=typeof e||!qe(e))throw new TypeError("First argument must be a valid error code number");if(void 0!==t&&t.length){const s=Buffer.byteLength(t);if(s>123)throw new RangeError("The message must not be greater than 123 bytes");i=Buffer.allocUnsafe(2+s),i.writeUInt16BE(e,0),"string"==typeof t?i.write(t,2):i.set(t,2)}else i=Buffer.allocUnsafe(2),i.writeUInt16BE(e,0)}this._deflating?this.enqueue([this.doClose,i,s,r]):this.doClose(i,s,r)}doClose(e,t,s){this.sendFrame(Ge.frame(e,{fin:!0,rsv1:!1,opcode:8,mask:t,readOnly:!1}),s)}ping(e,t,s){const r=Ve(e);if(r.length>125)throw new RangeError("The data size must not be greater than 125 bytes");this._deflating?this.enqueue([this.doPing,r,t,Ve.readOnly,s]):this.doPing(r,t,Ve.readOnly,s)}doPing(e,t,s,r){this.sendFrame(Ge.frame(e,{fin:!0,rsv1:!1,opcode:9,mask:t,readOnly:s}),r)}pong(e,t,s){const r=Ve(e);if(r.length>125)throw new RangeError("The data size must not be greater than 125 bytes");this._deflating?this.enqueue([this.doPong,r,t,Ve.readOnly,s]):this.doPong(r,t,Ve.readOnly,s)}doPong(e,t,s,r){this.sendFrame(Ge.frame(e,{fin:!0,rsv1:!1,opcode:10,mask:t,readOnly:s}),r)}send(e,t,s){const r=Ve(e),i=this._extensions[Fe.extensionName];let n=t.binary?2:1,o=t.compress;if(this._firstFragment?(this._firstFragment=!1,o&&i&&i.params[i._isServer?"server_no_context_takeover":"client_no_context_takeover"]&&(o=r.length>=i._threshold),this._compress=o):(o=!1,n=0),t.fin&&(this._firstFragment=!0),i){const e={fin:t.fin,rsv1:o,opcode:n,mask:t.mask,readOnly:Ve.readOnly};this._deflating?this.enqueue([this.dispatch,r,this._compress,e,s]):this.dispatch(r,this._compress,e,s)}else this.sendFrame(Ge.frame(r,{fin:t.fin,rsv1:!1,opcode:n,mask:t.mask,readOnly:Ve.readOnly}),s)}dispatch(e,t,s,r){if(!t)return void this.sendFrame(Ge.frame(e,s),r);const i=this._extensions[Fe.extensionName];this._bufferedBytes+=e.length,this._deflating=!0,i.compress(e,s.fin,((t,i)=>{if(this._socket.destroyed){const e=new Error("The socket was closed while data was being compressed");"function"==typeof r&&r(e);for(let t=0;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(", ")},parse:function(e){const t=Object.create(null);let s,r,i=Object.create(null),n=!1,o=!1,a=!1,h=-1,c=-1,l=-1,d=0;for(;d0&&e.unshift(t),e.on("close",Zt),e.on("data",es),e.on("end",ts),e.on("error",ss),this._readyState=Ft.OPEN,this.emit("open")}emitClose(){if(!this._socket)return this._readyState=Ft.CLOSED,void this.emit("close",this._closeCode,this._closeMessage);this._extensions[vt.extensionName]&&this._extensions[vt.extensionName].cleanup(),this._receiver.removeAllListeners(),this._readyState=Ft.CLOSED,this.emit("close",this._closeCode,this._closeMessage)}close(e,t){if(this.readyState!==Ft.CLOSED){if(this.readyState===Ft.CONNECTING){const e="WebSocket was closed before the connection was established";return Vt(this,this._req,e)}this.readyState!==Ft.CLOSING?(this._readyState=Ft.CLOSING,this._sender.close(e,t,!this._isServer,(e=>{e||(this._closeFrameSent=!0,(this._closeFrameReceived||this._receiver._writableState.errorEmitted)&&this._socket.end())})),this._closeTimer=setTimeout(this._socket.destroy.bind(this._socket),3e4)):this._closeFrameSent&&(this._closeFrameReceived||this._receiver._writableState.errorEmitted)&&this._socket.end()}}ping(e,t,s){if(this.readyState===Ft.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");"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===Ft.OPEN?(void 0===t&&(t=!this._isServer),this._sender.ping(e||kt,t,s)):$t(this,e,s)}pong(e,t,s){if(this.readyState===Ft.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");"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===Ft.OPEN?(void 0===t&&(t=!this._isServer),this._sender.pong(e||kt,t,s)):$t(this,e,s)}send(e,t,s){if(this.readyState===Ft.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");if("function"==typeof t&&(s=t,t={}),"number"==typeof e&&(e=e.toString()),this.readyState!==Ft.OPEN)return void $t(this,e,s);const r={binary:"string"!=typeof e,mask:!this._isServer,compress:!0,fin:!0,...t};this._extensions[vt.extensionName]||(r.compress=!1),this._sender.send(e||kt,r,s)}terminate(){if(this.readyState!==Ft.CLOSED){if(this.readyState===Ft.CONNECTING){const e="WebSocket was closed before the connection was established";return Vt(this,this._req,e)}this._socket&&(this._readyState=Ft.CLOSING,this._socket.destroy())}}}function Mt(e,t,s,r){const i={protocolVersion:jt[1],maxPayload:104857600,skipUTF8Validation:!1,perMessageDeflate:!0,followRedirects:!1,maxRedirects:10,...r,createConnection:void 0,socketPath:void 0,hostname:void 0,protocol:void 0,timeout:void 0,method:void 0,host:void 0,path:void 0,port:void 0};if(!jt.includes(i.protocolVersion))throw new RangeError(`Unsupported protocol version: ${i.protocolVersion} (supported versions: ${jt.join(", ")})`);let n;if(t instanceof bt)n=t,e._url=t.href;else{try{n=new bt(t)}catch(e){throw new SyntaxError(`Invalid URL: ${t}`)}e._url=t}const o="wss:"===n.protocol,a="ws+unix:"===n.protocol;if("ws:"!==n.protocol&&!o&&!a)throw new SyntaxError('The URL\'s protocol must be one of "ws:", "wss:", or "ws+unix:"');if(a&&!n.pathname)throw new SyntaxError("The URL's pathname is empty");if(n.hash)throw new SyntaxError("The URL contains a fragment identifier");const h=o?443:80,c=yt(16).toString("base64"),l=o?ut.get:ft.get,d=new Set;let p;if(i.createConnection=o?Wt:qt,i.defaultPort=i.defaultPort||h,i.port=n.port||h,i.host=n.hostname.startsWith("[")?n.hostname.slice(1,-1):n.hostname,i.headers={"Sec-WebSocket-Version":i.protocolVersion,"Sec-WebSocket-Key":c,Connection:"Upgrade",Upgrade:"websocket",...i.headers},i.path=n.pathname+n.search,i.timeout=i.handshakeTimeout,i.perMessageDeflate&&(p=new vt(!0!==i.perMessageDeflate?i.perMessageDeflate:{},!1,i.maxPayload),i.headers["Sec-WebSocket-Extensions"]=Bt({[vt.extensionName]:p.offer()})),s.length){for(const e of s){if("string"!=typeof e||!Ut.test(e)||d.has(e))throw new SyntaxError("An invalid or duplicated subprotocol was specified");d.add(e)}i.headers["Sec-WebSocket-Protocol"]=s.join(",")}if(i.origin&&(i.protocolVersion<13?i.headers["Sec-WebSocket-Origin"]=i.origin:i.headers.Origin=i.origin),(n.username||n.password)&&(i.auth=`${n.username}:${n.password}`),a){const e=i.path.split(":");i.socketPath=e[0],i.path=e[1]}let u=e._req=l(i);i.timeout&&u.on("timeout",(()=>{Vt(e,u,"Opening handshake has timed out")})),u.on("error",(t=>{null===u||u.aborted||(u=e._req=null,e._readyState=Ft.CLOSING,e.emit("error",t),e.emitClose())})),u.on("response",(n=>{const o=n.headers.location,a=n.statusCode;if(o&&i.followRedirects&&a>=300&&a<400){if(++e._redirects>i.maxRedirects)return void Vt(e,u,"Maximum redirects exceeded");u.abort();const n=new bt(o,t);Mt(e,n,s,r)}else e.emit("unexpected-response",u,n)||Vt(e,u,`Unexpected server response: ${n.statusCode}`)})),u.on("upgrade",((t,s,r)=>{if(e.emit("upgrade",t),e.readyState!==Ft.CONNECTING)return;u=e._req=null;const n=gt("sha1").update(c+xt).digest("base64");if(t.headers["sec-websocket-accept"]!==n)return void Vt(e,s,"Invalid Sec-WebSocket-Accept header");const o=t.headers["sec-websocket-protocol"];let a;if(void 0!==o?d.size?d.has(o)||(a="Server sent an invalid subprotocol"):a="Server sent a subprotocol but none was requested":d.size&&(a="Server sent no subprotocol"),a)return void Vt(e,s,a);o&&(e._protocol=o);const h=t.headers["sec-websocket-extensions"];if(void 0!==h){if(!p){return void Vt(e,s,"Server sent a Sec-WebSocket-Extensions header but no extension was requested")}let t;try{t=Pt(h)}catch(t){return void Vt(e,s,"Invalid Sec-WebSocket-Extensions header")}const r=Object.keys(t);if(1!==r.length||r[0]!==vt.extensionName){return void Vt(e,s,"Server indicated an extension that was not requested")}try{p.accept(t[vt.extensionName])}catch(t){return void Vt(e,s,"Invalid Sec-WebSocket-Extensions header")}e._extensions[vt.extensionName]=p}e.setSocket(s,r,{maxPayload:i.maxPayload,skipUTF8Validation:i.skipUTF8Validation})}))}function qt(e){return e.path=e.socketPath,_t.connect(e)}function Wt(e){return e.path=void 0,e.servername||""===e.servername||(e.servername=_t.isIP(e.host)?"":e.host),mt.connect(e)}function Vt(e,t,s){e._readyState=Ft.CLOSING;const r=new Error(s);Error.captureStackTrace(r,Vt),t.setHeader?(t.abort(),t.socket&&!t.socket.destroyed&&t.socket.destroy(),t.once("abort",e.emitClose.bind(e)),e.emit("error",r)):(t.destroy(r),t.once("error",e.emit.bind(e,"error")),t.once("close",e.emitClose.bind(e)))}function $t(e,t,s){if(t){const s=It(t).length;e._socket?e._sender._bufferedBytes+=s:e._bufferedAmount+=s}if(s){s(new Error(`WebSocket is not open: readyState ${e.readyState} (${Dt[e.readyState]})`))}}function Gt(e,t){const s=this[Rt];s._closeFrameReceived=!0,s._closeMessage=t,s._closeCode=e,void 0!==s._socket[Rt]&&(s._socket.removeListener("data",es),process.nextTick(Qt,s._socket),1005===e?s.close():s.close(e,t))}function Ht(){this[Rt]._socket.resume()}function zt(e){const t=this[Rt];void 0!==t._socket[Rt]&&(t._socket.removeListener("data",es),process.nextTick(Qt,t._socket),t.close(e[Nt])),t.emit("error",e)}function Yt(){this[Rt].emitClose()}function Kt(e,t){this[Rt].emit("message",e,t)}function Xt(e){const t=this[Rt];t.pong(e,!t._isServer,Ct),t.emit("ping",e)}function Jt(e){this[Rt].emit("pong",e)}function Qt(e){e.resume()}function Zt(){const e=this[Rt];let t;this.removeListener("close",Zt),this.removeListener("data",es),this.removeListener("end",ts),e._readyState=Ft.CLOSING,this._readableState.endEmitted||e._closeFrameReceived||e._receiver._writableState.errorEmitted||null===(t=e._socket.read())||e._receiver.write(t),e._receiver.end(),this[Rt]=void 0,clearTimeout(e._closeTimer),e._receiver._writableState.finished||e._receiver._writableState.errorEmitted?e.emitClose():(e._receiver.on("error",Yt),e._receiver.on("finish",Yt))}function es(e){this[Rt]._receiver.write(e)||this.pause()}function ts(){const e=this[Rt];e._readyState=Ft.CLOSING,e._receiver.end(),this.end()}function ss(){const e=this[Rt];this.removeListener("error",ss),this.on("error",Ct),e&&(e._readyState=Ft.CLOSING,this.destroy())}Object.defineProperty(Ft,"CONNECTING",{enumerable:!0,value:Dt.indexOf("CONNECTING")}),Object.defineProperty(Ft.prototype,"CONNECTING",{enumerable:!0,value:Dt.indexOf("CONNECTING")}),Object.defineProperty(Ft,"OPEN",{enumerable:!0,value:Dt.indexOf("OPEN")}),Object.defineProperty(Ft.prototype,"OPEN",{enumerable:!0,value:Dt.indexOf("OPEN")}),Object.defineProperty(Ft,"CLOSING",{enumerable:!0,value:Dt.indexOf("CLOSING")}),Object.defineProperty(Ft.prototype,"CLOSING",{enumerable:!0,value:Dt.indexOf("CLOSING")}),Object.defineProperty(Ft,"CLOSED",{enumerable:!0,value:Dt.indexOf("CLOSED")}),Object.defineProperty(Ft.prototype,"CLOSED",{enumerable:!0,value:Dt.indexOf("CLOSED")}),["binaryType","bufferedAmount","extensions","protocol","readyState","url"].forEach((e=>{Object.defineProperty(Ft.prototype,e,{enumerable:!0})})),["open","error","close","message"].forEach((e=>{Object.defineProperty(Ft.prototype,`on${e}`,{enumerable:!0,get(){for(const t of this.listeners(e))if(t[Ot])return t[Tt];return null},set(t){for(const t of this.listeners(e))if(t[Ot]){this.removeListener(e,t);break}"function"==typeof t&&this.addEventListener(e,t,{[Ot]:!0})}})})),Ft.prototype.addEventListener=Lt,Ft.prototype.removeEventListener=At;const rs=Ft,is=process.nextTick,ns="undefined"!=typeof navigator&&"string"==typeof navigator.product&&"reactnative"===navigator.product.toLowerCase();const os={websocket:class extends C{constructor(e){super(e),this.supportsBinary=!e.forceBase64}get name(){return"websocket"}doOpen(){if(!this.check())return;const e=this.uri(),t=this.opts.protocols,s=ns?{}:x(this.opts,"agent","perMessageDeflate","pfx","key","passphrase","cert","ca","ciphers","rejectUnauthorized","localAddress","protocolVersion","origin","maxPayload","family","checkServerIdentity");this.opts.extraHeaders&&(s.headers=this.opts.extraHeaders);try{this.ws=new rs(e,t,s)}catch(e){return this.emitReserved("error",e)}this.ws.binaryType=this.socket.binaryType||"nodebuffer",this.addEventListeners()}addEventListeners(){this.ws.onopen=()=>{this.opts.autoUnref&&this.ws._socket.unref(),this.onOpen()},this.ws.onclose=e=>this.onClose({description:"websocket connection closed",context:e}),this.ws.onmessage=e=>this.onData(e.data),this.ws.onerror=e=>this.onError("websocket error",e)}write(e){this.writable=!1;for(let t=0;t{const t={};if(s.options&&(t.compress=s.options.compress),this.opts.perMessageDeflate){("string"==typeof e?Buffer.byteLength(e):e.length){this.writable=!0,this.emitReserved("drain")}),this.setTimeoutFn)}))}}doClose(){void 0!==this.ws&&(this.ws.close(),this.ws=null)}uri(){let e=this.query||{};const t=this.opts.secure?"wss":"ws";let s="";this.opts.port&&("wss"===t&&443!==Number(this.opts.port)||"ws"===t&&80!==Number(this.opts.port))&&(s=":"+this.opts.port),this.opts.timestampRequests&&(e[this.opts.timestampParam]=U()),this.supportsBinary||(e.b64=1);const r=j(e);return t+"://"+(-1!==this.opts.hostname.indexOf(":")?"["+this.opts.hostname+"]":this.opts.hostname)+s+this.opts.path+(r.length?"?"+r:"")}check(){return!!rs}},polling:class extends C{constructor(e){if(super(e),this.polling=!1,"undefined"!=typeof location){const t="https:"===location.protocol;let s=location.port;s||(s=t?"443":"80"),this.xd="undefined"!=typeof location&&e.hostname!==location.hostname||s!==e.port,this.xs=e.secure!==t}const t=e&&e.forceBase64;this.supportsBinary=H&&!t}get name(){return"polling"}doOpen(){this.poll()}pause(e){this.readyState="pausing";const t=()=>{this.readyState="paused",e()};if(this.polling||!this.writable){let e=0;this.polling&&(e++,this.once("pollComplete",(function(){--e||t()}))),this.writable||(e++,this.once("drain",(function(){--e||t()})))}else t()}poll(){this.polling=!0,this.doPoll(),this.emitReserved("poll")}onData(e){((e,t)=>{const s=e.split(w),r=[];for(let e=0;e{if("opening"===this.readyState&&"open"===e.type&&this.onOpen(),"close"===e.type)return this.onClose({description:"transport closed by the server"}),!1;this.onPacket(e)})),"closed"!==this.readyState&&(this.polling=!1,this.emitReserved("pollComplete"),"open"===this.readyState&&this.poll())}doClose(){const e=()=>{this.write([{type:"close"}])};"open"===this.readyState?e():this.once("open",e)}write(e){this.writable=!1,((e,t)=>{const s=e.length,r=new Array(s);let i=0;e.forEach(((e,n)=>{m(e,!1,(e=>{r[n]=e,++i===s&&t(r.join(w))}))}))})(e,(e=>{this.doWrite(e,(()=>{this.writable=!0,this.emitReserved("drain")}))}))}uri(){let e=this.query||{};const t=this.opts.secure?"https":"http";let s="";!1!==this.opts.timestampRequests&&(e[this.opts.timestampParam]=U()),this.supportsBinary||e.sid||(e.b64=1),this.opts.port&&("https"===t&&443!==Number(this.opts.port)||"http"===t&&80!==Number(this.opts.port))&&(s=":"+this.opts.port);const r=j(e);return t+"://"+(-1!==this.opts.hostname.indexOf(":")?"["+this.opts.hostname+"]":this.opts.hostname)+s+this.opts.path+(r.length?"?"+r:"")}request(e={}){return Object.assign(e,{xd:this.xd,xs:this.xs},this.opts),new z(this.uri(),e)}doWrite(e,t){const s=this.request({method:"POST",data:e});s.on("success",t),s.on("error",((e,t)=>{this.onError("xhr post error",e,t)}))}doPoll(){const e=this.request();e.on("data",this.onData.bind(this)),e.on("error",((e,t)=>{this.onError("xhr poll error",e,t)})),this.pollXhr=e}}},as=/^(?:(?![^:@]+:[^:@\/]*@)(http|https|ws|wss):\/\/)?((?:(([^:@]*)(?::([^:@]*))?)?@)?((?:[a-f0-9]{0,4}:){2,7}[a-f0-9]{0,4}|[^:\/?#]*)(?::(\d*))?)(((\/(?:[^?#](?![^?#\/]*\.[^?#\/.]+(?:[?#]|$)))*\/?)?([^?#\/]*))(?:\?([^#]*))?(?:#(.*))?)/,hs=["source","protocol","authority","userInfo","user","password","host","port","relative","path","directory","file","query","anchor"];function cs(e){const t=e,s=e.indexOf("["),r=e.indexOf("]");-1!=s&&-1!=r&&(e=e.substring(0,s)+e.substring(s,r).replace(/:/g,";")+e.substring(r,e.length));let i=as.exec(e||""),n={},o=14;for(;o--;)n[hs[o]]=i[o]||"";return-1!=s&&-1!=r&&(n.source=t,n.host=n.host.substring(1,n.host.length-1).replace(/;/g,":"),n.authority=n.authority.replace("[","").replace("]","").replace(/;/g,":"),n.ipv6uri=!0),n.pathNames=function(e,t){const s=/\/{2,9}/g,r=t.replace(s,"/").split("/");"/"!=t.substr(0,1)&&0!==t.length||r.splice(0,1);"/"==t.substr(t.length-1,1)&&r.splice(r.length-1,1);return r}(0,n.path),n.queryKey=function(e,t){const s={};return t.replace(/(?:^|&)([^&=]*)=?([^&]*)/g,(function(e,t,r){t&&(s[t]=r)})),s}(0,n.query),n}class ls extends S{constructor(e,t={}){super(),e&&"object"==typeof e&&(t=e,e=null),e?(e=cs(e),t.hostname=e.host,t.secure="https"===e.protocol||"wss"===e.protocol,t.port=e.port,e.query&&(t.query=e.query)):t.host&&(t.hostname=cs(t.host).host),N(this,t),this.secure=null!=t.secure?t.secure:"undefined"!=typeof location&&"https:"===location.protocol,t.hostname&&!t.port&&(t.port=this.secure?"443":"80"),this.hostname=t.hostname||("undefined"!=typeof location?location.hostname:"localhost"),this.port=t.port||("undefined"!=typeof location&&location.port?location.port:this.secure?"443":"80"),this.transports=t.transports||["polling","websocket"],this.readyState="",this.writeBuffer=[],this.prevBufferLen=0,this.opts=Object.assign({path:"/engine.io",agent:!1,withCredentials:!1,upgrade:!0,timestampParam:"t",rememberUpgrade:!1,rejectUnauthorized:!0,perMessageDeflate:{threshold:1024},transportOptions:{},closeOnBeforeunload:!0},t),this.opts.path=this.opts.path.replace(/\/$/,"")+"/","string"==typeof this.opts.query&&(this.opts.query=function(e){let t={},s=e.split("&");for(let e=0,r=s.length;e{this.transport&&(this.transport.removeAllListeners(),this.transport.close())}),!1),"localhost"!==this.hostname&&(this.offlineEventListener=()=>{this.onClose("transport close",{description:"network connection lost"})},addEventListener("offline",this.offlineEventListener,!1))),this.open()}createTransport(e){const t=Object.assign({},this.opts.query);t.EIO=4,t.transport=e,this.id&&(t.sid=this.id);const s=Object.assign({},this.opts.transportOptions[e],this.opts,{query:t,socket:this,hostname:this.hostname,secure:this.secure,port:this.port});return new os[e](s)}open(){let e;if(this.opts.rememberUpgrade&&ls.priorWebsocketSuccess&&-1!==this.transports.indexOf("websocket"))e="websocket";else{if(0===this.transports.length)return void this.setTimeoutFn((()=>{this.emitReserved("error","No transports available")}),0);e=this.transports[0]}this.readyState="opening";try{e=this.createTransport(e)}catch(e){return this.transports.shift(),void this.open()}e.open(),this.setTransport(e)}setTransport(e){this.transport&&this.transport.removeAllListeners(),this.transport=e,e.on("drain",this.onDrain.bind(this)).on("packet",this.onPacket.bind(this)).on("error",this.onError.bind(this)).on("close",(e=>this.onClose("transport close",e)))}probe(e){let t=this.createTransport(e),s=!1;ls.priorWebsocketSuccess=!1;const r=()=>{s||(t.send([{type:"ping",data:"probe"}]),t.once("packet",(e=>{if(!s)if("pong"===e.type&&"probe"===e.data){if(this.upgrading=!0,this.emitReserved("upgrading",t),!t)return;ls.priorWebsocketSuccess="websocket"===t.name,this.transport.pause((()=>{s||"closed"!==this.readyState&&(c(),this.setTransport(t),t.send([{type:"upgrade"}]),this.emitReserved("upgrade",t),t=null,this.upgrading=!1,this.flush())}))}else{const e=new Error("probe error");e.transport=t.name,this.emitReserved("upgradeError",e)}})))};function i(){s||(s=!0,c(),t.close(),t=null)}const n=e=>{const s=new Error("probe error: "+e);s.transport=t.name,i(),this.emitReserved("upgradeError",s)};function o(){n("transport closed")}function a(){n("socket closed")}function h(e){t&&e.name!==t.name&&i()}const c=()=>{t.removeListener("open",r),t.removeListener("error",n),t.removeListener("close",o),this.off("close",a),this.off("upgrading",h)};t.once("open",r),t.once("error",n),t.once("close",o),this.once("close",a),this.once("upgrading",h),t.open()}onOpen(){if(this.readyState="open",ls.priorWebsocketSuccess="websocket"===this.transport.name,this.emitReserved("open"),this.flush(),"open"===this.readyState&&this.opts.upgrade&&this.transport.pause){let e=0;const t=this.upgrades.length;for(;e{this.onClose("ping timeout")}),this.pingInterval+this.pingTimeout),this.opts.autoUnref&&this.pingTimeoutTimer.unref()}onDrain(){this.writeBuffer.splice(0,this.prevBufferLen),this.prevBufferLen=0,0===this.writeBuffer.length?this.emitReserved("drain"):this.flush()}flush(){if("closed"!==this.readyState&&this.transport.writable&&!this.upgrading&&this.writeBuffer.length){const e=this.getWritablePackets();this.transport.send(e),this.prevBufferLen=e.length,this.emitReserved("flush")}}getWritablePackets(){if(!(this.maxPayload&&"polling"===this.transport.name&&this.writeBuffer.length>1))return this.writeBuffer;let e=1;for(let s=0;s=57344?s+=3:(r++,s+=4);return s}(t):Math.ceil(1.33*(t.byteLength||t.size))),s>0&&e>this.maxPayload)return this.writeBuffer.slice(0,s);e+=2}var t;return this.writeBuffer}write(e,t,s){return this.sendPacket("message",e,t,s),this}send(e,t,s){return this.sendPacket("message",e,t,s),this}sendPacket(e,t,s,r){if("function"==typeof t&&(r=t,t=void 0),"function"==typeof s&&(r=s,s=null),"closing"===this.readyState||"closed"===this.readyState)return;(s=s||{}).compress=!1!==s.compress;const i={type:e,data:t,options:s};this.emitReserved("packetCreate",i),this.writeBuffer.push(i),r&&this.once("flush",r),this.flush()}close(){const e=()=>{this.onClose("forced close"),this.transport.close()},t=()=>{this.off("upgrade",t),this.off("upgradeError",t),e()},s=()=>{this.once("upgrade",t),this.once("upgradeError",t)};return"opening"!==this.readyState&&"open"!==this.readyState||(this.readyState="closing",this.writeBuffer.length?this.once("drain",(()=>{this.upgrading?s():e()})):this.upgrading?s():e()),this}onError(e){ls.priorWebsocketSuccess=!1,this.emitReserved("error",e),this.onClose("transport error",e)}onClose(e,t){"opening"!==this.readyState&&"open"!==this.readyState&&"closing"!==this.readyState||(this.clearTimeoutFn(this.pingTimeoutTimer),this.transport.removeAllListeners("close"),this.transport.close(),this.transport.removeAllListeners(),"function"==typeof removeEventListener&&removeEventListener("offline",this.offlineEventListener,!1),this.readyState="closed",this.id=null,this.emitReserved("close",e,t),this.writeBuffer=[],this.prevBufferLen=0)}filterUpgrades(e){const t=[];let s=0;const r=e.length;for(;s"function"==typeof ArrayBuffer.isView?ArrayBuffer.isView(e):e.buffer instanceof ArrayBuffer)(e))||us&&e instanceof Blob||fs&&e instanceof File}function ms(e,t){if(!e||"object"!=typeof e)return!1;if(Array.isArray(e)){for(let t=0,s=e.length;t0;case Es.ACK:case Es.BINARY_ACK:return Array.isArray(t)}}destroy(){this.reconstructor&&this.reconstructor.finishedReconstruction()}}class Ss{constructor(e){this.packet=e,this.buffers=[],this.reconPack=e}takeBinaryData(e){if(this.buffers.push(e),this.buffers.length===this.reconPack.attachments){const e=bs(this.reconPack,this.buffers);return this.finishedReconstruction(),e}return null}finishedReconstruction(){this.reconPack=null,this.buffers=[]}}var ks=Object.freeze({__proto__:null,protocol:5,get PacketType(){return Es},Encoder:class{constructor(e){this.replacer=e}encode(e){return e.type!==Es.EVENT&&e.type!==Es.ACK||!ms(e)?[this.encodeAsString(e)]:(e.type=e.type===Es.EVENT?Es.BINARY_EVENT:Es.BINARY_ACK,this.encodeAsBinary(e))}encodeAsString(e){let t=""+e.type;return e.type!==Es.BINARY_EVENT&&e.type!==Es.BINARY_ACK||(t+=e.attachments+"-"),e.nsp&&"/"!==e.nsp&&(t+=e.nsp+","),null!=e.id&&(t+=e.id),null!=e.data&&(t+=JSON.stringify(e.data,this.replacer)),t}encodeAsBinary(e){const t=ys(e),s=this.encodeAsString(t.packet),r=t.buffers;return r.unshift(s),r}},Decoder:ws});function xs(e,t,s){return e.on(t,s),function(){e.off(t,s)}}const Os=Object.freeze({connect:1,connect_error:1,disconnect:1,disconnecting:1,newListener:1,removeListener:1});class Ts extends S{constructor(e,t,s){super(),this.connected=!1,this.receiveBuffer=[],this.sendBuffer=[],this.ids=0,this.acks={},this.flags={},this.io=e,this.nsp=t,s&&s.auth&&(this.auth=s.auth),this.io._autoConnect&&this.open()}get disconnected(){return!this.connected}subEvents(){if(this.subs)return;const e=this.io;this.subs=[xs(e,"open",this.onopen.bind(this)),xs(e,"packet",this.onpacket.bind(this)),xs(e,"error",this.onerror.bind(this)),xs(e,"close",this.onclose.bind(this))]}get active(){return!!this.subs}connect(){return this.connected||(this.subEvents(),this.io._reconnecting||this.io.open(),"open"===this.io._readyState&&this.onopen()),this}open(){return this.connect()}send(...e){return e.unshift("message"),this.emit.apply(this,e),this}emit(e,...t){if(Os.hasOwnProperty(e))throw new Error('"'+e+'" is a reserved event name');t.unshift(e);const s={type:Es.EVENT,data:t,options:{}};if(s.options.compress=!1!==this.flags.compress,"function"==typeof t[t.length-1]){const e=this.ids++,r=t.pop();this._registerAckCallback(e,r),s.id=e}const r=this.io.engine&&this.io.engine.transport&&this.io.engine.transport.writable;return this.flags.volatile&&(!r||!this.connected)||(this.connected?(this.notifyOutgoingListeners(s),this.packet(s)):this.sendBuffer.push(s)),this.flags={},this}_registerAckCallback(e,t){const s=this.flags.timeout;if(void 0===s)return void(this.acks[e]=t);const r=this.io.setTimeoutFn((()=>{delete this.acks[e];for(let t=0;t{this.io.clearTimeoutFn(r),t.apply(this,[null,...e])}}packet(e){e.nsp=this.nsp,this.io._packet(e)}onopen(){"function"==typeof this.auth?this.auth((e=>{this.packet({type:Es.CONNECT,data:e})})):this.packet({type:Es.CONNECT,data:this.auth})}onerror(e){this.connected||this.emitReserved("connect_error",e)}onclose(e,t){this.connected=!1,delete this.id,this.emitReserved("disconnect",e,t)}onpacket(e){if(e.nsp===this.nsp)switch(e.type){case Es.CONNECT:if(e.data&&e.data.sid){const t=e.data.sid;this.onconnect(t)}else this.emitReserved("connect_error",new Error("It seems you are trying to reach a Socket.IO server in v2.x with a v3.x client, but they are not compatible (more information here: https://socket.io/docs/v3/migrating-from-2-x-to-3-0/)"));break;case Es.EVENT:case Es.BINARY_EVENT:this.onevent(e);break;case Es.ACK:case Es.BINARY_ACK:this.onack(e);break;case Es.DISCONNECT:this.ondisconnect();break;case Es.CONNECT_ERROR:this.destroy();const t=new Error(e.data.message);t.data=e.data.data,this.emitReserved("connect_error",t)}}onevent(e){const t=e.data||[];null!=e.id&&t.push(this.ack(e.id)),this.connected?this.emitEvent(t):this.receiveBuffer.push(Object.freeze(t))}emitEvent(e){if(this._anyListeners&&this._anyListeners.length){const t=this._anyListeners.slice();for(const s of t)s.apply(this,e)}super.emit.apply(this,e)}ack(e){const t=this;let s=!1;return function(...r){s||(s=!0,t.packet({type:Es.ACK,id:e,data:r}))}}onack(e){const t=this.acks[e.id];"function"==typeof t&&(t.apply(this,e.data),delete this.acks[e.id])}onconnect(e){this.id=e,this.connected=!0,this.emitBuffered(),this.emitReserved("connect")}emitBuffered(){this.receiveBuffer.forEach((e=>this.emitEvent(e))),this.receiveBuffer=[],this.sendBuffer.forEach((e=>{this.notifyOutgoingListeners(e),this.packet(e)})),this.sendBuffer=[]}ondisconnect(){this.destroy(),this.onclose("io server disconnect")}destroy(){this.subs&&(this.subs.forEach((e=>e())),this.subs=void 0),this.io._destroy(this)}disconnect(){return this.connected&&this.packet({type:Es.DISCONNECT}),this.destroy(),this.connected&&this.onclose("io client disconnect"),this}close(){return this.disconnect()}compress(e){return this.flags.compress=e,this}get volatile(){return this.flags.volatile=!0,this}timeout(e){return this.flags.timeout=e,this}onAny(e){return this._anyListeners=this._anyListeners||[],this._anyListeners.push(e),this}prependAny(e){return this._anyListeners=this._anyListeners||[],this._anyListeners.unshift(e),this}offAny(e){if(!this._anyListeners)return this;if(e){const t=this._anyListeners;for(let s=0;s0&&e.jitter<=1?e.jitter:0,this.attempts=0}Ns.prototype.duration=function(){var e=this.ms*Math.pow(this.factor,this.attempts++);if(this.jitter){var t=Math.random(),s=Math.floor(t*this.jitter*e);e=0==(1&Math.floor(10*t))?e-s:e+s}return 0|Math.min(e,this.max)},Ns.prototype.reset=function(){this.attempts=0},Ns.prototype.setMin=function(e){this.ms=e},Ns.prototype.setMax=function(e){this.max=e},Ns.prototype.setJitter=function(e){this.jitter=e};class Rs extends S{constructor(e,t){var s;super(),this.nsps={},this.subs=[],e&&"object"==typeof e&&(t=e,e=void 0),(t=t||{}).path=t.path||"/socket.io",this.opts=t,N(this,t),this.reconnection(!1!==t.reconnection),this.reconnectionAttempts(t.reconnectionAttempts||1/0),this.reconnectionDelay(t.reconnectionDelay||1e3),this.reconnectionDelayMax(t.reconnectionDelayMax||5e3),this.randomizationFactor(null!==(s=t.randomizationFactor)&&void 0!==s?s:.5),this.backoff=new Ns({min:this.reconnectionDelay(),max:this.reconnectionDelayMax(),jitter:this.randomizationFactor()}),this.timeout(null==t.timeout?2e4:t.timeout),this._readyState="closed",this.uri=e;const r=t.parser||ks;this.encoder=new r.Encoder,this.decoder=new r.Decoder,this._autoConnect=!1!==t.autoConnect,this._autoConnect&&this.open()}reconnection(e){return arguments.length?(this._reconnection=!!e,this):this._reconnection}reconnectionAttempts(e){return void 0===e?this._reconnectionAttempts:(this._reconnectionAttempts=e,this)}reconnectionDelay(e){var t;return void 0===e?this._reconnectionDelay:(this._reconnectionDelay=e,null===(t=this.backoff)||void 0===t||t.setMin(e),this)}randomizationFactor(e){var t;return void 0===e?this._randomizationFactor:(this._randomizationFactor=e,null===(t=this.backoff)||void 0===t||t.setJitter(e),this)}reconnectionDelayMax(e){var t;return void 0===e?this._reconnectionDelayMax:(this._reconnectionDelayMax=e,null===(t=this.backoff)||void 0===t||t.setMax(e),this)}timeout(e){return arguments.length?(this._timeout=e,this):this._timeout}maybeReconnectOnOpen(){!this._reconnecting&&this._reconnection&&0===this.backoff.attempts&&this.reconnect()}open(e){if(~this._readyState.indexOf("open"))return this;this.engine=new ls(this.uri,this.opts);const t=this.engine,s=this;this._readyState="opening",this.skipReconnect=!1;const r=xs(t,"open",(function(){s.onopen(),e&&e()})),i=xs(t,"error",(t=>{s.cleanup(),s._readyState="closed",this.emitReserved("error",t),e?e(t):s.maybeReconnectOnOpen()}));if(!1!==this._timeout){const e=this._timeout;0===e&&r();const s=this.setTimeoutFn((()=>{r(),t.close(),t.emit("error",new Error("timeout"))}),e);this.opts.autoUnref&&s.unref(),this.subs.push((function(){clearTimeout(s)}))}return this.subs.push(r),this.subs.push(i),this}connect(e){return this.open(e)}onopen(){this.cleanup(),this._readyState="open",this.emitReserved("open");const e=this.engine;this.subs.push(xs(e,"ping",this.onping.bind(this)),xs(e,"data",this.ondata.bind(this)),xs(e,"error",this.onerror.bind(this)),xs(e,"close",this.onclose.bind(this)),xs(this.decoder,"decoded",this.ondecoded.bind(this)))}onping(){this.emitReserved("ping")}ondata(e){this.decoder.add(e)}ondecoded(e){this.emitReserved("packet",e)}onerror(e){this.emitReserved("error",e)}socket(e,t){let s=this.nsps[e];return s||(s=new Ts(this,e,t),this.nsps[e]=s),s}_destroy(e){const t=Object.keys(this.nsps);for(const e of t){if(this.nsps[e].active)return}this._close()}_packet(e){const t=this.encoder.encode(e);for(let s=0;se())),this.subs.length=0,this.decoder.destroy()}_close(){this.skipReconnect=!0,this._reconnecting=!1,this.onclose("forced close"),this.engine&&this.engine.close()}disconnect(){return this._close()}onclose(e,t){this.cleanup(),this.backoff.reset(),this._readyState="closed",this.emitReserved("close",e,t),this._reconnection&&!this.skipReconnect&&this.reconnect()}reconnect(){if(this._reconnecting||this.skipReconnect)return this;const e=this;if(this.backoff.attempts>=this._reconnectionAttempts)this.backoff.reset(),this.emitReserved("reconnect_failed"),this._reconnecting=!1;else{const t=this.backoff.duration();this._reconnecting=!0;const s=this.setTimeoutFn((()=>{e.skipReconnect||(this.emitReserved("reconnect_attempt",e.backoff.attempts),e.skipReconnect||e.open((t=>{t?(e._reconnecting=!1,e.reconnect(),this.emitReserved("reconnect_error",t)):e.onreconnect()})))}),t);this.opts.autoUnref&&s.unref(),this.subs.push((function(){clearTimeout(s)}))}}onreconnect(){const e=this.backoff.attempts;this._reconnecting=!1,this.backoff.reset(),this.emitReserved("reconnect",e)}}const Cs={};function Ls(e,t){"object"==typeof e&&(t=e,e=void 0);const s=function(e,t="",s){let r=e;s=s||"undefined"!=typeof location&&location,null==e&&(e=s.protocol+"//"+s.host),"string"==typeof e&&("/"===e.charAt(0)&&(e="/"===e.charAt(1)?s.protocol+e:s.host+e),/^(https?|wss?):\/\//.test(e)||(e=void 0!==s?s.protocol+"//"+e:"https://"+e),r=cs(e)),r.port||(/^(http|ws)$/.test(r.protocol)?r.port="80":/^(http|ws)s$/.test(r.protocol)&&(r.port="443")),r.path=r.path||"/";const i=-1!==r.host.indexOf(":")?"["+r.host+"]":r.host;return r.id=r.protocol+"://"+i+":"+r.port+t,r.href=r.protocol+"://"+i+(s&&s.port===r.port?"":":"+r.port),r}(e,(t=t||{}).path||"/socket.io"),r=s.source,i=s.id,n=s.path,o=Cs[i]&&n in Cs[i].nsps;let a;return t.forceNew||t["force new connection"]||!1===t.multiplex||o?a=new Rs(r,t):(Cs[i]||(Cs[i]=new Rs(r,t)),a=Cs[i]),s.query&&!t.query&&(t.query=s.queryKey),a.socket(s.path,t)}Object.assign(Ls,{Manager:Rs,Socket:Ts,io:Ls,connect:Ls});var As="e";var Bs="jr",Ps="jc";const Is=e=>()=>e;const{default:Ds}=await import(e.resolve("executor.config.js")),Us=process.argv.slice(2),js=JSON.parse(Buffer.from(Us[0],"base64").toString("utf8")),Fs=function(e){const t={...e};for(var s in t)"function"!=typeof t[s]&&(t[s]=Is(t[s]));return t}(Ds(js)),Ms=new class{constructor(e,t){this.url=e.url(t)??process.env.QUALITEER_URL,this.jobId=e.jobId(t)??process.env.QUALITEER_JOB_ID,this.command=e.command(t)??process.env.QUALITEER_COMMAND,this.mode=As,this.buf={},this.buf.e="",this.buf.o="",this.spawn=this.spawn.bind(this),this.report=this.report.bind(this),this.onProcClose=this.onProcClose.bind(this),this.onClose=this.onClose.bind(this)}spawn(){const e=this.command,t=e.shift();this.proc=r.spawn(t,e),this.proc.stdout.setEncoding("utf8"),this.proc.stderr.setEncoding("utf8"),this.proc.stdout.on("data",(e=>this.report(e.toString(),"o"))),this.proc.stderr.on("data",(e=>this.report(e.toString(),"e"))),this.proc.on("close",this.onProcClose)}runJob(){const e=new Rs(this.url,{query:{mode:this.mode,jobId:this.jobId}});this.socket=e.socket("/"),this.socket.on("connect",this.spawn),this.socket.on("disconnect",this.onClose)}onClose(){console.log("Server disconnected, terminating process."),this.proc&&this.proc.kill("SIGKILL")}onProcClose(e){this.socket.emit(Ps,e),console.log(`Process finished with code ${e}`),this.socket.disconnect()}report(e,t){this.buf[t]+=e,this.buf[t].includes("\n")&&(this.buf[t].endsWith("\n")&&(this.buf[t]=this.buf[t].slice(0,-1)),this.socket.emit(Bs,this.buf[t]),"e"===t?console.error(`err: ${this.buf[t]}`):console.log(`out: ${this.buf[t]}`),this.buf[t]="")}}(Fs,js);Ms.runJob(); diff --git a/executor.config.js b/executor.config.js index edd654e..9582eb7 100644 --- a/executor.config.js +++ b/executor.config.js @@ -1,7 +1,7 @@ -export default function executorConfig(args){ +export default function executorConfig(payload){ return { - command: ()=> args.slice(2), - url: process.env.QUALITEER_URL, - jobId: () => args[1], + command: ({command})=> command, + url: ({url})=>url , + jobId: ({jobId}) => jobId, } } \ No newline at end of file diff --git a/lib/database/queries/alerting.js b/lib/database/queries/alerting.js index 9e02639..5f6a2fe 100644 --- a/lib/database/queries/alerting.js +++ b/lib/database/queries/alerting.js @@ -10,13 +10,15 @@ const table = "silenced_tests"; const PG_DISABLED = process.env.POSTGRES_DISABLED; const silencedMock = () => { - return [{ - name: `failing`, - class: `failing.js`, - method: "FAKEMETHOD", - id: 0, - silencedUntil: new Date().toJSON(), - }] + return [ + { + name: `failing`, + class: `failing.js`, + method: "FAKEMETHOD", + id: 0, + silencedUntil: new Date().toJSON(), + }, + ]; }; // Queries diff --git a/lib/database/queries/catalog.js b/lib/database/queries/catalog.js index b521a39..d61778a 100644 --- a/lib/database/queries/catalog.js +++ b/lib/database/queries/catalog.js @@ -20,12 +20,12 @@ const testsMock = () => { isCompound: false, type: "api", description: "This is a single test", - tags: ["cron_1hour","reg_us", "env_ci", "proj_core", "skip_alt"], + tags: ["cron_1hour", "reg_us", "env_ci", "proj_core", "skip_alt"], path: "tests/assets/suite/single.js", created: Date.now(), - mergeRequest: "https://example.com" + mergeRequest: "https://example.com", }, - { + { id: 1, name: "failing", class: "failing.js", @@ -33,12 +33,12 @@ const testsMock = () => { isCompound: false, type: "ui", description: "This is a failing test", - tags: ["cron_1hour","reg_us", "env_ci", "proj_core"], + tags: ["cron_1hour", "reg_us", "env_ci", "proj_core"], path: "tests/assets/suite/failing.js", created: Date.now(), - mergeRequest: "https://example.com" + mergeRequest: "https://example.com", }, - { + { id: 2, name: "primary", class: "primary.js", @@ -46,11 +46,18 @@ const testsMock = () => { isCompound: true, type: "api", description: "This is a primary test", - tags: ["cron_1hour","reg_us", "proj_core", "skip_alt", "compound_secondary"], + tags: [ + "cron_1hour", + "reg_us", + "proj_core", + "skip_alt", + "compound_secondary", + ], path: "tests/assets/suite/primary.js", created: Date.now(), - mergeRequest: "https://example.com" - }, { + mergeRequest: "https://example.com", + }, + { id: 3, name: "secondary", class: "secondary.js", @@ -58,12 +65,12 @@ const testsMock = () => { isCompound: true, type: "api", description: "This is a secondary test", - tags: ["cron_1hour","reg_us", "proj_core", "compound_tertiary"], + tags: ["cron_1hour", "reg_us", "proj_core", "compound_tertiary"], path: "tests/assets/suite/secondary.js", created: Date.now(), - mergeRequest: "https://example.com" + mergeRequest: "https://example.com", }, - { + { id: 4, name: "tertiary", class: "tertiary.js", @@ -71,21 +78,21 @@ const testsMock = () => { isCompound: true, type: "api", description: "This is a single test", - tags: ["cron_1hour","reg_us", "proj_core"], + tags: ["cron_1hour", "reg_us", "proj_core"], path: "tests/assets/suite/tertiary.js", created: Date.now(), - mergeRequest: "https://example.com" + mergeRequest: "https://example.com", }, ]; }; const mappingsMock = () => { return [ - ["primary", "secondary1", "tertiary1"], - ["primary", "secondary1", "tertiary2"], - ["primary", "secondary2", "tertiary3"], -]; -} + ["primary", "secondary1", "tertiary1"], + ["primary", "secondary1", "tertiary2"], + ["primary", "secondary2", "tertiary3"], + ]; +}; export const getTests = async () => { if (PG_DISABLED) return testsMock(); diff --git a/lib/database/queries/results.js b/lib/database/queries/results.js index 9302c2e..e4522e3 100644 --- a/lib/database/queries/results.js +++ b/lib/database/queries/results.js @@ -10,33 +10,35 @@ import { const table = "test_results"; const PG_DISABLED = process.env.POSTGRES_DISABLED; - const failingMock = () => { - return [{ - name: "failing", - class: "failing.js", - timestamp: new Date().toJSON(), - method: "FAKEMETHOD", - cron: "1hour", - type: "api", - dailyFails: 12, - screenshot: "https://picsum.photos/1920/1080", - recentResults: [1, 0, 0, 1, 0], - isCompound: false, - failedMessage: `Some Test FailureMessage`, -},{ - name: "secondary", - class: "secondary.js", - timestamp: new Date().toJSON(), - method: "FAKEMETHOD", - cron: "1hour", - type: "api", - dailyFails: 1, - screenshot: "https://picsum.photos/1920/1080", - recentResults: [1, 0, 0, 1, 0], - isCompound: true, - failedMessage: `Some Test FailureMessage from Secondary`, -}] + return [ + { + name: "failing", + class: "failing.js", + timestamp: new Date().toJSON(), + method: "FAKEMETHOD", + cron: "1hour", + type: "api", + dailyFails: 12, + screenshot: "https://picsum.photos/1920/1080", + recentResults: [1, 0, 0, 1, 0], + isCompound: false, + failedMessage: `Some Test FailureMessage`, + }, + { + name: "secondary", + class: "secondary.js", + timestamp: new Date().toJSON(), + method: "FAKEMETHOD", + cron: "1hour", + type: "api", + dailyFails: 1, + screenshot: "https://picsum.photos/1920/1080", + recentResults: [1, 0, 0, 1, 0], + isCompound: true, + failedMessage: `Some Test FailureMessage from Secondary`, + }, + ]; }; // Queries export const insertTestResult = (testResult) => { diff --git a/lib/jobs/executor/executor-entrypoint.js b/lib/jobs/executor/executor-entrypoint.js index 9e51a60..a414e5b 100644 --- a/lib/jobs/executor/executor-entrypoint.js +++ b/lib/jobs/executor/executor-entrypoint.js @@ -7,7 +7,8 @@ const { default: executorConfig } = await import( // Load config and args const args = process.argv.slice(2); -const config = normalize(executorConfig(args)); +const payload = JSON.parse(Buffer.from(args[0], "base64").toString("utf8")); +const config = normalize(executorConfig(payload)); // Start Executor -const exec = new Executor(args, config); +const exec = new Executor(config, payload); exec.runJob(); diff --git a/lib/jobs/job-builder.js b/lib/jobs/job-builder.js index 39a894d..f752bcc 100644 --- a/lib/jobs/job-builder.js +++ b/lib/jobs/job-builder.js @@ -34,9 +34,15 @@ const pipelineMaxLife = (testName) => { const buildCompound = (jobReq, socketId) => { const { testName, command } = jobReq; - const pipelineTriggers = jobReq.pipelineTriggers; - if (pipelineTriggers) command.push(`pipelineTriggers=${pipelineTriggers}`); - command.push(`pipelineDashboardSocket=${socketId}`); + const { pipeline } = jobReq; + if (pipeline) { + pipeline.dashboardSocketId = socketId; + const pipelineArg = Buffer.from(JSON.stringify(pipeline), "utf8").toString( + "base64" + ); + command.push(`pipeline=${pipelineArg}`); + } + return { ...jobReq, command }; }; diff --git a/lib/jobs/k8s/k8s-bypass.js b/lib/jobs/k8s/k8s-bypass.js index 09e0a0c..8496f96 100644 --- a/lib/jobs/k8s/k8s-bypass.js +++ b/lib/jobs/k8s/k8s-bypass.js @@ -7,8 +7,8 @@ const { command } = job.spec.template.spec.containers[0]; INFO("EXEC", "Internal Executor Starting!"); cp.exec(command, (error, stdout, stderr) => { if (error) ERR("EXEC", error); - //if(stdout) VERB("EXEC-STDOUT", stdout); - //if(stderr) VERB("EXEC-STDERR", stderr); + //if (stdout) VERB("EXEC-STDOUT", stdout); + //if (stderr) VERB("EXEC-STDERR", stderr); OK("EXEC", "Internal Executor Finished!"); process.exit(error ? 1 : 0); }); diff --git a/lib/jobs/k8s/kubernetes.js b/lib/jobs/k8s/kubernetes.js index 4c0756f..acfedb5 100644 --- a/lib/jobs/k8s/kubernetes.js +++ b/lib/jobs/k8s/kubernetes.js @@ -22,9 +22,11 @@ const wrapCommand = (jobId, command) => { ? `node ${executorBin}` : `chmod +x ${executorBin} && ./${executorBin}`; const cmd = command.map((arg) => JSON.stringify(arg)); - const curlCmd = `curl -o qltr-executor ${executorUrl} && ${bin} ${qualiteerUrl} ${jobId} ${cmd.join( - " " - )}`; + const payload = Buffer.from( + JSON.stringify({ jobId, command, url: qualiteerUrl }), + "utf8" + ).toString("base64"); + const curlCmd = `curl -o qltr-executor ${executorUrl} && ${bin} ${payload}`; return curlCmd; }; diff --git a/lib/jobs/pipelines.js b/lib/jobs/pipelines.js index 6781dbd..e02b11f 100644 --- a/lib/jobs/pipelines.js +++ b/lib/jobs/pipelines.js @@ -7,25 +7,25 @@ const nest = (arr) => { }; export const asTree = (branches) => { - const nests = branches.map((b)=>nest(b)); - return _.merge(...nests); - }; + const nests = branches.map((b) => nest(b)); + return _.merge(...nests); +}; export const asBranches = (array) => { - const merged = []; - array.forEach((p, i) => { - p.forEach((v, i) => { - if (!merged[i]) merged[i] = []; - if (!merged[i].includes(v)) merged[i].push(v); - }); + const merged = []; + array.forEach((p, i) => { + p.forEach((v, i) => { + if (!merged[i]) merged[i] = []; + if (!merged[i].includes(v)) merged[i].push(v); }); - return merged; - } + }); + return merged; +}; export const as1d = (a) => [].concat.apply([], a); -export const selectBranch = (map,test) => { - const pipeline = map.find((pm)=>pm.includes(test)); - const testIndex = pipeline.findIndex((t) => t === test); - return pipeline.slice(0, testIndex + 1); - } +export const selectBranch = (map, test) => { + const pipeline = map.find((pm) => pm.includes(test)); + const testIndex = pipeline.findIndex((t) => t === test); + return pipeline.slice(0, testIndex + 1); +}; diff --git a/lib/rabbit/workers/TestResultsWorker.js b/lib/rabbit/workers/TestResultsWorker.js index 5009d88..7e048a1 100644 --- a/lib/rabbit/workers/TestResultsWorker.js +++ b/lib/rabbit/workers/TestResultsWorker.js @@ -24,21 +24,18 @@ export default class TestResultsWorker extends Worker { } */ onMessage(testResult) { - const { pipelineData, pipelineTriggers, pipelineDelay } = testResult; - const pipelineTrigger = { pipelineData, pipelineTriggers, pipelineDelay }; + const { pipeline } = testResult; + // Alter to start next test // TODO the delay should be autopopulated either by the suite, or filled in by the server - if (pipelineTriggers) - return this.pipelineTrigger( - pipelineTrigger, - testResult.pipelineDashboardSocket - ); - this.pipelineClose(testResult.pipelineDashboardSocket); + if (pipeline) return this.pipelineTrigger(pipeline); + const { dashboardSocketId: dsi } = pipeline; + this.pipelineClose(dsi); } - pipelineTrigger(pipelineTrigger, socketId) { - pipelineTrigger.pipelineDelay = 1000 * 5; - this.skio.to(socketId).emit(evt.PPL_TRG, pipelineTrigger); + pipelineTrigger(pipeline) { + const { dashboardSocketId: dsi } = pipeline; + this.skio.to(dsi).emit(evt.PPL_TRG, pipeline); } pipelineClose(socketId) { diff --git a/lib/routes/alerting-route.js b/lib/routes/alerting-route.js index d111e08..b03edbd 100644 --- a/lib/routes/alerting-route.js +++ b/lib/routes/alerting-route.js @@ -7,7 +7,7 @@ router.use(jsonMiddleware()); // Get Routes router.get("/silenced", (req, res) => { - getSilencedTests().then((t)=>res.send(t)); + getSilencedTests().then((t) => res.send(t)); }); // Post Routes diff --git a/lib/routes/catalog-route.js b/lib/routes/catalog-route.js index a9c58c3..62b79ba 100644 --- a/lib/routes/catalog-route.js +++ b/lib/routes/catalog-route.js @@ -9,12 +9,12 @@ router.use(jsonMiddleware({ limit: maxSize })); // Get Routes router.get("/tests", (req, res) => { - getTests().then((t)=>res.json(t)); + getTests().then((t) => res.json(t)); }); -router.get("/pipeline-mappings", (req,res)=>{ - getPipelineMappings().then((m)=>res.json(m)); -}) +router.get("/pipeline-mappings", (req, res) => { + getPipelineMappings().then((m) => res.json(m)); +}); // Post Routes router.post("/update", (req, res) => { diff --git a/lib/routes/results-route.js b/lib/routes/results-route.js index b6efa70..fd5692b 100644 --- a/lib/routes/results-route.js +++ b/lib/routes/results-route.js @@ -7,7 +7,7 @@ router.use(jsonMiddleware()); // Get Routes router.get("/failing", (req, res) => { - getCurrentlyFailing().then((f)=>res.json(f)); + getCurrentlyFailing().then((f) => res.json(f)); }); // Post Routes diff --git a/lib/sockets/clients/Executor.js b/lib/sockets/clients/Executor.js index 202b824..9281c04 100644 --- a/lib/sockets/clients/Executor.js +++ b/lib/sockets/clients/Executor.js @@ -12,10 +12,10 @@ const ERR = "e"; const OUT = "o"; export default class Executor { - constructor(args, config, options = {}) { - this.url = config.url(args) ?? process.env.QUALITEER_URL; - this.jobId = config.jobId(args) ?? process.env.QUALITEER_JOB_ID; - this.command = config.command(args) ?? process.env.QUALITEER_COMMAND; + constructor(config, payload) { + this.url = config.url(payload) ?? process.env.QUALITEER_URL; + this.jobId = config.jobId(payload) ?? process.env.QUALITEER_JOB_ID; + this.command = config.command(payload) ?? process.env.QUALITEER_COMMAND; this.mode = modes.EXEC; // Internal Buffer @@ -24,10 +24,10 @@ export default class Executor { this.buf[OUT] = ""; // Methods - this.spawn = options.spawn ?? this.spawn.bind(this); - this.report = options.report ?? this.report.bind(this); - this.onProcClose = options.onProcClose ?? this.onProcClose.bind(this); - this.onClose = options.onClose ?? this.onClose.bind(this); + this.spawn = this.spawn.bind(this); + this.report = this.report.bind(this); + this.onProcClose = this.onProcClose.bind(this); + this.onClose = this.onClose.bind(this); } spawn() { diff --git a/lib/sockets/clients/Initiator.js b/lib/sockets/clients/Initiator.js index 93cc77b..b2bb2de 100644 --- a/lib/sockets/clients/Initiator.js +++ b/lib/sockets/clients/Initiator.js @@ -54,29 +54,32 @@ export default class Initiator { onCreate = onCreate ?? this.onCreate.bind(this); onPipelineTrigger = onPipelineTrigger ?? - ((trigger) => { - console.log("job trg:", trigger); - const testName = trigger.pipelineTriggers; - const pipelineData = trigger.pipelineData; - const pipelineTriggers = trigger.newPipelineTriggers; - const jobReq = { - ...jobRequest, - testName, - pipelineData, - pipelineTriggers, - }; - setTimeout( - () => - this.newPipelineJob( - jobReq, - onLog, - onClose, - onCreate, - onPipelineTrigger, - onPipelineClose - ), - trigger.pipelineDelay - ); + ((pipeline) => { + console.log("job trg:", pipeline); + const { triggers } = pipeline; + if (!Object.keys(triggers).length) onPipelineClose(); + // For each trigger + for (var testName in triggers) { + const delay = triggers[testName].__testDelay ?? 0; + delete triggers[testName].__testDelay; + const jobReq = { + ...jobRequest, + pipeline: { ...pipeline, triggers: triggers[testName] }, + testName, + }; + setTimeout( + () => + this.newPipelineJob( + jobReq, + onLog, + onClose, + onCreate, + onPipelineTrigger, + onPipelineClose + ), + delay + ); + } }); onPipelineClose = onPipelineClose ?? this.onPipelineClose.bind(this); this.sk = mgr.socket("/"); diff --git a/src/Dashboard.jsx b/src/Dashboard.jsx index b7a1d09..a43ede5 100644 --- a/src/Dashboard.jsx +++ b/src/Dashboard.jsx @@ -1,24 +1,24 @@ // Import Contexts -import { QueryClient, QueryClientProvider} from '@tanstack/react-query' +import { QueryClient, QueryClientProvider } from "@tanstack/react-query"; import { JobProvider } from "./ctx/JobContext.jsx"; import { StoreProvider } from "./ctx/StoreContext.jsx"; import { BrowserRouter } from "react-router-dom"; // Import Views import Views from "./views/Views.jsx"; -const queryClient = new QueryClient() +const queryClient = new QueryClient(); export default function Dashboard() { return (
- - - - - - - - + + + + + + + +
); diff --git a/src/Queries.jsx b/src/Queries.jsx index 76cef4f..1096963 100644 --- a/src/Queries.jsx +++ b/src/Queries.jsx @@ -1,25 +1,28 @@ -import { useQuery } from '@tanstack/react-query' +import { useQuery } from "@tanstack/react-query"; const QUALITEER_URL = "https://qualiteer.elijahparker3.repl.co/api"; -const useMock = false; +const useMock = true; const asMock = (data) => ({ data }); -const fetchApi = (subPath)=> async ()=> fetch(`${QUALITEER_URL}${subPath}`).then((res)=>res.json()); +const fetchApi = (subPath) => async () => + fetch(`${QUALITEER_URL}${subPath}`).then((res) => res.json()); -export const useCatalogTests = () => useMock ? asMock([]): useQuery(['catalogTests'], fetchApi("/catalog/tests") - ) +export const useCatalogTests = () => + useMock ? asMock([]) : useQuery(["catalogTests"], fetchApi("/catalog/tests")); -export const usePipelineMappings = () => useMock ? asMock([ - ["primary", "secondary1", "tertiary1"], - ["primary", "secondary1", "tertiary2"], - ["primary", "secondary2", "tertiary3"], -]) : useQuery(['pipelineMappings'], fetchApi("/catalog/pipeline-mappings") - ) +export const usePipelineMappings = () => + useMock + ? asMock([ + ["primary", "secondary1", "tertiary1"], + ["primary", "secondary1", "tertiary2"], + ["primary", "secondary2", "tertiary3"], + ]) + : useQuery(["pipelineMappings"], fetchApi("/catalog/pipeline-mappings")); -export const useSilencedAlerts = () => useMock? asMock([]) : useQuery(['silenced'], fetchApi("/alerting/silenced") - ) +export const useSilencedAlerts = () => + useMock ? asMock([]) : useQuery(["silenced"], fetchApi("/alerting/silenced")); -export const useCurrentlyFailing = () => useMock? asMock([]) : useQuery(['failing'], fetchApi("/results/failing") - ) \ No newline at end of file +export const useCurrentlyFailing = () => + useMock ? asMock([]) : useQuery(["failing"], fetchApi("/results/failing")); diff --git a/src/ctx/JobContext.jsx b/src/ctx/JobContext.jsx index 1fb8f18..15d5cb7 100644 --- a/src/ctx/JobContext.jsx +++ b/src/ctx/JobContext.jsx @@ -15,7 +15,7 @@ const ACTIONS = { CREATE: "c", UPDATE: "u", DELETE: "d", - PIPELINE: "p" + PIPELINE: "p", }; const url = "https://qualiteer.elijahparker3.repl.co/"; @@ -44,7 +44,9 @@ const reducer = (state, action) => { return { ...state, jobs }; case ACTIONS.UPDATE: - jobIndex = jobs.findIndex((j) => j.jobId === (action.job.jobId ?? action.jobId)); + jobIndex = jobs.findIndex( + (j) => j.jobId === (action.job.jobId ?? action.jobId) + ); jobs[jobIndex] = { ...jobs[jobIndex], ...action.job }; return { ...state, jobs }; @@ -54,7 +56,7 @@ const reducer = (state, action) => { return { ...state, jobs }; case ACTIONS.PIPELINE: - return {...state, pipelines}; + return { ...state, pipelines }; default: return state; } @@ -69,25 +71,26 @@ export const JobProvider = ({ children }) => { dispatch({ type: ACTIONS.CREATE, job: { ...job, log: [] } }); const jobDelete = (jobId) => dispatch({ type: ACTIONS.DELETE, jobId }); - const updatePipelines = (pipelines) => dispatch({type: ACTIONS.pipeline, pipelines}); - + const updatePipelines = (pipelines) => + dispatch({ type: ACTIONS.pipeline, pipelines }); + function retryAll(failing) { // Query Full Locator console.log("Would retry all failing tests!"); return jobFactory({ testNames: ["single"] }); } - function pipelineComponentJob(jobPipeline, testName){ + function pipelineComponentJob(jobPipeline, testName) { const i = new Initiator(url); const jobId = `j${Date.now()}`; - const job = { + const job = { name: jobId, status: jobStatus.PENDING, jobId, isPipeline: true, builderCache: {}, initiator: i, - } + }; const request = { testName, image: "node", @@ -95,9 +98,9 @@ export const JobProvider = ({ children }) => { name: jobId, pipelineTriggers: "secondary", }; - + jobCreate(job); - const onLog = (d) => { + const onLog = (d) => { const job = state.jobs.find((j) => j.jobId === jobId); job.log.push(d); job.status = jobStatus.ACTIVE; @@ -112,41 +115,48 @@ export const JobProvider = ({ children }) => { }; const onPipelineTrigger = (trigger) => { console.log("Got trigger", trigger); - } - const started = i.newPipelineJob(request, onLog, onClose, onPipelineTrigger); - started.then(() => jobUpdate({ status: jobStatus.ACTIVE }, jobId)); - + }; + const started = i.newPipelineJob( + request, + onLog, + onClose, + onPipelineTrigger + ); + started.then(() => jobUpdate({ status: jobStatus.ACTIVE }, jobId)); } - + function pipelineFactory(builderCache) { console.log("Would create pipeline with cache"); console.log(builderCache); return pipelineComponentJob(state.pipelines, builderCache.branches[0][0]); -// return jobId; + // return jobId; /*return jobFactory({testNames: ["primary"]});*/ } - - function jobCancel(jobId){ - const job = state.jobs.find((j)=>j.jobId===jobId); - - if(job.initiator.sk) job.initiator.sk.close(); + function jobCancel(jobId) { + const job = state.jobs.find((j) => j.jobId === jobId); + + if (job.initiator.sk) job.initiator.sk.close(); job.status = jobStatus.CANCELED; jobUpdate({ ...job }, jobId); - } - function jobDestroy(jobId){ - const job = state.jobs.find((j)=>j.jobId===jobId); - - if(job.initiator.sk && job.status !== jobStatus.OK && job.status !== jobStatus.ERROR && job.status !== jobStatus.CANCELED){ - job.initiator.sk.close(); + function jobDestroy(jobId) { + const job = state.jobs.find((j) => j.jobId === jobId); + + if ( + job.initiator.sk && + job.status !== jobStatus.OK && + job.status !== jobStatus.ERROR && + job.status !== jobStatus.CANCELED + ) { + job.initiator.sk.close(); } jobDelete(jobId); } function jobFactory(builderCache) { - if(builderCache.tree) return pipelineFactory(builderCache); + if (builderCache.tree) return pipelineFactory(builderCache); // Find test const i = new Initiator(url); const jobId = `j${Date.now()}`; @@ -184,7 +194,7 @@ export const JobProvider = ({ children }) => { const started = i.newJob(request, onLog, onClose); started.then(() => jobUpdate({ status: jobStatus.ACTIVE }, jobId)); - + return jobId; } @@ -197,7 +207,7 @@ export const JobProvider = ({ children }) => { retryAll, jobFactory, jobCancel, - jobDestroy + jobDestroy, }; const contextValue = useMemo(() => context, [state, dispatch]); diff --git a/src/views/Navbar.jsx b/src/views/Navbar.jsx index 842171d..15808b8 100644 --- a/src/views/Navbar.jsx +++ b/src/views/Navbar.jsx @@ -1,5 +1,5 @@ import { useContext, useState } from "react"; -import {useCurrentlyFailing} from "../Queries.jsx"; +import { useCurrentlyFailing } from "../Queries.jsx"; import JobContext from "../ctx/JobContext.jsx"; import StoreContext from "../ctx/StoreContext.jsx"; @@ -24,18 +24,22 @@ import FormatListBulletedIcon from "@mui/icons-material/FormatListBulleted"; import SettingsIcon from "@mui/icons-material/Settings"; import WarningIcon from "@mui/icons-material/Warning"; import InfoIcon from "@mui/icons-material/Info"; -import SentimentSatisfiedAltIcon from '@mui/icons-material/SentimentSatisfiedAlt'; +import SentimentSatisfiedAltIcon from "@mui/icons-material/SentimentSatisfiedAlt"; const drawerWidth = 250; export default function Navbar(props) { const { state: jobState } = useContext(JobContext); const { state: store } = useContext(StoreContext); - const {isLoading, data: failing} = useCurrentlyFailing(); + const { isLoading, data: failing } = useCurrentlyFailing(); const pages = store.pages; const icons = [ - {(failing ?? []).length > 0 ? : } + {(failing ?? []).length > 0 ? ( + + ) : ( + + )} , , diff --git a/src/views/Views.jsx b/src/views/Views.jsx index 79d82eb..6c7bb9a 100644 --- a/src/views/Views.jsx +++ b/src/views/Views.jsx @@ -33,7 +33,9 @@ export default function Views() { } + element={ + + } /> } /> } /> diff --git a/src/views/alerting/Alerting.jsx b/src/views/alerting/Alerting.jsx index 54c58fd..9eeb6d7 100644 --- a/src/views/alerting/Alerting.jsx +++ b/src/views/alerting/Alerting.jsx @@ -1,5 +1,5 @@ import React, { useState, useContext } from "react"; -import {useSilencedAlerts} from "../../Queries.jsx"; +import { useSilencedAlerts } from "../../Queries.jsx"; import StoreContext from "../../ctx/StoreContext.jsx"; import SilencedBox from "./SilencedBox.jsx"; import SilenceDialog from "./SilenceDialog.jsx"; @@ -18,13 +18,9 @@ import Typography from "@mui/material/Typography"; import Box from "@mui/material/Box"; export default function Alerting() { - const { - updateStore, - silenceRequest, - } = useContext(StoreContext); + const { updateStore, silenceRequest } = useContext(StoreContext); - -const {isLoading, data: silenced} = useSilencedAlerts(); + const { isLoading, data: silenced } = useSilencedAlerts(); const [silenceEntry, setSilenceEntry] = useState({ open: false, @@ -61,36 +57,41 @@ const {isLoading, data: silenced} = useSilencedAlerts(); return (
- {isLoading? null : silenced.map((v, i) => ( - - ))} - - {(silenced ?? []).length === 0? ( - - + {isLoading + ? null + : silenced.map((v, i) => ( + + ))} - No alerts silenced! - Click the '+' to create a new one! - - + {(silenced ?? []).length === 0 ? ( + + + No alerts silenced! {" "} + + + {" "} + + Click the '+' to create a new one! + + - ): null} - + ) : null} + updateStore({ catalogSearch: e.target.value }); @@ -29,9 +28,9 @@ export default function Catalog() { clearOnUnmount />
{store.catalogSearch}
- {isLoading ? null : tests.map((v, i) => ( - - ))} + {isLoading + ? null + : tests.map((v, i) => )}
); } diff --git a/src/views/catalog/CatalogBox.jsx b/src/views/catalog/CatalogBox.jsx index b8bca28..0f7b577 100644 --- a/src/views/catalog/CatalogBox.jsx +++ b/src/views/catalog/CatalogBox.jsx @@ -29,7 +29,7 @@ export default function CatalogBox(props) { const { state: store, updateStore } = useContext(StoreContext); - const { state: jobState, jobFactory} = useContext(JobContext); + const { state: jobState, jobFactory } = useContext(JobContext); const [open, setOpen] = useState(false); @@ -38,7 +38,7 @@ export default function CatalogBox(props) { const runTest = (e) => { e.preventDefault(); e.stopPropagation(); - const jobId = jobFactory({testNames: [testName]}); + const jobId = jobFactory({ testNames: [testName] }); if (store.focusJob) navigate(`/qualiteer/jobs#${jobId}`); }; diff --git a/src/views/failing/Failing.jsx b/src/views/failing/Failing.jsx index c00034b..c566844 100644 --- a/src/views/failing/Failing.jsx +++ b/src/views/failing/Failing.jsx @@ -1,6 +1,6 @@ import { useState, useContext } from "react"; import { useNavigate } from "react-router-dom"; -import {useCurrentlyFailing, useSilencedAlerts} from "../../Queries.jsx"; +import { useCurrentlyFailing, useSilencedAlerts } from "../../Queries.jsx"; import StoreContext from "../../ctx/StoreContext.jsx"; import JobContext from "../../ctx/JobContext.jsx"; import SilenceDialog from "../alerting/SilenceDialog.jsx"; @@ -28,8 +28,8 @@ export default function Failing() { updateStore, silenceRequest, } = useContext(StoreContext); - const {isLoading, data: failing} = useCurrentlyFailing(); - const {isSilencedLoading, data:silencedAlerts} = useSilencedAlerts(); + const { isLoading, data: failing } = useCurrentlyFailing(); + const { isSilencedLoading, data: silencedAlerts } = useSilencedAlerts(); const [silenceEntry, setSilenceEntry] = useState({ open: false }); const closeSilence = () => setSilenceEntry({ ...silenceEntry, open: false }); @@ -58,22 +58,28 @@ export default function Failing() { const failingTestsWithJobs = () => { const silences = silencedAlerts ?? []; - for(var test of failing){ - if(test.isCompound) continue; - const job = jobState.jobs.find((j)=>j.builderCache.testNames.includes(test.name)) - if(job) test.job = job; - const silence = silences.find((s)=>s.name === test.name || s.class === test.class) + for (var test of failing) { + if (test.isCompound) continue; + const job = jobState.jobs.find((j) => + j.builderCache.testNames.includes(test.name) + ); + if (job) test.job = job; + const silence = silences.find( + (s) => s.name === test.name || s.class === test.class + ); - if(silence) test.silencedUntil = silence; + if (silence) test.silencedUntil = silence; } return failing; - } + }; return (
- {isLoading? null :failingTestsWithJobs().map((v, i) => ( - - ))} + {isLoading + ? null + : failingTestsWithJobs().map((v, i) => ( + + ))} - {(failing ?? []).length === 0? ( - No tests failing! - - - - ): null} + {(failing ?? []).length === 0 ? ( + + No tests failing! + + ) : null} - {(failing ?? []).length ===0? null :( - } - onClick={retryAllClick} - open={false} - />)} + {(failing ?? []).length === 0 ? null : ( + } + onClick={retryAllClick} + open={false} + /> + )}
); } diff --git a/src/views/failing/FailingBox.jsx b/src/views/failing/FailingBox.jsx index fc5eda3..f93fd8f 100644 --- a/src/views/failing/FailingBox.jsx +++ b/src/views/failing/FailingBox.jsx @@ -48,7 +48,7 @@ export default function FailingBox(props) { failedMessage, isCompound, jobStatus: testJobStatus, - job + job, } = failingTest; const navigate = useNavigate(); @@ -78,12 +78,12 @@ export default function FailingBox(props) { } const retryTest = () => { - const jobId = jobFactory({testNames: [testName], isTriage: true}); + const jobId = jobFactory({ testNames: [testName], isTriage: true }); if (store.focusJob) navigate(`/qualiteer/jobs#${jobId}`); }; const jobOnClick = () => { - if(!job) return retryTest; + if (!job) return retryTest; switch (job.status) { case jobStatus.OK: return null; @@ -103,7 +103,7 @@ export default function FailingBox(props) { }; function jobIcon() { - if(!job) return ; + if (!job) return ; switch (job.status) { case jobStatus.OK: return ; diff --git a/src/views/jobs/JobView.jsx b/src/views/jobs/JobView.jsx index 252cb99..d7dc8fb 100644 --- a/src/views/jobs/JobView.jsx +++ b/src/views/jobs/JobView.jsx @@ -21,13 +21,11 @@ import DoNotDisturbIcon from "@mui/icons-material/DoNotDisturb"; import DeleteIcon from "@mui/icons-material/Delete"; import PlayArrowIcon from "@mui/icons-material/PlayArrow"; - - export default function JobView(props) { const navigate = useNavigate(); const { job } = props; const { jobFactory, jobCancel, jobDestroy } = useContext(JobContext); - const {state: store} = useContext(StoreContext); + const { state: store } = useContext(StoreContext); const [anchorEl, setAnchorEl] = React.useState(null); const open = Boolean(anchorEl); const handleClick = (event) => { @@ -51,8 +49,8 @@ export default function JobView(props) { } function retryJob() { - const jobId = jobFactory(job.builderCache); - if(store.focusJob) navigate(`/qualiteer/jobs#${jobId}`); + const jobId = jobFactory(job.builderCache); + if (store.focusJob) navigate(`/qualiteer/jobs#${jobId}`); } function downloadLog() { @@ -60,12 +58,11 @@ export default function JobView(props) { download(`${job.jobId}.txt`, job.log.join("\n")); } - function cancelJob(){ + function cancelJob() { jobCancel(job.jobId); - } - function deleteJob(){ + function deleteJob() { jobDestroy(job.jobId); navigateToJobs(); } @@ -107,7 +104,7 @@ export default function JobView(props) { - + @@ -115,16 +112,27 @@ export default function JobView(props) { - {job.status === jobStatus.OK || job.status === jobStatus.ERROR ? : } + {job.status === jobStatus.OK || job.status === jobStatus.ERROR ? ( + + ) : ( + + )} - {job.status === jobStatus.ERROR? "Retry" : "Duplicate"} + + {" "} + {job.status === jobStatus.ERROR ? "Retry" : "Duplicate"} + - {job.status === jobStatus.OK || job.status === jobStatus.ERROR || job.status === jobStatus.CANCELED? null : - - - - Cancel - } + {job.status === jobStatus.OK || + job.status === jobStatus.ERROR || + job.status === jobStatus.CANCELED ? null : ( + + + + + Cancel + + )} diff --git a/src/views/jobs/Jobs.jsx b/src/views/jobs/Jobs.jsx index 39b465a..0571fd1 100644 --- a/src/views/jobs/Jobs.jsx +++ b/src/views/jobs/Jobs.jsx @@ -21,37 +21,42 @@ export default function Jobs() { return (
- {jobState.jobs.length === 0? ( - - - - No jobs found! - Click the '+' to start a new one! - - + {jobState.jobs.length === 0 ? ( + + + No jobs found! {" "} + + + {" "} + + Click the '+' to start a new one! + + - ): null} + ) : null} {location.hash === "" && - jobState.jobs.filter((j)=>!j.isPipeline).map((v, i) => ( - - - - ))} + jobState.jobs + .filter((j) => !j.isPipeline) + .map((v, i) => ( + + + + ))} {jobState.jobs.find((job) => job.name === location.hash.slice(1)) && ( job.name === location.hash.slice(1))} diff --git a/src/views/jobs/builder/PipelineConfirm.jsx b/src/views/jobs/builder/PipelineConfirm.jsx index c120861..48a6adb 100644 --- a/src/views/jobs/builder/PipelineConfirm.jsx +++ b/src/views/jobs/builder/PipelineConfirm.jsx @@ -6,7 +6,6 @@ import DialogContent from "@mui/material/DialogContent"; function PipelineConfirm(props) { const { cache, back, start } = props; - return ( diff --git a/src/views/jobs/builder/PipelineSelector.jsx b/src/views/jobs/builder/PipelineSelector.jsx index 30b73ba..1d5e489 100644 --- a/src/views/jobs/builder/PipelineSelector.jsx +++ b/src/views/jobs/builder/PipelineSelector.jsx @@ -1,5 +1,5 @@ import React, { useContext } from "react"; -import {usePipelineMappings} from "../../../Queries.jsx"; +import { usePipelineMappings } from "../../../Queries.jsx"; import Button from "@mui/material/Button"; import DialogActions from "@mui/material/DialogActions"; import DialogContent from "@mui/material/DialogContent"; @@ -11,27 +11,27 @@ import Stack from "@mui/material/Stack"; function PipelineSelector(props) { const { cache, setCache, cancel, next } = props; - const {isLoading, data: pipelineMappings} = usePipelineMappings(); + const { isLoading, data: pipelineMappings } = usePipelineMappings(); - const primaryMappings = () =>{ - if(isLoading) return {}; + const primaryMappings = () => { + if (isLoading) return {}; const primaryMappings = {}; - for (var pm of pipelineMappings) { - if (!(pm[0] in primaryMappings)) primaryMappings[pm[0]] = []; - primaryMappings[pm[0]].push(pm); - } - return primaryMappings; + for (var pm of pipelineMappings) { + if (!(pm[0] in primaryMappings)) primaryMappings[pm[0]] = []; + primaryMappings[pm[0]].push(pm); + } + return primaryMappings; }; - - + const selectPrimary = (primarySelectedMappings) => () => { setCache({ primarySelectedMappings }); }; - const clickNext = () =>{ - if(!cache.primarySelectedMappings ) return console.log("No mapping selected") - next() - } + const clickNext = () => { + if (!cache.primarySelectedMappings) + return console.log("No mapping selected"); + next(); + }; return ( @@ -53,11 +53,17 @@ function PipelineSelector(props) { {k} - {(primaryMappings[k] ?? []).length} + + {(primaryMappings[k] ?? []).length} + ))} diff --git a/src/views/jobs/builder/PipelineTrackSelector.jsx b/src/views/jobs/builder/PipelineTrackSelector.jsx index 3f0293c..1683c08 100644 --- a/src/views/jobs/builder/PipelineTrackSelector.jsx +++ b/src/views/jobs/builder/PipelineTrackSelector.jsx @@ -8,40 +8,48 @@ import AccordionSummary from "@mui/material/AccordionSummary"; import Box from "@mui/material/Box"; import Typography from "@mui/material/Typography"; import Stack from "@mui/material/Stack"; -import {selectBranch, asTree, asBranches, as1d} from "../../../../lib/jobs/pipelines.js"; +import { + selectBranch, + asTree, + asBranches, + as1d, +} from "../../../../lib/jobs/pipelines.js"; function PipelineTrackSelector(props) { const { cache, setCache, back, next } = props; - const {primarySelectedMappings: primaries} = cache; + const { primarySelectedMappings: primaries } = cache; const addTrack = (test) => { - const tracks = cache.tracks ?? []; tracks.push(selectBranch(primaries, test)); - setCache({ ...cache, tracks}); + const tracks = cache.tracks ?? []; + tracks.push(selectBranch(primaries, test)); + setCache({ ...cache, tracks }); }; const removeTrack = (test) => { - const {tracks} = cache; - for(var i in tracks){ + const { tracks } = cache; + for (var i in tracks) { const index = tracks[i].indexOf(test); - if(index===-1) continue; - tracks[i] = tracks[i].slice(0,index); + if (index === -1) continue; + tracks[i] = tracks[i].slice(0, index); } - setCache({ ...cache, tracks}); + setCache({ ...cache, tracks }); }; const selectTrack = (test) => () => { - if(as1d(cache.tracks).includes(test)) return removeTrack(test); + if (as1d(cache.tracks).includes(test)) return removeTrack(test); addTrack(test); }; - const getColor = (test) => as1d(cache.tracks).includes(test) - ? "primary" - : null; + const getColor = (test) => + as1d(cache.tracks).includes(test) ? "primary" : null; const nextClick = () => { - - setCache({...cache, branches: asBranches(primaries), tree: asTree(cache.tracks)}); + setCache({ + ...cache, + branches: asBranches(primaries), + tree: asTree(cache.tracks), + }); next(); - } + }; return ( diff --git a/tests/assets/suite/runner.js b/tests/assets/suite/runner.js index 7481a7c..114dc9d 100644 --- a/tests/assets/suite/runner.js +++ b/tests/assets/suite/runner.js @@ -1,7 +1,12 @@ import axios from "axios"; import primary from "./primary.js"; -import secondary from "./secondary.js"; -import tertiary from "./tertiary.js"; +import secondary1 from "./secondary1.js"; +import secondary2 from "./secondary2.js"; + +import tertiary1 from "./tertiary1.js"; +import tertiary2 from "./tertiary2.js"; +import tertiary3 from "./tertiary3.js"; + import single from "./single.js"; import failing from "./failing.js"; @@ -12,31 +17,33 @@ const reportingUrl = `${process.env.QUALITEER_URL}/api/dev/rabbit/TestResults`; // Pull args const args = process.argv.slice(2); const test = (args.find((v) => v.includes("test=")) ?? "").replace("test=", ""); -const pipelineData = ( - args.find((v) => v.includes("pipelineData=")) ?? "" -).replace("pipelineData=", ""); -const pipelineTriggers = ( - args.find((v) => v.includes("pipelineTriggers=")) ?? "" -).replace("pipelineTriggers=", ""); -const pipelineDashboardSocket = - (args.find((v) => v.includes("pipelineDashboardSocket=")) ?? "").replace( - "pipelineDashboardSocket=", - "" - ) || undefined; +var pipeline = (args.find((v) => v.includes("pipeline=")) ?? "").replace( + "pipeline=", + "" +); +if (pipeline) + pipeline = JSON.parse(Buffer.from(pipeline, "base64").toString("utf8")); const logNow = () => console.log(Date.now()); const liveIndicator = () => { - for (var i = 0; i < endLiveCount; i++) setTimeout(logNow, i * liveUpdateDelay); + for (var i = 0; i < endLiveCount; i++) + setTimeout(logNow, i * liveUpdateDelay); }; const runTests = () => { switch (test) { case "primary": return primary(); - case "secondary": - return secondary(pipelineData); - case "tertiary": - return tertiary(pipelineData); + case "secondary1": + return secondary1(pipeline.testData); + case "secondary2": + return secondary2(pipeline.testData); + case "tertiary1": + return tertiary1(pipeline.testData); + case "tertiary2": + return tertiary2(pipeline.testData); + case "tertiary3": + return tertiary3(pipeline.testData); case "single": return single(); case "failing": @@ -50,15 +57,18 @@ const runTests = () => { liveIndicator(); setTimeout(() => { const status = runTests(); + pipeline.testData = status.pipelineData; const testResult = { ...status, name: test, - pipelineTriggers: pipelineTriggers ? pipelineTriggers : undefined, - pipelineDashboardSocket, + pipeline, }; - axios.post(reportingUrl, { testResult }).catch((e) => { - console.log(e.response.status); - }).then(()=>{ - if(status.status === 1) process.exit(1); - }); + axios + .post(reportingUrl, { testResult }) + .catch((e) => { + console.log(e.response.status); + }) + .then(() => { + if (status.status === 1) process.exit(1); + }); }, endLiveCount * liveUpdateDelay); diff --git a/tests/assets/suite/secondary.js b/tests/assets/suite/secondary.js deleted file mode 100644 index 5afb55d..0000000 --- a/tests/assets/suite/secondary.js +++ /dev/null @@ -1,4 +0,0 @@ -export default function secondaryTest(pipelineData) { - console.log("This came from a secondary test!"); - return { status: +(pipelineData !== "SomeData"), pipelineData: "SomeOtherData" }; -} diff --git a/tests/assets/suite/secondary1.js b/tests/assets/suite/secondary1.js new file mode 100644 index 0000000..d8b4d04 --- /dev/null +++ b/tests/assets/suite/secondary1.js @@ -0,0 +1,7 @@ +export default function secondaryTest(pipelineData) { + console.log("This came from a secondary1 test!"); + return { + status: +(pipelineData !== "SomeData"), + pipelineData: "SomeOtherData", + }; +} diff --git a/tests/assets/suite/secondary2.js b/tests/assets/suite/secondary2.js new file mode 100644 index 0000000..a95bde9 --- /dev/null +++ b/tests/assets/suite/secondary2.js @@ -0,0 +1,7 @@ +export default function secondaryTest(pipelineData) { + console.log("This came from a secondary2 test!"); + return { + status: +(pipelineData !== "SomeData"), + pipelineData: "SomeOtherOtherData", + }; +} diff --git a/tests/assets/suite/tertiary.js b/tests/assets/suite/tertiary1.js similarity index 71% rename from tests/assets/suite/tertiary.js rename to tests/assets/suite/tertiary1.js index a3176e4..654c3fb 100644 --- a/tests/assets/suite/tertiary.js +++ b/tests/assets/suite/tertiary1.js @@ -1,4 +1,4 @@ export default function secondaryTest(pipelineData) { - console.log("This came from a tertiary!"); + console.log("This came from a tertiary1!"); return { status: +(pipelineData !== "SomeOtherData") }; } diff --git a/tests/assets/suite/tertiary2.js b/tests/assets/suite/tertiary2.js new file mode 100644 index 0000000..63f5108 --- /dev/null +++ b/tests/assets/suite/tertiary2.js @@ -0,0 +1,4 @@ +export default function secondaryTest(pipelineData) { + console.log("This came from a tertiary2!"); + return { status: +(pipelineData !== "SomeOtherData") }; +} diff --git a/tests/assets/suite/tertiary3.js b/tests/assets/suite/tertiary3.js new file mode 100644 index 0000000..f2627ea --- /dev/null +++ b/tests/assets/suite/tertiary3.js @@ -0,0 +1,4 @@ +export default function secondaryTest(pipelineData) { + console.log("This came from a tertiary3!"); + return { status: +(pipelineData !== "SomeOtherData") }; +} diff --git a/tests/index.js b/tests/index.js index ddf0e2a..aaf717c 100644 --- a/tests/index.js +++ b/tests/index.js @@ -14,7 +14,16 @@ const primary = new Initiator(url); const job = { type: "compound", testName: "primary", - pipelineTriggers: "secondary", + pipeline: { + triggers: { + secondary1: { + tertiary1: {}, + tertiary2: { __testDelay: 5000 }, + __testDelay: 1000, + }, + secondary2: { tertiary3: { __testDelay: 3000 }, __testDelay: 15000 }, + }, + }, name: "testing", image: "node", };