@cloudflare/realtimekit 0.5.0-staging.86 → 0.5.0-staging.88

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.
@@ -1,5 +1,4 @@
1
- import { Project, SyntaxKind } from "ts-morph";
2
- import fs from "fs";
1
+ import { Project, SyntaxKind, Scope } from "ts-morph";
3
2
 
4
3
  const project = new Project();
5
4
  const sourceFiles = project.addSourceFilesAtPaths("dist/**/*.d.ts");
@@ -12,6 +11,20 @@ for (const file of sourceFiles) {
12
11
  node.replaceWithText(node.getText().replace("Dyte", "RTK"));
13
12
  }
14
13
  });
14
+ file.getClasses().forEach(cls => {
15
+ cls.getProperties().forEach(prop => {
16
+ if (prop.hasModifier(SyntaxKind.PrivateKeyword) ||
17
+ prop.hasModifier(SyntaxKind.ProtectedKeyword) ||
18
+ prop.getName().startsWith("#"))
19
+ prop.remove();
20
+ });
21
+ cls.getMethods().forEach(method => {
22
+ if (method.hasScopeKeyword(Scope.Private) ||
23
+ method.hasScopeKeyword(Scope.Protected) ||
24
+ method.getName().startsWith("#"))
25
+ method.remove();
26
+ });
27
+ });
15
28
  }
16
29
 
17
30
  project.saveSync();
package/README.md CHANGED
@@ -68,21 +68,7 @@ const meeting = await RealtimeKit.init({
68
68
  });
69
69
  ```
70
70
 
71
- For React you can use the hooks wrapper
72
-
73
- ```ts
74
- const [meeting, initMeeting] = useRealtimeKitClient();
75
- useEffect(() => {
76
- await initMeeting({
77
- authToken: "<AuthTokenHere>",
78
- defaults: {
79
- audio: false,
80
- video: false,
81
- }
82
- });
83
- }, []);
84
- ```
85
-
71
+ For React you can use the hooks wrapper package `@cloudflare/realtimekit-react`
86
72
 
87
73
  The `meeting` object is used for all interaction with Cloudflare's servers. For example, the following code snippet is used for a user to join a room.
88
74
 
package/build-types.sh CHANGED
@@ -18,20 +18,4 @@ function restore {
18
18
  trap restore EXIT
19
19
 
20
20
  npx tsup src/index.ts --external @protobuf-ts/runtime,worker-timers,bowser,lodash-es,sdp-transform --dts-resolve --dts-only --format esm
21
- npx tsup src/react.ts --external @protobuf-ts/runtime,worker-timers,bowser,lodash-es,sdp-transform --dts-resolve --dts-only --format esm
22
21
  npx tsup src/mock.ts --external @protobuf-ts/runtime,worker-timers,bowser,lodash-es,sdp-transform --dts-resolve --dts-only --format esm
23
-
24
- # temp hack till we replace dyte completely with realtimekit
25
- OS="$(uname)"
26
- SED_CMD=""
27
-
28
- if [[ "$OS" == "Darwin" ]]; then
29
- # macOS (BSD sed requires backup extension or '')
30
- SED_CMD="sed -i '' '/#private;/d'"
31
- else
32
- # Linux (GNU sed)
33
- SED_CMD="sed -i '/#private;/d'"
34
- fi
35
-
36
- # Find and process all .d.ts files
37
- find dist/ -name '*.d.ts' -exec bash -c "$SED_CMD \"{}\"" \;
package/dist/browser.js CHANGED
@@ -19,4 +19,4 @@ ${t}`}const rs={maxInvocations:5,period:1};function Nt(t,e){return function(n,r,
19
19
  `}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 Bd extends Nh{constructor(e){super(),g(this,"supportsSendEncodings",!1),this.supportsSendEncodings=e.supportsSendEncodings}static createFactory(e){return()=>new Bd(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,x({direction:"sendonly",streams:[s?this._sendScreenShareStream:this._sendWebStream]},a));if(!this.supportsSendEncodings&&r){r.reverse();const h=c.sender.getParameters();h.encodings=r,yield c.sender.setParameters(h)}const d=(h,m)=>{var y;const T=Kr(h),b=T.media[T.media.length-1],O=b.rtp.filter(K=>m.some(I=>I.name===K.codec)),M=b.fmtp.filter(K=>O.some(I=>I.payload===K.payload)),F=(y=b.rtcpFb)==null?void 0:y.filter(K=>O.some(I=>I.payload===K.payload)),V=O.map(K=>K.payload);return T.media[T.media.length-1].rtp=O,T.media[T.media.length-1].fmtp=M,T.media[T.media.length-1].rtcpFb=F,T.media[T.media.length-1].payloads=V.join(" "),mc(T)},l=yield this.pc.createOffer();if(l.sdp=d(l.sdp,i),p.debug(`send() | calling pc.setLocalDescription() [offer:${JSON.stringify(l)}]`),yield this.pc.setLocalDescription(l),n==="audio"||n.kind==="audio"){const{enableDtx:h,enableStereo:m}=this,y=this.enableHighBitrate?m?128e3:64e3:m?64e3:32e3;l.sdp=l.sdp.replace("minptime=10;useinbandfec=1",`minptime=10;useinbandfec=1;${h?"usedtx=1;":""}${m?"stereo=1;sprop-stereo=1;":""}maxaveragebitrate=${y}`)}return this.midTransceiverMap.set(c.mid,c),{offerSdp:l,callback:h=>u(this,null,function*(){return p.debug(`send() | calling pc.setRemoteDescription() [answer:${JSON.stringify(h)}]`),yield this.pc.setRemoteDescription(h),c.mid}),sender:c.sender,mid:c.mid}})}setMaxSpatialLayer(e,n){return u(this,null,function*(){this._assertSendDirection(),p.debug(`setMaxSpatialLayer() [localId:${e}, spatialLayer:${n}]`);const r=this.midTransceiverMap.get(e);if(!r)throw new Error("associated RTCRtpTransceiver not found");const i=r.sender.getParameters(),s=i.encodings.length-1-n;i.encodings.forEach((a,c)=>{c>=s?a.active=!0:a.active=!1}),yield r.sender.setParameters(i)})}addCustomEventListeners(){this.pc.addEventListener("datachannel",e=>{const{channel:n}=e;n.onmessage=r=>u(this,null,function*(){const i=yield r.data.arrayBuffer();this.safeEmit("datachannel",e.channel,String.fromCharCode(...new Uint8Array(i)))})})}}class xh extends Nh{static createFactory(){return()=>new xh}get name(){return"Safari12"}send(e){return u(this,arguments,function*({track:n,encodings:r,codecOptions:i,screenShare:s}){this._assertSendDirection(),p.debug("Safari12::creating new transceiver");const a=this.pc.addTransceiver(n,{direction:"sendonly",streams:[s?this._sendScreenShareStream:this._sendWebStream],sendEncodings:r}),c=RTCRtpSender.getCapabilities(typeof n=="string"?n:n.kind);p.info(`Safari12::senders available params: ${JSON.stringify(c)}`);const d=[];i&&i.length>0&&i.forEach(h=>{var m;const y=c.codecs.find(T=>T.mimeType.includes(h.name));if(h.parameters){p.info(`Safari12::codecOption.parameters:, ${JSON.stringify(h.parameters)}`);const T=((m=y.sdpFmtpLine)==null?void 0:m.split(";"))||[];T.push(...h.parameters);const b=[...new Set(T).values()];y.sdpFmtpLine=b.join(";")}d.push(y)}),p.info(`Safari12::selected codecs: ${JSON.stringify(d)}`),a.setCodecPreferences(d);const l=yield this.pc.createOffer();if(yield this.pc.setLocalDescription(l),n==="audio"||n.kind==="audio"){const{enableStereo:h,enableDtx:m}=this,y=this.enableHighBitrate?h?128e3:64e3:h?64e3:32e3;l.sdp=l.sdp.replace("minptime=10;useinbandfec=1",`minptime=10;useinbandfec=1;${m?"usedtx=1;":""}${h?"stereo=1;sprop-stereo=1;":""}maxaveragebitrate=${y}`)}return this.midTransceiverMap.set(a.mid,a),{offerSdp:l,callback:h=>u(this,null,function*(){return p.debug(`Safari12::send() | calling pc.setRemoteDescription() [answer:${JSON.stringify(h)}]`),yield this.pc.setRemoteDescription(h),a.mid}),sender:a.sender,mid:a.mid}})}addCustomEventListeners(){this.pc.ondatachannel=e=>{const{channel:n}=e;n.onmessage=r=>u(this,null,function*(){const i=String.fromCharCode(...new Uint8Array(r.data));this.safeEmit("datachannel",e.channel,i)})}}}function xN(t,e){return typeof t=="undefined"?e:typeof window!="undefined"&&Object.getOwnPropertyDescriptor(window,"structuredClone")?structuredClone(t):JSON.parse(JSON.stringify(t))}var Wd,Ps,sr,ar,Dr,jd,Vh,Uh,Cy,Fh,Py;class VN extends io{constructor(e){var n;super(),f(this,ar),f(this,jd),f(this,Uh),f(this,Fh),g(this,"rtpReceiver"),g(this,"id"),g(this,"localId"),g(this,"producerId"),g(this,"producingTransportId"),g(this,"mimeType"),g(this,"track"),g(this,"peerId"),g(this,"appData"),g(this,"transceiver"),f(this,Wd,void 0),f(this,Ps,void 0),f(this,sr,void 0),this.id=e.id,this.localId=e.localId,v(this,Wd,e.handler),this.appData=e.appData,this.peerId=e.producingPeerId,this.producingTransportId=e.producingTransportId,v(this,sr,!1),this.producerId=e.producerId,this.track=e.track,v(this,Ps,(n=e.paused)!=null?n:!1),this.mimeType=e.mimeType,this.transceiver=e.transceiver,this.rtpReceiver=e.rtpReceiver,H(this,Uh,Cy).call(this)}get closed(){return o(this,sr)}get kind(){return this.track.kind}get paused(){return o(this,Ps)}close(e,n){o(this,sr)||(p.debug(`Consumer::close() ${e?`with reason ${e}`:""}`,o(this,ar,Dr)),v(this,sr,!0),n&&(H(this,Fh,Py).call(this),this.transceiver.stop()),this.safeEmit("close",e))}getStats(){return u(this,null,function*(){if(o(this,sr))throw new Ut("closed");return o(this,Wd).getReceiverStats(this.localId)})}pause(){if(p.debug("consumer::pause()",o(this,ar,Dr)),o(this,sr)){p.error("consumer::pause() | Consumer closed",o(this,ar,Dr));return}v(this,Ps,!0),this.track.enabled=!1,this.safeEmit("pause")}resume(){if(p.debug("consumer::resume()",o(this,ar,Dr)),o(this,sr)){p.error("Consumer::resume() | Consumer closed",o(this,ar,Dr));return}v(this,Ps,!1),this.track.enabled=!0,this.safeEmit("resume")}}Wd=new WeakMap,Ps=new WeakMap,sr=new WeakMap,ar=new WeakSet,Dr=function(){return{consumer:{id:this.id,appData:this.appData,peerId:this.peerId,kind:this.kind}}},jd=new WeakSet,Vh=function(){p.debug('Consumer::track "ended" event',o(this,ar,Dr)),this.safeEmit("trackended")},Uh=new WeakSet,Cy=function(){this.track.addEventListener("ended",H(this,jd,Vh).bind(this))},Fh=new WeakSet,Py=function(){try{this.track.removeEventListener("ended",H(this,jd,Vh)),this.track.stop()}catch(t){p.error("Consumer::destroyTrack()",G(x({},o(this,ar,Dr)),{error:t}))}};var Vn,so,ao,Rs,kn,gt,Ii,oo,sn,bn;class UN extends io{constructor(e){var n,r;super(),f(this,sn),g(this,"id"),g(this,"localId"),f(this,Vn,void 0),g(this,"kind"),g(this,"appData"),g(this,"rtpSender"),f(this,so,void 0),f(this,ao,void 0),f(this,Rs,void 0),f(this,kn,!1),f(this,gt,void 0),f(this,Ii,void 0),f(this,oo,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,Ii,e.disableTrackOnPause?!((r=e.track)!=null&&r.enabled):!1),v(this,oo,void 0),v(this,so,e.stopTracks),v(this,ao,e.disableTrackOnPause),v(this,Rs,e.zeroRtpOnPause),this.appData=e.appData||{},this._onTrackEnded=this._onTrackEnded.bind(this),v(this,Vn,e.handler),this.rtpSender=e.rtpSender,this._handleTrack()}get closed(){return o(this,kn)}get track(){return o(this,gt)}get paused(){return o(this,Ii)}get maxSpatialLayer(){return o(this,oo)}close(e){return u(this,null,function*(){if(o(this,kn))return;if(p.debug(`Producer::close() ${e?`with reason ${e}`:""}`,o(this,sn,bn)),v(this,kn,!0),this._destroyTrack(),e===qd){this.safeEmit("close",{reason:e});return}const{offerSdp:n,callback:r}=yield o(this,Vn).stopSending(this.localId),{answer:i}=yield this.safeEmitAsPromise("close",{offer:n,reason:e});r(i)})}getStats(){return u(this,null,function*(){if(o(this,kn))throw new Ut("closed");return o(this,Vn).getSenderStats(this.localId)})}pause(){p.debug("Producer::pause()",o(this,sn,bn)),o(this,kn)&&p.error("Producer::pause() | Producer closed",o(this,sn,bn)),v(this,Ii,!0),o(this,gt)&&o(this,ao)&&(o(this,gt).enabled=!1),o(this,Rs)&&o(this,Vn).replaceTrack(this.localId,null),this.emit("pause")}resume(){if(p.debug("Producer::resume()",o(this,sn,bn)),o(this,kn)){p.error("Producer::resume() | Producer closed",o(this,sn,bn));return}v(this,Ii,!1),o(this,gt)&&o(this,ao)&&(o(this,gt).enabled=!0),o(this,Rs)&&o(this,Vn).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,sn,bn)),o(this,kn)){if(n&&o(this,so))try{n.stop()}catch(r){p.error("Producer::replaceTrack",G(x({},o(this,sn,bn)),{error:r}))}throw new Ut("closed")}else if(n&&n.readyState==="ended")throw new Ut("track ended");if(n===o(this,gt)){p.debug(`replaceTrack() | same track, ignored trackId: ${n.id}`,o(this,sn,bn));return}(!o(this,Rs)||!o(this,Ii))&&(yield o(this,Vn).replaceTrack(this.localId,n)),this._destroyTrack(),v(this,gt,n),this._handleTrack()})}setMaxSpatialLayer(e){return u(this,null,function*(){if(o(this,kn))throw new Ut("closed");if(this.kind!=="video")throw new ro("not a video Producer");if(typeof e!="number")throw new TypeError("invalid spatialLayer");yield o(this,Vn).setMaxSpatialLayer(this.localId,e),v(this,oo,e)})}setRtpEncodingParameters(e){return u(this,null,function*(){if(o(this,kn))throw new Ut("closed");if(typeof e!="object")throw new TypeError("invalid params");yield o(this,Vn).setRtpEncodingParameters(this.localId,e)})}_onTrackEnded(){p.debug(`Producer::track "ended" event trackId: ${this.track.id}`,o(this,sn,bn)),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,so)&&o(this,gt).stop()}catch(n){p.error(`Producer::_destroyTrack trackId: ${(e=this.track)==null?void 0:e.id}`,G(x({},o(this,sn,bn)),{error:n}))}}}Vn=new WeakMap,so=new WeakMap,ao=new WeakMap,Rs=new WeakMap,kn=new WeakMap,gt=new WeakMap,Ii=new WeakMap,oo=new WeakMap,sn=new WeakSet,bn=function(){return{producer:{id:this.id,appData:this.appData,kind:this.kind}}};function Ry(t){return typeof t=="object"&&!Array.isArray(t)&&t!==null}function Bh(t){return Math.random().toString(36).substring(2,2+t)}const Hd=1;function My(t){const e=t;return delete e.payload._bolt,e}function FN(t){return t.payload&&Ry(t.payload)}function Ay(t){var e,n;return FN(t)&&(n=(e=t.payload._bolt)==null?void 0:e.id)!=null?n:""}var Ci;const co=class extends ut.EventEmitter{constructor(t,e,n){super(),g(this,"channel"),g(this,"queue"),g(this,"serverProtocolVersion"),f(this,Ci,new Map),g(this,"respond",(r,i,s=!1)=>{let a;s?a=co.createErrorResponse(r,i):a=co.createResponse(r,i),this.channel.send(JSON.stringify(a))}),g(this,"notify",r=>{const i=co.createNotification(r);this.channel.send(JSON.stringify(i))}),g(this,"request",r=>u(this,null,function*(){const i=co.createRequest(r),s=new Promise((a,c)=>{const{id:d}=i.payload._bolt,l={id:d,method:i.type,resolve:h=>{this.queue.delete(d)&&(clearTimeout(l.timer),a(h))},timer:setTimeout(()=>{this.queue.delete(d)&&c(new Error(`request timeout for message id: ${d}`))},2e4),cancel:h=>{this.queue.delete(d)&&(clearTimeout(l.timer),c(h))}};this.queue.set(d,l)});return this.channel.send(JSON.stringify(i)),s})),g(this,"send",r=>{const i=JSON.stringify(r),s=16384;if(i.length>s){const a=s-200,c=Math.ceil(i.length/a),d=[];for(let h=0;h<c;h+=1){const m=h*a,y=(h+1)*a;d.push(i.slice(m,y))}const l=Gi();for(let h=0;h<c;h+=1){const m=d[h],y=JSON.stringify({id:l,count:c,chunkIndex:h,chunk:m});p.debug(`Sending message chunk over dc: ${y}`),this.channel.send(y)}}else p.debug(`Sending message over dc: ${i}`),this.channel.send(i)}),g(this,"processMessage",r=>{var i;o(this,Ci).has(r.id)||o(this,Ci).set(r.id,[]);const s=o(this,Ci).get(r.id);if(s[r.chunkIndex]=r,(s==null?void 0:s.length)===r.count&&!s.some(a=>a===void 0)){const a=o(this,Ci).get(r.id),c=a==null?void 0:a.reduce((l,h)=>l+h.chunk,"");o(this,Ci).delete(r.id);const d=JSON.parse(c);if(!d.payload||!Ry(d.payload))throw new Error("corrupted incoming message over dc",{cause:{code:"CORRUPT_DC_MESSAGE",values:d}});if(this.processBoltHandshake(d))return;if(this.serverProtocolVersion=(i=d.payload._bolt)==null?void 0:i.version,!this.processResponseMsg(d))return d}}),g(this,"processResponseMsg",r=>{const{id:i}=r.payload._bolt,s=this.queue.get(i);return s?(p.debug(`resolving pending request with id: ${i}, complete response: ${JSON.stringify(r)}`),r.type==="error"?s.cancel(My(r)):s.resolve(My(r)),!0):!1}),g(this,"processBoltHandshake",r=>{var i,s;return r.type==="_bolt"||r.type==="handshake"?(this.respond((s=(i=r.payload._bolt)==null?void 0:i.id)!=null?s:Bh(8),{type:"_bolt",payload:{message:"pong"}}),!0):!1}),this.label=e,this.transportId=n,this.channel=t,this.queue=new Map}};let lo=co;Ci=new WeakMap,g(lo,"createRequest",t=>{var e;if((e=t.payload)!=null&&e._bolt)throw new Error("rpc fields are internal values");return{type:t.type,payload:G(x({},t.payload),{_bolt:{id:Bh(8),type:"REQUEST",version:Hd}})}}),g(lo,"createResponse",(t,e)=>{var n;if((n=e.payload)!=null&&n._bolt)throw new Error("rpc fields are internal values");return{type:e.type,payload:G(x({},e.payload),{_bolt:{id:t,type:"RESPONSE",version:Hd}})}}),g(lo,"createNotification",t=>{var e;if((e=t.payload)!=null&&e._bolt)throw new Error("rpc fields are internal values");return{type:t.type,payload:G(x({},t.payload),{bolt:{id:Bh(8),type:"NOTIFY",version:Hd}})}}),g(lo,"createErrorResponse",(t,e)=>({type:"error",payload:{error:e.message,_bolt:{id:t,type:"RESPONSE",version:Hd}}}));function BN(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 qd="transport closed";var uo;const ho=class extends io{constructor(t,{id:e,direction:n,handlerFactory:r,iceServers:i,iceTransportPolicy:s,proprietaryConstraints:a,additionalSettings:c,appData:d,config:l}){var h,m,y;super(),g(this,"awaitQueue"),g(this,"observer"),f(this,uo,void 0),g(this,"id"),g(this,"serverId"),g(this,"direction"),g(this,"maxSctpMessageSize"),g(this,"handler"),g(this,"connectionState","new"),g(this,"producers"),g(this,"consumers"),g(this,"datachannels"),g(this,"connected",!1),g(this,"eventsDCReadyPromise"),g(this,"eventsDCReadyPromiseResolver"),g(this,"eventsDCFailureTimer"),g(this,"transportConnectionPromise"),g(this,"consumerTrackEvents"),g(this,"unknownTracksMap"),g(this,"appData"),p.debug(`constructor() [id: ${e}, direction: ${n}]`),v(this,uo,t),this.id=e,this.direction=n;const T=xN(c,{});delete T.iceServers,delete T.iceTransportPolicy,delete T.bundlePolicy,delete T.rtcpMuxPolicy,delete T.sdpSemantics,this.producers=new Map,this.consumers=new Map,this.datachannels=new Map,this.consumerTrackEvents=new Map,this.unknownTracksMap=new Map,this.awaitQueue=new Vd,this.observer=new io,this.handler=r(),this.handler.enableHighBitrate=(h=l==null?void 0:l.enableHighBitrate)!=null?h:!1,this.handler.enableStereo=(m=l==null?void 0:l.enableStereo)!=null?m:!1,this.handler.enableDtx=(y=l==null?void 0:l.enableDtx)!=null?y:!0,this.handler.init({onTrackHandler:this._ontrack.bind(this),direction:n,iceServers:i,iceTransportPolicy:s,additionalSettings:c,proprietaryConstraints:a}),this.appData=d||{},this.transportConnectionPromise=new Promise(b=>{this.observer.once("connected",()=>{b(!0)}),this.observer.once("disconnect",()=>{b(!1)}),this.observer.once("close",()=>{b(!1)})}),this.eventsDCReadyPromise=new Promise(b=>{this.eventsDCReadyPromiseResolver=b}),this.handler.on("@connectionstatechange",b=>{b!==this.connectionState&&(p.debug(`connection state changed to ${b}`),this.connectionState=b,b==="connected"&&(this.connected=!0,this.observer.emit("connected")),b==="disconnected"&&(this.connected=!1,this.observer.emit("disconnect")),(b==="failed"||b==="closed")&&(this.connected=!1,this.observer.emit("close")),this.closed||this.safeEmit("connectionstatechange",b))}),this.handler.on("@icecandidate",({candidate:b})=>{this.closed||this.safeEmit("icecandidate",b)}),this.handler.on("dc_open",b=>{let O=this.datachannels.get(b.label);O||(O||(O=new lo(b,b.label,this.serverId),this.datachannels.set(b.label,O)),this.eventsDCFailureTimer=setTimeout(()=>{b.label==="events"&&(this.eventsDCReadyPromiseResolver(!1),this.safeEmit("dc_error",b.label))},5e3))}),this.handler.on("datachannel",(b,O)=>{b.label==="events"&&(this.eventsDCReadyPromiseResolver(!0),this.eventsDCFailureTimer&&clearTimeout(this.eventsDCFailureTimer));const M=this.datachannels.get(b.label);if(!M){p.error("unregistered datachannel for message",{rtcChannel:{label:b.label,message:O}});return}try{const F=JSON.parse(O);p.debug("datachannel message chunk recieved",{dataChannelMessageChunk:{id:F.id,count:F.count,chunkIndex:F.chunkIndex,chunk:F.chunk,transprtId:this.serverId}});const V=M.processMessage(F);if(!V)return;p.debug(`datachannel message with id:${F.id} on transport:${this.serverId}complete - ${JSON.stringify(V)}`),this.emit(`datachannel:${b.label}`,M.label,V)}catch(F){p.error("error parsing message",{error:F})}})}get closed(){return this.connectionState==="closed"}setServerId(t){this.serverId=t}getDatachannel(t){return this.datachannels.get(t)}get isEventsDCReady(){return this.eventsDCReadyPromise}close(){this.closed||(p.debug("Transport close called"),this.connectionState="closed",this.connected=!1,this.handler.close(),Array.from(this.producers.values()).forEach(t=>{t.close(qd).catch(()=>{})}),this.producers.clear(),Array.from(this.consumers.values()).forEach(t=>{t.close(qd)}),this.consumers.clear(),this.consumerTrackEvents.clear(),this.emit("close"),this.observer.emit("close"))}getStats(){return u(this,null,function*(){if(this.closed)throw new Ut("closed");return this.handler.getTransportStats()})}connect(t){return u(this,null,function*(){try{if(yield this.awaitQueue.push(()=>u(this,null,function*(){const{offerSdp:e,callback:n}=yield this.handler.connect(),{transportId:r,answer:i}=yield t(e);this.setServerId(r),yield n(i)})),!(yield this.transportConnectionPromise))throw new Error("ice connection failed");if(o(this,uo)===tt.HIVE&&!(yield this.isEventsDCReady))throw new Error("events datachannel not open")}catch(e){throw p.error("transport failed to connect:",{error:e}),e}})}restartIce(){return u(this,null,function*(){if(p.debug("restartIce()"),this.closed)throw new Ut("closed");return this.handler.restartIce()})}canProduce(t){return u(this,null,function*(){const{track:e,appData:n}=t;if(e){if(this.direction!=="send")throw new ro("not a sending Transport");if(e.readyState==="ended")throw new Ut("track ended");if(this.listenerCount("connect")===0&&this.connectionState==="new")throw new TypeError('no "connect" listener set into this transport');if(n&&typeof n!="object")throw new TypeError("if given, appData must be an object")}else throw new TypeError("missing track");if(!(yield this.transportConnectionPromise))throw new _i("transport not connected");return!0})}produce(t,e){return u(this,null,function*(){if(!(yield this.canProduce(t)))throw new Error("Cannot produce");const{track:n,encodings:r,codecOptions:i,stopTracks:s=!0,disableTrackOnPause:a=!0,zeroRtpOnPause:c=!1,appData:d={}}=t;p.debug(`produce() [track:${n.id}]`);const{producerId:l,localId:h,rtpSender:m}=yield this.awaitQueue.push(()=>u(this,null,function*(){const{offerSdp:y,callback:T,sender:b,mid:O}=yield this.handler.send({track:n,encodings:r,codecOptions:i,screenShare:d==null?void 0:d.screenShare}),{answer:M,producerId:F}=yield e({offer:y,kind:n.kind,paused:a?!n.enabled:!1,appData:G(x({},d||{}),{mid:O}),codecOptions:i,producingTransportId:this.serverId}),V=yield T(M);return{producerId:F,localId:V,rtpSender:b}}),"producer");return this.createProducerObject({id:l,localId:h,track:n,stopTracks:s,disableTrackOnPause:a,zeroRtpOnPause:c,appData:d,handler:this.handler,rtpSender:m})})}createProducerObject(t){return u(this,null,function*(){const e=new UN(t);return this.producers.set(e.id,e),e.once("close",()=>{this.producers.delete(e.id)}),e})}closeProducer(t){return u(this,null,function*(){yield this.awaitQueue.push(t.close.bind(t),"producer")})}canConsume(){return u(this,null,function*(){if(this.closed)throw new Ut("closed");if(this.direction!=="recv")throw new ro("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 _i("transport not connected");return!0})}consume(t,e,n){return u(this,null,function*(){return this.awaitQueue.push(()=>u(this,null,function*(){const r={},{consumerStates:i,sessionDescription:s,failedProducers:a}=yield e(t);i.forEach((l,h)=>{r[h]=this.createConsumerObjectAndWaitForTrack(G(x({},l),{producerId:h}))});const c=a;s&&(p.info("Session description found, sending negotiation request"),yield n(s));const d=[];return yield Promise.all(Object.entries(r).map(([l,h])=>h.then(m=>d.push(m)).catch(()=>{p.error(`Failed to create consumer object, producer: ${l}`,{error:{message:"This should not happen"},transport:{serverId:this.serverId}})}))),{consumers:d,failedProducers:c}}),"consumer")})}static parseHeaderExtensionMappings(t,e){const n=Kr(t.sdp),r={};return n.media.forEach(i=>{e.includes(i.mid.toString())&&(r[i.mid]=i.ext)}),r}static setHeaderExtensionMappings(t,e,n){const r=Kr(t.sdp);return r.media=r.media.map(i=>{if(e.includes(i.mid.toString())){const s=x({},i);return s.ext=n[i.mid],s}return i}),G(x({},t),{sdp:mc(r)})}static parseCodecAndFmtpMappings(t,e){const n=Kr(t.sdp),r={};return n.media.forEach(i=>{e.includes(i.mid.toString())&&(r[i.mid.toString()]={rtp:i.rtp,fmtp:i.fmtp,payloads:i.payloads,rtcpFb:i.rtcpFb})}),r}static setCodecAndFmtpMappings(t,e,n){const r=Kr(t.sdp);return r.media=r.media.map(i=>{if(e.includes(i.mid.toString())){const s=x({},i);return s.rtp=n[i.mid.toString()].rtp,s.fmtp=n[i.mid.toString()].fmtp,s.payloads=n[i.mid.toString()].payloads,s.rtcpFb=n[i.mid.toString()].rtcpFb,s}return i}),G(x({},t),{sdp:mc(r)})}closeConsumers(t,e){return u(this,null,function*(){const n=t.map(c=>c.transceiver.mid),r=ho.parseHeaderExtensionMappings(this.handler.pc.remoteDescription,n),i=ho.parseCodecAndFmtpMappings(this.handler.pc.remoteDescription,n);t.forEach(c=>c.close(void 0,!0));let s=yield this.handler.pc.createOffer();s=ho.setHeaderExtensionMappings(s,n,r),s=ho.setCodecAndFmtpMappings(s,n,i),yield this.setLocalDescription(s);const a=yield e(t,s);yield this.setRemoteDescription(a)})}setRemoteOffer(t){return u(this,null,function*(){yield this.setRemoteDescription(t);const e=yield this.handler.pc.createAnswer(),n=Kr(e.sdp);return n.media=n.media.map(r=>{if(r.type==="audio"){const i=x({},r),s=i.fmtp.find(a=>a.payload===111);return s&&(s.config+=";stereo=1;sprop-stereo=1"),i.rtcpFb||(i.rtcpFb=[]),i.rtcpFb.some(a=>a.type==="nack")||i.rtcpFb.push({payload:parseInt(i.payloads,10),type:"nack"}),i}return r}),e.sdp=mc(n),yield this.setLocalDescription(e),e})}_ontrack(t){const{track:e,transceiver:n,streams:r}=t;p.info(`track event received [trackId: ${e.id}]`);let i;o(this,uo)===tt.HIVE?i=`${r[0].id}:${e.kind}`:i=`${n.mid}:${e.kind}`,e.addEventListener("ended",()=>{p.info(`rtc consumer track ended [trackId: ${e.id}]`),this.unknownTracksMap.delete(i)});const s=this.consumerTrackEvents.get(i);s?(s(e,n),this.consumerTrackEvents.delete(i)):(p.warn(`track event handler not found ${i}`),this.unknownTracksMap.set(i,t))}sendErrorOverDC(t,e,n){const r=this.getDatachannel(t);if(!r)throw new Error("datachannel not found",{cause:{code:"DC_NOT_FOUND",values:{label:t}}});r.respond(e,n,!0)}sendResponseOverDC(t,e,n){const r=this.getDatachannel(t);if(!r)throw new Error("datachannel not found",{cause:{code:"DC_NOT_FOUND",values:{label:t}}});r.respond(e,n)}createConsumerObjectAndWaitForTrack(t){return u(this,null,function*(){const{consumerId:e,producerId:n,producingPeerId:r,producingTransportId:i,streamId:s,paused:a,screenShare:c,appData:d,kind:l,mimeType:h}=t,m=`${s}:${l}`,y=G(x({},t),{name:"consumer creation task error",message:"consumer creation failed"});return new Promise((T,b)=>u(this,null,function*(){const O=setTimeout(()=>{this.consumerTrackEvents.delete(m),y.isTimedout=!0,b(y)},5e3),M=(V,K)=>{try{if(V.readyState==="ended")clearTimeout(O),b(y);else{const I=V;I.enabled=!0,this.handler.midTransceiverMap.set(K.mid,K);const Z=new VN({id:e,localId:K.mid,transceiver:K,track:I,paused:a,producerId:n,producingPeerId:r,producingTransportId:i,handler:this.handler,appData:G(x({},d),{screenShare:c,peerId:r}),rtpReceiver:K.receiver,mimeType:h});this.consumers.set(e,Z),Z.once("close",()=>{this.consumers.delete(Z.id),this.handler.midTransceiverMap.delete(K.mid)}),p.info("consumer created for ",{consumer:{id:e,kind:l,appData:{screenShare:c},peerId:r,producerId:n}}),this.observer.emit("newconsumer",Z),clearTimeout(O),T(Z)}}catch(I){p.warn("error while creating consumer:",I),clearTimeout(O),b(y)}},F=this.unknownTracksMap.get(m);F?(this.unknownTracksMap.delete(m),M(F.track,F.transceiver)):this.consumerTrackEvents.set(m,M)}))})}setRemoteDescription(t){return u(this,null,function*(){yield this.handler.pc.setRemoteDescription(t)})}setLocalDescription(t){return u(this,null,function*(){p.debug(`${this.direction}() {transportId: ${this.serverId}} | calling pc.setLocalDescription() [offer:${JSON.stringify(t)}]`),yield this.handler.pc.setLocalDescription(t)})}retryFailedConsumerCreationTasks(t){return u(this,null,function*(){return BN(t.map(e=>u(this,null,function*(){return Oh(n=>u(this,null,function*(){return n>0&&p.warn(`retrying failed consumer creation task: ${JSON.stringify(e)}`),this.createConsumerObjectAndWaitForTrack(x({},e))}))})))})}sendDataChannelMessage(t,e){return u(this,null,function*(){const n=this.getDatachannel(t);if(!n)throw AN("DC_NOT_READY",`${t} datachannel not ready`);const r=(yield n.request(e)).payload;return p.info(`sendDataChannelMessage::response ${JSON.stringify(r)}`),r})}};let WN=ho;uo=new WeakMap;function jN(){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=Up.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 Gd;class HN{constructor(e,{handlerName:n,handlerFactory:r}={}){if(g(this,"handlerFactory"),f(this,Gd,void 0),p.debug("constructor()"),v(this,Gd,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=jN(),n)p.debug(`Device::constructor() | detected handler: ${n}`);else throw new Error("device not supported");switch(n){case"Chrome74":this.handlerFactory=Lh.createFactory();break;case"Safari12":this.handlerFactory=xh.createFactory();break;case"Firefox60":this.handlerFactory=Bd.createFactory({supportsSendEncodings:!1});break;case"Firefox110":this.handlerFactory=Bd.createFactory({supportsSendEncodings:!0});break;default:throw new TypeError(`unknown handlerName "${n}"`)}}}createTransport(e){const n=Gi();return new WN(o(this,Gd),G(x({id:n},e),{handlerFactory:this.handlerFactory}))}}Gd=new WeakMap;const qN=2e3;var Or,po,It,Ct,Ms,mo,go,fo,As,Pi,vo,yo,Jd,$d,Wh,jh,Dy,Hh,Oy,qh,Ny,Gh,Ly,Jh,xy,Kd,$h,zd,Kh;class GN extends ut.EventEmitter{constructor(e,n,r){switch(super(),f(this,yo),f(this,$d),f(this,jh),f(this,Hh),f(this,qh),f(this,Gh),f(this,Jh),f(this,Kd),f(this,zd),f(this,Or,void 0),f(this,po,void 0),f(this,It,void 0),f(this,Ct,void 0),f(this,Ms,void 0),f(this,mo,void 0),f(this,go,void 0),f(this,fo,{transportFailureCount:{send:0,recv:0},lastConnectionTime:0}),f(this,As,void 0),f(this,Pi,"all"),f(this,vo,void 0),v(this,Or,e),v(this,Ms,n),v(this,vo,r),v(this,po,new HN(r)),v(this,mo,new LN(n,r)),r){case tt.CF:{v(this,go,pn);break}case tt.HIVE:default:{v(this,go,en);break}}o(this,yo,Jd).mediaState={send:{state:Rr.NEW,reconnected:!1},recv:{state:Rr.NEW,reconnected:!1}},X.hasFeature(ie.FORCE_RELAY)&&v(this,Pi,"relay"),H(this,$d,Wh).call(this)}get socket(){return o(this,Ms)}get socketHandler(){return o(this,mo)}get sendTransport(){return o(this,It)}get recvTransport(){return o(this,Ct)}get events(){return o(this,go)}get nodeType(){return o(this,vo)}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,Pi,"relay"));const h=yield ot().getICEServers().catch(y=>(p.warn(`failed to get iceservers from server: ${y.message}`),[])),m=[];if(e.send){const y=X.hasFeature(ie.DISABLE_OPUS_DTX_CF),T=H(this,Hh,Oy).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,vo)===tt.HIVE?!0:!!y},iceTransportPolicy:o(this,Pi)});m.push(T)}if(e.recv){const y=H(this,qh,Ny).call(this,{iceServers:h,additionalSettings:{encodedInsertableStreams:(l=o(this,Or).getValue("modules").e2ee)==null?void 0:l.enabled},iceTransportPolicy:o(this,Pi)});m.push(y)}yield Promise.all(m)})}stopTransports(e){var n,r;if(e.send&&this.sendTransport!==void 0){const{id:i,serverId:s,direction:a}=o(this,It);p.info("Closing send transport",{transport:{id:i,serverId:s,type:a}}),o(this,It).close(),o(this,It).removeAllListeners(),v(this,It,void 0)}if(e.recv&&this.recvTransport!==void 0){const{id:i,serverId:s,direction:a}=o(this,Ct);p.info("Closing recv transport",{transport:{id:i,serverId:s,type:a}}),(n=o(this,Ct))==null||n.close(),(r=o(this,Ct))==null||r.removeAllListeners(),v(this,Ct,void 0)}H(this,$d,Wh).call(this)}stopAllTransports(){p.info("Closing all transports"),this.stopTransports({send:!0,recv:!0})}connectTransportWithRetry(e){return u(this,null,function*(){const{id:n,serverId:r,direction:i}=e;H(this,Gh,Ly).call(this,e);try{const s=X.hasFeature(ie.ENABLE_HIVE_INFINITE_RETRIES)?1/0:3;return yield Oh((a,c)=>u(this,null,function*(){a>0&&p.debug(`Retrying transport connect, count: ${a}`,{transport:{id:n,serverId:r,type:i}});try{if(e.closed)throw new _i("Cannot reconnect closed transport");yield H(this,jh,Dy).call(this,e)}catch(d){if(d instanceof _i){c(d);return}throw p.error("Failed to connect transport, retrying",{transport:e,error:d}),d}}),{delayTime:100,strategy:"exponential",maxRetryCount:s}),e}catch(s){throw p.error(`Failed to connect send transport after retry: ${e.id}`,{error:s,transport:{id:n,serverId:r,type:i}}),e.close(),e.removeAllListeners(),s}})}handleErrors(e){throw new Error("Method not implemented.")}}Or=new WeakMap,po=new WeakMap,It=new WeakMap,Ct=new WeakMap,Ms=new WeakMap,mo=new WeakMap,go=new WeakMap,fo=new WeakMap,As=new WeakMap,Pi=new WeakMap,vo=new WeakMap,yo=new WeakSet,Jd=function(){return o(this,Or).getValue("connectionHandler")},$d=new WeakSet,Wh=function(){v(this,As,{send:void 0,recv:void 0})},jh=new WeakSet,Dy=function(t){return u(this,null,function*(){const{id:e,direction:n}=t;if(p.info(`Connecting ${n} transport`,{transport:{id:e,type:n}}),!o(this,Ms).isConnected)throw new _i("Socket is not connected");if(t.connectionState==="closed")throw new _i("Transport is closed");try{yield t.connect(r=>H(this,Jh,xy).call(this,n,r)),p.info(`Connected ${n} transport`,{transport:{id:e,serverId:t.serverId,type:n}})}catch(r){throw o(this,fo).transportFailureCount[n]+=1,r.message==="ice connection failed"?new _i(r.message):r}})},Hh=new WeakSet,Oy=function(t){return u(this,null,function*(){var e,n;if(o(this,It)&&o(this,It).connected){p.info("Transport send is already connected",{transport:{id:(e=o(this,It))==null?void 0:e.id,serverId:(n=o(this,It))==null?void 0:n.serverId,type:"send"}});return}v(this,It,o(this,po).createTransport(G(x({},t),{direction:"send"}))),J.configureSendTransport(o(this,It))})},qh=new WeakSet,Ny=function(t){return u(this,null,function*(){var e,n;if(o(this,Ct)&&o(this,Ct).connected){p.info("Transport recv is already connected",{transport:{id:(e=o(this,Ct))==null?void 0:e.id,serverId:(n=o(this,Ct))==null?void 0:n.serverId,type:"recv"}});return}v(this,Ct,o(this,po).createTransport(G(x({},t),{direction:"recv"}))),J.configureRecvTransport(o(this,Ct))})},Gh=new WeakSet,Ly=function(t){const{direction:e,id:n}=t;t.on("connectionstatechange",r=>u(this,null,function*(){H(this,zd,Kh).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,As)[e];s!==void 0&&(clearTimeout(s),o(this,As)[e]=void 0)};switch(r){case"connected":i(),o(this,fo).lastConnectionTime=performance.now();break;case"disconnected":o(this,As)[e]=setTimeout(()=>u(this,null,function*(){yield H(this,Kd,$h).call(this,t)}),qN);break;case"failed":if(t.closed)return;i(),yield H(this,Kd,$h).call(this,t);break}})),t.on("icecandidate",r=>u(this,null,function*(){p.debug("Sending iceCandidate:",{iceCandidate:r})})),t.on("datachannel:events",(r,i)=>u(this,null,function*(){var s,a;p.debug("Got data channel message on event:",{rtcChannel:{label:r,message:i}});try{switch(i.type){case"handshake":{const c={type:"handshake",payload:{message:"pong"}};t.sendResponseOverDC(r,Ay(i),c);break}case"hub-disconnect":{p.debug(`media hub disconnected, full_reconnect: ${(s=i.payload)==null?void 0:s.full_reconnect}`),((a=i.payload)==null?void 0:a.full_reconnect)===!0&&this.handleErrors("rejoin");break}case"error":break;default:break}}catch(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"))})},Jh=new WeakSet,xy=function(t,e){return u(this,null,function*(){const n=t==="recv";try{const{sdp:r,type:i}=e,s={consuming:n,description:{sdp:r,type:i,target:n?zn.SUBSCRIBER:zn.PUBLISHER},producers:[]};return o(this,mo).connectTransport(s)}catch(r){throw p.error(`Error in ${t} transport connection:`,{error:r,country:S.location.country}),r}})},Kd=new WeakSet,$h=function(t){return u(this,null,function*(){p.info("Called reconnect transport",{transport:t}),t.close(),t.removeAllListeners();const{direction:e}=t;switch(X.hasFeature(ie.HIVE_TRANSPORT_FORCE_RELAY_ON_ICE_FAILED)&&o(this,Ms).isConnected&&o(this,fo).transportFailureCount[e]>2&&(p.warn(`Multiple disconnections in ${e} transport, forcing relay`),v(this,Pi,"relay")),yield this.createTransports({[e]:!0}),e){case"send":{yield this.connectTransportWithRetry(o(this,It)),p.info("Transport reconnected",{transport:o(this,It)}),P.emit(R.RESET_PRODUCER_STATE);break}case"recv":{yield this.connectTransportWithRetry(o(this,Ct)),p.info("Transport reconnected",{transport:o(this,Ct)}),P.emit(R.UPDATE_ACTIVE,{createAllConsumers:!0});break}default:p.warn("Unknown transport direction",{transport:t})}H(this,zd,Kh).call(this,{state:Rr.CONNECTED,direction:e})})},zd=new WeakSet,Kh=function(t){const{state:e,direction:n}=t;o(this,yo,Jd).mediaState[n]={state:e,reconnected:!0},P.emit(R.TRANSPORT_STATE_UPDATE,x({transport:n},o(this,yo,Jd).mediaState[n]))};var zh,Vy;class JN{constructor(e){f(this,zh),this.recvTransport=e,H(this,zh,Vy).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:x(x({},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}})}}zh=new WeakSet,Vy=function(){this.recvTransport.on("datachannel:events",(t,e)=>u(this,null,function*(){try{switch(e.type){case"negotiation":{const{sdp:n}=e.payload,r={sdp:n,type:"offer"};this.negotiate(r,Ay(e),t);break}default:break}}catch(n){p.error(`Unable to handle the incoming datachannel message on channel ${t}`)}}))};class $N{constructor(e,n,r,i){this.events=e,this.recvTransport=n,this.socket=r,this.socketHandler=i}create(e){return u(this,null,function*(){if(!e||e&&e.length===0)throw new Error("List of producers is required");const n=new Map,r=[];e.forEach(d=>{const{producingPeerId:l,producerId:h,producingTransportId:m}=d;n.set(h,l),r.push({producingPeerId:l,producerId:h,producingTransportId:m})});const i=yield this.socketHandler.consume({requests:r,consumingTransportId:this.recvTransport.serverId}),s=new Map;e.forEach(d=>s.set(d.producerId,d));const a=new Map,c=[];return Object.entries(i.consumerStateMap).forEach(([d,l])=>{const h=s.get(d);if(!h)return;if(l.errorCode){if(p.warn(`Consumer request failed for producer ${d}`,{error:{message:l.errorCode}}),l.errorCode==="not_found_track_error"){p.error(`Track not found for producer: ${h.producerId}. This will not be retried.`);return}c.push(h);return}let m={};try{m=JSON.parse(l.producerState.appData)}catch(y){}a.set(d,{consumerId:l.consumerId,producingTransportId:h.producingTransportId,producingPeerId:h.producingPeerId,kind:h.kind,paused:h.pause,streamId:l.producerTrack.streamId,trackId:l.producerTrack.trackId,screenShare:h.screenShare,mimeType:h.mimeType,appData:m})}),{consumerStates:a,sessionDescription:i.sessionDescription,failedProducers:c}})}negotiate(e){return u(this,null,function*(){p.info("Negotiating socket consumer",{transport:this.recvTransport}),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:zn.SUBSCRIBER}};return p.debug(`sending renegotiate request: ${JSON.stringify(r)} on recvTransport`,{transport:this.recvTransport}),yield this.socket.sendMessagePromise(this.events.renegotiateSessionDescription,EC.toBinary(r)),p.info("Renegotiation done",{transport:this.recvTransport}),n})}close(e){return u(this,null,function*(){if(!e.length)return{};const n=(r,i)=>u(this,null,function*(){const s=r.map(l=>l.localId);p.info(`Closing consumers: ${JSON.stringify(s)}`);const a={description:{sdp:i.sdp,type:i.type,target:zn.SUBSCRIBER},consumerIds:s,consumingTransportId:this.recvTransport.serverId},c=yield this.socketHandler.closeConsumer(a),d=HP.fromBinary(c).description;return{sdp:d.sdp,type:d.type}});return this.recvTransport.awaitQueue.push(()=>this.recvTransport.closeConsumers(e,n),"close_consumer"),{}})}}class Yh{constructor(e){this.socketHandler=e}static getMSIDFromSDP(e,n){return Kr(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=Yh.getMSIDFromSDP(n.sdp,r),m={description:{sdp:n.sdp,type:n.type,target:zn.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:T}=yield this.socketHandler.produce(m);return{answer:y,producerId:T}})}}var So,Ds,Ri,Eo,Yd,or,Qh,Nr,To,Xh,Uy,Qd,Zh,ep,Fy,tp,By,np,Wy,rp,jy,ip,Hy,sp,qy;class KN extends GN{constructor(e,n,r){super(e,n,r),f(this,Xh),f(this,Qd),f(this,ep),f(this,tp),f(this,np),f(this,rp),f(this,ip),f(this,sp),f(this,So,void 0),f(this,Ds,void 0),f(this,Ri,void 0),f(this,Eo,void 0),f(this,Yd,void 0),f(this,or,void 0),f(this,Qh,{producerCreationFailureCount:0,consumerCreationFailureCount:0,producerNotReadyFailureCount:0}),f(this,Nr,[]),f(this,To,void 0),v(this,So,e),o(this,Xh,Uy).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,Ds)}get consumers(){return o(this,Ri)}get producerIdToConsumerIdMap(){return o(this,Eo)}reset(){v(this,Ds,new Map),v(this,Ri,new Map),v(this,Eo,new Map)}setupTransports(e){return u(this,null,function*(){yield this.createTransports(e);let n,r;e.send&&(n=H(this,ep,Fy).call(this)),e.recv&&(r=H(this,tp,By).call(this)),yield Promise.all([n,r])})}createProducer(e,n){return u(this,null,function*(){var r;if(!this.sendTransport||this.sendTransport.closed)throw new Error("Send transport is closed");try{const i=yield this.sendTransport.produce(e,H(this,np,Wy).bind(this));return(r=e.appData)!=null&&r.e2ee&&P.emit(R.E2EE_ACTIVE_PRODUCER,i),H(this,rp,jy).call(this,i,n),i}catch(i){throw p.error("Failed to create producer",{error:i}),o(this,Qh).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,So).getValue("modules").e2ee)!=null&&r.enabled&&P.emit(R.E2EE_INACTIVE_PRODUCER,i)}catch(s){p.error("Failed to close producer on server",{error:s,producer:i})}})}closeAllProducers(){return Promise.all(Array.from(o(this,Ds).entries()).map(([,e])=>e.close()))}createConsumer(e){return this.createConsumers([e])}createConsumers(e){return u(this,null,function*(){o(this,To)||clearTimeout(o(this,To)),v(this,Nr,o(this,Nr).concat(e)),yield H(this,Qd,Zh).call(this)})}closeConsumer(e){return this.closeConsumers([e])}closeConsumers(e){return u(this,null,function*(){if(!o(this,or))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,or).close(n);r!=null&&r.length&&p.warn("Failed to close some consumers",{consumerIds:r})})}closeAllConsumers(){return this.closeConsumers(Array.from(o(this,Ri).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})})}}So=new WeakMap,Ds=new WeakMap,Ri=new WeakMap,Eo=new WeakMap,Yd=new WeakMap,or=new WeakMap,Qh=new WeakMap,Nr=new WeakMap,To=new WeakMap,Xh=new WeakSet,Uy=function(){return o(this,So).getValue("connectionHandler")},Qd=new WeakSet,Zh=function(){return u(this,null,function*(){if(!this.recvTransport||this.recvTransport.closed)throw new Error("Recv transport is closed");const t=500,e=o(this,Nr).splice(0,o(this,Nr).length);try{const n=e.filter(({producerId:s})=>!this.producers.get(s));if(n.length===0)return;const{consumers:r,failedProducers:i}=yield this.recvTransport.consume(n,H(this,ip,Hy).bind(this),o(this,or).negotiate.bind(o(this,or)));r.forEach(H(this,sp,qy).bind(this)),i!=null&&i.length&&(p.error("Failed to create consumers for producers",{producers:i}),v(this,Nr,o(this,Nr).concat(i)),v(this,To,setTimeout(H(this,Qd,Zh).bind(this),t)))}catch(n){p.error("failed to consume on transport",{error:n})}})},ep=new WeakSet,Fy=function(){return u(this,null,function*(){yield this.connectTransportWithRetry(this.sendTransport),v(this,Yd,new Yh(this.socketHandler))})},tp=new WeakSet,By=function(){return u(this,null,function*(){switch(this.recvTransport.on("connect",()=>{o(this,Eo).clear()}),yield this.connectTransportWithRetry(this.recvTransport),this.nodeType){case tt.CF:{v(this,or,new $N(this.events,this.recvTransport,this.socket,this.socketHandler));break}case tt.HIVE:default:v(this,or,new JN(this.recvTransport))}})},np=new WeakSet,Wy=function(t){return o(this,Yd).create(t)},rp=new WeakSet,jy=function(t,e){t.on("close",(n,r)=>u(this,null,function*(){const{offer:i,reason:s}=n;if(p.info("producer::closing",{debuggingHint:s,producer:G(x({},t),{status:"closing"})}),s!==qd){const a={producerId:t.id,description:{sdp:i.sdp,type:i.type,target:zn.PUBLISHER}};try{const c=yield this.socketHandler.closeProducer(a),d={sdp:c==null?void 0:c.sdp,type:c==null?void 0:c.type};p.info("producer::closed",{producer:G(x({},t),{status:"closed"})}),r({answer:d})}catch(c){p.error("producer close error",c)}}this.producers.delete(t.id),e()})),t.on("trackended",()=>{p.info("producer::trackended",{producer:G(x({},t),{status:"UNKNOWN"})})}),o(this,Ds).set(t.id,t)},ip=new WeakSet,Hy=function(t){return u(this,null,function*(){try{return yield this.recvTransport.canConsume(),yield o(this,or).create(t)}catch(e){throw p.error("Error in consume request",{error:e}),e}})},sp=new WeakSet,qy=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,Ri).delete(t.id),P.emit(R.CONSUMER_CLOSED,{id:t.id})})),o(this,Ri).set(t.id,t),this.producerIdToConsumerIdMap.set(t.producerId,t.id),P.emit(R.NEW_CONSUMER,{id:t.id,appData:t.appData,peerId:t.peerId})};var Xd,Zd,el,ko,bo,wo,tl,nl,_o,Yt,Un,Fn,Mi,Ai,Lr,rl,ap,Gy,op,Jy,cp,$y,dp,Ky;const lp=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,ap),f(this,op),f(this,Xd,void 0),f(this,Zd,void 0),f(this,el,void 0),f(this,ko,void 0),f(this,bo,void 0),f(this,wo,void 0),f(this,tl,void 0),f(this,nl,void 0),f(this,_o,void 0),f(this,Yt,void 0),f(this,Un,void 0),f(this,Fn,!1),f(this,Mi,0),f(this,Ai,0),f(this,Lr,[]),f(this,rl,void 0),v(this,ko,t),v(this,Yt,t),v(this,Xd,e),v(this,Zd,n),v(this,el,r),v(this,bo,i),v(this,wo,s),v(this,tl,a),v(this,nl,c),v(this,_o,d),v(this,rl,l),v(this,Un,t/2)}get voiceDetected(){return o(this,Fn)}processAudioChunk(t){var e,n;const r=H(e=lp,cp,$y).call(e,t),i=H(n=lp,dp,Ky).call(n,t);return H(this,ap,Gy).call(this,r),r/o(this,Un)>o(this,_o)&&r>o(this,Yt)&&i>o(this,Xd)?(v(this,Mi,o(this,Mi)+1),v(this,Ai,o(this,el)),o(this,Mi)>=o(this,Zd)&&v(this,Fn,!0)):(v(this,Mi,0),o(this,Ai)>0?v(this,Ai,o(this,Ai)-1):o(this,Fn)&&v(this,Fn,!1),o(this,Fn)||H(this,op,Jy).call(this,r)),{energy:r,isVoice:o(this,Fn)}}reset(){v(this,Fn,!1),v(this,Mi,0),v(this,Ai,0),v(this,Yt,o(this,ko)),v(this,Un,o(this,ko)/2),v(this,Lr,[])}getThresholdInfo(){return{currentEnergyThreshold:o(this,Yt),backgroundNoiseEnergy:o(this,Un),energyRatioThreshold:o(this,_o)}}};let up=lp;Xd=new WeakMap,Zd=new WeakMap,el=new WeakMap,ko=new WeakMap,bo=new WeakMap,wo=new WeakMap,tl=new WeakMap,nl=new WeakMap,_o=new WeakMap,Yt=new WeakMap,Un=new WeakMap,Fn=new WeakMap,Mi=new WeakMap,Ai=new WeakMap,Lr=new WeakMap,rl=new WeakMap,ap=new WeakSet,Gy=function(t){o(this,Fn)?v(this,Yt,o(this,wo)*o(this,Yt)+(1-o(this,wo))*t):v(this,Yt,o(this,bo)*o(this,Yt)+(1-o(this,bo))*o(this,Un)),v(this,Yt,Math.max(o(this,tl),Math.min(o(this,nl),o(this,Yt))))},op=new WeakSet,Jy=function(t){if(t<o(this,Yt)*1.2)if(o(this,Lr).push(t),o(this,Lr).length>o(this,rl)&&o(this,Lr).shift(),o(this,Lr).length>=10){const e=[...o(this,Lr)].sort((r,i)=>r-i),n=Math.floor(e.length/2);v(this,Un,e[n])}else v(this,Un,.95*o(this,Un)+.05*t)},cp=new WeakSet,$y=function(t){return Math.sqrt(t.map(e=>e*e).reduce((e,n)=>e+n)/t.length)},dp=new WeakSet,Ky=function(t){let e=0;for(let n=1;n<t.length;n+=1)(t[n]>=0&&t[n-1]<0||t[n]<0&&t[n-1]>=0)&&(e+=1);return e},f(up,cp),f(up,dp);const zN=60,YN=400;var Di,Oi,Io,Bn,Co,Ni,Po,Os,Ro,Li,Ns,Mo,hp,zy,il,pp,mp,Yy,gp,Qy;const sl=class{constructor(t){f(this,hp),f(this,mp),f(this,Di,void 0),f(this,Oi,void 0),f(this,Io,void 0),f(this,Bn,void 0),f(this,Co,void 0),f(this,Ni,void 0),f(this,Po,void 0),f(this,Os,void 0),f(this,Ro,void 0),f(this,Li,void 0),f(this,Ns,void 0),f(this,Mo,void 0),this.reportRequest=t,v(this,Co,new AudioContext),v(this,Ni,o(this,Co).createAnalyser()),o(this,Ni).fftSize=2048,v(this,Ro,new up)}set producerId(t){v(this,Bn,t)}set audioTrack(t){v(this,Po,t);const e=new MediaStream;e.addTrack(o(this,Po)),o(this,Co).createMediaStreamSource(e).connect(o(this,Ni))}start(){p.debug(`AudioActivityReporter: Starting audio activity reporter: ${o(this,Bn)}`),o(this,Di)&&Jr(o(this,Di)),v(this,Di,$s(()=>u(this,null,function*(){var t;if(!o(this,Po)||!o(this,Bn))return;const{energy:e}=H(this,hp,zy).call(this),n=H(t=sl,il,pp).call(t,e);let r=.9;o(this,Mo)!==n&&o(this,Mo)?r=.9:n?r=.3:r=.5,v(this,Os,(o(this,Os)||0)*(1-r)+e*r)}),zN)),o(this,Oi)&&Jr(o(this,Oi)),v(this,Oi,$s(H(this,mp,Yy).bind(this),YN)),v(this,Io,$s(()=>{p.debug(`AudioActivityReporter: producer: ${o(this,Bn)} energy: ${o(this,Os)}`)},5e3))}stop(){p.debug(`AudioActivityReporter: Stopping audio activity reporter: ${o(this,Bn)}`),o(this,Di)&&Jr(o(this,Di)),o(this,Oi)&&Jr(o(this,Oi)),o(this,Io)&&Jr(o(this,Io)),o(this,Ro).reset()}};let fp=sl;Di=new WeakMap,Oi=new WeakMap,Io=new WeakMap,Bn=new WeakMap,Co=new WeakMap,Ni=new WeakMap,Po=new WeakMap,Os=new WeakMap,Ro=new WeakMap,Li=new WeakMap,Ns=new WeakMap,Mo=new WeakMap,hp=new WeakSet,zy=function(){var t;const e=new Float32Array(o(this,Ni).frequencyBinCount);o(this,Ni).getFloatTimeDomainData(e);const{energy:n,isVoice:r}=o(this,Ro).processAudioChunk(e),i=H(t=sl,gp,Qy).call(t,n);return i===-1/0||n<1e-6?{energy:0,isVoice:!1}:((!o(this,Li)||i<o(this,Li))&&v(this,Li,i),(!o(this,Ns)||i>o(this,Ns))&&v(this,Ns,i),{energy:(i-o(this,Li))/(o(this,Ns)-o(this,Li))*10||0,isVoice:r})},il=new WeakSet,pp=function(t){return t<5},mp=new WeakSet,Yy=function(t=o(this,Os)){var e;if(!o(this,Bn)||!t){p.debug(`AudioActivityReporter: No producerId or energy to report: ${o(this,Bn)}`);return}const n={producerId:o(this,Bn),energy:Math.round(t),silent:H(e=sl,il,pp).call(e,t)};v(this,Mo,n.silent),this.reportRequest(n)},gp=new WeakSet,Qy=function(t){const e=Math.log10(t);return Math.round(e)},f(fp,il),f(fp,gp);const QN=()=>{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]},XN=()=>{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 ZN=Object.defineProperty,eL=Object.getOwnPropertyDescriptor,he=(t,e,n,r)=>{for(var i=r>1?void 0:r?eL(e,n):e,s=t.length-1,a;s>=0;s--)(a=t[s])&&(i=(r?a(e,n,i):a(i))||i);return r&&i&&ZN(e,n,i),i};const Wn=["video/VP9","video/VP8"];var al,ol,Pt,$,Ao,xi,Ft,Ls,xs,Vi,cl,xr,Do,Vs,Us,Bt,Qt,Ui,Fs,ft,Rt,Bs,Oo,vp,Xy,yp,Zy,Sp,eS;class ue{constructor(e,n,r){f(this,Ui),f(this,ft),f(this,Bs),f(this,vp),f(this,yp),f(this,Sp),g(this,"context"),g(this,"authToken"),g(this,"e2ee"),f(this,al,void 0),f(this,ol,void 0),f(this,Pt,void 0),f(this,$,void 0),f(this,Ao,void 0),f(this,xi,void 0),f(this,Ft,void 0),f(this,Ls,void 0),f(this,xs,void 0),f(this,Vi,void 0),f(this,cl,void 0),f(this,xr,void 0),f(this,Do,void 0),f(this,Vs,void 0),f(this,Us,void 0),f(this,Bt,void 0),f(this,Qt,void 0),g(this,"partialJoinRoomPromise");var i,s;this.context=e;const{socket:a}=r;this.mediaJoined=!1,v(this,Vs,new Map([["video/VP9",new Set],["video/VP8",new Set]])),v(this,Us,new Map([["video/VP9",new Set],["video/VP8",new Set]])),v(this,xi,n),v(this,Pt,a),v(this,Ls,!1),v(this,$,new KN(e,a,n)),v(this,Ft,o(this,$).events),v(this,xr,new Set),v(this,Bt,new Map),v(this,xs,!1),v(this,Vi,new Vd),n===tt.CF&&v(this,Qt,new fp(o(this,$).socketHandler.audioActivity.bind(o(this,$).socketHandler))),this.e2ee=(s=(i=e.getValue("modules").e2ee)==null?void 0:i.enabled)!=null?s:!1,this.handleSocketEvents(),this.handleCallstatsEvents(),v(this,cl,qc(()=>u(this,null,function*(){if(!o(this,Ui,Fs).mediaJoinAttempted)return;const{roomJoined:c}=yield this.joinRoom(o(this,ol),o(this,al),{},!0,!0);c&&(P.emit(R.RESET_PRODUCER_STATE),P.emit(R.ROOM_NODE_RECONNECTED))}),5e3,{leading:!0,maxWait:1e3}))}get peerId(){return this.context.getValue("peerId")}get mediaJoined(){return o(this,Ui,Fs).mediaJoined}set mediaJoined(e){o(this,Ui,Fs).mediaJoined=e}reset(e=!0){o(this,$).closeAllProducers(),o(this,$).closeAllConsumers(),o(this,Bt).clear(),o(this,xr).clear(),e&&(this.partialJoinRoomPromise=void 0,o(this,Vi).stop(),o(this,$).stopAllTransports(),o(this,$).reset(),v(this,Vi,new Vd))}joinRoom(e,n){return u(this,arguments,function*(r,i,s={},a=!1,c=!1){o(this,Ui,Fs).mediaJoinAttempted=!0,v(this,Ls,!0),this.reset(a);const d=ot().ipInfo;if(d!=null&&d.loc&&!o(this,Do)){const h=d.loc.split(",");v(this,Do,{latitude:parseFloat(h[0]),longitude:parseFloat(h[1])})}let l;try{return l=yield o(this,Vi).push(()=>this._joinRoom(r,i,s,c,o(this,Do)),"joinRoom"),l}catch(h){l={roomJoined:!1}}return l.roomJoined||P.emit(R.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[h,m]=a.loc.split(",").map(parseFloat);c={latitude:h,longitude:m}}const d=(s=X.getValue(ie.FORCE_VIDEO_CODEC))==null?void 0:s.toString(),l=NN(d);v(this,Ao,l),yield Oh((h,m)=>u(this,null,function*(){if(!o(this,Pt).isConnected){m(new Error("socket is not connected"));return}h>0&&p.warn(`retrying sending join room request, count: ${h}`);try{yield o(this,$).socketHandler.joinRoom(n,e,l,r,c)}catch(y){throw p.error("failed to send join room request, error:",{error:y}),y}}),{delayTime:1e3,strategy:"exponential",maxRetryCount:X.hasFeature(ie.ENABLE_HIVE_INFINITE_RETRIES)?1/0:3}),yield o(this,$).setupTransports({send:!0,recv:!0}),o(this,xi)!==tt.HIVE&&X.hasFeature(ie.PRECREATE_PRODUCERS)&&(this.shareWebcam(XN()),this.shareMic(QN()))})}partialJoinRoom(e,n,r=!1,i=void 0){return u(this,null,function*(){return this.partialJoinRoomPromise=o(this,Vi).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,ol,r);try{this.partialJoinRoomPromise?yield this.partialJoinRoomPromise:yield this._partialJoinRoom(r,i,a,c)}catch(d){p.error("error in partial join room",{error:d})}finally{this.partialJoinRoomPromise=void 0}try{return navigator.product!=="ReactNative"&&setTimeout(()=>u(this,null,function*(){const d={userId:this.context.getValue("userId"),peerId:this.peerId,roomUUID:i,roomViewType:"groupCall",deviceInfo:G(x({},Ie.getDeviceInfo()),{userAgent:navigator.userAgent,memory:navigator.deviceMemory,cpus:navigator.hardwareConcurrency}),sdkName:this.context.getValue("sdkName"),sdkVersion:this.context.getValue("sdkVersion"),metaData:{},permissions:{}};J.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{roomState:e}=yield o(this,$).socketHandler.notifySelfJoinComplete();return v(this,al,e.roomUuid),v(this,xs,!0),v(this,Ls,!1),!0}catch(e){return p.error("error on completing join room:",{error:e}),this.mediaJoined=!1,!1}})}leaveRoom(){return u(this,null,function*(){o(this,$).stopAllTransports(),v(this,xs,!1),o(this,Ui,Fs).mediaJoinAttempted=!1;const e={closeRoom:!1};o(this,Pt).sendMessagePromise(o(this,Ft).leaveRoom,qC.toBinary(e)).then(n=>{var r;(r=RP.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})}),J.callEnded(),S.destruct()})}getConsumers(){return o(this,$).consumers}activatePeers(e){return u(this,null,function*(){return this.createConsumers(e)})}deactivatePeers(e,n="default"){return u(this,null,function*(){const r=new Set;e.forEach(s=>{s.screenShare&&s.kind==="video"&&r.add(s.producingPeerId)});const i=n==="default"?e.filter(s=>!r.has(s.producingPeerId)).filter(s=>s.kind!=="audio"):e;yield Promise.all(i.map(s=>{const a=o(this,$).producerIdToConsumerIdMap.get(s.producerId);if(!a){p.warn(`consumer not found in deactivate producers: ${s.producerId}`);return}return o(this,$).closeConsumer(a)}))})}createConsumers(e){return u(this,null,function*(){return e.length===0?Promise.resolve():o(this,$).createConsumers(e)})}closeConsumers(e){return u(this,null,function*(){if(!e.length)return;const n=e.reduce((r,i)=>{const s=o(this,$).producerIdToConsumerIdMap.get(i.producerId);return s?(r.push(s),r):(p.warn(`consumer not found in deactivate producers: ${i.producerId}`),r)},[]);yield o(this,$).closeConsumers(n)})}_shareWebcam(e,n){return u(this,null,function*(){const r=n==="video/VP9"?ke.WEBCAM:ke.WEBCAM_BACKUP,i=H(this,ft,Rt).call(this,r);if(i){const h=yield i;if(o(this,$).producers.has(h)){const m=o(this,$).producers.get(h);if(!m.closed&&!navigator.isReactNative)return yield m.replaceTrack({track:e}),yield this.resumeWebcam(r),e;yield this.disableWebcam(n)}return this._shareWebcam(e,n)}const s=H(this,Sp,eS).call(this,e,n),a=$c(this.context,"disableSimulcast"),c=o(this,xi)===tt.CF?ie.ENABLE_CF_SIMULCAST:ie.ENABLE_HIVE_SIMULCAST;!a&&X.hasFeature(c)?(p.info(`Simulcast enabled for SFU: ${o(this,xi)}`),s.encodings=RO(e)):p.info(`Simulcast disabled for webcam producer, SFU: ${o(this,xi)}`),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,$).createProducer(s,d);return H(this,Bs,Oo).call(this,r,l.then(h=>h.id)),l.then(h=>h.track)})}shareWebcam(e){return u(this,null,function*(){if(e===void 0)return null;if(X.hasFeature(ie.FORCE_VIDEO_CODEC)){const n=X.getValue(ie.FORCE_VIDEO_CODEC).toString();if(n)return p.debug(`Calling _shareWebcam with forced video codec: ${n}`),this._shareWebcam(e,n)}return yield Promise.all(Wn.map(n=>{var r,i;return((i=(r=o(this,Ao).sender)==null?void 0:r.video)==null?void 0:i.codecs.findIndex(s=>s.mimeType===n))>=0&&o(this,Us).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(ke.SCREENSHARE_VIDEO),o(this,Bt).delete(ke.SCREENSHARE_AUDIO)},a=o(this,$).createProducer(i,s);H(this,Bs,Oo).call(this,ke.SCREENSHARE_VIDEO,a.then(d=>d.id));let c;if(r){const d={track:r,codecOptions:[{name:"opus"}],appData:{screenShare:!0,e2ee:this.e2ee,supportsRemoteControl:Ie.isElectron()},stopTracks:!1,zeroRtpOnPause:!0},l=()=>{};c=o(this,$).createProducer(d,l),H(this,Bs,Oo).call(this,ke.SCREENSHARE_AUDIO,c.then(h=>h.id))}yield Promise.all([a,c||Promise.resolve()]),J.screenShareStart()})}shareMic(e){return u(this,null,function*(){try{if(e===void 0)throw new Ut("track undefined");const n=H(this,ft,Rt).call(this,ke.MIC);if(n){const a=yield n;if(o(this,$).producers.has(a)){const c=o(this,$).producers.get(a);if(!c.closed&&!navigator.isReactNative){yield c.replaceTrack({track:e}),yield this.resumeMic(),o(this,Qt)&&(o(this,Qt).audioTrack=e,o(this,Qt).producerId=a,o(this,Qt).start());return}yield o(this,$).closeProducer(a,{stopTrack:!1})}yield this.shareMic(e);return}const r=H(this,yp,Zy).call(this,e),i=()=>{o(this,Bt).delete(ke.MIC)},s=o(this,$).createProducer(r,i);H(this,Bs,Oo).call(this,ke.MIC,s.then(a=>a.id)),yield s.then(a=>{o(this,Qt)&&(o(this,Qt).audioTrack=a.track,o(this,Qt).producerId=a.id,o(this,Qt).start())})}catch(n){throw new _(n)}})}pauseMic(){return u(this,null,function*(){const e=yield H(this,ft,Rt).call(this,ke.MIC),n=o(this,$).producers.get(e);if(!n){p.error("pauseMic::could_not_find_mic_producer");return}if(n.paused){p.info("pauseMic::mic_producer_already_paused");return}n.pause(),o(this,Qt).stop();const r={producerId:n.id,pause:!0};o(this,Pt).sendMessage(o(this,Ft).toggleProducer,Qc.toBinary(r))})}pauseWebcam(){return u(this,null,function*(){const e=yield H(this,ft,Rt).call(this,ke.WEBCAM),n=yield H(this,ft,Rt).call(this,ke.WEBCAM_BACKUP),r=o(this,$).producers.get(e),i=o(this,$).producers.get(n);if(!r&&!i){p.error("pauseWebcam::could_not_find_webcam_producer");return}const s=a=>{const c={producerId:a.id,pause:!0};o(this,Pt).sendMessage(o(this,Ft).toggleProducer,Qc.toBinary(c))};r&&(r.pause(),s(r)),i&&(i.pause(),s(i))})}resumeMic(){return u(this,null,function*(){const e=yield H(this,ft,Rt).call(this,ke.MIC),n=o(this,$).producers.get(e);if(!n){p.error("resumeMic::could_not_find_mic_producer");return}if(!n.pause){p.info("resumeMic::mic_producer_already_resumed");return}n.resume(),n.appData.e2ee&&P.emit(R.E2EE_ACTIVE_PRODUCER,n);const r={producerId:n.id,pause:!1};o(this,Pt).sendMessage(o(this,Ft).toggleProducer,Qc.toBinary(r))})}resumeWebcam(){return u(this,arguments,function*(e=ke.WEBCAM){const n=yield H(this,ft,Rt).call(this,e),r=o(this,$).producers.get(n);if(!r){p.error("resumeWebcam::could_not_find_webcam_producer");return}if(!r.paused){p.info("resumeWebcam::webcam_producer_already_resumed");return}r.resume(),r.appData.e2ee&&P.emit(R.E2EE_ACTIVE_PRODUCER,r);const i={producerId:r.id,pause:!1};o(this,Pt).sendMessage(o(this,Ft).toggleProducer,Qc.toBinary(i))})}disableWebcam(e){return u(this,null,function*(){const n=e==="video/VP9"?ke.WEBCAM:ke.WEBCAM_BACKUP,r=yield H(this,ft,Rt).call(this,n);H(this,vp,Xy).call(this,n),r&&(yield o(this,$).closeProducer(r))})}disableMic(){return u(this,null,function*(){var e;const n=yield H(this,ft,Rt).call(this,ke.MIC);n&&(yield o(this,$).closeProducer(n)),(e=o(this,Qt))==null||e.stop(),o(this,Bt).delete(ke.MIC)})}disableScreenShare(){return u(this,null,function*(){p.info("screen_sharing_stopped"),J.screenShareStop();const e=yield H(this,ft,Rt).call(this,ke.SCREENSHARE_VIDEO),n=yield H(this,ft,Rt).call(this,ke.SCREENSHARE_AUDIO);e&&(yield o(this,$).closeProducer(e)),n&&(yield o(this,$).closeProducer(n)),o(this,xr).clear(),o(this,Bt).delete(ke.SCREENSHARE_VIDEO),o(this,Bt).delete(ke.SCREENSHARE_AUDIO)})}muteSelf(){return u(this,null,function*(){this.pauseMic()})}unmuteSelf(){return u(this,null,function*(){})}resetVideoProducers(e,n){return u(this,null,function*(){if(e){const r=yield H(this,ft,Rt).call(this,ke.WEBCAM),i=yield H(this,ft,Rt).call(this,ke.WEBCAM_BACKUP);yield o(this,$).closeProducer(r,{stopTrack:!1}),yield o(this,$).closeProducer(i,{stopTrack:!1}),this.shareWebcam(e)}if(n){const r=yield H(this,ft,Rt).call(this,ke.SCREENSHARE_VIDEO);yield o(this,$).closeProducer(r,{stopTrack:!1}),this.shareScreen({video:n})}})}changeDisplayName(e,n){return u(this,null,function*(){const r={displayName:e,participantId:n!=null?n:this.peerId};if(!(yield o(this,$).socketHandler.changeDisplayName(r)))throw new Error("failed to change display name!")})}kick(e){return u(this,null,function*(){const n={participantId:e};if(!(yield o(this,$).socketHandler.kickPeer(n)))throw new Error("failed to kickout the participant!")})}kickAll(){return u(this,null,function*(){if(!(yield o(this,$).socketHandler.kickAll()))throw new Error("failed to kickout all participant!")})}muteAll(e){return u(this,null,function*(){if(!(yield o(this,$).socketHandler.hostControlForAll("audio")))throw new Error("failed to mute all participant")})}muteAllVideo(){return u(this,null,function*(){if(!(yield o(this,$).socketHandler.hostControlForAll("video")))throw new Error("failed to mute all video participant")})}disableAudio(e){return u(this,null,function*(){if(!(yield o(this,$).socketHandler.hostControlForPeer(e,"audio")))throw new Error("failed to mute given participant")})}disableVideo(e){return u(this,null,function*(){if(!(yield o(this,$).socketHandler.hostControlForPeer(e,"video")))throw new Error("failed to mute video of given participant")})}pinPeer(e){return u(this,null,function*(){const n={participantId:e!=null?e:""};try{yield o(this,Pt).sendMessagePromise(o(this,Ft).globalPinPeer,eP.toBinary(n))}catch(r){p.error("Error in pinning peer:",{error:r})}})}validateScreenShare(e){return this.peerId===e.peerId&&o(this,$).producers.get(e.producerId)&&o(this,xr).add(e.consumerPeerId),o(this,xr).size}switchConsumersToLayer(e,n){return u(this,null,function*(){o(this,$).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}=oR.fromBinary(e);if(i===this.peerId)return;if(s!=null&&s.mimeType||(s.mimeType=s.kind===Ln.AUDIO?"audio/opus":"video/VP8"),s.kind===Ln.VIDEO&&!s.screenShare&&((r=(n=o(this,Ao).receiver)==null?void 0:n.video)==null?void 0:r.codecs.findIndex(a=>a.mimeType===Wn[0]))>=0&&o(this,Vs).get(Wn[0]).has(i)&&s.mimeType!==Wn[0]){p.warn(`Ignoring producer: ${s.producerId}`);return}p.info(`producer created broadcast: ${i}, producer state: ${s}`),P.emit(R.NEW_PRODUCER,{peerId:i,producer:G(x({},s),{kind:s.kind===Ln.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}}=cv.fromBinary(e),c=i===Ln.AUDIO?"audio":"video";if(p.info(`producer toggle broadcast: ${n}, producerId: ${a}, kind:${c}, paused:${s} payload: ${JSON.stringify(cv.fromBinary(e))}`),n===this.peerId&&r!==this.peerId&&s&&P.emit(c==="audio"?R.MUTE_SELF:R.MUTE_SELF_VIDEO),n===this.peerId)return;P.emit(R.PRODUCER_TOGGLE,{peerId:n,producerId:a,paused:s,kind:c}),Array.from(this.getConsumers().values()).filter(d=>d.producerId===a).forEach(d=>{d.paused!==s&&(p.debug(`consumer state mismatched for ${d.id}. updating consumer pause state ${d.paused} to ${s}`),s?(d.pause(),P.emit(R.CONSUMER_PAUSED,{id:d.id})):(d.resume(),P.emit(R.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}=Lu.fromBinary(e);if(n===this.peerId)return;p.info(`peer left broadcast:${n}`),o(this,xr).delete(n),o(this,$).consumers.forEach(r=>{r.peerId===n&&r.close()}),P.emit(R.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}}=lR.fromBinary(e);if(n===this.peerId)return;p.info(`producer closed broadcast:${n}`),P.emit(R.PRODUCER_CLOSED,{peerId:n,producerId:r});const i=o(this,$).producerIdToConsumerIdMap.get(r);if(!i){p.warn(`no consumer found for producer:${r}`);return}p.info(`closing consumer ${i}, producer id: ${r}`),o(this,$).closeConsumer(i).then(()=>{p.info(`closed consumer: ${i}`),o(this,$).producerIdToConsumerIdMap.delete(r),P.emit(R.CONSUMER_CLOSED,{id:i})}).catch(s=>{p.error("error closing consumer",{error:s})})}catch(n){p.error("error on producer close broadcast",{error:n})}}),o(this,Pt).on(o(this,Ft).mediaRoomTerminationBroadcastResponse,()=>{!this.mediaJoined&&!o(this,Ls)&&!o(this,xs)||(p.warn("media hub termination broadcast received, rejoining room"),P.emit(R.ROOM_NODE_DISCONNECTED),o(this,cl).call(this))})})}handleCallstatsEvents(){J.onConsumerScore(e=>{e.forEach((n,r)=>{const i=o(this,$).consumers.get(r);i&&P.emit(R.CONSUMER_SCORE_UPDATE,{id:r,kind:i.kind,peerId:i.peerId,score:n.score,scoreStats:n})})}),J.onProducerScore(e=>{e.forEach((n,r)=>{const i=Array.from(o(this,$).producers.values()).find(s=>s.id===r);i&&P.emit(R.PRODUCER_SCORE_UPDATE,{id:r,kind:i.kind,appData:i.appData,score:n.score,scoreStats:n})})})}handlePeerCapabilities(e,n){var r,i,s,a;for(let c=0;c<=Wn.length;c+=1){const d=Wn[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===Wn.length-1){o(this,Us).get(d).add(e);break}}for(let c=0;c<=Wn.length;c+=1){const d=Wn[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===Wn.length-1){o(this,Vs).get(d).add(e);break}}}handlePeerLeaving(e){X.hasFeature(ie.FORCE_VIDEO_CODEC)||(o(this,Vs).forEach(n=>n.delete(e)),o(this,Us).forEach((n,r)=>{n.delete(e),n.size===0&&this.disableWebcam(r)}))}}al=new WeakMap,ol=new WeakMap,Pt=new WeakMap,$=new WeakMap,Ao=new WeakMap,xi=new WeakMap,Ft=new WeakMap,Ls=new WeakMap,xs=new WeakMap,Vi=new WeakMap,cl=new WeakMap,xr=new WeakMap,Do=new WeakMap,Vs=new WeakMap,Us=new WeakMap,Bt=new WeakMap,Qt=new WeakMap,Ui=new WeakSet,Fs=function(){return this.context.getValue("connectionHandler")},ft=new WeakSet,Rt=function(t){return o(this,Bt).get(t)},Bs=new WeakSet,Oo=function(t,e){return o(this,Bt).set(t,e)},vp=new WeakSet,Xy=function(t){return o(this,Bt).delete(t)},yp=new WeakSet,Zy=function(t){return{track:t,encodings:[{priority:"high"}],codecOptions:[{name:"opus"}],appData:{e2ee:this.e2ee},stopTracks:!1,zeroRtpOnPause:!0}},Sp=new WeakSet,eS=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 tS(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 nS(t){const e=t.getValue("roomNodeClient");try{e==null||e.leaveRoom()}catch(n){p.error("roomNodeClient::cleanupRoomNodeClient")}t.setValue("roomNodeClient",void 0)}var tL=Object.defineProperty,nL=Object.getOwnPropertyDescriptor,Fi=(t,e,n,r)=>{for(var i=r>1?void 0:r?nL(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},Bi,jn,Mt,an,wn,rS;const iS=(rS=class{constructor(t,e,n,r){f(this,an),g(this,"self"),g(this,"authToken"),f(this,Bi,void 0),g(this,"viewType"),f(this,jn,void 0),f(this,Mt,void 0);const{socket:i}=n,s=t.getValue("authToken");this.self=e,v(this,Mt,t),this.viewType=r,this.authToken=s,v(this,Bi,i),v(this,jn,n),e.config.viewType!==yt.Chat&&this.setupEvents()}get peerId(){return o(this,Mt).getValue("peerId")}get mediaJoined(){return o(this,Mt).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)}),J.devices("AUDIO",h==null?void 0:h.filter(m=>m.kind==="audioinput")),J.devices("VIDEO",h==null?void 0:h.filter(m=>m.kind==="videoinput")),J.devices("SPEAKER",h==null?void 0:h.filter(m=>m.kind==="audiooutput")),p.info("Callstats:: initializing");try{yield J.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:Gf(t),skipConnectivityChecks:l}),p.info("Callstats:: initialized")}catch(m){p.error("Callstats:: initialization failed",{error:m})}}),0)}else p.info("Callstats:: Skipped initialization due to navigator product being ReactNative.");return new iS(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,wn).shareMic(e)}catch(d){this.self.disableAudio()}if(r.canProduceVideo&&s)try{const d=yield o(this,an,wn).shareWebcam(n);d&&d.id!==n.id&&X.hasFeature(ie.EXP_RESHARE)&&(yield o(this,an,wn).shareWebcam(d))}catch(d){this.self.disableVideo()}if(r.canProduceScreenshare&&a)try{yield(t=o(this,an,wn))==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*(){J.callEnded(),o(this,an,wn).reset(),t&&(yield this.joinRoom(t))})}setupEvents(){P.on(R.RESET_PRODUCER_STATE,()=>u(this,null,function*(){this.mediaJoined&&this.shareMediaTracks()})),P.on(R.ROOM_NODE_RECONNECTED,()=>{this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:!0})}),P.on(R.ROOM_NODE_DISCONNECTED,()=>{this.self.roomState!=="disconnected"&&(this.self.roomState="disconnected",this.self.emit("roomLeft",{state:"disconnected"}))}),P.on(R.ROOM_NODE_FAILED,()=>{this.self.roomState="failed",this.self.emit("roomLeft",{state:"failed"})}),P.on(R.SOCKET_SERVICE_RECONNECTED,({wasJoinAttempted:t})=>{t===!1&&(this.self.roomState="init"),this.resetSelf(t)}),P.on(R.SOCKET_SERVICE_DISCONNECTED,({joinAttempted:t})=>{if(this.self.roomState==="disconnected")return;let{peerId:e}=this;t&&X.hasFeature(ie.REFRESH_ID_ON_DISCONNECTION)&&(e=Gi()),o(this,Bi).updateURL(e),S.resetPeerId(e),ot().setHeader("dyte-tracing-id",e),ri.remapContext(e,o(this,Mt)),this.self.roomState="disconnected",this.self.emit("roomLeft",{state:"disconnected"})}),P.on(R.SOCKET_SERVICE_FAILED,()=>{this.self.roomState="failed",this.self.emit("roomLeft",{state:"failed"})}),o(this,jn).on(W.waitingRoomRequestAccepted,()=>{this.waitlistAcceptHandler()}),o(this,jn).on(rd.updateUserPreset,t=>{t.updatePeersPresets.forEach(e=>{e.userIds===this.self.userId&&P.emit(R.UPDATE_PERMISSIONS,e.patch)})}),o(this,jn).on(W.waitingRoomRequestDenied,()=>{this.waitlistRejectedHandler()}),o(this,jn).on(W.kick,()=>{this.kickHandler({kickType:"kick"})}),o(this,jn).on(W.kickAll,()=>{this.kickHandler({kickType:"kickAll"})}),P.onAsync(R.JOIN_MEDIA_ROOM,this.joinMediaRoom.bind(this)),P.on(R.PRODUCER_SCORE_UPDATE,({score:t,kind:e,appData:n,scoreStats:r})=>{var i;const s=(i=n==null?void 0:n.screenShare)!=null?i:!1;this.self.emit("mediaScoreUpdate",{kind:e,isScreenshare:s,score:t,participantId:this.self.id,scoreStats:r})}),P.on(R.MUTE_SELF,()=>u(this,null,function*(){this.self.audioEnabled&&(yield this.self.disableAudio(),J.audioOff())})),P.on(R.MUTE_SELF_VIDEO,()=>u(this,null,function*(){this.self.videoEnabled&&(yield this.self.disableVideo(),J.videoOff())})),P.onAsync(R.LEAVE_MEDIA_ROOM,this.leaveMediaRoom.bind(this)),P.on(R.PIP_HANGUP,this.leaveRoom.bind(this))}joinRoom(t=!1){return u(this,null,function*(){try{const{peer:e}=yield o(this,jn).joinRoom(this.self);o(this,jn).socket.flush();const n=lh(e.stageType);if(o(this,Mt).setValue("stageStatus",n,!1),e.waitlisted){this.waitlistedHandler();return}yield this.joinMediaRoom(t),o(this,Mt).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,Bi))==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,Mt).setValue("stageStatus","OFF_STAGE",!1),yield this.leaveMediaRoom(t),o(this,Mt).notify("stageStatus");try{(n=o(this,Bi))==null||n.disconnect()}catch(r){p.error("SelfController::leaveRoom::socketDisconnect")}nS(o(this,Mt)),Ld.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,Mt).getAllValues(),{sfu:d}=c;try{if(i===yt.Livestream){if(a!=="ON_STAGE"){this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:t});return}tS(o(this,Mt),d,{socket:o(this,Bi),peerId:r})}const{roomJoined:l}=(n=yield(e=o(this,an,wn))==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",{error:l}),new _("Error: could not join media room","0002")}})}leaveMediaRoom(t){return u(this,null,function*(){const e=o(this,Mt).getValue("viewType");t!=="connected-meeting"&&(yield this.cleanupSelf()),!(t==="stageLeft"&&e===yt.Webinar)&&o(this,an,wn)&&(o(this,an,wn).mediaJoined&&t!=="disconnected"&&(yield o(this,an,wn).leaveRoom()),!(t==="stageLeft"&&e===yt.Livestream)&&(o(this,an,wn).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()})}},Bi=new WeakMap,jn=new WeakMap,Mt=new WeakMap,an=new WeakSet,wn=function(){return o(this,Mt).getValue("roomNodeClient")},rS);let Vr=iS;Fi([S.trace("SelfController.resetSelf")],Vr.prototype,"resetSelf",1),Fi([S.trace("SelfController.setupEvents")],Vr.prototype,"setupEvents",1),Fi([S.trace("SelfController.joinRoom")],Vr.prototype,"joinRoom",1),Fi([S.trace("SelfController.leaveRoom")],Vr.prototype,"leaveRoom",1),Fi([S.trace("SelfController.joinMediaRoom")],Vr.prototype,"joinMediaRoom",1),Fi([S.trace("SelfController.leaveMediaRoom")],Vr.prototype,"leaveMediaRoom",1),Fi([S.trace("SelfController.init")],Vr,"init",1);var dl;class rL{constructor(e){f(this,dl,void 0),v(this,dl,e)}on(e,n){let r;e===W.roomPeerCount?r=uv.fromBinary.bind(uv):r=Cv.fromBinary.bind(Cv),o(this,dl).on(e,({payload:i})=>{const s=r(i);return n(s)})}}dl=new WeakMap;var ll;class iL{constructor(e){f(this,ll,void 0),v(this,ll,e)}on(e,n){let r,i;switch(e){case W.transcript:{r=xu.fromBinary.bind(xu),i=xu.create();break}default:{p.debug("AISocketHandler switch case hit default, event not accounted for.");break}}o(this,ll).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)})}}ll=new WeakMap;var sL=Object.defineProperty,aL=Object.getOwnPropertyDescriptor,Ep=(t,e,n,r)=>{for(var i=r>1?void 0:r?aL(e,n):e,s=t.length-1,a;s>=0;s--)(a=t[s])&&(i=(r?a(e,n,i):a(i))||i);return r&&i&&sL(e,n,i),i},Ur;class ul{constructor(e){f(this,Ur,void 0),v(this,Ur,e)}getPolls(){return o(this,Ur).sendMessagePromise(Xn.getPolls)}createPoll(e,n,r=!1,i=!1){const s={anonymous:r,hideVotes:i,question:e,options:n};return o(this,Ur).sendMessage(Xn.createPoll,Z1.toBinary(s))}votePoll(e,n){const r={index:n,pollId:e};return o(this,Ur).sendMessage(Xn.votePoll,tD.toBinary(r))}on(e,n){let r,i;switch(e){case Xn.updatePoll:case Xn.createPoll:case Xn.votePoll:{r=zu.fromBinary.bind(zu),i=zu.create();break}}o(this,Ur).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,Ur).removeListeners(e)}}Ur=new WeakMap,Ep([S.trace("PollSocketHandler.getPolls")],ul.prototype,"getPolls",1),Ep([S.trace("PollSocketHandler.createPoll")],ul.prototype,"createPoll",1),Ep([S.trace("PollSocketHandler.votePoll")],ul.prototype,"votePoll",1);var Xt;class oL{constructor(e){f(this,Xt,void 0),v(this,Xt,e)}getStageRequests(){return u(this,null,function*(){const{payload:e}=yield o(this,Xt).sendMessagePromise(W.getStageRequests);return e?Ku.fromBinary(e):{stageRequests:[]}})}requestAccess(){o(this,Xt).sendMessage(W.requestStageAccess)}cancelRequestAccess(){o(this,Xt).sendMessage(W.cancelStageRequest)}grantAccess(e){return u(this,null,function*(){const n={userIds:e};o(this,Xt).sendMessage(W.grantStageAccess,H1.toBinary(n))})}denyAccess(e){return u(this,null,function*(){const n={userIds:e};o(this,Xt).sendMessage(W.denyStageAccess,G1.toBinary(n))})}joinStage(){return o(this,Xt).sendMessagePromise(W.joinStage,void 0,void 0,W.peerStageStatusUpdate)}leaveStage(e){const n={userIds:[e]};return o(this,Xt).sendMessagePromise(W.leaveStage,Rv.toBinary(n),void 0,W.peerStageStatusUpdate)}kick(e){const n={userIds:e};return o(this,Xt).sendMessagePromise(W.leaveStage,Rv.toBinary(n))}on(e,n){let r;switch(e){case W.grantStageAccess:case W.denyStageAccess:{r=void 0;break}case W.getStagePeers:{r=Pv.fromBinary.bind(Pv);break}case W.getStageRequests:case W.requestStageAccess:case W.cancelStageRequest:{r=Ku.fromBinary.bind(Ku);break}case W.peerStageStatusUpdate:{r=lv.fromBinary.bind(lv);break}}o(this,Xt).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,Xt).sendMessagePromise(W.getPeerInfo,mv.toBinary({peerId:e}));return ts.fromBinary(n.payload)})}}Xt=new WeakMap;var it;class cL{constructor(e){f(this,it,void 0),v(this,it,e)}addPlugin(e,n){o(this,it).sendMessage(z.addPlugin,a1.toBinary({pluginId:e,staggered:n}))}removePlugin(e){o(this,it).sendMessage(z.removePlugin,c1.toBinary({pluginId:e,staggered:!1}))}getActivePlugins(){return u(this,null,function*(){const{payload:e}=yield o(this,it).sendMessagePromise(z.getPlugins);return e?A1.fromBinary(e):{plugins:[]}})}customPluginEventToRoom(e,n,r){const i={pluginId:e,pluginData:new TextEncoder().encode(JSON.stringify(n))};o(this,it).sendMessage(z.customPluginEventToRoom,y1.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,E1.toBinary(s),i)}enablePluginForRoom(e,n){o(this,it).sendMessage(z.enablePluginForRoom,l1.toBinary({pluginId:e}),n)}enablePluginForPeers(e,n,r){o(this,it).sendMessage(z.enablePluginForPeers,m1.toBinary({pluginId:e,peerIds:n}),r)}disablePluginForRoom(e,n){o(this,it).sendMessage(z.disablePluginForRoom,h1.toBinary({pluginId:e}),n)}disablePluginForPeers(e,n,r){o(this,it).sendMessage(z.disablePluginForPeers,f1.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,bv.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,w1.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,I1.toBinary(s),i)}storeDelete(e,n,r){o(this,it).sendMessage(z.storeDelete,P1.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,bv.toBinary(i))}on(e,n){let r;switch(e){case z.addPlugin:case z.enablePluginForPeers:case z.enablePluginForRoom:{r=$u.fromBinary.bind($u);break}case z.removePlugin:case z.disablePluginForPeers:case z.disablePluginForRoom:{r=wv.fromBinary.bind(wv);break}case z.customPluginEventToPeers:case z.customPluginEventToRoom:{r=Iv.fromBinary.bind(Iv);break}case z.storeInsertKeys:case z.storeGetKeys:case z.storeDeleteKeys:case z.storeDelete:{r=_v.fromBinary.bind(_v);break}}o(this,it).on(e,({payload:i,id:s})=>{const a=r(i);return n(a,s)})}}it=new WeakMap;var dL=Object.defineProperty,lL=(t,e,n)=>e in t?dL(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n,uL=(t,e,n)=>(lL(t,typeof e!="symbol"?e+"":e,n),n),Tp=(t,e,n)=>{if(!e.has(t))throw TypeError("Cannot "+n)},L=(t,e,n)=>(Tp(t,e,"read from private field"),n?n.call(t):e.get(t)),Ce=(t,e,n)=>{if(e.has(t))throw TypeError("Cannot add the same private member more than once");e instanceof WeakSet?e.add(t):e.set(t,n)},me=(t,e,n,r)=>(Tp(t,e,"write to private field"),r?r.call(t,n):e.set(t,n),n),Me=(t,e,n)=>(Tp(t,e,"access private method"),n),hl={},hL={get exports(){return hl},set exports(t){hl=t}},Ws=typeof Reflect=="object"?Reflect:null,sS=Ws&&typeof Ws.apply=="function"?Ws.apply:function(t,e,n){return Function.prototype.apply.call(t,e,n)},pl;Ws&&typeof Ws.ownKeys=="function"?pl=Ws.ownKeys:Object.getOwnPropertySymbols?pl=function(t){return Object.getOwnPropertyNames(t).concat(Object.getOwnPropertySymbols(t))}:pl=function(t){return Object.getOwnPropertyNames(t)};function pL(t){console&&console.warn&&console.warn(t)}var aS=Number.isNaN||function(t){return t!==t};function fe(){fe.init.call(this)}hL.exports=fe,hl.once=vL,fe.EventEmitter=fe,fe.prototype._events=void 0,fe.prototype._eventsCount=0,fe.prototype._maxListeners=void 0;var oS=10;function ml(t){if(typeof t!="function")throw new TypeError('The "listener" argument must be of type Function. Received type '+typeof t)}Object.defineProperty(fe,"defaultMaxListeners",{enumerable:!0,get:function(){return oS},set:function(t){if(typeof t!="number"||t<0||aS(t))throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received '+t+".");oS=t}}),fe.init=function(){(this._events===void 0||this._events===Object.getPrototypeOf(this)._events)&&(this._events=Object.create(null),this._eventsCount=0),this._maxListeners=this._maxListeners||void 0},fe.prototype.setMaxListeners=function(t){if(typeof t!="number"||t<0||aS(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 cS(t){return t._maxListeners===void 0?fe.defaultMaxListeners:t._maxListeners}fe.prototype.getMaxListeners=function(){return cS(this)},fe.prototype.emit=function(t){for(var e=[],n=1;n<arguments.length;n++)e.push(arguments[n]);var r=t==="error",i=this._events;if(i!==void 0)r=r&&i.error===void 0;else if(!r)return!1;if(r){var s;if(e.length>0&&(s=e[0]),s instanceof Error)throw s;var a=new Error("Unhandled error."+(s?" ("+s.message+")":""));throw a.context=s,a}var c=i[t];if(c===void 0)return!1;if(typeof c=="function")sS(c,this,e);else for(var d=c.length,l=pS(c,d),n=0;n<d;++n)sS(l[n],this,e);return!0};function dS(t,e,n,r){var i,s,a;if(ml(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=cS(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,pL(c)}return t}fe.prototype.addListener=function(t,e){return dS(this,t,e,!1)},fe.prototype.on=fe.prototype.addListener,fe.prototype.prependListener=function(t,e){return dS(this,t,e,!0)};function mL(){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 lS(t,e,n){var r={fired:!1,wrapFn:void 0,target:t,type:e,listener:n},i=mL.bind(r);return i.listener=n,r.wrapFn=i,i}fe.prototype.once=function(t,e){return ml(e),this.on(t,lS(this,t,e)),this},fe.prototype.prependOnceListener=function(t,e){return ml(e),this.prependListener(t,lS(this,t,e)),this},fe.prototype.removeListener=function(t,e){var n,r,i,s,a;if(ml(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():gL(n,i),n.length===1&&(r[t]=n[0]),r.removeListener!==void 0&&this.emit("removeListener",t,a||e)}return this},fe.prototype.off=fe.prototype.removeListener,fe.prototype.removeAllListeners=function(t){var e,n,r;if(n=this._events,n===void 0)return this;if(n.removeListener===void 0)return arguments.length===0?(this._events=Object.create(null),this._eventsCount=0):n[t]!==void 0&&(--this._eventsCount===0?this._events=Object.create(null):delete n[t]),this;if(arguments.length===0){var i=Object.keys(n),s;for(r=0;r<i.length;++r)s=i[r],s!=="removeListener"&&this.removeAllListeners(s);return this.removeAllListeners("removeListener"),this._events=Object.create(null),this._eventsCount=0,this}if(e=n[t],typeof e=="function")this.removeListener(t,e);else if(e!==void 0)for(r=e.length-1;r>=0;r--)this.removeListener(t,e[r]);return this};function uS(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?fL(i):pS(i,i.length)}fe.prototype.listeners=function(t){return uS(this,t,!0)},fe.prototype.rawListeners=function(t){return uS(this,t,!1)},fe.listenerCount=function(t,e){return typeof t.listenerCount=="function"?t.listenerCount(e):hS.call(t,e)},fe.prototype.listenerCount=hS;function hS(t){var e=this._events;if(e!==void 0){var n=e[t];if(typeof n=="function")return 1;if(n!==void 0)return n.length}return 0}fe.prototype.eventNames=function(){return this._eventsCount>0?pl(this._events):[]};function pS(t,e){for(var n=new Array(e),r=0;r<e;++r)n[r]=t[r];return n}function gL(t,e){for(;e+1<t.length;e++)t[e]=t[e+1];t.pop()}function fL(t){for(var e=new Array(t.length),n=0;n<e.length;++n)e[n]=t[n].listener||t[n];return e}function vL(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))}mS(t,e,s,{once:!0}),e!=="error"&&yL(t,i,{once:!0})})}function yL(t,e,n){typeof t.on=="function"&&mS(t,"error",e,n)}function mS(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 SL extends E{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 gS=new SL;class fS{static encode(e){return gS.toBinary(e)}static decode(e){return gS.fromBinary(new Uint8Array(e))}}function EL(t,e){return Math.floor(Math.random()*(e-t+1)+t)}var Fr;class TL{constructor(e={}){uL(this,"opts"),Ce(this,Fr,void 0),this.opts={initialTimeout:e.initialTimeout||1e3,maxTimeout:e.maxTimeout||1e4,factor:e.factor||2},me(this,Fr,0)}wait(){return u(this,null,function*(){me(this,Fr,L(this,Fr)+1);const e=EL(0,Math.min(this.opts.maxTimeout,this.opts.initialTimeout*ME(2,L(this,Fr))));yield new Promise(n=>{setTimeout(n,e)})})}getAttempts(){return L(this,Fr)}reset(){me(this,Fr,0)}}Fr=new WeakMap;const Br={debug:0,info:1,warn:2,error:3};var Wi,ji;class kL{constructor(e){Ce(this,Wi,void 0),Ce(this,ji,void 0),me(this,Wi,console),me(this,ji,e)}debug(...e){Br[L(this,ji)]>Br.debug||L(this,Wi).debug("[Sockrates]:",...e)}info(...e){Br[L(this,ji)]>Br.info||L(this,Wi).info("[Sockrates]:",...e)}warn(...e){Br[L(this,ji)]>Br.warn||L(this,Wi).warn("[Sockrates]:",...e)}error(...e){Br[L(this,ji)]>Br.error||L(this,Wi).error("[Sockrates]:",...e)}}Wi=new WeakMap,ji=new WeakMap;var vS=(t=>(t[t.CONNECTING=0]="CONNECTING",t[t.OPEN=1]="OPEN",t[t.CLOSING=2]="CLOSING",t[t.CLOSED=3]="CLOSED",t))(vS||{});const bL="2",wL="3";var xe,js,Ae,He,Wr,st,cr,jr,_n,Hs,dr,kp,yS,No,gl,bp,SS,wp,ES,fl,_p,Ip,TS,Lo,vl,xo,yl,Sl,Cp,qs,Vo,Uo,El;class _L{constructor(e,n){var r;Ce(this,kp),Ce(this,No),Ce(this,bp),Ce(this,wp),Ce(this,fl),Ce(this,Ip),Ce(this,Lo),Ce(this,xo),Ce(this,Sl),Ce(this,qs),Ce(this,Uo),Ce(this,xe,void 0),Ce(this,js,void 0),Ce(this,Ae,void 0),Ce(this,He,void 0),Ce(this,Wr,void 0),Ce(this,st,void 0),Ce(this,cr,void 0),Ce(this,jr,void 0),Ce(this,_n,void 0),Ce(this,Hs,void 0),Ce(this,dr,void 0);var i,s,a,c,d,l,h,m,y;me(this,js,e),me(this,Wr,[]),me(this,st,new hl),me(this,cr,!0),me(this,_n,!1),me(this,Ae,n!=null?n:{}),(i=L(this,Ae)).autoReconnect!=null||(i.autoReconnect=!0),(s=L(this,Ae)).retryConnectionInterval!=null||(s.retryConnectionInterval=1e3),(a=L(this,Ae)).pingTimeout!=null||(a.pingTimeout=3e4),(c=L(this,Ae)).connectionTimeout!=null||(c.connectionTimeout=5e3),(d=L(this,Ae)).debug!=null||(d.debug=!0),(l=L(this,Ae)).maxReconnectionAttempts!=null||(l.maxReconnectionAttempts=10),(h=L(this,Ae)).disconnectOnPingTimeout!=null||(h.disconnectOnPingTimeout=!0),(m=L(this,Ae)).queueOnDisconnect!=null||(m.queueOnDisconnect=!1),(y=L(this,Ae)).flushOnReconnect!=null||(y.flushOnReconnect=!1),me(this,jr,{code:void 0,reason:void 0}),me(this,He,(r=L(this,Ae).logger)!=null?r:new kL(L(this,Ae).debug?"debug":"info")),me(this,dr,new TL)}get readyState(){var e;return(e=L(this,xe))==null?void 0:e.readyState}get url(){return L(this,js)}updateURL(e){me(this,js,e),Me(this,Ip,TS).call(this)}get config(){return L(this,Ae)}get sendQueue(){return L(this,Wr)}flush(){if(!L(this,Ae).queueOnDisconnect)return!1;const e=[];return L(this,Wr).forEach(n=>{this.send(n.event,n.id,n.payload,n.metadata)||e.push(n)}),me(this,Wr,e),L(this,Wr)}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,cr)!==!1)return new Promise((n,r)=>{Me(this,qs,Vo).call(this),Me(this,Uo,El).call(this);try{me(this,xe,new WebSocket(Me(this,kp,yS).call(this,L(this,js)))),L(this,xe).binaryType="arraybuffer",L(this,He).debug("Connecting");const i=setTimeout(()=>{L(this,He).debug("Connection timeout. Closing socket"),me(this,cr,!0),Me(this,Uo,El).call(this),L(this,xe).close(3001,"Connection Timeout"),L(this,Ae).autoReconnect&&!L(this,_n)&&(L(this,st).emit("reconnecting"),Me(this,Lo,vl).call(this)),r(new Error("Connection timed out!"))},L(this,Ae).connectionTimeout);L(this,xe).onopen=()=>{L(this,He).debug(`Ready State: ${vS[L(this,xe).readyState]}`),i&&clearTimeout(i),Me(this,Sl,Cp).call(this),me(this,jr,{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,_n)||Me(this,fl,_p).call(this,a,c)}catch(a){Me(this,No,gl).call(this,a)}},L(this,xe).onerror=s=>{Me(this,No,gl).call(this,s)},L(this,xe).onmessage=s=>Me(this,bp,SS).call(this,s)}catch(i){Me(this,No,gl).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,Wr).push(s),!1;const a=fS.encode(s);return Me(this,xo,yl).call(this,a)}emit(e,n,r,i){return this.send(e,n,r,i)}sendRaw(e){return Me(this,xo,yl).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,cr,!1),Me(this,qs,Vo).call(this),this.removeAllListeners(),me(this,jr,{code:1e3,reason:"Sockrates disconnect method called"}),L(this,xe).close(1e3,"Sockrates disconnect method called.")}}xe=new WeakMap,js=new WeakMap,Ae=new WeakMap,He=new WeakMap,Wr=new WeakMap,st=new WeakMap,cr=new WeakMap,jr=new WeakMap,_n=new WeakMap,Hs=new WeakMap,dr=new WeakMap,kp=new WeakSet,yS=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)://.")},No=new WeakSet,gl=function(t,e){L(this,He).error("Error:",{error:t}),L(this,st).emit("errored",{error:t}),e==null||e(t)},bp=new WeakSet,SS=function(t){if(Me(this,Sl,Cp).call(this),t.data===bL){L(this,He).debug("Received ping from server"),Me(this,xo,yl).call(this,wL);return}const e=fS.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})},wp=new WeakSet,ES=function(){return L(this,xe).readyState===1},fl=new WeakSet,_p=function(t,e){me(this,jr,{reason:e,code:t}),L(this,st).emit("disconnected",{code:t,reason:e})},Ip=new WeakSet,TS=function(){const{reason:t,code:e}=L(this,jr);e&&e!==1e3&&L(this,cr)&&L(this,Ae).autoReconnect&&!L(this,_n)&&(L(this,He).debug(`Triggering reconnection due to ${t}.`),L(this,st).emit("reconnecting"),Me(this,Lo,vl).call(this))},Lo=new WeakSet,vl=function(t=!0){return u(this,null,function*(){if(t&&L(this,_n)){L(this,He).debug("Reconnect called when already in a reconnect loop. Ignoring.");return}if(L(this,_n)||L(this,dr).reset(),L(this,Ae).maxReconnectionAttempts!==null&&L(this,dr).getAttempts()>=L(this,Ae).maxReconnectionAttempts){L(this,st).emit("failed"),me(this,_n,!1);return}me(this,_n,!0),Me(this,Uo,El).call(this),Me(this,qs,Vo).call(this);try{if(yield L(this,dr).wait(),L(this,cr)===!1)return;if(L(this,He).debug(`Reconnection attempt ${L(this,dr).getAttempts()}`),L(this,st).emit("reconnectAttempt",{attempt:L(this,dr).getAttempts()}),yield this.connect(),!Me(this,wp,ES).call(this))throw Error("Reconnect Failed");me(this,_n,!1),me(this,jr,{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,dr).getAttempts()}),Me(this,Lo,vl).call(this,!1)}})},xo=new WeakSet,yl=function(t){try{return L(this,xe).send(t),!0}catch(e){return L(this,He).error(e.message),!1}},Sl=new WeakSet,Cp=function(){this.config.disconnectOnPingTimeout&&(L(this,He).debug("Resetting ping timeout"),Me(this,qs,Vo).call(this),me(this,Hs,setTimeout(()=>{var t;L(this,He).debug("Disconnecting the socket due to ping timeout"),me(this,cr,!0);const e=3002,n="Ping timeout";(t=L(this,xe))==null||t.close(e,n),Me(this,fl,_p).call(this,e,n)},L(this,Ae).pingTimeout)))},qs=new WeakSet,Vo=function(){L(this,Hs)&&(clearTimeout(L(this,Hs)),me(this,Hs,void 0))},Uo=new WeakSet,El=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 IL=Object.defineProperty,CL=Object.getOwnPropertyDescriptor,Tl=(t,e,n,r)=>{for(var i=r>1?void 0:r?CL(e,n):e,s=t.length-1,a;s>=0;s--)(a=t[s])&&(i=(r?a(e,n,i):a(i))||i);return r&&i&&IL(e,n,i),i};const kS=65535,PL=3e3;var Hi,Ve,Ue,qe,In,Hr,kl,Pp,bl,Rp,bS;const wS=(bS=class{constructor(t,{peerId:e,meetingId:n,authToken:r,capabilities:i}){f(this,Ue),f(this,kl),f(this,bl),f(this,Hi,void 0),f(this,Ve,void 0),g(this,"roomName"),g(this,"authToken"),g(this,"capabilities"),f(this,In,void 0),f(this,Hr,void 0);var s;if(!e||!n||!r)throw new _("peerId, meetingId, or authToken can not be empty","0404");v(this,In,void 0),v(this,Hr,t),this.capabilities=i,this.roomName=n,this.authToken=r,v(this,Hi,H(this,kl,Pp).call(this,e)),v(this,Ve,new _L(o(this,Hi),{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,Hr).getValue("peerId")}updateURL(t){t!==this.peerId&&(v(this,Hi,H(this,kl,Pp).call(this,t)),p.debug("SocketService:: Connection URL updated.")),o(this,Ve).updateURL(o(this,Hi))}static getSocketEdgeDomain(t){return Zi({servicePrefix:"socket-edge",baseURI:t})}get url(){return o(this,Hi)}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,bl,Rp).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=(T,b)=>{o(this,Ve).removeListener(s,T),o(this,Ve).removeListener(kS,b),o(this,Ve).removeListener(en.errorResponse,b),o(this,Ve).removeListener(pn.errorResponse,b)},l=r!=null?r:H(this,bl,Rp).call(this),h={};S.injectContext(h);const m=({id:T,payload:b})=>{if(l===T){let O;try{const M=SP.fromBinary(b);O=new Error(M.errorMessage)}catch(M){O=new Error("failed to parse error message",{cause:M});try{const F=kR.fromBinary(b);O=new Error(F.message)}catch(F){O=new Error("failed to parse error message",{cause:F})}}c(O),d(y,m)}},y=({id:T,payload:b})=>{l===T&&(a({id:T,payload:b}),d(y,m))};o(this,Ve).on(s,y),o(this,Ve).on(kS,m),o(this,Ve).on(en.errorResponse,m),o(this,Ve).on(pn.errorResponse,m),setTimeout(()=>{d(y,m),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,In)&&(clearTimeout(o(this,In)),v(this,In,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?P.emit(R.SOCKET_SERVICE_DISCONNECTED,{joinAttempted:o(this,Ue,qe).joinAttempted}):v(this,In,setTimeout(()=>{P.emit(R.SOCKET_SERVICE_DISCONNECTED,{joinAttempted:o(this,Ue,qe).joinAttempted}),v(this,In,void 0)},PL)),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,In)&&(clearTimeout(o(this,In)),v(this,In,void 0)),P.emit(R.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}),P.emit(R.SOCKET_SERVICE_FAILED),o(this,Ue,qe).updateSocketConnectionState("failed")}))}},Hi=new WeakMap,Ve=new WeakMap,Ue=new WeakSet,qe=function(){return o(this,Hr).getValue("connectionHandler")},In=new WeakMap,Hr=new WeakMap,kl=new WeakSet,Pp=function(t){let e=wS.getSocketEdgeDomain(o(this,Hr).getValue("baseURI"));typeof $c(o(this,Hr),"socket_server_base")=="string"&&(e=$c(o(this,Hr),"socket_server_base"));const n=`wss://${e}`,r=new URL(`${n}/ws`),i=this.peerId,s=G(x({roomID:this.roomName,peerID:t,authToken:this.authToken,useMediaV2:!0},i!==t&&{oldPeerID:i}),{ping:this.capabilities.includes("PING"),capabilities:this.capabilities.map(a=>Xc[a]).join(" "),joinWithDetails:!0,useCfWorker:!0});return Object.entries(s).forEach(([a,c])=>{r.searchParams.append(a,c.toString())}),r.href},bl=new WeakSet,Rp=function(){return`${this.peerId}-${(Math.random()+1).toString(36).substring(7)}`},bS);let Fo=wS;Tl([S.trace("SocketService.connect")],Fo.prototype,"connect",1),Tl([S.trace("SocketService.disconnect")],Fo.prototype,"disconnect",1),Tl([S.trace("SocketService.sendMessagePromise")],Fo.prototype,"sendMessagePromise",1),Tl([S.trace("SocketService.sendMessagePromiseWithTimeout")],Fo.prototype,"sendMessagePromiseWithTimeout",1);const qi=class{static handleConnectedRoomsDumpRaw({payload:t}){var e;const n=zR.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=TM.fromBinary(t);return{authToken:e.authToken,meetingId:e.meetingId}}static handleMovedPeerRaw({payload:t}){const e=vv.fromBinary(t);return{meetingId:e.meetingId,customParticipantId:e.customParticipantId}}static handleConnectedRoomsUpdatedRaw({payload:t}){return fv.fromBinary(t).payloads.map(e=>({id:e.id,title:e.title}))}static handleConnectedRoomsDeletedRaw({payload:t}){return uM.fromBinary(t).payloads}static getConnectedRoomsDump(){return u(this,null,function*(){const t=yield qi.socketService.sendMessagePromise(W.getConnectedRoomsDump);return qi.handleConnectedRoomsDumpRaw(t)})}static createConnectedRooms(t){return u(this,null,function*(){const{payload:e}=yield qi.socketService.sendMessagePromise(W.createConnectedRooms,ZR.toBinary({payloads:t}));return fv.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 qi.socketService.sendMessagePromise(W.deleteConnectedRooms,dM.toBinary({payloads:e}));return qi.handleConnectedRoomsDeletedRaw(n)})}static movePeersBetweenRooms(t){return u(this,null,function*(){try{const e=yield qi.socketService.sendMessagePromise(W.movePeers,vM.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=qi;g(Ne,"socketService"),g(Ne,"currentMeetingId");var RL=Object.defineProperty,ML=Object.getOwnPropertyDescriptor,wl=(t,e,n,r)=>{for(var i=r>1?void 0:r?ML(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&&RL(e,n,i),i};const Gs=class{constructor(t,e){g(this,"apiBase"),g(this,"selfController"),g(this,"pollController"),g(this,"chatController"),g(this,"metaController"),g(this,"storesManager"),g(this,"stageController"),g(this,"pluginController"),g(this,"internalsController"),g(this,"recordingController"),g(this,"livestreamController"),g(this,"participantController"),this.apiBase=t,this.storesManager=e.storesManager,this.metaController=e.metaController,this.selfController=e.selfController,this.chatController=e.chatController,this.pollController=e.pollController,this.stageController=e.stageController,this.pluginController=e.pluginController,this.recordingController=e.recordingController,this.internalsController=e.internalsController,this.participantController=e.participantController,this.livestreamController=e.livestreamController}static init(t){return u(this,null,function*(){var e,n;const{peerId:r,apiBase:i,authToken:s,meetingId:a,organizationId:c,cachedUserDetails:d}=t.getAllValues();if(P.reset(),Ld.cleanup(),nS(t),Ie.isSupported()===!1)throw new _("Browser not supported","0010",!0);const l=ND(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 fO;t.setValue("connectionHandler",h);const m=Gs.createSocketService(t),y=m.connect(),T=l.getUserDetails(),b=l.getPlugins();let O=tt.HIVE,M,F="";try{yield Gs.setupFlagsmith(t)}catch(Z){p.error("Failed to setup flagsmith",{error:Z})}try{yield y}catch(Z){p.error("[Controller]: Failed to connect to socket server:",{error:Z})}try{({sfu:O,meetingTitle:F}=yield l.getRoomNodeData()),M=yield T,p.info(`SFU ${O} is being used.`),t.setValue("presetName",M.preset.name),t.setValue("roomNodeOptions",{sfu:O})}catch(Z){p.error("Failed to get room metadata",{error:Z})}const V=eN.init(M.preset,!t.getValue("modules").theme),K=Gs.setupControllers(m,t,M,b,F,V);sO(V)&&((e=Gs.createRoomNodeClient(t,m).partialJoinRoom(M.participant.name,a,void 0))==null||e.catch(Z=>{p.error("[Controller]: Failed to queue partial media room promise:",{error:Z})})),S.location.country=(n=l.ipInfo)==null?void 0:n.country;const{controllers:I}=yield K;return rC(),new Gs(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=tC(s),d=G(x({entity:Au.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?Zi({servicePrefix:"flags",baseURI:r}):"edge.api.flagsmith.com";yield X.identify(`${Au.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:m}=n,y=e.getValue("defaults"),{sfu:T}=e.getValue("roomNodeOptions"),{viewType:b,mediaConstraints:{audio:O}}=s;e.setValue("viewType",b),e.setValue("defaults",x({mediaConfiguration:{audio:{enableHighBitrate:(a=O.enableHighBitrate)!=null?a:!1,enableStereo:(c=O.enableStereo)!=null?c:!1}}},y));const M=TN.init(e,b,h.permissions);e.setValue("maxPreferredStreams",Ie.isMobile()?s.maxVideoStreams.mobile:s.maxVideoStreams.desktop);let F,V,K,I,Z,ae,we,ce;const De=new iL(t);Ne.socketService=t;const At=new ul(t),A=new tn(t),k=new oL(t),w=Ld.create(t,e),j=new cL(t),Pe=new rL(t),Qe=new ci(t),B=yield Vr.init(e,w,m,M,s),C=yield Yv.init(e,B.self,w,De,i);if(l.participant&&(ce=new rr(e,B.self,w,T)),(d=l.e2ee)!=null&&d.enabled&&l.e2ee.manager.init(p,P),l.chat&&(V=yield Zn.init(e,A,Qe,B.self,ce.participants)),l.internals&&(Z=yield mh.init()),l.livestream&&s.viewType===yt.Livestream&&X.hasFeature(ie.LIVESTREAM)&&(we=new my(B.self,Pe)),s.viewType!==yt.Chat){if(l.poll&&(F=yield qv.init(e,B.self,At)),l.recording&&(ae=new iy(e,B.self,w)),l.stage&&(K=new Qv(e,k,w,B.self,ce.participants)),l.plugin){if(!ce)throw new _("The plugin module cannot be initialized without the `participant` module","0102");const lr=yield r;I=yield _a.init(e,lr,j,A,V==null?void 0:V.chat,B.self,ce.participants,i)}if(l.pip){const lr=yield aC._init(e,B.self);e.setValue("pip",lr)}}const Xe={storesManager:new cN(e,j),pollController:F,selfController:B,metaController:C,chatController:V,stageController:K,pluginController:I,recordingController:ae,internalsController:Z,livestreamController:we,participantController:ce};return{theme:s,permissions:M,controllers:Xe}})}static createRoomNodeClient(t,e){const{peerId:n,roomNodeOptions:r}=t.getAllValues(),{sfu:i}=r;return tS(t,i,{socket:e,peerId:n})}static createSocketService(t){const{peerId:e,meetingId:n,authToken:r}=t.getAllValues(),i=["PING"];return new Fo(t,{peerId:e,meetingId:n,authToken:r,capabilities:i})}};let Bo=Gs;wl([S.trace("Controller.init")],Bo,"init",1),wl([S.trace("setupFlagsmith")],Bo,"setupFlagsmith",1),wl([S.trace("Controller.createRoomNodeClient")],Bo,"createRoomNodeClient",1),wl([S.trace("Controller.createSocketService")],Bo,"createSocketService",1);var AL=Object.defineProperty,DL=Object.getOwnPropertyDescriptor,OL=(t,e,n,r)=>{for(var i=r>1?void 0:r?DL(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&&AL(e,n,i),i},_l,Mp;class _S extends jt{constructor(e,n){super(),f(this,_l,void 0),g(this,"meetings",[]),g(this,"parentMeeting",null),f(this,Mp,void 0),v(this,Mp,e),v(this,_l,n.self)}get supportsConnectedMeetings(){return o(this,_l).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.
20
20
  Please connect with Dyte team to move you to V2 APIs & to enable connected meetings.`)}getConnectedMeetings(){return u(this,null,function*(){return this.validateConnectedMeetingsAction(),yield Ne.getConnectedRoomsDump()})}createMeetings(e){return u(this,null,function*(){return this.validateConnectedMeetingsAction(),(yield Ne.createConnectedRooms(e)).map(n=>({id:n.id,title:n.title}))})}updateMeetings(e){return u(this,null,function*(){this.validateConnectedMeetingsAction(),yield Ne.updateConnectedRooms(e.map(n=>({meetingId:n.id,title:n.title})))})}deleteMeetings(e){return u(this,null,function*(){this.validateConnectedMeetingsAction();const n=this.meetings.map(r=>e.includes(r.id)&&r.participants.length!==0?this.moveParticipants(r.id,this.parentMeeting.id,r.participants.map(i=>i.id)):Promise.resolve());return yield Promise.all(n),yield Ne.disableConnectedRooms(e)})}moveParticipants(e,n,r){return u(this,null,function*(){this.validateConnectedMeetingsAction();const i=yield Ne.movePeersBetweenRooms({sourceMeetingId:e,destinationMeetingId:n,participants:r.map(s=>({id:s}))});return i.success&&this.moveSuccessHandler(e,n,r),i})}moveParticipantsWithCustomPreset(e,n,r){return u(this,null,function*(){this.validateConnectedMeetingsAction();const i=yield Ne.movePeersBetweenRooms({sourceMeetingId:e,destinationMeetingId:n,participants:r});return i.success&&this.moveSuccessHandler(e,n,r.map(s=>s.id)),i})}moveSuccessHandler(e,n,r){const i=new Map;[...this.parentMeeting.participants,...this.meetings.flatMap(s=>s.participants)].forEach(s=>i.set(s.id,s)),n===this.parentMeeting.id&&(this.parentMeeting.participants=this.parentMeeting.participants.concat(r.map(s=>i.get(s)))),e===this.parentMeeting.id&&(this.parentMeeting.participants=this.parentMeeting.participants.filter(s=>!r.includes(s.id))),this.meetings=this.meetings.map(s=>{if(n===s.id){const a=s.participants.concat(r.map(c=>i.get(c)));return G(x({},s),{participants:a})}if(e===s.id){const a=s.participants.filter(c=>!r.includes(c.id));return G(x({},s),{participants:a})}return s})}}_l=new WeakMap,Mp=new WeakMap,OL([Nt({maxInvocations:60,period:60})],_S.prototype,"getConnectedMeetings",1);var NL=Object.defineProperty,LL=Object.getOwnPropertyDescriptor,Ap=(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&&NL(e,n,i),i},Wo,Cn,Dp,Op;const qr=(Dp=class{constructor(t,e,n){g(this,"connectedMeetings"),f(this,Wo,void 0),f(this,Cn,void 0),f(this,Op,void 0),v(this,Op,t),v(this,Wo,n),this.connectedMeetings=new _S(t,e),this.setCurrentMeeting(e)}static init(t,e,n){return qr.instance||(qr.instance=new qr(t,e,n)),qr.instance.connectedMeetings.supportsConnectedMeetings&&(qr.instance.setupEvents(),e.self.once("roomJoined",()=>qr.instance.getConnectedMeetings())),qr.instance}setCurrentMeeting(t){v(this,Cn,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.
21
21
  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,Cn).self.videoEnabled,audio:o(this,Cn).self.audioEnabled};try{o(this,Cn).self.cleanupEvents(),yield o(this,Cn).leave("connected-meeting")}catch(l){p.error(`ConnectedMeetingsController:: switchMeeting:: issues in leaving previous meeting. Meeting Id: ${(i=(r=o(this,Cn))==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 RS.init(G(x({},o(this,Wo)),{cachedUserDetails:null,defaults:G(x(x({},o(this,Wo).defaults),c),{mediaHandler:o(this,Cn).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,Cn).self;d.self.setName(o(this,Cn).self.name),yield d.join(),l&&d.self.hide()}catch(l){p.error("ConnectedMeetingsController.joinRoom",{error:l})}return p.info(`ConnectedMeetingsController::switchMeeting:: asking ui-kit to show in-meeting ui of newly joined meeting id: ${(a=d==null?void 0:d.meta)==null?void 0:a.meetingId}`),this.connectedMeetings.emit("meetingChanged",d),this.setCurrentMeeting(d),d})}handleConnectedRoomsDump(t){const e=Ne.handleConnectedRoomsDumpRaw(t);this.connectedMeetings.meetings=e.meetings.map(n=>({id:n.id,title:n.title,participants:n.participants||[]})),this.connectedMeetings.parentMeeting={id:e.parentMeeting.id,title:e.parentMeeting.title,participants:e.parentMeeting.participants},this.emitStateUpdate()}handleMovedPeer(t){return Ne.handleMovedPeerRaw(t)}handleConnectedRoomsUpdated(t){const e=Ne.handleConnectedRoomsUpdatedRaw(t),n=new Map;this.connectedMeetings.meetings.forEach(r=>{n.set(r.id,r)}),e.forEach(r=>{n.has(r.id)?n.get(r.id).title=r.title:n.set(r.id,G(x({},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})}},Wo=new WeakMap,Cn=new WeakMap,Op=new WeakMap,g(Dp,"instance"),Dp);let Il=qr;Ap([S.trace("ConnectedMeetingsController.getConnectedMeetings")],Il.prototype,"getConnectedMeetings",1),Ap([S.trace("ConnectedMeetingsController.setupEvents")],Il.prototype,"setupEvents",1),Ap([S.trace("ConnectedMeetingsController.switchMeeting")],Il.prototype,"switchMeeting",1);class xL{constructor(){g(this,"battery"),g(this,"init",()=>u(this,null,function*(){try{"getBattery"in navigator&&(this.battery=yield navigator.getBattery(),this.battery.addEventListener("chargingchange",this.updateChargeInfo),this.battery.addEventListener("levelchange",this.updateLevelInfo),this.updateLevelInfo(),this.updateChargeInfo())}catch(e){p.error("Error getting battery",e)}})),g(this,"updateChargeInfo",()=>{var e;p.log(`Battery charging? ${(e=this.battery)!=null&&e.charging?"Yes":"No"}`)}),g(this,"updateLevelInfo",()=>{if(!this.battery){p.log("Battery level: Not known");return}p.log(`Battery level: ${this.battery.level*100}%`)}),g(this,"cleanup",()=>{var e,n;"getBattery"in navigator&&((e=this.battery)==null||e.removeEventListener("chargingchange",this.updateChargeInfo),(n=this.battery)==null||n.removeEventListener("levelchange",this.updateLevelInfo))})}}const IS=new xL;function VL(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 UL=Object.defineProperty,FL=Object.getOwnPropertyDescriptor,Cl=(t,e,n,r)=>{for(var i=r>1?void 0:r?FL(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&&UL(e,n,i),i},dt,Pl,Rl,Np,CS,PS;let Gr=(PS=class{constructor(t,e){f(this,Np),f(this,dt,void 0),f(this,Pl,void 0),f(this,Rl,void 0),v(this,Rl,t),v(this,dt,e)}static init(t){return u(this,null,function*(){var e,n,r,i,s,a,c;XI(),Ie.init();const d=(n=(e=t==null?void 0:t.cachedUserDetails)==null?void 0:e.peerId)!=null?n:Gi();IS.init();const{authToken:l,baseURI:h}=t,m=VL(l,h),{meetingId:y}=m,T=fc(m,["meetingId"]);window.__zone_symbol__DISABLE_WRAPPING_UNCAUGHT_PROMISE_REJECTION=!0;const b=Gr.setupContext(d,t,y,T);S.meetingMetadata.roomName=y,S.meetingMetadata.userId=T.participantId,S.meetingMetadata.organizationId=T.orgId,S.init(b,(i=(r=t.modules)==null?void 0:r.tracing)!=null?i:!0),p.info("DyteClient::init::options",{dyteClientInitOptions:G(x({},t),{authToken:`${(s=t.authToken)==null?void 0:s.slice(0,10)}...
22
- ${(a=t.authToken)==null?void 0:a.slice(-10)}`})});const O=yield Bo.init(b),M=new Gr(b,O);return H(c=M,Np,CS).call(c,t),M})}static setupContext(t,e,n,r){var i;const s=ri.createContext(t,e),a=x(x({},JI),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",$I({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.86"),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*(){IS.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,Pl))==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,Pl=new WeakMap,Rl=new WeakMap,Np=new WeakSet,CS=function(t){v(this,Pl,Il.init(o(this,Rl),this,t))},PS);Cl([ht("0002"),Mr.executeWithLock({methodName:"meeting.join",lockName:"DyteClient.join",timeout:3e3})],Gr.prototype,"join",1),Cl([ht("0003")],Gr.prototype,"leave",1),Cl([ht("0001"),Mr.executeWithLock({methodName:"DyteClient.init",lockName:"DyteClient.init",timeout:3e3})],Gr,"init",1),Gr=Cl([ht("0000")],Gr);const RS=Gr;return RS}();
22
+ ${(a=t.authToken)==null?void 0:a.slice(-10)}`})});const O=yield Bo.init(b),M=new Gr(b,O);return H(c=M,Np,CS).call(c,t),M})}static setupContext(t,e,n,r){var i;const s=ri.createContext(t,e),a=x(x({},JI),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",$I({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.88"),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*(){IS.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,Pl))==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,Pl=new WeakMap,Rl=new WeakMap,Np=new WeakSet,CS=function(t){v(this,Pl,Il.init(o(this,Rl),this,t))},PS);Cl([ht("0002"),Mr.executeWithLock({methodName:"meeting.join",lockName:"DyteClient.join",timeout:3e3})],Gr.prototype,"join",1),Cl([ht("0003")],Gr.prototype,"leave",1),Cl([ht("0001"),Mr.executeWithLock({methodName:"DyteClient.init",lockName:"DyteClient.init",timeout:3e3})],Gr,"init",1),Gr=Cl([ht("0000")],Gr);const RS=Gr;return RS}();