@cloudflare/realtimekit 0.5.0-staging.73 → 0.5.0-staging.75
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser.js +6 -5
- package/dist/index.cjs.js +1 -1
- package/dist/index.es.js +1 -1
- package/dist/react.cjs.js +15 -15
- package/dist/react.d.ts +110 -4671
- package/dist/react.es.js +18635 -20991
- package/dist/ts3.4/dist/react.d.ts +109 -4571
- package/package.json +1 -1
package/dist/index.cjs.js
CHANGED
|
@@ -20,4 +20,4 @@ ${t}`}const Ws={maxInvocations:5,period:1};function Ut(t,e){return function(n,r,
|
|
|
20
20
|
`}this.midTransceiverMap.set(a.mid,a);const d=l=>u(this,null,function*(){return p.debug(`send() | calling pc.setRemoteDescription() [answer:${JSON.stringify(l)}]`),yield this.pc.setRemoteDescription(l),a.mid});return p.debug(`send() | calling pc.setLocalDescription() [offer: ${JSON.stringify(c,void 0,2)}]`),{offerSdp:c,callback:d,sender:a.sender,mid:a.mid}})}addCustomEventListeners(){this.pc.addEventListener("datachannel",e=>{const{channel:n}=e;n.onmessage=r=>{this.safeEmit("datachannel",e.channel,String.fromCharCode(...new Uint8Array(r.data)))}})}}class xd extends Sp{constructor(e){super(),g(this,"supportsSendEncodings",!1),this.supportsSendEncodings=e.supportsSendEncodings}static createFactory(e){return()=>new xd(e)}get name(){return"Firefox60"}send(e){return u(this,arguments,function*({track:n,encodings:r,codecOptions:i,screenShare:s}){this._assertSendDirection();const a=this.supportsSendEncodings&&r!==void 0?{sendEncodings:r}:{},c=this.pc.addTransceiver(n,V({direction:"sendonly",streams:[s?this._sendScreenShareStream:this._sendWebStream]},a));if(!this.supportsSendEncodings&&r){r.reverse();const h=c.sender.getParameters();h.encodings=r,yield c.sender.setParameters(h)}const d=(h,m)=>{var y;const E=ho(h),b=E.media[E.media.length-1],O=b.rtp.filter(J=>m.some(I=>I.name===J.codec)),M=b.fmtp.filter(J=>O.some(I=>I.payload===J.payload)),F=(y=b.rtcpFb)==null?void 0:y.filter(J=>O.some(I=>I.payload===J.payload)),x=O.map(J=>J.payload);return E.media[E.media.length-1].rtp=O,E.media[E.media.length-1].fmtp=M,E.media[E.media.length-1].rtcpFb=F,E.media[E.media.length-1].payloads=x.join(" "),ku(E)},l=yield this.pc.createOffer();if(l.sdp=d(l.sdp,i),p.debug(`send() | calling pc.setLocalDescription() [offer:${JSON.stringify(l)}]`),yield this.pc.setLocalDescription(l),n==="audio"||n.kind==="audio"){const{enableDtx:h,enableStereo:m}=this,y=this.enableHighBitrate?m?128e3:64e3:m?64e3:32e3;l.sdp=l.sdp.replace("minptime=10;useinbandfec=1",`minptime=10;useinbandfec=1;${h?"usedtx=1;":""}${m?"stereo=1;sprop-stereo=1;":""}maxaveragebitrate=${y}`)}return this.midTransceiverMap.set(c.mid,c),{offerSdp:l,callback:h=>u(this,null,function*(){return p.debug(`send() | calling pc.setRemoteDescription() [answer:${JSON.stringify(h)}]`),yield this.pc.setRemoteDescription(h),c.mid}),sender:c.sender,mid:c.mid}})}setMaxSpatialLayer(e,n){return u(this,null,function*(){this._assertSendDirection(),p.debug(`setMaxSpatialLayer() [localId:${e}, spatialLayer:${n}]`);const r=this.midTransceiverMap.get(e);if(!r)throw new Error("associated RTCRtpTransceiver not found");const i=r.sender.getParameters(),s=i.encodings.length-1-n;i.encodings.forEach((a,c)=>{c>=s?a.active=!0:a.active=!1}),yield r.sender.setParameters(i)})}addCustomEventListeners(){this.pc.addEventListener("datachannel",e=>{const{channel:n}=e;n.onmessage=r=>u(this,null,function*(){const i=yield r.data.arrayBuffer();this.safeEmit("datachannel",e.channel,String.fromCharCode(...new Uint8Array(i)))})})}}class Tp extends Sp{static createFactory(){return()=>new Tp}get name(){return"Chrome74"}send(e){return u(this,arguments,function*({track:n,encodings:r,codecOptions:i,screenShare:s}){this._assertSendDirection(),p.debug("Safari12::creating new transceiver");const a=this.pc.addTransceiver(n,{direction:"sendonly",streams:[s?this._sendScreenShareStream:this._sendWebStream],sendEncodings:r}),c=RTCRtpSender.getCapabilities(typeof n=="string"?n:n.kind);p.info(`Safari12::senders available params: ${JSON.stringify(c)}`);const d=[];i&&i.length>0&&i.forEach(h=>{var m;const y=c.codecs.find(E=>E.mimeType.includes(h.name));if(h.parameters){p.info(`Safari12::codecOption.parameters:, ${JSON.stringify(h.parameters)}`);const E=((m=y.sdpFmtpLine)==null?void 0:m.split(";"))||[];E.push(...h.parameters);const b=[...new Set(E).values()];y.sdpFmtpLine=b.join(";")}d.push(y)}),p.info(`Safari12::selected codecs: ${JSON.stringify(d)}`),a.setCodecPreferences(d);const l=yield this.pc.createOffer();if(yield this.pc.setLocalDescription(l),n==="audio"||n.kind==="audio"){const{enableStereo:h,enableDtx:m}=this,y=this.enableHighBitrate?h?128e3:64e3:h?64e3:32e3;l.sdp=l.sdp.replace("minptime=10;useinbandfec=1",`minptime=10;useinbandfec=1;${m?"usedtx=1;":""}${h?"stereo=1;sprop-stereo=1;":""}maxaveragebitrate=${y}`)}return this.midTransceiverMap.set(a.mid,a),{offerSdp:l,callback:h=>u(this,null,function*(){return p.debug(`Safari12::send() | calling pc.setRemoteDescription() [answer:${JSON.stringify(h)}]`),yield this.pc.setRemoteDescription(h),a.mid}),sender:a.sender,mid:a.mid}})}addCustomEventListeners(){this.pc.ondatachannel=e=>{const{channel:n}=e;n.onmessage=r=>u(this,null,function*(){const i=String.fromCharCode(...new Uint8Array(r.data));this.safeEmit("datachannel",e.channel,i)})}}}function RN(t,e){return typeof t=="undefined"?e:typeof window!="undefined"&&Object.getOwnPropertyDescriptor(window,"structuredClone")?structuredClone(t):JSON.parse(JSON.stringify(t))}var qc,cs,$n,Yn,Dr,Gc,du,ih,Ay,sh,Dy;class MN extends xo{constructor(e){var n;super(),f(this,Yn),f(this,Gc),f(this,ih),f(this,sh),g(this,"rtpReceiver"),g(this,"id"),g(this,"localId"),g(this,"producerId"),g(this,"producingTransportId"),g(this,"mimeType"),g(this,"track"),g(this,"peerId"),g(this,"appData"),g(this,"transceiver"),f(this,qc,void 0),f(this,cs,void 0),f(this,$n,void 0),this.id=e.id,this.localId=e.localId,v(this,qc,e.handler),this.appData=e.appData,this.peerId=e.producingPeerId,this.producingTransportId=e.producingTransportId,v(this,$n,!1),this.producerId=e.producerId,this.track=e.track,v(this,cs,(n=e.paused)!=null?n:!1),this.mimeType=e.mimeType,this.transceiver=e.transceiver,this.rtpReceiver=e.rtpReceiver,H(this,ih,Ay).call(this)}get closed(){return o(this,$n)}get kind(){return this.track.kind}get paused(){return o(this,cs)}close(e,n){o(this,$n)||(p.debug(`Consumer::close() ${e?`with reason ${e}`:""}`,o(this,Yn,Dr)),v(this,$n,!0),n&&(H(this,sh,Dy).call(this),this.transceiver.stop()),this.safeEmit("close",e))}getStats(){return u(this,null,function*(){if(o(this,$n))throw new Pt("closed");return o(this,qc).getReceiverStats(this.localId)})}pause(){if(p.debug("consumer::pause()",o(this,Yn,Dr)),o(this,$n)){p.error("consumer::pause() | Consumer closed",o(this,Yn,Dr));return}v(this,cs,!0),this.track.enabled=!1,this.safeEmit("pause")}resume(){if(p.debug("consumer::resume()",o(this,Yn,Dr)),o(this,$n)){p.error("Consumer::resume() | Consumer closed",o(this,Yn,Dr));return}v(this,cs,!1),this.track.enabled=!0,this.safeEmit("resume")}}qc=new WeakMap,cs=new WeakMap,$n=new WeakMap,Yn=new WeakSet,Dr=function(){return{consumer:{id:this.id,appData:this.appData,peerId:this.peerId,kind:this.kind}}},Gc=new WeakSet,du=function(){p.debug('Consumer::track "ended" event',o(this,Yn,Dr)),this.safeEmit("trackended")},ih=new WeakSet,Ay=function(){this.track.addEventListener("ended",H(this,Gc,du).bind(this))},sh=new WeakSet,Dy=function(){try{this.track.removeEventListener("ended",H(this,Gc,du)),this.track.stop()}catch(t){p.error("Consumer::destroyTrack()",G(V({},o(this,Yn,Dr)),{error:t}))}};var Mn,Ka,za,ds,fn,ut,oi,Ya,en,vn;class AN extends xo{constructor(e){var n,r;super(),f(this,en),g(this,"id"),g(this,"localId"),f(this,Mn,void 0),g(this,"kind"),g(this,"appData"),g(this,"rtpSender"),f(this,Ka,void 0),f(this,za,void 0),f(this,ds,void 0),f(this,fn,!1),f(this,ut,void 0),f(this,oi,void 0),f(this,Ya,void 0),this.id=e.id,this.localId=e.localId,v(this,ut,e.track),this.kind=(n=e.track)==null?void 0:n.kind,v(this,oi,e.disableTrackOnPause?!((r=e.track)!=null&&r.enabled):!1),v(this,Ya,void 0),v(this,Ka,e.stopTracks),v(this,za,e.disableTrackOnPause),v(this,ds,e.zeroRtpOnPause),this.appData=e.appData||{},this._onTrackEnded=this._onTrackEnded.bind(this),v(this,Mn,e.handler),this.rtpSender=e.rtpSender,this._handleTrack()}get closed(){return o(this,fn)}get track(){return o(this,ut)}get paused(){return o(this,oi)}get maxSpatialLayer(){return o(this,Ya)}close(e){return u(this,null,function*(){if(o(this,fn))return;if(p.debug(`Producer::close() ${e?`with reason ${e}`:""}`,o(this,en,vn)),v(this,fn,!0),this._destroyTrack(),e===oh){this.safeEmit("close");return}const{offerSdp:n,callback:r}=yield o(this,Mn).stopSending(this.localId),{answer:i}=yield this.safeEmitAsPromise("close",{offer:n,reason:e});r(i)})}getStats(){return u(this,null,function*(){if(o(this,fn))throw new Pt("closed");return o(this,Mn).getSenderStats(this.localId)})}pause(){p.debug("Producer::pause()",o(this,en,vn)),o(this,fn)&&p.error("Producer::pause() | Producer closed",o(this,en,vn)),v(this,oi,!0),o(this,ut)&&o(this,za)&&(o(this,ut).enabled=!1),o(this,ds)&&o(this,Mn).replaceTrack(this.localId,null),this.emit("pause")}resume(){if(p.debug("Producer::resume()",o(this,en,vn)),o(this,fn)){p.error("Producer::resume() | Producer closed",o(this,en,vn));return}v(this,oi,!1),o(this,ut)&&o(this,za)&&(o(this,ut).enabled=!0),o(this,ds)&&o(this,Mn).replaceTrack(this.localId,o(this,ut)),this.emit("resume")}replaceTrack(e){return u(this,arguments,function*({track:n}){if(p.debug(`Producer::replaceTrack() trackId: ${n==null?void 0:n.id}`,o(this,en,vn)),o(this,fn)){if(n&&o(this,Ka))try{n.stop()}catch(r){p.error("Producer::replaceTrack",G(V({},o(this,en,vn)),{error:r}))}throw new Pt("closed")}else if(n&&n.readyState==="ended")throw new Pt("track ended");if(n===o(this,ut)){p.debug(`replaceTrack() | same track, ignored trackId: ${n.id}`,o(this,en,vn));return}(!o(this,ds)||!o(this,oi))&&(yield o(this,Mn).replaceTrack(this.localId,n)),this._destroyTrack(),v(this,ut,n),this._handleTrack()})}setMaxSpatialLayer(e){return u(this,null,function*(){if(o(this,fn))throw new Pt("closed");if(this.kind!=="video")throw new Lo("not a video Producer");if(typeof e!="number")throw new TypeError("invalid spatialLayer");yield o(this,Mn).setMaxSpatialLayer(this.localId,e),v(this,Ya,e)})}setRtpEncodingParameters(e){return u(this,null,function*(){if(o(this,fn))throw new Pt("closed");if(typeof e!="object")throw new TypeError("invalid params");yield o(this,Mn).setRtpEncodingParameters(this.localId,e)})}_onTrackEnded(){p.debug(`Producer::track "ended" event trackId: ${this.track.id}`,o(this,en,vn)),this.safeEmit("trackended",this.track.id)}_handleTrack(){o(this,ut)&&o(this,ut).addEventListener("ended",this._onTrackEnded)}_destroyTrack(){var e;if(o(this,ut))try{o(this,ut).removeEventListener("ended",this._onTrackEnded),o(this,Ka)&&o(this,ut).stop()}catch(n){p.error(`Producer::_destroyTrack trackId: ${(e=this.track)==null?void 0:e.id}`,G(V({},o(this,en,vn)),{error:n}))}}}Mn=new WeakMap,Ka=new WeakMap,za=new WeakMap,ds=new WeakMap,fn=new WeakMap,ut=new WeakMap,oi=new WeakMap,Ya=new WeakMap,en=new WeakSet,vn=function(){return{producer:{id:this.id,appData:this.appData,kind:this.kind}}};function Oy(t){return typeof t=="object"&&!Array.isArray(t)&&t!==null}function ah(t){return Math.random().toString(36).substring(2,2+t)}const Tc=1;function qg(t){const e=t;return delete e.payload._bolt,e}function DN(t){return t.payload&&Oy(t.payload)}function Ny(t){var e,n;return DN(t)&&(n=(e=t.payload._bolt)==null?void 0:e.id)!=null?n:""}var ci;const Qa=class extends mt.EventEmitter{constructor(t,e,n){super(),g(this,"channel"),g(this,"queue"),g(this,"serverProtocolVersion"),f(this,ci,new Map),g(this,"respond",(r,i,s=!1)=>{let a;s?a=Qa.createErrorResponse(r,i):a=Qa.createResponse(r,i),this.channel.send(JSON.stringify(a))}),g(this,"notify",r=>{const i=Qa.createNotification(r);this.channel.send(JSON.stringify(i))}),g(this,"request",r=>u(this,null,function*(){const i=Qa.createRequest(r),s=new Promise((a,c)=>{const d=1e3*(5+.1*this.queue.size),{id:l}=i.payload._bolt,h={id:l,method:i.type,resolve:m=>{this.queue.delete(l)&&(clearTimeout(h.timer),a(m))},timer:setTimeout(()=>{this.queue.delete(l)&&c(new Error(`request timeout for message id: ${l}`))},d),cancel:m=>{this.queue.delete(l)&&(clearTimeout(h.timer),c(m))}};this.queue.set(l,h)});return this.channel.send(JSON.stringify(i)),s})),g(this,"send",r=>{const i=JSON.stringify(r),s=16384;if(i.length>s){const a=s-200,c=Math.ceil(i.length/a),d=[];for(let h=0;h<c;h+=1){const m=h*a,y=(h+1)*a;d.push(i.slice(m,y))}const l=Us();for(let h=0;h<c;h+=1){const m=d[h],y=JSON.stringify({id:l,count:c,chunkIndex:h,chunk:m});p.debug(`Sending message chunk over dc: ${y}`),this.channel.send(y)}}else p.debug(`Sending message over dc: ${i}`),this.channel.send(i)}),g(this,"processMessage",r=>{var i;o(this,ci).has(r.id)||o(this,ci).set(r.id,[]);const s=o(this,ci).get(r.id);if(s[r.chunkIndex]=r,(s==null?void 0:s.length)===r.count&&!s.some(a=>a===void 0)){const a=o(this,ci).get(r.id),c=a==null?void 0:a.reduce((l,h)=>l+h.chunk,"");o(this,ci).delete(r.id);const d=JSON.parse(c);if(!d.payload||!Oy(d.payload))throw new Error("corrupted incoming message over dc",{cause:{code:"CORRUPT_DC_MESSAGE",values:d}});if(this.processBoltHandshake(d))return;if(this.serverProtocolVersion=(i=d.payload._bolt)==null?void 0:i.version,!this.processResponseMsg(d))return d}}),g(this,"processResponseMsg",r=>{const{id:i}=r.payload._bolt,s=this.queue.get(i);return s?(p.debug(`resolving pending request with id: ${i}, complete response: ${JSON.stringify(r)}`),r.type==="error"?s.cancel(qg(r)):s.resolve(qg(r)),!0):!1}),g(this,"processBoltHandshake",r=>{var i,s;return r.type==="_bolt"||r.type==="handshake"?(this.respond((s=(i=r.payload._bolt)==null?void 0:i.id)!=null?s:ah(8),{type:"_bolt",payload:{message:"pong"}}),!0):!1}),this.label=e,this.transportId=n,this.channel=t,this.queue=new Map}};let Xa=Qa;ci=new WeakMap,g(Xa,"createRequest",t=>{var e;if((e=t.payload)!=null&&e._bolt)throw new Error("rpc fields are internal values");return{type:t.type,payload:G(V({},t.payload),{_bolt:{id:ah(8),type:"REQUEST",version:Tc}})}}),g(Xa,"createResponse",(t,e)=>{var n;if((n=e.payload)!=null&&n._bolt)throw new Error("rpc fields are internal values");return{type:e.type,payload:G(V({},e.payload),{_bolt:{id:t,type:"RESPONSE",version:Tc}})}}),g(Xa,"createNotification",t=>{var e;if((e=t.payload)!=null&&e._bolt)throw new Error("rpc fields are internal values");return{type:t.type,payload:G(V({},t.payload),{bolt:{id:ah(8),type:"NOTIFY",version:Tc}})}}),g(Xa,"createErrorResponse",(t,e)=>({type:"error",payload:{error:e.message,_bolt:{id:t,type:"RESPONSE",version:Tc}}}));function ON(t){if(Promise.allSettled)return Promise.allSettled(t);const e=t.map(n=>n.then(r=>({status:"fulfilled",value:r})).catch(r=>({status:"rejected",reason:r})));return Promise.all(e)}const oh="transport closed";var Za;const ch=class extends xo{constructor(t,{id:e,direction:n,handlerFactory:r,iceServers:i,iceTransportPolicy:s,proprietaryConstraints:a,additionalSettings:c,appData:d,config:l}){var h,m,y;super(),g(this,"awaitQueue"),g(this,"observer"),f(this,Za,void 0),g(this,"id"),g(this,"serverId"),g(this,"closed",!1),g(this,"direction"),g(this,"maxSctpMessageSize"),g(this,"handler"),g(this,"connectionState","new"),g(this,"producers"),g(this,"consumers"),g(this,"datachannels"),g(this,"connected",!1),g(this,"eventsDCReadyPromise"),g(this,"eventsDCReadyPromiseResolver"),g(this,"eventsDCFailureTimer"),g(this,"transportConnectionPromise"),g(this,"consumerTrackEvents"),g(this,"unknownTracksMap"),g(this,"appData"),p.debug(`constructor() [id: ${e}, direction: ${n}]`),v(this,Za,t),this.id=e,this.direction=n;const E=RN(c,{});delete E.iceServers,delete E.iceTransportPolicy,delete E.bundlePolicy,delete E.rtcpMuxPolicy,delete E.sdpSemantics,this.producers=new Map,this.consumers=new Map,this.datachannels=new Map,this.consumerTrackEvents=new Map,this.unknownTracksMap=new Map,this.awaitQueue=new Ld,this.observer=new xo,this.handler=r(),this.handler.enableHighBitrate=(h=l==null?void 0:l.enableHighBitrate)!=null?h:!1,this.handler.enableStereo=(m=l==null?void 0:l.enableStereo)!=null?m:!1,this.handler.enableDtx=(y=l==null?void 0:l.enableDtx)!=null?y:!0,this.handler.init({onTrackHandler:this._ontrack.bind(this),direction:n,iceServers:i,iceTransportPolicy:s,additionalSettings:c,proprietaryConstraints:a}),this.appData=d||{},this.transportConnectionPromise=new Promise(b=>{this.observer.once("connected",()=>{b(!0)}),this.observer.once("disconnect",()=>{b(!1)}),this.observer.once("close",()=>{b(!1)})}),this.eventsDCReadyPromise=new Promise(b=>{this.eventsDCReadyPromiseResolver=b}),this.handler.on("@connectionstatechange",b=>{b!==this.connectionState&&(p.debug(`connection state changed to ${b}`),this.connectionState=b,b==="connected"&&(this.connected=!0,this.observer.emit("connected")),b==="disconnected"&&(this.connected=!1,this.observer.emit("disconnect")),(b==="failed"||b==="closed")&&(this.connected=!1,this.observer.emit("close")),this.closed||this.safeEmit("connectionstatechange",b))}),this.handler.on("@icecandidate",({candidate:b})=>{this.closed||this.safeEmit("icecandidate",b)}),this.handler.on("dc_open",b=>{let O=this.datachannels.get(b.label);O||(O||(O=new Xa(b,b.label,this.serverId),this.datachannels.set(b.label,O)),this.eventsDCFailureTimer=setTimeout(()=>{b.label==="events"&&(this.eventsDCReadyPromiseResolver(!1),this.safeEmit("dc_error",b.label))},5e3))}),this.handler.on("datachannel",(b,O)=>{b.label==="events"&&(this.eventsDCReadyPromiseResolver(!0),this.eventsDCFailureTimer&&clearTimeout(this.eventsDCFailureTimer));const M=this.datachannels.get(b.label);if(!M){p.error("unregistered datachannel for message",{rtcChannel:{label:b.label,message:O}});return}try{const F=JSON.parse(O);p.debug("datachannel message chunk recieved",{dataChannelMessageChunk:{id:F.id,count:F.count,chunkIndex:F.chunkIndex,chunk:F.chunk,transprtId:this.serverId}});const x=M.processMessage(F);if(!x)return;p.debug(`datachannel message with id:${F.id} on transport:${this.serverId}complete - ${JSON.stringify(x)}`),this.emit(`datachannel:${b.label}`,M.label,x)}catch(F){p.error("error parsing message",{error:F})}})}setServerId(t){this.serverId=t}getDatachannel(t){return this.datachannels.get(t)}get isEventsDCReady(){return this.eventsDCReadyPromise}close(){this.closed||(p.debug("Transport close called"),this.connected=!1,this.closed=!0,this.handler.close(),Array.from(this.producers.values()).forEach(t=>{t.close(oh).catch(()=>{})}),this.producers.clear(),Array.from(this.consumers.values()).forEach(t=>{t.close(oh)}),this.consumers.clear(),this.consumerTrackEvents.clear(),this.emit("close"),this.observer.emit("close"))}getStats(){return u(this,null,function*(){if(this.closed)throw new Pt("closed");return this.handler.getTransportStats()})}connect(t){return u(this,null,function*(){try{if(yield this.awaitQueue.push(()=>u(this,null,function*(){const{offerSdp:e,callback:n}=yield this.handler.connect(),{transportId:r,answer:i}=yield t(e);this.setServerId(r),yield n(i)})),!(yield this.transportConnectionPromise))throw new Error("ice connection failed");if(o(this,Za)===rt.HIVE&&!(yield this.isEventsDCReady))throw new Error("events datachannel not open")}catch(e){throw p.error("transport failed to connect:",e),e}})}restartIce(){return u(this,null,function*(){if(p.debug("restartIce()"),this.closed)throw new Pt("closed");return this.handler.restartIce()})}canProduce(t){return u(this,null,function*(){const{track:e,appData:n}=t;if(e){if(this.direction!=="send")throw new Lo("not a sending Transport");if(e.readyState==="ended")throw new Pt("track ended");if(this.listenerCount("connect")===0&&this.connectionState==="new")throw new TypeError('no "connect" listener set into this transport');if(n&&typeof n!="object")throw new TypeError("if given, appData must be an object")}else throw new TypeError("missing track");if(!(yield this.transportConnectionPromise))throw new Rs("transport not connected");return!0})}produce(t,e){return u(this,null,function*(){if(!(yield this.canProduce(t)))throw new Error("Cannot produce");const{track:n,encodings:r,codecOptions:i,stopTracks:s=!0,disableTrackOnPause:a=!0,zeroRtpOnPause:c=!1,appData:d={}}=t;p.debug(`produce() [track:${n.id}]`);const{producerId:l,localId:h,rtpSender:m}=yield this.awaitQueue.push(()=>u(this,null,function*(){const{offerSdp:y,callback:E,sender:b,mid:O}=yield this.handler.send({track:n,encodings:r,codecOptions:i,screenShare:d==null?void 0:d.screenShare}),{answer:M,producerId:F}=yield e({offer:y,kind:n.kind,paused:a?!n.enabled:!1,appData:G(V({},d||{}),{mid:O}),codecOptions:i,producingTransportId:this.serverId}),x=yield E(M);return{producerId:F,localId:x,rtpSender:b}}),"producer");return this.createProducerObject({id:l,localId:h,track:n,stopTracks:s,disableTrackOnPause:a,zeroRtpOnPause:c,appData:d,handler:this.handler,rtpSender:m})})}createProducerObject(t){return u(this,null,function*(){const e=new AN(t);return this.producers.set(e.id,e),e.once("close",()=>{this.producers.delete(e.id)}),e})}closeProducer(t){return u(this,null,function*(){yield this.awaitQueue.push(t.close.bind(t),"producer")})}canConsume(){return u(this,null,function*(){if(this.closed)throw new Pt("closed");if(this.direction!=="recv")throw new Lo("not a receiving transport");if(this.listenerCount("connect")===0&&this.connectionState==="new")throw new TypeError('no "connect" listener set into this transport');if(!(yield this.transportConnectionPromise))throw new Rs("transport not connected");return!0})}consume(t,e,n){return u(this,null,function*(){return this.awaitQueue.push(()=>u(this,null,function*(){const r={},{consumerStates:i,sessionDescription:s,failedProducers:a}=yield e(t);i.forEach((l,h)=>{r[h]=this.createConsumerObjectAndWaitForTrack(G(V({},l),{producerId:h}))});const c=a;s&&(yield n(s));const d=[];return yield Promise.all(Object.entries(r).map(([l,h])=>h.then(m=>d.push(m)).catch(()=>{p.error(`Failed consumer creation task, producer: ${l}`,{error:{message:"This should not happen"},transport:{serverId:this.serverId}})}))),{consumers:d,failedProducers:c}}),"consumer")})}static parseHeaderExtensionMappings(t,e=[]){const n=ho(t.sdp),r={},i=e.map(s=>s.transceiver.mid);return n.media.forEach(s=>{i.includes(s.mid.toString())&&(r[s.mid]=s.ext)}),r}static setHeaderExtensionMappings(t,e,n){const r=ho(t.sdp),i=e.map(s=>s.transceiver.mid);return r.media=r.media.map(s=>{if(i.includes(s.mid.toString())){const a=V({},s);return a.ext=n[s.mid],a}return s}),G(V({},t),{sdp:ku(r)})}closeConsumers(t,e){return u(this,null,function*(){const n=ch.parseHeaderExtensionMappings(this.handler.pc.remoteDescription,t);t.forEach(s=>s.close(void 0,!0));let r=yield this.handler.pc.createOffer();r=ch.setHeaderExtensionMappings(r,t,n),yield this.setLocalDescription(r);const i=yield e(t,r);yield this.setRemoteDescription(i)})}setRemoteOffer(t){return u(this,null,function*(){yield this.setRemoteDescription(t);const e=yield this.handler.pc.createAnswer(),n=ho(e.sdp);return n.media=n.media.map(r=>{if(r.type==="audio"){const i=V({},r),s=i.fmtp.find(a=>a.payload===111);return s&&(s.config+=";stereo=1;sprop-stereo=1"),i.rtcpFb||(i.rtcpFb=[]),i.rtcpFb.some(a=>a.type==="nack")||i.rtcpFb.push({payload:parseInt(i.payloads,10),type:"nack"}),i}return r}),e.sdp=ku(n),yield this.setLocalDescription(e),e})}_ontrack(t){const{track:e,transceiver:n,streams:r}=t;p.info(`track event received [trackId: ${e.id}]`);let i;o(this,Za)===rt.HIVE?i=`${r[0].id}:${e.kind}`:i=`${n.mid}:${e.kind}`,e.addEventListener("ended",()=>{p.info(`rtc consumer track ended [trackId: ${e.id}]`),this.unknownTracksMap.delete(i)});const s=this.consumerTrackEvents.get(i);s?(s(e,n),this.consumerTrackEvents.delete(i)):(p.warn(`track event handler not found ${i}`),this.unknownTracksMap.set(i,t))}sendErrorOverDC(t,e,n){const r=this.getDatachannel(t);if(!r)throw new Error("datachannel not found",{cause:{code:"DC_NOT_FOUND",values:{label:t}}});r.respond(e,n,!0)}sendResponseOverDC(t,e,n){const r=this.getDatachannel(t);if(!r)throw new Error("datachannel not found",{cause:{code:"DC_NOT_FOUND",values:{label:t}}});r.respond(e,n)}createConsumerObjectAndWaitForTrack(t){return u(this,null,function*(){const{consumerId:e,producerId:n,producingPeerId:r,producingTransportId:i,streamId:s,paused:a,screenShare:c,appData:d,kind:l,mimeType:h}=t,m=`${s}:${l}`,y=G(V({},t),{name:"consumer creation task error",message:"consumer creation failed"});return new Promise((E,b)=>u(this,null,function*(){const O=setTimeout(()=>{this.consumerTrackEvents.delete(m),y.isTimedout=!0,b(y)},5e3),M=(x,J)=>{try{if(x.readyState==="ended")clearTimeout(O),b(y);else{const I=x;I.enabled=!0,this.handler.midTransceiverMap.set(J.mid,J);const X=new MN({id:e,localId:J.mid,transceiver:J,track:I,paused:a,producerId:n,producingPeerId:r,producingTransportId:i,handler:this.handler,appData:G(V({},d),{screenShare:c,peerId:r}),rtpReceiver:J.receiver,mimeType:h});this.consumers.set(e,X),X.once("close",()=>{this.consumers.delete(X.id),this.handler.midTransceiverMap.delete(J.mid)}),p.info("consumer created for ",{consumer:{id:e,kind:l,appData:{screenShare:c},peerId:r,producerId:n}}),this.observer.emit("newconsumer",X),clearTimeout(O),E(X)}}catch(I){p.warn("error while creating consumer:",I),clearTimeout(O),b(y)}},F=this.unknownTracksMap.get(m);F?(this.unknownTracksMap.delete(m),M(F.track,F.transceiver)):this.consumerTrackEvents.set(m,M)}))})}setRemoteDescription(t){return u(this,null,function*(){yield this.handler.pc.setRemoteDescription(t)})}setLocalDescription(t){return u(this,null,function*(){p.debug(`${this.direction}() {transportId: ${this.serverId}} | calling pc.setLocalDescription() [offer:${JSON.stringify(t)}]`),yield this.handler.pc.setLocalDescription(t)})}retryFailedConsumerCreationTasks(t){return u(this,null,function*(){return ON(t.map(e=>u(this,null,function*(){return yp(n=>u(this,null,function*(){return n>0&&p.warn(`retrying failed consumer creation task: ${JSON.stringify(e)}`),this.createConsumerObjectAndWaitForTrack(V({},e))}))})))})}sendDataChannelMessage(t,e){return u(this,null,function*(){const n=this.getDatachannel(t);if(!n)throw bN("DC_NOT_READY",`${t} datachannel not ready`);const r=(yield n.request(e)).payload;return p.info(`sendDataChannelMessage::response ${JSON.stringify(r)}`),r})}};let NN=ch;Za=new WeakMap;function LN(){if(typeof navigator=="object"&&navigator.product==="ReactNative"){if(typeof RTCPeerConnection=="undefined"){p.warn("Device::this._detectDevice() | unsupported ReactNative without RTCPeerConnection");return}return p.debug("Device::this._detectDevice() | ReactNative handler chosen"),"Chrome74"}if(typeof navigator=="object"&&typeof navigator.userAgent=="string"){const t=navigator.userAgent,e=of.getParser(t),n=e.getEngine();if(e.satisfies({chrome:">=74",chromium:">=74","microsoft edge":">=88"}))return"Chrome74";if(e.satisfies({chrome:">=55",chromium:">=55"}))return;if(e.satisfies({firefox:">=110"}))return"Firefox110";if(e.satisfies({firefox:">=60"}))return"Firefox60";if(e.satisfies({ios:{OS:">=14.3",firefox:">=30.0"}})||e.satisfies({safari:">=12.0"})&&typeof RTCRtpTransceiver!="undefined"&&RTCRtpTransceiver.prototype.hasOwnProperty("currentDirection"))return"Safari12";if(e.satisfies({safari:">=11"})||e.satisfies({"microsoft edge":">=11"})&&e.satisfies({"microsoft edge":"<=18"}))return;if(n.name&&n.name.toLowerCase()==="blink"){const r=t.match(/(?:(?:Chrome|Chromium))[ /](\w+)/i);return r?Number(r[1])>=74?"Chrome74":void 0:"Chrome74"}if(n.name.toLowerCase()==="webkit"&&e.getOS().name.toLowerCase()==="ios")return typeof RTCRtpTransceiver!="undefined"&&RTCRtpTransceiver.prototype.hasOwnProperty("currentDirection")?"Safari12":void 0;p.warn("Device::this._detectDevice() | browser not supported");return}p.warn("Device::this._detectDevice() | unknown device")}var Jc;class xN{constructor(e,{handlerName:n,handlerFactory:r}={}){if(g(this,"handlerFactory"),f(this,Jc,void 0),p.debug("constructor()"),v(this,Jc,e),n&&r)throw new TypeError("just one of handlerName or handlerInterface can be given");if(r)this.handlerFactory=r;else{if(n)p.debug(`Device::constructor() | handler given: ${n}`);else if(n=LN(),n)p.debug(`Device::constructor() | detected handler: ${n}`);else throw new Error("device not supported");switch(n){case"Chrome74":this.handlerFactory=Ep.createFactory();break;case"Safari12":this.handlerFactory=Tp.createFactory();break;case"Firefox60":this.handlerFactory=xd.createFactory({supportsSendEncodings:!1});break;case"Firefox110":this.handlerFactory=xd.createFactory({supportsSendEncodings:!0});break;default:throw new TypeError(`unknown handlerName "${n}"`)}}}createTransport(e){const n=Us();return new NN(o(this,Jc),G(V({id:n},e),{handlerFactory:this.handlerFactory}))}}Jc=new WeakMap;const VN=2e3;var Mr,vo,Lt,xt,Ms,yo,eo,to,ls,bi,no,So,$c,Kc,dh,lh,Ly,uh,xy,hh,Vy,ph,Uy,mh,Gg,zc,lu,Yc,uu;class UN extends mt.EventEmitter{constructor(e,n,r){switch(super(),f(this,So),f(this,Kc),f(this,lh),f(this,uh),f(this,hh),f(this,ph),f(this,mh),f(this,zc),f(this,Yc),f(this,Mr,void 0),f(this,vo,void 0),f(this,Lt,void 0),f(this,xt,void 0),f(this,Ms,void 0),f(this,yo,void 0),f(this,eo,void 0),f(this,to,{transportFailureCount:{send:0,recv:0},lastConnectionTime:0}),f(this,ls,void 0),f(this,bi,"all"),f(this,no,void 0),v(this,Mr,e),v(this,Ms,n),v(this,no,r),v(this,vo,new xN(r)),v(this,yo,new CN(n,r)),r){case rt.CF:{v(this,eo,Sn);break}case rt.HIVE:default:{v(this,eo,rn);break}}o(this,So,$c).mediaState={send:{state:Br.NEW,reconnected:!1},recv:{state:Br.NEW,reconnected:!1}},Z.hasFeature(ie.FORCE_RELAY)&&v(this,bi,"relay"),H(this,Kc,dh).call(this)}get socket(){return o(this,Ms)}get socketHandler(){return o(this,yo)}get sendTransport(){return o(this,Lt)}get recvTransport(){return o(this,xt)}get events(){return o(this,eo)}get nodeType(){return o(this,no)}createTransports(e){return u(this,null,function*(){var n,r,i,s,a,c,d,l;Z.hasFeature(ie.FORCE_RELAY)&&(p.info("ICE Transport Policy set to relay"),v(this,bi,"relay"));const h=yield dt().getICEServers().catch(y=>(p.warn(`failed to get iceservers from server: ${y.message}`),[])),m=[];if(e.send){const y=Z.hasFeature(ie.DISABLE_OPUS_DTX_CF),E=H(this,uh,xy).call(this,{iceServers:h,additionalSettings:{encodedInsertableStreams:(n=o(this,Mr).getValue("modules").e2ee)==null?void 0:n.enabled},config:{enableHighBitrate:(s=(i=(r=o(this,Mr).getValue("defaults").mediaConfiguration)==null?void 0:r.audio)==null?void 0:i.enableHighBitrate)!=null?s:!1,enableStereo:(d=(c=(a=o(this,Mr).getValue("defaults").mediaConfiguration)==null?void 0:a.audio)==null?void 0:c.enableStereo)!=null?d:!1,enableDtx:o(this,no)===rt.HIVE?!0:!!y},iceTransportPolicy:o(this,bi)});m.push(E)}if(e.recv){const y=H(this,hh,Vy).call(this,{iceServers:h,additionalSettings:{encodedInsertableStreams:(l=o(this,Mr).getValue("modules").e2ee)==null?void 0:l.enabled},iceTransportPolicy:o(this,bi)});m.push(y)}yield Promise.all(m)})}stopTransports(e){var n,r,i,s;e.send&&((n=o(this,Lt))==null||n.close(),(r=o(this,Lt))==null||r.removeAllListeners(),v(this,Lt,void 0)),e.recv&&((i=o(this,xt))==null||i.close(),(s=o(this,xt))==null||s.removeAllListeners(),v(this,xt,void 0)),H(this,Kc,dh).call(this)}stopAllTransports(){p.info("Closing all transports"),this.stopTransports({send:!0,recv:!0})}connectTransportWithRetry(e){return u(this,null,function*(){const{id:n,serverId:r,direction:i}=e;H(this,ph,Uy).call(this,e);try{const s=Z.hasFeature(ie.ENABLE_HIVE_INFINITE_RETRIES)?1/0:3;return yield yp((a,c)=>u(this,null,function*(){a>0&&p.debug(`Retrying transport connect, count: ${a}`,{transport:{id:n,serverId:r,type:i}});try{yield H(this,lh,Ly).call(this,e)}catch(d){if(d instanceof Rs){c(d);return}throw d}}),{delayTime:100,strategy:"exponential",maxRetryCount:s}),e}catch(s){throw p.error(`Failed to connect send transport after retry: ${e.id}`,{error:s,transport:{id:n,serverId:r,type:i}}),e.close(),e.removeAllListeners(),this.handleErrors("rejoin"),s}})}handleErrors(e){throw new Error("Method not implemented.")}}Mr=new WeakMap,vo=new WeakMap,Lt=new WeakMap,xt=new WeakMap,Ms=new WeakMap,yo=new WeakMap,eo=new WeakMap,to=new WeakMap,ls=new WeakMap,bi=new WeakMap,no=new WeakMap,So=new WeakSet,$c=function(){return o(this,Mr).getValue("connectionHandler")},Kc=new WeakSet,dh=function(){v(this,ls,{send:void 0,recv:void 0})},lh=new WeakSet,Ly=function(t){return u(this,null,function*(){const{id:e,serverId:n,direction:r}=t;if(p.info(`Connecting ${r} transport`,{transport:{id:e,serverId:n,type:r}}),!o(this,Ms).isConnected)throw new Rs("Socket is not connected");if(t.connectionState==="closed")throw new Rs("Transport is closed");try{yield t.connect(i=>H(this,mh,Gg).call(this,r,i)),p.info(`Connected ${r} transport`,{transport:{id:e,serverId:n,type:r}})}catch(i){throw o(this,to).transportFailureCount[r]+=1,i.message==="ice connection failed"?new Rs(i.message):i}})},uh=new WeakSet,xy=function(t){return u(this,null,function*(){var e,n;if(o(this,Lt)&&o(this,Lt).connected){p.info("Transport send is already connected",{transport:{id:(e=o(this,Lt))==null?void 0:e.id,serverId:(n=o(this,Lt))==null?void 0:n.serverId,type:"send"}});return}v(this,Lt,yield o(this,vo).createTransport(G(V({},t),{direction:"send"}))),K.configureSendTransport(o(this,Lt))})},hh=new WeakSet,Vy=function(t){return u(this,null,function*(){var e,n;if(o(this,xt)&&o(this,xt).connected){p.info("Transport recv is already connected",{transport:{id:(e=o(this,xt))==null?void 0:e.id,serverId:(n=o(this,xt))==null?void 0:n.serverId,type:"recv"}});return}v(this,xt,yield o(this,vo).createTransport(G(V({},t),{direction:"recv"}))),K.configureRecvTransport(o(this,xt))})},ph=new WeakSet,Uy=function(t){const{direction:e,id:n}=t;t.on("connectionstatechange",r=>u(this,null,function*(){H(this,Yc,uu).call(this,{state:r,direction:e}),p.info(`Transport connection state changed for ${e} transport`,{transport:{id:n,serverId:t.serverId,type:e,status:r}});const i=()=>{const s=o(this,ls)[e];s!==void 0&&(clearTimeout(s),o(this,ls)[e]=void 0)};switch(r){case"connected":i(),o(this,to).lastConnectionTime=performance.now();break;case"disconnected":o(this,ls)[e]=setTimeout(()=>u(this,null,function*(){yield H(this,zc,lu).call(this,t)}),VN);break;case"failed":if(t.closed)return;i(),yield H(this,zc,lu).call(this,t);break}})),t.on("icecandidate",r=>u(this,null,function*(){p.debug("Sending iceCandidate:",{iceCandidate:r})})),t.on("datachannel:events",(r,i)=>u(this,null,function*(){var s,a;p.debug("Got data channel message on event:",{rtcChannel:{label:r,message:i}});try{switch(i.type){case"handshake":{const c={type:"handshake",payload:{message:"pong"}};t.sendResponseOverDC(r,Ny(i),c);break}case"hub-disconnect":{p.debug(`media hub disconnected, full_reconnect: ${(s=i.payload)==null?void 0:s.full_reconnect}`),((a=i.payload)==null?void 0:a.full_reconnect)===!0&&this.handleErrors("rejoin");break}case"error":break;default:break}}catch{p.error(`Unable to handle the incoming datachannel message on channel ${r}`)}})),t.on("dc_error",()=>{t.direction==="recv"&&(p.warn("Events datachannel did not open in 5s",{country:S.location.country}),this.handleErrors("reconnectRecvTransport"))})},mh=new WeakSet,Gg=function(t,e){return u(this,null,function*(){const n=t==="recv";try{const{sdp:r,type:i}=e,s={consuming:n,description:{sdp:r,type:i,target:n?sr.SUBSCRIBER:sr.PUBLISHER},producers:[]};return o(this,yo).connectTransport(s)}catch(r){throw p.error(`Error in ${t} transport connection:`,{error:r,country:S.location.country}),r}})},zc=new WeakSet,lu=function(t){return u(this,null,function*(){t.close(),t.removeAllListeners();const{direction:e}=t;switch(Z.hasFeature(ie.HIVE_TRANSPORT_FORCE_RELAY_ON_ICE_FAILED)&&o(this,Ms).isConnected&&o(this,to).transportFailureCount[e]>2&&(p.warn(`Multiple disconnections in ${e} transport, forcing relay`),v(this,bi,"relay")),yield this.createTransports({[e]:!0}),e){case"send":{yield this.connectTransportWithRetry(o(this,Lt)),p.info("Transport reconnected",{transport:o(this,Lt)}),C.emit(R.RESET_PRODUCER_STATE);break}case"recv":{yield this.connectTransportWithRetry(o(this,xt)),p.info("Transport reconnected",{transport:o(this,xt)}),C.emit(R.UPDATE_ACTIVE,{createAllConsumers:!0});break}default:p.warn("Unknown transport direction",{transport:t})}H(this,Yc,uu).call(this,{state:Br.CONNECTED,direction:e})})},Yc=new WeakSet,uu=function(t){const{state:e,direction:n}=t;o(this,So,$c).mediaState[n]={state:e,reconnected:!0},C.emit(R.TRANSPORT_STATE_UPDATE,V({transport:n},o(this,So,$c).mediaState[n]))};var gh,Fy;class FN{constructor(e){f(this,gh),this.recvTransport=e,H(this,gh,Fy).call(this)}create(e){return u(this,null,function*(){if(!e||e&&e.length===0)throw new Error("List of producers is required");const n={type:"create_consumer",payload:{producers:e.map(({producerId:a,producingTransportId:c,kind:d,mimeType:l})=>({producerId:a,producingTransportId:c,preferredCodec:V(V({},d==="video"&&l?{video:l}:{}),d==="audio"&&l?{audio:l}:{})}))}},r=yield this.recvTransport.sendDataChannelMessage("events",n),i=new Map;e.forEach(a=>i.set(a.producerId,a));const s=new Map;return Object.entries(r).forEach(([a,c])=>{const d=i.get(c.producerId);d&&s.set(c.producerId,{consumerId:a,producingTransportId:d.producingTransportId,producingPeerId:d.producingPeerId,kind:d.kind,paused:d.pause,streamId:c.streamId,trackId:c.trackId,screenShare:d.screenShare,mimeType:d.mimeType,appData:{}})}),{consumerStates:s}})}negotiate(e,n,r){return u(this,null,function*(){try{p.debug(`Received offer over dc: ${e.sdp} for transport`);const i=yield this.recvTransport.setRemoteOffer(e),s={type:"answer",payload:{type:i.type,sdp:i.sdp}};return p.debug(`datachannel answer: ${JSON.stringify(s)}`),this.recvTransport.sendResponseOverDC(r,n,s),i}catch(i){throw p.error("datachannel:events::Error:",i),i.code!=="DC_NOT_FOUND"&&this.recvTransport.sendErrorOverDC(r,n,i),i}})}close(e){return u(this,null,function*(){if(!e.length)return{};const n=e.map(a=>a.id);p.info(`Closing consumers: ${JSON.stringify(n)}`);const r={type:"close_consumers",payload:{consumers:n}},i=yield this.recvTransport.sendDataChannelMessage("events",r),{failedConsumers:s}=i;return{failedConsumers:s}})}}gh=new WeakSet,Fy=function(){this.recvTransport.on("datachannel:events",(t,e)=>u(this,null,function*(){try{switch(e.type){case"negotiation":{const{sdp:n}=e.payload,r={sdp:n,type:"offer"};this.negotiate(r,Ny(e),t);break}default:break}}catch{p.error(`Unable to handle the incoming datachannel message on channel ${t}`)}}))};class BN{constructor(e,n,r,i){this.events=e,this.recvTransport=n,this.socket=r,this.socketHandler=i}create(e){return u(this,null,function*(){if(!e||e&&e.length===0)throw new Error("List of producers is required");const n=new Map,r=[];e.forEach(d=>{const{producingPeerId:l,producerId:h,producingTransportId:m}=d;n.set(h,l),r.push({producingPeerId:l,producerId:h,producingTransportId:m})});const i=yield this.socketHandler.consume({requests:r,consumingTransportId:this.recvTransport.serverId}),s=new Map;e.forEach(d=>s.set(d.producerId,d));const a=new Map,c=[];return Object.entries(i.consumerStateMap).forEach(([d,l])=>{const h=s.get(d);if(!h)return;if(l.errorCode){p.warn(`Consumer request failed for producer ${d}`,{error:{message:l.errorCode}}),c.push(h);return}let m={};try{m=JSON.parse(l.producerState.appData)}catch{}a.set(d,{consumerId:l.consumerId,producingTransportId:h.producingTransportId,producingPeerId:h.producingPeerId,kind:h.kind,paused:h.pause,streamId:l.producerTrack.streamId,trackId:l.producerTrack.trackId,screenShare:h.screenShare,mimeType:h.mimeType,appData:m})}),{consumerStates:a,sessionDescription:i.sessionDescription,failedProducers:c}})}negotiate(e){return u(this,null,function*(){p.debug(`setting remote offer: ${JSON.stringify(e)} on recvTransport`,{transport:this.recvTransport});const n=yield this.recvTransport.setRemoteOffer(e),r={transportId:this.recvTransport.serverId,description:{sdp:n.sdp,type:n.type,target:sr.SUBSCRIBER}};return p.debug(`sending renegotiate request: ${JSON.stringify(r)} on recvTransport`,{transport:this.recvTransport}),yield this.socket.sendMessagePromise(this.events.renegotiateSessionDescription,pP.toBinary(r)),p.info("renegotiation done",{transport:this.recvTransport}),n})}close(e){return u(this,null,function*(){if(!e.length)return{};const n=(r,i)=>u(this,null,function*(){const s=r.map(l=>l.localId);p.info(`Closing consumers: ${JSON.stringify(s)}`);const a={description:{sdp:i.sdp,type:i.type,target:sr.SUBSCRIBER},consumerIds:s,consumingTransportId:this.recvTransport.serverId},c=yield this.socketHandler.closeConsumer(a),d=xC.fromBinary(c).description;return{sdp:d.sdp,type:d.type}});return this.recvTransport.awaitQueue.push(()=>this.recvTransport.closeConsumers(e,n),"close_consumer"),{}})}}class kp{constructor(e){this.socketHandler=e}static getMSIDFromSDP(e,n){return ho(e).media.filter(r=>n==="video"?r.type==="video":r.type==="audio").at(-1).msid}create(e){return u(this,arguments,function*({offer:n,kind:r,paused:i,appData:s,codecOptions:a,producingTransportId:c}){var d,l;const h=kp.getMSIDFromSDP(n.sdp,r),m={description:{sdp:n.sdp,type:n.type,target:sr.PUBLISHER},paused:i,kind:r,msid:h,appData:JSON.stringify(s),screenShare:(d=s.screenShare)!=null?d:!1,mimeType:`${r}/${(l=a[0])==null?void 0:l.name}`,producingTransportId:c},{answer:y,producerId:E}=yield this.socketHandler.produce(m);return{answer:y,producerId:E}})}}const WN=3;var Eo,ws,Ii,To,Qc,Qn,Vd,Or,ko,fh,By,Ud,vh,yh,Wy,Sh,jy,Eh,Hy,Th,qy,Xc,hu,kh,Jg;class jN extends UN{constructor(e,n,r){super(e,n,r),f(this,fh),f(this,Ud),f(this,yh),f(this,Sh),f(this,Eh),f(this,Th),f(this,Xc),f(this,kh),f(this,Eo,void 0),f(this,ws,void 0),f(this,Ii,void 0),f(this,To,void 0),f(this,Qc,void 0),f(this,Qn,void 0),f(this,Vd,{producerCreationFailureCount:0,consumerCreationFailureCount:0,producerNotReadyFailureCount:0}),f(this,Or,[]),f(this,ko,void 0),v(this,Eo,e),o(this,fh,By).mediaState={send:{state:Br.NEW,reconnected:!1},recv:{state:Br.NEW,reconnected:!1}},this.reset()}get socketHandler(){return super.socketHandler}get producers(){return o(this,ws)}get consumers(){return o(this,Ii)}get producerIdToConsumerIdMap(){return o(this,To)}reset(){v(this,ws,new Map),v(this,Ii,new Map),v(this,To,new Map)}setupTransports(e){return u(this,null,function*(){yield this.createTransports(e);let n,r;e.send&&(n=H(this,yh,Wy).call(this)),e.recv&&(r=H(this,Sh,jy).call(this)),yield Promise.all([n,r])})}createProducer(e,n){return u(this,null,function*(){var r;if(!this.sendTransport||this.sendTransport.closed)throw new Error("Send transport is closed");try{const i=yield this.sendTransport.produce(e,H(this,Eh,Hy).bind(this));return(r=e.appData)!=null&&r.e2ee&&C.emit(R.E2EE_ACTIVE_PRODUCER,i),H(this,Th,qy).call(this,i,n),i}catch(i){throw p.error("Failed to create producer",{error:i}),o(this,Vd).producerCreationFailureCount+=1,i}})}closeProducer(e,n){return u(this,null,function*(){var r;const i=this.producers.get(e);if(!i){p.warn(`Producer with ID ${e} was not found`);return}n!=null&&n.stopTrack&&i.track.stop();try{yield this.sendTransport.closeProducer(i),(r=o(this,Eo).getValue("modules").e2ee)!=null&&r.enabled&&C.emit(R.E2EE_INACTIVE_PRODUCER,i)}catch(s){p.error("Failed to close producer on server",{error:s,producer:i})}})}closeAllProducers(){return Promise.all(Array.from(o(this,ws).entries()).map(([,e])=>e.close()))}createConsumer(e){return this.createConsumers([e])}createConsumers(e){return u(this,null,function*(){o(this,ko)||clearTimeout(o(this,ko)),v(this,Or,o(this,Or).concat(e)),yield H(this,Ud,vh).call(this)})}closeConsumer(e){return this.closeConsumers([e])}closeConsumers(e){return u(this,null,function*(){if(!o(this,Qn))return;const n=e.map(i=>this.consumers.get(i)).filter(i=>i!==void 0);if(n.length===0)return;const{failedConsumers:r}=yield o(this,Qn).close(n);r!=null&&r.length&&p.warn("Failed to close some consumers",{consumerIds:r})})}closeAllConsumers(){return this.closeConsumers(Array.from(o(this,Ii).keys()))}switchConsumersToLayer(e,n){return u(this,null,function*(){const r=this.recvTransport.getDatachannel("events");if(!r){p.warn("events datachannel not found");return}const i={type:"switch_consumer_layer",payload:{consumerIds:e,layer:n}};yield r.request(i),p.info(`Consumers switched layers to ${n}`,{consumerIds:e})})}}Eo=new WeakMap,ws=new WeakMap,Ii=new WeakMap,To=new WeakMap,Qc=new WeakMap,Qn=new WeakMap,Vd=new WeakMap,Or=new WeakMap,ko=new WeakMap,fh=new WeakSet,By=function(){return o(this,Eo).getValue("connectionHandler")},Ud=new WeakSet,vh=function(){return u(this,null,function*(){if(!this.recvTransport||this.recvTransport.closed)throw new Error("Recv transport is closed");const t=500,e=o(this,Or).splice(0,o(this,Or).length);try{const n=e.filter(({producerId:s})=>!this.producers.get(s)),{consumers:r,failedProducers:i}=yield this.recvTransport.consume(n,H(this,Xc,hu).bind(this),o(this,Qn).negotiate.bind(o(this,Qn)));r.forEach(H(this,kh,Jg).bind(this)),i!=null&&i.length&&(p.error("Failed to create consumers for producers",{producers:i}),v(this,Or,o(this,Or).concat(i)),v(this,ko,setTimeout(H(this,Ud,vh).bind(this),t)))}catch{}})},yh=new WeakSet,Wy=function(){return u(this,null,function*(){yield this.connectTransportWithRetry(this.sendTransport),v(this,Qc,new kp(this.socketHandler))})},Sh=new WeakSet,jy=function(){return u(this,null,function*(){switch(this.recvTransport.on("connect",()=>{o(this,To).clear()}),yield this.connectTransportWithRetry(this.recvTransport),this.nodeType){case rt.CF:{v(this,Qn,new BN(this.events,this.recvTransport,this.socket,this.socketHandler));break}case rt.HIVE:default:v(this,Qn,new FN(this.recvTransport))}})},Eh=new WeakSet,Hy=function(t){return o(this,Qc).create(t)},Th=new WeakSet,qy=function(t,e){t.on("close",(n,r)=>u(this,[n,r],function*({offer:i,reason:s},a){p.info("producer::closing",{debuggingHint:s,producer:G(V({},t),{status:"closing"})});const c={producerId:t.id,description:{sdp:i.sdp,type:i.type,target:sr.PUBLISHER}};try{const d=yield this.socketHandler.closeProducer(c),l={sdp:d==null?void 0:d.sdp,type:d==null?void 0:d.type};p.info("producer::closed",{producer:G(V({},t),{status:"closed"})}),a({answer:l})}catch(d){p.error("producer close error",d)}this.producers.delete(t.id),e()})),t.on("trackended",()=>{p.info("producer::trackended",{producer:G(V({},t),{status:"UNKNOWN"})})}),o(this,ws).set(t.id,t)},Xc=new WeakSet,hu=function(t,e=0){return u(this,null,function*(){try{return yield this.recvTransport.canConsume(),yield o(this,Qn).create(t)}catch(n){if(n instanceof wN&&(o(this,Vd).consumerCreationFailureCount+=1),e<=WN)return p.error(`Error in consume request attempt:${e}`,{error:n}),H(this,Xc,hu).call(this,t,e+1);throw p.error("Error in consume request",{error:n}),n}})},kh=new WeakSet,Jg=function(t){t.on("close",e=>u(this,null,function*(){p.debug("consumer closed",{consumer:{closureReason:e,id:t.id,kind:t.kind,appData:t.appData}}),o(this,Ii).delete(t.id),C.emit(R.CONSUMER_CLOSED,{id:t.id})})),o(this,Ii).set(t.id,t),this.producerIdToConsumerIdMap.set(t.producerId,t.id),C.emit(R.NEW_CONSUMER,{id:t.id,appData:t.appData,peerId:t.peerId})};var Zc,ed,td,ro,bo,wo,Fd,Bd,_s,Jt,Ln,An,di,li,Ar,Wd,bh,Gy,wh,Jy,_h,$y,Ih,Ky;const Ph=class{constructor({initialEnergyThreshold:t=.015,zeroCrossingThreshold:e=20,minVoiceDuration:n=3,hangoverFrames:r=5,noiseAdaptationRate:i=.95,voiceAdaptationRate:s=.99,minEnergyThreshold:a=.005,maxEnergyThreshold:c=.2,energyRatioThreshold:d=1.5,noiseHistorySize:l=50}={}){f(this,bh),f(this,wh),f(this,Zc,void 0),f(this,ed,void 0),f(this,td,void 0),f(this,ro,void 0),f(this,bo,void 0),f(this,wo,void 0),f(this,Fd,void 0),f(this,Bd,void 0),f(this,_s,void 0),f(this,Jt,void 0),f(this,Ln,void 0),f(this,An,!1),f(this,di,0),f(this,li,0),f(this,Ar,[]),f(this,Wd,void 0),v(this,ro,t),v(this,Jt,t),v(this,Zc,e),v(this,ed,n),v(this,td,r),v(this,bo,i),v(this,wo,s),v(this,Fd,a),v(this,Bd,c),v(this,_s,d),v(this,Wd,l),v(this,Ln,t/2)}get voiceDetected(){return o(this,An)}processAudioChunk(t){var e,n;const r=H(e=Ph,_h,$y).call(e,t),i=H(n=Ph,Ih,Ky).call(n,t);return H(this,bh,Gy).call(this,r),r/o(this,Ln)>o(this,_s)&&r>o(this,Jt)&&i>o(this,Zc)?(v(this,di,o(this,di)+1),v(this,li,o(this,td)),o(this,di)>=o(this,ed)&&v(this,An,!0)):(v(this,di,0),o(this,li)>0?v(this,li,o(this,li)-1):o(this,An)&&v(this,An,!1),o(this,An)||H(this,wh,Jy).call(this,r)),o(this,An)}reset(){v(this,An,!1),v(this,di,0),v(this,li,0),v(this,Jt,o(this,ro)),v(this,Ln,o(this,ro)/2),v(this,Ar,[])}getThresholdInfo(){return{currentEnergyThreshold:o(this,Jt),backgroundNoiseEnergy:o(this,Ln),energyRatioThreshold:o(this,_s)}}};let Ch=Ph;Zc=new WeakMap,ed=new WeakMap,td=new WeakMap,ro=new WeakMap,bo=new WeakMap,wo=new WeakMap,Fd=new WeakMap,Bd=new WeakMap,_s=new WeakMap,Jt=new WeakMap,Ln=new WeakMap,An=new WeakMap,di=new WeakMap,li=new WeakMap,Ar=new WeakMap,Wd=new WeakMap,bh=new WeakSet,Gy=function(t){o(this,An)?v(this,Jt,o(this,wo)*o(this,Jt)+(1-o(this,wo))*t):v(this,Jt,o(this,bo)*o(this,Jt)+(1-o(this,bo))*(o(this,Ln)*o(this,_s))),v(this,Jt,Math.max(o(this,Fd),Math.min(o(this,Bd),o(this,Jt))))},wh=new WeakSet,Jy=function(t){if(t<o(this,Jt)*1.2)if(o(this,Ar).push(t),o(this,Ar).length>o(this,Wd)&&o(this,Ar).shift(),o(this,Ar).length>=10){const e=[...o(this,Ar)].sort((r,i)=>r-i),n=Math.floor(e.length/2);v(this,Ln,e[n])}else v(this,Ln,.95*o(this,Ln)+.05*t)},_h=new WeakSet,$y=function(t){return Math.sqrt(t.map(e=>e*e).reduce((e,n)=>e+n)/t.length)},Ih=new WeakSet,Ky=function(t){let e=0;for(let n=1;n<t.length;n+=1)(t[n]>=0&&t[n-1]<0||t[n]<0&&t[n-1]>=0)&&(e+=1);return e},f(Ch,_h),f(Ch,Ih);const HN=60,qN=400;var ui,hi,As,io,Pi,so,_o,jd,pi,us,Io,Rh,zy,nd,Mh,Ah,Yy,pu,$g,mu,Kg;const Po=class{constructor(t){f(this,Rh),f(this,Ah),f(this,ui,void 0),f(this,hi,void 0),f(this,As,void 0),f(this,io,void 0),f(this,Pi,void 0),f(this,so,void 0),f(this,_o,void 0),f(this,jd,void 0),f(this,pi,void 0),f(this,us,void 0),f(this,Io,void 0),this.reportRequest=t,v(this,io,new AudioContext),v(this,Pi,o(this,io).createAnalyser()),o(this,Pi).fftSize=2048,v(this,jd,new Ch)}set producerId(t){v(this,As,t)}set audioTrack(t){v(this,so,t);const e=new MediaStream;e.addTrack(o(this,so)),o(this,io).createMediaStreamSource(e).connect(o(this,Pi))}start(){o(this,ui)&&Ts(o(this,ui)),v(this,ui,vd(()=>u(this,null,function*(){var t;if(!o(this,so)||!o(this,As))return;const{energy:e}=H(this,Rh,zy).call(this),n=H(t=Po,nd,Mh).call(t,e);let r=.9;o(this,Io)!==n&&o(this,Io)?r=.9:n?r=.3:r=.5,v(this,_o,(o(this,_o)||0)*(1-r)+e*r)}),HN)),o(this,hi)&&Ts(o(this,hi)),v(this,hi,vd(H(this,Ah,Yy).bind(this),qN))}stop(){o(this,ui)&&Ts(o(this,ui)),o(this,hi)&&Ts(o(this,hi))}};let rd=Po;ui=new WeakMap,hi=new WeakMap,As=new WeakMap,io=new WeakMap,Pi=new WeakMap,so=new WeakMap,_o=new WeakMap,jd=new WeakMap,pi=new WeakMap,us=new WeakMap,Io=new WeakMap,Rh=new WeakSet,zy=function(){var t,e;const n=new Float32Array(o(this,Pi).frequencyBinCount);o(this,Pi).getFloatTimeDomainData(n);const r=o(this,jd).processAudioChunk(n),i=H(t=Po,pu,$g).call(t,n),s=H(e=Po,mu,Kg).call(e,i);return(!o(this,pi)||s<o(this,pi))&&v(this,pi,s),(!o(this,us)||s>o(this,us))&&v(this,us,s),{energy:(s-o(this,pi))/(o(this,us)-o(this,pi))*10||0,isVoice:r}},nd=new WeakSet,Mh=function(t){return t<5},Ah=new WeakSet,Yy=function(t=o(this,_o)){var e;if(!o(this,As)||!t)return;const n={producerId:o(this,As),energy:Math.round(t),silent:H(e=Po,nd,Mh).call(e,t)};v(this,Io,n.silent),this.reportRequest(n)},pu=new WeakSet,$g=function(t){return Math.sqrt(t.reduce((e,n)=>e+n*n,0)/t.length)},mu=new WeakSet,Kg=function(t){const e=Math.log10(t);return Math.round(e)},f(rd,nd),f(rd,pu),f(rd,mu);const GN=()=>{const t=new window.AudioContext,e=t.createOscillator();e.type="triangle",e.frequency.setValueAtTime(20,t.currentTime);const n=t.createGain();n.gain.setValueAtTime(0,t.currentTime),e.connect(n);const r=t.createMediaStreamDestination();return n.connect(r),e.start(),r.stream.getAudioTracks()[0]},JN=()=>{var t,e;const n=new MediaStream().getVideoTracks()[0],r=document.createElement("canvas");r.height=(t=n==null?void 0:n.getSettings().height)!=null?t:720,r.width=(e=n==null?void 0:n.getSettings().width)!=null?e:1280;const i=r.getContext("2d");return i.fillStyle="black",i.fillRect(0,0,r.width,r.height),setInterval(()=>{i.fillStyle="black",i.fillRect(0,0,r.width,r.height)},1e3),r.captureStream().getVideoTracks()[0]};var $N=Object.defineProperty,KN=Object.getOwnPropertyDescriptor,he=(t,e,n,r)=>{for(var i=r>1?void 0:r?KN(e,n):e,s=t.length-1,a;s>=0;s--)(a=t[s])&&(i=(r?a(e,n,i):a(i))||i);return r&&i&&$N(e,n,i),i};const Pn=["video/VP9","video/VP8"];var id,sd,bt,$,ao,mi,Nt,hs,ps,gi,ad,_r,oo,ms,gs,Gt,tn,fi,fs,ht,wt,vs,co,Dh,Qy,Oh,Xy;class ue{constructor(e,n,r){f(this,fi),f(this,ht),f(this,vs),f(this,Dh),f(this,Oh),g(this,"context"),g(this,"authToken"),g(this,"e2ee"),f(this,id,void 0),f(this,sd,void 0),f(this,bt,void 0),f(this,$,void 0),f(this,ao,void 0),f(this,mi,void 0),f(this,Nt,void 0),f(this,hs,void 0),f(this,ps,void 0),f(this,gi,void 0),f(this,ad,void 0),f(this,_r,void 0),g(this,"maxPreferredStreams"),f(this,oo,void 0),f(this,ms,void 0),f(this,gs,void 0),f(this,Gt,void 0),f(this,tn,void 0),g(this,"partialJoinRoomPromise");var i,s;this.context=e;const{socket:a}=r;this.mediaJoined=!1,v(this,ms,new Map([["video/VP9",new Set],["video/VP8",new Set]])),v(this,gs,new Map([["video/VP9",new Set],["video/VP8",new Set]])),v(this,mi,n),v(this,bt,a),v(this,hs,!1),v(this,$,new jN(e,a,n)),v(this,Nt,o(this,$).events),this.maxPreferredStreams=6,v(this,_r,new Set),v(this,Gt,new Map),v(this,ps,!1),v(this,gi,new Ld),n===rt.CF&&v(this,tn,new rd(o(this,$).socketHandler.audioActivity.bind(o(this,$).socketHandler))),this.e2ee=(s=(i=e.getValue("modules").e2ee)==null?void 0:i.enabled)!=null?s:!1,this.handleSocketEvents(),this.handleCallstatsEvents(),v(this,ad,Pd(()=>u(this,null,function*(){if(!o(this,fi,fs).mediaJoinAttempted)return;const{roomJoined:c}=yield this.joinRoom(o(this,sd),o(this,id),{},!0,!0);c&&(C.emit(R.RESET_PRODUCER_STATE),C.emit(R.ROOM_NODE_RECONNECTED))}),5e3,{leading:!0,maxWait:1e3}))}get peerId(){return this.context.getValue("peerId")}get mediaJoined(){return o(this,fi,fs).mediaJoined}set mediaJoined(e){o(this,fi,fs).mediaJoined=e}reset(e=!0){o(this,$).closeAllProducers(),o(this,$).closeAllConsumers(),o(this,_r).clear(),e&&(this.partialJoinRoomPromise=void 0,o(this,gi).stop(),o(this,$).stopAllTransports(),o(this,$).reset(),v(this,gi,new Ld))}joinRoom(e,n){return u(this,arguments,function*(r,i,s={},a=!1,c=!1){o(this,fi,fs).mediaJoinAttempted=!0,v(this,hs,!0),this.reset(a);const d=dt().ipInfo;if(d!=null&&d.loc&&!o(this,oo)){const h=d.loc.split(",");v(this,oo,{latitude:parseFloat(h[0]),longitude:parseFloat(h[1])})}let l;try{return l=yield o(this,gi).push(()=>this._joinRoom(r,i,s,c,o(this,oo)),"joinRoom"),l}catch{l={roomJoined:!1}}return l.roomJoined||C.emit(R.ROOM_NODE_FAILED),l})}_partialJoinRoom(e,n,r=!1,i=void 0){return u(this,null,function*(){var s;const{ipInfo:a}=dt();let c=i;if(a!=null&&a.loc&&!i){const[h,m]=a.loc.split(",").map(parseFloat);c={latitude:h,longitude:m}}const d=(s=Z.getValue(ie.FORCE_VIDEO_CODEC))==null?void 0:s.toString(),l=PN(d);v(this,ao,l),this.maxPreferredStreams=this.context.getValue("maxPreferredStreams"),yield yp((h,m)=>u(this,null,function*(){if(!o(this,bt).isConnected){m(new Error("socket is not connected"));return}h>0&&p.warn(`retrying sending join room request, count: ${h}`);try{yield o(this,$).socketHandler.joinRoom(n,e,l,r,c)}catch(y){throw p.error("failed to send join room request, error:",{error:y}),y}}),{delayTime:1e3,strategy:"exponential",maxRetryCount:Z.hasFeature(ie.ENABLE_HIVE_INFINITE_RETRIES)?1/0:3}),yield o(this,$).setupTransports({send:!0,recv:!0}),o(this,mi)!==rt.HIVE&&Z.hasFeature(ie.PRECREATE_PRODUCERS)&&(this.shareWebcam(JN()),this.shareMic(GN()))})}partialJoinRoom(e,n,r=!1,i=void 0){return u(this,null,function*(){return this.partialJoinRoomPromise=o(this,gi).push(()=>this._partialJoinRoom(e,n,r,i)),this.partialJoinRoomPromise})}_joinRoom(e,n){return u(this,arguments,function*(r,i,s={},a=!1,c=null){v(this,sd,r);try{this.partialJoinRoomPromise?yield this.partialJoinRoomPromise:yield this._partialJoinRoom(r,i,a,c)}catch(d){p.error("error in partial join room",{error:d})}finally{this.partialJoinRoomPromise=void 0}try{return navigator.product!=="ReactNative"&&setTimeout(()=>u(this,null,function*(){const d={userId:this.context.getValue("userId"),peerId:this.peerId,roomUUID:i,roomViewType:"groupCall",deviceInfo:G(V({},Ce.getDeviceInfo()),{userAgent:navigator.userAgent,memory:navigator.deviceMemory,cpus:navigator.hardwareConcurrency}),sdkName:this.context.getValue("sdkName"),sdkVersion:this.context.getValue("sdkVersion"),metaData:{},permissions:{}};K.roomJoined(d)})),{roomJoined:yield this.completeJoinRoom()}}catch(d){return p.error("error on sending join room request",{error:d}),{roomJoined:!1}}})}completeJoinRoom(){return u(this,null,function*(){try{this.mediaJoined=!0;const{maxPreferredStreams:e,roomState:n}=yield o(this,$).socketHandler.notifySelfJoinComplete();return v(this,id,n.roomUuid),v(this,ps,!0),v(this,hs,!1),this.maxPreferredStreams=e!=null?e:6,!0}catch(e){return p.error("error on completing join room:",{error:e}),this.mediaJoined=!1,!1}})}leaveRoom(){return u(this,null,function*(){o(this,$).stopAllTransports(),v(this,ps,!1),o(this,fi,fs).mediaJoinAttempted=!1;const e={closeRoom:!1};o(this,bt).sendMessagePromise(o(this,Nt).leaveRoom,VP.toBinary(e)).then(n=>{var r;(r=kC.fromBinary(n.payload))!=null&&r.closed||p.warn("weird state on peer closed and should not happen")}).catch(n=>{p.error("error on sending leave room request",{error:n})}),K.callEnded(),S.destruct()})}getConsumers(){return o(this,$).consumers}activatePeers(e){return u(this,null,function*(){return this.createConsumers(e)})}deactivatePeers(e,n="default"){return u(this,null,function*(){const r=new Set;e.forEach(s=>{s.screenShare&&s.kind==="video"&&r.add(s.producingPeerId)});const i=n==="default"?e.filter(s=>!r.has(s.producingPeerId)).filter(s=>s.kind!=="audio"):e;yield Promise.all(i.map(s=>{const a=o(this,$).producerIdToConsumerIdMap.get(s.producerId);if(!a){p.warn(`consumer not found in deactivate producers: ${s.producerId}`);return}return o(this,$).closeConsumer(a)}))})}createConsumers(e){return u(this,null,function*(){return e.length===0?Promise.resolve():o(this,$).createConsumers(e)})}closeConsumers(e){return u(this,null,function*(){if(!e.length)return;const n=e.reduce((r,i)=>{const s=o(this,$).producerIdToConsumerIdMap.get(i.producerId);return s?(r.push(s),r):(p.warn(`consumer not found in deactivate producers: ${i.producerId}`),r)},[]);yield o(this,$).closeConsumers(n)})}_shareWebcam(e,n){return u(this,null,function*(){const r=n==="video/VP9"?ke.WEBCAM:ke.WEBCAM_BACKUP,i=H(this,ht,wt).call(this,r);if(i){const h=yield i;if(o(this,$).producers.has(h)){const m=o(this,$).producers.get(h);if(!m.closed&&!navigator.isReactNative)return yield m.replaceTrack({track:e}),yield this.resumeWebcam(r),e;yield this.disableWebcam(n)}return this._shareWebcam(e,n)}const s=H(this,Oh,Xy).call(this,e,n),a=Rd(this.context,"disableSimulcast"),c=o(this,mi)===rt.CF?ie.ENABLE_CF_SIMULCAST:ie.ENABLE_HIVE_SIMULCAST;!a&&Z.hasFeature(c)?(p.info(`Simulcast enabled for SFU: ${o(this,mi)}`),s.encodings=kO(e)):p.info(`Simulcast disabled for webcam producer, SFU: ${o(this,mi)}`),Z.hasFeature(ie.TRACK_HINT)&&(s.track.contentHint=Z.getValue(ie.TRACK_HINT));const d=()=>{p.info("Disabling video due to the producer closure"),o(this,Gt).delete(r)},l=o(this,$).createProducer(s,d);return H(this,vs,co).call(this,r,l.then(h=>h.id)),l.then(h=>h.track)})}shareWebcam(e){return u(this,null,function*(){if(e===void 0)return null;if(Z.hasFeature(ie.FORCE_VIDEO_CODEC)){const n=Z.getValue(ie.FORCE_VIDEO_CODEC).toString();if(n)return p.debug(`Calling _shareWebcam with forced video codec: ${n}`),this._shareWebcam(e,n)}return yield Promise.all(Pn.map(n=>{var r,i;return((i=(r=o(this,ao).sender)==null?void 0:r.video)==null?void 0:i.codecs.findIndex(s=>s.mimeType===n))>=0&&o(this,gs).get(n).size>0?(p.debug(`Calling _shareWebcam with video codec: ${n}`),this._shareWebcam(e,n)):e})),e})}shareScreen(e){return u(this,null,function*(){const{video:n,audio:r}=e;if(n===void 0)return;const i={track:n,codecOptions:[{name:"VP8"}],appData:{screenShare:!0,e2ee:this.e2ee,supportsRemoteControl:Ce.isElectron()},stopTracks:!1},s=()=>{p.info("Disabling screenShare due to the producer closure"),o(this,Gt).delete(ke.SCREENSHARE_VIDEO),o(this,Gt).delete(ke.SCREENSHARE_AUDIO)},a=o(this,$).createProducer(i,s);H(this,vs,co).call(this,ke.SCREENSHARE_VIDEO,a.then(d=>d.id));let c;if(r){const d={track:r,codecOptions:[{name:"opus"}],appData:{screenShare:!0,e2ee:this.e2ee,supportsRemoteControl:Ce.isElectron()},stopTracks:!1,zeroRtpOnPause:!0},l=()=>{};c=o(this,$).createProducer(d,l),H(this,vs,co).call(this,ke.SCREENSHARE_AUDIO,c.then(h=>h.id))}yield Promise.all([a,c||Promise.resolve()]),K.screenShareStart()})}shareMic(e){return u(this,null,function*(){try{if(e===void 0)throw new Pt("track undefined");const n=H(this,ht,wt).call(this,ke.MIC);if(n){const a=yield n;if(o(this,$).producers.has(a)){const c=o(this,$).producers.get(a);if(!c.closed&&!navigator.isReactNative){yield c.replaceTrack({track:e}),yield this.resumeMic(),o(this,tn)&&(o(this,tn).audioTrack=e,o(this,tn).producerId=a,o(this,tn).start());return}yield o(this,$).closeProducer(a,{stopTrack:!1})}yield this.shareMic(e);return}const r=H(this,Dh,Qy).call(this,e),i=()=>{o(this,Gt).delete(ke.MIC)},s=o(this,$).createProducer(r,i);H(this,vs,co).call(this,ke.MIC,s.then(a=>a.id)),yield s.then(a=>{o(this,tn)&&(o(this,tn).audioTrack=a.track,o(this,tn).producerId=a.id,o(this,tn).start())})}catch(n){throw new _(n)}})}pauseMic(){return u(this,null,function*(){const e=yield H(this,ht,wt).call(this,ke.MIC),n=o(this,$).producers.get(e);if(!n){p.error("pauseMic::could_not_find_mic_producer");return}if(n.paused){p.info("pauseMic::mic_producer_already_paused");return}n.pause();const r={producerId:n.id,pause:!0};o(this,bt).sendMessage(o(this,Nt).toggleProducer,rc.toBinary(r))})}pauseWebcam(){return u(this,null,function*(){const e=yield H(this,ht,wt).call(this,ke.WEBCAM),n=yield H(this,ht,wt).call(this,ke.WEBCAM_BACKUP),r=o(this,$).producers.get(e),i=o(this,$).producers.get(n);if(!r&&!i){p.error("pauseWebcam::could_not_find_webcam_producer");return}const s=a=>{const c={producerId:a.id,pause:!0};o(this,bt).sendMessage(o(this,Nt).toggleProducer,rc.toBinary(c))};r&&(r.pause(),s(r)),i&&(i.pause(),s(i))})}resumeMic(){return u(this,null,function*(){const e=yield H(this,ht,wt).call(this,ke.MIC),n=o(this,$).producers.get(e);if(!n){p.error("resumeMic::could_not_find_mic_producer");return}if(!n.pause){p.info("resumeMic::mic_producer_already_resumed");return}n.resume(),n.appData.e2ee&&C.emit(R.E2EE_ACTIVE_PRODUCER,n);const r={producerId:n.id,pause:!1};o(this,bt).sendMessage(o(this,Nt).toggleProducer,rc.toBinary(r))})}resumeWebcam(){return u(this,arguments,function*(e=ke.WEBCAM){const n=yield H(this,ht,wt).call(this,e),r=o(this,$).producers.get(n);if(!r){p.error("resumeWebcam::could_not_find_webcam_producer");return}if(!r.paused){p.info("resumeWebcam::webcam_producer_already_resumed");return}r.resume(),r.appData.e2ee&&C.emit(R.E2EE_ACTIVE_PRODUCER,r);const i={producerId:r.id,pause:!1};o(this,bt).sendMessage(o(this,Nt).toggleProducer,rc.toBinary(i))})}disableWebcam(e){return u(this,null,function*(){const n=e==="video/VP9"?ke.WEBCAM:ke.WEBCAM_BACKUP,r=yield H(this,ht,wt).call(this,n);r&&(yield o(this,$).closeProducer(r)),o(this,Gt).delete(n)})}disableMic(){return u(this,null,function*(){var e;const n=yield H(this,ht,wt).call(this,ke.MIC);n&&(yield o(this,$).closeProducer(n)),(e=o(this,tn))==null||e.stop(),o(this,Gt).delete(ke.MIC)})}disableScreenShare(){return u(this,null,function*(){p.info("screen_sharing_stopped"),K.screenShareStop();const e=yield H(this,ht,wt).call(this,ke.SCREENSHARE_VIDEO),n=yield H(this,ht,wt).call(this,ke.SCREENSHARE_AUDIO);e&&(yield o(this,$).closeProducer(e)),n&&(yield o(this,$).closeProducer(n)),o(this,_r).clear(),o(this,Gt).delete(ke.SCREENSHARE_VIDEO),o(this,Gt).delete(ke.SCREENSHARE_AUDIO)})}muteSelf(){return u(this,null,function*(){this.pauseMic()})}unmuteSelf(){return u(this,null,function*(){})}resetVideoProducers(e,n){return u(this,null,function*(){if(e){const r=yield H(this,ht,wt).call(this,ke.WEBCAM),i=yield H(this,ht,wt).call(this,ke.WEBCAM_BACKUP);yield o(this,$).closeProducer(r,{stopTrack:!1}),yield o(this,$).closeProducer(i,{stopTrack:!1}),this.shareWebcam(e)}if(n){const r=yield H(this,ht,wt).call(this,ke.SCREENSHARE_VIDEO);yield o(this,$).closeProducer(r,{stopTrack:!1}),this.shareScreen({video:n})}})}changeDisplayName(e,n){return u(this,null,function*(){const r={displayName:e,participantId:n!=null?n:this.peerId};if(!(yield o(this,$).socketHandler.changeDisplayName(r)))throw new Error("failed to change display name!")})}kick(e){return u(this,null,function*(){const n={participantId:e};if(!(yield o(this,$).socketHandler.kickPeer(n)))throw new Error("failed to kickout the participant!")})}kickAll(){return u(this,null,function*(){if(!(yield o(this,$).socketHandler.kickAll()))throw new Error("failed to kickout all participant!")})}muteAll(e){return u(this,null,function*(){if(!(yield o(this,$).socketHandler.hostControlForAll("audio")))throw new Error("failed to mute all participant")})}muteAllVideo(){return u(this,null,function*(){if(!(yield o(this,$).socketHandler.hostControlForAll("video")))throw new Error("failed to mute all video participant")})}disableAudio(e){return u(this,null,function*(){if(!(yield o(this,$).socketHandler.hostControlForPeer(e,"audio")))throw new Error("failed to mute given participant")})}disableVideo(e){return u(this,null,function*(){if(!(yield o(this,$).socketHandler.hostControlForPeer(e,"video")))throw new Error("failed to mute video of given participant")})}pinPeer(e){return u(this,null,function*(){const n={participantId:e!=null?e:""};try{yield o(this,bt).sendMessagePromise(o(this,Nt).globalPinPeer,$P.toBinary(n))}catch(r){p.error("Error in pinning peer:",{error:r})}})}validateScreenShare(e){return this.peerId===e.peerId&&o(this,$).producers.get(e.producerId)&&o(this,_r).add(e.consumerPeerId),o(this,_r).size}switchConsumersToLayer(e,n){return u(this,null,function*(){o(this,$).switchConsumersToLayer(e,n)})}handleSocketEvents(){return u(this,null,function*(){o(this,bt).on(o(this,Nt).peerProducerCreateBroadcast,({payload:e})=>{var n,r;if(this.mediaJoined)try{const{participantId:i,producerState:s}=eR.fromBinary(e);if(i===this.peerId)return;if(s!=null&&s.mimeType||(s.mimeType=s.kind===xn.AUDIO?"audio/opus":"video/VP8"),s.kind===xn.VIDEO&&!s.screenShare&&((r=(n=o(this,ao).receiver)==null?void 0:n.video)==null?void 0:r.codecs.findIndex(a=>a.mimeType===Pn[0]))>=0&&o(this,ms).get(Pn[0]).has(i)&&s.mimeType!==Pn[0]){p.warn(`Ignoring producer: ${s.producerId}`);return}p.info(`producer created broadcast: ${i}, producer state: ${s}`),C.emit(R.NEW_PRODUCER,{peerId:i,producer:G(V({},s),{kind:s.kind===xn.AUDIO?"audio":"video",producingPeerId:i})})}catch(i){p.error("error in peer-producer-create-broadcast",{error:i})}}),o(this,bt).on(o(this,Nt).peerProducerToggleBroadcast,({payload:e})=>{if(this.mediaJoined)try{const{participantId:n,initiatorParticipantId:r,producerState:{kind:i,pause:s,producerId:a}}=ng.fromBinary(e),c=i===xn.AUDIO?"audio":"video";if(p.info(`producer toggle broadcast: ${n}, producerId: ${a}, kind:${c}, paused:${s} payload: ${JSON.stringify(ng.fromBinary(e))}`),n===this.peerId&&r!==this.peerId&&s&&C.emit(c==="audio"?R.MUTE_SELF:R.MUTE_SELF_VIDEO),n===this.peerId)return;C.emit(R.PRODUCER_TOGGLE,{peerId:n,producerId:a,paused:s,kind:c}),Array.from(this.getConsumers().values()).filter(d=>d.producerId===a).forEach(d=>{d.paused!==s&&(p.debug(`consumer state mismatched for ${d.id}. updating consumer pause state ${d.paused} to ${s}`),s?(d.pause(),C.emit(R.CONSUMER_PAUSED,{id:d.id})):(d.resume(),C.emit(R.CONSUMER_RESUMED,{id:d.id})))})}catch(n){p.error("error in producer toggle broadcast handler",{error:n})}}),o(this,bt).on(o(this,Nt).peerLeaveBroadcast,({payload:e})=>{if(this.mediaJoined)try{const{participantId:n}=Fu.fromBinary(e);if(n===this.peerId)return;p.info(`peer left broadcast:${n}`),o(this,_r).delete(n),o(this,$).consumers.forEach(r=>{r.peerId===n&&r.close()}),C.emit(R.PEER_CLOSED,{id:n})}catch(n){p.error("error in peer left broadcast",{error:n})}}),o(this,bt).on(o(this,Nt).peerProducerCloseBroadcast,({payload:e})=>{if(this.mediaJoined)try{const{participantId:n,producerState:{producerId:r}}=rR.fromBinary(e);if(n===this.peerId)return;p.info(`producer closed broadcast:${n}`),C.emit(R.PRODUCER_CLOSED,{peerId:n,producerId:r});const i=o(this,$).producerIdToConsumerIdMap.get(r);if(!i){p.warn(`no consumer found for producer:${r}`);return}p.info(`closing consumer ${i}, producer id: ${r}`),o(this,$).closeConsumer(i).then(()=>{p.info(`closed consumer: ${i}`),o(this,$).producerIdToConsumerIdMap.delete(r),C.emit(R.CONSUMER_CLOSED,{id:i})}).catch(s=>{p.error("error closing consumer",{error:s})})}catch(n){p.error("error on producer close broadcast",{error:n})}}),o(this,bt).on(o(this,Nt).mediaRoomTerminationBroadcastResponse,()=>{!this.mediaJoined&&!o(this,hs)&&!o(this,ps)||(p.warn("media hub termination broadcast received, rejoining room"),C.emit(R.ROOM_NODE_DISCONNECTED),o(this,ad).call(this))})})}handleCallstatsEvents(){K.onConsumerScore(e=>{e.forEach((n,r)=>{const i=o(this,$).consumers.get(r);i&&C.emit(R.CONSUMER_SCORE_UPDATE,{id:r,kind:i.kind,peerId:i.peerId,score:n.score,scoreStats:n})})}),K.onProducerScore(e=>{e.forEach((n,r)=>{const i=Array.from(o(this,$).producers.values()).find(s=>s.id===r);i&&C.emit(R.PRODUCER_SCORE_UPDATE,{id:r,kind:i.kind,appData:i.appData,score:n.score,scoreStats:n})})})}handlePeerCapabilities(e,n){var r,i,s,a;for(let c=0;c<=Pn.length;c+=1){const d=Pn[c];if(((i=(r=n==null?void 0:n.receiver)==null?void 0:r.video)==null?void 0:i.codecs.findIndex(l=>l.mimeType===d))>=0||c===Pn.length-1){o(this,gs).get(d).add(e);break}}for(let c=0;c<=Pn.length;c+=1){const d=Pn[c];if(((a=(s=n==null?void 0:n.sender)==null?void 0:s.video)==null?void 0:a.codecs.findIndex(l=>l.mimeType===d))>=0||c===Pn.length-1){o(this,ms).get(d).add(e);break}}}handlePeerLeaving(e){Z.hasFeature(ie.FORCE_VIDEO_CODEC)||(o(this,ms).forEach(n=>n.delete(e)),o(this,gs).forEach((n,r)=>{n.delete(e),n.size===0&&this.disableWebcam(r)}))}}id=new WeakMap,sd=new WeakMap,bt=new WeakMap,$=new WeakMap,ao=new WeakMap,mi=new WeakMap,Nt=new WeakMap,hs=new WeakMap,ps=new WeakMap,gi=new WeakMap,ad=new WeakMap,_r=new WeakMap,oo=new WeakMap,ms=new WeakMap,gs=new WeakMap,Gt=new WeakMap,tn=new WeakMap,fi=new WeakSet,fs=function(){return this.context.getValue("connectionHandler")},ht=new WeakSet,wt=function(t){return o(this,Gt).get(t)},vs=new WeakSet,co=function(t,e){return o(this,Gt).set(t,e)},Dh=new WeakSet,Qy=function(t){return{track:t,encodings:[{priority:"high"}],codecOptions:[{name:"opus"}],appData:{e2ee:this.e2ee},stopTracks:!1,zeroRtpOnPause:!0}},Oh=new WeakSet,Xy=function(t,e){return{track:t,codecOptions:[{name:e?e.split("/")[1]:"VP8"}],appData:{screenShare:!1,e2ee:this.e2ee},stopTracks:!1}};he([S.trace("MediaNodeClient.reset",{country:S.location.country})],ue.prototype,"reset",1);he([S.trace("MediaNodeClient.joinRoom")],ue.prototype,"joinRoom",1);he([S.trace("MediaNodeClient.completeJoinRoom")],ue.prototype,"completeJoinRoom",1);he([S.trace("MediaNodeClient.leaveRoom")],ue.prototype,"leaveRoom",1);he([S.trace("MediaNodeClient.activatePeers")],ue.prototype,"activatePeers",1);he([S.trace("MediaNodeClient.deactivatePeers")],ue.prototype,"deactivatePeers",1);he([S.trace("MediaNodeClient.createConsumers")],ue.prototype,"createConsumers",1);he([S.trace("MediaNodeClient.closeConsumers")],ue.prototype,"closeConsumers",1);he([S.trace("MediaNodeClient._shareWebcam")],ue.prototype,"_shareWebcam",1);he([S.trace("MediaNodeClient.shareWebcam")],ue.prototype,"shareWebcam",1);he([S.trace("MediaNodeClient.shareScreen")],ue.prototype,"shareScreen",1);he([S.trace("MediaNodeClient.shareMic")],ue.prototype,"shareMic",1);he([S.trace("MediaNodeClient.pauseMic")],ue.prototype,"pauseMic",1);he([S.trace("MediaNodeClient.pauseWebcam")],ue.prototype,"pauseWebcam",1);he([S.trace("MediaNodeClient.resumeMic")],ue.prototype,"resumeMic",1);he([S.trace("MediaNodeClient.resumeWebcam")],ue.prototype,"resumeWebcam",1);he([S.trace("MediaNodeClient.disableWebcam")],ue.prototype,"disableWebcam",1);he([S.trace("HiveClient.disableMic")],ue.prototype,"disableMic",1);he([S.trace("HiveClient.disableScreenShare")],ue.prototype,"disableScreenShare",1);he([S.trace("MediaNodeClient.muteSelf")],ue.prototype,"muteSelf",1);he([S.trace("MediaNodeClient.resetVideoProducers")],ue.prototype,"resetVideoProducers",1);he([S.trace("MediaNodeClient.changeDisplayName")],ue.prototype,"changeDisplayName",1);he([S.trace("MediaNodeClient.kickPeer")],ue.prototype,"kick",1);he([S.trace("MediaNodeClient.kickAllPeers")],ue.prototype,"kickAll",1);he([S.trace("MediaNodeClient.muteAll")],ue.prototype,"muteAll",1);he([S.trace("MediaNodeClient.muteAllVideo")],ue.prototype,"muteAllVideo",1);he([S.trace("MediaNodeClient.disableAudio")],ue.prototype,"disableAudio",1);he([S.trace("MediaNodeClient.disableVideo")],ue.prototype,"disableVideo",1);he([S.trace("MediaNodeClient.pinPeer")],ue.prototype,"pinPeer",1);he([S.trace("MediaNodeClient.validateScreenShare")],ue.prototype,"validateScreenShare",1);function Zy(t,e,n){const r=t.getValue("roomNodeClient");if(r){if(r)return r;throw new Error("Room node client already set up.")}const i=new ue(t,e,n);return t.setValue("roomNodeClient",i),i}function eS(t){const e=t.getValue("roomNodeClient");try{e==null||e.leaveRoom()}catch{p.error("roomNodeClient::cleanupRoomNodeClient")}t.setValue("roomNodeClient",void 0)}var zN=Object.defineProperty,YN=Object.getOwnPropertyDescriptor,ji=(t,e,n,r)=>{for(var i=r>1?void 0:r?YN(e,n):e,s=t.length-1,a;s>=0;s--)(a=t[s])&&(i=(r?a(e,n,i):a(i))||i);return r&&i&&zN(e,n,i),i},Xr,Cn,St,Zt,dn,zg;const tS=(zg=class{constructor(t,e,n,r){f(this,Zt),g(this,"self"),g(this,"authToken"),f(this,Xr,void 0),g(this,"viewType"),f(this,Cn,void 0),f(this,St,void 0);const{socket:i}=n,s=t.getValue("authToken");this.self=e,v(this,St,t),this.viewType=r,this.authToken=s,v(this,Xr,i),v(this,Cn,n),e.config.viewType!==Ct.Chat&&this.setupEvents()}get peerId(){return o(this,St).getValue("peerId")}get mediaJoined(){return o(this,St).getValue("connectionHandler").mediaJoined}static init(t,e,n,r,i){return u(this,null,function*(){const s=dt(),a=t.getValue("peerId"),c=!!t.getValue("cachedUserDetails"),d=yield st.__init__(t,n,r,i,i.name,c);if(navigator.product!=="ReactNative"){const l=!Z.hasFeature(ie.PRECALL_BANDWIDTH_TEST);setTimeout(()=>u(this,null,function*(){const h=yield d.getAllDevices();p.info("populated_full_device_list",{devices:JSON.stringify(h)}),K.devices("AUDIO",h==null?void 0:h.filter(m=>m.kind==="audioinput")),K.devices("VIDEO",h==null?void 0:h.filter(m=>m.kind==="videoinput")),K.devices("SPEAKER",h==null?void 0:h.filter(m=>m.kind==="audiooutput")),p.info("Callstats:: initializing");try{yield K.initialize({peerId:a,engineName:Ce.getDeviceInfo().engineName,env:t.getValue("env"),iceServers:yield s.getICEServers(),apiBase:t.getValue("apiBase"),flags:Z.getAllFlags(),logger:p,apiHostnames:Jv(t),skipConnectivityChecks:l}),p.info("Callstats:: initialized")}catch(m){p.error("Callstats:: initialization failed",{error:m})}}),0)}else p.info("Callstats:: Skipped initialization due to navigator product being ReactNative.");return new tS(t,d,e,i.viewType)})}shareMediaTracks(){return u(this,null,function*(){var t;const{audioTrack:e,videoTrack:n,permissions:r,audioEnabled:i,videoEnabled:s,screenShareEnabled:a,screenShareTracks:c}=this.self;if(r.canProduceAudio&&i)try{yield o(this,Zt,dn).shareMic(e)}catch{this.self.disableAudio()}if(r.canProduceVideo&&s)try{const d=yield o(this,Zt,dn).shareWebcam(n);d&&d.id!==n.id&&Z.hasFeature(ie.EXP_RESHARE)&&(yield o(this,Zt,dn).shareWebcam(d))}catch{this.self.disableVideo()}if(r.canProduceScreenshare&&a)try{yield(t=o(this,Zt,dn))==null?void 0:t.shareScreen({video:c.video,audio:c.audio})}catch{this.self.disableScreenShare()}})}kickHandler(t){return u(this,null,function*(){let e="kicked";(t==null?void 0:t.kickType)==="kickAll"&&(e="ended"),this.leaveRoom(e)})}waitlistedHandler(){p.info("SelController.waitlisted"),this.self.waitlistStatus="waiting",this.self.roomState="waitlisted",this.self.emit("waitlisted")}waitlistAcceptHandler(){if(p.info("SelController.waitlistAccepted"),this.self.waitlistStatus==="accepted"){p.warn("SelfController.WAITLIST_ACCEPTED.UserAlreadyAccepted");return}this.self.waitlistStatus="accepted",this.joinRoom()}waitlistRejectedHandler(){if(p.info("SelfController.waitlistRejected"),this.self.waitlistStatus==="rejected"){p.warn("SelfController.WAITLIST_REJECTED.UserAlreadyRejected");return}this.self.waitlistStatus="rejected",this.leaveRoom("rejected")}resetSelf(t){return u(this,null,function*(){K.callEnded(),o(this,Zt,dn).reset(),t&&(yield this.joinRoom(t))})}setupEvents(){C.on(R.RESET_PRODUCER_STATE,()=>u(this,null,function*(){this.mediaJoined&&this.shareMediaTracks()})),C.on(R.ROOM_NODE_RECONNECTED,()=>{this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:!0})}),C.on(R.ROOM_NODE_DISCONNECTED,()=>{this.self.roomState!=="disconnected"&&(this.self.roomState="disconnected",this.self.emit("roomLeft",{state:"disconnected"}))}),C.on(R.ROOM_NODE_FAILED,()=>{this.self.roomState="failed",this.self.emit("roomLeft",{state:"failed"})}),C.on(R.SOCKET_SERVICE_RECONNECTED,({wasJoinAttempted:t})=>{t===!1&&(this.self.roomState="init"),this.resetSelf(t)}),C.on(R.SOCKET_SERVICE_DISCONNECTED,({joinAttempted:t})=>{if(this.self.roomState==="disconnected")return;let{peerId:e}=this;t&&Z.hasFeature(ie.REFRESH_ID_ON_DISCONNECTION)&&(e=Us()),o(this,Xr).updateURL(e),S.resetPeerId(e),dt().setHeader("dyte-tracing-id",e),Ci.remapContext(e,o(this,St)),this.self.roomState="disconnected",this.self.emit("roomLeft",{state:"disconnected"})}),C.on(R.SOCKET_SERVICE_FAILED,()=>{this.self.roomState="failed",this.self.emit("roomLeft",{state:"failed"})}),o(this,Cn).on(j.waitingRoomRequestAccepted,()=>{this.waitlistAcceptHandler()}),o(this,Cn).on(Nc.updateUserPreset,t=>{t.updatePeersPresets.forEach(e=>{e.userIds===this.self.userId&&C.emit(R.UPDATE_PERMISSIONS,e.patch)})}),o(this,Cn).on(j.waitingRoomRequestDenied,()=>{this.waitlistRejectedHandler()}),o(this,Cn).on(j.kick,()=>{this.kickHandler({kickType:"kick"})}),o(this,Cn).on(j.kickAll,()=>{this.kickHandler({kickType:"kickAll"})}),C.onAsync(R.JOIN_MEDIA_ROOM,this.joinMediaRoom.bind(this)),C.on(R.PRODUCER_SCORE_UPDATE,({score:t,kind:e,appData:n,scoreStats:r})=>{var i;const s=(i=n==null?void 0:n.screenShare)!=null?i:!1;this.self.emit("mediaScoreUpdate",{kind:e,isScreenshare:s,score:t,participantId:this.self.id,scoreStats:r})}),C.on(R.MUTE_SELF,()=>u(this,null,function*(){this.self.audioEnabled&&(yield this.self.disableAudio(),K.audioOff())})),C.on(R.MUTE_SELF_VIDEO,()=>u(this,null,function*(){this.self.videoEnabled&&(yield this.self.disableVideo(),K.videoOff())})),C.onAsync(R.LEAVE_MEDIA_ROOM,this.leaveMediaRoom.bind(this)),C.on(R.PIP_HANGUP,this.leaveRoom.bind(this))}joinRoom(t=!1){return u(this,null,function*(){try{const{peer:e}=yield o(this,Cn).joinRoom(this.self);o(this,Cn).socket.flush();const n=up(e.stageType);if(o(this,St).setValue("stageStatus",n,!1),e.waitlisted){this.waitlistedHandler();return}yield this.joinMediaRoom(t),o(this,St).notify("stageStatus")}catch(e){throw p.error("Error in joinRoom",{error:e}),e}})}leaveRoom(t="left"){return u(this,null,function*(){var e,n;if(t==="rejected"){try{(e=o(this,Xr))==null||e.disconnect()}catch{p.error("SelfController::leaveRoom::socketDisconnect")}this.self.roomState=t,this.self.emit("roomLeft",{state:t});return}this.self.setIsPinned(!1),o(this,St).setValue("stageStatus","OFF_STAGE",!1),yield this.leaveMediaRoom(t),o(this,St).notify("stageStatus");try{(n=o(this,Xr))==null||n.disconnect()}catch{p.error("SelfController::leaveRoom::socketDisconnect")}eS(o(this,St)),Nd.cleanup(),this.self.roomState=t,this.self.emit("roomLeft",{state:t})})}joinMediaRoom(t=!1){return u(this,null,function*(){var e,n;const{peerId:r,viewType:i,meetingId:s,stageStatus:a,roomNodeOptions:c}=o(this,St).getAllValues(),{sfu:d}=c;try{if(i===Ct.Livestream){if(a!=="ON_STAGE"){this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:t});return}Zy(o(this,St),d,{socket:o(this,Xr),peerId:r})}const{roomJoined:l}=(n=yield(e=o(this,Zt,dn))==null?void 0:e.joinRoom(this.self.name,s,{audio:this.self.audioEnabled,video:this.self.videoEnabled,screen:this.self.screenShareEnabled},t,t))!=null?n:{};if(!l)return;a==="ON_STAGE"&&(yield this.shareMediaTracks()),this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:t})}catch(l){throw p.error("Error:SelfController.mediaRoomJoin",l),new _("Error: could not join media room","0002")}})}leaveMediaRoom(t){return u(this,null,function*(){const e=o(this,St).getValue("viewType");t!=="connected-meeting"&&(yield this.cleanupSelf()),!(t==="stageLeft"&&e===Ct.Webinar)&&o(this,Zt,dn)&&(o(this,Zt,dn).mediaJoined&&t!=="disconnected"&&(yield o(this,Zt,dn).leaveRoom()),!(t==="stageLeft"&&e===Ct.Livestream)&&(o(this,Zt,dn).mediaJoined=!1))})}cleanupSelf(){return u(this,null,function*(){yield this.self.disableAudio(),yield this.self.disableVideo(),yield this.self.disableScreenShare(),this.self.cleanUpTracks(),this.self.destructMediaHandler(),navigator.isReactNative||this.self.removeDocumentEventListeners()})}},Xr=new WeakMap,Cn=new WeakMap,St=new WeakMap,Zt=new WeakSet,dn=function(){return o(this,St).getValue("roomNodeClient")},zg);let Gr=tS;ji([S.trace("SelfController.resetSelf")],Gr.prototype,"resetSelf",1);ji([S.trace("SelfController.setupEvents")],Gr.prototype,"setupEvents",1);ji([S.trace("SelfController.joinRoom")],Gr.prototype,"joinRoom",1);ji([S.trace("SelfController.leaveRoom")],Gr.prototype,"leaveRoom",1);ji([S.trace("SelfController.joinMediaRoom")],Gr.prototype,"joinMediaRoom",1);ji([S.trace("SelfController.leaveMediaRoom")],Gr.prototype,"leaveMediaRoom",1);ji([S.trace("SelfController.init")],Gr,"init",1);var od;class QN{constructor(e){f(this,od,void 0),v(this,od,e)}on(e,n){let r;e===j.roomPeerCount?r=sg.fromBinary.bind(sg):r=fg.fromBinary.bind(fg),o(this,od).on(e,({payload:i})=>{const s=r(i);return n(s)})}}od=new WeakMap;var cd;class XN{constructor(e){f(this,cd,void 0),v(this,cd,e)}on(e,n){let r,i;switch(e){case j.transcript:{r=ql.fromBinary.bind(ql),i=ql.create();break}default:{p.debug("AISocketHandler switch case hit default, event not accounted for.");break}}o(this,cd).on(e,({payload:s})=>{let a=i;try{a=r(s)}catch(c){p.error("chatSocketHandler::on::binary_decode_error",{error:c})}return n(a)})}}cd=new WeakMap;var ZN=Object.defineProperty,eL=Object.getOwnPropertyDescriptor,bp=(t,e,n,r)=>{for(var i=r>1?void 0:r?eL(e,n):e,s=t.length-1,a;s>=0;s--)(a=t[s])&&(i=(r?a(e,n,i):a(i))||i);return r&&i&&ZN(e,n,i),i},Ir;class fl{constructor(e){f(this,Ir,void 0),v(this,Ir,e)}getPolls(){return o(this,Ir).sendMessagePromise(zn.getPolls)}createPoll(e,n,r=!1,i=!1){const s={anonymous:r,hideVotes:i,question:e,options:n};return o(this,Ir).sendMessage(zn.createPoll,J1.toBinary(s))}votePoll(e,n){const r={index:n,pollId:e};return o(this,Ir).sendMessage(zn.votePoll,K1.toBinary(r))}on(e,n){let r,i;switch(e){case zn.updatePoll:case zn.createPoll:case zn.votePoll:{r=Yl.fromBinary.bind(Yl),i=Yl.create();break}}o(this,Ir).on(e,({payload:s})=>{let a=i;try{a=r(s)}catch(c){p.error("pollSocketHandler::on::binary_decode_error",{error:c})}return n(a)})}removeListeners(e){o(this,Ir).removeListeners(e)}}Ir=new WeakMap;bp([S.trace("PollSocketHandler.getPolls")],fl.prototype,"getPolls",1);bp([S.trace("PollSocketHandler.createPoll")],fl.prototype,"createPoll",1);bp([S.trace("PollSocketHandler.votePoll")],fl.prototype,"votePoll",1);var qt;class tL{constructor(e){f(this,qt,void 0),v(this,qt,e)}getStageRequests(){return u(this,null,function*(){const{payload:e}=yield o(this,qt).sendMessagePromise(j.getStageRequests);return e?zl.fromBinary(e):{stageRequests:[]}})}requestAccess(){o(this,qt).sendMessage(j.requestStageAccess)}cancelRequestAccess(){o(this,qt).sendMessage(j.cancelStageRequest)}grantAccess(e){return u(this,null,function*(){const n={userIds:e};o(this,qt).sendMessage(j.grantStageAccess,x1.toBinary(n))})}denyAccess(e){return u(this,null,function*(){const n={userIds:e};o(this,qt).sendMessage(j.denyStageAccess,U1.toBinary(n))})}joinStage(){return o(this,qt).sendMessagePromise(j.joinStage,void 0,void 0,j.peerStageStatusUpdate)}leaveStage(e){const n={userIds:[e]};return o(this,qt).sendMessagePromise(j.leaveStage,yg.toBinary(n),void 0,j.peerStageStatusUpdate)}kick(e){const n={userIds:e};return o(this,qt).sendMessagePromise(j.leaveStage,yg.toBinary(n))}on(e,n){let r;switch(e){case j.grantStageAccess:case j.denyStageAccess:{r=void 0;break}case j.getStagePeers:{r=vg.fromBinary.bind(vg);break}case j.getStageRequests:case j.requestStageAccess:case j.cancelStageRequest:{r=zl.fromBinary.bind(zl);break}case j.peerStageStatusUpdate:{r=ig.fromBinary.bind(ig);break}}o(this,qt).on(e,({payload:i,id:s})=>{if(!i||!r)return n(void 0,s);const a=r(i);return n(a,s)})}getPeerInfo(e){return u(this,null,function*(){const n=yield o(this,qt).sendMessagePromise(j.getPeerInfo,ny.toBinary({peerId:e}));return ts.fromBinary(n.payload)})}}qt=new WeakMap;var tt;class nL{constructor(e){f(this,tt,void 0),v(this,tt,e)}addPlugin(e,n){o(this,tt).sendMessage(z.addPlugin,ZA.toBinary({pluginId:e,staggered:n}))}removePlugin(e){o(this,tt).sendMessage(z.removePlugin,t1.toBinary({pluginId:e,staggered:!1}))}getActivePlugins(){return u(this,null,function*(){const{payload:e}=yield o(this,tt).sendMessagePromise(z.getPlugins);return e?w1.fromBinary(e):{plugins:[]}})}customPluginEventToRoom(e,n,r){const i={pluginId:e,pluginData:new TextEncoder().encode(JSON.stringify(n))};o(this,tt).sendMessage(z.customPluginEventToRoom,u1.toBinary(i),r)}customPluginEventToPeers(e,n,r,i){const s={pluginId:e,peerIds:n,pluginData:new TextEncoder().encode(JSON.stringify(r))};o(this,tt).sendMessage(z.customPluginEventToPeers,p1.toBinary(s),i)}enablePluginForRoom(e,n){o(this,tt).sendMessage(z.enablePluginForRoom,r1.toBinary({pluginId:e}),n)}enablePluginForPeers(e,n,r){o(this,tt).sendMessage(z.enablePluginForPeers,o1.toBinary({pluginId:e,peerIds:n}),r)}disablePluginForRoom(e,n){o(this,tt).sendMessage(z.disablePluginForRoom,s1.toBinary({pluginId:e}),n)}disablePluginForPeers(e,n,r){o(this,tt).sendMessage(z.disablePluginForPeers,d1.toBinary({pluginId:e,peerIds:n}),r)}storeInsertKeys(e,n,r,i){const s={pluginId:e,storeName:n,insertKeys:r.map(a=>({storeKey:a.key,payload:new TextEncoder().encode(JSON.stringify(a.payload))}))};o(this,tt).sendMessage(z.storeInsertKeys,hg.toBinary(s),i)}storeGetKeys(e,n,r,i){const s={pluginId:e,storeName:n,getKeys:r.map(a=>({storeKey:a.key}))};o(this,tt).sendMessage(z.storeGetKeys,v1.toBinary(s),i)}storeDeleteKeys(e,n,r,i){const s={pluginId:e,storeName:n,deleteKeys:r.map(a=>({storeKey:a.key}))};o(this,tt).sendMessage(z.storeDeleteKeys,S1.toBinary(s),i)}storeDelete(e,n,r){o(this,tt).sendMessage(z.storeDelete,T1.toBinary({pluginId:e,storeName:n}),r)}getPluginDataOld(e,n){p.info("getPluginDataOld",{plugin:{id:e,storeName:n}})}storePluginDataOld(e,n,r){const i={pluginId:e,storeName:n,insertKeys:[{storeKey:r.key,payload:new TextEncoder().encode(JSON.stringify(r))}]};o(this,tt).sendMessage(z.storeInsertKeys,hg.toBinary(i))}on(e,n){let r;switch(e){case z.addPlugin:case z.enablePluginForPeers:case z.enablePluginForRoom:{r=Hu.fromBinary.bind(Hu);break}case z.removePlugin:case z.disablePluginForPeers:case z.disablePluginForRoom:{r=pg.fromBinary.bind(pg);break}case z.customPluginEventToPeers:case z.customPluginEventToRoom:{r=gg.fromBinary.bind(gg);break}case z.storeInsertKeys:case z.storeGetKeys:case z.storeDeleteKeys:case z.storeDelete:{r=mg.fromBinary.bind(mg);break}}o(this,tt).on(e,({payload:i,id:s})=>{const a=r(i);return n(a,s)})}}tt=new WeakMap;var rL=Object.defineProperty,iL=(t,e,n)=>e in t?rL(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n,sL=(t,e,n)=>(iL(t,typeof e!="symbol"?e+"":e,n),n),wp=(t,e,n)=>{if(!e.has(t))throw TypeError("Cannot "+n)},L=(t,e,n)=>(wp(t,e,"read from private field"),n?n.call(t):e.get(t)),Ie=(t,e,n)=>{if(e.has(t))throw TypeError("Cannot add the same private member more than once");e instanceof WeakSet?e.add(t):e.set(t,n)},me=(t,e,n,r)=>(wp(t,e,"write to private field"),r?r.call(t,n):e.set(t,n),n),De=(t,e,n)=>(wp(t,e,"access private method"),n),Hd={},aL={get exports(){return Hd},set exports(t){Hd=t}},Ds=typeof Reflect=="object"?Reflect:null,Yg=Ds&&typeof Ds.apply=="function"?Ds.apply:function(t,e,n){return Function.prototype.apply.call(t,e,n)},dd;Ds&&typeof Ds.ownKeys=="function"?dd=Ds.ownKeys:Object.getOwnPropertySymbols?dd=function(t){return Object.getOwnPropertyNames(t).concat(Object.getOwnPropertySymbols(t))}:dd=function(t){return Object.getOwnPropertyNames(t)};function oL(t){console&&console.warn&&console.warn(t)}var nS=Number.isNaN||function(t){return t!==t};function fe(){fe.init.call(this)}aL.exports=fe;Hd.once=uL;fe.EventEmitter=fe;fe.prototype._events=void 0;fe.prototype._eventsCount=0;fe.prototype._maxListeners=void 0;var Qg=10;function vl(t){if(typeof t!="function")throw new TypeError('The "listener" argument must be of type Function. Received type '+typeof t)}Object.defineProperty(fe,"defaultMaxListeners",{enumerable:!0,get:function(){return Qg},set:function(t){if(typeof t!="number"||t<0||nS(t))throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received '+t+".");Qg=t}});fe.init=function(){(this._events===void 0||this._events===Object.getPrototypeOf(this)._events)&&(this._events=Object.create(null),this._eventsCount=0),this._maxListeners=this._maxListeners||void 0};fe.prototype.setMaxListeners=function(t){if(typeof t!="number"||t<0||nS(t))throw new RangeError('The value of "n" is out of range. It must be a non-negative number. Received '+t+".");return this._maxListeners=t,this};function rS(t){return t._maxListeners===void 0?fe.defaultMaxListeners:t._maxListeners}fe.prototype.getMaxListeners=function(){return rS(this)};fe.prototype.emit=function(t){for(var e=[],n=1;n<arguments.length;n++)e.push(arguments[n]);var r=t==="error",i=this._events;if(i!==void 0)r=r&&i.error===void 0;else if(!r)return!1;if(r){var s;if(e.length>0&&(s=e[0]),s instanceof Error)throw s;var a=new Error("Unhandled error."+(s?" ("+s.message+")":""));throw a.context=s,a}var c=i[t];if(c===void 0)return!1;if(typeof c=="function")Yg(c,this,e);else for(var d=c.length,l=cS(c,d),n=0;n<d;++n)Yg(l[n],this,e);return!0};function iS(t,e,n,r){var i,s,a;if(vl(n),s=t._events,s===void 0?(s=t._events=Object.create(null),t._eventsCount=0):(s.newListener!==void 0&&(t.emit("newListener",e,n.listener?n.listener:n),s=t._events),a=s[e]),a===void 0)a=s[e]=n,++t._eventsCount;else if(typeof a=="function"?a=s[e]=r?[n,a]:[a,n]:r?a.unshift(n):a.push(n),i=rS(t),i>0&&a.length>i&&!a.warned){a.warned=!0;var c=new Error("Possible EventEmitter memory leak detected. "+a.length+" "+String(e)+" listeners added. Use emitter.setMaxListeners() to increase limit");c.name="MaxListenersExceededWarning",c.emitter=t,c.type=e,c.count=a.length,oL(c)}return t}fe.prototype.addListener=function(t,e){return iS(this,t,e,!1)};fe.prototype.on=fe.prototype.addListener;fe.prototype.prependListener=function(t,e){return iS(this,t,e,!0)};function cL(){if(!this.fired)return this.target.removeListener(this.type,this.wrapFn),this.fired=!0,arguments.length===0?this.listener.call(this.target):this.listener.apply(this.target,arguments)}function sS(t,e,n){var r={fired:!1,wrapFn:void 0,target:t,type:e,listener:n},i=cL.bind(r);return i.listener=n,r.wrapFn=i,i}fe.prototype.once=function(t,e){return vl(e),this.on(t,sS(this,t,e)),this};fe.prototype.prependOnceListener=function(t,e){return vl(e),this.prependListener(t,sS(this,t,e)),this};fe.prototype.removeListener=function(t,e){var n,r,i,s,a;if(vl(e),r=this._events,r===void 0)return this;if(n=r[t],n===void 0)return this;if(n===e||n.listener===e)--this._eventsCount===0?this._events=Object.create(null):(delete r[t],r.removeListener&&this.emit("removeListener",t,n.listener||e));else if(typeof n!="function"){for(i=-1,s=n.length-1;s>=0;s--)if(n[s]===e||n[s].listener===e){a=n[s].listener,i=s;break}if(i<0)return this;i===0?n.shift():dL(n,i),n.length===1&&(r[t]=n[0]),r.removeListener!==void 0&&this.emit("removeListener",t,a||e)}return this};fe.prototype.off=fe.prototype.removeListener;fe.prototype.removeAllListeners=function(t){var e,n,r;if(n=this._events,n===void 0)return this;if(n.removeListener===void 0)return arguments.length===0?(this._events=Object.create(null),this._eventsCount=0):n[t]!==void 0&&(--this._eventsCount===0?this._events=Object.create(null):delete n[t]),this;if(arguments.length===0){var i=Object.keys(n),s;for(r=0;r<i.length;++r)s=i[r],s!=="removeListener"&&this.removeAllListeners(s);return this.removeAllListeners("removeListener"),this._events=Object.create(null),this._eventsCount=0,this}if(e=n[t],typeof e=="function")this.removeListener(t,e);else if(e!==void 0)for(r=e.length-1;r>=0;r--)this.removeListener(t,e[r]);return this};function aS(t,e,n){var r=t._events;if(r===void 0)return[];var i=r[e];return i===void 0?[]:typeof i=="function"?n?[i.listener||i]:[i]:n?lL(i):cS(i,i.length)}fe.prototype.listeners=function(t){return aS(this,t,!0)};fe.prototype.rawListeners=function(t){return aS(this,t,!1)};fe.listenerCount=function(t,e){return typeof t.listenerCount=="function"?t.listenerCount(e):oS.call(t,e)};fe.prototype.listenerCount=oS;function oS(t){var e=this._events;if(e!==void 0){var n=e[t];if(typeof n=="function")return 1;if(n!==void 0)return n.length}return 0}fe.prototype.eventNames=function(){return this._eventsCount>0?dd(this._events):[]};function cS(t,e){for(var n=new Array(e),r=0;r<e;++r)n[r]=t[r];return n}function dL(t,e){for(;e+1<t.length;e++)t[e]=t[e+1];t.pop()}function lL(t){for(var e=new Array(t.length),n=0;n<e.length;++n)e[n]=t[n].listener||t[n];return e}function uL(t,e){return new Promise(function(n,r){function i(a){t.removeListener(e,s),r(a)}function s(){typeof t.removeListener=="function"&&t.removeListener("error",i),n([].slice.call(arguments))}dS(t,e,s,{once:!0}),e!=="error"&&hL(t,i,{once:!0})})}function hL(t,e,n){typeof t.on=="function"&&dS(t,"error",e,n)}function dS(t,e,n,r){if(typeof t.on=="function")r.once?t.once(e,n):t.on(e,n);else if(typeof t.addEventListener=="function")t.addEventListener(e,function i(s){r.once&&t.removeEventListener(e,i),n(s)});else throw new TypeError('The "emitter" argument must be of type EventEmitter. Received type '+typeof t)}class pL extends T{constructor(){super("message.v1.SocketMessage",[{no:1,name:"event",kind:"scalar",T:13},{no:2,name:"id",kind:"scalar",opt:!0,T:9},{no:3,name:"payload",kind:"scalar",opt:!0,T:12},{no:4,name:"metadata",kind:"scalar",opt:!0,T:12}])}}const Xg=new pL;class lS{static encode(e){return Xg.toBinary(e)}static decode(e){return Xg.fromBinary(new Uint8Array(e))}}function mL(t,e){return Math.floor(Math.random()*(e-t+1)+t)}var Pr;class gL{constructor(e={}){sL(this,"opts"),Ie(this,Pr,void 0),this.opts={initialTimeout:e.initialTimeout||1e3,maxTimeout:e.maxTimeout||1e4,factor:e.factor||2},me(this,Pr,0)}wait(){return u(this,null,function*(){me(this,Pr,L(this,Pr)+1);const e=mL(0,Math.min(this.opts.maxTimeout,this.opts.initialTimeout*kE(2,L(this,Pr))));yield new Promise(n=>{setTimeout(n,e)})})}getAttempts(){return L(this,Pr)}reset(){me(this,Pr,0)}}Pr=new WeakMap;const gr={debug:0,info:1,warn:2,error:3};var vi,yi;class fL{constructor(e){Ie(this,vi,void 0),Ie(this,yi,void 0),me(this,vi,console),me(this,yi,e)}debug(...e){gr[L(this,yi)]>gr.debug||L(this,vi).debug("[Sockrates]:",...e)}info(...e){gr[L(this,yi)]>gr.info||L(this,vi).info("[Sockrates]:",...e)}warn(...e){gr[L(this,yi)]>gr.warn||L(this,vi).warn("[Sockrates]:",...e)}error(...e){gr[L(this,yi)]>gr.error||L(this,vi).error("[Sockrates]:",...e)}}vi=new WeakMap,yi=new WeakMap;var uS=(t=>(t[t.CONNECTING=0]="CONNECTING",t[t.OPEN=1]="OPEN",t[t.CLOSING=2]="CLOSING",t[t.CLOSED=3]="CLOSED",t))(uS||{});const vL="2",yL="3";var Ue,ys,Ae,He,Cr,nt,er,Lr,yn,Ss,Kn,Nh,hS,lo,ld,Lh,pS,xh,Zg,qd,Vh,Uh,mS,Co,ud,Ro,Gd,Jd,Fh,Os,Mo,Ao,$d;class SL{constructor(e,n){var r;Ie(this,Nh),Ie(this,lo),Ie(this,Lh),Ie(this,xh),Ie(this,qd),Ie(this,Uh),Ie(this,Co),Ie(this,Ro),Ie(this,Jd),Ie(this,Os),Ie(this,Ao),Ie(this,Ue,void 0),Ie(this,ys,void 0),Ie(this,Ae,void 0),Ie(this,He,void 0),Ie(this,Cr,void 0),Ie(this,nt,void 0),Ie(this,er,void 0),Ie(this,Lr,void 0),Ie(this,yn,void 0),Ie(this,Ss,void 0),Ie(this,Kn,void 0);var i,s,a,c,d,l,h,m,y;me(this,ys,e),me(this,Cr,[]),me(this,nt,new Hd),me(this,er,!0),me(this,yn,!1),me(this,Ae,n!=null?n:{}),(i=L(this,Ae)).autoReconnect!=null||(i.autoReconnect=!0),(s=L(this,Ae)).retryConnectionInterval!=null||(s.retryConnectionInterval=1e3),(a=L(this,Ae)).pingTimeout!=null||(a.pingTimeout=3e4),(c=L(this,Ae)).connectionTimeout!=null||(c.connectionTimeout=5e3),(d=L(this,Ae)).debug!=null||(d.debug=!0),(l=L(this,Ae)).maxReconnectionAttempts!=null||(l.maxReconnectionAttempts=10),(h=L(this,Ae)).disconnectOnPingTimeout!=null||(h.disconnectOnPingTimeout=!0),(m=L(this,Ae)).queueOnDisconnect!=null||(m.queueOnDisconnect=!1),(y=L(this,Ae)).flushOnReconnect!=null||(y.flushOnReconnect=!1),me(this,Lr,{code:void 0,reason:void 0}),me(this,He,(r=L(this,Ae).logger)!=null?r:new fL(L(this,Ae).debug?"debug":"info")),me(this,Kn,new gL)}get readyState(){var e;return(e=L(this,Ue))==null?void 0:e.readyState}get url(){return L(this,ys)}updateURL(e){me(this,ys,e),De(this,Uh,mS).call(this)}get config(){return L(this,Ae)}get sendQueue(){return L(this,Cr)}flush(){if(!L(this,Ae).queueOnDisconnect)return!1;const e=[];return L(this,Cr).forEach(n=>{this.send(n.event,n.id,n.payload,n.metadata)||e.push(n)}),me(this,Cr,e),L(this,Cr)}connect(e=!1){return u(this,null,function*(){if(!e&&[0,1].includes(this.readyState)){L(this,He).debug("Websocket was already connecting or connected.");return}if(L(this,er)!==!1)return new Promise((n,r)=>{De(this,Os,Mo).call(this),De(this,Ao,$d).call(this);try{me(this,Ue,new WebSocket(De(this,Nh,hS).call(this,L(this,ys)))),L(this,Ue).binaryType="arraybuffer",L(this,He).debug("Connecting");const i=setTimeout(()=>{L(this,He).debug("Connection timeout. Closing socket"),me(this,er,!0),De(this,Ao,$d).call(this),L(this,Ue).close(3001,"Connection Timeout"),L(this,Ae).autoReconnect&&!L(this,yn)&&(L(this,nt).emit("reconnecting"),De(this,Co,ud).call(this)),r(new Error("Connection timed out!"))},L(this,Ae).connectionTimeout);L(this,Ue).onopen=()=>{L(this,He).debug(`Ready State: ${uS[L(this,Ue).readyState]}`),i&&clearTimeout(i),De(this,Jd,Fh).call(this),me(this,Lr,{code:void 0,reason:void 0}),L(this,nt).emit("connected"),L(this,Ae).flushOnReconnect&&this.flush(),n()},L(this,Ue).onclose=s=>{try{i&&clearTimeout(i);const{code:a,reason:c}=s;r(c),L(this,He).debug("Socket closed. Close event:",{event:s}),L(this,He).debug(`Connection closed code: ${a}`),L(this,He).debug(`Connection closed reason: ${c}`),L(this,yn)||De(this,qd,Vh).call(this,a,c)}catch(a){De(this,lo,ld).call(this,a)}},L(this,Ue).onerror=s=>{De(this,lo,ld).call(this,s)},L(this,Ue).onmessage=s=>De(this,Lh,pS).call(this,s)}catch(i){De(this,lo,ld).call(this,i,r)}})})}send(e,n,r,i){const s={event:e,id:n,payload:r,metadata:i};if(L(this,Ae).queueOnDisconnect&&(!L(this,Ue)||L(this,Ue).readyState!==1))return L(this,He).debug("Queuing message since socket is not connected!",s),L(this,Cr).push(s),!1;const a=lS.encode(s);return De(this,Ro,Gd).call(this,a)}emit(e,n,r,i){return this.send(e,n,r,i)}sendRaw(e){return De(this,Ro,Gd).call(this,e)}receive(e,n){return L(this,nt).on(e.toString(),n)}on(e,n){if(typeof e=="string"&&(e==="connected"||e==="disconnected"||e==="errored"||e==="reconnected"||e==="reconnecting"||e==="reconnectAttempt"||e==="reconnectFailure"||e==="failed")){L(this,nt).on(e,n);return}this.receive(e,n)}removeAllListeners(){L(this,nt).removeAllListeners()}removeReceiver(e,n){this.removeListener(e,n)}removeListener(e,n){L(this,nt).removeListener(e.toString(),n)}removeReceivers(e){this.removeListeners(e)}removeListeners(e){L(this,nt).listeners(e.toString()).map(n=>this.removeListener(e,n))}disconnect(){me(this,er,!1),De(this,Os,Mo).call(this),this.removeAllListeners(),me(this,Lr,{code:1e3,reason:"Sockrates disconnect method called"}),L(this,Ue).close(1e3,"Sockrates disconnect method called.")}}Ue=new WeakMap,ys=new WeakMap,Ae=new WeakMap,He=new WeakMap,Cr=new WeakMap,nt=new WeakMap,er=new WeakMap,Lr=new WeakMap,yn=new WeakMap,Ss=new WeakMap,Kn=new WeakMap,Nh=new WeakSet,hS=function(t){if(t.startsWith("ws://")||t.startsWith("wss://"))return t;if(t.startsWith("https://"))return`wss://${t.substring(8)}`;if(t.startsWith("http://"))return`ws://${t.substring(7)}`;throw new Error("Invalid URL. URL must start with http(s):// or ws(s)://.")},lo=new WeakSet,ld=function(t,e){L(this,He).error("Error:",{error:t}),L(this,nt).emit("errored",{error:t}),e==null||e(t)},Lh=new WeakSet,pS=function(t){if(De(this,Jd,Fh).call(this),t.data===vL){L(this,He).debug("Received ping from server"),De(this,Ro,Gd).call(this,yL);return}const e=lS.decode(t.data),{id:n,payload:r}=e;L(this,He).debug("Received message",{event:e.event,messageID:n}),L(this,nt).emit(e.event.toString(),{id:n,payload:r})},xh=new WeakSet,Zg=function(){return L(this,Ue).readyState===1},qd=new WeakSet,Vh=function(t,e){me(this,Lr,{reason:e,code:t}),L(this,nt).emit("disconnected",{code:t,reason:e})},Uh=new WeakSet,mS=function(){const{reason:t,code:e}=L(this,Lr);e&&e!==1e3&&L(this,er)&&L(this,Ae).autoReconnect&&!L(this,yn)&&(L(this,He).debug(`Triggering reconnection due to ${t}.`),L(this,nt).emit("reconnecting"),De(this,Co,ud).call(this))},Co=new WeakSet,ud=function(t=!0){return u(this,null,function*(){if(t&&L(this,yn)){L(this,He).debug("Reconnect called when already in a reconnect loop. Ignoring.");return}if(L(this,yn)||L(this,Kn).reset(),L(this,Ae).maxReconnectionAttempts!==null&&L(this,Kn).getAttempts()>=L(this,Ae).maxReconnectionAttempts){L(this,nt).emit("failed"),me(this,yn,!1);return}me(this,yn,!0),De(this,Ao,$d).call(this),De(this,Os,Mo).call(this);try{if(yield L(this,Kn).wait(),L(this,er)===!1)return;if(L(this,He).debug(`Reconnection attempt ${L(this,Kn).getAttempts()}`),L(this,nt).emit("reconnectAttempt",{attempt:L(this,Kn).getAttempts()}),yield this.connect(),!De(this,xh,Zg).call(this))throw Error("Reconnect Failed");me(this,yn,!1),me(this,Lr,{code:void 0,reason:void 0}),L(this,nt).emit("reconnected")}catch{L(this,He).debug("Failed to reconnect."),L(this,nt).emit("reconnectFailure",{attempt:L(this,Kn).getAttempts()}),De(this,Co,ud).call(this,!1)}})},Ro=new WeakSet,Gd=function(t){try{return L(this,Ue).send(t),!0}catch(e){return L(this,He).error(e.message),!1}},Jd=new WeakSet,Fh=function(){this.config.disconnectOnPingTimeout&&(L(this,He).debug("Resetting ping timeout"),De(this,Os,Mo).call(this),me(this,Ss,setTimeout(()=>{var t;L(this,He).debug("Disconnecting the socket due to ping timeout"),me(this,er,!0);const e=3002,n="Ping timeout";(t=L(this,Ue))==null||t.close(e,n),De(this,qd,Vh).call(this,e,n)},L(this,Ae).pingTimeout)))},Os=new WeakSet,Mo=function(){L(this,Ss)&&(clearTimeout(L(this,Ss)),me(this,Ss,void 0))},Ao=new WeakSet,$d=function(){L(this,Ue)&&(L(this,Ue).onopen=void 0,L(this,Ue).onerror=void 0,L(this,Ue).onmessage=void 0,L(this,Ue).onclose=void 0)};var EL=Object.defineProperty,TL=Object.getOwnPropertyDescriptor,yl=(t,e,n,r)=>{for(var i=r>1?void 0:r?TL(e,n):e,s=t.length-1,a;s>=0;s--)(a=t[s])&&(i=(r?a(e,n,i):a(i))||i);return r&&i&&EL(e,n,i),i};const ef=65535,kL=3e3;var Zr,Le,xe,Fe,ln,fr,kc,gu,bc,fu,tf;const gS=(tf=class{constructor(t,{peerId:e,meetingId:n,authToken:r,capabilities:i}){f(this,xe),f(this,kc),f(this,bc),f(this,Zr,void 0),f(this,Le,void 0),g(this,"roomName"),g(this,"authToken"),g(this,"capabilities"),f(this,ln,void 0),f(this,fr,void 0);var s;if(!e||!n||!r)throw new _("peerId, meetingId, or authToken can not be empty","0404");v(this,ln,void 0),v(this,fr,t),this.capabilities=i,this.roomName=n,this.authToken=r,v(this,Zr,H(this,kc,gu).call(this,e)),v(this,Le,new SL(o(this,Zr),{autoReconnect:!0,disconnectOnPingTimeout:(s=i.includes("PING"))!=null?s:!1,queueOnDisconnect:!0,flushOnReconnect:!1,logger:p})),this.handleSocketConnectionEvents()}get joinAttempted(){return o(this,xe,Fe).socketJoinAttempted}set joinAttempted(t){o(this,xe,Fe).socketJoinAttempted=t}get peerId(){return o(this,fr).getValue("peerId")}updateURL(t){t!==this.peerId&&(v(this,Zr,H(this,kc,gu).call(this,t)),p.debug("SocketService:: Connection URL updated.")),o(this,Le).updateURL(o(this,Zr))}static getSocketEdgeDomain(t){return Cs({servicePrefix:"socket-edge",baseURI:t})}get url(){return o(this,Zr)}connect(){return u(this,null,function*(){o(this,xe,Fe).socketJoinAttempted=!0,yield o(this,Le).connect(),o(this,xe,Fe).socketJoinAttempted=!0,o(this,xe,Fe).socketState={state:"connected",reconnected:!1,reconnectionAttempt:void 0}})}disconnect(){return u(this,null,function*(){o(this,xe,Fe).socketJoinAttempted=!1,o(this,Le).disconnect(),o(this,xe,Fe).socketJoinAttempted=!0,o(this,xe,Fe).socketState={state:"disconnected",reconnected:!1,reconnectionAttempt:void 0}})}get isConnected(){try{return o(this,Le).readyState===1}catch{return!1}}sendMessage(t,e,n){const r={};return S.injectContext(r),o(this,Le).send(t,n!=null?n:H(this,bc,fu).call(this),e,new TextEncoder().encode(JSON.stringify(r)))}sendMessagePromise(t,e,n,r){const i=parseInt({}.SOCKET_SERVICE_MESSAGE_REQUEST_TIMEOUT,10)||2e4;return this.sendMessagePromiseWithTimeout({event:t,timeout:i,protobuf:e,messageId:n,resp:r})}sendMessagePromiseWithTimeout({event:t,timeout:e,protobuf:n,messageId:r,resp:i}){const s=i!=null?i:t;return new Promise((a,c)=>{const d=(E,b)=>{o(this,Le).removeListener(s,E),o(this,Le).removeListener(ef,b),o(this,Le).removeListener(rn.errorResponse,b),o(this,Le).removeListener(Sn.errorResponse,b)},l=r!=null?r:H(this,bc,fu).call(this),h={};S.injectContext(h);const m=({id:E,payload:b})=>{if(l===E){let O;try{const M=hC.fromBinary(b);O=new Error(M.errorMessage)}catch(M){O=new Error("failed to parse error message",{cause:M});try{const F=gR.fromBinary(b);O=new Error(F.message)}catch(F){O=new Error("failed to parse error message",{cause:F})}}c(O),d(y,m)}},y=({id:E,payload:b})=>{l===E&&(a({id:E,payload:b}),d(y,m))};o(this,Le).on(s,y),o(this,Le).on(ef,m),o(this,Le).on(rn.errorResponse,m),o(this,Le).on(Sn.errorResponse,m),setTimeout(()=>{d(y,m),c(new Error(`request timeout for callback eventId:${t}`))},e),o(this,Le).send(t,l,n,new TextEncoder().encode(JSON.stringify(h)))})}on(t,e){o(this,Le).on(t,e)}onStateEvent(t,e){o(this,Le).on(t,e)}removeListener(t,e){o(this,Le).removeListener(t,e)}removeListeners(t){o(this,Le).removeListeners(t)}flush(){return o(this,Le).flush()}handleSocketConnectionEvents(){this.onStateEvent("connected",()=>u(this,null,function*(){p.info("SocketService::Connected to socket-edge"),o(this,ln)&&(clearTimeout(o(this,ln)),v(this,ln,void 0)),o(this,xe,Fe).updateSocketConnectionState("connected")})),this.onStateEvent("disconnected",({code:t,reason:e})=>{var n;p.info("SocketService::Disconnected from socket-edge",{error:{code:t,reason:e},country:S.location.country});const{recv:r,send:i}=(n=o(this,xe,Fe).mediaState)!=null?n:{};r!=null&&r.state&&(r==null?void 0:r.state)!==Br.CONNECTED||i!=null&&i.state&&(i==null?void 0:i.state)!==Br.CONNECTED?C.emit(R.SOCKET_SERVICE_DISCONNECTED,{joinAttempted:o(this,xe,Fe).joinAttempted}):v(this,ln,setTimeout(()=>{C.emit(R.SOCKET_SERVICE_DISCONNECTED,{joinAttempted:o(this,xe,Fe).joinAttempted}),v(this,ln,void 0)},kL)),o(this,xe,Fe).updateSocketConnectionState("disconnected")}),this.onStateEvent("reconnecting",()=>u(this,null,function*(){p.info("SocketService::Reconnecting to socket-edge",{country:S.location.country}),o(this,xe,Fe).updateSocketConnectionState("reconnecting")})),this.onStateEvent("reconnectAttempt",t=>u(this,[t],function*({attempt:e}){p.info("SocketService::Attempting to reconnect to socket-edge",{socket:{retryAttempt:e}}),o(this,xe,Fe).updateSocketConnectionState("reconnectAttempt",e)})),this.onStateEvent("reconnectFailure",({attempt:t})=>{p.info("SocketService::Reconnect attempt to socket-edge failed",{socket:{retryAttempt:t}}),o(this,xe,Fe).updateSocketConnectionState("reconnectFailure",t)}),this.onStateEvent("reconnected",()=>u(this,null,function*(){p.info("SocketService::Reconnected to socket-edge",{connectionState:{joinAttempted:o(this,xe,Fe).mediaJoinAttempted}}),o(this,ln)&&(clearTimeout(o(this,ln)),v(this,ln,void 0)),C.emit(R.SOCKET_SERVICE_RECONNECTED,{wasJoinAttempted:o(this,xe,Fe).mediaJoinAttempted}),o(this,xe,Fe).updateSocketConnectionState("reconnected")})),this.onStateEvent("failed",()=>u(this,null,function*(){p.info("SocketService::Failed to connect to socket-edge",{country:S.location.country}),C.emit(R.SOCKET_SERVICE_FAILED),o(this,xe,Fe).updateSocketConnectionState("failed")}))}},Zr=new WeakMap,Le=new WeakMap,xe=new WeakSet,Fe=function(){return o(this,fr).getValue("connectionHandler")},ln=new WeakMap,fr=new WeakMap,kc=new WeakSet,gu=function(t){let e=gS.getSocketEdgeDomain(o(this,fr).getValue("baseURI"));typeof Rd(o(this,fr),"socket_server_base")=="string"&&(e=Rd(o(this,fr),"socket_server_base"));const n=`wss://${e}`,r=new URL(`${n}/ws`),i=this.peerId,s=G(V({roomID:this.roomName,peerID:t,authToken:this.authToken,useMediaV2:!0},i!==t&&{oldPeerID:i}),{ping:this.capabilities.includes("PING"),capabilities:this.capabilities.map(a=>Md[a]).join(" "),joinWithDetails:!0,useCfWorker:!0});return Object.entries(s).forEach(([a,c])=>{r.searchParams.append(a,c.toString())}),r.href},bc=new WeakSet,fu=function(){return`${this.peerId}-${(Math.random()+1).toString(36).substring(7)}`},tf);let $o=gS;yl([S.trace("SocketService.connect")],$o.prototype,"connect",1);yl([S.trace("SocketService.disconnect")],$o.prototype,"disconnect",1);yl([S.trace("SocketService.sendMessagePromise")],$o.prototype,"sendMessagePromise",1);yl([S.trace("SocketService.sendMessagePromiseWithTimeout")],$o.prototype,"sendMessagePromiseWithTimeout",1);const Si=class{static handleConnectedRoomsDumpRaw({payload:t}){var e;const n=jR.fromBinary(t),r=n.meetings.map(i=>{var s;return{id:i.id,title:i.title,participants:(s=i.participants)!=null?s:[]}});return{parentMeeting:{id:n.parentMeeting.id,title:n.parentMeeting.title,participants:(e=n.parentMeeting.participants)!=null?e:[]},meetings:r}}static handleTransferPeerRaw({payload:t}){const e=mM.fromBinary(t);return{authToken:e.authToken,meetingId:e.meetingId}}static handleMovedPeerRaw({payload:t}){const e=ry.fromBinary(t);return{meetingId:e.meetingId,customParticipantId:e.customParticipantId}}static handleConnectedRoomsUpdatedRaw({payload:t}){return cg.fromBinary(t).payloads.map(e=>({id:e.id,title:e.title}))}static handleConnectedRoomsDeletedRaw({payload:t}){return iM.fromBinary(t).payloads}static getConnectedRoomsDump(){return u(this,null,function*(){const t=yield Si.socketService.sendMessagePromise(j.getConnectedRoomsDump);return Si.handleConnectedRoomsDumpRaw(t)})}static createConnectedRooms(t){return u(this,null,function*(){const{payload:e}=yield Si.socketService.sendMessagePromise(j.createConnectedRooms,JR.toBinary({payloads:t}));return cg.fromBinary(e).payloads.map(n=>({id:n.id,title:n.title}))})}static updateConnectedRooms(t){return u(this,null,function*(){})}static disableConnectedRooms(t){return u(this,null,function*(){const e=t.map(r=>({id:r})),n=yield Si.socketService.sendMessagePromise(j.deleteConnectedRooms,nM.toBinary({payloads:e}));return Si.handleConnectedRoomsDeletedRaw(n)})}static movePeersBetweenRooms(t){return u(this,null,function*(){try{const e=yield Si.socketService.sendMessagePromise(j.movePeers,lM.toBinary({sourceMeetingId:t.sourceMeetingId,destinationMeetingId:t.destinationMeetingId,participants:t.participants}));return new TextDecoder().decode(e.payload).includes("error")?{success:!1,error:"failed to move participants"}:{success:!0}}catch(e){return{success:!1,error:e}}})}};let Ne=Si;g(Ne,"socketService"),g(Ne,"currentMeetingId");var bL=Object.defineProperty,wL=Object.getOwnPropertyDescriptor,Sl=(t,e,n,r)=>{for(var i=r>1?void 0:r?wL(e,n):e,s=t.length-1,a;s>=0;s--)(a=t[s])&&(i=(r?a(e,n,i):a(i))||i);return r&&i&&bL(e,n,i),i};const Es=class{constructor(t,e){g(this,"apiBase"),g(this,"selfController"),g(this,"pollController"),g(this,"chatController"),g(this,"metaController"),g(this,"storesManager"),g(this,"stageController"),g(this,"pluginController"),g(this,"internalsController"),g(this,"recordingController"),g(this,"livestreamController"),g(this,"participantController"),this.apiBase=t,this.storesManager=e.storesManager,this.metaController=e.metaController,this.selfController=e.selfController,this.chatController=e.chatController,this.pollController=e.pollController,this.stageController=e.stageController,this.pluginController=e.pluginController,this.recordingController=e.recordingController,this.internalsController=e.internalsController,this.participantController=e.participantController,this.livestreamController=e.livestreamController}static init(t){return u(this,null,function*(){var e,n;const{peerId:r,apiBase:i,authToken:s,meetingId:a,organizationId:c,cachedUserDetails:d}=t.getAllValues();if(C.reset(),Nd.cleanup(),eS(t),Ce.isSupported()===!1)throw new _("Browser not supported","0010",!0);const l=PD(t,{authToken:s,baseURL:i,cachedUserDetails:d});l.setRoomName(a),l.setRoomUUID(a),l.setOrganizationId(c),l.setHeader("dyte-tracing-id",r),t.setValue("apiClient",l);const h=new dO;t.setValue("connectionHandler",h);const m=Es.createSocketService(t),y=m.connect(),E=l.getUserDetails(),b=l.getPlugins();let O=rt.HIVE,M,F="";try{yield Es.setupFlagsmith(t)}catch(X){p.error("Failed to setup flagsmith",{error:X})}try{yield y}catch(X){p.error("[Controller]: Failed to connect to socket server:",{error:X})}try{({sfu:O,meetingTitle:F}=yield l.getRoomNodeData()),M=yield E,p.info(`SFU ${O} is being used.`),t.setValue("presetName",M.preset.name),t.setValue("roomNodeOptions",{sfu:O})}catch(X){p.error("Failed to get room metadata",{error:X})}const x=$O.init(M.preset,!t.getValue("modules").theme),J=Es.setupControllers(m,t,M,b,F,x);XD(x)&&((e=Es.createRoomNodeClient(t,m).partialJoinRoom(M.participant.name,a,void 0))==null||e.catch(X=>{p.error("[Controller]: Failed to queue partial media room promise:",{error:X})})),S.location.country=(n=l.ipInfo)==null?void 0:n.country;const{controllers:I}=yield J;return YI(),new Es(i,I)})}static setupFlagsmith(t){return u(this,null,function*(){var e;const{peerId:n,baseURI:r,overrides:i,meetingId:s,organizationId:a}=t.getAllValues(),c=KI(s),d=G(V({entity:xu.PEER,clientId:a,isAnonUser:!a,sdkVersion:t.getValue("sdkVersion"),presetName:t.getValue("presetName"),meetingHash:c,roomName:s},Ce.getDeviceInfo()),{isReactNative:navigator.isReactNative});try{const l=(e=i==null?void 0:i.whitelabelled_flags_endpoint)==null||e?Cs({servicePrefix:"flags",baseURI:r}):"edge.api.flagsmith.com";yield Z.identify(`${xu.PEER}_${n}`,JSON.parse(JSON.stringify(d)),!1,5e3,l,p),p.info("flagsmith::allFlags",{flags:JSON.stringify(Z.getAllFlags())},!0)}catch{p.error("Failed to fetch flagsmith flags")}})}static setupControllers(t,e,n,r,i,s){return u(this,null,function*(){var a,c,d;const l=e.getValue("modules"),{preset:h,participant:m}=n,y=e.getValue("defaults"),{sfu:E}=e.getValue("roomNodeOptions"),{viewType:b,mediaConstraints:{audio:O}}=s;e.setValue("viewType",b),e.setValue("defaults",V({mediaConfiguration:{audio:{enableHighBitrate:(a=O.enableHighBitrate)!=null?a:!1,enableStereo:(c=O.enableStereo)!=null?c:!1}}},y));const M=mN.init(e,b,h.permissions);e.setValue("maxPreferredStreams",Ce.isMobile()?s.maxVideoStreams.mobile:s.maxVideoStreams.desktop);let F,x,J,I,X,ae,Ee,ce;const Re=new XN(t);Ne.socketService=t;const vt=new fl(t),A=new sn(t),k=new tL(t),w=Nd.create(t,e),W=new nL(t),_e=new QN(t),ze=new Di(t),B=yield Gr.init(e,w,m,M,s),P=yield my.init(e,B.self,w,Re,i);if(l.participant&&(ce=new dr(e,B.self,w,E)),(d=l.e2ee)!=null&&d.enabled&&l.e2ee.manager.init(p,C),l.chat&&(x=yield nr.init(e,A,ze,B.self,ce.participants)),l.internals&&(X=yield pp.init()),l.livestream&&s.viewType===Ct.Livestream&&Z.hasFeature(ie.LIVESTREAM)&&(Ee=new by(B.self,_e)),s.viewType!==Ct.Chat){if(l.poll&&(F=yield ly.init(e,B.self,vt)),l.recording&&(ae=new yy(e,B.self,w)),l.stage&&(J=new gy(e,k,w,B.self,ce.participants)),l.plugin){if(!ce)throw new _("The plugin module cannot be initialized without the `participant` module","0102");const Wn=yield r;I=yield Ho.init(e,Wn,W,A,x==null?void 0:x.chat,B.self,ce.participants,i)}if(l.pip){const Wn=yield ZI._init(e,B.self);e.setValue("pip",Wn)}}const Ye={storesManager:new tN(e,W),pollController:F,selfController:B,metaController:P,chatController:x,stageController:J,pluginController:I,recordingController:ae,internalsController:X,livestreamController:Ee,participantController:ce};return{theme:s,permissions:M,controllers:Ye}})}static createRoomNodeClient(t,e){const{peerId:n,roomNodeOptions:r}=t.getAllValues(),{sfu:i}=r;return Zy(t,i,{socket:e,peerId:n})}static createSocketService(t){const{peerId:e,meetingId:n,authToken:r}=t.getAllValues(),i=["PING"];return new $o(t,{peerId:e,meetingId:n,authToken:r,capabilities:i})}};let Ko=Es;Sl([S.trace("Controller.init")],Ko,"init",1);Sl([S.trace("setupFlagsmith")],Ko,"setupFlagsmith",1);Sl([S.trace("Controller.createRoomNodeClient")],Ko,"createRoomNodeClient",1);Sl([S.trace("Controller.createSocketService")],Ko,"createSocketService",1);var _L=Object.defineProperty,IL=Object.getOwnPropertyDescriptor,PL=(t,e,n,r)=>{for(var i=r>1?void 0:r?IL(e,n):e,s=t.length-1,a;s>=0;s--)(a=t[s])&&(i=(r?a(e,n,i):a(i))||i);return r&&i&&_L(e,n,i),i},hd,Bh;class fS extends Kt{constructor(e,n){super(),f(this,hd,void 0),g(this,"meetings",[]),g(this,"parentMeeting",null),f(this,Bh,void 0),v(this,Bh,e),v(this,hd,n.self)}get supportsConnectedMeetings(){return o(this,hd).id!==""}get isActive(){return this.meetings.length!==0}get currentMeetingId(){return Ne.currentMeetingId}validateConnectedMeetingsAction(){if(!this.supportsConnectedMeetings)throw new Error(`You are not allowed to perform this action.
|
|
21
21
|
Please connect with Dyte team to move you to V2 APIs & to enable connected meetings.`)}getConnectedMeetings(){return u(this,null,function*(){return this.validateConnectedMeetingsAction(),yield Ne.getConnectedRoomsDump()})}createMeetings(e){return u(this,null,function*(){return this.validateConnectedMeetingsAction(),(yield Ne.createConnectedRooms(e)).map(n=>({id:n.id,title:n.title}))})}updateMeetings(e){return u(this,null,function*(){this.validateConnectedMeetingsAction(),yield Ne.updateConnectedRooms(e.map(n=>({meetingId:n.id,title:n.title})))})}deleteMeetings(e){return u(this,null,function*(){this.validateConnectedMeetingsAction();const n=this.meetings.map(r=>e.includes(r.id)&&r.participants.length!==0?this.moveParticipants(r.id,this.parentMeeting.id,r.participants.map(i=>i.id)):Promise.resolve());return yield Promise.all(n),yield Ne.disableConnectedRooms(e)})}moveParticipants(e,n,r){return u(this,null,function*(){this.validateConnectedMeetingsAction();const i=yield Ne.movePeersBetweenRooms({sourceMeetingId:e,destinationMeetingId:n,participants:r.map(s=>({id:s}))});return i.success&&this.moveSuccessHandler(e,n,r),i})}moveParticipantsWithCustomPreset(e,n,r){return u(this,null,function*(){this.validateConnectedMeetingsAction();const i=yield Ne.movePeersBetweenRooms({sourceMeetingId:e,destinationMeetingId:n,participants:r});return i.success&&this.moveSuccessHandler(e,n,r.map(s=>s.id)),i})}moveSuccessHandler(e,n,r){const i=new Map;[...this.parentMeeting.participants,...this.meetings.flatMap(s=>s.participants)].forEach(s=>i.set(s.id,s)),n===this.parentMeeting.id&&(this.parentMeeting.participants=this.parentMeeting.participants.concat(r.map(s=>i.get(s)))),e===this.parentMeeting.id&&(this.parentMeeting.participants=this.parentMeeting.participants.filter(s=>!r.includes(s.id))),this.meetings=this.meetings.map(s=>{if(n===s.id){const a=s.participants.concat(r.map(c=>i.get(c)));return G(V({},s),{participants:a})}if(e===s.id){const a=s.participants.filter(c=>!r.includes(c.id));return G(V({},s),{participants:a})}return s})}}hd=new WeakMap,Bh=new WeakMap;PL([Ut({maxInvocations:60,period:60})],fS.prototype,"getConnectedMeetings",1);var CL=Object.defineProperty,RL=Object.getOwnPropertyDescriptor,_p=(t,e,n,r)=>{for(var i=r>1?void 0:r?RL(e,n):e,s=t.length-1,a;s>=0;s--)(a=t[s])&&(i=(r?a(e,n,i):a(i))||i);return r&&i&&CL(e,n,i),i},Da,un,vu,yu;const Rr=(vu=class{constructor(t,e,n){g(this,"connectedMeetings"),f(this,Da,void 0),f(this,un,void 0),f(this,yu,void 0),v(this,yu,t),v(this,Da,n),this.connectedMeetings=new fS(t,e),this.setCurrentMeeting(e)}static init(t,e,n){return Rr.instance||(Rr.instance=new Rr(t,e,n)),Rr.instance.connectedMeetings.supportsConnectedMeetings&&(Rr.instance.setupEvents(),e.self.once("roomJoined",()=>Rr.instance.getConnectedMeetings())),Rr.instance}setCurrentMeeting(t){v(this,un,t),Ne.currentMeetingId=t.meta.meetingId}getConnectedMeetings(){this.connectedMeetings.getConnectedMeetings()}setupEvents(){Ne.socketService&&(Ne.socketService.on(j.getConnectedRoomsDump,this.handleConnectedRoomsDump.bind(this)),Ne.socketService.on(j.transferPeer,this.handleTransferPeer.bind(this)),Ne.socketService.on(j.movedPeer,this.handleMovedPeer.bind(this)),Ne.socketService.on(j.connectedRoomsUpdated,this.handleConnectedRoomsUpdated.bind(this)),Ne.socketService.on(j.connectedRoomsDeleted,this.handleConnectedRoomsDeleted.bind(this)))}handleTransferPeer(t){const e=Ne.handleTransferPeerRaw(t);return this.switchMeeting(e)}switchMeeting(t){return u(this,arguments,function*({authToken:e,meetingId:n}){var r,i,s,a;if(!this.connectedMeetings.supportsConnectedMeetings)throw new Error(`You are not allowed to perform this action.
|
|
22
22
|
Please connect with Dyte team to move you to V2 APIs & to enable connected meetings.`);p.info("ConnectedMeetingsController::switchMeeting:: asking ui-kit to show switching breakout UI"),this.connectedMeetings.emit("changingMeeting",n);const c={video:o(this,un).self.videoEnabled,audio:o(this,un).self.audioEnabled};try{o(this,un).self.cleanupEvents(),yield o(this,un).leave("connected-meeting")}catch(l){p.error(`ConnectedMeetingsController:: switchMeeting:: issues in leaving previous meeting. Meeting Id: ${(i=(r=o(this,un))==null?void 0:r.meta)==null?void 0:i.meetingId}`,{error:l})}Ne.socketService=void 0,p.info(`ConnectedMeetingsController::switchMeeting:: initializing new meeting. Meeting Id: ${n}`);const d=yield vS.init(G(V({},o(this,Da)),{cachedUserDetails:null,defaults:G(V(V({},o(this,Da).defaults),c),{mediaHandler:o(this,un).self}),authToken:e}));p.info(`ConnectedMeetingsController::switchMeeting:: initialized new meeting. Meeting Id: ${(s=d==null?void 0:d.meta)==null?void 0:s.meetingId}`);try{const{hidden:l}=o(this,un).self;d.self.setName(o(this,un).self.name),yield d.join(),l&&d.self.hide()}catch(l){p.error("ConnectedMeetingsController.joinRoom",{error:l})}return p.info(`ConnectedMeetingsController::switchMeeting:: asking ui-kit to show in-meeting ui of newly joined meeting id: ${(a=d==null?void 0:d.meta)==null?void 0:a.meetingId}`),this.connectedMeetings.emit("meetingChanged",d),this.setCurrentMeeting(d),d})}handleConnectedRoomsDump(t){const e=Ne.handleConnectedRoomsDumpRaw(t);this.connectedMeetings.meetings=e.meetings.map(n=>({id:n.id,title:n.title,participants:n.participants||[]})),this.connectedMeetings.parentMeeting={id:e.parentMeeting.id,title:e.parentMeeting.title,participants:e.parentMeeting.participants},this.emitStateUpdate()}handleMovedPeer(t){return Ne.handleMovedPeerRaw(t)}handleConnectedRoomsUpdated(t){const e=Ne.handleConnectedRoomsUpdatedRaw(t),n=new Map;this.connectedMeetings.meetings.forEach(r=>{n.set(r.id,r)}),e.forEach(r=>{n.has(r.id)?n.get(r.id).title=r.title:n.set(r.id,G(V({},r),{participants:[]}))}),this.connectedMeetings.meetings=Array.from(n.values()),this.emitStateUpdate()}handleConnectedRoomsDeleted(t){const e=Ne.handleConnectedRoomsDeletedRaw(t).map(n=>n.id);this.connectedMeetings.meetings=this.connectedMeetings.meetings.filter(n=>!e.includes(n.id)),this.emitStateUpdate()}emitStateUpdate(){this.connectedMeetings.emit("stateUpdate",{meetings:this.connectedMeetings.meetings,parentMeeting:this.connectedMeetings.parentMeeting})}},Da=new WeakMap,un=new WeakMap,yu=new WeakMap,g(vu,"instance"),vu);let El=Rr;_p([S.trace("ConnectedMeetingsController.getConnectedMeetings")],El.prototype,"getConnectedMeetings",1);_p([S.trace("ConnectedMeetingsController.setupEvents")],El.prototype,"setupEvents",1);_p([S.trace("ConnectedMeetingsController.switchMeeting")],El.prototype,"switchMeeting",1);class ML{constructor(){g(this,"battery"),g(this,"init",()=>u(this,null,function*(){try{"getBattery"in navigator&&(this.battery=yield navigator.getBattery(),this.battery.addEventListener("chargingchange",this.updateChargeInfo),this.battery.addEventListener("levelchange",this.updateLevelInfo),this.updateLevelInfo(),this.updateChargeInfo())}catch(e){p.error("Error getting battery",e)}})),g(this,"updateChargeInfo",()=>{var e;p.log(`Battery charging? ${(e=this.battery)!=null&&e.charging?"Yes":"No"}`)}),g(this,"updateLevelInfo",()=>{if(!this.battery){p.log("Battery level: Not known");return}p.log(`Battery level: ${this.battery.level*100}%`)}),g(this,"cleanup",()=>{var e,n;"getBattery"in navigator&&((e=this.battery)==null||e.removeEventListener("chargingchange",this.updateChargeInfo),(n=this.battery)==null||n.removeEventListener("levelchange",this.updateLevelInfo))})}}const nf=new ML;function AL(t,e){t.startsWith("eyJ")||console.error("Invalid auth token provided. Ensure you are passing a %cparticipant `authToken`%c \u2014 not an Org API Key or an incorrectly formatted token.\nYou get the participant token from the Add Participant API: https://docs.dyte.io/api#/operations/add_participant","font-weight: bold","font-weight: normal");try{const{meetingId:n,orgId:r,participantId:i}=JSON.parse(atob(t.split(".")[1]));if(!n)throw Error(`Received V1 auth token ${t}`);let s="dyte.io";e&&(s=e);const a=`https://api.${s}`;return{meetingId:n,orgId:r,participantId:i,baseURI:s,apiBase:a}}catch(n){throw p.error("constants::decodeAuthToken",{error:n,debuggingHint:`Unable to decode auth token: ${t}`},!0),new _("Invalid auth token","0004")}}var DL=Object.defineProperty,OL=Object.getOwnPropertyDescriptor,Tl=(t,e,n,r)=>{for(var i=r>1?void 0:r?OL(e,n):e,s=t.length-1,a;s>=0;s--)(a=t[s])&&(i=(r?a(e,n,i):a(i))||i);return r&&i&&DL(e,n,i),i},ot,wc,_c,Su,rf,sf;let Wr=(sf=class{constructor(t,e){f(this,Su),f(this,ot,void 0),f(this,wc,void 0),f(this,_c,void 0),v(this,_c,t),v(this,ot,e)}static init(t){return u(this,null,function*(){var e,n,r,i,s,a,c;GI(),Ce.init();const d=(n=(e=t==null?void 0:t.cachedUserDetails)==null?void 0:e.peerId)!=null?n:Us();nf.init();const{authToken:l,baseURI:h}=t,m=AL(l,h),{meetingId:y}=m,E=Yd(m,["meetingId"]);window.__zone_symbol__DISABLE_WRAPPING_UNCAUGHT_PROMISE_REJECTION=!0;const b=Wr.setupContext(d,t,y,E);S.meetingMetadata.roomName=y,S.meetingMetadata.userId=E.participantId,S.meetingMetadata.organizationId=E.orgId,S.init(b,(i=(r=t.modules)==null?void 0:r.tracing)!=null?i:!0),p.info("DyteClient::init::options",{dyteClientInitOptions:G(V({},t),{authToken:`${(s=t.authToken)==null?void 0:s.slice(0,10)}...
|
|
23
|
-
${(a=t.authToken)==null?void 0:a.slice(-10)}`})});const O=yield Ko.init(b),M=new Wr(b,O);return H(c=M,Su,rf).call(c,t),M})}static setupContext(t,e,n,r){var i;const s=Ci.createContext(t,e),a=V(V({},FI),e==null?void 0:e.modules);return s.setValue("peerId",t),s.setValue("modules",a),s.setValue("sdkName","web-core"),s.setValue("meetingId",n),s.setValue("apiBase",r.apiBase),s.setValue("baseURI",r.baseURI),s.setValue("userId",r.participantId),s.setValue("organizationId",r.orgId),s.setValue("authToken",e.authToken),s.setValue("overrides",(i=e.overrides)!=null?i:{}),s.setValue("env",BI({baseURI:r.baseURI})),s.setValue("defaults",e.defaults||{audio:!0,video:!0}),s.setValue("onError",e.onError||(()=>{})),s.setValue("cachedUserDetails",Tn(e.cachedUserDetails)),s.setValue("sdkVersion","2.5.0-staging.
|
|
23
|
+
${(a=t.authToken)==null?void 0:a.slice(-10)}`})});const O=yield Ko.init(b),M=new Wr(b,O);return H(c=M,Su,rf).call(c,t),M})}static setupContext(t,e,n,r){var i;const s=Ci.createContext(t,e),a=V(V({},FI),e==null?void 0:e.modules);return s.setValue("peerId",t),s.setValue("modules",a),s.setValue("sdkName","web-core"),s.setValue("meetingId",n),s.setValue("apiBase",r.apiBase),s.setValue("baseURI",r.baseURI),s.setValue("userId",r.participantId),s.setValue("organizationId",r.orgId),s.setValue("authToken",e.authToken),s.setValue("overrides",(i=e.overrides)!=null?i:{}),s.setValue("env",BI({baseURI:r.baseURI})),s.setValue("defaults",e.defaults||{audio:!0,video:!0}),s.setValue("onError",e.onError||(()=>{})),s.setValue("cachedUserDetails",Tn(e.cachedUserDetails)),s.setValue("sdkVersion","2.5.0-staging.72"),s}join(){return u(this,null,function*(){const{selfController:t}=o(this,ot);return t.self.roomJoined?null:t.joinRoom()})}leave(t){return u(this,null,function*(){nf.cleanup();const{selfController:e}=o(this,ot);return e.leaveRoom(t)})}get participants(){var t;return(t=o(this,ot).participantController)==null?void 0:t.participants}get self(){var t;return(t=o(this,ot).selfController)==null?void 0:t.self}get meta(){var t;return(t=o(this,ot).metaController)==null?void 0:t.meta}get ai(){var t;return(t=o(this,ot).metaController)==null?void 0:t.ai}get plugins(){var t;return(t=o(this,ot).pluginController)==null?void 0:t.plugins}get chat(){var t;return(t=o(this,ot).chatController)==null?void 0:t.chat}get polls(){var t;return(t=o(this,ot).pollController)==null?void 0:t.polls}get connectedMeetings(){var t;return(t=o(this,wc))==null?void 0:t.connectedMeetings}get recording(){var t;return(t=o(this,ot).recordingController)==null?void 0:t.recording}get livestream(){var t;return(t=o(this,ot).livestreamController)==null?void 0:t.livestream}get stage(){var t;return(t=o(this,ot).stageController)==null?void 0:t.stage}get stores(){return o(this,ot).storesManager}get __internals__(){var t;return(t=o(this,ot).internalsController)==null?void 0:t.internals}joinRoom(){return u(this,null,function*(){return this.join()})}leaveRoom(t){return u(this,null,function*(){return this.leave(t)})}},ot=new WeakMap,wc=new WeakMap,_c=new WeakMap,Su=new WeakSet,rf=function(t){v(this,wc,El.init(o(this,_c),this,t))},sf);Tl([gt("0002"),qr.executeWithLock({methodName:"meeting.join",lockName:"DyteClient.join",timeout:3e3})],Wr.prototype,"join",1);Tl([gt("0003")],Wr.prototype,"leave",1);Tl([gt("0001"),qr.executeWithLock({methodName:"DyteClient.init",lockName:"DyteClient.init",timeout:3e3})],Wr,"init",1);Wr=Tl([gt("0000")],Wr);const vS=Wr;exports.DyteSelfMedia=Ry;exports.default=vS;
|
package/dist/index.es.js
CHANGED
|
@@ -30644,7 +30644,7 @@ let ei = (mf = class {
|
|
|
30644
30644
|
var c;
|
|
30645
30645
|
const n = ji.createContext(t, e), a = N(N({}, VR), e == null ? void 0 : e.modules);
|
|
30646
30646
|
return n.setValue("peerId", t), n.setValue("modules", a), n.setValue("sdkName", "web-core"), n.setValue("meetingId", r), n.setValue("apiBase", i.apiBase), n.setValue("baseURI", i.baseURI), n.setValue("userId", i.participantId), n.setValue("organizationId", i.orgId), n.setValue("authToken", e.authToken), n.setValue("overrides", (c = e.overrides) != null ? c : {}), n.setValue("env", $R({ baseURI: i.baseURI })), n.setValue("defaults", e.defaults || { audio: true, video: true }), n.setValue("onError", e.onError || (() => {
|
|
30647
|
-
})), n.setValue("cachedUserDetails", gs(e.cachedUserDetails)), n.setValue("sdkVersion", "2.5.0-staging.
|
|
30647
|
+
})), n.setValue("cachedUserDetails", gs(e.cachedUserDetails)), n.setValue("sdkVersion", "2.5.0-staging.72"), n;
|
|
30648
30648
|
}
|
|
30649
30649
|
join() {
|
|
30650
30650
|
return u(this, null, function* () {
|