@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/browser.js
CHANGED
|
@@ -20,4 +20,4 @@ ${t}`}const ts={maxInvocations:5,period:1};function Ot(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 Pd extends wh{constructor(e){super(),m(this,"supportsSendEncodings",!1),this.supportsSendEncodings=e.supportsSendEncodings}static createFactory(e){return()=>new Pd(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=Dl(h),b=E.media[E.media.length-1],P=b.rtp.filter(G=>g.some(I=>I.name===G.codec)),R=b.fmtp.filter(G=>P.some(I=>I.payload===G.payload)),B=(y=b.rtcpFb)==null?void 0:y.filter(G=>P.some(I=>I.payload===G.payload)),x=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=x.join(" "),Jp(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 Ih extends wh{static createFactory(){return()=>new Ih}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 SN(t,e){return typeof t=="undefined"?e:typeof window!="undefined"&&Object.getOwnPropertyDescriptor(window,"structuredClone")?structuredClone(t):JSON.parse(JSON.stringify(t))}var Cd,ws,rr,ir,Dr,Rd,Ph,Ch,hy,Rh,py;class EN extends Ya{constructor(e){var n,r;super(),f(this,ir),f(this,Rd),f(this,Ch),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,Cd,void 0),f(this,ws,void 0),f(this,rr,void 0),this.id=e.id,this.localId=e.localId,v(this,Cd,e.handler),this.appData=e.appData,this.peerId=e.producingPeerId,this.producingTransportId=e.producingTransportId,v(this,rr,!1),this.producerId=e.producerId,this.track=e.track,v(this,ws,(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,Ch,hy).call(this)}get closed(){return o(this,rr)}get kind(){return this.track.kind}get paused(){return o(this,ws)}close(e){o(this,rr)||(p.debug(`Consumer::close() ${e?`with reason ${e}`:""}`,o(this,ir,Dr)),v(this,rr,!0),this.closeTranscieverOnClose&&(H(this,Rh,py).call(this),this.transceiver.stop()),this.safeEmit("close",e))}getStats(){return u(this,null,function*(){if(o(this,rr))throw new It("closed");return o(this,Cd).getReceiverStats(this.localId)})}pause(){if(p.debug("consumer::pause()",o(this,ir,Dr)),o(this,rr)){p.error("consumer::pause() | Consumer closed",o(this,ir,Dr));return}v(this,ws,!0),this.track.enabled=!1,this.safeEmit("pause")}resume(){if(p.debug("consumer::resume()",o(this,ir,Dr)),o(this,rr)){p.error("Consumer::resume() | Consumer closed",o(this,ir,Dr));return}v(this,ws,!1),this.track.enabled=!0,this.safeEmit("resume")}}Cd=new WeakMap,ws=new WeakMap,rr=new WeakMap,ir=new WeakSet,Dr=function(){return{consumer:{id:this.id,appData:this.appData,peerId:this.peerId,kind:this.kind}}},Rd=new WeakSet,Ph=function(){p.debug('Consumer::track "ended" event',o(this,ir,Dr)),this.safeEmit("trackended")},Ch=new WeakSet,hy=function(){this.track.addEventListener("ended",H(this,Rd,Ph).bind(this))},Rh=new WeakSet,py=function(){try{this.track.removeEventListener("ended",H(this,Rd,Ph)),this.track.stop()}catch(t){p.error("Consumer::destroyTrack()",J(V({},o(this,ir,Dr)),{error:t}))}};var xn,Qa,Xa,_s,Tn,gt,bi,Za,rn,kn;class TN extends Ya{constructor(e){var n,r;super(),f(this,rn),m(this,"id"),m(this,"localId"),f(this,xn,void 0),m(this,"kind"),m(this,"appData"),m(this,"rtpSender"),f(this,Qa,void 0),f(this,Xa,void 0),f(this,_s,void 0),f(this,Tn,!1),f(this,gt,void 0),f(this,bi,void 0),f(this,Za,void 0),this.id=e.id,this.localId=e.localId,v(this,gt,e.track),this.kind=(n=e.track)==null?void 0:n.kind,v(this,bi,e.disableTrackOnPause?!((r=e.track)!=null&&r.enabled):!1),v(this,Za,void 0),v(this,Qa,e.stopTracks),v(this,Xa,e.disableTrackOnPause),v(this,_s,e.zeroRtpOnPause),this.appData=e.appData||{},this._onTrackEnded=this._onTrackEnded.bind(this),v(this,xn,e.handler),this.rtpSender=e.rtpSender,this._handleTrack()}get closed(){return o(this,Tn)}get track(){return o(this,gt)}get paused(){return o(this,bi)}get maxSpatialLayer(){return o(this,Za)}close(e){return u(this,null,function*(){if(o(this,Tn))return;if(p.debug(`Producer::close() ${e?`with reason ${e}`:""}`,o(this,rn,kn)),v(this,Tn,!0),this._destroyTrack(),e===Ah){this.safeEmit("close");return}const{offerSdp:n,callback:r}=yield o(this,xn).stopSending(this.localId),{answer:i}=yield this.safeEmitAsPromise("close",{offer:n,reason:e});r(i)})}getStats(){return u(this,null,function*(){if(o(this,Tn))throw new It("closed");return o(this,xn).getSenderStats(this.localId)})}pause(){p.debug("Producer::pause()",o(this,rn,kn)),o(this,Tn)&&p.error("Producer::pause() | Producer closed",o(this,rn,kn)),v(this,bi,!0),o(this,gt)&&o(this,Xa)&&(o(this,gt).enabled=!1),o(this,_s)&&o(this,xn).replaceTrack(this.localId,null),this.emit("pause")}resume(){if(p.debug("Producer::resume()",o(this,rn,kn)),o(this,Tn)){p.error("Producer::resume() | Producer closed",o(this,rn,kn));return}v(this,bi,!1),o(this,gt)&&o(this,Xa)&&(o(this,gt).enabled=!0),o(this,_s)&&o(this,xn).replaceTrack(this.localId,o(this,gt)),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,rn,kn)),o(this,Tn)){if(n&&o(this,Qa))try{n.stop()}catch(r){p.error("Producer::replaceTrack",J(V({},o(this,rn,kn)),{error:r}))}throw new It("closed")}else if(n&&n.readyState==="ended")throw new It("track ended");if(n===o(this,gt)){p.debug(`replaceTrack() | same track, ignored trackId: ${n.id}`,o(this,rn,kn));return}(!o(this,_s)||!o(this,bi))&&(yield o(this,xn).replaceTrack(this.localId,n)),this._destroyTrack(),v(this,gt,n),this._handleTrack()})}setMaxSpatialLayer(e){return u(this,null,function*(){if(o(this,Tn))throw new It("closed");if(this.kind!=="video")throw new za("not a video Producer");if(typeof e!="number")throw new TypeError("invalid spatialLayer");yield o(this,xn).setMaxSpatialLayer(this.localId,e),v(this,Za,e)})}setRtpEncodingParameters(e){return u(this,null,function*(){if(o(this,Tn))throw new It("closed");if(typeof e!="object")throw new TypeError("invalid params");yield o(this,xn).setRtpEncodingParameters(this.localId,e)})}_onTrackEnded(){p.debug(`Producer::track "ended" event trackId: ${this.track.id}`,o(this,rn,kn)),this.safeEmit("trackended",this.track.id)}_handleTrack(){o(this,gt)&&o(this,gt).addEventListener("ended",this._onTrackEnded)}_destroyTrack(){var e;if(o(this,gt))try{o(this,gt).removeEventListener("ended",this._onTrackEnded),o(this,Qa)&&o(this,gt).stop()}catch(n){p.error(`Producer::_destroyTrack trackId: ${(e=this.track)==null?void 0:e.id}`,J(V({},o(this,rn,kn)),{error:n}))}}}xn=new WeakMap,Qa=new WeakMap,Xa=new WeakMap,_s=new WeakMap,Tn=new WeakMap,gt=new WeakMap,bi=new WeakMap,Za=new WeakMap,rn=new WeakSet,kn=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 Mh(t){return Math.random().toString(36).substring(2,2+t)}const Md=1;function gy(t){const e=t;return delete e.payload._bolt,e}function kN(t){return t.payload&&my(t.payload)}function fy(t){var e,n;return kN(t)&&(n=(e=t.payload._bolt)==null?void 0:e.id)!=null?n:""}var wi;const eo=class extends ut.EventEmitter{constructor(t,e,n){super(),m(this,"channel"),m(this,"queue"),m(this,"serverProtocolVersion"),f(this,wi,new Map),m(this,"respond",(r,i,s=!1)=>{let a;s?a=eo.createErrorResponse(r,i):a=eo.createResponse(r,i),this.channel.send(JSON.stringify(a))}),m(this,"notify",r=>{const i=eo.createNotification(r);this.channel.send(JSON.stringify(i))}),m(this,"request",r=>u(this,null,function*(){const i=eo.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=ji();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,wi).has(r.id)||o(this,wi).set(r.id,[]);const s=o(this,wi).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,wi).get(r.id),c=a==null?void 0:a.reduce((l,h)=>l+h.chunk,"");o(this,wi).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(gy(r)):s.resolve(gy(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:Mh(8),{type:"_bolt",payload:{message:"pong"}}),!0):!1}),this.label=e,this.transportId=n,this.channel=t,this.queue=new Map}};let to=eo;wi=new WeakMap,m(to,"createRequest",t=>{var e;if((e=t.payload)!=null&&e._bolt)throw new Error("rpc fields are internal values");return{type:t.type,payload:J(V({},t.payload),{_bolt:{id:Mh(8),type:"REQUEST",version:Md}})}}),m(to,"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:J(V({},e.payload),{_bolt:{id:t,type:"RESPONSE",version:Md}})}}),m(to,"createNotification",t=>{var e;if((e=t.payload)!=null&&e._bolt)throw new Error("rpc fields are internal values");return{type:t.type,payload:J(V({},t.payload),{bolt:{id:Mh(8),type:"NOTIFY",version:Md}})}}),m(to,"createErrorResponse",(t,e)=>({type:"error",payload:{error:e.message,_bolt:{id:t,type:"RESPONSE",version:Md}}}));function vy(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 Ah="transport closed";var no;class bN extends Ya{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,no,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,no,e),this.id=n,this.direction=r;const b=SN(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 wd,this.observer=new Ya,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 to(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 x=JSON.parse(R);p.debug("datachannel message chunk recieved",{dataChannelMessageChunk:{id:x.id,count:x.count,chunkIndex:x.chunkIndex,chunk:x.chunk,transprtId:this.serverId}});const G=B.processMessage(x);if(!G)return;p.debug(`datachannel message with id:${x.id} on transport:${this.serverId}complete - ${JSON.stringify(G)}`),this.emit(`datachannel:${P.label}`,B.label,G)}catch(x){p.error("error parsing message",{error:x})}})}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(Ah).catch(()=>{})}),this.producers.clear(),Array.from(this.consumers.values()).forEach(e=>{e.close(Ah)}),this.consumers.clear(),this.consumerTrackEvents.clear(),this.emit("close"),this.observer.emit("close"))}getStats(){return u(this,null,function*(){if(this.closed)throw new It("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,no)===tt.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 It("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 za("not a sending Transport");if(n.readyState==="ended")throw new It("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 bs("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:x}=yield n({offer:E,kind:r.kind,paused:c?!r.enabled:!1,appData:J(V({},l||{}),{mid:R}),codecOptions:s,producingTransportId:this.serverId}),G=yield b(B);return{producerId:x,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 TN(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 It("closed");if(this.direction!=="recv")throw new za("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 bs("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(J(V({},c),{producerId:d})))}),a&&(yield r(a)),vy(i)}),"consumer")})}setRemoteOffer(e){return u(this,null,function*(){yield this.setRemoteDescription(e);const n=yield this.handler.pc.createAnswer(),r=Dl(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=Jp(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,no)===tt.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=J(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,I)=>{try{if(G.readyState==="ended")clearTimeout(R),P(E);else{const ne=G;ne.enabled=!0,this.handler.midTransceiverMap.set(I.mid,I);const se=new EN({id:n,localId:I.mid,transceiver:I,track:ne,paused:c,producerId:r,producingPeerId:i,producingTransportId:s,handler:this.handler,appData:J(V({},l),{screenShare:d,peerId:i}),rtpReceiver:I.receiver,mimeType:g});this.consumers.set(n,se),se.once("close",()=>{this.consumers.delete(se.id),this.handler.midTransceiverMap.delete(I.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(ne){p.warn("error while creating consumer:",ne),clearTimeout(R),P(E)}},x=this.unknownTracksMap.get(y);x?(this.unknownTracksMap.delete(y),B(x.track,x.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 vy(e.map(n=>u(this,null,function*(){return bh(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 pN("DC_NOT_READY",`${e} datachannel not ready`);const i=(yield r.request(n)).payload;return p.info(`sendDataChannelMessage::response ${JSON.stringify(i)}`),i})}}no=new WeakMap;function wN(){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=_p.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 Ad;class _N{constructor(e,{handlerName:n,handlerFactory:r}={}){if(m(this,"handlerFactory"),f(this,Ad,void 0),p.debug("constructor()"),v(this,Ad,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=wN(),n)p.debug(`Device::constructor() | detected handler: ${n}`);else throw new Error("device not supported");switch(n){case"Chrome74":this.handlerFactory=_h.createFactory();break;case"Safari12":this.handlerFactory=Ih.createFactory();break;case"Firefox60":this.handlerFactory=Pd.createFactory({supportsSendEncodings:!1});break;case"Firefox110":this.handlerFactory=Pd.createFactory({supportsSendEncodings:!0});break;default:throw new TypeError(`unknown handlerName "${n}"`)}}}createTransport(e){const n=ji();return new bN(o(this,Ad),J(V({id:n},e),{handlerFactory:this.handlerFactory}))}}Ad=new WeakMap;const IN=2e3;var Or,ro,Vt,Ut,Is,io,so,ao,Ps,_i,oo,co,Dd,Od,Dh,Oh,yy,Nh,Sy,Lh,Ey,xh,Ty,Vh,ky,Nd,Uh,Ld,Fh;class PN extends ut.EventEmitter{constructor(e,n,r){switch(super(),f(this,co),f(this,Od),f(this,Oh),f(this,Nh),f(this,Lh),f(this,xh),f(this,Vh),f(this,Nd),f(this,Ld),f(this,Or,void 0),f(this,ro,void 0),f(this,Vt,void 0),f(this,Ut,void 0),f(this,Is,void 0),f(this,io,void 0),f(this,so,void 0),f(this,ao,{transportFailureCount:{send:0,recv:0},lastConnectionTime:0}),f(this,Ps,void 0),f(this,_i,"all"),f(this,oo,void 0),v(this,Or,e),v(this,Is,n),v(this,oo,r),v(this,ro,new _N(r)),v(this,io,new yN(n,r)),r){case tt.CF:{v(this,so,pn);break}case tt.HIVE:default:{v(this,so,Zt);break}}o(this,co,Dd).mediaState={send:{state:Rr.NEW,reconnected:!1},recv:{state:Rr.NEW,reconnected:!1}},X.hasFeature(ie.FORCE_RELAY)&&v(this,_i,"relay"),H(this,Od,Dh).call(this)}get socket(){return o(this,Is)}get socketHandler(){return o(this,io)}get sendTransport(){return o(this,Vt)}get recvTransport(){return o(this,Ut)}get events(){return o(this,so)}get nodeType(){return o(this,oo)}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,_i,"relay"));const h=yield ot().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,Nh,Sy).call(this,{iceServers:h,additionalSettings:{encodedInsertableStreams:(n=o(this,Or).getValue("modules").e2ee)==null?void 0:n.enabled},config:{enableHighBitrate:(s=(i=(r=o(this,Or).getValue("defaults").mediaConfiguration)==null?void 0:r.audio)==null?void 0:i.enableHighBitrate)!=null?s:!1,enableStereo:(d=(c=(a=o(this,Or).getValue("defaults").mediaConfiguration)==null?void 0:a.audio)==null?void 0:c.enableStereo)!=null?d:!1,enableDtx:o(this,oo)===tt.HIVE?!0:!!y},iceTransportPolicy:o(this,_i)});g.push(E)}if(e.recv){const y=H(this,Lh,Ey).call(this,{iceServers:h,additionalSettings:{encodedInsertableStreams:(l=o(this,Or).getValue("modules").e2ee)==null?void 0:l.enabled},iceTransportPolicy:o(this,_i)});g.push(y)}yield Promise.all(g)})}stopTransports(e){var n,r,i,s;e.send&&((n=o(this,Vt))==null||n.close(),(r=o(this,Vt))==null||r.removeAllListeners(),v(this,Vt,void 0)),e.recv&&((i=o(this,Ut))==null||i.close(),(s=o(this,Ut))==null||s.removeAllListeners(),v(this,Ut,void 0)),H(this,Od,Dh).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,xh,Ty).call(this,e);try{const a=X.hasFeature(ie.ENABLE_HIVE_INFINITE_RETRIES)?1/0:3;return yield bh((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,yy).call(this,e,n)}catch(l){if(l instanceof bs){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.")}}Or=new WeakMap,ro=new WeakMap,Vt=new WeakMap,Ut=new WeakMap,Is=new WeakMap,io=new WeakMap,so=new WeakMap,ao=new WeakMap,Ps=new WeakMap,_i=new WeakMap,oo=new WeakMap,co=new WeakSet,Dd=function(){return o(this,Or).getValue("connectionHandler")},Od=new WeakSet,Dh=function(){v(this,Ps,{send:void 0,recv:void 0})},Oh=new WeakSet,yy=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,Is).isConnected)throw new bs("Socket is not connected");if(t.connectionState==="closed")throw new bs("Transport is closed");try{yield t.connect(s=>H(this,Vh,ky).call(this,i,s,e),e),p.info(`Connected ${i} transport`,{transport:{id:n,serverId:r,type:i}})}catch(s){throw o(this,ao).transportFailureCount[i]+=1,s.message==="ice connection failed"?new bs(s.message):s}})},Nh=new WeakSet,Sy=function(t){return u(this,null,function*(){var e,n;if(o(this,Vt)&&o(this,Vt).connected){p.info("Transport send 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:"send"}});return}v(this,Vt,yield o(this,ro).createTransport(J(V({},t),{direction:"send"}))),$.configureSendTransport(o(this,Vt))})},Lh=new WeakSet,Ey=function(t){return u(this,null,function*(){var e,n;if(o(this,Ut)&&o(this,Ut).connected){p.info("Transport recv is already connected",{transport:{id:(e=o(this,Ut))==null?void 0:e.id,serverId:(n=o(this,Ut))==null?void 0:n.serverId,type:"recv"}});return}v(this,Ut,yield o(this,ro).createTransport(J(V({},t),{direction:"recv"}))),$.configureRecvTransport(o(this,Ut))})},xh=new WeakSet,Ty=function(t){const{direction:e,id:n}=t;t.on("connectionstatechange",r=>u(this,null,function*(){H(this,Ld,Fh).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,Ps)[e];s!==void 0&&(clearTimeout(s),o(this,Ps)[e]=void 0)};switch(r){case"connected":i(),o(this,ao).lastConnectionTime=performance.now();break;case"disconnected":o(this,Ps)[e]=setTimeout(()=>u(this,null,function*(){yield H(this,Nd,Uh).call(this,t)}),IN);break;case"failed":if(t.closed)return;i(),yield H(this,Nd,Uh).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,fy(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(c){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"))})},Vh=new WeakSet,ky=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?Sr.SUBSCRIBER:Sr.PUBLISHER},producers:[]};return!r&&n&&(a.producers=n),o(this,io).connectTransport(a)}catch(i){throw p.error(`Error in ${t} transport connection:`,{error:i,country:S.location.country}),i}})},Nd=new WeakSet,Uh=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,Is).isConnected&&o(this,ao).transportFailureCount[e]>2&&(p.warn(`Multiple disconnections in ${e} transport, forcing relay`),v(this,_i,"relay")),yield this.createTransports({[e]:!0}),e){case"send":{yield this.connectTransportWithRetry(o(this,Vt)),p.info("Transport reconnected",{transport:o(this,Vt)}),M.emit(A.RESET_PRODUCER_STATE);break}case"recv":{yield this.connectTransportWithRetry(o(this,Ut)),p.info("Transport reconnected",{transport:o(this,Ut)}),M.emit(A.UPDATE_ACTIVE,{createAllConsumers:!0});break}default:p.warn("Unknown transport direction",{transport:t})}H(this,Ld,Fh).call(this,{state:Rr.CONNECTED,direction:e})})},Ld=new WeakSet,Fh=function(t){const{state:e,direction:n}=t;o(this,co,Dd).mediaState[n]={state:e,reconnected:!0},M.emit(A.TRANSPORT_STATE_UPDATE,V({transport:n},o(this,co,Dd).mediaState[n]))};var Bh,by;class CN{constructor(e){f(this,Bh),this.recvTransport=e,H(this,Bh,by).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}})}}Bh=new WeakSet,by=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,fy(e),t);break}default:break}}catch(n){p.error(`Unable to handle the incoming datachannel message on channel ${t}`)}}))};class RN{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(g){}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:Sr.SUBSCRIBER}};return p.debug(`sending renegotiate request: ${JSON.stringify(r)} on recvTransport`,{transport:this.recvTransport}),yield this.socket.sendMessagePromise(this.events.renegotiateSessionDescription,rP.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 xd{constructor(e){this.socketHandler=e}static getMSIDFromSDP(e,n){return Dl(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=xd.getMSIDFromSDP(n.sdp,r),g={description:{sdp:n.sdp,type:n.type,target:Sr.PUBLISHER},paused:i,kind:r,msid:h,appData:JSON.stringify(s),screenShare:(d=s.screenShare)!=null?d:!1,mimeType:`${r}/${(l=a[0])==null?void 0:l.name}`,producingTransportId:c},{answer:y,producerId:E}=yield this.socketHandler.produce(g);return{answer:y,producerId:E}})}}const MN=3;var lo,Cs,Ii,uo,Vd,sr,Ud,Wh,wy,jh,_y,Hh,Iy,qh,Py,Fd,Gh,Bd,Jh,$h,Cy;class AN extends PN{constructor(e,n,r){super(e,n,r),f(this,Wh),f(this,jh),f(this,Hh),f(this,qh),f(this,Fd),f(this,Bd),f(this,$h),f(this,lo,void 0),f(this,Cs,void 0),f(this,Ii,void 0),f(this,uo,void 0),f(this,Vd,void 0),f(this,sr,void 0),f(this,Ud,{producerCreationFailureCount:0,consumerCreationFailureCount:0,producerNotReadyFailureCount:0}),v(this,lo,e),o(this,Wh,wy).mediaState={send:{state:Rr.NEW,reconnected:!1},recv:{state:Rr.NEW,reconnected:!1}},this.reset()}get socketHandler(){return super.socketHandler}get producers(){return o(this,Cs)}get consumers(){return o(this,Ii)}get producerIdToConsumerIdMap(){return o(this,uo)}reset(){v(this,Cs,new Map),v(this,Ii,new Map),v(this,uo,new Map)}setupTransports(e,n){return u(this,null,function*(){yield this.createTransports(e);let r,i;e.send&&(r=H(this,jh,_y).call(this,n)),e.recv&&(i=H(this,Hh,Iy).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,qh,Py).bind(this));return(r=e.appData)!=null&&r.e2ee&&M.emit(A.E2EE_ACTIVE_PRODUCER,i),H(this,Fd,Gh).call(this,i,n),i}catch(i){throw p.error("Failed to create producer",{error:i}),o(this,Ud).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,lo).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,Cs).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,Bd,Jh).bind(this),o(this,sr).negotiate.bind(o(this,sr)))).forEach(r=>{r.status!=="rejected"&&H(this,$h,Cy).call(this,r.value)})}catch(n){}})}closeConsumer(e){return this.closeConsumers([e])}closeConsumers(e){return u(this,null,function*(){if(!o(this,sr))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,sr).close(n);r!=null&&r.length&&p.warn("Failed to close some consumers",{consumerIds:r})})}closeAllConsumers(){return this.closeConsumers(Array.from(o(this,Ii).keys()))}switchConsumersToLayer(e,n){return u(this,null,function*(){const r=this.recvTransport.getDatachannel("events");if(!r){p.warn("events datachannel not found");return}const i={type:"switch_consumer_layer",payload:{consumerIds:e,layer:n}};yield r.request(i),p.info(`Consumers switched layers to ${n}`,{consumerIds:e})})}}lo=new WeakMap,Cs=new WeakMap,Ii=new WeakMap,uo=new WeakMap,Vd=new WeakMap,sr=new WeakMap,Ud=new WeakMap,Wh=new WeakSet,wy=function(){return o(this,lo).getValue("connectionHandler")},jh=new WeakSet,_y=function(t){return u(this,null,function*(){v(this,Vd,new xd(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:xd.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,Fd,Gh).call(this,i,t[r].onClose),i}):[]})},Hh=new WeakSet,Iy=function(){return u(this,null,function*(){switch(this.recvTransport.on("connect",()=>{o(this,uo).clear()}),yield this.connectTransportWithRetry(this.recvTransport),this.nodeType){case tt.CF:{v(this,sr,new RN(this.events,this.recvTransport,this.socket,this.socketHandler));break}case tt.HIVE:default:v(this,sr,new CN(this.recvTransport))}})},qh=new WeakSet,Py=function(t){return o(this,Vd).create(t)},Fd=new WeakSet,Gh=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:J(V({},t),{status:"closing"})});const c={producerId:t.id,description:{sdp:i.sdp,type:i.type,target:Sr.PUBLISHER}};try{const d=yield this.socketHandler.closeProducer(c),l={sdp:d==null?void 0:d.sdp,type:d==null?void 0:d.type};p.info("producer::closed",{producer:J(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:J(V({},t),{status:"UNKNOWN"})})}),o(this,Cs).set(t.id,t)},Bd=new WeakSet,Jh=function(t,e=0){return u(this,null,function*(){try{return yield this.recvTransport.canConsume(),yield o(this,sr).create(t)}catch(n){if(n instanceof mN&&(o(this,Ud).consumerCreationFailureCount+=1),e<=MN)return p.error(`Error in consume request attempt:${e}`,{error:n}),H(this,Bd,Jh).call(this,t,e+1);throw p.error("Error in consume request",{error:n}),n}})},$h=new WeakSet,Cy=function(t){t.on("close",e=>u(this,null,function*(){p.debug("consumer closed",{consumer:{closureReason:e,id:t.id,kind:t.kind,appData:t.appData}}),o(this,Ii).delete(t.id),M.emit(A.CONSUMER_CLOSED,{id:t.id})})),o(this,Ii).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 Wd,jd,Hd,ho,po,mo,qd,Gd,Rs,Yt,Vn,Un,Pi,Ci,Nr,Jd,Kh,Ry,zh,My,Yh,Ay,Qh,Dy;const Xh=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,Kh),f(this,zh),f(this,Wd,void 0),f(this,jd,void 0),f(this,Hd,void 0),f(this,ho,void 0),f(this,po,void 0),f(this,mo,void 0),f(this,qd,void 0),f(this,Gd,void 0),f(this,Rs,void 0),f(this,Yt,void 0),f(this,Vn,void 0),f(this,Un,!1),f(this,Pi,0),f(this,Ci,0),f(this,Nr,[]),f(this,Jd,void 0),v(this,ho,t),v(this,Yt,t),v(this,Wd,e),v(this,jd,n),v(this,Hd,r),v(this,po,i),v(this,mo,s),v(this,qd,a),v(this,Gd,c),v(this,Rs,d),v(this,Jd,l),v(this,Vn,t/2)}get voiceDetected(){return o(this,Un)}processAudioChunk(t){var e,n;const r=H(e=Xh,Yh,Ay).call(e,t),i=H(n=Xh,Qh,Dy).call(n,t);return H(this,Kh,Ry).call(this,r),r/o(this,Vn)>o(this,Rs)&&r>o(this,Yt)&&i>o(this,Wd)?(v(this,Pi,o(this,Pi)+1),v(this,Ci,o(this,Hd)),o(this,Pi)>=o(this,jd)&&v(this,Un,!0)):(v(this,Pi,0),o(this,Ci)>0?v(this,Ci,o(this,Ci)-1):o(this,Un)&&v(this,Un,!1),o(this,Un)||H(this,zh,My).call(this,r)),o(this,Un)}reset(){v(this,Un,!1),v(this,Pi,0),v(this,Ci,0),v(this,Yt,o(this,ho)),v(this,Vn,o(this,ho)/2),v(this,Nr,[])}getThresholdInfo(){return{currentEnergyThreshold:o(this,Yt),backgroundNoiseEnergy:o(this,Vn),energyRatioThreshold:o(this,Rs)}}};let Zh=Xh;Wd=new WeakMap,jd=new WeakMap,Hd=new WeakMap,ho=new WeakMap,po=new WeakMap,mo=new WeakMap,qd=new WeakMap,Gd=new WeakMap,Rs=new WeakMap,Yt=new WeakMap,Vn=new WeakMap,Un=new WeakMap,Pi=new WeakMap,Ci=new WeakMap,Nr=new WeakMap,Jd=new WeakMap,Kh=new WeakSet,Ry=function(t){o(this,Un)?v(this,Yt,o(this,mo)*o(this,Yt)+(1-o(this,mo))*t):v(this,Yt,o(this,po)*o(this,Yt)+(1-o(this,po))*(o(this,Vn)*o(this,Rs))),v(this,Yt,Math.max(o(this,qd),Math.min(o(this,Gd),o(this,Yt))))},zh=new WeakSet,My=function(t){if(t<o(this,Yt)*1.2)if(o(this,Nr).push(t),o(this,Nr).length>o(this,Jd)&&o(this,Nr).shift(),o(this,Nr).length>=10){const e=[...o(this,Nr)].sort((r,i)=>r-i),n=Math.floor(e.length/2);v(this,Vn,e[n])}else v(this,Vn,.95*o(this,Vn)+.05*t)},Yh=new WeakSet,Ay=function(t){return Math.sqrt(t.map(e=>e*e).reduce((e,n)=>e+n)/t.length)},Qh=new WeakSet,Dy=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(Zh,Yh),f(Zh,Qh);const DN=60,ON=400;var Ri,Mi,Ms,go,Ai,fo,vo,$d,Di,As,yo,ep,Oy,Kd,tp,np,Ny,rp,Ly,ip,xy;const So=class{constructor(t){f(this,ep),f(this,np),f(this,Ri,void 0),f(this,Mi,void 0),f(this,Ms,void 0),f(this,go,void 0),f(this,Ai,void 0),f(this,fo,void 0),f(this,vo,void 0),f(this,$d,void 0),f(this,Di,void 0),f(this,As,void 0),f(this,yo,void 0),this.reportRequest=t,v(this,go,new AudioContext),v(this,Ai,o(this,go).createAnalyser()),o(this,Ai).fftSize=2048,v(this,$d,new Zh)}set producerId(t){v(this,Ms,t)}set audioTrack(t){v(this,fo,t);const e=new MediaStream;e.addTrack(o(this,fo)),o(this,go).createMediaStreamSource(e).connect(o(this,Ai))}start(){o(this,Ri)&&Hi(o(this,Ri)),v(this,Ri,rc(()=>u(this,null,function*(){var t;if(!o(this,fo)||!o(this,Ms))return;const{energy:e}=H(this,ep,Oy).call(this),n=H(t=So,Kd,tp).call(t,e);let r=.9;o(this,yo)!==n&&o(this,yo)?r=.9:n?r=.3:r=.5,v(this,vo,(o(this,vo)||0)*(1-r)+e*r)}),DN)),o(this,Mi)&&Hi(o(this,Mi)),v(this,Mi,rc(H(this,np,Ny).bind(this),ON))}stop(){o(this,Ri)&&Hi(o(this,Ri)),o(this,Mi)&&Hi(o(this,Mi))}};let zd=So;Ri=new WeakMap,Mi=new WeakMap,Ms=new WeakMap,go=new WeakMap,Ai=new WeakMap,fo=new WeakMap,vo=new WeakMap,$d=new WeakMap,Di=new WeakMap,As=new WeakMap,yo=new WeakMap,ep=new WeakSet,Oy=function(){var t,e;const n=new Float32Array(o(this,Ai).frequencyBinCount);o(this,Ai).getFloatTimeDomainData(n);const r=o(this,$d).processAudioChunk(n),i=H(t=So,rp,Ly).call(t,n),s=H(e=So,ip,xy).call(e,i);return(!o(this,Di)||s<o(this,Di))&&v(this,Di,s),(!o(this,As)||s>o(this,As))&&v(this,As,s),{energy:(s-o(this,Di))/(o(this,As)-o(this,Di))*10||0,isVoice:r}},Kd=new WeakSet,tp=function(t){return t<5},np=new WeakSet,Ny=function(t=o(this,vo)){var e;if(!o(this,Ms)||!t)return;const n={producerId:o(this,Ms),energy:Math.round(t),silent:H(e=So,Kd,tp).call(e,t)};v(this,yo,n.silent),this.reportRequest(n)},rp=new WeakSet,Ly=function(t){return Math.sqrt(t.reduce((e,n)=>e+n*n,0)/t.length)},ip=new WeakSet,xy=function(t){const e=Math.log10(t);return Math.round(e)},f(zd,Kd),f(zd,rp),f(zd,ip);const NN=()=>{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]},LN=()=>{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 xN=Object.defineProperty,VN=Object.getOwnPropertyDescriptor,he=(t,e,n,r)=>{for(var i=r>1?void 0:r?VN(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&&xN(e,n,i),i};const Fn=["video/VP9","video/VP8"];var Yd,Qd,Pt,K,Eo,Oi,Ft,Ds,Os,Ni,Xd,Lr,To,Ns,Ls,Bt,sn,Li,xs,ft,Ct,Vs,ko,Zd,sp,el,ap;class ue{constructor(e,n,r){f(this,Li),f(this,ft),f(this,Vs),f(this,Zd),f(this,el),m(this,"context"),m(this,"authToken"),m(this,"e2ee"),f(this,Yd,void 0),f(this,Qd,void 0),f(this,Pt,void 0),f(this,K,void 0),f(this,Eo,void 0),f(this,Oi,void 0),f(this,Ft,void 0),f(this,Ds,void 0),f(this,Os,void 0),f(this,Ni,void 0),f(this,Xd,void 0),f(this,Lr,void 0),m(this,"maxPreferredStreams"),f(this,To,void 0),f(this,Ns,void 0),f(this,Ls,void 0),f(this,Bt,void 0),f(this,sn,void 0),m(this,"partialJoinRoomPromise");var i,s;this.context=e;const{socket:a}=r;this.mediaJoined=!1,v(this,Ns,new Map([["video/VP9",new Set],["video/VP8",new Set]])),v(this,Ls,new Map([["video/VP9",new Set],["video/VP8",new Set]])),v(this,Oi,n),v(this,Pt,a),v(this,Ds,!1),v(this,K,new AN(e,a,n)),v(this,Ft,o(this,K).events),this.maxPreferredStreams=6,v(this,Lr,new Set),v(this,Bt,new Map),v(this,Os,!1),v(this,Ni,new wd),n===tt.CF&&v(this,sn,new zd(o(this,K).socketHandler.audioActivity.bind(o(this,K).socketHandler))),this.e2ee=(s=(i=e.getValue("modules").e2ee)==null?void 0:i.enabled)!=null?s:!1,this.handleSocketEvents(),this.handleCallstatsEvents(),v(this,Xd,Oc(()=>u(this,null,function*(){if(!o(this,Li,xs).mediaJoinAttempted)return;const{roomJoined:c}=yield this.joinRoom(o(this,Qd),o(this,Yd),{},!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,Li,xs).mediaJoined}set mediaJoined(e){o(this,Li,xs).mediaJoined=e}reset(e=!0){o(this,K).closeAllProducers(),o(this,K).closeAllConsumers(),o(this,Lr).clear(),e&&(this.partialJoinRoomPromise=void 0,o(this,Ni).stop(),o(this,K).stopAllTransports(),o(this,K).reset(),v(this,Ni,new wd))}joinRoom(e,n){return u(this,arguments,function*(r,i,s={},a=!1,c=!1){o(this,Li,xs).mediaJoinAttempted=!0,v(this,Ds,!0),this.reset(a);const d=ot().ipInfo;if(d!=null&&d.loc&&!o(this,To)){const h=d.loc.split(",");v(this,To,{latitude:parseFloat(h[0]),longitude:parseFloat(h[1])})}let l;try{return l=yield o(this,Ni).push(()=>this._joinRoom(r,i,s,c,o(this,To)),"joinRoom"),l}catch(h){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}=ot();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=vN(d);v(this,Eo,l),this.maxPreferredStreams=this.context.getValue("maxPreferredStreams"),yield bh((E,b)=>u(this,null,function*(){if(!o(this,Pt).isConnected){b(new Error("socket is not connected"));return}E>0&&p.warn(`retrying sending join room request, count: ${E}`);try{yield o(this,K).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,Oi)!==tt.HIVE&&X.hasFeature(ie.PRECREATE_PRODUCERS)?[{type:fe.MIC,kind:"audio",options:H(this,Zd,sp).call(this,NN()),onClose:()=>this.disableMic()},{type:fe.WEBCAM,kind:"video",options:H(this,el,ap).call(this,LN(),h),onClose:()=>{this.disableWebcam(h)}}]:[],y=yield o(this,K).setupTransports({send:!0,recv:!0},g);y!=null&&y.length&&g.forEach((E,b)=>{o(this,Bt).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,Ni).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,Qd,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:J(V({},Ie.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,K).socketHandler.notifySelfJoinComplete();return v(this,Yd,n.roomUuid),v(this,Os,!0),v(this,Ds,!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,K).stopAllTransports(),v(this,Os,!1),o(this,Li,xs).mediaJoinAttempted=!1;const e={closeRoom:!1};o(this,Pt).sendMessagePromise(o(this,Ft).leaveRoom,PP.toBinary(e)).then(n=>{var r;(r=hC.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,K).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,K).producerIdToConsumerIdMap.get(s.producerId);if(!a){p.warn(`consumer not found in deactivate producers: ${s.producerId}`);return}return o(this,K).closeConsumer(a)}))})}createConsumers(e){return u(this,null,function*(){return e.length===0?Promise.resolve():o(this,K).createConsumers(e)})}closeConsumers(e){return u(this,null,function*(){if(!e.length)return;const n=e.reduce((r,i)=>{const s=o(this,K).producerIdToConsumerIdMap.get(i.producerId);return s?(r.push(s),r):(p.warn(`consumer not found in deactivate producers: ${i.producerId}`),r)},[]);yield o(this,K).closeConsumers(n)})}_shareWebcam(e,n){return u(this,null,function*(){const r=n==="video/VP9"?fe.WEBCAM:fe.WEBCAM_BACKUP,i=H(this,ft,Ct).call(this,r);if(i){const h=yield i;if(o(this,K).producers.has(h)){const g=o(this,K).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,el,ap).call(this,e,n),a=xc(this.context,"disableSimulcast"),c=o(this,Oi)===tt.CF?ie.ENABLE_CF_SIMULCAST:ie.ENABLE_HIVE_SIMULCAST;!a&&X.hasFeature(c)?(p.info(`Simulcast enabled for SFU: ${o(this,Oi)}`),s.encodings=uO(e)):p.info(`Simulcast disabled for webcam producer, SFU: ${o(this,Oi)}`),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,Bt).delete(r)},l=o(this,K).createProducer(s,d);return H(this,Vs,ko).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(Fn.map(n=>{var r,i;return((i=(r=o(this,Eo).sender)==null?void 0:r.video)==null?void 0:i.codecs.findIndex(s=>s.mimeType===n))>=0&&o(this,Ls).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:Ie.isElectron()},stopTracks:!1},s=()=>{p.info("Disabling screenShare due to the producer closure"),o(this,Bt).delete(fe.SCREENSHARE_VIDEO),o(this,Bt).delete(fe.SCREENSHARE_AUDIO)},a=o(this,K).createProducer(i,s);H(this,Vs,ko).call(this,fe.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:Ie.isElectron()},stopTracks:!1,zeroRtpOnPause:!0},l=()=>{};c=o(this,K).createProducer(d,l),H(this,Vs,ko).call(this,fe.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 It("track undefined");const n=H(this,ft,Ct).call(this,fe.MIC);if(n){const a=yield n;if(o(this,K).producers.has(a)){const c=o(this,K).producers.get(a);if(!c.closed&&!navigator.isReactNative){yield c.replaceTrack({track:e}),yield this.resumeMic(),o(this,sn)&&(o(this,sn).audioTrack=e,o(this,sn).producerId=a,o(this,sn).start());return}yield o(this,K).closeProducer(a,{stopTrack:!1})}yield this.shareMic(e);return}const r=H(this,Zd,sp).call(this,e),i=()=>{o(this,Bt).delete(fe.MIC)},s=o(this,K).createProducer(r,i);H(this,Vs,ko).call(this,fe.MIC,s.then(a=>a.id)),yield s.then(a=>{o(this,sn)&&(o(this,sn).audioTrack=a.track,o(this,sn).producerId=a.id,o(this,sn).start())})}catch(n){throw new _(n)}})}pauseMic(){return u(this,null,function*(){const e=yield H(this,ft,Ct).call(this,fe.MIC),n=o(this,K).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,Pt).sendMessage(o(this,Ft).toggleProducer,Bc.toBinary(r))})}pauseWebcam(){return u(this,null,function*(){const e=yield H(this,ft,Ct).call(this,fe.WEBCAM),n=yield H(this,ft,Ct).call(this,fe.WEBCAM_BACKUP),r=o(this,K).producers.get(e),i=o(this,K).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,Pt).sendMessage(o(this,Ft).toggleProducer,Bc.toBinary(c))};r&&(r.pause(),s(r)),i&&(i.pause(),s(i))})}resumeMic(){return u(this,null,function*(){const e=yield H(this,ft,Ct).call(this,fe.MIC),n=o(this,K).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,Pt).sendMessage(o(this,Ft).toggleProducer,Bc.toBinary(r))})}resumeWebcam(){return u(this,arguments,function*(e=fe.WEBCAM){const n=yield H(this,ft,Ct).call(this,e),r=o(this,K).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,Pt).sendMessage(o(this,Ft).toggleProducer,Bc.toBinary(i))})}disableWebcam(e){return u(this,null,function*(){const n=e==="video/VP9"?fe.WEBCAM:fe.WEBCAM_BACKUP,r=yield H(this,ft,Ct).call(this,n);r&&(yield o(this,K).closeProducer(r)),o(this,Bt).delete(n)})}disableMic(){return u(this,null,function*(){var e;const n=yield H(this,ft,Ct).call(this,fe.MIC);n&&(yield o(this,K).closeProducer(n)),(e=o(this,sn))==null||e.stop(),o(this,Bt).delete(fe.MIC)})}disableScreenShare(){return u(this,null,function*(){p.info("screen_sharing_stopped"),$.screenShareStop();const e=yield H(this,ft,Ct).call(this,fe.SCREENSHARE_VIDEO),n=yield H(this,ft,Ct).call(this,fe.SCREENSHARE_AUDIO);e&&(yield o(this,K).closeProducer(e)),n&&(yield o(this,K).closeProducer(n)),o(this,Lr).clear(),o(this,Bt).delete(fe.SCREENSHARE_VIDEO),o(this,Bt).delete(fe.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,ft,Ct).call(this,fe.WEBCAM),i=yield H(this,ft,Ct).call(this,fe.WEBCAM_BACKUP);yield o(this,K).closeProducer(r,{stopTrack:!1}),yield o(this,K).closeProducer(i,{stopTrack:!1}),this.shareWebcam(e)}if(n){const r=yield H(this,ft,Ct).call(this,fe.SCREENSHARE_VIDEO);yield o(this,K).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,K).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,K).socketHandler.kickPeer(n)))throw new Error("failed to kickout the participant!")})}kickAll(){return u(this,null,function*(){if(!(yield o(this,K).socketHandler.kickAll()))throw new Error("failed to kickout all participant!")})}muteAll(e){return u(this,null,function*(){if(!(yield o(this,K).socketHandler.hostControlForAll("audio")))throw new Error("failed to mute all participant")})}muteAllVideo(){return u(this,null,function*(){if(!(yield o(this,K).socketHandler.hostControlForAll("video")))throw new Error("failed to mute all video participant")})}disableAudio(e){return u(this,null,function*(){if(!(yield o(this,K).socketHandler.hostControlForPeer(e,"audio")))throw new Error("failed to mute given participant")})}disableVideo(e){return u(this,null,function*(){if(!(yield o(this,K).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,Pt).sendMessagePromise(o(this,Ft).globalPinPeer,VP.toBinary(n))}catch(r){p.error("Error in pinning peer:",{error:r})}})}validateScreenShare(e){return this.peerId===e.peerId&&o(this,K).producers.get(e.producerId)&&o(this,Lr).add(e.consumerPeerId),o(this,Lr).size}switchConsumersToLayer(e,n){return u(this,null,function*(){o(this,K).switchConsumersToLayer(e,n)})}handleSocketEvents(){return u(this,null,function*(){o(this,Pt).on(o(this,Ft).peerProducerCreateBroadcast,({payload:e})=>{var n,r;if(this.mediaJoined)try{const{participantId:i,producerState:s}=HC.fromBinary(e);if(i===this.peerId)return;if(s!=null&&s.mimeType||(s.mimeType=s.kind===Nn.AUDIO?"audio/opus":"video/VP8"),s.kind===Nn.VIDEO&&!s.screenShare&&((r=(n=o(this,Eo).receiver)==null?void 0:n.video)==null?void 0:r.codecs.findIndex(a=>a.mimeType===Fn[0]))>=0&&o(this,Ns).get(Fn[0]).has(i)&&s.mimeType!==Fn[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:J(V({},s),{kind:s.kind===Nn.AUDIO?"audio":"video",producingPeerId:i})})}catch(i){p.error("error in peer-producer-create-broadcast",{error:i})}}),o(this,Pt).on(o(this,Ft).peerProducerToggleBroadcast,({payload:e})=>{if(this.mediaJoined)try{const{participantId:n,initiatorParticipantId:r,producerState:{kind:i,pause:s,producerId:a}}=zf.fromBinary(e),c=i===Nn.AUDIO?"audio":"video";if(p.info(`producer toggle broadcast: ${n}, producerId: ${a}, kind:${c}, paused:${s} payload: ${JSON.stringify(zf.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,Pt).on(o(this,Ft).peerLeaveBroadcast,({payload:e})=>{if(this.mediaJoined)try{const{participantId:n}=Cu.fromBinary(e);if(n===this.peerId)return;p.info(`peer left broadcast:${n}`),o(this,Lr).delete(n),o(this,K).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,Pt).on(o(this,Ft).peerProducerCloseBroadcast,({payload:e})=>{if(this.mediaJoined)try{const{participantId:n,producerState:{producerId:r}}=JC.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,K).producerIdToConsumerIdMap.get(r);if(!i){p.warn(`no consumer found for producer:${r}`);return}p.info(`closing consumer ${i}, producer id: ${r}`),o(this,K).closeConsumer(i).then(()=>{p.info(`closed consumer: ${i}`),o(this,K).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,Pt).on(o(this,Ft).mediaRoomTerminationBroadcastResponse,()=>{!this.mediaJoined&&!o(this,Ds)&&!o(this,Os)||(p.warn("media hub termination broadcast received, rejoining room"),M.emit(A.ROOM_NODE_DISCONNECTED),o(this,Xd).call(this))})})}handleCallstatsEvents(){$.onConsumerScore(e=>{e.forEach((n,r)=>{const i=o(this,K).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,K).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<=Fn.length;c+=1){const d=Fn[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===Fn.length-1){o(this,Ls).get(d).add(e);break}}for(let c=0;c<=Fn.length;c+=1){const d=Fn[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===Fn.length-1){o(this,Ns).get(d).add(e);break}}}handlePeerLeaving(e){X.hasFeature(ie.FORCE_VIDEO_CODEC)||(o(this,Ns).forEach(n=>n.delete(e)),o(this,Ls).forEach((n,r)=>{n.delete(e),n.size===0&&this.disableWebcam(r)}))}}Yd=new WeakMap,Qd=new WeakMap,Pt=new WeakMap,K=new WeakMap,Eo=new WeakMap,Oi=new WeakMap,Ft=new WeakMap,Ds=new WeakMap,Os=new WeakMap,Ni=new WeakMap,Xd=new WeakMap,Lr=new WeakMap,To=new WeakMap,Ns=new WeakMap,Ls=new WeakMap,Bt=new WeakMap,sn=new WeakMap,Li=new WeakSet,xs=function(){return this.context.getValue("connectionHandler")},ft=new WeakSet,Ct=function(t){return o(this,Bt).get(t)},Vs=new WeakSet,ko=function(t,e){return o(this,Bt).set(t,e)},Zd=new WeakSet,sp=function(t){return{track:t,encodings:[{priority:"high"}],codecOptions:[{name:"opus"}],appData:{e2ee:this.e2ee},stopTracks:!1,zeroRtpOnPause:!0}},el=new WeakSet,ap=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 Vy(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 Uy(t){const e=t.getValue("roomNodeClient");try{e==null||e.leaveRoom()}catch(n){p.error("roomNodeClient::cleanupRoomNodeClient")}t.setValue("roomNodeClient",void 0)}var UN=Object.defineProperty,FN=Object.getOwnPropertyDescriptor,xi=(t,e,n,r)=>{for(var i=r>1?void 0:r?FN(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&&UN(e,n,i),i},Vi,Bn,Rt,an,bn,Fy;const By=(Fy=class{constructor(t,e,n,r){f(this,an),m(this,"self"),m(this,"authToken"),f(this,Vi,void 0),m(this,"viewType"),f(this,Bn,void 0),f(this,Rt,void 0);const{socket:i}=n,s=t.getValue("authToken");this.self=e,v(this,Rt,t),this.viewType=r,this.authToken=s,v(this,Vi,i),v(this,Bn,n),e.config.viewType!==yt.Chat&&this.setupEvents()}get peerId(){return o(this,Rt).getValue("peerId")}get mediaJoined(){return o(this,Rt).getValue("connectionHandler").mediaJoined}static init(t,e,n,r,i){return u(this,null,function*(){const s=ot(),a=t.getValue("peerId"),c=!!t.getValue("cachedUserDetails"),d=yield rt.__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:Ie.getDeviceInfo().engineName,env:t.getValue("env"),iceServers:yield s.getICEServers(),apiBase:t.getValue("apiBase"),flags:X.getAllFlags(),logger:p,apiHostnames:Of(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 By(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,an,bn).shareMic(e)}catch(d){this.self.disableAudio()}if(r.canProduceVideo&&s)try{const d=yield o(this,an,bn).shareWebcam(n);d&&d.id!==n.id&&X.hasFeature(ie.EXP_RESHARE)&&(yield o(this,an,bn).shareWebcam(d))}catch(d){this.self.disableVideo()}if(r.canProduceScreenshare&&a)try{yield(t=o(this,an,bn))==null?void 0:t.shareScreen({video:c.video,audio:c.audio})}catch(d){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,an,bn).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=ji()),o(this,Vi).updateURL(e),S.resetPeerId(e),ot().setHeader("dyte-tracing-id",e),ei.remapContext(e,o(this,Rt)),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,Bn).on(W.waitingRoomRequestAccepted,()=>{this.waitlistAcceptHandler()}),o(this,Bn).on(Jc.updateUserPreset,t=>{t.updatePeersPresets.forEach(e=>{e.userIds===this.self.userId&&M.emit(A.UPDATE_PERMISSIONS,e.patch)})}),o(this,Bn).on(W.waitingRoomRequestDenied,()=>{this.waitlistRejectedHandler()}),o(this,Bn).on(W.kick,()=>{this.kickHandler({kickType:"kick"})}),o(this,Bn).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,Bn).joinRoom(this.self);o(this,Bn).socket.flush();const n=th(e.stageType);if(o(this,Rt).setValue("stageStatus",n,!1),e.waitlisted){this.waitlistedHandler();return}yield this.joinMediaRoom(t),o(this,Rt).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,Vi))==null||e.disconnect()}catch(r){p.error("SelfController::leaveRoom::socketDisconnect")}this.self.roomState=t,this.self.emit("roomLeft",{state:t});return}this.self.setIsPinned(!1),o(this,Rt).setValue("stageStatus","OFF_STAGE",!1),yield this.leaveMediaRoom(t),o(this,Rt).notify("stageStatus");try{(n=o(this,Vi))==null||n.disconnect()}catch(r){p.error("SelfController::leaveRoom::socketDisconnect")}Uy(o(this,Rt)),kd.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,Rt).getAllValues(),{sfu:d}=c;try{if(i===yt.Livestream){if(a!=="ON_STAGE"){this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:t});return}Vy(o(this,Rt),d,{socket:o(this,Vi),peerId:r})}const{roomJoined:l}=(n=yield(e=o(this,an,bn))==null?void 0:e.joinRoom(this.self.name,s,{audio:this.self.audioEnabled,video:this.self.videoEnabled,screen:this.self.screenShareEnabled},t,t))!=null?n:{};if(!l)return;a==="ON_STAGE"&&(yield this.shareMediaTracks()),this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:t})}catch(l){throw p.error("Error:SelfController.mediaRoomJoin",l),new _("Error: could not join media room","0002")}})}leaveMediaRoom(t){return u(this,null,function*(){const e=o(this,Rt).getValue("viewType");t!=="connected-meeting"&&(yield this.cleanupSelf()),!(t==="stageLeft"&&e===yt.Webinar)&&o(this,an,bn)&&(o(this,an,bn).mediaJoined&&t!=="disconnected"&&(yield o(this,an,bn).leaveRoom()),!(t==="stageLeft"&&e===yt.Livestream)&&(o(this,an,bn).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()})}},Vi=new WeakMap,Bn=new WeakMap,Rt=new WeakMap,an=new WeakSet,bn=function(){return o(this,Rt).getValue("roomNodeClient")},Fy);let xr=By;xi([S.trace("SelfController.resetSelf")],xr.prototype,"resetSelf",1),xi([S.trace("SelfController.setupEvents")],xr.prototype,"setupEvents",1),xi([S.trace("SelfController.joinRoom")],xr.prototype,"joinRoom",1),xi([S.trace("SelfController.leaveRoom")],xr.prototype,"leaveRoom",1),xi([S.trace("SelfController.joinMediaRoom")],xr.prototype,"joinMediaRoom",1),xi([S.trace("SelfController.leaveMediaRoom")],xr.prototype,"leaveMediaRoom",1),xi([S.trace("SelfController.init")],xr,"init",1);var tl;class BN{constructor(e){f(this,tl,void 0),v(this,tl,e)}on(e,n){let r;e===W.roomPeerCount?r=Xf.fromBinary.bind(Xf):r=mv.fromBinary.bind(mv),o(this,tl).on(e,({payload:i})=>{const s=r(i);return n(s)})}}tl=new WeakMap;var nl;class WN{constructor(e){f(this,nl,void 0),v(this,nl,e)}on(e,n){let r,i;switch(e){case W.transcript:{r=Ru.fromBinary.bind(Ru),i=Ru.create();break}default:{p.debug("AISocketHandler switch case hit default, event not accounted for.");break}}o(this,nl).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)})}}nl=new WeakMap;var jN=Object.defineProperty,HN=Object.getOwnPropertyDescriptor,op=(t,e,n,r)=>{for(var i=r>1?void 0:r?HN(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&&jN(e,n,i),i},Vr;class rl{constructor(e){f(this,Vr,void 0),v(this,Vr,e)}getPolls(){return o(this,Vr).sendMessagePromise(zn.getPolls)}createPoll(e,n,r=!1,i=!1){const s={anonymous:r,hideVotes:i,question:e,options:n};return o(this,Vr).sendMessage(zn.createPoll,L1.toBinary(s))}votePoll(e,n){const r={index:n,pollId:e};return o(this,Vr).sendMessage(zn.votePoll,V1.toBinary(r))}on(e,n){let r,i;switch(e){case zn.updatePoll:case zn.createPoll:case zn.votePoll:{r=ju.fromBinary.bind(ju),i=ju.create();break}}o(this,Vr).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,Vr).removeListeners(e)}}Vr=new WeakMap,op([S.trace("PollSocketHandler.getPolls")],rl.prototype,"getPolls",1),op([S.trace("PollSocketHandler.createPoll")],rl.prototype,"createPoll",1),op([S.trace("PollSocketHandler.votePoll")],rl.prototype,"votePoll",1);var Qt;class qN{constructor(e){f(this,Qt,void 0),v(this,Qt,e)}getStageRequests(){return u(this,null,function*(){const{payload:e}=yield o(this,Qt).sendMessagePromise(W.getStageRequests);return e?Wu.fromBinary(e):{stageRequests:[]}})}requestAccess(){o(this,Qt).sendMessage(W.requestStageAccess)}cancelRequestAccess(){o(this,Qt).sendMessage(W.cancelStageRequest)}grantAccess(e){return u(this,null,function*(){const n={userIds:e};o(this,Qt).sendMessage(W.grantStageAccess,_1.toBinary(n))})}denyAccess(e){return u(this,null,function*(){const n={userIds:e};o(this,Qt).sendMessage(W.denyStageAccess,P1.toBinary(n))})}joinStage(){return o(this,Qt).sendMessagePromise(W.joinStage,void 0,void 0,W.peerStageStatusUpdate)}leaveStage(e){const n={userIds:[e]};return o(this,Qt).sendMessagePromise(W.leaveStage,fv.toBinary(n),void 0,W.peerStageStatusUpdate)}kick(e){const n={userIds:e};return o(this,Qt).sendMessagePromise(W.leaveStage,fv.toBinary(n))}on(e,n){let r;switch(e){case W.grantStageAccess:case W.denyStageAccess:{r=void 0;break}case W.getStagePeers:{r=gv.fromBinary.bind(gv);break}case W.getStageRequests:case W.requestStageAccess:case W.cancelStageRequest:{r=Wu.fromBinary.bind(Wu);break}case W.peerStageStatusUpdate:{r=Qf.fromBinary.bind(Qf);break}}o(this,Qt).on(e,({payload:i,id:s})=>{if(!i||!r)return n(void 0,s);const a=r(i);return n(a,s)})}getPeerInfo(e){return u(this,null,function*(){const n=yield o(this,Qt).sendMessagePromise(W.getPeerInfo,tv.toBinary({peerId:e}));return Zi.fromBinary(n.payload)})}}Qt=new WeakMap;var it;class GN{constructor(e){f(this,it,void 0),v(this,it,e)}addPlugin(e,n){o(this,it).sendMessage(z.addPlugin,jA.toBinary({pluginId:e,staggered:n}))}removePlugin(e){o(this,it).sendMessage(z.removePlugin,qA.toBinary({pluginId:e,staggered:!1}))}getActivePlugins(){return u(this,null,function*(){const{payload:e}=yield o(this,it).sendMessagePromise(z.getPlugins);return e?p1.fromBinary(e):{plugins:[]}})}customPluginEventToRoom(e,n,r){const i={pluginId:e,pluginData:new TextEncoder().encode(JSON.stringify(n))};o(this,it).sendMessage(z.customPluginEventToRoom,e1.toBinary(i),r)}customPluginEventToPeers(e,n,r,i){const s={pluginId:e,peerIds:n,pluginData:new TextEncoder().encode(JSON.stringify(r))};o(this,it).sendMessage(z.customPluginEventToPeers,n1.toBinary(s),i)}enablePluginForRoom(e,n){o(this,it).sendMessage(z.enablePluginForRoom,JA.toBinary({pluginId:e}),n)}enablePluginForPeers(e,n,r){o(this,it).sendMessage(z.enablePluginForPeers,YA.toBinary({pluginId:e,peerIds:n}),r)}disablePluginForRoom(e,n){o(this,it).sendMessage(z.disablePluginForRoom,KA.toBinary({pluginId:e}),n)}disablePluginForPeers(e,n,r){o(this,it).sendMessage(z.disablePluginForPeers,XA.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,it).sendMessage(z.storeInsertKeys,lv.toBinary(s),i)}storeGetKeys(e,n,r,i){const s={pluginId:e,storeName:n,getKeys:r.map(a=>({storeKey:a.key}))};o(this,it).sendMessage(z.storeGetKeys,a1.toBinary(s),i)}storeDeleteKeys(e,n,r,i){const s={pluginId:e,storeName:n,deleteKeys:r.map(a=>({storeKey:a.key}))};o(this,it).sendMessage(z.storeDeleteKeys,c1.toBinary(s),i)}storeDelete(e,n,r){o(this,it).sendMessage(z.storeDelete,l1.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,it).sendMessage(z.storeInsertKeys,lv.toBinary(i))}on(e,n){let r;switch(e){case z.addPlugin:case z.enablePluginForPeers:case z.enablePluginForRoom:{r=Bu.fromBinary.bind(Bu);break}case z.removePlugin:case z.disablePluginForPeers:case z.disablePluginForRoom:{r=uv.fromBinary.bind(uv);break}case z.customPluginEventToPeers:case z.customPluginEventToRoom:{r=pv.fromBinary.bind(pv);break}case z.storeInsertKeys:case z.storeGetKeys:case z.storeDeleteKeys:case z.storeDelete:{r=hv.fromBinary.bind(hv);break}}o(this,it).on(e,({payload:i,id:s})=>{const a=r(i);return n(a,s)})}}it=new WeakMap;var JN=Object.defineProperty,$N=(t,e,n)=>e in t?JN(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n,KN=(t,e,n)=>($N(t,typeof e!="symbol"?e+"":e,n),n),cp=(t,e,n)=>{if(!e.has(t))throw TypeError("Cannot "+n)},L=(t,e,n)=>(cp(t,e,"read from private field"),n?n.call(t):e.get(t)),Pe=(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)=>(cp(t,e,"write to private field"),r?r.call(t,n):e.set(t,n),n),Me=(t,e,n)=>(cp(t,e,"access private method"),n),il={},zN={get exports(){return il},set exports(t){il=t}},Us=typeof Reflect=="object"?Reflect:null,Wy=Us&&typeof Us.apply=="function"?Us.apply:function(t,e,n){return Function.prototype.apply.call(t,e,n)},sl;Us&&typeof Us.ownKeys=="function"?sl=Us.ownKeys:Object.getOwnPropertySymbols?sl=function(t){return Object.getOwnPropertyNames(t).concat(Object.getOwnPropertySymbols(t))}:sl=function(t){return Object.getOwnPropertyNames(t)};function YN(t){console&&console.warn&&console.warn(t)}var jy=Number.isNaN||function(t){return t!==t};function ve(){ve.init.call(this)}zN.exports=ve,il.once=eL,ve.EventEmitter=ve,ve.prototype._events=void 0,ve.prototype._eventsCount=0,ve.prototype._maxListeners=void 0;var Hy=10;function al(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 Hy},set:function(t){if(typeof t!="number"||t<0||jy(t))throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received '+t+".");Hy=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||jy(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 qy(t){return t._maxListeners===void 0?ve.defaultMaxListeners:t._maxListeners}ve.prototype.getMaxListeners=function(){return qy(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")Wy(c,this,e);else for(var d=c.length,l=zy(c,d),n=0;n<d;++n)Wy(l[n],this,e);return!0};function Gy(t,e,n,r){var i,s,a;if(al(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=qy(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,YN(c)}return t}ve.prototype.addListener=function(t,e){return Gy(this,t,e,!1)},ve.prototype.on=ve.prototype.addListener,ve.prototype.prependListener=function(t,e){return Gy(this,t,e,!0)};function QN(){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 Jy(t,e,n){var r={fired:!1,wrapFn:void 0,target:t,type:e,listener:n},i=QN.bind(r);return i.listener=n,r.wrapFn=i,i}ve.prototype.once=function(t,e){return al(e),this.on(t,Jy(this,t,e)),this},ve.prototype.prependOnceListener=function(t,e){return al(e),this.prependListener(t,Jy(this,t,e)),this},ve.prototype.removeListener=function(t,e){var n,r,i,s,a;if(al(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():XN(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 $y(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?ZN(i):zy(i,i.length)}ve.prototype.listeners=function(t){return $y(this,t,!0)},ve.prototype.rawListeners=function(t){return $y(this,t,!1)},ve.listenerCount=function(t,e){return typeof t.listenerCount=="function"?t.listenerCount(e):Ky.call(t,e)},ve.prototype.listenerCount=Ky;function Ky(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?sl(this._events):[]};function zy(t,e){for(var n=new Array(e),r=0;r<e;++r)n[r]=t[r];return n}function XN(t,e){for(;e+1<t.length;e++)t[e]=t[e+1];t.pop()}function ZN(t){for(var e=new Array(t.length),n=0;n<e.length;++n)e[n]=t[n].listener||t[n];return e}function eL(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))}Yy(t,e,s,{once:!0}),e!=="error"&&tL(t,i,{once:!0})})}function tL(t,e,n){typeof t.on=="function"&&Yy(t,"error",e,n)}function Yy(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 nL 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 Qy=new nL;class Xy{static encode(e){return Qy.toBinary(e)}static decode(e){return Qy.fromBinary(new Uint8Array(e))}}function rL(t,e){return Math.floor(Math.random()*(e-t+1)+t)}var Ur;class iL{constructor(e={}){KN(this,"opts"),Pe(this,Ur,void 0),this.opts={initialTimeout:e.initialTimeout||1e3,maxTimeout:e.maxTimeout||1e4,factor:e.factor||2},me(this,Ur,0)}wait(){return u(this,null,function*(){me(this,Ur,L(this,Ur)+1);const e=rL(0,Math.min(this.opts.maxTimeout,this.opts.initialTimeout*hE(2,L(this,Ur))));yield new Promise(n=>{setTimeout(n,e)})})}getAttempts(){return L(this,Ur)}reset(){me(this,Ur,0)}}Ur=new WeakMap;const Fr={debug:0,info:1,warn:2,error:3};var Ui,Fi;class sL{constructor(e){Pe(this,Ui,void 0),Pe(this,Fi,void 0),me(this,Ui,console),me(this,Fi,e)}debug(...e){Fr[L(this,Fi)]>Fr.debug||L(this,Ui).debug("[Sockrates]:",...e)}info(...e){Fr[L(this,Fi)]>Fr.info||L(this,Ui).info("[Sockrates]:",...e)}warn(...e){Fr[L(this,Fi)]>Fr.warn||L(this,Ui).warn("[Sockrates]:",...e)}error(...e){Fr[L(this,Fi)]>Fr.error||L(this,Ui).error("[Sockrates]:",...e)}}Ui=new WeakMap,Fi=new WeakMap;var Zy=(t=>(t[t.CONNECTING=0]="CONNECTING",t[t.OPEN=1]="OPEN",t[t.CLOSING=2]="CLOSING",t[t.CLOSED=3]="CLOSED",t))(Zy||{});const aL="2",oL="3";var xe,Fs,Ae,He,Br,st,ar,Wr,wn,Bs,or,dp,eS,bo,ol,lp,tS,up,nS,cl,hp,pp,rS,wo,dl,_o,ll,ul,mp,Ws,Io,Po,hl;class cL{constructor(e,n){var r;Pe(this,dp),Pe(this,bo),Pe(this,lp),Pe(this,up),Pe(this,cl),Pe(this,pp),Pe(this,wo),Pe(this,_o),Pe(this,ul),Pe(this,Ws),Pe(this,Po),Pe(this,xe,void 0),Pe(this,Fs,void 0),Pe(this,Ae,void 0),Pe(this,He,void 0),Pe(this,Br,void 0),Pe(this,st,void 0),Pe(this,ar,void 0),Pe(this,Wr,void 0),Pe(this,wn,void 0),Pe(this,Bs,void 0),Pe(this,or,void 0);var i,s,a,c,d,l,h,g,y;me(this,Fs,e),me(this,Br,[]),me(this,st,new il),me(this,ar,!0),me(this,wn,!1),me(this,Ae,n!=null?n:{}),(i=L(this,Ae)).autoReconnect!=null||(i.autoReconnect=!0),(s=L(this,Ae)).retryConnectionInterval!=null||(s.retryConnectionInterval=1e3),(a=L(this,Ae)).pingTimeout!=null||(a.pingTimeout=3e4),(c=L(this,Ae)).connectionTimeout!=null||(c.connectionTimeout=5e3),(d=L(this,Ae)).debug!=null||(d.debug=!0),(l=L(this,Ae)).maxReconnectionAttempts!=null||(l.maxReconnectionAttempts=10),(h=L(this,Ae)).disconnectOnPingTimeout!=null||(h.disconnectOnPingTimeout=!0),(g=L(this,Ae)).queueOnDisconnect!=null||(g.queueOnDisconnect=!1),(y=L(this,Ae)).flushOnReconnect!=null||(y.flushOnReconnect=!1),me(this,Wr,{code:void 0,reason:void 0}),me(this,He,(r=L(this,Ae).logger)!=null?r:new sL(L(this,Ae).debug?"debug":"info")),me(this,or,new iL)}get readyState(){var e;return(e=L(this,xe))==null?void 0:e.readyState}get url(){return L(this,Fs)}updateURL(e){me(this,Fs,e),Me(this,pp,rS).call(this)}get config(){return L(this,Ae)}get sendQueue(){return L(this,Br)}flush(){if(!L(this,Ae).queueOnDisconnect)return!1;const e=[];return L(this,Br).forEach(n=>{this.send(n.event,n.id,n.payload,n.metadata)||e.push(n)}),me(this,Br,e),L(this,Br)}connect(e=!1){return u(this,null,function*(){if(!e&&[0,1].includes(this.readyState)){L(this,He).debug("Websocket was already connecting or connected.");return}if(L(this,ar)!==!1)return new Promise((n,r)=>{Me(this,Ws,Io).call(this),Me(this,Po,hl).call(this);try{me(this,xe,new WebSocket(Me(this,dp,eS).call(this,L(this,Fs)))),L(this,xe).binaryType="arraybuffer",L(this,He).debug("Connecting");const i=setTimeout(()=>{L(this,He).debug("Connection timeout. Closing socket"),me(this,ar,!0),Me(this,Po,hl).call(this),L(this,xe).close(3001,"Connection Timeout"),L(this,Ae).autoReconnect&&!L(this,wn)&&(L(this,st).emit("reconnecting"),Me(this,wo,dl).call(this)),r(new Error("Connection timed out!"))},L(this,Ae).connectionTimeout);L(this,xe).onopen=()=>{L(this,He).debug(`Ready State: ${Zy[L(this,xe).readyState]}`),i&&clearTimeout(i),Me(this,ul,mp).call(this),me(this,Wr,{code:void 0,reason:void 0}),L(this,st).emit("connected"),L(this,Ae).flushOnReconnect&&this.flush(),n()},L(this,xe).onclose=s=>{try{i&&clearTimeout(i);const{code:a,reason:c}=s;r(c),L(this,He).debug("Socket closed. Close event:",{event:s}),L(this,He).debug(`Connection closed code: ${a}`),L(this,He).debug(`Connection closed reason: ${c}`),L(this,wn)||Me(this,cl,hp).call(this,a,c)}catch(a){Me(this,bo,ol).call(this,a)}},L(this,xe).onerror=s=>{Me(this,bo,ol).call(this,s)},L(this,xe).onmessage=s=>Me(this,lp,tS).call(this,s)}catch(i){Me(this,bo,ol).call(this,i,r)}})})}send(e,n,r,i){const s={event:e,id:n,payload:r,metadata:i};if(L(this,Ae).queueOnDisconnect&&(!L(this,xe)||L(this,xe).readyState!==1))return L(this,He).debug("Queuing message since socket is not connected!",s),L(this,Br).push(s),!1;const a=Xy.encode(s);return Me(this,_o,ll).call(this,a)}emit(e,n,r,i){return this.send(e,n,r,i)}sendRaw(e){return Me(this,_o,ll).call(this,e)}receive(e,n){return L(this,st).on(e.toString(),n)}on(e,n){if(typeof e=="string"&&(e==="connected"||e==="disconnected"||e==="errored"||e==="reconnected"||e==="reconnecting"||e==="reconnectAttempt"||e==="reconnectFailure"||e==="failed")){L(this,st).on(e,n);return}this.receive(e,n)}removeAllListeners(){L(this,st).removeAllListeners()}removeReceiver(e,n){this.removeListener(e,n)}removeListener(e,n){L(this,st).removeListener(e.toString(),n)}removeReceivers(e){this.removeListeners(e)}removeListeners(e){L(this,st).listeners(e.toString()).map(n=>this.removeListener(e,n))}disconnect(){me(this,ar,!1),Me(this,Ws,Io).call(this),this.removeAllListeners(),me(this,Wr,{code:1e3,reason:"Sockrates disconnect method called"}),L(this,xe).close(1e3,"Sockrates disconnect method called.")}}xe=new WeakMap,Fs=new WeakMap,Ae=new WeakMap,He=new WeakMap,Br=new WeakMap,st=new WeakMap,ar=new WeakMap,Wr=new WeakMap,wn=new WeakMap,Bs=new WeakMap,or=new WeakMap,dp=new WeakSet,eS=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)://.")},bo=new WeakSet,ol=function(t,e){L(this,He).error("Error:",{error:t}),L(this,st).emit("errored",{error:t}),e==null||e(t)},lp=new WeakSet,tS=function(t){if(Me(this,ul,mp).call(this),t.data===aL){L(this,He).debug("Received ping from server"),Me(this,_o,ll).call(this,oL);return}const e=Xy.decode(t.data),{id:n,payload:r}=e;L(this,He).debug("Received message",{event:e.event,messageID:n}),L(this,st).emit(e.event.toString(),{id:n,payload:r})},up=new WeakSet,nS=function(){return L(this,xe).readyState===1},cl=new WeakSet,hp=function(t,e){me(this,Wr,{reason:e,code:t}),L(this,st).emit("disconnected",{code:t,reason:e})},pp=new WeakSet,rS=function(){const{reason:t,code:e}=L(this,Wr);e&&e!==1e3&&L(this,ar)&&L(this,Ae).autoReconnect&&!L(this,wn)&&(L(this,He).debug(`Triggering reconnection due to ${t}.`),L(this,st).emit("reconnecting"),Me(this,wo,dl).call(this))},wo=new WeakSet,dl=function(t=!0){return u(this,null,function*(){if(t&&L(this,wn)){L(this,He).debug("Reconnect called when already in a reconnect loop. Ignoring.");return}if(L(this,wn)||L(this,or).reset(),L(this,Ae).maxReconnectionAttempts!==null&&L(this,or).getAttempts()>=L(this,Ae).maxReconnectionAttempts){L(this,st).emit("failed"),me(this,wn,!1);return}me(this,wn,!0),Me(this,Po,hl).call(this),Me(this,Ws,Io).call(this);try{if(yield L(this,or).wait(),L(this,ar)===!1)return;if(L(this,He).debug(`Reconnection attempt ${L(this,or).getAttempts()}`),L(this,st).emit("reconnectAttempt",{attempt:L(this,or).getAttempts()}),yield this.connect(),!Me(this,up,nS).call(this))throw Error("Reconnect Failed");me(this,wn,!1),me(this,Wr,{code:void 0,reason:void 0}),L(this,st).emit("reconnected")}catch(e){L(this,He).debug("Failed to reconnect."),L(this,st).emit("reconnectFailure",{attempt:L(this,or).getAttempts()}),Me(this,wo,dl).call(this,!1)}})},_o=new WeakSet,ll=function(t){try{return L(this,xe).send(t),!0}catch(e){return L(this,He).error(e.message),!1}},ul=new WeakSet,mp=function(){this.config.disconnectOnPingTimeout&&(L(this,He).debug("Resetting ping timeout"),Me(this,Ws,Io).call(this),me(this,Bs,setTimeout(()=>{var t;L(this,He).debug("Disconnecting the socket due to ping timeout"),me(this,ar,!0);const e=3002,n="Ping timeout";(t=L(this,xe))==null||t.close(e,n),Me(this,cl,hp).call(this,e,n)},L(this,Ae).pingTimeout)))},Ws=new WeakSet,Io=function(){L(this,Bs)&&(clearTimeout(L(this,Bs)),me(this,Bs,void 0))},Po=new WeakSet,hl=function(){L(this,xe)&&(L(this,xe).onopen=void 0,L(this,xe).onerror=void 0,L(this,xe).onmessage=void 0,L(this,xe).onclose=void 0)};var dL=Object.defineProperty,lL=Object.getOwnPropertyDescriptor,pl=(t,e,n,r)=>{for(var i=r>1?void 0:r?lL(e,n):e,s=t.length-1,a;s>=0;s--)(a=t[s])&&(i=(r?a(e,n,i):a(i))||i);return r&&i&&dL(e,n,i),i};const iS=65535,uL=3e3;var Bi,Ve,Ue,qe,_n,jr,ml,gp,gl,fp,sS;const aS=(sS=class{constructor(t,{peerId:e,meetingId:n,authToken:r,capabilities:i}){f(this,Ue),f(this,ml),f(this,gl),f(this,Bi,void 0),f(this,Ve,void 0),m(this,"roomName"),m(this,"authToken"),m(this,"capabilities"),f(this,_n,void 0),f(this,jr,void 0);var s;if(!e||!n||!r)throw new _("peerId, meetingId, or authToken can not be empty","0404");v(this,_n,void 0),v(this,jr,t),this.capabilities=i,this.roomName=n,this.authToken=r,v(this,Bi,H(this,ml,gp).call(this,e)),v(this,Ve,new cL(o(this,Bi),{autoReconnect:!0,disconnectOnPingTimeout:(s=i.includes("PING"))!=null?s:!1,queueOnDisconnect:!0,flushOnReconnect:!1,logger:p})),this.handleSocketConnectionEvents()}get joinAttempted(){return o(this,Ue,qe).socketJoinAttempted}set joinAttempted(t){o(this,Ue,qe).socketJoinAttempted=t}get peerId(){return o(this,jr).getValue("peerId")}updateURL(t){t!==this.peerId&&(v(this,Bi,H(this,ml,gp).call(this,t)),p.debug("SocketService:: Connection URL updated.")),o(this,Ve).updateURL(o(this,Bi))}static getSocketEdgeDomain(t){return Qi({servicePrefix:"socket-edge",baseURI:t})}get url(){return o(this,Bi)}connect(){return u(this,null,function*(){o(this,Ue,qe).socketJoinAttempted=!0,yield o(this,Ve).connect(),o(this,Ue,qe).socketJoinAttempted=!0,o(this,Ue,qe).socketState={state:"connected",reconnected:!1,reconnectionAttempt:void 0}})}disconnect(){return u(this,null,function*(){o(this,Ue,qe).socketJoinAttempted=!1,o(this,Ve).disconnect(),o(this,Ue,qe).socketJoinAttempted=!0,o(this,Ue,qe).socketState={state:"disconnected",reconnected:!1,reconnectionAttempt:void 0}})}get isConnected(){try{return o(this,Ve).readyState===1}catch(t){return!1}}sendMessage(t,e,n){const r={};return S.injectContext(r),o(this,Ve).send(t,n!=null?n:H(this,gl,fp).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,Ve).removeListener(s,E),o(this,Ve).removeListener(iS,b),o(this,Ve).removeListener(Zt.errorResponse,b),o(this,Ve).removeListener(pn.errorResponse,b)},l=r!=null?r:H(this,gl,fp).call(this),h={};S.injectContext(h);const g=({id:E,payload:b})=>{if(l===E){let P;try{const R=nC.fromBinary(b);P=new Error(R.errorMessage)}catch(R){P=new Error("failed to parse error message",{cause:R});try{const B=iR.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,Ve).on(s,y),o(this,Ve).on(iS,g),o(this,Ve).on(Zt.errorResponse,g),o(this,Ve).on(pn.errorResponse,g),setTimeout(()=>{d(y,g),c(new Error(`request timeout for callback eventId:${t}`))},e),o(this,Ve).send(t,l,n,new TextEncoder().encode(JSON.stringify(h)))})}on(t,e){o(this,Ve).on(t,e)}onStateEvent(t,e){o(this,Ve).on(t,e)}removeListener(t,e){o(this,Ve).removeListener(t,e)}removeListeners(t){o(this,Ve).removeListeners(t)}flush(){return o(this,Ve).flush()}handleSocketConnectionEvents(){this.onStateEvent("connected",()=>u(this,null,function*(){p.info("SocketService::Connected to socket-edge"),o(this,_n)&&(clearTimeout(o(this,_n)),v(this,_n,void 0)),o(this,Ue,qe).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,Ue,qe).mediaState)!=null?n:{};r!=null&&r.state&&(r==null?void 0:r.state)!==Rr.CONNECTED||i!=null&&i.state&&(i==null?void 0:i.state)!==Rr.CONNECTED?M.emit(A.SOCKET_SERVICE_DISCONNECTED,{joinAttempted:o(this,Ue,qe).joinAttempted}):v(this,_n,setTimeout(()=>{M.emit(A.SOCKET_SERVICE_DISCONNECTED,{joinAttempted:o(this,Ue,qe).joinAttempted}),v(this,_n,void 0)},uL)),o(this,Ue,qe).updateSocketConnectionState("disconnected")}),this.onStateEvent("reconnecting",()=>u(this,null,function*(){p.info("SocketService::Reconnecting to socket-edge",{country:S.location.country}),o(this,Ue,qe).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,Ue,qe).updateSocketConnectionState("reconnectAttempt",e)})),this.onStateEvent("reconnectFailure",({attempt:t})=>{p.info("SocketService::Reconnect attempt to socket-edge failed",{socket:{retryAttempt:t}}),o(this,Ue,qe).updateSocketConnectionState("reconnectFailure",t)}),this.onStateEvent("reconnected",()=>u(this,null,function*(){p.info("SocketService::Reconnected to socket-edge",{connectionState:{joinAttempted:o(this,Ue,qe).mediaJoinAttempted}}),o(this,_n)&&(clearTimeout(o(this,_n)),v(this,_n,void 0)),M.emit(A.SOCKET_SERVICE_RECONNECTED,{wasJoinAttempted:o(this,Ue,qe).mediaJoinAttempted}),o(this,Ue,qe).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,Ue,qe).updateSocketConnectionState("failed")}))}},Bi=new WeakMap,Ve=new WeakMap,Ue=new WeakSet,qe=function(){return o(this,jr).getValue("connectionHandler")},_n=new WeakMap,jr=new WeakMap,ml=new WeakSet,gp=function(t){let e=aS.getSocketEdgeDomain(o(this,jr).getValue("baseURI"));typeof xc(o(this,jr),"socket_server_base")=="string"&&(e=xc(o(this,jr),"socket_server_base"));const n=`wss://${e}`,r=new URL(`${n}/ws`),i=this.peerId,s=J(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=>Wc[a]).join(" "),joinWithDetails:!0,useCfWorker:!0});return Object.entries(s).forEach(([a,c])=>{r.searchParams.append(a,c.toString())}),r.href},gl=new WeakSet,fp=function(){return`${this.peerId}-${(Math.random()+1).toString(36).substring(7)}`},sS);let Co=aS;pl([S.trace("SocketService.connect")],Co.prototype,"connect",1),pl([S.trace("SocketService.disconnect")],Co.prototype,"disconnect",1),pl([S.trace("SocketService.sendMessagePromise")],Co.prototype,"sendMessagePromise",1),pl([S.trace("SocketService.sendMessagePromiseWithTimeout")],Co.prototype,"sendMessagePromiseWithTimeout",1);const Wi=class{static handleConnectedRoomsDumpRaw({payload:t}){var e;const n=AR.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=rM.fromBinary(t);return{authToken:e.authToken,meetingId:e.meetingId}}static handleMovedPeerRaw({payload:t}){const e=iv.fromBinary(t);return{meetingId:e.meetingId,customParticipantId:e.customParticipantId}}static handleConnectedRoomsUpdatedRaw({payload:t}){return rv.fromBinary(t).payloads.map(e=>({id:e.id,title:e.title}))}static handleConnectedRoomsDeletedRaw({payload:t}){return $R.fromBinary(t).payloads}static getConnectedRoomsDump(){return u(this,null,function*(){const t=yield Wi.socketService.sendMessagePromise(W.getConnectedRoomsDump);return Wi.handleConnectedRoomsDumpRaw(t)})}static createConnectedRooms(t){return u(this,null,function*(){const{payload:e}=yield Wi.socketService.sendMessagePromise(W.createConnectedRooms,LR.toBinary({payloads:t}));return rv.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 Wi.socketService.sendMessagePromise(W.deleteConnectedRooms,GR.toBinary({payloads:e}));return Wi.handleConnectedRoomsDeletedRaw(n)})}static movePeersBetweenRooms(t){return u(this,null,function*(){try{const e=yield Wi.socketService.sendMessagePromise(W.movePeers,ZR.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=Wi;m(Ne,"socketService"),m(Ne,"currentMeetingId");var hL=Object.defineProperty,pL=Object.getOwnPropertyDescriptor,fl=(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&&hL(e,n,i),i};const js=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(),kd.cleanup(),Uy(t),Ie.isSupported()===!1)throw new _("Browser not supported","0010",!0);const l=fD(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 XD;t.setValue("connectionHandler",h);const g=js.createSocketService(t),y=g.connect(),E=l.getUserDetails(),b=l.getPlugins();let P=tt.HIVE,R,B="";try{yield js.setupFlagsmith(t)}catch(ne){p.error("Failed to setup flagsmith",{error:ne})}try{yield y}catch(ne){p.error("[Controller]: Failed to connect to socket server:",{error:ne})}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(ne){p.error("Failed to get room metadata",{error:ne})}const x=xO.init(R.preset,!t.getValue("modules").theme),G=js.setupControllers(g,t,R,b,B,x);WD(x)&&((e=js.createRoomNodeClient(t,g).partialJoinRoom(R.participant.name,a,void 0))==null||e.catch(ne=>{p.error("[Controller]: Failed to queue partial media room promise:",{error:ne})})),S.location.country=(n=l.ipInfo)==null?void 0:n.country;const{controllers:I}=yield G;return FI(),new js(i,I)})}static setupFlagsmith(t){return u(this,null,function*(){var e;const{peerId:n,baseURI:r,overrides:i,meetingId:s,organizationId:a}=t.getAllValues(),c=VI(s),d=J(V({entity:wu.PEER,clientId:a,isAnonUser:!a,sdkVersion:t.getValue("sdkVersion"),presetName:t.getValue("presetName"),meetingHash:c,roomName:s},Ie.getDeviceInfo()),{isReactNative:navigator.isReactNative});try{const l=(e=i==null?void 0:i.whitelabelled_flags_endpoint)==null||e?Qi({servicePrefix:"flags",baseURI:r}):"edge.api.flagsmith.com";yield X.identify(`${wu.PEER}_${n}`,JSON.parse(JSON.stringify(d)),!1,5e3,l,p),p.info("flagsmith::allFlags",{flags:JSON.stringify(X.getAllFlags())},!0)}catch(l){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=rN.init(e,b,h.permissions);e.setValue("maxPreferredStreams",Ie.isMobile()?s.maxVideoStreams.mobile:s.maxVideoStreams.desktop);let B,x,G,I,ne,se,we,ce;const De=new WN(t);Ne.socketService=t;const Mt=new rl(t),D=new en(t),k=new qN(t),w=kd.create(t,e),j=new GN(t),Ce=new BN(t),Qe=new si(t),F=yield xr.init(e,w,g,R,s),C=yield xv.init(e,F.self,w,De,i);if(l.participant&&(ce=new tr(e,F.self,w,E)),(d=l.e2ee)!=null&&d.enabled&&l.e2ee.manager.init(p,M),l.chat&&(x=yield Yn.init(e,D,Qe,F.self,ce.participants)),l.internals&&(ne=yield sh.init()),l.livestream&&s.viewType===yt.Livestream&&X.hasFeature(ie.LIVESTREAM)&&(we=new ey(F.self,Ce)),s.viewType!==yt.Chat){if(l.poll&&(B=yield Mv.init(e,F.self,Mt)),l.recording&&(se=new qv(e,F.self,w)),l.stage&&(G=new Vv(e,k,w,F.self,ce.participants)),l.plugin){if(!ce)throw new _("The plugin module cannot be initialized without the `participant` module","0102");const cr=yield r;I=yield Ta.init(e,cr,j,D,x==null?void 0:x.chat,F.self,ce.participants,i)}if(l.pip){const cr=yield jI._init(e,F.self);e.setValue("pip",cr)}}const Xe={storesManager:new qO(e,j),pollController:B,selfController:F,metaController:C,chatController:x,stageController:G,pluginController:I,recordingController:se,internalsController:ne,livestreamController:we,participantController:ce};return{theme:s,permissions:R,controllers:Xe}})}static createRoomNodeClient(t,e){const{peerId:n,roomNodeOptions:r}=t.getAllValues(),{sfu:i}=r;return Vy(t,i,{socket:e,peerId:n})}static createSocketService(t){const{peerId:e,meetingId:n,authToken:r}=t.getAllValues(),i=["PING"];return new Co(t,{peerId:e,meetingId:n,authToken:r,capabilities:i})}};let Ro=js;fl([S.trace("Controller.init")],Ro,"init",1),fl([S.trace("setupFlagsmith")],Ro,"setupFlagsmith",1),fl([S.trace("Controller.createRoomNodeClient")],Ro,"createRoomNodeClient",1),fl([S.trace("Controller.createSocketService")],Ro,"createSocketService",1);var mL=Object.defineProperty,gL=Object.getOwnPropertyDescriptor,fL=(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},vl,vp;class oS extends jt{constructor(e,n){super(),f(this,vl,void 0),m(this,"meetings",[]),m(this,"parentMeeting",null),f(this,vp,void 0),v(this,vp,e),v(this,vl,n.self)}get supportsConnectedMeetings(){return o(this,vl).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 J(V({},s),{participants:a})}if(e===s.id){const a=s.participants.filter(c=>!r.includes(c.id));return J(V({},s),{participants:a})}return s})}}vl=new WeakMap,vp=new WeakMap,fL([Ot({maxInvocations:60,period:60})],oS.prototype,"getConnectedMeetings",1);var vL=Object.defineProperty,yL=Object.getOwnPropertyDescriptor,yp=(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},Mo,In,Sp,Ep;const Hr=(Sp=class{constructor(t,e,n){m(this,"connectedMeetings"),f(this,Mo,void 0),f(this,In,void 0),f(this,Ep,void 0),v(this,Ep,t),v(this,Mo,n),this.connectedMeetings=new oS(t,e),this.setCurrentMeeting(e)}static init(t,e,n){return Hr.instance||(Hr.instance=new Hr(t,e,n)),Hr.instance.connectedMeetings.supportsConnectedMeetings&&(Hr.instance.setupEvents(),e.self.once("roomJoined",()=>Hr.instance.getConnectedMeetings())),Hr.instance}setCurrentMeeting(t){v(this,In,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,In).self.videoEnabled,audio:o(this,In).self.audioEnabled};try{o(this,In).self.cleanupEvents(),yield o(this,In).leave("connected-meeting")}catch(l){p.error(`ConnectedMeetingsController:: switchMeeting:: issues in leaving previous meeting. Meeting Id: ${(i=(r=o(this,In))==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 uS.init(J(V({},o(this,Mo)),{cachedUserDetails:null,defaults:J(V(V({},o(this,Mo).defaults),c),{mediaHandler:o(this,In).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,In).self;d.self.setName(o(this,In).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,J(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})}},Mo=new WeakMap,In=new WeakMap,Ep=new WeakMap,m(Sp,"instance"),Sp);let yl=Hr;yp([S.trace("ConnectedMeetingsController.getConnectedMeetings")],yl.prototype,"getConnectedMeetings",1),yp([S.trace("ConnectedMeetingsController.setupEvents")],yl.prototype,"setupEvents",1),yp([S.trace("ConnectedMeetingsController.switchMeeting")],yl.prototype,"switchMeeting",1);class SL{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 cS=new SL;function EL(t,e){t.startsWith("eyJ")||console.error("Invalid auth token provided. Ensure you are passing a %cparticipant `authToken`%c \u2014 not an Org API Key or an incorrectly formatted token.\nYou get the participant token from the Add Participant API: https://docs.dyte.io/api#/operations/add_participant","font-weight: bold","font-weight: normal");try{const{meetingId:n,orgId:r,participantId:i}=JSON.parse(atob(t.split(".")[1]));if(!n)throw Error(`Received V1 auth token ${t}`);let s="dyte.io";e&&(s=e);const a=`https://api.${s}`;return{meetingId:n,orgId:r,participantId:i,baseURI:s,apiBase:a}}catch(n){throw p.error("constants::decodeAuthToken",{error:n,debuggingHint:`Unable to decode auth token: ${t}`},!0),new _("Invalid auth token","0004")}}var TL=Object.defineProperty,kL=Object.getOwnPropertyDescriptor,Sl=(t,e,n,r)=>{for(var i=r>1?void 0:r?kL(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&&TL(e,n,i),i},dt,El,Tl,Tp,dS,lS;let qr=(lS=class{constructor(t,e){f(this,Tp),f(this,dt,void 0),f(this,El,void 0),f(this,Tl,void 0),v(this,Tl,t),v(this,dt,e)}static init(t){return u(this,null,function*(){var e,n,r,i,s;NI(),Ie.init();const a=ji();cS.init();const{authToken:c,baseURI:d}=t,l=EL(c,d),{meetingId:h}=l,g=sc(l,["meetingId"]);window.__zone_symbol__DISABLE_WRAPPING_UNCAUGHT_PROMISE_REJECTION=!0;const y=qr.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:J(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 Ro.init(y),b=new qr(y,E);return H(s=b,Tp,dS).call(s,t),b})}static setupContext(t,e,n,r){var i;const s=ei.createContext(t,e),a=V(V({},CI),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",RI({baseURI:r.baseURI})),s.setValue("defaults",e.defaults||{audio:!0,video:!0}),s.setValue("onError",e.onError||(()=>{})),s.setValue("cachedUserDetails",gn(e.cachedUserDetails)),s.setValue("sdkVersion","2.5.0-staging.
|
|
23
|
+
${(i=t.authToken)==null?void 0:i.slice(-10)}`})});const E=yield Ro.init(y),b=new qr(y,E);return H(s=b,Tp,dS).call(s,t),b})}static setupContext(t,e,n,r){var i;const s=ei.createContext(t,e),a=V(V({},CI),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",RI({baseURI:r.baseURI})),s.setValue("defaults",e.defaults||{audio:!0,video:!0}),s.setValue("onError",e.onError||(()=>{})),s.setValue("cachedUserDetails",gn(e.cachedUserDetails)),s.setValue("sdkVersion","2.5.0-staging.66"),s}join(){return u(this,null,function*(){const{selfController:t}=o(this,dt);return t.self.roomJoined?null:t.joinRoom()})}leave(t){return u(this,null,function*(){cS.cleanup();const{selfController:e}=o(this,dt);return e.leaveRoom(t)})}get participants(){var t;return(t=o(this,dt).participantController)==null?void 0:t.participants}get self(){var t;return(t=o(this,dt).selfController)==null?void 0:t.self}get meta(){var t;return(t=o(this,dt).metaController)==null?void 0:t.meta}get ai(){var t;return(t=o(this,dt).metaController)==null?void 0:t.ai}get plugins(){var t;return(t=o(this,dt).pluginController)==null?void 0:t.plugins}get chat(){var t;return(t=o(this,dt).chatController)==null?void 0:t.chat}get polls(){var t;return(t=o(this,dt).pollController)==null?void 0:t.polls}get connectedMeetings(){var t;return(t=o(this,El))==null?void 0:t.connectedMeetings}get recording(){var t;return(t=o(this,dt).recordingController)==null?void 0:t.recording}get livestream(){var t;return(t=o(this,dt).livestreamController)==null?void 0:t.livestream}get stage(){var t;return(t=o(this,dt).stageController)==null?void 0:t.stage}get stores(){return o(this,dt).storesManager}get __internals__(){var t;return(t=o(this,dt).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)})}},dt=new WeakMap,El=new WeakMap,Tl=new WeakMap,Tp=new WeakSet,dS=function(t){v(this,El,yl.init(o(this,Tl),this,t))},lS);Sl([ht("0002"),Mr.executeWithLock({methodName:"meeting.join",lockName:"DyteClient.join",timeout:3e3})],qr.prototype,"join",1),Sl([ht("0003")],qr.prototype,"leave",1),Sl([ht("0001"),Mr.executeWithLock({methodName:"DyteClient.init",lockName:"DyteClient.init",timeout:3e3})],qr,"init",1),qr=Sl([ht("0000")],qr);const uS=qr;return uS}();
|