| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376 |
- var __defProp = Object.defineProperty;
- var __export = (target, all) => {
- for (var name in all)
- __defProp(target, name, { get: all[name], enumerable: true });
- };
-
- // ../../../../Newweb/starter/node_modules/engine.io-parser/build/esm/commons.js
- var PACKET_TYPES = /* @__PURE__ */ Object.create(null);
- PACKET_TYPES["open"] = "0";
- PACKET_TYPES["close"] = "1";
- PACKET_TYPES["ping"] = "2";
- PACKET_TYPES["pong"] = "3";
- PACKET_TYPES["message"] = "4";
- PACKET_TYPES["upgrade"] = "5";
- PACKET_TYPES["noop"] = "6";
- var PACKET_TYPES_REVERSE = /* @__PURE__ */ Object.create(null);
- Object.keys(PACKET_TYPES).forEach((key) => {
- PACKET_TYPES_REVERSE[PACKET_TYPES[key]] = key;
- });
- var ERROR_PACKET = { type: "error", data: "parser error" };
-
- // ../../../../Newweb/starter/node_modules/engine.io-parser/build/esm/encodePacket.browser.js
- var withNativeBlob = typeof Blob === "function" || typeof Blob !== "undefined" && Object.prototype.toString.call(Blob) === "[object BlobConstructor]";
- var withNativeArrayBuffer = typeof ArrayBuffer === "function";
- var isView = (obj) => {
- return typeof ArrayBuffer.isView === "function" ? ArrayBuffer.isView(obj) : obj && obj.buffer instanceof ArrayBuffer;
- };
- var encodePacket = ({ type, data }, supportsBinary, callback) => {
- if (withNativeBlob && data instanceof Blob) {
- if (supportsBinary) {
- return callback(data);
- } else {
- return encodeBlobAsBase64(data, callback);
- }
- } else if (withNativeArrayBuffer && (data instanceof ArrayBuffer || isView(data))) {
- if (supportsBinary) {
- return callback(data);
- } else {
- return encodeBlobAsBase64(new Blob([data]), callback);
- }
- }
- return callback(PACKET_TYPES[type] + (data || ""));
- };
- var encodeBlobAsBase64 = (data, callback) => {
- const fileReader = new FileReader();
- fileReader.onload = function() {
- const content = fileReader.result.split(",")[1];
- callback("b" + (content || ""));
- };
- return fileReader.readAsDataURL(data);
- };
- function toArray(data) {
- if (data instanceof Uint8Array) {
- return data;
- } else if (data instanceof ArrayBuffer) {
- return new Uint8Array(data);
- } else {
- return new Uint8Array(data.buffer, data.byteOffset, data.byteLength);
- }
- }
- var TEXT_ENCODER;
- function encodePacketToBinary(packet, callback) {
- if (withNativeBlob && packet.data instanceof Blob) {
- return packet.data.arrayBuffer().then(toArray).then(callback);
- } else if (withNativeArrayBuffer && (packet.data instanceof ArrayBuffer || isView(packet.data))) {
- return callback(toArray(packet.data));
- }
- encodePacket(packet, false, (encoded) => {
- if (!TEXT_ENCODER) {
- TEXT_ENCODER = new TextEncoder();
- }
- callback(TEXT_ENCODER.encode(encoded));
- });
- }
-
- // ../../../../Newweb/starter/node_modules/engine.io-parser/build/esm/contrib/base64-arraybuffer.js
- var chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
- var lookup = typeof Uint8Array === "undefined" ? [] : new Uint8Array(256);
- for (let i = 0; i < chars.length; i++) {
- lookup[chars.charCodeAt(i)] = i;
- }
- var decode = (base64) => {
- let bufferLength = base64.length * 0.75, len = base64.length, i, p = 0, encoded1, encoded2, encoded3, encoded4;
- if (base64[base64.length - 1] === "=") {
- bufferLength--;
- if (base64[base64.length - 2] === "=") {
- bufferLength--;
- }
- }
- const arraybuffer = new ArrayBuffer(bufferLength), bytes = new Uint8Array(arraybuffer);
- for (i = 0; i < len; i += 4) {
- encoded1 = lookup[base64.charCodeAt(i)];
- encoded2 = lookup[base64.charCodeAt(i + 1)];
- encoded3 = lookup[base64.charCodeAt(i + 2)];
- encoded4 = lookup[base64.charCodeAt(i + 3)];
- bytes[p++] = encoded1 << 2 | encoded2 >> 4;
- bytes[p++] = (encoded2 & 15) << 4 | encoded3 >> 2;
- bytes[p++] = (encoded3 & 3) << 6 | encoded4 & 63;
- }
- return arraybuffer;
- };
-
- // ../../../../Newweb/starter/node_modules/engine.io-parser/build/esm/decodePacket.browser.js
- var withNativeArrayBuffer2 = typeof ArrayBuffer === "function";
- var decodePacket = (encodedPacket, binaryType) => {
- if (typeof encodedPacket !== "string") {
- return {
- type: "message",
- data: mapBinary(encodedPacket, binaryType)
- };
- }
- const type = encodedPacket.charAt(0);
- if (type === "b") {
- return {
- type: "message",
- data: decodeBase64Packet(encodedPacket.substring(1), binaryType)
- };
- }
- const packetType = PACKET_TYPES_REVERSE[type];
- if (!packetType) {
- return ERROR_PACKET;
- }
- return encodedPacket.length > 1 ? {
- type: PACKET_TYPES_REVERSE[type],
- data: encodedPacket.substring(1)
- } : {
- type: PACKET_TYPES_REVERSE[type]
- };
- };
- var decodeBase64Packet = (data, binaryType) => {
- if (withNativeArrayBuffer2) {
- const decoded = decode(data);
- return mapBinary(decoded, binaryType);
- } else {
- return { base64: true, data };
- }
- };
- var mapBinary = (data, binaryType) => {
- switch (binaryType) {
- case "blob":
- if (data instanceof Blob) {
- return data;
- } else {
- return new Blob([data]);
- }
- case "arraybuffer":
- default:
- if (data instanceof ArrayBuffer) {
- return data;
- } else {
- return data.buffer;
- }
- }
- };
-
- // ../../../../Newweb/starter/node_modules/engine.io-parser/build/esm/index.js
- var SEPARATOR = String.fromCharCode(30);
- var encodePayload = (packets, callback) => {
- const length = packets.length;
- const encodedPackets = new Array(length);
- let count = 0;
- packets.forEach((packet, i) => {
- encodePacket(packet, false, (encodedPacket) => {
- encodedPackets[i] = encodedPacket;
- if (++count === length) {
- callback(encodedPackets.join(SEPARATOR));
- }
- });
- });
- };
- var decodePayload = (encodedPayload, binaryType) => {
- const encodedPackets = encodedPayload.split(SEPARATOR);
- const packets = [];
- for (let i = 0; i < encodedPackets.length; i++) {
- const decodedPacket = decodePacket(encodedPackets[i], binaryType);
- packets.push(decodedPacket);
- if (decodedPacket.type === "error") {
- break;
- }
- }
- return packets;
- };
- function createPacketEncoderStream() {
- return new TransformStream({
- transform(packet, controller) {
- encodePacketToBinary(packet, (encodedPacket) => {
- const payloadLength = encodedPacket.length;
- let header;
- if (payloadLength < 126) {
- header = new Uint8Array(1);
- new DataView(header.buffer).setUint8(0, payloadLength);
- } else if (payloadLength < 65536) {
- header = new Uint8Array(3);
- const view = new DataView(header.buffer);
- view.setUint8(0, 126);
- view.setUint16(1, payloadLength);
- } else {
- header = new Uint8Array(9);
- const view = new DataView(header.buffer);
- view.setUint8(0, 127);
- view.setBigUint64(1, BigInt(payloadLength));
- }
- if (packet.data && typeof packet.data !== "string") {
- header[0] |= 128;
- }
- controller.enqueue(header);
- controller.enqueue(encodedPacket);
- });
- }
- });
- }
- var TEXT_DECODER;
- function totalLength(chunks) {
- return chunks.reduce((acc, chunk) => acc + chunk.length, 0);
- }
- function concatChunks(chunks, size) {
- if (chunks[0].length === size) {
- return chunks.shift();
- }
- const buffer = new Uint8Array(size);
- let j = 0;
- for (let i = 0; i < size; i++) {
- buffer[i] = chunks[0][j++];
- if (j === chunks[0].length) {
- chunks.shift();
- j = 0;
- }
- }
- if (chunks.length && j < chunks[0].length) {
- chunks[0] = chunks[0].slice(j);
- }
- return buffer;
- }
- function createPacketDecoderStream(maxPayload, binaryType) {
- if (!TEXT_DECODER) {
- TEXT_DECODER = new TextDecoder();
- }
- const chunks = [];
- let state = 0;
- let expectedLength = -1;
- let isBinary2 = false;
- return new TransformStream({
- transform(chunk, controller) {
- chunks.push(chunk);
- while (true) {
- if (state === 0) {
- if (totalLength(chunks) < 1) {
- break;
- }
- const header = concatChunks(chunks, 1);
- isBinary2 = (header[0] & 128) === 128;
- expectedLength = header[0] & 127;
- if (expectedLength < 126) {
- state = 3;
- } else if (expectedLength === 126) {
- state = 1;
- } else {
- state = 2;
- }
- } else if (state === 1) {
- if (totalLength(chunks) < 2) {
- break;
- }
- const headerArray = concatChunks(chunks, 2);
- expectedLength = new DataView(headerArray.buffer, headerArray.byteOffset, headerArray.length).getUint16(0);
- state = 3;
- } else if (state === 2) {
- if (totalLength(chunks) < 8) {
- break;
- }
- const headerArray = concatChunks(chunks, 8);
- const view = new DataView(headerArray.buffer, headerArray.byteOffset, headerArray.length);
- const n = view.getUint32(0);
- if (n > Math.pow(2, 53 - 32) - 1) {
- controller.enqueue(ERROR_PACKET);
- break;
- }
- expectedLength = n * Math.pow(2, 32) + view.getUint32(4);
- state = 3;
- } else {
- if (totalLength(chunks) < expectedLength) {
- break;
- }
- const data = concatChunks(chunks, expectedLength);
- controller.enqueue(decodePacket(isBinary2 ? data : TEXT_DECODER.decode(data), binaryType));
- state = 0;
- }
- if (expectedLength === 0 || expectedLength > maxPayload) {
- controller.enqueue(ERROR_PACKET);
- break;
- }
- }
- }
- });
- }
- var protocol = 4;
-
- // ../../../../Newweb/starter/node_modules/@socket.io/component-emitter/lib/esm/index.js
- function Emitter(obj) {
- if (obj)
- return mixin(obj);
- }
- function mixin(obj) {
- for (var key in Emitter.prototype) {
- obj[key] = Emitter.prototype[key];
- }
- return obj;
- }
- Emitter.prototype.on = Emitter.prototype.addEventListener = function(event, fn) {
- this._callbacks = this._callbacks || {};
- (this._callbacks["$" + event] = this._callbacks["$" + event] || []).push(fn);
- return this;
- };
- Emitter.prototype.once = function(event, fn) {
- function on2() {
- this.off(event, on2);
- fn.apply(this, arguments);
- }
- on2.fn = fn;
- this.on(event, on2);
- return this;
- };
- Emitter.prototype.off = Emitter.prototype.removeListener = Emitter.prototype.removeAllListeners = Emitter.prototype.removeEventListener = function(event, fn) {
- this._callbacks = this._callbacks || {};
- if (0 == arguments.length) {
- this._callbacks = {};
- return this;
- }
- var callbacks = this._callbacks["$" + event];
- if (!callbacks)
- return this;
- if (1 == arguments.length) {
- delete this._callbacks["$" + event];
- return this;
- }
- var cb;
- for (var i = 0; i < callbacks.length; i++) {
- cb = callbacks[i];
- if (cb === fn || cb.fn === fn) {
- callbacks.splice(i, 1);
- break;
- }
- }
- if (callbacks.length === 0) {
- delete this._callbacks["$" + event];
- }
- return this;
- };
- Emitter.prototype.emit = function(event) {
- this._callbacks = this._callbacks || {};
- var args = new Array(arguments.length - 1), callbacks = this._callbacks["$" + event];
- for (var i = 1; i < arguments.length; i++) {
- args[i - 1] = arguments[i];
- }
- if (callbacks) {
- callbacks = callbacks.slice(0);
- for (var i = 0, len = callbacks.length; i < len; ++i) {
- callbacks[i].apply(this, args);
- }
- }
- return this;
- };
- Emitter.prototype.emitReserved = Emitter.prototype.emit;
- Emitter.prototype.listeners = function(event) {
- this._callbacks = this._callbacks || {};
- return this._callbacks["$" + event] || [];
- };
- Emitter.prototype.hasListeners = function(event) {
- return !!this.listeners(event).length;
- };
-
- // ../../../../Newweb/starter/node_modules/engine.io-client/build/esm/globals.js
- var nextTick = (() => {
- const isPromiseAvailable = typeof Promise === "function" && typeof Promise.resolve === "function";
- if (isPromiseAvailable) {
- return (cb) => Promise.resolve().then(cb);
- } else {
- return (cb, setTimeoutFn) => setTimeoutFn(cb, 0);
- }
- })();
- var globalThisShim = (() => {
- if (typeof self !== "undefined") {
- return self;
- } else if (typeof window !== "undefined") {
- return window;
- } else {
- return Function("return this")();
- }
- })();
- var defaultBinaryType = "arraybuffer";
- function createCookieJar() {
- }
-
- // ../../../../Newweb/starter/node_modules/engine.io-client/build/esm/util.js
- function pick(obj, ...attr) {
- return attr.reduce((acc, k) => {
- if (obj.hasOwnProperty(k)) {
- acc[k] = obj[k];
- }
- return acc;
- }, {});
- }
- var NATIVE_SET_TIMEOUT = globalThisShim.setTimeout;
- var NATIVE_CLEAR_TIMEOUT = globalThisShim.clearTimeout;
- function installTimerFunctions(obj, opts) {
- if (opts.useNativeTimers) {
- obj.setTimeoutFn = NATIVE_SET_TIMEOUT.bind(globalThisShim);
- obj.clearTimeoutFn = NATIVE_CLEAR_TIMEOUT.bind(globalThisShim);
- } else {
- obj.setTimeoutFn = globalThisShim.setTimeout.bind(globalThisShim);
- obj.clearTimeoutFn = globalThisShim.clearTimeout.bind(globalThisShim);
- }
- }
- var BASE64_OVERHEAD = 1.33;
- function byteLength(obj) {
- if (typeof obj === "string") {
- return utf8Length(obj);
- }
- return Math.ceil((obj.byteLength || obj.size) * BASE64_OVERHEAD);
- }
- function utf8Length(str) {
- let c = 0, length = 0;
- for (let i = 0, l = str.length; i < l; i++) {
- c = str.charCodeAt(i);
- if (c < 128) {
- length += 1;
- } else if (c < 2048) {
- length += 2;
- } else if (c < 55296 || c >= 57344) {
- length += 3;
- } else {
- i++;
- length += 4;
- }
- }
- return length;
- }
- function randomString() {
- return Date.now().toString(36).substring(3) + Math.random().toString(36).substring(2, 5);
- }
-
- // ../../../../Newweb/starter/node_modules/engine.io-client/build/esm/contrib/parseqs.js
- function encode(obj) {
- let str = "";
- for (let i in obj) {
- if (obj.hasOwnProperty(i)) {
- if (str.length)
- str += "&";
- str += encodeURIComponent(i) + "=" + encodeURIComponent(obj[i]);
- }
- }
- return str;
- }
- function decode2(qs) {
- let qry = {};
- let pairs = qs.split("&");
- for (let i = 0, l = pairs.length; i < l; i++) {
- let pair = pairs[i].split("=");
- qry[decodeURIComponent(pair[0])] = decodeURIComponent(pair[1]);
- }
- return qry;
- }
-
- // ../../../../Newweb/starter/node_modules/engine.io-client/build/esm/transport.js
- var TransportError = class extends Error {
- constructor(reason, description, context) {
- super(reason);
- this.description = description;
- this.context = context;
- this.type = "TransportError";
- }
- };
- var Transport = class extends Emitter {
- /**
- * Transport abstract constructor.
- *
- * @param {Object} opts - options
- * @protected
- */
- constructor(opts) {
- super();
- this.writable = false;
- installTimerFunctions(this, opts);
- this.opts = opts;
- this.query = opts.query;
- this.socket = opts.socket;
- this.supportsBinary = !opts.forceBase64;
- }
- /**
- * Emits an error.
- *
- * @param {String} reason
- * @param description
- * @param context - the error context
- * @return {Transport} for chaining
- * @protected
- */
- onError(reason, description, context) {
- super.emitReserved("error", new TransportError(reason, description, context));
- return this;
- }
- /**
- * Opens the transport.
- */
- open() {
- this.readyState = "opening";
- this.doOpen();
- return this;
- }
- /**
- * Closes the transport.
- */
- close() {
- if (this.readyState === "opening" || this.readyState === "open") {
- this.doClose();
- this.onClose();
- }
- return this;
- }
- /**
- * Sends multiple packets.
- *
- * @param {Array} packets
- */
- send(packets) {
- if (this.readyState === "open") {
- this.write(packets);
- } else {
- }
- }
- /**
- * Called upon open
- *
- * @protected
- */
- onOpen() {
- this.readyState = "open";
- this.writable = true;
- super.emitReserved("open");
- }
- /**
- * Called with data.
- *
- * @param {String} data
- * @protected
- */
- onData(data) {
- const packet = decodePacket(data, this.socket.binaryType);
- this.onPacket(packet);
- }
- /**
- * Called with a decoded packet.
- *
- * @protected
- */
- onPacket(packet) {
- super.emitReserved("packet", packet);
- }
- /**
- * Called upon close.
- *
- * @protected
- */
- onClose(details) {
- this.readyState = "closed";
- super.emitReserved("close", details);
- }
- /**
- * Pauses the transport, in order not to lose packets during an upgrade.
- *
- * @param onPause
- */
- pause(onPause) {
- }
- createUri(schema, query = {}) {
- return schema + "://" + this._hostname() + this._port() + this.opts.path + this._query(query);
- }
- _hostname() {
- const hostname = this.opts.hostname;
- return hostname.indexOf(":") === -1 ? hostname : "[" + hostname + "]";
- }
- _port() {
- if (this.opts.port && (this.opts.secure && Number(this.opts.port !== 443) || !this.opts.secure && Number(this.opts.port) !== 80)) {
- return ":" + this.opts.port;
- } else {
- return "";
- }
- }
- _query(query) {
- const encodedQuery = encode(query);
- return encodedQuery.length ? "?" + encodedQuery : "";
- }
- };
-
- // ../../../../Newweb/starter/node_modules/engine.io-client/build/esm/transports/polling.js
- var Polling = class extends Transport {
- constructor() {
- super(...arguments);
- this._polling = false;
- }
- get name() {
- return "polling";
- }
- /**
- * Opens the socket (triggers polling). We write a PING message to determine
- * when the transport is open.
- *
- * @protected
- */
- doOpen() {
- this._poll();
- }
- /**
- * Pauses polling.
- *
- * @param {Function} onPause - callback upon buffers are flushed and transport is paused
- * @package
- */
- pause(onPause) {
- this.readyState = "pausing";
- const pause = () => {
- this.readyState = "paused";
- onPause();
- };
- if (this._polling || !this.writable) {
- let total = 0;
- if (this._polling) {
- total++;
- this.once("pollComplete", function() {
- --total || pause();
- });
- }
- if (!this.writable) {
- total++;
- this.once("drain", function() {
- --total || pause();
- });
- }
- } else {
- pause();
- }
- }
- /**
- * Starts polling cycle.
- *
- * @private
- */
- _poll() {
- this._polling = true;
- this.doPoll();
- this.emitReserved("poll");
- }
- /**
- * Overloads onData to detect payloads.
- *
- * @protected
- */
- onData(data) {
- const callback = (packet) => {
- if ("opening" === this.readyState && packet.type === "open") {
- this.onOpen();
- }
- if ("close" === packet.type) {
- this.onClose({ description: "transport closed by the server" });
- return false;
- }
- this.onPacket(packet);
- };
- decodePayload(data, this.socket.binaryType).forEach(callback);
- if ("closed" !== this.readyState) {
- this._polling = false;
- this.emitReserved("pollComplete");
- if ("open" === this.readyState) {
- this._poll();
- } else {
- }
- }
- }
- /**
- * For polling, send a close packet.
- *
- * @protected
- */
- doClose() {
- const close = () => {
- this.write([{ type: "close" }]);
- };
- if ("open" === this.readyState) {
- close();
- } else {
- this.once("open", close);
- }
- }
- /**
- * Writes a packets payload.
- *
- * @param {Array} packets - data packets
- * @protected
- */
- write(packets) {
- this.writable = false;
- encodePayload(packets, (data) => {
- this.doWrite(data, () => {
- this.writable = true;
- this.emitReserved("drain");
- });
- });
- }
- /**
- * Generates uri for connection.
- *
- * @private
- */
- uri() {
- const schema = this.opts.secure ? "https" : "http";
- const query = this.query || {};
- if (false !== this.opts.timestampRequests) {
- query[this.opts.timestampParam] = randomString();
- }
- if (!this.supportsBinary && !query.sid) {
- query.b64 = 1;
- }
- return this.createUri(schema, query);
- }
- };
-
- // ../../../../Newweb/starter/node_modules/engine.io-client/build/esm/contrib/has-cors.js
- var value = false;
- try {
- value = typeof XMLHttpRequest !== "undefined" && "withCredentials" in new XMLHttpRequest();
- } catch (err) {
- }
- var hasCORS = value;
-
- // ../../../../Newweb/starter/node_modules/engine.io-client/build/esm/transports/polling-xhr.js
- function empty() {
- }
- var BaseXHR = class extends Polling {
- /**
- * XHR Polling constructor.
- *
- * @param {Object} opts
- * @package
- */
- constructor(opts) {
- super(opts);
- if (typeof location !== "undefined") {
- const isSSL = "https:" === location.protocol;
- let port = location.port;
- if (!port) {
- port = isSSL ? "443" : "80";
- }
- this.xd = typeof location !== "undefined" && opts.hostname !== location.hostname || port !== opts.port;
- }
- }
- /**
- * Sends data.
- *
- * @param {String} data to send.
- * @param {Function} called upon flush.
- * @private
- */
- doWrite(data, fn) {
- const req = this.request({
- method: "POST",
- data
- });
- req.on("success", fn);
- req.on("error", (xhrStatus, context) => {
- this.onError("xhr post error", xhrStatus, context);
- });
- }
- /**
- * Starts a poll cycle.
- *
- * @private
- */
- doPoll() {
- const req = this.request();
- req.on("data", this.onData.bind(this));
- req.on("error", (xhrStatus, context) => {
- this.onError("xhr poll error", xhrStatus, context);
- });
- this.pollXhr = req;
- }
- };
- var Request = class _Request extends Emitter {
- /**
- * Request constructor
- *
- * @param {Object} options
- * @package
- */
- constructor(createRequest, uri, opts) {
- super();
- this.createRequest = createRequest;
- installTimerFunctions(this, opts);
- this._opts = opts;
- this._method = opts.method || "GET";
- this._uri = uri;
- this._data = void 0 !== opts.data ? opts.data : null;
- this._create();
- }
- /**
- * Creates the XHR object and sends the request.
- *
- * @private
- */
- _create() {
- var _a;
- const opts = pick(this._opts, "agent", "pfx", "key", "passphrase", "cert", "ca", "ciphers", "rejectUnauthorized", "autoUnref");
- opts.xdomain = !!this._opts.xd;
- const xhr = this._xhr = this.createRequest(opts);
- try {
- xhr.open(this._method, this._uri, true);
- try {
- if (this._opts.extraHeaders) {
- xhr.setDisableHeaderCheck && xhr.setDisableHeaderCheck(true);
- for (let i in this._opts.extraHeaders) {
- if (this._opts.extraHeaders.hasOwnProperty(i)) {
- xhr.setRequestHeader(i, this._opts.extraHeaders[i]);
- }
- }
- }
- } catch (e) {
- }
- if ("POST" === this._method) {
- try {
- xhr.setRequestHeader("Content-type", "text/plain;charset=UTF-8");
- } catch (e) {
- }
- }
- try {
- xhr.setRequestHeader("Accept", "*/*");
- } catch (e) {
- }
- (_a = this._opts.cookieJar) === null || _a === void 0 ? void 0 : _a.addCookies(xhr);
- if ("withCredentials" in xhr) {
- xhr.withCredentials = this._opts.withCredentials;
- }
- if (this._opts.requestTimeout) {
- xhr.timeout = this._opts.requestTimeout;
- }
- xhr.onreadystatechange = () => {
- var _a2;
- if (xhr.readyState === 3) {
- (_a2 = this._opts.cookieJar) === null || _a2 === void 0 ? void 0 : _a2.parseCookies(
- // @ts-ignore
- xhr.getResponseHeader("set-cookie")
- );
- }
- if (4 !== xhr.readyState)
- return;
- if (200 === xhr.status || 1223 === xhr.status) {
- this._onLoad();
- } else {
- this.setTimeoutFn(() => {
- this._onError(typeof xhr.status === "number" ? xhr.status : 0);
- }, 0);
- }
- };
- xhr.send(this._data);
- } catch (e) {
- this.setTimeoutFn(() => {
- this._onError(e);
- }, 0);
- return;
- }
- if (typeof document !== "undefined") {
- this._index = _Request.requestsCount++;
- _Request.requests[this._index] = this;
- }
- }
- /**
- * Called upon error.
- *
- * @private
- */
- _onError(err) {
- this.emitReserved("error", err, this._xhr);
- this._cleanup(true);
- }
- /**
- * Cleans up house.
- *
- * @private
- */
- _cleanup(fromError) {
- if ("undefined" === typeof this._xhr || null === this._xhr) {
- return;
- }
- this._xhr.onreadystatechange = empty;
- if (fromError) {
- try {
- this._xhr.abort();
- } catch (e) {
- }
- }
- if (typeof document !== "undefined") {
- delete _Request.requests[this._index];
- }
- this._xhr = null;
- }
- /**
- * Called upon load.
- *
- * @private
- */
- _onLoad() {
- const data = this._xhr.responseText;
- if (data !== null) {
- this.emitReserved("data", data);
- this.emitReserved("success");
- this._cleanup();
- }
- }
- /**
- * Aborts the request.
- *
- * @package
- */
- abort() {
- this._cleanup();
- }
- };
- Request.requestsCount = 0;
- Request.requests = {};
- if (typeof document !== "undefined") {
- if (typeof attachEvent === "function") {
- attachEvent("onunload", unloadHandler);
- } else if (typeof addEventListener === "function") {
- const terminationEvent = "onpagehide" in globalThisShim ? "pagehide" : "unload";
- addEventListener(terminationEvent, unloadHandler, false);
- }
- }
- function unloadHandler() {
- for (let i in Request.requests) {
- if (Request.requests.hasOwnProperty(i)) {
- Request.requests[i].abort();
- }
- }
- }
- var hasXHR2 = function() {
- const xhr = newRequest({
- xdomain: false
- });
- return xhr && xhr.responseType !== null;
- }();
- var XHR = class extends BaseXHR {
- constructor(opts) {
- super(opts);
- const forceBase64 = opts && opts.forceBase64;
- this.supportsBinary = hasXHR2 && !forceBase64;
- }
- request(opts = {}) {
- Object.assign(opts, { xd: this.xd }, this.opts);
- return new Request(newRequest, this.uri(), opts);
- }
- };
- function newRequest(opts) {
- const xdomain = opts.xdomain;
- try {
- if ("undefined" !== typeof XMLHttpRequest && (!xdomain || hasCORS)) {
- return new XMLHttpRequest();
- }
- } catch (e) {
- }
- if (!xdomain) {
- try {
- return new globalThisShim[["Active"].concat("Object").join("X")]("Microsoft.XMLHTTP");
- } catch (e) {
- }
- }
- }
-
- // ../../../../Newweb/starter/node_modules/engine.io-client/build/esm/transports/websocket.js
- var isReactNative = typeof navigator !== "undefined" && typeof navigator.product === "string" && navigator.product.toLowerCase() === "reactnative";
- var BaseWS = class extends Transport {
- get name() {
- return "websocket";
- }
- doOpen() {
- const uri = this.uri();
- const protocols = this.opts.protocols;
- const opts = isReactNative ? {} : pick(this.opts, "agent", "perMessageDeflate", "pfx", "key", "passphrase", "cert", "ca", "ciphers", "rejectUnauthorized", "localAddress", "protocolVersion", "origin", "maxPayload", "family", "checkServerIdentity");
- if (this.opts.extraHeaders) {
- opts.headers = this.opts.extraHeaders;
- }
- try {
- this.ws = this.createSocket(uri, protocols, opts);
- } catch (err) {
- return this.emitReserved("error", err);
- }
- this.ws.binaryType = this.socket.binaryType;
- this.addEventListeners();
- }
- /**
- * Adds event listeners to the socket
- *
- * @private
- */
- addEventListeners() {
- this.ws.onopen = () => {
- if (this.opts.autoUnref) {
- this.ws._socket.unref();
- }
- this.onOpen();
- };
- this.ws.onclose = (closeEvent) => this.onClose({
- description: "websocket connection closed",
- context: closeEvent
- });
- this.ws.onmessage = (ev) => this.onData(ev.data);
- this.ws.onerror = (e) => this.onError("websocket error", e);
- }
- write(packets) {
- this.writable = false;
- for (let i = 0; i < packets.length; i++) {
- const packet = packets[i];
- const lastPacket = i === packets.length - 1;
- encodePacket(packet, this.supportsBinary, (data) => {
- try {
- this.doWrite(packet, data);
- } catch (e) {
- }
- if (lastPacket) {
- nextTick(() => {
- this.writable = true;
- this.emitReserved("drain");
- }, this.setTimeoutFn);
- }
- });
- }
- }
- doClose() {
- if (typeof this.ws !== "undefined") {
- this.ws.close();
- this.ws = null;
- }
- }
- /**
- * Generates uri for connection.
- *
- * @private
- */
- uri() {
- const schema = this.opts.secure ? "wss" : "ws";
- const query = this.query || {};
- if (this.opts.timestampRequests) {
- query[this.opts.timestampParam] = randomString();
- }
- if (!this.supportsBinary) {
- query.b64 = 1;
- }
- return this.createUri(schema, query);
- }
- };
- var WebSocketCtor = globalThisShim.WebSocket || globalThisShim.MozWebSocket;
- var WS = class extends BaseWS {
- createSocket(uri, protocols, opts) {
- return !isReactNative ? protocols ? new WebSocketCtor(uri, protocols) : new WebSocketCtor(uri) : new WebSocketCtor(uri, protocols, opts);
- }
- doWrite(_packet, data) {
- this.ws.send(data);
- }
- };
-
- // ../../../../Newweb/starter/node_modules/engine.io-client/build/esm/transports/webtransport.js
- var WT = class extends Transport {
- get name() {
- return "webtransport";
- }
- doOpen() {
- try {
- this._transport = new WebTransport(this.createUri("https"), this.opts.transportOptions[this.name]);
- } catch (err) {
- return this.emitReserved("error", err);
- }
- this._transport.closed.then(() => {
- this.onClose();
- }).catch((err) => {
- this.onError("webtransport error", err);
- });
- this._transport.ready.then(() => {
- this._transport.createBidirectionalStream().then((stream) => {
- const decoderStream = createPacketDecoderStream(Number.MAX_SAFE_INTEGER, this.socket.binaryType);
- const reader = stream.readable.pipeThrough(decoderStream).getReader();
- const encoderStream = createPacketEncoderStream();
- encoderStream.readable.pipeTo(stream.writable);
- this._writer = encoderStream.writable.getWriter();
- const read = () => {
- reader.read().then(({ done, value: value2 }) => {
- if (done) {
- return;
- }
- this.onPacket(value2);
- read();
- }).catch((err) => {
- });
- };
- read();
- const packet = { type: "open" };
- if (this.query.sid) {
- packet.data = `{"sid":"${this.query.sid}"}`;
- }
- this._writer.write(packet).then(() => this.onOpen());
- });
- });
- }
- write(packets) {
- this.writable = false;
- for (let i = 0; i < packets.length; i++) {
- const packet = packets[i];
- const lastPacket = i === packets.length - 1;
- this._writer.write(packet).then(() => {
- if (lastPacket) {
- nextTick(() => {
- this.writable = true;
- this.emitReserved("drain");
- }, this.setTimeoutFn);
- }
- });
- }
- }
- doClose() {
- var _a;
- (_a = this._transport) === null || _a === void 0 ? void 0 : _a.close();
- }
- };
-
- // ../../../../Newweb/starter/node_modules/engine.io-client/build/esm/transports/index.js
- var transports = {
- websocket: WS,
- webtransport: WT,
- polling: XHR
- };
-
- // ../../../../Newweb/starter/node_modules/engine.io-client/build/esm/contrib/parseuri.js
- var re = /^(?:(?![^:@\/?#]+:[^:@\/]*@)(http|https|ws|wss):\/\/)?((?:(([^:@\/?#]*)(?::([^:@\/?#]*))?)?@)?((?:[a-f0-9]{0,4}:){2,7}[a-f0-9]{0,4}|[^:\/?#]*)(?::(\d*))?)(((\/(?:[^?#](?![^?#\/]*\.[^?#\/.]+(?:[?#]|$)))*\/?)?([^?#\/]*))(?:\?([^#]*))?(?:#(.*))?)/;
- var parts = [
- "source",
- "protocol",
- "authority",
- "userInfo",
- "user",
- "password",
- "host",
- "port",
- "relative",
- "path",
- "directory",
- "file",
- "query",
- "anchor"
- ];
- function parse(str) {
- if (str.length > 8e3) {
- throw "URI too long";
- }
- const src = str, b = str.indexOf("["), e = str.indexOf("]");
- if (b != -1 && e != -1) {
- str = str.substring(0, b) + str.substring(b, e).replace(/:/g, ";") + str.substring(e, str.length);
- }
- let m = re.exec(str || ""), uri = {}, i = 14;
- while (i--) {
- uri[parts[i]] = m[i] || "";
- }
- if (b != -1 && e != -1) {
- uri.source = src;
- uri.host = uri.host.substring(1, uri.host.length - 1).replace(/;/g, ":");
- uri.authority = uri.authority.replace("[", "").replace("]", "").replace(/;/g, ":");
- uri.ipv6uri = true;
- }
- uri.pathNames = pathNames(uri, uri["path"]);
- uri.queryKey = queryKey(uri, uri["query"]);
- return uri;
- }
- function pathNames(obj, path) {
- const regx = /\/{2,9}/g, names = path.replace(regx, "/").split("/");
- if (path.slice(0, 1) == "/" || path.length === 0) {
- names.splice(0, 1);
- }
- if (path.slice(-1) == "/") {
- names.splice(names.length - 1, 1);
- }
- return names;
- }
- function queryKey(uri, query) {
- const data = {};
- query.replace(/(?:^|&)([^&=]*)=?([^&]*)/g, function($0, $1, $2) {
- if ($1) {
- data[$1] = $2;
- }
- });
- return data;
- }
-
- // ../../../../Newweb/starter/node_modules/engine.io-client/build/esm/socket.js
- var withEventListeners = typeof addEventListener === "function" && typeof removeEventListener === "function";
- var OFFLINE_EVENT_LISTENERS = [];
- if (withEventListeners) {
- addEventListener("offline", () => {
- OFFLINE_EVENT_LISTENERS.forEach((listener) => listener());
- }, false);
- }
- var SocketWithoutUpgrade = class _SocketWithoutUpgrade extends Emitter {
- /**
- * Socket constructor.
- *
- * @param {String|Object} uri - uri or options
- * @param {Object} opts - options
- */
- constructor(uri, opts) {
- super();
- this.binaryType = defaultBinaryType;
- this.writeBuffer = [];
- this._prevBufferLen = 0;
- this._pingInterval = -1;
- this._pingTimeout = -1;
- this._maxPayload = -1;
- this._pingTimeoutTime = Infinity;
- if (uri && "object" === typeof uri) {
- opts = uri;
- uri = null;
- }
- if (uri) {
- const parsedUri = parse(uri);
- opts.hostname = parsedUri.host;
- opts.secure = parsedUri.protocol === "https" || parsedUri.protocol === "wss";
- opts.port = parsedUri.port;
- if (parsedUri.query)
- opts.query = parsedUri.query;
- } else if (opts.host) {
- opts.hostname = parse(opts.host).host;
- }
- installTimerFunctions(this, opts);
- this.secure = null != opts.secure ? opts.secure : typeof location !== "undefined" && "https:" === location.protocol;
- if (opts.hostname && !opts.port) {
- opts.port = this.secure ? "443" : "80";
- }
- this.hostname = opts.hostname || (typeof location !== "undefined" ? location.hostname : "localhost");
- this.port = opts.port || (typeof location !== "undefined" && location.port ? location.port : this.secure ? "443" : "80");
- this.transports = [];
- this._transportsByName = {};
- opts.transports.forEach((t) => {
- const transportName = t.prototype.name;
- this.transports.push(transportName);
- this._transportsByName[transportName] = t;
- });
- this.opts = Object.assign({
- path: "/engine.io",
- agent: false,
- withCredentials: false,
- upgrade: true,
- timestampParam: "t",
- rememberUpgrade: false,
- addTrailingSlash: true,
- rejectUnauthorized: true,
- perMessageDeflate: {
- threshold: 1024
- },
- transportOptions: {},
- closeOnBeforeunload: false
- }, opts);
- this.opts.path = this.opts.path.replace(/\/$/, "") + (this.opts.addTrailingSlash ? "/" : "");
- if (typeof this.opts.query === "string") {
- this.opts.query = decode2(this.opts.query);
- }
- if (withEventListeners) {
- if (this.opts.closeOnBeforeunload) {
- this._beforeunloadEventListener = () => {
- if (this.transport) {
- this.transport.removeAllListeners();
- this.transport.close();
- }
- };
- addEventListener("beforeunload", this._beforeunloadEventListener, false);
- }
- if (this.hostname !== "localhost") {
- this._offlineEventListener = () => {
- this._onClose("transport close", {
- description: "network connection lost"
- });
- };
- OFFLINE_EVENT_LISTENERS.push(this._offlineEventListener);
- }
- }
- if (this.opts.withCredentials) {
- this._cookieJar = createCookieJar();
- }
- this._open();
- }
- /**
- * Creates transport of the given type.
- *
- * @param {String} name - transport name
- * @return {Transport}
- * @private
- */
- createTransport(name) {
- const query = Object.assign({}, this.opts.query);
- query.EIO = protocol;
- query.transport = name;
- if (this.id)
- query.sid = this.id;
- const opts = Object.assign({}, this.opts, {
- query,
- socket: this,
- hostname: this.hostname,
- secure: this.secure,
- port: this.port
- }, this.opts.transportOptions[name]);
- return new this._transportsByName[name](opts);
- }
- /**
- * Initializes transport to use and starts probe.
- *
- * @private
- */
- _open() {
- if (this.transports.length === 0) {
- this.setTimeoutFn(() => {
- this.emitReserved("error", "No transports available");
- }, 0);
- return;
- }
- const transportName = this.opts.rememberUpgrade && _SocketWithoutUpgrade.priorWebsocketSuccess && this.transports.indexOf("websocket") !== -1 ? "websocket" : this.transports[0];
- this.readyState = "opening";
- const transport = this.createTransport(transportName);
- transport.open();
- this.setTransport(transport);
- }
- /**
- * Sets the current transport. Disables the existing one (if any).
- *
- * @private
- */
- setTransport(transport) {
- if (this.transport) {
- this.transport.removeAllListeners();
- }
- this.transport = transport;
- transport.on("drain", this._onDrain.bind(this)).on("packet", this._onPacket.bind(this)).on("error", this._onError.bind(this)).on("close", (reason) => this._onClose("transport close", reason));
- }
- /**
- * Called when connection is deemed open.
- *
- * @private
- */
- onOpen() {
- this.readyState = "open";
- _SocketWithoutUpgrade.priorWebsocketSuccess = "websocket" === this.transport.name;
- this.emitReserved("open");
- this.flush();
- }
- /**
- * Handles a packet.
- *
- * @private
- */
- _onPacket(packet) {
- if ("opening" === this.readyState || "open" === this.readyState || "closing" === this.readyState) {
- this.emitReserved("packet", packet);
- this.emitReserved("heartbeat");
- switch (packet.type) {
- case "open":
- this.onHandshake(JSON.parse(packet.data));
- break;
- case "ping":
- this._sendPacket("pong");
- this.emitReserved("ping");
- this.emitReserved("pong");
- this._resetPingTimeout();
- break;
- case "error":
- const err = new Error("server error");
- err.code = packet.data;
- this._onError(err);
- break;
- case "message":
- this.emitReserved("data", packet.data);
- this.emitReserved("message", packet.data);
- break;
- }
- } else {
- }
- }
- /**
- * Called upon handshake completion.
- *
- * @param {Object} data - handshake obj
- * @private
- */
- onHandshake(data) {
- this.emitReserved("handshake", data);
- this.id = data.sid;
- this.transport.query.sid = data.sid;
- this._pingInterval = data.pingInterval;
- this._pingTimeout = data.pingTimeout;
- this._maxPayload = data.maxPayload;
- this.onOpen();
- if ("closed" === this.readyState)
- return;
- this._resetPingTimeout();
- }
- /**
- * Sets and resets ping timeout timer based on server pings.
- *
- * @private
- */
- _resetPingTimeout() {
- this.clearTimeoutFn(this._pingTimeoutTimer);
- const delay = this._pingInterval + this._pingTimeout;
- this._pingTimeoutTime = Date.now() + delay;
- this._pingTimeoutTimer = this.setTimeoutFn(() => {
- this._onClose("ping timeout");
- }, delay);
- if (this.opts.autoUnref) {
- this._pingTimeoutTimer.unref();
- }
- }
- /**
- * Called on `drain` event
- *
- * @private
- */
- _onDrain() {
- this.writeBuffer.splice(0, this._prevBufferLen);
- this._prevBufferLen = 0;
- if (0 === this.writeBuffer.length) {
- this.emitReserved("drain");
- } else {
- this.flush();
- }
- }
- /**
- * Flush write buffers.
- *
- * @private
- */
- flush() {
- if ("closed" !== this.readyState && this.transport.writable && !this.upgrading && this.writeBuffer.length) {
- const packets = this._getWritablePackets();
- this.transport.send(packets);
- this._prevBufferLen = packets.length;
- this.emitReserved("flush");
- }
- }
- /**
- * Ensure the encoded size of the writeBuffer is below the maxPayload value sent by the server (only for HTTP
- * long-polling)
- *
- * @private
- */
- _getWritablePackets() {
- const shouldCheckPayloadSize = this._maxPayload && this.transport.name === "polling" && this.writeBuffer.length > 1;
- if (!shouldCheckPayloadSize) {
- return this.writeBuffer;
- }
- let payloadSize = 1;
- for (let i = 0; i < this.writeBuffer.length; i++) {
- const data = this.writeBuffer[i].data;
- if (data) {
- payloadSize += byteLength(data);
- }
- if (i > 0 && payloadSize > this._maxPayload) {
- return this.writeBuffer.slice(0, i);
- }
- payloadSize += 2;
- }
- return this.writeBuffer;
- }
- /**
- * Checks whether the heartbeat timer has expired but the socket has not yet been notified.
- *
- * Note: this method is private for now because it does not really fit the WebSocket API, but if we put it in the
- * `write()` method then the message would not be buffered by the Socket.IO client.
- *
- * @return {boolean}
- * @private
- */
- /* private */
- _hasPingExpired() {
- if (!this._pingTimeoutTime)
- return true;
- const hasExpired = Date.now() > this._pingTimeoutTime;
- if (hasExpired) {
- this._pingTimeoutTime = 0;
- nextTick(() => {
- this._onClose("ping timeout");
- }, this.setTimeoutFn);
- }
- return hasExpired;
- }
- /**
- * Sends a message.
- *
- * @param {String} msg - message.
- * @param {Object} options.
- * @param {Function} fn - callback function.
- * @return {Socket} for chaining.
- */
- write(msg, options, fn) {
- this._sendPacket("message", msg, options, fn);
- return this;
- }
- /**
- * Sends a message. Alias of {@link Socket#write}.
- *
- * @param {String} msg - message.
- * @param {Object} options.
- * @param {Function} fn - callback function.
- * @return {Socket} for chaining.
- */
- send(msg, options, fn) {
- this._sendPacket("message", msg, options, fn);
- return this;
- }
- /**
- * Sends a packet.
- *
- * @param {String} type: packet type.
- * @param {String} data.
- * @param {Object} options.
- * @param {Function} fn - callback function.
- * @private
- */
- _sendPacket(type, data, options, fn) {
- if ("function" === typeof data) {
- fn = data;
- data = void 0;
- }
- if ("function" === typeof options) {
- fn = options;
- options = null;
- }
- if ("closing" === this.readyState || "closed" === this.readyState) {
- return;
- }
- options = options || {};
- options.compress = false !== options.compress;
- const packet = {
- type,
- data,
- options
- };
- this.emitReserved("packetCreate", packet);
- this.writeBuffer.push(packet);
- if (fn)
- this.once("flush", fn);
- this.flush();
- }
- /**
- * Closes the connection.
- */
- close() {
- const close = () => {
- this._onClose("forced close");
- this.transport.close();
- };
- const cleanupAndClose = () => {
- this.off("upgrade", cleanupAndClose);
- this.off("upgradeError", cleanupAndClose);
- close();
- };
- const waitForUpgrade = () => {
- this.once("upgrade", cleanupAndClose);
- this.once("upgradeError", cleanupAndClose);
- };
- if ("opening" === this.readyState || "open" === this.readyState) {
- this.readyState = "closing";
- if (this.writeBuffer.length) {
- this.once("drain", () => {
- if (this.upgrading) {
- waitForUpgrade();
- } else {
- close();
- }
- });
- } else if (this.upgrading) {
- waitForUpgrade();
- } else {
- close();
- }
- }
- return this;
- }
- /**
- * Called upon transport error
- *
- * @private
- */
- _onError(err) {
- _SocketWithoutUpgrade.priorWebsocketSuccess = false;
- if (this.opts.tryAllTransports && this.transports.length > 1 && this.readyState === "opening") {
- this.transports.shift();
- return this._open();
- }
- this.emitReserved("error", err);
- this._onClose("transport error", err);
- }
- /**
- * Called upon transport close.
- *
- * @private
- */
- _onClose(reason, description) {
- if ("opening" === this.readyState || "open" === this.readyState || "closing" === this.readyState) {
- this.clearTimeoutFn(this._pingTimeoutTimer);
- this.transport.removeAllListeners("close");
- this.transport.close();
- this.transport.removeAllListeners();
- if (withEventListeners) {
- if (this._beforeunloadEventListener) {
- removeEventListener("beforeunload", this._beforeunloadEventListener, false);
- }
- if (this._offlineEventListener) {
- const i = OFFLINE_EVENT_LISTENERS.indexOf(this._offlineEventListener);
- if (i !== -1) {
- OFFLINE_EVENT_LISTENERS.splice(i, 1);
- }
- }
- }
- this.readyState = "closed";
- this.id = null;
- this.emitReserved("close", reason, description);
- this.writeBuffer = [];
- this._prevBufferLen = 0;
- }
- }
- };
- SocketWithoutUpgrade.protocol = protocol;
- var SocketWithUpgrade = class extends SocketWithoutUpgrade {
- constructor() {
- super(...arguments);
- this._upgrades = [];
- }
- onOpen() {
- super.onOpen();
- if ("open" === this.readyState && this.opts.upgrade) {
- for (let i = 0; i < this._upgrades.length; i++) {
- this._probe(this._upgrades[i]);
- }
- }
- }
- /**
- * Probes a transport.
- *
- * @param {String} name - transport name
- * @private
- */
- _probe(name) {
- let transport = this.createTransport(name);
- let failed = false;
- SocketWithoutUpgrade.priorWebsocketSuccess = false;
- const onTransportOpen = () => {
- if (failed)
- return;
- transport.send([{ type: "ping", data: "probe" }]);
- transport.once("packet", (msg) => {
- if (failed)
- return;
- if ("pong" === msg.type && "probe" === msg.data) {
- this.upgrading = true;
- this.emitReserved("upgrading", transport);
- if (!transport)
- return;
- SocketWithoutUpgrade.priorWebsocketSuccess = "websocket" === transport.name;
- this.transport.pause(() => {
- if (failed)
- return;
- if ("closed" === this.readyState)
- return;
- cleanup();
- this.setTransport(transport);
- transport.send([{ type: "upgrade" }]);
- this.emitReserved("upgrade", transport);
- transport = null;
- this.upgrading = false;
- this.flush();
- });
- } else {
- const err = new Error("probe error");
- err.transport = transport.name;
- this.emitReserved("upgradeError", err);
- }
- });
- };
- function freezeTransport() {
- if (failed)
- return;
- failed = true;
- cleanup();
- transport.close();
- transport = null;
- }
- const onerror = (err) => {
- const error = new Error("probe error: " + err);
- error.transport = transport.name;
- freezeTransport();
- this.emitReserved("upgradeError", error);
- };
- function onTransportClose() {
- onerror("transport closed");
- }
- function onclose() {
- onerror("socket closed");
- }
- function onupgrade(to) {
- if (transport && to.name !== transport.name) {
- freezeTransport();
- }
- }
- const cleanup = () => {
- transport.removeListener("open", onTransportOpen);
- transport.removeListener("error", onerror);
- transport.removeListener("close", onTransportClose);
- this.off("close", onclose);
- this.off("upgrading", onupgrade);
- };
- transport.once("open", onTransportOpen);
- transport.once("error", onerror);
- transport.once("close", onTransportClose);
- this.once("close", onclose);
- this.once("upgrading", onupgrade);
- if (this._upgrades.indexOf("webtransport") !== -1 && name !== "webtransport") {
- this.setTimeoutFn(() => {
- if (!failed) {
- transport.open();
- }
- }, 200);
- } else {
- transport.open();
- }
- }
- onHandshake(data) {
- this._upgrades = this._filterUpgrades(data.upgrades);
- super.onHandshake(data);
- }
- /**
- * Filters upgrades, returning only those matching client transports.
- *
- * @param {Array} upgrades - server upgrades
- * @private
- */
- _filterUpgrades(upgrades) {
- const filteredUpgrades = [];
- for (let i = 0; i < upgrades.length; i++) {
- if (~this.transports.indexOf(upgrades[i]))
- filteredUpgrades.push(upgrades[i]);
- }
- return filteredUpgrades;
- }
- };
- var Socket = class extends SocketWithUpgrade {
- constructor(uri, opts = {}) {
- const o = typeof uri === "object" ? uri : opts;
- if (!o.transports || o.transports && typeof o.transports[0] === "string") {
- o.transports = (o.transports || ["polling", "websocket", "webtransport"]).map((transportName) => transports[transportName]).filter((t) => !!t);
- }
- super(uri, o);
- }
- };
-
- // ../../../../Newweb/starter/node_modules/engine.io-client/build/esm/index.js
- var protocol2 = Socket.protocol;
-
- // ../../../../Newweb/starter/node_modules/socket.io-client/build/esm/url.js
- function url(uri, path = "", loc) {
- let obj = uri;
- loc = loc || typeof location !== "undefined" && location;
- if (null == uri)
- uri = loc.protocol + "//" + loc.host;
- if (typeof uri === "string") {
- if ("/" === uri.charAt(0)) {
- if ("/" === uri.charAt(1)) {
- uri = loc.protocol + uri;
- } else {
- uri = loc.host + uri;
- }
- }
- if (!/^(https?|wss?):\/\//.test(uri)) {
- if ("undefined" !== typeof loc) {
- uri = loc.protocol + "//" + uri;
- } else {
- uri = "https://" + uri;
- }
- }
- obj = parse(uri);
- }
- if (!obj.port) {
- if (/^(http|ws)$/.test(obj.protocol)) {
- obj.port = "80";
- } else if (/^(http|ws)s$/.test(obj.protocol)) {
- obj.port = "443";
- }
- }
- obj.path = obj.path || "/";
- const ipv6 = obj.host.indexOf(":") !== -1;
- const host = ipv6 ? "[" + obj.host + "]" : obj.host;
- obj.id = obj.protocol + "://" + host + ":" + obj.port + path;
- obj.href = obj.protocol + "://" + host + (loc && loc.port === obj.port ? "" : ":" + obj.port);
- return obj;
- }
-
- // ../../../../Newweb/starter/node_modules/socket.io-parser/build/esm/index.js
- var esm_exports = {};
- __export(esm_exports, {
- Decoder: () => Decoder,
- Encoder: () => Encoder,
- PacketType: () => PacketType,
- protocol: () => protocol3
- });
-
- // ../../../../Newweb/starter/node_modules/socket.io-parser/build/esm/is-binary.js
- var withNativeArrayBuffer3 = typeof ArrayBuffer === "function";
- var isView2 = (obj) => {
- return typeof ArrayBuffer.isView === "function" ? ArrayBuffer.isView(obj) : obj.buffer instanceof ArrayBuffer;
- };
- var toString = Object.prototype.toString;
- var withNativeBlob2 = typeof Blob === "function" || typeof Blob !== "undefined" && toString.call(Blob) === "[object BlobConstructor]";
- var withNativeFile = typeof File === "function" || typeof File !== "undefined" && toString.call(File) === "[object FileConstructor]";
- function isBinary(obj) {
- return withNativeArrayBuffer3 && (obj instanceof ArrayBuffer || isView2(obj)) || withNativeBlob2 && obj instanceof Blob || withNativeFile && obj instanceof File;
- }
- function hasBinary(obj, toJSON) {
- if (!obj || typeof obj !== "object") {
- return false;
- }
- if (Array.isArray(obj)) {
- for (let i = 0, l = obj.length; i < l; i++) {
- if (hasBinary(obj[i])) {
- return true;
- }
- }
- return false;
- }
- if (isBinary(obj)) {
- return true;
- }
- if (obj.toJSON && typeof obj.toJSON === "function" && arguments.length === 1) {
- return hasBinary(obj.toJSON(), true);
- }
- for (const key in obj) {
- if (Object.prototype.hasOwnProperty.call(obj, key) && hasBinary(obj[key])) {
- return true;
- }
- }
- return false;
- }
-
- // ../../../../Newweb/starter/node_modules/socket.io-parser/build/esm/binary.js
- function deconstructPacket(packet) {
- const buffers = [];
- const packetData = packet.data;
- const pack = packet;
- pack.data = _deconstructPacket(packetData, buffers);
- pack.attachments = buffers.length;
- return { packet: pack, buffers };
- }
- function _deconstructPacket(data, buffers) {
- if (!data)
- return data;
- if (isBinary(data)) {
- const placeholder = { _placeholder: true, num: buffers.length };
- buffers.push(data);
- return placeholder;
- } else if (Array.isArray(data)) {
- const newData = new Array(data.length);
- for (let i = 0; i < data.length; i++) {
- newData[i] = _deconstructPacket(data[i], buffers);
- }
- return newData;
- } else if (typeof data === "object" && !(data instanceof Date)) {
- const newData = {};
- for (const key in data) {
- if (Object.prototype.hasOwnProperty.call(data, key)) {
- newData[key] = _deconstructPacket(data[key], buffers);
- }
- }
- return newData;
- }
- return data;
- }
- function reconstructPacket(packet, buffers) {
- packet.data = _reconstructPacket(packet.data, buffers);
- delete packet.attachments;
- return packet;
- }
- function _reconstructPacket(data, buffers) {
- if (!data)
- return data;
- if (data && data._placeholder === true) {
- const isIndexValid = typeof data.num === "number" && data.num >= 0 && data.num < buffers.length;
- if (isIndexValid) {
- return buffers[data.num];
- } else {
- throw new Error("illegal attachments");
- }
- } else if (Array.isArray(data)) {
- for (let i = 0; i < data.length; i++) {
- data[i] = _reconstructPacket(data[i], buffers);
- }
- } else if (typeof data === "object") {
- for (const key in data) {
- if (Object.prototype.hasOwnProperty.call(data, key)) {
- data[key] = _reconstructPacket(data[key], buffers);
- }
- }
- }
- return data;
- }
-
- // ../../../../Newweb/starter/node_modules/socket.io-parser/build/esm/index.js
- var RESERVED_EVENTS = [
- "connect",
- "connect_error",
- "disconnect",
- "disconnecting",
- "newListener",
- "removeListener"
- // used by the Node.js EventEmitter
- ];
- var protocol3 = 5;
- var PacketType;
- (function(PacketType2) {
- PacketType2[PacketType2["CONNECT"] = 0] = "CONNECT";
- PacketType2[PacketType2["DISCONNECT"] = 1] = "DISCONNECT";
- PacketType2[PacketType2["EVENT"] = 2] = "EVENT";
- PacketType2[PacketType2["ACK"] = 3] = "ACK";
- PacketType2[PacketType2["CONNECT_ERROR"] = 4] = "CONNECT_ERROR";
- PacketType2[PacketType2["BINARY_EVENT"] = 5] = "BINARY_EVENT";
- PacketType2[PacketType2["BINARY_ACK"] = 6] = "BINARY_ACK";
- })(PacketType || (PacketType = {}));
- var Encoder = class {
- /**
- * Encoder constructor
- *
- * @param {function} replacer - custom replacer to pass down to JSON.parse
- */
- constructor(replacer) {
- this.replacer = replacer;
- }
- /**
- * Encode a packet as a single string if non-binary, or as a
- * buffer sequence, depending on packet type.
- *
- * @param {Object} obj - packet object
- */
- encode(obj) {
- if (obj.type === PacketType.EVENT || obj.type === PacketType.ACK) {
- if (hasBinary(obj)) {
- return this.encodeAsBinary({
- type: obj.type === PacketType.EVENT ? PacketType.BINARY_EVENT : PacketType.BINARY_ACK,
- nsp: obj.nsp,
- data: obj.data,
- id: obj.id
- });
- }
- }
- return [this.encodeAsString(obj)];
- }
- /**
- * Encode packet as string.
- */
- encodeAsString(obj) {
- let str = "" + obj.type;
- if (obj.type === PacketType.BINARY_EVENT || obj.type === PacketType.BINARY_ACK) {
- str += obj.attachments + "-";
- }
- if (obj.nsp && "/" !== obj.nsp) {
- str += obj.nsp + ",";
- }
- if (null != obj.id) {
- str += obj.id;
- }
- if (null != obj.data) {
- str += JSON.stringify(obj.data, this.replacer);
- }
- return str;
- }
- /**
- * Encode packet as 'buffer sequence' by removing blobs, and
- * deconstructing packet into object with placeholders and
- * a list of buffers.
- */
- encodeAsBinary(obj) {
- const deconstruction = deconstructPacket(obj);
- const pack = this.encodeAsString(deconstruction.packet);
- const buffers = deconstruction.buffers;
- buffers.unshift(pack);
- return buffers;
- }
- };
- function isObject(value2) {
- return Object.prototype.toString.call(value2) === "[object Object]";
- }
- var Decoder = class _Decoder extends Emitter {
- /**
- * Decoder constructor
- *
- * @param {function} reviver - custom reviver to pass down to JSON.stringify
- */
- constructor(reviver) {
- super();
- this.reviver = reviver;
- }
- /**
- * Decodes an encoded packet string into packet JSON.
- *
- * @param {String} obj - encoded packet
- */
- add(obj) {
- let packet;
- if (typeof obj === "string") {
- if (this.reconstructor) {
- throw new Error("got plaintext data when reconstructing a packet");
- }
- packet = this.decodeString(obj);
- const isBinaryEvent = packet.type === PacketType.BINARY_EVENT;
- if (isBinaryEvent || packet.type === PacketType.BINARY_ACK) {
- packet.type = isBinaryEvent ? PacketType.EVENT : PacketType.ACK;
- this.reconstructor = new BinaryReconstructor(packet);
- if (packet.attachments === 0) {
- super.emitReserved("decoded", packet);
- }
- } else {
- super.emitReserved("decoded", packet);
- }
- } else if (isBinary(obj) || obj.base64) {
- if (!this.reconstructor) {
- throw new Error("got binary data when not reconstructing a packet");
- } else {
- packet = this.reconstructor.takeBinaryData(obj);
- if (packet) {
- this.reconstructor = null;
- super.emitReserved("decoded", packet);
- }
- }
- } else {
- throw new Error("Unknown type: " + obj);
- }
- }
- /**
- * Decode a packet String (JSON data)
- *
- * @param {String} str
- * @return {Object} packet
- */
- decodeString(str) {
- let i = 0;
- const p = {
- type: Number(str.charAt(0))
- };
- if (PacketType[p.type] === void 0) {
- throw new Error("unknown packet type " + p.type);
- }
- if (p.type === PacketType.BINARY_EVENT || p.type === PacketType.BINARY_ACK) {
- const start = i + 1;
- while (str.charAt(++i) !== "-" && i != str.length) {
- }
- const buf = str.substring(start, i);
- if (buf != Number(buf) || str.charAt(i) !== "-") {
- throw new Error("Illegal attachments");
- }
- p.attachments = Number(buf);
- }
- if ("/" === str.charAt(i + 1)) {
- const start = i + 1;
- while (++i) {
- const c = str.charAt(i);
- if ("," === c)
- break;
- if (i === str.length)
- break;
- }
- p.nsp = str.substring(start, i);
- } else {
- p.nsp = "/";
- }
- const next = str.charAt(i + 1);
- if ("" !== next && Number(next) == next) {
- const start = i + 1;
- while (++i) {
- const c = str.charAt(i);
- if (null == c || Number(c) != c) {
- --i;
- break;
- }
- if (i === str.length)
- break;
- }
- p.id = Number(str.substring(start, i + 1));
- }
- if (str.charAt(++i)) {
- const payload = this.tryParse(str.substr(i));
- if (_Decoder.isPayloadValid(p.type, payload)) {
- p.data = payload;
- } else {
- throw new Error("invalid payload");
- }
- }
- return p;
- }
- tryParse(str) {
- try {
- return JSON.parse(str, this.reviver);
- } catch (e) {
- return false;
- }
- }
- static isPayloadValid(type, payload) {
- switch (type) {
- case PacketType.CONNECT:
- return isObject(payload);
- case PacketType.DISCONNECT:
- return payload === void 0;
- case PacketType.CONNECT_ERROR:
- return typeof payload === "string" || isObject(payload);
- case PacketType.EVENT:
- case PacketType.BINARY_EVENT:
- return Array.isArray(payload) && (typeof payload[0] === "number" || typeof payload[0] === "string" && RESERVED_EVENTS.indexOf(payload[0]) === -1);
- case PacketType.ACK:
- case PacketType.BINARY_ACK:
- return Array.isArray(payload);
- }
- }
- /**
- * Deallocates a parser's resources
- */
- destroy() {
- if (this.reconstructor) {
- this.reconstructor.finishedReconstruction();
- this.reconstructor = null;
- }
- }
- };
- var BinaryReconstructor = class {
- constructor(packet) {
- this.packet = packet;
- this.buffers = [];
- this.reconPack = packet;
- }
- /**
- * Method to be called when binary data received from connection
- * after a BINARY_EVENT packet.
- *
- * @param {Buffer | ArrayBuffer} binData - the raw binary data received
- * @return {null | Object} returns null if more binary data is expected or
- * a reconstructed packet object if all buffers have been received.
- */
- takeBinaryData(binData) {
- this.buffers.push(binData);
- if (this.buffers.length === this.reconPack.attachments) {
- const packet = reconstructPacket(this.reconPack, this.buffers);
- this.finishedReconstruction();
- return packet;
- }
- return null;
- }
- /**
- * Cleans up binary packet reconstruction variables.
- */
- finishedReconstruction() {
- this.reconPack = null;
- this.buffers = [];
- }
- };
-
- // ../../../../Newweb/starter/node_modules/socket.io-client/build/esm/on.js
- function on(obj, ev, fn) {
- obj.on(ev, fn);
- return function subDestroy() {
- obj.off(ev, fn);
- };
- }
-
- // ../../../../Newweb/starter/node_modules/socket.io-client/build/esm/socket.js
- var RESERVED_EVENTS2 = Object.freeze({
- connect: 1,
- connect_error: 1,
- disconnect: 1,
- disconnecting: 1,
- // EventEmitter reserved events: https://nodejs.org/api/events.html#events_event_newlistener
- newListener: 1,
- removeListener: 1
- });
- var Socket2 = class extends Emitter {
- /**
- * `Socket` constructor.
- */
- constructor(io, nsp, opts) {
- super();
- this.connected = false;
- this.recovered = false;
- this.receiveBuffer = [];
- this.sendBuffer = [];
- this._queue = [];
- this._queueSeq = 0;
- this.ids = 0;
- this.acks = {};
- this.flags = {};
- this.io = io;
- this.nsp = nsp;
- if (opts && opts.auth) {
- this.auth = opts.auth;
- }
- this._opts = Object.assign({}, opts);
- if (this.io._autoConnect)
- this.open();
- }
- /**
- * Whether the socket is currently disconnected
- *
- * @example
- * const socket = io();
- *
- * socket.on("connect", () => {
- * console.log(socket.disconnected); // false
- * });
- *
- * socket.on("disconnect", () => {
- * console.log(socket.disconnected); // true
- * });
- */
- get disconnected() {
- return !this.connected;
- }
- /**
- * Subscribe to open, close and packet events
- *
- * @private
- */
- subEvents() {
- if (this.subs)
- return;
- const io = this.io;
- this.subs = [
- on(io, "open", this.onopen.bind(this)),
- on(io, "packet", this.onpacket.bind(this)),
- on(io, "error", this.onerror.bind(this)),
- on(io, "close", this.onclose.bind(this))
- ];
- }
- /**
- * Whether the Socket will try to reconnect when its Manager connects or reconnects.
- *
- * @example
- * const socket = io();
- *
- * console.log(socket.active); // true
- *
- * socket.on("disconnect", (reason) => {
- * if (reason === "io server disconnect") {
- * // the disconnection was initiated by the server, you need to manually reconnect
- * console.log(socket.active); // false
- * }
- * // else the socket will automatically try to reconnect
- * console.log(socket.active); // true
- * });
- */
- get active() {
- return !!this.subs;
- }
- /**
- * "Opens" the socket.
- *
- * @example
- * const socket = io({
- * autoConnect: false
- * });
- *
- * socket.connect();
- */
- connect() {
- if (this.connected)
- return this;
- this.subEvents();
- if (!this.io["_reconnecting"])
- this.io.open();
- if ("open" === this.io._readyState)
- this.onopen();
- return this;
- }
- /**
- * Alias for {@link connect()}.
- */
- open() {
- return this.connect();
- }
- /**
- * Sends a `message` event.
- *
- * This method mimics the WebSocket.send() method.
- *
- * @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket/send
- *
- * @example
- * socket.send("hello");
- *
- * // this is equivalent to
- * socket.emit("message", "hello");
- *
- * @return self
- */
- send(...args) {
- args.unshift("message");
- this.emit.apply(this, args);
- return this;
- }
- /**
- * Override `emit`.
- * If the event is in `events`, it's emitted normally.
- *
- * @example
- * socket.emit("hello", "world");
- *
- * // all serializable datastructures are supported (no need to call JSON.stringify)
- * socket.emit("hello", 1, "2", { 3: ["4"], 5: Uint8Array.from([6]) });
- *
- * // with an acknowledgement from the server
- * socket.emit("hello", "world", (val) => {
- * // ...
- * });
- *
- * @return self
- */
- emit(ev, ...args) {
- var _a, _b, _c;
- if (RESERVED_EVENTS2.hasOwnProperty(ev)) {
- throw new Error('"' + ev.toString() + '" is a reserved event name');
- }
- args.unshift(ev);
- if (this._opts.retries && !this.flags.fromQueue && !this.flags.volatile) {
- this._addToQueue(args);
- return this;
- }
- const packet = {
- type: PacketType.EVENT,
- data: args
- };
- packet.options = {};
- packet.options.compress = this.flags.compress !== false;
- if ("function" === typeof args[args.length - 1]) {
- const id = this.ids++;
- const ack = args.pop();
- this._registerAckCallback(id, ack);
- packet.id = id;
- }
- const isTransportWritable = (_b = (_a = this.io.engine) === null || _a === void 0 ? void 0 : _a.transport) === null || _b === void 0 ? void 0 : _b.writable;
- const isConnected = this.connected && !((_c = this.io.engine) === null || _c === void 0 ? void 0 : _c._hasPingExpired());
- const discardPacket = this.flags.volatile && !isTransportWritable;
- if (discardPacket) {
- } else if (isConnected) {
- this.notifyOutgoingListeners(packet);
- this.packet(packet);
- } else {
- this.sendBuffer.push(packet);
- }
- this.flags = {};
- return this;
- }
- /**
- * @private
- */
- _registerAckCallback(id, ack) {
- var _a;
- const timeout = (_a = this.flags.timeout) !== null && _a !== void 0 ? _a : this._opts.ackTimeout;
- if (timeout === void 0) {
- this.acks[id] = ack;
- return;
- }
- const timer = this.io.setTimeoutFn(() => {
- delete this.acks[id];
- for (let i = 0; i < this.sendBuffer.length; i++) {
- if (this.sendBuffer[i].id === id) {
- this.sendBuffer.splice(i, 1);
- }
- }
- ack.call(this, new Error("operation has timed out"));
- }, timeout);
- const fn = (...args) => {
- this.io.clearTimeoutFn(timer);
- ack.apply(this, args);
- };
- fn.withError = true;
- this.acks[id] = fn;
- }
- /**
- * Emits an event and waits for an acknowledgement
- *
- * @example
- * // without timeout
- * const response = await socket.emitWithAck("hello", "world");
- *
- * // with a specific timeout
- * try {
- * const response = await socket.timeout(1000).emitWithAck("hello", "world");
- * } catch (err) {
- * // the server did not acknowledge the event in the given delay
- * }
- *
- * @return a Promise that will be fulfilled when the server acknowledges the event
- */
- emitWithAck(ev, ...args) {
- return new Promise((resolve, reject) => {
- const fn = (arg1, arg2) => {
- return arg1 ? reject(arg1) : resolve(arg2);
- };
- fn.withError = true;
- args.push(fn);
- this.emit(ev, ...args);
- });
- }
- /**
- * Add the packet to the queue.
- * @param args
- * @private
- */
- _addToQueue(args) {
- let ack;
- if (typeof args[args.length - 1] === "function") {
- ack = args.pop();
- }
- const packet = {
- id: this._queueSeq++,
- tryCount: 0,
- pending: false,
- args,
- flags: Object.assign({ fromQueue: true }, this.flags)
- };
- args.push((err, ...responseArgs) => {
- if (packet !== this._queue[0]) {
- return;
- }
- const hasError = err !== null;
- if (hasError) {
- if (packet.tryCount > this._opts.retries) {
- this._queue.shift();
- if (ack) {
- ack(err);
- }
- }
- } else {
- this._queue.shift();
- if (ack) {
- ack(null, ...responseArgs);
- }
- }
- packet.pending = false;
- return this._drainQueue();
- });
- this._queue.push(packet);
- this._drainQueue();
- }
- /**
- * Send the first packet of the queue, and wait for an acknowledgement from the server.
- * @param force - whether to resend a packet that has not been acknowledged yet
- *
- * @private
- */
- _drainQueue(force = false) {
- if (!this.connected || this._queue.length === 0) {
- return;
- }
- const packet = this._queue[0];
- if (packet.pending && !force) {
- return;
- }
- packet.pending = true;
- packet.tryCount++;
- this.flags = packet.flags;
- this.emit.apply(this, packet.args);
- }
- /**
- * Sends a packet.
- *
- * @param packet
- * @private
- */
- packet(packet) {
- packet.nsp = this.nsp;
- this.io._packet(packet);
- }
- /**
- * Called upon engine `open`.
- *
- * @private
- */
- onopen() {
- if (typeof this.auth == "function") {
- this.auth((data) => {
- this._sendConnectPacket(data);
- });
- } else {
- this._sendConnectPacket(this.auth);
- }
- }
- /**
- * Sends a CONNECT packet to initiate the Socket.IO session.
- *
- * @param data
- * @private
- */
- _sendConnectPacket(data) {
- this.packet({
- type: PacketType.CONNECT,
- data: this._pid ? Object.assign({ pid: this._pid, offset: this._lastOffset }, data) : data
- });
- }
- /**
- * Called upon engine or manager `error`.
- *
- * @param err
- * @private
- */
- onerror(err) {
- if (!this.connected) {
- this.emitReserved("connect_error", err);
- }
- }
- /**
- * Called upon engine `close`.
- *
- * @param reason
- * @param description
- * @private
- */
- onclose(reason, description) {
- this.connected = false;
- delete this.id;
- this.emitReserved("disconnect", reason, description);
- this._clearAcks();
- }
- /**
- * Clears the acknowledgement handlers upon disconnection, since the client will never receive an acknowledgement from
- * the server.
- *
- * @private
- */
- _clearAcks() {
- Object.keys(this.acks).forEach((id) => {
- const isBuffered = this.sendBuffer.some((packet) => String(packet.id) === id);
- if (!isBuffered) {
- const ack = this.acks[id];
- delete this.acks[id];
- if (ack.withError) {
- ack.call(this, new Error("socket has been disconnected"));
- }
- }
- });
- }
- /**
- * Called with socket packet.
- *
- * @param packet
- * @private
- */
- onpacket(packet) {
- const sameNamespace = packet.nsp === this.nsp;
- if (!sameNamespace)
- return;
- switch (packet.type) {
- case PacketType.CONNECT:
- if (packet.data && packet.data.sid) {
- this.onconnect(packet.data.sid, packet.data.pid);
- } 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 PacketType.EVENT:
- case PacketType.BINARY_EVENT:
- this.onevent(packet);
- break;
- case PacketType.ACK:
- case PacketType.BINARY_ACK:
- this.onack(packet);
- break;
- case PacketType.DISCONNECT:
- this.ondisconnect();
- break;
- case PacketType.CONNECT_ERROR:
- this.destroy();
- const err = new Error(packet.data.message);
- err.data = packet.data.data;
- this.emitReserved("connect_error", err);
- break;
- }
- }
- /**
- * Called upon a server event.
- *
- * @param packet
- * @private
- */
- onevent(packet) {
- const args = packet.data || [];
- if (null != packet.id) {
- args.push(this.ack(packet.id));
- }
- if (this.connected) {
- this.emitEvent(args);
- } else {
- this.receiveBuffer.push(Object.freeze(args));
- }
- }
- emitEvent(args) {
- if (this._anyListeners && this._anyListeners.length) {
- const listeners = this._anyListeners.slice();
- for (const listener of listeners) {
- listener.apply(this, args);
- }
- }
- super.emit.apply(this, args);
- if (this._pid && args.length && typeof args[args.length - 1] === "string") {
- this._lastOffset = args[args.length - 1];
- }
- }
- /**
- * Produces an ack callback to emit with an event.
- *
- * @private
- */
- ack(id) {
- const self2 = this;
- let sent = false;
- return function(...args) {
- if (sent)
- return;
- sent = true;
- self2.packet({
- type: PacketType.ACK,
- id,
- data: args
- });
- };
- }
- /**
- * Called upon a server acknowledgement.
- *
- * @param packet
- * @private
- */
- onack(packet) {
- const ack = this.acks[packet.id];
- if (typeof ack !== "function") {
- return;
- }
- delete this.acks[packet.id];
- if (ack.withError) {
- packet.data.unshift(null);
- }
- ack.apply(this, packet.data);
- }
- /**
- * Called upon server connect.
- *
- * @private
- */
- onconnect(id, pid) {
- this.id = id;
- this.recovered = pid && this._pid === pid;
- this._pid = pid;
- this.connected = true;
- this.emitBuffered();
- this.emitReserved("connect");
- this._drainQueue(true);
- }
- /**
- * Emit buffered events (received and emitted).
- *
- * @private
- */
- emitBuffered() {
- this.receiveBuffer.forEach((args) => this.emitEvent(args));
- this.receiveBuffer = [];
- this.sendBuffer.forEach((packet) => {
- this.notifyOutgoingListeners(packet);
- this.packet(packet);
- });
- this.sendBuffer = [];
- }
- /**
- * Called upon server disconnect.
- *
- * @private
- */
- ondisconnect() {
- this.destroy();
- this.onclose("io server disconnect");
- }
- /**
- * Called upon forced client/server side disconnections,
- * this method ensures the manager stops tracking us and
- * that reconnections don't get triggered for this.
- *
- * @private
- */
- destroy() {
- if (this.subs) {
- this.subs.forEach((subDestroy) => subDestroy());
- this.subs = void 0;
- }
- this.io["_destroy"](this);
- }
- /**
- * Disconnects the socket manually. In that case, the socket will not try to reconnect.
- *
- * If this is the last active Socket instance of the {@link Manager}, the low-level connection will be closed.
- *
- * @example
- * const socket = io();
- *
- * socket.on("disconnect", (reason) => {
- * // console.log(reason); prints "io client disconnect"
- * });
- *
- * socket.disconnect();
- *
- * @return self
- */
- disconnect() {
- if (this.connected) {
- this.packet({ type: PacketType.DISCONNECT });
- }
- this.destroy();
- if (this.connected) {
- this.onclose("io client disconnect");
- }
- return this;
- }
- /**
- * Alias for {@link disconnect()}.
- *
- * @return self
- */
- close() {
- return this.disconnect();
- }
- /**
- * Sets the compress flag.
- *
- * @example
- * socket.compress(false).emit("hello");
- *
- * @param compress - if `true`, compresses the sending data
- * @return self
- */
- compress(compress) {
- this.flags.compress = compress;
- return this;
- }
- /**
- * Sets a modifier for a subsequent event emission that the event message will be dropped when this socket is not
- * ready to send messages.
- *
- * @example
- * socket.volatile.emit("hello"); // the server may or may not receive it
- *
- * @returns self
- */
- get volatile() {
- this.flags.volatile = true;
- return this;
- }
- /**
- * Sets a modifier for a subsequent event emission that the callback will be called with an error when the
- * given number of milliseconds have elapsed without an acknowledgement from the server:
- *
- * @example
- * socket.timeout(5000).emit("my-event", (err) => {
- * if (err) {
- * // the server did not acknowledge the event in the given delay
- * }
- * });
- *
- * @returns self
- */
- timeout(timeout) {
- this.flags.timeout = timeout;
- return this;
- }
- /**
- * Adds a listener that will be fired when any event is emitted. The event name is passed as the first argument to the
- * callback.
- *
- * @example
- * socket.onAny((event, ...args) => {
- * console.log(`got ${event}`);
- * });
- *
- * @param listener
- */
- onAny(listener) {
- this._anyListeners = this._anyListeners || [];
- this._anyListeners.push(listener);
- return this;
- }
- /**
- * Adds a listener that will be fired when any event is emitted. The event name is passed as the first argument to the
- * callback. The listener is added to the beginning of the listeners array.
- *
- * @example
- * socket.prependAny((event, ...args) => {
- * console.log(`got event ${event}`);
- * });
- *
- * @param listener
- */
- prependAny(listener) {
- this._anyListeners = this._anyListeners || [];
- this._anyListeners.unshift(listener);
- return this;
- }
- /**
- * Removes the listener that will be fired when any event is emitted.
- *
- * @example
- * const catchAllListener = (event, ...args) => {
- * console.log(`got event ${event}`);
- * }
- *
- * socket.onAny(catchAllListener);
- *
- * // remove a specific listener
- * socket.offAny(catchAllListener);
- *
- * // or remove all listeners
- * socket.offAny();
- *
- * @param listener
- */
- offAny(listener) {
- if (!this._anyListeners) {
- return this;
- }
- if (listener) {
- const listeners = this._anyListeners;
- for (let i = 0; i < listeners.length; i++) {
- if (listener === listeners[i]) {
- listeners.splice(i, 1);
- return this;
- }
- }
- } else {
- this._anyListeners = [];
- }
- return this;
- }
- /**
- * Returns an array of listeners that are listening for any event that is specified. This array can be manipulated,
- * e.g. to remove listeners.
- */
- listenersAny() {
- return this._anyListeners || [];
- }
- /**
- * Adds a listener that will be fired when any event is emitted. The event name is passed as the first argument to the
- * callback.
- *
- * Note: acknowledgements sent to the server are not included.
- *
- * @example
- * socket.onAnyOutgoing((event, ...args) => {
- * console.log(`sent event ${event}`);
- * });
- *
- * @param listener
- */
- onAnyOutgoing(listener) {
- this._anyOutgoingListeners = this._anyOutgoingListeners || [];
- this._anyOutgoingListeners.push(listener);
- return this;
- }
- /**
- * Adds a listener that will be fired when any event is emitted. The event name is passed as the first argument to the
- * callback. The listener is added to the beginning of the listeners array.
- *
- * Note: acknowledgements sent to the server are not included.
- *
- * @example
- * socket.prependAnyOutgoing((event, ...args) => {
- * console.log(`sent event ${event}`);
- * });
- *
- * @param listener
- */
- prependAnyOutgoing(listener) {
- this._anyOutgoingListeners = this._anyOutgoingListeners || [];
- this._anyOutgoingListeners.unshift(listener);
- return this;
- }
- /**
- * Removes the listener that will be fired when any event is emitted.
- *
- * @example
- * const catchAllListener = (event, ...args) => {
- * console.log(`sent event ${event}`);
- * }
- *
- * socket.onAnyOutgoing(catchAllListener);
- *
- * // remove a specific listener
- * socket.offAnyOutgoing(catchAllListener);
- *
- * // or remove all listeners
- * socket.offAnyOutgoing();
- *
- * @param [listener] - the catch-all listener (optional)
- */
- offAnyOutgoing(listener) {
- if (!this._anyOutgoingListeners) {
- return this;
- }
- if (listener) {
- const listeners = this._anyOutgoingListeners;
- for (let i = 0; i < listeners.length; i++) {
- if (listener === listeners[i]) {
- listeners.splice(i, 1);
- return this;
- }
- }
- } else {
- this._anyOutgoingListeners = [];
- }
- return this;
- }
- /**
- * Returns an array of listeners that are listening for any event that is specified. This array can be manipulated,
- * e.g. to remove listeners.
- */
- listenersAnyOutgoing() {
- return this._anyOutgoingListeners || [];
- }
- /**
- * Notify the listeners for each packet sent
- *
- * @param packet
- *
- * @private
- */
- notifyOutgoingListeners(packet) {
- if (this._anyOutgoingListeners && this._anyOutgoingListeners.length) {
- const listeners = this._anyOutgoingListeners.slice();
- for (const listener of listeners) {
- listener.apply(this, packet.data);
- }
- }
- }
- };
-
- // ../../../../Newweb/starter/node_modules/socket.io-client/build/esm/contrib/backo2.js
- function Backoff(opts) {
- opts = opts || {};
- this.ms = opts.min || 100;
- this.max = opts.max || 1e4;
- this.factor = opts.factor || 2;
- this.jitter = opts.jitter > 0 && opts.jitter <= 1 ? opts.jitter : 0;
- this.attempts = 0;
- }
- Backoff.prototype.duration = function() {
- var ms = this.ms * Math.pow(this.factor, this.attempts++);
- if (this.jitter) {
- var rand = Math.random();
- var deviation = Math.floor(rand * this.jitter * ms);
- ms = (Math.floor(rand * 10) & 1) == 0 ? ms - deviation : ms + deviation;
- }
- return Math.min(ms, this.max) | 0;
- };
- Backoff.prototype.reset = function() {
- this.attempts = 0;
- };
- Backoff.prototype.setMin = function(min) {
- this.ms = min;
- };
- Backoff.prototype.setMax = function(max) {
- this.max = max;
- };
- Backoff.prototype.setJitter = function(jitter) {
- this.jitter = jitter;
- };
-
- // ../../../../Newweb/starter/node_modules/socket.io-client/build/esm/manager.js
- var Manager = class extends Emitter {
- constructor(uri, opts) {
- var _a;
- super();
- this.nsps = {};
- this.subs = [];
- if (uri && "object" === typeof uri) {
- opts = uri;
- uri = void 0;
- }
- opts = opts || {};
- opts.path = opts.path || "/socket.io";
- this.opts = opts;
- installTimerFunctions(this, opts);
- this.reconnection(opts.reconnection !== false);
- this.reconnectionAttempts(opts.reconnectionAttempts || Infinity);
- this.reconnectionDelay(opts.reconnectionDelay || 1e3);
- this.reconnectionDelayMax(opts.reconnectionDelayMax || 5e3);
- this.randomizationFactor((_a = opts.randomizationFactor) !== null && _a !== void 0 ? _a : 0.5);
- this.backoff = new Backoff({
- min: this.reconnectionDelay(),
- max: this.reconnectionDelayMax(),
- jitter: this.randomizationFactor()
- });
- this.timeout(null == opts.timeout ? 2e4 : opts.timeout);
- this._readyState = "closed";
- this.uri = uri;
- const _parser = opts.parser || esm_exports;
- this.encoder = new _parser.Encoder();
- this.decoder = new _parser.Decoder();
- this._autoConnect = opts.autoConnect !== false;
- if (this._autoConnect)
- this.open();
- }
- reconnection(v) {
- if (!arguments.length)
- return this._reconnection;
- this._reconnection = !!v;
- if (!v) {
- this.skipReconnect = true;
- }
- return this;
- }
- reconnectionAttempts(v) {
- if (v === void 0)
- return this._reconnectionAttempts;
- this._reconnectionAttempts = v;
- return this;
- }
- reconnectionDelay(v) {
- var _a;
- if (v === void 0)
- return this._reconnectionDelay;
- this._reconnectionDelay = v;
- (_a = this.backoff) === null || _a === void 0 ? void 0 : _a.setMin(v);
- return this;
- }
- randomizationFactor(v) {
- var _a;
- if (v === void 0)
- return this._randomizationFactor;
- this._randomizationFactor = v;
- (_a = this.backoff) === null || _a === void 0 ? void 0 : _a.setJitter(v);
- return this;
- }
- reconnectionDelayMax(v) {
- var _a;
- if (v === void 0)
- return this._reconnectionDelayMax;
- this._reconnectionDelayMax = v;
- (_a = this.backoff) === null || _a === void 0 ? void 0 : _a.setMax(v);
- return this;
- }
- timeout(v) {
- if (!arguments.length)
- return this._timeout;
- this._timeout = v;
- return this;
- }
- /**
- * Starts trying to reconnect if reconnection is enabled and we have not
- * started reconnecting yet
- *
- * @private
- */
- maybeReconnectOnOpen() {
- if (!this._reconnecting && this._reconnection && this.backoff.attempts === 0) {
- this.reconnect();
- }
- }
- /**
- * Sets the current transport `socket`.
- *
- * @param {Function} fn - optional, callback
- * @return self
- * @public
- */
- open(fn) {
- if (~this._readyState.indexOf("open"))
- return this;
- this.engine = new Socket(this.uri, this.opts);
- const socket = this.engine;
- const self2 = this;
- this._readyState = "opening";
- this.skipReconnect = false;
- const openSubDestroy = on(socket, "open", function() {
- self2.onopen();
- fn && fn();
- });
- const onError = (err) => {
- this.cleanup();
- this._readyState = "closed";
- this.emitReserved("error", err);
- if (fn) {
- fn(err);
- } else {
- this.maybeReconnectOnOpen();
- }
- };
- const errorSub = on(socket, "error", onError);
- if (false !== this._timeout) {
- const timeout = this._timeout;
- const timer = this.setTimeoutFn(() => {
- openSubDestroy();
- onError(new Error("timeout"));
- socket.close();
- }, timeout);
- if (this.opts.autoUnref) {
- timer.unref();
- }
- this.subs.push(() => {
- this.clearTimeoutFn(timer);
- });
- }
- this.subs.push(openSubDestroy);
- this.subs.push(errorSub);
- return this;
- }
- /**
- * Alias for open()
- *
- * @return self
- * @public
- */
- connect(fn) {
- return this.open(fn);
- }
- /**
- * Called upon transport open.
- *
- * @private
- */
- onopen() {
- this.cleanup();
- this._readyState = "open";
- this.emitReserved("open");
- const socket = this.engine;
- this.subs.push(
- on(socket, "ping", this.onping.bind(this)),
- on(socket, "data", this.ondata.bind(this)),
- on(socket, "error", this.onerror.bind(this)),
- on(socket, "close", this.onclose.bind(this)),
- // @ts-ignore
- on(this.decoder, "decoded", this.ondecoded.bind(this))
- );
- }
- /**
- * Called upon a ping.
- *
- * @private
- */
- onping() {
- this.emitReserved("ping");
- }
- /**
- * Called with data.
- *
- * @private
- */
- ondata(data) {
- try {
- this.decoder.add(data);
- } catch (e) {
- this.onclose("parse error", e);
- }
- }
- /**
- * Called when parser fully decodes a packet.
- *
- * @private
- */
- ondecoded(packet) {
- nextTick(() => {
- this.emitReserved("packet", packet);
- }, this.setTimeoutFn);
- }
- /**
- * Called upon socket error.
- *
- * @private
- */
- onerror(err) {
- this.emitReserved("error", err);
- }
- /**
- * Creates a new socket for the given `nsp`.
- *
- * @return {Socket}
- * @public
- */
- socket(nsp, opts) {
- let socket = this.nsps[nsp];
- if (!socket) {
- socket = new Socket2(this, nsp, opts);
- this.nsps[nsp] = socket;
- } else if (this._autoConnect && !socket.active) {
- socket.connect();
- }
- return socket;
- }
- /**
- * Called upon a socket close.
- *
- * @param socket
- * @private
- */
- _destroy(socket) {
- const nsps = Object.keys(this.nsps);
- for (const nsp of nsps) {
- const socket2 = this.nsps[nsp];
- if (socket2.active) {
- return;
- }
- }
- this._close();
- }
- /**
- * Writes a packet.
- *
- * @param packet
- * @private
- */
- _packet(packet) {
- const encodedPackets = this.encoder.encode(packet);
- for (let i = 0; i < encodedPackets.length; i++) {
- this.engine.write(encodedPackets[i], packet.options);
- }
- }
- /**
- * Clean up transport subscriptions and packet buffer.
- *
- * @private
- */
- cleanup() {
- this.subs.forEach((subDestroy) => subDestroy());
- this.subs.length = 0;
- this.decoder.destroy();
- }
- /**
- * Close the current socket.
- *
- * @private
- */
- _close() {
- this.skipReconnect = true;
- this._reconnecting = false;
- this.onclose("forced close");
- }
- /**
- * Alias for close()
- *
- * @private
- */
- disconnect() {
- return this._close();
- }
- /**
- * Called when:
- *
- * - the low-level engine is closed
- * - the parser encountered a badly formatted packet
- * - all sockets are disconnected
- *
- * @private
- */
- onclose(reason, description) {
- var _a;
- this.cleanup();
- (_a = this.engine) === null || _a === void 0 ? void 0 : _a.close();
- this.backoff.reset();
- this._readyState = "closed";
- this.emitReserved("close", reason, description);
- if (this._reconnection && !this.skipReconnect) {
- this.reconnect();
- }
- }
- /**
- * Attempt a reconnection.
- *
- * @private
- */
- reconnect() {
- if (this._reconnecting || this.skipReconnect)
- return this;
- const self2 = this;
- if (this.backoff.attempts >= this._reconnectionAttempts) {
- this.backoff.reset();
- this.emitReserved("reconnect_failed");
- this._reconnecting = false;
- } else {
- const delay = this.backoff.duration();
- this._reconnecting = true;
- const timer = this.setTimeoutFn(() => {
- if (self2.skipReconnect)
- return;
- this.emitReserved("reconnect_attempt", self2.backoff.attempts);
- if (self2.skipReconnect)
- return;
- self2.open((err) => {
- if (err) {
- self2._reconnecting = false;
- self2.reconnect();
- this.emitReserved("reconnect_error", err);
- } else {
- self2.onreconnect();
- }
- });
- }, delay);
- if (this.opts.autoUnref) {
- timer.unref();
- }
- this.subs.push(() => {
- this.clearTimeoutFn(timer);
- });
- }
- }
- /**
- * Called upon successful reconnect.
- *
- * @private
- */
- onreconnect() {
- const attempt = this.backoff.attempts;
- this._reconnecting = false;
- this.backoff.reset();
- this.emitReserved("reconnect", attempt);
- }
- };
-
- // ../../../../Newweb/starter/node_modules/socket.io-client/build/esm/index.js
- var cache = {};
- function lookup2(uri, opts) {
- if (typeof uri === "object") {
- opts = uri;
- uri = void 0;
- }
- opts = opts || {};
- const parsed = url(uri, opts.path || "/socket.io");
- const source = parsed.source;
- const id = parsed.id;
- const path = parsed.path;
- const sameNamespace = cache[id] && path in cache[id]["nsps"];
- const newConnection = opts.forceNew || opts["force new connection"] || false === opts.multiplex || sameNamespace;
- let io;
- if (newConnection) {
- io = new Manager(source, opts);
- } else {
- if (!cache[id]) {
- cache[id] = new Manager(source, opts);
- }
- io = cache[id];
- }
- if (parsed.query && !opts.query) {
- opts.query = parsed.queryKey;
- }
- return io.socket(parsed.path, opts);
- }
- Object.assign(lookup2, {
- Manager,
- Socket: Socket2,
- io: lookup2,
- connect: lookup2
- });
- export {
- Manager,
- Socket2 as Socket,
- lookup2 as connect,
- lookup2 as default,
- lookup2 as io,
- protocol3 as protocol
- };
- //# sourceMappingURL=socket__io-client.js.map
|