@ceeblue/web-utils 1.0.1 → 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,3 +1,21 @@
1
1
  # Ceeblue web framework
2
2
 
3
3
  This is a web framework for CeeblueTV's web libraries. It is a collection of tools and utilities that are used across all of CeeblueTV's web projects.
4
+
5
+ ## Installation
6
+
7
+ You can install the package using npm:
8
+
9
+ ```bash
10
+ npm install @ceeblue/web-utils
11
+ ```
12
+
13
+ Or manually add it to your `package.json` file:
14
+
15
+ ```json
16
+ {
17
+ "dependencies": {
18
+ "@ceeblue/web-utils": "latest"
19
+ }
20
+ }
21
+ ```
@@ -549,10 +549,6 @@ declare const SDP: {
549
549
  /**
550
550
  * Some basic utility functions
551
551
  */
552
- /**
553
- * Version of the library
554
- */
555
- declare const VERSION = "?";
556
552
  /**
557
553
  * An empty lambda function, pratical to disable default behavior of function or events which are not expected to be null
558
554
  * @example
@@ -605,19 +601,28 @@ declare function stringify(obj: any, params?: {
605
601
  decimal?: number;
606
602
  recursive?: number;
607
603
  }): string;
604
+ /**
605
+ * Encode a string to a binary representation
606
+ * @param value string value to convert
607
+ * @returns binary conversion
608
+ */
608
609
  declare function toBin(value: string): Uint8Array;
610
+ /**
611
+ * Execute a promise in a safe way with a timeout if caller doesn't resolve it in the accurate time
612
+ */
613
+ declare function safePromise<T>(timeout: number, promise: Promise<T>): Promise<unknown>;
609
614
 
610
615
  declare const Util_EMPTY_FUNCTION: typeof EMPTY_FUNCTION;
611
- declare const Util_VERSION: typeof VERSION;
612
616
  declare const Util_objectEntries: typeof objectEntries;
613
617
  declare const Util_objectFrom: typeof objectFrom;
614
618
  declare const Util_options: typeof options;
619
+ declare const Util_safePromise: typeof safePromise;
615
620
  declare const Util_stringify: typeof stringify;
616
621
  declare const Util_time: typeof time;
617
622
  declare const Util_timeOrigin: typeof timeOrigin;
618
623
  declare const Util_toBin: typeof toBin;
619
624
  declare namespace Util {
620
- export { Util_EMPTY_FUNCTION as EMPTY_FUNCTION, Util_VERSION as VERSION, Util_objectEntries as objectEntries, Util_objectFrom as objectFrom, Util_options as options, Util_stringify as stringify, Util_time as time, Util_timeOrigin as timeOrigin, Util_toBin as toBin };
625
+ export { Util_EMPTY_FUNCTION as EMPTY_FUNCTION, Util_objectEntries as objectEntries, Util_objectFrom as objectFrom, Util_options as options, Util_safePromise as safePromise, Util_stringify as stringify, Util_time as time, Util_timeOrigin as timeOrigin, Util_toBin as toBin };
621
626
  }
622
627
 
623
628
  /**
@@ -738,4 +743,12 @@ declare class WebSocketReliable extends EventEmitter {
738
743
  close(error?: string): void;
739
744
  }
740
745
 
741
- export { BinaryReader, BinaryWriter, BitReader, Connect, EventEmitter, type ILog, NetAddress, Numbers, Queue, SDP, Util, WebSocketReliable };
746
+ /**
747
+ * Copyright 2024 Ceeblue B.V.
748
+ * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.
749
+ * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.
750
+ */
751
+
752
+ declare const VERSION: string;
753
+
754
+ export { BinaryReader, BinaryWriter, BitReader, Connect, EventEmitter, type ILog, NetAddress, Numbers, Queue, SDP, Util, VERSION, WebSocketReliable };
package/dist/web-utils.js CHANGED
@@ -1106,10 +1106,6 @@ const _perf = performance; // to increase x10 now performance!
1106
1106
  /**
1107
1107
  * Some basic utility functions
1108
1108
  */
1109
- /**
1110
- * Version of the library
1111
- */
1112
- const VERSION = '1.0.1';
1113
1109
  /**
1114
1110
  * An empty lambda function, pratical to disable default behavior of function or events which are not expected to be null
1115
1111
  * @example
@@ -1240,7 +1236,7 @@ function objectEntries(value) {
1240
1236
  // Write, Edit and Run your Javascript code using JS Online Compiler
1241
1237
  function stringify(obj, params = {}) {
1242
1238
  params = Object.assign({ space: ' ', decimal: 2, recursive: 1 }, params);
1243
- if (!obj) {
1239
+ if (obj == null) {
1244
1240
  return String(obj);
1245
1241
  }
1246
1242
  const error = obj.error || obj.message;
@@ -1276,9 +1272,25 @@ function stringify(obj, params = {}) {
1276
1272
  }
1277
1273
  return (res += space + '}');
1278
1274
  }
1275
+ /**
1276
+ * Encode a string to a binary representation
1277
+ * @param value string value to convert
1278
+ * @returns binary conversion
1279
+ */
1279
1280
  function toBin(value) {
1280
1281
  return _encoder.encode(value);
1281
- }var Util=/*#__PURE__*/Object.freeze({__proto__:null,EMPTY_FUNCTION:EMPTY_FUNCTION,VERSION:VERSION,objectEntries:objectEntries,objectFrom:objectFrom,options:options,stringify:stringify,time:time,timeOrigin:timeOrigin,toBin:toBin});/**
1282
+ }
1283
+ /**
1284
+ * Execute a promise in a safe way with a timeout if caller doesn't resolve it in the accurate time
1285
+ */
1286
+ function safePromise(timeout, promise) {
1287
+ // Returns a race between our timeout and the passed in promise
1288
+ let timer;
1289
+ return Promise.race([
1290
+ promise instanceof Promise ? promise : new Promise(promise),
1291
+ new Promise((resolve, reject) => (timer = setTimeout(() => reject('timed out in ' + timeout + 'ms'), timeout)))
1292
+ ]).finally(() => clearTimeout(timer));
1293
+ }var Util=/*#__PURE__*/Object.freeze({__proto__:null,EMPTY_FUNCTION:EMPTY_FUNCTION,objectEntries:objectEntries,objectFrom:objectFrom,options:options,safePromise:safePromise,stringify:stringify,time:time,timeOrigin:timeOrigin,toBin:toBin});/**
1282
1294
  * Copyright 2024 Ceeblue B.V.
1283
1295
  * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.
1284
1296
  * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.
@@ -1482,4 +1494,9 @@ class WebSocketReliable extends EventEmitter {
1482
1494
  this._queueingBytes = 0;
1483
1495
  this.onClose(error);
1484
1496
  }
1485
- }export{BinaryReader,BinaryWriter,BitReader,Connect,EventEmitter,NetAddress,Numbers,Queue,SDP,Util,WebSocketReliable};//# sourceMappingURL=web-utils.js.map
1497
+ }/**
1498
+ * Copyright 2024 Ceeblue B.V.
1499
+ * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.
1500
+ * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.
1501
+ */
1502
+ const VERSION = '1.2.0';export{BinaryReader,BinaryWriter,BitReader,Connect,EventEmitter,NetAddress,Numbers,Queue,SDP,Util,VERSION,WebSocketReliable};//# sourceMappingURL=web-utils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"web-utils.js","sources":["../src/BinaryReader.ts","../src/BinaryWriter.ts","../src/BitReader.ts","../src/NetAddress.ts","../src/Connect.ts","../src/EventEmitter.ts","../src/Queue.ts","../src/Numbers.ts","../src/SDP.ts","../src/Util.ts","../src/WebSocketReliable.ts"],"sourcesContent":["/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/**\n * BinaryReader allows to read binary data\n */\nexport class BinaryReader {\n private _data: Uint8Array;\n private _size: number;\n private _position: number;\n private _view: DataView;\n\n constructor(data: BufferSource) {\n this._data =\n 'buffer' in data ? new Uint8Array(data.buffer, data.byteOffset, data.byteLength) : new Uint8Array(data);\n this._size = this._data.byteLength;\n this._position = 0;\n this._view = new DataView(this._data.buffer, this._data.byteOffset, this._size);\n }\n\n data(): Uint8Array {\n return this._data;\n }\n size(): number {\n return this._size;\n }\n\n available(): number {\n return this._size - this._position;\n }\n value(position: number = this._position): number {\n return this._data[position];\n }\n position(): number {\n return this._position;\n }\n reset(position = 0) {\n this._position = position > this._size ? this._size : position;\n }\n\n shrink(available: number): number {\n const rest = this._size - this._position;\n if (available > rest) {\n return rest;\n }\n this._size = this._position + available;\n return available;\n }\n\n next(count = 1): number {\n const rest = this._size - this._position;\n if (count > rest) {\n count = rest;\n }\n this._position += count;\n return count;\n }\n\n read8(): number {\n return this.next(1) === 1 ? this._view.getUint8(this._position - 1) : 0;\n }\n read16(): number {\n return this.next(2) === 2 ? this._view.getUint16(this._position - 2) : 0;\n }\n read24(): number {\n return this.next(3) === 3\n ? (this._view.getUint16(this._position - 3) << 8) | (this._view.getUint8(this._position - 1) & 0xff)\n : 0;\n }\n read32(): number {\n return this.next(4) === 4 ? this._view.getUint32(this._position - 4) : 0;\n }\n readFloat(): number {\n return this.next(4) === 4 ? this._view.getFloat32(this._position - 4) : 0;\n }\n readDouble(): number {\n return this.next(8) === 8 ? this._view.getFloat64(this._position - 8) : 0;\n }\n read7Bit(bytes = 5): number {\n if (bytes > 5) {\n throw Error(\"BinaryReader in JS can't decode more than 32 usefull bits\");\n }\n if (!(bytes > 0)) {\n // negation to catch NaN value\n throw Error('Have to indicate a positive number of bytes to decode');\n }\n let result = 0;\n let byte;\n do {\n byte = this.read8();\n if (!--bytes) {\n return ((result << 8) | byte) >>> 0; // Use all 8 bits from the 5th byte\n }\n result = (result << 7) | (byte & 0x7f);\n } while (byte & 0x80);\n return result;\n }\n readString(): string {\n return String.fromCharCode(...this.read(this.read7Bit()));\n }\n\n readHex(size: number): string {\n let hex = '';\n while (size--) {\n hex += ('0' + this.read8().toString(16)).slice(-2);\n }\n return hex;\n }\n\n /**\n * Read bytes, to convert bytes to string use String.fromCharCode(...reader.read(size))\n * @param {UInt32} size\n */\n read(size = this.available()): Uint8Array {\n if (this.available() < size) {\n return new Uint8Array(size); // default value = empty bytearray!\n }\n const value = this._data.subarray(this._position, this._position + size);\n this._position += size;\n return value;\n }\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/**\n * BinaryWriter allows to write data in its binary form\n */\nexport class BinaryWriter {\n get view(): DataView {\n if (!this._view) {\n this._view = new DataView(this._data.buffer, this._data.byteOffset, this._data.byteLength);\n }\n return this._view;\n }\n get capacity(): number {\n return this._data.byteLength;\n }\n\n private _data: Uint8Array;\n private _size: number;\n private _view?: DataView;\n private _isConst?: boolean;\n\n constructor(dataOrSize: BufferSource | number = 64, offset: number = 0, length?: number) {\n if (typeof dataOrSize == 'number') {\n // allocate new buffer\n this._data = new Uint8Array(dataOrSize);\n this._size = 0;\n } else if ('buffer' in dataOrSize) {\n // append to existing data!\n this._data = new Uint8Array(dataOrSize.buffer, dataOrSize.byteOffset, dataOrSize.byteLength);\n this._size = dataOrSize.byteLength;\n } else {\n // overrides data\n this._isConst = true; // better than boolean for memory usage\n if (length == null) {\n // /!\\ Safari does not support undefined length, so we need to use byteLength instead\n length = dataOrSize.byteLength;\n }\n this._data = new Uint8Array(dataOrSize, offset, length);\n this._size = 0;\n }\n }\n\n data(): Uint8Array {\n return new Uint8Array(this._data.buffer, this._data.byteOffset, this._size);\n }\n size(): number {\n return this._size || 0;\n }\n\n next(count = 1): BinaryWriter {\n return this.reserve((this._size += count));\n }\n clear(size = 0): BinaryWriter {\n return this.reserve((this._size = size));\n }\n\n write(data: string | ArrayLike<number>): BinaryWriter {\n this.reserve(this._size + data.length);\n if (typeof data === 'string') {\n // beware here support just the 255 first bytes (compatible Latin-1)\n for (let i = 0; i < data.length; ++i) {\n const value = data.charCodeAt(i);\n this._data[this._size++] = value > 255 ? 32 : value;\n }\n return this;\n }\n this._data.set(data, this._size);\n this._size += data.length;\n return this;\n }\n\n write8(value: number): BinaryWriter {\n if (value > 0xff) {\n // cast to 8bits range\n value = 0xff;\n }\n this.reserve(this._size + 1);\n this._data[this._size++] = value;\n return this;\n }\n\n write16(value: number): BinaryWriter {\n if (value > 0xffff) {\n // cast to 16bits range\n value = 0xffff;\n }\n this.reserve(this._size + 2);\n this.view.setUint16(this._size, value);\n this._size += 2;\n return this;\n }\n\n write24(value: number): BinaryWriter {\n if (value > 0xffffff) {\n // cast to 24bits range\n value = 0xffffff;\n }\n this.reserve(this._size + 3);\n this.view.setUint16(this._size, value >> 8);\n this.view.setUint8((this._size += 2), value & 0xff);\n ++this._size;\n return this;\n }\n write32(value: number): BinaryWriter {\n if (value > 0xffffffff) {\n // cast to 32bits range\n value = 0xffffffff;\n }\n this.reserve(this._size + 4);\n this.view.setUint32(this._size, value);\n this._size += 4;\n return this;\n }\n\n writeFloat(value: number): BinaryWriter {\n this.reserve(this._size + 4);\n this.view.setFloat32(this._size, value);\n this._size += 4;\n return this;\n }\n\n writeDouble(value: number): BinaryWriter {\n this.reserve(this._size + 8);\n this.view.setFloat64(this._size, value);\n this._size += 8;\n return this;\n }\n\n write7Bit(value: number, bytes: number = 5): BinaryWriter {\n if (bytes > 5) {\n throw Error(\"BinaryWriter in JS can't encode more than 32 usefull bits\");\n }\n if (!(bytes > 0)) {\n // negation to catch NaN value\n throw Error('Have to indicate a positive number of bytes to encode');\n }\n let bits = --bytes * 7;\n const front = value > 0xffffffff ? 0x100 : value >>> bits;\n if (front) {\n ++bits;\n if (front > 0xff) {\n value = 0xffffffff;\n }\n } else {\n while ((bits -= 7) && !(value >>> bits)) {\n continue;\n }\n }\n\n while (bits > 1) {\n this.write8(0x80 | ((value >>> bits) & 0xff));\n bits -= 7;\n }\n return this.write8(value & (bits ? 0xff : 0x7f));\n }\n\n writeString(value: string): BinaryWriter {\n return this.write7Bit(value.length).write(value);\n }\n\n writeHex(value: string): BinaryWriter {\n for (let i = 0; i < value.length; i += 2) {\n this.write8(parseInt(value.substring(i, i + 2), 16));\n }\n return this;\n }\n\n reserve(size: number): BinaryWriter {\n if (!this._data) {\n throw new Error('buffer not writable');\n }\n if (size <= this._data.byteLength) {\n return this;\n }\n if (this._isConst) {\n throw new Error('writing exceeds maximum ' + this._data.byteLength + ' bytes limit');\n }\n\n --size;\n size |= size >> 1;\n size |= size >> 2;\n size |= size >> 4;\n size |= size >> 8;\n size |= size >> 16;\n ++size;\n\n const data = new Uint8Array(size);\n data.set(this._data); // copy old buffer!\n this._data = data;\n this._view = undefined; // release view\n return this;\n }\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/**\n * BitReader allows to read binary data bit by bit\n */\nexport class BitReader {\n private _data: Uint8Array;\n private _size: number;\n private _position: number;\n private _bit: number;\n\n constructor(data: BufferSource) {\n if ('buffer' in data) {\n this._data = new Uint8Array(data.buffer, data.byteOffset, data.byteLength);\n } else {\n this._data = new Uint8Array(data);\n }\n this._size = this._data.byteLength;\n this._position = 0;\n this._bit = 0;\n }\n\n data(): Uint8Array {\n return this._data;\n }\n size(): number {\n return this._size;\n }\n available(): number {\n return (this._size - this._position) * 8 - this._bit;\n }\n\n next(count = 1): number {\n let gotten = 0;\n while (this._position !== this._size && count--) {\n ++gotten;\n if (++this._bit === 8) {\n this._bit = 0;\n ++this._position;\n }\n }\n return gotten;\n }\n read(count = 1): number {\n let result = 0;\n while (this._position !== this._size && count--) {\n result <<= 1;\n if (this._data[this._position] & (0x80 >> this._bit++)) {\n result |= 1;\n }\n if (this._bit === 8) {\n this._bit = 0;\n ++this._position;\n }\n }\n return result;\n }\n read8(): number {\n return this.read(8);\n }\n read16(): number {\n return this.read(16);\n }\n read24(): number {\n return this.read(24);\n }\n read32(): number {\n return this.read(32);\n }\n}\n\nexport function readExpGolomb(reader: BitReader): number {\n let i = 0;\n while (reader.available() && !reader.read()) {\n ++i;\n }\n const result = reader.read(i);\n if (i > 15) {\n console.warn('Exponential-Golomb code exceeding unsigned 16 bits');\n return 0;\n }\n return result + (1 << i) - 1;\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/**\n * Help class to manipulate and parse a net address. The Address can be only the domain field,\n * or a URL format with protocol and path part `(http://)domain(:port/path)`\n * @example\n * const address = new Address('nl-ams-42.live.ceeblue.tv:80');\n * console.log(address.domain) // 'nl-ams-42.live.ceeblue.tv'\n * console.log(address.port) // '80'\n * console.log(address) // 'nl-ams-42.live.ceeblue.tv:80'\n */\nexport class NetAddress {\n /**\n * Static help function to build an end point from an address `(proto://)domain(:port/path)`\n *\n * Mainly it fix the protocol, in addition if:\n * - the address passed is securized (TLS) and protocol is not => it tries to fix protocol to get its securize version\n * - the address passed is non securized and protocol is (TLS) => it tries to fix protocol to get its unsecurized version\n * @param protocol protocol to set in the end point returned\n * @param address string address to fix with protocol as indicated\n * @returns the end point built\n * @example\n * console.log(NetAddress.fixProtocol('ws','http://domain/path')) // 'ws://domain/path'\n * console.log(NetAddress.fixProtocol('ws','https://domain/path')) // 'wss://domain/path'\n * console.log(NetAddress.fixProtocol('wss','http://domain/path')) // 'ws://domain/path'\n */\n static fixProtocol(protocol: string, address: string): string {\n const found = address.indexOf('://');\n // isolate protocol is present in address\n if (found >= 0) {\n // In this case replace by protocol in keeping SSL like given in address\n if (found > 2 && address.charAt(found - 1).toLowerCase() === 's') {\n // SSL!\n if (protocol.length <= 2 || !protocol.endsWith('s')) {\n protocol += 's'; // Add SSL\n }\n } else {\n // Not SSL!\n if (protocol.length > 2 && protocol.endsWith('s')) {\n protocol = protocol.slice(0, -1); // Remove SSL\n }\n }\n // Build host!\n address = address.substring(found + 3);\n }\n return protocol + '://' + address;\n }\n\n /**\n * The domain part from address `(http://)domain(:port/path)`\n */\n get domain(): string {\n return this._domain;\n }\n /**\n * The port part from address `(http://)domain(:port/path)`, or defaultPort if passed in NetAddress constructor\n */\n get port(): number | undefined {\n return this._port;\n }\n /**\n * @returns the string address as passed in the constructor\n */\n toString(): string {\n return this._address;\n }\n /**\n * @returns the string address as passed in the constructor\n * @override\n */\n valueOf(): string {\n return this._address;\n }\n\n private _address: string;\n private _domain: string;\n private _port?: number;\n /**\n * Build a NetAddress object and parse address\n * @param address string address to parse, accept an url format with protocol and path `(http://)domain(:port/path)`\n * @param defaultPort set a default port to use if there is no port in the string address parsed\n */\n constructor(address: string, defaultPort?: number) {\n this._address = address;\n\n // Remove Protocol\n let pos = address.indexOf('/');\n if (pos >= 0) {\n // Remove ://\n if (address.charCodeAt(pos + 1) === 47) {\n // has //\n if (pos > 0) {\n if (address.charCodeAt(pos - 1) === 58) {\n // has ://\n address = address.substring(pos + 2);\n } // something else #//\n } else {\n // otherwise starts by //\n address = address.substring(2);\n }\n } else if (!pos) {\n // starts by /, remove it\n address = address.substring(1);\n } // else something else #/\n }\n\n this._domain = address;\n this._port = defaultPort;\n\n // Parse Port\n pos = address.lastIndexOf(':');\n if (pos >= 0) {\n const port = parseInt(address.substring(pos + 1));\n if (port && port <= 0xffff) {\n this._port = port;\n this._domain = address.substring(0, pos);\n }\n } else {\n // Remove Path!\n pos = address.indexOf('/');\n if (pos >= 0) {\n this._domain = address.substring(0, pos);\n }\n }\n }\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\nimport { NetAddress } from './NetAddress';\n\n/**\n * Parameters of connections\n */\nexport type Params = {\n /**\n * Host to connect. Can include port, and accept also an url format with port and path,\n * it can help to force a path OR try to give a protocol preference\n */\n host: string;\n /**\n * The name of the stream to join\n */\n streamName: string;\n /**\n * Optional access token to use to join a private stream\n */\n accessToken?: string;\n /**\n * iceServer to use while connecting to a WebRTC stream\n */\n iceServer?: RTCIceServer; // Authentication value\n /**\n * Optional query to add into the generated url of connection\n */\n query?: Record<string, string>;\n};\n\n/**\n * Type of connection\n */\nexport enum Type {\n HESP = 'hesp',\n WEBRTS = 'webrts',\n WEBRTC = 'webrtc',\n META = 'meta',\n DATA = 'data'\n}\n\n/**\n * Some connection utility functions\n */\n\n/**\n * Build an URL from {@link Type | type} and {@link Params | params}\n * @param type Type of the connection wanted\n * @param params Connection parameters\n * @param protocol Optional parameter to choose the prefered protocol to connect\n * @returns The URL of connection\n */\nexport function buildURL(type: Type, params: Params, protocol: string = 'wss'): URL {\n const url = new URL(NetAddress.fixProtocol(protocol, params.host));\n\n if (url.pathname.length <= 1) {\n // build ceeblue path!\n switch (type) {\n case Type.HESP:\n url.pathname = '/hesp/' + params.streamName + '/index.json';\n break;\n case Type.WEBRTC:\n url.pathname = '/webrtc/' + params.streamName;\n break;\n case Type.WEBRTS:\n url.pathname = '/webrts/' + params.streamName;\n break;\n case Type.META:\n url.pathname = '/json_' + params.streamName + '.js';\n break;\n case Type.DATA:\n url.pathname = '/' + params.streamName + '.json';\n break;\n default:\n console.warn('Unknown url type ' + type);\n break;\n }\n } // Host has already a path! keep it unchanged, it's user intentionnal (used with some other WHIP/WHEP server?)\n if (params.accessToken) {\n url.searchParams.set('id', params.accessToken);\n }\n\n for (const key in params.query) {\n url.searchParams.set(key, params.query[key]);\n }\n return url;\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/**\n * A advanced EventEmitter which allows to declare event as natural function in the inheriting children class,\n * function must start by `on` prefix to be recognized as an event.\n * The function can define a behavior by default, and user can choose to redefine this behavior,\n * or add an additionnal subscription for this event.\n * In addition you can unsubscribe to multiple events with an `AbortController`\n * @example\n * class Logger extends EventEmitter {\n * onLog(log:string) { console.log(log); } // behavior by default\n *\n * test() {\n * // raise event onLog\n * this.onLog('test');\n * }\n * }\n *\n * const logger = new Logger();\n * logger.test(); // displays a log 'test'\n *\n * // redefine default behavior to display nothing\n * logger.onLog = () => {}\n * logger.test(); // displays nothing\n *\n * // add an additionnal subscription\n * logger.on('log', console.log);\n * logger.test(); // displays a log 'test'\n *\n * // remove the additionnal subscription\n * logger.off('log', console.log);\n * logger.test(); // displays nothing\n *\n * // add two additionnal subscriptions with a AbortController\n * const controller = new AbortController();\n * logger.on('log', log => console.log(log), controller);\n * logger.on('log', log => console.error(log), controller);\n * logger.test(); // displays a log 'test' + an error 'test'\n *\n * // Unsubscribe all the subscription with the AbortController\n * controller.abort();\n * logger.test(); // displays nothing\n */\nexport class EventEmitter {\n private _events: Map<string, Set<Function>>;\n\n /**\n * Build our EventEmitter, usually call from children class\n */\n constructor() {\n this._events = new Map();\n // Fill events with events as defined!\n let proto = Object.getPrototypeOf(this);\n while (proto && proto !== Object.prototype) {\n for (const name of Object.getOwnPropertyNames(proto)) {\n if (name.length < 3 || !name.startsWith('on')) {\n continue;\n }\n if (proto[name] instanceof Function) {\n const events = new Set<Function>();\n this._events.set(name.substring(2).toLowerCase(), events);\n let defaultEvent = proto[name];\n Object.defineProperties(this, {\n [name]: {\n get:\n () =>\n (...args: unknown[]) => {\n // Call default event if not null (can happen in JS usage)\n if (defaultEvent) {\n defaultEvent.call(this, ...args);\n }\n // Call subscribers\n for (const event of events) {\n event(...args);\n }\n },\n set: (value: Function | undefined) => {\n // Assign a default behavior!\n defaultEvent = value;\n }\n }\n });\n }\n }\n proto = Object.getPrototypeOf(proto);\n }\n }\n\n /**\n * Event subscription\n * @param name Name of event without the `on` prefix (ex: `log` to `onLog` event declared)\n * @param event Subscriber Function\n * @param abort Optional `AbortController` to stop this or multiple subscriptions in same time\n */\n on(name: string, event: Function, abort?: AbortController) {\n if (!event) {\n throw Error('event to subscribe cannot be null');\n }\n const events = this._event(name);\n events.add(event);\n if (abort) {\n abort.signal.addEventListener('abort', () => {\n events.delete(event);\n });\n }\n }\n\n /**\n * Event subscription only one time, once time fired it's automatically unsubscribe\n * @param name Name of event without the `on` prefix (ex: `log` to `onLog` event declared)\n * @param event Subscriber Function\n * @param abort Optional `AbortController` to stop this or multiple subscriptions in same time\n */\n once(name: string, event: Function, abort?: AbortController) {\n if (!event) {\n throw Error('event to subscribe cannot be null');\n }\n const events = this._event(name);\n events.add(() => {\n events.delete(event); // delete from events\n event(); // execute event\n });\n if (abort) {\n abort.signal.addEventListener('abort', () => {\n events.delete(event);\n });\n }\n }\n\n /**\n * Event unsubscription\n * @param name Name of event without the 'on' prefix (ex: 'log' to 'onLog' event declared)\n * @param event Unsubscriber Function, must be the one passed to {@link on} or {@link once} subscription methods\n */\n off(name: string, event: Function) {\n if (!event) {\n throw Error('event to unsubscribe cannot be null');\n }\n this._event(name).delete(event);\n }\n\n private _event(name: string): Set<Function> {\n const events = this._events.get(name.toLowerCase());\n if (!events) {\n throw Error('No event on' + name + ' on class ' + this.constructor.name);\n }\n return events;\n }\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/**\n * Queue typed similar to a {@link https://en.cppreference.com/w/cpp/container/queue | std::queue<Type>} with possibility to limit the capacity like a FIFO\n * @example\n * const queue = new Queue<number>(2);\n * queue.push(1); // [1]\n * queue.push(2); // [1,2]\n * queue.push(3); // [2,3] 1 has been removed to respect 2 capacity\n */\nexport class Queue<Type> {\n /**\n * Number of element in the queue\n */\n get size(): number {\n return this._queue.length;\n }\n\n /**\n * Maximum capacity for the queue, if not set queue has unlimited capacity\n */\n get capacity(): number | undefined {\n return this._capacity;\n }\n\n /**\n * Set a maximum capacity for the queue,\n * if you push new value exceding this capacity the firsts are removed (FIFO)\n * if set to undefined the queue is unlimited\n */\n set capacity(value: number | undefined) {\n this._capacity = value;\n if (value != null && this._queue.length > value) {\n this._queue.splice(0, this._queue.length - value);\n }\n }\n\n /**\n * The front element\n */\n get front(): Type {\n return this._queue[0];\n }\n\n /**\n * The back element\n */\n get back(): Type {\n return this._queue[this._queue.length - 1];\n }\n\n /**\n * Iterator though queue's elements\n */\n [Symbol.iterator](): IterableIterator<Type> {\n return this._queue[Symbol.iterator]();\n }\n\n private _capacity?: number;\n private _queue: Array<Type>;\n /**\n * Instanciate a new queue object with the type passed as template\n * @param capacity if set it limits the size of the queue, any exceding element pops the first element pushed (FIFO)\n */\n constructor(capacity?: number) {\n this._capacity = capacity;\n this._queue = new Array<Type>();\n }\n\n /**\n * Push a new element in the queue\n * @param value value of the element\n * @returns this\n */\n push(value: Type): Queue<Type> {\n if (this._capacity != null && this._queue.push(value) > this._capacity) {\n this.pop();\n }\n return this;\n }\n\n /**\n * Pop the first element from the queue\n * @returns The first element removed\n */\n pop(): Type | undefined {\n return this._queue.shift();\n }\n\n /**\n * Clear all the elements, queue becomes empty\n * @returns this\n */\n clear(): Queue<Type> {\n this._queue.length = 0;\n return this;\n }\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\nimport { Queue } from './Queue';\n\n/**\n * A collection of number Queue<number> with the following efficient mathematic computation:\n * - minimum value in the collection\n * - maximum value in the collection\n * - average value of the collection\n */\nexport class Numbers extends Queue<number> {\n /**\n * minimum value in the collection, or 0 if colleciton is empty\n */\n get minimum(): number {\n return this._min;\n }\n\n /**\n * maximum value in the collection, or 0 if colleciton is empty\n */\n get maximum(): number {\n return this._max;\n }\n\n /**\n * average value of the collection, or 0 if collection if empty\n */\n get average(): number {\n if (this._average == null) {\n this._average = this.size ? this._sum / this.size : 0;\n }\n return this._average;\n }\n\n private _average?: number;\n private _sum: number = 0;\n private _min: number = 0;\n private _max: number = 0;\n /**\n * Instantiate the collection of the number\n * @param capacity if set it limits the number of values stored, any exceding number pops the first number pushed (FIFO)\n */\n constructor(capacity?: number) {\n super(capacity);\n }\n\n /**\n * Push a value to the back to the collection\n * @param value number to add\n * @returns this\n */\n push(value: number): Numbers {\n if (value > this._max) {\n this._max = value;\n } else if (value < this._min) {\n this._min = value;\n }\n this._average = undefined;\n this._sum += value;\n super.push(value);\n return this;\n }\n\n /**\n * Pop the front number from the collection\n * @returns the front number removed\n */\n pop(): number | undefined {\n const front = super.pop();\n if (front === this._max) {\n this._max = Math.max(0, ...this);\n } else if (front === this._min) {\n this._min = Math.min(0, ...this);\n }\n this._average = undefined;\n this._sum -= front || 0;\n return front;\n }\n\n /**\n * Clear all the numbers, collection becomes empty\n * @returns this\n */\n clear() {\n this._min = this._max = this._sum = 0;\n super.clear();\n return this;\n }\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n/**\n * Toolkit to deal with Session Description Protocol (SDP),\n * mainly to tranform a SDP string Offer/Answer to a manipulable JS object representation\n * @example\n * const peerConnection = new RTCPeerConnection();\n * peerConnection.createOffer()\n * .then( offer =>\n * // Change offer.sdp string to a JS manipulable object\n * const sdp = SDP.fromString(offer.sdp || '');\n * // Change a property of SDP\n * sdp.v = 2; // change SDP version\n * // Reserialize to the legal SDP string format\n * offer.sdp = SDP.toString(sdp);\n * // Set SDP offer to peerConnection\n * peerConnection.setLocalDescription(offer);\n * )\n */\nexport const SDP = {\n /**\n * Unserialize SDP string to a manipulable JS object representation\n * It's an object with:\n * - root SDP properties\n * - media description iterable\n * @param lines SDP string reprensentation\n * @returns SDP object representation, iterable through media description\n * @example\n * [\n * group: \"DUNBLE 0 1\",\n * o: \"- 1699450751193623 0 IN IP4 0.0.0.0\",\n * s: \"-\",\n * t: \"0 0\",\n * v: \"0\",\n * ice-lite: \"\",\n * length: 2,\n * {\n * m: \"audio 9 UDP/TLS/RTP/SAVPF 111\",\n * c: \"IN IP4 0.0.0.0\",\n * rtcp: \"9\",\n * sendonly: \"\",\n * setup: \"passive\",\n * fingerprint: \"sha-256 51:36:ED:78:A4:9F:25:8C:39:9A:0E:A0:B4:9B:6E:04:37:FF:AD:96:93:71:43:88:2C:0B:0F:AB:6F:9A:52:B8\",\n * ice-ufrag: \"fa37\",\n * ice-pwd: \"JncCHryDsbzayy4cBWDxS2\",\n * rtcp-mux: \"\",\n * rtcp-rsize: \"\",\n * rtpmap: \"111 opus/48000/2\",\n * rtcp-fb: \"111 nack\",\n * id: \"0\",\n * fmtp: \"111 minptime=10;useinbandfec=1\",\n * candidate: \"1 1 udp 2130706431 89.105.221.108 56643 typ host\",\n * end-of-candidates: \"\"\n * },\n * {\n * m: \"video 9 UDP/TLS/RTP/SAVPF 106\",\n * c: \"IN IP4 0.0.0.0\",\n * rtcp: \"9\",\n * sendonly: \"\",\n * setup: \"passive\",\n * fingerprint: \"sha-256 51:36:ED:78:A4:9F:25:8C:39:9A:0E:A0:B4:9B:6E:04:37:FF:AD:96:93:71:43:88:2C:0B:0F:AB:6F:9A:52:B8\",\n * ice-ufrag: \"fa37\",\n * ice-pwd: \"JncCHryDsbzayy4cBWDxS2\",\n * rtcp-mux: \"\",\n * rtcp-rsize: \"\",\n * rtpmap: \"106 H264/90000\",\n * rtcp-fb: [\n * \"106 nack\",\n * \"106 goog-remb\"\n * ],\n * mid: \"1\",\n * fmtp: \"106 profile-level-id=42e01f;level-asymmetry-allowed=1;packetization-mode=1\",\n * candidate: \"1 1 udp 2130706431 89.105.221.108 56643 typ host\",\n * end-of-candidates: \"\"\n * }\n * ]\n */\n fromString(lines: string): any {\n if (Array.isArray(lines)) {\n return lines; // already converted\n }\n const sdp = new Array<any>();\n let media: any = sdp;\n let fingerprint;\n for (let line of lines.toString().split('\\n')) {\n line = line.trim();\n if (!line) {\n continue;\n }\n\n let key = line[0];\n const value = line.substring(line.indexOf('=') + 1).trim();\n switch (key.toLowerCase()) {\n case 'a': {\n if (!value) {\n continue;\n } // empty attribute!\n key = this.addAttribute(media, value);\n // save fingerprint to repeat it in medias\n if (sdp === media && key.toLowerCase() === 'fingerprint') {\n fingerprint = media.fingerprint;\n }\n break;\n }\n case 'm':\n if (sdp.length && fingerprint && !sdp[sdp.length - 1].fingerprint) {\n media.fingerprint = fingerprint;\n }\n sdp.push((media = { m: value }));\n break;\n default:\n media[key] = value;\n }\n }\n if (sdp.length && fingerprint && !sdp[sdp.length - 1].fingerprint) {\n media.fingerprint = fingerprint;\n }\n return sdp;\n },\n\n /**\n * Serialize SDP JS object to a SDP string legal representation\n * @param sdp SDP object reprensetation\n * @returns SDP string reprensentation\n */\n toString(sdp: any): string {\n if (typeof sdp === 'string') {\n return sdp; // already converted\n }\n const medias = [];\n // https://www.cl.cam.ac.uk/~jac22/books/mm/book/node182.html\n let lines = 'v' in sdp ? 'v=' + sdp.v + '\\n' : '';\n if ('o' in sdp) {\n lines += 'o=' + sdp.o + '\\n';\n }\n if ('s' in sdp) {\n lines += 's=' + sdp.s + '\\n';\n }\n const obj: any = sdp;\n for (const key of Object.keys(sdp)) {\n if (key === 'v' || key === 'o' || key === 's') {\n continue;\n }\n const value = obj[key];\n if (value == null) {\n continue;\n } // ignore this key/value\n const index = parseInt(key);\n if (!isNaN(index)) {\n // Is a number! Media object!\n medias[index] = value;\n continue;\n }\n const count = (Array.isArray(value) && value.length) || 1; // value can be numeric!\n for (let i = 0; i < count; ++i) {\n const line = Array.isArray(value) && value.length ? value[i] : value;\n if (key.length > 1) {\n // when key is superior to 1 letter it's a attribute!\n lines += 'a=' + key;\n if (line) {\n lines += ':';\n }\n } else {\n lines += key + '=';\n }\n lines += line + '\\n';\n }\n }\n for (const media of medias) {\n lines += this.toString(media);\n }\n return lines;\n },\n\n /**\n * While set a property to a SDP object representation is possible directly,\n * we could prefer add a new property without overload a possible already existing value.\n * This function allows to add a property to our SDP representation:\n * - if the key's attribute doesn't exists yet it adds it like a simple JS property sdp[key] = value\n * - if the key's attribute exists already it morphs the value to a Array and push it inside\n * @param sdp the SDP object representation on which added the attribute\n * @param attribute the string attribut in a format \"key:value\" or just \"key\" to add an attribute without value\n * @returns the key part of the attribute added (or if value is empty it returns the same attribute as passed in argument)\n */\n addAttribute(sdp: object, attribute: string): string {\n const a = SDP.parseAttribute(attribute);\n const value = a.value ?? ''; // to allow to test if key exists even without value with if(sdp.key != null)\n const obj: any = sdp;\n const oldValue = obj[a.key];\n if (!oldValue) {\n obj[a.key] = value;\n } else if (Array.isArray(oldValue)) {\n oldValue.push(value);\n } else if (value !== oldValue) {\n obj[a.key] = [oldValue, value];\n }\n return a.key;\n },\n\n /**\n * While it's possible to delete a attribute manually on the SDP object representation with a delete sdp.key,\n * we could prefer remove only a value in a sdp.key array containing multiple values.\n * Like opposite to addAttribute this method allows to remove an unique attribute value.\n * @param sdp the SDP object representation on which removed the attribute\n * @param attribute the string attribut in a format \"key:value\" or just \"key\" to remove the whole attribute and all its values\n * @returns the key part of the attribute removed (or if value is empty it returns the same attribute as passed in argument)\n */\n removeAttribute(sdp: object, attribute: string): string {\n const a = SDP.parseAttribute(attribute);\n const obj: any = sdp;\n if (a.value === undefined) {\n delete obj[attribute];\n return attribute;\n }\n const current = obj[attribute];\n if (Array.isArray(a.value)) {\n const i = current.findIndex((current: string) => current === a.value);\n if (i >= 0) {\n current.splice(i, 1);\n }\n } else if (current === a.value) {\n delete obj[attribute];\n }\n return a.key;\n },\n\n /**\n * Parse an attribute in a format \"key:value\"\n * @param attribute string attribute to parse\n * @returns the {key, value} result, with value undefined if attribute was a \"key\" without value\n */\n parseAttribute(attribute: string): { key: string; value: string | undefined } {\n const found = attribute.indexOf(':');\n return {\n key: (found >= 0 ? attribute.substring(0, found) : attribute).trim(),\n value: found >= 0 ? attribute.substring(found + 1).trim() : undefined\n };\n }\n};\nObject.freeze(SDP);\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\nconst _decoder = new TextDecoder();\nconst _encoder = new TextEncoder();\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nconst _perf = performance; // to increase x10 now performance!\nconst __lib__version__ = '?'; // will be replaced on building by library version\n\n/**\n * Some basic utility functions\n */\n/**\n * Version of the library\n */\nexport const VERSION = __lib__version__;\n\n/**\n * An empty lambda function, pratical to disable default behavior of function or events which are not expected to be null\n * @example\n * console.log = Util.EMPTY_FUNCTION; // disable logs without breaking calls\n */\nexport const EMPTY_FUNCTION = () => {};\n\n/**\n * Efficient and high resolution timestamp in milliseconds elapsed since {@link Util.timeOrigin}\n */\nexport function time(): number {\n return Math.floor(_perf.now());\n}\n\n/**\n * Time origin represents the time when the application has started\n */\nexport function timeOrigin(): number {\n return Math.floor(_perf.now() + _perf.timeOrigin);\n}\n\n/**\n * Parse query and returns it in an easy-to-use Javascript object form\n * @param urlOrQueryOrSearch string, url, or searchParams containing query. If not set it uses `location.search` to determinate query.\n * @returns An javascript object containing each option\n */\nexport function options(\n urlOrQueryOrSearch: URL | URLSearchParams | string | object | undefined = typeof location === 'undefined'\n ? undefined\n : location\n): object {\n if (!urlOrQueryOrSearch) {\n return {};\n }\n try {\n const url: any = urlOrQueryOrSearch;\n urlOrQueryOrSearch = new URL(url).searchParams;\n } catch (e) {\n if (typeof urlOrQueryOrSearch == 'string') {\n if (urlOrQueryOrSearch.startsWith('?')) {\n urlOrQueryOrSearch = urlOrQueryOrSearch.substring(1);\n }\n urlOrQueryOrSearch = new URLSearchParams(urlOrQueryOrSearch);\n }\n }\n // works same if urlOrQueryOrSearch is null, integer, or a already object etc...\n return objectFrom(urlOrQueryOrSearch, { withType: true, noEmptyString: true });\n}\n\n/**\n * Returns an easy-to-use Javascript object something iterable, such as a Map, Set, or Array\n * @param value iterable input\n * @param params.withType `false`, if set it tries to cast string value to a JS number/boolean/undefined/null type.\n * @param params.noEmptyString `false`, if set it converts empty string value to a true boolean, usefull to allow a `if(result.key)` check for example\n * @returns An javascript object\n */\nexport function objectFrom(value: any, params: { withType: boolean; noEmptyString: boolean }): object {\n params = Object.assign({ withType: false, noEmptyString: false }, params);\n const obj: any = {};\n if (!value) {\n return obj;\n }\n for (const [key, val] of objectEntries(value)) {\n value = val;\n if (params.withType && value != null && value.substring) {\n if (value) {\n const number = Number(value);\n if (isNaN(number)) {\n switch (value.toLowerCase()) {\n case 'true':\n value = true;\n break;\n case 'false':\n value = false;\n break;\n case 'null':\n value = null;\n break;\n case 'undefined':\n value = undefined;\n break;\n }\n } else {\n value = number;\n }\n } else if (params.noEmptyString) {\n // if empty string => TRUE to allow a if(options.key) check for example\n value = true;\n }\n }\n if (obj[key]) {\n if (!Array.isArray(obj[key])) {\n obj[key] = new Array(obj[key]);\n }\n obj[key].push(value);\n } else {\n obj[key] = value;\n }\n }\n return obj;\n}\n\n/**\n * Returns entries from something iterable, such as a Map, Set, or Array\n * @param value iterable input\n * @returns An javascript object\n */\nexport function objectEntries(value: any): [string, any][] {\n if (value.entries) {\n return value.entries();\n }\n return Array.from({\n [Symbol.iterator]: function* () {\n for (const key in value) {\n yield [key, value[key]];\n }\n }\n });\n}\n\n/**\n * Converts various data types, such as objects, strings, exceptions, errors,\n * or numbers, into a string representation. Since it offers a more comprehensive format,\n * this function is preferred to `JSON.stringify()`.\n * @param obj Any objects, strings, exceptions, errors, or number\n * @param params.space `''`, allows to configure space in the string representation\n * @param params.decimal `2`, allows to choose the number of decimal to display in the string representation\n * @param params.recursive `false`, allows to serialize recursively every object value, beware if a value refers to a already parsed value an infinite loop will occur.\n * @returns the final string representation\n */\n// Online Javascript Editor for free\n// Write, Edit and Run your Javascript code using JS Online Compiler\nexport function stringify(obj: any, params: { space?: string; decimal?: number; recursive?: number } = {}): string {\n params = Object.assign({ space: ' ', decimal: 2, recursive: 1 }, params);\n if (!obj) {\n return String(obj);\n }\n const error = obj.error || obj.message;\n if (error) {\n // is a error!\n obj = error;\n }\n if (obj.toFixed) {\n return obj.toFixed(Number(params.decimal) || 0);\n }\n if (obj.substring || !params.recursive) {\n // is already a string OR has to be stringified\n return String(obj);\n }\n\n const space = params.space || '';\n\n if (Array.isArray(obj)) {\n // Array!\n let res = '';\n for (const value of obj) {\n res += (res ? ',' : '[') + space;\n res += stringify(value, Object.assign(params, { recursive: params.recursive - 1 }));\n }\n return (res += space + ']');\n }\n if (obj.byteLength != null && obj?.[Symbol.iterator]) {\n // Binary!\n return _decoder.decode(obj);\n }\n let res = '';\n for (const name in obj) {\n res += (res ? ',' : '{') + space + name + ':';\n res += stringify(obj[name], Object.assign(params, { recursive: params.recursive - 1 }));\n }\n return (res += space + '}');\n}\n\nexport function toBin(value: string): Uint8Array {\n return _encoder.encode(value);\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\nimport { EventEmitter } from './EventEmitter';\n\n/**\n * The WebSocketReliable class extends WebSocket to bring up the following improvements:\n * - Fix all possible unintentional closing ways to get always a related error message, {@link onClose | onClose(error?) event}\n * - Make possible message sending while connecting. Indeed no need to wait {@link onOpen} before to send message,\n * you can open the socket and immediately send messages, it will be queue and flushs on connection etablishment\n * - Make possible a delayed connection, or a reconnection. Indeed you can create an unconnected Websocket instance\n * without passing any url argument and starts the conneciton more later with {@link WebSocketReliable.open(url) | open(url)} method\n * - Make possible to control sending/queueing message: send method take an optional queueing=true argument to\n * queue message rather send it, a futur call to flush will send it. Then queueing getter allows to handle the queue\n * if need to purge it or remove some queued message. Use it all together can help to prioritize messages or control overload.\n * @example\n * const ws = new WebSocketReliable(url);\n * ws.onClose = (error?:string) => {\n * if(error) {\n * console.error(error);\n * }\n * // reconnection attempt every seconds\n * setTimeout(() => ws.open(url), 1000);\n * }\n * ws.onMessage = (message:string) => {\n * console.log(message);\n * }\n * ws.send('hello'); // send immediatly a hello message is possible (no need to wait onOpen)\n */\nexport class WebSocketReliable extends EventEmitter {\n /**\n * @event `open` fired when socket is connected\n */\n onOpen() {}\n\n /**\n * @event `message` fired on message reception\n * @param message can be binary or string.\n * If you subscribe to the event with message as string type (and not union),\n * it means that you know that all your messages are distributed in a string format\n */\n onMessage(message: ArrayBuffer | string) {}\n\n /**\n * @event `close` fired on websocket close\n * @param error error description on an improper closure\n */\n onClose(error?: string) {\n if (error) {\n console.error(error);\n }\n }\n\n /**\n * binaryType, fix binary type to arrayBuffer\n */\n get binaryType(): BinaryType {\n return 'arraybuffer';\n }\n\n /**\n * url of connection\n */\n get url(): string {\n return this._ws?.url ?? '';\n }\n\n /**\n * extensions negociated by the server\n */\n get extensions(): string {\n return this._ws?.extensions ?? '';\n }\n\n /**\n * protocol negociated by the server\n */\n get protocol(): string {\n return this._ws?.protocol ?? '';\n }\n\n /**\n * opened equals true when connection is etablished, in other word when onOpen event is fired\n */\n get opened(): boolean {\n return this._opened;\n }\n\n /**\n * {@link https://developer.mozilla.org/docs/Web/API/WebSocket/readyState | Official websocket readyState}\n */\n get readyState(): number {\n return this._ws ? this._ws.readyState : 3;\n }\n\n /**\n * True when connection is closed, in other words when {@link onClose} event is fired\n * or when WebSocketReliable is build without url (disconnected creation)\n */\n get closed(): boolean {\n return this._closed;\n }\n\n /**\n * The number of bytes of data that were queued during calls to send() but not yet transmitted to the network\n */\n get bufferedAmount(): number {\n return this._queueingBytes + (this._ws?.bufferedAmount || 0);\n }\n\n /**\n * Queued messages from a call to send() waiting to be transmit one time websocket connection opened (or with an explicit call to flush() method)\n */\n get queueing(): Array<string | ArrayBuffer | ArrayBufferView> {\n return this._queueing;\n }\n\n private _opened: boolean;\n private _closed: boolean;\n private _queueing: Array<string | ArrayBuffer | ArrayBufferView>;\n private _queueingBytes: number;\n private _ws?: WebSocket;\n /**\n * Create a WebSocketReliable object, and open it if an url is passed in argument\n * @param url URL of the WebSocket endpoint or null to start the connection later\n */\n constructor(url?: string | URL, protocols?: string | string[]) {\n super();\n this._queueing = [];\n this._queueingBytes = 0;\n this._opened = false;\n this._closed = true;\n if (url) {\n this.open(url, protocols);\n }\n }\n\n /**\n * Open a WebSocket connection\n * @param url url of the websocket endpoint\n * @returns this\n */\n open(url: URL | string, protocols?: string | string[]) {\n this._closed = false;\n const ws = (this._ws = new WebSocket(url, protocols));\n ws.binaryType = this.binaryType;\n ws.onmessage = e => this.onMessage(e.data);\n // Add details and fix close ways\n ws.onclose = (e: CloseEvent) => {\n if (!this._opened) {\n // close during connection\n this.close(url.toString() + ' connection failed (' + String(e.reason || e.code) + ')');\n } else if (e.code === 1000 || e.code === 1005) {\n // normal disconnection from server (no error code)\n this.close(url.toString() + ' shutdown');\n } else {\n // disconnection from server\n this.close(url.toString() + ' disconnection (' + String(e.reason || e.code) + ')');\n }\n };\n // Wrap send method to queue messages until connection is established.\n ws.onopen = _ => {\n this._opened = true;\n this.flush();\n this.onOpen();\n };\n return this;\n }\n\n /**\n * Send a message\n * @param message\n * @param queueing When set it reports the sending to a more later call to flush\n * @returns this\n */\n send(message: string | ArrayBuffer | ArrayBufferView, queueing: boolean = false) {\n if (!this._ws) {\n throw Error('Open socket before to send data');\n }\n if (queueing || !this._opened) {\n this._queueing.push(message);\n this._queueingBytes += typeof message === 'string' ? message.length : message.byteLength;\n } else {\n this._ws.send(message);\n }\n return this;\n }\n\n /**\n * Send queueing messages\n */\n flush() {\n if (this._ws) {\n for (const message of this._queueing) {\n this._ws.send(message);\n }\n }\n this._queueing.length = 0;\n this._queueingBytes = 0;\n }\n\n /**\n * Close websocket\n * @param error the error reason if is not a proper close\n */\n close(error?: string) {\n if (!this._ws || this._closed) {\n return;\n }\n this._closed = true;\n this._ws.onopen = this._ws.onclose = this._ws.onmessage = null; // otherwise can receive message AFTER close!\n this._ws.close(); // Don't set to undefined to keep this._ws properties valid!\n // release resources!\n this._opened = false;\n this._queueing.length = 0;\n this._queueingBytes = 0;\n this.onClose(error);\n }\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"web-utils.js","sources":["../src/BinaryReader.ts","../src/BinaryWriter.ts","../src/BitReader.ts","../src/NetAddress.ts","../src/Connect.ts","../src/EventEmitter.ts","../src/Queue.ts","../src/Numbers.ts","../src/SDP.ts","../src/Util.ts","../src/WebSocketReliable.ts","../index.ts"],"sourcesContent":["/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/**\n * BinaryReader allows to read binary data\n */\nexport class BinaryReader {\n private _data: Uint8Array;\n private _size: number;\n private _position: number;\n private _view: DataView;\n\n constructor(data: BufferSource) {\n this._data =\n 'buffer' in data ? new Uint8Array(data.buffer, data.byteOffset, data.byteLength) : new Uint8Array(data);\n this._size = this._data.byteLength;\n this._position = 0;\n this._view = new DataView(this._data.buffer, this._data.byteOffset, this._size);\n }\n\n data(): Uint8Array {\n return this._data;\n }\n size(): number {\n return this._size;\n }\n\n available(): number {\n return this._size - this._position;\n }\n value(position: number = this._position): number {\n return this._data[position];\n }\n position(): number {\n return this._position;\n }\n reset(position = 0) {\n this._position = position > this._size ? this._size : position;\n }\n\n shrink(available: number): number {\n const rest = this._size - this._position;\n if (available > rest) {\n return rest;\n }\n this._size = this._position + available;\n return available;\n }\n\n next(count = 1): number {\n const rest = this._size - this._position;\n if (count > rest) {\n count = rest;\n }\n this._position += count;\n return count;\n }\n\n read8(): number {\n return this.next(1) === 1 ? this._view.getUint8(this._position - 1) : 0;\n }\n read16(): number {\n return this.next(2) === 2 ? this._view.getUint16(this._position - 2) : 0;\n }\n read24(): number {\n return this.next(3) === 3\n ? (this._view.getUint16(this._position - 3) << 8) | (this._view.getUint8(this._position - 1) & 0xff)\n : 0;\n }\n read32(): number {\n return this.next(4) === 4 ? this._view.getUint32(this._position - 4) : 0;\n }\n readFloat(): number {\n return this.next(4) === 4 ? this._view.getFloat32(this._position - 4) : 0;\n }\n readDouble(): number {\n return this.next(8) === 8 ? this._view.getFloat64(this._position - 8) : 0;\n }\n read7Bit(bytes = 5): number {\n if (bytes > 5) {\n throw Error(\"BinaryReader in JS can't decode more than 32 usefull bits\");\n }\n if (!(bytes > 0)) {\n // negation to catch NaN value\n throw Error('Have to indicate a positive number of bytes to decode');\n }\n let result = 0;\n let byte;\n do {\n byte = this.read8();\n if (!--bytes) {\n return ((result << 8) | byte) >>> 0; // Use all 8 bits from the 5th byte\n }\n result = (result << 7) | (byte & 0x7f);\n } while (byte & 0x80);\n return result;\n }\n readString(): string {\n return String.fromCharCode(...this.read(this.read7Bit()));\n }\n\n readHex(size: number): string {\n let hex = '';\n while (size--) {\n hex += ('0' + this.read8().toString(16)).slice(-2);\n }\n return hex;\n }\n\n /**\n * Read bytes, to convert bytes to string use String.fromCharCode(...reader.read(size))\n * @param {UInt32} size\n */\n read(size = this.available()): Uint8Array {\n if (this.available() < size) {\n return new Uint8Array(size); // default value = empty bytearray!\n }\n const value = this._data.subarray(this._position, this._position + size);\n this._position += size;\n return value;\n }\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/**\n * BinaryWriter allows to write data in its binary form\n */\nexport class BinaryWriter {\n get view(): DataView {\n if (!this._view) {\n this._view = new DataView(this._data.buffer, this._data.byteOffset, this._data.byteLength);\n }\n return this._view;\n }\n get capacity(): number {\n return this._data.byteLength;\n }\n\n private _data: Uint8Array;\n private _size: number;\n private _view?: DataView;\n private _isConst?: boolean;\n\n constructor(dataOrSize: BufferSource | number = 64, offset: number = 0, length?: number) {\n if (typeof dataOrSize == 'number') {\n // allocate new buffer\n this._data = new Uint8Array(dataOrSize);\n this._size = 0;\n } else if ('buffer' in dataOrSize) {\n // append to existing data!\n this._data = new Uint8Array(dataOrSize.buffer, dataOrSize.byteOffset, dataOrSize.byteLength);\n this._size = dataOrSize.byteLength;\n } else {\n // overrides data\n this._isConst = true; // better than boolean for memory usage\n if (length == null) {\n // /!\\ Safari does not support undefined length, so we need to use byteLength instead\n length = dataOrSize.byteLength;\n }\n this._data = new Uint8Array(dataOrSize, offset, length);\n this._size = 0;\n }\n }\n\n data(): Uint8Array {\n return new Uint8Array(this._data.buffer, this._data.byteOffset, this._size);\n }\n size(): number {\n return this._size || 0;\n }\n\n next(count = 1): BinaryWriter {\n return this.reserve((this._size += count));\n }\n clear(size = 0): BinaryWriter {\n return this.reserve((this._size = size));\n }\n\n write(data: string | ArrayLike<number>): BinaryWriter {\n this.reserve(this._size + data.length);\n if (typeof data === 'string') {\n // beware here support just the 255 first bytes (compatible Latin-1)\n for (let i = 0; i < data.length; ++i) {\n const value = data.charCodeAt(i);\n this._data[this._size++] = value > 255 ? 32 : value;\n }\n return this;\n }\n this._data.set(data, this._size);\n this._size += data.length;\n return this;\n }\n\n write8(value: number): BinaryWriter {\n if (value > 0xff) {\n // cast to 8bits range\n value = 0xff;\n }\n this.reserve(this._size + 1);\n this._data[this._size++] = value;\n return this;\n }\n\n write16(value: number): BinaryWriter {\n if (value > 0xffff) {\n // cast to 16bits range\n value = 0xffff;\n }\n this.reserve(this._size + 2);\n this.view.setUint16(this._size, value);\n this._size += 2;\n return this;\n }\n\n write24(value: number): BinaryWriter {\n if (value > 0xffffff) {\n // cast to 24bits range\n value = 0xffffff;\n }\n this.reserve(this._size + 3);\n this.view.setUint16(this._size, value >> 8);\n this.view.setUint8((this._size += 2), value & 0xff);\n ++this._size;\n return this;\n }\n write32(value: number): BinaryWriter {\n if (value > 0xffffffff) {\n // cast to 32bits range\n value = 0xffffffff;\n }\n this.reserve(this._size + 4);\n this.view.setUint32(this._size, value);\n this._size += 4;\n return this;\n }\n\n writeFloat(value: number): BinaryWriter {\n this.reserve(this._size + 4);\n this.view.setFloat32(this._size, value);\n this._size += 4;\n return this;\n }\n\n writeDouble(value: number): BinaryWriter {\n this.reserve(this._size + 8);\n this.view.setFloat64(this._size, value);\n this._size += 8;\n return this;\n }\n\n write7Bit(value: number, bytes: number = 5): BinaryWriter {\n if (bytes > 5) {\n throw Error(\"BinaryWriter in JS can't encode more than 32 usefull bits\");\n }\n if (!(bytes > 0)) {\n // negation to catch NaN value\n throw Error('Have to indicate a positive number of bytes to encode');\n }\n let bits = --bytes * 7;\n const front = value > 0xffffffff ? 0x100 : value >>> bits;\n if (front) {\n ++bits;\n if (front > 0xff) {\n value = 0xffffffff;\n }\n } else {\n while ((bits -= 7) && !(value >>> bits)) {\n continue;\n }\n }\n\n while (bits > 1) {\n this.write8(0x80 | ((value >>> bits) & 0xff));\n bits -= 7;\n }\n return this.write8(value & (bits ? 0xff : 0x7f));\n }\n\n writeString(value: string): BinaryWriter {\n return this.write7Bit(value.length).write(value);\n }\n\n writeHex(value: string): BinaryWriter {\n for (let i = 0; i < value.length; i += 2) {\n this.write8(parseInt(value.substring(i, i + 2), 16));\n }\n return this;\n }\n\n reserve(size: number): BinaryWriter {\n if (!this._data) {\n throw new Error('buffer not writable');\n }\n if (size <= this._data.byteLength) {\n return this;\n }\n if (this._isConst) {\n throw new Error('writing exceeds maximum ' + this._data.byteLength + ' bytes limit');\n }\n\n --size;\n size |= size >> 1;\n size |= size >> 2;\n size |= size >> 4;\n size |= size >> 8;\n size |= size >> 16;\n ++size;\n\n const data = new Uint8Array(size);\n data.set(this._data); // copy old buffer!\n this._data = data;\n this._view = undefined; // release view\n return this;\n }\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/**\n * BitReader allows to read binary data bit by bit\n */\nexport class BitReader {\n private _data: Uint8Array;\n private _size: number;\n private _position: number;\n private _bit: number;\n\n constructor(data: BufferSource) {\n if ('buffer' in data) {\n this._data = new Uint8Array(data.buffer, data.byteOffset, data.byteLength);\n } else {\n this._data = new Uint8Array(data);\n }\n this._size = this._data.byteLength;\n this._position = 0;\n this._bit = 0;\n }\n\n data(): Uint8Array {\n return this._data;\n }\n size(): number {\n return this._size;\n }\n available(): number {\n return (this._size - this._position) * 8 - this._bit;\n }\n\n next(count = 1): number {\n let gotten = 0;\n while (this._position !== this._size && count--) {\n ++gotten;\n if (++this._bit === 8) {\n this._bit = 0;\n ++this._position;\n }\n }\n return gotten;\n }\n read(count = 1): number {\n let result = 0;\n while (this._position !== this._size && count--) {\n result <<= 1;\n if (this._data[this._position] & (0x80 >> this._bit++)) {\n result |= 1;\n }\n if (this._bit === 8) {\n this._bit = 0;\n ++this._position;\n }\n }\n return result;\n }\n read8(): number {\n return this.read(8);\n }\n read16(): number {\n return this.read(16);\n }\n read24(): number {\n return this.read(24);\n }\n read32(): number {\n return this.read(32);\n }\n}\n\nexport function readExpGolomb(reader: BitReader): number {\n let i = 0;\n while (reader.available() && !reader.read()) {\n ++i;\n }\n const result = reader.read(i);\n if (i > 15) {\n console.warn('Exponential-Golomb code exceeding unsigned 16 bits');\n return 0;\n }\n return result + (1 << i) - 1;\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/**\n * Help class to manipulate and parse a net address. The Address can be only the domain field,\n * or a URL format with protocol and path part `(http://)domain(:port/path)`\n * @example\n * const address = new Address('nl-ams-42.live.ceeblue.tv:80');\n * console.log(address.domain) // 'nl-ams-42.live.ceeblue.tv'\n * console.log(address.port) // '80'\n * console.log(address) // 'nl-ams-42.live.ceeblue.tv:80'\n */\nexport class NetAddress {\n /**\n * Static help function to build an end point from an address `(proto://)domain(:port/path)`\n *\n * Mainly it fix the protocol, in addition if:\n * - the address passed is securized (TLS) and protocol is not => it tries to fix protocol to get its securize version\n * - the address passed is non securized and protocol is (TLS) => it tries to fix protocol to get its unsecurized version\n * @param protocol protocol to set in the end point returned\n * @param address string address to fix with protocol as indicated\n * @returns the end point built\n * @example\n * console.log(NetAddress.fixProtocol('ws','http://domain/path')) // 'ws://domain/path'\n * console.log(NetAddress.fixProtocol('ws','https://domain/path')) // 'wss://domain/path'\n * console.log(NetAddress.fixProtocol('wss','http://domain/path')) // 'ws://domain/path'\n */\n static fixProtocol(protocol: string, address: string): string {\n const found = address.indexOf('://');\n // isolate protocol is present in address\n if (found >= 0) {\n // In this case replace by protocol in keeping SSL like given in address\n if (found > 2 && address.charAt(found - 1).toLowerCase() === 's') {\n // SSL!\n if (protocol.length <= 2 || !protocol.endsWith('s')) {\n protocol += 's'; // Add SSL\n }\n } else {\n // Not SSL!\n if (protocol.length > 2 && protocol.endsWith('s')) {\n protocol = protocol.slice(0, -1); // Remove SSL\n }\n }\n // Build host!\n address = address.substring(found + 3);\n }\n return protocol + '://' + address;\n }\n\n /**\n * The domain part from address `(http://)domain(:port/path)`\n */\n get domain(): string {\n return this._domain;\n }\n /**\n * The port part from address `(http://)domain(:port/path)`, or defaultPort if passed in NetAddress constructor\n */\n get port(): number | undefined {\n return this._port;\n }\n /**\n * @returns the string address as passed in the constructor\n */\n toString(): string {\n return this._address;\n }\n /**\n * @returns the string address as passed in the constructor\n * @override\n */\n valueOf(): string {\n return this._address;\n }\n\n private _address: string;\n private _domain: string;\n private _port?: number;\n /**\n * Build a NetAddress object and parse address\n * @param address string address to parse, accept an url format with protocol and path `(http://)domain(:port/path)`\n * @param defaultPort set a default port to use if there is no port in the string address parsed\n */\n constructor(address: string, defaultPort?: number) {\n this._address = address;\n\n // Remove Protocol\n let pos = address.indexOf('/');\n if (pos >= 0) {\n // Remove ://\n if (address.charCodeAt(pos + 1) === 47) {\n // has //\n if (pos > 0) {\n if (address.charCodeAt(pos - 1) === 58) {\n // has ://\n address = address.substring(pos + 2);\n } // something else #//\n } else {\n // otherwise starts by //\n address = address.substring(2);\n }\n } else if (!pos) {\n // starts by /, remove it\n address = address.substring(1);\n } // else something else #/\n }\n\n this._domain = address;\n this._port = defaultPort;\n\n // Parse Port\n pos = address.lastIndexOf(':');\n if (pos >= 0) {\n const port = parseInt(address.substring(pos + 1));\n if (port && port <= 0xffff) {\n this._port = port;\n this._domain = address.substring(0, pos);\n }\n } else {\n // Remove Path!\n pos = address.indexOf('/');\n if (pos >= 0) {\n this._domain = address.substring(0, pos);\n }\n }\n }\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\nimport { NetAddress } from './NetAddress';\n\n/**\n * Parameters of connections\n */\nexport type Params = {\n /**\n * Host to connect. Can include port, and accept also an url format with port and path,\n * it can help to force a path OR try to give a protocol preference\n */\n host: string;\n /**\n * The name of the stream to join\n */\n streamName: string;\n /**\n * Optional access token to use to join a private stream\n */\n accessToken?: string;\n /**\n * iceServer to use while connecting to a WebRTC stream\n */\n iceServer?: RTCIceServer; // Authentication value\n /**\n * Optional query to add into the generated url of connection\n */\n query?: Record<string, string>;\n};\n\n/**\n * Type of connection\n */\nexport enum Type {\n HESP = 'hesp',\n WEBRTS = 'webrts',\n WEBRTC = 'webrtc',\n META = 'meta',\n DATA = 'data'\n}\n\n/**\n * Some connection utility functions\n */\n\n/**\n * Build an URL from {@link Type | type} and {@link Params | params}\n * @param type Type of the connection wanted\n * @param params Connection parameters\n * @param protocol Optional parameter to choose the prefered protocol to connect\n * @returns The URL of connection\n */\nexport function buildURL(type: Type, params: Params, protocol: string = 'wss'): URL {\n const url = new URL(NetAddress.fixProtocol(protocol, params.host));\n\n if (url.pathname.length <= 1) {\n // build ceeblue path!\n switch (type) {\n case Type.HESP:\n url.pathname = '/hesp/' + params.streamName + '/index.json';\n break;\n case Type.WEBRTC:\n url.pathname = '/webrtc/' + params.streamName;\n break;\n case Type.WEBRTS:\n url.pathname = '/webrts/' + params.streamName;\n break;\n case Type.META:\n url.pathname = '/json_' + params.streamName + '.js';\n break;\n case Type.DATA:\n url.pathname = '/' + params.streamName + '.json';\n break;\n default:\n console.warn('Unknown url type ' + type);\n break;\n }\n } // Host has already a path! keep it unchanged, it's user intentionnal (used with some other WHIP/WHEP server?)\n if (params.accessToken) {\n url.searchParams.set('id', params.accessToken);\n }\n\n for (const key in params.query) {\n url.searchParams.set(key, params.query[key]);\n }\n return url;\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/**\n * A advanced EventEmitter which allows to declare event as natural function in the inheriting children class,\n * function must start by `on` prefix to be recognized as an event.\n * The function can define a behavior by default, and user can choose to redefine this behavior,\n * or add an additionnal subscription for this event.\n * In addition you can unsubscribe to multiple events with an `AbortController`\n * @example\n * class Logger extends EventEmitter {\n * onLog(log:string) { console.log(log); } // behavior by default\n *\n * test() {\n * // raise event onLog\n * this.onLog('test');\n * }\n * }\n *\n * const logger = new Logger();\n * logger.test(); // displays a log 'test'\n *\n * // redefine default behavior to display nothing\n * logger.onLog = () => {}\n * logger.test(); // displays nothing\n *\n * // add an additionnal subscription\n * logger.on('log', console.log);\n * logger.test(); // displays a log 'test'\n *\n * // remove the additionnal subscription\n * logger.off('log', console.log);\n * logger.test(); // displays nothing\n *\n * // add two additionnal subscriptions with a AbortController\n * const controller = new AbortController();\n * logger.on('log', log => console.log(log), controller);\n * logger.on('log', log => console.error(log), controller);\n * logger.test(); // displays a log 'test' + an error 'test'\n *\n * // Unsubscribe all the subscription with the AbortController\n * controller.abort();\n * logger.test(); // displays nothing\n */\nexport class EventEmitter {\n private _events: Map<string, Set<Function>>;\n\n /**\n * Build our EventEmitter, usually call from children class\n */\n constructor() {\n this._events = new Map();\n // Fill events with events as defined!\n let proto = Object.getPrototypeOf(this);\n while (proto && proto !== Object.prototype) {\n for (const name of Object.getOwnPropertyNames(proto)) {\n if (name.length < 3 || !name.startsWith('on')) {\n continue;\n }\n if (proto[name] instanceof Function) {\n const events = new Set<Function>();\n this._events.set(name.substring(2).toLowerCase(), events);\n let defaultEvent = proto[name];\n Object.defineProperties(this, {\n [name]: {\n get:\n () =>\n (...args: unknown[]) => {\n // Call default event if not null (can happen in JS usage)\n if (defaultEvent) {\n defaultEvent.call(this, ...args);\n }\n // Call subscribers\n for (const event of events) {\n event(...args);\n }\n },\n set: (value: Function | undefined) => {\n // Assign a default behavior!\n defaultEvent = value;\n }\n }\n });\n }\n }\n proto = Object.getPrototypeOf(proto);\n }\n }\n\n /**\n * Event subscription\n * @param name Name of event without the `on` prefix (ex: `log` to `onLog` event declared)\n * @param event Subscriber Function\n * @param abort Optional `AbortController` to stop this or multiple subscriptions in same time\n */\n on(name: string, event: Function, abort?: AbortController) {\n if (!event) {\n throw Error('event to subscribe cannot be null');\n }\n const events = this._event(name);\n events.add(event);\n if (abort) {\n abort.signal.addEventListener('abort', () => {\n events.delete(event);\n });\n }\n }\n\n /**\n * Event subscription only one time, once time fired it's automatically unsubscribe\n * @param name Name of event without the `on` prefix (ex: `log` to `onLog` event declared)\n * @param event Subscriber Function\n * @param abort Optional `AbortController` to stop this or multiple subscriptions in same time\n */\n once(name: string, event: Function, abort?: AbortController) {\n if (!event) {\n throw Error('event to subscribe cannot be null');\n }\n const events = this._event(name);\n events.add(() => {\n events.delete(event); // delete from events\n event(); // execute event\n });\n if (abort) {\n abort.signal.addEventListener('abort', () => {\n events.delete(event);\n });\n }\n }\n\n /**\n * Event unsubscription\n * @param name Name of event without the 'on' prefix (ex: 'log' to 'onLog' event declared)\n * @param event Unsubscriber Function, must be the one passed to {@link on} or {@link once} subscription methods\n */\n off(name: string, event: Function) {\n if (!event) {\n throw Error('event to unsubscribe cannot be null');\n }\n this._event(name).delete(event);\n }\n\n private _event(name: string): Set<Function> {\n const events = this._events.get(name.toLowerCase());\n if (!events) {\n throw Error('No event on' + name + ' on class ' + this.constructor.name);\n }\n return events;\n }\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/**\n * Queue typed similar to a {@link https://en.cppreference.com/w/cpp/container/queue | std::queue<Type>} with possibility to limit the capacity like a FIFO\n * @example\n * const queue = new Queue<number>(2);\n * queue.push(1); // [1]\n * queue.push(2); // [1,2]\n * queue.push(3); // [2,3] 1 has been removed to respect 2 capacity\n */\nexport class Queue<Type> {\n /**\n * Number of element in the queue\n */\n get size(): number {\n return this._queue.length;\n }\n\n /**\n * Maximum capacity for the queue, if not set queue has unlimited capacity\n */\n get capacity(): number | undefined {\n return this._capacity;\n }\n\n /**\n * Set a maximum capacity for the queue,\n * if you push new value exceding this capacity the firsts are removed (FIFO)\n * if set to undefined the queue is unlimited\n */\n set capacity(value: number | undefined) {\n this._capacity = value;\n if (value != null && this._queue.length > value) {\n this._queue.splice(0, this._queue.length - value);\n }\n }\n\n /**\n * The front element\n */\n get front(): Type {\n return this._queue[0];\n }\n\n /**\n * The back element\n */\n get back(): Type {\n return this._queue[this._queue.length - 1];\n }\n\n /**\n * Iterator though queue's elements\n */\n [Symbol.iterator](): IterableIterator<Type> {\n return this._queue[Symbol.iterator]();\n }\n\n private _capacity?: number;\n private _queue: Array<Type>;\n /**\n * Instanciate a new queue object with the type passed as template\n * @param capacity if set it limits the size of the queue, any exceding element pops the first element pushed (FIFO)\n */\n constructor(capacity?: number) {\n this._capacity = capacity;\n this._queue = new Array<Type>();\n }\n\n /**\n * Push a new element in the queue\n * @param value value of the element\n * @returns this\n */\n push(value: Type): Queue<Type> {\n if (this._capacity != null && this._queue.push(value) > this._capacity) {\n this.pop();\n }\n return this;\n }\n\n /**\n * Pop the first element from the queue\n * @returns The first element removed\n */\n pop(): Type | undefined {\n return this._queue.shift();\n }\n\n /**\n * Clear all the elements, queue becomes empty\n * @returns this\n */\n clear(): Queue<Type> {\n this._queue.length = 0;\n return this;\n }\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\nimport { Queue } from './Queue';\n\n/**\n * A collection of number Queue<number> with the following efficient mathematic computation:\n * - minimum value in the collection\n * - maximum value in the collection\n * - average value of the collection\n */\nexport class Numbers extends Queue<number> {\n /**\n * minimum value in the collection, or 0 if colleciton is empty\n */\n get minimum(): number {\n return this._min;\n }\n\n /**\n * maximum value in the collection, or 0 if colleciton is empty\n */\n get maximum(): number {\n return this._max;\n }\n\n /**\n * average value of the collection, or 0 if collection if empty\n */\n get average(): number {\n if (this._average == null) {\n this._average = this.size ? this._sum / this.size : 0;\n }\n return this._average;\n }\n\n private _average?: number;\n private _sum: number = 0;\n private _min: number = 0;\n private _max: number = 0;\n /**\n * Instantiate the collection of the number\n * @param capacity if set it limits the number of values stored, any exceding number pops the first number pushed (FIFO)\n */\n constructor(capacity?: number) {\n super(capacity);\n }\n\n /**\n * Push a value to the back to the collection\n * @param value number to add\n * @returns this\n */\n push(value: number): Numbers {\n if (value > this._max) {\n this._max = value;\n } else if (value < this._min) {\n this._min = value;\n }\n this._average = undefined;\n this._sum += value;\n super.push(value);\n return this;\n }\n\n /**\n * Pop the front number from the collection\n * @returns the front number removed\n */\n pop(): number | undefined {\n const front = super.pop();\n if (front === this._max) {\n this._max = Math.max(0, ...this);\n } else if (front === this._min) {\n this._min = Math.min(0, ...this);\n }\n this._average = undefined;\n this._sum -= front || 0;\n return front;\n }\n\n /**\n * Clear all the numbers, collection becomes empty\n * @returns this\n */\n clear() {\n this._min = this._max = this._sum = 0;\n super.clear();\n return this;\n }\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n/**\n * Toolkit to deal with Session Description Protocol (SDP),\n * mainly to tranform a SDP string Offer/Answer to a manipulable JS object representation\n * @example\n * const peerConnection = new RTCPeerConnection();\n * peerConnection.createOffer()\n * .then( offer =>\n * // Change offer.sdp string to a JS manipulable object\n * const sdp = SDP.fromString(offer.sdp || '');\n * // Change a property of SDP\n * sdp.v = 2; // change SDP version\n * // Reserialize to the legal SDP string format\n * offer.sdp = SDP.toString(sdp);\n * // Set SDP offer to peerConnection\n * peerConnection.setLocalDescription(offer);\n * )\n */\nexport const SDP = {\n /**\n * Unserialize SDP string to a manipulable JS object representation\n * It's an object with:\n * - root SDP properties\n * - media description iterable\n * @param lines SDP string reprensentation\n * @returns SDP object representation, iterable through media description\n * @example\n * [\n * group: \"DUNBLE 0 1\",\n * o: \"- 1699450751193623 0 IN IP4 0.0.0.0\",\n * s: \"-\",\n * t: \"0 0\",\n * v: \"0\",\n * ice-lite: \"\",\n * length: 2,\n * {\n * m: \"audio 9 UDP/TLS/RTP/SAVPF 111\",\n * c: \"IN IP4 0.0.0.0\",\n * rtcp: \"9\",\n * sendonly: \"\",\n * setup: \"passive\",\n * fingerprint: \"sha-256 51:36:ED:78:A4:9F:25:8C:39:9A:0E:A0:B4:9B:6E:04:37:FF:AD:96:93:71:43:88:2C:0B:0F:AB:6F:9A:52:B8\",\n * ice-ufrag: \"fa37\",\n * ice-pwd: \"JncCHryDsbzayy4cBWDxS2\",\n * rtcp-mux: \"\",\n * rtcp-rsize: \"\",\n * rtpmap: \"111 opus/48000/2\",\n * rtcp-fb: \"111 nack\",\n * id: \"0\",\n * fmtp: \"111 minptime=10;useinbandfec=1\",\n * candidate: \"1 1 udp 2130706431 89.105.221.108 56643 typ host\",\n * end-of-candidates: \"\"\n * },\n * {\n * m: \"video 9 UDP/TLS/RTP/SAVPF 106\",\n * c: \"IN IP4 0.0.0.0\",\n * rtcp: \"9\",\n * sendonly: \"\",\n * setup: \"passive\",\n * fingerprint: \"sha-256 51:36:ED:78:A4:9F:25:8C:39:9A:0E:A0:B4:9B:6E:04:37:FF:AD:96:93:71:43:88:2C:0B:0F:AB:6F:9A:52:B8\",\n * ice-ufrag: \"fa37\",\n * ice-pwd: \"JncCHryDsbzayy4cBWDxS2\",\n * rtcp-mux: \"\",\n * rtcp-rsize: \"\",\n * rtpmap: \"106 H264/90000\",\n * rtcp-fb: [\n * \"106 nack\",\n * \"106 goog-remb\"\n * ],\n * mid: \"1\",\n * fmtp: \"106 profile-level-id=42e01f;level-asymmetry-allowed=1;packetization-mode=1\",\n * candidate: \"1 1 udp 2130706431 89.105.221.108 56643 typ host\",\n * end-of-candidates: \"\"\n * }\n * ]\n */\n fromString(lines: string): any {\n if (Array.isArray(lines)) {\n return lines; // already converted\n }\n const sdp = new Array<any>();\n let media: any = sdp;\n let fingerprint;\n for (let line of lines.toString().split('\\n')) {\n line = line.trim();\n if (!line) {\n continue;\n }\n\n let key = line[0];\n const value = line.substring(line.indexOf('=') + 1).trim();\n switch (key.toLowerCase()) {\n case 'a': {\n if (!value) {\n continue;\n } // empty attribute!\n key = this.addAttribute(media, value);\n // save fingerprint to repeat it in medias\n if (sdp === media && key.toLowerCase() === 'fingerprint') {\n fingerprint = media.fingerprint;\n }\n break;\n }\n case 'm':\n if (sdp.length && fingerprint && !sdp[sdp.length - 1].fingerprint) {\n media.fingerprint = fingerprint;\n }\n sdp.push((media = { m: value }));\n break;\n default:\n media[key] = value;\n }\n }\n if (sdp.length && fingerprint && !sdp[sdp.length - 1].fingerprint) {\n media.fingerprint = fingerprint;\n }\n return sdp;\n },\n\n /**\n * Serialize SDP JS object to a SDP string legal representation\n * @param sdp SDP object reprensetation\n * @returns SDP string reprensentation\n */\n toString(sdp: any): string {\n if (typeof sdp === 'string') {\n return sdp; // already converted\n }\n const medias = [];\n // https://www.cl.cam.ac.uk/~jac22/books/mm/book/node182.html\n let lines = 'v' in sdp ? 'v=' + sdp.v + '\\n' : '';\n if ('o' in sdp) {\n lines += 'o=' + sdp.o + '\\n';\n }\n if ('s' in sdp) {\n lines += 's=' + sdp.s + '\\n';\n }\n const obj: any = sdp;\n for (const key of Object.keys(sdp)) {\n if (key === 'v' || key === 'o' || key === 's') {\n continue;\n }\n const value = obj[key];\n if (value == null) {\n continue;\n } // ignore this key/value\n const index = parseInt(key);\n if (!isNaN(index)) {\n // Is a number! Media object!\n medias[index] = value;\n continue;\n }\n const count = (Array.isArray(value) && value.length) || 1; // value can be numeric!\n for (let i = 0; i < count; ++i) {\n const line = Array.isArray(value) && value.length ? value[i] : value;\n if (key.length > 1) {\n // when key is superior to 1 letter it's a attribute!\n lines += 'a=' + key;\n if (line) {\n lines += ':';\n }\n } else {\n lines += key + '=';\n }\n lines += line + '\\n';\n }\n }\n for (const media of medias) {\n lines += this.toString(media);\n }\n return lines;\n },\n\n /**\n * While set a property to a SDP object representation is possible directly,\n * we could prefer add a new property without overload a possible already existing value.\n * This function allows to add a property to our SDP representation:\n * - if the key's attribute doesn't exists yet it adds it like a simple JS property sdp[key] = value\n * - if the key's attribute exists already it morphs the value to a Array and push it inside\n * @param sdp the SDP object representation on which added the attribute\n * @param attribute the string attribut in a format \"key:value\" or just \"key\" to add an attribute without value\n * @returns the key part of the attribute added (or if value is empty it returns the same attribute as passed in argument)\n */\n addAttribute(sdp: object, attribute: string): string {\n const a = SDP.parseAttribute(attribute);\n const value = a.value ?? ''; // to allow to test if key exists even without value with if(sdp.key != null)\n const obj: any = sdp;\n const oldValue = obj[a.key];\n if (!oldValue) {\n obj[a.key] = value;\n } else if (Array.isArray(oldValue)) {\n oldValue.push(value);\n } else if (value !== oldValue) {\n obj[a.key] = [oldValue, value];\n }\n return a.key;\n },\n\n /**\n * While it's possible to delete a attribute manually on the SDP object representation with a delete sdp.key,\n * we could prefer remove only a value in a sdp.key array containing multiple values.\n * Like opposite to addAttribute this method allows to remove an unique attribute value.\n * @param sdp the SDP object representation on which removed the attribute\n * @param attribute the string attribut in a format \"key:value\" or just \"key\" to remove the whole attribute and all its values\n * @returns the key part of the attribute removed (or if value is empty it returns the same attribute as passed in argument)\n */\n removeAttribute(sdp: object, attribute: string): string {\n const a = SDP.parseAttribute(attribute);\n const obj: any = sdp;\n if (a.value === undefined) {\n delete obj[attribute];\n return attribute;\n }\n const current = obj[attribute];\n if (Array.isArray(a.value)) {\n const i = current.findIndex((current: string) => current === a.value);\n if (i >= 0) {\n current.splice(i, 1);\n }\n } else if (current === a.value) {\n delete obj[attribute];\n }\n return a.key;\n },\n\n /**\n * Parse an attribute in a format \"key:value\"\n * @param attribute string attribute to parse\n * @returns the {key, value} result, with value undefined if attribute was a \"key\" without value\n */\n parseAttribute(attribute: string): { key: string; value: string | undefined } {\n const found = attribute.indexOf(':');\n return {\n key: (found >= 0 ? attribute.substring(0, found) : attribute).trim(),\n value: found >= 0 ? attribute.substring(found + 1).trim() : undefined\n };\n }\n};\nObject.freeze(SDP);\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\nconst _decoder = new TextDecoder();\nconst _encoder = new TextEncoder();\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nconst _perf = performance; // to increase x10 now performance!\n\n/**\n * Some basic utility functions\n */\n\n/**\n * An empty lambda function, pratical to disable default behavior of function or events which are not expected to be null\n * @example\n * console.log = Util.EMPTY_FUNCTION; // disable logs without breaking calls\n */\nexport const EMPTY_FUNCTION = () => {};\n\n/**\n * Efficient and high resolution timestamp in milliseconds elapsed since {@link Util.timeOrigin}\n */\nexport function time(): number {\n return Math.floor(_perf.now());\n}\n\n/**\n * Time origin represents the time when the application has started\n */\nexport function timeOrigin(): number {\n return Math.floor(_perf.now() + _perf.timeOrigin);\n}\n\n/**\n * Parse query and returns it in an easy-to-use Javascript object form\n * @param urlOrQueryOrSearch string, url, or searchParams containing query. If not set it uses `location.search` to determinate query.\n * @returns An javascript object containing each option\n */\nexport function options(\n urlOrQueryOrSearch: URL | URLSearchParams | string | object | undefined = typeof location === 'undefined'\n ? undefined\n : location\n): object {\n if (!urlOrQueryOrSearch) {\n return {};\n }\n try {\n const url: any = urlOrQueryOrSearch;\n urlOrQueryOrSearch = new URL(url).searchParams;\n } catch (e) {\n if (typeof urlOrQueryOrSearch == 'string') {\n if (urlOrQueryOrSearch.startsWith('?')) {\n urlOrQueryOrSearch = urlOrQueryOrSearch.substring(1);\n }\n urlOrQueryOrSearch = new URLSearchParams(urlOrQueryOrSearch);\n }\n }\n // works same if urlOrQueryOrSearch is null, integer, or a already object etc...\n return objectFrom(urlOrQueryOrSearch, { withType: true, noEmptyString: true });\n}\n\n/**\n * Returns an easy-to-use Javascript object something iterable, such as a Map, Set, or Array\n * @param value iterable input\n * @param params.withType `false`, if set it tries to cast string value to a JS number/boolean/undefined/null type.\n * @param params.noEmptyString `false`, if set it converts empty string value to a true boolean, usefull to allow a `if(result.key)` check for example\n * @returns An javascript object\n */\nexport function objectFrom(value: any, params: { withType: boolean; noEmptyString: boolean }): object {\n params = Object.assign({ withType: false, noEmptyString: false }, params);\n const obj: any = {};\n if (!value) {\n return obj;\n }\n for (const [key, val] of objectEntries(value)) {\n value = val;\n if (params.withType && value != null && value.substring) {\n if (value) {\n const number = Number(value);\n if (isNaN(number)) {\n switch (value.toLowerCase()) {\n case 'true':\n value = true;\n break;\n case 'false':\n value = false;\n break;\n case 'null':\n value = null;\n break;\n case 'undefined':\n value = undefined;\n break;\n }\n } else {\n value = number;\n }\n } else if (params.noEmptyString) {\n // if empty string => TRUE to allow a if(options.key) check for example\n value = true;\n }\n }\n if (obj[key]) {\n if (!Array.isArray(obj[key])) {\n obj[key] = new Array(obj[key]);\n }\n obj[key].push(value);\n } else {\n obj[key] = value;\n }\n }\n return obj;\n}\n\n/**\n * Returns entries from something iterable, such as a Map, Set, or Array\n * @param value iterable input\n * @returns An javascript object\n */\nexport function objectEntries(value: any): [string, any][] {\n if (value.entries) {\n return value.entries();\n }\n return Array.from({\n [Symbol.iterator]: function* () {\n for (const key in value) {\n yield [key, value[key]];\n }\n }\n });\n}\n\n/**\n * Converts various data types, such as objects, strings, exceptions, errors,\n * or numbers, into a string representation. Since it offers a more comprehensive format,\n * this function is preferred to `JSON.stringify()`.\n * @param obj Any objects, strings, exceptions, errors, or number\n * @param params.space `''`, allows to configure space in the string representation\n * @param params.decimal `2`, allows to choose the number of decimal to display in the string representation\n * @param params.recursive `false`, allows to serialize recursively every object value, beware if a value refers to a already parsed value an infinite loop will occur.\n * @returns the final string representation\n */\n// Online Javascript Editor for free\n// Write, Edit and Run your Javascript code using JS Online Compiler\nexport function stringify(obj: any, params: { space?: string; decimal?: number; recursive?: number } = {}): string {\n params = Object.assign({ space: ' ', decimal: 2, recursive: 1 }, params);\n if (obj == null) {\n return String(obj);\n }\n const error = obj.error || obj.message;\n if (error) {\n // is a error!\n obj = error;\n }\n if (obj.toFixed) {\n return obj.toFixed(Number(params.decimal) || 0);\n }\n if (obj.substring || !params.recursive) {\n // is already a string OR has to be stringified\n return String(obj);\n }\n\n const space = params.space || '';\n\n if (Array.isArray(obj)) {\n // Array!\n let res = '';\n for (const value of obj) {\n res += (res ? ',' : '[') + space;\n res += stringify(value, Object.assign(params, { recursive: params.recursive - 1 }));\n }\n return (res += space + ']');\n }\n if (obj.byteLength != null && obj?.[Symbol.iterator]) {\n // Binary!\n return _decoder.decode(obj);\n }\n let res = '';\n for (const name in obj) {\n res += (res ? ',' : '{') + space + name + ':';\n res += stringify(obj[name], Object.assign(params, { recursive: params.recursive - 1 }));\n }\n return (res += space + '}');\n}\n\n/**\n * Encode a string to a binary representation\n * @param value string value to convert\n * @returns binary conversion\n */\nexport function toBin(value: string): Uint8Array {\n return _encoder.encode(value);\n}\n\n/**\n * Execute a promise in a safe way with a timeout if caller doesn't resolve it in the accurate time\n */\nexport function safePromise<T>(timeout: number, promise: Promise<T>) {\n // Returns a race between our timeout and the passed in promise\n let timer: NodeJS.Timeout;\n return Promise.race([\n promise instanceof Promise ? promise : new Promise(promise),\n new Promise((resolve, reject) => (timer = setTimeout(() => reject('timed out in ' + timeout + 'ms'), timeout)))\n ]).finally(() => clearTimeout(timer));\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\nimport { EventEmitter } from './EventEmitter';\n\n/**\n * The WebSocketReliable class extends WebSocket to bring up the following improvements:\n * - Fix all possible unintentional closing ways to get always a related error message, {@link onClose | onClose(error?) event}\n * - Make possible message sending while connecting. Indeed no need to wait {@link onOpen} before to send message,\n * you can open the socket and immediately send messages, it will be queue and flushs on connection etablishment\n * - Make possible a delayed connection, or a reconnection. Indeed you can create an unconnected Websocket instance\n * without passing any url argument and starts the conneciton more later with {@link WebSocketReliable.open(url) | open(url)} method\n * - Make possible to control sending/queueing message: send method take an optional queueing=true argument to\n * queue message rather send it, a futur call to flush will send it. Then queueing getter allows to handle the queue\n * if need to purge it or remove some queued message. Use it all together can help to prioritize messages or control overload.\n * @example\n * const ws = new WebSocketReliable(url);\n * ws.onClose = (error?:string) => {\n * if(error) {\n * console.error(error);\n * }\n * // reconnection attempt every seconds\n * setTimeout(() => ws.open(url), 1000);\n * }\n * ws.onMessage = (message:string) => {\n * console.log(message);\n * }\n * ws.send('hello'); // send immediatly a hello message is possible (no need to wait onOpen)\n */\nexport class WebSocketReliable extends EventEmitter {\n /**\n * @event `open` fired when socket is connected\n */\n onOpen() {}\n\n /**\n * @event `message` fired on message reception\n * @param message can be binary or string.\n * If you subscribe to the event with message as string type (and not union),\n * it means that you know that all your messages are distributed in a string format\n */\n onMessage(message: ArrayBuffer | string) {}\n\n /**\n * @event `close` fired on websocket close\n * @param error error description on an improper closure\n */\n onClose(error?: string) {\n if (error) {\n console.error(error);\n }\n }\n\n /**\n * binaryType, fix binary type to arrayBuffer\n */\n get binaryType(): BinaryType {\n return 'arraybuffer';\n }\n\n /**\n * url of connection\n */\n get url(): string {\n return this._ws?.url ?? '';\n }\n\n /**\n * extensions negociated by the server\n */\n get extensions(): string {\n return this._ws?.extensions ?? '';\n }\n\n /**\n * protocol negociated by the server\n */\n get protocol(): string {\n return this._ws?.protocol ?? '';\n }\n\n /**\n * opened equals true when connection is etablished, in other word when onOpen event is fired\n */\n get opened(): boolean {\n return this._opened;\n }\n\n /**\n * {@link https://developer.mozilla.org/docs/Web/API/WebSocket/readyState | Official websocket readyState}\n */\n get readyState(): number {\n return this._ws ? this._ws.readyState : 3;\n }\n\n /**\n * True when connection is closed, in other words when {@link onClose} event is fired\n * or when WebSocketReliable is build without url (disconnected creation)\n */\n get closed(): boolean {\n return this._closed;\n }\n\n /**\n * The number of bytes of data that were queued during calls to send() but not yet transmitted to the network\n */\n get bufferedAmount(): number {\n return this._queueingBytes + (this._ws?.bufferedAmount || 0);\n }\n\n /**\n * Queued messages from a call to send() waiting to be transmit one time websocket connection opened (or with an explicit call to flush() method)\n */\n get queueing(): Array<string | ArrayBuffer | ArrayBufferView> {\n return this._queueing;\n }\n\n private _opened: boolean;\n private _closed: boolean;\n private _queueing: Array<string | ArrayBuffer | ArrayBufferView>;\n private _queueingBytes: number;\n private _ws?: WebSocket;\n /**\n * Create a WebSocketReliable object, and open it if an url is passed in argument\n * @param url URL of the WebSocket endpoint or null to start the connection later\n */\n constructor(url?: string | URL, protocols?: string | string[]) {\n super();\n this._queueing = [];\n this._queueingBytes = 0;\n this._opened = false;\n this._closed = true;\n if (url) {\n this.open(url, protocols);\n }\n }\n\n /**\n * Open a WebSocket connection\n * @param url url of the websocket endpoint\n * @returns this\n */\n open(url: URL | string, protocols?: string | string[]) {\n this._closed = false;\n const ws = (this._ws = new WebSocket(url, protocols));\n ws.binaryType = this.binaryType;\n ws.onmessage = e => this.onMessage(e.data);\n // Add details and fix close ways\n ws.onclose = (e: CloseEvent) => {\n if (!this._opened) {\n // close during connection\n this.close(url.toString() + ' connection failed (' + String(e.reason || e.code) + ')');\n } else if (e.code === 1000 || e.code === 1005) {\n // normal disconnection from server (no error code)\n this.close(url.toString() + ' shutdown');\n } else {\n // disconnection from server\n this.close(url.toString() + ' disconnection (' + String(e.reason || e.code) + ')');\n }\n };\n // Wrap send method to queue messages until connection is established.\n ws.onopen = _ => {\n this._opened = true;\n this.flush();\n this.onOpen();\n };\n return this;\n }\n\n /**\n * Send a message\n * @param message\n * @param queueing When set it reports the sending to a more later call to flush\n * @returns this\n */\n send(message: string | ArrayBuffer | ArrayBufferView, queueing: boolean = false) {\n if (!this._ws) {\n throw Error('Open socket before to send data');\n }\n if (queueing || !this._opened) {\n this._queueing.push(message);\n this._queueingBytes += typeof message === 'string' ? message.length : message.byteLength;\n } else {\n this._ws.send(message);\n }\n return this;\n }\n\n /**\n * Send queueing messages\n */\n flush() {\n if (this._ws) {\n for (const message of this._queueing) {\n this._ws.send(message);\n }\n }\n this._queueing.length = 0;\n this._queueingBytes = 0;\n }\n\n /**\n * Close websocket\n * @param error the error reason if is not a proper close\n */\n close(error?: string) {\n if (!this._ws || this._closed) {\n return;\n }\n this._closed = true;\n this._ws.onopen = this._ws.onclose = this._ws.onmessage = null; // otherwise can receive message AFTER close!\n this._ws.close(); // Don't set to undefined to keep this._ws properties valid!\n // release resources!\n this._opened = false;\n this._queueing.length = 0;\n this._queueingBytes = 0;\n this.onClose(error);\n }\n}\n","/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n\nexport { BinaryReader } from './src/BinaryReader';\nexport { BinaryWriter } from './src/BinaryWriter';\nexport { BitReader } from './src/BitReader';\nexport * as Connect from './src/Connect';\nexport { EventEmitter } from './src/EventEmitter';\nexport { ILog } from './src/ILog';\nexport { NetAddress } from './src/NetAddress';\nexport { Numbers } from './src/Numbers';\nexport { Queue } from './src//Queue';\nexport { SDP } from './src/SDP';\nexport * as Util from './src/Util';\nexport { WebSocketReliable } from './src/WebSocketReliable';\n\nconst __lib__version__ = '?'; // will be replaced on building by project version\n\nexport const VERSION: string = __lib__version__;\n"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- class t{constructor(t){this._data="buffer"in t?new Uint8Array(t.buffer,t.byteOffset,t.byteLength):new Uint8Array(t),this._size=this._data.byteLength,this._position=0,this._view=new DataView(this._data.buffer,this._data.byteOffset,this._size)}data(){return this._data}size(){return this._size}available(){return this._size-this._position}value(t=this._position){return this._data[t]}position(){return this._position}reset(t=0){this._position=t>this._size?this._size:t}shrink(t){const e=this._size-this._position;return t>e?e:(this._size=this._position+t,t)}next(t=1){const e=this._size-this._position;return t>e&&(t=e),this._position+=t,t}read8(){return 1===this.next(1)?this._view.getUint8(this._position-1):0}read16(){return 2===this.next(2)?this._view.getUint16(this._position-2):0}read24(){return 3===this.next(3)?this._view.getUint16(this._position-3)<<8|255&this._view.getUint8(this._position-1):0}read32(){return 4===this.next(4)?this._view.getUint32(this._position-4):0}readFloat(){return 4===this.next(4)?this._view.getFloat32(this._position-4):0}readDouble(){return 8===this.next(8)?this._view.getFloat64(this._position-8):0}read7Bit(t=5){if(t>5)throw Error("BinaryReader in JS can't decode more than 32 usefull bits");if(!(t>0))throw Error("Have to indicate a positive number of bytes to decode");let e,i=0;do{if(e=this.read8(),! --t)return(i<<8|e)>>>0;i=i<<7|127&e}while(128&e);return i}readString(){return String.fromCharCode(...this.read(this.read7Bit()))}readHex(t){let e="";for(;t--;)e+=("0"+this.read8().toString(16)).slice(-2);return e}read(t=this.available()){if(this.available()<t)return new Uint8Array(t);const e=this._data.subarray(this._position,this._position+t);return this._position+=t,e}}class e{get view(){return this._view||(this._view=new DataView(this._data.buffer,this._data.byteOffset,this._data.byteLength)),this._view}get capacity(){return this._data.byteLength}constructor(t=64,e=0,i){"number"==typeof t?(this._data=new Uint8Array(t),this._size=0):"buffer"in t?(this._data=new Uint8Array(t.buffer,t.byteOffset,t.byteLength),this._size=t.byteLength):(this._isConst=!0,null==i&&(i=t.byteLength),this._data=new Uint8Array(t,e,i),this._size=0)}data(){return new Uint8Array(this._data.buffer,this._data.byteOffset,this._size)}size(){return this._size||0}next(t=1){return this.reserve(this._size+=t)}clear(t=0){return this.reserve(this._size=t)}write(t){if(this.reserve(this._size+t.length),"string"==typeof t){for(let e=0;e<t.length;++e){const i=t.charCodeAt(e);this._data[this._size++]=i>255?32:i}return this}return this._data.set(t,this._size),this._size+=t.length,this}write8(t){return t>255&&(t=255),this.reserve(this._size+1),this._data[this._size++]=t,this}write16(t){return t>65535&&(t=65535),this.reserve(this._size+2),this.view.setUint16(this._size,t),this._size+=2,this}write24(t){return t>16777215&&(t=16777215),this.reserve(this._size+3),this.view.setUint16(this._size,t>>8),this.view.setUint8(this._size+=2,255&t),++this._size,this}write32(t){return t>4294967295&&(t=4294967295),this.reserve(this._size+4),this.view.setUint32(this._size,t),this._size+=4,this}writeFloat(t){return this.reserve(this._size+4),this.view.setFloat32(this._size,t),this._size+=4,this}writeDouble(t){return this.reserve(this._size+8),this.view.setFloat64(this._size,t),this._size+=8,this}write7Bit(t,e=5){if(e>5)throw Error("BinaryWriter in JS can't encode more than 32 usefull bits");if(!(e>0))throw Error("Have to indicate a positive number of bytes to encode");let i=7*--e;const s=t>4294967295?256:t>>>i;if(s)++i,s>255&&(t=4294967295);else for(;(i-=7)&&!(t>>>i););for(;i>1;)this.write8(128|t>>>i&255),i-=7;return this.write8(t&(i?255:127))}writeString(t){return this.write7Bit(t.length).write(t)}writeHex(t){for(let e=0;e<t.length;e+=2)this.write8(parseInt(t.substring(e,e+2),16));return this}reserve(t){if(!this._data)throw new Error("buffer not writable");if(t<=this._data.byteLength)return this;if(this._isConst)throw new Error("writing exceeds maximum "+this._data.byteLength+" bytes limit");--t,t|=t>>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,++t;const e=new Uint8Array(t);return e.set(this._data),this._data=e,this._view=void 0,this}}class i{constructor(t){this._data="buffer"in t?new Uint8Array(t.buffer,t.byteOffset,t.byteLength):new Uint8Array(t),this._size=this._data.byteLength,this._position=0,this._bit=0}data(){return this._data}size(){return this._size}available(){return 8*(this._size-this._position)-this._bit}next(t=1){let e=0;for(;this._position!==this._size&&t--;)++e,8==++this._bit&&(this._bit=0,++this._position);return e}read(t=1){let e=0;for(;this._position!==this._size&&t--;)e<<=1,this._data[this._position]&128>>this._bit++&&(e|=1),8===this._bit&&(this._bit=0,++this._position);return e}read8(){return this.read(8)}read16(){return this.read(16)}read24(){return this.read(24)}read32(){return this.read(32)}}class s{static fixProtocol(t,e){const i=e.indexOf("://");return i>=0&&(i>2&&"s"===e.charAt(i-1).toLowerCase()?(t.length<=2||!t.endsWith("s"))&&(t+="s"):t.length>2&&t.endsWith("s")&&(t=t.slice(0,-1)),e=e.substring(i+3)),t+"://"+e}get domain(){return this._domain}get port(){return this._port}toString(){return this._address}valueOf(){return this._address}constructor(t,e){this._address=t;let i=t.indexOf("/");if(i>=0&&(47===t.charCodeAt(i+1)?i>0?58===t.charCodeAt(i-1)&&(t=t.substring(i+2)):t=t.substring(2):i||(t=t.substring(1))),this._domain=t,this._port=e,i=t.lastIndexOf(":"),i>=0){const e=parseInt(t.substring(i+1));e&&e<=65535&&(this._port=e,this._domain=t.substring(0,i))}else i=t.indexOf("/"),i>=0&&(this._domain=t.substring(0,i))}}var r;!function(t){t.HESP="hesp",t.WEBRTS="webrts",t.WEBRTC="webrtc",t.META="meta",t.DATA="data"}(r||(r={}));var n=Object.freeze({__proto__:null,get Type(){return r},buildURL:function(t,e,i="wss"){const n=new URL(s.fixProtocol(i,e.host));if(n.pathname.length<=1)switch(t){case r.HESP:n.pathname="/hesp/"+e.streamName+"/index.json";break;case r.WEBRTC:n.pathname="/webrtc/"+e.streamName;break;case r.WEBRTS:n.pathname="/webrts/"+e.streamName;break;case r.META:n.pathname="/json_"+e.streamName+".js";break;case r.DATA:n.pathname="/"+e.streamName+".json";break;default:console.warn("Unknown url type "+t)}e.accessToken&&n.searchParams.set("id",e.accessToken);for(const t in e.query)n.searchParams.set(t,e.query[t]);return n}});class o{constructor(){this._events=new Map;let t=Object.getPrototypeOf(this);for(;t&&t!==Object.prototype;){for(const e of Object.getOwnPropertyNames(t))if(!(e.length<3)&&e.startsWith("on")&&t[e]instanceof Function){const i=new Set;this._events.set(e.substring(2).toLowerCase(),i);let s=t[e];Object.defineProperties(this,{[e]:{get:()=>(...t)=>{s&&s.call(this,...t);for(const e of i)e(...t)},set:t=>{s=t}}})}t=Object.getPrototypeOf(t)}}on(t,e,i){if(!e)throw Error("event to subscribe cannot be null");const s=this._event(t);s.add(e),i&&i.signal.addEventListener("abort",(()=>{s.delete(e)}))}once(t,e,i){if(!e)throw Error("event to subscribe cannot be null");const s=this._event(t);s.add((()=>{s.delete(e),e()})),i&&i.signal.addEventListener("abort",(()=>{s.delete(e)}))}off(t,e){if(!e)throw Error("event to unsubscribe cannot be null");this._event(t).delete(e)}_event(t){const e=this._events.get(t.toLowerCase());if(!e)throw Error("No event on"+t+" on class "+this.constructor.name);return e}}class h{get size(){return this._queue.length}get capacity(){return this._capacity}set capacity(t){this._capacity=t,null!=t&&this._queue.length>t&&this._queue.splice(0,this._queue.length-t)}get front(){return this._queue[0]}get back(){return this._queue[this._queue.length-1]}[Symbol.iterator](){return this._queue[Symbol.iterator]()}constructor(t){this._capacity=t,this._queue=new Array}push(t){return null!=this._capacity&&this._queue.push(t)>this._capacity&&this.pop(),this}pop(){return this._queue.shift()}clear(){return this._queue.length=0,this}}class a extends h{get minimum(){return this._min}get maximum(){return this._max}get average(){return null==this._average&&(this._average=this.size?this._sum/this.size:0),this._average}constructor(t){super(t),this._sum=0,this._min=0,this._max=0}push(t){return t>this._max?this._max=t:t<this._min&&(this._min=t),this._average=void 0,this._sum+=t,super.push(t),this}pop(){const t=super.pop();return t===this._max?this._max=Math.max(0,...this):t===this._min&&(this._min=Math.min(0,...this)),this._average=void 0,this._sum-=t||0,t}clear(){return this._min=this._max=this._sum=0,super.clear(),this}}const u={fromString(t){if(Array.isArray(t))return t;const e=new Array;let i,s=e;for(let r of t.toString().split("\n")){if(r=r.trim(),!r)continue;let t=r[0];const n=r.substring(r.indexOf("=")+1).trim();switch(t.toLowerCase()){case"a":if(!n)continue;t=this.addAttribute(s,n),e===s&&"fingerprint"===t.toLowerCase()&&(i=s.fingerprint);break;case"m":e.length&&i&&!e[e.length-1].fingerprint&&(s.fingerprint=i),e.push(s={m:n});break;default:s[t]=n}}return e.length&&i&&!e[e.length-1].fingerprint&&(s.fingerprint=i),e},toString(t){if("string"==typeof t)return t;const e=[];let i="v"in t?"v="+t.v+"\n":"";"o"in t&&(i+="o="+t.o+"\n"),"s"in t&&(i+="s="+t.s+"\n");const s=t;for(const r of Object.keys(t)){if("v"===r||"o"===r||"s"===r)continue;const t=s[r];if(null==t)continue;const n=parseInt(r);if(!isNaN(n)){e[n]=t;continue}const o=Array.isArray(t)&&t.length||1;for(let e=0;e<o;++e){const s=Array.isArray(t)&&t.length?t[e]:t;r.length>1?(i+="a="+r,s&&(i+=":")):i+=r+"=",i+=s+"\n"}}for(const t of e)i+=this.toString(t);return i},addAttribute(t,e){var i;const s=u.parseAttribute(e),r=null!==(i=s.value)&&void 0!==i?i:"",n=t,o=n[s.key];return o?Array.isArray(o)?o.push(r):r!==o&&(n[s.key]=[o,r]):n[s.key]=r,s.key},removeAttribute(t,e){const i=u.parseAttribute(e),s=t;if(void 0===i.value)return delete s[e],e;const r=s[e];if(Array.isArray(i.value)){const t=r.findIndex((t=>t===i.value));t>=0&&r.splice(t,1)}else r===i.value&&delete s[e];return i.key},parseAttribute(t){const e=t.indexOf(":");return{key:(e>=0?t.substring(0,e):t).trim(),value:e>=0?t.substring(e+1).trim():void 0}}};Object.freeze(u);const _=new TextDecoder,c=new TextEncoder,l=performance;function d(t,e){e=Object.assign({withType:!1,noEmptyString:!1},e);const i={};if(!t)return i;for(const[s,r]of f(t)){if(t=r,e.withType&&null!=t&&t.substring)if(t){const e=Number(t);if(isNaN(e))switch(t.toLowerCase()){case"true":t=!0;break;case"false":t=!1;break;case"null":t=null;break;case"undefined":t=void 0}else t=e}else e.noEmptyString&&(t=!0);i[s]?(Array.isArray(i[s])||(i[s]=new Array(i[s])),i[s].push(t)):i[s]=t}return i}function f(t){return t.entries?t.entries():Array.from({[Symbol.iterator]:function*(){for(const e in t)yield[e,t[e]]}})}var g=Object.freeze({__proto__:null,EMPTY_FUNCTION:()=>{},VERSION:"1.0.1",objectEntries:f,objectFrom:d,options:function(t=("undefined"==typeof location?void 0:location)){if(!t)return{};try{t=new URL(t).searchParams}catch(e){"string"==typeof t&&(t.startsWith("?")&&(t=t.substring(1)),t=new URLSearchParams(t))}return d(t,{withType:!0,noEmptyString:!0})},stringify:function t(e,i={}){if(i=Object.assign({space:" ",decimal:2,recursive:1},i),!e)return String(e);const s=e.error||e.message;if(s&&(e=s),e.toFixed)return e.toFixed(Number(i.decimal)||0);if(e.substring||!i.recursive)return String(e);const r=i.space||"";if(Array.isArray(e)){let s="";for(const n of e)s+=(s?",":"[")+r,s+=t(n,Object.assign(i,{recursive:i.recursive-1}));return s+=r+"]"}if(null!=e.byteLength&&(null==e?void 0:e[Symbol.iterator]))return _.decode(e);let n="";for(const s in e)n+=(n?",":"{")+r+s+":",n+=t(e[s],Object.assign(i,{recursive:i.recursive-1}));return n+(r+"}")},time:function(){return Math.floor(l.now())},timeOrigin:function(){return Math.floor(l.now()+l.timeOrigin)},toBin:function(t){return c.encode(t)}});class p extends o{onOpen(){}onMessage(t){}onClose(t){t&&console.error(t)}get binaryType(){return"arraybuffer"}get url(){var t,e;return null!==(e=null===(t=this._ws)||void 0===t?void 0:t.url)&&void 0!==e?e:""}get extensions(){var t,e;return null!==(e=null===(t=this._ws)||void 0===t?void 0:t.extensions)&&void 0!==e?e:""}get protocol(){var t,e;return null!==(e=null===(t=this._ws)||void 0===t?void 0:t.protocol)&&void 0!==e?e:""}get opened(){return this._opened}get readyState(){return this._ws?this._ws.readyState:3}get closed(){return this._closed}get bufferedAmount(){var t;return this._queueingBytes+((null===(t=this._ws)||void 0===t?void 0:t.bufferedAmount)||0)}get queueing(){return this._queueing}constructor(t,e){super(),this._queueing=[],this._queueingBytes=0,this._opened=!1,this._closed=!0,t&&this.open(t,e)}open(t,e){this._closed=!1;const i=this._ws=new WebSocket(t,e);return i.binaryType=this.binaryType,i.onmessage=t=>this.onMessage(t.data),i.onclose=e=>{this._opened?1e3===e.code||1005===e.code?this.close(t.toString()+" shutdown"):this.close(t.toString()+" disconnection ("+String(e.reason||e.code)+")"):this.close(t.toString()+" connection failed ("+String(e.reason||e.code)+")")},i.onopen=t=>{this._opened=!0,this.flush(),this.onOpen()},this}send(t,e=!1){if(!this._ws)throw Error("Open socket before to send data");return e||!this._opened?(this._queueing.push(t),this._queueingBytes+="string"==typeof t?t.length:t.byteLength):this._ws.send(t),this}flush(){if(this._ws)for(const t of this._queueing)this._ws.send(t);this._queueing.length=0,this._queueingBytes=0}close(t){this._ws&&!this._closed&&(this._closed=!0,this._ws.onopen=this._ws.onclose=this._ws.onmessage=null,this._ws.close(),this._opened=!1,this._queueing.length=0,this._queueingBytes=0,this.onClose(t))}}export{t as BinaryReader,e as BinaryWriter,i as BitReader,n as Connect,o as EventEmitter,s as NetAddress,a as Numbers,h as Queue,u as SDP,g as Util,p as WebSocketReliable};//# sourceMappingURL=web-utils.min.js.map
1
+ class t{constructor(t){this._data="buffer"in t?new Uint8Array(t.buffer,t.byteOffset,t.byteLength):new Uint8Array(t),this._size=this._data.byteLength,this._position=0,this._view=new DataView(this._data.buffer,this._data.byteOffset,this._size)}data(){return this._data}size(){return this._size}available(){return this._size-this._position}value(t=this._position){return this._data[t]}position(){return this._position}reset(t=0){this._position=t>this._size?this._size:t}shrink(t){const e=this._size-this._position;return t>e?e:(this._size=this._position+t,t)}next(t=1){const e=this._size-this._position;return t>e&&(t=e),this._position+=t,t}read8(){return 1===this.next(1)?this._view.getUint8(this._position-1):0}read16(){return 2===this.next(2)?this._view.getUint16(this._position-2):0}read24(){return 3===this.next(3)?this._view.getUint16(this._position-3)<<8|255&this._view.getUint8(this._position-1):0}read32(){return 4===this.next(4)?this._view.getUint32(this._position-4):0}readFloat(){return 4===this.next(4)?this._view.getFloat32(this._position-4):0}readDouble(){return 8===this.next(8)?this._view.getFloat64(this._position-8):0}read7Bit(t=5){if(t>5)throw Error("BinaryReader in JS can't decode more than 32 usefull bits");if(!(t>0))throw Error("Have to indicate a positive number of bytes to decode");let e,i=0;do{if(e=this.read8(),! --t)return(i<<8|e)>>>0;i=i<<7|127&e}while(128&e);return i}readString(){return String.fromCharCode(...this.read(this.read7Bit()))}readHex(t){let e="";for(;t--;)e+=("0"+this.read8().toString(16)).slice(-2);return e}read(t=this.available()){if(this.available()<t)return new Uint8Array(t);const e=this._data.subarray(this._position,this._position+t);return this._position+=t,e}}class e{get view(){return this._view||(this._view=new DataView(this._data.buffer,this._data.byteOffset,this._data.byteLength)),this._view}get capacity(){return this._data.byteLength}constructor(t=64,e=0,i){"number"==typeof t?(this._data=new Uint8Array(t),this._size=0):"buffer"in t?(this._data=new Uint8Array(t.buffer,t.byteOffset,t.byteLength),this._size=t.byteLength):(this._isConst=!0,null==i&&(i=t.byteLength),this._data=new Uint8Array(t,e,i),this._size=0)}data(){return new Uint8Array(this._data.buffer,this._data.byteOffset,this._size)}size(){return this._size||0}next(t=1){return this.reserve(this._size+=t)}clear(t=0){return this.reserve(this._size=t)}write(t){if(this.reserve(this._size+t.length),"string"==typeof t){for(let e=0;e<t.length;++e){const i=t.charCodeAt(e);this._data[this._size++]=i>255?32:i}return this}return this._data.set(t,this._size),this._size+=t.length,this}write8(t){return t>255&&(t=255),this.reserve(this._size+1),this._data[this._size++]=t,this}write16(t){return t>65535&&(t=65535),this.reserve(this._size+2),this.view.setUint16(this._size,t),this._size+=2,this}write24(t){return t>16777215&&(t=16777215),this.reserve(this._size+3),this.view.setUint16(this._size,t>>8),this.view.setUint8(this._size+=2,255&t),++this._size,this}write32(t){return t>4294967295&&(t=4294967295),this.reserve(this._size+4),this.view.setUint32(this._size,t),this._size+=4,this}writeFloat(t){return this.reserve(this._size+4),this.view.setFloat32(this._size,t),this._size+=4,this}writeDouble(t){return this.reserve(this._size+8),this.view.setFloat64(this._size,t),this._size+=8,this}write7Bit(t,e=5){if(e>5)throw Error("BinaryWriter in JS can't encode more than 32 usefull bits");if(!(e>0))throw Error("Have to indicate a positive number of bytes to encode");let i=7*--e;const s=t>4294967295?256:t>>>i;if(s)++i,s>255&&(t=4294967295);else for(;(i-=7)&&!(t>>>i););for(;i>1;)this.write8(128|t>>>i&255),i-=7;return this.write8(t&(i?255:127))}writeString(t){return this.write7Bit(t.length).write(t)}writeHex(t){for(let e=0;e<t.length;e+=2)this.write8(parseInt(t.substring(e,e+2),16));return this}reserve(t){if(!this._data)throw new Error("buffer not writable");if(t<=this._data.byteLength)return this;if(this._isConst)throw new Error("writing exceeds maximum "+this._data.byteLength+" bytes limit");--t,t|=t>>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,++t;const e=new Uint8Array(t);return e.set(this._data),this._data=e,this._view=void 0,this}}class i{constructor(t){this._data="buffer"in t?new Uint8Array(t.buffer,t.byteOffset,t.byteLength):new Uint8Array(t),this._size=this._data.byteLength,this._position=0,this._bit=0}data(){return this._data}size(){return this._size}available(){return 8*(this._size-this._position)-this._bit}next(t=1){let e=0;for(;this._position!==this._size&&t--;)++e,8==++this._bit&&(this._bit=0,++this._position);return e}read(t=1){let e=0;for(;this._position!==this._size&&t--;)e<<=1,this._data[this._position]&128>>this._bit++&&(e|=1),8===this._bit&&(this._bit=0,++this._position);return e}read8(){return this.read(8)}read16(){return this.read(16)}read24(){return this.read(24)}read32(){return this.read(32)}}class s{static fixProtocol(t,e){const i=e.indexOf("://");return i>=0&&(i>2&&"s"===e.charAt(i-1).toLowerCase()?(t.length<=2||!t.endsWith("s"))&&(t+="s"):t.length>2&&t.endsWith("s")&&(t=t.slice(0,-1)),e=e.substring(i+3)),t+"://"+e}get domain(){return this._domain}get port(){return this._port}toString(){return this._address}valueOf(){return this._address}constructor(t,e){this._address=t;let i=t.indexOf("/");if(i>=0&&(47===t.charCodeAt(i+1)?i>0?58===t.charCodeAt(i-1)&&(t=t.substring(i+2)):t=t.substring(2):i||(t=t.substring(1))),this._domain=t,this._port=e,i=t.lastIndexOf(":"),i>=0){const e=parseInt(t.substring(i+1));e&&e<=65535&&(this._port=e,this._domain=t.substring(0,i))}else i=t.indexOf("/"),i>=0&&(this._domain=t.substring(0,i))}}var r;!function(t){t.HESP="hesp",t.WEBRTS="webrts",t.WEBRTC="webrtc",t.META="meta",t.DATA="data"}(r||(r={}));var n=Object.freeze({__proto__:null,get Type(){return r},buildURL:function(t,e,i="wss"){const n=new URL(s.fixProtocol(i,e.host));if(n.pathname.length<=1)switch(t){case r.HESP:n.pathname="/hesp/"+e.streamName+"/index.json";break;case r.WEBRTC:n.pathname="/webrtc/"+e.streamName;break;case r.WEBRTS:n.pathname="/webrts/"+e.streamName;break;case r.META:n.pathname="/json_"+e.streamName+".js";break;case r.DATA:n.pathname="/"+e.streamName+".json";break;default:console.warn("Unknown url type "+t)}e.accessToken&&n.searchParams.set("id",e.accessToken);for(const t in e.query)n.searchParams.set(t,e.query[t]);return n}});class o{constructor(){this._events=new Map;let t=Object.getPrototypeOf(this);for(;t&&t!==Object.prototype;){for(const e of Object.getOwnPropertyNames(t))if(!(e.length<3)&&e.startsWith("on")&&t[e]instanceof Function){const i=new Set;this._events.set(e.substring(2).toLowerCase(),i);let s=t[e];Object.defineProperties(this,{[e]:{get:()=>(...t)=>{s&&s.call(this,...t);for(const e of i)e(...t)},set:t=>{s=t}}})}t=Object.getPrototypeOf(t)}}on(t,e,i){if(!e)throw Error("event to subscribe cannot be null");const s=this._event(t);s.add(e),i&&i.signal.addEventListener("abort",(()=>{s.delete(e)}))}once(t,e,i){if(!e)throw Error("event to subscribe cannot be null");const s=this._event(t);s.add((()=>{s.delete(e),e()})),i&&i.signal.addEventListener("abort",(()=>{s.delete(e)}))}off(t,e){if(!e)throw Error("event to unsubscribe cannot be null");this._event(t).delete(e)}_event(t){const e=this._events.get(t.toLowerCase());if(!e)throw Error("No event on"+t+" on class "+this.constructor.name);return e}}class h{get size(){return this._queue.length}get capacity(){return this._capacity}set capacity(t){this._capacity=t,null!=t&&this._queue.length>t&&this._queue.splice(0,this._queue.length-t)}get front(){return this._queue[0]}get back(){return this._queue[this._queue.length-1]}[Symbol.iterator](){return this._queue[Symbol.iterator]()}constructor(t){this._capacity=t,this._queue=new Array}push(t){return null!=this._capacity&&this._queue.push(t)>this._capacity&&this.pop(),this}pop(){return this._queue.shift()}clear(){return this._queue.length=0,this}}class a extends h{get minimum(){return this._min}get maximum(){return this._max}get average(){return null==this._average&&(this._average=this.size?this._sum/this.size:0),this._average}constructor(t){super(t),this._sum=0,this._min=0,this._max=0}push(t){return t>this._max?this._max=t:t<this._min&&(this._min=t),this._average=void 0,this._sum+=t,super.push(t),this}pop(){const t=super.pop();return t===this._max?this._max=Math.max(0,...this):t===this._min&&(this._min=Math.min(0,...this)),this._average=void 0,this._sum-=t||0,t}clear(){return this._min=this._max=this._sum=0,super.clear(),this}}const u={fromString(t){if(Array.isArray(t))return t;const e=new Array;let i,s=e;for(let r of t.toString().split("\n")){if(r=r.trim(),!r)continue;let t=r[0];const n=r.substring(r.indexOf("=")+1).trim();switch(t.toLowerCase()){case"a":if(!n)continue;t=this.addAttribute(s,n),e===s&&"fingerprint"===t.toLowerCase()&&(i=s.fingerprint);break;case"m":e.length&&i&&!e[e.length-1].fingerprint&&(s.fingerprint=i),e.push(s={m:n});break;default:s[t]=n}}return e.length&&i&&!e[e.length-1].fingerprint&&(s.fingerprint=i),e},toString(t){if("string"==typeof t)return t;const e=[];let i="v"in t?"v="+t.v+"\n":"";"o"in t&&(i+="o="+t.o+"\n"),"s"in t&&(i+="s="+t.s+"\n");const s=t;for(const r of Object.keys(t)){if("v"===r||"o"===r||"s"===r)continue;const t=s[r];if(null==t)continue;const n=parseInt(r);if(!isNaN(n)){e[n]=t;continue}const o=Array.isArray(t)&&t.length||1;for(let e=0;e<o;++e){const s=Array.isArray(t)&&t.length?t[e]:t;r.length>1?(i+="a="+r,s&&(i+=":")):i+=r+"=",i+=s+"\n"}}for(const t of e)i+=this.toString(t);return i},addAttribute(t,e){var i;const s=u.parseAttribute(e),r=null!==(i=s.value)&&void 0!==i?i:"",n=t,o=n[s.key];return o?Array.isArray(o)?o.push(r):r!==o&&(n[s.key]=[o,r]):n[s.key]=r,s.key},removeAttribute(t,e){const i=u.parseAttribute(e),s=t;if(void 0===i.value)return delete s[e],e;const r=s[e];if(Array.isArray(i.value)){const t=r.findIndex((t=>t===i.value));t>=0&&r.splice(t,1)}else r===i.value&&delete s[e];return i.key},parseAttribute(t){const e=t.indexOf(":");return{key:(e>=0?t.substring(0,e):t).trim(),value:e>=0?t.substring(e+1).trim():void 0}}};Object.freeze(u);const c=new TextDecoder,_=new TextEncoder,l=performance;function d(t,e){e=Object.assign({withType:!1,noEmptyString:!1},e);const i={};if(!t)return i;for(const[s,r]of f(t)){if(t=r,e.withType&&null!=t&&t.substring)if(t){const e=Number(t);if(isNaN(e))switch(t.toLowerCase()){case"true":t=!0;break;case"false":t=!1;break;case"null":t=null;break;case"undefined":t=void 0}else t=e}else e.noEmptyString&&(t=!0);i[s]?(Array.isArray(i[s])||(i[s]=new Array(i[s])),i[s].push(t)):i[s]=t}return i}function f(t){return t.entries?t.entries():Array.from({[Symbol.iterator]:function*(){for(const e in t)yield[e,t[e]]}})}var g=Object.freeze({__proto__:null,EMPTY_FUNCTION:()=>{},objectEntries:f,objectFrom:d,options:function(t=("undefined"==typeof location?void 0:location)){if(!t)return{};try{t=new URL(t).searchParams}catch(e){"string"==typeof t&&(t.startsWith("?")&&(t=t.substring(1)),t=new URLSearchParams(t))}return d(t,{withType:!0,noEmptyString:!0})},safePromise:function(t,e){let i;return Promise.race([e instanceof Promise?e:new Promise(e),new Promise(((e,s)=>i=setTimeout((()=>s("timed out in "+t+"ms")),t)))]).finally((()=>clearTimeout(i)))},stringify:function t(e,i={}){if(i=Object.assign({space:" ",decimal:2,recursive:1},i),null==e)return String(e);const s=e.error||e.message;if(s&&(e=s),e.toFixed)return e.toFixed(Number(i.decimal)||0);if(e.substring||!i.recursive)return String(e);const r=i.space||"";if(Array.isArray(e)){let s="";for(const n of e)s+=(s?",":"[")+r,s+=t(n,Object.assign(i,{recursive:i.recursive-1}));return s+=r+"]"}if(null!=e.byteLength&&(null==e?void 0:e[Symbol.iterator]))return c.decode(e);let n="";for(const s in e)n+=(n?",":"{")+r+s+":",n+=t(e[s],Object.assign(i,{recursive:i.recursive-1}));return n+(r+"}")},time:function(){return Math.floor(l.now())},timeOrigin:function(){return Math.floor(l.now()+l.timeOrigin)},toBin:function(t){return _.encode(t)}});class p extends o{onOpen(){}onMessage(t){}onClose(t){t&&console.error(t)}get binaryType(){return"arraybuffer"}get url(){var t,e;return null!==(e=null===(t=this._ws)||void 0===t?void 0:t.url)&&void 0!==e?e:""}get extensions(){var t,e;return null!==(e=null===(t=this._ws)||void 0===t?void 0:t.extensions)&&void 0!==e?e:""}get protocol(){var t,e;return null!==(e=null===(t=this._ws)||void 0===t?void 0:t.protocol)&&void 0!==e?e:""}get opened(){return this._opened}get readyState(){return this._ws?this._ws.readyState:3}get closed(){return this._closed}get bufferedAmount(){var t;return this._queueingBytes+((null===(t=this._ws)||void 0===t?void 0:t.bufferedAmount)||0)}get queueing(){return this._queueing}constructor(t,e){super(),this._queueing=[],this._queueingBytes=0,this._opened=!1,this._closed=!0,t&&this.open(t,e)}open(t,e){this._closed=!1;const i=this._ws=new WebSocket(t,e);return i.binaryType=this.binaryType,i.onmessage=t=>this.onMessage(t.data),i.onclose=e=>{this._opened?1e3===e.code||1005===e.code?this.close(t.toString()+" shutdown"):this.close(t.toString()+" disconnection ("+String(e.reason||e.code)+")"):this.close(t.toString()+" connection failed ("+String(e.reason||e.code)+")")},i.onopen=t=>{this._opened=!0,this.flush(),this.onOpen()},this}send(t,e=!1){if(!this._ws)throw Error("Open socket before to send data");return e||!this._opened?(this._queueing.push(t),this._queueingBytes+="string"==typeof t?t.length:t.byteLength):this._ws.send(t),this}flush(){if(this._ws)for(const t of this._queueing)this._ws.send(t);this._queueing.length=0,this._queueingBytes=0}close(t){this._ws&&!this._closed&&(this._closed=!0,this._ws.onopen=this._ws.onclose=this._ws.onmessage=null,this._ws.close(),this._opened=!1,this._queueing.length=0,this._queueingBytes=0,this.onClose(t))}}const b="1.2.0";export{t as BinaryReader,e as BinaryWriter,i as BitReader,n as Connect,o as EventEmitter,s as NetAddress,a as Numbers,h as Queue,u as SDP,g as Util,b as VERSION,p as WebSocketReliable};//# sourceMappingURL=web-utils.min.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"web-utils.min.js","sources":["web-utils.js"],"sourcesContent":["/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * BinaryReader allows to read binary data\n */\nclass BinaryReader {\n constructor(data) {\n this._data =\n 'buffer' in data ? new Uint8Array(data.buffer, data.byteOffset, data.byteLength) : new Uint8Array(data);\n this._size = this._data.byteLength;\n this._position = 0;\n this._view = new DataView(this._data.buffer, this._data.byteOffset, this._size);\n }\n data() {\n return this._data;\n }\n size() {\n return this._size;\n }\n available() {\n return this._size - this._position;\n }\n value(position = this._position) {\n return this._data[position];\n }\n position() {\n return this._position;\n }\n reset(position = 0) {\n this._position = position > this._size ? this._size : position;\n }\n shrink(available) {\n const rest = this._size - this._position;\n if (available > rest) {\n return rest;\n }\n this._size = this._position + available;\n return available;\n }\n next(count = 1) {\n const rest = this._size - this._position;\n if (count > rest) {\n count = rest;\n }\n this._position += count;\n return count;\n }\n read8() {\n return this.next(1) === 1 ? this._view.getUint8(this._position - 1) : 0;\n }\n read16() {\n return this.next(2) === 2 ? this._view.getUint16(this._position - 2) : 0;\n }\n read24() {\n return this.next(3) === 3\n ? (this._view.getUint16(this._position - 3) << 8) | (this._view.getUint8(this._position - 1) & 0xff)\n : 0;\n }\n read32() {\n return this.next(4) === 4 ? this._view.getUint32(this._position - 4) : 0;\n }\n readFloat() {\n return this.next(4) === 4 ? this._view.getFloat32(this._position - 4) : 0;\n }\n readDouble() {\n return this.next(8) === 8 ? this._view.getFloat64(this._position - 8) : 0;\n }\n read7Bit(bytes = 5) {\n if (bytes > 5) {\n throw Error(\"BinaryReader in JS can't decode more than 32 usefull bits\");\n }\n if (!(bytes > 0)) {\n // negation to catch NaN value\n throw Error('Have to indicate a positive number of bytes to decode');\n }\n let result = 0;\n let byte;\n do {\n byte = this.read8();\n if (!--bytes) {\n return ((result << 8) | byte) >>> 0; // Use all 8 bits from the 5th byte\n }\n result = (result << 7) | (byte & 0x7f);\n } while (byte & 0x80);\n return result;\n }\n readString() {\n return String.fromCharCode(...this.read(this.read7Bit()));\n }\n readHex(size) {\n let hex = '';\n while (size--) {\n hex += ('0' + this.read8().toString(16)).slice(-2);\n }\n return hex;\n }\n /**\n * Read bytes, to convert bytes to string use String.fromCharCode(...reader.read(size))\n * @param {UInt32} size\n */\n read(size = this.available()) {\n if (this.available() < size) {\n return new Uint8Array(size); // default value = empty bytearray!\n }\n const value = this._data.subarray(this._position, this._position + size);\n this._position += size;\n return value;\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * BinaryWriter allows to write data in its binary form\n */\nclass BinaryWriter {\n get view() {\n if (!this._view) {\n this._view = new DataView(this._data.buffer, this._data.byteOffset, this._data.byteLength);\n }\n return this._view;\n }\n get capacity() {\n return this._data.byteLength;\n }\n constructor(dataOrSize = 64, offset = 0, length) {\n if (typeof dataOrSize == 'number') {\n // allocate new buffer\n this._data = new Uint8Array(dataOrSize);\n this._size = 0;\n }\n else if ('buffer' in dataOrSize) {\n // append to existing data!\n this._data = new Uint8Array(dataOrSize.buffer, dataOrSize.byteOffset, dataOrSize.byteLength);\n this._size = dataOrSize.byteLength;\n }\n else {\n // overrides data\n this._isConst = true; // better than boolean for memory usage\n if (length == null) {\n // /!\\ Safari does not support undefined length, so we need to use byteLength instead\n length = dataOrSize.byteLength;\n }\n this._data = new Uint8Array(dataOrSize, offset, length);\n this._size = 0;\n }\n }\n data() {\n return new Uint8Array(this._data.buffer, this._data.byteOffset, this._size);\n }\n size() {\n return this._size || 0;\n }\n next(count = 1) {\n return this.reserve((this._size += count));\n }\n clear(size = 0) {\n return this.reserve((this._size = size));\n }\n write(data) {\n this.reserve(this._size + data.length);\n if (typeof data === 'string') {\n // beware here support just the 255 first bytes (compatible Latin-1)\n for (let i = 0; i < data.length; ++i) {\n const value = data.charCodeAt(i);\n this._data[this._size++] = value > 255 ? 32 : value;\n }\n return this;\n }\n this._data.set(data, this._size);\n this._size += data.length;\n return this;\n }\n write8(value) {\n if (value > 0xff) {\n // cast to 8bits range\n value = 0xff;\n }\n this.reserve(this._size + 1);\n this._data[this._size++] = value;\n return this;\n }\n write16(value) {\n if (value > 0xffff) {\n // cast to 16bits range\n value = 0xffff;\n }\n this.reserve(this._size + 2);\n this.view.setUint16(this._size, value);\n this._size += 2;\n return this;\n }\n write24(value) {\n if (value > 0xffffff) {\n // cast to 24bits range\n value = 0xffffff;\n }\n this.reserve(this._size + 3);\n this.view.setUint16(this._size, value >> 8);\n this.view.setUint8((this._size += 2), value & 0xff);\n ++this._size;\n return this;\n }\n write32(value) {\n if (value > 0xffffffff) {\n // cast to 32bits range\n value = 0xffffffff;\n }\n this.reserve(this._size + 4);\n this.view.setUint32(this._size, value);\n this._size += 4;\n return this;\n }\n writeFloat(value) {\n this.reserve(this._size + 4);\n this.view.setFloat32(this._size, value);\n this._size += 4;\n return this;\n }\n writeDouble(value) {\n this.reserve(this._size + 8);\n this.view.setFloat64(this._size, value);\n this._size += 8;\n return this;\n }\n write7Bit(value, bytes = 5) {\n if (bytes > 5) {\n throw Error(\"BinaryWriter in JS can't encode more than 32 usefull bits\");\n }\n if (!(bytes > 0)) {\n // negation to catch NaN value\n throw Error('Have to indicate a positive number of bytes to encode');\n }\n let bits = --bytes * 7;\n const front = value > 0xffffffff ? 0x100 : value >>> bits;\n if (front) {\n ++bits;\n if (front > 0xff) {\n value = 0xffffffff;\n }\n }\n else {\n while ((bits -= 7) && !(value >>> bits)) {\n continue;\n }\n }\n while (bits > 1) {\n this.write8(0x80 | ((value >>> bits) & 0xff));\n bits -= 7;\n }\n return this.write8(value & (bits ? 0xff : 0x7f));\n }\n writeString(value) {\n return this.write7Bit(value.length).write(value);\n }\n writeHex(value) {\n for (let i = 0; i < value.length; i += 2) {\n this.write8(parseInt(value.substring(i, i + 2), 16));\n }\n return this;\n }\n reserve(size) {\n if (!this._data) {\n throw new Error('buffer not writable');\n }\n if (size <= this._data.byteLength) {\n return this;\n }\n if (this._isConst) {\n throw new Error('writing exceeds maximum ' + this._data.byteLength + ' bytes limit');\n }\n --size;\n size |= size >> 1;\n size |= size >> 2;\n size |= size >> 4;\n size |= size >> 8;\n size |= size >> 16;\n ++size;\n const data = new Uint8Array(size);\n data.set(this._data); // copy old buffer!\n this._data = data;\n this._view = undefined; // release view\n return this;\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * BitReader allows to read binary data bit by bit\n */\nclass BitReader {\n constructor(data) {\n if ('buffer' in data) {\n this._data = new Uint8Array(data.buffer, data.byteOffset, data.byteLength);\n }\n else {\n this._data = new Uint8Array(data);\n }\n this._size = this._data.byteLength;\n this._position = 0;\n this._bit = 0;\n }\n data() {\n return this._data;\n }\n size() {\n return this._size;\n }\n available() {\n return (this._size - this._position) * 8 - this._bit;\n }\n next(count = 1) {\n let gotten = 0;\n while (this._position !== this._size && count--) {\n ++gotten;\n if (++this._bit === 8) {\n this._bit = 0;\n ++this._position;\n }\n }\n return gotten;\n }\n read(count = 1) {\n let result = 0;\n while (this._position !== this._size && count--) {\n result <<= 1;\n if (this._data[this._position] & (0x80 >> this._bit++)) {\n result |= 1;\n }\n if (this._bit === 8) {\n this._bit = 0;\n ++this._position;\n }\n }\n return result;\n }\n read8() {\n return this.read(8);\n }\n read16() {\n return this.read(16);\n }\n read24() {\n return this.read(24);\n }\n read32() {\n return this.read(32);\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * Help class to manipulate and parse a net address. The Address can be only the domain field,\n * or a URL format with protocol and path part `(http://)domain(:port/path)`\n * @example\n * const address = new Address('nl-ams-42.live.ceeblue.tv:80');\n * console.log(address.domain) // 'nl-ams-42.live.ceeblue.tv'\n * console.log(address.port) // '80'\n * console.log(address) // 'nl-ams-42.live.ceeblue.tv:80'\n */\nclass NetAddress {\n /**\n * Static help function to build an end point from an address `(proto://)domain(:port/path)`\n *\n * Mainly it fix the protocol, in addition if:\n * - the address passed is securized (TLS) and protocol is not => it tries to fix protocol to get its securize version\n * - the address passed is non securized and protocol is (TLS) => it tries to fix protocol to get its unsecurized version\n * @param protocol protocol to set in the end point returned\n * @param address string address to fix with protocol as indicated\n * @returns the end point built\n * @example\n * console.log(NetAddress.fixProtocol('ws','http://domain/path')) // 'ws://domain/path'\n * console.log(NetAddress.fixProtocol('ws','https://domain/path')) // 'wss://domain/path'\n * console.log(NetAddress.fixProtocol('wss','http://domain/path')) // 'ws://domain/path'\n */\n static fixProtocol(protocol, address) {\n const found = address.indexOf('://');\n // isolate protocol is present in address\n if (found >= 0) {\n // In this case replace by protocol in keeping SSL like given in address\n if (found > 2 && address.charAt(found - 1).toLowerCase() === 's') {\n // SSL!\n if (protocol.length <= 2 || !protocol.endsWith('s')) {\n protocol += 's'; // Add SSL\n }\n }\n else {\n // Not SSL!\n if (protocol.length > 2 && protocol.endsWith('s')) {\n protocol = protocol.slice(0, -1); // Remove SSL\n }\n }\n // Build host!\n address = address.substring(found + 3);\n }\n return protocol + '://' + address;\n }\n /**\n * The domain part from address `(http://)domain(:port/path)`\n */\n get domain() {\n return this._domain;\n }\n /**\n * The port part from address `(http://)domain(:port/path)`, or defaultPort if passed in NetAddress constructor\n */\n get port() {\n return this._port;\n }\n /**\n * @returns the string address as passed in the constructor\n */\n toString() {\n return this._address;\n }\n /**\n * @returns the string address as passed in the constructor\n * @override\n */\n valueOf() {\n return this._address;\n }\n /**\n * Build a NetAddress object and parse address\n * @param address string address to parse, accept an url format with protocol and path `(http://)domain(:port/path)`\n * @param defaultPort set a default port to use if there is no port in the string address parsed\n */\n constructor(address, defaultPort) {\n this._address = address;\n // Remove Protocol\n let pos = address.indexOf('/');\n if (pos >= 0) {\n // Remove ://\n if (address.charCodeAt(pos + 1) === 47) {\n // has //\n if (pos > 0) {\n if (address.charCodeAt(pos - 1) === 58) {\n // has ://\n address = address.substring(pos + 2);\n } // something else #//\n }\n else {\n // otherwise starts by //\n address = address.substring(2);\n }\n }\n else if (!pos) {\n // starts by /, remove it\n address = address.substring(1);\n } // else something else #/\n }\n this._domain = address;\n this._port = defaultPort;\n // Parse Port\n pos = address.lastIndexOf(':');\n if (pos >= 0) {\n const port = parseInt(address.substring(pos + 1));\n if (port && port <= 0xffff) {\n this._port = port;\n this._domain = address.substring(0, pos);\n }\n }\n else {\n // Remove Path!\n pos = address.indexOf('/');\n if (pos >= 0) {\n this._domain = address.substring(0, pos);\n }\n }\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * Type of connection\n */\nvar Type;\n(function (Type) {\n Type[\"HESP\"] = \"hesp\";\n Type[\"WEBRTS\"] = \"webrts\";\n Type[\"WEBRTC\"] = \"webrtc\";\n Type[\"META\"] = \"meta\";\n Type[\"DATA\"] = \"data\";\n})(Type || (Type = {}));\n/**\n * Some connection utility functions\n */\n/**\n * Build an URL from {@link Type | type} and {@link Params | params}\n * @param type Type of the connection wanted\n * @param params Connection parameters\n * @param protocol Optional parameter to choose the prefered protocol to connect\n * @returns The URL of connection\n */\nfunction buildURL(type, params, protocol = 'wss') {\n const url = new URL(NetAddress.fixProtocol(protocol, params.host));\n if (url.pathname.length <= 1) {\n // build ceeblue path!\n switch (type) {\n case Type.HESP:\n url.pathname = '/hesp/' + params.streamName + '/index.json';\n break;\n case Type.WEBRTC:\n url.pathname = '/webrtc/' + params.streamName;\n break;\n case Type.WEBRTS:\n url.pathname = '/webrts/' + params.streamName;\n break;\n case Type.META:\n url.pathname = '/json_' + params.streamName + '.js';\n break;\n case Type.DATA:\n url.pathname = '/' + params.streamName + '.json';\n break;\n default:\n console.warn('Unknown url type ' + type);\n break;\n }\n } // Host has already a path! keep it unchanged, it's user intentionnal (used with some other WHIP/WHEP server?)\n if (params.accessToken) {\n url.searchParams.set('id', params.accessToken);\n }\n for (const key in params.query) {\n url.searchParams.set(key, params.query[key]);\n }\n return url;\n}var Connect=/*#__PURE__*/Object.freeze({__proto__:null,get Type(){return Type},buildURL:buildURL});/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * A advanced EventEmitter which allows to declare event as natural function in the inheriting children class,\n * function must start by `on` prefix to be recognized as an event.\n * The function can define a behavior by default, and user can choose to redefine this behavior,\n * or add an additionnal subscription for this event.\n * In addition you can unsubscribe to multiple events with an `AbortController`\n * @example\n * class Logger extends EventEmitter {\n * onLog(log:string) { console.log(log); } // behavior by default\n *\n * test() {\n * // raise event onLog\n * this.onLog('test');\n * }\n * }\n *\n * const logger = new Logger();\n * logger.test(); // displays a log 'test'\n *\n * // redefine default behavior to display nothing\n * logger.onLog = () => {}\n * logger.test(); // displays nothing\n *\n * // add an additionnal subscription\n * logger.on('log', console.log);\n * logger.test(); // displays a log 'test'\n *\n * // remove the additionnal subscription\n * logger.off('log', console.log);\n * logger.test(); // displays nothing\n *\n * // add two additionnal subscriptions with a AbortController\n * const controller = new AbortController();\n * logger.on('log', log => console.log(log), controller);\n * logger.on('log', log => console.error(log), controller);\n * logger.test(); // displays a log 'test' + an error 'test'\n *\n * // Unsubscribe all the subscription with the AbortController\n * controller.abort();\n * logger.test(); // displays nothing\n */\nclass EventEmitter {\n /**\n * Build our EventEmitter, usually call from children class\n */\n constructor() {\n this._events = new Map();\n // Fill events with events as defined!\n let proto = Object.getPrototypeOf(this);\n while (proto && proto !== Object.prototype) {\n for (const name of Object.getOwnPropertyNames(proto)) {\n if (name.length < 3 || !name.startsWith('on')) {\n continue;\n }\n if (proto[name] instanceof Function) {\n const events = new Set();\n this._events.set(name.substring(2).toLowerCase(), events);\n let defaultEvent = proto[name];\n Object.defineProperties(this, {\n [name]: {\n get: () => (...args) => {\n // Call default event if not null (can happen in JS usage)\n if (defaultEvent) {\n defaultEvent.call(this, ...args);\n }\n // Call subscribers\n for (const event of events) {\n event(...args);\n }\n },\n set: (value) => {\n // Assign a default behavior!\n defaultEvent = value;\n }\n }\n });\n }\n }\n proto = Object.getPrototypeOf(proto);\n }\n }\n /**\n * Event subscription\n * @param name Name of event without the `on` prefix (ex: `log` to `onLog` event declared)\n * @param event Subscriber Function\n * @param abort Optional `AbortController` to stop this or multiple subscriptions in same time\n */\n on(name, event, abort) {\n if (!event) {\n throw Error('event to subscribe cannot be null');\n }\n const events = this._event(name);\n events.add(event);\n if (abort) {\n abort.signal.addEventListener('abort', () => {\n events.delete(event);\n });\n }\n }\n /**\n * Event subscription only one time, once time fired it's automatically unsubscribe\n * @param name Name of event without the `on` prefix (ex: `log` to `onLog` event declared)\n * @param event Subscriber Function\n * @param abort Optional `AbortController` to stop this or multiple subscriptions in same time\n */\n once(name, event, abort) {\n if (!event) {\n throw Error('event to subscribe cannot be null');\n }\n const events = this._event(name);\n events.add(() => {\n events.delete(event); // delete from events\n event(); // execute event\n });\n if (abort) {\n abort.signal.addEventListener('abort', () => {\n events.delete(event);\n });\n }\n }\n /**\n * Event unsubscription\n * @param name Name of event without the 'on' prefix (ex: 'log' to 'onLog' event declared)\n * @param event Unsubscriber Function, must be the one passed to {@link on} or {@link once} subscription methods\n */\n off(name, event) {\n if (!event) {\n throw Error('event to unsubscribe cannot be null');\n }\n this._event(name).delete(event);\n }\n _event(name) {\n const events = this._events.get(name.toLowerCase());\n if (!events) {\n throw Error('No event on' + name + ' on class ' + this.constructor.name);\n }\n return events;\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * Queue typed similar to a {@link https://en.cppreference.com/w/cpp/container/queue | std::queue<Type>} with possibility to limit the capacity like a FIFO\n * @example\n * const queue = new Queue<number>(2);\n * queue.push(1); // [1]\n * queue.push(2); // [1,2]\n * queue.push(3); // [2,3] 1 has been removed to respect 2 capacity\n */\nclass Queue {\n /**\n * Number of element in the queue\n */\n get size() {\n return this._queue.length;\n }\n /**\n * Maximum capacity for the queue, if not set queue has unlimited capacity\n */\n get capacity() {\n return this._capacity;\n }\n /**\n * Set a maximum capacity for the queue,\n * if you push new value exceding this capacity the firsts are removed (FIFO)\n * if set to undefined the queue is unlimited\n */\n set capacity(value) {\n this._capacity = value;\n if (value != null && this._queue.length > value) {\n this._queue.splice(0, this._queue.length - value);\n }\n }\n /**\n * The front element\n */\n get front() {\n return this._queue[0];\n }\n /**\n * The back element\n */\n get back() {\n return this._queue[this._queue.length - 1];\n }\n /**\n * Iterator though queue's elements\n */\n [Symbol.iterator]() {\n return this._queue[Symbol.iterator]();\n }\n /**\n * Instanciate a new queue object with the type passed as template\n * @param capacity if set it limits the size of the queue, any exceding element pops the first element pushed (FIFO)\n */\n constructor(capacity) {\n this._capacity = capacity;\n this._queue = new Array();\n }\n /**\n * Push a new element in the queue\n * @param value value of the element\n * @returns this\n */\n push(value) {\n if (this._capacity != null && this._queue.push(value) > this._capacity) {\n this.pop();\n }\n return this;\n }\n /**\n * Pop the first element from the queue\n * @returns The first element removed\n */\n pop() {\n return this._queue.shift();\n }\n /**\n * Clear all the elements, queue becomes empty\n * @returns this\n */\n clear() {\n this._queue.length = 0;\n return this;\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * A collection of number Queue<number> with the following efficient mathematic computation:\n * - minimum value in the collection\n * - maximum value in the collection\n * - average value of the collection\n */\nclass Numbers extends Queue {\n /**\n * minimum value in the collection, or 0 if colleciton is empty\n */\n get minimum() {\n return this._min;\n }\n /**\n * maximum value in the collection, or 0 if colleciton is empty\n */\n get maximum() {\n return this._max;\n }\n /**\n * average value of the collection, or 0 if collection if empty\n */\n get average() {\n if (this._average == null) {\n this._average = this.size ? this._sum / this.size : 0;\n }\n return this._average;\n }\n /**\n * Instantiate the collection of the number\n * @param capacity if set it limits the number of values stored, any exceding number pops the first number pushed (FIFO)\n */\n constructor(capacity) {\n super(capacity);\n this._sum = 0;\n this._min = 0;\n this._max = 0;\n }\n /**\n * Push a value to the back to the collection\n * @param value number to add\n * @returns this\n */\n push(value) {\n if (value > this._max) {\n this._max = value;\n }\n else if (value < this._min) {\n this._min = value;\n }\n this._average = undefined;\n this._sum += value;\n super.push(value);\n return this;\n }\n /**\n * Pop the front number from the collection\n * @returns the front number removed\n */\n pop() {\n const front = super.pop();\n if (front === this._max) {\n this._max = Math.max(0, ...this);\n }\n else if (front === this._min) {\n this._min = Math.min(0, ...this);\n }\n this._average = undefined;\n this._sum -= front || 0;\n return front;\n }\n /**\n * Clear all the numbers, collection becomes empty\n * @returns this\n */\n clear() {\n this._min = this._max = this._sum = 0;\n super.clear();\n return this;\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * Toolkit to deal with Session Description Protocol (SDP),\n * mainly to tranform a SDP string Offer/Answer to a manipulable JS object representation\n * @example\n * const peerConnection = new RTCPeerConnection();\n * peerConnection.createOffer()\n * .then( offer =>\n * // Change offer.sdp string to a JS manipulable object\n * const sdp = SDP.fromString(offer.sdp || '');\n * // Change a property of SDP\n * sdp.v = 2; // change SDP version\n * // Reserialize to the legal SDP string format\n * offer.sdp = SDP.toString(sdp);\n * // Set SDP offer to peerConnection\n * peerConnection.setLocalDescription(offer);\n * )\n */\nconst SDP = {\n /**\n * Unserialize SDP string to a manipulable JS object representation\n * It's an object with:\n * - root SDP properties\n * - media description iterable\n * @param lines SDP string reprensentation\n * @returns SDP object representation, iterable through media description\n * @example\n * [\n * group: \"DUNBLE 0 1\",\n * o: \"- 1699450751193623 0 IN IP4 0.0.0.0\",\n * s: \"-\",\n * t: \"0 0\",\n * v: \"0\",\n * ice-lite: \"\",\n * length: 2,\n * {\n * m: \"audio 9 UDP/TLS/RTP/SAVPF 111\",\n * c: \"IN IP4 0.0.0.0\",\n * rtcp: \"9\",\n * sendonly: \"\",\n * setup: \"passive\",\n * fingerprint: \"sha-256 51:36:ED:78:A4:9F:25:8C:39:9A:0E:A0:B4:9B:6E:04:37:FF:AD:96:93:71:43:88:2C:0B:0F:AB:6F:9A:52:B8\",\n * ice-ufrag: \"fa37\",\n * ice-pwd: \"JncCHryDsbzayy4cBWDxS2\",\n * rtcp-mux: \"\",\n * rtcp-rsize: \"\",\n * rtpmap: \"111 opus/48000/2\",\n * rtcp-fb: \"111 nack\",\n * id: \"0\",\n * fmtp: \"111 minptime=10;useinbandfec=1\",\n * candidate: \"1 1 udp 2130706431 89.105.221.108 56643 typ host\",\n * end-of-candidates: \"\"\n * },\n * {\n * m: \"video 9 UDP/TLS/RTP/SAVPF 106\",\n * c: \"IN IP4 0.0.0.0\",\n * rtcp: \"9\",\n * sendonly: \"\",\n * setup: \"passive\",\n * fingerprint: \"sha-256 51:36:ED:78:A4:9F:25:8C:39:9A:0E:A0:B4:9B:6E:04:37:FF:AD:96:93:71:43:88:2C:0B:0F:AB:6F:9A:52:B8\",\n * ice-ufrag: \"fa37\",\n * ice-pwd: \"JncCHryDsbzayy4cBWDxS2\",\n * rtcp-mux: \"\",\n * rtcp-rsize: \"\",\n * rtpmap: \"106 H264/90000\",\n * rtcp-fb: [\n * \"106 nack\",\n * \"106 goog-remb\"\n * ],\n * mid: \"1\",\n * fmtp: \"106 profile-level-id=42e01f;level-asymmetry-allowed=1;packetization-mode=1\",\n * candidate: \"1 1 udp 2130706431 89.105.221.108 56643 typ host\",\n * end-of-candidates: \"\"\n * }\n * ]\n */\n fromString(lines) {\n if (Array.isArray(lines)) {\n return lines; // already converted\n }\n const sdp = new Array();\n let media = sdp;\n let fingerprint;\n for (let line of lines.toString().split('\\n')) {\n line = line.trim();\n if (!line) {\n continue;\n }\n let key = line[0];\n const value = line.substring(line.indexOf('=') + 1).trim();\n switch (key.toLowerCase()) {\n case 'a': {\n if (!value) {\n continue;\n } // empty attribute!\n key = this.addAttribute(media, value);\n // save fingerprint to repeat it in medias\n if (sdp === media && key.toLowerCase() === 'fingerprint') {\n fingerprint = media.fingerprint;\n }\n break;\n }\n case 'm':\n if (sdp.length && fingerprint && !sdp[sdp.length - 1].fingerprint) {\n media.fingerprint = fingerprint;\n }\n sdp.push((media = { m: value }));\n break;\n default:\n media[key] = value;\n }\n }\n if (sdp.length && fingerprint && !sdp[sdp.length - 1].fingerprint) {\n media.fingerprint = fingerprint;\n }\n return sdp;\n },\n /**\n * Serialize SDP JS object to a SDP string legal representation\n * @param sdp SDP object reprensetation\n * @returns SDP string reprensentation\n */\n toString(sdp) {\n if (typeof sdp === 'string') {\n return sdp; // already converted\n }\n const medias = [];\n // https://www.cl.cam.ac.uk/~jac22/books/mm/book/node182.html\n let lines = 'v' in sdp ? 'v=' + sdp.v + '\\n' : '';\n if ('o' in sdp) {\n lines += 'o=' + sdp.o + '\\n';\n }\n if ('s' in sdp) {\n lines += 's=' + sdp.s + '\\n';\n }\n const obj = sdp;\n for (const key of Object.keys(sdp)) {\n if (key === 'v' || key === 'o' || key === 's') {\n continue;\n }\n const value = obj[key];\n if (value == null) {\n continue;\n } // ignore this key/value\n const index = parseInt(key);\n if (!isNaN(index)) {\n // Is a number! Media object!\n medias[index] = value;\n continue;\n }\n const count = (Array.isArray(value) && value.length) || 1; // value can be numeric!\n for (let i = 0; i < count; ++i) {\n const line = Array.isArray(value) && value.length ? value[i] : value;\n if (key.length > 1) {\n // when key is superior to 1 letter it's a attribute!\n lines += 'a=' + key;\n if (line) {\n lines += ':';\n }\n }\n else {\n lines += key + '=';\n }\n lines += line + '\\n';\n }\n }\n for (const media of medias) {\n lines += this.toString(media);\n }\n return lines;\n },\n /**\n * While set a property to a SDP object representation is possible directly,\n * we could prefer add a new property without overload a possible already existing value.\n * This function allows to add a property to our SDP representation:\n * - if the key's attribute doesn't exists yet it adds it like a simple JS property sdp[key] = value\n * - if the key's attribute exists already it morphs the value to a Array and push it inside\n * @param sdp the SDP object representation on which added the attribute\n * @param attribute the string attribut in a format \"key:value\" or just \"key\" to add an attribute without value\n * @returns the key part of the attribute added (or if value is empty it returns the same attribute as passed in argument)\n */\n addAttribute(sdp, attribute) {\n var _a;\n const a = SDP.parseAttribute(attribute);\n const value = (_a = a.value) !== null && _a !== void 0 ? _a : ''; // to allow to test if key exists even without value with if(sdp.key != null)\n const obj = sdp;\n const oldValue = obj[a.key];\n if (!oldValue) {\n obj[a.key] = value;\n }\n else if (Array.isArray(oldValue)) {\n oldValue.push(value);\n }\n else if (value !== oldValue) {\n obj[a.key] = [oldValue, value];\n }\n return a.key;\n },\n /**\n * While it's possible to delete a attribute manually on the SDP object representation with a delete sdp.key,\n * we could prefer remove only a value in a sdp.key array containing multiple values.\n * Like opposite to addAttribute this method allows to remove an unique attribute value.\n * @param sdp the SDP object representation on which removed the attribute\n * @param attribute the string attribut in a format \"key:value\" or just \"key\" to remove the whole attribute and all its values\n * @returns the key part of the attribute removed (or if value is empty it returns the same attribute as passed in argument)\n */\n removeAttribute(sdp, attribute) {\n const a = SDP.parseAttribute(attribute);\n const obj = sdp;\n if (a.value === undefined) {\n delete obj[attribute];\n return attribute;\n }\n const current = obj[attribute];\n if (Array.isArray(a.value)) {\n const i = current.findIndex((current) => current === a.value);\n if (i >= 0) {\n current.splice(i, 1);\n }\n }\n else if (current === a.value) {\n delete obj[attribute];\n }\n return a.key;\n },\n /**\n * Parse an attribute in a format \"key:value\"\n * @param attribute string attribute to parse\n * @returns the {key, value} result, with value undefined if attribute was a \"key\" without value\n */\n parseAttribute(attribute) {\n const found = attribute.indexOf(':');\n return {\n key: (found >= 0 ? attribute.substring(0, found) : attribute).trim(),\n value: found >= 0 ? attribute.substring(found + 1).trim() : undefined\n };\n }\n};\nObject.freeze(SDP);/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\nconst _decoder = new TextDecoder();\nconst _encoder = new TextEncoder();\n/* eslint-disable @typescript-eslint/no-explicit-any */\nconst _perf = performance; // to increase x10 now performance!\n/**\n * Some basic utility functions\n */\n/**\n * Version of the library\n */\nconst VERSION = '1.0.1';\n/**\n * An empty lambda function, pratical to disable default behavior of function or events which are not expected to be null\n * @example\n * console.log = Util.EMPTY_FUNCTION; // disable logs without breaking calls\n */\nconst EMPTY_FUNCTION = () => { };\n/**\n * Efficient and high resolution timestamp in milliseconds elapsed since {@link Util.timeOrigin}\n */\nfunction time() {\n return Math.floor(_perf.now());\n}\n/**\n * Time origin represents the time when the application has started\n */\nfunction timeOrigin() {\n return Math.floor(_perf.now() + _perf.timeOrigin);\n}\n/**\n * Parse query and returns it in an easy-to-use Javascript object form\n * @param urlOrQueryOrSearch string, url, or searchParams containing query. If not set it uses `location.search` to determinate query.\n * @returns An javascript object containing each option\n */\nfunction options(urlOrQueryOrSearch = typeof location === 'undefined'\n ? undefined\n : location) {\n if (!urlOrQueryOrSearch) {\n return {};\n }\n try {\n const url = urlOrQueryOrSearch;\n urlOrQueryOrSearch = new URL(url).searchParams;\n }\n catch (e) {\n if (typeof urlOrQueryOrSearch == 'string') {\n if (urlOrQueryOrSearch.startsWith('?')) {\n urlOrQueryOrSearch = urlOrQueryOrSearch.substring(1);\n }\n urlOrQueryOrSearch = new URLSearchParams(urlOrQueryOrSearch);\n }\n }\n // works same if urlOrQueryOrSearch is null, integer, or a already object etc...\n return objectFrom(urlOrQueryOrSearch, { withType: true, noEmptyString: true });\n}\n/**\n * Returns an easy-to-use Javascript object something iterable, such as a Map, Set, or Array\n * @param value iterable input\n * @param params.withType `false`, if set it tries to cast string value to a JS number/boolean/undefined/null type.\n * @param params.noEmptyString `false`, if set it converts empty string value to a true boolean, usefull to allow a `if(result.key)` check for example\n * @returns An javascript object\n */\nfunction objectFrom(value, params) {\n params = Object.assign({ withType: false, noEmptyString: false }, params);\n const obj = {};\n if (!value) {\n return obj;\n }\n for (const [key, val] of objectEntries(value)) {\n value = val;\n if (params.withType && value != null && value.substring) {\n if (value) {\n const number = Number(value);\n if (isNaN(number)) {\n switch (value.toLowerCase()) {\n case 'true':\n value = true;\n break;\n case 'false':\n value = false;\n break;\n case 'null':\n value = null;\n break;\n case 'undefined':\n value = undefined;\n break;\n }\n }\n else {\n value = number;\n }\n }\n else if (params.noEmptyString) {\n // if empty string => TRUE to allow a if(options.key) check for example\n value = true;\n }\n }\n if (obj[key]) {\n if (!Array.isArray(obj[key])) {\n obj[key] = new Array(obj[key]);\n }\n obj[key].push(value);\n }\n else {\n obj[key] = value;\n }\n }\n return obj;\n}\n/**\n * Returns entries from something iterable, such as a Map, Set, or Array\n * @param value iterable input\n * @returns An javascript object\n */\nfunction objectEntries(value) {\n if (value.entries) {\n return value.entries();\n }\n return Array.from({\n [Symbol.iterator]: function* () {\n for (const key in value) {\n yield [key, value[key]];\n }\n }\n });\n}\n/**\n * Converts various data types, such as objects, strings, exceptions, errors,\n * or numbers, into a string representation. Since it offers a more comprehensive format,\n * this function is preferred to `JSON.stringify()`.\n * @param obj Any objects, strings, exceptions, errors, or number\n * @param params.space `''`, allows to configure space in the string representation\n * @param params.decimal `2`, allows to choose the number of decimal to display in the string representation\n * @param params.recursive `false`, allows to serialize recursively every object value, beware if a value refers to a already parsed value an infinite loop will occur.\n * @returns the final string representation\n */\n// Online Javascript Editor for free\n// Write, Edit and Run your Javascript code using JS Online Compiler\nfunction stringify(obj, params = {}) {\n params = Object.assign({ space: ' ', decimal: 2, recursive: 1 }, params);\n if (!obj) {\n return String(obj);\n }\n const error = obj.error || obj.message;\n if (error) {\n // is a error!\n obj = error;\n }\n if (obj.toFixed) {\n return obj.toFixed(Number(params.decimal) || 0);\n }\n if (obj.substring || !params.recursive) {\n // is already a string OR has to be stringified\n return String(obj);\n }\n const space = params.space || '';\n if (Array.isArray(obj)) {\n // Array!\n let res = '';\n for (const value of obj) {\n res += (res ? ',' : '[') + space;\n res += stringify(value, Object.assign(params, { recursive: params.recursive - 1 }));\n }\n return (res += space + ']');\n }\n if (obj.byteLength != null && (obj === null || obj === void 0 ? void 0 : obj[Symbol.iterator])) {\n // Binary!\n return _decoder.decode(obj);\n }\n let res = '';\n for (const name in obj) {\n res += (res ? ',' : '{') + space + name + ':';\n res += stringify(obj[name], Object.assign(params, { recursive: params.recursive - 1 }));\n }\n return (res += space + '}');\n}\nfunction toBin(value) {\n return _encoder.encode(value);\n}var Util=/*#__PURE__*/Object.freeze({__proto__:null,EMPTY_FUNCTION:EMPTY_FUNCTION,VERSION:VERSION,objectEntries:objectEntries,objectFrom:objectFrom,options:options,stringify:stringify,time:time,timeOrigin:timeOrigin,toBin:toBin});/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * The WebSocketReliable class extends WebSocket to bring up the following improvements:\n * - Fix all possible unintentional closing ways to get always a related error message, {@link onClose | onClose(error?) event}\n * - Make possible message sending while connecting. Indeed no need to wait {@link onOpen} before to send message,\n * you can open the socket and immediately send messages, it will be queue and flushs on connection etablishment\n * - Make possible a delayed connection, or a reconnection. Indeed you can create an unconnected Websocket instance\n * without passing any url argument and starts the conneciton more later with {@link WebSocketReliable.open(url) | open(url)} method\n * - Make possible to control sending/queueing message: send method take an optional queueing=true argument to\n * queue message rather send it, a futur call to flush will send it. Then queueing getter allows to handle the queue\n * if need to purge it or remove some queued message. Use it all together can help to prioritize messages or control overload.\n * @example\n * const ws = new WebSocketReliable(url);\n * ws.onClose = (error?:string) => {\n * if(error) {\n * console.error(error);\n * }\n * // reconnection attempt every seconds\n * setTimeout(() => ws.open(url), 1000);\n * }\n * ws.onMessage = (message:string) => {\n * console.log(message);\n * }\n * ws.send('hello'); // send immediatly a hello message is possible (no need to wait onOpen)\n */\nclass WebSocketReliable extends EventEmitter {\n /**\n * @event `open` fired when socket is connected\n */\n onOpen() { }\n /**\n * @event `message` fired on message reception\n * @param message can be binary or string.\n * If you subscribe to the event with message as string type (and not union),\n * it means that you know that all your messages are distributed in a string format\n */\n onMessage(message) { }\n /**\n * @event `close` fired on websocket close\n * @param error error description on an improper closure\n */\n onClose(error) {\n if (error) {\n console.error(error);\n }\n }\n /**\n * binaryType, fix binary type to arrayBuffer\n */\n get binaryType() {\n return 'arraybuffer';\n }\n /**\n * url of connection\n */\n get url() {\n var _a, _b;\n return (_b = (_a = this._ws) === null || _a === void 0 ? void 0 : _a.url) !== null && _b !== void 0 ? _b : '';\n }\n /**\n * extensions negociated by the server\n */\n get extensions() {\n var _a, _b;\n return (_b = (_a = this._ws) === null || _a === void 0 ? void 0 : _a.extensions) !== null && _b !== void 0 ? _b : '';\n }\n /**\n * protocol negociated by the server\n */\n get protocol() {\n var _a, _b;\n return (_b = (_a = this._ws) === null || _a === void 0 ? void 0 : _a.protocol) !== null && _b !== void 0 ? _b : '';\n }\n /**\n * opened equals true when connection is etablished, in other word when onOpen event is fired\n */\n get opened() {\n return this._opened;\n }\n /**\n * {@link https://developer.mozilla.org/docs/Web/API/WebSocket/readyState | Official websocket readyState}\n */\n get readyState() {\n return this._ws ? this._ws.readyState : 3;\n }\n /**\n * True when connection is closed, in other words when {@link onClose} event is fired\n * or when WebSocketReliable is build without url (disconnected creation)\n */\n get closed() {\n return this._closed;\n }\n /**\n * The number of bytes of data that were queued during calls to send() but not yet transmitted to the network\n */\n get bufferedAmount() {\n var _a;\n return this._queueingBytes + (((_a = this._ws) === null || _a === void 0 ? void 0 : _a.bufferedAmount) || 0);\n }\n /**\n * Queued messages from a call to send() waiting to be transmit one time websocket connection opened (or with an explicit call to flush() method)\n */\n get queueing() {\n return this._queueing;\n }\n /**\n * Create a WebSocketReliable object, and open it if an url is passed in argument\n * @param url URL of the WebSocket endpoint or null to start the connection later\n */\n constructor(url, protocols) {\n super();\n this._queueing = [];\n this._queueingBytes = 0;\n this._opened = false;\n this._closed = true;\n if (url) {\n this.open(url, protocols);\n }\n }\n /**\n * Open a WebSocket connection\n * @param url url of the websocket endpoint\n * @returns this\n */\n open(url, protocols) {\n this._closed = false;\n const ws = (this._ws = new WebSocket(url, protocols));\n ws.binaryType = this.binaryType;\n ws.onmessage = e => this.onMessage(e.data);\n // Add details and fix close ways\n ws.onclose = (e) => {\n if (!this._opened) {\n // close during connection\n this.close(url.toString() + ' connection failed (' + String(e.reason || e.code) + ')');\n }\n else if (e.code === 1000 || e.code === 1005) {\n // normal disconnection from server (no error code)\n this.close(url.toString() + ' shutdown');\n }\n else {\n // disconnection from server\n this.close(url.toString() + ' disconnection (' + String(e.reason || e.code) + ')');\n }\n };\n // Wrap send method to queue messages until connection is established.\n ws.onopen = _ => {\n this._opened = true;\n this.flush();\n this.onOpen();\n };\n return this;\n }\n /**\n * Send a message\n * @param message\n * @param queueing When set it reports the sending to a more later call to flush\n * @returns this\n */\n send(message, queueing = false) {\n if (!this._ws) {\n throw Error('Open socket before to send data');\n }\n if (queueing || !this._opened) {\n this._queueing.push(message);\n this._queueingBytes += typeof message === 'string' ? message.length : message.byteLength;\n }\n else {\n this._ws.send(message);\n }\n return this;\n }\n /**\n * Send queueing messages\n */\n flush() {\n if (this._ws) {\n for (const message of this._queueing) {\n this._ws.send(message);\n }\n }\n this._queueing.length = 0;\n this._queueingBytes = 0;\n }\n /**\n * Close websocket\n * @param error the error reason if is not a proper close\n */\n close(error) {\n if (!this._ws || this._closed) {\n return;\n }\n this._closed = true;\n this._ws.onopen = this._ws.onclose = this._ws.onmessage = null; // otherwise can receive message AFTER close!\n this._ws.close(); // Don't set to undefined to keep this._ws properties valid!\n // release resources!\n this._opened = false;\n this._queueing.length = 0;\n this._queueingBytes = 0;\n this.onClose(error);\n }\n}export{BinaryReader,BinaryWriter,BitReader,Connect,EventEmitter,NetAddress,Numbers,Queue,SDP,Util,WebSocketReliable};//# sourceMappingURL=web-utils.js.map\n"],"names":["BinaryReader","constructor","data","this","_data","Uint8Array","buffer","byteOffset","byteLength","_size","_position","_view","DataView","size","available","value","position","reset","shrink","rest","next","count","read8","getUint8","read16","getUint16","read24","read32","getUint32","readFloat","getFloat32","readDouble","getFloat64","read7Bit","bytes","Error","byte","result","readString","String","fromCharCode","read","readHex","hex","toString","slice","subarray","BinaryWriter","view","capacity","dataOrSize","offset","length","_isConst","reserve","clear","write","i","charCodeAt","set","write8","write16","setUint16","write24","setUint8","write32","setUint32","writeFloat","setFloat32","writeDouble","setFloat64","write7Bit","bits","front","writeString","writeHex","parseInt","substring","undefined","BitReader","_bit","gotten","NetAddress","fixProtocol","protocol","address","found","indexOf","charAt","toLowerCase","endsWith","domain","_domain","port","_port","_address","valueOf","defaultPort","pos","lastIndexOf","Type","Connect","Object","freeze","__proto__","buildURL","type","params","url","URL","host","pathname","HESP","streamName","WEBRTC","WEBRTS","META","DATA","console","warn","accessToken","searchParams","key","query","EventEmitter","_events","Map","proto","getPrototypeOf","prototype","name","getOwnPropertyNames","startsWith","Function","events","Set","defaultEvent","defineProperties","get","args","call","event","on","abort","_event","add","signal","addEventListener","delete","once","off","Queue","_queue","_capacity","splice","back","Symbol","iterator","Array","push","pop","shift","Numbers","minimum","_min","maximum","_max","average","_average","_sum","super","Math","max","min","SDP","fromString","lines","isArray","sdp","fingerprint","media","line","split","trim","addAttribute","m","medias","v","o","s","obj","keys","index","isNaN","attribute","_a","a","parseAttribute","oldValue","removeAttribute","current","findIndex","_decoder","TextDecoder","_encoder","TextEncoder","_perf","performance","objectFrom","assign","withType","noEmptyString","val","objectEntries","number","Number","entries","from","Util","EMPTY_FUNCTION","VERSION","options","urlOrQueryOrSearch","location","e","URLSearchParams","stringify","space","decimal","recursive","error","message","toFixed","res","decode","time","floor","now","timeOrigin","toBin","encode","WebSocketReliable","onOpen","onMessage","onClose","binaryType","_b","_ws","extensions","opened","_opened","readyState","closed","_closed","bufferedAmount","_queueingBytes","queueing","_queueing","protocols","open","ws","WebSocket","onmessage","onclose","code","close","reason","onopen","_","flush","send"],"mappings":"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"}
1
+ {"version":3,"file":"web-utils.min.js","sources":["web-utils.js"],"sourcesContent":["/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * BinaryReader allows to read binary data\n */\nclass BinaryReader {\n constructor(data) {\n this._data =\n 'buffer' in data ? new Uint8Array(data.buffer, data.byteOffset, data.byteLength) : new Uint8Array(data);\n this._size = this._data.byteLength;\n this._position = 0;\n this._view = new DataView(this._data.buffer, this._data.byteOffset, this._size);\n }\n data() {\n return this._data;\n }\n size() {\n return this._size;\n }\n available() {\n return this._size - this._position;\n }\n value(position = this._position) {\n return this._data[position];\n }\n position() {\n return this._position;\n }\n reset(position = 0) {\n this._position = position > this._size ? this._size : position;\n }\n shrink(available) {\n const rest = this._size - this._position;\n if (available > rest) {\n return rest;\n }\n this._size = this._position + available;\n return available;\n }\n next(count = 1) {\n const rest = this._size - this._position;\n if (count > rest) {\n count = rest;\n }\n this._position += count;\n return count;\n }\n read8() {\n return this.next(1) === 1 ? this._view.getUint8(this._position - 1) : 0;\n }\n read16() {\n return this.next(2) === 2 ? this._view.getUint16(this._position - 2) : 0;\n }\n read24() {\n return this.next(3) === 3\n ? (this._view.getUint16(this._position - 3) << 8) | (this._view.getUint8(this._position - 1) & 0xff)\n : 0;\n }\n read32() {\n return this.next(4) === 4 ? this._view.getUint32(this._position - 4) : 0;\n }\n readFloat() {\n return this.next(4) === 4 ? this._view.getFloat32(this._position - 4) : 0;\n }\n readDouble() {\n return this.next(8) === 8 ? this._view.getFloat64(this._position - 8) : 0;\n }\n read7Bit(bytes = 5) {\n if (bytes > 5) {\n throw Error(\"BinaryReader in JS can't decode more than 32 usefull bits\");\n }\n if (!(bytes > 0)) {\n // negation to catch NaN value\n throw Error('Have to indicate a positive number of bytes to decode');\n }\n let result = 0;\n let byte;\n do {\n byte = this.read8();\n if (!--bytes) {\n return ((result << 8) | byte) >>> 0; // Use all 8 bits from the 5th byte\n }\n result = (result << 7) | (byte & 0x7f);\n } while (byte & 0x80);\n return result;\n }\n readString() {\n return String.fromCharCode(...this.read(this.read7Bit()));\n }\n readHex(size) {\n let hex = '';\n while (size--) {\n hex += ('0' + this.read8().toString(16)).slice(-2);\n }\n return hex;\n }\n /**\n * Read bytes, to convert bytes to string use String.fromCharCode(...reader.read(size))\n * @param {UInt32} size\n */\n read(size = this.available()) {\n if (this.available() < size) {\n return new Uint8Array(size); // default value = empty bytearray!\n }\n const value = this._data.subarray(this._position, this._position + size);\n this._position += size;\n return value;\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * BinaryWriter allows to write data in its binary form\n */\nclass BinaryWriter {\n get view() {\n if (!this._view) {\n this._view = new DataView(this._data.buffer, this._data.byteOffset, this._data.byteLength);\n }\n return this._view;\n }\n get capacity() {\n return this._data.byteLength;\n }\n constructor(dataOrSize = 64, offset = 0, length) {\n if (typeof dataOrSize == 'number') {\n // allocate new buffer\n this._data = new Uint8Array(dataOrSize);\n this._size = 0;\n }\n else if ('buffer' in dataOrSize) {\n // append to existing data!\n this._data = new Uint8Array(dataOrSize.buffer, dataOrSize.byteOffset, dataOrSize.byteLength);\n this._size = dataOrSize.byteLength;\n }\n else {\n // overrides data\n this._isConst = true; // better than boolean for memory usage\n if (length == null) {\n // /!\\ Safari does not support undefined length, so we need to use byteLength instead\n length = dataOrSize.byteLength;\n }\n this._data = new Uint8Array(dataOrSize, offset, length);\n this._size = 0;\n }\n }\n data() {\n return new Uint8Array(this._data.buffer, this._data.byteOffset, this._size);\n }\n size() {\n return this._size || 0;\n }\n next(count = 1) {\n return this.reserve((this._size += count));\n }\n clear(size = 0) {\n return this.reserve((this._size = size));\n }\n write(data) {\n this.reserve(this._size + data.length);\n if (typeof data === 'string') {\n // beware here support just the 255 first bytes (compatible Latin-1)\n for (let i = 0; i < data.length; ++i) {\n const value = data.charCodeAt(i);\n this._data[this._size++] = value > 255 ? 32 : value;\n }\n return this;\n }\n this._data.set(data, this._size);\n this._size += data.length;\n return this;\n }\n write8(value) {\n if (value > 0xff) {\n // cast to 8bits range\n value = 0xff;\n }\n this.reserve(this._size + 1);\n this._data[this._size++] = value;\n return this;\n }\n write16(value) {\n if (value > 0xffff) {\n // cast to 16bits range\n value = 0xffff;\n }\n this.reserve(this._size + 2);\n this.view.setUint16(this._size, value);\n this._size += 2;\n return this;\n }\n write24(value) {\n if (value > 0xffffff) {\n // cast to 24bits range\n value = 0xffffff;\n }\n this.reserve(this._size + 3);\n this.view.setUint16(this._size, value >> 8);\n this.view.setUint8((this._size += 2), value & 0xff);\n ++this._size;\n return this;\n }\n write32(value) {\n if (value > 0xffffffff) {\n // cast to 32bits range\n value = 0xffffffff;\n }\n this.reserve(this._size + 4);\n this.view.setUint32(this._size, value);\n this._size += 4;\n return this;\n }\n writeFloat(value) {\n this.reserve(this._size + 4);\n this.view.setFloat32(this._size, value);\n this._size += 4;\n return this;\n }\n writeDouble(value) {\n this.reserve(this._size + 8);\n this.view.setFloat64(this._size, value);\n this._size += 8;\n return this;\n }\n write7Bit(value, bytes = 5) {\n if (bytes > 5) {\n throw Error(\"BinaryWriter in JS can't encode more than 32 usefull bits\");\n }\n if (!(bytes > 0)) {\n // negation to catch NaN value\n throw Error('Have to indicate a positive number of bytes to encode');\n }\n let bits = --bytes * 7;\n const front = value > 0xffffffff ? 0x100 : value >>> bits;\n if (front) {\n ++bits;\n if (front > 0xff) {\n value = 0xffffffff;\n }\n }\n else {\n while ((bits -= 7) && !(value >>> bits)) {\n continue;\n }\n }\n while (bits > 1) {\n this.write8(0x80 | ((value >>> bits) & 0xff));\n bits -= 7;\n }\n return this.write8(value & (bits ? 0xff : 0x7f));\n }\n writeString(value) {\n return this.write7Bit(value.length).write(value);\n }\n writeHex(value) {\n for (let i = 0; i < value.length; i += 2) {\n this.write8(parseInt(value.substring(i, i + 2), 16));\n }\n return this;\n }\n reserve(size) {\n if (!this._data) {\n throw new Error('buffer not writable');\n }\n if (size <= this._data.byteLength) {\n return this;\n }\n if (this._isConst) {\n throw new Error('writing exceeds maximum ' + this._data.byteLength + ' bytes limit');\n }\n --size;\n size |= size >> 1;\n size |= size >> 2;\n size |= size >> 4;\n size |= size >> 8;\n size |= size >> 16;\n ++size;\n const data = new Uint8Array(size);\n data.set(this._data); // copy old buffer!\n this._data = data;\n this._view = undefined; // release view\n return this;\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * BitReader allows to read binary data bit by bit\n */\nclass BitReader {\n constructor(data) {\n if ('buffer' in data) {\n this._data = new Uint8Array(data.buffer, data.byteOffset, data.byteLength);\n }\n else {\n this._data = new Uint8Array(data);\n }\n this._size = this._data.byteLength;\n this._position = 0;\n this._bit = 0;\n }\n data() {\n return this._data;\n }\n size() {\n return this._size;\n }\n available() {\n return (this._size - this._position) * 8 - this._bit;\n }\n next(count = 1) {\n let gotten = 0;\n while (this._position !== this._size && count--) {\n ++gotten;\n if (++this._bit === 8) {\n this._bit = 0;\n ++this._position;\n }\n }\n return gotten;\n }\n read(count = 1) {\n let result = 0;\n while (this._position !== this._size && count--) {\n result <<= 1;\n if (this._data[this._position] & (0x80 >> this._bit++)) {\n result |= 1;\n }\n if (this._bit === 8) {\n this._bit = 0;\n ++this._position;\n }\n }\n return result;\n }\n read8() {\n return this.read(8);\n }\n read16() {\n return this.read(16);\n }\n read24() {\n return this.read(24);\n }\n read32() {\n return this.read(32);\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * Help class to manipulate and parse a net address. The Address can be only the domain field,\n * or a URL format with protocol and path part `(http://)domain(:port/path)`\n * @example\n * const address = new Address('nl-ams-42.live.ceeblue.tv:80');\n * console.log(address.domain) // 'nl-ams-42.live.ceeblue.tv'\n * console.log(address.port) // '80'\n * console.log(address) // 'nl-ams-42.live.ceeblue.tv:80'\n */\nclass NetAddress {\n /**\n * Static help function to build an end point from an address `(proto://)domain(:port/path)`\n *\n * Mainly it fix the protocol, in addition if:\n * - the address passed is securized (TLS) and protocol is not => it tries to fix protocol to get its securize version\n * - the address passed is non securized and protocol is (TLS) => it tries to fix protocol to get its unsecurized version\n * @param protocol protocol to set in the end point returned\n * @param address string address to fix with protocol as indicated\n * @returns the end point built\n * @example\n * console.log(NetAddress.fixProtocol('ws','http://domain/path')) // 'ws://domain/path'\n * console.log(NetAddress.fixProtocol('ws','https://domain/path')) // 'wss://domain/path'\n * console.log(NetAddress.fixProtocol('wss','http://domain/path')) // 'ws://domain/path'\n */\n static fixProtocol(protocol, address) {\n const found = address.indexOf('://');\n // isolate protocol is present in address\n if (found >= 0) {\n // In this case replace by protocol in keeping SSL like given in address\n if (found > 2 && address.charAt(found - 1).toLowerCase() === 's') {\n // SSL!\n if (protocol.length <= 2 || !protocol.endsWith('s')) {\n protocol += 's'; // Add SSL\n }\n }\n else {\n // Not SSL!\n if (protocol.length > 2 && protocol.endsWith('s')) {\n protocol = protocol.slice(0, -1); // Remove SSL\n }\n }\n // Build host!\n address = address.substring(found + 3);\n }\n return protocol + '://' + address;\n }\n /**\n * The domain part from address `(http://)domain(:port/path)`\n */\n get domain() {\n return this._domain;\n }\n /**\n * The port part from address `(http://)domain(:port/path)`, or defaultPort if passed in NetAddress constructor\n */\n get port() {\n return this._port;\n }\n /**\n * @returns the string address as passed in the constructor\n */\n toString() {\n return this._address;\n }\n /**\n * @returns the string address as passed in the constructor\n * @override\n */\n valueOf() {\n return this._address;\n }\n /**\n * Build a NetAddress object and parse address\n * @param address string address to parse, accept an url format with protocol and path `(http://)domain(:port/path)`\n * @param defaultPort set a default port to use if there is no port in the string address parsed\n */\n constructor(address, defaultPort) {\n this._address = address;\n // Remove Protocol\n let pos = address.indexOf('/');\n if (pos >= 0) {\n // Remove ://\n if (address.charCodeAt(pos + 1) === 47) {\n // has //\n if (pos > 0) {\n if (address.charCodeAt(pos - 1) === 58) {\n // has ://\n address = address.substring(pos + 2);\n } // something else #//\n }\n else {\n // otherwise starts by //\n address = address.substring(2);\n }\n }\n else if (!pos) {\n // starts by /, remove it\n address = address.substring(1);\n } // else something else #/\n }\n this._domain = address;\n this._port = defaultPort;\n // Parse Port\n pos = address.lastIndexOf(':');\n if (pos >= 0) {\n const port = parseInt(address.substring(pos + 1));\n if (port && port <= 0xffff) {\n this._port = port;\n this._domain = address.substring(0, pos);\n }\n }\n else {\n // Remove Path!\n pos = address.indexOf('/');\n if (pos >= 0) {\n this._domain = address.substring(0, pos);\n }\n }\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * Type of connection\n */\nvar Type;\n(function (Type) {\n Type[\"HESP\"] = \"hesp\";\n Type[\"WEBRTS\"] = \"webrts\";\n Type[\"WEBRTC\"] = \"webrtc\";\n Type[\"META\"] = \"meta\";\n Type[\"DATA\"] = \"data\";\n})(Type || (Type = {}));\n/**\n * Some connection utility functions\n */\n/**\n * Build an URL from {@link Type | type} and {@link Params | params}\n * @param type Type of the connection wanted\n * @param params Connection parameters\n * @param protocol Optional parameter to choose the prefered protocol to connect\n * @returns The URL of connection\n */\nfunction buildURL(type, params, protocol = 'wss') {\n const url = new URL(NetAddress.fixProtocol(protocol, params.host));\n if (url.pathname.length <= 1) {\n // build ceeblue path!\n switch (type) {\n case Type.HESP:\n url.pathname = '/hesp/' + params.streamName + '/index.json';\n break;\n case Type.WEBRTC:\n url.pathname = '/webrtc/' + params.streamName;\n break;\n case Type.WEBRTS:\n url.pathname = '/webrts/' + params.streamName;\n break;\n case Type.META:\n url.pathname = '/json_' + params.streamName + '.js';\n break;\n case Type.DATA:\n url.pathname = '/' + params.streamName + '.json';\n break;\n default:\n console.warn('Unknown url type ' + type);\n break;\n }\n } // Host has already a path! keep it unchanged, it's user intentionnal (used with some other WHIP/WHEP server?)\n if (params.accessToken) {\n url.searchParams.set('id', params.accessToken);\n }\n for (const key in params.query) {\n url.searchParams.set(key, params.query[key]);\n }\n return url;\n}var Connect=/*#__PURE__*/Object.freeze({__proto__:null,get Type(){return Type},buildURL:buildURL});/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * A advanced EventEmitter which allows to declare event as natural function in the inheriting children class,\n * function must start by `on` prefix to be recognized as an event.\n * The function can define a behavior by default, and user can choose to redefine this behavior,\n * or add an additionnal subscription for this event.\n * In addition you can unsubscribe to multiple events with an `AbortController`\n * @example\n * class Logger extends EventEmitter {\n * onLog(log:string) { console.log(log); } // behavior by default\n *\n * test() {\n * // raise event onLog\n * this.onLog('test');\n * }\n * }\n *\n * const logger = new Logger();\n * logger.test(); // displays a log 'test'\n *\n * // redefine default behavior to display nothing\n * logger.onLog = () => {}\n * logger.test(); // displays nothing\n *\n * // add an additionnal subscription\n * logger.on('log', console.log);\n * logger.test(); // displays a log 'test'\n *\n * // remove the additionnal subscription\n * logger.off('log', console.log);\n * logger.test(); // displays nothing\n *\n * // add two additionnal subscriptions with a AbortController\n * const controller = new AbortController();\n * logger.on('log', log => console.log(log), controller);\n * logger.on('log', log => console.error(log), controller);\n * logger.test(); // displays a log 'test' + an error 'test'\n *\n * // Unsubscribe all the subscription with the AbortController\n * controller.abort();\n * logger.test(); // displays nothing\n */\nclass EventEmitter {\n /**\n * Build our EventEmitter, usually call from children class\n */\n constructor() {\n this._events = new Map();\n // Fill events with events as defined!\n let proto = Object.getPrototypeOf(this);\n while (proto && proto !== Object.prototype) {\n for (const name of Object.getOwnPropertyNames(proto)) {\n if (name.length < 3 || !name.startsWith('on')) {\n continue;\n }\n if (proto[name] instanceof Function) {\n const events = new Set();\n this._events.set(name.substring(2).toLowerCase(), events);\n let defaultEvent = proto[name];\n Object.defineProperties(this, {\n [name]: {\n get: () => (...args) => {\n // Call default event if not null (can happen in JS usage)\n if (defaultEvent) {\n defaultEvent.call(this, ...args);\n }\n // Call subscribers\n for (const event of events) {\n event(...args);\n }\n },\n set: (value) => {\n // Assign a default behavior!\n defaultEvent = value;\n }\n }\n });\n }\n }\n proto = Object.getPrototypeOf(proto);\n }\n }\n /**\n * Event subscription\n * @param name Name of event without the `on` prefix (ex: `log` to `onLog` event declared)\n * @param event Subscriber Function\n * @param abort Optional `AbortController` to stop this or multiple subscriptions in same time\n */\n on(name, event, abort) {\n if (!event) {\n throw Error('event to subscribe cannot be null');\n }\n const events = this._event(name);\n events.add(event);\n if (abort) {\n abort.signal.addEventListener('abort', () => {\n events.delete(event);\n });\n }\n }\n /**\n * Event subscription only one time, once time fired it's automatically unsubscribe\n * @param name Name of event without the `on` prefix (ex: `log` to `onLog` event declared)\n * @param event Subscriber Function\n * @param abort Optional `AbortController` to stop this or multiple subscriptions in same time\n */\n once(name, event, abort) {\n if (!event) {\n throw Error('event to subscribe cannot be null');\n }\n const events = this._event(name);\n events.add(() => {\n events.delete(event); // delete from events\n event(); // execute event\n });\n if (abort) {\n abort.signal.addEventListener('abort', () => {\n events.delete(event);\n });\n }\n }\n /**\n * Event unsubscription\n * @param name Name of event without the 'on' prefix (ex: 'log' to 'onLog' event declared)\n * @param event Unsubscriber Function, must be the one passed to {@link on} or {@link once} subscription methods\n */\n off(name, event) {\n if (!event) {\n throw Error('event to unsubscribe cannot be null');\n }\n this._event(name).delete(event);\n }\n _event(name) {\n const events = this._events.get(name.toLowerCase());\n if (!events) {\n throw Error('No event on' + name + ' on class ' + this.constructor.name);\n }\n return events;\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * Queue typed similar to a {@link https://en.cppreference.com/w/cpp/container/queue | std::queue<Type>} with possibility to limit the capacity like a FIFO\n * @example\n * const queue = new Queue<number>(2);\n * queue.push(1); // [1]\n * queue.push(2); // [1,2]\n * queue.push(3); // [2,3] 1 has been removed to respect 2 capacity\n */\nclass Queue {\n /**\n * Number of element in the queue\n */\n get size() {\n return this._queue.length;\n }\n /**\n * Maximum capacity for the queue, if not set queue has unlimited capacity\n */\n get capacity() {\n return this._capacity;\n }\n /**\n * Set a maximum capacity for the queue,\n * if you push new value exceding this capacity the firsts are removed (FIFO)\n * if set to undefined the queue is unlimited\n */\n set capacity(value) {\n this._capacity = value;\n if (value != null && this._queue.length > value) {\n this._queue.splice(0, this._queue.length - value);\n }\n }\n /**\n * The front element\n */\n get front() {\n return this._queue[0];\n }\n /**\n * The back element\n */\n get back() {\n return this._queue[this._queue.length - 1];\n }\n /**\n * Iterator though queue's elements\n */\n [Symbol.iterator]() {\n return this._queue[Symbol.iterator]();\n }\n /**\n * Instanciate a new queue object with the type passed as template\n * @param capacity if set it limits the size of the queue, any exceding element pops the first element pushed (FIFO)\n */\n constructor(capacity) {\n this._capacity = capacity;\n this._queue = new Array();\n }\n /**\n * Push a new element in the queue\n * @param value value of the element\n * @returns this\n */\n push(value) {\n if (this._capacity != null && this._queue.push(value) > this._capacity) {\n this.pop();\n }\n return this;\n }\n /**\n * Pop the first element from the queue\n * @returns The first element removed\n */\n pop() {\n return this._queue.shift();\n }\n /**\n * Clear all the elements, queue becomes empty\n * @returns this\n */\n clear() {\n this._queue.length = 0;\n return this;\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * A collection of number Queue<number> with the following efficient mathematic computation:\n * - minimum value in the collection\n * - maximum value in the collection\n * - average value of the collection\n */\nclass Numbers extends Queue {\n /**\n * minimum value in the collection, or 0 if colleciton is empty\n */\n get minimum() {\n return this._min;\n }\n /**\n * maximum value in the collection, or 0 if colleciton is empty\n */\n get maximum() {\n return this._max;\n }\n /**\n * average value of the collection, or 0 if collection if empty\n */\n get average() {\n if (this._average == null) {\n this._average = this.size ? this._sum / this.size : 0;\n }\n return this._average;\n }\n /**\n * Instantiate the collection of the number\n * @param capacity if set it limits the number of values stored, any exceding number pops the first number pushed (FIFO)\n */\n constructor(capacity) {\n super(capacity);\n this._sum = 0;\n this._min = 0;\n this._max = 0;\n }\n /**\n * Push a value to the back to the collection\n * @param value number to add\n * @returns this\n */\n push(value) {\n if (value > this._max) {\n this._max = value;\n }\n else if (value < this._min) {\n this._min = value;\n }\n this._average = undefined;\n this._sum += value;\n super.push(value);\n return this;\n }\n /**\n * Pop the front number from the collection\n * @returns the front number removed\n */\n pop() {\n const front = super.pop();\n if (front === this._max) {\n this._max = Math.max(0, ...this);\n }\n else if (front === this._min) {\n this._min = Math.min(0, ...this);\n }\n this._average = undefined;\n this._sum -= front || 0;\n return front;\n }\n /**\n * Clear all the numbers, collection becomes empty\n * @returns this\n */\n clear() {\n this._min = this._max = this._sum = 0;\n super.clear();\n return this;\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * Toolkit to deal with Session Description Protocol (SDP),\n * mainly to tranform a SDP string Offer/Answer to a manipulable JS object representation\n * @example\n * const peerConnection = new RTCPeerConnection();\n * peerConnection.createOffer()\n * .then( offer =>\n * // Change offer.sdp string to a JS manipulable object\n * const sdp = SDP.fromString(offer.sdp || '');\n * // Change a property of SDP\n * sdp.v = 2; // change SDP version\n * // Reserialize to the legal SDP string format\n * offer.sdp = SDP.toString(sdp);\n * // Set SDP offer to peerConnection\n * peerConnection.setLocalDescription(offer);\n * )\n */\nconst SDP = {\n /**\n * Unserialize SDP string to a manipulable JS object representation\n * It's an object with:\n * - root SDP properties\n * - media description iterable\n * @param lines SDP string reprensentation\n * @returns SDP object representation, iterable through media description\n * @example\n * [\n * group: \"DUNBLE 0 1\",\n * o: \"- 1699450751193623 0 IN IP4 0.0.0.0\",\n * s: \"-\",\n * t: \"0 0\",\n * v: \"0\",\n * ice-lite: \"\",\n * length: 2,\n * {\n * m: \"audio 9 UDP/TLS/RTP/SAVPF 111\",\n * c: \"IN IP4 0.0.0.0\",\n * rtcp: \"9\",\n * sendonly: \"\",\n * setup: \"passive\",\n * fingerprint: \"sha-256 51:36:ED:78:A4:9F:25:8C:39:9A:0E:A0:B4:9B:6E:04:37:FF:AD:96:93:71:43:88:2C:0B:0F:AB:6F:9A:52:B8\",\n * ice-ufrag: \"fa37\",\n * ice-pwd: \"JncCHryDsbzayy4cBWDxS2\",\n * rtcp-mux: \"\",\n * rtcp-rsize: \"\",\n * rtpmap: \"111 opus/48000/2\",\n * rtcp-fb: \"111 nack\",\n * id: \"0\",\n * fmtp: \"111 minptime=10;useinbandfec=1\",\n * candidate: \"1 1 udp 2130706431 89.105.221.108 56643 typ host\",\n * end-of-candidates: \"\"\n * },\n * {\n * m: \"video 9 UDP/TLS/RTP/SAVPF 106\",\n * c: \"IN IP4 0.0.0.0\",\n * rtcp: \"9\",\n * sendonly: \"\",\n * setup: \"passive\",\n * fingerprint: \"sha-256 51:36:ED:78:A4:9F:25:8C:39:9A:0E:A0:B4:9B:6E:04:37:FF:AD:96:93:71:43:88:2C:0B:0F:AB:6F:9A:52:B8\",\n * ice-ufrag: \"fa37\",\n * ice-pwd: \"JncCHryDsbzayy4cBWDxS2\",\n * rtcp-mux: \"\",\n * rtcp-rsize: \"\",\n * rtpmap: \"106 H264/90000\",\n * rtcp-fb: [\n * \"106 nack\",\n * \"106 goog-remb\"\n * ],\n * mid: \"1\",\n * fmtp: \"106 profile-level-id=42e01f;level-asymmetry-allowed=1;packetization-mode=1\",\n * candidate: \"1 1 udp 2130706431 89.105.221.108 56643 typ host\",\n * end-of-candidates: \"\"\n * }\n * ]\n */\n fromString(lines) {\n if (Array.isArray(lines)) {\n return lines; // already converted\n }\n const sdp = new Array();\n let media = sdp;\n let fingerprint;\n for (let line of lines.toString().split('\\n')) {\n line = line.trim();\n if (!line) {\n continue;\n }\n let key = line[0];\n const value = line.substring(line.indexOf('=') + 1).trim();\n switch (key.toLowerCase()) {\n case 'a': {\n if (!value) {\n continue;\n } // empty attribute!\n key = this.addAttribute(media, value);\n // save fingerprint to repeat it in medias\n if (sdp === media && key.toLowerCase() === 'fingerprint') {\n fingerprint = media.fingerprint;\n }\n break;\n }\n case 'm':\n if (sdp.length && fingerprint && !sdp[sdp.length - 1].fingerprint) {\n media.fingerprint = fingerprint;\n }\n sdp.push((media = { m: value }));\n break;\n default:\n media[key] = value;\n }\n }\n if (sdp.length && fingerprint && !sdp[sdp.length - 1].fingerprint) {\n media.fingerprint = fingerprint;\n }\n return sdp;\n },\n /**\n * Serialize SDP JS object to a SDP string legal representation\n * @param sdp SDP object reprensetation\n * @returns SDP string reprensentation\n */\n toString(sdp) {\n if (typeof sdp === 'string') {\n return sdp; // already converted\n }\n const medias = [];\n // https://www.cl.cam.ac.uk/~jac22/books/mm/book/node182.html\n let lines = 'v' in sdp ? 'v=' + sdp.v + '\\n' : '';\n if ('o' in sdp) {\n lines += 'o=' + sdp.o + '\\n';\n }\n if ('s' in sdp) {\n lines += 's=' + sdp.s + '\\n';\n }\n const obj = sdp;\n for (const key of Object.keys(sdp)) {\n if (key === 'v' || key === 'o' || key === 's') {\n continue;\n }\n const value = obj[key];\n if (value == null) {\n continue;\n } // ignore this key/value\n const index = parseInt(key);\n if (!isNaN(index)) {\n // Is a number! Media object!\n medias[index] = value;\n continue;\n }\n const count = (Array.isArray(value) && value.length) || 1; // value can be numeric!\n for (let i = 0; i < count; ++i) {\n const line = Array.isArray(value) && value.length ? value[i] : value;\n if (key.length > 1) {\n // when key is superior to 1 letter it's a attribute!\n lines += 'a=' + key;\n if (line) {\n lines += ':';\n }\n }\n else {\n lines += key + '=';\n }\n lines += line + '\\n';\n }\n }\n for (const media of medias) {\n lines += this.toString(media);\n }\n return lines;\n },\n /**\n * While set a property to a SDP object representation is possible directly,\n * we could prefer add a new property without overload a possible already existing value.\n * This function allows to add a property to our SDP representation:\n * - if the key's attribute doesn't exists yet it adds it like a simple JS property sdp[key] = value\n * - if the key's attribute exists already it morphs the value to a Array and push it inside\n * @param sdp the SDP object representation on which added the attribute\n * @param attribute the string attribut in a format \"key:value\" or just \"key\" to add an attribute without value\n * @returns the key part of the attribute added (or if value is empty it returns the same attribute as passed in argument)\n */\n addAttribute(sdp, attribute) {\n var _a;\n const a = SDP.parseAttribute(attribute);\n const value = (_a = a.value) !== null && _a !== void 0 ? _a : ''; // to allow to test if key exists even without value with if(sdp.key != null)\n const obj = sdp;\n const oldValue = obj[a.key];\n if (!oldValue) {\n obj[a.key] = value;\n }\n else if (Array.isArray(oldValue)) {\n oldValue.push(value);\n }\n else if (value !== oldValue) {\n obj[a.key] = [oldValue, value];\n }\n return a.key;\n },\n /**\n * While it's possible to delete a attribute manually on the SDP object representation with a delete sdp.key,\n * we could prefer remove only a value in a sdp.key array containing multiple values.\n * Like opposite to addAttribute this method allows to remove an unique attribute value.\n * @param sdp the SDP object representation on which removed the attribute\n * @param attribute the string attribut in a format \"key:value\" or just \"key\" to remove the whole attribute and all its values\n * @returns the key part of the attribute removed (or if value is empty it returns the same attribute as passed in argument)\n */\n removeAttribute(sdp, attribute) {\n const a = SDP.parseAttribute(attribute);\n const obj = sdp;\n if (a.value === undefined) {\n delete obj[attribute];\n return attribute;\n }\n const current = obj[attribute];\n if (Array.isArray(a.value)) {\n const i = current.findIndex((current) => current === a.value);\n if (i >= 0) {\n current.splice(i, 1);\n }\n }\n else if (current === a.value) {\n delete obj[attribute];\n }\n return a.key;\n },\n /**\n * Parse an attribute in a format \"key:value\"\n * @param attribute string attribute to parse\n * @returns the {key, value} result, with value undefined if attribute was a \"key\" without value\n */\n parseAttribute(attribute) {\n const found = attribute.indexOf(':');\n return {\n key: (found >= 0 ? attribute.substring(0, found) : attribute).trim(),\n value: found >= 0 ? attribute.substring(found + 1).trim() : undefined\n };\n }\n};\nObject.freeze(SDP);/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\nconst _decoder = new TextDecoder();\nconst _encoder = new TextEncoder();\n/* eslint-disable @typescript-eslint/no-explicit-any */\nconst _perf = performance; // to increase x10 now performance!\n/**\n * Some basic utility functions\n */\n/**\n * An empty lambda function, pratical to disable default behavior of function or events which are not expected to be null\n * @example\n * console.log = Util.EMPTY_FUNCTION; // disable logs without breaking calls\n */\nconst EMPTY_FUNCTION = () => { };\n/**\n * Efficient and high resolution timestamp in milliseconds elapsed since {@link Util.timeOrigin}\n */\nfunction time() {\n return Math.floor(_perf.now());\n}\n/**\n * Time origin represents the time when the application has started\n */\nfunction timeOrigin() {\n return Math.floor(_perf.now() + _perf.timeOrigin);\n}\n/**\n * Parse query and returns it in an easy-to-use Javascript object form\n * @param urlOrQueryOrSearch string, url, or searchParams containing query. If not set it uses `location.search` to determinate query.\n * @returns An javascript object containing each option\n */\nfunction options(urlOrQueryOrSearch = typeof location === 'undefined'\n ? undefined\n : location) {\n if (!urlOrQueryOrSearch) {\n return {};\n }\n try {\n const url = urlOrQueryOrSearch;\n urlOrQueryOrSearch = new URL(url).searchParams;\n }\n catch (e) {\n if (typeof urlOrQueryOrSearch == 'string') {\n if (urlOrQueryOrSearch.startsWith('?')) {\n urlOrQueryOrSearch = urlOrQueryOrSearch.substring(1);\n }\n urlOrQueryOrSearch = new URLSearchParams(urlOrQueryOrSearch);\n }\n }\n // works same if urlOrQueryOrSearch is null, integer, or a already object etc...\n return objectFrom(urlOrQueryOrSearch, { withType: true, noEmptyString: true });\n}\n/**\n * Returns an easy-to-use Javascript object something iterable, such as a Map, Set, or Array\n * @param value iterable input\n * @param params.withType `false`, if set it tries to cast string value to a JS number/boolean/undefined/null type.\n * @param params.noEmptyString `false`, if set it converts empty string value to a true boolean, usefull to allow a `if(result.key)` check for example\n * @returns An javascript object\n */\nfunction objectFrom(value, params) {\n params = Object.assign({ withType: false, noEmptyString: false }, params);\n const obj = {};\n if (!value) {\n return obj;\n }\n for (const [key, val] of objectEntries(value)) {\n value = val;\n if (params.withType && value != null && value.substring) {\n if (value) {\n const number = Number(value);\n if (isNaN(number)) {\n switch (value.toLowerCase()) {\n case 'true':\n value = true;\n break;\n case 'false':\n value = false;\n break;\n case 'null':\n value = null;\n break;\n case 'undefined':\n value = undefined;\n break;\n }\n }\n else {\n value = number;\n }\n }\n else if (params.noEmptyString) {\n // if empty string => TRUE to allow a if(options.key) check for example\n value = true;\n }\n }\n if (obj[key]) {\n if (!Array.isArray(obj[key])) {\n obj[key] = new Array(obj[key]);\n }\n obj[key].push(value);\n }\n else {\n obj[key] = value;\n }\n }\n return obj;\n}\n/**\n * Returns entries from something iterable, such as a Map, Set, or Array\n * @param value iterable input\n * @returns An javascript object\n */\nfunction objectEntries(value) {\n if (value.entries) {\n return value.entries();\n }\n return Array.from({\n [Symbol.iterator]: function* () {\n for (const key in value) {\n yield [key, value[key]];\n }\n }\n });\n}\n/**\n * Converts various data types, such as objects, strings, exceptions, errors,\n * or numbers, into a string representation. Since it offers a more comprehensive format,\n * this function is preferred to `JSON.stringify()`.\n * @param obj Any objects, strings, exceptions, errors, or number\n * @param params.space `''`, allows to configure space in the string representation\n * @param params.decimal `2`, allows to choose the number of decimal to display in the string representation\n * @param params.recursive `false`, allows to serialize recursively every object value, beware if a value refers to a already parsed value an infinite loop will occur.\n * @returns the final string representation\n */\n// Online Javascript Editor for free\n// Write, Edit and Run your Javascript code using JS Online Compiler\nfunction stringify(obj, params = {}) {\n params = Object.assign({ space: ' ', decimal: 2, recursive: 1 }, params);\n if (obj == null) {\n return String(obj);\n }\n const error = obj.error || obj.message;\n if (error) {\n // is a error!\n obj = error;\n }\n if (obj.toFixed) {\n return obj.toFixed(Number(params.decimal) || 0);\n }\n if (obj.substring || !params.recursive) {\n // is already a string OR has to be stringified\n return String(obj);\n }\n const space = params.space || '';\n if (Array.isArray(obj)) {\n // Array!\n let res = '';\n for (const value of obj) {\n res += (res ? ',' : '[') + space;\n res += stringify(value, Object.assign(params, { recursive: params.recursive - 1 }));\n }\n return (res += space + ']');\n }\n if (obj.byteLength != null && (obj === null || obj === void 0 ? void 0 : obj[Symbol.iterator])) {\n // Binary!\n return _decoder.decode(obj);\n }\n let res = '';\n for (const name in obj) {\n res += (res ? ',' : '{') + space + name + ':';\n res += stringify(obj[name], Object.assign(params, { recursive: params.recursive - 1 }));\n }\n return (res += space + '}');\n}\n/**\n * Encode a string to a binary representation\n * @param value string value to convert\n * @returns binary conversion\n */\nfunction toBin(value) {\n return _encoder.encode(value);\n}\n/**\n * Execute a promise in a safe way with a timeout if caller doesn't resolve it in the accurate time\n */\nfunction safePromise(timeout, promise) {\n // Returns a race between our timeout and the passed in promise\n let timer;\n return Promise.race([\n promise instanceof Promise ? promise : new Promise(promise),\n new Promise((resolve, reject) => (timer = setTimeout(() => reject('timed out in ' + timeout + 'ms'), timeout)))\n ]).finally(() => clearTimeout(timer));\n}var Util=/*#__PURE__*/Object.freeze({__proto__:null,EMPTY_FUNCTION:EMPTY_FUNCTION,objectEntries:objectEntries,objectFrom:objectFrom,options:options,safePromise:safePromise,stringify:stringify,time:time,timeOrigin:timeOrigin,toBin:toBin});/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\n/**\n * The WebSocketReliable class extends WebSocket to bring up the following improvements:\n * - Fix all possible unintentional closing ways to get always a related error message, {@link onClose | onClose(error?) event}\n * - Make possible message sending while connecting. Indeed no need to wait {@link onOpen} before to send message,\n * you can open the socket and immediately send messages, it will be queue and flushs on connection etablishment\n * - Make possible a delayed connection, or a reconnection. Indeed you can create an unconnected Websocket instance\n * without passing any url argument and starts the conneciton more later with {@link WebSocketReliable.open(url) | open(url)} method\n * - Make possible to control sending/queueing message: send method take an optional queueing=true argument to\n * queue message rather send it, a futur call to flush will send it. Then queueing getter allows to handle the queue\n * if need to purge it or remove some queued message. Use it all together can help to prioritize messages or control overload.\n * @example\n * const ws = new WebSocketReliable(url);\n * ws.onClose = (error?:string) => {\n * if(error) {\n * console.error(error);\n * }\n * // reconnection attempt every seconds\n * setTimeout(() => ws.open(url), 1000);\n * }\n * ws.onMessage = (message:string) => {\n * console.log(message);\n * }\n * ws.send('hello'); // send immediatly a hello message is possible (no need to wait onOpen)\n */\nclass WebSocketReliable extends EventEmitter {\n /**\n * @event `open` fired when socket is connected\n */\n onOpen() { }\n /**\n * @event `message` fired on message reception\n * @param message can be binary or string.\n * If you subscribe to the event with message as string type (and not union),\n * it means that you know that all your messages are distributed in a string format\n */\n onMessage(message) { }\n /**\n * @event `close` fired on websocket close\n * @param error error description on an improper closure\n */\n onClose(error) {\n if (error) {\n console.error(error);\n }\n }\n /**\n * binaryType, fix binary type to arrayBuffer\n */\n get binaryType() {\n return 'arraybuffer';\n }\n /**\n * url of connection\n */\n get url() {\n var _a, _b;\n return (_b = (_a = this._ws) === null || _a === void 0 ? void 0 : _a.url) !== null && _b !== void 0 ? _b : '';\n }\n /**\n * extensions negociated by the server\n */\n get extensions() {\n var _a, _b;\n return (_b = (_a = this._ws) === null || _a === void 0 ? void 0 : _a.extensions) !== null && _b !== void 0 ? _b : '';\n }\n /**\n * protocol negociated by the server\n */\n get protocol() {\n var _a, _b;\n return (_b = (_a = this._ws) === null || _a === void 0 ? void 0 : _a.protocol) !== null && _b !== void 0 ? _b : '';\n }\n /**\n * opened equals true when connection is etablished, in other word when onOpen event is fired\n */\n get opened() {\n return this._opened;\n }\n /**\n * {@link https://developer.mozilla.org/docs/Web/API/WebSocket/readyState | Official websocket readyState}\n */\n get readyState() {\n return this._ws ? this._ws.readyState : 3;\n }\n /**\n * True when connection is closed, in other words when {@link onClose} event is fired\n * or when WebSocketReliable is build without url (disconnected creation)\n */\n get closed() {\n return this._closed;\n }\n /**\n * The number of bytes of data that were queued during calls to send() but not yet transmitted to the network\n */\n get bufferedAmount() {\n var _a;\n return this._queueingBytes + (((_a = this._ws) === null || _a === void 0 ? void 0 : _a.bufferedAmount) || 0);\n }\n /**\n * Queued messages from a call to send() waiting to be transmit one time websocket connection opened (or with an explicit call to flush() method)\n */\n get queueing() {\n return this._queueing;\n }\n /**\n * Create a WebSocketReliable object, and open it if an url is passed in argument\n * @param url URL of the WebSocket endpoint or null to start the connection later\n */\n constructor(url, protocols) {\n super();\n this._queueing = [];\n this._queueingBytes = 0;\n this._opened = false;\n this._closed = true;\n if (url) {\n this.open(url, protocols);\n }\n }\n /**\n * Open a WebSocket connection\n * @param url url of the websocket endpoint\n * @returns this\n */\n open(url, protocols) {\n this._closed = false;\n const ws = (this._ws = new WebSocket(url, protocols));\n ws.binaryType = this.binaryType;\n ws.onmessage = e => this.onMessage(e.data);\n // Add details and fix close ways\n ws.onclose = (e) => {\n if (!this._opened) {\n // close during connection\n this.close(url.toString() + ' connection failed (' + String(e.reason || e.code) + ')');\n }\n else if (e.code === 1000 || e.code === 1005) {\n // normal disconnection from server (no error code)\n this.close(url.toString() + ' shutdown');\n }\n else {\n // disconnection from server\n this.close(url.toString() + ' disconnection (' + String(e.reason || e.code) + ')');\n }\n };\n // Wrap send method to queue messages until connection is established.\n ws.onopen = _ => {\n this._opened = true;\n this.flush();\n this.onOpen();\n };\n return this;\n }\n /**\n * Send a message\n * @param message\n * @param queueing When set it reports the sending to a more later call to flush\n * @returns this\n */\n send(message, queueing = false) {\n if (!this._ws) {\n throw Error('Open socket before to send data');\n }\n if (queueing || !this._opened) {\n this._queueing.push(message);\n this._queueingBytes += typeof message === 'string' ? message.length : message.byteLength;\n }\n else {\n this._ws.send(message);\n }\n return this;\n }\n /**\n * Send queueing messages\n */\n flush() {\n if (this._ws) {\n for (const message of this._queueing) {\n this._ws.send(message);\n }\n }\n this._queueing.length = 0;\n this._queueingBytes = 0;\n }\n /**\n * Close websocket\n * @param error the error reason if is not a proper close\n */\n close(error) {\n if (!this._ws || this._closed) {\n return;\n }\n this._closed = true;\n this._ws.onopen = this._ws.onclose = this._ws.onmessage = null; // otherwise can receive message AFTER close!\n this._ws.close(); // Don't set to undefined to keep this._ws properties valid!\n // release resources!\n this._opened = false;\n this._queueing.length = 0;\n this._queueingBytes = 0;\n this.onClose(error);\n }\n}/**\n * Copyright 2024 Ceeblue B.V.\n * This file is part of https://github.com/CeeblueTV/web-utils which is released under GNU Affero General Public License.\n * See file LICENSE or go to https://spdx.org/licenses/AGPL-3.0-or-later.html for full license details.\n */\nconst VERSION = '1.2.0';export{BinaryReader,BinaryWriter,BitReader,Connect,EventEmitter,NetAddress,Numbers,Queue,SDP,Util,VERSION,WebSocketReliable};//# sourceMappingURL=web-utils.js.map\n"],"names":["BinaryReader","constructor","data","this","_data","Uint8Array","buffer","byteOffset","byteLength","_size","_position","_view","DataView","size","available","value","position","reset","shrink","rest","next","count","read8","getUint8","read16","getUint16","read24","read32","getUint32","readFloat","getFloat32","readDouble","getFloat64","read7Bit","bytes","Error","byte","result","readString","String","fromCharCode","read","readHex","hex","toString","slice","subarray","BinaryWriter","view","capacity","dataOrSize","offset","length","_isConst","reserve","clear","write","i","charCodeAt","set","write8","write16","setUint16","write24","setUint8","write32","setUint32","writeFloat","setFloat32","writeDouble","setFloat64","write7Bit","bits","front","writeString","writeHex","parseInt","substring","undefined","BitReader","_bit","gotten","NetAddress","fixProtocol","protocol","address","found","indexOf","charAt","toLowerCase","endsWith","domain","_domain","port","_port","_address","valueOf","defaultPort","pos","lastIndexOf","Type","Connect","Object","freeze","__proto__","buildURL","type","params","url","URL","host","pathname","HESP","streamName","WEBRTC","WEBRTS","META","DATA","console","warn","accessToken","searchParams","key","query","EventEmitter","_events","Map","proto","getPrototypeOf","prototype","name","getOwnPropertyNames","startsWith","Function","events","Set","defaultEvent","defineProperties","get","args","call","event","on","abort","_event","add","signal","addEventListener","delete","once","off","Queue","_queue","_capacity","splice","back","Symbol","iterator","Array","push","pop","shift","Numbers","minimum","_min","maximum","_max","average","_average","_sum","super","Math","max","min","SDP","fromString","lines","isArray","sdp","fingerprint","media","line","split","trim","addAttribute","m","medias","v","o","s","obj","keys","index","isNaN","attribute","_a","a","parseAttribute","oldValue","removeAttribute","current","findIndex","_decoder","TextDecoder","_encoder","TextEncoder","_perf","performance","objectFrom","assign","withType","noEmptyString","val","objectEntries","number","Number","entries","from","Util","EMPTY_FUNCTION","options","urlOrQueryOrSearch","location","e","URLSearchParams","safePromise","timeout","promise","timer","Promise","race","resolve","reject","setTimeout","finally","clearTimeout","stringify","space","decimal","recursive","error","message","toFixed","res","decode","time","floor","now","timeOrigin","toBin","encode","WebSocketReliable","onOpen","onMessage","onClose","binaryType","_b","_ws","extensions","opened","_opened","readyState","closed","_closed","bufferedAmount","_queueingBytes","queueing","_queueing","protocols","open","ws","WebSocket","onmessage","onclose","code","close","reason","onopen","_","flush","send","VERSION"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ceeblue/web-utils",
3
- "version": "1.0.1",
3
+ "version": "1.2.0",
4
4
  "description": "Ceeblue web framework",
5
5
  "keywords": [
6
6
  "utils"
@@ -67,6 +67,6 @@
67
67
  }
68
68
  },
69
69
  "publishConfig": {
70
- "access": "restricted"
70
+ "access": "public"
71
71
  }
72
72
  }