@hubui/client 0.1.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.
@@ -0,0 +1,2 @@
1
+ function _mergeNamespaces$1(e,t){return t.forEach(function(t){t&&"string"!=typeof t&&!Array.isArray(t)&&Object.keys(t).forEach(function(i){if("default"!==i&&!(i in e)){var n=Object.getOwnPropertyDescriptor(t,i);Object.defineProperty(e,i,n.get?n:{enumerable:!0,get:function(){return t[i]}})}})}),Object.freeze(e)}var e=Object.defineProperty,o=(t,i,n)=>((t,i,n)=>i in t?e(t,i,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[i]=n)(t,"symbol"!=typeof i?i+"":i,n);class _{constructor(){o(this,"_locking"),o(this,"_locks"),this._locking=Promise.resolve(),this._locks=0}isLocked(){return this._locks>0}lock(){let e;this._locks+=1;const t=new Promise(t=>e=()=>{this._locks-=1,t()}),i=this._locking.then(()=>e);return this._locking=this._locking.then(()=>t),i}}function assert(e,t){if(!e)throw new Error(t)}function assertInt32(e){if("number"!=typeof e)throw new Error("invalid int 32: "+typeof e);if(!Number.isInteger(e)||e>2147483647||e<-2147483648)throw new Error("invalid int 32: "+e)}function assertUInt32(e){if("number"!=typeof e)throw new Error("invalid uint 32: "+typeof e);if(!Number.isInteger(e)||e>4294967295||e<0)throw new Error("invalid uint 32: "+e)}function assertFloat32(e){if("number"!=typeof e)throw new Error("invalid float 32: "+typeof e);if(Number.isFinite(e)&&(e>34028234663852886e22||e<-34028234663852886e22))throw new Error("invalid float 32: "+e)}const t=Symbol("@bufbuild/protobuf/enum-type");function getEnumType(e){const i=e[t];return assert(i,"missing enum type on enum object"),i}function setEnumType(e,i,n,s){e[t]=makeEnumType(i,n.map(t=>({no:t.no,name:t.name,localName:e[t.no]})))}function makeEnumType(e,t,i){const n=Object.create(null),s=Object.create(null),a=[];for(const e of t){const t=normalizeEnumValue(e);a.push(t),n[e.name]=t,s[e.no]=t}return{typeName:e,values:a,findName:e=>n[e],findNumber:e=>s[e]}}function makeEnum(e,t,i){const n={};for(const e of t){const t=normalizeEnumValue(e);n[t.localName]=t.no,n[t.no]=t.localName}return setEnumType(n,e,t),n}function normalizeEnumValue(e){return"localName"in e?e:Object.assign(Object.assign({},e),{localName:e.name})}class Message{equals(e){return this.getType().runtime.util.equals(this.getType(),this,e)}clone(){return this.getType().runtime.util.clone(this)}fromBinary(e,t){const i=this.getType().runtime.bin,n=i.makeReadOptions(t);return i.readMessage(this,n.readerFactory(e),e.byteLength,n),this}fromJson(e,t){const i=this.getType(),n=i.runtime.json,s=n.makeReadOptions(t);return n.readMessage(i,e,s,this),this}fromJsonString(e,t){let i;try{i=JSON.parse(e)}catch(e){throw new Error("cannot decode ".concat(this.getType().typeName," from JSON: ").concat(e instanceof Error?e.message:String(e)))}return this.fromJson(i,t)}toBinary(e){const t=this.getType().runtime.bin,i=t.makeWriteOptions(e),n=i.writerFactory();return t.writeMessage(this,n,i),n.finish()}toJson(e){const t=this.getType().runtime.json,i=t.makeWriteOptions(e);return t.writeMessage(this,i)}toJsonString(e){var t;const i=this.toJson(e);return JSON.stringify(i,null,null!==(t=null==e?void 0:e.prettySpaces)&&void 0!==t?t:0)}toJSON(){return this.toJson({emitDefaultValues:!0})}getType(){return Object.getPrototypeOf(this).constructor}}function varint64read(){let e=0,t=0;for(let i=0;i<28;i+=7){let n=this.buf[this.pos++];if(e|=(127&n)<<i,!(128&n))return this.assertBounds(),[e,t]}let i=this.buf[this.pos++];if(e|=(15&i)<<28,t=(112&i)>>4,!(128&i))return this.assertBounds(),[e,t];for(let i=3;i<=31;i+=7){let n=this.buf[this.pos++];if(t|=(127&n)<<i,!(128&n))return this.assertBounds(),[e,t]}throw new Error("invalid varint")}function varint64write(e,t,i){for(let n=0;n<28;n+=7){const s=e>>>n,a=!(s>>>7==0&&0==t),c=255&(a?128|s:s);if(i.push(c),!a)return}const n=e>>>28&15|(7&t)<<4,s=!!(t>>3);if(i.push(255&(s?128|n:n)),s){for(let e=3;e<31;e+=7){const n=t>>>e,s=!(n>>>7==0),a=255&(s?128|n:n);if(i.push(a),!s)return}i.push(t>>>31&1)}}const i=4294967296;function int64FromString(e){const t="-"===e[0];t&&(e=e.slice(1));const n=1e6;let s=0,a=0;function add1e6digit(t,c){const l=Number(e.slice(t,c));a*=n,s=s*n+l,s>=i&&(a+=s/i|0,s%=i)}return add1e6digit(-24,-18),add1e6digit(-18,-12),add1e6digit(-12,-6),add1e6digit(-6),t?negate(s,a):newBits(s,a)}function uInt64ToString(e,t){if(({lo:e,hi:t}=function(e,t){return{lo:e>>>0,hi:t>>>0}}(e,t)),t<=2097151)return String(i*t+e);const n=16777215&(e>>>24|t<<8),s=t>>16&65535;let a=(16777215&e)+6777216*n+6710656*s,c=n+8147497*s,l=2*s;const u=1e7;return a>=u&&(c+=Math.floor(a/u),a%=u),c>=u&&(l+=Math.floor(c/u),c%=u),l.toString()+decimalFrom1e7WithLeadingZeros(c)+decimalFrom1e7WithLeadingZeros(a)}function newBits(e,t){return{lo:0|e,hi:0|t}}function negate(e,t){return t=~t,e?e=1+~e:t+=1,newBits(e,t)}const decimalFrom1e7WithLeadingZeros=e=>{const t=String(e);return"0000000".slice(t.length)+t};function varint32write(e,t){if(e>=0){for(;e>127;)t.push(127&e|128),e>>>=7;t.push(e)}else{for(let i=0;i<9;i++)t.push(127&e|128),e>>=7;t.push(1)}}function varint32read(){let e=this.buf[this.pos++],t=127&e;if(!(128&e))return this.assertBounds(),t;if(e=this.buf[this.pos++],t|=(127&e)<<7,!(128&e))return this.assertBounds(),t;if(e=this.buf[this.pos++],t|=(127&e)<<14,!(128&e))return this.assertBounds(),t;if(e=this.buf[this.pos++],t|=(127&e)<<21,!(128&e))return this.assertBounds(),t;e=this.buf[this.pos++],t|=(15&e)<<28;for(let t=5;128&e&&t<10;t++)e=this.buf[this.pos++];if(128&e)throw new Error("invalid varint");return this.assertBounds(),t>>>0}const n=function(){const e=new DataView(new ArrayBuffer(8));if("function"==typeof BigInt&&"function"==typeof e.getBigInt64&&"function"==typeof e.getBigUint64&&"function"==typeof e.setBigInt64&&"function"==typeof e.setBigUint64&&("object"!=typeof process||"object"!=typeof process.env||"1"!==process.env.BUF_BIGINT_DISABLE)){const t=BigInt("-9223372036854775808"),i=BigInt("9223372036854775807"),n=BigInt("0"),s=BigInt("18446744073709551615");return{zero:BigInt(0),supported:!0,parse(e){const n="bigint"==typeof e?e:BigInt(e);if(n>i||n<t)throw new Error("int64 invalid: ".concat(e));return n},uParse(e){const t="bigint"==typeof e?e:BigInt(e);if(t>s||t<n)throw new Error("uint64 invalid: ".concat(e));return t},enc(t){return e.setBigInt64(0,this.parse(t),!0),{lo:e.getInt32(0,!0),hi:e.getInt32(4,!0)}},uEnc(t){return e.setBigInt64(0,this.uParse(t),!0),{lo:e.getInt32(0,!0),hi:e.getInt32(4,!0)}},dec:(t,i)=>(e.setInt32(0,t,!0),e.setInt32(4,i,!0),e.getBigInt64(0,!0)),uDec:(t,i)=>(e.setInt32(0,t,!0),e.setInt32(4,i,!0),e.getBigUint64(0,!0))}}const assertInt64String=e=>assert(/^-?[0-9]+$/.test(e),"int64 invalid: ".concat(e)),assertUInt64String=e=>assert(/^[0-9]+$/.test(e),"uint64 invalid: ".concat(e));return{zero:"0",supported:!1,parse:e=>("string"!=typeof e&&(e=e.toString()),assertInt64String(e),e),uParse:e=>("string"!=typeof e&&(e=e.toString()),assertUInt64String(e),e),enc:e=>("string"!=typeof e&&(e=e.toString()),assertInt64String(e),int64FromString(e)),uEnc:e=>("string"!=typeof e&&(e=e.toString()),assertUInt64String(e),int64FromString(e)),dec:(e,t)=>function(e,t){let i=newBits(e,t);const n=2147483648&i.hi;n&&(i=negate(i.lo,i.hi));const s=uInt64ToString(i.lo,i.hi);return n?"-"+s:s}(e,t),uDec:(e,t)=>uInt64ToString(e,t)}}();var s,a,c;function scalarEquals(e,t,i){if(t===i)return!0;if(e==s.BYTES){if(!(t instanceof Uint8Array&&i instanceof Uint8Array))return!1;if(t.length!==i.length)return!1;for(let e=0;e<t.length;e++)if(t[e]!==i[e])return!1;return!0}switch(e){case s.UINT64:case s.FIXED64:case s.INT64:case s.SFIXED64:case s.SINT64:return t==i}return!1}function scalarZeroValue(e,t){switch(e){case s.BOOL:return!1;case s.UINT64:case s.FIXED64:case s.INT64:case s.SFIXED64:case s.SINT64:return 0==t?n.zero:"0";case s.DOUBLE:case s.FLOAT:return 0;case s.BYTES:return new Uint8Array(0);case s.STRING:return"";default:return 0}}function isScalarZeroValue(e,t){switch(e){case s.BOOL:return!1===t;case s.STRING:return""===t;case s.BYTES:return t instanceof Uint8Array&&!t.byteLength;default:return 0==t}}!function(e){e[e.DOUBLE=1]="DOUBLE",e[e.FLOAT=2]="FLOAT",e[e.INT64=3]="INT64",e[e.UINT64=4]="UINT64",e[e.INT32=5]="INT32",e[e.FIXED64=6]="FIXED64",e[e.FIXED32=7]="FIXED32",e[e.BOOL=8]="BOOL",e[e.STRING=9]="STRING",e[e.BYTES=12]="BYTES",e[e.UINT32=13]="UINT32",e[e.SFIXED32=15]="SFIXED32",e[e.SFIXED64=16]="SFIXED64",e[e.SINT32=17]="SINT32",e[e.SINT64=18]="SINT64"}(s||(s={})),function(e){e[e.BIGINT=0]="BIGINT",e[e.STRING=1]="STRING"}(a||(a={})),function(e){e[e.Varint=0]="Varint",e[e.Bit64=1]="Bit64",e[e.LengthDelimited=2]="LengthDelimited",e[e.StartGroup=3]="StartGroup",e[e.EndGroup=4]="EndGroup",e[e.Bit32=5]="Bit32"}(c||(c={}));class BinaryWriter{constructor(e){this.stack=[],this.textEncoder=null!=e?e:new TextEncoder,this.chunks=[],this.buf=[]}finish(){this.chunks.push(new Uint8Array(this.buf));let e=0;for(let t=0;t<this.chunks.length;t++)e+=this.chunks[t].length;let t=new Uint8Array(e),i=0;for(let e=0;e<this.chunks.length;e++)t.set(this.chunks[e],i),i+=this.chunks[e].length;return this.chunks=[],t}fork(){return this.stack.push({chunks:this.chunks,buf:this.buf}),this.chunks=[],this.buf=[],this}join(){let e=this.finish(),t=this.stack.pop();if(!t)throw new Error("invalid state, fork stack empty");return this.chunks=t.chunks,this.buf=t.buf,this.uint32(e.byteLength),this.raw(e)}tag(e,t){return this.uint32((e<<3|t)>>>0)}raw(e){return this.buf.length&&(this.chunks.push(new Uint8Array(this.buf)),this.buf=[]),this.chunks.push(e),this}uint32(e){for(assertUInt32(e);e>127;)this.buf.push(127&e|128),e>>>=7;return this.buf.push(e),this}int32(e){return assertInt32(e),varint32write(e,this.buf),this}bool(e){return this.buf.push(e?1:0),this}bytes(e){return this.uint32(e.byteLength),this.raw(e)}string(e){let t=this.textEncoder.encode(e);return this.uint32(t.byteLength),this.raw(t)}float(e){assertFloat32(e);let t=new Uint8Array(4);return new DataView(t.buffer).setFloat32(0,e,!0),this.raw(t)}double(e){let t=new Uint8Array(8);return new DataView(t.buffer).setFloat64(0,e,!0),this.raw(t)}fixed32(e){assertUInt32(e);let t=new Uint8Array(4);return new DataView(t.buffer).setUint32(0,e,!0),this.raw(t)}sfixed32(e){assertInt32(e);let t=new Uint8Array(4);return new DataView(t.buffer).setInt32(0,e,!0),this.raw(t)}sint32(e){return assertInt32(e),varint32write(e=(e<<1^e>>31)>>>0,this.buf),this}sfixed64(e){let t=new Uint8Array(8),i=new DataView(t.buffer),s=n.enc(e);return i.setInt32(0,s.lo,!0),i.setInt32(4,s.hi,!0),this.raw(t)}fixed64(e){let t=new Uint8Array(8),i=new DataView(t.buffer),s=n.uEnc(e);return i.setInt32(0,s.lo,!0),i.setInt32(4,s.hi,!0),this.raw(t)}int64(e){let t=n.enc(e);return varint64write(t.lo,t.hi,this.buf),this}sint64(e){let t=n.enc(e),i=t.hi>>31;return varint64write(t.lo<<1^i,(t.hi<<1|t.lo>>>31)^i,this.buf),this}uint64(e){let t=n.uEnc(e);return varint64write(t.lo,t.hi,this.buf),this}}class BinaryReader{constructor(e,t){this.varint64=varint64read,this.uint32=varint32read,this.buf=e,this.len=e.length,this.pos=0,this.view=new DataView(e.buffer,e.byteOffset,e.byteLength),this.textDecoder=null!=t?t:new TextDecoder}tag(){let e=this.uint32(),t=e>>>3,i=7&e;if(t<=0||i<0||i>5)throw new Error("illegal tag: field no "+t+" wire type "+i);return[t,i]}skip(e,t){let i=this.pos;switch(e){case c.Varint:for(;128&this.buf[this.pos++];);break;case c.Bit64:this.pos+=4;case c.Bit32:this.pos+=4;break;case c.LengthDelimited:let i=this.uint32();this.pos+=i;break;case c.StartGroup:for(;;){const[e,i]=this.tag();if(i===c.EndGroup){if(void 0!==t&&e!==t)throw new Error("invalid end group tag");break}this.skip(i,e)}break;default:throw new Error("cant skip wire type "+e)}return this.assertBounds(),this.buf.subarray(i,this.pos)}assertBounds(){if(this.pos>this.len)throw new RangeError("premature EOF")}int32(){return 0|this.uint32()}sint32(){let e=this.uint32();return e>>>1^-(1&e)}int64(){return n.dec(...this.varint64())}uint64(){return n.uDec(...this.varint64())}sint64(){let[e,t]=this.varint64(),i=-(1&e);return e=(e>>>1|(1&t)<<31)^i,t=t>>>1^i,n.dec(e,t)}bool(){let[e,t]=this.varint64();return 0!==e||0!==t}fixed32(){return this.view.getUint32((this.pos+=4)-4,!0)}sfixed32(){return this.view.getInt32((this.pos+=4)-4,!0)}fixed64(){return n.uDec(this.sfixed32(),this.sfixed32())}sfixed64(){return n.dec(this.sfixed32(),this.sfixed32())}float(){return this.view.getFloat32((this.pos+=4)-4,!0)}double(){return this.view.getFloat64((this.pos+=8)-8,!0)}bytes(){let e=this.uint32(),t=this.pos;return this.pos+=e,this.assertBounds(),this.buf.subarray(t,t+e)}string(){return this.textDecoder.decode(this.bytes())}}function createExtensionContainer(e){const t=e.field.localName,i=Object.create(null);return i[t]=function(e){const t=e.field;if(t.repeated)return[];if(void 0!==t.default)return t.default;switch(t.kind){case"enum":return t.T.values[0].no;case"scalar":return scalarZeroValue(t.T,t.L);case"message":const e=t.T,i=new e;return e.fieldWrapper?e.fieldWrapper.unwrapField(i):i;case"map":throw"map fields are not allowed to be extensions"}}(e),[i,()=>i[t]]}let l="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".split(""),u=[];for(let e=0;e<l.length;e++)u[l[e].charCodeAt(0)]=e;u["-".charCodeAt(0)]=l.indexOf("+"),u["_".charCodeAt(0)]=l.indexOf("/");const h={dec(e){let t=3*e.length/4;"="==e[e.length-2]?t-=2:"="==e[e.length-1]&&(t-=1);let i,n=new Uint8Array(t),s=0,a=0,c=0;for(let t=0;t<e.length;t++){if(i=u[e.charCodeAt(t)],void 0===i)switch(e[t]){case"=":a=0;case"\n":case"\r":case"\t":case" ":continue;default:throw Error("invalid base64 string.")}switch(a){case 0:c=i,a=1;break;case 1:n[s++]=c<<2|(48&i)>>4,c=i,a=2;break;case 2:n[s++]=(15&c)<<4|(60&i)>>2,c=i,a=3;break;case 3:n[s++]=(3&c)<<6|i,a=0}}if(1==a)throw Error("invalid base64 string.");return n.subarray(0,s)},enc(e){let t,i="",n=0,s=0;for(let a=0;a<e.length;a++)switch(t=e[a],n){case 0:i+=l[t>>2],s=(3&t)<<4,n=1;break;case 1:i+=l[s|t>>4],s=(15&t)<<2,n=2;break;case 2:i+=l[s|t>>6],i+=l[63&t],n=0}return n&&(i+=l[s],i+="=",1==n&&(i+="=")),i}};function getExtension(e,t,i){assertExtendee(t,e);const n=t.runtime.bin.makeReadOptions(i),s=function(e,t){if(!t.repeated&&("enum"==t.kind||"scalar"==t.kind)){for(let i=e.length-1;i>=0;--i)if(e[i].no==t.no)return[e[i]];return[]}return e.filter(e=>e.no===t.no)}(e.getType().runtime.bin.listUnknownFields(e),t.field),[a,c]=createExtensionContainer(t);for(const e of s)t.runtime.bin.readField(a,n.readerFactory(e.data),t.field,e.wireType,n);return c()}function setExtension(e,t,i,n){assertExtendee(t,e);const s=t.runtime.bin.makeReadOptions(n),a=t.runtime.bin.makeWriteOptions(n);if(hasExtension(e,t)){const i=e.getType().runtime.bin.listUnknownFields(e).filter(e=>e.no!=t.field.no);e.getType().runtime.bin.discardUnknownFields(e);for(const t of i)e.getType().runtime.bin.onUnknownField(e,t.no,t.wireType,t.data)}const c=a.writerFactory();let l=t.field;l.opt||l.repeated||"enum"!=l.kind&&"scalar"!=l.kind||(l=Object.assign(Object.assign({},t.field),{opt:!0})),t.runtime.bin.writeField(l,i,c,a);const u=s.readerFactory(c.finish());for(;u.pos<u.len;){const[t,i]=u.tag(),n=u.skip(i,t);e.getType().runtime.bin.onUnknownField(e,t,i,n)}}function hasExtension(e,t){const i=e.getType();return t.extendee.typeName===i.typeName&&!!i.runtime.bin.listUnknownFields(e).find(e=>e.no==t.field.no)}function assertExtendee(e,t){assert(e.extendee.typeName==t.getType().typeName,"extension ".concat(e.typeName," can only be applied to message ").concat(e.extendee.typeName))}function isFieldSet(e,t){const i=e.localName;if(e.repeated)return t[i].length>0;if(e.oneof)return t[e.oneof.localName].case===i;switch(e.kind){case"enum":case"scalar":return e.opt||e.req?void 0!==t[i]:"enum"==e.kind?t[i]!==e.T.values[0].no:!isScalarZeroValue(e.T,t[i]);case"message":return void 0!==t[i];case"map":return Object.keys(t[i]).length>0}}function clearField(e,t){const i=e.localName,n=!e.opt&&!e.req;if(e.repeated)t[i]=[];else if(e.oneof)t[e.oneof.localName]={case:void 0};else switch(e.kind){case"map":t[i]={};break;case"enum":t[i]=n?e.T.values[0].no:void 0;break;case"scalar":t[i]=n?scalarZeroValue(e.T,e.L):void 0;break;case"message":t[i]=void 0}}function isMessage(e,t){if(null===e||"object"!=typeof e)return!1;if(!Object.getOwnPropertyNames(Message.prototype).every(t=>t in e&&"function"==typeof e[t]))return!1;const i=e.getType();return null!==i&&"function"==typeof i&&"typeName"in i&&"string"==typeof i.typeName&&(void 0===t||i.typeName==t.typeName)}function wrapField(e,t){return isMessage(t)||!e.fieldWrapper?t:e.fieldWrapper.wrapField(t)}s.DOUBLE,s.FLOAT,s.INT64,s.UINT64,s.INT32,s.UINT32,s.BOOL,s.STRING,s.BYTES;const p={ignoreUnknownFields:!1},m={emitDefaultValues:!1,enumAsInteger:!1,useProtoFieldName:!1,prettySpaces:0};function makeReadOptions$1(e){return e?Object.assign(Object.assign({},p),e):p}function makeWriteOptions$1(e){return e?Object.assign(Object.assign({},m),e):m}const g=Symbol(),v=Symbol();function debugJsonValue(e){if(null===e)return"null";switch(typeof e){case"object":return Array.isArray(e)?"array":"object";case"string":return e.length>100?"string":'"'.concat(e.split('"').join('\\"'),'"');default:return String(e)}}function readField$1(e,t,i,n,s){let c=i.localName;if(i.repeated){if(assert("map"!=i.kind),null===t)return;if(!Array.isArray(t))throw new Error("cannot decode field ".concat(s.typeName,".").concat(i.name," from JSON: ").concat(debugJsonValue(t)));const a=e[c];for(const e of t){if(null===e)throw new Error("cannot decode field ".concat(s.typeName,".").concat(i.name," from JSON: ").concat(debugJsonValue(e)));switch(i.kind){case"message":a.push(i.T.fromJson(e,n));break;case"enum":const t=readEnum(i.T,e,n.ignoreUnknownFields,!0);t!==v&&a.push(t);break;case"scalar":try{a.push(readScalar$1(i.T,e,i.L,!0))}catch(t){let n="cannot decode field ".concat(s.typeName,".").concat(i.name," from JSON: ").concat(debugJsonValue(e));throw t instanceof Error&&t.message.length>0&&(n+=": ".concat(t.message)),new Error(n)}}}}else if("map"==i.kind){if(null===t)return;if("object"!=typeof t||Array.isArray(t))throw new Error("cannot decode field ".concat(s.typeName,".").concat(i.name," from JSON: ").concat(debugJsonValue(t)));const l=e[c];for(const[e,c]of Object.entries(t)){if(null===c)throw new Error("cannot decode field ".concat(s.typeName,".").concat(i.name," from JSON: map value null"));let u;try{u=readMapKey(i.K,e)}catch(e){let n="cannot decode map key for field ".concat(s.typeName,".").concat(i.name," from JSON: ").concat(debugJsonValue(t));throw e instanceof Error&&e.message.length>0&&(n+=": ".concat(e.message)),new Error(n)}switch(i.V.kind){case"message":l[u]=i.V.T.fromJson(c,n);break;case"enum":const e=readEnum(i.V.T,c,n.ignoreUnknownFields,!0);e!==v&&(l[u]=e);break;case"scalar":try{l[u]=readScalar$1(i.V.T,c,a.BIGINT,!0)}catch(e){let n="cannot decode map value for field ".concat(s.typeName,".").concat(i.name," from JSON: ").concat(debugJsonValue(t));throw e instanceof Error&&e.message.length>0&&(n+=": ".concat(e.message)),new Error(n)}}}}else switch(i.oneof&&(e=e[i.oneof.localName]={case:c},c="value"),i.kind){case"message":const a=i.T;if(null===t&&"google.protobuf.Value"!=a.typeName)return;let l=e[c];isMessage(l)?l.fromJson(t,n):(e[c]=l=a.fromJson(t,n),a.fieldWrapper&&!i.oneof&&(e[c]=a.fieldWrapper.unwrapField(l)));break;case"enum":const u=readEnum(i.T,t,n.ignoreUnknownFields,!1);switch(u){case g:clearField(i,e);break;case v:break;default:e[c]=u}break;case"scalar":try{const n=readScalar$1(i.T,t,i.L,!1);if(n===g)clearField(i,e);else e[c]=n}catch(e){let n="cannot decode field ".concat(s.typeName,".").concat(i.name," from JSON: ").concat(debugJsonValue(t));throw e instanceof Error&&e.message.length>0&&(n+=": ".concat(e.message)),new Error(n)}}}function readMapKey(e,t){if(e===s.BOOL)switch(t){case"true":t=!0;break;case"false":t=!1}return readScalar$1(e,t,a.BIGINT,!0).toString()}function readScalar$1(e,t,i,a){if(null===t)return a?scalarZeroValue(e,i):g;switch(e){case s.DOUBLE:case s.FLOAT:if("NaN"===t)return Number.NaN;if("Infinity"===t)return Number.POSITIVE_INFINITY;if("-Infinity"===t)return Number.NEGATIVE_INFINITY;if(""===t)break;if("string"==typeof t&&t.trim().length!==t.length)break;if("string"!=typeof t&&"number"!=typeof t)break;const a=Number(t);if(Number.isNaN(a))break;if(!Number.isFinite(a))break;return e==s.FLOAT&&assertFloat32(a),a;case s.INT32:case s.FIXED32:case s.SFIXED32:case s.SINT32:case s.UINT32:let c;if("number"==typeof t?c=t:"string"==typeof t&&t.length>0&&t.trim().length===t.length&&(c=Number(t)),void 0===c)break;return e==s.UINT32||e==s.FIXED32?assertUInt32(c):assertInt32(c),c;case s.INT64:case s.SFIXED64:case s.SINT64:if("number"!=typeof t&&"string"!=typeof t)break;const l=n.parse(t);return i?l.toString():l;case s.FIXED64:case s.UINT64:if("number"!=typeof t&&"string"!=typeof t)break;const u=n.uParse(t);return i?u.toString():u;case s.BOOL:if("boolean"!=typeof t)break;return t;case s.STRING:if("string"!=typeof t)break;try{encodeURIComponent(t)}catch(e){throw new Error("invalid UTF8")}return t;case s.BYTES:if(""===t)return new Uint8Array(0);if("string"!=typeof t)break;return h.dec(t)}throw new Error}function readEnum(e,t,i,n){if(null===t)return"google.protobuf.NullValue"==e.typeName?0:n?e.values[0].no:g;switch(typeof t){case"number":if(Number.isInteger(t))return t;break;case"string":const n=e.findName(t);if(void 0!==n)return n.no;if(i)return v}throw new Error("cannot decode enum ".concat(e.typeName," from JSON: ").concat(debugJsonValue(t)))}function canEmitFieldDefaultValue(e){return!(!e.repeated&&"map"!=e.kind)||!e.oneof&&("message"!=e.kind&&(!e.opt&&!e.req))}function writeField$1(e,t,i){if("map"==e.kind){assert("object"==typeof t&&null!=t);const n={},s=Object.entries(t);switch(e.V.kind){case"scalar":for(const[t,i]of s)n[t.toString()]=writeScalar$1(e.V.T,i);break;case"message":for(const[e,t]of s)n[e.toString()]=t.toJson(i);break;case"enum":const t=e.V.T;for(const[e,a]of s)n[e.toString()]=writeEnum(t,a,i.enumAsInteger)}return i.emitDefaultValues||s.length>0?n:void 0}if(e.repeated){assert(Array.isArray(t));const n=[];switch(e.kind){case"scalar":for(let i=0;i<t.length;i++)n.push(writeScalar$1(e.T,t[i]));break;case"enum":for(let s=0;s<t.length;s++)n.push(writeEnum(e.T,t[s],i.enumAsInteger));break;case"message":for(let e=0;e<t.length;e++)n.push(t[e].toJson(i))}return i.emitDefaultValues||n.length>0?n:void 0}switch(e.kind){case"scalar":return writeScalar$1(e.T,t);case"enum":return writeEnum(e.T,t,i.enumAsInteger);case"message":return wrapField(e.T,t).toJson(i)}}function writeEnum(e,t,i){var n;if(assert("number"==typeof t),"google.protobuf.NullValue"==e.typeName)return null;if(i)return t;const s=e.findNumber(t);return null!==(n=null==s?void 0:s.name)&&void 0!==n?n:t}function writeScalar$1(e,t){switch(e){case s.INT32:case s.SFIXED32:case s.SINT32:case s.FIXED32:case s.UINT32:return assert("number"==typeof t),t;case s.FLOAT:case s.DOUBLE:return assert("number"==typeof t),Number.isNaN(t)?"NaN":t===Number.POSITIVE_INFINITY?"Infinity":t===Number.NEGATIVE_INFINITY?"-Infinity":t;case s.STRING:return assert("string"==typeof t),t;case s.BOOL:return assert("boolean"==typeof t),t;case s.UINT64:case s.FIXED64:case s.INT64:case s.SFIXED64:case s.SINT64:return assert("bigint"==typeof t||"string"==typeof t||"number"==typeof t),t.toString();case s.BYTES:return assert(t instanceof Uint8Array),h.enc(t)}}const k=Symbol("@bufbuild/protobuf/unknown-fields"),b={readUnknownFields:!0,readerFactory:e=>new BinaryReader(e)},y={writeUnknownFields:!0,writerFactory:()=>new BinaryWriter};function makeReadOptions(e){return e?Object.assign(Object.assign({},b),e):b}function makeWriteOptions(e){return e?Object.assign(Object.assign({},y),e):y}function readField(e,t,i,n,l){let{repeated:u,localName:h}=i;switch(i.oneof&&((e=e[i.oneof.localName]).case!=h&&delete e.value,e.case=h,h="value"),i.kind){case"scalar":case"enum":const p="enum"==i.kind?s.INT32:i.T;let m=readScalar;if("scalar"==i.kind&&i.L>0&&(m=readScalarLTString),u){let i=e[h];if(n==c.LengthDelimited&&p!=s.STRING&&p!=s.BYTES){let e=t.uint32()+t.pos;for(;t.pos<e;)i.push(m(t,p))}else i.push(m(t,p))}else e[h]=m(t,p);break;case"message":const g=i.T;u?e[h].push(readMessageField(t,new g,l,i)):isMessage(e[h])?readMessageField(t,e[h],l,i):(e[h]=readMessageField(t,new g,l,i),!g.fieldWrapper||i.oneof||i.repeated||(e[h]=g.fieldWrapper.unwrapField(e[h])));break;case"map":let[v,k]=function(e,t,i){const n=t.uint32(),s=t.pos+n;let c,l;for(;t.pos<s;){const[n]=t.tag();switch(n){case 1:c=readScalar(t,e.K);break;case 2:switch(e.V.kind){case"scalar":l=readScalar(t,e.V.T);break;case"enum":l=t.int32();break;case"message":l=readMessageField(t,new e.V.T,i,void 0)}}}void 0===c&&(c=scalarZeroValue(e.K,a.BIGINT));"string"!=typeof c&&"number"!=typeof c&&(c=c.toString());if(void 0===l)switch(e.V.kind){case"scalar":l=scalarZeroValue(e.V.T,a.BIGINT);break;case"enum":l=e.V.T.values[0].no;break;case"message":l=new e.V.T}return[c,l]}(i,t,l);e[h][v]=k}}function readMessageField(e,t,i,n){const s=t.getType().runtime.bin,a=null==n?void 0:n.delimited;return s.readMessage(t,e,a?n.no:e.uint32(),i,a),t}function readScalarLTString(e,t){const i=readScalar(e,t);return"bigint"==typeof i?i.toString():i}function readScalar(e,t){switch(t){case s.STRING:return e.string();case s.BOOL:return e.bool();case s.DOUBLE:return e.double();case s.FLOAT:return e.float();case s.INT32:return e.int32();case s.INT64:return e.int64();case s.UINT64:return e.uint64();case s.FIXED64:return e.fixed64();case s.BYTES:return e.bytes();case s.FIXED32:return e.fixed32();case s.SFIXED32:return e.sfixed32();case s.SFIXED64:return e.sfixed64();case s.SINT64:return e.sint64();case s.UINT32:return e.uint32();case s.SINT32:return e.sint32()}}function writeField(e,t,i,n){assert(void 0!==t);const a=e.repeated;switch(e.kind){case"scalar":case"enum":let l="enum"==e.kind?s.INT32:e.T;if(a)if(assert(Array.isArray(t)),e.packed)!function(e,t,i,n){if(!n.length)return;e.tag(i,c.LengthDelimited).fork();let[,s]=scalarTypeInfo(t);for(let t=0;t<n.length;t++)e[s](n[t]);e.join()}(i,l,e.no,t);else for(const n of t)writeScalar(i,l,e.no,n);else writeScalar(i,l,e.no,t);break;case"message":if(a){assert(Array.isArray(t));for(const s of t)writeMessageField(i,n,e,s)}else writeMessageField(i,n,e,t);break;case"map":assert("object"==typeof t&&null!=t);for(const[s,a]of Object.entries(t))writeMapEntry(i,n,e,s,a)}}function writeMapEntry(e,t,i,n,a){e.tag(i.no,c.LengthDelimited),e.fork();let l=n;switch(i.K){case s.INT32:case s.FIXED32:case s.UINT32:case s.SFIXED32:case s.SINT32:l=Number.parseInt(n);break;case s.BOOL:assert("true"==n||"false"==n),l="true"==n}switch(writeScalar(e,i.K,1,l),i.V.kind){case"scalar":writeScalar(e,i.V.T,2,a);break;case"enum":writeScalar(e,s.INT32,2,a);break;case"message":assert(void 0!==a),e.tag(2,c.LengthDelimited).bytes(a.toBinary(t))}e.join()}function writeMessageField(e,t,i,n){const s=wrapField(i.T,n);i.delimited?e.tag(i.no,c.StartGroup).raw(s.toBinary(t)).tag(i.no,c.EndGroup):e.tag(i.no,c.LengthDelimited).bytes(s.toBinary(t))}function writeScalar(e,t,i,n){assert(void 0!==n);let[s,a]=scalarTypeInfo(t);e.tag(i,s)[a](n)}function scalarTypeInfo(e){let t=c.Varint;switch(e){case s.BYTES:case s.STRING:t=c.LengthDelimited;break;case s.DOUBLE:case s.FIXED64:case s.SFIXED64:t=c.Bit64;break;case s.FIXED32:case s.SFIXED32:case s.FLOAT:t=c.Bit32}return[t,s[e].toLowerCase()]}function cloneSingularField(e){if(void 0===e)return e;if(isMessage(e))return e.clone();if(e instanceof Uint8Array){const t=new Uint8Array(e.byteLength);return t.set(e),t}return e}function toU8Arr(e){return e instanceof Uint8Array?e:new Uint8Array(e)}class InternalFieldList{constructor(e,t){this._fields=e,this._normalizer=t}findJsonName(e){if(!this.jsonNames){const e={};for(const t of this.list())e[t.jsonName]=e[t.name]=t;this.jsonNames=e}return this.jsonNames[e]}find(e){if(!this.numbers){const e={};for(const t of this.list())e[t.no]=t;this.numbers=e}return this.numbers[e]}list(){return this.all||(this.all=this._normalizer(this._fields)),this.all}byNumber(){return this.numbersAsc||(this.numbersAsc=this.list().concat().sort((e,t)=>e.no-t.no)),this.numbersAsc}byMember(){if(!this.members){this.members=[];const e=this.members;let t;for(const i of this.list())i.oneof?i.oneof!==t&&(t=i.oneof,e.push(t)):e.push(i)}return this.members}}function localFieldName(e,t){const i=protoCamelCase(e);return t?i:safeObjectProperty(safeMessageProperty(i))}const T=protoCamelCase;function protoCamelCase(e){let t=!1;const i=[];for(let n=0;n<e.length;n++){let s=e.charAt(n);switch(s){case"_":t=!0;break;case"0":case"1":case"2":case"3":case"4":case"5":case"6":case"7":case"8":case"9":i.push(s),t=!1;break;default:t&&(t=!1,s=s.toUpperCase()),i.push(s)}}return i.join("")}const C=new Set(["constructor","toString","toJSON","valueOf"]),S=new Set(["getType","clone","equals","fromBinary","fromJson","fromJsonString","toBinary","toJson","toJsonString","toObject"]),fallback=e=>"".concat(e,"$"),safeMessageProperty=e=>S.has(e)?fallback(e):e,safeObjectProperty=e=>C.has(e)?fallback(e):e;class InternalOneofInfo{constructor(e){this.kind="oneof",this.repeated=!1,this.packed=!1,this.opt=!1,this.req=!1,this.default=void 0,this.fields=[],this.name=e,this.localName=localFieldName(e,!1)}addField(e){assert(e.oneof===this,"field ".concat(e.name," not one of ").concat(this.name)),this.fields.push(e)}findField(e){if(!this._lookup){this._lookup=Object.create(null);for(let e=0;e<this.fields.length;e++)this._lookup[this.fields[e].localName]=this.fields[e]}return this._lookup[e]}}const E=(w=e=>new InternalFieldList(e,e=>function(e){var t,i,n,c,l,u;const h=[];let p;for(const m of"function"==typeof e?e():e){const e=m;if(e.localName=localFieldName(m.name,void 0!==m.oneof),e.jsonName=null!==(t=m.jsonName)&&void 0!==t?t:T(m.name),e.repeated=null!==(i=m.repeated)&&void 0!==i&&i,"scalar"==m.kind&&(e.L=null!==(n=m.L)&&void 0!==n?n:a.BIGINT),e.delimited=null!==(c=m.delimited)&&void 0!==c&&c,e.req=null!==(l=m.req)&&void 0!==l&&l,e.opt=null!==(u=m.opt)&&void 0!==u&&u,void 0===m.packed&&(e.packed="enum"==m.kind||"scalar"==m.kind&&m.T!=s.BYTES&&m.T!=s.STRING),void 0!==m.oneof){const t="string"==typeof m.oneof?m.oneof:m.oneof.name;p&&p.name==t||(p=new InternalOneofInfo(t)),e.oneof=p,p.addField(e)}h.push(e)}return h}(e)),P=e=>{for(const t of e.getType().fields.byMember()){if(t.opt)continue;const i=t.localName,n=e;if(t.repeated)n[i]=[];else switch(t.kind){case"oneof":n[i]={case:void 0};break;case"enum":n[i]=0;break;case"map":n[i]={};break;case"scalar":n[i]=scalarZeroValue(t.T,t.L)}}},{syntax:"proto3",json:{makeReadOptions:makeReadOptions$1,makeWriteOptions:makeWriteOptions$1,readMessage(e,t,i,n){if(null==t||Array.isArray(t)||"object"!=typeof t)throw new Error("cannot decode message ".concat(e.typeName," from JSON: ").concat(debugJsonValue(t)));n=null!=n?n:new e;const s=new Map,a=i.typeRegistry;for(const[c,l]of Object.entries(t)){const t=e.fields.findJsonName(c);if(t){if(t.oneof){if(null===l&&"scalar"==t.kind)continue;const i=s.get(t.oneof);if(void 0!==i)throw new Error("cannot decode message ".concat(e.typeName,' from JSON: multiple keys for oneof "').concat(t.oneof.name,'" present: "').concat(i,'", "').concat(c,'"'));s.set(t.oneof,c)}readField$1(n,l,t,i,e)}else{let t=!1;if((null==a?void 0:a.findExtension)&&c.startsWith("[")&&c.endsWith("]")){const s=a.findExtension(c.substring(1,c.length-1));if(s&&s.extendee.typeName==e.typeName){t=!0;const[e,a]=createExtensionContainer(s);readField$1(e,l,s.field,i,s),setExtension(n,s,a(),i)}}if(!t&&!i.ignoreUnknownFields)throw new Error("cannot decode message ".concat(e.typeName,' from JSON: key "').concat(c,'" is unknown'))}}return n},writeMessage(e,t){const i=e.getType(),n={};let s;try{for(s of i.fields.byNumber()){if(!isFieldSet(s,e)){if(s.req)throw"required field not set";if(!t.emitDefaultValues)continue;if(!canEmitFieldDefaultValue(s))continue}const i=writeField$1(s,s.oneof?e[s.oneof.localName].value:e[s.localName],t);void 0!==i&&(n[t.useProtoFieldName?s.name:s.jsonName]=i)}const a=t.typeRegistry;if(null==a?void 0:a.findExtensionFor)for(const s of i.runtime.bin.listUnknownFields(e)){const c=a.findExtensionFor(i.typeName,s.no);if(c&&hasExtension(e,c)){const i=getExtension(e,c,t),s=writeField$1(c.field,i,t);void 0!==s&&(n[c.field.jsonName]=s)}}}catch(e){const t=s?"cannot encode field ".concat(i.typeName,".").concat(s.name," to JSON"):"cannot encode message ".concat(i.typeName," to JSON"),n=e instanceof Error?e.message:String(e);throw new Error(t+(n.length>0?": ".concat(n):""))}return n},readScalar:(e,t,i)=>readScalar$1(e,t,null!=i?i:a.BIGINT,!0),writeScalar(e,t,i){if(void 0!==t)return i||isScalarZeroValue(e,t)?writeScalar$1(e,t):void 0},debug:debugJsonValue},bin:{makeReadOptions:makeReadOptions,makeWriteOptions:makeWriteOptions,listUnknownFields(e){var t;return null!==(t=e[k])&&void 0!==t?t:[]},discardUnknownFields(e){delete e[k]},writeUnknownFields(e,t){const i=e[k];if(i)for(const e of i)t.tag(e.no,e.wireType).raw(e.data)},onUnknownField(e,t,i,n){const s=e;Array.isArray(s[k])||(s[k]=[]),s[k].push({no:t,wireType:i,data:n})},readMessage(e,t,i,n,s){const a=e.getType(),l=s?t.len:t.pos+i;let u,h;for(;t.pos<l&&([u,h]=t.tag(),!0!==s||h!=c.EndGroup);){const i=a.fields.find(u);if(!i){const i=t.skip(h,u);n.readUnknownFields&&this.onUnknownField(e,u,h,i);continue}readField(e,t,i,h,n)}if(s&&(h!=c.EndGroup||u!==i))throw new Error("invalid end group tag")},readField:readField,writeMessage(e,t,i){const n=e.getType();for(const s of n.fields.byNumber())if(isFieldSet(s,e))writeField(s,s.oneof?e[s.oneof.localName].value:e[s.localName],t,i);else if(s.req)throw new Error("cannot encode field ".concat(n.typeName,".").concat(s.name," to binary: required field not set"));return i.writeUnknownFields&&this.writeUnknownFields(e,t),t},writeField(e,t,i,n){void 0!==t&&writeField(e,t,i,n)}},util:Object.assign(Object.assign({},{setEnumType:setEnumType,initPartial(e,t){if(void 0===e)return;const i=t.getType();for(const n of i.fields.byMember()){const i=n.localName,a=t,c=e;if(null!=c[i])switch(n.kind){case"oneof":const e=c[i].case;if(void 0===e)continue;const t=n.findField(e);let l=c[i].value;t&&"message"==t.kind&&!isMessage(l,t.T)?l=new t.T(l):t&&"scalar"===t.kind&&t.T===s.BYTES&&(l=toU8Arr(l)),a[i]={case:e,value:l};break;case"scalar":case"enum":let u=c[i];n.T===s.BYTES&&(u=n.repeated?u.map(toU8Arr):toU8Arr(u)),a[i]=u;break;case"map":switch(n.V.kind){case"scalar":case"enum":if(n.V.T===s.BYTES)for(const[e,t]of Object.entries(c[i]))a[i][e]=toU8Arr(t);else Object.assign(a[i],c[i]);break;case"message":const e=n.V.T;for(const t of Object.keys(c[i])){let n=c[i][t];e.fieldWrapper||(n=new e(n)),a[i][t]=n}}break;case"message":const h=n.T;if(n.repeated)a[i]=c[i].map(e=>isMessage(e,h)?e:new h(e));else{const e=c[i];h.fieldWrapper?"google.protobuf.BytesValue"===h.typeName?a[i]=toU8Arr(e):a[i]=e:a[i]=isMessage(e,h)?e:new h(e)}}}},equals:(e,t,i)=>t===i||!(!t||!i)&&e.fields.byMember().every(e=>{const n=t[e.localName],a=i[e.localName];if(e.repeated){if(n.length!==a.length)return!1;switch(e.kind){case"message":return n.every((t,i)=>e.T.equals(t,a[i]));case"scalar":return n.every((t,i)=>scalarEquals(e.T,t,a[i]));case"enum":return n.every((e,t)=>scalarEquals(s.INT32,e,a[t]))}throw new Error("repeated cannot contain ".concat(e.kind))}switch(e.kind){case"message":let t=n,i=a;return e.T.fieldWrapper&&(void 0===t||isMessage(t)||(t=e.T.fieldWrapper.wrapField(t)),void 0===i||isMessage(i)||(i=e.T.fieldWrapper.wrapField(i))),e.T.equals(t,i);case"enum":return scalarEquals(s.INT32,n,a);case"scalar":return scalarEquals(e.T,n,a);case"oneof":if(n.case!==a.case)return!1;const c=e.findField(n.case);if(void 0===c)return!0;switch(c.kind){case"message":return c.T.equals(n.value,a.value);case"enum":return scalarEquals(s.INT32,n.value,a.value);case"scalar":return scalarEquals(c.T,n.value,a.value)}throw new Error("oneof cannot contain ".concat(c.kind));case"map":const l=Object.keys(n).concat(Object.keys(a));switch(e.V.kind){case"message":const t=e.V.T;return l.every(e=>t.equals(n[e],a[e]));case"enum":return l.every(e=>scalarEquals(s.INT32,n[e],a[e]));case"scalar":const i=e.V.T;return l.every(e=>scalarEquals(i,n[e],a[e]))}}}),clone(e){const t=e.getType(),i=new t,n=i;for(const i of t.fields.byMember()){const t=e[i.localName];let s;if(i.repeated)s=t.map(cloneSingularField);else if("map"==i.kind){s=n[i.localName];for(const[e,i]of Object.entries(t))s[e]=cloneSingularField(i)}else s="oneof"==i.kind?i.findField(t.case)?{case:t.case,value:cloneSingularField(t.value)}:{case:void 0}:cloneSingularField(t);n[i.localName]=s}for(const i of t.runtime.bin.listUnknownFields(e))t.runtime.bin.onUnknownField(n,i.no,i.wireType,i.data);return i}}),{newFieldList:w,initFields:P}),makeMessageType(e,t,i){return function(e,t,i,n){var s;const a=null!==(s=null==n?void 0:n.localName)&&void 0!==s?s:t.substring(t.lastIndexOf(".")+1),c={[a]:function(t){e.util.initFields(this),e.util.initPartial(t,this)}}[a];return Object.setPrototypeOf(c.prototype,new Message),Object.assign(c,{runtime:e,typeName:t,fields:e.util.newFieldList(i),fromBinary:(e,t)=>(new c).fromBinary(e,t),fromJson:(e,t)=>(new c).fromJson(e,t),fromJsonString:(e,t)=>(new c).fromJsonString(e,t),equals:(t,i)=>e.util.equals(c,t,i)}),c}(this,e,t,i)},makeEnum:makeEnum,makeEnumType:makeEnumType,getEnumType:getEnumType,makeExtension(e,t,i){return function(e,t,i,n){let s;return{typeName:t,extendee:i,get field(){if(!s){const i="function"==typeof n?n():n;i.name=t.split(".").pop(),i.jsonName="[".concat(t,"]"),s=e.util.newFieldList([i]).list()[0]}return s},runtime:e}}(this,e,t,i)}});var w,P;class Timestamp extends Message{constructor(e){super(),this.seconds=n.zero,this.nanos=0,E.util.initPartial(e,this)}fromJson(e,t){if("string"!=typeof e)throw new Error("cannot decode google.protobuf.Timestamp from JSON: ".concat(E.json.debug(e)));const i=e.match(/^([0-9]{4})-([0-9]{2})-([0-9]{2})T([0-9]{2}):([0-9]{2}):([0-9]{2})(?:Z|\.([0-9]{3,9})Z|([+-][0-9][0-9]:[0-9][0-9]))$/);if(!i)throw new Error("cannot decode google.protobuf.Timestamp from JSON: invalid RFC 3339 string");const s=Date.parse(i[1]+"-"+i[2]+"-"+i[3]+"T"+i[4]+":"+i[5]+":"+i[6]+(i[8]?i[8]:"Z"));if(Number.isNaN(s))throw new Error("cannot decode google.protobuf.Timestamp from JSON: invalid RFC 3339 string");if(s<Date.parse("0001-01-01T00:00:00Z")||s>Date.parse("9999-12-31T23:59:59Z"))throw new Error("cannot decode message google.protobuf.Timestamp from JSON: must be from 0001-01-01T00:00:00Z to 9999-12-31T23:59:59Z inclusive");return this.seconds=n.parse(s/1e3),this.nanos=0,i[7]&&(this.nanos=parseInt("1"+i[7]+"0".repeat(9-i[7].length))-1e9),this}toJson(e){const t=1e3*Number(this.seconds);if(t<Date.parse("0001-01-01T00:00:00Z")||t>Date.parse("9999-12-31T23:59:59Z"))throw new Error("cannot encode google.protobuf.Timestamp to JSON: must be from 0001-01-01T00:00:00Z to 9999-12-31T23:59:59Z inclusive");if(this.nanos<0)throw new Error("cannot encode google.protobuf.Timestamp to JSON: nanos must not be negative");let i="Z";if(this.nanos>0){const e=(this.nanos+1e9).toString().substring(1);i="000000"===e.substring(3)?"."+e.substring(0,3)+"Z":"000"===e.substring(6)?"."+e.substring(0,6)+"Z":"."+e+"Z"}return new Date(t).toISOString().replace(".000Z",i)}toDate(){return new Date(1e3*Number(this.seconds)+Math.ceil(this.nanos/1e6))}static now(){return Timestamp.fromDate(new Date)}static fromDate(e){const t=e.getTime();return new Timestamp({seconds:n.parse(Math.floor(t/1e3)),nanos:t%1e3*1e6})}static fromBinary(e,t){return(new Timestamp).fromBinary(e,t)}static fromJson(e,t){return(new Timestamp).fromJson(e,t)}static fromJsonString(e,t){return(new Timestamp).fromJsonString(e,t)}static equals(e,t){return E.util.equals(Timestamp,e,t)}}Timestamp.runtime=E,Timestamp.typeName="google.protobuf.Timestamp",Timestamp.fields=E.util.newFieldList(()=>[{no:1,name:"seconds",kind:"scalar",T:3},{no:2,name:"nanos",kind:"scalar",T:5}]);const R=E.makeMessageType("livekit.MetricsBatch",()=>[{no:1,name:"timestamp_ms",kind:"scalar",T:3},{no:2,name:"normalized_timestamp",kind:"message",T:Timestamp},{no:3,name:"str_data",kind:"scalar",T:9,repeated:!0},{no:4,name:"time_series",kind:"message",T:I,repeated:!0},{no:5,name:"events",kind:"message",T:D,repeated:!0}]),I=E.makeMessageType("livekit.TimeSeriesMetric",()=>[{no:1,name:"label",kind:"scalar",T:13},{no:2,name:"participant_identity",kind:"scalar",T:13},{no:3,name:"track_sid",kind:"scalar",T:13},{no:4,name:"samples",kind:"message",T:O,repeated:!0},{no:5,name:"rid",kind:"scalar",T:13}]),O=E.makeMessageType("livekit.MetricSample",()=>[{no:1,name:"timestamp_ms",kind:"scalar",T:3},{no:2,name:"normalized_timestamp",kind:"message",T:Timestamp},{no:3,name:"value",kind:"scalar",T:2}]),D=E.makeMessageType("livekit.EventMetric",()=>[{no:1,name:"label",kind:"scalar",T:13},{no:2,name:"participant_identity",kind:"scalar",T:13},{no:3,name:"track_sid",kind:"scalar",T:13},{no:4,name:"start_timestamp_ms",kind:"scalar",T:3},{no:5,name:"end_timestamp_ms",kind:"scalar",T:3,opt:!0},{no:6,name:"normalized_start_timestamp",kind:"message",T:Timestamp},{no:7,name:"normalized_end_timestamp",kind:"message",T:Timestamp,opt:!0},{no:8,name:"metadata",kind:"scalar",T:9},{no:9,name:"rid",kind:"scalar",T:13}]),x=E.makeEnum("livekit.BackupCodecPolicy",[{no:0,name:"PREFER_REGRESSION"},{no:1,name:"SIMULCAST"},{no:2,name:"REGRESSION"}]),M=E.makeEnum("livekit.TrackType",[{no:0,name:"AUDIO"},{no:1,name:"VIDEO"},{no:2,name:"DATA"}]),A=E.makeEnum("livekit.TrackSource",[{no:0,name:"UNKNOWN"},{no:1,name:"CAMERA"},{no:2,name:"MICROPHONE"},{no:3,name:"SCREEN_SHARE"},{no:4,name:"SCREEN_SHARE_AUDIO"}]),N=E.makeEnum("livekit.VideoQuality",[{no:0,name:"LOW"},{no:1,name:"MEDIUM"},{no:2,name:"HIGH"},{no:3,name:"OFF"}]),L=E.makeEnum("livekit.ConnectionQuality",[{no:0,name:"POOR"},{no:1,name:"GOOD"},{no:2,name:"EXCELLENT"},{no:3,name:"LOST"}]),U=E.makeEnum("livekit.ClientConfigSetting",[{no:0,name:"UNSET"},{no:1,name:"DISABLED"},{no:2,name:"ENABLED"}]),F=E.makeEnum("livekit.DisconnectReason",[{no:0,name:"UNKNOWN_REASON"},{no:1,name:"CLIENT_INITIATED"},{no:2,name:"DUPLICATE_IDENTITY"},{no:3,name:"SERVER_SHUTDOWN"},{no:4,name:"PARTICIPANT_REMOVED"},{no:5,name:"ROOM_DELETED"},{no:6,name:"STATE_MISMATCH"},{no:7,name:"JOIN_FAILURE"},{no:8,name:"MIGRATION"},{no:9,name:"SIGNAL_CLOSE"},{no:10,name:"ROOM_CLOSED"},{no:11,name:"USER_UNAVAILABLE"},{no:12,name:"USER_REJECTED"},{no:13,name:"SIP_TRUNK_FAILURE"},{no:14,name:"CONNECTION_TIMEOUT"},{no:15,name:"MEDIA_FAILURE"}]),j=E.makeEnum("livekit.ReconnectReason",[{no:0,name:"RR_UNKNOWN"},{no:1,name:"RR_SIGNAL_DISCONNECTED"},{no:2,name:"RR_PUBLISHER_FAILED"},{no:3,name:"RR_SUBSCRIBER_FAILED"},{no:4,name:"RR_SWITCH_CANDIDATE"}]),B=E.makeEnum("livekit.SubscriptionError",[{no:0,name:"SE_UNKNOWN"},{no:1,name:"SE_CODEC_UNSUPPORTED"},{no:2,name:"SE_TRACK_NOTFOUND"}]),V=E.makeEnum("livekit.AudioTrackFeature",[{no:0,name:"TF_STEREO"},{no:1,name:"TF_NO_DTX"},{no:2,name:"TF_AUTO_GAIN_CONTROL"},{no:3,name:"TF_ECHO_CANCELLATION"},{no:4,name:"TF_NOISE_SUPPRESSION"},{no:5,name:"TF_ENHANCED_NOISE_CANCELLATION"},{no:6,name:"TF_PRECONNECT_BUFFER"}]),q=E.makeMessageType("livekit.Room",()=>[{no:1,name:"sid",kind:"scalar",T:9},{no:2,name:"name",kind:"scalar",T:9},{no:3,name:"empty_timeout",kind:"scalar",T:13},{no:14,name:"departure_timeout",kind:"scalar",T:13},{no:4,name:"max_participants",kind:"scalar",T:13},{no:5,name:"creation_time",kind:"scalar",T:3},{no:15,name:"creation_time_ms",kind:"scalar",T:3},{no:6,name:"turn_password",kind:"scalar",T:9},{no:7,name:"enabled_codecs",kind:"message",T:H,repeated:!0},{no:8,name:"metadata",kind:"scalar",T:9},{no:9,name:"num_participants",kind:"scalar",T:13},{no:11,name:"num_publishers",kind:"scalar",T:13},{no:10,name:"active_recording",kind:"scalar",T:8},{no:13,name:"version",kind:"message",T:Se}]),H=E.makeMessageType("livekit.Codec",()=>[{no:1,name:"mime",kind:"scalar",T:9},{no:2,name:"fmtp_line",kind:"scalar",T:9}]),W=E.makeMessageType("livekit.ParticipantPermission",()=>[{no:1,name:"can_subscribe",kind:"scalar",T:8},{no:2,name:"can_publish",kind:"scalar",T:8},{no:3,name:"can_publish_data",kind:"scalar",T:8},{no:9,name:"can_publish_sources",kind:"enum",T:E.getEnumType(A),repeated:!0},{no:7,name:"hidden",kind:"scalar",T:8},{no:8,name:"recorder",kind:"scalar",T:8},{no:10,name:"can_update_metadata",kind:"scalar",T:8},{no:11,name:"agent",kind:"scalar",T:8},{no:12,name:"can_subscribe_metrics",kind:"scalar",T:8}]),G=E.makeMessageType("livekit.ParticipantInfo",()=>[{no:1,name:"sid",kind:"scalar",T:9},{no:2,name:"identity",kind:"scalar",T:9},{no:3,name:"state",kind:"enum",T:E.getEnumType(K)},{no:4,name:"tracks",kind:"message",T:$,repeated:!0},{no:5,name:"metadata",kind:"scalar",T:9},{no:6,name:"joined_at",kind:"scalar",T:3},{no:17,name:"joined_at_ms",kind:"scalar",T:3},{no:9,name:"name",kind:"scalar",T:9},{no:10,name:"version",kind:"scalar",T:13},{no:11,name:"permission",kind:"message",T:W},{no:12,name:"region",kind:"scalar",T:9},{no:13,name:"is_publisher",kind:"scalar",T:8},{no:14,name:"kind",kind:"enum",T:E.getEnumType(J)},{no:15,name:"attributes",kind:"map",K:9,V:{kind:"scalar",T:9}},{no:16,name:"disconnect_reason",kind:"enum",T:E.getEnumType(F)},{no:18,name:"kind_details",kind:"enum",T:E.getEnumType(z),repeated:!0}]),K=E.makeEnum("livekit.ParticipantInfo.State",[{no:0,name:"JOINING"},{no:1,name:"JOINED"},{no:2,name:"ACTIVE"},{no:3,name:"DISCONNECTED"}]),J=E.makeEnum("livekit.ParticipantInfo.Kind",[{no:0,name:"STANDARD"},{no:1,name:"INGRESS"},{no:2,name:"EGRESS"},{no:3,name:"SIP"},{no:4,name:"AGENT"},{no:7,name:"CONNECTOR"}]),z=E.makeEnum("livekit.ParticipantInfo.KindDetail",[{no:0,name:"CLOUD_AGENT"},{no:1,name:"FORWARDED"}]),Q=E.makeEnum("livekit.Encryption.Type",[{no:0,name:"NONE"},{no:1,name:"GCM"},{no:2,name:"CUSTOM"}]),Y=E.makeMessageType("livekit.SimulcastCodecInfo",()=>[{no:1,name:"mime_type",kind:"scalar",T:9},{no:2,name:"mid",kind:"scalar",T:9},{no:3,name:"cid",kind:"scalar",T:9},{no:4,name:"layers",kind:"message",T:X,repeated:!0},{no:5,name:"video_layer_mode",kind:"enum",T:E.getEnumType(Z)},{no:6,name:"sdp_cid",kind:"scalar",T:9}]),$=E.makeMessageType("livekit.TrackInfo",()=>[{no:1,name:"sid",kind:"scalar",T:9},{no:2,name:"type",kind:"enum",T:E.getEnumType(M)},{no:3,name:"name",kind:"scalar",T:9},{no:4,name:"muted",kind:"scalar",T:8},{no:5,name:"width",kind:"scalar",T:13},{no:6,name:"height",kind:"scalar",T:13},{no:7,name:"simulcast",kind:"scalar",T:8},{no:8,name:"disable_dtx",kind:"scalar",T:8},{no:9,name:"source",kind:"enum",T:E.getEnumType(A)},{no:10,name:"layers",kind:"message",T:X,repeated:!0},{no:11,name:"mime_type",kind:"scalar",T:9},{no:12,name:"mid",kind:"scalar",T:9},{no:13,name:"codecs",kind:"message",T:Y,repeated:!0},{no:14,name:"stereo",kind:"scalar",T:8},{no:15,name:"disable_red",kind:"scalar",T:8},{no:16,name:"encryption",kind:"enum",T:E.getEnumType(Q)},{no:17,name:"stream",kind:"scalar",T:9},{no:18,name:"version",kind:"message",T:Se},{no:19,name:"audio_features",kind:"enum",T:E.getEnumType(V),repeated:!0},{no:20,name:"backup_codec_policy",kind:"enum",T:E.getEnumType(x)}]),X=E.makeMessageType("livekit.VideoLayer",()=>[{no:1,name:"quality",kind:"enum",T:E.getEnumType(N)},{no:2,name:"width",kind:"scalar",T:13},{no:3,name:"height",kind:"scalar",T:13},{no:4,name:"bitrate",kind:"scalar",T:13},{no:5,name:"ssrc",kind:"scalar",T:13},{no:6,name:"spatial_layer",kind:"scalar",T:5},{no:7,name:"rid",kind:"scalar",T:9}]),Z=E.makeEnum("livekit.VideoLayer.Mode",[{no:0,name:"MODE_UNUSED"},{no:1,name:"ONE_SPATIAL_LAYER_PER_STREAM"},{no:2,name:"MULTIPLE_SPATIAL_LAYERS_PER_STREAM"},{no:3,name:"ONE_SPATIAL_LAYER_PER_STREAM_INCOMPLETE_RTCP_SR"}]),ee=E.makeMessageType("livekit.DataPacket",()=>[{no:1,name:"kind",kind:"enum",T:E.getEnumType(te)},{no:4,name:"participant_identity",kind:"scalar",T:9},{no:5,name:"destination_identities",kind:"scalar",T:9,repeated:!0},{no:2,name:"user",kind:"message",T:ae,oneof:"value"},{no:3,name:"speaker",kind:"message",T:re,oneof:"value"},{no:6,name:"sip_dtmf",kind:"message",T:oe,oneof:"value"},{no:7,name:"transcription",kind:"message",T:ce,oneof:"value"},{no:8,name:"metrics",kind:"message",T:R,oneof:"value"},{no:9,name:"chat_message",kind:"message",T:le,oneof:"value"},{no:10,name:"rpc_request",kind:"message",T:ue,oneof:"value"},{no:11,name:"rpc_ack",kind:"message",T:he,oneof:"value"},{no:12,name:"rpc_response",kind:"message",T:pe,oneof:"value"},{no:13,name:"stream_header",kind:"message",T:Re,oneof:"value"},{no:14,name:"stream_chunk",kind:"message",T:_e,oneof:"value"},{no:15,name:"stream_trailer",kind:"message",T:Ie,oneof:"value"},{no:18,name:"encrypted_packet",kind:"message",T:ie,oneof:"value"},{no:16,name:"sequence",kind:"scalar",T:13},{no:17,name:"participant_sid",kind:"scalar",T:9}]),te=E.makeEnum("livekit.DataPacket.Kind",[{no:0,name:"RELIABLE"},{no:1,name:"LOSSY"}]),ie=E.makeMessageType("livekit.EncryptedPacket",()=>[{no:1,name:"encryption_type",kind:"enum",T:E.getEnumType(Q)},{no:2,name:"iv",kind:"scalar",T:12},{no:3,name:"key_index",kind:"scalar",T:13},{no:4,name:"encrypted_value",kind:"scalar",T:12}]),ne=E.makeMessageType("livekit.EncryptedPacketPayload",()=>[{no:1,name:"user",kind:"message",T:ae,oneof:"value"},{no:3,name:"chat_message",kind:"message",T:le,oneof:"value"},{no:4,name:"rpc_request",kind:"message",T:ue,oneof:"value"},{no:5,name:"rpc_ack",kind:"message",T:he,oneof:"value"},{no:6,name:"rpc_response",kind:"message",T:pe,oneof:"value"},{no:7,name:"stream_header",kind:"message",T:Re,oneof:"value"},{no:8,name:"stream_chunk",kind:"message",T:_e,oneof:"value"},{no:9,name:"stream_trailer",kind:"message",T:Ie,oneof:"value"}]),re=E.makeMessageType("livekit.ActiveSpeakerUpdate",()=>[{no:1,name:"speakers",kind:"message",T:se,repeated:!0}]),se=E.makeMessageType("livekit.SpeakerInfo",()=>[{no:1,name:"sid",kind:"scalar",T:9},{no:2,name:"level",kind:"scalar",T:2},{no:3,name:"active",kind:"scalar",T:8}]),ae=E.makeMessageType("livekit.UserPacket",()=>[{no:1,name:"participant_sid",kind:"scalar",T:9},{no:5,name:"participant_identity",kind:"scalar",T:9},{no:2,name:"payload",kind:"scalar",T:12},{no:3,name:"destination_sids",kind:"scalar",T:9,repeated:!0},{no:6,name:"destination_identities",kind:"scalar",T:9,repeated:!0},{no:4,name:"topic",kind:"scalar",T:9,opt:!0},{no:8,name:"id",kind:"scalar",T:9,opt:!0},{no:9,name:"start_time",kind:"scalar",T:4,opt:!0},{no:10,name:"end_time",kind:"scalar",T:4,opt:!0},{no:11,name:"nonce",kind:"scalar",T:12}]),oe=E.makeMessageType("livekit.SipDTMF",()=>[{no:3,name:"code",kind:"scalar",T:13},{no:4,name:"digit",kind:"scalar",T:9}]),ce=E.makeMessageType("livekit.Transcription",()=>[{no:2,name:"transcribed_participant_identity",kind:"scalar",T:9},{no:3,name:"track_id",kind:"scalar",T:9},{no:4,name:"segments",kind:"message",T:de,repeated:!0}]),de=E.makeMessageType("livekit.TranscriptionSegment",()=>[{no:1,name:"id",kind:"scalar",T:9},{no:2,name:"text",kind:"scalar",T:9},{no:3,name:"start_time",kind:"scalar",T:4},{no:4,name:"end_time",kind:"scalar",T:4},{no:5,name:"final",kind:"scalar",T:8},{no:6,name:"language",kind:"scalar",T:9}]),le=E.makeMessageType("livekit.ChatMessage",()=>[{no:1,name:"id",kind:"scalar",T:9},{no:2,name:"timestamp",kind:"scalar",T:3},{no:3,name:"edit_timestamp",kind:"scalar",T:3,opt:!0},{no:4,name:"message",kind:"scalar",T:9},{no:5,name:"deleted",kind:"scalar",T:8},{no:6,name:"generated",kind:"scalar",T:8}]),ue=E.makeMessageType("livekit.RpcRequest",()=>[{no:1,name:"id",kind:"scalar",T:9},{no:2,name:"method",kind:"scalar",T:9},{no:3,name:"payload",kind:"scalar",T:9},{no:4,name:"response_timeout_ms",kind:"scalar",T:13},{no:5,name:"version",kind:"scalar",T:13}]),he=E.makeMessageType("livekit.RpcAck",()=>[{no:1,name:"request_id",kind:"scalar",T:9}]),pe=E.makeMessageType("livekit.RpcResponse",()=>[{no:1,name:"request_id",kind:"scalar",T:9},{no:2,name:"payload",kind:"scalar",T:9,oneof:"value"},{no:3,name:"error",kind:"message",T:me,oneof:"value"}]),me=E.makeMessageType("livekit.RpcError",()=>[{no:1,name:"code",kind:"scalar",T:13},{no:2,name:"message",kind:"scalar",T:9},{no:3,name:"data",kind:"scalar",T:9}]),ge=E.makeMessageType("livekit.ParticipantTracks",()=>[{no:1,name:"participant_sid",kind:"scalar",T:9},{no:2,name:"track_sids",kind:"scalar",T:9,repeated:!0}]),fe=E.makeMessageType("livekit.ServerInfo",()=>[{no:1,name:"edition",kind:"enum",T:E.getEnumType(ve)},{no:2,name:"version",kind:"scalar",T:9},{no:3,name:"protocol",kind:"scalar",T:5},{no:4,name:"region",kind:"scalar",T:9},{no:5,name:"node_id",kind:"scalar",T:9},{no:6,name:"debug_info",kind:"scalar",T:9},{no:7,name:"agent_protocol",kind:"scalar",T:5}]),ve=E.makeEnum("livekit.ServerInfo.Edition",[{no:0,name:"Standard"},{no:1,name:"Cloud"}]),ke=E.makeMessageType("livekit.ClientInfo",()=>[{no:1,name:"sdk",kind:"enum",T:E.getEnumType(be)},{no:2,name:"version",kind:"scalar",T:9},{no:3,name:"protocol",kind:"scalar",T:5},{no:4,name:"os",kind:"scalar",T:9},{no:5,name:"os_version",kind:"scalar",T:9},{no:6,name:"device_model",kind:"scalar",T:9},{no:7,name:"browser",kind:"scalar",T:9},{no:8,name:"browser_version",kind:"scalar",T:9},{no:9,name:"address",kind:"scalar",T:9},{no:10,name:"network",kind:"scalar",T:9},{no:11,name:"other_sdks",kind:"scalar",T:9}]),be=E.makeEnum("livekit.ClientInfo.SDK",[{no:0,name:"UNKNOWN"},{no:1,name:"JS"},{no:2,name:"SWIFT"},{no:3,name:"ANDROID"},{no:4,name:"FLUTTER"},{no:5,name:"GO"},{no:6,name:"UNITY"},{no:7,name:"REACT_NATIVE"},{no:8,name:"RUST"},{no:9,name:"PYTHON"},{no:10,name:"CPP"},{no:11,name:"UNITY_WEB"},{no:12,name:"NODE"},{no:13,name:"UNREAL"},{no:14,name:"ESP32"}]),ye=E.makeMessageType("livekit.ClientConfiguration",()=>[{no:1,name:"video",kind:"message",T:Te},{no:2,name:"screen",kind:"message",T:Te},{no:3,name:"resume_connection",kind:"enum",T:E.getEnumType(U)},{no:4,name:"disabled_codecs",kind:"message",T:Ce},{no:5,name:"force_relay",kind:"enum",T:E.getEnumType(U)}]),Te=E.makeMessageType("livekit.VideoConfiguration",()=>[{no:1,name:"hardware_encoder",kind:"enum",T:E.getEnumType(U)}]),Ce=E.makeMessageType("livekit.DisabledCodecs",()=>[{no:1,name:"codecs",kind:"message",T:H,repeated:!0},{no:2,name:"publish",kind:"message",T:H,repeated:!0}]),Se=E.makeMessageType("livekit.TimedVersion",()=>[{no:1,name:"unix_micro",kind:"scalar",T:3},{no:2,name:"ticks",kind:"scalar",T:5}]),Ee=E.makeEnum("livekit.DataStream.OperationType",[{no:0,name:"CREATE"},{no:1,name:"UPDATE"},{no:2,name:"DELETE"},{no:3,name:"REACTION"}]),we=E.makeMessageType("livekit.DataStream.TextHeader",()=>[{no:1,name:"operation_type",kind:"enum",T:E.getEnumType(Ee)},{no:2,name:"version",kind:"scalar",T:5},{no:3,name:"reply_to_stream_id",kind:"scalar",T:9},{no:4,name:"attached_stream_ids",kind:"scalar",T:9,repeated:!0},{no:5,name:"generated",kind:"scalar",T:8}],{localName:"DataStream_TextHeader"}),Pe=E.makeMessageType("livekit.DataStream.ByteHeader",()=>[{no:1,name:"name",kind:"scalar",T:9}],{localName:"DataStream_ByteHeader"}),Re=E.makeMessageType("livekit.DataStream.Header",()=>[{no:1,name:"stream_id",kind:"scalar",T:9},{no:2,name:"timestamp",kind:"scalar",T:3},{no:3,name:"topic",kind:"scalar",T:9},{no:4,name:"mime_type",kind:"scalar",T:9},{no:5,name:"total_length",kind:"scalar",T:4,opt:!0},{no:7,name:"encryption_type",kind:"enum",T:E.getEnumType(Q)},{no:8,name:"attributes",kind:"map",K:9,V:{kind:"scalar",T:9}},{no:9,name:"text_header",kind:"message",T:we,oneof:"content_header"},{no:10,name:"byte_header",kind:"message",T:Pe,oneof:"content_header"}],{localName:"DataStream_Header"}),_e=E.makeMessageType("livekit.DataStream.Chunk",()=>[{no:1,name:"stream_id",kind:"scalar",T:9},{no:2,name:"chunk_index",kind:"scalar",T:4},{no:3,name:"content",kind:"scalar",T:12},{no:4,name:"version",kind:"scalar",T:5},{no:5,name:"iv",kind:"scalar",T:12,opt:!0}],{localName:"DataStream_Chunk"}),Ie=E.makeMessageType("livekit.DataStream.Trailer",()=>[{no:1,name:"stream_id",kind:"scalar",T:9},{no:2,name:"reason",kind:"scalar",T:9},{no:3,name:"attributes",kind:"map",K:9,V:{kind:"scalar",T:9}}],{localName:"DataStream_Trailer"}),Oe=E.makeMessageType("livekit.SubscribedAudioCodec",()=>[{no:1,name:"codec",kind:"scalar",T:9},{no:2,name:"enabled",kind:"scalar",T:8}]),De=E.makeEnum("livekit.SignalTarget",[{no:0,name:"PUBLISHER"},{no:1,name:"SUBSCRIBER"}]),xe=E.makeEnum("livekit.StreamState",[{no:0,name:"ACTIVE"},{no:1,name:"PAUSED"}]),Me=E.makeEnum("livekit.CandidateProtocol",[{no:0,name:"UDP"},{no:1,name:"TCP"},{no:2,name:"TLS"}]),Ae=E.makeMessageType("livekit.SignalRequest",()=>[{no:1,name:"offer",kind:"message",T:We,oneof:"message"},{no:2,name:"answer",kind:"message",T:We,oneof:"message"},{no:3,name:"trickle",kind:"message",T:Fe,oneof:"message"},{no:4,name:"add_track",kind:"message",T:Ue,oneof:"message"},{no:5,name:"mute",kind:"message",T:je,oneof:"message"},{no:6,name:"subscription",kind:"message",T:Ke,oneof:"message"},{no:7,name:"track_setting",kind:"message",T:Je,oneof:"message"},{no:8,name:"leave",kind:"message",T:Ye,oneof:"message"},{no:10,name:"update_layers",kind:"message",T:Xe,oneof:"message"},{no:11,name:"subscription_permission",kind:"message",T:ht,oneof:"message"},{no:12,name:"sync_state",kind:"message",T:gt,oneof:"message"},{no:13,name:"simulate",kind:"message",T:kt,oneof:"message"},{no:14,name:"ping",kind:"scalar",T:3,oneof:"message"},{no:15,name:"update_metadata",kind:"message",T:Ze,oneof:"message"},{no:16,name:"ping_req",kind:"message",T:bt,oneof:"message"},{no:17,name:"update_audio_track",kind:"message",T:ze,oneof:"message"},{no:18,name:"update_video_track",kind:"message",T:Qe,oneof:"message"}]),Ne=E.makeMessageType("livekit.SignalResponse",()=>[{no:1,name:"join",kind:"message",T:Be,oneof:"message"},{no:2,name:"answer",kind:"message",T:We,oneof:"message"},{no:3,name:"offer",kind:"message",T:We,oneof:"message"},{no:4,name:"trickle",kind:"message",T:Fe,oneof:"message"},{no:5,name:"update",kind:"message",T:Ge,oneof:"message"},{no:6,name:"track_published",kind:"message",T:qe,oneof:"message"},{no:8,name:"leave",kind:"message",T:Ye,oneof:"message"},{no:9,name:"mute",kind:"message",T:je,oneof:"message"},{no:10,name:"speakers_changed",kind:"message",T:tt,oneof:"message"},{no:11,name:"room_update",kind:"message",T:it,oneof:"message"},{no:12,name:"connection_quality",kind:"message",T:rt,oneof:"message"},{no:13,name:"stream_state_update",kind:"message",T:at,oneof:"message"},{no:14,name:"subscribed_quality_update",kind:"message",T:dt,oneof:"message"},{no:15,name:"subscription_permission_update",kind:"message",T:pt,oneof:"message"},{no:16,name:"refresh_token",kind:"scalar",T:9,oneof:"message"},{no:17,name:"track_unpublished",kind:"message",T:He,oneof:"message"},{no:18,name:"pong",kind:"scalar",T:3,oneof:"message"},{no:19,name:"reconnect",kind:"message",T:Ve,oneof:"message"},{no:20,name:"pong_resp",kind:"message",T:yt,oneof:"message"},{no:21,name:"subscription_response",kind:"message",T:St,oneof:"message"},{no:22,name:"request_response",kind:"message",T:Et,oneof:"message"},{no:23,name:"track_subscribed",kind:"message",T:Pt,oneof:"message"},{no:24,name:"room_moved",kind:"message",T:mt,oneof:"message"},{no:25,name:"media_sections_requirement",kind:"message",T:Dt,oneof:"message"},{no:26,name:"subscribed_audio_codec_update",kind:"message",T:lt,oneof:"message"}]),Le=E.makeMessageType("livekit.SimulcastCodec",()=>[{no:1,name:"codec",kind:"scalar",T:9},{no:2,name:"cid",kind:"scalar",T:9},{no:4,name:"layers",kind:"message",T:X,repeated:!0},{no:5,name:"video_layer_mode",kind:"enum",T:E.getEnumType(Z)}]),Ue=E.makeMessageType("livekit.AddTrackRequest",()=>[{no:1,name:"cid",kind:"scalar",T:9},{no:2,name:"name",kind:"scalar",T:9},{no:3,name:"type",kind:"enum",T:E.getEnumType(M)},{no:4,name:"width",kind:"scalar",T:13},{no:5,name:"height",kind:"scalar",T:13},{no:6,name:"muted",kind:"scalar",T:8},{no:7,name:"disable_dtx",kind:"scalar",T:8},{no:8,name:"source",kind:"enum",T:E.getEnumType(A)},{no:9,name:"layers",kind:"message",T:X,repeated:!0},{no:10,name:"simulcast_codecs",kind:"message",T:Le,repeated:!0},{no:11,name:"sid",kind:"scalar",T:9},{no:12,name:"stereo",kind:"scalar",T:8},{no:13,name:"disable_red",kind:"scalar",T:8},{no:14,name:"encryption",kind:"enum",T:E.getEnumType(Q)},{no:15,name:"stream",kind:"scalar",T:9},{no:16,name:"backup_codec_policy",kind:"enum",T:E.getEnumType(x)},{no:17,name:"audio_features",kind:"enum",T:E.getEnumType(V),repeated:!0}]),Fe=E.makeMessageType("livekit.TrickleRequest",()=>[{no:1,name:"candidateInit",kind:"scalar",T:9},{no:2,name:"target",kind:"enum",T:E.getEnumType(De)},{no:3,name:"final",kind:"scalar",T:8}]),je=E.makeMessageType("livekit.MuteTrackRequest",()=>[{no:1,name:"sid",kind:"scalar",T:9},{no:2,name:"muted",kind:"scalar",T:8}]),Be=E.makeMessageType("livekit.JoinResponse",()=>[{no:1,name:"room",kind:"message",T:q},{no:2,name:"participant",kind:"message",T:G},{no:3,name:"other_participants",kind:"message",T:G,repeated:!0},{no:4,name:"server_version",kind:"scalar",T:9},{no:5,name:"ice_servers",kind:"message",T:et,repeated:!0},{no:6,name:"subscriber_primary",kind:"scalar",T:8},{no:7,name:"alternative_url",kind:"scalar",T:9},{no:8,name:"client_configuration",kind:"message",T:ye},{no:9,name:"server_region",kind:"scalar",T:9},{no:10,name:"ping_timeout",kind:"scalar",T:5},{no:11,name:"ping_interval",kind:"scalar",T:5},{no:12,name:"server_info",kind:"message",T:fe},{no:13,name:"sif_trailer",kind:"scalar",T:12},{no:14,name:"enabled_publish_codecs",kind:"message",T:H,repeated:!0},{no:15,name:"fast_publish",kind:"scalar",T:8}]),Ve=E.makeMessageType("livekit.ReconnectResponse",()=>[{no:1,name:"ice_servers",kind:"message",T:et,repeated:!0},{no:2,name:"client_configuration",kind:"message",T:ye},{no:3,name:"server_info",kind:"message",T:fe},{no:4,name:"last_message_seq",kind:"scalar",T:13}]),qe=E.makeMessageType("livekit.TrackPublishedResponse",()=>[{no:1,name:"cid",kind:"scalar",T:9},{no:2,name:"track",kind:"message",T:$}]),He=E.makeMessageType("livekit.TrackUnpublishedResponse",()=>[{no:1,name:"track_sid",kind:"scalar",T:9}]),We=E.makeMessageType("livekit.SessionDescription",()=>[{no:1,name:"type",kind:"scalar",T:9},{no:2,name:"sdp",kind:"scalar",T:9},{no:3,name:"id",kind:"scalar",T:13},{no:4,name:"mid_to_track_id",kind:"map",K:9,V:{kind:"scalar",T:9}}]),Ge=E.makeMessageType("livekit.ParticipantUpdate",()=>[{no:1,name:"participants",kind:"message",T:G,repeated:!0}]),Ke=E.makeMessageType("livekit.UpdateSubscription",()=>[{no:1,name:"track_sids",kind:"scalar",T:9,repeated:!0},{no:2,name:"subscribe",kind:"scalar",T:8},{no:3,name:"participant_tracks",kind:"message",T:ge,repeated:!0}]),Je=E.makeMessageType("livekit.UpdateTrackSettings",()=>[{no:1,name:"track_sids",kind:"scalar",T:9,repeated:!0},{no:3,name:"disabled",kind:"scalar",T:8},{no:4,name:"quality",kind:"enum",T:E.getEnumType(N)},{no:5,name:"width",kind:"scalar",T:13},{no:6,name:"height",kind:"scalar",T:13},{no:7,name:"fps",kind:"scalar",T:13},{no:8,name:"priority",kind:"scalar",T:13}]),ze=E.makeMessageType("livekit.UpdateLocalAudioTrack",()=>[{no:1,name:"track_sid",kind:"scalar",T:9},{no:2,name:"features",kind:"enum",T:E.getEnumType(V),repeated:!0}]),Qe=E.makeMessageType("livekit.UpdateLocalVideoTrack",()=>[{no:1,name:"track_sid",kind:"scalar",T:9},{no:2,name:"width",kind:"scalar",T:13},{no:3,name:"height",kind:"scalar",T:13}]),Ye=E.makeMessageType("livekit.LeaveRequest",()=>[{no:1,name:"can_reconnect",kind:"scalar",T:8},{no:2,name:"reason",kind:"enum",T:E.getEnumType(F)},{no:3,name:"action",kind:"enum",T:E.getEnumType($e)},{no:4,name:"regions",kind:"message",T:Tt}]),$e=E.makeEnum("livekit.LeaveRequest.Action",[{no:0,name:"DISCONNECT"},{no:1,name:"RESUME"},{no:2,name:"RECONNECT"}]),Xe=E.makeMessageType("livekit.UpdateVideoLayers",()=>[{no:1,name:"track_sid",kind:"scalar",T:9},{no:2,name:"layers",kind:"message",T:X,repeated:!0}]),Ze=E.makeMessageType("livekit.UpdateParticipantMetadata",()=>[{no:1,name:"metadata",kind:"scalar",T:9},{no:2,name:"name",kind:"scalar",T:9},{no:3,name:"attributes",kind:"map",K:9,V:{kind:"scalar",T:9}},{no:4,name:"request_id",kind:"scalar",T:13}]),et=E.makeMessageType("livekit.ICEServer",()=>[{no:1,name:"urls",kind:"scalar",T:9,repeated:!0},{no:2,name:"username",kind:"scalar",T:9},{no:3,name:"credential",kind:"scalar",T:9}]),tt=E.makeMessageType("livekit.SpeakersChanged",()=>[{no:1,name:"speakers",kind:"message",T:se,repeated:!0}]),it=E.makeMessageType("livekit.RoomUpdate",()=>[{no:1,name:"room",kind:"message",T:q}]),nt=E.makeMessageType("livekit.ConnectionQualityInfo",()=>[{no:1,name:"participant_sid",kind:"scalar",T:9},{no:2,name:"quality",kind:"enum",T:E.getEnumType(L)},{no:3,name:"score",kind:"scalar",T:2}]),rt=E.makeMessageType("livekit.ConnectionQualityUpdate",()=>[{no:1,name:"updates",kind:"message",T:nt,repeated:!0}]),st=E.makeMessageType("livekit.StreamStateInfo",()=>[{no:1,name:"participant_sid",kind:"scalar",T:9},{no:2,name:"track_sid",kind:"scalar",T:9},{no:3,name:"state",kind:"enum",T:E.getEnumType(xe)}]),at=E.makeMessageType("livekit.StreamStateUpdate",()=>[{no:1,name:"stream_states",kind:"message",T:st,repeated:!0}]),ot=E.makeMessageType("livekit.SubscribedQuality",()=>[{no:1,name:"quality",kind:"enum",T:E.getEnumType(N)},{no:2,name:"enabled",kind:"scalar",T:8}]),ct=E.makeMessageType("livekit.SubscribedCodec",()=>[{no:1,name:"codec",kind:"scalar",T:9},{no:2,name:"qualities",kind:"message",T:ot,repeated:!0}]),dt=E.makeMessageType("livekit.SubscribedQualityUpdate",()=>[{no:1,name:"track_sid",kind:"scalar",T:9},{no:2,name:"subscribed_qualities",kind:"message",T:ot,repeated:!0},{no:3,name:"subscribed_codecs",kind:"message",T:ct,repeated:!0}]),lt=E.makeMessageType("livekit.SubscribedAudioCodecUpdate",()=>[{no:1,name:"track_sid",kind:"scalar",T:9},{no:2,name:"subscribed_audio_codecs",kind:"message",T:Oe,repeated:!0}]),ut=E.makeMessageType("livekit.TrackPermission",()=>[{no:1,name:"participant_sid",kind:"scalar",T:9},{no:2,name:"all_tracks",kind:"scalar",T:8},{no:3,name:"track_sids",kind:"scalar",T:9,repeated:!0},{no:4,name:"participant_identity",kind:"scalar",T:9}]),ht=E.makeMessageType("livekit.SubscriptionPermission",()=>[{no:1,name:"all_participants",kind:"scalar",T:8},{no:2,name:"track_permissions",kind:"message",T:ut,repeated:!0}]),pt=E.makeMessageType("livekit.SubscriptionPermissionUpdate",()=>[{no:1,name:"participant_sid",kind:"scalar",T:9},{no:2,name:"track_sid",kind:"scalar",T:9},{no:3,name:"allowed",kind:"scalar",T:8}]),mt=E.makeMessageType("livekit.RoomMovedResponse",()=>[{no:1,name:"room",kind:"message",T:q},{no:2,name:"token",kind:"scalar",T:9},{no:3,name:"participant",kind:"message",T:G},{no:4,name:"other_participants",kind:"message",T:G,repeated:!0}]),gt=E.makeMessageType("livekit.SyncState",()=>[{no:1,name:"answer",kind:"message",T:We},{no:2,name:"subscription",kind:"message",T:Ke},{no:3,name:"publish_tracks",kind:"message",T:qe,repeated:!0},{no:4,name:"data_channels",kind:"message",T:vt,repeated:!0},{no:5,name:"offer",kind:"message",T:We},{no:6,name:"track_sids_disabled",kind:"scalar",T:9,repeated:!0},{no:7,name:"datachannel_receive_states",kind:"message",T:ft,repeated:!0}]),ft=E.makeMessageType("livekit.DataChannelReceiveState",()=>[{no:1,name:"publisher_sid",kind:"scalar",T:9},{no:2,name:"last_seq",kind:"scalar",T:13}]),vt=E.makeMessageType("livekit.DataChannelInfo",()=>[{no:1,name:"label",kind:"scalar",T:9},{no:2,name:"id",kind:"scalar",T:13},{no:3,name:"target",kind:"enum",T:E.getEnumType(De)}]),kt=E.makeMessageType("livekit.SimulateScenario",()=>[{no:1,name:"speaker_update",kind:"scalar",T:5,oneof:"scenario"},{no:2,name:"node_failure",kind:"scalar",T:8,oneof:"scenario"},{no:3,name:"migration",kind:"scalar",T:8,oneof:"scenario"},{no:4,name:"server_leave",kind:"scalar",T:8,oneof:"scenario"},{no:5,name:"switch_candidate_protocol",kind:"enum",T:E.getEnumType(Me),oneof:"scenario"},{no:6,name:"subscriber_bandwidth",kind:"scalar",T:3,oneof:"scenario"},{no:7,name:"disconnect_signal_on_resume",kind:"scalar",T:8,oneof:"scenario"},{no:8,name:"disconnect_signal_on_resume_no_messages",kind:"scalar",T:8,oneof:"scenario"},{no:9,name:"leave_request_full_reconnect",kind:"scalar",T:8,oneof:"scenario"}]),bt=E.makeMessageType("livekit.Ping",()=>[{no:1,name:"timestamp",kind:"scalar",T:3},{no:2,name:"rtt",kind:"scalar",T:3}]),yt=E.makeMessageType("livekit.Pong",()=>[{no:1,name:"last_ping_timestamp",kind:"scalar",T:3},{no:2,name:"timestamp",kind:"scalar",T:3}]),Tt=E.makeMessageType("livekit.RegionSettings",()=>[{no:1,name:"regions",kind:"message",T:Ct,repeated:!0}]),Ct=E.makeMessageType("livekit.RegionInfo",()=>[{no:1,name:"region",kind:"scalar",T:9},{no:2,name:"url",kind:"scalar",T:9},{no:3,name:"distance",kind:"scalar",T:3}]),St=E.makeMessageType("livekit.SubscriptionResponse",()=>[{no:1,name:"track_sid",kind:"scalar",T:9},{no:2,name:"err",kind:"enum",T:E.getEnumType(B)}]),Et=E.makeMessageType("livekit.RequestResponse",()=>[{no:1,name:"request_id",kind:"scalar",T:13},{no:2,name:"reason",kind:"enum",T:E.getEnumType(wt)},{no:3,name:"message",kind:"scalar",T:9},{no:4,name:"trickle",kind:"message",T:Fe,oneof:"request"},{no:5,name:"add_track",kind:"message",T:Ue,oneof:"request"},{no:6,name:"mute",kind:"message",T:je,oneof:"request"},{no:7,name:"update_metadata",kind:"message",T:Ze,oneof:"request"},{no:8,name:"update_audio_track",kind:"message",T:ze,oneof:"request"},{no:9,name:"update_video_track",kind:"message",T:Qe,oneof:"request"}]),wt=E.makeEnum("livekit.RequestResponse.Reason",[{no:0,name:"OK"},{no:1,name:"NOT_FOUND"},{no:2,name:"NOT_ALLOWED"},{no:3,name:"LIMIT_EXCEEDED"},{no:4,name:"QUEUED"},{no:5,name:"UNSUPPORTED_TYPE"},{no:6,name:"UNCLASSIFIED_ERROR"}]),Pt=E.makeMessageType("livekit.TrackSubscribed",()=>[{no:1,name:"track_sid",kind:"scalar",T:9}]),Rt=E.makeMessageType("livekit.ConnectionSettings",()=>[{no:1,name:"auto_subscribe",kind:"scalar",T:8},{no:2,name:"adaptive_stream",kind:"scalar",T:8},{no:3,name:"subscriber_allow_pause",kind:"scalar",T:8,opt:!0},{no:4,name:"disable_ice_lite",kind:"scalar",T:8}]),_t=E.makeMessageType("livekit.JoinRequest",()=>[{no:1,name:"client_info",kind:"message",T:ke},{no:2,name:"connection_settings",kind:"message",T:Rt},{no:3,name:"metadata",kind:"scalar",T:9},{no:4,name:"participant_attributes",kind:"map",K:9,V:{kind:"scalar",T:9}},{no:5,name:"add_track_requests",kind:"message",T:Ue,repeated:!0},{no:6,name:"publisher_offer",kind:"message",T:We},{no:7,name:"reconnect",kind:"scalar",T:8},{no:8,name:"reconnect_reason",kind:"enum",T:E.getEnumType(j)},{no:9,name:"participant_sid",kind:"scalar",T:9},{no:10,name:"sync_state",kind:"message",T:gt}]),It=E.makeMessageType("livekit.WrappedJoinRequest",()=>[{no:1,name:"compression",kind:"enum",T:E.getEnumType(Ot)},{no:2,name:"join_request",kind:"scalar",T:12}]),Ot=E.makeEnum("livekit.WrappedJoinRequest.Compression",[{no:0,name:"NONE"},{no:1,name:"GZIP"}]),Dt=E.makeMessageType("livekit.MediaSectionsRequirement",()=>[{no:1,name:"num_audios",kind:"scalar",T:13},{no:2,name:"num_videos",kind:"scalar",T:13}]);function getDefaultExportFromCjs(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var xt,Mt={exports:{}};var At,Nt,Lt,Ut,Ft,jt=(xt||(xt=1,Nt=Mt.exports,Lt=function(){var noop=function(){},e="undefined",t=typeof window!==e&&typeof window.navigator!==e&&/Trident\/|MSIE /.test(window.navigator.userAgent),i=["trace","debug","info","warn","error"],n={},s=null;function bindMethod(e,t){var i=e[t];if("function"==typeof i.bind)return i.bind(e);try{return Function.prototype.bind.call(i,e)}catch(t){return function(){return Function.prototype.apply.apply(i,[e,arguments])}}}function traceForIE(){console.log&&(console.log.apply?console.log.apply(console,arguments):Function.prototype.apply.apply(console.log,[console,arguments])),console.trace&&console.trace()}function replaceLoggingMethods(){for(var t=this.getLevel(),n=0;n<i.length;n++){var s=i[n];this[s]=n<t?noop:this.methodFactory(s,t,this.name)}if(this.log=this.debug,typeof console===e&&t<this.levels.SILENT)return"No console available for logging"}function enableLoggingWhenConsoleArrives(t){return function(){typeof console!==e&&(replaceLoggingMethods.call(this),this[t].apply(this,arguments))}}function defaultMethodFactory(i,n,s){return function(i){return"debug"===i&&(i="log"),typeof console!==e&&("trace"===i&&t?traceForIE:void 0!==console[i]?bindMethod(console,i):void 0!==console.log?bindMethod(console,"log"):noop)}(i)||enableLoggingWhenConsoleArrives.apply(this,arguments)}function Logger(t,a){var c,l,u,h=this,p="loglevel";function getPersistedLevel(){var t;if(typeof window!==e&&p){try{t=window.localStorage[p]}catch(e){}if(typeof t===e)try{var i=window.document.cookie,n=encodeURIComponent(p),s=i.indexOf(n+"=");-1!==s&&(t=/^([^;]+)/.exec(i.slice(s+n.length+1))[1])}catch(e){}return void 0===h.levels[t]&&(t=void 0),t}}function normalizeLevel(e){var t=e;if("string"==typeof t&&void 0!==h.levels[t.toUpperCase()]&&(t=h.levels[t.toUpperCase()]),"number"==typeof t&&t>=0&&t<=h.levels.SILENT)return t;throw new TypeError("log.setLevel() called with invalid level: "+e)}"string"==typeof t?p+=":"+t:"symbol"==typeof t&&(p=void 0),h.name=t,h.levels={TRACE:0,DEBUG:1,INFO:2,WARN:3,ERROR:4,SILENT:5},h.methodFactory=a||defaultMethodFactory,h.getLevel=function(){return null!=u?u:null!=l?l:c},h.setLevel=function(t,n){return u=normalizeLevel(t),!1!==n&&function(t){var n=(i[t]||"silent").toUpperCase();if(typeof window!==e&&p){try{return void(window.localStorage[p]=n)}catch(e){}try{window.document.cookie=encodeURIComponent(p)+"="+n+";"}catch(e){}}}(u),replaceLoggingMethods.call(h)},h.setDefaultLevel=function(e){l=normalizeLevel(e),getPersistedLevel()||h.setLevel(e,!1)},h.resetLevel=function(){u=null,function(){if(typeof window!==e&&p){try{window.localStorage.removeItem(p)}catch(e){}try{window.document.cookie=encodeURIComponent(p)+"=; expires=Thu, 01 Jan 1970 00:00:00 UTC"}catch(e){}}}(),replaceLoggingMethods.call(h)},h.enableAll=function(e){h.setLevel(h.levels.TRACE,e)},h.disableAll=function(e){h.setLevel(h.levels.SILENT,e)},h.rebuild=function(){if(s!==h&&(c=normalizeLevel(s.getLevel())),replaceLoggingMethods.call(h),s===h)for(var e in n)n[e].rebuild()},c=normalizeLevel(s?s.getLevel():"WARN");var m=getPersistedLevel();null!=m&&(u=normalizeLevel(m)),replaceLoggingMethods.call(h)}(s=new Logger).getLogger=function(e){if("symbol"!=typeof e&&"string"!=typeof e||""===e)throw new TypeError("You must supply a name when creating a logger.");var t=n[e];return t||(t=n[e]=new Logger(e,s.methodFactory)),t};var a=typeof window!==e?window.log:void 0;return s.noConflict=function(){return typeof window!==e&&window.log===s&&(window.log=a),s},s.getLoggers=function(){return n},s.default=s,s},(At=Mt).exports?At.exports=Lt():Nt.log=Lt()),Mt.exports);!function(e){e[e.trace=0]="trace",e[e.debug=1]="debug",e[e.info=2]="info",e[e.warn=3]="warn",e[e.error=4]="error",e[e.silent=5]="silent"}(Ut||(Ut={})),function(e){e.Default="livekit",e.Room="livekit-room",e.TokenSource="livekit-token-source",e.Participant="livekit-participant",e.Track="livekit-track",e.Publication="livekit-track-publication",e.Engine="livekit-engine",e.Signal="livekit-signal",e.PCManager="livekit-pc-manager",e.PCTransport="livekit-pc-transport",e.E2EE="lk-e2ee"}(Ft||(Ft={}));let Bt=jt.getLogger("livekit");const Vt=Object.values(Ft).map(e=>jt.getLogger(e));function getLogger(e){const t=jt.getLogger(e);return t.setDefaultLevel(Bt.getLevel()),t}Bt.setDefaultLevel(Ut.info);const qt=jt.getLogger("lk-e2ee"),Ht=7e3,Wt=[0,300,1200,2700,4800,Ht,Ht,Ht,Ht,Ht];function __awaiter(e,t,i,n){return new(i||(i=Promise))(function(s,a){function fulfilled(e){try{step(n.next(e))}catch(e){a(e)}}function rejected(e){try{step(n.throw(e))}catch(e){a(e)}}function step(e){var t;e.done?s(e.value):(t=e.value,t instanceof i?t:new i(function(e){e(t)})).then(fulfilled,rejected)}step((n=n.apply(e,t||[])).next())})}function __values(e){var t="function"==typeof Symbol&&Symbol.iterator,i=t&&e[t],n=0;if(i)return i.call(e);if(e&&"number"==typeof e.length)return{next:function(){return e&&n>=e.length&&(e=void 0),{value:e&&e[n++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function __asyncValues(e){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var t,i=e[Symbol.asyncIterator];return i?i.call(e):(e=__values(e),t={},verb("next"),verb("throw"),verb("return"),t[Symbol.asyncIterator]=function(){return this},t);function verb(i){t[i]=e[i]&&function(t){return new Promise(function(n,s){(function(e,t,i,n){Promise.resolve(n).then(function(t){e({value:t,done:i})},t)})(n,s,(t=e[i](t)).done,t.value)})}}}"function"==typeof SuppressedError&&SuppressedError;var Gt,Kt={exports:{}};var Jt=function(){if(Gt)return Kt.exports;Gt=1;var e,t="object"==typeof Reflect?Reflect:null,i=t&&"function"==typeof t.apply?t.apply:function(e,t,i){return Function.prototype.apply.call(e,t,i)};e=t&&"function"==typeof t.ownKeys?t.ownKeys:Object.getOwnPropertySymbols?function(e){return Object.getOwnPropertyNames(e).concat(Object.getOwnPropertySymbols(e))}:function(e){return Object.getOwnPropertyNames(e)};var n=Number.isNaN||function(e){return e!=e};function EventEmitter(){EventEmitter.init.call(this)}Kt.exports=EventEmitter,Kt.exports.once=function(e,t){return new Promise(function(i,n){function errorListener(i){e.removeListener(t,resolver),n(i)}function resolver(){"function"==typeof e.removeListener&&e.removeListener("error",errorListener),i([].slice.call(arguments))}eventTargetAgnosticAddListener(e,t,resolver,{once:!0}),"error"!==t&&function(e,t,i){"function"==typeof e.on&&eventTargetAgnosticAddListener(e,"error",t,i)}(e,errorListener,{once:!0})})},EventEmitter.EventEmitter=EventEmitter,EventEmitter.prototype._events=void 0,EventEmitter.prototype._eventsCount=0,EventEmitter.prototype._maxListeners=void 0;var s=10;function checkListener(e){if("function"!=typeof e)throw new TypeError('The "listener" argument must be of type Function. Received type '+typeof e)}function _getMaxListeners(e){return void 0===e._maxListeners?EventEmitter.defaultMaxListeners:e._maxListeners}function _addListener(e,t,i,n){var s,a,c,l;if(checkListener(i),void 0===(a=e._events)?(a=e._events=Object.create(null),e._eventsCount=0):(void 0!==a.newListener&&(e.emit("newListener",t,i.listener?i.listener:i),a=e._events),c=a[t]),void 0===c)c=a[t]=i,++e._eventsCount;else if("function"==typeof c?c=a[t]=n?[i,c]:[c,i]:n?c.unshift(i):c.push(i),(s=_getMaxListeners(e))>0&&c.length>s&&!c.warned){c.warned=!0;var u=new Error("Possible EventEmitter memory leak detected. "+c.length+" "+String(t)+" listeners added. Use emitter.setMaxListeners() to increase limit");u.name="MaxListenersExceededWarning",u.emitter=e,u.type=t,u.count=c.length,l=u,console&&console.warn&&console.warn(l)}return e}function onceWrapper(){if(!this.fired)return this.target.removeListener(this.type,this.wrapFn),this.fired=!0,0===arguments.length?this.listener.call(this.target):this.listener.apply(this.target,arguments)}function _onceWrap(e,t,i){var n={fired:!1,wrapFn:void 0,target:e,type:t,listener:i},s=onceWrapper.bind(n);return s.listener=i,n.wrapFn=s,s}function _listeners(e,t,i){var n=e._events;if(void 0===n)return[];var s=n[t];return void 0===s?[]:"function"==typeof s?i?[s.listener||s]:[s]:i?function(e){for(var t=new Array(e.length),i=0;i<t.length;++i)t[i]=e[i].listener||e[i];return t}(s):arrayClone(s,s.length)}function listenerCount(e){var t=this._events;if(void 0!==t){var i=t[e];if("function"==typeof i)return 1;if(void 0!==i)return i.length}return 0}function arrayClone(e,t){for(var i=new Array(t),n=0;n<t;++n)i[n]=e[n];return i}function eventTargetAgnosticAddListener(e,t,i,n){if("function"==typeof e.on)n.once?e.once(t,i):e.on(t,i);else{if("function"!=typeof e.addEventListener)throw new TypeError('The "emitter" argument must be of type EventEmitter. Received type '+typeof e);e.addEventListener(t,function wrapListener(s){n.once&&e.removeEventListener(t,wrapListener),i(s)})}}return Object.defineProperty(EventEmitter,"defaultMaxListeners",{enumerable:!0,get:function(){return s},set:function(e){if("number"!=typeof e||e<0||n(e))throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received '+e+".");s=e}}),EventEmitter.init=function(){void 0!==this._events&&this._events!==Object.getPrototypeOf(this)._events||(this._events=Object.create(null),this._eventsCount=0),this._maxListeners=this._maxListeners||void 0},EventEmitter.prototype.setMaxListeners=function(e){if("number"!=typeof e||e<0||n(e))throw new RangeError('The value of "n" is out of range. It must be a non-negative number. Received '+e+".");return this._maxListeners=e,this},EventEmitter.prototype.getMaxListeners=function(){return _getMaxListeners(this)},EventEmitter.prototype.emit=function(e){for(var t=[],n=1;n<arguments.length;n++)t.push(arguments[n]);var s="error"===e,a=this._events;if(void 0!==a)s=s&&void 0===a.error;else if(!s)return!1;if(s){var c;if(t.length>0&&(c=t[0]),c instanceof Error)throw c;var l=new Error("Unhandled error."+(c?" ("+c.message+")":""));throw l.context=c,l}var u=a[e];if(void 0===u)return!1;if("function"==typeof u)i(u,this,t);else{var h=u.length,p=arrayClone(u,h);for(n=0;n<h;++n)i(p[n],this,t)}return!0},EventEmitter.prototype.addListener=function(e,t){return _addListener(this,e,t,!1)},EventEmitter.prototype.on=EventEmitter.prototype.addListener,EventEmitter.prototype.prependListener=function(e,t){return _addListener(this,e,t,!0)},EventEmitter.prototype.once=function(e,t){return checkListener(t),this.on(e,_onceWrap(this,e,t)),this},EventEmitter.prototype.prependOnceListener=function(e,t){return checkListener(t),this.prependListener(e,_onceWrap(this,e,t)),this},EventEmitter.prototype.removeListener=function(e,t){var i,n,s,a,c;if(checkListener(t),void 0===(n=this._events))return this;if(void 0===(i=n[e]))return this;if(i===t||i.listener===t)0===--this._eventsCount?this._events=Object.create(null):(delete n[e],n.removeListener&&this.emit("removeListener",e,i.listener||t));else if("function"!=typeof i){for(s=-1,a=i.length-1;a>=0;a--)if(i[a]===t||i[a].listener===t){c=i[a].listener,s=a;break}if(s<0)return this;0===s?i.shift():function(e,t){for(;t+1<e.length;t++)e[t]=e[t+1];e.pop()}(i,s),1===i.length&&(n[e]=i[0]),void 0!==n.removeListener&&this.emit("removeListener",e,c||t)}return this},EventEmitter.prototype.off=EventEmitter.prototype.removeListener,EventEmitter.prototype.removeAllListeners=function(e){var t,i,n;if(void 0===(i=this._events))return this;if(void 0===i.removeListener)return 0===arguments.length?(this._events=Object.create(null),this._eventsCount=0):void 0!==i[e]&&(0===--this._eventsCount?this._events=Object.create(null):delete i[e]),this;if(0===arguments.length){var s,a=Object.keys(i);for(n=0;n<a.length;++n)"removeListener"!==(s=a[n])&&this.removeAllListeners(s);return this.removeAllListeners("removeListener"),this._events=Object.create(null),this._eventsCount=0,this}if("function"==typeof(t=i[e]))this.removeListener(e,t);else if(void 0!==t)for(n=t.length-1;n>=0;n--)this.removeListener(e,t[n]);return this},EventEmitter.prototype.listeners=function(e){return _listeners(this,e,!0)},EventEmitter.prototype.rawListeners=function(e){return _listeners(this,e,!1)},EventEmitter.listenerCount=function(e,t){return"function"==typeof e.listenerCount?e.listenerCount(t):listenerCount.call(e,t)},EventEmitter.prototype.listenerCount=listenerCount,EventEmitter.prototype.eventNames=function(){return this._eventsCount>0?e(this._events):[]},Kt.exports}();let zt=!0,Qt=!0;function extractVersion(e,t,i){const n=e.match(t);return n&&n.length>=i&&parseFloat(n[i],10)}function wrapPeerConnectionEvent(e,t,i){if(!e.RTCPeerConnection)return;const n=e.RTCPeerConnection.prototype,s=n.addEventListener;n.addEventListener=function(e,n){if(e!==t)return s.apply(this,arguments);const wrappedCallback=e=>{const t=i(e);t&&(n.handleEvent?n.handleEvent(t):n(t))};return this._eventMap=this._eventMap||{},this._eventMap[t]||(this._eventMap[t]=new Map),this._eventMap[t].set(n,wrappedCallback),s.apply(this,[e,wrappedCallback])};const a=n.removeEventListener;n.removeEventListener=function(e,i){if(e!==t||!this._eventMap||!this._eventMap[t])return a.apply(this,arguments);if(!this._eventMap[t].has(i))return a.apply(this,arguments);const n=this._eventMap[t].get(i);return this._eventMap[t].delete(i),0===this._eventMap[t].size&&delete this._eventMap[t],0===Object.keys(this._eventMap).length&&delete this._eventMap,a.apply(this,[e,n])},Object.defineProperty(n,"on"+t,{get(){return this["_on"+t]},set(e){this["_on"+t]&&(this.removeEventListener(t,this["_on"+t]),delete this["_on"+t]),e&&this.addEventListener(t,this["_on"+t]=e)},enumerable:!0,configurable:!0})}function disableLog(e){return"boolean"!=typeof e?new Error("Argument type: "+typeof e+". Please use a boolean."):(zt=e,e?"adapter.js logging disabled":"adapter.js logging enabled")}function disableWarnings(e){return"boolean"!=typeof e?new Error("Argument type: "+typeof e+". Please use a boolean."):(Qt=!e,"adapter.js deprecation warnings "+(e?"disabled":"enabled"))}function log(){if("object"==typeof window){if(zt)return;"undefined"!=typeof console&&"function"==typeof console.log&&console.log.apply(console,arguments)}}function deprecated(e,t){Qt&&console.warn(e+" is deprecated, please use "+t+" instead.")}function isObject$1(e){return"[object Object]"===Object.prototype.toString.call(e)}function compactObject(e){return isObject$1(e)?Object.keys(e).reduce(function(t,i){const n=isObject$1(e[i]),s=n?compactObject(e[i]):e[i],a=n&&!Object.keys(s).length;return void 0===s||a?t:Object.assign(t,{[i]:s})},{}):e}function walkStats(e,t,i){t&&!i.has(t.id)&&(i.set(t.id,t),Object.keys(t).forEach(n=>{n.endsWith("Id")?walkStats(e,e.get(t[n]),i):n.endsWith("Ids")&&t[n].forEach(t=>{walkStats(e,e.get(t),i)})}))}function filterStats(e,t,i){const n=i?"outbound-rtp":"inbound-rtp",s=new Map;if(null===t)return s;const a=[];return e.forEach(e=>{"track"===e.type&&e.trackIdentifier===t.id&&a.push(e)}),a.forEach(t=>{e.forEach(i=>{i.type===n&&i.trackId===t.id&&walkStats(e,i,s)})}),s}const Yt=log;function shimGetUserMedia$2(e,t){const i=e&&e.navigator;if(!i.mediaDevices)return;const constraintsToChrome_=function(e){if("object"!=typeof e||e.mandatory||e.optional)return e;const t={};return Object.keys(e).forEach(i=>{if("require"===i||"advanced"===i||"mediaSource"===i)return;const n="object"==typeof e[i]?e[i]:{ideal:e[i]};void 0!==n.exact&&"number"==typeof n.exact&&(n.min=n.max=n.exact);const oldname_=function(e,t){return e?e+t.charAt(0).toUpperCase()+t.slice(1):"deviceId"===t?"sourceId":t};if(void 0!==n.ideal){t.optional=t.optional||[];let e={};"number"==typeof n.ideal?(e[oldname_("min",i)]=n.ideal,t.optional.push(e),e={},e[oldname_("max",i)]=n.ideal,t.optional.push(e)):(e[oldname_("",i)]=n.ideal,t.optional.push(e))}void 0!==n.exact&&"number"!=typeof n.exact?(t.mandatory=t.mandatory||{},t.mandatory[oldname_("",i)]=n.exact):["min","max"].forEach(e=>{void 0!==n[e]&&(t.mandatory=t.mandatory||{},t.mandatory[oldname_(e,i)]=n[e])})}),e.advanced&&(t.optional=(t.optional||[]).concat(e.advanced)),t},shimConstraints_=function(e,n){if(t.version>=61)return n(e);if((e=JSON.parse(JSON.stringify(e)))&&"object"==typeof e.audio){const remap=function(e,t,i){t in e&&!(i in e)&&(e[i]=e[t],delete e[t])};remap((e=JSON.parse(JSON.stringify(e))).audio,"autoGainControl","googAutoGainControl"),remap(e.audio,"noiseSuppression","googNoiseSuppression"),e.audio=constraintsToChrome_(e.audio)}if(e&&"object"==typeof e.video){let s=e.video.facingMode;s=s&&("object"==typeof s?s:{ideal:s});const a=t.version<66;if(s&&("user"===s.exact||"environment"===s.exact||"user"===s.ideal||"environment"===s.ideal)&&(!i.mediaDevices.getSupportedConstraints||!i.mediaDevices.getSupportedConstraints().facingMode||a)){let t;if(delete e.video.facingMode,"environment"===s.exact||"environment"===s.ideal?t=["back","rear"]:"user"!==s.exact&&"user"!==s.ideal||(t=["front"]),t)return i.mediaDevices.enumerateDevices().then(i=>{let a=(i=i.filter(e=>"videoinput"===e.kind)).find(e=>t.some(t=>e.label.toLowerCase().includes(t)));return!a&&i.length&&t.includes("back")&&(a=i[i.length-1]),a&&(e.video.deviceId=s.exact?{exact:a.deviceId}:{ideal:a.deviceId}),e.video=constraintsToChrome_(e.video),Yt("chrome: "+JSON.stringify(e)),n(e)})}e.video=constraintsToChrome_(e.video)}return Yt("chrome: "+JSON.stringify(e)),n(e)},shimError_=function(e){return t.version>=64?e:{name:{PermissionDeniedError:"NotAllowedError",PermissionDismissedError:"NotAllowedError",InvalidStateError:"NotAllowedError",DevicesNotFoundError:"NotFoundError",ConstraintNotSatisfiedError:"OverconstrainedError",TrackStartError:"NotReadableError",MediaDeviceFailedDueToShutdown:"NotAllowedError",MediaDeviceKillSwitchOn:"NotAllowedError",TabCaptureError:"AbortError",ScreenCaptureError:"AbortError",DeviceCaptureError:"AbortError"}[e.name]||e.name,message:e.message,constraint:e.constraint||e.constraintName,toString(){return this.name+(this.message&&": ")+this.message}}};if(i.getUserMedia=function(e,t,n){shimConstraints_(e,e=>{i.webkitGetUserMedia(e,t,e=>{n&&n(shimError_(e))})})}.bind(i),i.mediaDevices.getUserMedia){const e=i.mediaDevices.getUserMedia.bind(i.mediaDevices);i.mediaDevices.getUserMedia=function(t){return shimConstraints_(t,t=>e(t).then(e=>{if(t.audio&&!e.getAudioTracks().length||t.video&&!e.getVideoTracks().length)throw e.getTracks().forEach(e=>{e.stop()}),new DOMException("","NotFoundError");return e},e=>Promise.reject(shimError_(e))))}}}function shimMediaStream(e){e.MediaStream=e.MediaStream||e.webkitMediaStream}function shimOnTrack$1(e){if("object"==typeof e&&e.RTCPeerConnection&&!("ontrack"in e.RTCPeerConnection.prototype)){Object.defineProperty(e.RTCPeerConnection.prototype,"ontrack",{get(){return this._ontrack},set(e){this._ontrack&&this.removeEventListener("track",this._ontrack),this.addEventListener("track",this._ontrack=e)},enumerable:!0,configurable:!0});const t=e.RTCPeerConnection.prototype.setRemoteDescription;e.RTCPeerConnection.prototype.setRemoteDescription=function(){return this._ontrackpoly||(this._ontrackpoly=t=>{t.stream.addEventListener("addtrack",i=>{let n;n=e.RTCPeerConnection.prototype.getReceivers?this.getReceivers().find(e=>e.track&&e.track.id===i.track.id):{track:i.track};const s=new Event("track");s.track=i.track,s.receiver=n,s.transceiver={receiver:n},s.streams=[t.stream],this.dispatchEvent(s)}),t.stream.getTracks().forEach(i=>{let n;n=e.RTCPeerConnection.prototype.getReceivers?this.getReceivers().find(e=>e.track&&e.track.id===i.id):{track:i};const s=new Event("track");s.track=i,s.receiver=n,s.transceiver={receiver:n},s.streams=[t.stream],this.dispatchEvent(s)})},this.addEventListener("addstream",this._ontrackpoly)),t.apply(this,arguments)}}else wrapPeerConnectionEvent(e,"track",e=>(e.transceiver||Object.defineProperty(e,"transceiver",{value:{receiver:e.receiver}}),e))}function shimGetSendersWithDtmf(e){if("object"==typeof e&&e.RTCPeerConnection&&!("getSenders"in e.RTCPeerConnection.prototype)&&"createDTMFSender"in e.RTCPeerConnection.prototype){const shimSenderWithDtmf=function(e,t){return{track:t,get dtmf(){return void 0===this._dtmf&&("audio"===t.kind?this._dtmf=e.createDTMFSender(t):this._dtmf=null),this._dtmf},_pc:e}};if(!e.RTCPeerConnection.prototype.getSenders){e.RTCPeerConnection.prototype.getSenders=function(){return this._senders=this._senders||[],this._senders.slice()};const t=e.RTCPeerConnection.prototype.addTrack;e.RTCPeerConnection.prototype.addTrack=function(e,i){let n=t.apply(this,arguments);return n||(n=shimSenderWithDtmf(this,e),this._senders.push(n)),n};const i=e.RTCPeerConnection.prototype.removeTrack;e.RTCPeerConnection.prototype.removeTrack=function(e){i.apply(this,arguments);const t=this._senders.indexOf(e);-1!==t&&this._senders.splice(t,1)}}const t=e.RTCPeerConnection.prototype.addStream;e.RTCPeerConnection.prototype.addStream=function(e){this._senders=this._senders||[],t.apply(this,[e]),e.getTracks().forEach(e=>{this._senders.push(shimSenderWithDtmf(this,e))})};const i=e.RTCPeerConnection.prototype.removeStream;e.RTCPeerConnection.prototype.removeStream=function(e){this._senders=this._senders||[],i.apply(this,[e]),e.getTracks().forEach(e=>{const t=this._senders.find(t=>t.track===e);t&&this._senders.splice(this._senders.indexOf(t),1)})}}else if("object"==typeof e&&e.RTCPeerConnection&&"getSenders"in e.RTCPeerConnection.prototype&&"createDTMFSender"in e.RTCPeerConnection.prototype&&e.RTCRtpSender&&!("dtmf"in e.RTCRtpSender.prototype)){const t=e.RTCPeerConnection.prototype.getSenders;e.RTCPeerConnection.prototype.getSenders=function(){const e=t.apply(this,[]);return e.forEach(e=>e._pc=this),e},Object.defineProperty(e.RTCRtpSender.prototype,"dtmf",{get(){return void 0===this._dtmf&&("audio"===this.track.kind?this._dtmf=this._pc.createDTMFSender(this.track):this._dtmf=null),this._dtmf}})}}function shimSenderReceiverGetStats(e){if(!("object"==typeof e&&e.RTCPeerConnection&&e.RTCRtpSender&&e.RTCRtpReceiver))return;if(!("getStats"in e.RTCRtpSender.prototype)){const t=e.RTCPeerConnection.prototype.getSenders;t&&(e.RTCPeerConnection.prototype.getSenders=function(){const e=t.apply(this,[]);return e.forEach(e=>e._pc=this),e});const i=e.RTCPeerConnection.prototype.addTrack;i&&(e.RTCPeerConnection.prototype.addTrack=function(){const e=i.apply(this,arguments);return e._pc=this,e}),e.RTCRtpSender.prototype.getStats=function(){const e=this;return this._pc.getStats().then(t=>filterStats(t,e.track,!0))}}if(!("getStats"in e.RTCRtpReceiver.prototype)){const t=e.RTCPeerConnection.prototype.getReceivers;t&&(e.RTCPeerConnection.prototype.getReceivers=function(){const e=t.apply(this,[]);return e.forEach(e=>e._pc=this),e}),wrapPeerConnectionEvent(e,"track",e=>(e.receiver._pc=e.srcElement,e)),e.RTCRtpReceiver.prototype.getStats=function(){const e=this;return this._pc.getStats().then(t=>filterStats(t,e.track,!1))}}if(!("getStats"in e.RTCRtpSender.prototype)||!("getStats"in e.RTCRtpReceiver.prototype))return;const t=e.RTCPeerConnection.prototype.getStats;e.RTCPeerConnection.prototype.getStats=function(){if(arguments.length>0&&arguments[0]instanceof e.MediaStreamTrack){const e=arguments[0];let t,i,n;return this.getSenders().forEach(i=>{i.track===e&&(t?n=!0:t=i)}),this.getReceivers().forEach(t=>(t.track===e&&(i?n=!0:i=t),t.track===e)),n||t&&i?Promise.reject(new DOMException("There are more than one sender or receiver for the track.","InvalidAccessError")):t?t.getStats():i?i.getStats():Promise.reject(new DOMException("There is no sender or receiver for the track.","InvalidAccessError"))}return t.apply(this,arguments)}}function shimAddTrackRemoveTrackWithNative(e){e.RTCPeerConnection.prototype.getLocalStreams=function(){return this._shimmedLocalStreams=this._shimmedLocalStreams||{},Object.keys(this._shimmedLocalStreams).map(e=>this._shimmedLocalStreams[e][0])};const t=e.RTCPeerConnection.prototype.addTrack;e.RTCPeerConnection.prototype.addTrack=function(e,i){if(!i)return t.apply(this,arguments);this._shimmedLocalStreams=this._shimmedLocalStreams||{};const n=t.apply(this,arguments);return this._shimmedLocalStreams[i.id]?-1===this._shimmedLocalStreams[i.id].indexOf(n)&&this._shimmedLocalStreams[i.id].push(n):this._shimmedLocalStreams[i.id]=[i,n],n};const i=e.RTCPeerConnection.prototype.addStream;e.RTCPeerConnection.prototype.addStream=function(e){this._shimmedLocalStreams=this._shimmedLocalStreams||{},e.getTracks().forEach(e=>{if(this.getSenders().find(t=>t.track===e))throw new DOMException("Track already exists.","InvalidAccessError")});const t=this.getSenders();i.apply(this,arguments);const n=this.getSenders().filter(e=>-1===t.indexOf(e));this._shimmedLocalStreams[e.id]=[e].concat(n)};const n=e.RTCPeerConnection.prototype.removeStream;e.RTCPeerConnection.prototype.removeStream=function(e){return this._shimmedLocalStreams=this._shimmedLocalStreams||{},delete this._shimmedLocalStreams[e.id],n.apply(this,arguments)};const s=e.RTCPeerConnection.prototype.removeTrack;e.RTCPeerConnection.prototype.removeTrack=function(e){return this._shimmedLocalStreams=this._shimmedLocalStreams||{},e&&Object.keys(this._shimmedLocalStreams).forEach(t=>{const i=this._shimmedLocalStreams[t].indexOf(e);-1!==i&&this._shimmedLocalStreams[t].splice(i,1),1===this._shimmedLocalStreams[t].length&&delete this._shimmedLocalStreams[t]}),s.apply(this,arguments)}}function shimAddTrackRemoveTrack(e,t){if(!e.RTCPeerConnection)return;if(e.RTCPeerConnection.prototype.addTrack&&t.version>=65)return shimAddTrackRemoveTrackWithNative(e);const i=e.RTCPeerConnection.prototype.getLocalStreams;e.RTCPeerConnection.prototype.getLocalStreams=function(){const e=i.apply(this);return this._reverseStreams=this._reverseStreams||{},e.map(e=>this._reverseStreams[e.id])};const n=e.RTCPeerConnection.prototype.addStream;e.RTCPeerConnection.prototype.addStream=function(t){if(this._streams=this._streams||{},this._reverseStreams=this._reverseStreams||{},t.getTracks().forEach(e=>{if(this.getSenders().find(t=>t.track===e))throw new DOMException("Track already exists.","InvalidAccessError")}),!this._reverseStreams[t.id]){const i=new e.MediaStream(t.getTracks());this._streams[t.id]=i,this._reverseStreams[i.id]=t,t=i}n.apply(this,[t])};const s=e.RTCPeerConnection.prototype.removeStream;function replaceInternalStreamId(e,t){let i=t.sdp;return Object.keys(e._reverseStreams||[]).forEach(t=>{const n=e._reverseStreams[t],s=e._streams[n.id];i=i.replace(new RegExp(s.id,"g"),n.id)}),new RTCSessionDescription({type:t.type,sdp:i})}e.RTCPeerConnection.prototype.removeStream=function(e){this._streams=this._streams||{},this._reverseStreams=this._reverseStreams||{},s.apply(this,[this._streams[e.id]||e]),delete this._reverseStreams[this._streams[e.id]?this._streams[e.id].id:e.id],delete this._streams[e.id]},e.RTCPeerConnection.prototype.addTrack=function(t,i){if("closed"===this.signalingState)throw new DOMException("The RTCPeerConnection's signalingState is 'closed'.","InvalidStateError");const n=[].slice.call(arguments,1);if(1!==n.length||!n[0].getTracks().find(e=>e===t))throw new DOMException("The adapter.js addTrack polyfill only supports a single stream which is associated with the specified track.","NotSupportedError");if(this.getSenders().find(e=>e.track===t))throw new DOMException("Track already exists.","InvalidAccessError");this._streams=this._streams||{},this._reverseStreams=this._reverseStreams||{};const s=this._streams[i.id];if(s)s.addTrack(t),Promise.resolve().then(()=>{this.dispatchEvent(new Event("negotiationneeded"))});else{const n=new e.MediaStream([t]);this._streams[i.id]=n,this._reverseStreams[n.id]=i,this.addStream(n)}return this.getSenders().find(e=>e.track===t)},["createOffer","createAnswer"].forEach(function(t){const i=e.RTCPeerConnection.prototype[t],n={[t](){const e=arguments;return arguments.length&&"function"==typeof arguments[0]?i.apply(this,[t=>{const i=replaceInternalStreamId(this,t);e[0].apply(null,[i])},t=>{e[1]&&e[1].apply(null,t)},arguments[2]]):i.apply(this,arguments).then(e=>replaceInternalStreamId(this,e))}};e.RTCPeerConnection.prototype[t]=n[t]});const a=e.RTCPeerConnection.prototype.setLocalDescription;e.RTCPeerConnection.prototype.setLocalDescription=function(){return arguments.length&&arguments[0].type?(arguments[0]=function(e,t){let i=t.sdp;return Object.keys(e._reverseStreams||[]).forEach(t=>{const n=e._reverseStreams[t],s=e._streams[n.id];i=i.replace(new RegExp(n.id,"g"),s.id)}),new RTCSessionDescription({type:t.type,sdp:i})}(this,arguments[0]),a.apply(this,arguments)):a.apply(this,arguments)};const c=Object.getOwnPropertyDescriptor(e.RTCPeerConnection.prototype,"localDescription");Object.defineProperty(e.RTCPeerConnection.prototype,"localDescription",{get(){const e=c.get.apply(this);return""===e.type?e:replaceInternalStreamId(this,e)}}),e.RTCPeerConnection.prototype.removeTrack=function(e){if("closed"===this.signalingState)throw new DOMException("The RTCPeerConnection's signalingState is 'closed'.","InvalidStateError");if(!e._pc)throw new DOMException("Argument 1 of RTCPeerConnection.removeTrack does not implement interface RTCRtpSender.","TypeError");if(!(e._pc===this))throw new DOMException("Sender was not created by this connection.","InvalidAccessError");let t;this._streams=this._streams||{},Object.keys(this._streams).forEach(i=>{this._streams[i].getTracks().find(t=>e.track===t)&&(t=this._streams[i])}),t&&(1===t.getTracks().length?this.removeStream(this._reverseStreams[t.id]):t.removeTrack(e.track),this.dispatchEvent(new Event("negotiationneeded")))}}function shimPeerConnection$1(e,t){!e.RTCPeerConnection&&e.webkitRTCPeerConnection&&(e.RTCPeerConnection=e.webkitRTCPeerConnection),e.RTCPeerConnection&&t.version<53&&["setLocalDescription","setRemoteDescription","addIceCandidate"].forEach(function(t){const i=e.RTCPeerConnection.prototype[t],n={[t](){return arguments[0]=new("addIceCandidate"===t?e.RTCIceCandidate:e.RTCSessionDescription)(arguments[0]),i.apply(this,arguments)}};e.RTCPeerConnection.prototype[t]=n[t]})}function fixNegotiationNeeded(e,t){wrapPeerConnectionEvent(e,"negotiationneeded",e=>{const i=e.target;if(!(t.version<72||i.getConfiguration&&"plan-b"===i.getConfiguration().sdpSemantics)||"stable"===i.signalingState)return e})}var $t=Object.freeze({__proto__:null,fixNegotiationNeeded:fixNegotiationNeeded,shimAddTrackRemoveTrack:shimAddTrackRemoveTrack,shimAddTrackRemoveTrackWithNative:shimAddTrackRemoveTrackWithNative,shimGetSendersWithDtmf:shimGetSendersWithDtmf,shimGetUserMedia:shimGetUserMedia$2,shimMediaStream:shimMediaStream,shimOnTrack:shimOnTrack$1,shimPeerConnection:shimPeerConnection$1,shimSenderReceiverGetStats:shimSenderReceiverGetStats});function shimGetUserMedia$1(e,t){const i=e&&e.navigator,n=e&&e.MediaStreamTrack;if(i.getUserMedia=function(e,t,n){deprecated("navigator.getUserMedia","navigator.mediaDevices.getUserMedia"),i.mediaDevices.getUserMedia(e).then(t,n)},!(t.version>55&&"autoGainControl"in i.mediaDevices.getSupportedConstraints())){const remap=function(e,t,i){t in e&&!(i in e)&&(e[i]=e[t],delete e[t])},e=i.mediaDevices.getUserMedia.bind(i.mediaDevices);if(i.mediaDevices.getUserMedia=function(t){return"object"==typeof t&&"object"==typeof t.audio&&(t=JSON.parse(JSON.stringify(t)),remap(t.audio,"autoGainControl","mozAutoGainControl"),remap(t.audio,"noiseSuppression","mozNoiseSuppression")),e(t)},n&&n.prototype.getSettings){const e=n.prototype.getSettings;n.prototype.getSettings=function(){const t=e.apply(this,arguments);return remap(t,"mozAutoGainControl","autoGainControl"),remap(t,"mozNoiseSuppression","noiseSuppression"),t}}if(n&&n.prototype.applyConstraints){const e=n.prototype.applyConstraints;n.prototype.applyConstraints=function(t){return"audio"===this.kind&&"object"==typeof t&&(t=JSON.parse(JSON.stringify(t)),remap(t,"autoGainControl","mozAutoGainControl"),remap(t,"noiseSuppression","mozNoiseSuppression")),e.apply(this,[t])}}}}function shimOnTrack(e){"object"==typeof e&&e.RTCTrackEvent&&"receiver"in e.RTCTrackEvent.prototype&&!("transceiver"in e.RTCTrackEvent.prototype)&&Object.defineProperty(e.RTCTrackEvent.prototype,"transceiver",{get(){return{receiver:this.receiver}}})}function shimPeerConnection(e,t){if("object"!=typeof e||!e.RTCPeerConnection&&!e.mozRTCPeerConnection)return;!e.RTCPeerConnection&&e.mozRTCPeerConnection&&(e.RTCPeerConnection=e.mozRTCPeerConnection),t.version<53&&["setLocalDescription","setRemoteDescription","addIceCandidate"].forEach(function(t){const i=e.RTCPeerConnection.prototype[t],n={[t](){return arguments[0]=new("addIceCandidate"===t?e.RTCIceCandidate:e.RTCSessionDescription)(arguments[0]),i.apply(this,arguments)}};e.RTCPeerConnection.prototype[t]=n[t]});const i={inboundrtp:"inbound-rtp",outboundrtp:"outbound-rtp",candidatepair:"candidate-pair",localcandidate:"local-candidate",remotecandidate:"remote-candidate"},n=e.RTCPeerConnection.prototype.getStats;e.RTCPeerConnection.prototype.getStats=function(){const[e,s,a]=arguments;return n.apply(this,[e||null]).then(e=>{if(t.version<53&&!s)try{e.forEach(e=>{e.type=i[e.type]||e.type})}catch(t){if("TypeError"!==t.name)throw t;e.forEach((t,n)=>{e.set(n,Object.assign({},t,{type:i[t.type]||t.type}))})}return e}).then(s,a)}}function shimSenderGetStats(e){if("object"!=typeof e||!e.RTCPeerConnection||!e.RTCRtpSender)return;if(e.RTCRtpSender&&"getStats"in e.RTCRtpSender.prototype)return;const t=e.RTCPeerConnection.prototype.getSenders;t&&(e.RTCPeerConnection.prototype.getSenders=function(){const e=t.apply(this,[]);return e.forEach(e=>e._pc=this),e});const i=e.RTCPeerConnection.prototype.addTrack;i&&(e.RTCPeerConnection.prototype.addTrack=function(){const e=i.apply(this,arguments);return e._pc=this,e}),e.RTCRtpSender.prototype.getStats=function(){return this.track?this._pc.getStats(this.track):Promise.resolve(new Map)}}function shimReceiverGetStats(e){if("object"!=typeof e||!e.RTCPeerConnection||!e.RTCRtpSender)return;if(e.RTCRtpSender&&"getStats"in e.RTCRtpReceiver.prototype)return;const t=e.RTCPeerConnection.prototype.getReceivers;t&&(e.RTCPeerConnection.prototype.getReceivers=function(){const e=t.apply(this,[]);return e.forEach(e=>e._pc=this),e}),wrapPeerConnectionEvent(e,"track",e=>(e.receiver._pc=e.srcElement,e)),e.RTCRtpReceiver.prototype.getStats=function(){return this._pc.getStats(this.track)}}function shimRemoveStream(e){e.RTCPeerConnection&&!("removeStream"in e.RTCPeerConnection.prototype)&&(e.RTCPeerConnection.prototype.removeStream=function(e){deprecated("removeStream","removeTrack"),this.getSenders().forEach(t=>{t.track&&e.getTracks().includes(t.track)&&this.removeTrack(t)})})}function shimRTCDataChannel(e){e.DataChannel&&!e.RTCDataChannel&&(e.RTCDataChannel=e.DataChannel)}function shimAddTransceiver(e){if("object"!=typeof e||!e.RTCPeerConnection)return;const t=e.RTCPeerConnection.prototype.addTransceiver;t&&(e.RTCPeerConnection.prototype.addTransceiver=function(){this.setParametersPromises=[];let e=arguments[1]&&arguments[1].sendEncodings;void 0===e&&(e=[]),e=[...e];const i=e.length>0;i&&e.forEach(e=>{if("rid"in e){if(!/^[a-z0-9]{0,16}$/i.test(e.rid))throw new TypeError("Invalid RID value provided.")}if("scaleResolutionDownBy"in e&&!(parseFloat(e.scaleResolutionDownBy)>=1))throw new RangeError("scale_resolution_down_by must be >= 1.0");if("maxFramerate"in e&&!(parseFloat(e.maxFramerate)>=0))throw new RangeError("max_framerate must be >= 0.0")});const n=t.apply(this,arguments);if(i){const{sender:t}=n,i=t.getParameters();(!("encodings"in i)||1===i.encodings.length&&0===Object.keys(i.encodings[0]).length)&&(i.encodings=e,t.sendEncodings=e,this.setParametersPromises.push(t.setParameters(i).then(()=>{delete t.sendEncodings}).catch(()=>{delete t.sendEncodings})))}return n})}function shimGetParameters(e){if("object"!=typeof e||!e.RTCRtpSender)return;const t=e.RTCRtpSender.prototype.getParameters;t&&(e.RTCRtpSender.prototype.getParameters=function(){const e=t.apply(this,arguments);return"encodings"in e||(e.encodings=[].concat(this.sendEncodings||[{}])),e})}function shimCreateOffer(e){if("object"!=typeof e||!e.RTCPeerConnection)return;const t=e.RTCPeerConnection.prototype.createOffer;e.RTCPeerConnection.prototype.createOffer=function(){return this.setParametersPromises&&this.setParametersPromises.length?Promise.all(this.setParametersPromises).then(()=>t.apply(this,arguments)).finally(()=>{this.setParametersPromises=[]}):t.apply(this,arguments)}}function shimCreateAnswer(e){if("object"!=typeof e||!e.RTCPeerConnection)return;const t=e.RTCPeerConnection.prototype.createAnswer;e.RTCPeerConnection.prototype.createAnswer=function(){return this.setParametersPromises&&this.setParametersPromises.length?Promise.all(this.setParametersPromises).then(()=>t.apply(this,arguments)).finally(()=>{this.setParametersPromises=[]}):t.apply(this,arguments)}}var Xt=Object.freeze({__proto__:null,shimAddTransceiver:shimAddTransceiver,shimCreateAnswer:shimCreateAnswer,shimCreateOffer:shimCreateOffer,shimGetDisplayMedia:function(e,t){e.navigator.mediaDevices&&"getDisplayMedia"in e.navigator.mediaDevices||e.navigator.mediaDevices&&(e.navigator.mediaDevices.getDisplayMedia=function(i){if(!i||!i.video){const e=new DOMException("getDisplayMedia without video constraints is undefined");return e.name="NotFoundError",e.code=8,Promise.reject(e)}return!0===i.video?i.video={mediaSource:t}:i.video.mediaSource=t,e.navigator.mediaDevices.getUserMedia(i)})},shimGetParameters:shimGetParameters,shimGetUserMedia:shimGetUserMedia$1,shimOnTrack:shimOnTrack,shimPeerConnection:shimPeerConnection,shimRTCDataChannel:shimRTCDataChannel,shimReceiverGetStats:shimReceiverGetStats,shimRemoveStream:shimRemoveStream,shimSenderGetStats:shimSenderGetStats});function shimLocalStreamsAPI(e){if("object"==typeof e&&e.RTCPeerConnection){if("getLocalStreams"in e.RTCPeerConnection.prototype||(e.RTCPeerConnection.prototype.getLocalStreams=function(){return this._localStreams||(this._localStreams=[]),this._localStreams}),!("addStream"in e.RTCPeerConnection.prototype)){const t=e.RTCPeerConnection.prototype.addTrack;e.RTCPeerConnection.prototype.addStream=function(e){this._localStreams||(this._localStreams=[]),this._localStreams.includes(e)||this._localStreams.push(e),e.getAudioTracks().forEach(i=>t.call(this,i,e)),e.getVideoTracks().forEach(i=>t.call(this,i,e))},e.RTCPeerConnection.prototype.addTrack=function(e){for(var i=arguments.length,n=new Array(i>1?i-1:0),s=1;s<i;s++)n[s-1]=arguments[s];return n&&n.forEach(e=>{this._localStreams?this._localStreams.includes(e)||this._localStreams.push(e):this._localStreams=[e]}),t.apply(this,arguments)}}"removeStream"in e.RTCPeerConnection.prototype||(e.RTCPeerConnection.prototype.removeStream=function(e){this._localStreams||(this._localStreams=[]);const t=this._localStreams.indexOf(e);if(-1===t)return;this._localStreams.splice(t,1);const i=e.getTracks();this.getSenders().forEach(e=>{i.includes(e.track)&&this.removeTrack(e)})})}}function shimRemoteStreamsAPI(e){if("object"==typeof e&&e.RTCPeerConnection&&("getRemoteStreams"in e.RTCPeerConnection.prototype||(e.RTCPeerConnection.prototype.getRemoteStreams=function(){return this._remoteStreams?this._remoteStreams:[]}),!("onaddstream"in e.RTCPeerConnection.prototype))){Object.defineProperty(e.RTCPeerConnection.prototype,"onaddstream",{get(){return this._onaddstream},set(e){this._onaddstream&&(this.removeEventListener("addstream",this._onaddstream),this.removeEventListener("track",this._onaddstreampoly)),this.addEventListener("addstream",this._onaddstream=e),this.addEventListener("track",this._onaddstreampoly=e=>{e.streams.forEach(e=>{if(this._remoteStreams||(this._remoteStreams=[]),this._remoteStreams.includes(e))return;this._remoteStreams.push(e);const t=new Event("addstream");t.stream=e,this.dispatchEvent(t)})})}});const t=e.RTCPeerConnection.prototype.setRemoteDescription;e.RTCPeerConnection.prototype.setRemoteDescription=function(){const e=this;return this._onaddstreampoly||this.addEventListener("track",this._onaddstreampoly=function(t){t.streams.forEach(t=>{if(e._remoteStreams||(e._remoteStreams=[]),e._remoteStreams.indexOf(t)>=0)return;e._remoteStreams.push(t);const i=new Event("addstream");i.stream=t,e.dispatchEvent(i)})}),t.apply(e,arguments)}}}function shimCallbacksAPI(e){if("object"!=typeof e||!e.RTCPeerConnection)return;const t=e.RTCPeerConnection.prototype,i=t.createOffer,n=t.createAnswer,s=t.setLocalDescription,a=t.setRemoteDescription,c=t.addIceCandidate;t.createOffer=function(e,t){const n=arguments.length>=2?arguments[2]:arguments[0],s=i.apply(this,[n]);return t?(s.then(e,t),Promise.resolve()):s},t.createAnswer=function(e,t){const i=arguments.length>=2?arguments[2]:arguments[0],s=n.apply(this,[i]);return t?(s.then(e,t),Promise.resolve()):s};let withCallback=function(e,t,i){const n=s.apply(this,[e]);return i?(n.then(t,i),Promise.resolve()):n};t.setLocalDescription=withCallback,withCallback=function(e,t,i){const n=a.apply(this,[e]);return i?(n.then(t,i),Promise.resolve()):n},t.setRemoteDescription=withCallback,withCallback=function(e,t,i){const n=c.apply(this,[e]);return i?(n.then(t,i),Promise.resolve()):n},t.addIceCandidate=withCallback}function shimGetUserMedia(e){const t=e&&e.navigator;if(t.mediaDevices&&t.mediaDevices.getUserMedia){const e=t.mediaDevices,i=e.getUserMedia.bind(e);t.mediaDevices.getUserMedia=e=>i(shimConstraints(e))}!t.getUserMedia&&t.mediaDevices&&t.mediaDevices.getUserMedia&&(t.getUserMedia=function(e,i,n){t.mediaDevices.getUserMedia(e).then(i,n)}.bind(t))}function shimConstraints(e){return e&&void 0!==e.video?Object.assign({},e,{video:compactObject(e.video)}):e}function shimRTCIceServerUrls(e){if(!e.RTCPeerConnection)return;const t=e.RTCPeerConnection;e.RTCPeerConnection=function(e,i){if(e&&e.iceServers){const t=[];for(let i=0;i<e.iceServers.length;i++){let n=e.iceServers[i];void 0===n.urls&&n.url?(deprecated("RTCIceServer.url","RTCIceServer.urls"),n=JSON.parse(JSON.stringify(n)),n.urls=n.url,delete n.url,t.push(n)):t.push(e.iceServers[i])}e.iceServers=t}return new t(e,i)},e.RTCPeerConnection.prototype=t.prototype,"generateCertificate"in t&&Object.defineProperty(e.RTCPeerConnection,"generateCertificate",{get:()=>t.generateCertificate})}function shimTrackEventTransceiver(e){"object"==typeof e&&e.RTCTrackEvent&&"receiver"in e.RTCTrackEvent.prototype&&!("transceiver"in e.RTCTrackEvent.prototype)&&Object.defineProperty(e.RTCTrackEvent.prototype,"transceiver",{get(){return{receiver:this.receiver}}})}function shimCreateOfferLegacy(e){const t=e.RTCPeerConnection.prototype.createOffer;e.RTCPeerConnection.prototype.createOffer=function(e){if(e){void 0!==e.offerToReceiveAudio&&(e.offerToReceiveAudio=!!e.offerToReceiveAudio);const t=this.getTransceivers().find(e=>"audio"===e.receiver.track.kind);!1===e.offerToReceiveAudio&&t?"sendrecv"===t.direction?t.setDirection?t.setDirection("sendonly"):t.direction="sendonly":"recvonly"===t.direction&&(t.setDirection?t.setDirection("inactive"):t.direction="inactive"):!0!==e.offerToReceiveAudio||t||this.addTransceiver("audio",{direction:"recvonly"}),void 0!==e.offerToReceiveVideo&&(e.offerToReceiveVideo=!!e.offerToReceiveVideo);const i=this.getTransceivers().find(e=>"video"===e.receiver.track.kind);!1===e.offerToReceiveVideo&&i?"sendrecv"===i.direction?i.setDirection?i.setDirection("sendonly"):i.direction="sendonly":"recvonly"===i.direction&&(i.setDirection?i.setDirection("inactive"):i.direction="inactive"):!0!==e.offerToReceiveVideo||i||this.addTransceiver("video",{direction:"recvonly"})}return t.apply(this,arguments)}}function shimAudioContext(e){"object"!=typeof e||e.AudioContext||(e.AudioContext=e.webkitAudioContext)}var Zt,ei=Object.freeze({__proto__:null,shimAudioContext:shimAudioContext,shimCallbacksAPI:shimCallbacksAPI,shimConstraints:shimConstraints,shimCreateOfferLegacy:shimCreateOfferLegacy,shimGetUserMedia:shimGetUserMedia,shimLocalStreamsAPI:shimLocalStreamsAPI,shimRTCIceServerUrls:shimRTCIceServerUrls,shimRemoteStreamsAPI:shimRemoteStreamsAPI,shimTrackEventTransceiver:shimTrackEventTransceiver}),ti={exports:{}};var ii=(Zt||(Zt=1,function(e){const t={generateIdentifier:function(){return Math.random().toString(36).substring(2,12)}};t.localCName=t.generateIdentifier(),t.splitLines=function(e){return e.trim().split("\n").map(e=>e.trim())},t.splitSections=function(e){return e.split("\nm=").map((e,t)=>(t>0?"m="+e:e).trim()+"\r\n")},t.getDescription=function(e){const i=t.splitSections(e);return i&&i[0]},t.getMediaSections=function(e){const i=t.splitSections(e);return i.shift(),i},t.matchPrefix=function(e,i){return t.splitLines(e).filter(e=>0===e.indexOf(i))},t.parseCandidate=function(e){let t;t=0===e.indexOf("a=candidate:")?e.substring(12).split(" "):e.substring(10).split(" ");const i={foundation:t[0],component:{1:"rtp",2:"rtcp"}[t[1]]||t[1],protocol:t[2].toLowerCase(),priority:parseInt(t[3],10),ip:t[4],address:t[4],port:parseInt(t[5],10),type:t[7]};for(let e=8;e<t.length;e+=2)switch(t[e]){case"raddr":i.relatedAddress=t[e+1];break;case"rport":i.relatedPort=parseInt(t[e+1],10);break;case"tcptype":i.tcpType=t[e+1];break;case"ufrag":i.ufrag=t[e+1],i.usernameFragment=t[e+1];break;default:void 0===i[t[e]]&&(i[t[e]]=t[e+1])}return i},t.writeCandidate=function(e){const t=[];t.push(e.foundation);const i=e.component;"rtp"===i?t.push(1):"rtcp"===i?t.push(2):t.push(i),t.push(e.protocol.toUpperCase()),t.push(e.priority),t.push(e.address||e.ip),t.push(e.port);const n=e.type;return t.push("typ"),t.push(n),"host"!==n&&e.relatedAddress&&e.relatedPort&&(t.push("raddr"),t.push(e.relatedAddress),t.push("rport"),t.push(e.relatedPort)),e.tcpType&&"tcp"===e.protocol.toLowerCase()&&(t.push("tcptype"),t.push(e.tcpType)),(e.usernameFragment||e.ufrag)&&(t.push("ufrag"),t.push(e.usernameFragment||e.ufrag)),"candidate:"+t.join(" ")},t.parseIceOptions=function(e){return e.substring(14).split(" ")},t.parseRtpMap=function(e){let t=e.substring(9).split(" ");const i={payloadType:parseInt(t.shift(),10)};return t=t[0].split("/"),i.name=t[0],i.clockRate=parseInt(t[1],10),i.channels=3===t.length?parseInt(t[2],10):1,i.numChannels=i.channels,i},t.writeRtpMap=function(e){let t=e.payloadType;void 0!==e.preferredPayloadType&&(t=e.preferredPayloadType);const i=e.channels||e.numChannels||1;return"a=rtpmap:"+t+" "+e.name+"/"+e.clockRate+(1!==i?"/"+i:"")+"\r\n"},t.parseExtmap=function(e){const t=e.substring(9).split(" ");return{id:parseInt(t[0],10),direction:t[0].indexOf("/")>0?t[0].split("/")[1]:"sendrecv",uri:t[1],attributes:t.slice(2).join(" ")}},t.writeExtmap=function(e){return"a=extmap:"+(e.id||e.preferredId)+(e.direction&&"sendrecv"!==e.direction?"/"+e.direction:"")+" "+e.uri+(e.attributes?" "+e.attributes:"")+"\r\n"},t.parseFmtp=function(e){const t={};let i;const n=e.substring(e.indexOf(" ")+1).split(";");for(let e=0;e<n.length;e++)i=n[e].trim().split("="),t[i[0].trim()]=i[1];return t},t.writeFmtp=function(e){let t="",i=e.payloadType;if(void 0!==e.preferredPayloadType&&(i=e.preferredPayloadType),e.parameters&&Object.keys(e.parameters).length){const n=[];Object.keys(e.parameters).forEach(t=>{void 0!==e.parameters[t]?n.push(t+"="+e.parameters[t]):n.push(t)}),t+="a=fmtp:"+i+" "+n.join(";")+"\r\n"}return t},t.parseRtcpFb=function(e){const t=e.substring(e.indexOf(" ")+1).split(" ");return{type:t.shift(),parameter:t.join(" ")}},t.writeRtcpFb=function(e){let t="",i=e.payloadType;return void 0!==e.preferredPayloadType&&(i=e.preferredPayloadType),e.rtcpFeedback&&e.rtcpFeedback.length&&e.rtcpFeedback.forEach(e=>{t+="a=rtcp-fb:"+i+" "+e.type+(e.parameter&&e.parameter.length?" "+e.parameter:"")+"\r\n"}),t},t.parseSsrcMedia=function(e){const t=e.indexOf(" "),i={ssrc:parseInt(e.substring(7,t),10)},n=e.indexOf(":",t);return n>-1?(i.attribute=e.substring(t+1,n),i.value=e.substring(n+1)):i.attribute=e.substring(t+1),i},t.parseSsrcGroup=function(e){const t=e.substring(13).split(" ");return{semantics:t.shift(),ssrcs:t.map(e=>parseInt(e,10))}},t.getMid=function(e){const i=t.matchPrefix(e,"a=mid:")[0];if(i)return i.substring(6)},t.parseFingerprint=function(e){const t=e.substring(14).split(" ");return{algorithm:t[0].toLowerCase(),value:t[1].toUpperCase()}},t.getDtlsParameters=function(e,i){return{role:"auto",fingerprints:t.matchPrefix(e+i,"a=fingerprint:").map(t.parseFingerprint)}},t.writeDtlsParameters=function(e,t){let i="a=setup:"+t+"\r\n";return e.fingerprints.forEach(e=>{i+="a=fingerprint:"+e.algorithm+" "+e.value+"\r\n"}),i},t.parseCryptoLine=function(e){const t=e.substring(9).split(" ");return{tag:parseInt(t[0],10),cryptoSuite:t[1],keyParams:t[2],sessionParams:t.slice(3)}},t.writeCryptoLine=function(e){return"a=crypto:"+e.tag+" "+e.cryptoSuite+" "+("object"==typeof e.keyParams?t.writeCryptoKeyParams(e.keyParams):e.keyParams)+(e.sessionParams?" "+e.sessionParams.join(" "):"")+"\r\n"},t.parseCryptoKeyParams=function(e){if(0!==e.indexOf("inline:"))return null;const t=e.substring(7).split("|");return{keyMethod:"inline",keySalt:t[0],lifeTime:t[1],mkiValue:t[2]?t[2].split(":")[0]:void 0,mkiLength:t[2]?t[2].split(":")[1]:void 0}},t.writeCryptoKeyParams=function(e){return e.keyMethod+":"+e.keySalt+(e.lifeTime?"|"+e.lifeTime:"")+(e.mkiValue&&e.mkiLength?"|"+e.mkiValue+":"+e.mkiLength:"")},t.getCryptoParameters=function(e,i){return t.matchPrefix(e+i,"a=crypto:").map(t.parseCryptoLine)},t.getIceParameters=function(e,i){const n=t.matchPrefix(e+i,"a=ice-ufrag:")[0],s=t.matchPrefix(e+i,"a=ice-pwd:")[0];return n&&s?{usernameFragment:n.substring(12),password:s.substring(10)}:null},t.writeIceParameters=function(e){let t="a=ice-ufrag:"+e.usernameFragment+"\r\na=ice-pwd:"+e.password+"\r\n";return e.iceLite&&(t+="a=ice-lite\r\n"),t},t.parseRtpParameters=function(e){const i={codecs:[],headerExtensions:[],fecMechanisms:[],rtcp:[]},n=t.splitLines(e)[0].split(" ");i.profile=n[2];for(let s=3;s<n.length;s++){const a=n[s],c=t.matchPrefix(e,"a=rtpmap:"+a+" ")[0];if(c){const n=t.parseRtpMap(c),s=t.matchPrefix(e,"a=fmtp:"+a+" ");switch(n.parameters=s.length?t.parseFmtp(s[0]):{},n.rtcpFeedback=t.matchPrefix(e,"a=rtcp-fb:"+a+" ").map(t.parseRtcpFb),i.codecs.push(n),n.name.toUpperCase()){case"RED":case"ULPFEC":i.fecMechanisms.push(n.name.toUpperCase())}}}t.matchPrefix(e,"a=extmap:").forEach(e=>{i.headerExtensions.push(t.parseExtmap(e))});const s=t.matchPrefix(e,"a=rtcp-fb:* ").map(t.parseRtcpFb);return i.codecs.forEach(e=>{s.forEach(t=>{e.rtcpFeedback.find(e=>e.type===t.type&&e.parameter===t.parameter)||e.rtcpFeedback.push(t)})}),i},t.writeRtpDescription=function(e,i){let n="";n+="m="+e+" ",n+=i.codecs.length>0?"9":"0",n+=" "+(i.profile||"UDP/TLS/RTP/SAVPF")+" ",n+=i.codecs.map(e=>void 0!==e.preferredPayloadType?e.preferredPayloadType:e.payloadType).join(" ")+"\r\n",n+="c=IN IP4 0.0.0.0\r\n",n+="a=rtcp:9 IN IP4 0.0.0.0\r\n",i.codecs.forEach(e=>{n+=t.writeRtpMap(e),n+=t.writeFmtp(e),n+=t.writeRtcpFb(e)});let s=0;return i.codecs.forEach(e=>{e.maxptime>s&&(s=e.maxptime)}),s>0&&(n+="a=maxptime:"+s+"\r\n"),i.headerExtensions&&i.headerExtensions.forEach(e=>{n+=t.writeExtmap(e)}),n},t.parseRtpEncodingParameters=function(e){const i=[],n=t.parseRtpParameters(e),s=-1!==n.fecMechanisms.indexOf("RED"),a=-1!==n.fecMechanisms.indexOf("ULPFEC"),c=t.matchPrefix(e,"a=ssrc:").map(e=>t.parseSsrcMedia(e)).filter(e=>"cname"===e.attribute),l=c.length>0&&c[0].ssrc;let u;const h=t.matchPrefix(e,"a=ssrc-group:FID").map(e=>e.substring(17).split(" ").map(e=>parseInt(e,10)));h.length>0&&h[0].length>1&&h[0][0]===l&&(u=h[0][1]),n.codecs.forEach(e=>{if("RTX"===e.name.toUpperCase()&&e.parameters.apt){let t={ssrc:l,codecPayloadType:parseInt(e.parameters.apt,10)};l&&u&&(t.rtx={ssrc:u}),i.push(t),s&&(t=JSON.parse(JSON.stringify(t)),t.fec={ssrc:l,mechanism:a?"red+ulpfec":"red"},i.push(t))}}),0===i.length&&l&&i.push({ssrc:l});let p=t.matchPrefix(e,"b=");return p.length&&(p=0===p[0].indexOf("b=TIAS:")?parseInt(p[0].substring(7),10):0===p[0].indexOf("b=AS:")?1e3*parseInt(p[0].substring(5),10)*.95-16e3:void 0,i.forEach(e=>{e.maxBitrate=p})),i},t.parseRtcpParameters=function(e){const i={},n=t.matchPrefix(e,"a=ssrc:").map(e=>t.parseSsrcMedia(e)).filter(e=>"cname"===e.attribute)[0];n&&(i.cname=n.value,i.ssrc=n.ssrc);const s=t.matchPrefix(e,"a=rtcp-rsize");i.reducedSize=s.length>0,i.compound=0===s.length;const a=t.matchPrefix(e,"a=rtcp-mux");return i.mux=a.length>0,i},t.writeRtcpParameters=function(e){let t="";return e.reducedSize&&(t+="a=rtcp-rsize\r\n"),e.mux&&(t+="a=rtcp-mux\r\n"),void 0!==e.ssrc&&e.cname&&(t+="a=ssrc:"+e.ssrc+" cname:"+e.cname+"\r\n"),t},t.parseMsid=function(e){let i;const n=t.matchPrefix(e,"a=msid:");if(1===n.length)return i=n[0].substring(7).split(" "),{stream:i[0],track:i[1]};const s=t.matchPrefix(e,"a=ssrc:").map(e=>t.parseSsrcMedia(e)).filter(e=>"msid"===e.attribute);return s.length>0?(i=s[0].value.split(" "),{stream:i[0],track:i[1]}):void 0},t.parseSctpDescription=function(e){const i=t.parseMLine(e),n=t.matchPrefix(e,"a=max-message-size:");let s;n.length>0&&(s=parseInt(n[0].substring(19),10)),isNaN(s)&&(s=65536);const a=t.matchPrefix(e,"a=sctp-port:");if(a.length>0)return{port:parseInt(a[0].substring(12),10),protocol:i.fmt,maxMessageSize:s};const c=t.matchPrefix(e,"a=sctpmap:");if(c.length>0){const e=c[0].substring(10).split(" ");return{port:parseInt(e[0],10),protocol:e[1],maxMessageSize:s}}},t.writeSctpDescription=function(e,t){let i=[];return i="DTLS/SCTP"!==e.protocol?["m="+e.kind+" 9 "+e.protocol+" "+t.protocol+"\r\n","c=IN IP4 0.0.0.0\r\n","a=sctp-port:"+t.port+"\r\n"]:["m="+e.kind+" 9 "+e.protocol+" "+t.port+"\r\n","c=IN IP4 0.0.0.0\r\n","a=sctpmap:"+t.port+" "+t.protocol+" 65535\r\n"],void 0!==t.maxMessageSize&&i.push("a=max-message-size:"+t.maxMessageSize+"\r\n"),i.join("")},t.generateSessionId=function(){return Math.random().toString().substr(2,22)},t.writeSessionBoilerplate=function(e,i,n){let s;const a=void 0!==i?i:2;return s=e||t.generateSessionId(),"v=0\r\no="+(n||"thisisadapterortc")+" "+s+" "+a+" IN IP4 127.0.0.1\r\ns=-\r\nt=0 0\r\n"},t.getDirection=function(e,i){const n=t.splitLines(e);for(let e=0;e<n.length;e++)switch(n[e]){case"a=sendrecv":case"a=sendonly":case"a=recvonly":case"a=inactive":return n[e].substring(2)}return i?t.getDirection(i):"sendrecv"},t.getKind=function(e){return t.splitLines(e)[0].split(" ")[0].substring(2)},t.isRejected=function(e){return"0"===e.split(" ",2)[1]},t.parseMLine=function(e){const i=t.splitLines(e)[0].substring(2).split(" ");return{kind:i[0],port:parseInt(i[1],10),protocol:i[2],fmt:i.slice(3).join(" ")}},t.parseOLine=function(e){const i=t.matchPrefix(e,"o=")[0].substring(2).split(" ");return{username:i[0],sessionId:i[1],sessionVersion:parseInt(i[2],10),netType:i[3],addressType:i[4],address:i[5]}},t.isValidSDP=function(e){if("string"!=typeof e||0===e.length)return!1;const i=t.splitLines(e);for(let e=0;e<i.length;e++)if(i[e].length<2||"="!==i[e].charAt(1))return!1;return!0},e.exports=t}(ti)),ti.exports),ni=getDefaultExportFromCjs(ii),ri=_mergeNamespaces$1({__proto__:null,default:ni},[ii]);function shimRTCIceCandidate(e){if(!e.RTCIceCandidate||e.RTCIceCandidate&&"foundation"in e.RTCIceCandidate.prototype)return;const t=e.RTCIceCandidate;e.RTCIceCandidate=function(e){if("object"==typeof e&&e.candidate&&0===e.candidate.indexOf("a=")&&((e=JSON.parse(JSON.stringify(e))).candidate=e.candidate.substring(2)),e.candidate&&e.candidate.length){const i=new t(e),n=ni.parseCandidate(e.candidate);for(const e in n)e in i||Object.defineProperty(i,e,{value:n[e]});return i.toJSON=function(){return{candidate:i.candidate,sdpMid:i.sdpMid,sdpMLineIndex:i.sdpMLineIndex,usernameFragment:i.usernameFragment}},i}return new t(e)},e.RTCIceCandidate.prototype=t.prototype,wrapPeerConnectionEvent(e,"icecandidate",t=>(t.candidate&&Object.defineProperty(t,"candidate",{value:new e.RTCIceCandidate(t.candidate),writable:"false"}),t))}function shimRTCIceCandidateRelayProtocol(e){!e.RTCIceCandidate||e.RTCIceCandidate&&"relayProtocol"in e.RTCIceCandidate.prototype||wrapPeerConnectionEvent(e,"icecandidate",e=>{if(e.candidate){const t=ni.parseCandidate(e.candidate.candidate);"relay"===t.type&&(e.candidate.relayProtocol={0:"tls",1:"tcp",2:"udp"}[t.priority>>24])}return e})}function shimMaxMessageSize(e,t){if(!e.RTCPeerConnection)return;"sctp"in e.RTCPeerConnection.prototype||Object.defineProperty(e.RTCPeerConnection.prototype,"sctp",{get(){return void 0===this._sctp?null:this._sctp}});const i=e.RTCPeerConnection.prototype.setRemoteDescription;e.RTCPeerConnection.prototype.setRemoteDescription=function(){if(this._sctp=null,"chrome"===t.browser&&t.version>=76){const{sdpSemantics:e}=this.getConfiguration();"plan-b"===e&&Object.defineProperty(this,"sctp",{get(){return void 0===this._sctp?null:this._sctp},enumerable:!0,configurable:!0})}if(function(e){if(!e||!e.sdp)return!1;const t=ni.splitSections(e.sdp);return t.shift(),t.some(e=>{const t=ni.parseMLine(e);return t&&"application"===t.kind&&-1!==t.protocol.indexOf("SCTP")})}(arguments[0])){const e=function(e){const t=e.sdp.match(/mozilla...THIS_IS_SDPARTA-(\d+)/);if(null===t||t.length<2)return-1;const i=parseInt(t[1],10);return i!=i?-1:i}(arguments[0]),i=function(e){let i=65536;return"firefox"===t.browser&&(i=t.version<57?-1===e?16384:2147483637:t.version<60?57===t.version?65535:65536:2147483637),i}(e),n=function(e,i){let n=65536;"firefox"===t.browser&&57===t.version&&(n=65535);const s=ni.matchPrefix(e.sdp,"a=max-message-size:");return s.length>0?n=parseInt(s[0].substring(19),10):"firefox"===t.browser&&-1!==i&&(n=2147483637),n}(arguments[0],e);let s;s=0===i&&0===n?Number.POSITIVE_INFINITY:0===i||0===n?Math.max(i,n):Math.min(i,n);const a={};Object.defineProperty(a,"maxMessageSize",{get:()=>s}),this._sctp=a}return i.apply(this,arguments)}}function shimSendThrowTypeError(e){if(!e.RTCPeerConnection||!("createDataChannel"in e.RTCPeerConnection.prototype))return;function wrapDcSend(e,t){const i=e.send;e.send=function(){const n=arguments[0],s=n.length||n.size||n.byteLength;if("open"===e.readyState&&t.sctp&&s>t.sctp.maxMessageSize)throw new TypeError("Message too large (can send a maximum of "+t.sctp.maxMessageSize+" bytes)");return i.apply(e,arguments)}}const t=e.RTCPeerConnection.prototype.createDataChannel;e.RTCPeerConnection.prototype.createDataChannel=function(){const e=t.apply(this,arguments);return wrapDcSend(e,this),e},wrapPeerConnectionEvent(e,"datachannel",e=>(wrapDcSend(e.channel,e.target),e))}function shimConnectionState(e){if(!e.RTCPeerConnection||"connectionState"in e.RTCPeerConnection.prototype)return;const t=e.RTCPeerConnection.prototype;Object.defineProperty(t,"connectionState",{get(){return{completed:"connected",checking:"connecting"}[this.iceConnectionState]||this.iceConnectionState},enumerable:!0,configurable:!0}),Object.defineProperty(t,"onconnectionstatechange",{get(){return this._onconnectionstatechange||null},set(e){this._onconnectionstatechange&&(this.removeEventListener("connectionstatechange",this._onconnectionstatechange),delete this._onconnectionstatechange),e&&this.addEventListener("connectionstatechange",this._onconnectionstatechange=e)},enumerable:!0,configurable:!0}),["setLocalDescription","setRemoteDescription"].forEach(e=>{const i=t[e];t[e]=function(){return this._connectionstatechangepoly||(this._connectionstatechangepoly=e=>{const t=e.target;if(t._lastConnectionState!==t.connectionState){t._lastConnectionState=t.connectionState;const i=new Event("connectionstatechange",e);t.dispatchEvent(i)}return e},this.addEventListener("iceconnectionstatechange",this._connectionstatechangepoly)),i.apply(this,arguments)}})}function removeExtmapAllowMixed(e,t){if(!e.RTCPeerConnection)return;if("chrome"===t.browser&&t.version>=71)return;if("safari"===t.browser&&t._safariVersion>=13.1)return;const i=e.RTCPeerConnection.prototype.setRemoteDescription;e.RTCPeerConnection.prototype.setRemoteDescription=function(t){if(t&&t.sdp&&-1!==t.sdp.indexOf("\na=extmap-allow-mixed")){const i=t.sdp.split("\n").filter(e=>"a=extmap-allow-mixed"!==e.trim()).join("\n");e.RTCSessionDescription&&t instanceof e.RTCSessionDescription?arguments[0]=new e.RTCSessionDescription({type:t.type,sdp:i}):t.sdp=i}return i.apply(this,arguments)}}function shimAddIceCandidateNullOrEmpty(e,t){if(!e.RTCPeerConnection||!e.RTCPeerConnection.prototype)return;const i=e.RTCPeerConnection.prototype.addIceCandidate;i&&0!==i.length&&(e.RTCPeerConnection.prototype.addIceCandidate=function(){return arguments[0]?("chrome"===t.browser&&t.version<78||"firefox"===t.browser&&t.version<68||"safari"===t.browser)&&arguments[0]&&""===arguments[0].candidate?Promise.resolve():i.apply(this,arguments):(arguments[1]&&arguments[1].apply(null),Promise.resolve())})}function shimParameterlessSetLocalDescription(e,t){if(!e.RTCPeerConnection||!e.RTCPeerConnection.prototype)return;const i=e.RTCPeerConnection.prototype.setLocalDescription;i&&0!==i.length&&(e.RTCPeerConnection.prototype.setLocalDescription=function(){let e=arguments[0]||{};if("object"!=typeof e||e.type&&e.sdp)return i.apply(this,arguments);if(e={type:e.type,sdp:e.sdp},!e.type)switch(this.signalingState){case"stable":case"have-local-offer":case"have-remote-pranswer":e.type="offer";break;default:e.type="answer"}if(e.sdp||"offer"!==e.type&&"answer"!==e.type)return i.apply(this,[e]);return("offer"===e.type?this.createOffer:this.createAnswer).apply(this).then(e=>i.apply(this,[e]))})}var si=Object.freeze({__proto__:null,removeExtmapAllowMixed:removeExtmapAllowMixed,shimAddIceCandidateNullOrEmpty:shimAddIceCandidateNullOrEmpty,shimConnectionState:shimConnectionState,shimMaxMessageSize:shimMaxMessageSize,shimParameterlessSetLocalDescription:shimParameterlessSetLocalDescription,shimRTCIceCandidate:shimRTCIceCandidate,shimRTCIceCandidateRelayProtocol:shimRTCIceCandidateRelayProtocol,shimSendThrowTypeError:shimSendThrowTypeError});!function(){let{window:e}=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{shimChrome:!0,shimFirefox:!0,shimSafari:!0};const i=log,n=function(e){const t={browser:null,version:null};if(void 0===e||!e.navigator||!e.navigator.userAgent)return t.browser="Not a browser.",t;const{navigator:i}=e;if(i.userAgentData&&i.userAgentData.brands){const e=i.userAgentData.brands.find(e=>"Chromium"===e.brand);if(e)return{browser:"chrome",version:parseInt(e.version,10)}}if(i.mozGetUserMedia)t.browser="firefox",t.version=parseInt(extractVersion(i.userAgent,/Firefox\/(\d+)\./,1));else if(i.webkitGetUserMedia||!1===e.isSecureContext&&e.webkitRTCPeerConnection)t.browser="chrome",t.version=parseInt(extractVersion(i.userAgent,/Chrom(e|ium)\/(\d+)\./,2));else{if(!e.RTCPeerConnection||!i.userAgent.match(/AppleWebKit\/(\d+)\./))return t.browser="Not a supported browser.",t;t.browser="safari",t.version=parseInt(extractVersion(i.userAgent,/AppleWebKit\/(\d+)\./,1)),t.supportsUnifiedPlan=e.RTCRtpTransceiver&&"currentDirection"in e.RTCRtpTransceiver.prototype,t._safariVersion=extractVersion(i.userAgent,/Version\/(\d+(\.?\d+))/,1)}return t}(e),s={browserDetails:n,commonShim:si,extractVersion:extractVersion,disableLog:disableLog,disableWarnings:disableWarnings,sdp:ri};switch(n.browser){case"chrome":if(!$t||!shimPeerConnection$1||!t.shimChrome)return i("Chrome shim is not included in this adapter release."),s;if(null===n.version)return i("Chrome shim can not determine version, not shimming."),s;i("adapter.js shimming chrome."),s.browserShim=$t,shimAddIceCandidateNullOrEmpty(e,n),shimParameterlessSetLocalDescription(e),shimGetUserMedia$2(e,n),shimMediaStream(e),shimPeerConnection$1(e,n),shimOnTrack$1(e),shimAddTrackRemoveTrack(e,n),shimGetSendersWithDtmf(e),shimSenderReceiverGetStats(e),fixNegotiationNeeded(e,n),shimRTCIceCandidate(e),shimRTCIceCandidateRelayProtocol(e),shimConnectionState(e),shimMaxMessageSize(e,n),shimSendThrowTypeError(e),removeExtmapAllowMixed(e,n);break;case"firefox":if(!Xt||!shimPeerConnection||!t.shimFirefox)return i("Firefox shim is not included in this adapter release."),s;i("adapter.js shimming firefox."),s.browserShim=Xt,shimAddIceCandidateNullOrEmpty(e,n),shimParameterlessSetLocalDescription(e),shimGetUserMedia$1(e,n),shimPeerConnection(e,n),shimOnTrack(e),shimRemoveStream(e),shimSenderGetStats(e),shimReceiverGetStats(e),shimRTCDataChannel(e),shimAddTransceiver(e),shimGetParameters(e),shimCreateOffer(e),shimCreateAnswer(e),shimRTCIceCandidate(e),shimConnectionState(e),shimMaxMessageSize(e,n),shimSendThrowTypeError(e);break;case"safari":if(!ei||!t.shimSafari)return i("Safari shim is not included in this adapter release."),s;i("adapter.js shimming safari."),s.browserShim=ei,shimAddIceCandidateNullOrEmpty(e,n),shimParameterlessSetLocalDescription(e),shimRTCIceServerUrls(e),shimCreateOfferLegacy(e),shimCallbacksAPI(e),shimLocalStreamsAPI(e),shimRemoteStreamsAPI(e),shimTrackEventTransceiver(e),shimGetUserMedia(e),shimAudioContext(e),shimRTCIceCandidate(e),shimRTCIceCandidateRelayProtocol(e),shimMaxMessageSize(e,n),shimSendThrowTypeError(e),removeExtmapAllowMixed(e,n);break;default:i("Unsupported browser!")}}({window:"undefined"==typeof window?void 0:window});class TypedPromise extends Promise{constructor(e){super(e)}catch(e){return super.catch(e)}static reject(e){return super.reject(e)}static all(e){return super.all(e)}static race(e){return super.race(e)}}const ai=/version\/(\d+(\.?_?\d+)+)/i;let oi;function getBrowser(e){let t=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];if("undefined"==typeof navigator)return;const i=navigator.userAgent.toLowerCase();if(void 0===oi||t){const e=ci.find(e=>{let{test:t}=e;return t.test(i)});oi=null==e?void 0:e.describe(i)}return oi}const ci=[{test:/firefox|iceweasel|fxios/i,describe:e=>({name:"Firefox",version:getMatch(/(?:firefox|iceweasel|fxios)[\s/](\d+(\.?_?\d+)+)/i,e),os:e.toLowerCase().includes("fxios")?"iOS":void 0,osVersion:getOSVersion(e)})},{test:/chrom|crios|crmo/i,describe:e=>({name:"Chrome",version:getMatch(/(?:chrome|chromium|crios|crmo)\/(\d+(\.?_?\d+)+)/i,e),os:e.toLowerCase().includes("crios")?"iOS":void 0,osVersion:getOSVersion(e)})},{test:/safari|applewebkit/i,describe:e=>({name:"Safari",version:getMatch(ai,e),os:e.includes("mobile/")?"iOS":"macOS",osVersion:getOSVersion(e)})}];function getMatch(e,t){let i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;const n=t.match(e);return n&&n.length>=i&&n[i]||""}function getOSVersion(e){return e.includes("mac os")?getMatch(/\(.+?(\d+_\d+(:?_\d+)?)/,e,1).replace(/_/g,"."):void 0}class LivekitError extends Error{constructor(e,t){super(t||"an error has occured"),this.name="LiveKitError",this.code=e}}var di,li,ui,hi,pi,mi,gi;!function(e){e[e.NotAllowed=0]="NotAllowed",e[e.ServerUnreachable=1]="ServerUnreachable",e[e.InternalError=2]="InternalError",e[e.Cancelled=3]="Cancelled",e[e.LeaveRequest=4]="LeaveRequest",e[e.Timeout=5]="Timeout",e[e.WebSocket=6]="WebSocket",e[e.ServiceNotFound=7]="ServiceNotFound"}(di||(di={}));class ConnectionError extends LivekitError{constructor(e,t,i,n){super(1,e),this.name="ConnectionError",this.status=i,this.reason=t,this.context=n,this.reasonName=di[t]}static notAllowed(e,t,i){return new ConnectionError(e,di.NotAllowed,t,i)}static timeout(e){return new ConnectionError(e,di.Timeout)}static leaveRequest(e,t){return new ConnectionError(e,di.LeaveRequest,void 0,t)}static internal(e,t){return new ConnectionError(e,di.InternalError,void 0,t)}static cancelled(e){return new ConnectionError(e,di.Cancelled)}static serverUnreachable(e,t){return new ConnectionError(e,di.ServerUnreachable,t)}static websocket(e,t,i){return new ConnectionError(e,di.WebSocket,t,i)}static serviceNotFound(e,t){return new ConnectionError(e,di.ServiceNotFound,void 0,t)}}class DeviceUnsupportedError extends LivekitError{constructor(e){super(21,null!=e?e:"device is unsupported"),this.name="DeviceUnsupportedError"}}class TrackInvalidError extends LivekitError{constructor(e){super(20,null!=e?e:"track is invalid"),this.name="TrackInvalidError"}}class UnsupportedServer extends LivekitError{constructor(e){super(10,null!=e?e:"unsupported server"),this.name="UnsupportedServer"}}class UnexpectedConnectionState extends LivekitError{constructor(e){super(12,null!=e?e:"unexpected connection state"),this.name="UnexpectedConnectionState"}}class NegotiationError extends LivekitError{constructor(e){super(13,null!=e?e:"unable to negotiate"),this.name="NegotiationError"}}class PublishTrackError extends LivekitError{constructor(e,t){super(15,e),this.name="PublishTrackError",this.status=t}}class SignalRequestError extends LivekitError{constructor(e,t){super(15,e),this.name="SignalRequestError",this.reason=t,this.reasonName="string"==typeof t?t:wt[t]}}!function(e){e[e.AlreadyOpened=0]="AlreadyOpened",e[e.AbnormalEnd=1]="AbnormalEnd",e[e.DecodeFailed=2]="DecodeFailed",e[e.LengthExceeded=3]="LengthExceeded",e[e.Incomplete=4]="Incomplete",e[e.HandlerAlreadyRegistered=7]="HandlerAlreadyRegistered",e[e.EncryptionTypeMismatch=8]="EncryptionTypeMismatch"}(li||(li={}));class DataStreamError extends LivekitError{constructor(e,t){super(16,e),this.name="DataStreamError",this.reason=t,this.reasonName=li[t]}}class SignalReconnectError extends LivekitError{constructor(e){super(18,e),this.name="SignalReconnectError"}}!function(e){e.PermissionDenied="PermissionDenied",e.NotFound="NotFound",e.DeviceInUse="DeviceInUse",e.Other="Other"}(ui||(ui={})),function(e){e.getFailure=function(t){if(t&&"name"in t)return"NotFoundError"===t.name||"DevicesNotFoundError"===t.name?e.NotFound:"NotAllowedError"===t.name||"PermissionDeniedError"===t.name?e.PermissionDenied:"NotReadableError"===t.name||"TrackStartError"===t.name?e.DeviceInUse:e.Other}}(ui||(ui={}));class CriticalTimers{}CriticalTimers.setTimeout=function(){return setTimeout(...arguments)},CriticalTimers.setInterval=function(){return setInterval(...arguments)},CriticalTimers.clearTimeout=function(){return clearTimeout(...arguments)},CriticalTimers.clearInterval=function(){return clearInterval(...arguments)},function(e){e.Connected="connected",e.Reconnecting="reconnecting",e.SignalReconnecting="signalReconnecting",e.Reconnected="reconnected",e.Disconnected="disconnected",e.ConnectionStateChanged="connectionStateChanged",e.Moved="moved",e.MediaDevicesChanged="mediaDevicesChanged",e.ParticipantConnected="participantConnected",e.ParticipantDisconnected="participantDisconnected",e.TrackPublished="trackPublished",e.TrackSubscribed="trackSubscribed",e.TrackSubscriptionFailed="trackSubscriptionFailed",e.TrackUnpublished="trackUnpublished",e.TrackUnsubscribed="trackUnsubscribed",e.TrackMuted="trackMuted",e.TrackUnmuted="trackUnmuted",e.LocalTrackPublished="localTrackPublished",e.LocalTrackUnpublished="localTrackUnpublished",e.LocalAudioSilenceDetected="localAudioSilenceDetected",e.ActiveSpeakersChanged="activeSpeakersChanged",e.ParticipantMetadataChanged="participantMetadataChanged",e.ParticipantNameChanged="participantNameChanged",e.ParticipantAttributesChanged="participantAttributesChanged",e.ParticipantActive="participantActive",e.RoomMetadataChanged="roomMetadataChanged",e.DataReceived="dataReceived",e.SipDTMFReceived="sipDTMFReceived",e.TranscriptionReceived="transcriptionReceived",e.ConnectionQualityChanged="connectionQualityChanged",e.TrackStreamStateChanged="trackStreamStateChanged",e.TrackSubscriptionPermissionChanged="trackSubscriptionPermissionChanged",e.TrackSubscriptionStatusChanged="trackSubscriptionStatusChanged",e.AudioPlaybackStatusChanged="audioPlaybackChanged",e.VideoPlaybackStatusChanged="videoPlaybackChanged",e.MediaDevicesError="mediaDevicesError",e.ParticipantPermissionsChanged="participantPermissionsChanged",e.SignalConnected="signalConnected",e.RecordingStatusChanged="recordingStatusChanged",e.ParticipantEncryptionStatusChanged="participantEncryptionStatusChanged",e.EncryptionError="encryptionError",e.DCBufferStatusChanged="dcBufferStatusChanged",e.ActiveDeviceChanged="activeDeviceChanged",e.ChatMessage="chatMessage",e.LocalTrackSubscribed="localTrackSubscribed",e.MetricsReceived="metricsReceived"}(hi||(hi={})),function(e){e.TrackPublished="trackPublished",e.TrackSubscribed="trackSubscribed",e.TrackSubscriptionFailed="trackSubscriptionFailed",e.TrackUnpublished="trackUnpublished",e.TrackUnsubscribed="trackUnsubscribed",e.TrackMuted="trackMuted",e.TrackUnmuted="trackUnmuted",e.LocalTrackPublished="localTrackPublished",e.LocalTrackUnpublished="localTrackUnpublished",e.LocalTrackCpuConstrained="localTrackCpuConstrained",e.LocalSenderCreated="localSenderCreated",e.ParticipantMetadataChanged="participantMetadataChanged",e.ParticipantNameChanged="participantNameChanged",e.DataReceived="dataReceived",e.SipDTMFReceived="sipDTMFReceived",e.TranscriptionReceived="transcriptionReceived",e.IsSpeakingChanged="isSpeakingChanged",e.ConnectionQualityChanged="connectionQualityChanged",e.TrackStreamStateChanged="trackStreamStateChanged",e.TrackSubscriptionPermissionChanged="trackSubscriptionPermissionChanged",e.TrackSubscriptionStatusChanged="trackSubscriptionStatusChanged",e.TrackCpuConstrained="trackCpuConstrained",e.MediaDevicesError="mediaDevicesError",e.AudioStreamAcquired="audioStreamAcquired",e.ParticipantPermissionsChanged="participantPermissionsChanged",e.PCTrackAdded="pcTrackAdded",e.AttributesChanged="attributesChanged",e.LocalTrackSubscribed="localTrackSubscribed",e.ChatMessage="chatMessage",e.Active="active"}(pi||(pi={})),function(e){e.TransportsCreated="transportsCreated",e.Connected="connected",e.Disconnected="disconnected",e.Resuming="resuming",e.Resumed="resumed",e.Restarting="restarting",e.Restarted="restarted",e.SignalResumed="signalResumed",e.SignalRestarted="signalRestarted",e.Closing="closing",e.MediaTrackAdded="mediaTrackAdded",e.ActiveSpeakersUpdate="activeSpeakersUpdate",e.DataPacketReceived="dataPacketReceived",e.RTPVideoMapUpdate="rtpVideoMapUpdate",e.DCBufferStatusChanged="dcBufferStatusChanged",e.ParticipantUpdate="participantUpdate",e.RoomUpdate="roomUpdate",e.SpeakersChanged="speakersChanged",e.StreamStateChanged="streamStateChanged",e.ConnectionQualityUpdate="connectionQualityUpdate",e.SubscriptionError="subscriptionError",e.SubscriptionPermissionUpdate="subscriptionPermissionUpdate",e.RemoteMute="remoteMute",e.SubscribedQualityUpdate="subscribedQualityUpdate",e.LocalTrackUnpublished="localTrackUnpublished",e.LocalTrackSubscribed="localTrackSubscribed",e.Offline="offline",e.SignalRequestResponse="signalRequestResponse",e.SignalConnected="signalConnected",e.RoomMoved="roomMoved"}(mi||(mi={})),function(e){e.Message="message",e.Muted="muted",e.Unmuted="unmuted",e.Restarted="restarted",e.Ended="ended",e.Subscribed="subscribed",e.Unsubscribed="unsubscribed",e.CpuConstrained="cpuConstrained",e.UpdateSettings="updateSettings",e.UpdateSubscription="updateSubscription",e.AudioPlaybackStarted="audioPlaybackStarted",e.AudioPlaybackFailed="audioPlaybackFailed",e.AudioSilenceDetected="audioSilenceDetected",e.VisibilityChanged="visibilityChanged",e.VideoDimensionsChanged="videoDimensionsChanged",e.VideoPlaybackStarted="videoPlaybackStarted",e.VideoPlaybackFailed="videoPlaybackFailed",e.ElementAttached="elementAttached",e.ElementDetached="elementDetached",e.UpstreamPaused="upstreamPaused",e.UpstreamResumed="upstreamResumed",e.SubscriptionPermissionChanged="subscriptionPermissionChanged",e.SubscriptionStatusChanged="subscriptionStatusChanged",e.SubscriptionFailed="subscriptionFailed",e.TrackProcessorUpdate="trackProcessorUpdate",e.AudioTrackFeatureUpdate="audioTrackFeatureUpdate",e.TranscriptionReceived="transcriptionReceived",e.TimeSyncUpdate="timeSyncUpdate",e.PreConnectBufferFlushed="preConnectBufferFlushed"}(gi||(gi={}));class VideoPreset{constructor(e,t,i,n,s){if("object"==typeof e)this.width=e.width,this.height=e.height,this.aspectRatio=e.aspectRatio,this.encoding={maxBitrate:e.maxBitrate,maxFramerate:e.maxFramerate,priority:e.priority};else{if(void 0===t||void 0===i)throw new TypeError("Unsupported options: provide at least width, height and maxBitrate");this.width=e,this.height=t,this.aspectRatio=e/t,this.encoding={maxBitrate:i,maxFramerate:n,priority:s}}}get resolution(){return{width:this.width,height:this.height,frameRate:this.encoding.maxFramerate,aspectRatio:this.aspectRatio}}}const fi=["vp8","h264"],vi=["vp8","h264","vp9","av1","h265"];const isBackupCodec=function(e){return!!fi.find(t=>t===e)};var ki,bi;!function(e){e[e.PREFER_REGRESSION=0]="PREFER_REGRESSION",e[e.SIMULCAST=1]="SIMULCAST",e[e.REGRESSION=2]="REGRESSION"}(ki||(ki={})),function(e){e.telephone={maxBitrate:12e3},e.speech={maxBitrate:24e3},e.music={maxBitrate:48e3},e.musicStereo={maxBitrate:64e3},e.musicHighQuality={maxBitrate:96e3},e.musicHighQualityStereo={maxBitrate:128e3}}(bi||(bi={}));const yi={h90:new VideoPreset(160,90,9e4,20),h180:new VideoPreset(320,180,16e4,20),h216:new VideoPreset(384,216,18e4,20),h360:new VideoPreset(640,360,45e4,20),h540:new VideoPreset(960,540,8e5,25),h720:new VideoPreset(1280,720,17e5,30),h1080:new VideoPreset(1920,1080,3e6,30),h1440:new VideoPreset(2560,1440,5e6,30),h2160:new VideoPreset(3840,2160,8e6,30)},Ti={h120:new VideoPreset(160,120,7e4,20),h180:new VideoPreset(240,180,125e3,20),h240:new VideoPreset(320,240,14e4,20),h360:new VideoPreset(480,360,33e4,20),h480:new VideoPreset(640,480,5e5,20),h540:new VideoPreset(720,540,6e5,25),h720:new VideoPreset(960,720,13e5,30),h1080:new VideoPreset(1440,1080,23e5,30),h1440:new VideoPreset(1920,1440,38e5,30)},Ci={h360fps3:new VideoPreset(640,360,2e5,3,"medium"),h360fps15:new VideoPreset(640,360,4e5,15,"medium"),h720fps5:new VideoPreset(1280,720,8e5,5,"medium"),h720fps15:new VideoPreset(1280,720,15e5,15,"medium"),h720fps30:new VideoPreset(1280,720,2e6,30,"medium"),h1080fps15:new VideoPreset(1920,1080,25e5,15,"medium"),h1080fps30:new VideoPreset(1920,1080,5e6,30,"medium"),original:new VideoPreset(0,0,7e6,30,"medium")};function mergeDefaultOptions(e,t,i){var n,s,a,c;const{optionsWithoutProcessor:l,audioProcessor:u,videoProcessor:h}=extractProcessorsFromOptions(null!=e?e:{}),p=null==t?void 0:t.processor,m=null==i?void 0:i.processor,g=null!=l?l:{};return!0===g.audio&&(g.audio={}),!0===g.video&&(g.video={}),g.audio&&(mergeObjectWithoutOverwriting(g.audio,t),null!==(n=(a=g.audio).deviceId)&&void 0!==n||(a.deviceId={ideal:"default"}),(u||p)&&(g.audio.processor=null!=u?u:p)),g.video&&(mergeObjectWithoutOverwriting(g.video,i),null!==(s=(c=g.video).deviceId)&&void 0!==s||(c.deviceId={ideal:"default"}),(h||m)&&(g.video.processor=null!=h?h:m)),g}function mergeObjectWithoutOverwriting(e,t){return Object.keys(t).forEach(i=>{void 0===e[i]&&(e[i]=t[i])}),e}function constraintsForOptions(e){var t,i,n,s;const a={};if(e.video)if("object"==typeof e.video){const i={},s=i,c=e.video;Object.keys(c).forEach(e=>{if("resolution"===e)mergeObjectWithoutOverwriting(s,c.resolution);else s[e]=c[e]}),a.video=i,null!==(t=(n=a.video).deviceId)&&void 0!==t||(n.deviceId={ideal:"default"})}else a.video=!!e.video&&{deviceId:{ideal:"default"}};else a.video=!1;return e.audio?"object"==typeof e.audio?(a.audio=e.audio,null!==(i=(s=a.audio).deviceId)&&void 0!==i||(s.deviceId={ideal:"default"})):a.audio={deviceId:{ideal:"default"}}:a.audio=!1,a}function detectSilence(e){return __awaiter(this,arguments,void 0,function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:200;return function*(){const i=getNewAudioContext();if(i){const n=i.createAnalyser();n.fftSize=2048;const s=n.frequencyBinCount,a=new Uint8Array(s);i.createMediaStreamSource(new MediaStream([e.mediaStreamTrack])).connect(n),yield sleep(t),n.getByteTimeDomainData(a);const c=a.some(e=>128!==e&&0!==e);return i.close(),!c}return!1}()})}function getNewAudioContext(){var e;const t="undefined"!=typeof window&&(window.AudioContext||window.webkitAudioContext);if(t){const i=new t({latencyHint:"interactive"});if("suspended"===i.state&&"undefined"!=typeof window&&(null===(e=window.document)||void 0===e?void 0:e.body)){const handleResume=()=>__awaiter(this,void 0,void 0,function*(){var e;try{"suspended"===i.state&&(yield i.resume())}catch(e){console.warn("Error trying to auto-resume audio context",e)}finally{null===(e=window.document.body)||void 0===e||e.removeEventListener("click",handleResume)}});i.addEventListener("statechange",()=>{var e;"closed"===i.state&&(null===(e=window.document.body)||void 0===e||e.removeEventListener("click",handleResume))}),window.document.body.addEventListener("click",handleResume)}return i}}function kindToSource(e){return"audioinput"===e?Track.Source.Microphone:"videoinput"===e?Track.Source.Camera:Track.Source.Unknown}function sourceToKind(e){return e===Track.Source.Microphone?"audioinput":e===Track.Source.Camera?"videoinput":void 0}function mimeTypeToVideoCodecString(e){return e.split("/")[1].toLowerCase()}function getTrackPublicationInfo(e){const t=[];return e.forEach(e=>{void 0!==e.track&&t.push(new qe({cid:e.track.mediaStreamID,track:e.trackInfo}))}),t}function getLogContextFromTrack(e){return"mediaStreamTrack"in e?{trackID:e.sid,source:e.source,muted:e.isMuted,enabled:e.mediaStreamTrack.enabled,kind:e.kind,streamID:e.mediaStreamID,streamTrackID:e.mediaStreamTrack.id}:{trackID:e.trackSid,enabled:e.isEnabled,muted:e.isMuted,trackInfo:Object.assign({mimeType:e.mimeType,name:e.trackName,encrypted:e.isEncrypted,kind:e.kind,source:e.source},e.track?getLogContextFromTrack(e.track):{})}}function extractProcessorsFromOptions(e){const t=Object.assign({},e);let i,n;return"object"==typeof t.audio&&t.audio.processor&&(i=t.audio.processor,t.audio=Object.assign(Object.assign({},t.audio),{processor:void 0})),"object"==typeof t.video&&t.video.processor&&(n=t.video.processor,t.video=Object.assign(Object.assign({},t.video),{processor:void 0})),{audioProcessor:i,videoProcessor:n,optionsWithoutProcessor:(s=t,void 0===s?s:"function"==typeof structuredClone?"object"==typeof s&&null!==s?structuredClone(Object.assign({},s)):structuredClone(s):JSON.parse(JSON.stringify(s)))};var s}function areDimensionsSmaller(e,t){return e.width*e.height<t.width*t.height}const Si=[];var Ei;!function(e){e[e.LOW=0]="LOW",e[e.MEDIUM=1]="MEDIUM",e[e.HIGH=2]="HIGH"}(Ei||(Ei={}));class Track extends Jt.EventEmitter{get streamState(){return this._streamState}setStreamState(e){this._streamState=e}constructor(e,t){let i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};var n;super(),this.attachedElements=[],this.isMuted=!1,this._streamState=Track.StreamState.Active,this.isInBackground=!1,this._currentBitrate=0,this.log=Bt,this.appVisibilityChangedListener=()=>{this.backgroundTimeout&&clearTimeout(this.backgroundTimeout),"hidden"===document.visibilityState?this.backgroundTimeout=setTimeout(()=>this.handleAppVisibilityChanged(),5e3):this.handleAppVisibilityChanged()},this.log=getLogger(null!==(n=i.loggerName)&&void 0!==n?n:Ft.Track),this.loggerContextCb=i.loggerContextCb,this.setMaxListeners(100),this.kind=t,this._mediaStreamTrack=e,this._mediaStreamID=e.id,this.source=Track.Source.Unknown}get logContext(){var e;return Object.assign(Object.assign({},null===(e=this.loggerContextCb)||void 0===e?void 0:e.call(this)),getLogContextFromTrack(this))}get currentBitrate(){return this._currentBitrate}get mediaStreamTrack(){return this._mediaStreamTrack}get mediaStreamID(){return this._mediaStreamID}attach(e){let t="audio";this.kind===Track.Kind.Video&&(t="video"),0===this.attachedElements.length&&this.kind===Track.Kind.Video&&this.addAppVisibilityListener(),e||("audio"===t&&(Si.forEach(t=>{null!==t.parentElement||e||(e=t)}),e&&Si.splice(Si.indexOf(e),1)),e||(e=document.createElement(t))),this.attachedElements.includes(e)||this.attachedElements.push(e),attachToElement(this.mediaStreamTrack,e);const i=e.srcObject.getTracks(),n=i.some(e=>"audio"===e.kind);return e.play().then(()=>{this.emit(n?gi.AudioPlaybackStarted:gi.VideoPlaybackStarted)}).catch(t=>{"NotAllowedError"===t.name?this.emit(n?gi.AudioPlaybackFailed:gi.VideoPlaybackFailed,t):"AbortError"===t.name?Bt.debug("".concat(n?"audio":"video"," playback aborted, likely due to new play request")):Bt.warn("could not playback ".concat(n?"audio":"video"),t),n&&e&&i.some(e=>"video"===e.kind)&&"NotAllowedError"===t.name&&(e.muted=!0,e.play().catch(()=>{}))}),this.emit(gi.ElementAttached,e),e}detach(e){try{if(e){detachTrack(this.mediaStreamTrack,e);const t=this.attachedElements.indexOf(e);return t>=0&&(this.attachedElements.splice(t,1),this.recycleElement(e),this.emit(gi.ElementDetached,e)),e}const t=[];return this.attachedElements.forEach(e=>{detachTrack(this.mediaStreamTrack,e),t.push(e),this.recycleElement(e),this.emit(gi.ElementDetached,e)}),this.attachedElements=[],t}finally{0===this.attachedElements.length&&this.removeAppVisibilityListener()}}stop(){this.stopMonitor(),this._mediaStreamTrack.stop()}enable(){this._mediaStreamTrack.enabled=!0}disable(){this._mediaStreamTrack.enabled=!1}stopMonitor(){this.monitorInterval&&clearInterval(this.monitorInterval),this.timeSyncHandle&&cancelAnimationFrame(this.timeSyncHandle)}updateLoggerOptions(e){e.loggerName&&(this.log=getLogger(e.loggerName)),e.loggerContextCb&&(this.loggerContextCb=e.loggerContextCb)}recycleElement(e){if(e instanceof HTMLAudioElement){let t=!0;e.pause(),Si.forEach(e=>{e.parentElement||(t=!1)}),t&&Si.push(e)}}handleAppVisibilityChanged(){return __awaiter(this,void 0,void 0,function*(){this.isInBackground="hidden"===document.visibilityState,this.isInBackground||this.kind!==Track.Kind.Video||setTimeout(()=>this.attachedElements.forEach(e=>e.play().catch(()=>{})),0)})}addAppVisibilityListener(){isWeb()?(this.isInBackground="hidden"===document.visibilityState,document.addEventListener("visibilitychange",this.appVisibilityChangedListener)):this.isInBackground=!1}removeAppVisibilityListener(){isWeb()&&document.removeEventListener("visibilitychange",this.appVisibilityChangedListener)}}function attachToElement(e,t){let i,n;i=t.srcObject instanceof MediaStream?t.srcObject:new MediaStream,n="audio"===e.kind?i.getAudioTracks():i.getVideoTracks(),n.includes(e)||(n.forEach(e=>{i.removeTrack(e)}),i.addTrack(e)),isSafari()&&t instanceof HTMLVideoElement||(t.autoplay=!0),t.muted=0===i.getAudioTracks().length,t instanceof HTMLVideoElement&&(t.playsInline=!0),t.srcObject!==i&&(t.srcObject=i,(isSafari()||isFireFox())&&t instanceof HTMLVideoElement&&setTimeout(()=>{t.srcObject=i,t.play().catch(()=>{})},0))}function detachTrack(e,t){if(t.srcObject instanceof MediaStream){const i=t.srcObject;i.removeTrack(e),i.getTracks().length>0?t.srcObject=i:t.srcObject=null}}!function(e){let t,i,n;!function(e){e.Audio="audio",e.Video="video",e.Unknown="unknown"}(t=e.Kind||(e.Kind={})),function(e){e.Camera="camera",e.Microphone="microphone",e.ScreenShare="screen_share",e.ScreenShareAudio="screen_share_audio",e.Unknown="unknown"}(i=e.Source||(e.Source={})),function(e){e.Active="active",e.Paused="paused",e.Unknown="unknown"}(n=e.StreamState||(e.StreamState={})),e.kindToProto=function(e){switch(e){case t.Audio:return M.AUDIO;case t.Video:return M.VIDEO;default:return M.DATA}},e.kindFromProto=function(e){switch(e){case M.AUDIO:return t.Audio;case M.VIDEO:return t.Video;default:return t.Unknown}},e.sourceToProto=function(e){switch(e){case i.Camera:return A.CAMERA;case i.Microphone:return A.MICROPHONE;case i.ScreenShare:return A.SCREEN_SHARE;case i.ScreenShareAudio:return A.SCREEN_SHARE_AUDIO;default:return A.UNKNOWN}},e.sourceFromProto=function(e){switch(e){case A.CAMERA:return i.Camera;case A.MICROPHONE:return i.Microphone;case A.SCREEN_SHARE:return i.ScreenShare;case A.SCREEN_SHARE_AUDIO:return i.ScreenShareAudio;default:return i.Unknown}},e.streamStateFromProto=function(e){switch(e){case xe.ACTIVE:return n.Active;case xe.PAUSED:return n.Paused;default:return n.Unknown}}}(Track||(Track={}));const wi="https://aomediacodec.github.io/av1-rtp-spec/#dependency-descriptor-rtp-header-extension";function sleep(e){return new TypedPromise(t=>CriticalTimers.setTimeout(t,e))}function supportsTransceiver(){return"addTransceiver"in RTCPeerConnection.prototype}function supportsAddTrack(){return"addTrack"in RTCPeerConnection.prototype}function isSVCCodec(e){return"av1"===e||"vp9"===e}function supportsSetSinkId(e){return!(!document||isSafariBased())&&(e||(e=document.createElement("audio")),"setSinkId"in e)}function isFireFox(){var e;return"Firefox"===(null===(e=getBrowser())||void 0===e?void 0:e.name)}function isChromiumBased(){const e=getBrowser();return!!e&&"Chrome"===e.name&&"iOS"!==e.os}function isSafari(){var e;return"Safari"===(null===(e=getBrowser())||void 0===e?void 0:e.name)}function isSafariBased(){const e=getBrowser();return"Safari"===(null==e?void 0:e.name)||"iOS"===(null==e?void 0:e.os)}function isMobile(){var e,t;return!!isWeb()&&(null!==(t=null===(e=navigator.userAgentData)||void 0===e?void 0:e.mobile)&&void 0!==t?t:/Tablet|iPad|Mobile|Android|BlackBerry/.test(navigator.userAgent))}function isWeb(){return"undefined"!=typeof document}function isReactNative(){return"ReactNative"==navigator.product}function isCloud(e){return e.hostname.endsWith(".livekit.cloud")||e.hostname.endsWith(".livekit.run")}function extractProjectFromUrl(e){return isCloud(e)?e.hostname.split(".")[0]:null}function getLKReactNativeInfo(){if(global&&global.LiveKitReactNativeGlobal)return global.LiveKitReactNativeGlobal}function getReactNativeOs(){if(!isReactNative())return;let e=getLKReactNativeInfo();return e?e.platform:void 0}function getDevicePixelRatio(){if(isWeb())return window.devicePixelRatio;if(isReactNative()){let e=getLKReactNativeInfo();if(e)return e.devicePixelRatio}return 1}function compareVersions(e,t){const i=e.split("."),n=t.split("."),s=Math.min(i.length,n.length);for(let e=0;e<s;++e){const t=parseInt(i[e],10),a=parseInt(n[e],10);if(t>a)return 1;if(t<a)return-1;if(e===s-1&&t===a)return 0}return""===e&&""!==t?-1:""===t?1:i.length==n.length?0:i.length<n.length?-1:1}function roDispatchCallback(e){for(const t of e)t.target.handleResize(t)}function ioDispatchCallback(e){for(const t of e)t.target.handleVisibilityChanged(t)}let Pi=null;const getResizeObserver=()=>(Pi||(Pi=new ResizeObserver(roDispatchCallback)),Pi);let Ri=null;const getIntersectionObserver=()=>(Ri||(Ri=new IntersectionObserver(ioDispatchCallback,{root:null,rootMargin:"0px"})),Ri);function createDummyVideoStreamTrack(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:16,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:16,i=arguments.length>2&&void 0!==arguments[2]&&arguments[2],n=arguments.length>3&&void 0!==arguments[3]&&arguments[3];const s=document.createElement("canvas");s.width=e,s.height=t;const a=s.getContext("2d");null==a||a.fillRect(0,0,s.width,s.height),n&&a&&(a.beginPath(),a.arc(e/2,t/2,50,0,2*Math.PI,!0),a.closePath(),a.fillStyle="grey",a.fill());const c=s.captureStream(),[l]=c.getTracks();if(!l)throw Error("Could not get empty media stream video track");return l.enabled=i,l}let _i;function getEmptyAudioStreamTrack(){if(!_i){const e=new AudioContext,t=e.createOscillator(),i=e.createGain();i.gain.setValueAtTime(0,0);const n=e.createMediaStreamDestination();if(t.connect(i),i.connect(n),t.start(),[_i]=n.stream.getAudioTracks(),!_i)throw Error("Could not get empty media stream audio track");_i.enabled=!1}return _i.clone()}class Future{get isResolved(){return this._isResolved}constructor(e,t){this._isResolved=!1,this.onFinally=t,this.promise=new Promise((t,i)=>__awaiter(this,void 0,void 0,function*(){this.resolve=t,this.reject=i,e&&(yield e(t,i))})).finally(()=>{var e;this._isResolved=!0,null===(e=this.onFinally)||void 0===e||e.call(this)})}}function unwrapConstraint(e){if("string"==typeof e||"number"==typeof e)return e;if(Array.isArray(e))return e[0];if(void 0!==e.exact)return Array.isArray(e.exact)?e.exact[0]:e.exact;if(void 0!==e.ideal)return Array.isArray(e.ideal)?e.ideal[0]:e.ideal;throw Error("could not unwrap constraint")}function toHttpUrl(e){return e.startsWith("ws")?e.replace(/^(ws)/,"http"):e}function getDisconnectReasonFromConnectionError(e){switch(e.reason){case di.LeaveRequest:return e.context;case di.Cancelled:return F.CLIENT_INITIATED;case di.NotAllowed:return F.USER_REJECTED;case di.ServerUnreachable:return F.JOIN_FAILURE;default:return F.UNKNOWN_REASON}}function bigIntToNumber(e){return void 0!==e?Number(e):void 0}function numberToBigInt(e){return void 0!==e?BigInt(e):void 0}function isLocalTrack(e){return!!e&&!(e instanceof MediaStreamTrack)&&e.isLocal}function isAudioTrack(e){return!!e&&e.kind==Track.Kind.Audio}function isVideoTrack(e){return!!e&&e.kind==Track.Kind.Video}function isLocalVideoTrack(e){return isLocalTrack(e)&&isVideoTrack(e)}function isLocalAudioTrack(e){return isLocalTrack(e)&&isAudioTrack(e)}function isRemoteTrack(e){return!!e&&!e.isLocal}function isRemotePub(e){return!!e&&!e.isLocal}function isRemoteVideoTrack(e){return isRemoteTrack(e)&&isVideoTrack(e)}function createRtcUrl(e,t){let i=arguments.length>2&&void 0!==arguments[2]&&arguments[2];const n=function(e,t){const i=new URL(function(e){return e.startsWith("http")?e.replace(/^(http)/,"ws"):e}(e));return t.forEach((e,t)=>{i.searchParams.set(t,e)}),appendUrlPath(i,"rtc")}(e,t);return i?n:appendUrlPath(n,"v1")}function ensureTrailingSlash(e){return e.endsWith("/")?e:"".concat(e,"/")}function appendUrlPath(e,t){return e.pathname="".concat(ensureTrailingSlash(e.pathname)).concat(t),e}function parseSignalResponse(e){if("string"==typeof e)return Ne.fromJson(JSON.parse(e),{ignoreUnknownFields:!0});if(e instanceof ArrayBuffer)return Ne.fromBinary(new Uint8Array(e));throw new Error("could not decode websocket message: ".concat(typeof e))}const Ii="lk_e2ee";var Oi,Di,xi,Mi,Ai;function isE2EESupported(){return void 0!==window.RTCRtpSender&&void 0!==window.RTCRtpSender.prototype.createEncodedStreams||isScriptTransformSupported()}function isScriptTransformSupported(){return void 0!==window.RTCRtpScriptTransform}!function(e){e.SetKey="setKey",e.RatchetRequest="ratchetRequest",e.KeyRatcheted="keyRatcheted"}(Oi||(Oi={})),function(e){e.KeyRatcheted="keyRatcheted"}(Di||(Di={})),function(e){e.ParticipantEncryptionStatusChanged="participantEncryptionStatusChanged",e.EncryptionError="encryptionError"}(xi||(xi={})),function(e){e.Error="cryptorError"}(Mi||(Mi={}));Jt.EventEmitter;!function(e){e[e.InvalidKey=0]="InvalidKey",e[e.MissingKey=1]="MissingKey",e[e.InternalError=2]="InternalError"}(Ai||(Ai={}));class E2EEManager extends Jt.EventEmitter{constructor(e,t){super(),this.decryptDataRequests=new Map,this.encryptDataRequests=new Map,this.onWorkerMessage=e=>{var t,i;const{kind:n,data:s}=e.data;switch(n){case"error":if(Bt.error(s.error.message),s.uuid){const e=this.decryptDataRequests.get(s.uuid);if(null==e?void 0:e.reject){e.reject(s.error);break}const t=this.encryptDataRequests.get(s.uuid);if(null==t?void 0:t.reject){t.reject(s.error);break}}this.emit(xi.EncryptionError,s.error,s.participantIdentity);break;case"initAck":s.enabled&&this.keyProvider.getKeys().forEach(e=>{this.postKey(e)});break;case"enable":if(s.enabled&&this.keyProvider.getKeys().forEach(e=>{this.postKey(e)}),this.encryptionEnabled!==s.enabled&&s.participantIdentity===(null===(t=this.room)||void 0===t?void 0:t.localParticipant.identity))this.emit(xi.ParticipantEncryptionStatusChanged,s.enabled,this.room.localParticipant),this.encryptionEnabled=s.enabled;else if(s.participantIdentity){const e=null===(i=this.room)||void 0===i?void 0:i.getParticipantByIdentity(s.participantIdentity);if(!e)throw TypeError("couldn't set encryption status, participant not found".concat(s.participantIdentity));this.emit(xi.ParticipantEncryptionStatusChanged,s.enabled,e)}break;case"ratchetKey":this.keyProvider.emit(Oi.KeyRatcheted,s.ratchetResult,s.participantIdentity,s.keyIndex);break;case"decryptDataResponse":const e=this.decryptDataRequests.get(s.uuid);(null==e?void 0:e.resolve)&&e.resolve(s);break;case"encryptDataResponse":const n=this.encryptDataRequests.get(s.uuid);(null==n?void 0:n.resolve)&&n.resolve(s)}},this.onWorkerError=e=>{Bt.error("e2ee worker encountered an error:",{error:e.error}),this.emit(xi.EncryptionError,e.error,void 0)},this.keyProvider=e.keyProvider,this.worker=e.worker,this.encryptionEnabled=!1,this.dataChannelEncryptionEnabled=t}get isEnabled(){return this.encryptionEnabled}get isDataChannelEncryptionEnabled(){return this.isEnabled&&this.dataChannelEncryptionEnabled}setup(e){if(!isE2EESupported())throw new DeviceUnsupportedError("tried to setup end-to-end encryption on an unsupported browser");if(Bt.info("setting up e2ee"),e!==this.room){this.room=e,this.setupEventListeners(e,this.keyProvider);const t={kind:"init",data:{keyProviderOptions:this.keyProvider.getOptions(),loglevel:qt.getLevel()}};this.worker&&(Bt.info("initializing worker",{worker:this.worker}),this.worker.onmessage=this.onWorkerMessage,this.worker.onerror=this.onWorkerError,this.worker.postMessage(t))}}setParticipantCryptorEnabled(e,t){Bt.debug("set e2ee to ".concat(e," for participant ").concat(t)),this.postEnable(e,t)}setSifTrailer(e){e&&0!==e.length?this.postSifTrailer(e):Bt.warn("ignoring server sent trailer as it's empty")}setupEngine(e){e.on(mi.RTPVideoMapUpdate,e=>{this.postRTPMap(e)})}setupEventListeners(e,t){e.on(hi.TrackPublished,(e,t)=>this.setParticipantCryptorEnabled(e.trackInfo.encryption!==Q.NONE,t.identity)),e.on(hi.ConnectionStateChanged,t=>{t===bn.Connected&&e.remoteParticipants.forEach(e=>{e.trackPublications.forEach(t=>{this.setParticipantCryptorEnabled(t.trackInfo.encryption!==Q.NONE,e.identity)})})}).on(hi.TrackUnsubscribed,(e,t,i)=>{var n;const s={kind:"removeTransform",data:{participantIdentity:i.identity,trackId:e.mediaStreamID}};null===(n=this.worker)||void 0===n||n.postMessage(s)}).on(hi.TrackSubscribed,(e,t,i)=>{this.setupE2EEReceiver(e,i.identity,t.trackInfo)}).on(hi.SignalConnected,()=>{if(!this.room)throw new TypeError("expected room to be present on signal connect");t.getKeys().forEach(e=>{this.postKey(e)}),this.setParticipantCryptorEnabled(this.room.localParticipant.isE2EEEnabled,this.room.localParticipant.identity)}),e.localParticipant.on(pi.LocalSenderCreated,(e,t)=>__awaiter(this,void 0,void 0,function*(){this.setupE2EESender(t,e)})),e.localParticipant.on(pi.LocalTrackPublished,e=>{if(!isVideoTrack(e.track)||!isSafariBased())return;const t={kind:"updateCodec",data:{trackId:e.track.mediaStreamID,codec:mimeTypeToVideoCodecString(e.trackInfo.codecs[0].mimeType),participantIdentity:this.room.localParticipant.identity}};this.worker.postMessage(t)}),t.on(Oi.SetKey,e=>this.postKey(e)).on(Oi.RatchetRequest,(e,t)=>this.postRatchetRequest(e,t))}encryptData(e){return __awaiter(this,void 0,void 0,function*(){if(!this.worker)throw Error("could not encrypt data, worker is missing");const t=crypto.randomUUID(),i={kind:"encryptDataRequest",data:{uuid:t,payload:e,participantIdentity:this.room.localParticipant.identity}},n=new Future;return n.onFinally=()=>{this.encryptDataRequests.delete(t)},this.encryptDataRequests.set(t,n),this.worker.postMessage(i),n.promise})}handleEncryptedData(e,t,i,n){if(!this.worker)throw Error("could not handle encrypted data, worker is missing");const s=crypto.randomUUID(),a={kind:"decryptDataRequest",data:{uuid:s,payload:e,iv:t,participantIdentity:i,keyIndex:n}},c=new Future;return c.onFinally=()=>{this.decryptDataRequests.delete(s)},this.decryptDataRequests.set(s,c),this.worker.postMessage(a),c.promise}postRatchetRequest(e,t){if(!this.worker)throw Error("could not ratchet key, worker is missing");const i={kind:"ratchetRequest",data:{participantIdentity:e,keyIndex:t}};this.worker.postMessage(i)}postKey(e){let{key:t,participantIdentity:i,keyIndex:n}=e;var s;if(!this.worker)throw Error("could not set key, worker is missing");const a={kind:"setKey",data:{participantIdentity:i,isPublisher:i===(null===(s=this.room)||void 0===s?void 0:s.localParticipant.identity),key:t,keyIndex:n}};this.worker.postMessage(a)}postEnable(e,t){if(!this.worker)throw new ReferenceError("failed to enable e2ee, worker is not ready");{const i={kind:"enable",data:{enabled:e,participantIdentity:t}};this.worker.postMessage(i)}}postRTPMap(e){var t;if(!this.worker)throw TypeError("could not post rtp map, worker is missing");if(!(null===(t=this.room)||void 0===t?void 0:t.localParticipant.identity))throw TypeError("could not post rtp map, local participant identity is missing");const i={kind:"setRTPMap",data:{map:e,participantIdentity:this.room.localParticipant.identity}};this.worker.postMessage(i)}postSifTrailer(e){if(!this.worker)throw Error("could not post SIF trailer, worker is missing");const t={kind:"setSifTrailer",data:{trailer:e}};this.worker.postMessage(t)}setupE2EEReceiver(e,t,i){if(e.receiver){if(!(null==i?void 0:i.mimeType)||""===i.mimeType)throw new TypeError("MimeType missing from trackInfo, cannot set up E2EE cryptor");this.handleReceiver(e.receiver,e.mediaStreamID,t,"video"===e.kind?mimeTypeToVideoCodecString(i.mimeType):void 0)}}setupE2EESender(e,t){isLocalTrack(e)&&t?this.handleSender(t,e.mediaStreamID,void 0):t||Bt.warn("early return because sender is not ready")}handleReceiver(e,t,i,n){return __awaiter(this,void 0,void 0,function*(){if(this.worker){if(isScriptTransformSupported()&&!isChromiumBased()){const s={kind:"decode",participantIdentity:i,trackId:t,codec:n};e.transform=new RTCRtpScriptTransform(this.worker,s)}else{if(Ii in e&&n){const e={kind:"updateCodec",data:{trackId:t,codec:n,participantIdentity:i}};return void this.worker.postMessage(e)}let s=e.writableStream,a=e.readableStream;if(!s||!a){const t=e.createEncodedStreams();e.writableStream=t.writable,s=t.writable,e.readableStream=t.readable,a=t.readable}const c={kind:"decode",data:{readableStream:a,writableStream:s,trackId:t,codec:n,participantIdentity:i,isReuse:Ii in e}};this.worker.postMessage(c,[a,s])}e[Ii]=!0}})}handleSender(e,t,i){var n;if(!(Ii in e)&&this.worker){if(!(null===(n=this.room)||void 0===n?void 0:n.localParticipant.identity)||""===this.room.localParticipant.identity)throw TypeError("local identity needs to be known in order to set up encrypted sender");if(isScriptTransformSupported()&&!isChromiumBased()){Bt.info("initialize script transform");const n={kind:"encode",participantIdentity:this.room.localParticipant.identity,trackId:t,codec:i};e.transform=new RTCRtpScriptTransform(this.worker,n)}else{Bt.info("initialize encoded streams");const n=e.createEncodedStreams(),s={kind:"encode",data:{readableStream:n.readable,writableStream:n.writable,codec:i,trackId:t,participantIdentity:this.room.localParticipant.identity,isReuse:!1}};this.worker.postMessage(s,[n.readable,n.writable])}e[Ii]=!0}}}class BackOffStrategy{constructor(){this.failedConnectionAttempts=new Map,this.backOffPromises=new Map}static getInstance(){return this._instance||(this._instance=new BackOffStrategy),this._instance}addFailedConnectionAttempt(e){var t;const i=extractProjectFromUrl(new URL(e));if(!i)return;let n=null!==(t=this.failedConnectionAttempts.get(i))&&void 0!==t?t:0;this.failedConnectionAttempts.set(i,n+1),this.backOffPromises.set(i,sleep(Math.min(500*Math.pow(2,n),15e3)))}getBackOffPromise(e){const t=new URL(e),i=t&&extractProjectFromUrl(t);return i&&this.backOffPromises.get(i)||Promise.resolve()}resetFailedConnectionAttempts(e){const t=new URL(e),i=t&&extractProjectFromUrl(t);i&&(this.failedConnectionAttempts.set(i,0),this.backOffPromises.set(i,Promise.resolve()))}resetAll(){this.backOffPromises.clear(),this.failedConnectionAttempts.clear()}}BackOffStrategy._instance=null;const Ni="default";class DeviceManager{constructor(){this._previousDevices=[]}static getInstance(){return void 0===this.instance&&(this.instance=new DeviceManager),this.instance}get previousDevices(){return this._previousDevices}getDevices(e){return __awaiter(this,arguments,void 0,function(e){var t=this;let i=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];return function*(){var n;if((null===(n=DeviceManager.userMediaPromiseMap)||void 0===n?void 0:n.size)>0){Bt.debug("awaiting getUserMedia promise");try{e?yield DeviceManager.userMediaPromiseMap.get(e):yield Promise.all(DeviceManager.userMediaPromiseMap.values())}catch(e){Bt.warn("error waiting for media permissons")}}let s=yield navigator.mediaDevices.enumerateDevices();if(i&&(!isSafari()||!t.hasDeviceInUse(e))){if(0===s.filter(t=>t.kind===e).length||s.some(t=>{const i=""===t.label,n=!e||t.kind===e;return i&&n})){const t={video:"audioinput"!==e&&"audiooutput"!==e,audio:"videoinput"!==e&&{deviceId:{ideal:"default"}}},i=yield navigator.mediaDevices.getUserMedia(t);s=yield navigator.mediaDevices.enumerateDevices(),i.getTracks().forEach(e=>{e.stop()})}}return t._previousDevices=s,e&&(s=s.filter(t=>t.kind===e)),s}()})}normalizeDeviceId(e,t,i){return __awaiter(this,void 0,void 0,function*(){if(t!==Ni)return t;const n=yield this.getDevices(e),s=n.find(e=>e.deviceId===Ni);if(!s)return void Bt.warn("could not reliably determine default device");const a=n.find(e=>e.deviceId!==Ni&&e.groupId===(null!=i?i:s.groupId));if(a)return null==a?void 0:a.deviceId;Bt.warn("could not reliably determine default device")})}hasDeviceInUse(e){return e?DeviceManager.userMediaPromiseMap.has(e):DeviceManager.userMediaPromiseMap.size>0}}var Li;DeviceManager.mediaDeviceKinds=["audioinput","audiooutput","videoinput"],DeviceManager.userMediaPromiseMap=new Map,function(e){e[e.WAITING=0]="WAITING",e[e.RUNNING=1]="RUNNING",e[e.COMPLETED=2]="COMPLETED"}(Li||(Li={}));class AsyncQueue{constructor(){this.pendingTasks=new Map,this.taskMutex=new _,this.nextTaskIndex=0}run(e){return __awaiter(this,void 0,void 0,function*(){const t={id:this.nextTaskIndex++,enqueuedAt:Date.now(),status:Li.WAITING};this.pendingTasks.set(t.id,t);const i=yield this.taskMutex.lock();try{return t.executedAt=Date.now(),t.status=Li.RUNNING,yield e()}finally{t.status=Li.COMPLETED,this.pendingTasks.delete(t.id),i()}})}flush(){return __awaiter(this,void 0,void 0,function*(){return this.run(()=>__awaiter(this,void 0,void 0,function*(){}))})}snapshot(){return Array.from(this.pendingTasks.values())}}class WebSocketStream{get readyState(){return this.ws.readyState}constructor(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};var i,n;if(null===(i=t.signal)||void 0===i?void 0:i.aborted)throw new DOMException("This operation was aborted","AbortError");this.url=e;const s=new WebSocket(e,null!==(n=t.protocols)&&void 0!==n?n:[]);s.binaryType="arraybuffer",this.ws=s;const closeWithInfo=function(){let{closeCode:e,reason:t}=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return s.close(e,t)};this.opened=new TypedPromise((e,t)=>{const rejectHandler=()=>{t(ConnectionError.websocket("Encountered websocket error during connection establishment"))};s.onopen=()=>{e({readable:new ReadableStream({start(e){s.onmessage=t=>{let{data:i}=t;return e.enqueue(i)},s.onerror=t=>e.error(t)},cancel:closeWithInfo}),writable:new WritableStream({write(e){s.send(e)},abort(){s.close()},close:closeWithInfo}),protocol:s.protocol,extensions:s.extensions}),s.removeEventListener("error",rejectHandler)},s.addEventListener("error",rejectHandler)}),this.closed=new TypedPromise((e,t)=>{const rejectHandler=()=>__awaiter(this,void 0,void 0,function*(){const i=new TypedPromise(e=>{s.readyState!==WebSocket.CLOSED&&s.addEventListener("close",t=>{e(t)},{once:!0})}),n=yield TypedPromise.race([sleep(250),i]);n?e(n):t(ConnectionError.websocket("Encountered unspecified websocket error without a timely close event"))});s.onclose=t=>{let{code:i,reason:n}=t;e({closeCode:i,reason:n}),s.removeEventListener("error",rejectHandler)},s.addEventListener("error",rejectHandler)}),t.signal&&(t.signal.onabort=()=>s.close()),this.close=closeWithInfo}}const Ui=["syncState","trickle","offer","answer","simulate","leave"];var Fi;!function(e){e[e.CONNECTING=0]="CONNECTING",e[e.CONNECTED=1]="CONNECTED",e[e.RECONNECTING=2]="RECONNECTING",e[e.DISCONNECTING=3]="DISCONNECTING",e[e.DISCONNECTED=4]="DISCONNECTED"}(Fi||(Fi={}));class SignalClient{get currentState(){return this.state}get isDisconnected(){return this.state===Fi.DISCONNECTING||this.state===Fi.DISCONNECTED}get isEstablishingConnection(){return this.state===Fi.CONNECTING||this.state===Fi.RECONNECTING}getNextRequestId(){return this._requestId+=1,this._requestId}constructor(){let e=arguments.length>0&&void 0!==arguments[0]&&arguments[0],t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};var i;this.rtt=0,this.state=Fi.DISCONNECTED,this.log=Bt,this._requestId=0,this.useV0SignalPath=!1,this.resetCallbacks=()=>{this.onAnswer=void 0,this.onLeave=void 0,this.onLocalTrackPublished=void 0,this.onLocalTrackUnpublished=void 0,this.onNegotiateRequested=void 0,this.onOffer=void 0,this.onRemoteMuteChanged=void 0,this.onSubscribedQualityUpdate=void 0,this.onTokenRefresh=void 0,this.onTrickle=void 0,this.onClose=void 0,this.onMediaSectionsRequirement=void 0},this.log=getLogger(null!==(i=t.loggerName)&&void 0!==i?i:Ft.Signal),this.loggerContextCb=t.loggerContextCb,this.useJSON=e,this.requestQueue=new AsyncQueue,this.queuedRequests=[],this.closingLock=new _,this.connectionLock=new _,this.state=Fi.DISCONNECTED}get logContext(){var e,t;return null!==(t=null===(e=this.loggerContextCb)||void 0===e?void 0:e.call(this))&&void 0!==t?t:{}}join(e,t,i,n){return __awaiter(this,arguments,void 0,function(e,t,i,n){var s=this;let a=arguments.length>4&&void 0!==arguments[4]&&arguments[4];return function*(){s.state=Fi.CONNECTING,s.options=i;return yield s.connect(e,t,i,n,a)}()})}reconnect(e,t,i,n){return __awaiter(this,void 0,void 0,function*(){if(!this.options)return void this.log.warn("attempted to reconnect without signal options being set, ignoring",this.logContext);this.state=Fi.RECONNECTING,this.clearPingInterval();return yield this.connect(e,t,Object.assign(Object.assign({},this.options),{reconnect:!0,sid:i,reconnectReason:n}),void 0,this.useV0SignalPath)})}connect(e,t,i,n){return __awaiter(this,arguments,void 0,function(e,t,i,n){var s=this;let a=arguments.length>4&&void 0!==arguments[4]&&arguments[4];return function*(){const c=yield s.connectionLock.lock();s.connectOptions=i,s.useV0SignalPath=a;const l=function(){var e;const t=new ke({sdk:be.JS,protocol:16,version:"2.17.0"});return isReactNative()&&(t.os=null!==(e=getReactNativeOs())&&void 0!==e?e:""),t}(),u=a?function(e,t,i){var n;const s=new URLSearchParams;s.set("access_token",e),i.reconnect&&(s.set("reconnect","1"),i.sid&&s.set("sid",i.sid));s.set("auto_subscribe",i.autoSubscribe?"1":"0"),s.set("sdk",isReactNative()?"reactnative":"js"),s.set("version",t.version),s.set("protocol",t.protocol.toString()),t.deviceModel&&s.set("device_model",t.deviceModel);t.os&&s.set("os",t.os);t.osVersion&&s.set("os_version",t.osVersion);t.browser&&s.set("browser",t.browser);t.browserVersion&&s.set("browser_version",t.browserVersion);i.adaptiveStream&&s.set("adaptive_stream","1");i.reconnectReason&&s.set("reconnect_reason",i.reconnectReason.toString());(null===(n=navigator.connection)||void 0===n?void 0:n.type)&&s.set("network",navigator.connection.type);return s}(t,l,i):function(e,t,i){const n=new URLSearchParams;n.set("access_token",e);const s=new _t({clientInfo:t,connectionSettings:new Rt({autoSubscribe:!!i.autoSubscribe,adaptiveStream:!!i.adaptiveStream}),reconnect:!!i.reconnect,participantSid:i.sid?i.sid:void 0});i.reconnectReason&&(s.reconnectReason=i.reconnectReason);const a=new It({joinRequest:s.toBinary()});return n.set("join_request",btoa(new TextDecoder("utf-8").decode(a.toBinary()))),n}(t,l,i),h=createRtcUrl(e,u,a).toString(),p=(m=h,appendUrlPath(new URL(toHttpUrl(m)),"validate")).toString();var m;return new Promise((e,t)=>__awaiter(s,void 0,void 0,function*(){var s,a;try{let c=!1;const abortHandler=e=>__awaiter(this,void 0,void 0,function*(){if(c)return;c=!0;const i=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"Unknown reason";if(!(e instanceof AbortSignal))return t;const i=e.reason;switch(typeof i){case"string":return i;case"object":return i instanceof Error?i.message:t;default:return"toString"in i?i.toString():t}}(e instanceof Event?e.currentTarget:e,"Abort handler called");this.streamWriter&&!this.isDisconnected?this.sendLeave().then(()=>this.close(i)).catch(e=>{this.log.error(e),this.close()}):this.close(),cleanupAbortHandlers(),t(ConnectionError.cancelled(i))});null==n||n.addEventListener("abort",abortHandler);const cleanupAbortHandlers=()=>{clearTimeout(l),null==n||n.removeEventListener("abort",abortHandler)},l=setTimeout(()=>{abortHandler(ConnectionError.timeout("room connection has timed out (signal)"))},i.websocketTimeout),handleSignalConnected=(e,t)=>{this.handleSignalConnected(e,l,t)},u=new URL(h);u.searchParams.has("access_token")&&u.searchParams.set("access_token","<redacted>"),this.log.debug("connecting to ".concat(u),Object.assign({reconnect:i.reconnect,reconnectReason:i.reconnectReason},this.logContext)),this.ws&&(yield this.close(!1)),this.ws=new WebSocketStream(h);try{this.ws.closed.then(e=>{var i;this.isEstablishingConnection&&t(ConnectionError.internal("Websocket got closed during a (re)connection attempt: ".concat(e.reason))),1e3!==e.closeCode&&(this.log.warn("websocket closed",Object.assign(Object.assign({},this.logContext),{reason:e.reason,code:e.closeCode,wasClean:1e3===e.closeCode,state:this.state})),this.state===Fi.CONNECTED&&this.handleOnClose(null!==(i=e.reason)&&void 0!==i?i:"Unexpected WS error"))}).catch(e=>{this.isEstablishingConnection&&t(ConnectionError.internal("Websocket error during a (re)connection attempt: ".concat(e)))});const n=yield this.ws.opened.catch(e=>__awaiter(this,void 0,void 0,function*(){if(this.state!==Fi.CONNECTED){this.state=Fi.DISCONNECTED,clearTimeout(l);const i=yield this.handleConnectionError(e,p);return void t(i)}this.handleWSError(e),t(e)}));if(clearTimeout(l),!n)return;const c=n.readable.getReader();this.streamWriter=n.writable.getWriter();const u=yield c.read();if(c.releaseLock(),!u.value)throw ConnectionError.internal("no message received as first message");const h=parseSignalResponse(u.value),m=this.validateFirstMessage(h,null!==(s=i.reconnect)&&void 0!==s&&s);if(!m.isValid)return void t(m.error);"join"===(null===(a=h.message)||void 0===a?void 0:a.case)&&(this.pingTimeoutDuration=h.message.value.pingTimeout,this.pingIntervalDuration=h.message.value.pingInterval,this.pingTimeoutDuration&&this.pingTimeoutDuration>0&&this.log.debug("ping config",Object.assign(Object.assign({},this.logContext),{timeout:this.pingTimeoutDuration,interval:this.pingIntervalDuration})));handleSignalConnected(n,m.shouldProcessFirstMessage?h:void 0),e(m.response)}catch(e){t(e)}finally{cleanupAbortHandlers()}}finally{c()}}))}()})}startReadingLoop(e,t){return __awaiter(this,void 0,void 0,function*(){for(t&&this.handleSignalResponse(t);;){this.signalLatency&&(yield sleep(this.signalLatency));const{done:t,value:i}=yield e.read();if(t)break;const n=parseSignalResponse(i);this.handleSignalResponse(n)}})}close(){return __awaiter(this,arguments,void 0,function(){var e=this;let t=!(arguments.length>0&&void 0!==arguments[0])||arguments[0],i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"Close method called on signal client";return function*(){if([Fi.DISCONNECTING||Fi.DISCONNECTED].includes(e.state))return void e.log.debug("ignoring signal close as it's already in disconnecting state");const n=yield e.closingLock.lock();try{if(e.clearPingInterval(),t&&(e.state=Fi.DISCONNECTING),e.ws){e.ws.close({closeCode:1e3,reason:i});const t=e.ws.closed;e.ws=void 0,e.streamWriter=void 0,yield Promise.race([t,sleep(250)])}}catch(t){e.log.debug("websocket error while closing",Object.assign(Object.assign({},e.logContext),{error:t}))}finally{t&&(e.state=Fi.DISCONNECTED),n()}}()})}sendOffer(e,t){this.log.debug("sending offer",Object.assign(Object.assign({},this.logContext),{offerSdp:e.sdp})),this.sendRequest({case:"offer",value:toProtoSessionDescription(e,t)})}sendAnswer(e,t){return this.log.debug("sending answer",Object.assign(Object.assign({},this.logContext),{answerSdp:e.sdp})),this.sendRequest({case:"answer",value:toProtoSessionDescription(e,t)})}sendIceCandidate(e,t){return this.log.debug("sending ice candidate",Object.assign(Object.assign({},this.logContext),{candidate:e})),this.sendRequest({case:"trickle",value:new Fe({candidateInit:JSON.stringify(e),target:t})})}sendMuteTrack(e,t){return this.sendRequest({case:"mute",value:new je({sid:e,muted:t})})}sendAddTrack(e){return this.sendRequest({case:"addTrack",value:e})}sendUpdateLocalMetadata(e,t){return __awaiter(this,arguments,void 0,function(e,t){var i=this;let n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};return function*(){const s=i.getNextRequestId();return yield i.sendRequest({case:"updateMetadata",value:new Ze({requestId:s,metadata:e,name:t,attributes:n})}),s}()})}sendUpdateTrackSettings(e){this.sendRequest({case:"trackSetting",value:e})}sendUpdateSubscription(e){return this.sendRequest({case:"subscription",value:e})}sendSyncState(e){return this.sendRequest({case:"syncState",value:e})}sendUpdateVideoLayers(e,t){return this.sendRequest({case:"updateLayers",value:new Xe({trackSid:e,layers:t})})}sendUpdateSubscriptionPermissions(e,t){return this.sendRequest({case:"subscriptionPermission",value:new ht({allParticipants:e,trackPermissions:t})})}sendSimulateScenario(e){return this.sendRequest({case:"simulate",value:e})}sendPing(){return Promise.all([this.sendRequest({case:"ping",value:n.parse(Date.now())}),this.sendRequest({case:"pingReq",value:new bt({timestamp:n.parse(Date.now()),rtt:n.parse(this.rtt)})})])}sendUpdateLocalAudioTrack(e,t){return this.sendRequest({case:"updateAudioTrack",value:new ze({trackSid:e,features:t})})}sendLeave(){return this.sendRequest({case:"leave",value:new Ye({reason:F.CLIENT_INITIATED,action:$e.DISCONNECT})})}sendRequest(e){return __awaiter(this,arguments,void 0,function(e){var t=this;let i=arguments.length>1&&void 0!==arguments[1]&&arguments[1];return function*(){const n=!i&&!function(e){const t=Ui.indexOf(e.case)>=0;return Bt.trace("request allowed to bypass queue:",{canPass:t,req:e}),t}(e);if(n&&t.state===Fi.RECONNECTING)return void t.queuedRequests.push(()=>__awaiter(t,void 0,void 0,function*(){yield this.sendRequest(e,!0)}));if(i||(yield t.requestQueue.flush()),t.signalLatency&&(yield sleep(t.signalLatency)),t.isDisconnected)return void t.log.debug("skipping signal request (type: ".concat(e.case,") - SignalClient disconnected"));if(!t.streamWriter)return void t.log.error("cannot send signal request before connected, type: ".concat(null==e?void 0:e.case),t.logContext);const s=new Ae({message:e});try{t.useJSON?yield t.streamWriter.write(s.toJsonString()):yield t.streamWriter.write(s.toBinary())}catch(e){t.log.error("error sending signal message",Object.assign(Object.assign({},t.logContext),{error:e}))}}()})}handleSignalResponse(e){var t,i;const n=e.message;if(null==n)return void this.log.debug("received unsupported message",this.logContext);let s=!1;if("answer"===n.case){const e=fromProtoSessionDescription(n.value);this.onAnswer&&this.onAnswer(e,n.value.id,n.value.midToTrackId)}else if("offer"===n.case){const e=fromProtoSessionDescription(n.value);this.onOffer&&this.onOffer(e,n.value.id,n.value.midToTrackId)}else if("trickle"===n.case){const e=JSON.parse(n.value.candidateInit);this.onTrickle&&this.onTrickle(e,n.value.target)}else"update"===n.case?this.onParticipantUpdate&&this.onParticipantUpdate(null!==(t=n.value.participants)&&void 0!==t?t:[]):"trackPublished"===n.case?this.onLocalTrackPublished&&this.onLocalTrackPublished(n.value):"speakersChanged"===n.case?this.onSpeakersChanged&&this.onSpeakersChanged(null!==(i=n.value.speakers)&&void 0!==i?i:[]):"leave"===n.case?this.onLeave&&this.onLeave(n.value):"mute"===n.case?this.onRemoteMuteChanged&&this.onRemoteMuteChanged(n.value.sid,n.value.muted):"roomUpdate"===n.case?this.onRoomUpdate&&n.value.room&&this.onRoomUpdate(n.value.room):"connectionQuality"===n.case?this.onConnectionQuality&&this.onConnectionQuality(n.value):"streamStateUpdate"===n.case?this.onStreamStateUpdate&&this.onStreamStateUpdate(n.value):"subscribedQualityUpdate"===n.case?this.onSubscribedQualityUpdate&&this.onSubscribedQualityUpdate(n.value):"subscriptionPermissionUpdate"===n.case?this.onSubscriptionPermissionUpdate&&this.onSubscriptionPermissionUpdate(n.value):"refreshToken"===n.case?this.onTokenRefresh&&this.onTokenRefresh(n.value):"trackUnpublished"===n.case?this.onLocalTrackUnpublished&&this.onLocalTrackUnpublished(n.value):"subscriptionResponse"===n.case?this.onSubscriptionError&&this.onSubscriptionError(n.value):"pong"===n.case||("pongResp"===n.case?(this.rtt=Date.now()-Number.parseInt(n.value.lastPingTimestamp.toString()),this.resetPingTimeout(),s=!0):"requestResponse"===n.case?this.onRequestResponse&&this.onRequestResponse(n.value):"trackSubscribed"===n.case?this.onLocalTrackSubscribed&&this.onLocalTrackSubscribed(n.value.trackSid):"roomMoved"===n.case?(this.onTokenRefresh&&this.onTokenRefresh(n.value.token),this.onRoomMoved&&this.onRoomMoved(n.value)):"mediaSectionsRequirement"===n.case?this.onMediaSectionsRequirement&&this.onMediaSectionsRequirement(n.value):this.log.debug("unsupported message",Object.assign(Object.assign({},this.logContext),{msgCase:n.case})));s||this.resetPingTimeout()}setReconnected(){for(;this.queuedRequests.length>0;){const e=this.queuedRequests.shift();e&&this.requestQueue.run(e)}}handleOnClose(e){return __awaiter(this,void 0,void 0,function*(){if(this.state===Fi.DISCONNECTED)return;const t=this.onClose;yield this.close(void 0,e),this.log.debug("websocket connection closed: ".concat(e),Object.assign(Object.assign({},this.logContext),{reason:e})),t&&t(e)})}handleWSError(e){this.log.error("websocket error",Object.assign(Object.assign({},this.logContext),{error:e}))}resetPingTimeout(){this.clearPingTimeout(),this.pingTimeoutDuration?this.pingTimeout=CriticalTimers.setTimeout(()=>{this.log.warn("ping timeout triggered. last pong received at: ".concat(new Date(Date.now()-1e3*this.pingTimeoutDuration).toUTCString()),this.logContext),this.handleOnClose("ping timeout")},1e3*this.pingTimeoutDuration):this.log.warn("ping timeout duration not set",this.logContext)}clearPingTimeout(){this.pingTimeout&&CriticalTimers.clearTimeout(this.pingTimeout)}startPingInterval(){this.clearPingInterval(),this.resetPingTimeout(),this.pingIntervalDuration?(this.log.debug("start ping interval",this.logContext),this.pingInterval=CriticalTimers.setInterval(()=>{this.sendPing()},1e3*this.pingIntervalDuration)):this.log.warn("ping interval duration not set",this.logContext)}clearPingInterval(){this.log.debug("clearing ping interval",this.logContext),this.clearPingTimeout(),this.pingInterval&&CriticalTimers.clearInterval(this.pingInterval)}handleSignalConnected(e,t,i){this.state=Fi.CONNECTED,clearTimeout(t),this.startPingInterval(),this.startReadingLoop(e.readable.getReader(),i)}validateFirstMessage(e,t){var i,n,s,a,c;return"join"===(null===(i=e.message)||void 0===i?void 0:i.case)?{isValid:!0,response:e.message.value}:this.state===Fi.RECONNECTING&&"leave"!==(null===(n=e.message)||void 0===n?void 0:n.case)?"reconnect"===(null===(s=e.message)||void 0===s?void 0:s.case)?{isValid:!0,response:e.message.value}:(this.log.debug("declaring signal reconnected without reconnect response received",this.logContext),{isValid:!0,response:void 0,shouldProcessFirstMessage:!0}):this.isEstablishingConnection&&"leave"===(null===(a=e.message)||void 0===a?void 0:a.case)?{isValid:!1,error:ConnectionError.leaveRequest("Received leave request while trying to (re)connect",e.message.value.reason)}:t?{isValid:!1,error:ConnectionError.internal("Unexpected first message")}:{isValid:!1,error:ConnectionError.internal("did not receive join response, got ".concat(null===(c=e.message)||void 0===c?void 0:c.case," instead"))}}handleConnectionError(e,t){return __awaiter(this,void 0,void 0,function*(){try{const i=yield fetch(t);switch(i.status){case 404:return ConnectionError.serviceNotFound("v1 RTC path not found. Consider upgrading your LiveKit server version","v0-rtc");case 401:case 403:const e=yield i.text();return ConnectionError.notAllowed(e,i.status)}return e instanceof ConnectionError?e:ConnectionError.internal("Encountered unknown websocket error during connection: ".concat(e),{status:i.status,statusText:i.statusText})}catch(e){return e instanceof ConnectionError?e:ConnectionError.serverUnreachable(e instanceof Error?e.message:"server was not reachable")}})}}function fromProtoSessionDescription(e){const t={type:"offer",sdp:e.sdp};switch(e.type){case"answer":case"offer":case"pranswer":case"rollback":t.type=e.type}return t}function toProtoSessionDescription(e,t){return new We({sdp:e.sdp,type:e.type,id:t})}class DataPacketBuffer{constructor(){this.buffer=[],this._totalSize=0}push(e){this.buffer.push(e),this._totalSize+=e.data.byteLength}pop(){const e=this.buffer.shift();return e&&(this._totalSize-=e.data.byteLength),e}getAll(){return this.buffer.slice()}popToSequence(e){for(;this.buffer.length>0;){if(!(this.buffer[0].sequence<=e))break;this.pop()}}alignBufferedAmount(e){for(;this.buffer.length>0;){const t=this.buffer[0];if(this._totalSize-t.data.byteLength<=e)break;this.pop()}}get length(){return this.buffer.length}}class TTLMap{constructor(e){this._map=new Map,this._lastCleanup=0,this.ttl=e}set(e,t){const i=Date.now();i-this._lastCleanup>this.ttl/2&&this.cleanup();const n=i+this.ttl;return this._map.set(e,{value:t,expiresAt:n}),this}get(e){const t=this._map.get(e);if(t){if(!(t.expiresAt<Date.now()))return t.value;this._map.delete(e)}}has(e){const t=this._map.get(e);return!!t&&(!(t.expiresAt<Date.now())||(this._map.delete(e),!1))}delete(e){return this._map.delete(e)}clear(){this._map.clear()}cleanup(){const e=Date.now();for(const[t,i]of this._map.entries())i.expiresAt<e&&this._map.delete(t);this._lastCleanup=e}get size(){return this.cleanup(),this._map.size}forEach(e){this.cleanup();for(const[t,i]of this._map.entries())i.expiresAt>=Date.now()&&e(i.value,t,this.asValueMap())}map(e){this.cleanup();const t=[],i=this.asValueMap();for(const[n,s]of i.entries())t.push(e(s,n,i));return t}asValueMap(){const e=new Map;for(const[t,i]of this._map.entries())i.expiresAt>=Date.now()&&e.set(t,i.value);return e}}var ji,Bi,Vi,qi,Hi,Wi={},Gi={},Ki={exports:{}};function requireGrammar(){if(ji)return Ki.exports;ji=1;var e=Ki.exports={v:[{name:"version",reg:/^(\d*)$/}],o:[{name:"origin",reg:/^(\S*) (\d*) (\d*) (\S*) IP(\d) (\S*)/,names:["username","sessionId","sessionVersion","netType","ipVer","address"],format:"%s %s %d %s IP%d %s"}],s:[{name:"name"}],i:[{name:"description"}],u:[{name:"uri"}],e:[{name:"email"}],p:[{name:"phone"}],z:[{name:"timezones"}],r:[{name:"repeats"}],t:[{name:"timing",reg:/^(\d*) (\d*)/,names:["start","stop"],format:"%d %d"}],c:[{name:"connection",reg:/^IN IP(\d) (\S*)/,names:["version","ip"],format:"IN IP%d %s"}],b:[{push:"bandwidth",reg:/^(TIAS|AS|CT|RR|RS):(\d*)/,names:["type","limit"],format:"%s:%s"}],m:[{reg:/^(\w*) (\d*) ([\w/]*)(?: (.*))?/,names:["type","port","protocol","payloads"],format:"%s %d %s %s"}],a:[{push:"rtp",reg:/^rtpmap:(\d*) ([\w\-.]*)(?:\s*\/(\d*)(?:\s*\/(\S*))?)?/,names:["payload","codec","rate","encoding"],format:function(e){return e.encoding?"rtpmap:%d %s/%s/%s":e.rate?"rtpmap:%d %s/%s":"rtpmap:%d %s"}},{push:"fmtp",reg:/^fmtp:(\d*) ([\S| ]*)/,names:["payload","config"],format:"fmtp:%d %s"},{name:"control",reg:/^control:(.*)/,format:"control:%s"},{name:"rtcp",reg:/^rtcp:(\d*)(?: (\S*) IP(\d) (\S*))?/,names:["port","netType","ipVer","address"],format:function(e){return null!=e.address?"rtcp:%d %s IP%d %s":"rtcp:%d"}},{push:"rtcpFbTrrInt",reg:/^rtcp-fb:(\*|\d*) trr-int (\d*)/,names:["payload","value"],format:"rtcp-fb:%s trr-int %d"},{push:"rtcpFb",reg:/^rtcp-fb:(\*|\d*) ([\w-_]*)(?: ([\w-_]*))?/,names:["payload","type","subtype"],format:function(e){return null!=e.subtype?"rtcp-fb:%s %s %s":"rtcp-fb:%s %s"}},{push:"ext",reg:/^extmap:(\d+)(?:\/(\w+))?(?: (urn:ietf:params:rtp-hdrext:encrypt))? (\S*)(?: (\S*))?/,names:["value","direction","encrypt-uri","uri","config"],format:function(e){return"extmap:%d"+(e.direction?"/%s":"%v")+(e["encrypt-uri"]?" %s":"%v")+" %s"+(e.config?" %s":"")}},{name:"extmapAllowMixed",reg:/^(extmap-allow-mixed)/},{push:"crypto",reg:/^crypto:(\d*) ([\w_]*) (\S*)(?: (\S*))?/,names:["id","suite","config","sessionConfig"],format:function(e){return null!=e.sessionConfig?"crypto:%d %s %s %s":"crypto:%d %s %s"}},{name:"setup",reg:/^setup:(\w*)/,format:"setup:%s"},{name:"connectionType",reg:/^connection:(new|existing)/,format:"connection:%s"},{name:"mid",reg:/^mid:([^\s]*)/,format:"mid:%s"},{name:"msid",reg:/^msid:(.*)/,format:"msid:%s"},{name:"ptime",reg:/^ptime:(\d*(?:\.\d*)*)/,format:"ptime:%d"},{name:"maxptime",reg:/^maxptime:(\d*(?:\.\d*)*)/,format:"maxptime:%d"},{name:"direction",reg:/^(sendrecv|recvonly|sendonly|inactive)/},{name:"icelite",reg:/^(ice-lite)/},{name:"iceUfrag",reg:/^ice-ufrag:(\S*)/,format:"ice-ufrag:%s"},{name:"icePwd",reg:/^ice-pwd:(\S*)/,format:"ice-pwd:%s"},{name:"fingerprint",reg:/^fingerprint:(\S*) (\S*)/,names:["type","hash"],format:"fingerprint:%s %s"},{push:"candidates",reg:/^candidate:(\S*) (\d*) (\S*) (\d*) (\S*) (\d*) typ (\S*)(?: raddr (\S*) rport (\d*))?(?: tcptype (\S*))?(?: generation (\d*))?(?: network-id (\d*))?(?: network-cost (\d*))?/,names:["foundation","component","transport","priority","ip","port","type","raddr","rport","tcptype","generation","network-id","network-cost"],format:function(e){var t="candidate:%s %d %s %d %s %d typ %s";return t+=null!=e.raddr?" raddr %s rport %d":"%v%v",t+=null!=e.tcptype?" tcptype %s":"%v",null!=e.generation&&(t+=" generation %d"),t+=null!=e["network-id"]?" network-id %d":"%v",t+=null!=e["network-cost"]?" network-cost %d":"%v"}},{name:"endOfCandidates",reg:/^(end-of-candidates)/},{name:"remoteCandidates",reg:/^remote-candidates:(.*)/,format:"remote-candidates:%s"},{name:"iceOptions",reg:/^ice-options:(\S*)/,format:"ice-options:%s"},{push:"ssrcs",reg:/^ssrc:(\d*) ([\w_-]*)(?::(.*))?/,names:["id","attribute","value"],format:function(e){var t="ssrc:%d";return null!=e.attribute&&(t+=" %s",null!=e.value&&(t+=":%s")),t}},{push:"ssrcGroups",reg:/^ssrc-group:([\x21\x23\x24\x25\x26\x27\x2A\x2B\x2D\x2E\w]*) (.*)/,names:["semantics","ssrcs"],format:"ssrc-group:%s %s"},{name:"msidSemantic",reg:/^msid-semantic:\s?(\w*) (\S*)/,names:["semantic","token"],format:"msid-semantic: %s %s"},{push:"groups",reg:/^group:(\w*) (.*)/,names:["type","mids"],format:"group:%s %s"},{name:"rtcpMux",reg:/^(rtcp-mux)/},{name:"rtcpRsize",reg:/^(rtcp-rsize)/},{name:"sctpmap",reg:/^sctpmap:([\w_/]*) (\S*)(?: (\S*))?/,names:["sctpmapNumber","app","maxMessageSize"],format:function(e){return null!=e.maxMessageSize?"sctpmap:%s %s %s":"sctpmap:%s %s"}},{name:"xGoogleFlag",reg:/^x-google-flag:([^\s]*)/,format:"x-google-flag:%s"},{push:"rids",reg:/^rid:([\d\w]+) (\w+)(?: ([\S| ]*))?/,names:["id","direction","params"],format:function(e){return e.params?"rid:%s %s %s":"rid:%s %s"}},{push:"imageattrs",reg:new RegExp("^imageattr:(\\d+|\\*)[\\s\\t]+(send|recv)[\\s\\t]+(\\*|\\[\\S+\\](?:[\\s\\t]+\\[\\S+\\])*)(?:[\\s\\t]+(recv|send)[\\s\\t]+(\\*|\\[\\S+\\](?:[\\s\\t]+\\[\\S+\\])*))?"),names:["pt","dir1","attrs1","dir2","attrs2"],format:function(e){return"imageattr:%s %s %s"+(e.dir2?" %s %s":"")}},{name:"simulcast",reg:new RegExp("^simulcast:(send|recv) ([a-zA-Z0-9\\-_~;,]+)(?:\\s?(send|recv) ([a-zA-Z0-9\\-_~;,]+))?$"),names:["dir1","list1","dir2","list2"],format:function(e){return"simulcast:%s %s"+(e.dir2?" %s %s":"")}},{name:"simulcast_03",reg:/^simulcast:[\s\t]+([\S+\s\t]+)$/,names:["value"],format:"simulcast: %s"},{name:"framerate",reg:/^framerate:(\d+(?:$|\.\d+))/,format:"framerate:%s"},{name:"sourceFilter",reg:/^source-filter: *(excl|incl) (\S*) (IP4|IP6|\*) (\S*) (.*)/,names:["filterMode","netType","addressTypes","destAddress","srcList"],format:"source-filter: %s %s %s %s %s"},{name:"bundleOnly",reg:/^(bundle-only)/},{name:"label",reg:/^label:(.+)/,format:"label:%s"},{name:"sctpPort",reg:/^sctp-port:(\d+)$/,format:"sctp-port:%s"},{name:"maxMessageSize",reg:/^max-message-size:(\d+)$/,format:"max-message-size:%s"},{push:"tsRefClocks",reg:/^ts-refclk:([^\s=]*)(?:=(\S*))?/,names:["clksrc","clksrcExt"],format:function(e){return"ts-refclk:%s"+(null!=e.clksrcExt?"=%s":"")}},{name:"mediaClk",reg:/^mediaclk:(?:id=(\S*))? *([^\s=]*)(?:=(\S*))?(?: *rate=(\d+)\/(\d+))?/,names:["id","mediaClockName","mediaClockValue","rateNumerator","rateDenominator"],format:function(e){var t="mediaclk:";return t+=null!=e.id?"id=%s %s":"%v%s",t+=null!=e.mediaClockValue?"=%s":"",t+=null!=e.rateNumerator?" rate=%s":"",t+=null!=e.rateDenominator?"/%s":""}},{name:"keywords",reg:/^keywds:(.+)$/,format:"keywds:%s"},{name:"content",reg:/^content:(.+)/,format:"content:%s"},{name:"bfcpFloorCtrl",reg:/^floorctrl:(c-only|s-only|c-s)/,format:"floorctrl:%s"},{name:"bfcpConfId",reg:/^confid:(\d+)/,format:"confid:%s"},{name:"bfcpUserId",reg:/^userid:(\d+)/,format:"userid:%s"},{name:"bfcpFloorId",reg:/^floorid:(.+) (?:m-stream|mstrm):(.+)/,names:["id","mStream"],format:"floorid:%s mstrm:%s"},{push:"invalid",names:["value"]}]};return Object.keys(e).forEach(function(t){e[t].forEach(function(e){e.reg||(e.reg=/(.*)/),e.format||(e.format="%s")})}),Ki.exports}function requireParser(){return Bi||(Bi=1,function(e){var toIntIfInt=function(e){return String(Number(e))===e?Number(e):e},parseReg=function(e,t,i){var n=e.name&&e.names;e.push&&!t[e.push]?t[e.push]=[]:n&&!t[e.name]&&(t[e.name]={});var s=e.push?{}:n?t[e.name]:t;!function(e,t,i,n){if(n&&!i)t[n]=toIntIfInt(e[1]);else for(var s=0;s<i.length;s+=1)null!=e[s+1]&&(t[i[s]]=toIntIfInt(e[s+1]))}(i.match(e.reg),s,e.names,e.name),e.push&&t[e.push].push(s)},t=requireGrammar(),i=RegExp.prototype.test.bind(/^([a-z])=(.*)/);e.parse=function(e){var n={},s=[],a=n;return e.split(/(\r\n|\r|\n)/).filter(i).forEach(function(e){var i=e[0],n=e.slice(2);"m"===i&&(s.push({rtp:[],fmtp:[]}),a=s[s.length-1]);for(var c=0;c<(t[i]||[]).length;c+=1){var l=t[i][c];if(l.reg.test(n))return parseReg(l,a,n)}}),n.media=s,n};var paramReducer=function(e,t){var i=t.split(/=(.+)/,2);return 2===i.length?e[i[0]]=toIntIfInt(i[1]):1===i.length&&t.length>1&&(e[i[0]]=void 0),e};e.parseParams=function(e){return e.split(/;\s?/).reduce(paramReducer,{})},e.parseFmtpConfig=e.parseParams,e.parsePayloads=function(e){return e.toString().split(" ").map(Number)},e.parseRemoteCandidates=function(e){for(var t=[],i=e.split(" ").map(toIntIfInt),n=0;n<i.length;n+=3)t.push({component:i[n],ip:i[n+1],port:i[n+2]});return t},e.parseImageAttributes=function(e){return e.split(" ").map(function(e){return e.substring(1,e.length-1).split(",").reduce(paramReducer,{})})},e.parseSimulcastStreamList=function(e){return e.split(";").map(function(e){return e.split(",").map(function(e){var t,i=!1;return"~"!==e[0]?t=toIntIfInt(e):(t=toIntIfInt(e.substring(1,e.length)),i=!0),{scid:t,paused:i}})})}}(Gi)),Gi}function requireWriter(){if(qi)return Vi;qi=1;var e=requireGrammar(),t=/%[sdv%]/g,format=function(e){var i=1,n=arguments,s=n.length;return e.replace(t,function(e){if(i>=s)return e;var t=n[i];switch(i+=1,e){case"%%":return"%";case"%s":return String(t);case"%d":return Number(t);case"%v":return""}})},makeLine=function(e,t,i){var n=[e+"="+(t.format instanceof Function?t.format(t.push?i:i[t.name]):t.format)];if(t.names)for(var s=0;s<t.names.length;s+=1){var a=t.names[s];t.name?n.push(i[t.name][a]):n.push(i[t.names[s]])}else n.push(i[t.name]);return format.apply(null,n)},i=["v","o","s","i","u","e","p","c","b","t","r","z","a"],n=["i","c","b","a"];return Vi=function(t,s){s=s||{},null==t.version&&(t.version=0),null==t.name&&(t.name=" "),t.media.forEach(function(e){null==e.payloads&&(e.payloads="")});var a=s.outerOrder||i,c=s.innerOrder||n,l=[];return a.forEach(function(i){e[i].forEach(function(e){e.name in t&&null!=t[e.name]?l.push(makeLine(i,e,t)):e.push in t&&null!=t[e.push]&&t[e.push].forEach(function(t){l.push(makeLine(i,e,t))})})}),t.media.forEach(function(t){l.push(makeLine("m",e.m[0],t)),c.forEach(function(i){e[i].forEach(function(e){e.name in t&&null!=t[e.name]?l.push(makeLine(i,e,t)):e.push in t&&null!=t[e.push]&&t[e.push].forEach(function(t){l.push(makeLine(i,e,t))})})})}),l.join("\r\n")+"\r\n"},Vi}var Ji=function(){if(Hi)return Wi;Hi=1;var e=requireParser(),t=requireWriter(),i=requireGrammar();return Wi.grammar=i,Wi.write=t,Wi.parse=e.parse,Wi.parseParams=e.parseParams,Wi.parseFmtpConfig=e.parseFmtpConfig,Wi.parsePayloads=e.parsePayloads,Wi.parseRemoteCandidates=e.parseRemoteCandidates,Wi.parseImageAttributes=e.parseImageAttributes,Wi.parseSimulcastStreamList=e.parseSimulcastStreamList,Wi}();function r(e,t,i){var n,s,a;void 0===t&&(t=50),void 0===i&&(i={});var c=null!=(n=i.isImmediate)&&n,l=null!=(s=i.callback)&&s,u=i.maxWait,h=Date.now(),p=[];function f(){if(void 0!==u){var e=Date.now()-h;if(e+t>=u)return u-e}return t}var d=function(){var t=[].slice.call(arguments),i=this;return new Promise(function(n,s){var u=c&&void 0===a;if(void 0!==a&&clearTimeout(a),a=setTimeout(function(){if(a=void 0,h=Date.now(),!c){var n=e.apply(i,t);l&&l(n),p.forEach(function(e){return(0,e.resolve)(n)}),p=[]}},f()),u){var m=e.apply(i,t);return l&&l(m),n(m)}p.push({resolve:n,reject:s})})};return d.cancel=function(e){void 0!==a&&clearTimeout(a),p.forEach(function(t){return(0,t.reject)(e)}),p=[]},d}const zi="negotiationStarted",Qi="negotiationComplete",Yi="rtpVideoPayloadTypes";class PCTransport extends Jt.EventEmitter{get pc(){return this._pc||(this._pc=this.createPC()),this._pc}constructor(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};var i;super(),this.log=Bt,this.ddExtID=0,this.latestOfferId=0,this.pendingCandidates=[],this.restartingIce=!1,this.renegotiate=!1,this.trackBitrates=[],this.remoteStereoMids=[],this.remoteNackMids=[],this.negotiate=r(e=>__awaiter(this,void 0,void 0,function*(){this.emit(zi);try{yield this.createAndSendOffer()}catch(t){if(!e)throw t;e(t)}}),20),this.close=()=>{this._pc&&(this._pc.close(),this._pc.onconnectionstatechange=null,this._pc.oniceconnectionstatechange=null,this._pc.onicegatheringstatechange=null,this._pc.ondatachannel=null,this._pc.onnegotiationneeded=null,this._pc.onsignalingstatechange=null,this._pc.onicecandidate=null,this._pc.ondatachannel=null,this._pc.ontrack=null,this._pc.onconnectionstatechange=null,this._pc.oniceconnectionstatechange=null,this._pc=null)},this.log=getLogger(null!==(i=t.loggerName)&&void 0!==i?i:Ft.PCTransport),this.loggerOptions=t,this.config=e,this._pc=this.createPC(),this.offerLock=new _}createPC(){const e=new RTCPeerConnection(this.config);return e.onicecandidate=e=>{var t;e.candidate&&(null===(t=this.onIceCandidate)||void 0===t||t.call(this,e.candidate))},e.onicecandidateerror=e=>{var t;null===(t=this.onIceCandidateError)||void 0===t||t.call(this,e)},e.oniceconnectionstatechange=()=>{var t;null===(t=this.onIceConnectionStateChange)||void 0===t||t.call(this,e.iceConnectionState)},e.onsignalingstatechange=()=>{var t;null===(t=this.onSignalingStatechange)||void 0===t||t.call(this,e.signalingState)},e.onconnectionstatechange=()=>{var t;null===(t=this.onConnectionStateChange)||void 0===t||t.call(this,e.connectionState)},e.ondatachannel=e=>{var t;null===(t=this.onDataChannel)||void 0===t||t.call(this,e)},e.ontrack=e=>{var t;null===(t=this.onTrack)||void 0===t||t.call(this,e)},e}get logContext(){var e,t;return Object.assign({},null===(t=(e=this.loggerOptions).loggerContextCb)||void 0===t?void 0:t.call(e))}get isICEConnected(){return null!==this._pc&&("connected"===this.pc.iceConnectionState||"completed"===this.pc.iceConnectionState)}addIceCandidate(e){return __awaiter(this,void 0,void 0,function*(){if(this.pc.remoteDescription&&!this.restartingIce)return this.pc.addIceCandidate(e);this.pendingCandidates.push(e)})}setRemoteDescription(e,t){return __awaiter(this,void 0,void 0,function*(){var i;if("answer"===e.type&&this.latestOfferId>0&&t>0&&t!==this.latestOfferId)return this.log.warn("ignoring answer for old offer",Object.assign(Object.assign({},this.logContext),{offerId:t,latestOfferId:this.latestOfferId})),!1;let n;if("offer"===e.type){let{stereoMids:t,nackMids:i}=function(e){var t;const i=[],n=[],s=Ji.parse(null!==(t=e.sdp)&&void 0!==t?t:"");let a=0;return s.media.forEach(e=>{var t;const s=getMidString(e.mid);"audio"===e.type&&(e.rtp.some(e=>"opus"===e.codec&&(a=e.payload,!0)),(null===(t=e.rtcpFb)||void 0===t?void 0:t.some(e=>e.payload===a&&"nack"===e.type))&&n.push(s),e.fmtp.some(e=>e.payload===a&&(e.config.includes("sprop-stereo=1")&&i.push(s),!0)))}),{stereoMids:i,nackMids:n}}(e);this.remoteStereoMids=t,this.remoteNackMids=i}else if("answer"===e.type){const t=Ji.parse(null!==(i=e.sdp)&&void 0!==i?i:"");t.media.forEach(e=>{const t=getMidString(e.mid);"audio"===e.type&&this.trackBitrates.some(i=>{if(!i.transceiver||t!=i.transceiver.mid)return!1;let n=0;if(e.rtp.some(e=>e.codec.toUpperCase()===i.codec.toUpperCase()&&(n=e.payload,!0)),0===n)return!0;let s=!1;for(const t of e.fmtp)if(t.payload===n){t.config=t.config.split(";").filter(e=>!e.includes("maxaveragebitrate")).join(";"),i.maxbr>0&&(t.config+=";maxaveragebitrate=".concat(1e3*i.maxbr)),s=!0;break}return s||i.maxbr>0&&e.fmtp.push({payload:n,config:"maxaveragebitrate=".concat(1e3*i.maxbr)}),!0})}),n=Ji.write(t)}if(yield this.setMungedSDP(e,n,!0),this.pendingCandidates.forEach(e=>{this.pc.addIceCandidate(e)}),this.pendingCandidates=[],this.restartingIce=!1,this.renegotiate)this.renegotiate=!1,yield this.createAndSendOffer();else if("answer"===e.type&&(this.emit(Qi),e.sdp)){Ji.parse(e.sdp).media.forEach(e=>{"video"===e.type&&this.emit(Yi,e.rtp)})}return!0})}createAndSendOffer(e){return __awaiter(this,void 0,void 0,function*(){var t;const i=yield this.offerLock.lock();try{if(void 0===this.onOffer)return;if((null==e?void 0:e.iceRestart)&&(this.log.debug("restarting ICE",this.logContext),this.restartingIce=!0),this._pc&&"have-local-offer"===this._pc.signalingState){const t=this._pc.remoteDescription;if(!(null==e?void 0:e.iceRestart)||!t)return void(this.renegotiate=!0);yield this._pc.setRemoteDescription(t)}else if(!this._pc||"closed"===this._pc.signalingState)return void this.log.warn("could not createOffer with closed peer connection",this.logContext);this.log.debug("starting to negotiate",this.logContext);const i=this.latestOfferId+1;this.latestOfferId=i;const n=yield this.pc.createOffer(e);this.log.debug("original offer",Object.assign({sdp:n.sdp},this.logContext));const s=Ji.parse(null!==(t=n.sdp)&&void 0!==t?t:"");if(s.media.forEach(e=>{ensureIPAddrMatchVersion(e),"audio"===e.type?ensureAudioNackAndStereo(e,["all"],[]):"video"===e.type&&this.trackBitrates.some(t=>{if(!e.msid||!t.cid||!e.msid.includes(t.cid))return!1;let i=0;if(e.rtp.some(e=>e.codec.toUpperCase()===t.codec.toUpperCase()&&(i=e.payload,!0)),0===i)return!0;if(isSVCCodec(t.codec)&&!isSafari()&&this.ensureVideoDDExtensionForSVC(e,s),!isSVCCodec(t.codec))return!0;const n=Math.round(.7*t.maxbr);for(const t of e.fmtp)if(t.payload===i){t.config.includes("x-google-start-bitrate")||(t.config+=";x-google-start-bitrate=".concat(n));break}return!0})}),this.latestOfferId>i)return void this.log.warn("latestOfferId mismatch",Object.assign(Object.assign({},this.logContext),{latestOfferId:this.latestOfferId,offerId:i}));yield this.setMungedSDP(n,Ji.write(s)),this.onOffer(n,this.latestOfferId)}finally{i()}})}createAndSetAnswer(){return __awaiter(this,void 0,void 0,function*(){var e;const t=yield this.pc.createAnswer(),i=Ji.parse(null!==(e=t.sdp)&&void 0!==e?e:"");return i.media.forEach(e=>{ensureIPAddrMatchVersion(e),"audio"===e.type&&ensureAudioNackAndStereo(e,this.remoteStereoMids,this.remoteNackMids)}),yield this.setMungedSDP(t,Ji.write(i)),t})}createDataChannel(e,t){return this.pc.createDataChannel(e,t)}addTransceiver(e,t){return this.pc.addTransceiver(e,t)}addTransceiverOfKind(e,t){return this.pc.addTransceiver(e,t)}addTrack(e){if(!this._pc)throw new UnexpectedConnectionState("PC closed, cannot add track");return this._pc.addTrack(e)}setTrackCodecBitrate(e){this.trackBitrates.push(e)}setConfiguration(e){var t;if(!this._pc)throw new UnexpectedConnectionState("PC closed, cannot configure");return null===(t=this._pc)||void 0===t?void 0:t.setConfiguration(e)}canRemoveTrack(){var e;return!!(null===(e=this._pc)||void 0===e?void 0:e.removeTrack)}removeTrack(e){var t;return null===(t=this._pc)||void 0===t?void 0:t.removeTrack(e)}getConnectionState(){var e,t;return null!==(t=null===(e=this._pc)||void 0===e?void 0:e.connectionState)&&void 0!==t?t:"closed"}getICEConnectionState(){var e,t;return null!==(t=null===(e=this._pc)||void 0===e?void 0:e.iceConnectionState)&&void 0!==t?t:"closed"}getSignallingState(){var e,t;return null!==(t=null===(e=this._pc)||void 0===e?void 0:e.signalingState)&&void 0!==t?t:"closed"}getTransceivers(){var e,t;return null!==(t=null===(e=this._pc)||void 0===e?void 0:e.getTransceivers())&&void 0!==t?t:[]}getSenders(){var e,t;return null!==(t=null===(e=this._pc)||void 0===e?void 0:e.getSenders())&&void 0!==t?t:[]}getLocalDescription(){var e;return null===(e=this._pc)||void 0===e?void 0:e.localDescription}getRemoteDescription(){var e;return null===(e=this.pc)||void 0===e?void 0:e.remoteDescription}getStats(){return this.pc.getStats()}getConnectedAddress(){return __awaiter(this,void 0,void 0,function*(){var e;if(!this._pc)return;let t="";const i=new Map,n=new Map;if((yield this._pc.getStats()).forEach(e=>{switch(e.type){case"transport":t=e.selectedCandidatePairId;break;case"candidate-pair":""===t&&e.selected&&(t=e.id),i.set(e.id,e);break;case"remote-candidate":n.set(e.id,"".concat(e.address,":").concat(e.port))}}),""===t)return;const s=null===(e=i.get(t))||void 0===e?void 0:e.remoteCandidateId;return void 0!==s?n.get(s):void 0})}setMungedSDP(e,t,i){return __awaiter(this,void 0,void 0,function*(){if(t){const n=e.sdp;e.sdp=t;try{return this.log.debug("setting munged ".concat(i?"remote":"local"," description"),this.logContext),void(i?yield this.pc.setRemoteDescription(e):yield this.pc.setLocalDescription(e))}catch(i){this.log.warn("not able to set ".concat(e.type,", falling back to unmodified sdp"),Object.assign(Object.assign({},this.logContext),{error:i,sdp:t})),e.sdp=n}}try{i?yield this.pc.setRemoteDescription(e):yield this.pc.setLocalDescription(e)}catch(t){let n="unknown error";t instanceof Error?n=t.message:"string"==typeof t&&(n=t);const s={error:n,sdp:e.sdp};throw!i&&this.pc.remoteDescription&&(s.remoteSdp=this.pc.remoteDescription),this.log.error("unable to set ".concat(e.type),Object.assign(Object.assign({},this.logContext),{fields:s})),new NegotiationError(n)}})}ensureVideoDDExtensionForSVC(e,t){var i,n;if(!(null===(i=e.ext)||void 0===i?void 0:i.some(e=>e.uri===wi))){if(0===this.ddExtID){let e=0;t.media.forEach(t=>{var i;"video"===t.type&&(null===(i=t.ext)||void 0===i||i.forEach(t=>{t.value>e&&(e=t.value)}))}),this.ddExtID=e+1}null===(n=e.ext)||void 0===n||n.push({value:this.ddExtID,uri:wi})}}}function ensureAudioNackAndStereo(e,t,i){const n=getMidString(e.mid);let s=0;e.rtp.some(e=>"opus"===e.codec&&(s=e.payload,!0)),s>0&&(e.rtcpFb||(e.rtcpFb=[]),i.includes(n)&&!e.rtcpFb.some(e=>e.payload===s&&"nack"===e.type)&&e.rtcpFb.push({payload:s,type:"nack"}),(t.includes(n)||1===t.length&&"all"===t[0])&&e.fmtp.some(e=>e.payload===s&&(e.config.includes("stereo=1")||(e.config+=";stereo=1"),!0)))}function ensureIPAddrMatchVersion(e){if(e.connection){const t=e.connection.ip.indexOf(":")>=0;(4===e.connection.version&&t||6===e.connection.version&&!t)&&(e.connection.ip="0.0.0.0",e.connection.version=4)}}function getMidString(e){return"number"==typeof e?e.toFixed(0):e}const $i="vp8",Xi={audioPreset:bi.music,dtx:!0,red:!0,forceStereo:!1,simulcast:!0,screenShareEncoding:Ci.h1080fps15.encoding,stopMicTrackOnMute:!1,videoCodec:$i,backupCodec:!0,preConnectBuffer:!1},Zi={deviceId:{ideal:"default"},autoGainControl:!0,echoCancellation:!0,noiseSuppression:!0,voiceIsolation:!0},en={deviceId:{ideal:"default"},resolution:yi.h720.resolution},tn={adaptiveStream:!1,dynacast:!1,stopLocalTrackOnUnpublish:!0,reconnectPolicy:new class{constructor(e){this._retryDelays=void 0!==e?[...e]:Wt}nextRetryDelayInMs(e){if(e.retryCount>=this._retryDelays.length)return null;const t=this._retryDelays[e.retryCount];return e.retryCount<=1?t:t+1e3*Math.random()}},disconnectOnPageLeave:!0,webAudioMix:!1,singlePeerConnection:!0},nn={autoSubscribe:!0,maxRetries:1,peerConnectionTimeout:15e3,websocketTimeout:15e3};var rn;!function(e){e[e.NEW=0]="NEW",e[e.CONNECTING=1]="CONNECTING",e[e.CONNECTED=2]="CONNECTED",e[e.FAILED=3]="FAILED",e[e.CLOSING=4]="CLOSING",e[e.CLOSED=5]="CLOSED"}(rn||(rn={}));class PCTransportManager{get needsPublisher(){return this.isPublisherConnectionRequired}get needsSubscriber(){return this.isSubscriberConnectionRequired}get currentState(){return this.state}get mode(){return this._mode}constructor(e,t,i){var n;this.peerConnectionTimeout=nn.peerConnectionTimeout,this.log=Bt,this.updateState=()=>{var e,t;const i=this.state,n=this.requiredTransports.map(e=>e.getConnectionState());n.every(e=>"connected"===e)?this.state=rn.CONNECTED:n.some(e=>"failed"===e)?this.state=rn.FAILED:n.some(e=>"connecting"===e)?this.state=rn.CONNECTING:n.every(e=>"closed"===e)?this.state=rn.CLOSED:n.some(e=>"closed"===e)?this.state=rn.CLOSING:n.every(e=>"new"===e)&&(this.state=rn.NEW),i!==this.state&&(this.log.debug("pc state change: from ".concat(rn[i]," to ").concat(rn[this.state]),this.logContext),null===(e=this.onStateChange)||void 0===e||e.call(this,this.state,this.publisher.getConnectionState(),null===(t=this.subscriber)||void 0===t?void 0:t.getConnectionState()))},this.log=getLogger(null!==(n=i.loggerName)&&void 0!==n?n:Ft.PCManager),this.loggerOptions=i,this.isPublisherConnectionRequired="subscriber-primary"!==t,this.isSubscriberConnectionRequired="subscriber-primary"===t,this.publisher=new PCTransport(e,i),this._mode=t,"publisher-only"!==t&&(this.subscriber=new PCTransport(e,i),this.subscriber.onConnectionStateChange=this.updateState,this.subscriber.onIceConnectionStateChange=this.updateState,this.subscriber.onSignalingStatechange=this.updateState,this.subscriber.onIceCandidate=e=>{var t;null===(t=this.onIceCandidate)||void 0===t||t.call(this,e,De.SUBSCRIBER)},this.subscriber.onDataChannel=e=>{var t;null===(t=this.onDataChannel)||void 0===t||t.call(this,e)},this.subscriber.onTrack=e=>{var t;null===(t=this.onTrack)||void 0===t||t.call(this,e)}),this.publisher.onConnectionStateChange=this.updateState,this.publisher.onIceConnectionStateChange=this.updateState,this.publisher.onSignalingStatechange=this.updateState,this.publisher.onIceCandidate=e=>{var t;null===(t=this.onIceCandidate)||void 0===t||t.call(this,e,De.PUBLISHER)},this.publisher.onTrack=e=>{var t;null===(t=this.onTrack)||void 0===t||t.call(this,e)},this.publisher.onOffer=(e,t)=>{var i;null===(i=this.onPublisherOffer)||void 0===i||i.call(this,e,t)},this.state=rn.NEW,this.connectionLock=new _,this.remoteOfferLock=new _}get logContext(){var e,t;return Object.assign({},null===(t=(e=this.loggerOptions).loggerContextCb)||void 0===t?void 0:t.call(e))}requirePublisher(){let e=!(arguments.length>0&&void 0!==arguments[0])||arguments[0];this.isPublisherConnectionRequired=e,this.updateState()}createAndSendPublisherOffer(e){return this.publisher.createAndSendOffer(e)}setPublisherAnswer(e,t){return this.publisher.setRemoteDescription(e,t)}removeTrack(e){return this.publisher.removeTrack(e)}close(){return __awaiter(this,void 0,void 0,function*(){var e;if(this.publisher&&"closed"!==this.publisher.getSignallingState()){const e=this.publisher;for(const t of e.getSenders())try{e.canRemoveTrack()&&e.removeTrack(t)}catch(e){this.log.warn("could not removeTrack",Object.assign(Object.assign({},this.logContext),{error:e}))}}yield Promise.all([this.publisher.close(),null===(e=this.subscriber)||void 0===e?void 0:e.close()]),this.updateState()})}triggerIceRestart(){return __awaiter(this,void 0,void 0,function*(){this.subscriber&&(this.subscriber.restartingIce=!0),this.needsPublisher&&(yield this.createAndSendPublisherOffer({iceRestart:!0}))})}addIceCandidate(e,t){return __awaiter(this,void 0,void 0,function*(){var i;t===De.PUBLISHER?yield this.publisher.addIceCandidate(e):yield null===(i=this.subscriber)||void 0===i?void 0:i.addIceCandidate(e)})}createSubscriberAnswerFromOffer(e,t){return __awaiter(this,void 0,void 0,function*(){var i,n,s;this.log.debug("received server offer",Object.assign(Object.assign({},this.logContext),{RTCSdpType:e.type,sdp:e.sdp,signalingState:null===(i=this.subscriber)||void 0===i?void 0:i.getSignallingState().toString()}));const a=yield this.remoteOfferLock.lock();try{if(!(yield null===(n=this.subscriber)||void 0===n?void 0:n.setRemoteDescription(e,t)))return;return yield null===(s=this.subscriber)||void 0===s?void 0:s.createAndSetAnswer()}finally{a()}})}updateConfiguration(e,t){var i;this.publisher.setConfiguration(e),null===(i=this.subscriber)||void 0===i||i.setConfiguration(e),t&&this.triggerIceRestart()}ensurePCTransportConnection(e,t){return __awaiter(this,void 0,void 0,function*(){var i;const n=yield this.connectionLock.lock();try{this.isPublisherConnectionRequired&&"connected"!==this.publisher.getConnectionState()&&"connecting"!==this.publisher.getConnectionState()&&(this.log.debug("negotiation required, start negotiating",this.logContext),this.publisher.negotiate()),yield Promise.all(null===(i=this.requiredTransports)||void 0===i?void 0:i.map(i=>this.ensureTransportConnected(i,e,t)))}finally{n()}})}negotiate(e){return __awaiter(this,void 0,void 0,function*(){return new TypedPromise((t,i)=>__awaiter(this,void 0,void 0,function*(){const n=setTimeout(()=>{i(new NegotiationError("negotiation timed out"))},this.peerConnectionTimeout);e.signal.addEventListener("abort",()=>{clearTimeout(n),i(new NegotiationError("negotiation aborted"))}),this.publisher.once(zi,()=>{e.signal.aborted||this.publisher.once(Qi,()=>{clearTimeout(n),t()})}),yield this.publisher.negotiate(e=>{clearTimeout(n),e instanceof Error?i(e):i(new Error(String(e)))})}))})}addPublisherTransceiver(e,t){return this.publisher.addTransceiver(e,t)}addPublisherTransceiverOfKind(e,t){return this.publisher.addTransceiverOfKind(e,t)}getMidForReceiver(e){const t=(this.subscriber?this.subscriber.getTransceivers():this.publisher.getTransceivers()).find(t=>t.receiver===e);return null==t?void 0:t.mid}addPublisherTrack(e){return this.publisher.addTrack(e)}createPublisherDataChannel(e,t){return this.publisher.createDataChannel(e,t)}getConnectedAddress(e){return e===De.PUBLISHER||e===De.SUBSCRIBER?this.publisher.getConnectedAddress():this.requiredTransports[0].getConnectedAddress()}get requiredTransports(){const e=[];return this.isPublisherConnectionRequired&&e.push(this.publisher),this.isSubscriberConnectionRequired&&this.subscriber&&e.push(this.subscriber),e}ensureTransportConnected(e,t){return __awaiter(this,arguments,void 0,function(e,t){var i=this;let n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:this.peerConnectionTimeout;return function*(){if("connected"!==e.getConnectionState())return new Promise((e,s)=>__awaiter(i,void 0,void 0,function*(){const abortHandler=()=>{this.log.warn("abort transport connection",this.logContext),CriticalTimers.clearTimeout(i),s(ConnectionError.cancelled("room connection has been cancelled"))};(null==t?void 0:t.signal.aborted)&&abortHandler(),null==t||t.signal.addEventListener("abort",abortHandler);const i=CriticalTimers.setTimeout(()=>{null==t||t.signal.removeEventListener("abort",abortHandler),s(ConnectionError.internal("could not establish pc connection"))},n);for(;this.state!==rn.CONNECTED;)if(yield sleep(50),null==t?void 0:t.signal.aborted)return void s(ConnectionError.cancelled("room connection has been cancelled"));CriticalTimers.clearTimeout(i),null==t||t.signal.removeEventListener("abort",abortHandler),e()}))}()})}}class RegionUrlProvider{static fetchRegionSettings(e,t,i){return __awaiter(this,void 0,void 0,function*(){const n=yield RegionUrlProvider.fetchLock.lock();try{const n=yield fetch("".concat(function(e){return"".concat(e.protocol.replace("ws","http"),"//").concat(e.host,"/settings")}(e),"/regions"),{headers:{authorization:"Bearer ".concat(t)},signal:i});if(n.ok){const e=function(e){var t;const i=e.get("Cache-Control");if(i){const e=null===(t=i.match(/(?:^|[,\s])max-age=(\d+)/))||void 0===t?void 0:t[1];if(e)return parseInt(e,10)}}(n.headers),t=e?1e3*e:5e3;return{regionSettings:yield n.json(),updatedAtInMs:Date.now(),maxAgeInMs:t}}throw 401===n.status?ConnectionError.notAllowed("Could not fetch region settings: ".concat(n.statusText),n.status):ConnectionError.internal("Could not fetch region settings: ".concat(n.statusText))}catch(e){throw e instanceof ConnectionError?e:(null==i?void 0:i.aborted)?ConnectionError.cancelled("Region fetching was aborted"):ConnectionError.serverUnreachable("Could not fetch region settings, ".concat(e instanceof Error?"".concat(e.name,": ").concat(e.message):e))}finally{n()}})}static scheduleRefetch(e,t,i){return __awaiter(this,void 0,void 0,function*(){const n=RegionUrlProvider.settingsTimeouts.get(e.hostname);clearTimeout(n),RegionUrlProvider.settingsTimeouts.set(e.hostname,setTimeout(()=>__awaiter(this,void 0,void 0,function*(){try{const i=yield RegionUrlProvider.fetchRegionSettings(e,t);RegionUrlProvider.updateCachedRegionSettings(e,t,i)}catch(n){if(n instanceof ConnectionError&&n.reason===di.NotAllowed)return void Bt.debug("token is not valid, cancelling auto region refresh");Bt.debug("auto refetching of region settings failed",{error:n}),RegionUrlProvider.scheduleRefetch(e,t,i)}}),i))})}static updateCachedRegionSettings(e,t,i){RegionUrlProvider.cache.set(e.hostname,i),RegionUrlProvider.scheduleRefetch(e,t,i.maxAgeInMs)}static stopRefetch(e){const t=RegionUrlProvider.settingsTimeouts.get(e);t&&(clearTimeout(t),RegionUrlProvider.settingsTimeouts.delete(e))}static scheduleCleanup(e){let t=RegionUrlProvider.connectionTrackers.get(e);t&&(t.cleanupTimeout&&clearTimeout(t.cleanupTimeout),t.cleanupTimeout=setTimeout(()=>{const t=RegionUrlProvider.connectionTrackers.get(e);t&&0===t.connectionCount&&(Bt.debug("stopping region refetch after disconnect delay",{hostname:e}),RegionUrlProvider.stopRefetch(e)),t&&(t.cleanupTimeout=void 0)},3e4))}static cancelCleanup(e){const t=RegionUrlProvider.connectionTrackers.get(e);(null==t?void 0:t.cleanupTimeout)&&(clearTimeout(t.cleanupTimeout),t.cleanupTimeout=void 0)}notifyConnected(){const e=this.serverUrl.hostname;let t=RegionUrlProvider.connectionTrackers.get(e);t||(t={connectionCount:0},RegionUrlProvider.connectionTrackers.set(e,t)),t.connectionCount++,RegionUrlProvider.cancelCleanup(e)}notifyDisconnected(){const e=this.serverUrl.hostname,t=RegionUrlProvider.connectionTrackers.get(e);t&&(t.connectionCount=Math.max(0,t.connectionCount-1),0===t.connectionCount&&RegionUrlProvider.scheduleCleanup(e))}constructor(e,t){this.attemptedRegions=[],this.serverUrl=new URL(e),this.token=t}updateToken(e){this.token=e}isCloud(){return isCloud(this.serverUrl)}getServerUrl(){return this.serverUrl}fetchRegionSettings(e){return __awaiter(this,void 0,void 0,function*(){return RegionUrlProvider.fetchRegionSettings(this.serverUrl,this.token,e)})}getNextBestRegionUrl(e){return __awaiter(this,void 0,void 0,function*(){if(!this.isCloud())throw Error("region availability is only supported for LiveKit Cloud domains");let t=RegionUrlProvider.cache.get(this.serverUrl.hostname);(!t||Date.now()-t.updatedAtInMs>t.maxAgeInMs)&&(t=yield this.fetchRegionSettings(e),RegionUrlProvider.updateCachedRegionSettings(this.serverUrl,this.token,t));const i=t.regionSettings.regions.filter(e=>!this.attemptedRegions.find(t=>t.url===e.url));if(i.length>0){const e=i[0];return this.attemptedRegions.push(e),Bt.debug("next region: ".concat(e.region)),e.url}return null})}resetAttempts(){this.attemptedRegions=[]}setServerReportedRegions(e){RegionUrlProvider.updateCachedRegionSettings(this.serverUrl,this.token,e)}}RegionUrlProvider.cache=new Map,RegionUrlProvider.settingsTimeouts=new Map,RegionUrlProvider.connectionTrackers=new Map,RegionUrlProvider.fetchLock=new _;class RpcError extends Error{constructor(e,t,i){super(t),this.code=e,this.message=truncateBytes(t,RpcError.MAX_MESSAGE_BYTES),this.data=i?truncateBytes(i,RpcError.MAX_DATA_BYTES):void 0}static fromProto(e){return new RpcError(e.code,e.message,e.data)}toProto(){return new me({code:this.code,message:this.message,data:this.data})}static builtIn(e,t){return new RpcError(RpcError.ErrorCode[e],RpcError.ErrorMessage[e],t)}}RpcError.MAX_MESSAGE_BYTES=256,RpcError.MAX_DATA_BYTES=15360,RpcError.ErrorCode={APPLICATION_ERROR:1500,CONNECTION_TIMEOUT:1501,RESPONSE_TIMEOUT:1502,RECIPIENT_DISCONNECTED:1503,RESPONSE_PAYLOAD_TOO_LARGE:1504,SEND_FAILED:1505,UNSUPPORTED_METHOD:1400,RECIPIENT_NOT_FOUND:1401,REQUEST_PAYLOAD_TOO_LARGE:1402,UNSUPPORTED_SERVER:1403,UNSUPPORTED_VERSION:1404},RpcError.ErrorMessage={APPLICATION_ERROR:"Application error in method handler",CONNECTION_TIMEOUT:"Connection timeout",RESPONSE_TIMEOUT:"Response timeout",RECIPIENT_DISCONNECTED:"Recipient disconnected",RESPONSE_PAYLOAD_TOO_LARGE:"Response payload too large",SEND_FAILED:"Failed to send",UNSUPPORTED_METHOD:"Method not supported at destination",RECIPIENT_NOT_FOUND:"Recipient not found",REQUEST_PAYLOAD_TOO_LARGE:"Request payload too large",UNSUPPORTED_SERVER:"RPC not supported by server",UNSUPPORTED_VERSION:"Unsupported RPC version"};function byteLength(e){return(new TextEncoder).encode(e).length}function truncateBytes(e,t){if(byteLength(e)<=t)return e;let i=0,n=e.length;const s=new TextEncoder;for(;i<n;){const a=Math.floor((i+n+1)/2);s.encode(e.slice(0,a)).length<=t?i=a:n=a-1}return e.slice(0,i)}const sn=2e3;function computeBitrate(e,t){if(!t)return 0;let i,n;return"bytesReceived"in e?(i=e.bytesReceived,n=t.bytesReceived):"bytesSent"in e&&(i=e.bytesSent,n=t.bytesSent),void 0===i||void 0===n||void 0===e.timestamp||void 0===t.timestamp?0:8*(i-n)*1e3/(e.timestamp-t.timestamp)}const an="undefined"!=typeof MediaRecorder;const on=an?MediaRecorder:class{constructor(){throw new Error("MediaRecorder is not available in this environment")}};class LocalTrackRecorder extends on{constructor(e,t){if(!an)throw new Error("MediaRecorder is not available in this environment");let i,n;super(new MediaStream([e.mediaStreamTrack]),t);const onStop=()=>{this.removeEventListener("dataavailable",i),this.removeEventListener("stop",onStop),this.removeEventListener("error",onError),null==n||n.close(),n=void 0},onError=e=>{null==n||n.error(e),this.removeEventListener("dataavailable",i),this.removeEventListener("stop",onStop),this.removeEventListener("error",onError),n=void 0};this.byteStream=new ReadableStream({start:e=>{n=e,i=t=>__awaiter(this,void 0,void 0,function*(){let i;if(t.data.arrayBuffer){const e=yield t.data.arrayBuffer();i=new Uint8Array(e)}else{if(!t.data.byteArray)throw new Error("no data available!");i=t.data.byteArray}void 0!==n&&e.enqueue(i)}),this.addEventListener("dataavailable",i)},cancel:()=>{onStop()}}),this.addEventListener("stop",onStop),this.addEventListener("error",onError)}}class LocalTrack extends Track{get sender(){return this._sender}set sender(e){this._sender=e}get constraints(){return this._constraints}get hasPreConnectBuffer(){return!!this.localTrackRecorder}constructor(e,t,i){let n=arguments.length>3&&void 0!==arguments[3]&&arguments[3];super(e,t,arguments.length>4?arguments[4]:void 0),this.manuallyStopped=!1,this._isUpstreamPaused=!1,this.handleTrackMuteEvent=()=>this.debouncedTrackMuteHandler().catch(()=>this.log.debug("track mute bounce got cancelled by an unmute event",this.logContext)),this.debouncedTrackMuteHandler=r(()=>__awaiter(this,void 0,void 0,function*(){yield this.pauseUpstream()}),5e3),this.handleTrackUnmuteEvent=()=>__awaiter(this,void 0,void 0,function*(){this.debouncedTrackMuteHandler.cancel("unmute"),yield this.resumeUpstream()}),this.handleEnded=()=>{this.isInBackground&&(this.reacquireTrack=!0),this._mediaStreamTrack.removeEventListener("mute",this.handleTrackMuteEvent),this._mediaStreamTrack.removeEventListener("unmute",this.handleTrackUnmuteEvent),this.emit(gi.Ended,this)},this.reacquireTrack=!1,this.providedByUser=n,this.muteLock=new _,this.pauseUpstreamLock=new _,this.trackChangeLock=new _,this.trackChangeLock.lock().then(t=>__awaiter(this,void 0,void 0,function*(){try{yield this.setMediaStreamTrack(e,!0)}finally{t()}})),this._constraints=e.getConstraints(),i&&(this._constraints=i)}get id(){return this._mediaStreamTrack.id}get dimensions(){if(this.kind!==Track.Kind.Video)return;const{width:e,height:t}=this._mediaStreamTrack.getSettings();return e&&t?{width:e,height:t}:void 0}get isUpstreamPaused(){return this._isUpstreamPaused}get isUserProvided(){return this.providedByUser}get mediaStreamTrack(){var e,t;return null!==(t=null===(e=this.processor)||void 0===e?void 0:e.processedTrack)&&void 0!==t?t:this._mediaStreamTrack}get isLocal(){return!0}getSourceTrackSettings(){return this._mediaStreamTrack.getSettings()}setMediaStreamTrack(e,t){return __awaiter(this,void 0,void 0,function*(){var i;if(e===this._mediaStreamTrack&&!t)return;let n;if(this._mediaStreamTrack&&(this.attachedElements.forEach(e=>{detachTrack(this._mediaStreamTrack,e)}),this.debouncedTrackMuteHandler.cancel("new-track"),this._mediaStreamTrack.removeEventListener("ended",this.handleEnded),this._mediaStreamTrack.removeEventListener("mute",this.handleTrackMuteEvent),this._mediaStreamTrack.removeEventListener("unmute",this.handleTrackUnmuteEvent)),this.mediaStream=new MediaStream([e]),e&&(e.addEventListener("ended",this.handleEnded),e.addEventListener("mute",this.handleTrackMuteEvent),e.addEventListener("unmute",this.handleTrackUnmuteEvent),this._constraints=e.getConstraints()),this.processor&&e){if(this.log.debug("restarting processor",this.logContext),"unknown"===this.kind)throw TypeError("cannot set processor on track of unknown kind");this.processorElement&&(attachToElement(e,this.processorElement),this.processorElement.muted=!0),yield this.processor.restart({track:e,kind:this.kind,element:this.processorElement}),n=this.processor.processedTrack}this.sender&&"closed"!==(null===(i=this.sender.transport)||void 0===i?void 0:i.state)&&(yield this.sender.replaceTrack(null!=n?n:e)),this.providedByUser||this._mediaStreamTrack===e||this._mediaStreamTrack.stop(),this._mediaStreamTrack=e,e&&(this._mediaStreamTrack.enabled=!this.isMuted,yield this.resumeUpstream(),this.attachedElements.forEach(t=>{attachToElement(null!=n?n:e,t)}))})}waitForDimensions(){return __awaiter(this,arguments,void 0,function(){var e=this;let t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1e3;return function*(){var i;if(e.kind===Track.Kind.Audio)throw new Error("cannot get dimensions for audio tracks");"iOS"===(null===(i=getBrowser())||void 0===i?void 0:i.os)&&(yield sleep(10));const n=Date.now();for(;Date.now()-n<t;){const t=e.dimensions;if(t)return t;yield sleep(50)}throw new TrackInvalidError("unable to get track dimensions after timeout")}()})}setDeviceId(e){return __awaiter(this,void 0,void 0,function*(){return this._constraints.deviceId===e&&this._mediaStreamTrack.getSettings().deviceId===unwrapConstraint(e)||(this._constraints.deviceId=e,!!this.isMuted||(yield this.restartTrack(),unwrapConstraint(e)===this._mediaStreamTrack.getSettings().deviceId))})}getDeviceId(){return __awaiter(this,arguments,void 0,function(){var e=this;let t=!(arguments.length>0&&void 0!==arguments[0])||arguments[0];return function*(){if(e.source===Track.Source.ScreenShare)return;const{deviceId:i,groupId:n}=e._mediaStreamTrack.getSettings(),s=e.kind===Track.Kind.Audio?"audioinput":"videoinput";return t?DeviceManager.getInstance().normalizeDeviceId(s,i,n):i}()})}mute(){return __awaiter(this,void 0,void 0,function*(){return this.setTrackMuted(!0),this})}unmute(){return __awaiter(this,void 0,void 0,function*(){return this.setTrackMuted(!1),this})}replaceTrack(e,t){return __awaiter(this,void 0,void 0,function*(){const i=yield this.trackChangeLock.lock();try{if(!this.sender)throw new TrackInvalidError("unable to replace an unpublished track");let i,n;return"boolean"==typeof t?i=t:void 0!==t&&(i=t.userProvidedTrack,n=t.stopProcessor),this.providedByUser=null==i||i,this.log.debug("replace MediaStreamTrack",this.logContext),yield this.setMediaStreamTrack(e),n&&this.processor&&(yield this.internalStopProcessor()),this}finally{i()}})}restart(e){return __awaiter(this,void 0,void 0,function*(){this.manuallyStopped=!1;const t=yield this.trackChangeLock.lock();try{e||(e=this._constraints);const{deviceId:t,facingMode:i}=e,n=function(e,t){var i={};for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&t.indexOf(n)<0&&(i[n]=e[n]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols){var s=0;for(n=Object.getOwnPropertySymbols(e);s<n.length;s++)t.indexOf(n[s])<0&&Object.prototype.propertyIsEnumerable.call(e,n[s])&&(i[n[s]]=e[n[s]])}return i}(e,["deviceId","facingMode"]);this.log.debug("restarting track with constraints",Object.assign(Object.assign({},this.logContext),{constraints:e}));const s={audio:!1,video:!1};this.kind===Track.Kind.Video?s.video=!t&&!i||{deviceId:t,facingMode:i}:s.audio=!t||Object.assign({deviceId:t},n),this.attachedElements.forEach(e=>{detachTrack(this.mediaStreamTrack,e)}),this._mediaStreamTrack.removeEventListener("ended",this.handleEnded),this._mediaStreamTrack.stop();const a=(yield navigator.mediaDevices.getUserMedia(s)).getTracks()[0];return this.kind===Track.Kind.Video&&(yield a.applyConstraints(n)),a.addEventListener("ended",this.handleEnded),this.log.debug("re-acquired MediaStreamTrack",this.logContext),yield this.setMediaStreamTrack(a),this._constraints=e,this.emit(gi.Restarted,this),this.manuallyStopped&&(this.log.warn("track was stopped during a restart, stopping restarted track",this.logContext),this.stop()),this}finally{t()}})}setTrackMuted(e){this.log.debug("setting ".concat(this.kind," track ").concat(e?"muted":"unmuted"),this.logContext),this.isMuted===e&&this._mediaStreamTrack.enabled!==e||(this.isMuted=e,this._mediaStreamTrack.enabled=!e,this.emit(e?gi.Muted:gi.Unmuted,this))}get needsReAcquisition(){return"live"!==this._mediaStreamTrack.readyState||this._mediaStreamTrack.muted||!this._mediaStreamTrack.enabled||this.reacquireTrack}handleAppVisibilityChanged(){const e=Object.create(null,{handleAppVisibilityChanged:{get:()=>super.handleAppVisibilityChanged}});return __awaiter(this,void 0,void 0,function*(){yield e.handleAppVisibilityChanged.call(this),isMobile()&&(this.log.debug("visibility changed, is in Background: ".concat(this.isInBackground),this.logContext),this.isInBackground||!this.needsReAcquisition||this.isUserProvided||this.isMuted||(this.log.debug("track needs to be reacquired, restarting ".concat(this.source),this.logContext),yield this.restart(),this.reacquireTrack=!1))})}stop(){var e;this.manuallyStopped=!0,super.stop(),this._mediaStreamTrack.removeEventListener("ended",this.handleEnded),this._mediaStreamTrack.removeEventListener("mute",this.handleTrackMuteEvent),this._mediaStreamTrack.removeEventListener("unmute",this.handleTrackUnmuteEvent),null===(e=this.processor)||void 0===e||e.destroy(),this.processor=void 0}pauseUpstream(){return __awaiter(this,void 0,void 0,function*(){var e;const t=yield this.pauseUpstreamLock.lock();try{if(!0===this._isUpstreamPaused)return;if(!this.sender)return void this.log.warn("unable to pause upstream for an unpublished track",this.logContext);this._isUpstreamPaused=!0,this.emit(gi.UpstreamPaused,this);const t=getBrowser();if("Safari"===(null==t?void 0:t.name)&&compareVersions(t.version,"12.0")<0)throw new DeviceUnsupportedError("pauseUpstream is not supported on Safari < 12.");"closed"!==(null===(e=this.sender.transport)||void 0===e?void 0:e.state)&&(yield this.sender.replaceTrack(null))}finally{t()}})}resumeUpstream(){return __awaiter(this,void 0,void 0,function*(){var e;const t=yield this.pauseUpstreamLock.lock();try{if(!1===this._isUpstreamPaused)return;if(!this.sender)return void this.log.warn("unable to resume upstream for an unpublished track",this.logContext);this._isUpstreamPaused=!1,this.emit(gi.UpstreamResumed,this),"closed"!==(null===(e=this.sender.transport)||void 0===e?void 0:e.state)&&(yield this.sender.replaceTrack(this.mediaStreamTrack))}finally{t()}})}getRTCStatsReport(){return __awaiter(this,void 0,void 0,function*(){var e;if(!(null===(e=this.sender)||void 0===e?void 0:e.getStats))return;return yield this.sender.getStats()})}setProcessor(e){return __awaiter(this,arguments,void 0,function(e){var t=this;let i=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];return function*(){var n;const s=yield t.trackChangeLock.lock();try{t.log.debug("setting up processor",t.logContext);const s=document.createElement(t.kind),a={kind:t.kind,track:t._mediaStreamTrack,element:s,audioContext:t.audioContext};if(yield e.init(a),t.log.debug("processor initialized",t.logContext),t.processor&&(yield t.internalStopProcessor()),"unknown"===t.kind)throw TypeError("cannot set processor on track of unknown kind");if(attachToElement(t._mediaStreamTrack,s),s.muted=!0,s.play().catch(e=>{e instanceof DOMException&&"AbortError"===e.name?(t.log.warn("failed to play processor element, retrying",Object.assign(Object.assign({},t.logContext),{error:e})),setTimeout(()=>{s.play().catch(e=>{t.log.error("failed to play processor element",Object.assign(Object.assign({},t.logContext),{err:e}))})},100)):t.log.error("failed to play processor element",Object.assign(Object.assign({},t.logContext),{error:e}))}),t.processor=e,t.processorElement=s,t.processor.processedTrack){for(const e of t.attachedElements)e!==t.processorElement&&i&&(detachTrack(t._mediaStreamTrack,e),attachToElement(t.processor.processedTrack,e));yield null===(n=t.sender)||void 0===n?void 0:n.replaceTrack(t.processor.processedTrack)}t.emit(gi.TrackProcessorUpdate,t.processor)}finally{s()}}()})}getProcessor(){return this.processor}stopProcessor(){return __awaiter(this,arguments,void 0,function(){var e=this;let t=!(arguments.length>0&&void 0!==arguments[0])||arguments[0];return function*(){const i=yield e.trackChangeLock.lock();try{yield e.internalStopProcessor(t)}finally{i()}}()})}internalStopProcessor(){return __awaiter(this,arguments,void 0,function(){var e=this;let t=!(arguments.length>0&&void 0!==arguments[0])||arguments[0];return function*(){var i,n;e.processor&&(e.log.debug("stopping processor",e.logContext),null===(i=e.processor.processedTrack)||void 0===i||i.stop(),yield e.processor.destroy(),e.processor=void 0,t||(null===(n=e.processorElement)||void 0===n||n.remove(),e.processorElement=void 0),yield e._mediaStreamTrack.applyConstraints(e._constraints),yield e.setMediaStreamTrack(e._mediaStreamTrack,!0),e.emit(gi.TrackProcessorUpdate))}()})}startPreConnectBuffer(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;if(an)if(this.localTrackRecorder)this.log.warn("preconnect buffer already started");else{{let e="audio/webm;codecs=opus";MediaRecorder.isTypeSupported(e)||(e="video/mp4"),this.localTrackRecorder=new LocalTrackRecorder(this,{mimeType:e})}this.localTrackRecorder.start(e),this.autoStopPreConnectBuffer=setTimeout(()=>{this.log.warn("preconnect buffer timed out, stopping recording automatically",this.logContext),this.stopPreConnectBuffer()},1e4)}else this.log.warn("MediaRecorder is not available, cannot start preconnect buffer",this.logContext)}stopPreConnectBuffer(){clearTimeout(this.autoStopPreConnectBuffer),this.localTrackRecorder&&(this.localTrackRecorder.stop(),this.localTrackRecorder=void 0)}getPreConnectBuffer(){var e;return null===(e=this.localTrackRecorder)||void 0===e?void 0:e.byteStream}getPreConnectBufferMimeType(){var e;return null===(e=this.localTrackRecorder)||void 0===e?void 0:e.mimeType}}class LocalAudioTrack extends LocalTrack{get enhancedNoiseCancellation(){return this.isKrispNoiseFilterEnabled}constructor(e,t){let i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],n=arguments.length>3?arguments[3]:void 0,s=arguments.length>4?arguments[4]:void 0;super(e,Track.Kind.Audio,t,i,s),this.stopOnMute=!1,this.isKrispNoiseFilterEnabled=!1,this.monitorSender=()=>__awaiter(this,void 0,void 0,function*(){if(!this.sender)return void(this._currentBitrate=0);let e;try{e=yield this.getSenderStats()}catch(e){return void this.log.error("could not get audio sender stats",Object.assign(Object.assign({},this.logContext),{error:e}))}e&&this.prevStats&&(this._currentBitrate=computeBitrate(e,this.prevStats)),this.prevStats=e}),this.handleKrispNoiseFilterEnable=()=>{this.isKrispNoiseFilterEnabled=!0,this.log.debug("Krisp noise filter enabled",this.logContext),this.emit(gi.AudioTrackFeatureUpdate,this,V.TF_ENHANCED_NOISE_CANCELLATION,!0)},this.handleKrispNoiseFilterDisable=()=>{this.isKrispNoiseFilterEnabled=!1,this.log.debug("Krisp noise filter disabled",this.logContext),this.emit(gi.AudioTrackFeatureUpdate,this,V.TF_ENHANCED_NOISE_CANCELLATION,!1)},this.audioContext=n,this.checkForSilence()}mute(){const e=Object.create(null,{mute:{get:()=>super.mute}});return __awaiter(this,void 0,void 0,function*(){const t=yield this.muteLock.lock();try{return this.isMuted?(this.log.debug("Track already muted",this.logContext),this):(this.source===Track.Source.Microphone&&this.stopOnMute&&!this.isUserProvided&&(this.log.debug("stopping mic track",this.logContext),this._mediaStreamTrack.stop()),yield e.mute.call(this),this)}finally{t()}})}unmute(){const e=Object.create(null,{unmute:{get:()=>super.unmute}});return __awaiter(this,void 0,void 0,function*(){const t=yield this.muteLock.lock();try{if(!this.isMuted)return this.log.debug("Track already unmuted",this.logContext),this;const t=this._constraints.deviceId&&this._mediaStreamTrack.getSettings().deviceId!==unwrapConstraint(this._constraints.deviceId);return this.source!==Track.Source.Microphone||!this.stopOnMute&&"ended"!==this._mediaStreamTrack.readyState&&!t||this.isUserProvided||(this.log.debug("reacquiring mic track",this.logContext),yield this.restartTrack()),yield e.unmute.call(this),this}finally{t()}})}restartTrack(e){return __awaiter(this,void 0,void 0,function*(){let t;if(e){const i=constraintsForOptions({audio:e});"boolean"!=typeof i.audio&&(t=i.audio)}yield this.restart(t)})}restart(e){const t=Object.create(null,{restart:{get:()=>super.restart}});return __awaiter(this,void 0,void 0,function*(){const i=yield t.restart.call(this,e);return this.checkForSilence(),i})}startMonitor(){isWeb()&&(this.monitorInterval||(this.monitorInterval=setInterval(()=>{this.monitorSender()},sn)))}setProcessor(e){return __awaiter(this,void 0,void 0,function*(){var t;const i=yield this.trackChangeLock.lock();try{if(!isReactNative()&&!this.audioContext)throw Error("Audio context needs to be set on LocalAudioTrack in order to enable processors");this.processor&&(yield this.internalStopProcessor());const i={kind:this.kind,track:this._mediaStreamTrack,audioContext:this.audioContext};this.log.debug("setting up audio processor ".concat(e.name),this.logContext),yield e.init(i),this.processor=e,this.processor.processedTrack&&(yield null===(t=this.sender)||void 0===t?void 0:t.replaceTrack(this.processor.processedTrack),this.processor.processedTrack.addEventListener("enable-lk-krisp-noise-filter",this.handleKrispNoiseFilterEnable),this.processor.processedTrack.addEventListener("disable-lk-krisp-noise-filter",this.handleKrispNoiseFilterDisable)),this.emit(gi.TrackProcessorUpdate,this.processor)}finally{i()}})}setAudioContext(e){this.audioContext=e}getSenderStats(){return __awaiter(this,void 0,void 0,function*(){var e;if(!(null===(e=this.sender)||void 0===e?void 0:e.getStats))return;let t;return(yield this.sender.getStats()).forEach(e=>{"outbound-rtp"===e.type&&(t={type:"audio",streamId:e.id,packetsSent:e.packetsSent,packetsLost:e.packetsLost,bytesSent:e.bytesSent,timestamp:e.timestamp,roundTripTime:e.roundTripTime,jitter:e.jitter})}),t})}checkForSilence(){return __awaiter(this,void 0,void 0,function*(){const e=yield detectSilence(this);return e&&(this.isMuted||this.log.debug("silence detected on local audio track",this.logContext),this.emit(gi.AudioSilenceDetected)),e})}}const cn=Object.values(yi),dn=Object.values(Ti),ln=Object.values(Ci),un=[yi.h180,yi.h360],hn=[Ti.h180,Ti.h360],pn=["q","h","f"];function computeVideoEncodings(e,t,i,n){var s,a;let c=null==n?void 0:n.videoEncoding;e&&(c=null==n?void 0:n.screenShareEncoding);const l=null==n?void 0:n.simulcast,u=null==n?void 0:n.scalabilityMode,h=null==n?void 0:n.videoCodec;if(!c&&!l&&!u||!t||!i)return[{}];c||(c=function(e,t,i,n){const s=function(e,t,i){if(e)return ln;const n=t>i?t/i:i/t;if(Math.abs(n-16/9)<Math.abs(n-4/3))return cn;return dn}(e,t,i);let{encoding:a}=s[0];const c=Math.max(t,i);for(let e=0;e<s.length;e+=1){const t=s[e];if(a=t.encoding,t.width>=c)break}if(n)switch(n){case"av1":case"h265":a=Object.assign({},a),a.maxBitrate=.7*a.maxBitrate;break;case"vp9":a=Object.assign({},a),a.maxBitrate=.85*a.maxBitrate}return a}(e,t,i,h),Bt.debug("using video encoding",c));const p=c.maxFramerate,m=new VideoPreset(t,i,c.maxBitrate,c.maxFramerate,c.priority);if(u&&isSVCCodec(h)){const e=new ScalabilityMode(u),t=[];if(e.spatial>3)throw new Error("unsupported scalabilityMode: ".concat(u));const i=getBrowser();if(isSafariBased()||isReactNative()||"Chrome"===(null==i?void 0:i.name)&&compareVersions(null==i?void 0:i.version,"113")<0){const n="h"==e.suffix?2:3,s=function(e){return e||(e=getBrowser()),"Safari"===(null==e?void 0:e.name)&&compareVersions(e.version,"18.3")>0||"iOS"===(null==e?void 0:e.os)&&!!(null==e?void 0:e.osVersion)&&compareVersions(e.osVersion,"18.3")>0}(i);for(let i=0;i<e.spatial;i+=1)t.push({rid:pn[2-i],maxBitrate:c.maxBitrate/Math.pow(n,i),maxFramerate:m.encoding.maxFramerate,scaleResolutionDownBy:s?Math.pow(2,i):void 0});t[0].scalabilityMode=u}else t.push({maxBitrate:c.maxBitrate,maxFramerate:m.encoding.maxFramerate,scalabilityMode:u});return m.encoding.priority&&(t[0].priority=m.encoding.priority,t[0].networkPriority=m.encoding.priority),Bt.debug("using svc encoding",{encodings:t}),t}if(!l)return[c];let g,v=[];if(v=e?null!==(s=sortPresets(null==n?void 0:n.screenShareSimulcastLayers))&&void 0!==s?s:defaultSimulcastLayers(e,m):null!==(a=sortPresets(null==n?void 0:n.videoSimulcastLayers))&&void 0!==a?a:defaultSimulcastLayers(e,m),v.length>0){const e=v[0];v.length>1&&([,g]=v);const n=Math.max(t,i);if(n>=960&&g)return encodingsFromPresets(t,i,[e,g,m],p);if(n>=480)return encodingsFromPresets(t,i,[e,m],p)}return encodingsFromPresets(t,i,[m])}function defaultSimulcastLayers(e,t){if(e)return[{scaleResolutionDownBy:2,fps:(i=t).encoding.maxFramerate}].map(e=>{var t,n;return new VideoPreset(Math.floor(i.width/e.scaleResolutionDownBy),Math.floor(i.height/e.scaleResolutionDownBy),Math.max(15e4,Math.floor(i.encoding.maxBitrate/(Math.pow(e.scaleResolutionDownBy,2)*((null!==(t=i.encoding.maxFramerate)&&void 0!==t?t:30)/(null!==(n=e.fps)&&void 0!==n?n:30))))),e.fps,i.encoding.priority)});var i;const{width:n,height:s}=t,a=n>s?n/s:s/n;return Math.abs(a-16/9)<Math.abs(a-4/3)?un:hn}function encodingsFromPresets(e,t,i,n){const s=[];if(i.forEach((i,a)=>{if(a>=pn.length)return;const c=Math.min(e,t),l={rid:pn[a],scaleResolutionDownBy:Math.max(1,c/Math.min(i.width,i.height)),maxBitrate:i.encoding.maxBitrate},u=n&&i.encoding.maxFramerate?Math.min(n,i.encoding.maxFramerate):i.encoding.maxFramerate;u&&(l.maxFramerate=u);const h=isFireFox()||0===a;i.encoding.priority&&h&&(l.priority=i.encoding.priority,l.networkPriority=i.encoding.priority),s.push(l)}),isReactNative()&&"ios"===getReactNativeOs()){let e;s.forEach(t=>{e?t.maxFramerate&&t.maxFramerate>e&&(e=t.maxFramerate):e=t.maxFramerate});let t=!0;s.forEach(i=>{var n;i.maxFramerate!=e&&(t&&(t=!1,Bt.info("Simulcast on iOS React-Native requires all encodings to share the same framerate.")),Bt.info('Setting framerate of encoding "'.concat(null!==(n=i.rid)&&void 0!==n?n:"",'" to ').concat(e)),i.maxFramerate=e)})}return s}function sortPresets(e){if(e)return e.sort((e,t)=>{const{encoding:i}=e,{encoding:n}=t;return i.maxBitrate>n.maxBitrate?1:i.maxBitrate<n.maxBitrate?-1:i.maxBitrate===n.maxBitrate&&i.maxFramerate&&n.maxFramerate?i.maxFramerate>n.maxFramerate?1:-1:0})}class ScalabilityMode{constructor(e){const t=e.match(/^L(\d)T(\d)(h|_KEY|_KEY_SHIFT){0,1}$/);if(!t)throw new Error("invalid scalability mode");if(this.spatial=parseInt(t[1]),this.temporal=parseInt(t[2]),t.length>3)switch(t[3]){case"h":case"_KEY":case"_KEY_SHIFT":this.suffix=t[3]}}toString(){var e;return"L".concat(this.spatial,"T").concat(this.temporal).concat(null!==(e=this.suffix)&&void 0!==e?e:"")}}class LocalVideoTrack extends LocalTrack{get sender(){return this._sender}set sender(e){this._sender=e,this.degradationPreference&&this.setDegradationPreference(this.degradationPreference)}constructor(e,t){let i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],n=arguments.length>3?arguments[3]:void 0;super(e,Track.Kind.Video,t,i,n),this.simulcastCodecs=new Map,this.degradationPreference="balanced",this.isCpuConstrained=!1,this.optimizeForPerformance=!1,this.monitorSender=()=>__awaiter(this,void 0,void 0,function*(){if(!this.sender)return void(this._currentBitrate=0);let e;try{e=yield this.getSenderStats()}catch(e){return void this.log.error("could not get video sender stats",Object.assign(Object.assign({},this.logContext),{error:e}))}const t=new Map(e.map(e=>[e.rid,e])),i=e.some(e=>"cpu"===e.qualityLimitationReason);if(i!==this.isCpuConstrained&&(this.isCpuConstrained=i,this.isCpuConstrained&&this.emit(gi.CpuConstrained)),this.prevStats){let e=0;t.forEach((t,i)=>{var n;const s=null===(n=this.prevStats)||void 0===n?void 0:n.get(i);e+=computeBitrate(t,s)}),this._currentBitrate=e}this.prevStats=t}),this.senderLock=new _}get isSimulcast(){return!!(this.sender&&this.sender.getParameters().encodings.length>1)}startMonitor(e){var t;if(this.signalClient=e,!isWeb())return;const i=null===(t=this.sender)||void 0===t?void 0:t.getParameters();i&&(this.encodings=i.encodings),this.monitorInterval||(this.monitorInterval=setInterval(()=>{this.monitorSender()},sn))}stop(){this._mediaStreamTrack.getConstraints(),this.simulcastCodecs.forEach(e=>{e.mediaStreamTrack.stop()}),super.stop()}pauseUpstream(){const e=Object.create(null,{pauseUpstream:{get:()=>super.pauseUpstream}});return __awaiter(this,void 0,void 0,function*(){var t,i,n,s,a;yield e.pauseUpstream.call(this);try{for(var c,l=!0,u=__asyncValues(this.simulcastCodecs.values());!(t=(c=yield u.next()).done);l=!0){s=c.value,l=!1;const e=s;yield null===(a=e.sender)||void 0===a?void 0:a.replaceTrack(null)}}catch(e){i={error:e}}finally{try{l||t||!(n=u.return)||(yield n.call(u))}finally{if(i)throw i.error}}})}resumeUpstream(){const e=Object.create(null,{resumeUpstream:{get:()=>super.resumeUpstream}});return __awaiter(this,void 0,void 0,function*(){var t,i,n,s,a;yield e.resumeUpstream.call(this);try{for(var c,l=!0,u=__asyncValues(this.simulcastCodecs.values());!(t=(c=yield u.next()).done);l=!0){s=c.value,l=!1;const e=s;yield null===(a=e.sender)||void 0===a?void 0:a.replaceTrack(e.mediaStreamTrack)}}catch(e){i={error:e}}finally{try{l||t||!(n=u.return)||(yield n.call(u))}finally{if(i)throw i.error}}})}mute(){const e=Object.create(null,{mute:{get:()=>super.mute}});return __awaiter(this,void 0,void 0,function*(){const t=yield this.muteLock.lock();try{return this.isMuted?(this.log.debug("Track already muted",this.logContext),this):(this.source!==Track.Source.Camera||this.isUserProvided||(this.log.debug("stopping camera track",this.logContext),this._mediaStreamTrack.stop()),yield e.mute.call(this),this)}finally{t()}})}unmute(){const e=Object.create(null,{unmute:{get:()=>super.unmute}});return __awaiter(this,void 0,void 0,function*(){const t=yield this.muteLock.lock();try{return this.isMuted?(this.source!==Track.Source.Camera||this.isUserProvided||(this.log.debug("reacquiring camera track",this.logContext),yield this.restartTrack()),yield e.unmute.call(this),this):(this.log.debug("Track already unmuted",this.logContext),this)}finally{t()}})}setTrackMuted(e){super.setTrackMuted(e);for(const t of this.simulcastCodecs.values())t.mediaStreamTrack.enabled=!e}getSenderStats(){return __awaiter(this,void 0,void 0,function*(){var e;if(!(null===(e=this.sender)||void 0===e?void 0:e.getStats))return[];const t=[],i=yield this.sender.getStats();return i.forEach(e=>{var n;if("outbound-rtp"===e.type){const s={type:"video",streamId:e.id,frameHeight:e.frameHeight,frameWidth:e.frameWidth,framesPerSecond:e.framesPerSecond,framesSent:e.framesSent,firCount:e.firCount,pliCount:e.pliCount,nackCount:e.nackCount,packetsSent:e.packetsSent,bytesSent:e.bytesSent,qualityLimitationReason:e.qualityLimitationReason,qualityLimitationDurations:e.qualityLimitationDurations,qualityLimitationResolutionChanges:e.qualityLimitationResolutionChanges,rid:null!==(n=e.rid)&&void 0!==n?n:e.id,retransmittedPacketsSent:e.retransmittedPacketsSent,targetBitrate:e.targetBitrate,timestamp:e.timestamp},a=i.get(e.remoteId);a&&(s.jitter=a.jitter,s.packetsLost=a.packetsLost,s.roundTripTime=a.roundTripTime),t.push(s)}}),t.sort((e,t)=>{var i,n;return(null!==(i=t.frameWidth)&&void 0!==i?i:0)-(null!==(n=e.frameWidth)&&void 0!==n?n:0)}),t})}setPublishingQuality(e){const t=[];for(let i=Ei.LOW;i<=Ei.HIGH;i+=1)t.push(new ot({quality:i,enabled:i<=e}));this.log.debug("setting publishing quality. max quality ".concat(e),this.logContext),this.setPublishingLayers(isSVCCodec(this.codec),t)}restartTrack(e){return __awaiter(this,void 0,void 0,function*(){var t,i,n,s,a;let c;if(e){const t=constraintsForOptions({video:e});"boolean"!=typeof t.video&&(c=t.video)}yield this.restart(c),this.isCpuConstrained=!1;try{for(var l,u=!0,h=__asyncValues(this.simulcastCodecs.values());!(t=(l=yield h.next()).done);u=!0){s=l.value,u=!1;const e=s;e.sender&&"closed"!==(null===(a=e.sender.transport)||void 0===a?void 0:a.state)&&(e.mediaStreamTrack=this.mediaStreamTrack.clone(),yield e.sender.replaceTrack(e.mediaStreamTrack))}}catch(e){i={error:e}}finally{try{u||t||!(n=h.return)||(yield n.call(h))}finally{if(i)throw i.error}}})}setProcessor(e){const t=Object.create(null,{setProcessor:{get:()=>super.setProcessor}});return __awaiter(this,arguments,void 0,function(e){var i=this;let n=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];return function*(){var s,a,c,l,u,h;if(yield t.setProcessor.call(i,e,n),null===(u=i.processor)||void 0===u?void 0:u.processedTrack)try{for(var p,m=!0,g=__asyncValues(i.simulcastCodecs.values());!(s=(p=yield g.next()).done);m=!0){l=p.value,m=!1;const e=l;yield null===(h=e.sender)||void 0===h?void 0:h.replaceTrack(i.processor.processedTrack)}}catch(e){a={error:e}}finally{try{m||s||!(c=g.return)||(yield c.call(g))}finally{if(a)throw a.error}}}()})}setDegradationPreference(e){return __awaiter(this,void 0,void 0,function*(){if(this.degradationPreference=e,this.sender)try{this.log.debug("setting degradationPreference to ".concat(e),this.logContext);const t=this.sender.getParameters();t.degradationPreference=e,this.sender.setParameters(t)}catch(e){this.log.warn("failed to set degradationPreference",Object.assign({error:e},this.logContext))}})}addSimulcastTrack(e,t){if(this.simulcastCodecs.has(e))return void this.log.error("".concat(e," already added, skipping adding simulcast codec"),this.logContext);const i={codec:e,mediaStreamTrack:this.mediaStreamTrack.clone(),sender:void 0,encodings:t};return this.simulcastCodecs.set(e,i),i}setSimulcastTrackSender(e,t){const i=this.simulcastCodecs.get(e);i&&(i.sender=t,setTimeout(()=>{this.subscribedCodecs&&this.setPublishingCodecs(this.subscribedCodecs)},5e3))}setPublishingCodecs(e){return __awaiter(this,void 0,void 0,function*(){var t,i,n,s,a,c,l;if(this.log.debug("setting publishing codecs",Object.assign(Object.assign({},this.logContext),{codecs:e,currentCodec:this.codec})),!this.codec&&e.length>0)return yield this.setPublishingLayers(isSVCCodec(e[0].codec),e[0].qualities),[];this.subscribedCodecs=e;const u=[];try{for(t=!0,i=__asyncValues(e);!(s=(n=yield i.next()).done);t=!0){l=n.value,t=!1;const e=l;if(this.codec&&this.codec!==e.codec){const t=this.simulcastCodecs.get(e.codec);if(this.log.debug("try setPublishingCodec for ".concat(e.codec),Object.assign(Object.assign({},this.logContext),{simulcastCodecInfo:t})),t&&t.sender)t.encodings&&(this.log.debug("try setPublishingLayersForSender ".concat(e.codec),this.logContext),yield setPublishingLayersForSender(t.sender,t.encodings,e.qualities,this.senderLock,isSVCCodec(e.codec),this.log,this.logContext));else for(const t of e.qualities)if(t.enabled){u.push(e.codec);break}}else yield this.setPublishingLayers(isSVCCodec(e.codec),e.qualities)}}catch(e){a={error:e}}finally{try{t||s||!(c=i.return)||(yield c.call(i))}finally{if(a)throw a.error}}return u})}setPublishingLayers(e,t){return __awaiter(this,void 0,void 0,function*(){this.optimizeForPerformance?this.log.info("skipping setPublishingLayers due to optimized publishing performance",Object.assign(Object.assign({},this.logContext),{qualities:t})):(this.log.debug("setting publishing layers",Object.assign(Object.assign({},this.logContext),{qualities:t})),this.sender&&this.encodings&&(yield setPublishingLayersForSender(this.sender,this.encodings,t,this.senderLock,e,this.log,this.logContext)))})}prioritizePerformance(){return __awaiter(this,void 0,void 0,function*(){if(!this.sender)throw new Error("sender not found");const e=yield this.senderLock.lock();try{this.optimizeForPerformance=!0;const e=this.sender.getParameters();e.encodings=e.encodings.map((e,t)=>{var i;return Object.assign(Object.assign({},e),{active:0===t,scaleResolutionDownBy:Math.max(1,Math.ceil((null!==(i=this.mediaStreamTrack.getSettings().height)&&void 0!==i?i:360)/360)),scalabilityMode:0===t&&isSVCCodec(this.codec)?"L1T3":void 0,maxFramerate:0===t?15:0,maxBitrate:0===t?e.maxBitrate:0})}),this.log.debug("setting performance optimised encodings",Object.assign(Object.assign({},this.logContext),{encodings:e.encodings})),this.encodings=e.encodings,yield this.sender.setParameters(e)}catch(e){this.log.error("failed to set performance optimised encodings",Object.assign(Object.assign({},this.logContext),{error:e})),this.optimizeForPerformance=!1}finally{e()}})}handleAppVisibilityChanged(){const e=Object.create(null,{handleAppVisibilityChanged:{get:()=>super.handleAppVisibilityChanged}});return __awaiter(this,void 0,void 0,function*(){yield e.handleAppVisibilityChanged.call(this),isMobile()&&this.isInBackground&&this.source===Track.Source.Camera&&(this._mediaStreamTrack.enabled=!1)})}}function setPublishingLayersForSender(e,t,i,n,s,a,c){return __awaiter(this,void 0,void 0,function*(){const l=yield n.lock();a.debug("setPublishingLayersForSender",Object.assign(Object.assign({},c),{sender:e,qualities:i,senderEncodings:t}));try{const n=e.getParameters(),{encodings:l}=n;if(!l)return;if(l.length!==t.length)return void a.warn("cannot set publishing layers, encodings mismatch",Object.assign(Object.assign({},c),{encodings:l,senderEncodings:t}));let u=!1;if(!1&&l[0].scalabilityMode);else{if(s){i.some(e=>e.enabled)&&i.forEach(e=>e.enabled=!0)}l.forEach((e,n)=>{var s;let l=null!==(s=e.rid)&&void 0!==s?s:"";""===l&&(l="q");const h=videoQualityForRid(l),p=i.find(e=>e.quality===h);p&&e.active!==p.enabled&&(u=!0,e.active=p.enabled,a.debug("setting layer ".concat(p.quality," to ").concat(e.active?"enabled":"disabled"),c),isFireFox()&&(p.enabled?(e.scaleResolutionDownBy=t[n].scaleResolutionDownBy,e.maxBitrate=t[n].maxBitrate,e.maxFrameRate=t[n].maxFrameRate):(e.scaleResolutionDownBy=4,e.maxBitrate=10,e.maxFrameRate=2)))})}u&&(n.encodings=l,a.debug("setting encodings",Object.assign(Object.assign({},c),{encodings:n.encodings})),yield e.setParameters(n))}finally{l()}})}function videoQualityForRid(e){switch(e){case"f":default:return Ei.HIGH;case"h":return Ei.MEDIUM;case"q":return Ei.LOW}}function videoLayersFromEncodings(e,t,i,n){if(!i)return[new X({quality:Ei.HIGH,width:e,height:t,bitrate:0,ssrc:0})];if(n){const n=i[0].scalabilityMode,s=new ScalabilityMode(n),a=[],c="h"==s.suffix?1.5:2,l="h"==s.suffix?2:3;for(let n=0;n<s.spatial;n+=1)a.push(new X({quality:Math.min(Ei.HIGH,s.spatial-1)-n,width:Math.ceil(e/Math.pow(c,n)),height:Math.ceil(t/Math.pow(c,n)),bitrate:i[0].maxBitrate?Math.ceil(i[0].maxBitrate/Math.pow(l,n)):0,ssrc:0}));return a}return i.map(i=>{var n,s,a;const c=null!==(n=i.scaleResolutionDownBy)&&void 0!==n?n:1;let l=videoQualityForRid(null!==(s=i.rid)&&void 0!==s?s:"");return new X({quality:l,width:Math.ceil(e/c),height:Math.ceil(t/c),bitrate:null!==(a=i.maxBitrate)&&void 0!==a?a:0,ssrc:0})})}const mn="_lossy",gn="_reliable",fn="leave-reconnect";var vn;!function(e){e[e.New=0]="New",e[e.Connected=1]="Connected",e[e.Disconnected=2]="Disconnected",e[e.Reconnecting=3]="Reconnecting",e[e.Closed=4]="Closed"}(vn||(vn={}));class RTCEngine extends Jt.EventEmitter{get isClosed(){return this._isClosed}get pendingReconnect(){return!!this.reconnectTimeout}constructor(e){var t;super(),this.options=e,this.rtcConfig={},this.peerConnectionTimeout=nn.peerConnectionTimeout,this.fullReconnectOnNext=!1,this.latestRemoteOfferId=0,this.subscriberPrimary=!1,this.pcState=vn.New,this._isClosed=!0,this.pendingTrackResolvers={},this.reconnectAttempts=0,this.reconnectStart=0,this.attemptingReconnect=!1,this.joinAttempts=0,this.maxJoinAttempts=1,this.shouldFailNext=!1,this.log=Bt,this.reliableDataSequence=1,this.reliableMessageBuffer=new DataPacketBuffer,this.reliableReceivedState=new TTLMap(3e4),this.lossyDataStatCurrentBytes=0,this.lossyDataStatByterate=0,this.lossyDataDropCount=0,this.midToTrackId={},this.isWaitingForNetworkReconnect=!1,this.handleDataChannel=e=>__awaiter(this,[e],void 0,function(e){var t=this;let{channel:i}=e;return function*(){if(i){if(i.label===gn)t.reliableDCSub=i;else{if(i.label!==mn)return;t.lossyDCSub=i}t.log.debug("on data channel ".concat(i.id,", ").concat(i.label),t.logContext),i.onmessage=t.handleDataMessage}}()}),this.handleDataMessage=e=>__awaiter(this,void 0,void 0,function*(){var t,i,n,s,a;const c=yield this.dataProcessLock.lock();try{let c;if(e.data instanceof ArrayBuffer)c=e.data;else{if(!(e.data instanceof Blob))return void this.log.error("unsupported data type",Object.assign(Object.assign({},this.logContext),{data:e.data}));c=yield e.data.arrayBuffer()}const l=ee.fromBinary(new Uint8Array(c));if(l.sequence>0&&""!==l.participantSid){const e=this.reliableReceivedState.get(l.participantSid);if(e&&l.sequence<=e)return;this.reliableReceivedState.set(l.participantSid,l.sequence)}if("speaker"===(null===(t=l.value)||void 0===t?void 0:t.case))this.emit(mi.ActiveSpeakersUpdate,l.value.value.speakers);else if("encryptedPacket"===(null===(i=l.value)||void 0===i?void 0:i.case)){if(!this.e2eeManager)return void this.log.error("Received encrypted packet but E2EE not set up",this.logContext);const e=yield null===(n=this.e2eeManager)||void 0===n?void 0:n.handleEncryptedData(l.value.value.encryptedValue,l.value.value.iv,l.participantIdentity,l.value.value.keyIndex),t=ne.fromBinary(e.payload),i=new ee({value:t.value,participantIdentity:l.participantIdentity,participantSid:l.participantSid});"user"===(null===(s=i.value)||void 0===s?void 0:s.case)&&applyUserDataCompat(i,i.value.value),this.emit(mi.DataPacketReceived,i,l.value.value.encryptionType)}else"user"===(null===(a=l.value)||void 0===a?void 0:a.case)&&applyUserDataCompat(l,l.value.value),this.emit(mi.DataPacketReceived,l,Q.NONE)}finally{c()}}),this.handleDataError=e=>{const t=0===e.currentTarget.maxRetransmits?"lossy":"reliable";if(e instanceof ErrorEvent&&e.error){const{error:i}=e.error;this.log.error("DataChannel error on ".concat(t,": ").concat(e.message),Object.assign(Object.assign({},this.logContext),{error:i}))}else this.log.error("Unknown DataChannel error on ".concat(t),Object.assign(Object.assign({},this.logContext),{event:e}))},this.handleBufferedAmountLow=e=>{const t=0===e.currentTarget.maxRetransmits?te.LOSSY:te.RELIABLE;this.updateAndEmitDCBufferStatus(t)},this.handleDisconnect=(e,t)=>{if(this._isClosed)return;this.log.warn("".concat(e," disconnected"),this.logContext),0===this.reconnectAttempts&&(this.reconnectStart=Date.now());const disconnect=e=>{this.log.warn("could not recover connection after ".concat(this.reconnectAttempts," attempts, ").concat(e,"ms. giving up"),this.logContext),this.emit(mi.Disconnected),this.close()},i=Date.now()-this.reconnectStart;let n=this.getNextRetryDelay({elapsedMs:i,retryCount:this.reconnectAttempts});null!==n?(e===fn&&(n=0),this.log.debug("reconnecting in ".concat(n,"ms"),this.logContext),this.clearReconnectTimeout(),this.token&&this.regionUrlProvider&&this.regionUrlProvider.updateToken(this.token),this.reconnectTimeout=CriticalTimers.setTimeout(()=>this.attemptReconnect(t).finally(()=>this.reconnectTimeout=void 0),n)):disconnect(i)},this.waitForRestarted=()=>new Promise((e,t)=>{this.pcState===vn.Connected&&e();const onRestarted=()=>{this.off(mi.Disconnected,onDisconnected),e()},onDisconnected=()=>{this.off(mi.Restarted,onRestarted),t()};this.once(mi.Restarted,onRestarted),this.once(mi.Disconnected,onDisconnected)}),this.updateAndEmitDCBufferStatus=e=>{if(e===te.RELIABLE){const t=this.dataChannelForKind(e);t&&this.reliableMessageBuffer.alignBufferedAmount(t.bufferedAmount)}const t=this.isBufferStatusLow(e);void 0!==t&&t!==this.dcBufferStatus.get(e)&&(this.dcBufferStatus.set(e,t),this.emit(mi.DCBufferStatusChanged,t,e))},this.isBufferStatusLow=e=>{const t=this.dataChannelForKind(e);if(t)return t.bufferedAmount<=t.bufferedAmountLowThreshold},this.handleBrowserOnLine=()=>__awaiter(this,void 0,void 0,function*(){if(!this.url)return;(yield fetch(toHttpUrl(this.url),{method:"HEAD"}).then(e=>e.ok).catch(()=>!1))&&(this.log.info("detected network reconnected"),(this.client.currentState===Fi.RECONNECTING||this.isWaitingForNetworkReconnect&&this.client.currentState===Fi.CONNECTED)&&(this.clearReconnectTimeout(),this.attemptReconnect(j.RR_SIGNAL_DISCONNECTED),this.isWaitingForNetworkReconnect=!1))}),this.handleBrowserOffline=()=>__awaiter(this,void 0,void 0,function*(){if(this.url)try{yield Promise.race([fetch(toHttpUrl(this.url),{method:"HEAD"}),sleep(4e3).then(()=>Promise.reject())])}catch(e){!1===window.navigator.onLine&&(this.log.info("detected network interruption"),this.isWaitingForNetworkReconnect=!0)}}),this.log=getLogger(null!==(t=e.loggerName)&&void 0!==t?t:Ft.Engine),this.loggerOptions={loggerName:e.loggerName,loggerContextCb:()=>this.logContext},this.client=new SignalClient(void 0,this.loggerOptions),this.client.signalLatency=this.options.expSignalLatency,this.reconnectPolicy=this.options.reconnectPolicy,this.closingLock=new _,this.dataProcessLock=new _,this.dcBufferStatus=new Map([[te.LOSSY,!0],[te.RELIABLE,!0]]),this.client.onParticipantUpdate=e=>this.emit(mi.ParticipantUpdate,e),this.client.onConnectionQuality=e=>this.emit(mi.ConnectionQualityUpdate,e),this.client.onRoomUpdate=e=>this.emit(mi.RoomUpdate,e),this.client.onSubscriptionError=e=>this.emit(mi.SubscriptionError,e),this.client.onSubscriptionPermissionUpdate=e=>this.emit(mi.SubscriptionPermissionUpdate,e),this.client.onSpeakersChanged=e=>this.emit(mi.SpeakersChanged,e),this.client.onStreamStateUpdate=e=>this.emit(mi.StreamStateChanged,e),this.client.onRequestResponse=e=>this.emit(mi.SignalRequestResponse,e)}get logContext(){var e,t,i,n,s,a;return{room:null===(t=null===(e=this.latestJoinResponse)||void 0===e?void 0:e.room)||void 0===t?void 0:t.name,roomID:null===(n=null===(i=this.latestJoinResponse)||void 0===i?void 0:i.room)||void 0===n?void 0:n.sid,participant:null===(a=null===(s=this.latestJoinResponse)||void 0===s?void 0:s.participant)||void 0===a?void 0:a.identity,pID:this.participantSid}}join(e,t,i,n){return __awaiter(this,arguments,void 0,function(e,t,i,n){var s=this;let a=arguments.length>4&&void 0!==arguments[4]&&arguments[4];return function*(){s.url=e,s.token=t,s.signalOpts=i,s.maxJoinAttempts=i.maxRetries;try{s.joinAttempts+=1,s.setupSignalClientCallbacks();const c=yield s.client.join(e,t,i,n,a);return s._isClosed=!1,s.latestJoinResponse=c,s.subscriberPrimary=c.subscriberPrimary,s.pcManager||(yield s.configure(c,!a)),s.subscriberPrimary&&!c.fastPublish||s.negotiate().catch(e=>{Bt.error(e,s.logContext)}),s.registerOnLineListener(),s.clientConfiguration=c.clientConfiguration,s.emit(mi.SignalConnected,c),c}catch(c){if(c instanceof ConnectionError)if(c.reason===di.ServerUnreachable){if(s.log.warn("Couldn't connect to server, attempt ".concat(s.joinAttempts," of ").concat(s.maxJoinAttempts),s.logContext),s.joinAttempts<s.maxJoinAttempts)return s.join(e,t,i,n,a)}else if(c.reason===di.ServiceNotFound)return s.log.warn("Initial connection failed: ".concat(c.message," – Retrying")),s.join(e,t,i,n,!0);throw c}}()})}close(){return __awaiter(this,void 0,void 0,function*(){const e=yield this.closingLock.lock();if(this.isClosed)e();else try{this._isClosed=!0,this.joinAttempts=0,this.emit(mi.Closing),this.removeAllListeners(),this.deregisterOnLineListener(),this.clearPendingReconnect(),this.cleanupLossyDataStats(),yield this.cleanupPeerConnections(),yield this.cleanupClient()}finally{e()}})}cleanupPeerConnections(){return __awaiter(this,void 0,void 0,function*(){var e;yield null===(e=this.pcManager)||void 0===e?void 0:e.close(),this.pcManager=void 0;const dcCleanup=e=>{e&&(e.close(),e.onbufferedamountlow=null,e.onclose=null,e.onclosing=null,e.onerror=null,e.onmessage=null,e.onopen=null)};dcCleanup(this.lossyDC),dcCleanup(this.lossyDCSub),dcCleanup(this.reliableDC),dcCleanup(this.reliableDCSub),this.lossyDC=void 0,this.lossyDCSub=void 0,this.reliableDC=void 0,this.reliableDCSub=void 0,this.reliableMessageBuffer=new DataPacketBuffer,this.reliableDataSequence=1,this.reliableReceivedState.clear()})}cleanupLossyDataStats(){this.lossyDataStatByterate=0,this.lossyDataStatCurrentBytes=0,this.lossyDataStatInterval&&(clearInterval(this.lossyDataStatInterval),this.lossyDataStatInterval=void 0),this.lossyDataDropCount=0}cleanupClient(){return __awaiter(this,void 0,void 0,function*(){yield this.client.close(),this.client.resetCallbacks()})}addTrack(e){if(this.pendingTrackResolvers[e.cid])throw new TrackInvalidError("a track with the same ID has already been published");return new Promise((t,i)=>{const n=setTimeout(()=>{delete this.pendingTrackResolvers[e.cid],i(ConnectionError.timeout("publication of local track timed out, no response from server"))},1e4);this.pendingTrackResolvers[e.cid]={resolve:e=>{clearTimeout(n),t(e)},reject:()=>{clearTimeout(n),i(new Error("Cancelled publication by calling unpublish"))}},this.client.sendAddTrack(e)})}removeTrack(e){if(e.track&&this.pendingTrackResolvers[e.track.id]){const{reject:t}=this.pendingTrackResolvers[e.track.id];t&&t(),delete this.pendingTrackResolvers[e.track.id]}try{return this.pcManager.removeTrack(e),!0}catch(e){this.log.warn("failed to remove track",Object.assign(Object.assign({},this.logContext),{error:e}))}return!1}updateMuteStatus(e,t){this.client.sendMuteTrack(e,t)}get dataSubscriberReadyState(){var e;return null===(e=this.reliableDCSub)||void 0===e?void 0:e.readyState}getConnectedServerAddress(){return __awaiter(this,void 0,void 0,function*(){var e;return null===(e=this.pcManager)||void 0===e?void 0:e.getConnectedAddress()})}setRegionUrlProvider(e){this.regionUrlProvider=e}configure(e,t){return __awaiter(this,void 0,void 0,function*(){var i,n;if(this.pcManager&&this.pcManager.currentState!==rn.NEW)return;this.participantSid=null===(i=e.participant)||void 0===i?void 0:i.sid;const s=this.makeRTCConfiguration(e);var a;this.pcManager=new PCTransportManager(s,t?"publisher-only":e.subscriberPrimary?"subscriber-primary":"publisher-primary",this.loggerOptions),this.emit(mi.TransportsCreated,this.pcManager.publisher,this.pcManager.subscriber),this.pcManager.onIceCandidate=(e,t)=>{this.client.sendIceCandidate(e,t)},this.pcManager.onPublisherOffer=(e,t)=>{this.client.sendOffer(e,t)},this.pcManager.onDataChannel=this.handleDataChannel,this.pcManager.onStateChange=(t,i,n)=>__awaiter(this,void 0,void 0,function*(){if(this.log.debug("primary PC state changed ".concat(t),this.logContext),["closed","disconnected","failed"].includes(i)&&(this.publisherConnectionPromise=void 0),t===rn.CONNECTED){const t=this.pcState===vn.New;this.pcState=vn.Connected,t&&this.emit(mi.Connected,e)}else t===rn.FAILED&&(this.pcState!==vn.Connected&&this.pcState!==vn.Reconnecting||(this.pcState=vn.Disconnected,this.handleDisconnect("peerconnection failed","failed"===n?j.RR_SUBSCRIBER_FAILED:j.RR_PUBLISHER_FAILED)));const s=this.client.isDisconnected||this.client.currentState===Fi.RECONNECTING,a=[rn.FAILED,rn.CLOSING,rn.CLOSED].includes(t);s&&a&&!this._isClosed&&this.emit(mi.Offline)}),this.pcManager.onTrack=e=>{0!==e.streams.length&&this.emit(mi.MediaTrackAdded,e.track,e.streams[0],e.receiver)},void 0!==(a=null===(n=e.serverInfo)||void 0===n?void 0:n.protocol)&&a>13||this.createDataChannels()})}setupSignalClientCallbacks(){this.client.onAnswer=(e,t,i)=>__awaiter(this,void 0,void 0,function*(){this.pcManager&&(this.log.debug("received server answer",Object.assign(Object.assign({},this.logContext),{RTCSdpType:e.type,sdp:e.sdp,midToTrackId:i})),this.midToTrackId=i,yield this.pcManager.setPublisherAnswer(e,t))}),this.client.onTrickle=(e,t)=>{this.pcManager&&(this.log.debug("got ICE candidate from peer",Object.assign(Object.assign({},this.logContext),{candidate:e,target:t})),this.pcManager.addIceCandidate(e,t))},this.client.onOffer=(e,t,i)=>__awaiter(this,void 0,void 0,function*(){if(this.latestRemoteOfferId=t,!this.pcManager)return;this.midToTrackId=i;const n=yield this.pcManager.createSubscriberAnswerFromOffer(e,t);n&&this.client.sendAnswer(n,t)}),this.client.onLocalTrackPublished=e=>{var t;if(this.log.debug("received trackPublishedResponse",Object.assign(Object.assign({},this.logContext),{cid:e.cid,track:null===(t=e.track)||void 0===t?void 0:t.sid})),!this.pendingTrackResolvers[e.cid])return void this.log.error("missing track resolver for ".concat(e.cid),Object.assign(Object.assign({},this.logContext),{cid:e.cid}));const{resolve:i}=this.pendingTrackResolvers[e.cid];delete this.pendingTrackResolvers[e.cid],i(e.track)},this.client.onLocalTrackUnpublished=e=>{this.emit(mi.LocalTrackUnpublished,e)},this.client.onLocalTrackSubscribed=e=>{this.emit(mi.LocalTrackSubscribed,e)},this.client.onTokenRefresh=e=>{var t;this.token=e,null===(t=this.regionUrlProvider)||void 0===t||t.updateToken(e)},this.client.onRemoteMuteChanged=(e,t)=>{this.emit(mi.RemoteMute,e,t)},this.client.onSubscribedQualityUpdate=e=>{this.emit(mi.SubscribedQualityUpdate,e)},this.client.onRoomMoved=e=>{var t;this.participantSid=null===(t=e.participant)||void 0===t?void 0:t.sid,this.latestJoinResponse&&(this.latestJoinResponse.room=e.room),this.emit(mi.RoomMoved,e)},this.client.onMediaSectionsRequirement=e=>{var t,i;const n={direction:"recvonly"};for(let i=0;i<e.numAudios;i++)null===(t=this.pcManager)||void 0===t||t.addPublisherTransceiverOfKind("audio",n);for(let t=0;t<e.numVideos;t++)null===(i=this.pcManager)||void 0===i||i.addPublisherTransceiverOfKind("video",n);this.negotiate()},this.client.onClose=()=>{this.handleDisconnect("signal",j.RR_SIGNAL_DISCONNECTED)},this.client.onLeave=e=>{switch(this.log.debug("client leave request",Object.assign(Object.assign({},this.logContext),{reason:null==e?void 0:e.reason})),e.regions&&this.regionUrlProvider&&(this.log.debug("updating regions",this.logContext),this.regionUrlProvider.setServerReportedRegions({updatedAtInMs:Date.now(),maxAgeInMs:5e3,regionSettings:e.regions})),e.action){case $e.DISCONNECT:this.emit(mi.Disconnected,null==e?void 0:e.reason),this.close();break;case $e.RECONNECT:this.fullReconnectOnNext=!0,this.handleDisconnect(fn);break;case $e.RESUME:this.handleDisconnect(fn)}}}makeRTCConfiguration(e){var t;const i=Object.assign({},this.rtcConfig);if((null===(t=this.signalOpts)||void 0===t?void 0:t.e2eeEnabled)&&(this.log.debug("E2EE - setting up transports with insertable streams",this.logContext),i.encodedInsertableStreams=!0),e.iceServers&&!i.iceServers){const t=[];e.iceServers.forEach(e=>{const i={urls:e.urls};e.username&&(i.username=e.username),e.credential&&(i.credential=e.credential),t.push(i)}),i.iceServers=t}return e.clientConfiguration&&e.clientConfiguration.forceRelay===U.ENABLED&&(i.iceTransportPolicy="relay"),i.sdpSemantics="unified-plan",i.continualGatheringPolicy="gather_continually",i}createDataChannels(){this.pcManager&&(this.lossyDC&&(this.lossyDC.onmessage=null,this.lossyDC.onerror=null),this.reliableDC&&(this.reliableDC.onmessage=null,this.reliableDC.onerror=null),this.lossyDC=this.pcManager.createPublisherDataChannel(mn,{ordered:!1,maxRetransmits:0}),this.reliableDC=this.pcManager.createPublisherDataChannel(gn,{ordered:!0}),this.lossyDC.onmessage=this.handleDataMessage,this.reliableDC.onmessage=this.handleDataMessage,this.lossyDC.onerror=this.handleDataError,this.reliableDC.onerror=this.handleDataError,this.lossyDC.bufferedAmountLowThreshold=65535,this.reliableDC.bufferedAmountLowThreshold=65535,this.lossyDC.onbufferedamountlow=this.handleBufferedAmountLow,this.reliableDC.onbufferedamountlow=this.handleBufferedAmountLow,this.cleanupLossyDataStats(),this.lossyDataStatInterval=setInterval(()=>{this.lossyDataStatByterate=this.lossyDataStatCurrentBytes,this.lossyDataStatCurrentBytes=0;const e=this.dataChannelForKind(te.LOSSY);if(e){const t=this.lossyDataStatByterate/10;e.bufferedAmountLowThreshold=Math.min(Math.max(t,8192),262144)}},1e3))}createSender(e,t,i){return __awaiter(this,void 0,void 0,function*(){if(supportsTransceiver()){return yield this.createTransceiverRTCRtpSender(e,t,i)}if(supportsAddTrack()){this.log.warn("using add-track fallback",this.logContext);return yield this.createRTCRtpSender(e.mediaStreamTrack)}throw new UnexpectedConnectionState("Required webRTC APIs not supported on this device")})}createSimulcastSender(e,t,i,n){return __awaiter(this,void 0,void 0,function*(){if(supportsTransceiver())return this.createSimulcastTransceiverSender(e,t,i,n);if(supportsAddTrack())return this.log.debug("using add-track fallback",this.logContext),this.createRTCRtpSender(e.mediaStreamTrack);throw new UnexpectedConnectionState("Cannot stream on this device")})}createTransceiverRTCRtpSender(e,t,i){return __awaiter(this,void 0,void 0,function*(){if(!this.pcManager)throw new UnexpectedConnectionState("publisher is closed");const n=[];e.mediaStream&&n.push(e.mediaStream),isVideoTrack(e)&&(e.codec=t.videoCodec);const s={direction:"sendonly",streams:n};i&&(s.sendEncodings=i);return(yield this.pcManager.addPublisherTransceiver(e.mediaStreamTrack,s)).sender})}createSimulcastTransceiverSender(e,t,i,n){return __awaiter(this,void 0,void 0,function*(){if(!this.pcManager)throw new UnexpectedConnectionState("publisher is closed");const s={direction:"sendonly"};n&&(s.sendEncodings=n);const a=yield this.pcManager.addPublisherTransceiver(t.mediaStreamTrack,s);if(i.videoCodec)return e.setSimulcastTrackSender(i.videoCodec,a.sender),a.sender})}createRTCRtpSender(e){return __awaiter(this,void 0,void 0,function*(){if(!this.pcManager)throw new UnexpectedConnectionState("publisher is closed");return this.pcManager.addPublisherTrack(e)})}attemptReconnect(e){return __awaiter(this,void 0,void 0,function*(){var t,i,n;if(!this._isClosed)if(this.attemptingReconnect)Bt.warn("already attempting reconnect, returning early",this.logContext);else{(null===(t=this.clientConfiguration)||void 0===t?void 0:t.resumeConnection)!==U.DISABLED&&(null!==(n=null===(i=this.pcManager)||void 0===i?void 0:i.currentState)&&void 0!==n?n:rn.NEW)!==rn.NEW||(this.fullReconnectOnNext=!0);try{this.attemptingReconnect=!0,this.fullReconnectOnNext?yield this.restartConnection():yield this.resumeConnection(e),this.clearPendingReconnect(),this.fullReconnectOnNext=!1}catch(e){this.reconnectAttempts+=1;let t=!0;e instanceof UnexpectedConnectionState?(this.log.debug("received unrecoverable error",Object.assign(Object.assign({},this.logContext),{error:e})),t=!1):e instanceof SignalReconnectError||(this.fullReconnectOnNext=!0),t?this.handleDisconnect("reconnect",j.RR_UNKNOWN):(this.log.info("could not recover connection after ".concat(this.reconnectAttempts," attempts, ").concat(Date.now()-this.reconnectStart,"ms. giving up"),this.logContext),this.emit(mi.Disconnected),yield this.close())}finally{this.attemptingReconnect=!1}}})}getNextRetryDelay(e){try{return this.reconnectPolicy.nextRetryDelayInMs(e)}catch(e){this.log.warn("encountered error in reconnect policy",Object.assign(Object.assign({},this.logContext),{error:e}))}return null}restartConnection(e){return __awaiter(this,void 0,void 0,function*(){var t,i,n;try{if(!this.url||!this.token)throw new UnexpectedConnectionState("could not reconnect, url or token not saved");let i;this.log.info("reconnecting, attempt: ".concat(this.reconnectAttempts),this.logContext),this.emit(mi.Restarting),this.client.isDisconnected||(yield this.client.sendLeave()),yield this.cleanupPeerConnections(),yield this.cleanupClient();try{if(!this.signalOpts)throw this.log.warn("attempted connection restart, without signal options present",this.logContext),new SignalReconnectError;i=yield this.join(null!=e?e:this.url,this.token,this.signalOpts,void 0,!this.options.singlePeerConnection)}catch(e){if(e instanceof ConnectionError&&e.reason===di.NotAllowed)throw new UnexpectedConnectionState("could not reconnect, token might be expired");throw new SignalReconnectError}if(this.shouldFailNext)throw this.shouldFailNext=!1,new Error("simulated failure");if(this.client.setReconnected(),this.emit(mi.SignalRestarted,i),yield this.waitForPCReconnected(),this.client.currentState!==Fi.CONNECTED)throw new SignalReconnectError("Signal connection got severed during reconnect");null===(t=this.regionUrlProvider)||void 0===t||t.resetAttempts(),this.emit(mi.Restarted)}catch(e){const t=yield null===(i=this.regionUrlProvider)||void 0===i?void 0:i.getNextBestRegionUrl();if(t)return void(yield this.restartConnection(t));throw null===(n=this.regionUrlProvider)||void 0===n||n.resetAttempts(),e}})}resumeConnection(e){return __awaiter(this,void 0,void 0,function*(){var t;if(!this.url||!this.token)throw new UnexpectedConnectionState("could not reconnect, url or token not saved");if(!this.pcManager)throw new UnexpectedConnectionState("publisher and subscriber connections unset");let i;this.log.info("resuming signal connection, attempt ".concat(this.reconnectAttempts),this.logContext),this.emit(mi.Resuming);try{this.setupSignalClientCallbacks(),i=yield this.client.reconnect(this.url,this.token,this.participantSid,e)}catch(e){let t="";if(e instanceof Error&&(t=e.message,this.log.error(e.message,Object.assign(Object.assign({},this.logContext),{error:e}))),e instanceof ConnectionError&&e.reason===di.NotAllowed)throw new UnexpectedConnectionState("could not reconnect, token might be expired");if(e instanceof ConnectionError&&e.reason===di.LeaveRequest)throw e;throw new SignalReconnectError(t)}if(this.emit(mi.SignalResumed),i){const e=this.makeRTCConfiguration(i);this.pcManager.updateConfiguration(e),this.latestJoinResponse&&(this.latestJoinResponse.serverInfo=i.serverInfo)}else this.log.warn("Did not receive reconnect response",this.logContext);if(this.shouldFailNext)throw this.shouldFailNext=!1,new Error("simulated failure");if(yield this.pcManager.triggerIceRestart(),yield this.waitForPCReconnected(),this.client.currentState!==Fi.CONNECTED)throw new SignalReconnectError("Signal connection got severed during reconnect");this.client.setReconnected(),"open"===(null===(t=this.reliableDC)||void 0===t?void 0:t.readyState)&&null===this.reliableDC.id&&this.createDataChannels(),(null==i?void 0:i.lastMessageSeq)&&this.resendReliableMessagesForResume(i.lastMessageSeq),this.emit(mi.Resumed)})}waitForPCInitialConnection(e,t){return __awaiter(this,void 0,void 0,function*(){if(!this.pcManager)throw new UnexpectedConnectionState("PC manager is closed");yield this.pcManager.ensurePCTransportConnection(t,e)})}waitForPCReconnected(){return __awaiter(this,void 0,void 0,function*(){this.pcState=vn.Reconnecting,this.log.debug("waiting for peer connection to reconnect",this.logContext);try{if(yield sleep(2e3),!this.pcManager)throw new UnexpectedConnectionState("PC manager is closed");yield this.pcManager.ensurePCTransportConnection(void 0,this.peerConnectionTimeout),this.pcState=vn.Connected}catch(e){throw this.pcState=vn.Disconnected,ConnectionError.internal("could not establish PC connection, ".concat(e.message))}})}publishRpcResponse(e,t,i,n){return __awaiter(this,void 0,void 0,function*(){const s=new ee({destinationIdentities:[e],kind:te.RELIABLE,value:{case:"rpcResponse",value:new pe({requestId:t,value:n?{case:"error",value:n.toProto()}:{case:"payload",value:null!=i?i:""}})}});yield this.sendDataPacket(s,te.RELIABLE)})}publishRpcAck(e,t){return __awaiter(this,void 0,void 0,function*(){const i=new ee({destinationIdentities:[e],kind:te.RELIABLE,value:{case:"rpcAck",value:new he({requestId:t})}});yield this.sendDataPacket(i,te.RELIABLE)})}sendDataPacket(e,t){return __awaiter(this,void 0,void 0,function*(){if(yield this.ensurePublisherConnected(t),this.e2eeManager&&this.e2eeManager.isDataChannelEncryptionEnabled){const t=function(e){var t,i,n,s,a;if("sipDtmf"!==(null===(t=e.value)||void 0===t?void 0:t.case)&&"metrics"!==(null===(i=e.value)||void 0===i?void 0:i.case)&&"speaker"!==(null===(n=e.value)||void 0===n?void 0:n.case)&&"transcription"!==(null===(s=e.value)||void 0===s?void 0:s.case)&&"encryptedPacket"!==(null===(a=e.value)||void 0===a?void 0:a.case))return new ne({value:e.value})}(e);if(t){const i=yield this.e2eeManager.encryptData(t.toBinary());e.value={case:"encryptedPacket",value:new ie({encryptedValue:i.payload,iv:i.iv,keyIndex:i.keyIndex})}}}t===te.RELIABLE&&(e.sequence=this.reliableDataSequence,this.reliableDataSequence+=1);const i=e.toBinary(),n=this.dataChannelForKind(t);if(n){if(t===te.RELIABLE)yield this.waitForBufferStatusLow(t),this.reliableMessageBuffer.push({data:i,sequence:e.sequence});else{if(!this.isBufferStatusLow(t))return this.lossyDataDropCount+=1,void(this.lossyDataDropCount%100==0&&this.log.warn("dropping lossy data channel messages, total dropped: ".concat(this.lossyDataDropCount),this.logContext));this.lossyDataStatCurrentBytes+=i.byteLength}if(this.attemptingReconnect)return;n.send(i)}this.updateAndEmitDCBufferStatus(t)})}resendReliableMessagesForResume(e){return __awaiter(this,void 0,void 0,function*(){yield this.ensurePublisherConnected(te.RELIABLE);const t=this.dataChannelForKind(te.RELIABLE);t&&(this.reliableMessageBuffer.popToSequence(e),this.reliableMessageBuffer.getAll().forEach(e=>{t.send(e.data)})),this.updateAndEmitDCBufferStatus(te.RELIABLE)})}waitForBufferStatusLow(e){return new TypedPromise((t,i)=>__awaiter(this,void 0,void 0,function*(){if(this.isBufferStatusLow(e))t();else{const onClosing=()=>i(new UnexpectedConnectionState("engine closed"));for(this.once(mi.Closing,onClosing);!this.dcBufferStatus.get(e);)yield sleep(10);this.off(mi.Closing,onClosing),t()}}))}ensureDataTransportConnected(e){return __awaiter(this,arguments,void 0,function(e){var t=this;let i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.subscriberPrimary;return function*(){var n;if(!t.pcManager)throw new UnexpectedConnectionState("PC manager is closed");const s=i?t.pcManager.subscriber:t.pcManager.publisher,a=i?"Subscriber":"Publisher";if(!s)throw ConnectionError.internal("".concat(a," connection not set"));let c=!1;i||t.dataChannelForKind(e,i)||(t.createDataChannels(),c=!0),c||i||t.pcManager.publisher.isICEConnected||"checking"===t.pcManager.publisher.getICEConnectionState()||(c=!0),c&&t.negotiate().catch(e=>{Bt.error(e,t.logContext)});const l=t.dataChannelForKind(e,i);if("open"===(null==l?void 0:l.readyState))return;const u=(new Date).getTime()+t.peerConnectionTimeout;for(;(new Date).getTime()<u;){if(s.isICEConnected&&"open"===(null===(n=t.dataChannelForKind(e,i))||void 0===n?void 0:n.readyState))return;yield sleep(50)}throw ConnectionError.internal("could not establish ".concat(a," connection, state: ").concat(s.getICEConnectionState()))}()})}ensurePublisherConnected(e){return __awaiter(this,void 0,void 0,function*(){this.publisherConnectionPromise||(this.publisherConnectionPromise=this.ensureDataTransportConnected(e,!1)),yield this.publisherConnectionPromise})}verifyTransport(){return!!this.pcManager&&(this.pcManager.currentState===rn.CONNECTED&&!(!this.client.ws||this.client.ws.readyState===WebSocket.CLOSED))}negotiate(){return __awaiter(this,void 0,void 0,function*(){return new TypedPromise((e,t)=>__awaiter(this,void 0,void 0,function*(){if(!this.pcManager)return void t(new NegotiationError("PC manager is closed"));this.pcManager.requirePublisher(),0!=this.pcManager.publisher.getTransceivers().length||this.lossyDC||this.reliableDC||this.createDataChannels();const i=new AbortController,handleClosed=()=>{i.abort(),this.log.debug("engine disconnected while negotiation was ongoing",this.logContext),e()};this.isClosed&&t(new NegotiationError("cannot negotiate on closed engine")),this.on(mi.Closing,handleClosed),this.pcManager.publisher.once(Yi,e=>{const t=new Map;e.forEach(e=>{const i=e.codec.toLowerCase();var n;n=i,vi.includes(n)&&t.set(e.payload,i)}),this.emit(mi.RTPVideoMapUpdate,t)});try{yield this.pcManager.negotiate(i),e()}catch(e){e instanceof NegotiationError&&(this.fullReconnectOnNext=!0),this.handleDisconnect("negotiation",j.RR_UNKNOWN),e instanceof Error?t(e):t(new Error(String(e)))}finally{this.off(mi.Closing,handleClosed)}}))})}dataChannelForKind(e,t){if(t){if(e===te.LOSSY)return this.lossyDCSub;if(e===te.RELIABLE)return this.reliableDCSub}else{if(e===te.LOSSY)return this.lossyDC;if(e===te.RELIABLE)return this.reliableDC}}sendSyncState(e,t){var i,n,s,a;if(!this.pcManager)return void this.log.warn("sync state cannot be sent without peer connection setup",this.logContext);const c=this.pcManager.publisher.getLocalDescription(),l=this.pcManager.publisher.getRemoteDescription(),u=null===(i=this.pcManager.subscriber)||void 0===i?void 0:i.getRemoteDescription(),h=null===(n=this.pcManager.subscriber)||void 0===n?void 0:n.getLocalDescription(),p=null===(a=null===(s=this.signalOpts)||void 0===s?void 0:s.autoSubscribe)||void 0===a||a,m=new Array,g=new Array;e.forEach(e=>{e.isDesired!==p&&m.push(e.trackSid),e.isEnabled||g.push(e.trackSid)}),this.client.sendSyncState(new gt({answer:"publisher-only"===this.pcManager.mode?l?toProtoSessionDescription({sdp:l.sdp,type:l.type}):void 0:h?toProtoSessionDescription({sdp:h.sdp,type:h.type}):void 0,offer:"publisher-only"===this.pcManager.mode?c?toProtoSessionDescription({sdp:c.sdp,type:c.type}):void 0:u?toProtoSessionDescription({sdp:u.sdp,type:u.type}):void 0,subscription:new Ke({trackSids:m,subscribe:!p,participantTracks:[]}),publishTracks:getTrackPublicationInfo(t),dataChannels:this.dataChannelsInfo(),trackSidsDisabled:g,datachannelReceiveStates:this.reliableReceivedState.map((e,t)=>new ft({publisherSid:t,lastSeq:e}))}))}failNext(){this.shouldFailNext=!0}dataChannelsInfo(){const e=[],getInfo=(t,i)=>{void 0!==(null==t?void 0:t.id)&&null!==t.id&&e.push(new vt({label:t.label,id:t.id,target:i}))};return getInfo(this.dataChannelForKind(te.LOSSY),De.PUBLISHER),getInfo(this.dataChannelForKind(te.RELIABLE),De.PUBLISHER),getInfo(this.dataChannelForKind(te.LOSSY,!0),De.SUBSCRIBER),getInfo(this.dataChannelForKind(te.RELIABLE,!0),De.SUBSCRIBER),e}clearReconnectTimeout(){this.reconnectTimeout&&CriticalTimers.clearTimeout(this.reconnectTimeout)}clearPendingReconnect(){this.clearReconnectTimeout(),this.reconnectAttempts=0}registerOnLineListener(){isWeb()&&(window.addEventListener("online",this.handleBrowserOnLine),window.addEventListener("offline",this.handleBrowserOffline))}deregisterOnLineListener(){isWeb()&&(window.removeEventListener("online",this.handleBrowserOnLine),window.removeEventListener("offline",this.handleBrowserOffline))}getTrackIdForReceiver(e){var t;const i=null===(t=this.pcManager)||void 0===t?void 0:t.getMidForReceiver(e);if(i){const e=Object.entries(this.midToTrackId).find(e=>{let[t]=e;return t===i});if(e)return e[1]}}}function applyUserDataCompat(e,t){const i=e.participantIdentity?e.participantIdentity:t.participantIdentity;e.participantIdentity=i,t.participantIdentity=i;const n=0!==e.destinationIdentities.length?e.destinationIdentities:t.destinationIdentities;e.destinationIdentities=n,t.destinationIdentities=n}class BaseStreamReader{get info(){return this._info}validateBytesReceived(){let e=arguments.length>0&&void 0!==arguments[0]&&arguments[0];if("number"==typeof this.totalByteSize&&0!==this.totalByteSize){if(e&&this.bytesReceived<this.totalByteSize)throw new DataStreamError("Not enough chunk(s) received - expected ".concat(this.totalByteSize," bytes of data total, only received ").concat(this.bytesReceived," bytes"),li.Incomplete);if(this.bytesReceived>this.totalByteSize)throw new DataStreamError("Extra chunk(s) received - expected ".concat(this.totalByteSize," bytes of data total, received ").concat(this.bytesReceived," bytes"),li.LengthExceeded)}}constructor(e,t,i,n){this.reader=t,this.totalByteSize=i,this._info=e,this.bytesReceived=0,this.outOfBandFailureRejectingFuture=n}}class ByteStreamReader extends BaseStreamReader{handleChunkReceived(e){var t;this.bytesReceived+=e.content.byteLength,this.validateBytesReceived();const i=this.totalByteSize?this.bytesReceived/this.totalByteSize:void 0;null===(t=this.onProgress)||void 0===t||t.call(this,i)}[Symbol.asyncIterator](){const e=this.reader.getReader();let t=new Future,i=null,n=null;if(this.signal){const e=this.signal;n=()=>{var i;null===(i=t.reject)||void 0===i||i.call(t,e.reason)},e.addEventListener("abort",n),i=e}const cleanup=()=>{e.releaseLock(),i&&n&&i.removeEventListener("abort",n),this.signal=void 0};return{next:()=>__awaiter(this,void 0,void 0,function*(){var i,n;try{const{done:s,value:a}=yield Promise.race([e.read(),t.promise,null!==(n=null===(i=this.outOfBandFailureRejectingFuture)||void 0===i?void 0:i.promise)&&void 0!==n?n:new Promise(()=>{})]);return s?(this.validateBytesReceived(!0),{done:!0,value:void 0}):(this.handleChunkReceived(a),{done:!1,value:a.content})}catch(e){throw cleanup(),e}}),return(){return __awaiter(this,void 0,void 0,function*(){return cleanup(),{done:!0,value:void 0}})}}}withAbortSignal(e){return this.signal=e,this}readAll(){return __awaiter(this,arguments,void 0,function(){var e=this;let t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return function*(){var i,n,s,a;let c=new Set;const l=t.signal?e.withAbortSignal(t.signal):e;try{for(var u,h=!0,p=__asyncValues(l);!(i=(u=yield p.next()).done);h=!0){a=u.value,h=!1;const e=a;c.add(e)}}catch(e){n={error:e}}finally{try{h||i||!(s=p.return)||(yield s.call(p))}finally{if(n)throw n.error}}return Array.from(c)}()})}}class TextStreamReader extends BaseStreamReader{constructor(e,t,i,n){super(e,t,i,n),this.receivedChunks=new Map}handleChunkReceived(e){var t;const i=bigIntToNumber(e.chunkIndex),n=this.receivedChunks.get(i);if(n&&n.version>e.version)return;this.receivedChunks.set(i,e),this.bytesReceived+=e.content.byteLength,this.validateBytesReceived();const s=this.totalByteSize?this.bytesReceived/this.totalByteSize:void 0;null===(t=this.onProgress)||void 0===t||t.call(this,s)}[Symbol.asyncIterator](){const e=this.reader.getReader(),t=new TextDecoder("utf-8",{fatal:!0});let i=new Future,n=null,s=null;if(this.signal){const e=this.signal;s=()=>{var t;null===(t=i.reject)||void 0===t||t.call(i,e.reason)},e.addEventListener("abort",s),n=e}const cleanup=()=>{e.releaseLock(),n&&s&&n.removeEventListener("abort",s),this.signal=void 0};return{next:()=>__awaiter(this,void 0,void 0,function*(){var n,s;try{const{done:a,value:c}=yield Promise.race([e.read(),i.promise,null!==(s=null===(n=this.outOfBandFailureRejectingFuture)||void 0===n?void 0:n.promise)&&void 0!==s?s:new Promise(()=>{})]);if(a)return this.validateBytesReceived(!0),{done:!0,value:void 0};{let e;this.handleChunkReceived(c);try{e=t.decode(c.content)}catch(e){throw new DataStreamError("Cannot decode datastream chunk ".concat(c.chunkIndex," as text: ").concat(e),li.DecodeFailed)}return{done:!1,value:e}}}catch(e){throw cleanup(),e}}),return(){return __awaiter(this,void 0,void 0,function*(){return cleanup(),{done:!0,value:void 0}})}}}withAbortSignal(e){return this.signal=e,this}readAll(){return __awaiter(this,arguments,void 0,function(){var e=this;let t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return function*(){var i,n,s,a;let c="";const l=t.signal?e.withAbortSignal(t.signal):e;try{for(var u,h=!0,p=__asyncValues(l);!(i=(u=yield p.next()).done);h=!0){a=u.value,h=!1;c+=a}}catch(e){n={error:e}}finally{try{h||i||!(s=p.return)||(yield s.call(p))}finally{if(n)throw n.error}}return c}()})}}class IncomingDataStreamManager{constructor(){this.log=Bt,this.byteStreamControllers=new Map,this.textStreamControllers=new Map,this.byteStreamHandlers=new Map,this.textStreamHandlers=new Map}registerTextStreamHandler(e,t){if(this.textStreamHandlers.has(e))throw new DataStreamError('A text stream handler for topic "'.concat(e,'" has already been set.'),li.HandlerAlreadyRegistered);this.textStreamHandlers.set(e,t)}unregisterTextStreamHandler(e){this.textStreamHandlers.delete(e)}registerByteStreamHandler(e,t){if(this.byteStreamHandlers.has(e))throw new DataStreamError('A byte stream handler for topic "'.concat(e,'" has already been set.'),li.HandlerAlreadyRegistered);this.byteStreamHandlers.set(e,t)}unregisterByteStreamHandler(e){this.byteStreamHandlers.delete(e)}clearControllers(){this.byteStreamControllers.clear(),this.textStreamControllers.clear()}validateParticipantHasNoActiveDataStreams(e){var t,i,n,s;const a=Array.from(this.textStreamControllers.entries()).filter(t=>t[1].sendingParticipantIdentity===e),c=Array.from(this.byteStreamControllers.entries()).filter(t=>t[1].sendingParticipantIdentity===e);if(a.length>0||c.length>0){const l=new DataStreamError("Participant ".concat(e," unexpectedly disconnected in the middle of sending data"),li.AbnormalEnd);for(const[e,n]of c)null===(i=(t=n.outOfBandFailureRejectingFuture).reject)||void 0===i||i.call(t,l),this.byteStreamControllers.delete(e);for(const[e,t]of a)null===(s=(n=t.outOfBandFailureRejectingFuture).reject)||void 0===s||s.call(n,l),this.textStreamControllers.delete(e)}}handleDataStreamPacket(e,t){return __awaiter(this,void 0,void 0,function*(){switch(e.value.case){case"streamHeader":return this.handleStreamHeader(e.value.value,e.participantIdentity,t);case"streamChunk":return this.handleStreamChunk(e.value.value,t);case"streamTrailer":return this.handleStreamTrailer(e.value.value,t);default:throw new Error('DataPacket of value "'.concat(e.value.case,'" is not data stream related!'))}})}handleStreamHeader(e,t,i){return __awaiter(this,void 0,void 0,function*(){var n;if("byteHeader"===e.contentHeader.case){const s=this.byteStreamHandlers.get(e.topic);if(!s)return void this.log.debug("ignoring incoming byte stream due to no handler for topic",e.topic);let a;const c=new Future;c.promise.catch(e=>{this.log.error(e)});const l={id:e.streamId,name:null!==(n=e.contentHeader.value.name)&&void 0!==n?n:"unknown",mimeType:e.mimeType,size:e.totalLength?Number(e.totalLength):void 0,topic:e.topic,timestamp:bigIntToNumber(e.timestamp),attributes:e.attributes,encryptionType:i},u=new ReadableStream({start:i=>{if(a=i,this.textStreamControllers.has(e.streamId))throw new DataStreamError("A data stream read is already in progress for a stream with id ".concat(e.streamId,"."),li.AlreadyOpened);this.byteStreamControllers.set(e.streamId,{info:l,controller:a,startTime:Date.now(),sendingParticipantIdentity:t,outOfBandFailureRejectingFuture:c})}});s(new ByteStreamReader(l,u,bigIntToNumber(e.totalLength),c),{identity:t})}else if("textHeader"===e.contentHeader.case){const n=this.textStreamHandlers.get(e.topic);if(!n)return void this.log.debug("ignoring incoming text stream due to no handler for topic",e.topic);let s;const a=new Future;a.promise.catch(e=>{this.log.error(e)});const c={id:e.streamId,mimeType:e.mimeType,size:e.totalLength?Number(e.totalLength):void 0,topic:e.topic,timestamp:Number(e.timestamp),attributes:e.attributes,encryptionType:i},l=new ReadableStream({start:i=>{if(s=i,this.textStreamControllers.has(e.streamId))throw new DataStreamError("A data stream read is already in progress for a stream with id ".concat(e.streamId,"."),li.AlreadyOpened);this.textStreamControllers.set(e.streamId,{info:c,controller:s,startTime:Date.now(),sendingParticipantIdentity:t,outOfBandFailureRejectingFuture:a})}});n(new TextStreamReader(c,l,bigIntToNumber(e.totalLength),a),{identity:t})}})}handleStreamChunk(e,t){const i=this.byteStreamControllers.get(e.streamId);i&&(i.info.encryptionType!==t?(i.controller.error(new DataStreamError("Encryption type mismatch for stream ".concat(e.streamId,". Expected ").concat(t,", got ").concat(i.info.encryptionType),li.EncryptionTypeMismatch)),this.byteStreamControllers.delete(e.streamId)):e.content.length>0&&i.controller.enqueue(e));const n=this.textStreamControllers.get(e.streamId);n&&(n.info.encryptionType!==t?(n.controller.error(new DataStreamError("Encryption type mismatch for stream ".concat(e.streamId,". Expected ").concat(t,", got ").concat(n.info.encryptionType),li.EncryptionTypeMismatch)),this.textStreamControllers.delete(e.streamId)):e.content.length>0&&n.controller.enqueue(e))}handleStreamTrailer(e,t){const i=this.textStreamControllers.get(e.streamId);i&&(i.info.encryptionType!==t?i.controller.error(new DataStreamError("Encryption type mismatch for stream ".concat(e.streamId,". Expected ").concat(t,", got ").concat(i.info.encryptionType),li.EncryptionTypeMismatch)):(i.info.attributes=Object.assign(Object.assign({},i.info.attributes),e.attributes),i.controller.close(),this.textStreamControllers.delete(e.streamId)));const n=this.byteStreamControllers.get(e.streamId);n&&(n.info.encryptionType!==t?n.controller.error(new DataStreamError("Encryption type mismatch for stream ".concat(e.streamId,". Expected ").concat(t,", got ").concat(n.info.encryptionType),li.EncryptionTypeMismatch)):(n.info.attributes=Object.assign(Object.assign({},n.info.attributes),e.attributes),n.controller.close()),this.byteStreamControllers.delete(e.streamId))}}class BaseStreamWriter{constructor(e,t,i){this.writableStream=e,this.defaultWriter=e.getWriter(),this.onClose=i,this.info=t}write(e){return this.defaultWriter.write(e)}close(){return __awaiter(this,void 0,void 0,function*(){var e;yield this.defaultWriter.close(),this.defaultWriter.releaseLock(),null===(e=this.onClose)||void 0===e||e.call(this)})}}class TextStreamWriter extends BaseStreamWriter{}class ByteStreamWriter extends BaseStreamWriter{}class OutgoingDataStreamManager{constructor(e,t){this.engine=e,this.log=t}setupEngine(e){this.engine=e}sendText(e,t){return __awaiter(this,void 0,void 0,function*(){var i;const n=crypto.randomUUID(),s=(new TextEncoder).encode(e).byteLength,a=null===(i=null==t?void 0:t.attachments)||void 0===i?void 0:i.map(()=>crypto.randomUUID()),c=new Array(a?a.length+1:1).fill(0),handleProgress=(e,i)=>{var n;c[i]=e;const s=c.reduce((e,t)=>e+t,0);null===(n=null==t?void 0:t.onProgress)||void 0===n||n.call(t,s)},l=yield this.streamText({streamId:n,totalSize:s,destinationIdentities:null==t?void 0:t.destinationIdentities,topic:null==t?void 0:t.topic,attachedStreamIds:a,attributes:null==t?void 0:t.attributes});return yield l.write(e),handleProgress(1,0),yield l.close(),(null==t?void 0:t.attachments)&&a&&(yield Promise.all(t.attachments.map((e,i)=>__awaiter(this,void 0,void 0,function*(){return this._sendFile(a[i],e,{topic:t.topic,mimeType:e.type,onProgress:e=>{handleProgress(e,i+1)}})})))),l.info})}streamText(e){return __awaiter(this,void 0,void 0,function*(){var t,i,n;const s=null!==(t=null==e?void 0:e.streamId)&&void 0!==t?t:crypto.randomUUID(),a={id:s,mimeType:"text/plain",timestamp:Date.now(),topic:null!==(i=null==e?void 0:e.topic)&&void 0!==i?i:"",size:null==e?void 0:e.totalSize,attributes:null==e?void 0:e.attributes,encryptionType:(null===(n=this.engine.e2eeManager)||void 0===n?void 0:n.isDataChannelEncryptionEnabled)?Q.GCM:Q.NONE},c=new Re({streamId:s,mimeType:a.mimeType,topic:a.topic,timestamp:numberToBigInt(a.timestamp),totalLength:numberToBigInt(null==e?void 0:e.totalSize),attributes:a.attributes,contentHeader:{case:"textHeader",value:new we({version:null==e?void 0:e.version,attachedStreamIds:null==e?void 0:e.attachedStreamIds,replyToStreamId:null==e?void 0:e.replyToStreamId,operationType:"update"===(null==e?void 0:e.type)?Ee.UPDATE:Ee.CREATE})}}),l=null==e?void 0:e.destinationIdentities,u=new ee({destinationIdentities:l,value:{case:"streamHeader",value:c}});yield this.engine.sendDataPacket(u,te.RELIABLE);let h=0;const p=this.engine,m=new WritableStream({write(e){return __awaiter(this,void 0,void 0,function*(){for(const t of function(e,t){const i=[];let n=(new TextEncoder).encode(e);for(;n.length>t;){let e=t;for(;e>0;){const t=n[e];if(void 0!==t&&128!=(192&t))break;e--}i.push(n.slice(0,e)),n=n.slice(e)}return n.length>0&&i.push(n),i}(e,15e3)){const e=new _e({content:t,streamId:s,chunkIndex:numberToBigInt(h)}),i=new ee({destinationIdentities:l,value:{case:"streamChunk",value:e}});yield p.sendDataPacket(i,te.RELIABLE),h+=1}})},close(){return __awaiter(this,void 0,void 0,function*(){const e=new Ie({streamId:s}),t=new ee({destinationIdentities:l,value:{case:"streamTrailer",value:e}});yield p.sendDataPacket(t,te.RELIABLE)})},abort(e){console.log("Sink error:",e)}});let onEngineClose=()=>__awaiter(this,void 0,void 0,function*(){yield g.close()});p.once(mi.Closing,onEngineClose);const g=new TextStreamWriter(m,a,()=>this.engine.off(mi.Closing,onEngineClose));return g})}sendFile(e,t){return __awaiter(this,void 0,void 0,function*(){const i=crypto.randomUUID();return yield this._sendFile(i,e,t),{id:i}})}_sendFile(e,t,i){return __awaiter(this,void 0,void 0,function*(){var n;const s=yield this.streamBytes({streamId:e,totalSize:t.size,name:t.name,mimeType:null!==(n=null==i?void 0:i.mimeType)&&void 0!==n?n:t.type,topic:null==i?void 0:i.topic,destinationIdentities:null==i?void 0:i.destinationIdentities}),a=t.stream().getReader();for(;;){const{done:e,value:t}=yield a.read();if(e)break;yield s.write(t)}return yield s.close(),s.info})}streamBytes(e){return __awaiter(this,void 0,void 0,function*(){var t,i,n,s,a,c;const l=null!==(t=null==e?void 0:e.streamId)&&void 0!==t?t:crypto.randomUUID(),u=null==e?void 0:e.destinationIdentities,h={id:l,mimeType:null!==(i=null==e?void 0:e.mimeType)&&void 0!==i?i:"application/octet-stream",topic:null!==(n=null==e?void 0:e.topic)&&void 0!==n?n:"",timestamp:Date.now(),attributes:null==e?void 0:e.attributes,size:null==e?void 0:e.totalSize,name:null!==(s=null==e?void 0:e.name)&&void 0!==s?s:"unknown",encryptionType:(null===(a=this.engine.e2eeManager)||void 0===a?void 0:a.isDataChannelEncryptionEnabled)?Q.GCM:Q.NONE},p=new Re({totalLength:numberToBigInt(null!==(c=h.size)&&void 0!==c?c:0),mimeType:h.mimeType,streamId:l,topic:h.topic,timestamp:numberToBigInt(Date.now()),attributes:h.attributes,contentHeader:{case:"byteHeader",value:new Pe({name:h.name})}}),m=new ee({destinationIdentities:u,value:{case:"streamHeader",value:p}});yield this.engine.sendDataPacket(m,te.RELIABLE);let g=0;const v=new _,k=this.engine,b=this.log,y=new WritableStream({write(e){return __awaiter(this,void 0,void 0,function*(){const t=yield v.lock();let i=0;try{for(;i<e.byteLength;){const t=e.slice(i,i+15e3),n=new ee({destinationIdentities:u,value:{case:"streamChunk",value:new _e({content:t,streamId:l,chunkIndex:numberToBigInt(g)})}});yield k.sendDataPacket(n,te.RELIABLE),g+=1,i+=t.byteLength}}finally{t()}})},close(){return __awaiter(this,void 0,void 0,function*(){const e=new Ie({streamId:l}),t=new ee({destinationIdentities:u,value:{case:"streamTrailer",value:e}});yield k.sendDataPacket(t,te.RELIABLE)})},abort(e){b.error("Sink error:",e)}});return new ByteStreamWriter(y,h)})}}class RemoteTrack extends Track{constructor(e,t,i,n,s){super(e,i,s),this.sid=t,this.receiver=n}get isLocal(){return!1}setMuted(e){this.isMuted!==e&&(this.isMuted=e,this._mediaStreamTrack.enabled=!e,this.emit(e?gi.Muted:gi.Unmuted,this))}setMediaStream(e){this.mediaStream=e;const onRemoveTrack=t=>{t.track===this._mediaStreamTrack&&(e.removeEventListener("removetrack",onRemoveTrack),this.receiver&&"playoutDelayHint"in this.receiver&&(this.receiver.playoutDelayHint=void 0),this.receiver=void 0,this._currentBitrate=0,this.emit(gi.Ended,this))};e.addEventListener("removetrack",onRemoveTrack)}start(){this.startMonitor(),super.enable()}stop(){this.stopMonitor(),super.disable()}getRTCStatsReport(){return __awaiter(this,void 0,void 0,function*(){var e;if(!(null===(e=this.receiver)||void 0===e?void 0:e.getStats))return;return yield this.receiver.getStats()})}setPlayoutDelay(e){this.receiver?"playoutDelayHint"in this.receiver?this.receiver.playoutDelayHint=e:this.log.warn("Playout delay not supported in this browser"):this.log.warn("Cannot set playout delay, track already ended")}getPlayoutDelay(){if(this.receiver){if("playoutDelayHint"in this.receiver)return this.receiver.playoutDelayHint;this.log.warn("Playout delay not supported in this browser")}else this.log.warn("Cannot get playout delay, track already ended");return 0}startMonitor(){this.monitorInterval||(this.monitorInterval=setInterval(()=>this.monitorReceiver(),sn)),"undefined"!=typeof RTCRtpReceiver&&"getSynchronizationSources"in RTCRtpReceiver&&this.registerTimeSyncUpdate()}registerTimeSyncUpdate(){const loop=()=>{var e;this.timeSyncHandle=requestAnimationFrame(()=>loop());const t=null===(e=this.receiver)||void 0===e?void 0:e.getSynchronizationSources()[0];if(t){const{timestamp:e,rtpTimestamp:i}=t;i&&this.rtpTimestamp!==i&&(this.emit(gi.TimeSyncUpdate,{timestamp:e,rtpTimestamp:i}),this.rtpTimestamp=i)}};loop()}}class RemoteAudioTrack extends RemoteTrack{constructor(e,t,i,n,s,a){super(e,t,Track.Kind.Audio,i,a),this.monitorReceiver=()=>__awaiter(this,void 0,void 0,function*(){if(!this.receiver)return void(this._currentBitrate=0);const e=yield this.getReceiverStats();e&&this.prevStats&&this.receiver&&(this._currentBitrate=computeBitrate(e,this.prevStats)),this.prevStats=e}),this.audioContext=n,this.webAudioPluginNodes=[],s&&(this.sinkId=s.deviceId)}setVolume(e){var t;for(const i of this.attachedElements)this.audioContext?null===(t=this.gainNode)||void 0===t||t.gain.setTargetAtTime(e,0,.1):i.volume=e;isReactNative()&&this._mediaStreamTrack._setVolume(e),this.elementVolume=e}getVolume(){if(this.elementVolume)return this.elementVolume;if(isReactNative())return 1;let e=0;return this.attachedElements.forEach(t=>{t.volume>e&&(e=t.volume)}),e}setSinkId(e){return __awaiter(this,void 0,void 0,function*(){this.sinkId=e,yield Promise.all(this.attachedElements.map(t=>{if(supportsSetSinkId(t))return t.setSinkId(e)}))})}attach(e){const t=0===this.attachedElements.length;return e?super.attach(e):e=super.attach(),this.sinkId&&supportsSetSinkId(e)&&e.setSinkId(this.sinkId).catch(e=>{this.log.error("Failed to set sink id on remote audio track",e,this.logContext)}),this.audioContext&&t&&(this.log.debug("using audio context mapping",this.logContext),this.connectWebAudio(this.audioContext,e),e.volume=0,e.muted=!0),this.elementVolume&&this.setVolume(this.elementVolume),e}detach(e){let t;return e?(t=super.detach(e),this.audioContext&&(this.attachedElements.length>0?this.connectWebAudio(this.audioContext,this.attachedElements[0]):this.disconnectWebAudio())):(t=super.detach(),this.disconnectWebAudio()),t}setAudioContext(e){this.audioContext=e,e&&this.attachedElements.length>0?this.connectWebAudio(e,this.attachedElements[0]):e||this.disconnectWebAudio()}setWebAudioPlugins(e){this.webAudioPluginNodes=e,this.attachedElements.length>0&&this.audioContext&&this.connectWebAudio(this.audioContext,this.attachedElements[0])}connectWebAudio(e,t){this.disconnectWebAudio(),this.sourceNode=e.createMediaStreamSource(t.srcObject);let i=this.sourceNode;this.webAudioPluginNodes.forEach(e=>{i.connect(e),i=e}),this.gainNode=e.createGain(),i.connect(this.gainNode),this.gainNode.connect(e.destination),this.elementVolume&&this.gainNode.gain.setTargetAtTime(this.elementVolume,0,.1),"running"!==e.state&&e.resume().then(()=>{"running"!==e.state&&this.emit(gi.AudioPlaybackFailed,new Error("Audio Context couldn't be started automatically"))}).catch(e=>{this.emit(gi.AudioPlaybackFailed,e)})}disconnectWebAudio(){var e,t;null===(e=this.gainNode)||void 0===e||e.disconnect(),null===(t=this.sourceNode)||void 0===t||t.disconnect(),this.gainNode=void 0,this.sourceNode=void 0}getReceiverStats(){return __awaiter(this,void 0,void 0,function*(){if(!this.receiver||!this.receiver.getStats)return;let e;return(yield this.receiver.getStats()).forEach(t=>{"inbound-rtp"===t.type&&(e={type:"audio",streamId:t.id,timestamp:t.timestamp,jitter:t.jitter,bytesReceived:t.bytesReceived,concealedSamples:t.concealedSamples,concealmentEvents:t.concealmentEvents,silentConcealedSamples:t.silentConcealedSamples,silentConcealmentEvents:t.silentConcealmentEvents,totalAudioEnergy:t.totalAudioEnergy,totalSamplesDuration:t.totalSamplesDuration})}),e})}}class RemoteVideoTrack extends RemoteTrack{constructor(e,t,i,n,s){super(e,t,Track.Kind.Video,i,s),this.elementInfos=[],this.monitorReceiver=()=>__awaiter(this,void 0,void 0,function*(){if(!this.receiver)return void(this._currentBitrate=0);const e=yield this.getReceiverStats();e&&this.prevStats&&this.receiver&&(this._currentBitrate=computeBitrate(e,this.prevStats)),this.prevStats=e}),this.debouncedHandleResize=r(()=>{this.updateDimensions()},100),this.adaptiveStreamSettings=n}get isAdaptiveStream(){return void 0!==this.adaptiveStreamSettings}setStreamState(e){super.setStreamState(e),this.log.debug("setStreamState",e),this.isAdaptiveStream&&e===Track.StreamState.Active&&this.updateVisibility()}get mediaStreamTrack(){return this._mediaStreamTrack}setMuted(e){super.setMuted(e),this.attachedElements.forEach(t=>{e?detachTrack(this._mediaStreamTrack,t):attachToElement(this._mediaStreamTrack,t)})}attach(e){if(e?super.attach(e):e=super.attach(),this.adaptiveStreamSettings&&void 0===this.elementInfos.find(t=>t.element===e)){const t=new HTMLElementInfo(e);this.observeElementInfo(t)}return e}observeElementInfo(e){this.adaptiveStreamSettings&&void 0===this.elementInfos.find(t=>t===e)?(e.handleResize=()=>{this.debouncedHandleResize()},e.handleVisibilityChanged=()=>{this.updateVisibility()},this.elementInfos.push(e),e.observe(),this.debouncedHandleResize(),this.updateVisibility()):this.log.warn("visibility resize observer not triggered",this.logContext)}stopObservingElementInfo(e){if(!this.isAdaptiveStream)return void this.log.warn("stopObservingElementInfo ignored",this.logContext);const t=this.elementInfos.filter(t=>t===e);for(const e of t)e.stopObserving();this.elementInfos=this.elementInfos.filter(t=>t!==e),this.updateVisibility(),this.debouncedHandleResize()}detach(e){let t=[];if(e)return this.stopObservingElement(e),super.detach(e);t=super.detach();for(const e of t)this.stopObservingElement(e);return t}getDecoderImplementation(){var e;return null===(e=this.prevStats)||void 0===e?void 0:e.decoderImplementation}getReceiverStats(){return __awaiter(this,void 0,void 0,function*(){if(!this.receiver||!this.receiver.getStats)return;const e=yield this.receiver.getStats();let t,i="",n=new Map;return e.forEach(e=>{"inbound-rtp"===e.type?(i=e.codecId,t={type:"video",streamId:e.id,framesDecoded:e.framesDecoded,framesDropped:e.framesDropped,framesReceived:e.framesReceived,packetsReceived:e.packetsReceived,packetsLost:e.packetsLost,frameWidth:e.frameWidth,frameHeight:e.frameHeight,pliCount:e.pliCount,firCount:e.firCount,nackCount:e.nackCount,jitter:e.jitter,timestamp:e.timestamp,bytesReceived:e.bytesReceived,decoderImplementation:e.decoderImplementation}):"codec"===e.type&&n.set(e.id,e)}),t&&""!==i&&n.get(i)&&(t.mimeType=n.get(i).mimeType),t})}stopObservingElement(e){const t=this.elementInfos.filter(t=>t.element===e);for(const e of t)this.stopObservingElementInfo(e)}handleAppVisibilityChanged(){const e=Object.create(null,{handleAppVisibilityChanged:{get:()=>super.handleAppVisibilityChanged}});return __awaiter(this,void 0,void 0,function*(){yield e.handleAppVisibilityChanged.call(this),this.isAdaptiveStream&&this.updateVisibility()})}updateVisibility(e){var t,i;const n=this.elementInfos.reduce((e,t)=>Math.max(e,t.visibilityChangedAt||0),0),s=!(null!==(i=null===(t=this.adaptiveStreamSettings)||void 0===t?void 0:t.pauseVideoInBackground)&&void 0!==i&&!i)&&this.isInBackground,a=this.elementInfos.some(e=>e.pictureInPicture),c=this.elementInfos.some(e=>e.visible)&&!s||a;(this.lastVisible!==c||e)&&(!c&&Date.now()-n<100?CriticalTimers.setTimeout(()=>{this.updateVisibility()},100):(this.lastVisible=c,this.emit(gi.VisibilityChanged,c,this)))}updateDimensions(){var e,t;let i=0,n=0;const s=this.getPixelDensity();for(const e of this.elementInfos){const t=e.width()*s,a=e.height()*s;t+a>i+n&&(i=t,n=a)}(null===(e=this.lastDimensions)||void 0===e?void 0:e.width)===i&&(null===(t=this.lastDimensions)||void 0===t?void 0:t.height)===n||(this.lastDimensions={width:i,height:n},this.emit(gi.VideoDimensionsChanged,this.lastDimensions,this))}getPixelDensity(){var e;const t=null===(e=this.adaptiveStreamSettings)||void 0===e?void 0:e.pixelDensity;if("screen"===t)return getDevicePixelRatio();if(!t){return getDevicePixelRatio()>2?2:1}return t}}class HTMLElementInfo{get visible(){return this.isPiP||this.isIntersecting}get pictureInPicture(){return this.isPiP}constructor(e,t){this.onVisibilityChanged=e=>{var t;const{target:i,isIntersecting:n}=e;i===this.element&&(this.isIntersecting=n,this.isPiP=isElementInPiP(this.element),this.visibilityChangedAt=Date.now(),null===(t=this.handleVisibilityChanged)||void 0===t||t.call(this))},this.onEnterPiP=()=>{var e,t,i;null===(t=null===(e=window.documentPictureInPicture)||void 0===e?void 0:e.window)||void 0===t||t.addEventListener("pagehide",this.onLeavePiP),this.isPiP=isElementInPiP(this.element),null===(i=this.handleVisibilityChanged)||void 0===i||i.call(this)},this.onLeavePiP=()=>{var e;this.isPiP=isElementInPiP(this.element),null===(e=this.handleVisibilityChanged)||void 0===e||e.call(this)},this.element=e,this.isIntersecting=null!=t?t:isElementInViewport(e),this.isPiP=isWeb()&&isElementInPiP(e),this.visibilityChangedAt=0}width(){return this.element.clientWidth}height(){return this.element.clientHeight}observe(){var e,t,i;this.isIntersecting=isElementInViewport(this.element),this.isPiP=isElementInPiP(this.element),this.element.handleResize=()=>{var e;null===(e=this.handleResize)||void 0===e||e.call(this)},this.element.handleVisibilityChanged=this.onVisibilityChanged,getIntersectionObserver().observe(this.element),getResizeObserver().observe(this.element),this.element.addEventListener("enterpictureinpicture",this.onEnterPiP),this.element.addEventListener("leavepictureinpicture",this.onLeavePiP),null===(e=window.documentPictureInPicture)||void 0===e||e.addEventListener("enter",this.onEnterPiP),null===(i=null===(t=window.documentPictureInPicture)||void 0===t?void 0:t.window)||void 0===i||i.addEventListener("pagehide",this.onLeavePiP)}stopObserving(){var e,t,i,n,s;null===(e=getIntersectionObserver())||void 0===e||e.unobserve(this.element),null===(t=getResizeObserver())||void 0===t||t.unobserve(this.element),this.element.removeEventListener("enterpictureinpicture",this.onEnterPiP),this.element.removeEventListener("leavepictureinpicture",this.onLeavePiP),null===(i=window.documentPictureInPicture)||void 0===i||i.removeEventListener("enter",this.onEnterPiP),null===(s=null===(n=window.documentPictureInPicture)||void 0===n?void 0:n.window)||void 0===s||s.removeEventListener("pagehide",this.onLeavePiP)}}function isElementInPiP(e){var t,i;return document.pictureInPictureElement===e||!!(null===(t=window.documentPictureInPicture)||void 0===t?void 0:t.window)&&isElementInViewport(e,null===(i=window.documentPictureInPicture)||void 0===i?void 0:i.window)}function isElementInViewport(e,t){const i=t||window;let n=e.offsetTop,s=e.offsetLeft;const a=e.offsetWidth,c=e.offsetHeight,{hidden:l}=e,{display:u}=getComputedStyle(e);for(;e.offsetParent;)n+=(e=e.offsetParent).offsetTop,s+=e.offsetLeft;return n<i.pageYOffset+i.innerHeight&&s<i.pageXOffset+i.innerWidth&&n+c>i.pageYOffset&&s+a>i.pageXOffset&&!l&&"none"!==u}class TrackPublication extends Jt.EventEmitter{constructor(e,t,i,n){var s;super(),this.metadataMuted=!1,this.encryption=Q.NONE,this.log=Bt,this.handleMuted=()=>{this.emit(gi.Muted)},this.handleUnmuted=()=>{this.emit(gi.Unmuted)},this.log=getLogger(null!==(s=null==n?void 0:n.loggerName)&&void 0!==s?s:Ft.Publication),this.loggerContextCb=this.loggerContextCb,this.setMaxListeners(100),this.kind=e,this.trackSid=t,this.trackName=i,this.source=Track.Source.Unknown}setTrack(e){this.track&&(this.track.off(gi.Muted,this.handleMuted),this.track.off(gi.Unmuted,this.handleUnmuted)),this.track=e,e&&(e.on(gi.Muted,this.handleMuted),e.on(gi.Unmuted,this.handleUnmuted))}get logContext(){var e;return Object.assign(Object.assign({},null===(e=this.loggerContextCb)||void 0===e?void 0:e.call(this)),getLogContextFromTrack(this))}get isMuted(){return this.metadataMuted}get isEnabled(){return!0}get isSubscribed(){return void 0!==this.track}get isEncrypted(){return this.encryption!==Q.NONE}get audioTrack(){if(isAudioTrack(this.track))return this.track}get videoTrack(){if(isVideoTrack(this.track))return this.track}updateInfo(e){this.trackSid=e.sid,this.trackName=e.name,this.source=Track.sourceFromProto(e.source),this.mimeType=e.mimeType,this.kind===Track.Kind.Video&&e.width>0&&(this.dimensions={width:e.width,height:e.height},this.simulcasted=e.simulcast),this.encryption=e.encryption,this.trackInfo=e,this.log.debug("update publication info",Object.assign(Object.assign({},this.logContext),{info:e}))}}!function(e){var t,i;(t=e.SubscriptionStatus||(e.SubscriptionStatus={})).Desired="desired",t.Subscribed="subscribed",t.Unsubscribed="unsubscribed",(i=e.PermissionStatus||(e.PermissionStatus={})).Allowed="allowed",i.NotAllowed="not_allowed"}(TrackPublication||(TrackPublication={}));class LocalTrackPublication extends TrackPublication{get isUpstreamPaused(){var e;return null===(e=this.track)||void 0===e?void 0:e.isUpstreamPaused}constructor(e,t,i,n){super(e,t.sid,t.name,n),this.track=void 0,this.handleTrackEnded=()=>{this.emit(gi.Ended)},this.handleCpuConstrained=()=>{this.track&&isVideoTrack(this.track)&&this.emit(gi.CpuConstrained,this.track)},this.updateInfo(t),this.setTrack(i)}setTrack(e){this.track&&(this.track.off(gi.Ended,this.handleTrackEnded),this.track.off(gi.CpuConstrained,this.handleCpuConstrained)),super.setTrack(e),e&&(e.on(gi.Ended,this.handleTrackEnded),e.on(gi.CpuConstrained,this.handleCpuConstrained))}get isMuted(){return this.track?this.track.isMuted:super.isMuted}get audioTrack(){return super.audioTrack}get videoTrack(){return super.videoTrack}get isLocal(){return!0}mute(){return __awaiter(this,void 0,void 0,function*(){var e;return null===(e=this.track)||void 0===e?void 0:e.mute()})}unmute(){return __awaiter(this,void 0,void 0,function*(){var e;return null===(e=this.track)||void 0===e?void 0:e.unmute()})}pauseUpstream(){return __awaiter(this,void 0,void 0,function*(){var e;yield null===(e=this.track)||void 0===e?void 0:e.pauseUpstream()})}resumeUpstream(){return __awaiter(this,void 0,void 0,function*(){var e;yield null===(e=this.track)||void 0===e?void 0:e.resumeUpstream()})}getTrackFeatures(){var e;if(isAudioTrack(this.track)){const t=this.track.getSourceTrackSettings(),i=new Set;return t.autoGainControl&&i.add(V.TF_AUTO_GAIN_CONTROL),t.echoCancellation&&i.add(V.TF_ECHO_CANCELLATION),t.noiseSuppression&&i.add(V.TF_NOISE_SUPPRESSION),t.channelCount&&t.channelCount>1&&i.add(V.TF_STEREO),(null===(e=this.options)||void 0===e?void 0:e.dtx)||i.add(V.TF_NO_DTX),this.track.enhancedNoiseCancellation&&i.add(V.TF_ENHANCED_NOISE_CANCELLATION),Array.from(i.values())}return[]}}function createLocalTracks(e,t){return __awaiter(this,void 0,void 0,function*(){null!=e||(e={});let i=!1;const{audioProcessor:n,videoProcessor:s,optionsWithoutProcessor:a}=extractProcessorsFromOptions(e);let c=a.audio,l=a.video;if(n&&"object"==typeof a.audio&&(a.audio.processor=n),s&&"object"==typeof a.video&&(a.video.processor=s),e.audio&&"object"==typeof a.audio&&"string"==typeof a.audio.deviceId){const e=a.audio.deviceId;a.audio.deviceId={exact:e},i=!0,c=Object.assign(Object.assign({},a.audio),{deviceId:{ideal:e}})}if(a.video&&"object"==typeof a.video&&"string"==typeof a.video.deviceId){const e=a.video.deviceId;a.video.deviceId={exact:e},i=!0,l=Object.assign(Object.assign({},a.video),{deviceId:{ideal:e}})}!0===a.audio?a.audio={deviceId:"default"}:"object"==typeof a.audio&&null!==a.audio&&(a.audio=Object.assign(Object.assign({},a.audio),{deviceId:a.audio.deviceId||"default"})),!0===a.video?a.video={deviceId:"default"}:"object"!=typeof a.video||a.video.deviceId||(a.video.deviceId="default");const u=mergeDefaultOptions(a,Zi,en),h=constraintsForOptions(u),p=navigator.mediaDevices.getUserMedia(h);a.audio&&(DeviceManager.userMediaPromiseMap.set("audioinput",p),p.catch(()=>DeviceManager.userMediaPromiseMap.delete("audioinput"))),a.video&&(DeviceManager.userMediaPromiseMap.set("videoinput",p),p.catch(()=>DeviceManager.userMediaPromiseMap.delete("videoinput")));try{const e=yield p;return yield Promise.all(e.getTracks().map(i=>__awaiter(this,void 0,void 0,function*(){const a="audio"===i.kind;let c,l=a?u.audio:u.video;"boolean"!=typeof l&&l||(l={});const p=a?h.audio:h.video;"boolean"!=typeof p&&(c=p);const m=i.getSettings().deviceId;(null==c?void 0:c.deviceId)&&unwrapConstraint(c.deviceId)!==m?c.deviceId=m:c||(c={deviceId:m});const g=function(e,t,i){switch(e.kind){case"audio":return new LocalAudioTrack(e,t,!1,void 0,i);case"video":return new LocalVideoTrack(e,t,!1,i);default:throw new TrackInvalidError("unsupported track type: ".concat(e.kind))}}(i,c,t);return g.kind===Track.Kind.Video?g.source=Track.Source.Camera:g.kind===Track.Kind.Audio&&(g.source=Track.Source.Microphone),g.mediaStream=e,isAudioTrack(g)&&n?yield g.setProcessor(n):isVideoTrack(g)&&s&&(yield g.setProcessor(s)),g})))}catch(n){if(!i)throw n;return createLocalTracks(Object.assign(Object.assign({},e),{audio:c,video:l}),t)}})}var kn,bn;!function(e){e.Excellent="excellent",e.Good="good",e.Poor="poor",e.Lost="lost",e.Unknown="unknown"}(kn||(kn={}));class Participant extends Jt.EventEmitter{get logContext(){var e,t;return Object.assign({},null===(t=null===(e=this.loggerOptions)||void 0===e?void 0:e.loggerContextCb)||void 0===t?void 0:t.call(e))}get isEncrypted(){return this.trackPublications.size>0&&Array.from(this.trackPublications.values()).every(e=>e.isEncrypted)}get isAgent(){var e;return(null===(e=this.permissions)||void 0===e?void 0:e.agent)||this.kind===J.AGENT}get isActive(){var e;return(null===(e=this.participantInfo)||void 0===e?void 0:e.state)===K.ACTIVE}get kind(){return this._kind}get attributes(){return Object.freeze(Object.assign({},this._attributes))}constructor(e,t,i,n,s,a){let c=arguments.length>6&&void 0!==arguments[6]?arguments[6]:J.STANDARD;var l;super(),this.audioLevel=0,this.isSpeaking=!1,this._connectionQuality=kn.Unknown,this.log=Bt,this.log=getLogger(null!==(l=null==a?void 0:a.loggerName)&&void 0!==l?l:Ft.Participant),this.loggerOptions=a,this.setMaxListeners(100),this.sid=e,this.identity=t,this.name=i,this.metadata=n,this.audioTrackPublications=new Map,this.videoTrackPublications=new Map,this.trackPublications=new Map,this._kind=c,this._attributes=null!=s?s:{}}getTrackPublications(){return Array.from(this.trackPublications.values())}getTrackPublication(e){for(const[,t]of this.trackPublications)if(t.source===e)return t}getTrackPublicationByName(e){for(const[,t]of this.trackPublications)if(t.trackName===e)return t}waitUntilActive(){return this.isActive?Promise.resolve():(this.activeFuture||(this.activeFuture=new Future,this.once(pi.Active,()=>{var e,t;null===(t=null===(e=this.activeFuture)||void 0===e?void 0:e.resolve)||void 0===t||t.call(e),this.activeFuture=void 0})),this.activeFuture.promise)}get connectionQuality(){return this._connectionQuality}get isCameraEnabled(){var e;const t=this.getTrackPublication(Track.Source.Camera);return!(null===(e=null==t?void 0:t.isMuted)||void 0===e||e)}get isMicrophoneEnabled(){var e;const t=this.getTrackPublication(Track.Source.Microphone);return!(null===(e=null==t?void 0:t.isMuted)||void 0===e||e)}get isScreenShareEnabled(){return!!this.getTrackPublication(Track.Source.ScreenShare)}get isLocal(){return!1}get joinedAt(){return this.participantInfo?new Date(1e3*Number.parseInt(this.participantInfo.joinedAt.toString())):new Date}updateInfo(e){var t;return!(this.participantInfo&&this.participantInfo.sid===e.sid&&this.participantInfo.version>e.version)&&(this.identity=e.identity,this.sid=e.sid,this._setName(e.name),this._setMetadata(e.metadata),this._setAttributes(e.attributes),e.state===K.ACTIVE&&(null===(t=this.participantInfo)||void 0===t?void 0:t.state)!==K.ACTIVE&&this.emit(pi.Active),e.permission&&this.setPermissions(e.permission),this.participantInfo=e,!0)}_setMetadata(e){const t=this.metadata!==e,i=this.metadata;this.metadata=e,t&&this.emit(pi.ParticipantMetadataChanged,i)}_setName(e){const t=this.name!==e;this.name=e,t&&this.emit(pi.ParticipantNameChanged,e)}_setAttributes(e){const t=function(e,t){var i;void 0===e&&(e={}),void 0===t&&(t={});const n=[...Object.keys(t),...Object.keys(e)],s={};for(const a of n)e[a]!==t[a]&&(s[a]=null!==(i=t[a])&&void 0!==i?i:"");return s}(this.attributes,e);this._attributes=e,Object.keys(t).length>0&&this.emit(pi.AttributesChanged,t)}setPermissions(e){var t,i,n,s,a,c;const l=this.permissions,u=e.canPublish!==(null===(t=this.permissions)||void 0===t?void 0:t.canPublish)||e.canSubscribe!==(null===(i=this.permissions)||void 0===i?void 0:i.canSubscribe)||e.canPublishData!==(null===(n=this.permissions)||void 0===n?void 0:n.canPublishData)||e.hidden!==(null===(s=this.permissions)||void 0===s?void 0:s.hidden)||e.recorder!==(null===(a=this.permissions)||void 0===a?void 0:a.recorder)||e.canPublishSources.length!==this.permissions.canPublishSources.length||e.canPublishSources.some((e,t)=>{var i;return e!==(null===(i=this.permissions)||void 0===i?void 0:i.canPublishSources[t])})||e.canSubscribeMetrics!==(null===(c=this.permissions)||void 0===c?void 0:c.canSubscribeMetrics);return this.permissions=e,u&&this.emit(pi.ParticipantPermissionsChanged,l),u}setIsSpeaking(e){e!==this.isSpeaking&&(this.isSpeaking=e,e&&(this.lastSpokeAt=new Date),this.emit(pi.IsSpeakingChanged,e))}setConnectionQuality(e){const t=this._connectionQuality;this._connectionQuality=function(e){switch(e){case L.EXCELLENT:return kn.Excellent;case L.GOOD:return kn.Good;case L.POOR:return kn.Poor;case L.LOST:return kn.Lost;default:return kn.Unknown}}(e),t!==this._connectionQuality&&this.emit(pi.ConnectionQualityChanged,this._connectionQuality)}setDisconnected(){var e,t;this.activeFuture&&(null===(t=(e=this.activeFuture).reject)||void 0===t||t.call(e,new Error("Participant disconnected")),this.activeFuture=void 0)}setAudioContext(e){this.audioContext=e,this.audioTrackPublications.forEach(t=>isAudioTrack(t.track)&&t.track.setAudioContext(e))}addTrackPublication(e){e.on(gi.Muted,()=>{this.emit(pi.TrackMuted,e)}),e.on(gi.Unmuted,()=>{this.emit(pi.TrackUnmuted,e)});const t=e;switch(t.track&&(t.track.sid=e.trackSid),this.trackPublications.set(e.trackSid,e),e.kind){case Track.Kind.Audio:this.audioTrackPublications.set(e.trackSid,e);break;case Track.Kind.Video:this.videoTrackPublications.set(e.trackSid,e)}}}class LocalParticipant extends Participant{constructor(e,t,i,n,s,a){super(e,t,void 0,void 0,void 0,{loggerName:n.loggerName,loggerContextCb:()=>this.engine.logContext}),this.pendingPublishing=new Set,this.pendingPublishPromises=new Map,this.participantTrackPermissions=[],this.allParticipantsAllowedToSubscribe=!0,this.encryptionType=Q.NONE,this.enabledPublishVideoCodecs=[],this.pendingAcks=new Map,this.pendingResponses=new Map,this.handleReconnecting=()=>{this.reconnectFuture||(this.reconnectFuture=new Future)},this.handleReconnected=()=>{var e,t;null===(t=null===(e=this.reconnectFuture)||void 0===e?void 0:e.resolve)||void 0===t||t.call(e),this.reconnectFuture=void 0,this.updateTrackSubscriptionPermissions()},this.handleClosing=()=>{var e,t,i,n,s,a;this.reconnectFuture&&(this.reconnectFuture.promise.catch(e=>this.log.warn(e.message,this.logContext)),null===(t=null===(e=this.reconnectFuture)||void 0===e?void 0:e.reject)||void 0===t||t.call(e,new Error("Got disconnected during reconnection attempt")),this.reconnectFuture=void 0),this.signalConnectedFuture&&(null===(n=(i=this.signalConnectedFuture).reject)||void 0===n||n.call(i,new Error("Got disconnected without signal connected")),this.signalConnectedFuture=void 0),null===(a=null===(s=this.activeAgentFuture)||void 0===s?void 0:s.reject)||void 0===a||a.call(s,new Error("Got disconnected without active agent present")),this.activeAgentFuture=void 0,this.firstActiveAgent=void 0},this.handleSignalConnected=e=>{var t,i;e.participant&&this.updateInfo(e.participant),this.signalConnectedFuture||(this.signalConnectedFuture=new Future),null===(i=(t=this.signalConnectedFuture).resolve)||void 0===i||i.call(t)},this.handleSignalRequestResponse=e=>{const{requestId:t,reason:i,message:n}=e,s=this.pendingSignalRequests.get(t);s&&(i!==wt.OK&&s.reject(new SignalRequestError(n,i)),this.pendingSignalRequests.delete(t))},this.handleDataPacket=e=>{switch(e.value.case){case"rpcResponse":let t=e.value.value,i=null,n=null;"payload"===t.value.case?i=t.value.value:"error"===t.value.case&&(n=RpcError.fromProto(t.value.value)),this.handleIncomingRpcResponse(t.requestId,i,n);break;case"rpcAck":let s=e.value.value;this.handleIncomingRpcAck(s.requestId)}},this.updateTrackSubscriptionPermissions=()=>{this.log.debug("updating track subscription permissions",Object.assign(Object.assign({},this.logContext),{allParticipantsAllowed:this.allParticipantsAllowedToSubscribe,participantTrackPermissions:this.participantTrackPermissions})),this.engine.client.sendUpdateSubscriptionPermissions(this.allParticipantsAllowedToSubscribe,this.participantTrackPermissions.map(e=>function(e){var t,i,n;if(!e.participantSid&&!e.participantIdentity)throw new Error("Invalid track permission, must provide at least one of participantIdentity and participantSid");return new ut({participantIdentity:null!==(t=e.participantIdentity)&&void 0!==t?t:"",participantSid:null!==(i=e.participantSid)&&void 0!==i?i:"",allTracks:null!==(n=e.allowAll)&&void 0!==n&&n,trackSids:e.allowedTrackSids||[]})}(e)))},this.onTrackUnmuted=e=>{this.onTrackMuted(e,e.isUpstreamPaused)},this.onTrackMuted=(e,t)=>{void 0===t&&(t=!0),e.sid?this.engine.updateMuteStatus(e.sid,t):this.log.error("could not update mute status for unpublished track",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e)))},this.onTrackUpstreamPaused=e=>{this.log.debug("upstream paused",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e))),this.onTrackMuted(e,!0)},this.onTrackUpstreamResumed=e=>{this.log.debug("upstream resumed",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e))),this.onTrackMuted(e,e.isMuted)},this.onTrackFeatureUpdate=e=>{const t=this.audioTrackPublications.get(e.sid);t?this.engine.client.sendUpdateLocalAudioTrack(t.trackSid,t.getTrackFeatures()):this.log.warn("Could not update local audio track settings, missing publication for track ".concat(e.sid),this.logContext)},this.onTrackCpuConstrained=(e,t)=>{this.log.debug("track cpu constrained",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(t))),this.emit(pi.LocalTrackCpuConstrained,e,t)},this.handleSubscribedQualityUpdate=e=>__awaiter(this,void 0,void 0,function*(){var t,i,n,s,a;if(!(null===(a=this.roomOptions)||void 0===a?void 0:a.dynacast))return;const c=this.videoTrackPublications.get(e.trackSid);if(!c)return void this.log.warn("received subscribed quality update for unknown track",Object.assign(Object.assign({},this.logContext),{trackSid:e.trackSid}));if(!c.videoTrack)return;const l=yield c.videoTrack.setPublishingCodecs(e.subscribedCodecs);try{for(var u,h=!0,p=__asyncValues(l);!(t=(u=yield p.next()).done);h=!0){s=u.value,h=!1;const e=s;isBackupCodec(e)&&(this.log.debug("publish ".concat(e," for ").concat(c.videoTrack.sid),Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(c))),yield this.publishAdditionalCodecForTrack(c.videoTrack,e,c.options))}}catch(e){i={error:e}}finally{try{h||t||!(n=p.return)||(yield n.call(p))}finally{if(i)throw i.error}}}),this.handleLocalTrackUnpublished=e=>{const t=this.trackPublications.get(e.trackSid);t?this.unpublishTrack(t.track):this.log.warn("received unpublished event for unknown track",Object.assign(Object.assign({},this.logContext),{trackSid:e.trackSid}))},this.handleTrackEnded=e=>__awaiter(this,void 0,void 0,function*(){if(e.source===Track.Source.ScreenShare||e.source===Track.Source.ScreenShareAudio)this.log.debug("unpublishing local track due to TrackEnded",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e))),this.unpublishTrack(e);else if(e.isUserProvided)yield e.mute();else if(isLocalAudioTrack(e)||isLocalVideoTrack(e))try{if(isWeb())try{const t=yield null===navigator||void 0===navigator?void 0:navigator.permissions.query({name:e.source===Track.Source.Camera?"camera":"microphone"});if(t&&"denied"===t.state)throw this.log.warn("user has revoked access to ".concat(e.source),Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e))),t.onchange=()=>{"denied"!==t.state&&(e.isMuted||e.restartTrack(),t.onchange=null)},new Error("GetUserMedia Permission denied")}catch(e){}e.isMuted||(this.log.debug("track ended, attempting to use a different device",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e))),isLocalAudioTrack(e)?yield e.restartTrack({deviceId:"default"}):yield e.restartTrack())}catch(t){this.log.warn("could not restart track, muting instead",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e))),yield e.mute()}}),this.audioTrackPublications=new Map,this.videoTrackPublications=new Map,this.trackPublications=new Map,this.engine=i,this.roomOptions=n,this.setupEngine(i),this.activeDeviceMap=new Map([["audioinput","default"],["videoinput","default"],["audiooutput","default"]]),this.pendingSignalRequests=new Map,this.rpcHandlers=s,this.roomOutgoingDataStreamManager=a}get lastCameraError(){return this.cameraError}get lastMicrophoneError(){return this.microphoneError}get isE2EEEnabled(){return this.encryptionType!==Q.NONE}getTrackPublication(e){const t=super.getTrackPublication(e);if(t)return t}getTrackPublicationByName(e){const t=super.getTrackPublicationByName(e);if(t)return t}setupEngine(e){var t;this.engine=e,this.engine.on(mi.RemoteMute,(e,t)=>{const i=this.trackPublications.get(e);i&&i.track&&(t?i.mute():i.unmute())}),(null===(t=this.signalConnectedFuture)||void 0===t?void 0:t.isResolved)&&(this.signalConnectedFuture=void 0),this.engine.on(mi.Connected,this.handleReconnected).on(mi.SignalConnected,this.handleSignalConnected).on(mi.SignalRestarted,this.handleReconnected).on(mi.SignalResumed,this.handleReconnected).on(mi.Restarting,this.handleReconnecting).on(mi.Resuming,this.handleReconnecting).on(mi.LocalTrackUnpublished,this.handleLocalTrackUnpublished).on(mi.SubscribedQualityUpdate,this.handleSubscribedQualityUpdate).on(mi.Closing,this.handleClosing).on(mi.SignalRequestResponse,this.handleSignalRequestResponse).on(mi.DataPacketReceived,this.handleDataPacket)}setMetadata(e){return __awaiter(this,void 0,void 0,function*(){yield this.requestMetadataUpdate({metadata:e})})}setName(e){return __awaiter(this,void 0,void 0,function*(){yield this.requestMetadataUpdate({name:e})})}setAttributes(e){return __awaiter(this,void 0,void 0,function*(){yield this.requestMetadataUpdate({attributes:e})})}requestMetadataUpdate(e){return __awaiter(this,arguments,void 0,function(e){var t=this;let{metadata:i,name:n,attributes:s}=e;return function*(){return new TypedPromise((e,a)=>__awaiter(t,void 0,void 0,function*(){var t,c;try{let l=!1;const u=yield this.engine.client.sendUpdateLocalMetadata(null!==(t=null!=i?i:this.metadata)&&void 0!==t?t:"",null!==(c=null!=n?n:this.name)&&void 0!==c?c:"",s),h=performance.now();for(this.pendingSignalRequests.set(u,{resolve:e,reject:e=>{a(e),l=!0},values:{name:n,metadata:i,attributes:s}});performance.now()-h<5e3&&!l;){if((!n||this.name===n)&&(!i||this.metadata===i)&&(!s||Object.entries(s).every(e=>{let[t,i]=e;return this.attributes[t]===i||""===i&&!this.attributes[t]})))return this.pendingSignalRequests.delete(u),void e();yield sleep(50)}a(new SignalRequestError("Request to update local metadata timed out","TimeoutError"))}catch(e){e instanceof Error?a(e):a(new Error(String(e)))}}))}()})}setCameraEnabled(e,t,i){return this.setTrackEnabled(Track.Source.Camera,e,t,i)}setMicrophoneEnabled(e,t,i){return this.setTrackEnabled(Track.Source.Microphone,e,t,i)}setScreenShareEnabled(e,t,i){return this.setTrackEnabled(Track.Source.ScreenShare,e,t,i)}setE2EEEnabled(e){return __awaiter(this,void 0,void 0,function*(){this.encryptionType=e?Q.GCM:Q.NONE,yield this.republishAllTracks(void 0,!1)})}setTrackEnabled(e,t,i,n){return __awaiter(this,void 0,void 0,function*(){var s,a;this.log.debug("setTrackEnabled",Object.assign(Object.assign({},this.logContext),{source:e,enabled:t})),this.republishPromise&&(yield this.republishPromise);let c=this.getTrackPublication(e);if(t)if(c)yield c.unmute();else{let t;if(this.pendingPublishing.has(e)){const t=yield this.waitForPendingPublicationOfSource(e);return t||this.log.info("waiting for pending publication promise timed out",Object.assign(Object.assign({},this.logContext),{source:e})),yield null==t?void 0:t.unmute(),t}this.pendingPublishing.add(e);try{switch(e){case Track.Source.Camera:t=yield this.createTracks({video:null===(s=i)||void 0===s||s});break;case Track.Source.Microphone:t=yield this.createTracks({audio:null===(a=i)||void 0===a||a});break;case Track.Source.ScreenShare:t=yield this.createScreenTracks(Object.assign({},i));break;default:throw new TrackInvalidError(e)}}catch(i){throw null==t||t.forEach(e=>{e.stop()}),i instanceof Error&&this.emit(pi.MediaDevicesError,i,sourceToKind(e)),this.pendingPublishing.delete(e),i}for(const n of t){const t=Object.assign(Object.assign({},this.roomOptions.publishDefaults),i);e===Track.Source.Microphone&&isAudioTrack(n)&&t.preConnectBuffer&&(this.log.info("starting preconnect buffer for microphone",Object.assign({},this.logContext)),n.startPreConnectBuffer())}try{const e=[];for(const i of t)this.log.info("publishing track",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(i))),e.push(this.publishTrack(i,n));const i=yield Promise.all(e);[c]=i}catch(e){throw null==t||t.forEach(e=>{e.stop()}),e}finally{this.pendingPublishing.delete(e)}}else if(!(null==c?void 0:c.track)&&this.pendingPublishing.has(e)&&(c=yield this.waitForPendingPublicationOfSource(e),c||this.log.info("waiting for pending publication promise timed out",Object.assign(Object.assign({},this.logContext),{source:e}))),c&&c.track)if(e===Track.Source.ScreenShare){c=yield this.unpublishTrack(c.track);const e=this.getTrackPublication(Track.Source.ScreenShareAudio);e&&e.track&&this.unpublishTrack(e.track)}else yield c.mute();return c})}enableCameraAndMicrophone(){return __awaiter(this,void 0,void 0,function*(){if(!this.pendingPublishing.has(Track.Source.Camera)&&!this.pendingPublishing.has(Track.Source.Microphone)){this.pendingPublishing.add(Track.Source.Camera),this.pendingPublishing.add(Track.Source.Microphone);try{const e=yield this.createTracks({audio:!0,video:!0});yield Promise.all(e.map(e=>this.publishTrack(e)))}finally{this.pendingPublishing.delete(Track.Source.Camera),this.pendingPublishing.delete(Track.Source.Microphone)}}})}createTracks(e){return __awaiter(this,void 0,void 0,function*(){var t,i;null!=e||(e={});const n=mergeDefaultOptions(e,null===(t=this.roomOptions)||void 0===t?void 0:t.audioCaptureDefaults,null===(i=this.roomOptions)||void 0===i?void 0:i.videoCaptureDefaults);try{const e=yield createLocalTracks(n,{loggerName:this.roomOptions.loggerName,loggerContextCb:()=>this.logContext});return e.map(e=>(isAudioTrack(e)&&(this.microphoneError=void 0,e.setAudioContext(this.audioContext),e.source=Track.Source.Microphone,this.emit(pi.AudioStreamAcquired)),isVideoTrack(e)&&(this.cameraError=void 0,e.source=Track.Source.Camera),e))}catch(t){throw t instanceof Error&&(e.audio&&(this.microphoneError=t),e.video&&(this.cameraError=t)),t}})}createScreenTracks(e){return __awaiter(this,void 0,void 0,function*(){if(void 0===e&&(e={}),void 0===navigator.mediaDevices.getDisplayMedia)throw new DeviceUnsupportedError("getDisplayMedia not supported");void 0!==e.resolution||function(){const e=getBrowser();return"Safari"===(null==e?void 0:e.name)&&e.version.startsWith("17.")||"iOS"===(null==e?void 0:e.os)&&!!(null==e?void 0:e.osVersion)&&compareVersions(e.osVersion,"17")>=0}()||(e.resolution=Ci.h1080fps30.resolution);const t=function(e){var t,i;let n=null===(t=e.video)||void 0===t||t;return e.resolution&&e.resolution.width>0&&e.resolution.height>0&&(n="boolean"==typeof n?{}:n,n=isSafari()?Object.assign(Object.assign({},n),{width:{max:e.resolution.width},height:{max:e.resolution.height},frameRate:e.resolution.frameRate}):Object.assign(Object.assign({},n),{width:{ideal:e.resolution.width},height:{ideal:e.resolution.height},frameRate:e.resolution.frameRate})),{audio:null!==(i=e.audio)&&void 0!==i&&i,video:n,controller:e.controller,selfBrowserSurface:e.selfBrowserSurface,surfaceSwitching:e.surfaceSwitching,systemAudio:e.systemAudio,preferCurrentTab:e.preferCurrentTab}}(e),i=yield navigator.mediaDevices.getDisplayMedia(t),n=i.getVideoTracks();if(0===n.length)throw new TrackInvalidError("no video track found");const s=new LocalVideoTrack(n[0],void 0,!1,{loggerName:this.roomOptions.loggerName,loggerContextCb:()=>this.logContext});s.source=Track.Source.ScreenShare,e.contentHint&&(s.mediaStreamTrack.contentHint=e.contentHint);const a=[s];if(i.getAudioTracks().length>0){this.emit(pi.AudioStreamAcquired);const e=new LocalAudioTrack(i.getAudioTracks()[0],void 0,!1,this.audioContext,{loggerName:this.roomOptions.loggerName,loggerContextCb:()=>this.logContext});e.source=Track.Source.ScreenShareAudio,a.push(e)}return a})}publishTrack(e,t){return __awaiter(this,void 0,void 0,function*(){return this.publishOrRepublishTrack(e,t)})}publishOrRepublishTrack(e,t){return __awaiter(this,arguments,void 0,function(e,t){var i=this;let n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function*(){var s,a,c,l;let u,h;if(isLocalAudioTrack(e)&&e.setAudioContext(i.audioContext),yield null===(s=i.reconnectFuture)||void 0===s?void 0:s.promise,i.republishPromise&&!n&&(yield i.republishPromise),isLocalTrack(e)&&i.pendingPublishPromises.has(e)&&(yield i.pendingPublishPromises.get(e)),e instanceof MediaStreamTrack)u=e.getConstraints();else{let t;switch(u=e.constraints,e.source){case Track.Source.Microphone:t="audioinput";break;case Track.Source.Camera:t="videoinput"}t&&i.activeDeviceMap.has(t)&&(u=Object.assign(Object.assign({},u),{deviceId:i.activeDeviceMap.get(t)}))}if(e instanceof MediaStreamTrack)switch(e.kind){case"audio":e=new LocalAudioTrack(e,u,!0,i.audioContext,{loggerName:i.roomOptions.loggerName,loggerContextCb:()=>i.logContext});break;case"video":e=new LocalVideoTrack(e,u,!0,{loggerName:i.roomOptions.loggerName,loggerContextCb:()=>i.logContext});break;default:throw new TrackInvalidError("unsupported MediaStreamTrack kind ".concat(e.kind))}else e.updateLoggerOptions({loggerName:i.roomOptions.loggerName,loggerContextCb:()=>i.logContext});if(i.trackPublications.forEach(t=>{t.track&&t.track===e&&(h=t)}),h)return i.log.warn("track has already been published, skipping",Object.assign(Object.assign({},i.logContext),getLogContextFromTrack(h))),h;const p=Object.assign(Object.assign({},i.roomOptions.publishDefaults),t),m="channelCount"in e.mediaStreamTrack.getSettings()&&2===e.mediaStreamTrack.getSettings().channelCount||2===e.mediaStreamTrack.getConstraints().channelCount,g=null!==(a=p.forceStereo)&&void 0!==a?a:m;g&&(void 0===p.dtx&&i.log.info("Opus DTX will be disabled for stereo tracks by default. Enable them explicitly to make it work.",Object.assign(Object.assign({},i.logContext),getLogContextFromTrack(e))),void 0===p.red&&i.log.info("Opus RED will be disabled for stereo tracks by default. Enable them explicitly to make it work."),null!==(c=p.dtx)&&void 0!==c||(p.dtx=!1),null!==(l=p.red)&&void 0!==l||(p.red=!1)),!function(){const e=getBrowser(),t="17.2";if(e)return"Safari"!==e.name&&"iOS"!==e.os||!!("iOS"===e.os&&e.osVersion&&compareVersions(e.osVersion,t)>=0)||"Safari"===e.name&&compareVersions(e.version,t)>=0}()&&i.roomOptions.e2ee&&(i.log.info("End-to-end encryption is set up, simulcast publishing will be disabled on Safari versions and iOS browsers running iOS < v17.2",Object.assign({},i.logContext)),p.simulcast=!1),p.source&&(e.source=p.source);const v=new Promise((t,n)=>__awaiter(i,void 0,void 0,function*(){try{if(this.engine.client.currentState!==Fi.CONNECTED){this.log.debug("deferring track publication until signal is connected",Object.assign(Object.assign({},this.logContext),{track:getLogContextFromTrack(e)}));let i=!1;const s=setTimeout(()=>{i=!0,e.stop(),n(new PublishTrackError("publishing rejected as engine not connected within timeout",408))},15e3);if(yield this.waitUntilEngineConnected(),clearTimeout(s),i)return;const a=yield this.publish(e,p,g);t(a)}else try{const i=yield this.publish(e,p,g);t(i)}catch(e){n(e)}}catch(e){n(e)}}));i.pendingPublishPromises.set(e,v);try{return yield v}catch(e){throw e}finally{i.pendingPublishPromises.delete(e)}}()})}waitUntilEngineConnected(){return this.signalConnectedFuture||(this.signalConnectedFuture=new Future),this.signalConnectedFuture.promise}hasPermissionsToPublish(e){if(!this.permissions)return this.log.warn("no permissions present for publishing track",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e))),!1;const{canPublish:t,canPublishSources:i}=this.permissions;return!(!t||0!==i.length&&!i.map(e=>function(e){switch(e){case A.CAMERA:return Track.Source.Camera;case A.MICROPHONE:return Track.Source.Microphone;case A.SCREEN_SHARE:return Track.Source.ScreenShare;case A.SCREEN_SHARE_AUDIO:return Track.Source.ScreenShareAudio;default:return Track.Source.Unknown}}(e)).includes(e.source))||(this.log.warn("insufficient permissions to publish",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e))),!1)}publish(e,t,i){return __awaiter(this,void 0,void 0,function*(){var n,s,a,c,l,u,h,p,m,g;if(!this.hasPermissionsToPublish(e))throw new PublishTrackError("failed to publish track, insufficient permissions",403);Array.from(this.trackPublications.values()).find(t=>isLocalTrack(e)&&t.source===e.source)&&e.source!==Track.Source.Unknown&&this.log.info("publishing a second track with the same source: ".concat(e.source),Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e))),t.stopMicTrackOnMute&&isAudioTrack(e)&&(e.stopOnMute=!0),e.source===Track.Source.ScreenShare&&isFireFox()&&(t.simulcast=!1),"av1"!==t.videoCodec||function(){if(!("getCapabilities"in RTCRtpSender))return!1;if(isSafari()||isFireFox())return!1;const e=RTCRtpSender.getCapabilities("video");let t=!1;if(e)for(const i of e.codecs)if("video/av1"===i.mimeType.toLowerCase()){t=!0;break}return t}()||(t.videoCodec=void 0),"vp9"!==t.videoCodec||function(){if(!("getCapabilities"in RTCRtpSender))return!1;if(isFireFox())return!1;if(isSafari()){const e=getBrowser();if((null==e?void 0:e.version)&&compareVersions(e.version,"16")<0)return!1;if("iOS"===(null==e?void 0:e.os)&&(null==e?void 0:e.osVersion)&&compareVersions(e.osVersion,"16")<0)return!1}const e=RTCRtpSender.getCapabilities("video");let t=!1;if(e)for(const i of e.codecs)if("video/vp9"===i.mimeType.toLowerCase()){t=!0;break}return t}()||(t.videoCodec=void 0),void 0===t.videoCodec&&(t.videoCodec=$i),this.enabledPublishVideoCodecs.length>0&&(this.enabledPublishVideoCodecs.some(e=>t.videoCodec===mimeTypeToVideoCodecString(e.mime))||(t.videoCodec=mimeTypeToVideoCodecString(this.enabledPublishVideoCodecs[0].mime)));const v=t.videoCodec;e.on(gi.Muted,this.onTrackMuted),e.on(gi.Unmuted,this.onTrackUnmuted),e.on(gi.Ended,this.handleTrackEnded),e.on(gi.UpstreamPaused,this.onTrackUpstreamPaused),e.on(gi.UpstreamResumed,this.onTrackUpstreamResumed),e.on(gi.AudioTrackFeatureUpdate,this.onTrackFeatureUpdate);const k=[],b=!(null===(n=t.dtx)||void 0===n||n),y=e.getSourceTrackSettings();y.autoGainControl&&k.push(V.TF_AUTO_GAIN_CONTROL),y.echoCancellation&&k.push(V.TF_ECHO_CANCELLATION),y.noiseSuppression&&k.push(V.TF_NOISE_SUPPRESSION),y.channelCount&&y.channelCount>1&&k.push(V.TF_STEREO),b&&k.push(V.TF_NO_DTX),isLocalAudioTrack(e)&&e.hasPreConnectBuffer&&k.push(V.TF_PRECONNECT_BUFFER);const T=new Ue({cid:e.mediaStreamTrack.id,name:t.name,type:Track.kindToProto(e.kind),muted:e.isMuted,source:Track.sourceToProto(e.source),disableDtx:b,encryption:this.encryptionType,stereo:i,disableRed:this.isE2EEEnabled||!(null===(s=t.red)||void 0===s||s),stream:null==t?void 0:t.stream,backupCodecPolicy:null==t?void 0:t.backupCodecPolicy,audioFeatures:k});let C;if(e.kind===Track.Kind.Video){let i={width:0,height:0};try{i=yield e.waitForDimensions()}catch(t){const n=null!==(c=null===(a=this.roomOptions.videoCaptureDefaults)||void 0===a?void 0:a.resolution)&&void 0!==c?c:yi.h720.resolution;i={width:n.width,height:n.height},this.log.error("could not determine track dimensions, using defaults",Object.assign(Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e)),{dims:i}))}T.width=i.width,T.height=i.height,isLocalVideoTrack(e)&&(isSVCCodec(v)&&(e.source===Track.Source.ScreenShare&&(t.scalabilityMode="L1T3","contentHint"in e.mediaStreamTrack&&(e.mediaStreamTrack.contentHint="motion",this.log.info("forcing contentHint to motion for screenshare with SVC codecs",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e))))),t.scalabilityMode=null!==(l=t.scalabilityMode)&&void 0!==l?l:"L3T3_KEY"),T.simulcastCodecs=[new Le({codec:v,cid:e.mediaStreamTrack.id})],!0===t.backupCodec&&(t.backupCodec={codec:$i}),t.backupCodec&&v!==t.backupCodec.codec&&T.encryption===Q.NONE&&(this.roomOptions.dynacast||(this.roomOptions.dynacast=!0),T.simulcastCodecs.push(new Le({codec:t.backupCodec.codec,cid:""})))),C=computeVideoEncodings(e.source===Track.Source.ScreenShare,T.width,T.height,t),T.layers=videoLayersFromEncodings(T.width,T.height,C,isSVCCodec(t.videoCodec))}else e.kind===Track.Kind.Audio&&(C=[{maxBitrate:null===(u=t.audioPreset)||void 0===u?void 0:u.maxBitrate,priority:null!==(p=null===(h=t.audioPreset)||void 0===h?void 0:h.priority)&&void 0!==p?p:"high",networkPriority:null!==(g=null===(m=t.audioPreset)||void 0===m?void 0:m.priority)&&void 0!==g?g:"high"}]);if(!this.engine||this.engine.isClosed)throw new UnexpectedConnectionState("cannot publish track when not connected");const negotiate=()=>__awaiter(this,void 0,void 0,function*(){var i,n,s;if(!this.engine.pcManager)throw new UnexpectedConnectionState("pcManager is not ready");if(e.sender=yield this.engine.createSender(e,t,C),this.emit(pi.LocalSenderCreated,e.sender,e),isLocalVideoTrack(e)&&(null!==(i=t.degradationPreference)&&void 0!==i||(t.degradationPreference=function(e){return e.source===Track.Source.ScreenShare||e.constraints.height&&unwrapConstraint(e.constraints.height)>=1080?"maintain-resolution":"balanced"}(e)),e.setDegradationPreference(t.degradationPreference)),C)if(isFireFox()&&e.kind===Track.Kind.Audio){let t;for(const i of this.engine.pcManager.publisher.getTransceivers())if(i.sender===e.sender){t=i;break}t&&this.engine.pcManager.publisher.setTrackCodecBitrate({transceiver:t,codec:"opus",maxbr:(null===(n=C[0])||void 0===n?void 0:n.maxBitrate)?C[0].maxBitrate/1e3:0})}else e.codec&&isSVCCodec(e.codec)&&(null===(s=C[0])||void 0===s?void 0:s.maxBitrate)&&this.engine.pcManager.publisher.setTrackCodecBitrate({cid:T.cid,codec:e.codec,maxbr:C[0].maxBitrate/1e3});yield this.engine.negotiate()});let S;const E=new Promise((t,i)=>__awaiter(this,void 0,void 0,function*(){var n;try{S=yield this.engine.addTrack(T),t(S)}catch(t){e.sender&&(null===(n=this.engine.pcManager)||void 0===n?void 0:n.publisher)&&(this.engine.pcManager.publisher.removeTrack(e.sender),yield this.engine.negotiate().catch(t=>{this.log.error("failed to negotiate after removing track due to failed add track request",Object.assign(Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e)),{error:t}))})),i(t)}}));if(this.enabledPublishVideoCodecs.length>0){const e=yield Promise.all([E,negotiate()]);S=e[0]}else{let i;if(S=yield E,S.codecs.forEach(e=>{void 0===i&&(i=e.mimeType)}),i&&e.kind===Track.Kind.Video){const n=mimeTypeToVideoCodecString(i);n!==v&&(this.log.debug("falling back to server selected codec",Object.assign(Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e)),{codec:n})),t.videoCodec=n,C=computeVideoEncodings(e.source===Track.Source.ScreenShare,T.width,T.height,t))}yield negotiate()}const w=new LocalTrackPublication(e.kind,S,e,{loggerName:this.roomOptions.loggerName,loggerContextCb:()=>this.logContext});if(w.on(gi.CpuConstrained,e=>this.onTrackCpuConstrained(e,w)),w.options=t,e.sid=S.sid,this.log.debug("publishing ".concat(e.kind," with encodings"),Object.assign(Object.assign({},this.logContext),{encodings:C,trackInfo:S})),isLocalVideoTrack(e)?e.startMonitor(this.engine.client):isLocalAudioTrack(e)&&e.startMonitor(),this.addTrackPublication(w),this.emit(pi.LocalTrackPublished,w),isLocalAudioTrack(e)&&S.audioFeatures.includes(V.TF_PRECONNECT_BUFFER)){const t=e.getPreConnectBuffer(),i=e.getPreConnectBufferMimeType();if(this.on(pi.LocalTrackSubscribed,t=>{if(t.trackSid===S.sid){if(!e.hasPreConnectBuffer)return void this.log.warn("subscribe event came to late, buffer already closed",this.logContext);this.log.debug("finished recording preconnect buffer",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e))),e.stopPreConnectBuffer()}}),t){const n=new Promise((n,s)=>__awaiter(this,void 0,void 0,function*(){var a,c,l,u,h,p;try{this.log.debug("waiting for agent",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e)));const k=setTimeout(()=>{s(new Error("agent not active within 10 seconds"))},1e4),b=yield this.waitUntilActiveAgentPresent();clearTimeout(k),this.log.debug("sending preconnect buffer",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e)));const T=yield this.streamBytes({name:"preconnect-buffer",mimeType:i,topic:"lk.agent.pre-connect-audio-buffer",destinationIdentities:[b.identity],attributes:{trackId:w.trackSid,sampleRate:String(null!==(h=y.sampleRate)&&void 0!==h?h:"48000"),channels:String(null!==(p=y.channelCount)&&void 0!==p?p:"1")}});try{for(var m,g=!0,v=__asyncValues(t);!(a=(m=yield v.next()).done);g=!0){u=m.value,g=!1;const e=u;yield T.write(e)}}catch(e){c={error:e}}finally{try{g||a||!(l=v.return)||(yield l.call(v))}finally{if(c)throw c.error}}yield T.close(),n()}catch(e){s(e)}}));n.then(()=>{this.log.debug("preconnect buffer sent successfully",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e)))}).catch(t=>{this.log.error("error sending preconnect buffer",Object.assign(Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e)),{error:t}))})}}return w})}get isLocal(){return!0}publishAdditionalCodecForTrack(e,t,i){return __awaiter(this,void 0,void 0,function*(){var n;if(this.encryptionType!==Q.NONE)return;let s;if(this.trackPublications.forEach(t=>{t.track&&t.track===e&&(s=t)}),!s)throw new TrackInvalidError("track is not published");if(!isLocalVideoTrack(e))throw new TrackInvalidError("track is not a video track");const a=Object.assign(Object.assign({},null===(n=this.roomOptions)||void 0===n?void 0:n.publishDefaults),i),c=function(e,t,i){var n,s,a,c;if(!i.backupCodec||!0===i.backupCodec||i.backupCodec.codec===i.videoCodec)return;t!==i.backupCodec.codec&&Bt.warn("requested a different codec than specified as backup",{serverRequested:t,backup:i.backupCodec.codec}),i.videoCodec=t,i.videoEncoding=i.backupCodec.encoding;const l=e.mediaStreamTrack.getSettings(),u=null!==(n=l.width)&&void 0!==n?n:null===(s=e.dimensions)||void 0===s?void 0:s.width,h=null!==(a=l.height)&&void 0!==a?a:null===(c=e.dimensions)||void 0===c?void 0:c.height;return e.source===Track.Source.ScreenShare&&i.simulcast&&(i.simulcast=!1),computeVideoEncodings(e.source===Track.Source.ScreenShare,u,h,i)}(e,t,a);if(!c)return void this.log.info("backup codec has been disabled, ignoring request to add additional codec for track",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e)));const l=e.addSimulcastTrack(t,c);if(!l)return;const u=new Ue({cid:l.mediaStreamTrack.id,type:Track.kindToProto(e.kind),muted:e.isMuted,source:Track.sourceToProto(e.source),sid:e.sid,simulcastCodecs:[{codec:a.videoCodec,cid:l.mediaStreamTrack.id}]});if(u.layers=videoLayersFromEncodings(u.width,u.height,c),!this.engine||this.engine.isClosed)throw new UnexpectedConnectionState("cannot publish track when not connected");const h=(yield Promise.all([this.engine.addTrack(u),(()=>__awaiter(this,void 0,void 0,function*(){yield this.engine.createSimulcastSender(e,l,a,c),yield this.engine.negotiate()}))()]))[0];this.log.debug("published ".concat(t," for track ").concat(e.sid),Object.assign(Object.assign({},this.logContext),{encodings:c,trackInfo:h}))})}unpublishTrack(e,t){return __awaiter(this,void 0,void 0,function*(){var i,n;if(isLocalTrack(e)){const t=this.pendingPublishPromises.get(e);t&&(this.log.info("awaiting publish promise before attempting to unpublish",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e))),yield t)}const s=this.getPublicationForTrack(e),a=s?getLogContextFromTrack(s):void 0;if(this.log.debug("unpublishing track",Object.assign(Object.assign({},this.logContext),a)),!s||!s.track)return void this.log.warn("track was not unpublished because no publication was found",Object.assign(Object.assign({},this.logContext),a));(e=s.track).off(gi.Muted,this.onTrackMuted),e.off(gi.Unmuted,this.onTrackUnmuted),e.off(gi.Ended,this.handleTrackEnded),e.off(gi.UpstreamPaused,this.onTrackUpstreamPaused),e.off(gi.UpstreamResumed,this.onTrackUpstreamResumed),e.off(gi.AudioTrackFeatureUpdate,this.onTrackFeatureUpdate),void 0===t&&(t=null===(n=null===(i=this.roomOptions)||void 0===i?void 0:i.stopLocalTrackOnUnpublish)||void 0===n||n),t?e.stop():e.stopMonitor();let c=!1;const l=e.sender;if(e.sender=void 0,this.engine.pcManager&&this.engine.pcManager.currentState<rn.FAILED&&l)try{for(const e of this.engine.pcManager.publisher.getTransceivers())e.sender===l&&(e.direction="inactive",c=!0);if(this.engine.removeTrack(l)&&(c=!0),isLocalVideoTrack(e)){for(const[,t]of e.simulcastCodecs)t.sender&&(this.engine.removeTrack(t.sender)&&(c=!0),t.sender=void 0);e.simulcastCodecs.clear()}}catch(e){this.log.warn("failed to unpublish track",Object.assign(Object.assign(Object.assign({},this.logContext),a),{error:e}))}switch(this.trackPublications.delete(s.trackSid),s.kind){case Track.Kind.Audio:this.audioTrackPublications.delete(s.trackSid);break;case Track.Kind.Video:this.videoTrackPublications.delete(s.trackSid)}return this.emit(pi.LocalTrackUnpublished,s),s.setTrack(void 0),c&&(yield this.engine.negotiate()),s})}unpublishTracks(e){return __awaiter(this,void 0,void 0,function*(){return(yield Promise.all(e.map(e=>this.unpublishTrack(e)))).filter(e=>!!e)})}republishAllTracks(e){return __awaiter(this,arguments,void 0,function(e){var t=this;let i=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];return function*(){t.republishPromise&&(yield t.republishPromise),t.republishPromise=new TypedPromise((n,s)=>__awaiter(t,void 0,void 0,function*(){try{const t=[];this.trackPublications.forEach(i=>{i.track&&(e&&(i.options=Object.assign(Object.assign({},i.options),e)),t.push(i))}),yield Promise.all(t.map(e=>__awaiter(this,void 0,void 0,function*(){const t=e.track;yield this.unpublishTrack(t,!1),!i||t.isMuted||t.source===Track.Source.ScreenShare||t.source===Track.Source.ScreenShareAudio||!isLocalAudioTrack(t)&&!isLocalVideoTrack(t)||t.isUserProvided||(this.log.debug("restarting existing track",Object.assign(Object.assign({},this.logContext),{track:e.trackSid})),yield t.restartTrack()),yield this.publishOrRepublishTrack(t,e.options,!0)}))),n()}catch(e){e instanceof Error?s(e):s(new Error(String(e)))}finally{this.republishPromise=void 0}})),yield t.republishPromise}()})}publishData(e){return __awaiter(this,arguments,void 0,function(e){var t=this;let i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return function*(){const n=i.reliable?te.RELIABLE:te.LOSSY,s=i.destinationIdentities,a=i.topic;let c=new ae({participantIdentity:t.identity,payload:e,destinationIdentities:s,topic:a});const l=new ee({kind:n,value:{case:"user",value:c}});yield t.engine.sendDataPacket(l,n)}()})}publishDtmf(e,t){return __awaiter(this,void 0,void 0,function*(){const i=new ee({kind:te.RELIABLE,value:{case:"sipDtmf",value:new oe({code:e,digit:t})}});yield this.engine.sendDataPacket(i,te.RELIABLE)})}sendChatMessage(e,t){return __awaiter(this,void 0,void 0,function*(){const i={id:crypto.randomUUID(),message:e,timestamp:Date.now(),attachedFiles:null==t?void 0:t.attachments},s=new ee({value:{case:"chatMessage",value:new le(Object.assign(Object.assign({},i),{timestamp:n.parse(i.timestamp)}))}});return yield this.engine.sendDataPacket(s,te.RELIABLE),this.emit(pi.ChatMessage,i),i})}editChatMessage(e,t){return __awaiter(this,void 0,void 0,function*(){const i=Object.assign(Object.assign({},t),{message:e,editTimestamp:Date.now()}),s=new ee({value:{case:"chatMessage",value:new le(Object.assign(Object.assign({},i),{timestamp:n.parse(i.timestamp),editTimestamp:n.parse(i.editTimestamp)}))}});return yield this.engine.sendDataPacket(s,te.RELIABLE),this.emit(pi.ChatMessage,i),i})}sendText(e,t){return __awaiter(this,void 0,void 0,function*(){return this.roomOutgoingDataStreamManager.sendText(e,t)})}streamText(e){return __awaiter(this,void 0,void 0,function*(){return this.roomOutgoingDataStreamManager.streamText(e)})}sendFile(e,t){return __awaiter(this,void 0,void 0,function*(){return this.roomOutgoingDataStreamManager.sendFile(e,t)})}streamBytes(e){return __awaiter(this,void 0,void 0,function*(){return this.roomOutgoingDataStreamManager.streamBytes(e)})}performRpc(e){let{destinationIdentity:t,method:i,payload:n,responseTimeout:s=15e3}=e;return new TypedPromise((e,a)=>__awaiter(this,void 0,void 0,function*(){var c,l,u,h;if(byteLength(n)>15360)return void a(RpcError.builtIn("REQUEST_PAYLOAD_TOO_LARGE"));if((null===(l=null===(c=this.engine.latestJoinResponse)||void 0===c?void 0:c.serverInfo)||void 0===l?void 0:l.version)&&compareVersions(null===(h=null===(u=this.engine.latestJoinResponse)||void 0===u?void 0:u.serverInfo)||void 0===h?void 0:h.version,"1.8.0")<0)return void a(RpcError.builtIn("UNSUPPORTED_SERVER"));const p=Math.max(s,8e3),m=crypto.randomUUID();yield this.publishRpcRequest(t,m,i,n,p);const g=setTimeout(()=>{this.pendingAcks.delete(m),a(RpcError.builtIn("CONNECTION_TIMEOUT")),this.pendingResponses.delete(m),clearTimeout(v)},7e3);this.pendingAcks.set(m,{resolve:()=>{clearTimeout(g)},participantIdentity:t});const v=setTimeout(()=>{this.pendingResponses.delete(m),a(RpcError.builtIn("RESPONSE_TIMEOUT"))},s);this.pendingResponses.set(m,{resolve:(t,i)=>{clearTimeout(v),this.pendingAcks.has(m)&&(this.log.warn("RPC response received before ack",m),this.pendingAcks.delete(m),clearTimeout(g)),i?a(i):e(null!=t?t:"")},participantIdentity:t})}))}registerRpcMethod(e,t){this.rpcHandlers.has(e)&&this.log.warn("you're overriding the RPC handler for method ".concat(e,", in the future this will throw an error")),this.rpcHandlers.set(e,t)}unregisterRpcMethod(e){this.rpcHandlers.delete(e)}setTrackSubscriptionPermissions(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];this.participantTrackPermissions=t,this.allParticipantsAllowedToSubscribe=e,this.engine.client.isDisconnected||this.updateTrackSubscriptionPermissions()}handleIncomingRpcAck(e){const t=this.pendingAcks.get(e);t?(t.resolve(),this.pendingAcks.delete(e)):console.error("Ack received for unexpected RPC request",e)}handleIncomingRpcResponse(e,t,i){const n=this.pendingResponses.get(e);n?(n.resolve(t,i),this.pendingResponses.delete(e)):console.error("Response received for unexpected RPC request",e)}publishRpcRequest(e,t,i,n,s){return __awaiter(this,void 0,void 0,function*(){const a=new ee({destinationIdentities:[e],kind:te.RELIABLE,value:{case:"rpcRequest",value:new ue({id:t,method:i,payload:n,responseTimeoutMs:s,version:1})}});yield this.engine.sendDataPacket(a,te.RELIABLE)})}handleParticipantDisconnected(e){for(const[t,{participantIdentity:i}]of this.pendingAcks)i===e&&this.pendingAcks.delete(t);for(const[t,{participantIdentity:i,resolve:n}]of this.pendingResponses)i===e&&(n(null,RpcError.builtIn("RECIPIENT_DISCONNECTED")),this.pendingResponses.delete(t))}setEnabledPublishCodecs(e){this.enabledPublishVideoCodecs=e.filter(e=>"video"===e.mime.split("/")[0].toLowerCase())}updateInfo(e){return!!super.updateInfo(e)&&(e.tracks.forEach(e=>{var t,i;const n=this.trackPublications.get(e.sid);if(n){const s=n.isMuted||null!==(i=null===(t=n.track)||void 0===t?void 0:t.isUpstreamPaused)&&void 0!==i&&i;s!==e.muted&&(this.log.debug("updating server mute state after reconcile",Object.assign(Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(n)),{mutedOnServer:s})),this.engine.client.sendMuteTrack(e.sid,s))}}),!0)}setActiveAgent(e){var t,i,n,s;this.firstActiveAgent=e,e&&!this.firstActiveAgent&&(this.firstActiveAgent=e),e?null===(i=null===(t=this.activeAgentFuture)||void 0===t?void 0:t.resolve)||void 0===i||i.call(t,e):null===(s=null===(n=this.activeAgentFuture)||void 0===n?void 0:n.reject)||void 0===s||s.call(n,new Error("Agent disconnected")),this.activeAgentFuture=void 0}waitUntilActiveAgentPresent(){return this.firstActiveAgent?Promise.resolve(this.firstActiveAgent):(this.activeAgentFuture||(this.activeAgentFuture=new Future),this.activeAgentFuture.promise)}getPublicationForTrack(e){let t;return this.trackPublications.forEach(i=>{const n=i.track;n&&(e instanceof MediaStreamTrack?(isLocalAudioTrack(n)||isLocalVideoTrack(n))&&n.mediaStreamTrack===e&&(t=i):e===n&&(t=i))}),t}waitForPendingPublicationOfSource(e){return __awaiter(this,void 0,void 0,function*(){const t=Date.now();for(;Date.now()<t+1e4;){const t=Array.from(this.pendingPublishPromises.entries()).find(t=>{let[i]=t;return i.source===e});if(t)return t[1];yield sleep(20)}})}}class RemoteTrackPublication extends TrackPublication{constructor(e,t,i,n){super(e,t.sid,t.name,n),this.track=void 0,this.allowed=!0,this.requestedDisabled=void 0,this.visible=!0,this.handleEnded=e=>{this.setTrack(void 0),this.emit(gi.Ended,e)},this.handleVisibilityChange=e=>{this.log.debug("adaptivestream video visibility ".concat(this.trackSid,", visible=").concat(e),this.logContext),this.visible=e,this.emitTrackUpdate()},this.handleVideoDimensionsChange=e=>{this.log.debug("adaptivestream video dimensions ".concat(e.width,"x").concat(e.height),this.logContext),this.videoDimensionsAdaptiveStream=e,this.emitTrackUpdate()},this.subscribed=i,this.updateInfo(t)}setSubscribed(e){const t=this.subscriptionStatus,i=this.permissionStatus;this.subscribed=e,e&&(this.allowed=!0);const n=new Ke({trackSids:[this.trackSid],subscribe:this.subscribed,participantTracks:[new ge({participantSid:"",trackSids:[this.trackSid]})]});this.emit(gi.UpdateSubscription,n),this.emitSubscriptionUpdateIfChanged(t),this.emitPermissionUpdateIfChanged(i)}get subscriptionStatus(){return!1===this.subscribed?TrackPublication.SubscriptionStatus.Unsubscribed:super.isSubscribed?TrackPublication.SubscriptionStatus.Subscribed:TrackPublication.SubscriptionStatus.Desired}get permissionStatus(){return this.allowed?TrackPublication.PermissionStatus.Allowed:TrackPublication.PermissionStatus.NotAllowed}get isSubscribed(){return!1!==this.subscribed&&super.isSubscribed}get isDesired(){return!1!==this.subscribed}get isEnabled(){return void 0!==this.requestedDisabled?!this.requestedDisabled:!this.isAdaptiveStream||this.visible}get isLocal(){return!1}setEnabled(e){this.isManualOperationAllowed()&&this.requestedDisabled!==!e&&(this.requestedDisabled=!e,this.emitTrackUpdate())}setVideoQuality(e){this.isManualOperationAllowed()&&this.requestedMaxQuality!==e&&(this.requestedMaxQuality=e,this.requestedVideoDimensions=void 0,this.emitTrackUpdate())}setVideoDimensions(e){var t,i;this.isManualOperationAllowed()&&((null===(t=this.requestedVideoDimensions)||void 0===t?void 0:t.width)===e.width&&(null===(i=this.requestedVideoDimensions)||void 0===i?void 0:i.height)===e.height||(isRemoteVideoTrack(this.track)&&(this.requestedVideoDimensions=e),this.requestedMaxQuality=void 0,this.emitTrackUpdate()))}setVideoFPS(e){this.isManualOperationAllowed()&&isRemoteVideoTrack(this.track)&&this.fps!==e&&(this.fps=e,this.emitTrackUpdate())}get videoQuality(){var e;return null!==(e=this.requestedMaxQuality)&&void 0!==e?e:Ei.HIGH}setTrack(e){const t=this.subscriptionStatus,i=this.permissionStatus,n=this.track;n!==e&&(n&&(n.off(gi.VideoDimensionsChanged,this.handleVideoDimensionsChange),n.off(gi.VisibilityChanged,this.handleVisibilityChange),n.off(gi.Ended,this.handleEnded),n.detach(),n.stopMonitor(),this.emit(gi.Unsubscribed,n)),super.setTrack(e),e&&(e.sid=this.trackSid,e.on(gi.VideoDimensionsChanged,this.handleVideoDimensionsChange),e.on(gi.VisibilityChanged,this.handleVisibilityChange),e.on(gi.Ended,this.handleEnded),this.emit(gi.Subscribed,e)),this.emitPermissionUpdateIfChanged(i),this.emitSubscriptionUpdateIfChanged(t))}setAllowed(e){const t=this.subscriptionStatus,i=this.permissionStatus;this.allowed=e,this.emitPermissionUpdateIfChanged(i),this.emitSubscriptionUpdateIfChanged(t)}setSubscriptionError(e){this.emit(gi.SubscriptionFailed,e)}updateInfo(e){super.updateInfo(e);const t=this.metadataMuted;this.metadataMuted=e.muted,this.track?this.track.setMuted(e.muted):t!==e.muted&&this.emit(e.muted?gi.Muted:gi.Unmuted)}emitSubscriptionUpdateIfChanged(e){const t=this.subscriptionStatus;e!==t&&this.emit(gi.SubscriptionStatusChanged,t,e)}emitPermissionUpdateIfChanged(e){this.permissionStatus!==e&&this.emit(gi.SubscriptionPermissionChanged,this.permissionStatus,e)}isManualOperationAllowed(){return!!this.isDesired||(this.log.warn("cannot update track settings when not subscribed",this.logContext),!1)}get isAdaptiveStream(){return isRemoteVideoTrack(this.track)&&this.track.isAdaptiveStream}emitTrackUpdate(){const e=new Je({trackSids:[this.trackSid],disabled:!this.isEnabled,fps:this.fps});if(this.kind===Track.Kind.Video){let s=this.requestedVideoDimensions;if(void 0!==this.videoDimensionsAdaptiveStream)if(s){areDimensionsSmaller(this.videoDimensionsAdaptiveStream,s)&&(this.log.debug("using adaptive stream dimensions instead of requested",Object.assign(Object.assign({},this.logContext),this.videoDimensionsAdaptiveStream)),s=this.videoDimensionsAdaptiveStream)}else if(void 0!==this.requestedMaxQuality&&this.trackInfo){const e=(t=this.trackInfo,i=this.requestedMaxQuality,null===(n=t.layers)||void 0===n?void 0:n.find(e=>e.quality===i));e&&areDimensionsSmaller(this.videoDimensionsAdaptiveStream,e)&&(this.log.debug("using adaptive stream dimensions instead of max quality layer",Object.assign(Object.assign({},this.logContext),this.videoDimensionsAdaptiveStream)),s=this.videoDimensionsAdaptiveStream)}else this.log.debug("using adaptive stream dimensions",Object.assign(Object.assign({},this.logContext),this.videoDimensionsAdaptiveStream)),s=this.videoDimensionsAdaptiveStream;s?(e.width=Math.ceil(s.width),e.height=Math.ceil(s.height)):void 0!==this.requestedMaxQuality?(this.log.debug("using requested max quality",Object.assign(Object.assign({},this.logContext),{quality:this.requestedMaxQuality})),e.quality=this.requestedMaxQuality):(this.log.debug("using default quality",Object.assign(Object.assign({},this.logContext),{quality:Ei.HIGH})),e.quality=Ei.HIGH)}var t,i,n;this.emit(gi.UpdateSettings,e)}}class RemoteParticipant extends Participant{static fromParticipantInfo(e,t,i){return new RemoteParticipant(e,t.sid,t.identity,t.name,t.metadata,t.attributes,i,t.kind)}get logContext(){return Object.assign(Object.assign({},super.logContext),{rpID:this.sid,remoteParticipant:this.identity})}constructor(e,t,i,n,s,a,c){super(t,i||"",n,s,a,c,arguments.length>7&&void 0!==arguments[7]?arguments[7]:J.STANDARD),this.signalClient=e,this.trackPublications=new Map,this.audioTrackPublications=new Map,this.videoTrackPublications=new Map,this.volumeMap=new Map}addTrackPublication(e){super.addTrackPublication(e),e.on(gi.UpdateSettings,t=>{this.log.debug("send update settings",Object.assign(Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e)),{settings:t})),this.signalClient.sendUpdateTrackSettings(t)}),e.on(gi.UpdateSubscription,e=>{e.participantTracks.forEach(e=>{e.participantSid=this.sid}),this.signalClient.sendUpdateSubscription(e)}),e.on(gi.SubscriptionPermissionChanged,t=>{this.emit(pi.TrackSubscriptionPermissionChanged,e,t)}),e.on(gi.SubscriptionStatusChanged,t=>{this.emit(pi.TrackSubscriptionStatusChanged,e,t)}),e.on(gi.Subscribed,t=>{this.emit(pi.TrackSubscribed,t,e)}),e.on(gi.Unsubscribed,t=>{this.emit(pi.TrackUnsubscribed,t,e)}),e.on(gi.SubscriptionFailed,t=>{this.emit(pi.TrackSubscriptionFailed,e.trackSid,t)})}getTrackPublication(e){const t=super.getTrackPublication(e);if(t)return t}getTrackPublicationByName(e){const t=super.getTrackPublicationByName(e);if(t)return t}setVolume(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:Track.Source.Microphone;this.volumeMap.set(t,e);const i=this.getTrackPublication(t);i&&i.track&&i.track.setVolume(e)}getVolume(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:Track.Source.Microphone;const t=this.getTrackPublication(e);return t&&t.track?t.track.getVolume():this.volumeMap.get(e)}addSubscribedMediaTrack(e,t,i,n,s,a){let c=this.getTrackPublicationBySid(t);if(c||t.startsWith("TR")||this.trackPublications.forEach(t=>{c||e.kind!==t.kind.toString()||(c=t)}),!c)return 0===a?(this.log.error("could not find published track",Object.assign(Object.assign({},this.logContext),{trackSid:t})),void this.emit(pi.TrackSubscriptionFailed,t)):(void 0===a&&(a=20),void setTimeout(()=>{this.addSubscribedMediaTrack(e,t,i,n,s,a-1)},150));if("ended"===e.readyState)return this.log.error("unable to subscribe because MediaStreamTrack is ended. Do not call MediaStreamTrack.stop()",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(c))),void this.emit(pi.TrackSubscriptionFailed,t);let l;return l="video"===e.kind?new RemoteVideoTrack(e,t,n,s):new RemoteAudioTrack(e,t,n,this.audioContext,this.audioOutput),l.source=c.source,l.isMuted=c.isMuted,l.setMediaStream(i),l.start(),c.setTrack(l),this.volumeMap.has(c.source)&&isRemoteTrack(l)&&isAudioTrack(l)&&l.setVolume(this.volumeMap.get(c.source)),c}get hasMetadata(){return!!this.participantInfo}getTrackPublicationBySid(e){return this.trackPublications.get(e)}updateInfo(e){if(!super.updateInfo(e))return!1;const t=new Map,i=new Map;return e.tracks.forEach(e=>{var n,s;let a=this.getTrackPublicationBySid(e.sid);if(a)a.updateInfo(e);else{const t=Track.kindFromProto(e.type);if(!t)return;a=new RemoteTrackPublication(t,e,null===(n=this.signalClient.connectOptions)||void 0===n?void 0:n.autoSubscribe,{loggerContextCb:()=>this.logContext,loggerName:null===(s=this.loggerOptions)||void 0===s?void 0:s.loggerName}),a.updateInfo(e),i.set(e.sid,a);const c=Array.from(this.trackPublications.values()).find(e=>e.source===(null==a?void 0:a.source));c&&a.source!==Track.Source.Unknown&&this.log.debug("received a second track publication for ".concat(this.identity," with the same source: ").concat(a.source),Object.assign(Object.assign({},this.logContext),{oldTrack:getLogContextFromTrack(c),newTrack:getLogContextFromTrack(a)})),this.addTrackPublication(a)}t.set(e.sid,a)}),this.trackPublications.forEach(e=>{t.has(e.trackSid)||(this.log.trace("detected removed track on remote participant, unpublishing",Object.assign(Object.assign({},this.logContext),getLogContextFromTrack(e))),this.unpublishTrack(e.trackSid,!0))}),i.forEach(e=>{this.emit(pi.TrackPublished,e)}),!0}unpublishTrack(e,t){const i=this.trackPublications.get(e);if(!i)return;const{track:n}=i;switch(n&&(n.stop(),i.setTrack(void 0)),this.trackPublications.delete(e),i.kind){case Track.Kind.Audio:this.audioTrackPublications.delete(e);break;case Track.Kind.Video:this.videoTrackPublications.delete(e)}t&&this.emit(pi.TrackUnpublished,i)}setAudioOutput(e){return __awaiter(this,void 0,void 0,function*(){this.audioOutput=e;const t=[];this.audioTrackPublications.forEach(i=>{var n;isAudioTrack(i.track)&&isRemoteTrack(i.track)&&t.push(i.track.setSinkId(null!==(n=e.deviceId)&&void 0!==n?n:"default"))}),yield Promise.all(t)})}emit(e){for(var t=arguments.length,i=new Array(t>1?t-1:0),n=1;n<t;n++)i[n-1]=arguments[n];return this.log.trace("participant event",Object.assign(Object.assign({},this.logContext),{event:e,args:i})),super.emit(e,...i)}}!function(e){e.Disconnected="disconnected",e.Connecting="connecting",e.Connected="connected",e.Reconnecting="reconnecting",e.SignalReconnecting="signalReconnecting"}(bn||(bn={}));class Room extends Jt.EventEmitter{get hasE2EESetup(){return void 0!==this.e2eeManager}constructor(e){var t,i,n,s,a;if(super(),t=this,this.state=bn.Disconnected,this.activeSpeakers=[],this.isE2EEEnabled=!1,this.audioEnabled=!0,this.isVideoPlaybackBlocked=!1,this.log=Bt,this.bufferedEvents=[],this.isResuming=!1,this.rpcHandlers=new Map,this.connect=(e,t,i)=>__awaiter(this,void 0,void 0,function*(){var n;if("undefined"==typeof RTCPeerConnection||!supportsTransceiver()&&!supportsAddTrack())throw isReactNative()?Error("WebRTC isn't detected, have you called registerGlobals?"):Error("LiveKit doesn't seem to be supported on this browser. Try to update your browser and make sure no browser extensions are disabling webRTC.");const s=yield this.disconnectLock.lock();if(this.state===bn.Connected)return this.log.info("already connected to room ".concat(this.name),this.logContext),s(),Promise.resolve();if(this.connectFuture)return s(),this.connectFuture.promise;this.setAndEmitConnectionState(bn.Connecting),(null===(n=this.regionUrlProvider)||void 0===n?void 0:n.getServerUrl().toString())!==ensureTrailingSlash(e)&&(this.regionUrl=void 0,this.regionUrlProvider=void 0),isCloud(new URL(e))&&(void 0===this.regionUrlProvider?this.regionUrlProvider=new RegionUrlProvider(e,t):this.regionUrlProvider.updateToken(t),this.regionUrlProvider.fetchRegionSettings().then(e=>{var t;null===(t=this.regionUrlProvider)||void 0===t||t.setServerReportedRegions(e)}).catch(e=>{this.log.warn("could not fetch region settings",Object.assign(Object.assign({},this.logContext),{error:e}))}));const connectFn=(n,a,c)=>__awaiter(this,void 0,void 0,function*(){var l,u;this.abortController&&this.abortController.abort();const h=new AbortController;this.abortController=h,null==s||s();try{if(yield BackOffStrategy.getInstance().getBackOffPromise(e),h.signal.aborted)throw ConnectionError.cancelled("Connection attempt aborted");yield this.attemptConnection(null!=c?c:e,t,i,h),this.abortController=void 0,n()}catch(t){if(this.regionUrlProvider&&t instanceof ConnectionError&&t.reason!==di.Cancelled&&t.reason!==di.NotAllowed){let i=null;try{this.log.debug("Fetching next region"),i=yield this.regionUrlProvider.getNextBestRegionUrl(null===(l=this.abortController)||void 0===l?void 0:l.signal)}catch(e){if(e instanceof ConnectionError&&(401===e.status||e.reason===di.Cancelled))return this.handleDisconnect(this.options.stopLocalTrackOnUnpublish),void a(e)}[di.InternalError,di.ServerUnreachable,di.Timeout].includes(t.reason)&&(this.log.debug("Adding failed connection attempt to back off"),BackOffStrategy.getInstance().addFailedConnectionAttempt(e)),i&&!(null===(u=this.abortController)||void 0===u?void 0:u.signal.aborted)?(this.log.info("Initial connection failed with ConnectionError: ".concat(t.message,". Retrying with another region: ").concat(i),this.logContext),this.recreateEngine(),yield connectFn(n,a,i)):(this.handleDisconnect(this.options.stopLocalTrackOnUnpublish,getDisconnectReasonFromConnectionError(t)),a(t))}else{let e=F.UNKNOWN_REASON;t instanceof ConnectionError&&(e=getDisconnectReasonFromConnectionError(t)),this.handleDisconnect(this.options.stopLocalTrackOnUnpublish,e),a(t)}}}),a=this.regionUrl;return this.regionUrl=void 0,this.connectFuture=new Future((e,t)=>{connectFn(e,t,a)},()=>{this.clearConnectionFutures()}),this.connectFuture.promise}),this.connectSignal=(e,t,i,n,s,a)=>__awaiter(this,void 0,void 0,function*(){var c,l,u;const h=yield i.join(e,t,{autoSubscribe:n.autoSubscribe,adaptiveStream:"object"==typeof s.adaptiveStream||s.adaptiveStream,maxRetries:n.maxRetries,e2eeEnabled:!!this.e2eeManager,websocketTimeout:n.websocketTimeout},a.signal,!s.singlePeerConnection);let p=h.serverInfo;if(p||(p={version:h.serverVersion,region:h.serverRegion}),this.serverInfo=p,this.log.debug("connected to Livekit Server ".concat(Object.entries(p).map(e=>{let[t,i]=e;return"".concat(t,": ").concat(i)}).join(", ")),{room:null===(c=h.room)||void 0===c?void 0:c.name,roomSid:null===(l=h.room)||void 0===l?void 0:l.sid,identity:null===(u=h.participant)||void 0===u?void 0:u.identity}),!p.version)throw new UnsupportedServer("unknown server version");return"0.15.1"===p.version&&this.options.dynacast&&(this.log.debug("disabling dynacast due to server version",this.logContext),s.dynacast=!1),h}),this.applyJoinResponse=e=>{const t=e.participant;if(this.localParticipant.sid=t.sid,this.localParticipant.identity=t.identity,this.localParticipant.setEnabledPublishCodecs(e.enabledPublishCodecs),this.e2eeManager)try{this.e2eeManager.setSifTrailer(e.sifTrailer)}catch(e){this.log.error(e instanceof Error?e.message:"Could not set SifTrailer",Object.assign(Object.assign({},this.logContext),{error:e}))}this.handleParticipantUpdates([t,...e.otherParticipants]),e.room&&this.handleRoomUpdate(e.room)},this.attemptConnection=(e,t,i,n)=>__awaiter(this,void 0,void 0,function*(){var s,a;this.state===bn.Reconnecting||this.isResuming||(null===(s=this.engine)||void 0===s?void 0:s.pendingReconnect)?(this.log.info("Reconnection attempt replaced by new connection attempt",this.logContext),this.recreateEngine()):this.maybeCreateEngine(),(null===(a=this.regionUrlProvider)||void 0===a?void 0:a.isCloud())&&this.engine.setRegionUrlProvider(this.regionUrlProvider),this.acquireAudioContext(),this.connOptions=Object.assign(Object.assign({},nn),i),this.connOptions.rtcConfig&&(this.engine.rtcConfig=this.connOptions.rtcConfig),this.connOptions.peerConnectionTimeout&&(this.engine.peerConnectionTimeout=this.connOptions.peerConnectionTimeout);try{const i=yield this.connectSignal(e,t,this.engine,this.connOptions,this.options,n);this.applyJoinResponse(i),this.setupLocalParticipantEvents(),this.emit(hi.SignalConnected)}catch(e){yield this.engine.close(),this.recreateEngine();const t=n.signal.aborted?ConnectionError.cancelled("Signal connection aborted"):ConnectionError.serverUnreachable("could not establish signal connection");throw e instanceof Error&&(t.message="".concat(t.message,": ").concat(e.message)),e instanceof ConnectionError&&(t.reason=e.reason,t.status=e.status),this.log.debug("error trying to establish signal connection",Object.assign(Object.assign({},this.logContext),{error:e})),t}if(n.signal.aborted)throw yield this.engine.close(),this.recreateEngine(),ConnectionError.cancelled("Connection attempt aborted");try{yield this.engine.waitForPCInitialConnection(this.connOptions.peerConnectionTimeout,n)}catch(e){throw yield this.engine.close(),this.recreateEngine(),e}isWeb()&&this.options.disconnectOnPageLeave&&(window.addEventListener("pagehide",this.onPageLeave),window.addEventListener("beforeunload",this.onPageLeave)),isWeb()&&window.addEventListener("freeze",this.onPageLeave),this.setAndEmitConnectionState(bn.Connected),this.emit(hi.Connected),BackOffStrategy.getInstance().resetFailedConnectionAttempts(e),this.registerConnectionReconcile(),this.regionUrlProvider&&this.regionUrlProvider.notifyConnected()}),this.disconnect=function(){for(var e=arguments.length,i=new Array(e),n=0;n<e;n++)i[n]=arguments[n];return __awaiter(t,[...i],void 0,function(){var e=this;let t=!(arguments.length>0&&void 0!==arguments[0])||arguments[0];return function*(){var i,n,s;const a=yield e.disconnectLock.lock();try{if(e.state===bn.Disconnected)return void e.log.debug("already disconnected",e.logContext);if(e.log.info("disconnect from room",Object.assign({},e.logContext)),e.state===bn.Connecting||e.state===bn.Reconnecting||e.isResuming){const t="Abort connection attempt due to user initiated disconnect";e.log.warn(t,e.logContext),null===(i=e.abortController)||void 0===i||i.abort(t),null===(s=null===(n=e.connectFuture)||void 0===n?void 0:n.reject)||void 0===s||s.call(n,ConnectionError.cancelled("Client initiated disconnect")),e.connectFuture=void 0}e.engine&&(e.engine.client.isDisconnected||(yield e.engine.client.sendLeave()),yield e.engine.close()),e.handleDisconnect(t,F.CLIENT_INITIATED),e.engine=void 0}finally{a()}}()})},this.onPageLeave=()=>__awaiter(this,void 0,void 0,function*(){this.log.info("Page leave detected, disconnecting",this.logContext),yield this.disconnect()}),this.startAudio=()=>__awaiter(this,void 0,void 0,function*(){const e=[],t=getBrowser();if(t&&"iOS"===t.os){const t="livekit-dummy-audio-el";let i=document.getElementById(t);if(!i){i=document.createElement("audio"),i.id=t,i.autoplay=!0,i.hidden=!0;const e=getEmptyAudioStreamTrack();e.enabled=!0;const n=new MediaStream([e]);i.srcObject=n,document.addEventListener("visibilitychange",()=>{i&&(i.srcObject=document.hidden?null:n,document.hidden||(this.log.debug("page visible again, triggering startAudio to resume playback and update playback status",this.logContext),this.startAudio()))}),document.body.append(i),this.once(hi.Disconnected,()=>{null==i||i.remove(),i=null})}e.push(i)}this.remoteParticipants.forEach(t=>{t.audioTrackPublications.forEach(t=>{t.track&&t.track.attachedElements.forEach(t=>{e.push(t)})})});try{yield Promise.all([this.acquireAudioContext(),...e.map(e=>(e.muted=!1,e.play()))]),this.handleAudioPlaybackStarted()}catch(e){throw this.handleAudioPlaybackFailed(e),e}}),this.startVideo=()=>__awaiter(this,void 0,void 0,function*(){const e=[];for(const t of this.remoteParticipants.values())t.videoTrackPublications.forEach(t=>{var i;null===(i=t.track)||void 0===i||i.attachedElements.forEach(t=>{e.includes(t)||e.push(t)})});yield Promise.all(e.map(e=>e.play())).then(()=>{this.handleVideoPlaybackStarted()}).catch(e=>{"NotAllowedError"===e.name?this.handleVideoPlaybackFailed():this.log.warn("Resuming video playback failed, make sure you call `startVideo` directly in a user gesture handler",this.logContext)})}),this.handleRestarting=()=>{this.clearConnectionReconcile(),this.isResuming=!1;for(const e of this.remoteParticipants.values())this.handleParticipantDisconnected(e.identity,e);this.setAndEmitConnectionState(bn.Reconnecting)&&this.emit(hi.Reconnecting)},this.handleSignalRestarted=e=>__awaiter(this,void 0,void 0,function*(){this.log.debug("signal reconnected to server, region ".concat(e.serverRegion),Object.assign(Object.assign({},this.logContext),{region:e.serverRegion})),this.bufferedEvents=[],this.applyJoinResponse(e);try{yield this.localParticipant.republishAllTracks(void 0,!0)}catch(e){this.log.error("error trying to re-publish tracks after reconnection",Object.assign(Object.assign({},this.logContext),{error:e}))}try{yield this.engine.waitForRestarted(),this.log.debug("fully reconnected to server",Object.assign(Object.assign({},this.logContext),{region:e.serverRegion}))}catch(e){return}this.setAndEmitConnectionState(bn.Connected),this.emit(hi.Reconnected),this.registerConnectionReconcile(),this.emitBufferedEvents()}),this.handleParticipantUpdates=e=>{e.forEach(e=>{var t;if(e.identity===this.localParticipant.identity)return void this.localParticipant.updateInfo(e);""===e.identity&&(e.identity=null!==(t=this.sidToIdentity.get(e.sid))&&void 0!==t?t:"");let i=this.remoteParticipants.get(e.identity);e.state===K.DISCONNECTED?this.handleParticipantDisconnected(e.identity,i):i=this.getOrCreateParticipant(e.identity,e)})},this.handleActiveSpeakersUpdate=e=>{const t=[],i={};e.forEach(e=>{if(i[e.sid]=!0,e.sid===this.localParticipant.sid)this.localParticipant.audioLevel=e.level,this.localParticipant.setIsSpeaking(!0),t.push(this.localParticipant);else{const i=this.getRemoteParticipantBySid(e.sid);i&&(i.audioLevel=e.level,i.setIsSpeaking(!0),t.push(i))}}),i[this.localParticipant.sid]||(this.localParticipant.audioLevel=0,this.localParticipant.setIsSpeaking(!1)),this.remoteParticipants.forEach(e=>{i[e.sid]||(e.audioLevel=0,e.setIsSpeaking(!1))}),this.activeSpeakers=t,this.emitWhenConnected(hi.ActiveSpeakersChanged,t)},this.handleSpeakersChanged=e=>{const t=new Map;this.activeSpeakers.forEach(e=>{const i=this.remoteParticipants.get(e.identity);i&&i.sid!==e.sid||t.set(e.sid,e)}),e.forEach(e=>{let i=this.getRemoteParticipantBySid(e.sid);e.sid===this.localParticipant.sid&&(i=this.localParticipant),i&&(i.audioLevel=e.level,i.setIsSpeaking(e.active),e.active?t.set(e.sid,i):t.delete(e.sid))});const i=Array.from(t.values());i.sort((e,t)=>t.audioLevel-e.audioLevel),this.activeSpeakers=i,this.emitWhenConnected(hi.ActiveSpeakersChanged,i)},this.handleStreamStateUpdate=e=>{e.streamStates.forEach(e=>{const t=this.getRemoteParticipantBySid(e.participantSid);if(!t)return;const i=t.getTrackPublicationBySid(e.trackSid);if(!i||!i.track)return;const n=Track.streamStateFromProto(e.state);i.track.setStreamState(n),n!==i.track.streamState&&(t.emit(pi.TrackStreamStateChanged,i,i.track.streamState),this.emitWhenConnected(hi.TrackStreamStateChanged,i,i.track.streamState,t))})},this.handleSubscriptionPermissionUpdate=e=>{const t=this.getRemoteParticipantBySid(e.participantSid);if(!t)return;const i=t.getTrackPublicationBySid(e.trackSid);i&&i.setAllowed(e.allowed)},this.handleSubscriptionError=e=>{const t=Array.from(this.remoteParticipants.values()).find(t=>t.trackPublications.has(e.trackSid));if(!t)return;const i=t.getTrackPublicationBySid(e.trackSid);i&&i.setSubscriptionError(e.err)},this.handleDataPacket=(e,t)=>{const i=this.remoteParticipants.get(e.participantIdentity);if("user"===e.value.case)this.handleUserPacket(i,e.value.value,e.kind,t);else if("transcription"===e.value.case)this.handleTranscription(i,e.value.value);else if("sipDtmf"===e.value.case)this.handleSipDtmf(i,e.value.value);else if("chatMessage"===e.value.case)this.handleChatMessage(i,e.value.value);else if("metrics"===e.value.case)this.handleMetrics(e.value.value,i);else if("streamHeader"===e.value.case||"streamChunk"===e.value.case||"streamTrailer"===e.value.case)this.handleDataStream(e,t);else if("rpcRequest"===e.value.case){const t=e.value.value;this.handleIncomingRpcRequest(e.participantIdentity,t.id,t.method,t.payload,t.responseTimeoutMs,t.version)}},this.handleUserPacket=(e,t,i,n)=>{this.emit(hi.DataReceived,t.payload,e,i,t.topic,n),null==e||e.emit(pi.DataReceived,t.payload,i,n)},this.handleSipDtmf=(e,t)=>{this.emit(hi.SipDTMFReceived,t,e),null==e||e.emit(pi.SipDTMFReceived,t)},this.handleTranscription=(e,t)=>{const i=t.transcribedParticipantIdentity===this.localParticipant.identity?this.localParticipant:this.getParticipantByIdentity(t.transcribedParticipantIdentity),n=null==i?void 0:i.trackPublications.get(t.trackId),s=function(e,t){return e.segments.map(e=>{let{id:i,text:n,language:s,startTime:a,endTime:c,final:l}=e;var u;const h=null!==(u=t.get(i))&&void 0!==u?u:Date.now(),p=Date.now();return l?t.delete(i):t.set(i,h),{id:i,text:n,startTime:Number.parseInt(a.toString()),endTime:Number.parseInt(c.toString()),final:l,language:s,firstReceivedTime:h,lastReceivedTime:p}})}(t,this.transcriptionReceivedTimes);null==n||n.emit(gi.TranscriptionReceived,s),null==i||i.emit(pi.TranscriptionReceived,s,n),this.emit(hi.TranscriptionReceived,s,i,n)},this.handleChatMessage=(e,t)=>{const i=function(e){const{id:t,timestamp:i,message:n,editTimestamp:s}=e;return{id:t,timestamp:Number.parseInt(i.toString()),editTimestamp:s?Number.parseInt(s.toString()):void 0,message:n}}(t);this.emit(hi.ChatMessage,i,e)},this.handleMetrics=(e,t)=>{this.emit(hi.MetricsReceived,e,t)},this.handleDataStream=(e,t)=>{this.incomingDataStreamManager.handleDataStreamPacket(e,t)},this.bufferedSegments=new Map,this.handleAudioPlaybackStarted=()=>{this.canPlaybackAudio||(this.audioEnabled=!0,this.emit(hi.AudioPlaybackStatusChanged,!0))},this.handleAudioPlaybackFailed=e=>{this.log.warn("could not playback audio",Object.assign(Object.assign({},this.logContext),{error:e})),this.canPlaybackAudio&&(this.audioEnabled=!1,this.emit(hi.AudioPlaybackStatusChanged,!1))},this.handleVideoPlaybackStarted=()=>{this.isVideoPlaybackBlocked&&(this.isVideoPlaybackBlocked=!1,this.emit(hi.VideoPlaybackStatusChanged,!0))},this.handleVideoPlaybackFailed=()=>{this.isVideoPlaybackBlocked||(this.isVideoPlaybackBlocked=!0,this.emit(hi.VideoPlaybackStatusChanged,!1))},this.handleDeviceChange=()=>__awaiter(this,void 0,void 0,function*(){var e;"iOS"!==(null===(e=getBrowser())||void 0===e?void 0:e.os)&&(yield this.selectDefaultDevices()),this.emit(hi.MediaDevicesChanged)}),this.handleRoomUpdate=e=>{const t=this.roomInfo;this.roomInfo=e,t&&t.metadata!==e.metadata&&this.emitWhenConnected(hi.RoomMetadataChanged,e.metadata),(null==t?void 0:t.activeRecording)!==e.activeRecording&&this.emitWhenConnected(hi.RecordingStatusChanged,e.activeRecording)},this.handleConnectionQualityUpdate=e=>{e.updates.forEach(e=>{if(e.participantSid===this.localParticipant.sid)return void this.localParticipant.setConnectionQuality(e.quality);const t=this.getRemoteParticipantBySid(e.participantSid);t&&t.setConnectionQuality(e.quality)})},this.onLocalParticipantMetadataChanged=e=>{this.emit(hi.ParticipantMetadataChanged,e,this.localParticipant)},this.onLocalParticipantNameChanged=e=>{this.emit(hi.ParticipantNameChanged,e,this.localParticipant)},this.onLocalAttributesChanged=e=>{this.emit(hi.ParticipantAttributesChanged,e,this.localParticipant)},this.onLocalTrackMuted=e=>{this.emit(hi.TrackMuted,e,this.localParticipant)},this.onLocalTrackUnmuted=e=>{this.emit(hi.TrackUnmuted,e,this.localParticipant)},this.onTrackProcessorUpdate=e=>{var t;null===(t=null==e?void 0:e.onPublish)||void 0===t||t.call(e,this)},this.onLocalTrackPublished=e=>__awaiter(this,void 0,void 0,function*(){var t,i,n,s,a,c;if(null===(t=e.track)||void 0===t||t.on(gi.TrackProcessorUpdate,this.onTrackProcessorUpdate),null===(i=e.track)||void 0===i||i.on(gi.Restarted,this.onLocalTrackRestarted),null===(a=null===(s=null===(n=e.track)||void 0===n?void 0:n.getProcessor())||void 0===s?void 0:s.onPublish)||void 0===a||a.call(s,this),this.emit(hi.LocalTrackPublished,e,this.localParticipant),isLocalAudioTrack(e.track)){(yield e.track.checkForSilence())&&this.emit(hi.LocalAudioSilenceDetected,e)}const l=yield null===(c=e.track)||void 0===c?void 0:c.getDeviceId(!1),u=sourceToKind(e.source);u&&l&&l!==this.localParticipant.activeDeviceMap.get(u)&&(this.localParticipant.activeDeviceMap.set(u,l),this.emit(hi.ActiveDeviceChanged,u,l))}),this.onLocalTrackUnpublished=e=>{var t,i;null===(t=e.track)||void 0===t||t.off(gi.TrackProcessorUpdate,this.onTrackProcessorUpdate),null===(i=e.track)||void 0===i||i.off(gi.Restarted,this.onLocalTrackRestarted),this.emit(hi.LocalTrackUnpublished,e,this.localParticipant)},this.onLocalTrackRestarted=e=>__awaiter(this,void 0,void 0,function*(){const t=yield e.getDeviceId(!1),i=sourceToKind(e.source);i&&t&&t!==this.localParticipant.activeDeviceMap.get(i)&&(this.log.debug("local track restarted, setting ".concat(i," ").concat(t," active"),this.logContext),this.localParticipant.activeDeviceMap.set(i,t),this.emit(hi.ActiveDeviceChanged,i,t))}),this.onLocalConnectionQualityChanged=e=>{this.emit(hi.ConnectionQualityChanged,e,this.localParticipant)},this.onMediaDevicesError=(e,t)=>{this.emit(hi.MediaDevicesError,e,t)},this.onLocalParticipantPermissionsChanged=e=>{this.emit(hi.ParticipantPermissionsChanged,e,this.localParticipant)},this.onLocalChatMessageSent=e=>{this.emit(hi.ChatMessage,e,this.localParticipant)},this.setMaxListeners(100),this.remoteParticipants=new Map,this.sidToIdentity=new Map,this.options=Object.assign(Object.assign({},tn),e),this.log=getLogger(null!==(i=this.options.loggerName)&&void 0!==i?i:Ft.Room),this.transcriptionReceivedTimes=new Map,this.options.audioCaptureDefaults=Object.assign(Object.assign({},Zi),null==e?void 0:e.audioCaptureDefaults),this.options.videoCaptureDefaults=Object.assign(Object.assign({},en),null==e?void 0:e.videoCaptureDefaults),this.options.publishDefaults=Object.assign(Object.assign({},Xi),null==e?void 0:e.publishDefaults),this.maybeCreateEngine(),this.incomingDataStreamManager=new IncomingDataStreamManager,this.outgoingDataStreamManager=new OutgoingDataStreamManager(this.engine,this.log),this.disconnectLock=new _,this.localParticipant=new LocalParticipant("","",this.engine,this.options,this.rpcHandlers,this.outgoingDataStreamManager),(this.options.e2ee||this.options.encryption)&&this.setupE2EE(),this.engine.e2eeManager=this.e2eeManager,this.options.videoCaptureDefaults.deviceId&&this.localParticipant.activeDeviceMap.set("videoinput",unwrapConstraint(this.options.videoCaptureDefaults.deviceId)),this.options.audioCaptureDefaults.deviceId&&this.localParticipant.activeDeviceMap.set("audioinput",unwrapConstraint(this.options.audioCaptureDefaults.deviceId)),(null===(n=this.options.audioOutput)||void 0===n?void 0:n.deviceId)&&this.switchActiveDevice("audiooutput",unwrapConstraint(this.options.audioOutput.deviceId)).catch(e=>this.log.warn("Could not set audio output: ".concat(e.message),this.logContext)),isWeb()){const e=new AbortController;null===(a=null===(s=navigator.mediaDevices)||void 0===s?void 0:s.addEventListener)||void 0===a||a.call(s,"devicechange",this.handleDeviceChange,{signal:e.signal}),Room.cleanupRegistry&&Room.cleanupRegistry.register(this,()=>{e.abort()})}}registerTextStreamHandler(e,t){return this.incomingDataStreamManager.registerTextStreamHandler(e,t)}unregisterTextStreamHandler(e){return this.incomingDataStreamManager.unregisterTextStreamHandler(e)}registerByteStreamHandler(e,t){return this.incomingDataStreamManager.registerByteStreamHandler(e,t)}unregisterByteStreamHandler(e){return this.incomingDataStreamManager.unregisterByteStreamHandler(e)}registerRpcMethod(e,t){if(this.rpcHandlers.has(e))throw Error("RPC handler already registered for method ".concat(e,", unregisterRpcMethod before trying to register again"));this.rpcHandlers.set(e,t)}unregisterRpcMethod(e){this.rpcHandlers.delete(e)}setE2EEEnabled(e){return __awaiter(this,void 0,void 0,function*(){if(!this.e2eeManager)throw Error("e2ee not configured, please set e2ee settings within the room options");yield Promise.all([this.localParticipant.setE2EEEnabled(e)]),""!==this.localParticipant.identity&&this.e2eeManager.setParticipantCryptorEnabled(e,this.localParticipant.identity)})}setupE2EE(){var e;const t=!!this.options.encryption,i=this.options.encryption||this.options.e2ee;i&&("e2eeManager"in i?(this.e2eeManager=i.e2eeManager,this.e2eeManager.isDataChannelEncryptionEnabled=t):this.e2eeManager=new E2EEManager(i,t),this.e2eeManager.on(xi.ParticipantEncryptionStatusChanged,(e,t)=>{t.isLocal&&(this.isE2EEEnabled=e),this.emit(hi.ParticipantEncryptionStatusChanged,e,t)}),this.e2eeManager.on(xi.EncryptionError,(e,t)=>{const i=t?this.getParticipantByIdentity(t):void 0;this.emit(hi.EncryptionError,e,i)}),null===(e=this.e2eeManager)||void 0===e||e.setup(this))}get logContext(){var e;return{room:this.name,roomID:null===(e=this.roomInfo)||void 0===e?void 0:e.sid,participant:this.localParticipant.identity,pID:this.localParticipant.sid}}get isRecording(){var e,t;return null!==(t=null===(e=this.roomInfo)||void 0===e?void 0:e.activeRecording)&&void 0!==t&&t}getSid(){return this.state===bn.Disconnected?TypedPromise.resolve(""):this.roomInfo&&""!==this.roomInfo.sid?TypedPromise.resolve(this.roomInfo.sid):new TypedPromise((e,t)=>{const handleRoomUpdate=t=>{""!==t.sid&&(this.engine.off(mi.RoomUpdate,handleRoomUpdate),e(t.sid))};this.engine.on(mi.RoomUpdate,handleRoomUpdate),this.once(hi.Disconnected,()=>{this.engine.off(mi.RoomUpdate,handleRoomUpdate),t(new UnexpectedConnectionState("Room disconnected before room server id was available"))})})}get name(){var e,t;return null!==(t=null===(e=this.roomInfo)||void 0===e?void 0:e.name)&&void 0!==t?t:""}get metadata(){var e;return null===(e=this.roomInfo)||void 0===e?void 0:e.metadata}get numParticipants(){var e,t;return null!==(t=null===(e=this.roomInfo)||void 0===e?void 0:e.numParticipants)&&void 0!==t?t:0}get numPublishers(){var e,t;return null!==(t=null===(e=this.roomInfo)||void 0===e?void 0:e.numPublishers)&&void 0!==t?t:0}maybeCreateEngine(){this.engine&&!this.engine.isClosed||(this.engine=new RTCEngine(this.options),this.engine.e2eeManager=this.e2eeManager,this.engine.on(mi.ParticipantUpdate,this.handleParticipantUpdates).on(mi.RoomUpdate,this.handleRoomUpdate).on(mi.SpeakersChanged,this.handleSpeakersChanged).on(mi.StreamStateChanged,this.handleStreamStateUpdate).on(mi.ConnectionQualityUpdate,this.handleConnectionQualityUpdate).on(mi.SubscriptionError,this.handleSubscriptionError).on(mi.SubscriptionPermissionUpdate,this.handleSubscriptionPermissionUpdate).on(mi.MediaTrackAdded,(e,t,i)=>{this.onTrackAdded(e,t,i)}).on(mi.Disconnected,e=>{this.handleDisconnect(this.options.stopLocalTrackOnUnpublish,e)}).on(mi.ActiveSpeakersUpdate,this.handleActiveSpeakersUpdate).on(mi.DataPacketReceived,this.handleDataPacket).on(mi.Resuming,()=>{this.clearConnectionReconcile(),this.isResuming=!0,this.log.info("Resuming signal connection",this.logContext),this.setAndEmitConnectionState(bn.SignalReconnecting)&&this.emit(hi.SignalReconnecting)}).on(mi.Resumed,()=>{this.registerConnectionReconcile(),this.isResuming=!1,this.log.info("Resumed signal connection",this.logContext),this.updateSubscriptions(),this.emitBufferedEvents(),this.setAndEmitConnectionState(bn.Connected)&&this.emit(hi.Reconnected)}).on(mi.SignalResumed,()=>{this.bufferedEvents=[],(this.state===bn.Reconnecting||this.isResuming)&&this.sendSyncState()}).on(mi.Restarting,this.handleRestarting).on(mi.SignalRestarted,this.handleSignalRestarted).on(mi.Offline,()=>{this.setAndEmitConnectionState(bn.Reconnecting)&&this.emit(hi.Reconnecting)}).on(mi.DCBufferStatusChanged,(e,t)=>{this.emit(hi.DCBufferStatusChanged,e,t)}).on(mi.LocalTrackSubscribed,e=>{const t=this.localParticipant.getTrackPublications().find(t=>{let{trackSid:i}=t;return i===e});t?(this.localParticipant.emit(pi.LocalTrackSubscribed,t),this.emitWhenConnected(hi.LocalTrackSubscribed,t,this.localParticipant)):this.log.warn("could not find local track subscription for subscribed event",this.logContext)}).on(mi.RoomMoved,e=>{this.log.debug("room moved",e),e.room&&this.handleRoomUpdate(e.room),this.remoteParticipants.forEach((e,t)=>{this.handleParticipantDisconnected(t,e)}),this.emit(hi.Moved,e.room.name),e.participant?this.handleParticipantUpdates([e.participant,...e.otherParticipants]):this.handleParticipantUpdates(e.otherParticipants)}),this.localParticipant&&this.localParticipant.setupEngine(this.engine),this.e2eeManager&&this.e2eeManager.setupEngine(this.engine),this.outgoingDataStreamManager&&this.outgoingDataStreamManager.setupEngine(this.engine))}static getLocalDevices(e){let t=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];return DeviceManager.getInstance().getDevices(e,t)}prepareConnection(e,t){return __awaiter(this,void 0,void 0,function*(){if(this.state===bn.Disconnected){this.log.debug("prepareConnection to ".concat(e),this.logContext);try{if(isCloud(new URL(e))&&t){this.regionUrlProvider=new RegionUrlProvider(e,t);const i=yield this.regionUrlProvider.getNextBestRegionUrl();i&&this.state===bn.Disconnected&&(this.regionUrl=i,yield fetch(toHttpUrl(i),{method:"HEAD"}),this.log.debug("prepared connection to ".concat(i),this.logContext))}else yield fetch(toHttpUrl(e),{method:"HEAD"})}catch(e){this.log.warn("could not prepare connection",Object.assign(Object.assign({},this.logContext),{error:e}))}}})}getParticipantByIdentity(e){return this.localParticipant.identity===e?this.localParticipant:this.remoteParticipants.get(e)}clearConnectionFutures(){this.connectFuture=void 0}simulateScenario(e,t){return __awaiter(this,void 0,void 0,function*(){let i,postAction=()=>__awaiter(this,void 0,void 0,function*(){});switch(e){case"signal-reconnect":yield this.engine.client.handleOnClose("simulate disconnect");break;case"speaker":i=new kt({scenario:{case:"speakerUpdate",value:3}});break;case"node-failure":i=new kt({scenario:{case:"nodeFailure",value:!0}});break;case"server-leave":i=new kt({scenario:{case:"serverLeave",value:!0}});break;case"migration":i=new kt({scenario:{case:"migration",value:!0}});break;case"resume-reconnect":this.engine.failNext(),yield this.engine.client.handleOnClose("simulate resume-disconnect");break;case"disconnect-signal-on-resume":postAction=()=>__awaiter(this,void 0,void 0,function*(){yield this.engine.client.handleOnClose("simulate resume-disconnect")}),i=new kt({scenario:{case:"disconnectSignalOnResume",value:!0}});break;case"disconnect-signal-on-resume-no-messages":postAction=()=>__awaiter(this,void 0,void 0,function*(){yield this.engine.client.handleOnClose("simulate resume-disconnect")}),i=new kt({scenario:{case:"disconnectSignalOnResumeNoMessages",value:!0}});break;case"full-reconnect":this.engine.fullReconnectOnNext=!0,yield this.engine.client.handleOnClose("simulate full-reconnect");break;case"force-tcp":case"force-tls":i=new kt({scenario:{case:"switchCandidateProtocol",value:"force-tls"===e?2:1}}),postAction=()=>__awaiter(this,void 0,void 0,function*(){const e=this.engine.client.onLeave;e&&e(new Ye({reason:F.CLIENT_INITIATED,action:$e.RECONNECT}))});break;case"subscriber-bandwidth":if(void 0===t||"number"!=typeof t)throw new Error("subscriber-bandwidth requires a number as argument");i=new kt({scenario:{case:"subscriberBandwidth",value:numberToBigInt(t)}});break;case"leave-full-reconnect":i=new kt({scenario:{case:"leaveRequestFullReconnect",value:!0}})}i&&(yield this.engine.client.sendSimulateScenario(i),yield postAction())})}get canPlaybackAudio(){return this.audioEnabled}get canPlaybackVideo(){return!this.isVideoPlaybackBlocked}getActiveDevice(e){return this.localParticipant.activeDeviceMap.get(e)}switchActiveDevice(e,t){return __awaiter(this,arguments,void 0,function(e,t){var i=this;let n=!(arguments.length>2&&void 0!==arguments[2])||arguments[2];return function*(){var s,a,c,l,u,h,p;let m=!0,g=!1;const v=n?{exact:t}:t;if("audioinput"===e){g=0===i.localParticipant.audioTrackPublications.size;const t=null!==(s=i.getActiveDevice(e))&&void 0!==s?s:i.options.audioCaptureDefaults.deviceId;i.options.audioCaptureDefaults.deviceId=v;const n=Array.from(i.localParticipant.audioTrackPublications.values()).filter(e=>e.source===Track.Source.Microphone);try{m=(yield Promise.all(n.map(e=>{var t;return null===(t=e.audioTrack)||void 0===t?void 0:t.setDeviceId(v)}))).every(e=>!0===e)}catch(e){throw i.options.audioCaptureDefaults.deviceId=t,e}const a=n.some(e=>{var t,i;return null!==(i=null===(t=e.track)||void 0===t?void 0:t.isMuted)&&void 0!==i&&i});m&&a&&(g=!0)}else if("videoinput"===e){g=0===i.localParticipant.videoTrackPublications.size;const t=null!==(a=i.getActiveDevice(e))&&void 0!==a?a:i.options.videoCaptureDefaults.deviceId;i.options.videoCaptureDefaults.deviceId=v;const n=Array.from(i.localParticipant.videoTrackPublications.values()).filter(e=>e.source===Track.Source.Camera);try{m=(yield Promise.all(n.map(e=>{var t;return null===(t=e.videoTrack)||void 0===t?void 0:t.setDeviceId(v)}))).every(e=>!0===e)}catch(e){throw i.options.videoCaptureDefaults.deviceId=t,e}const s=n.some(e=>{var t,i;return null!==(i=null===(t=e.track)||void 0===t?void 0:t.isMuted)&&void 0!==i&&i});m&&s&&(g=!0)}else if("audiooutput"===e){if(g=!0,!supportsSetSinkId()&&!i.options.webAudioMix||i.options.webAudioMix&&i.audioContext&&!("setSinkId"in i.audioContext))throw new Error("cannot switch audio output, the current browser does not support it");i.options.webAudioMix&&(t=null!==(c=yield DeviceManager.getInstance().normalizeDeviceId("audiooutput",t))&&void 0!==c?c:""),null!==(l=(p=i.options).audioOutput)&&void 0!==l||(p.audioOutput={});const n=null!==(u=i.getActiveDevice(e))&&void 0!==u?u:i.options.audioOutput.deviceId;i.options.audioOutput.deviceId=t;try{i.options.webAudioMix&&(null===(h=i.audioContext)||void 0===h||h.setSinkId(t)),yield Promise.all(Array.from(i.remoteParticipants.values()).map(e=>e.setAudioOutput({deviceId:t})))}catch(e){throw i.options.audioOutput.deviceId=n,e}}return g&&(i.localParticipant.activeDeviceMap.set(e,t),i.emit(hi.ActiveDeviceChanged,e,t)),m}()})}setupLocalParticipantEvents(){this.localParticipant.on(pi.ParticipantMetadataChanged,this.onLocalParticipantMetadataChanged).on(pi.ParticipantNameChanged,this.onLocalParticipantNameChanged).on(pi.AttributesChanged,this.onLocalAttributesChanged).on(pi.TrackMuted,this.onLocalTrackMuted).on(pi.TrackUnmuted,this.onLocalTrackUnmuted).on(pi.LocalTrackPublished,this.onLocalTrackPublished).on(pi.LocalTrackUnpublished,this.onLocalTrackUnpublished).on(pi.ConnectionQualityChanged,this.onLocalConnectionQualityChanged).on(pi.MediaDevicesError,this.onMediaDevicesError).on(pi.AudioStreamAcquired,this.startAudio).on(pi.ChatMessage,this.onLocalChatMessageSent).on(pi.ParticipantPermissionsChanged,this.onLocalParticipantPermissionsChanged)}recreateEngine(){var e;null===(e=this.engine)||void 0===e||e.close(),this.engine=void 0,this.isResuming=!1,this.remoteParticipants.clear(),this.sidToIdentity.clear(),this.bufferedEvents=[],this.maybeCreateEngine()}onTrackAdded(e,t,i){if(this.state===bn.Connecting||this.state===bn.Reconnecting){const reconnectedHandler=()=>{this.log.debug("deferring on track for later",{mediaTrackId:e.id,mediaStreamId:t.id,tracksInStream:t.getTracks().map(e=>e.id)}),this.onTrackAdded(e,t,i),cleanup()},cleanup=()=>{this.off(hi.Reconnected,reconnectedHandler),this.off(hi.Connected,reconnectedHandler),this.off(hi.Disconnected,cleanup)};return this.once(hi.Reconnected,reconnectedHandler),this.once(hi.Connected,reconnectedHandler),void this.once(hi.Disconnected,cleanup)}if(this.state===bn.Disconnected)return void this.log.warn("skipping incoming track after Room disconnected",this.logContext);if("ended"===e.readyState)return void this.log.info("skipping incoming track as it already ended",this.logContext);const n=function(e){const t=e.split("|");return t.length>1?[t[0],e.substr(t[0].length+1)]:[e,""]}(t.id),s=n[0];let a=n[1],c=e.id;if(a&&a.startsWith("TR")&&(c=a),s===this.localParticipant.sid)return void this.log.warn("tried to create RemoteParticipant for local participant",this.logContext);const l=Array.from(this.remoteParticipants.values()).find(e=>e.sid===s);if(!l)return void this.log.error("Tried to add a track for a participant, that's not present. Sid: ".concat(s),this.logContext);if(!c.startsWith("TR")){const e=this.engine.getTrackIdForReceiver(i);if(!e)return void this.log.error("Tried to add a track whose 'sid' could not be found for a participant, that's not present. Sid: ".concat(s),this.logContext);c=e}let u;c.startsWith("TR")||this.log.warn("Tried to add a track whose 'sid' could not be determined for a participant, that's not present. Sid: ".concat(s,", streamId: ").concat(a,", trackId: ").concat(c),Object.assign(Object.assign({},this.logContext),{rpID:s,streamId:a,trackId:c})),this.options.adaptiveStream&&(u="object"==typeof this.options.adaptiveStream?this.options.adaptiveStream:{});const h=l.addSubscribedMediaTrack(e,c,t,i,u);(null==h?void 0:h.isEncrypted)&&!this.e2eeManager&&this.emit(hi.EncryptionError,new Error("Encrypted ".concat(h.source," track received from participant ").concat(l.sid,", but room does not have encryption enabled!")))}handleDisconnect(){let e=!(arguments.length>0&&void 0!==arguments[0])||arguments[0],t=arguments.length>1?arguments[1]:void 0;var i,n;if(this.clearConnectionReconcile(),this.isResuming=!1,this.bufferedEvents=[],this.transcriptionReceivedTimes.clear(),this.incomingDataStreamManager.clearControllers(),this.state!==bn.Disconnected){this.regionUrl=void 0,this.regionUrlProvider&&this.regionUrlProvider.notifyDisconnected();try{this.remoteParticipants.forEach(e=>{e.trackPublications.forEach(t=>{e.unpublishTrack(t.trackSid)})}),this.localParticipant.trackPublications.forEach(t=>{var i,n,s;t.track&&this.localParticipant.unpublishTrack(t.track,e),e?(null===(i=t.track)||void 0===i||i.detach(),null===(n=t.track)||void 0===n||n.stop()):null===(s=t.track)||void 0===s||s.stopMonitor()}),this.localParticipant.off(pi.ParticipantMetadataChanged,this.onLocalParticipantMetadataChanged).off(pi.ParticipantNameChanged,this.onLocalParticipantNameChanged).off(pi.AttributesChanged,this.onLocalAttributesChanged).off(pi.TrackMuted,this.onLocalTrackMuted).off(pi.TrackUnmuted,this.onLocalTrackUnmuted).off(pi.LocalTrackPublished,this.onLocalTrackPublished).off(pi.LocalTrackUnpublished,this.onLocalTrackUnpublished).off(pi.ConnectionQualityChanged,this.onLocalConnectionQualityChanged).off(pi.MediaDevicesError,this.onMediaDevicesError).off(pi.AudioStreamAcquired,this.startAudio).off(pi.ChatMessage,this.onLocalChatMessageSent).off(pi.ParticipantPermissionsChanged,this.onLocalParticipantPermissionsChanged),this.localParticipant.trackPublications.clear(),this.localParticipant.videoTrackPublications.clear(),this.localParticipant.audioTrackPublications.clear(),this.remoteParticipants.clear(),this.sidToIdentity.clear(),this.activeSpeakers=[],this.audioContext&&"boolean"==typeof this.options.webAudioMix&&(this.audioContext.close(),this.audioContext=void 0),isWeb()&&(window.removeEventListener("beforeunload",this.onPageLeave),window.removeEventListener("pagehide",this.onPageLeave),window.removeEventListener("freeze",this.onPageLeave),null===(n=null===(i=navigator.mediaDevices)||void 0===i?void 0:i.removeEventListener)||void 0===n||n.call(i,"devicechange",this.handleDeviceChange))}finally{this.setAndEmitConnectionState(bn.Disconnected),this.emit(hi.Disconnected,t)}}}handleParticipantDisconnected(e,t){var i;this.remoteParticipants.delete(e),t&&(this.incomingDataStreamManager.validateParticipantHasNoActiveDataStreams(e),t.trackPublications.forEach(e=>{t.unpublishTrack(e.trackSid,!0)}),this.emit(hi.ParticipantDisconnected,t),t.setDisconnected(),null===(i=this.localParticipant)||void 0===i||i.handleParticipantDisconnected(t.identity))}handleIncomingRpcRequest(e,t,i,n,s,a){return __awaiter(this,void 0,void 0,function*(){if(yield this.engine.publishRpcAck(e,t),1!==a)return void(yield this.engine.publishRpcResponse(e,t,null,RpcError.builtIn("UNSUPPORTED_VERSION")));const c=this.rpcHandlers.get(i);if(!c)return void(yield this.engine.publishRpcResponse(e,t,null,RpcError.builtIn("UNSUPPORTED_METHOD")));let l=null,u=null;try{const a=yield c({requestId:t,callerIdentity:e,payload:n,responseTimeout:s});byteLength(a)>15360?(l=RpcError.builtIn("RESPONSE_PAYLOAD_TOO_LARGE"),this.log.warn("RPC Response payload too large for ".concat(i))):u=a}catch(e){e instanceof RpcError?l=e:(this.log.warn("Uncaught error returned by RPC handler for ".concat(i,". Returning APPLICATION_ERROR instead."),e),l=RpcError.builtIn("APPLICATION_ERROR"))}yield this.engine.publishRpcResponse(e,t,u,l)})}selectDefaultDevices(){return __awaiter(this,void 0,void 0,function*(){var e,t,i;const n=DeviceManager.getInstance().previousDevices,s=yield DeviceManager.getInstance().getDevices(void 0,!1),a=getBrowser();if("Chrome"===(null==a?void 0:a.name)&&"iOS"!==a.os)for(let e of s){const t=n.find(t=>t.deviceId===e.deviceId);t&&""!==t.label&&t.kind===e.kind&&t.label!==e.label&&"default"===this.getActiveDevice(e.kind)&&this.emit(hi.ActiveDeviceChanged,e.kind,e.deviceId)}const c=["audiooutput","audioinput","videoinput"];for(let a of c){const c=kindToSource(a),l=this.localParticipant.getTrackPublication(c);if(l&&(null===(e=l.track)||void 0===e?void 0:e.isUserProvided))continue;const u=s.filter(e=>e.kind===a),h=this.getActiveDevice(a);h===(null===(t=n.filter(e=>e.kind===a)[0])||void 0===t?void 0:t.deviceId)&&u.length>0&&(null===(i=u[0])||void 0===i?void 0:i.deviceId)!==h?yield this.switchActiveDevice(a,u[0].deviceId):"audioinput"===a&&!isSafariBased()||"videoinput"===a||!(u.length>0)||u.find(e=>e.deviceId===this.getActiveDevice(a))||"audiooutput"===a&&isSafariBased()||(yield this.switchActiveDevice(a,u[0].deviceId))}})}acquireAudioContext(){return __awaiter(this,void 0,void 0,function*(){var e,t;if("boolean"!=typeof this.options.webAudioMix&&this.options.webAudioMix.audioContext?this.audioContext=this.options.webAudioMix.audioContext:this.audioContext&&"closed"!==this.audioContext.state||(this.audioContext=null!==(e=getNewAudioContext())&&void 0!==e?e:void 0),this.options.webAudioMix&&this.remoteParticipants.forEach(e=>e.setAudioContext(this.audioContext)),this.localParticipant.setAudioContext(this.audioContext),this.audioContext&&"suspended"===this.audioContext.state)try{yield Promise.race([this.audioContext.resume(),sleep(200)])}catch(e){this.log.warn("Could not resume audio context",Object.assign(Object.assign({},this.logContext),{error:e}))}const i="running"===(null===(t=this.audioContext)||void 0===t?void 0:t.state);i!==this.canPlaybackAudio&&(this.audioEnabled=i,this.emit(hi.AudioPlaybackStatusChanged,i))})}createParticipant(e,t){var i;let n;return n=t?RemoteParticipant.fromParticipantInfo(this.engine.client,t,{loggerContextCb:()=>this.logContext,loggerName:this.options.loggerName}):new RemoteParticipant(this.engine.client,"",e,void 0,void 0,void 0,{loggerContextCb:()=>this.logContext,loggerName:this.options.loggerName}),this.options.webAudioMix&&n.setAudioContext(this.audioContext),(null===(i=this.options.audioOutput)||void 0===i?void 0:i.deviceId)&&n.setAudioOutput(this.options.audioOutput).catch(e=>this.log.warn("Could not set audio output: ".concat(e.message),this.logContext)),n}getOrCreateParticipant(e,t){if(this.remoteParticipants.has(e)){const i=this.remoteParticipants.get(e);if(t){i.updateInfo(t)&&this.sidToIdentity.set(t.sid,t.identity)}return i}const i=this.createParticipant(e,t);return this.remoteParticipants.set(e,i),this.sidToIdentity.set(t.sid,t.identity),this.emitWhenConnected(hi.ParticipantConnected,i),i.on(pi.TrackPublished,e=>{this.emitWhenConnected(hi.TrackPublished,e,i)}).on(pi.TrackSubscribed,(e,t)=>{e.kind===Track.Kind.Audio?(e.on(gi.AudioPlaybackStarted,this.handleAudioPlaybackStarted),e.on(gi.AudioPlaybackFailed,this.handleAudioPlaybackFailed)):e.kind===Track.Kind.Video&&(e.on(gi.VideoPlaybackFailed,this.handleVideoPlaybackFailed),e.on(gi.VideoPlaybackStarted,this.handleVideoPlaybackStarted)),this.emit(hi.TrackSubscribed,e,t,i)}).on(pi.TrackUnpublished,e=>{this.emit(hi.TrackUnpublished,e,i)}).on(pi.TrackUnsubscribed,(e,t)=>{this.emit(hi.TrackUnsubscribed,e,t,i)}).on(pi.TrackMuted,e=>{this.emitWhenConnected(hi.TrackMuted,e,i)}).on(pi.TrackUnmuted,e=>{this.emitWhenConnected(hi.TrackUnmuted,e,i)}).on(pi.ParticipantMetadataChanged,e=>{this.emitWhenConnected(hi.ParticipantMetadataChanged,e,i)}).on(pi.ParticipantNameChanged,e=>{this.emitWhenConnected(hi.ParticipantNameChanged,e,i)}).on(pi.AttributesChanged,e=>{this.emitWhenConnected(hi.ParticipantAttributesChanged,e,i)}).on(pi.ConnectionQualityChanged,e=>{this.emitWhenConnected(hi.ConnectionQualityChanged,e,i)}).on(pi.ParticipantPermissionsChanged,e=>{this.emitWhenConnected(hi.ParticipantPermissionsChanged,e,i)}).on(pi.TrackSubscriptionStatusChanged,(e,t)=>{this.emitWhenConnected(hi.TrackSubscriptionStatusChanged,e,t,i)}).on(pi.TrackSubscriptionFailed,(e,t)=>{this.emit(hi.TrackSubscriptionFailed,e,i,t)}).on(pi.TrackSubscriptionPermissionChanged,(e,t)=>{this.emitWhenConnected(hi.TrackSubscriptionPermissionChanged,e,t,i)}).on(pi.Active,()=>{this.emitWhenConnected(hi.ParticipantActive,i),i.kind===J.AGENT&&this.localParticipant.setActiveAgent(i)}),t&&i.updateInfo(t),i}sendSyncState(){const e=Array.from(this.remoteParticipants.values()).reduce((e,t)=>(e.push(...t.getTrackPublications()),e),[]),t=this.localParticipant.getTrackPublications();this.engine.sendSyncState(e,t)}updateSubscriptions(){for(const e of this.remoteParticipants.values())for(const t of e.videoTrackPublications.values())t.isSubscribed&&isRemotePub(t)&&t.emitTrackUpdate()}getRemoteParticipantBySid(e){const t=this.sidToIdentity.get(e);if(t)return this.remoteParticipants.get(t)}registerConnectionReconcile(){this.clearConnectionReconcile();let e=0;this.connectionReconcileInterval=CriticalTimers.setInterval(()=>{this.engine&&!this.engine.isClosed&&this.engine.verifyTransport()?e=0:(e++,this.log.warn("detected connection state mismatch",Object.assign(Object.assign({},this.logContext),{numFailures:e,engine:this.engine?{closed:this.engine.isClosed,transportsConnected:this.engine.verifyTransport()}:void 0})),e>=3&&(this.recreateEngine(),this.handleDisconnect(this.options.stopLocalTrackOnUnpublish,F.STATE_MISMATCH)))},4e3)}clearConnectionReconcile(){this.connectionReconcileInterval&&CriticalTimers.clearInterval(this.connectionReconcileInterval)}setAndEmitConnectionState(e){return e!==this.state&&(this.state=e,this.emit(hi.ConnectionStateChanged,this.state),!0)}emitBufferedEvents(){this.bufferedEvents.forEach(e=>{let[t,i]=e;this.emit(t,...i)}),this.bufferedEvents=[]}emitWhenConnected(e){for(var t=arguments.length,i=new Array(t>1?t-1:0),n=1;n<t;n++)i[n-1]=arguments[n];if(this.state===bn.Reconnecting||this.isResuming||!this.engine||this.engine.pendingReconnect)this.bufferedEvents.push([e,i]);else if(this.state===bn.Connected)return this.emit(e,...i);return!1}simulateParticipants(e){return __awaiter(this,void 0,void 0,function*(){var t,i,s,a;const c=Object.assign({audio:!0,video:!0,useRealTracks:!1},e.publish),l=Object.assign({count:9,audio:!1,video:!0,aspectRatios:[1.66,1.7,1.3]},e.participants);if(this.handleDisconnect(),this.roomInfo=new q({sid:"RM_SIMULATED",name:"simulated-room",emptyTimeout:0,maxParticipants:0,creationTime:n.parse((new Date).getTime()),metadata:"",numParticipants:1,numPublishers:1,turnPassword:"",enabledCodecs:[],activeRecording:!1}),this.localParticipant.updateInfo(new G({identity:"simulated-local",name:"local-name"})),this.setupLocalParticipantEvents(),this.emit(hi.SignalConnected),this.emit(hi.Connected),this.setAndEmitConnectionState(bn.Connected),c.video){const e=new LocalTrackPublication(Track.Kind.Video,new $({source:A.CAMERA,sid:Math.floor(1e4*Math.random()).toString(),type:M.AUDIO,name:"video-dummy"}),new LocalVideoTrack(c.useRealTracks&&(null===(t=window.navigator.mediaDevices)||void 0===t?void 0:t.getUserMedia)?(yield window.navigator.mediaDevices.getUserMedia({video:!0})).getVideoTracks()[0]:createDummyVideoStreamTrack(160*(null!==(i=l.aspectRatios[0])&&void 0!==i?i:1),160,!0,!0),void 0,!1,{loggerName:this.options.loggerName,loggerContextCb:()=>this.logContext}),{loggerName:this.options.loggerName,loggerContextCb:()=>this.logContext});this.localParticipant.addTrackPublication(e),this.localParticipant.emit(pi.LocalTrackPublished,e)}if(c.audio){const e=new LocalTrackPublication(Track.Kind.Audio,new $({source:A.MICROPHONE,sid:Math.floor(1e4*Math.random()).toString(),type:M.AUDIO}),new LocalAudioTrack(c.useRealTracks&&(null===(s=navigator.mediaDevices)||void 0===s?void 0:s.getUserMedia)?(yield navigator.mediaDevices.getUserMedia({audio:!0})).getAudioTracks()[0]:getEmptyAudioStreamTrack(),void 0,!1,this.audioContext,{loggerName:this.options.loggerName,loggerContextCb:()=>this.logContext}),{loggerName:this.options.loggerName,loggerContextCb:()=>this.logContext});this.localParticipant.addTrackPublication(e),this.localParticipant.emit(pi.LocalTrackPublished,e)}for(let e=0;e<l.count-1;e+=1){let t=new G({sid:Math.floor(1e4*Math.random()).toString(),identity:"simulated-".concat(e),state:K.ACTIVE,tracks:[],joinedAt:n.parse(Date.now())});const i=this.getOrCreateParticipant(t.identity,t);if(l.video){const n=createDummyVideoStreamTrack(160*(null!==(a=l.aspectRatios[e%l.aspectRatios.length])&&void 0!==a?a:1),160,!1,!0),s=new $({source:A.CAMERA,sid:Math.floor(1e4*Math.random()).toString(),type:M.AUDIO});i.addSubscribedMediaTrack(n,s.sid,new MediaStream([n]),new RTCRtpReceiver),t.tracks=[...t.tracks,s]}if(l.audio){const e=getEmptyAudioStreamTrack(),n=new $({source:A.MICROPHONE,sid:Math.floor(1e4*Math.random()).toString(),type:M.AUDIO});i.addSubscribedMediaTrack(e,n.sid,new MediaStream([e]),new RTCRtpReceiver),t.tracks=[...t.tracks,n]}i.updateInfo(t)}})}emit(e){for(var t=arguments.length,i=new Array(t>1?t-1:0),n=1;n<t;n++)i[n-1]=arguments[n];if(e!==hi.ActiveSpeakersChanged&&e!==hi.TranscriptionReceived){const t=mapArgs(i).filter(e=>void 0!==e);e!==hi.TrackSubscribed&&e!==hi.TrackUnsubscribed||this.log.trace("subscribe trace: ".concat(e),Object.assign(Object.assign({},this.logContext),{event:e,args:t})),this.log.debug("room event ".concat(e),Object.assign(Object.assign({},this.logContext),{event:e,args:t}))}return super.emit(e,...i)}}function mapArgs(e){return e.map(e=>{if(e)return Array.isArray(e)?mapArgs(e):"object"==typeof e?"logContext"in e?e.logContext:void 0:e})}var yn;Room.cleanupRegistry="undefined"!=typeof FinalizationRegistry&&new FinalizationRegistry(e=>{e()}),function(e){e[e.IDLE=0]="IDLE",e[e.RUNNING=1]="RUNNING",e[e.SKIPPED=2]="SKIPPED",e[e.SUCCESS=3]="SUCCESS",e[e.FAILED=4]="FAILED"}(yn||(yn={}));Jt.EventEmitter;Jt.EventEmitter;function _defineProperty(e,t,i){return(t=function(e){var t=function(e,t){if("object"!=typeof e||!e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var n=i.call(e,t);if("object"!=typeof n)return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}(e,"string");return"symbol"==typeof t?t:t+""}(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}new TextEncoder,new TextDecoder;class JOSEError extends Error{constructor(e,t){var i;super(e,t),_defineProperty(this,"code","ERR_JOSE_GENERIC"),this.name=this.constructor.name,null===(i=Error.captureStackTrace)||void 0===i||i.call(Error,this,this.constructor)}}_defineProperty(JOSEError,"code","ERR_JOSE_GENERIC");_defineProperty(class extends JOSEError{constructor(e,t){let i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"unspecified",n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"unspecified";super(e,{cause:{claim:i,reason:n,payload:t}}),_defineProperty(this,"code","ERR_JWT_CLAIM_VALIDATION_FAILED"),_defineProperty(this,"claim",void 0),_defineProperty(this,"reason",void 0),_defineProperty(this,"payload",void 0),this.claim=i,this.reason=n,this.payload=t}},"code","ERR_JWT_CLAIM_VALIDATION_FAILED");_defineProperty(class extends JOSEError{constructor(e,t){let i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"unspecified",n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"unspecified";super(e,{cause:{claim:i,reason:n,payload:t}}),_defineProperty(this,"code","ERR_JWT_EXPIRED"),_defineProperty(this,"claim",void 0),_defineProperty(this,"reason",void 0),_defineProperty(this,"payload",void 0),this.claim=i,this.reason=n,this.payload=t}},"code","ERR_JWT_EXPIRED");_defineProperty(class extends JOSEError{constructor(){super(...arguments),_defineProperty(this,"code","ERR_JOSE_ALG_NOT_ALLOWED")}},"code","ERR_JOSE_ALG_NOT_ALLOWED");_defineProperty(class extends JOSEError{constructor(){super(...arguments),_defineProperty(this,"code","ERR_JOSE_NOT_SUPPORTED")}},"code","ERR_JOSE_NOT_SUPPORTED");_defineProperty(class extends JOSEError{constructor(){super(arguments.length>0&&void 0!==arguments[0]?arguments[0]:"decryption operation failed",arguments.length>1?arguments[1]:void 0),_defineProperty(this,"code","ERR_JWE_DECRYPTION_FAILED")}},"code","ERR_JWE_DECRYPTION_FAILED");_defineProperty(class extends JOSEError{constructor(){super(...arguments),_defineProperty(this,"code","ERR_JWE_INVALID")}},"code","ERR_JWE_INVALID");_defineProperty(class extends JOSEError{constructor(){super(...arguments),_defineProperty(this,"code","ERR_JWS_INVALID")}},"code","ERR_JWS_INVALID");_defineProperty(class extends JOSEError{constructor(){super(...arguments),_defineProperty(this,"code","ERR_JWT_INVALID")}},"code","ERR_JWT_INVALID");_defineProperty(class extends JOSEError{constructor(){super(...arguments),_defineProperty(this,"code","ERR_JWK_INVALID")}},"code","ERR_JWK_INVALID");_defineProperty(class extends JOSEError{constructor(){super(...arguments),_defineProperty(this,"code","ERR_JWKS_INVALID")}},"code","ERR_JWKS_INVALID");_defineProperty(class extends JOSEError{constructor(){super(arguments.length>0&&void 0!==arguments[0]?arguments[0]:"no applicable key found in the JSON Web Key Set",arguments.length>1?arguments[1]:void 0),_defineProperty(this,"code","ERR_JWKS_NO_MATCHING_KEY")}},"code","ERR_JWKS_NO_MATCHING_KEY");_defineProperty(class extends JOSEError{constructor(){super(arguments.length>0&&void 0!==arguments[0]?arguments[0]:"multiple matching keys found in the JSON Web Key Set",arguments.length>1?arguments[1]:void 0),_defineProperty(this,Symbol.asyncIterator,void 0),_defineProperty(this,"code","ERR_JWKS_MULTIPLE_MATCHING_KEYS")}},"code","ERR_JWKS_MULTIPLE_MATCHING_KEYS");_defineProperty(class extends JOSEError{constructor(){super(arguments.length>0&&void 0!==arguments[0]?arguments[0]:"request timed out",arguments.length>1?arguments[1]:void 0),_defineProperty(this,"code","ERR_JWKS_TIMEOUT")}},"code","ERR_JWKS_TIMEOUT");_defineProperty(class extends JOSEError{constructor(){super(arguments.length>0&&void 0!==arguments[0]?arguments[0]:"signature verification failed",arguments.length>1?arguments[1]:void 0),_defineProperty(this,"code","ERR_JWS_SIGNATURE_VERIFICATION_FAILED")}},"code","ERR_JWS_SIGNATURE_VERIFICATION_FAILED");class HubUIError extends Error{constructor(e,t="HUBUI_ERROR"){super(e),this.name="HubUIError",this.code=t;const i=Error.captureStackTrace;i&&i(this,HubUIError)}}const Tn={CONNECTION_FAILED:"CONNECTION_FAILED",CONNECTION_TIMEOUT:"CONNECTION_TIMEOUT",CONNECTION_LOST:"CONNECTION_LOST",INVALID_API_KEY:"INVALID_API_KEY",INVALID_AGENT_ID:"INVALID_AGENT_ID",UNAUTHORIZED:"UNAUTHORIZED",INVALID_CONFIG:"INVALID_CONFIG",MISSING_AGENT_ID:"MISSING_AGENT_ID",MISSING_API_KEY:"MISSING_API_KEY",INVALID_MODE:"INVALID_MODE",MICROPHONE_ACCESS_DENIED:"MICROPHONE_ACCESS_DENIED",AUDIO_DEVICE_ERROR:"AUDIO_DEVICE_ERROR",SESSION_NOT_CONNECTED:"SESSION_NOT_CONNECTED",SESSION_ALREADY_CONNECTED:"SESSION_ALREADY_CONNECTED",NETWORK_ERROR:"NETWORK_ERROR",TOKEN_FETCH_FAILED:"TOKEN_FETCH_FAILED",UNKNOWN:"UNKNOWN"};function createError(e,t){return new HubUIError(e,t)}const Cn="/api/v1/tokens/public",Sn="lk-chat-topic",En="User",wn="0.1.0";class HubUISession{constructor(e){this.eventListeners=new Map,this._state="disconnected",this._transcript=[],this._isMuted=!1,this.transcriptIdCounter=0,this.audioContext=null,this.audioUnlocked=!1,this.config=e,this.debug=e.debug??!1,function(e){for(const t of Vt)t.setLevel(e)}(this.debug?Ut.debug:Ut.silent),this.room=new Room({adaptiveStream:!0,dynacast:!0})}get state(){return this._state}get mode(){return this.config.mode}get transcript(){return[...this._transcript]}async connect(e){this.log("[HubUI] Connecting to room..."),this.log("[HubUI] Token response:",{hubui_url:e.hubui_url,room_name:e.room_name,token_length:e.token?.length}),this.updateState("connecting");try{"voice"===this.config.mode&&await this.unlockAudio(),this.setupRoomListeners(),this.registerTextStreamHandlers(),this.log("[HubUI] Connecting to realtime room:",e.hubui_url),await this.room.connect(e.hubui_url,e.token,{autoSubscribe:!0}),this.log("[HubUI] Room connected, localParticipant:",this.room.localParticipant.identity);const t=Array.from(this.room.remoteParticipants.values());if(this.log("[HubUI] Remote participants on connect:",t.map(e=>e.identity)),"voice"===this.config.mode)try{await this.room.startAudio(),this.log("[HubUI] Audio started successfully")}catch(e){this.log("[HubUI] startAudio deferred - may need user gesture")}"voice"===this.config.mode&&(this.log("[HubUI] Enabling microphone..."),this.config.audioInput?await this.room.localParticipant.setMicrophoneEnabled(!0,{deviceId:this.config.audioInput}):await this.room.localParticipant.setMicrophoneEnabled(!0),this.log("[HubUI] Microphone enabled")),this.config.audioOutput&&await this.setAudioOutput(this.config.audioOutput),this.updateState("connected"),this.emit("connected"),this.log("[HubUI] Connection complete, state:",this._state)}catch(e){throw this.logError("[HubUI] Connection failed:",e),this.updateState("disconnected"),function(e){return e instanceof HubUIError?e:e instanceof Error?new HubUIError(e.message,Tn.UNKNOWN):new HubUIError(String(e),Tn.UNKNOWN)}(e)}}on(e,t){this.eventListeners.has(e)||this.eventListeners.set(e,new Set),this.eventListeners.get(e).add(t)}off(e,t){const i=this.eventListeners.get(e);i&&i.delete(t)}mute(){"voice"===this.config.mode&&(this.room.localParticipant.setMicrophoneEnabled(!1),this._isMuted=!0)}unmute(){"voice"===this.config.mode&&(this.room.localParticipant.setMicrophoneEnabled(!0),this._isMuted=!1)}isMuted(){return this._isMuted}async enableAudio(){await this.room.startAudio()}async send(e){if("connected"!==this._state)throw createError("Not connected to agent",Tn.SESSION_NOT_CONNECTED);if(e.trim()){this.log("[HubUI] Sending message:",e),this.addTranscriptEntry("user",e,!0);try{this.log("[HubUI] Creating text stream on lk.chat topic...");const t=await this.room.localParticipant.streamText({topic:"lk.chat"});await t.write(e),await t.close(),this.log("[HubUI] Message sent successfully via text stream")}catch(t){this.log("[HubUI] Text stream failed, using data channel fallback:",t);const i=(new TextEncoder).encode(JSON.stringify({text:e}));await this.room.localParticipant.publishData(i,{reliable:!0,topic:Sn}),this.log("[HubUI] Message sent via data channel fallback")}}}async setAudioInput(e){await this.room.switchActiveDevice("audioinput",e)}async setAudioOutput(e){await this.room.switchActiveDevice("audiooutput",e)}async disconnect(){if(this.audioContext){try{await this.audioContext.close()}catch(e){}this.audioContext=null}if(this.room&&"connected"===this._state)try{const e=await this.room.localParticipant.streamText({topic:"lk.chat"});await e.write("[SESSION_END]"),await e.close(),await new Promise(e=>setTimeout(e,100))}catch(e){}await this.room.disconnect(),this.updateState("disconnected"),this.emit("disconnected")}async unlockAudio(){if(!this.audioUnlocked)try{const e=window.AudioContext||window.webkitAudioContext;if(e){const t=new e;this.audioContext=t,"suspended"===t.state&&await t.resume();const i=t.createBuffer(1,1,22050),n=t.createBufferSource();n.buffer=i,n.connect(t.destination),n.start(0)}const t=document.createElement("audio");t.setAttribute("playsinline","true"),t.setAttribute("webkit-playsinline","true"),t.muted=!1,t.src="data:audio/wav;base64,UklGRigAAABXQVZFZm10IBIAAAABAAEARKwAAIhYAQACABAAAABkYXRhAgAAAAEA",t.volume=.1;try{await t.play()}catch(e){}this.audioUnlocked=!0}catch(e){this.log("[HubUI] Audio unlock failed:",e)}}registerTextStreamHandlers(){this.room.registerTextStreamHandler("lk.chat",async(e,t)=>{this.log("[HubUI] lk.chat stream received from:",t);if(("string"==typeof t?t:t?.identity)===this.room.localParticipant.identity)return void this.log("[HubUI] Skipping lk.chat - from local participant");const i=`chat-${Date.now()}`;let n="";try{for await(const t of e)this.log("[HubUI] lk.chat chunk:",t),n+=t,n.trim()&&this.updateTranscriptEntry(i,"agent",n,!1);n.trim()&&(this.log("[HubUI] lk.chat complete:",n),this.updateTranscriptEntry(i,"agent",n,!0),this.emit("message",n))}catch(e){this.logError("[HubUI] Error reading lk.chat stream:",e)}}),this.room.registerTextStreamHandler("lk.transcription",async(e,t)=>{if(this.log("[HubUI] lk.transcription stream received from:",t),"text"!==this.config.mode)return void this.log("[HubUI] Skipping lk.transcription - not in text mode");if(("string"==typeof t?t:t?.identity)===this.room.localParticipant.identity)return void this.log("[HubUI] Skipping lk.transcription - from local participant");const i=e.info?.attributes?.["lk.segment_id"]||`agent-${Date.now()}`;let n="";try{for await(const t of e)this.log("[HubUI] lk.transcription chunk:",t),n+=t,n.trim()&&(this.updateTranscriptEntry(i,"agent",n,!1),this.emit("transcript",n,"agent",!1));n.trim()&&(this.log("[HubUI] lk.transcription complete:",n),this.updateTranscriptEntry(i,"agent",n,!0),this.emit("transcript",n,"agent",!0))}catch(e){this.logError("[HubUI] Error reading lk.transcription stream:",e)}})}setupRoomListeners(){this.room.on(hi.ConnectionStateChanged,e=>{this.log("[HubUI] Room ConnectionStateChanged:",e);const t=this.mapConnectionState(e);this.updateState(t)}),this.room.on(hi.ParticipantConnected,e=>{this.log("[HubUI] Participant connected:",e.identity,e.kind)}),this.room.on(hi.TrackPublished,(e,t)=>{this.log("[HubUI] Track published:",e.kind,"from",t.identity)}),this.room.on(hi.TrackSubscribed,(e,t,i)=>{if(this.log("[HubUI] Track subscribed:",e.kind,"from",i.identity),e.kind===Track.Kind.Audio&&"voice"===this.config.mode){const t=e.attach();t.setAttribute("playsinline","true"),t.setAttribute("webkit-playsinline","true"),t.autoplay=!0,t.muted=!1,t.volume=1,document.body.appendChild(t),t.play().catch(e=>{this.log("[HubUI] Audio play blocked, user interaction needed"),this.emit("audioPlaybackBlocked")})}}),this.room.on(hi.TrackUnsubscribed,e=>{e.kind===Track.Kind.Audio&&e.detach().forEach(e=>e.remove())}),this.room.on(hi.TranscriptionReceived,(e,t)=>{this.log("[HubUI] TranscriptionReceived:",e.length,"segments from",t?.identity);for(const i of e){const e=t?.sid===this.room.localParticipant.sid?"user":"agent",n=i.final;this.log(`[HubUI] Transcript segment: speaker=${e}, final=${n}, text="${i.text}"`);const s=this._transcript.findIndex(e=>e.id===i.id);s>=0?(this._transcript[s].text=i.text,this._transcript[s].isFinal=n):this._transcript.push({id:i.id,speaker:e,text:i.text,timestamp:new Date,isFinal:n}),this.emit("transcript",i.text,e,n)}}),this.room.on(hi.DataReceived,(e,t,i,n)=>{this.log("[HubUI] DataReceived, topic:",n,"from:",t?.identity);if(t&&!t.isLocal)try{const t=(new TextDecoder).decode(e);this.log("[HubUI] DataReceived decoded:",t);try{const e=JSON.parse(t),i=e.text||e.response||e.message||e.content;i&&(this.addTranscriptEntry("agent",i,!0),this.emit("message",i))}catch{t.trim()&&(this.addTranscriptEntry("agent",t,!0),this.emit("message",t))}}catch(e){this.logWarn("[HubUI] Failed to decode data message",e)}}),this.room.on(hi.AudioPlaybackStatusChanged,()=>{this.log("[HubUI] AudioPlaybackStatusChanged, canPlaybackAudio:",this.room.canPlaybackAudio),this.room.canPlaybackAudio||this.emit("audioPlaybackBlocked")}),this.room.on(hi.Disconnected,()=>{this.log("[HubUI] Room disconnected"),this.updateState("disconnected"),this.emit("disconnected")})}mapConnectionState(e){switch(e){case bn.Connected:return"connected";case bn.Connecting:return"connecting";case bn.Reconnecting:return"reconnecting";case bn.Disconnected:default:return"disconnected"}}updateState(e){this._state!==e&&(this._state=e,this.emit("connectionStateChanged",e))}addTranscriptEntry(e,t,i){const n={id:""+ ++this.transcriptIdCounter,speaker:e,text:t,timestamp:new Date,isFinal:i};this._transcript.push(n)}updateTranscriptEntry(e,t,i,n){const s=this._transcript.findIndex(t=>t.id===e);s>=0?(this._transcript[s].text=i,this._transcript[s].isFinal=n):this._transcript.push({id:e,speaker:t,text:i,timestamp:new Date,isFinal:n})}log(...e){this.debug&&console.log(...e)}logWarn(...e){this.debug&&console.warn(...e)}logError(...e){this.debug&&console.error(...e)}emit(e,...t){const i=this.eventListeners.get(e);i&&i.forEach(i=>{try{i(...t)}catch(t){this.logError(`[HubUI] Error in ${e} listener:`,t)}})}}class HubUI{static async connect(e){let t;if(HubUI.validateConfig(e),e.token){if(!e.serverUrl)throw createError("serverUrl is required when using token directly",Tn.INVALID_CONFIG);t={token:e.token,hubui_url:e.serverUrl,room_name:""}}else t=await HubUI.fetchToken(e);const i=new HubUISession(e);return await i.connect(t),i}static async getAudioDevices(){try{await navigator.mediaDevices.getUserMedia({audio:!0});const e=await navigator.mediaDevices.enumerateDevices(),t=e.filter(e=>"audioinput"===e.kind).map(e=>({deviceId:e.deviceId,label:e.label||`Microphone ${e.deviceId.slice(0,8)}`,kind:"audioinput"}));return{inputs:t,outputs:e.filter(e=>"audiooutput"===e.kind).map(e=>({deviceId:e.deviceId,label:e.label||`Speaker ${e.deviceId.slice(0,8)}`,kind:"audiooutput"}))}}catch(e){throw createError("Failed to get audio devices. Please ensure microphone permission is granted.",Tn.AUDIO_DEVICE_ERROR)}}static validateConfig(e){if(!e)throw createError("Configuration is required",Tn.INVALID_CONFIG);if(!e.agentId||"string"!=typeof e.agentId)throw createError("agentId is required",Tn.MISSING_AGENT_ID);if(!e.token){if(!e.apiKey||"string"!=typeof e.apiKey)throw createError("apiKey or token is required",Tn.MISSING_API_KEY);if(!e.apiKey.startsWith("pk_live_"))throw createError("Invalid API key format. Key should start with pk_live_",Tn.INVALID_API_KEY)}if(!e.mode||!["voice","text"].includes(e.mode))throw createError('mode must be either "voice" or "text"',Tn.INVALID_MODE)}static async fetchToken(e){const t=`${e.apiBaseUrl||"https://api.hubui.ai"}${Cn}`;try{const i=await fetch(t,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({api_key:e.apiKey,agent_id:e.agentId,mode:e.mode,user_name:e.userName||En,user_email:e.userEmail})});if(!i.ok){const e=await i.json().catch(()=>({})),t=e.detail||e.error||"Failed to authenticate";if(401===i.status||403===i.status)throw createError(t,Tn.INVALID_API_KEY);if(404===i.status)throw createError("Agent not found or not accessible",Tn.INVALID_AGENT_ID);throw createError(t,Tn.TOKEN_FETCH_FAILED)}const n=await i.json();if(!n.token||!n.hubui_url)throw createError("Invalid token response from server",Tn.TOKEN_FETCH_FAILED);return n}catch(e){if(e instanceof HubUIError)throw e;throw createError("Failed to connect to HubUI. Please check your internet connection.",Tn.NETWORK_ERROR)}}}export{Tn as ErrorCodes,HubUI,HubUIError,HubUISession,wn as SDK_VERSION};
2
+ //# sourceMappingURL=index.esm.js.map