@cloudflare/realtimekit 0.5.0-staging.66 → 0.5.0-staging.68
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 +1 -1
- package/dist/index.cjs.js +1 -1
- package/dist/index.es.js +1 -1
- package/dist/mock.cjs.js +2 -2
- package/dist/mock.es.js +57 -56
- package/dist/react.cjs.js +1 -1
- package/dist/react.es.js +1 -1
- package/package.json +1 -1
package/dist/index.cjs.js
CHANGED
|
@@ -20,4 +20,4 @@ ${t}`}const Bs={maxInvocations:5,period:1};function Ft(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 Nd extends vp{constructor(e){super(),m(this,"supportsSendEncodings",!1),this.supportsSendEncodings=e.supportsSendEncodings}static createFactory(e){return()=>new Nd(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,g)=>{var y;const E=jh(h),b=E.media[E.media.length-1],P=b.rtp.filter(G=>g.some(_=>_.name===G.codec)),R=b.fmtp.filter(G=>P.some(_=>_.payload===G.payload)),B=(y=b.rtcpFb)==null?void 0:y.filter(G=>P.some(_=>_.payload===G.payload)),L=P.map(G=>G.payload);return E.media[E.media.length-1].rtp=P,E.media[E.media.length-1].fmtp=R,E.media[E.media.length-1].rtcpFb=B,E.media[E.media.length-1].payloads=L.join(" "),mf(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:g}=this,y=this.enableHighBitrate?g?128e3:64e3:g?64e3:32e3;l.sdp=l.sdp.replace("minptime=10;useinbandfec=1",`minptime=10;useinbandfec=1;${h?"usedtx=1;":""}${g?"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 Sp extends vp{static createFactory(){return()=>new Sp}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 g;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=((g=y.sdpFmtpLine)==null?void 0:g.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:g}=this,y=this.enableHighBitrate?h?128e3:64e3:h?64e3:32e3;l.sdp=l.sdp.replace("minptime=10;useinbandfec=1",`minptime=10;useinbandfec=1;${g?"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 wN(t,e){return typeof t=="undefined"?e:typeof window!="undefined"&&Object.getOwnPropertyDescriptor(window,"structuredClone")?structuredClone(t):JSON.parse(JSON.stringify(t))}var Wc,os,$n,Yn,Ar,jc,du,nh,Cy,rh,Ry;class _N extends Oo{constructor(e){var n,r;super(),f(this,Yn),f(this,jc),f(this,nh),f(this,rh),m(this,"rtpReceiver"),m(this,"id"),m(this,"localId"),m(this,"producerId"),m(this,"producingTransportId"),m(this,"mimeType"),m(this,"track"),m(this,"peerId"),m(this,"appData"),m(this,"transceiver"),m(this,"closeTranscieverOnClose"),f(this,Wc,void 0),f(this,os,void 0),f(this,$n,void 0),this.id=e.id,this.localId=e.localId,v(this,Wc,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,os,(n=e.paused)!=null?n:!1),this.mimeType=e.mimeType,this.transceiver=e.transceiver,this.closeTranscieverOnClose=(r=e.closeTranscieverOnClose)!=null?r:!1,this.rtpReceiver=e.rtpReceiver,H(this,nh,Cy).call(this)}get closed(){return o(this,$n)}get kind(){return this.track.kind}get paused(){return o(this,os)}close(e){o(this,$n)||(p.debug(`Consumer::close() ${e?`with reason ${e}`:""}`,o(this,Yn,Ar)),v(this,$n,!0),this.closeTranscieverOnClose&&(H(this,rh,Ry).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,Wc).getReceiverStats(this.localId)})}pause(){if(p.debug("consumer::pause()",o(this,Yn,Ar)),o(this,$n)){p.error("consumer::pause() | Consumer closed",o(this,Yn,Ar));return}v(this,os,!0),this.track.enabled=!1,this.safeEmit("pause")}resume(){if(p.debug("consumer::resume()",o(this,Yn,Ar)),o(this,$n)){p.error("Consumer::resume() | Consumer closed",o(this,Yn,Ar));return}v(this,os,!1),this.track.enabled=!0,this.safeEmit("resume")}}Wc=new WeakMap,os=new WeakMap,$n=new WeakMap,Yn=new WeakSet,Ar=function(){return{consumer:{id:this.id,appData:this.appData,peerId:this.peerId,kind:this.kind}}},jc=new WeakSet,du=function(){p.debug('Consumer::track "ended" event',o(this,Yn,Ar)),this.safeEmit("trackended")},nh=new WeakSet,Cy=function(){this.track.addEventListener("ended",H(this,jc,du).bind(this))},rh=new WeakSet,Ry=function(){try{this.track.removeEventListener("ended",H(this,jc,du)),this.track.stop()}catch(t){p.error("Consumer::destroyTrack()",K(V({},o(this,Yn,Ar)),{error:t}))}};var Mn,$a,Ka,cs,fn,ut,ai,za,en,vn;class IN extends Oo{constructor(e){var n,r;super(),f(this,en),m(this,"id"),m(this,"localId"),f(this,Mn,void 0),m(this,"kind"),m(this,"appData"),m(this,"rtpSender"),f(this,$a,void 0),f(this,Ka,void 0),f(this,cs,void 0),f(this,fn,!1),f(this,ut,void 0),f(this,ai,void 0),f(this,za,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,ai,e.disableTrackOnPause?!((r=e.track)!=null&&r.enabled):!1),v(this,za,void 0),v(this,$a,e.stopTracks),v(this,Ka,e.disableTrackOnPause),v(this,cs,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,ai)}get maxSpatialLayer(){return o(this,za)}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===sh){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,ai,!0),o(this,ut)&&o(this,Ka)&&(o(this,ut).enabled=!1),o(this,cs)&&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,ai,!1),o(this,ut)&&o(this,Ka)&&(o(this,ut).enabled=!0),o(this,cs)&&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,$a))try{n.stop()}catch(r){p.error("Producer::replaceTrack",K(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,cs)||!o(this,ai))&&(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 Do("not a video Producer");if(typeof e!="number")throw new TypeError("invalid spatialLayer");yield o(this,Mn).setMaxSpatialLayer(this.localId,e),v(this,za,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,$a)&&o(this,ut).stop()}catch(n){p.error(`Producer::_destroyTrack trackId: ${(e=this.track)==null?void 0:e.id}`,K(V({},o(this,en,vn)),{error:n}))}}}Mn=new WeakMap,$a=new WeakMap,Ka=new WeakMap,cs=new WeakMap,fn=new WeakMap,ut=new WeakMap,ai=new WeakMap,za=new WeakMap,en=new WeakSet,vn=function(){return{producer:{id:this.id,appData:this.appData,kind:this.kind}}};function My(t){return typeof t=="object"&&!Array.isArray(t)&&t!==null}function ih(t){return Math.random().toString(36).substring(2,2+t)}const yc=1;function Wg(t){const e=t;return delete e.payload._bolt,e}function PN(t){return t.payload&&My(t.payload)}function Ay(t){var e,n;return PN(t)&&(n=(e=t.payload._bolt)==null?void 0:e.id)!=null?n:""}var oi;const Ya=class extends mt.EventEmitter{constructor(t,e,n){super(),m(this,"channel"),m(this,"queue"),m(this,"serverProtocolVersion"),f(this,oi,new Map),m(this,"respond",(r,i,s=!1)=>{let a;s?a=Ya.createErrorResponse(r,i):a=Ya.createResponse(r,i),this.channel.send(JSON.stringify(a))}),m(this,"notify",r=>{const i=Ya.createNotification(r);this.channel.send(JSON.stringify(i))}),m(this,"request",r=>u(this,null,function*(){const i=Ya.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:g=>{this.queue.delete(l)&&(clearTimeout(h.timer),a(g))},timer:setTimeout(()=>{this.queue.delete(l)&&c(new Error(`request timeout for message id: ${l}`))},d),cancel:g=>{this.queue.delete(l)&&(clearTimeout(h.timer),c(g))}};this.queue.set(l,h)});return this.channel.send(JSON.stringify(i)),s})),m(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 g=h*a,y=(h+1)*a;d.push(i.slice(g,y))}const l=Vs();for(let h=0;h<c;h+=1){const g=d[h],y=JSON.stringify({id:l,count:c,chunkIndex:h,chunk:g});p.debug(`Sending message chunk over dc: ${y}`),this.channel.send(y)}}else p.debug(`Sending message over dc: ${i}`),this.channel.send(i)}),m(this,"processMessage",r=>{var i;o(this,oi).has(r.id)||o(this,oi).set(r.id,[]);const s=o(this,oi).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,oi).get(r.id),c=a==null?void 0:a.reduce((l,h)=>l+h.chunk,"");o(this,oi).delete(r.id);const d=JSON.parse(c);if(!d.payload||!My(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}}),m(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(Wg(r)):s.resolve(Wg(r)),!0):!1}),m(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:ih(8),{type:"_bolt",payload:{message:"pong"}}),!0):!1}),this.label=e,this.transportId=n,this.channel=t,this.queue=new Map}};let Qa=Ya;oi=new WeakMap,m(Qa,"createRequest",t=>{var e;if((e=t.payload)!=null&&e._bolt)throw new Error("rpc fields are internal values");return{type:t.type,payload:K(V({},t.payload),{_bolt:{id:ih(8),type:"REQUEST",version:yc}})}}),m(Qa,"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:K(V({},e.payload),{_bolt:{id:t,type:"RESPONSE",version:yc}})}}),m(Qa,"createNotification",t=>{var e;if((e=t.payload)!=null&&e._bolt)throw new Error("rpc fields are internal values");return{type:t.type,payload:K(V({},t.payload),{bolt:{id:ih(8),type:"NOTIFY",version:yc}})}}),m(Qa,"createErrorResponse",(t,e)=>({type:"error",payload:{error:e.message,_bolt:{id:t,type:"RESPONSE",version:yc}}}));function jg(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 sh="transport closed";var Xa;class CN extends Oo{constructor(e,{id:n,direction:r,handlerFactory:i,iceServers:s,iceTransportPolicy:a,proprietaryConstraints:c,additionalSettings:d,appData:l,config:h}){var g,y,E;super(),m(this,"awaitQueue"),m(this,"observer"),f(this,Xa,void 0),m(this,"id"),m(this,"serverId"),m(this,"closed",!1),m(this,"direction"),m(this,"maxSctpMessageSize"),m(this,"handler"),m(this,"connectionState","new"),m(this,"producers"),m(this,"consumers"),m(this,"datachannels"),m(this,"connected",!1),m(this,"eventsDCReadyPromise"),m(this,"eventsDCReadyPromiseResolver"),m(this,"eventsDCFailureTimer"),m(this,"transportConnectionPromise"),m(this,"consumerTrackEvents"),m(this,"unknownTracksMap"),m(this,"appData"),p.debug(`constructor() [id: ${n}, direction: ${r}]`),v(this,Xa,e),this.id=n,this.direction=r;const b=wN(d,{});delete b.iceServers,delete b.iceTransportPolicy,delete b.bundlePolicy,delete b.rtcpMuxPolicy,delete b.sdpSemantics,this.producers=new Map,this.consumers=new Map,this.datachannels=new Map,this.consumerTrackEvents=new Map,this.unknownTracksMap=new Map,this.awaitQueue=new Od,this.observer=new Oo,this.handler=i(),this.handler.enableHighBitrate=(g=h==null?void 0:h.enableHighBitrate)!=null?g:!1,this.handler.enableStereo=(y=h==null?void 0:h.enableStereo)!=null?y:!1,this.handler.enableDtx=(E=h==null?void 0:h.enableDtx)!=null?E:!0,this.handler.init({onTrackHandler:this._ontrack.bind(this),direction:r,iceServers:s,iceTransportPolicy:a,additionalSettings:d,proprietaryConstraints:c}),this.appData=l||{},this.transportConnectionPromise=new Promise(P=>{this.observer.once("connected",()=>{P(!0)}),this.observer.once("disconnect",()=>{P(!1)}),this.observer.once("close",()=>{P(!1)})}),this.eventsDCReadyPromise=new Promise(P=>{this.eventsDCReadyPromiseResolver=P}),this.handler.on("@connectionstatechange",P=>{P!==this.connectionState&&(p.debug(`connection state changed to ${P}`),this.connectionState=P,P==="connected"&&(this.connected=!0,this.observer.emit("connected")),P==="disconnected"&&(this.connected=!1,this.observer.emit("disconnect")),(P==="failed"||P==="closed")&&(this.connected=!1,this.observer.emit("close")),this.closed||this.safeEmit("connectionstatechange",P))}),this.handler.on("@icecandidate",({candidate:P})=>{this.closed||this.safeEmit("icecandidate",P)}),this.handler.on("dc_open",P=>{let R=this.datachannels.get(P.label);R||(R||(R=new Qa(P,P.label,this.serverId),this.datachannels.set(P.label,R)),this.eventsDCFailureTimer=setTimeout(()=>{P.label==="events"&&(this.eventsDCReadyPromiseResolver(!1),this.safeEmit("dc_error",P.label))},5e3))}),this.handler.on("datachannel",(P,R)=>{P.label==="events"&&(this.eventsDCReadyPromiseResolver(!0),this.eventsDCFailureTimer&&clearTimeout(this.eventsDCFailureTimer));const B=this.datachannels.get(P.label);if(!B){p.error("unregistered datachannel for message",{rtcChannel:{label:P.label,message:R}});return}try{const L=JSON.parse(R);p.debug("datachannel message chunk recieved",{dataChannelMessageChunk:{id:L.id,count:L.count,chunkIndex:L.chunkIndex,chunk:L.chunk,transprtId:this.serverId}});const G=B.processMessage(L);if(!G)return;p.debug(`datachannel message with id:${L.id} on transport:${this.serverId}complete - ${JSON.stringify(G)}`),this.emit(`datachannel:${P.label}`,B.label,G)}catch(L){p.error("error parsing message",{error:L})}})}setServerId(e){this.serverId=e}getDatachannel(e){return this.datachannels.get(e)}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(e=>{e.close(sh).catch(()=>{})}),this.producers.clear(),Array.from(this.consumers.values()).forEach(e=>{e.close(sh)}),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(e,n){return u(this,null,function*(){try{const{producerIds:r}=yield this.awaitQueue.push(()=>u(this,null,function*(){const{offerSdp:i,callback:s}=yield this.handler.connect(),{transportId:a,answer:c,producerIds:d}=yield e(i);return this.setServerId(a),yield s(c),{producerIds:d}}));if(r.forEach((i,s)=>{this.createProducerObject({id:i,localId:n[s].mid,track:n[s].track,stopTracks:!0,disableTrackOnPause:!0,zeroRtpOnPause:!1,appData:JSON.parse(n[s].appData||"{}"),handler:this.handler}).catch(a=>{p.error("error creating producer:",a)})}),!(yield this.transportConnectionPromise))throw new Error("ice connection failed");if(o(this,Xa)===rt.HIVE&&!(yield this.isEventsDCReady))throw new Error("events datachannel not open")}catch(r){throw p.error("transport failed to connect:",r),r}})}restartIce(){return u(this,null,function*(){if(p.debug("restartIce()"),this.closed)throw new Pt("closed");return this.handler.restartIce()})}canProduce(e){return u(this,null,function*(){const{track:n,appData:r}=e;if(n){if(this.direction!=="send")throw new Do("not a sending Transport");if(n.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(r&&typeof r!="object")throw new TypeError("if given, appData must be an object")}else throw new TypeError("missing track");if(!(yield this.transportConnectionPromise))throw new Cs("transport not connected");return!0})}produce(e,n){return u(this,null,function*(){if(!(yield this.canProduce(e)))throw new Error("Cannot produce");const{track:r,encodings:i,codecOptions:s,stopTracks:a=!0,disableTrackOnPause:c=!0,zeroRtpOnPause:d=!1,appData:l={}}=e;p.debug(`produce() [track:${r.id}]`);const{producerId:h,localId:g,rtpSender:y}=yield this.awaitQueue.push(()=>u(this,null,function*(){const{offerSdp:E,callback:b,sender:P,mid:R}=yield this.handler.send({track:r,encodings:i,codecOptions:s,screenShare:l==null?void 0:l.screenShare}),{answer:B,producerId:L}=yield n({offer:E,kind:r.kind,paused:c?!r.enabled:!1,appData:K(V({},l||{}),{mid:R}),codecOptions:s,producingTransportId:this.serverId}),G=yield b(B);return{producerId:L,localId:G,rtpSender:P}}),"producer");return this.createProducerObject({id:h,localId:g,track:r,stopTracks:a,disableTrackOnPause:c,zeroRtpOnPause:d,appData:l,handler:this.handler,rtpSender:y})})}precreateProducers(e){return u(this,null,function*(){const n=[];for(const{kind:r,options:{encodings:i,codecOptions:s,track:a}}of e){const c=yield this.handler.send({track:a,encodings:i,codecOptions:s});n.push({kind:r,result:c})}return n})}createProducerObject(e){return u(this,null,function*(){const n=new IN(e);return this.producers.set(n.id,n),n.once("close",()=>{this.producers.delete(n.id)}),n})}closeProducer(e){return u(this,null,function*(){yield this.awaitQueue.push(e.close.bind(e),"producer")})}canConsume(){return u(this,null,function*(){if(this.closed)throw new Pt("closed");if(this.direction!=="recv")throw new Do("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 Cs("transport not connected");return!0})}consume(e,n,r){return u(this,null,function*(){const i=[];return this.awaitQueue.push(()=>u(this,null,function*(){const{consumerStates:s,sessionDescription:a}=yield n(e);return s.forEach((c,d)=>{i.push(this.createConsumerObjectAndWaitForTrack(K(V({},c),{producerId:d})))}),a&&(yield r(a)),jg(i)}),"consumer")})}setRemoteOffer(e){return u(this,null,function*(){yield this.setRemoteDescription(e);const n=yield this.handler.pc.createAnswer(),r=jh(n.sdp);return r.media=r.media.map(i=>{if(i.type==="audio"){const s=V({},i),a=s.fmtp.find(c=>c.payload===111);return a&&(a.config+=";stereo=1;sprop-stereo=1"),s.rtcpFb||(s.rtcpFb=[]),s.rtcpFb.some(c=>c.type==="nack")||s.rtcpFb.push({payload:parseInt(s.payloads,10),type:"nack"}),s}return i}),n.sdp=mf(r),yield this.setLocalDescription(n),n})}_ontrack(e){const{track:n,transceiver:r,streams:i}=e;p.info(`track event received [trackId: ${n.id}]`);let s;o(this,Xa)===rt.HIVE?s=`${i[0].id}:${n.kind}`:s=`${r.mid}:${n.kind}`,n.addEventListener("ended",()=>{p.info(`rtc consumer track ended [trackId: ${n.id}]`),this.unknownTracksMap.delete(s)});const a=this.consumerTrackEvents.get(s);a?(a(n,r),this.consumerTrackEvents.delete(s)):(p.warn(`track event handler not found ${s}`),this.unknownTracksMap.set(s,e))}sendErrorOverDC(e,n,r){const i=this.getDatachannel(e);if(!i)throw new Error("datachannel not found",{cause:{code:"DC_NOT_FOUND",values:{label:e}}});i.respond(n,r,!0)}sendResponseOverDC(e,n,r){const i=this.getDatachannel(e);if(!i)throw new Error("datachannel not found",{cause:{code:"DC_NOT_FOUND",values:{label:e}}});i.respond(n,r)}createConsumerObjectAndWaitForTrack(e){return u(this,null,function*(){const{consumerId:n,producerId:r,producingPeerId:i,producingTransportId:s,streamId:a,paused:c,screenShare:d,appData:l,kind:h,mimeType:g}=e,y=`${a}:${h}`,E=K(V({},e),{name:"consumer creation task error",message:"consumer creation failed"});return new Promise((b,P)=>u(this,null,function*(){const R=setTimeout(()=>{this.consumerTrackEvents.delete(y),E.isTimedout=!0,P(E)},5e3),B=(G,_)=>{try{if(G.readyState==="ended")clearTimeout(R),P(E);else{const Z=G;Z.enabled=!0,this.handler.midTransceiverMap.set(_.mid,_);const se=new _N({id:n,localId:_.mid,transceiver:_,track:Z,paused:c,producerId:r,producingPeerId:i,producingTransportId:s,handler:this.handler,appData:K(V({},l),{screenShare:d,peerId:i}),rtpReceiver:_.receiver,mimeType:g});this.consumers.set(n,se),se.once("close",()=>{this.consumers.delete(se.id),this.handler.midTransceiverMap.delete(_.mid)}),p.info("consumer created for ",{consumer:{id:n,kind:h,appData:{screenShare:d},peerId:i,producerId:r}}),this.observer.emit("newconsumer",se),clearTimeout(R),b(se)}}catch(Z){p.warn("error while creating consumer:",Z),clearTimeout(R),P(E)}},L=this.unknownTracksMap.get(y);L?(this.unknownTracksMap.delete(y),B(L.track,L.transceiver)):this.consumerTrackEvents.set(y,B)}))})}setRemoteDescription(e){return u(this,null,function*(){yield this.handler.pc.setRemoteDescription(e)})}setLocalDescription(e){return u(this,null,function*(){p.debug(`${this.direction}() {transportId: ${this.serverId}} | calling pc.setLocalDescription() [offer:${JSON.stringify(e)}]`),yield this.handler.pc.setLocalDescription(e)})}retryFailedConsumerCreationTasks(e){return u(this,null,function*(){return jg(e.map(n=>u(this,null,function*(){return fp(r=>u(this,null,function*(){return r>0&&p.warn(`retrying failed consumer creation task: ${JSON.stringify(n)}`),this.createConsumerObjectAndWaitForTrack(V({},n))}))})))})}sendDataChannelMessage(e,n){return u(this,null,function*(){const r=this.getDatachannel(e);if(!r)throw yN("DC_NOT_READY",`${e} datachannel not ready`);const i=(yield r.request(n)).payload;return p.info(`sendDataChannelMessage::response ${JSON.stringify(i)}`),i})}}Xa=new WeakMap;function RN(){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=rf.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 Hc;class MN{constructor(e,{handlerName:n,handlerFactory:r}={}){if(m(this,"handlerFactory"),f(this,Hc,void 0),p.debug("constructor()"),v(this,Hc,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=RN(),n)p.debug(`Device::constructor() | detected handler: ${n}`);else throw new Error("device not supported");switch(n){case"Chrome74":this.handlerFactory=yp.createFactory();break;case"Safari12":this.handlerFactory=Sp.createFactory();break;case"Firefox60":this.handlerFactory=Nd.createFactory({supportsSendEncodings:!1});break;case"Firefox110":this.handlerFactory=Nd.createFactory({supportsSendEncodings:!0});break;default:throw new TypeError(`unknown handlerName "${n}"`)}}}createTransport(e){const n=Vs();return new CN(o(this,Hc),K(V({id:n},e),{handlerFactory:this.handlerFactory}))}}Hc=new WeakMap;const AN=2e3;var Rr,go,xt,Vt,Rs,fo,Za,eo,ds,ki,to,vo,qc,Gc,ah,oh,Dy,ch,Oy,dh,Ny,lh,Ly,uh,Hg,Jc,lu,$c,uu;class DN extends mt.EventEmitter{constructor(e,n,r){switch(super(),f(this,vo),f(this,Gc),f(this,oh),f(this,ch),f(this,dh),f(this,lh),f(this,uh),f(this,Jc),f(this,$c),f(this,Rr,void 0),f(this,go,void 0),f(this,xt,void 0),f(this,Vt,void 0),f(this,Rs,void 0),f(this,fo,void 0),f(this,Za,void 0),f(this,eo,{transportFailureCount:{send:0,recv:0},lastConnectionTime:0}),f(this,ds,void 0),f(this,ki,"all"),f(this,to,void 0),v(this,Rr,e),v(this,Rs,n),v(this,to,r),v(this,go,new MN(r)),v(this,fo,new bN(n,r)),r){case rt.CF:{v(this,Za,Sn);break}case rt.HIVE:default:{v(this,Za,rn);break}}o(this,vo,qc).mediaState={send:{state:Fr.NEW,reconnected:!1},recv:{state:Fr.NEW,reconnected:!1}},X.hasFeature(ie.FORCE_RELAY)&&v(this,ki,"relay"),H(this,Gc,ah).call(this)}get socket(){return o(this,Rs)}get socketHandler(){return o(this,fo)}get sendTransport(){return o(this,xt)}get recvTransport(){return o(this,Vt)}get events(){return o(this,Za)}get nodeType(){return o(this,to)}createTransports(e){return u(this,null,function*(){var n,r,i,s,a,c,d,l;X.hasFeature(ie.FORCE_RELAY)&&(p.info("ICE Transport Policy set to relay"),v(this,ki,"relay"));const h=yield dt().getICEServers().catch(y=>(p.warn(`failed to get iceservers from server: ${y.message}`),[])),g=[];if(e.send){const y=X.hasFeature(ie.DISABLE_OPUS_DTX_CF),E=H(this,ch,Oy).call(this,{iceServers:h,additionalSettings:{encodedInsertableStreams:(n=o(this,Rr).getValue("modules").e2ee)==null?void 0:n.enabled},config:{enableHighBitrate:(s=(i=(r=o(this,Rr).getValue("defaults").mediaConfiguration)==null?void 0:r.audio)==null?void 0:i.enableHighBitrate)!=null?s:!1,enableStereo:(d=(c=(a=o(this,Rr).getValue("defaults").mediaConfiguration)==null?void 0:a.audio)==null?void 0:c.enableStereo)!=null?d:!1,enableDtx:o(this,to)===rt.HIVE?!0:!!y},iceTransportPolicy:o(this,ki)});g.push(E)}if(e.recv){const y=H(this,dh,Ny).call(this,{iceServers:h,additionalSettings:{encodedInsertableStreams:(l=o(this,Rr).getValue("modules").e2ee)==null?void 0:l.enabled},iceTransportPolicy:o(this,ki)});g.push(y)}yield Promise.all(g)})}stopTransports(e){var n,r,i,s;e.send&&((n=o(this,xt))==null||n.close(),(r=o(this,xt))==null||r.removeAllListeners(),v(this,xt,void 0)),e.recv&&((i=o(this,Vt))==null||i.close(),(s=o(this,Vt))==null||s.removeAllListeners(),v(this,Vt,void 0)),H(this,Gc,ah).call(this)}stopAllTransports(){p.info("Closing all transports"),this.stopTransports({send:!0,recv:!0})}connectTransportWithRetry(e,n){return u(this,null,function*(){const{id:r,serverId:i,direction:s}=e;H(this,lh,Ly).call(this,e);try{const a=X.hasFeature(ie.ENABLE_HIVE_INFINITE_RETRIES)?1/0:3;return yield fp((c,d)=>u(this,null,function*(){c>0&&p.debug(`Retrying transport connect, count: ${c}`,{transport:{id:r,serverId:i,type:s}});try{yield H(this,oh,Dy).call(this,e,n)}catch(l){if(l instanceof Cs){d(l);return}throw l}}),{delayTime:100,strategy:"exponential",maxRetryCount:a}),e}catch(a){throw p.error(`Failed to connect send transport after retry: ${e.id}`,{error:a,transport:{id:r,serverId:i,type:s}}),e.close(),e.removeAllListeners(),this.handleErrors("rejoin"),a}})}handleErrors(e){throw new Error("Method not implemented.")}}Rr=new WeakMap,go=new WeakMap,xt=new WeakMap,Vt=new WeakMap,Rs=new WeakMap,fo=new WeakMap,Za=new WeakMap,eo=new WeakMap,ds=new WeakMap,ki=new WeakMap,to=new WeakMap,vo=new WeakSet,qc=function(){return o(this,Rr).getValue("connectionHandler")},Gc=new WeakSet,ah=function(){v(this,ds,{send:void 0,recv:void 0})},oh=new WeakSet,Dy=function(t,e){return u(this,null,function*(){const{id:n,serverId:r,direction:i}=t;if(p.info(`Connecting ${i} transport`,{transport:{id:n,serverId:r,type:i}}),!o(this,Rs).isConnected)throw new Cs("Socket is not connected");if(t.connectionState==="closed")throw new Cs("Transport is closed");try{yield t.connect(s=>H(this,uh,Hg).call(this,i,s,e),e),p.info(`Connected ${i} transport`,{transport:{id:n,serverId:r,type:i}})}catch(s){throw o(this,eo).transportFailureCount[i]+=1,s.message==="ice connection failed"?new Cs(s.message):s}})},ch=new WeakSet,Oy=function(t){return u(this,null,function*(){var e,n;if(o(this,xt)&&o(this,xt).connected){p.info("Transport send 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:"send"}});return}v(this,xt,yield o(this,go).createTransport(K(V({},t),{direction:"send"}))),$.configureSendTransport(o(this,xt))})},dh=new WeakSet,Ny=function(t){return u(this,null,function*(){var e,n;if(o(this,Vt)&&o(this,Vt).connected){p.info("Transport recv is already connected",{transport:{id:(e=o(this,Vt))==null?void 0:e.id,serverId:(n=o(this,Vt))==null?void 0:n.serverId,type:"recv"}});return}v(this,Vt,yield o(this,go).createTransport(K(V({},t),{direction:"recv"}))),$.configureRecvTransport(o(this,Vt))})},lh=new WeakSet,Ly=function(t){const{direction:e,id:n}=t;t.on("connectionstatechange",r=>u(this,null,function*(){H(this,$c,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,ds)[e];s!==void 0&&(clearTimeout(s),o(this,ds)[e]=void 0)};switch(r){case"connected":i(),o(this,eo).lastConnectionTime=performance.now();break;case"disconnected":o(this,ds)[e]=setTimeout(()=>u(this,null,function*(){yield H(this,Jc,lu).call(this,t)}),AN);break;case"failed":if(t.closed)return;i(),yield H(this,Jc,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,Ay(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"))})},uh=new WeakSet,Hg=function(t,e,n){return u(this,null,function*(){const r=t==="recv";try{const{sdp:i,type:s}=e,a={consuming:r,description:{sdp:i,type:s,target:r?Ur.SUBSCRIBER:Ur.PUBLISHER},producers:[]};return!r&&n&&(a.producers=n),o(this,fo).connectTransport(a)}catch(i){throw p.error(`Error in ${t} transport connection:`,{error:i,country:S.location.country}),i}})},Jc=new WeakSet,lu=function(t){return u(this,null,function*(){t.close(),t.removeAllListeners();const{direction:e}=t;switch(X.hasFeature(ie.HIVE_TRANSPORT_FORCE_RELAY_ON_ICE_FAILED)&&o(this,Rs).isConnected&&o(this,eo).transportFailureCount[e]>2&&(p.warn(`Multiple disconnections in ${e} transport, forcing relay`),v(this,ki,"relay")),yield this.createTransports({[e]:!0}),e){case"send":{yield this.connectTransportWithRetry(o(this,xt)),p.info("Transport reconnected",{transport:o(this,xt)}),M.emit(A.RESET_PRODUCER_STATE);break}case"recv":{yield this.connectTransportWithRetry(o(this,Vt)),p.info("Transport reconnected",{transport:o(this,Vt)}),M.emit(A.UPDATE_ACTIVE,{createAllConsumers:!0});break}default:p.warn("Unknown transport direction",{transport:t})}H(this,$c,uu).call(this,{state:Fr.CONNECTED,direction:e})})},$c=new WeakSet,uu=function(t){const{state:e,direction:n}=t;o(this,vo,qc).mediaState[n]={state:e,reconnected:!0},M.emit(A.TRANSPORT_STATE_UPDATE,V({transport:n},o(this,vo,qc).mediaState[n]))};var hh,xy;class ON{constructor(e){f(this,hh),this.recvTransport=e,H(this,hh,xy).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}})}}hh=new WeakSet,xy=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,Ay(e),t);break}default:break}}catch{p.error(`Unable to handle the incoming datachannel message on channel ${t}`)}}))};class NN{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(c=>{const{producingPeerId:d,producerId:l,producingTransportId:h}=c;n.set(l,d),r.push({producingPeerId:d,producerId:l,producingTransportId:h})});const i=yield this.socketHandler.consume({requests:r,consumingTransportId:this.recvTransport.serverId}),s=new Map;e.forEach(c=>s.set(c.producerId,c));const a=new Map;return Object.entries(i.consumerStateMap).forEach(([c,d])=>{const l=s.get(c);if(!l)return;let h={};try{h=JSON.parse(d.producerState.appData)}catch{}a.set(c,{consumerId:d.consumerId,producingTransportId:l.producingTransportId,producingPeerId:l.producingPeerId,kind:l.kind,paused:l.pause,streamId:d.producerTrack.streamId,trackId:d.producerTrack.trackId,screenShare:l.screenShare,mimeType:l.mimeType,appData:h})}),{consumerStates:a,sessionDescription:i.sessionDescription}})}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:Ur.SUBSCRIBER}};return p.debug(`sending renegotiate request: ${JSON.stringify(r)} on recvTransport`,{transport:this.recvTransport}),yield this.socket.sendMessagePromise(this.events.renegotiateSessionDescription,dP.toBinary(r)),p.info("renegotiation done",{transport:this.recvTransport}),n})}close(e){return u(this,null,function*(){if(!e.length)return{};const n=e.map(i=>i.localId);p.info(`Closing consumers: ${JSON.stringify(n)}`);const r={consumerIds:n};return yield(()=>u(this,null,function*(){var i;return(i=this.recvTransport)==null?void 0:i.awaitQueue.push(()=>u(this,null,function*(){yield this.socketHandler.closeConsumer(r)}),"close_consumer").catch(s=>{p.warn("error on closing consumer:",{error:s})})}))(),{}})}}class Ld{constructor(e){this.socketHandler=e}static getMSIDFromSDP(e,n){return jh(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=Ld.getMSIDFromSDP(n.sdp,r),g={description:{sdp:n.sdp,type:n.type,target:Ur.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(g);return{answer:y,producerId:E}})}}const LN=3;var yo,bs,_i,So,Kc,Zn,xd,ph,Vy,mh,Uy,gh,Fy,fh,By,Vd,vh,Ud,yh,Sh,Wy;class xN extends DN{constructor(e,n,r){super(e,n,r),f(this,ph),f(this,mh),f(this,gh),f(this,fh),f(this,Vd),f(this,Ud),f(this,Sh),f(this,yo,void 0),f(this,bs,void 0),f(this,_i,void 0),f(this,So,void 0),f(this,Kc,void 0),f(this,Zn,void 0),f(this,xd,{producerCreationFailureCount:0,consumerCreationFailureCount:0,producerNotReadyFailureCount:0}),v(this,yo,e),o(this,ph,Vy).mediaState={send:{state:Fr.NEW,reconnected:!1},recv:{state:Fr.NEW,reconnected:!1}},this.reset()}get socketHandler(){return super.socketHandler}get producers(){return o(this,bs)}get consumers(){return o(this,_i)}get producerIdToConsumerIdMap(){return o(this,So)}reset(){v(this,bs,new Map),v(this,_i,new Map),v(this,So,new Map)}setupTransports(e,n){return u(this,null,function*(){yield this.createTransports(e);let r,i;e.send&&(r=H(this,mh,Uy).call(this,n)),e.recv&&(i=H(this,gh,Fy).call(this));const[s]=yield Promise.all([r,i]);return s})}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,fh,By).bind(this));return(r=e.appData)!=null&&r.e2ee&&M.emit(A.E2EE_ACTIVE_PRODUCER,i),H(this,Vd,vh).call(this,i,n),i}catch(i){throw p.error("Failed to create producer",{error:i}),o(this,xd).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,yo).getValue("modules").e2ee)!=null&&r.enabled&&M.emit(A.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,bs).entries()).map(([,e])=>e.close()))}createConsumer(e){return this.createConsumers([e])}createConsumers(e){return u(this,null,function*(){if(!this.recvTransport||this.recvTransport.closed)throw new Error("Recv transport is closed");try{const n=e.filter(({producerId:r})=>!this.producers.get(r));(yield this.recvTransport.consume(n,H(this,Ud,yh).bind(this),o(this,Zn).negotiate.bind(o(this,Zn)))).forEach(r=>{r.status!=="rejected"&&H(this,Sh,Wy).call(this,r.value)})}catch{}})}closeConsumer(e){return this.closeConsumers([e])}closeConsumers(e){return u(this,null,function*(){if(!o(this,Zn))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,Zn).close(n);r!=null&&r.length&&p.warn("Failed to close some consumers",{consumerIds:r})})}closeAllConsumers(){return this.closeConsumers(Array.from(o(this,_i).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})})}}yo=new WeakMap,bs=new WeakMap,_i=new WeakMap,So=new WeakMap,Kc=new WeakMap,Zn=new WeakMap,xd=new WeakMap,ph=new WeakSet,Vy=function(){return o(this,yo).getValue("connectionHandler")},mh=new WeakSet,Uy=function(t){return u(this,null,function*(){v(this,Kc,new Ld(this.socketHandler));const e=[];return t&&(yield this.sendTransport.precreateProducers(t)).forEach((n,r)=>u(this,[n,r],function*({kind:i,result:s},a){var c;const{codecOptions:d}=t[a].options,l=d[0]?`${i}/${(c=d[0])==null?void 0:c.name}`:void 0;e.push({kind:i,msid:Ld.getMSIDFromSDP(s.offerSdp.sdp,i),mid:s.mid,paused:!0,mimeType:l,appData:JSON.stringify({mid:s.mid}),screenShare:!1,track:t[a].options.track})})),yield this.connectTransportWithRetry(this.sendTransport,e),this.sendTransport.producers.size?e.map(({mid:n},r)=>{const[,i]=Array.from(this.sendTransport.producers.entries()).find(([,s])=>s.localId===n);return H(this,Vd,vh).call(this,i,t[r].onClose),i}):[]})},gh=new WeakSet,Fy=function(){return u(this,null,function*(){switch(this.recvTransport.on("connect",()=>{o(this,So).clear()}),yield this.connectTransportWithRetry(this.recvTransport),this.nodeType){case rt.CF:{v(this,Zn,new NN(this.events,this.recvTransport,this.socket,this.socketHandler));break}case rt.HIVE:default:v(this,Zn,new ON(this.recvTransport))}})},fh=new WeakSet,By=function(t){return o(this,Kc).create(t)},Vd=new WeakSet,vh=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:K(V({},t),{status:"closing"})});const c={producerId:t.id,description:{sdp:i.sdp,type:i.type,target:Ur.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:K(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:K(V({},t),{status:"UNKNOWN"})})}),o(this,bs).set(t.id,t)},Ud=new WeakSet,yh=function(t,e=0){return u(this,null,function*(){try{return yield this.recvTransport.canConsume(),yield o(this,Zn).create(t)}catch(n){if(n instanceof SN&&(o(this,xd).consumerCreationFailureCount+=1),e<=LN)return p.error(`Error in consume request attempt:${e}`,{error:n}),H(this,Ud,yh).call(this,t,e+1);throw p.error("Error in consume request",{error:n}),n}})},Sh=new WeakSet,Wy=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,_i).delete(t.id),M.emit(A.CONSUMER_CLOSED,{id:t.id})})),o(this,_i).set(t.id,t),this.producerIdToConsumerIdMap.set(t.producerId,t.id),M.emit(A.NEW_CONSUMER,{id:t.id,appData:t.appData,peerId:t.peerId})};var zc,Yc,Qc,no,Eo,To,Fd,Bd,ws,Jt,Ln,An,ci,di,Mr,Wd,Eh,jy,Th,Hy,kh,qy,bh,Gy;const wh=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,Eh),f(this,Th),f(this,zc,void 0),f(this,Yc,void 0),f(this,Qc,void 0),f(this,no,void 0),f(this,Eo,void 0),f(this,To,void 0),f(this,Fd,void 0),f(this,Bd,void 0),f(this,ws,void 0),f(this,Jt,void 0),f(this,Ln,void 0),f(this,An,!1),f(this,ci,0),f(this,di,0),f(this,Mr,[]),f(this,Wd,void 0),v(this,no,t),v(this,Jt,t),v(this,zc,e),v(this,Yc,n),v(this,Qc,r),v(this,Eo,i),v(this,To,s),v(this,Fd,a),v(this,Bd,c),v(this,ws,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=wh,kh,qy).call(e,t),i=H(n=wh,bh,Gy).call(n,t);return H(this,Eh,jy).call(this,r),r/o(this,Ln)>o(this,ws)&&r>o(this,Jt)&&i>o(this,zc)?(v(this,ci,o(this,ci)+1),v(this,di,o(this,Qc)),o(this,ci)>=o(this,Yc)&&v(this,An,!0)):(v(this,ci,0),o(this,di)>0?v(this,di,o(this,di)-1):o(this,An)&&v(this,An,!1),o(this,An)||H(this,Th,Hy).call(this,r)),o(this,An)}reset(){v(this,An,!1),v(this,ci,0),v(this,di,0),v(this,Jt,o(this,no)),v(this,Ln,o(this,no)/2),v(this,Mr,[])}getThresholdInfo(){return{currentEnergyThreshold:o(this,Jt),backgroundNoiseEnergy:o(this,Ln),energyRatioThreshold:o(this,ws)}}};let _h=wh;zc=new WeakMap,Yc=new WeakMap,Qc=new WeakMap,no=new WeakMap,Eo=new WeakMap,To=new WeakMap,Fd=new WeakMap,Bd=new WeakMap,ws=new WeakMap,Jt=new WeakMap,Ln=new WeakMap,An=new WeakMap,ci=new WeakMap,di=new WeakMap,Mr=new WeakMap,Wd=new WeakMap,Eh=new WeakSet,jy=function(t){o(this,An)?v(this,Jt,o(this,To)*o(this,Jt)+(1-o(this,To))*t):v(this,Jt,o(this,Eo)*o(this,Jt)+(1-o(this,Eo))*(o(this,Ln)*o(this,ws))),v(this,Jt,Math.max(o(this,Fd),Math.min(o(this,Bd),o(this,Jt))))},Th=new WeakSet,Hy=function(t){if(t<o(this,Jt)*1.2)if(o(this,Mr).push(t),o(this,Mr).length>o(this,Wd)&&o(this,Mr).shift(),o(this,Mr).length>=10){const e=[...o(this,Mr)].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)},kh=new WeakSet,qy=function(t){return Math.sqrt(t.map(e=>e*e).reduce((e,n)=>e+n)/t.length)},bh=new WeakSet,Gy=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(_h,kh),f(_h,bh);const VN=60,UN=400;var li,ui,Ms,ro,Ii,io,ko,jd,hi,ls,bo,Ih,Jy,Xc,Ph,Ch,$y,hu,qg,pu,Gg;const wo=class{constructor(t){f(this,Ih),f(this,Ch),f(this,li,void 0),f(this,ui,void 0),f(this,Ms,void 0),f(this,ro,void 0),f(this,Ii,void 0),f(this,io,void 0),f(this,ko,void 0),f(this,jd,void 0),f(this,hi,void 0),f(this,ls,void 0),f(this,bo,void 0),this.reportRequest=t,v(this,ro,new AudioContext),v(this,Ii,o(this,ro).createAnalyser()),o(this,Ii).fftSize=2048,v(this,jd,new _h)}set producerId(t){v(this,Ms,t)}set audioTrack(t){v(this,io,t);const e=new MediaStream;e.addTrack(o(this,io)),o(this,ro).createMediaStreamSource(e).connect(o(this,Ii))}start(){o(this,li)&&Es(o(this,li)),v(this,li,gd(()=>u(this,null,function*(){var t;if(!o(this,io)||!o(this,Ms))return;const{energy:e}=H(this,Ih,Jy).call(this),n=H(t=wo,Xc,Ph).call(t,e);let r=.9;o(this,bo)!==n&&o(this,bo)?r=.9:n?r=.3:r=.5,v(this,ko,(o(this,ko)||0)*(1-r)+e*r)}),VN)),o(this,ui)&&Es(o(this,ui)),v(this,ui,gd(H(this,Ch,$y).bind(this),UN))}stop(){o(this,li)&&Es(o(this,li)),o(this,ui)&&Es(o(this,ui))}};let Zc=wo;li=new WeakMap,ui=new WeakMap,Ms=new WeakMap,ro=new WeakMap,Ii=new WeakMap,io=new WeakMap,ko=new WeakMap,jd=new WeakMap,hi=new WeakMap,ls=new WeakMap,bo=new WeakMap,Ih=new WeakSet,Jy=function(){var t,e;const n=new Float32Array(o(this,Ii).frequencyBinCount);o(this,Ii).getFloatTimeDomainData(n);const r=o(this,jd).processAudioChunk(n),i=H(t=wo,hu,qg).call(t,n),s=H(e=wo,pu,Gg).call(e,i);return(!o(this,hi)||s<o(this,hi))&&v(this,hi,s),(!o(this,ls)||s>o(this,ls))&&v(this,ls,s),{energy:(s-o(this,hi))/(o(this,ls)-o(this,hi))*10||0,isVoice:r}},Xc=new WeakSet,Ph=function(t){return t<5},Ch=new WeakSet,$y=function(t=o(this,ko)){var e;if(!o(this,Ms)||!t)return;const n={producerId:o(this,Ms),energy:Math.round(t),silent:H(e=wo,Xc,Ph).call(e,t)};v(this,bo,n.silent),this.reportRequest(n)},hu=new WeakSet,qg=function(t){return Math.sqrt(t.reduce((e,n)=>e+n*n,0)/t.length)},pu=new WeakSet,Gg=function(t){const e=Math.log10(t);return Math.round(e)},f(Zc,Xc),f(Zc,hu),f(Zc,pu);const FN=()=>{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]},BN=()=>{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 WN=Object.defineProperty,jN=Object.getOwnPropertyDescriptor,he=(t,e,n,r)=>{for(var i=r>1?void 0:r?jN(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&&WN(e,n,i),i};const Pn=["video/VP9","video/VP8"];var ed,td,bt,J,so,pi,Nt,us,hs,mi,nd,wr,ao,ps,ms,Lt,tn,gi,gs,ht,wt,fs,oo,rd,Rh,id,Mh;class ue{constructor(e,n,r){f(this,gi),f(this,ht),f(this,fs),f(this,rd),f(this,id),m(this,"context"),m(this,"authToken"),m(this,"e2ee"),f(this,ed,void 0),f(this,td,void 0),f(this,bt,void 0),f(this,J,void 0),f(this,so,void 0),f(this,pi,void 0),f(this,Nt,void 0),f(this,us,void 0),f(this,hs,void 0),f(this,mi,void 0),f(this,nd,void 0),f(this,wr,void 0),m(this,"maxPreferredStreams"),f(this,ao,void 0),f(this,ps,void 0),f(this,ms,void 0),f(this,Lt,void 0),f(this,tn,void 0),m(this,"partialJoinRoomPromise");var i,s;this.context=e;const{socket:a}=r;this.mediaJoined=!1,v(this,ps,new Map([["video/VP9",new Set],["video/VP8",new Set]])),v(this,ms,new Map([["video/VP9",new Set],["video/VP8",new Set]])),v(this,pi,n),v(this,bt,a),v(this,us,!1),v(this,J,new xN(e,a,n)),v(this,Nt,o(this,J).events),this.maxPreferredStreams=6,v(this,wr,new Set),v(this,Lt,new Map),v(this,hs,!1),v(this,mi,new Od),n===rt.CF&&v(this,tn,new Zc(o(this,J).socketHandler.audioActivity.bind(o(this,J).socketHandler))),this.e2ee=(s=(i=e.getValue("modules").e2ee)==null?void 0:i.enabled)!=null?s:!1,this.handleSocketEvents(),this.handleCallstatsEvents(),v(this,nd,_d(()=>u(this,null,function*(){if(!o(this,gi,gs).mediaJoinAttempted)return;const{roomJoined:c}=yield this.joinRoom(o(this,td),o(this,ed),{},!0,!0);c&&(M.emit(A.RESET_PRODUCER_STATE),M.emit(A.ROOM_NODE_RECONNECTED))}),5e3,{leading:!0,maxWait:1e3}))}get peerId(){return this.context.getValue("peerId")}get mediaJoined(){return o(this,gi,gs).mediaJoined}set mediaJoined(e){o(this,gi,gs).mediaJoined=e}reset(e=!0){o(this,J).closeAllProducers(),o(this,J).closeAllConsumers(),o(this,wr).clear(),e&&(this.partialJoinRoomPromise=void 0,o(this,mi).stop(),o(this,J).stopAllTransports(),o(this,J).reset(),v(this,mi,new Od))}joinRoom(e,n){return u(this,arguments,function*(r,i,s={},a=!1,c=!1){o(this,gi,gs).mediaJoinAttempted=!0,v(this,us,!0),this.reset(a);const d=dt().ipInfo;if(d!=null&&d.loc&&!o(this,ao)){const h=d.loc.split(",");v(this,ao,{latitude:parseFloat(h[0]),longitude:parseFloat(h[1])})}let l;try{return l=yield o(this,mi).push(()=>this._joinRoom(r,i,s,c,o(this,ao)),"joinRoom"),l}catch{l={roomJoined:!1}}return l.roomJoined||M.emit(A.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[E,b]=a.loc.split(",").map(parseFloat);c={latitude:E,longitude:b}}const d=(s=X.getValue(ie.FORCE_VIDEO_CODEC))==null?void 0:s.toString(),l=kN(d);v(this,so,l),this.maxPreferredStreams=this.context.getValue("maxPreferredStreams"),yield fp((E,b)=>u(this,null,function*(){if(!o(this,bt).isConnected){b(new Error("socket is not connected"));return}E>0&&p.warn(`retrying sending join room request, count: ${E}`);try{yield o(this,J).socketHandler.joinRoom(n,e,l,r,c)}catch(P){throw p.error("failed to send join room request, error:",{error:P}),P}}),{delayTime:1e3,strategy:"exponential",maxRetryCount:X.hasFeature(ie.ENABLE_HIVE_INFINITE_RETRIES)?1/0:3});const h="video/VP8",g=o(this,pi)!==rt.HIVE&&X.hasFeature(ie.PRECREATE_PRODUCERS)?[{type:ge.MIC,kind:"audio",options:H(this,rd,Rh).call(this,FN()),onClose:()=>this.disableMic()},{type:ge.WEBCAM,kind:"video",options:H(this,id,Mh).call(this,BN(),h),onClose:()=>{this.disableWebcam(h)}}]:[],y=yield o(this,J).setupTransports({send:!0,recv:!0},g);y!=null&&y.length&&g.forEach((E,b)=>{o(this,Lt).set(E.type,Promise.resolve(y[b].id))})})}partialJoinRoom(e,n,r=!1,i=void 0){return u(this,null,function*(){return this.partialJoinRoomPromise=o(this,mi).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,td,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:K(V({},Ce.getDeviceInfo()),{userAgent:navigator.userAgent,memory:navigator.deviceMemory,cpus:navigator.hardwareConcurrency}),sdkName:this.context.getValue("sdkName"),sdkVersion:this.context.getValue("sdkVersion"),metaData:{},permissions:{}};$.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,J).socketHandler.notifySelfJoinComplete();return v(this,ed,n.roomUuid),v(this,hs,!0),v(this,us,!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,J).stopAllTransports(),v(this,hs,!1),o(this,gi,gs).mediaJoinAttempted=!1;const e={closeRoom:!1};o(this,bt).sendMessagePromise(o(this,Nt).leaveRoom,OP.toBinary(e)).then(n=>{var r;(r=yC.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})}),$.callEnded(),S.destruct()})}getConsumers(){return o(this,J).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,J).producerIdToConsumerIdMap.get(s.producerId);if(!a){p.warn(`consumer not found in deactivate producers: ${s.producerId}`);return}return o(this,J).closeConsumer(a)}))})}createConsumers(e){return u(this,null,function*(){return e.length===0?Promise.resolve():o(this,J).createConsumers(e)})}closeConsumers(e){return u(this,null,function*(){if(!e.length)return;const n=e.reduce((r,i)=>{const s=o(this,J).producerIdToConsumerIdMap.get(i.producerId);return s?(r.push(s),r):(p.warn(`consumer not found in deactivate producers: ${i.producerId}`),r)},[]);yield o(this,J).closeConsumers(n)})}_shareWebcam(e,n){return u(this,null,function*(){const r=n==="video/VP9"?ge.WEBCAM:ge.WEBCAM_BACKUP,i=H(this,ht,wt).call(this,r);if(i){const h=yield i;if(o(this,J).producers.has(h)){const g=o(this,J).producers.get(h);if(!g.closed&&!navigator.isReactNative)return yield g.replaceTrack({track:e}),yield this.resumeWebcam(r),e;yield this.disableWebcam(n)}return this._shareWebcam(e,n)}const s=H(this,id,Mh).call(this,e,n),a=Pd(this.context,"disableSimulcast"),c=o(this,pi)===rt.CF?ie.ENABLE_CF_SIMULCAST:ie.ENABLE_HIVE_SIMULCAST;!a&&X.hasFeature(c)?(p.info(`Simulcast enabled for SFU: ${o(this,pi)}`),s.encodings=vO(e)):p.info(`Simulcast disabled for webcam producer, SFU: ${o(this,pi)}`),X.hasFeature(ie.TRACK_HINT)&&(s.track.contentHint=X.getValue(ie.TRACK_HINT));const d=()=>{p.info("Disabling video due to the producer closure"),o(this,Lt).delete(r)},l=o(this,J).createProducer(s,d);return H(this,fs,oo).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(X.hasFeature(ie.FORCE_VIDEO_CODEC)){const n=X.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,so).sender)==null?void 0:r.video)==null?void 0:i.codecs.findIndex(s=>s.mimeType===n))>=0&&o(this,ms).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,Lt).delete(ge.SCREENSHARE_VIDEO),o(this,Lt).delete(ge.SCREENSHARE_AUDIO)},a=o(this,J).createProducer(i,s);H(this,fs,oo).call(this,ge.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,J).createProducer(d,l),H(this,fs,oo).call(this,ge.SCREENSHARE_AUDIO,c.then(h=>h.id))}yield Promise.all([a,c||Promise.resolve()]),$.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,ge.MIC);if(n){const a=yield n;if(o(this,J).producers.has(a)){const c=o(this,J).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,J).closeProducer(a,{stopTrack:!1})}yield this.shareMic(e);return}const r=H(this,rd,Rh).call(this,e),i=()=>{o(this,Lt).delete(ge.MIC)},s=o(this,J).createProducer(r,i);H(this,fs,oo).call(this,ge.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 I(n)}})}pauseMic(){return u(this,null,function*(){const e=yield H(this,ht,wt).call(this,ge.MIC),n=o(this,J).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,ec.toBinary(r))})}pauseWebcam(){return u(this,null,function*(){const e=yield H(this,ht,wt).call(this,ge.WEBCAM),n=yield H(this,ht,wt).call(this,ge.WEBCAM_BACKUP),r=o(this,J).producers.get(e),i=o(this,J).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,ec.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,ge.MIC),n=o(this,J).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&&M.emit(A.E2EE_ACTIVE_PRODUCER,n);const r={producerId:n.id,pause:!1};o(this,bt).sendMessage(o(this,Nt).toggleProducer,ec.toBinary(r))})}resumeWebcam(){return u(this,arguments,function*(e=ge.WEBCAM){const n=yield H(this,ht,wt).call(this,e),r=o(this,J).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&&M.emit(A.E2EE_ACTIVE_PRODUCER,r);const i={producerId:r.id,pause:!1};o(this,bt).sendMessage(o(this,Nt).toggleProducer,ec.toBinary(i))})}disableWebcam(e){return u(this,null,function*(){const n=e==="video/VP9"?ge.WEBCAM:ge.WEBCAM_BACKUP,r=yield H(this,ht,wt).call(this,n);r&&(yield o(this,J).closeProducer(r)),o(this,Lt).delete(n)})}disableMic(){return u(this,null,function*(){var e;const n=yield H(this,ht,wt).call(this,ge.MIC);n&&(yield o(this,J).closeProducer(n)),(e=o(this,tn))==null||e.stop(),o(this,Lt).delete(ge.MIC)})}disableScreenShare(){return u(this,null,function*(){p.info("screen_sharing_stopped"),$.screenShareStop();const e=yield H(this,ht,wt).call(this,ge.SCREENSHARE_VIDEO),n=yield H(this,ht,wt).call(this,ge.SCREENSHARE_AUDIO);e&&(yield o(this,J).closeProducer(e)),n&&(yield o(this,J).closeProducer(n)),o(this,wr).clear(),o(this,Lt).delete(ge.SCREENSHARE_VIDEO),o(this,Lt).delete(ge.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,ge.WEBCAM),i=yield H(this,ht,wt).call(this,ge.WEBCAM_BACKUP);yield o(this,J).closeProducer(r,{stopTrack:!1}),yield o(this,J).closeProducer(i,{stopTrack:!1}),this.shareWebcam(e)}if(n){const r=yield H(this,ht,wt).call(this,ge.SCREENSHARE_VIDEO);yield o(this,J).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,J).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,J).socketHandler.kickPeer(n)))throw new Error("failed to kickout the participant!")})}kickAll(){return u(this,null,function*(){if(!(yield o(this,J).socketHandler.kickAll()))throw new Error("failed to kickout all participant!")})}muteAll(e){return u(this,null,function*(){if(!(yield o(this,J).socketHandler.hostControlForAll("audio")))throw new Error("failed to mute all participant")})}muteAllVideo(){return u(this,null,function*(){if(!(yield o(this,J).socketHandler.hostControlForAll("video")))throw new Error("failed to mute all video participant")})}disableAudio(e){return u(this,null,function*(){if(!(yield o(this,J).socketHandler.hostControlForPeer(e,"audio")))throw new Error("failed to mute given participant")})}disableVideo(e){return u(this,null,function*(){if(!(yield o(this,J).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,HP.toBinary(n))}catch(r){p.error("Error in pinning peer:",{error:r})}})}validateScreenShare(e){return this.peerId===e.peerId&&o(this,J).producers.get(e.producerId)&&o(this,wr).add(e.consumerPeerId),o(this,wr).size}switchConsumersToLayer(e,n){return u(this,null,function*(){o(this,J).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}=zC.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,so).receiver)==null?void 0:n.video)==null?void 0:r.codecs.findIndex(a=>a.mimeType===Pn[0]))>=0&&o(this,ps).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}`),M.emit(A.NEW_PRODUCER,{peerId:i,producer:K(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}}=Zm.fromBinary(e),c=i===xn.AUDIO?"audio":"video";if(p.info(`producer toggle broadcast: ${n}, producerId: ${a}, kind:${c}, paused:${s} payload: ${JSON.stringify(Zm.fromBinary(e))}`),n===this.peerId&&r!==this.peerId&&s&&M.emit(c==="audio"?A.MUTE_SELF:A.MUTE_SELF_VIDEO),n===this.peerId)return;M.emit(A.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(),M.emit(A.CONSUMER_PAUSED,{id:d.id})):(d.resume(),M.emit(A.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}=Vu.fromBinary(e);if(n===this.peerId)return;p.info(`peer left broadcast:${n}`),o(this,wr).delete(n),o(this,J).consumers.forEach(r=>{r.peerId===n&&r.close()}),M.emit(A.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}}=XC.fromBinary(e);if(n===this.peerId)return;p.info(`producer closed broadcast:${n}`),M.emit(A.PRODUCER_CLOSED,{peerId:n,producerId:r});const i=o(this,J).producerIdToConsumerIdMap.get(r);if(!i){p.warn(`no consumer found for producer:${r}`);return}p.info(`closing consumer ${i}, producer id: ${r}`),o(this,J).closeConsumer(i).then(()=>{p.info(`closed consumer: ${i}`),o(this,J).producerIdToConsumerIdMap.delete(r),M.emit(A.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,us)&&!o(this,hs)||(p.warn("media hub termination broadcast received, rejoining room"),M.emit(A.ROOM_NODE_DISCONNECTED),o(this,nd).call(this))})})}handleCallstatsEvents(){$.onConsumerScore(e=>{e.forEach((n,r)=>{const i=o(this,J).consumers.get(r);i&&M.emit(A.CONSUMER_SCORE_UPDATE,{id:r,kind:i.kind,peerId:i.peerId,score:n.score,scoreStats:n})})}),$.onProducerScore(e=>{e.forEach((n,r)=>{const i=Array.from(o(this,J).producers.values()).find(s=>s.id===r);i&&M.emit(A.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,ms).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,ps).get(d).add(e);break}}}handlePeerLeaving(e){X.hasFeature(ie.FORCE_VIDEO_CODEC)||(o(this,ps).forEach(n=>n.delete(e)),o(this,ms).forEach((n,r)=>{n.delete(e),n.size===0&&this.disableWebcam(r)}))}}ed=new WeakMap,td=new WeakMap,bt=new WeakMap,J=new WeakMap,so=new WeakMap,pi=new WeakMap,Nt=new WeakMap,us=new WeakMap,hs=new WeakMap,mi=new WeakMap,nd=new WeakMap,wr=new WeakMap,ao=new WeakMap,ps=new WeakMap,ms=new WeakMap,Lt=new WeakMap,tn=new WeakMap,gi=new WeakSet,gs=function(){return this.context.getValue("connectionHandler")},ht=new WeakSet,wt=function(t){return o(this,Lt).get(t)},fs=new WeakSet,oo=function(t,e){return o(this,Lt).set(t,e)},rd=new WeakSet,Rh=function(t){return{track:t,encodings:[{priority:"high"}],codecOptions:[{name:"opus"}],appData:{e2ee:this.e2ee},stopTracks:!1,zeroRtpOnPause:!0}},id=new WeakSet,Mh=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 Ky(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 zy(t){const e=t.getValue("roomNodeClient");try{e==null||e.leaveRoom()}catch{p.error("roomNodeClient::cleanupRoomNodeClient")}t.setValue("roomNodeClient",void 0)}var HN=Object.defineProperty,qN=Object.getOwnPropertyDescriptor,Wi=(t,e,n,r)=>{for(var i=r>1?void 0:r?qN(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&&HN(e,n,i),i},Qr,Cn,St,Zt,dn,Jg;const Yy=(Jg=class{constructor(t,e,n,r){f(this,Zt),m(this,"self"),m(this,"authToken"),f(this,Qr,void 0),m(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,Qr,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=!X.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)}),$.devices("AUDIO",h==null?void 0:h.filter(g=>g.kind==="audioinput")),$.devices("VIDEO",h==null?void 0:h.filter(g=>g.kind==="videoinput")),$.devices("SPEAKER",h==null?void 0:h.filter(g=>g.kind==="audiooutput")),p.info("Callstats:: initializing");try{yield $.initialize({peerId:a,engineName:Ce.getDeviceInfo().engineName,env:t.getValue("env"),iceServers:yield s.getICEServers(),apiBase:t.getValue("apiBase"),flags:X.getAllFlags(),logger:p,apiHostnames:qv(t),skipConnectivityChecks:l}),p.info("Callstats:: initialized")}catch(g){p.error("Callstats:: initialization failed",{error:g})}}),0)}else p.info("Callstats:: Skipped initialization due to navigator product being ReactNative.");return new Yy(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&&X.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*(){$.callEnded(),o(this,Zt,dn).reset(),t&&(yield this.joinRoom(t))})}setupEvents(){M.on(A.RESET_PRODUCER_STATE,()=>u(this,null,function*(){this.mediaJoined&&this.shareMediaTracks()})),M.on(A.ROOM_NODE_RECONNECTED,()=>{this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:!0})}),M.on(A.ROOM_NODE_DISCONNECTED,()=>{this.self.roomState!=="disconnected"&&(this.self.roomState="disconnected",this.self.emit("roomLeft",{state:"disconnected"}))}),M.on(A.ROOM_NODE_FAILED,()=>{this.self.roomState="failed",this.self.emit("roomLeft",{state:"failed"})}),M.on(A.SOCKET_SERVICE_RECONNECTED,({wasJoinAttempted:t})=>{t===!1&&(this.self.roomState="init"),this.resetSelf(t)}),M.on(A.SOCKET_SERVICE_DISCONNECTED,({joinAttempted:t})=>{if(this.self.roomState==="disconnected")return;let{peerId:e}=this;t&&X.hasFeature(ie.REFRESH_ID_ON_DISCONNECTION)&&(e=Vs()),o(this,Qr).updateURL(e),S.resetPeerId(e),dt().setHeader("dyte-tracing-id",e),Pi.remapContext(e,o(this,St)),this.self.roomState="disconnected",this.self.emit("roomLeft",{state:"disconnected"})}),M.on(A.SOCKET_SERVICE_FAILED,()=>{this.self.roomState="failed",this.self.emit("roomLeft",{state:"failed"})}),o(this,Cn).on(W.waitingRoomRequestAccepted,()=>{this.waitlistAcceptHandler()}),o(this,Cn).on(Ac.updateUserPreset,t=>{t.updatePeersPresets.forEach(e=>{e.userIds===this.self.userId&&M.emit(A.UPDATE_PERMISSIONS,e.patch)})}),o(this,Cn).on(W.waitingRoomRequestDenied,()=>{this.waitlistRejectedHandler()}),o(this,Cn).on(W.kick,()=>{this.kickHandler({kickType:"kick"})}),o(this,Cn).on(W.kickAll,()=>{this.kickHandler({kickType:"kickAll"})}),M.onAsync(A.JOIN_MEDIA_ROOM,this.joinMediaRoom.bind(this)),M.on(A.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})}),M.on(A.MUTE_SELF,()=>u(this,null,function*(){this.self.audioEnabled&&(yield this.self.disableAudio(),$.audioOff())})),M.on(A.MUTE_SELF_VIDEO,()=>u(this,null,function*(){this.self.videoEnabled&&(yield this.self.disableVideo(),$.videoOff())})),M.onAsync(A.LEAVE_MEDIA_ROOM,this.leaveMediaRoom.bind(this)),M.on(A.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=dp(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,Qr))==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,Qr))==null||n.disconnect()}catch{p.error("SelfController::leaveRoom::socketDisconnect")}zy(o(this,St)),Dd.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}Ky(o(this,St),d,{socket:o(this,Qr),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 I("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()})}},Qr=new WeakMap,Cn=new WeakMap,St=new WeakMap,Zt=new WeakSet,dn=function(){return o(this,St).getValue("roomNodeClient")},Jg);let qr=Yy;Wi([S.trace("SelfController.resetSelf")],qr.prototype,"resetSelf",1);Wi([S.trace("SelfController.setupEvents")],qr.prototype,"setupEvents",1);Wi([S.trace("SelfController.joinRoom")],qr.prototype,"joinRoom",1);Wi([S.trace("SelfController.leaveRoom")],qr.prototype,"leaveRoom",1);Wi([S.trace("SelfController.joinMediaRoom")],qr.prototype,"joinMediaRoom",1);Wi([S.trace("SelfController.leaveMediaRoom")],qr.prototype,"leaveMediaRoom",1);Wi([S.trace("SelfController.init")],qr,"init",1);var sd;class GN{constructor(e){f(this,sd,void 0),v(this,sd,e)}on(e,n){let r;e===W.roomPeerCount?r=ng.fromBinary.bind(ng):r=pg.fromBinary.bind(pg),o(this,sd).on(e,({payload:i})=>{const s=r(i);return n(s)})}}sd=new WeakMap;var ad;class JN{constructor(e){f(this,ad,void 0),v(this,ad,e)}on(e,n){let r,i;switch(e){case W.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,ad).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)})}}ad=new WeakMap;var $N=Object.defineProperty,KN=Object.getOwnPropertyDescriptor,Ep=(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},_r;class fl{constructor(e){f(this,_r,void 0),v(this,_r,e)}getPolls(){return o(this,_r).sendMessagePromise(zn.getPolls)}createPoll(e,n,r=!1,i=!1){const s={anonymous:r,hideVotes:i,question:e,options:n};return o(this,_r).sendMessage(zn.createPoll,W1.toBinary(s))}votePoll(e,n){const r={index:n,pollId:e};return o(this,_r).sendMessage(zn.votePoll,H1.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,_r).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,_r).removeListeners(e)}}_r=new WeakMap;Ep([S.trace("PollSocketHandler.getPolls")],fl.prototype,"getPolls",1);Ep([S.trace("PollSocketHandler.createPoll")],fl.prototype,"createPoll",1);Ep([S.trace("PollSocketHandler.votePoll")],fl.prototype,"votePoll",1);var Gt;class zN{constructor(e){f(this,Gt,void 0),v(this,Gt,e)}getStageRequests(){return u(this,null,function*(){const{payload:e}=yield o(this,Gt).sendMessagePromise(W.getStageRequests);return e?zl.fromBinary(e):{stageRequests:[]}})}requestAccess(){o(this,Gt).sendMessage(W.requestStageAccess)}cancelRequestAccess(){o(this,Gt).sendMessage(W.cancelStageRequest)}grantAccess(e){return u(this,null,function*(){const n={userIds:e};o(this,Gt).sendMessage(W.grantStageAccess,A1.toBinary(n))})}denyAccess(e){return u(this,null,function*(){const n={userIds:e};o(this,Gt).sendMessage(W.denyStageAccess,O1.toBinary(n))})}joinStage(){return o(this,Gt).sendMessagePromise(W.joinStage,void 0,void 0,W.peerStageStatusUpdate)}leaveStage(e){const n={userIds:[e]};return o(this,Gt).sendMessagePromise(W.leaveStage,gg.toBinary(n),void 0,W.peerStageStatusUpdate)}kick(e){const n={userIds:e};return o(this,Gt).sendMessagePromise(W.leaveStage,gg.toBinary(n))}on(e,n){let r;switch(e){case W.grantStageAccess:case W.denyStageAccess:{r=void 0;break}case W.getStagePeers:{r=mg.fromBinary.bind(mg);break}case W.getStageRequests:case W.requestStageAccess:case W.cancelStageRequest:{r=zl.fromBinary.bind(zl);break}case W.peerStageStatusUpdate:{r=tg.fromBinary.bind(tg);break}}o(this,Gt).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,Gt).sendMessagePromise(W.getPeerInfo,Zv.toBinary({peerId:e}));return es.fromBinary(n.payload)})}}Gt=new WeakMap;var tt;class YN{constructor(e){f(this,tt,void 0),v(this,tt,e)}addPlugin(e,n){o(this,tt).sendMessage(z.addPlugin,KA.toBinary({pluginId:e,staggered:n}))}removePlugin(e){o(this,tt).sendMessage(z.removePlugin,YA.toBinary({pluginId:e,staggered:!1}))}getActivePlugins(){return u(this,null,function*(){const{payload:e}=yield o(this,tt).sendMessagePromise(z.getPlugins);return e?S1.fromBinary(e):{plugins:[]}})}customPluginEventToRoom(e,n,r){const i={pluginId:e,pluginData:new TextEncoder().encode(JSON.stringify(n))};o(this,tt).sendMessage(z.customPluginEventToRoom,a1.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,c1.toBinary(s),i)}enablePluginForRoom(e,n){o(this,tt).sendMessage(z.enablePluginForRoom,XA.toBinary({pluginId:e}),n)}enablePluginForPeers(e,n,r){o(this,tt).sendMessage(z.enablePluginForPeers,n1.toBinary({pluginId:e,peerIds:n}),r)}disablePluginForRoom(e,n){o(this,tt).sendMessage(z.disablePluginForRoom,e1.toBinary({pluginId:e}),n)}disablePluginForPeers(e,n,r){o(this,tt).sendMessage(z.disablePluginForPeers,i1.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,dg.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,h1.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,m1.toBinary(s),i)}storeDelete(e,n,r){o(this,tt).sendMessage(z.storeDelete,f1.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,dg.toBinary(i))}on(e,n){let r;switch(e){case z.addPlugin:case z.enablePluginForPeers:case z.enablePluginForRoom:{r=Wu.fromBinary.bind(Wu);break}case z.removePlugin:case z.disablePluginForPeers:case z.disablePluginForRoom:{r=lg.fromBinary.bind(lg);break}case z.customPluginEventToPeers:case z.customPluginEventToRoom:{r=hg.fromBinary.bind(hg);break}case z.storeInsertKeys:case z.storeGetKeys:case z.storeDeleteKeys:case z.storeDelete:{r=ug.fromBinary.bind(ug);break}}o(this,tt).on(e,({payload:i,id:s})=>{const a=r(i);return n(a,s)})}}tt=new WeakMap;var QN=Object.defineProperty,XN=(t,e,n)=>e in t?QN(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n,ZN=(t,e,n)=>(XN(t,typeof e!="symbol"?e+"":e,n),n),Tp=(t,e,n)=>{if(!e.has(t))throw TypeError("Cannot "+n)},x=(t,e,n)=>(Tp(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)=>(Tp(t,e,"write to private field"),r?r.call(t,n):e.set(t,n),n),De=(t,e,n)=>(Tp(t,e,"access private method"),n),Hd={},eL={get exports(){return Hd},set exports(t){Hd=t}},As=typeof Reflect=="object"?Reflect:null,$g=As&&typeof As.apply=="function"?As.apply:function(t,e,n){return Function.prototype.apply.call(t,e,n)},od;As&&typeof As.ownKeys=="function"?od=As.ownKeys:Object.getOwnPropertySymbols?od=function(t){return Object.getOwnPropertyNames(t).concat(Object.getOwnPropertySymbols(t))}:od=function(t){return Object.getOwnPropertyNames(t)};function tL(t){console&&console.warn&&console.warn(t)}var Qy=Number.isNaN||function(t){return t!==t};function ve(){ve.init.call(this)}eL.exports=ve;Hd.once=sL;ve.EventEmitter=ve;ve.prototype._events=void 0;ve.prototype._eventsCount=0;ve.prototype._maxListeners=void 0;var Kg=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(ve,"defaultMaxListeners",{enumerable:!0,get:function(){return Kg},set:function(t){if(typeof t!="number"||t<0||Qy(t))throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received '+t+".");Kg=t}});ve.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};ve.prototype.setMaxListeners=function(t){if(typeof t!="number"||t<0||Qy(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 Xy(t){return t._maxListeners===void 0?ve.defaultMaxListeners:t._maxListeners}ve.prototype.getMaxListeners=function(){return Xy(this)};ve.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")$g(c,this,e);else for(var d=c.length,l=rS(c,d),n=0;n<d;++n)$g(l[n],this,e);return!0};function Zy(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=Xy(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,tL(c)}return t}ve.prototype.addListener=function(t,e){return Zy(this,t,e,!1)};ve.prototype.on=ve.prototype.addListener;ve.prototype.prependListener=function(t,e){return Zy(this,t,e,!0)};function nL(){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 eS(t,e,n){var r={fired:!1,wrapFn:void 0,target:t,type:e,listener:n},i=nL.bind(r);return i.listener=n,r.wrapFn=i,i}ve.prototype.once=function(t,e){return vl(e),this.on(t,eS(this,t,e)),this};ve.prototype.prependOnceListener=function(t,e){return vl(e),this.prependListener(t,eS(this,t,e)),this};ve.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():rL(n,i),n.length===1&&(r[t]=n[0]),r.removeListener!==void 0&&this.emit("removeListener",t,a||e)}return this};ve.prototype.off=ve.prototype.removeListener;ve.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 tS(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?iL(i):rS(i,i.length)}ve.prototype.listeners=function(t){return tS(this,t,!0)};ve.prototype.rawListeners=function(t){return tS(this,t,!1)};ve.listenerCount=function(t,e){return typeof t.listenerCount=="function"?t.listenerCount(e):nS.call(t,e)};ve.prototype.listenerCount=nS;function nS(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}ve.prototype.eventNames=function(){return this._eventsCount>0?od(this._events):[]};function rS(t,e){for(var n=new Array(e),r=0;r<e;++r)n[r]=t[r];return n}function rL(t,e){for(;e+1<t.length;e++)t[e]=t[e+1];t.pop()}function iL(t){for(var e=new Array(t.length),n=0;n<e.length;++n)e[n]=t[n].listener||t[n];return e}function sL(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))}iS(t,e,s,{once:!0}),e!=="error"&&aL(t,i,{once:!0})})}function aL(t,e,n){typeof t.on=="function"&&iS(t,"error",e,n)}function iS(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 oL 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 zg=new oL;class sS{static encode(e){return zg.toBinary(e)}static decode(e){return zg.fromBinary(new Uint8Array(e))}}function cL(t,e){return Math.floor(Math.random()*(e-t+1)+t)}var Ir;class dL{constructor(e={}){ZN(this,"opts"),Ie(this,Ir,void 0),this.opts={initialTimeout:e.initialTimeout||1e3,maxTimeout:e.maxTimeout||1e4,factor:e.factor||2},me(this,Ir,0)}wait(){return u(this,null,function*(){me(this,Ir,x(this,Ir)+1);const e=cL(0,Math.min(this.opts.maxTimeout,this.opts.initialTimeout*vE(2,x(this,Ir))));yield new Promise(n=>{setTimeout(n,e)})})}getAttempts(){return x(this,Ir)}reset(){me(this,Ir,0)}}Ir=new WeakMap;const mr={debug:0,info:1,warn:2,error:3};var fi,vi;class lL{constructor(e){Ie(this,fi,void 0),Ie(this,vi,void 0),me(this,fi,console),me(this,vi,e)}debug(...e){mr[x(this,vi)]>mr.debug||x(this,fi).debug("[Sockrates]:",...e)}info(...e){mr[x(this,vi)]>mr.info||x(this,fi).info("[Sockrates]:",...e)}warn(...e){mr[x(this,vi)]>mr.warn||x(this,fi).warn("[Sockrates]:",...e)}error(...e){mr[x(this,vi)]>mr.error||x(this,fi).error("[Sockrates]:",...e)}}fi=new WeakMap,vi=new WeakMap;var aS=(t=>(t[t.CONNECTING=0]="CONNECTING",t[t.OPEN=1]="OPEN",t[t.CLOSING=2]="CLOSING",t[t.CLOSED=3]="CLOSED",t))(aS||{});const uL="2",hL="3";var Ue,vs,Ae,He,Pr,nt,er,Or,yn,ys,Kn,Ah,oS,co,cd,Dh,cS,Oh,Yg,qd,Nh,Lh,dS,_o,dd,Io,Gd,Jd,xh,Ds,Po,Co,$d;class pL{constructor(e,n){var r;Ie(this,Ah),Ie(this,co),Ie(this,Dh),Ie(this,Oh),Ie(this,qd),Ie(this,Lh),Ie(this,_o),Ie(this,Io),Ie(this,Jd),Ie(this,Ds),Ie(this,Co),Ie(this,Ue,void 0),Ie(this,vs,void 0),Ie(this,Ae,void 0),Ie(this,He,void 0),Ie(this,Pr,void 0),Ie(this,nt,void 0),Ie(this,er,void 0),Ie(this,Or,void 0),Ie(this,yn,void 0),Ie(this,ys,void 0),Ie(this,Kn,void 0);var i,s,a,c,d,l,h,g,y;me(this,vs,e),me(this,Pr,[]),me(this,nt,new Hd),me(this,er,!0),me(this,yn,!1),me(this,Ae,n!=null?n:{}),(i=x(this,Ae)).autoReconnect!=null||(i.autoReconnect=!0),(s=x(this,Ae)).retryConnectionInterval!=null||(s.retryConnectionInterval=1e3),(a=x(this,Ae)).pingTimeout!=null||(a.pingTimeout=3e4),(c=x(this,Ae)).connectionTimeout!=null||(c.connectionTimeout=5e3),(d=x(this,Ae)).debug!=null||(d.debug=!0),(l=x(this,Ae)).maxReconnectionAttempts!=null||(l.maxReconnectionAttempts=10),(h=x(this,Ae)).disconnectOnPingTimeout!=null||(h.disconnectOnPingTimeout=!0),(g=x(this,Ae)).queueOnDisconnect!=null||(g.queueOnDisconnect=!1),(y=x(this,Ae)).flushOnReconnect!=null||(y.flushOnReconnect=!1),me(this,Or,{code:void 0,reason:void 0}),me(this,He,(r=x(this,Ae).logger)!=null?r:new lL(x(this,Ae).debug?"debug":"info")),me(this,Kn,new dL)}get readyState(){var e;return(e=x(this,Ue))==null?void 0:e.readyState}get url(){return x(this,vs)}updateURL(e){me(this,vs,e),De(this,Lh,dS).call(this)}get config(){return x(this,Ae)}get sendQueue(){return x(this,Pr)}flush(){if(!x(this,Ae).queueOnDisconnect)return!1;const e=[];return x(this,Pr).forEach(n=>{this.send(n.event,n.id,n.payload,n.metadata)||e.push(n)}),me(this,Pr,e),x(this,Pr)}connect(e=!1){return u(this,null,function*(){if(!e&&[0,1].includes(this.readyState)){x(this,He).debug("Websocket was already connecting or connected.");return}if(x(this,er)!==!1)return new Promise((n,r)=>{De(this,Ds,Po).call(this),De(this,Co,$d).call(this);try{me(this,Ue,new WebSocket(De(this,Ah,oS).call(this,x(this,vs)))),x(this,Ue).binaryType="arraybuffer",x(this,He).debug("Connecting");const i=setTimeout(()=>{x(this,He).debug("Connection timeout. Closing socket"),me(this,er,!0),De(this,Co,$d).call(this),x(this,Ue).close(3001,"Connection Timeout"),x(this,Ae).autoReconnect&&!x(this,yn)&&(x(this,nt).emit("reconnecting"),De(this,_o,dd).call(this)),r(new Error("Connection timed out!"))},x(this,Ae).connectionTimeout);x(this,Ue).onopen=()=>{x(this,He).debug(`Ready State: ${aS[x(this,Ue).readyState]}`),i&&clearTimeout(i),De(this,Jd,xh).call(this),me(this,Or,{code:void 0,reason:void 0}),x(this,nt).emit("connected"),x(this,Ae).flushOnReconnect&&this.flush(),n()},x(this,Ue).onclose=s=>{try{i&&clearTimeout(i);const{code:a,reason:c}=s;r(c),x(this,He).debug("Socket closed. Close event:",{event:s}),x(this,He).debug(`Connection closed code: ${a}`),x(this,He).debug(`Connection closed reason: ${c}`),x(this,yn)||De(this,qd,Nh).call(this,a,c)}catch(a){De(this,co,cd).call(this,a)}},x(this,Ue).onerror=s=>{De(this,co,cd).call(this,s)},x(this,Ue).onmessage=s=>De(this,Dh,cS).call(this,s)}catch(i){De(this,co,cd).call(this,i,r)}})})}send(e,n,r,i){const s={event:e,id:n,payload:r,metadata:i};if(x(this,Ae).queueOnDisconnect&&(!x(this,Ue)||x(this,Ue).readyState!==1))return x(this,He).debug("Queuing message since socket is not connected!",s),x(this,Pr).push(s),!1;const a=sS.encode(s);return De(this,Io,Gd).call(this,a)}emit(e,n,r,i){return this.send(e,n,r,i)}sendRaw(e){return De(this,Io,Gd).call(this,e)}receive(e,n){return x(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")){x(this,nt).on(e,n);return}this.receive(e,n)}removeAllListeners(){x(this,nt).removeAllListeners()}removeReceiver(e,n){this.removeListener(e,n)}removeListener(e,n){x(this,nt).removeListener(e.toString(),n)}removeReceivers(e){this.removeListeners(e)}removeListeners(e){x(this,nt).listeners(e.toString()).map(n=>this.removeListener(e,n))}disconnect(){me(this,er,!1),De(this,Ds,Po).call(this),this.removeAllListeners(),me(this,Or,{code:1e3,reason:"Sockrates disconnect method called"}),x(this,Ue).close(1e3,"Sockrates disconnect method called.")}}Ue=new WeakMap,vs=new WeakMap,Ae=new WeakMap,He=new WeakMap,Pr=new WeakMap,nt=new WeakMap,er=new WeakMap,Or=new WeakMap,yn=new WeakMap,ys=new WeakMap,Kn=new WeakMap,Ah=new WeakSet,oS=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)://.")},co=new WeakSet,cd=function(t,e){x(this,He).error("Error:",{error:t}),x(this,nt).emit("errored",{error:t}),e==null||e(t)},Dh=new WeakSet,cS=function(t){if(De(this,Jd,xh).call(this),t.data===uL){x(this,He).debug("Received ping from server"),De(this,Io,Gd).call(this,hL);return}const e=sS.decode(t.data),{id:n,payload:r}=e;x(this,He).debug("Received message",{event:e.event,messageID:n}),x(this,nt).emit(e.event.toString(),{id:n,payload:r})},Oh=new WeakSet,Yg=function(){return x(this,Ue).readyState===1},qd=new WeakSet,Nh=function(t,e){me(this,Or,{reason:e,code:t}),x(this,nt).emit("disconnected",{code:t,reason:e})},Lh=new WeakSet,dS=function(){const{reason:t,code:e}=x(this,Or);e&&e!==1e3&&x(this,er)&&x(this,Ae).autoReconnect&&!x(this,yn)&&(x(this,He).debug(`Triggering reconnection due to ${t}.`),x(this,nt).emit("reconnecting"),De(this,_o,dd).call(this))},_o=new WeakSet,dd=function(t=!0){return u(this,null,function*(){if(t&&x(this,yn)){x(this,He).debug("Reconnect called when already in a reconnect loop. Ignoring.");return}if(x(this,yn)||x(this,Kn).reset(),x(this,Ae).maxReconnectionAttempts!==null&&x(this,Kn).getAttempts()>=x(this,Ae).maxReconnectionAttempts){x(this,nt).emit("failed"),me(this,yn,!1);return}me(this,yn,!0),De(this,Co,$d).call(this),De(this,Ds,Po).call(this);try{if(yield x(this,Kn).wait(),x(this,er)===!1)return;if(x(this,He).debug(`Reconnection attempt ${x(this,Kn).getAttempts()}`),x(this,nt).emit("reconnectAttempt",{attempt:x(this,Kn).getAttempts()}),yield this.connect(),!De(this,Oh,Yg).call(this))throw Error("Reconnect Failed");me(this,yn,!1),me(this,Or,{code:void 0,reason:void 0}),x(this,nt).emit("reconnected")}catch{x(this,He).debug("Failed to reconnect."),x(this,nt).emit("reconnectFailure",{attempt:x(this,Kn).getAttempts()}),De(this,_o,dd).call(this,!1)}})},Io=new WeakSet,Gd=function(t){try{return x(this,Ue).send(t),!0}catch(e){return x(this,He).error(e.message),!1}},Jd=new WeakSet,xh=function(){this.config.disconnectOnPingTimeout&&(x(this,He).debug("Resetting ping timeout"),De(this,Ds,Po).call(this),me(this,ys,setTimeout(()=>{var t;x(this,He).debug("Disconnecting the socket due to ping timeout"),me(this,er,!0);const e=3002,n="Ping timeout";(t=x(this,Ue))==null||t.close(e,n),De(this,qd,Nh).call(this,e,n)},x(this,Ae).pingTimeout)))},Ds=new WeakSet,Po=function(){x(this,ys)&&(clearTimeout(x(this,ys)),me(this,ys,void 0))},Co=new WeakSet,$d=function(){x(this,Ue)&&(x(this,Ue).onopen=void 0,x(this,Ue).onerror=void 0,x(this,Ue).onmessage=void 0,x(this,Ue).onclose=void 0)};var mL=Object.defineProperty,gL=Object.getOwnPropertyDescriptor,yl=(t,e,n,r)=>{for(var i=r>1?void 0:r?gL(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&&mL(e,n,i),i};const Qg=65535,fL=3e3;var Xr,Le,xe,Fe,ln,gr,Sc,mu,Ec,gu,Xg;const lS=(Xg=class{constructor(t,{peerId:e,meetingId:n,authToken:r,capabilities:i}){f(this,xe),f(this,Sc),f(this,Ec),f(this,Xr,void 0),f(this,Le,void 0),m(this,"roomName"),m(this,"authToken"),m(this,"capabilities"),f(this,ln,void 0),f(this,gr,void 0);var s;if(!e||!n||!r)throw new I("peerId, meetingId, or authToken can not be empty","0404");v(this,ln,void 0),v(this,gr,t),this.capabilities=i,this.roomName=n,this.authToken=r,v(this,Xr,H(this,Sc,mu).call(this,e)),v(this,Le,new pL(o(this,Xr),{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,gr).getValue("peerId")}updateURL(t){t!==this.peerId&&(v(this,Xr,H(this,Sc,mu).call(this,t)),p.debug("SocketService:: Connection URL updated.")),o(this,Le).updateURL(o(this,Xr))}static getSocketEdgeDomain(t){return Ps({servicePrefix:"socket-edge",baseURI:t})}get url(){return o(this,Xr)}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,Ec,gu).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(Qg,b),o(this,Le).removeListener(rn.errorResponse,b),o(this,Le).removeListener(Sn.errorResponse,b)},l=r!=null?r:H(this,Ec,gu).call(this),h={};S.injectContext(h);const g=({id:E,payload:b})=>{if(l===E){let P;try{const R=cC.fromBinary(b);P=new Error(R.errorMessage)}catch(R){P=new Error("failed to parse error message",{cause:R});try{const B=lR.fromBinary(b);P=new Error(B.message)}catch(B){P=new Error("failed to parse error message",{cause:B})}}c(P),d(y,g)}},y=({id:E,payload:b})=>{l===E&&(a({id:E,payload:b}),d(y,g))};o(this,Le).on(s,y),o(this,Le).on(Qg,g),o(this,Le).on(rn.errorResponse,g),o(this,Le).on(Sn.errorResponse,g),setTimeout(()=>{d(y,g),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)!==Fr.CONNECTED||i!=null&&i.state&&(i==null?void 0:i.state)!==Fr.CONNECTED?M.emit(A.SOCKET_SERVICE_DISCONNECTED,{joinAttempted:o(this,xe,Fe).joinAttempted}):v(this,ln,setTimeout(()=>{M.emit(A.SOCKET_SERVICE_DISCONNECTED,{joinAttempted:o(this,xe,Fe).joinAttempted}),v(this,ln,void 0)},fL)),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)),M.emit(A.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}),M.emit(A.SOCKET_SERVICE_FAILED),o(this,xe,Fe).updateSocketConnectionState("failed")}))}},Xr=new WeakMap,Le=new WeakMap,xe=new WeakSet,Fe=function(){return o(this,gr).getValue("connectionHandler")},ln=new WeakMap,gr=new WeakMap,Sc=new WeakSet,mu=function(t){let e=lS.getSocketEdgeDomain(o(this,gr).getValue("baseURI"));typeof Pd(o(this,gr),"socket_server_base")=="string"&&(e=Pd(o(this,gr),"socket_server_base"));const n=`wss://${e}`,r=new URL(`${n}/ws`),i=this.peerId,s=K(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=>Cd[a]).join(" "),joinWithDetails:!0,useCfWorker:!0});return Object.entries(s).forEach(([a,c])=>{r.searchParams.append(a,c.toString())}),r.href},Ec=new WeakSet,gu=function(){return`${this.peerId}-${(Math.random()+1).toString(36).substring(7)}`},Xg);let qo=lS;yl([S.trace("SocketService.connect")],qo.prototype,"connect",1);yl([S.trace("SocketService.disconnect")],qo.prototype,"disconnect",1);yl([S.trace("SocketService.sendMessagePromise")],qo.prototype,"sendMessagePromise",1);yl([S.trace("SocketService.sendMessagePromiseWithTimeout")],qo.prototype,"sendMessagePromiseWithTimeout",1);const yi=class{static handleConnectedRoomsDumpRaw({payload:t}){var e;const n=VR.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=dM.fromBinary(t);return{authToken:e.authToken,meetingId:e.meetingId}}static handleMovedPeerRaw({payload:t}){const e=ey.fromBinary(t);return{meetingId:e.meetingId,customParticipantId:e.customParticipantId}}static handleConnectedRoomsUpdatedRaw({payload:t}){return sg.fromBinary(t).payloads.map(e=>({id:e.id,title:e.title}))}static handleConnectedRoomsDeletedRaw({payload:t}){return ZR.fromBinary(t).payloads}static getConnectedRoomsDump(){return u(this,null,function*(){const t=yield yi.socketService.sendMessagePromise(W.getConnectedRoomsDump);return yi.handleConnectedRoomsDumpRaw(t)})}static createConnectedRooms(t){return u(this,null,function*(){const{payload:e}=yield yi.socketService.sendMessagePromise(W.createConnectedRooms,WR.toBinary({payloads:t}));return sg.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 yi.socketService.sendMessagePromise(W.deleteConnectedRooms,QR.toBinary({payloads:e}));return yi.handleConnectedRoomsDeletedRaw(n)})}static movePeersBetweenRooms(t){return u(this,null,function*(){try{const e=yield yi.socketService.sendMessagePromise(W.movePeers,sM.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=yi;m(Ne,"socketService"),m(Ne,"currentMeetingId");var vL=Object.defineProperty,yL=Object.getOwnPropertyDescriptor,Sl=(t,e,n,r)=>{for(var i=r>1?void 0:r?yL(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&&vL(e,n,i),i};const Ss=class{constructor(t,e){m(this,"apiBase"),m(this,"selfController"),m(this,"pollController"),m(this,"chatController"),m(this,"metaController"),m(this,"storesManager"),m(this,"stageController"),m(this,"pluginController"),m(this,"internalsController"),m(this,"recordingController"),m(this,"livestreamController"),m(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(M.reset(),Dd.cleanup(),zy(t),Ce.isSupported()===!1)throw new I("Browser not supported","0010",!0);const l=kD(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 iO;t.setValue("connectionHandler",h);const g=Ss.createSocketService(t),y=g.connect(),E=l.getUserDetails(),b=l.getPlugins();let P=rt.HIVE,R,B="";try{yield Ss.setupFlagsmith(t)}catch(Z){p.error("Failed to setup flagsmith",{error:Z})}try{yield y}catch(Z){p.error("[Controller]: Failed to connect to socket server:",{error:Z})}try{({sfu:P,meetingTitle:B}=yield l.getRoomNodeData()),R=yield E,p.info(`SFU ${P} is being used.`),t.setValue("presetName",R.preset.name),t.setValue("roomNodeOptions",{sfu:P})}catch(Z){p.error("Failed to get room metadata",{error:Z})}const L=jO.init(R.preset,!t.getValue("modules").theme),G=Ss.setupControllers(g,t,R,b,B,L);$D(L)&&((e=Ss.createRoomNodeClient(t,g).partialJoinRoom(R.participant.name,a,void 0))==null||e.catch(Z=>{p.error("[Controller]: Failed to queue partial media room promise:",{error:Z})})),S.location.country=(n=l.ipInfo)==null?void 0:n.country;const{controllers:_}=yield G;return GI(),new Ss(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=HI(s),d=K(V({entity:Nu.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?Ps({servicePrefix:"flags",baseURI:r}):"edge.api.flagsmith.com";yield X.identify(`${Nu.PEER}_${n}`,JSON.parse(JSON.stringify(d)),!1,5e3,l,p),p.info("flagsmith::allFlags",{flags:JSON.stringify(X.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:g}=n,y=e.getValue("defaults"),{sfu:E}=e.getValue("roomNodeOptions"),{viewType:b,mediaConstraints:{audio:P}}=s;e.setValue("viewType",b),e.setValue("defaults",V({mediaConfiguration:{audio:{enableHighBitrate:(a=P.enableHighBitrate)!=null?a:!1,enableStereo:(c=P.enableStereo)!=null?c:!1}}},y));const R=dN.init(e,b,h.permissions);e.setValue("maxPreferredStreams",Ce.isMobile()?s.maxVideoStreams.mobile:s.maxVideoStreams.desktop);let B,L,G,_,Z,se,Te,ce;const Re=new JN(t);Ne.socketService=t;const vt=new fl(t),D=new sn(t),k=new zN(t),w=Dd.create(t,e),j=new YN(t),_e=new GN(t),ze=new Ai(t),F=yield qr.init(e,w,g,R,s),C=yield uy.init(e,F.self,w,Re,i);if(l.participant&&(ce=new cr(e,F.self,w,E)),(d=l.e2ee)!=null&&d.enabled&&l.e2ee.manager.init(p,M),l.chat&&(L=yield nr.init(e,D,ze,F.self,ce.participants)),l.internals&&(Z=yield up.init()),l.livestream&&s.viewType===Ct.Livestream&&X.hasFeature(ie.LIVESTREAM)&&(Te=new Ey(F.self,_e)),s.viewType!==Ct.Chat){if(l.poll&&(B=yield oy.init(e,F.self,vt)),l.recording&&(se=new gy(e,F.self,w)),l.stage&&(G=new hy(e,k,w,F.self,ce.participants)),l.plugin){if(!ce)throw new I("The plugin module cannot be initialized without the `participant` module","0102");const Wn=yield r;_=yield Bo.init(e,Wn,j,D,L==null?void 0:L.chat,F.self,ce.participants,i)}if(l.pip){const Wn=yield KI._init(e,F.self);e.setValue("pip",Wn)}}const Ye={storesManager:new YO(e,j),pollController:B,selfController:F,metaController:C,chatController:L,stageController:G,pluginController:_,recordingController:se,internalsController:Z,livestreamController:Te,participantController:ce};return{theme:s,permissions:R,controllers:Ye}})}static createRoomNodeClient(t,e){const{peerId:n,roomNodeOptions:r}=t.getAllValues(),{sfu:i}=r;return Ky(t,i,{socket:e,peerId:n})}static createSocketService(t){const{peerId:e,meetingId:n,authToken:r}=t.getAllValues(),i=["PING"];return new qo(t,{peerId:e,meetingId:n,authToken:r,capabilities:i})}};let Go=Ss;Sl([S.trace("Controller.init")],Go,"init",1);Sl([S.trace("setupFlagsmith")],Go,"setupFlagsmith",1);Sl([S.trace("Controller.createRoomNodeClient")],Go,"createRoomNodeClient",1);Sl([S.trace("Controller.createSocketService")],Go,"createSocketService",1);var SL=Object.defineProperty,EL=Object.getOwnPropertyDescriptor,TL=(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&&SL(e,n,i),i},ld,Vh;class uS extends Kt{constructor(e,n){super(),f(this,ld,void 0),m(this,"meetings",[]),m(this,"parentMeeting",null),f(this,Vh,void 0),v(this,Vh,e),v(this,ld,n.self)}get supportsConnectedMeetings(){return o(this,ld).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 K(V({},s),{participants:a})}if(e===s.id){const a=s.participants.filter(c=>!r.includes(c.id));return K(V({},s),{participants:a})}return s})}}ld=new WeakMap,Vh=new WeakMap;TL([Ft({maxInvocations:60,period:60})],uS.prototype,"getConnectedMeetings",1);var kL=Object.defineProperty,bL=Object.getOwnPropertyDescriptor,kp=(t,e,n,r)=>{for(var i=r>1?void 0:r?bL(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&&kL(e,n,i),i},Aa,un,fu,vu;const Cr=(fu=class{constructor(t,e,n){m(this,"connectedMeetings"),f(this,Aa,void 0),f(this,un,void 0),f(this,vu,void 0),v(this,vu,t),v(this,Aa,n),this.connectedMeetings=new uS(t,e),this.setCurrentMeeting(e)}static init(t,e,n){return Cr.instance||(Cr.instance=new Cr(t,e,n)),Cr.instance.connectedMeetings.supportsConnectedMeetings&&(Cr.instance.setupEvents(),e.self.once("roomJoined",()=>Cr.instance.getConnectedMeetings())),Cr.instance}setCurrentMeeting(t){v(this,un,t),Ne.currentMeetingId=t.meta.meetingId}getConnectedMeetings(){this.connectedMeetings.getConnectedMeetings()}setupEvents(){Ne.socketService&&(Ne.socketService.on(W.getConnectedRoomsDump,this.handleConnectedRoomsDump.bind(this)),Ne.socketService.on(W.transferPeer,this.handleTransferPeer.bind(this)),Ne.socketService.on(W.movedPeer,this.handleMovedPeer.bind(this)),Ne.socketService.on(W.connectedRoomsUpdated,this.handleConnectedRoomsUpdated.bind(this)),Ne.socketService.on(W.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 hS.init(K(V({},o(this,Aa)),{cachedUserDetails:null,defaults:K(V(V({},o(this,Aa).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,K(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})}},Aa=new WeakMap,un=new WeakMap,vu=new WeakMap,m(fu,"instance"),fu);let El=Cr;kp([S.trace("ConnectedMeetingsController.getConnectedMeetings")],El.prototype,"getConnectedMeetings",1);kp([S.trace("ConnectedMeetingsController.setupEvents")],El.prototype,"setupEvents",1);kp([S.trace("ConnectedMeetingsController.switchMeeting")],El.prototype,"switchMeeting",1);class wL{constructor(){m(this,"battery"),m(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)}})),m(this,"updateChargeInfo",()=>{var e;p.log(`Battery charging? ${(e=this.battery)!=null&&e.charging?"Yes":"No"}`)}),m(this,"updateLevelInfo",()=>{if(!this.battery){p.log("Battery level: Not known");return}p.log(`Battery level: ${this.battery.level*100}%`)}),m(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 Zg=new wL;function _L(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 I("Invalid auth token","0004")}}var IL=Object.defineProperty,PL=Object.getOwnPropertyDescriptor,Tl=(t,e,n,r)=>{for(var i=r>1?void 0:r?PL(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&&IL(e,n,i),i},ot,Tc,kc,yu,ef,tf;let Br=(tf=class{constructor(t,e){f(this,yu),f(this,ot,void 0),f(this,Tc,void 0),f(this,kc,void 0),v(this,kc,t),v(this,ot,e)}static init(t){return u(this,null,function*(){var e,n,r,i,s;BI(),Ce.init();const a=Vs();Zg.init();const{authToken:c,baseURI:d}=t,l=_L(c,d),{meetingId:h}=l,g=Yd(l,["meetingId"]);window.__zone_symbol__DISABLE_WRAPPING_UNCAUGHT_PROMISE_REJECTION=!0;const y=Br.setupContext(a,t,h,g);S.meetingMetadata.roomName=h,S.meetingMetadata.userId=g.participantId,S.meetingMetadata.organizationId=g.orgId,S.init(y,(n=(e=t.modules)==null?void 0:e.tracing)!=null?n:!0),p.info("DyteClient::init::options",{dyteClientInitOptions:K(V({},t),{authToken:`${(r=t.authToken)==null?void 0:r.slice(0,10)}...
|
|
23
|
-
${(i=t.authToken)==null?void 0:i.slice(-10)}`})});const E=yield Go.init(y),b=new Br(y,E);return H(s=b,yu,ef).call(s,t),b})}static setupContext(t,e,n,r){var i;const s=Pi.createContext(t,e),a=V(V({},NI),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",LI({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
|
+
${(i=t.authToken)==null?void 0:i.slice(-10)}`})});const E=yield Go.init(y),b=new Br(y,E);return H(s=b,yu,ef).call(s,t),b})}static setupContext(t,e,n,r){var i;const s=Pi.createContext(t,e),a=V(V({},NI),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",LI({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.66"),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*(){Zg.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,Tc))==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,Tc=new WeakMap,kc=new WeakMap,yu=new WeakSet,ef=function(t){v(this,Tc,El.init(o(this,kc),this,t))},tf);Tl([gt("0002"),Hr.executeWithLock({methodName:"meeting.join",lockName:"DyteClient.join",timeout:3e3})],Br.prototype,"join",1);Tl([gt("0003")],Br.prototype,"leave",1);Tl([gt("0001"),Hr.executeWithLock({methodName:"DyteClient.init",lockName:"DyteClient.init",timeout:3e3})],Br,"init",1);Br=Tl([gt("0000")],Br);const hS=Br;exports.DyteSelfMedia=Iy;exports.default=hS;
|
package/dist/index.es.js
CHANGED
|
@@ -30643,7 +30643,7 @@ let Xr = (hf = class {
|
|
|
30643
30643
|
var c;
|
|
30644
30644
|
const n = Hi.createContext(t, e), a = N(N({}, DR), e == null ? void 0 : e.modules);
|
|
30645
30645
|
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", OR({ baseURI: i.baseURI })), n.setValue("defaults", e.defaults || { audio: true, video: true }), n.setValue("onError", e.onError || (() => {
|
|
30646
|
-
})), n.setValue("cachedUserDetails", gs(e.cachedUserDetails)), n.setValue("sdkVersion", "2.5.0-staging.
|
|
30646
|
+
})), n.setValue("cachedUserDetails", gs(e.cachedUserDetails)), n.setValue("sdkVersion", "2.5.0-staging.66"), n;
|
|
30647
30647
|
}
|
|
30648
30648
|
join() {
|
|
30649
30649
|
return u(this, null, function* () {
|