@cloudflare/realtimekit 1.2.5-staging.1 → 1.2.5-staging.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/AGENTS.md +63 -0
- package/dist/ClientMock.cjs.js +2 -2
- package/dist/ClientMock.es.js +1439 -1707
- package/dist/EncryptionManager.cjs.js +1 -1
- package/dist/EncryptionManager.d.ts +13 -947
- package/dist/EncryptionManager.es.js +156 -156
- package/dist/browser.js +10 -10
- package/dist/dependencies.txt +8 -229
- package/dist/index.cjs.js +10 -13
- package/dist/index.d.ts +15 -948
- package/dist/index.es.js +6979 -11036
- package/dist/index.es5.js +9868 -13315
- package/dist/index.rn.js +10 -13
- package/dist/ts3.4/dist/EncryptionManager.d.ts +13 -940
- package/dist/ts3.4/dist/index.d.ts +15 -941
- package/package.json +5 -5
package/dist/index.cjs.js
CHANGED
|
@@ -1,13 +1,10 @@
|
|
|
1
|
-
"use strict";var WT=Object.defineProperty,JT=Object.defineProperties;var KT=Object.getOwnPropertyDescriptors;var Fc=Object.getOwnPropertySymbols,zT=Object.getPrototypeOf,qh=Object.prototype.hasOwnProperty,jh=Object.prototype.propertyIsEnumerable,YT=Reflect.get;var Gh=Math.pow,Jl=(s,t,e)=>t in s?WT(s,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):s[t]=e,D=(s,t)=>{for(var e in t||(t={}))qh.call(t,e)&&Jl(s,e,t[e]);if(Fc)for(var e of Fc(t))jh.call(t,e)&&Jl(s,e,t[e]);return s},G=(s,t)=>JT(s,KT(t));var Bc=(s,t)=>{var e={};for(var r in s)qh.call(s,r)&&t.indexOf(r)<0&&(e[r]=s[r]);if(s!=null&&Fc)for(var r of Fc(s))t.indexOf(r)<0&&jh.call(s,r)&&(e[r]=s[r]);return e};var h=(s,t,e)=>(Jl(s,typeof t!="symbol"?t+"":t,e),e),Kl=(s,t,e)=>{if(!t.has(s))throw TypeError("Cannot "+e)};var n=(s,t,e)=>(Kl(s,t,"read from private field"),e?e.call(s):t.get(s)),m=(s,t,e)=>{if(t.has(s))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(s):t.set(s,e)},f=(s,t,e,r)=>(Kl(s,t,"write to private field"),r?r.call(s,e):t.set(s,e),e);var x=(s,t,e)=>(Kl(s,t,"access private method"),e),Wh=(s,t,e)=>YT(zT(s),e,t);var u=(s,t,e)=>new Promise((r,i)=>{var a=d=>{try{c(e.next(d))}catch(l){i(l)}},o=d=>{try{c(e.throw(d))}catch(l){i(l)}},c=d=>d.done?r(d.value):Promise.resolve(d.value).then(a,o);c((e=e.apply(s,t)).next())});const gr=require("uuid"),$g=require("bowser"),S=require("@protobuf-ts/runtime"),QT=require("worker-timers"),XT=require("sdp-transform");function Fg(s){const t=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(s){for(const e in s)if(e!=="default"){const r=Object.getOwnPropertyDescriptor(s,e);Object.defineProperty(t,e,r.get?r:{enumerable:!0,get:()=>s[e]})}}return t.default=s,Object.freeze(t)}const Xc=Fg(QT),ls=Fg(XT);function ZT(s){const{length:t}=this,e=s>=0?s:t+s;return e<0||e>=t?void 0:this[e]}Array.prototype.at||Object.assign(Array.prototype,{at:ZT});function ev(s){const{length:t}=this,e=s>=0?s:t+s;return e<0||e>=t?void 0:this[e]}String.prototype.at||Object.assign(String.prototype,{at:ev});const tv=s=>{!navigator.isReactNative&&typeof window!="undefined"&&(window.addEventListener("error",t=>{var e;!((e=t.filename)!=null&&e.includes("localhost"))&&t.lineno!==0&&s.error("window::error",{error:t.error},!0)}),window.addEventListener("unhandledrejection",t=>{var e,r,i,a,o,c,d,l;s.error("window::unhandledrejection",{error:t==null?void 0:t.reason,networkCall:{url:(r=(e=t==null?void 0:t.reason)==null?void 0:e.config)==null?void 0:r.url,baseURL:(a=(i=t==null?void 0:t.reason)==null?void 0:i.config)==null?void 0:a.baseURL,method:(c=(o=t==null?void 0:t.reason)==null?void 0:o.config)==null?void 0:c.method,status:(d=t==null?void 0:t.reason)==null?void 0:d.status,statusText:(l=t==null?void 0:t.reason)==null?void 0:l.statusText}},!0)}),window.addEventListener("offline",()=>{s.info("window::offline")}),window.addEventListener("online",()=>{s.info("window::online")}))},vo="chrome",Bg="opera",Hg="firefox",qg="iexplorer",jg="safari",Gg="nwjs",Wg="electron",Jg="react-native",ih="unknown",pd={Chrome:vo,Chromium:vo,Opera:Bg,Firefox:Hg,"Internet Explorer":qg,Safari:jg};function sv(){const{userAgent:s}=navigator,t={name:ih,version:void 0};if(s.match(/Chrome/)&&!s.match(/Edge/))if(s.match(/Edg(A?)/)){const e=s.match(/Chrome\/([\d.]+)/)[1];Number.parseInt(e,10)>72&&(t.name=vo,t.version=e)}else t.name=vo,t.version=s.match(/Chrome\/([\d.]+)/)[1];return t}function rv(){const{userAgent:s}=navigator;if(s.match(/Electron/)){const t=s.match(/Electron\/([\d.]+)/)[1];return{name:Wg,version:t}}return null}function iv(){const{userAgent:s}=navigator;if(s.match(/JitsiMeetNW/)){const t=s.match(/JitsiMeetNW\/([\d.]+)/)[1];return{name:Gg,version:t}}}function nv(){const s=navigator.userAgent.match(/\b(react[ \t_-]*native)(?:\/(\S+))?/i);let t;if(s||navigator.product==="ReactNative")return s&&s.length>2&&(s[1],t=s[2]),t||(t="unknown"),{name:Jg,version:t}}function av(s){let t;const e=[nv,rv,iv];for(let i=0;i<e.length;i+=1)if(t=e[i](),t)return t;const r=s.getBrowserName();return r in pd?{name:pd[r],version:s.getBrowserVersion()}:(t=sv(),t||{name:ih,version:void 0})}class ov{constructor(){h(this,"_bowser");h(this,"_name");h(this,"_version");h(this,"getDeviceInfo",()=>({isMobile:this.isMobile(),browserName:this._bowser.getBrowserName(),osName:this._bowser.getOSName(),browserVersion:this._bowser.getBrowserVersion(),osVersionName:this._bowser.getOSVersion(),engineName:this._bowser.getEngineName()}))}init(t){let e,r;if(this._bowser=$g.getParser(navigator.userAgent),typeof t=="undefined"){const i=av(this._bowser);e=i.name,r=i.version}else t.name in pd?(e=pd[t.name],r=t.version):(e=ih,r=void 0);this._name=e,this._version=r}getName(){return this._name}isChrome(){return this._name===vo}isOpera(){return this._name===Bg}isFirefox(){return this._name===Hg}isIExplorer(){return this._name===qg}isSafari(){return this._name===jg}isNWJS(){return this._name===Gg}isElectron(){return this._name===Wg}isReactNative(){return this._name===Jg||navigator.isReactNative===!0}getVersion(){return this._version}isMobile(){return this._bowser.getPlatformType()==="mobile"}_checkCondition(t){if(this._version)return this._bowser.satisfies(t)}isVersionGreaterThan(t){return this._checkCondition({[this._name]:`>${t}`})}isVersionLessThan(t){return this._checkCondition({[this._name]:`<${t}`})}isVersionEqualTo(t){return this._checkCondition({[this._name]:`~${t}`})}}class cv extends ov{doesVideoMuteByStreamRemove(){return this.isChromiumBased()||this.isWebKitBased()}supportsP2P(){return!this.usesUnifiedPlan()}isChromiumBased(){return this.isChrome()||this.isElectron()||this.isNWJS()||this.isOpera()}isWebKitBased(){return this._bowser.isEngine("webkit")&&typeof navigator.mediaDevices!="undefined"&&typeof navigator.mediaDevices.getUserMedia!="undefined"&&typeof window.RTCRtpTransceiver!="undefined"&&Object.keys(RTCRtpTransceiver.prototype).indexOf("currentDirection")>-1}isSupported(){return typeof RTCPeerConnection!="undefined"}isUserInteractionRequiredForUnmute(){return this.isFirefox()&&this.isVersionLessThan("68")}supportsVideoMuteOnConnInterrupted(){return this.isChromiumBased()||this.isReactNative()||this.isWebKitBased()}supportsBandwidthStatistics(){return!this.isFirefox()&&!this.isWebKitBased()}supportsCodecPreferences(){return this.usesUnifiedPlan()&&typeof window.RTCRtpTransceiver!="undefined"&&Object.keys(window.RTCRtpTransceiver.prototype).indexOf("setCodecPreferences")>-1&&Object.keys(RTCRtpSender.prototype).indexOf("getCapabilities")>-1&&!this.isWebKitBased()}supportsDeviceChangeEvent(){return navigator.mediaDevices&&typeof navigator.mediaDevices.ondevicechange!="undefined"&&typeof navigator.mediaDevices.addEventListener!="undefined"}supportsLocalCandidateRttStatistics(){return this.isChromiumBased()||this.isReactNative()||this.isWebKitBased()}supportsPerformanceObserver(){return typeof window.PerformanceObserver!="undefined"&&PerformanceObserver.supportedEntryTypes.indexOf("longtask")>-1}supportsReceiverStats(){return typeof window.RTCRtpReceiver!="undefined"&&Object.keys(RTCRtpReceiver.prototype).indexOf("getSynchronizationSources")>-1}supportsRTTStatistics(){return!this.isFirefox()}usesPlanB(){return!this.usesUnifiedPlan()}usesSdpMungingForSimulcast(){return this.isChromiumBased()||this.isReactNative()||this.isWebKitBased()}usesUnifiedPlan(){return!!(this.isFirefox()||this.isWebKitBased())}usesNewGumFlow(){return!!(this.isChromiumBased()||this.isFirefox()||this.isWebKitBased())}usesAdapter(){return this.usesNewGumFlow()}usesRidsForSimulcast(){return!1}supportsGetDisplayMedia(){return typeof navigator.getDisplayMedia!="undefined"||typeof navigator.mediaDevices!="undefined"&&typeof navigator.mediaDevices.getDisplayMedia!="undefined"}supportsInsertableStreams(){if(!(typeof window.RTCRtpSender!="undefined"&&(window.RTCRtpSender.prototype.createEncodedStreams||window.RTCRtpSender.prototype.createEncodedVideoStreams)))return!1;const t=new ReadableStream;try{return window.postMessage(t,"*",[t]),!0}catch(e){return!1}}supportsAudioRed(){return Boolean(window.RTCRtpSender&&window.RTCRtpSender.getCapabilities&&window.RTCRtpSender.getCapabilities("audio").codecs.some(t=>t.mimeType==="audio/red")&&window.RTCRtpReceiver&&window.RTCRtpReceiver.getCapabilities&&window.RTCRtpReceiver.getCapabilities("audio").codecs.some(t=>t.mimeType==="audio/red"))}supportsSdpSemantics(){return this.isChromiumBased()}_getChromiumBasedVersion(){if(this.isChromiumBased()){if(this.isNWJS())return Number.parseInt(process.versions.chromium,10);const t=navigator.userAgent;if(t.match(/Chrome/))return Number.parseInt(t.match(/Chrome\/([\d.]+)/)[1],10)}return-1}isIOSMobile(){return this.isMobile&&this._bowser.getOSName()==="iOS"}}const Se=new cv;var ct={},dv={get exports(){return ct},set exports(s){ct=s}},_n=typeof Reflect=="object"?Reflect:null,Jh=_n&&typeof _n.apply=="function"?_n.apply:function(t,e,r){return Function.prototype.apply.call(t,e,r)},Zc;_n&&typeof _n.ownKeys=="function"?Zc=_n.ownKeys:Object.getOwnPropertySymbols?Zc=function(t){return Object.getOwnPropertyNames(t).concat(Object.getOwnPropertySymbols(t))}:Zc=function(t){return Object.getOwnPropertyNames(t)};function lv(s){console&&console.warn&&console.warn(s)}var Kg=Number.isNaN||function(t){return t!==t};function oe(){oe.init.call(this)}dv.exports=oe;ct.once=gv;oe.EventEmitter=oe;oe.prototype._events=void 0;oe.prototype._eventsCount=0;oe.prototype._maxListeners=void 0;var Kh=10;function Pl(s){if(typeof s!="function")throw new TypeError('The "listener" argument must be of type Function. Received type '+typeof s)}Object.defineProperty(oe,"defaultMaxListeners",{enumerable:!0,get:function(){return Kh},set:function(s){if(typeof s!="number"||s<0||Kg(s))throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received '+s+".");Kh=s}});oe.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};oe.prototype.setMaxListeners=function(t){if(typeof t!="number"||t<0||Kg(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 zg(s){return s._maxListeners===void 0?oe.defaultMaxListeners:s._maxListeners}oe.prototype.getMaxListeners=function(){return zg(this)};oe.prototype.emit=function(t){for(var e=[],r=1;r<arguments.length;r++)e.push(arguments[r]);var i=t==="error",a=this._events;if(a!==void 0)i=i&&a.error===void 0;else if(!i)return!1;if(i){var o;if(e.length>0&&(o=e[0]),o instanceof Error)throw o;var c=new Error("Unhandled error."+(o?" ("+o.message+")":""));throw c.context=o,c}var d=a[t];if(d===void 0)return!1;if(typeof d=="function")Jh(d,this,e);else for(var l=d.length,p=em(d,l),r=0;r<l;++r)Jh(p[r],this,e);return!0};function Yg(s,t,e,r){var i,a,o;if(Pl(e),a=s._events,a===void 0?(a=s._events=Object.create(null),s._eventsCount=0):(a.newListener!==void 0&&(s.emit("newListener",t,e.listener?e.listener:e),a=s._events),o=a[t]),o===void 0)o=a[t]=e,++s._eventsCount;else if(typeof o=="function"?o=a[t]=r?[e,o]:[o,e]:r?o.unshift(e):o.push(e),i=zg(s),i>0&&o.length>i&&!o.warned){o.warned=!0;var c=new Error("Possible EventEmitter memory leak detected. "+o.length+" "+String(t)+" listeners added. Use emitter.setMaxListeners() to increase limit");c.name="MaxListenersExceededWarning",c.emitter=s,c.type=t,c.count=o.length,lv(c)}return s}oe.prototype.addListener=function(t,e){return Yg(this,t,e,!1)};oe.prototype.on=oe.prototype.addListener;oe.prototype.prependListener=function(t,e){return Yg(this,t,e,!0)};function uv(){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 Qg(s,t,e){var r={fired:!1,wrapFn:void 0,target:s,type:t,listener:e},i=uv.bind(r);return i.listener=e,r.wrapFn=i,i}oe.prototype.once=function(t,e){return Pl(e),this.on(t,Qg(this,t,e)),this};oe.prototype.prependOnceListener=function(t,e){return Pl(e),this.prependListener(t,Qg(this,t,e)),this};oe.prototype.removeListener=function(t,e){var r,i,a,o,c;if(Pl(e),i=this._events,i===void 0)return this;if(r=i[t],r===void 0)return this;if(r===e||r.listener===e)--this._eventsCount===0?this._events=Object.create(null):(delete i[t],i.removeListener&&this.emit("removeListener",t,r.listener||e));else if(typeof r!="function"){for(a=-1,o=r.length-1;o>=0;o--)if(r[o]===e||r[o].listener===e){c=r[o].listener,a=o;break}if(a<0)return this;a===0?r.shift():hv(r,a),r.length===1&&(i[t]=r[0]),i.removeListener!==void 0&&this.emit("removeListener",t,c||e)}return this};oe.prototype.off=oe.prototype.removeListener;oe.prototype.removeAllListeners=function(t){var e,r,i;if(r=this._events,r===void 0)return this;if(r.removeListener===void 0)return arguments.length===0?(this._events=Object.create(null),this._eventsCount=0):r[t]!==void 0&&(--this._eventsCount===0?this._events=Object.create(null):delete r[t]),this;if(arguments.length===0){var a=Object.keys(r),o;for(i=0;i<a.length;++i)o=a[i],o!=="removeListener"&&this.removeAllListeners(o);return this.removeAllListeners("removeListener"),this._events=Object.create(null),this._eventsCount=0,this}if(e=r[t],typeof e=="function")this.removeListener(t,e);else if(e!==void 0)for(i=e.length-1;i>=0;i--)this.removeListener(t,e[i]);return this};function Xg(s,t,e){var r=s._events;if(r===void 0)return[];var i=r[t];return i===void 0?[]:typeof i=="function"?e?[i.listener||i]:[i]:e?pv(i):em(i,i.length)}oe.prototype.listeners=function(t){return Xg(this,t,!0)};oe.prototype.rawListeners=function(t){return Xg(this,t,!1)};oe.listenerCount=function(s,t){return typeof s.listenerCount=="function"?s.listenerCount(t):Zg.call(s,t)};oe.prototype.listenerCount=Zg;function Zg(s){var t=this._events;if(t!==void 0){var e=t[s];if(typeof e=="function")return 1;if(e!==void 0)return e.length}return 0}oe.prototype.eventNames=function(){return this._eventsCount>0?Zc(this._events):[]};function em(s,t){for(var e=new Array(t),r=0;r<t;++r)e[r]=s[r];return e}function hv(s,t){for(;t+1<s.length;t++)s[t]=s[t+1];s.pop()}function pv(s){for(var t=new Array(s.length),e=0;e<t.length;++e)t[e]=s[e].listener||s[e];return t}function gv(s,t){return new Promise(function(e,r){function i(o){s.removeListener(t,a),r(o)}function a(){typeof s.removeListener=="function"&&s.removeListener("error",i),e([].slice.call(arguments))}tm(s,t,a,{once:!0}),t!=="error"&&mv(s,i,{once:!0})})}function mv(s,t,e){typeof s.on=="function"&&tm(s,"error",t,e)}function tm(s,t,e,r){if(typeof s.on=="function")r.once?s.once(t,e):s.on(t,e);else if(typeof s.addEventListener=="function")s.addEventListener(t,function i(a){r.once&&s.removeEventListener(t,i),e(a)});else throw new TypeError('The "emitter" argument must be of type EventEmitter. Received type '+typeof s)}var z;(function(s){s[s.MAJOR_EVENT=0]="MAJOR_EVENT",s[s.MINOR_EVENT=1]="MINOR_EVENT"})(z||(z={}));var O;(function(s){s.PRECALL_TEST_BEGIN="precall_begin",s.PRECALL_TEST_COMPLETE="precall_end",s.CALL_JOIN_BEGIN="call_join",s.NET_QUALITY_TEST_BEGIN="net_quality_test_begin",s.NET_QUALITY_TEST_END="net_quality_test_end",s.WEBSOCKET_CONNECTED="websocket_connected",s.TRANSPORT_CONNECTED="transport_connected",s.AUDIO_ON="audio_on",s.AUDIO_OFF="audio_off",s.VIDEO_ON="video_on",s.VIDEO_OFF="video_off",s.PARTICIPANT_ROLE="participant_role",s.PING_STAT="ping_stat",s.DISCONNECT="disconnect",s.RECONNECT_ATTEMPT="reconnect_attempt",s.SCREENSHARE_START_REQUESTED="screenshare_start_requested",s.SCREENSHARE_STARTED="screenshare_started",s.SCREENSHARE_STOPPED="screenshare_stopped",s.TAB_CHANGE="tab_change",s.BROWSER_BACKGROUNDED="browser_backgrounded",s.BROWSER_FOREGROUNDED="browser_foregrounded",s.DOMINANT_SPEAKER="dominant_speaker",s.AUDIO_DEVICES_UPDATES="audio_devices_updates",s.VIDEO_DEVICES_UPDATES="video_devices_updates",s.SPEAKER_DEVICES_UPDATES="speaker_devices_updates",s.SELECTED_MICROHPONE_UPDATE="selected_microphone_update",s.SELECTED_CAMERA_UPDATE="selected_camera_update",s.SELECTED_SPEAKER_UPDATE="selected_speaker_update",s.EXPECTED_VIDEO_RESOLUTION="expected_video_resolution",s.EXPECTED_SCREENSHARE_RESOLUTION="expected_screenshare_resolution",s.MEDIA_PERMISSION="media_permission",s.LEGACY_SWITCH="legacy_switch",s.AUDIO_PLAY_FAILED="audio_play_failed",s.VIDEO_PLAY_FAILED="video_play_failed",s.AUDIO_TRACK_MUTED="audio_track_muted",s.VIDEO_TRACK_MUTED="video_track_muted",s.IVS_PLAYER_REBUFFERING="ivs_player_rebuffering",s.IVS_PLAYER_AUDIO_BLOCKED="ivs_player_audio_blocked",s.IVS_PLAYER_PLAYBACK_BLOCKED="ivs_player_playback_blocked",s.IVS_PLAYER_ERROR="ivs_player_error",s.IVS_PLAYER_RECOVERABLE_ERROR="ivs_player_recoverable_error",s.IVS_PLAYER_WORKER_ERROR="ivs_player_worker_error",s.IVS_PLAYER_NETWORK_UNAVAILABLE="ivs_player_network_unavailable",s.LIVESTREAM_LATENCY="livestream_latency",s.IVS_PLAYER_ANALYTICS_EVENT="ivs_player_analytics_event",s.IVS_PLAYER_PLAYBACK_RATE_CHANGED="ivs_player_playback_rate_changed",s.IVS_PLAYER_QUALITY_CHANGED="ivs_player_quality_changed",s.IVS_PLAYER_INITIALIZED="ivs_player_initialized"})(O||(O={}));const fv=new Map([[O.PRECALL_TEST_BEGIN,z.MINOR_EVENT],[O.PRECALL_TEST_COMPLETE,z.MINOR_EVENT],[O.CALL_JOIN_BEGIN,z.MAJOR_EVENT],[O.NET_QUALITY_TEST_BEGIN,z.MINOR_EVENT],[O.NET_QUALITY_TEST_END,z.MINOR_EVENT],[O.WEBSOCKET_CONNECTED,z.MINOR_EVENT],[O.TRANSPORT_CONNECTED,z.MAJOR_EVENT],[O.AUDIO_ON,z.MINOR_EVENT],[O.AUDIO_OFF,z.MINOR_EVENT],[O.VIDEO_ON,z.MINOR_EVENT],[O.VIDEO_OFF,z.MINOR_EVENT],[O.PARTICIPANT_ROLE,z.MINOR_EVENT],[O.PING_STAT,z.MAJOR_EVENT],[O.DISCONNECT,z.MAJOR_EVENT],[O.RECONNECT_ATTEMPT,z.MAJOR_EVENT],[O.SCREENSHARE_START_REQUESTED,z.MINOR_EVENT],[O.SCREENSHARE_STARTED,z.MINOR_EVENT],[O.SCREENSHARE_STOPPED,z.MINOR_EVENT],[O.TAB_CHANGE,z.MINOR_EVENT],[O.BROWSER_BACKGROUNDED,z.MINOR_EVENT],[O.BROWSER_FOREGROUNDED,z.MINOR_EVENT],[O.DOMINANT_SPEAKER,z.MINOR_EVENT],[O.AUDIO_DEVICES_UPDATES,z.MINOR_EVENT],[O.VIDEO_DEVICES_UPDATES,z.MINOR_EVENT],[O.SPEAKER_DEVICES_UPDATES,z.MINOR_EVENT],[O.SELECTED_MICROHPONE_UPDATE,z.MINOR_EVENT],[O.SELECTED_CAMERA_UPDATE,z.MINOR_EVENT],[O.SELECTED_SPEAKER_UPDATE,z.MINOR_EVENT],[O.MEDIA_PERMISSION,z.MINOR_EVENT],[O.LEGACY_SWITCH,z.MINOR_EVENT],[O.AUDIO_PLAY_FAILED,z.MINOR_EVENT],[O.VIDEO_PLAY_FAILED,z.MINOR_EVENT],[O.AUDIO_TRACK_MUTED,z.MINOR_EVENT],[O.VIDEO_TRACK_MUTED,z.MINOR_EVENT],[O.IVS_PLAYER_REBUFFERING,z.MAJOR_EVENT],[O.IVS_PLAYER_AUDIO_BLOCKED,z.MAJOR_EVENT],[O.IVS_PLAYER_PLAYBACK_BLOCKED,z.MAJOR_EVENT],[O.IVS_PLAYER_ERROR,z.MAJOR_EVENT],[O.IVS_PLAYER_RECOVERABLE_ERROR,z.MAJOR_EVENT],[O.IVS_PLAYER_WORKER_ERROR,z.MAJOR_EVENT],[O.IVS_PLAYER_NETWORK_UNAVAILABLE,z.MAJOR_EVENT],[O.LIVESTREAM_LATENCY,z.MAJOR_EVENT],[O.IVS_PLAYER_ANALYTICS_EVENT,z.MINOR_EVENT],[O.IVS_PLAYER_PLAYBACK_RATE_CHANGED,z.MINOR_EVENT],[O.IVS_PLAYER_QUALITY_CHANGED,z.MINOR_EVENT],[O.IVS_PLAYER_INITIALIZED,z.MINOR_EVENT],[O.EXPECTED_VIDEO_RESOLUTION,z.MINOR_EVENT],[O.EXPECTED_SCREENSHARE_RESOLUTION,z.MINOR_EVENT]]);class Tv{constructor(){h(this,"events");this.events=[]}add(t){this.events.push(t)}flush(){return{entries:this.events.splice(0,25)}}}class vv extends ct{constructor({logger:e,peerId:r,apiHostnames:i}){super();h(this,"logger");h(this,"peerId");h(this,"eventStore");h(this,"apiEndpoint");this.logger=e,this.peerId=r,this.apiEndpoint=`https://${i.daCollector}/api/v1/message`,this.eventStore=new Tv}sendEventsChunkToServer(e){return u(this,null,function*(){var i;const r={payload:e,peerId:this.peerId};try{return yield fetch(this.apiEndpoint,{method:"POST",body:JSON.stringify(r)}),!0}catch(a){return this.logger.error("callStats::sendEventsChunkToServer::catch",{error:a}),(i=e.entries)==null||i.forEach(o=>{this.eventStore.add(o)}),!1}})}callEvent(e){e.timestamp=new Date,this.eventStore.add(e),this.emit(e.event,e.metaData),fv.get(e.event)===z.MAJOR_EVENT&&this.flush()}flush(){return u(this,null,function*(){var r;const e=this.eventStore.flush();return(r=e==null?void 0:e.entries)!=null&&r.length?(yield this.sendEventsChunkToServer(e),!0):!1})}}var zh;(function(s){s.CHROMIUM="chromum",s.FIREFOX="firefox",s.SAFARI="safari"})(zh||(zh={}));const uo={DEVEL:"devel",PREPROD:"preprod",PROD:"prod"};var Gt;(function(s){s.AUDIO="AUDIO",s.VIDEO="VIDEO",s.SPEAKER="SPEAKER",s.SCREENSHARE="SCREENSHARE"})(Gt||(Gt={}));var Yh;(function(s){s[s.INIT=0]="INIT",s[s.ACCEPTED=1]="ACCEPTED",s[s.DENIED=2]="DENIED",s[s.SYS_DENIED=3]="SYS_DENIED",s[s.FAILED=4]="FAILED",s[s.NOTFOUND=5]="NOTFOUND",s[s.NOT_APPLICABLE=6]="NOT_APPLICABLE"})(Yh||(Yh={}));function Yr(s){return s?s.split(".").slice(0,2).concat(["0","0"]).join("."):""}function gd({packetsLost:s,packetsSent:t}){return t>0?s*100/t:0}function md({packetsLost:s,packetsReceived:t}){return t+s>0?s*100/(t+s):0}const sm=240,rm=720,im=8,nm=3,_l=10,Cl=.02,wl=.03;function hr({stat:s,weight:t,rangeMin:e,rangeMax:r,rangeRankingDirection:i}){return s==null?t:e===r?i==="UP"?s<=e?t:0:s>=r?t:0:i==="UP"?(1-Math.max(Math.min(r,Math.abs(s))-e,0)/(r-e))*t:i==="DOWN"?Math.max(Math.min(r,Math.abs(s))-e,0)/(r-e)*t:t}function am({isLowQualityVideo:s,isVideoStuck:t,isVideoLagging:e,jitterQuality:r,packetsLostQuality:i}){const a=.8*((s?.85:1)*(e?.7:1)*(t?.5:1))+.2*(r*i);return Math.round((a+Number.EPSILON)*100)/100}function om({packetsLost:s,packetsSent:t}){return t>0?s*100/t:0}function cm({packetsLost:s,packetsSent:t,jitter:e}){const i=hr({stat:om({packetsLost:s,packetsSent:t}),weight:.7,rangeMin:0,rangeMax:_l,rangeRankingDirection:"UP"}),o=hr({stat:e,weight:.3,rangeMin:Cl,rangeMax:wl,rangeRankingDirection:"UP"});return i+o}function Sv({frameWidth:s,isScreenShare:t}){return s<(t?rm:sm)}function yv({framesPerSecond:s,isScreenShare:t}){return s<(t?nm:im)}function Ev({framesEncoded:s}){return s===0}function dm({frameWidth:s,framesPerSecond:t,packetsLost:e,packetsSent:r,jitter:i,isScreenShare:a,framesEncoded:o}){const c=hr({stat:om({packetsLost:e,packetsSent:r}),weight:1,rangeMin:0,rangeMax:_l,rangeRankingDirection:"UP"}),d=hr({stat:i,weight:1,rangeMin:Cl,rangeMax:wl,rangeRankingDirection:"UP"}),l=Sv({frameWidth:s,isScreenShare:a}),p=yv({framesPerSecond:t,isScreenShare:a}),g=Ev({framesEncoded:o,isScreenShare:a});return am({isLowQualityVideo:l,isVideoLagging:p,isVideoStuck:g,jitterQuality:d,packetsLostQuality:c})}function lm({packetsLost:s,packetsReceived:t}){return t+s>0?s*100/(t+s):0}function um({concealmentEvents:s,packetsLost:t,packetsReceived:e,jitter:r}){const a=hr({stat:s,weight:.2,rangeMin:0,rangeMax:3,rangeRankingDirection:"UP"}),o=.5,c=hr({stat:lm({packetsLost:t,packetsReceived:e}),weight:o,rangeMin:0,rangeMax:_l,rangeRankingDirection:"UP"}),l=hr({stat:r,weight:.3,rangeMin:Cl,rangeMax:wl,rangeRankingDirection:"UP"});return a+c+l}function Pv({framesDecoded:s}){return s===0}function _v({framesPerSecond:s,isScreenShare:t}){return s<(t?nm:im)}function Cv({frameWidth:s,isScreenShare:t}){return s<(t?rm:sm)}function hm({frameWidth:s,framesPerSecond:t,packetsLost:e,packetsReceived:r,jitter:i,isScreenShare:a,framesDecoded:o}){const c=hr({stat:lm({packetsLost:e,packetsReceived:r}),weight:1,rangeMin:0,rangeMax:_l,rangeRankingDirection:"UP"}),d=hr({stat:i,weight:1,rangeMin:Cl,rangeMax:wl,rangeRankingDirection:"UP"}),l=Cv({frameWidth:s,isScreenShare:a}),p=_v({framesPerSecond:t,isScreenShare:a}),g=Pv({framesDecoded:o,isScreenShare:a});return am({isLowQualityVideo:l,isVideoLagging:p,isVideoStuck:g,jitterQuality:d,packetsLostQuality:c})}class mr{constructor(t){h(this,"pc1");h(this,"pc2");h(this,"constrainVideoBitrateKbps");h(this,"constrainOfferToRemoveVideoFec",!1);h(this,"iceCandidateFilter");const e=new RTCPeerConnection(t),r=new RTCPeerConnection(t);this.pc1=e,this.pc2=r,this.iceCandidateFilter=mr.noFilter,this.pc1.addEventListener("icecandidate",this.onIceCandidate.bind(this,this.pc2)),this.pc2.addEventListener("icecandidate",this.onIceCandidate.bind(this,this.pc1))}static parseCandidate(t){const e="candidate:",r=t.indexOf(e)+e.length,i=t.substr(r).split(" ");return{type:i[7],protocol:i[2],address:i[4]}}static isNotHostCandidate(t){return t.type!=="host"}static isHost(t){return t.type==="host"}static isRelay(t){return t.type==="relay"}static isReflexive(t){return t.type==="srflx"}static noFilter(t){return!0}onIceCandidate(t,e){if(e.candidate){const r=mr.parseCandidate(e.candidate.candidate);this.iceCandidateFilter(r)&&t.addIceCandidate(e.candidate)}}setIceCandidateFilter(t){this.iceCandidateFilter=t}constrainVideoBitrate(t){this.constrainVideoBitrateKbps=t}disableVideoFec(){this.constrainOfferToRemoveVideoFec=!0}gotOffer(t){this.constrainOfferToRemoveVideoFec&&(t.sdp=t.sdp.replace(/(m=video 1 [^\r]+)(116 117)(\r\n)/g,`$1\r
|
|
2
|
-
`),t.sdp=t.sdp.replace(/a=rtpmap:116 red\/90000\r\n/g,""),t.sdp=t.sdp.replace(/a=rtpmap:117 ulpfec\/90000\r\n/g,""),t.sdp=t.sdp.replace(/a=rtpmap:98 rtx\/90000\r\n/g,""),t.sdp=t.sdp.replace(/a=fmtp:98 apt=116\r\n/g,"")),this.pc1.setLocalDescription(t),this.pc2.setRemoteDescription(t),this.pc2.createAnswer().then(this.gotAnswer.bind(this),this.reportFatal.bind(this))}gotAnswer(t){this.constrainVideoBitrateKbps&&(t.sdp=t.sdp.replace(/a=mid:video\r\n/g,`a=mid:video\r
|
|
3
|
-
|
|
4
|
-
`)),this.pc2.setLocalDescription(t),this.pc1.setRemoteDescription(t)}establishConnection(){this.pc1.createOffer().then(this.gotOffer.bind(this),this.reportFatal.bind(this))}reportFatal(t){console.error("Error:",t)}getRoundTripTime(){return u(this,null,function*(){const[t,e]=yield Promise.all([this.pc1.getStats(),this.pc2.getStats()]);let r,i;if(t.forEach(a=>{a.type==="candidate-pair"&&a.nominated===!0&&a.bytesSent>0&&(r=a)}),e.forEach(a=>{a.type==="candidate-pair"&&a.nominated===!0&&a.bytesReceived>0&&(i=a)}),r&&i)try{if(r.currentRoundTripTime&&i.currentRoundTripTime)return{rtt:r.currentRoundTripTime,backendRTT:i.currentRoundTripTime};const a=(i.lastPacketReceivedTimestamp-r.lastPacketSentTimestamp)/1e3;return{rtt:a,backendRTT:a}}catch(a){return}})}close(){this.pc1.close(),this.pc2.close()}}class pm extends ct{constructor(e){super();h(this,"call");h(this,"timeOut");this.call=new mr(e)}start(e=1e4){this.call.establishConnection(),this.timeOut=setTimeout(this.testFailed.bind(this),e)}testComplete(e){clearTimeout(this.timeOut),this.call.close(),this.emit("done",e)}testFailed(e){this.call.close(),this.emit("failed",e)}}const wv=8,Rv=1/1e3;class bv extends pm{constructor(e){super(e);h(this,"senderChannel");h(this,"recieveChannel");h(this,"startTime");h(this,"lastBitrateMeasureTime");h(this,"sentPayloadBytes",0);h(this,"recievedPayloadBytes",0);h(this,"lastReceivedPayloadBytes",0);h(this,"stopSending",!1);h(this,"testProgress",0);h(this,"samplePacket","");h(this,"finalBitrateSum",0);h(this,"bitRateSampels",0);h(this,"maxNumberOfPacketsToSend",0);h(this,"bytesToKeepBuffered",0);h(this,"testDurationSeconds",5);this.call.setIceCandidateFilter(mr.isNotHostCandidate),this.senderChannel=this.call.pc1.createDataChannel(null);for(let r=0;r<1024*256;r+=1)this.samplePacket+="h";this.maxNumberOfPacketsToSend=1,this.bytesToKeepBuffered=1024*this.maxNumberOfPacketsToSend,this.testDurationSeconds=4,this.senderChannel.addEventListener("open",this.sendingStep.bind(this)),this.call.pc2.addEventListener("datachannel",this.onRecieverChannel.bind(this))}sendingStep(){const e=new Date;this.startTime||(this.startTime=e,this.lastBitrateMeasureTime=e);for(let i=0;i!==this.maxNumberOfPacketsToSend&&!(this.senderChannel.bufferedAmount>=this.bytesToKeepBuffered);i+=1){this.sentPayloadBytes+=this.samplePacket.length;try{this.senderChannel.send(this.samplePacket)}catch(a){}}const r=e.getTime()-this.startTime.getTime();r>=1e3*this.testDurationSeconds?(this.stopSending=!0,this.testProgress=100):(this.testProgress=r/(10*this.testDurationSeconds),setTimeout(this.sendingStep.bind(this),1))}onMessageRecieved(e){this.recievedPayloadBytes+=e.data.length;const r=new Date,i=r.getTime()-this.lastBitrateMeasureTime.getTime();if(i>=1e3){const o=(this.recievedPayloadBytes-this.lastReceivedPayloadBytes)*wv/(i/1e3);this.finalBitrateSum+=o,this.bitRateSampels+=1,this.lastReceivedPayloadBytes=this.recievedPayloadBytes,this.lastBitrateMeasureTime=r}if(this.stopSending&&this.sentPayloadBytes===this.recievedPayloadBytes){const a=this.finalBitrateSum/this.bitRateSampels;this.testComplete({throughput:Math.round(a*Rv)})}}testComplete(e){this.call.getRoundTripTime().then(({rtt:r,backendRTT:i})=>super.testComplete({RTT:r,backendRTT:i,throughput:e.throughput}))}onRecieverChannel(e){this.recieveChannel=e.channel,this.recieveChannel.addEventListener("message",this.onMessageRecieved.bind(this))}}class nh extends pm{constructor(e,r=mr.noFilter){super(e);h(this,"ch1");h(this,"ch2");this.call.setIceCandidateFilter(r);const i=this.call.pc1.createDataChannel(null);this.ch1=i,i.addEventListener("open",()=>{i.send("hello")}),i.addEventListener("message",this.onCh1Recieve.bind(this)),this.call.pc2.addEventListener("datachannel",this.dataChannelHandler.bind(this))}onCh1Recieve(e){e.data!=="world"?this.hangup("Invalid data transmitted."):this.testComplete({connectivity:!0})}onCh2Recieve(e){if(e.data!=="hello")this.hangup("Invalid data transmitted.");else try{this.ch2.send("world")}catch(r){}}dataChannelHandler(e){const r=e.channel;this.ch2=r,r.addEventListener("message",this.onCh2Recieve.bind(this))}hangup(e){this.testFailed(e)}}class kv extends nh{constructor(t){super(t,mr.isHost)}}class Av extends nh{constructor(t){super(t,mr.isRelay)}}class Iv extends nh{constructor(t){super(t,mr.isReflexive)}}class Mv{constructor(){h(this,"ipInformation",null)}getIPDetails(i){return u(this,arguments,function*({peerId:t,apiHostnames:e,logger:r}){var a,o,c;if(!this.ipInformation){try{const d=`https://${e.location}`,p=yield(yield fetch(d)).json();if(((a=p.loc)==null?void 0:a.length)>5)return this.ipInformation=p,(o=this.ipInformation)!=null&&o.ip&&(this.ipInformation.ip=Yr(this.ipInformation.ip)),p;throw Error("Insufficient data")}catch(d){r.error("callstats::ipDetails:: failed to fetch ip using location service",{error:d})}try{const d=yield fetch(`https://${e.locationLegacy}/?token=3c493932b0624c&peerId=${t}`,{method:"POST"});this.ipInformation=yield d.json(),(c=this.ipInformation)!=null&&c.ip&&(this.ipInformation.ip=Yr(this.ipInformation.ip))}catch(d){r.error("callstats::ipDetails:: failed to fetch ip using legacy location service",{error:d})}}return this.ipInformation})}resetCache(){this.ipInformation=null}}const ah=new Mv,Qh=[{urls:"turn:turn.dyte.in:443?transport=tcp",username:"dyte",credential:"dytein",credentialType:"password"},{urls:"turn:turn.dyte.in:3478?transport=udp",username:"dyte",credential:"dytein",credentialType:"password"}];function Xh(s){const[t,e]=s.split(",");return{coords:{latitude:Number(t),longitude:Number(e)}}}class gm{constructor(){h(this,"transport");h(this,"candidatePair");h(this,"outboundVideoRtp",new Map);h(this,"inboundVideoRtp",new Map);h(this,"outboundAudioRtp",new Map);h(this,"inboundAudioRtp",new Map);h(this,"remoteInboundRtp",new Map);h(this,"producerStreamMap",new Map);h(this,"consumerStreamMap",new Map);h(this,"staleProducerStreamMap",!1);h(this,"staleConsumerStreamMap",!1)}}class mm extends ct{constructor(){super();h(this,"observer");h(this,"outboundProducerMap",new Map);h(this,"inboundConsumerMap",new Map);h(this,"consumerPeerIdMap",new Map);h(this,"pausedConsumerMap",new Map);h(this,"pausedProducerMap",new Map);h(this,"overallProducingTransportsStatsMap",{});h(this,"overallConsumingTransportsStatsMap",{});h(this,"overallConsumersStatsMap",{});h(this,"overallProducersStatsMap",{});h(this,"videoProducerToStatsMap",new Map);h(this,"audioProducerToStatsMap",new Map);h(this,"videoConsumerToStatsMap",new Map);h(this,"audioConsumerToStatsMap",new Map);h(this,"consumerIdsWithFreezedVideo",new Set);h(this,"consumerIdsWithFreezedAudio",new Set);h(this,"producerIdsWithFreezedVideo",new Set);h(this,"producerIdsWithFreezedAudio",new Set);h(this,"freezedProducingTransportIds",new Set);h(this,"freezedConsumingTransportIds",new Set);h(this,"screenShareProducers",new Set);h(this,"screenShareConsumers",new Set);h(this,"ipDetails");h(this,"callStatsInstance");this.observer=new ct}registerProducer(e){return u(this,null,function*(){yield this.generateProducerStreamMap(e),e.on("close",this.deregisterProducer.bind(this,e)),e.on("pause",this.pauseProducer.bind(this,e.id)),e.on("resume",this.resumeProducer.bind(this,e.id)),e.appData.screenShare===!0&&this.screenShareProducers.add(e.id)})}pauseProducer(e){this.pausedProducerMap.set(e,{lastReportCalculated:!1})}resumeProducer(e){this.pausedProducerMap.delete(e)}processInboundConsumerVideoStats(e,r,i){var o,c;const a=((c=(o=this==null?void 0:this.callStatsInstance)==null?void 0:o.consumerSharedMediaStatesMap)==null?void 0:c.get(e))||{};r.totalVideoPacketsReceived===i.packetsReceived?(this.consumerIdsWithFreezedVideo.add(e),this.callStatsInstance&&a.video&&(this.callStatsInstance.logger.debug("callstats::measurements::consumerVideoFreezed",{consumerId:e}),this.callStatsInstance.eventHandler.emit("consumer_video_status","pause",e))):(r.totalVideoPacketsReceived=i.packetsReceived,this.consumerIdsWithFreezedVideo.has(e)&&(this.consumerIdsWithFreezedVideo.delete(e),this.callStatsInstance&&a.video&&(this.callStatsInstance.logger.debug("callstats::measurements::consumerVideoDefreezed",{consumerId:e}),this.callStatsInstance.eventHandler.emit("consumer_video_status","resume",e))))}processInboundConsumerAudioStats(e,r,i){var o,c;const a=((c=(o=this==null?void 0:this.callStatsInstance)==null?void 0:o.consumerSharedMediaStatesMap)==null?void 0:c.get(e))||{};r.totalAudioPacketsReceived===i.packetsReceived?(this.consumerIdsWithFreezedAudio.add(e),this.callStatsInstance&&a.audio&&(this.callStatsInstance.logger.debug("callStats::measurements::consumerAudioFreezed",{consumerId:e}),this.callStatsInstance.eventHandler.emit("consumer_audio_status","pause",e))):(r.totalAudioPacketsReceived=i.packetsReceived,this.consumerIdsWithFreezedAudio.has(e)&&(this.consumerIdsWithFreezedAudio.delete(e),this.callStatsInstance&&a.audio&&(this.callStatsInstance.logger.debug("callStats::measurements::consumerAudioDefreezed",{consumerId:e}),this.callStatsInstance.eventHandler.emit("consumer_audio_status","resume",e))))}processOutboundProducerVideoStats(e,r,i){var o;const a=((o=this==null?void 0:this.callStatsInstance)==null?void 0:o.currentUserMediaStates)||{};r.totalVideoPacketsSent===i.packetsSent?(this.producerIdsWithFreezedVideo.add(e),this.callStatsInstance&&a.video&&(this.callStatsInstance.logger.debug("callStats::measurements::producerVideoFreezed",{producerId:e}),this.callStatsInstance.eventHandler.emit("producer_video_status","pause",e))):(r.totalVideoPacketsSent=i.packetsSent,this.producerIdsWithFreezedVideo.has(e)&&(this.producerIdsWithFreezedVideo.delete(e),this.callStatsInstance&&a.video&&(this.callStatsInstance.logger.debug("callStats::measurements::producerVideoDefreezed",{producerId:e}),this.callStatsInstance.eventHandler.emit("producer_video_status","resume",e))))}processOutboundProducerAudioStats(e,r,i){var o;const a=((o=this==null?void 0:this.callStatsInstance)==null?void 0:o.currentUserMediaStates)||{};r.totalAudioPacketsSent===i.packetsSent?(this.producerIdsWithFreezedAudio.add(e),this.callStatsInstance&&a.audio&&(this.callStatsInstance.logger.debug("callStats::measurements::producerAudioFreezed",{producerId:e}),this.callStatsInstance.eventHandler.emit("producer_audio_status","pause",e))):(r.totalAudioPacketsSent=i.packetsSent,this.producerIdsWithFreezedAudio.has(e)&&(this.producerIdsWithFreezedAudio.delete(e),this.callStatsInstance&&a.audio&&(this.callStatsInstance.logger.debug("callStats::measurements::producerAudioDefreezed",{producerId:e}),this.callStatsInstance.eventHandler.emit("producer_audio_status","resume",e))))}processProducingTransportStats(e,r,i){var p;const a=((p=this==null?void 0:this.callStatsInstance)==null?void 0:p.currentUserMediaStates)||{},{audio:o,video:c,screen:d}=a,l=o||c||d;r.totalPacketsSent===i.packetsSent?(this.freezedProducingTransportIds.add(e),this.callStatsInstance&&l&&(this.callStatsInstance.logger.debug("callStats::measurements::producingTransportFreezed",{transportId:e}),this.callStatsInstance.eventHandler.emit("producing_transport_status","pause",e))):(r.totalPacketsSent=i.packetsSent,this.freezedProducingTransportIds.has(e)&&(this.freezedProducingTransportIds.delete(e),this.callStatsInstance&&l&&(this.callStatsInstance.logger.debug("callStats::measurements::producingTransportDefreezed",{transportId:e}),this.callStatsInstance.eventHandler.emit("producing_transport_status","resume",e))))}processConsumingTransportStats(e,r,i){var c,d;const o=!!Array.from(((d=(c=this==null?void 0:this.callStatsInstance)==null?void 0:c.consumerSharedMediaStatesMap)==null?void 0:d.values())||[]).reduce((l,p)=>l||p.audio||p.video||p.screen,!1);r.totalPacketsReceived===i.packetsSent?(this.freezedConsumingTransportIds.add(e),this.callStatsInstance&&o&&(this.callStatsInstance.logger.debug("callStats::measurements::consumingTransportFreezed",{transportId:e}),this.callStatsInstance.eventHandler.emit("consuming_transport_status","pause",e))):(r.totalPacketsReceived=i.packetsSent,this.freezedConsumingTransportIds.has(e)&&(this.freezedConsumingTransportIds.delete(e),this.callStatsInstance&&o&&(this.callStatsInstance.logger.debug("callStats::measurements::consumingTransportDefreezed",{transportId:e}),this.callStatsInstance.eventHandler.emit("consuming_transport_status","resume",e))))}registerConsumer(e){return u(this,null,function*(){yield this.generateConsumerStreamMap(e),this.consumerPeerIdMap.set(e.id,{producerId:e.producerId,peerId:e.appData.peerId,appData:e.appData}),e.on("close",this.deregisterConsumer.bind(this,e)),e.on("pause",this.pauseConsumer.bind(this,e.id)),e.on("resume",this.resumeConsumer.bind(this,e.id)),e.appData.screenShare===!0&&this.screenShareConsumers.add(e.id)})}pauseConsumer(e){this.pausedConsumerMap.set(e,{lastReportCalculated:!1})}resumeConsumer(e){this.pausedConsumerMap.delete(e)}generateProducerStreamMap(e,r=!1){return u(this,null,function*(){const i=yield e.getStats(),a=r?this.getProducerStatsFromReport(this.parseRTCReport(i,["outbound-rtp","remote-inbound-rtp"],!1,e.id))[0]:void 0;for(const o of i.values())switch(o.type){case"outbound-rtp":{this.outboundProducerMap.set(o.id,e.id);break}}return a})}generateConsumerStreamMap(e,r=!1){return u(this,null,function*(){const i=yield e.getStats(),a=r?this.getConsumerStatsFromReport(this.parseRTCReport(i,["inbound-rtp"],!1,e.id))[0]:void 0;for(const o of i.values())switch(o.type){case"inbound-rtp":{this.inboundConsumerMap.set(o.id,e.id);break}}return a})}deregisterProducer(e){this.outboundProducerMap.forEach((r,i)=>{r===e.id&&this.outboundProducerMap.delete(i)}),this.pausedProducerMap.delete(e.id),this.screenShareProducers.delete(e.id)}deregisterConsumer(e){this.inboundConsumerMap.forEach((r,i)=>{r===e.id&&this.inboundConsumerMap.delete(i)}),this.consumerPeerIdMap.delete(e.id),this.pausedConsumerMap.delete(e.id),this.screenShareConsumers.delete(e.id)}getIceCandidateStats(e){var r;return{id:e.id,type:e.candidateType||e.type,address:e.address,port:e.port,url:e.url,protocol:(r=e.relayProtocol)!=null?r:e.protocol,networkType:e.networkType,relatedAddress:e.relatedAddress,relatedPort:e.relatedPort}}getWorkingSimulcastVideoStats(e){return e.find(i=>{const a=i.framesEncoded>0,o=i.packetsSent>0,c=i.frameWidth&&i.frameHeight;return a&&o&&!!c})||e[e.length-1]}parseRTCReport(e,r=[],i=!1,a=void 0,o=void 0){var _,C,R,L,F,N,B,j,re,et,os,ri,cs;const c=e,d=new gm,l=r.length?new Set(r):void 0,p=[],g=[],T=[],v=new Map,E=new Map;for(const I of c.values()){if(l){if(l.size===0)break;if(l.has(I.type))i&&l.delete(I.type);else continue}switch(I.type){case"local-candidate":{p.push(this.getIceCandidateStats(I));break}case"remote-candidate":{g.push(this.getIceCandidateStats(I));break}case"candidate-pair":{const{nominated:y}=I,{selected:w}=I,$=I,ye={nominated:y!=null?y:w,currentRoundTripTime:$.currentRoundTripTime,totalRoundTripTime:$.totalRoundTripTime,bytesReceived:$.bytesReceived,bytesSent:$.bytesSent,availableOutgoingBitrate:$.availableOutgoingBitrate,availableIncomingBitrate:$.availableIncomingBitrate,lastPacketReceivedTimestamp:$.lastPacketReceivedTimestamp,lastPacketSentTimestamp:$.lastPacketSentTimestamp,localCandidateId:$.localCandidateId,remoteCandidateId:$.remoteCandidateId,bytesDiscardedOnSend:$.bytesDiscardedOnSend,packetsSent:$.packetsSent,packetsReceived:$.packetsReceived,packetsDiscardedOnSend:$.packetsDiscardedOnSend};T.push(ye),(I.nominated===!0||I.selected===!0)&&(d.candidatePair=ye);break}case"transport":{const y=I;o&&(o.producing&&(this.overallProducingTransportsStatsMap[o.id]||(this.overallProducingTransportsStatsMap[o.id]={totalPacketsSent:0})),o.consuming&&(this.overallConsumingTransportsStatsMap[o.id]||(this.overallConsumingTransportsStatsMap[o.id]={totalPacketsReceived:0})));const w={bytesReceived:y.bytesReceived,bytesSent:y.bytesSent,packetsSent:y.packetsSent,packetsReceived:y.packetsReceived,dtlsCipher:y.dtlsCipher,dtlsState:y.dtlsState,iceRole:y.iceRole};if(d.transport=w,o){if(o.producing){const $=this.overallProducingTransportsStatsMap[o.id];this.processProducingTransportStats(o.id,$,w)}if(o.consuming){const $=this.overallConsumingTransportsStatsMap[o.id];this.processConsumingTransportStats(o.id,$,w)}}break}case"remote-inbound-rtp":{const y=I,w={jitter:y.jitter,fractionLost:y.fractionLost,roundTripTime:y.roundTripTime,roundTripTimeMeasurements:y.roundTripTimeMeasurements,totalRoundTripTime:y.totalRoundTripTime,packetsLost:y.packetsLost};d.remoteInboundRtp.set(y.localId,w);break}case"outbound-rtp":{if(!this.outboundProducerMap.has(I.id))break;const y=I,w=a||this.outboundProducerMap.get(I.id),$=this.pausedProducerMap.get(w);if($){if($.lastReportCalculated===!0)break;this.pausedProducerMap.set(w,{lastReportCalculated:!0})}this.overallProducersStatsMap[w]||(this.overallProducersStatsMap[w]={totalVideoPacketsSent:0,totalAudioPacketsSent:0});const ye=this.overallProducersStatsMap[w];if(["video","audio"].includes(y.mediaType)||["video","audio"].includes(y.kind)){if(!this.outboundProducerMap.has(I.id)){d.staleProducerStreamMap=!0;break}const Ie=this.callStatsInstance.producers.get(w);if(((_=Ie==null?void 0:Ie.track)==null?void 0:_.readyState)==="ended")break;d.producerStreamMap.has(w)||d.producerStreamMap.set(w,{outboundVideoRtpId:[],outboundAudioRtpId:[]});const V={bytesSent:y.bytesSent,packetsSent:y.packetsSent,nackCount:y.nackCount,ssrc:y.ssrc,mid:y.mid,active:y.active,codecId:y.codecId,headerBytesSent:y.headerBytesSent||0,totalPacketSendDelay:y.totalPacketSendDelay||0};if(y.mediaType==="video"||y.kind==="video"){const k=y,xe=D({frameHeight:k.frameHeight,frameWidth:k.frameWidth,framesEncoded:k.framesEncoded,framesDropped:k.framesDropped,framesPerSecond:k.framesPerSecond,framesSent:k.framesSent,keyFramesEncoded:k.keyFramesEncoded,firCount:k.firCount,encoderImplementation:k.encoderImplementation,hugeFramesSent:k.hugeFramesSent,pliCount:k.pliCount,qpSum:k.qpSum,qualityLimitationDurations:k.qualityLimitationDurations,qualityLimitationReason:k.qualityLimitationReason,qualityLimitationResolutionChanges:k.qualityLimitationResolutionChanges,totalEncodeTime:k.targetBitrate,totalPacketSendDelay:k.totalPacketSendDelay,retransmittedBytesSent:k.retransmittedBytesSent,retransmittedPacketsSent:k.retransmittedPacketsSent,scalabilityMode:k.scalabilityMode,powerEfficientEncoder:k.powerEfficientEncoder},V);d.outboundVideoRtp.set(I.id,xe),d.producerStreamMap.get(w).outboundVideoRtpId.push(I.id),this.processOutboundProducerVideoStats(w,ye,xe)}else if(y.mediaType==="audio"||y.kind==="audio"){const k=y,xe=D({retransmittedBytesSent:k.retransmittedBytesSent,retransmittedPacketsSent:k.retransmittedPacketsSent},V);d.outboundAudioRtp.set(I.id,xe),d.producerStreamMap.get(w).outboundAudioRtpId.push(I.id),this.processOutboundProducerAudioStats(w,ye,xe)}}else this.callStatsInstance.logger.error(`Callstats: Unknown Outbound-rtp. mediatype: ${y.mediaType} kind: ${y.kind}`);break}case"inbound-rtp":{if(!this.inboundConsumerMap.has(I.id))break;const y=I,w=a||this.inboundConsumerMap.get(I.id),$=this.pausedConsumerMap.get(w);if($){if($.lastReportCalculated===!0)break;this.pausedConsumerMap.set(w,{lastReportCalculated:!0})}if(y.ssrc===1234)break;this.overallConsumersStatsMap[w]||(this.overallConsumersStatsMap[w]={totalVideoPacketsReceived:0,totalAudioPacketsReceived:0});const ye=this.overallConsumersStatsMap[w];if(["video","audio"].includes(y.mediaType)||["video","audio"].includes(y.kind)){if(!this.inboundConsumerMap.has(I.id)){d.staleConsumerStreamMap=!0;break}d.consumerStreamMap.has(w)||d.consumerStreamMap.set(w,{inboundVideoRtpId:[],inboundAudioRtpId:[]});const Ie={bytesReceived:y.bytesReceived,packetsReceived:y.packetsReceived,packetsLost:y.packetsLost>=0?y.packetsLost:0,jitter:y.jitter,nackCount:y.nackCount,jitterBufferDelay:y.jitterBufferDelay,jitterBufferEmittedCount:y.jitterBufferEmittedCount,lastPacketReceivedTimestamp:y.lastPacketReceivedTimestamp,ssrc:y.ssrc,mid:y.mid,codecId:y.codecId,headerBytesReceived:y.headerBytesReceived||0,packetsDiscarded:y.packetsDiscarded||0,jitterBufferMinimumDelay:y.jitterBufferMinimumDelay||0,jitterBufferTargetDelay:y.jitterBufferTargetDelay||0};if(y.mediaType==="video"||y.kind==="video"){const V=y,k=D({frameHeight:V.frameHeight,frameWidth:V.frameWidth,framesDecoded:V.framesDecoded,framesDropped:V.framesDropped,framesPerSecond:V.framesPerSecond,framesReceived:V.framesReceived,keyFramesDecoded:V.keyFramesDecoded,firCount:V.firCount,decoderImplementation:V.decoderImplementation,pliCount:V.pliCount,totalProcessingDelay:V.totalProcessingDelay,qpSum:V.qpSum||0,totalAssemblyTime:V.totalAssemblyTime||0,totalDecodeTime:V.totalDecodeTime||0,totalFreezesDuration:V.totalFreezesDuration||0,totalInterFrameDelay:V.totalInterFrameDelay||0,totalPausesDuration:V.totalPausesDuration||0,totalSquaredInterFrameDelay:V.totalSquaredInterFrameDelay||0,freezeCount:V.freezeCount||0,pauseCount:V.pauseCount||0,powerEfficientDecoder:V.powerEfficientDecoder},Ie);k.score=hm({frameWidth:k.frameWidth||0,framesDecoded:(k.framesDecoded||0)-(((C=this.videoConsumerToStatsMap.get(w))==null?void 0:C.framesDecoded)||0),framesPerSecond:k.framesPerSecond||0,packetsLost:(k.packetsLost||0)-(((R=this.videoConsumerToStatsMap.get(w))==null?void 0:R.packetsLost)||0),packetsReceived:(k.packetsReceived||0)-(((L=this.videoConsumerToStatsMap.get(w))==null?void 0:L.packetsReceived)||0),jitter:k.jitter||0,isScreenShare:this.screenShareConsumers.has(w)}),E.set(w,{score:+(k.score*10).toFixed(),frameWidth:k.frameWidth||0,frameHeight:k.frameHeight||0,framesPerSecond:k.framesPerSecond||0,packetsLostPercentage:md({packetsLost:(k.packetsLost||0)-(((F=this.videoConsumerToStatsMap.get(w))==null?void 0:F.packetsLost)||0),packetsReceived:(k.packetsReceived||0)-(((N=this.videoConsumerToStatsMap.get(w))==null?void 0:N.packetsReceived)||0)}),jitter:k.jitter||0,isScreenShare:this.screenShareConsumers.has(w),bitrate:((k.bytesReceived||0)-(((B=this.videoConsumerToStatsMap.get(w))==null?void 0:B.bytesReceived)||0))*8/7}),this.videoConsumerToStatsMap.set(w,k),d.inboundVideoRtp.set(I.id,k),d.consumerStreamMap.get(w).inboundVideoRtpId.push(I.id),this.processInboundConsumerVideoStats(w,ye,k)}else if(y.mediaType==="audio"||y.kind==="audio"){const V=y,k=D({audioLevel:V.audioLevel,concealedSamples:V.concealedSamples,concealmentEvents:V.concealmentEvents,totalAudioEnergy:V.totalAudioEnergy,totalSamplesDuration:V.totalSamplesDuration,totalSamplesReceived:V.totalSamplesReceived,fecPacketsDiscarded:V.fecPacketsDiscarded||0,fecPacketsReceived:V.fecPacketsReceived||0,insertedSamplesForDeceleration:V.insertedSamplesForDeceleration||0,removedSamplesForAcceleration:V.removedSamplesForAcceleration||0,silentConcealedSamples:V.silentConcealedSamples||0,playoutId:V.playoutId},Ie);k.score=um({concealmentEvents:(k.concealmentEvents||0)-(((j=this.audioConsumerToStatsMap.get(w))==null?void 0:j.concealmentEvents)||0),packetsLost:(k.packetsLost||0)-(((re=this.audioConsumerToStatsMap.get(w))==null?void 0:re.packetsLost)||0),packetsReceived:(k.packetsReceived||0)-(((et=this.audioConsumerToStatsMap.get(w))==null?void 0:et.packetsReceived)||0),jitter:k.jitter||0}),E.set(w,{score:+(k.score*10).toFixed(),packetsLostPercentage:md({packetsLost:(k.packetsLost||0)-(((os=this.audioConsumerToStatsMap.get(w))==null?void 0:os.packetsLost)||0),packetsReceived:(k.packetsReceived||0)-(((ri=this.audioConsumerToStatsMap.get(w))==null?void 0:ri.packetsReceived)||0)}),jitter:k.jitter||0,isScreenShare:this.screenShareConsumers.has(w),bitrate:((k.bytesReceived||0)-(((cs=this.audioConsumerToStatsMap.get(w))==null?void 0:cs.bytesReceived)||0))*8/7}),this.audioConsumerToStatsMap.set(w,k),d.inboundAudioRtp.set(I.id,k),d.consumerStreamMap.get(w).inboundAudioRtpId.push(I.id),this.processInboundConsumerAudioStats(w,ye,k)}}else this.callStatsInstance.logger.error(`Callstats: Unknown Inbound-rtp. mediatype: ${y.mediaType} kind: ${y.kind}`);break}}}if(d.producerStreamMap.forEach((I,y)=>{var w,$,ye,Ie,V,k,xe,Fs,La,xa,Ua,$a,Fa,Ba,Ha,qa,ja,Ga,Wa,Ja,Ka,za,Ya;if(I.outboundVideoRtpId.length>0){const le=[];I.outboundVideoRtpId.forEach(Wl=>{le.push(d.outboundVideoRtp.get(Wl))});const te=this.getWorkingSimulcastVideoStats(le);te.score=dm({frameWidth:te.frameWidth||0,framesPerSecond:te.framesPerSecond||0,jitter:((w=te.remoteData)==null?void 0:w.jitter)||0,isScreenShare:this.screenShareProducers.has(y),packetsSent:(te.packetsSent||0)-((($=this.videoProducerToStatsMap.get(y))==null?void 0:$.packetsSent)||0),packetsLost:(((ye=te.remoteData)==null?void 0:ye.packetsLost)||0)-(((V=(Ie=this.videoProducerToStatsMap.get(y))==null?void 0:Ie.remoteData)==null?void 0:V.packetsLost)||0),framesEncoded:(te.framesEncoded||0)-(((k=this.videoProducerToStatsMap.get(y))==null?void 0:k.framesEncoded)||0)}),v.set(y,{score:+(te.score*10).toFixed(),frameWidth:te.frameWidth||0,frameHeight:te.frameHeight||0,framesPerSecond:te.framesPerSecond||0,jitter:((xe=te.remoteData)==null?void 0:xe.jitter)||0,isScreenShare:this.screenShareProducers.has(y),packetsLostPercentage:gd({packetsSent:(te.packetsSent||0)-(((Fs=this.videoProducerToStatsMap.get(y))==null?void 0:Fs.packetsSent)||0),packetsLost:(((La=te.remoteData)==null?void 0:La.packetsLost)||0)-(((Ua=(xa=this.videoProducerToStatsMap.get(y))==null?void 0:xa.remoteData)==null?void 0:Ua.packetsLost)||0)}),bitrate:((te.bytesSent||0)-((($a=this.videoProducerToStatsMap.get(y))==null?void 0:$a.bytesSent)||0))*8/7,cpuLimitations:te.qualityLimitationReason==="cpu",bandwidthLimitations:te.qualityLimitationReason==="bandwidth"}),this.videoProducerToStatsMap.set(y,te)}else if(I.outboundAudioRtpId.length>0){const le=d.outboundAudioRtp.get(I.outboundAudioRtpId[0]);le.score=cm({packetsSent:(le.packetsSent||0)-(((Fa=this.audioProducerToStatsMap.get(y))==null?void 0:Fa.packetsSent)||0),packetsLost:(((Ba=le.remoteData)==null?void 0:Ba.packetsLost)||0)-(((qa=(Ha=this.audioProducerToStatsMap.get(y))==null?void 0:Ha.remoteData)==null?void 0:qa.packetsLost)||0),jitter:((ja=le.remoteData)==null?void 0:ja.jitter)||0}),v.set(y,{score:+(le.score*10).toFixed(),bitrate:((le.bytesSent||0)-(((Ga=this.audioProducerToStatsMap.get(y))==null?void 0:Ga.bytesSent)||0))*8/7,packetsLostPercentage:gd({packetsSent:(le.packetsSent||0)-(((Wa=this.audioProducerToStatsMap.get(y))==null?void 0:Wa.packetsSent)||0),packetsLost:(((Ja=le.remoteData)==null?void 0:Ja.packetsLost)||0)-(((za=(Ka=this.audioProducerToStatsMap.get(y))==null?void 0:Ka.remoteData)==null?void 0:za.packetsLost)||0)}),jitter:((Ya=le.remoteData)==null?void 0:Ya.jitter)||0,isScreenShare:this.screenShareProducers.has(y)}),this.audioProducerToStatsMap.set(y,le)}}),T.forEach(I=>{const y=p.find($=>$.id===I.localCandidateId?(I.localCandidateId=$.id,$):null),w=g.find($=>$.id===I.remoteCandidateId?(I.remoteCandidateId=$.id,$):null);y&&(I.localCandidateType=y.type,I.localCandidateAddress=Yr(y.address),I.localCandidatePort=y.port,I.localCandidateProtocol=y.protocol,I.localCandidateUrl=y.url,I.localCandidateNetworkType=y.networkType,I.localCandidateRelatedAddress=Yr(y.relatedAddress),I.localCandidateRelatedPort=y.relatedPort),w&&(I.remoteCandidateType=w.type,I.remoteCandidateAddress=Yr(w.address),I.remoteCandidatePort=w.port,I.remoteCandidateProtocol=w.protocol,I.remoteCandidateUrl=w.url)}),d.candidatePair&&(d.transport?(d.transport.totalRoundTripTime=d.candidatePair.totalRoundTripTime,d.transport.availableOutgoingBitrate=d.candidatePair.availableOutgoingBitrate,d.transport.availableIncomingBitrate=d.candidatePair.availableIncomingBitrate,d.transport.roundTripTime=d.candidatePair.currentRoundTripTime):d.transport={bytesReceived:d.candidatePair.bytesReceived,bytesSent:d.candidatePair.bytesSent,totalRoundTripTime:d.candidatePair.totalRoundTripTime,availableOutgoingBitrate:d.candidatePair.availableOutgoingBitrate,availableIncomingBitrate:d.candidatePair.availableIncomingBitrate,roundTripTime:d.candidatePair.currentRoundTripTime}),d.transport&&(d.transport.candidatePairs=T),d.transport&&!d.transport.roundTripTime){let I=0,y=0;d.remoteInboundRtp.forEach((w,$)=>{w.roundTripTime&&w.roundTripTime>I&&(I=w.roundTripTime,y=w.totalRoundTripTime)}),d.transport.roundTripTime=I,d.transport.totalRoundTripTime=y}if(E.size>0)try{this.observer.emit("consumer_score",E)}catch(I){}if(v.size>0)try{this.observer.emit("producer_score",v)}catch(I){}return d}getProducersReport(e){return u(this,null,function*(){const r=e.map(i=>this.generateProducerStreamMap(i,!0));return r.length>0?Promise.all(r):void 0})}getConsumersReport(e){return u(this,null,function*(){const r=e.map(i=>this.generateConsumerStreamMap(i,!0));return r.length>0?Promise.all(r):void 0})}getTransportReport(e){return u(this,null,function*(){return e.getStats()})}getProcessedStats(e,r,i){return u(this,null,function*(){const a=yield this.getTransportReport(e),o={producing:i,consuming:r,id:e.id},c=a,d=this.parseRTCReport(c,["transport","candidate-pair","inbound-rtp","outbound-rtp","remote-inbound-rtp","local-candidate","remote-candidate"],!1,void 0,o);if(!d)return;const l={stats:d.transport,transportId:e.id,consuming:r,producing:i},p=d.staleProducerStreamMap?void 0:this.getProducerStatsFromReport(d),g=d.staleConsumerStreamMap?void 0:this.getConsumerStatsFromReport(d);return{transportReport:l,producerReport:p,consumerReport:g}})}getProducerStatsFromReport(e){const r=[];try{e.producerStreamMap.forEach((i,a)=>{var o,c;r.push({producerId:a,videoStats:i.outboundVideoRtpId.map(d=>e.outboundVideoRtp.get(d)),audioStats:i.outboundAudioRtpId.map(d=>e.outboundAudioRtp.get(d)),appData:((c=(o=this.callStatsInstance.producers)==null?void 0:o.get(a))==null?void 0:c.appData)||null})})}catch(i){this.callStatsInstance.logger.error("callStats::measurements::getProducerStatsFromReport",{error:{reason:i.reason,message:i.message}})}return r}getConsumerStatsFromReport(e){const r=[];try{e.consumerStreamMap.forEach((i,a)=>{const{peerId:o,producerId:c,appData:d}=this.consumerPeerIdMap.get(a);r.push({consumerId:a,peerId:o,producerId:c,appData:d,videoStats:i.inboundVideoRtpId.map(l=>e.inboundVideoRtp.get(l)),audioStats:i.inboundAudioRtpId.map(l=>e.inboundAudioRtp.get(l))})})}catch(i){console.error("getConsumersReport: ",i,e)}return r}getUserLocation(){return u(this,null,function*(){return new Promise((e,r)=>{try{navigator.geolocation?navigator.geolocation.getCurrentPosition(i=>{e(i)}):r()}catch(i){r(i)}})})}getConnectivity(e){return u(this,null,function*(){try{const r={iceServers:e||Qh},i=new Promise((p,g)=>{try{const T=new kv(r);T.addListener("done",p),T.addListener("failed",()=>{p({connectivity:!1})}),T.start(2e3)}catch(T){g(T)}}),a=new Promise((p,g)=>{try{const T=new Av(r);T.addListener("done",p),T.addListener("failed",()=>{p({connectivity:!1})}),T.start(2e3)}catch(T){g(T)}}),o=new Promise((p,g)=>{try{const T=new Iv(r);T.addListener("done",p),T.addListener("failed",()=>{p({connectivity:!1})}),T.start(2e3)}catch(T){g(T)}}),[c,d,l]=yield Promise.all([i,a,o]);return{host:c==null?void 0:c.connectivity,relay:d==null?void 0:d.connectivity,reflexive:l==null?void 0:l.connectivity}}catch(r){return{host:!1,relay:!1,reflexive:!1}}})}getThroughput(e){return u(this,null,function*(){try{const i=yield new Promise((a,o)=>{try{const c={iceServers:e||Qh},d=new bv(c);d.addListener("done",a),d.addListener("failed",o),d.start(1e4)}catch(c){o(c)}});return{throughput:i.throughput,fractionalLoss:0,RTT:i.RTT,jitter:0,backendRTT:i.backendRTT}}catch(r){return}})}getIPDetails(){return u(this,null,function*(){var e,r;try{return this.ipDetails||(this.ipDetails=yield ah.getIPDetails({peerId:(e=this.callStatsInstance)==null?void 0:e.peerId,apiHostnames:(r=this.callStatsInstance)==null?void 0:r.apiHostnames,logger:this.callStatsInstance.logger})),this.ipDetails}catch(i){return}})}getNetworkQuality(e){return u(this,null,function*(){const[r,i]=yield Promise.all([this.getConnectivity(e),this.getThroughput(e)]);return{connectivity:r,throughput:i==null?void 0:i.throughput,fractionalLoss:i==null?void 0:i.fractionalLoss,RTT:i==null?void 0:i.RTT,jitter:i==null?void 0:i.jitter,backendRTT:i==null?void 0:i.backendRTT}})}getNetworkInfo(e,r=!1){return u(this,null,function*(){var c,d;if(r){const l=yield this.getIPDetails();return{ipDetails:l,effectiveNetworkType:(c=navigator.connection)==null?void 0:c.effectiveType,location:l!=null&&l.loc?Xh(l==null?void 0:l.loc):void 0}}const[i,a,o]=yield Promise.all([this.getConnectivity(e),this.getThroughput(e),this.getIPDetails()]);return{ipDetails:o,effectiveNetworkType:(d=navigator.connection)==null?void 0:d.effectiveType,location:o!=null&&o.loc?Xh(o==null?void 0:o.loc):void 0,turnConnectivity:i?i.host||i.relay||i.reflexive:!1,connectivity:i,throughput:a==null?void 0:a.throughput,fractionalLoss:a==null?void 0:a.fractionalLoss,RTT:a==null?void 0:a.RTT,jitter:a==null?void 0:a.jitter,backendRTT:a==null?void 0:a.backendRTT}})}}class Dv extends mm{}class fm extends mm{constructor(){super(...arguments);h(this,"producerMap",new Map);h(this,"consumerMap",new Map)}registerProducer(e){return u(this,null,function*(){this.producerMap.set(e.id,e),yield this.generateProducerStreamMap(e),e.on("close",this.deregisterProducer.bind(this,e)),e.on("pause",this.pauseProducer.bind(this,e.id)),e.on("resume",this.resumeProducer.bind(this,e.id)),e.appData.screenShare===!0&&this.screenShareProducers.add(e.id)})}registerConsumer(e){return u(this,null,function*(){this.consumerMap.set(e.id,e),yield this.generateConsumerStreamMap(e),this.consumerPeerIdMap.set(e.id,{producerId:e.producerId,peerId:e.appData.peerId,appData:e.appData}),e.on("close",this.deregisterConsumer.bind(this,e)),e.on("pause",this.pauseConsumer.bind(this,e.id)),e.on("resume",this.resumeConsumer.bind(this,e.id)),e.appData.screenShare===!0&&this.screenShareConsumers.add(e.id)})}generateConsumerStreamMap(e,r=!1){return u(this,null,function*(){const i=yield e.getStats(),a=this.parseRTCReport(i,["inbound-rtp"],!1,e.id),o=[...a.consumerStreamMap.values()][0],c=r?this.getConsumerStatsFromParsedConsumerStats(a,o,e.id):void 0;for(const d of i.values())switch(d.type){case"inbound-rtp":{this.inboundConsumerMap.set(d.id,e.id);break}}return c})}deregisterProducer(e){this.producerMap.delete(e.id),this.outboundProducerMap.forEach((r,i)=>{r===e.id&&this.outboundProducerMap.delete(i)}),this.pausedProducerMap.delete(e.id),this.screenShareProducers.delete(e.id)}deregisterConsumer(e){this.consumerMap.delete(e.id),this.inboundConsumerMap.forEach((r,i)=>{r===e.id&&this.inboundConsumerMap.delete(i)}),this.consumerPeerIdMap.delete(e.id),this.pausedConsumerMap.delete(e.id),this.screenShareConsumers.delete(e.id)}getIceCandidateStats(e){var r;return{id:e.id,type:e.candidateType||e.type,address:e.address,port:e.port,url:e.url,protocol:(r=e.relayProtocol)!=null?r:e.protocol,networkType:e.networkType,relatedAddress:e.relatedAddress,relatedPort:e.relatedPort}}parseRTCReport(e,r=[],i=!1,a=void 0,o=void 0){var _,C,R,L,F,N,B,j,re,et,os,ri,cs;const c=e,d=new gm,l=r.length?new Set(r):void 0,p=[],g=[],T=[],v=new Map,E=new Map;for(const I of c.values()){if(l){if(l.size===0)break;if(l.has(I.type))i&&l.delete(I.type);else continue}switch(I.type){case"local-candidate":{p.push(this.getIceCandidateStats(I));break}case"remote-candidate":{g.push(this.getIceCandidateStats(I));break}case"candidate-pair":{const{nominated:y}=I,{selected:w}=I,$=I,ye={nominated:y!=null?y:w,currentRoundTripTime:$.currentRoundTripTime,totalRoundTripTime:$.totalRoundTripTime,bytesReceived:$.bytesReceived,bytesSent:$.bytesSent,availableOutgoingBitrate:$.availableOutgoingBitrate,availableIncomingBitrate:$.availableIncomingBitrate,lastPacketReceivedTimestamp:$.lastPacketReceivedTimestamp,lastPacketSentTimestamp:$.lastPacketSentTimestamp,localCandidateId:$.localCandidateId,remoteCandidateId:$.remoteCandidateId,bytesDiscardedOnSend:$.bytesDiscardedOnSend,packetsSent:$.packetsSent,packetsReceived:$.packetsReceived,packetsDiscardedOnSend:$.packetsDiscardedOnSend};T.push(ye),(I.nominated===!0||I.selected===!0)&&(d.candidatePair=ye);break}case"transport":{const y=I;o&&(o.producing&&(this.overallProducingTransportsStatsMap[o.id]||(this.overallProducingTransportsStatsMap[o.id]={totalPacketsSent:0})),o.consuming&&(this.overallConsumingTransportsStatsMap[o.id]||(this.overallConsumingTransportsStatsMap[o.id]={totalPacketsReceived:0})));const w={bytesReceived:y.bytesReceived,bytesSent:y.bytesSent,packetsSent:y.packetsSent,packetsReceived:y.packetsReceived,dtlsCipher:y.dtlsCipher,dtlsState:y.dtlsState,iceRole:y.iceRole};if(d.transport=w,o){if(o.producing){const $=this.overallProducingTransportsStatsMap[o.id];this.processProducingTransportStats(o.id,$,w)}if(o.consuming){const $=this.overallConsumingTransportsStatsMap[o.id];this.processConsumingTransportStats(o.id,$,w)}}break}case"remote-inbound-rtp":{const y=I,w={jitter:y.jitter,fractionLost:y.fractionLost,roundTripTime:y.roundTripTime,roundTripTimeMeasurements:y.roundTripTimeMeasurements,totalRoundTripTime:y.totalRoundTripTime,packetsLost:y.packetsLost};d.remoteInboundRtp.set(y.localId,w);break}case"outbound-rtp":{if(!this.outboundProducerMap.has(I.id))break;const y=I,w=a||this.outboundProducerMap.get(I.id),$=this.pausedProducerMap.get(w);if($){if($.lastReportCalculated===!0)break;this.pausedProducerMap.set(w,{lastReportCalculated:!0})}this.overallProducersStatsMap[w]||(this.overallProducersStatsMap[w]={totalVideoPacketsSent:0,totalAudioPacketsSent:0});const ye=this.overallProducersStatsMap[w];if(["video","audio"].includes(y.mediaType)||["video","audio"].includes(y.kind)){if(!this.outboundProducerMap.has(I.id)){d.staleProducerStreamMap=!0;break}const Ie=this.callStatsInstance.producers.get(w);if(((_=Ie==null?void 0:Ie.track)==null?void 0:_.readyState)==="ended")break;d.producerStreamMap.has(w)||d.producerStreamMap.set(w,{outboundVideoRtpId:[],outboundAudioRtpId:[]});const V={bytesSent:y.bytesSent,packetsSent:y.packetsSent,nackCount:y.nackCount,ssrc:y.ssrc,mid:y.mid,active:y.active,codecId:y.codecId,headerBytesSent:y.headerBytesSent||0,totalPacketSendDelay:y.totalPacketSendDelay||0};if(y.mediaType==="video"||y.kind==="video"){const k=y,xe=D({frameHeight:k.frameHeight,frameWidth:k.frameWidth,framesEncoded:k.framesEncoded,framesDropped:k.framesDropped?k.framesDropped:k.droppedFrames,framesPerSecond:k.framesPerSecond?k.framesPerSecond:k.framerateMean,framesSent:k.framesSent,keyFramesEncoded:k.keyFramesEncoded,firCount:k.firCount,encoderImplementation:k.encoderImplementation,hugeFramesSent:k.hugeFramesSent,pliCount:k.pliCount,qpSum:k.qpSum,qualityLimitationReason:k.qualityLimitationReason,qualityLimitationDurations:k.qualityLimitationDurations,qualityLimitationResolutionChanges:k.qualityLimitationResolutionChanges,totalEncodeTime:k.totalEncodeTime,totalPacketSendDelay:k.totalEncodeTime,retransmittedBytesSent:k.retransmittedBytesSent,retransmittedPacketsSent:k.retransmittedPacketsSent,scalabilityMode:k.scalabilityMode,powerEfficientEncoder:k.powerEfficientEncoder},V);d.outboundVideoRtp.set(I.id,xe),d.producerStreamMap.get(w).outboundVideoRtpId.push(I.id),this.processOutboundProducerVideoStats(w,ye,xe)}else if(y.mediaType==="audio"||y.kind==="audio"){const k=y,xe=D({retransmittedBytesSent:k.retransmittedBytesSent,retransmittedPacketsSent:k.retransmittedPacketsSent},V);d.outboundAudioRtp.set(I.id,xe),d.producerStreamMap.get(w).outboundAudioRtpId.push(I.id),this.processOutboundProducerAudioStats(w,ye,xe)}}else this.callStatsInstance.logger.error(`Callstats: Unknown Outbound-rtp. mediatype: ${y.mediaType} kind: ${y.kind}`);break}case"inbound-rtp":{if(!this.inboundConsumerMap.has(I.id))break;const y=I,w=a||this.inboundConsumerMap.get(I.id),$=this.pausedConsumerMap.get(w);if($){if($.lastReportCalculated===!0)break;this.pausedConsumerMap.set(w,{lastReportCalculated:!0})}if(y.ssrc===1234)break;this.overallConsumersStatsMap[w]||(this.overallConsumersStatsMap[w]={totalVideoPacketsReceived:0,totalAudioPacketsReceived:0});const ye=this.overallConsumersStatsMap[w];if(["video","audio"].includes(y.mediaType)||["video","audio"].includes(y.kind)){if(!this.inboundConsumerMap.has(I.id)){d.staleConsumerStreamMap=!0;break}d.consumerStreamMap.has(w)||d.consumerStreamMap.set(w,{inboundVideoRtpId:[],inboundAudioRtpId:[]});const Ie={bytesReceived:y.bytesReceived,packetsReceived:y.packetsReceived,packetsLost:y.packetsLost>=0?y.packetsLost:0,jitter:y.jitter,nackCount:y.nackCount,jitterBufferDelay:y.jitterBufferDelay,jitterBufferEmittedCount:y.jitterBufferEmittedCount,lastPacketReceivedTimestamp:y.lastPacketReceivedTimestamp,ssrc:y.ssrc,mid:y.mid,codecId:y.codecId,headerBytesReceived:y.headerBytesReceived||0,packetsDiscarded:y.packetsDiscarded||0,jitterBufferMinimumDelay:y.jitterBufferMinimumDelay||0,jitterBufferTargetDelay:y.jitterBufferTargetDelay||0};if(y.mediaType==="video"||y.kind==="video"){const V=y,k=D({frameHeight:V.frameHeight,frameWidth:V.frameWidth,framesDecoded:V.framesDecoded,framesDropped:V.framesDropped?V.framesDropped:V.droppedFrames,framesPerSecond:V.framesPerSecond?V.framesPerSecond:V.framerateMean,framesReceived:V.framesReceived,keyFramesDecoded:V.keyFramesDecoded,firCount:V.firCount,decoderImplementation:V.decoderImplementation,pliCount:V.pliCount,totalProcessingDelay:V.totalProcessingDelay,qpSum:V.qpSum||0,totalAssemblyTime:V.totalAssemblyTime||0,totalDecodeTime:V.totalDecodeTime||0,totalFreezesDuration:V.totalFreezesDuration||0,totalInterFrameDelay:V.totalInterFrameDelay||0,totalPausesDuration:V.totalPausesDuration||0,totalSquaredInterFrameDelay:V.totalSquaredInterFrameDelay||0,freezeCount:V.freezeCount||0,pauseCount:V.pauseCount||0,powerEfficientDecoder:V.powerEfficientDecoder},Ie);k.score=hm({frameWidth:k.frameWidth||0,framesDecoded:(k.framesDecoded||0)-(((C=this.videoConsumerToStatsMap.get(w))==null?void 0:C.framesDecoded)||0),framesPerSecond:k.framesPerSecond||0,packetsLost:(k.packetsLost||0)-(((R=this.videoConsumerToStatsMap.get(w))==null?void 0:R.packetsLost)||0),packetsReceived:(k.packetsReceived||0)-(((L=this.videoConsumerToStatsMap.get(w))==null?void 0:L.packetsReceived)||0),jitter:k.jitter||0,isScreenShare:this.screenShareConsumers.has(w)}),E.set(w,{score:+(k.score*10).toFixed(),frameWidth:k.frameWidth||0,frameHeight:k.frameHeight||0,framesPerSecond:k.framesPerSecond||0,packetsLostPercentage:md({packetsLost:(k.packetsLost||0)-(((F=this.videoConsumerToStatsMap.get(w))==null?void 0:F.packetsLost)||0),packetsReceived:(k.packetsReceived||0)-(((N=this.videoConsumerToStatsMap.get(w))==null?void 0:N.packetsReceived)||0)}),jitter:k.jitter||0,isScreenShare:this.screenShareConsumers.has(w),bitrate:((k.bytesReceived||0)-(((B=this.videoConsumerToStatsMap.get(w))==null?void 0:B.bytesReceived)||0))*8/7}),this.videoConsumerToStatsMap.set(w,k),d.inboundVideoRtp.set(I.id,k),d.consumerStreamMap.get(w).inboundVideoRtpId.push(I.id),this.processInboundConsumerVideoStats(w,ye,k)}else if(y.mediaType==="audio"||y.kind==="audio"){const V=y,k=D({audioLevel:V.audioLevel,concealedSamples:V.concealedSamples,concealmentEvents:V.concealmentEvents,totalAudioEnergy:V.totalAudioEnergy,totalSamplesDuration:V.totalSamplesDuration,totalSamplesReceived:V.totalSamplesReceived,fecPacketsDiscarded:V.fecPacketsDiscarded||0,fecPacketsReceived:V.fecPacketsReceived||0,insertedSamplesForDeceleration:V.insertedSamplesForDeceleration||0,removedSamplesForAcceleration:V.removedSamplesForAcceleration||0,silentConcealedSamples:V.silentConcealedSamples||0,playoutId:V.playoutId},Ie);k.score=um({concealmentEvents:(k.concealmentEvents||0)-(((j=this.audioConsumerToStatsMap.get(w))==null?void 0:j.concealmentEvents)||0),packetsLost:(k.packetsLost||0)-(((re=this.audioConsumerToStatsMap.get(w))==null?void 0:re.packetsLost)||0),packetsReceived:(k.packetsReceived||0)-(((et=this.audioConsumerToStatsMap.get(w))==null?void 0:et.packetsReceived)||0),jitter:k.jitter||0}),E.set(w,{score:+(k.score*10).toFixed(),packetsLostPercentage:md({packetsLost:(k.packetsLost||0)-(((os=this.audioConsumerToStatsMap.get(w))==null?void 0:os.packetsLost)||0),packetsReceived:(k.packetsReceived||0)-(((ri=this.audioConsumerToStatsMap.get(w))==null?void 0:ri.packetsReceived)||0)}),jitter:k.jitter||0,isScreenShare:this.screenShareConsumers.has(w),bitrate:((k.bytesReceived||0)-(((cs=this.audioConsumerToStatsMap.get(w))==null?void 0:cs.bytesReceived)||0))*8/7}),this.audioConsumerToStatsMap.set(w,k),d.inboundAudioRtp.set(I.id,k),d.consumerStreamMap.get(w).inboundAudioRtpId.push(I.id),this.processInboundConsumerAudioStats(w,ye,k)}}else this.callStatsInstance.logger.error(`Callstats: Unknown Inbound-rtp. mediatype: ${y.mediaType} kind: ${y.kind}`);break}}}if(d.producerStreamMap.forEach((I,y)=>{var w,$,ye,Ie,V,k,xe,Fs,La,xa,Ua,$a,Fa,Ba,Ha,qa,ja,Ga,Wa,Ja,Ka,za,Ya;if(I.outboundVideoRtpId.length>0){const le=[];I.outboundVideoRtpId.forEach(Wl=>{le.push(d.outboundVideoRtp.get(Wl))});const te=this.getWorkingSimulcastVideoStats(le);te.score=dm({frameWidth:te.frameWidth||0,framesPerSecond:te.framesPerSecond||0,jitter:((w=te.remoteData)==null?void 0:w.jitter)||0,isScreenShare:this.screenShareProducers.has(y),packetsSent:(te.packetsSent||0)-((($=this.videoProducerToStatsMap.get(y))==null?void 0:$.packetsSent)||0),packetsLost:(((ye=te.remoteData)==null?void 0:ye.packetsLost)||0)-(((V=(Ie=this.videoProducerToStatsMap.get(y))==null?void 0:Ie.remoteData)==null?void 0:V.packetsLost)||0),framesEncoded:(te.framesEncoded||0)-(((k=this.videoProducerToStatsMap.get(y))==null?void 0:k.framesEncoded)||0)}),v.set(y,{score:+(te.score*10).toFixed(),frameWidth:te.frameWidth||0,frameHeight:te.frameHeight||0,framesPerSecond:te.framesPerSecond||0,jitter:((xe=te.remoteData)==null?void 0:xe.jitter)||0,isScreenShare:this.screenShareProducers.has(y),packetsLostPercentage:gd({packetsSent:(te.packetsSent||0)-(((Fs=this.videoProducerToStatsMap.get(y))==null?void 0:Fs.packetsSent)||0),packetsLost:(((La=te.remoteData)==null?void 0:La.packetsLost)||0)-(((Ua=(xa=this.videoProducerToStatsMap.get(y))==null?void 0:xa.remoteData)==null?void 0:Ua.packetsLost)||0)}),bitrate:((te.bytesSent||0)-((($a=this.videoProducerToStatsMap.get(y))==null?void 0:$a.bytesSent)||0))*8/7,cpuLimitations:te.qualityLimitationReason==="cpu",bandwidthLimitations:te.qualityLimitationReason==="bandwidth"}),this.videoProducerToStatsMap.set(y,te)}else if(I.outboundAudioRtpId.length>0){const le=d.outboundAudioRtp.get(I.outboundAudioRtpId[0]);le.score=cm({packetsSent:(le.packetsSent||0)-(((Fa=this.audioProducerToStatsMap.get(y))==null?void 0:Fa.packetsSent)||0),packetsLost:(((Ba=le.remoteData)==null?void 0:Ba.packetsLost)||0)-(((qa=(Ha=this.audioProducerToStatsMap.get(y))==null?void 0:Ha.remoteData)==null?void 0:qa.packetsLost)||0),jitter:((ja=le.remoteData)==null?void 0:ja.jitter)||0}),v.set(y,{score:+(le.score*10).toFixed(),bitrate:((le.bytesSent||0)-(((Ga=this.audioProducerToStatsMap.get(y))==null?void 0:Ga.bytesSent)||0))*8/7,packetsLostPercentage:gd({packetsSent:(le.packetsSent||0)-(((Wa=this.audioProducerToStatsMap.get(y))==null?void 0:Wa.packetsSent)||0),packetsLost:(((Ja=le.remoteData)==null?void 0:Ja.packetsLost)||0)-(((za=(Ka=this.audioProducerToStatsMap.get(y))==null?void 0:Ka.remoteData)==null?void 0:za.packetsLost)||0)}),jitter:((Ya=le.remoteData)==null?void 0:Ya.jitter)||0,isScreenShare:this.screenShareProducers.has(y)}),this.audioProducerToStatsMap.set(y,le)}}),T.forEach(I=>{const y=p.find($=>$.id===I.localCandidateId?(I.localCandidateId=$.id,$):null),w=g.find($=>$.id===I.remoteCandidateId?(I.remoteCandidateId=$.id,$):null);y&&(I.localCandidateType=y.type,I.localCandidateAddress=Yr(y.address),I.localCandidatePort=y.port,I.localCandidateProtocol=y.protocol,I.localCandidateUrl=y.url,I.localCandidateNetworkType=y.networkType,I.localCandidateRelatedAddress=Yr(y.relatedAddress),I.localCandidateRelatedPort=y.relatedPort),w&&(I.remoteCandidateType=w.type,I.remoteCandidateAddress=Yr(w.address),I.remoteCandidatePort=w.port,I.remoteCandidateProtocol=w.protocol,I.remoteCandidateUrl=w.url)}),d.candidatePair&&(d.transport?(d.transport.bytesReceived=d.candidatePair.bytesReceived,d.transport.bytesSent=d.candidatePair.bytesSent,d.transport.totalRoundTripTime=d.candidatePair.totalRoundTripTime,d.transport.availableOutgoingBitrate=d.candidatePair.availableOutgoingBitrate,d.transport.availableIncomingBitrate=d.candidatePair.availableIncomingBitrate,d.transport.roundTripTime=d.candidatePair.currentRoundTripTime):d.transport={bytesReceived:d.candidatePair.bytesReceived,bytesSent:d.candidatePair.bytesSent,totalRoundTripTime:d.candidatePair.totalRoundTripTime,availableOutgoingBitrate:d.candidatePair.availableOutgoingBitrate,availableIncomingBitrate:d.candidatePair.availableIncomingBitrate,roundTripTime:d.candidatePair.currentRoundTripTime}),d.transport&&(d.transport.candidatePairs=T),d.transport&&!d.transport.roundTripTime){let I=0,y=0;d.remoteInboundRtp.forEach((w,$)=>{w.roundTripTime&&w.roundTripTime>I&&(I=w.roundTripTime,y=w.totalRoundTripTime)}),d.transport.roundTripTime=I,d.transport.totalRoundTripTime=y}if(E.size>0)try{this.observer.emit("consumer_score",E)}catch(I){}if(v.size>0)try{this.observer.emit("producer_score",v)}catch(I){}return d}getProducerStatsFromReport(e){const r=[];try{e.producerStreamMap.forEach((i,a)=>{const o=this.producerMap.get(a),c=o.track.getSettings(),d=i.outboundVideoRtpId.map(p=>{const g=e.outboundVideoRtp.get(p);return g.frameHeight||(g.frameHeight=c.height,g.frameWidth=c.width,g.framesPerSecond=c.frameRate),g}),l={producerId:a,appData:o.appData,videoStats:d,audioStats:i.outboundAudioRtpId.map(p=>e.outboundAudioRtp.get(p))};r.push(l)})}catch(i){console.error("getProducersReport: ",i,e)}return r}getConsumerStatsFromParsedConsumerStats(e,r,i){let a;try{const{peerId:o,producerId:c,appData:d}=this.consumerPeerIdMap.get(i),l=r==null?void 0:r.inboundVideoRtpId.map(p=>{const T=this.consumerMap.get(i).track.getSettings(),v=e.inboundVideoRtp.get(p);return v.frameHeight||(v.frameHeight=T.height,v.frameWidth=T.width,v.framesPerSecond=T.frameRate),v});a={consumerId:i,peerId:o,producerId:c,appData:d,videoStats:l,audioStats:r==null?void 0:r.inboundAudioRtpId.map(p=>e.inboundAudioRtp.get(p))}}catch(o){console.error("getConsumerStatsFromParsedConsumerStats: ",o,e)}return a}getConsumerStatsFromReport(e){const r=[];try{e.consumerStreamMap.forEach((i,a)=>{r.push(this.getConsumerStatsFromParsedConsumerStats(e,i,a))})}catch(i){console.error("getConsumerStatsFromReport: ",i,e)}return r}}class Ov extends fm{}function fd(s,t,e,r){if(s!=null&&s.logger&&s.logger.error("Callstats::handleError",{error:r}),typeof e=="function"&&r instanceof t)e.call(null,r,s);else throw r}function Zh(s,t,e){const r=s.value;return s.value=function(...i){try{const a=r.apply(this,i);return a&&a instanceof Promise?a.catch(o=>{fd(this,t,e,o)}):a}catch(a){fd(this,t,e,a)}return null},s}const X=(s,t)=>(e,r,i)=>{const a=i.value;return i.value=function(...o){try{const c=a.apply(this,o);return c&&c instanceof Promise?c.catch(d=>{fd(this,s,t,d)}):c}catch(c){fd(this,s,t,c)}return null},i},Nv=(s,t)=>(e,r,i)=>{if(i)return Zh(i,s,t);for(const a of Reflect.ownKeys(e.prototype).filter(o=>o!=="constructor")){const o=Object.getOwnPropertyDescriptor(e.prototype,a);o.value instanceof Function&&Object.defineProperty(e.prototype,a,Zh(o,s,t))}};var Y=globalThis&&globalThis.__decorate||function(s,t,e,r){var i=arguments.length,a=i<3?t:r===null?r=Object.getOwnPropertyDescriptor(t,e):r,o;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")a=Reflect.decorate(s,t,e,r);else for(var c=s.length-1;c>=0;c--)(o=s[c])&&(a=(i<3?o(a):i>3?o(t,e,a):o(t,e))||a);return i>3&&a&&Object.defineProperty(t,e,a),a};const Q=console;let K=class extends ct{constructor(e="https://api.testingv3.dyte.in",r="Blink",i=uo.PROD,a,o,c,d){super();h(this,"observer");h(this,"eventHandler");h(this,"measurements");h(this,"producingTransport");h(this,"consumingTransport");h(this,"producers",new Map);h(this,"consumers",new Map);h(this,"iceServers");h(this,"connectionInfoPromise");h(this,"pingStatsTimeout");h(this,"logger");h(this,"env");h(this,"apiHostnames");h(this,"peerId");h(this,"consumerSharedMediaStatesMap",new Map);h(this,"currentUserMediaStates",{});switch(this.env=i,this.apiHostnames=d,this.logger=o,this.peerId=c,this.eventHandler=new vv({logger:o,peerId:c,apiHostnames:d}),this.logger.debug("callStats::engineName: ",{engineName:r}),r){case"Blink":this.measurements=new Dv;break;case"Gecko":this.measurements=new fm;break;case"WebKit":this.measurements=new Ov;break;default:throw Error(`Unknown engineName! ${r}`)}this.measurements.callStatsInstance=this,this.registerProducer=this.registerProducer.bind(this),this.registerConsumer=this.registerConsumer.bind(this),this.observer=new ct,this.measurements.observer.on("consumer_score",l=>{o.debug(`callStats::consumer_score ${[...l.entries()]}`),this.eventHandler.emit("consumer_score",l)}),this.measurements.observer.on("producer_score",l=>{o.debug(`callStats::producer_score ${[...l.entries()]}`),this.eventHandler.emit("producer_score",l)})}registerIceServers(e){this.iceServers=e}registerConsumer(e){var r;this.consumerSharedMediaStatesMap.has(e.id)||this.consumerSharedMediaStatesMap.set(e.id,{}),this.consumers.set(e.id,e),this.measurements.registerConsumer(e),this.logger.debug("callStats::registerConsumer",{consumerId:e.id,consumerkind:e.kind,isScreenShare:!!((r=e.appData)!=null&&r.screenShare)}),e.on("close",this.deRegisterConsumer.bind(this,e))}registerProducer(e){var r;this.producers.set(e.id,e),this.measurements.registerProducer(e),this.logger.debug("callStats::registerProducer",{producerId:e.id,producerKind:e.kind,isScreenShare:!!((r=e.appData)!=null&&r.screenShare)}),e.on("close",this.deRegisterProducer.bind(this,e))}sendConsumerSharedMediaStateEvent(e,r){this.consumerSharedMediaStatesMap.has(e)||this.consumerSharedMediaStatesMap.set(e,{});const i=this.consumerSharedMediaStatesMap.get(e);this.consumerSharedMediaStatesMap.set(e,Object.assign(i,r))}registerProducingTransport(e){var i;this.producingTransport=e,e.on("close",this.disconnectProducingTransport.bind(this,e)),e.on("disconnect",this.disconnectProducingTransport.bind(this,e)),Array.from(((i=e._producers)==null?void 0:i.values())||[]).forEach(a=>{this.registerProducer(a)}),e.on("newproducer",this.registerProducer)}registerConsumingTransport(e){var i;this.consumingTransport=e,e.on("close",this.disconnectConsumingTransport.bind(this,e)),e.on("disconnect",this.disconnectConsumingTransport.bind(this,e)),Array.from(((i=e._consumers)==null?void 0:i.values())||[]).forEach(a=>{this.registerConsumer(a)}),e.on("newconsumer",this.registerConsumer)}deRegisterConsumer(e){this.consumers.delete(e.id)}deRegisterProducer(e){var r;this.producers.delete(e.id),this.logger.debug("callStats::deRegisterProducer",{producerId:e.id,producerKind:e.kind,isScreenShare:!!((r=e.appData)!=null&&r.screenShare)})}disconnectConsumingTransport(){this.consumingTransport=void 0}disconnectProducingTransport(){this.producingTransport=void 0}callEvent(e){this.eventHandler.callEvent(e)}sendPreCallTestBeginEvent(e=!1,r){this.connectionInfoPromise=this.measurements.getNetworkInfo(this.iceServers,e),this.eventHandler.callEvent({event:O.PRECALL_TEST_BEGIN,timestamp:r}),this.connectionInfoPromise&&this.connectionInfoPromise.then(i=>{this.eventHandler.callEvent({event:O.PRECALL_TEST_COMPLETE,metaData:{connectionInfo:i},timestamp:r})})}sendScreenShareToggleEvent(e,r=null,i){this.currentUserMediaStates.screen=e,this.eventHandler.callEvent({event:e?O.SCREENSHARE_STARTED:O.SCREENSHARE_STOPPED,metaData:{ssrc:r},timestamp:i})}sendScreenShareRequestedEvent(e){this.eventHandler.callEvent({event:O.SCREENSHARE_START_REQUESTED,timestamp:e})}sendActiveSpeakerEvent(e,r){this.eventHandler.callEvent({event:O.DOMINANT_SPEAKER,metaData:{peerId:e},timestamp:r})}devices(e,r,i){this.eventHandler.callEvent({event:e===Gt.AUDIO&&O.AUDIO_DEVICES_UPDATES||e===Gt.VIDEO&&O.VIDEO_DEVICES_UPDATES||e===Gt.SPEAKER&&O.SPEAKER_DEVICES_UPDATES,metaData:{deviceList:r},timestamp:i})}selectedDevice(e,r,i){this.eventHandler.callEvent({event:e===Gt.AUDIO&&O.SELECTED_MICROHPONE_UPDATE||e===Gt.VIDEO&&O.SELECTED_CAMERA_UPDATE||e===Gt.SPEAKER&&O.SELECTED_SPEAKER_UPDATE,metaData:{device:r},timestamp:i})}mediaPermission(e,r,i){this.eventHandler.callEvent({event:O.MEDIA_PERMISSION,metaData:{deviceType:e,permission:r},timestamp:i})}mediaPlaybackFailed(e,r){this.eventHandler.callEvent({event:e===Gt.AUDIO&&O.AUDIO_PLAY_FAILED||e===Gt.VIDEO&&O.VIDEO_PLAY_FAILED,metaData:{deviceType:e},timestamp:r})}mediaTrackMuted(e,r){this.eventHandler.callEvent({event:e===Gt.AUDIO&&O.AUDIO_TRACK_MUTED||e===Gt.VIDEO&&O.VIDEO_TRACK_MUTED,metaData:{deviceType:e},timestamp:r})}tabChanged(e,r){this.eventHandler.callEvent({event:O.TAB_CHANGE,metaData:{isMeetingsTabActive:e},timestamp:r})}browserBackgrounded(e){this.eventHandler.callEvent({event:O.BROWSER_BACKGROUNDED,timestamp:e})}browserForegrounded(e){this.eventHandler.callEvent({event:O.BROWSER_FOREGROUNDED,timestamp:e})}legacySwitch(e,r){this.eventHandler.callEvent({event:O.LEGACY_SWITCH,metadata:{on:e},timestamp:r})}getPreCallTestResults(){return u(this,null,function*(){return this.connectionInfoPromise})}sendCallJoinBeginEvent(e,r){e=G(D({},e),{meetingEnv:this.env}),e.deviceInfo=G(D({},e.deviceInfo),{userAgent:navigator.userAgent,cpus:navigator.hardwareConcurrency,memory:navigator.deviceMemory}),this.eventHandler.callEvent({event:O.CALL_JOIN_BEGIN,metaData:{peerMetaData:e},timestamp:r})}sendNetworkQualityTestBeginEvent(e,r){this.eventHandler.callEvent({event:O.NET_QUALITY_TEST_BEGIN,timestamp:r}),new Promise((a,o)=>u(this,null,function*(){const c=[];try{for(const d of e)try{if(d.iceServers&&d.iceServers.length>0){const l=yield this.measurements.getNetworkQuality(d.iceServers);c.push(G(D({},d),{networkResults:l}))}}catch(l){console.warn("Error handling ",l)}a({regionData:c})}catch(d){console.warn("Error in callstats, ",d),o(d)}})).then(a=>{this.eventHandler.callEvent({event:O.NET_QUALITY_TEST_END,timestamp:r,metaData:a})})}sendWebSocketConnectedEvent(e){this.eventHandler.callEvent({event:O.WEBSOCKET_CONNECTED,timestamp:e})}sendTransportConnectedEvent(e){this.eventHandler.callEvent({event:O.TRANSPORT_CONNECTED,timestamp:e})}sendAudioToggleEvent(e,r){this.currentUserMediaStates.audio=e;let i;e?i=O.AUDIO_ON:i=O.AUDIO_OFF,this.eventHandler.callEvent({event:i,timestamp:r})}sendVideoToggleEvent(e,r){this.currentUserMediaStates.video=e;let i;e?i=O.VIDEO_ON:i=O.VIDEO_OFF,this.eventHandler.callEvent({event:i,timestamp:r})}sendParticipantRoleToggleEvent(e,r){this.eventHandler.callEvent({event:O.PARTICIPANT_ROLE,timestamp:r,metaData:e})}startPingStats(e=7e3){this.sendPingStatsEvent(!1,new Date),this.pingStatsTimeout=setInterval(this.sendPingStatsEvent.bind(this),e)}stopPingStats(){clearInterval(this.pingStatsTimeout)}sendPingStatsEvent(e=!0,r){return u(this,null,function*(){let i,a;if(this.producingTransport&&(i=yield this.measurements.getProcessedStats(this.producingTransport,!1,!0),!i||!(i!=null&&i.producerReport))){this.logger.debug("callStats::sendPingStatsEvent::staleProducingTransport",{disclaimer:"Stale producer? Regenerating Stream Maps!"});const c=yield this.measurements.getProducersReport([...this.producers.values()]);i&&c?i.producerReport=c:(i=yield this.measurements.getProcessedStats(this.producingTransport,!1,!0),(!i||!(i!=null&&i.producerReport))&&this.logger.debug("callStats::sendPingStatsEvent::noProducingTransportReport",{disclaimer:"Stream maps invalid despite regenerating!"}))}if(this.consumingTransport&&(a=yield this.measurements.getProcessedStats(this.consumingTransport,!0,!1),!a||!a.consumerReport)){this.logger.debug("callStats::sendPingStatsEvent::staleConsumingTransport",{disclaimer:"Stale consumer? Regenerating Stream Maps!"});const c=yield this.measurements.getConsumersReport([...this.consumers.values()]);a&&c?a.consumerReport=c:(a=yield this.measurements.getProcessedStats(this.consumingTransport,!0,!1),(!a||!a.consumerReport)&&this.logger.debug("callStats::sendPingStatsEvent::noConsumingTransportReport",{disclaimer:"Stream maps invalid despite regenerating!"}))}const o={producingTransportStats:i?i==null?void 0:i.transportReport:void 0,consumingTransportStats:a?a==null?void 0:a.transportReport:void 0,producerStats:[].concat((i==null?void 0:i.producerReport)||[]).concat((a==null?void 0:a.producerReport)||[]),consumerStats:[].concat((a==null?void 0:a.consumerReport)||[]).concat((i==null?void 0:i.consumerReport)||[])};if(e&&o.producerStats.length===0&&o.consumerStats.length===0){yield this.eventHandler.flush();return}this.eventHandler.callEvent({event:O.PING_STAT,metaData:o,timestamp:r})})}sendIVSPlayerRebufferEvent(e){this.eventHandler.callEvent({event:O.IVS_PLAYER_REBUFFERING,timestamp:e})}sendIVSPlayerAudioBlockEvent(e){this.eventHandler.callEvent({event:O.IVS_PLAYER_AUDIO_BLOCKED,timestamp:e})}sendIVSPlayerPlaybackBlockedEvent(e){this.eventHandler.callEvent({event:O.IVS_PLAYER_PLAYBACK_BLOCKED,timestamp:e})}sendIVSPlayerNetworkUnavailableEvent(e){this.eventHandler.callEvent({event:O.IVS_PLAYER_NETWORK_UNAVAILABLE,timestamp:e})}sendIVSPlayerInitializedEvent(e){this.eventHandler.callEvent({event:O.IVS_PLAYER_INITIALIZED,timestamp:e})}sendIVSPlayerWorkerErrorEvent(e){this.eventHandler.callEvent({event:O.IVS_PLAYER_WORKER_ERROR,timestamp:e})}sendIVSPlayerErrorEvent(e,r){this.eventHandler.callEvent({event:O.IVS_PLAYER_ERROR,timestamp:r,metaData:e})}sendIVSPlayerRecoverableErrorEvent(e,r){this.eventHandler.callEvent({event:O.IVS_PLAYER_RECOVERABLE_ERROR,timestamp:r,metaData:e})}sendIVSPlayerAnalyticsEvent(e,r){this.eventHandler.callEvent({event:O.IVS_PLAYER_ANALYTICS_EVENT,timestamp:r,metaData:e})}sendIVSPlayerPlaybackRateChangedEvent(e,r){this.eventHandler.callEvent({event:O.IVS_PLAYER_PLAYBACK_RATE_CHANGED,timestamp:r,metaData:{updatedPlaybackRate:e}})}sendIVSPlayerQualityChanged(e,r){this.eventHandler.callEvent({event:O.IVS_PLAYER_QUALITY_CHANGED,timestamp:r,metaData:e})}sendPlayerLiveLatency(e,r){this.eventHandler.callEvent({event:O.LIVESTREAM_LATENCY,timestamp:r,metaData:{latency:e}})}sendDisconnectEvent(e){this.eventHandler.callEvent({event:O.DISCONNECT,timestamp:e})}sendReconnectEvent(e){this.eventHandler.callEvent({event:O.RECONNECT_ATTEMPT,timestamp:e})}expectedVideoResolution(e,r,i){this.eventHandler.callEvent({event:O.EXPECTED_VIDEO_RESOLUTION,timestamp:i,metaData:{frameWidth:e,frameHeight:r}})}expectedScreenshareResolution(e,r,i){this.eventHandler.callEvent({event:O.EXPECTED_SCREENSHARE_RESOLUTION,timestamp:i,metaData:{frameWidth:e,frameHeight:r}})}};Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"registerIceServers",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"registerConsumer",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"registerProducer",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendConsumerSharedMediaStateEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"registerProducingTransport",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"registerConsumingTransport",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"deRegisterConsumer",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"deRegisterProducer",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"disconnectConsumingTransport",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"disconnectProducingTransport",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendPreCallTestBeginEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendScreenShareToggleEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendScreenShareRequestedEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendActiveSpeakerEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"devices",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"selectedDevice",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"mediaPermission",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"mediaPlaybackFailed",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"mediaTrackMuted",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"tabChanged",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"browserBackgrounded",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"browserForegrounded",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"legacySwitch",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"getPreCallTestResults",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendCallJoinBeginEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendNetworkQualityTestBeginEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendWebSocketConnectedEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendTransportConnectedEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendAudioToggleEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendVideoToggleEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendParticipantRoleToggleEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"startPingStats",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"stopPingStats",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendPingStatsEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendIVSPlayerRebufferEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendIVSPlayerAudioBlockEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendIVSPlayerPlaybackBlockedEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendIVSPlayerNetworkUnavailableEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendIVSPlayerInitializedEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendIVSPlayerWorkerErrorEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendIVSPlayerErrorEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendIVSPlayerRecoverableErrorEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendIVSPlayerAnalyticsEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendIVSPlayerPlaybackRateChangedEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendIVSPlayerQualityChanged",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendPlayerLiveLatency",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendDisconnectEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"sendReconnectEvent",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"expectedVideoResolution",null);Y([X(TypeError,(s,t)=>Q.error(t,s))],K.prototype,"expectedScreenshareResolution",null);K=Y([Nv(TypeError,(s,t)=>Q.error(t,s))],K);const Vv=K;class Tm extends ct{constructor(){super(...arguments);h(this,"stats");h(this,"peerId");h(this,"backend");h(this,"iceServers");h(this,"initialized",!1);h(this,"stalled",!1);h(this,"ipInformation");h(this,"logger")}initialize(g){return u(this,arguments,function*({peerId:e,engineName:r,env:i=uo.PROD,iceServers:a,apiBase:o="https://api.cluster.dyte.in",flags:c,logger:d=console,apiHostnames:l,skipConnectivityChecks:p=!1}){var T,v,E;try{this.peerId=e,this.logger=d,this.ipInformation=yield ah.getIPDetails({peerId:e,apiHostnames:l,logger:d}),this.backend=new Vv(o,r,i,c,d,e,l),this.iceServers=a,(T=this.backend)==null||T.registerIceServers(this.iceServers),this.initialized=!0,(E=(v=this.backend)==null?void 0:v.eventHandler)==null||E.emit("initialized",this.ipInformation),this.emit("initialized",this.ipInformation),this.startPreCallTest(p)}catch(_){this.logger.error("callStats::CallStatsIntegration: ",{error:_}),this.stallCallStats()}})}configureSendTransport(e){this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.registerProducingTransport(e)})}configureRecvTransport(e){this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.registerConsumingTransport(e)})}candidateRegionalNetworkQualityTest(e){return u(this,null,function*(){const r=new Date;this.onSafeInitialization(()=>{var i;try{(i=this.backend)==null||i.sendNetworkQualityTestBeginEvent(e,r)}catch(a){this.logger.error("callStats::sendNetworkQualityTestBeginEvent",{error:{reason:a.reason}})}})})}roomJoined(e){return u(this,null,function*(){const r=new Date;this.onSafeInitialization(()=>{var i,a;(i=this.backend)==null||i.sendCallJoinBeginEvent(e,r),this.backend,(a=this.backend)==null||a.startPingStats()})})}audioOff(){const e=new Date;this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.sendAudioToggleEvent(!1,e)})}audioOn(){const e=new Date;this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.sendAudioToggleEvent(!0,e)})}videoOff(){const e=new Date;this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.sendVideoToggleEvent(!1,e)})}videoOn(){const e=new Date;this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.sendVideoToggleEvent(!0,e)})}callEnded(){const e=new Date;this.onSafeInitialization(()=>{var r,i;(r=this.backend)==null||r.stopPingStats(),(i=this.backend)==null||i.sendDisconnectEvent(e)})}screenShareStart(e){const r=new Date;this.onSafeInitialization(()=>{var i;(i=this.backend)==null||i.sendScreenShareToggleEvent(!0,e,r)})}consumerSharedMediaState(e,r){this.onSafeInitialization(()=>{var i;(i=this.backend)==null||i.sendConsumerSharedMediaStateEvent(e,r)})}screenShareStop(e){const r=new Date;this.onSafeInitialization(()=>{var i;(i=this.backend)==null||i.sendScreenShareToggleEvent(!1,e,r)})}screenShareRequested(){const e=new Date;this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.sendScreenShareRequestedEvent(e)})}activeSpeaker(e){if(e!==this.peerId)return;const r=new Date;this.onSafeInitialization(()=>{var i;(i=this.backend)==null||i.sendActiveSpeakerEvent(e,r)})}devices(e,r){const i=new Date;this.onSafeInitialization(()=>{var a;(a=this.backend)==null||a.devices(e,r,i)})}selectedDevice(e,r){const i=new Date;this.onSafeInitialization(()=>{var a;(a=this.backend)==null||a.selectedDevice(e,r,i)})}mediaPermission(e,r){const i=new Date;this.onSafeInitialization(()=>{var a;(a=this.backend)==null||a.mediaPermission(e,r,i)})}mediaPlaybackFailed(e){const r=new Date;this.onSafeInitialization(()=>{var i;(i=this.backend)==null||i.mediaPlaybackFailed(e,r)})}mediaTrackMuted(e){const r=new Date;this.onSafeInitialization(()=>{var i;(i=this.backend)==null||i.mediaTrackMuted(e,r)})}tabChanged(e=!1){const r=new Date;this.onSafeInitialization(()=>{var i;(i=this.backend)==null||i.tabChanged(e,r)})}browserBackgrounded(){const e=new Date;this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.browserBackgrounded(e)})}browserForegrounded(){const e=new Date;this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.browserForegrounded(e)})}legacySwitch(e){const r=new Date;this.onSafeInitialization(()=>{var i;(i=this.backend)==null||i.legacySwitch(e,r)})}startPreCallTest(e=!1){return u(this,null,function*(){const r=new Date;this.onSafeInitialization(()=>{var i;(i=this.backend)==null||i.sendPreCallTestBeginEvent(e,r)})})}onPreCallTestResults(e){return this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.eventHandler.once("precall_end",e)}),e}onReceivingConsumerAudioStatus(e){this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.eventHandler.on("consumer_audio_status",e)})}onReceivingConsumerVideoStatus(e){this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.eventHandler.on("consumer_video_status",e)})}onReceivingProducerAudioStatus(e){this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.eventHandler.on("producer_audio_status",e)})}onReceivingProducerVideoStatus(e){this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.eventHandler.on("producer_video_status",e)})}onReceivingProducingTransportStatus(e){this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.eventHandler.on("producing_transport_status",e)})}onReceivingConsumingTransportStatus(e){this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.eventHandler.on("consuming_transport_status",e)})}onProducerScore(e){this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.eventHandler.on("producer_score",e)})}onConsumerScore(e){this.onSafeInitialization(()=>{var r;(r=this.backend)==null||r.eventHandler.on("consumer_score",e)})}onSafeInitialization(e){if(this.initialized)e(this.ipInformation,!1);else if(!this.stalled){const r=i=>{e(i,!0)};return this.once("initialized",r),r}return()=>{}}removeInitializationListener(e){this.removeListener("initialized",e)}stallCallStats(){this.stalled=!0,this.removeAllListeners("initialized")}ivsPlayerEvent(e,r){const i=new Date;this.onSafeInitialization(()=>{var a,o,c,d,l,p,g,T,v,E,_;switch(e){case"PlayerRebuffering":(a=this.backend)==null||a.sendIVSPlayerRebufferEvent(i);break;case"PlayerAudioBlocked":(o=this.backend)==null||o.sendIVSPlayerAudioBlockEvent(i);break;case"PlayerPlaybackBlocked":(c=this.backend)==null||c.sendIVSPlayerPlaybackBlockedEvent(i);break;case"PlayerNetworkUnavailable":(d=this.backend)==null||d.sendIVSPlayerNetworkUnavailableEvent(i);break;case"PlayerInitialized":(l=this.backend)==null||l.sendIVSPlayerInitializedEvent(i);break;case"PlayerWorkerError":(p=this.backend)==null||p.sendIVSPlayerWorkerErrorEvent(i);break;case"PlayerError":(g=this.backend)==null||g.sendIVSPlayerErrorEvent(r,i);break;case"PlayerRecoverableError":(T=this.backend)==null||T.sendIVSPlayerRecoverableErrorEvent(r,i);break;case"PlayerAnalyticsEvent":(v=this.backend)==null||v.sendIVSPlayerAnalyticsEvent(r,i);break;case"PlayerPlaybackRateChanged":(E=this.backend)==null||E.sendIVSPlayerPlaybackRateChangedEvent(r,i);break;case"PlayerQualityChanged":(_=this.backend)==null||_.sendIVSPlayerQualityChanged(r,i);break}})}livestreamLatency(e){const r=new Date;this.onSafeInitialization(()=>{var i;(i=this.backend)==null||i.sendPlayerLiveLatency(e,r)})}expectedVideoResolution(e,r){const i=new Date;this.onSafeInitialization(()=>{var a;(a=this.backend)==null||a.expectedVideoResolution(e,r,i)})}expectedScreenshareResolution(e,r){const i=new Date;this.onSafeInitialization(()=>{var a;(a=this.backend)==null||a.expectedScreenshareResolution(e,r,i)})}}const Lv=new Tm;Lv.setMaxListeners(30);function xv(){this.__data__=[],this.size=0}function kc(s,t){return s===t||s!==s&&t!==t}function Rl(s,t){for(var e=s.length;e--;)if(kc(s[e][0],t))return e;return-1}var Uv=Array.prototype,$v=Uv.splice;function Fv(s){var t=this.__data__,e=Rl(t,s);if(e<0)return!1;var r=t.length-1;return e==r?t.pop():$v.call(t,e,1),--this.size,!0}function Bv(s){var t=this.__data__,e=Rl(t,s);return e<0?void 0:t[e][1]}function Hv(s){return Rl(this.__data__,s)>-1}function qv(s,t){var e=this.__data__,r=Rl(e,s);return r<0?(++this.size,e.push([s,t])):e[r][1]=t,this}function vr(s){var t=-1,e=s==null?0:s.length;for(this.clear();++t<e;){var r=s[t];this.set(r[0],r[1])}}vr.prototype.clear=xv;vr.prototype.delete=Fv;vr.prototype.get=Bv;vr.prototype.has=Hv;vr.prototype.set=qv;function jv(){this.__data__=new vr,this.size=0}function Gv(s){var t=this.__data__,e=t.delete(s);return this.size=t.size,e}function Wv(s){return this.__data__.get(s)}function Jv(s){return this.__data__.has(s)}var Kv=typeof global=="object"&&global&&global.Object===Object&&global;const vm=Kv;var zv=typeof self=="object"&&self&&self.Object===Object&&self,Yv=vm||zv||Function("return this")();const ws=Yv;var Qv=ws.Symbol;const Us=Qv;var Sm=Object.prototype,Xv=Sm.hasOwnProperty,Zv=Sm.toString,Qa=Us?Us.toStringTag:void 0;function eS(s){var t=Xv.call(s,Qa),e=s[Qa];try{s[Qa]=void 0;var r=!0}catch(a){}var i=Zv.call(s);return r&&(t?s[Qa]=e:delete s[Qa]),i}var tS=Object.prototype,sS=tS.toString;function rS(s){return sS.call(s)}var iS="[object Null]",nS="[object Undefined]",ep=Us?Us.toStringTag:void 0;function nn(s){return s==null?s===void 0?nS:iS:ep&&ep in Object(s)?eS(s):rS(s)}function ns(s){var t=typeof s;return s!=null&&(t=="object"||t=="function")}var aS="[object AsyncFunction]",oS="[object Function]",cS="[object GeneratorFunction]",dS="[object Proxy]";function oh(s){if(!ns(s))return!1;var t=nn(s);return t==oS||t==cS||t==aS||t==dS}var lS=ws["__core-js_shared__"];const zl=lS;var tp=function(){var s=/[^.]+$/.exec(zl&&zl.keys&&zl.keys.IE_PROTO||"");return s?"Symbol(src)_1."+s:""}();function uS(s){return!!tp&&tp in s}var hS=Function.prototype,pS=hS.toString;function an(s){if(s!=null){try{return pS.call(s)}catch(t){}try{return s+""}catch(t){}}return""}var gS=/[\\^$.*+?()[\]{}|]/g,mS=/^\[object .+?Constructor\]$/,fS=Function.prototype,TS=Object.prototype,vS=fS.toString,SS=TS.hasOwnProperty,yS=RegExp("^"+vS.call(SS).replace(gS,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function ES(s){if(!ns(s)||uS(s))return!1;var t=oh(s)?yS:mS;return t.test(an(s))}function PS(s,t){return s==null?void 0:s[t]}function on(s,t){var e=PS(s,t);return ES(e)?e:void 0}var _S=on(ws,"Map");const So=_S;var CS=on(Object,"create");const yo=CS;function wS(){this.__data__=yo?yo(null):{},this.size=0}function RS(s){var t=this.has(s)&&delete this.__data__[s];return this.size-=t?1:0,t}var bS="__lodash_hash_undefined__",kS=Object.prototype,AS=kS.hasOwnProperty;function IS(s){var t=this.__data__;if(yo){var e=t[s];return e===bS?void 0:e}return AS.call(t,s)?t[s]:void 0}var MS=Object.prototype,DS=MS.hasOwnProperty;function OS(s){var t=this.__data__;return yo?t[s]!==void 0:DS.call(t,s)}var NS="__lodash_hash_undefined__";function VS(s,t){var e=this.__data__;return this.size+=this.has(s)?0:1,e[s]=yo&&t===void 0?NS:t,this}function sn(s){var t=-1,e=s==null?0:s.length;for(this.clear();++t<e;){var r=s[t];this.set(r[0],r[1])}}sn.prototype.clear=wS;sn.prototype.delete=RS;sn.prototype.get=IS;sn.prototype.has=OS;sn.prototype.set=VS;function LS(){this.size=0,this.__data__={hash:new sn,map:new(So||vr),string:new sn}}function xS(s){var t=typeof s;return t=="string"||t=="number"||t=="symbol"||t=="boolean"?s!=="__proto__":s===null}function bl(s,t){var e=s.__data__;return xS(t)?e[typeof t=="string"?"string":"hash"]:e.map}function US(s){var t=bl(this,s).delete(s);return this.size-=t?1:0,t}function $S(s){return bl(this,s).get(s)}function FS(s){return bl(this,s).has(s)}function BS(s,t){var e=bl(this,s),r=e.size;return e.set(s,t),this.size+=e.size==r?0:1,this}function Sr(s){var t=-1,e=s==null?0:s.length;for(this.clear();++t<e;){var r=s[t];this.set(r[0],r[1])}}Sr.prototype.clear=LS;Sr.prototype.delete=US;Sr.prototype.get=$S;Sr.prototype.has=FS;Sr.prototype.set=BS;var HS=200;function qS(s,t){var e=this.__data__;if(e instanceof vr){var r=e.__data__;if(!So||r.length<HS-1)return r.push([s,t]),this.size=++e.size,this;e=this.__data__=new Sr(r)}return e.set(s,t),this.size=e.size,this}function Cs(s){var t=this.__data__=new vr(s);this.size=t.size}Cs.prototype.clear=jv;Cs.prototype.delete=Gv;Cs.prototype.get=Wv;Cs.prototype.has=Jv;Cs.prototype.set=qS;function jS(s,t){for(var e=-1,r=s==null?0:s.length;++e<r&&t(s[e],e,s)!==!1;);return s}var GS=function(){try{var s=on(Object,"defineProperty");return s({},"",{}),s}catch(t){}}();const Td=GS;function ch(s,t,e){t=="__proto__"&&Td?Td(s,t,{configurable:!0,enumerable:!0,value:e,writable:!0}):s[t]=e}var WS=Object.prototype,JS=WS.hasOwnProperty;function ym(s,t,e){var r=s[t];(!(JS.call(s,t)&&kc(r,e))||e===void 0&&!(t in s))&&ch(s,t,e)}function Ac(s,t,e,r){var i=!e;e||(e={});for(var a=-1,o=t.length;++a<o;){var c=t[a],d=r?r(e[c],s[c],c,e,s):void 0;d===void 0&&(d=s[c]),i?ch(e,c,d):ym(e,c,d)}return e}function KS(s,t){for(var e=-1,r=Array(s);++e<s;)r[e]=t(e);return r}function $s(s){return s!=null&&typeof s=="object"}var zS="[object Arguments]";function sp(s){return $s(s)&&nn(s)==zS}var Em=Object.prototype,YS=Em.hasOwnProperty,QS=Em.propertyIsEnumerable,XS=sp(function(){return arguments}())?sp:function(s){return $s(s)&&YS.call(s,"callee")&&!QS.call(s,"callee")};const Eo=XS;var ZS=Array.isArray;const Ut=ZS;function ey(){return!1}var Pm=typeof exports=="object"&&exports&&!exports.nodeType&&exports,rp=Pm&&typeof module=="object"&&module&&!module.nodeType&&module,ty=rp&&rp.exports===Pm,ip=ty?ws.Buffer:void 0,sy=ip?ip.isBuffer:void 0,ry=sy||ey;const ba=ry;var iy=9007199254740991,ny=/^(?:0|[1-9]\d*)$/;function dh(s,t){var e=typeof s;return t=t==null?iy:t,!!t&&(e=="number"||e!="symbol"&&ny.test(s))&&s>-1&&s%1==0&&s<t}var ay=9007199254740991;function lh(s){return typeof s=="number"&&s>-1&&s%1==0&&s<=ay}var oy="[object Arguments]",cy="[object Array]",dy="[object Boolean]",ly="[object Date]",uy="[object Error]",hy="[object Function]",py="[object Map]",gy="[object Number]",my="[object Object]",fy="[object RegExp]",Ty="[object Set]",vy="[object String]",Sy="[object WeakMap]",yy="[object ArrayBuffer]",Ey="[object DataView]",Py="[object Float32Array]",_y="[object Float64Array]",Cy="[object Int8Array]",wy="[object Int16Array]",Ry="[object Int32Array]",by="[object Uint8Array]",ky="[object Uint8ClampedArray]",Ay="[object Uint16Array]",Iy="[object Uint32Array]",ve={};ve[Py]=ve[_y]=ve[Cy]=ve[wy]=ve[Ry]=ve[by]=ve[ky]=ve[Ay]=ve[Iy]=!0;ve[oy]=ve[cy]=ve[yy]=ve[dy]=ve[Ey]=ve[ly]=ve[uy]=ve[hy]=ve[py]=ve[gy]=ve[my]=ve[fy]=ve[Ty]=ve[vy]=ve[Sy]=!1;function My(s){return $s(s)&&lh(s.length)&&!!ve[nn(s)]}function uh(s){return function(t){return s(t)}}var _m=typeof exports=="object"&&exports&&!exports.nodeType&&exports,ho=_m&&typeof module=="object"&&module&&!module.nodeType&&module,Dy=ho&&ho.exports===_m,Yl=Dy&&vm.process,Oy=function(){try{var s=ho&&ho.require&&ho.require("util").types;return s||Yl&&Yl.binding&&Yl.binding("util")}catch(t){}}();const ka=Oy;var np=ka&&ka.isTypedArray,Ny=np?uh(np):My;const kl=Ny;var Vy=Object.prototype,Ly=Vy.hasOwnProperty;function Cm(s,t){var e=Ut(s),r=!e&&Eo(s),i=!e&&!r&&ba(s),a=!e&&!r&&!i&&kl(s),o=e||r||i||a,c=o?KS(s.length,String):[],d=c.length;for(var l in s)(t||Ly.call(s,l))&&!(o&&(l=="length"||i&&(l=="offset"||l=="parent")||a&&(l=="buffer"||l=="byteLength"||l=="byteOffset")||dh(l,d)))&&c.push(l);return c}var xy=Object.prototype;function Al(s){var t=s&&s.constructor,e=typeof t=="function"&&t.prototype||xy;return s===e}function wm(s,t){return function(e){return s(t(e))}}var Uy=wm(Object.keys,Object);const $y=Uy;var Fy=Object.prototype,By=Fy.hasOwnProperty;function Rm(s){if(!Al(s))return $y(s);var t=[];for(var e in Object(s))By.call(s,e)&&e!="constructor"&&t.push(e);return t}function Ic(s){return s!=null&&lh(s.length)&&!oh(s)}function Il(s){return Ic(s)?Cm(s):Rm(s)}function Hy(s,t){return s&&Ac(t,Il(t),s)}function qy(s){var t=[];if(s!=null)for(var e in Object(s))t.push(e);return t}var jy=Object.prototype,Gy=jy.hasOwnProperty;function Wy(s){if(!ns(s))return qy(s);var t=Al(s),e=[];for(var r in s)r=="constructor"&&(t||!Gy.call(s,r))||e.push(r);return e}function Mc(s){return Ic(s)?Cm(s,!0):Wy(s)}function Jy(s,t){return s&&Ac(t,Mc(t),s)}var bm=typeof exports=="object"&&exports&&!exports.nodeType&&exports,ap=bm&&typeof module=="object"&&module&&!module.nodeType&&module,Ky=ap&&ap.exports===bm,op=Ky?ws.Buffer:void 0,cp=op?op.allocUnsafe:void 0;function km(s,t){if(t)return s.slice();var e=s.length,r=cp?cp(e):new s.constructor(e);return s.copy(r),r}function Am(s,t){var e=-1,r=s.length;for(t||(t=Array(r));++e<r;)t[e]=s[e];return t}function zy(s,t){for(var e=-1,r=s==null?0:s.length,i=0,a=[];++e<r;){var o=s[e];t(o,e,s)&&(a[i++]=o)}return a}function Im(){return[]}var Yy=Object.prototype,Qy=Yy.propertyIsEnumerable,dp=Object.getOwnPropertySymbols,Xy=dp?function(s){return s==null?[]:(s=Object(s),zy(dp(s),function(t){return Qy.call(s,t)}))}:Im;const hh=Xy;function Zy(s,t){return Ac(s,hh(s),t)}function Mm(s,t){for(var e=-1,r=t.length,i=s.length;++e<r;)s[i+e]=t[e];return s}var eE=wm(Object.getPrototypeOf,Object);const ph=eE;var tE=Object.getOwnPropertySymbols,sE=tE?function(s){for(var t=[];s;)Mm(t,hh(s)),s=ph(s);return t}:Im;const Dm=sE;function rE(s,t){return Ac(s,Dm(s),t)}function Om(s,t,e){var r=t(s);return Ut(s)?r:Mm(r,e(s))}function lu(s){return Om(s,Il,hh)}function iE(s){return Om(s,Mc,Dm)}var nE=on(ws,"DataView");const uu=nE;var aE=on(ws,"Promise");const hu=aE;var oE=on(ws,"Set");const Cn=oE;var cE=on(ws,"WeakMap");const pu=cE;var lp="[object Map]",dE="[object Object]",up="[object Promise]",hp="[object Set]",pp="[object WeakMap]",gp="[object DataView]",lE=an(uu),uE=an(So),hE=an(hu),pE=an(Cn),gE=an(pu),ii=nn;(uu&&ii(new uu(new ArrayBuffer(1)))!=gp||So&&ii(new So)!=lp||hu&&ii(hu.resolve())!=up||Cn&&ii(new Cn)!=hp||pu&&ii(new pu)!=pp)&&(ii=function(s){var t=nn(s),e=t==dE?s.constructor:void 0,r=e?an(e):"";if(r)switch(r){case lE:return gp;case uE:return lp;case hE:return up;case pE:return hp;case gE:return pp}return t});const Aa=ii;var mE=Object.prototype,fE=mE.hasOwnProperty;function TE(s){var t=s.length,e=new s.constructor(t);return t&&typeof s[0]=="string"&&fE.call(s,"index")&&(e.index=s.index,e.input=s.input),e}var vE=ws.Uint8Array;const vd=vE;function gh(s){var t=new s.constructor(s.byteLength);return new vd(t).set(new vd(s)),t}function SE(s,t){var e=t?gh(s.buffer):s.buffer;return new s.constructor(e,s.byteOffset,s.byteLength)}var yE=/\w*$/;function EE(s){var t=new s.constructor(s.source,yE.exec(s));return t.lastIndex=s.lastIndex,t}var mp=Us?Us.prototype:void 0,fp=mp?mp.valueOf:void 0;function PE(s){return fp?Object(fp.call(s)):{}}function Nm(s,t){var e=t?gh(s.buffer):s.buffer;return new s.constructor(e,s.byteOffset,s.length)}var _E="[object Boolean]",CE="[object Date]",wE="[object Map]",RE="[object Number]",bE="[object RegExp]",kE="[object Set]",AE="[object String]",IE="[object Symbol]",ME="[object ArrayBuffer]",DE="[object DataView]",OE="[object Float32Array]",NE="[object Float64Array]",VE="[object Int8Array]",LE="[object Int16Array]",xE="[object Int32Array]",UE="[object Uint8Array]",$E="[object Uint8ClampedArray]",FE="[object Uint16Array]",BE="[object Uint32Array]";function HE(s,t,e){var r=s.constructor;switch(t){case ME:return gh(s);case _E:case CE:return new r(+s);case DE:return SE(s,e);case OE:case NE:case VE:case LE:case xE:case UE:case $E:case FE:case BE:return Nm(s,e);case wE:return new r;case RE:case AE:return new r(s);case bE:return EE(s);case kE:return new r;case IE:return PE(s)}}var Tp=Object.create,qE=function(){function s(){}return function(t){if(!ns(t))return{};if(Tp)return Tp(t);s.prototype=t;var e=new s;return s.prototype=void 0,e}}();const jE=qE;function Vm(s){return typeof s.constructor=="function"&&!Al(s)?jE(ph(s)):{}}var GE="[object Map]";function WE(s){return $s(s)&&Aa(s)==GE}var vp=ka&&ka.isMap,JE=vp?uh(vp):WE;const KE=JE;var zE="[object Set]";function YE(s){return $s(s)&&Aa(s)==zE}var Sp=ka&&ka.isSet,QE=Sp?uh(Sp):YE;const XE=QE;var ZE=1,eP=2,tP=4,Lm="[object Arguments]",sP="[object Array]",rP="[object Boolean]",iP="[object Date]",nP="[object Error]",xm="[object Function]",aP="[object GeneratorFunction]",oP="[object Map]",cP="[object Number]",Um="[object Object]",dP="[object RegExp]",lP="[object Set]",uP="[object String]",hP="[object Symbol]",pP="[object WeakMap]",gP="[object ArrayBuffer]",mP="[object DataView]",fP="[object Float32Array]",TP="[object Float64Array]",vP="[object Int8Array]",SP="[object Int16Array]",yP="[object Int32Array]",EP="[object Uint8Array]",PP="[object Uint8ClampedArray]",_P="[object Uint16Array]",CP="[object Uint32Array]",ge={};ge[Lm]=ge[sP]=ge[gP]=ge[mP]=ge[rP]=ge[iP]=ge[fP]=ge[TP]=ge[vP]=ge[SP]=ge[yP]=ge[oP]=ge[cP]=ge[Um]=ge[dP]=ge[lP]=ge[uP]=ge[hP]=ge[EP]=ge[PP]=ge[_P]=ge[CP]=!0;ge[nP]=ge[xm]=ge[pP]=!1;function ed(s,t,e,r,i,a){var o,c=t&ZE,d=t&eP,l=t&tP;if(e&&(o=i?e(s,r,i,a):e(s)),o!==void 0)return o;if(!ns(s))return s;var p=Ut(s);if(p){if(o=TE(s),!c)return Am(s,o)}else{var g=Aa(s),T=g==xm||g==aP;if(ba(s))return km(s,c);if(g==Um||g==Lm||T&&!i){if(o=d||T?{}:Vm(s),!c)return d?rE(s,Jy(o,s)):Zy(s,Hy(o,s))}else{if(!ge[g])return i?s:{};o=HE(s,g,c)}}a||(a=new Cs);var v=a.get(s);if(v)return v;a.set(s,o),XE(s)?s.forEach(function(C){o.add(ed(C,t,e,C,s,a))}):KE(s)&&s.forEach(function(C,R){o.set(R,ed(C,t,e,R,s,a))});var E=l?d?iE:lu:d?Mc:Il,_=p?void 0:E(s);return jS(_||s,function(C,R){_&&(R=C,C=s[R]),ym(o,R,ed(C,t,e,R,s,a))}),o}var wP=1,RP=4;function mh(s){return ed(s,wP|RP)}var bP="[object Symbol]";function Ml(s){return typeof s=="symbol"||$s(s)&&nn(s)==bP}var kP=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,AP=/^\w*$/;function fh(s,t){if(Ut(s))return!1;var e=typeof s;return e=="number"||e=="symbol"||e=="boolean"||s==null||Ml(s)?!0:AP.test(s)||!kP.test(s)||t!=null&&s in Object(t)}var IP="Expected a function";function Th(s,t){if(typeof s!="function"||t!=null&&typeof t!="function")throw new TypeError(IP);var e=function(){var r=arguments,i=t?t.apply(this,r):r[0],a=e.cache;if(a.has(i))return a.get(i);var o=s.apply(this,r);return e.cache=a.set(i,o)||a,o};return e.cache=new(Th.Cache||Sr),e}Th.Cache=Sr;var MP=500;function DP(s){var t=Th(s,function(r){return e.size===MP&&e.clear(),r}),e=t.cache;return t}var OP=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,NP=/\\(\\)?/g,VP=DP(function(s){var t=[];return s.charCodeAt(0)===46&&t.push(""),s.replace(OP,function(e,r,i,a){t.push(i?a.replace(NP,"$1"):r||e)}),t});const LP=VP;function xP(s,t){for(var e=-1,r=s==null?0:s.length,i=Array(r);++e<r;)i[e]=t(s[e],e,s);return i}var UP=1/0,yp=Us?Us.prototype:void 0,Ep=yp?yp.toString:void 0;function $m(s){if(typeof s=="string")return s;if(Ut(s))return xP(s,$m)+"";if(Ml(s))return Ep?Ep.call(s):"";var t=s+"";return t=="0"&&1/s==-UP?"-0":t}function $P(s){return s==null?"":$m(s)}function Fm(s,t){return Ut(s)?s:fh(s,t)?[s]:LP($P(s))}var FP=1/0;function Dl(s){if(typeof s=="string"||Ml(s))return s;var t=s+"";return t=="0"&&1/s==-FP?"-0":t}function Bm(s,t){t=Fm(t,s);for(var e=0,r=t.length;s!=null&&e<r;)s=s[Dl(t[e++])];return e&&e==r?s:void 0}function BP(s,t,e){var r=s==null?void 0:Bm(s,t);return r===void 0?e:r}function HP(s,t,e){t=Fm(t,s);for(var r=-1,i=t.length,a=!1;++r<i;){var o=Dl(t[r]);if(!(a=s!=null&&e(s,o)))break;s=s[o]}return a||++r!=i?a:(i=s==null?0:s.length,!!i&&lh(i)&&dh(o,i)&&(Ut(s)||Eo(s)))}var qP=Object.defineProperty,jP=(s,t)=>{for(var e in t)qP(s,e,{get:t[e],enumerable:!0})},GP={};jP(GP,{permissions:()=>WP,theme:()=>JP});var pr=(s=>(s.GroupCall="GROUP_CALL",s.Webinar="WEBINAR",s.AudioRoom="AUDIO_ROOM",s.Livestream="LIVESTREAM",s.Chat="CHAT",s))(pr||{}),H=(s=>(s.Allowed="ALLOWED",s.NotAllowed="NOT_ALLOWED",s.CanRequest="CAN_REQUEST",s))(H||{}),WP={view_type:"GROUP_CALL",accept_waiting_requests:!1,accept_present_requests:!1,request_produce:!1,can_allow_participant_audio:!1,can_allow_participant_screensharing:!1,can_allow_participant_video:!1,can_spotlight:!1,request_kick_participant:!1,kick_participant:!1,pin_participant:!1,can_edit_display_name:!1,can_record:!1,can_livestream:!1,can_present:!0,waiting_room_type:"SKIP_ON_ACCEPT",recorder_type:"NONE",plugins:{can_close:!0,can_start:!0},polls:{can_create:!0,can_vote:!0,can_view:!0},produce:{video:{allow:!0,quality:"vga",frame_rate:24},audio:!0,screenshare:{allow:!0,quality:"hd",frame_rate:5}},chat:{public:{can_send:!0,text:!0,files:!0},private:{can_send:!1,can_receive:!1,text:!1,files:!1}},connected_meetings:{can_alter_connected_meetings:!1,can_switch_connected_meetings:!1,can_switch_to_parent_meeting:!1},reactions:!1,hidden_participant:!1,is_recorder:!1,show_participant_list:!0,can_change_participant_role:!1,can_change_theme:!1,max_screenshare_count:1},JP={setup_screen:{is_enabled:!0},alone_here:{is_enabled:!0},waiting_room:{is_enabled:!1,enable_preview:!0},control_bar:{is_enabled:!0,elements:{plugins:!0,screenshare:!0,invite:!0,participants:!0,chat:!0,reactions:!1,polls:!0,fullscreen:!0,layout:!0}},header:{is_enabled:!0,elements:{timer:!0,title:!0,participant_count:!0,change_layout:!0}},pip_mode:!0,auto_tune:!0,grid:{multi:{maxVideoCount:6,videoFit:"cover"},single:{maxVideoCount:6,videoFit:"cover"},defaultView:"multi"},controls:{pip_toggle:!1}},Hm="hXgU8Wc8pwuGNq9ms5q9Hh",Sg;typeof process!="undefined"&&(Sg=process==null?void 0:process.env)!=null&&Sg.FLAGSMITH_ENVIRONMENT_KEY&&(Hm=process.env.FLAGSMITH_ENVIRONMENT_KEY);function KP(s=[]){const t={};return s.forEach(e=>{t[e.feature.name]={enabled:e.enabled,value:e.feature_state_value}}),t}var qm=class{constructor(s=Hm){h(this,"flags",{});h(this,"environmentKey",null);this.environmentKey=s}identifyAndFetchFlagsWithRetry(c){return u(this,arguments,function*({primaryEndpoint:s,secondaryEndpoint:t,forceEvaluate:e,timeout:r,uniqueIdentifier:i,traitsObj:a,logger:o}){const d=JSON.parse(JSON.stringify(a)),l=Object.entries(d).map(g=>({trait_key:g[0],trait_value:g[1]})),p=[s,t,t];for(const g of p)try{const T=new AbortController,v=setTimeout(()=>T.abort(),r),E="_"+(Math.random()+1).toString(36).substring(2),_=yield fetch(`https://${g}/api/v1/identities/`,{method:"POST",headers:{"Content-Type":"application/json","X-Environment-Key":this.environmentKey},body:JSON.stringify({identifier:i+(e?E:""),traits:l}),signal:T.signal});if(clearTimeout(v),!_.ok)throw new Error(`Request failed with status ${_.status}`);const C=yield _.json();return KP(C.flags||[])}catch(T){o.error("Flagsmith identify failed!!",{error:T,url:g})}return{}})}identify(o){return u(this,arguments,function*(s,t={},e=!1,r=5e3,i="edge.api.flagsmith.com",a=console){return this.flags=yield this.identifyAndFetchFlagsWithRetry({traitsObj:t,uniqueIdentifier:s,forceEvaluate:e,timeout:r,primaryEndpoint:i,secondaryEndpoint:"edge.api.flagsmith.com",logger:a}),this.flags})}getValue(s){return this.flags&&this.flags[s]&&this.flags[s].value}hasFeature(s){return this.flags&&this.flags[s]&&this.flags[s].enabled}getAllFlags(){return this.flags}},zP=new qm;function YP(s){return new qm(s)}var jm=[-2,-1,0,1,2],QP=[0,1,2,3,4];function XP(s){s=s.trim();let t="0",e="0",r="0";return s.length==4?(t="0x"+s[1]+s[1],e="0x"+s[2]+s[2],r="0x"+s[3]+s[3]):s.length>6&&(t="0x"+s[1]+s[2],e="0x"+s[3]+s[4],r="0x"+s[5]+s[6]),[+t,+e,+r]}var ZP=(s,t,e)=>{let r,i,a;if(t==0)r=i=a=e;else{const o=(l,p,g)=>(g<0&&(g+=1),g>1&&(g-=1),g<.16666666666666666?l+(p-l)*6*g:g<.5?p:g<.6666666666666666?l+(p-l)*(.6666666666666666-g)*6:l),c=e<.5?e*(1+t):e+t-e*t,d=2*e-c;r=o(d,c,s+1/3),i=o(d,c,s),a=o(d,c,s-1/3)}return[Math.round(r*255),Math.round(i*255),Math.round(a*255)]},e_=(s,t,e)=>{s/=255,t/=255,e/=255;const r=Math.max(s,t,e),i=Math.min(s,t,e);let a,o;const c=(r+i)/2;if(r==i)a=o=0;else{const d=r-i;switch(o=c>.5?d/(2-r-i):d/(r+i),r){case s:a=(t-e)/d+(t<e?6:0);break;case t:a=(e-s)/d+2;break;case e:a=(s-t)/d+4;break}a/=6}return[a,o,c]},t_=(s,t,e)=>{const r=i=>i.toString(16).padStart(2,"0");return`#${r(s)}${r(t)}${r(e)}`},Gm=(s,t=jm,e=.4)=>{const r=[],[i,a,o]=XP(s),[c,d,l]=e_(i,a,o),p=Math.round(l*100);p>70?e=.8:p>60?e=.9:p<10?e=.075:p<42&&(e=.3);const g=t.findIndex(C=>C===0);if(g===-1)throw new Error("Invalid reducer provided, it must contain atleast one zero");const T=5-g,v=g+1,E=(100-p)/T,_=p/v;for(const C of t){let R;C<0?R=p+C*_*e:C>0?R=p+C*E*e:R=p;const[L,F,N]=ZP(c,d,R/100);r.push(t_(L,F,N))}return r},Pp={dark:{background:{1e3:"#252525",900:"#2F2F2F",800:"#323232",700:"#3E3E3E",600:"#4A4A4A"},text:"#F5F5F5","video-bg":"#1C1C1C"},light:{background:{1e3:"#FFFFFF",900:"#F5F5F5",800:"#EBEBEB",700:"#E0E0E0",600:"#D6D6D6"},text:"#111111","text-on-brand":"#ffffff","video-bg":"#DADADA"}},s_=s=>{const[t,e,r,i,a]=Gm(s,jm);return{300:t,400:e,500:r,600:i,700:a}},r_=s=>{if(s==="#FFFFFF")return Pp.light.background;if(s==="#000000")return Pp.dark.background;const[t,e,r,i,a]=Gm(s,QP);return{1e3:t,900:e,800:r,700:i,600:a}},i_={border_radius:"rounded",border_width:"thin",spacing_base:4,theme:"dark",colors:{brand:s_("#2160FD"),background:r_("#141414"),danger:"#FF2D2D",text:"#EEEEEE",text_on_brand:"#EEEEEE",success:"#62A504",video_bg:"#191919",warning:"#FFCD07"}};function Wm(){return mh(i_)}var n_={permissions:{can_accept_production_requests:!1,can_edit_display_name:!0,accept_waiting_requests:!1,disable_participant_audio:!1,disable_participant_screensharing:!1,disable_participant_video:!1,can_spotlight:!1,kick_participant:!1,pin_participant:!1,can_record:!1,can_livestream:!1,waiting_room_type:"SKIP",plugins:{can_close:!0,can_start:!0,can_edit_config:!1,config:{}},polls:{can_create:!0,can_vote:!0,can_view:!0},media:{video:{can_produce:"ALLOWED",can_consume:"ALLOWED"},audio:{can_produce:"ALLOWED"},screenshare:{can_produce:"ALLOWED",can_consume:"ALLOWED"}},chat:{public:{can_send:!0,text:!0,files:!0},private:{can_send:!1,can_receive:!1,text:!1,files:!1},channel:{can_create:"ALL",can_delete:"ALL",can_update:"ALL",can_read_all:!1},message:{can_delete:"ALL",can_edit:"ALL",delete_cutoff_time_seconds:0,edit_cutoff_time_seconds:0}},hidden_participant:!1,is_recorder:!1,recorder_type:"NONE",show_participant_list:!0,transcription_enabled:!1,can_change_participant_permissions:!1,connected_meetings:{can_alter_connected_meetings:!1,can_switch_connected_meetings:!1,can_switch_to_parent_meeting:!1},stage_enabled:!1,stage_access:void 0,accept_stage_requests:!1},ui:{oldTheme:{setup_screen:{is_enabled:!1},alone_here:{is_enabled:!1},waiting_room:{is_enabled:!1,enable_preview:!0},control_bar:{is_enabled:!0,elements:{plugins:!0,screenshare:!0,invite:!1,participants:!0,chat:!0,reactions:!1,polls:!0,fullscreen:!0,layout:!0}},header:{is_enabled:!0,elements:{timer:!0,title:!0,participant_count:!0,change_layout:!0}},pip_mode:!0,auto_tune:!0,colors:{primary:"#2160FD",secondary:"#1A1A1A",text:"#EEEEEE",background:"#1A1A1A",textPrimary:"#EEEEEE",videoBackground:"#1A1A1A"},dimensions:{mode:"fillParent"},grid:{multi:{maxVideoCount:6,videoFit:"cover"},single:{maxVideoCount:6,videoFit:"cover"},defaultView:"MULTI"},controls:{pip_toggle:!1},plugins:[]},design_tokens:Wm(),config_diff:{}},config:{view_type:"GROUP_CALL",media:{audio:{enable_stereo:!1,enable_high_bitrate:!1},video:{quality:"vga",frame_rate:24},screenshare:{quality:"hd",frame_rate:5}},max_video_streams:{mobile:6,desktop:6},max_screenshare_count:1,track_recording:{subscriptions:[]}},version:"hybrid"};function a_(){return mh(n_)}var o_={permissions:{can_accept_production_requests:!1,can_edit_display_name:!0,accept_waiting_requests:!1,disable_participant_audio:!1,disable_participant_screensharing:!1,disable_participant_video:!1,can_spotlight:!1,kick_participant:!1,pin_participant:!1,can_record:!1,can_livestream:!1,waiting_room_type:"SKIP",plugins:{can_close:!0,can_start:!0,can_edit_config:!1,config:{}},polls:{can_create:!0,can_vote:!0,can_view:!0},media:{video:{can_produce:"ALLOWED"},audio:{can_produce:"ALLOWED"},screenshare:{can_produce:"ALLOWED"}},chat:{public:{can_send:!0,text:!0,files:!0},private:{can_send:!1,can_receive:!1,text:!1,files:!1}},hidden_participant:!1,is_recorder:!1,recorder_type:"NONE",show_participant_list:!0,transcription_enabled:!1,can_change_participant_permissions:!1,connected_meetings:{can_alter_connected_meetings:!1,can_switch_connected_meetings:!1,can_switch_to_parent_meeting:!1},stage_enabled:!1,stage_access:void 0,accept_stage_requests:!1},ui:{design_tokens:Wm(),config_diff:{}},config:{view_type:"GROUP_CALL",media:{audio:{enable_stereo:!1,enable_high_bitrate:!1},video:{quality:"vga",frame_rate:24},screenshare:{quality:"hd",frame_rate:5}},max_video_streams:{mobile:6,desktop:6},max_screenshare_count:1,track_recording:{subscriptions:[]}},version:"2.0.0"};function vh(){return mh(o_)}var Co;class Jm{constructor(){m(this,Co,void 0)}get telemetry(){var t;return(t=n(this,Co))==null?void 0:t.getValue("telemetry")}init(t){f(this,Co,t)}info(t,e,r){var i;(i=this.telemetry)==null||i.addLogInCurrentSpan("info",t,e,r)}error(t,e,r){var i;(i=this.telemetry)==null||i.addLogInCurrentSpan("error",t,e,r)}debug(t,e,r){var i;(i=this.telemetry)==null||i.addLogInCurrentSpan("debug",t,e,r)}log(t,e,r){var i;(i=this.telemetry)==null||i.addLogInCurrentSpan("log",t,e,r)}warn(t,e,r){var i;(i=this.telemetry)==null||i.addLogInCurrentSpan("warn",t,e,r)}}Co=new WeakMap;var qs,js;const Fh=class extends ct.EventEmitter{constructor(e){super();m(this,qs,void 0);m(this,js,void 0);h(this,"asyncPromiseTimeout");h(this,"logger");this.logger=e,f(this,qs,new Map),f(this,js,new Map),this.asyncPromiseTimeout=8e3}emitAsync(e,...r){return u(this,null,function*(){n(this,qs).set(e,[]);const i=n(this,js).get(e).map(()=>new Promise(a=>{n(this,qs).get(e).push(a)}));Wh(Fh.prototype,this,"emit").call(this,e,...r),yield Promise.race([Promise.all(i),new Promise((a,o)=>setTimeout(()=>o(new Error(`emitAsync failed to resolve for event ${e}.`)),this.asyncPromiseTimeout))]),n(this,qs).delete(e)})}onAsync(e,r){const i=n(this,qs),a=(...o)=>u(this,null,function*(){var d;try{yield r(...o)}catch(l){this.logger.error("[onAsync]",{error:l})}const c=(d=i.get(e))==null?void 0:d.shift();c==null||c()});return n(this,js).get(e)||n(this,js).set(e,[]),n(this,js).get(e).push(a),super.on(e,a)}reset(){f(this,qs,new Map),f(this,js,new Map),super.removeAllListeners()}};let gu=Fh;qs=new WeakMap,js=new WeakMap;var c_=/\s/;function d_(s){for(var t=s.length;t--&&c_.test(s.charAt(t)););return t}var l_=/^\s+/;function u_(s){return s&&s.slice(0,d_(s)+1).replace(l_,"")}var _p=0/0,h_=/^[-+]0x[0-9a-f]+$/i,p_=/^0b[01]+$/i,g_=/^0o[0-7]+$/i,m_=parseInt;function Cp(s){if(typeof s=="number")return s;if(Ml(s))return _p;if(ns(s)){var t=typeof s.valueOf=="function"?s.valueOf():s;s=ns(t)?t+"":t}if(typeof s!="string")return s===0?s:+s;s=u_(s);var e=p_.test(s);return e||g_.test(s)?m_(s.slice(2),e?2:8):h_.test(s)?_p:+s}function Sh(s){return s}function f_(s,t,e){switch(e.length){case 0:return s.call(t);case 1:return s.call(t,e[0]);case 2:return s.call(t,e[0],e[1]);case 3:return s.call(t,e[0],e[1],e[2])}return s.apply(t,e)}function T_(){}var v_=800,S_=16,y_=Date.now;function E_(s){var t=0,e=0;return function(){var r=y_(),i=S_-(r-e);if(e=r,i>0){if(++t>=v_)return arguments[0]}else t=0;return s.apply(void 0,arguments)}}function P_(s){return function(){return s}}var __=Td?function(s,t){return Td(s,"toString",{configurable:!0,enumerable:!1,value:P_(t),writable:!0})}:Sh;const C_=__;var w_=E_(C_);const R_=w_;function b_(s,t,e,r){for(var i=s.length,a=e+(r?1:-1);r?a--:++a<i;)if(t(s[a],a,s))return a;return-1}function k_(s){return s!==s}function A_(s,t,e){for(var r=e-1,i=s.length;++r<i;)if(s[r]===t)return r;return-1}function I_(s,t,e){return t===t?A_(s,t,e):b_(s,k_,e)}function M_(s,t){var e=s==null?0:s.length;return!!e&&I_(s,t,0)>-1}var wp=Math.max;function D_(s,t,e){return t=wp(t===void 0?s.length-1:t,0),function(){for(var r=arguments,i=-1,a=wp(r.length-t,0),o=Array(a);++i<a;)o[i]=r[t+i];i=-1;for(var c=Array(t+1);++i<t;)c[i]=r[i];return c[t]=e(o),f_(s,this,c)}}function O_(s,t){return R_(D_(s,t,Sh),s+"")}function N_(s,t,e){if(!ns(e))return!1;var r=typeof t;return(r=="number"?Ic(e)&&dh(t,e.length):r=="string"&&t in e)?kc(e[t],s):!1}function V_(s){return O_(function(t,e){var r=-1,i=e.length,a=i>1?e[i-1]:void 0,o=i>2?e[2]:void 0;for(a=s.length>3&&typeof a=="function"?(i--,a):void 0,o&&N_(e[0],e[1],o)&&(a=i<3?void 0:a,i=1),t=Object(t);++r<i;){var c=e[r];c&&s(t,c,r,a)}return t})}var L_="[object Object]",x_=Function.prototype,U_=Object.prototype,Km=x_.toString,$_=U_.hasOwnProperty,F_=Km.call(Object);function B_(s){if(!$s(s)||nn(s)!=L_)return!1;var t=ph(s);if(t===null)return!0;var e=$_.call(t,"constructor")&&t.constructor;return typeof e=="function"&&e instanceof e&&Km.call(e)==F_}var H_="__lodash_hash_undefined__";function q_(s){return this.__data__.set(s,H_),this}function j_(s){return this.__data__.has(s)}function Po(s){var t=-1,e=s==null?0:s.length;for(this.__data__=new Sr;++t<e;)this.add(s[t])}Po.prototype.add=Po.prototype.push=q_;Po.prototype.has=j_;function G_(s,t){for(var e=-1,r=s==null?0:s.length;++e<r;)if(t(s[e],e,s))return!0;return!1}function zm(s,t){return s.has(t)}var W_=1,J_=2;function Ym(s,t,e,r,i,a){var o=e&W_,c=s.length,d=t.length;if(c!=d&&!(o&&d>c))return!1;var l=a.get(s),p=a.get(t);if(l&&p)return l==t&&p==s;var g=-1,T=!0,v=e&J_?new Po:void 0;for(a.set(s,t),a.set(t,s);++g<c;){var E=s[g],_=t[g];if(r)var C=o?r(_,E,g,t,s,a):r(E,_,g,s,t,a);if(C!==void 0){if(C)continue;T=!1;break}if(v){if(!G_(t,function(R,L){if(!zm(v,L)&&(E===R||i(E,R,e,r,a)))return v.push(L)})){T=!1;break}}else if(!(E===_||i(E,_,e,r,a))){T=!1;break}}return a.delete(s),a.delete(t),T}function K_(s){var t=-1,e=Array(s.size);return s.forEach(function(r,i){e[++t]=[i,r]}),e}function yh(s){var t=-1,e=Array(s.size);return s.forEach(function(r){e[++t]=r}),e}var z_=1,Y_=2,Q_="[object Boolean]",X_="[object Date]",Z_="[object Error]",eC="[object Map]",tC="[object Number]",sC="[object RegExp]",rC="[object Set]",iC="[object String]",nC="[object Symbol]",aC="[object ArrayBuffer]",oC="[object DataView]",Rp=Us?Us.prototype:void 0,Ql=Rp?Rp.valueOf:void 0;function cC(s,t,e,r,i,a,o){switch(e){case oC:if(s.byteLength!=t.byteLength||s.byteOffset!=t.byteOffset)return!1;s=s.buffer,t=t.buffer;case aC:return!(s.byteLength!=t.byteLength||!a(new vd(s),new vd(t)));case Q_:case X_:case tC:return kc(+s,+t);case Z_:return s.name==t.name&&s.message==t.message;case sC:case iC:return s==t+"";case eC:var c=K_;case rC:var d=r&z_;if(c||(c=yh),s.size!=t.size&&!d)return!1;var l=o.get(s);if(l)return l==t;r|=Y_,o.set(s,t);var p=Ym(c(s),c(t),r,i,a,o);return o.delete(s),p;case nC:if(Ql)return Ql.call(s)==Ql.call(t)}return!1}var dC=1,lC=Object.prototype,uC=lC.hasOwnProperty;function hC(s,t,e,r,i,a){var o=e&dC,c=lu(s),d=c.length,l=lu(t),p=l.length;if(d!=p&&!o)return!1;for(var g=d;g--;){var T=c[g];if(!(o?T in t:uC.call(t,T)))return!1}var v=a.get(s),E=a.get(t);if(v&&E)return v==t&&E==s;var _=!0;a.set(s,t),a.set(t,s);for(var C=o;++g<d;){T=c[g];var R=s[T],L=t[T];if(r)var F=o?r(L,R,T,t,s,a):r(R,L,T,s,t,a);if(!(F===void 0?R===L||i(R,L,e,r,a):F)){_=!1;break}C||(C=T=="constructor")}if(_&&!C){var N=s.constructor,B=t.constructor;N!=B&&"constructor"in s&&"constructor"in t&&!(typeof N=="function"&&N instanceof N&&typeof B=="function"&&B instanceof B)&&(_=!1)}return a.delete(s),a.delete(t),_}var pC=1,bp="[object Arguments]",kp="[object Array]",Hc="[object Object]",gC=Object.prototype,Ap=gC.hasOwnProperty;function mC(s,t,e,r,i,a){var o=Ut(s),c=Ut(t),d=o?kp:Aa(s),l=c?kp:Aa(t);d=d==bp?Hc:d,l=l==bp?Hc:l;var p=d==Hc,g=l==Hc,T=d==l;if(T&&ba(s)){if(!ba(t))return!1;o=!0,p=!1}if(T&&!p)return a||(a=new Cs),o||kl(s)?Ym(s,t,e,r,i,a):cC(s,t,d,e,r,i,a);if(!(e&pC)){var v=p&&Ap.call(s,"__wrapped__"),E=g&&Ap.call(t,"__wrapped__");if(v||E){var _=v?s.value():s,C=E?t.value():t;return a||(a=new Cs),i(_,C,e,r,a)}}return T?(a||(a=new Cs),hC(s,t,e,r,i,a)):!1}function Ol(s,t,e,r,i){return s===t?!0:s==null||t==null||!$s(s)&&!$s(t)?s!==s&&t!==t:mC(s,t,e,r,Ol,i)}var fC=1,TC=2;function vC(s,t,e,r){var i=e.length,a=i,o=!r;if(s==null)return!a;for(s=Object(s);i--;){var c=e[i];if(o&&c[2]?c[1]!==s[c[0]]:!(c[0]in s))return!1}for(;++i<a;){c=e[i];var d=c[0],l=s[d],p=c[1];if(o&&c[2]){if(l===void 0&&!(d in s))return!1}else{var g=new Cs;if(r)var T=r(l,p,d,s,t,g);if(!(T===void 0?Ol(p,l,fC|TC,r,g):T))return!1}}return!0}function Qm(s){return s===s&&!ns(s)}function SC(s){for(var t=Il(s),e=t.length;e--;){var r=t[e],i=s[r];t[e]=[r,i,Qm(i)]}return t}function Xm(s,t){return function(e){return e==null?!1:e[s]===t&&(t!==void 0||s in Object(e))}}function yC(s){var t=SC(s);return t.length==1&&t[0][2]?Xm(t[0][0],t[0][1]):function(e){return e===s||vC(e,s,t)}}function EC(s,t){return s!=null&&t in Object(s)}function PC(s,t){return s!=null&&HP(s,t,EC)}var _C=1,CC=2;function wC(s,t){return fh(s)&&Qm(t)?Xm(Dl(s),t):function(e){var r=BP(e,s);return r===void 0&&r===t?PC(e,s):Ol(t,r,_C|CC)}}function RC(s){return function(t){return t==null?void 0:t[s]}}function bC(s){return function(t){return Bm(t,s)}}function kC(s){return fh(s)?RC(Dl(s)):bC(s)}function AC(s){return typeof s=="function"?s:s==null?Sh:typeof s=="object"?Ut(s)?wC(s[0],s[1]):yC(s):kC(s)}function IC(s){return function(t,e,r){for(var i=-1,a=Object(t),o=r(t),c=o.length;c--;){var d=o[s?c:++i];if(e(a[d],d,a)===!1)break}return t}}var MC=IC();const DC=MC;var OC=function(){return ws.Date.now()};const Xl=OC;var NC="Expected a function",VC=Math.max,LC=Math.min;function Eh(s,t,e){var r,i,a,o,c,d,l=0,p=!1,g=!1,T=!0;if(typeof s!="function")throw new TypeError(NC);t=Cp(t)||0,ns(e)&&(p=!!e.leading,g="maxWait"in e,a=g?VC(Cp(e.maxWait)||0,t):a,T="trailing"in e?!!e.trailing:T);function v(j){var re=r,et=i;return r=i=void 0,l=j,o=s.apply(et,re),o}function E(j){return l=j,c=setTimeout(R,t),p?v(j):o}function _(j){var re=j-d,et=j-l,os=t-re;return g?LC(os,a-et):os}function C(j){var re=j-d,et=j-l;return d===void 0||re>=t||re<0||g&&et>=a}function R(){var j=Xl();if(C(j))return L(j);c=setTimeout(R,_(j))}function L(j){return c=void 0,T&&r?v(j):(r=i=void 0,o)}function F(){c!==void 0&&clearTimeout(c),l=0,r=d=i=c=void 0}function N(){return c===void 0?o:L(Xl())}function B(){var j=Xl(),re=C(j);if(r=arguments,i=this,d=j,re){if(c===void 0)return E(d);if(g)return clearTimeout(c),c=setTimeout(R,t),v(d)}return c===void 0&&(c=setTimeout(R,t)),o}return B.cancel=F,B.flush=N,B}function mu(s,t,e){(e!==void 0&&!kc(s[t],e)||e===void 0&&!(t in s))&&ch(s,t,e)}function xC(s){return $s(s)&&Ic(s)}function fu(s,t){if(!(t==="constructor"&&typeof s[t]=="function")&&t!="__proto__")return s[t]}function UC(s){return Ac(s,Mc(s))}function $C(s,t,e,r,i,a,o){var c=fu(s,e),d=fu(t,e),l=o.get(d);if(l){mu(s,e,l);return}var p=a?a(c,d,e+"",s,t,o):void 0,g=p===void 0;if(g){var T=Ut(d),v=!T&&ba(d),E=!T&&!v&&kl(d);p=d,T||v||E?Ut(c)?p=c:xC(c)?p=Am(c):v?(g=!1,p=km(d,!0)):E?(g=!1,p=Nm(d,!0)):p=[]:B_(d)||Eo(d)?(p=c,Eo(c)?p=UC(c):(!ns(c)||oh(c))&&(p=Vm(d))):g=!1}g&&(o.set(d,p),i(p,d,r,a,o),o.delete(d)),mu(s,e,p)}function Zm(s,t,e,r,i){s!==t&&DC(t,function(a,o){if(i||(i=new Cs),ns(a))$C(s,t,o,e,Zm,r,i);else{var c=r?r(fu(s,o),a,o+"",s,t,i):void 0;c===void 0&&(c=a),mu(s,o,c)}},Mc)}function FC(s,t,e){for(var r=-1,i=s==null?0:s.length;++r<i;)if(e(t,s[r]))return!0;return!1}var BC="[object Map]",HC="[object Set]",qC=Object.prototype,jC=qC.hasOwnProperty;function GC(s){if(s==null)return!0;if(Ic(s)&&(Ut(s)||typeof s=="string"||typeof s.splice=="function"||ba(s)||kl(s)||Eo(s)))return!s.length;var t=Aa(s);if(t==BC||t==HC)return!s.size;if(Al(s))return!Rm(s).length;for(var e in s)if(jC.call(s,e))return!1;return!0}function WC(s,t){return Ol(s,t)}var JC=V_(function(s,t,e){Zm(s,t,e)});const Cr=JC;var KC=1/0,zC=Cn&&1/yh(new Cn([,-0]))[1]==KC?function(s){return new Cn(s)}:T_;const YC=zC;var QC=200;function ef(s,t,e){var r=-1,i=M_,a=s.length,o=!0,c=[],d=c;if(e)o=!1,i=FC;else if(a>=QC){var l=t?null:YC(s);if(l)return yh(l);o=!1,i=zm,d=new Po}else d=t?[]:c;e:for(;++r<a;){var p=s[r],g=t?t(p):p;if(p=e||p!==0?p:0,o&&g===g){for(var T=d.length;T--;)if(d[T]===g)continue e;t&&d.push(g),c.push(p)}else i(d,g,e)||(d!==c&&d.push(g),c.push(p))}return c}function XC(s){return s&&s.length?ef(s):[]}function ZC(s,t){return s&&s.length?ef(s,AC(t)):[]}var Tu=(s=>(s.PARTICIPANT="PARTICIPANT",s.PEER="PEER",s.CLIENT="CLIENT",s))(Tu||{});const Z={PROPAGATE_KICK_ALL:"propagate_kick_across_rooms",REFRESH_ID_ON_DISCONNECTION:"refresh_id_on_disconnection",SKIP_OTEL_TRACES:"skip_otel_traces",ENABLE_CF_SIMULCAST:"enable_cf_simulcast",CF_TRANSPORT_FORCE_RELAY_ON_ICE_FAILED:"cf_transport_force_relay_on_ice_failed",LOG_LEVEL:"log_level",V1_PLUGINS:"v1_plugins",LIVESTREAM:"feat_livestream",VAL_MIN_FRAMERATE:"val_min_framerate",SCREEENSHARE_ERR_HACK:"screenshare_err_hack",SCREEENSHARE_CONSTRAINTS_RETRY:"screenshare_constraints_retry",VIDEO_CONSTRAINTS:"video_constraints",SCREENSHARE_CONSTRAINTS:"screenshare_constraints",OBS_QUALITY:"obs_quality",ALLOW_SAFARI_MEDIA_MIDDLEWARES:"allow_safari_media_middlewares",EXP_RESHARE:"exp_reshare",SKIP_SETTING_IN_USE_DEVICE:"skip_setting_in_use_device",PRECALL_BANDWIDTH_TEST:"precall_bandwidth_test",DEBUG_SOCKET_JOIN:"debug_socket_join",FORCE_RELAY:"force_relay",FORCE_VIDEO_CODEC:"force_video_codec",TRACK_HINT:"track_hint",OVERRIDE_SIMULCAST_DYNAMIC:"override_simulcast_dynamic",PRECREATE_PRODUCERS:"precreate_producers",DISABLE_OPUS_DTX_CF:"disable_opus_dtx_cf",ENABLE_AUDIO_ACTIVITY_DEBUG_LOGS:"enable_audio_activity_debug_logs",DISABLE_LAYER_SWITCH:"disable_layer_switch"};function td(s){const t={};return typeof(s==null?void 0:s.code)=="number"&&(t.code=s.code),typeof(s==null?void 0:s.code)=="string"&&(t.code=s.code.substring(0,100)),typeof(s==null?void 0:s.name)=="string"&&(t.name=s.name.substring(0,500)),typeof(s==null?void 0:s.message)=="string"&&(t.message=s.message.substring(0,500)),typeof(s==null?void 0:s.reason)=="string"&&(t.reason=s.reason.substring(0,500)),typeof(s==null?void 0:s.stack)=="string"&&(t.stack=s.stack.substring(0,500)),t}const ew={audio:!0,video:!0,screenshareAudio:!0,screenshareVideo:!0},Xa={baseURL:"http://localhost:5000",createdAt:"2021-08-05T10:49:56.602Z",description:"Develop plugins locally",id:"09259e3b-7be8-46f6-9801-106bf1866e1c",name:"Localhost Dev",organizationId:"4ad15a19-80e2-4105-bf43-48039fd2963e",picture:"https://dyte-uploads.s3.ap-south-1.amazonaws.com/dyte.png",private:!1,published:!0,staggered:!1,tags:["#localhost","#dev"],type:"self_hosted",updatedAt:"2021-08-05T10:50:07.681Z"},tw={pip:!0,poll:!0,chat:!0,stage:!0,theme:!0,plugin:!0,tracing:!0,internals:!0,recording:!0,livestream:!0,participant:!0,connectedMeetings:!0,devTools:{logs:!1}};function Ia(s,t){const e=s.getValue("overrides");return e&&e[t]?e[t]:!1}function sw({baseURI:s}){return s.includes("preprod.dyte")||s.includes("preprod.realtime")?uo.PREPROD:s.includes("devel.dyte")||s.includes("devel.realtime")?uo.DEVEL:uo.PROD}function Zi({servicePrefix:s,baseURI:t}){return`${s}.${t}`}function tf(s){const t=s.getValue("baseURI");return{location:Zi({servicePrefix:"location",baseURI:t}),locationLegacy:Zi({servicePrefix:"location-legacy",baseURI:t}),daCollector:Zi({servicePrefix:"da-collector",baseURI:t.replace("realtime.cloudflare.com","dyte.io")})}}const rw='<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="m16.242 2.932 4.826 4.826a2.75 2.75 0 0 1-.715 4.404l-4.87 2.435a.75.75 0 0 0-.374.426l-1.44 4.166a1.25 1.25 0 0 1-2.065.476L8.5 16.561 4.06 21H3v-1.06l4.44-4.44-3.105-3.104a1.25 1.25 0 0 1 .476-2.066l4.166-1.44a.75.75 0 0 0 .426-.373l2.435-4.87a2.75 2.75 0 0 1 4.405-.715Zm3.766 5.886-4.826-4.826a1.25 1.25 0 0 0-2.002.325l-2.435 4.871a2.25 2.25 0 0 1-1.278 1.12l-3.789 1.31 6.705 6.704 1.308-3.789a2.25 2.25 0 0 1 1.12-1.277l4.872-2.436a1.25 1.25 0 0 0 .325-2.002Z" fill="currentColor"/></svg>',iw='<svg viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"><path d="M4 12.02c0 1.06.2 2.1.6 3.08l.6 1.42c.22.55.64 1.01 1.17 1.29.27.14.56.21.86.21h2.55c.77 0 1.49-.41 1.87-1.08.5-.87 1.02-1.7 1.72-2.43l1.32-1.39c.44-.46.97-.84 1.49-1.23l.59-.45a.6.6 0 0 0 .23-.47c0-.75-.54-1.57-1.22-1.79a3.34 3.34 0 0 0-2.78.29V4.5a1.5 1.5 0 0 0-2.05-1.4 1.5 1.5 0 0 0-2.9 0A1.5 1.5 0 0 0 6 4.5v.09A1.5 1.5 0 0 0 4 6v6.02ZM8 4.5v4a.5.5 0 0 0 1 0v-5a.5.5 0 0 1 1 0v5a.5.5 0 0 0 1 0v-4a.5.5 0 0 1 1 0v6a.5.5 0 0 0 .85.37h.01c.22-.22.44-.44.72-.58.7-.35 2.22-.57 2.4.5l-.53.4c-.52.4-1.04.78-1.48 1.24l-1.33 1.38c-.75.79-1.31 1.7-1.85 2.63-.21.36-.6.58-1.01.58H7.23a.87.87 0 0 1-.4-.1 1.55 1.55 0 0 1-.71-.78l-.59-1.42a7.09 7.09 0 0 1-.53-2.7V6a.5.5 0 0 1 1 0v3.5a.5.5 0 0 0 1 0v-5a.5.5 0 0 1 1 0Z" fill="currentColor"></path></svg>',qc=s=>{if(!s)return;if(!s.startsWith("<svg"))return new Promise(a=>{a(s)});const e=new Blob([s],{type:"image/svg+xml"}),r=new Image,i=window.URL.createObjectURL(e);return new Promise((a,o)=>{r.onload=()=>{a(r),window.URL.revokeObjectURL(i)},r.onerror=()=>{o(),window.URL.revokeObjectURL(i)},r.src=i})},ui={logs:"https://api-silos.dyte.io/otel/logs",mock:{url:"https://mock.dyte.io",domain:"mock.dyte.io",app:"https://app.dyte.io/v2/meeting",stagingApp:"https://app.devel.dyte.io/v2/meeting"},apiBase:{prod:"https://api.dyte.io",staging:"https://api.devel.dyte.io",prodAlternate:"https://api.cluster.dyte.in"},baseURI:{prod:"dyte.io",staging:"devel.dyte.io"}};function nw(s){var r,i,a;const t=typeof navigator!="undefined"&&!navigator.isReactNative&&typeof window!="undefined"&&((r=window.location.host)==null?void 0:r.includes(ui.baseURI.staging)),e=!!((a=(i=s==null?void 0:s.getValue("modules"))==null?void 0:i.devTools)!=null&&a.logs);return t||e}function aw(s,t){var e;if(s!=null&&s.getValue("flagsmith").hasFeature(Z.LOG_LEVEL)){let r=((e=s.getValue("flagsmith").getValue(Z.LOG_LEVEL))==null?void 0:e.toString())||"all";if(r=r.toLowerCase().trim(),r==="off")return!1;if(r!=="all"){const i=["debug","log","info","warn","error"],a=i.indexOf(t),o=i.indexOf(r);if(a<o)return!1}}return!0}function sf(s,t,e={}){return Object.getOwnPropertyNames(s).forEach(r=>{var a;if([null,void 0,NaN].includes(s[r])||t&&(((a=t.match(/\./g))==null?void 0:a.length)||0)>=10)return;const i=t?`${t}.${r}`:r;typeof s[r]=="object"?sf(s[r],i,e):["number","string","boolean"].includes(typeof s[r])&&(e[i]=s[r])}),e}function Ip(s,t,e={},r=""){const i={};try{const a=JSON.stringify(e),o=JSON.parse(a),c=sf(o,r),d=JSON.stringify(c);return JSON.parse(d)}catch(a){const o=td(a);i[`${r}.error.message`]=o.message||"",i[`${r}.error.stack`]=o.stack||"",i[`${r}.error.reason`]=o.reason||"",i[`${r}.error.source`]="safelyFlattenObjForOpenTelemetry"}return i}const Bh=class{constructor(){h(this,"logsCache",[]);h(this,"logsProcessorTimer");h(this,"tracingEnabled",!0);h(this,"initialized",!1);h(this,"logsProcessingInterval",7e3);h(this,"logExclusionList",["message","websocket/message","roomMessage","websocket/room-message","websocket/room-legacy-mode","chatMessage","websocket/new-chat-message","websocket/no-active-speaker","websocket/selected-peers","websocket/active-speaker","ping","websocket/new-consumer","websocket/producer-score","websocket/consumer-score","websocket/plugin-event","websocket/plugin-data","websocket/plugin-internal-data"]);h(this,"meetingMetadata",{})}get logsEndpoint(){const t=ur.getContext(this.meetingMetadata.peerId);return`https://${Zi({servicePrefix:"api-silos",baseURI:t.getValue("baseURI")})}/otel/logs`}resetPeerId(t){this.meetingMetadata.peerId=t}init(t,e,r){this.tracingEnabled=!0,this.initialized=!1,this.logsCache=[];const i=t.getValue("peerId");this.meetingMetadata=e,this.tracingEnabled=r,this.meetingMetadata.peerId=i,this.meetingMetadata.sdkVersion=t.getValue("sdkVersion");const{RNDeviceInfoImpl:a}=navigator;this.meetingMetadata.deviceInfo=navigator.isReactNative?a==null?void 0:a.getDeviceInfo():Se.getDeviceInfo(),this.meetingMetadata.visitedUrl=!navigator.isReactNative&&typeof window!="undefined"&&window.location.href,this.logsProcessorTimer=setInterval(this.processCachedLogs.bind(this),this.logsProcessingInterval),r&&(this.initialized=!0)}static trace(t,e=void 0){return(r,i,a)=>{const o=a.value;return a.value=function(...d){var T;const l=this==null?void 0:this.telemetry;if(!l||!l.initialized||navigator.isReactNative||!l.tracingEnabled||(T=ur.getContext(l.meetingMetadata.peerId))!=null&&T.getValue("flagsmith").hasFeature(Z.SKIP_OTEL_TRACES))return o.apply(this,d);l.addLogInCurrentSpan("info",t,e);const p=performance.now(),g=o.apply(this,d);return Promise.resolve(g).then(()=>{const v=performance.now();v-p>10&&l.addLogInCurrentSpan("info",`${t}_timing`,{execTime:v-p,country:Bh.location.country})}).catch(()=>{const v=performance.now();l.addLogInCurrentSpan("info",`${t}_timing`,{execTime:v-p})}),g},a}}injectContext(t){var i;const e=gr.v4().replace(/-/g,"").substring(0,16),r=(i=this.meetingMetadata.peerId)==null?void 0:i.replace(/-/g,"");t.TRACEPARENT=`00-${r}-${e}-01`}addLogInCurrentSpan(t,e,r={},i=!1){r!=null&&r.error&&Object.assign(r,{error:td(r.error)});const a=ur.getContext(this.meetingMetadata.peerId);if(nw(a)&&(GC(r)?console[t]("InternalLogs:: ",t,e):console[t]("InternalLogs:: ",t,e,r)),!!aw(a,t))try{const c=Ip(a,e,r,"metadata"),d=new Date,l=G(D({message:e,level:t},c),{loggedAt:d.toISOString(),loggedAtTzOffset:d.getTimezoneOffset()});i?this.sendOtelLogsToNewRelic([l]):this.logsCache.push(l)}catch(c){this.addLogInCurrentSpan("error","opentelemetry::addLogInCurrentSpan_failed",{error:td(c)})}}sendOtelLogsToNewRelic(t){const e=ur.getContext(this.meetingMetadata.peerId);fetch(this.logsEndpoint,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({meetingMetadata:Ip(e,"sendOtelLogsToNewRelic",this.meetingMetadata,"meetingMetadata"),serviceName:e.getValue("sdkName"),logs:t})}).catch(r=>{this.addLogInCurrentSpan("error","opentelemetry::sendOtelLogToNewRelic_failed",{error:td(r)}),this.logsCache.push(...t)})}processCachedLogs(){const t=this.logsCache.splice(0,25);t!=null&&t.length&&this.sendOtelLogsToNewRelic(t)}destruct(){clearInterval(this.logsProcessorTimer),this.processCachedLogs()}};let P=Bh;h(P,"location",{country:void 0});function ow(s){const t=D({},s),e=new Map,r=(l,p)=>(e.has(l)||e.set(l,new Set),e.get(l).add(p),()=>{var g;return(g=e.get(l))==null?void 0:g.delete(p)}),i=(l,p)=>{var g;(g=e.get(l))==null||g.delete(p)},a=l=>{var p;(p=e.get(l))==null||p.forEach(g=>{try{g(t[l])}catch(T){}})};return{subscribe:r,unsubscribe:i,notify:a,setValue:(l,p,g=!0)=>{t[l]=p,g&&a(l)},getValue:l=>t[l],getAllValues:()=>t}}class cw{constructor(){h(this,"contexts",new Map);h(this,"mostRecentPeerId",null)}createContext(t,e){if(this.contexts.has(t))return this.contexts.get(t);const r=new P,i=new Jm;this.contexts.set(t,ow(e)),this.contexts.get(t).setValue("peerSessionStore",new gu(i));const a=new Tm;return a.setMaxListeners(50),this.contexts.get(t).setValue("logger",i),this.contexts.get(t).setValue("telemetry",r),this.contexts.get(t).setValue("callstats",a),this.contexts.get(t).setValue("flagsmith",YP()),this.mostRecentPeerId=t,this.contexts.get(t)}remapContext(t,e){const r=e.getValue("peerId");r!==t&&(e.setValue("peerId",t),this.mostRecentPeerId=t,this.contexts.set(t,e),this.contexts.delete(r))}getContext(t){return this.contexts.get(t)}getMostRecentPeerId(){return this.mostRecentPeerId}}const ur=new cw,dw={"00":"Client","01":"Controller","02":"RoomNodeClient","03":"HiveNodeClient","04":"SocketService","05":"Chat","06":"Plugin","07":"Polls","08":"Meta","09":"Preset",10:"Recording",11:"Self",12:"Participant",13:"Spotlight",14:"Remote Request",15:"Webinar",16:"LocalMediaHandler",17:"End-End Encryption",18:"AI",19:"Livestream",20:"Stage"},sd={"0000":"Internal exception.","0001":"Failed to initialize.","0002":"Failed to join room.","0003":"Failed to leave room.","0004":"Invalid auth token","0010":"Browser not supported","0011":"HTTP Network Error","0012":"Websocket Network Error","0013":"Rate Limited","0100":"Internal exception","0101":"Permission denied","0102":"Prerequisite module missing","0200":"Internal exception.","0300":"Internal exception","0400":"Internal exception","0404":"Missing prerequisites to establish a websocket connection","0500":"Internal exception","0501":"Permission denied.","0502":"Invalid message body.","0503":"Text Message is too large","0504":"Message not found by the given id","0505":"Action not permitted without joining room","0506":"Message search is disabled","0600":"Internal exception","0601":"Permission denied.","0602":"Auth token not set for plugin","0603":"Iframe was not provided","0700":"Internal exception","0705":"Action not permitted without joining room","0800":"Internal exception","0801":"Permission denied","0900":"Internal exception","0904":"Could not load preset",1e3:"Internal exception",1001:"Permission denied",1004:"Could not find specified recording",1005:"Action not permitted in given recording state",1100:"Internal exception",1101:"Permission denied",1102:"Unsupported",1103:"Name cannot be empty",1104:"No device selected while calling meeting.self.setDevice",1105:"Action not permitted without joining room",1106:"Can't set currently used device",1200:"Internal exception",1201:"Permission denied",1202:"Invalid page number was requested",1203:"Invalid participant count per page was requested",1204:"No participants exists with the given UserIds",1205:"Action not permitted without joining room",1206:"Manual Subscription Mode was not ACTIVATED",1207:"Invalid view mode",1208:"Manual Subscription not enabled for organization",1209:"Broadcast message type must be a non-empty string",1300:"Internal exception",1400:"Internal exception",1402:"No existing remote requests",1403:"No peer exists with given id",1500:"Internal exception",1600:"Internal exception",1601:"Failed to get audio track",1602:"Failed to get video track",1603:"Incorrect device",1604:"Failed to change device",1605:"Failed to get audio & video track",1606:"No audio input devices are available",1607:"No video input devices are available",1608:"No audio output devices (speakers) are available",1609:"Failed to fetch list of media devices",1610:"No media track exists",1611:"Failed to unmute track",1612:"Failed to get screenshare tracks",1701:"Crypto error",1800:"Internal exception",1801:"Can't fetch transcript file",1900:"Internal exception",1901:"Permission denied.",1902:"Livestream that has not yet started, can't be stopped",2e3:"Internal exception",2001:"Permission denied",2002:"Unsupported",2003:"Stage is disabled",2004:"Method not implemented",2005:"Action not permitted without joining room",2006:"Action not permitted in current stage status",9900:"Internal exception"};Object.keys(sd).forEach(s=>{sd[s]=`{${dw[s.slice(0,2)]}} ${sd[s]}`});class A extends Error{constructor(e,r,i=void 0,a=!1){super(e);h(this,"code");this.code=r,this.name="ClientError",this.message=`[ERR${this.code}]: ${sd[this.code]}
|
|
5
|
-
${this.message}`;try{let o=a&&!!i;r&&r.endsWith("00")&&i&&(o=!0),o&&i.error("ClientError",{error:{message:this.message,name:this.name,code:r}});const c=ur.getContext(ur.getMostRecentPeerId());if(c){const d=c.getValue("onError");try{d(this)}catch(l){}}typeof window!="undefined"&&window.dispatchEvent(new CustomEvent("ClientError",{detail:this}))}catch(o){}}}function jc(s,t,e,r){if(r instanceof A)throw r;if(r instanceof t){const i=new A(r.message,e);throw i.stack=r.stack,i}else throw r}function Mp(s,t,e){if(!s.value){const i=s.get,a=s.set;return i&&(s.get=function(){try{return i.apply(this)}catch(o){jc(this,t,e,o)}}),a&&(s.set=function(o){try{return a.apply(this,[o])}catch(c){jc(this,t,e,c)}}),s}const r=s.value;return s.value=function(...i){try{const a=r.apply(this,i);return a&&a instanceof Promise?a.catch(o=>{jc(this,t,e,o)}):a}catch(a){jc(this,t,e,a)}},s}function lw(s,t){return(e,r,i)=>{if(i)return Mp(i,s,t);for(const a of Reflect.ownKeys(e.prototype).filter(o=>o!=="constructor")){const o=Object.getOwnPropertyDescriptor(e.prototype,a);(o.value instanceof Function||o.get instanceof Function||o.set instanceof Function)&&Object.defineProperty(e.prototype,a,Mp(o,s,t))}}}const dt=s=>lw(Error,s);function uw(s){let t=0,e,r;if(!s)return t;for(e=0;e<s.length;e+=1)r=s.charCodeAt(e),t=(t<<5)-t+r,t|=0;return Math.abs(t)%100+1}function hw(){Se.isElectron()&&window.electronGetDisplayMediaSource&&(navigator.mediaDevices.getDisplayMedia=()=>u(this,null,function*(){const s=yield window.electronGetDisplayMediaSource({types:["window","screen"]});let t=[];if(s&&(Array.isArray(s)?t=s:t=[s]),!(t!=null&&t.length))throw new Error("Couldn't find any media source for screen share.");let e=t.find(a=>{var o;return(o=a.id)==null?void 0:o.includes("screen")});e=e!=null?e:t[0];const r={audio:!1,video:{mandatory:{chromeMediaSource:"desktop",chromeMediaSourceId:e.id}}};return yield navigator.mediaDevices.getUserMedia(r)}))}var b=(s=>(s.NEW_PRODUCER="NEW_PRODUCER",s.ROOM_NODE_CONNECTION_ERROR="ROOM_NODE_CONNECTION_ERROR",s.SOCKET_SERVICE_ROOM_JOINED="SOCKET_SERVICE_ROOM_JOINED",s.SOCKET_SERVICE_RECONNECTED="SOCKET_SERVICE_RECONNECTED",s.SOCKET_SERVICE_DISCONNECTED="SOCKET_SERVICE_DISCONNECTED",s.SOCKET_SERVICE_FAILED="SOCKET_SERVICE_FAILED",s.SOCKET_STATE_UPDATE="SOCKET_STATE_UPDATE",s.ROOM_NODE_RECONNECTED="ROOM_NODE_RECONNECTED",s.ROOM_NODE_DISCONNECTED="ROOM_NODE_DISCONNECTED",s.ROOM_NODE_FAILED="ROOM_NODE_FAILED",s.TRANSPORT_STATE_UPDATE="TRANSPORT_STATE_UPDATE",s.PRODUCER_SCORE_UPDATE="PRODUCER_SCORE_UPDATE",s.CONSUMER_SCORE_UPDATE="CONSUMER_SCORE_UPDATE",s.PRODUCER_STATUS_UPDATE="PRODUCER_STATUS_UPDATE",s.CONSUMER_STATUS_UPDATE="CONSUMER_STATUS_UPDATE",s.LOW_CONSUMER_SCORE="LOW_CONSUMER_SCORE",s.MEDIA_PERMISSION_ERROR="MEDIA_PERMISSION_ERROR",s.MEDIA_PERMISSION_UPDATE="MEDIA_PERMISSION_UPDATE",s.MESSAGE="websocket/message",s.ROOM_MESSAGE="websocket/room-message",s.PEER_JOINED_INTERNAL="peer/joined-internal",s.PEER_CLOSED="websocket/peer-closed",s.CONSUMER_CLOSED="websocket/consumer-closed",s.CONSUMER_PAUSED="websocket/consumer-paused",s.CONSUMER_RESUMED="websocket/consumer-resumed",s.PRODUCER_CLOSED="websocket/producer-closed",s.NEW_CONSUMER="websocket/new-consumer",s.PRODUCER_SCORE="websocket/producer-score",s.CONSUMER_SCORE="websocket/consumer-score",s.PRODUCER_TOGGLE="cf/producer-toggle",s.UPDATE_ACTIVE="media/update-active",s.RESET_PRODUCER_STATE="cf/reset-producer-state",s.ROOM_STATE="sockethub/room-state",s.GET_STAGE_REQUESTS="GET_STAGE_REQUESTS",s.UPDATE_STAGE_REQUESTS="UPDATE_STAGE_REQUESTS",s.KICK_PEER="KICK_PEER",s.UPDATE_PEER_STAGE_STATUS="UPDATE_PEER_STAGE_STATUS",s.JOIN_MEDIA_ROOM="JOIN_MEDIA_ROOM",s.LEAVE_MEDIA_ROOM="LEAVE_MEDIA_ROOM",s.PIP_HANGUP="PIP_HANGUP",s.E2EE_ACTIVE_PRODUCER="E2EE_ACTIVE_PRODUCER",s.E2EE_INACTIVE_PRODUCER="E2EE_INACTIVE_PRODUCER",s.E2EE_ACTIVE_CONSUMER="E2EE_ACTIVE_CONSUMER",s.E2EE_INACTIVE_CONSUMER="E2EE_INACTIVE_CONSUMER",s.SOCKET_PEERS="SOCKET_PEERS",s.UPDATE_PERMISSIONS="UPDATE_PERMISSIONS",s.MAX_SPATIAL_LAYER_CHANGE="MAX_SPATIAL_LAYER_CHANGE",s.MUTE_SELF="MUTE_SELF",s.MUTE_SELF_VIDEO="MUTE_SELF_VIDEO",s))(b||{});class Da extends ct.EventEmitter{constructor(e){super();h(this,"logger");this.logger=e,super.setMaxListeners(25)}emit(e,...r){return super.emit("*",e,...r),super.emit(e,...r)}on(e,r){var i;try{const a=this.listenerCount(e);a>25&&a%25===0&&((i=this.logger)==null||i.warn("CustomEventEmitter::maxListenersExceeded",{eventListener:{eventName:e.toString(),listenerCount:this.listenerCount(e)}}))}catch(a){}return super.on(e,r)}addListener(e,r){var i;try{const a=this.listenerCount(e);a>25&&a%25===0&&((i=this.logger)==null||i.warn("CustomEventEmitter::maxListenersExceeded",{eventListener:{eventName:e.toString(),listenerCount:this.listenerCount(e)}}))}catch(a){}return super.addListener(e,r)}off(e,r){return super.off(e,r)}once(e,r){return super.once(e,r)}prependListener(e,r){return super.prependListener(e,r)}prependOnceListener(e,r){return super.prependOnceListener(e,r)}removeListener(e,r){return super.removeListener(e,r)}removeAllListeners(e){return super.removeAllListeners(e)}listeners(e){return super.listeners(e)}listenerCount(e){return super.listenerCount(e)}}class Bt extends ct.EventEmitter{constructor(e){super();h(this,"logger");this.logger=e,super.setMaxListeners(25)}emit(e,...r){return super.emit("*",e,...r),super.emit(e,...r)}on(e,r){var i;try{const a=this.listenerCount(e);a>25&&a%25===0&&((i=this.logger)==null||i.warn("CustomEventEmitter::maxListenersExceeded",{eventListener:{eventName:e.toString(),listenerCount:this.listenerCount(e)}}))}catch(a){}return super.on(e,r)}addListener(e,r){var i;try{const a=this.listenerCount(e);a>25&&a%25===0&&((i=this.logger)==null||i.warn("CustomEventEmitter::maxListenersExceeded",{eventListener:{eventName:e.toString(),listenerCount:this.listenerCount(e)}}))}catch(a){}return super.addListener(e,r)}off(e,r){return super.off(e,r)}once(e,r){return super.once(e,r)}prependListener(e,r){return super.prependListener(e,r)}prependOnceListener(e,r){return super.prependOnceListener(e,r)}removeListener(e,r){return super.removeListener(e,r)}removeAllListeners(e){return super.removeAllListeners(e)}listeners(e){return super.listeners(e)}listenerCount(e){return super.listenerCount(e)}}function pw(s,t=2){return s.replace(/[^\u00BF-\u1FFF\u2C00-\uD7FF\w\s]/g,"").trim().split(/\s+/).slice(0,t).map(i=>i.charAt(0)).join("").toUpperCase()}const Dp=1080,Op=1920,gw=(s,t,e,r,i,a)=>{let o=.5,c=.5;const d=i,l=a,p=Math.min(e/d,r/l);let g=d*p,T=l*p,v,E,_,C,R=1;return g<e&&(R=e/g),Math.abs(R-1)<1e-14&&T<r&&(R=r/T),g*=R,T*=R,_=d/(g/e),C=l/(T/r),v=(d-_)*o,E=(l-C)*c,v<0&&(v=0),E<0&&(E=0),_>d&&(_=d),C>l&&(C=l),[v,E,_,C,s,t,e,r]};var Wt,hi,tt,Jt,Re,us,Gs,ut,De,kn,An,Ws,In;const Hh=class extends Bt{constructor(e,r,i,a){const o=e.getValue("logger");super(o);m(this,Wt,void 0);m(this,hi,void 0);m(this,tt,void 0);m(this,Jt,void 0);m(this,Re,{height:Dp,width:Op});m(this,us,{brand:"#2160FD",background:"#141414",text:"#000000",videoBackground:"#191919",textOnBrand:"#EEEEEE"});m(this,Gs,void 0);m(this,ut,{});m(this,De,void 0);m(this,kn,void 0);m(this,An,void 0);m(this,Ws,void 0);m(this,In,!1);h(this,"cleanupEventListeners",()=>{n(this,hi).unsubscribe("stageStatus",this.handlePipMediaControls),n(this,De).removeListener("videoUpdate",this.onSelfVideoUpdateListener),n(this,De).removeListener("audioUpdate",this.onSelfAudioUpdateListener),n(this,De).removeListener("roomLeft",()=>this.disable())});h(this,"enablePipMediaControls",()=>{this.mountAudioEvents(),this.mountVideoEvents()});h(this,"onSelfVideoUpdateListener",({videoEnabled:e})=>{this.updateMediaSession("CAMERA",e)});h(this,"onSelfAudioUpdateListener",({audioEnabled:e})=>{this.updateMediaSession("MIC",e)});h(this,"handlePipMediaControls",e=>{e==="ON_STAGE"?this.enablePipMediaControls():this.unmountEvents()});h(this,"eventCallback",e=>{e==="CAMERA"&&(n(this,De).videoEnabled?n(this,De).disableVideo():n(this,De).enableVideo(),this.emit("cameraToggled")),e==="MIC"&&(n(this,De).audioEnabled?n(this,De).disableAudio():n(this,De).enableAudio(),this.emit("micToggled")),e==="END"&&(n(this,hi).getValue("peerSessionStore").emit(b.PIP_HANGUP),this.cleanupEventListeners(),this.emit("hangup"),this.cleanup())});h(this,"unmountEvents",()=>{navigator.mediaSession===void 0||navigator.mediaSession.setCameraActive===void 0||(navigator.mediaSession.setActionHandler("togglemicrophone",void 0),navigator.mediaSession.setActionHandler("togglecamera",void 0))});h(this,"animate",()=>{if(!this.isActive&&n(this,Ws)==="active"){this.disable(!0);return}n(this,ut)!==void 0&&this.paintCanvas(),n(this,Gs)!==void 0&&f(this,Gs,requestAnimationFrame(()=>this.animate()))});h(this,"disable",(e=!1)=>{f(this,Ws,"idle"),this.cleanupEventListeners(),cancelAnimationFrame(n(this,Gs)),e!==!0&&document.body.removeChild(n(this,tt)),f(this,Gs,void 0),document.pictureInPictureElement&&document.exitPictureInPicture()});f(this,hi,e),f(this,Ws,"idle"),f(this,De,r),f(this,us,{brand:r.config.designTokens.colors.brand[500],background:r.config.designTokens.colors.background[1e3],text:r.config.designTokens.colors.text,videoBackground:r.config.designTokens.colors.videoBg,textOnBrand:r.config.designTokens.colors.textOnBrand}),i&&this.setupIcon("pin",i),a&&this.setupIcon("handRaise",a)}static _init(e,r){return u(this,null,function*(){let i,a;try{i=yield qc(rw),a=yield qc(iw)}catch(o){}return new Hh(e,r,i,a)})}setupIcon(e,r){return u(this,null,function*(){switch(e){case"handRaise":f(this,An,r);break;case"pin":f(this,kn,r);break}})}overrideIcon(e,r){return u(this,null,function*(){switch(e){case"handRaise":f(this,An,yield qc(r));break;case"pin":f(this,kn,yield qc(r));break}})}constructImage(e){const r=new Image,i=new Blob([e],{type:"image/svg+xml"}),a=window.URL.createObjectURL(i);return new Promise(o=>{r.onload=()=>{o(r),window.URL.revokeObjectURL(a)},r.src=a})}createVideoContainer(){f(this,tt,document.createElement("div")),n(this,tt).style.width="0.1px",n(this,tt).style.height="0.1px",n(this,tt).style.overflow="hidden",n(this,tt).style.position="absolute",n(this,tt).style.bottom="0",n(this,tt).style.right="0",n(this,tt).style.opacity="0",n(this,tt).appendChild(n(this,Jt))}setupEventListeners(){n(this,hi).subscribe("stageStatus",this.handlePipMediaControls),n(this,De).addListener("videoUpdate",this.onSelfVideoUpdateListener),n(this,De).addListener("audioUpdate",this.onSelfAudioUpdateListener),n(this,De).addListener("roomLeft",()=>this.disable())}createCanvas(){const e=document.createElement("canvas");e.height=n(this,Re).height,e.width=n(this,Re).width,f(this,Wt,e)}setupMediaSessionEvents(){navigator.mediaSession===void 0||navigator.mediaSession.setCameraActive===void 0||(navigator.mediaSession.setActionHandler("hangup",()=>{this.eventCallback("END")}),this.mountAudioEvents(),this.mountVideoEvents())}mountAudioEvents(){navigator.mediaSession===void 0||navigator.mediaSession.setMicrophoneActive===void 0||n(this,De).permissions.canProduceAudio&&navigator.mediaSession.setActionHandler("togglemicrophone",()=>{this.eventCallback("MIC")})}mountVideoEvents(){navigator.mediaSession===void 0||navigator.mediaSession.setCameraActive===void 0||n(this,De).permissions.canProduceVideo&&navigator.mediaSession.setActionHandler("togglecamera",()=>{this.eventCallback("CAMERA")})}getSources(){const r=Object.values(n(this,ut)).reduce((i,a)=>(i[a.pinned?"pinned":"regular"].push(a),i),{pinned:[],regular:[]});return[...r.pinned,...r.regular]}drawEmptyTile(e,r,i,a){if(n(this,Wt)===void 0)return;const o=n(this,Wt).getContext("2d"),c=n(this,Wt).width,d=0,l=0,p=r-d*2,g=i-d*2,T=Math.floor(c/p),v=Math.floor(e/T),_=e%T*(p+d)+d,C=v*(g+d)+d,{displayText:R,image:L}=a!=null?a:{};o.fillStyle=R||L?n(this,us).videoBackground:n(this,us).background,o.strokeStyle=n(this,us).brand,o.beginPath(),o.moveTo(_+l,C),o.arcTo(_+p,C,_+p,C+l,l),o.arcTo(_+p,C+g,_+p-l,C+g,l),o.arcTo(_,C+g,_,C+g-l,l),o.arcTo(_,C,_+l,C,l),o.closePath(),o.fill(),o.stroke();const F=p/6,N=p/2+_,B=g/2+C;o.save(),(R||L)&&(o.beginPath(),o.arc(N,B,F,0,Math.PI*2),o.fillStyle=n(this,us).brand,o.fill(),L?(o.clip(),o.drawImage(L,N-F,B-F,F*2,F*2),o.restore()):R&&(o.fillStyle=n(this,us).textOnBrand,o.font=`${F/2}px sans-serif`,o.textAlign="center",o.textBaseline="middle",o.fillText(R,N,B)),this.drawIcons(a,_,C,Math.max(p,g)))}drawIcons(e,r,i,a){const o=Math.min(Math.max(a*.15,100),200),c=o*.2,d=o*.2;let l=r+c;const p=i+c,g=T=>{const v=n(this,Wt).getContext("2d");v.save(),v.fillStyle=n(this,us).background,v.beginPath(),v.moveTo(l+d,p),v.arcTo(l+o,p,l+o,p+d,d),v.arcTo(l+o,p+o,l+o-d,p+o,d),v.arcTo(l,p+o,l,p+o-d,d),v.arcTo(l,p,l+d,p,d),v.closePath(),v.fill(),typeof T=="string"?(v.font=`${o/1.5}px sans-serif`,v.fillStyle=n(this,us).text,v.textAlign="center",v.textBaseline="top",v.fillText(T,o/2+l,p+c)):v.drawImage(T,l+c,p+c,o-c*2,o-c*2),l+=o+c,v.restore()};e.pinned&&g(n(this,kn)),e.handRaised&&g(n(this,An)),e.reaction&&g(e.reaction)}drawTile(e,r,i){var l,p;if(n(this,Wt)===void 0)return;const a=n(this,Wt).getContext("2d"),o=this.getSources();let c=0,d=0;for(;c<n(this,Re).height-5;){let g=0;for(;g<n(this,Re).width-5&&d<i;){if((l=o[d])!=null&&l.enabled){const T=o[d].element,[v,E,_,C,R,L,F,N]=gw(g,c,e,r,T.videoWidth,T.videoHeight);((p=T==null?void 0:T.classList)==null?void 0:p.contains("mirror"))?(a.save(),a.scale(-1,1),a.drawImage(T,v,E,_,C,-1*R,L,-1*F,N),a.restore()):a.drawImage(T,v,E,_,C,R,L,F,N),this.drawIcons(o[d],R,L,Math.max(F,N))}else this.drawEmptyTile(d,e,r,o[d]);d+=1,g+=e}c+=r}}calcGridElemSize(e){switch(e){case 0:case 1:return[n(this,Re).width,n(this,Re).height];case 2:return[Math.floor(n(this,Re).width/2),n(this,Re).height];case 3:case 4:return[Math.floor(n(this,Re).width/2),Math.floor(n(this,Re).height/2)];case 5:case 6:return[Math.floor(n(this,Re).width/3),Math.floor(n(this,Re).height/2)];case 7:case 8:case 9:return[Math.floor(n(this,Re).width/3),Math.floor(n(this,Re).height/3)];default:return[Math.floor(n(this,Re).width/3),Math.floor(n(this,Re).height/2)]}}paintCanvas(){let e=this.getSources().length;e!==1&&(e=e%2>0?e+1:e);const[r,i]=this.calcGridElemSize(e);this.drawTile(r,i,e)}isSupported(){var e;return!!window.chrome&&document.pictureInPictureEnabled&&((e=n(this,De).config)==null?void 0:e.viewType)!=="LIVESTREAM"}get isActive(){return document.pictureInPictureElement!==null}cleanup(){if(f(this,In,!1),this.isSupported()&&document.exitPictureInPicture!==void 0&&document.pictureInPictureElement!==null&&document.exitPictureInPicture(),n(this,tt))try{document.body.removeChild(n(this,tt))}catch(e){}this.removeAllSources(),f(this,Wt,void 0),f(this,Jt,void 0),f(this,Gs,void 0)}init({height:e,width:r}={}){if(!this.isSupported())throw this.logger.error("Pip.unsupported"),new Error("Picture-in-picture is not available in this environment");if(n(this,In))return;f(this,In,!0),this.createCanvas(),this.setupMediaSessionEvents();const i=document.createElement("video");f(this,Re,{height:e!=null?e:Dp,width:r!=null?r:Op}),i.height=n(this,Re).height,i.width=n(this,Re).width,i.autoplay=!0,i.muted=!0,i.srcObject=n(this,Wt).captureStream(24),f(this,Jt,i),n(this,Jt).onloadedmetadata=()=>{try{this.emit("pipStarted"),n(this,Jt).onleavepictureinpicture=()=>{this.emit("pipEnded")}}catch(a){this.emit("pipEnded")}},this.createVideoContainer(),this.paintCanvas()}updateMediaSession(e,r){navigator.mediaSession!==void 0&&(e==="CAMERA"&&navigator.mediaSession.setCameraActive!==void 0&&navigator.mediaSession.setCameraActive(r),e==="MIC"&&navigator.mediaSession.setMicrophoneActive!==void 0&&navigator.mediaSession.setMicrophoneActive(r))}enableSource(e){n(this,ut)[e]!==void 0&&(n(this,ut)[e].enabled=!0)}disableSource(e){n(this,ut)[e]!==void 0&&(n(this,ut)[e].enabled=!1)}generateAvatar(e,r){return u(this,null,function*(){if(!r)return;const i=new Image;try{const a=yield(yield fetch(r)).blob(),o=window.URL.createObjectURL(a);i.onload=()=>{this.updateSource(e,{image:i}),window.URL.revokeObjectURL(o)},i.src=o}catch(a){this.logger.error("Pip::GenerateAvatar",{error:a})}})}addSource(e,r,i,a=!1,o=void 0,c=void 0,d=!1){this.logger.debug("Pip::AddSource",{pip:{id:e,handRaised:d}}),n(this,ut)[e]={id:e,element:r,enabled:i,pinned:a,displayText:o?pw(o):void 0,imageUrl:c,handRaised:d},c&&this.generateAvatar(e,c)}updateSource(e,r){this.logger.info("Pip::UpdateSource",{pip:{id:e,handRaised:r.handRaised,reaction:r.reaction}});const i=n(this,ut)[e];i&&(n(this,ut)[e]=D(D({},i),r))}removeSource(e){delete n(this,ut)[e]}removePinnedSource(){Object.values(n(this,ut)).forEach(r=>{r.pinned&&this.removeSource(r.id)})}removeAllSources(){f(this,ut,{})}enable(){f(this,Ws,"activating"),this.setupEventListeners(),this.updateMediaSession("CAMERA",n(this,De).videoEnabled),this.updateMediaSession("MIC",n(this,De).audioEnabled),document.body.appendChild(n(this,tt)),f(this,Gs,requestAnimationFrame(()=>this.animate())),n(this,Jt).onloadedmetadata=()=>{n(this,Jt).requestPictureInPicture().then(()=>{f(this,Ws,"active")})},n(this,Jt).readyState===4&&n(this,Jt).requestPictureInPicture().then(()=>{f(this,Ws,"active")})}};let vu=Hh;Wt=new WeakMap,hi=new WeakMap,tt=new WeakMap,Jt=new WeakMap,Re=new WeakMap,us=new WeakMap,Gs=new WeakMap,ut=new WeakMap,De=new WeakMap,kn=new WeakMap,An=new WeakMap,Ws=new WeakMap,In=new WeakMap;var fr;(function(s){s[s.PUBLISHER=0]="PUBLISHER",s[s.SUBSCRIBER=1]="SUBSCRIBER"})(fr||(fr={}));var xs;(function(s){s[s.AUDIO=0]="AUDIO",s[s.VIDEO=1]="VIDEO"})(xs||(xs={}));class mw extends S.MessageType{constructor(){super("media.Codec",[{no:1,name:"channels",kind:"scalar",opt:!0,T:5},{no:2,name:"clock_rate",kind:"scalar",T:5},{no:3,name:"mime_type",kind:"scalar",T:9},{no:4,name:"sdp_fmtp_line",kind:"scalar",opt:!0,T:9},{no:5,name:"payload_type",kind:"scalar",opt:!0,T:13}])}}const rf=new mw;class fw extends S.MessageType{constructor(){super("media.HeaderExtension",[{no:1,name:"direction",kind:"scalar",opt:!0,T:9},{no:2,name:"uri",kind:"scalar",T:9}])}}const Tw=new fw;class vw extends S.MessageType{constructor(){super("media.Fingerprint",[{no:1,name:"algorithm",kind:"scalar",T:9},{no:2,name:"value",kind:"scalar",T:9}])}}new vw;class Sw extends S.MessageType{constructor(){super("media.SessionDescription",[{no:1,name:"target",kind:"enum",T:()=>["media.Target",fr]},{no:2,name:"type",kind:"scalar",T:9},{no:3,name:"sdp",kind:"scalar",T:9}])}}const Rs=new Sw;class yw extends S.MessageType{constructor(){super("media.ProducerPayload",[{no:1,name:"kind",kind:"scalar",T:9},{no:2,name:"paused",kind:"scalar",T:8},{no:3,name:"screen_share",kind:"scalar",T:8},{no:4,name:"msid",kind:"scalar",T:9},{no:5,name:"app_data",kind:"scalar",opt:!0,T:9},{no:6,name:"mime_type",kind:"scalar",opt:!0,T:9}])}}const Ew=new yw;class Pw extends S.MessageType{constructor(){super("media.CreateTransportRequest",[{no:1,name:"consuming",kind:"scalar",T:8},{no:2,name:"force_tcp",kind:"scalar",opt:!0,T:8},{no:3,name:"description",kind:"message",T:()=>Rs},{no:4,name:"private_ice",kind:"scalar",opt:!0,T:8},{no:5,name:"producers",kind:"message",repeat:1,T:()=>Ew}])}}const _w=new Pw;class Cw extends S.MessageType{constructor(){super("media.AudioActivityRequest",[{no:1,name:"producer_id",kind:"scalar",T:9},{no:2,name:"energy",kind:"scalar",T:5},{no:3,name:"silent",kind:"scalar",T:8}])}}const ww=new Cw;class Rw extends S.MessageType{constructor(){super("media.CreateTransportResponse",[{no:1,name:"transport_id",kind:"scalar",T:9},{no:2,name:"description",kind:"message",T:()=>Rs},{no:3,name:"transcription_enabled",kind:"scalar",opt:!0,T:8},{no:4,name:"producer_ids",kind:"scalar",repeat:2,T:9}])}}const nf=new Rw;class bw extends S.MessageType{constructor(){super("media.RenegotiateRequest",[{no:1,name:"transport_id",kind:"scalar",T:9},{no:2,name:"description",kind:"message",T:()=>Rs}])}}const kw=new bw;class Aw extends S.MessageType{constructor(){super("media.RenegotiateResponse",[{no:1,name:"transport_id",kind:"scalar",T:9},{no:2,name:"description",kind:"message",T:()=>Rs}])}}new Aw;class Iw extends S.MessageType{constructor(){super("media.NestedScore",[{no:1,name:"encoding_idx",kind:"scalar",T:5},{no:2,name:"rid",kind:"scalar",T:9},{no:3,name:"score",kind:"scalar",T:5},{no:4,name:"ssrc",kind:"scalar",T:3,L:0}])}}const Mw=new Iw;class Dw extends S.MessageType{constructor(){super("media.ProducerTrack",[{no:1,name:"track_id",kind:"scalar",T:9},{no:2,name:"producer_id",kind:"scalar",T:9},{no:3,name:"stream_id",kind:"scalar",T:9}])}}const Ow=new Dw;class Nw extends S.MessageType{constructor(){super("media.ProducerEntry",[{no:1,name:"producing_transport_id",kind:"scalar",T:9},{no:2,name:"producer_id",kind:"scalar",T:9}])}}new Nw;class Vw extends S.MessageType{constructor(){super("media.ConsumerEntry",[{no:1,name:"consuming_transport_id",kind:"scalar",T:9},{no:2,name:"consumer_id",kind:"scalar",T:9}])}}new Vw;class Lw extends S.MessageType{constructor(){super("media.ProducerState",[{no:1,name:"producer_id",kind:"scalar",T:9},{no:2,name:"kind",kind:"enum",T:()=>["media.ProducerKind",xs]},{no:3,name:"pause",kind:"scalar",T:8},{no:4,name:"screen_share",kind:"scalar",T:8},{no:5,name:"app_data",kind:"scalar",opt:!0,T:9},{no:6,name:"producing_transport_id",kind:"scalar",opt:!0,T:9},{no:7,name:"mime_type",kind:"scalar",opt:!0,T:9},{no:8,name:"codec",kind:"message",T:()=>rf}])}}const Dc=new Lw;class xw extends S.MessageType{constructor(){super("media.ConsumerState",[{no:1,name:"consumer_id",kind:"scalar",T:9},{no:2,name:"producer_state",kind:"message",T:()=>Dc},{no:3,name:"producer_track",kind:"message",T:()=>Ow},{no:4,name:"error_code",kind:"scalar",opt:!0,T:9}])}}const Uw=new xw;class $w extends S.MessageType{constructor(){super("media.ProducerIdToConsumerMap",[{no:1,name:"map",kind:"map",K:9,V:{kind:"message",T:()=>Uw}}])}}const af=new $w;class Fw extends S.MessageType{constructor(){super("media.PeerRtpCapabilitites",[{no:1,name:"sender",kind:"message",T:()=>Vp},{no:2,name:"receiver",kind:"message",T:()=>Vp}])}}const of=new Fw;class Bw extends S.MessageType{constructor(){super("media.RtpCapability",[{no:1,name:"codecs",kind:"message",repeat:1,T:()=>rf},{no:2,name:"header_extensions",kind:"message",repeat:1,T:()=>Tw}])}}const Np=new Bw;class Hw extends S.MessageType{constructor(){super("media.RtpCapabilitites",[{no:1,name:"audio",kind:"message",T:()=>Np},{no:2,name:"video",kind:"message",T:()=>Np}])}}const Vp=new Hw;class qw extends S.MessageType{constructor(){super("media.PreferredCodec",[{no:1,name:"audio",kind:"scalar",opt:!0,T:9},{no:2,name:"video",kind:"scalar",opt:!0,T:9}])}}const jw=new qw;class Gw extends S.MessageType{constructor(){super("media.Simulcast",[{no:1,name:"preferred_rid",kind:"scalar",opt:!0,T:9},{no:2,name:"priority_ordering",kind:"scalar",opt:!0,T:9},{no:3,name:"rid_not_available",kind:"scalar",opt:!0,T:9}])}}const cf=new Gw;class Ww extends S.MessageType{constructor(){super("media.edge.GeoLocation",[{no:1,name:"latitude",kind:"scalar",T:2},{no:2,name:"longitude",kind:"scalar",T:2},{no:3,name:"region",kind:"scalar",opt:!0,T:9}])}}const Jw=new Ww;class Kw extends S.MessageType{constructor(){super("media.edge.PeerJoinRequest",[{no:1,name:"display_name",kind:"scalar",opt:!0,T:9},{no:2,name:"prejoined",kind:"scalar",T:8},{no:3,name:"room_uuid",kind:"scalar",T:9},{no:4,name:"meeting_id",kind:"scalar",opt:!0,T:9},{no:5,name:"preset",kind:"scalar",opt:!0,T:12},{no:6,name:"user_id",kind:"scalar",opt:!0,T:9},{no:7,name:"organization_id",kind:"scalar",opt:!0,T:9},{no:8,name:"location",kind:"message",T:()=>Jw},{no:9,name:"capabilities",kind:"message",T:()=>of}])}}const zw=new Kw;class Yw extends S.MessageType{constructor(){super("media.edge.PeerJoinCompleteRequest",[])}}const Qw=new Yw;class Xw extends S.MessageType{constructor(){super("media.edge.PeerLeaveRequest",[{no:1,name:"close_room",kind:"scalar",T:8}])}}const Zw=new Xw;class eR extends S.MessageType{constructor(){super("media.edge.ConsumeMultipleProducerRequest",[{no:1,name:"producer_ids",kind:"scalar",repeat:2,T:9},{no:2,name:"paused",kind:"scalar",opt:!0,T:8}])}}new eR;class tR extends S.MessageType{constructor(){super("media.edge.ConsumePeerRequest",[{no:1,name:"producing_peer_id",kind:"scalar",T:9},{no:2,name:"paused",kind:"scalar",opt:!0,T:8},{no:3,name:"producer_id",kind:"scalar",opt:!0,T:9},{no:4,name:"preferred_codec",kind:"message",T:()=>jw},{no:5,name:"producing_transport_id",kind:"scalar",opt:!0,T:9},{no:6,name:"simulcast",kind:"message",T:()=>cf}])}}const sR=new tR;class rR extends S.MessageType{constructor(){super("media.edge.ConsumePeersRequest",[{no:1,name:"requests",kind:"message",repeat:1,T:()=>sR},{no:2,name:"consuming_transport_id",kind:"scalar",opt:!0,T:9}])}}const iR=new rR;class nR extends S.MessageType{constructor(){super("media.edge.UpdateConsumerSimulcastConfigRequest",[{no:1,name:"producer_id",kind:"scalar",T:9},{no:2,name:"simulcast",kind:"message",T:()=>cf},{no:3,name:"producing_transport_id",kind:"scalar",T:9},{no:4,name:"mid",kind:"scalar",T:9}])}}const aR=new nR;class oR extends S.MessageType{constructor(){super("media.edge.UpdateConsumersSimulcastConfigRequest",[{no:1,name:"requests",kind:"message",repeat:1,T:()=>aR},{no:2,name:"consuming_transport_id",kind:"scalar",opt:!0,T:9}])}}const cR=new oR;class dR extends S.MessageType{constructor(){super("media.edge.ProducerCreateRequest",[{no:1,name:"kind",kind:"scalar",T:9},{no:2,name:"paused",kind:"scalar",T:8},{no:3,name:"screen_share",kind:"scalar",T:8},{no:4,name:"description",kind:"message",T:()=>Rs},{no:5,name:"msid",kind:"scalar",T:9},{no:6,name:"app_data",kind:"scalar",opt:!0,T:9},{no:7,name:"mime_type",kind:"scalar",opt:!0,T:9},{no:8,name:"producing_transport_id",kind:"scalar",opt:!0,T:9}])}}const lR=new dR;class uR extends S.MessageType{constructor(){super("media.edge.SelectedPeersRequest",[])}}new uR;class hR extends S.MessageType{constructor(){super("media.edge.GlobalPeerPinningRequest",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}const pR=new hR;class gR extends S.MessageType{constructor(){super("media.edge.ProducerToggleRequest",[{no:1,name:"producer_id",kind:"scalar",T:9},{no:2,name:"pause",kind:"scalar",T:8}])}}const Gc=new gR;class mR extends S.MessageType{constructor(){super("media.edge.ConsumerToggleRequest",[{no:1,name:"consumer_id",kind:"scalar",T:9},{no:2,name:"pause",kind:"scalar",T:8}])}}new mR;class fR extends S.MessageType{constructor(){super("media.edge.ProducerCloseRequest",[{no:1,name:"producer_id",kind:"scalar",T:9},{no:2,name:"description",kind:"message",T:()=>Rs},{no:3,name:"producing_transport_id",kind:"scalar",opt:!0,T:9}])}}const TR=new fR;class vR extends S.MessageType{constructor(){super("media.edge.ConsumerCloseRequest",[{no:1,name:"consumer_ids",kind:"scalar",repeat:2,T:9},{no:2,name:"description",kind:"message",T:()=>Rs},{no:3,name:"consuming_transport_id",kind:"scalar",opt:!0,T:9}])}}const SR=new vR;class yR extends S.MessageType{constructor(){super("media.edge.KickPeerRequest",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}new yR;class ER extends S.MessageType{constructor(){super("media.edge.KickAllPeersRequest",[{no:1,name:"propagate_kick_across_rooms",kind:"scalar",T:8}])}}const df=new ER;class PR extends S.MessageType{constructor(){super("media.edge.PeerDisplayNameEditRequest",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"display_name",kind:"scalar",T:9}])}}const _R=new PR;class CR extends S.MessageType{constructor(){super("media.edge.HostMediaControlForPeerRequest",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"audio",kind:"scalar",T:8},{no:3,name:"video",kind:"scalar",T:8},{no:4,name:"scree_share",kind:"scalar",T:8}])}}const wR=new CR;class RR extends S.MessageType{constructor(){super("media.edge.HostMediaControlForAllPeerRequest",[{no:1,name:"audio",kind:"scalar",T:8},{no:2,name:"video",kind:"scalar",T:8},{no:3,name:"screen_share",kind:"scalar",T:8}])}}const bR=new RR;class kR extends S.MessageType{constructor(){super("media.edge.GetRoomStateResponse",[{no:1,name:"display_title",kind:"scalar",T:9},{no:2,name:"locked_mode",kind:"scalar",T:8},{no:3,name:"room_uuid",kind:"scalar",T:9},{no:4,name:"room_name",kind:"scalar",T:9},{no:5,name:"current_peer_id",kind:"scalar",T:9},{no:6,name:"is_recording",kind:"scalar",opt:!0,T:8},{no:7,name:"recorder_participant_id",kind:"scalar",opt:!0,T:9},{no:8,name:"pinned_peer_ids",kind:"scalar",repeat:2,T:9}])}}const AR=new kR;class IR extends S.MessageType{constructor(){super("media.edge.ErrorResponse",[{no:1,name:"error_message",kind:"scalar",T:9},{no:2,name:"event_id",kind:"scalar",T:5}])}}const MR=new IR;class DR extends S.MessageType{constructor(){super("media.edge.EmptyResponse",[])}}new DR;class OR extends S.MessageType{constructor(){super("media.edge.RoomParticipants",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"producer_states",kind:"message",repeat:1,T:()=>Dc},{no:3,name:"display_name",kind:"scalar",T:9},{no:4,name:"user_id",kind:"scalar",opt:!0,T:9},{no:5,name:"capabilities",kind:"message",T:()=>of}])}}const lf=new OR;class NR extends S.MessageType{constructor(){super("media.edge.SelectedPeersResponse",[{no:1,name:"audio_peers",kind:"scalar",repeat:2,T:9},{no:2,name:"compulsory_peers",kind:"scalar",repeat:2,T:9}])}}const Su=new NR;class VR extends S.MessageType{constructor(){super("media.edge.SelectedPeersDiffEntry",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"priority",kind:"scalar",T:5}])}}const LR=new VR;class xR extends S.MessageType{constructor(){super("media.edge.SelectedPeersDiffResponse",[{no:1,name:"entries",kind:"message",repeat:1,T:()=>LR}])}}const Lp=new xR;class UR extends S.MessageType{constructor(){super("media.edge.PeerJoinResponse",[])}}new UR;class $R extends S.MessageType{constructor(){super("media.edge.PeerJoinCompleteResponse",[{no:1,name:"room_state",kind:"message",T:()=>AR},{no:2,name:"participants",kind:"message",repeat:1,T:()=>lf},{no:3,name:"selected_peers",kind:"message",T:()=>Su},{no:4,name:"max_preferred_streams",kind:"scalar",T:5}])}}const yu=new $R;class FR extends S.MessageType{constructor(){super("media.edge.PeerLeaveResponse",[{no:1,name:"closed",kind:"scalar",T:8}])}}const BR=new FR;class HR extends S.MessageType{constructor(){super("media.edge.ConsumeMultipleProducerResponse",[{no:1,name:"status",kind:"scalar",T:8},{no:2,name:"consumer_ids_map",kind:"message",T:()=>af}])}}new HR;class qR extends S.MessageType{constructor(){super("media.edge.ConsumePeerResponse",[{no:1,name:"status",kind:"scalar",T:8},{no:2,name:"consumer_ids_map",kind:"message",T:()=>af},{no:3,name:"description",kind:"message",T:()=>Rs}])}}const jR=new qR;class GR extends S.MessageType{constructor(){super("media.edge.ProducerCreateResponse",[{no:1,name:"status",kind:"scalar",T:8},{no:2,name:"producer_id",kind:"scalar",T:9},{no:4,name:"description",kind:"message",T:()=>Rs}])}}const WR=new GR;class JR extends S.MessageType{constructor(){super("media.edge.ProducerScoreResponse",[{no:1,name:"responseid",kind:"scalar",T:9},{no:2,name:"score",kind:"message",T:()=>Mw}])}}new JR;class KR extends S.MessageType{constructor(){super("media.edge.ActiveSpeakerResponse",[{no:1,name:"responsepeer_id",kind:"scalar",T:9},{no:2,name:"volume",kind:"scalar",T:5}])}}new KR;class zR extends S.MessageType{constructor(){super("media.edge.NoActiveSpeakerResponse",[])}}new zR;class YR extends S.MessageType{constructor(){super("media.edge.ProducerToggleResponse",[])}}new YR;class QR extends S.MessageType{constructor(){super("media.edge.ConsumerToggleResponse",[])}}new QR;class XR extends S.MessageType{constructor(){super("media.edge.ProducerClosingResponse",[{no:1,name:"description",kind:"message",T:()=>Rs}])}}const ZR=new XR;class eb extends S.MessageType{constructor(){super("media.edge.ConsumerClosingResponse",[{no:1,name:"description",kind:"message",T:()=>Rs}])}}const tb=new eb;class sb extends S.MessageType{constructor(){super("media.edge.GlobalPeerPinningResponse",[])}}new sb;class rb extends S.MessageType{constructor(){super("media.edge.KickPeerResponse",[{no:1,name:"status",kind:"scalar",T:9}])}}new rb;class ib extends S.MessageType{constructor(){super("media.edge.KickAllPeersResponse",[{no:1,name:"status",kind:"scalar",T:9}])}}new ib;class nb extends S.MessageType{constructor(){super("media.edge.HostMediaControlForPeerResponse",[{no:1,name:"status",kind:"scalar",T:9}])}}const ab=new nb;class ob extends S.MessageType{constructor(){super("media.edge.HostMediaControlForAllPeerResponse",[{no:1,name:"status",kind:"scalar",T:9}])}}const cb=new ob;class db extends S.MessageType{constructor(){super("media.edge.PeerDisplayNameEditResponse",[{no:1,name:"status",kind:"scalar",T:9}])}}const lb=new db;class ub extends S.MessageType{constructor(){super("media.edge.PeerJoinBroadcastResponse",[{no:1,name:"participant",kind:"message",T:()=>lf}])}}const xp=new ub;class hb extends S.MessageType{constructor(){super("media.edge.TrackSubscriptionKind",[{no:1,name:"audio",kind:"scalar",T:8},{no:2,name:"video",kind:"scalar",T:8}])}}const Up=new hb;class pb extends S.MessageType{constructor(){super("media.edge.TrackSubscription",[{no:1,name:"label",kind:"scalar",T:9},{no:2,name:"webcam",kind:"message",T:()=>Up},{no:3,name:"screenshare",kind:"message",T:()=>Up}])}}const gb=new pb;class mb extends S.MessageType{constructor(){super("media.edge.PeerProducingTransportCreateBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"transport_details",kind:"message",T:()=>nf},{no:3,name:"track_subscriptions",kind:"message",repeat:1,T:()=>gb}])}}new mb;class fb extends S.MessageType{constructor(){super("media.edge.PeerProducerCreateBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"producer_state",kind:"message",T:()=>Dc}])}}const Tb=new fb;class vb extends S.MessageType{constructor(){super("media.edge.PeerProducerToggleBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"producer_state",kind:"message",T:()=>Dc},{no:3,name:"initiator_participant_id",kind:"scalar",opt:!0,T:9}])}}const $p=new vb;class Sb extends S.MessageType{constructor(){super("media.edge.PeerProducerCloseBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"producer_state",kind:"message",T:()=>Dc}])}}const yb=new Sb;class Eb extends S.MessageType{constructor(){super("media.edge.PeerLeaveBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}const Eu=new Eb;class Pb extends S.MessageType{constructor(){super("media.edge.GlobalPeerPinningBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}const Fp=new Pb;class _b extends S.MessageType{constructor(){super("media.edge.GlobalPeerUnPinningBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}new _b;class Cb extends S.MessageType{constructor(){super("media.edge.RecordingStartedBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}new Cb;class wb extends S.MessageType{constructor(){super("media.edge.RecordingStoppedBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}new wb;class Rb extends S.MessageType{constructor(){super("media.edge.PeerDisplayNameEditBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"display_name",kind:"scalar",T:9}])}}new Rb;class bb extends S.MessageType{constructor(){super("media.edge.PeerPingRequestBroadcastResponse",[{no:1,name:"password",kind:"scalar",T:9}])}}new bb;class kb extends S.MessageType{constructor(){super("media.edge.MediaRoomTerminationBroadcastResponse",[{no:1,name:"reason",kind:"scalar",T:9}])}}new kb;class Ab extends S.MessageType{constructor(){super("socket.ai.MeetingTranscript",[{no:1,name:"meeting_id",kind:"scalar",T:9},{no:2,name:"transcript",kind:"scalar",T:9},{no:3,name:"is_partial",kind:"scalar",T:8}])}}const Zl=new Ab;class Ib extends S.MessageType{constructor(){super("socket.api.BaseSocketHubMessage",[{no:1,name:"event",kind:"scalar",T:5},{no:2,name:"id",kind:"scalar",T:9},{no:3,name:"peer_id",kind:"scalar",T:9},{no:4,name:"room_id",kind:"scalar",T:9},{no:5,name:"user_id",kind:"scalar",T:9},{no:6,name:"payload",kind:"scalar",T:12},{no:7,name:"error",kind:"scalar",opt:!0,T:8},{no:8,name:"sid",kind:"scalar",opt:!0,T:9}])}}new Ib;class Mb extends S.MessageType{constructor(){super("socket.api.ErrorMessage",[{no:1,name:"code",kind:"scalar",opt:!0,T:5},{no:2,name:"message",kind:"scalar",T:9}])}}const Db=new Mb;var en;(function(s){s[s.BROWSER=0]="BROWSER",s[s.TRACK=1]="TRACK",s[s.COMPOSITE=2]="COMPOSITE"})(en||(en={}));var dr;(function(s){s[s.UNSPECIFIED=0]="UNSPECIFIED",s[s.ON_STAGE=1]="ON_STAGE",s[s.APPROVED_STAGE=2]="APPROVED_STAGE",s[s.REQUESTED_STAGE=3]="REQUESTED_STAGE",s[s.OFF_STAGE=4]="OFF_STAGE"})(dr||(dr={}));var Pu;(function(s){s[s.NONE=0]="NONE",s[s.RECORDER=1]="RECORDER",s[s.LIVESTREAMER=2]="LIVESTREAMER"})(Pu||(Pu={}));var _u;(function(s){s[s.PEERS=0]="PEERS",s[s.ROOMS=1]="ROOMS"})(_u||(_u={}));var Sd;(function(s){s[s.HIVE=0]="HIVE",s[s.CHAT=1]="CHAT",s[s.PING=2]="PING"})(Sd||(Sd={}));class Ob extends S.MessageType{constructor(){super("socket.room.PeerFlags",[{no:1,name:"preset_name",kind:"scalar",T:9},{no:2,name:"recorder_type",kind:"scalar",T:9},{no:3,name:"hidden_participant",kind:"scalar",T:8}])}}const Nb=new Ob;class Vb extends S.MessageType{constructor(){super("socket.room.Peer",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"user_id",kind:"scalar",T:9},{no:3,name:"display_name",kind:"scalar",T:9},{no:4,name:"stage_type",kind:"enum",opt:!0,T:()=>["socket.room.StageType",dr,"STAGE_TYPE_"]},{no:5,name:"custom_participant_id",kind:"scalar",opt:!0,T:9},{no:6,name:"preset_id",kind:"scalar",opt:!0,T:9},{no:7,name:"display_picture_url",kind:"scalar",opt:!0,T:9},{no:8,name:"waitlisted",kind:"scalar",T:8},{no:9,name:"flags",kind:"message",T:()=>Nb}])}}const Nl=new Vb;class Lb extends S.MessageType{constructor(){super("socket.room.PeerInfoResponse",[{no:1,name:"peer",kind:"message",T:()=>Nl}])}}const hn=new Lb;class xb extends S.MessageType{constructor(){super("socket.room.PeerStatusUpdate",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"user_id",kind:"scalar",T:9},{no:3,name:"stage_type",kind:"enum",opt:!0,T:()=>["socket.room.StageType",dr,"STAGE_TYPE_"]}])}}const Bp=new xb;class Ub extends S.MessageType{constructor(){super("socket.room.RoomPeersInfoRequest",[{no:1,name:"seach_query",kind:"scalar",T:9},{no:2,name:"limit",kind:"scalar",T:5},{no:3,name:"offset",kind:"scalar",T:5}])}}const $b=new Ub;class Fb extends S.MessageType{constructor(){super("socket.room.RoomPeersInfoResponse",[{no:1,name:"peers",kind:"message",repeat:1,T:()=>Nl}])}}const eu=new Fb;class Bb extends S.MessageType{constructor(){super("socket.room.RoomPeerCountResponse",[{no:1,name:"count",kind:"scalar",T:4,L:2}])}}const Hp=new Bb;class Hb extends S.MessageType{constructor(){super("socket.room.Room",[{no:1,name:"room_id",kind:"scalar",T:9},{no:2,name:"title",kind:"scalar",T:9},{no:4,name:"created_at",kind:"scalar",T:4,L:2},{no:5,name:"active_recordings",kind:"message",repeat:1,T:()=>jb},{no:6,name:"room_uuid",kind:"scalar",opt:!0,T:9}])}}const uf=new Hb;class qb extends S.MessageType{constructor(){super("socket.room.ActiveRecording",[{no:1,name:"recording_id",kind:"scalar",T:9},{no:2,name:"recording_type",kind:"enum",T:()=>["common.RecordingType",en]},{no:3,name:"recording_status",kind:"scalar",T:9}])}}const jb=new qb;class Gb extends S.MessageType{constructor(){super("socket.room.RoomInfoResponse",[{no:1,name:"room",kind:"message",T:()=>uf}])}}const qp=new Gb;class Wb extends S.MessageType{constructor(){super("socket.room.GetPeerInfoRequest",[{no:1,name:"peer_id",kind:"scalar",T:9}])}}const hf=new Wb;class Jb extends S.MessageType{constructor(){super("socket.room.UpdatePeerInfoRequest",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"display_name",kind:"scalar",opt:!0,T:9}])}}new Jb;class Kb extends S.MessageType{constructor(){super("socket.room.JoinRoomRequest",[{no:1,name:"peer",kind:"message",T:()=>Nl},{no:3,name:"room_uuid",kind:"scalar",T:9},{no:4,name:"organization_id",kind:"scalar",opt:!0,T:9},{no:5,name:"use_hive",kind:"scalar",opt:!0,T:8},{no:6,name:"preset",kind:"scalar",opt:!0,T:12},{no:7,name:"capabilities",kind:"enum",repeat:1,T:()=>["socket.room.Capabilities",Sd,"CAPABILITIES_"]},{no:8,name:"timestamp",kind:"scalar",opt:!0,T:4,L:2}])}}const zb=new Kb;class Yb extends S.MessageType{constructor(){super("socket.room.LeaveRoomRequest",[{no:1,name:"peer",kind:"message",T:()=>Nl},{no:2,name:"timestamp",kind:"scalar",opt:!0,T:4,L:2}])}}const Qb=new Yb;class Xb extends S.MessageType{constructor(){super("socket.room.UpdateRoomInfoRequest",[{no:1,name:"room",kind:"message",T:()=>uf}])}}new Xb;class Zb extends S.MessageType{constructor(){super("socket.room.GetConnectedRoomsDumpRequest",[])}}new Zb;class ek extends S.MessageType{constructor(){super("socket.room.ServiceError",[{no:1,name:"message",kind:"scalar",opt:!0,T:9},{no:2,name:"code",kind:"scalar",opt:!0,T:9}])}}const Ph=new ek;class tk extends S.MessageType{constructor(){super("socket.room.ConnectedMeetingPeer",[{no:1,name:"id",kind:"scalar",opt:!0,T:9},{no:2,name:"display_name",kind:"scalar",opt:!0,T:9},{no:3,name:"custom_participant_id",kind:"scalar",opt:!0,T:9},{no:4,name:"preset_id",kind:"scalar",opt:!0,T:9},{no:5,name:"display_picture_url",kind:"scalar",opt:!0,T:9}])}}const sk=new tk;class rk extends S.MessageType{constructor(){super("socket.room.ConnectedMeetingDump",[{no:1,name:"id",kind:"scalar",opt:!0,T:9},{no:2,name:"title",kind:"scalar",opt:!0,T:9},{no:3,name:"participants",kind:"message",repeat:1,T:()=>sk}])}}const jp=new rk;class ik extends S.MessageType{constructor(){super("socket.room.GetConnectedRoomsDumpResponse",[{no:1,name:"parent_meeting",kind:"message",T:()=>jp},{no:2,name:"meetings",kind:"message",repeat:1,T:()=>jp}])}}const nk=new ik;class ak extends S.MessageType{constructor(){super("socket.room.CreateRoomRequestPayload",[{no:1,name:"title",kind:"scalar",opt:!0,T:9}])}}const ok=new ak;class ck extends S.MessageType{constructor(){super("socket.room.CreateConnectedRoomsRequest",[{no:1,name:"payloads",kind:"message",repeat:1,T:()=>ok}])}}const dk=new ck;class lk extends S.MessageType{constructor(){super("socket.room.CreateRoomResponsePayload",[{no:1,name:"id",kind:"scalar",opt:!0,T:9},{no:2,name:"title",kind:"scalar",opt:!0,T:9},{no:3,name:"error",kind:"message",T:()=>Ph}])}}const uk=new lk;class hk extends S.MessageType{constructor(){super("socket.room.CreateConnectedRoomsResponse",[{no:1,name:"payloads",kind:"message",repeat:1,T:()=>uk}])}}const Gp=new hk;class pk extends S.MessageType{constructor(){super("socket.room.UpdateRoomRequestPayload",[{no:1,name:"meeting_id",kind:"scalar",opt:!0,T:9},{no:2,name:"title",kind:"scalar",opt:!0,T:9}])}}const gk=new pk;class mk extends S.MessageType{constructor(){super("socket.room.UpdateConnectedRoomsRequest",[{no:1,name:"payloads",kind:"message",repeat:1,T:()=>gk}])}}new mk;class fk extends S.MessageType{constructor(){super("socket.room.DisableRoomPayload",[{no:1,name:"id",kind:"scalar",opt:!0,T:9}])}}const Tk=new fk;class vk extends S.MessageType{constructor(){super("socket.room.DisableConnectedRoomsRequest",[{no:1,name:"payloads",kind:"message",repeat:1,T:()=>Tk}])}}const Sk=new vk;class yk extends S.MessageType{constructor(){super("socket.room.DisableConnectedRoomsResponse",[{no:1,name:"payloads",kind:"message",repeat:1,T:()=>_k}])}}const Ek=new yk;class Pk extends S.MessageType{constructor(){super("socket.room.DisableConnectedRoomPayload",[{no:1,name:"id",kind:"scalar",opt:!0,T:9},{no:2,name:"status",kind:"scalar",opt:!0,T:9},{no:3,name:"title",kind:"scalar",opt:!0,T:9},{no:4,name:"error",kind:"message",T:()=>Ph}])}}const _k=new Pk;class Ck extends S.MessageType{constructor(){super("socket.room.MovePeerPayload",[{no:1,name:"id",kind:"scalar",opt:!0,T:9},{no:2,name:"preset_id",kind:"scalar",opt:!0,T:9}])}}const wk=new Ck;class Rk extends S.MessageType{constructor(){super("socket.room.MovePeersBetweenRoomsRequest",[{no:1,name:"source_meeting_id",kind:"scalar",opt:!0,T:9},{no:2,name:"destination_meeting_id",kind:"scalar",opt:!0,T:9},{no:3,name:"participants",kind:"message",repeat:1,T:()=>wk}])}}const bk=new Rk;class kk extends S.MessageType{constructor(){super("socket.room.MovedPeer",[{no:1,name:"meeting_id",kind:"scalar",opt:!0,T:9},{no:2,name:"custom_participant_id",kind:"scalar",opt:!0,T:9},{no:3,name:"error",kind:"message",T:()=>Ph}])}}const pf=new kk;class Ak extends S.MessageType{constructor(){super("socket.room.MovePeersBetweenRoomsResponse",[{no:1,name:"payloads",kind:"message",repeat:1,T:()=>pf}])}}new Ak;class Ik extends S.MessageType{constructor(){super("socket.room.TransferPeer",[{no:1,name:"meeting_id",kind:"scalar",opt:!0,T:9},{no:2,name:"auth_token",kind:"scalar",opt:!0,T:9}])}}const Mk=new Ik;class Dk extends S.MessageType{constructor(){super("socket.room.GetAllAddedParticipantsResponse",[{no:1,name:"participants",kind:"message",repeat:1,T:()=>Vk}])}}const Ok=new Dk;class Nk extends S.MessageType{constructor(){super("socket.room.AddedParticipant",[{no:1,name:"id",kind:"scalar",T:9},{no:2,name:"name",kind:"scalar",opt:!0,T:9},{no:3,name:"picture",kind:"scalar",opt:!0,T:9},{no:4,name:"custom_participant_id",kind:"scalar",T:9}])}}const Vk=new Nk;class Lk extends S.MessageType{constructor(){super("socket.room.RemoveParticipantsRequest",[{no:1,name:"peer_ids",kind:"scalar",repeat:2,T:9}])}}const gf=new Lk;class xk extends S.MessageType{constructor(){super("socket.room.BroadcastMessage",[{no:1,name:"type",kind:"scalar",T:9},{no:2,name:"payload",kind:"scalar",T:12},{no:3,name:"timestamp",kind:"scalar",T:4,L:2},{no:4,name:"ids",kind:"scalar",repeat:2,T:9},{no:5,name:"broadcast_type",kind:"enum",opt:!0,T:()=>["socket.room.BroadcastType",_u,"BROADCAST_TYPE_"]}])}}const Za=new xk;class Uk extends S.MessageType{constructor(){super("socket.room.AcceptWaitingRoomRequests",[{no:1,name:"user_ids",kind:"scalar",repeat:2,T:9}])}}const $k=new Uk;class Fk extends S.MessageType{constructor(){super("socket.room.DenyWaitingRoomRequests",[{no:1,name:"user_ids",kind:"scalar",repeat:2,T:9}])}}const Bk=new Fk;class Hk extends S.MessageType{constructor(){super("socket.room.WaitingRoomRequest",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"user_id",kind:"scalar",T:9},{no:3,name:"display_name",kind:"scalar",T:9},{no:4,name:"picture",kind:"scalar",opt:!0,T:9},{no:5,name:"custom_participant_id",kind:"scalar",opt:!0,T:9},{no:6,name:"preset_name",kind:"scalar",opt:!0,T:9}])}}const qk=new Hk;class jk extends S.MessageType{constructor(){super("socket.room.GetWaitingRoomRequests",[{no:1,name:"requests",kind:"message",repeat:1,T:()=>qk}])}}const Wp=new jk;class Gk extends S.MessageType{constructor(){super("socket.room.GetRoomStageStateResponse",[{no:1,name:"on_stage_peers",kind:"scalar",repeat:2,T:9},{no:2,name:"approved_stage_peers",kind:"scalar",repeat:2,T:9},{no:3,name:"requested_stage_peers",kind:"scalar",repeat:2,T:9}])}}const Jp=new Gk;var Cu;(function(s){s[s.NONE=0]="NONE",s[s.SKIP=1]="SKIP",s[s.ON_PRIVILEGED_USER_ENTRY=2]="ON_PRIVILEGED_USER_ENTRY",s[s.SKIP_ON_ACCEPT=3]="SKIP_ON_ACCEPT"})(Cu||(Cu={}));var Kr;(function(s){s[s.NONE=0]="NONE",s[s.ALLOWED=1]="ALLOWED",s[s.NOT_ALLOWED=2]="NOT_ALLOWED",s[s.CAN_REQUEST=3]="CAN_REQUEST"})(Kr||(Kr={}));class Wk extends S.MessageType{constructor(){super("socket.preset.PollsPermissionUpdate",[{no:1,name:"can_create",kind:"scalar",opt:!0,T:8},{no:2,name:"can_vote",kind:"scalar",opt:!0,T:8},{no:3,name:"can_view",kind:"scalar",opt:!0,T:8}])}}const Jk=new Wk;class Kk extends S.MessageType{constructor(){super("socket.preset.PluginsPermissionsUpdate",[{no:1,name:"can_close",kind:"scalar",opt:!0,T:8},{no:2,name:"can_start",kind:"scalar",opt:!0,T:8}])}}const zk=new Kk;class Yk extends S.MessageType{constructor(){super("socket.preset.PublicChatPermission",[{no:1,name:"can_send",kind:"scalar",opt:!0,T:8},{no:2,name:"text",kind:"scalar",opt:!0,T:8},{no:3,name:"files",kind:"scalar",opt:!0,T:8}])}}const Qk=new Yk;class Xk extends S.MessageType{constructor(){super("socket.preset.PrivateChatPermission",[{no:1,name:"can_send",kind:"scalar",opt:!0,T:8},{no:2,name:"can_receive",kind:"scalar",opt:!0,T:8},{no:3,name:"text",kind:"scalar",opt:!0,T:8},{no:4,name:"files",kind:"scalar",opt:!0,T:8}])}}const Zk=new Xk;class eA extends S.MessageType{constructor(){super("socket.preset.ChatPermissionUpdate",[{no:1,name:"public",kind:"message",T:()=>Qk},{no:2,name:"private",kind:"message",T:()=>Zk}])}}const tA=new eA;class sA extends S.MessageType{constructor(){super("socket.preset.ConnectedMeetingPermissionUpdate",[{no:1,name:"can_alter_connected_meetings",kind:"scalar",opt:!0,T:8},{no:2,name:"can_switch_to_parent_meeting",kind:"scalar",opt:!0,T:8},{no:3,name:"can_switch_connected_meetings",kind:"scalar",opt:!0,T:8}])}}const rA=new sA;class iA extends S.MessageType{constructor(){super("socket.preset.StreamPermission",[{no:1,name:"can_produce",kind:"enum",opt:!0,T:()=>["socket.preset.StreamPermissionType",Kr,"STREAM_PERMISSION_TYPE_"]},{no:2,name:"can_consume",kind:"enum",opt:!0,T:()=>["socket.preset.StreamPermissionType",Kr,"STREAM_PERMISSION_TYPE_"]}])}}const tu=new iA;class nA extends S.MessageType{constructor(){super("socket.preset.MediaPermissionUpdate",[{no:1,name:"video",kind:"message",T:()=>tu},{no:2,name:"audio",kind:"message",T:()=>tu},{no:3,name:"screenshare",kind:"message",T:()=>tu}])}}const aA=new nA;class oA extends S.MessageType{constructor(){super("socket.preset.PresetUpdates",[{no:1,name:"polls",kind:"message",T:()=>Jk},{no:2,name:"plugins",kind:"message",T:()=>zk},{no:3,name:"chat",kind:"message",T:()=>tA},{no:4,name:"accept_waiting_requests",kind:"scalar",opt:!0,T:8},{no:5,name:"can_accept_production_requests",kind:"scalar",opt:!0,T:8},{no:6,name:"can_edit_display_name",kind:"scalar",opt:!0,T:8},{no:7,name:"can_record",kind:"scalar",opt:!0,T:8},{no:8,name:"can_livestream",kind:"scalar",opt:!0,T:8},{no:9,name:"can_spotlight",kind:"scalar",opt:!0,T:8},{no:10,name:"disable_participant_audio",kind:"scalar",opt:!0,T:8},{no:11,name:"disable_participant_screensharing",kind:"scalar",opt:!0,T:8},{no:12,name:"disable_participant_video",kind:"scalar",opt:!0,T:8},{no:13,name:"kick_participant",kind:"scalar",opt:!0,T:8},{no:14,name:"pin_participant",kind:"scalar",opt:!0,T:8},{no:15,name:"transcription_enabled",kind:"scalar",opt:!0,T:8},{no:16,name:"waiting_room_type",kind:"enum",opt:!0,T:()=>["socket.preset.WaitingRoomType",Cu,"WAITING_ROOM_TYPE_"]},{no:17,name:"is_recorder",kind:"scalar",opt:!0,T:8},{no:18,name:"recorder_type",kind:"enum",opt:!0,T:()=>["socket.room.RecorderType",Pu,"RECORDER_TYPE_"]},{no:19,name:"hidden_participant",kind:"scalar",opt:!0,T:8},{no:20,name:"show_participant_list",kind:"scalar",opt:!0,T:8},{no:21,name:"can_change_participant_permissions",kind:"scalar",opt:!0,T:8},{no:22,name:"connected_meetings",kind:"message",T:()=>rA},{no:23,name:"media",kind:"message",T:()=>aA}])}}const _h=new oA;class cA extends S.MessageType{constructor(){super("socket.preset.ReadPeersPresetRequest",[{no:1,name:"user_ids",kind:"scalar",repeat:2,T:9}])}}const dA=new cA;class lA extends S.MessageType{constructor(){super("socket.preset.PeerPreset",[{no:1,name:"user_id",kind:"scalar",T:9},{no:2,name:"peer_id",kind:"scalar",T:9},{no:3,name:"preset",kind:"scalar",T:12}])}}const uA=new lA;class hA extends S.MessageType{constructor(){super("socket.preset.ReadPeersPresetResponse",[{no:1,name:"peer_presets",kind:"message",repeat:1,T:()=>uA}])}}const pA=new hA;class gA extends S.MessageType{constructor(){super("socket.preset.UpdatePeerPreset",[{no:1,name:"user_ids",kind:"scalar",T:9},{no:2,name:"patch",kind:"message",T:()=>_h}])}}const mf=new gA;class mA extends S.MessageType{constructor(){super("socket.preset.UpdatePeersPresetRequest",[{no:1,name:"update_peers_presets",kind:"message",repeat:1,T:()=>mf}])}}const fA=new mA;class TA extends S.MessageType{constructor(){super("socket.preset.UpdatePeersPresetResponse",[{no:1,name:"update_peers_presets",kind:"message",repeat:1,T:()=>mf}])}}const Kp=new TA;class vA extends S.MessageType{constructor(){super("socket.preset.PeerUserIDMap",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"user_id",kind:"scalar",T:9}])}}const SA=new vA;class yA extends S.MessageType{constructor(){super("socket.preset.BulkUpdatePeerPresetRequest",[{no:1,name:"peers",kind:"message",repeat:1,T:()=>SA},{no:2,name:"patch",kind:"message",T:()=>_h}])}}new yA;class EA extends S.MessageType{constructor(){super("socket.preset.BulkUpdatePeerPresetResponse",[{no:2,name:"patch",kind:"message",T:()=>_h}])}}new EA;class PA extends S.MessageType{constructor(){super("socket.chat.ChatMessage",[{no:1,name:"chat_id",kind:"scalar",T:9},{no:2,name:"peer_id",kind:"scalar",T:9},{no:3,name:"user_id",kind:"scalar",T:9},{no:4,name:"display_name",kind:"scalar",T:9},{no:5,name:"pinned",kind:"scalar",T:8},{no:6,name:"is_edited",kind:"scalar",T:8},{no:7,name:"payload_type",kind:"scalar",T:5},{no:8,name:"payload",kind:"scalar",T:9},{no:10,name:"target_user_ids",kind:"scalar",repeat:2,T:9},{no:11,name:"created_at",kind:"scalar",T:4,L:2},{no:12,name:"created_at_ms",kind:"scalar",opt:!0,T:4,L:2},{no:13,name:"channel_id",kind:"scalar",opt:!0,T:9},{no:14,name:"channel_index",kind:"scalar",opt:!0,T:9}])}}const Zr=new PA;class _A extends S.MessageType{constructor(){super("socket.chat.GetPaginatedChatMessageFilters",[{no:1,name:"pinned",kind:"scalar",oneof:"filters",T:8},{no:2,name:"user_id",kind:"scalar",oneof:"filters",T:9}])}}const CA=new _A;class wA extends S.MessageType{constructor(){super("socket.chat.GetPaginatedChatMessageRoomRequest",[{no:1,name:"time_stamp",kind:"scalar",T:4,L:2},{no:2,name:"size",kind:"scalar",T:5},{no:3,name:"from",kind:"scalar",T:5},{no:4,name:"reversed",kind:"scalar",T:8},{no:5,name:"channel_id",kind:"scalar",opt:!0,T:9},{no:6,name:"filters",kind:"message",T:()=>CA}])}}const RA=new wA;class bA extends S.MessageType{constructor(){super("socket.chat.GetPaginatedChatMessageRoomResponse",[{no:1,name:"messages",kind:"message",repeat:1,T:()=>Zr},{no:2,name:"next",kind:"scalar",T:8}])}}const kA=new bA;class AA extends S.MessageType{constructor(){super("socket.chat.GetChatMessagesResponse",[{no:1,name:"messages",kind:"message",repeat:1,T:()=>Zr}])}}const ff=new AA;class IA extends S.MessageType{constructor(){super("socket.chat.SendChatMessageToRoomRequest",[{no:1,name:"payload_type",kind:"scalar",T:5},{no:2,name:"payload",kind:"scalar",T:9}])}}const MA=new IA;class DA extends S.MessageType{constructor(){super("socket.chat.SendChatMessageToRoomResponse",[{no:1,name:"message",kind:"message",T:()=>Zr}])}}const su=new DA;class OA extends S.MessageType{constructor(){super("socket.chat.SendChatMessageToPeersRequest",[{no:1,name:"peer_ids",kind:"scalar",repeat:2,T:9},{no:2,name:"payload_type",kind:"scalar",T:5},{no:3,name:"payload",kind:"scalar",T:9}])}}const NA=new OA;class VA extends S.MessageType{constructor(){super("socket.chat.SendChatMessageToPeersResponse",[{no:1,name:"message",kind:"message",T:()=>Zr}])}}const ru=new VA;class LA extends S.MessageType{constructor(){super("socket.chat.SendChatMessageToChannelRequest",[{no:1,name:"channel_id",kind:"scalar",T:9},{no:2,name:"payload_type",kind:"scalar",T:5},{no:3,name:"payload",kind:"scalar",T:9}])}}new LA;class xA extends S.MessageType{constructor(){super("socket.chat.SendChatMessageToChannelResponse",[{no:1,name:"message",kind:"message",T:()=>Zr}])}}new xA;class UA extends S.MessageType{constructor(){super("socket.chat.EditChatMessageRequest",[{no:1,name:"chat_id",kind:"scalar",T:9},{no:2,name:"payload_type",kind:"scalar",opt:!0,T:5},{no:3,name:"payload",kind:"scalar",opt:!0,T:9},{no:4,name:"pinned",kind:"scalar",opt:!0,T:8},{no:5,name:"channel_id",kind:"scalar",opt:!0,T:9}])}}const $A=new UA;class FA extends S.MessageType{constructor(){super("socket.chat.PinChatMessageRequest",[{no:1,name:"chat_id",kind:"scalar",T:9},{no:2,name:"pinned",kind:"scalar",T:8},{no:3,name:"channel_id",kind:"scalar",opt:!0,T:9}])}}const BA=new FA;class HA extends S.MessageType{constructor(){super("socket.chat.PinChatMessageResponse",[{no:1,name:"chat_id",kind:"scalar",T:9},{no:2,name:"pinned",kind:"scalar",T:8},{no:3,name:"channel_id",kind:"scalar",opt:!0,T:9},{no:4,name:"message",kind:"message",T:()=>Zr}])}}const Wc=new HA;class qA extends S.MessageType{constructor(){super("socket.chat.EditChatMessageResponse",[{no:1,name:"message",kind:"message",T:()=>Zr}])}}const Jc=new qA;class jA extends S.MessageType{constructor(){super("socket.chat.DeleteChatMessageRequest",[{no:1,name:"chat_id",kind:"scalar",T:9},{no:2,name:"channel_id",kind:"scalar",opt:!0,T:9}])}}const GA=new jA;class WA extends S.MessageType{constructor(){super("socket.chat.DeleteChatMessageResponse",[{no:1,name:"chat_id",kind:"scalar",T:9},{no:2,name:"channel_id",kind:"scalar",opt:!0,T:9}])}}const Kc=new WA;class JA extends S.MessageType{constructor(){super("socket.chat.SearchChatMessagesRequest",[{no:1,name:"time_stamp",kind:"scalar",T:4,L:2},{no:2,name:"size",kind:"scalar",T:5},{no:3,name:"from",kind:"scalar",T:5},{no:4,name:"reversed",kind:"scalar",T:8},{no:5,name:"channel_id",kind:"scalar",opt:!0,T:9},{no:6,name:"search_term",kind:"scalar",T:9}])}}const KA=new JA;class zA extends S.MessageType{constructor(){super("socket.chat.MarkChannelIndexAsReadRequest",[{no:1,name:"channel_id",kind:"scalar",T:9},{no:2,name:"user_id",kind:"scalar",T:9},{no:3,name:"channel_index",kind:"scalar",T:9}])}}new zA;class YA extends S.MessageType{constructor(){super("socket.chat.MarkChannelIndexAsReadResponse",[{no:1,name:"channel_index",kind:"scalar",T:9}])}}new YA;class QA extends S.MessageType{constructor(){super("socket.chat.CreateChatChannelRequest",[{no:1,name:"display_name",kind:"scalar",T:9},{no:2,name:"target_user_ids",kind:"scalar",repeat:2,T:9},{no:3,name:"display_picture_url",kind:"scalar",opt:!0,T:9},{no:4,name:"visibility",kind:"scalar",T:9},{no:5,name:"is_direct_message",kind:"scalar",T:8}])}}new QA;class XA extends S.MessageType{constructor(){super("socket.chat.UpdateChatChannelRequest",[{no:1,name:"chat_channel_id",kind:"scalar",T:9},{no:2,name:"display_name",kind:"scalar",opt:!0,T:9},{no:3,name:"target_user_ids",kind:"scalar",repeat:2,T:9},{no:4,name:"display_picture_url",kind:"scalar",opt:!0,T:9},{no:5,name:"visibility",kind:"scalar",opt:!0,T:9},{no:6,name:"is_direct_message",kind:"scalar",opt:!0,T:8}])}}new XA;class ZA extends S.MessageType{constructor(){super("socket.chat.CreateChatChannelResponse",[{no:1,name:"chat_channel_id",kind:"scalar",T:9}])}}new ZA;class eI extends S.MessageType{constructor(){super("socket.chat.GetChatChannelRequest",[{no:1,name:"chat_channel_id",kind:"scalar",T:9}])}}new eI;class tI extends S.MessageType{constructor(){super("socket.chat.LatestMessageAndUnreadCount",[{no:1,name:"message",kind:"message",T:()=>Zr},{no:2,name:"unread_count",kind:"scalar",T:4,L:2}])}}const sI=new tI;class rI extends S.MessageType{constructor(){super("socket.chat.ChatChannel",[{no:1,name:"chat_channel_id",kind:"scalar",T:9},{no:2,name:"display_name",kind:"scalar",T:9},{no:3,name:"display_picture_url",kind:"scalar",opt:!0,T:9},{no:4,name:"visibility",kind:"scalar",T:9},{no:5,name:"is_direct_message",kind:"scalar",T:8},{no:6,name:"latest_message_and_unread_count",kind:"message",T:()=>sI},{no:7,name:"target_user_ids",kind:"scalar",repeat:2,T:9}])}}const iI=new rI;class nI extends S.MessageType{constructor(){super("socket.chat.GetChatChannelResponse",[{no:1,name:"chat_channels",kind:"message",repeat:1,T:()=>iI}])}}new nI;class aI extends S.MessageType{constructor(){super("socket.chat.ChannelMember",[{no:1,name:"id",kind:"scalar",T:9},{no:2,name:"name",kind:"scalar",opt:!0,T:9},{no:3,name:"picture",kind:"scalar",opt:!0,T:9},{no:4,name:"custom_participant_id",kind:"scalar",T:9}])}}const oI=new aI;class cI extends S.MessageType{constructor(){super("socket.chat.GetChatChannelMembersResponse",[{no:1,name:"channel_members",kind:"message",repeat:1,T:()=>oI}])}}new cI;class dI extends S.MessageType{constructor(){super("socket.plugin.AddPluginRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"staggered",kind:"scalar",T:8}])}}const lI=new dI;class uI extends S.MessageType{constructor(){super("socket.plugin.RemovePluginRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"staggered",kind:"scalar",T:8}])}}const hI=new uI;class pI extends S.MessageType{constructor(){super("socket.plugin.EnablePluginForRoomRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9}])}}const gI=new pI;class mI extends S.MessageType{constructor(){super("socket.plugin.DisablePluginForRoomRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9}])}}const fI=new mI;class TI extends S.MessageType{constructor(){super("socket.plugin.EnablePluginForPeersRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"peer_ids",kind:"scalar",repeat:2,T:9}])}}const vI=new TI;class SI extends S.MessageType{constructor(){super("socket.plugin.DisablePluginForPeersRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"peer_ids",kind:"scalar",repeat:2,T:9}])}}const yI=new SI;class EI extends S.MessageType{constructor(){super("socket.plugin.PluginEventToRoomRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"plugin_data",kind:"scalar",T:12}])}}const PI=new EI;class _I extends S.MessageType{constructor(){super("socket.plugin.PluginEventToPeersRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"peer_ids",kind:"scalar",repeat:2,T:9},{no:3,name:"plugin_data",kind:"scalar",T:12}])}}const CI=new _I;class wI extends S.MessageType{constructor(){super("socket.plugin.StoreKeys",[{no:1,name:"store_key",kind:"scalar",T:9},{no:2,name:"payload",kind:"scalar",opt:!0,T:12}])}}const Ch=new wI;class RI extends S.MessageType{constructor(){super("socket.plugin.PluginStoreInsertKeysRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"store_name",kind:"scalar",T:9},{no:3,name:"insert_keys",kind:"message",repeat:1,T:()=>Ch}])}}const zp=new RI;class bI extends S.MessageType{constructor(){super("socket.plugin.PluginStoreGetKeysRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"store_name",kind:"scalar",T:9},{no:3,name:"get_keys",kind:"message",repeat:1,T:()=>Ch}])}}const kI=new bI;class AI extends S.MessageType{constructor(){super("socket.plugin.PluginStoreDeleteKeysRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"store_name",kind:"scalar",T:9},{no:3,name:"delete_keys",kind:"message",repeat:1,T:()=>Ch}])}}const II=new AI;class MI extends S.MessageType{constructor(){super("socket.plugin.PluginStoreDeleteRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"store_name",kind:"scalar",T:9}])}}const DI=new MI;class OI extends S.MessageType{constructor(){super("socket.plugin.EnablePluginResponse",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"enabled_by",kind:"scalar",T:9}])}}const wu=new OI;class NI extends S.MessageType{constructor(){super("socket.plugin.EnablePluginsResponse",[{no:1,name:"plugins",kind:"message",repeat:1,T:()=>wu}])}}const VI=new NI;class LI extends S.MessageType{constructor(){super("socket.plugin.DisablePluginResponse",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"disabled_by",kind:"scalar",T:9}])}}const Yp=new LI;class xI extends S.MessageType{constructor(){super("socket.plugin.PluginStoreItem",[{no:1,name:"timestamp",kind:"scalar",T:9},{no:2,name:"peer_id",kind:"scalar",T:9},{no:3,name:"store_key",kind:"scalar",T:9},{no:4,name:"payload",kind:"scalar",T:12}])}}const UI=new xI;class $I extends S.MessageType{constructor(){super("socket.plugin.PluginStoreResponse",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"store_name",kind:"scalar",T:9},{no:3,name:"store_items",kind:"message",repeat:1,T:()=>UI}])}}const Qp=new $I;class FI extends S.MessageType{constructor(){super("socket.plugin.PluginEventResponse",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"plugin_data",kind:"scalar",T:12}])}}const Xp=new FI;class BI extends S.MessageType{constructor(){super("socket.livestreaming.LiveStreamingEvent",[{no:1,name:"livestream_id",kind:"scalar",T:9},{no:2,name:"err_message",kind:"scalar",T:9},{no:3,name:"name",kind:"scalar",T:9},{no:4,name:"meeting_id",kind:"scalar",T:9},{no:5,name:"playback_url",kind:"scalar",T:9},{no:6,name:"org_id",kind:"scalar",T:9},{no:7,name:"room_name",kind:"scalar",T:9},{no:8,name:"room_uuid",kind:"scalar",T:9},{no:9,name:"status",kind:"scalar",T:9},{no:10,name:"manual_ingest",kind:"scalar",opt:!0,T:8}])}}const Zp=new BI;class HI extends S.MessageType{constructor(){super("socket.livestreaming.GetStagePeersResponse",[{no:1,name:"stage_peers",kind:"scalar",repeat:2,T:9}])}}const eg=new HI;class qI extends S.MessageType{constructor(){super("socket.livestreaming.StageRequest",[{no:1,name:"display_name",kind:"scalar",T:9},{no:2,name:"user_id",kind:"scalar",T:9},{no:3,name:"peer_id",kind:"scalar",T:9}])}}const jI=new qI;class GI extends S.MessageType{constructor(){super("socket.livestreaming.GetStageRequestsResponse",[{no:1,name:"stage_requests",kind:"message",repeat:1,T:()=>jI}])}}const iu=new GI;class WI extends S.MessageType{constructor(){super("socket.livestreaming.GrantStageAccessRequest",[{no:1,name:"user_ids",kind:"scalar",repeat:2,T:9}])}}const JI=new WI;class KI extends S.MessageType{constructor(){super("socket.livestreaming.DenyStageAccessRequest",[{no:1,name:"user_ids",kind:"scalar",repeat:2,T:9}])}}const zI=new KI;class YI extends S.MessageType{constructor(){super("socket.livestreaming.LeaveStageRequest",[{no:1,name:"user_ids",kind:"scalar",repeat:2,T:9}])}}const tg=new YI;class QI extends S.MessageType{constructor(){super("socket.polls.Poll",[{no:1,name:"poll_id",kind:"scalar",T:9},{no:2,name:"created_by",kind:"scalar",T:9},{no:3,name:"created_by_user_id",kind:"scalar",T:9},{no:4,name:"question",kind:"scalar",T:9},{no:5,name:"options",kind:"message",repeat:1,T:()=>ZI},{no:6,name:"hide_votes",kind:"scalar",T:8},{no:7,name:"anonymous",kind:"scalar",T:8},{no:8,name:"votes",kind:"scalar",repeat:2,T:9}])}}const Tf=new QI;class XI extends S.MessageType{constructor(){super("socket.polls.PollOption",[{no:1,name:"text",kind:"scalar",T:9},{no:2,name:"count",kind:"scalar",opt:!0,T:4,L:2},{no:3,name:"votes",kind:"message",repeat:1,T:()=>tM}])}}const ZI=new XI;class eM extends S.MessageType{constructor(){super("socket.polls.PollVote",[{no:1,name:"user_id",kind:"scalar",T:9},{no:2,name:"name",kind:"scalar",T:9}])}}const tM=new eM;class sM extends S.MessageType{constructor(){super("socket.polls.NewPollRequest",[{no:1,name:"question",kind:"scalar",T:9},{no:2,name:"options",kind:"scalar",repeat:2,T:9},{no:3,name:"anonymous",kind:"scalar",T:8},{no:4,name:"hide_votes",kind:"scalar",T:8},{no:5,name:"created_by",kind:"scalar",opt:!0,T:9},{no:6,name:"created_by_user_id",kind:"scalar",opt:!0,T:9}])}}const rM=new sM;class iM extends S.MessageType{constructor(){super("socket.polls.VotePollRequest",[{no:1,name:"poll_id",kind:"scalar",T:9},{no:2,name:"index",kind:"scalar",T:4,L:2}])}}const nM=new iM;class aM extends S.MessageType{constructor(){super("socket.polls.UpdatePollResponse",[{no:1,name:"poll",kind:"message",T:()=>Tf}])}}const nu=new aM;class oM extends S.MessageType{constructor(){super("socket.polls.GetPollsResponse",[{no:1,name:"polls",kind:"message",repeat:1,T:()=>Tf}])}}const cM=new oM;class dM extends S.MessageType{constructor(){super("socket.recording.RecordingEvent",[{no:1,name:"recording_id",kind:"scalar",T:9},{no:2,name:"err_message",kind:"scalar",T:9},{no:3,name:"recording_type",kind:"enum",T:()=>["common.RecordingType",en]}])}}const sg=new dM;class lM extends S.MessageType{constructor(){super("google.protobuf.Timestamp",[{no:1,name:"seconds",kind:"scalar",T:3,L:0},{no:2,name:"nanos",kind:"scalar",T:5}])}now(){const t=this.create(),e=Date.now();return t.seconds=S.PbLong.from(Math.floor(e/1e3)).toBigInt(),t.nanos=e%1e3*1e6,t}toDate(t){return new Date(S.PbLong.from(t.seconds).toNumber()*1e3+Math.ceil(t.nanos/1e6))}fromDate(t){const e=this.create(),r=t.getTime();return e.seconds=S.PbLong.from(Math.floor(r/1e3)).toBigInt(),e.nanos=r%1e3*1e6,e}internalJsonWrite(t,e){let r=S.PbLong.from(t.seconds).toNumber()*1e3;if(r<Date.parse("0001-01-01T00:00:00Z")||r>Date.parse("9999-12-31T23:59:59Z"))throw new Error("Unable to encode Timestamp to JSON. Must be from 0001-01-01T00:00:00Z to 9999-12-31T23:59:59Z inclusive.");if(t.nanos<0)throw new Error("Unable to encode invalid Timestamp to JSON. Nanos must not be negative.");let i="Z";if(t.nanos>0){let a=(t.nanos+1e9).toString().substring(1);a.substring(3)==="000000"?i="."+a.substring(0,3)+"Z":a.substring(6)==="000"?i="."+a.substring(0,6)+"Z":i="."+a+"Z"}return new Date(r).toISOString().replace(".000Z",i)}internalJsonRead(t,e,r){if(typeof t!="string")throw new Error("Unable to parse Timestamp from JSON "+S.typeofJsonValue(t)+".");let i=t.match(/^([0-9]{4})-([0-9]{2})-([0-9]{2})T([0-9]{2}):([0-9]{2}):([0-9]{2})(?:Z|\.([0-9]{3,9})Z|([+-][0-9][0-9]:[0-9][0-9]))$/);if(!i)throw new Error("Unable to parse Timestamp from JSON. Invalid format.");let a=Date.parse(i[1]+"-"+i[2]+"-"+i[3]+"T"+i[4]+":"+i[5]+":"+i[6]+(i[8]?i[8]:"Z"));if(Number.isNaN(a))throw new Error("Unable to parse Timestamp from JSON. Invalid value.");if(a<Date.parse("0001-01-01T00:00:00Z")||a>Date.parse("9999-12-31T23:59:59Z"))throw new globalThis.Error("Unable to parse Timestamp from JSON. Must be from 0001-01-01T00:00:00Z to 9999-12-31T23:59:59Z inclusive.");return r||(r=this.create()),r.seconds=S.PbLong.from(a/1e3).toBigInt(),r.nanos=0,i[7]&&(r.nanos=parseInt("1"+i[7]+"0".repeat(9-i[7].length))-1e9),r}}new lM;class uM extends S.MessageType{constructor(){super("common.BaseHubMessage",[{no:1,name:"event",kind:"scalar",T:5},{no:2,name:"id",kind:"scalar",T:9},{no:3,name:"peer_id",kind:"scalar",T:9},{no:4,name:"room_id",kind:"scalar",T:9},{no:5,name:"user_id",kind:"scalar",T:9},{no:6,name:"payload",kind:"scalar",T:12},{no:7,name:"error",kind:"scalar",opt:!0,T:8},{no:8,name:"sid",kind:"scalar",opt:!0,T:9},{no:9,name:"room_object_id",kind:"scalar",opt:!0,T:9},{no:10,name:"preset",kind:"scalar",opt:!0,T:9},{no:11,name:"use_start_session",kind:"scalar",opt:!0,T:8}])}}const Ru=new uM;class hM extends S.MessageType{constructor(){super("common.BulkedHubMessage",[{no:1,name:"messages",kind:"message",repeat:1,T:()=>Ru}])}}new hM;class pM extends S.MessageType{constructor(){super("common.CFWorkersResponse",[{no:1,name:"responses",kind:"message",repeat:1,T:()=>Ru},{no:2,name:"broadcast_responses",kind:"message",repeat:1,T:()=>Ru}])}}new pM;const gM=0,mM=1,fM=2,TM=3,vM=5,SM={getPeerInfo:0,updatePeerInfo:1,getRoomPeersInfo:2,joinRoom:3,leaveRoom:4,getRoomInfo:5,updateRoomInfo:6,closeRoom:7,startedLivestream:8,stoppedLivestream:9,erroredLivestream:10,getStagePeers:11,getStageRequests:12,requestStageAccess:13,cancelStageRequest:14,grantStageAccess:15,denyStageAccess:16,roomPeerCount:17,joinStage:18,leaveStage:19,getConnectedRoomsDump:20,createConnectedRooms:21,deleteConnectedRooms:22,movePeers:23,transferPeer:24,movedPeer:25,connectedRoomsUpdated:26,connectedRoomsDeleted:27,getAllAddedParticipants:28,broadcastMessage:29,kick:30,kickAll:31,transcript:32,getWaitingRoomRequests:33,acceptWaitingRoomRequests:34,waitingRoomRequestAccepted:35,denyWaitingRoomRequests:36,waitingRoomRequestDenied:37,peerStageStatusUpdate:38,broadcastToEntity:39,recordingStarted:40,recordingStopped:41,recordingPaused:42,getRoomStageState:43,livestreamingInvoked:44},yM={getMessages:0,sendMessageToRoom:1,sendMessageToPeers:2,editMessage:3,deleteMessage:4,getPaginatedMessages:5,searchChannelMessages:7,pinMessage:10},EM={getPlugins:0,addPlugin:1,enablePluginForRoom:2,disablePluginForPeers:3,enablePluginForPeers:4,disablePluginForRoom:5,removePlugin:6,customPluginEventToRoom:7,customPluginEventToPeers:8,storeInsertKeys:9,storeGetKeys:10,storeDeleteKeys:11,storeDelete:12},PM={createPoll:0,getPolls:1,votePoll:2,updatePoll:3},vf={unknown:0,createWebRTCTransport:1,produce:2,consume:3,toggleProducer:4,toggleConsumer:5,closeProducer:6,closeConsumer:7,updateConsumersSimulcastConfig:8,joinRoom:16,leaveRoom:17,selectedPeer:18,globalPinPeer:19,selfJoinComplete:20,peerJoinedBroadcast:25,peerLeaveBroadcast:26,peerProducerCreateBroadcast:27,peerProducerToggleBroadcast:28,peerProducerCloseBroadcast:29,globalPeerPinBroadcast:30,recordingStartedBroadcast:31,recordingStoppedBroadcast:32,peerDisplayNameEditBroadcast:33,mediaRoomTerminationBroadcastResponse:36,selectedPeerDiff:40,renegotiateSessionDescription:50,errorResponse:60,kickPeer:90,kickAll:91,changeDisplayName:92,hostControlPeer:93,hostControlAllPeers:94,audioActivity:100},_M={getUserPresets:0,updateUserPreset:1};function Oc(s,t){return Object.keys(t).reduce((e,r)=>(e[r]=(s<<16)+t[r],e),{})}function Sf(s,t){return Object.keys(s).reduce((e,r)=>(e[r]=t|s[r],e),{})}const U=Oc(gM,SM),$e=Oc(mM,yM),J=Oc(fM,EM),Hs=Oc(TM,PM),Ar=Sf(vf,16777216),Ps=Sf(vf,50331648),rd=Oc(vM,_M);var CM=Object.defineProperty,wM=Object.getOwnPropertyDescriptor,ei=(s,t,e,r)=>{for(var i=r>1?void 0:r?wM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&CM(t,e,i),i},rs=(s=>(s[s.TEXT=0]="TEXT",s[s.IMAGE=1]="IMAGE",s[s.FILE=2]="FILE",s[s.CUSTOM=3]="CUSTOM",s))(rs||{}),Mt,Mn;class yr{constructor(t,e){m(this,Mt,void 0);m(this,Mn,void 0);f(this,Mt,e),f(this,Mn,t)}get telemetry(){return n(this,Mn).getValue("telemetry")}get logger(){return n(this,Mn).getValue("logger")}getChatMessages(){return n(this,Mt).sendMessagePromise($e.getMessages)}getChatMessagesPaginated(t,e,r,i){return u(this,null,function*(){const a=D({timeStamp:t,size:e,from:0,reversed:r},i&&{filters:{filters:i}}),o=yield n(this,Mt).sendMessagePromise($e.getPaginatedMessages,RA.toBinary(a));return o.payload?kA.fromBinary(o.payload):{messages:[],next:!1}})}sendMessageToRoom(t,e){const r={payloadType:e,payload:t};n(this,Mt).sendMessage($e.sendMessageToRoom,MA.toBinary(r))}sendMessageToPeers(t,e,r){const i={payloadType:e,peerIds:r,payload:t};n(this,Mt).sendMessage($e.sendMessageToPeers,NA.toBinary(i))}sendMessage(t,e,r){if(r&&r.length>0){this.sendMessageToPeers(t,e,r);return}this.sendMessageToRoom(t,e)}editMessage(t,e,r,i){return u(this,null,function*(){const a={chatId:t,payloadType:r,payload:e};i!==void 0&&(a.pinned=i);const o=yield n(this,Mt).sendMessagePromise($e.editMessage,$A.toBinary(a));return Jc.fromBinary(o.payload).message})}deleteMessage(t){return u(this,null,function*(){const e={chatId:t},r=yield n(this,Mt).sendMessagePromise($e.deleteMessage,GA.toBinary(e));return{id:Kc.fromBinary(r.payload).chatId}})}searchMessages(t,e){return u(this,null,function*(){var i,a,o,c;const r={searchTerm:t,timeStamp:(i=e.timestamp)!=null?i:Date.now(),size:(a=e.limit)!=null?a:75,from:(o=e.offset)!=null?o:0,reversed:(c=e.reversed)!=null?c:!0};try{const d=yield n(this,Mt).sendMessagePromise($e.searchChannelMessages,KA.toBinary(r));return ff.fromBinary(d.payload).messages}catch(d){return[]}})}setPinState(t,e){return u(this,null,function*(){const r={chatId:t,pinned:e},i=yield n(this,Mt).sendMessagePromise($e.pinMessage,BA.toBinary(r));return Wc.fromBinary(i.payload)})}on(t,e){let r,i;switch(t){case $e.sendMessageToRoom:{r=su.fromBinary.bind(su),i=su.create();break}case $e.sendMessageToPeers:{r=ru.fromBinary.bind(ru),i=ru.create();break}case $e.editMessage:{r=Jc.fromBinary.bind(Jc),i=Jc.create();break}case $e.pinMessage:{r=Wc.fromBinary.bind(Wc),i=Wc.create();break}case $e.deleteMessage:{r=Kc.fromBinary.bind(Kc),i=Kc.create();break}}if(!r){this.logger.warn(`ChatSocketHandler::Event ${t} is not recognized`);return}n(this,Mt).on(t,({payload:a})=>{let o=i;try{o=r(a)}catch(c){this.logger.error("chatSocketHandler::on::binary_decode_error",{error:c})}return e(o)})}}Mt=new WeakMap,Mn=new WeakMap;ei([P.trace("SocketService.getChatMessages")],yr.prototype,"getChatMessages",1);ei([P.trace("SocketService.getChatMessagesPaginated")],yr.prototype,"getChatMessagesPaginated",1);ei([P.trace("SocketService.sendMessageToRoom")],yr.prototype,"sendMessageToRoom",1);ei([P.trace("SocketService.sendMessageToPeers")],yr.prototype,"sendMessageToPeers",1);ei([P.trace("SocketService.sendMessage")],yr.prototype,"sendMessage",1);ei([P.trace("SocketService.editMessage")],yr.prototype,"editMessage",1);ei([P.trace("SocketService.deleteMessage")],yr.prototype,"deleteMessage",1);ei([P.trace("SocketService.searchMessages")],yr.prototype,"searchMessages",1);function RM(s){return s.replace(/([-_]\w)/g,t=>t[1].toUpperCase())}function _s(s){if(!s||typeof s!="object")return s;if(Array.isArray(s))return s.map(e=>_s(e));const t={};return Object.keys(s).forEach(e=>{const r=gr.validate(e)?e:RM(e);t[r]=_s(s[e])}),t}function bM(s){return s.replace(/[A-Z]/g,t=>`_${t.toLowerCase()}`)}function yf(s){if(!s||typeof s!="object")return s;if(Array.isArray(s))return s.map(e=>yf(e));const t={};return Object.keys(s).forEach(e=>{const r=gr.validate(e)?e:bM(e);t[r]=s[e]}),t}function yd(s,t={}){return s==null?{}:(Object.getOwnPropertyNames(s).forEach(e=>{if(typeof s[e]!="function"){if(typeof s[e]=="object"){yd(s[e],t[e]={});return}t[e]=s[e]}}),t)}class rg{constructor(t){h(this,"defaults");this.defaults={baseURL:t.baseURL,headers:{common:{}},timeout:t.timeout,retry:t.retry,retryDelay:t.retryDelay}}buildURL(t,e){const{baseURL:r}=this.defaults,i=t.startsWith("http")?t:`${r}${t.startsWith("/")?t:`/${t}`}`;if(e){const a=new URLSearchParams;return Object.entries(e).forEach(([o,c])=>{a.append(o,c)}),`${i}${i.includes("?")?"&":"?"}${a.toString()}`}return i}request(t){return u(this,null,function*(){var g;const e=((g=t.method)==null?void 0:g.toUpperCase())||"GET",r=this.buildURL(t.url||"",t.params),i=D(D({},this.defaults.headers.common),t.headers);e!=="GET"&&e!=="HEAD"&&t.data&&!i["Content-Type"]&&(i["Content-Type"]="application/json");const o=i["Content-Type"]==="application/json"?JSON.stringify(t.data):t.data,c={method:e,headers:i,body:e!=="GET"&&e!=="HEAD"&&t.data?o:void 0},d=t.timeout||this.defaults.timeout,l=t.retry!==void 0?t.retry:this.defaults.retry,p=t.retryDelay||this.defaults.retryDelay;try{const T=new AbortController,v=setTimeout(()=>T.abort(),d);c.signal=T.signal;const E=yield fetch(r,c);clearTimeout(v);let _=null;const C=E.headers.get("content-type");C&&C.includes("application/json")?_=yield E.json():_=yield E.text();const R={};E.headers.forEach((F,N)=>{R[N]=F});const L={data:_,status:E.status,statusText:E.statusText,headers:R,config:t};if(!E.ok)throw L;return L}catch(T){if(T instanceof Error&&l>0)return yield new Promise(v=>setTimeout(v,p)),this.defaults.baseURL===ui.apiBase.prod?this.defaults.baseURL=ui.apiBase.prodAlternate:this.defaults.baseURL===ui.apiBase.prodAlternate&&(this.defaults.baseURL=ui.apiBase.prod),this.request(G(D({},t),{retry:l-1}));throw T}})}get(r){return u(this,arguments,function*(t,e={}){return this.request(G(D({},e),{method:"GET",url:t}))})}post(i,a){return u(this,arguments,function*(t,e,r={}){return this.request(G(D({},r),{method:"POST",url:t,data:e}))})}put(i,a){return u(this,arguments,function*(t,e,r={}){return this.request(G(D({},r),{method:"PUT",url:t,data:e}))})}}const kM=3,AM=30,IM=8e3;class MM{constructor(t,e){h(this,"ipInfo");h(this,"fetchClient");h(this,"requests");h(this,"roomName");h(this,"roomUUID");h(this,"authToken");h(this,"organizationId");h(this,"iceServers");h(this,"pluginInformation");h(this,"userDetails");h(this,"roomDetails");h(this,"context");this.context=t;const{timeout:r=IM,retry:i=kM,retryDelay:a=AM,baseURL:o=ui.apiBase.prod,authToken:c,cachedUserDetails:d}=e||{};this.iceServers=d==null?void 0:d.iceServers,this.pluginInformation=d==null?void 0:d.pluginInformation,this.userDetails=d==null?void 0:d.userDetails,this.roomDetails=d==null?void 0:d.roomDetails,this.requests=new rg({baseURL:o,timeout:r,retry:i,retryDelay:a,responseType:"json"}),this.fetchClient=new rg({baseURL:"",timeout:r,retry:i,retryDelay:a,responseType:"json"}),this.setAuthToken(c,{bearer:!0});const l=this.requests.request.bind(this.requests);this.requests.request=p=>u(this,null,function*(){var T,v,E,_,C;const g=t.getValue("telemetry");try{g.injectContext(this.requests.defaults.headers.common);const R=yield l(p);return p.url!==g.logsEndpoint&&this.logger.debug("xhr::fetch",{networkCall:{status:R.status,statusText:R.statusText,baseURL:p.baseURL||this.requests.defaults.baseURL,url:p.url,method:p.method}}),R}catch(R){throw R?(((T=R.config)==null?void 0:T.url)!==g.logsEndpoint&&this.logger.error("xhr::fetch",{error:R,networkCall:{status:R.status,statusText:R.statusText,baseURL:((v=R.config)==null?void 0:v.baseURL)||this.requests.defaults.baseURL,url:(E=R.config)==null?void 0:E.url,retries:(_=R.config)==null?void 0:_.retry,method:(C=R.config)==null?void 0:C.method,isOnline:navigator.onLine?"online":"offline"}}),new A(R.message||"Network request failed","0011")):new A("Unknown network error occurred","0011")}})}get peerId(){return this.context.getValue("peerId")}get logger(){return this.context.getValue("logger")}setAuthToken(t,e){const{bearer:r}=e||{};this.authToken=t,this.requests.defaults.headers.common.Authorization=r?`Bearer ${t}`:t}setHeader(t,e){this.requests.defaults.headers.common[t]=e}setRoomName(t){this.roomName=t}setRoomUUID(t){this.roomUUID=t}setOrganizationId(t){this.organizationId=t}}var DM=Object.defineProperty,OM=Object.getOwnPropertyDescriptor,as=(s,t,e,r)=>{for(var i=r>1?void 0:r?OM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&DM(t,e,i),i};class Ht extends MM{constructor(e,r){super(e,r);h(this,"telemetry");this.telemetry=e.getValue("telemetry"),this.setHeader("x-realtimekit-version",e.getValue("sdkVersion"))}getIPDetails(){return u(this,null,function*(){var r;const{peerId:e}=this;try{const i=yield ah.getIPDetails({peerId:e,apiHostnames:tf(this.context),logger:Jm});if(this.logger.log("ipInfo",{ipInfo:i}),((r=i==null?void 0:i.loc)==null?void 0:r.length)>5)return i;throw Error("Insufficient data")}catch(i){this.logger.warn("APIClient.getIPDetails Failed to get ip details",{error:{name:i.name,message:i.message}});return}})}getICEServers(){return u(this,null,function*(){if(this.iceServers)return this.iceServers;const{success:e,iceServers:r}=(yield this.requests.get("/iceservers")).data;if(e)return(r==null?void 0:r.length)>0&&(this.iceServers=r),r})}getPlugins(){return u(this,null,function*(){var a,o,c,d,l,p,g;if(this.pluginInformation)return this.pluginInformation;const{plugins:e}=(yield this.requests.get("/v2/plugins/user")).data.data,r=((o=(a=this.context.getValue("flagsmith").getValue(Z.V1_PLUGINS))==null?void 0:a.toString())==null?void 0:o.split(","))||[],i=e.reduce((T,v)=>(T[r.includes(v.id)?"v1":"v2"].push(G(D({},v),{name:v.name.replace("v2","")})),T),{v1:[],v2:[]});return(l=(d=(c=this.context.getValue("modules"))==null?void 0:c.devTools)==null?void 0:d.plugins)!=null&&l.length&&((g=(p=this.context.getValue("modules"))==null?void 0:p.devTools)==null||g.plugins.forEach(T=>{var E,_,C;const v=G(D({},Xa),{tags:[...Xa.tags],baseUrl:`http://localhost:${T.port}`,name:T.name,picture:(E=T.picture)!=null?E:Xa.picture,createdAt:new Date().toISOString(),updatedAt:new Date().toISOString(),id:T.id,organizationId:this.organizationId,description:(_=T.description)!=null?_:Xa.description,staggered:(C=T.staggered)!=null?C:Xa.staggered});i.v2.push(v)})),i.v2})}getPluginDetails(e){return u(this,null,function*(){const{plugin:r}=(yield this.requests.get(`/v2/plugins/view/${e}`)).data.data;return r})}getPluginConfig(e){return u(this,null,function*(){return(yield this.fetchClient.get(`${e}/dyte-config.json`)).data})}authorizePlugin(e){return u(this,null,function*(){const r={peerId:this.peerId},{token:i}=(yield this.requests.post(`/v2/plugins/authorize/${e}`,r)).data.data;return i})}getPresignedUrls(e){return u(this,null,function*(){const r=Ia(this.context,"chat_upload_expiry"),i={roomUUID:this.roomUUID,filename:e,expiry:typeof r=="number"?r:void 0},{get_location:a,put_location:o}=(yield this.requests.post("/v2/meetings/chat-upload",i)).data.data;return{getLocation:a,putLocation:o}})}uploadFile(e,r){return u(this,null,function*(){if(navigator.isReactNative&&"uri"in e)try{yield fetch(r,{method:"PUT",headers:{"Content-Type":"application/octet-stream"},body:{uri:e.uri,name:e.name}})}catch(i){this.logger.error(`sendFileMessage::${i}`)}else yield this.fetchClient.put(r,e,{headers:{"Content-Type":e.type}})})}startLivestreaming(r){return u(this,arguments,function*({manualIngestion:e}){const i=_s(yield this.requests.post(`/v2/meetings/${this.context.getValue("meetingId")}/livestreams`,{manual_ingest:!!e})).data.data;return{playbackUrl:i.playbackUrl,status:i.status,manualIngest:i.manualIngest,ingestionCredentials:i.streamKey?{ingestionServer:i.ingestServer,streamKey:i.streamKey}:null}})}stopLivestreaming(){return u(this,null,function*(){return this.requests.post(`/v2/meetings/${this.context.getValue("meetingId")}/active-livestream/stop`)})}getActiveLivestream(){return u(this,null,function*(){const e=_s((yield this.requests.get(`/v2/meetings/${this.context.getValue("meetingId")}/active-livestream`)).data.data);return{playbackUrl:e.playbackUrl,status:e.status,manualIngest:e.manualIngest,ingestionCredentials:e.streamKey?{ingestionServer:e.ingestServer,streamKey:e.streamKey}:null}})}getUserDetails(){return u(this,null,function*(){if(this.userDetails)return this.userDetails;const e=(yield this.requests.get("v2/internals/participant-details")).data.data;return _s(e)})}startRecording(e,r){return u(this,null,function*(){return(yield this.requests.post("/v2/recordings",G(D({},yf(e)),{meeting_id:this.context.getValue("meetingId"),allow_multiple_recordings:!!r}))).data.data.id})}updateRecording(e,r){return u(this,null,function*(){return this.requests.put(`v2/recordings/${e}`,{action:r})})}getActiveRecording(){return u(this,null,function*(){const{status:e,id:r}=(yield this.requests.get(`v2/recordings/active-recording/${this.context.getValue("meetingId")}`)).data.data;return{status:e,id:r}})}getActiveTranscript(){return u(this,null,function*(){const{transcript_download_url:e}=(yield this.requests.get(`v2/meetings/${this.context.getValue("meetingId")}/active-transcript`)).data.data;try{return{transcript:(yield this.fetchClient.get(e)).data}}catch(r){throw new A("Cant fetch transcript s3 url","1801")}})}getRoomNodeData(){return u(this,null,function*(){const e=yield this.getIPDetails();if(this.ipInfo=e,this.roomDetails)return this.roomDetails;const{title:r}=_s((yield this.requests.post("v2/internals/rooms",{ip_information:e})).data.data);return{meetingTitle:r}})}}as([P.trace("APIClient.getIPDetails")],Ht.prototype,"getIPDetails",1);as([P.trace("APIClient.getICEServers")],Ht.prototype,"getICEServers",1);as([P.trace("APIClient.getPlugins")],Ht.prototype,"getPlugins",1);as([P.trace("APIClient.startLivestreaming")],Ht.prototype,"startLivestreaming",1);as([P.trace("APIClient.stopLivestreaming")],Ht.prototype,"stopLivestreaming",1);as([P.trace("APIClient.getActiveLivestream")],Ht.prototype,"getActiveLivestream",1);as([P.trace("APIClient.getUserDetails")],Ht.prototype,"getUserDetails",1);as([P.trace("APIClient.startRecording")],Ht.prototype,"startRecording",1);as([P.trace("APIClient.stopRecording")],Ht.prototype,"updateRecording",1);as([P.trace("APIClient.getActiveRecording")],Ht.prototype,"getActiveRecording",1);as([P.trace("APIClient.getActiveTranscript")],Ht.prototype,"getActiveTranscript",1);as([P.trace("APIClient.getRoomNodeData")],Ht.prototype,"getRoomNodeData",1);let bu;function NM(s,t){return bu=new Ht(s,t),bu}function ot(){return bu}const Oa={maxInvocations:5,period:1};function Rt(s,t){return function(e,r,i){const a=i.value;let o=0,c=Date.now();return i.value=function(...d){const l=Date.now(),p=t?this[t]:s;if(l-c>p.period*1e3&&(c=l,o=0),o>=p.maxInvocations)throw new A(`Method rate limit ${p.maxInvocations} invocations/${p.period}sec exceeded`,"0013");return o+=1,a.apply(this,d)},i}}var VM=Object.defineProperty,LM=Object.getOwnPropertyDescriptor,bs=(s,t,e,r)=>{for(var i=r>1?void 0:r?LM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&VM(t,e,i),i};const xM=["text","image","file","custom","poll"],id={maxInvocations:180,period:60};var se,pi,Ge,Dn,Id,Ef,wo,ku,yg;let $t=(yg=class extends Bt{constructor(t,e,r,i){const a=t.getValue("logger");super(a);m(this,Id);m(this,wo);h(this,"messages");m(this,se,void 0);m(this,pi,void 0);m(this,Ge,void 0);m(this,Dn,void 0);h(this,"maxTextLimit",2e3);f(this,Dn,t),f(this,Ge,e),f(this,se,r),f(this,pi,i),this.messages=[]}get telemetry(){return n(this,Dn).getValue("telemetry")}setMaxTextLimit(t){this.maxTextLimit=t}sendMessageInternal(t,e){return u(this,null,function*(){switch(t.type){case"text":{yield this.sendTextMessageInternal(t.message,e);break}case"image":yield this.sendImageMessageInternal(t.image,e);break;case"file":yield this.sendFileMessageInternal(t.file,e);break;default:this.logger.error("sendMessage::message_type_not_supported",{chat:{messageType:t.type}});break}})}sendTextMessageInternal(t,e){return u(this,null,function*(){var i,a,o,c,d,l;if(t.length>this.maxTextLimit)throw new A("Max character limit breached","0503");if(e&&e.length>0){if(!((i=n(this,se).permissions)!=null&&i.chatPrivate.canSend)||!((a=n(this,se).permissions)!=null&&a.chatPrivate.text))throw this.logger.error("sendTextMessage::private_chat_permission_denied"),new A("Could not send message to private chat.","0501")}else if(!((c=(o=n(this,se).permissions)==null?void 0:o.chatPublic)!=null&&c.canSend)||!((l=(d=n(this,se).permissions)==null?void 0:d.chatPublic)!=null&&l.text))throw this.logger.error("sendTextMessage::public_chat_permission_denied"),new A("Could not send message to public chat.","0501");if(!t)throw this.logger.error("sendTextMessage::message_can_not_be_empty"),new A("Message can not be empty.","0502");let r=[];e&&e.length>0&&(e.push(n(this,se).id),r=n(this,pi).joined.toArray().filter(p=>e.includes(p.id)).map(p=>p.userId),r.push(n(this,se).userId)),n(this,Ge).sendMessage(t,rs.TEXT,e)})}sendImageMessageInternal(t,e){return u(this,null,function*(){var i,a,o,c,d,l;if(e&&e.length>0){if(!((i=n(this,se).permissions)!=null&&i.chatPrivate.canSend)||!((a=n(this,se).permissions)!=null&&a.chatPrivate.files)){this.logger.error("sendImageMessage::private_chat_permission_denied");return}}else if(!((c=(o=n(this,se).permissions)==null?void 0:o.chatPublic)!=null&&c.canSend)||!((l=(d=n(this,se).permissions)==null?void 0:d.chatPublic)!=null&&l.files)){this.logger.error("sendImageMessage::permission_denied");return}if(!t){this.logger.error("sendImageMessage::required_argument_image_can_not_be_empty");return}if(!["image/gif","image/jpeg","image/png"].includes(t.type)){this.logger.error("sendImageMessage::image_type_not_supported",{chat:{imageType:t.type}});return}try{const p=ot(),{getLocation:g,putLocation:T}=yield p.getPresignedUrls(t.name);yield p.uploadFile(t,T);let v=[];e&&e.length>0&&(e.push(n(this,se).id),v=n(this,pi).joined.toArray().filter(E=>e.includes(E.id)).map(E=>E.userId),v.push(n(this,se).userId)),n(this,Ge).sendMessage(g,rs.IMAGE,e)}catch(p){throw new A("Error sending image message.","0500",this.logger)}})}sendFileMessageInternal(t,e){return u(this,null,function*(){var r,i,a,o,c,d;if(e&&e.length>0){if(!((r=n(this,se).permissions)!=null&&r.chatPrivate.canSend)||!((i=n(this,se).permissions)!=null&&i.chatPrivate.files)){this.logger.error("sendFileMessage::private_chat_permission_denied");return}}else if(!((o=(a=n(this,se).permissions)==null?void 0:a.chatPublic)!=null&&o.canSend)||!((d=(c=n(this,se).permissions)==null?void 0:c.chatPublic)!=null&&d.files)){this.logger.error("sendFileMessage::permission_denied");return}if(!t){this.logger.error("sendFileMessage::required_argument_file_can_not_be_empty");return}try{const l=ot(),{getLocation:p,putLocation:g}=yield l.getPresignedUrls(t.name);yield l.uploadFile(t,g);let T=[];e&&e.length>0&&(e.push(n(this,se).id),T=n(this,pi).joined.toArray().filter(E=>e.includes(E.id)).map(E=>E.userId),T.push(n(this,se).userId));const v=JSON.stringify({link:p,name:t.name,size:"size"in t?t.size:0});n(this,Ge).sendMessage(v,rs.FILE,e)}catch(l){throw new A("Error sending file message.","0500",this.logger)}})}get rateLimits(){return id}updateRateLimits(t,e){id.maxInvocations=t,id.period=e}sendTextMessage(t,e){return u(this,null,function*(){return this.sendTextMessageInternal(t,e)})}sendCustomMessage(t,e){return u(this,null,function*(){var a,o,c,d,l,p,g,T,v,E,_,C,R,L,F;if(e&&e.length>0){if(!((a=n(this,se).permissions)!=null&&a.chatPrivate.canSend)||!((o=n(this,se).permissions)!=null&&o.chatPrivate.files)||!((c=n(this,se).permissions)!=null&&c.chatPrivate.text)){this.logger.error("sendCustomMessage::private_chat_permission_denied");return}}else if(!((l=(d=n(this,se).permissions)==null?void 0:d.chatPublic)!=null&&l.canSend)||!((g=(p=n(this,se).permissions)==null?void 0:p.chatPublic)!=null&&g.files)||!((v=(T=n(this,se).permissions)==null?void 0:T.chatPublic)!=null&&v.text)){this.logger.error("sendCustomMessage::permission_denied");return}const r=N=>u(this,null,function*(){try{if(typeof N=="string")return{link:N};const B=ot(),{getLocation:j,putLocation:re}=yield B.getPresignedUrls(N.name);return yield B.uploadFile(N,re),{link:j,type:N.type,name:N.name,size:N.size}}catch(B){throw new A("Error sending image message.","0500",this.logger)}}),i=G(D({},t),{files:yield Promise.all((_=(E=t.files)!=null?E:[])==null?void 0:_.map(N=>u(this,null,function*(){return r(N)}))),images:yield Promise.all((R=(C=t.images)!=null?C:[])==null?void 0:R.map(N=>u(this,null,function*(){return r(N)}))),videos:yield Promise.all((F=(L=t.videos)!=null?L:[])==null?void 0:F.map(N=>u(this,null,function*(){return r(N)})))});n(this,Ge).sendMessage(JSON.stringify(i),rs.CUSTOM,e)})}sendImageMessage(t,e){return u(this,null,function*(){return this.sendImageMessageInternal(t,e)})}sendFileMessage(t,e){return u(this,null,function*(){return this.sendFileMessageInternal(t,e)})}sendMessage(t,e){return u(this,null,function*(){return this.sendMessageInternal(t,e)})}editTextMessage(t,e){return u(this,null,function*(){var r,i,a,o;if(!((i=(r=n(this,se).permissions)==null?void 0:r.chatPublic)!=null&&i.canSend)||!((o=(a=n(this,se).permissions)==null?void 0:a.chatPublic)!=null&&o.text)){this.logger.error("editTextMessage::permission_denied");return}if(!e){this.logger.error("editTextMessage::message_can_not_be_empty");return}n(this,Ge).editMessage(t,e,rs.TEXT)})}editImageMessage(t,e){return u(this,null,function*(){var i,a,o,c;if(!((a=(i=n(this,se).permissions)==null?void 0:i.chatPublic)!=null&&a.canSend)||!((c=(o=n(this,se).permissions)==null?void 0:o.chatPublic)!=null&&c.files)){this.logger.error("editImageMessage::permission_denied");return}if(!e){this.logger.error("editImageMessage::required_argument_image_can_not_be_empty");return}if(!["image/gif","image/jpeg","image/png"].includes(e.type)){this.logger.error("sendImageMessage::image_type_not_supported",{chat:{imageType:e.type}});return}try{const d=ot(),{getLocation:l,putLocation:p}=yield d.getPresignedUrls(e.name);yield d.uploadFile(e,p),n(this,Ge).editMessage(t,l,rs.IMAGE)}catch(d){throw new A("Error editing image message.","0500",this.logger)}})}editFileMessage(t,e){return u(this,null,function*(){var r,i,a,o;if(!((i=(r=n(this,se).permissions)==null?void 0:r.chatPublic)!=null&&i.canSend)||!((o=(a=n(this,se).permissions)==null?void 0:a.chatPublic)!=null&&o.files)){this.logger.error("sendFileMessage::permission_denied");return}if(!e){this.logger.error("sendFileMessage::required_argument_file_can_not_be_empty");return}try{const c=ot(),{getLocation:d,putLocation:l}=yield c.getPresignedUrls(e.name);yield c.uploadFile(e,l),n(this,Ge).editMessage(t,JSON.stringify({link:d,name:e.name,size:"size"in e?e.size:0}),rs.FILE)}catch(c){throw new A("Error editing file message.","0500",this.logger)}})}editMessage(t,e){return u(this,null,function*(){switch(e.type){case"text":{this.editTextMessage(t,e.message);break}case"image":{this.editImageMessage(t,e.image);break}case"file":{this.editFileMessage(t,e.file);break}default:{this.logger.error("editMessage::message_type_not_supported",{chat:{messageType:e.type}});break}}})}deleteMessage(t){return u(this,null,function*(){n(this,Ge).deleteMessage(t)})}getMessagesByUser(t){return this.messages.filter(e=>e.userId===t)}getMessagesByType(t){return this.messages.filter(e=>e.type===t)}pin(t){return u(this,null,function*(){if(!n(this,wo,ku))throw new A("Can`t pin message without joining room","0505");try{yield n(this,Ge).setPinState(t,!0)}catch(e){throw new A(`No message found with id: ${t}`,"0504")}})}unpin(t){return u(this,null,function*(){if(!n(this,wo,ku))throw new A("Can`t unpin message without joining room","0505");try{yield n(this,Ge).setPinState(t,!1)}catch(e){throw new A(`No message found with id: ${t}`,"0504")}})}fetchPublicMessages(i){return u(this,arguments,function*({timestamp:t=new Date().getTime(),limit:e,direction:r="after"}){return(yield n(this,Ge).getChatMessagesPaginated(t,e,r==="before")).messages.map(c=>is.formatSocketPeerMessage(c))})}fetchPrivateMessages(a){return u(this,arguments,function*({timestamp:t=new Date().getTime(),limit:e,direction:r="after",userId:i}){return(yield n(this,Ge).getChatMessagesPaginated(t,e,r==="before",{oneofKind:"userId",userId:i})).messages.map(d=>is.formatSocketPeerMessage(d))})}fetchPinnedMessages(i){return u(this,arguments,function*({timestamp:t=new Date().getTime(),limit:e,direction:r="after"}){return(yield n(this,Ge).getChatMessagesPaginated(t,e,r==="before",{oneofKind:"pinned",pinned:!0})).messages.map(c=>is.formatSocketPeerMessage(c))})}getMessages(t,e,r,i=0){return u(this,null,function*(){const a=yield n(this,Ge).getChatMessagesPaginated(t,e,r);return{messages:a.messages.map(o=>is.formatSocketPeerMessage(o)),next:a.next}})}searchMessages(t,e){return u(this,null,function*(){throw new A("searchMessages is disabled! Please use `fetchPublicMessages` method instead.","0506")})}get pinned(){return this.messages.filter(t=>t.pinned)}},se=new WeakMap,pi=new WeakMap,Ge=new WeakMap,Dn=new WeakMap,Id=new WeakSet,Ef=function(){return n(this,Dn).getValue("connectionHandler")},wo=new WeakSet,ku=function(){return n(this,Id,Ef).socketJoined===!0},yg);bs([P.trace("Chat.sendTextMessage"),Rt(id)],$t.prototype,"sendTextMessage",1);bs([P.trace("Chat.sendImageMessage"),Rt({maxInvocations:20,period:60})],$t.prototype,"sendImageMessage",1);bs([P.trace("Chat.sendFileMessage"),Rt({maxInvocations:20,period:60})],$t.prototype,"sendFileMessage",1);bs([P.trace("Chat.sendMessage"),Rt({maxInvocations:180,period:60})],$t.prototype,"sendMessage",1);bs([P.trace("Chat.editTextMessage")],$t.prototype,"editTextMessage",1);bs([P.trace("Chat.editImageMessage")],$t.prototype,"editImageMessage",1);bs([P.trace("Chat.editFileMessage")],$t.prototype,"editFileMessage",1);bs([P.trace("Chat.editMessage")],$t.prototype,"editMessage",1);bs([P.trace("Chat.deleteMessage")],$t.prototype,"deleteMessage",1);bs([P.trace("Chat.searchMessages")],$t.prototype,"searchMessages",1);$t=bs([dt("0500")],$t);var UM=Object.defineProperty,$M=Object.getOwnPropertyDescriptor,FM=(s,t,e,r)=>{for(var i=r>1?void 0:r?$M(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&UM(t,e,i),i},gi,Eg;const wr=(Eg=class{constructor(s,t,e,r){h(this,"chat");h(this,"chatSocketHandler");h(this,"self");m(this,gi,void 0);f(this,gi,s),this.chatSocketHandler=t,this.chat=new $t(s,t,e,r),this.self=e,this.setupEvents()}get telemetry(){return n(this,gi).getValue("telemetry")}get logger(){return n(this,gi).getValue("logger")}static init(s,t,e,r){return u(this,null,function*(){return new wr(s,t,e,r)})}static formatMessage(s){return G(D({},s),{time:new Date(s.time),type:xM[s.type]})}static formatSocketPeerMessage(s){const t=s.createdAt*1e3,e={displayName:s.displayName,id:s.chatId,time:t,timeMs:s.createdAtMs,type:s.payloadType,isEdited:s.isEdited,userId:s.userId,targetUserIds:s.targetUserIds,message:"",link:"",name:"",html:"",images:[],videos:[],files:[],size:0,pinned:s.pinned};switch(e.type){case rs.TEXT:{e.message=s.payload;break}case rs.IMAGE:{e.link=s.payload;break}case rs.FILE:{const{link:r,name:i,size:a}=JSON.parse(s.payload);e.link=r,e.name=i,e.size=a;break}case rs.CUSTOM:{const{html:r,images:i,message:a,videos:o,files:c}=JSON.parse(s.payload);e.message=a,e.html=r,e.images=i,e.videos=o,e.files=c;break}}return wr.formatMessage(e)}getChatMessages(){return u(this,null,function*(){if(this.self.config.viewType==="LIVESTREAM")return;const s=yield this.chatSocketHandler.getChatMessages();if(!(s!=null&&s.payload))return;const t=ff.fromBinary(s.payload).messages;this.chat.messages=t.map(e=>wr.formatSocketPeerMessage(e))})}setupEvents(){n(this,gi).getValue("peerSessionStore").on(b.SOCKET_SERVICE_ROOM_JOINED,()=>u(this,null,function*(){this.getChatMessages()})),this.chatSocketHandler.on($e.sendMessageToRoom,s=>{if(!s.message)return;const t=wr.formatSocketPeerMessage(s.message);this.chat.messages=[...this.chat.messages,t],this.chat.emit("chatUpdate",{action:"add",message:t,messages:this.chat.messages})}),this.chatSocketHandler.on($e.sendMessageToPeers,s=>{const t=wr.formatSocketPeerMessage(s.message);this.chat.messages=[...this.chat.messages,t],this.chat.emit("chatUpdate",{action:"add",message:t,messages:this.chat.messages})}),this.chatSocketHandler.on($e.editMessage,s=>{if(!s.message)return;const t=wr.formatSocketPeerMessage(s.message),e=this.chat.messages.findIndex(r=>r.id===t.id);e!==-1&&(this.chat.messages[e]=t),this.chat.emit("chatUpdate",{action:"edit",message:t,messages:this.chat.messages})}),this.chatSocketHandler.on($e.deleteMessage,s=>{const t=this.chat.messages.findIndex(r=>r.id===s.chatId);let e={id:s.chatId};t!==-1&&([e]=this.chat.messages.splice(t,1)),this.chat.emit("chatUpdate",{action:"delete",message:e,messages:this.chat.messages})}),this.chatSocketHandler.on($e.pinMessage,s=>{const t=this.chat.messages.findIndex(r=>r.id===s.chatId),e=wr.formatSocketPeerMessage(s.message);t!==-1&&(this.chat.messages[t]=e),this.chat.emit("chatUpdate",{action:"edit",message:e,messages:this.chat.messages}),s.pinned?this.chat.emit("pinMessage",{message:e,messages:this.chat.messages}):this.chat.emit("unpinMessage",{message:e,messages:this.chat.messages})})}},gi=new WeakMap,Eg);let is=wr;FM([P.trace("ChatController.setupEvents")],is.prototype,"setupEvents",1);var BM=Object.defineProperty,HM=Object.getOwnPropertyDescriptor,qM=(s,t,e,r)=>{for(var i=r>1?void 0:r?HM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&BM(t,e,i),i},Md,Pf,Dd,_f,On,Nn,Ro,Pg;let Au=(Pg=class extends Bt{constructor(t,e,r){const i=t.getValue("logger");super(i);m(this,Md);m(this,Dd);h(this,"items");m(this,On,void 0);m(this,Nn,void 0);m(this,Ro,void 0);f(this,Ro,t),f(this,On,e),f(this,Nn,r),this.items=[]}create(t,e,r=!1,i=!1){return u(this,null,function*(){if(!n(this,Dd,_f))throw new A("Can't create polls without joining room","0705");if(!n(this,On).permissions.polls.canCreate){this.logger.error("Polls::create::permission_denied");return}if(!t||!e){this.logger.error("Polls::question_and_options_can_not_be_empty",{polls:{hasQuestion:!!t,optionsLength:e==null?void 0:e.length}});return}if(e.length<2){this.logger.error("Polls::there_must_be_at_least_two_options",{polls:{hasQuestion:!!t,optionsLength:e.length}});return}yield n(this,Nn).createPoll(t,e,r,i)})}vote(t,e){return u(this,null,function*(){if(!n(this,On).permissions.polls.canVote){this.logger.error("Polls::vote::permission_denied");return}yield n(this,Nn).votePoll(t,e)})}},Md=new WeakSet,Pf=function(){return n(this,Ro).getValue("connectionHandler")},Dd=new WeakSet,_f=function(){var t;return((t=n(this,Md,Pf))==null?void 0:t.socketJoined)===!0},On=new WeakMap,Nn=new WeakMap,Ro=new WeakMap,Pg);Au=qM([dt("0700")],Au);var jM=Object.defineProperty,GM=Object.getOwnPropertyDescriptor,WM=(s,t,e,r)=>{for(var i=r>1?void 0:r?GM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&jM(t,e,i),i},Ir,Vn,mi,_g;const pn=(_g=class{constructor(s,t,e){h(this,"polls");m(this,Ir,void 0);m(this,Vn,void 0);m(this,mi,void 0);this.polls=new Au(s,t,e),f(this,Vn,t),f(this,Ir,s),f(this,mi,e),this.setupEvents()}get telemetry(){return n(this,Ir).getValue("telemetry")}get logger(){return n(this,Ir).getValue("logger")}static init(s,t,e){return u(this,null,function*(){return new pn(s,t,e)})}canViewPolls(){return n(this,Vn).permissions.polls.canView}setupEvents(){const s={[Hs.createPoll]:r=>{r.poll&&this.updatePoll(pn.formatSocketServicePoll(r.poll))},[Hs.updatePoll]:r=>{r.poll&&this.updatePoll(pn.formatSocketServicePoll(r.poll))},[Hs.votePoll]:r=>{r.poll&&this.updatePoll(pn.formatSocketServicePoll(r.poll))}},t=()=>{n(this,Ir).getValue("peerSessionStore").on(b.SOCKET_SERVICE_ROOM_JOINED,()=>{this.getPolls()}),Object.keys(s).map(Number).forEach(r=>{n(this,mi).on(r,s[r])})},e=()=>{n(this,Ir).getValue("peerSessionStore").on(b.SOCKET_SERVICE_ROOM_JOINED,()=>{this.getPolls()}),Object.keys(s).map(Number).forEach(r=>{n(this,mi).removeListeners(r)})};n(this,Vn).permissions.on("permissionsUpdate",r=>u(this,null,function*(){var i;r!=null&&r.polls&&((i=r==null?void 0:r.polls)!=null&&i.canView?(yield this.getPolls(),t()):(this.polls.items=[],e()))})),this.canViewPolls()&&t()}updatePoll(s){if(!this.canViewPolls())return;const t=this.polls.items.findIndex(e=>e.id===s.id);if(t>-1){const e=JSON.stringify(this.polls.items[t]);this.polls.items[t]=s,e!==JSON.stringify(s)&&this.polls.emit("pollsUpdate",{polls:this.polls.items,newPoll:!1});return}this.polls.items=[...this.polls.items,s],this.polls.emit("pollsUpdate",{polls:this.polls.items,newPoll:!0})}getPolls(){return u(this,null,function*(){const s=yield n(this,mi).getPolls();if(!(s!=null&&s.payload))return;const{polls:t}=cM.fromBinary(s.payload);this.polls.items=t.map(e=>pn.formatSocketServicePoll(e))})}static formatSocketServicePoll(s){const t=s.options.map(e=>({count:e.count,text:e.text,votes:e.votes.map(r=>({id:r.userId,name:r.name}))}));return{anonymous:s.anonymous,createdBy:s.createdBy,createdByUserId:s.createdByUserId,hideVotes:s.hideVotes,id:s.pollId,options:t,question:s.question,voted:s.votes}}},Ir=new WeakMap,Vn=new WeakMap,mi=new WeakMap,_g);let Cf=pn;WM([P.trace("PollController.setupEvents")],Cf.prototype,"setupEvents",1);var JM=Object.defineProperty,KM=Object.getOwnPropertyDescriptor,zM=(s,t,e,r)=>{for(var i=r>1?void 0:r?KM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&JM(t,e,i),i},wf=(s=>(s[s.User=0]="User",s[s.Meeting=1]="Meeting",s))(wf||{}),Ln,bo,Mu,fi,ko,Cg;let Iu=(Cg=class extends Bt{constructor(t,e,r,i,a){const o=t.getValue("logger");super(o);m(this,bo);h(this,"selfActiveTab");h(this,"broadcastTabChanges");m(this,Ln,void 0);m(this,fi,void 0);m(this,ko,void 0);h(this,"viewType");h(this,"meetingStartedTimestamp");h(this,"meetingTitle");h(this,"sessionId");f(this,Ln,t),f(this,fi,e),this.viewType=r,f(this,ko,i),this.meetingTitle=a,this.broadcastTabChanges=e.permissions.canSpotlight}get socketState(){return n(this,bo,Mu).socketState}get mediaState(){return n(this,bo,Mu).mediaState}get meetingId(){return n(this,Ln).getValue("meetingId")}setBroadcastTabChanges(t){if(!n(this,fi).permissions.canSpotlight)throw this.logger.error("Spotlight::setSpotlighted::permission_denied"),new A("User does not have permission to toggle spotlight","0801");this.broadcastTabChanges=t,this.emit("broadcastTabChangesUpdate",this.broadcastTabChanges),this.broadcastTabChanges&&this.assertActiveTabToRoom()}setSelfActiveTab(t,e){var r;this.logger.info("Spotlight::setActiveTab",{spotlight:{currentTab:{id:t.id,type:t.type}}}),this.selfActiveTab=t,e===0&&this.emit("selfTabUpdate",t),(r=n(this,fi).permissions)!=null&&r.canSpotlight&&this.broadcastTabChanges&&e===0&&this.assertActiveTabToRoom()}assertActiveTabToRoom(){n(this,ko).broadcastMessage("spotlight",{userId:n(this,fi).userId,currentTab:this.selfActiveTab})}},Ln=new WeakMap,bo=new WeakSet,Mu=function(){return n(this,Ln).getValue("connectionHandler")},fi=new WeakMap,ko=new WeakMap,Cg);Iu=zM([dt("0800")],Iu);function YM(s){let t="",e=[""];const r=[e];let i=0,a=0,o=!0,c;for(c of s)c==='"'?(o&&c===t&&(e[i]+=c),o=!o):c===","&&o?c=e[++i]="":c===`
|
|
6
|
-
|
|
7
|
-
`).map(e=>Qr.parseTranscript(e,!1)).filter(Boolean):[]}getActiveTranscript(){return u(this,null,function*(){try{const t=ot(),{transcript:e}=yield t.getActiveTranscript();this.transcripts=Qr.parseTranscripts(e)}catch(t){}})}onTranscript(t){return u(this,null,function*(){var r;const e=this.transcripts.filter(({peerId:i})=>i===t.peerId);if((r=e==null?void 0:e.at(-1))!=null&&r.isPartialTranscript){const i=e.at(-1);i.transcript=t.transcript,i.isPartialTranscript=t.isPartialTranscript,this.emit("transcript",i);return}this.transcripts=[...this.transcripts,t],this.emit("transcript",t)})}},Ao=new WeakMap,wg);Rf([P.trace("Ai.getActiveTranscript")],Qr.prototype,"getActiveTranscript",1);Qr=Rf([dt("0000")],Qr);var ZM=Object.defineProperty,e0=Object.getOwnPropertyDescriptor,t0=(s,t,e,r)=>{for(var i=r>1?void 0:r?e0(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&ZM(t,e,i),i},Mr,xn,Dt,Rg;const bf=(Rg=class{constructor(s,t,e,r,i,a){h(this,"meta");h(this,"ai");m(this,Mr,void 0);m(this,xn,void 0);h(this,"aiSocketHandler");m(this,Dt,void 0);f(this,Dt,s),this.meta=new Iu(s,t,t.config.viewType,e,a),this.ai=r,f(this,Mr,t),f(this,xn,e),this.aiSocketHandler=i,this.setupEvents()}get telemetry(){return n(this,Dt).getValue("telemetry")}get logger(){return n(this,Dt).getValue("logger")}static init(s,t,e,r,i){return u(this,null,function*(){const a=yield Qr.init(s,t.permissions.transcriptionEnabled);return new bf(s,t,e,a,r,i)})}conditionallySetActiveTab(s){var t;s!=null&&s.currentTab&&((t=this.meta.selfActiveTab)==null?void 0:t.id)!==s.currentTab.id&&(this.meta.setSelfActiveTab(s.currentTab,wf.Meeting),this.meta.emit("activeTabUpdate",s.currentTab))}setupEvents(){n(this,Dt).getValue("peerSessionStore").on(b.TRANSPORT_STATE_UPDATE,s=>{this.meta.emit("mediaConnectionUpdate",s)}),n(this,Dt).getValue("peerSessionStore").on(b.SOCKET_STATE_UPDATE,s=>{this.meta.emit("socketConnectionUpdate",s)}),n(this,Dt).getValue("peerSessionStore").on(b.ROOM_STATE,({createdAt:s,roomUuid:t})=>{const e=this.meta.meetingStartedTimestamp;if(t&&(this.meta.sessionId=t),s&&!e){const r=new Date(s*1e3);this.meta.meetingStartedTimestamp=r,this.meta.emit("meetingStartTimeUpdate",{meetingStartedTimestamp:this.meta.meetingStartedTimestamp})}}),n(this,Dt).getValue("peerSessionStore").on(b.PRODUCER_SCORE_UPDATE,({score:s})=>{s<5&&this.meta.emit("poorConnection",{score:s})}),n(this,Mr).permissions.canSpotlight&&(this.logger.info("MetaController::Asserting Spotlight"),this.meta.selfActiveTab&&n(this,xn).broadcastMessage("spotlight",{userId:n(this,Mr).userId,currentTab:this.meta.selfActiveTab})),n(this,Dt).getValue("peerSessionStore").on(b.PEER_JOINED_INTERNAL,s=>u(this,null,function*(){n(this,Mr).permissions.canSpotlight&&this.meta.selfActiveTab&&n(this,xn).broadcastToPeers("spotlight",[s.id],{userId:n(this,Mr).userId,currentTab:this.meta.selfActiveTab})})),n(this,Dt).getValue("peerSessionStore").on(b.ROOM_MESSAGE,s=>{var e,r;let t;if("type"in s){if(s.type!=="spotlight")return;t=D(D({},s),s.payload)}else if("roomMessageType"in s){if(s.roomMessageType!=="spotlight")return;t=s}else return;this.logger.info("Spotlight Assertion Received",{spotlight:{spotlighter:{id:t.userId},currentTab:{id:(e=t.currentTab)==null?void 0:e.id,type:(r=t.currentTab)==null?void 0:r.type}}}),this.conditionallySetActiveTab(t)}),n(this,Dt).getValue("peerSessionStore").on(b.MESSAGE,s=>{var e,r;let t;if("type"in s){if(s.type!=="spotlight")return;t=D(D({},s),s.payload)}else if("roomMessageType"in s){if(s.roomMessageType!=="spotlight")return;t=s}else return;this.logger.info("Spotlight Assertion Received",{spotlight:{spotlighter:{id:t.userId},currentTab:{id:(e=t.currentTab)==null?void 0:e.id,type:(r=t.currentTab)==null?void 0:r.type}}}),this.conditionallySetActiveTab(t)}),this.aiSocketHandler.on(U.transcript,s=>{const{meetingId:t,transcript:e,isPartial:r}=s;let i;try{i=Qr.parseTranscript(e,r)}catch(d){this.logger.error(`Failed to parse transcript: ${e}`,d)}if(!i){this.logger.warn("Received empty transcript data");return}this.ai.onTranscript(i),this.meta.emit("transcript",i);const{peerId:a,name:o,transcript:c}=i;this.logger.debug(`${t} Received transcript for peer ${a} - ${o}: ${c}`)})}},Mr=new WeakMap,xn=new WeakMap,Dt=new WeakMap,Rg);let kf=bf;t0([P.trace("MetaController.setupEvents")],kf.prototype,"setupEvents",1);const eo={},Er={executeWithLock({methodName:s,lockName:t,timeout:e}){return(r,i,a)=>{const o=a.value;return a.value=function(...d){var E,_;const l=(_=(this==null?void 0:this.peerId)||((E=d[0])==null?void 0:E.authToken))!=null?_:"",p=`${t}-${l}`,g=this==null?void 0:this.logger;if(eo[p]){const C=new Error(`Unsupported concurrent calls on method: ${s}.`);throw C.name="UnsupportedConcurrentMethodExecution",g==null||g.error("Locker::UnsupportedConcurrentMethodExecution",{error:{stack:C.stack},locker:{methodName:s,lockName:p}}),C}eo[p]=!0;const T=setTimeout(()=>delete eo[p],e),v=o.apply(this,d);return Promise.resolve(v).then(()=>{delete eo[p],clearTimeout(T)}).catch(()=>{delete eo[p],clearTimeout(T)}),v},a}}};var s0=Object.defineProperty,r0=Object.getOwnPropertyDescriptor,cn=(s,t,e,r)=>{for(var i=r>1?void 0:r?r0(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&s0(t,e,i),i},Kt,Od,ie,Io,As,We,Mo,Du,Un,nd;class ti extends Bt{constructor(e,r,i,a,o){const c=e.getValue("logger");super(c);m(this,Mo);m(this,Un);m(this,Kt,void 0);m(this,Od,void 0);m(this,ie,void 0);m(this,Io,void 0);m(this,As,void 0);m(this,We,void 0);f(this,We,e),f(this,Kt,a),f(this,Od,o),f(this,ie,r),f(this,Io,i),f(this,As,[]),this.setupEvents()}get telemetry(){return n(this,We).getValue("telemetry")}get status(){return n(this,We).getValue("stageStatus")}setupEvents(){const e={[b.GET_STAGE_REQUESTS]:a=>u(this,null,function*(){f(this,As,a)}),[b.UPDATE_STAGE_REQUESTS]:o=>u(this,[o],function*({add:a}){const c=n(this,As).length,{stageRequests:d}=this.getAccessRequests();(a||d.length>c)&&this.emit("newStageRequest",{count:d.length}),this.emit("stageAccessRequestUpdate",d)})},r=()=>{Object.entries(e).forEach(([a,o])=>{n(this,We).getValue("peerSessionStore").onAsync(a,o)})},i=()=>{Object.entries(e).forEach(([a,o])=>{n(this,We).getValue("peerSessionStore").removeListener(a,o)})};n(this,ie).permissions.on("permissionsUpdate",a=>{const{canAcceptProductionRequests:o}=a;o!==void 0&&(n(this,ie).permissions.acceptStageRequests?(r(),n(this,Kt).getStageRequests()):(i(),f(this,As,[]),this.emit("stageAccessRequestUpdate",n(this,As))))}),n(this,ie).permissions.acceptStageRequests&&r()}getAccessRequests(){if(!n(this,ie).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new A("Stage is disabled","2003");if(!n(this,ie).permissions.acceptStageRequests)throw this.logger.error("Stage::get_access_request::permission_denied"),new A("You do not have permission to perform this action","2001");const e=n(this,Io).joined.toArray().filter(r=>r.stageStatus==="REQUESTED_TO_JOIN_STAGE").map(r=>({displayName:r.name,userId:r.userId,peerId:r.id}));return f(this,As,e),{stageRequests:n(this,As)}}requestAccess(){return u(this,null,function*(){if(!n(this,ie).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new A("Stage is disabled","2003");if(this.status!=="OFF_STAGE")throw new A(`Unable to request access you are currently ${this.status}`,"2006");if(n(this,ie).permissions.stageAccess===H.Allowed){x(this,Un,nd).call(this,"ACCEPTED_TO_JOIN_STAGE");return}n(this,Kt).requestAccess(),x(this,Un,nd).call(this,"REQUESTED_TO_JOIN_STAGE")})}cancelRequestAccess(){return u(this,null,function*(){if(!n(this,ie).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new A("Stage is disabled","2003");n(this,Kt).cancelRequestAccess(),x(this,Un,nd).call(this,"OFF_STAGE")})}grantAccess(e){if(!n(this,ie).roomJoined)throw new A("Can`t grant for participant without joining room");if(!n(this,ie).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new A("Stage is disabled","2003");if(!n(this,ie).permissions.acceptStageRequests)throw this.logger.error("Stage::grant_access::permission_denied"),new A("You do not have permission to perform this action","2001");return n(this,Kt).grantAccess(e)}denyAccess(e){if(!n(this,ie).roomJoined)throw new A("Can`t rejectRequestToJoinStage for participant without joining room","2005");if(!n(this,ie).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new A("Stage is disabled","2003");if(!n(this,ie).permissions.acceptStageRequests)throw this.logger.error("Stage::deny_access::permission_denied"),new A("You do not have permission to perform this action","2001");return n(this,Kt).denyAccess(e)}get peerId(){return n(this,We).getValue("peerId")}join(){return u(this,null,function*(){const e=n(this,We).getValue("viewType");if(this.status==="ON_STAGE")throw new A("You are already on stage.","2006");if(this.status!=="ACCEPTED_TO_JOIN_STAGE"||n(this,ie).permissions.stageAccess===H.NotAllowed)throw new A(`Unable to join stage you are currently ${this.status}`,"2006");if(n(this,We).setValue("stageStatus","ON_STAGE",!1),yield n(this,Kt).joinStage(),e===pr.Livestream){yield n(this,We).getValue("selfController").joinRoom();return}n(this,We).notify("stageStatus"),n(this,ie).audioEnabled&&n(this,Mo,Du).shareMic(n(this,ie).audioTrack),n(this,ie).videoEnabled&&n(this,Mo,Du).shareWebcam(n(this,ie).videoTrack)})}leave(){return u(this,null,function*(){if(!n(this,ie).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new A("Stage is disabled","2003");if(!(this.status==="ON_STAGE"||this.status==="ACCEPTED_TO_JOIN_STAGE"))throw new A(`Unable to leave stage you are currently ${this.status}`,"2006");n(this,ie).setIsPinned(!1),n(this,We).setValue("stageStatus","OFF_STAGE",!1),yield n(this,Kt).leaveStage(n(this,ie).userId);try{yield n(this,We).getValue("peerSessionStore").emitAsync(b.LEAVE_MEDIA_ROOM,"stageLeft")}catch(e){this.logger.error("Stage::leave::emitAsync::failed",{error:e})}n(this,We).notify("stageStatus")})}kick(e){return u(this,null,function*(){if(!n(this,ie).roomJoined)throw new A("Can`t kick participant without joining room","2005");if(!n(this,ie).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new A("Stage is disabled","2003");if(!n(this,ie).permissions.acceptStageRequests)throw this.logger.error("Stage::kick::permission_denied"),new A("You do not have permissions for kick","2001");return n(this,Kt).kick(e)})}}Kt=new WeakMap,Od=new WeakMap,ie=new WeakMap,Io=new WeakMap,As=new WeakMap,We=new WeakMap,Mo=new WeakSet,Du=function(){return n(this,We).getValue("roomNodeClient")},Un=new WeakSet,nd=function(e){return u(this,null,function*(){this.status!==e&&n(this,We).setValue("stageStatus",e)})};cn([P.trace("Stage.getStageRequests")],ti.prototype,"getAccessRequests",1);cn([P.trace("Stage.requestAccess")],ti.prototype,"requestAccess",1);cn([P.trace("Stage.cancelRequestAccess")],ti.prototype,"cancelRequestAccess",1);cn([P.trace("Stage.grantAccess")],ti.prototype,"grantAccess",1);cn([P.trace("Stage.denyAccess")],ti.prototype,"denyAccess",1);cn([Er.executeWithLock({methodName:"joinStage",lockName:"Stage.join",timeout:5e3}),P.trace("Stage.joinStage")],ti.prototype,"join",1);cn([P.trace("Stage.leaveStage")],ti.prototype,"leave",1);function i0(s){return!(s.viewType==="LIVESTREAM"||s.viewType==="CHAT")}function wh(s){switch(s){case dr.UNSPECIFIED:return"OFF_STAGE";case dr.REQUESTED_STAGE:return"REQUESTED_TO_JOIN_STAGE";case dr.APPROVED_STAGE:return"ACCEPTED_TO_JOIN_STAGE";case dr.OFF_STAGE:return"OFF_STAGE";case dr.ON_STAGE:return"ON_STAGE";default:return"OFF_STAGE"}}var n0=Object.defineProperty,a0=Object.getOwnPropertyDescriptor,o0=(s,t,e,r)=>{for(var i=r>1?void 0:r?a0(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&n0(t,e,i),i},Dr,hs,Or,Do,ht;class Af{constructor(t,e,r,i,a){h(this,"stage");m(this,Dr,void 0);m(this,hs,void 0);m(this,Or,void 0);m(this,Do,0);m(this,ht,void 0);f(this,ht,t),this.stage=new ti(t,i,a,e,r),f(this,Or,e),f(this,Dr,i),f(this,hs,a),this.setupEvents()}get telemetry(){return n(this,ht).getValue("telemetry")}get logger(){return n(this,ht).getValue("logger")}setupEvents(){n(this,ht).subscribe("stageStatus",t=>{this.stage.emit("stageStatusUpdate",t)}),n(this,Or).on(U.grantStageAccess,()=>{n(this,Dr).permissions.stageAccess!==H.Allowed&&(this.stage.emit("stageRequestApproved"),this.setStageStatus("ACCEPTED_TO_JOIN_STAGE"))}),n(this,Or).on(U.peerStageStatusUpdate,t=>{t!==void 0&&(t.peerId===n(this,Dr).id?this.selfStageStatusHandler(t):this.peerStageStatusHandler(t))}),n(this,Or).on(U.denyStageAccess,()=>{n(this,Dr).permissions.stageAccess!==H.Allowed&&(this.stage.emit("stageRequestRejected"),this.setStageStatus("OFF_STAGE"))}),n(this,Or).on(U.getStageRequests,t=>u(this,null,function*(){var r;if(n(this,Dr).permissions.stageAccess!==H.Allowed)return;const e=(r=t==null?void 0:t.stageRequests)!=null?r:[];yield n(this,ht).getValue("peerSessionStore").emitAsync(b.GET_STAGE_REQUESTS,e),n(this,Do)<e.length&&e.length>0&&this.stage.emit("newStageRequest",{count:e.length}),f(this,Do,e.length),this.stage.emit("stageAccessRequestUpdate",e)}))}getCurrentStageRequests(){return n(this,hs).joined.toArray().filter(e=>e.stageStatus==="REQUESTED_TO_JOIN_STAGE").map(e=>({displayName:e.name,userId:e.userId,peerId:e.id}))}setStageStatus(t){return u(this,null,function*(){this.stage.status!==t&&n(this,ht).setValue("stageStatus",t)})}selfStageStatusHandler(t){const e=wh(t.stageType),r=n(this,ht).getValue("stageStatus");if(r!==e)switch(t.stageType){case 1:n(this,ht).setValue("stageStatus","ACCEPTED_TO_JOIN_STAGE",!1),this.stage.join();break;case 2:case 3:this.setStageStatus(r);break;case 0:case 4:default:n(this,ht).setValue("stageStatus","ACCEPTED_TO_JOIN_STAGE",!1),this.stage.leave();break}}peerStageStatusHandler(t){return u(this,null,function*(){const e=n(this,hs).joined.get(t.peerId),r=n(this,hs).viewMode==="ACTIVE_GRID";if(!e){this.logger.warn("err::peerStageStatusUpdate: participant not found");return}switch(t.stageType){case 1:e.setStageStatus("ON_STAGE"),r&&n(this,ht).getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:n(this,hs).viewMode,page:n(this,hs).currentPage});break;case 2:e.setStageStatus("ACCEPTED_TO_JOIN_STAGE");break;case 3:e.setStageStatus("REQUESTED_TO_JOIN_STAGE");break;case 0:case 4:default:e.setStageStatus("OFF_STAGE"),r&&n(this,ht).getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:n(this,hs).viewMode,page:n(this,hs).currentPage});break}n(this,ht).getValue("peerSessionStore").emit(b.UPDATE_PEER_STAGE_STATUS,{id:e.id,status:e.stageStatus})})}}Dr=new WeakMap,hs=new WeakMap,Or=new WeakMap,Do=new WeakMap,ht=new WeakMap;o0([P.trace("Stage.setupEvents")],Af.prototype,"setupEvents",1);var c0=Object.defineProperty,d0=Object.getOwnPropertyDescriptor,Vl=(s,t,e,r)=>{for(var i=r>1?void 0:r?d0(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&c0(t,e,i),i};const ke={getPeer:14,getPeers:15,chatMessage:16,getRoomName:17,getDisplayTitle:18,getPluginInitiator:19,customPluginEventToParent:20,peerJoined:22,peerLeft:23,sendData:24,stageStatusUpdate:25,peerStageStatusUpdate:26};var st,Ot,$n,Fn,Js,Bn,Nr,Hn,bg;let Ma=(bg=class extends Da{constructor(t,{baseURL:e,createdAt:r,description:i,id:a,name:o,organizationId:c,picture:d,private:l,published:p,staggered:g,tags:T,type:v,updatedAt:E},_,C,R,L,F){const N=t.getValue("logger");super(N);m(this,st,void 0);h(this,"baseURL");h(this,"createdAt");h(this,"description");h(this,"id");h(this,"name");m(this,Ot,void 0);m(this,$n,void 0);m(this,Fn,void 0);h(this,"organizationId");h(this,"picture");h(this,"private");h(this,"published");h(this,"staggered");h(this,"tags");h(this,"type");h(this,"updatedAt");m(this,Js,void 0);h(this,"config");m(this,Bn,void 0);h(this,"active");h(this,"iframes");h(this,"enabledBy");m(this,Nr,void 0);m(this,Hn,void 0);f(this,Nr,t),this.baseURL=e,this.createdAt=new Date(r),this.description=i,this.id=a,this.name=o,f(this,Ot,C),this.organizationId=c,this.picture=d,this.private=l,this.published=p,this.staggered=g,this.tags=T,this.type=v,this.updatedAt=new Date(E),this.active=!1,this.iframes=new Map,f(this,st,_),f(this,$n,R),f(this,Fn,L),this.enabledBy="",f(this,Hn,F)}get telemetry(){return n(this,Nr).getValue("telemetry")}sendIframeEvent(t){this.iframes.size&&this.iframes.forEach(e=>{const{iframe:r}=e;r&&(navigator.isReactNative?r.postMessage(JSON.stringify(t)):r.contentWindow.postMessage(t,"*"))})}handleIframeMessage(t){return u(this,null,function*(){var o;if(!this.active)return;const e=t,{payload:r,uuid:i,type:a}=e;switch(a){case J.customPluginEventToRoom:{n(this,st).customPluginEventToRoom(this.id,r,i);break}case J.customPluginEventToPeers:{n(this,st).customPluginEventToPeers(this.id,r.peerIds,r,i);break}case J.enablePluginForRoom:{n(this,st).enablePluginForRoom(this.id,i);break}case J.enablePluginForPeers:{n(this,st).enablePluginForPeers(this.id,r.peerIds,i);break}case J.disablePluginForRoom:{n(this,st).disablePluginForRoom(this.id,i);break}case J.disablePluginForPeers:{n(this,st).disablePluginForPeers(this.id,r.peerIds,i);break}case J.storeInsertKeys:{n(this,st).storeInsertKeys(this.id,r.store,r.insertKeys,i);break}case J.storeGetKeys:{n(this,st).storeGetKeys(this.id,r.store,r.getKeys,i);break}case J.storeDeleteKeys:{n(this,st).storeDeleteKeys(this.id,r.store,r.deleteKeys,i);break}case J.storeDelete:{n(this,st).storeDelete(this.id,r.store,i);break}case ke.chatMessage:{const{messagePayload:c,peerIds:d}=r;if(!n(this,Fn)){this.sendIframeEvent({type:ke.chatMessage,uuid:e.uuid,payload:{error:"Chat is disabled for this room."}});return}try{yield n(this,Fn).sendMessage(c,d),this.sendIframeEvent({type:ke.chatMessage,uuid:e.uuid,payload:{success:!0}})}catch(l){this.sendIframeEvent({type:ke.chatMessage,uuid:e.uuid,payload:{error:l}})}break}case ke.getPeer:{let c;const{peerId:d}=r,l=G(D({},n(this,Ot)),{id:n(this,Ot).id,isRecorder:(o=n(this,Ot).permissions)==null?void 0:o.isRecorder,isHidden:n(this,Ot).permissions.hiddenParticipant,stageStatus:n(this,Ot).stageStatus});d?(c=n(this,$n).joined.get(r.peerId),n(this,Ot).id===d&&(c=l)):c=l,this.sendIframeEvent({type:ke.getPeer,payload:{peer:c&&yd(c)},uuid:e.uuid});break}case ke.getPeers:{const c=n(this,$n).joined.toArray().map(d=>yd(d));this.sendIframeEvent({type:ke.getPeers,payload:{peers:c},uuid:e.uuid});break}case ke.getPluginInitiator:{this.sendIframeEvent({type:ke.getPluginInitiator,payload:{enabledBy:this.enabledBy},uuid:e.uuid});break}case ke.getDisplayTitle:{this.sendIframeEvent({type:ke.getDisplayTitle,payload:{displayTitle:n(this,Hn)},uuid:e.uuid});break}case ke.getRoomName:{this.sendIframeEvent({type:ke.getRoomName,payload:{roomName:n(this,Nr).getValue("meetingId")},uuid:e.uuid});break}case ke.customPluginEventToParent:{this.emit(e.payload.eventName,e.payload.data);break}}})}sendData(t){this.active&&(this.logger.info("Plugin::SendData",{plugin:{id:this.id,name:this.name,data:{eventName:t.eventName}}}),this.sendIframeEvent({type:ke.sendData,uuid:"",payload:t}))}removePluginView(t="default"){var i;const{iframe:e,listener:r}=(i=this.iframes.get(t))!=null?i:{};(e||r)&&(navigator.isReactNative?e.props.onMessage=void 0:window.removeEventListener("message",r),this.iframes.delete(t))}addPluginView(t,e="default"){var o;if(!n(this,Bn))throw this.logger.error("Plugin::addPluginView::no_auth_token_set_for_plugin"),new A("No auth token set for plugin.","0602");if(!t)throw this.logger.error("Plugin::addPluginView::iframe_was_not_provided"),new A("Iframe was not provided.","0603");this.removePluginView(e);const r=t,i=new URL(this.baseURL),a={auth:n(this,Bn),parent:navigator.isReactNative?this.baseURL:window.location.origin,backend:n(this,Nr).getValue("apiBase"),pluginId:this.id,roomName:(o=n(this,Nr).getValue("meetingId"))!=null?o:"",displayTitle:n(this,Hn)};if(Object.keys(a).forEach(c=>{i.searchParams.set(c,a[c])}),r.src=i.href,r.allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture",r.title=e,navigator.isReactNative)r.props.onMessage=c=>{this.handleIframeMessage(JSON.parse(c.nativeEvent.data))},this.iframes.set(e,{iframe:r});else{const c=d=>u(this,null,function*(){d.source===t.contentWindow&&(yield this.handleIframeMessage(d.data))});window.addEventListener("message",c),this.iframes.set(e,{iframe:r,listener:c})}}setActive(t){var e,r;if(this.active=t,t){this.emit("stateUpdate",{active:this.active,pluginId:this.id,bind:this.addPluginView.bind(this),views:(e=this.config)==null?void 0:e.views});return}this.active=!1,this.emit("stateUpdate",{active:this.active,pluginId:this.id,views:(r=this.config)==null?void 0:r.views})}activateForSelf(){return u(this,null,function*(){const t=ot(),e=yield t.authorizePlugin(this.id);f(this,Bn,e),f(this,Js,new Date);try{const r=yield t.getPluginConfig(this.baseURL);this.config=r}catch(r){this.logger.error("Plugin::activateForSelf",{error:r})}this.setActive(!0),this.emit("enabled")})}deactivateForSelf(){Array.from(this.iframes.keys()).forEach(t=>{this.removePluginView(t)}),f(this,Js,void 0),this.iframes.clear(),this.setActive(!1),this.emit("closed")}enable(){return u(this,null,function*(){return this.activateForSelf()})}disable(){return this.deactivateForSelf()}activate(){return u(this,null,function*(){var t,e;this.active||(e=(t=n(this,Ot).permissions)==null?void 0:t.plugins)!=null&&e.canStart&&(n(this,st).addPlugin(this.id,this.staggered),f(this,Js,new Date),this.logger.info("plugin::activated",{plugin:{id:this.id,enabledBy:this.enabledBy,name:this.name}}))})}deactivate(){return u(this,null,function*(){var t,e;this.active&&(!((e=(t=n(this,Ot).permissions)==null?void 0:t.plugins)!=null&&e.canClose)&&this.enabledBy!==n(this,Ot).id||(n(this,st).removePlugin(this.id),this.logger.info("plugin::deactivated",{plugin:{id:this.id,name:this.name,duration:n(this,Js)?new Date().getTime()-n(this,Js).getTime():0}}),f(this,Js,void 0)))})}},st=new WeakMap,Ot=new WeakMap,$n=new WeakMap,Fn=new WeakMap,Js=new WeakMap,Bn=new WeakMap,Nr=new WeakMap,Hn=new WeakMap,bg);Vl([Rt({maxInvocations:5,period:1})],Ma.prototype,"sendData",1);Vl([P.trace("Plugin.activatePlugin")],Ma.prototype,"activate",1);Vl([P.trace("Plugin.deactivatePlugin")],Ma.prototype,"deactivate",1);Ma=Vl([dt("0600")],Ma);var Oe,Ti;class If extends Map{constructor(e,r=void 0){const{onAddEvent:i,onDeleteEvent:a,onClearEvent:o}=e;super();m(this,Oe,void 0);m(this,Ti,void 0);h(this,"onAddEvent");h(this,"onDeleteEvent");h(this,"onClearEvent");f(this,Oe,new Da(r)),this.onAddEvent=i,this.onDeleteEvent=a,this.onClearEvent=o,f(this,Ti,new Map)}emit(e,...r){return n(this,Oe).emit(e,...r)}on(e,r){return n(this,Oe).on(e,r)}addListener(e,r){return n(this,Oe).addListener(e,r)}off(e,r){return n(this,Oe).off(e,r)}once(e,r){return n(this,Oe).once(e,r)}prependListener(e,r){return n(this,Oe).prependListener(e,r)}prependOnceListener(e,r){return n(this,Oe).prependOnceListener(e,r)}removeListener(e,r){return n(this,Oe).removeListener(e,r)}removeAllListeners(e){return n(this,Oe).removeAllListeners(e)}listeners(e){return n(this,Oe).listeners(e)}listenerCount(e){return n(this,Oe).listenerCount(e)}getMaxListeners(){return n(this,Oe).getMaxListeners()}setMaxListeners(e){return n(this,Oe).setMaxListeners(e)}eventNames(){return n(this,Oe).eventNames()}add(e,r=!0){return this.set(e.id,e,r)}set(e,r,i=!0){const a=super.set(e,r),o=(c,...d)=>{this.emit(c,r,...d)};return n(this,Ti).set(e,o),r.on("*",o),i&&n(this,Oe).emit(this.onAddEvent,r),a}delete(e,r=!0,i=!1){const a=this.get(e);if(!a)return!1;a.removeListener("*",n(this,Ti).get(e));const o=super.delete(e);return i&&a.removeAllListeners(),r&&n(this,Oe).emit(this.onDeleteEvent,a),o}clear(e=!0,r=!1){this.forEach(a=>{a.removeListener("*",n(this,Ti).get(a.id)),r&&a.removeAllListeners()});const i=super.clear();return e&&n(this,Oe).emit(this.onClearEvent),i}toArray(){return Array.from(this.values())}}Oe=new WeakMap,Ti=new WeakMap;class ig extends If{constructor(t){super({onAddEvent:"pluginAdded",onDeleteEvent:"pluginDeleted"},t)}add(t,e=!0){return super.add(t,e)}delete(t,e=!0,r=!1){return super.delete(t,e,r)}}var l0=Object.defineProperty,u0=Object.getOwnPropertyDescriptor,h0=(s,t,e,r)=>{for(var i=r>1?void 0:r?u0(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&l0(t,e,i),i};let Ou=class{constructor(s){h(this,"all");h(this,"active");this.all=new ig(s),this.active=new ig(s)}};Ou=h0([dt("0600")],Ou);var p0=Object.defineProperty,g0=Object.getOwnPropertyDescriptor,Ll=(s,t,e,r)=>{for(var i=r>1?void 0:r?g0(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&p0(t,e,i),i},zt,qn,ps,kg;const Mf=(kg=class{constructor(s,t,e,r){h(this,"plugins");m(this,zt,void 0);m(this,qn,void 0);m(this,ps,void 0);f(this,zt,t),f(this,qn,e),f(this,ps,s),this.plugins=r,this.setupEvents()}get telemetry(){return n(this,ps).getValue("telemetry")}get logger(){return n(this,ps).getValue("logger")}static init(s,t,e,r,i,a,o,c){return u(this,null,function*(){const d=s.getValue("logger"),l=new Ou(d);return t.forEach(p=>{const g=new Ma(s,p,e,a,o,i,c);l.all.add(g)}),new Mf(s,e,r,l)})}getRoomPlugins(){return u(this,null,function*(){var t;const{plugins:s}=yield n(this,zt).getActivePlugins();(t=this.plugins.active)==null||t.toArray().forEach(e=>{this.disablePlugin({id:e.id})}),yield Promise.all(s.map(e=>this.enablePlugin({id:e.pluginId,enabledBy:e.enabledBy})))})}enablePlugin(e){return u(this,arguments,function*({id:s,enabledBy:t}){const r=this.plugins.all.get(s);r&&(yield r.activateForSelf(),r.enabledBy=t)})}disablePlugin(t){return u(this,arguments,function*({id:s}){const e=this.plugins.all.get(s);e&&e.deactivateForSelf()})}sendIframeEvent(s,t,e,r){const i=this.plugins.all.get(t);i&&i.sendIframeEvent({type:s,uuid:e,payload:r})}broadcastIframeEvent(s,t){this.plugins.active.forEach(e=>{this.sendIframeEvent(s,e.id,"",t)})}setupEvents(){this.plugins.all.on("stateUpdate",({active:s,id:t})=>{if(s){this.plugins.active.add(this.plugins.all.get(t));return}this.plugins.active.delete(t)}),n(this,ps).getValue("peerSessionStore").onAsync(b.SOCKET_SERVICE_ROOM_JOINED,()=>u(this,null,function*(){yield this.getRoomPlugins(),this.logger.debug("[SOCKET_SERVICE_ROOM_JOINED] resolved request to fetch plugins.")})),n(this,zt).on(J.addPlugin,s=>u(this,null,function*(){var e;const t=s.pluginId;(e=this.plugins.all.get(t))!=null&&e.active||(yield this.enablePlugin({id:t,enabledBy:s.enabledBy}))})),n(this,zt).on(J.removePlugin,s=>u(this,null,function*(){var e;const t=s.pluginId;(e=this.plugins.all.get(t))!=null&&e.active&&(yield this.disablePlugin({id:t}))})),[J.enablePluginForPeers,J.enablePluginForRoom].forEach(s=>{n(this,zt).on(s,(t,e)=>u(this,null,function*(){this.sendIframeEvent(s,t.pluginId,e,{enabledBy:t.enabledBy})}))}),[J.disablePluginForPeers,J.disablePluginForRoom].forEach(s=>{n(this,zt).on(s,(t,e)=>u(this,null,function*(){this.sendIframeEvent(s,t.pluginId,e,{disabledBy:t.disabledBy})}))}),[J.customPluginEventToPeers,J.customPluginEventToRoom].forEach(s=>{n(this,zt).on(s,(t,e)=>u(this,null,function*(){this.sendIframeEvent(s,t.pluginId,e,{data:JSON.parse(new TextDecoder().decode(t.pluginData))})}))}),[J.storeInsertKeys,J.storeGetKeys,J.storeDeleteKeys].forEach(s=>{n(this,zt).on(s,(t,e)=>u(this,null,function*(){var i;const r=(i=t.storeItems)==null?void 0:i.map(a=>{var o;return{timestamp:a.timestamp,peerId:a.peerId,payload:JSON.parse((o=a.payload)!=null&&o.length?new TextDecoder().decode(a.payload):"{}"),key:a.storeKey}});this.sendIframeEvent(s,t.pluginId,e,{storeName:t.storeName,storeItems:r})}))}),n(this,zt).on(J.storeDelete,(s,t)=>u(this,null,function*(){this.sendIframeEvent(J.storeDelete,s.pluginId,t,{storeName:s.storeName})})),n(this,qn).on($e.sendMessageToPeers,s=>{const t=is==null?void 0:is.formatSocketPeerMessage(s.message);this.broadcastIframeEvent(ke.chatMessage,{message:t})}),n(this,qn).on($e.sendMessageToRoom,s=>{const t=is==null?void 0:is.formatSocketPeerMessage(s.message);this.broadcastIframeEvent(ke.chatMessage,{message:t})}),n(this,ps).getValue("peerSessionStore").on(b.PEER_JOINED_INTERNAL,s=>{const t=yd(s);this.broadcastIframeEvent(ke.peerJoined,t)}),n(this,ps).getValue("peerSessionStore").on(b.PEER_CLOSED,s=>{this.broadcastIframeEvent(ke.peerLeft,s)}),n(this,ps).getValue("peerSessionStore").on(b.UPDATE_PEER_STAGE_STATUS,s=>{this.broadcastIframeEvent(ke.peerStageStatusUpdate,s)}),n(this,ps).subscribe("stageStatus",s=>{this.broadcastIframeEvent(ke.stageStatusUpdate,s)})}},zt=new WeakMap,qn=new WeakMap,ps=new WeakMap,kg);let Nc=Mf;Ll([P.trace("PluginController.getRoomPlugins")],Nc.prototype,"getRoomPlugins",1);Ll([P.trace("PluginController.enableForSelf")],Nc.prototype,"enablePlugin",1);Ll([P.trace("PluginController.disableForSelf")],Nc.prototype,"disablePlugin",1);Ll([P.trace("PluginController.setupEvents")],Nc.prototype,"setupEvents",1);var Oo;class m0{constructor(t){h(this,"mediaJoined");h(this,"socketJoined");h(this,"socketJoinAttempted");h(this,"mediaJoinAttempted");h(this,"socketState");h(this,"mediaState");m(this,Oo,void 0);this.mediaJoined=!1,this.socketJoined=!1,this.socketJoinAttempted=!1,this.mediaJoinAttempted=!1,this.socketState={state:void 0,reconnected:!1,reconnectionAttempt:void 0},this.mediaState={recv:void 0,send:void 0},f(this,Oo,t)}get joinAttempted(){return this.mediaJoinAttempted||this.socketJoinAttempted}get roomJoined(){return this.mediaJoined&&this.socketJoined}updateSocketConnectionState(t,e){let r;const{reconnected:i}=this.socketState;switch(t){case"connected":r={state:"connected",reconnected:i,reconnectionAttempt:void 0};break;case"disconnected":r={state:"disconnected",reconnected:!1,reconnectionAttempt:0},this.socketJoined=!1;break;case"reconnected":r={state:"connected",reconnected:!0,reconnectionAttempt:void 0};break;case"reconnecting":r={state:"reconnecting",reconnected:i,reconnectionAttempt:0};break;case"reconnectAttempt":r={state:"reconnecting",reconnected:i,reconnectionAttempt:e};break;case"failed":r={state:"failed",reconnected:i,reconnectionAttempt:void 0},this.socketJoined=!1;break}r&&(n(this,Oo).getValue("peerSessionStore").emit(b.SOCKET_STATE_UPDATE,r),this.socketState=r)}}Oo=new WeakMap;var f0=Object.defineProperty,T0=Object.getOwnPropertyDescriptor,Vc=(s,t,e,r)=>{for(var i=r>1?void 0:r?T0(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&f0(t,e,i),i},jn,Gn,Wn,ad,Ag;let rn=(Ag=class extends Bt{constructor(t,e){const r=t.getValue("logger");super(r);m(this,Wn);m(this,jn,void 0);m(this,Gn,void 0);h(this,"recordingPeerIds",[]);h(this,"recordings",[]);f(this,Gn,t),f(this,jn,e)}get recordingState(){return this.recordings.some(t=>t.state==="RECORDING")?"RECORDING":this.recordings.some(t=>t.state==="PAUSED")?"PAUSED":this.recordings.some(t=>t.state==="STARTING")?"STARTING":this.recordings.some(t=>t.state==="STOPPING")?"STOPPING":"IDLE"}get telemetry(){return n(this,Gn).getValue("telemetry")}updateRecordings(t){this.recordings=t,this.emit("recordingUpdate",this.recordingState)}start(t){return u(this,null,function*(){if(!n(this,jn).permissions.canRecord)throw this.logger.error("Recording::start::permission_denied"),new A("User does not have permission to start recording","1001");if((t==null?void 0:t.allowMultiple)!==!0&&(this.recordingState==="STARTING"||this.recordingState==="RECORDING"||this.recordingState==="STOPPING"))throw this.logger.error("Recording::start::recording_in_progress",{recording:{state:this.recordingState}}),new A(`Cant start recording, recordingState irregular: ${this.recordingState}`,"1005");try{const e=ot(),{recording:r={}}=n(this,Gn).getValue("defaults"),i=yield e.startRecording(r,t==null?void 0:t.allowMultiple);this.updateRecordings([...this.recordings,{id:i,state:"STARTING",type:"BROWSER"}])}catch(e){throw this.logger.error("Recording::stop::recording_failed_to_start",{error:e}),new A("Error while starting recording","1000",this.logger)}})}stop(t){return u(this,null,function*(){yield x(this,Wn,ad).call(this,"stop",["RECORDING","PAUSED"],t)})}pause(t){return u(this,null,function*(){yield x(this,Wn,ad).call(this,"pause",["RECORDING"],t)})}resume(t){return u(this,null,function*(){yield x(this,Wn,ad).call(this,"resume",["PAUSED"],t)})}},jn=new WeakMap,Gn=new WeakMap,Wn=new WeakSet,ad=function(t,e,r){return u(this,null,function*(){if(!n(this,jn).permissions.canRecord)throw this.logger.error("Recording::stop::permission_denied"),new A("User does not have permission to stop recording","1001");let i=[];if(r!==void 0){const a=this.recordings.find(o=>o.id===r);if(a===void 0)throw new A("Could not find the specified recording","1004");if(e.includes(a.state)){this.logger.error("Recording::stop::recording_not_in_expected_state",{recording:{state:a.state}});return}i.push(a)}else i=this.recordings.filter(a=>e.includes(a.state));i.forEach(a=>u(this,null,function*(){const o=a.state;t==="stop"&&(a.state="STOPPING",this.emit("recordingUpdate","STOPPING"));try{yield ot().updateRecording(a.id,t)}catch(c){throw this.logger.error("Recording::stop::recording_failed_to_stop",{error:c}),a.state!==o&&(a.state=o,this.emit("recordingUpdate",o)),new A("Error while stopping recording","1000",this.logger)}}))})},Ag);Vc([P.trace("Recording.start")],rn.prototype,"start",1);Vc([P.trace("Recording.stop")],rn.prototype,"stop",1);Vc([P.trace("Recording.stop")],rn.prototype,"pause",1);Vc([P.trace("Recording.stop")],rn.prototype,"resume",1);rn=Vc([dt("1000")],rn);var v0=Object.defineProperty,S0=Object.getOwnPropertyDescriptor,y0=(s,t,e,r)=>{for(var i=r>1?void 0:r?S0(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&v0(t,e,i),i},vi;class Df{constructor(t,e,r){h(this,"recording");h(this,"room");m(this,vi,void 0);f(this,vi,t),this.recording=new rn(t,e),this.room=r,this.setupEvents()}get telemetry(){return n(this,vi).getValue("telemetry")}get logger(){return n(this,vi).getValue("logger")}getRecordingTypeFromProtoType(t){let e;switch(t){case en.BROWSER:e="BROWSER";break;case en.COMPOSITE:e="COMPOSITE";break;case en.TRACK:e="TRACK";break;default:e="BROWSER"}return e}setupEvents(){n(this,vi).getValue("peerSessionStore").on(b.ROOM_STATE,t=>{t.activeRecordings.length!==0?this.recording.updateRecordings(t.activeRecordings.map(e=>{const r=this.getRecordingTypeFromProtoType(e.recordingType);return{id:e.recordingId,state:e.recordingStatus,type:r}})):this.recording.recordings.length&&this.recording.updateRecordings([])}),this.room.on(U.recordingStarted,t=>{let e=!1;const r=[...this.recording.recordings];if(r.forEach(i=>{i.id===t.recordingId&&(e=!0,i.state="RECORDING")}),e===!1){const i=this.getRecordingTypeFromProtoType(t.recordingType);r.push({id:t.recordingId,state:"RECORDING",type:i})}this.recording.updateRecordings(r)}),this.room.on(U.recordingPaused,t=>{const e=[...this.recording.recordings];e.forEach(r=>{r.id===t.recordingId&&(r.state="PAUSED")}),this.recording.updateRecordings(e)}),this.room.on(U.recordingStopped,t=>{const e=[...this.recording.recordings.filter(r=>r.id!==t.recordingId)];this.recording.updateRecordings(e)})}}vi=new WeakMap;y0([P.trace("RecordingController.setupEvents")],Df.prototype,"setupEvents",1);var Si;class E0{constructor(t){m(this,Si,void 0);f(this,Si,t)}hasFeature(t){var e;return(e=n(this,Si).getValue("flagsmith").hasFeature(t))!=null?e:!1}getFeatureValue(t){return n(this,Si).getValue("flagsmith").getValue(t)}getAllFeatures(){return n(this,Si).getValue("flagsmith").getAllFlags()}}Si=new WeakMap;class Rh{constructor(t,e,r){h(this,"logger");h(this,"features");h(this,"browserSpecs");h(this,"callStats");this.logger=t,this.features=e,this.browserSpecs=Se,this.callStats=r}static init(t){return new Rh(t.getValue("logger"),new E0(t),t.getValue("callstats"))}}class bh{constructor(t){h(this,"internals");this.internals=t}static init(t){return u(this,null,function*(){const e=Rh.init(t);return new bh(e)})}}var P0=Object.defineProperty,_0=Object.getOwnPropertyDescriptor,qt=(s,t,e,r)=>{for(var i=r>1?void 0:r?_0(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&P0(t,e,i),i},Be,Te,he,Ks,Yt,No,be;class bt extends Da{constructor(e,r,i=Ed,a=!0){const o=e.getValue("logger");super(o);m(this,Be,void 0);m(this,Te,void 0);m(this,he,void 0);m(this,Ks,void 0);m(this,Yt,void 0);m(this,No,void 0);m(this,be,void 0);h(this,"audioUpdateInProgress");h(this,"videoUpdateInProgress");f(this,be,e),this.audioUpdateInProgress=!1,this.videoUpdateInProgress=!1,f(this,Be,new Of(e,r)),f(this,Te,new G0(e,n(this,Be),void 0,i)),f(this,he,new X0(e,n(this,Be),void 0,i)),f(this,Yt,new z0(n(this,be),n(this,Be))),f(this,Ks,new J0(e,n(this,Be))),f(this,No,a),n(this,Te).on("trackMuted",this.onAudioTrackMuted.bind(this)),n(this,Te).on("trackChanged",this.onAudioTrackChanged.bind(this)),n(this,he).on("trackChanged",this.onVideoTrackChanged.bind(this)),n(this,he).on("trackEnded",this.onVideoTrackEnded.bind(this)),n(this,Yt).on("trackEnded",this.onScreenShareEnded.bind(this)),this.onVisibilityChange=this.onVisibilityChange.bind(this),document.addEventListener("visibilitychange",this.onVisibilityChange)}get telemetry(){return n(this,be).getValue("telemetry")}set context(e){f(this,be,e)}onVisibilityChange(){return u(this,null,function*(){n(this,be).getValue("callstats").tabChanged(document.visibilityState==="visible"),document.visibilityState!=="visible"?n(this,be).getValue("callstats").browserBackgrounded():(n(this,be).getValue("callstats").browserForegrounded(),yield this.setupSpeaker())})}repopulateAvailableDevices(){return u(this,null,function*(){return!0})}setupStreams(i){return u(this,arguments,function*({audio:e,video:r}){var c;e?n(this,be).getValue("callstats").audioOn():n(this,be).getValue("callstats").audioOff(),r?n(this,be).getValue("callstats").videoOn():n(this,be).getValue("callstats").videoOff();let a,o;if(e&&r)try{const d=yield n(this,Be).getAudioAndVideoTrack(n(this,Te).userSelectedDevice,n(this,he).userSelectedDevice);a=d.audioTrack,o=d.videoTrack}catch(d){this.logger.error("LocalMediaHandler::init::Failed to get audio video tracks",{error:d})}if(!a&&e)try{a=yield n(this,Be).getAudioTrack(!1,n(this,Te).userSelectedDevice)}catch(d){this.logger.error("LocalMediaHandler::init::Failed to get audio track",{error:d})}if(!o&&r)try{o=yield n(this,Be).getVideoTrack(n(this,he).userSelectedDevice)}catch(d){this.logger.error("LocalMediaHandler::init::Failed to get video track",{error:d})}e&&!a&&n(this,be).getValue("callstats").audioOff(),r&&!o&&n(this,be).getValue("callstats").videoOff(),yield n(this,Te).setMediaTrack(a),yield n(this,he).setMediaTrack(o);try{yield this.setupSpeaker()}catch(d){}if(o){const d=yield this.getDeviceById(o.getSettings().deviceId);n(this,be).getValue("callstats").selectedDevice("VIDEO",d)}if(a){const d=yield this.getDeviceById(a.getSettings().deviceId);n(this,be).getValue("callstats").selectedDevice("AUDIO",d)}(c=n(this,Ks).currentDevice)!=null&&c.deviceId&&n(this,be).getValue("callstats").selectedDevice("SPEAKER",n(this,Ks).currentDevice),n(this,Be).onDeviceChange((d,l,p)=>{this.onDeviceChange(l,p)})})}getCurrentDevices(){return{audio:n(this,Te).currentDevice,video:n(this,he).currentDevice,speaker:n(this,Ks).currentDevice}}get permissions(){return n(this,Be).permissions}getAllDevices(){return n(this,Be).getAvailableDevices()}getDeviceById(e,r){return n(this,Be).getDevice(e)}onAudioTrackMuted(){this.emit("AUDIO_TRACK_SILENT")}onAudioTrackChanged(){this.emit("AUDIO_TRACK_CHANGE")}get rawAudioTrack(){return n(this,Te).mediaTrack}get audioTrack(){return n(this,Te).transformedMediaTrack}get audioEnabled(){return n(this,Te).trackEnabled}enableAudio(e){return u(this,null,function*(){if(!this.audioUpdateInProgress){this.audioUpdateInProgress=!0;try{e?yield n(this,Te).enableTrack(!1,e):yield n(this,Te).unmuteTrack()}catch(r){}finally{this.audioUpdateInProgress=!1}}})}disableAudio(){n(this,Te).mediaTrack&&!n(this,Te).isCustomTrack?n(this,Te).muteTrack():n(this,Te).disableTrack()}getAudioDevices(e){return n(this,Be).getAudioInputDevices(e)}setAudioDevice(i,a){return u(this,arguments,function*(e,{saveDevicePreference:r}){yield n(this,Te).setDevice(e,{saveDevicePreference:r}),e!=null&&e.deviceId&&n(this,be).getValue("callstats").selectedDevice("AUDIO",e),this.emit("AUDIO_TRACK_CHANGE"),this.emit("DEVICE_CHANGE",{device:e})})}setupSpeaker(){return u(this,null,function*(){const{speaker:e}=this.getCurrentDevices();yield n(this,Ks).setPreferredSpeaker();const{speaker:r}=this.getCurrentDevices();(e==null?void 0:e.deviceId)!==(r==null?void 0:r.deviceId)&&r&&this.emit("DEVICE_CHANGE",{device:r})})}setSpeakerDevice(i,a){return u(this,arguments,function*(e,{saveDevicePreference:r}){yield n(this,Ks).setupSpeaker(e,{saveDevicePreference:r}),e!=null&&e.deviceId&&n(this,be).getValue("callstats").selectedDevice("SPEAKER",e),this.emit("DEVICE_CHANGE",{device:e})})}onVideoTrackChanged(){this.emit("VIDEO_TRACK_CHANGE")}onVideoTrackEnded(){this.emit("VIDEO_TRACK_CHANGE")}get rawVideoTrack(){return n(this,he).mediaTrack}get videoTrack(){return n(this,he).transformedMediaTrack}get videoEnabled(){return n(this,he).trackEnabled}enableVideo(e){return u(this,null,function*(){if(!this.videoUpdateInProgress){this.videoUpdateInProgress=!0;try{e?yield n(this,he).enableTrack(!1,e):yield n(this,he).unmuteTrack()}catch(r){}finally{this.videoUpdateInProgress=!1}}})}disableVideo(){n(this,he).disableTrack()}getVideoDevices(e){return n(this,Be).getVideoInputDevices(e)}setVideoDevice(i,a){return u(this,arguments,function*(e,{saveDevicePreference:r}){yield n(this,he).setDevice(e,{saveDevicePreference:r}),e!=null&&e.deviceId&&n(this,be).getValue("callstats").selectedDevice("VIDEO",e),this.emit("VIDEO_TRACK_CHANGE"),this.emit("DEVICE_CHANGE",{device:e})})}updateVideoConstraints(e){return u(this,null,function*(){yield n(this,he).updateConstraints(e)})}onScreenShareEnded(){this.emit("SCREENSHARE_ENDED")}get screenShareTracks(){return{audio:n(this,Yt).audioMediaTrack,video:n(this,Yt).videoMediaTrack}}get screenShareEnabled(){return n(this,Yt).trackEnabled}enableScreenShare(){return u(this,null,function*(){yield n(this,Yt).enableScreenShare()})}disableScreenShare(){return u(this,null,function*(){n(this,Yt).disableScreenShare()})}updateScreenshareConstraints(e){return u(this,null,function*(){yield n(this,Yt).updateConstraints(e)})}getSpeakerDevices(e){return n(this,Be).getAudioOutputDevices(e)}addAudioMiddleware(e){return n(this,Te).addMiddleware(e)}removeAudioMiddleware(e){return n(this,Te).removeMiddleware(e)}removeAllAudioMiddlewares(){return n(this,Te).removeAllMiddlewares()}addVideoMiddleware(e){return n(this,he).addMiddleware(e)}removeVideoMiddleware(e){return n(this,he).removeMiddleware(e)}removeAllVideoMiddlewares(){return n(this,he).removeAllMiddlewares()}setVideoMiddlewareGlobalConfig(e){return n(this,he).setVideoMiddlewareGlobalConfig(e)}destruct(){n(this,Te).disableTrack(),n(this,he).disableTrack(),n(this,he).terminateMiddlewareWebWorker(),n(this,Yt).disableScreenShare(),n(this,Be).destruct()}onDeviceChange(e,r){return u(this,null,function*(){var a,o;if(this.emit("DEVICE_LIST_UPDATED",e),r||!n(this,No))return;let i=!1;(a=e==null?void 0:e.added)==null||a.reverse().forEach(c=>u(this,null,function*(){var d;c&&!Ed(c)&&(c.kind==="audioinput"&&((d=this.audioTrack)==null?void 0:d.enabled)===!0?yield this.setAudioDevice(c,{saveDevicePreference:!1}):c.kind==="audiooutput"&&(i=!0,yield this.setSpeakerDevice(c,{saveDevicePreference:!1})))})),i||(o=e==null?void 0:e.removed)==null||o.forEach(c=>u(this,null,function*(){var d;if(c.kind==="audiooutput"&&((d=this.getCurrentDevices().speaker)==null?void 0:d.deviceId)===c.deviceId){const l=yield this.getSpeakerDevices();(l==null?void 0:l.length)>0&&(yield this.setSpeakerDevice(l[0],{saveDevicePreference:!1}))}}))})}removeAllTracks(){this.destruct()}removeAudioTrack(){n(this,Te).disableTrack()}removeVideoTrack(){n(this,he).disableTrack(),n(this,he).terminateMiddlewareWebWorker()}removeDocumentEventListeners(){return u(this,null,function*(){document.removeEventListener("visibilitychange",this.onVisibilityChange)})}}Be=new WeakMap,Te=new WeakMap,he=new WeakMap,Ks=new WeakMap,Yt=new WeakMap,No=new WeakMap,be=new WeakMap;qt([P.trace("MediaHandler.setupStreams")],bt.prototype,"setupStreams",1);qt([P.trace("MediaHandler.enableAudio")],bt.prototype,"enableAudio",1);qt([P.trace("MediaHandler.disableAudio")],bt.prototype,"disableAudio",1);qt([P.trace("MediaHandler.setAudioDevice")],bt.prototype,"setAudioDevice",1);qt([P.trace("MediaHandler.enableVideo")],bt.prototype,"enableVideo",1);qt([P.trace("MediaHandler.disableVideo")],bt.prototype,"disableVideo",1);qt([P.trace("MediaHandler.setVideoDevice")],bt.prototype,"setVideoDevice",1);qt([P.trace("MediaHandler.updateVideoConstraints")],bt.prototype,"updateVideoConstraints",1);qt([P.trace("MediaHandler.enableScreenShare")],bt.prototype,"enableScreenShare",1);qt([P.trace("MediaHandler.disableScreenShare")],bt.prototype,"disableScreenShare",1);qt([P.trace("MediaHandler.updateScreenshareConstraints")],bt.prototype,"updateScreenshareConstraints",1);qt([P.trace("MediaHandler.destruct")],bt.prototype,"destruct",1);qt([P.trace("MediaHandler.onDeviceChange")],bt.prototype,"onDeviceChange",1);function zc(s,t,e){switch(!0){case Se.isChromiumBased():switch(t){case"NotAllowedError":return e.includes("by system")?"SYSTEM_DENIED":s==="screenshare"?"CANCELED":"DENIED";case"NotReadableError":default:return"COULD_NOT_START"}case Se.isSafari():switch(t){case"NotAllowedError":return"DENIED";default:return"COULD_NOT_START"}case Se.isFirefox():switch(t){case"NotFoundError":case"NotReadableError":return"SYSTEM_DENIED";case"NotAllowedError":return"DENIED";case"AbortError":default:return"COULD_NOT_START"}default:return"COULD_NOT_START"}}const C0=["virtual","emulator","krisp","solstice conference","teams","loom","zoom","manycam","blackhole","displayport","xsplit","wirecast","vMix","elgato","epiphan","voice changer","voicemod","morphvoxx"];function Ed(s){var e,r;const t=(e=s.label)==null?void 0:e.toLowerCase();return((r=Se._bowser)==null?void 0:r.getOSName())==="macOS"&&t.includes("iphone")?!0:C0.some(i=>t==null?void 0:t.includes(i))}function w0(s,t,e){return u(this,null,function*(){if(!(t!=null&&t.length))return e;const r=s.getValue("logger"),i=new AudioContext,a=yield Promise.all(t==null?void 0:t.map(d=>d(i))),o=i.createMediaStreamSource(new MediaStream([e])),c=i.createMediaStreamDestination();try{let d=o;for(let l=0;l<a.length;l+=1)d.connect(a[l]),d=a[l];d.connect(c)}catch(d){return r.error("getTransformedAudioTrack::middleware_execution_failed",{error:d}),e}return c.stream.getAudioTracks()[0]})}var yi,Vo;class R0{constructor(t){m(this,yi,void 0);m(this,Vo,void 0);f(this,Vo,t)}get logger(){return n(this,Vo).getValue("logger")}terminateMiddlewareWebWorker(){if(n(this,yi))try{Xc.clearInterval(n(this,yi)),f(this,yi,void 0)}catch(t){this.logger.debug("WorkerTimers::terminateMiddlewareWebWorker::failed")}}getTransformedVideoTrack(t,e,r){return u(this,null,function*(){if(!(t!=null&&t.length))return e;const i=document.createElement("canvas"),a=yield Promise.all(t==null?void 0:t.map(T=>T({canvas:i,WorkerTimers:Xc})));if(r.disablePerFrameCanvasRendering){const v=i.captureStream().getVideoTracks()[0];return Object.defineProperty(v,"originalSettings",{value:e.getSettings()}),v}const o=document.createElement("video"),c=new MediaStream;c.addTrack(e);const d=i.getContext("2d");o.srcObject=c,o.autoplay=!0,this.terminateMiddlewareWebWorker();const l=()=>u(this,null,function*(){if(e.enabled===!1||e.readyState==="ended"){this.terminateMiddlewareWebWorker(),o.remove(),i.remove();return}try{d.drawImage(o,0,0);for(let T=0;T<a.length;T+=1)typeof a[T]=="function"&&(yield a[T](i,d))}catch(T){this.logger.error("getTransformedVideoTrack::middleware_execution_failed",{error:T})}});try{o.play()}catch(T){}o.addEventListener("play",()=>{i.width=o.width||e.getSettings().width,i.height=o.width||e.getSettings().height,f(this,yi,Xc.setInterval(l,50))},!1);const g=i.captureStream().getVideoTracks()[0];return Object.defineProperty(g,"originalSettings",{value:e.getSettings()}),g})}}yi=new WeakMap,Vo=new WeakMap;const ng={gross:{width:{ideal:192},height:{ideal:144}},qvga:{width:{ideal:384},height:{ideal:288}},pvga:{width:{ideal:480},height:{ideal:360}},vga:{width:{ideal:640},height:{ideal:480}},hd:{width:{ideal:1280},height:{ideal:720}},hd_cropped:{width:{ideal:900},height:{ideal:720}},fhd:{width:{ideal:1920},height:{ideal:1080}}},b0=[[320,[{rid:"q",maxBitrate:25e4,maxFramerate:24,scalabilityMode:"L1T1"}]],[640,[{rid:"q",scaleResolutionDownBy:2,maxBitrate:25e4,maxFramerate:24,scalabilityMode:"L1T1"},{rid:"h",maxBitrate:7e5,maxFramerate:30,scalabilityMode:"L1T1"}]],[1280,[{rid:"q",scaleResolutionDownBy:2,maxBitrate:5e5,maxFramerate:24,scalabilityMode:"L1T1"},{rid:"h",maxBitrate:13e5,maxFramerate:30,scalabilityMode:"L1T1"}]],[1920,[{rid:"q",scaleResolutionDownBy:2,maxBitrate:9e5,maxFramerate:24,scalabilityMode:"L1T1"},{rid:"h",maxBitrate:15e5,maxFramerate:30,scalabilityMode:"L1T1"}]]],k0=(s,t)=>{var d,l,p;const e=(d=s==null?void 0:s.getValue("overrides"))==null?void 0:d.simulcastConfig;if((l=e==null?void 0:e.encodings)!=null&&l.length)return e.encodings;const r="getSettings"in t&&t.getSettings().width||"getConstraints"in t&&t.getConstraints().width||"originalSettings"in t&&((p=t.originalSettings)==null?void 0:p.width);let i=b0;s.getValue("flagsmith").hasFeature(Z.OVERRIDE_SIMULCAST_DYNAMIC)&&(i=JSON.parse(s.getValue("flagsmith").getValue(Z.OVERRIDE_SIMULCAST_DYNAMIC)));const a=i.map(([g])=>g).sort((g,T)=>g-T);let o=Number.MAX_VALUE,c=0;return a.forEach((g,T)=>{Math.abs(g-r)<o&&(o=Math.abs(g-r),c=T)}),i[c][1]};var ue=(s=>(s.WEBCAM="webcam",s.WEBCAM_BACKUP="webcam_backup",s.MIC="mic",s.SCREENSHARE_VIDEO="screenshare_video",s.SCREENSHARE_AUDIO="screenshare_audio",s))(ue||{});const A0=a_(),un=_s(A0.config.media);function I0(s){var e,r;const t={};return s.audio&&(t.audio={enableStereo:(e=s.audio.enableStereo)!=null?e:!1,enableHighBitrate:(r=s.audio.enableHighBitrate)!=null?r:!1}),t.video=s.video.quality,t}var Ei,Is;class M0{constructor(t,e){m(this,Ei,void 0);m(this,Is,void 0);h(this,"getScreenShareConstraints",()=>{var l,p,g,T,v,E,_,C,R,L,F;const t=(l=n(this,Ei))==null?void 0:l.screenshare,e=(g=(p=t==null?void 0:t.width)==null?void 0:p.max)!=null?g:1920,r=(v=(T=t==null?void 0:t.height)==null?void 0:T.max)!=null?v:1080,i=(_=(E=t==null?void 0:t.frameRate)==null?void 0:E.max)!=null?_:5;let a=(R=(C=t==null?void 0:t.frameRate)==null?void 0:C.ideal)!=null?R:5;const o=t==null?void 0:t.displaySurface,c=t==null?void 0:t.selfBrowserSurface;n(this,Is).getValue("flagsmith").getValue(Z.VAL_MIN_FRAMERATE)&&(a=parseInt((L=n(this,Is).getValue("flagsmith").getValue(Z.VAL_MIN_FRAMERATE))==null?void 0:L.toString(),10));let d={width:{max:e},height:{max:r},frameRate:{ideal:a,max:i}};if(n(this,Is).getValue("flagsmith").hasFeature(Z.SCREENSHARE_CONSTRAINTS)){const N=(F=n(this,Is).getValue("flagsmith").getValue(Z.SCREENSHARE_CONSTRAINTS))==null?void 0:F.toString();d=JSON.parse(N)}return o!==void 0&&["monitor","browser","window"].includes(o)&&(d=G(D({},d),{displaySurface:o})),c!==void 0&&(d=G(D({},d),{selfBrowserSurface:c})),{audio:!0,video:d}});h(this,"getAudioConstraints",t=>{var a,o,c,d,l,p,g;const e={},r=(a=n(this,Ei))==null?void 0:a.audio,i=r!=null&&r.enableStereo?2:1;return Se.isFirefox()||Se.isWebKitBased()?(e.audio={deviceId:t,autoGainControl:(o=r==null?void 0:r.autoGainControl)!=null?o:!0,echoCancellation:(c=r==null?void 0:r.echoCancellation)!=null?c:!0,noiseSuppression:(d=r==null?void 0:r.noiseSupression)!=null?d:!0,channelCount:i},e):(e.audio={autoGainControl:(l=r==null?void 0:r.autoGainControl)!=null?l:!0,echoCancellation:(p=r==null?void 0:r.echoCancellation)!=null?p:!0,noiseSuppression:(g=r==null?void 0:r.noiseSupression)!=null?g:!0,channelCount:i},t&&(e.audio.deviceId={exact:t}),e)});h(this,"getVideoConstraints",t=>{var a,o,c,d;const e={},r=(a=n(this,Ei))==null?void 0:a.video;let i=ng.vga;if(typeof r=="string"?i=ng[r]:r!==void 0&&(i.height.ideal=r.height.ideal,i.width.ideal=r.width.ideal),i.frameRate={ideal:(c=(o=i.frameRate)==null?void 0:o.ideal)!=null?c:24},Se.isChromiumBased()&&(i.frameRate.max=30),n(this,Is).getValue("flagsmith").hasFeature(Z.VIDEO_CONSTRAINTS)){const l=(d=n(this,Is).getValue("flagsmith").getValue(Z.VIDEO_CONSTRAINTS))==null?void 0:d.toString();i=JSON.parse(l)}return e.video=i,typeof e.video=="boolean"||(t?e.video.deviceId={exact:t}:e.video.facingMode="user"),e});f(this,Is,t),f(this,Ei,e)}getUpdatedVideoConstraints(t){return t}}Ei=new WeakMap,Is=new WeakMap;class au extends Error{constructor(e,r,i){super(r);h(this,"constraints");h(this,"name");this.name=e,this.constraints=i}}class D0{constructor(){h(this,"permissions");this.permissions={audio:"NOT_REQUESTED",video:"NOT_REQUESTED",screenshare:"NOT_REQUESTED"}}getAudioInputDevices(t){return u(this,null,function*(){let e=t;return t||(e=yield this.getAvailableDevices()),e.filter(r=>r.kind==="audioinput")})}getVideoInputDevices(t){return u(this,null,function*(){let e=t;return t||(e=yield this.getAvailableDevices()),e.filter(r=>r.kind==="videoinput")})}getAudioOutputDevices(t){return u(this,null,function*(){let e=t;return t||(e=yield this.getAvailableDevices()),e.filter(r=>r.kind==="audiooutput")})}}var O0=Object.defineProperty,N0=Object.getOwnPropertyDescriptor,ks=(s,t,e,r)=>{for(var i=r>1?void 0:r?N0(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&O0(t,e,i),i},Jn,Qt,Ne,Ig;let Ft=(Ig=class extends D0{constructor(t,e){super();m(this,Jn,void 0);m(this,Qt,void 0);m(this,Ne,void 0);f(this,Ne,t),f(this,Qt,new M0(t,e)),f(this,Jn,new AbortController)}get telemetry(){return n(this,Ne).getValue("telemetry")}get logger(){return n(this,Ne).getValue("logger")}get constraintsBuilder(){return n(this,Qt)}destruct(){return u(this,null,function*(){var t;(t=n(this,Jn))==null||t.abort()})}handlePermissionErrors(t,e){const r=zc(t,e.name,e.message);return this.permissions[t]=r,n(this,Ne).getValue("peerSessionStore").emit(b.MEDIA_PERMISSION_ERROR,{message:r,constraints:e.constraints,kind:t}),r}getAudioAndVideoTrack(t,e){return u(this,null,function*(){var r,i,a,o;try{const c=yield this.getAudioInputDevices(),d=yield this.getVideoInputDevices(),l=!!(c!=null&&c.find(L=>L.deviceId===t));let p;t&&l?p=t:c&&((r=c[0])!=null&&r.deviceId)&&(p=(i=c[0])==null?void 0:i.deviceId);const g=!!(d!=null&&d.find(L=>L.deviceId===e));let T;e&&g?T=e:d&&((a=d[0])!=null&&a.deviceId)&&(T=(o=d[0])==null?void 0:o.deviceId);const v={audio:n(this,Qt).getAudioConstraints(p).audio,video:n(this,Qt).getVideoConstraints(T).video};this.logger.info("getUserMediaWithoutTimeout::requesting_user_media",{constraints:JSON.stringify(v)});const E=yield navigator.mediaDevices.getUserMedia(v);this.logger.info("getUserMediaWithoutTimeout::received_user_media",{constraints:JSON.stringify(v)});const _=E.getAudioTracks()[0];let C=E.getVideoTracks()[0];if(this.permissions.audio="ACCEPTED",this.permissions.video="ACCEPTED",n(this,Ne).getValue("flagsmith").hasFeature(Z.OBS_QUALITY)&&C.label.includes("OBS Virtual")){const F=(yield this.getVideoInputDevices()).find(N=>N.label.includes("OBS Virtual"));C=yield this.getVideoTrack(F.deviceId)}return n(this,Ne).getValue("peerSessionStore").emit(b.MEDIA_PERMISSION_UPDATE,{message:this.permissions.audio,kind:"audio"}),n(this,Ne).getValue("peerSessionStore").emit(b.MEDIA_PERMISSION_UPDATE,{message:this.permissions.video,kind:"video"}),{audioTrack:_,videoTrack:C}}catch(c){throw this.logger.error("WebMediaInterface.getAudioAndVideoTrack",{error:c}),new A("Couldnt fetch audio and video track","1605")}})}getAudioTrack(t,e){return u(this,null,function*(){var c,d;let r=yield this.getAudioInputDevices();if(!(r!=null&&r.length))throw this.permissions.audio="NO_DEVICES_AVAILABLE",n(this,Ne).getValue("peerSessionStore").emit(b.MEDIA_PERMISSION_UPDATE,{message:this.permissions.audio,kind:"audio"}),new A("No audio devices available","1606");const i=!!(r!=null&&r.find(l=>l.deviceId===e));let a;e&&i?a=e:(c=r[0])!=null&&c.deviceId&&(a=(d=r[0])==null?void 0:d.deviceId);const o=l=>u(this,null,function*(){let p;try{r=r.filter(T=>T.deviceId!==l),p=n(this,Qt).getAudioConstraints(l),this.logger.info("getUserMediaWithoutTimeout::requesting_user_media",{constraints:JSON.stringify(p)});const[g]=(yield navigator.mediaDevices.getUserMedia(p)).getAudioTracks();return this.logger.info("getUserMediaWithoutTimeout::received_user_media",{constraints:JSON.stringify(p)}),g}catch(g){const T=zc("audio",g.name,g.message),v=new au(g.name,g.message,p);if(T==="COULD_NOT_START"){const E=r.shift();if(!E)throw v;this.logger.info("getAudioTrack::gum_failed",{constraints:JSON.stringify(p),error:g});const _=n(this,Qt).getAudioConstraints(E.deviceId);return this.logger.info("getAudioTrack::retrying_gum_for_next_device",{constraints:JSON.stringify(_)}),o(E.deviceId)}throw v}});try{const l=yield o(a);return l.enabled=!t,this.permissions.audio!=="ACCEPTED"&&(this.permissions.audio="ACCEPTED",n(this,Ne).getValue("peerSessionStore").emit(b.MEDIA_PERMISSION_UPDATE,{message:this.permissions.audio,kind:"audio"})),l}catch(l){throw l.constraints&&this.handlePermissionErrors("audio",l),new A(l.message,"1601")}})}getVideoTrack(t){return u(this,null,function*(){var l,p,g;const e=n(this,Ne).getValue("flagsmith").hasFeature(Z.OBS_QUALITY),r=(l=yield this.getCurrentDeviceLabel(t))==null?void 0:l.includes("OBS Virtual"),i=e&&r,a=yield this.getVideoInputDevices();if(!(a!=null&&a.length))throw this.permissions.video="NO_DEVICES_AVAILABLE",n(this,Ne).getValue("peerSessionStore").emit(b.MEDIA_PERMISSION_UPDATE,{message:this.permissions.video,kind:"video"}),new A("No video devices available","1607");const o=!!(a!=null&&a.find(T=>T.deviceId===t));let c;t&&o?c=t:(p=a[0])!=null&&p.deviceId&&(c=(g=a[0])==null?void 0:g.deviceId);const d=T=>u(this,null,function*(){try{let v=T;const{video:E}=v;i&&typeof E!="boolean"&&(v={video:{deviceId:E.deviceId}}),this.logger.info("getUserMediaWithoutTimeout::requesting_user_media",{constraints:JSON.stringify(v)});const[_]=(yield navigator.mediaDevices.getUserMedia(v)).getVideoTracks();if(i&&typeof E!="boolean"&&typeof E.width=="object"){const{width:C,height:R}=_.getSettings(),{ideal:L}=E.width;_.applyConstraints({width:{ideal:L},height:{ideal:Math.floor(R*L/C)},frameRate:E.frameRate})}return this.logger.info("getUserMediaWithoutTimeout::received_user_media",{constraints:JSON.stringify(v)}),_}catch(v){const E=zc("video",v.name,v.message),_=new au(v.name,v.message,T);if(E==="COULD_NOT_START"){const C=a.shift();if(!C)throw _;this.logger.info("getVideoTrack::gum_failed",{constraints:JSON.stringify(T),error:v});const R=n(this,Qt).getVideoConstraints(C.deviceId);return this.logger.info("getVideoTrack::retrying_gum_for_next_device",{constraints:JSON.stringify(R)}),d({video:R.video})}throw _}});try{const T=n(this,Qt).getVideoConstraints(c),v=yield d(T);return this.permissions.video!=="ACCEPTED"&&(this.permissions.video="ACCEPTED",n(this,Ne).getValue("peerSessionStore").emit(b.MEDIA_PERMISSION_UPDATE,{message:this.permissions.video,kind:"video"})),v}catch(T){throw T.constraints&&this.handlePermissionErrors("video",T),new A(T.message,"1602")}})}getScreenShareTracks(){return u(this,null,function*(){const t=e=>u(this,null,function*(){try{this.logger.info("getDisplayMediaWithoutTimeout::requesting_display_media",{constraints:JSON.stringify(e)}),n(this,Ne).getValue("callstats").screenShareRequested();const r=yield navigator.mediaDevices.getDisplayMedia(e);return this.logger.info("getDisplayMediaWithoutTimeout::received_display_media",{constraints:JSON.stringify(e)}),r}catch(r){const i=zc("video",r.name,r.message),a=new au(r.name,r.message,e),o={video:!0};if(WC(e,o)||!n(this,Ne).getValue("flagsmith").hasFeature(Z.SCREEENSHARE_CONSTRAINTS_RETRY))throw a;if(i==="COULD_NOT_START")return t(o);throw a}});try{const e=n(this,Qt).getScreenShareConstraints(),r=yield t(e);return this.permissions.screenshare!=="ACCEPTED"&&(this.permissions.screenshare="ACCEPTED",n(this,Ne).getValue("peerSessionStore").emit(b.MEDIA_PERMISSION_UPDATE,{message:this.permissions.screenshare,kind:"screenshare"})),{audioTrack:r.getAudioTracks()[0],videoTrack:r.getVideoTracks()[0]}}catch(e){throw e.constraints&&this.handlePermissionErrors("screenshare",e),new A(e.message,"1612")}})}getCurrentDeviceLabel(t){return u(this,null,function*(){const e=yield this.getDevice(t||"default");return e==null?void 0:e.label})}enumerateDevicesWithExternalFirst(){return u(this,null,function*(){const t=yield navigator.mediaDevices.enumerateDevices(),e=i=>{var o;const a=((o=i.label)==null?void 0:o.toLowerCase())||"";return Ed(i)?4:a.includes("airpods")||a.includes("airdopes")||a.includes("bluetooth")||a.includes("wireless")||a.includes("headphones")||a.includes("headset")||a.includes("earbuds")||a.includes("usb")||a.includes("external")?0:i.deviceId==="default"||a.includes("default")?1:a.includes("built-in")||a.includes("internal")?2:3},r=i=>{var o;if(i.kind!=="videoinput")return!1;const a=((o=i.label)==null?void 0:o.toLowerCase())||"";return a.includes("front")||a.includes("user")||a.includes("selfie")?!0:!(a.includes("back")||a.includes("rear")||a.includes("environment"))};return t.sort((i,a)=>{var p,g;const o=e(i),c=e(a);if(o!==c)return o-c;const d=i.deviceId==="default"||((p=i.label)==null?void 0:p.toLowerCase().includes("default")),l=a.deviceId==="default"||((g=a.label)==null?void 0:g.toLowerCase().includes("default"));if(d&&!l)return-1;if(!d&&l)return 1;if(i.kind==="videoinput"&&a.kind==="videoinput"){const T=r(i),v=r(a);if(T&&!v)return-1;if(!T&&v)return 1}return 0})})}getAvailableDevices(){return u(this,null,function*(){try{return(yield this.enumerateDevicesWithExternalFirst())||[]}catch(t){return this.logger.error("enumerate_devices_failed",{error:t}),[]}})}getAvailableDevicesByKind(t){return u(this,null,function*(){try{return(yield this.enumerateDevicesWithExternalFirst()).filter(({kind:e})=>t===e)}catch(e){throw this.logger.error("enumerate_devices_failed",{error:e}),new A("Failed to get available devices by kind","1609")}})}getDevice(t){return u(this,null,function*(){try{return(yield this.enumerateDevicesWithExternalFirst()).filter(r=>r.deviceId===t)[0]}catch(e){throw this.logger.error("enumerate_devices_failed",{error:e}),new A("Failed to get device","1609")}})}onDeviceChange(t){return u(this,null,function*(){if(Se.supportsDeviceChangeEvent()){let e=yield this.getAvailableDevices();navigator.mediaDevices.addEventListener("devicechange",r=>u(this,null,function*(){var l,p;const i=g=>`${g.kind}-${g.label}-${g.deviceId}-${g.groupId}`,a=new Set(e.map(g=>i(g))),o=yield this.getAvailableDevices(),c=new Set(o.map(g=>i(g))),d={added:o.filter(g=>!a.has(i(g))),removed:e.filter(g=>!c.has(i(g))),devices:o};if(e=o,(l=d.added)!=null&&l.length||(p=d.removed)!=null&&p.length){this.logger.info("repopulated_full_device_list",{devices:JSON.stringify(o)});const g=[...d.added,...d.removed];g.some(T=>T.kind==="audioinput")&&n(this,Ne).getValue("callstats").devices("AUDIO",o==null?void 0:o.filter(T=>T.kind==="audioinput")),g.some(T=>T.kind==="videoinput")&&n(this,Ne).getValue("callstats").devices("VIDEO",o==null?void 0:o.filter(T=>T.kind==="videoinput")),g.some(T=>T.kind==="audiooutput")&&n(this,Ne).getValue("callstats").devices("SPEAKER",o==null?void 0:o.filter(T=>T.kind==="audiooutput")),t(r,d,!1)}}),{signal:n(this,Jn).signal})}})}},Jn=new WeakMap,Qt=new WeakMap,Ne=new WeakMap,Ig);ks([P.trace("WebMediaInterface.destruct")],Ft.prototype,"destruct",1);ks([P.trace("WebMediaInterface.handlePermissionErrors")],Ft.prototype,"handlePermissionErrors",1);ks([P.trace("WebMediaInterface.getAudioAndVideoTrack")],Ft.prototype,"getAudioAndVideoTrack",1);ks([P.trace("WebMediaInterface.getAudioTrack")],Ft.prototype,"getAudioTrack",1);ks([P.trace("WebMediaInterface.getVideoTrack")],Ft.prototype,"getVideoTrack",1);ks([P.trace("WebMediaInterface.getScreenShareTracks")],Ft.prototype,"getScreenShareTracks",1);ks([P.trace("WebMediaInterface.getAvailableDevices")],Ft.prototype,"getAvailableDevices",1);ks([P.trace("WebMediaInterface.getAvailableDevicesByKind")],Ft.prototype,"getAvailableDevicesByKind",1);ks([P.trace("WebMediaInterface.getDevice")],Ft.prototype,"getDevice",1);ks([P.trace("WebMediaInterface.onDeviceChange")],Ft.prototype,"onDeviceChange",1);Ft=ks([dt("1600")],Ft);const Of=Ft,tn={setItem:(s,t,e)=>{try{localStorage.setItem(s,t)}catch(r){e==null||e.error("LocalStorage::setItem::crashed",{error:r,localStorage:{key:s,value:t}})}},getItem:(s,t)=>{try{return localStorage.getItem(s)}catch(e){t==null||t.error("LocalStorage::getItem::crashed",{error:e,localStorage:{key:s}})}return null}},V0=(s=0)=>new Promise(t=>setTimeout(t,s)),L0=(s,t,e)=>{const r=typeof e=="number"?e:250,i=s.createMediaStreamSource(t),a=s.createAnalyser();a.fftSize=2048,i.connect(a);const o=new Uint8Array(a.fftSize);let c=!1;setTimeout(()=>{c=!0},r);function d(){return c?Promise.resolve(!0):(a.getByteTimeDomainData(o),o.some(l=>l!==128&&l!==0)?Promise.resolve(!1):V0().then(d))}return d().then(l=>(i.disconnect(),l),l=>{throw i.disconnect(),l})},x0=typeof AudioContext!="undefined"?AudioContext:null;class kh{constructor(t){h(this,"_AudioContext");h(this,"audioContext");h(this,"_audioContextRefContainers");const e=D({AudioContext:x0},t);Object.defineProperties(this,{_AudioContext:{value:e.AudioContext},audioContext:{value:null,writable:!0},_audioContextRefContainers:{value:new Set},AudioContextProvider:{enumerable:!0,value:kh}})}getOrCreate(t){if(!this._audioContextRefContainers.has(t)&&(this._audioContextRefContainers.add(t),this._AudioContext&&!this.audioContext))try{this.audioContext=new this._AudioContext}catch(e){}return this.audioContext}release(t){this._audioContextRefContainers.has(t)&&(this._audioContextRefContainers.delete(t),!this._audioContextRefContainers.size&&this.audioContext&&(this.audioContext.close(),this.audioContext=null))}}const ag=new kh,U0=3,$0=250;function F0(s){const t={},e=ag.getOrCreate(t);let r=U0;function i(){return r-=1,L0(e,s.srcObject,$0).then(a=>a?r>0?i():!0:!1).catch(()=>!0)}return i().finally(()=>{ag.release(t)})}function og(s,t){return u(this,null,function*(){const e=new Audio,r=new MediaStream;r.addTrack(t),e.srcObject=r;let i=!1;try{const a=e.play();a&&(yield a),i=yield F0(e),i&&s.info("checkIfAudioTrackIsSilent::silence_detected")}catch(a){s.error("checkIfAudioTrackIsSilent::failed_to_detect_silence",{error:a})}finally{e.pause(),e.remove()}return i})}var B0=Object.defineProperty,H0=Object.getOwnPropertyDescriptor,Nf=(s,t,e,r)=>{for(var i=r>1?void 0:r?H0(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&B0(t,e,i),i};let Pd=class extends Da{constructor(t,e,r,i){var o;const a=t.getValue("logger");super(a);h(this,"constructorName",this.constructor.name);h(this,"userSelectedDevice");h(this,"mediaInterface");h(this,"isNonPreferredDevice");h(this,"_mediaTrack");h(this,"transformedMediaTrack");h(this,"middlewares",[]);h(this,"currentDevice");h(this,"userPreferredDeviceKey",`Realtimekit::${this.constructorName}::UserDeviceID`);h(this,"setUserPreferredDevice",t=>tn.setItem(this.userPreferredDeviceKey,t,this.logger));h(this,"getUserPreferredDevice",()=>tn.getItem(this.userPreferredDeviceKey,this.logger));h(this,"isCustomTrack",!1);h(this,"context");this.context=t,this.mediaInterface=e,r&&this.setMediaTrack(r),this.userSelectedDevice=(o=this.getUserPreferredDevice())!=null?o:void 0,this.isNonPreferredDevice=i,this.onTrackEnded=this.onTrackEnded.bind(this),this.onTrackMuted=this.onTrackMuted.bind(this)}get telemetry(){return this.context.getValue("telemetry")}disableTrack(){var t,e;this.removeMediaTrackListeners(),this.isCustomTrack||(t=this._mediaTrack)==null||t.stop(),this._mediaTrack=void 0,(e=this.transformedMediaTrack)==null||e.stop(),this.transformedMediaTrack=void 0}get mediaTrack(){return this._mediaTrack}setMediaTrack(t,e=!1){return u(this,null,function*(){const r=i=>{this.logger.error(`${this.constructorName}.setMediaTrack.error`,{error:i})};try{this.disableTrack()}catch(i){r(i)}this._mediaTrack=yield this.conditionallyChangeTrack(t,e),yield this.setTransformedTrack();try{this.addMediaTrackListeners(),yield this.setCurrentDevice()}catch(i){r(i)}})}get trackEnabled(){return!!this.mediaTrack&&this.mediaTrack.readyState==="live"&&this.mediaTrack.enabled}muteTrack(){if(!this.mediaTrack){this.logger.warn("BaseMediaHandler.muteTrack Tried muting with no track present");return}this.transformedMediaTrack&&(this.transformedMediaTrack.enabled=!1),this.mediaTrack.enabled=!1}unmuteTrack(){return u(this,null,function*(){try{this.mediaTrack?this.mediaTrack.enabled=!0:yield this.enableTrack(!1)}catch(t){throw this.logger.error(`${this.constructorName}.unmuteTrack.error`,{error:t}),this.disableTrack(),new A("Failed to unmute track","1611")}})}getCurrentDeviceId(){var e;const{kind:t}=this.mediaTrack;switch(t){case"audio":{const{deviceId:r}=this.mediaTrack.getSettings();if(r)return r;const i=this.mediaTrack.getConstraints();return this.userSelectedDevice?(i&&typeof i.deviceId=="object"&&"exact"in i.deviceId?i.deviceId.exact:i.deviceId)||((e=i==null?void 0:i.advanced)==null?void 0:e[0].deviceId)||"default":this.mediaTrack.getSettings().deviceId}default:return this.mediaTrack.getSettings().deviceId}}setCurrentDevice(){return u(this,null,function*(){var e;if(!this.mediaTrack){this.currentDevice=void 0;return}const t=this.getCurrentDeviceId();((e=this.currentDevice)==null?void 0:e.deviceId)!==t&&(this.currentDevice=yield this.mediaInterface.getDevice(t))})}setDevice(r,i){return u(this,arguments,function*(t,{saveDevicePreference:e}){if(!t)throw this.logger.warn(`${this.constructorName}.setDevice No device received`),new A("No device received!","1603");this.userSelectedDevice=t.deviceId,e&&this.setUserPreferredDevice(t.deviceId),yield this.onSetDevice(t)})}addMiddleware(t){return u(this,null,function*(){if(Se.isWebKitBased()&&!zP.hasFeature(Z.ALLOW_SAFARI_MEDIA_MIDDLEWARES))return{success:!1,message:"Middlewares are not supported in this WebKit engine based browser."};if(this.middlewares.includes(t))return{success:!1,message:"This middleware has been applied, already. Skipping."};try{return this.middlewares.push(t),this.trackEnabled&&(yield this.setTransformedTrack()),{success:!0,message:"Successfully added the middleware."}}catch(e){return this.logger.error("While adding middleware",{error:e}),this.removeMiddleware(t),{success:!1,message:e==null?void 0:e.message}}})}removeMiddleware(t){return u(this,null,function*(){const e=this.middlewares.indexOf(t,0);if(e>-1)try{return this.middlewares.splice(e,1),yield this.setTransformedTrack(!0),{success:!0,message:"Successfully removed the middleware."}}catch(r){return this.logger.error("While removing middleware",{error:r}),{success:!1,message:r==null?void 0:r.message}}return{success:!1,message:"No such middleware was found. Skipping."}})}removeAllMiddlewares(){return u(this,null,function*(){var t;if((t=this.middlewares)!=null&&t.length)try{return this.middlewares=[],yield this.setTransformedTrack(!0),{success:!0,message:"Successfully removed all the middlewares."}}catch(e){return this.logger.error("While removing all the middlewares",{error:e}),{success:!1,message:e==null?void 0:e.message}}return{success:!1,message:"No middlewares were found. Skipping."}})}addMediaTrackListeners(){var t,e,r;this.mediaTrack&&(this.logger.info(`${this.constructorName}.addMediaTrackListeners for deviceId ${(e=(t=this.mediaTrack)==null?void 0:t.getSettings())==null?void 0:e.deviceId} of type ${(r=this.mediaTrack)==null?void 0:r.kind}`),this.mediaTrack.addEventListener("ended",this.onTrackEnded),this.mediaTrack.addEventListener("mute",this.onTrackMuted))}removeMediaTrackListeners(){var t,e,r;this.mediaTrack&&(this.logger.info(`${this.constructorName}.removeMediaTrackListeners for deviceId ${(e=(t=this.mediaTrack)==null?void 0:t.getSettings())==null?void 0:e.deviceId} of type ${(r=this.mediaTrack)==null?void 0:r.kind}`),this.logger.info(`${this.constructorName}.removeMediaTrackListeners`),this.mediaTrack.removeEventListener("ended",this.onTrackEnded),this.mediaTrack.removeEventListener("mute",this.onTrackMuted))}};Nf([P.trace("BaseMediaHandler.unmuteTrack")],Pd.prototype,"unmuteTrack",1);Pd=Nf([dt("1600")],Pd);const Vf=Pd;var q0=Object.defineProperty,j0=Object.getOwnPropertyDescriptor,Ah=(s,t,e,r)=>{for(var i=r>1?void 0:r?j0(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&q0(t,e,i),i};const ou="[Realtimekit]nonSilentDeviceLabels";class xl extends Vf{onSetDevice(t){return u(this,null,function*(){if(!t)throw this.logger.warn("AudioMediaHandler.setDevice No device received"),new A("No device received!","1603");if(t.kind!=="audioinput")throw this.logger.warn("AudioMediaHandler.setDevice Received non audio device"),new A("Non audio device received while setting device!","1603");try{const e=this.trackEnabled;this.disableTrack(),yield this.setMediaTrack(yield this.mediaInterface.getAudioTrack(!e,this.userSelectedDevice))}catch(e){throw this.logger.error("AudioMediaHandler.setDevice.error",{error:e}),this.disableTrack(),new A(e.message,"1604")}})}enableTrack(t,e){return u(this,null,function*(){if(this.trackEnabled){this.logger.warn("AudioMediaHandler.enableTrack Track already enabled!");return}if(e){this.isCustomTrack=!0,yield this.setMediaTrack(e,!0);return}this.isCustomTrack=!1;const r=yield this.mediaInterface.getAudioTrack(t,this.userSelectedDevice);yield this.setMediaTrack(r)})}setTransformedTrack(t){return u(this,null,function*(){var e;if(!t&&!((e=this.middlewares)!=null&&e.length)){this.transformedMediaTrack=this.mediaTrack;return}try{this.transformedMediaTrack=yield w0(this.context,this.middlewares,this.mediaTrack),this.emit("trackChanged")}catch(r){this.logger.error("AudioMediaHandler.setTransformedTrack",{error:r}),this.transformedMediaTrack=this.mediaTrack}})}onTrackEnded(){return u(this,null,function*(){this.logger.info("AudioMediaHandler.TrackEnded"),this.emit("trackEnded");const t=this.mediaTrack.enabled;this.disableTrack(),yield this.enableTrack(!t),yield this.setTransformedTrack(),this.emit("trackChanged")})}onTrackMuted(){this.logger.info("AudioMediaHandler.TrackMuted"),this.emit("trackMuted")}conditionallyChangeTrack(t,e=!1){return u(this,null,function*(){var d;if(!t||this.userSelectedDevice||e)return t;let r=t;const i=yield this.mediaInterface.getAudioInputDevices(),a=this.isNonPreferredDevice?i.filter(l=>l&&!this.isNonPreferredDevice(l)):i;if(!(a!=null&&a.length))return r;a.find(l=>l.deviceId===t.getSettings().deviceId)||(r.stop(),this.logger.info("localmediahandler::setupstreams::found_audio_non_preferred"),r=yield this.mediaInterface.getAudioTrack(!1,a[0].deviceId));const o=JSON.parse(tn.getItem(ou,this.logger));if(o!=null&&o.devices.some(l=>l.label===r.label))return r;if(!(yield og(this.logger,r))){const l=(d=o==null?void 0:o.devices.concat({label:r.label}))!=null?d:[{label:r.label}];return tn.setItem(ou,JSON.stringify({devices:l}),this.logger),r}this.logger.info("AudioMediaHandler.conditionallyChangeTrack.DetectedSilentTrack");const c=r.getSettings().deviceId;return a.filter(l=>l.deviceId!==c).some(l=>u(this,null,function*(){var p;if(r=yield this.mediaInterface.getAudioTrack(!1,l.deviceId),!(yield og(this.logger,r))){const g=(p=o==null?void 0:o.devices.concat({label:r.label}))!=null?p:[{label:r.label}];return tn.setItem(ou,JSON.stringify({devices:g}),this.logger),this.logger.info("AudioMediaHandler.conditionallyChangeTrack.SuccesfullyChangedTrack"),!0}return this.logger.info("AudioMediaHandler.conditionallyChangeTrack.AnotherSilentTrackFound"),!1})),r})}}Ah([P.trace("AudioMediaHandler.setTransformedTrack")],xl.prototype,"setTransformedTrack",1);Ah([P.trace("AudioMediaHandler.onTrackEnded")],xl.prototype,"onTrackEnded",1);Ah([P.trace("AudioMediaHandler.conditionallyChangeTrack")],xl.prototype,"conditionallyChangeTrack",1);const G0=xl;var Pi;class W0{constructor(t,e){m(this,Pi,void 0);h(this,"currentDevice");h(this,"userPreferredDeviceKey","Realtimekit::speaker::UserDeviceID");h(this,"logger");h(this,"setUserPreferredDevice",t=>tn.setItem(this.userPreferredDeviceKey,t,this.logger));h(this,"getUserPreferredDevice",()=>tn.getItem(this.userPreferredDeviceKey,this.logger));f(this,Pi,e),this.logger=t.getValue("logger")}setPreferredSpeaker(){return u(this,null,function*(){const t=this.getUserPreferredDevice(),e=yield n(this,Pi).getAudioOutputDevices(),r=e==null?void 0:e.find(i=>i.deviceId===t);yield this.setupSpeaker(r,{saveDevicePreference:!1})})}setupSpeaker(r,i){return u(this,arguments,function*(t,{saveDevicePreference:e}){var c,d;if(!(n(this,Pi)instanceof Of))return;let a=t;if(t||([a]=(yield n(this,Pi).getAvailableDevicesByKind("audiooutput")).filter(p=>!Ed(p))),!a)throw new A("No speaker found","1608");if(((c=this.currentDevice)==null?void 0:c.deviceId)===a.deviceId)return;e&&this.setUserPreferredDevice(a.deviceId),this.currentDevice=a;const o=document.querySelectorAll("audio");(d=o[0])!=null&&d.setSinkId&&o.forEach(l=>u(this,null,function*(){if(typeof l.sinkId!="undefined"&&this.currentDevice.deviceId&&l.sinkId!==this.currentDevice.deviceId)try{yield l.setSinkId(this.currentDevice.deviceId)}catch(p){}}))})}}Pi=new WeakMap;const J0=W0;var Lo;class K0 extends Da{constructor(e,r){const i=e.getValue("logger");super(i);h(this,"mediaInterface");h(this,"audioMediaTrack");h(this,"videoMediaTrack");m(this,Lo,void 0);f(this,Lo,e),this.mediaInterface=r}get trackEnabled(){return!!this.videoMediaTrack}enableScreenShare(){return u(this,null,function*(){var e,r;try{const{audioTrack:i,videoTrack:a}=yield this.mediaInterface.getScreenShareTracks();if(this.audioMediaTrack=i,this.videoMediaTrack=a,this.addMediaTrackListeners(),((r=(e=this.mediaInterface)==null?void 0:e.permissions)==null?void 0:r.screenshare)==="ACCEPTED")return;this.mediaInterface.permissions&&(this.mediaInterface.permissions.screenshare="ACCEPTED",n(this,Lo).getValue("peerSessionStore").emit(b.MEDIA_PERMISSION_UPDATE,{message:this.mediaInterface.permissions.screenshare,kind:"screenshare"}))}catch(i){}})}disableScreenShare(){var e,r;this.removeMediaTrackListeners(),(e=this.audioMediaTrack)==null||e.stop(),(r=this.videoMediaTrack)==null||r.stop(),this.videoMediaTrack=void 0,this.audioMediaTrack=void 0}updateConstraints(e){return u(this,null,function*(){if(!this.videoMediaTrack)throw new A("No media track enabled!","1610");const r=this.mediaInterface;if(!r.constraintsBuilder)throw new A("update constraints not supported for non web clients","1100",this.logger);try{this.videoMediaTrack.applyConstraints(r.constraintsBuilder.getUpdatedVideoConstraints(e)),this.addMediaTrackListeners()}catch(i){this.logger.error("ScreenShareHandler.updateConstraints.error",{error:i})}})}addMediaTrackListeners(){var e,r;(e=this.videoMediaTrack)==null||e.addEventListener("ended",this.onTrackEnded.bind(this)),Se.isWebKitBased()&&((r=this.videoMediaTrack)==null||r.addEventListener("mute",this.onTrackEnded.bind(this)))}removeMediaTrackListeners(){var e,r;(e=this.videoMediaTrack)==null||e.removeEventListener("ended",this.onTrackEnded),(r=this.videoMediaTrack)==null||r.removeEventListener("mute",this.onTrackEnded)}onTrackEnded(){this.emit("trackEnded")}}Lo=new WeakMap;const z0=K0;var Y0=Object.defineProperty,Q0=Object.getOwnPropertyDescriptor,Ul=(s,t,e,r)=>{for(var i=r>1?void 0:r?Q0(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Y0(t,e,i),i},Kn,xo;class Lc extends Vf{constructor(e,r,i,a){super(e,r,i,a);m(this,Kn,void 0);m(this,xo,{disablePerFrameCanvasRendering:!1});f(this,Kn,new R0(e))}onSetDevice(e){return u(this,null,function*(){if(!e)throw this.logger.warn("VideoMediaHandler.setDevice No device received"),new A("No device received!","1603");if(e.kind!=="videoinput")throw this.logger.warn("VideoMediaHandler.setDevice Received non video device",{devices:[e]}),new A("Non video device received while setting video device!","1603");if(!(this.mediaTrack&&this.mediaTrack.enabled)){this.logger.warn("VideoMediaHandler.setDevice Tried switching device with video disabled",{devices:[e]}),this.currentDevice=e;return}try{this.disableTrack(),yield this.setMediaTrack(yield this.mediaInterface.getVideoTrack(this.userSelectedDevice))}catch(r){throw this.logger.error("VideoMediaHandler.setDevice.error",{error:r}),this.disableTrack(),new A("Failed to change device","1600",this.logger)}})}enableTrack(e,r){return u(this,null,function*(){if(this.trackEnabled){this.logger.warn("VideoMediaHandler.enableTrack Track already enabled!");return}if(r){this.isCustomTrack=!0,yield this.setMediaTrack(r,!0);return}this.isCustomTrack=!1;const i=yield this.mediaInterface.getVideoTrack(this.userSelectedDevice);yield this.setMediaTrack(i)})}setTransformedTrack(e){return u(this,null,function*(){var r;if(!e&&!((r=this.middlewares)!=null&&r.length)){this.transformedMediaTrack=this.mediaTrack;return}try{this.transformedMediaTrack=yield n(this,Kn).getTransformedVideoTrack(this.middlewares,this.mediaTrack,n(this,xo)),this.emit("trackChanged")}catch(i){this.logger.error("VideoMediaHandler.setTransformedTrack",{error:i}),this.transformedMediaTrack=this.mediaTrack}})}setVideoMiddlewareGlobalConfig(e){return u(this,null,function*(){f(this,xo,e)})}updateConstraints(e){return u(this,null,function*(){if(!this._mediaTrack)throw new A("No media track enabled!","1610");const r=this.mediaInterface;if(!r.constraintsBuilder)throw new A("update constraints not supported for non web clients","1100",this.logger);try{this._mediaTrack.applyConstraints(r.constraintsBuilder.getUpdatedVideoConstraints(e)),yield this.setTransformedTrack(),this.addMediaTrackListeners(),yield this.setCurrentDevice()}catch(i){this.logger.error("VideoMediaHandler.updateConstraints.error",{error:i})}})}terminateMiddlewareWebWorker(){n(this,Kn).terminateMiddlewareWebWorker()}onTrackEnded(){return u(this,null,function*(){this.logger.info("VideoMediaHandler.TrackEnded"),this.disableTrack(),this.emit("trackEnded")})}onTrackMuted(){this.logger.info("VideoMediaHandler.TrackMuted"),this.emit("trackMuted")}conditionallyChangeTrack(e,r=!1){return u(this,null,function*(){if(!e||this.userSelectedDevice||r)return e;let i=e;const a=yield this.mediaInterface.getVideoInputDevices(),o=this.isNonPreferredDevice?a.filter(c=>!this.isNonPreferredDevice(c)):a;return!(o!=null&&o.length)||window.FAST_RTK||o.find(c=>c.deviceId===e.getSettings().deviceId)||(i.stop(),this.logger.info("localmediahandler::setupstreams::found_video_non_preferred"),i=yield this.mediaInterface.getVideoTrack(o[0].deviceId)),i})}}Kn=new WeakMap,xo=new WeakMap;Ul([P.trace("VideoMediaHandler.setTransformedTrack")],Lc.prototype,"setTransformedTrack",1);Ul([P.trace("VideoMediaHandler.setVideoMiddlewareGlobalConfig")],Lc.prototype,"setVideoMiddlewareGlobalConfig",1);Ul([P.trace("VideoMediaHandler.onTrackEnded")],Lc.prototype,"onTrackEnded",1);Ul([P.trace("VideoMediaHandler.conditionallyChangeTrack")],Lc.prototype,"conditionallyChangeTrack",1);const X0=Lc,cg=_s(vh());var yt,_i,Uo,zn;const Sn=class{constructor(t){m(this,yt,void 0);m(this,_i,void 0);m(this,Uo,void 0);m(this,zn,void 0);if(!t)throw new A("Could not load preset.","0904");f(this,yt,t.config),f(this,Uo,t.name),f(this,_i,t.ui||_s(vh().ui)),f(this,zn,t.permissions.plugins.config)}static fromResponse(t){return new Sn(t)}static default(){return new Sn(cg)}static init(t,e=!0){return!t||e?new Sn(cg):new Sn(t)}get setupScreen(){return{isEnabled:!0}}get waitingRoom(){return{isEnabled:!0}}get controlBar(){return{isEnabled:!0,elements:{chat:!0,fullscreen:!0,invite:!1,layout:!1,participants:!0,plugins:!0,polls:!0,reactions:!1,screenshare:!0}}}get header(){return{isEnabled:!0,elements:{logo:n(this,_i).designTokens.logo,timer:!0,title:!0,participantCount:!0,changeLayout:!1}}}get pipMode(){return!0}get viewType(){return n(this,yt).viewType}get livestreamViewerQualities(){return n(this,yt).livestreamViewerQualities||[]}get maxVideoStreams(){return n(this,yt).maxVideoStreams}get maxScreenShareCount(){return n(this,yt).maxScreenshareCount}get plugins(){return[]}get disabledPlugins(){return Object.keys(n(this,zn)).filter(t=>n(this,zn)[t].disabled)}get designTokens(){return n(this,_i).designTokens}get configDiff(){return n(this,_i).configDiff}get mediaConstraints(){var t,e,r,i,a,o,c,d,l,p,g,T,v,E,_,C,R,L,F,N,B,j,re,et;return{audio:{enableStereo:(i=(r=(e=(t=n(this,yt))==null?void 0:t.media)==null?void 0:e.audio)==null?void 0:r.enableStereo)!=null?i:un.audio.enableStereo,enableHighBitrate:(d=(c=(o=(a=n(this,yt))==null?void 0:a.media)==null?void 0:o.audio)==null?void 0:c.enableHighBitrate)!=null?d:un.audio.enableHighBitrate},video:{quality:(T=(g=(p=(l=n(this,yt))==null?void 0:l.media)==null?void 0:p.video)==null?void 0:g.quality)!=null?T:un.video.quality,frameRate:(C=(_=(E=(v=n(this,yt))==null?void 0:v.media)==null?void 0:E.video)==null?void 0:_.frameRate)!=null?C:un.video.frameRate},screenshare:{quality:(N=(F=(L=(R=n(this,yt))==null?void 0:R.media)==null?void 0:L.screenshare)==null?void 0:F.quality)!=null?N:un.screenshare.quality,frameRate:(et=(re=(j=(B=n(this,yt))==null?void 0:B.media)==null?void 0:j.screenshare)==null?void 0:re.frameRate)!=null?et:un.screenshare.frameRate}}}get name(){return n(this,Uo)}};let Nu=Sn;yt=new WeakMap,_i=new WeakMap,Uo=new WeakMap,zn=new WeakMap;var Z0=Object.defineProperty,eD=Object.getOwnPropertyDescriptor,Lf=(s,t,e,r)=>{for(var i=r>1?void 0:r?eD(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Z0(t,e,i),i},Yn,$o;class Ih extends Bt{constructor(e,r){const i=e.getValue("logger");super(i);m(this,Yn,void 0);h(this,"state","IDLE");h(this,"playbackUrl");h(this,"ingestionCredentials");h(this,"viewerCount");m(this,$o,void 0);f(this,Yn,r),f(this,$o,e),this.viewerCount=0}get telemetry(){return n(this,$o).getValue("telemetry")}setLivestreamState(e){const r=this.state;this.state=e,r!==e&&this.emitCurrentLivestreamState()}emitCurrentLivestreamState(){this.emit("livestreamUpdate",this.state)}start(){return u(this,arguments,function*(e={manualIngestion:!1}){if(!n(this,Yn).permissions.canLivestream)throw this.logger.error("Livestream::start::permission_denied"),new A("User does not have permission to start livestreaming","1901");this.setLivestreamState("STARTING");try{const r=ot(),{playbackUrl:i,ingestionCredentials:a}=yield r.startLivestreaming(e);this.playbackUrl=i,this.ingestionCredentials=a,e!=null&&e.manualIngestion&&this.setLivestreamState("WAITING_ON_MANUAL_INGESTION")}catch(r){throw this.logger.error("Recording::stop::livestream_failed_to_start",{error:r}),this.setLivestreamState("IDLE"),new A("Error while starting livestream","1900",this.logger)}})}stop(){return u(this,null,function*(){if(!n(this,Yn).permissions.canLivestream)throw this.logger.error("Livestream::stop::permission_denied"),new A("User does not have permission to stop livestreaming","1901");if(this.state!=="LIVESTREAMING"&&this.state!=="WAITING_ON_MANUAL_INGESTION")throw this.logger.error("Livestream::stop::inconsistent_state"),new A("Livestream not started yet","1902");try{this.setLivestreamState("STOPPING"),yield ot().stopLivestreaming()}catch(e){throw this.logger.error("Livestream::stop::livestream_failed_to_stop",{error:e}),this.setLivestreamState("STOPPING"),new A("Error while stopping livestream","1900",this.logger)}})}}Yn=new WeakMap,$o=new WeakMap;Lf([P.trace("livestream.start")],Ih.prototype,"start",1);Lf([P.trace("livestream.stop")],Ih.prototype,"stop",1);var tD=Object.defineProperty,sD=Object.getOwnPropertyDescriptor,rD=(s,t,e,r)=>{for(var i=r>1?void 0:r?sD(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&tD(t,e,i),i},Qn,Xn,zs,Ms;class xf{constructor(t,e,r){h(this,"livestream");m(this,Qn,void 0);m(this,Xn,void 0);m(this,zs,void 0);m(this,Ms,void 0);f(this,Ms,t),f(this,Xn,e),this.livestream=new Ih(t,e),f(this,zs,r),this.setupEvents()}get logger(){return n(this,Ms).getValue("logger")}get telemetry(){return n(this,Ms).getValue("telemetry")}fetchInitialLivestreamingState(){return u(this,null,function*(){const t=ot(),{status:e,playbackUrl:r,manualIngest:i,ingestionCredentials:a}=yield t.getActiveLivestream();this.livestream.playbackUrl=r,this.livestream.ingestionCredentials=a,e==="LIVE"&&this.livestream.setLivestreamState("LIVESTREAMING"),e==="INVOKED"&&i&&this.livestream.setLivestreamState("WAITING_ON_MANUAL_INGESTION")})}setupEvents(){n(this,zs).on(U.startedLivestream,t=>u(this,null,function*(){this.livestream.playbackUrl=t.playbackUrl,this.livestream.setLivestreamState("LIVESTREAMING");try{n(this,Xn).permissions.canLivestream&&(yield this.fetchInitialLivestreamingState())}catch(e){this.logger.error("Error: LivestreamController.fetchLivestream during startedLivestream re-fetch")}})),n(this,zs).on(U.livestreamingInvoked,t=>u(this,null,function*(){if(t.manualIngest){this.livestream.setLivestreamState("WAITING_ON_MANUAL_INGESTION");try{n(this,Xn).permissions.canLivestream&&(yield this.fetchInitialLivestreamingState())}catch(e){this.logger.error("Error: LivestreamController.fetchLivestream during livestreamingInvoked re-fetch")}}})),n(this,zs).on(U.stoppedLivestream,()=>{this.livestream.setLivestreamState("IDLE"),this.livestream.playbackUrl=void 0,this.livestream.ingestionCredentials=void 0}),n(this,zs).on(U.erroredLivestream,()=>{this.livestream.setLivestreamState("IDLE"),this.livestream.playbackUrl=void 0}),n(this,zs).on(U.roomPeerCount,t=>{this.livestream.viewerCount=t.count,this.livestream.emit("viewerCountUpdate",t.count)}),n(this,Ms).getValue("peerSessionStore").on(b.PEER_JOINED_INTERNAL,t=>u(this,null,function*(){var e;((e=t.flags)==null?void 0:e.hiddenParticipant)===!0&&t.recorderType==="LIVESTREAMER"&&(f(this,Qn,t.id),this.livestream.setLivestreamState("LIVESTREAMING"))})),n(this,Ms).getValue("peerSessionStore").on(b.PEER_CLOSED,t=>{t.id===n(this,Qn)&&(f(this,Qn,void 0),this.livestream.setLivestreamState("IDLE"))}),n(this,Ms).getValue("peerSessionStore").onAsync(b.LEAVE_MEDIA_ROOM,()=>u(this,null,function*(){if(!this.livestream.playbackUrl){this.logger.info("Fetching livestreaming state on leave stage");try{yield this.fetchInitialLivestreamingState()}catch(t){this.logger.error("Failed to fetch livestreaming state on leave stage",{error:t})}}})),n(this,Ms).getValue("peerSessionStore").on(b.SOCKET_SERVICE_ROOM_JOINED,()=>u(this,null,function*(){try{yield this.fetchInitialLivestreamingState()}catch(t){this.logger.error("Error: LivestreamController.fetchLivestream")}}))}}Qn=new WeakMap,Xn=new WeakMap,zs=new WeakMap,Ms=new WeakMap;rD([P.trace("LivestreamController.setupEvents")],xf.prototype,"setupEvents",1);var iD=Object.defineProperty,nD=Object.getOwnPropertyDescriptor,xc=(s,t,e,r)=>{for(var i=r>1?void 0:r?nD(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&iD(t,e,i),i},rt,Vr,Lr,Nd,Uf;class Na{constructor({name:t,socketHandler:e,meetingId:r}){m(this,Nd);h(this,"name","");m(this,rt,{});m(this,Vr,"");m(this,Lr,void 0);h(this,"rateLimitConfig",{maxInvocations:5,period:1});h(this,"bulkRateLimitConfig",{maxInvocations:5,period:1});h(this,"listeners",{});this.name=t,f(this,Lr,e),f(this,Vr,r)}set(t,e,r=!0,i=!1){return u(this,null,function*(){n(this,rt)[t]=e,r&&this.remoteSet(t,e),i&&(this.listeners[t]&&this.listeners[t].forEach(a=>a({[t]:n(this,rt)[t]})),this.listeners["*"]&&this.listeners["*"].forEach(a=>a({[t]:n(this,rt)[t]})))})}remoteSet(t,e){n(this,Lr).storeInsertKeys(n(this,Vr),this.name,[{key:t,payload:e}])}bulkSet(t){return u(this,null,function*(){t.forEach(({key:e,payload:r})=>{n(this,rt)[e]=r}),n(this,Lr).storeInsertKeys(n(this,Vr),this.name,t)})}update(t,e,r=!0){return u(this,null,function*(){x(this,Nd,Uf).call(this,t,e,r)})}delete(t,e=!0,r=!1){return u(this,null,function*(){if(n(this,rt)[t]&&delete n(this,rt)[t],e)return n(this,Lr).storeDeleteKeys(n(this,Vr),this.name,[{key:t}]);r&&(this.listeners[t]&&(this.listeners[t].forEach(i=>i({[t]:void 0})),delete this.listeners[t]),this.listeners["*"]&&this.listeners["*"].forEach(i=>i({[t]:void 0})))})}bulkDelete(t){return u(this,null,function*(){return t.forEach(({key:e})=>{n(this,rt)[e]&&delete n(this,rt)[e]}),n(this,Lr).storeDeleteKeys(n(this,Vr),this.name,t)})}get(t){if(n(this,rt)[t])return n(this,rt)[t]}getAll(){return n(this,rt)}get rateLimits(){return this.rateLimitConfig}updateRateLimits(t,e){this.rateLimitConfig.maxInvocations=t,this.rateLimitConfig.period=e}get bulkRateLimits(){return this.bulkRateLimitConfig}updateBulkRateLimits(t,e){this.bulkRateLimitConfig.maxInvocations=t,this.bulkRateLimitConfig.period=e}subscribe(t,e){if(this.listeners[t]){this.listeners[t].push(e);return}this.listeners[t]=[e]}unsubscribe(t,e){var r;if(e){this.listeners[t]=((r=this.listeners[t])==null?void 0:r.filter(i=>i!==e))||[];return}this.listeners[t]&&delete this.listeners[t]}populate(t){f(this,rt,t)}}rt=new WeakMap,Vr=new WeakMap,Lr=new WeakMap,Nd=new WeakSet,Uf=function(t,e,r=!0){let i;const a=n(this,rt)[t],o=Object.prototype.toString.call(e),c=Object.prototype.toString.call(a);if(o!==c){this.set(t,e);return}switch(c){case"[object Array]":i=[...a,...e];break;case"[object Object]":i=D(D({},a),e);break;case"[object Map]":i=new Map([...a,...e]);break;case"[object Set]":i=new Set([...a,...e]);break;default:i=e;break}this.set(t,i,r)};xc([Rt(Oa,"rateLimitConfig")],Na.prototype,"remoteSet",1);xc([Rt(Oa,"bulkRateLimitConfig")],Na.prototype,"bulkSet",1);xc([Rt(Oa,"rateLimitConfig")],Na.prototype,"update",1);xc([Rt(Oa,"rateLimitConfig")],Na.prototype,"delete",1);xc([Rt(Oa,"bulkRateLimitConfig")],Na.prototype,"bulkDelete",1);var Ci,wi,Fo,Vu,Bo,xr,Vd,$f;class aD{constructor(t,e){m(this,Fo);m(this,Vd);h(this,"stores",new Map);m(this,Ci,void 0);m(this,wi,"");m(this,Bo,void 0);m(this,xr,new Map);f(this,Ci,e),f(this,wi,t.getValue("meetingId")),f(this,Bo,t),x(this,Vd,$f).call(this)}create(t){const e=new Na({name:t,socketHandler:n(this,Ci),meetingId:n(this,wi)});return n(this,Ci).storeGetKeys(n(this,wi),t,[]),new Promise((i,a)=>{const o=setTimeout(()=>a(Error("Failed")),3e3);n(this,xr).set(t,{rejectTimeout:o,resolve:i,store:e})})}}Ci=new WeakMap,wi=new WeakMap,Fo=new WeakSet,Vu=function(){return n(this,Bo).getValue("peerId")},Bo=new WeakMap,xr=new WeakMap,Vd=new WeakSet,$f=function(){[J.storeInsertKeys,J.storeGetKeys,J.storeDeleteKeys].forEach(t=>{n(this,Ci).on(t,e=>u(this,null,function*(){var a,o;if(e.pluginId!==n(this,wi))return;const r=(a=e.storeItems)==null?void 0:a.map(c=>{var d;return{timestamp:c.timestamp,peerId:c.peerId,payload:JSON.parse((d=c.payload)!=null&&d.length?new TextDecoder().decode(c.payload):"{}"),key:c.storeKey}});if(t===J.storeGetKeys){const c=n(this,xr).get(e.storeName),d=this.stores.get(e.storeName)||(c==null?void 0:c.store);n(this,xr).get(e.storeName)&&(this.stores.set(e.storeName,c.store),c.resolve(d),clearTimeout(c.rejectTimeout),n(this,xr).delete(e.storeName)),r.forEach(l=>{d.set(l.key,l.payload,!1,!1)});return}const i=this.stores.get(e.storeName)||((o=n(this,xr).get(e.storeName))==null?void 0:o.store);i!==void 0&&(t===J.storeInsertKeys&&r.forEach(({key:c,peerId:d,payload:l})=>{d!==n(this,Fo,Vu)&&i.set(c,l,!1,!0)}),t===J.storeDeleteKeys&&r.forEach(({key:c,peerId:d})=>{d!==n(this,Fo,Vu)&&i.delete(c,!1,!0)}))}))})};function di(s){var t,e,r,i,a,o,c,d,l,p,g,T,v;return s?{media:{audio:{enabled:s.audioEnabled,trackId:(t=s.audioTrack)==null?void 0:t.id,permission:"mediaPermissions"in s?(e=s.mediaPermissions)==null?void 0:e.audio:null},video:{enabled:s.videoEnabled,trackId:(r=s.videoTrack)==null?void 0:r.id,permission:"mediaPermissions"in s?(i=s.mediaPermissions)==null?void 0:i.video:null},screenshare:{enabled:s.screenShareEnabled,permission:"mediaPermissions"in s?(a=s.mediaPermissions)==null?void 0:a.screenshare:null,audio:{enabled:(c=(o=s.screenShareTracks)==null?void 0:o.audio)==null?void 0:c.enabled,trackId:(l=(d=s.screenShareTracks)==null?void 0:d.audio)==null?void 0:l.id},video:{enabled:(g=(p=s.screenShareTracks)==null?void 0:p.video)==null?void 0:g.enabled,trackId:(v=(T=s.screenShareTracks)==null?void 0:T.video)==null?void 0:v.id}}}}:{}}var oD=Object.defineProperty,cD=Object.getOwnPropertyDescriptor,Va=(s,t,e,r)=>{for(var i=r>1?void 0:r?cD(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&oD(t,e,i),i};const dD=.8,lD=1.2;var Zn,ea,Nt,Ri,so,Ur,gn,bi,ro,Ld,Ff,Ys,Ho,$r,ki,io,Qs,xd,qo,Lu,Ud,Bf,$d,Hf,Mg;let Tr=(Mg=class extends Bt{constructor(t,e,r,i){const a=t.getValue("logger");super(a);m(this,Ri);m(this,Ur);m(this,bi);m(this,Ld);m(this,ki);m(this,qo);m(this,Ud);m(this,$d);h(this,"id");h(this,"userId");h(this,"name");h(this,"picture");h(this,"isHost");h(this,"customParticipantId");h(this,"flags");h(this,"device");h(this,"videoTrack");h(this,"audioTrack");h(this,"screenShareTracks");h(this,"videoEnabled");h(this,"audioEnabled");h(this,"screenShareEnabled");h(this,"producers");h(this,"manualProducerConfig");m(this,Zn,void 0);h(this,"supportsRemoteControl",!1);m(this,ea,void 0);h(this,"presetName");m(this,Nt,void 0);m(this,Ys,void 0);m(this,Ho,void 0);m(this,$r,new Map);m(this,Qs,1);m(this,xd,Eh(t=>{if(!this.videoTrack)return;const{clientWidth:e,clientHeight:r}=t,{width:i,height:a}=this.videoTrack.getSettings();if(!i||!a)return;const o=a/r,c=i/e,d=Math.max(o,c);d>lD&&n(this,Qs)===1?(f(this,Qs,0),n(this,Nt).getValue("peerSessionStore").emit(b.MAX_SPATIAL_LAYER_CHANGE,{peerId:this.id,maxSpatialLayer:n(this,Qs)})):d<dD&&n(this,Qs)===0&&(f(this,Qs,1),n(this,Nt).getValue("peerSessionStore").emit(b.MAX_SPATIAL_LAYER_CHANGE,{peerId:this.id,maxSpatialLayer:n(this,Qs)}))},2e3));f(this,Nt,t);const{id:o,userId:c,displayName:d,device:l,picture:p,isHost:g,flags:T,clientSpecificId:v,stageStatus:E,customParticipantId:_,audioMuted:C,audioTrack:R,videoEnabled:L=!1,videoTrack:F,producers:N,metadata:B}=e;this.id=o,this.userId=c,this.name=d,this.device=l,this.picture=p,this.isHost=g,this.flags=T,this.manualProducerConfig=ew,f(this,ea,E!=null?E:"ON_STAGE"),this.customParticipantId=_!=null?_:v,this.audioEnabled=!C,this.audioTrack=R,this.videoEnabled=L,this.videoTrack=F,this.screenShareTracks={audio:void 0,video:void 0},this.producers=N!=null?N:[],this.presetName=B==null?void 0:B.preset_name,f(this,Zn,!1),f(this,Ys,r),f(this,Ho,i),this.setupEvents(),this.updateVideo=this.updateVideo.bind(this),x(this,qo,Lu).call(this)}get clientSpecificId(){return this.customParticipantId}get stageStatus(){return n(this,ea)}get telemetry(){return n(this,Nt).getValue("telemetry")}setVideoEnabled(t,e=!0){this.videoEnabled=t,e&&(this.logger.info("Participant::setVideoEnabled::videoUpdate",D({},di(this))),this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack}))}setAudioEnabled(t,e=!0){this.audioEnabled=t,e&&(this.logger.info("Participant::setAudioEnabled::audioUpdate",D({},di(this))),this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack}))}setScreenShareEnabled(t,e=!0){this.screenShareEnabled=t,e&&this.emit("screenShareUpdate",{screenShareEnabled:this.screenShareEnabled,screenShareTracks:this.screenShareTracks})}setupEvents(){this.on("videoUpdate",x(this,qo,Lu)),n(this,Ur,gn)&&(this.on("audioUpdate",x(this,Ud,Bf)),this.on("screenShareUpdate",x(this,$d,Hf)))}pin(){return u(this,null,function*(){if(!n(this,bi,ro))throw new A("Can`t pin participant without joining room","1205");if(!n(this,Ys).permissions.pinParticipant)throw new A("You do not have permission to pin participants.","1201");return n(this,Ri,so).pinPeer(this.id)})}unpin(){return u(this,null,function*(){if(!n(this,bi,ro))throw new A("Can`t unpin participant without joining room","1205");if(!n(this,Ys).permissions.pinParticipant)throw new A("You do not have permission to unpin participants.","1201");return n(this,Ri,so).pinPeer(null)})}setIsPinned(t,e=!0){var i;f(this,Zn,t);const r=t?"pinned":"unpinned";(i=n(this,ki,io))==null||i.updateSource(this.id,{pinned:t}),e&&this.emit(r,this)}disableAudio(){return u(this,null,function*(){const t=this.id;if(this.logger.info("Participant::disable_audio",{participant:{id:t}}),!n(this,bi,ro))throw new A("Can`t disable participant audio without joining room","1205");if(n(this,Ys).permissions.canDisableParticipantAudio)return n(this,Ri,so).disableAudio(t);throw this.logger.error("Participant::unauthorized_disable_audio",{participant:{id:t}}),new A("Unauthorized: User does not have permission to disable participant audio.","1201")})}kick(){return u(this,null,function*(){const t=this.id;if(this.logger.info("Participant::kick",{participant:{id:t}}),!n(this,Ld,Ff))throw new A("Can`t kick participant without joining room","1205");if(n(this,Ys).permissions.kickParticipant){yield n(this,Nt).getValue("peerSessionStore").emitAsync(b.KICK_PEER,{peerId:t});return}throw this.logger.error("Participant::unauthorized_kick",{participant:{id:t}}),new A("Unauthorized: User does not have permission to kick participants.","1201")})}disableVideo(){return u(this,null,function*(){const t=this.id;if(this.logger.info("Participant::disable_video",{participant:{id:t}}),!n(this,bi,ro))throw new A("Can`t disable participant video without joining room","1205");if(n(this,Ys).permissions.canDisableParticipantVideo)return n(this,Ri,so).disableVideo(t);throw this.logger.error("Participant::unauthorized_disable_video",{participant:{id:t}}),new A("Unauthorized: User does not have permission to disable participant video.","1201")})}getPermissions(){return u(this,null,function*(){return n(this,Ho).getUserPermissions(this.userId)})}setStageStatus(t){f(this,ea,t),this.emit("stageStatusUpdate",this)}get isPinned(){return n(this,Zn)}registerVideoElement(t){var r,i,a,o;if(!t)return;let e;(i=(r=n(this,$r).get(t))==null?void 0:r.observer)==null||i.disconnect(),"ResizeObserver"in window&&(e=new ResizeObserver(()=>n(this,xd).call(this,t)),e.observe(t)),n(this,$r).set(t,{observer:e}),this.updateVideo(t),(o=n(this,ki,io))==null||o.addSource(this.id,t,this.videoEnabled,this.isPinned,this.name,this.picture,(a=this.raised)!=null?a:!1)}deregisterVideoElement(t){var e,r,i,a;if(!t){(e=n(this,ki,io))==null||e.removeSource(this.id);return}t.srcObject=void 0,(i=(r=n(this,$r).get(t))==null?void 0:r.observer)==null||i.disconnect(),n(this,$r).delete(t),(a=n(this,ki,io))==null||a.removeSource(this.id)}updateVideo(t){var e;if(this.videoEnabled){if(this.videoTrack==null)return;const r=(e=t.srcObject)==null?void 0:e.getTracks()[0];if((r==null?void 0:r.id)===this.videoTrack.id)return;const i=new MediaStream;i.addTrack(this.videoTrack),t.srcObject=i}else t.srcObject=void 0;t.style.display=this.videoEnabled?"block":"none"}},Zn=new WeakMap,ea=new WeakMap,Nt=new WeakMap,Ri=new WeakSet,so=function(){return n(this,Nt).getValue("roomNodeClient")},Ur=new WeakSet,gn=function(){return n(this,Nt).getValue("audioPlayback")},bi=new WeakSet,ro=function(){return n(this,Nt).getValue("connectionHandler").mediaJoined},Ld=new WeakSet,Ff=function(){return n(this,Nt).getValue("connectionHandler").socketJoined},Ys=new WeakMap,Ho=new WeakMap,$r=new WeakMap,ki=new WeakSet,io=function(){return n(this,Nt).getValue("pip")},Qs=new WeakMap,xd=new WeakMap,qo=new WeakSet,Lu=function(){Array.from(n(this,$r).keys()).forEach(this.updateVideo)},Ud=new WeakSet,Bf=function(){var t,e;this.audioEnabled&&this.audioTrack?(t=n(this,Ur,gn))==null||t.addParticipantTrack(this.id,this.audioTrack):(e=n(this,Ur,gn))==null||e.removeParticipantTrack(this.id)},$d=new WeakSet,Hf=function(){var t,e;this.screenShareEnabled&&this.screenShareTracks.audio?(t=n(this,Ur,gn))==null||t.addParticipantTrack(`screenshare-${this.id}`,this.screenShareTracks.audio):(e=n(this,Ur,gn))==null||e.removeParticipantTrack(`screenshare-${this.id}`)},Mg);Va([P.trace("Participant.disableAudio")],Tr.prototype,"disableAudio",1);Va([P.trace("Participant.kick")],Tr.prototype,"kick",1);Va([P.trace("Participant.disableVideo")],Tr.prototype,"disableVideo",1);Va([P.trace("Participant.getPermissions")],Tr.prototype,"getPermissions",1);Va([P.trace("Participant.setStageStatus")],Tr.prototype,"setStageStatus",1);Tr=Va([dt("1200")],Tr);class to extends If{constructor(t,e){const{onAddEvent:r="participantJoined",onDeleteEvent:i="participantLeft",onClearEvent:a="participantsCleared"}=e!=null?e:{};super({onAddEvent:r,onDeleteEvent:i,onClearEvent:a},t)}add(t,e=!0){return this.has(t.id)&&Object.is(this.get(t.id),t)===!1&&this.delete(t.id),super.add(t,e)}clear(t=!0,e=!1){return super.clear(t,e)}delete(t,e=!0,r=!1){return super.delete(t,e,r)}}var Fr;class uD extends Da{constructor(e){super(e);m(this,Fr,void 0);f(this,Fr,new Map)}__set(e,r){return n(this,Fr).set(e,r)}__clear(){return n(this,Fr).clear()}get(e){return n(this,Fr).get(e)}toArray(){return Array.from(n(this,Fr).values())}}Fr=new WeakMap;class hD{constructor(){h(this,"_orderedArray");h(this,"_map");this._map=new Map,this._orderedArray=[]}add(t,e){if(!this._map.has(t))return this._map.set(t,{peerId:t,priority:e}),this._orderedArray.splice(Math.max(e-1,0),0,t),this.index(t);const r=this.index(t);this.delete(t);const i=this.add(t,e);return r!==i?i:-1}delete(t){if(this._map.has(t)){const e=this.index(t);this._map.delete(t),this._orderedArray.splice(e,1)}}index(t){return this._map.has(t)?this._orderedArray.indexOf(t):-1}[Symbol.iterator](){return this._orderedArray[Symbol.iterator]()}}class pD{constructor(){h(this,"_activeSpeakerPeers");h(this,"_compulsoryPeers");this._activeSpeakerPeers=new hD,this._compulsoryPeers=new Set}add(t,e,r){if(!t)return-1;if(e<0)return this._compulsoryPeers.add(t),0;const i=r.getValue("logger");if(this.compulsoryPeers.includes(t)&&(e>0||e===246267631)){if(i.info("SelectedPeer::removing_compulsory_peer",{selectedPeer:{peerId:t}}),this._removeFromCompulsoryPeer(t),e===246267631)return-1}else if(e===229490415)return this.delete(t,r),-1;return this._activeSpeakerPeers.add(t,e)}delete(t,e){const r=e==null?void 0:e.getValue("logger");r==null||r.info("SelectedPeer::deleting_peer_from_selectedPeer",{selectedPeer:{peerId:t}}),this._removeFromCompulsoryPeer(t),this._activeSpeakerPeers.delete(t)}index(t){return this._activeSpeakerPeers.index(t)}get peers(){return Array.from(new Set(this.compulsoryPeers.concat(this.activeSpeakerPeers)))}get compulsoryPeers(){return Array.from(this._compulsoryPeers.values())}get activeSpeakerPeers(){return Array.from(this._activeSpeakerPeers)}_removeFromCompulsoryPeer(t){this._compulsoryPeers.delete(t)}}const qf=new pD;var gD=Object.defineProperty,mD=Object.getOwnPropertyDescriptor,jt=(s,t,e,r)=>{for(var i=r>1?void 0:r?mD(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&gD(t,e,i),i};const fD=["ACTIVE_GRID","PAGINATED","MANUAL"];var Ee,jo,xu,Ai,no,ta,od,Ii,Et,Dg;let vt=(Dg=class extends Bt{constructor(t,e,r){const i=t.getValue("logger");super(i);m(this,jo);m(this,Ai);m(this,ta);h(this,"waitlisted");h(this,"joined");h(this,"active");h(this,"videoSubscribed");h(this,"audioSubscribed");h(this,"pinned");h(this,"all");m(this,Ee,void 0);m(this,Ii,void 0);m(this,Et,void 0);h(this,"rateLimitConfig",{maxInvocations:5,period:1});h(this,"viewMode");h(this,"currentPage");h(this,"lastActiveSpeaker");h(this,"selectedPeers",qf);f(this,Ee,t),f(this,Ii,e),f(this,Et,r),this.waitlisted=new to(i),this.joined=new to(i),this.videoSubscribed=new to(i),this.audioSubscribed=new to(i),this.active=this.videoSubscribed,this.pinned=new to(i),this.all=new uD(i),this.viewMode="ACTIVE_GRID",this.currentPage=0,this.setupEvents()}get pip(){return n(this,Ee).getValue("pip")}get rateLimits(){return this.rateLimitConfig}updateRateLimits(t,e){this.rateLimitConfig.maxInvocations=t,this.rateLimitConfig.period=e}get telemetry(){return n(this,Ee).getValue("telemetry")}setupEvents(){n(this,Ee).getValue("peerSessionStore").on(b.E2EE_ACTIVE_CONSUMER,({peerId:e})=>{var r;((r=n(this,Ee).getValue("modules").e2ee)==null?void 0:r.enabled)!==!0&&this.emit("media_decode_error",{reason:`Got encrypted media for participantId ${e}, but encryption wasn't enabled in init.defaults`,code:"1702"})});const t=n(this,Ee).getValue("audioPlayback");t&&this.audioSubscribed.on("participantLeft",e=>{t.removeParticipantTrack(e.id)})}get count(){return this.joined.size}get maxActiveParticipantsCount(){var t;return(t=n(this,Ee))==null?void 0:t.getValue("maxPreferredStreams")}setMaxActiveParticipantsCount(t){if(t<0||t>24)throw new A("0 <= Max active participants count limit <= 24","1203");n(this,Ee).setValue("maxPreferredStreams",t),n(this,ta,od)&&n(this,Ee).getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:this.viewMode,page:this.currentPage})}get pageCount(){if(this.viewMode==="PAGINATED"){const t=this.selectedPeers.compulsoryPeers.length,e=this.joined.toArray().filter(r=>r.stageStatus==="ON_STAGE");return Math.ceil((e.length-t)/Math.max(this.maxActiveParticipantsCount-t,1))}return 0}acceptWaitingRoomRequest(t){var r,i;if(!n(this,Ai,no))throw new A("Can`t accept waiting room request without joining room","1205");const e=(i=(r=this.waitlisted.get(t))==null?void 0:r.userId)!=null?i:t;return n(this,Et).acceptWaitingRoomRequest([e])}acceptAllWaitingRoomRequest(t){return u(this,null,function*(){const e=t.map(r=>{var i,a;return(a=(i=this.waitlisted.get(r))==null?void 0:i.userId)!=null?a:r});return n(this,Et).acceptWaitingRoomRequest(e)})}rejectWaitingRoomRequest(t){return u(this,null,function*(){var r,i;if(!n(this,Ai,no))throw new A("Can`t reject waiting room request without joining room","1205");const e=(i=(r=this.waitlisted.get(t))==null?void 0:r.userId)!=null?i:t;n(this,Et).rejectWaitingRoomRequest([e])})}setViewMode(t){return u(this,null,function*(){if(this.logger.info("Participants::set_view_mode",{pageNavigation:{viewMode:t,currentPage:this.currentPage,pageCount:this.pageCount,maxActiveParticipantsCount:this.maxActiveParticipantsCount}}),!(r=>fD.includes(r))(t))throw this.logger.error("Participants::setViewMode::invalid_view_mode",{pageNavigation:{viewMode:t,currentPage:this.currentPage,pageCount:this.pageCount,maxActiveParticipantsCount:this.maxActiveParticipantsCount}}),new A(`Invalid view mode: ${t}. Try ACTIVE_GRID, PAGINATED or MANUAL.`,"1207");if(this.viewMode===t){this.logger.info("Participants::setViewMode::view_mode_same_as_previous");return}this.viewMode=t,t==="PAGINATED"?(this.currentPage=1,n(this,Ee).getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:t,page:this.currentPage})):t==="ACTIVE_GRID"?(this.currentPage=0,n(this,Ee).getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:t,page:this.currentPage})):t==="MANUAL"&&(this.currentPage=0,n(this,Ee).getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:t,page:this.currentPage})),this.emit("viewModeChanged",{viewMode:t,currentPage:this.currentPage,pageCount:this.pageCount})})}subscribe(r){return u(this,arguments,function*(t,e=["audio","video","screenshareAudio","screenshareVideo"]){if(this.viewMode!=="MANUAL")throw new A("MANUAL subscription mode was not activated.","1206");t.forEach(i=>{const a=this.joined.get(i);a&&(e.includes("audio")&&(a.manualProducerConfig=G(D({},a.manualProducerConfig),{audio:!0}),this.audioSubscribed.has(a.id)||this.audioSubscribed.add(a)),e.includes("video")&&(a.manualProducerConfig=G(D({},a.manualProducerConfig),{video:!0}),this.videoSubscribed.has(a.id)||this.videoSubscribed.add(a)),e.includes("screenshareAudio")&&(a.manualProducerConfig=G(D({},a.manualProducerConfig),{screenshareAudio:!0}),this.audioSubscribed.has(a.id)||this.audioSubscribed.add(a)),e.includes("screenshareVideo")&&(a.manualProducerConfig=G(D({},a.manualProducerConfig),{screenshareVideo:!0}),this.videoSubscribed.has(a.id)||this.videoSubscribed.add(a)))}),n(this,Ee).getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:this.viewMode,page:this.currentPage})})}unsubscribe(r){return u(this,arguments,function*(t,e=["audio","video","screenshareAudio","screenshareVideo"]){if(this.viewMode!=="MANUAL")throw new A("MANUAL subscription mode was not activated.","1206");t.forEach(i=>{const a=this.joined.get(i);a&&(e.includes("audio")&&(a.manualProducerConfig=G(D({},a.manualProducerConfig),{audio:!1}),a.manualProducerConfig.screenshareAudio||this.audioSubscribed.delete(a.id)),e.includes("video")&&(a.manualProducerConfig=G(D({},a.manualProducerConfig),{video:!1}),a.manualProducerConfig.screenshareVideo||this.videoSubscribed.delete(a.id)),e.includes("screenshareAudio")&&(a.manualProducerConfig=G(D({},a.manualProducerConfig),{screenshareAudio:!1}),a.manualProducerConfig.audio||this.audioSubscribed.delete(a.id)),e.includes("screenshareVideo")&&(a.manualProducerConfig=G(D({},a.manualProducerConfig),{screenshareVideo:!1}),a.manualProducerConfig.video||this.videoSubscribed.delete(a.id)))}),n(this,Ee).getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:this.viewMode,page:this.currentPage})})}getPeerIdsForCurrentPage(){this.logger.info("Participants::getPeerIdsForCurrentPage()",{pageNavigation:{viewMode:this.viewMode,currentPage:this.currentPage,pageCount:this.pageCount,maxActiveParticipantsCount:this.maxActiveParticipantsCount}});const{compulsoryPeers:t}=this.selectedPeers,e=t.filter(c=>this.joined.has(c)),r=Array.from(this.pinned.keys()).filter(c=>!e.includes(c)),i=Array.from(this.joined.toArray().filter(c=>c.stageStatus==="ON_STAGE").map(c=>c.id)),a=Math.max((this.currentPage-1)*(this.maxActiveParticipantsCount-e.length-r.length)),o=this.currentPage*(this.maxActiveParticipantsCount-e.length-r.length);return e.concat(r,i.slice(a,o))}setPage(t){return u(this,null,function*(){if(this.logger.info("Participants::set_page",{pageNavigation:{settingPage:t,viewMode:this.viewMode,currentPage:this.currentPage,pageCount:this.pageCount,maxActiveParticipantsCount:this.maxActiveParticipantsCount}}),this.viewMode==="PAGINATED"){if(!Number.isInteger(t))throw this.logger.error("Participants::invalid_page_number"),new A(`Invalid page: ${t}. Page must be an integer and greater than 0 and less than or equal to .pageCount`,"1202");this.currentPage=t,n(this,Ee).getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:this.viewMode,page:t}),this.emit("pageChanged",{viewMode:this.viewMode,currentPage:this.currentPage,pageCount:this.pageCount})}})}disableAllAudio(t){return u(this,null,function*(){if(this.logger.info("Participants::disable_all_audio",{actions:{disableAllAudio:{allowUnmute:t}}}),!n(this,ta,od))throw new A("Can`t disable all audio without joining room","1205");if(n(this,Ii).permissions.canAllowParticipantAudio)return n(this,jo,xu).muteAll(t);throw this.logger.error("Participants::unauthorized_disable_all_audio",{actions:{disableAllAudio:{allowUnmute:t}}}),new A("Unauthorized: User does not have permission to disable peer audio.","1201")})}disableAllVideo(){return u(this,null,function*(){if(this.logger.info("Participants::disable_all_video"),!n(this,ta,od))throw new A("Can`t disable all video without joining room","1205");if(n(this,Ii).permissions.canAllowParticipantVideo)return n(this,jo,xu).muteAllVideo();throw this.logger.error("Participants::unauthorized_disable_all_video"),new A("Unauthorized: User does not have permission to disable peer video.","1201")})}disableAudio(t){return u(this,null,function*(){this.joined.get(t).disableAudio()})}disableVideo(t){return u(this,null,function*(){this.joined.get(t).disableVideo()})}kick(t){return u(this,null,function*(){yield n(this,Ee).getValue("peerSessionStore").emitAsync(b.KICK_PEER,{peerId:t})})}kickAll(){return u(this,null,function*(){if(this.logger.info("Participants::kick_all"),n(this,Ee).getValue("viewType")!=="LIVESTREAM"&&!n(this,Ai,no))throw new A("Can`t kick all without joining room","1205");if(!n(this,Ii).permissions.kickParticipant)throw this.logger.error("Participants::unauthorized_kick_all"),new A("Unauthorized: User does not have permission to kick peers.","1201");const e=n(this,Ee).getValue("flagsmith").hasFeature(Z.PROPAGATE_KICK_ALL);n(this,Et).kickAll(e)})}broadcastMessage(t,e,r){return u(this,null,function*(){if(this.logger.info("Participants::broadcastMessage"),!n(this,Ai,no))throw new A("Can`t broadcast message without joining room","1205");if(!(t!=null&&t.trim()))throw new A("`type` must be a non-empty string.","1209");if(r)if("meetingIds"in r)yield n(this,Et).broadcastToMeetings(t,r.meetingIds,e);else{let i=[];"participantIds"in r?i=r.participantIds:i=this.joined.toArray().filter(a=>{var o;return(o=r.presetNames)==null?void 0:o.includes(a.presetName)}).map(a=>a.id),yield n(this,Et).broadcastToPeers(t,i,e)}else yield n(this,Et).broadcastMessage(t,e)})}getAllJoinedPeers(t,e,r){return u(this,null,function*(){return(yield n(this,Et).getRoomPeers(t,e,r)).peers.map(Pr.formatSocketPeerMessage)})}updatePermissions(t,e){return u(this,null,function*(){const r=this.joined.toArray().filter(a=>t.includes(a.id)).map(a=>a.userId),i=[...new Set(r)];if(!i.length)throw new A("Cannot update permissions, no valid userIDs found","1204");n(this,Et).updatePermissions(i,e)})}getParticipantsInMeetingPreJoin(){return u(this,null,function*(){return n(this,Et).getRoomPeersNonPaginated()})}},Ee=new WeakMap,jo=new WeakSet,xu=function(){return n(this,Ee).getValue("roomNodeClient")},Ai=new WeakSet,no=function(){var t;return((t=n(this,Ee).getValue("connectionHandler"))==null?void 0:t.socketJoined)===!0},ta=new WeakSet,od=function(){var t;return((t=n(this,Ee).getValue("connectionHandler"))==null?void 0:t.mediaJoined)===!0},Ii=new WeakMap,Et=new WeakMap,Dg);jt([P.trace("Participants.setViewMode")],vt.prototype,"setViewMode",1);jt([P.trace("Participants.setPage")],vt.prototype,"setPage",1);jt([P.trace("Participants.disableAllAudio")],vt.prototype,"disableAllAudio",1);jt([P.trace("Participants.disableAllVideo")],vt.prototype,"disableAllVideo",1);jt([P.trace("Participants.disablePeerAudio")],vt.prototype,"disableAudio",1);jt([P.trace("Participants.disablePeerVideo")],vt.prototype,"disableVideo",1);jt([P.trace("Participants.kickPeer")],vt.prototype,"kick",1);jt([P.trace("Participants.kickAll")],vt.prototype,"kickAll",1);jt([P.trace("Participants.broadcastMessage"),Rt(Oa,"rateLimitConfig")],vt.prototype,"broadcastMessage",1);jt([P.trace("Participants.getAllJoinedPeers"),Rt({maxInvocations:10,period:60})],vt.prototype,"getAllJoinedPeers",1);jt([P.trace("Participant.updatePermissions"),Rt({maxInvocations:1e3,period:60})],vt.prototype,"updatePermissions",1);jt([P.trace("Participants.getParticipantsInMeetingPreJoin")],vt.prototype,"getParticipantsInMeetingPreJoin",1);vt=jt([dt("1200")],vt);var TD=Object.defineProperty,vD=Object.getOwnPropertyDescriptor,dn=(s,t,e,r)=>{for(var i=r>1?void 0:r?vD(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&TD(t,e,i),i},Xt,gs,sa,Og;const jf=(Og=class{constructor(s,t,e){h(this,"participants");h(this,"self");h(this,"selectedPeers",qf);h(this,"maxSpatialLayerUpdates",new Map);h(this,"consumerPeerMap");h(this,"events");h(this,"roomSocketHandler");h(this,"context");h(this,"videoPeerConsumerMap",new Map);m(this,Xt,{mode:"ACTIVE_GRID",page:0});m(this,gs,!1);m(this,sa,!1);h(this,"updateConsumerSpatialLayers",Eh(()=>{const s={},t=new Map(this.maxSpatialLayerUpdates);this.maxSpatialLayerUpdates.clear(),Array.from(t.entries()).forEach(([e,r])=>{s[r]===void 0&&(s[r]={layer:r,consumerIds:[]}),s[r].consumerIds.push(e)}),Object.keys(s).forEach(e=>{const r=s[e];this.logger.log(`Switching max spatial layer to ${r.layer}`,{consumerIds:r.consumerIds}),this.roomNodeClient.switchConsumersToLayer(r.consumerIds,r.layer)})},2e3));h(this,"updateConsumers",(s,t)=>u(this,null,function*(){this.logger.info(`updateConsumers: Starting consumer updates - AddProducers: ${s.length}, RemoveProducers: ${t.length}, ConsumersSyncing: ${n(this,gs)}`);try{s.length!==0&&(this.logger.info(`updateConsumers: Creating consumers for ${s.length} producers: [${s.map(e=>e.producerId).join(", ")}]`),yield this.roomNodeClient.createConsumers(s),this.logger.info("updateConsumers: Successfully created consumers."))}catch(e){this.logger.error("updateConsumers: Error creating consumers",{error:e})}try{t.length!==0&&(this.logger.info(`updateConsumers: Closing consumers for ${t.length} producers: [${t.map(e=>e.producerId).join(", ")}]`),yield this.roomNodeClient.closeConsumers(t),this.logger.info("updateConsumers: Successfully closed consumers."))}catch(e){this.logger.error("updateConsumers: Error closing consumers",{error:e})}this.logger.info("updateConsumers: Completed consumer updates.")}));this.context=s,this.roomSocketHandler=e,this.participants=new vt(s,t,this.roomSocketHandler),this.self=t,this.consumerPeerMap=new Map,this.events=Ps,t.config.viewType!=="CHAT"&&this.setupEventsGlobal(),this.setupEvents()}get roomNodeClient(){return this.context.getValue("roomNodeClient")}get mediaJoined(){var s;return((s=this.roomNodeClient)==null?void 0:s.mediaJoined)===!0}get pip(){return this.context.getValue("pip")}get telemetry(){return this.context.getValue("telemetry")}get logger(){return this.context.getValue("logger")}setupEvents(){this.roomSocketHandler.on(U.getWaitingRoomRequests,this.waitingRoomRequestHandler.bind(this)),this.context.getValue("peerSessionStore").on(b.SOCKET_PEERS,s=>u(this,null,function*(){const t=this.context.getValue("flagsmith").hasFeature(Z.DEBUG_SOCKET_JOIN);if(t){const e=s&&(s==null?void 0:s.length)<20?{peers:JSON.stringify(s.map(r=>r.peerId))}:void 0;this.logger.info("Processing socket peers",e)}s==null||s.forEach(e=>{e.waitlisted||this.onParticipantSocketJoined(this.createParticipantObjFromSocketPeer(e))}),t&&this.logger.info("Processed socket peers")})),this.roomSocketHandler.on(this.events.peerJoinedBroadcast,({participant:s})=>{this.logger.info("PEER_INFO:::MEDIA_JOIN",{participant:{id:s.peerId,maskedName:[...(s==null?void 0:s.displayName)||""].map((t,e)=>e%2?"*":t).join("")}}),this.logger.info("events.peerJoinedBroadcast",{peers:s.peerId}),this.onParticipantMediaJoined(s.peerId,s.producerStates,s.capabilities)}),this.roomSocketHandler.on(this.events.selfJoinComplete,({participants:s,selectedPeers:t,roomState:e})=>{if(this.context.getValue("flagsmith").hasFeature(Z.DEBUG_SOCKET_JOIN)){const a=s&&(s==null?void 0:s.length)<20?{peers:JSON.stringify(s.map(o=>o.peerId))}:void 0;this.logger.info("events.selfJoinComplete",a)}s.forEach(({peerId:a,producerStates:o,capabilities:c})=>this.onParticipantMediaJoined(a,o,c));const{audioPeers:r,compulsoryPeers:i}=t!=null?t:{};e.pinnedPeerIds.length!==0&&this.onParticipantPinned(e.pinnedPeerIds[0]),this.computeActivateParticipants(r!=null?r:[],i),this.logger.info("selfJoinComplete: Emitting UPDATE_ACTIVE with createAllConsumers=true"),this.context.getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{createAllConsumers:!0})}),this.context.getValue("peerSessionStore").on(b.MAX_SPATIAL_LAYER_CHANGE,({peerId:s,maxSpatialLayer:t})=>{const e=this.videoPeerConsumerMap.get(s);e&&(this.context.getValue("flagsmith").hasFeature(Z.DISABLE_LAYER_SWITCH)||(this.maxSpatialLayerUpdates.set(e,t),this.updateConsumerSpatialLayers()))}),this.context.getValue("peerSessionStore").on(b.NEW_PRODUCER,({peerId:s,producer:t})=>{const e=this.participants.joined.get(s);if(!e){this.logger.warn("ParticipantController::NEW_PRODUCER::participant not found",{producer:{id:t==null?void 0:t.producerId,kind:t==null?void 0:t.kind,status:"not_initialized",appData:{screenShare:t==null?void 0:t.screenShare}},participant:{id:s}});return}e.producers.push(t),this.logger.info("ParticipantController::NEW_PRODUCER::producer_added_to_participant",{producer:{id:t==null?void 0:t.producerId,peerId:s,kind:t==null?void 0:t.kind,status:"not_initialized",appData:{screenShare:t==null?void 0:t.screenShare}}}),(t==null?void 0:t.kind)==="audio"&&this.participants.audioSubscribed.get(s)||(t==null?void 0:t.kind)==="video"&&this.participants.videoSubscribed.get(s)||t!=null&&t.screenShare?(this.logger.info(`NEW_PRODUCER: scheduling syncConsumer (AUTO mode) - Producer: ${t.producerId}, Peer: ${s}, Kind: ${t.kind}, ScreenShare: ${t.screenShare}, ConsumersSyncing: ${n(this,gs)}, VideoSub: ${t.kind==="video"?this.participants.videoSubscribed.has(s):"N/A"}, AudioSub: ${t.kind==="audio"?this.participants.audioSubscribed.has(s):"N/A"}`),this.scheduleSyncConsumers({source:"NEW_PRODUCER_AUTO"})):this.logger.info("ParticipantController::NEW_PRODUCER::not_consuming_producer_auto",{producer:{id:t==null?void 0:t.producerId,peerId:s,kind:t==null?void 0:t.kind,status:"UNKNOWN",appData:{screenShare:t==null?void 0:t.screenShare}}})}),this.context.getValue("peerSessionStore").on(b.PRODUCER_CLOSED,({peerId:s,producerId:t})=>{const e=this.participants.joined.get(s);if(!e){this.logger.warn("ParticipantController::NEW_PRODUCER::participant not found",{participant:{id:s}});return}e.producers=e.producers.filter(r=>r.producerId!==t)}),this.context.getValue("peerSessionStore").on(b.PRODUCER_TOGGLE,({peerId:s,producerId:t,paused:e,kind:r})=>{const i=this.participants.joined.get(s);if(i){r==="audio"&&i.setAudioEnabled(!e);const a=i.producers.find(o=>o.producerId===t);a&&(a.pause=e),r==="video"&&this.context.getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:this.participants.viewMode,page:this.participants.currentPage})}}),this.roomSocketHandler.on(this.events.globalPeerPinBroadcast,s=>{let t;if(s&&(t=s.participantId),!this.mediaJoined)return;const e=t;this.onParticipantPinned(e);const r=this.participants.joined.get(e);r&&(this.logger.info(`globalPeerPinBroadcast: Scheduling audio/video consumer sync for pinned participant ${e} - ProducerCount: ${r.producers.length}, ConsumersSyncing: ${n(this,gs)}, ProducerIds: [${r.producers.map(i=>i.producerId).join(", ")}]`),this.scheduleSyncConsumers({source:"GLOBAL_PEER_PIN"}))}),this.roomSocketHandler.on(this.events.selectedPeer,({audioPeers:s,compulsoryPeers:t})=>{this.mediaJoined&&this.onSelectedPeers(t.concat(s))}),this.roomSocketHandler.on(this.events.selectedPeerDiff,({entries:s})=>{if(!this.mediaJoined)return;const t=s.map(e=>({peerId:e.peerId,priority:e.priority}));this.updateActiveParticipantsWithPriorities(t,!0)})}waitingRoomRequestHandler(s){const t=s.requests.filter(r=>!this.participants.waitlisted.toArray().find(i=>i.userId===r.userId)),e=this.participants.waitlisted.toArray().filter(r=>!s.requests.find(i=>i.userId===r.userId));t.forEach(r=>this.participants.waitlisted.add(new Tr(this.context,{id:r.peerId,displayName:r.displayName,audioMuted:!0,videoEnabled:!1,audioTrack:void 0,videoTrack:void 0,stageStatus:"OFF_STAGE",userId:r.userId,flags:{},isHost:!1,customParticipantId:r.customParticipantId,picture:r.picture,metadata:{preset_name:r.presetName}},this.self,this.roomSocketHandler))),e.forEach(r=>this.participants.waitlisted.delete(r.id))}get maxPreferredStreams(){return this.participants.maxActiveParticipantsCount}selectPagePeers(s){const{compulsoryPeers:t}=this.selectedPeers,e=t.filter(d=>this.participants.joined.has(d)),r=Array.from(this.participants.pinned.keys()).filter(d=>!e.includes(d)),i=Array.from(this.participants.joined.toArray().filter(d=>d.stageStatus==="ON_STAGE").map(d=>d.id)),a=Math.max((s-1)*(this.maxPreferredStreams-e.length-r.length)),o=s*(this.maxPreferredStreams-e.length-r.length);return e.concat(r,i.slice(a,o))}selectActivePeers(s){const t=new Map,e=Array.from(this.participants.joined.toArray().filter(p=>p.stageStatus==="ON_STAGE").map(p=>(t.set(p.id,!0),p.id))),r=this.selectedPeers.peers,i=this.participants.pinned.toArray().reduce((p,g)=>(g.stageStatus!=="ON_STAGE"?this.participants.pinned.delete(g.id):p.push(g.id),p),[]),a=this.self.stageStatus==="ON_STAGE"?1:0,o=s-a,c=new Set(r.concat(i).filter(p=>p!==this.self.id&&t.has(p)));let d=Array.from(c);const l=o-c.size;if(l>=0){const p=e.filter(g=>!c.has(g)&&g!==this.self.id).slice(0,l);d=Array.from(c).concat(p)}else d=d.slice(0,o);return d}updateMediaSubscribedMaps(s,t){const{page:e}=t!=null?t:{};s&&n(this,Xt).mode!==s&&(n(this,Xt).mode=s),e&&n(this,Xt).page!==e&&(n(this,Xt).page=e);const{mode:r,page:i}=n(this,Xt);switch(r){case"PAGINATED":{if(!i)return;const a=this.selectPagePeers(i),o=this.selectActivePeers(this.participants.maxActiveParticipantsCount+4);this.updateParticipantsMap(this.participants.videoSubscribed,a),this.updateParticipantsMap(this.participants.audioSubscribed,o),this.logger.debug("ParticipantController::updateActive::updating_current_page_peers",{peerIds:a});break}case"ACTIVE_GRID":{const a=this.selectActivePeers(this.participants.maxActiveParticipantsCount),o=this.selectActivePeers(this.participants.maxActiveParticipantsCount+4);this.updateParticipantsMapMinReplacement(this.participants.videoSubscribed,a),this.updateParticipantsMap(this.participants.audioSubscribed,o);break}case"MANUAL":break;default:throw new Error(`View mode ${s} not supported`)}}scheduleSyncConsumers(t){return u(this,arguments,function*({source:s}){var r,i,a;const e=((r=n(this,Xt))==null?void 0:r.mode)==="PAGINATED"&&!n(this,gs)?200:0;this.logger.info(`scheduleSyncConsumers():: Source: ${s}, ViewMode: ${(i=n(this,Xt))==null?void 0:i.mode}, ConsumersSyncing: ${n(this,gs)}, Delay: ${e}, Page: ${(a=n(this,Xt))==null?void 0:a.page}`),setTimeout(()=>this.syncConsumers(),e)})}syncConsumers(){return u(this,null,function*(){var o,c,d,l,p;if(((d=(c=(o=this.context.getValue("connectionHandler"))==null?void 0:o.mediaState)==null?void 0:c.recv)==null?void 0:d.state)!=="connected"){this.logger.info("syncConsumers: Connection not ready, exiting.");return}if(n(this,gs)){f(this,sa,!0),this.logger.info("syncConsumers: Sync in progress, marking resyncRequired=true and exiting.");return}this.logger.info("syncConsumers: Starting sync operation."),f(this,gs,!0),f(this,sa,!1);let s=[];this.participants.videoSubscribed.forEach(g=>{var E,_;const T=this.participants.joined.get(g.id),v=(_=(E=g.producers)==null?void 0:E.filter(C=>C.kind==="video"))!=null?_:[];T&&(v!=null&&v.length)&&v.forEach(C=>{var F,N,B,j;const R=((N=(F=T.manualProducerConfig)==null?void 0:F.video)!=null?N:!0)&&C.kind==="video"&&!C.screenShare,L=((j=(B=T.manualProducerConfig)==null?void 0:B.screenshareVideo)!=null?j:!0)&&C.kind==="video"&&C.screenShare;(R||L)&&(C.pause||s.push(C))})}),this.participants.audioSubscribed.forEach(g=>{var E,_;const T=this.participants.joined.get(g.id),v=(_=(E=g.producers)==null?void 0:E.filter(C=>C.kind==="audio"))!=null?_:[];T&&(v!=null&&v.length)&&v.forEach(C=>{var F,N,B,j;const R=((N=(F=T.manualProducerConfig)==null?void 0:F.audio)!=null?N:!0)&&C.kind==="audio"&&!C.screenShare,L=((j=(B=T.manualProducerConfig)==null?void 0:B.screenshareAudio)!=null?j:!0)&&C.kind==="audio"&&C.screenShare;(R||L)&&s.push(C)})}),s=ZC(s,g=>g.producerId);const t=new Map;s.forEach(g=>{t.set(g.producerId,g)});const e=(l=this.roomNodeClient)==null?void 0:l.getConsumers(),r=s.filter(g=>!(e!=null&&e.has(g.producerId))),i=[];let a=Array.from((p=e==null?void 0:e.values())!=null?p:[]).map(g=>g.peerId);a=XC(a),a==null||a.forEach(g=>{var v;const T=this.participants.joined.get(g);if(!T){this.logger.warn(`Peer with ${g} doesn't exist in joined list but producers of it are being consumed.`);return}(v=T.producers)!=null&&v.length&&T.producers.forEach(E=>{const _=E.consumer&&e.has(E.consumer.id);!t.has(E.producerId)&&(e.has(E.producerId)||_)&&i.push(E)})}),this.logger.info(`syncConsumers: Computed changes - AddProducers: ${r.length} [${r.map(g=>g.producerId).join(", ")}], RemoveProducers: ${i.length} [${i.map(g=>g.producerId).join(", ")}]`.substring(0,5e3));try{r.length>0||i.length>0?(this.logger.info(`syncConsumers: Calling updateConsumers with changes. Adding ${r.length} and removing ${i.length}.`),yield this.updateConsumers(r,i),this.logger.info("syncConsumers: updateConsumers completed successfully.")):this.logger.info("syncConsumers: No changes needed, skipping updateConsumers.")}catch(g){this.logger.error("syncConsumers: updateConsumers failed with error.",{error:g})}finally{this.logger.info("syncConsumers: Setting consumersSyncing=false and completing sync."),f(this,gs,!1)}n(this,sa)&&(this.logger.info("syncConsumers: Resync required, calling syncConsumers again."),this.syncConsumers())})}computeActivateParticipants(s,t){const e=s.map((i,a)=>({peerId:i,priority:a+1})),r=t==null?void 0:t.map((i,a)=>({peerId:i,priority:-(a+1)}));e.push(...r!=null?r:[]),e.length>0&&this.updateActiveParticipantsWithPriorities(e)}createParticipantObjFromSocketPeer(s){const t=jf.formatSocketPeerMessage(s);return new Tr(this.context,G(D({},t),{isHost:!1,videoEnabled:!1,audioMuted:!0,videoTrack:void 0,audioTrack:void 0}),this.self,this.roomSocketHandler)}updatePipSource(s,t){var e,r;t?(e=this.pip)==null||e.enableSource(s):(r=this.pip)==null||r.disableSource(s)}onParticipantMediaJoined(s,t,e){if(!this.mediaJoined||s===this.self.id)return;const r=this.participants.joined.get(s);if(!r){this.logger.warn(`Received media.peerJoinedBroadcast for non-existent peer ${s}`);return}this.logger.info("PEER_INFO:::SOCKET_ON_MEDIA_JOIN",{participant:{id:r.id,maskedName:[...(r==null?void 0:r.name)||""].map((i,a)=>a%2?"*":i).join("")}}),this.logger.info(`onParticipantMediaJoined: peer ${s} has joined media room. Processing.`),t.forEach(i=>{i.kind===xs.AUDIO&&!i.screenShare?r.setAudioEnabled(!i.pause):i.kind===xs.VIDEO&&!i.screenShare&&(r.setVideoEnabled(!i.pause),this.updatePipSource(r.id,!i.pause)),r.producers.push(G(D({},i),{producingTransportId:i.producingTransportId,kind:i.kind===xs.AUDIO?"audio":"video",producingPeerId:s,mimeType:i.mimeType}))}),this.roomNodeClient.handlePeerCapabilities(s,e),this.context.getValue("flagsmith").hasFeature(Z.FORCE_VIDEO_CODEC)||this.roomNodeClient.shareWebcam(this.self.videoTrack),this.logger.info(`onParticipantMediaJoined: Emitting UPDATE_ACTIVE for peer ${s}`),this.context.getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:this.participants.viewMode,page:this.participants.currentPage})}updateParticipantsMapMinReplacement(s,t){const e=Array.from(s.keys()),r=new Map(s),i=new Set(t),a=[];e.forEach((o,c)=>{(!i.has(o)||!this.participants.joined.get(o))&&a.push(c)}),t.forEach(o=>{if(s.get(o))return;if(e.length<t.length){e.push(o);return}const c=a.shift();e[c]=o}),a.forEach(o=>{e.splice(o,1)}),Array.from(s.keys()).forEach(o=>{s.delete(o,!i.has(o))}),e.forEach(o=>{if(!this.participants.joined.get(o)){this.logger.warn("updateActiveParticipants::participant_not_in_joined_list",{participant:{id:o}});return}s.add(this.participants.joined.get(o),!r.get(o))}),s.emit("participantsUpdate")}updateParticipantsMap(s,t){Array.from(s.keys()).forEach(r=>{t.includes(r)||s.delete(r,!0)}),t.forEach(r=>{s.get(r)||s.add(this.participants.joined.get(r),!0)}),s.emit("participantsUpdate")}updatePinnedParticipants(){this.participants.pinned.forEach(s=>{s.setIsPinned(!1),this.participants.pinned.delete(s.id)})}setupEventsGlobal(){this.roomSocketHandler.on(U.joinRoom,({peer:s})=>{if(!s.waitlisted){const t=this.context.getValue("flagsmith").hasFeature(Z.DEBUG_SOCKET_JOIN);t&&this.logger.info("Processing socket join",{peers:s.peerId}),this.onParticipantSocketJoined(this.createParticipantObjFromSocketPeer(s)),t&&this.logger.info("Processed socket join",{peers:s.peerId})}}),this.roomSocketHandler.on(U.leaveRoom,s=>{const{peerId:t}=s.peer;this.selectedPeers.delete(t,this.context),this.onParticipantLeave(t)}),this.context.getValue("peerSessionStore").on(b.SOCKET_SERVICE_ROOM_JOINED,()=>{this.self.permissions.acceptWaitingRequests&&this.roomSocketHandler.getWaitingRoomRequests()}),this.self.permissions.on("permissionsUpdate",s=>{const{acceptWaitingRequests:t}=s;t!==void 0&&(t?this.roomSocketHandler.getWaitingRoomRequests():this.participants.waitlisted.clear())}),this.context.getValue("peerSessionStore").on(b.SOCKET_SERVICE_DISCONNECTED,()=>{this.participants.joined.clear(),this.participants.videoSubscribed.clear(),this.participants.audioSubscribed.clear(),this.participants.pinned.clear(),this.participants.currentPage=0,this.participants.viewMode="ACTIVE_GRID",this.participants.emit("viewModeChanged",{viewMode:"ACTIVE_GRID",currentPage:this.participants.currentPage,pageCount:this.participants.pageCount})}),this.context.getValue("peerSessionStore").on(b.CONSUMER_PAUSED,({id:s})=>{this.processConsumerPaused(s)}),this.context.getValue("peerSessionStore").on(b.CONSUMER_RESUMED,({id:s})=>{this.processConsumerResumed(s)}),this.context.getValue("peerSessionStore").on(b.NEW_CONSUMER,({id:s})=>{this.processNewConsumer(s)}),this.context.getValue("peerSessionStore").on(b.CONSUMER_CLOSED,({id:s})=>{this.processConsumerClosed(s)}),this.context.getValue("peerSessionStore").on(b.ROOM_MESSAGE,r=>u(this,[r],function*({payload:s,type:t,timestamp:e}){this.participants.emit("broadcastedMessage",{type:t,payload:s,timestamp:e})})),this.context.getValue("peerSessionStore").on(b.MESSAGE,r=>u(this,[r],function*({payload:s,type:t,timestamp:e}){t!=="spotlight"&&this.participants.emit("broadcastedMessage",{type:t,payload:s,timestamp:e})})),this.context.getValue("peerSessionStore").on(b.LOW_CONSUMER_SCORE,({peerId:s,score:t,kind:e})=>{const r=this.participants.joined.get(s);r&&(r.emit("poorConnection",{score:t,kind:e}),this.participants.emit("poorConnection",{participantId:s,score:t,kind:e}))}),this.context.getValue("peerSessionStore").on(b.CONSUMER_SCORE_UPDATE,({score:s,kind:t,appData:e,peerId:r,scoreStats:i})=>{var c;const a=t==="video"&&((c=e==null?void 0:e.screenShare)!=null?c:!1),o=this.participants.joined.get(r);o&&(o.emit("mediaScoreUpdate",{kind:t,isScreenshare:a,score:s,participantId:r,scoreStats:i}),this.participants.emit("mediaScoreUpdate",{kind:t,isScreenshare:a,score:s,participantId:r,scoreStats:i}))}),this.context.getValue("peerSessionStore").onAsync(b.KICK_PEER,t=>u(this,[t],function*({peerId:s}){const e=this.participants.joined.get(s);this.roomNodeClient.kick(s),yield this.roomSocketHandler.kick(s),e?e.emit("kicked"):this.participants.joined.emit("kicked",{id:s})})),this.context.getValue("peerSessionStore").on(b.UPDATE_ACTIVE,(...r)=>u(this,[...r],function*({viewMode:s,page:t,createAllConsumers:e}={viewMode:"ACTIVE_GRID",page:0,createAllConsumers:!1}){this.logger.info(`UPDATE_ACTIVE event received - viewMode: ${n(this,Xt).mode}, page: ${t}, CreateAllConsumers: ${e}`),e&&(this.logger.info(`UPDATE_ACTIVE viewMode: ${s}, Page: ${t}, Removing existing subscriptions.`),this.participants.videoSubscribed.clear(),this.participants.audioSubscribed.clear()),this.updateMediaSubscribedMaps(s,{page:t}),this.scheduleSyncConsumers({source:"UPDATE_ACTIVE"})}))}onParticipantPinned(s){return u(this,null,function*(){if(!s){this.self.isPinned&&this.self.setIsPinned(!1),this.participants.pinned.size!==0&&this.updatePinnedParticipants();return}if(s===this.self.id){this.participants.pinned.size!==0&&this.updatePinnedParticipants(),this.self.setIsPinned(!0);return}const t=this.participants.joined.get(s);this.self.isPinned&&this.self.setIsPinned(!1),this.updatePinnedParticipants(),t.setIsPinned(!0),this.participants.pinned.add(t)})}onParticipantSocketJoined(s){return u(this,null,function*(){var t,e,r;this.logger.info(`onParticipantSocketJoined: peer ${s.id} has joined socket edge. Processing.`),this.self.id!==s.id&&!((t=s.flags)!=null&&t.recorder)&&!((e=s.flags)!=null&&e.hidden_participant)&&!((r=s.flags)!=null&&r.hiddenParticipant)&&(this.participants.videoSubscribed.delete(s.id),this.participants.audioSubscribed.delete(s.id),this.participants.joined.add(s),this.participants.waitlisted.delete(s.id),s.stageStatus==="REQUESTED_TO_JOIN_STAGE"&&this.context.getValue("peerSessionStore").emit(b.UPDATE_STAGE_REQUESTS,{request:{displayName:s.name,userId:s.userId,peerId:s.id},add:!0})),this.context.getValue("peerSessionStore").emit(b.PEER_JOINED_INTERNAL,s)})}onParticipantLeave(s){return u(this,null,function*(){const t=this.participants.joined.get(s);this.participants.joined.delete(s,!0,!0),this.participants.pinned.delete(s,!0,!0),this.participants.waitlisted.delete(s,!0,!0),this.roomNodeClient&&(this.roomNodeClient.handlePeerLeaving(s),this.roomNodeClient.closeConsumers(t==null?void 0:t.producers)),t&&t.stageStatus==="REQUESTED_TO_JOIN_STAGE"&&this.context.getValue("peerSessionStore").emit(b.UPDATE_STAGE_REQUESTS,{request:{displayName:t.name,userId:t.userId,peerId:t.id},add:!1});const{currentPage:e}=this.participants,r=this.maxPreferredStreams*(e-1),i=this.participants.videoSubscribed.get(s);this.participants.viewMode==="MANUAL"?this.context.getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:this.participants.viewMode,page:e}):r===0?this.participants.setViewMode("ACTIVE_GRID"):this.participants.joined.size<=r?e===2?this.participants.setViewMode("ACTIVE_GRID"):this.participants.setPage(e-1):i&&this.context.getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:this.participants.viewMode,page:e})})}processMedia(s){var g;const t=this.roomNodeClient.getConsumers(),{peerId:e,kind:r,appData:i,track:a,producerId:o,rtpReceiver:c,paused:d,localId:l}=(g=t.get(s))!=null?g:{};if(!e)return this.logger.warn("processMedia::Peer ID is undefined",{consumer:{id:s,kind:r,peerId:e,appData:{supportsRemoteControl:!!(i!=null&&i.supportsRemoteControl),screenShare:!!(i!=null&&i.screenShare)},remotelyPaused:d,producerId:o}}),{};const p=i;return r==="video"&&p.screenShare!==!0&&this.videoPeerConsumerMap.set(e,s),this.logger.info("ParticipantController::processMedia",{consumer:{id:s,peerId:e,kind:r,appData:p,remotelyPaused:d,producerId:o}}),this.consumerPeerMap.set(s,{type:r,peerId:e,appData:p,remotelyPaused:d,producerId:o}),{peerId:e,kind:r,appData:p,remotelyPaused:d,track:a,producerId:o,rtpReceiver:c,localId:l}}processConsumerClosed(s){const{peerId:t,type:e,appData:r,remotelyPaused:i,producerId:a}=this.consumerPeerMap.get(s)||{},o=this.participants.joined.get(t);if(this.logger.info("ParticipantController::processConsumerClosed",{consumer:{id:s,peerId:t,appData:r,kind:e,remotelyPaused:i,producerId:a}}),this.consumerPeerMap.delete(s),e==="video"&&r.screenShare!==!0&&this.videoPeerConsumerMap.delete(t),!o)return;const c=o.producers.find(l=>l.producerId===a);c&&(c.consumer={id:s,peerId:t,kind:void 0,appData:r,paused:i,producerId:a,rtpReceiver:void 0,localId:void 0});const d=[];r&&r.screenShare?(o.setScreenShareEnabled(!1),this.context.getValue("callstats").consumerSharedMediaState(s,{screen:!1}),o.screenShareTracks.video&&d.push(o.screenShareTracks.video.id),o.screenShareTracks.audio&&d.push(o.screenShareTracks.audio.id),o.screenShareTracks={audio:void 0,video:void 0}):e==="audio"?(o.setAudioEnabled(!1),o.audioTrack&&d.push(o.audioTrack.id),this.context.getValue("callstats").consumerSharedMediaState(s,{audio:!1}),o.audioTrack=void 0):e==="video"&&(o.setVideoEnabled(!1),this.updatePipSource(o.id,!1),o.videoTrack&&d.push(o.videoTrack.id),this.context.getValue("callstats").consumerSharedMediaState(s,{video:!1}),o.videoTrack=void 0),r.e2ee&&d.forEach(l=>{this.context.getValue("peerSessionStore").emit(b.E2EE_INACTIVE_CONSUMER,{peerId:t,trackId:l})})}processConsumerResumed(s){var T;const t=this.processMedia(s),{peerId:e,kind:r,appData:i,track:a,remotelyPaused:o,producerId:c,rtpReceiver:d,localId:l}=t;if(!e)return;this.logger.info("ParticipantController::processConsumerResumed",{consumer:{id:s,peerId:e,kind:r,appData:i,remotelyPaused:o,producerId:c}});const p=this.participants.joined.get(e);if(!p)return;const g=p.producers.find(v=>v.producerId===c);if(g&&(g.consumer={id:s,peerId:e,kind:r,appData:i,paused:o,producerId:c,rtpReceiver:d,localId:l}),i.e2ee&&this.context.getValue("peerSessionStore").emit(b.E2EE_ACTIVE_CONSUMER,{peerId:e,rtpReceiver:d,track:a}),i.screenShare){r==="video"?p.screenShareTracks.video=a:r==="audio"&&(p.screenShareTracks.audio=a),p.setScreenShareEnabled(!0),(T=this.context)==null||T.getValue("callstats").consumerSharedMediaState(s,{screen:!0});return}r==="video"?(p.videoTrack=a,p.setVideoEnabled(!0),this.updatePipSource(p.id,!0),this.context.getValue("callstats").consumerSharedMediaState(s,{video:!0})):r==="audio"&&(p.audioTrack=a,p.setAudioEnabled(p.audioEnabled),this.context.getValue("callstats").consumerSharedMediaState(s,{audio:p.audioEnabled}))}processConsumerPaused(s){this.logger.info(`ParticipantController::processConsumerPaused called for consumerId: ${s}`);const{peerId:t,kind:e,track:r,appData:i,remotelyPaused:a,producerId:o,rtpReceiver:c,localId:d}=this.processMedia(s);if(!t)return;this.logger.info("ParticipantController::processConsumerPaused",{consumer:{id:s,peerId:t,kind:e,appData:i,remotelyPaused:a,producerId:o}});const l=this.participants.joined.get(t);if(!l)return;const p=l.producers.find(g=>g.producerId===o);p&&(p.consumer={id:s,peerId:t,kind:e,appData:i,paused:a,producerId:o,rtpReceiver:c,localId:d}),r&&i.e2ee&&this.context.getValue("peerSessionStore").emit(b.E2EE_INACTIVE_CONSUMER,{peerId:t,trackId:r.id}),e==="video"?(l.videoTrack=r,l.setVideoEnabled(!1),this.updatePipSource(l.id,!1),this.context.getValue("callstats").consumerSharedMediaState(s,{video:!1})):e==="audio"&&(l.audioTrack=r,l.setAudioEnabled(l.audioEnabled),this.context.getValue("callstats").consumerSharedMediaState(s,{audio:l.audioEnabled}))}processNewConsumer(s){const{peerId:t,kind:e,remotelyPaused:r,track:i,appData:a,producerId:o,rtpReceiver:c,localId:d}=this.processMedia(s);if(!t)return;this.logger.info("ParticipantController::processNewConsumer",{consumer:{id:s,peerId:t,kind:e,remotelyPaused:r,appData:a,producerId:o}});const l=this.participants.joined.get(t);if(!l)return;const p=l.producers.find(g=>g.producerId===o);if(p&&(p.consumer={id:s,peerId:t,kind:e,appData:a,paused:r,producerId:o,rtpReceiver:c,localId:d}),a.screenShare){e==="video"?l.screenShareTracks.video=i:e==="audio"&&(l.screenShareTracks.audio=i),(!r||this.self.permissions.isRecorder||this.context.getValue("flagsmith").hasFeature(Z.SCREEENSHARE_ERR_HACK))&&l.setScreenShareEnabled(!0),a.supportsRemoteControl&&(l.supportsRemoteControl=!0),this.participants.broadcastMessage("screenshareConsumerCreated",{producerId:o,peerId:t,screenShare:!0,consumerId:s,consumerPeerId:this.self.id}),this.logger.info("ParticipantController::newScreenshareConsumer::screenshareConsumerCreated",{consumer:{id:s,peerId:t,kind:e,remotelyPaused:r,appData:a,producerId:o}});return}e==="video"?(l.videoTrack=i,r||(l.setVideoEnabled(!0),this.updatePipSource(l.id,!0)),this.context.getValue("callstats").consumerSharedMediaState(s,{video:!r})):e==="audio"&&(l.audioTrack=i,r||l.setAudioEnabled(!0),this.context.getValue("callstats").consumerSharedMediaState(s,{audio:!r})),!r&&a.e2ee&&this.context.getValue("peerSessionStore").emit(b.E2EE_ACTIVE_CONSUMER,{peerId:t,rtpReceiver:c,track:i})}static formatSocketPeerMessage(s){var e,r,i,a,o,c;if(!s)return;const t=wh(s.stageType);return{id:s.peerId,userId:s.userId,name:s.displayName,displayName:s.displayName,stageType:t,customParticipantId:s.customParticipantId,presetId:s.presetId,picture:s.displayPictureUrl,waitlisted:s.waitlisted,stageStatus:t,metadata:{preset_name:(e=s.flags)==null?void 0:e.presetName},recorderType:(r=s.flags)==null?void 0:r.recorderType,flags:{hiddenParticipant:(i=s.flags)==null?void 0:i.hiddenParticipant,hidden_participant:(a=s.flags)==null?void 0:a.hiddenParticipant,recorder:((o=s.flags)==null?void 0:o.recorderType)!==void 0&&((c=s.flags)==null?void 0:c.recorderType)!=="NONE"}}}onSelectedPeers(s,t){return u(this,null,function*(){this.participants.viewMode==="ACTIVE_GRID"&&this.computeActivateParticipants(s,t)})}updateActiveParticipantsWithPriorities(s,t=!1){if(this.participants.viewMode==="MANUAL")return;if(!this.mediaJoined){this.logger.warn("Skipped::ParticipantController::updateActiveParticipantsWithPriorities",{roomJoined:this.mediaJoined});return}s.forEach(r=>{this.selectedPeers.add(r.peerId,r.priority,this.context)});const e=this.selectedPeers.activeSpeakerPeers.at(0);e!==void 0&&e!==this.participants.lastActiveSpeaker&&(this.participants.lastActiveSpeaker=e,this.participants.emit("activeSpeaker",{peerId:e,volume:1})),t&&this.context.getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{viewMode:this.participants.viewMode,page:this.participants.currentPage})}},Xt=new WeakMap,gs=new WeakMap,sa=new WeakMap,Og);let Pr=jf;dn([P.trace("ParticipantController.setupEvents")],Pr.prototype,"setupEvents",1);dn([P.trace("ParticipantController.setupEvents")],Pr.prototype,"setupEventsGlobal",1);dn([P.trace("ParticipantController.processMedia")],Pr.prototype,"processMedia",1);dn([P.trace("ParticipantController.processConsumerClosed")],Pr.prototype,"processConsumerClosed",1);dn([P.trace("ParticipantController.processConsumerResumed")],Pr.prototype,"processConsumerResumed",1);dn([P.trace("ParticipantController.processConsumerPaused")],Pr.prototype,"processConsumerPaused",1);dn([P.trace("ParticipantController.processNewConsumer")],Pr.prototype,"processNewConsumer",1);const me=_s(vh().permissions);var q,ra,ia,Fd,pt,At;const yn=class extends Bt{constructor(e,r,i,a=!1){const o=e.getValue("logger");super(o);m(this,pt);m(this,q,void 0);m(this,ra,void 0);m(this,ia,void 0);m(this,Fd,e=>{var p,g,T;const l=e,{chat:r,connectedMeetings:i,plugins:a,polls:o,media:c}=l,d=Bc(l,["chat","connectedMeetings","plugins","polls","media"]);if(r&&(r.private&&Cr(n(this,q).chat.private,r.private),r.public&&Cr(n(this,q).chat.public,r.public),this.emit("chatUpdate")),i&&Cr(n(this,q).connectedMeetings,i),c){const v=_=>{switch(_){case Kr.NONE:return H.Allowed;case Kr.ALLOWED:return H.Allowed;case Kr.NOT_ALLOWED:return H.NotAllowed;case Kr.CAN_REQUEST:return H.CanRequest;default:return}},E={audio:void 0,video:void 0,screenshare:void 0};(p=c.audio)!=null&&p.canProduce&&(E.audio={canProduce:v(c.audio.canProduce)}),(g=c.video)!=null&&g.canProduce&&(E.video={canProduce:v(c.video.canProduce)}),(T=c.screenshare)!=null&&T.canProduce&&(E.screenshare={canProduce:v(c.screenshare.canProduce)}),Cr(n(this,q).media,E)}a&&(Cr(n(this,q).plugins,a),this.emit("pluginsUpdate")),o&&(Cr(n(this,q).polls,o),this.emit("pollsUpdate")),Object.keys(d).length!==0&&Cr(n(this,q),d),this.emit("permissionsUpdate",e)});if(!r)throw this.logger.error("PermissionPreset::load_preset_permissions_failed"),new A("Could not load preset permissions.","0904");f(this,ia,e),f(this,ra,i),f(this,q,r),a&&this.setupEvents()}setupEvents(){n(this,ia).getValue("peerSessionStore").on(b.UPDATE_PERMISSIONS,n(this,Fd))}static fromResponse(e,r,i){return new yn(i,e,r,!0)}static default(e,r){return new yn(e,me,r)}static init(e,r,i){let a;return i?a=new yn(e,i,r,!0):a=new yn(e,me,r),a}get mediaRoomType(){return"CF"}get stageEnabled(){var e;return((e=n(this,q))==null?void 0:e.stageEnabled)||n(this,ra)===pr.Webinar||n(this,ra)===pr.Livestream}get acceptStageRequests(){var e,r;return this.stageEnabled?((e=n(this,q))==null?void 0:e.acceptStageRequests)||((r=n(this,q))==null?void 0:r.canAcceptProductionRequests):!1}get stageAccess(){var e,r,i;return((e=n(this,q))==null?void 0:e.stageAccess)===H.NotAllowed?H.NotAllowed:((r=n(this,q))==null?void 0:r.stageAccess)===H.CanRequest?H.CanRequest:((i=n(this,q))==null?void 0:i.stageAccess)===H.Allowed||n(this,q).media.audio.canProduce===H.Allowed||n(this,q).media.video.canProduce===H.Allowed||n(this,q).media.screenshare.canProduce===H.Allowed?H.Allowed:n(this,q).media.audio.canProduce===H.CanRequest||n(this,q).media.video.canProduce===H.CanRequest||n(this,q).media.screenshare.canProduce===H.CanRequest?H.CanRequest:H.NotAllowed}get acceptWaitingRequests(){var e,r;return(r=(e=n(this,q))==null?void 0:e.acceptWaitingRequests)!=null?r:me.acceptWaitingRequests}get requestProduceVideo(){var e,r,i;return((i=(r=(e=n(this,q))==null?void 0:e.media)==null?void 0:r.video)==null?void 0:i.canProduce)===H.CanRequest}get requestProduceAudio(){var e,r,i;return((i=(r=(e=n(this,q))==null?void 0:e.media)==null?void 0:r.audio)==null?void 0:i.canProduce)===H.CanRequest}get requestProduceScreenshare(){var e,r,i;return((i=(r=(e=n(this,q))==null?void 0:e.media)==null?void 0:r.screenshare)==null?void 0:i.canProduce)===H.CanRequest}get canAllowParticipantAudio(){var e,r;return(r=(e=n(this,q))==null?void 0:e.disableParticipantAudio)!=null?r:me.disableParticipantAudio}get canAllowParticipantScreensharing(){var e,r;return(r=(e=n(this,q))==null?void 0:e.canAcceptProductionRequests)!=null?r:me.canAcceptProductionRequests}get canAllowParticipantVideo(){var e,r;return(r=(e=n(this,q))==null?void 0:e.disableParticipantVideo)!=null?r:me.disableParticipantVideo}get canDisableParticipantAudio(){return this.canAllowParticipantAudio}get canDisableParticipantVideo(){return this.canAllowParticipantVideo}get kickParticipant(){var e,r;return(r=(e=n(this,q))==null?void 0:e.kickParticipant)!=null?r:me.kickParticipant}get pinParticipant(){var e,r;return(r=(e=n(this,q))==null?void 0:e.pinParticipant)!=null?r:me.pinParticipant}get canRecord(){var e,r;return(r=(e=n(this,q))==null?void 0:e.canRecord)!=null?r:me.canRecord}get waitingRoomType(){var e,r;return(r=(e=n(this,q))==null?void 0:e.waitingRoomType)!=null?r:me.waitingRoomType}get waitingRoomBehaviour(){var e,r;return(r=(e=n(this,q))==null?void 0:e.waitingRoomType)!=null?r:me.waitingRoomType}get plugins(){var e,r;return(r=(e=n(this,q))==null?void 0:e.plugins)!=null?r:me.plugins}get polls(){var e,r;return(r=(e=n(this,q))==null?void 0:e.polls)!=null?r:me.polls}get produceVideo(){return this.canProduceVideo}get requestProduce(){return n(this,q).media.audio.canProduce===H.CanRequest||n(this,q).media.video.canProduce===H.CanRequest||n(this,q).media.screenshare.canProduce===H.CanRequest}get canProduceVideo(){var r;const e=(r=n(this,q).media.video.canProduce)!=null?r:me.media.video.canProduce;return this.stageEnabled&&(n(this,pt,At)==="ACCEPTED_TO_JOIN_STAGE"||n(this,pt,At)==="ON_STAGE")&&e===H.CanRequest?H.Allowed:this.stageEnabled&&(n(this,pt,At)==="OFF_STAGE"||n(this,pt,At)==="REQUESTED_TO_JOIN_STAGE")&&e===H.Allowed?H.NotAllowed:e}get produceScreenshare(){return this.canProduceScreenshare}get canProduceScreenshare(){var r;const e=(r=n(this,q).media.screenshare.canProduce)!=null?r:me.media.screenshare.canProduce;return this.stageEnabled&&(n(this,pt,At)==="ACCEPTED_TO_JOIN_STAGE"||n(this,pt,At)==="ON_STAGE")&&e===H.CanRequest?H.Allowed:this.stageEnabled&&(n(this,pt,At)==="OFF_STAGE"||n(this,pt,At)==="REQUESTED_TO_JOIN_STAGE")&&e===H.Allowed?H.NotAllowed:e}get produceAudio(){return this.canProduceAudio}get canProduceAudio(){var r;const e=(r=n(this,q).media.audio.canProduce)!=null?r:me.media.audio.canProduce;return this.stageEnabled&&(n(this,pt,At)==="ACCEPTED_TO_JOIN_STAGE"||n(this,pt,At)==="ON_STAGE")&&e===H.CanRequest?H.Allowed:this.stageEnabled&&(n(this,pt,At)==="OFF_STAGE"||n(this,pt,At)==="REQUESTED_TO_JOIN_STAGE")&&e===H.Allowed?H.NotAllowed:e}get chatPublic(){var e,r,i;return(i=(r=(e=n(this,q))==null?void 0:e.chat)==null?void 0:r.public)!=null?i:me.chat.public}get chatPrivate(){var e,r,i;return(i=(r=(e=n(this,q))==null?void 0:e.chat)==null?void 0:r.private)!=null?i:me.chat.private}get connectedMeetings(){var e,r;return(r=(e=n(this,q))==null?void 0:e.connectedMeetings)!=null?r:me==null?void 0:me.connectedMeetings}get hiddenParticipant(){var e,r;return(r=(e=n(this,q))==null?void 0:e.hiddenParticipant)!=null?r:me.hiddenParticipant}get showParticipantList(){var e;return(e=n(this,q).showParticipantList)!=null?e:me.showParticipantList}get canChangeParticipantRole(){var e,r;return(r=(e=n(this,q))==null?void 0:e.canChangeParticipantPermissions)!=null?r:me.canChangeParticipantPermissions}get canChangeParticipantPermissions(){var e,r;return(r=(e=n(this,q))==null?void 0:e.canChangeParticipantPermissions)!=null?r:me.canChangeParticipantPermissions}get canChangeTheme(){return!1}get canPresent(){return n(this,q).media.audio.canProduce===H.Allowed||n(this,q).media.video.canProduce===H.Allowed||n(this,q).media.screenshare.canProduce===H.Allowed}get acceptPresentRequests(){return this.acceptStageRequests}get canEditDisplayName(){var e;return(e=n(this,q).canEditDisplayName)!=null?e:!1}get maxScreenShareCount(){return 1}get isRecorder(){return n(this,q).isRecorder}get canSpotlight(){return n(this,q).canSpotlight}get canLivestream(){return n(this,q).canLivestream}get transcriptionEnabled(){return n(this,q).transcriptionEnabled}};let Uu=yn;q=new WeakMap,ra=new WeakMap,ia=new WeakMap,Fd=new WeakMap,pt=new WeakSet,At=function(){return n(this,ia).getValue("stageStatus")};var Vt;class Gf extends Bt{constructor(e,r){super(r);h(this,"localMediaHandler");m(this,Vt,void 0);f(this,Vt,e)}updatePermission(){return u(this,null,function*(){var d,l;const e=(p,g)=>{this.mediaPermissions[p]=g;const T={message:this.mediaPermissions[p],kind:p};g==="DENIED"?n(this,Vt).getValue("peerSessionStore").emit(b.MEDIA_PERMISSION_ERROR,T):n(this,Vt).getValue("peerSessionStore").emit(b.MEDIA_PERMISSION_UPDATE,T)};if(Se.getName()==="firefox")return;const r="microphone",i="camera",a=yield(d=navigator==null?void 0:navigator.permissions)==null?void 0:d.query({name:r}),o=yield(l=navigator==null?void 0:navigator.permissions)==null?void 0:l.query({name:i}),c=(p,g)=>{switch(g){case"granted":e(p,"ACCEPTED");break;case"denied":e(p,"DENIED");break;case"prompt":e(p,"NOT_REQUESTED");break}this.localMediaHandler.repopulateAvailableDevices()};a&&(a.onchange=()=>c("audio",a.state)),o&&(o.onchange=()=>c("video",o.state))})}populateMediaPermissionsInCallstats(i){return u(this,arguments,function*({message:e,kind:r}){var a,o,c,d;switch(r){case"audio":{(a=n(this,Vt))==null||a.getValue("callstats").mediaPermission("AUDIO",e),(o=n(this,Vt))==null||o.getValue("callstats").mediaPermission("SPEAKER",e);break}case"video":{(c=n(this,Vt))==null||c.getValue("callstats").mediaPermission("VIDEO",e);break}case"screenshare":{(d=n(this,Vt))==null||d.getValue("callstats").mediaPermission("SCREENSHARE",e);break}}})}get peerId(){var e;return(e=n(this,Vt))==null?void 0:e.getValue("peerId")}init(){return u(this,arguments,function*(e={},r=!1,i=null){var a,o,c,d,l,p,g;if(Se.init(),i&&f(this,Vt,i),!this.localMediaHandler)try{let T=!0;if((a=i==null?void 0:i.getValue("defaults"))!=null&&a.mediaHandler)T=!1,this.localMediaHandler=i.getValue("defaults").mediaHandler.localMediaHandler;else if(navigator.RNLocalMediaHandlerImpl){const{RNLocalMediaHandlerImpl:v}=navigator;this.localMediaHandler=yield v.init(e)}else this.localMediaHandler=new bt(i,e.constraints,(o=i==null?void 0:i.getValue("defaults"))==null?void 0:o.isNonPreferredDevice,(c=i==null?void 0:i.getValue("defaults"))==null?void 0:c.autoSwitchAudioDevice);if(i==null||i.getValue("peerSessionStore").on(b.MEDIA_PERMISSION_UPDATE,v=>u(this,null,function*(){if(this.populateMediaPermissionsInCallstats({message:v.message,kind:v.kind}),v.message==="NOT_REQUESTED")switch(v==null?void 0:v.kind){case"audio":this.rawAudioTrack&&(this.logger.info("Disabling audio due to media permission update"),this.disableAudio());break;case"video":this.rawVideoTrack&&(this.logger.info("Disabling video due to media permission update"),this.disableVideo());break;default:break}this.emit("mediaPermissionUpdate",v)})),i==null||i.getValue("peerSessionStore").on(b.MEDIA_PERMISSION_ERROR,v=>u(this,null,function*(){const{kind:E,message:_,constraints:C}=v;this.populateMediaPermissionsInCallstats({message:_,kind:E}),E==="audio"?(this.logger.info(`Disabling audio due to media permission error skipping: ${this.localMediaHandler.audioUpdateInProgress}`),this.localMediaHandler.audioUpdateInProgress===!1&&this.disableAudio()):E==="video"&&(this.logger.info(`Disabling video due to media permission error skipping: ${this.localMediaHandler.videoUpdateInProgress}`),this.localMediaHandler.videoUpdateInProgress===!1&&this.disableVideo()),this.logger.error("SelfController::mediaPermissionError",{error:{message:_},constraints:C,mediaPermissionsErrors:{kind:E,message:_}}),this.emit("mediaPermissionError",v),this.emit("mediaPermissionUpdate",{message:_,kind:E})})),T){this.logger.info(`Setting up SelfMedia streams using media handler. audio:${(d=e==null?void 0:e.audio)!=null?d:!0} video:${(l=e==null?void 0:e.video)!=null?l:!0}`);const v=this.localMediaHandler.setupStreams({video:(p=e==null?void 0:e.video)!=null?p:!0,audio:(g=e==null?void 0:e.audio)!=null?g:!0});r||(yield v)}}catch(T){this.logger.error("Self::init::Failed To Setup Streams",{error:{name:T.name,message:T.message}})}})}set context(e){f(this,Vt,e),this.localMediaHandler.context=e}get audioTrack(){return this.localMediaHandler.audioTrack}get rawAudioTrack(){return this.localMediaHandler.rawAudioTrack}get mediaPermissions(){return this.localMediaHandler.permissions}addAudioMiddleware(e){return u(this,null,function*(){return this.localMediaHandler.addAudioMiddleware(e)})}removeAudioMiddleware(e){return u(this,null,function*(){return this.localMediaHandler.removeAudioMiddleware(e)})}removeAllAudioMiddlewares(){return u(this,null,function*(){return this.localMediaHandler.removeAllAudioMiddlewares()})}get videoTrack(){return this.localMediaHandler.videoTrack}get rawVideoTrack(){return this.localMediaHandler.rawVideoTrack}addVideoMiddleware(e){return u(this,null,function*(){return this.localMediaHandler.addVideoMiddleware(e)})}setVideoMiddlewareGlobalConfig(){return u(this,arguments,function*(e={disablePerFrameCanvasRendering:!1}){return this.localMediaHandler.setVideoMiddlewareGlobalConfig(e)})}removeVideoMiddleware(e){return u(this,null,function*(){return this.localMediaHandler.removeVideoMiddleware(e)})}removeAllVideoMiddlewares(){return u(this,null,function*(){return this.localMediaHandler.removeAllVideoMiddlewares()})}get screenShareTracks(){return this.localMediaHandler.screenShareTracks}get audioEnabled(){return this.localMediaHandler.audioEnabled}get videoEnabled(){return this.localMediaHandler.videoEnabled}get screenShareEnabled(){return this.localMediaHandler.screenShareEnabled}enableAudio(){return u(this,null,function*(){yield this.localMediaHandler.enableAudio(),this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack})})}enableVideo(){return u(this,null,function*(){yield this.localMediaHandler.enableVideo(),this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack})})}disableAudio(){return u(this,null,function*(){this.localMediaHandler.disableAudio(),this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack})})}enableScreenShare(){return u(this,null,function*(){yield this.localMediaHandler.enableScreenShare(),this.emit("screenShareUpdate",{screenShareEnabled:this.screenShareEnabled,screenShareTracks:this.screenShareTracks})})}disableScreenShare(){return u(this,null,function*(){yield this.localMediaHandler.disableScreenShare(),this.emit("screenShareUpdate",{screenShareEnabled:this.screenShareEnabled,screenShareTracks:this.screenShareTracks})})}disableVideo(){return u(this,null,function*(){yield this.localMediaHandler.disableVideo(),this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack})})}getCurrentDevices(){return this.localMediaHandler.getCurrentDevices()}getAudioDevices(){return u(this,null,function*(){return yield this.localMediaHandler.getAudioDevices()})}getVideoDevices(){return u(this,null,function*(){return yield this.localMediaHandler.getVideoDevices()})}getSpeakerDevices(){return u(this,null,function*(){return yield this.localMediaHandler.getSpeakerDevices()})}getDeviceById(e,r){let i;return r==="audio"?i="audioinput":r==="video"?i="videoinput":r==="speaker"&&(i="audiooutput"),this.localMediaHandler.getDeviceById(e,i)}setDevice(e){return u(this,null,function*(){switch(e.kind){case"audioinput":try{yield this.localMediaHandler.setAudioDevice(e,{saveDevicePreference:!0})}catch(r){}finally{this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack})}break;case"audiooutput":yield this.localMediaHandler.setSpeakerDevice(e,{saveDevicePreference:!0});break;case"videoinput":try{yield this.localMediaHandler.setVideoDevice(e,{saveDevicePreference:!0})}catch(r){}finally{this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack})}break}this.emit("deviceUpdate",{device:e})})}}Vt=new WeakMap;var SD=Object.defineProperty,yD=Object.getOwnPropertyDescriptor,St=(s,t,e,r)=>{for(var i=r>1?void 0:r?yD(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&SD(t,e,i),i},na,gt,aa,Ue,Xs,ni,He,Ye,oa,cd,Ve,Fe,ca,da,Go,$u,Ng;let ze=(Ng=class extends Gf{constructor(t,e,r,i,a){var c;const o=t.getValue("logger");super(t,o);m(this,Xs);m(this,He);m(this,oa);m(this,Ve);m(this,Go);h(this,"name");h(this,"picture");h(this,"customParticipantId");h(this,"waitlistStatus");m(this,na,void 0);m(this,gt,void 0);m(this,aa,void 0);h(this,"role");h(this,"userId");h(this,"organizationId");h(this,"supportsRemoteControl",!1);h(this,"device");m(this,Ue,void 0);h(this,"hidden",!1);h(this,"presetName");h(this,"roomState","init");m(this,ca,new Set);m(this,da,new Set);f(this,Ue,t),this.userId=e.id,this.name=e.name,this.picture=e.picture,this.customParticipantId=(c=e.customParticipantId)!=null?c:e.clientSpecificId,this.waitlistStatus="none",f(this,gt,r),f(this,na,i),this.hidden=!1,f(this,aa,!1),this.organizationId=e.organizationId,this.supportsRemoteControl=Se.isElectron(),this.device=Se.getDeviceInfo(),this.presetName=a,this.updatePermission(),this.updateVideo=this.updateVideo.bind(this),x(this,Go,$u).call(this)}get telemetry(){return n(this,Ue).getValue("telemetry")}get stageStatus(){return n(this,Ue).getValue("stageStatus")}get producers(){var t,e;return Array.from((e=(t=n(this,He,Ye).getProducers())==null?void 0:t.values())!=null?e:[])}get id(){return this.peerId}get peerId(){return n(this,Ue).getValue("peerId")}static __init__(t,e,r,i,a,o=!1){return u(this,null,function*(){var T,v,E,_,C,R;let c=(v=(T=t.getValue("defaults"))==null?void 0:T.audio)!=null?v:!0,d=(_=(E=t.getValue("defaults"))==null?void 0:E.video)!=null?_:!0;r.canProduceAudio!=="ALLOWED"&&(c=!1),r.canProduceVideo!=="ALLOWED"&&(d=!1);const l=new ze(t,e,r,i,a),p=I0(i.mediaConstraints);Cr(p,(C=t.getValue("defaults"))==null?void 0:C.mediaConfiguration);const g=(R=t.getValue("defaults"))==null?void 0:R.mediaHandler;return g&&(g.context=t),yield l.init({audio:c,video:d,constraints:p},o,t),l.setupEvents(),l})}cleanupEvents(){this.removeAllListeners("videoUpdate"),this.localMediaHandler.removeAllListeners("AUDIO_TRACK_CHANGE"),this.localMediaHandler.removeAllListeners("VIDEO_TRACK_CHANGE"),this.localMediaHandler.removeAllListeners("DEVICE_CHANGE"),this.localMediaHandler.removeAllListeners("DEVICE_LIST_UPDATED"),this.localMediaHandler.removeAllListeners("SCREENSHARE_TRACK_CHANGE"),this.localMediaHandler.removeAllListeners("SCREENSHARE_ENDED"),this.localMediaHandler.removeAllListeners("AUDIO_TRACK_SILENT"),this.localMediaHandler.removeAllListeners("FORCE_MUTE_AUDIO"),this.localMediaHandler.removeAllListeners("FORCE_MUTE_VIDEO"),n(this,gt).removeAllListeners("permissionsUpdate")}setupEvents(){this.on("videoUpdate",x(this,Go,$u));const t=n(this,oa,cd);t&&t.onError(e=>{this.emit("autoplayError",e)}),this.localMediaHandler.on("AUDIO_TRACK_CHANGE",()=>u(this,null,function*(){if(this.logger.info("Self::setupEvents::AUDIO_TRACK_CHANGE",D({},di(this))),n(this,Ve,Fe)&&this.audioEnabled)try{yield n(this,He,Ye).shareMic(this.audioTrack)}catch(e){this.logger.error("Self::setupEvents::Error while sharing mic",{error:e}),this.localMediaHandler.disableAudio()}this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack})})),this.localMediaHandler.on("VIDEO_TRACK_CHANGE",()=>u(this,null,function*(){if(this.logger.info("Self::setupEvents::VIDEO_TRACK_CHANGE",D({},di(this))),n(this,Ve,Fe)&&this.rawVideoTrack===void 0)this.logger.info("Self::VIDEO_TRACK_CHANGE::Forcing_disable_video"),this.disableVideo();else if(this.videoEnabled&&n(this,Ve,Fe))try{const e=yield n(this,He,Ye).shareWebcam(this.videoTrack);e&&e.id!==this.videoTrack.id&&n(this,Ue).getValue("flagsmith").hasFeature(Z.EXP_RESHARE)&&(yield n(this,He,Ye).shareWebcam(this.videoTrack))}catch(e){this.logger.error("Self::setupEvents::failed shareWebcam",{error:e}),this.videoEnabled&&(yield this.localMediaHandler.disableVideo())}this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack})})),this.localMediaHandler.on("DEVICE_CHANGE",r=>u(this,[r],function*({device:e}){var i;this.emit("deviceUpdate",{device:e}),e.kind==="audiooutput"&&typeof HTMLAudioElement.prototype.setSinkId=="function"&&((i=n(this,oa,cd))==null||i.setSpeakerDevice(e.deviceId))})),this.localMediaHandler.on("DEVICE_LIST_UPDATED",e=>{this.emit("deviceListUpdate",e)}),this.localMediaHandler.on("SCREENSHARE_TRACK_CHANGE",()=>u(this,null,function*(){if(!n(this,Ve,Fe)){this.logger.error("Self.SCREENSHARE_TRACK_CHANGE.LocalMediaInitialized_WithoutRoomNode");return}if(this.screenShareEnabled)try{yield n(this,He,Ye).shareScreen(this.screenShareTracks)}catch(e){this.logger.error("Self::setupEvents::Error while sharing screen",{error:e}),this.screenShareEnabled&&(yield this.localMediaHandler.disableScreenShare())}this.logger.info("Self::setupEvents::SCREENSHARE_TRACK_CHANGE",D({},di(this))),this.emit("screenShareUpdate",{screenShareEnabled:this.screenShareEnabled,screenShareTracks:this.screenShareTracks})})),this.localMediaHandler.on("SCREENSHARE_ENDED",()=>u(this,null,function*(){this.logger.log("Disabling screenshare due to SCREENSHARE_ENDED"),yield this.disableScreenShare(),this.logger.info("Self::setupEvents::SCREENSHARE_ENDED",D({},di(this)))})),this.localMediaHandler.on("AUDIO_TRACK_SILENT",()=>{var e;(e=n(this,Ue))==null||e.getValue("callstats").mediaTrackMuted("AUDIO")}),this.localMediaHandler.on("FORCE_MUTE_AUDIO",()=>{this.disableAudio()}),this.localMediaHandler.on("FORCE_MUTE_VIDEO",()=>u(this,null,function*(){var e;n(this,Ve,Fe)&&(yield n(this,He,Ye).pauseWebcam()),this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack}),(e=n(this,Ue))==null||e.getValue("callstats").videoOff()})),n(this,gt).on("permissionsUpdate",e=>{var r,i,a;(r=e==null?void 0:e.media)!=null&&r.audio&&n(this,gt).canProduceAudio!==H.Allowed&&(this.disableAudio(),this.logger.info(`Disabled audio due to dynamic preset change: canProduceAudio: ${this.permissions.canProduceAudio}`)),(i=e==null?void 0:e.media)!=null&&i.video&&n(this,gt).canProduceVideo!==H.Allowed&&(this.disableVideo(),this.logger.info(`Disabled video due to dynamic preset change: canProduceVideo: ${this.permissions.canProduceVideo}`)),(a=e==null?void 0:e.media)!=null&&a.screenshare&&n(this,gt).canProduceScreenshare!==H.Allowed&&(this.disableScreenShare(),this.logger.info(`Disabled screenshare due to dynamic preset change: canProduceScreenshare: ${this.permissions.canProduceScreenshare}`))})}get permissions(){return n(this,gt)}get config(){return n(this,na)}get roomJoined(){var t;return n(this,na).viewType===pr.Livestream&&this.stageStatus!=="ON_STAGE"?((t=n(this,Ue).getValue("connectionHandler"))==null?void 0:t.socketJoined)===!0:n(this,Ve,Fe)}setName(t){if(!t)throw new A("Name cannot be empty.","1103");this.name=t}setupTracks(){return u(this,arguments,function*(t={}){t.forceReset,yield this.disableAudio(),yield this.disableVideo(),this.localMediaHandler.removeAudioTrack(),this.localMediaHandler.removeVideoTrack(),t.audio&&(yield this.enableAudio()),t.video&&(yield this.enableVideo())})}destructMediaHandler(){return u(this,null,function*(){return this.localMediaHandler.destruct()})}removeDocumentEventListeners(){return u(this,null,function*(){return this.localMediaHandler.removeDocumentEventListeners()})}enableAudio(t){return u(this,null,function*(){var e;if(this.permissions.canProduceAudio!==H.NotAllowed&&!(n(this,gt).canProduceAudio===H.CanRequest&&(this.stageStatus==="OFF_STAGE"||this.stageStatus==="REQUESTED_TO_JOIN_STAGE"))&&!this.audioEnabled){if((e=n(this,Ue))==null||e.getValue("callstats").audioOn(),yield this.localMediaHandler.enableAudio(t),n(this,Ve,Fe)&&this.stageStatus==="ON_STAGE"){if(this.audioTrack)try{yield n(this,He,Ye).shareMic(this.audioTrack)}catch(r){this.logger.error("Self::enableAudio::Error while sharing mic",{error:r}),this.localMediaHandler.disableAudio()}if(!this.audioEnabled)return}this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack})}})}enableVideo(t){return u(this,null,function*(){var e;if(n(this,gt).canProduceVideo!==H.NotAllowed&&!(n(this,gt).canProduceVideo===H.CanRequest&&(this.stageStatus==="OFF_STAGE"||this.stageStatus==="REQUESTED_TO_JOIN_STAGE"))&&!this.videoEnabled){if((e=n(this,Ue))==null||e.getValue("callstats").videoOn(),yield this.localMediaHandler.enableVideo(t),n(this,Ve,Fe)&&this.stageStatus==="ON_STAGE")try{yield n(this,He,Ye).shareWebcam(this.videoTrack)}catch(r){this.logger.error("Self::enableVideo::Error while sharing video",{error:r}),this.videoEnabled&&this.localMediaHandler.disableVideo()}this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack}),this.logger.info("Self.enableVideo",D({},di(this)))}})}updateVideoConstraints(t){return u(this,null,function*(){if(!this.localMediaHandler.updateVideoConstraints)throw new A("Unsupported","1102");yield this.localMediaHandler.updateVideoConstraints(t)})}enableScreenShare(){return u(this,null,function*(){if(!n(this,Ve,Fe))throw new A("Can`t enable screenshare without joining room","1105");if(n(this,gt).canProduceScreenshare!==H.NotAllowed&&!(n(this,gt).canProduceScreenshare===H.CanRequest&&(this.stageStatus==="OFF_STAGE"||this.stageStatus==="REQUESTED_TO_JOIN_STAGE"))&&!this.screenShareEnabled&&(yield this.localMediaHandler.enableScreenShare(),this.screenShareTracks.audio||this.screenShareTracks.video)){try{yield n(this,He,Ye).shareScreen(this.screenShareTracks)}catch(t){this.logger.error("Self::enableScreenShare::Error while sharing screen",{error:t}),this.screenShareEnabled&&(yield this.localMediaHandler.disableScreenShare())}this.emit("screenShareUpdate",{screenShareEnabled:this.screenShareEnabled,screenShareTracks:this.screenShareTracks})}})}updateScreenshareConstraints(t){return u(this,null,function*(){if(!this.localMediaHandler.updateScreenshareConstraints)throw new A("Unsupported","1102");yield this.localMediaHandler.updateScreenshareConstraints(t)})}disableAudio(){return u(this,null,function*(){var t;this.audioEnabled&&(this.localMediaHandler.disableAudio(),n(this,Ve,Fe)&&n(this,He,Ye).muteSelf(),this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack}),(t=n(this,Ue))==null||t.getValue("callstats").audioOff())})}disableVideo(){return u(this,null,function*(){var t;this.videoEnabled&&(yield this.localMediaHandler.disableVideo(),n(this,Ve,Fe)&&(yield n(this,He,Ye).pauseWebcam()),this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack}),(t=n(this,Ue))==null||t.getValue("callstats").videoOff())})}disableScreenShare(){return u(this,null,function*(){this.screenShareEnabled&&(yield this.localMediaHandler.disableScreenShare(),n(this,Ve,Fe)&&(yield n(this,He,Ye).disableScreenShare()),this.emit("screenShareUpdate",{screenShareEnabled:this.screenShareEnabled,screenShareTracks:this.screenShareTracks}))})}getAllDevices(){return this.localMediaHandler.getAllDevices()}setIsPinned(t,e=!0){var i;f(this,aa,t);const r=t?"pinned":"unpinned";(i=n(this,Xs,ni))==null||i.updateSource(this.id,{pinned:t}),e&&this.emit(r,this)}get isPinned(){return n(this,aa)}pin(){return u(this,null,function*(){if(!n(this,Ve,Fe))throw new A("Can`t pin participants without joining room","1105");return this.show(),n(this,He,Ye).pinPeer(this.id)})}unpin(){return u(this,null,function*(){if(!n(this,Ve,Fe))throw new A("Can`t unpin participants without joining room","1105");return n(this,He,Ye).pinPeer(null)})}hide(){return u(this,null,function*(){if(!n(this,Ve,Fe))throw new A("Can`t toggle participant tile without joining room","1105");this.hidden=!0,this.emit("toggleTile",{hidden:this.hidden})})}show(){if(!n(this,Ve,Fe))throw new A("Can`t toggle participant tile without joining room","1105");this.hidden=!1,this.emit("toggleTile",{hidden:this.hidden})}setDevice(t){return u(this,null,function*(){var r,i,a;if(!t)throw new A("No device selected","1104");const e=this.getCurrentDevices();if(t.deviceId&&(((r=e==null?void 0:e.audio)==null?void 0:r.deviceId)===t.deviceId||((i=e==null?void 0:e.video)==null?void 0:i.deviceId)===t.deviceId||((a=e==null?void 0:e.speaker)==null?void 0:a.deviceId)===t.deviceId)&&(this.logger.warn("Self.setDevice.setting_to_in_use_device",{devices:[t]}),n(this,Ue).getValue("flagsmith").hasFeature(Z.SKIP_SETTING_IN_USE_DEVICE)))throw new A("Cannot set device currently in use","1106");switch(t.kind){case"audioinput":try{yield this.localMediaHandler.setAudioDevice(t,{saveDevicePreference:!0})}catch(o){n(this,Ve,Fe)&&(yield n(this,He,Ye).muteSelf()),this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack})}break;case"audiooutput":yield this.localMediaHandler.setSpeakerDevice(t,{saveDevicePreference:!0});break;case"videoinput":try{yield this.localMediaHandler.setVideoDevice(t,{saveDevicePreference:!0})}catch(o){n(this,Ve,Fe)&&(yield n(this,He,Ye).pauseWebcam()),this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack})}break}})}cleanUpTracks(){var t,e,r,i;(t=this.audioTrack)==null||t.stop(),(e=this.rawAudioTrack)==null||e.stop(),(r=this.videoTrack)==null||r.stop(),(i=this.rawVideoTrack)==null||i.stop()}playAudio(){var t;return(t=n(this,oa,cd))==null?void 0:t.play()}registerVideoElement(t,e=!1){var r,i;t&&(e?n(this,ca).add(t):n(this,da).add(t),this.updateVideo(t),e||(i=n(this,Xs,ni))==null||i.addSource(this.id,t,this.videoEnabled,this.isPinned,this.name,this.picture,(r=this.raised)!=null?r:!1))}deregisterVideoElement(t,e=!1){if(!t){n(this,Xs,ni).removeSource(this.id);return}t.srcObject=void 0,e?n(this,ca).delete(t):(n(this,da).delete(t),n(this,Xs,ni).removeSource(this.id))}updateVideo(t,e=!1){var r,i,a;if(this.videoEnabled){if(this.videoTrack==null)return;const o=(r=t.srcObject)==null?void 0:r.getTracks()[0];if((o==null?void 0:o.id)===this.videoTrack.id)return;const c=new MediaStream;c.addTrack(this.videoTrack),t.srcObject=c,e||(i=n(this,Xs,ni))==null||i.enableSource(this.id)}else t.srcObject=void 0,e||(a=n(this,Xs,ni))==null||a.disableSource(this.id);t.style.display=this.videoEnabled?"block":"none"}},na=new WeakMap,gt=new WeakMap,aa=new WeakMap,Ue=new WeakMap,Xs=new WeakSet,ni=function(){return n(this,Ue).getValue("pip")},He=new WeakSet,Ye=function(){return n(this,Ue).getValue("roomNodeClient")},oa=new WeakSet,cd=function(){return n(this,Ue).getValue("audioPlayback")},Ve=new WeakSet,Fe=function(){var t;return((t=n(this,Ue).getValue("connectionHandler"))==null?void 0:t.mediaJoined)===!0},ca=new WeakMap,da=new WeakMap,Go=new WeakSet,$u=function(){Array.from(n(this,da)).forEach(t=>this.updateVideo(t,!1)),Array.from(n(this,ca)).forEach(t=>this.updateVideo(t,!0))},Ng);St([P.trace("Self.cleanupEvents")],ze.prototype,"cleanupEvents",1);St([P.trace("Self.setupEvents")],ze.prototype,"setupEvents",1);St([P.trace("Self.setupTracks")],ze.prototype,"setupTracks",1);St([P.trace("Self.destructMediaHandler")],ze.prototype,"destructMediaHandler",1);St([P.trace("Self.removeDocumentEventListeners")],ze.prototype,"removeDocumentEventListeners",1);St([Er.executeWithLock({methodName:"meeting.self.enableAudio",lockName:"Self.toggleAudio",timeout:3e3}),P.trace("Self.enableAudio")],ze.prototype,"enableAudio",1);St([Er.executeWithLock({methodName:"meeting.self.enableVideo",lockName:"Self.toggleVideo",timeout:3e3}),P.trace("Self.enableVideo")],ze.prototype,"enableVideo",1);St([P.trace("Self.updateVideoConstraints")],ze.prototype,"updateVideoConstraints",1);St([P.trace("Self.enableScreenShare"),Er.executeWithLock({methodName:"meeting.self.enableScreenShare",lockName:"Self.toggleScreenShare",timeout:3e3})],ze.prototype,"enableScreenShare",1);St([P.trace("Self.updateScreenshareConstraints")],ze.prototype,"updateScreenshareConstraints",1);St([Er.executeWithLock({methodName:"meeting.self.disableAudio",lockName:"Self.toggleAudio",timeout:3e3}),P.trace("Self.disableAudio")],ze.prototype,"disableAudio",1);St([Er.executeWithLock({methodName:"meeting.self.disableVideo",lockName:"Self.toggleVideo",timeout:3e3}),P.trace("Self.disableVideo")],ze.prototype,"disableVideo",1);St([Er.executeWithLock({methodName:"meeting.self.disableScreenShare",lockName:"Self.toggleScreenShare",timeout:3e3}),P.trace("Self.disableScreenShare")],ze.prototype,"disableScreenShare",1);St([P.trace("Self.setDevice")],ze.prototype,"setDevice",1);ze=St([dt("1100")],ze);class Mh extends Error{constructor(t){super(t!=null?t:"AwaitQueue stopped"),this.name="AwaitQueueStoppedError",typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,Mh)}}class Dh extends Error{constructor(t){super(t!=null?t:"AwaitQueue task removed"),this.name="AwaitQueueRemovedTaskError",typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,Dh)}}var Wo;class Fu{constructor(t,e=!1){h(this,"pendingTasks",new Map);h(this,"nextTaskId",0);h(this,"stopping",!1);m(this,Wo,void 0);this.log=e,f(this,Wo,{info:e&&t?t.info:()=>{}})}get size(){return this.pendingTasks.size}push(t,e,r){return u(this,null,function*(){if(e=e!=null?e:t.name,typeof t!="function")throw new TypeError("given task is not a function");if(e)try{Object.defineProperty(t,"name",{value:e})}catch(i){}return new Promise((i,a)=>{const o={id:this.nextTaskId++,task:t,metadata:r,name:e,enqueuedAt:Date.now(),executedAt:void 0,completed:!1,resolve:c=>{if(o.completed)return;o.completed=!0,this.pendingTasks.delete(o.id),i(c);const[d]=this.pendingTasks.values();d&&!d.executedAt&&this.execute(d)},reject:c=>{if(!o.completed&&(o.completed=!0,this.pendingTasks.delete(o.id),a(c),!this.stopping)){const[d]=this.pendingTasks.values();d&&!d.executedAt&&this.execute(d)}}};this.pendingTasks.set(o.id,o),this.pendingTasks.size===1&&this.execute(o)})})}stop(){this.stopping=!0;for(const t of this.pendingTasks.values())t.reject(new Mh);this.stopping=!1}remove(t){const e=Array.from(this.pendingTasks.values())[t];e&&e.reject(new Dh)}get(t){return Array.from(this.pendingTasks.values())[t]}dump(){const t=Date.now();let e=0;return Array.from(this.pendingTasks.values()).map(r=>({idx:e++,task:r.task,name:r.name,enqueuedTime:r.executedAt?r.executedAt-r.enqueuedAt:t-r.enqueuedAt,executionTime:r.executedAt?t-r.executedAt:0}))}execute(t){return u(this,null,function*(){if(t.executedAt)throw new Error("task already being executed");t.executedAt=Date.now();try{const e=this.pendingTasks.size,r=yield t.task(),i=Date.now();n(this,Wo).info(`AwaitQueue.push(${t.name})_timings`,{awaitQueueTask:{id:t.id,metadata:t.metadata,queueSizeAtStart:e,execTime:(i-t.executedAt)/1e3,taskStartTime:(t.executedAt-t.enqueuedAt)/1e3}}),t.resolve(r)}catch(e){t.reject(e)}})}}Wo=new WeakMap;function ED(s,t){const e=new Error(t);return e.name=s,e}class _o extends A{constructor(t){super(t),this.name="UnsupportedError",Error.hasOwnProperty("captureStackTrace")?Error.captureStackTrace(this,_o):this.stack=new Error(t).stack}}class wt extends A{constructor(t){super(t),this.name="InvalidStateError",Error.hasOwnProperty("captureStackTrace")?Error.captureStackTrace(this,wt):this.stack=new Error(t).stack}}class li extends A{constructor(t){super(t),this.name="TransportConnectionError",Error.hasOwnProperty("captureStackTrace")?Error.captureStackTrace(this,wt):this.stack=new Error(t).stack}}const dg=s=>new Promise(t=>setTimeout(t,s));function Wf(s,t){return u(this,null,function*(){return new Promise((e,r)=>u(this,null,function*(){const{strategy:i,maxRetryCount:a,delayTime:o}=D({strategy:"linear",maxRetryCount:3,delayTime:10},t);let c=0,d,l=!1;const p=g=>{l=!0,r(g)};for(;c<a;){try{const g=yield s(c,p);return e(g)}catch(g){if(d=g,l)break;if(c<a)i==="linear"?yield dg(o*(c+1)):i==="exponential"&&(yield dg(o*(c+Math.max(0,c-1))));else break}c+=1}return r(d)}))})}function PD(s){return s.map(t=>({channels:t.channels,clockRate:t.clockRate,mimeType:t.mimeType,sdpFmtpLine:t.sdpFmtpLine}))}function _D(s){return s.map(t=>({uri:t.uri}))}function Yc(s){return{codecs:PD(s.codecs),headerExtensions:_D(s.headerExtensions?s.headerExtensions:[])}}function CD(s){const t=RTCRtpReceiver.getCapabilities("audio"),e=RTCRtpReceiver.getCapabilities("video"),r=RTCRtpSender.getCapabilities("audio"),i=RTCRtpSender.getCapabilities("video");s&&(e.codecs=e.codecs.filter(({mimeType:d})=>s===d),i.codecs=i.codecs.filter(({mimeType:d})=>s===d));const a={audio:Yc(t),video:Yc(e)};return{sender:{audio:Yc(r),video:Yc(i)},receiver:a}}var Je;class wD{constructor(t){m(this,Je,void 0);h(this,"events");f(this,Je,t),this.events=Ps}joinRoom(t,e,r,i=!1,a=null){return u(this,null,function*(){const o={roomUuid:t,displayName:e,prejoined:i,capabilities:r};return a&&(o.location=a),(yield n(this,Je).sendMessagePromiseWithTimeout({event:this.events.joinRoom,protobuf:zw.toBinary(o),timeout:5e3})).payload})}connectTransport(t){return u(this,null,function*(){const e=(yield n(this,Je).sendMessagePromise(this.events.createWebRTCTransport,_w.toBinary(t))).payload,{transportId:r,description:i,producerIds:a}=nf.fromBinary(e),o={sdp:i==null?void 0:i.sdp,type:i.type};return{transportId:r,answer:o,producerIds:a}})}produce(t){return u(this,null,function*(){var a,o;const e=(yield n(this,Je).sendMessagePromise(this.events.produce,lR.toBinary(t))).payload,r=WR.fromBinary(e);return{answer:{sdp:(a=r==null?void 0:r.description)==null?void 0:a.sdp,type:(o=r==null?void 0:r.description)==null?void 0:o.type},producerId:r.producerId}})}consume(t){return u(this,null,function*(){const e=(yield n(this,Je).sendMessagePromise(this.events.consume,iR.toBinary(t))).payload,{consumerIdsMap:{map:r},description:i}=jR.fromBinary(e);return{consumerStateMap:r,sessionDescription:i}})}closeProducer(t){return u(this,null,function*(){const e=(yield n(this,Je).sendMessagePromise(this.events.closeProducer,TR.toBinary(t))).payload,{description:r}=ZR.fromBinary(e);return r})}closeConsumer(t){return u(this,null,function*(){return(yield n(this,Je).sendMessagePromise(this.events.closeConsumer,SR.toBinary(t))).payload})}updateConsumersSimulcastConfig(t){return u(this,null,function*(){return(yield n(this,Je).sendMessagePromise(this.events.updateConsumersSimulcastConfig,cR.toBinary(t))).payload})}hostControlForPeer(t,e){return u(this,null,function*(){const r={audio:e==="audio",screeShare:!1,video:e==="video",participantId:t},i=(yield n(this,Je).sendMessagePromise(this.events.hostControlPeer,wR.toBinary(r))).payload;if(!i)return!1;const{status:a}=ab.fromBinary(i);return a==="success"})}hostControlForAll(t){return u(this,null,function*(){const e={audio:t==="audio",screenShare:!1,video:t==="video"},r=(yield n(this,Je).sendMessagePromise(this.events.hostControlAllPeers,bR.toBinary(e))).payload;if(!r)return!1;const{status:i}=cb.fromBinary(r);return i==="success"})}kickAll(){return u(this,null,function*(){const t={propagateKickAcrossRooms:!1};n(this,Je).sendMessagePromise(U.kickAll,df.toBinary(t))})}kickPeer(t){return u(this,null,function*(){n(this,Je).sendMessagePromise(U.kick,gf.toBinary(t))})}changeDisplayName(t){return u(this,null,function*(){const e=(yield n(this,Je).sendMessagePromise(this.events.changeDisplayName,_R.toBinary(t))).payload;if(!e)return!1;const{status:r}=lb.fromBinary(e);return r==="success"})}notifySelfJoinComplete(){return u(this,null,function*(){const t={},e=(yield n(this,Je).sendMessagePromise(this.events.selfJoinComplete,Qw.toBinary(t))).payload;return yu.fromBinary(e)})}audioActivity(t){return u(this,null,function*(){n(this,Je).sendMessage(this.events.audioActivity,ww.toBinary(t))})}}Je=new WeakMap;var wn=(s=>(s.NEW="new",s.CONNECTING="connecting",s.RECONNECTING="reconnecting",s.DISCONNECTED="disconnected",s.CONNECTED="connected",s.FAILED="failed",s.CLOSED="closed",s))(wn||{}),Jo;class $l extends ct.EventEmitter{constructor(e){super();m(this,Jo,void 0);f(this,Jo,e),this.setMaxListeners(1/0)}get logger(){return n(this,Jo).getValue("logger")}safeEmit(e,...r){const i=this.listenerCount(e);try{return this.emit(e,...r)}catch(a){return this.logger.error(`EnhancedEventEmitter:: safeEmit() | event listener ${e} threw an error`,{error:a}),Boolean(i)}}safeEmitAsPromise(e,...r){return u(this,null,function*(){const i={}.EVENT_PROMISE_TIMEOUT?parseInt({}.EVENT_PROMISE_TIMEOUT,10):1e4;return this.safeEmitAsPromiseWithTimeout(e,i,...r)})}safeEmitAsPromiseWithTimeout(e,r,...i){return u(this,null,function*(){return new Promise((a,o)=>{setTimeout(o,r,"event request timeout");try{this.emit(e.toString(),...i,a,o)}catch(c){this.logger.error(`EnhancedEventEmitter:: safeEmitAsPromise() | event listener for event ${e.toString()} threw an error [event:%s]:%o`,{error:c}),o(c)}})})}}Jo=new WeakMap;class Oh extends $l{constructor(){super(...arguments);h(this,"_sendWebStream",new MediaStream);h(this,"_sendScreenShareStream",new MediaStream);h(this,"_direction");h(this,"pc");h(this,"_transportReady",!1);h(this,"_mapMidTransceiver",new Map);h(this,"enableHighBitrate",!1);h(this,"enableStereo",!1);h(this,"enableDtx",!0)}get midTransceiverMap(){return this._mapMidTransceiver}close(){if(this.logger.debug(`${this.name}::close()`),this.pc)try{this.pc.close()}catch(e){this.logger.error(`${this.name}::pc.close()`,{error:e})}}restartIce(){return u(this,null,function*(){this.logger.debug(`${this.name}::restartIce()`);const e=yield this.pc.createOffer({iceRestart:!0});return this.logger.debug(`${this.name}::restartIce() | calling pc.setLocalDescription() [offer:${JSON.stringify(e)}]`),{offerSdp:e,callback:i=>u(this,null,function*(){this.logger.info(`${this.name}::restartIce() | calling pc.setRemoteDescription() [answer:${JSON.stringify(i)}]`),yield this.pc.setRemoteDescription(i)})}})}init({direction:e,iceServers:r,iceTransportPolicy:i,additionalSettings:a,proprietaryConstraints:o,onTrackHandler:c}){this.logger.debug("HandlerInterface::init()"),this._direction=e,this.pc=new RTCPeerConnection(D({iceServers:r||[],iceTransportPolicy:i||"all",bundlePolicy:"max-bundle",rtcpMuxPolicy:"require"},a),o),c&&this.pc.addEventListener("track",d=>{c(d)}),this._addEventListeners()}connect(){return u(this,null,function*(){this.pc.addTransceiver("audio",{direction:"sendonly"}),this.pc.addTransceiver("video",{direction:"sendonly"});const e=yield this.pc.createOffer();return yield this.pc.setLocalDescription(e),this.logger.info(`connect offer: ${JSON.stringify(e)}`),{offerSdp:e,callback:i=>u(this,null,function*(){this.logger.debug(`${this.name}::connect() | calling pc.setRemoteDescription() [answer:${JSON.stringify(i)}]`),yield this.pc.setRemoteDescription(i)})}})}getTransportStats(){return u(this,null,function*(){return this.pc.getStats()})}_assertSendDirection(){if(this._direction!=="send")throw new Error('method can just be called for handlers with "send" direction')}_assertRecvDirection(){if(this._direction!=="recv")throw new Error('method can just be called for handlers with "recv" direction')}getReceiverStats(e){return u(this,null,function*(){this._assertRecvDirection();const r=this.midTransceiverMap.get(e);if(!r)throw new Error("associated RTCRtpTransceiver not found");return r.receiver.getStats()})}stopSending(e){return u(this,null,function*(){this._assertSendDirection(),this.logger.debug(`stopSending() [localId:${e}]`);const r=this.midTransceiverMap.get(e);if(!r)throw new Error("associated RTCRtpTransceiver not found");r.sender.replaceTrack(null),this.pc.removeTrack(r.sender),r.direction="inactive";const i=yield this.pc.createOffer();return this.logger.debug(`stopSending() | calling pc.setLocalDescription() [offer:${JSON.stringify(i)}]`),yield this.pc.setLocalDescription(i),{offerSdp:i,callback:o=>u(this,null,function*(){this.logger.debug(`stopSending() | calling pc.setRemoteDescription() [answer:${JSON.stringify(o)}]`),yield this.pc.setRemoteDescription(o),this.midTransceiverMap.delete(e)})}})}replaceTrack(e,r){return u(this,null,function*(){this._assertSendDirection(),r?this.logger.debug(`replaceTrack() [localId:${e}, track.id:${r.id}]`):this.logger.debug(`replaceTrack() [localId:${e}, no track]`);const i=this.midTransceiverMap.get(e);if(!i)throw new Error("associated RTCRtpTransceiver not found");yield i.sender.replaceTrack(r)})}setMaxSpatialLayer(e,r){return u(this,null,function*(){this._assertSendDirection(),this.logger.debug(`setMaxSpatialLayer() [localId:${e}, spatialLayer:${r}]`);const i=this.midTransceiverMap.get(e);if(!i)throw new Error("associated RTCRtpTransceiver not found");const a=i.sender.getParameters();a.encodings.forEach((o,c)=>{c<=r?o.active=!0:o.active=!1}),yield i.sender.setParameters(a)})}setRtpEncodingParameters(e,r){return u(this,null,function*(){this._assertSendDirection(),this.logger.debug(`setRtpEncodingParameters() [localId:${e}, params:${JSON.stringify(r)}]`);const i=this.midTransceiverMap.get(e);if(!i)throw new Error("associated RTCRtpTransceiver not found");const a=i.sender.getParameters();a.encodings.forEach((o,c)=>{a.encodings[c]=D(D({},o),r)}),yield i.sender.setParameters(a)})}getSenderStats(e){this._assertSendDirection();const r=this.midTransceiverMap.get(e);if(!r)throw new Error("associated RTCRtpTransceiver not found");return r.sender.getStats()}_addEventListeners(){this.pc.addEventListener("icecandidate",e=>{e.candidate&&this.emit("@icecandidate",{candidate:e.candidate})}),this.pc.addEventListener("iceconnectionstatechange",()=>{switch(this.pc.iceConnectionState){case"checking":this.emit("@connectionstatechange","connecting");break;case"connected":case"completed":this.emit("@connectionstatechange","connected"),this._transportReady=!0;break;case"failed":this.emit("@connectionstatechange","failed");break;case"disconnected":this.emit("@connectionstatechange","disconnected");break;case"closed":this.emit("@connectionstatechange","closed");break;default:this.logger.warn("unknown state");break}}),this.pc.addEventListener("negotiationneeded",()=>{this.emit("@negotiationneeded",{}),this.logger.debug("negotiationneeded")}),this.pc.addEventListener("icegatheringstatechange",()=>{switch(this.pc.iceGatheringState){case"gathering":this.logger.debug("icegatheringstatechange | gathering"),this.emit("@icegatheringstatechange","gathering");break;case"complete":this.logger.debug("icegatheringstatechange | complete"),this.emit("@icegatheringstatechange","complete");break;default:this.logger.warn("unknown state");break}}),this.pc.addEventListener("icecandidateerror",e=>{this.logger.warn("icecandidateerror",{error:{code:e.errorCode,message:e.errorText}})}),this.pc.addEventListener("datachannel",e=>{this.logger.info("data channel created: ",{rtcChannel:{label:e.channel.label}});const{channel:r}=e;r.onopen=()=>{this.logger.info("data channel open: ",{rtcChannel:{label:e.channel.label}}),this.safeEmit("dc_open",e.channel)},r.onclose=()=>{this.logger.warn("data channel closed: ",{rtcChannel:{label:e.channel.label}})},r.onerror=()=>{this.logger.error("data channel error: ",{rtcChannel:{label:e.channel.label}})}}),this.addCustomEventListeners()}addCustomEventListeners(){}}class Nh extends Oh{static createFactory(t){return()=>new Nh(t)}get name(){return"Chrome74"}init({direction:t,iceServers:e,iceTransportPolicy:r,additionalSettings:i,proprietaryConstraints:a,onTrackHandler:o}){this._direction=t,this.pc=new RTCPeerConnection(D({iceServers:e||[],iceTransportPolicy:r||"all",bundlePolicy:"max-bundle",rtcpMuxPolicy:"require",sdpSemantics:"unified-plan"},i),a),o&&this.pc.addEventListener("track",c=>{o(c)}),this._addEventListeners()}send(a){return u(this,arguments,function*({track:t,encodings:e,codecOptions:r,screenShare:i}){this._assertSendDirection();const o=this.pc.addTransceiver(t,{direction:"sendonly",streams:[i?this._sendScreenShareStream:this._sendWebStream],sendEncodings:e});if(!navigator.isReactNative){this.logger.debug("creating new transceiver");const l=RTCRtpSender.getCapabilities(typeof t=="string"?t:t.kind);this.logger.info(`senders available params: ${JSON.stringify(l)}`);const p=[];r&&r.length&&r.forEach(g=>{var v;const T=l.codecs.find(E=>E.mimeType.includes(g.name));if(g.parameters){this.logger.debug(`codecOption.parameters:${JSON.stringify(g.parameters)}`);const E=((v=T.sdpFmtpLine)==null?void 0:v.split(";"))||[];E.push(...g.parameters);const _=Array.from(new Set(E).values());T.sdpFmtpLine=_.join(";")}p.push(T)}),this.logger.info(`selected codecs: ${JSON.stringify(p)}`),o.setCodecPreferences(p)}const c=yield this.pc.createOffer();if(yield this.pc.setLocalDescription(c),r&&r.findIndex(({name:l})=>l==="opus")>=0){const{enableDtx:l,enableStereo:p}=this,g=this.enableHighBitrate?p?128e3:64e3:p?64e3:32e3;c.sdp=c.sdp.replace("minptime=10;useinbandfec=1",`minptime=10;useinbandfec=1;${l?"usedtx=1;":""}${p?"stereo=1;sprop-stereo=1;":""}maxaveragebitrate=${g}`),c.sdp+=`a=rtcp-fb:111 nack\r
|
|
8
|
-
`}this.midTransceiverMap.set(o.mid,o);const d=l=>u(this,null,function*(){return this.logger.debug(`send() | calling pc.setRemoteDescription() [answer:${JSON.stringify(l)}]`),yield this.pc.setRemoteDescription(l),o.mid});return this.logger.debug(`send() | calling pc.setLocalDescription() [offer: ${JSON.stringify(c,void 0,2)}]`),{offerSdp:c,callback:d,sender:o.sender,mid:o.mid}})}addCustomEventListeners(){this.pc.addEventListener("datachannel",t=>{const{channel:e}=t;e.onmessage=r=>{this.safeEmit("datachannel",t.channel,String.fromCharCode(...new Uint8Array(r.data)))}})}}class _d extends Oh{constructor(e,r){super(e);h(this,"supportsSendEncodings",!1);this.supportsSendEncodings=r.supportsSendEncodings}static createFactory(e,r){return()=>new _d(e,r)}get name(){return"Firefox60"}send(o){return u(this,arguments,function*({track:e,encodings:r,codecOptions:i,screenShare:a}){this._assertSendDirection();const c=this.supportsSendEncodings&&r!==void 0?{sendEncodings:r}:{},d=this.pc.addTransceiver(e,D({direction:"sendonly",streams:[a?this._sendScreenShareStream:this._sendWebStream]},c));if(!this.supportsSendEncodings&&r){r.reverse();const T=d.sender.getParameters();T.encodings=r,yield d.sender.setParameters(T)}const l=(T,v)=>{var N;const E=ls.parse(T),_=E.media[E.media.length-1],C=_.rtp.filter(B=>v.some(j=>j.name===B.codec)),R=_.fmtp.filter(B=>C.some(j=>j.payload===B.payload)),L=(N=_.rtcpFb)==null?void 0:N.filter(B=>C.some(j=>j.payload===B.payload)),F=C.map(B=>B.payload);return E.media[E.media.length-1].rtp=C,E.media[E.media.length-1].fmtp=R,E.media[E.media.length-1].rtcpFb=L,E.media[E.media.length-1].payloads=F.join(" "),ls.write(E)},p=yield this.pc.createOffer();if(p.sdp=l(p.sdp,i),this.logger.debug(`send() | calling pc.setLocalDescription() [offer:${JSON.stringify(p)}]`),yield this.pc.setLocalDescription(p),e==="audio"||e.kind==="audio"){const{enableDtx:T,enableStereo:v}=this,E=this.enableHighBitrate?v?128e3:64e3:v?64e3:32e3;p.sdp=p.sdp.replace("minptime=10;useinbandfec=1",`minptime=10;useinbandfec=1;${T?"usedtx=1;":""}${v?"stereo=1;sprop-stereo=1;":""}maxaveragebitrate=${E}`)}return this.midTransceiverMap.set(d.mid,d),{offerSdp:p,callback:T=>u(this,null,function*(){return this.logger.debug(`send() | calling pc.setRemoteDescription() [answer:${JSON.stringify(T)}]`),yield this.pc.setRemoteDescription(T),d.mid}),sender:d.sender,mid:d.mid}})}setMaxSpatialLayer(e,r){return u(this,null,function*(){this._assertSendDirection(),this.logger.debug(`setMaxSpatialLayer() [localId:${e}, spatialLayer:${r}]`);const i=this.midTransceiverMap.get(e);if(!i)throw new Error("associated RTCRtpTransceiver not found");const a=i.sender.getParameters(),o=a.encodings.length-1-r;a.encodings.forEach((c,d)=>{d>=o?c.active=!0:c.active=!1}),yield i.sender.setParameters(a)})}addCustomEventListeners(){this.pc.addEventListener("datachannel",e=>{const{channel:r}=e;r.onmessage=i=>u(this,null,function*(){const a=yield i.data.arrayBuffer();this.safeEmit("datachannel",e.channel,String.fromCharCode(...new Uint8Array(a)))})})}}class Vh extends Oh{static createFactory(t){return()=>new Vh(t)}get name(){return"Safari12"}send(a){return u(this,arguments,function*({track:t,encodings:e,codecOptions:r,screenShare:i}){this._assertSendDirection(),this.logger.debug("Safari12::creating new transceiver");const o=this.pc.addTransceiver(t,{direction:"sendonly",streams:[i?this._sendScreenShareStream:this._sendWebStream],sendEncodings:e}),c=RTCRtpSender.getCapabilities(typeof t=="string"?t:t.kind);this.logger.info(`Safari12::senders available params: ${JSON.stringify(c)}`);const d=[];r&&r.length>0&&r.forEach(g=>{var v;const T=c.codecs.find(E=>E.mimeType.includes(g.name));if(g.parameters){this.logger.info(`Safari12::codecOption.parameters:, ${JSON.stringify(g.parameters)}`);const E=((v=T.sdpFmtpLine)==null?void 0:v.split(";"))||[];E.push(...g.parameters);const _=[...new Set(E).values()];T.sdpFmtpLine=_.join(";")}d.push(T)}),this.logger.info(`Safari12::selected codecs: ${JSON.stringify(d)}`),o.setCodecPreferences(d);const l=yield this.pc.createOffer();if(yield this.pc.setLocalDescription(l),t==="audio"||t.kind==="audio"){const{enableStereo:g,enableDtx:T}=this,v=this.enableHighBitrate?g?128e3:64e3:g?64e3:32e3;l.sdp=l.sdp.replace("minptime=10;useinbandfec=1",`minptime=10;useinbandfec=1;${T?"usedtx=1;":""}${g?"stereo=1;sprop-stereo=1;":""}maxaveragebitrate=${v}`)}return this.midTransceiverMap.set(o.mid,o),{offerSdp:l,callback:g=>u(this,null,function*(){return this.logger.debug(`Safari12::send() | calling pc.setRemoteDescription() [answer:${JSON.stringify(g)}]`),yield this.pc.setRemoteDescription(g),o.mid}),sender:o.sender,mid:o.mid}})}addCustomEventListeners(){this.pc.ondatachannel=t=>{const{channel:e}=t;e.onmessage=r=>u(this,null,function*(){const i=String.fromCharCode(...new Uint8Array(r.data));this.safeEmit("datachannel",t.channel,i)})}}}function RD(s,t){return typeof s=="undefined"?t:typeof window!="undefined"&&Object.getOwnPropertyDescriptor(window,"structuredClone")?structuredClone(s):JSON.parse(JSON.stringify(s))}var Ko,Mi,Ds,Bd,Os,Rr,zo,Bu,Hd,Jf,qd,Kf;class bD extends $l{constructor(e,r){var i;super(e);m(this,Os);m(this,zo);m(this,Hd);m(this,qd);h(this,"rtpReceiver");h(this,"id");h(this,"localId");h(this,"producerId");h(this,"producingTransportId");h(this,"mimeType");h(this,"track");h(this,"peerId");h(this,"appData");h(this,"transceiver");m(this,Ko,void 0);m(this,Mi,void 0);m(this,Ds,void 0);m(this,Bd,void 0);this.id=r.id,this.localId=r.localId,f(this,Ko,r.handler),this.appData=r.appData,this.peerId=r.producingPeerId,this.producingTransportId=r.producingTransportId,f(this,Ds,!1),this.producerId=r.producerId,this.track=r.track,f(this,Mi,(i=r.paused)!=null?i:!1),this.mimeType=r.mimeType,this.transceiver=r.transceiver,this.rtpReceiver=r.rtpReceiver,x(this,Hd,Jf).call(this),f(this,Bd,e)}get closed(){return n(this,Ds)}get kind(){return this.track.kind}get paused(){return n(this,Mi)}close(e,r){n(this,Ds)||(this.logger.debug(`Consumer::close() ${e?`with reason ${e}`:""}`,n(this,Os,Rr)),f(this,Ds,!0),r&&(x(this,qd,Kf).call(this),this.transceiver.stop()),this.safeEmit("close",e))}getStats(){return u(this,null,function*(){if(n(this,Ds))throw new wt("closed");return n(this,Ko).getReceiverStats(this.localId)})}pause(){if(this.logger.debug("consumer::pause()",n(this,Os,Rr)),n(this,Ds)){this.logger.error("consumer::pause() | Consumer closed",n(this,Os,Rr));return}f(this,Mi,!0),this.track.enabled=!1,this.safeEmit("pause")}resume(){if(this.logger.debug("consumer::resume()",n(this,Os,Rr)),n(this,Ds)){this.logger.error("Consumer::resume() | Consumer closed",n(this,Os,Rr));return}f(this,Mi,!1),this.track.enabled=!0,this.safeEmit("resume")}}Ko=new WeakMap,Mi=new WeakMap,Ds=new WeakMap,Bd=new WeakMap,Os=new WeakSet,Rr=function(){return{consumer:{id:this.id,appData:this.appData,peerId:this.peerId,kind:this.kind}}},zo=new WeakSet,Bu=function(){this.logger.debug('Consumer::track "ended" event',n(this,Os,Rr)),this.safeEmit("trackended")},Hd=new WeakSet,Jf=function(){this.track.addEventListener("ended",x(this,zo,Bu).bind(this))},qd=new WeakSet,Kf=function(){try{this.track.removeEventListener("ended",x(this,zo,Bu)),this.track.stop()}catch(e){this.logger.error("Consumer::destroyTrack()",G(D({},n(this,Os,Rr)),{error:e}))}};var ms,la,ua,Di,Zt,Qe,Br,ha,jd,Lt,ds;class kD extends $l{constructor(e,r){var i,a;super(e);m(this,Lt);h(this,"id");h(this,"localId");m(this,ms,void 0);h(this,"kind");h(this,"appData");h(this,"rtpSender");m(this,la,void 0);m(this,ua,void 0);m(this,Di,void 0);m(this,Zt,!1);m(this,Qe,void 0);m(this,Br,void 0);m(this,ha,void 0);m(this,jd,void 0);this.id=r.id,this.localId=r.localId,f(this,Qe,r.track),this.kind=(i=r.track)==null?void 0:i.kind,f(this,Br,r.disableTrackOnPause?!((a=r.track)!=null&&a.enabled):!1),f(this,ha,void 0),f(this,la,r.stopTracks),f(this,ua,r.disableTrackOnPause),f(this,Di,r.zeroRtpOnPause),this.appData=r.appData||{},this._onTrackEnded=this._onTrackEnded.bind(this),f(this,ms,r.handler),this.rtpSender=r.rtpSender,this._handleTrack(),f(this,jd,e)}get closed(){return n(this,Zt)}get track(){return n(this,Qe)}get paused(){return n(this,Br)}get maxSpatialLayer(){return n(this,ha)}close(e){return u(this,null,function*(){if(n(this,Zt))return;if(this.logger.debug(`Producer::close() ${e?`with reason ${e}`:""}`,n(this,Lt,ds)),f(this,Zt,!0),this._destroyTrack(),e===Cd){this.safeEmit("close",{reason:e});return}const{offerSdp:r,callback:i}=yield n(this,ms).stopSending(this.localId),{answer:a}=yield this.safeEmitAsPromise("close",{offer:r,reason:e});i(a)})}getStats(){return u(this,null,function*(){if(n(this,Zt))throw new wt("closed");return n(this,ms).getSenderStats(this.localId)})}pause(){this.logger.debug("Producer::pause()",n(this,Lt,ds)),n(this,Zt)&&this.logger.error("Producer::pause() | Producer closed",n(this,Lt,ds)),f(this,Br,!0),n(this,Qe)&&n(this,ua)&&(n(this,Qe).enabled=!1),n(this,Di)&&n(this,ms).replaceTrack(this.localId,null),this.emit("pause")}resume(){if(this.logger.debug("Producer::resume()",n(this,Lt,ds)),n(this,Zt)){this.logger.error("Producer::resume() | Producer closed",n(this,Lt,ds));return}f(this,Br,!1),n(this,Qe)&&n(this,ua)&&(n(this,Qe).enabled=!0),n(this,Di)&&n(this,ms).replaceTrack(this.localId,n(this,Qe)),this.emit("resume")}replaceTrack(r){return u(this,arguments,function*({track:e}){if(this.logger.debug(`Producer::replaceTrack() trackId: ${e==null?void 0:e.id}`,n(this,Lt,ds)),n(this,Zt)){if(e&&n(this,la))try{e.stop()}catch(i){this.logger.error("Producer::replaceTrack",G(D({},n(this,Lt,ds)),{error:i}))}throw new wt("closed")}else if(e&&e.readyState==="ended")throw new wt("track ended");if(e===n(this,Qe)){this.logger.debug(`replaceTrack() | same track, ignored trackId: ${e.id}`,n(this,Lt,ds));return}(!n(this,Di)||!n(this,Br))&&(yield n(this,ms).replaceTrack(this.localId,e)),this._destroyTrack(),f(this,Qe,e),this._handleTrack()})}setMaxSpatialLayer(e){return u(this,null,function*(){if(n(this,Zt))throw new wt("closed");if(this.kind!=="video")throw new _o("not a video Producer");if(typeof e!="number")throw new TypeError("invalid spatialLayer");yield n(this,ms).setMaxSpatialLayer(this.localId,e),f(this,ha,e)})}setRtpEncodingParameters(e){return u(this,null,function*(){if(n(this,Zt))throw new wt("closed");if(typeof e!="object")throw new TypeError("invalid params");yield n(this,ms).setRtpEncodingParameters(this.localId,e)})}_onTrackEnded(){this.logger.debug(`Producer::track "ended" event trackId: ${this.track.id}`,n(this,Lt,ds)),this.safeEmit("trackended",this.track.id)}_handleTrack(){n(this,Qe)&&n(this,Qe).addEventListener("ended",this._onTrackEnded)}_destroyTrack(){var e;if(n(this,Qe))try{n(this,Qe).removeEventListener("ended",this._onTrackEnded),n(this,la)&&n(this,Qe).stop()}catch(r){this.logger.error(`Producer::_destroyTrack trackId: ${(e=this.track)==null?void 0:e.id}`,G(D({},n(this,Lt,ds)),{error:r}))}}}ms=new WeakMap,la=new WeakMap,ua=new WeakMap,Di=new WeakMap,Zt=new WeakMap,Qe=new WeakMap,Br=new WeakMap,ha=new WeakMap,jd=new WeakMap,Lt=new WeakSet,ds=function(){return{producer:{id:this.id,appData:this.appData,kind:this.kind}}};function zf(s){return typeof s=="object"&&!Array.isArray(s)&&s!==null}function cu(s){return Math.random().toString(36).substring(2,2+s)}const Qc=1;function lg(s){const t=s;return delete t.payload._bolt,t}function AD(s){return s.payload&&zf(s.payload)}function ID(s){var t,e;return AD(s)&&(e=(t=s.payload._bolt)==null?void 0:t.id)!=null?e:""}var Hr,Gd,Oi;const En=class extends ct.EventEmitter{constructor(e,r,i,a){super();h(this,"channel");h(this,"queue");h(this,"serverProtocolVersion");m(this,Hr,new Map);m(this,Gd,void 0);m(this,Oi,void 0);h(this,"respond",(e,r,i=!1)=>{let a;i?a=En.createErrorResponse(e,r):a=En.createResponse(e,r),this.channel.send(JSON.stringify(a))});h(this,"notify",e=>{const r=En.createNotification(e);this.channel.send(JSON.stringify(r))});h(this,"request",e=>u(this,null,function*(){const r=En.createRequest(e),i=new Promise((a,o)=>{const{id:d}=r.payload._bolt,l={id:d,method:r.type,resolve:p=>{this.queue.delete(d)&&(clearTimeout(l.timer),a(p))},timer:setTimeout(()=>{this.queue.delete(d)&&o(new Error(`request timeout for message id: ${d}`))},2e4),cancel:p=>{this.queue.delete(d)&&(clearTimeout(l.timer),o(p))}};this.queue.set(d,l)});return this.channel.send(JSON.stringify(r)),i}));h(this,"send",e=>{const r=JSON.stringify(e),i=16384;if(r.length>i){const a=i-200,o=Math.ceil(r.length/a),c=[];for(let l=0;l<o;l+=1){const p=l*a,g=(l+1)*a;c.push(r.slice(p,g))}const d=gr.v4();for(let l=0;l<o;l+=1){const p=c[l],T=JSON.stringify({id:d,count:o,chunkIndex:l,chunk:p});n(this,Oi).debug(`Sending message chunk over dc: ${T}`),this.channel.send(T)}}else n(this,Oi).debug(`Sending message over dc: ${r}`),this.channel.send(r)});h(this,"processMessage",e=>{var i;n(this,Hr).has(e.id)||n(this,Hr).set(e.id,[]);const r=n(this,Hr).get(e.id);if(r[e.chunkIndex]=e,(r==null?void 0:r.length)===e.count&&!r.some(a=>a===void 0)){const a=n(this,Hr).get(e.id),o=a==null?void 0:a.reduce((d,l)=>d+l.chunk,"");n(this,Hr).delete(e.id);const c=JSON.parse(o);if(!c.payload||!zf(c.payload))throw new Error("corrupted incoming message over dc",{cause:{code:"CORRUPT_DC_MESSAGE",values:c}});if(this.processBoltHandshake(c))return;if(this.serverProtocolVersion=(i=c.payload._bolt)==null?void 0:i.version,!this.processResponseMsg(c))return c}});h(this,"processResponseMsg",e=>{const{id:r}=e.payload._bolt,i=this.queue.get(r);return i?(n(this,Oi).debug(`resolving pending request with id: ${r}, complete response: ${JSON.stringify(e)}`),e.type==="error"?i.cancel(lg(e)):i.resolve(lg(e)),!0):!1});h(this,"processBoltHandshake",e=>{var r,i;return e.type==="_bolt"||e.type==="handshake"?(this.respond((i=(r=e.payload._bolt)==null?void 0:r.id)!=null?i:cu(8),{type:"_bolt",payload:{message:"pong"}}),!0):!1});this.label=i,this.transportId=a,f(this,Gd,e),f(this,Oi,e.getValue("logger")),this.channel=r,this.queue=new Map}};let ai=En;Hr=new WeakMap,Gd=new WeakMap,Oi=new WeakMap,h(ai,"createRequest",e=>{var r;if((r=e.payload)!=null&&r._bolt)throw new Error("rpc fields are internal values");return{type:e.type,payload:G(D({},e.payload),{_bolt:{id:cu(8),type:"REQUEST",version:Qc}})}}),h(ai,"createResponse",(e,r)=>{var i;if((i=r.payload)!=null&&i._bolt)throw new Error("rpc fields are internal values");return{type:r.type,payload:G(D({},r.payload),{_bolt:{id:e,type:"RESPONSE",version:Qc}})}}),h(ai,"createNotification",e=>{var r;if((r=e.payload)!=null&&r._bolt)throw new Error("rpc fields are internal values");return{type:e.type,payload:G(D({},e.payload),{bolt:{id:cu(8),type:"NOTIFY",version:Qc}})}}),h(ai,"createErrorResponse",(e,r)=>({type:"error",payload:{error:r.message,_bolt:{id:e,type:"RESPONSE",version:Qc}}}));const Cd="transport closed";var Ni;const Pn=class extends $l{constructor(e,{id:r,direction:i,handlerFactory:a,iceServers:o,iceTransportPolicy:c,proprietaryConstraints:d,additionalSettings:l,appData:p,config:g}){var E,_,C;super(e);h(this,"awaitQueue");h(this,"observer");h(this,"id");h(this,"serverId");h(this,"direction");h(this,"maxSctpMessageSize");h(this,"handler");h(this,"connectionState","new");h(this,"producers");h(this,"consumers");h(this,"datachannels");h(this,"connected",!1);h(this,"eventsDCReadyPromise");h(this,"eventsDCReadyPromiseResolver");h(this,"eventsDCFailureTimer");h(this,"transportConnectionPromise");h(this,"consumerTrackEvents");h(this,"unknownTracksMap");h(this,"appData");m(this,Ni,void 0);f(this,Ni,e);const T=e.getValue("logger");T.debug(`constructor() [id: ${r}, direction: ${i}]`),this.id=r,this.direction=i;const v=RD(l,{});delete v.iceServers,delete v.iceTransportPolicy,delete v.bundlePolicy,delete v.rtcpMuxPolicy,delete v.sdpSemantics,this.producers=new Map,this.consumers=new Map,this.datachannels=new Map,this.consumerTrackEvents=new Map,this.unknownTracksMap=new Map,this.awaitQueue=new Fu(T,!0),this.handler=a(),this.handler.enableHighBitrate=(E=g==null?void 0:g.enableHighBitrate)!=null?E:!1,this.handler.enableStereo=(_=g==null?void 0:g.enableStereo)!=null?_:!1,this.handler.enableDtx=(C=g==null?void 0:g.enableDtx)!=null?C:!0,this.handler.init({onTrackHandler:this._ontrack.bind(this),direction:i,iceServers:o,iceTransportPolicy:c,additionalSettings:l,proprietaryConstraints:d}),this.appData=p||{},this.transportConnectionPromise=new Promise(R=>{this.once("connected",()=>{R(!0)}),this.once("disconnect",()=>{R(!1)}),this.once("close",()=>{R(!1)})}),this.eventsDCReadyPromise=new Promise(R=>{this.eventsDCReadyPromiseResolver=R}),this.handler.on("@connectionstatechange",R=>{R!==this.connectionState&&(this.logger.debug(`connection state changed to ${R}`),this.connectionState=R,R==="connected"&&(this.connected=!0,this.emit("connected")),R==="disconnected"&&(this.connected=!1,this.emit("disconnect")),(R==="failed"||R==="closed")&&(this.connected=!1,this.emit("close")),this.closed||this.safeEmit("connectionstatechange",R))}),this.handler.on("@icecandidate",({candidate:R})=>{this.closed||this.safeEmit("icecandidate",R)}),this.handler.on("dc_open",R=>{let L=this.datachannels.get(R.label);L||(L||(L=new ai(n(this,Ni),R,R.label,this.serverId),this.datachannels.set(R.label,L)),this.eventsDCFailureTimer=setTimeout(()=>{R.label==="events"&&(this.eventsDCReadyPromiseResolver(!1),this.safeEmit("dc_error",R.label))},5e3))}),this.handler.on("datachannel",(R,L)=>{R.label==="events"&&(this.eventsDCReadyPromiseResolver(!0),this.eventsDCFailureTimer&&clearTimeout(this.eventsDCFailureTimer));const F=this.datachannels.get(R.label);if(!F){this.logger.error("unregistered datachannel for message",{rtcChannel:{label:R.label,message:L}});return}try{const N=JSON.parse(L);this.logger.debug("datachannel message chunk recieved",{dataChannelMessageChunk:{id:N.id,count:N.count,chunkIndex:N.chunkIndex,chunk:N.chunk,transprtId:this.serverId}});const B=F.processMessage(N);if(!B)return;this.logger.debug(`datachannel message with id:${N.id} on transport:${this.serverId}complete - ${JSON.stringify(B)}`),this.emit(`datachannel:${R.label}`,F.label,B)}catch(N){this.logger.error("error parsing message",{error:N})}})}get closed(){return this.connectionState==="closed"}setServerId(e){this.serverId=e}getDatachannel(e){return this.datachannels.get(e)}get isEventsDCReady(){return this.eventsDCReadyPromise}close(){this.closed||(this.logger.debug("Transport close called"),this.connectionState="closed",this.awaitQueue.stop(),this.awaitQueue=void 0,this.connected=!1,this.handler.close(),Array.from(this.producers.values()).forEach(e=>{e.close(Cd).catch(()=>{})}),this.producers.clear(),Array.from(this.consumers.values()).forEach(e=>{e.close(Cd)}),this.consumers.clear(),this.consumerTrackEvents.clear(),this.emit("close"))}getStats(){return u(this,null,function*(){if(this.closed)throw new wt("closed");return this.handler.getTransportStats()})}connect(e){return u(this,null,function*(){try{if(yield this.awaitQueue.push(()=>u(this,null,function*(){const{offerSdp:r,callback:i}=yield this.handler.connect(),{transportId:a,answer:o}=yield e(r);this.setServerId(a),yield i(o)})),!(yield this.transportConnectionPromise))throw new Error("ice connection failed")}catch(r){throw this.logger.error("transport failed to connect:",{error:r}),r}})}restartIce(){return u(this,null,function*(){if(this.logger.debug("restartIce()"),this.closed)throw new wt("closed");return this.handler.restartIce()})}canProduce(e){return u(this,null,function*(){const{track:r,appData:i}=e;if(r){if(this.direction!=="send")throw new _o("not a sending Transport");if(r.readyState==="ended")throw new wt("track ended");if(i&&typeof i!="object")throw new TypeError("if given, appData must be an object")}else throw new TypeError("missing track");if(!(yield this.transportConnectionPromise))throw new li("transport not connected");return!0})}produce(e,r){return u(this,null,function*(){if(!(yield this.canProduce(e)))throw new Error("Cannot produce");const{track:a,encodings:o,codecOptions:c,stopTracks:d=!0,disableTrackOnPause:l=!0,zeroRtpOnPause:p=!1,appData:g={}}=e;this.logger.debug(`produce() [track:${a.id}]`);const{producerId:T,localId:v,rtpSender:E}=yield this.awaitQueue.push(()=>u(this,null,function*(){const{offerSdp:_,callback:C,sender:R,mid:L}=yield this.handler.send({track:a,encodings:o,codecOptions:c,screenShare:g==null?void 0:g.screenShare}),{answer:F,producerId:N}=yield r({offer:_,kind:a.kind,paused:l?!a.enabled||Object.hasOwn(a,"fakeTracks"):!1,appData:G(D({},g||{}),{mid:L}),codecOptions:c,producingTransportId:this.serverId}),B=yield C(F);return{producerId:N,localId:B,rtpSender:R}}),"Transport.produce");return this.createProducerObject({id:T,localId:v,track:a,stopTracks:d,disableTrackOnPause:l,zeroRtpOnPause:p,appData:g,handler:this.handler,rtpSender:E})})}createProducerObject(e){return u(this,null,function*(){const r=new kD(n(this,Ni),e);return this.producers.set(r.id,r),r.once("close",()=>{this.producers.delete(r.id)}),this.emit("newproducer",r),r})}closeProducer(e){return u(this,null,function*(){yield this.awaitQueue.push(e.close.bind(e),"Transport.closeProducer")})}canConsume(){return u(this,null,function*(){if(this.closed)throw new wt("closed");if(this.direction!=="recv")throw new _o("not a receiving transport");if(!(yield this.transportConnectionPromise))throw new li("transport not connected");return!0})}consume(e,r,i){return u(this,null,function*(){return this.awaitQueue.push(()=>u(this,null,function*(){const a={},{consumerStates:o,sessionDescription:c,failedProducers:d}=yield r(e);o.forEach((p,g)=>{a[g]=this.createConsumerObjectAndWaitForTrack(G(D({},p),{producerId:g}))}),c&&(this.logger.info("Session description found, sending negotiation request"),yield i(c));const l=[];return yield Promise.all(Object.entries(a).map(([p,g])=>g.then(T=>l.push(T)).catch(()=>{this.logger.error(`Failed to create consumer object, producer: ${p}`,{error:{message:"This should not happen"},transport:{serverId:this.serverId}})}))),{consumers:l,failedProducers:d}}),"Transport.consume",{producersLength:e.length})})}static parseCodecAndFmtpMappings(e,r){const i=ls.parse(e.sdp),a={};return i.media.forEach(o=>{r.includes(o.mid.toString())&&(a[o.mid.toString()]={rtp:o.rtp,fmtp:o.fmtp,payloads:o.payloads,rtcpFb:o.rtcpFb})}),a}static setCodecAndFmtpMappings(e,r,i){const a=ls.parse(e.sdp);return a.media=a.media.map(c=>{if(r.includes(c.mid.toString())){const d=D({},c);return d.rtp=i[c.mid.toString()].rtp,d.fmtp=i[c.mid.toString()].fmtp,d.payloads=i[c.mid.toString()].payloads,d.rtcpFb=i[c.mid.toString()].rtcpFb,d}return c}),G(D({},e),{sdp:ls.write(a)})}static parseHeaderExtensionMappings(e){const r=ls.parse(e.sdp),i={};return r.media.forEach(a=>{i[a.mid]=a.ext}),i}static setHeaderExtensionMappings(e,r){const i=ls.parse(e.sdp);return i.media=i.media.map(o=>{const c=D({},o);return c.ext=r[o.mid],c}),G(D({},e),{sdp:ls.write(i)})}closeConsumers(e,r){return u(this,null,function*(){try{const i=e.map(l=>l.transceiver.mid),a=Pn.parseCodecAndFmtpMappings(this.handler.pc.remoteDescription,i),o=Pn.parseHeaderExtensionMappings(this.handler.pc.remoteDescription);this.logger.info("Stopping transceivers",{consumerIds:e.map(({id:l})=>l)}),e.forEach(l=>l.close(void 0,!0));let c=yield this.handler.pc.createOffer();this.logger.info("Created offer for closing consumers",{sdp:c.sdp}),c=Pn.setCodecAndFmtpMappings(c,i,a),c=Pn.setHeaderExtensionMappings(c,o),this.logger.info("Updated codec and fmtp mappings in close consumer offer",{sdp:c.sdp}),yield this.setLocalDescription(c),this.logger.info("Successfully set local description in close consumers");const d=yield r(e,c);this.logger.info("Received answer in close consumers",{sdp:d.sdp}),yield this.setRemoteDescription(d),this.logger.info("Remote description was set successfully in close consumers",{sdp:d.sdp})}catch(i){this.logger.error("Failed to close consumers",{error:i})}})}setRemoteOffer(e){return u(this,null,function*(){try{this.logger.info("Received offer from SFU",{sdp:e.sdp}),yield this.setRemoteDescription(e);const r=yield this.handler.pc.createAnswer();this.logger.info("Created answer corresponding to received offer",{sdp:r.sdp});const i=ls.parse(r.sdp);return i.media=i.media.map(a=>{if(a.type==="audio"){const o=D({},a),c=o.fmtp.find(l=>l.payload===111);return c&&(c.config+=";stereo=1;sprop-stereo=1"),o.rtcpFb||(o.rtcpFb=[]),o.rtcpFb.some(l=>l.type==="nack")||o.rtcpFb.push({payload:parseInt(o.payloads,10),type:"nack"}),o}return a}),r.sdp=ls.write(i),this.logger.info("Setting munged SDP",{sdp:r.sdp}),yield this.setLocalDescription(r),this.logger.info("Successfully set local description",{sdp:r.sdp}),r}catch(r){throw this.logger.error("Set remote offer failed",{error:r}),r}})}_ontrack(e){const{track:r,transceiver:i}=e;this.logger.info(`track event received [trackId: ${r.id}] [mid: ${i.mid}]`);const a=`${i.mid}:${r.kind}`;r.addEventListener("ended",()=>{this.logger.info(`rtc consumer track ended [trackId: ${r.id}]`),this.unknownTracksMap.delete(a)});const o=this.consumerTrackEvents.get(a);o?(o(r,i),this.consumerTrackEvents.delete(a)):(this.logger.warn(`track event handler not found ${a}`),this.unknownTracksMap.set(a,e))}sendErrorOverDC(e,r,i){const a=this.getDatachannel(e);if(!a)throw new Error("datachannel not found",{cause:{code:"DC_NOT_FOUND",values:{label:e}}});a.respond(r,i,!0)}sendResponseOverDC(e,r,i){const a=this.getDatachannel(e);if(!a)throw new Error("datachannel not found",{cause:{code:"DC_NOT_FOUND",values:{label:e}}});a.respond(r,i)}createConsumerObjectAndWaitForTrack(e){return u(this,null,function*(){const{consumerId:r,producerId:i,producingPeerId:a,producingTransportId:o,streamId:c,paused:d,screenShare:l,appData:p,kind:g,mimeType:T}=e,v=`${c}:${g}`,E=G(D({},e),{name:"consumer creation task error",message:"consumer creation failed"});return new Promise((_,C)=>u(this,null,function*(){const R=setTimeout(()=>{this.logger.warn(`Timed out waiting for track event ${v} producingPeerId: ${a}`),this.consumerTrackEvents.delete(v),E.isTimedout=!0,C(E)},5e3),L=(N,B)=>{try{if(N.readyState==="ended")clearTimeout(R),C(E);else{const j=N;j.enabled=!0,this.handler.midTransceiverMap.set(B.mid,B);const re=new bD(n(this,Ni),{id:r,localId:B.mid,transceiver:B,track:j,paused:d,producerId:i,producingPeerId:a,producingTransportId:o,handler:this.handler,appData:G(D({},p),{screenShare:l,peerId:a}),rtpReceiver:B.receiver,mimeType:T});this.consumers.set(r,re),re.once("close",()=>{this.consumers.delete(re.id),this.handler.midTransceiverMap.delete(B.mid)}),this.logger.info("consumer created for ",{consumer:{id:r,kind:g,appData:{screenShare:l},peerId:a,producerId:i}}),this.emit("newconsumer",re),clearTimeout(R),_(re)}}catch(j){this.logger.warn("error while creating consumer:",j),clearTimeout(R),C(E)}},F=this.unknownTracksMap.get(v);F?(this.logger.info(`track event already received [trackId: ${F.track.id}] [mid: ${F.transceiver.mid}]`),this.unknownTracksMap.delete(v),L(F.track,F.transceiver)):(this.logger.info(`Registering onTrack handler for key ${v} [producingPeerId: ${a}]`),this.consumerTrackEvents.set(v,L))}))})}setRemoteDescription(e){return u(this,null,function*(){yield this.handler.pc.setRemoteDescription(e)})}setLocalDescription(e){return u(this,null,function*(){this.logger.debug(`${this.direction}() {transportId: ${this.serverId}} | calling pc.setLocalDescription() [offer:${JSON.stringify(e)}]`),yield this.handler.pc.setLocalDescription(e)})}sendDataChannelMessage(e,r){return u(this,null,function*(){const i=this.getDatachannel(e);if(!i)throw ED("DC_NOT_READY",`${e} datachannel not ready`);const a=(yield i.request(r)).payload;return this.logger.info(`sendDataChannelMessage::response ${JSON.stringify(a)}`),a})}};let Hu=Pn;Ni=new WeakMap;function MD(s){if(typeof navigator=="object"&&navigator.product==="ReactNative"){if(typeof RTCPeerConnection=="undefined"){s.warn("Device::this._detectDevice() | unsupported ReactNative without RTCPeerConnection");return}return s.debug("Device::this._detectDevice() | ReactNative handler chosen"),"Chrome74"}if(typeof navigator=="object"&&typeof navigator.userAgent=="string"){const t=navigator.userAgent,e=$g.getParser(t),r=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(r.name&&r.name.toLowerCase()==="blink"){const i=t.match(/(?:(?:Chrome|Chromium))[ /](\w+)/i);return i?Number(i[1])>=74?"Chrome74":void 0:"Chrome74"}if(r.name.toLowerCase()==="webkit"&&e.getOS().name.toLowerCase()==="ios")return typeof RTCRtpTransceiver!="undefined"&&RTCRtpTransceiver.prototype.hasOwnProperty("currentDirection")?"Safari12":void 0;s.warn("Device::this._detectDevice() | browser not supported");return}s.warn("Device::this._detectDevice() | unknown device")}var Zs,Vi;class DD{constructor(t,{handlerName:e,handlerFactory:r}={}){h(this,"handlerFactory");m(this,Zs,void 0);m(this,Vi,void 0);const i=t.getValue("logger");if(i.debug("constructor()"),f(this,Zs,t),f(this,Vi,i),e&&r)throw new TypeError("just one of handlerName or handlerInterface can be given");if(r)this.handlerFactory=r;else{if(e)n(this,Vi).debug(`Device::constructor() | handler given: ${e}`);else if(e=MD(n(this,Vi)),e)n(this,Vi).debug(`Device::constructor() | detected handler: ${e}`);else throw new Error("device not supported");switch(e){case"Chrome74":this.handlerFactory=Nh.createFactory(n(this,Zs));break;case"Safari12":this.handlerFactory=Vh.createFactory(n(this,Zs));break;case"Firefox60":this.handlerFactory=_d.createFactory(n(this,Zs),{supportsSendEncodings:!1});break;case"Firefox110":this.handlerFactory=_d.createFactory(n(this,Zs),{supportsSendEncodings:!0});break;default:throw new TypeError(`unknown handlerName "${e}"`)}}}createTransport(t){const e=gr.v4();return new Hu(n(this,Zs),G(D({id:e},t),{handlerFactory:this.handlerFactory}))}}Zs=new WeakMap,Vi=new WeakMap;const OD=2e3;var pa,it,nt,Yo,Qo,Li,ga,Xo,ma,xi,Ns,fa,dd,Zo,qu,Wd,Yf,ec,ju,Jd,Qf,Kd,Xf,zd,Zf,Yd,eT,Qd,tT,tc,Gu,sc,Wu;class ND extends ct.EventEmitter{constructor(e,r){super();m(this,fa);m(this,Zo);m(this,Wd);m(this,ec);m(this,Jd);m(this,Kd);m(this,zd);m(this,Yd);m(this,Qd);m(this,tc);m(this,sc);h(this,"context");m(this,pa,void 0);m(this,it,void 0);m(this,nt,void 0);m(this,Yo,void 0);m(this,Qo,void 0);m(this,Li,void 0);m(this,ga,void 0);m(this,Xo,void 0);m(this,ma,{transportFailureCount:{send:0,recv:0},lastConnectionTime:0});m(this,xi,void 0);m(this,Ns,"all");this.context=e,f(this,Li,r),f(this,pa,new DD(e)),f(this,ga,new wD(r)),f(this,Xo,Ps),n(this,fa,dd).mediaState={send:{state:wn.NEW},recv:{state:wn.NEW}},(Ia(this.context,"forceRelay")||this.context.getValue("flagsmith").hasFeature(Z.FORCE_RELAY))&&f(this,Ns,"relay"),this.logger.info(`ICE Transport Policy initially set to ${n(this,Ns)}`),x(this,Zo,qu).call(this)}get telemetry(){return this.context.getValue("telemetry")}get logger(){return this.context.getValue("logger")}get socket(){return n(this,Li)}get socketHandler(){return n(this,ga)}get sendTransport(){return n(this,it)}get recvTransport(){return n(this,nt)}get events(){return n(this,Xo)}set sendTransportConnectedCallback(e){f(this,Yo,e)}set recvTransportConnectedCallback(e){f(this,Qo,e)}setupTransports(e){return u(this,null,function*(){yield x(this,Wd,Yf).call(this,e);let r,i;e.send&&(r=x(this,ec,ju).call(this,n(this,it)).then(a=>{try{n(this,Yo).call(this,a)}catch(o){this.logger.error("Failed to run send transport callback")}})),e.recv&&(i=x(this,ec,ju).call(this,n(this,nt)).then(a=>{try{n(this,Qo).call(this,a)}catch(o){this.logger.error("Failed to run recv transport callback")}})),yield Promise.all([r,i])})}stopTransports(e){var r,i;if(e.send&&this.sendTransport!==void 0){const{id:a,serverId:o,direction:c}=n(this,it);this.logger.info("Closing send transport",{transport:{id:a,serverId:o,type:c}}),n(this,it).close(),n(this,it).removeAllListeners(),f(this,it,void 0)}if(e.recv&&this.recvTransport!==void 0){const{id:a,serverId:o,direction:c}=n(this,nt);this.logger.info("Closing recv transport",{transport:{id:a,serverId:o,type:c}}),(r=n(this,nt))==null||r.close(),(i=n(this,nt))==null||i.removeAllListeners(),f(this,nt,void 0)}x(this,Zo,qu).call(this)}stopAllTransports(){this.logger.info("Closing all transports"),this.stopTransports({send:!0,recv:!0})}handleErrors(e){throw new Error("Method not implemented.")}}pa=new WeakMap,it=new WeakMap,nt=new WeakMap,Yo=new WeakMap,Qo=new WeakMap,Li=new WeakMap,ga=new WeakMap,Xo=new WeakMap,ma=new WeakMap,xi=new WeakMap,Ns=new WeakMap,fa=new WeakSet,dd=function(){return this.context.getValue("connectionHandler")},Zo=new WeakSet,qu=function(){f(this,xi,{send:void 0,recv:void 0})},Wd=new WeakSet,Yf=function(e){return u(this,null,function*(){var o,c,d,l,p,g,T,v;(Ia(this.context,"forceRelay")||this.context.getValue("flagsmith").hasFeature(Z.FORCE_RELAY))&&f(this,Ns,"relay"),this.logger.info(`ICE Transport Policy set to ${n(this,Ns)}`);const a=yield ot().getICEServers().catch(E=>(this.logger.warn(`failed to get iceservers from server: ${E.message}`),[]));if(e.send){const E=this.context.getValue("flagsmith").hasFeature(Z.DISABLE_OPUS_DTX_CF);x(this,Kd,Xf).call(this,{iceServers:a,additionalSettings:{encodedInsertableStreams:(o=this.context.getValue("modules").e2ee)==null?void 0:o.enabled},config:{enableHighBitrate:(l=(d=(c=this.context.getValue("defaults").mediaConfiguration)==null?void 0:c.audio)==null?void 0:d.enableHighBitrate)!=null?l:!1,enableStereo:(T=(g=(p=this.context.getValue("defaults").mediaConfiguration)==null?void 0:p.audio)==null?void 0:g.enableStereo)!=null?T:!1,enableDtx:!!E},iceTransportPolicy:n(this,Ns)})}e.recv&&x(this,zd,Zf).call(this,{iceServers:a,additionalSettings:{encodedInsertableStreams:(v=this.context.getValue("modules").e2ee)==null?void 0:v.enabled},iceTransportPolicy:n(this,Ns)})})},ec=new WeakSet,ju=function(e){return u(this,null,function*(){const{id:r,serverId:i,direction:a}=e;x(this,Yd,eT).call(this,e);try{return yield Wf((c,d)=>u(this,null,function*(){c>0&&this.logger.debug(`Retrying transport connect, count: ${c}`,{transport:{id:r,serverId:i,type:a}});try{if(e.closed)throw new li("Cannot reconnect closed transport");yield x(this,Jd,Qf).call(this,e)}catch(l){if(l instanceof li){d(l);return}throw this.logger.error("Failed to connect transport, retrying",{transport:e,error:l}),l}}),{delayTime:100,strategy:"exponential",maxRetryCount:1/0}),e}catch(o){throw this.logger.error(`Failed to connect send transport after retry: ${e.id}`,{error:o,transport:{id:r,serverId:i,type:a}}),e.close(),e.removeAllListeners(),o}})},Jd=new WeakSet,Qf=function(e){return u(this,null,function*(){const{id:r,direction:i}=e;if(this.logger.info(`Connecting ${i} transport`,{transport:{id:r,type:i}}),!n(this,Li).isConnected)throw new li("Socket is not connected");if(e.connectionState==="closed")throw new li("Transport is closed");try{yield e.connect(a=>x(this,Qd,tT).call(this,i,a)),this.logger.info(`Connected ${i} transport`,{transport:{id:r,serverId:e.serverId,type:i}})}catch(a){throw n(this,ma).transportFailureCount[i]+=1,a.message==="ice connection failed"?new li(a.message):a}})},Kd=new WeakSet,Xf=function(e){var r,i;if(n(this,it)&&n(this,it).connected){this.logger.info("Transport send is already connected",{transport:{id:(r=n(this,it))==null?void 0:r.id,serverId:(i=n(this,it))==null?void 0:i.serverId,type:"send"}});return}f(this,it,n(this,pa).createTransport(G(D({},e),{direction:"send"}))),this.context.getValue("callstats").configureSendTransport(n(this,it))},zd=new WeakSet,Zf=function(e){var r,i;if(n(this,nt)&&n(this,nt).connected){this.logger.info("Transport recv is already connected",{transport:{id:(r=n(this,nt))==null?void 0:r.id,serverId:(i=n(this,nt))==null?void 0:i.serverId,type:"recv"}});return}f(this,nt,n(this,pa).createTransport(G(D({},e),{direction:"recv"}))),this.context.getValue("callstats").configureRecvTransport(n(this,nt))},Yd=new WeakSet,eT=function(e){const{direction:r,id:i}=e;e.on("connectionstatechange",a=>u(this,null,function*(){x(this,sc,Wu).call(this,{state:a,direction:r}),this.logger.info(`Transport connection state changed for ${r} transport`,{transport:{id:i,serverId:e.serverId,type:r,status:a}});const o=()=>{const c=n(this,xi)[r];c!==void 0&&(clearTimeout(c),n(this,xi)[r]=void 0)};switch(a){case"connected":o(),n(this,ma).lastConnectionTime=performance.now();break;case"disconnected":n(this,xi)[r]=setTimeout(()=>u(this,null,function*(){this.logger.warn(`${r} transport is in disconnected state, reconnecting transport`,{transport:{id:i,serverId:e.serverId,type:r}}),yield x(this,tc,Gu).call(this,e.direction)}),OD);break;case"failed":if(e.closed)return;o(),this.logger.warn(`${r} transport is in failed state, reconnecting transport`,{transport:{id:i,serverId:e.serverId,type:r}}),yield x(this,tc,Gu).call(this,e.direction);break}})),e.on("icecandidate",a=>u(this,null,function*(){this.logger.debug("Sending iceCandidate:",{iceCandidate:a})})),e.on("datachannel:events",(a,o)=>u(this,null,function*(){var c,d;this.logger.debug("Got data channel message on event:",{rtcChannel:{label:a,message:o}});try{switch(o.type){case"handshake":{const l={type:"handshake",payload:{message:"pong"}};e.sendResponseOverDC(a,ID(o),l);break}case"hub-disconnect":{this.logger.debug(`media hub disconnected, full_reconnect: ${(c=o.payload)==null?void 0:c.full_reconnect}`),((d=o.payload)==null?void 0:d.full_reconnect)===!0&&this.handleErrors("rejoin");break}case"error":break;default:break}}catch(l){this.logger.error(`Unable to handle the incoming datachannel message on channel ${a}`)}})),e.on("dc_error",()=>{e.direction==="recv"&&(this.logger.warn("Events datachannel did not open in 5s",{country:P.location.country}),this.handleErrors("reconnectRecvTransport"))})},Qd=new WeakSet,tT=function(e,r){return u(this,null,function*(){const i=e==="recv";try{const{sdp:a,type:o}=r,c={consuming:i,description:{sdp:a,type:o,target:i?fr.SUBSCRIBER:fr.PUBLISHER},producers:[]};return n(this,ga).connectTransport(c)}catch(a){throw this.logger.error(`Error in ${e} transport connection:`,{error:a,country:P.location.country}),a}})},tc=new WeakSet,Gu=function(e){return u(this,null,function*(){switch(this.logger.info("Called reconnect transport",{transport:{type:e}}),this.stopTransports({[e]:!0}),this.context.getValue("flagsmith").hasFeature(Z.CF_TRANSPORT_FORCE_RELAY_ON_ICE_FAILED)&&n(this,Li).isConnected&&n(this,ma).transportFailureCount[e]>2&&(this.logger.warn(`Multiple disconnections in ${e} transport, forcing relay`),f(this,Ns,"relay")),yield this.setupTransports({[e]:!0}),e){case"send":{this.logger.info("Transport reconnected",{transport:n(this,it)}),this.context.getValue("peerSessionStore").emit(b.RESET_PRODUCER_STATE);break}case"recv":{this.logger.info("Transport reconnected",{transport:n(this,nt)}),this.context.getValue("peerSessionStore").emit(b.UPDATE_ACTIVE,{createAllConsumers:!0});break}default:this.logger.warn("Unknown transport direction",{transport:{type:e}})}x(this,sc,Wu).call(this,{state:wn.CONNECTED,direction:e})})},sc=new WeakSet,Wu=function(e){const{state:r,direction:i}=e;n(this,fa,dd).mediaState[i]={state:r},this.context.getValue("peerSessionStore").emit(b.TRANSPORT_STATE_UPDATE,D({transport:i},n(this,fa,dd).mediaState[i]))};var rc,es;class VD{constructor(t,e,r,i,a){m(this,rc,void 0);m(this,es,void 0);this.events=e,this.recvTransport=r,this.socket=i,this.socketHandler=a,f(this,rc,t),f(this,es,t.getValue("logger"))}create(t){return u(this,null,function*(){if(!t||t&&t.length===0)throw new Error("List of producers is required");const e=new Map,r=[];t.forEach(d=>{const{producingPeerId:l,producerId:p,producingTransportId:g}=d,T=n(this,rc).getValue("flagsmith").hasFeature(Z.ENABLE_CF_SIMULCAST)?{simulcast:{preferredRid:"h",priorityOrdering:"asciibetical",ridNotAvailable:"asciibetical"}}:{};e.set(p,l),r.push(D({producingPeerId:l,producerId:p,producingTransportId:g},T))});const i=yield this.socketHandler.consume({requests:r,consumingTransportId:this.recvTransport.serverId}),a=new Map;t.forEach(d=>a.set(d.producerId,d));const o=new Map,c=[];return Object.entries(i.consumerStateMap).forEach(([d,l])=>{const p=a.get(d);if(!p)return;if(l.errorCode){n(this,es).warn(`Consumer request failed for producer ${d}`,{error:{message:l.errorCode}}),c.push(G(D({},p),{errorCode:l.errorCode}));return}let g={};try{g=JSON.parse(l.producerState.appData)}catch(T){}o.set(d,{consumerId:l.consumerId,producingTransportId:p.producingTransportId,producingPeerId:p.producingPeerId,kind:p.kind,paused:p.pause,streamId:l.producerTrack.streamId,trackId:l.producerTrack.trackId,screenShare:p.screenShare,mimeType:p.mimeType,appData:g})}),{consumerStates:o,sessionDescription:i.sessionDescription,failedProducers:c}})}negotiate(t){return u(this,null,function*(){try{n(this,es).info("Negotiating socket consumer",{transport:this.recvTransport}),n(this,es).debug(`setting remote offer: ${JSON.stringify(t)} on recvTransport`,{transport:this.recvTransport});const e=yield this.recvTransport.setRemoteOffer(t),r={transportId:this.recvTransport.serverId,description:{sdp:e.sdp,type:e.type,target:fr.SUBSCRIBER}};return n(this,es).debug(`sending renegotiate request: ${JSON.stringify(r)} on recvTransport`,{transport:this.recvTransport}),yield this.socket.sendMessagePromise(this.events.renegotiateSessionDescription,kw.toBinary(r)),n(this,es).info("Renegotiation done",{transport:this.recvTransport}),e}catch(e){n(this,es).error("Failed to renegotiate",{error:e});return}})}close(t){return u(this,null,function*(){if(!t.length)return{};const e=(r,i)=>u(this,null,function*(){const a=r.map(l=>l.localId);n(this,es).info(`Closing consumers: ${JSON.stringify(a)}`);const o={description:{sdp:i.sdp,type:i.type,target:fr.SUBSCRIBER},consumerIds:a,consumingTransportId:this.recvTransport.serverId},c=yield this.socketHandler.closeConsumer(o),d=tb.fromBinary(c).description;return{sdp:d.sdp,type:d.type}});return yield this.recvTransport.awaitQueue.push(()=>this.recvTransport.closeConsumers(t,e),"ConsumerStrategy.close",{consumersLength:t.length}),{}})}switchConsumersToLayer(t,e){return u(this,null,function*(){const r={requests:[],consumingTransportId:this.recvTransport.serverId},i=t.filter(a=>a&&a.id);i.forEach(({id:a,producingTransportId:o,localId:c})=>{r.requests.push({producerId:a,producingTransportId:o,mid:c,simulcast:{preferredRid:e===0?"q":"h",priorityOrdering:"asciibetical",ridNotAvailable:"asciibetical"}})}),yield this.socketHandler.updateConsumersSimulcastConfig(r),n(this,es).info(`Consumers switched layers to ${e}`,{consumerIds:i==null?void 0:i.map(({id:a})=>a)})})}}rc=new WeakMap,es=new WeakMap;class Lh{constructor(t){this.socketHandler=t}static getMSIDFromSDP(t,e){return ls.parse(t).media.filter(a=>e==="video"?a.type==="video":a.type==="audio").at(-1).msid}create(c){return u(this,arguments,function*({offer:t,kind:e,paused:r,appData:i,codecOptions:a,producingTransportId:o}){var T,v;const d=Lh.getMSIDFromSDP(t.sdp,e),l={description:{sdp:t.sdp,type:t.type,target:fr.PUBLISHER},paused:r,kind:e,msid:d,appData:JSON.stringify(i),screenShare:(T=i.screenShare)!=null?T:!1,mimeType:`${e}/${(v=a[0])==null?void 0:v.name}`,producingTransportId:o},{answer:p,producerId:g}=yield this.socketHandler.produce(l);return{answer:p,producerId:g}})}}var Ui,qr,Ta,ic,Vs,Xd,er,va,nc,Ju,Zd,sT,el,rT,tl,iT,sl,nT;class LD extends ND{constructor(e,r){super(e,r);m(this,nc);m(this,Zd);m(this,el);m(this,tl);m(this,sl);m(this,Ui,void 0);m(this,qr,void 0);m(this,Ta,void 0);m(this,ic,void 0);m(this,Vs,void 0);m(this,Xd,{producerCreationFailureCount:0,consumerCreationFailureCount:0,producerNotReadyFailureCount:0});m(this,er,[]);m(this,va,void 0);this.context=e,this.sendTransportConnectedCallback=()=>u(this,null,function*(){f(this,ic,new Lh(this.socketHandler))}),this.recvTransportConnectedCallback=i=>u(this,null,function*(){n(this,Ta).clear(),f(this,Vs,new VD(this.context,this.events,i,this.socket,this.socketHandler))}),this.reset()}get socketHandler(){return super.socketHandler}get producers(){return n(this,Ui)}get consumers(){return n(this,qr)}get producerIdToConsumerIdMap(){return n(this,Ta)}get logger(){return this.context.getValue("logger")}reset(){f(this,Ui,new Map),f(this,qr,new Map),f(this,Ta,new Map)}createProducer(e,r){return u(this,null,function*(){var i;if(!this.sendTransport||this.sendTransport.closed)throw new Error("Send transport is closed");try{const a=yield this.sendTransport.produce(e,x(this,Zd,sT).bind(this));return(i=e.appData)!=null&&i.e2ee&&this.context.getValue("peerSessionStore").emit(b.E2EE_ACTIVE_PRODUCER,a),x(this,el,rT).call(this,a,r),a}catch(a){throw this.logger.error("Failed to create producer",{error:a}),n(this,Xd).producerCreationFailureCount+=1,a}})}closeProducer(e,r){return u(this,null,function*(){var a;const i=this.producers.get(e);if(!i){this.logger.warn(`Producer with ID ${e} was not found`);return}r!=null&&r.stopTrack&&i.track.stop();try{yield this.sendTransport.closeProducer(i),(a=this.context.getValue("modules").e2ee)!=null&&a.enabled&&this.context.getValue("peerSessionStore").emit(b.E2EE_INACTIVE_PRODUCER,i)}catch(o){this.logger.error("Failed to close producer on server",{error:o,producer:i})}})}closeAllProducers(){return Promise.all(Array.from(n(this,Ui).entries()).map(([,e])=>e.close()))}createConsumer(e){return this.createConsumers([e])}createConsumers(e){return u(this,null,function*(){n(this,va)||clearTimeout(n(this,va)),f(this,er,n(this,er).concat(e)),yield x(this,nc,Ju).call(this)})}closeConsumer(e){return this.closeConsumers([e])}closeConsumers(e){return u(this,null,function*(){if(!n(this,Vs))return;const r=e.map(a=>this.consumers.get(a)).filter(a=>a!==void 0);if(r.length===0)return;const{failedConsumers:i}=yield n(this,Vs).close(r);i!=null&&i.length&&this.logger.warn("Failed to close some consumers",{consumerIds:i})})}closeAllConsumers(){return this.closeConsumers(Array.from(n(this,qr).keys()))}switchConsumersToLayer(e,r){return u(this,null,function*(){n(this,Vs).switchConsumersToLayer(e,r)})}}Ui=new WeakMap,qr=new WeakMap,Ta=new WeakMap,ic=new WeakMap,Vs=new WeakMap,Xd=new WeakMap,er=new WeakMap,va=new WeakMap,nc=new WeakSet,Ju=function(){return u(this,null,function*(){if(!this.recvTransport||this.recvTransport.closed)throw new Error("Recv transport is closed");const e=500,r=n(this,er).splice(0,n(this,er).length);try{const i=new Set(Array.from(this.consumers.values()).map(({producerId:d})=>d)),a=r.filter(({producerId:d})=>!this.producers.get(d)&&!i.has(d));if(a.length===0)return;const{consumers:o,failedProducers:c}=yield this.recvTransport.consume(a,x(this,tl,iT).bind(this),n(this,Vs).negotiate.bind(n(this,Vs)));if(o.forEach(x(this,sl,nT).bind(this)),c!=null&&c.length){this.logger.error("Failed to create consumers for producers",{producers:c});const d=c.filter(({errorCode:l,producerId:p})=>l==="not_found_track_error"?(this.logger.error(`Track not found for producer: ${p}. This will not be retried.`),!1):l==="backend_error"?(this.logger.error("Unrecoverable error: backend error"),!1):!0);f(this,er,n(this,er).concat(d)),f(this,va,setTimeout(x(this,nc,Ju).bind(this),e))}}catch(i){if(this.logger.error("failed to consume on transport",{error:i}),i.errorCode==="internal_error"&&i.errorDescription==="Backend error"||i.errorCode==="invalid_session_description"){this.logger.error("Irrecoverable error, closing current recvTransport to create a new one",{transport:this.recvTransport,error:{code:i.errorCode,message:i.errorDescription}});try{this.stopTransports({recv:!0})}catch(a){}yield this.setupTransports({recv:!0})}}})},Zd=new WeakSet,sT=function(e){return n(this,ic).create(e)},el=new WeakSet,rT=function(e,r){e.on("close",(i,a)=>u(this,null,function*(){const{offer:o,reason:c}=i;if(this.logger.info("producer::closing",{debuggingHint:c,producer:G(D({},e),{status:"closing"})}),c!==Cd){const d={producerId:e.id,description:{sdp:o.sdp,type:o.type,target:fr.PUBLISHER}};try{const l=yield this.socketHandler.closeProducer(d),p={sdp:l==null?void 0:l.sdp,type:l==null?void 0:l.type};this.logger.info("producer::closed",{producer:G(D({},e),{status:"closed"})}),a({answer:p})}catch(l){this.logger.error("producer close error",l)}}this.producers.delete(e.id),r()})),e.on("trackended",()=>{this.logger.info("producer::trackended",{producer:G(D({},e),{status:"UNKNOWN"})})}),n(this,Ui).set(e.id,e)},tl=new WeakSet,iT=function(e){return u(this,null,function*(){try{return yield this.recvTransport.canConsume(),yield n(this,Vs).create(e)}catch(r){throw this.logger.error("Error in consume request",{error:r}),r}})},sl=new WeakSet,nT=function(e){e.on("close",r=>u(this,null,function*(){this.logger.debug("consumer closed",{consumer:{closureReason:r,id:e.id,kind:e.kind,appData:e.appData}}),n(this,qr).delete(e.id),this.context.getValue("peerSessionStore").emit(b.CONSUMER_CLOSED,{id:e.id})})),n(this,qr).set(e.id,e),this.producerIdToConsumerIdMap.set(e.producerId,e.id),this.context.getValue("peerSessionStore").emit(b.NEW_CONSUMER,{id:e.id,appData:e.appData,peerId:e.peerId})};var ac,oc,cc,Sa,ya,Ea,dc,lc,Pa,Pt,fs,Ts,$i,Fi,tr,uc,rl,aT,il,oT,nl,cT,al,dT;const ol=class{constructor({initialEnergyThreshold:t=.015,zeroCrossingThreshold:e=20,minVoiceDuration:r=3,hangoverFrames:i=5,noiseAdaptationRate:a=.95,voiceAdaptationRate:o=.99,minEnergyThreshold:c=.005,maxEnergyThreshold:d=.2,energyRatioThreshold:l=1.5,noiseHistorySize:p=50}={}){m(this,rl);m(this,il);m(this,ac,void 0);m(this,oc,void 0);m(this,cc,void 0);m(this,Sa,void 0);m(this,ya,void 0);m(this,Ea,void 0);m(this,dc,void 0);m(this,lc,void 0);m(this,Pa,void 0);m(this,Pt,void 0);m(this,fs,void 0);m(this,Ts,!1);m(this,$i,0);m(this,Fi,0);m(this,tr,[]);m(this,uc,void 0);f(this,Sa,t),f(this,Pt,t),f(this,ac,e),f(this,oc,r),f(this,cc,i),f(this,ya,a),f(this,Ea,o),f(this,dc,c),f(this,lc,d),f(this,Pa,l),f(this,uc,p),f(this,fs,t/2)}get voiceDetected(){return n(this,Ts)}processAudioChunk(t){var o,c;const e=x(o=ol,nl,cT).call(o,t),r=x(c=ol,al,dT).call(c,t);return x(this,rl,aT).call(this,e),e/n(this,fs)>n(this,Pa)&&e>n(this,Pt)&&r>n(this,ac)?(f(this,$i,n(this,$i)+1),f(this,Fi,n(this,cc)),n(this,$i)>=n(this,oc)&&f(this,Ts,!0)):(f(this,$i,0),n(this,Fi)>0?f(this,Fi,n(this,Fi)-1):n(this,Ts)&&f(this,Ts,!1),n(this,Ts)||x(this,il,oT).call(this,e)),{energy:e,isVoice:n(this,Ts)}}reset(){f(this,Ts,!1),f(this,$i,0),f(this,Fi,0),f(this,Pt,n(this,Sa)),f(this,fs,n(this,Sa)/2),f(this,tr,[])}getThresholdInfo(){return{currentEnergyThreshold:n(this,Pt),backgroundNoiseEnergy:n(this,fs),energyRatioThreshold:n(this,Pa)}}};let ao=ol;ac=new WeakMap,oc=new WeakMap,cc=new WeakMap,Sa=new WeakMap,ya=new WeakMap,Ea=new WeakMap,dc=new WeakMap,lc=new WeakMap,Pa=new WeakMap,Pt=new WeakMap,fs=new WeakMap,Ts=new WeakMap,$i=new WeakMap,Fi=new WeakMap,tr=new WeakMap,uc=new WeakMap,rl=new WeakSet,aT=function(t){n(this,Ts)?f(this,Pt,n(this,Ea)*n(this,Pt)+(1-n(this,Ea))*t):f(this,Pt,n(this,ya)*n(this,Pt)+(1-n(this,ya))*n(this,fs)),f(this,Pt,Math.max(n(this,dc),Math.min(n(this,lc),n(this,Pt))))},il=new WeakSet,oT=function(t){if(t<n(this,Pt)*1.2)if(n(this,tr).push(t),n(this,tr).length>n(this,uc)&&n(this,tr).shift(),n(this,tr).length>=10){const e=[...n(this,tr)].sort((i,a)=>i-a),r=Math.floor(e.length/2);f(this,fs,e[r])}else f(this,fs,.95*n(this,fs)+.05*t)},nl=new WeakSet,cT=function(t){return Math.sqrt(t.map(e=>e*e).reduce((e,r)=>e+r)/t.length)},al=new WeakSet,dT=function(t){let e=0;for(let r=1;r<t.length;r+=1)(t[r]>=0&&t[r-1]<0||t[r]<0&&t[r-1]>=0)&&(e+=1);return e},m(ao,nl),m(ao,al);var hc;class ug{constructor(t){h(this,"RNAudioSampleHandler");m(this,hc,void 0);f(this,hc,t);const{RNAudioSampleHandlerImpl:e}=navigator;e==null||e.init().then(r=>{this.RNAudioSampleHandler=r}).catch(r=>{this.logger.error("ReactNativeAudioSampler: Failed to initialize audio sampler",r)})}get logger(){return n(this,hc).getValue("logger")}get samples(){var e;const t=new Float32Array(1024);return(e=this.RNAudioSampleHandler)==null||e.getFloatTimeDomainData(t),t}stop(){var t;(t=this.RNAudioSampleHandler)==null||t.destructor()}}hc=new WeakMap;var pc;class hg{constructor(t){h(this,"audioContext");h(this,"analyser");m(this,pc,void 0);f(this,pc,t),this.audioContext=new AudioContext,this.analyser=this.audioContext.createAnalyser(),this.analyser.fftSize=2048}get logger(){return n(this,pc).getValue("logger")}get samples(){if(this.audioContext.state==="suspended")try{this.audioContext.resume()}catch(e){this.logger.error("AudioContextSampler: Failed to resume audio context",e)}const t=new Float32Array(this.analyser.frequencyBinCount);return this.analyser.getFloatTimeDomainData(t),t}set audioTrack(t){const e=new MediaStream;e.addTrack(t),this.audioContext.createMediaStreamSource(e).connect(this.analyser)}}pc=new WeakMap;class xD{static setInterval(t,e=0,...r){return navigator&&navigator.RNBackgroundTimerImpl?navigator.RNBackgroundTimerImpl.setInterval(t,e,...r):global.setInterval(t,e,...r)}static clearInterval(t){return navigator&&navigator.RNBackgroundTimerImpl?navigator.RNBackgroundTimerImpl.clearInterval(t):global.clearInterval(t)}static setTimeout(t,e=0,...r){return navigator&&navigator.RNBackgroundTimerImpl?navigator.RNBackgroundTimerImpl.setTimeout(t,e,...r):global.setTimeout(t,e,...r)}static clearTimeout(t){return navigator&&navigator.RNBackgroundTimerImpl?navigator.RNBackgroundTimerImpl.clearTimeout(t):global.clearTimeout(t)}}const UD=60,$D=400;var sr,rr,vs,gc,Bi,_a,ir,jr,Ca,nr,ar,Ls,cl,lT,mc,Ku,dl,uT,ll,hT;const To=class{constructor(t,e){m(this,cl);m(this,dl);m(this,sr,void 0);m(this,rr,void 0);m(this,vs,void 0);m(this,gc,void 0);m(this,Bi,void 0);m(this,_a,void 0);m(this,ir,void 0);m(this,jr,void 0);m(this,Ca,void 0);m(this,nr,void 0);m(this,ar,void 0);m(this,Ls,void 0);this.reportRequest=e,f(this,nr,t),f(this,_a,new ao);const{isReactNative:r}=navigator;f(this,ar,r?new ug(n(this,nr)):new hg(n(this,nr))),f(this,Ls,r?xD:Xc)}get logger(){return n(this,nr).getValue("logger")}set producerId(t){f(this,vs,t)}set audioTrack(t){f(this,gc,t),n(this,ar)instanceof hg&&(n(this,ar).audioTrack=t)}start(){this.logger.debug(`AudioActivityReporter: Starting audio activity reporter: ${n(this,vs)}`),n(this,sr)&&n(this,Ls).clearInterval(n(this,sr)),f(this,sr,n(this,Ls).setInterval(()=>u(this,null,function*(){var i;if(!n(this,gc)||!n(this,vs))return;const{energy:t}=x(this,cl,lT).call(this),e=x(i=To,mc,Ku).call(i,t);let r=.9;n(this,Ca)!==e&&n(this,Ca)?r=.9:e?r=.3:r=.5,f(this,Bi,(n(this,Bi)||0)*(1-r)+t*r)}),UD)),n(this,rr)&&n(this,Ls).clearInterval(n(this,rr)),f(this,rr,n(this,Ls).setInterval(x(this,dl,uT).bind(this),$D))}stop(){try{this.logger.debug(`AudioActivityReporter: Stopping audio activity reporter: ${n(this,vs)}`),n(this,sr)&&(n(this,Ls).clearInterval(n(this,sr)),f(this,sr,void 0)),n(this,rr)&&(n(this,Ls).clearInterval(n(this,rr)),f(this,rr,void 0))}catch(t){}n(this,_a).reset(),n(this,ar)instanceof ug&&n(this,ar).stop()}};let oo=To;sr=new WeakMap,rr=new WeakMap,vs=new WeakMap,gc=new WeakMap,Bi=new WeakMap,_a=new WeakMap,ir=new WeakMap,jr=new WeakMap,Ca=new WeakMap,nr=new WeakMap,ar=new WeakMap,Ls=new WeakMap,cl=new WeakSet,lT=function(){var o;const{samples:t}=n(this,ar),{energy:e,isVoice:r}=n(this,_a).processAudioChunk(t),i=x(o=To,ll,hT).call(o,e);return n(this,nr).getValue("flagsmith").hasFeature(Z.ENABLE_AUDIO_ACTIVITY_DEBUG_LOGS)&&this.logger.debug(`AudioActivityReporter: producer: ${n(this,vs)}, energy: ${n(this,Bi)},
|
|
9
|
-
slogScale: ${i}, isVoice: ${r}, minEnergy: ${n(this,ir)},
|
|
10
|
-
maxEnergy: ${n(this,jr)}`),i===-1/0||e<1e-6?{energy:0,isVoice:!1}:((!n(this,ir)||i<n(this,ir))&&f(this,ir,i),(!n(this,jr)||i>n(this,jr))&&f(this,jr,i),{energy:(i-n(this,ir))/(n(this,jr)-n(this,ir))*10||0,isVoice:r})},mc=new WeakSet,Ku=function(t){return t<5},dl=new WeakSet,uT=function(t=n(this,Bi)){var r;if(!n(this,vs)||!t){n(this,nr).getValue("flagsmith").hasFeature(Z.ENABLE_AUDIO_ACTIVITY_DEBUG_LOGS)&&this.logger.debug(`AudioActivityReporter: No producerId or energy to report: ${n(this,vs)}`);return}const e={producerId:n(this,vs),energy:Math.round(t),silent:x(r=To,mc,Ku).call(r,t)};f(this,Ca,e.silent),this.reportRequest(e)},ll=new WeakSet,hT=function(t){const e=Math.log10(t);return Math.round(e)},m(oo,mc),m(oo,ll);const FD=(s=!1)=>{if("MediaStreamTrackGenerator"in window&&"AudioData"in window)try{const e=new window.MediaStreamTrackGenerator({kind:"audio"}),r=e.writable.getWriter(),i=48e3,a=128,o=1;let c=0,d=null;const l=()=>u(exports,null,function*(){try{const T=new Float32Array(a*o),v=new window.AudioData({format:"f32",sampleRate:i,numberOfFrames:a,numberOfChannels:o,timestamp:c,data:T});c+=a/i*1e6,yield r.ready,yield r.write(v)}catch(T){d&&clearInterval(d),r.releaseLock(),e.writable.abort()}});d=window.setInterval(l,100);const g=new MediaStream([e]).getAudioTracks()[0];return g.addEventListener("ended",()=>{d&&clearInterval(d),r.releaseLock(),e.writable.abort()}),Object.assign(g,{fakeTracks:"fakeTracks:fakeAudioTrack"}),g.enabled=s,g}catch(e){}const t=window.AudioContext||window.webkitAudioContext;if(t)try{const e=new t;if(!e||e.state!=="running"||!e.destination)return;const r=e.createOscillator();r.frequency.value=0,r.type="sine";const i=e.createGain();i.gain.value=0,r.connect(i);const a=e.createMediaStreamDestination();i.connect(a),r.start();const o=a.stream.getAudioTracks()[0];return o?(Object.assign(o,{fakeTracks:"fakeTracks:fakeAudioTrack"}),o.enabled=s,o):void 0}catch(e){return}},BD=(s=!1)=>{var a,o;const t=new MediaStream().getVideoTracks()[0],e=document.createElement("canvas");e.height=(a=t==null?void 0:t.getSettings().height)!=null?a:720,e.width=(o=t==null?void 0:t.getSettings().width)!=null?o:1280;const r=e.getContext("2d");r.fillStyle="black",r.fillRect(0,0,e.width,e.height),setInterval(()=>{r.fillStyle="black",r.fillRect(0,0,e.width,e.height)},1e3);const i=e.captureStream().getVideoTracks()[0];return Object.assign(i,{fakeTracks:"fakeTracks:fakeVideoTrack"}),i.enabled=s,i};var HD=Object.defineProperty,qD=Object.getOwnPropertyDescriptor,de=(s,t,e,r)=>{for(var i=r>1?void 0:r?qD(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&HD(t,e,i),i};const kt=["video/VP9","video/VP8"];var fc,Tc,at,W,wa,mt,Hi,qi,ji,vc,ts,or,Sc,Gi,Wi,ft,_t,Gr,mn,ul,gT,hl,mT,pl,fT,yc,zu,gl,du,TT,ml,vT,fl,ST,Tl,yT,Xe,lt,Ji,co,vl,ET,Sl,PT,yl,_T;const pT=(du=class{constructor(s,t){m(this,Gr);m(this,ul);m(this,hl);m(this,pl);m(this,yc);m(this,ml);m(this,fl);m(this,Tl);m(this,Xe);m(this,Ji);m(this,vl);m(this,Sl);m(this,yl);h(this,"context");h(this,"authToken");h(this,"e2ee");m(this,fc,void 0);m(this,Tc,void 0);m(this,at,void 0);m(this,W,void 0);m(this,wa,void 0);m(this,mt,void 0);m(this,Hi,void 0);m(this,qi,void 0);m(this,ji,void 0);m(this,vc,void 0);m(this,ts,null);m(this,or,void 0);m(this,Sc,void 0);m(this,Gi,void 0);m(this,Wi,void 0);m(this,ft,void 0);m(this,_t,void 0);var r,i;this.context=s;const{socket:e}=t;this.mediaJoined=!1,f(this,Gi,new Map([["video/VP9",new Set],["video/VP8",new Set]])),f(this,Wi,new Map([["video/VP9",new Set],["video/VP8",new Set]])),f(this,at,e),f(this,Hi,!1),f(this,W,new LD(s,e)),f(this,mt,n(this,W).events),f(this,or,new Set),f(this,ft,new Map),f(this,qi,!1),f(this,ji,new Fu(s.getValue("logger"))),f(this,_t,new oo(this.context,n(this,W).socketHandler.audioActivity.bind(n(this,W).socketHandler))),this.e2ee=(i=(r=s.getValue("modules").e2ee)==null?void 0:r.enabled)!=null?i:!1,this.handleSocketEvents(),this.handleCallstatsEvents(),f(this,vc,Eh(()=>u(this,null,function*(){if(!n(this,Gr,mn).mediaJoinAttempted)return;const{roomJoined:a}=yield this.joinRoom(n(this,Tc),n(this,fc),!0,!0);a&&(this.context.getValue("peerSessionStore").emit(b.RESET_PRODUCER_STATE),this.context.getValue("peerSessionStore").emit(b.ROOM_NODE_RECONNECTED))}),5e3,{leading:!0,maxWait:1e3}))}get peerId(){return this.context.getValue("peerId")}get telemetry(){return this.context.getValue("telemetry")}get logger(){return this.context.getValue("logger")}get mediaJoined(){return n(this,Gr,mn).mediaJoined}set mediaJoined(s){n(this,Gr,mn).mediaJoined=s}reset(){n(this,W).closeAllProducers(),n(this,W).closeAllConsumers(),n(this,ft).clear(),n(this,or).clear(),f(this,ts,null),n(this,ji).stop(),n(this,W).stopAllTransports(),n(this,W).reset(),f(this,ji,new Fu)}joinRoom(a,o){return u(this,arguments,function*(s,t,e=!1,r=!1,i={}){n(this,Gr,mn).mediaJoinAttempted=!0,f(this,Hi,!0),e&&this.reset();try{return yield n(this,ji).push(()=>x(this,ul,gT).call(this,s,t,r,i),"joinRoom")}catch(c){return this.logger.error("Error in room joining process",{error:c}),this.context.getValue("peerSessionStore").emit(b.ROOM_NODE_FAILED),{roomJoined:!1}}})}initializeConnection(i,a){return u(this,arguments,function*(s,t,e=!1,r={}){return n(this,ts)?n(this,ts):(f(this,ts,(()=>u(this,null,function*(){try{yield x(this,yc,zu).call(this,s,t,e,r)}catch(o){throw f(this,ts,null),o}}))()),n(this,ts))})}getConsumers(){return n(this,W).consumers}getProducers(){return n(this,W).producers}leaveRoom(){return u(this,null,function*(){n(this,W).stopAllTransports(),f(this,qi,!1),n(this,Gr,mn).mediaJoinAttempted=!1;const s={closeRoom:!1};n(this,at).sendMessagePromise(n(this,mt).leaveRoom,Zw.toBinary(s)).then(e=>{var r;(r=BR.fromBinary(e.payload))!=null&&r.closed&&this.logger.warn("Weird state on peer closed and should not happen")}).catch(e=>{this.logger.error("error on sending leave room request",{error:e})}),this.context.getValue("callstats").callEnded(),this.context.getValue("telemetry").destruct()})}activatePeers(s){return u(this,null,function*(){return this.createConsumers(s)})}createConsumers(s){return u(this,null,function*(){return s.length===0?Promise.resolve():n(this,W).createConsumers(s)})}closeConsumers(s){return u(this,null,function*(){if(!s.length)return;const t=s.reduce((e,r)=>{const i=n(this,W).producerIdToConsumerIdMap.get(r.producerId);return i?(e.push(i),e):(this.logger.warn(`consumer not found in close consumers: ${r.producerId}`),e)},[]);yield n(this,W).closeConsumers(t)})}_shareWebcam(s,t){return u(this,null,function*(){var g,T;const e=t==="video/VP9"?ue.WEBCAM:ue.WEBCAM_BACKUP,r=x(this,Xe,lt).call(this,e);if(r){const v=yield r;if(n(this,W).producers.has(v)){const E=n(this,W).producers.get(v);if(!E.closed)return yield E.replaceTrack({track:s}),yield this.resumeWebcam(e),s;yield this.disableWebcam(t)}return this._shareWebcam(s,t)}const i=[t].concat(kt.filter(v=>v!==t)),a=x(this,yl,_T).call(this,s,i),o=Ia(this.context,"disableSimulcast"),c=(T=(g=this.context)==null?void 0:g.getValue("overrides"))==null?void 0:T.simulcastConfig;!(o||c&&c.disable)&&this.context.getValue("flagsmith").hasFeature(Z.ENABLE_CF_SIMULCAST)?(this.logger.info("Simulcast enabled for SFU: CF"),a.encodings=k0(this.context,s)):this.logger.info("Simulcast disabled for webcam producer, SFU: CF"),this.context.getValue("flagsmith").hasFeature(Z.TRACK_HINT)&&(a.track.contentHint=this.context.getValue("flagsmith").getValue(Z.TRACK_HINT));const l=()=>{this.logger.info("Disabling video due to the producer closure"),n(this,ft).delete(e)},p=n(this,W).createProducer(a,l);return x(this,Ji,co).call(this,e,p.then(v=>v.id)),p.then(v=>v.track)})}shareWebcam(s){return u(this,null,function*(){var r;if(s===void 0)return null;const t=(r=this.context.getValue("flagsmith").getValue(Z.FORCE_VIDEO_CODEC))==null?void 0:r.toString();if(t)return this.logger.debug(`Calling _shareWebcam with forced video codec: ${t}`),this._shareWebcam(s,t);const e=kt.filter(i=>{var a,o;return((o=(a=n(this,wa).sender)==null?void 0:a.video)==null?void 0:o.codecs.findIndex(c=>c.mimeType===i))>=0&&n(this,Wi).get(i).size>0});return e.length===0&&e.push(kt[0]),yield Promise.all(e.map(i=>(this.logger.debug(`Calling _shareWebcam with video codec: ${i}`),this._shareWebcam(s,i)))),s})}shareScreen(s){return u(this,null,function*(){const{video:t,audio:e}=s;if(t===void 0)return;const r={track:t,codecOptions:[{name:"VP8"}],appData:{screenShare:!0,e2ee:this.e2ee,supportsRemoteControl:Se.isElectron()},stopTracks:!1},i=()=>{this.logger.info("Disabling screenShare due to the producer closure"),n(this,ft).delete(ue.SCREENSHARE_VIDEO),n(this,ft).delete(ue.SCREENSHARE_AUDIO)},a=n(this,W).createProducer(r,i);x(this,Ji,co).call(this,ue.SCREENSHARE_VIDEO,a.then(c=>c.id));let o;if(e){const c={track:e,codecOptions:[{name:"opus"}],appData:{screenShare:!0,e2ee:this.e2ee,supportsRemoteControl:Se.isElectron()},stopTracks:!1,zeroRtpOnPause:!1},d=()=>{};o=n(this,W).createProducer(c,d),x(this,Ji,co).call(this,ue.SCREENSHARE_AUDIO,o.then(l=>l.id))}yield Promise.all([a,o||Promise.resolve()]),this.context.getValue("callstats").screenShareStart()})}shareMic(s){return u(this,null,function*(){try{if(s===void 0)throw new wt("track undefined");const t=x(this,Xe,lt).call(this,ue.MIC);if(t){const a=yield t;if(n(this,W).producers.has(a)){const o=n(this,W).producers.get(a);if(!o.closed){yield o.replaceTrack({track:s}),yield this.resumeMic(),n(this,_t)&&(n(this,_t).audioTrack=s,n(this,_t).producerId=a,n(this,_t).start());return}yield n(this,W).closeProducer(a,{stopTrack:!1})}yield this.shareMic(s);return}const e=x(this,Sl,PT).call(this,s),r=()=>{n(this,ft).delete(ue.MIC)},i=n(this,W).createProducer(e,r);x(this,Ji,co).call(this,ue.MIC,i.then(a=>a.id)),yield i.then(a=>{n(this,_t)&&(n(this,_t).audioTrack=a.track,n(this,_t).producerId=a.id,n(this,_t).start())})}catch(t){throw new A(t)}})}pauseMic(){return u(this,null,function*(){var r;const s=yield x(this,Xe,lt).call(this,ue.MIC),t=n(this,W).producers.get(s);if(!t){this.logger.error("pauseMic::could_not_find_mic_producer");return}if(t.paused){this.logger.info("pauseMic::mic_producer_already_paused");return}t.pause(),(r=n(this,_t))==null||r.stop();const e={producerId:t.id,pause:!0};n(this,at).sendMessage(n(this,mt).toggleProducer,Gc.toBinary(e))})}pauseWebcam(){return u(this,null,function*(){const s=yield x(this,Xe,lt).call(this,ue.WEBCAM),t=yield x(this,Xe,lt).call(this,ue.WEBCAM_BACKUP),e=n(this,W).producers.get(s),r=n(this,W).producers.get(t);if(!e&&!r){this.logger.error("pauseWebcam::could_not_find_webcam_producer");return}const i=a=>{const o={producerId:a.id,pause:!0};n(this,at).sendMessage(n(this,mt).toggleProducer,Gc.toBinary(o))};e&&(e.pause(),i(e)),r&&(r.pause(),i(r))})}resumeMic(){return u(this,null,function*(){const s=yield x(this,Xe,lt).call(this,ue.MIC),t=n(this,W).producers.get(s);if(!t){this.logger.error("resumeMic::could_not_find_mic_producer");return}if(!t.pause){this.logger.info("resumeMic::mic_producer_already_resumed");return}t.resume(),t.appData.e2ee&&this.context.getValue("peerSessionStore").emit(b.E2EE_ACTIVE_PRODUCER,t);const e={producerId:t.id,pause:!1};n(this,at).sendMessage(n(this,mt).toggleProducer,Gc.toBinary(e))})}resumeWebcam(){return u(this,arguments,function*(s=ue.WEBCAM){const t=yield x(this,Xe,lt).call(this,s),e=n(this,W).producers.get(t);if(!e){this.logger.error("resumeWebcam::could_not_find_webcam_producer");return}if(!e.paused){this.logger.info("resumeWebcam::webcam_producer_already_resumed");return}e.resume(),e.appData.e2ee&&this.context.getValue("peerSessionStore").emit(b.E2EE_ACTIVE_PRODUCER,e);const r={producerId:e.id,pause:!1};n(this,at).sendMessage(n(this,mt).toggleProducer,Gc.toBinary(r))})}disableWebcam(s){return u(this,null,function*(){const t=s==="video/VP9"?ue.WEBCAM:ue.WEBCAM_BACKUP,e=yield x(this,Xe,lt).call(this,t);x(this,vl,ET).call(this,t),e&&(yield n(this,W).closeProducer(e))})}disableMic(){return u(this,null,function*(){var t;const s=yield x(this,Xe,lt).call(this,ue.MIC);s&&(yield n(this,W).closeProducer(s)),(t=n(this,_t))==null||t.stop(),n(this,ft).delete(ue.MIC)})}disableScreenShare(){return u(this,null,function*(){this.logger.info("screen_sharing_stopped"),this.context.getValue("callstats").screenShareStop();const s=yield x(this,Xe,lt).call(this,ue.SCREENSHARE_VIDEO),t=yield x(this,Xe,lt).call(this,ue.SCREENSHARE_AUDIO);s&&(yield n(this,W).closeProducer(s)),t&&(yield n(this,W).closeProducer(t)),n(this,or).clear(),n(this,ft).delete(ue.SCREENSHARE_VIDEO),n(this,ft).delete(ue.SCREENSHARE_AUDIO)})}muteSelf(){return u(this,null,function*(){this.pauseMic()})}resetVideoProducers(s,t){return u(this,null,function*(){if(s){const e=yield x(this,Xe,lt).call(this,ue.WEBCAM),r=yield x(this,Xe,lt).call(this,ue.WEBCAM_BACKUP);yield n(this,W).closeProducer(e,{stopTrack:!1}),yield n(this,W).closeProducer(r,{stopTrack:!1}),this.shareWebcam(s)}if(t){const e=yield x(this,Xe,lt).call(this,ue.SCREENSHARE_VIDEO);yield n(this,W).closeProducer(e,{stopTrack:!1}),this.shareScreen({video:t})}})}changeDisplayName(s,t){return u(this,null,function*(){const e={displayName:s,participantId:t!=null?t:this.peerId};if(!(yield n(this,W).socketHandler.changeDisplayName(e)))throw new Error("failed to change display name!")})}kick(s){const t={peerIds:[s]};n(this,W).socketHandler.kickPeer(t)}kickAll(){n(this,W).socketHandler.kickAll()}muteAll(s){return u(this,null,function*(){if(!(yield n(this,W).socketHandler.hostControlForAll("audio")))throw new Error("failed to mute all participant")})}muteAllVideo(){return u(this,null,function*(){if(!(yield n(this,W).socketHandler.hostControlForAll("video")))throw new Error("failed to mute all video participant")})}disableAudio(s){return u(this,null,function*(){if(!(yield n(this,W).socketHandler.hostControlForPeer(s,"audio")))throw new Error("failed to mute given participant")})}disableVideo(s){return u(this,null,function*(){if(!(yield n(this,W).socketHandler.hostControlForPeer(s,"video")))throw new Error("failed to mute video of given participant")})}pinPeer(s){return u(this,null,function*(){const t={participantId:s!=null?s:""};try{yield n(this,at).sendMessagePromise(n(this,mt).globalPinPeer,pR.toBinary(t))}catch(e){this.logger.error("Error in pinning peer:",{error:e})}})}validateScreenShare(s){return this.peerId===s.peerId&&n(this,W).producers.get(s.producerId)&&n(this,or).add(s.consumerPeerId),n(this,or).size}switchConsumersToLayer(s,t){return u(this,null,function*(){const e=s.map(r=>this.getConsumers().get(r));n(this,W).switchConsumersToLayer(e,t)})}handleSocketEvents(){return u(this,null,function*(){n(this,at).on(n(this,mt).peerProducerCreateBroadcast,({payload:s})=>{var t,e;if(this.mediaJoined)try{const{participantId:r,producerState:i}=Tb.fromBinary(s);if(r===this.peerId)return;if(i!=null&&i.mimeType||(i.mimeType=i.kind===xs.AUDIO?"audio/opus":"video/VP8"),i.kind===xs.VIDEO&&!i.screenShare&&((e=(t=n(this,wa).receiver)==null?void 0:t.video)==null?void 0:e.codecs.findIndex(a=>a.mimeType===kt[0]))>=0&&n(this,Gi).get(kt[0]).has(r)&&i.mimeType!==kt[0]){this.logger.warn(`Ignoring producer: ${i.producerId}`);return}this.logger.info(`producer created broadcast: ${r}, producer state: ${i}`),this.context.getValue("peerSessionStore").emit(b.NEW_PRODUCER,{peerId:r,producer:G(D({},i),{kind:i.kind===xs.AUDIO?"audio":"video",producingPeerId:r})})}catch(r){this.logger.error("error in peer-producer-create-broadcast",{error:r})}}),n(this,at).on(n(this,mt).peerProducerToggleBroadcast,({payload:s})=>{if(this.mediaJoined)try{const{participantId:t,initiatorParticipantId:e,producerState:{kind:r,pause:i,producerId:a,screenShare:o}}=$p.fromBinary(s);if(o)return;const c=r===xs.AUDIO?"audio":"video";if(this.logger.info(`producer toggle broadcast: ${t}, producerId: ${a}, kind:${c}, paused:${i} payload: ${JSON.stringify($p.fromBinary(s))}`),t===this.peerId&&e!==this.peerId&&i&&this.context.getValue("peerSessionStore").emit(c==="audio"?b.MUTE_SELF:b.MUTE_SELF_VIDEO),t===this.peerId)return;this.context.getValue("peerSessionStore").emit(b.PRODUCER_TOGGLE,{peerId:t,producerId:a,paused:i,kind:c}),Array.from(this.getConsumers().values()).filter(l=>l.producerId===a).forEach(l=>{l.kind==="video"&&i||l.paused!==i&&(this.logger.debug(`consumer state mismatched for ${l.id}. updating consumer pause state ${l.paused} to ${i}`),i?(l.pause(),this.context.getValue("peerSessionStore").emit(b.CONSUMER_PAUSED,{id:l.id})):(l.resume(),this.context.getValue("peerSessionStore").emit(b.CONSUMER_RESUMED,{id:l.id})))})}catch(t){this.logger.error("error in producer toggle broadcast handler",{error:t})}}),n(this,at).on(n(this,mt).peerLeaveBroadcast,({payload:s})=>{if(this.mediaJoined)try{const{participantId:t}=Eu.fromBinary(s);if(t===this.peerId)return;this.logger.info(`peer left broadcast:${t}`),n(this,or).delete(t),n(this,W).consumers.forEach(e=>{e.peerId===t&&e.close()}),this.context.getValue("peerSessionStore").emit(b.PEER_CLOSED,{id:t})}catch(t){this.logger.error("error in peer left broadcast",{error:t})}}),n(this,at).on(n(this,mt).peerProducerCloseBroadcast,({payload:s})=>{if(this.mediaJoined)try{const{participantId:t,producerState:{producerId:e}}=yb.fromBinary(s);if(t===this.peerId)return;this.logger.info(`producer closed broadcast:${t}`),this.context.getValue("peerSessionStore").emit(b.PRODUCER_CLOSED,{peerId:t,producerId:e});const r=n(this,W).producerIdToConsumerIdMap.get(e);if(!r){this.logger.warn(`no consumer found for producer:${e}`);return}this.logger.info(`closing consumer ${r}, producer id: ${e}`),n(this,W).closeConsumer(r).then(()=>{this.logger.info(`closed consumer: ${r}`),n(this,W).producerIdToConsumerIdMap.delete(e),this.context.getValue("peerSessionStore").emit(b.CONSUMER_CLOSED,{id:r})}).catch(i=>{this.logger.error("error closing consumer",{error:i})})}catch(t){this.logger.error("error on producer close broadcast",{error:t})}}),n(this,at).on(n(this,mt).mediaRoomTerminationBroadcastResponse,()=>{!this.mediaJoined&&!n(this,Hi)&&!n(this,qi)||(this.logger.warn("media hub termination broadcast received, rejoining room"),this.context.getValue("peerSessionStore").emit(b.ROOM_NODE_DISCONNECTED),n(this,vc).call(this))})})}handleCallstatsEvents(){this.context.getValue("callstats").onConsumerScore(s=>{s.forEach((t,e)=>{const r=n(this,W).consumers.get(e);r&&this.context.getValue("peerSessionStore").emit(b.CONSUMER_SCORE_UPDATE,{id:e,kind:r.kind,peerId:r.peerId,score:t.score,scoreStats:t})})}),this.context.getValue("callstats").onProducerScore(s=>{s.forEach((t,e)=>{const r=Array.from(n(this,W).producers.values()).find(i=>i.id===e);r&&this.context.getValue("peerSessionStore").emit(b.PRODUCER_SCORE_UPDATE,{id:e,kind:r.kind,appData:r.appData,score:t.score,scoreStats:t})})})}handlePeerCapabilities(s,t){var e,r,i,a;for(let o=0;o<=kt.length;o+=1){const c=kt[o];if(((r=(e=t==null?void 0:t.receiver)==null?void 0:e.video)==null?void 0:r.codecs.findIndex(d=>d.mimeType===c))>=0||o===kt.length-1){n(this,Wi).get(c).add(s);break}}for(let o=0;o<=kt.length;o+=1){const c=kt[o];if(((a=(i=t==null?void 0:t.sender)==null?void 0:i.video)==null?void 0:a.codecs.findIndex(d=>d.mimeType===c))>=0||o===kt.length-1){n(this,Gi).get(c).add(s);break}}}handlePeerLeaving(s){this.context.getValue("flagsmith").hasFeature(Z.FORCE_VIDEO_CODEC)||(n(this,Gi).forEach(t=>t.delete(s)),n(this,Wi).forEach((t,e)=>{t.delete(s),!(t.size!==0||e===kt[0])&&this.disableWebcam(e)}))}},fc=new WeakMap,Tc=new WeakMap,at=new WeakMap,W=new WeakMap,wa=new WeakMap,mt=new WeakMap,Hi=new WeakMap,qi=new WeakMap,ji=new WeakMap,vc=new WeakMap,ts=new WeakMap,or=new WeakMap,Sc=new WeakMap,Gi=new WeakMap,Wi=new WeakMap,ft=new WeakMap,_t=new WeakMap,Gr=new WeakSet,mn=function(){return this.context.getValue("connectionHandler")},ul=new WeakSet,gT=function(s,t,e,r){return u(this,null,function*(){f(this,Tc,s);try{return n(this,ts)?yield n(this,ts):yield x(this,yc,zu).call(this,s,t,e,r),x(this,pl,fT).call(this,t),{roomJoined:yield x(this,hl,mT).call(this)}}catch(i){return this.logger.error("Failed to complete room join",{error:i}),{roomJoined:!1}}finally{f(this,ts,null)}})},hl=new WeakSet,mT=function(){return u(this,null,function*(){try{this.mediaJoined=!0;const{roomState:s}=yield n(this,W).socketHandler.notifySelfJoinComplete();return f(this,fc,s.roomUuid),f(this,qi,!0),f(this,Hi,!1),!0}catch(s){return this.logger.error("Error completing room join",{error:s}),this.mediaJoined=!1,!1}})},pl=new WeakSet,fT=function(s){navigator.product!=="ReactNative"&&setTimeout(()=>{try{const e={userId:this.context.getValue("userId"),peerId:this.peerId,roomUUID:s,roomViewType:"groupCall",deviceInfo:G(D({},Se.getDeviceInfo()),{userAgent:navigator.userAgent,memory:navigator.deviceMemory,cpus:navigator.hardwareConcurrency}),sdkName:this.context.getValue("sdkName"),sdkVersion:this.context.getValue("sdkVersion"),metaData:{},permissions:{}};this.context.getValue("callstats").roomJoined(e)}catch(t){this.logger.error("Error reporting room joined analytics",{error:t})}},0)},yc=new WeakSet,zu=function(s,t,e,r){return u(this,null,function*(){var i,a;try{(a=n(this,Sc))!=null||f(this,Sc,x(i=pT,gl,TT).call(i));const o=x(this,ml,vT).call(this);yield x(this,fl,ST).call(this,s,t,e,o),yield n(this,W).setupTransports({send:!0,recv:!0}),yield x(this,Tl,yT).call(this,r)}catch(o){throw this.logger.error("Failed to initialize connection",{error:o}),o}})},gl=new WeakSet,TT=function(){const{ipInfo:s}=ot();if(!(s!=null&&s.loc))return;const[t,e]=s.loc.split(",").map(parseFloat);return{latitude:t,longitude:e}},ml=new WeakSet,vT=function(){var e;const s=(e=this.context.getValue("flagsmith").getValue(Z.FORCE_VIDEO_CODEC))==null?void 0:e.toString(),t=CD(s);return f(this,wa,t),t},fl=new WeakSet,ST=function(s,t,e,r){return u(this,null,function*(){yield Wf((i,a)=>u(this,null,function*(){if(!n(this,at).isConnected){a(new Error("Socket is not connected"));return}i>0&&this.logger.warn("Retry: send joinRoom message",{debuggingHint:`Retry attempt ${i}`});try{yield n(this,W).socketHandler.joinRoom(t,s,r,e,n(this,Sc))}catch(o){throw this.logger.error("Failed to send joinRoom message after retries",{error:o}),o}}),{delayTime:1e3,strategy:"exponential",maxRetryCount:1/0})})},Tl=new WeakSet,yT=function(s){return u(this,null,function*(){if(!(!this.context.getValue("flagsmith").hasFeature(Z.PRECREATE_PRODUCERS)||!s))try{const e=[];if(s.canProduceVideo===H.Allowed&&e.push(this.shareWebcam(BD(!1))),s.canProduceAudio===H.Allowed){const r=FD(!1);r&&e.push(this.shareMic(r))}e.length>0&&(yield Promise.all(e))}catch(e){this.logger.warn("Failed to precreate producers",{error:e})}})},Xe=new WeakSet,lt=function(s){return n(this,ft).get(s)},Ji=new WeakSet,co=function(s,t){return n(this,ft).set(s,t)},vl=new WeakSet,ET=function(s){return n(this,ft).delete(s)},Sl=new WeakSet,PT=function(s){return{track:s,encodings:[{priority:"high"}],codecOptions:[{name:"opus"}],appData:{e2ee:this.e2ee},stopTracks:!1,zeroRtpOnPause:!1}},yl=new WeakSet,_T=function(s,t){return{track:s,codecOptions:t?t.map(e=>({name:e.split("/")[1]})):[{name:"VP8"}],appData:{screenShare:!1,e2ee:this.e2ee},stopTracks:!1}},m(du,gl),du);let ae=pT;de([P.trace("MediaNodeClient.reset",{country:P.location.country})],ae.prototype,"reset",1);de([P.trace("MediaNodeClient.joinRoom")],ae.prototype,"joinRoom",1);de([P.trace("MediaNodeClient.leaveRoom")],ae.prototype,"leaveRoom",1);de([P.trace("MediaNodeClient.activatePeers")],ae.prototype,"activatePeers",1);de([P.trace("MediaNodeClient.createConsumers")],ae.prototype,"createConsumers",1);de([P.trace("MediaNodeClient.closeConsumers")],ae.prototype,"closeConsumers",1);de([P.trace("MediaNodeClient._shareWebcam")],ae.prototype,"_shareWebcam",1);de([P.trace("MediaNodeClient.shareWebcam")],ae.prototype,"shareWebcam",1);de([P.trace("MediaNodeClient.shareScreen")],ae.prototype,"shareScreen",1);de([P.trace("MediaNodeClient.shareMic")],ae.prototype,"shareMic",1);de([P.trace("MediaNodeClient.pauseMic")],ae.prototype,"pauseMic",1);de([P.trace("MediaNodeClient.pauseWebcam")],ae.prototype,"pauseWebcam",1);de([P.trace("MediaNodeClient.resumeMic")],ae.prototype,"resumeMic",1);de([P.trace("MediaNodeClient.resumeWebcam")],ae.prototype,"resumeWebcam",1);de([P.trace("MediaNodeClient.disableWebcam")],ae.prototype,"disableWebcam",1);de([P.trace("MediaNodeClient.disableMic")],ae.prototype,"disableMic",1);de([P.trace("MediaNodeClient.disableScreenShare")],ae.prototype,"disableScreenShare",1);de([P.trace("MediaNodeClient.muteSelf")],ae.prototype,"muteSelf",1);de([P.trace("MediaNodeClient.resetVideoProducers")],ae.prototype,"resetVideoProducers",1);de([P.trace("MediaNodeClient.changeDisplayName")],ae.prototype,"changeDisplayName",1);de([P.trace("MediaNodeClient.kickPeer")],ae.prototype,"kick",1);de([P.trace("MediaNodeClient.kickAllPeers")],ae.prototype,"kickAll",1);de([P.trace("MediaNodeClient.muteAll")],ae.prototype,"muteAll",1);de([P.trace("MediaNodeClient.muteAllVideo")],ae.prototype,"muteAllVideo",1);de([P.trace("MediaNodeClient.disableAudio")],ae.prototype,"disableAudio",1);de([P.trace("MediaNodeClient.disableVideo")],ae.prototype,"disableVideo",1);de([P.trace("MediaNodeClient.pinPeer")],ae.prototype,"pinPeer",1);de([P.trace("MediaNodeClient.validateScreenShare")],ae.prototype,"validateScreenShare",1);function CT(s,t){const e=s.getValue("roomNodeClient");if(e){if(e)return e;throw new Error("Room node client already set up.")}const r=new ae(s,t);return s.setValue("roomNodeClient",r),r}function wT(s){const t=s.getValue("roomNodeClient");try{t==null||t.leaveRoom()}catch(e){s.getValue("logger").error("roomNodeClient::cleanupRoomNodeClient")}s.setValue("roomNodeClient",void 0)}var jD=Object.defineProperty,GD=Object.getOwnPropertyDescriptor,ln=(s,t,e,r)=>{for(var i=r>1?void 0:r?GD(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&jD(t,e,i),i},Ki,Ss,ee,Tt,It,Vg;const RT=(Vg=class{constructor(s,t,e,r){m(this,Tt);h(this,"self");h(this,"authToken");m(this,Ki,void 0);h(this,"viewType");m(this,Ss,void 0);m(this,ee,void 0);const{socket:i}=e,a=s.getValue("authToken");this.self=t,f(this,ee,s),this.viewType=r,this.authToken=a,f(this,Ki,i),f(this,Ss,e),this.setupEvents()}get peerId(){return n(this,ee).getValue("peerId")}get telemetry(){return n(this,ee).getValue("telemetry")}get logger(){return n(this,ee).getValue("logger")}get mediaJoined(){return n(this,ee).getValue("connectionHandler").mediaJoined}static init(s,t,e,r,i){return u(this,null,function*(){const a=ot(),o=s.getValue("peerId"),c=!!s.getValue("cachedUserDetails"),d=yield ze.__init__(s,e,r,i,i.name,c);s.setValue("self",d);const l=s.getValue("logger");if(navigator.product!=="ReactNative"){const p=!s.getValue("flagsmith").hasFeature(Z.PRECALL_BANDWIDTH_TEST);setTimeout(()=>u(this,null,function*(){const g=yield d.getAllDevices();l.info("populated_full_device_list",{devices:JSON.stringify(g)}),s.getValue("callstats").devices("AUDIO",g==null?void 0:g.filter(T=>T.kind==="audioinput")),s.getValue("callstats").devices("VIDEO",g==null?void 0:g.filter(T=>T.kind==="videoinput")),s.getValue("callstats").devices("SPEAKER",g==null?void 0:g.filter(T=>T.kind==="audiooutput")),l.info("Callstats:: initializing");try{yield s.getValue("callstats").initialize({peerId:o,engineName:Se.getDeviceInfo().engineName,env:s.getValue("env"),iceServers:yield a.getICEServers(),apiBase:s.getValue("apiBase"),flags:s.getValue("flagsmith").getAllFlags(),logger:l,apiHostnames:tf(s),skipConnectivityChecks:p}),l.info("Callstats:: initialized")}catch(T){l.error("Callstats:: initialization failed",{error:T})}}),0)}else l.info("Callstats:: Skipped initialization due to navigator product being ReactNative.");return new RT(s,d,t,i.viewType)})}shareMediaTracks(){return u(this,null,function*(){var c;const{audioTrack:s,videoTrack:t,permissions:e,audioEnabled:r,videoEnabled:i,screenShareEnabled:a,screenShareTracks:o}=this.self;if(e.canProduceAudio===H.Allowed&&r)try{yield n(this,Tt,It).shareMic(s),this.self.audioEnabled||n(this,Tt,It).pauseMic()}catch(d){this.self.disableAudio()}if(e.canProduceVideo===H.Allowed&&i)try{const d=yield n(this,Tt,It).shareWebcam(t);d&&d.id!==t.id&&n(this,ee).getValue("flagsmith").hasFeature(Z.EXP_RESHARE)&&(yield n(this,Tt,It).shareWebcam(d)),this.self.videoEnabled||n(this,Tt,It).pauseWebcam()}catch(d){this.self.disableVideo()}if(e.canProduceScreenshare===H.Allowed&&a)try{yield(c=n(this,Tt,It))==null?void 0:c.shareScreen({video:o.video,audio:o.audio})}catch(d){this.self.disableScreenShare()}})}kickHandler(s){return u(this,null,function*(){let t="kicked";(s==null?void 0:s.kickType)==="kickAll"&&(t="ended"),this.leaveRoom(t)})}waitlistedHandler(){this.logger.info("SelController.waitlisted"),this.self.waitlistStatus="waiting",this.self.roomState="waitlisted",this.self.emit("waitlisted")}waitlistAcceptHandler(){if(this.logger.info("SelController.waitlistAccepted"),this.self.waitlistStatus==="accepted"){this.logger.warn("SelfController.WAITLIST_ACCEPTED.UserAlreadyAccepted");return}this.self.waitlistStatus="accepted",this.joinRoom()}waitlistRejectedHandler(){if(this.logger.info("SelfController.waitlistRejected"),this.self.waitlistStatus==="rejected"){this.logger.warn("SelfController.WAITLIST_REJECTED.UserAlreadyRejected");return}this.self.waitlistStatus="rejected",this.leaveRoom("rejected")}resetSelf(s){return u(this,null,function*(){n(this,ee).getValue("callstats").callEnded(),n(this,Tt,It).reset(),s&&(yield this.joinRoom(s))})}setupEvents(){n(this,ee).getValue("peerSessionStore").on(b.RESET_PRODUCER_STATE,()=>u(this,null,function*(){this.mediaJoined&&this.shareMediaTracks()})),n(this,ee).getValue("peerSessionStore").on(b.ROOM_NODE_RECONNECTED,()=>{this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:!0})}),n(this,ee).getValue("peerSessionStore").on(b.ROOM_NODE_DISCONNECTED,()=>{this.self.roomState!=="disconnected"&&(this.self.roomState="disconnected",this.self.emit("roomLeft",{state:"disconnected"}))}),n(this,ee).getValue("peerSessionStore").on(b.ROOM_NODE_FAILED,()=>{this.self.roomState="failed",this.self.emit("roomLeft",{state:"failed"})}),n(this,ee).getValue("peerSessionStore").on(b.SOCKET_SERVICE_RECONNECTED,({wasJoinAttempted:s})=>{s===!1&&(this.self.roomState="init"),this.resetSelf(s)}),n(this,ee).getValue("peerSessionStore").on(b.SOCKET_SERVICE_DISCONNECTED,({joinAttempted:s})=>{if(this.self.roomState==="disconnected")return;let{peerId:t}=this;s&&n(this,ee).getValue("flagsmith").hasFeature(Z.REFRESH_ID_ON_DISCONNECTION)&&(t=gr.v4()),n(this,Ki).updateURL(t),n(this,ee).getValue("telemetry").resetPeerId(t),ot().setHeader("tracing-id",t),ur.remapContext(t,n(this,ee)),this.self.roomState="disconnected",this.self.emit("roomLeft",{state:"disconnected"})}),n(this,ee).getValue("peerSessionStore").on(b.SOCKET_SERVICE_FAILED,()=>{this.self.roomState="failed",this.self.emit("roomLeft",{state:"failed"})}),n(this,Ss).on(U.waitingRoomRequestAccepted,()=>{this.waitlistAcceptHandler()}),n(this,Ss).on(rd.updateUserPreset,s=>{s.updatePeersPresets.forEach(t=>{t.userIds===this.self.userId&&n(this,ee).getValue("peerSessionStore").emit(b.UPDATE_PERMISSIONS,t.patch)})}),n(this,Ss).on(U.waitingRoomRequestDenied,()=>{this.waitlistRejectedHandler()}),n(this,Ss).on(U.kick,()=>{this.kickHandler({kickType:"kick"})}),n(this,Ss).on(U.kickAll,()=>{this.kickHandler({kickType:"kickAll"})}),n(this,ee).getValue("peerSessionStore").onAsync(b.JOIN_MEDIA_ROOM,this.joinMediaRoom.bind(this)),n(this,ee).getValue("peerSessionStore").on(b.PRODUCER_SCORE_UPDATE,({score:s,kind:t,appData:e,scoreStats:r})=>{var a;const i=(a=e==null?void 0:e.screenShare)!=null?a:!1;this.self.emit("mediaScoreUpdate",{kind:t,isScreenshare:i,score:s,participantId:this.self.id,scoreStats:r})}),n(this,ee).getValue("peerSessionStore").on(b.MUTE_SELF,()=>u(this,null,function*(){this.self.audioEnabled&&(yield this.self.disableAudio(),n(this,ee).getValue("callstats").audioOff())})),n(this,ee).getValue("peerSessionStore").on(b.MUTE_SELF_VIDEO,()=>u(this,null,function*(){this.self.videoEnabled&&(yield this.self.disableVideo(),n(this,ee).getValue("callstats").videoOff())})),n(this,ee).getValue("peerSessionStore").onAsync(b.LEAVE_MEDIA_ROOM,this.leaveMediaRoom.bind(this)),n(this,ee).getValue("peerSessionStore").on(b.PIP_HANGUP,this.leaveRoom.bind(this))}joinRoom(s=!1){return u(this,null,function*(){try{const{peer:t}=yield n(this,Ss).joinRoom(this.self);n(this,Ss).socket.flush();const e=wh(t.stageType);if(n(this,ee).setValue("stageStatus",e,!1),t.waitlisted){this.waitlistedHandler();return}yield this.joinMediaRoom(s),n(this,ee).notify("stageStatus")}catch(t){throw this.logger.error("Error in joinRoom",{error:t}),t}})}leaveRoom(s="left"){return u(this,null,function*(){var t,e;if(this.logger.info(`Leaving room with state: ${s}`),(t=n(this,ee).getValue("roomSocketHandler"))==null||t.cleanup(),s==="rejected"){this.self.roomState=s,this.self.emit("roomLeft",{state:s});return}this.self.setIsPinned(!1),n(this,ee).setValue("stageStatus","OFF_STAGE",!1),yield this.leaveMediaRoom(s),n(this,ee).notify("stageStatus");try{(e=n(this,Ki))==null||e.disconnect()}catch(r){this.logger.error("SelfController::leaveRoom::socketDisconnect")}wT(n(this,ee)),this.self.roomState=s,this.self.emit("roomLeft",{state:s}),this.logger.info(`roomLeft event emitted with state: ${s}`)})}joinMediaRoom(s=!1){return u(this,null,function*(){var a,o;const{peerId:t,viewType:e,meetingId:r,stageStatus:i}=n(this,ee).getAllValues();try{if(e===pr.Livestream){if(i!=="ON_STAGE"){this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:s});return}CT(n(this,ee),{socket:n(this,Ki),peerId:t})}const{canProduceAudio:c,canProduceVideo:d,canProduceScreenshare:l}=this.self.permissions,{roomJoined:p}=(o=yield(a=n(this,Tt,It))==null?void 0:a.joinRoom(this.self.name,r,s,s,{canProduceAudio:c,canProduceVideo:d,canProduceScreenshare:l}))!=null?o:{};if(!p)return;i==="ON_STAGE"&&(yield this.shareMediaTracks()),this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:s})}catch(c){throw this.logger.error("Error:SelfController.mediaRoomJoin",{error:c}),new A("Error: could not join media room","0002")}})}leaveMediaRoom(s){return u(this,null,function*(){const t=n(this,ee).getValue("viewType");s!=="connected-meeting"&&(yield this.cleanupSelf()),!(s==="stageLeft"&&t===pr.Webinar)&&n(this,Tt,It)&&(n(this,Tt,It).mediaJoined&&s!=="disconnected"&&(yield n(this,Tt,It).leaveRoom()),!(s==="stageLeft"&&t===pr.Livestream)&&(n(this,Tt,It).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()})}},Ki=new WeakMap,Ss=new WeakMap,ee=new WeakMap,Tt=new WeakSet,It=function(){return n(this,ee).getValue("roomNodeClient")},Vg);let si=RT;ln([P.trace("SelfController.resetSelf")],si.prototype,"resetSelf",1);ln([P.trace("SelfController.setupEvents")],si.prototype,"setupEvents",1);ln([P.trace("SelfController.joinRoom")],si.prototype,"joinRoom",1);ln([P.trace("SelfController.leaveRoom")],si.prototype,"leaveRoom",1);ln([P.trace("SelfController.joinMediaRoom")],si.prototype,"joinMediaRoom",1);ln([P.trace("SelfController.leaveMediaRoom")],si.prototype,"leaveMediaRoom",1);ln([P.trace("SelfController.init")],si,"init",1);var Ec;class WD{constructor(t){m(this,Ec,void 0);f(this,Ec,t)}on(t,e){let r;t===U.roomPeerCount?r=Hp.fromBinary.bind(Hp):r=Zp.fromBinary.bind(Zp),n(this,Ec).on(t,({payload:i})=>{if(t===U.roomPeerCount&&!i)return;const a=r(i);e(a)})}}Ec=new WeakMap;var Pc,_c;class JD{constructor(t,e){m(this,Pc,void 0);m(this,_c,void 0);f(this,Pc,e),f(this,_c,t)}get logger(){return n(this,_c).getValue("logger")}on(t,e){let r,i;switch(t){case U.transcript:{r=Zl.fromBinary.bind(Zl),i=Zl.create();break}default:{this.logger.debug("AISocketHandler switch case hit default, event not accounted for.");break}}n(this,Pc).on(t,({payload:a})=>{let o=i;try{o=r(a)}catch(c){this.logger.error("aiSocketHandler::on::binary_decode_error",{error:c})}return e(o)})}}Pc=new WeakMap,_c=new WeakMap;var KD=Object.defineProperty,zD=Object.getOwnPropertyDescriptor,xh=(s,t,e,r)=>{for(var i=r>1?void 0:r?zD(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&KD(t,e,i),i},cr,Ra;class Fl{constructor(t,e){m(this,cr,void 0);m(this,Ra,void 0);f(this,cr,e),f(this,Ra,t)}get logger(){return n(this,Ra).getValue("logger")}get telemetry(){return n(this,Ra).getValue("telemetry")}getPolls(){return n(this,cr).sendMessagePromise(Hs.getPolls)}createPoll(t,e,r=!1,i=!1){const a={anonymous:r,hideVotes:i,question:t,options:e};return n(this,cr).sendMessage(Hs.createPoll,rM.toBinary(a))}votePoll(t,e){const r={index:e,pollId:t};return n(this,cr).sendMessage(Hs.votePoll,nM.toBinary(r))}on(t,e){let r,i;switch(t){case Hs.updatePoll:case Hs.createPoll:case Hs.votePoll:{r=nu.fromBinary.bind(nu),i=nu.create();break}}n(this,cr).on(t,({payload:a})=>{let o=i;try{o=r(a)}catch(c){this.logger.error("pollSocketHandler::on::binary_decode_error",{error:c})}return e(o)})}removeListeners(t){n(this,cr).removeListeners(t)}}cr=new WeakMap,Ra=new WeakMap;xh([P.trace("PollSocketHandler.getPolls")],Fl.prototype,"getPolls",1);xh([P.trace("PollSocketHandler.createPoll")],Fl.prototype,"createPoll",1);xh([P.trace("PollSocketHandler.votePoll")],Fl.prototype,"votePoll",1);var YD=Object.defineProperty,QD=Object.getOwnPropertyDescriptor,XD=(s,t,e,r)=>{for(var i=r>1?void 0:r?QD(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&YD(t,e,i),i},xt;class bT{constructor(t,e){h(this,"socket");m(this,xt,void 0);f(this,xt,t),this.socket=e,this.handleSocketEvents(),n(this,xt).setValue("roomSocketHandler",this)}get telemetry(){return n(this,xt).getValue("telemetry")}get logger(){return n(this,xt).getValue("logger")}cleanup(){var t;try{(t=this.socket)==null||t.disconnect()}catch(e){this.logger.error("roomSocketHandler::cleanup")}}joinRoom(t){return u(this,null,function*(){var i;this.socket.joinAttempted=!0;const e={capabilities:[],peer:{displayName:(i=t.name)!=null?i:"Participant",customParticipantId:t.customParticipantId,peerId:t.id,userId:t.userId,displayPictureUrl:t.picture,waitlisted:!1},roomUuid:""},r=this.socket.sendMessagePromise(U.joinRoom,zb.toBinary(e));try{const{peer:a}=hn.fromBinary((yield r).payload);n(this,xt).getValue("connectionHandler").socketJoined=!0,n(this,xt).getValue("peerSessionStore").emit(b.SOCKET_SERVICE_ROOM_JOINED,{peer:a});const o=this.getRoomState(),c=this.getRoomPeersNonPaginated(),[{room:d},{peers:l}]=yield Promise.all([o,c]);return n(this,xt).getValue("peerSessionStore").emit(b.ROOM_STATE,d),n(this,xt).getValue("peerSessionStore").emit(b.SOCKET_PEERS,l),{peer:a}}catch(a){throw this.logger.error("RoomSocketHandler.joinRoom.failed",{error:a}),new A("Error: RoomSocketHandler.joinRoom failed.","0002",this.logger,a)}})}getAllAddedParticipants(){return u(this,null,function*(){try{return Ok.fromBinary((yield this.socket.sendMessagePromise(U.getAllAddedParticipants)).payload).participants.map(i=>{var a=i,{id:e}=a,r=Bc(a,["id"]);return G(D({},r),{userId:e})})}catch(t){return[]}})}getRoomPeers(t,e,r){return u(this,null,function*(){let i;try{const a={seachQuery:t,limit:e,offset:r},o=yield this.socket.sendMessagePromise(U.getRoomPeersInfo,$b.toBinary(a));i=eu.fromBinary(o.payload)}catch(a){this.logger.error("getRoomPeers::binary_decode_error",{error:a})}return i})}getRoomPeersNonPaginated(){return u(this,null,function*(){let t;try{const e=yield this.socket.sendMessagePromise(U.getRoomPeersInfo);t=eu.fromBinary(e.payload)}catch(e){this.logger.error("getRoomJoinedPeers::binary_decode_error",{error:e})}return t})}getStagePeers(){return u(this,null,function*(){let t;try{const e=yield this.socket.sendMessagePromise(U.getRoomPeersInfo);t=eu.fromBinary(e.payload)}catch(e){this.logger.error("getRoomJoinedPeers::binary_decode_error",{error:e})}return t})}getPeerInfo(t){return u(this,null,function*(){let e;try{const r=yield this.socket.sendMessagePromise(U.getPeerInfo,hf.toBinary({peerId:t}));e=hn.fromBinary(r.payload)}catch(r){this.logger.error("getPeerInfo::binary_decode_error",{error:r})}return e})}getRoomState(){return u(this,null,function*(){let t=qp.create();try{const e=yield this.socket.sendMessagePromise(U.getRoomInfo);t=qp.fromBinary(e.payload)}catch(e){this.logger.error("getRoomState::binary_decode_error",{error:e})}return t})}getRoomStageState(){return u(this,null,function*(){let t=Jp.create();try{const e=yield this.socket.sendMessagePromise(U.getRoomStageState);t=Jp.fromBinary(e.payload)}catch(e){this.logger.error("getRoomStageState::binary_decode_error",{error:e})}return t})}broadcastMessage(t,e){return u(this,null,function*(){const r={type:t,payload:new TextEncoder().encode(JSON.stringify(e)),timestamp:Date.now(),ids:[]};return this.socket.sendMessagePromise(U.broadcastMessage,Za.toBinary(r))})}broadcastToMeetings(t,e,r){return u(this,null,function*(){const i={type:t,payload:new TextEncoder().encode(JSON.stringify(r)),timestamp:Date.now(),ids:e,broadcastType:1};return this.socket.sendMessagePromise(U.broadcastToEntity,Za.toBinary(i))})}broadcastToPeers(t,e,r){return u(this,null,function*(){const i={type:t,payload:new TextEncoder().encode(JSON.stringify(r)),timestamp:Date.now(),ids:e,broadcastType:0};return this.socket.sendMessage(U.broadcastToEntity,Za.toBinary(i))})}leaveRoom(){return u(this,null,function*(){this.socket.joinAttempted=!1,this.socket.sendMessagePromise(U.leaveRoom,Qb.toBinary({}))})}kick(t){return u(this,null,function*(){const e={peerIds:[t]};this.socket.sendMessage(U.kick,gf.toBinary(e))})}kickAll(t=!1){return u(this,null,function*(){const e={propagateKickAcrossRooms:t};this.socket.sendMessage(U.kickAll,df.toBinary(e))})}getWaitingRoomRequests(){this.socket.sendMessage(U.getWaitingRoomRequests)}acceptWaitingRoomRequest(t){const e={userIds:t};this.socket.sendMessage(U.acceptWaitingRoomRequests,$k.toBinary(e))}rejectWaitingRoomRequest(t){const e={userIds:t};this.socket.sendMessage(U.denyWaitingRoomRequests,Bk.toBinary(e))}updatePermissions(t,e){return u(this,null,function*(){const r={updatePeersPresets:[]};return t.forEach(i=>{r.updatePeersPresets.push({userIds:i,patch:e})}),this.socket.sendMessagePromise(rd.updateUserPreset,fA.toBinary(r))})}handleSocketEvents(){this.socket.on(U.broadcastMessage,({payload:t})=>{try{const e=Za.fromBinary(t);n(this,xt).getValue("peerSessionStore").emit(b.ROOM_MESSAGE,{payload:JSON.parse(new TextDecoder().decode(e.payload)),type:e.type,timestamp:e.timestamp})}catch(e){this.logger.error("failed to decode broadcast message:",e)}}),this.socket.on(U.broadcastToEntity,({payload:t})=>{try{const e=Za.fromBinary(t);n(this,xt).getValue("peerSessionStore").emit(b.MESSAGE,{payload:JSON.parse(new TextDecoder().decode(e.payload)),type:e.type,timestamp:e.timestamp})}catch(e){this.logger.error("failed to decode peer broadcast message:",e)}})}on(t,e){let r,i;switch(t){case U.joinRoom:case U.leaveRoom:case U.kick:case U.kickAll:{r=hn.fromBinary.bind(hn),i=hn.create();break}case U.getWaitingRoomRequests:{r=(a,o)=>a?Wp.fromBinary(a,o):{requests:[]},i=Wp.create();break}case U.recordingPaused:case U.recordingStarted:case U.recordingStopped:{r=sg.fromBinary.bind(sg);break}case rd.updateUserPreset:{r=Kp.fromBinary.bind(Kp);break}case Ps.peerJoinedBroadcast:case Ar.peerJoinedBroadcast:{r=xp.fromBinary.bind(xp);break}case Ps.selfJoinComplete:case Ar.selfJoinComplete:{r=yu.fromBinary.bind(yu);break}case Ps.globalPeerPinBroadcast:case Ar.globalPeerPinBroadcast:{r=Fp.fromBinary.bind(Fp);break}case Ps.selectedPeer:case Ar.selectedPeer:{r=Su.fromBinary.bind(Su);break}case Ps.selectedPeerDiff:case Ar.selectedPeerDiff:{r=Lp.fromBinary.bind(Lp);break}case Ps.leaveRoom:case Ar.leaveRoom:{r=Eu.fromBinary.bind(Eu);break}}this.socket.on(t,({payload:a})=>{let o=i;if(!r)return e(void 0);try{o=r(a)}catch(c){this.logger.error("roomSocketHandler::on::binary_decode_error",{error:c})}return e(o)})}getUserPermissions(t){return u(this,null,function*(){const e={userIds:[t]};try{const r=yield this.socket.sendMessagePromise(rd.getUserPresets,dA.toBinary(e)),i=pA.fromBinary(r.payload).peerPresets[0],a=new TextDecoder().decode(i.preset),o=JSON.parse(a).permissions;return{chat:o.chat,polls:o.polls,plugins:o.plugins}}catch(r){throw this.logger.error("Error in getting user preset",{error:r}),r}})}}xt=new WeakMap;XD([P.trace("RoomSocketHandler.joinRoom")],bT.prototype,"joinRoom",1);var Ct;class ZD{constructor(t){m(this,Ct,void 0);f(this,Ct,t)}getStageRequests(){return u(this,null,function*(){const{payload:t}=yield n(this,Ct).sendMessagePromise(U.getStageRequests);return t?iu.fromBinary(t):{stageRequests:[]}})}requestAccess(){n(this,Ct).sendMessage(U.requestStageAccess)}cancelRequestAccess(){n(this,Ct).sendMessage(U.cancelStageRequest)}grantAccess(t){return u(this,null,function*(){const e={userIds:t};n(this,Ct).sendMessage(U.grantStageAccess,JI.toBinary(e))})}denyAccess(t){return u(this,null,function*(){const e={userIds:t};n(this,Ct).sendMessage(U.denyStageAccess,zI.toBinary(e))})}joinStage(){return n(this,Ct).sendMessagePromise(U.joinStage,void 0,void 0,U.peerStageStatusUpdate)}leaveStage(t){const e={userIds:[t]};return n(this,Ct).sendMessagePromise(U.leaveStage,tg.toBinary(e),void 0,U.peerStageStatusUpdate)}kick(t){const e={userIds:t};return n(this,Ct).sendMessagePromise(U.leaveStage,tg.toBinary(e))}on(t,e){let r;switch(t){case U.grantStageAccess:case U.denyStageAccess:{r=void 0;break}case U.getStagePeers:{r=eg.fromBinary.bind(eg);break}case U.getStageRequests:case U.requestStageAccess:case U.cancelStageRequest:{r=iu.fromBinary.bind(iu);break}case U.peerStageStatusUpdate:{r=Bp.fromBinary.bind(Bp);break}}n(this,Ct).on(t,({payload:i,id:a})=>{if(!i||!r)return e(void 0,a);const o=r(i);return e(o,a)})}getPeerInfo(t){return u(this,null,function*(){const e=yield n(this,Ct).sendMessagePromise(U.getPeerInfo,hf.toBinary({peerId:t}));return hn.fromBinary(e.payload)})}}Ct=new WeakMap;var qe,Cc;class eO{constructor(t,e){m(this,qe,void 0);m(this,Cc,void 0);f(this,qe,e),f(this,Cc,t)}get logger(){return n(this,Cc).getValue("logger")}addPlugin(t,e){n(this,qe).sendMessage(J.addPlugin,lI.toBinary({pluginId:t,staggered:e}))}removePlugin(t){n(this,qe).sendMessage(J.removePlugin,hI.toBinary({pluginId:t,staggered:!1}))}getActivePlugins(){return u(this,null,function*(){const{payload:t}=yield n(this,qe).sendMessagePromise(J.getPlugins);return t?VI.fromBinary(t):{plugins:[]}})}customPluginEventToRoom(t,e,r){const i={pluginId:t,pluginData:new TextEncoder().encode(JSON.stringify(e))};n(this,qe).sendMessage(J.customPluginEventToRoom,PI.toBinary(i),r)}customPluginEventToPeers(t,e,r,i){const a={pluginId:t,peerIds:e,pluginData:new TextEncoder().encode(JSON.stringify(r))};n(this,qe).sendMessage(J.customPluginEventToPeers,CI.toBinary(a),i)}enablePluginForRoom(t,e){n(this,qe).sendMessage(J.enablePluginForRoom,gI.toBinary({pluginId:t}),e)}enablePluginForPeers(t,e,r){n(this,qe).sendMessage(J.enablePluginForPeers,vI.toBinary({pluginId:t,peerIds:e}),r)}disablePluginForRoom(t,e){n(this,qe).sendMessage(J.disablePluginForRoom,fI.toBinary({pluginId:t}),e)}disablePluginForPeers(t,e,r){n(this,qe).sendMessage(J.disablePluginForPeers,yI.toBinary({pluginId:t,peerIds:e}),r)}storeInsertKeys(t,e,r,i){const a={pluginId:t,storeName:e,insertKeys:r.map(o=>({storeKey:o.key,payload:new TextEncoder().encode(JSON.stringify(o.payload))}))};n(this,qe).sendMessage(J.storeInsertKeys,zp.toBinary(a),i)}storeGetKeys(t,e,r,i){const a={pluginId:t,storeName:e,getKeys:r.map(o=>({storeKey:o.key}))};n(this,qe).sendMessage(J.storeGetKeys,kI.toBinary(a),i)}storeDeleteKeys(t,e,r,i){const a={pluginId:t,storeName:e,deleteKeys:r.map(o=>({storeKey:o.key}))};n(this,qe).sendMessage(J.storeDeleteKeys,II.toBinary(a),i)}storeDelete(t,e,r){n(this,qe).sendMessage(J.storeDelete,DI.toBinary({pluginId:t,storeName:e}),r)}getPluginDataOld(t,e){this.logger.info("getPluginDataOld",{plugin:{id:t,storeName:e}})}storePluginDataOld(t,e,r){const i={pluginId:t,storeName:e,insertKeys:[{storeKey:r.key,payload:new TextEncoder().encode(JSON.stringify(r))}]};n(this,qe).sendMessage(J.storeInsertKeys,zp.toBinary(i))}on(t,e){let r;switch(t){case J.addPlugin:case J.enablePluginForPeers:case J.enablePluginForRoom:{r=wu.fromBinary.bind(wu);break}case J.removePlugin:case J.disablePluginForPeers:case J.disablePluginForRoom:{r=Yp.fromBinary.bind(Yp);break}case J.customPluginEventToPeers:case J.customPluginEventToRoom:{r=Xp.fromBinary.bind(Xp);break}case J.storeInsertKeys:case J.storeGetKeys:case J.storeDeleteKeys:case J.storeDelete:{r=Qp.fromBinary.bind(Qp);break}}n(this,qe).on(t,({payload:i,id:a})=>{const o=r(i);return e(o,a)})}}qe=new WeakMap,Cc=new WeakMap;var tO=Object.defineProperty,sO=(s,t,e)=>t in s?tO(s,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):s[t]=e,rO=(s,t,e)=>(sO(s,typeof t!="symbol"?t+"":t,e),e),Uh=(s,t,e)=>{if(!t.has(s))throw TypeError("Cannot "+e)},M=(s,t,e)=>(Uh(s,t,"read from private field"),e?e.call(s):t.get(s)),fe=(s,t,e)=>{if(t.has(s))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(s):t.set(s,e)},ne=(s,t,e,r)=>(Uh(s,t,"write to private field"),r?r.call(s,e):t.set(s,e),e),_e=(s,t,e)=>(Uh(s,t,"access private method"),e),wd={},iO={get exports(){return wd},set exports(s){wd=s}},Rn=typeof Reflect=="object"?Reflect:null,pg=Rn&&typeof Rn.apply=="function"?Rn.apply:function(s,t,e){return Function.prototype.apply.call(s,t,e)},ld;Rn&&typeof Rn.ownKeys=="function"?ld=Rn.ownKeys:Object.getOwnPropertySymbols?ld=function(s){return Object.getOwnPropertyNames(s).concat(Object.getOwnPropertySymbols(s))}:ld=function(s){return Object.getOwnPropertyNames(s)};function nO(s){console&&console.warn&&console.warn(s)}var kT=Number.isNaN||function(s){return s!==s};function ce(){ce.init.call(this)}iO.exports=ce;wd.once=dO;ce.EventEmitter=ce;ce.prototype._events=void 0;ce.prototype._eventsCount=0;ce.prototype._maxListeners=void 0;var gg=10;function Bl(s){if(typeof s!="function")throw new TypeError('The "listener" argument must be of type Function. Received type '+typeof s)}Object.defineProperty(ce,"defaultMaxListeners",{enumerable:!0,get:function(){return gg},set:function(s){if(typeof s!="number"||s<0||kT(s))throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received '+s+".");gg=s}});ce.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};ce.prototype.setMaxListeners=function(s){if(typeof s!="number"||s<0||kT(s))throw new RangeError('The value of "n" is out of range. It must be a non-negative number. Received '+s+".");return this._maxListeners=s,this};function AT(s){return s._maxListeners===void 0?ce.defaultMaxListeners:s._maxListeners}ce.prototype.getMaxListeners=function(){return AT(this)};ce.prototype.emit=function(s){for(var t=[],e=1;e<arguments.length;e++)t.push(arguments[e]);var r=s==="error",i=this._events;if(i!==void 0)r=r&&i.error===void 0;else if(!r)return!1;if(r){var a;if(t.length>0&&(a=t[0]),a instanceof Error)throw a;var o=new Error("Unhandled error."+(a?" ("+a.message+")":""));throw o.context=a,o}var c=i[s];if(c===void 0)return!1;if(typeof c=="function")pg(c,this,t);else for(var d=c.length,l=NT(c,d),e=0;e<d;++e)pg(l[e],this,t);return!0};function IT(s,t,e,r){var i,a,o;if(Bl(e),a=s._events,a===void 0?(a=s._events=Object.create(null),s._eventsCount=0):(a.newListener!==void 0&&(s.emit("newListener",t,e.listener?e.listener:e),a=s._events),o=a[t]),o===void 0)o=a[t]=e,++s._eventsCount;else if(typeof o=="function"?o=a[t]=r?[e,o]:[o,e]:r?o.unshift(e):o.push(e),i=AT(s),i>0&&o.length>i&&!o.warned){o.warned=!0;var c=new Error("Possible EventEmitter memory leak detected. "+o.length+" "+String(t)+" listeners added. Use emitter.setMaxListeners() to increase limit");c.name="MaxListenersExceededWarning",c.emitter=s,c.type=t,c.count=o.length,nO(c)}return s}ce.prototype.addListener=function(s,t){return IT(this,s,t,!1)};ce.prototype.on=ce.prototype.addListener;ce.prototype.prependListener=function(s,t){return IT(this,s,t,!0)};function aO(){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 MT(s,t,e){var r={fired:!1,wrapFn:void 0,target:s,type:t,listener:e},i=aO.bind(r);return i.listener=e,r.wrapFn=i,i}ce.prototype.once=function(s,t){return Bl(t),this.on(s,MT(this,s,t)),this};ce.prototype.prependOnceListener=function(s,t){return Bl(t),this.prependListener(s,MT(this,s,t)),this};ce.prototype.removeListener=function(s,t){var e,r,i,a,o;if(Bl(t),r=this._events,r===void 0)return this;if(e=r[s],e===void 0)return this;if(e===t||e.listener===t)--this._eventsCount===0?this._events=Object.create(null):(delete r[s],r.removeListener&&this.emit("removeListener",s,e.listener||t));else if(typeof e!="function"){for(i=-1,a=e.length-1;a>=0;a--)if(e[a]===t||e[a].listener===t){o=e[a].listener,i=a;break}if(i<0)return this;i===0?e.shift():oO(e,i),e.length===1&&(r[s]=e[0]),r.removeListener!==void 0&&this.emit("removeListener",s,o||t)}return this};ce.prototype.off=ce.prototype.removeListener;ce.prototype.removeAllListeners=function(s){var t,e,r;if(e=this._events,e===void 0)return this;if(e.removeListener===void 0)return arguments.length===0?(this._events=Object.create(null),this._eventsCount=0):e[s]!==void 0&&(--this._eventsCount===0?this._events=Object.create(null):delete e[s]),this;if(arguments.length===0){var i=Object.keys(e),a;for(r=0;r<i.length;++r)a=i[r],a!=="removeListener"&&this.removeAllListeners(a);return this.removeAllListeners("removeListener"),this._events=Object.create(null),this._eventsCount=0,this}if(t=e[s],typeof t=="function")this.removeListener(s,t);else if(t!==void 0)for(r=t.length-1;r>=0;r--)this.removeListener(s,t[r]);return this};function DT(s,t,e){var r=s._events;if(r===void 0)return[];var i=r[t];return i===void 0?[]:typeof i=="function"?e?[i.listener||i]:[i]:e?cO(i):NT(i,i.length)}ce.prototype.listeners=function(s){return DT(this,s,!0)};ce.prototype.rawListeners=function(s){return DT(this,s,!1)};ce.listenerCount=function(s,t){return typeof s.listenerCount=="function"?s.listenerCount(t):OT.call(s,t)};ce.prototype.listenerCount=OT;function OT(s){var t=this._events;if(t!==void 0){var e=t[s];if(typeof e=="function")return 1;if(e!==void 0)return e.length}return 0}ce.prototype.eventNames=function(){return this._eventsCount>0?ld(this._events):[]};function NT(s,t){for(var e=new Array(t),r=0;r<t;++r)e[r]=s[r];return e}function oO(s,t){for(;t+1<s.length;t++)s[t]=s[t+1];s.pop()}function cO(s){for(var t=new Array(s.length),e=0;e<t.length;++e)t[e]=s[e].listener||s[e];return t}function dO(s,t){return new Promise(function(e,r){function i(o){s.removeListener(t,a),r(o)}function a(){typeof s.removeListener=="function"&&s.removeListener("error",i),e([].slice.call(arguments))}VT(s,t,a,{once:!0}),t!=="error"&&lO(s,i,{once:!0})})}function lO(s,t,e){typeof s.on=="function"&&VT(s,"error",t,e)}function VT(s,t,e,r){if(typeof s.on=="function")r.once?s.once(t,e):s.on(t,e);else if(typeof s.addEventListener=="function")s.addEventListener(t,function i(a){r.once&&s.removeEventListener(t,i),e(a)});else throw new TypeError('The "emitter" argument must be of type EventEmitter. Received type '+typeof s)}class uO extends S.MessageType{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 mg=new uO;class LT{static encode(t){return mg.toBinary(t)}static decode(t){return mg.fromBinary(new Uint8Array(t))}}function hO(s,t){return Math.floor(Math.random()*(t-s+1)+s)}var br;class pO{constructor(t={}){rO(this,"opts"),fe(this,br,void 0),this.opts={initialTimeout:t.initialTimeout||1e3,maxTimeout:t.maxTimeout||1e4,factor:t.factor||2},ne(this,br,0)}wait(){return u(this,null,function*(){ne(this,br,M(this,br)+1);const t=hO(0,Math.min(this.opts.maxTimeout,this.opts.initialTimeout*Gh(2,M(this,br))));yield new Promise(e=>{setTimeout(e,t)})})}getAttempts(){return M(this,br)}reset(){ne(this,br,0)}}br=new WeakMap;const _r={debug:0,info:1,warn:2,error:3};var oi,ci;class gO{constructor(t){fe(this,oi,void 0),fe(this,ci,void 0),ne(this,oi,console),ne(this,ci,t)}debug(...t){_r[M(this,ci)]>_r.debug||M(this,oi).debug("[Sockrates]:",...t)}info(...t){_r[M(this,ci)]>_r.info||M(this,oi).info("[Sockrates]:",...t)}warn(...t){_r[M(this,ci)]>_r.warn||M(this,oi).warn("[Sockrates]:",...t)}error(...t){_r[M(this,ci)]>_r.error||M(this,oi).error("[Sockrates]:",...t)}}oi=new WeakMap,ci=new WeakMap;var xT=(s=>(s[s.CONNECTING=0]="CONNECTING",s[s.OPEN=1]="OPEN",s[s.CLOSING=2]="CLOSING",s[s.CLOSED=3]="CLOSED",s))(xT||{});const mO="2",fO="3";var Ae,fn,Pe,Le,kr,Ke,lr,zr,Es,Tn,Bs,Yu,UT,lo,ud,Qu,$T,Xu,fg,Rd,Zu,eh,FT,po,hd,go,bd,kd,th,bn,mo,fo,Ad;class TO{constructor(t,e){var T,v,E,_,C,R,L,F,N,B;fe(this,Yu),fe(this,lo),fe(this,Qu),fe(this,Xu),fe(this,Rd),fe(this,eh),fe(this,po),fe(this,go),fe(this,kd),fe(this,bn),fe(this,fo),fe(this,Ae,void 0),fe(this,fn,void 0),fe(this,Pe,void 0),fe(this,Le,void 0),fe(this,kr,void 0),fe(this,Ke,void 0),fe(this,lr,void 0),fe(this,zr,void 0),fe(this,Es,void 0),fe(this,Tn,void 0),fe(this,Bs,void 0);var r,i,a,o,c,d,l,p,g;ne(this,fn,t),ne(this,kr,[]),ne(this,Ke,new wd),ne(this,lr,!0),ne(this,Es,!1),ne(this,Pe,e!=null?e:{}),(T=(r=M(this,Pe)).autoReconnect)!=null||(r.autoReconnect=!0),(v=(i=M(this,Pe)).retryConnectionInterval)!=null||(i.retryConnectionInterval=1e3),(E=(a=M(this,Pe)).pingTimeout)!=null||(a.pingTimeout=3e4),(_=(o=M(this,Pe)).connectionTimeout)!=null||(o.connectionTimeout=5e3),(C=(c=M(this,Pe)).debug)!=null||(c.debug=!0),(R=(d=M(this,Pe)).maxReconnectionAttempts)!=null||(d.maxReconnectionAttempts=10),(L=(l=M(this,Pe)).disconnectOnPingTimeout)!=null||(l.disconnectOnPingTimeout=!0),(F=(p=M(this,Pe)).queueOnDisconnect)!=null||(p.queueOnDisconnect=!1),(N=(g=M(this,Pe)).flushOnReconnect)!=null||(g.flushOnReconnect=!1),ne(this,zr,{code:void 0,reason:void 0}),ne(this,Le,(B=M(this,Pe).logger)!=null?B:new gO(M(this,Pe).debug?"debug":"info")),ne(this,Bs,new pO)}get readyState(){var t;return(t=M(this,Ae))==null?void 0:t.readyState}get url(){return M(this,fn)}updateURL(t){ne(this,fn,t),_e(this,eh,FT).call(this)}get config(){return M(this,Pe)}get sendQueue(){return M(this,kr)}flush(){if(!M(this,Pe).queueOnDisconnect)return!1;const t=[];return M(this,kr).forEach(e=>{this.send(e.event,e.id,e.payload,e.metadata)||t.push(e)}),ne(this,kr,t),M(this,kr)}connect(t=!1){return u(this,null,function*(){if(!t&&[0,1].includes(this.readyState)){M(this,Le).debug("Websocket was already connecting or connected.");return}if(M(this,lr)!==!1)return new Promise((e,r)=>{_e(this,bn,mo).call(this),_e(this,fo,Ad).call(this);try{ne(this,Ae,new WebSocket(_e(this,Yu,UT).call(this,M(this,fn)))),M(this,Ae).binaryType="arraybuffer",M(this,Le).debug("Connecting");const i=setTimeout(()=>{M(this,Le).debug("Connection timeout. Closing socket"),ne(this,lr,!0),_e(this,fo,Ad).call(this),M(this,Ae).close(3001,"Connection Timeout"),M(this,Pe).autoReconnect&&!M(this,Es)&&(M(this,Ke).emit("reconnecting"),_e(this,po,hd).call(this)),r(new Error("Connection timed out!"))},M(this,Pe).connectionTimeout);M(this,Ae).onopen=()=>{M(this,Le).debug(`Ready State: ${xT[M(this,Ae).readyState]}`),i&&clearTimeout(i),_e(this,kd,th).call(this),ne(this,zr,{code:void 0,reason:void 0}),M(this,Ke).emit("connected"),M(this,Pe).flushOnReconnect&&this.flush(),e()},M(this,Ae).onclose=a=>{try{i&&clearTimeout(i);const{code:o,reason:c}=a;r(c),M(this,Le).debug("Socket closed. Close event:",{event:a}),M(this,Le).debug(`Connection closed code: ${o}`),M(this,Le).debug(`Connection closed reason: ${c}`),M(this,Es)||_e(this,Rd,Zu).call(this,o,c)}catch(o){_e(this,lo,ud).call(this,o)}},M(this,Ae).onerror=a=>{_e(this,lo,ud).call(this,a)},M(this,Ae).onmessage=a=>_e(this,Qu,$T).call(this,a)}catch(i){_e(this,lo,ud).call(this,i,r)}})})}send(t,e,r,i){const a={event:t,id:e,payload:r,metadata:i};if(M(this,Pe).queueOnDisconnect&&(!M(this,Ae)||M(this,Ae).readyState!==1))return M(this,Le).debug("Queuing message since socket is not connected!",a),M(this,kr).push(a),!1;const o=LT.encode(a);return _e(this,go,bd).call(this,o)}emit(t,e,r,i){return this.send(t,e,r,i)}sendRaw(t){return _e(this,go,bd).call(this,t)}receive(t,e){return M(this,Ke).on(t.toString(),e)}on(t,e){if(typeof t=="string"&&(t==="connected"||t==="disconnected"||t==="errored"||t==="reconnected"||t==="reconnecting"||t==="reconnectAttempt"||t==="reconnectFailure"||t==="failed")){M(this,Ke).on(t,e);return}this.receive(t,e)}removeAllListeners(){M(this,Ke).removeAllListeners()}removeReceiver(t,e){this.removeListener(t,e)}removeListener(t,e){M(this,Ke).removeListener(t.toString(),e)}removeReceivers(t){this.removeListeners(t)}removeListeners(t){M(this,Ke).listeners(t.toString()).map(e=>this.removeListener(t,e))}disconnect(){ne(this,lr,!1),_e(this,bn,mo).call(this),this.removeAllListeners(),ne(this,zr,{code:1e3,reason:"Sockrates disconnect method called"}),M(this,Ae).close(1e3,"Sockrates disconnect method called.")}}Ae=new WeakMap,fn=new WeakMap,Pe=new WeakMap,Le=new WeakMap,kr=new WeakMap,Ke=new WeakMap,lr=new WeakMap,zr=new WeakMap,Es=new WeakMap,Tn=new WeakMap,Bs=new WeakMap,Yu=new WeakSet,UT=function(s){if(s.startsWith("ws://")||s.startsWith("wss://"))return s;if(s.startsWith("https://"))return`wss://${s.substring(8)}`;if(s.startsWith("http://"))return`ws://${s.substring(7)}`;throw new Error("Invalid URL. URL must start with http(s):// or ws(s)://.")},lo=new WeakSet,ud=function(s,t){M(this,Le).error("Error:",{error:s}),M(this,Ke).emit("errored",{error:s}),t==null||t(s)},Qu=new WeakSet,$T=function(s){if(_e(this,kd,th).call(this),s.data===mO){M(this,Le).debug("Received ping from server"),_e(this,go,bd).call(this,fO);return}const t=LT.decode(s.data),{id:e,payload:r}=t;M(this,Le).debug("Received message",{event:t.event,messageID:e}),M(this,Ke).emit(t.event.toString(),{id:e,payload:r})},Xu=new WeakSet,fg=function(){return M(this,Ae).readyState===1},Rd=new WeakSet,Zu=function(s,t){ne(this,zr,{reason:t,code:s}),M(this,Ke).emit("disconnected",{code:s,reason:t})},eh=new WeakSet,FT=function(){const{reason:s,code:t}=M(this,zr);t&&t!==1e3&&M(this,lr)&&M(this,Pe).autoReconnect&&!M(this,Es)&&(M(this,Le).debug(`Triggering reconnection due to ${s}.`),M(this,Ke).emit("reconnecting"),_e(this,po,hd).call(this))},po=new WeakSet,hd=function(s=!0){return u(this,null,function*(){if(s&&M(this,Es)){M(this,Le).debug("Reconnect called when already in a reconnect loop. Ignoring.");return}if(M(this,Es)||M(this,Bs).reset(),M(this,Pe).maxReconnectionAttempts!==null&&M(this,Bs).getAttempts()>=M(this,Pe).maxReconnectionAttempts){M(this,Ke).emit("failed"),ne(this,Es,!1);return}ne(this,Es,!0),_e(this,fo,Ad).call(this),_e(this,bn,mo).call(this);try{if(yield M(this,Bs).wait(),M(this,lr)===!1)return;if(M(this,Le).debug(`Reconnection attempt ${M(this,Bs).getAttempts()}`),M(this,Ke).emit("reconnectAttempt",{attempt:M(this,Bs).getAttempts()}),yield this.connect(),!_e(this,Xu,fg).call(this))throw Error("Reconnect Failed");ne(this,Es,!1),ne(this,zr,{code:void 0,reason:void 0}),M(this,Ke).emit("reconnected")}catch(t){M(this,Le).debug("Failed to reconnect."),M(this,Ke).emit("reconnectFailure",{attempt:M(this,Bs).getAttempts()}),_e(this,po,hd).call(this,!1)}})},go=new WeakSet,bd=function(s){try{return M(this,Ae).send(s),!0}catch(t){return M(this,Le).error(t.message),!1}},kd=new WeakSet,th=function(){this.config.disconnectOnPingTimeout&&(M(this,Le).debug("Resetting ping timeout"),_e(this,bn,mo).call(this),ne(this,Tn,setTimeout(()=>{var s;M(this,Le).debug("Disconnecting the socket due to ping timeout"),ne(this,lr,!0);const t=3002,e="Ping timeout";(s=M(this,Ae))==null||s.close(t,e),_e(this,Rd,Zu).call(this,t,e)},M(this,Pe).pingTimeout)))},bn=new WeakSet,mo=function(){M(this,Tn)&&(clearTimeout(M(this,Tn)),ne(this,Tn,void 0))},fo=new WeakSet,Ad=function(){M(this,Ae)&&(M(this,Ae).onopen=void 0,M(this,Ae).onerror=void 0,M(this,Ae).onmessage=void 0,M(this,Ae).onclose=void 0)};var vO=Object.defineProperty,SO=Object.getOwnPropertyDescriptor,Hl=(s,t,e,r)=>{for(var i=r>1?void 0:r?SO(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&vO(t,e,i),i};const Tg=65535,yO=3e3;var Wr,Ce,we,Me,ss,Ze,wc,sh,Rc,rh,Lg;const BT=(Lg=class{constructor(s,{peerId:t,meetingId:e,authToken:r,capabilities:i}){m(this,we);m(this,wc);m(this,Rc);m(this,Wr,void 0);m(this,Ce,void 0);h(this,"roomName");h(this,"authToken");h(this,"capabilities");m(this,ss,void 0);m(this,Ze,void 0);var a;if(!t||!e||!r)throw new A("peerId, meetingId, or authToken can not be empty","0404");f(this,ss,void 0),f(this,Ze,s),this.capabilities=i,this.roomName=e,this.authToken=r,f(this,Wr,x(this,wc,sh).call(this,t)),f(this,Ce,new TO(n(this,Wr),{autoReconnect:!0,disconnectOnPingTimeout:(a=i.includes("PING"))!=null?a:!1,queueOnDisconnect:!0,flushOnReconnect:!1,logger:this.logger})),this.handleSocketConnectionEvents()}get joinAttempted(){return n(this,we,Me).socketJoinAttempted}set joinAttempted(s){n(this,we,Me).socketJoinAttempted=s}get telemetry(){return n(this,Ze).getValue("telemetry")}get logger(){return n(this,Ze).getValue("logger")}get peerId(){return n(this,Ze).getValue("peerId")}updateURL(s){s!==this.peerId&&(f(this,Wr,x(this,wc,sh).call(this,s)),this.logger.debug("SocketService:: Connection URL updated.")),n(this,Ce).updateURL(n(this,Wr))}static getSocketEdgeDomain(s){return Zi({servicePrefix:"socket-edge",baseURI:s})}get url(){return n(this,Wr)}connect(){return u(this,null,function*(){n(this,we,Me).socketJoinAttempted=!0,yield n(this,Ce).connect(),n(this,we,Me).socketJoinAttempted=!0,n(this,we,Me).socketState={state:"connected",reconnected:!1,reconnectionAttempt:void 0}})}disconnect(){n(this,we,Me).socketJoinAttempted=!1,n(this,Ce).disconnect(),n(this,we,Me).socketJoinAttempted=!0,n(this,we,Me).socketState={state:"disconnected",reconnected:!1,reconnectionAttempt:void 0}}get isConnected(){try{return n(this,Ce).readyState===1}catch(s){return!1}}sendMessage(s,t,e){const r={};return n(this,Ze).getValue("telemetry").injectContext(r),n(this,Ce).send(s,e!=null?e:x(this,Rc,rh).call(this),t,new TextEncoder().encode(JSON.stringify(r)))}sendMessagePromise(s,t,e,r){const i=parseInt({}.SOCKET_SERVICE_MESSAGE_REQUEST_TIMEOUT,10)||2e4;return this.sendMessagePromiseWithTimeout({event:s,timeout:i,protobuf:t,messageId:e,resp:r})}sendMessagePromiseWithTimeout({event:s,timeout:t,protobuf:e,messageId:r,resp:i}){const a=i!=null?i:s;return new Promise((o,c)=>{const d=(E,_)=>{n(this,Ce).removeListener(a,E),n(this,Ce).removeListener(Tg,_),n(this,Ce).removeListener(Ar.errorResponse,_),n(this,Ce).removeListener(Ps.errorResponse,_)},l=r!=null?r:x(this,Rc,rh).call(this),p={};n(this,Ze).getValue("telemetry").injectContext(p);const T=({id:E,payload:_})=>{if(l===E){let C;try{const R=MR.fromBinary(_);C=new Error(R.errorMessage)}catch(R){C=new Error("failed to parse error message",{cause:R});try{const L=Db.fromBinary(_);C=new Error(L.message)}catch(L){C=new Error("failed to parse error message",{cause:L})}}c(C),d(v,T)}},v=({id:E,payload:_})=>{l===E&&(o({id:E,payload:_}),d(v,T))};n(this,Ce).on(a,v),n(this,Ce).on(Tg,T),n(this,Ce).on(Ar.errorResponse,T),n(this,Ce).on(Ps.errorResponse,T),setTimeout(()=>{d(v,T),c(new Error(`request timeout for callback eventId:${s}`))},t),n(this,Ce).send(s,l,e,new TextEncoder().encode(JSON.stringify(p)))})}on(s,t){n(this,Ce).on(s,t)}onStateEvent(s,t){n(this,Ce).on(s,t)}removeListener(s,t){n(this,Ce).removeListener(s,t)}removeListeners(s){n(this,Ce).removeListeners(s)}flush(){return n(this,Ce).flush()}handleSocketConnectionEvents(){this.onStateEvent("connected",()=>u(this,null,function*(){this.logger.info("SocketService::Connected to socket-edge"),n(this,ss)&&(clearTimeout(n(this,ss)),f(this,ss,void 0)),n(this,we,Me).updateSocketConnectionState("connected")})),this.onStateEvent("disconnected",({code:s,reason:t})=>{var i;this.logger.info("SocketService::Disconnected from socket-edge",{error:{code:s,reason:t},country:P.location.country});const{recv:e,send:r}=(i=n(this,we,Me).mediaState)!=null?i:{};e!=null&&e.state&&(e==null?void 0:e.state)!==wn.CONNECTED||r!=null&&r.state&&(r==null?void 0:r.state)!==wn.CONNECTED?n(this,Ze).getValue("peerSessionStore").emit(b.SOCKET_SERVICE_DISCONNECTED,{joinAttempted:n(this,we,Me).joinAttempted}):f(this,ss,setTimeout(()=>{n(this,Ze).getValue("peerSessionStore").emit(b.SOCKET_SERVICE_DISCONNECTED,{joinAttempted:n(this,we,Me).joinAttempted}),f(this,ss,void 0)},yO)),n(this,we,Me).updateSocketConnectionState("disconnected")}),this.onStateEvent("reconnecting",()=>u(this,null,function*(){this.logger.info("SocketService::Reconnecting to socket-edge",{country:P.location.country}),n(this,we,Me).updateSocketConnectionState("reconnecting")})),this.onStateEvent("reconnectAttempt",t=>u(this,[t],function*({attempt:s}){this.logger.info("SocketService::Attempting to reconnect to socket-edge",{socket:{retryAttempt:s}}),n(this,we,Me).updateSocketConnectionState("reconnectAttempt",s)})),this.onStateEvent("reconnectFailure",({attempt:s})=>{this.logger.info("SocketService::Reconnect attempt to socket-edge failed",{socket:{retryAttempt:s}}),n(this,we,Me).updateSocketConnectionState("reconnectFailure",s)}),this.onStateEvent("reconnected",()=>u(this,null,function*(){this.logger.info("SocketService::Reconnected to socket-edge",{connectionState:{joinAttempted:n(this,we,Me).mediaJoinAttempted}}),n(this,ss)&&(clearTimeout(n(this,ss)),f(this,ss,void 0)),n(this,Ze).getValue("peerSessionStore").emit(b.SOCKET_SERVICE_RECONNECTED,{wasJoinAttempted:n(this,we,Me).mediaJoinAttempted}),n(this,we,Me).updateSocketConnectionState("reconnected")})),this.onStateEvent("failed",()=>u(this,null,function*(){this.logger.info("SocketService::Failed to connect to socket-edge",{country:P.location.country}),n(this,Ze).getValue("peerSessionStore").emit(b.SOCKET_SERVICE_FAILED),n(this,we,Me).updateSocketConnectionState("failed")}))}},Wr=new WeakMap,Ce=new WeakMap,we=new WeakSet,Me=function(){return n(this,Ze).getValue("connectionHandler")},ss=new WeakMap,Ze=new WeakMap,wc=new WeakSet,sh=function(s){let t=BT.getSocketEdgeDomain(n(this,Ze).getValue("baseURI"));typeof Ia(n(this,Ze),"socket_server_base")=="string"&&(t=Ia(n(this,Ze),"socket_server_base"));const e=`wss://${t}`,r=new URL(`${e}/ws`),i=this.peerId,a=G(D({roomID:this.roomName,peerID:s,authToken:this.authToken,useMediaV2:!0},i!==s&&{oldPeerID:i}),{ping:this.capabilities.includes("PING"),capabilities:this.capabilities.map(o=>Sd[o]).join(" "),joinWithDetails:!0,useCfWorker:!0,useStartSession:!0});return Object.entries(a).forEach(([o,c])=>{r.searchParams.append(o,c.toString())}),r.href},Rc=new WeakSet,rh=function(){return`${this.peerId}-${(Math.random()+1).toString(36).substring(7)}`},Lg);let Uc=BT;Hl([P.trace("SocketService.connect")],Uc.prototype,"connect",1);Hl([P.trace("SocketService.disconnect")],Uc.prototype,"disconnect",1);Hl([P.trace("SocketService.sendMessagePromise")],Uc.prototype,"sendMessagePromise",1);Hl([P.trace("SocketService.sendMessagePromiseWithTimeout")],Uc.prototype,"sendMessagePromiseWithTimeout",1);class EO{constructor(t){h(this,"socketService");this.socketService=t}handleConnectedRoomsDumpRaw({payload:t}){var a;const e=nk.fromBinary(t),r=e.meetings.map(o=>{var c;return{id:o.id,title:o.title,participants:(c=o.participants)!=null?c:[]}});return{parentMeeting:{id:e.parentMeeting.id,title:e.parentMeeting.title,participants:(a=e.parentMeeting.participants)!=null?a:[]},meetings:r}}handleTransferPeerRaw({payload:t}){const e=Mk.fromBinary(t);return{authToken:e.authToken,meetingId:e.meetingId}}handleMovedPeerRaw({payload:t}){const e=pf.fromBinary(t);return{meetingId:e.meetingId,customParticipantId:e.customParticipantId}}handleConnectedRoomsUpdatedRaw({payload:t}){return Gp.fromBinary(t).payloads.map(r=>({id:r.id,title:r.title}))}handleConnectedRoomsDeletedRaw({payload:t}){return Ek.fromBinary(t).payloads}getConnectedRoomsDump(){return u(this,null,function*(){const t=yield this.socketService.sendMessagePromise(U.getConnectedRoomsDump);return this.handleConnectedRoomsDumpRaw(t)})}createConnectedRooms(t){return u(this,null,function*(){const{payload:e}=yield this.socketService.sendMessagePromise(U.createConnectedRooms,dk.toBinary({payloads:t}));return Gp.fromBinary(e).payloads.map(i=>({id:i.id,title:i.title}))})}updateConnectedRooms(t){return u(this,null,function*(){})}disableConnectedRooms(t){return u(this,null,function*(){const e=t.map(i=>({id:i})),r=yield this.socketService.sendMessagePromise(U.deleteConnectedRooms,Sk.toBinary({payloads:e}));return this.handleConnectedRoomsDeletedRaw(r)})}movePeersBetweenRooms(t){return u(this,null,function*(){try{const e=yield this.socketService.sendMessagePromise(U.movePeers,bk.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}}})}}var PO=Object.defineProperty,_O=Object.getOwnPropertyDescriptor,CO=(s,t,e,r)=>{for(var i=r>1?void 0:r?_O(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&PO(t,e,i),i},ys;class HT extends Bt{constructor(e){const r=e.getValue("logger");super(r);h(this,"meetings",[]);h(this,"parentMeeting",null);m(this,ys,void 0);f(this,ys,e)}get supportsConnectedMeetings(){return n(this,ys).getValue("self").id!==""}get isActive(){return this.meetings.length!==0}validateConnectedMeetingsAction(){if(!this.supportsConnectedMeetings)throw new Error(`You are not allowed to perform this action.
|
|
11
|
-
Please connect with our support team to enable connected meetings.`)}getConnectedMeetings(){return u(this,null,function*(){this.validateConnectedMeetingsAction(),this.logger.info("Getting connected meetings dump");const e=yield n(this,ys).getValue("connectedMeetingsSocketHandler").getConnectedRoomsDump();return this.logger.info("Got connected meetings dump"),e})}createMeetings(e){return u(this,null,function*(){this.validateConnectedMeetingsAction(),this.logger.info(`Creating connected meetings ${JSON.stringify(e)}`);const r=yield n(this,ys).getValue("connectedMeetingsSocketHandler").createConnectedRooms(e);return this.logger.info(`Created connected meetings ${JSON.stringify(r)}`),r.map(i=>({id:i.id,title:i.title}))})}updateMeetings(e){return u(this,null,function*(){this.validateConnectedMeetingsAction(),this.logger.info(`Updating connected meetings ${JSON.stringify(e)}`),yield n(this,ys).getValue("connectedMeetingsSocketHandler").updateConnectedRooms(e.map(r=>({meetingId:r.id,title:r.title}))),this.logger.info(`Updated connected meetings ${JSON.stringify(e)}`)})}deleteMeetings(e){return u(this,null,function*(){this.validateConnectedMeetingsAction(),this.logger.info(`Moving participants before deleting connected meetings ${JSON.stringify(e)}`);const r=this.meetings.map(a=>e.includes(a.id)&&a.participants.length!==0?this.moveParticipants(a.id,this.parentMeeting.id,a.participants.map(o=>o.id)):Promise.resolve());this.logger.info(`Moved participants before deleting connected meetings ${JSON.stringify(e)}. Deleting now.`),yield Promise.all(r);const i=yield n(this,ys).getValue("connectedMeetingsSocketHandler").disableConnectedRooms(e);return this.logger.info(`Deleted connected meetings ${JSON.stringify(e)}`),i})}moveParticipants(e,r,i){return u(this,null,function*(){this.validateConnectedMeetingsAction(),this.logger.info(`Moving connected meetings participants ${JSON.stringify(i)} from ${e} to ${r}`);const a=yield n(this,ys).getValue("connectedMeetingsSocketHandler").movePeersBetweenRooms({sourceMeetingId:e,destinationMeetingId:r,participants:i.map(o=>({id:o}))});return a.success?(this.logger.info(`Moved connected meetings participants ${JSON.stringify(i)} from ${e} to ${r}`),this.moveSuccessHandler(e,r,i)):this.logger.error(`Failed to move connected meetings participants ${JSON.stringify(i)} from ${e} to ${r}`),a})}moveParticipantsWithCustomPreset(e,r,i){return u(this,null,function*(){this.validateConnectedMeetingsAction(),this.logger.info(`Moving connected meetings participants (custom preset) ${JSON.stringify(i)} from ${e} to ${r}`);const a=yield n(this,ys).getValue("connectedMeetingsSocketHandler").movePeersBetweenRooms({sourceMeetingId:e,destinationMeetingId:r,participants:i});return a.success?(this.logger.info(`Moved connected meetings participants (custom preset) ${JSON.stringify(i)} from ${e} to ${r}`),this.moveSuccessHandler(e,r,i.map(o=>o.id))):this.logger.error(`Failed to move connected meetings participants (custom preset) ${JSON.stringify(i)} from ${e} to ${r}`),a})}moveSuccessHandler(e,r,i){const a=new Map;[...this.parentMeeting.participants,...this.meetings.flatMap(o=>o.participants)].forEach(o=>a.set(o.id,o)),r===this.parentMeeting.id&&(this.parentMeeting.participants=this.parentMeeting.participants.concat(i.map(o=>a.get(o)))),e===this.parentMeeting.id&&(this.parentMeeting.participants=this.parentMeeting.participants.filter(o=>!i.includes(o.id))),this.meetings=this.meetings.map(o=>{if(r===o.id){const c=o.participants.concat(i.map(d=>a.get(d)));return G(D({},o),{participants:c})}if(e===o.id){const c=o.participants.filter(d=>!i.includes(d.id));return G(D({},o),{participants:c})}return o})}}ys=new WeakMap;CO([Rt({maxInvocations:60,period:60})],HT.prototype,"getConnectedMeetings",1);var wO=Object.defineProperty,RO=Object.getOwnPropertyDescriptor,$h=(s,t,e,r)=>{for(var i=r>1?void 0:r?RO(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&wO(t,e,i),i},pe,xg;const qT=(xg=class{constructor(s){h(this,"connectedMeetings");m(this,pe,void 0);f(this,pe,s),this.connectedMeetings=new HT(s)}get telemetry(){return n(this,pe).getValue("telemetry")}get logger(){return n(this,pe).getValue("logger")}static init(s){const t=new qT(s);return t.connectedMeetings.supportsConnectedMeetings&&(t.setupEvents(),s.getValue("self").once("roomJoined",()=>t.getConnectedMeetings())),t}getConnectedMeetings(){this.connectedMeetings.getConnectedMeetings()}setupEvents(){n(this,pe).getValue("connectedMeetingsSocketHandler").socketService.on(U.getConnectedRoomsDump,this.handleConnectedRoomsDump.bind(this)),n(this,pe).getValue("connectedMeetingsSocketHandler").socketService.on(U.transferPeer,this.handleTransferPeer.bind(this)),n(this,pe).getValue("connectedMeetingsSocketHandler").socketService.on(U.movedPeer,this.handleMovedPeer.bind(this)),n(this,pe).getValue("connectedMeetingsSocketHandler").socketService.on(U.connectedRoomsUpdated,this.handleConnectedRoomsUpdated.bind(this)),n(this,pe).getValue("connectedMeetingsSocketHandler").socketService.on(U.connectedRoomsDeleted,this.handleConnectedRoomsDeleted.bind(this))}handleTransferPeer(s){this.logger.info("Received backend request to switch connected meetings");const t=n(this,pe).getValue("connectedMeetingsSocketHandler").handleTransferPeerRaw(s);return this.logger.info(`Honoring request to switch connected meetings. Going to ${t==null?void 0:t.meetingId}`),this.switchMeeting(t)}switchMeeting(e){return u(this,arguments,function*({authToken:s,meetingId:t}){var a,o,c,d;if(!this.connectedMeetings.supportsConnectedMeetings)throw new Error(`You are not allowed to perform this action.
|
|
12
|
-
Please connect with our support team to enable connected meetings.`);this.logger.info("ConnectedMeetingsController::switchMeeting:: asking ui-kit to show switching breakout UI"),this.connectedMeetings.emit("changingMeeting",t);const r={video:n(this,pe).getValue("self").videoEnabled,audio:n(this,pe).getValue("self").audioEnabled};try{n(this,pe).getValue("self").cleanupEvents(),yield n(this,pe).getValue("meeting").leave("connected-meeting")}catch(l){this.logger.error(`ConnectedMeetingsController:: switchMeeting:: issues in leaving previous meeting. Meeting Id: ${(o=(a=n(this,pe).getValue("meeting"))==null?void 0:a.meta)==null?void 0:o.meetingId}`,{error:l})}this.logger.info(`ConnectedMeetingsController::switchMeeting:: initializing new meeting. Meeting Id: ${t}`);const i=yield GT.init(G(D({},n(this,pe).getValue("options")),{cachedUserDetails:null,defaults:G(D(D({},n(this,pe).getValue("options").defaults),r),{mediaHandler:n(this,pe).getValue("self")}),authToken:s}));this.logger.info(`ConnectedMeetingsController::switchMeeting:: initialized new meeting. Meeting Id: ${(c=i==null?void 0:i.meta)==null?void 0:c.meetingId}`);try{const{hidden:l}=n(this,pe).getValue("self");i.self.setName(n(this,pe).getValue("self").name),yield i.join(),l&&i.self.hide()}catch(l){this.logger.error("ConnectedMeetingsController.joinRoom",{error:l})}return this.logger.info(`ConnectedMeetingsController::switchMeeting:: asking ui-kit to show in-meeting ui of newly joined meeting id: ${(d=i==null?void 0:i.meta)==null?void 0:d.meetingId}`),this.connectedMeetings.emit("meetingChanged",i),i})}handleConnectedRoomsDump(s){const t=n(this,pe).getValue("connectedMeetingsSocketHandler").handleConnectedRoomsDumpRaw(s);this.connectedMeetings.meetings=t.meetings.map(e=>({id:e.id,title:e.title,participants:e.participants||[]})),this.connectedMeetings.parentMeeting={id:t.parentMeeting.id,title:t.parentMeeting.title,participants:t.parentMeeting.participants},this.emitStateUpdate()}handleMovedPeer(s){return n(this,pe).getValue("connectedMeetingsSocketHandler").handleMovedPeerRaw(s)}handleConnectedRoomsUpdated(s){const t=n(this,pe).getValue("connectedMeetingsSocketHandler").handleConnectedRoomsUpdatedRaw(s),e=new Map;this.connectedMeetings.meetings.forEach(r=>{e.set(r.id,r)}),t.forEach(r=>{e.has(r.id)?e.get(r.id).title=r.title:e.set(r.id,G(D({},r),{participants:[]}))}),this.connectedMeetings.meetings=Array.from(e.values()),this.emitStateUpdate()}handleConnectedRoomsDeleted(s){const e=n(this,pe).getValue("connectedMeetingsSocketHandler").handleConnectedRoomsDeletedRaw(s).map(r=>r.id);this.connectedMeetings.meetings=this.connectedMeetings.meetings.filter(r=>!e.includes(r.id)),this.emitStateUpdate()}emitStateUpdate(){this.connectedMeetings.emit("stateUpdate",{meetings:this.connectedMeetings.meetings,parentMeeting:this.connectedMeetings.parentMeeting})}},pe=new WeakMap,xg);let ql=qT;$h([P.trace("ConnectedMeetingsController.getConnectedMeetings")],ql.prototype,"getConnectedMeetings",1);$h([P.trace("ConnectedMeetingsController.setupEvents")],ql.prototype,"setupEvents",1);$h([P.trace("ConnectedMeetingsController.switchMeeting")],ql.prototype,"switchMeeting",1);var bO=Object.defineProperty,kO=Object.getOwnPropertyDescriptor,jl=(s,t,e,r)=>{for(var i=r>1?void 0:r?kO(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&bO(t,e,i),i};const vn=class{constructor(s,t,e){h(this,"apiBase");h(this,"selfController");h(this,"pollController");h(this,"chatController");h(this,"metaController");h(this,"storesManager");h(this,"stageController");h(this,"pluginController");h(this,"internalsController");h(this,"recordingController");h(this,"livestreamController");h(this,"participantController");h(this,"connectedMeetingsController");h(this,"telemetry");h(this,"logger");this.apiBase=s,this.storesManager=t.storesManager,this.metaController=t.metaController,this.selfController=t.selfController,this.chatController=t.chatController,this.pollController=t.pollController,this.stageController=t.stageController,this.pluginController=t.pluginController,this.recordingController=t.recordingController,this.internalsController=t.internalsController,this.participantController=t.participantController,this.livestreamController=t.livestreamController,this.connectedMeetingsController=t.connectedMeetingsController,this.telemetry=e.getValue("telemetry"),this.logger=e.getValue("logger")}static init(s){return u(this,null,function*(){var N,B;const{peerId:t,apiBase:e,authToken:r,meetingId:i,organizationId:a,cachedUserDetails:o,logger:c}=s.getAllValues();if(wT(s),Se.isSupported()===!1)throw new A("Browser not supported","0010",c,!0);const d=NM(s,{authToken:r,baseURL:e,cachedUserDetails:o});d.setRoomName(i),d.setRoomUUID(i),d.setOrganizationId(a),d.setHeader("tracing-id",t),s.setValue("apiClient",d);const l=new m0(s);s.setValue("connectionHandler",l);const p=vn.createSocketService(s),g=p.connect(),T=d.getUserDetails(),v=d.getPlugins();let E,_="";try{yield vn.setupFlagsmith(s)}catch(j){c.error("Failed to setup flagsmith",{error:j})}try{yield g}catch(j){c.error("[Controller]: Failed to connect to socket server:",{error:j})}try{({meetingTitle:_}=yield d.getRoomNodeData()),E=yield T,c.info("CF SFU is being used."),s.setValue("presetName",E.preset.name)}catch(j){c.error("Failed to get room metadata",{error:j})}const C=Nu.init(E.preset,!s.getValue("modules").theme),R=Uu.init(s,C.viewType,E.preset.permissions),L=vn.setupControllers(p,s,E,v,_,C,R);i0(C)&&((N=vn.createRoomNodeClient(s,p).initializeConnection(E.participant.name,i,!1,R))==null||N.catch(re=>{c.error("[Controller]: Failed to queue partial media room promise:",{error:re})})),P.location.country=(B=d.ipInfo)==null?void 0:B.country;const{controllers:F}=yield L;return hw(),new vn(e,F,s)})}static setupFlagsmith(s){return u(this,null,function*(){var l;const{peerId:t,baseURI:e,overrides:r,meetingId:i,organizationId:a,logger:o}=s.getAllValues(),c=uw(i),d=G(D({entity:Tu.PEER,clientId:a,isAnonUser:!a,sdkVersion:s.getValue("sdkVersion"),presetName:s.getValue("presetName"),meetingHash:c,roomName:i},Se.getDeviceInfo()),{isReactNative:navigator.isReactNative});try{const p=(l=r==null?void 0:r.whitelabelled_flags_endpoint)==null||l?Zi({servicePrefix:"flags",baseURI:e}):"edge.api.flagsmith.com";yield s.getValue("flagsmith").identify(`${Tu.PEER}_${t}`,JSON.parse(JSON.stringify(d)),!1,5e3,p,o),o.info("flagsmith::allFlags",{flags:JSON.stringify(s.getValue("flagsmith").getAllFlags())},!0)}catch(p){o.error("Failed to fetch flagsmith flags")}})}static setupControllers(s,t,e,r,i,a,o){return u(this,null,function*(){var V,k,xe;const c=t.getValue("modules"),{participant:d}=e,l=t.getValue("defaults"),p=t.getValue("logger"),{viewType:g,mediaConstraints:{audio:T}}=a;t.setValue("viewType",g),t.setValue("defaults",D({mediaConfiguration:{audio:{enableHighBitrate:(V=T.enableHighBitrate)!=null?V:!1,enableStereo:(k=T.enableStereo)!=null?k:!1}}},l)),t.setValue("maxPreferredStreams",Se.isMobile()?a.maxVideoStreams.mobile:a.maxVideoStreams.desktop);let v,E,_,C,R,L,F,N,B;const j=new JD(t,s),re=new EO(s);t.setValue("connectedMeetingsSocketHandler",re);const et=new Fl(t,s),os=new yr(t,s),ri=new ZD(s),cs=new bT(t,s),I=new eO(t,s),y=new WD(s),w=yield si.init(t,cs,d,o,a);t.setValue("selfController",w);const $=yield kf.init(t,w.self,cs,j,i);if(c.participant&&(N=new Pr(t,w.self,cs)),(xe=c.e2ee)!=null&&xe.enabled&&c.e2ee.manager.init(p,t.getValue("peerSessionStore")),c.chat&&(E=yield is.init(t,os,w.self,N.participants)),c.internals&&(R=yield bh.init(t)),c.livestream&&a.viewType===pr.Livestream&&t.getValue("flagsmith").hasFeature(Z.LIVESTREAM)&&(F=new xf(t,w.self,y)),c.poll&&(v=yield Cf.init(t,w.self,et)),c.recording&&(L=new Df(t,w.self,cs)),c.stage&&(_=new Af(t,ri,cs,w.self,N.participants)),c.plugin){if(!N)throw new A("The plugin module cannot be initialized without the `participant` module","0102");const Fs=yield r;C=yield Nc.init(t,Fs,I,os,E==null?void 0:E.chat,w.self,N.participants,i)}if(c.connectedMeetings&&(B=yield ql.init(t)),c.pip){const Fs=yield vu._init(t,w.self);t.setValue("pip",Fs)}const Ie={storesManager:new aD(t,I),pollController:v,selfController:w,metaController:$,chatController:E,stageController:_,pluginController:C,recordingController:L,internalsController:R,livestreamController:F,participantController:N,connectedMeetingsController:B};return{theme:a,permissions:o,controllers:Ie}})}static createRoomNodeClient(s,t){const{peerId:e}=s.getAllValues();return CT(s,{socket:t,peerId:e})}static createSocketService(s){const{peerId:t,meetingId:e,authToken:r}=s.getAllValues(),i=["PING"];return new Uc(s,{peerId:t,meetingId:e,authToken:r,capabilities:i})}};let $c=vn;jl([P.trace("Controller.init")],$c,"init",1);jl([P.trace("setupFlagsmith")],$c,"setupFlagsmith",1);jl([P.trace("Controller.createRoomNodeClient")],$c,"createRoomNodeClient",1);jl([P.trace("Controller.createSocketService")],$c,"createSocketService",1);class AO{constructor(){h(this,"battery");h(this,"logger");h(this,"init",t=>u(this,null,function*(){this.logger=t;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){t.error("Error getting battery",e)}}));h(this,"updateChargeInfo",()=>{var t;this.logger.log(`Battery charging? ${(t=this.battery)!=null&&t.charging?"Yes":"No"}`)});h(this,"updateLevelInfo",()=>{if(!this.battery){this.logger.log("Battery level: Not known");return}this.logger.log(`Battery level: ${this.battery.level*100}%`)});h(this,"cleanup",()=>{var t,e;"getBattery"in navigator&&((t=this.battery)==null||t.removeEventListener("chargingchange",this.updateChargeInfo),(e=this.battery)==null||e.removeEventListener("levelchange",this.updateLevelInfo))})}}const vg=new AO;function IO(s,t){s.startsWith("eyJ")||console.error("Invalid auth token provided. Ensure you are passing a %cparticipant `authToken`%c — not an Org API Key or an incorrectly formatted token.\nYou get the participant token from the Add Participant API: https://docs.realtime.cloudflare.com/api#/operations/add_participant","font-weight: bold","font-weight: normal");try{const{meetingId:e,orgId:r,participantId:i}=JSON.parse(atob(s.split(".")[1]));if(!e)throw Error(`Received V1 auth token ${s}`);let a=ui.baseURI.prod;t&&(a=t);const o=`https://${Zi({servicePrefix:"api",baseURI:a})}`;return{meetingId:e,orgId:r,participantId:i,baseURI:a,apiBase:o}}catch(e){throw new A("Invalid auth token","0004")}}var Jr,zi,Yi,bc,El,jT;class MO{constructor(){m(this,El);m(this,Jr,new Audio);m(this,zi,new MediaStream);m(this,Yi,new Map);m(this,bc,void 0);n(this,Jr).srcObject=n(this,zi),n(this,Jr).autoplay=!0}playTracks(t){return u(this,null,function*(){return t.forEach(e=>{n(this,Yi).has(e.id)||(n(this,zi).addTrack(e),n(this,Yi).set(e.id,e))}),this.play()})}setSpeakerDevice(t){typeof HTMLAudioElement.prototype.setSinkId=="function"&&n(this,Jr).setSinkId(t)}removeTrack(t){const e=n(this,Yi).get(t);e&&(n(this,zi).removeTrack(e),n(this,Yi).delete(t))}play(){return u(this,null,function*(){return n(this,Jr).srcObject=n(this,zi),n(this,Jr).play().catch(t=>{x(this,El,jT).call(this,t)})})}onError(t){f(this,bc,t)}}Jr=new WeakMap,zi=new WeakMap,Yi=new WeakMap,bc=new WeakMap,El=new WeakSet,jT=function(t){var e;(e=n(this,bc))==null||e.call(this,t)};var Qi;class DO extends MO{constructor(){super();m(this,Qi,void 0);f(this,Qi,new Map)}addParticipantTrack(e,r){n(this,Qi).set(e,r.id),this.playTracks([r])}removeParticipantTrack(e){const r=n(this,Qi).get(e);r&&this.removeTrack(r),n(this,Qi).delete(e)}}Qi=new WeakMap;var OO=Object.defineProperty,NO=Object.getOwnPropertyDescriptor,Gl=(s,t,e,r)=>{for(var i=r>1?void 0:r?NO(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&OO(t,e,i),i},je,Xi,Ug;let Xr=(Ug=class{constructor(t,e){m(this,je,void 0);m(this,Xi,void 0);f(this,Xi,t),f(this,je,e)}get peerId(){return n(this,Xi).getValue("peerId")}static initMedia(){return u(this,arguments,function*(t={},e=!1,r=void 0){var d;const i=(d=r==null?void 0:r.peerId)!=null?d:gr.v4(),a=ur.createContext(i,{peerId:i}),o=a.getValue("logger");o.init(a);const c=new Gf(a,o);return yield c.init(t,e,a),a.setValue("defaults",{mediaHandler:c}),c})}static init(t){return u(this,null,function*(){var v,E,_,R,L,F,N;Se.init();const{mediaHandler:e}=(v=t.defaults)!=null?v:{},r=(e==null?void 0:e.peerId)||((_=(E=t==null?void 0:t.cachedUserDetails)==null?void 0:E.peerId)!=null?_:gr.v4()),{authToken:i,baseURI:a}=t,C=IO(i,a),{meetingId:o}=C,c=Bc(C,["meetingId"]);window.__zone_symbol__DISABLE_WRAPPING_UNCAUGHT_PROMISE_REJECTION=!0;const d=Xr.setupContext(r,t,o,c),l=d.getValue("telemetry"),p=d.getValue("logger");tv(p),vg.init(p),l.init(d,{roomName:o,userId:c.participantId,organizationId:c.orgId,peerId:r},(L=(R=t.modules)==null?void 0:R.tracing)!=null?L:!0),p.init(d),p.info("Client::init::options",{clientInitOptions:G(D({},t),{authToken:`${(F=t.authToken)==null?void 0:F.slice(0,10)}...
|
|
13
|
-
${(N=t.authToken)==null?void 0:N.slice(-10)}`})});const g=yield $c.init(d),T=new Xr(d,g);return d.setValue("meeting",T),T})}static setupContext(t,e,r,i){var d,l;const a=ur.createContext(t,e),o=D(D({},tw),e==null?void 0:e.modules),c=e.defaults||{audio:!0,video:!0};return a.setValue("options",e),a.setValue("peerId",t),a.setValue("modules",o),a.setValue("sdkName","web-core"),a.setValue("meetingId",r),a.setValue("apiBase",i.apiBase),a.setValue("baseURI",i.baseURI),a.setValue("userId",i.participantId),a.setValue("organizationId",i.orgId),a.setValue("authToken",e.authToken),a.setValue("overrides",(d=e.overrides)!=null?d:{}),a.setValue("env",sw({baseURI:i.baseURI})),a.setValue("defaults",c),a.setValue("onError",e.onError||(()=>{})),a.setValue("cachedUserDetails",_s(e.cachedUserDetails)),a.setValue("sdkVersion","1.2.5-staging.1"),(l=e.modules)!=null&&l.experimentalAudioPlayback&&a.setValue("audioPlayback",new DO),a}join(){return u(this,null,function*(){const{selfController:t}=n(this,je);return t.self.roomJoined?null:t.joinRoom()})}leave(t){return u(this,null,function*(){vg.cleanup(),n(this,Xi).getValue("peerSessionStore").reset();const{selfController:e}=n(this,je);return e.leaveRoom(t)})}get participants(){var t;return(t=n(this,je).participantController)==null?void 0:t.participants}get self(){var t;return(t=n(this,je).selfController)==null?void 0:t.self}get meta(){var t;return(t=n(this,je).metaController)==null?void 0:t.meta}get ai(){var t;return(t=n(this,je).metaController)==null?void 0:t.ai}get plugins(){var t;return(t=n(this,je).pluginController)==null?void 0:t.plugins}get chat(){var t;return(t=n(this,je).chatController)==null?void 0:t.chat}get polls(){var t;return(t=n(this,je).pollController)==null?void 0:t.polls}get connectedMeetings(){var t;return(t=n(this,je).connectedMeetingsController)==null?void 0:t.connectedMeetings}get recording(){var t;return(t=n(this,je).recordingController)==null?void 0:t.recording}get livestream(){var t;return(t=n(this,je).livestreamController)==null?void 0:t.livestream}get stage(){var t;return(t=n(this,je).stageController)==null?void 0:t.stage}get stores(){return n(this,je).storesManager}get audio(){return n(this,Xi).getValue("audioPlayback")}get __internals__(){var t;return(t=n(this,je).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)})}},je=new WeakMap,Xi=new WeakMap,Ug);Gl([dt("0002"),Er.executeWithLock({methodName:"meeting.join",lockName:"Client.join",timeout:3e3})],Xr.prototype,"join",1);Gl([dt("0003")],Xr.prototype,"leave",1);Gl([dt("0001"),Er.executeWithLock({methodName:"Client.init",lockName:"Client.init",timeout:3e3})],Xr,"init",1);Xr=Gl([dt("0000")],Xr);const GT=Xr;module.exports=GT;
|
|
1
|
+
"use strict";var am=Object.defineProperty,om=Object.defineProperties;var cm=Object.getOwnPropertyDescriptors;var wo=Object.getOwnPropertySymbols,dm=Object.getPrototypeOf,Zl=Object.prototype.hasOwnProperty,eu=Object.prototype.propertyIsEnumerable,lm=Reflect.get;var pd=(s,t,e)=>t in s?am(s,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):s[t]=e,b=(s,t)=>{for(var e in t||(t={}))Zl.call(t,e)&&pd(s,e,t[e]);if(wo)for(var e of wo(t))eu.call(t,e)&&pd(s,e,t[e]);return s},U=(s,t)=>om(s,cm(t));var Co=(s,t)=>{var e={};for(var r in s)Zl.call(s,r)&&t.indexOf(r)<0&&(e[r]=s[r]);if(s!=null&&wo)for(var r of wo(s))t.indexOf(r)<0&&eu.call(s,r)&&(e[r]=s[r]);return e};var g=(s,t,e)=>(pd(s,typeof t!="symbol"?t+"":t,e),e),gd=(s,t,e)=>{if(!t.has(s))throw TypeError("Cannot "+e)};var n=(s,t,e)=>(gd(s,t,"read from private field"),e?e.call(s):t.get(s)),h=(s,t,e)=>{if(t.has(s))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(s):t.set(s,e)},f=(s,t,e,r)=>(gd(s,t,"write to private field"),r?r.call(s,e):t.set(s,e),e);var M=(s,t,e)=>(gd(s,t,"access private method"),e),tu=(s,t,e)=>lm(dm(s),e,t);var l=(s,t,e)=>new Promise((r,i)=>{var a=d=>{try{c(e.next(d))}catch(u){i(u)}},o=d=>{try{c(e.throw(d))}catch(u){i(u)}},c=d=>d.done?r(d.value):Promise.resolve(d.value).then(a,o);c((e=e.apply(s,t)).next())});const As=require("uuid"),$h=require("bowser"),Uh=require("@cloudflare/realtimekit-callstats"),I=require("@cloudflare/realtimekit-utils"),y=require("@protobuf-ts/runtime"),um=require("worker-timers"),hm=require("sdp-transform"),pm=require("@cloudflare/realtimekit-sockrates");function qh(s){const t=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(s){for(const e in s)if(e!=="default"){const r=Object.getOwnPropertyDescriptor(s,e);Object.defineProperty(t,e,r.get?r:{enumerable:!0,get:()=>s[e]})}}return t.default=s,Object.freeze(t)}const Vo=qh(um),Ot=qh(hm);function gm(s){const{length:t}=this,e=s>=0?s:t+s;return e<0||e>=t?void 0:this[e]}Array.prototype.at||Object.assign(Array.prototype,{at:gm});function mm(s){const{length:t}=this,e=s>=0?s:t+s;return e<0||e>=t?void 0:this[e]}String.prototype.at||Object.assign(String.prototype,{at:mm});const fm=s=>{!navigator.isReactNative&&typeof window!="undefined"&&(window.addEventListener("error",t=>{var e;!((e=t.filename)!=null&&e.includes("localhost"))&&t.lineno!==0&&s.error("window::error",{error:t.error},!0)}),window.addEventListener("unhandledrejection",t=>{var e,r,i,a,o,c,d,u;s.error("window::unhandledrejection",{error:t==null?void 0:t.reason,networkCall:{url:(r=(e=t==null?void 0:t.reason)==null?void 0:e.config)==null?void 0:r.url,baseURL:(a=(i=t==null?void 0:t.reason)==null?void 0:i.config)==null?void 0:a.baseURL,method:(c=(o=t==null?void 0:t.reason)==null?void 0:o.config)==null?void 0:c.method,status:(d=t==null?void 0:t.reason)==null?void 0:d.status,statusText:(u=t==null?void 0:t.reason)==null?void 0:u.statusText}},!0)}),window.addEventListener("offline",()=>{s.info("window::offline")}),window.addEventListener("online",()=>{s.info("window::online")}))},ta="chrome",Hh="opera",Fh="firefox",Bh="iexplorer",jh="safari",Gh="nwjs",Jh="electron",Wh="react-native",vl="unknown",Jo={Chrome:ta,Chromium:ta,Opera:Hh,Firefox:Fh,"Internet Explorer":Bh,Safari:jh};function Tm(){const{userAgent:s}=navigator,t={name:vl,version:void 0};if(s.match(/Chrome/)&&!s.match(/Edge/))if(s.match(/Edg(A?)/)){const e=s.match(/Chrome\/([\d.]+)/)[1];Number.parseInt(e,10)>72&&(t.name=ta,t.version=e)}else t.name=ta,t.version=s.match(/Chrome\/([\d.]+)/)[1];return t}function ym(){const{userAgent:s}=navigator;if(s.match(/Electron/)){const t=s.match(/Electron\/([\d.]+)/)[1];return{name:Jh,version:t}}return null}function vm(){const{userAgent:s}=navigator;if(s.match(/JitsiMeetNW/)){const t=s.match(/JitsiMeetNW\/([\d.]+)/)[1];return{name:Gh,version:t}}}function Sm(){const s=navigator.userAgent.match(/\b(react[ \t_-]*native)(?:\/(\S+))?/i);let t;if(s||navigator.product==="ReactNative")return s&&s.length>2&&(s[1],t=s[2]),t||(t="unknown"),{name:Wh,version:t}}function Pm(s){let t;const e=[Sm,ym,vm];for(let i=0;i<e.length;i+=1)if(t=e[i](),t)return t;const r=s.getBrowserName();return r in Jo?{name:Jo[r],version:s.getBrowserVersion()}:(t=Tm(),t||{name:vl,version:void 0})}class Em{constructor(){g(this,"_bowser");g(this,"_name");g(this,"_version");g(this,"getDeviceInfo",()=>({isMobile:this.isMobile(),browserName:this._bowser.getBrowserName(),osName:this._bowser.getOSName(),browserVersion:this._bowser.getBrowserVersion(),osVersionName:this._bowser.getOSVersion(),engineName:this._bowser.getEngineName()}))}init(t){let e,r;if(this._bowser=$h.getParser(navigator.userAgent),typeof t=="undefined"){const i=Pm(this._bowser);e=i.name,r=i.version}else t.name in Jo?(e=Jo[t.name],r=t.version):(e=vl,r=void 0);this._name=e,this._version=r}getName(){return this._name}isChrome(){return this._name===ta}isOpera(){return this._name===Hh}isFirefox(){return this._name===Fh}isIExplorer(){return this._name===Bh}isSafari(){return this._name===jh}isNWJS(){return this._name===Gh}isElectron(){return this._name===Jh}isReactNative(){return this._name===Wh||navigator.isReactNative===!0}getVersion(){return this._version}isMobile(){return this._bowser.getPlatformType()==="mobile"}_checkCondition(t){if(this._version)return this._bowser.satisfies(t)}isVersionGreaterThan(t){return this._checkCondition({[this._name]:`>${t}`})}isVersionLessThan(t){return this._checkCondition({[this._name]:`<${t}`})}isVersionEqualTo(t){return this._checkCondition({[this._name]:`~${t}`})}}class wm extends Em{doesVideoMuteByStreamRemove(){return this.isChromiumBased()||this.isWebKitBased()}supportsP2P(){return!this.usesUnifiedPlan()}isChromiumBased(){return this.isChrome()||this.isElectron()||this.isNWJS()||this.isOpera()}isWebKitBased(){return this._bowser.isEngine("webkit")&&typeof navigator.mediaDevices!="undefined"&&typeof navigator.mediaDevices.getUserMedia!="undefined"&&typeof window.RTCRtpTransceiver!="undefined"&&Object.keys(RTCRtpTransceiver.prototype).indexOf("currentDirection")>-1}isSupported(){return typeof RTCPeerConnection!="undefined"}isUserInteractionRequiredForUnmute(){return this.isFirefox()&&this.isVersionLessThan("68")}supportsVideoMuteOnConnInterrupted(){return this.isChromiumBased()||this.isReactNative()||this.isWebKitBased()}supportsBandwidthStatistics(){return!this.isFirefox()&&!this.isWebKitBased()}supportsCodecPreferences(){return this.usesUnifiedPlan()&&typeof window.RTCRtpTransceiver!="undefined"&&Object.keys(window.RTCRtpTransceiver.prototype).indexOf("setCodecPreferences")>-1&&Object.keys(RTCRtpSender.prototype).indexOf("getCapabilities")>-1&&!this.isWebKitBased()}supportsDeviceChangeEvent(){return navigator.mediaDevices&&typeof navigator.mediaDevices.ondevicechange!="undefined"&&typeof navigator.mediaDevices.addEventListener!="undefined"}supportsLocalCandidateRttStatistics(){return this.isChromiumBased()||this.isReactNative()||this.isWebKitBased()}supportsPerformanceObserver(){return typeof window.PerformanceObserver!="undefined"&&PerformanceObserver.supportedEntryTypes.indexOf("longtask")>-1}supportsReceiverStats(){return typeof window.RTCRtpReceiver!="undefined"&&Object.keys(RTCRtpReceiver.prototype).indexOf("getSynchronizationSources")>-1}supportsRTTStatistics(){return!this.isFirefox()}usesPlanB(){return!this.usesUnifiedPlan()}usesSdpMungingForSimulcast(){return this.isChromiumBased()||this.isReactNative()||this.isWebKitBased()}usesUnifiedPlan(){return!!(this.isFirefox()||this.isWebKitBased())}usesNewGumFlow(){return!!(this.isChromiumBased()||this.isFirefox()||this.isWebKitBased())}usesAdapter(){return this.usesNewGumFlow()}usesRidsForSimulcast(){return!1}supportsGetDisplayMedia(){return typeof navigator.getDisplayMedia!="undefined"||typeof navigator.mediaDevices!="undefined"&&typeof navigator.mediaDevices.getDisplayMedia!="undefined"}supportsInsertableStreams(){if(!(typeof window.RTCRtpSender!="undefined"&&(window.RTCRtpSender.prototype.createEncodedStreams||window.RTCRtpSender.prototype.createEncodedVideoStreams)))return!1;const t=new ReadableStream;try{return window.postMessage(t,"*",[t]),!0}catch(e){return!1}}supportsAudioRed(){return Boolean(window.RTCRtpSender&&window.RTCRtpSender.getCapabilities&&window.RTCRtpSender.getCapabilities("audio").codecs.some(t=>t.mimeType==="audio/red")&&window.RTCRtpReceiver&&window.RTCRtpReceiver.getCapabilities&&window.RTCRtpReceiver.getCapabilities("audio").codecs.some(t=>t.mimeType==="audio/red"))}supportsSdpSemantics(){return this.isChromiumBased()}_getChromiumBasedVersion(){if(this.isChromiumBased()){if(this.isNWJS())return Number.parseInt(process.versions.chromium,10);const t=navigator.userAgent;if(t.match(/Chrome/))return Number.parseInt(t.match(/Chrome\/([\d.]+)/)[1],10)}return-1}isIOSMobile(){return this.isMobile&&this._bowser.getOSName()==="iOS"}}const Z=new wm;var ca;class Kh{constructor(){h(this,ca,void 0)}get telemetry(){var t;return(t=n(this,ca))==null?void 0:t.getValue("telemetry")}init(t){f(this,ca,t)}info(t,e,r){var i;(i=this.telemetry)==null||i.addLogInCurrentSpan("info",t,e,r)}error(t,e,r){var i;(i=this.telemetry)==null||i.addLogInCurrentSpan("error",t,e,r)}debug(t,e,r){var i;(i=this.telemetry)==null||i.addLogInCurrentSpan("debug",t,e,r)}log(t,e,r){var i;(i=this.telemetry)==null||i.addLogInCurrentSpan("log",t,e,r)}warn(t,e,r){var i;(i=this.telemetry)==null||i.addLogInCurrentSpan("warn",t,e,r)}}ca=new WeakMap;var Is={},Cm={get exports(){return Is},set exports(s){Is=s}},Ai=typeof Reflect=="object"?Reflect:null,su=Ai&&typeof Ai.apply=="function"?Ai.apply:function(t,e,r){return Function.prototype.apply.call(t,e,r)},xo;Ai&&typeof Ai.ownKeys=="function"?xo=Ai.ownKeys:Object.getOwnPropertySymbols?xo=function(t){return Object.getOwnPropertyNames(t).concat(Object.getOwnPropertySymbols(t))}:xo=function(t){return Object.getOwnPropertyNames(t)};function _m(s){console&&console.warn&&console.warn(s)}var zh=Number.isNaN||function(t){return t!==t};function G(){G.init.call(this)}Cm.exports=G;Is.once=Mm;G.EventEmitter=G;G.prototype._events=void 0;G.prototype._eventsCount=0;G.prototype._maxListeners=void 0;var ru=10;function Wc(s){if(typeof s!="function")throw new TypeError('The "listener" argument must be of type Function. Received type '+typeof s)}Object.defineProperty(G,"defaultMaxListeners",{enumerable:!0,get:function(){return ru},set:function(s){if(typeof s!="number"||s<0||zh(s))throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received '+s+".");ru=s}});G.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};G.prototype.setMaxListeners=function(t){if(typeof t!="number"||t<0||zh(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 Yh(s){return s._maxListeners===void 0?G.defaultMaxListeners:s._maxListeners}G.prototype.getMaxListeners=function(){return Yh(this)};G.prototype.emit=function(t){for(var e=[],r=1;r<arguments.length;r++)e.push(arguments[r]);var i=t==="error",a=this._events;if(a!==void 0)i=i&&a.error===void 0;else if(!i)return!1;if(i){var o;if(e.length>0&&(o=e[0]),o instanceof Error)throw o;var c=new Error("Unhandled error."+(o?" ("+o.message+")":""));throw c.context=o,c}var d=a[t];if(d===void 0)return!1;if(typeof d=="function")su(d,this,e);else for(var u=d.length,p=tp(d,u),r=0;r<u;++r)su(p[r],this,e);return!0};function Qh(s,t,e,r){var i,a,o;if(Wc(e),a=s._events,a===void 0?(a=s._events=Object.create(null),s._eventsCount=0):(a.newListener!==void 0&&(s.emit("newListener",t,e.listener?e.listener:e),a=s._events),o=a[t]),o===void 0)o=a[t]=e,++s._eventsCount;else if(typeof o=="function"?o=a[t]=r?[e,o]:[o,e]:r?o.unshift(e):o.push(e),i=Yh(s),i>0&&o.length>i&&!o.warned){o.warned=!0;var c=new Error("Possible EventEmitter memory leak detected. "+o.length+" "+String(t)+" listeners added. Use emitter.setMaxListeners() to increase limit");c.name="MaxListenersExceededWarning",c.emitter=s,c.type=t,c.count=o.length,_m(c)}return s}G.prototype.addListener=function(t,e){return Qh(this,t,e,!1)};G.prototype.on=G.prototype.addListener;G.prototype.prependListener=function(t,e){return Qh(this,t,e,!0)};function Rm(){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 Xh(s,t,e){var r={fired:!1,wrapFn:void 0,target:s,type:t,listener:e},i=Rm.bind(r);return i.listener=e,r.wrapFn=i,i}G.prototype.once=function(t,e){return Wc(e),this.on(t,Xh(this,t,e)),this};G.prototype.prependOnceListener=function(t,e){return Wc(e),this.prependListener(t,Xh(this,t,e)),this};G.prototype.removeListener=function(t,e){var r,i,a,o,c;if(Wc(e),i=this._events,i===void 0)return this;if(r=i[t],r===void 0)return this;if(r===e||r.listener===e)--this._eventsCount===0?this._events=Object.create(null):(delete i[t],i.removeListener&&this.emit("removeListener",t,r.listener||e));else if(typeof r!="function"){for(a=-1,o=r.length-1;o>=0;o--)if(r[o]===e||r[o].listener===e){c=r[o].listener,a=o;break}if(a<0)return this;a===0?r.shift():km(r,a),r.length===1&&(i[t]=r[0]),i.removeListener!==void 0&&this.emit("removeListener",t,c||e)}return this};G.prototype.off=G.prototype.removeListener;G.prototype.removeAllListeners=function(t){var e,r,i;if(r=this._events,r===void 0)return this;if(r.removeListener===void 0)return arguments.length===0?(this._events=Object.create(null),this._eventsCount=0):r[t]!==void 0&&(--this._eventsCount===0?this._events=Object.create(null):delete r[t]),this;if(arguments.length===0){var a=Object.keys(r),o;for(i=0;i<a.length;++i)o=a[i],o!=="removeListener"&&this.removeAllListeners(o);return this.removeAllListeners("removeListener"),this._events=Object.create(null),this._eventsCount=0,this}if(e=r[t],typeof e=="function")this.removeListener(t,e);else if(e!==void 0)for(i=e.length-1;i>=0;i--)this.removeListener(t,e[i]);return this};function Zh(s,t,e){var r=s._events;if(r===void 0)return[];var i=r[t];return i===void 0?[]:typeof i=="function"?e?[i.listener||i]:[i]:e?bm(i):tp(i,i.length)}G.prototype.listeners=function(t){return Zh(this,t,!0)};G.prototype.rawListeners=function(t){return Zh(this,t,!1)};G.listenerCount=function(s,t){return typeof s.listenerCount=="function"?s.listenerCount(t):ep.call(s,t)};G.prototype.listenerCount=ep;function ep(s){var t=this._events;if(t!==void 0){var e=t[s];if(typeof e=="function")return 1;if(e!==void 0)return e.length}return 0}G.prototype.eventNames=function(){return this._eventsCount>0?xo(this._events):[]};function tp(s,t){for(var e=new Array(t),r=0;r<t;++r)e[r]=s[r];return e}function km(s,t){for(;t+1<s.length;t++)s[t]=s[t+1];s.pop()}function bm(s){for(var t=new Array(s.length),e=0;e<t.length;++e)t[e]=s[e].listener||s[e];return t}function Mm(s,t){return new Promise(function(e,r){function i(o){s.removeListener(t,a),r(o)}function a(){typeof s.removeListener=="function"&&s.removeListener("error",i),e([].slice.call(arguments))}sp(s,t,a,{once:!0}),t!=="error"&&Am(s,i,{once:!0})})}function Am(s,t,e){typeof s.on=="function"&&sp(s,"error",t,e)}function sp(s,t,e,r){if(typeof s.on=="function")r.once?s.once(t,e):s.on(t,e);else if(typeof s.addEventListener=="function")s.addEventListener(t,function i(a){r.once&&s.removeEventListener(t,i),e(a)});else throw new TypeError('The "emitter" argument must be of type EventEmitter. Received type '+typeof s)}var cs,ds;const Jl=class extends Is.EventEmitter{constructor(e){super();h(this,cs,void 0);h(this,ds,void 0);g(this,"asyncPromiseTimeout");g(this,"logger");this.logger=e,f(this,cs,new Map),f(this,ds,new Map),this.asyncPromiseTimeout=8e3}emitAsync(e,...r){return l(this,null,function*(){n(this,cs).set(e,[]);const i=n(this,ds).get(e).map(()=>new Promise(a=>{n(this,cs).get(e).push(a)}));tu(Jl.prototype,this,"emit").call(this,e,...r),yield Promise.race([Promise.all(i),new Promise((a,o)=>setTimeout(()=>o(new Error(`emitAsync failed to resolve for event ${e}.`)),this.asyncPromiseTimeout))]),n(this,cs).delete(e)})}onAsync(e,r){const i=n(this,cs),a=(...o)=>l(this,null,function*(){var d;try{yield r(...o)}catch(u){this.logger.error("[onAsync]",{error:u})}const c=(d=i.get(e))==null?void 0:d.shift();c==null||c()});return n(this,ds).get(e)||n(this,ds).set(e,[]),n(this,ds).get(e).push(a),super.on(e,a)}reset(){f(this,cs,new Map),f(this,ds,new Map),super.removeAllListeners()}};let Id=Jl;cs=new WeakMap,ds=new WeakMap;var Im=typeof global=="object"&&global&&global.Object===Object&&global;const rp=Im;var Om=typeof self=="object"&&self&&self.Object===Object&&self,Dm=rp||Om||Function("return this")();const Jt=Dm;var Nm=Jt.Symbol;const dr=Nm;var ip=Object.prototype,Vm=ip.hasOwnProperty,xm=ip.toString,Hn=dr?dr.toStringTag:void 0;function Lm(s){var t=Vm.call(s,Hn),e=s[Hn];try{s[Hn]=void 0;var r=!0}catch(a){}var i=xm.call(s);return r&&(t?s[Hn]=e:delete s[Hn]),i}var $m=Object.prototype,Um=$m.toString;function qm(s){return Um.call(s)}var Hm="[object Null]",Fm="[object Undefined]",iu=dr?dr.toStringTag:void 0;function gi(s){return s==null?s===void 0?Fm:Hm:iu&&iu in Object(s)?Lm(s):qm(s)}function lr(s){return s!=null&&typeof s=="object"}var Bm="[object Symbol]";function Kc(s){return typeof s=="symbol"||lr(s)&&gi(s)==Bm}function jm(s,t){for(var e=-1,r=s==null?0:s.length,i=Array(r);++e<r;)i[e]=t(s[e],e,s);return i}var Gm=Array.isArray;const bt=Gm;var Jm=1/0,nu=dr?dr.prototype:void 0,au=nu?nu.toString:void 0;function np(s){if(typeof s=="string")return s;if(bt(s))return jm(s,np)+"";if(Kc(s))return au?au.call(s):"";var t=s+"";return t=="0"&&1/s==-Jm?"-0":t}var Wm=/\s/;function Km(s){for(var t=s.length;t--&&Wm.test(s.charAt(t)););return t}var zm=/^\s+/;function Ym(s){return s&&s.slice(0,Km(s)+1).replace(zm,"")}function Gt(s){var t=typeof s;return s!=null&&(t=="object"||t=="function")}var ou=0/0,Qm=/^[-+]0x[0-9a-f]+$/i,Xm=/^0b[01]+$/i,Zm=/^0o[0-7]+$/i,ef=parseInt;function cu(s){if(typeof s=="number")return s;if(Kc(s))return ou;if(Gt(s)){var t=typeof s.valueOf=="function"?s.valueOf():s;s=Gt(t)?t+"":t}if(typeof s!="string")return s===0?s:+s;s=Ym(s);var e=Xm.test(s);return e||Zm.test(s)?ef(s.slice(2),e?2:8):Qm.test(s)?ou:+s}function Sl(s){return s}var tf="[object AsyncFunction]",sf="[object Function]",rf="[object GeneratorFunction]",nf="[object Proxy]";function Pl(s){if(!Gt(s))return!1;var t=gi(s);return t==sf||t==rf||t==tf||t==nf}var af=Jt["__core-js_shared__"];const md=af;var du=function(){var s=/[^.]+$/.exec(md&&md.keys&&md.keys.IE_PROTO||"");return s?"Symbol(src)_1."+s:""}();function of(s){return!!du&&du in s}var cf=Function.prototype,df=cf.toString;function mi(s){if(s!=null){try{return df.call(s)}catch(t){}try{return s+""}catch(t){}}return""}var lf=/[\\^$.*+?()[\]{}|]/g,uf=/^\[object .+?Constructor\]$/,hf=Function.prototype,pf=Object.prototype,gf=hf.toString,mf=pf.hasOwnProperty,ff=RegExp("^"+gf.call(mf).replace(lf,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function Tf(s){if(!Gt(s)||of(s))return!1;var t=Pl(s)?ff:uf;return t.test(mi(s))}function yf(s,t){return s==null?void 0:s[t]}function fi(s,t){var e=yf(s,t);return Tf(e)?e:void 0}var vf=fi(Jt,"WeakMap");const Od=vf;var lu=Object.create,Sf=function(){function s(){}return function(t){if(!Gt(t))return{};if(lu)return lu(t);s.prototype=t;var e=new s;return s.prototype=void 0,e}}();const Pf=Sf;function Ef(s,t,e){switch(e.length){case 0:return s.call(t);case 1:return s.call(t,e[0]);case 2:return s.call(t,e[0],e[1]);case 3:return s.call(t,e[0],e[1],e[2])}return s.apply(t,e)}function wf(){}function Cf(s,t){var e=-1,r=s.length;for(t||(t=Array(r));++e<r;)t[e]=s[e];return t}var _f=800,Rf=16,kf=Date.now;function bf(s){var t=0,e=0;return function(){var r=kf(),i=Rf-(r-e);if(e=r,i>0){if(++t>=_f)return arguments[0]}else t=0;return s.apply(void 0,arguments)}}function Mf(s){return function(){return s}}var Af=function(){try{var s=fi(Object,"defineProperty");return s({},"",{}),s}catch(t){}}();const Wo=Af;var If=Wo?function(s,t){return Wo(s,"toString",{configurable:!0,enumerable:!1,value:Mf(t),writable:!0})}:Sl;const Of=If;var Df=bf(Of);const Nf=Df;function Vf(s,t,e,r){for(var i=s.length,a=e+(r?1:-1);r?a--:++a<i;)if(t(s[a],a,s))return a;return-1}function xf(s){return s!==s}function Lf(s,t,e){for(var r=e-1,i=s.length;++r<i;)if(s[r]===t)return r;return-1}function $f(s,t,e){return t===t?Lf(s,t,e):Vf(s,xf,e)}function Uf(s,t){var e=s==null?0:s.length;return!!e&&$f(s,t,0)>-1}var qf=9007199254740991,Hf=/^(?:0|[1-9]\d*)$/;function El(s,t){var e=typeof s;return t=t==null?qf:t,!!t&&(e=="number"||e!="symbol"&&Hf.test(s))&&s>-1&&s%1==0&&s<t}function wl(s,t,e){t=="__proto__"&&Wo?Wo(s,t,{configurable:!0,enumerable:!0,value:e,writable:!0}):s[t]=e}function po(s,t){return s===t||s!==s&&t!==t}var Ff=Object.prototype,Bf=Ff.hasOwnProperty;function jf(s,t,e){var r=s[t];(!(Bf.call(s,t)&&po(r,e))||e===void 0&&!(t in s))&&wl(s,t,e)}function Gf(s,t,e,r){var i=!e;e||(e={});for(var a=-1,o=t.length;++a<o;){var c=t[a],d=r?r(e[c],s[c],c,e,s):void 0;d===void 0&&(d=s[c]),i?wl(e,c,d):jf(e,c,d)}return e}var uu=Math.max;function Jf(s,t,e){return t=uu(t===void 0?s.length-1:t,0),function(){for(var r=arguments,i=-1,a=uu(r.length-t,0),o=Array(a);++i<a;)o[i]=r[t+i];i=-1;for(var c=Array(t+1);++i<t;)c[i]=r[i];return c[t]=e(o),Ef(s,this,c)}}function Wf(s,t){return Nf(Jf(s,t,Sl),s+"")}var Kf=9007199254740991;function Cl(s){return typeof s=="number"&&s>-1&&s%1==0&&s<=Kf}function go(s){return s!=null&&Cl(s.length)&&!Pl(s)}function zf(s,t,e){if(!Gt(e))return!1;var r=typeof t;return(r=="number"?go(e)&&El(t,e.length):r=="string"&&t in e)?po(e[t],s):!1}function Yf(s){return Wf(function(t,e){var r=-1,i=e.length,a=i>1?e[i-1]:void 0,o=i>2?e[2]:void 0;for(a=s.length>3&&typeof a=="function"?(i--,a):void 0,o&&zf(e[0],e[1],o)&&(a=i<3?void 0:a,i=1),t=Object(t);++r<i;){var c=e[r];c&&s(t,c,r,a)}return t})}var Qf=Object.prototype;function zc(s){var t=s&&s.constructor,e=typeof t=="function"&&t.prototype||Qf;return s===e}function Xf(s,t){for(var e=-1,r=Array(s);++e<s;)r[e]=t(e);return r}var Zf="[object Arguments]";function hu(s){return lr(s)&&gi(s)==Zf}var ap=Object.prototype,eT=ap.hasOwnProperty,tT=ap.propertyIsEnumerable,sT=hu(function(){return arguments}())?hu:function(s){return lr(s)&&eT.call(s,"callee")&&!tT.call(s,"callee")};const sa=sT;function rT(){return!1}var op=typeof exports=="object"&&exports&&!exports.nodeType&&exports,pu=op&&typeof module=="object"&&module&&!module.nodeType&&module,iT=pu&&pu.exports===op,gu=iT?Jt.Buffer:void 0,nT=gu?gu.isBuffer:void 0,aT=nT||rT;const ra=aT;var oT="[object Arguments]",cT="[object Array]",dT="[object Boolean]",lT="[object Date]",uT="[object Error]",hT="[object Function]",pT="[object Map]",gT="[object Number]",mT="[object Object]",fT="[object RegExp]",TT="[object Set]",yT="[object String]",vT="[object WeakMap]",ST="[object ArrayBuffer]",PT="[object DataView]",ET="[object Float32Array]",wT="[object Float64Array]",CT="[object Int8Array]",_T="[object Int16Array]",RT="[object Int32Array]",kT="[object Uint8Array]",bT="[object Uint8ClampedArray]",MT="[object Uint16Array]",AT="[object Uint32Array]",X={};X[ET]=X[wT]=X[CT]=X[_T]=X[RT]=X[kT]=X[bT]=X[MT]=X[AT]=!0;X[oT]=X[cT]=X[ST]=X[dT]=X[PT]=X[lT]=X[uT]=X[hT]=X[pT]=X[gT]=X[mT]=X[fT]=X[TT]=X[yT]=X[vT]=!1;function IT(s){return lr(s)&&Cl(s.length)&&!!X[gi(s)]}function OT(s){return function(t){return s(t)}}var cp=typeof exports=="object"&&exports&&!exports.nodeType&&exports,Zn=cp&&typeof module=="object"&&module&&!module.nodeType&&module,DT=Zn&&Zn.exports===cp,fd=DT&&rp.process,NT=function(){try{var s=Zn&&Zn.require&&Zn.require("util").types;return s||fd&&fd.binding&&fd.binding("util")}catch(t){}}();const mu=NT;var fu=mu&&mu.isTypedArray,VT=fu?OT(fu):IT;const Yc=VT;var xT=Object.prototype,LT=xT.hasOwnProperty;function dp(s,t){var e=bt(s),r=!e&&sa(s),i=!e&&!r&&ra(s),a=!e&&!r&&!i&&Yc(s),o=e||r||i||a,c=o?Xf(s.length,String):[],d=c.length;for(var u in s)(t||LT.call(s,u))&&!(o&&(u=="length"||i&&(u=="offset"||u=="parent")||a&&(u=="buffer"||u=="byteLength"||u=="byteOffset")||El(u,d)))&&c.push(u);return c}function lp(s,t){return function(e){return s(t(e))}}var $T=lp(Object.keys,Object);const UT=$T;var qT=Object.prototype,HT=qT.hasOwnProperty;function up(s){if(!zc(s))return UT(s);var t=[];for(var e in Object(s))HT.call(s,e)&&e!="constructor"&&t.push(e);return t}function hp(s){return go(s)?dp(s):up(s)}function FT(s){var t=[];if(s!=null)for(var e in Object(s))t.push(e);return t}var BT=Object.prototype,jT=BT.hasOwnProperty;function GT(s){if(!Gt(s))return FT(s);var t=zc(s),e=[];for(var r in s)r=="constructor"&&(t||!jT.call(s,r))||e.push(r);return e}function pp(s){return go(s)?dp(s,!0):GT(s)}var JT=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,WT=/^\w*$/;function _l(s,t){if(bt(s))return!1;var e=typeof s;return e=="number"||e=="symbol"||e=="boolean"||s==null||Kc(s)?!0:WT.test(s)||!JT.test(s)||t!=null&&s in Object(t)}var KT=fi(Object,"create");const ia=KT;function zT(){this.__data__=ia?ia(null):{},this.size=0}function YT(s){var t=this.has(s)&&delete this.__data__[s];return this.size-=t?1:0,t}var QT="__lodash_hash_undefined__",XT=Object.prototype,ZT=XT.hasOwnProperty;function ey(s){var t=this.__data__;if(ia){var e=t[s];return e===QT?void 0:e}return ZT.call(t,s)?t[s]:void 0}var ty=Object.prototype,sy=ty.hasOwnProperty;function ry(s){var t=this.__data__;return ia?t[s]!==void 0:sy.call(t,s)}var iy="__lodash_hash_undefined__";function ny(s,t){var e=this.__data__;return this.size+=this.has(s)?0:1,e[s]=ia&&t===void 0?iy:t,this}function hi(s){var t=-1,e=s==null?0:s.length;for(this.clear();++t<e;){var r=s[t];this.set(r[0],r[1])}}hi.prototype.clear=zT;hi.prototype.delete=YT;hi.prototype.get=ey;hi.prototype.has=ry;hi.prototype.set=ny;function ay(){this.__data__=[],this.size=0}function Qc(s,t){for(var e=s.length;e--;)if(po(s[e][0],t))return e;return-1}var oy=Array.prototype,cy=oy.splice;function dy(s){var t=this.__data__,e=Qc(t,s);if(e<0)return!1;var r=t.length-1;return e==r?t.pop():cy.call(t,e,1),--this.size,!0}function ly(s){var t=this.__data__,e=Qc(t,s);return e<0?void 0:t[e][1]}function uy(s){return Qc(this.__data__,s)>-1}function hy(s,t){var e=this.__data__,r=Qc(e,s);return r<0?(++this.size,e.push([s,t])):e[r][1]=t,this}function Ns(s){var t=-1,e=s==null?0:s.length;for(this.clear();++t<e;){var r=s[t];this.set(r[0],r[1])}}Ns.prototype.clear=ay;Ns.prototype.delete=dy;Ns.prototype.get=ly;Ns.prototype.has=uy;Ns.prototype.set=hy;var py=fi(Jt,"Map");const na=py;function gy(){this.size=0,this.__data__={hash:new hi,map:new(na||Ns),string:new hi}}function my(s){var t=typeof s;return t=="string"||t=="number"||t=="symbol"||t=="boolean"?s!=="__proto__":s===null}function Xc(s,t){var e=s.__data__;return my(t)?e[typeof t=="string"?"string":"hash"]:e.map}function fy(s){var t=Xc(this,s).delete(s);return this.size-=t?1:0,t}function Ty(s){return Xc(this,s).get(s)}function yy(s){return Xc(this,s).has(s)}function vy(s,t){var e=Xc(this,s),r=e.size;return e.set(s,t),this.size+=e.size==r?0:1,this}function Vs(s){var t=-1,e=s==null?0:s.length;for(this.clear();++t<e;){var r=s[t];this.set(r[0],r[1])}}Vs.prototype.clear=gy;Vs.prototype.delete=fy;Vs.prototype.get=Ty;Vs.prototype.has=yy;Vs.prototype.set=vy;var Sy="Expected a function";function Rl(s,t){if(typeof s!="function"||t!=null&&typeof t!="function")throw new TypeError(Sy);var e=function(){var r=arguments,i=t?t.apply(this,r):r[0],a=e.cache;if(a.has(i))return a.get(i);var o=s.apply(this,r);return e.cache=a.set(i,o)||a,o};return e.cache=new(Rl.Cache||Vs),e}Rl.Cache=Vs;var Py=500;function Ey(s){var t=Rl(s,function(r){return e.size===Py&&e.clear(),r}),e=t.cache;return t}var wy=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,Cy=/\\(\\)?/g,_y=Ey(function(s){var t=[];return s.charCodeAt(0)===46&&t.push(""),s.replace(wy,function(e,r,i,a){t.push(i?a.replace(Cy,"$1"):r||e)}),t});const Ry=_y;function ky(s){return s==null?"":np(s)}function gp(s,t){return bt(s)?s:_l(s,t)?[s]:Ry(ky(s))}var by=1/0;function Zc(s){if(typeof s=="string"||Kc(s))return s;var t=s+"";return t=="0"&&1/s==-by?"-0":t}function mp(s,t){t=gp(t,s);for(var e=0,r=t.length;s!=null&&e<r;)s=s[Zc(t[e++])];return e&&e==r?s:void 0}function My(s,t,e){var r=s==null?void 0:mp(s,t);return r===void 0?e:r}function Ay(s,t){for(var e=-1,r=t.length,i=s.length;++e<r;)s[i+e]=t[e];return s}var Iy=lp(Object.getPrototypeOf,Object);const fp=Iy;var Oy="[object Object]",Dy=Function.prototype,Ny=Object.prototype,Tp=Dy.toString,Vy=Ny.hasOwnProperty,xy=Tp.call(Object);function Ly(s){if(!lr(s)||gi(s)!=Oy)return!1;var t=fp(s);if(t===null)return!0;var e=Vy.call(t,"constructor")&&t.constructor;return typeof e=="function"&&e instanceof e&&Tp.call(e)==xy}function $y(){this.__data__=new Ns,this.size=0}function Uy(s){var t=this.__data__,e=t.delete(s);return this.size=t.size,e}function qy(s){return this.__data__.get(s)}function Hy(s){return this.__data__.has(s)}var Fy=200;function By(s,t){var e=this.__data__;if(e instanceof Ns){var r=e.__data__;if(!na||r.length<Fy-1)return r.push([s,t]),this.size=++e.size,this;e=this.__data__=new Vs(r)}return e.set(s,t),this.size=e.size,this}function as(s){var t=this.__data__=new Ns(s);this.size=t.size}as.prototype.clear=$y;as.prototype.delete=Uy;as.prototype.get=qy;as.prototype.has=Hy;as.prototype.set=By;var yp=typeof exports=="object"&&exports&&!exports.nodeType&&exports,Tu=yp&&typeof module=="object"&&module&&!module.nodeType&&module,jy=Tu&&Tu.exports===yp,yu=jy?Jt.Buffer:void 0,vu=yu?yu.allocUnsafe:void 0;function Gy(s,t){if(t)return s.slice();var e=s.length,r=vu?vu(e):new s.constructor(e);return s.copy(r),r}function Jy(s,t){for(var e=-1,r=s==null?0:s.length,i=0,a=[];++e<r;){var o=s[e];t(o,e,s)&&(a[i++]=o)}return a}function Wy(){return[]}var Ky=Object.prototype,zy=Ky.propertyIsEnumerable,Su=Object.getOwnPropertySymbols,Yy=Su?function(s){return s==null?[]:(s=Object(s),Jy(Su(s),function(t){return zy.call(s,t)}))}:Wy;const Qy=Yy;function Xy(s,t,e){var r=t(s);return bt(s)?r:Ay(r,e(s))}function Pu(s){return Xy(s,hp,Qy)}var Zy=fi(Jt,"DataView");const Dd=Zy;var ev=fi(Jt,"Promise");const Nd=ev;var tv=fi(Jt,"Set");const Ii=tv;var Eu="[object Map]",sv="[object Object]",wu="[object Promise]",Cu="[object Set]",_u="[object WeakMap]",Ru="[object DataView]",rv=mi(Dd),iv=mi(na),nv=mi(Nd),av=mi(Ii),ov=mi(Od),fr=gi;(Dd&&fr(new Dd(new ArrayBuffer(1)))!=Ru||na&&fr(new na)!=Eu||Nd&&fr(Nd.resolve())!=wu||Ii&&fr(new Ii)!=Cu||Od&&fr(new Od)!=_u)&&(fr=function(s){var t=gi(s),e=t==sv?s.constructor:void 0,r=e?mi(e):"";if(r)switch(r){case rv:return Ru;case iv:return Eu;case nv:return wu;case av:return Cu;case ov:return _u}return t});const Vd=fr;var cv=Jt.Uint8Array;const Ko=cv;function dv(s){var t=new s.constructor(s.byteLength);return new Ko(t).set(new Ko(s)),t}function lv(s,t){var e=t?dv(s.buffer):s.buffer;return new s.constructor(e,s.byteOffset,s.length)}function uv(s){return typeof s.constructor=="function"&&!zc(s)?Pf(fp(s)):{}}var hv="__lodash_hash_undefined__";function pv(s){return this.__data__.set(s,hv),this}function gv(s){return this.__data__.has(s)}function aa(s){var t=-1,e=s==null?0:s.length;for(this.__data__=new Vs;++t<e;)this.add(s[t])}aa.prototype.add=aa.prototype.push=pv;aa.prototype.has=gv;function mv(s,t){for(var e=-1,r=s==null?0:s.length;++e<r;)if(t(s[e],e,s))return!0;return!1}function vp(s,t){return s.has(t)}var fv=1,Tv=2;function Sp(s,t,e,r,i,a){var o=e&fv,c=s.length,d=t.length;if(c!=d&&!(o&&d>c))return!1;var u=a.get(s),p=a.get(t);if(u&&p)return u==t&&p==s;var m=-1,T=!0,v=e&Tv?new aa:void 0;for(a.set(s,t),a.set(t,s);++m<c;){var P=s[m],w=t[m];if(r)var C=o?r(w,P,m,t,s,a):r(P,w,m,s,t,a);if(C!==void 0){if(C)continue;T=!1;break}if(v){if(!mv(t,function(k,R){if(!vp(v,R)&&(P===k||i(P,k,e,r,a)))return v.push(R)})){T=!1;break}}else if(!(P===w||i(P,w,e,r,a))){T=!1;break}}return a.delete(s),a.delete(t),T}function yv(s){var t=-1,e=Array(s.size);return s.forEach(function(r,i){e[++t]=[i,r]}),e}function kl(s){var t=-1,e=Array(s.size);return s.forEach(function(r){e[++t]=r}),e}var vv=1,Sv=2,Pv="[object Boolean]",Ev="[object Date]",wv="[object Error]",Cv="[object Map]",_v="[object Number]",Rv="[object RegExp]",kv="[object Set]",bv="[object String]",Mv="[object Symbol]",Av="[object ArrayBuffer]",Iv="[object DataView]",ku=dr?dr.prototype:void 0,Td=ku?ku.valueOf:void 0;function Ov(s,t,e,r,i,a,o){switch(e){case Iv:if(s.byteLength!=t.byteLength||s.byteOffset!=t.byteOffset)return!1;s=s.buffer,t=t.buffer;case Av:return!(s.byteLength!=t.byteLength||!a(new Ko(s),new Ko(t)));case Pv:case Ev:case _v:return po(+s,+t);case wv:return s.name==t.name&&s.message==t.message;case Rv:case bv:return s==t+"";case Cv:var c=yv;case kv:var d=r&vv;if(c||(c=kl),s.size!=t.size&&!d)return!1;var u=o.get(s);if(u)return u==t;r|=Sv,o.set(s,t);var p=Sp(c(s),c(t),r,i,a,o);return o.delete(s),p;case Mv:if(Td)return Td.call(s)==Td.call(t)}return!1}var Dv=1,Nv=Object.prototype,Vv=Nv.hasOwnProperty;function xv(s,t,e,r,i,a){var o=e&Dv,c=Pu(s),d=c.length,u=Pu(t),p=u.length;if(d!=p&&!o)return!1;for(var m=d;m--;){var T=c[m];if(!(o?T in t:Vv.call(t,T)))return!1}var v=a.get(s),P=a.get(t);if(v&&P)return v==t&&P==s;var w=!0;a.set(s,t),a.set(t,s);for(var C=o;++m<d;){T=c[m];var k=s[T],R=t[T];if(r)var D=o?r(R,k,T,t,s,a):r(k,R,T,s,t,a);if(!(D===void 0?k===R||i(k,R,e,r,a):D)){w=!1;break}C||(C=T=="constructor")}if(w&&!C){var O=s.constructor,N=t.constructor;O!=N&&"constructor"in s&&"constructor"in t&&!(typeof O=="function"&&O instanceof O&&typeof N=="function"&&N instanceof N)&&(w=!1)}return a.delete(s),a.delete(t),w}var Lv=1,bu="[object Arguments]",Mu="[object Array]",_o="[object Object]",$v=Object.prototype,Au=$v.hasOwnProperty;function Uv(s,t,e,r,i,a){var o=bt(s),c=bt(t),d=o?Mu:Vd(s),u=c?Mu:Vd(t);d=d==bu?_o:d,u=u==bu?_o:u;var p=d==_o,m=u==_o,T=d==u;if(T&&ra(s)){if(!ra(t))return!1;o=!0,p=!1}if(T&&!p)return a||(a=new as),o||Yc(s)?Sp(s,t,e,r,i,a):Ov(s,t,d,e,r,i,a);if(!(e&Lv)){var v=p&&Au.call(s,"__wrapped__"),P=m&&Au.call(t,"__wrapped__");if(v||P){var w=v?s.value():s,C=P?t.value():t;return a||(a=new as),i(w,C,e,r,a)}}return T?(a||(a=new as),xv(s,t,e,r,i,a)):!1}function ed(s,t,e,r,i){return s===t?!0:s==null||t==null||!lr(s)&&!lr(t)?s!==s&&t!==t:Uv(s,t,e,r,ed,i)}var qv=1,Hv=2;function Fv(s,t,e,r){var i=e.length,a=i,o=!r;if(s==null)return!a;for(s=Object(s);i--;){var c=e[i];if(o&&c[2]?c[1]!==s[c[0]]:!(c[0]in s))return!1}for(;++i<a;){c=e[i];var d=c[0],u=s[d],p=c[1];if(o&&c[2]){if(u===void 0&&!(d in s))return!1}else{var m=new as;if(r)var T=r(u,p,d,s,t,m);if(!(T===void 0?ed(p,u,qv|Hv,r,m):T))return!1}}return!0}function Pp(s){return s===s&&!Gt(s)}function Bv(s){for(var t=hp(s),e=t.length;e--;){var r=t[e],i=s[r];t[e]=[r,i,Pp(i)]}return t}function Ep(s,t){return function(e){return e==null?!1:e[s]===t&&(t!==void 0||s in Object(e))}}function jv(s){var t=Bv(s);return t.length==1&&t[0][2]?Ep(t[0][0],t[0][1]):function(e){return e===s||Fv(e,s,t)}}function Gv(s,t){return s!=null&&t in Object(s)}function Jv(s,t,e){t=gp(t,s);for(var r=-1,i=t.length,a=!1;++r<i;){var o=Zc(t[r]);if(!(a=s!=null&&e(s,o)))break;s=s[o]}return a||++r!=i?a:(i=s==null?0:s.length,!!i&&Cl(i)&&El(o,i)&&(bt(s)||sa(s)))}function Wv(s,t){return s!=null&&Jv(s,t,Gv)}var Kv=1,zv=2;function Yv(s,t){return _l(s)&&Pp(t)?Ep(Zc(s),t):function(e){var r=My(e,s);return r===void 0&&r===t?Wv(e,s):ed(t,r,Kv|zv)}}function Qv(s){return function(t){return t==null?void 0:t[s]}}function Xv(s){return function(t){return mp(t,s)}}function Zv(s){return _l(s)?Qv(Zc(s)):Xv(s)}function eS(s){return typeof s=="function"?s:s==null?Sl:typeof s=="object"?bt(s)?Yv(s[0],s[1]):jv(s):Zv(s)}function tS(s){return function(t,e,r){for(var i=-1,a=Object(t),o=r(t),c=o.length;c--;){var d=o[s?c:++i];if(e(a[d],d,a)===!1)break}return t}}var sS=tS();const rS=sS;var iS=function(){return Jt.Date.now()};const yd=iS;var nS="Expected a function",aS=Math.max,oS=Math.min;function bl(s,t,e){var r,i,a,o,c,d,u=0,p=!1,m=!1,T=!0;if(typeof s!="function")throw new TypeError(nS);t=cu(t)||0,Gt(e)&&(p=!!e.leading,m="maxWait"in e,a=m?aS(cu(e.maxWait)||0,t):a,T="trailing"in e?!!e.trailing:T);function v(L){var te=r,Yt=i;return r=i=void 0,u=L,o=s.apply(Yt,te),o}function P(L){return u=L,c=setTimeout(k,t),p?v(L):o}function w(L){var te=L-d,Yt=L-u,Un=t-te;return m?oS(Un,a-Yt):Un}function C(L){var te=L-d,Yt=L-u;return d===void 0||te>=t||te<0||m&&Yt>=a}function k(){var L=yd();if(C(L))return R(L);c=setTimeout(k,w(L))}function R(L){return c=void 0,T&&r?v(L):(r=i=void 0,o)}function D(){c!==void 0&&clearTimeout(c),u=0,r=d=i=c=void 0}function O(){return c===void 0?o:R(yd())}function N(){var L=yd(),te=C(L);if(r=arguments,i=this,d=L,te){if(c===void 0)return P(d);if(m)return clearTimeout(c),c=setTimeout(k,t),v(d)}return c===void 0&&(c=setTimeout(k,t)),o}return N.cancel=D,N.flush=O,N}function xd(s,t,e){(e!==void 0&&!po(s[t],e)||e===void 0&&!(t in s))&&wl(s,t,e)}function cS(s){return lr(s)&&go(s)}function Ld(s,t){if(!(t==="constructor"&&typeof s[t]=="function")&&t!="__proto__")return s[t]}function dS(s){return Gf(s,pp(s))}function lS(s,t,e,r,i,a,o){var c=Ld(s,e),d=Ld(t,e),u=o.get(d);if(u){xd(s,e,u);return}var p=a?a(c,d,e+"",s,t,o):void 0,m=p===void 0;if(m){var T=bt(d),v=!T&&ra(d),P=!T&&!v&&Yc(d);p=d,T||v||P?bt(c)?p=c:cS(c)?p=Cf(c):v?(m=!1,p=Gy(d,!0)):P?(m=!1,p=lv(d,!0)):p=[]:Ly(d)||sa(d)?(p=c,sa(c)?p=dS(c):(!Gt(c)||Pl(c))&&(p=uv(d))):m=!1}m&&(o.set(d,p),i(p,d,r,a,o),o.delete(d)),xd(s,e,p)}function wp(s,t,e,r,i){s!==t&&rS(t,function(a,o){if(i||(i=new as),Gt(a))lS(s,t,o,e,wp,r,i);else{var c=r?r(Ld(s,o),a,o+"",s,t,i):void 0;c===void 0&&(c=a),xd(s,o,c)}},pp)}function uS(s,t,e){for(var r=-1,i=s==null?0:s.length;++r<i;)if(e(t,s[r]))return!0;return!1}var hS="[object Map]",pS="[object Set]",gS=Object.prototype,mS=gS.hasOwnProperty;function fS(s){if(s==null)return!0;if(go(s)&&(bt(s)||typeof s=="string"||typeof s.splice=="function"||ra(s)||Yc(s)||sa(s)))return!s.length;var t=Vd(s);if(t==hS||t==pS)return!s.size;if(zc(s))return!up(s).length;for(var e in s)if(mS.call(s,e))return!1;return!0}function TS(s,t){return ed(s,t)}var yS=Yf(function(s,t,e){wp(s,t,e)});const Us=yS;var vS=1/0,SS=Ii&&1/kl(new Ii([,-0]))[1]==vS?function(s){return new Ii(s)}:wf;const PS=SS;var ES=200;function Cp(s,t,e){var r=-1,i=Uf,a=s.length,o=!0,c=[],d=c;if(e)o=!1,i=uS;else if(a>=ES){var u=t?null:PS(s);if(u)return kl(u);o=!1,i=vp,d=new aa}else d=t?[]:c;e:for(;++r<a;){var p=s[r],m=t?t(p):p;if(p=e||p!==0?p:0,o&&m===m){for(var T=d.length;T--;)if(d[T]===m)continue e;t&&d.push(m),c.push(p)}else i(d,m,e)||(d!==c&&d.push(m),c.push(p))}return c}function wS(s){return s&&s.length?Cp(s):[]}function CS(s,t){return s&&s.length?Cp(s,eS(t)):[]}var $d=(s=>(s.PARTICIPANT="PARTICIPANT",s.PEER="PEER",s.CLIENT="CLIENT",s))($d||{});const q={PROPAGATE_KICK_ALL:"propagate_kick_across_rooms",REFRESH_ID_ON_DISCONNECTION:"refresh_id_on_disconnection",SKIP_OTEL_TRACES:"skip_otel_traces",ENABLE_CF_SIMULCAST:"enable_cf_simulcast",CF_TRANSPORT_FORCE_RELAY_ON_ICE_FAILED:"cf_transport_force_relay_on_ice_failed",LOG_LEVEL:"log_level",V1_PLUGINS:"v1_plugins",LIVESTREAM:"feat_livestream",VAL_MIN_FRAMERATE:"val_min_framerate",SCREEENSHARE_ERR_HACK:"screenshare_err_hack",SCREEENSHARE_CONSTRAINTS_RETRY:"screenshare_constraints_retry",VIDEO_CONSTRAINTS:"video_constraints",SCREENSHARE_CONSTRAINTS:"screenshare_constraints",OBS_QUALITY:"obs_quality",ALLOW_SAFARI_MEDIA_MIDDLEWARES:"allow_safari_media_middlewares",EXP_RESHARE:"exp_reshare",SKIP_SETTING_IN_USE_DEVICE:"skip_setting_in_use_device",PRECALL_BANDWIDTH_TEST:"precall_bandwidth_test",DEBUG_SOCKET_JOIN:"debug_socket_join",FORCE_RELAY:"force_relay",FORCE_VIDEO_CODEC:"force_video_codec",TRACK_HINT:"track_hint",OVERRIDE_SIMULCAST_DYNAMIC:"override_simulcast_dynamic",PRECREATE_PRODUCERS:"precreate_producers",DISABLE_OPUS_DTX_CF:"disable_opus_dtx_cf",ENABLE_AUDIO_ACTIVITY_DEBUG_LOGS:"enable_audio_activity_debug_logs",DISABLE_LAYER_SWITCH:"disable_layer_switch"};function Lo(s){const t={};return typeof(s==null?void 0:s.code)=="number"&&(t.code=s.code),typeof(s==null?void 0:s.code)=="string"&&(t.code=s.code.substring(0,100)),typeof(s==null?void 0:s.name)=="string"&&(t.name=s.name.substring(0,500)),typeof(s==null?void 0:s.message)=="string"&&(t.message=s.message.substring(0,500)),typeof(s==null?void 0:s.reason)=="string"&&(t.reason=s.reason.substring(0,500)),typeof(s==null?void 0:s.stack)=="string"&&(t.stack=s.stack.substring(0,500)),t}var Iu;(function(s){s.CHROMIUM="chromum",s.FIREFOX="firefox",s.SAFARI="safari"})(Iu||(Iu={}));const vd={DEVEL:"devel",PREPROD:"preprod",PROD:"prod"};var Ou;(function(s){s.AUDIO="AUDIO",s.VIDEO="VIDEO",s.SPEAKER="SPEAKER",s.SCREENSHARE="SCREENSHARE"})(Ou||(Ou={}));var Du;(function(s){s[s.INIT=0]="INIT",s[s.ACCEPTED=1]="ACCEPTED",s[s.DENIED=2]="DENIED",s[s.SYS_DENIED=3]="SYS_DENIED",s[s.FAILED=4]="FAILED",s[s.NOTFOUND=5]="NOTFOUND",s[s.NOT_APPLICABLE=6]="NOT_APPLICABLE"})(Du||(Du={}));const _S={audio:!0,video:!0,screenshareAudio:!0,screenshareVideo:!0},Fn={baseURL:"http://localhost:5000",createdAt:"2021-08-05T10:49:56.602Z",description:"Develop plugins locally",id:"09259e3b-7be8-46f6-9801-106bf1866e1c",name:"Localhost Dev",organizationId:"4ad15a19-80e2-4105-bf43-48039fd2963e",picture:"https://dyte-uploads.s3.ap-south-1.amazonaws.com/dyte.png",private:!1,published:!0,staggered:!1,tags:["#localhost","#dev"],type:"self_hosted",updatedAt:"2021-08-05T10:50:07.681Z"},RS={pip:!0,poll:!0,chat:!0,stage:!0,theme:!0,plugin:!0,tracing:!0,internals:!0,recording:!0,livestream:!0,participant:!0,connectedMeetings:!0,devTools:{logs:!1}};function Dn(s,t){const e=s.getValue("overrides");return e&&e[t]?e[t]:!1}function kS({baseURI:s}){return s.includes("preprod.dyte")||s.includes("preprod.realtime")?vd.PREPROD:s.includes("devel.dyte")||s.includes("devel.realtime")?vd.DEVEL:vd.PROD}function di({servicePrefix:s,baseURI:t}){return`${s}.${t}`}function _p(s){const t=s.getValue("baseURI");return{location:di({servicePrefix:"location",baseURI:t}),locationLegacy:di({servicePrefix:"location-legacy",baseURI:t}),daCollector:di({servicePrefix:"da-collector",baseURI:t.replace("realtime.cloudflare.com","dyte.io")})}}const bS='<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="m16.242 2.932 4.826 4.826a2.75 2.75 0 0 1-.715 4.404l-4.87 2.435a.75.75 0 0 0-.374.426l-1.44 4.166a1.25 1.25 0 0 1-2.065.476L8.5 16.561 4.06 21H3v-1.06l4.44-4.44-3.105-3.104a1.25 1.25 0 0 1 .476-2.066l4.166-1.44a.75.75 0 0 0 .426-.373l2.435-4.87a2.75 2.75 0 0 1 4.405-.715Zm3.766 5.886-4.826-4.826a1.25 1.25 0 0 0-2.002.325l-2.435 4.871a2.25 2.25 0 0 1-1.278 1.12l-3.789 1.31 6.705 6.704 1.308-3.789a2.25 2.25 0 0 1 1.12-1.277l4.872-2.436a1.25 1.25 0 0 0 .325-2.002Z" fill="currentColor"/></svg>',MS='<svg viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"><path d="M4 12.02c0 1.06.2 2.1.6 3.08l.6 1.42c.22.55.64 1.01 1.17 1.29.27.14.56.21.86.21h2.55c.77 0 1.49-.41 1.87-1.08.5-.87 1.02-1.7 1.72-2.43l1.32-1.39c.44-.46.97-.84 1.49-1.23l.59-.45a.6.6 0 0 0 .23-.47c0-.75-.54-1.57-1.22-1.79a3.34 3.34 0 0 0-2.78.29V4.5a1.5 1.5 0 0 0-2.05-1.4 1.5 1.5 0 0 0-2.9 0A1.5 1.5 0 0 0 6 4.5v.09A1.5 1.5 0 0 0 4 6v6.02ZM8 4.5v4a.5.5 0 0 0 1 0v-5a.5.5 0 0 1 1 0v5a.5.5 0 0 0 1 0v-4a.5.5 0 0 1 1 0v6a.5.5 0 0 0 .85.37h.01c.22-.22.44-.44.72-.58.7-.35 2.22-.57 2.4.5l-.53.4c-.52.4-1.04.78-1.48 1.24l-1.33 1.38c-.75.79-1.31 1.7-1.85 2.63-.21.36-.6.58-1.01.58H7.23a.87.87 0 0 1-.4-.1 1.55 1.55 0 0 1-.71-.78l-.59-1.42a7.09 7.09 0 0 1-.53-2.7V6a.5.5 0 0 1 1 0v3.5a.5.5 0 0 0 1 0v-5a.5.5 0 0 1 1 0Z" fill="currentColor"></path></svg>',Ro=s=>{if(!s)return;if(!s.startsWith("<svg"))return new Promise(a=>{a(s)});const e=new Blob([s],{type:"image/svg+xml"}),r=new Image,i=window.URL.createObjectURL(e);return new Promise((a,o)=>{r.onload=()=>{a(r),window.URL.revokeObjectURL(i)},r.onerror=()=>{o(),window.URL.revokeObjectURL(i)},r.src=i})},Pr={logs:"https://api-silos.dyte.io/otel/logs",mock:{url:"https://mock.dyte.io",domain:"mock.dyte.io",app:"https://app.dyte.io/v2/meeting",stagingApp:"https://app.devel.dyte.io/v2/meeting"},apiBase:{prod:"https://api.dyte.io",staging:"https://api.devel.dyte.io",prodAlternate:"https://api.cluster.dyte.in"},baseURI:{prod:"dyte.io",staging:"devel.dyte.io"}};function AS(s){var r,i,a;const t=typeof navigator!="undefined"&&!navigator.isReactNative&&typeof window!="undefined"&&((r=window.location.host)==null?void 0:r.includes(Pr.baseURI.staging)),e=!!((a=(i=s==null?void 0:s.getValue("modules"))==null?void 0:i.devTools)!=null&&a.logs);return t||e}function IS(s,t){var e;if(s!=null&&s.getValue("flagsmith").hasFeature(q.LOG_LEVEL)){let r=((e=s.getValue("flagsmith").getValue(q.LOG_LEVEL))==null?void 0:e.toString())||"all";if(r=r.toLowerCase().trim(),r==="off")return!1;if(r!=="all"){const i=["debug","log","info","warn","error"],a=i.indexOf(t),o=i.indexOf(r);if(a<o)return!1}}return!0}function Rp(s,t,e={}){return Object.getOwnPropertyNames(s).forEach(r=>{var a;if([null,void 0,NaN].includes(s[r])||t&&(((a=t.match(/\./g))==null?void 0:a.length)||0)>=10)return;const i=t?`${t}.${r}`:r;typeof s[r]=="object"?Rp(s[r],i,e):["number","string","boolean"].includes(typeof s[r])&&(e[i]=s[r])}),e}function Nu(s,t,e={},r=""){const i={};try{const a=JSON.stringify(e),o=JSON.parse(a),c=Rp(o,r),d=JSON.stringify(c);return JSON.parse(d)}catch(a){const o=Lo(a);i[`${r}.error.message`]=o.message||"",i[`${r}.error.stack`]=o.stack||"",i[`${r}.error.reason`]=o.reason||"",i[`${r}.error.source`]="safelyFlattenObjForOpenTelemetry"}return i}const Wl=class{constructor(){g(this,"logsCache",[]);g(this,"logsProcessorTimer");g(this,"tracingEnabled",!0);g(this,"initialized",!1);g(this,"logsProcessingInterval",7e3);g(this,"logExclusionList",["message","websocket/message","roomMessage","websocket/room-message","websocket/room-legacy-mode","chatMessage","websocket/new-chat-message","websocket/no-active-speaker","websocket/selected-peers","websocket/active-speaker","ping","websocket/new-consumer","websocket/producer-score","websocket/consumer-score","websocket/plugin-event","websocket/plugin-data","websocket/plugin-internal-data"]);g(this,"meetingMetadata",{})}get logsEndpoint(){const t=Ms.getContext(this.meetingMetadata.peerId);return`https://${di({servicePrefix:"api-silos",baseURI:t.getValue("baseURI")})}/otel/logs`}resetPeerId(t){this.meetingMetadata.peerId=t}init(t,e,r){this.tracingEnabled=!0,this.initialized=!1,this.logsCache=[];const i=t.getValue("peerId");this.meetingMetadata=e,this.tracingEnabled=r,this.meetingMetadata.peerId=i,this.meetingMetadata.sdkVersion=t.getValue("sdkVersion");const{RNDeviceInfoImpl:a}=navigator;this.meetingMetadata.deviceInfo=navigator.isReactNative?a==null?void 0:a.getDeviceInfo():Z.getDeviceInfo(),this.meetingMetadata.visitedUrl=!navigator.isReactNative&&typeof window!="undefined"&&window.location.href,this.logsProcessorTimer=setInterval(this.processCachedLogs.bind(this),this.logsProcessingInterval),r&&(this.initialized=!0)}static trace(t,e=void 0){return(r,i,a)=>{const o=a.value;return a.value=function(...d){var T;const u=this==null?void 0:this.telemetry;if(!u||!u.initialized||navigator.isReactNative||!u.tracingEnabled||(T=Ms.getContext(u.meetingMetadata.peerId))!=null&&T.getValue("flagsmith").hasFeature(q.SKIP_OTEL_TRACES))return o.apply(this,d);u.addLogInCurrentSpan("info",t,e);const p=performance.now(),m=o.apply(this,d);return Promise.resolve(m).then(()=>{const v=performance.now();v-p>10&&u.addLogInCurrentSpan("info",`${t}_timing`,{execTime:v-p,country:Wl.location.country})}).catch(()=>{const v=performance.now();u.addLogInCurrentSpan("info",`${t}_timing`,{execTime:v-p})}),m},a}}injectContext(t){var i;const e=As.v4().replace(/-/g,"").substring(0,16),r=(i=this.meetingMetadata.peerId)==null?void 0:i.replace(/-/g,"");t.TRACEPARENT=`00-${r}-${e}-01`}addLogInCurrentSpan(t,e,r={},i=!1){r!=null&&r.error&&Object.assign(r,{error:Lo(r.error)});const a=Ms.getContext(this.meetingMetadata.peerId);if(AS(a)&&(fS(r)?console[t]("InternalLogs:: ",t,e):console[t]("InternalLogs:: ",t,e,r)),!!IS(a,t))try{const c=Nu(a,e,r,"metadata"),d=new Date,u=U(b({message:e,level:t},c),{loggedAt:d.toISOString(),loggedAtTzOffset:d.getTimezoneOffset()});i?this.sendOtelLogsToNewRelic([u]):this.logsCache.push(u)}catch(c){this.addLogInCurrentSpan("error","opentelemetry::addLogInCurrentSpan_failed",{error:Lo(c)})}}sendOtelLogsToNewRelic(t){const e=Ms.getContext(this.meetingMetadata.peerId);fetch(this.logsEndpoint,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({meetingMetadata:Nu(e,"sendOtelLogsToNewRelic",this.meetingMetadata,"meetingMetadata"),serviceName:e.getValue("sdkName"),logs:t})}).catch(r=>{this.addLogInCurrentSpan("error","opentelemetry::sendOtelLogToNewRelic_failed",{error:Lo(r)}),this.logsCache.push(...t)})}processCachedLogs(){const t=this.logsCache.splice(0,25);t!=null&&t.length&&this.sendOtelLogsToNewRelic(t)}destruct(){clearInterval(this.logsProcessorTimer),this.processCachedLogs()}};let S=Wl;g(S,"location",{country:void 0});function OS(s){const t=b({},s),e=new Map,r=(u,p)=>(e.has(u)||e.set(u,new Set),e.get(u).add(p),()=>{var m;return(m=e.get(u))==null?void 0:m.delete(p)}),i=(u,p)=>{var m;(m=e.get(u))==null||m.delete(p)},a=u=>{var p;(p=e.get(u))==null||p.forEach(m=>{try{m(t[u])}catch(T){}})};return{subscribe:r,unsubscribe:i,notify:a,setValue:(u,p,m=!0)=>{t[u]=p,m&&a(u)},getValue:u=>t[u],getAllValues:()=>t}}class DS{constructor(){g(this,"contexts",new Map);g(this,"mostRecentPeerId",null)}createContext(t,e){if(this.contexts.has(t))return this.contexts.get(t);const r=new S,i=new Kh;this.contexts.set(t,OS(e)),this.contexts.get(t).setValue("peerSessionStore",new Id(i));const a=new Uh.InhouseCallStats;return a.setMaxListeners(50),this.contexts.get(t).setValue("logger",i),this.contexts.get(t).setValue("telemetry",r),this.contexts.get(t).setValue("callstats",a),this.contexts.get(t).setValue("flagsmith",I.createNewFlagsmithInstance()),this.mostRecentPeerId=t,this.contexts.get(t)}remapContext(t,e){const r=e.getValue("peerId");r!==t&&(e.setValue("peerId",t),this.mostRecentPeerId=t,this.contexts.set(t,e),this.contexts.delete(r))}getContext(t){return this.contexts.get(t)}getMostRecentPeerId(){return this.mostRecentPeerId}}const Ms=new DS,NS={"00":"Client","01":"Controller","02":"RoomNodeClient","03":"HiveNodeClient","04":"SocketService","05":"Chat","06":"Plugin","07":"Polls","08":"Meta","09":"Preset",10:"Recording",11:"Self",12:"Participant",13:"Spotlight",14:"Remote Request",15:"Webinar",16:"LocalMediaHandler",17:"End-End Encryption",18:"AI",19:"Livestream",20:"Stage"},$o={"0000":"Internal exception.","0001":"Failed to initialize.","0002":"Failed to join room.","0003":"Failed to leave room.","0004":"Invalid auth token","0010":"Browser not supported","0011":"HTTP Network Error","0012":"Websocket Network Error","0013":"Rate Limited","0100":"Internal exception","0101":"Permission denied","0102":"Prerequisite module missing","0200":"Internal exception.","0300":"Internal exception","0400":"Internal exception","0404":"Missing prerequisites to establish a websocket connection","0500":"Internal exception","0501":"Permission denied.","0502":"Invalid message body.","0503":"Text Message is too large","0504":"Message not found by the given id","0505":"Action not permitted without joining room","0506":"Message search is disabled","0600":"Internal exception","0601":"Permission denied.","0602":"Auth token not set for plugin","0603":"Iframe was not provided","0700":"Internal exception","0705":"Action not permitted without joining room","0800":"Internal exception","0801":"Permission denied","0900":"Internal exception","0904":"Could not load preset",1e3:"Internal exception",1001:"Permission denied",1004:"Could not find specified recording",1005:"Action not permitted in given recording state",1100:"Internal exception",1101:"Permission denied",1102:"Unsupported",1103:"Name cannot be empty",1104:"No device selected while calling meeting.self.setDevice",1105:"Action not permitted without joining room",1106:"Can't set currently used device",1200:"Internal exception",1201:"Permission denied",1202:"Invalid page number was requested",1203:"Invalid participant count per page was requested",1204:"No participants exists with the given UserIds",1205:"Action not permitted without joining room",1206:"Manual Subscription Mode was not ACTIVATED",1207:"Invalid view mode",1208:"Manual Subscription not enabled for organization",1209:"Broadcast message type must be a non-empty string",1300:"Internal exception",1400:"Internal exception",1402:"No existing remote requests",1403:"No peer exists with given id",1500:"Internal exception",1600:"Internal exception",1601:"Failed to get audio track",1602:"Failed to get video track",1603:"Incorrect device",1604:"Failed to change device",1605:"Failed to get audio & video track",1606:"No audio input devices are available",1607:"No video input devices are available",1608:"No audio output devices (speakers) are available",1609:"Failed to fetch list of media devices",1610:"No media track exists",1611:"Failed to unmute track",1612:"Failed to get screenshare tracks",1701:"Crypto error",1800:"Internal exception",1801:"Can't fetch transcript file",1900:"Internal exception",1901:"Permission denied.",1902:"Livestream that has not yet started, can't be stopped",2e3:"Internal exception",2001:"Permission denied",2002:"Unsupported",2003:"Stage is disabled",2004:"Method not implemented",2005:"Action not permitted without joining room",2006:"Action not permitted in current stage status",9900:"Internal exception"};Object.keys($o).forEach(s=>{$o[s]=`{${NS[s.slice(0,2)]}} ${$o[s]}`});class _ extends Error{constructor(e,r,i=void 0,a=!1){super(e);g(this,"code");this.code=r,this.name="ClientError";const o=this.code?`[ERR${this.code}]`:"[ERR]",c=this.code?$o[this.code]:"";this.message=`${o}: ${c}
|
|
2
|
+
${this.message}`;try{let d=a&&!!i;r&&r.endsWith("00")&&i&&(d=!0),d&&i.error("ClientError",{error:{message:this.message,name:this.name,code:r}});const u=Ms.getContext(Ms.getMostRecentPeerId());if(u){const p=u.getValue("onError");try{p(this)}catch(m){}}typeof window!="undefined"&&window.dispatchEvent(new CustomEvent("ClientError",{detail:this}))}catch(d){}}}function ko(s,t,e,r){if(r instanceof _)throw r;if(r instanceof t){const i=new _(r.message,e);throw i.stack=r.stack,i}else throw r}function Vu(s,t,e){if(!s.value){const i=s.get,a=s.set;return i&&(s.get=function(){try{return i.apply(this)}catch(o){ko(this,t,e,o)}}),a&&(s.set=function(o){try{return a.apply(this,[o])}catch(c){ko(this,t,e,c)}}),s}const r=s.value;return s.value=function(...i){try{const a=r.apply(this,i);return a&&a instanceof Promise?a.catch(o=>{ko(this,t,e,o)}):a}catch(a){ko(this,t,e,a)}},s}function VS(s,t){return(e,r,i)=>{if(i)return Vu(i,s,t);for(const a of Reflect.ownKeys(e.prototype).filter(o=>o!=="constructor")){const o=Object.getOwnPropertyDescriptor(e.prototype,a);(o.value instanceof Function||o.get instanceof Function||o.set instanceof Function)&&Object.defineProperty(e.prototype,a,Vu(o,s,t))}}}const Ne=s=>VS(Error,s);function xS(s){let t=0,e,r;if(!s)return t;for(e=0;e<s.length;e+=1)r=s.charCodeAt(e),t=(t<<5)-t+r,t|=0;return Math.abs(t)%100+1}function LS(){Z.isElectron()&&window.electronGetDisplayMediaSource&&(navigator.mediaDevices.getDisplayMedia=()=>l(this,null,function*(){const s=yield window.electronGetDisplayMediaSource({types:["window","screen"]});let t=[];if(s&&(Array.isArray(s)?t=s:t=[s]),!(t!=null&&t.length))throw new Error("Couldn't find any media source for screen share.");let e=t.find(a=>{var o;return(o=a.id)==null?void 0:o.includes("screen")});e=e!=null?e:t[0];const r={audio:!1,video:{mandatory:{chromeMediaSource:"desktop",chromeMediaSourceId:e.id}}};return yield navigator.mediaDevices.getUserMedia(r)}))}var E=(s=>(s.NEW_PRODUCER="NEW_PRODUCER",s.ROOM_NODE_CONNECTION_ERROR="ROOM_NODE_CONNECTION_ERROR",s.SOCKET_SERVICE_ROOM_JOINED="SOCKET_SERVICE_ROOM_JOINED",s.SOCKET_SERVICE_RECONNECTED="SOCKET_SERVICE_RECONNECTED",s.SOCKET_SERVICE_DISCONNECTED="SOCKET_SERVICE_DISCONNECTED",s.SOCKET_SERVICE_FAILED="SOCKET_SERVICE_FAILED",s.SOCKET_STATE_UPDATE="SOCKET_STATE_UPDATE",s.ROOM_NODE_RECONNECTED="ROOM_NODE_RECONNECTED",s.ROOM_NODE_DISCONNECTED="ROOM_NODE_DISCONNECTED",s.ROOM_NODE_FAILED="ROOM_NODE_FAILED",s.TRANSPORT_STATE_UPDATE="TRANSPORT_STATE_UPDATE",s.PRODUCER_SCORE_UPDATE="PRODUCER_SCORE_UPDATE",s.CONSUMER_SCORE_UPDATE="CONSUMER_SCORE_UPDATE",s.PRODUCER_STATUS_UPDATE="PRODUCER_STATUS_UPDATE",s.CONSUMER_STATUS_UPDATE="CONSUMER_STATUS_UPDATE",s.LOW_CONSUMER_SCORE="LOW_CONSUMER_SCORE",s.MEDIA_PERMISSION_ERROR="MEDIA_PERMISSION_ERROR",s.MEDIA_PERMISSION_UPDATE="MEDIA_PERMISSION_UPDATE",s.MESSAGE="websocket/message",s.ROOM_MESSAGE="websocket/room-message",s.PEER_JOINED_INTERNAL="peer/joined-internal",s.PEER_CLOSED="websocket/peer-closed",s.CONSUMER_CLOSED="websocket/consumer-closed",s.CONSUMER_PAUSED="websocket/consumer-paused",s.CONSUMER_RESUMED="websocket/consumer-resumed",s.PRODUCER_CLOSED="websocket/producer-closed",s.NEW_CONSUMER="websocket/new-consumer",s.PRODUCER_SCORE="websocket/producer-score",s.CONSUMER_SCORE="websocket/consumer-score",s.PRODUCER_TOGGLE="cf/producer-toggle",s.UPDATE_ACTIVE="media/update-active",s.RESET_PRODUCER_STATE="cf/reset-producer-state",s.ROOM_STATE="sockethub/room-state",s.GET_STAGE_REQUESTS="GET_STAGE_REQUESTS",s.UPDATE_STAGE_REQUESTS="UPDATE_STAGE_REQUESTS",s.KICK_PEER="KICK_PEER",s.UPDATE_PEER_STAGE_STATUS="UPDATE_PEER_STAGE_STATUS",s.JOIN_MEDIA_ROOM="JOIN_MEDIA_ROOM",s.LEAVE_MEDIA_ROOM="LEAVE_MEDIA_ROOM",s.PIP_HANGUP="PIP_HANGUP",s.E2EE_ACTIVE_PRODUCER="E2EE_ACTIVE_PRODUCER",s.E2EE_INACTIVE_PRODUCER="E2EE_INACTIVE_PRODUCER",s.E2EE_ACTIVE_CONSUMER="E2EE_ACTIVE_CONSUMER",s.E2EE_INACTIVE_CONSUMER="E2EE_INACTIVE_CONSUMER",s.SOCKET_PEERS="SOCKET_PEERS",s.UPDATE_PERMISSIONS="UPDATE_PERMISSIONS",s.MAX_SPATIAL_LAYER_CHANGE="MAX_SPATIAL_LAYER_CHANGE",s.MUTE_SELF="MUTE_SELF",s.MUTE_SELF_VIDEO="MUTE_SELF_VIDEO",s))(E||{});class Vn extends Is.EventEmitter{constructor(e){super();g(this,"logger");this.logger=e,super.setMaxListeners(25)}emit(e,...r){return super.emit("*",e,...r),super.emit(e,...r)}on(e,r){var i;try{const a=this.listenerCount(e);a>25&&a%25===0&&((i=this.logger)==null||i.warn("CustomEventEmitter::maxListenersExceeded",{eventListener:{eventName:e.toString(),listenerCount:this.listenerCount(e)}}))}catch(a){}return super.on(e,r)}addListener(e,r){var i;try{const a=this.listenerCount(e);a>25&&a%25===0&&((i=this.logger)==null||i.warn("CustomEventEmitter::maxListenersExceeded",{eventListener:{eventName:e.toString(),listenerCount:this.listenerCount(e)}}))}catch(a){}return super.addListener(e,r)}off(e,r){return super.off(e,r)}once(e,r){return super.once(e,r)}prependListener(e,r){return super.prependListener(e,r)}prependOnceListener(e,r){return super.prependOnceListener(e,r)}removeListener(e,r){return super.removeListener(e,r)}removeAllListeners(e){return super.removeAllListeners(e)}listeners(e){return super.listeners(e)}listenerCount(e){return super.listenerCount(e)}}class ut extends Is.EventEmitter{constructor(e){super();g(this,"logger");this.logger=e,super.setMaxListeners(25)}emit(e,...r){return super.emit("*",e,...r),super.emit(e,...r)}on(e,r){var i;try{const a=this.listenerCount(e);a>25&&a%25===0&&((i=this.logger)==null||i.warn("CustomEventEmitter::maxListenersExceeded",{eventListener:{eventName:e.toString(),listenerCount:this.listenerCount(e)}}))}catch(a){}return super.on(e,r)}addListener(e,r){var i;try{const a=this.listenerCount(e);a>25&&a%25===0&&((i=this.logger)==null||i.warn("CustomEventEmitter::maxListenersExceeded",{eventListener:{eventName:e.toString(),listenerCount:this.listenerCount(e)}}))}catch(a){}return super.addListener(e,r)}off(e,r){return super.off(e,r)}once(e,r){return super.once(e,r)}prependListener(e,r){return super.prependListener(e,r)}prependOnceListener(e,r){return super.prependOnceListener(e,r)}removeListener(e,r){return super.removeListener(e,r)}removeAllListeners(e){return super.removeAllListeners(e)}listeners(e){return super.listeners(e)}listenerCount(e){return super.listenerCount(e)}}function $S(s,t=2){return s.replace(/[^\u00BF-\u1FFF\u2C00-\uD7FF\w\s]/g,"").trim().split(/\s+/).slice(0,t).map(i=>i.charAt(0)).join("").toUpperCase()}const xu=1080,Lu=1920,US=(s,t,e,r,i,a)=>{let o=.5,c=.5;const d=i,u=a,p=Math.min(e/d,r/u);let m=d*p,T=u*p,v,P,w,C,k=1;return m<e&&(k=e/m),Math.abs(k-1)<1e-14&&T<r&&(k=r/T),m*=k,T*=k,w=d/(m/e),C=u/(T/r),v=(d-w)*o,P=(u-C)*c,v<0&&(v=0),P<0&&(P=0),w>d&&(w=d),C>u&&(C=u),[v,P,w,C,s,t,e,r]};var mt,Er,ke,ft,ie,Dt,ls,xe,ce,Di,Ni,us,Vi;const Kl=class extends ut{constructor(e,r,i,a){const o=e.getValue("logger");super(o);h(this,mt,void 0);h(this,Er,void 0);h(this,ke,void 0);h(this,ft,void 0);h(this,ie,{height:xu,width:Lu});h(this,Dt,{brand:"#2160FD",background:"#141414",text:"#000000",videoBackground:"#191919",textOnBrand:"#EEEEEE"});h(this,ls,void 0);h(this,xe,{});h(this,ce,void 0);h(this,Di,void 0);h(this,Ni,void 0);h(this,us,void 0);h(this,Vi,!1);g(this,"cleanupEventListeners",()=>{n(this,Er).unsubscribe("stageStatus",this.handlePipMediaControls),n(this,ce).removeListener("videoUpdate",this.onSelfVideoUpdateListener),n(this,ce).removeListener("audioUpdate",this.onSelfAudioUpdateListener),n(this,ce).removeListener("roomLeft",()=>this.disable())});g(this,"enablePipMediaControls",()=>{this.mountAudioEvents(),this.mountVideoEvents()});g(this,"onSelfVideoUpdateListener",({videoEnabled:e})=>{this.updateMediaSession("CAMERA",e)});g(this,"onSelfAudioUpdateListener",({audioEnabled:e})=>{this.updateMediaSession("MIC",e)});g(this,"handlePipMediaControls",e=>{e==="ON_STAGE"?this.enablePipMediaControls():this.unmountEvents()});g(this,"eventCallback",e=>{e==="CAMERA"&&(n(this,ce).videoEnabled?n(this,ce).disableVideo():n(this,ce).enableVideo(),this.emit("cameraToggled")),e==="MIC"&&(n(this,ce).audioEnabled?n(this,ce).disableAudio():n(this,ce).enableAudio(),this.emit("micToggled")),e==="END"&&(n(this,Er).getValue("peerSessionStore").emit(E.PIP_HANGUP),this.cleanupEventListeners(),this.emit("hangup"),this.cleanup())});g(this,"unmountEvents",()=>{navigator.mediaSession===void 0||navigator.mediaSession.setCameraActive===void 0||(navigator.mediaSession.setActionHandler("togglemicrophone",void 0),navigator.mediaSession.setActionHandler("togglecamera",void 0))});g(this,"animate",()=>{if(!this.isActive&&n(this,us)==="active"){this.disable(!0);return}n(this,xe)!==void 0&&this.paintCanvas(),n(this,ls)!==void 0&&f(this,ls,requestAnimationFrame(()=>this.animate()))});g(this,"disable",(e=!1)=>{f(this,us,"idle"),this.cleanupEventListeners(),cancelAnimationFrame(n(this,ls)),e!==!0&&document.body.removeChild(n(this,ke)),f(this,ls,void 0),document.pictureInPictureElement&&document.exitPictureInPicture()});f(this,Er,e),f(this,us,"idle"),f(this,ce,r),f(this,Dt,{brand:r.config.designTokens.colors.brand[500],background:r.config.designTokens.colors.background[1e3],text:r.config.designTokens.colors.text,videoBackground:r.config.designTokens.colors.videoBg,textOnBrand:r.config.designTokens.colors.textOnBrand}),i&&this.setupIcon("pin",i),a&&this.setupIcon("handRaise",a)}static _init(e,r){return l(this,null,function*(){let i,a;try{i=yield Ro(bS),a=yield Ro(MS)}catch(o){}return new Kl(e,r,i,a)})}setupIcon(e,r){return l(this,null,function*(){switch(e){case"handRaise":f(this,Ni,r);break;case"pin":f(this,Di,r);break}})}overrideIcon(e,r){return l(this,null,function*(){switch(e){case"handRaise":f(this,Ni,yield Ro(r));break;case"pin":f(this,Di,yield Ro(r));break}})}constructImage(e){const r=new Image,i=new Blob([e],{type:"image/svg+xml"}),a=window.URL.createObjectURL(i);return new Promise(o=>{r.onload=()=>{o(r),window.URL.revokeObjectURL(a)},r.src=a})}createVideoContainer(){f(this,ke,document.createElement("div")),n(this,ke).style.width="0.1px",n(this,ke).style.height="0.1px",n(this,ke).style.overflow="hidden",n(this,ke).style.position="absolute",n(this,ke).style.bottom="0",n(this,ke).style.right="0",n(this,ke).style.opacity="0",n(this,ke).appendChild(n(this,ft))}setupEventListeners(){n(this,Er).subscribe("stageStatus",this.handlePipMediaControls),n(this,ce).addListener("videoUpdate",this.onSelfVideoUpdateListener),n(this,ce).addListener("audioUpdate",this.onSelfAudioUpdateListener),n(this,ce).addListener("roomLeft",()=>this.disable())}createCanvas(){const e=document.createElement("canvas");e.height=n(this,ie).height,e.width=n(this,ie).width,f(this,mt,e)}setupMediaSessionEvents(){navigator.mediaSession===void 0||navigator.mediaSession.setCameraActive===void 0||(navigator.mediaSession.setActionHandler("hangup",()=>{this.eventCallback("END")}),this.mountAudioEvents(),this.mountVideoEvents())}mountAudioEvents(){navigator.mediaSession===void 0||navigator.mediaSession.setMicrophoneActive===void 0||n(this,ce).permissions.canProduceAudio&&navigator.mediaSession.setActionHandler("togglemicrophone",()=>{this.eventCallback("MIC")})}mountVideoEvents(){navigator.mediaSession===void 0||navigator.mediaSession.setCameraActive===void 0||n(this,ce).permissions.canProduceVideo&&navigator.mediaSession.setActionHandler("togglecamera",()=>{this.eventCallback("CAMERA")})}getSources(){const r=Object.values(n(this,xe)).reduce((i,a)=>(i[a.pinned?"pinned":"regular"].push(a),i),{pinned:[],regular:[]});return[...r.pinned,...r.regular]}drawEmptyTile(e,r,i,a){if(n(this,mt)===void 0)return;const o=n(this,mt).getContext("2d"),c=n(this,mt).width,d=0,u=0,p=r-d*2,m=i-d*2,T=Math.floor(c/p),v=Math.floor(e/T),w=e%T*(p+d)+d,C=v*(m+d)+d,{displayText:k,image:R}=a!=null?a:{};o.fillStyle=k||R?n(this,Dt).videoBackground:n(this,Dt).background,o.strokeStyle=n(this,Dt).brand,o.beginPath(),o.moveTo(w+u,C),o.arcTo(w+p,C,w+p,C+u,u),o.arcTo(w+p,C+m,w+p-u,C+m,u),o.arcTo(w,C+m,w,C+m-u,u),o.arcTo(w,C,w+u,C,u),o.closePath(),o.fill(),o.stroke();const D=p/6,O=p/2+w,N=m/2+C;o.save(),(k||R)&&(o.beginPath(),o.arc(O,N,D,0,Math.PI*2),o.fillStyle=n(this,Dt).brand,o.fill(),R?(o.clip(),o.drawImage(R,O-D,N-D,D*2,D*2),o.restore()):k&&(o.fillStyle=n(this,Dt).textOnBrand,o.font=`${D/2}px sans-serif`,o.textAlign="center",o.textBaseline="middle",o.fillText(k,O,N)),this.drawIcons(a,w,C,Math.max(p,m)))}drawIcons(e,r,i,a){const o=Math.min(Math.max(a*.15,100),200),c=o*.2,d=o*.2;let u=r+c;const p=i+c,m=T=>{const v=n(this,mt).getContext("2d");v.save(),v.fillStyle=n(this,Dt).background,v.beginPath(),v.moveTo(u+d,p),v.arcTo(u+o,p,u+o,p+d,d),v.arcTo(u+o,p+o,u+o-d,p+o,d),v.arcTo(u,p+o,u,p+o-d,d),v.arcTo(u,p,u+d,p,d),v.closePath(),v.fill(),typeof T=="string"?(v.font=`${o/1.5}px sans-serif`,v.fillStyle=n(this,Dt).text,v.textAlign="center",v.textBaseline="top",v.fillText(T,o/2+u,p+c)):v.drawImage(T,u+c,p+c,o-c*2,o-c*2),u+=o+c,v.restore()};e.pinned&&m(n(this,Di)),e.handRaised&&m(n(this,Ni)),e.reaction&&m(e.reaction)}drawTile(e,r,i){var u,p;if(n(this,mt)===void 0)return;const a=n(this,mt).getContext("2d"),o=this.getSources();let c=0,d=0;for(;c<n(this,ie).height-5;){let m=0;for(;m<n(this,ie).width-5&&d<i;){if((u=o[d])!=null&&u.enabled){const T=o[d].element,[v,P,w,C,k,R,D,O]=US(m,c,e,r,T.videoWidth,T.videoHeight);((p=T==null?void 0:T.classList)==null?void 0:p.contains("mirror"))?(a.save(),a.scale(-1,1),a.drawImage(T,v,P,w,C,-1*k,R,-1*D,O),a.restore()):a.drawImage(T,v,P,w,C,k,R,D,O),this.drawIcons(o[d],k,R,Math.max(D,O))}else this.drawEmptyTile(d,e,r,o[d]);d+=1,m+=e}c+=r}}calcGridElemSize(e){switch(e){case 0:case 1:return[n(this,ie).width,n(this,ie).height];case 2:return[Math.floor(n(this,ie).width/2),n(this,ie).height];case 3:case 4:return[Math.floor(n(this,ie).width/2),Math.floor(n(this,ie).height/2)];case 5:case 6:return[Math.floor(n(this,ie).width/3),Math.floor(n(this,ie).height/2)];case 7:case 8:case 9:return[Math.floor(n(this,ie).width/3),Math.floor(n(this,ie).height/3)];default:return[Math.floor(n(this,ie).width/3),Math.floor(n(this,ie).height/2)]}}paintCanvas(){let e=this.getSources().length;e!==1&&(e=e%2>0?e+1:e);const[r,i]=this.calcGridElemSize(e);this.drawTile(r,i,e)}isSupported(){var e;return!!window.chrome&&document.pictureInPictureEnabled&&((e=n(this,ce).config)==null?void 0:e.viewType)!=="LIVESTREAM"}get isActive(){return document.pictureInPictureElement!==null}cleanup(){if(f(this,Vi,!1),this.isSupported()&&document.exitPictureInPicture!==void 0&&document.pictureInPictureElement!==null&&document.exitPictureInPicture(),n(this,ke))try{document.body.removeChild(n(this,ke))}catch(e){}this.removeAllSources(),f(this,mt,void 0),f(this,ft,void 0),f(this,ls,void 0)}init({height:e,width:r}={}){if(!this.isSupported())throw this.logger.error("Pip.unsupported"),new Error("Picture-in-picture is not available in this environment");if(n(this,Vi))return;f(this,Vi,!0),this.createCanvas(),this.setupMediaSessionEvents();const i=document.createElement("video");f(this,ie,{height:e!=null?e:xu,width:r!=null?r:Lu}),i.height=n(this,ie).height,i.width=n(this,ie).width,i.autoplay=!0,i.muted=!0,i.srcObject=n(this,mt).captureStream(24),f(this,ft,i),n(this,ft).onloadedmetadata=()=>{try{this.emit("pipStarted"),n(this,ft).onleavepictureinpicture=()=>{this.emit("pipEnded")}}catch(a){this.emit("pipEnded")}},this.createVideoContainer(),this.paintCanvas()}updateMediaSession(e,r){navigator.mediaSession!==void 0&&(e==="CAMERA"&&navigator.mediaSession.setCameraActive!==void 0&&navigator.mediaSession.setCameraActive(r),e==="MIC"&&navigator.mediaSession.setMicrophoneActive!==void 0&&navigator.mediaSession.setMicrophoneActive(r))}enableSource(e){n(this,xe)[e]!==void 0&&(n(this,xe)[e].enabled=!0)}disableSource(e){n(this,xe)[e]!==void 0&&(n(this,xe)[e].enabled=!1)}generateAvatar(e,r){return l(this,null,function*(){if(!r)return;const i=new Image;try{const a=yield(yield fetch(r)).blob(),o=window.URL.createObjectURL(a);i.onload=()=>{this.updateSource(e,{image:i}),window.URL.revokeObjectURL(o)},i.src=o}catch(a){this.logger.error("Pip::GenerateAvatar",{error:a})}})}addSource(e,r,i,a=!1,o=void 0,c=void 0,d=!1){this.logger.debug("Pip::AddSource",{pip:{id:e,handRaised:d}}),n(this,xe)[e]={id:e,element:r,enabled:i,pinned:a,displayText:o?$S(o):void 0,imageUrl:c,handRaised:d},c&&this.generateAvatar(e,c)}updateSource(e,r){this.logger.info("Pip::UpdateSource",{pip:{id:e,handRaised:r.handRaised,reaction:r.reaction}});const i=n(this,xe)[e];i&&(n(this,xe)[e]=b(b({},i),r))}removeSource(e){delete n(this,xe)[e]}removePinnedSource(){Object.values(n(this,xe)).forEach(r=>{r.pinned&&this.removeSource(r.id)})}removeAllSources(){f(this,xe,{})}enable(){f(this,us,"activating"),this.setupEventListeners(),this.updateMediaSession("CAMERA",n(this,ce).videoEnabled),this.updateMediaSession("MIC",n(this,ce).audioEnabled),document.body.appendChild(n(this,ke)),f(this,ls,requestAnimationFrame(()=>this.animate())),n(this,ft).onloadedmetadata=()=>{n(this,ft).requestPictureInPicture().then(()=>{f(this,us,"active")})},n(this,ft).readyState===4&&n(this,ft).requestPictureInPicture().then(()=>{f(this,us,"active")})}};let Ud=Kl;mt=new WeakMap,Er=new WeakMap,ke=new WeakMap,ft=new WeakMap,ie=new WeakMap,Dt=new WeakMap,ls=new WeakMap,xe=new WeakMap,ce=new WeakMap,Di=new WeakMap,Ni=new WeakMap,us=new WeakMap,Vi=new WeakMap;var Os;(function(s){s[s.PUBLISHER=0]="PUBLISHER",s[s.SUBSCRIBER=1]="SUBSCRIBER"})(Os||(Os={}));var ns;(function(s){s[s.AUDIO=0]="AUDIO",s[s.VIDEO=1]="VIDEO"})(ns||(ns={}));class qS extends y.MessageType{constructor(){super("media.Codec",[{no:1,name:"channels",kind:"scalar",opt:!0,T:5},{no:2,name:"clock_rate",kind:"scalar",T:5},{no:3,name:"mime_type",kind:"scalar",T:9},{no:4,name:"sdp_fmtp_line",kind:"scalar",opt:!0,T:9},{no:5,name:"payload_type",kind:"scalar",opt:!0,T:13}])}}const kp=new qS;class HS extends y.MessageType{constructor(){super("media.HeaderExtension",[{no:1,name:"direction",kind:"scalar",opt:!0,T:9},{no:2,name:"uri",kind:"scalar",T:9}])}}const FS=new HS;class BS extends y.MessageType{constructor(){super("media.Fingerprint",[{no:1,name:"algorithm",kind:"scalar",T:9},{no:2,name:"value",kind:"scalar",T:9}])}}new BS;class jS extends y.MessageType{constructor(){super("media.SessionDescription",[{no:1,name:"target",kind:"enum",T:()=>["media.Target",Os]},{no:2,name:"type",kind:"scalar",T:9},{no:3,name:"sdp",kind:"scalar",T:9}])}}const Wt=new jS;class GS extends y.MessageType{constructor(){super("media.ProducerPayload",[{no:1,name:"kind",kind:"scalar",T:9},{no:2,name:"paused",kind:"scalar",T:8},{no:3,name:"screen_share",kind:"scalar",T:8},{no:4,name:"msid",kind:"scalar",T:9},{no:5,name:"app_data",kind:"scalar",opt:!0,T:9},{no:6,name:"mime_type",kind:"scalar",opt:!0,T:9}])}}const JS=new GS;class WS extends y.MessageType{constructor(){super("media.CreateTransportRequest",[{no:1,name:"consuming",kind:"scalar",T:8},{no:2,name:"force_tcp",kind:"scalar",opt:!0,T:8},{no:3,name:"description",kind:"message",T:()=>Wt},{no:4,name:"private_ice",kind:"scalar",opt:!0,T:8},{no:5,name:"producers",kind:"message",repeat:1,T:()=>JS}])}}const KS=new WS;class zS extends y.MessageType{constructor(){super("media.AudioActivityRequest",[{no:1,name:"producer_id",kind:"scalar",T:9},{no:2,name:"energy",kind:"scalar",T:5},{no:3,name:"silent",kind:"scalar",T:8}])}}const YS=new zS;class QS extends y.MessageType{constructor(){super("media.CreateTransportResponse",[{no:1,name:"transport_id",kind:"scalar",T:9},{no:2,name:"description",kind:"message",T:()=>Wt},{no:3,name:"transcription_enabled",kind:"scalar",opt:!0,T:8},{no:4,name:"producer_ids",kind:"scalar",repeat:2,T:9}])}}const bp=new QS;class XS extends y.MessageType{constructor(){super("media.RenegotiateRequest",[{no:1,name:"transport_id",kind:"scalar",T:9},{no:2,name:"description",kind:"message",T:()=>Wt}])}}const ZS=new XS;class eP extends y.MessageType{constructor(){super("media.RenegotiateResponse",[{no:1,name:"transport_id",kind:"scalar",T:9},{no:2,name:"description",kind:"message",T:()=>Wt}])}}new eP;class tP extends y.MessageType{constructor(){super("media.NestedScore",[{no:1,name:"encoding_idx",kind:"scalar",T:5},{no:2,name:"rid",kind:"scalar",T:9},{no:3,name:"score",kind:"scalar",T:5},{no:4,name:"ssrc",kind:"scalar",T:3,L:0}])}}const sP=new tP;class rP extends y.MessageType{constructor(){super("media.ProducerTrack",[{no:1,name:"track_id",kind:"scalar",T:9},{no:2,name:"producer_id",kind:"scalar",T:9},{no:3,name:"stream_id",kind:"scalar",T:9}])}}const iP=new rP;class nP extends y.MessageType{constructor(){super("media.ProducerEntry",[{no:1,name:"producing_transport_id",kind:"scalar",T:9},{no:2,name:"producer_id",kind:"scalar",T:9}])}}new nP;class aP extends y.MessageType{constructor(){super("media.ConsumerEntry",[{no:1,name:"consuming_transport_id",kind:"scalar",T:9},{no:2,name:"consumer_id",kind:"scalar",T:9}])}}new aP;class oP extends y.MessageType{constructor(){super("media.ProducerState",[{no:1,name:"producer_id",kind:"scalar",T:9},{no:2,name:"kind",kind:"enum",T:()=>["media.ProducerKind",ns]},{no:3,name:"pause",kind:"scalar",T:8},{no:4,name:"screen_share",kind:"scalar",T:8},{no:5,name:"app_data",kind:"scalar",opt:!0,T:9},{no:6,name:"producing_transport_id",kind:"scalar",opt:!0,T:9},{no:7,name:"mime_type",kind:"scalar",opt:!0,T:9},{no:8,name:"codec",kind:"message",T:()=>kp}])}}const mo=new oP;class cP extends y.MessageType{constructor(){super("media.ConsumerState",[{no:1,name:"consumer_id",kind:"scalar",T:9},{no:2,name:"producer_state",kind:"message",T:()=>mo},{no:3,name:"producer_track",kind:"message",T:()=>iP},{no:4,name:"error_code",kind:"scalar",opt:!0,T:9}])}}const dP=new cP;class lP extends y.MessageType{constructor(){super("media.ProducerIdToConsumerMap",[{no:1,name:"map",kind:"map",K:9,V:{kind:"message",T:()=>dP}}])}}const Mp=new lP;class uP extends y.MessageType{constructor(){super("media.PeerRtpCapabilitites",[{no:1,name:"sender",kind:"message",T:()=>Uu},{no:2,name:"receiver",kind:"message",T:()=>Uu}])}}const Ap=new uP;class hP extends y.MessageType{constructor(){super("media.RtpCapability",[{no:1,name:"codecs",kind:"message",repeat:1,T:()=>kp},{no:2,name:"header_extensions",kind:"message",repeat:1,T:()=>FS}])}}const $u=new hP;class pP extends y.MessageType{constructor(){super("media.RtpCapabilitites",[{no:1,name:"audio",kind:"message",T:()=>$u},{no:2,name:"video",kind:"message",T:()=>$u}])}}const Uu=new pP;class gP extends y.MessageType{constructor(){super("media.PreferredCodec",[{no:1,name:"audio",kind:"scalar",opt:!0,T:9},{no:2,name:"video",kind:"scalar",opt:!0,T:9}])}}const mP=new gP;class fP extends y.MessageType{constructor(){super("media.Simulcast",[{no:1,name:"preferred_rid",kind:"scalar",opt:!0,T:9},{no:2,name:"priority_ordering",kind:"scalar",opt:!0,T:9},{no:3,name:"rid_not_available",kind:"scalar",opt:!0,T:9}])}}const Ip=new fP;class TP extends y.MessageType{constructor(){super("media.edge.GeoLocation",[{no:1,name:"latitude",kind:"scalar",T:2},{no:2,name:"longitude",kind:"scalar",T:2},{no:3,name:"region",kind:"scalar",opt:!0,T:9}])}}const yP=new TP;class vP extends y.MessageType{constructor(){super("media.edge.PeerJoinRequest",[{no:1,name:"display_name",kind:"scalar",opt:!0,T:9},{no:2,name:"prejoined",kind:"scalar",T:8},{no:3,name:"room_uuid",kind:"scalar",T:9},{no:4,name:"meeting_id",kind:"scalar",opt:!0,T:9},{no:5,name:"preset",kind:"scalar",opt:!0,T:12},{no:6,name:"user_id",kind:"scalar",opt:!0,T:9},{no:7,name:"organization_id",kind:"scalar",opt:!0,T:9},{no:8,name:"location",kind:"message",T:()=>yP},{no:9,name:"capabilities",kind:"message",T:()=>Ap}])}}const SP=new vP;class PP extends y.MessageType{constructor(){super("media.edge.PeerJoinCompleteRequest",[])}}const EP=new PP;class wP extends y.MessageType{constructor(){super("media.edge.PeerLeaveRequest",[{no:1,name:"close_room",kind:"scalar",T:8}])}}const CP=new wP;class _P extends y.MessageType{constructor(){super("media.edge.ConsumeMultipleProducerRequest",[{no:1,name:"producer_ids",kind:"scalar",repeat:2,T:9},{no:2,name:"paused",kind:"scalar",opt:!0,T:8}])}}new _P;class RP extends y.MessageType{constructor(){super("media.edge.ConsumePeerRequest",[{no:1,name:"producing_peer_id",kind:"scalar",T:9},{no:2,name:"paused",kind:"scalar",opt:!0,T:8},{no:3,name:"producer_id",kind:"scalar",opt:!0,T:9},{no:4,name:"preferred_codec",kind:"message",T:()=>mP},{no:5,name:"producing_transport_id",kind:"scalar",opt:!0,T:9},{no:6,name:"simulcast",kind:"message",T:()=>Ip}])}}const kP=new RP;class bP extends y.MessageType{constructor(){super("media.edge.ConsumePeersRequest",[{no:1,name:"requests",kind:"message",repeat:1,T:()=>kP},{no:2,name:"consuming_transport_id",kind:"scalar",opt:!0,T:9}])}}const MP=new bP;class AP extends y.MessageType{constructor(){super("media.edge.UpdateConsumerSimulcastConfigRequest",[{no:1,name:"producer_id",kind:"scalar",T:9},{no:2,name:"simulcast",kind:"message",T:()=>Ip},{no:3,name:"producing_transport_id",kind:"scalar",T:9},{no:4,name:"mid",kind:"scalar",T:9}])}}const IP=new AP;class OP extends y.MessageType{constructor(){super("media.edge.UpdateConsumersSimulcastConfigRequest",[{no:1,name:"requests",kind:"message",repeat:1,T:()=>IP},{no:2,name:"consuming_transport_id",kind:"scalar",opt:!0,T:9}])}}const DP=new OP;class NP extends y.MessageType{constructor(){super("media.edge.ProducerCreateRequest",[{no:1,name:"kind",kind:"scalar",T:9},{no:2,name:"paused",kind:"scalar",T:8},{no:3,name:"screen_share",kind:"scalar",T:8},{no:4,name:"description",kind:"message",T:()=>Wt},{no:5,name:"msid",kind:"scalar",T:9},{no:6,name:"app_data",kind:"scalar",opt:!0,T:9},{no:7,name:"mime_type",kind:"scalar",opt:!0,T:9},{no:8,name:"producing_transport_id",kind:"scalar",opt:!0,T:9}])}}const VP=new NP;class xP extends y.MessageType{constructor(){super("media.edge.SelectedPeersRequest",[])}}new xP;class LP extends y.MessageType{constructor(){super("media.edge.GlobalPeerPinningRequest",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}const $P=new LP;class UP extends y.MessageType{constructor(){super("media.edge.ProducerToggleRequest",[{no:1,name:"producer_id",kind:"scalar",T:9},{no:2,name:"pause",kind:"scalar",T:8}])}}const bo=new UP;class qP extends y.MessageType{constructor(){super("media.edge.ConsumerToggleRequest",[{no:1,name:"consumer_id",kind:"scalar",T:9},{no:2,name:"pause",kind:"scalar",T:8}])}}new qP;class HP extends y.MessageType{constructor(){super("media.edge.ProducerCloseRequest",[{no:1,name:"producer_id",kind:"scalar",T:9},{no:2,name:"description",kind:"message",T:()=>Wt},{no:3,name:"producing_transport_id",kind:"scalar",opt:!0,T:9}])}}const FP=new HP;class BP extends y.MessageType{constructor(){super("media.edge.ConsumerCloseRequest",[{no:1,name:"consumer_ids",kind:"scalar",repeat:2,T:9},{no:2,name:"description",kind:"message",T:()=>Wt},{no:3,name:"consuming_transport_id",kind:"scalar",opt:!0,T:9}])}}const jP=new BP;class GP extends y.MessageType{constructor(){super("media.edge.KickPeerRequest",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}new GP;class JP extends y.MessageType{constructor(){super("media.edge.KickAllPeersRequest",[{no:1,name:"propagate_kick_across_rooms",kind:"scalar",T:8}])}}const Op=new JP;class WP extends y.MessageType{constructor(){super("media.edge.PeerDisplayNameEditRequest",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"display_name",kind:"scalar",T:9}])}}const KP=new WP;class zP extends y.MessageType{constructor(){super("media.edge.HostMediaControlForPeerRequest",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"audio",kind:"scalar",T:8},{no:3,name:"video",kind:"scalar",T:8},{no:4,name:"scree_share",kind:"scalar",T:8}])}}const YP=new zP;class QP extends y.MessageType{constructor(){super("media.edge.HostMediaControlForAllPeerRequest",[{no:1,name:"audio",kind:"scalar",T:8},{no:2,name:"video",kind:"scalar",T:8},{no:3,name:"screen_share",kind:"scalar",T:8}])}}const XP=new QP;class ZP extends y.MessageType{constructor(){super("media.edge.GetRoomStateResponse",[{no:1,name:"display_title",kind:"scalar",T:9},{no:2,name:"locked_mode",kind:"scalar",T:8},{no:3,name:"room_uuid",kind:"scalar",T:9},{no:4,name:"room_name",kind:"scalar",T:9},{no:5,name:"current_peer_id",kind:"scalar",T:9},{no:6,name:"is_recording",kind:"scalar",opt:!0,T:8},{no:7,name:"recorder_participant_id",kind:"scalar",opt:!0,T:9},{no:8,name:"pinned_peer_ids",kind:"scalar",repeat:2,T:9}])}}const eE=new ZP;class tE extends y.MessageType{constructor(){super("media.edge.ErrorResponse",[{no:1,name:"error_message",kind:"scalar",T:9},{no:2,name:"event_id",kind:"scalar",T:5}])}}const sE=new tE;class rE extends y.MessageType{constructor(){super("media.edge.EmptyResponse",[])}}new rE;class iE extends y.MessageType{constructor(){super("media.edge.RoomParticipants",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"producer_states",kind:"message",repeat:1,T:()=>mo},{no:3,name:"display_name",kind:"scalar",T:9},{no:4,name:"user_id",kind:"scalar",opt:!0,T:9},{no:5,name:"capabilities",kind:"message",T:()=>Ap}])}}const Dp=new iE;class nE extends y.MessageType{constructor(){super("media.edge.SelectedPeersResponse",[{no:1,name:"audio_peers",kind:"scalar",repeat:2,T:9},{no:2,name:"compulsory_peers",kind:"scalar",repeat:2,T:9}])}}const qd=new nE;class aE extends y.MessageType{constructor(){super("media.edge.SelectedPeersDiffEntry",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"priority",kind:"scalar",T:5}])}}const oE=new aE;class cE extends y.MessageType{constructor(){super("media.edge.SelectedPeersDiffResponse",[{no:1,name:"entries",kind:"message",repeat:1,T:()=>oE}])}}const qu=new cE;class dE extends y.MessageType{constructor(){super("media.edge.PeerJoinResponse",[])}}new dE;class lE extends y.MessageType{constructor(){super("media.edge.PeerJoinCompleteResponse",[{no:1,name:"room_state",kind:"message",T:()=>eE},{no:2,name:"participants",kind:"message",repeat:1,T:()=>Dp},{no:3,name:"selected_peers",kind:"message",T:()=>qd},{no:4,name:"max_preferred_streams",kind:"scalar",T:5}])}}const Hd=new lE;class uE extends y.MessageType{constructor(){super("media.edge.PeerLeaveResponse",[{no:1,name:"closed",kind:"scalar",T:8}])}}const hE=new uE;class pE extends y.MessageType{constructor(){super("media.edge.ConsumeMultipleProducerResponse",[{no:1,name:"status",kind:"scalar",T:8},{no:2,name:"consumer_ids_map",kind:"message",T:()=>Mp}])}}new pE;class gE extends y.MessageType{constructor(){super("media.edge.ConsumePeerResponse",[{no:1,name:"status",kind:"scalar",T:8},{no:2,name:"consumer_ids_map",kind:"message",T:()=>Mp},{no:3,name:"description",kind:"message",T:()=>Wt}])}}const mE=new gE;class fE extends y.MessageType{constructor(){super("media.edge.ProducerCreateResponse",[{no:1,name:"status",kind:"scalar",T:8},{no:2,name:"producer_id",kind:"scalar",T:9},{no:4,name:"description",kind:"message",T:()=>Wt}])}}const TE=new fE;class yE extends y.MessageType{constructor(){super("media.edge.ProducerScoreResponse",[{no:1,name:"responseid",kind:"scalar",T:9},{no:2,name:"score",kind:"message",T:()=>sP}])}}new yE;class vE extends y.MessageType{constructor(){super("media.edge.ActiveSpeakerResponse",[{no:1,name:"responsepeer_id",kind:"scalar",T:9},{no:2,name:"volume",kind:"scalar",T:5}])}}new vE;class SE extends y.MessageType{constructor(){super("media.edge.NoActiveSpeakerResponse",[])}}new SE;class PE extends y.MessageType{constructor(){super("media.edge.ProducerToggleResponse",[])}}new PE;class EE extends y.MessageType{constructor(){super("media.edge.ConsumerToggleResponse",[])}}new EE;class wE extends y.MessageType{constructor(){super("media.edge.ProducerClosingResponse",[{no:1,name:"description",kind:"message",T:()=>Wt}])}}const CE=new wE;class _E extends y.MessageType{constructor(){super("media.edge.ConsumerClosingResponse",[{no:1,name:"description",kind:"message",T:()=>Wt}])}}const RE=new _E;class kE extends y.MessageType{constructor(){super("media.edge.GlobalPeerPinningResponse",[])}}new kE;class bE extends y.MessageType{constructor(){super("media.edge.KickPeerResponse",[{no:1,name:"status",kind:"scalar",T:9}])}}new bE;class ME extends y.MessageType{constructor(){super("media.edge.KickAllPeersResponse",[{no:1,name:"status",kind:"scalar",T:9}])}}new ME;class AE extends y.MessageType{constructor(){super("media.edge.HostMediaControlForPeerResponse",[{no:1,name:"status",kind:"scalar",T:9}])}}const IE=new AE;class OE extends y.MessageType{constructor(){super("media.edge.HostMediaControlForAllPeerResponse",[{no:1,name:"status",kind:"scalar",T:9}])}}const DE=new OE;class NE extends y.MessageType{constructor(){super("media.edge.PeerDisplayNameEditResponse",[{no:1,name:"status",kind:"scalar",T:9}])}}const VE=new NE;class xE extends y.MessageType{constructor(){super("media.edge.PeerJoinBroadcastResponse",[{no:1,name:"participant",kind:"message",T:()=>Dp}])}}const Hu=new xE;class LE extends y.MessageType{constructor(){super("media.edge.TrackSubscriptionKind",[{no:1,name:"audio",kind:"scalar",T:8},{no:2,name:"video",kind:"scalar",T:8}])}}const Fu=new LE;class $E extends y.MessageType{constructor(){super("media.edge.TrackSubscription",[{no:1,name:"label",kind:"scalar",T:9},{no:2,name:"webcam",kind:"message",T:()=>Fu},{no:3,name:"screenshare",kind:"message",T:()=>Fu}])}}const UE=new $E;class qE extends y.MessageType{constructor(){super("media.edge.PeerProducingTransportCreateBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"transport_details",kind:"message",T:()=>bp},{no:3,name:"track_subscriptions",kind:"message",repeat:1,T:()=>UE}])}}new qE;class HE extends y.MessageType{constructor(){super("media.edge.PeerProducerCreateBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"producer_state",kind:"message",T:()=>mo}])}}const FE=new HE;class BE extends y.MessageType{constructor(){super("media.edge.PeerProducerToggleBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"producer_state",kind:"message",T:()=>mo},{no:3,name:"initiator_participant_id",kind:"scalar",opt:!0,T:9}])}}const Bu=new BE;class jE extends y.MessageType{constructor(){super("media.edge.PeerProducerCloseBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"producer_state",kind:"message",T:()=>mo}])}}const GE=new jE;class JE extends y.MessageType{constructor(){super("media.edge.PeerLeaveBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}const Fd=new JE;class WE extends y.MessageType{constructor(){super("media.edge.GlobalPeerPinningBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}const ju=new WE;class KE extends y.MessageType{constructor(){super("media.edge.GlobalPeerUnPinningBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}new KE;class zE extends y.MessageType{constructor(){super("media.edge.RecordingStartedBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}new zE;class YE extends y.MessageType{constructor(){super("media.edge.RecordingStoppedBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9}])}}new YE;class QE extends y.MessageType{constructor(){super("media.edge.PeerDisplayNameEditBroadcastResponse",[{no:1,name:"participant_id",kind:"scalar",T:9},{no:2,name:"display_name",kind:"scalar",T:9}])}}new QE;class XE extends y.MessageType{constructor(){super("media.edge.PeerPingRequestBroadcastResponse",[{no:1,name:"password",kind:"scalar",T:9}])}}new XE;class ZE extends y.MessageType{constructor(){super("media.edge.MediaRoomTerminationBroadcastResponse",[{no:1,name:"reason",kind:"scalar",T:9}])}}new ZE;class ew extends y.MessageType{constructor(){super("socket.ai.MeetingTranscript",[{no:1,name:"meeting_id",kind:"scalar",T:9},{no:2,name:"transcript",kind:"scalar",T:9},{no:3,name:"is_partial",kind:"scalar",T:8}])}}const Sd=new ew;class tw extends y.MessageType{constructor(){super("socket.api.BaseSocketHubMessage",[{no:1,name:"event",kind:"scalar",T:5},{no:2,name:"id",kind:"scalar",T:9},{no:3,name:"peer_id",kind:"scalar",T:9},{no:4,name:"room_id",kind:"scalar",T:9},{no:5,name:"user_id",kind:"scalar",T:9},{no:6,name:"payload",kind:"scalar",T:12},{no:7,name:"error",kind:"scalar",opt:!0,T:8},{no:8,name:"sid",kind:"scalar",opt:!0,T:9}])}}new tw;class sw extends y.MessageType{constructor(){super("socket.api.ErrorMessage",[{no:1,name:"code",kind:"scalar",opt:!0,T:5},{no:2,name:"message",kind:"scalar",T:9}])}}const rw=new sw;var li;(function(s){s[s.BROWSER=0]="BROWSER",s[s.TRACK=1]="TRACK",s[s.COMPOSITE=2]="COMPOSITE"})(li||(li={}));var bs;(function(s){s[s.UNSPECIFIED=0]="UNSPECIFIED",s[s.ON_STAGE=1]="ON_STAGE",s[s.APPROVED_STAGE=2]="APPROVED_STAGE",s[s.REQUESTED_STAGE=3]="REQUESTED_STAGE",s[s.OFF_STAGE=4]="OFF_STAGE"})(bs||(bs={}));var Bd;(function(s){s[s.NONE=0]="NONE",s[s.RECORDER=1]="RECORDER",s[s.LIVESTREAMER=2]="LIVESTREAMER"})(Bd||(Bd={}));var jd;(function(s){s[s.PEERS=0]="PEERS",s[s.ROOMS=1]="ROOMS"})(jd||(jd={}));var zo;(function(s){s[s.HIVE=0]="HIVE",s[s.CHAT=1]="CHAT",s[s.PING=2]="PING"})(zo||(zo={}));class iw extends y.MessageType{constructor(){super("socket.room.PeerFlags",[{no:1,name:"preset_name",kind:"scalar",T:9},{no:2,name:"recorder_type",kind:"scalar",T:9},{no:3,name:"hidden_participant",kind:"scalar",T:8}])}}const nw=new iw;class aw extends y.MessageType{constructor(){super("socket.room.Peer",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"user_id",kind:"scalar",T:9},{no:3,name:"display_name",kind:"scalar",T:9},{no:4,name:"stage_type",kind:"enum",opt:!0,T:()=>["socket.room.StageType",bs,"STAGE_TYPE_"]},{no:5,name:"custom_participant_id",kind:"scalar",opt:!0,T:9},{no:6,name:"preset_id",kind:"scalar",opt:!0,T:9},{no:7,name:"display_picture_url",kind:"scalar",opt:!0,T:9},{no:8,name:"waitlisted",kind:"scalar",T:8},{no:9,name:"flags",kind:"message",T:()=>nw}])}}const td=new aw;class ow extends y.MessageType{constructor(){super("socket.room.PeerInfoResponse",[{no:1,name:"peer",kind:"message",T:()=>td}])}}const Pi=new ow;class cw extends y.MessageType{constructor(){super("socket.room.PeerStatusUpdate",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"user_id",kind:"scalar",T:9},{no:3,name:"stage_type",kind:"enum",opt:!0,T:()=>["socket.room.StageType",bs,"STAGE_TYPE_"]}])}}const Gu=new cw;class dw extends y.MessageType{constructor(){super("socket.room.RoomPeersInfoRequest",[{no:1,name:"seach_query",kind:"scalar",T:9},{no:2,name:"limit",kind:"scalar",T:5},{no:3,name:"offset",kind:"scalar",T:5}])}}const lw=new dw;class uw extends y.MessageType{constructor(){super("socket.room.RoomPeersInfoResponse",[{no:1,name:"peers",kind:"message",repeat:1,T:()=>td}])}}const Pd=new uw;class hw extends y.MessageType{constructor(){super("socket.room.RoomPeerCountResponse",[{no:1,name:"count",kind:"scalar",T:4,L:2}])}}const Ju=new hw;class pw extends y.MessageType{constructor(){super("socket.room.Room",[{no:1,name:"room_id",kind:"scalar",T:9},{no:2,name:"title",kind:"scalar",T:9},{no:4,name:"created_at",kind:"scalar",T:4,L:2},{no:5,name:"active_recordings",kind:"message",repeat:1,T:()=>mw},{no:6,name:"room_uuid",kind:"scalar",opt:!0,T:9}])}}const Np=new pw;class gw extends y.MessageType{constructor(){super("socket.room.ActiveRecording",[{no:1,name:"recording_id",kind:"scalar",T:9},{no:2,name:"recording_type",kind:"enum",T:()=>["common.RecordingType",li]},{no:3,name:"recording_status",kind:"scalar",T:9}])}}const mw=new gw;class fw extends y.MessageType{constructor(){super("socket.room.RoomInfoResponse",[{no:1,name:"room",kind:"message",T:()=>Np}])}}const Wu=new fw;class Tw extends y.MessageType{constructor(){super("socket.room.GetPeerInfoRequest",[{no:1,name:"peer_id",kind:"scalar",T:9}])}}const Vp=new Tw;class yw extends y.MessageType{constructor(){super("socket.room.UpdatePeerInfoRequest",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"display_name",kind:"scalar",opt:!0,T:9}])}}new yw;class vw extends y.MessageType{constructor(){super("socket.room.JoinRoomRequest",[{no:1,name:"peer",kind:"message",T:()=>td},{no:3,name:"room_uuid",kind:"scalar",T:9},{no:4,name:"organization_id",kind:"scalar",opt:!0,T:9},{no:5,name:"use_hive",kind:"scalar",opt:!0,T:8},{no:6,name:"preset",kind:"scalar",opt:!0,T:12},{no:7,name:"capabilities",kind:"enum",repeat:1,T:()=>["socket.room.Capabilities",zo,"CAPABILITIES_"]},{no:8,name:"timestamp",kind:"scalar",opt:!0,T:4,L:2}])}}const Sw=new vw;class Pw extends y.MessageType{constructor(){super("socket.room.LeaveRoomRequest",[{no:1,name:"peer",kind:"message",T:()=>td},{no:2,name:"timestamp",kind:"scalar",opt:!0,T:4,L:2}])}}const Ew=new Pw;class ww extends y.MessageType{constructor(){super("socket.room.UpdateRoomInfoRequest",[{no:1,name:"room",kind:"message",T:()=>Np}])}}new ww;class Cw extends y.MessageType{constructor(){super("socket.room.GetConnectedRoomsDumpRequest",[])}}new Cw;class _w extends y.MessageType{constructor(){super("socket.room.ServiceError",[{no:1,name:"message",kind:"scalar",opt:!0,T:9},{no:2,name:"code",kind:"scalar",opt:!0,T:9}])}}const Ml=new _w;class Rw extends y.MessageType{constructor(){super("socket.room.ConnectedMeetingPeer",[{no:1,name:"id",kind:"scalar",opt:!0,T:9},{no:2,name:"display_name",kind:"scalar",opt:!0,T:9},{no:3,name:"custom_participant_id",kind:"scalar",opt:!0,T:9},{no:4,name:"preset_id",kind:"scalar",opt:!0,T:9},{no:5,name:"display_picture_url",kind:"scalar",opt:!0,T:9}])}}const kw=new Rw;class bw extends y.MessageType{constructor(){super("socket.room.ConnectedMeetingDump",[{no:1,name:"id",kind:"scalar",opt:!0,T:9},{no:2,name:"title",kind:"scalar",opt:!0,T:9},{no:3,name:"participants",kind:"message",repeat:1,T:()=>kw}])}}const Ku=new bw;class Mw extends y.MessageType{constructor(){super("socket.room.GetConnectedRoomsDumpResponse",[{no:1,name:"parent_meeting",kind:"message",T:()=>Ku},{no:2,name:"meetings",kind:"message",repeat:1,T:()=>Ku}])}}const Aw=new Mw;class Iw extends y.MessageType{constructor(){super("socket.room.CreateRoomRequestPayload",[{no:1,name:"title",kind:"scalar",opt:!0,T:9}])}}const Ow=new Iw;class Dw extends y.MessageType{constructor(){super("socket.room.CreateConnectedRoomsRequest",[{no:1,name:"payloads",kind:"message",repeat:1,T:()=>Ow}])}}const Nw=new Dw;class Vw extends y.MessageType{constructor(){super("socket.room.CreateRoomResponsePayload",[{no:1,name:"id",kind:"scalar",opt:!0,T:9},{no:2,name:"title",kind:"scalar",opt:!0,T:9},{no:3,name:"error",kind:"message",T:()=>Ml}])}}const xw=new Vw;class Lw extends y.MessageType{constructor(){super("socket.room.CreateConnectedRoomsResponse",[{no:1,name:"payloads",kind:"message",repeat:1,T:()=>xw}])}}const zu=new Lw;class $w extends y.MessageType{constructor(){super("socket.room.UpdateRoomRequestPayload",[{no:1,name:"meeting_id",kind:"scalar",opt:!0,T:9},{no:2,name:"title",kind:"scalar",opt:!0,T:9}])}}const Uw=new $w;class qw extends y.MessageType{constructor(){super("socket.room.UpdateConnectedRoomsRequest",[{no:1,name:"payloads",kind:"message",repeat:1,T:()=>Uw}])}}new qw;class Hw extends y.MessageType{constructor(){super("socket.room.DisableRoomPayload",[{no:1,name:"id",kind:"scalar",opt:!0,T:9}])}}const Fw=new Hw;class Bw extends y.MessageType{constructor(){super("socket.room.DisableConnectedRoomsRequest",[{no:1,name:"payloads",kind:"message",repeat:1,T:()=>Fw}])}}const jw=new Bw;class Gw extends y.MessageType{constructor(){super("socket.room.DisableConnectedRoomsResponse",[{no:1,name:"payloads",kind:"message",repeat:1,T:()=>Kw}])}}const Jw=new Gw;class Ww extends y.MessageType{constructor(){super("socket.room.DisableConnectedRoomPayload",[{no:1,name:"id",kind:"scalar",opt:!0,T:9},{no:2,name:"status",kind:"scalar",opt:!0,T:9},{no:3,name:"title",kind:"scalar",opt:!0,T:9},{no:4,name:"error",kind:"message",T:()=>Ml}])}}const Kw=new Ww;class zw extends y.MessageType{constructor(){super("socket.room.MovePeerPayload",[{no:1,name:"id",kind:"scalar",opt:!0,T:9},{no:2,name:"preset_id",kind:"scalar",opt:!0,T:9}])}}const Yw=new zw;class Qw extends y.MessageType{constructor(){super("socket.room.MovePeersBetweenRoomsRequest",[{no:1,name:"source_meeting_id",kind:"scalar",opt:!0,T:9},{no:2,name:"destination_meeting_id",kind:"scalar",opt:!0,T:9},{no:3,name:"participants",kind:"message",repeat:1,T:()=>Yw}])}}const Xw=new Qw;class Zw extends y.MessageType{constructor(){super("socket.room.MovedPeer",[{no:1,name:"meeting_id",kind:"scalar",opt:!0,T:9},{no:2,name:"custom_participant_id",kind:"scalar",opt:!0,T:9},{no:3,name:"error",kind:"message",T:()=>Ml}])}}const xp=new Zw;class eC extends y.MessageType{constructor(){super("socket.room.MovePeersBetweenRoomsResponse",[{no:1,name:"payloads",kind:"message",repeat:1,T:()=>xp}])}}new eC;class tC extends y.MessageType{constructor(){super("socket.room.TransferPeer",[{no:1,name:"meeting_id",kind:"scalar",opt:!0,T:9},{no:2,name:"auth_token",kind:"scalar",opt:!0,T:9}])}}const sC=new tC;class rC extends y.MessageType{constructor(){super("socket.room.GetAllAddedParticipantsResponse",[{no:1,name:"participants",kind:"message",repeat:1,T:()=>aC}])}}const iC=new rC;class nC extends y.MessageType{constructor(){super("socket.room.AddedParticipant",[{no:1,name:"id",kind:"scalar",T:9},{no:2,name:"name",kind:"scalar",opt:!0,T:9},{no:3,name:"picture",kind:"scalar",opt:!0,T:9},{no:4,name:"custom_participant_id",kind:"scalar",T:9}])}}const aC=new nC;class oC extends y.MessageType{constructor(){super("socket.room.RemoveParticipantsRequest",[{no:1,name:"peer_ids",kind:"scalar",repeat:2,T:9}])}}const Lp=new oC;class cC extends y.MessageType{constructor(){super("socket.room.BroadcastMessage",[{no:1,name:"type",kind:"scalar",T:9},{no:2,name:"payload",kind:"scalar",T:12},{no:3,name:"timestamp",kind:"scalar",T:4,L:2},{no:4,name:"ids",kind:"scalar",repeat:2,T:9},{no:5,name:"broadcast_type",kind:"enum",opt:!0,T:()=>["socket.room.BroadcastType",jd,"BROADCAST_TYPE_"]}])}}const Bn=new cC;class dC extends y.MessageType{constructor(){super("socket.room.AcceptWaitingRoomRequests",[{no:1,name:"user_ids",kind:"scalar",repeat:2,T:9}])}}const lC=new dC;class uC extends y.MessageType{constructor(){super("socket.room.DenyWaitingRoomRequests",[{no:1,name:"user_ids",kind:"scalar",repeat:2,T:9}])}}const hC=new uC;class pC extends y.MessageType{constructor(){super("socket.room.WaitingRoomRequest",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"user_id",kind:"scalar",T:9},{no:3,name:"display_name",kind:"scalar",T:9},{no:4,name:"picture",kind:"scalar",opt:!0,T:9},{no:5,name:"custom_participant_id",kind:"scalar",opt:!0,T:9},{no:6,name:"preset_name",kind:"scalar",opt:!0,T:9}])}}const gC=new pC;class mC extends y.MessageType{constructor(){super("socket.room.GetWaitingRoomRequests",[{no:1,name:"requests",kind:"message",repeat:1,T:()=>gC}])}}const Yu=new mC;class fC extends y.MessageType{constructor(){super("socket.room.GetRoomStageStateResponse",[{no:1,name:"on_stage_peers",kind:"scalar",repeat:2,T:9},{no:2,name:"approved_stage_peers",kind:"scalar",repeat:2,T:9},{no:3,name:"requested_stage_peers",kind:"scalar",repeat:2,T:9}])}}const Qu=new fC;var Gd;(function(s){s[s.NONE=0]="NONE",s[s.SKIP=1]="SKIP",s[s.ON_PRIVILEGED_USER_ENTRY=2]="ON_PRIVILEGED_USER_ENTRY",s[s.SKIP_ON_ACCEPT=3]="SKIP_ON_ACCEPT"})(Gd||(Gd={}));var or;(function(s){s[s.NONE=0]="NONE",s[s.ALLOWED=1]="ALLOWED",s[s.NOT_ALLOWED=2]="NOT_ALLOWED",s[s.CAN_REQUEST=3]="CAN_REQUEST"})(or||(or={}));class TC extends y.MessageType{constructor(){super("socket.preset.PollsPermissionUpdate",[{no:1,name:"can_create",kind:"scalar",opt:!0,T:8},{no:2,name:"can_vote",kind:"scalar",opt:!0,T:8},{no:3,name:"can_view",kind:"scalar",opt:!0,T:8}])}}const yC=new TC;class vC extends y.MessageType{constructor(){super("socket.preset.PluginsPermissionsUpdate",[{no:1,name:"can_close",kind:"scalar",opt:!0,T:8},{no:2,name:"can_start",kind:"scalar",opt:!0,T:8}])}}const SC=new vC;class PC extends y.MessageType{constructor(){super("socket.preset.PublicChatPermission",[{no:1,name:"can_send",kind:"scalar",opt:!0,T:8},{no:2,name:"text",kind:"scalar",opt:!0,T:8},{no:3,name:"files",kind:"scalar",opt:!0,T:8}])}}const EC=new PC;class wC extends y.MessageType{constructor(){super("socket.preset.PrivateChatPermission",[{no:1,name:"can_send",kind:"scalar",opt:!0,T:8},{no:2,name:"can_receive",kind:"scalar",opt:!0,T:8},{no:3,name:"text",kind:"scalar",opt:!0,T:8},{no:4,name:"files",kind:"scalar",opt:!0,T:8}])}}const CC=new wC;class _C extends y.MessageType{constructor(){super("socket.preset.ChatPermissionUpdate",[{no:1,name:"public",kind:"message",T:()=>EC},{no:2,name:"private",kind:"message",T:()=>CC}])}}const RC=new _C;class kC extends y.MessageType{constructor(){super("socket.preset.ConnectedMeetingPermissionUpdate",[{no:1,name:"can_alter_connected_meetings",kind:"scalar",opt:!0,T:8},{no:2,name:"can_switch_to_parent_meeting",kind:"scalar",opt:!0,T:8},{no:3,name:"can_switch_connected_meetings",kind:"scalar",opt:!0,T:8}])}}const bC=new kC;class MC extends y.MessageType{constructor(){super("socket.preset.StreamPermission",[{no:1,name:"can_produce",kind:"enum",opt:!0,T:()=>["socket.preset.StreamPermissionType",or,"STREAM_PERMISSION_TYPE_"]},{no:2,name:"can_consume",kind:"enum",opt:!0,T:()=>["socket.preset.StreamPermissionType",or,"STREAM_PERMISSION_TYPE_"]}])}}const Ed=new MC;class AC extends y.MessageType{constructor(){super("socket.preset.MediaPermissionUpdate",[{no:1,name:"video",kind:"message",T:()=>Ed},{no:2,name:"audio",kind:"message",T:()=>Ed},{no:3,name:"screenshare",kind:"message",T:()=>Ed}])}}const IC=new AC;class OC extends y.MessageType{constructor(){super("socket.preset.PresetUpdates",[{no:1,name:"polls",kind:"message",T:()=>yC},{no:2,name:"plugins",kind:"message",T:()=>SC},{no:3,name:"chat",kind:"message",T:()=>RC},{no:4,name:"accept_waiting_requests",kind:"scalar",opt:!0,T:8},{no:5,name:"can_accept_production_requests",kind:"scalar",opt:!0,T:8},{no:6,name:"can_edit_display_name",kind:"scalar",opt:!0,T:8},{no:7,name:"can_record",kind:"scalar",opt:!0,T:8},{no:8,name:"can_livestream",kind:"scalar",opt:!0,T:8},{no:9,name:"can_spotlight",kind:"scalar",opt:!0,T:8},{no:10,name:"disable_participant_audio",kind:"scalar",opt:!0,T:8},{no:11,name:"disable_participant_screensharing",kind:"scalar",opt:!0,T:8},{no:12,name:"disable_participant_video",kind:"scalar",opt:!0,T:8},{no:13,name:"kick_participant",kind:"scalar",opt:!0,T:8},{no:14,name:"pin_participant",kind:"scalar",opt:!0,T:8},{no:15,name:"transcription_enabled",kind:"scalar",opt:!0,T:8},{no:16,name:"waiting_room_type",kind:"enum",opt:!0,T:()=>["socket.preset.WaitingRoomType",Gd,"WAITING_ROOM_TYPE_"]},{no:17,name:"is_recorder",kind:"scalar",opt:!0,T:8},{no:18,name:"recorder_type",kind:"enum",opt:!0,T:()=>["socket.room.RecorderType",Bd,"RECORDER_TYPE_"]},{no:19,name:"hidden_participant",kind:"scalar",opt:!0,T:8},{no:20,name:"show_participant_list",kind:"scalar",opt:!0,T:8},{no:21,name:"can_change_participant_permissions",kind:"scalar",opt:!0,T:8},{no:22,name:"connected_meetings",kind:"message",T:()=>bC},{no:23,name:"media",kind:"message",T:()=>IC}])}}const Al=new OC;class DC extends y.MessageType{constructor(){super("socket.preset.ReadPeersPresetRequest",[{no:1,name:"user_ids",kind:"scalar",repeat:2,T:9}])}}const NC=new DC;class VC extends y.MessageType{constructor(){super("socket.preset.PeerPreset",[{no:1,name:"user_id",kind:"scalar",T:9},{no:2,name:"peer_id",kind:"scalar",T:9},{no:3,name:"preset",kind:"scalar",T:12}])}}const xC=new VC;class LC extends y.MessageType{constructor(){super("socket.preset.ReadPeersPresetResponse",[{no:1,name:"peer_presets",kind:"message",repeat:1,T:()=>xC}])}}const $C=new LC;class UC extends y.MessageType{constructor(){super("socket.preset.UpdatePeerPreset",[{no:1,name:"user_ids",kind:"scalar",T:9},{no:2,name:"patch",kind:"message",T:()=>Al}])}}const $p=new UC;class qC extends y.MessageType{constructor(){super("socket.preset.UpdatePeersPresetRequest",[{no:1,name:"update_peers_presets",kind:"message",repeat:1,T:()=>$p}])}}const HC=new qC;class FC extends y.MessageType{constructor(){super("socket.preset.UpdatePeersPresetResponse",[{no:1,name:"update_peers_presets",kind:"message",repeat:1,T:()=>$p}])}}const Xu=new FC;class BC extends y.MessageType{constructor(){super("socket.preset.PeerUserIDMap",[{no:1,name:"peer_id",kind:"scalar",T:9},{no:2,name:"user_id",kind:"scalar",T:9}])}}const jC=new BC;class GC extends y.MessageType{constructor(){super("socket.preset.BulkUpdatePeerPresetRequest",[{no:1,name:"peers",kind:"message",repeat:1,T:()=>jC},{no:2,name:"patch",kind:"message",T:()=>Al}])}}new GC;class JC extends y.MessageType{constructor(){super("socket.preset.BulkUpdatePeerPresetResponse",[{no:2,name:"patch",kind:"message",T:()=>Al}])}}new JC;class WC extends y.MessageType{constructor(){super("socket.chat.ChatMessage",[{no:1,name:"chat_id",kind:"scalar",T:9},{no:2,name:"peer_id",kind:"scalar",T:9},{no:3,name:"user_id",kind:"scalar",T:9},{no:4,name:"display_name",kind:"scalar",T:9},{no:5,name:"pinned",kind:"scalar",T:8},{no:6,name:"is_edited",kind:"scalar",T:8},{no:7,name:"payload_type",kind:"scalar",T:5},{no:8,name:"payload",kind:"scalar",T:9},{no:10,name:"target_user_ids",kind:"scalar",repeat:2,T:9},{no:11,name:"created_at",kind:"scalar",T:4,L:2},{no:12,name:"created_at_ms",kind:"scalar",opt:!0,T:4,L:2},{no:13,name:"channel_id",kind:"scalar",opt:!0,T:9},{no:14,name:"channel_index",kind:"scalar",opt:!0,T:9}])}}const hr=new WC;class KC extends y.MessageType{constructor(){super("socket.chat.GetPaginatedChatMessageFilters",[{no:1,name:"pinned",kind:"scalar",oneof:"filters",T:8},{no:2,name:"user_id",kind:"scalar",oneof:"filters",T:9}])}}const zC=new KC;class YC extends y.MessageType{constructor(){super("socket.chat.GetPaginatedChatMessageRoomRequest",[{no:1,name:"time_stamp",kind:"scalar",T:4,L:2},{no:2,name:"size",kind:"scalar",T:5},{no:3,name:"from",kind:"scalar",T:5},{no:4,name:"reversed",kind:"scalar",T:8},{no:5,name:"channel_id",kind:"scalar",opt:!0,T:9},{no:6,name:"filters",kind:"message",T:()=>zC}])}}const QC=new YC;class XC extends y.MessageType{constructor(){super("socket.chat.GetPaginatedChatMessageRoomResponse",[{no:1,name:"messages",kind:"message",repeat:1,T:()=>hr},{no:2,name:"next",kind:"scalar",T:8}])}}const ZC=new XC;class e_ extends y.MessageType{constructor(){super("socket.chat.GetChatMessagesResponse",[{no:1,name:"messages",kind:"message",repeat:1,T:()=>hr}])}}const Up=new e_;class t_ extends y.MessageType{constructor(){super("socket.chat.SendChatMessageToRoomRequest",[{no:1,name:"payload_type",kind:"scalar",T:5},{no:2,name:"payload",kind:"scalar",T:9}])}}const s_=new t_;class r_ extends y.MessageType{constructor(){super("socket.chat.SendChatMessageToRoomResponse",[{no:1,name:"message",kind:"message",T:()=>hr}])}}const wd=new r_;class i_ extends y.MessageType{constructor(){super("socket.chat.SendChatMessageToPeersRequest",[{no:1,name:"peer_ids",kind:"scalar",repeat:2,T:9},{no:2,name:"payload_type",kind:"scalar",T:5},{no:3,name:"payload",kind:"scalar",T:9}])}}const n_=new i_;class a_ extends y.MessageType{constructor(){super("socket.chat.SendChatMessageToPeersResponse",[{no:1,name:"message",kind:"message",T:()=>hr}])}}const Cd=new a_;class o_ extends y.MessageType{constructor(){super("socket.chat.SendChatMessageToChannelRequest",[{no:1,name:"channel_id",kind:"scalar",T:9},{no:2,name:"payload_type",kind:"scalar",T:5},{no:3,name:"payload",kind:"scalar",T:9}])}}new o_;class c_ extends y.MessageType{constructor(){super("socket.chat.SendChatMessageToChannelResponse",[{no:1,name:"message",kind:"message",T:()=>hr}])}}new c_;class d_ extends y.MessageType{constructor(){super("socket.chat.EditChatMessageRequest",[{no:1,name:"chat_id",kind:"scalar",T:9},{no:2,name:"payload_type",kind:"scalar",opt:!0,T:5},{no:3,name:"payload",kind:"scalar",opt:!0,T:9},{no:4,name:"pinned",kind:"scalar",opt:!0,T:8},{no:5,name:"channel_id",kind:"scalar",opt:!0,T:9}])}}const l_=new d_;class u_ extends y.MessageType{constructor(){super("socket.chat.PinChatMessageRequest",[{no:1,name:"chat_id",kind:"scalar",T:9},{no:2,name:"pinned",kind:"scalar",T:8},{no:3,name:"channel_id",kind:"scalar",opt:!0,T:9}])}}const h_=new u_;class p_ extends y.MessageType{constructor(){super("socket.chat.PinChatMessageResponse",[{no:1,name:"chat_id",kind:"scalar",T:9},{no:2,name:"pinned",kind:"scalar",T:8},{no:3,name:"channel_id",kind:"scalar",opt:!0,T:9},{no:4,name:"message",kind:"message",T:()=>hr}])}}const Mo=new p_;class g_ extends y.MessageType{constructor(){super("socket.chat.EditChatMessageResponse",[{no:1,name:"message",kind:"message",T:()=>hr}])}}const Ao=new g_;class m_ extends y.MessageType{constructor(){super("socket.chat.DeleteChatMessageRequest",[{no:1,name:"chat_id",kind:"scalar",T:9},{no:2,name:"channel_id",kind:"scalar",opt:!0,T:9}])}}const f_=new m_;class T_ extends y.MessageType{constructor(){super("socket.chat.DeleteChatMessageResponse",[{no:1,name:"chat_id",kind:"scalar",T:9},{no:2,name:"channel_id",kind:"scalar",opt:!0,T:9}])}}const Io=new T_;class y_ extends y.MessageType{constructor(){super("socket.chat.SearchChatMessagesRequest",[{no:1,name:"time_stamp",kind:"scalar",T:4,L:2},{no:2,name:"size",kind:"scalar",T:5},{no:3,name:"from",kind:"scalar",T:5},{no:4,name:"reversed",kind:"scalar",T:8},{no:5,name:"channel_id",kind:"scalar",opt:!0,T:9},{no:6,name:"search_term",kind:"scalar",T:9}])}}const v_=new y_;class S_ extends y.MessageType{constructor(){super("socket.chat.MarkChannelIndexAsReadRequest",[{no:1,name:"channel_id",kind:"scalar",T:9},{no:2,name:"user_id",kind:"scalar",T:9},{no:3,name:"channel_index",kind:"scalar",T:9}])}}new S_;class P_ extends y.MessageType{constructor(){super("socket.chat.MarkChannelIndexAsReadResponse",[{no:1,name:"channel_index",kind:"scalar",T:9}])}}new P_;class E_ extends y.MessageType{constructor(){super("socket.chat.CreateChatChannelRequest",[{no:1,name:"display_name",kind:"scalar",T:9},{no:2,name:"target_user_ids",kind:"scalar",repeat:2,T:9},{no:3,name:"display_picture_url",kind:"scalar",opt:!0,T:9},{no:4,name:"visibility",kind:"scalar",T:9},{no:5,name:"is_direct_message",kind:"scalar",T:8}])}}new E_;class w_ extends y.MessageType{constructor(){super("socket.chat.UpdateChatChannelRequest",[{no:1,name:"chat_channel_id",kind:"scalar",T:9},{no:2,name:"display_name",kind:"scalar",opt:!0,T:9},{no:3,name:"target_user_ids",kind:"scalar",repeat:2,T:9},{no:4,name:"display_picture_url",kind:"scalar",opt:!0,T:9},{no:5,name:"visibility",kind:"scalar",opt:!0,T:9},{no:6,name:"is_direct_message",kind:"scalar",opt:!0,T:8}])}}new w_;class C_ extends y.MessageType{constructor(){super("socket.chat.CreateChatChannelResponse",[{no:1,name:"chat_channel_id",kind:"scalar",T:9}])}}new C_;class __ extends y.MessageType{constructor(){super("socket.chat.GetChatChannelRequest",[{no:1,name:"chat_channel_id",kind:"scalar",T:9}])}}new __;class R_ extends y.MessageType{constructor(){super("socket.chat.LatestMessageAndUnreadCount",[{no:1,name:"message",kind:"message",T:()=>hr},{no:2,name:"unread_count",kind:"scalar",T:4,L:2}])}}const k_=new R_;class b_ extends y.MessageType{constructor(){super("socket.chat.ChatChannel",[{no:1,name:"chat_channel_id",kind:"scalar",T:9},{no:2,name:"display_name",kind:"scalar",T:9},{no:3,name:"display_picture_url",kind:"scalar",opt:!0,T:9},{no:4,name:"visibility",kind:"scalar",T:9},{no:5,name:"is_direct_message",kind:"scalar",T:8},{no:6,name:"latest_message_and_unread_count",kind:"message",T:()=>k_},{no:7,name:"target_user_ids",kind:"scalar",repeat:2,T:9}])}}const M_=new b_;class A_ extends y.MessageType{constructor(){super("socket.chat.GetChatChannelResponse",[{no:1,name:"chat_channels",kind:"message",repeat:1,T:()=>M_}])}}new A_;class I_ extends y.MessageType{constructor(){super("socket.chat.ChannelMember",[{no:1,name:"id",kind:"scalar",T:9},{no:2,name:"name",kind:"scalar",opt:!0,T:9},{no:3,name:"picture",kind:"scalar",opt:!0,T:9},{no:4,name:"custom_participant_id",kind:"scalar",T:9}])}}const O_=new I_;class D_ extends y.MessageType{constructor(){super("socket.chat.GetChatChannelMembersResponse",[{no:1,name:"channel_members",kind:"message",repeat:1,T:()=>O_}])}}new D_;class N_ extends y.MessageType{constructor(){super("socket.plugin.AddPluginRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"staggered",kind:"scalar",T:8}])}}const V_=new N_;class x_ extends y.MessageType{constructor(){super("socket.plugin.RemovePluginRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"staggered",kind:"scalar",T:8}])}}const L_=new x_;class $_ extends y.MessageType{constructor(){super("socket.plugin.EnablePluginForRoomRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9}])}}const U_=new $_;class q_ extends y.MessageType{constructor(){super("socket.plugin.DisablePluginForRoomRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9}])}}const H_=new q_;class F_ extends y.MessageType{constructor(){super("socket.plugin.EnablePluginForPeersRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"peer_ids",kind:"scalar",repeat:2,T:9}])}}const B_=new F_;class j_ extends y.MessageType{constructor(){super("socket.plugin.DisablePluginForPeersRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"peer_ids",kind:"scalar",repeat:2,T:9}])}}const G_=new j_;class J_ extends y.MessageType{constructor(){super("socket.plugin.PluginEventToRoomRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"plugin_data",kind:"scalar",T:12}])}}const W_=new J_;class K_ extends y.MessageType{constructor(){super("socket.plugin.PluginEventToPeersRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"peer_ids",kind:"scalar",repeat:2,T:9},{no:3,name:"plugin_data",kind:"scalar",T:12}])}}const z_=new K_;class Y_ extends y.MessageType{constructor(){super("socket.plugin.StoreKeys",[{no:1,name:"store_key",kind:"scalar",T:9},{no:2,name:"payload",kind:"scalar",opt:!0,T:12}])}}const Il=new Y_;class Q_ extends y.MessageType{constructor(){super("socket.plugin.PluginStoreInsertKeysRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"store_name",kind:"scalar",T:9},{no:3,name:"insert_keys",kind:"message",repeat:1,T:()=>Il}])}}const Zu=new Q_;class X_ extends y.MessageType{constructor(){super("socket.plugin.PluginStoreGetKeysRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"store_name",kind:"scalar",T:9},{no:3,name:"get_keys",kind:"message",repeat:1,T:()=>Il}])}}const Z_=new X_;class eR extends y.MessageType{constructor(){super("socket.plugin.PluginStoreDeleteKeysRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"store_name",kind:"scalar",T:9},{no:3,name:"delete_keys",kind:"message",repeat:1,T:()=>Il}])}}const tR=new eR;class sR extends y.MessageType{constructor(){super("socket.plugin.PluginStoreDeleteRequest",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"store_name",kind:"scalar",T:9}])}}const rR=new sR;class iR extends y.MessageType{constructor(){super("socket.plugin.EnablePluginResponse",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"enabled_by",kind:"scalar",T:9}])}}const Jd=new iR;class nR extends y.MessageType{constructor(){super("socket.plugin.EnablePluginsResponse",[{no:1,name:"plugins",kind:"message",repeat:1,T:()=>Jd}])}}const aR=new nR;class oR extends y.MessageType{constructor(){super("socket.plugin.DisablePluginResponse",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"disabled_by",kind:"scalar",T:9}])}}const eh=new oR;class cR extends y.MessageType{constructor(){super("socket.plugin.PluginStoreItem",[{no:1,name:"timestamp",kind:"scalar",T:9},{no:2,name:"peer_id",kind:"scalar",T:9},{no:3,name:"store_key",kind:"scalar",T:9},{no:4,name:"payload",kind:"scalar",T:12}])}}const dR=new cR;class lR extends y.MessageType{constructor(){super("socket.plugin.PluginStoreResponse",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"store_name",kind:"scalar",T:9},{no:3,name:"store_items",kind:"message",repeat:1,T:()=>dR}])}}const th=new lR;class uR extends y.MessageType{constructor(){super("socket.plugin.PluginEventResponse",[{no:1,name:"plugin_id",kind:"scalar",T:9},{no:2,name:"plugin_data",kind:"scalar",T:12}])}}const sh=new uR;class hR extends y.MessageType{constructor(){super("socket.livestreaming.LiveStreamingEvent",[{no:1,name:"livestream_id",kind:"scalar",T:9},{no:2,name:"err_message",kind:"scalar",T:9},{no:3,name:"name",kind:"scalar",T:9},{no:4,name:"meeting_id",kind:"scalar",T:9},{no:5,name:"playback_url",kind:"scalar",T:9},{no:6,name:"org_id",kind:"scalar",T:9},{no:7,name:"room_name",kind:"scalar",T:9},{no:8,name:"room_uuid",kind:"scalar",T:9},{no:9,name:"status",kind:"scalar",T:9},{no:10,name:"manual_ingest",kind:"scalar",opt:!0,T:8}])}}const rh=new hR;class pR extends y.MessageType{constructor(){super("socket.livestreaming.GetStagePeersResponse",[{no:1,name:"stage_peers",kind:"scalar",repeat:2,T:9}])}}const ih=new pR;class gR extends y.MessageType{constructor(){super("socket.livestreaming.StageRequest",[{no:1,name:"display_name",kind:"scalar",T:9},{no:2,name:"user_id",kind:"scalar",T:9},{no:3,name:"peer_id",kind:"scalar",T:9}])}}const mR=new gR;class fR extends y.MessageType{constructor(){super("socket.livestreaming.GetStageRequestsResponse",[{no:1,name:"stage_requests",kind:"message",repeat:1,T:()=>mR}])}}const _d=new fR;class TR extends y.MessageType{constructor(){super("socket.livestreaming.GrantStageAccessRequest",[{no:1,name:"user_ids",kind:"scalar",repeat:2,T:9}])}}const yR=new TR;class vR extends y.MessageType{constructor(){super("socket.livestreaming.DenyStageAccessRequest",[{no:1,name:"user_ids",kind:"scalar",repeat:2,T:9}])}}const SR=new vR;class PR extends y.MessageType{constructor(){super("socket.livestreaming.LeaveStageRequest",[{no:1,name:"user_ids",kind:"scalar",repeat:2,T:9}])}}const nh=new PR;class ER extends y.MessageType{constructor(){super("socket.polls.Poll",[{no:1,name:"poll_id",kind:"scalar",T:9},{no:2,name:"created_by",kind:"scalar",T:9},{no:3,name:"created_by_user_id",kind:"scalar",T:9},{no:4,name:"question",kind:"scalar",T:9},{no:5,name:"options",kind:"message",repeat:1,T:()=>CR},{no:6,name:"hide_votes",kind:"scalar",T:8},{no:7,name:"anonymous",kind:"scalar",T:8},{no:8,name:"votes",kind:"scalar",repeat:2,T:9}])}}const qp=new ER;class wR extends y.MessageType{constructor(){super("socket.polls.PollOption",[{no:1,name:"text",kind:"scalar",T:9},{no:2,name:"count",kind:"scalar",opt:!0,T:4,L:2},{no:3,name:"votes",kind:"message",repeat:1,T:()=>RR}])}}const CR=new wR;class _R extends y.MessageType{constructor(){super("socket.polls.PollVote",[{no:1,name:"user_id",kind:"scalar",T:9},{no:2,name:"name",kind:"scalar",T:9}])}}const RR=new _R;class kR extends y.MessageType{constructor(){super("socket.polls.NewPollRequest",[{no:1,name:"question",kind:"scalar",T:9},{no:2,name:"options",kind:"scalar",repeat:2,T:9},{no:3,name:"anonymous",kind:"scalar",T:8},{no:4,name:"hide_votes",kind:"scalar",T:8},{no:5,name:"created_by",kind:"scalar",opt:!0,T:9},{no:6,name:"created_by_user_id",kind:"scalar",opt:!0,T:9}])}}const bR=new kR;class MR extends y.MessageType{constructor(){super("socket.polls.VotePollRequest",[{no:1,name:"poll_id",kind:"scalar",T:9},{no:2,name:"index",kind:"scalar",T:4,L:2}])}}const AR=new MR;class IR extends y.MessageType{constructor(){super("socket.polls.UpdatePollResponse",[{no:1,name:"poll",kind:"message",T:()=>qp}])}}const Rd=new IR;class OR extends y.MessageType{constructor(){super("socket.polls.GetPollsResponse",[{no:1,name:"polls",kind:"message",repeat:1,T:()=>qp}])}}const DR=new OR;class NR extends y.MessageType{constructor(){super("socket.recording.RecordingEvent",[{no:1,name:"recording_id",kind:"scalar",T:9},{no:2,name:"err_message",kind:"scalar",T:9},{no:3,name:"recording_type",kind:"enum",T:()=>["common.RecordingType",li]}])}}const ah=new NR;class VR extends y.MessageType{constructor(){super("google.protobuf.Timestamp",[{no:1,name:"seconds",kind:"scalar",T:3,L:0},{no:2,name:"nanos",kind:"scalar",T:5}])}now(){const t=this.create(),e=Date.now();return t.seconds=y.PbLong.from(Math.floor(e/1e3)).toBigInt(),t.nanos=e%1e3*1e6,t}toDate(t){return new Date(y.PbLong.from(t.seconds).toNumber()*1e3+Math.ceil(t.nanos/1e6))}fromDate(t){const e=this.create(),r=t.getTime();return e.seconds=y.PbLong.from(Math.floor(r/1e3)).toBigInt(),e.nanos=r%1e3*1e6,e}internalJsonWrite(t,e){let r=y.PbLong.from(t.seconds).toNumber()*1e3;if(r<Date.parse("0001-01-01T00:00:00Z")||r>Date.parse("9999-12-31T23:59:59Z"))throw new Error("Unable to encode Timestamp to JSON. Must be from 0001-01-01T00:00:00Z to 9999-12-31T23:59:59Z inclusive.");if(t.nanos<0)throw new Error("Unable to encode invalid Timestamp to JSON. Nanos must not be negative.");let i="Z";if(t.nanos>0){let a=(t.nanos+1e9).toString().substring(1);a.substring(3)==="000000"?i="."+a.substring(0,3)+"Z":a.substring(6)==="000"?i="."+a.substring(0,6)+"Z":i="."+a+"Z"}return new Date(r).toISOString().replace(".000Z",i)}internalJsonRead(t,e,r){if(typeof t!="string")throw new Error("Unable to parse Timestamp from JSON "+y.typeofJsonValue(t)+".");let i=t.match(/^([0-9]{4})-([0-9]{2})-([0-9]{2})T([0-9]{2}):([0-9]{2}):([0-9]{2})(?:Z|\.([0-9]{3,9})Z|([+-][0-9][0-9]:[0-9][0-9]))$/);if(!i)throw new Error("Unable to parse Timestamp from JSON. Invalid format.");let a=Date.parse(i[1]+"-"+i[2]+"-"+i[3]+"T"+i[4]+":"+i[5]+":"+i[6]+(i[8]?i[8]:"Z"));if(Number.isNaN(a))throw new Error("Unable to parse Timestamp from JSON. Invalid value.");if(a<Date.parse("0001-01-01T00:00:00Z")||a>Date.parse("9999-12-31T23:59:59Z"))throw new globalThis.Error("Unable to parse Timestamp from JSON. Must be from 0001-01-01T00:00:00Z to 9999-12-31T23:59:59Z inclusive.");return r||(r=this.create()),r.seconds=y.PbLong.from(a/1e3).toBigInt(),r.nanos=0,i[7]&&(r.nanos=parseInt("1"+i[7]+"0".repeat(9-i[7].length))-1e9),r}}new VR;class xR extends y.MessageType{constructor(){super("common.BaseHubMessage",[{no:1,name:"event",kind:"scalar",T:5},{no:2,name:"id",kind:"scalar",T:9},{no:3,name:"peer_id",kind:"scalar",T:9},{no:4,name:"room_id",kind:"scalar",T:9},{no:5,name:"user_id",kind:"scalar",T:9},{no:6,name:"payload",kind:"scalar",T:12},{no:7,name:"error",kind:"scalar",opt:!0,T:8},{no:8,name:"sid",kind:"scalar",opt:!0,T:9},{no:9,name:"room_object_id",kind:"scalar",opt:!0,T:9},{no:10,name:"preset",kind:"scalar",opt:!0,T:9},{no:11,name:"use_start_session",kind:"scalar",opt:!0,T:8}])}}const Wd=new xR;class LR extends y.MessageType{constructor(){super("common.BulkedHubMessage",[{no:1,name:"messages",kind:"message",repeat:1,T:()=>Wd}])}}new LR;class $R extends y.MessageType{constructor(){super("common.CFWorkersResponse",[{no:1,name:"responses",kind:"message",repeat:1,T:()=>Wd},{no:2,name:"broadcast_responses",kind:"message",repeat:1,T:()=>Wd}])}}new $R;const UR=0,qR=1,HR=2,FR=3,BR=5,jR={getPeerInfo:0,updatePeerInfo:1,getRoomPeersInfo:2,joinRoom:3,leaveRoom:4,getRoomInfo:5,updateRoomInfo:6,closeRoom:7,startedLivestream:8,stoppedLivestream:9,erroredLivestream:10,getStagePeers:11,getStageRequests:12,requestStageAccess:13,cancelStageRequest:14,grantStageAccess:15,denyStageAccess:16,roomPeerCount:17,joinStage:18,leaveStage:19,getConnectedRoomsDump:20,createConnectedRooms:21,deleteConnectedRooms:22,movePeers:23,transferPeer:24,movedPeer:25,connectedRoomsUpdated:26,connectedRoomsDeleted:27,getAllAddedParticipants:28,broadcastMessage:29,kick:30,kickAll:31,transcript:32,getWaitingRoomRequests:33,acceptWaitingRoomRequests:34,waitingRoomRequestAccepted:35,denyWaitingRoomRequests:36,waitingRoomRequestDenied:37,peerStageStatusUpdate:38,broadcastToEntity:39,recordingStarted:40,recordingStopped:41,recordingPaused:42,getRoomStageState:43,livestreamingInvoked:44},GR={getMessages:0,sendMessageToRoom:1,sendMessageToPeers:2,editMessage:3,deleteMessage:4,getPaginatedMessages:5,searchChannelMessages:7,pinMessage:10},JR={getPlugins:0,addPlugin:1,enablePluginForRoom:2,disablePluginForPeers:3,enablePluginForPeers:4,disablePluginForRoom:5,removePlugin:6,customPluginEventToRoom:7,customPluginEventToPeers:8,storeInsertKeys:9,storeGetKeys:10,storeDeleteKeys:11,storeDelete:12},WR={createPoll:0,getPolls:1,votePoll:2,updatePoll:3},Hp={unknown:0,createWebRTCTransport:1,produce:2,consume:3,toggleProducer:4,toggleConsumer:5,closeProducer:6,closeConsumer:7,updateConsumersSimulcastConfig:8,joinRoom:16,leaveRoom:17,selectedPeer:18,globalPinPeer:19,selfJoinComplete:20,peerJoinedBroadcast:25,peerLeaveBroadcast:26,peerProducerCreateBroadcast:27,peerProducerToggleBroadcast:28,peerProducerCloseBroadcast:29,globalPeerPinBroadcast:30,recordingStartedBroadcast:31,recordingStoppedBroadcast:32,peerDisplayNameEditBroadcast:33,mediaRoomTerminationBroadcastResponse:36,selectedPeerDiff:40,renegotiateSessionDescription:50,errorResponse:60,kickPeer:90,kickAll:91,changeDisplayName:92,hostControlPeer:93,hostControlAllPeers:94,audioActivity:100},KR={getUserPresets:0,updateUserPreset:1};function fo(s,t){return Object.keys(t).reduce((e,r)=>(e[r]=(s<<16)+t[r],e),{})}function Fp(s,t){return Object.keys(s).reduce((e,r)=>(e[r]=t|s[r],e),{})}const A=fo(UR,jR),pe=fo(qR,GR),$=fo(HR,JR),os=fo(FR,WR),Fs=Fp(Hp,16777216),Bt=Fp(Hp,50331648),Uo=fo(BR,KR);var zR=Object.defineProperty,YR=Object.getOwnPropertyDescriptor,pr=(s,t,e,r)=>{for(var i=r>1?void 0:r?YR(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&zR(t,e,i),i},Rt=(s=>(s[s.TEXT=0]="TEXT",s[s.IMAGE=1]="IMAGE",s[s.FILE=2]="FILE",s[s.CUSTOM=3]="CUSTOM",s))(Rt||{}),st,xi;class xs{constructor(t,e){h(this,st,void 0);h(this,xi,void 0);f(this,st,e),f(this,xi,t)}get telemetry(){return n(this,xi).getValue("telemetry")}get logger(){return n(this,xi).getValue("logger")}getChatMessages(){return n(this,st).sendMessagePromise(pe.getMessages)}getChatMessagesPaginated(t,e,r,i){return l(this,null,function*(){const a=b({timeStamp:t,size:e,from:0,reversed:r},i&&{filters:{filters:i}}),o=yield n(this,st).sendMessagePromise(pe.getPaginatedMessages,QC.toBinary(a));return o.payload?ZC.fromBinary(o.payload):{messages:[],next:!1}})}sendMessageToRoom(t,e){const r={payloadType:e,payload:t};n(this,st).sendMessage(pe.sendMessageToRoom,s_.toBinary(r))}sendMessageToPeers(t,e,r){const i={payloadType:e,peerIds:r,payload:t};n(this,st).sendMessage(pe.sendMessageToPeers,n_.toBinary(i))}sendMessage(t,e,r){if(r&&r.length>0){this.sendMessageToPeers(t,e,r);return}this.sendMessageToRoom(t,e)}editMessage(t,e,r,i){return l(this,null,function*(){const a={chatId:t,payloadType:r,payload:e};i!==void 0&&(a.pinned=i);const o=yield n(this,st).sendMessagePromise(pe.editMessage,l_.toBinary(a));return Ao.fromBinary(o.payload).message})}deleteMessage(t){return l(this,null,function*(){const e={chatId:t},r=yield n(this,st).sendMessagePromise(pe.deleteMessage,f_.toBinary(e));return{id:Io.fromBinary(r.payload).chatId}})}searchMessages(t,e){return l(this,null,function*(){var i,a,o,c;const r={searchTerm:t,timeStamp:(i=e.timestamp)!=null?i:Date.now(),size:(a=e.limit)!=null?a:75,from:(o=e.offset)!=null?o:0,reversed:(c=e.reversed)!=null?c:!0};try{const d=yield n(this,st).sendMessagePromise(pe.searchChannelMessages,v_.toBinary(r));return Up.fromBinary(d.payload).messages}catch(d){return[]}})}setPinState(t,e){return l(this,null,function*(){const r={chatId:t,pinned:e},i=yield n(this,st).sendMessagePromise(pe.pinMessage,h_.toBinary(r));return Mo.fromBinary(i.payload)})}on(t,e){let r,i;switch(t){case pe.sendMessageToRoom:{r=wd.fromBinary.bind(wd),i=wd.create();break}case pe.sendMessageToPeers:{r=Cd.fromBinary.bind(Cd),i=Cd.create();break}case pe.editMessage:{r=Ao.fromBinary.bind(Ao),i=Ao.create();break}case pe.pinMessage:{r=Mo.fromBinary.bind(Mo),i=Mo.create();break}case pe.deleteMessage:{r=Io.fromBinary.bind(Io),i=Io.create();break}}if(!r){this.logger.warn(`ChatSocketHandler::Event ${t} is not recognized`);return}n(this,st).on(t,({payload:a})=>{let o=i;try{o=r(a)}catch(c){this.logger.error("chatSocketHandler::on::binary_decode_error",{error:c})}return e(o)})}}st=new WeakMap,xi=new WeakMap;pr([S.trace("SocketService.getChatMessages")],xs.prototype,"getChatMessages",1);pr([S.trace("SocketService.getChatMessagesPaginated")],xs.prototype,"getChatMessagesPaginated",1);pr([S.trace("SocketService.sendMessageToRoom")],xs.prototype,"sendMessageToRoom",1);pr([S.trace("SocketService.sendMessageToPeers")],xs.prototype,"sendMessageToPeers",1);pr([S.trace("SocketService.sendMessage")],xs.prototype,"sendMessage",1);pr([S.trace("SocketService.editMessage")],xs.prototype,"editMessage",1);pr([S.trace("SocketService.deleteMessage")],xs.prototype,"deleteMessage",1);pr([S.trace("SocketService.searchMessages")],xs.prototype,"searchMessages",1);function QR(s){return s.replace(/([-_]\w)/g,t=>t[1].toUpperCase())}function jt(s){if(!s||typeof s!="object")return s;if(Array.isArray(s))return s.map(e=>jt(e));const t={};return Object.keys(s).forEach(e=>{const r=As.validate(e)?e:QR(e);t[r]=jt(s[e])}),t}function XR(s){return s.replace(/[A-Z]/g,t=>`_${t.toLowerCase()}`)}function Bp(s){if(!s||typeof s!="object")return s;if(Array.isArray(s))return s.map(e=>Bp(e));const t={};return Object.keys(s).forEach(e=>{const r=As.validate(e)?e:XR(e);t[r]=s[e]}),t}function Yo(s,t={}){return s==null?{}:(Object.getOwnPropertyNames(s).forEach(e=>{if(typeof s[e]!="function"){if(typeof s[e]=="object"){Yo(s[e],t[e]={});return}t[e]=s[e]}}),t)}class oh{constructor(t){g(this,"defaults");this.defaults={baseURL:t.baseURL,headers:{common:{}},timeout:t.timeout,retry:t.retry,retryDelay:t.retryDelay}}buildURL(t,e){const{baseURL:r}=this.defaults,i=t.startsWith("http")?t:`${r}${t.startsWith("/")?t:`/${t}`}`;if(e){const a=new URLSearchParams;return Object.entries(e).forEach(([o,c])=>{a.append(o,c)}),`${i}${i.includes("?")?"&":"?"}${a.toString()}`}return i}request(t){return l(this,null,function*(){var m;const e=((m=t.method)==null?void 0:m.toUpperCase())||"GET",r=this.buildURL(t.url||"",t.params),i=b(b({},this.defaults.headers.common),t.headers);e!=="GET"&&e!=="HEAD"&&t.data&&!i["Content-Type"]&&(i["Content-Type"]="application/json");const o=i["Content-Type"]==="application/json"?JSON.stringify(t.data):t.data,c={method:e,headers:i,body:e!=="GET"&&e!=="HEAD"&&t.data?o:void 0},d=t.timeout||this.defaults.timeout,u=t.retry!==void 0?t.retry:this.defaults.retry,p=t.retryDelay||this.defaults.retryDelay;try{const T=new AbortController,v=setTimeout(()=>T.abort(),d);c.signal=T.signal;const P=yield fetch(r,c);clearTimeout(v);let w=null;const C=P.headers.get("content-type");C&&C.includes("application/json")?w=yield P.json():w=yield P.text();const k={};P.headers.forEach((D,O)=>{k[O]=D});const R={data:w,status:P.status,statusText:P.statusText,headers:k,config:t};if(!P.ok)throw R;return R}catch(T){if(T instanceof Error&&u>0)return yield new Promise(v=>setTimeout(v,p)),this.defaults.baseURL===Pr.apiBase.prod?this.defaults.baseURL=Pr.apiBase.prodAlternate:this.defaults.baseURL===Pr.apiBase.prodAlternate&&(this.defaults.baseURL=Pr.apiBase.prod),this.request(U(b({},t),{retry:u-1}));throw T}})}get(r){return l(this,arguments,function*(t,e={}){return this.request(U(b({},e),{method:"GET",url:t}))})}post(i,a){return l(this,arguments,function*(t,e,r={}){return this.request(U(b({},r),{method:"POST",url:t,data:e}))})}put(i,a){return l(this,arguments,function*(t,e,r={}){return this.request(U(b({},r),{method:"PUT",url:t,data:e}))})}}const ZR=3,ek=30,tk=8e3;class sk{constructor(t,e){g(this,"ipInfo");g(this,"fetchClient");g(this,"requests");g(this,"roomName");g(this,"roomUUID");g(this,"authToken");g(this,"organizationId");g(this,"iceServers");g(this,"pluginInformation");g(this,"userDetails");g(this,"roomDetails");g(this,"context");this.context=t;const{timeout:r=tk,retry:i=ZR,retryDelay:a=ek,baseURL:o=Pr.apiBase.prod,authToken:c,cachedUserDetails:d}=e||{};this.iceServers=d==null?void 0:d.iceServers,this.pluginInformation=d==null?void 0:d.pluginInformation,this.userDetails=d==null?void 0:d.userDetails,this.roomDetails=d==null?void 0:d.roomDetails,this.requests=new oh({baseURL:o,timeout:r,retry:i,retryDelay:a,responseType:"json"}),this.fetchClient=new oh({baseURL:"",timeout:r,retry:i,retryDelay:a,responseType:"json"}),this.setAuthToken(c,{bearer:!0});const u=this.requests.request.bind(this.requests);this.requests.request=p=>l(this,null,function*(){var T,v,P,w,C;const m=t.getValue("telemetry");try{m.injectContext(this.requests.defaults.headers.common);const k=yield u(p);return p.url!==m.logsEndpoint&&this.logger.debug("xhr::fetch",{networkCall:{status:k.status,statusText:k.statusText,baseURL:p.baseURL||this.requests.defaults.baseURL,url:p.url,method:p.method}}),k}catch(k){throw k?(((T=k.config)==null?void 0:T.url)!==m.logsEndpoint&&this.logger.error("xhr::fetch",{error:k,networkCall:{status:k.status,statusText:k.statusText,baseURL:((v=k.config)==null?void 0:v.baseURL)||this.requests.defaults.baseURL,url:(P=k.config)==null?void 0:P.url,retries:(w=k.config)==null?void 0:w.retry,method:(C=k.config)==null?void 0:C.method,isOnline:navigator.onLine?"online":"offline"}}),new _(k.message||"Network request failed","0011")):new _("Unknown network error occurred","0011")}})}get peerId(){return this.context.getValue("peerId")}get logger(){return this.context.getValue("logger")}setAuthToken(t,e){const{bearer:r}=e||{};this.authToken=t,this.requests.defaults.headers.common.Authorization=r?`Bearer ${t}`:t}setHeader(t,e){this.requests.defaults.headers.common[t]=e}setRoomName(t){this.roomName=t}setRoomUUID(t){this.roomUUID=t}setOrganizationId(t){this.organizationId=t}}var rk=Object.defineProperty,ik=Object.getOwnPropertyDescriptor,Mt=(s,t,e,r)=>{for(var i=r>1?void 0:r?ik(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&rk(t,e,i),i};class ht extends sk{constructor(e,r){super(e,r);g(this,"telemetry");this.telemetry=e.getValue("telemetry"),this.setHeader("x-realtimekit-version",e.getValue("sdkVersion"))}getIPDetails(){return l(this,null,function*(){var r;const{peerId:e}=this;try{const i=yield Uh.ipDetails.getIPDetails({peerId:e,apiHostnames:_p(this.context),logger:Kh});if(this.logger.log("ipInfo",{ipInfo:i}),((r=i==null?void 0:i.loc)==null?void 0:r.length)>5)return i;throw Error("Insufficient data")}catch(i){this.logger.warn("APIClient.getIPDetails Failed to get ip details",{error:{name:i.name,message:i.message}});return}})}getICEServers(){return l(this,null,function*(){if(this.iceServers)return this.iceServers;const{success:e,iceServers:r}=(yield this.requests.get("/iceservers")).data;if(e)return(r==null?void 0:r.length)>0&&(this.iceServers=r),r})}getPlugins(){return l(this,null,function*(){var a,o,c,d,u,p,m;if(this.pluginInformation)return this.pluginInformation;const{plugins:e}=(yield this.requests.get("/v2/plugins/user")).data.data,r=((o=(a=this.context.getValue("flagsmith").getValue(q.V1_PLUGINS))==null?void 0:a.toString())==null?void 0:o.split(","))||[],i=e.reduce((T,v)=>(T[r.includes(v.id)?"v1":"v2"].push(U(b({},v),{name:v.name.replace("v2","")})),T),{v1:[],v2:[]});return(u=(d=(c=this.context.getValue("modules"))==null?void 0:c.devTools)==null?void 0:d.plugins)!=null&&u.length&&((m=(p=this.context.getValue("modules"))==null?void 0:p.devTools)==null||m.plugins.forEach(T=>{var P,w,C;const v=U(b({},Fn),{tags:[...Fn.tags],baseUrl:`http://localhost:${T.port}`,name:T.name,picture:(P=T.picture)!=null?P:Fn.picture,createdAt:new Date().toISOString(),updatedAt:new Date().toISOString(),id:T.id,organizationId:this.organizationId,description:(w=T.description)!=null?w:Fn.description,staggered:(C=T.staggered)!=null?C:Fn.staggered});i.v2.push(v)})),i.v2})}getPluginDetails(e){return l(this,null,function*(){const{plugin:r}=(yield this.requests.get(`/v2/plugins/view/${e}`)).data.data;return r})}getPluginConfig(e){return l(this,null,function*(){return(yield this.fetchClient.get(`${e}/dyte-config.json`)).data})}authorizePlugin(e){return l(this,null,function*(){const r={peerId:this.peerId},{token:i}=(yield this.requests.post(`/v2/plugins/authorize/${e}`,r)).data.data;return i})}getPresignedUrls(e){return l(this,null,function*(){const r=Dn(this.context,"chat_upload_expiry"),i={roomUUID:this.roomUUID,filename:e,expiry:typeof r=="number"?r:void 0},{get_location:a,put_location:o}=(yield this.requests.post("/v2/meetings/chat-upload",i)).data.data;return{getLocation:a,putLocation:o}})}uploadFile(e,r){return l(this,null,function*(){if(navigator.isReactNative&&"uri"in e)try{yield fetch(r,{method:"PUT",headers:{"Content-Type":"application/octet-stream"},body:{uri:e.uri,name:e.name}})}catch(i){this.logger.error(`sendFileMessage::${i}`)}else yield this.fetchClient.put(r,e,{headers:{"Content-Type":e.type}})})}startLivestreaming(r){return l(this,arguments,function*({manualIngestion:e}){const i=jt(yield this.requests.post(`/v2/meetings/${this.context.getValue("meetingId")}/livestreams`,{manual_ingest:!!e})).data.data;return{playbackUrl:i.playbackUrl,status:i.status,manualIngest:i.manualIngest,ingestionCredentials:i.streamKey?{ingestionServer:i.ingestServer,streamKey:i.streamKey}:null}})}stopLivestreaming(){return l(this,null,function*(){return this.requests.post(`/v2/meetings/${this.context.getValue("meetingId")}/active-livestream/stop`)})}getActiveLivestream(){return l(this,null,function*(){const e=jt((yield this.requests.get(`/v2/meetings/${this.context.getValue("meetingId")}/active-livestream`)).data.data);return{playbackUrl:e.playbackUrl,status:e.status,manualIngest:e.manualIngest,ingestionCredentials:e.streamKey?{ingestionServer:e.ingestServer,streamKey:e.streamKey}:null}})}getUserDetails(){return l(this,null,function*(){if(this.userDetails)return this.userDetails;const e=(yield this.requests.get("v2/internals/participant-details")).data.data;return jt(e)})}startRecording(e,r){return l(this,null,function*(){return(yield this.requests.post("/v2/recordings",U(b({},Bp(e)),{meeting_id:this.context.getValue("meetingId"),allow_multiple_recordings:!!r}))).data.data.id})}updateRecording(e,r){return l(this,null,function*(){return this.requests.put(`v2/recordings/${e}`,{action:r})})}getActiveRecording(){return l(this,null,function*(){const{status:e,id:r}=(yield this.requests.get(`v2/recordings/active-recording/${this.context.getValue("meetingId")}`)).data.data;return{status:e,id:r}})}getActiveTranscript(){return l(this,null,function*(){const{transcript_download_url:e}=(yield this.requests.get(`v2/meetings/${this.context.getValue("meetingId")}/active-transcript`)).data.data;try{return{transcript:(yield this.fetchClient.get(e)).data}}catch(r){throw new _("Cant fetch transcript s3 url","1801")}})}getRoomNodeData(){return l(this,null,function*(){const e=yield this.getIPDetails();if(this.ipInfo=e,this.roomDetails)return this.roomDetails;const{title:r}=jt((yield this.requests.post("v2/internals/rooms",{ip_information:e})).data.data);return{meetingTitle:r}})}}Mt([S.trace("APIClient.getIPDetails")],ht.prototype,"getIPDetails",1);Mt([S.trace("APIClient.getICEServers")],ht.prototype,"getICEServers",1);Mt([S.trace("APIClient.getPlugins")],ht.prototype,"getPlugins",1);Mt([S.trace("APIClient.startLivestreaming")],ht.prototype,"startLivestreaming",1);Mt([S.trace("APIClient.stopLivestreaming")],ht.prototype,"stopLivestreaming",1);Mt([S.trace("APIClient.getActiveLivestream")],ht.prototype,"getActiveLivestream",1);Mt([S.trace("APIClient.getUserDetails")],ht.prototype,"getUserDetails",1);Mt([S.trace("APIClient.startRecording")],ht.prototype,"startRecording",1);Mt([S.trace("APIClient.stopRecording")],ht.prototype,"updateRecording",1);Mt([S.trace("APIClient.getActiveRecording")],ht.prototype,"getActiveRecording",1);Mt([S.trace("APIClient.getActiveTranscript")],ht.prototype,"getActiveTranscript",1);Mt([S.trace("APIClient.getRoomNodeData")],ht.prototype,"getRoomNodeData",1);let Kd;function nk(s,t){return Kd=new ht(s,t),Kd}function De(){return Kd}const xn={maxInvocations:5,period:1};function Qe(s,t){return function(e,r,i){const a=i.value;let o=0,c=Date.now();return i.value=function(...d){const u=Date.now(),p=t?this[t]:s;if(u-c>p.period*1e3&&(c=u,o=0),o>=p.maxInvocations)throw new _(`Method rate limit ${p.maxInvocations} invocations/${p.period}sec exceeded`,"0013");return o+=1,a.apply(this,d)},i}}var ak=Object.defineProperty,ok=Object.getOwnPropertyDescriptor,Kt=(s,t,e,r)=>{for(var i=r>1?void 0:r?ok(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&ak(t,e,i),i};const ck=["text","image","file","custom","poll"],qo={maxInvocations:180,period:60};var F,wr,ve,Li,tc,jp,da,zd,vh;let dt=(vh=class extends ut{constructor(t,e,r,i){const a=t.getValue("logger");super(a);h(this,tc);h(this,da);g(this,"messages");h(this,F,void 0);h(this,wr,void 0);h(this,ve,void 0);h(this,Li,void 0);g(this,"maxTextLimit",2e3);f(this,Li,t),f(this,ve,e),f(this,F,r),f(this,wr,i),this.messages=[]}get telemetry(){return n(this,Li).getValue("telemetry")}setMaxTextLimit(t){this.maxTextLimit=t}sendMessageInternal(t,e){return l(this,null,function*(){switch(t.type){case"text":{yield this.sendTextMessageInternal(t.message,e);break}case"image":yield this.sendImageMessageInternal(t.image,e);break;case"file":yield this.sendFileMessageInternal(t.file,e);break;default:this.logger.error("sendMessage::message_type_not_supported",{chat:{messageType:t.type}});break}})}sendTextMessageInternal(t,e){return l(this,null,function*(){var i,a,o,c,d,u;if(t.length>this.maxTextLimit)throw new _("Max character limit breached","0503");if(e&&e.length>0){if(!((i=n(this,F).permissions)!=null&&i.chatPrivate.canSend)||!((a=n(this,F).permissions)!=null&&a.chatPrivate.text))throw this.logger.error("sendTextMessage::private_chat_permission_denied"),new _("Could not send message to private chat.","0501")}else if(!((c=(o=n(this,F).permissions)==null?void 0:o.chatPublic)!=null&&c.canSend)||!((u=(d=n(this,F).permissions)==null?void 0:d.chatPublic)!=null&&u.text))throw this.logger.error("sendTextMessage::public_chat_permission_denied"),new _("Could not send message to public chat.","0501");if(!t)throw this.logger.error("sendTextMessage::message_can_not_be_empty"),new _("Message can not be empty.","0502");let r=[];e&&e.length>0&&(e.push(n(this,F).id),r=n(this,wr).joined.toArray().filter(p=>e.includes(p.id)).map(p=>p.userId),r.push(n(this,F).userId)),n(this,ve).sendMessage(t,Rt.TEXT,e)})}sendImageMessageInternal(t,e){return l(this,null,function*(){var i,a,o,c,d,u;if(e&&e.length>0){if(!((i=n(this,F).permissions)!=null&&i.chatPrivate.canSend)||!((a=n(this,F).permissions)!=null&&a.chatPrivate.files)){this.logger.error("sendImageMessage::private_chat_permission_denied");return}}else if(!((c=(o=n(this,F).permissions)==null?void 0:o.chatPublic)!=null&&c.canSend)||!((u=(d=n(this,F).permissions)==null?void 0:d.chatPublic)!=null&&u.files)){this.logger.error("sendImageMessage::permission_denied");return}if(!t){this.logger.error("sendImageMessage::required_argument_image_can_not_be_empty");return}if(!["image/gif","image/jpeg","image/png"].includes(t.type)){this.logger.error("sendImageMessage::image_type_not_supported",{chat:{imageType:t.type}});return}try{const p=De(),{getLocation:m,putLocation:T}=yield p.getPresignedUrls(t.name);yield p.uploadFile(t,T);let v=[];e&&e.length>0&&(e.push(n(this,F).id),v=n(this,wr).joined.toArray().filter(P=>e.includes(P.id)).map(P=>P.userId),v.push(n(this,F).userId)),n(this,ve).sendMessage(m,Rt.IMAGE,e)}catch(p){throw new _("Error sending image message.","0500",this.logger)}})}sendFileMessageInternal(t,e){return l(this,null,function*(){var r,i,a,o,c,d;if(e&&e.length>0){if(!((r=n(this,F).permissions)!=null&&r.chatPrivate.canSend)||!((i=n(this,F).permissions)!=null&&i.chatPrivate.files)){this.logger.error("sendFileMessage::private_chat_permission_denied");return}}else if(!((o=(a=n(this,F).permissions)==null?void 0:a.chatPublic)!=null&&o.canSend)||!((d=(c=n(this,F).permissions)==null?void 0:c.chatPublic)!=null&&d.files)){this.logger.error("sendFileMessage::permission_denied");return}if(!t){this.logger.error("sendFileMessage::required_argument_file_can_not_be_empty");return}try{const u=De(),{getLocation:p,putLocation:m}=yield u.getPresignedUrls(t.name);yield u.uploadFile(t,m);let T=[];e&&e.length>0&&(e.push(n(this,F).id),T=n(this,wr).joined.toArray().filter(P=>e.includes(P.id)).map(P=>P.userId),T.push(n(this,F).userId));const v=JSON.stringify({link:p,name:t.name,size:"size"in t?t.size:0});n(this,ve).sendMessage(v,Rt.FILE,e)}catch(u){throw new _("Error sending file message.","0500",this.logger)}})}get rateLimits(){return qo}updateRateLimits(t,e){qo.maxInvocations=t,qo.period=e}sendTextMessage(t,e){return l(this,null,function*(){return this.sendTextMessageInternal(t,e)})}sendCustomMessage(t,e){return l(this,null,function*(){var a,o,c,d,u,p,m,T,v,P,w,C,k,R,D;if(e&&e.length>0){if(!((a=n(this,F).permissions)!=null&&a.chatPrivate.canSend)||!((o=n(this,F).permissions)!=null&&o.chatPrivate.files)||!((c=n(this,F).permissions)!=null&&c.chatPrivate.text)){this.logger.error("sendCustomMessage::private_chat_permission_denied");return}}else if(!((u=(d=n(this,F).permissions)==null?void 0:d.chatPublic)!=null&&u.canSend)||!((m=(p=n(this,F).permissions)==null?void 0:p.chatPublic)!=null&&m.files)||!((v=(T=n(this,F).permissions)==null?void 0:T.chatPublic)!=null&&v.text)){this.logger.error("sendCustomMessage::permission_denied");return}const r=O=>l(this,null,function*(){try{if(typeof O=="string")return{link:O};const N=De(),{getLocation:L,putLocation:te}=yield N.getPresignedUrls(O.name);return yield N.uploadFile(O,te),{link:L,type:O.type,name:O.name,size:O.size}}catch(N){throw new _("Error sending image message.","0500",this.logger)}}),i=U(b({},t),{files:yield Promise.all((w=(P=t.files)!=null?P:[])==null?void 0:w.map(O=>l(this,null,function*(){return r(O)}))),images:yield Promise.all((k=(C=t.images)!=null?C:[])==null?void 0:k.map(O=>l(this,null,function*(){return r(O)}))),videos:yield Promise.all((D=(R=t.videos)!=null?R:[])==null?void 0:D.map(O=>l(this,null,function*(){return r(O)})))});n(this,ve).sendMessage(JSON.stringify(i),Rt.CUSTOM,e)})}sendImageMessage(t,e){return l(this,null,function*(){return this.sendImageMessageInternal(t,e)})}sendFileMessage(t,e){return l(this,null,function*(){return this.sendFileMessageInternal(t,e)})}sendMessage(t,e){return l(this,null,function*(){return this.sendMessageInternal(t,e)})}editTextMessage(t,e){return l(this,null,function*(){var r,i,a,o;if(!((i=(r=n(this,F).permissions)==null?void 0:r.chatPublic)!=null&&i.canSend)||!((o=(a=n(this,F).permissions)==null?void 0:a.chatPublic)!=null&&o.text)){this.logger.error("editTextMessage::permission_denied");return}if(!e){this.logger.error("editTextMessage::message_can_not_be_empty");return}n(this,ve).editMessage(t,e,Rt.TEXT)})}editImageMessage(t,e){return l(this,null,function*(){var i,a,o,c;if(!((a=(i=n(this,F).permissions)==null?void 0:i.chatPublic)!=null&&a.canSend)||!((c=(o=n(this,F).permissions)==null?void 0:o.chatPublic)!=null&&c.files)){this.logger.error("editImageMessage::permission_denied");return}if(!e){this.logger.error("editImageMessage::required_argument_image_can_not_be_empty");return}if(!["image/gif","image/jpeg","image/png"].includes(e.type)){this.logger.error("sendImageMessage::image_type_not_supported",{chat:{imageType:e.type}});return}try{const d=De(),{getLocation:u,putLocation:p}=yield d.getPresignedUrls(e.name);yield d.uploadFile(e,p),n(this,ve).editMessage(t,u,Rt.IMAGE)}catch(d){throw new _("Error editing image message.","0500",this.logger)}})}editFileMessage(t,e){return l(this,null,function*(){var r,i,a,o;if(!((i=(r=n(this,F).permissions)==null?void 0:r.chatPublic)!=null&&i.canSend)||!((o=(a=n(this,F).permissions)==null?void 0:a.chatPublic)!=null&&o.files)){this.logger.error("sendFileMessage::permission_denied");return}if(!e){this.logger.error("sendFileMessage::required_argument_file_can_not_be_empty");return}try{const c=De(),{getLocation:d,putLocation:u}=yield c.getPresignedUrls(e.name);yield c.uploadFile(e,u),n(this,ve).editMessage(t,JSON.stringify({link:d,name:e.name,size:"size"in e?e.size:0}),Rt.FILE)}catch(c){throw new _("Error editing file message.","0500",this.logger)}})}editMessage(t,e){return l(this,null,function*(){switch(e.type){case"text":{this.editTextMessage(t,e.message);break}case"image":{this.editImageMessage(t,e.image);break}case"file":{this.editFileMessage(t,e.file);break}default:{this.logger.error("editMessage::message_type_not_supported",{chat:{messageType:e.type}});break}}})}deleteMessage(t){return l(this,null,function*(){n(this,ve).deleteMessage(t)})}getMessagesByUser(t){return this.messages.filter(e=>e.userId===t)}getMessagesByType(t){return this.messages.filter(e=>e.type===t)}pin(t){return l(this,null,function*(){if(!n(this,da,zd))throw new _("Can`t pin message without joining room","0505");try{yield n(this,ve).setPinState(t,!0)}catch(e){throw new _(`No message found with id: ${t}`,"0504")}})}unpin(t){return l(this,null,function*(){if(!n(this,da,zd))throw new _("Can`t unpin message without joining room","0505");try{yield n(this,ve).setPinState(t,!1)}catch(e){throw new _(`No message found with id: ${t}`,"0504")}})}fetchPublicMessages(i){return l(this,arguments,function*({timestamp:t=new Date().getTime(),limit:e,direction:r="after"}){return(yield n(this,ve).getChatMessagesPaginated(t,e,r==="before")).messages.map(c=>kt.formatSocketPeerMessage(c))})}fetchPrivateMessages(a){return l(this,arguments,function*({timestamp:t=new Date().getTime(),limit:e,direction:r="after",userId:i}){return(yield n(this,ve).getChatMessagesPaginated(t,e,r==="before",{oneofKind:"userId",userId:i})).messages.map(d=>kt.formatSocketPeerMessage(d))})}fetchPinnedMessages(i){return l(this,arguments,function*({timestamp:t=new Date().getTime(),limit:e,direction:r="after"}){return(yield n(this,ve).getChatMessagesPaginated(t,e,r==="before",{oneofKind:"pinned",pinned:!0})).messages.map(c=>kt.formatSocketPeerMessage(c))})}getMessages(t,e,r,i=0){return l(this,null,function*(){const a=yield n(this,ve).getChatMessagesPaginated(t,e,r);return{messages:a.messages.map(o=>kt.formatSocketPeerMessage(o)),next:a.next}})}searchMessages(t,e){return l(this,null,function*(){throw new _("searchMessages is disabled! Please use `fetchPublicMessages` method instead.","0506")})}get pinned(){return this.messages.filter(t=>t.pinned)}},F=new WeakMap,wr=new WeakMap,ve=new WeakMap,Li=new WeakMap,tc=new WeakSet,jp=function(){return n(this,Li).getValue("connectionHandler")},da=new WeakSet,zd=function(){return n(this,tc,jp).socketJoined===!0},vh);Kt([S.trace("Chat.sendTextMessage"),Qe(qo)],dt.prototype,"sendTextMessage",1);Kt([S.trace("Chat.sendImageMessage"),Qe({maxInvocations:20,period:60})],dt.prototype,"sendImageMessage",1);Kt([S.trace("Chat.sendFileMessage"),Qe({maxInvocations:20,period:60})],dt.prototype,"sendFileMessage",1);Kt([S.trace("Chat.sendMessage"),Qe({maxInvocations:180,period:60})],dt.prototype,"sendMessage",1);Kt([S.trace("Chat.editTextMessage")],dt.prototype,"editTextMessage",1);Kt([S.trace("Chat.editImageMessage")],dt.prototype,"editImageMessage",1);Kt([S.trace("Chat.editFileMessage")],dt.prototype,"editFileMessage",1);Kt([S.trace("Chat.editMessage")],dt.prototype,"editMessage",1);Kt([S.trace("Chat.deleteMessage")],dt.prototype,"deleteMessage",1);Kt([S.trace("Chat.searchMessages")],dt.prototype,"searchMessages",1);dt=Kt([Ne("0500")],dt);var dk=Object.defineProperty,lk=Object.getOwnPropertyDescriptor,uk=(s,t,e,r)=>{for(var i=r>1?void 0:r?lk(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&dk(t,e,i),i},Cr,Sh;const qs=(Sh=class{constructor(s,t,e,r){g(this,"chat");g(this,"chatSocketHandler");g(this,"self");h(this,Cr,void 0);f(this,Cr,s),this.chatSocketHandler=t,this.chat=new dt(s,t,e,r),this.self=e,this.setupEvents()}get telemetry(){return n(this,Cr).getValue("telemetry")}get logger(){return n(this,Cr).getValue("logger")}static init(s,t,e,r){return l(this,null,function*(){return new qs(s,t,e,r)})}static formatMessage(s){return U(b({},s),{time:new Date(s.time),type:ck[s.type]})}static formatSocketPeerMessage(s){const t=s.createdAt*1e3,e={displayName:s.displayName,id:s.chatId,time:t,timeMs:s.createdAtMs,type:s.payloadType,isEdited:s.isEdited,userId:s.userId,targetUserIds:s.targetUserIds,message:"",link:"",name:"",html:"",images:[],videos:[],files:[],size:0,pinned:s.pinned};switch(e.type){case Rt.TEXT:{e.message=s.payload;break}case Rt.IMAGE:{e.link=s.payload;break}case Rt.FILE:{const{link:r,name:i,size:a}=JSON.parse(s.payload);e.link=r,e.name=i,e.size=a;break}case Rt.CUSTOM:{const{html:r,images:i,message:a,videos:o,files:c}=JSON.parse(s.payload);e.message=a,e.html=r,e.images=i,e.videos=o,e.files=c;break}}return qs.formatMessage(e)}getChatMessages(){return l(this,null,function*(){if(this.self.config.viewType==="LIVESTREAM")return;const s=yield this.chatSocketHandler.getChatMessages();if(!(s!=null&&s.payload))return;const t=Up.fromBinary(s.payload).messages;this.chat.messages=t.map(e=>qs.formatSocketPeerMessage(e))})}setupEvents(){n(this,Cr).getValue("peerSessionStore").on(E.SOCKET_SERVICE_ROOM_JOINED,()=>l(this,null,function*(){this.getChatMessages()})),this.chatSocketHandler.on(pe.sendMessageToRoom,s=>{if(!s.message)return;const t=qs.formatSocketPeerMessage(s.message);this.chat.messages=[...this.chat.messages,t],this.chat.emit("chatUpdate",{action:"add",message:t,messages:this.chat.messages})}),this.chatSocketHandler.on(pe.sendMessageToPeers,s=>{const t=qs.formatSocketPeerMessage(s.message);this.chat.messages=[...this.chat.messages,t],this.chat.emit("chatUpdate",{action:"add",message:t,messages:this.chat.messages})}),this.chatSocketHandler.on(pe.editMessage,s=>{if(!s.message)return;const t=qs.formatSocketPeerMessage(s.message),e=this.chat.messages.findIndex(r=>r.id===t.id);e!==-1&&(this.chat.messages[e]=t),this.chat.emit("chatUpdate",{action:"edit",message:t,messages:this.chat.messages})}),this.chatSocketHandler.on(pe.deleteMessage,s=>{const t=this.chat.messages.findIndex(r=>r.id===s.chatId);let e={id:s.chatId};t!==-1&&([e]=this.chat.messages.splice(t,1)),this.chat.emit("chatUpdate",{action:"delete",message:e,messages:this.chat.messages})}),this.chatSocketHandler.on(pe.pinMessage,s=>{const t=this.chat.messages.findIndex(r=>r.id===s.chatId),e=qs.formatSocketPeerMessage(s.message);t!==-1&&(this.chat.messages[t]=e),this.chat.emit("chatUpdate",{action:"edit",message:e,messages:this.chat.messages}),s.pinned?this.chat.emit("pinMessage",{message:e,messages:this.chat.messages}):this.chat.emit("unpinMessage",{message:e,messages:this.chat.messages})})}},Cr=new WeakMap,Sh);let kt=qs;uk([S.trace("ChatController.setupEvents")],kt.prototype,"setupEvents",1);var hk=Object.defineProperty,pk=Object.getOwnPropertyDescriptor,gk=(s,t,e,r)=>{for(var i=r>1?void 0:r?pk(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&hk(t,e,i),i},sc,Gp,rc,Jp,$i,Ui,la,Ph;let Yd=(Ph=class extends ut{constructor(t,e,r){const i=t.getValue("logger");super(i);h(this,sc);h(this,rc);g(this,"items");h(this,$i,void 0);h(this,Ui,void 0);h(this,la,void 0);f(this,la,t),f(this,$i,e),f(this,Ui,r),this.items=[]}create(t,e,r=!1,i=!1){return l(this,null,function*(){if(!n(this,rc,Jp))throw new _("Can't create polls without joining room","0705");if(!n(this,$i).permissions.polls.canCreate){this.logger.error("Polls::create::permission_denied");return}if(!t||!e){this.logger.error("Polls::question_and_options_can_not_be_empty",{polls:{hasQuestion:!!t,optionsLength:e==null?void 0:e.length}});return}if(e.length<2){this.logger.error("Polls::there_must_be_at_least_two_options",{polls:{hasQuestion:!!t,optionsLength:e.length}});return}yield n(this,Ui).createPoll(t,e,r,i)})}vote(t,e){return l(this,null,function*(){if(!n(this,$i).permissions.polls.canVote){this.logger.error("Polls::vote::permission_denied");return}yield n(this,Ui).votePoll(t,e)})}},sc=new WeakSet,Gp=function(){return n(this,la).getValue("connectionHandler")},rc=new WeakSet,Jp=function(){var t;return((t=n(this,sc,Gp))==null?void 0:t.socketJoined)===!0},$i=new WeakMap,Ui=new WeakMap,la=new WeakMap,Ph);Yd=gk([Ne("0700")],Yd);var mk=Object.defineProperty,fk=Object.getOwnPropertyDescriptor,Tk=(s,t,e,r)=>{for(var i=r>1?void 0:r?fk(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&mk(t,e,i),i},Bs,qi,_r,Eh;const Ei=(Eh=class{constructor(s,t,e){g(this,"polls");h(this,Bs,void 0);h(this,qi,void 0);h(this,_r,void 0);this.polls=new Yd(s,t,e),f(this,qi,t),f(this,Bs,s),f(this,_r,e),this.setupEvents()}get telemetry(){return n(this,Bs).getValue("telemetry")}get logger(){return n(this,Bs).getValue("logger")}static init(s,t,e){return l(this,null,function*(){return new Ei(s,t,e)})}canViewPolls(){return n(this,qi).permissions.polls.canView}setupEvents(){const s={[os.createPoll]:r=>{r.poll&&this.updatePoll(Ei.formatSocketServicePoll(r.poll))},[os.updatePoll]:r=>{r.poll&&this.updatePoll(Ei.formatSocketServicePoll(r.poll))},[os.votePoll]:r=>{r.poll&&this.updatePoll(Ei.formatSocketServicePoll(r.poll))}},t=()=>{n(this,Bs).getValue("peerSessionStore").on(E.SOCKET_SERVICE_ROOM_JOINED,()=>{this.getPolls()}),Object.keys(s).map(Number).forEach(r=>{n(this,_r).on(r,s[r])})},e=()=>{n(this,Bs).getValue("peerSessionStore").on(E.SOCKET_SERVICE_ROOM_JOINED,()=>{this.getPolls()}),Object.keys(s).map(Number).forEach(r=>{n(this,_r).removeListeners(r)})};n(this,qi).permissions.on("permissionsUpdate",r=>l(this,null,function*(){var i;r!=null&&r.polls&&((i=r==null?void 0:r.polls)!=null&&i.canView?(yield this.getPolls(),t()):(this.polls.items=[],e()))})),this.canViewPolls()&&t()}updatePoll(s){if(!this.canViewPolls())return;const t=this.polls.items.findIndex(e=>e.id===s.id);if(t>-1){const e=JSON.stringify(this.polls.items[t]);this.polls.items[t]=s,e!==JSON.stringify(s)&&this.polls.emit("pollsUpdate",{polls:this.polls.items,newPoll:!1});return}this.polls.items=[...this.polls.items,s],this.polls.emit("pollsUpdate",{polls:this.polls.items,newPoll:!0})}getPolls(){return l(this,null,function*(){const s=yield n(this,_r).getPolls();if(!(s!=null&&s.payload))return;const{polls:t}=DR.fromBinary(s.payload);this.polls.items=t.map(e=>Ei.formatSocketServicePoll(e))})}static formatSocketServicePoll(s){const t=s.options.map(e=>({count:e.count,text:e.text,votes:e.votes.map(r=>({id:r.userId,name:r.name}))}));return{anonymous:s.anonymous,createdBy:s.createdBy,createdByUserId:s.createdByUserId,hideVotes:s.hideVotes,id:s.pollId,options:t,question:s.question,voted:s.votes}}},Bs=new WeakMap,qi=new WeakMap,_r=new WeakMap,Eh);let Wp=Ei;Tk([S.trace("PollController.setupEvents")],Wp.prototype,"setupEvents",1);var yk=Object.defineProperty,vk=Object.getOwnPropertyDescriptor,Sk=(s,t,e,r)=>{for(var i=r>1?void 0:r?vk(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&yk(t,e,i),i},Kp=(s=>(s[s.User=0]="User",s[s.Meeting=1]="Meeting",s))(Kp||{}),Hi,ua,Xd,Rr,ha,wh;let Qd=(wh=class extends ut{constructor(t,e,r,i,a){const o=t.getValue("logger");super(o);h(this,ua);g(this,"selfActiveTab");g(this,"broadcastTabChanges");h(this,Hi,void 0);h(this,Rr,void 0);h(this,ha,void 0);g(this,"viewType");g(this,"meetingStartedTimestamp");g(this,"meetingTitle");g(this,"sessionId");f(this,Hi,t),f(this,Rr,e),this.viewType=r,f(this,ha,i),this.meetingTitle=a,this.broadcastTabChanges=e.permissions.canSpotlight}get socketState(){return n(this,ua,Xd).socketState}get mediaState(){return n(this,ua,Xd).mediaState}get meetingId(){return n(this,Hi).getValue("meetingId")}setBroadcastTabChanges(t){if(!n(this,Rr).permissions.canSpotlight)throw this.logger.error("Spotlight::setSpotlighted::permission_denied"),new _("User does not have permission to toggle spotlight","0801");this.broadcastTabChanges=t,this.emit("broadcastTabChangesUpdate",this.broadcastTabChanges),this.broadcastTabChanges&&this.assertActiveTabToRoom()}setSelfActiveTab(t,e){var r;this.logger.info("Spotlight::setActiveTab",{spotlight:{currentTab:{id:t.id,type:t.type}}}),this.selfActiveTab=t,e===0&&this.emit("selfTabUpdate",t),(r=n(this,Rr).permissions)!=null&&r.canSpotlight&&this.broadcastTabChanges&&e===0&&this.assertActiveTabToRoom()}assertActiveTabToRoom(){n(this,ha).broadcastMessage("spotlight",{userId:n(this,Rr).userId,currentTab:this.selfActiveTab})}},Hi=new WeakMap,ua=new WeakSet,Xd=function(){return n(this,Hi).getValue("connectionHandler")},Rr=new WeakMap,ha=new WeakMap,wh);Qd=Sk([Ne("0800")],Qd);function Pk(s){let t="",e=[""];const r=[e];let i=0,a=0,o=!0,c;for(c of s)c==='"'?(o&&c===t&&(e[i]+=c),o=!o):c===","&&o?c=e[++i]="":c===`
|
|
3
|
+
`&&o?(t==="\r"&&(e[i]=e[i].slice(0,-1)),e=r[++a]=[c=""],i=0):e[i]+=c,t=c;return r}var Ek=Object.defineProperty,wk=Object.getOwnPropertyDescriptor,zp=(s,t,e,r)=>{for(var i=r>1?void 0:r?wk(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Ek(t,e,i),i},pa,Ch;let cr=(Ch=class extends ut{constructor(t){const e=t.getValue("logger");super(e);g(this,"transcripts");h(this,pa,void 0);f(this,pa,t),this.transcripts=[]}get telemetry(){return n(this,pa).getValue("telemetry")}static init(t,e){return l(this,null,function*(){const r=new cr(t),i=t.getValue("logger");try{e&&r.getActiveTranscript()}catch(a){i.error("Error fetching active transcriptions ",a)}return r})}static parseTranscript(t,e=!1){if(!t)return;const[[r,i,a,o,c,d]]=Pk(t);return{id:As.v4(),name:c,peerId:i,userId:a,customParticipantId:o,transcript:d,isPartialTranscript:e,date:new Date(parseInt(r,10)*1e3)}}static parseTranscripts(t){return t?t.split(`
|
|
4
|
+
`).map(e=>cr.parseTranscript(e,!1)).filter(Boolean):[]}getActiveTranscript(){return l(this,null,function*(){try{const t=De(),{transcript:e}=yield t.getActiveTranscript();this.transcripts=cr.parseTranscripts(e)}catch(t){}})}onTranscript(t){return l(this,null,function*(){var r;const e=this.transcripts.filter(({peerId:i})=>i===t.peerId);if((r=e==null?void 0:e.at(-1))!=null&&r.isPartialTranscript){const i=e.at(-1);i.transcript=t.transcript,i.isPartialTranscript=t.isPartialTranscript,this.emit("transcript",i);return}this.transcripts=[...this.transcripts,t],this.emit("transcript",t)})}},pa=new WeakMap,Ch);zp([S.trace("Ai.getActiveTranscript")],cr.prototype,"getActiveTranscript",1);cr=zp([Ne("0000")],cr);var Ck=Object.defineProperty,_k=Object.getOwnPropertyDescriptor,Rk=(s,t,e,r)=>{for(var i=r>1?void 0:r?_k(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Ck(t,e,i),i},js,Fi,rt,_h;const Yp=(_h=class{constructor(s,t,e,r,i,a){g(this,"meta");g(this,"ai");h(this,js,void 0);h(this,Fi,void 0);g(this,"aiSocketHandler");h(this,rt,void 0);f(this,rt,s),this.meta=new Qd(s,t,t.config.viewType,e,a),this.ai=r,f(this,js,t),f(this,Fi,e),this.aiSocketHandler=i,this.setupEvents()}get telemetry(){return n(this,rt).getValue("telemetry")}get logger(){return n(this,rt).getValue("logger")}static init(s,t,e,r,i){return l(this,null,function*(){const a=yield cr.init(s,t.permissions.transcriptionEnabled);return new Yp(s,t,e,a,r,i)})}conditionallySetActiveTab(s){var t;s!=null&&s.currentTab&&((t=this.meta.selfActiveTab)==null?void 0:t.id)!==s.currentTab.id&&(this.meta.setSelfActiveTab(s.currentTab,Kp.Meeting),this.meta.emit("activeTabUpdate",s.currentTab))}setupEvents(){n(this,rt).getValue("peerSessionStore").on(E.TRANSPORT_STATE_UPDATE,s=>{this.meta.emit("mediaConnectionUpdate",s)}),n(this,rt).getValue("peerSessionStore").on(E.SOCKET_STATE_UPDATE,s=>{this.meta.emit("socketConnectionUpdate",s)}),n(this,rt).getValue("peerSessionStore").on(E.ROOM_STATE,({createdAt:s,roomUuid:t})=>{const e=this.meta.meetingStartedTimestamp;if(t&&(this.meta.sessionId=t),s&&!e){const r=new Date(s*1e3);this.meta.meetingStartedTimestamp=r,this.meta.emit("meetingStartTimeUpdate",{meetingStartedTimestamp:this.meta.meetingStartedTimestamp})}}),n(this,rt).getValue("peerSessionStore").on(E.PRODUCER_SCORE_UPDATE,({score:s})=>{s<5&&this.meta.emit("poorConnection",{score:s})}),n(this,js).permissions.canSpotlight&&(this.logger.info("MetaController::Asserting Spotlight"),this.meta.selfActiveTab&&n(this,Fi).broadcastMessage("spotlight",{userId:n(this,js).userId,currentTab:this.meta.selfActiveTab})),n(this,rt).getValue("peerSessionStore").on(E.PEER_JOINED_INTERNAL,s=>l(this,null,function*(){n(this,js).permissions.canSpotlight&&this.meta.selfActiveTab&&n(this,Fi).broadcastToPeers("spotlight",[s.id],{userId:n(this,js).userId,currentTab:this.meta.selfActiveTab})})),n(this,rt).getValue("peerSessionStore").on(E.ROOM_MESSAGE,s=>{var e,r;let t;if("type"in s){if(s.type!=="spotlight")return;t=b(b({},s),s.payload)}else if("roomMessageType"in s){if(s.roomMessageType!=="spotlight")return;t=s}else return;this.logger.info("Spotlight Assertion Received",{spotlight:{spotlighter:{id:t.userId},currentTab:{id:(e=t.currentTab)==null?void 0:e.id,type:(r=t.currentTab)==null?void 0:r.type}}}),this.conditionallySetActiveTab(t)}),n(this,rt).getValue("peerSessionStore").on(E.MESSAGE,s=>{var e,r;let t;if("type"in s){if(s.type!=="spotlight")return;t=b(b({},s),s.payload)}else if("roomMessageType"in s){if(s.roomMessageType!=="spotlight")return;t=s}else return;this.logger.info("Spotlight Assertion Received",{spotlight:{spotlighter:{id:t.userId},currentTab:{id:(e=t.currentTab)==null?void 0:e.id,type:(r=t.currentTab)==null?void 0:r.type}}}),this.conditionallySetActiveTab(t)}),this.aiSocketHandler.on(A.transcript,s=>{const{meetingId:t,transcript:e,isPartial:r}=s;let i;try{i=cr.parseTranscript(e,r)}catch(d){this.logger.error(`Failed to parse transcript: ${e}`,d)}if(!i){this.logger.warn("Received empty transcript data");return}this.ai.onTranscript(i),this.meta.emit("transcript",i);const{peerId:a,name:o,transcript:c}=i;this.logger.debug(`${t} Received transcript for peer ${a} - ${o}: ${c}`)})}},js=new WeakMap,Fi=new WeakMap,rt=new WeakMap,_h);let Qp=Yp;Rk([S.trace("MetaController.setupEvents")],Qp.prototype,"setupEvents",1);const jn={},Ls={executeWithLock({methodName:s,lockName:t,timeout:e}){return(r,i,a)=>{const o=a.value;return a.value=function(...d){var P,w;const u=(w=(this==null?void 0:this.peerId)||((P=d[0])==null?void 0:P.authToken))!=null?w:"",p=`${t}-${u}`,m=this==null?void 0:this.logger;if(jn[p]){const C=new Error(`Unsupported concurrent calls on method: ${s}.`);throw C.name="UnsupportedConcurrentMethodExecution",m==null||m.error("Locker::UnsupportedConcurrentMethodExecution",{error:{stack:C.stack},locker:{methodName:s,lockName:p}}),C}jn[p]=!0;const T=setTimeout(()=>delete jn[p],e),v=o.apply(this,d);return Promise.resolve(v).then(()=>{delete jn[p],clearTimeout(T)}).catch(()=>{delete jn[p],clearTimeout(T)}),v},a}}};var kk=Object.defineProperty,bk=Object.getOwnPropertyDescriptor,Ti=(s,t,e,r)=>{for(var i=r>1?void 0:r?bk(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&kk(t,e,i),i},Tt,ic,B,ga,Qt,Se,ma,Zd,Bi,Ho;class gr extends ut{constructor(e,r,i,a,o){const c=e.getValue("logger");super(c);h(this,ma);h(this,Bi);h(this,Tt,void 0);h(this,ic,void 0);h(this,B,void 0);h(this,ga,void 0);h(this,Qt,void 0);h(this,Se,void 0);f(this,Se,e),f(this,Tt,a),f(this,ic,o),f(this,B,r),f(this,ga,i),f(this,Qt,[]),this.setupEvents()}get telemetry(){return n(this,Se).getValue("telemetry")}get status(){return n(this,Se).getValue("stageStatus")}setupEvents(){const e={[E.GET_STAGE_REQUESTS]:a=>l(this,null,function*(){f(this,Qt,a)}),[E.UPDATE_STAGE_REQUESTS]:o=>l(this,[o],function*({add:a}){const c=n(this,Qt).length,{stageRequests:d}=this.getAccessRequests();(a||d.length>c)&&this.emit("newStageRequest",{count:d.length}),this.emit("stageAccessRequestUpdate",d)})},r=()=>{Object.entries(e).forEach(([a,o])=>{n(this,Se).getValue("peerSessionStore").onAsync(a,o)})},i=()=>{Object.entries(e).forEach(([a,o])=>{n(this,Se).getValue("peerSessionStore").removeListener(a,o)})};n(this,B).permissions.on("permissionsUpdate",a=>{const{canAcceptProductionRequests:o}=a;o!==void 0&&(n(this,B).permissions.acceptStageRequests?(r(),n(this,Tt).getStageRequests()):(i(),f(this,Qt,[]),this.emit("stageAccessRequestUpdate",n(this,Qt))))}),n(this,B).permissions.acceptStageRequests&&r()}getAccessRequests(){if(!n(this,B).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new _("Stage is disabled","2003");if(!n(this,B).permissions.acceptStageRequests)throw this.logger.error("Stage::get_access_request::permission_denied"),new _("You do not have permission to perform this action","2001");const e=n(this,ga).joined.toArray().filter(r=>r.stageStatus==="REQUESTED_TO_JOIN_STAGE").map(r=>({displayName:r.name,userId:r.userId,peerId:r.id}));return f(this,Qt,e),{stageRequests:n(this,Qt)}}requestAccess(){return l(this,null,function*(){if(!n(this,B).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new _("Stage is disabled","2003");if(this.status!=="OFF_STAGE")throw new _(`Unable to request access you are currently ${this.status}`,"2006");if(n(this,B).permissions.stageAccess===I.MediaProductionPermissionType.Allowed){M(this,Bi,Ho).call(this,"ACCEPTED_TO_JOIN_STAGE");return}n(this,Tt).requestAccess(),M(this,Bi,Ho).call(this,"REQUESTED_TO_JOIN_STAGE")})}cancelRequestAccess(){return l(this,null,function*(){if(!n(this,B).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new _("Stage is disabled","2003");n(this,Tt).cancelRequestAccess(),M(this,Bi,Ho).call(this,"OFF_STAGE")})}grantAccess(e){if(!n(this,B).roomJoined)throw new _("Can`t grant for participant without joining room");if(!n(this,B).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new _("Stage is disabled","2003");if(!n(this,B).permissions.acceptStageRequests)throw this.logger.error("Stage::grant_access::permission_denied"),new _("You do not have permission to perform this action","2001");return n(this,Tt).grantAccess(e)}denyAccess(e){if(!n(this,B).roomJoined)throw new _("Can`t rejectRequestToJoinStage for participant without joining room","2005");if(!n(this,B).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new _("Stage is disabled","2003");if(!n(this,B).permissions.acceptStageRequests)throw this.logger.error("Stage::deny_access::permission_denied"),new _("You do not have permission to perform this action","2001");return n(this,Tt).denyAccess(e)}get peerId(){return n(this,Se).getValue("peerId")}join(){return l(this,null,function*(){const e=n(this,Se).getValue("viewType");if(this.status==="ON_STAGE")throw new _("You are already on stage.","2006");if(this.status!=="ACCEPTED_TO_JOIN_STAGE"||n(this,B).permissions.stageAccess===I.MediaProductionPermissionType.NotAllowed)throw new _(`Unable to join stage you are currently ${this.status}`,"2006");if(n(this,Se).setValue("stageStatus","ON_STAGE",!1),yield n(this,Tt).joinStage(),e===I.ViewType.Livestream){yield n(this,Se).getValue("selfController").joinRoom();return}n(this,Se).notify("stageStatus"),n(this,B).audioEnabled&&n(this,ma,Zd).shareMic(n(this,B).audioTrack),n(this,B).videoEnabled&&n(this,ma,Zd).shareWebcam(n(this,B).videoTrack)})}leave(){return l(this,null,function*(){if(!n(this,B).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new _("Stage is disabled","2003");if(!(this.status==="ON_STAGE"||this.status==="ACCEPTED_TO_JOIN_STAGE"))throw new _(`Unable to leave stage you are currently ${this.status}`,"2006");n(this,B).setIsPinned(!1),n(this,Se).setValue("stageStatus","OFF_STAGE",!1),yield n(this,Tt).leaveStage(n(this,B).userId);try{yield n(this,Se).getValue("peerSessionStore").emitAsync(E.LEAVE_MEDIA_ROOM,"stageLeft")}catch(e){this.logger.error("Stage::leave::emitAsync::failed",{error:e})}n(this,Se).notify("stageStatus")})}kick(e){return l(this,null,function*(){if(!n(this,B).roomJoined)throw new _("Can`t kick participant without joining room","2005");if(!n(this,B).permissions.stageEnabled)throw this.logger.error("Stage::stage_disabled"),new _("Stage is disabled","2003");if(!n(this,B).permissions.acceptStageRequests)throw this.logger.error("Stage::kick::permission_denied"),new _("You do not have permissions for kick","2001");return n(this,Tt).kick(e)})}}Tt=new WeakMap,ic=new WeakMap,B=new WeakMap,ga=new WeakMap,Qt=new WeakMap,Se=new WeakMap,ma=new WeakSet,Zd=function(){return n(this,Se).getValue("roomNodeClient")},Bi=new WeakSet,Ho=function(e){return l(this,null,function*(){this.status!==e&&n(this,Se).setValue("stageStatus",e)})};Ti([S.trace("Stage.getStageRequests")],gr.prototype,"getAccessRequests",1);Ti([S.trace("Stage.requestAccess")],gr.prototype,"requestAccess",1);Ti([S.trace("Stage.cancelRequestAccess")],gr.prototype,"cancelRequestAccess",1);Ti([S.trace("Stage.grantAccess")],gr.prototype,"grantAccess",1);Ti([S.trace("Stage.denyAccess")],gr.prototype,"denyAccess",1);Ti([Ls.executeWithLock({methodName:"joinStage",lockName:"Stage.join",timeout:5e3}),S.trace("Stage.joinStage")],gr.prototype,"join",1);Ti([S.trace("Stage.leaveStage")],gr.prototype,"leave",1);function Mk(s){return!(s.viewType==="LIVESTREAM"||s.viewType==="CHAT")}function Ol(s){switch(s){case bs.UNSPECIFIED:return"OFF_STAGE";case bs.REQUESTED_STAGE:return"REQUESTED_TO_JOIN_STAGE";case bs.APPROVED_STAGE:return"ACCEPTED_TO_JOIN_STAGE";case bs.OFF_STAGE:return"OFF_STAGE";case bs.ON_STAGE:return"ON_STAGE";default:return"OFF_STAGE"}}var Ak=Object.defineProperty,Ik=Object.getOwnPropertyDescriptor,Ok=(s,t,e,r)=>{for(var i=r>1?void 0:r?Ik(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Ak(t,e,i),i},Gs,Nt,Js,fa,Le;class Xp{constructor(t,e,r,i,a){g(this,"stage");h(this,Gs,void 0);h(this,Nt,void 0);h(this,Js,void 0);h(this,fa,0);h(this,Le,void 0);f(this,Le,t),this.stage=new gr(t,i,a,e,r),f(this,Js,e),f(this,Gs,i),f(this,Nt,a),this.setupEvents()}get telemetry(){return n(this,Le).getValue("telemetry")}get logger(){return n(this,Le).getValue("logger")}setupEvents(){n(this,Le).subscribe("stageStatus",t=>{this.stage.emit("stageStatusUpdate",t)}),n(this,Js).on(A.grantStageAccess,()=>{n(this,Gs).permissions.stageAccess!==I.MediaProductionPermissionType.Allowed&&(this.stage.emit("stageRequestApproved"),this.setStageStatus("ACCEPTED_TO_JOIN_STAGE"))}),n(this,Js).on(A.peerStageStatusUpdate,t=>{t!==void 0&&(t.peerId===n(this,Gs).id?this.selfStageStatusHandler(t):this.peerStageStatusHandler(t))}),n(this,Js).on(A.denyStageAccess,()=>{n(this,Gs).permissions.stageAccess!==I.MediaProductionPermissionType.Allowed&&(this.stage.emit("stageRequestRejected"),this.setStageStatus("OFF_STAGE"))}),n(this,Js).on(A.getStageRequests,t=>l(this,null,function*(){var r;if(n(this,Gs).permissions.stageAccess!==I.MediaProductionPermissionType.Allowed)return;const e=(r=t==null?void 0:t.stageRequests)!=null?r:[];yield n(this,Le).getValue("peerSessionStore").emitAsync(E.GET_STAGE_REQUESTS,e),n(this,fa)<e.length&&e.length>0&&this.stage.emit("newStageRequest",{count:e.length}),f(this,fa,e.length),this.stage.emit("stageAccessRequestUpdate",e)}))}getCurrentStageRequests(){return n(this,Nt).joined.toArray().filter(e=>e.stageStatus==="REQUESTED_TO_JOIN_STAGE").map(e=>({displayName:e.name,userId:e.userId,peerId:e.id}))}setStageStatus(t){return l(this,null,function*(){this.stage.status!==t&&n(this,Le).setValue("stageStatus",t)})}selfStageStatusHandler(t){const e=Ol(t.stageType),r=n(this,Le).getValue("stageStatus");if(r!==e)switch(t.stageType){case 1:n(this,Le).setValue("stageStatus","ACCEPTED_TO_JOIN_STAGE",!1),this.stage.join();break;case 2:case 3:this.setStageStatus(r);break;case 0:case 4:default:n(this,Le).setValue("stageStatus","ACCEPTED_TO_JOIN_STAGE",!1),this.stage.leave();break}}peerStageStatusHandler(t){return l(this,null,function*(){const e=n(this,Nt).joined.get(t.peerId),r=n(this,Nt).viewMode==="ACTIVE_GRID";if(!e){this.logger.warn("err::peerStageStatusUpdate: participant not found");return}switch(t.stageType){case 1:e.setStageStatus("ON_STAGE"),r&&n(this,Le).getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:n(this,Nt).viewMode,page:n(this,Nt).currentPage});break;case 2:e.setStageStatus("ACCEPTED_TO_JOIN_STAGE");break;case 3:e.setStageStatus("REQUESTED_TO_JOIN_STAGE");break;case 0:case 4:default:e.setStageStatus("OFF_STAGE"),r&&n(this,Le).getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:n(this,Nt).viewMode,page:n(this,Nt).currentPage});break}n(this,Le).getValue("peerSessionStore").emit(E.UPDATE_PEER_STAGE_STATUS,{id:e.id,status:e.stageStatus})})}}Gs=new WeakMap,Nt=new WeakMap,Js=new WeakMap,fa=new WeakMap,Le=new WeakMap;Ok([S.trace("Stage.setupEvents")],Xp.prototype,"setupEvents",1);var Dk=Object.defineProperty,Nk=Object.getOwnPropertyDescriptor,sd=(s,t,e,r)=>{for(var i=r>1?void 0:r?Nk(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Dk(t,e,i),i};const ae={getPeer:14,getPeers:15,chatMessage:16,getRoomName:17,getDisplayTitle:18,getPluginInitiator:19,customPluginEventToParent:20,peerJoined:22,peerLeft:23,sendData:24,stageStatusUpdate:25,peerStageStatusUpdate:26};var be,it,ji,Gi,hs,Ji,Ws,Wi,Rh;let Nn=(Rh=class extends Vn{constructor(t,{baseURL:e,createdAt:r,description:i,id:a,name:o,organizationId:c,picture:d,private:u,published:p,staggered:m,tags:T,type:v,updatedAt:P},w,C,k,R,D){const O=t.getValue("logger");super(O);h(this,be,void 0);g(this,"baseURL");g(this,"createdAt");g(this,"description");g(this,"id");g(this,"name");h(this,it,void 0);h(this,ji,void 0);h(this,Gi,void 0);g(this,"organizationId");g(this,"picture");g(this,"private");g(this,"published");g(this,"staggered");g(this,"tags");g(this,"type");g(this,"updatedAt");h(this,hs,void 0);g(this,"config");h(this,Ji,void 0);g(this,"active");g(this,"iframes");g(this,"enabledBy");h(this,Ws,void 0);h(this,Wi,void 0);f(this,Ws,t),this.baseURL=e,this.createdAt=new Date(r),this.description=i,this.id=a,this.name=o,f(this,it,C),this.organizationId=c,this.picture=d,this.private=u,this.published=p,this.staggered=m,this.tags=T,this.type=v,this.updatedAt=new Date(P),this.active=!1,this.iframes=new Map,f(this,be,w),f(this,ji,k),f(this,Gi,R),this.enabledBy="",f(this,Wi,D)}get telemetry(){return n(this,Ws).getValue("telemetry")}sendIframeEvent(t){this.iframes.size&&this.iframes.forEach(e=>{const{iframe:r}=e;r&&(navigator.isReactNative?r.postMessage(JSON.stringify(t)):r.contentWindow.postMessage(t,"*"))})}handleIframeMessage(t){return l(this,null,function*(){var o;if(!this.active)return;const e=t,{payload:r,uuid:i,type:a}=e;switch(a){case $.customPluginEventToRoom:{n(this,be).customPluginEventToRoom(this.id,r,i);break}case $.customPluginEventToPeers:{n(this,be).customPluginEventToPeers(this.id,r.peerIds,r,i);break}case $.enablePluginForRoom:{n(this,be).enablePluginForRoom(this.id,i);break}case $.enablePluginForPeers:{n(this,be).enablePluginForPeers(this.id,r.peerIds,i);break}case $.disablePluginForRoom:{n(this,be).disablePluginForRoom(this.id,i);break}case $.disablePluginForPeers:{n(this,be).disablePluginForPeers(this.id,r.peerIds,i);break}case $.storeInsertKeys:{n(this,be).storeInsertKeys(this.id,r.store,r.insertKeys,i);break}case $.storeGetKeys:{n(this,be).storeGetKeys(this.id,r.store,r.getKeys,i);break}case $.storeDeleteKeys:{n(this,be).storeDeleteKeys(this.id,r.store,r.deleteKeys,i);break}case $.storeDelete:{n(this,be).storeDelete(this.id,r.store,i);break}case ae.chatMessage:{const{messagePayload:c,peerIds:d}=r;if(!n(this,Gi)){this.sendIframeEvent({type:ae.chatMessage,uuid:e.uuid,payload:{error:"Chat is disabled for this room."}});return}try{yield n(this,Gi).sendMessage(c,d),this.sendIframeEvent({type:ae.chatMessage,uuid:e.uuid,payload:{success:!0}})}catch(u){this.sendIframeEvent({type:ae.chatMessage,uuid:e.uuid,payload:{error:u}})}break}case ae.getPeer:{let c;const{peerId:d}=r,u=U(b({},n(this,it)),{id:n(this,it).id,isRecorder:(o=n(this,it).permissions)==null?void 0:o.isRecorder,isHidden:n(this,it).permissions.hiddenParticipant,stageStatus:n(this,it).stageStatus});d?(c=n(this,ji).joined.get(r.peerId),n(this,it).id===d&&(c=u)):c=u,this.sendIframeEvent({type:ae.getPeer,payload:{peer:c&&Yo(c)},uuid:e.uuid});break}case ae.getPeers:{const c=n(this,ji).joined.toArray().map(d=>Yo(d));this.sendIframeEvent({type:ae.getPeers,payload:{peers:c},uuid:e.uuid});break}case ae.getPluginInitiator:{this.sendIframeEvent({type:ae.getPluginInitiator,payload:{enabledBy:this.enabledBy},uuid:e.uuid});break}case ae.getDisplayTitle:{this.sendIframeEvent({type:ae.getDisplayTitle,payload:{displayTitle:n(this,Wi)},uuid:e.uuid});break}case ae.getRoomName:{this.sendIframeEvent({type:ae.getRoomName,payload:{roomName:n(this,Ws).getValue("meetingId")},uuid:e.uuid});break}case ae.customPluginEventToParent:{this.emit(e.payload.eventName,e.payload.data);break}}})}sendData(t){this.active&&(this.logger.info("Plugin::SendData",{plugin:{id:this.id,name:this.name,data:{eventName:t.eventName}}}),this.sendIframeEvent({type:ae.sendData,uuid:"",payload:t}))}removePluginView(t="default"){var i;const{iframe:e,listener:r}=(i=this.iframes.get(t))!=null?i:{};(e||r)&&(navigator.isReactNative?e.props.onMessage=void 0:window.removeEventListener("message",r),this.iframes.delete(t))}addPluginView(t,e="default"){var o;if(!n(this,Ji))throw this.logger.error("Plugin::addPluginView::no_auth_token_set_for_plugin"),new _("No auth token set for plugin.","0602");if(!t)throw this.logger.error("Plugin::addPluginView::iframe_was_not_provided"),new _("Iframe was not provided.","0603");this.removePluginView(e);const r=t,i=new URL(this.baseURL),a={auth:n(this,Ji),parent:navigator.isReactNative?this.baseURL:window.location.origin,backend:n(this,Ws).getValue("apiBase"),pluginId:this.id,roomName:(o=n(this,Ws).getValue("meetingId"))!=null?o:"",displayTitle:n(this,Wi)};if(Object.keys(a).forEach(c=>{i.searchParams.set(c,a[c])}),r.src=i.href,r.allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture",r.title=e,navigator.isReactNative)r.props.onMessage=c=>{this.handleIframeMessage(JSON.parse(c.nativeEvent.data))},this.iframes.set(e,{iframe:r});else{const c=d=>l(this,null,function*(){d.source===t.contentWindow&&(yield this.handleIframeMessage(d.data))});window.addEventListener("message",c),this.iframes.set(e,{iframe:r,listener:c})}}setActive(t){var e,r;if(this.active=t,t){this.emit("stateUpdate",{active:this.active,pluginId:this.id,bind:this.addPluginView.bind(this),views:(e=this.config)==null?void 0:e.views});return}this.active=!1,this.emit("stateUpdate",{active:this.active,pluginId:this.id,views:(r=this.config)==null?void 0:r.views})}activateForSelf(){return l(this,null,function*(){const t=De(),e=yield t.authorizePlugin(this.id);f(this,Ji,e),f(this,hs,new Date);try{const r=yield t.getPluginConfig(this.baseURL);this.config=r}catch(r){this.logger.error("Plugin::activateForSelf",{error:r})}this.setActive(!0),this.emit("enabled")})}deactivateForSelf(){Array.from(this.iframes.keys()).forEach(t=>{this.removePluginView(t)}),f(this,hs,void 0),this.iframes.clear(),this.setActive(!1),this.emit("closed")}enable(){return l(this,null,function*(){return this.activateForSelf()})}disable(){return this.deactivateForSelf()}activate(){return l(this,null,function*(){var t,e;this.active||(e=(t=n(this,it).permissions)==null?void 0:t.plugins)!=null&&e.canStart&&(n(this,be).addPlugin(this.id,this.staggered),f(this,hs,new Date),this.logger.info("plugin::activated",{plugin:{id:this.id,enabledBy:this.enabledBy,name:this.name}}))})}deactivate(){return l(this,null,function*(){var t,e;this.active&&(!((e=(t=n(this,it).permissions)==null?void 0:t.plugins)!=null&&e.canClose)&&this.enabledBy!==n(this,it).id||(n(this,be).removePlugin(this.id),this.logger.info("plugin::deactivated",{plugin:{id:this.id,name:this.name,duration:n(this,hs)?new Date().getTime()-n(this,hs).getTime():0}}),f(this,hs,void 0)))})}},be=new WeakMap,it=new WeakMap,ji=new WeakMap,Gi=new WeakMap,hs=new WeakMap,Ji=new WeakMap,Ws=new WeakMap,Wi=new WeakMap,Rh);sd([Qe({maxInvocations:5,period:1})],Nn.prototype,"sendData",1);sd([S.trace("Plugin.activatePlugin")],Nn.prototype,"activate",1);sd([S.trace("Plugin.deactivatePlugin")],Nn.prototype,"deactivate",1);Nn=sd([Ne("0600")],Nn);var de,kr;class Zp extends Map{constructor(e,r=void 0){const{onAddEvent:i,onDeleteEvent:a,onClearEvent:o}=e;super();h(this,de,void 0);h(this,kr,void 0);g(this,"onAddEvent");g(this,"onDeleteEvent");g(this,"onClearEvent");f(this,de,new Vn(r)),this.onAddEvent=i,this.onDeleteEvent=a,this.onClearEvent=o,f(this,kr,new Map)}emit(e,...r){return n(this,de).emit(e,...r)}on(e,r){return n(this,de).on(e,r)}addListener(e,r){return n(this,de).addListener(e,r)}off(e,r){return n(this,de).off(e,r)}once(e,r){return n(this,de).once(e,r)}prependListener(e,r){return n(this,de).prependListener(e,r)}prependOnceListener(e,r){return n(this,de).prependOnceListener(e,r)}removeListener(e,r){return n(this,de).removeListener(e,r)}removeAllListeners(e){return n(this,de).removeAllListeners(e)}listeners(e){return n(this,de).listeners(e)}listenerCount(e){return n(this,de).listenerCount(e)}getMaxListeners(){return n(this,de).getMaxListeners()}setMaxListeners(e){return n(this,de).setMaxListeners(e)}eventNames(){return n(this,de).eventNames()}add(e,r=!0){return this.set(e.id,e,r)}set(e,r,i=!0){const a=super.set(e,r),o=(c,...d)=>{this.emit(c,r,...d)};return n(this,kr).set(e,o),r.on("*",o),i&&n(this,de).emit(this.onAddEvent,r),a}delete(e,r=!0,i=!1){const a=this.get(e);if(!a)return!1;a.removeListener("*",n(this,kr).get(e));const o=super.delete(e);return i&&a.removeAllListeners(),r&&n(this,de).emit(this.onDeleteEvent,a),o}clear(e=!0,r=!1){this.forEach(a=>{a.removeListener("*",n(this,kr).get(a.id)),r&&a.removeAllListeners()});const i=super.clear();return e&&n(this,de).emit(this.onClearEvent),i}toArray(){return Array.from(this.values())}}de=new WeakMap,kr=new WeakMap;class ch extends Zp{constructor(t){super({onAddEvent:"pluginAdded",onDeleteEvent:"pluginDeleted"},t)}add(t,e=!0){return super.add(t,e)}delete(t,e=!0,r=!1){return super.delete(t,e,r)}}var Vk=Object.defineProperty,xk=Object.getOwnPropertyDescriptor,Lk=(s,t,e,r)=>{for(var i=r>1?void 0:r?xk(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Vk(t,e,i),i};let el=class{constructor(s){g(this,"all");g(this,"active");this.all=new ch(s),this.active=new ch(s)}};el=Lk([Ne("0600")],el);var $k=Object.defineProperty,Uk=Object.getOwnPropertyDescriptor,rd=(s,t,e,r)=>{for(var i=r>1?void 0:r?Uk(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&$k(t,e,i),i},yt,Ki,Vt,kh;const eg=(kh=class{constructor(s,t,e,r){g(this,"plugins");h(this,yt,void 0);h(this,Ki,void 0);h(this,Vt,void 0);f(this,yt,t),f(this,Ki,e),f(this,Vt,s),this.plugins=r,this.setupEvents()}get telemetry(){return n(this,Vt).getValue("telemetry")}get logger(){return n(this,Vt).getValue("logger")}static init(s,t,e,r,i,a,o,c){return l(this,null,function*(){const d=s.getValue("logger"),u=new el(d);return t.forEach(p=>{const m=new Nn(s,p,e,a,o,i,c);u.all.add(m)}),new eg(s,e,r,u)})}getRoomPlugins(){return l(this,null,function*(){var t;const{plugins:s}=yield n(this,yt).getActivePlugins();(t=this.plugins.active)==null||t.toArray().forEach(e=>{this.disablePlugin({id:e.id})}),yield Promise.all(s.map(e=>this.enablePlugin({id:e.pluginId,enabledBy:e.enabledBy})))})}enablePlugin(e){return l(this,arguments,function*({id:s,enabledBy:t}){const r=this.plugins.all.get(s);r&&(yield r.activateForSelf(),r.enabledBy=t)})}disablePlugin(t){return l(this,arguments,function*({id:s}){const e=this.plugins.all.get(s);e&&e.deactivateForSelf()})}sendIframeEvent(s,t,e,r){const i=this.plugins.all.get(t);i&&i.sendIframeEvent({type:s,uuid:e,payload:r})}broadcastIframeEvent(s,t){this.plugins.active.forEach(e=>{this.sendIframeEvent(s,e.id,"",t)})}setupEvents(){this.plugins.all.on("stateUpdate",({active:s,id:t})=>{if(s){this.plugins.active.add(this.plugins.all.get(t));return}this.plugins.active.delete(t)}),n(this,Vt).getValue("peerSessionStore").onAsync(E.SOCKET_SERVICE_ROOM_JOINED,()=>l(this,null,function*(){yield this.getRoomPlugins(),this.logger.debug("[SOCKET_SERVICE_ROOM_JOINED] resolved request to fetch plugins.")})),n(this,yt).on($.addPlugin,s=>l(this,null,function*(){var e;const t=s.pluginId;(e=this.plugins.all.get(t))!=null&&e.active||(yield this.enablePlugin({id:t,enabledBy:s.enabledBy}))})),n(this,yt).on($.removePlugin,s=>l(this,null,function*(){var e;const t=s.pluginId;(e=this.plugins.all.get(t))!=null&&e.active&&(yield this.disablePlugin({id:t}))})),[$.enablePluginForPeers,$.enablePluginForRoom].forEach(s=>{n(this,yt).on(s,(t,e)=>l(this,null,function*(){this.sendIframeEvent(s,t.pluginId,e,{enabledBy:t.enabledBy})}))}),[$.disablePluginForPeers,$.disablePluginForRoom].forEach(s=>{n(this,yt).on(s,(t,e)=>l(this,null,function*(){this.sendIframeEvent(s,t.pluginId,e,{disabledBy:t.disabledBy})}))}),[$.customPluginEventToPeers,$.customPluginEventToRoom].forEach(s=>{n(this,yt).on(s,(t,e)=>l(this,null,function*(){this.sendIframeEvent(s,t.pluginId,e,{data:JSON.parse(new TextDecoder().decode(t.pluginData))})}))}),[$.storeInsertKeys,$.storeGetKeys,$.storeDeleteKeys].forEach(s=>{n(this,yt).on(s,(t,e)=>l(this,null,function*(){var i;const r=(i=t.storeItems)==null?void 0:i.map(a=>{var o;return{timestamp:a.timestamp,peerId:a.peerId,payload:JSON.parse((o=a.payload)!=null&&o.length?new TextDecoder().decode(a.payload):"{}"),key:a.storeKey}});this.sendIframeEvent(s,t.pluginId,e,{storeName:t.storeName,storeItems:r})}))}),n(this,yt).on($.storeDelete,(s,t)=>l(this,null,function*(){this.sendIframeEvent($.storeDelete,s.pluginId,t,{storeName:s.storeName})})),n(this,Ki).on(pe.sendMessageToPeers,s=>{const t=kt==null?void 0:kt.formatSocketPeerMessage(s.message);this.broadcastIframeEvent(ae.chatMessage,{message:t})}),n(this,Ki).on(pe.sendMessageToRoom,s=>{const t=kt==null?void 0:kt.formatSocketPeerMessage(s.message);this.broadcastIframeEvent(ae.chatMessage,{message:t})}),n(this,Vt).getValue("peerSessionStore").on(E.PEER_JOINED_INTERNAL,s=>{const t=Yo(s);this.broadcastIframeEvent(ae.peerJoined,t)}),n(this,Vt).getValue("peerSessionStore").on(E.PEER_CLOSED,s=>{this.broadcastIframeEvent(ae.peerLeft,s)}),n(this,Vt).getValue("peerSessionStore").on(E.UPDATE_PEER_STAGE_STATUS,s=>{this.broadcastIframeEvent(ae.peerStageStatusUpdate,s)}),n(this,Vt).subscribe("stageStatus",s=>{this.broadcastIframeEvent(ae.stageStatusUpdate,s)})}},yt=new WeakMap,Ki=new WeakMap,Vt=new WeakMap,kh);let To=eg;rd([S.trace("PluginController.getRoomPlugins")],To.prototype,"getRoomPlugins",1);rd([S.trace("PluginController.enableForSelf")],To.prototype,"enablePlugin",1);rd([S.trace("PluginController.disableForSelf")],To.prototype,"disablePlugin",1);rd([S.trace("PluginController.setupEvents")],To.prototype,"setupEvents",1);var Ta;class qk{constructor(t){g(this,"mediaJoined");g(this,"socketJoined");g(this,"socketJoinAttempted");g(this,"mediaJoinAttempted");g(this,"socketState");g(this,"mediaState");h(this,Ta,void 0);this.mediaJoined=!1,this.socketJoined=!1,this.socketJoinAttempted=!1,this.mediaJoinAttempted=!1,this.socketState={state:void 0,reconnected:!1,reconnectionAttempt:void 0},this.mediaState={recv:void 0,send:void 0},f(this,Ta,t)}get joinAttempted(){return this.mediaJoinAttempted||this.socketJoinAttempted}get roomJoined(){return this.mediaJoined&&this.socketJoined}updateSocketConnectionState(t,e){let r;const{reconnected:i}=this.socketState;switch(t){case"connected":r={state:"connected",reconnected:i,reconnectionAttempt:void 0};break;case"disconnected":r={state:"disconnected",reconnected:!1,reconnectionAttempt:0},this.socketJoined=!1;break;case"reconnected":r={state:"connected",reconnected:!0,reconnectionAttempt:void 0};break;case"reconnecting":r={state:"reconnecting",reconnected:i,reconnectionAttempt:0};break;case"reconnectAttempt":r={state:"reconnecting",reconnected:i,reconnectionAttempt:e};break;case"failed":r={state:"failed",reconnected:i,reconnectionAttempt:void 0},this.socketJoined=!1;break}r&&(n(this,Ta).getValue("peerSessionStore").emit(E.SOCKET_STATE_UPDATE,r),this.socketState=r)}}Ta=new WeakMap;var Hk=Object.defineProperty,Fk=Object.getOwnPropertyDescriptor,yo=(s,t,e,r)=>{for(var i=r>1?void 0:r?Fk(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Hk(t,e,i),i},zi,Yi,Qi,Fo,bh;let pi=(bh=class extends ut{constructor(t,e){const r=t.getValue("logger");super(r);h(this,Qi);h(this,zi,void 0);h(this,Yi,void 0);g(this,"recordingPeerIds",[]);g(this,"recordings",[]);f(this,Yi,t),f(this,zi,e)}get recordingState(){return this.recordings.some(t=>t.state==="RECORDING")?"RECORDING":this.recordings.some(t=>t.state==="PAUSED")?"PAUSED":this.recordings.some(t=>t.state==="STARTING")?"STARTING":this.recordings.some(t=>t.state==="STOPPING")?"STOPPING":"IDLE"}get telemetry(){return n(this,Yi).getValue("telemetry")}updateRecordings(t){this.recordings=t,this.emit("recordingUpdate",this.recordingState)}start(t){return l(this,null,function*(){if(!n(this,zi).permissions.canRecord)throw this.logger.error("Recording::start::permission_denied"),new _("User does not have permission to start recording","1001");if((t==null?void 0:t.allowMultiple)!==!0&&(this.recordingState==="STARTING"||this.recordingState==="RECORDING"||this.recordingState==="STOPPING"))throw this.logger.error("Recording::start::recording_in_progress",{recording:{state:this.recordingState}}),new _(`Cant start recording, recordingState irregular: ${this.recordingState}`,"1005");try{const e=De(),{recording:r={}}=n(this,Yi).getValue("defaults"),i=yield e.startRecording(r,t==null?void 0:t.allowMultiple);this.updateRecordings([...this.recordings,{id:i,state:"STARTING",type:"BROWSER"}])}catch(e){throw this.logger.error("Recording::stop::recording_failed_to_start",{error:e}),new _("Error while starting recording","1000",this.logger)}})}stop(t){return l(this,null,function*(){yield M(this,Qi,Fo).call(this,"stop",["RECORDING","PAUSED"],t)})}pause(t){return l(this,null,function*(){yield M(this,Qi,Fo).call(this,"pause",["RECORDING"],t)})}resume(t){return l(this,null,function*(){yield M(this,Qi,Fo).call(this,"resume",["PAUSED"],t)})}},zi=new WeakMap,Yi=new WeakMap,Qi=new WeakSet,Fo=function(t,e,r){return l(this,null,function*(){if(!n(this,zi).permissions.canRecord)throw this.logger.error("Recording::stop::permission_denied"),new _("User does not have permission to stop recording","1001");let i=[];if(r!==void 0){const a=this.recordings.find(o=>o.id===r);if(a===void 0)throw new _("Could not find the specified recording","1004");if(e.includes(a.state)){this.logger.error("Recording::stop::recording_not_in_expected_state",{recording:{state:a.state}});return}i.push(a)}else i=this.recordings.filter(a=>e.includes(a.state));i.forEach(a=>l(this,null,function*(){const o=a.state;t==="stop"&&(a.state="STOPPING",this.emit("recordingUpdate","STOPPING"));try{yield De().updateRecording(a.id,t)}catch(c){throw this.logger.error("Recording::stop::recording_failed_to_stop",{error:c}),a.state!==o&&(a.state=o,this.emit("recordingUpdate",o)),new _("Error while stopping recording","1000",this.logger)}}))})},bh);yo([S.trace("Recording.start")],pi.prototype,"start",1);yo([S.trace("Recording.stop")],pi.prototype,"stop",1);yo([S.trace("Recording.stop")],pi.prototype,"pause",1);yo([S.trace("Recording.stop")],pi.prototype,"resume",1);pi=yo([Ne("1000")],pi);var Bk=Object.defineProperty,jk=Object.getOwnPropertyDescriptor,Gk=(s,t,e,r)=>{for(var i=r>1?void 0:r?jk(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Bk(t,e,i),i},br;class tg{constructor(t,e,r){g(this,"recording");g(this,"room");h(this,br,void 0);f(this,br,t),this.recording=new pi(t,e),this.room=r,this.setupEvents()}get telemetry(){return n(this,br).getValue("telemetry")}get logger(){return n(this,br).getValue("logger")}getRecordingTypeFromProtoType(t){let e;switch(t){case li.BROWSER:e="BROWSER";break;case li.COMPOSITE:e="COMPOSITE";break;case li.TRACK:e="TRACK";break;default:e="BROWSER"}return e}setupEvents(){n(this,br).getValue("peerSessionStore").on(E.ROOM_STATE,t=>{t.activeRecordings.length!==0?this.recording.updateRecordings(t.activeRecordings.map(e=>{const r=this.getRecordingTypeFromProtoType(e.recordingType);return{id:e.recordingId,state:e.recordingStatus,type:r}})):this.recording.recordings.length&&this.recording.updateRecordings([])}),this.room.on(A.recordingStarted,t=>{let e=!1;const r=[...this.recording.recordings];if(r.forEach(i=>{i.id===t.recordingId&&(e=!0,i.state="RECORDING")}),e===!1){const i=this.getRecordingTypeFromProtoType(t.recordingType);r.push({id:t.recordingId,state:"RECORDING",type:i})}this.recording.updateRecordings(r)}),this.room.on(A.recordingPaused,t=>{const e=[...this.recording.recordings];e.forEach(r=>{r.id===t.recordingId&&(r.state="PAUSED")}),this.recording.updateRecordings(e)}),this.room.on(A.recordingStopped,t=>{const e=[...this.recording.recordings.filter(r=>r.id!==t.recordingId)];this.recording.updateRecordings(e)})}}br=new WeakMap;Gk([S.trace("RecordingController.setupEvents")],tg.prototype,"setupEvents",1);var Mr;class Jk{constructor(t){h(this,Mr,void 0);f(this,Mr,t)}hasFeature(t){var e;return(e=n(this,Mr).getValue("flagsmith").hasFeature(t))!=null?e:!1}getFeatureValue(t){return n(this,Mr).getValue("flagsmith").getValue(t)}getAllFeatures(){return n(this,Mr).getValue("flagsmith").getAllFlags()}}Mr=new WeakMap;class Dl{constructor(t,e,r){g(this,"logger");g(this,"features");g(this,"browserSpecs");g(this,"callStats");this.logger=t,this.features=e,this.browserSpecs=Z,this.callStats=r}static init(t){return new Dl(t.getValue("logger"),new Jk(t),t.getValue("callstats"))}}class Nl{constructor(t){g(this,"internals");this.internals=t}static init(t){return l(this,null,function*(){const e=Dl.init(t);return new Nl(e)})}}var Wk=Object.defineProperty,Kk=Object.getOwnPropertyDescriptor,pt=(s,t,e,r)=>{for(var i=r>1?void 0:r?Kk(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Wk(t,e,i),i},me,Q,K,ps,vt,ya,ne;class Xe extends Vn{constructor(e,r,i=Qo,a=!0){const o=e.getValue("logger");super(o);h(this,me,void 0);h(this,Q,void 0);h(this,K,void 0);h(this,ps,void 0);h(this,vt,void 0);h(this,ya,void 0);h(this,ne,void 0);g(this,"audioUpdateInProgress");g(this,"videoUpdateInProgress");f(this,ne,e),this.audioUpdateInProgress=!1,this.videoUpdateInProgress=!1,f(this,me,new sg(e,r)),f(this,Q,new fb(e,n(this,me),void 0,i)),f(this,K,new wb(e,n(this,me),void 0,i)),f(this,vt,new Sb(n(this,ne),n(this,me))),f(this,ps,new yb(e,n(this,me))),f(this,ya,a),n(this,Q).on("trackMuted",this.onAudioTrackMuted.bind(this)),n(this,Q).on("trackChanged",this.onAudioTrackChanged.bind(this)),n(this,K).on("trackChanged",this.onVideoTrackChanged.bind(this)),n(this,K).on("trackEnded",this.onVideoTrackEnded.bind(this)),n(this,vt).on("trackEnded",this.onScreenShareEnded.bind(this)),this.onVisibilityChange=this.onVisibilityChange.bind(this),document.addEventListener("visibilitychange",this.onVisibilityChange)}get telemetry(){return n(this,ne).getValue("telemetry")}set context(e){f(this,ne,e)}onVisibilityChange(){return l(this,null,function*(){n(this,ne).getValue("callstats").tabChanged(document.visibilityState==="visible"),document.visibilityState!=="visible"?n(this,ne).getValue("callstats").browserBackgrounded():(n(this,ne).getValue("callstats").browserForegrounded(),yield this.setupSpeaker())})}repopulateAvailableDevices(){return l(this,null,function*(){return!0})}setupStreams(i){return l(this,arguments,function*({audio:e,video:r}){var c;e?n(this,ne).getValue("callstats").audioOn():n(this,ne).getValue("callstats").audioOff(),r?n(this,ne).getValue("callstats").videoOn():n(this,ne).getValue("callstats").videoOff();let a,o;if(e&&r)try{const d=yield n(this,me).getAudioAndVideoTrack(n(this,Q).userSelectedDevice,n(this,K).userSelectedDevice);a=d.audioTrack,o=d.videoTrack}catch(d){this.logger.error("LocalMediaHandler::init::Failed to get audio video tracks",{error:d})}if(!a&&e)try{a=yield n(this,me).getAudioTrack(!1,n(this,Q).userSelectedDevice)}catch(d){this.logger.error("LocalMediaHandler::init::Failed to get audio track",{error:d})}if(!o&&r)try{o=yield n(this,me).getVideoTrack(n(this,K).userSelectedDevice)}catch(d){this.logger.error("LocalMediaHandler::init::Failed to get video track",{error:d})}e&&!a&&n(this,ne).getValue("callstats").audioOff(),r&&!o&&n(this,ne).getValue("callstats").videoOff(),yield n(this,Q).setMediaTrack(a),yield n(this,K).setMediaTrack(o);try{yield this.setupSpeaker()}catch(d){}if(o){const d=yield this.getDeviceById(o.getSettings().deviceId);n(this,ne).getValue("callstats").selectedDevice("VIDEO",d)}if(a){const d=yield this.getDeviceById(a.getSettings().deviceId);n(this,ne).getValue("callstats").selectedDevice("AUDIO",d)}(c=n(this,ps).currentDevice)!=null&&c.deviceId&&n(this,ne).getValue("callstats").selectedDevice("SPEAKER",n(this,ps).currentDevice),n(this,me).onDeviceChange((d,u,p)=>{this.onDeviceChange(u,p)})})}getCurrentDevices(){return{audio:n(this,Q).currentDevice,video:n(this,K).currentDevice,speaker:n(this,ps).currentDevice}}get permissions(){return n(this,me).permissions}getAllDevices(){return n(this,me).getAvailableDevices()}getDeviceById(e,r){return n(this,me).getDevice(e)}onAudioTrackMuted(){this.emit("AUDIO_TRACK_SILENT")}onAudioTrackChanged(){this.emit("AUDIO_TRACK_CHANGE")}get rawAudioTrack(){return n(this,Q).mediaTrack}get audioTrack(){return n(this,Q).transformedMediaTrack}get audioEnabled(){return n(this,Q).trackEnabled}enableAudio(e){return l(this,null,function*(){if(!this.audioUpdateInProgress){this.audioUpdateInProgress=!0;try{e?yield n(this,Q).enableTrack(!1,e):yield n(this,Q).unmuteTrack()}catch(r){}finally{this.audioUpdateInProgress=!1}}})}disableAudio(){n(this,Q).mediaTrack&&!n(this,Q).isCustomTrack?n(this,Q).muteTrack():n(this,Q).disableTrack()}getAudioDevices(e){return n(this,me).getAudioInputDevices(e)}setAudioDevice(i,a){return l(this,arguments,function*(e,{saveDevicePreference:r}){yield n(this,Q).setDevice(e,{saveDevicePreference:r}),e!=null&&e.deviceId&&n(this,ne).getValue("callstats").selectedDevice("AUDIO",e),this.emit("AUDIO_TRACK_CHANGE"),this.emit("DEVICE_CHANGE",{device:e})})}setupSpeaker(){return l(this,null,function*(){const{speaker:e}=this.getCurrentDevices();yield n(this,ps).setPreferredSpeaker();const{speaker:r}=this.getCurrentDevices();(e==null?void 0:e.deviceId)!==(r==null?void 0:r.deviceId)&&r&&this.emit("DEVICE_CHANGE",{device:r})})}setSpeakerDevice(i,a){return l(this,arguments,function*(e,{saveDevicePreference:r}){yield n(this,ps).setupSpeaker(e,{saveDevicePreference:r}),e!=null&&e.deviceId&&n(this,ne).getValue("callstats").selectedDevice("SPEAKER",e),this.emit("DEVICE_CHANGE",{device:e})})}onVideoTrackChanged(){this.emit("VIDEO_TRACK_CHANGE")}onVideoTrackEnded(){this.emit("VIDEO_TRACK_CHANGE")}get rawVideoTrack(){return n(this,K).mediaTrack}get videoTrack(){return n(this,K).transformedMediaTrack}get videoEnabled(){return n(this,K).trackEnabled}enableVideo(e){return l(this,null,function*(){if(!this.videoUpdateInProgress){this.videoUpdateInProgress=!0;try{e?yield n(this,K).enableTrack(!1,e):yield n(this,K).unmuteTrack()}catch(r){}finally{this.videoUpdateInProgress=!1}}})}disableVideo(){n(this,K).disableTrack()}getVideoDevices(e){return n(this,me).getVideoInputDevices(e)}setVideoDevice(i,a){return l(this,arguments,function*(e,{saveDevicePreference:r}){yield n(this,K).setDevice(e,{saveDevicePreference:r}),e!=null&&e.deviceId&&n(this,ne).getValue("callstats").selectedDevice("VIDEO",e),this.emit("VIDEO_TRACK_CHANGE"),this.emit("DEVICE_CHANGE",{device:e})})}updateVideoConstraints(e){return l(this,null,function*(){yield n(this,K).updateConstraints(e)})}onScreenShareEnded(){this.emit("SCREENSHARE_ENDED")}get screenShareTracks(){return{audio:n(this,vt).audioMediaTrack,video:n(this,vt).videoMediaTrack}}get screenShareEnabled(){return n(this,vt).trackEnabled}enableScreenShare(){return l(this,null,function*(){yield n(this,vt).enableScreenShare()})}disableScreenShare(){return l(this,null,function*(){n(this,vt).disableScreenShare()})}updateScreenshareConstraints(e){return l(this,null,function*(){yield n(this,vt).updateConstraints(e)})}getSpeakerDevices(e){return n(this,me).getAudioOutputDevices(e)}addAudioMiddleware(e){return n(this,Q).addMiddleware(e)}removeAudioMiddleware(e){return n(this,Q).removeMiddleware(e)}removeAllAudioMiddlewares(){return n(this,Q).removeAllMiddlewares()}addVideoMiddleware(e){return n(this,K).addMiddleware(e)}removeVideoMiddleware(e){return n(this,K).removeMiddleware(e)}removeAllVideoMiddlewares(){return n(this,K).removeAllMiddlewares()}setVideoMiddlewareGlobalConfig(e){return n(this,K).setVideoMiddlewareGlobalConfig(e)}destruct(){n(this,Q).disableTrack(),n(this,K).disableTrack(),n(this,K).terminateMiddlewareWebWorker(),n(this,vt).disableScreenShare(),n(this,me).destruct()}onDeviceChange(e,r){return l(this,null,function*(){var a,o;if(this.emit("DEVICE_LIST_UPDATED",e),r||!n(this,ya))return;let i=!1;(a=e==null?void 0:e.added)==null||a.reverse().forEach(c=>l(this,null,function*(){var d;c&&!Qo(c)&&(c.kind==="audioinput"&&((d=this.audioTrack)==null?void 0:d.enabled)===!0?yield this.setAudioDevice(c,{saveDevicePreference:!1}):c.kind==="audiooutput"&&(i=!0,yield this.setSpeakerDevice(c,{saveDevicePreference:!1})))})),i||(o=e==null?void 0:e.removed)==null||o.forEach(c=>l(this,null,function*(){var d;if(c.kind==="audiooutput"&&((d=this.getCurrentDevices().speaker)==null?void 0:d.deviceId)===c.deviceId){const u=yield this.getSpeakerDevices();(u==null?void 0:u.length)>0&&(yield this.setSpeakerDevice(u[0],{saveDevicePreference:!1}))}}))})}removeAllTracks(){this.destruct()}removeAudioTrack(){n(this,Q).disableTrack()}removeVideoTrack(){n(this,K).disableTrack(),n(this,K).terminateMiddlewareWebWorker()}removeDocumentEventListeners(){return l(this,null,function*(){document.removeEventListener("visibilitychange",this.onVisibilityChange)})}}me=new WeakMap,Q=new WeakMap,K=new WeakMap,ps=new WeakMap,vt=new WeakMap,ya=new WeakMap,ne=new WeakMap;pt([S.trace("MediaHandler.setupStreams")],Xe.prototype,"setupStreams",1);pt([S.trace("MediaHandler.enableAudio")],Xe.prototype,"enableAudio",1);pt([S.trace("MediaHandler.disableAudio")],Xe.prototype,"disableAudio",1);pt([S.trace("MediaHandler.setAudioDevice")],Xe.prototype,"setAudioDevice",1);pt([S.trace("MediaHandler.enableVideo")],Xe.prototype,"enableVideo",1);pt([S.trace("MediaHandler.disableVideo")],Xe.prototype,"disableVideo",1);pt([S.trace("MediaHandler.setVideoDevice")],Xe.prototype,"setVideoDevice",1);pt([S.trace("MediaHandler.updateVideoConstraints")],Xe.prototype,"updateVideoConstraints",1);pt([S.trace("MediaHandler.enableScreenShare")],Xe.prototype,"enableScreenShare",1);pt([S.trace("MediaHandler.disableScreenShare")],Xe.prototype,"disableScreenShare",1);pt([S.trace("MediaHandler.updateScreenshareConstraints")],Xe.prototype,"updateScreenshareConstraints",1);pt([S.trace("MediaHandler.destruct")],Xe.prototype,"destruct",1);pt([S.trace("MediaHandler.onDeviceChange")],Xe.prototype,"onDeviceChange",1);function Oo(s,t,e){switch(!0){case Z.isChromiumBased():switch(t){case"NotAllowedError":return e.includes("by system")?"SYSTEM_DENIED":s==="screenshare"?"CANCELED":"DENIED";case"NotReadableError":default:return"COULD_NOT_START"}case Z.isSafari():switch(t){case"NotAllowedError":return"DENIED";default:return"COULD_NOT_START"}case Z.isFirefox():switch(t){case"NotFoundError":case"NotReadableError":return"SYSTEM_DENIED";case"NotAllowedError":return"DENIED";case"AbortError":default:return"COULD_NOT_START"}default:return"COULD_NOT_START"}}const zk=["virtual","emulator","krisp","solstice conference","teams","loom","zoom","manycam","blackhole","displayport","xsplit","wirecast","vMix","elgato","epiphan","voice changer","voicemod","morphvoxx"];function Qo(s){var e,r;const t=(e=s.label)==null?void 0:e.toLowerCase();return((r=Z._bowser)==null?void 0:r.getOSName())==="macOS"&&t.includes("iphone")?!0:zk.some(i=>t==null?void 0:t.includes(i))}function Yk(s,t,e){return l(this,null,function*(){if(!(t!=null&&t.length))return e;const r=s.getValue("logger"),i=new AudioContext,a=yield Promise.all(t==null?void 0:t.map(d=>d(i))),o=i.createMediaStreamSource(new MediaStream([e])),c=i.createMediaStreamDestination();try{let d=o;for(let u=0;u<a.length;u+=1)d.connect(a[u]),d=a[u];d.connect(c)}catch(d){return r.error("getTransformedAudioTrack::middleware_execution_failed",{error:d}),e}return c.stream.getAudioTracks()[0]})}var Ar,va;class Qk{constructor(t){h(this,Ar,void 0);h(this,va,void 0);f(this,va,t)}get logger(){return n(this,va).getValue("logger")}terminateMiddlewareWebWorker(){if(n(this,Ar))try{Vo.clearInterval(n(this,Ar)),f(this,Ar,void 0)}catch(t){this.logger.debug("WorkerTimers::terminateMiddlewareWebWorker::failed")}}getTransformedVideoTrack(t,e,r){return l(this,null,function*(){if(!(t!=null&&t.length))return e;const i=document.createElement("canvas"),a=yield Promise.all(t==null?void 0:t.map(T=>T({canvas:i,WorkerTimers:Vo})));if(r.disablePerFrameCanvasRendering){const v=i.captureStream().getVideoTracks()[0];return Object.defineProperty(v,"originalSettings",{value:e.getSettings()}),v}const o=document.createElement("video"),c=new MediaStream;c.addTrack(e);const d=i.getContext("2d");o.srcObject=c,o.autoplay=!0,this.terminateMiddlewareWebWorker();const u=()=>l(this,null,function*(){if(e.enabled===!1||e.readyState==="ended"){this.terminateMiddlewareWebWorker(),o.remove(),i.remove();return}try{d.drawImage(o,0,0);for(let T=0;T<a.length;T+=1)typeof a[T]=="function"&&(yield a[T](i,d))}catch(T){this.logger.error("getTransformedVideoTrack::middleware_execution_failed",{error:T})}});try{o.play()}catch(T){}o.addEventListener("play",()=>{i.width=o.width||e.getSettings().width,i.height=o.width||e.getSettings().height,f(this,Ar,Vo.setInterval(u,50))},!1);const m=i.captureStream().getVideoTracks()[0];return Object.defineProperty(m,"originalSettings",{value:e.getSettings()}),m})}}Ar=new WeakMap,va=new WeakMap;const dh={gross:{width:{ideal:192},height:{ideal:144}},qvga:{width:{ideal:384},height:{ideal:288}},pvga:{width:{ideal:480},height:{ideal:360}},vga:{width:{ideal:640},height:{ideal:480}},hd:{width:{ideal:1280},height:{ideal:720}},hd_cropped:{width:{ideal:900},height:{ideal:720}},fhd:{width:{ideal:1920},height:{ideal:1080}}},Xk=[[320,[{rid:"q",maxBitrate:25e4,maxFramerate:24,scalabilityMode:"L1T1"}]],[640,[{rid:"q",scaleResolutionDownBy:2,maxBitrate:25e4,maxFramerate:24,scalabilityMode:"L1T1"},{rid:"h",maxBitrate:7e5,maxFramerate:30,scalabilityMode:"L1T1"}]],[1280,[{rid:"q",scaleResolutionDownBy:2,maxBitrate:5e5,maxFramerate:24,scalabilityMode:"L1T1"},{rid:"h",maxBitrate:13e5,maxFramerate:30,scalabilityMode:"L1T1"}]],[1920,[{rid:"q",scaleResolutionDownBy:2,maxBitrate:9e5,maxFramerate:24,scalabilityMode:"L1T1"},{rid:"h",maxBitrate:15e5,maxFramerate:30,scalabilityMode:"L1T1"}]]],Zk=(s,t)=>{var d,u,p;const e=(d=s==null?void 0:s.getValue("overrides"))==null?void 0:d.simulcastConfig;if((u=e==null?void 0:e.encodings)!=null&&u.length)return e.encodings;const r="getSettings"in t&&t.getSettings().width||"getConstraints"in t&&t.getConstraints().width||"originalSettings"in t&&((p=t.originalSettings)==null?void 0:p.width);let i=Xk;s.getValue("flagsmith").hasFeature(q.OVERRIDE_SIMULCAST_DYNAMIC)&&(i=JSON.parse(s.getValue("flagsmith").getValue(q.OVERRIDE_SIMULCAST_DYNAMIC)));const a=i.map(([m])=>m).sort((m,T)=>m-T);let o=Number.MAX_VALUE,c=0;return a.forEach((m,T)=>{Math.abs(m-r)<o&&(o=Math.abs(m-r),c=T)}),i[c][1]};var W=(s=>(s.WEBCAM="webcam",s.WEBCAM_BACKUP="webcam_backup",s.MIC="mic",s.SCREENSHARE_VIDEO="screenshare_video",s.SCREENSHARE_AUDIO="screenshare_audio",s))(W||{});const eb=I.getDefaultHybridPreset(),Si=jt(eb.config.media);function tb(s){var e,r;const t={};return s.audio&&(t.audio={enableStereo:(e=s.audio.enableStereo)!=null?e:!1,enableHighBitrate:(r=s.audio.enableHighBitrate)!=null?r:!1}),t.video=s.video.quality,t}var Ir,Xt;class sb{constructor(t,e){h(this,Ir,void 0);h(this,Xt,void 0);g(this,"getScreenShareConstraints",()=>{var u,p,m,T,v,P,w,C,k,R,D;const t=(u=n(this,Ir))==null?void 0:u.screenshare,e=(m=(p=t==null?void 0:t.width)==null?void 0:p.max)!=null?m:1920,r=(v=(T=t==null?void 0:t.height)==null?void 0:T.max)!=null?v:1080,i=(w=(P=t==null?void 0:t.frameRate)==null?void 0:P.max)!=null?w:5;let a=(k=(C=t==null?void 0:t.frameRate)==null?void 0:C.ideal)!=null?k:5;const o=t==null?void 0:t.displaySurface,c=t==null?void 0:t.selfBrowserSurface;n(this,Xt).getValue("flagsmith").getValue(q.VAL_MIN_FRAMERATE)&&(a=parseInt((R=n(this,Xt).getValue("flagsmith").getValue(q.VAL_MIN_FRAMERATE))==null?void 0:R.toString(),10));let d={width:{max:e},height:{max:r},frameRate:{ideal:a,max:i}};if(n(this,Xt).getValue("flagsmith").hasFeature(q.SCREENSHARE_CONSTRAINTS)){const O=(D=n(this,Xt).getValue("flagsmith").getValue(q.SCREENSHARE_CONSTRAINTS))==null?void 0:D.toString();d=JSON.parse(O)}return o!==void 0&&["monitor","browser","window"].includes(o)&&(d=U(b({},d),{displaySurface:o})),c!==void 0&&(d=U(b({},d),{selfBrowserSurface:c})),{audio:!0,video:d}});g(this,"getAudioConstraints",t=>{var a,o,c,d,u,p,m;const e={},r=(a=n(this,Ir))==null?void 0:a.audio,i=r!=null&&r.enableStereo?2:1;return Z.isFirefox()||Z.isWebKitBased()?(e.audio={deviceId:t,autoGainControl:(o=r==null?void 0:r.autoGainControl)!=null?o:!0,echoCancellation:(c=r==null?void 0:r.echoCancellation)!=null?c:!0,noiseSuppression:(d=r==null?void 0:r.noiseSupression)!=null?d:!0,channelCount:i},e):(e.audio={autoGainControl:(u=r==null?void 0:r.autoGainControl)!=null?u:!0,echoCancellation:(p=r==null?void 0:r.echoCancellation)!=null?p:!0,noiseSuppression:(m=r==null?void 0:r.noiseSupression)!=null?m:!0,channelCount:i},t&&(e.audio.deviceId={exact:t}),e)});g(this,"getVideoConstraints",t=>{var a,o,c,d;const e={},r=(a=n(this,Ir))==null?void 0:a.video;let i=dh.vga;if(typeof r=="string"?i=dh[r]:r!==void 0&&(i.height.ideal=r.height.ideal,i.width.ideal=r.width.ideal),i.frameRate={ideal:(c=(o=i.frameRate)==null?void 0:o.ideal)!=null?c:24},Z.isChromiumBased()&&(i.frameRate.max=30),n(this,Xt).getValue("flagsmith").hasFeature(q.VIDEO_CONSTRAINTS)){const u=(d=n(this,Xt).getValue("flagsmith").getValue(q.VIDEO_CONSTRAINTS))==null?void 0:d.toString();i=JSON.parse(u)}return e.video=i,typeof e.video=="boolean"||(t?e.video.deviceId={exact:t}:e.video.facingMode="user"),e});f(this,Xt,t),f(this,Ir,e)}getUpdatedVideoConstraints(t){return t}}Ir=new WeakMap,Xt=new WeakMap;class kd extends Error{constructor(e,r,i){super(r);g(this,"constraints");g(this,"name");this.name=e,this.constraints=i}}class rb{constructor(){g(this,"permissions");this.permissions={audio:"NOT_REQUESTED",video:"NOT_REQUESTED",screenshare:"NOT_REQUESTED"}}getAudioInputDevices(t){return l(this,null,function*(){let e=t;return t||(e=yield this.getAvailableDevices()),e.filter(r=>r.kind==="audioinput")})}getVideoInputDevices(t){return l(this,null,function*(){let e=t;return t||(e=yield this.getAvailableDevices()),e.filter(r=>r.kind==="videoinput")})}getAudioOutputDevices(t){return l(this,null,function*(){let e=t;return t||(e=yield this.getAvailableDevices()),e.filter(r=>r.kind==="audiooutput")})}}var ib=Object.defineProperty,nb=Object.getOwnPropertyDescriptor,zt=(s,t,e,r)=>{for(var i=r>1?void 0:r?nb(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&ib(t,e,i),i},Xi,St,le,Mh;let lt=(Mh=class extends rb{constructor(t,e){super();h(this,Xi,void 0);h(this,St,void 0);h(this,le,void 0);f(this,le,t),f(this,St,new sb(t,e)),f(this,Xi,new AbortController)}get telemetry(){return n(this,le).getValue("telemetry")}get logger(){return n(this,le).getValue("logger")}get constraintsBuilder(){return n(this,St)}destruct(){return l(this,null,function*(){var t;(t=n(this,Xi))==null||t.abort()})}handlePermissionErrors(t,e){const r=Oo(t,e.name,e.message);return this.permissions[t]=r,n(this,le).getValue("peerSessionStore").emit(E.MEDIA_PERMISSION_ERROR,{message:r,constraints:e.constraints,kind:t}),r}getAudioAndVideoTrack(t,e){return l(this,null,function*(){var r,i,a,o;try{const c=yield this.getAudioInputDevices(),d=yield this.getVideoInputDevices(),u=!!(c!=null&&c.find(R=>R.deviceId===t));let p;t&&u?p=t:c&&((r=c[0])!=null&&r.deviceId)&&(p=(i=c[0])==null?void 0:i.deviceId);const m=!!(d!=null&&d.find(R=>R.deviceId===e));let T;e&&m?T=e:d&&((a=d[0])!=null&&a.deviceId)&&(T=(o=d[0])==null?void 0:o.deviceId);const v={audio:n(this,St).getAudioConstraints(p).audio,video:n(this,St).getVideoConstraints(T).video};this.logger.info("getUserMediaWithoutTimeout::requesting_user_media",{constraints:JSON.stringify(v)});const P=yield navigator.mediaDevices.getUserMedia(v);this.logger.info("getUserMediaWithoutTimeout::received_user_media",{constraints:JSON.stringify(v)});const w=P.getAudioTracks()[0];let C=P.getVideoTracks()[0];if(this.permissions.audio="ACCEPTED",this.permissions.video="ACCEPTED",n(this,le).getValue("flagsmith").hasFeature(q.OBS_QUALITY)&&C.label.includes("OBS Virtual")){const D=(yield this.getVideoInputDevices()).find(O=>O.label.includes("OBS Virtual"));C=yield this.getVideoTrack(D.deviceId)}return n(this,le).getValue("peerSessionStore").emit(E.MEDIA_PERMISSION_UPDATE,{message:this.permissions.audio,kind:"audio"}),n(this,le).getValue("peerSessionStore").emit(E.MEDIA_PERMISSION_UPDATE,{message:this.permissions.video,kind:"video"}),{audioTrack:w,videoTrack:C}}catch(c){throw this.logger.error("WebMediaInterface.getAudioAndVideoTrack",{error:c}),new _("Couldnt fetch audio and video track","1605")}})}getAudioTrack(t,e){return l(this,null,function*(){var c,d;let r=yield this.getAudioInputDevices();if(!(r!=null&&r.length))throw this.permissions.audio="NO_DEVICES_AVAILABLE",n(this,le).getValue("peerSessionStore").emit(E.MEDIA_PERMISSION_UPDATE,{message:this.permissions.audio,kind:"audio"}),new _("No audio devices available","1606");const i=!!(r!=null&&r.find(u=>u.deviceId===e));let a;e&&i?a=e:(c=r[0])!=null&&c.deviceId&&(a=(d=r[0])==null?void 0:d.deviceId);const o=u=>l(this,null,function*(){let p;try{r=r.filter(T=>T.deviceId!==u),p=n(this,St).getAudioConstraints(u),this.logger.info("getUserMediaWithoutTimeout::requesting_user_media",{constraints:JSON.stringify(p)});const[m]=(yield navigator.mediaDevices.getUserMedia(p)).getAudioTracks();return this.logger.info("getUserMediaWithoutTimeout::received_user_media",{constraints:JSON.stringify(p)}),m}catch(m){const T=Oo("audio",m.name,m.message),v=new kd(m.name,m.message,p);if(T==="COULD_NOT_START"){const P=r.shift();if(!P)throw v;this.logger.info("getAudioTrack::gum_failed",{constraints:JSON.stringify(p),error:m});const w=n(this,St).getAudioConstraints(P.deviceId);return this.logger.info("getAudioTrack::retrying_gum_for_next_device",{constraints:JSON.stringify(w)}),o(P.deviceId)}throw v}});try{const u=yield o(a);return u.enabled=!t,this.permissions.audio!=="ACCEPTED"&&(this.permissions.audio="ACCEPTED",n(this,le).getValue("peerSessionStore").emit(E.MEDIA_PERMISSION_UPDATE,{message:this.permissions.audio,kind:"audio"})),u}catch(u){throw u.constraints&&this.handlePermissionErrors("audio",u),new _(u.message,"1601")}})}getVideoTrack(t){return l(this,null,function*(){var u,p,m;const e=n(this,le).getValue("flagsmith").hasFeature(q.OBS_QUALITY),r=(u=yield this.getCurrentDeviceLabel(t))==null?void 0:u.includes("OBS Virtual"),i=e&&r,a=yield this.getVideoInputDevices();if(!(a!=null&&a.length))throw this.permissions.video="NO_DEVICES_AVAILABLE",n(this,le).getValue("peerSessionStore").emit(E.MEDIA_PERMISSION_UPDATE,{message:this.permissions.video,kind:"video"}),new _("No video devices available","1607");const o=!!(a!=null&&a.find(T=>T.deviceId===t));let c;t&&o?c=t:(p=a[0])!=null&&p.deviceId&&(c=(m=a[0])==null?void 0:m.deviceId);const d=T=>l(this,null,function*(){try{let v=T;const{video:P}=v;i&&typeof P!="boolean"&&(v={video:{deviceId:P.deviceId}}),this.logger.info("getUserMediaWithoutTimeout::requesting_user_media",{constraints:JSON.stringify(v)});const[w]=(yield navigator.mediaDevices.getUserMedia(v)).getVideoTracks();if(i&&typeof P!="boolean"&&typeof P.width=="object"){const{width:C,height:k}=w.getSettings(),{ideal:R}=P.width;w.applyConstraints({width:{ideal:R},height:{ideal:Math.floor(k*R/C)},frameRate:P.frameRate})}return this.logger.info("getUserMediaWithoutTimeout::received_user_media",{constraints:JSON.stringify(v)}),w}catch(v){const P=Oo("video",v.name,v.message),w=new kd(v.name,v.message,T);if(P==="COULD_NOT_START"){const C=a.shift();if(!C)throw w;this.logger.info("getVideoTrack::gum_failed",{constraints:JSON.stringify(T),error:v});const k=n(this,St).getVideoConstraints(C.deviceId);return this.logger.info("getVideoTrack::retrying_gum_for_next_device",{constraints:JSON.stringify(k)}),d({video:k.video})}throw w}});try{const T=n(this,St).getVideoConstraints(c),v=yield d(T);return this.permissions.video!=="ACCEPTED"&&(this.permissions.video="ACCEPTED",n(this,le).getValue("peerSessionStore").emit(E.MEDIA_PERMISSION_UPDATE,{message:this.permissions.video,kind:"video"})),v}catch(T){throw T.constraints&&this.handlePermissionErrors("video",T),new _(T.message,"1602")}})}getScreenShareTracks(){return l(this,null,function*(){const t=e=>l(this,null,function*(){try{this.logger.info("getDisplayMediaWithoutTimeout::requesting_display_media",{constraints:JSON.stringify(e)}),n(this,le).getValue("callstats").screenShareRequested();const r=yield navigator.mediaDevices.getDisplayMedia(e);return this.logger.info("getDisplayMediaWithoutTimeout::received_display_media",{constraints:JSON.stringify(e)}),r}catch(r){const i=Oo("video",r.name,r.message),a=new kd(r.name,r.message,e),o={video:!0};if(TS(e,o)||!n(this,le).getValue("flagsmith").hasFeature(q.SCREEENSHARE_CONSTRAINTS_RETRY))throw a;if(i==="COULD_NOT_START")return t(o);throw a}});try{const e=n(this,St).getScreenShareConstraints(),r=yield t(e);return this.permissions.screenshare!=="ACCEPTED"&&(this.permissions.screenshare="ACCEPTED",n(this,le).getValue("peerSessionStore").emit(E.MEDIA_PERMISSION_UPDATE,{message:this.permissions.screenshare,kind:"screenshare"})),{audioTrack:r.getAudioTracks()[0],videoTrack:r.getVideoTracks()[0]}}catch(e){throw e.constraints&&this.handlePermissionErrors("screenshare",e),new _(e.message,"1612")}})}getCurrentDeviceLabel(t){return l(this,null,function*(){const e=yield this.getDevice(t||"default");return e==null?void 0:e.label})}enumerateDevicesWithExternalFirst(){return l(this,null,function*(){const t=yield navigator.mediaDevices.enumerateDevices(),e=i=>{var o;const a=((o=i.label)==null?void 0:o.toLowerCase())||"";return Qo(i)?4:a.includes("airpods")||a.includes("airdopes")||a.includes("bluetooth")||a.includes("wireless")||a.includes("headphones")||a.includes("headset")||a.includes("earbuds")||a.includes("usb")||a.includes("external")?0:i.deviceId==="default"||a.includes("default")?1:a.includes("built-in")||a.includes("internal")?2:3},r=i=>{var o;if(i.kind!=="videoinput")return!1;const a=((o=i.label)==null?void 0:o.toLowerCase())||"";return a.includes("front")||a.includes("user")||a.includes("selfie")?!0:!(a.includes("back")||a.includes("rear")||a.includes("environment"))};return t.sort((i,a)=>{var p,m;const o=e(i),c=e(a);if(o!==c)return o-c;const d=i.deviceId==="default"||((p=i.label)==null?void 0:p.toLowerCase().includes("default")),u=a.deviceId==="default"||((m=a.label)==null?void 0:m.toLowerCase().includes("default"));if(d&&!u)return-1;if(!d&&u)return 1;if(i.kind==="videoinput"&&a.kind==="videoinput"){const T=r(i),v=r(a);if(T&&!v)return-1;if(!T&&v)return 1}return 0})})}getAvailableDevices(){return l(this,null,function*(){try{return(yield this.enumerateDevicesWithExternalFirst())||[]}catch(t){return this.logger.error("enumerate_devices_failed",{error:t}),[]}})}getAvailableDevicesByKind(t){return l(this,null,function*(){try{return(yield this.enumerateDevicesWithExternalFirst()).filter(({kind:e})=>t===e)}catch(e){throw this.logger.error("enumerate_devices_failed",{error:e}),new _("Failed to get available devices by kind","1609")}})}getDevice(t){return l(this,null,function*(){try{return(yield this.enumerateDevicesWithExternalFirst()).filter(r=>r.deviceId===t)[0]}catch(e){throw this.logger.error("enumerate_devices_failed",{error:e}),new _("Failed to get device","1609")}})}onDeviceChange(t){return l(this,null,function*(){if(Z.supportsDeviceChangeEvent()){let e=yield this.getAvailableDevices();navigator.mediaDevices.addEventListener("devicechange",r=>l(this,null,function*(){var u,p;const i=m=>`${m.kind}-${m.label}-${m.deviceId}-${m.groupId}`,a=new Set(e.map(m=>i(m))),o=yield this.getAvailableDevices(),c=new Set(o.map(m=>i(m))),d={added:o.filter(m=>!a.has(i(m))),removed:e.filter(m=>!c.has(i(m))),devices:o};if(e=o,(u=d.added)!=null&&u.length||(p=d.removed)!=null&&p.length){this.logger.info("repopulated_full_device_list",{devices:JSON.stringify(o)});const m=[...d.added,...d.removed];m.some(T=>T.kind==="audioinput")&&n(this,le).getValue("callstats").devices("AUDIO",o==null?void 0:o.filter(T=>T.kind==="audioinput")),m.some(T=>T.kind==="videoinput")&&n(this,le).getValue("callstats").devices("VIDEO",o==null?void 0:o.filter(T=>T.kind==="videoinput")),m.some(T=>T.kind==="audiooutput")&&n(this,le).getValue("callstats").devices("SPEAKER",o==null?void 0:o.filter(T=>T.kind==="audiooutput")),t(r,d,!1)}}),{signal:n(this,Xi).signal})}})}},Xi=new WeakMap,St=new WeakMap,le=new WeakMap,Mh);zt([S.trace("WebMediaInterface.destruct")],lt.prototype,"destruct",1);zt([S.trace("WebMediaInterface.handlePermissionErrors")],lt.prototype,"handlePermissionErrors",1);zt([S.trace("WebMediaInterface.getAudioAndVideoTrack")],lt.prototype,"getAudioAndVideoTrack",1);zt([S.trace("WebMediaInterface.getAudioTrack")],lt.prototype,"getAudioTrack",1);zt([S.trace("WebMediaInterface.getVideoTrack")],lt.prototype,"getVideoTrack",1);zt([S.trace("WebMediaInterface.getScreenShareTracks")],lt.prototype,"getScreenShareTracks",1);zt([S.trace("WebMediaInterface.getAvailableDevices")],lt.prototype,"getAvailableDevices",1);zt([S.trace("WebMediaInterface.getAvailableDevicesByKind")],lt.prototype,"getAvailableDevicesByKind",1);zt([S.trace("WebMediaInterface.getDevice")],lt.prototype,"getDevice",1);zt([S.trace("WebMediaInterface.onDeviceChange")],lt.prototype,"onDeviceChange",1);lt=zt([Ne("1600")],lt);const sg=lt,ui={setItem:(s,t,e)=>{try{localStorage.setItem(s,t)}catch(r){e==null||e.error("LocalStorage::setItem::crashed",{error:r,localStorage:{key:s,value:t}})}},getItem:(s,t)=>{try{return localStorage.getItem(s)}catch(e){t==null||t.error("LocalStorage::getItem::crashed",{error:e,localStorage:{key:s}})}return null}},ab=(s=0)=>new Promise(t=>setTimeout(t,s)),ob=(s,t,e)=>{const r=typeof e=="number"?e:250,i=s.createMediaStreamSource(t),a=s.createAnalyser();a.fftSize=2048,i.connect(a);const o=new Uint8Array(a.fftSize);let c=!1;setTimeout(()=>{c=!0},r);function d(){return c?Promise.resolve(!0):(a.getByteTimeDomainData(o),o.some(u=>u!==128&&u!==0)?Promise.resolve(!1):ab().then(d))}return d().then(u=>(i.disconnect(),u),u=>{throw i.disconnect(),u})},cb=typeof AudioContext!="undefined"?AudioContext:null;class Vl{constructor(t){g(this,"_AudioContext");g(this,"audioContext");g(this,"_audioContextRefContainers");const e=b({AudioContext:cb},t);Object.defineProperties(this,{_AudioContext:{value:e.AudioContext},audioContext:{value:null,writable:!0},_audioContextRefContainers:{value:new Set},AudioContextProvider:{enumerable:!0,value:Vl}})}getOrCreate(t){if(!this._audioContextRefContainers.has(t)&&(this._audioContextRefContainers.add(t),this._AudioContext&&!this.audioContext))try{this.audioContext=new this._AudioContext}catch(e){}return this.audioContext}release(t){this._audioContextRefContainers.has(t)&&(this._audioContextRefContainers.delete(t),!this._audioContextRefContainers.size&&this.audioContext&&(this.audioContext.close(),this.audioContext=null))}}const lh=new Vl,db=3,lb=250;function ub(s){const t={},e=lh.getOrCreate(t);let r=db;function i(){return r-=1,ob(e,s.srcObject,lb).then(a=>a?r>0?i():!0:!1).catch(()=>!0)}return i().finally(()=>{lh.release(t)})}function uh(s,t){return l(this,null,function*(){const e=new Audio,r=new MediaStream;r.addTrack(t),e.srcObject=r;let i=!1;try{const a=e.play();a&&(yield a),i=yield ub(e),i&&s.info("checkIfAudioTrackIsSilent::silence_detected")}catch(a){s.error("checkIfAudioTrackIsSilent::failed_to_detect_silence",{error:a})}finally{e.pause(),e.remove()}return i})}var hb=Object.defineProperty,pb=Object.getOwnPropertyDescriptor,rg=(s,t,e,r)=>{for(var i=r>1?void 0:r?pb(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&hb(t,e,i),i};let Xo=class extends Vn{constructor(t,e,r,i){var o;const a=t.getValue("logger");super(a);g(this,"constructorName",this.constructor.name);g(this,"userSelectedDevice");g(this,"mediaInterface");g(this,"isNonPreferredDevice");g(this,"_mediaTrack");g(this,"transformedMediaTrack");g(this,"middlewares",[]);g(this,"currentDevice");g(this,"userPreferredDeviceKey",`Realtimekit::${this.constructorName}::UserDeviceID`);g(this,"setUserPreferredDevice",t=>ui.setItem(this.userPreferredDeviceKey,t,this.logger));g(this,"getUserPreferredDevice",()=>ui.getItem(this.userPreferredDeviceKey,this.logger));g(this,"isCustomTrack",!1);g(this,"context");this.context=t,this.mediaInterface=e,r&&this.setMediaTrack(r),this.userSelectedDevice=(o=this.getUserPreferredDevice())!=null?o:void 0,this.isNonPreferredDevice=i,this.onTrackEnded=this.onTrackEnded.bind(this),this.onTrackMuted=this.onTrackMuted.bind(this)}get telemetry(){return this.context.getValue("telemetry")}disableTrack(){var t,e;this.removeMediaTrackListeners(),this.isCustomTrack||(t=this._mediaTrack)==null||t.stop(),this._mediaTrack=void 0,(e=this.transformedMediaTrack)==null||e.stop(),this.transformedMediaTrack=void 0}get mediaTrack(){return this._mediaTrack}setMediaTrack(t,e=!1){return l(this,null,function*(){const r=i=>{this.logger.error(`${this.constructorName}.setMediaTrack.error`,{error:i})};try{this.disableTrack()}catch(i){r(i)}this._mediaTrack=yield this.conditionallyChangeTrack(t,e),yield this.setTransformedTrack();try{this.addMediaTrackListeners(),yield this.setCurrentDevice()}catch(i){r(i)}})}get trackEnabled(){return!!this.mediaTrack&&this.mediaTrack.readyState==="live"&&this.mediaTrack.enabled}muteTrack(){if(!this.mediaTrack){this.logger.warn("BaseMediaHandler.muteTrack Tried muting with no track present");return}this.transformedMediaTrack&&(this.transformedMediaTrack.enabled=!1),this.mediaTrack.enabled=!1}unmuteTrack(){return l(this,null,function*(){try{this.mediaTrack?this.mediaTrack.enabled=!0:yield this.enableTrack(!1)}catch(t){throw this.logger.error(`${this.constructorName}.unmuteTrack.error`,{error:t}),this.disableTrack(),new _("Failed to unmute track","1611")}})}getCurrentDeviceId(){var e;const{kind:t}=this.mediaTrack;switch(t){case"audio":{const{deviceId:r}=this.mediaTrack.getSettings();if(r)return r;const i=this.mediaTrack.getConstraints();return this.userSelectedDevice?(i&&typeof i.deviceId=="object"&&"exact"in i.deviceId?i.deviceId.exact:i.deviceId)||((e=i==null?void 0:i.advanced)==null?void 0:e[0].deviceId)||"default":this.mediaTrack.getSettings().deviceId}default:return this.mediaTrack.getSettings().deviceId}}setCurrentDevice(){return l(this,null,function*(){var e;if(!this.mediaTrack){this.currentDevice=void 0;return}const t=this.getCurrentDeviceId();((e=this.currentDevice)==null?void 0:e.deviceId)!==t&&(this.currentDevice=yield this.mediaInterface.getDevice(t))})}setDevice(r,i){return l(this,arguments,function*(t,{saveDevicePreference:e}){if(!t)throw this.logger.warn(`${this.constructorName}.setDevice No device received`),new _("No device received!","1603");this.userSelectedDevice=t.deviceId,e&&this.setUserPreferredDevice(t.deviceId),yield this.onSetDevice(t)})}addMiddleware(t){return l(this,null,function*(){if(Z.isWebKitBased()&&!I.globalFlagsmith.hasFeature(q.ALLOW_SAFARI_MEDIA_MIDDLEWARES))return{success:!1,message:"Middlewares are not supported in this WebKit engine based browser."};if(this.middlewares.includes(t))return{success:!1,message:"This middleware has been applied, already. Skipping."};try{return this.middlewares.push(t),this.trackEnabled&&(yield this.setTransformedTrack()),{success:!0,message:"Successfully added the middleware."}}catch(e){return this.logger.error("While adding middleware",{error:e}),this.removeMiddleware(t),{success:!1,message:e==null?void 0:e.message}}})}removeMiddleware(t){return l(this,null,function*(){const e=this.middlewares.indexOf(t,0);if(e>-1)try{return this.middlewares.splice(e,1),yield this.setTransformedTrack(!0),{success:!0,message:"Successfully removed the middleware."}}catch(r){return this.logger.error("While removing middleware",{error:r}),{success:!1,message:r==null?void 0:r.message}}return{success:!1,message:"No such middleware was found. Skipping."}})}removeAllMiddlewares(){return l(this,null,function*(){var t;if((t=this.middlewares)!=null&&t.length)try{return this.middlewares=[],yield this.setTransformedTrack(!0),{success:!0,message:"Successfully removed all the middlewares."}}catch(e){return this.logger.error("While removing all the middlewares",{error:e}),{success:!1,message:e==null?void 0:e.message}}return{success:!1,message:"No middlewares were found. Skipping."}})}addMediaTrackListeners(){var t,e,r;this.mediaTrack&&(this.logger.info(`${this.constructorName}.addMediaTrackListeners for deviceId ${(e=(t=this.mediaTrack)==null?void 0:t.getSettings())==null?void 0:e.deviceId} of type ${(r=this.mediaTrack)==null?void 0:r.kind}`),this.mediaTrack.addEventListener("ended",this.onTrackEnded),this.mediaTrack.addEventListener("mute",this.onTrackMuted))}removeMediaTrackListeners(){var t,e,r;this.mediaTrack&&(this.logger.info(`${this.constructorName}.removeMediaTrackListeners for deviceId ${(e=(t=this.mediaTrack)==null?void 0:t.getSettings())==null?void 0:e.deviceId} of type ${(r=this.mediaTrack)==null?void 0:r.kind}`),this.logger.info(`${this.constructorName}.removeMediaTrackListeners`),this.mediaTrack.removeEventListener("ended",this.onTrackEnded),this.mediaTrack.removeEventListener("mute",this.onTrackMuted))}};rg([S.trace("BaseMediaHandler.unmuteTrack")],Xo.prototype,"unmuteTrack",1);Xo=rg([Ne("1600")],Xo);const ig=Xo;var gb=Object.defineProperty,mb=Object.getOwnPropertyDescriptor,xl=(s,t,e,r)=>{for(var i=r>1?void 0:r?mb(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&gb(t,e,i),i};const bd="[Realtimekit]nonSilentDeviceLabels";class id extends ig{onSetDevice(t){return l(this,null,function*(){if(!t)throw this.logger.warn("AudioMediaHandler.setDevice No device received"),new _("No device received!","1603");if(t.kind!=="audioinput")throw this.logger.warn("AudioMediaHandler.setDevice Received non audio device"),new _("Non audio device received while setting device!","1603");try{const e=this.trackEnabled;this.disableTrack(),yield this.setMediaTrack(yield this.mediaInterface.getAudioTrack(!e,this.userSelectedDevice))}catch(e){throw this.logger.error("AudioMediaHandler.setDevice.error",{error:e}),this.disableTrack(),new _(e.message,"1604")}})}enableTrack(t,e){return l(this,null,function*(){if(this.trackEnabled){this.logger.warn("AudioMediaHandler.enableTrack Track already enabled!");return}if(e){this.isCustomTrack=!0,yield this.setMediaTrack(e,!0);return}this.isCustomTrack=!1;const r=yield this.mediaInterface.getAudioTrack(t,this.userSelectedDevice);yield this.setMediaTrack(r)})}setTransformedTrack(t){return l(this,null,function*(){var e;if(!t&&!((e=this.middlewares)!=null&&e.length)){this.transformedMediaTrack=this.mediaTrack;return}try{this.transformedMediaTrack=yield Yk(this.context,this.middlewares,this.mediaTrack),this.emit("trackChanged")}catch(r){this.logger.error("AudioMediaHandler.setTransformedTrack",{error:r}),this.transformedMediaTrack=this.mediaTrack}})}onTrackEnded(){return l(this,null,function*(){this.logger.info("AudioMediaHandler.TrackEnded"),this.emit("trackEnded");const t=this.mediaTrack.enabled;this.disableTrack(),yield this.enableTrack(!t),yield this.setTransformedTrack(),this.emit("trackChanged")})}onTrackMuted(){this.logger.info("AudioMediaHandler.TrackMuted"),this.emit("trackMuted")}conditionallyChangeTrack(t,e=!1){return l(this,null,function*(){var d;if(!t||this.userSelectedDevice||e)return t;let r=t;const i=yield this.mediaInterface.getAudioInputDevices(),a=this.isNonPreferredDevice?i.filter(u=>u&&!this.isNonPreferredDevice(u)):i;if(!(a!=null&&a.length))return r;a.find(u=>u.deviceId===t.getSettings().deviceId)||(r.stop(),this.logger.info("localmediahandler::setupstreams::found_audio_non_preferred"),r=yield this.mediaInterface.getAudioTrack(!1,a[0].deviceId));const o=JSON.parse(ui.getItem(bd,this.logger));if(o!=null&&o.devices.some(u=>u.label===r.label))return r;if(!(yield uh(this.logger,r))){const u=(d=o==null?void 0:o.devices.concat({label:r.label}))!=null?d:[{label:r.label}];return ui.setItem(bd,JSON.stringify({devices:u}),this.logger),r}this.logger.info("AudioMediaHandler.conditionallyChangeTrack.DetectedSilentTrack");const c=r.getSettings().deviceId;return a.filter(u=>u.deviceId!==c).some(u=>l(this,null,function*(){var p;if(r=yield this.mediaInterface.getAudioTrack(!1,u.deviceId),!(yield uh(this.logger,r))){const m=(p=o==null?void 0:o.devices.concat({label:r.label}))!=null?p:[{label:r.label}];return ui.setItem(bd,JSON.stringify({devices:m}),this.logger),this.logger.info("AudioMediaHandler.conditionallyChangeTrack.SuccesfullyChangedTrack"),!0}return this.logger.info("AudioMediaHandler.conditionallyChangeTrack.AnotherSilentTrackFound"),!1})),r})}}xl([S.trace("AudioMediaHandler.setTransformedTrack")],id.prototype,"setTransformedTrack",1);xl([S.trace("AudioMediaHandler.onTrackEnded")],id.prototype,"onTrackEnded",1);xl([S.trace("AudioMediaHandler.conditionallyChangeTrack")],id.prototype,"conditionallyChangeTrack",1);const fb=id;var Or;class Tb{constructor(t,e){h(this,Or,void 0);g(this,"currentDevice");g(this,"userPreferredDeviceKey","Realtimekit::speaker::UserDeviceID");g(this,"logger");g(this,"setUserPreferredDevice",t=>ui.setItem(this.userPreferredDeviceKey,t,this.logger));g(this,"getUserPreferredDevice",()=>ui.getItem(this.userPreferredDeviceKey,this.logger));f(this,Or,e),this.logger=t.getValue("logger")}setPreferredSpeaker(){return l(this,null,function*(){const t=this.getUserPreferredDevice(),e=yield n(this,Or).getAudioOutputDevices(),r=e==null?void 0:e.find(i=>i.deviceId===t);yield this.setupSpeaker(r,{saveDevicePreference:!1})})}setupSpeaker(r,i){return l(this,arguments,function*(t,{saveDevicePreference:e}){var c,d;if(!(n(this,Or)instanceof sg))return;let a=t;if(t||([a]=(yield n(this,Or).getAvailableDevicesByKind("audiooutput")).filter(p=>!Qo(p))),!a)throw new _("No speaker found","1608");if(((c=this.currentDevice)==null?void 0:c.deviceId)===a.deviceId)return;e&&this.setUserPreferredDevice(a.deviceId),this.currentDevice=a;const o=document.querySelectorAll("audio");(d=o[0])!=null&&d.setSinkId&&o.forEach(u=>l(this,null,function*(){if(typeof u.sinkId!="undefined"&&this.currentDevice.deviceId&&u.sinkId!==this.currentDevice.deviceId)try{yield u.setSinkId(this.currentDevice.deviceId)}catch(p){}}))})}}Or=new WeakMap;const yb=Tb;var Sa;class vb extends Vn{constructor(e,r){const i=e.getValue("logger");super(i);g(this,"mediaInterface");g(this,"audioMediaTrack");g(this,"videoMediaTrack");h(this,Sa,void 0);f(this,Sa,e),this.mediaInterface=r}get trackEnabled(){return!!this.videoMediaTrack}enableScreenShare(){return l(this,null,function*(){var e,r;try{const{audioTrack:i,videoTrack:a}=yield this.mediaInterface.getScreenShareTracks();if(this.audioMediaTrack=i,this.videoMediaTrack=a,this.addMediaTrackListeners(),((r=(e=this.mediaInterface)==null?void 0:e.permissions)==null?void 0:r.screenshare)==="ACCEPTED")return;this.mediaInterface.permissions&&(this.mediaInterface.permissions.screenshare="ACCEPTED",n(this,Sa).getValue("peerSessionStore").emit(E.MEDIA_PERMISSION_UPDATE,{message:this.mediaInterface.permissions.screenshare,kind:"screenshare"}))}catch(i){}})}disableScreenShare(){var e,r;this.removeMediaTrackListeners(),(e=this.audioMediaTrack)==null||e.stop(),(r=this.videoMediaTrack)==null||r.stop(),this.videoMediaTrack=void 0,this.audioMediaTrack=void 0}updateConstraints(e){return l(this,null,function*(){if(!this.videoMediaTrack)throw new _("No media track enabled!","1610");const r=this.mediaInterface;if(!r.constraintsBuilder)throw new _("update constraints not supported for non web clients","1100",this.logger);try{this.videoMediaTrack.applyConstraints(r.constraintsBuilder.getUpdatedVideoConstraints(e)),this.addMediaTrackListeners()}catch(i){this.logger.error("ScreenShareHandler.updateConstraints.error",{error:i})}})}addMediaTrackListeners(){var e,r;(e=this.videoMediaTrack)==null||e.addEventListener("ended",this.onTrackEnded.bind(this)),Z.isWebKitBased()&&((r=this.videoMediaTrack)==null||r.addEventListener("mute",this.onTrackEnded.bind(this)))}removeMediaTrackListeners(){var e,r;(e=this.videoMediaTrack)==null||e.removeEventListener("ended",this.onTrackEnded),(r=this.videoMediaTrack)==null||r.removeEventListener("mute",this.onTrackEnded)}onTrackEnded(){this.emit("trackEnded")}}Sa=new WeakMap;const Sb=vb;var Pb=Object.defineProperty,Eb=Object.getOwnPropertyDescriptor,nd=(s,t,e,r)=>{for(var i=r>1?void 0:r?Eb(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Pb(t,e,i),i},Zi,Pa;class vo extends ig{constructor(e,r,i,a){super(e,r,i,a);h(this,Zi,void 0);h(this,Pa,{disablePerFrameCanvasRendering:!1});f(this,Zi,new Qk(e))}onSetDevice(e){return l(this,null,function*(){if(!e)throw this.logger.warn("VideoMediaHandler.setDevice No device received"),new _("No device received!","1603");if(e.kind!=="videoinput")throw this.logger.warn("VideoMediaHandler.setDevice Received non video device",{devices:[e]}),new _("Non video device received while setting video device!","1603");if(!(this.mediaTrack&&this.mediaTrack.enabled)){this.logger.warn("VideoMediaHandler.setDevice Tried switching device with video disabled",{devices:[e]}),this.currentDevice=e;return}try{this.disableTrack(),yield this.setMediaTrack(yield this.mediaInterface.getVideoTrack(this.userSelectedDevice))}catch(r){throw this.logger.error("VideoMediaHandler.setDevice.error",{error:r}),this.disableTrack(),new _("Failed to change device","1600",this.logger)}})}enableTrack(e,r){return l(this,null,function*(){if(this.trackEnabled){this.logger.warn("VideoMediaHandler.enableTrack Track already enabled!");return}if(r){this.isCustomTrack=!0,yield this.setMediaTrack(r,!0);return}this.isCustomTrack=!1;const i=yield this.mediaInterface.getVideoTrack(this.userSelectedDevice);yield this.setMediaTrack(i)})}setTransformedTrack(e){return l(this,null,function*(){var r;if(!e&&!((r=this.middlewares)!=null&&r.length)){this.transformedMediaTrack=this.mediaTrack;return}try{this.transformedMediaTrack=yield n(this,Zi).getTransformedVideoTrack(this.middlewares,this.mediaTrack,n(this,Pa)),this.emit("trackChanged")}catch(i){this.logger.error("VideoMediaHandler.setTransformedTrack",{error:i}),this.transformedMediaTrack=this.mediaTrack}})}setVideoMiddlewareGlobalConfig(e){return l(this,null,function*(){f(this,Pa,e)})}updateConstraints(e){return l(this,null,function*(){if(!this._mediaTrack)throw new _("No media track enabled!","1610");const r=this.mediaInterface;if(!r.constraintsBuilder)throw new _("update constraints not supported for non web clients","1100",this.logger);try{this._mediaTrack.applyConstraints(r.constraintsBuilder.getUpdatedVideoConstraints(e)),yield this.setTransformedTrack(),this.addMediaTrackListeners(),yield this.setCurrentDevice()}catch(i){this.logger.error("VideoMediaHandler.updateConstraints.error",{error:i})}})}terminateMiddlewareWebWorker(){n(this,Zi).terminateMiddlewareWebWorker()}onTrackEnded(){return l(this,null,function*(){this.logger.info("VideoMediaHandler.TrackEnded"),this.disableTrack(),this.emit("trackEnded")})}onTrackMuted(){this.logger.info("VideoMediaHandler.TrackMuted"),this.emit("trackMuted")}conditionallyChangeTrack(e,r=!1){return l(this,null,function*(){if(!e||this.userSelectedDevice||r)return e;let i=e;const a=yield this.mediaInterface.getVideoInputDevices(),o=this.isNonPreferredDevice?a.filter(c=>!this.isNonPreferredDevice(c)):a;return!(o!=null&&o.length)||window.FAST_RTK||o.find(c=>c.deviceId===e.getSettings().deviceId)||(i.stop(),this.logger.info("localmediahandler::setupstreams::found_video_non_preferred"),i=yield this.mediaInterface.getVideoTrack(o[0].deviceId)),i})}}Zi=new WeakMap,Pa=new WeakMap;nd([S.trace("VideoMediaHandler.setTransformedTrack")],vo.prototype,"setTransformedTrack",1);nd([S.trace("VideoMediaHandler.setVideoMiddlewareGlobalConfig")],vo.prototype,"setVideoMiddlewareGlobalConfig",1);nd([S.trace("VideoMediaHandler.onTrackEnded")],vo.prototype,"onTrackEnded",1);nd([S.trace("VideoMediaHandler.conditionallyChangeTrack")],vo.prototype,"conditionallyChangeTrack",1);const wb=vo,hh=jt(I.getDefaultPresetV2());var Ge,Dr,Ea,en;const Ri=class{constructor(t){h(this,Ge,void 0);h(this,Dr,void 0);h(this,Ea,void 0);h(this,en,void 0);if(!t)throw new _("Could not load preset.","0904");f(this,Ge,t.config),f(this,Ea,t.name),f(this,Dr,t.ui||jt(I.getDefaultPresetV2().ui)),f(this,en,t.permissions.plugins.config)}static fromResponse(t){return new Ri(t)}static default(){return new Ri(hh)}static init(t,e=!0){return!t||e?new Ri(hh):new Ri(t)}get setupScreen(){return{isEnabled:!0}}get waitingRoom(){return{isEnabled:!0}}get controlBar(){return{isEnabled:!0,elements:{chat:!0,fullscreen:!0,invite:!1,layout:!1,participants:!0,plugins:!0,polls:!0,reactions:!1,screenshare:!0}}}get header(){return{isEnabled:!0,elements:{logo:n(this,Dr).designTokens.logo,timer:!0,title:!0,participantCount:!0,changeLayout:!1}}}get pipMode(){return!0}get viewType(){return n(this,Ge).viewType}get livestreamViewerQualities(){return n(this,Ge).livestreamViewerQualities||[]}get maxVideoStreams(){return n(this,Ge).maxVideoStreams}get maxScreenShareCount(){return n(this,Ge).maxScreenshareCount}get plugins(){return[]}get disabledPlugins(){return Object.keys(n(this,en)).filter(t=>n(this,en)[t].disabled)}get designTokens(){return n(this,Dr).designTokens}get configDiff(){return n(this,Dr).configDiff}get mediaConstraints(){var t,e,r,i,a,o,c,d,u,p,m,T,v,P,w,C,k,R,D,O,N,L,te,Yt;return{audio:{enableStereo:(i=(r=(e=(t=n(this,Ge))==null?void 0:t.media)==null?void 0:e.audio)==null?void 0:r.enableStereo)!=null?i:Si.audio.enableStereo,enableHighBitrate:(d=(c=(o=(a=n(this,Ge))==null?void 0:a.media)==null?void 0:o.audio)==null?void 0:c.enableHighBitrate)!=null?d:Si.audio.enableHighBitrate},video:{quality:(T=(m=(p=(u=n(this,Ge))==null?void 0:u.media)==null?void 0:p.video)==null?void 0:m.quality)!=null?T:Si.video.quality,frameRate:(C=(w=(P=(v=n(this,Ge))==null?void 0:v.media)==null?void 0:P.video)==null?void 0:w.frameRate)!=null?C:Si.video.frameRate},screenshare:{quality:(O=(D=(R=(k=n(this,Ge))==null?void 0:k.media)==null?void 0:R.screenshare)==null?void 0:D.quality)!=null?O:Si.screenshare.quality,frameRate:(Yt=(te=(L=(N=n(this,Ge))==null?void 0:N.media)==null?void 0:L.screenshare)==null?void 0:te.frameRate)!=null?Yt:Si.screenshare.frameRate}}}get name(){return n(this,Ea)}};let tl=Ri;Ge=new WeakMap,Dr=new WeakMap,Ea=new WeakMap,en=new WeakMap;var Cb=Object.defineProperty,_b=Object.getOwnPropertyDescriptor,ng=(s,t,e,r)=>{for(var i=r>1?void 0:r?_b(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Cb(t,e,i),i},tn,wa;class Ll extends ut{constructor(e,r){const i=e.getValue("logger");super(i);h(this,tn,void 0);g(this,"state","IDLE");g(this,"playbackUrl");g(this,"ingestionCredentials");g(this,"viewerCount");h(this,wa,void 0);f(this,tn,r),f(this,wa,e),this.viewerCount=0}get telemetry(){return n(this,wa).getValue("telemetry")}setLivestreamState(e){const r=this.state;this.state=e,r!==e&&this.emitCurrentLivestreamState()}emitCurrentLivestreamState(){this.emit("livestreamUpdate",this.state)}start(){return l(this,arguments,function*(e={manualIngestion:!1}){if(!n(this,tn).permissions.canLivestream)throw this.logger.error("Livestream::start::permission_denied"),new _("User does not have permission to start livestreaming","1901");this.setLivestreamState("STARTING");try{const r=De(),{playbackUrl:i,ingestionCredentials:a}=yield r.startLivestreaming(e);this.playbackUrl=i,this.ingestionCredentials=a,e!=null&&e.manualIngestion&&this.setLivestreamState("WAITING_ON_MANUAL_INGESTION")}catch(r){throw this.logger.error("Recording::stop::livestream_failed_to_start",{error:r}),this.setLivestreamState("IDLE"),new _("Error while starting livestream","1900",this.logger)}})}stop(){return l(this,null,function*(){if(!n(this,tn).permissions.canLivestream)throw this.logger.error("Livestream::stop::permission_denied"),new _("User does not have permission to stop livestreaming","1901");if(this.state!=="LIVESTREAMING"&&this.state!=="WAITING_ON_MANUAL_INGESTION")throw this.logger.error("Livestream::stop::inconsistent_state"),new _("Livestream not started yet","1902");try{this.setLivestreamState("STOPPING"),yield De().stopLivestreaming()}catch(e){throw this.logger.error("Livestream::stop::livestream_failed_to_stop",{error:e}),this.setLivestreamState("STOPPING"),new _("Error while stopping livestream","1900",this.logger)}})}}tn=new WeakMap,wa=new WeakMap;ng([S.trace("livestream.start")],Ll.prototype,"start",1);ng([S.trace("livestream.stop")],Ll.prototype,"stop",1);var Rb=Object.defineProperty,kb=Object.getOwnPropertyDescriptor,bb=(s,t,e,r)=>{for(var i=r>1?void 0:r?kb(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Rb(t,e,i),i},sn,rn,gs,Zt;class ag{constructor(t,e,r){g(this,"livestream");h(this,sn,void 0);h(this,rn,void 0);h(this,gs,void 0);h(this,Zt,void 0);f(this,Zt,t),f(this,rn,e),this.livestream=new Ll(t,e),f(this,gs,r),this.setupEvents()}get logger(){return n(this,Zt).getValue("logger")}get telemetry(){return n(this,Zt).getValue("telemetry")}fetchInitialLivestreamingState(){return l(this,null,function*(){const t=De(),{status:e,playbackUrl:r,manualIngest:i,ingestionCredentials:a}=yield t.getActiveLivestream();this.livestream.playbackUrl=r,this.livestream.ingestionCredentials=a,e==="LIVE"&&this.livestream.setLivestreamState("LIVESTREAMING"),e==="INVOKED"&&i&&this.livestream.setLivestreamState("WAITING_ON_MANUAL_INGESTION")})}setupEvents(){n(this,gs).on(A.startedLivestream,t=>l(this,null,function*(){this.livestream.playbackUrl=t.playbackUrl,this.livestream.setLivestreamState("LIVESTREAMING");try{n(this,rn).permissions.canLivestream&&(yield this.fetchInitialLivestreamingState())}catch(e){this.logger.error("Error: LivestreamController.fetchLivestream during startedLivestream re-fetch")}})),n(this,gs).on(A.livestreamingInvoked,t=>l(this,null,function*(){if(t.manualIngest){this.livestream.setLivestreamState("WAITING_ON_MANUAL_INGESTION");try{n(this,rn).permissions.canLivestream&&(yield this.fetchInitialLivestreamingState())}catch(e){this.logger.error("Error: LivestreamController.fetchLivestream during livestreamingInvoked re-fetch")}}})),n(this,gs).on(A.stoppedLivestream,()=>{this.livestream.setLivestreamState("IDLE"),this.livestream.playbackUrl=void 0,this.livestream.ingestionCredentials=void 0}),n(this,gs).on(A.erroredLivestream,()=>{this.livestream.setLivestreamState("IDLE"),this.livestream.playbackUrl=void 0}),n(this,gs).on(A.roomPeerCount,t=>{this.livestream.viewerCount=t.count,this.livestream.emit("viewerCountUpdate",t.count)}),n(this,Zt).getValue("peerSessionStore").on(E.PEER_JOINED_INTERNAL,t=>l(this,null,function*(){var e;((e=t.flags)==null?void 0:e.hiddenParticipant)===!0&&t.recorderType==="LIVESTREAMER"&&(f(this,sn,t.id),this.livestream.setLivestreamState("LIVESTREAMING"))})),n(this,Zt).getValue("peerSessionStore").on(E.PEER_CLOSED,t=>{t.id===n(this,sn)&&(f(this,sn,void 0),this.livestream.setLivestreamState("IDLE"))}),n(this,Zt).getValue("peerSessionStore").onAsync(E.LEAVE_MEDIA_ROOM,()=>l(this,null,function*(){if(!this.livestream.playbackUrl){this.logger.info("Fetching livestreaming state on leave stage");try{yield this.fetchInitialLivestreamingState()}catch(t){this.logger.error("Failed to fetch livestreaming state on leave stage",{error:t})}}})),n(this,Zt).getValue("peerSessionStore").on(E.SOCKET_SERVICE_ROOM_JOINED,()=>l(this,null,function*(){try{yield this.fetchInitialLivestreamingState()}catch(t){this.logger.error("Error: LivestreamController.fetchLivestream")}}))}}sn=new WeakMap,rn=new WeakMap,gs=new WeakMap,Zt=new WeakMap;bb([S.trace("LivestreamController.setupEvents")],ag.prototype,"setupEvents",1);var Mb=Object.defineProperty,Ab=Object.getOwnPropertyDescriptor,So=(s,t,e,r)=>{for(var i=r>1?void 0:r?Ab(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Mb(t,e,i),i},Me,Ks,zs,nc,og;class Ln{constructor({name:t,socketHandler:e,meetingId:r}){h(this,nc);g(this,"name","");h(this,Me,{});h(this,Ks,"");h(this,zs,void 0);g(this,"rateLimitConfig",{maxInvocations:5,period:1});g(this,"bulkRateLimitConfig",{maxInvocations:5,period:1});g(this,"listeners",{});this.name=t,f(this,zs,e),f(this,Ks,r)}set(t,e,r=!0,i=!1){return l(this,null,function*(){n(this,Me)[t]=e,r&&this.remoteSet(t,e),i&&(this.listeners[t]&&this.listeners[t].forEach(a=>a({[t]:n(this,Me)[t]})),this.listeners["*"]&&this.listeners["*"].forEach(a=>a({[t]:n(this,Me)[t]})))})}remoteSet(t,e){n(this,zs).storeInsertKeys(n(this,Ks),this.name,[{key:t,payload:e}])}bulkSet(t){return l(this,null,function*(){t.forEach(({key:e,payload:r})=>{n(this,Me)[e]=r}),n(this,zs).storeInsertKeys(n(this,Ks),this.name,t)})}update(t,e,r=!0){return l(this,null,function*(){M(this,nc,og).call(this,t,e,r)})}delete(t,e=!0,r=!1){return l(this,null,function*(){if(n(this,Me)[t]&&delete n(this,Me)[t],e)return n(this,zs).storeDeleteKeys(n(this,Ks),this.name,[{key:t}]);r&&(this.listeners[t]&&(this.listeners[t].forEach(i=>i({[t]:void 0})),delete this.listeners[t]),this.listeners["*"]&&this.listeners["*"].forEach(i=>i({[t]:void 0})))})}bulkDelete(t){return l(this,null,function*(){return t.forEach(({key:e})=>{n(this,Me)[e]&&delete n(this,Me)[e]}),n(this,zs).storeDeleteKeys(n(this,Ks),this.name,t)})}get(t){if(n(this,Me)[t])return n(this,Me)[t]}getAll(){return n(this,Me)}get rateLimits(){return this.rateLimitConfig}updateRateLimits(t,e){this.rateLimitConfig.maxInvocations=t,this.rateLimitConfig.period=e}get bulkRateLimits(){return this.bulkRateLimitConfig}updateBulkRateLimits(t,e){this.bulkRateLimitConfig.maxInvocations=t,this.bulkRateLimitConfig.period=e}subscribe(t,e){if(this.listeners[t]){this.listeners[t].push(e);return}this.listeners[t]=[e]}unsubscribe(t,e){var r;if(e){this.listeners[t]=((r=this.listeners[t])==null?void 0:r.filter(i=>i!==e))||[];return}this.listeners[t]&&delete this.listeners[t]}populate(t){f(this,Me,t)}}Me=new WeakMap,Ks=new WeakMap,zs=new WeakMap,nc=new WeakSet,og=function(t,e,r=!0){let i;const a=n(this,Me)[t],o=Object.prototype.toString.call(e),c=Object.prototype.toString.call(a);if(o!==c){this.set(t,e);return}switch(c){case"[object Array]":i=[...a,...e];break;case"[object Object]":i=b(b({},a),e);break;case"[object Map]":i=new Map([...a,...e]);break;case"[object Set]":i=new Set([...a,...e]);break;default:i=e;break}this.set(t,i,r)};So([Qe(xn,"rateLimitConfig")],Ln.prototype,"remoteSet",1);So([Qe(xn,"bulkRateLimitConfig")],Ln.prototype,"bulkSet",1);So([Qe(xn,"rateLimitConfig")],Ln.prototype,"update",1);So([Qe(xn,"rateLimitConfig")],Ln.prototype,"delete",1);So([Qe(xn,"bulkRateLimitConfig")],Ln.prototype,"bulkDelete",1);var Nr,Vr,Ca,sl,_a,Ys,ac,cg;class Ib{constructor(t,e){h(this,Ca);h(this,ac);g(this,"stores",new Map);h(this,Nr,void 0);h(this,Vr,"");h(this,_a,void 0);h(this,Ys,new Map);f(this,Nr,e),f(this,Vr,t.getValue("meetingId")),f(this,_a,t),M(this,ac,cg).call(this)}create(t){const e=new Ln({name:t,socketHandler:n(this,Nr),meetingId:n(this,Vr)});return n(this,Nr).storeGetKeys(n(this,Vr),t,[]),new Promise((i,a)=>{const o=setTimeout(()=>a(Error("Failed")),3e3);n(this,Ys).set(t,{rejectTimeout:o,resolve:i,store:e})})}}Nr=new WeakMap,Vr=new WeakMap,Ca=new WeakSet,sl=function(){return n(this,_a).getValue("peerId")},_a=new WeakMap,Ys=new WeakMap,ac=new WeakSet,cg=function(){[$.storeInsertKeys,$.storeGetKeys,$.storeDeleteKeys].forEach(t=>{n(this,Nr).on(t,e=>l(this,null,function*(){var a,o;if(e.pluginId!==n(this,Vr))return;const r=(a=e.storeItems)==null?void 0:a.map(c=>{var d;return{timestamp:c.timestamp,peerId:c.peerId,payload:JSON.parse((d=c.payload)!=null&&d.length?new TextDecoder().decode(c.payload):"{}"),key:c.storeKey}});if(t===$.storeGetKeys){const c=n(this,Ys).get(e.storeName),d=this.stores.get(e.storeName)||(c==null?void 0:c.store);n(this,Ys).get(e.storeName)&&(this.stores.set(e.storeName,c.store),c.resolve(d),clearTimeout(c.rejectTimeout),n(this,Ys).delete(e.storeName)),r.forEach(u=>{d.set(u.key,u.payload,!1,!1)});return}const i=this.stores.get(e.storeName)||((o=n(this,Ys).get(e.storeName))==null?void 0:o.store);i!==void 0&&(t===$.storeInsertKeys&&r.forEach(({key:c,peerId:d,payload:u})=>{d!==n(this,Ca,sl)&&i.set(c,u,!1,!0)}),t===$.storeDeleteKeys&&r.forEach(({key:c,peerId:d})=>{d!==n(this,Ca,sl)&&i.delete(c,!1,!0)}))}))})};function vr(s){var t,e,r,i,a,o,c,d,u,p,m,T,v;return s?{media:{audio:{enabled:s.audioEnabled,trackId:(t=s.audioTrack)==null?void 0:t.id,permission:"mediaPermissions"in s?(e=s.mediaPermissions)==null?void 0:e.audio:null},video:{enabled:s.videoEnabled,trackId:(r=s.videoTrack)==null?void 0:r.id,permission:"mediaPermissions"in s?(i=s.mediaPermissions)==null?void 0:i.video:null},screenshare:{enabled:s.screenShareEnabled,permission:"mediaPermissions"in s?(a=s.mediaPermissions)==null?void 0:a.screenshare:null,audio:{enabled:(c=(o=s.screenShareTracks)==null?void 0:o.audio)==null?void 0:c.enabled,trackId:(u=(d=s.screenShareTracks)==null?void 0:d.audio)==null?void 0:u.id},video:{enabled:(m=(p=s.screenShareTracks)==null?void 0:p.video)==null?void 0:m.enabled,trackId:(v=(T=s.screenShareTracks)==null?void 0:T.video)==null?void 0:v.id}}}}:{}}var Ob=Object.defineProperty,Db=Object.getOwnPropertyDescriptor,$n=(s,t,e,r)=>{for(var i=r>1?void 0:r?Db(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Ob(t,e,i),i};const Nb=.8,Vb=1.2;var nn,an,nt,xr,Jn,Qs,wi,Lr,Wn,oc,dg,ms,Ra,Xs,$r,Kn,fs,cc,ka,rl,dc,lg,lc,ug,Ah;let Ds=(Ah=class extends ut{constructor(t,e,r,i){const a=t.getValue("logger");super(a);h(this,xr);h(this,Qs);h(this,Lr);h(this,oc);h(this,$r);h(this,ka);h(this,dc);h(this,lc);g(this,"id");g(this,"userId");g(this,"name");g(this,"picture");g(this,"isHost");g(this,"customParticipantId");g(this,"flags");g(this,"device");g(this,"videoTrack");g(this,"audioTrack");g(this,"screenShareTracks");g(this,"videoEnabled");g(this,"audioEnabled");g(this,"screenShareEnabled");g(this,"producers");g(this,"manualProducerConfig");h(this,nn,void 0);g(this,"supportsRemoteControl",!1);h(this,an,void 0);g(this,"presetName");h(this,nt,void 0);h(this,ms,void 0);h(this,Ra,void 0);h(this,Xs,new Map);h(this,fs,1);h(this,cc,bl(t=>{if(!this.videoTrack)return;const{clientWidth:e,clientHeight:r}=t,{width:i,height:a}=this.videoTrack.getSettings();if(!i||!a)return;const o=a/r,c=i/e,d=Math.max(o,c);d>Vb&&n(this,fs)===1?(f(this,fs,0),n(this,nt).getValue("peerSessionStore").emit(E.MAX_SPATIAL_LAYER_CHANGE,{peerId:this.id,maxSpatialLayer:n(this,fs)})):d<Nb&&n(this,fs)===0&&(f(this,fs,1),n(this,nt).getValue("peerSessionStore").emit(E.MAX_SPATIAL_LAYER_CHANGE,{peerId:this.id,maxSpatialLayer:n(this,fs)}))},2e3));f(this,nt,t);const{id:o,userId:c,displayName:d,device:u,picture:p,isHost:m,flags:T,clientSpecificId:v,stageStatus:P,customParticipantId:w,audioMuted:C,audioTrack:k,videoEnabled:R=!1,videoTrack:D,producers:O,metadata:N}=e;this.id=o,this.userId=c,this.name=d,this.device=u,this.picture=p,this.isHost=m,this.flags=T,this.manualProducerConfig=_S,f(this,an,P!=null?P:"ON_STAGE"),this.customParticipantId=w!=null?w:v,this.audioEnabled=!C,this.audioTrack=k,this.videoEnabled=R,this.videoTrack=D,this.screenShareTracks={audio:void 0,video:void 0},this.producers=O!=null?O:[],this.presetName=N==null?void 0:N.preset_name,f(this,nn,!1),f(this,ms,r),f(this,Ra,i),this.setupEvents(),this.updateVideo=this.updateVideo.bind(this),M(this,ka,rl).call(this)}get clientSpecificId(){return this.customParticipantId}get stageStatus(){return n(this,an)}get telemetry(){return n(this,nt).getValue("telemetry")}setVideoEnabled(t,e=!0){this.videoEnabled=t,e&&(this.logger.info("Participant::setVideoEnabled::videoUpdate",b({},vr(this))),this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack}))}setAudioEnabled(t,e=!0){this.audioEnabled=t,e&&(this.logger.info("Participant::setAudioEnabled::audioUpdate",b({},vr(this))),this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack}))}setScreenShareEnabled(t,e=!0){this.screenShareEnabled=t,e&&this.emit("screenShareUpdate",{screenShareEnabled:this.screenShareEnabled,screenShareTracks:this.screenShareTracks})}setupEvents(){this.on("videoUpdate",M(this,ka,rl)),n(this,Qs,wi)&&(this.on("audioUpdate",M(this,dc,lg)),this.on("screenShareUpdate",M(this,lc,ug)))}pin(){return l(this,null,function*(){if(!n(this,Lr,Wn))throw new _("Can`t pin participant without joining room","1205");if(!n(this,ms).permissions.pinParticipant)throw new _("You do not have permission to pin participants.","1201");return n(this,xr,Jn).pinPeer(this.id)})}unpin(){return l(this,null,function*(){if(!n(this,Lr,Wn))throw new _("Can`t unpin participant without joining room","1205");if(!n(this,ms).permissions.pinParticipant)throw new _("You do not have permission to unpin participants.","1201");return n(this,xr,Jn).pinPeer(null)})}setIsPinned(t,e=!0){var i;f(this,nn,t);const r=t?"pinned":"unpinned";(i=n(this,$r,Kn))==null||i.updateSource(this.id,{pinned:t}),e&&this.emit(r,this)}disableAudio(){return l(this,null,function*(){const t=this.id;if(this.logger.info("Participant::disable_audio",{participant:{id:t}}),!n(this,Lr,Wn))throw new _("Can`t disable participant audio without joining room","1205");if(n(this,ms).permissions.canDisableParticipantAudio)return n(this,xr,Jn).disableAudio(t);throw this.logger.error("Participant::unauthorized_disable_audio",{participant:{id:t}}),new _("Unauthorized: User does not have permission to disable participant audio.","1201")})}kick(){return l(this,null,function*(){const t=this.id;if(this.logger.info("Participant::kick",{participant:{id:t}}),!n(this,oc,dg))throw new _("Can`t kick participant without joining room","1205");if(n(this,ms).permissions.kickParticipant){yield n(this,nt).getValue("peerSessionStore").emitAsync(E.KICK_PEER,{peerId:t});return}throw this.logger.error("Participant::unauthorized_kick",{participant:{id:t}}),new _("Unauthorized: User does not have permission to kick participants.","1201")})}disableVideo(){return l(this,null,function*(){const t=this.id;if(this.logger.info("Participant::disable_video",{participant:{id:t}}),!n(this,Lr,Wn))throw new _("Can`t disable participant video without joining room","1205");if(n(this,ms).permissions.canDisableParticipantVideo)return n(this,xr,Jn).disableVideo(t);throw this.logger.error("Participant::unauthorized_disable_video",{participant:{id:t}}),new _("Unauthorized: User does not have permission to disable participant video.","1201")})}getPermissions(){return l(this,null,function*(){return n(this,Ra).getUserPermissions(this.userId)})}setStageStatus(t){f(this,an,t),this.emit("stageStatusUpdate",this)}get isPinned(){return n(this,nn)}registerVideoElement(t){var r,i,a,o;if(!t)return;let e;(i=(r=n(this,Xs).get(t))==null?void 0:r.observer)==null||i.disconnect(),"ResizeObserver"in window&&(e=new ResizeObserver(()=>n(this,cc).call(this,t)),e.observe(t)),n(this,Xs).set(t,{observer:e}),this.updateVideo(t),(o=n(this,$r,Kn))==null||o.addSource(this.id,t,this.videoEnabled,this.isPinned,this.name,this.picture,(a=this.raised)!=null?a:!1)}deregisterVideoElement(t){var e,r,i,a;if(!t){(e=n(this,$r,Kn))==null||e.removeSource(this.id);return}t.srcObject=void 0,(i=(r=n(this,Xs).get(t))==null?void 0:r.observer)==null||i.disconnect(),n(this,Xs).delete(t),(a=n(this,$r,Kn))==null||a.removeSource(this.id)}updateVideo(t){var e;if(this.videoEnabled){if(this.videoTrack==null)return;const r=(e=t.srcObject)==null?void 0:e.getTracks()[0];if((r==null?void 0:r.id)===this.videoTrack.id)return;const i=new MediaStream;i.addTrack(this.videoTrack),t.srcObject=i}else t.srcObject=void 0;t.style.display=this.videoEnabled?"block":"none"}},nn=new WeakMap,an=new WeakMap,nt=new WeakMap,xr=new WeakSet,Jn=function(){return n(this,nt).getValue("roomNodeClient")},Qs=new WeakSet,wi=function(){return n(this,nt).getValue("audioPlayback")},Lr=new WeakSet,Wn=function(){return n(this,nt).getValue("connectionHandler").mediaJoined},oc=new WeakSet,dg=function(){return n(this,nt).getValue("connectionHandler").socketJoined},ms=new WeakMap,Ra=new WeakMap,Xs=new WeakMap,$r=new WeakSet,Kn=function(){return n(this,nt).getValue("pip")},fs=new WeakMap,cc=new WeakMap,ka=new WeakSet,rl=function(){Array.from(n(this,Xs).keys()).forEach(this.updateVideo)},dc=new WeakSet,lg=function(){var t,e;this.audioEnabled&&this.audioTrack?(t=n(this,Qs,wi))==null||t.addParticipantTrack(this.id,this.audioTrack):(e=n(this,Qs,wi))==null||e.removeParticipantTrack(this.id)},lc=new WeakSet,ug=function(){var t,e;this.screenShareEnabled&&this.screenShareTracks.audio?(t=n(this,Qs,wi))==null||t.addParticipantTrack(`screenshare-${this.id}`,this.screenShareTracks.audio):(e=n(this,Qs,wi))==null||e.removeParticipantTrack(`screenshare-${this.id}`)},Ah);$n([S.trace("Participant.disableAudio")],Ds.prototype,"disableAudio",1);$n([S.trace("Participant.kick")],Ds.prototype,"kick",1);$n([S.trace("Participant.disableVideo")],Ds.prototype,"disableVideo",1);$n([S.trace("Participant.getPermissions")],Ds.prototype,"getPermissions",1);$n([S.trace("Participant.setStageStatus")],Ds.prototype,"setStageStatus",1);Ds=$n([Ne("1200")],Ds);class Gn extends Zp{constructor(t,e){const{onAddEvent:r="participantJoined",onDeleteEvent:i="participantLeft",onClearEvent:a="participantsCleared"}=e!=null?e:{};super({onAddEvent:r,onDeleteEvent:i,onClearEvent:a},t)}add(t,e=!0){return this.has(t.id)&&Object.is(this.get(t.id),t)===!1&&this.delete(t.id),super.add(t,e)}clear(t=!0,e=!1){return super.clear(t,e)}delete(t,e=!0,r=!1){return super.delete(t,e,r)}}var Zs;class xb extends Vn{constructor(e){super(e);h(this,Zs,void 0);f(this,Zs,new Map)}__set(e,r){return n(this,Zs).set(e,r)}__clear(){return n(this,Zs).clear()}get(e){return n(this,Zs).get(e)}toArray(){return Array.from(n(this,Zs).values())}}Zs=new WeakMap;class Lb{constructor(){g(this,"_orderedArray");g(this,"_map");this._map=new Map,this._orderedArray=[]}add(t,e){if(!this._map.has(t))return this._map.set(t,{peerId:t,priority:e}),this._orderedArray.splice(Math.max(e-1,0),0,t),this.index(t);const r=this.index(t);this.delete(t);const i=this.add(t,e);return r!==i?i:-1}delete(t){if(this._map.has(t)){const e=this.index(t);this._map.delete(t),this._orderedArray.splice(e,1)}}index(t){return this._map.has(t)?this._orderedArray.indexOf(t):-1}[Symbol.iterator](){return this._orderedArray[Symbol.iterator]()}}class $b{constructor(){g(this,"_activeSpeakerPeers");g(this,"_compulsoryPeers");this._activeSpeakerPeers=new Lb,this._compulsoryPeers=new Set}add(t,e,r){if(!t)return-1;if(e<0)return this._compulsoryPeers.add(t),0;const i=r.getValue("logger");if(this.compulsoryPeers.includes(t)&&(e>0||e===246267631)){if(i.info("SelectedPeer::removing_compulsory_peer",{selectedPeer:{peerId:t}}),this._removeFromCompulsoryPeer(t),e===246267631)return-1}else if(e===229490415)return this.delete(t,r),-1;return this._activeSpeakerPeers.add(t,e)}delete(t,e){const r=e==null?void 0:e.getValue("logger");r==null||r.info("SelectedPeer::deleting_peer_from_selectedPeer",{selectedPeer:{peerId:t}}),this._removeFromCompulsoryPeer(t),this._activeSpeakerPeers.delete(t)}index(t){return this._activeSpeakerPeers.index(t)}get peers(){return Array.from(new Set(this.compulsoryPeers.concat(this.activeSpeakerPeers)))}get compulsoryPeers(){return Array.from(this._compulsoryPeers.values())}get activeSpeakerPeers(){return Array.from(this._activeSpeakerPeers)}_removeFromCompulsoryPeer(t){this._compulsoryPeers.delete(t)}}const hg=new $b;var Ub=Object.defineProperty,qb=Object.getOwnPropertyDescriptor,gt=(s,t,e,r)=>{for(var i=r>1?void 0:r?qb(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Ub(t,e,i),i};const Hb=["ACTIVE_GRID","PAGINATED","MANUAL"];var ee,ba,il,Ur,zn,on,Bo,qr,Je,Ih;let Be=(Ih=class extends ut{constructor(t,e,r){const i=t.getValue("logger");super(i);h(this,ba);h(this,Ur);h(this,on);g(this,"waitlisted");g(this,"joined");g(this,"active");g(this,"videoSubscribed");g(this,"audioSubscribed");g(this,"pinned");g(this,"all");h(this,ee,void 0);h(this,qr,void 0);h(this,Je,void 0);g(this,"rateLimitConfig",{maxInvocations:5,period:1});g(this,"viewMode");g(this,"currentPage");g(this,"lastActiveSpeaker");g(this,"selectedPeers",hg);f(this,ee,t),f(this,qr,e),f(this,Je,r),this.waitlisted=new Gn(i),this.joined=new Gn(i),this.videoSubscribed=new Gn(i),this.audioSubscribed=new Gn(i),this.active=this.videoSubscribed,this.pinned=new Gn(i),this.all=new xb(i),this.viewMode="ACTIVE_GRID",this.currentPage=0,this.setupEvents()}get pip(){return n(this,ee).getValue("pip")}get rateLimits(){return this.rateLimitConfig}updateRateLimits(t,e){this.rateLimitConfig.maxInvocations=t,this.rateLimitConfig.period=e}get telemetry(){return n(this,ee).getValue("telemetry")}setupEvents(){n(this,ee).getValue("peerSessionStore").on(E.E2EE_ACTIVE_CONSUMER,({peerId:e})=>{var r;((r=n(this,ee).getValue("modules").e2ee)==null?void 0:r.enabled)!==!0&&this.emit("media_decode_error",{reason:`Got encrypted media for participantId ${e}, but encryption wasn't enabled in init.defaults`,code:"1702"})});const t=n(this,ee).getValue("audioPlayback");t&&this.audioSubscribed.on("participantLeft",e=>{t.removeParticipantTrack(e.id)})}get count(){return this.joined.size}get maxActiveParticipantsCount(){var t;return(t=n(this,ee))==null?void 0:t.getValue("maxPreferredStreams")}setMaxActiveParticipantsCount(t){if(t<0||t>24)throw new _("0 <= Max active participants count limit <= 24","1203");n(this,ee).setValue("maxPreferredStreams",t),n(this,on,Bo)&&n(this,ee).getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:this.viewMode,page:this.currentPage})}get pageCount(){if(this.viewMode==="PAGINATED"){const t=this.selectedPeers.compulsoryPeers.length,e=this.joined.toArray().filter(r=>r.stageStatus==="ON_STAGE");return Math.ceil((e.length-t)/Math.max(this.maxActiveParticipantsCount-t,1))}return 0}acceptWaitingRoomRequest(t){var r,i;if(!n(this,Ur,zn))throw new _("Can`t accept waiting room request without joining room","1205");const e=(i=(r=this.waitlisted.get(t))==null?void 0:r.userId)!=null?i:t;return n(this,Je).acceptWaitingRoomRequest([e])}acceptAllWaitingRoomRequest(t){return l(this,null,function*(){const e=t.map(r=>{var i,a;return(a=(i=this.waitlisted.get(r))==null?void 0:i.userId)!=null?a:r});return n(this,Je).acceptWaitingRoomRequest(e)})}rejectWaitingRoomRequest(t){return l(this,null,function*(){var r,i;if(!n(this,Ur,zn))throw new _("Can`t reject waiting room request without joining room","1205");const e=(i=(r=this.waitlisted.get(t))==null?void 0:r.userId)!=null?i:t;n(this,Je).rejectWaitingRoomRequest([e])})}setViewMode(t){return l(this,null,function*(){if(this.logger.info("Participants::set_view_mode",{pageNavigation:{viewMode:t,currentPage:this.currentPage,pageCount:this.pageCount,maxActiveParticipantsCount:this.maxActiveParticipantsCount}}),!(r=>Hb.includes(r))(t))throw this.logger.error("Participants::setViewMode::invalid_view_mode",{pageNavigation:{viewMode:t,currentPage:this.currentPage,pageCount:this.pageCount,maxActiveParticipantsCount:this.maxActiveParticipantsCount}}),new _(`Invalid view mode: ${t}. Try ACTIVE_GRID, PAGINATED or MANUAL.`,"1207");if(this.viewMode===t){this.logger.info("Participants::setViewMode::view_mode_same_as_previous");return}this.viewMode=t,t==="PAGINATED"?(this.currentPage=1,n(this,ee).getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:t,page:this.currentPage})):t==="ACTIVE_GRID"?(this.currentPage=0,n(this,ee).getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:t,page:this.currentPage})):t==="MANUAL"&&(this.currentPage=0,n(this,ee).getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:t,page:this.currentPage})),this.emit("viewModeChanged",{viewMode:t,currentPage:this.currentPage,pageCount:this.pageCount})})}subscribe(r){return l(this,arguments,function*(t,e=["audio","video","screenshareAudio","screenshareVideo"]){if(this.viewMode!=="MANUAL")throw new _("MANUAL subscription mode was not activated.","1206");t.forEach(i=>{const a=this.joined.get(i);a&&(e.includes("audio")&&(a.manualProducerConfig=U(b({},a.manualProducerConfig),{audio:!0}),this.audioSubscribed.has(a.id)||this.audioSubscribed.add(a)),e.includes("video")&&(a.manualProducerConfig=U(b({},a.manualProducerConfig),{video:!0}),this.videoSubscribed.has(a.id)||this.videoSubscribed.add(a)),e.includes("screenshareAudio")&&(a.manualProducerConfig=U(b({},a.manualProducerConfig),{screenshareAudio:!0}),this.audioSubscribed.has(a.id)||this.audioSubscribed.add(a)),e.includes("screenshareVideo")&&(a.manualProducerConfig=U(b({},a.manualProducerConfig),{screenshareVideo:!0}),this.videoSubscribed.has(a.id)||this.videoSubscribed.add(a)))}),n(this,ee).getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:this.viewMode,page:this.currentPage})})}unsubscribe(r){return l(this,arguments,function*(t,e=["audio","video","screenshareAudio","screenshareVideo"]){if(this.viewMode!=="MANUAL")throw new _("MANUAL subscription mode was not activated.","1206");t.forEach(i=>{const a=this.joined.get(i);a&&(e.includes("audio")&&(a.manualProducerConfig=U(b({},a.manualProducerConfig),{audio:!1}),a.manualProducerConfig.screenshareAudio||this.audioSubscribed.delete(a.id)),e.includes("video")&&(a.manualProducerConfig=U(b({},a.manualProducerConfig),{video:!1}),a.manualProducerConfig.screenshareVideo||this.videoSubscribed.delete(a.id)),e.includes("screenshareAudio")&&(a.manualProducerConfig=U(b({},a.manualProducerConfig),{screenshareAudio:!1}),a.manualProducerConfig.audio||this.audioSubscribed.delete(a.id)),e.includes("screenshareVideo")&&(a.manualProducerConfig=U(b({},a.manualProducerConfig),{screenshareVideo:!1}),a.manualProducerConfig.video||this.videoSubscribed.delete(a.id)))}),n(this,ee).getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:this.viewMode,page:this.currentPage})})}getPeerIdsForCurrentPage(){this.logger.info("Participants::getPeerIdsForCurrentPage()",{pageNavigation:{viewMode:this.viewMode,currentPage:this.currentPage,pageCount:this.pageCount,maxActiveParticipantsCount:this.maxActiveParticipantsCount}});const{compulsoryPeers:t}=this.selectedPeers,e=t.filter(c=>this.joined.has(c)),r=Array.from(this.pinned.keys()).filter(c=>!e.includes(c)),i=Array.from(this.joined.toArray().filter(c=>c.stageStatus==="ON_STAGE").map(c=>c.id)),a=Math.max((this.currentPage-1)*(this.maxActiveParticipantsCount-e.length-r.length)),o=this.currentPage*(this.maxActiveParticipantsCount-e.length-r.length);return e.concat(r,i.slice(a,o))}setPage(t){return l(this,null,function*(){if(this.logger.info("Participants::set_page",{pageNavigation:{settingPage:t,viewMode:this.viewMode,currentPage:this.currentPage,pageCount:this.pageCount,maxActiveParticipantsCount:this.maxActiveParticipantsCount}}),this.viewMode==="PAGINATED"){if(!Number.isInteger(t))throw this.logger.error("Participants::invalid_page_number"),new _(`Invalid page: ${t}. Page must be an integer and greater than 0 and less than or equal to .pageCount`,"1202");this.currentPage=t,n(this,ee).getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:this.viewMode,page:t}),this.emit("pageChanged",{viewMode:this.viewMode,currentPage:this.currentPage,pageCount:this.pageCount})}})}disableAllAudio(t){return l(this,null,function*(){if(this.logger.info("Participants::disable_all_audio",{actions:{disableAllAudio:{allowUnmute:t}}}),!n(this,on,Bo))throw new _("Can`t disable all audio without joining room","1205");if(n(this,qr).permissions.canAllowParticipantAudio)return n(this,ba,il).muteAll(t);throw this.logger.error("Participants::unauthorized_disable_all_audio",{actions:{disableAllAudio:{allowUnmute:t}}}),new _("Unauthorized: User does not have permission to disable peer audio.","1201")})}disableAllVideo(){return l(this,null,function*(){if(this.logger.info("Participants::disable_all_video"),!n(this,on,Bo))throw new _("Can`t disable all video without joining room","1205");if(n(this,qr).permissions.canAllowParticipantVideo)return n(this,ba,il).muteAllVideo();throw this.logger.error("Participants::unauthorized_disable_all_video"),new _("Unauthorized: User does not have permission to disable peer video.","1201")})}disableAudio(t){return l(this,null,function*(){this.joined.get(t).disableAudio()})}disableVideo(t){return l(this,null,function*(){this.joined.get(t).disableVideo()})}kick(t){return l(this,null,function*(){yield n(this,ee).getValue("peerSessionStore").emitAsync(E.KICK_PEER,{peerId:t})})}kickAll(){return l(this,null,function*(){if(this.logger.info("Participants::kick_all"),n(this,ee).getValue("viewType")!=="LIVESTREAM"&&!n(this,Ur,zn))throw new _("Can`t kick all without joining room","1205");if(!n(this,qr).permissions.kickParticipant)throw this.logger.error("Participants::unauthorized_kick_all"),new _("Unauthorized: User does not have permission to kick peers.","1201");const e=n(this,ee).getValue("flagsmith").hasFeature(q.PROPAGATE_KICK_ALL);n(this,Je).kickAll(e)})}broadcastMessage(t,e,r){return l(this,null,function*(){if(this.logger.info("Participants::broadcastMessage"),!n(this,Ur,zn))throw new _("Can`t broadcast message without joining room","1205");if(!(t!=null&&t.trim()))throw new _("`type` must be a non-empty string.","1209");if(r)if("meetingIds"in r)yield n(this,Je).broadcastToMeetings(t,r.meetingIds,e);else{let i=[];"participantIds"in r?i=r.participantIds:i=this.joined.toArray().filter(a=>{var o;return(o=r.presetNames)==null?void 0:o.includes(a.presetName)}).map(a=>a.id),yield n(this,Je).broadcastToPeers(t,i,e)}else yield n(this,Je).broadcastMessage(t,e)})}getAllJoinedPeers(t,e,r){return l(this,null,function*(){return(yield n(this,Je).getRoomPeers(t,e,r)).peers.map($s.formatSocketPeerMessage)})}updatePermissions(t,e){return l(this,null,function*(){const r=this.joined.toArray().filter(a=>t.includes(a.id)).map(a=>a.userId),i=[...new Set(r)];if(!i.length)throw new _("Cannot update permissions, no valid userIDs found","1204");n(this,Je).updatePermissions(i,e)})}getParticipantsInMeetingPreJoin(){return l(this,null,function*(){return n(this,Je).getRoomPeersNonPaginated()})}},ee=new WeakMap,ba=new WeakSet,il=function(){return n(this,ee).getValue("roomNodeClient")},Ur=new WeakSet,zn=function(){var t;return((t=n(this,ee).getValue("connectionHandler"))==null?void 0:t.socketJoined)===!0},on=new WeakSet,Bo=function(){var t;return((t=n(this,ee).getValue("connectionHandler"))==null?void 0:t.mediaJoined)===!0},qr=new WeakMap,Je=new WeakMap,Ih);gt([S.trace("Participants.setViewMode")],Be.prototype,"setViewMode",1);gt([S.trace("Participants.setPage")],Be.prototype,"setPage",1);gt([S.trace("Participants.disableAllAudio")],Be.prototype,"disableAllAudio",1);gt([S.trace("Participants.disableAllVideo")],Be.prototype,"disableAllVideo",1);gt([S.trace("Participants.disablePeerAudio")],Be.prototype,"disableAudio",1);gt([S.trace("Participants.disablePeerVideo")],Be.prototype,"disableVideo",1);gt([S.trace("Participants.kickPeer")],Be.prototype,"kick",1);gt([S.trace("Participants.kickAll")],Be.prototype,"kickAll",1);gt([S.trace("Participants.broadcastMessage"),Qe(xn,"rateLimitConfig")],Be.prototype,"broadcastMessage",1);gt([S.trace("Participants.getAllJoinedPeers"),Qe({maxInvocations:10,period:60})],Be.prototype,"getAllJoinedPeers",1);gt([S.trace("Participant.updatePermissions"),Qe({maxInvocations:1e3,period:60})],Be.prototype,"updatePermissions",1);gt([S.trace("Participants.getParticipantsInMeetingPreJoin")],Be.prototype,"getParticipantsInMeetingPreJoin",1);Be=gt([Ne("1200")],Be);var Fb=Object.defineProperty,Bb=Object.getOwnPropertyDescriptor,yi=(s,t,e,r)=>{for(var i=r>1?void 0:r?Bb(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&Fb(t,e,i),i},Pt,xt,cn,Oh;const pg=(Oh=class{constructor(s,t,e){g(this,"participants");g(this,"self");g(this,"selectedPeers",hg);g(this,"maxSpatialLayerUpdates",new Map);g(this,"consumerPeerMap");g(this,"events");g(this,"roomSocketHandler");g(this,"context");g(this,"videoPeerConsumerMap",new Map);h(this,Pt,{mode:"ACTIVE_GRID",page:0});h(this,xt,!1);h(this,cn,!1);g(this,"updateConsumerSpatialLayers",bl(()=>{const s={},t=new Map(this.maxSpatialLayerUpdates);this.maxSpatialLayerUpdates.clear(),Array.from(t.entries()).forEach(([e,r])=>{s[r]===void 0&&(s[r]={layer:r,consumerIds:[]}),s[r].consumerIds.push(e)}),Object.keys(s).forEach(e=>{const r=s[e];this.logger.log(`Switching max spatial layer to ${r.layer}`,{consumerIds:r.consumerIds}),this.roomNodeClient.switchConsumersToLayer(r.consumerIds,r.layer)})},2e3));g(this,"updateConsumers",(s,t)=>l(this,null,function*(){this.logger.info(`updateConsumers: Starting consumer updates - AddProducers: ${s.length}, RemoveProducers: ${t.length}, ConsumersSyncing: ${n(this,xt)}`);try{s.length!==0&&(this.logger.info(`updateConsumers: Creating consumers for ${s.length} producers: [${s.map(e=>e.producerId).join(", ")}]`),yield this.roomNodeClient.createConsumers(s),this.logger.info("updateConsumers: Successfully created consumers."))}catch(e){this.logger.error("updateConsumers: Error creating consumers",{error:e})}try{t.length!==0&&(this.logger.info(`updateConsumers: Closing consumers for ${t.length} producers: [${t.map(e=>e.producerId).join(", ")}]`),yield this.roomNodeClient.closeConsumers(t),this.logger.info("updateConsumers: Successfully closed consumers."))}catch(e){this.logger.error("updateConsumers: Error closing consumers",{error:e})}this.logger.info("updateConsumers: Completed consumer updates.")}));this.context=s,this.roomSocketHandler=e,this.participants=new Be(s,t,this.roomSocketHandler),this.self=t,this.consumerPeerMap=new Map,this.events=Bt,t.config.viewType!=="CHAT"&&this.setupEventsGlobal(),this.setupEvents()}get roomNodeClient(){return this.context.getValue("roomNodeClient")}get mediaJoined(){var s;return((s=this.roomNodeClient)==null?void 0:s.mediaJoined)===!0}get pip(){return this.context.getValue("pip")}get telemetry(){return this.context.getValue("telemetry")}get logger(){return this.context.getValue("logger")}setupEvents(){this.roomSocketHandler.on(A.getWaitingRoomRequests,this.waitingRoomRequestHandler.bind(this)),this.context.getValue("peerSessionStore").on(E.SOCKET_PEERS,s=>l(this,null,function*(){const t=this.context.getValue("flagsmith").hasFeature(q.DEBUG_SOCKET_JOIN);if(t){const e=s&&(s==null?void 0:s.length)<20?{peers:JSON.stringify(s.map(r=>r.peerId))}:void 0;this.logger.info("Processing socket peers",e)}s==null||s.forEach(e=>{e.waitlisted||this.onParticipantSocketJoined(this.createParticipantObjFromSocketPeer(e))}),t&&this.logger.info("Processed socket peers")})),this.roomSocketHandler.on(this.events.peerJoinedBroadcast,({participant:s})=>{this.logger.info("PEER_INFO:::MEDIA_JOIN",{participant:{id:s.peerId,maskedName:[...(s==null?void 0:s.displayName)||""].map((t,e)=>e%2?"*":t).join("")}}),this.logger.info("events.peerJoinedBroadcast",{peers:s.peerId}),this.onParticipantMediaJoined(s.peerId,s.producerStates,s.capabilities)}),this.roomSocketHandler.on(this.events.selfJoinComplete,({participants:s,selectedPeers:t,roomState:e})=>{if(this.context.getValue("flagsmith").hasFeature(q.DEBUG_SOCKET_JOIN)){const a=s&&(s==null?void 0:s.length)<20?{peers:JSON.stringify(s.map(o=>o.peerId))}:void 0;this.logger.info("events.selfJoinComplete",a)}s.forEach(({peerId:a,producerStates:o,capabilities:c})=>this.onParticipantMediaJoined(a,o,c));const{audioPeers:r,compulsoryPeers:i}=t!=null?t:{};e.pinnedPeerIds.length!==0&&this.onParticipantPinned(e.pinnedPeerIds[0]),this.computeActivateParticipants(r!=null?r:[],i),this.logger.info("selfJoinComplete: Emitting UPDATE_ACTIVE with createAllConsumers=true"),this.context.getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{createAllConsumers:!0})}),this.context.getValue("peerSessionStore").on(E.MAX_SPATIAL_LAYER_CHANGE,({peerId:s,maxSpatialLayer:t})=>{const e=this.videoPeerConsumerMap.get(s);e&&(this.context.getValue("flagsmith").hasFeature(q.DISABLE_LAYER_SWITCH)||(this.maxSpatialLayerUpdates.set(e,t),this.updateConsumerSpatialLayers()))}),this.context.getValue("peerSessionStore").on(E.NEW_PRODUCER,({peerId:s,producer:t})=>{const e=this.participants.joined.get(s);if(!e){this.logger.warn("ParticipantController::NEW_PRODUCER::participant not found",{producer:{id:t==null?void 0:t.producerId,kind:t==null?void 0:t.kind,status:"not_initialized",appData:{screenShare:t==null?void 0:t.screenShare}},participant:{id:s}});return}e.producers.push(t),this.logger.info("ParticipantController::NEW_PRODUCER::producer_added_to_participant",{producer:{id:t==null?void 0:t.producerId,peerId:s,kind:t==null?void 0:t.kind,status:"not_initialized",appData:{screenShare:t==null?void 0:t.screenShare}}}),(t==null?void 0:t.kind)==="audio"&&this.participants.audioSubscribed.get(s)||(t==null?void 0:t.kind)==="video"&&this.participants.videoSubscribed.get(s)||t!=null&&t.screenShare?(this.logger.info(`NEW_PRODUCER: scheduling syncConsumer (AUTO mode) - Producer: ${t.producerId}, Peer: ${s}, Kind: ${t.kind}, ScreenShare: ${t.screenShare}, ConsumersSyncing: ${n(this,xt)}, VideoSub: ${t.kind==="video"?this.participants.videoSubscribed.has(s):"N/A"}, AudioSub: ${t.kind==="audio"?this.participants.audioSubscribed.has(s):"N/A"}`),this.scheduleSyncConsumers({source:"NEW_PRODUCER_AUTO"})):this.logger.info("ParticipantController::NEW_PRODUCER::not_consuming_producer_auto",{producer:{id:t==null?void 0:t.producerId,peerId:s,kind:t==null?void 0:t.kind,status:"UNKNOWN",appData:{screenShare:t==null?void 0:t.screenShare}}})}),this.context.getValue("peerSessionStore").on(E.PRODUCER_CLOSED,({peerId:s,producerId:t})=>{const e=this.participants.joined.get(s);if(!e){this.logger.warn("ParticipantController::NEW_PRODUCER::participant not found",{participant:{id:s}});return}e.producers=e.producers.filter(r=>r.producerId!==t)}),this.context.getValue("peerSessionStore").on(E.PRODUCER_TOGGLE,({peerId:s,producerId:t,paused:e,kind:r})=>{const i=this.participants.joined.get(s);if(i){r==="audio"&&i.setAudioEnabled(!e);const a=i.producers.find(o=>o.producerId===t);a&&(a.pause=e),r==="video"&&this.context.getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:this.participants.viewMode,page:this.participants.currentPage})}}),this.roomSocketHandler.on(this.events.globalPeerPinBroadcast,s=>{let t;if(s&&(t=s.participantId),!this.mediaJoined)return;const e=t;this.onParticipantPinned(e);const r=this.participants.joined.get(e);r&&(this.logger.info(`globalPeerPinBroadcast: Scheduling audio/video consumer sync for pinned participant ${e} - ProducerCount: ${r.producers.length}, ConsumersSyncing: ${n(this,xt)}, ProducerIds: [${r.producers.map(i=>i.producerId).join(", ")}]`),this.scheduleSyncConsumers({source:"GLOBAL_PEER_PIN"}))}),this.roomSocketHandler.on(this.events.selectedPeer,({audioPeers:s,compulsoryPeers:t})=>{this.mediaJoined&&this.onSelectedPeers(t.concat(s))}),this.roomSocketHandler.on(this.events.selectedPeerDiff,({entries:s})=>{if(!this.mediaJoined)return;const t=s.map(e=>({peerId:e.peerId,priority:e.priority}));this.updateActiveParticipantsWithPriorities(t,!0)})}waitingRoomRequestHandler(s){const t=s.requests.filter(r=>!this.participants.waitlisted.toArray().find(i=>i.userId===r.userId)),e=this.participants.waitlisted.toArray().filter(r=>!s.requests.find(i=>i.userId===r.userId));t.forEach(r=>this.participants.waitlisted.add(new Ds(this.context,{id:r.peerId,displayName:r.displayName,audioMuted:!0,videoEnabled:!1,audioTrack:void 0,videoTrack:void 0,stageStatus:"OFF_STAGE",userId:r.userId,flags:{},isHost:!1,customParticipantId:r.customParticipantId,picture:r.picture,metadata:{preset_name:r.presetName}},this.self,this.roomSocketHandler))),e.forEach(r=>this.participants.waitlisted.delete(r.id))}get maxPreferredStreams(){return this.participants.maxActiveParticipantsCount}selectPagePeers(s){const{compulsoryPeers:t}=this.selectedPeers,e=t.filter(d=>this.participants.joined.has(d)),r=Array.from(this.participants.pinned.keys()).filter(d=>!e.includes(d)),i=Array.from(this.participants.joined.toArray().filter(d=>d.stageStatus==="ON_STAGE").map(d=>d.id)),a=Math.max((s-1)*(this.maxPreferredStreams-e.length-r.length)),o=s*(this.maxPreferredStreams-e.length-r.length);return e.concat(r,i.slice(a,o))}selectActivePeers(s){const t=new Map,e=Array.from(this.participants.joined.toArray().filter(p=>p.stageStatus==="ON_STAGE").map(p=>(t.set(p.id,!0),p.id))),r=this.selectedPeers.peers,i=this.participants.pinned.toArray().reduce((p,m)=>(m.stageStatus!=="ON_STAGE"?this.participants.pinned.delete(m.id):p.push(m.id),p),[]),a=this.self.stageStatus==="ON_STAGE"?1:0,o=s-a,c=new Set(r.concat(i).filter(p=>p!==this.self.id&&t.has(p)));let d=Array.from(c);const u=o-c.size;if(u>=0){const p=e.filter(m=>!c.has(m)&&m!==this.self.id).slice(0,u);d=Array.from(c).concat(p)}else d=d.slice(0,o);return d}updateMediaSubscribedMaps(s,t){const{page:e}=t!=null?t:{};s&&n(this,Pt).mode!==s&&(n(this,Pt).mode=s),e&&n(this,Pt).page!==e&&(n(this,Pt).page=e);const{mode:r,page:i}=n(this,Pt);switch(r){case"PAGINATED":{if(!i)return;const a=this.selectPagePeers(i),o=this.selectActivePeers(this.participants.maxActiveParticipantsCount+4);this.updateParticipantsMap(this.participants.videoSubscribed,a),this.updateParticipantsMap(this.participants.audioSubscribed,o),this.logger.debug("ParticipantController::updateActive::updating_current_page_peers",{peerIds:a});break}case"ACTIVE_GRID":{const a=this.selectActivePeers(this.participants.maxActiveParticipantsCount),o=this.selectActivePeers(this.participants.maxActiveParticipantsCount+4);this.updateParticipantsMapMinReplacement(this.participants.videoSubscribed,a),this.updateParticipantsMap(this.participants.audioSubscribed,o);break}case"MANUAL":break;default:throw new Error(`View mode ${s} not supported`)}}scheduleSyncConsumers(t){return l(this,arguments,function*({source:s}){var r,i,a;const e=((r=n(this,Pt))==null?void 0:r.mode)==="PAGINATED"&&!n(this,xt)?200:0;this.logger.info(`scheduleSyncConsumers():: Source: ${s}, ViewMode: ${(i=n(this,Pt))==null?void 0:i.mode}, ConsumersSyncing: ${n(this,xt)}, Delay: ${e}, Page: ${(a=n(this,Pt))==null?void 0:a.page}`),setTimeout(()=>this.syncConsumers(),e)})}syncConsumers(){return l(this,null,function*(){var o,c,d,u,p;if(((d=(c=(o=this.context.getValue("connectionHandler"))==null?void 0:o.mediaState)==null?void 0:c.recv)==null?void 0:d.state)!=="connected"){this.logger.info("syncConsumers: Connection not ready, exiting.");return}if(n(this,xt)){f(this,cn,!0),this.logger.info("syncConsumers: Sync in progress, marking resyncRequired=true and exiting.");return}this.logger.info("syncConsumers: Starting sync operation."),f(this,xt,!0),f(this,cn,!1);let s=[];this.participants.videoSubscribed.forEach(m=>{var P,w;const T=this.participants.joined.get(m.id),v=(w=(P=m.producers)==null?void 0:P.filter(C=>C.kind==="video"))!=null?w:[];T&&(v!=null&&v.length)&&v.forEach(C=>{var D,O,N,L;const k=((O=(D=T.manualProducerConfig)==null?void 0:D.video)!=null?O:!0)&&C.kind==="video"&&!C.screenShare,R=((L=(N=T.manualProducerConfig)==null?void 0:N.screenshareVideo)!=null?L:!0)&&C.kind==="video"&&C.screenShare;(k||R)&&(C.pause||s.push(C))})}),this.participants.audioSubscribed.forEach(m=>{var P,w;const T=this.participants.joined.get(m.id),v=(w=(P=m.producers)==null?void 0:P.filter(C=>C.kind==="audio"))!=null?w:[];T&&(v!=null&&v.length)&&v.forEach(C=>{var D,O,N,L;const k=((O=(D=T.manualProducerConfig)==null?void 0:D.audio)!=null?O:!0)&&C.kind==="audio"&&!C.screenShare,R=((L=(N=T.manualProducerConfig)==null?void 0:N.screenshareAudio)!=null?L:!0)&&C.kind==="audio"&&C.screenShare;(k||R)&&s.push(C)})}),s=CS(s,m=>m.producerId);const t=new Map;s.forEach(m=>{t.set(m.producerId,m)});const e=(u=this.roomNodeClient)==null?void 0:u.getConsumers(),r=s.filter(m=>!(e!=null&&e.has(m.producerId))),i=[];let a=Array.from((p=e==null?void 0:e.values())!=null?p:[]).map(m=>m.peerId);a=wS(a),a==null||a.forEach(m=>{var v;const T=this.participants.joined.get(m);if(!T){this.logger.warn(`Peer with ${m} doesn't exist in joined list but producers of it are being consumed.`);return}(v=T.producers)!=null&&v.length&&T.producers.forEach(P=>{const w=P.consumer&&e.has(P.consumer.id);!t.has(P.producerId)&&(e.has(P.producerId)||w)&&i.push(P)})}),this.logger.info(`syncConsumers: Computed changes - AddProducers: ${r.length} [${r.map(m=>m.producerId).join(", ")}], RemoveProducers: ${i.length} [${i.map(m=>m.producerId).join(", ")}]`.substring(0,5e3));try{r.length>0||i.length>0?(this.logger.info(`syncConsumers: Calling updateConsumers with changes. Adding ${r.length} and removing ${i.length}.`),yield this.updateConsumers(r,i),this.logger.info("syncConsumers: updateConsumers completed successfully.")):this.logger.info("syncConsumers: No changes needed, skipping updateConsumers.")}catch(m){this.logger.error("syncConsumers: updateConsumers failed with error.",{error:m})}finally{this.logger.info("syncConsumers: Setting consumersSyncing=false and completing sync."),f(this,xt,!1)}n(this,cn)&&(this.logger.info("syncConsumers: Resync required, calling syncConsumers again."),this.syncConsumers())})}computeActivateParticipants(s,t){const e=s.map((i,a)=>({peerId:i,priority:a+1})),r=t==null?void 0:t.map((i,a)=>({peerId:i,priority:-(a+1)}));e.push(...r!=null?r:[]),e.length>0&&this.updateActiveParticipantsWithPriorities(e)}createParticipantObjFromSocketPeer(s){const t=pg.formatSocketPeerMessage(s);return new Ds(this.context,U(b({},t),{isHost:!1,videoEnabled:!1,audioMuted:!0,videoTrack:void 0,audioTrack:void 0}),this.self,this.roomSocketHandler)}updatePipSource(s,t){var e,r;t?(e=this.pip)==null||e.enableSource(s):(r=this.pip)==null||r.disableSource(s)}onParticipantMediaJoined(s,t,e){if(!this.mediaJoined||s===this.self.id)return;const r=this.participants.joined.get(s);if(!r){this.logger.warn(`Received media.peerJoinedBroadcast for non-existent peer ${s}`);return}this.logger.info("PEER_INFO:::SOCKET_ON_MEDIA_JOIN",{participant:{id:r.id,maskedName:[...(r==null?void 0:r.name)||""].map((i,a)=>a%2?"*":i).join("")}}),this.logger.info(`onParticipantMediaJoined: peer ${s} has joined media room. Processing.`),t.forEach(i=>{i.kind===ns.AUDIO&&!i.screenShare?r.setAudioEnabled(!i.pause):i.kind===ns.VIDEO&&!i.screenShare&&(r.setVideoEnabled(!i.pause),this.updatePipSource(r.id,!i.pause)),r.producers.push(U(b({},i),{producingTransportId:i.producingTransportId,kind:i.kind===ns.AUDIO?"audio":"video",producingPeerId:s,mimeType:i.mimeType}))}),this.roomNodeClient.handlePeerCapabilities(s,e),this.context.getValue("flagsmith").hasFeature(q.FORCE_VIDEO_CODEC)||this.roomNodeClient.shareWebcam(this.self.videoTrack),this.logger.info(`onParticipantMediaJoined: Emitting UPDATE_ACTIVE for peer ${s}`),this.context.getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:this.participants.viewMode,page:this.participants.currentPage})}updateParticipantsMapMinReplacement(s,t){const e=Array.from(s.keys()),r=new Map(s),i=new Set(t),a=[];e.forEach((o,c)=>{(!i.has(o)||!this.participants.joined.get(o))&&a.push(c)}),t.forEach(o=>{if(s.get(o))return;if(e.length<t.length){e.push(o);return}const c=a.shift();e[c]=o}),a.forEach(o=>{e.splice(o,1)}),Array.from(s.keys()).forEach(o=>{s.delete(o,!i.has(o))}),e.forEach(o=>{if(!this.participants.joined.get(o)){this.logger.warn("updateActiveParticipants::participant_not_in_joined_list",{participant:{id:o}});return}s.add(this.participants.joined.get(o),!r.get(o))}),s.emit("participantsUpdate")}updateParticipantsMap(s,t){Array.from(s.keys()).forEach(r=>{t.includes(r)||s.delete(r,!0)}),t.forEach(r=>{s.get(r)||s.add(this.participants.joined.get(r),!0)}),s.emit("participantsUpdate")}updatePinnedParticipants(){this.participants.pinned.forEach(s=>{s.setIsPinned(!1),this.participants.pinned.delete(s.id)})}setupEventsGlobal(){this.roomSocketHandler.on(A.joinRoom,({peer:s})=>{if(!s.waitlisted){const t=this.context.getValue("flagsmith").hasFeature(q.DEBUG_SOCKET_JOIN);t&&this.logger.info("Processing socket join",{peers:s.peerId}),this.onParticipantSocketJoined(this.createParticipantObjFromSocketPeer(s)),t&&this.logger.info("Processed socket join",{peers:s.peerId})}}),this.roomSocketHandler.on(A.leaveRoom,s=>{const{peerId:t}=s.peer;this.selectedPeers.delete(t,this.context),this.onParticipantLeave(t)}),this.context.getValue("peerSessionStore").on(E.SOCKET_SERVICE_ROOM_JOINED,()=>{this.self.permissions.acceptWaitingRequests&&this.roomSocketHandler.getWaitingRoomRequests()}),this.self.permissions.on("permissionsUpdate",s=>{const{acceptWaitingRequests:t}=s;t!==void 0&&(t?this.roomSocketHandler.getWaitingRoomRequests():this.participants.waitlisted.clear())}),this.context.getValue("peerSessionStore").on(E.SOCKET_SERVICE_DISCONNECTED,()=>{this.participants.joined.clear(),this.participants.videoSubscribed.clear(),this.participants.audioSubscribed.clear(),this.participants.pinned.clear(),this.participants.currentPage=0,this.participants.viewMode="ACTIVE_GRID",this.participants.emit("viewModeChanged",{viewMode:"ACTIVE_GRID",currentPage:this.participants.currentPage,pageCount:this.participants.pageCount})}),this.context.getValue("peerSessionStore").on(E.CONSUMER_PAUSED,({id:s})=>{this.processConsumerPaused(s)}),this.context.getValue("peerSessionStore").on(E.CONSUMER_RESUMED,({id:s})=>{this.processConsumerResumed(s)}),this.context.getValue("peerSessionStore").on(E.NEW_CONSUMER,({id:s})=>{this.processNewConsumer(s)}),this.context.getValue("peerSessionStore").on(E.CONSUMER_CLOSED,({id:s})=>{this.processConsumerClosed(s)}),this.context.getValue("peerSessionStore").on(E.ROOM_MESSAGE,r=>l(this,[r],function*({payload:s,type:t,timestamp:e}){this.participants.emit("broadcastedMessage",{type:t,payload:s,timestamp:e})})),this.context.getValue("peerSessionStore").on(E.MESSAGE,r=>l(this,[r],function*({payload:s,type:t,timestamp:e}){t!=="spotlight"&&this.participants.emit("broadcastedMessage",{type:t,payload:s,timestamp:e})})),this.context.getValue("peerSessionStore").on(E.LOW_CONSUMER_SCORE,({peerId:s,score:t,kind:e})=>{const r=this.participants.joined.get(s);r&&(r.emit("poorConnection",{score:t,kind:e}),this.participants.emit("poorConnection",{participantId:s,score:t,kind:e}))}),this.context.getValue("peerSessionStore").on(E.CONSUMER_SCORE_UPDATE,({score:s,kind:t,appData:e,peerId:r,scoreStats:i})=>{var c;const a=t==="video"&&((c=e==null?void 0:e.screenShare)!=null?c:!1),o=this.participants.joined.get(r);o&&(o.emit("mediaScoreUpdate",{kind:t,isScreenshare:a,score:s,participantId:r,scoreStats:i}),this.participants.emit("mediaScoreUpdate",{kind:t,isScreenshare:a,score:s,participantId:r,scoreStats:i}))}),this.context.getValue("peerSessionStore").onAsync(E.KICK_PEER,t=>l(this,[t],function*({peerId:s}){const e=this.participants.joined.get(s);this.roomNodeClient.kick(s),yield this.roomSocketHandler.kick(s),e?e.emit("kicked"):this.participants.joined.emit("kicked",{id:s})})),this.context.getValue("peerSessionStore").on(E.UPDATE_ACTIVE,(...r)=>l(this,[...r],function*({viewMode:s,page:t,createAllConsumers:e}={viewMode:"ACTIVE_GRID",page:0,createAllConsumers:!1}){this.logger.info(`UPDATE_ACTIVE event received - viewMode: ${n(this,Pt).mode}, page: ${t}, CreateAllConsumers: ${e}`),e&&(this.logger.info(`UPDATE_ACTIVE viewMode: ${s}, Page: ${t}, Removing existing subscriptions.`),this.participants.videoSubscribed.clear(),this.participants.audioSubscribed.clear()),this.updateMediaSubscribedMaps(s,{page:t}),this.scheduleSyncConsumers({source:"UPDATE_ACTIVE"})}))}onParticipantPinned(s){return l(this,null,function*(){if(!s){this.self.isPinned&&this.self.setIsPinned(!1),this.participants.pinned.size!==0&&this.updatePinnedParticipants();return}if(s===this.self.id){this.participants.pinned.size!==0&&this.updatePinnedParticipants(),this.self.setIsPinned(!0);return}const t=this.participants.joined.get(s);this.self.isPinned&&this.self.setIsPinned(!1),this.updatePinnedParticipants(),t.setIsPinned(!0),this.participants.pinned.add(t)})}onParticipantSocketJoined(s){return l(this,null,function*(){var t,e,r;this.logger.info(`onParticipantSocketJoined: peer ${s.id} has joined socket edge. Processing.`),this.self.id!==s.id&&!((t=s.flags)!=null&&t.recorder)&&!((e=s.flags)!=null&&e.hidden_participant)&&!((r=s.flags)!=null&&r.hiddenParticipant)&&(this.participants.videoSubscribed.delete(s.id),this.participants.audioSubscribed.delete(s.id),this.participants.joined.add(s),this.participants.waitlisted.delete(s.id),s.stageStatus==="REQUESTED_TO_JOIN_STAGE"&&this.context.getValue("peerSessionStore").emit(E.UPDATE_STAGE_REQUESTS,{request:{displayName:s.name,userId:s.userId,peerId:s.id},add:!0})),this.context.getValue("peerSessionStore").emit(E.PEER_JOINED_INTERNAL,s)})}onParticipantLeave(s){return l(this,null,function*(){const t=this.participants.joined.get(s);this.participants.joined.delete(s,!0,!0),this.participants.pinned.delete(s,!0,!0),this.participants.waitlisted.delete(s,!0,!0),this.roomNodeClient&&(this.roomNodeClient.handlePeerLeaving(s),this.roomNodeClient.closeConsumers(t==null?void 0:t.producers)),t&&t.stageStatus==="REQUESTED_TO_JOIN_STAGE"&&this.context.getValue("peerSessionStore").emit(E.UPDATE_STAGE_REQUESTS,{request:{displayName:t.name,userId:t.userId,peerId:t.id},add:!1});const{currentPage:e}=this.participants,r=this.maxPreferredStreams*(e-1),i=this.participants.videoSubscribed.get(s);this.participants.viewMode==="MANUAL"?this.context.getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:this.participants.viewMode,page:e}):r===0?this.participants.setViewMode("ACTIVE_GRID"):this.participants.joined.size<=r?e===2?this.participants.setViewMode("ACTIVE_GRID"):this.participants.setPage(e-1):i&&this.context.getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:this.participants.viewMode,page:e})})}processMedia(s){var m;const t=this.roomNodeClient.getConsumers(),{peerId:e,kind:r,appData:i,track:a,producerId:o,rtpReceiver:c,paused:d,localId:u}=(m=t.get(s))!=null?m:{};if(!e)return this.logger.warn("processMedia::Peer ID is undefined",{consumer:{id:s,kind:r,peerId:e,appData:{supportsRemoteControl:!!(i!=null&&i.supportsRemoteControl),screenShare:!!(i!=null&&i.screenShare)},remotelyPaused:d,producerId:o}}),{};const p=i;return r==="video"&&p.screenShare!==!0&&this.videoPeerConsumerMap.set(e,s),this.logger.info("ParticipantController::processMedia",{consumer:{id:s,peerId:e,kind:r,appData:p,remotelyPaused:d,producerId:o}}),this.consumerPeerMap.set(s,{type:r,peerId:e,appData:p,remotelyPaused:d,producerId:o}),{peerId:e,kind:r,appData:p,remotelyPaused:d,track:a,producerId:o,rtpReceiver:c,localId:u}}processConsumerClosed(s){const{peerId:t,type:e,appData:r,remotelyPaused:i,producerId:a}=this.consumerPeerMap.get(s)||{},o=this.participants.joined.get(t);if(this.logger.info("ParticipantController::processConsumerClosed",{consumer:{id:s,peerId:t,appData:r,kind:e,remotelyPaused:i,producerId:a}}),this.consumerPeerMap.delete(s),e==="video"&&r.screenShare!==!0&&this.videoPeerConsumerMap.delete(t),!o)return;const c=o.producers.find(u=>u.producerId===a);c&&(c.consumer={id:s,peerId:t,kind:void 0,appData:r,paused:i,producerId:a,rtpReceiver:void 0,localId:void 0});const d=[];r&&r.screenShare?(o.setScreenShareEnabled(!1),this.context.getValue("callstats").consumerSharedMediaState(s,{screen:!1}),o.screenShareTracks.video&&d.push(o.screenShareTracks.video.id),o.screenShareTracks.audio&&d.push(o.screenShareTracks.audio.id),o.screenShareTracks={audio:void 0,video:void 0}):e==="audio"?(o.setAudioEnabled(!1),o.audioTrack&&d.push(o.audioTrack.id),this.context.getValue("callstats").consumerSharedMediaState(s,{audio:!1}),o.audioTrack=void 0):e==="video"&&(o.setVideoEnabled(!1),this.updatePipSource(o.id,!1),o.videoTrack&&d.push(o.videoTrack.id),this.context.getValue("callstats").consumerSharedMediaState(s,{video:!1}),o.videoTrack=void 0),r.e2ee&&d.forEach(u=>{this.context.getValue("peerSessionStore").emit(E.E2EE_INACTIVE_CONSUMER,{peerId:t,trackId:u})})}processConsumerResumed(s){var T;const t=this.processMedia(s),{peerId:e,kind:r,appData:i,track:a,remotelyPaused:o,producerId:c,rtpReceiver:d,localId:u}=t;if(!e)return;this.logger.info("ParticipantController::processConsumerResumed",{consumer:{id:s,peerId:e,kind:r,appData:i,remotelyPaused:o,producerId:c}});const p=this.participants.joined.get(e);if(!p)return;const m=p.producers.find(v=>v.producerId===c);if(m&&(m.consumer={id:s,peerId:e,kind:r,appData:i,paused:o,producerId:c,rtpReceiver:d,localId:u}),i.e2ee&&this.context.getValue("peerSessionStore").emit(E.E2EE_ACTIVE_CONSUMER,{peerId:e,rtpReceiver:d,track:a}),i.screenShare){r==="video"?p.screenShareTracks.video=a:r==="audio"&&(p.screenShareTracks.audio=a),p.setScreenShareEnabled(!0),(T=this.context)==null||T.getValue("callstats").consumerSharedMediaState(s,{screen:!0});return}r==="video"?(p.videoTrack=a,p.setVideoEnabled(!0),this.updatePipSource(p.id,!0),this.context.getValue("callstats").consumerSharedMediaState(s,{video:!0})):r==="audio"&&(p.audioTrack=a,p.setAudioEnabled(p.audioEnabled),this.context.getValue("callstats").consumerSharedMediaState(s,{audio:p.audioEnabled}))}processConsumerPaused(s){this.logger.info(`ParticipantController::processConsumerPaused called for consumerId: ${s}`);const{peerId:t,kind:e,track:r,appData:i,remotelyPaused:a,producerId:o,rtpReceiver:c,localId:d}=this.processMedia(s);if(!t)return;this.logger.info("ParticipantController::processConsumerPaused",{consumer:{id:s,peerId:t,kind:e,appData:i,remotelyPaused:a,producerId:o}});const u=this.participants.joined.get(t);if(!u)return;const p=u.producers.find(m=>m.producerId===o);p&&(p.consumer={id:s,peerId:t,kind:e,appData:i,paused:a,producerId:o,rtpReceiver:c,localId:d}),r&&i.e2ee&&this.context.getValue("peerSessionStore").emit(E.E2EE_INACTIVE_CONSUMER,{peerId:t,trackId:r.id}),e==="video"?(u.videoTrack=r,u.setVideoEnabled(!1),this.updatePipSource(u.id,!1),this.context.getValue("callstats").consumerSharedMediaState(s,{video:!1})):e==="audio"&&(u.audioTrack=r,u.setAudioEnabled(u.audioEnabled),this.context.getValue("callstats").consumerSharedMediaState(s,{audio:u.audioEnabled}))}processNewConsumer(s){const{peerId:t,kind:e,remotelyPaused:r,track:i,appData:a,producerId:o,rtpReceiver:c,localId:d}=this.processMedia(s);if(!t)return;this.logger.info("ParticipantController::processNewConsumer",{consumer:{id:s,peerId:t,kind:e,remotelyPaused:r,appData:a,producerId:o}});const u=this.participants.joined.get(t);if(!u)return;const p=u.producers.find(m=>m.producerId===o);if(p&&(p.consumer={id:s,peerId:t,kind:e,appData:a,paused:r,producerId:o,rtpReceiver:c,localId:d}),a.screenShare){e==="video"?u.screenShareTracks.video=i:e==="audio"&&(u.screenShareTracks.audio=i),(!r||this.self.permissions.isRecorder||this.context.getValue("flagsmith").hasFeature(q.SCREEENSHARE_ERR_HACK))&&u.setScreenShareEnabled(!0),a.supportsRemoteControl&&(u.supportsRemoteControl=!0),this.participants.broadcastMessage("screenshareConsumerCreated",{producerId:o,peerId:t,screenShare:!0,consumerId:s,consumerPeerId:this.self.id}),this.logger.info("ParticipantController::newScreenshareConsumer::screenshareConsumerCreated",{consumer:{id:s,peerId:t,kind:e,remotelyPaused:r,appData:a,producerId:o}});return}e==="video"?(u.videoTrack=i,r||(u.setVideoEnabled(!0),this.updatePipSource(u.id,!0)),this.context.getValue("callstats").consumerSharedMediaState(s,{video:!r})):e==="audio"&&(u.audioTrack=i,r||u.setAudioEnabled(!0),this.context.getValue("callstats").consumerSharedMediaState(s,{audio:!r})),!r&&a.e2ee&&this.context.getValue("peerSessionStore").emit(E.E2EE_ACTIVE_CONSUMER,{peerId:t,rtpReceiver:c,track:i})}static formatSocketPeerMessage(s){var e,r,i,a,o,c;if(!s)return;const t=Ol(s.stageType);return{id:s.peerId,userId:s.userId,name:s.displayName,displayName:s.displayName,stageType:t,customParticipantId:s.customParticipantId,presetId:s.presetId,picture:s.displayPictureUrl,waitlisted:s.waitlisted,stageStatus:t,metadata:{preset_name:(e=s.flags)==null?void 0:e.presetName},recorderType:(r=s.flags)==null?void 0:r.recorderType,flags:{hiddenParticipant:(i=s.flags)==null?void 0:i.hiddenParticipant,hidden_participant:(a=s.flags)==null?void 0:a.hiddenParticipant,recorder:((o=s.flags)==null?void 0:o.recorderType)!==void 0&&((c=s.flags)==null?void 0:c.recorderType)!=="NONE"}}}onSelectedPeers(s,t){return l(this,null,function*(){this.participants.viewMode==="ACTIVE_GRID"&&this.computeActivateParticipants(s,t)})}updateActiveParticipantsWithPriorities(s,t=!1){if(this.participants.viewMode==="MANUAL")return;if(!this.mediaJoined){this.logger.warn("Skipped::ParticipantController::updateActiveParticipantsWithPriorities",{roomJoined:this.mediaJoined});return}s.forEach(r=>{this.selectedPeers.add(r.peerId,r.priority,this.context)});const e=this.selectedPeers.activeSpeakerPeers.at(0);e!==void 0&&e!==this.participants.lastActiveSpeaker&&(this.participants.lastActiveSpeaker=e,this.participants.emit("activeSpeaker",{peerId:e,volume:1})),t&&this.context.getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{viewMode:this.participants.viewMode,page:this.participants.currentPage})}},Pt=new WeakMap,xt=new WeakMap,cn=new WeakMap,Oh);let $s=pg;yi([S.trace("ParticipantController.setupEvents")],$s.prototype,"setupEvents",1);yi([S.trace("ParticipantController.setupEvents")],$s.prototype,"setupEventsGlobal",1);yi([S.trace("ParticipantController.processMedia")],$s.prototype,"processMedia",1);yi([S.trace("ParticipantController.processConsumerClosed")],$s.prototype,"processConsumerClosed",1);yi([S.trace("ParticipantController.processConsumerResumed")],$s.prototype,"processConsumerResumed",1);yi([S.trace("ParticipantController.processConsumerPaused")],$s.prototype,"processConsumerPaused",1);yi([S.trace("ParticipantController.processNewConsumer")],$s.prototype,"processNewConsumer",1);const Y=jt(I.getDefaultPresetV2().permissions);var V,dn,ln,uc,$e,et;const ki=class extends ut{constructor(e,r,i,a=!1){const o=e.getValue("logger");super(o);h(this,$e);h(this,V,void 0);h(this,dn,void 0);h(this,ln,void 0);h(this,uc,e=>{var p,m,T;const u=e,{chat:r,connectedMeetings:i,plugins:a,polls:o,media:c}=u,d=Co(u,["chat","connectedMeetings","plugins","polls","media"]);if(r&&(r.private&&Us(n(this,V).chat.private,r.private),r.public&&Us(n(this,V).chat.public,r.public),this.emit("chatUpdate")),i&&Us(n(this,V).connectedMeetings,i),c){const v=w=>{switch(w){case or.NONE:return I.MediaProductionPermissionType.Allowed;case or.ALLOWED:return I.MediaProductionPermissionType.Allowed;case or.NOT_ALLOWED:return I.MediaProductionPermissionType.NotAllowed;case or.CAN_REQUEST:return I.MediaProductionPermissionType.CanRequest;default:return}},P={audio:void 0,video:void 0,screenshare:void 0};(p=c.audio)!=null&&p.canProduce&&(P.audio={canProduce:v(c.audio.canProduce)}),(m=c.video)!=null&&m.canProduce&&(P.video={canProduce:v(c.video.canProduce)}),(T=c.screenshare)!=null&&T.canProduce&&(P.screenshare={canProduce:v(c.screenshare.canProduce)}),Us(n(this,V).media,P)}a&&(Us(n(this,V).plugins,a),this.emit("pluginsUpdate")),o&&(Us(n(this,V).polls,o),this.emit("pollsUpdate")),Object.keys(d).length!==0&&Us(n(this,V),d),this.emit("permissionsUpdate",e)});if(!r)throw this.logger.error("PermissionPreset::load_preset_permissions_failed"),new _("Could not load preset permissions.","0904");f(this,ln,e),f(this,dn,i),f(this,V,r),a&&this.setupEvents()}setupEvents(){n(this,ln).getValue("peerSessionStore").on(E.UPDATE_PERMISSIONS,n(this,uc))}static fromResponse(e,r,i){return new ki(i,e,r,!0)}static default(e,r){return new ki(e,Y,r)}static init(e,r,i){let a;return i?a=new ki(e,i,r,!0):a=new ki(e,Y,r),a}get mediaRoomType(){return"CF"}get stageEnabled(){var e;return((e=n(this,V))==null?void 0:e.stageEnabled)||n(this,dn)===I.ViewType.Webinar||n(this,dn)===I.ViewType.Livestream}get acceptStageRequests(){var e,r;return this.stageEnabled?((e=n(this,V))==null?void 0:e.acceptStageRequests)||((r=n(this,V))==null?void 0:r.canAcceptProductionRequests):!1}get stageAccess(){var e,r,i;return((e=n(this,V))==null?void 0:e.stageAccess)===I.MediaProductionPermissionType.NotAllowed?I.MediaProductionPermissionType.NotAllowed:((r=n(this,V))==null?void 0:r.stageAccess)===I.MediaProductionPermissionType.CanRequest?I.MediaProductionPermissionType.CanRequest:((i=n(this,V))==null?void 0:i.stageAccess)===I.MediaProductionPermissionType.Allowed||n(this,V).media.audio.canProduce===I.MediaProductionPermissionType.Allowed||n(this,V).media.video.canProduce===I.MediaProductionPermissionType.Allowed||n(this,V).media.screenshare.canProduce===I.MediaProductionPermissionType.Allowed?I.MediaProductionPermissionType.Allowed:n(this,V).media.audio.canProduce===I.MediaProductionPermissionType.CanRequest||n(this,V).media.video.canProduce===I.MediaProductionPermissionType.CanRequest||n(this,V).media.screenshare.canProduce===I.MediaProductionPermissionType.CanRequest?I.MediaProductionPermissionType.CanRequest:I.MediaProductionPermissionType.NotAllowed}get acceptWaitingRequests(){var e,r;return(r=(e=n(this,V))==null?void 0:e.acceptWaitingRequests)!=null?r:Y.acceptWaitingRequests}get requestProduceVideo(){var e,r,i;return((i=(r=(e=n(this,V))==null?void 0:e.media)==null?void 0:r.video)==null?void 0:i.canProduce)===I.MediaProductionPermissionType.CanRequest}get requestProduceAudio(){var e,r,i;return((i=(r=(e=n(this,V))==null?void 0:e.media)==null?void 0:r.audio)==null?void 0:i.canProduce)===I.MediaProductionPermissionType.CanRequest}get requestProduceScreenshare(){var e,r,i;return((i=(r=(e=n(this,V))==null?void 0:e.media)==null?void 0:r.screenshare)==null?void 0:i.canProduce)===I.MediaProductionPermissionType.CanRequest}get canAllowParticipantAudio(){var e,r;return(r=(e=n(this,V))==null?void 0:e.disableParticipantAudio)!=null?r:Y.disableParticipantAudio}get canAllowParticipantScreensharing(){var e,r;return(r=(e=n(this,V))==null?void 0:e.canAcceptProductionRequests)!=null?r:Y.canAcceptProductionRequests}get canAllowParticipantVideo(){var e,r;return(r=(e=n(this,V))==null?void 0:e.disableParticipantVideo)!=null?r:Y.disableParticipantVideo}get canDisableParticipantAudio(){return this.canAllowParticipantAudio}get canDisableParticipantVideo(){return this.canAllowParticipantVideo}get kickParticipant(){var e,r;return(r=(e=n(this,V))==null?void 0:e.kickParticipant)!=null?r:Y.kickParticipant}get pinParticipant(){var e,r;return(r=(e=n(this,V))==null?void 0:e.pinParticipant)!=null?r:Y.pinParticipant}get canRecord(){var e,r;return(r=(e=n(this,V))==null?void 0:e.canRecord)!=null?r:Y.canRecord}get waitingRoomType(){var e,r;return(r=(e=n(this,V))==null?void 0:e.waitingRoomType)!=null?r:Y.waitingRoomType}get waitingRoomBehaviour(){var e,r;return(r=(e=n(this,V))==null?void 0:e.waitingRoomType)!=null?r:Y.waitingRoomType}get plugins(){var e,r;return(r=(e=n(this,V))==null?void 0:e.plugins)!=null?r:Y.plugins}get polls(){var e,r;return(r=(e=n(this,V))==null?void 0:e.polls)!=null?r:Y.polls}get produceVideo(){return this.canProduceVideo}get requestProduce(){return n(this,V).media.audio.canProduce===I.MediaProductionPermissionType.CanRequest||n(this,V).media.video.canProduce===I.MediaProductionPermissionType.CanRequest||n(this,V).media.screenshare.canProduce===I.MediaProductionPermissionType.CanRequest}get canProduceVideo(){var r;const e=(r=n(this,V).media.video.canProduce)!=null?r:Y.media.video.canProduce;return this.stageEnabled&&(n(this,$e,et)==="ACCEPTED_TO_JOIN_STAGE"||n(this,$e,et)==="ON_STAGE")&&e===I.MediaProductionPermissionType.CanRequest?I.MediaProductionPermissionType.Allowed:this.stageEnabled&&(n(this,$e,et)==="OFF_STAGE"||n(this,$e,et)==="REQUESTED_TO_JOIN_STAGE")&&e===I.MediaProductionPermissionType.Allowed?I.MediaProductionPermissionType.NotAllowed:e}get produceScreenshare(){return this.canProduceScreenshare}get canProduceScreenshare(){var r;const e=(r=n(this,V).media.screenshare.canProduce)!=null?r:Y.media.screenshare.canProduce;return this.stageEnabled&&(n(this,$e,et)==="ACCEPTED_TO_JOIN_STAGE"||n(this,$e,et)==="ON_STAGE")&&e===I.MediaProductionPermissionType.CanRequest?I.MediaProductionPermissionType.Allowed:this.stageEnabled&&(n(this,$e,et)==="OFF_STAGE"||n(this,$e,et)==="REQUESTED_TO_JOIN_STAGE")&&e===I.MediaProductionPermissionType.Allowed?I.MediaProductionPermissionType.NotAllowed:e}get produceAudio(){return this.canProduceAudio}get canProduceAudio(){var r;const e=(r=n(this,V).media.audio.canProduce)!=null?r:Y.media.audio.canProduce;return this.stageEnabled&&(n(this,$e,et)==="ACCEPTED_TO_JOIN_STAGE"||n(this,$e,et)==="ON_STAGE")&&e===I.MediaProductionPermissionType.CanRequest?I.MediaProductionPermissionType.Allowed:this.stageEnabled&&(n(this,$e,et)==="OFF_STAGE"||n(this,$e,et)==="REQUESTED_TO_JOIN_STAGE")&&e===I.MediaProductionPermissionType.Allowed?I.MediaProductionPermissionType.NotAllowed:e}get chatPublic(){var e,r,i;return(i=(r=(e=n(this,V))==null?void 0:e.chat)==null?void 0:r.public)!=null?i:Y.chat.public}get chatPrivate(){var e,r,i;return(i=(r=(e=n(this,V))==null?void 0:e.chat)==null?void 0:r.private)!=null?i:Y.chat.private}get connectedMeetings(){var e,r;return(r=(e=n(this,V))==null?void 0:e.connectedMeetings)!=null?r:Y==null?void 0:Y.connectedMeetings}get hiddenParticipant(){var e,r;return(r=(e=n(this,V))==null?void 0:e.hiddenParticipant)!=null?r:Y.hiddenParticipant}get showParticipantList(){var e;return(e=n(this,V).showParticipantList)!=null?e:Y.showParticipantList}get canChangeParticipantRole(){var e,r;return(r=(e=n(this,V))==null?void 0:e.canChangeParticipantPermissions)!=null?r:Y.canChangeParticipantPermissions}get canChangeParticipantPermissions(){var e,r;return(r=(e=n(this,V))==null?void 0:e.canChangeParticipantPermissions)!=null?r:Y.canChangeParticipantPermissions}get canChangeTheme(){return!1}get canPresent(){return n(this,V).media.audio.canProduce===I.MediaProductionPermissionType.Allowed||n(this,V).media.video.canProduce===I.MediaProductionPermissionType.Allowed||n(this,V).media.screenshare.canProduce===I.MediaProductionPermissionType.Allowed}get acceptPresentRequests(){return this.acceptStageRequests}get canEditDisplayName(){var e;return(e=n(this,V).canEditDisplayName)!=null?e:!1}get maxScreenShareCount(){return 1}get isRecorder(){return n(this,V).isRecorder}get canSpotlight(){return n(this,V).canSpotlight}get canLivestream(){return n(this,V).canLivestream}get transcriptionEnabled(){return n(this,V).transcriptionEnabled}};let nl=ki;V=new WeakMap,dn=new WeakMap,ln=new WeakMap,uc=new WeakMap,$e=new WeakSet,et=function(){return n(this,ln).getValue("stageStatus")};var at;class gg extends ut{constructor(e,r){super(r);g(this,"localMediaHandler");h(this,at,void 0);f(this,at,e)}updatePermission(){return l(this,null,function*(){var d,u;const e=(p,m)=>{this.mediaPermissions[p]=m;const T={message:this.mediaPermissions[p],kind:p};m==="DENIED"?n(this,at).getValue("peerSessionStore").emit(E.MEDIA_PERMISSION_ERROR,T):n(this,at).getValue("peerSessionStore").emit(E.MEDIA_PERMISSION_UPDATE,T)};if(Z.getName()==="firefox")return;const r="microphone",i="camera",a=yield(d=navigator==null?void 0:navigator.permissions)==null?void 0:d.query({name:r}),o=yield(u=navigator==null?void 0:navigator.permissions)==null?void 0:u.query({name:i}),c=(p,m)=>{switch(m){case"granted":e(p,"ACCEPTED");break;case"denied":e(p,"DENIED");break;case"prompt":e(p,"NOT_REQUESTED");break}this.localMediaHandler.repopulateAvailableDevices()};a&&(a.onchange=()=>c("audio",a.state)),o&&(o.onchange=()=>c("video",o.state))})}populateMediaPermissionsInCallstats(i){return l(this,arguments,function*({message:e,kind:r}){var a,o,c,d;switch(r){case"audio":{(a=n(this,at))==null||a.getValue("callstats").mediaPermission("AUDIO",e),(o=n(this,at))==null||o.getValue("callstats").mediaPermission("SPEAKER",e);break}case"video":{(c=n(this,at))==null||c.getValue("callstats").mediaPermission("VIDEO",e);break}case"screenshare":{(d=n(this,at))==null||d.getValue("callstats").mediaPermission("SCREENSHARE",e);break}}})}get peerId(){var e;return(e=n(this,at))==null?void 0:e.getValue("peerId")}init(){return l(this,arguments,function*(e={},r=!1,i=null){var a,o,c,d,u,p,m;if(Z.init(),i&&f(this,at,i),!this.localMediaHandler)try{let T=!0;if((a=i==null?void 0:i.getValue("defaults"))!=null&&a.mediaHandler)T=!1,this.localMediaHandler=i.getValue("defaults").mediaHandler.localMediaHandler;else if(navigator.RNLocalMediaHandlerImpl){const{RNLocalMediaHandlerImpl:v}=navigator;this.localMediaHandler=yield v.init(e)}else this.localMediaHandler=new Xe(i,e.constraints,(o=i==null?void 0:i.getValue("defaults"))==null?void 0:o.isNonPreferredDevice,(c=i==null?void 0:i.getValue("defaults"))==null?void 0:c.autoSwitchAudioDevice);if(i==null||i.getValue("peerSessionStore").on(E.MEDIA_PERMISSION_UPDATE,v=>l(this,null,function*(){if(this.populateMediaPermissionsInCallstats({message:v.message,kind:v.kind}),v.message==="NOT_REQUESTED")switch(v==null?void 0:v.kind){case"audio":this.rawAudioTrack&&(this.logger.info("Disabling audio due to media permission update"),this.disableAudio());break;case"video":this.rawVideoTrack&&(this.logger.info("Disabling video due to media permission update"),this.disableVideo());break;default:break}this.emit("mediaPermissionUpdate",v)})),i==null||i.getValue("peerSessionStore").on(E.MEDIA_PERMISSION_ERROR,v=>l(this,null,function*(){const{kind:P,message:w,constraints:C}=v;this.populateMediaPermissionsInCallstats({message:w,kind:P}),P==="audio"?(this.logger.info(`Disabling audio due to media permission error skipping: ${this.localMediaHandler.audioUpdateInProgress}`),this.localMediaHandler.audioUpdateInProgress===!1&&this.disableAudio()):P==="video"&&(this.logger.info(`Disabling video due to media permission error skipping: ${this.localMediaHandler.videoUpdateInProgress}`),this.localMediaHandler.videoUpdateInProgress===!1&&this.disableVideo()),this.logger.error("SelfController::mediaPermissionError",{error:{message:w},constraints:C,mediaPermissionsErrors:{kind:P,message:w}}),this.emit("mediaPermissionError",v),this.emit("mediaPermissionUpdate",{message:w,kind:P})})),T){this.logger.info(`Setting up SelfMedia streams using media handler. audio:${(d=e==null?void 0:e.audio)!=null?d:!0} video:${(u=e==null?void 0:e.video)!=null?u:!0}`);const v=this.localMediaHandler.setupStreams({video:(p=e==null?void 0:e.video)!=null?p:!0,audio:(m=e==null?void 0:e.audio)!=null?m:!0});r||(yield v)}}catch(T){this.logger.error("Self::init::Failed To Setup Streams",{error:{name:T.name,message:T.message}})}})}set context(e){f(this,at,e),this.localMediaHandler.context=e}get audioTrack(){return this.localMediaHandler.audioTrack}get rawAudioTrack(){return this.localMediaHandler.rawAudioTrack}get mediaPermissions(){return this.localMediaHandler.permissions}addAudioMiddleware(e){return l(this,null,function*(){return this.localMediaHandler.addAudioMiddleware(e)})}removeAudioMiddleware(e){return l(this,null,function*(){return this.localMediaHandler.removeAudioMiddleware(e)})}removeAllAudioMiddlewares(){return l(this,null,function*(){return this.localMediaHandler.removeAllAudioMiddlewares()})}get videoTrack(){return this.localMediaHandler.videoTrack}get rawVideoTrack(){return this.localMediaHandler.rawVideoTrack}addVideoMiddleware(e){return l(this,null,function*(){return this.localMediaHandler.addVideoMiddleware(e)})}setVideoMiddlewareGlobalConfig(){return l(this,arguments,function*(e={disablePerFrameCanvasRendering:!1}){return this.localMediaHandler.setVideoMiddlewareGlobalConfig(e)})}removeVideoMiddleware(e){return l(this,null,function*(){return this.localMediaHandler.removeVideoMiddleware(e)})}removeAllVideoMiddlewares(){return l(this,null,function*(){return this.localMediaHandler.removeAllVideoMiddlewares()})}get screenShareTracks(){return this.localMediaHandler.screenShareTracks}get audioEnabled(){return this.localMediaHandler.audioEnabled}get videoEnabled(){return this.localMediaHandler.videoEnabled}get screenShareEnabled(){return this.localMediaHandler.screenShareEnabled}enableAudio(){return l(this,null,function*(){yield this.localMediaHandler.enableAudio(),this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack})})}enableVideo(){return l(this,null,function*(){yield this.localMediaHandler.enableVideo(),this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack})})}disableAudio(){return l(this,null,function*(){this.localMediaHandler.disableAudio(),this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack})})}enableScreenShare(){return l(this,null,function*(){yield this.localMediaHandler.enableScreenShare(),this.emit("screenShareUpdate",{screenShareEnabled:this.screenShareEnabled,screenShareTracks:this.screenShareTracks})})}disableScreenShare(){return l(this,null,function*(){yield this.localMediaHandler.disableScreenShare(),this.emit("screenShareUpdate",{screenShareEnabled:this.screenShareEnabled,screenShareTracks:this.screenShareTracks})})}disableVideo(){return l(this,null,function*(){yield this.localMediaHandler.disableVideo(),this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack})})}getCurrentDevices(){return this.localMediaHandler.getCurrentDevices()}getAudioDevices(){return l(this,null,function*(){return yield this.localMediaHandler.getAudioDevices()})}getVideoDevices(){return l(this,null,function*(){return yield this.localMediaHandler.getVideoDevices()})}getSpeakerDevices(){return l(this,null,function*(){return yield this.localMediaHandler.getSpeakerDevices()})}getDeviceById(e,r){let i;return r==="audio"?i="audioinput":r==="video"?i="videoinput":r==="speaker"&&(i="audiooutput"),this.localMediaHandler.getDeviceById(e,i)}setDevice(e){return l(this,null,function*(){switch(e.kind){case"audioinput":try{yield this.localMediaHandler.setAudioDevice(e,{saveDevicePreference:!0})}catch(r){}finally{this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack})}break;case"audiooutput":yield this.localMediaHandler.setSpeakerDevice(e,{saveDevicePreference:!0});break;case"videoinput":try{yield this.localMediaHandler.setVideoDevice(e,{saveDevicePreference:!0})}catch(r){}finally{this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack})}break}this.emit("deviceUpdate",{device:e})})}}at=new WeakMap;var jb=Object.defineProperty,Gb=Object.getOwnPropertyDescriptor,je=(s,t,e,r)=>{for(var i=r>1?void 0:r?Gb(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&jb(t,e,i),i},un,Ue,hn,he,Ts,Tr,fe,we,pn,jo,ue,ge,gn,mn,Ma,al,Dh;let Ee=(Dh=class extends gg{constructor(t,e,r,i,a){var c;const o=t.getValue("logger");super(t,o);h(this,Ts);h(this,fe);h(this,pn);h(this,ue);h(this,Ma);g(this,"name");g(this,"picture");g(this,"customParticipantId");g(this,"waitlistStatus");h(this,un,void 0);h(this,Ue,void 0);h(this,hn,void 0);g(this,"role");g(this,"userId");g(this,"organizationId");g(this,"supportsRemoteControl",!1);g(this,"device");h(this,he,void 0);g(this,"hidden",!1);g(this,"presetName");g(this,"roomState","init");h(this,gn,new Set);h(this,mn,new Set);f(this,he,t),this.userId=e.id,this.name=e.name,this.picture=e.picture,this.customParticipantId=(c=e.customParticipantId)!=null?c:e.clientSpecificId,this.waitlistStatus="none",f(this,Ue,r),f(this,un,i),this.hidden=!1,f(this,hn,!1),this.organizationId=e.organizationId,this.supportsRemoteControl=Z.isElectron(),this.device=Z.getDeviceInfo(),this.presetName=a,this.updatePermission(),this.updateVideo=this.updateVideo.bind(this),M(this,Ma,al).call(this)}get telemetry(){return n(this,he).getValue("telemetry")}get stageStatus(){return n(this,he).getValue("stageStatus")}get producers(){var t,e;return Array.from((e=(t=n(this,fe,we).getProducers())==null?void 0:t.values())!=null?e:[])}get id(){return this.peerId}get peerId(){return n(this,he).getValue("peerId")}static __init__(t,e,r,i,a,o=!1){return l(this,null,function*(){var T,v,P,w,C,k;let c=(v=(T=t.getValue("defaults"))==null?void 0:T.audio)!=null?v:!0,d=(w=(P=t.getValue("defaults"))==null?void 0:P.video)!=null?w:!0;r.canProduceAudio!=="ALLOWED"&&(c=!1),r.canProduceVideo!=="ALLOWED"&&(d=!1);const u=new Ee(t,e,r,i,a),p=tb(i.mediaConstraints);Us(p,(C=t.getValue("defaults"))==null?void 0:C.mediaConfiguration);const m=(k=t.getValue("defaults"))==null?void 0:k.mediaHandler;return m&&(m.context=t),yield u.init({audio:c,video:d,constraints:p},o,t),u.setupEvents(),u})}cleanupEvents(){this.removeAllListeners("videoUpdate"),this.localMediaHandler.removeAllListeners("AUDIO_TRACK_CHANGE"),this.localMediaHandler.removeAllListeners("VIDEO_TRACK_CHANGE"),this.localMediaHandler.removeAllListeners("DEVICE_CHANGE"),this.localMediaHandler.removeAllListeners("DEVICE_LIST_UPDATED"),this.localMediaHandler.removeAllListeners("SCREENSHARE_TRACK_CHANGE"),this.localMediaHandler.removeAllListeners("SCREENSHARE_ENDED"),this.localMediaHandler.removeAllListeners("AUDIO_TRACK_SILENT"),this.localMediaHandler.removeAllListeners("FORCE_MUTE_AUDIO"),this.localMediaHandler.removeAllListeners("FORCE_MUTE_VIDEO"),n(this,Ue).removeAllListeners("permissionsUpdate")}setupEvents(){this.on("videoUpdate",M(this,Ma,al));const t=n(this,pn,jo);t&&t.onError(e=>{this.emit("autoplayError",e)}),this.localMediaHandler.on("AUDIO_TRACK_CHANGE",()=>l(this,null,function*(){if(this.logger.info("Self::setupEvents::AUDIO_TRACK_CHANGE",b({},vr(this))),n(this,ue,ge)&&this.audioEnabled)try{yield n(this,fe,we).shareMic(this.audioTrack)}catch(e){this.logger.error("Self::setupEvents::Error while sharing mic",{error:e}),this.localMediaHandler.disableAudio()}this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack})})),this.localMediaHandler.on("VIDEO_TRACK_CHANGE",()=>l(this,null,function*(){if(this.logger.info("Self::setupEvents::VIDEO_TRACK_CHANGE",b({},vr(this))),n(this,ue,ge)&&this.rawVideoTrack===void 0)this.logger.info("Self::VIDEO_TRACK_CHANGE::Forcing_disable_video"),this.disableVideo();else if(this.videoEnabled&&n(this,ue,ge))try{const e=yield n(this,fe,we).shareWebcam(this.videoTrack);e&&e.id!==this.videoTrack.id&&n(this,he).getValue("flagsmith").hasFeature(q.EXP_RESHARE)&&(yield n(this,fe,we).shareWebcam(this.videoTrack))}catch(e){this.logger.error("Self::setupEvents::failed shareWebcam",{error:e}),this.videoEnabled&&(yield this.localMediaHandler.disableVideo())}this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack})})),this.localMediaHandler.on("DEVICE_CHANGE",r=>l(this,[r],function*({device:e}){var i;this.emit("deviceUpdate",{device:e}),e.kind==="audiooutput"&&typeof HTMLAudioElement.prototype.setSinkId=="function"&&((i=n(this,pn,jo))==null||i.setSpeakerDevice(e.deviceId))})),this.localMediaHandler.on("DEVICE_LIST_UPDATED",e=>{this.emit("deviceListUpdate",e)}),this.localMediaHandler.on("SCREENSHARE_TRACK_CHANGE",()=>l(this,null,function*(){if(!n(this,ue,ge)){this.logger.error("Self.SCREENSHARE_TRACK_CHANGE.LocalMediaInitialized_WithoutRoomNode");return}if(this.screenShareEnabled)try{yield n(this,fe,we).shareScreen(this.screenShareTracks)}catch(e){this.logger.error("Self::setupEvents::Error while sharing screen",{error:e}),this.screenShareEnabled&&(yield this.localMediaHandler.disableScreenShare())}this.logger.info("Self::setupEvents::SCREENSHARE_TRACK_CHANGE",b({},vr(this))),this.emit("screenShareUpdate",{screenShareEnabled:this.screenShareEnabled,screenShareTracks:this.screenShareTracks})})),this.localMediaHandler.on("SCREENSHARE_ENDED",()=>l(this,null,function*(){this.logger.log("Disabling screenshare due to SCREENSHARE_ENDED"),yield this.disableScreenShare(),this.logger.info("Self::setupEvents::SCREENSHARE_ENDED",b({},vr(this)))})),this.localMediaHandler.on("AUDIO_TRACK_SILENT",()=>{var e;(e=n(this,he))==null||e.getValue("callstats").mediaTrackMuted("AUDIO")}),this.localMediaHandler.on("FORCE_MUTE_AUDIO",()=>{this.disableAudio()}),this.localMediaHandler.on("FORCE_MUTE_VIDEO",()=>l(this,null,function*(){var e;n(this,ue,ge)&&(yield n(this,fe,we).pauseWebcam()),this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack}),(e=n(this,he))==null||e.getValue("callstats").videoOff()})),n(this,Ue).on("permissionsUpdate",e=>{var r,i,a;(r=e==null?void 0:e.media)!=null&&r.audio&&n(this,Ue).canProduceAudio!==I.MediaProductionPermissionType.Allowed&&(this.disableAudio(),this.logger.info(`Disabled audio due to dynamic preset change: canProduceAudio: ${this.permissions.canProduceAudio}`)),(i=e==null?void 0:e.media)!=null&&i.video&&n(this,Ue).canProduceVideo!==I.MediaProductionPermissionType.Allowed&&(this.disableVideo(),this.logger.info(`Disabled video due to dynamic preset change: canProduceVideo: ${this.permissions.canProduceVideo}`)),(a=e==null?void 0:e.media)!=null&&a.screenshare&&n(this,Ue).canProduceScreenshare!==I.MediaProductionPermissionType.Allowed&&(this.disableScreenShare(),this.logger.info(`Disabled screenshare due to dynamic preset change: canProduceScreenshare: ${this.permissions.canProduceScreenshare}`))})}get permissions(){return n(this,Ue)}get config(){return n(this,un)}get roomJoined(){var t;return n(this,un).viewType===I.ViewType.Livestream&&this.stageStatus!=="ON_STAGE"?((t=n(this,he).getValue("connectionHandler"))==null?void 0:t.socketJoined)===!0:n(this,ue,ge)}setName(t){if(!t)throw new _("Name cannot be empty.","1103");this.name=t}setupTracks(){return l(this,arguments,function*(t={}){t.forceReset,yield this.disableAudio(),yield this.disableVideo(),this.localMediaHandler.removeAudioTrack(),this.localMediaHandler.removeVideoTrack(),t.audio&&(yield this.enableAudio()),t.video&&(yield this.enableVideo())})}destructMediaHandler(){return l(this,null,function*(){return this.localMediaHandler.destruct()})}removeDocumentEventListeners(){return l(this,null,function*(){return this.localMediaHandler.removeDocumentEventListeners()})}enableAudio(t){return l(this,null,function*(){var e;if(this.permissions.canProduceAudio!==I.MediaProductionPermissionType.NotAllowed&&!(n(this,Ue).canProduceAudio===I.MediaProductionPermissionType.CanRequest&&(this.stageStatus==="OFF_STAGE"||this.stageStatus==="REQUESTED_TO_JOIN_STAGE"))&&!this.audioEnabled){if((e=n(this,he))==null||e.getValue("callstats").audioOn(),yield this.localMediaHandler.enableAudio(t),n(this,ue,ge)&&this.stageStatus==="ON_STAGE"){if(this.audioTrack)try{yield n(this,fe,we).shareMic(this.audioTrack)}catch(r){this.logger.error("Self::enableAudio::Error while sharing mic",{error:r}),this.localMediaHandler.disableAudio()}if(!this.audioEnabled)return}this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack})}})}enableVideo(t){return l(this,null,function*(){var e;if(n(this,Ue).canProduceVideo!==I.MediaProductionPermissionType.NotAllowed&&!(n(this,Ue).canProduceVideo===I.MediaProductionPermissionType.CanRequest&&(this.stageStatus==="OFF_STAGE"||this.stageStatus==="REQUESTED_TO_JOIN_STAGE"))&&!this.videoEnabled){if((e=n(this,he))==null||e.getValue("callstats").videoOn(),yield this.localMediaHandler.enableVideo(t),n(this,ue,ge)&&this.stageStatus==="ON_STAGE")try{yield n(this,fe,we).shareWebcam(this.videoTrack)}catch(r){this.logger.error("Self::enableVideo::Error while sharing video",{error:r}),this.videoEnabled&&this.localMediaHandler.disableVideo()}this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack}),this.logger.info("Self.enableVideo",b({},vr(this)))}})}updateVideoConstraints(t){return l(this,null,function*(){if(!this.localMediaHandler.updateVideoConstraints)throw new _("Unsupported","1102");yield this.localMediaHandler.updateVideoConstraints(t)})}enableScreenShare(){return l(this,null,function*(){if(!n(this,ue,ge))throw new _("Can`t enable screenshare without joining room","1105");if(n(this,Ue).canProduceScreenshare!==I.MediaProductionPermissionType.NotAllowed&&!(n(this,Ue).canProduceScreenshare===I.MediaProductionPermissionType.CanRequest&&(this.stageStatus==="OFF_STAGE"||this.stageStatus==="REQUESTED_TO_JOIN_STAGE"))&&!this.screenShareEnabled&&(yield this.localMediaHandler.enableScreenShare(),this.screenShareTracks.audio||this.screenShareTracks.video)){try{yield n(this,fe,we).shareScreen(this.screenShareTracks)}catch(t){this.logger.error("Self::enableScreenShare::Error while sharing screen",{error:t}),this.screenShareEnabled&&(yield this.localMediaHandler.disableScreenShare())}this.emit("screenShareUpdate",{screenShareEnabled:this.screenShareEnabled,screenShareTracks:this.screenShareTracks})}})}updateScreenshareConstraints(t){return l(this,null,function*(){if(!this.localMediaHandler.updateScreenshareConstraints)throw new _("Unsupported","1102");yield this.localMediaHandler.updateScreenshareConstraints(t)})}disableAudio(){return l(this,null,function*(){var t;this.audioEnabled&&(this.localMediaHandler.disableAudio(),n(this,ue,ge)&&n(this,fe,we).muteSelf(),this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack}),(t=n(this,he))==null||t.getValue("callstats").audioOff())})}disableVideo(){return l(this,null,function*(){var t;this.videoEnabled&&(yield this.localMediaHandler.disableVideo(),n(this,ue,ge)&&(yield n(this,fe,we).pauseWebcam()),this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack}),(t=n(this,he))==null||t.getValue("callstats").videoOff())})}disableScreenShare(){return l(this,null,function*(){this.screenShareEnabled&&(yield this.localMediaHandler.disableScreenShare(),n(this,ue,ge)&&(yield n(this,fe,we).disableScreenShare()),this.emit("screenShareUpdate",{screenShareEnabled:this.screenShareEnabled,screenShareTracks:this.screenShareTracks}))})}getAllDevices(){return this.localMediaHandler.getAllDevices()}setIsPinned(t,e=!0){var i;f(this,hn,t);const r=t?"pinned":"unpinned";(i=n(this,Ts,Tr))==null||i.updateSource(this.id,{pinned:t}),e&&this.emit(r,this)}get isPinned(){return n(this,hn)}pin(){return l(this,null,function*(){if(!n(this,ue,ge))throw new _("Can`t pin participants without joining room","1105");return this.show(),n(this,fe,we).pinPeer(this.id)})}unpin(){return l(this,null,function*(){if(!n(this,ue,ge))throw new _("Can`t unpin participants without joining room","1105");return n(this,fe,we).pinPeer(null)})}hide(){return l(this,null,function*(){if(!n(this,ue,ge))throw new _("Can`t toggle participant tile without joining room","1105");this.hidden=!0,this.emit("toggleTile",{hidden:this.hidden})})}show(){if(!n(this,ue,ge))throw new _("Can`t toggle participant tile without joining room","1105");this.hidden=!1,this.emit("toggleTile",{hidden:this.hidden})}setDevice(t){return l(this,null,function*(){var r,i,a;if(!t)throw new _("No device selected","1104");const e=this.getCurrentDevices();if(t.deviceId&&(((r=e==null?void 0:e.audio)==null?void 0:r.deviceId)===t.deviceId||((i=e==null?void 0:e.video)==null?void 0:i.deviceId)===t.deviceId||((a=e==null?void 0:e.speaker)==null?void 0:a.deviceId)===t.deviceId)&&(this.logger.warn("Self.setDevice.setting_to_in_use_device",{devices:[t]}),n(this,he).getValue("flagsmith").hasFeature(q.SKIP_SETTING_IN_USE_DEVICE)))throw new _("Cannot set device currently in use","1106");switch(t.kind){case"audioinput":try{yield this.localMediaHandler.setAudioDevice(t,{saveDevicePreference:!0})}catch(o){n(this,ue,ge)&&(yield n(this,fe,we).muteSelf()),this.emit("audioUpdate",{audioEnabled:this.audioEnabled,audioTrack:this.audioTrack})}break;case"audiooutput":yield this.localMediaHandler.setSpeakerDevice(t,{saveDevicePreference:!0});break;case"videoinput":try{yield this.localMediaHandler.setVideoDevice(t,{saveDevicePreference:!0})}catch(o){n(this,ue,ge)&&(yield n(this,fe,we).pauseWebcam()),this.emit("videoUpdate",{videoEnabled:this.videoEnabled,videoTrack:this.videoTrack})}break}})}cleanUpTracks(){var t,e,r,i;(t=this.audioTrack)==null||t.stop(),(e=this.rawAudioTrack)==null||e.stop(),(r=this.videoTrack)==null||r.stop(),(i=this.rawVideoTrack)==null||i.stop()}playAudio(){var t;return(t=n(this,pn,jo))==null?void 0:t.play()}registerVideoElement(t,e=!1){var r,i;t&&(e?n(this,gn).add(t):n(this,mn).add(t),this.updateVideo(t),e||(i=n(this,Ts,Tr))==null||i.addSource(this.id,t,this.videoEnabled,this.isPinned,this.name,this.picture,(r=this.raised)!=null?r:!1))}deregisterVideoElement(t,e=!1){if(!t){n(this,Ts,Tr).removeSource(this.id);return}t.srcObject=void 0,e?n(this,gn).delete(t):(n(this,mn).delete(t),n(this,Ts,Tr).removeSource(this.id))}updateVideo(t,e=!1){var r,i,a;if(this.videoEnabled){if(this.videoTrack==null)return;const o=(r=t.srcObject)==null?void 0:r.getTracks()[0];if((o==null?void 0:o.id)===this.videoTrack.id)return;const c=new MediaStream;c.addTrack(this.videoTrack),t.srcObject=c,e||(i=n(this,Ts,Tr))==null||i.enableSource(this.id)}else t.srcObject=void 0,e||(a=n(this,Ts,Tr))==null||a.disableSource(this.id);t.style.display=this.videoEnabled?"block":"none"}},un=new WeakMap,Ue=new WeakMap,hn=new WeakMap,he=new WeakMap,Ts=new WeakSet,Tr=function(){return n(this,he).getValue("pip")},fe=new WeakSet,we=function(){return n(this,he).getValue("roomNodeClient")},pn=new WeakSet,jo=function(){return n(this,he).getValue("audioPlayback")},ue=new WeakSet,ge=function(){var t;return((t=n(this,he).getValue("connectionHandler"))==null?void 0:t.mediaJoined)===!0},gn=new WeakMap,mn=new WeakMap,Ma=new WeakSet,al=function(){Array.from(n(this,mn)).forEach(t=>this.updateVideo(t,!1)),Array.from(n(this,gn)).forEach(t=>this.updateVideo(t,!0))},Dh);je([S.trace("Self.cleanupEvents")],Ee.prototype,"cleanupEvents",1);je([S.trace("Self.setupEvents")],Ee.prototype,"setupEvents",1);je([S.trace("Self.setupTracks")],Ee.prototype,"setupTracks",1);je([S.trace("Self.destructMediaHandler")],Ee.prototype,"destructMediaHandler",1);je([S.trace("Self.removeDocumentEventListeners")],Ee.prototype,"removeDocumentEventListeners",1);je([Ls.executeWithLock({methodName:"meeting.self.enableAudio",lockName:"Self.toggleAudio",timeout:3e3}),S.trace("Self.enableAudio")],Ee.prototype,"enableAudio",1);je([Ls.executeWithLock({methodName:"meeting.self.enableVideo",lockName:"Self.toggleVideo",timeout:3e3}),S.trace("Self.enableVideo")],Ee.prototype,"enableVideo",1);je([S.trace("Self.updateVideoConstraints")],Ee.prototype,"updateVideoConstraints",1);je([S.trace("Self.enableScreenShare"),Ls.executeWithLock({methodName:"meeting.self.enableScreenShare",lockName:"Self.toggleScreenShare",timeout:3e3})],Ee.prototype,"enableScreenShare",1);je([S.trace("Self.updateScreenshareConstraints")],Ee.prototype,"updateScreenshareConstraints",1);je([Ls.executeWithLock({methodName:"meeting.self.disableAudio",lockName:"Self.toggleAudio",timeout:3e3}),S.trace("Self.disableAudio")],Ee.prototype,"disableAudio",1);je([Ls.executeWithLock({methodName:"meeting.self.disableVideo",lockName:"Self.toggleVideo",timeout:3e3}),S.trace("Self.disableVideo")],Ee.prototype,"disableVideo",1);je([Ls.executeWithLock({methodName:"meeting.self.disableScreenShare",lockName:"Self.toggleScreenShare",timeout:3e3}),S.trace("Self.disableScreenShare")],Ee.prototype,"disableScreenShare",1);je([S.trace("Self.setDevice")],Ee.prototype,"setDevice",1);Ee=je([Ne("1100")],Ee);class $l extends Error{constructor(t){super(t!=null?t:"AwaitQueue stopped"),this.name="AwaitQueueStoppedError",typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,$l)}}class Ul extends Error{constructor(t){super(t!=null?t:"AwaitQueue task removed"),this.name="AwaitQueueRemovedTaskError",typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,Ul)}}var Aa;class ol{constructor(t,e=!1){g(this,"pendingTasks",new Map);g(this,"nextTaskId",0);g(this,"stopping",!1);h(this,Aa,void 0);this.log=e,f(this,Aa,{info:e&&t?t.info:()=>{}})}get size(){return this.pendingTasks.size}push(t,e,r){return l(this,null,function*(){if(e=e!=null?e:t.name,typeof t!="function")throw new TypeError("given task is not a function");if(e)try{Object.defineProperty(t,"name",{value:e})}catch(i){}return new Promise((i,a)=>{const o={id:this.nextTaskId++,task:t,metadata:r,name:e,enqueuedAt:Date.now(),executedAt:void 0,completed:!1,resolve:c=>{if(o.completed)return;o.completed=!0,this.pendingTasks.delete(o.id),i(c);const[d]=this.pendingTasks.values();d&&!d.executedAt&&this.execute(d)},reject:c=>{if(!o.completed&&(o.completed=!0,this.pendingTasks.delete(o.id),a(c),!this.stopping)){const[d]=this.pendingTasks.values();d&&!d.executedAt&&this.execute(d)}}};this.pendingTasks.set(o.id,o),this.pendingTasks.size===1&&this.execute(o)})})}stop(){this.stopping=!0;for(const t of this.pendingTasks.values())t.reject(new $l);this.stopping=!1}remove(t){const e=Array.from(this.pendingTasks.values())[t];e&&e.reject(new Ul)}get(t){return Array.from(this.pendingTasks.values())[t]}dump(){const t=Date.now();let e=0;return Array.from(this.pendingTasks.values()).map(r=>({idx:e++,task:r.task,name:r.name,enqueuedTime:r.executedAt?r.executedAt-r.enqueuedAt:t-r.enqueuedAt,executionTime:r.executedAt?t-r.executedAt:0}))}execute(t){return l(this,null,function*(){if(t.executedAt)throw new Error("task already being executed");t.executedAt=Date.now();try{const e=this.pendingTasks.size,r=yield t.task(),i=Date.now();n(this,Aa).info(`AwaitQueue.push(${t.name})_timings`,{awaitQueueTask:{id:t.id,metadata:t.metadata,queueSizeAtStart:e,execTime:(i-t.executedAt)/1e3,taskStartTime:(t.executedAt-t.enqueuedAt)/1e3}}),t.resolve(r)}catch(e){t.reject(e)}})}}Aa=new WeakMap;function Jb(s,t){const e=new Error(t);return e.name=s,e}class oa extends Error{constructor(t){super(t),this.name="UnsupportedError",Error.hasOwnProperty("captureStackTrace")?Error.captureStackTrace(this,oa):this.stack=new Error(t).stack}}class Ye extends Error{constructor(t){super(t),this.name="InvalidStateError",Error.hasOwnProperty("captureStackTrace")?Error.captureStackTrace(this,Ye):this.stack=new Error(t).stack}}class Sr extends Error{constructor(t){super(t),this.name="TransportConnectionError",Error.hasOwnProperty("captureStackTrace")?Error.captureStackTrace(this,Ye):this.stack=new Error(t).stack}}const ph=s=>new Promise(t=>setTimeout(t,s));function mg(s,t){return l(this,null,function*(){return new Promise((e,r)=>l(this,null,function*(){const{strategy:i,maxRetryCount:a,delayTime:o}=b({strategy:"linear",maxRetryCount:3,delayTime:10},t);let c=0,d,u=!1;const p=m=>{u=!0,r(m)};for(;c<a;){try{const m=yield s(c,p);return e(m)}catch(m){if(d=m,u)break;if(c<a)i==="linear"?yield ph(o*(c+1)):i==="exponential"&&(yield ph(o*(c+Math.max(0,c-1))));else break}c+=1}return r(d)}))})}function Wb(s){return s.map(t=>({channels:t.channels,clockRate:t.clockRate,mimeType:t.mimeType,sdpFmtpLine:t.sdpFmtpLine}))}function Kb(s){return s.map(t=>({uri:t.uri}))}function Do(s){return{codecs:Wb(s.codecs),headerExtensions:Kb(s.headerExtensions?s.headerExtensions:[])}}function zb(s){const t=RTCRtpReceiver.getCapabilities("audio"),e=RTCRtpReceiver.getCapabilities("video"),r=RTCRtpSender.getCapabilities("audio"),i=RTCRtpSender.getCapabilities("video");s&&(e.codecs=e.codecs.filter(({mimeType:d})=>s===d),i.codecs=i.codecs.filter(({mimeType:d})=>s===d));const a={audio:Do(t),video:Do(e)};return{sender:{audio:Do(r),video:Do(i)},receiver:a}}var Pe;class Yb{constructor(t){h(this,Pe,void 0);g(this,"events");f(this,Pe,t),this.events=Bt}joinRoom(t,e,r,i=!1,a=null){return l(this,null,function*(){const o={roomUuid:t,displayName:e,prejoined:i,capabilities:r};return a&&(o.location=a),(yield n(this,Pe).sendMessagePromiseWithTimeout({event:this.events.joinRoom,protobuf:SP.toBinary(o),timeout:5e3})).payload})}connectTransport(t){return l(this,null,function*(){const e=(yield n(this,Pe).sendMessagePromise(this.events.createWebRTCTransport,KS.toBinary(t))).payload,{transportId:r,description:i,producerIds:a}=bp.fromBinary(e),o={sdp:i==null?void 0:i.sdp,type:i.type};return{transportId:r,answer:o,producerIds:a}})}produce(t){return l(this,null,function*(){var a,o;const e=(yield n(this,Pe).sendMessagePromise(this.events.produce,VP.toBinary(t))).payload,r=TE.fromBinary(e);return{answer:{sdp:(a=r==null?void 0:r.description)==null?void 0:a.sdp,type:(o=r==null?void 0:r.description)==null?void 0:o.type},producerId:r.producerId}})}consume(t){return l(this,null,function*(){const e=(yield n(this,Pe).sendMessagePromise(this.events.consume,MP.toBinary(t))).payload,{consumerIdsMap:{map:r},description:i}=mE.fromBinary(e);return{consumerStateMap:r,sessionDescription:i}})}closeProducer(t){return l(this,null,function*(){const e=(yield n(this,Pe).sendMessagePromise(this.events.closeProducer,FP.toBinary(t))).payload,{description:r}=CE.fromBinary(e);return r})}closeConsumer(t){return l(this,null,function*(){return(yield n(this,Pe).sendMessagePromise(this.events.closeConsumer,jP.toBinary(t))).payload})}updateConsumersSimulcastConfig(t){return l(this,null,function*(){return(yield n(this,Pe).sendMessagePromise(this.events.updateConsumersSimulcastConfig,DP.toBinary(t))).payload})}hostControlForPeer(t,e){return l(this,null,function*(){const r={audio:e==="audio",screeShare:!1,video:e==="video",participantId:t},i=(yield n(this,Pe).sendMessagePromise(this.events.hostControlPeer,YP.toBinary(r))).payload;if(!i)return!1;const{status:a}=IE.fromBinary(i);return a==="success"})}hostControlForAll(t){return l(this,null,function*(){const e={audio:t==="audio",screenShare:!1,video:t==="video"},r=(yield n(this,Pe).sendMessagePromise(this.events.hostControlAllPeers,XP.toBinary(e))).payload;if(!r)return!1;const{status:i}=DE.fromBinary(r);return i==="success"})}kickAll(){return l(this,null,function*(){const t={propagateKickAcrossRooms:!1};n(this,Pe).sendMessagePromise(A.kickAll,Op.toBinary(t))})}kickPeer(t){return l(this,null,function*(){n(this,Pe).sendMessagePromise(A.kick,Lp.toBinary(t))})}changeDisplayName(t){return l(this,null,function*(){const e=(yield n(this,Pe).sendMessagePromise(this.events.changeDisplayName,KP.toBinary(t))).payload;if(!e)return!1;const{status:r}=VE.fromBinary(e);return r==="success"})}notifySelfJoinComplete(){return l(this,null,function*(){const t={},e=(yield n(this,Pe).sendMessagePromise(this.events.selfJoinComplete,EP.toBinary(t))).payload;return Hd.fromBinary(e)})}audioActivity(t){return l(this,null,function*(){n(this,Pe).sendMessage(this.events.audioActivity,YS.toBinary(t))})}}Pe=new WeakMap;var Oi=(s=>(s.NEW="new",s.CONNECTING="connecting",s.RECONNECTING="reconnecting",s.DISCONNECTED="disconnected",s.CONNECTED="connected",s.FAILED="failed",s.CLOSED="closed",s))(Oi||{}),Ia;class ad extends Is.EventEmitter{constructor(e){super();h(this,Ia,void 0);f(this,Ia,e),this.setMaxListeners(1/0)}get logger(){return n(this,Ia).getValue("logger")}safeEmit(e,...r){const i=this.listenerCount(e);try{return this.emit(e,...r)}catch(a){return this.logger.error(`EnhancedEventEmitter:: safeEmit() | event listener ${e} threw an error`,{error:a}),Boolean(i)}}safeEmitAsPromise(e,...r){return l(this,null,function*(){const i={}.EVENT_PROMISE_TIMEOUT?parseInt({}.EVENT_PROMISE_TIMEOUT,10):1e4;return this.safeEmitAsPromiseWithTimeout(e,i,...r)})}safeEmitAsPromiseWithTimeout(e,r,...i){return l(this,null,function*(){return new Promise((a,o)=>{setTimeout(o,r,"event request timeout");try{this.emit(e.toString(),...i,a,o)}catch(c){this.logger.error(`EnhancedEventEmitter:: safeEmitAsPromise() | event listener for event ${e.toString()} threw an error [event:%s]:%o`,{error:c}),o(c)}})})}}Ia=new WeakMap;class ql extends ad{constructor(){super(...arguments);g(this,"_sendWebStream",new MediaStream);g(this,"_sendScreenShareStream",new MediaStream);g(this,"_direction");g(this,"pc");g(this,"_transportReady",!1);g(this,"_mapMidTransceiver",new Map);g(this,"enableHighBitrate",!1);g(this,"enableStereo",!1);g(this,"enableDtx",!0)}get midTransceiverMap(){return this._mapMidTransceiver}close(){if(this.logger.debug(`${this.name}::close()`),this.pc)try{this.pc.close()}catch(e){this.logger.error(`${this.name}::pc.close()`,{error:e})}}restartIce(){return l(this,null,function*(){this.logger.debug(`${this.name}::restartIce()`);const e=yield this.pc.createOffer({iceRestart:!0});return this.logger.debug(`${this.name}::restartIce() | calling pc.setLocalDescription() [offer:${JSON.stringify(e)}]`),{offerSdp:e,callback:i=>l(this,null,function*(){this.logger.info(`${this.name}::restartIce() | calling pc.setRemoteDescription() [answer:${JSON.stringify(i)}]`),yield this.pc.setRemoteDescription(i)})}})}init({direction:e,iceServers:r,iceTransportPolicy:i,additionalSettings:a,proprietaryConstraints:o,onTrackHandler:c}){this.logger.debug("HandlerInterface::init()"),this._direction=e,this.pc=new RTCPeerConnection(b({iceServers:r||[],iceTransportPolicy:i||"all",bundlePolicy:"max-bundle",rtcpMuxPolicy:"require"},a),o),c&&this.pc.addEventListener("track",d=>{c(d)}),this._addEventListeners()}connect(){return l(this,null,function*(){this.pc.addTransceiver("audio",{direction:"sendonly"}),this.pc.addTransceiver("video",{direction:"sendonly"});const e=yield this.pc.createOffer();return yield this.pc.setLocalDescription(e),this.logger.info(`connect offer: ${JSON.stringify(e)}`),{offerSdp:e,callback:i=>l(this,null,function*(){this.logger.debug(`${this.name}::connect() | calling pc.setRemoteDescription() [answer:${JSON.stringify(i)}]`),yield this.pc.setRemoteDescription(i)})}})}getTransportStats(){return l(this,null,function*(){return this.pc.getStats()})}_assertSendDirection(){if(this._direction!=="send")throw new Error('method can just be called for handlers with "send" direction')}_assertRecvDirection(){if(this._direction!=="recv")throw new Error('method can just be called for handlers with "recv" direction')}getReceiverStats(e){return l(this,null,function*(){this._assertRecvDirection();const r=this.midTransceiverMap.get(e);if(!r)throw new Error("associated RTCRtpTransceiver not found");return r.receiver.getStats()})}stopSending(e){return l(this,null,function*(){this._assertSendDirection(),this.logger.debug(`stopSending() [localId:${e}]`);const r=this.midTransceiverMap.get(e);if(!r)throw new Error("associated RTCRtpTransceiver not found");r.sender.replaceTrack(null),this.pc.removeTrack(r.sender),r.direction="inactive";const i=yield this.pc.createOffer();return this.logger.debug(`stopSending() | calling pc.setLocalDescription() [offer:${JSON.stringify(i)}]`),yield this.pc.setLocalDescription(i),{offerSdp:i,callback:o=>l(this,null,function*(){this.logger.debug(`stopSending() | calling pc.setRemoteDescription() [answer:${JSON.stringify(o)}]`),yield this.pc.setRemoteDescription(o),this.midTransceiverMap.delete(e)})}})}replaceTrack(e,r){return l(this,null,function*(){this._assertSendDirection(),r?this.logger.debug(`replaceTrack() [localId:${e}, track.id:${r.id}]`):this.logger.debug(`replaceTrack() [localId:${e}, no track]`);const i=this.midTransceiverMap.get(e);if(!i)throw new Error("associated RTCRtpTransceiver not found");yield i.sender.replaceTrack(r)})}setMaxSpatialLayer(e,r){return l(this,null,function*(){this._assertSendDirection(),this.logger.debug(`setMaxSpatialLayer() [localId:${e}, spatialLayer:${r}]`);const i=this.midTransceiverMap.get(e);if(!i)throw new Error("associated RTCRtpTransceiver not found");const a=i.sender.getParameters();a.encodings.forEach((o,c)=>{c<=r?o.active=!0:o.active=!1}),yield i.sender.setParameters(a)})}setRtpEncodingParameters(e,r){return l(this,null,function*(){this._assertSendDirection(),this.logger.debug(`setRtpEncodingParameters() [localId:${e}, params:${JSON.stringify(r)}]`);const i=this.midTransceiverMap.get(e);if(!i)throw new Error("associated RTCRtpTransceiver not found");const a=i.sender.getParameters();a.encodings.forEach((o,c)=>{a.encodings[c]=b(b({},o),r)}),yield i.sender.setParameters(a)})}getSenderStats(e){this._assertSendDirection();const r=this.midTransceiverMap.get(e);if(!r)throw new Error("associated RTCRtpTransceiver not found");return r.sender.getStats()}_addEventListeners(){this.pc.addEventListener("icecandidate",e=>{e.candidate&&this.emit("@icecandidate",{candidate:e.candidate})}),this.pc.addEventListener("iceconnectionstatechange",()=>{switch(this.pc.iceConnectionState){case"checking":this.emit("@connectionstatechange","connecting");break;case"connected":case"completed":this.emit("@connectionstatechange","connected"),this._transportReady=!0;break;case"failed":this.emit("@connectionstatechange","failed");break;case"disconnected":this.emit("@connectionstatechange","disconnected");break;case"closed":this.emit("@connectionstatechange","closed");break;default:this.logger.warn("unknown state");break}}),this.pc.addEventListener("negotiationneeded",()=>{this.emit("@negotiationneeded",{}),this.logger.debug("negotiationneeded")}),this.pc.addEventListener("icegatheringstatechange",()=>{switch(this.pc.iceGatheringState){case"gathering":this.logger.debug("icegatheringstatechange | gathering"),this.emit("@icegatheringstatechange","gathering");break;case"complete":this.logger.debug("icegatheringstatechange | complete"),this.emit("@icegatheringstatechange","complete");break;default:this.logger.warn("unknown state");break}}),this.pc.addEventListener("icecandidateerror",e=>{this.logger.warn("icecandidateerror",{error:{code:e.errorCode,message:e.errorText}})}),this.pc.addEventListener("datachannel",e=>{this.logger.info("data channel created: ",{rtcChannel:{label:e.channel.label}});const{channel:r}=e;r.onopen=()=>{this.logger.info("data channel open: ",{rtcChannel:{label:e.channel.label}}),this.safeEmit("dc_open",e.channel)},r.onclose=()=>{this.logger.warn("data channel closed: ",{rtcChannel:{label:e.channel.label}})},r.onerror=()=>{this.logger.error("data channel error: ",{rtcChannel:{label:e.channel.label}})}}),this.addCustomEventListeners()}addCustomEventListeners(){}}class Hl extends ql{static createFactory(t){return()=>new Hl(t)}get name(){return"Chrome74"}init({direction:t,iceServers:e,iceTransportPolicy:r,additionalSettings:i,proprietaryConstraints:a,onTrackHandler:o}){this._direction=t,this.pc=new RTCPeerConnection(b({iceServers:e||[],iceTransportPolicy:r||"all",bundlePolicy:"max-bundle",rtcpMuxPolicy:"require",sdpSemantics:"unified-plan"},i),a),o&&this.pc.addEventListener("track",c=>{o(c)}),this._addEventListeners()}send(a){return l(this,arguments,function*({track:t,encodings:e,codecOptions:r,screenShare:i}){this._assertSendDirection();const o=this.pc.addTransceiver(t,{direction:"sendonly",streams:[i?this._sendScreenShareStream:this._sendWebStream],sendEncodings:e});if(!navigator.isReactNative){this.logger.debug("creating new transceiver");const u=RTCRtpSender.getCapabilities(typeof t=="string"?t:t.kind);this.logger.info(`senders available params: ${JSON.stringify(u)}`);const p=[];r&&r.length&&r.forEach(m=>{var v;const T=u.codecs.find(P=>P.mimeType.includes(m.name));if(m.parameters){this.logger.debug(`codecOption.parameters:${JSON.stringify(m.parameters)}`);const P=((v=T.sdpFmtpLine)==null?void 0:v.split(";"))||[];P.push(...m.parameters);const w=Array.from(new Set(P).values());T.sdpFmtpLine=w.join(";")}p.push(T)}),this.logger.info(`selected codecs: ${JSON.stringify(p)}`),o.setCodecPreferences(p)}const c=yield this.pc.createOffer();if(yield this.pc.setLocalDescription(c),r&&r.findIndex(({name:u})=>u==="opus")>=0){const{enableDtx:u,enableStereo:p}=this,m=this.enableHighBitrate?p?128e3:64e3:p?64e3:32e3;c.sdp=c.sdp.replace("minptime=10;useinbandfec=1",`minptime=10;useinbandfec=1;${u?"usedtx=1;":""}${p?"stereo=1;sprop-stereo=1;":""}maxaveragebitrate=${m}`),c.sdp+=`a=rtcp-fb:111 nack\r
|
|
5
|
+
`}this.midTransceiverMap.set(o.mid,o);const d=u=>l(this,null,function*(){return this.logger.debug(`send() | calling pc.setRemoteDescription() [answer:${JSON.stringify(u)}]`),yield this.pc.setRemoteDescription(u),o.mid});return this.logger.debug(`send() | calling pc.setLocalDescription() [offer: ${JSON.stringify(c,void 0,2)}]`),{offerSdp:c,callback:d,sender:o.sender,mid:o.mid}})}addCustomEventListeners(){this.pc.addEventListener("datachannel",t=>{const{channel:e}=t;e.onmessage=r=>{this.safeEmit("datachannel",t.channel,String.fromCharCode(...new Uint8Array(r.data)))}})}}class Zo extends ql{constructor(e,r){super(e);g(this,"supportsSendEncodings",!1);this.supportsSendEncodings=r.supportsSendEncodings}static createFactory(e,r){return()=>new Zo(e,r)}get name(){return"Firefox60"}send(o){return l(this,arguments,function*({track:e,encodings:r,codecOptions:i,screenShare:a}){this._assertSendDirection();const c=this.supportsSendEncodings&&r!==void 0?{sendEncodings:r}:{},d=this.pc.addTransceiver(e,b({direction:"sendonly",streams:[a?this._sendScreenShareStream:this._sendWebStream]},c));if(!this.supportsSendEncodings&&r){r.reverse();const T=d.sender.getParameters();T.encodings=r,yield d.sender.setParameters(T)}const u=(T,v)=>{var O;const P=Ot.parse(T),w=P.media[P.media.length-1],C=w.rtp.filter(N=>v.some(L=>L.name===N.codec)),k=w.fmtp.filter(N=>C.some(L=>L.payload===N.payload)),R=(O=w.rtcpFb)==null?void 0:O.filter(N=>C.some(L=>L.payload===N.payload)),D=C.map(N=>N.payload);return P.media[P.media.length-1].rtp=C,P.media[P.media.length-1].fmtp=k,P.media[P.media.length-1].rtcpFb=R,P.media[P.media.length-1].payloads=D.join(" "),Ot.write(P)},p=yield this.pc.createOffer();if(p.sdp=u(p.sdp,i),this.logger.debug(`send() | calling pc.setLocalDescription() [offer:${JSON.stringify(p)}]`),yield this.pc.setLocalDescription(p),e==="audio"||e.kind==="audio"){const{enableDtx:T,enableStereo:v}=this,P=this.enableHighBitrate?v?128e3:64e3:v?64e3:32e3;p.sdp=p.sdp.replace("minptime=10;useinbandfec=1",`minptime=10;useinbandfec=1;${T?"usedtx=1;":""}${v?"stereo=1;sprop-stereo=1;":""}maxaveragebitrate=${P}`)}return this.midTransceiverMap.set(d.mid,d),{offerSdp:p,callback:T=>l(this,null,function*(){return this.logger.debug(`send() | calling pc.setRemoteDescription() [answer:${JSON.stringify(T)}]`),yield this.pc.setRemoteDescription(T),d.mid}),sender:d.sender,mid:d.mid}})}setMaxSpatialLayer(e,r){return l(this,null,function*(){this._assertSendDirection(),this.logger.debug(`setMaxSpatialLayer() [localId:${e}, spatialLayer:${r}]`);const i=this.midTransceiverMap.get(e);if(!i)throw new Error("associated RTCRtpTransceiver not found");const a=i.sender.getParameters(),o=a.encodings.length-1-r;a.encodings.forEach((c,d)=>{d>=o?c.active=!0:c.active=!1}),yield i.sender.setParameters(a)})}addCustomEventListeners(){this.pc.addEventListener("datachannel",e=>{const{channel:r}=e;r.onmessage=i=>l(this,null,function*(){const a=yield i.data.arrayBuffer();this.safeEmit("datachannel",e.channel,String.fromCharCode(...new Uint8Array(a)))})})}}class Fl extends ql{static createFactory(t){return()=>new Fl(t)}get name(){return"Safari12"}send(a){return l(this,arguments,function*({track:t,encodings:e,codecOptions:r,screenShare:i}){this._assertSendDirection(),this.logger.debug("Safari12::creating new transceiver");const o=this.pc.addTransceiver(t,{direction:"sendonly",streams:[i?this._sendScreenShareStream:this._sendWebStream],sendEncodings:e}),c=RTCRtpSender.getCapabilities(typeof t=="string"?t:t.kind);this.logger.info(`Safari12::senders available params: ${JSON.stringify(c)}`);const d=[];r&&r.length>0&&r.forEach(m=>{var v;const T=c.codecs.find(P=>P.mimeType.includes(m.name));if(m.parameters){this.logger.info(`Safari12::codecOption.parameters:, ${JSON.stringify(m.parameters)}`);const P=((v=T.sdpFmtpLine)==null?void 0:v.split(";"))||[];P.push(...m.parameters);const w=[...new Set(P).values()];T.sdpFmtpLine=w.join(";")}d.push(T)}),this.logger.info(`Safari12::selected codecs: ${JSON.stringify(d)}`),o.setCodecPreferences(d);const u=yield this.pc.createOffer();if(yield this.pc.setLocalDescription(u),t==="audio"||t.kind==="audio"){const{enableStereo:m,enableDtx:T}=this,v=this.enableHighBitrate?m?128e3:64e3:m?64e3:32e3;u.sdp=u.sdp.replace("minptime=10;useinbandfec=1",`minptime=10;useinbandfec=1;${T?"usedtx=1;":""}${m?"stereo=1;sprop-stereo=1;":""}maxaveragebitrate=${v}`)}return this.midTransceiverMap.set(o.mid,o),{offerSdp:u,callback:m=>l(this,null,function*(){return this.logger.debug(`Safari12::send() | calling pc.setRemoteDescription() [answer:${JSON.stringify(m)}]`),yield this.pc.setRemoteDescription(m),o.mid}),sender:o.sender,mid:o.mid}})}addCustomEventListeners(){this.pc.ondatachannel=t=>{const{channel:e}=t;e.onmessage=r=>l(this,null,function*(){const i=String.fromCharCode(...new Uint8Array(r.data));this.safeEmit("datachannel",t.channel,i)})}}}function Qb(s,t){return typeof s=="undefined"?t:typeof window!="undefined"&&Object.getOwnPropertyDescriptor(window,"structuredClone")?structuredClone(s):JSON.parse(JSON.stringify(s))}var Oa,Hr,es,hc,ts,Hs,Da,cl,pc,fg,gc,Tg;class Xb extends ad{constructor(e,r){var i;super(e);h(this,ts);h(this,Da);h(this,pc);h(this,gc);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");h(this,Oa,void 0);h(this,Hr,void 0);h(this,es,void 0);h(this,hc,void 0);this.id=r.id,this.localId=r.localId,f(this,Oa,r.handler),this.appData=r.appData,this.peerId=r.producingPeerId,this.producingTransportId=r.producingTransportId,f(this,es,!1),this.producerId=r.producerId,this.track=r.track,f(this,Hr,(i=r.paused)!=null?i:!1),this.mimeType=r.mimeType,this.transceiver=r.transceiver,this.rtpReceiver=r.rtpReceiver,M(this,pc,fg).call(this),f(this,hc,e)}get closed(){return n(this,es)}get kind(){return this.track.kind}get paused(){return n(this,Hr)}close(e,r){n(this,es)||(this.logger.debug(`Consumer::close() ${e?`with reason ${e}`:""}`,n(this,ts,Hs)),f(this,es,!0),r&&(M(this,gc,Tg).call(this),this.transceiver.stop()),this.safeEmit("close",e))}getStats(){return l(this,null,function*(){if(n(this,es))throw new Ye("closed");return n(this,Oa).getReceiverStats(this.localId)})}pause(){if(this.logger.debug("consumer::pause()",n(this,ts,Hs)),n(this,es)){this.logger.error("consumer::pause() | Consumer closed",n(this,ts,Hs));return}f(this,Hr,!0),this.track.enabled=!1,this.safeEmit("pause")}resume(){if(this.logger.debug("consumer::resume()",n(this,ts,Hs)),n(this,es)){this.logger.error("Consumer::resume() | Consumer closed",n(this,ts,Hs));return}f(this,Hr,!1),this.track.enabled=!0,this.safeEmit("resume")}}Oa=new WeakMap,Hr=new WeakMap,es=new WeakMap,hc=new WeakMap,ts=new WeakSet,Hs=function(){return{consumer:{id:this.id,appData:this.appData,peerId:this.peerId,kind:this.kind}}},Da=new WeakSet,cl=function(){this.logger.debug('Consumer::track "ended" event',n(this,ts,Hs)),this.safeEmit("trackended")},pc=new WeakSet,fg=function(){this.track.addEventListener("ended",M(this,Da,cl).bind(this))},gc=new WeakSet,Tg=function(){try{this.track.removeEventListener("ended",M(this,Da,cl)),this.track.stop()}catch(e){this.logger.error("Consumer::destroyTrack()",U(b({},n(this,ts,Hs)),{error:e}))}};var Lt,fn,Tn,Fr,Et,Ce,er,yn,mc,ot,It;class Zb extends ad{constructor(e,r){var i,a;super(e);h(this,ot);g(this,"id");g(this,"localId");h(this,Lt,void 0);g(this,"kind");g(this,"appData");g(this,"rtpSender");h(this,fn,void 0);h(this,Tn,void 0);h(this,Fr,void 0);h(this,Et,!1);h(this,Ce,void 0);h(this,er,void 0);h(this,yn,void 0);h(this,mc,void 0);this.id=r.id,this.localId=r.localId,f(this,Ce,r.track),this.kind=(i=r.track)==null?void 0:i.kind,f(this,er,r.disableTrackOnPause?!((a=r.track)!=null&&a.enabled):!1),f(this,yn,void 0),f(this,fn,r.stopTracks),f(this,Tn,r.disableTrackOnPause),f(this,Fr,r.zeroRtpOnPause),this.appData=r.appData||{},this._onTrackEnded=this._onTrackEnded.bind(this),f(this,Lt,r.handler),this.rtpSender=r.rtpSender,this._handleTrack(),f(this,mc,e)}get closed(){return n(this,Et)}get track(){return n(this,Ce)}get paused(){return n(this,er)}get maxSpatialLayer(){return n(this,yn)}close(e){return l(this,null,function*(){if(n(this,Et))return;if(this.logger.debug(`Producer::close() ${e?`with reason ${e}`:""}`,n(this,ot,It)),f(this,Et,!0),this._destroyTrack(),e===ec){this.safeEmit("close",{reason:e});return}const{offerSdp:r,callback:i}=yield n(this,Lt).stopSending(this.localId),{answer:a}=yield this.safeEmitAsPromise("close",{offer:r,reason:e});i(a)})}getStats(){return l(this,null,function*(){if(n(this,Et))throw new Ye("closed");return n(this,Lt).getSenderStats(this.localId)})}pause(){this.logger.debug("Producer::pause()",n(this,ot,It)),n(this,Et)&&this.logger.error("Producer::pause() | Producer closed",n(this,ot,It)),f(this,er,!0),n(this,Ce)&&n(this,Tn)&&(n(this,Ce).enabled=!1),n(this,Fr)&&n(this,Lt).replaceTrack(this.localId,null),this.emit("pause")}resume(){if(this.logger.debug("Producer::resume()",n(this,ot,It)),n(this,Et)){this.logger.error("Producer::resume() | Producer closed",n(this,ot,It));return}f(this,er,!1),n(this,Ce)&&n(this,Tn)&&(n(this,Ce).enabled=!0),n(this,Fr)&&n(this,Lt).replaceTrack(this.localId,n(this,Ce)),this.emit("resume")}replaceTrack(r){return l(this,arguments,function*({track:e}){if(this.logger.debug(`Producer::replaceTrack() trackId: ${e==null?void 0:e.id}`,n(this,ot,It)),n(this,Et)){if(e&&n(this,fn))try{e.stop()}catch(i){this.logger.error("Producer::replaceTrack",U(b({},n(this,ot,It)),{error:i}))}throw new Ye("closed")}else if(e&&e.readyState==="ended")throw new Ye("track ended");if(e===n(this,Ce)){this.logger.debug(`replaceTrack() | same track, ignored trackId: ${e.id}`,n(this,ot,It));return}(!n(this,Fr)||!n(this,er))&&(yield n(this,Lt).replaceTrack(this.localId,e)),this._destroyTrack(),f(this,Ce,e),this._handleTrack()})}setMaxSpatialLayer(e){return l(this,null,function*(){if(n(this,Et))throw new Ye("closed");if(this.kind!=="video")throw new oa("not a video Producer");if(typeof e!="number")throw new TypeError("invalid spatialLayer");yield n(this,Lt).setMaxSpatialLayer(this.localId,e),f(this,yn,e)})}setRtpEncodingParameters(e){return l(this,null,function*(){if(n(this,Et))throw new Ye("closed");if(typeof e!="object")throw new TypeError("invalid params");yield n(this,Lt).setRtpEncodingParameters(this.localId,e)})}_onTrackEnded(){this.logger.debug(`Producer::track "ended" event trackId: ${this.track.id}`,n(this,ot,It)),this.safeEmit("trackended",this.track.id)}_handleTrack(){n(this,Ce)&&n(this,Ce).addEventListener("ended",this._onTrackEnded)}_destroyTrack(){var e;if(n(this,Ce))try{n(this,Ce).removeEventListener("ended",this._onTrackEnded),n(this,fn)&&n(this,Ce).stop()}catch(r){this.logger.error(`Producer::_destroyTrack trackId: ${(e=this.track)==null?void 0:e.id}`,U(b({},n(this,ot,It)),{error:r}))}}}Lt=new WeakMap,fn=new WeakMap,Tn=new WeakMap,Fr=new WeakMap,Et=new WeakMap,Ce=new WeakMap,er=new WeakMap,yn=new WeakMap,mc=new WeakMap,ot=new WeakSet,It=function(){return{producer:{id:this.id,appData:this.appData,kind:this.kind}}};function yg(s){return typeof s=="object"&&!Array.isArray(s)&&s!==null}function Md(s){return Math.random().toString(36).substring(2,2+s)}const No=1;function gh(s){const t=s;return delete t.payload._bolt,t}function eM(s){return s.payload&&yg(s.payload)}function tM(s){var t,e;return eM(s)&&(e=(t=s.payload._bolt)==null?void 0:t.id)!=null?e:""}var tr,fc,Br;const bi=class extends Is.EventEmitter{constructor(e,r,i,a){super();g(this,"channel");g(this,"queue");g(this,"serverProtocolVersion");h(this,tr,new Map);h(this,fc,void 0);h(this,Br,void 0);g(this,"respond",(e,r,i=!1)=>{let a;i?a=bi.createErrorResponse(e,r):a=bi.createResponse(e,r),this.channel.send(JSON.stringify(a))});g(this,"notify",e=>{const r=bi.createNotification(e);this.channel.send(JSON.stringify(r))});g(this,"request",e=>l(this,null,function*(){const r=bi.createRequest(e),i=new Promise((a,o)=>{const{id:d}=r.payload._bolt,u={id:d,method:r.type,resolve:p=>{this.queue.delete(d)&&(clearTimeout(u.timer),a(p))},timer:setTimeout(()=>{this.queue.delete(d)&&o(new Error(`request timeout for message id: ${d}`))},2e4),cancel:p=>{this.queue.delete(d)&&(clearTimeout(u.timer),o(p))}};this.queue.set(d,u)});return this.channel.send(JSON.stringify(r)),i}));g(this,"send",e=>{const r=JSON.stringify(e),i=16384;if(r.length>i){const a=i-200,o=Math.ceil(r.length/a),c=[];for(let u=0;u<o;u+=1){const p=u*a,m=(u+1)*a;c.push(r.slice(p,m))}const d=As.v4();for(let u=0;u<o;u+=1){const p=c[u],T=JSON.stringify({id:d,count:o,chunkIndex:u,chunk:p});n(this,Br).debug(`Sending message chunk over dc: ${T}`),this.channel.send(T)}}else n(this,Br).debug(`Sending message over dc: ${r}`),this.channel.send(r)});g(this,"processMessage",e=>{var i;n(this,tr).has(e.id)||n(this,tr).set(e.id,[]);const r=n(this,tr).get(e.id);if(r[e.chunkIndex]=e,(r==null?void 0:r.length)===e.count&&!r.some(a=>a===void 0)){const a=n(this,tr).get(e.id),o=a==null?void 0:a.reduce((d,u)=>d+u.chunk,"");n(this,tr).delete(e.id);const c=JSON.parse(o);if(!c.payload||!yg(c.payload))throw new Error("corrupted incoming message over dc",{cause:{code:"CORRUPT_DC_MESSAGE",values:c}});if(this.processBoltHandshake(c))return;if(this.serverProtocolVersion=(i=c.payload._bolt)==null?void 0:i.version,!this.processResponseMsg(c))return c}});g(this,"processResponseMsg",e=>{const{id:r}=e.payload._bolt,i=this.queue.get(r);return i?(n(this,Br).debug(`resolving pending request with id: ${r}, complete response: ${JSON.stringify(e)}`),e.type==="error"?i.cancel(gh(e)):i.resolve(gh(e)),!0):!1});g(this,"processBoltHandshake",e=>{var r,i;return e.type==="_bolt"||e.type==="handshake"?(this.respond((i=(r=e.payload._bolt)==null?void 0:r.id)!=null?i:Md(8),{type:"_bolt",payload:{message:"pong"}}),!0):!1});this.label=i,this.transportId=a,f(this,fc,e),f(this,Br,e.getValue("logger")),this.channel=r,this.queue=new Map}};let yr=bi;tr=new WeakMap,fc=new WeakMap,Br=new WeakMap,g(yr,"createRequest",e=>{var r;if((r=e.payload)!=null&&r._bolt)throw new Error("rpc fields are internal values");return{type:e.type,payload:U(b({},e.payload),{_bolt:{id:Md(8),type:"REQUEST",version:No}})}}),g(yr,"createResponse",(e,r)=>{var i;if((i=r.payload)!=null&&i._bolt)throw new Error("rpc fields are internal values");return{type:r.type,payload:U(b({},r.payload),{_bolt:{id:e,type:"RESPONSE",version:No}})}}),g(yr,"createNotification",e=>{var r;if((r=e.payload)!=null&&r._bolt)throw new Error("rpc fields are internal values");return{type:e.type,payload:U(b({},e.payload),{bolt:{id:Md(8),type:"NOTIFY",version:No}})}}),g(yr,"createErrorResponse",(e,r)=>({type:"error",payload:{error:r.message,_bolt:{id:e,type:"RESPONSE",version:No}}}));const ec="transport closed";var jr;const Mi=class extends ad{constructor(e,{id:r,direction:i,handlerFactory:a,iceServers:o,iceTransportPolicy:c,proprietaryConstraints:d,additionalSettings:u,appData:p,config:m}){var w,C,k;super(e);g(this,"awaitQueue");g(this,"observer");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");h(this,jr,void 0);f(this,jr,e);const T=e.getValue("logger");T.debug(`constructor() [id: ${r}, direction: ${i}]`),this.id=r,this.direction=i;const v=Qb(u,{});delete v.iceServers,delete v.iceTransportPolicy,delete v.bundlePolicy,delete v.rtcpMuxPolicy,delete v.sdpSemantics,this.producers=new Map,this.consumers=new Map,this.datachannels=new Map,this.consumerTrackEvents=new Map,this.unknownTracksMap=new Map,this.awaitQueue=new ol(T,!0),this.handler=a(),this.handler.enableHighBitrate=(w=m==null?void 0:m.enableHighBitrate)!=null?w:!1,this.handler.enableStereo=(C=m==null?void 0:m.enableStereo)!=null?C:!1,this.handler.enableDtx=(k=m==null?void 0:m.enableDtx)!=null?k:!0,this.handler.init({onTrackHandler:this._ontrack.bind(this),direction:i,iceServers:o,iceTransportPolicy:c,additionalSettings:u,proprietaryConstraints:d}),this.appData=p||{};const P=3e4;this.transportConnectionPromise=new Promise(R=>{const D=setTimeout(()=>{T.error("ICE connection timeout - possible firewall blocking WebRTC or TURN unreachable",{transport:{id:this.id,type:this.direction}}),R(!1)},P);this.once("connected",()=>{clearTimeout(D),R(!0)}),this.once("disconnect",()=>{clearTimeout(D),R(!1)}),this.once("close",()=>{clearTimeout(D),R(!1)})}),this.eventsDCReadyPromise=new Promise(R=>{this.eventsDCReadyPromiseResolver=R}),this.handler.on("@connectionstatechange",R=>{R!==this.connectionState&&(this.logger.debug(`connection state changed to ${R}`),this.connectionState=R,R==="connected"&&(this.connected=!0,this.emit("connected")),R==="disconnected"&&(this.connected=!1,this.emit("disconnect")),(R==="failed"||R==="closed")&&(this.connected=!1,this.emit("close")),this.closed||this.safeEmit("connectionstatechange",R))}),this.handler.on("@icecandidate",({candidate:R})=>{this.closed||this.safeEmit("icecandidate",R)}),this.handler.on("dc_open",R=>{let D=this.datachannels.get(R.label);D||(D||(D=new yr(n(this,jr),R,R.label,this.serverId),this.datachannels.set(R.label,D)),this.eventsDCFailureTimer=setTimeout(()=>{R.label==="events"&&(this.eventsDCReadyPromiseResolver(!1),this.safeEmit("dc_error",R.label))},5e3))}),this.handler.on("datachannel",(R,D)=>{R.label==="events"&&(this.eventsDCReadyPromiseResolver(!0),this.eventsDCFailureTimer&&clearTimeout(this.eventsDCFailureTimer));const O=this.datachannels.get(R.label);if(!O){this.logger.error("unregistered datachannel for message",{rtcChannel:{label:R.label,message:D}});return}try{const N=JSON.parse(D);this.logger.debug("datachannel message chunk recieved",{dataChannelMessageChunk:{id:N.id,count:N.count,chunkIndex:N.chunkIndex,chunk:N.chunk,transprtId:this.serverId}});const L=O.processMessage(N);if(!L)return;this.logger.debug(`datachannel message with id:${N.id} on transport:${this.serverId}complete - ${JSON.stringify(L)}`),this.emit(`datachannel:${R.label}`,O.label,L)}catch(N){this.logger.error("error parsing message",{error:N})}})}get closed(){return this.connectionState==="closed"}setServerId(e){this.serverId=e}getDatachannel(e){return this.datachannels.get(e)}get isEventsDCReady(){return this.eventsDCReadyPromise}close(){this.closed||(this.logger.debug("Transport close called"),this.connectionState="closed",this.awaitQueue.stop(),this.awaitQueue=void 0,this.connected=!1,this.handler.close(),Array.from(this.producers.values()).forEach(e=>{e.close(ec).catch(()=>{})}),this.producers.clear(),Array.from(this.consumers.values()).forEach(e=>{e.close(ec)}),this.consumers.clear(),this.consumerTrackEvents.clear(),this.emit("close"))}getStats(){return l(this,null,function*(){if(this.closed)throw new Ye("closed");return this.handler.getTransportStats()})}connect(e){return l(this,null,function*(){try{if(yield this.awaitQueue.push(()=>l(this,null,function*(){const{offerSdp:r,callback:i}=yield this.handler.connect(),{transportId:a,answer:o}=yield e(r);this.setServerId(a),yield i(o)})),!(yield this.transportConnectionPromise))throw new Error("ice connection failed")}catch(r){throw this.logger.error("transport failed to connect:",{error:r}),r}})}restartIce(){return l(this,null,function*(){if(this.logger.debug("restartIce()"),this.closed)throw new Ye("closed");return this.handler.restartIce()})}canProduce(e){return l(this,null,function*(){const{track:r,appData:i}=e;if(r){if(this.direction!=="send")throw new oa("not a sending Transport");if(r.readyState==="ended")throw new Ye("track ended");if(i&&typeof i!="object")throw new TypeError("if given, appData must be an object")}else throw new TypeError("missing track");if(!(yield this.transportConnectionPromise))throw new Sr("transport not connected");return!0})}produce(e,r){return l(this,null,function*(){if(!(yield this.canProduce(e)))throw new Error("Cannot produce");const{track:a,encodings:o,codecOptions:c,stopTracks:d=!0,disableTrackOnPause:u=!0,zeroRtpOnPause:p=!1,appData:m={}}=e;this.logger.debug(`produce() [track:${a.id}]`);const{producerId:T,localId:v,rtpSender:P}=yield this.awaitQueue.push(()=>l(this,null,function*(){const{offerSdp:w,callback:C,sender:k,mid:R}=yield this.handler.send({track:a,encodings:o,codecOptions:c,screenShare:m==null?void 0:m.screenShare}),{answer:D,producerId:O}=yield r({offer:w,kind:a.kind,paused:u?!a.enabled||Object.hasOwn(a,"fakeTracks"):!1,appData:U(b({},m||{}),{mid:R}),codecOptions:c,producingTransportId:this.serverId}),N=yield C(D);return{producerId:O,localId:N,rtpSender:k}}),"Transport.produce");return this.createProducerObject({id:T,localId:v,track:a,stopTracks:d,disableTrackOnPause:u,zeroRtpOnPause:p,appData:m,handler:this.handler,rtpSender:P})})}createProducerObject(e){return l(this,null,function*(){const r=new Zb(n(this,jr),e);return this.producers.set(r.id,r),r.once("close",()=>{this.producers.delete(r.id)}),this.emit("newproducer",r),r})}closeProducer(e){return l(this,null,function*(){yield this.awaitQueue.push(e.close.bind(e),"Transport.closeProducer")})}canConsume(){return l(this,null,function*(){if(this.closed)throw new Ye("closed");if(this.direction!=="recv")throw new oa("not a receiving transport");if(!(yield this.transportConnectionPromise))throw new Sr("transport not connected");return!0})}consume(e,r,i){return l(this,null,function*(){return this.awaitQueue.push(()=>l(this,null,function*(){const a={},{consumerStates:o,sessionDescription:c,failedProducers:d}=yield r(e);o.forEach((p,m)=>{a[m]=this.createConsumerObjectAndWaitForTrack(U(b({},p),{producerId:m}))}),c&&(this.logger.info("Session description found, sending negotiation request"),yield i(c));const u=[];return yield Promise.all(Object.entries(a).map(([p,m])=>m.then(T=>u.push(T)).catch(()=>{this.logger.error(`Failed to create consumer object, producer: ${p}`,{error:{message:"This should not happen"},transport:{serverId:this.serverId}})}))),{consumers:u,failedProducers:d}}),"Transport.consume",{producersLength:e.length})})}static parseCodecAndFmtpMappings(e,r){const i=Ot.parse(e.sdp),a={};return i.media.forEach(o=>{r.includes(o.mid.toString())&&(a[o.mid.toString()]={rtp:o.rtp,fmtp:o.fmtp,payloads:o.payloads,rtcpFb:o.rtcpFb})}),a}static setCodecAndFmtpMappings(e,r,i){const a=Ot.parse(e.sdp);return a.media=a.media.map(c=>{if(r.includes(c.mid.toString())){const d=b({},c);return d.rtp=i[c.mid.toString()].rtp,d.fmtp=i[c.mid.toString()].fmtp,d.payloads=i[c.mid.toString()].payloads,d.rtcpFb=i[c.mid.toString()].rtcpFb,d}return c}),U(b({},e),{sdp:Ot.write(a)})}static parseHeaderExtensionMappings(e){const r=Ot.parse(e.sdp),i={};return r.media.forEach(a=>{i[a.mid]=a.ext}),i}static setHeaderExtensionMappings(e,r){const i=Ot.parse(e.sdp);return i.media=i.media.map(o=>{const c=b({},o);return c.ext=r[o.mid],c}),U(b({},e),{sdp:Ot.write(i)})}closeConsumers(e,r){return l(this,null,function*(){try{const i=e.map(u=>u.transceiver.mid),a=Mi.parseCodecAndFmtpMappings(this.handler.pc.remoteDescription,i),o=Mi.parseHeaderExtensionMappings(this.handler.pc.remoteDescription);this.logger.info("Stopping transceivers",{consumerIds:e.map(({id:u})=>u)}),e.forEach(u=>u.close(void 0,!0));let c=yield this.handler.pc.createOffer();this.logger.info("Created offer for closing consumers",{sdp:c.sdp}),c=Mi.setCodecAndFmtpMappings(c,i,a),c=Mi.setHeaderExtensionMappings(c,o),this.logger.info("Updated codec and fmtp mappings in close consumer offer",{sdp:c.sdp}),yield this.setLocalDescription(c),this.logger.info("Successfully set local description in close consumers");const d=yield r(e,c);this.logger.info("Received answer in close consumers",{sdp:d.sdp}),yield this.setRemoteDescription(d),this.logger.info("Remote description was set successfully in close consumers",{sdp:d.sdp})}catch(i){this.logger.error("Failed to close consumers",{error:i})}})}setRemoteOffer(e){return l(this,null,function*(){try{this.logger.info("Received offer from SFU",{sdp:e.sdp}),yield this.setRemoteDescription(e);const r=yield this.handler.pc.createAnswer();this.logger.info("Created answer corresponding to received offer",{sdp:r.sdp});const i=Ot.parse(r.sdp);return i.media=i.media.map(a=>{if(a.type==="audio"){const o=b({},a),c=o.fmtp.find(u=>u.payload===111);return c&&(c.config+=";stereo=1;sprop-stereo=1"),o.rtcpFb||(o.rtcpFb=[]),o.rtcpFb.some(u=>u.type==="nack")||o.rtcpFb.push({payload:parseInt(o.payloads,10),type:"nack"}),o}return a}),r.sdp=Ot.write(i),this.logger.info("Setting munged SDP",{sdp:r.sdp}),yield this.setLocalDescription(r),this.logger.info("Successfully set local description",{sdp:r.sdp}),r}catch(r){throw this.logger.error("Set remote offer failed",{error:r}),r}})}_ontrack(e){const{track:r,transceiver:i}=e;this.logger.info(`track event received [trackId: ${r.id}] [mid: ${i.mid}]`);const a=`${i.mid}:${r.kind}`;r.addEventListener("ended",()=>{this.logger.info(`rtc consumer track ended [trackId: ${r.id}]`),this.unknownTracksMap.delete(a)});const o=this.consumerTrackEvents.get(a);o?(o(r,i),this.consumerTrackEvents.delete(a)):(this.logger.warn(`track event handler not found ${a}`),this.unknownTracksMap.set(a,e))}sendErrorOverDC(e,r,i){const a=this.getDatachannel(e);if(!a)throw new Error("datachannel not found",{cause:{code:"DC_NOT_FOUND",values:{label:e}}});a.respond(r,i,!0)}sendResponseOverDC(e,r,i){const a=this.getDatachannel(e);if(!a)throw new Error("datachannel not found",{cause:{code:"DC_NOT_FOUND",values:{label:e}}});a.respond(r,i)}createConsumerObjectAndWaitForTrack(e){return l(this,null,function*(){const{consumerId:r,producerId:i,producingPeerId:a,producingTransportId:o,streamId:c,paused:d,screenShare:u,appData:p,kind:m,mimeType:T}=e,v=`${c}:${m}`,P=U(b({},e),{name:"consumer creation task error",message:"consumer creation failed"});return new Promise((w,C)=>l(this,null,function*(){const k=setTimeout(()=>{this.logger.warn(`Timed out waiting for track event ${v} producingPeerId: ${a}`),this.consumerTrackEvents.delete(v),P.isTimedout=!0,C(P)},5e3),R=(O,N)=>{try{if(O.readyState==="ended")clearTimeout(k),C(P);else{const L=O;L.enabled=!0,this.handler.midTransceiverMap.set(N.mid,N);const te=new Xb(n(this,jr),{id:r,localId:N.mid,transceiver:N,track:L,paused:d,producerId:i,producingPeerId:a,producingTransportId:o,handler:this.handler,appData:U(b({},p),{screenShare:u,peerId:a}),rtpReceiver:N.receiver,mimeType:T});this.consumers.set(r,te),te.once("close",()=>{this.consumers.delete(te.id),this.handler.midTransceiverMap.delete(N.mid)}),this.logger.info("consumer created for ",{consumer:{id:r,kind:m,appData:{screenShare:u},peerId:a,producerId:i}}),this.emit("newconsumer",te),clearTimeout(k),w(te)}}catch(L){this.logger.warn("error while creating consumer:",L),clearTimeout(k),C(P)}},D=this.unknownTracksMap.get(v);D?(this.logger.info(`track event already received [trackId: ${D.track.id}] [mid: ${D.transceiver.mid}]`),this.unknownTracksMap.delete(v),R(D.track,D.transceiver)):(this.logger.info(`Registering onTrack handler for key ${v} [producingPeerId: ${a}]`),this.consumerTrackEvents.set(v,R))}))})}setRemoteDescription(e){return l(this,null,function*(){yield this.handler.pc.setRemoteDescription(e)})}setLocalDescription(e){return l(this,null,function*(){this.logger.debug(`${this.direction}() {transportId: ${this.serverId}} | calling pc.setLocalDescription() [offer:${JSON.stringify(e)}]`),yield this.handler.pc.setLocalDescription(e)})}sendDataChannelMessage(e,r){return l(this,null,function*(){const i=this.getDatachannel(e);if(!i)throw Jb("DC_NOT_READY",`${e} datachannel not ready`);const a=(yield i.request(r)).payload;return this.logger.info(`sendDataChannelMessage::response ${JSON.stringify(a)}`),a})}};let dl=Mi;jr=new WeakMap;function sM(s){if(typeof navigator=="object"&&navigator.product==="ReactNative"){if(typeof RTCPeerConnection=="undefined"){s.warn("Device::this._detectDevice() | unsupported ReactNative without RTCPeerConnection");return}return s.debug("Device::this._detectDevice() | ReactNative handler chosen"),"Chrome74"}if(typeof navigator=="object"&&typeof navigator.userAgent=="string"){const t=navigator.userAgent,e=$h.getParser(t),r=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(r.name&&r.name.toLowerCase()==="blink"){const i=t.match(/(?:(?:Chrome|Chromium))[ /](\w+)/i);return i?Number(i[1])>=74?"Chrome74":void 0:"Chrome74"}if(r.name.toLowerCase()==="webkit"&&e.getOS().name.toLowerCase()==="ios")return typeof RTCRtpTransceiver!="undefined"&&RTCRtpTransceiver.prototype.hasOwnProperty("currentDirection")?"Safari12":void 0;s.warn("Device::this._detectDevice() | browser not supported");return}s.warn("Device::this._detectDevice() | unknown device")}var ys,Gr;class rM{constructor(t,{handlerName:e,handlerFactory:r}={}){g(this,"handlerFactory");h(this,ys,void 0);h(this,Gr,void 0);const i=t.getValue("logger");if(i.debug("constructor()"),f(this,ys,t),f(this,Gr,i),e&&r)throw new TypeError("just one of handlerName or handlerInterface can be given");if(r)this.handlerFactory=r;else{if(e)n(this,Gr).debug(`Device::constructor() | handler given: ${e}`);else if(e=sM(n(this,Gr)),e)n(this,Gr).debug(`Device::constructor() | detected handler: ${e}`);else throw new Error("device not supported");switch(e){case"Chrome74":this.handlerFactory=Hl.createFactory(n(this,ys));break;case"Safari12":this.handlerFactory=Fl.createFactory(n(this,ys));break;case"Firefox60":this.handlerFactory=Zo.createFactory(n(this,ys),{supportsSendEncodings:!1});break;case"Firefox110":this.handlerFactory=Zo.createFactory(n(this,ys),{supportsSendEncodings:!0});break;default:throw new TypeError(`unknown handlerName "${e}"`)}}}createTransport(t){const e=As.v4();return new dl(n(this,ys),U(b({id:e},t),{handlerFactory:this.handlerFactory}))}}ys=new WeakMap,Gr=new WeakMap;const iM=2e3;var vn,Ae,Ie,Na,Va,Jr,Sn,xa,Pn,Wr,ss,En,Go,La,ll,Tc,vg,$a,ul,yc,Sg,vc,Pg,Sc,Eg,Pc,wg,Ec,Cg,Ua,hl,qa,pl;class nM extends Is.EventEmitter{constructor(e,r){super();h(this,En);h(this,La);h(this,Tc);h(this,$a);h(this,yc);h(this,vc);h(this,Sc);h(this,Pc);h(this,Ec);h(this,Ua);h(this,qa);g(this,"context");h(this,vn,void 0);h(this,Ae,void 0);h(this,Ie,void 0);h(this,Na,void 0);h(this,Va,void 0);h(this,Jr,void 0);h(this,Sn,void 0);h(this,xa,void 0);h(this,Pn,{transportFailureCount:{send:0,recv:0},lastConnectionTime:0});h(this,Wr,void 0);h(this,ss,"all");this.context=e,f(this,Jr,r),f(this,vn,new rM(e)),f(this,Sn,new Yb(r)),f(this,xa,Bt),n(this,En,Go).mediaState={send:{state:Oi.NEW},recv:{state:Oi.NEW}},(Dn(this.context,"forceRelay")||this.context.getValue("flagsmith").hasFeature(q.FORCE_RELAY))&&f(this,ss,"relay"),this.logger.info(`ICE Transport Policy initially set to ${n(this,ss)}`),M(this,La,ll).call(this)}get telemetry(){return this.context.getValue("telemetry")}get logger(){return this.context.getValue("logger")}get socket(){return n(this,Jr)}get socketHandler(){return n(this,Sn)}get sendTransport(){return n(this,Ae)}get recvTransport(){return n(this,Ie)}get events(){return n(this,xa)}set sendTransportConnectedCallback(e){f(this,Na,e)}set recvTransportConnectedCallback(e){f(this,Va,e)}setupTransports(e){return l(this,null,function*(){yield M(this,Tc,vg).call(this,e);let r,i;e.send&&(r=M(this,$a,ul).call(this,n(this,Ae)).then(a=>{try{n(this,Na).call(this,a)}catch(o){this.logger.error("Failed to run send transport callback")}})),e.recv&&(i=M(this,$a,ul).call(this,n(this,Ie)).then(a=>{try{n(this,Va).call(this,a)}catch(o){this.logger.error("Failed to run recv transport callback")}})),yield Promise.all([r,i])})}stopTransports(e){var r,i;if(e.send&&this.sendTransport!==void 0){const{id:a,serverId:o,direction:c}=n(this,Ae);this.logger.info("Closing send transport",{transport:{id:a,serverId:o,type:c}}),n(this,Ae).close(),n(this,Ae).removeAllListeners(),f(this,Ae,void 0)}if(e.recv&&this.recvTransport!==void 0){const{id:a,serverId:o,direction:c}=n(this,Ie);this.logger.info("Closing recv transport",{transport:{id:a,serverId:o,type:c}}),(r=n(this,Ie))==null||r.close(),(i=n(this,Ie))==null||i.removeAllListeners(),f(this,Ie,void 0)}M(this,La,ll).call(this)}stopAllTransports(){this.logger.info("Closing all transports"),this.stopTransports({send:!0,recv:!0})}handleErrors(e){throw new Error("Method not implemented.")}}vn=new WeakMap,Ae=new WeakMap,Ie=new WeakMap,Na=new WeakMap,Va=new WeakMap,Jr=new WeakMap,Sn=new WeakMap,xa=new WeakMap,Pn=new WeakMap,Wr=new WeakMap,ss=new WeakMap,En=new WeakSet,Go=function(){return this.context.getValue("connectionHandler")},La=new WeakSet,ll=function(){f(this,Wr,{send:void 0,recv:void 0})},Tc=new WeakSet,vg=function(e){return l(this,null,function*(){var o,c,d,u,p,m,T,v;(Dn(this.context,"forceRelay")||this.context.getValue("flagsmith").hasFeature(q.FORCE_RELAY))&&f(this,ss,"relay"),this.logger.info(`ICE Transport Policy set to ${n(this,ss)}`);const a=yield De().getICEServers().catch(P=>(this.logger.warn(`failed to get iceservers from server: ${P.message}`),[]));if(e.send){const P=this.context.getValue("flagsmith").hasFeature(q.DISABLE_OPUS_DTX_CF);M(this,vc,Pg).call(this,{iceServers:a,additionalSettings:{encodedInsertableStreams:(o=this.context.getValue("modules").e2ee)==null?void 0:o.enabled},config:{enableHighBitrate:(u=(d=(c=this.context.getValue("defaults").mediaConfiguration)==null?void 0:c.audio)==null?void 0:d.enableHighBitrate)!=null?u:!1,enableStereo:(T=(m=(p=this.context.getValue("defaults").mediaConfiguration)==null?void 0:p.audio)==null?void 0:m.enableStereo)!=null?T:!1,enableDtx:!!P},iceTransportPolicy:n(this,ss)})}e.recv&&M(this,Sc,Eg).call(this,{iceServers:a,additionalSettings:{encodedInsertableStreams:(v=this.context.getValue("modules").e2ee)==null?void 0:v.enabled},iceTransportPolicy:n(this,ss)})})},$a=new WeakSet,ul=function(e){return l(this,null,function*(){const{id:r,serverId:i,direction:a}=e;M(this,Pc,wg).call(this,e);try{return yield mg((c,d)=>l(this,null,function*(){c>0&&this.logger.debug(`Retrying transport connect, count: ${c}`,{transport:{id:r,serverId:i,type:a}});try{if(e.closed)throw new Sr("Cannot reconnect closed transport");yield M(this,yc,Sg).call(this,e)}catch(u){if(u instanceof Sr){d(u);return}throw this.logger.error("Failed to connect transport, retrying",{transport:e,error:u}),u}}),{delayTime:100,strategy:"exponential",maxRetryCount:15}),e}catch(o){throw this.logger.error(`Failed to connect send transport after retry: ${e.id}`,{error:o,transport:{id:r,serverId:i,type:a}}),e.close(),e.removeAllListeners(),o}})},yc=new WeakSet,Sg=function(e){return l(this,null,function*(){const{id:r,direction:i}=e;if(this.logger.info(`Connecting ${i} transport`,{transport:{id:r,type:i}}),!n(this,Jr).isConnected)throw new Sr("Socket is not connected");if(e.connectionState==="closed")throw new Sr("Transport is closed");try{yield e.connect(a=>M(this,Ec,Cg).call(this,i,a)),this.logger.info(`Connected ${i} transport`,{transport:{id:r,serverId:e.serverId,type:i}})}catch(a){throw n(this,Pn).transportFailureCount[i]+=1,a.message==="ice connection failed"?new Sr(a.message):a}})},vc=new WeakSet,Pg=function(e){var r,i;if(n(this,Ae)&&n(this,Ae).connected){this.logger.info("Transport send is already connected",{transport:{id:(r=n(this,Ae))==null?void 0:r.id,serverId:(i=n(this,Ae))==null?void 0:i.serverId,type:"send"}});return}f(this,Ae,n(this,vn).createTransport(U(b({},e),{direction:"send"}))),this.context.getValue("callstats").configureSendTransport(n(this,Ae))},Sc=new WeakSet,Eg=function(e){var r,i;if(n(this,Ie)&&n(this,Ie).connected){this.logger.info("Transport recv is already connected",{transport:{id:(r=n(this,Ie))==null?void 0:r.id,serverId:(i=n(this,Ie))==null?void 0:i.serverId,type:"recv"}});return}f(this,Ie,n(this,vn).createTransport(U(b({},e),{direction:"recv"}))),this.context.getValue("callstats").configureRecvTransport(n(this,Ie))},Pc=new WeakSet,wg=function(e){const{direction:r,id:i}=e;e.on("connectionstatechange",a=>l(this,null,function*(){M(this,qa,pl).call(this,{state:a,direction:r}),this.logger.info(`Transport connection state changed for ${r} transport`,{transport:{id:i,serverId:e.serverId,type:r,status:a}});const o=()=>{const c=n(this,Wr)[r];c!==void 0&&(clearTimeout(c),n(this,Wr)[r]=void 0)};switch(a){case"connected":o(),n(this,Pn).lastConnectionTime=performance.now();break;case"disconnected":n(this,Wr)[r]=setTimeout(()=>l(this,null,function*(){this.logger.warn(`${r} transport is in disconnected state, reconnecting transport`,{transport:{id:i,serverId:e.serverId,type:r}}),yield M(this,Ua,hl).call(this,e.direction)}),iM);break;case"failed":if(e.closed)return;o(),this.logger.warn(`${r} transport is in failed state, reconnecting transport`,{transport:{id:i,serverId:e.serverId,type:r}}),yield M(this,Ua,hl).call(this,e.direction);break}})),e.on("icecandidate",a=>l(this,null,function*(){this.logger.debug("Sending iceCandidate:",{iceCandidate:a})})),e.on("datachannel:events",(a,o)=>l(this,null,function*(){var c,d;this.logger.debug("Got data channel message on event:",{rtcChannel:{label:a,message:o}});try{switch(o.type){case"handshake":{const u={type:"handshake",payload:{message:"pong"}};e.sendResponseOverDC(a,tM(o),u);break}case"hub-disconnect":{this.logger.debug(`media hub disconnected, full_reconnect: ${(c=o.payload)==null?void 0:c.full_reconnect}`),((d=o.payload)==null?void 0:d.full_reconnect)===!0&&this.handleErrors("rejoin");break}case"error":break;default:break}}catch(u){this.logger.error(`Unable to handle the incoming datachannel message on channel ${a}`)}})),e.on("dc_error",()=>{e.direction==="recv"&&(this.logger.warn("Events datachannel did not open in 5s",{country:S.location.country}),this.handleErrors("reconnectRecvTransport"))})},Ec=new WeakSet,Cg=function(e,r){return l(this,null,function*(){const i=e==="recv";try{const{sdp:a,type:o}=r,c={consuming:i,description:{sdp:a,type:o,target:i?Os.SUBSCRIBER:Os.PUBLISHER},producers:[]};return n(this,Sn).connectTransport(c)}catch(a){throw this.logger.error(`Error in ${e} transport connection:`,{error:a,country:S.location.country}),a}})},Ua=new WeakSet,hl=function(e){return l(this,null,function*(){switch(this.logger.info("Called reconnect transport",{transport:{type:e}}),this.stopTransports({[e]:!0}),this.context.getValue("flagsmith").hasFeature(q.CF_TRANSPORT_FORCE_RELAY_ON_ICE_FAILED)&&n(this,Jr).isConnected&&n(this,Pn).transportFailureCount[e]>2&&(this.logger.warn(`Multiple disconnections in ${e} transport, forcing relay`),f(this,ss,"relay")),yield this.setupTransports({[e]:!0}),e){case"send":{this.logger.info("Transport reconnected",{transport:n(this,Ae)}),this.context.getValue("peerSessionStore").emit(E.RESET_PRODUCER_STATE);break}case"recv":{this.logger.info("Transport reconnected",{transport:n(this,Ie)}),this.context.getValue("peerSessionStore").emit(E.UPDATE_ACTIVE,{createAllConsumers:!0});break}default:this.logger.warn("Unknown transport direction",{transport:{type:e}})}M(this,qa,pl).call(this,{state:Oi.CONNECTED,direction:e})})},qa=new WeakSet,pl=function(e){const{state:r,direction:i}=e;n(this,En,Go).mediaState[i]={state:r},this.context.getValue("peerSessionStore").emit(E.TRANSPORT_STATE_UPDATE,b({transport:i},n(this,En,Go).mediaState[i]))};var Ha,wt;class aM{constructor(t,e,r,i,a){h(this,Ha,void 0);h(this,wt,void 0);this.events=e,this.recvTransport=r,this.socket=i,this.socketHandler=a,f(this,Ha,t),f(this,wt,t.getValue("logger"))}create(t){return l(this,null,function*(){if(!t||t&&t.length===0)throw new Error("List of producers is required");const e=new Map,r=[];t.forEach(d=>{const{producingPeerId:u,producerId:p,producingTransportId:m}=d,T=n(this,Ha).getValue("flagsmith").hasFeature(q.ENABLE_CF_SIMULCAST)?{simulcast:{preferredRid:"h",priorityOrdering:"asciibetical",ridNotAvailable:"asciibetical"}}:{};e.set(p,u),r.push(b({producingPeerId:u,producerId:p,producingTransportId:m},T))});const i=yield this.socketHandler.consume({requests:r,consumingTransportId:this.recvTransport.serverId}),a=new Map;t.forEach(d=>a.set(d.producerId,d));const o=new Map,c=[];return Object.entries(i.consumerStateMap).forEach(([d,u])=>{const p=a.get(d);if(!p)return;if(u.errorCode){n(this,wt).warn(`Consumer request failed for producer ${d}`,{error:{message:u.errorCode}}),c.push(U(b({},p),{errorCode:u.errorCode}));return}let m={};try{m=JSON.parse(u.producerState.appData)}catch(T){}o.set(d,{consumerId:u.consumerId,producingTransportId:p.producingTransportId,producingPeerId:p.producingPeerId,kind:p.kind,paused:p.pause,streamId:u.producerTrack.streamId,trackId:u.producerTrack.trackId,screenShare:p.screenShare,mimeType:p.mimeType,appData:m})}),{consumerStates:o,sessionDescription:i.sessionDescription,failedProducers:c}})}negotiate(t){return l(this,null,function*(){try{n(this,wt).info("Negotiating socket consumer",{transport:this.recvTransport}),n(this,wt).debug(`setting remote offer: ${JSON.stringify(t)} on recvTransport`,{transport:this.recvTransport});const e=yield this.recvTransport.setRemoteOffer(t),r={transportId:this.recvTransport.serverId,description:{sdp:e.sdp,type:e.type,target:Os.SUBSCRIBER}};return n(this,wt).debug(`sending renegotiate request: ${JSON.stringify(r)} on recvTransport`,{transport:this.recvTransport}),yield this.socket.sendMessagePromise(this.events.renegotiateSessionDescription,ZS.toBinary(r)),n(this,wt).info("Renegotiation done",{transport:this.recvTransport}),e}catch(e){n(this,wt).error("Failed to renegotiate",{error:e});return}})}close(t){return l(this,null,function*(){if(!t.length)return{};const e=(r,i)=>l(this,null,function*(){const a=r.map(u=>u.localId);n(this,wt).info(`Closing consumers: ${JSON.stringify(a)}`);const o={description:{sdp:i.sdp,type:i.type,target:Os.SUBSCRIBER},consumerIds:a,consumingTransportId:this.recvTransport.serverId},c=yield this.socketHandler.closeConsumer(o),d=RE.fromBinary(c).description;return{sdp:d.sdp,type:d.type}});return yield this.recvTransport.awaitQueue.push(()=>this.recvTransport.closeConsumers(t,e),"ConsumerStrategy.close",{consumersLength:t.length}),{}})}switchConsumersToLayer(t,e){return l(this,null,function*(){const r={requests:[],consumingTransportId:this.recvTransport.serverId},i=t.filter(a=>a&&a.id);i.forEach(({id:a,producingTransportId:o,localId:c})=>{r.requests.push({producerId:a,producingTransportId:o,mid:c,simulcast:{preferredRid:e===0?"q":"h",priorityOrdering:"asciibetical",ridNotAvailable:"asciibetical"}})}),yield this.socketHandler.updateConsumersSimulcastConfig(r),n(this,wt).info(`Consumers switched layers to ${e}`,{consumerIds:i==null?void 0:i.map(({id:a})=>a)})})}}Ha=new WeakMap,wt=new WeakMap;class Bl{constructor(t){this.socketHandler=t}static getMSIDFromSDP(t,e){return Ot.parse(t).media.filter(a=>e==="video"?a.type==="video":a.type==="audio").at(-1).msid}create(c){return l(this,arguments,function*({offer:t,kind:e,paused:r,appData:i,codecOptions:a,producingTransportId:o}){var T,v;const d=Bl.getMSIDFromSDP(t.sdp,e),u={description:{sdp:t.sdp,type:t.type,target:Os.PUBLISHER},paused:r,kind:e,msid:d,appData:JSON.stringify(i),screenShare:(T=i.screenShare)!=null?T:!1,mimeType:`${e}/${(v=a[0])==null?void 0:v.name}`,producingTransportId:o},{answer:p,producerId:m}=yield this.socketHandler.produce(u);return{answer:p,producerId:m}})}}var Kr,sr,wn,Fa,rs,wc,vs,Cn,Ba,gl,Cc,_g,_c,Rg,Rc,kg,kc,bg;class oM extends nM{constructor(e,r){super(e,r);h(this,Ba);h(this,Cc);h(this,_c);h(this,Rc);h(this,kc);h(this,Kr,void 0);h(this,sr,void 0);h(this,wn,void 0);h(this,Fa,void 0);h(this,rs,void 0);h(this,wc,{producerCreationFailureCount:0,consumerCreationFailureCount:0,producerNotReadyFailureCount:0});h(this,vs,[]);h(this,Cn,void 0);this.context=e,this.sendTransportConnectedCallback=()=>l(this,null,function*(){f(this,Fa,new Bl(this.socketHandler))}),this.recvTransportConnectedCallback=i=>l(this,null,function*(){n(this,wn).clear(),f(this,rs,new aM(this.context,this.events,i,this.socket,this.socketHandler))}),this.reset()}get socketHandler(){return super.socketHandler}get producers(){return n(this,Kr)}get consumers(){return n(this,sr)}get producerIdToConsumerIdMap(){return n(this,wn)}get logger(){return this.context.getValue("logger")}reset(){f(this,Kr,new Map),f(this,sr,new Map),f(this,wn,new Map)}createProducer(e,r){return l(this,null,function*(){var i;if(!this.sendTransport||this.sendTransport.closed)throw new Error("Send transport is closed");try{const a=yield this.sendTransport.produce(e,M(this,Cc,_g).bind(this));return(i=e.appData)!=null&&i.e2ee&&this.context.getValue("peerSessionStore").emit(E.E2EE_ACTIVE_PRODUCER,a),M(this,_c,Rg).call(this,a,r),a}catch(a){throw this.logger.error("Failed to create producer",{error:a}),n(this,wc).producerCreationFailureCount+=1,a}})}closeProducer(e,r){return l(this,null,function*(){var a;const i=this.producers.get(e);if(!i){this.logger.warn(`Producer with ID ${e} was not found`);return}r!=null&&r.stopTrack&&i.track.stop();try{yield this.sendTransport.closeProducer(i),(a=this.context.getValue("modules").e2ee)!=null&&a.enabled&&this.context.getValue("peerSessionStore").emit(E.E2EE_INACTIVE_PRODUCER,i)}catch(o){this.logger.error("Failed to close producer on server",{error:o,producer:i})}})}closeAllProducers(){return Promise.all(Array.from(n(this,Kr).entries()).map(([,e])=>e.close()))}createConsumer(e){return this.createConsumers([e])}createConsumers(e){return l(this,null,function*(){n(this,Cn)||clearTimeout(n(this,Cn)),f(this,vs,n(this,vs).concat(e)),yield M(this,Ba,gl).call(this)})}closeConsumer(e){return this.closeConsumers([e])}closeConsumers(e){return l(this,null,function*(){if(!n(this,rs))return;const r=e.map(a=>this.consumers.get(a)).filter(a=>a!==void 0);if(r.length===0)return;const{failedConsumers:i}=yield n(this,rs).close(r);i!=null&&i.length&&this.logger.warn("Failed to close some consumers",{consumerIds:i})})}closeAllConsumers(){return this.closeConsumers(Array.from(n(this,sr).keys()))}switchConsumersToLayer(e,r){return l(this,null,function*(){n(this,rs).switchConsumersToLayer(e,r)})}}Kr=new WeakMap,sr=new WeakMap,wn=new WeakMap,Fa=new WeakMap,rs=new WeakMap,wc=new WeakMap,vs=new WeakMap,Cn=new WeakMap,Ba=new WeakSet,gl=function(){return l(this,null,function*(){if(!this.recvTransport||this.recvTransport.closed)throw new Error("Recv transport is closed");const e=500,r=n(this,vs).splice(0,n(this,vs).length);try{const i=new Set(Array.from(this.consumers.values()).map(({producerId:d})=>d)),a=r.filter(({producerId:d})=>!this.producers.get(d)&&!i.has(d));if(a.length===0)return;const{consumers:o,failedProducers:c}=yield this.recvTransport.consume(a,M(this,Rc,kg).bind(this),n(this,rs).negotiate.bind(n(this,rs)));if(o.forEach(M(this,kc,bg).bind(this)),c!=null&&c.length){this.logger.error("Failed to create consumers for producers",{producers:c});const d=c.filter(({errorCode:u,producerId:p})=>u==="not_found_track_error"?(this.logger.error(`Track not found for producer: ${p}. This will not be retried.`),!1):u==="backend_error"?(this.logger.error("Unrecoverable error: backend error"),!1):!0);f(this,vs,n(this,vs).concat(d)),f(this,Cn,setTimeout(M(this,Ba,gl).bind(this),e))}}catch(i){if(this.logger.error("failed to consume on transport",{error:i}),i.errorCode==="internal_error"&&i.errorDescription==="Backend error"||i.errorCode==="invalid_session_description"){this.logger.error("Irrecoverable error, closing current recvTransport to create a new one",{transport:this.recvTransport,error:{code:i.errorCode,message:i.errorDescription}});try{this.stopTransports({recv:!0})}catch(a){}yield this.setupTransports({recv:!0})}}})},Cc=new WeakSet,_g=function(e){return n(this,Fa).create(e)},_c=new WeakSet,Rg=function(e,r){e.on("close",(i,a)=>l(this,null,function*(){const{offer:o,reason:c}=i;if(this.logger.info("producer::closing",{debuggingHint:c,producer:U(b({},e),{status:"closing"})}),c!==ec){const d={producerId:e.id,description:{sdp:o.sdp,type:o.type,target:Os.PUBLISHER}};try{const u=yield this.socketHandler.closeProducer(d),p={sdp:u==null?void 0:u.sdp,type:u==null?void 0:u.type};this.logger.info("producer::closed",{producer:U(b({},e),{status:"closed"})}),a({answer:p})}catch(u){this.logger.error("producer close error",u)}}this.producers.delete(e.id),r()})),e.on("trackended",()=>{this.logger.info("producer::trackended",{producer:U(b({},e),{status:"UNKNOWN"})})}),n(this,Kr).set(e.id,e)},Rc=new WeakSet,kg=function(e){return l(this,null,function*(){try{return yield this.recvTransport.canConsume(),yield n(this,rs).create(e)}catch(r){throw this.logger.error("Error in consume request",{error:r}),r}})},kc=new WeakSet,bg=function(e){e.on("close",r=>l(this,null,function*(){this.logger.debug("consumer closed",{consumer:{closureReason:r,id:e.id,kind:e.kind,appData:e.appData}}),n(this,sr).delete(e.id),this.context.getValue("peerSessionStore").emit(E.CONSUMER_CLOSED,{id:e.id})})),n(this,sr).set(e.id,e),this.producerIdToConsumerIdMap.set(e.producerId,e.id),this.context.getValue("peerSessionStore").emit(E.NEW_CONSUMER,{id:e.id,appData:e.appData,peerId:e.peerId})};var ja,Ga,Ja,_n,Rn,kn,Wa,Ka,bn,We,$t,Ut,zr,Yr,Ss,za,bc,Mg,Mc,Ag,Ac,Ig,Ic,Og;const Oc=class{constructor({initialEnergyThreshold:t=.015,zeroCrossingThreshold:e=20,minVoiceDuration:r=3,hangoverFrames:i=5,noiseAdaptationRate:a=.95,voiceAdaptationRate:o=.99,minEnergyThreshold:c=.005,maxEnergyThreshold:d=.2,energyRatioThreshold:u=1.5,noiseHistorySize:p=50}={}){h(this,bc);h(this,Mc);h(this,ja,void 0);h(this,Ga,void 0);h(this,Ja,void 0);h(this,_n,void 0);h(this,Rn,void 0);h(this,kn,void 0);h(this,Wa,void 0);h(this,Ka,void 0);h(this,bn,void 0);h(this,We,void 0);h(this,$t,void 0);h(this,Ut,!1);h(this,zr,0);h(this,Yr,0);h(this,Ss,[]);h(this,za,void 0);f(this,_n,t),f(this,We,t),f(this,ja,e),f(this,Ga,r),f(this,Ja,i),f(this,Rn,a),f(this,kn,o),f(this,Wa,c),f(this,Ka,d),f(this,bn,u),f(this,za,p),f(this,$t,t/2)}get voiceDetected(){return n(this,Ut)}processAudioChunk(t){var o,c;const e=M(o=Oc,Ac,Ig).call(o,t),r=M(c=Oc,Ic,Og).call(c,t);return M(this,bc,Mg).call(this,e),e/n(this,$t)>n(this,bn)&&e>n(this,We)&&r>n(this,ja)?(f(this,zr,n(this,zr)+1),f(this,Yr,n(this,Ja)),n(this,zr)>=n(this,Ga)&&f(this,Ut,!0)):(f(this,zr,0),n(this,Yr)>0?f(this,Yr,n(this,Yr)-1):n(this,Ut)&&f(this,Ut,!1),n(this,Ut)||M(this,Mc,Ag).call(this,e)),{energy:e,isVoice:n(this,Ut)}}reset(){f(this,Ut,!1),f(this,zr,0),f(this,Yr,0),f(this,We,n(this,_n)),f(this,$t,n(this,_n)/2),f(this,Ss,[])}getThresholdInfo(){return{currentEnergyThreshold:n(this,We),backgroundNoiseEnergy:n(this,$t),energyRatioThreshold:n(this,bn)}}};let Yn=Oc;ja=new WeakMap,Ga=new WeakMap,Ja=new WeakMap,_n=new WeakMap,Rn=new WeakMap,kn=new WeakMap,Wa=new WeakMap,Ka=new WeakMap,bn=new WeakMap,We=new WeakMap,$t=new WeakMap,Ut=new WeakMap,zr=new WeakMap,Yr=new WeakMap,Ss=new WeakMap,za=new WeakMap,bc=new WeakSet,Mg=function(t){n(this,Ut)?f(this,We,n(this,kn)*n(this,We)+(1-n(this,kn))*t):f(this,We,n(this,Rn)*n(this,We)+(1-n(this,Rn))*n(this,$t)),f(this,We,Math.max(n(this,Wa),Math.min(n(this,Ka),n(this,We))))},Mc=new WeakSet,Ag=function(t){if(t<n(this,We)*1.2)if(n(this,Ss).push(t),n(this,Ss).length>n(this,za)&&n(this,Ss).shift(),n(this,Ss).length>=10){const e=[...n(this,Ss)].sort((i,a)=>i-a),r=Math.floor(e.length/2);f(this,$t,e[r])}else f(this,$t,.95*n(this,$t)+.05*t)},Ac=new WeakSet,Ig=function(t){return Math.sqrt(t.map(e=>e*e).reduce((e,r)=>e+r)/t.length)},Ic=new WeakSet,Og=function(t){let e=0;for(let r=1;r<t.length;r+=1)(t[r]>=0&&t[r-1]<0||t[r]<0&&t[r-1]>=0)&&(e+=1);return e},h(Yn,Ac),h(Yn,Ic);var Ya;class mh{constructor(t){g(this,"RNAudioSampleHandler");h(this,Ya,void 0);f(this,Ya,t);const{RNAudioSampleHandlerImpl:e}=navigator;e==null||e.init().then(r=>{this.RNAudioSampleHandler=r}).catch(r=>{this.logger.error("ReactNativeAudioSampler: Failed to initialize audio sampler",r)})}get logger(){return n(this,Ya).getValue("logger")}get samples(){var e;const t=new Float32Array(1024);return(e=this.RNAudioSampleHandler)==null||e.getFloatTimeDomainData(t),t}stop(){var t;(t=this.RNAudioSampleHandler)==null||t.destructor()}}Ya=new WeakMap;var Qa;class fh{constructor(t){g(this,"audioContext");g(this,"analyser");h(this,Qa,void 0);f(this,Qa,t),this.audioContext=new AudioContext,this.analyser=this.audioContext.createAnalyser(),this.analyser.fftSize=2048}get logger(){return n(this,Qa).getValue("logger")}get samples(){if(this.audioContext.state==="suspended")try{this.audioContext.resume()}catch(e){this.logger.error("AudioContextSampler: Failed to resume audio context",e)}const t=new Float32Array(this.analyser.frequencyBinCount);return this.analyser.getFloatTimeDomainData(t),t}set audioTrack(t){const e=new MediaStream;e.addTrack(t),this.audioContext.createMediaStreamSource(e).connect(this.analyser)}}Qa=new WeakMap;class cM{static setInterval(t,e=0,...r){return navigator&&navigator.RNBackgroundTimerImpl?navigator.RNBackgroundTimerImpl.setInterval(t,e,...r):global.setInterval(t,e,...r)}static clearInterval(t){return navigator&&navigator.RNBackgroundTimerImpl?navigator.RNBackgroundTimerImpl.clearInterval(t):global.clearInterval(t)}static setTimeout(t,e=0,...r){return navigator&&navigator.RNBackgroundTimerImpl?navigator.RNBackgroundTimerImpl.setTimeout(t,e,...r):global.setTimeout(t,e,...r)}static clearTimeout(t){return navigator&&navigator.RNBackgroundTimerImpl?navigator.RNBackgroundTimerImpl.clearTimeout(t):global.clearTimeout(t)}}const dM=60,lM=400;var Ps,Es,qt,Xa,Qr,Mn,ws,rr,An,Cs,_s,is,Dc,Dg,Za,ml,Nc,Ng,Vc,Vg;const ea=class{constructor(t,e){h(this,Dc);h(this,Nc);h(this,Ps,void 0);h(this,Es,void 0);h(this,qt,void 0);h(this,Xa,void 0);h(this,Qr,void 0);h(this,Mn,void 0);h(this,ws,void 0);h(this,rr,void 0);h(this,An,void 0);h(this,Cs,void 0);h(this,_s,void 0);h(this,is,void 0);this.reportRequest=e,f(this,Cs,t),f(this,Mn,new Yn);const{isReactNative:r}=navigator;f(this,_s,r?new mh(n(this,Cs)):new fh(n(this,Cs))),f(this,is,r?cM:Vo)}get logger(){return n(this,Cs).getValue("logger")}set producerId(t){f(this,qt,t)}set audioTrack(t){f(this,Xa,t),n(this,_s)instanceof fh&&(n(this,_s).audioTrack=t)}start(){this.logger.debug(`AudioActivityReporter: Starting audio activity reporter: ${n(this,qt)}`),n(this,Ps)&&n(this,is).clearInterval(n(this,Ps)),f(this,Ps,n(this,is).setInterval(()=>l(this,null,function*(){var i;if(!n(this,Xa)||!n(this,qt))return;const{energy:t}=M(this,Dc,Dg).call(this),e=M(i=ea,Za,ml).call(i,t);let r=.9;n(this,An)!==e&&n(this,An)?r=.9:e?r=.3:r=.5,f(this,Qr,(n(this,Qr)||0)*(1-r)+t*r)}),dM)),n(this,Es)&&n(this,is).clearInterval(n(this,Es)),f(this,Es,n(this,is).setInterval(M(this,Nc,Ng).bind(this),lM))}stop(){try{this.logger.debug(`AudioActivityReporter: Stopping audio activity reporter: ${n(this,qt)}`),n(this,Ps)&&(n(this,is).clearInterval(n(this,Ps)),f(this,Ps,void 0)),n(this,Es)&&(n(this,is).clearInterval(n(this,Es)),f(this,Es,void 0))}catch(t){}n(this,Mn).reset(),n(this,_s)instanceof mh&&n(this,_s).stop()}};let Qn=ea;Ps=new WeakMap,Es=new WeakMap,qt=new WeakMap,Xa=new WeakMap,Qr=new WeakMap,Mn=new WeakMap,ws=new WeakMap,rr=new WeakMap,An=new WeakMap,Cs=new WeakMap,_s=new WeakMap,is=new WeakMap,Dc=new WeakSet,Dg=function(){var o;const{samples:t}=n(this,_s),{energy:e,isVoice:r}=n(this,Mn).processAudioChunk(t),i=M(o=ea,Vc,Vg).call(o,e);return n(this,Cs).getValue("flagsmith").hasFeature(q.ENABLE_AUDIO_ACTIVITY_DEBUG_LOGS)&&this.logger.debug(`AudioActivityReporter: producer: ${n(this,qt)}, energy: ${n(this,Qr)},
|
|
6
|
+
slogScale: ${i}, isVoice: ${r}, minEnergy: ${n(this,ws)},
|
|
7
|
+
maxEnergy: ${n(this,rr)}`),i===-1/0||e<1e-6?{energy:0,isVoice:!1}:((!n(this,ws)||i<n(this,ws))&&f(this,ws,i),(!n(this,rr)||i>n(this,rr))&&f(this,rr,i),{energy:(i-n(this,ws))/(n(this,rr)-n(this,ws))*10||0,isVoice:r})},Za=new WeakSet,ml=function(t){return t<5},Nc=new WeakSet,Ng=function(t=n(this,Qr)){var r;if(!n(this,qt)||!t){n(this,Cs).getValue("flagsmith").hasFeature(q.ENABLE_AUDIO_ACTIVITY_DEBUG_LOGS)&&this.logger.debug(`AudioActivityReporter: No producerId or energy to report: ${n(this,qt)}`);return}const e={producerId:n(this,qt),energy:Math.round(t),silent:M(r=ea,Za,ml).call(r,t)};f(this,An,e.silent),this.reportRequest(e)},Vc=new WeakSet,Vg=function(t){const e=Math.log10(t);return Math.round(e)},h(Qn,Za),h(Qn,Vc);const uM=(s=!1)=>{if("MediaStreamTrackGenerator"in window&&"AudioData"in window)try{const e=new window.MediaStreamTrackGenerator({kind:"audio"}),r=e.writable.getWriter(),i=48e3,a=128,o=1;let c=0,d=null;const u=()=>l(exports,null,function*(){try{const T=new Float32Array(a*o),v=new window.AudioData({format:"f32",sampleRate:i,numberOfFrames:a,numberOfChannels:o,timestamp:c,data:T});c+=a/i*1e6,yield r.ready,yield r.write(v)}catch(T){d&&clearInterval(d),r.releaseLock(),e.writable.abort()}});d=window.setInterval(u,100);const m=new MediaStream([e]).getAudioTracks()[0];return m.addEventListener("ended",()=>{d&&clearInterval(d),r.releaseLock(),e.writable.abort()}),Object.assign(m,{fakeTracks:"fakeTracks:fakeAudioTrack"}),m.enabled=s,m}catch(e){}const t=window.AudioContext||window.webkitAudioContext;if(t)try{const e=new t;if(!e||e.state!=="running"||!e.destination)return;const r=e.createOscillator();r.frequency.value=0,r.type="sine";const i=e.createGain();i.gain.value=0,r.connect(i);const a=e.createMediaStreamDestination();i.connect(a),r.start();const o=a.stream.getAudioTracks()[0];return o?(Object.assign(o,{fakeTracks:"fakeTracks:fakeAudioTrack"}),o.enabled=s,o):void 0}catch(e){return}},hM=(s=!1)=>{var a,o;const t=new MediaStream().getVideoTracks()[0],e=document.createElement("canvas");e.height=(a=t==null?void 0:t.getSettings().height)!=null?a:720,e.width=(o=t==null?void 0:t.getSettings().width)!=null?o:1280;const r=e.getContext("2d");r.fillStyle="black",r.fillRect(0,0,e.width,e.height),setInterval(()=>{r.fillStyle="black",r.fillRect(0,0,e.width,e.height)},1e3);const i=e.captureStream().getVideoTracks()[0];return Object.assign(i,{fakeTracks:"fakeTracks:fakeVideoTrack"}),i.enabled=s,i};var pM=Object.defineProperty,gM=Object.getOwnPropertyDescriptor,J=(s,t,e,r)=>{for(var i=r>1?void 0:r?gM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&pM(t,e,i),i};const Ze=["video/VP9","video/VP8"];var eo,to,Oe,x,In,qe,Xr,Zr,ei,so,Ct,Rs,ro,ti,si,He,Ke,ir,Ci,xc,Lg,Lc,$g,$c,Ug,io,fl,Uc,Ad,qg,qc,Hg,Hc,Fg,Fc,Bg,_e,Ve,ri,Xn,Bc,jg,jc,Gg,Gc,Jg;const xg=(Ad=class{constructor(s,t){h(this,ir);h(this,xc);h(this,Lc);h(this,$c);h(this,io);h(this,qc);h(this,Hc);h(this,Fc);h(this,_e);h(this,ri);h(this,Bc);h(this,jc);h(this,Gc);g(this,"context");g(this,"authToken");g(this,"e2ee");h(this,eo,void 0);h(this,to,void 0);h(this,Oe,void 0);h(this,x,void 0);h(this,In,void 0);h(this,qe,void 0);h(this,Xr,void 0);h(this,Zr,void 0);h(this,ei,void 0);h(this,so,void 0);h(this,Ct,null);h(this,Rs,void 0);h(this,ro,void 0);h(this,ti,void 0);h(this,si,void 0);h(this,He,void 0);h(this,Ke,void 0);var r,i;this.context=s;const{socket:e}=t;this.mediaJoined=!1,f(this,ti,new Map([["video/VP9",new Set],["video/VP8",new Set]])),f(this,si,new Map([["video/VP9",new Set],["video/VP8",new Set]])),f(this,Oe,e),f(this,Xr,!1),f(this,x,new oM(s,e)),f(this,qe,n(this,x).events),f(this,Rs,new Set),f(this,He,new Map),f(this,Zr,!1),f(this,ei,new ol(s.getValue("logger"))),f(this,Ke,new Qn(this.context,n(this,x).socketHandler.audioActivity.bind(n(this,x).socketHandler))),this.e2ee=(i=(r=s.getValue("modules").e2ee)==null?void 0:r.enabled)!=null?i:!1,this.handleSocketEvents(),this.handleCallstatsEvents(),f(this,so,bl(()=>l(this,null,function*(){if(!n(this,ir,Ci).mediaJoinAttempted)return;const{roomJoined:a}=yield this.joinRoom(n(this,to),n(this,eo),!0,!0);a&&(this.context.getValue("peerSessionStore").emit(E.RESET_PRODUCER_STATE),this.context.getValue("peerSessionStore").emit(E.ROOM_NODE_RECONNECTED))}),5e3,{leading:!0,maxWait:1e3}))}get peerId(){return this.context.getValue("peerId")}get telemetry(){return this.context.getValue("telemetry")}get logger(){return this.context.getValue("logger")}get mediaJoined(){return n(this,ir,Ci).mediaJoined}set mediaJoined(s){n(this,ir,Ci).mediaJoined=s}reset(){n(this,x).closeAllProducers(),n(this,x).closeAllConsumers(),n(this,He).clear(),n(this,Rs).clear(),f(this,Ct,null),n(this,ei).stop(),n(this,x).stopAllTransports(),n(this,x).reset(),f(this,ei,new ol)}joinRoom(a,o){return l(this,arguments,function*(s,t,e=!1,r=!1,i={}){n(this,ir,Ci).mediaJoinAttempted=!0,f(this,Xr,!0),e&&this.reset();try{return yield n(this,ei).push(()=>M(this,xc,Lg).call(this,s,t,r,i),"joinRoom")}catch(c){return this.logger.error("Error in room joining process",{error:c}),this.context.getValue("peerSessionStore").emit(E.ROOM_NODE_FAILED),{roomJoined:!1,error:c}}})}initializeConnection(i,a){return l(this,arguments,function*(s,t,e=!1,r={}){return n(this,Ct)?n(this,Ct):(f(this,Ct,(()=>l(this,null,function*(){try{yield M(this,io,fl).call(this,s,t,e,r)}catch(o){throw f(this,Ct,null),o}}))()),n(this,Ct))})}getConsumers(){return n(this,x).consumers}getProducers(){return n(this,x).producers}leaveRoom(){return l(this,null,function*(){n(this,x).stopAllTransports(),f(this,Zr,!1),n(this,ir,Ci).mediaJoinAttempted=!1;const s={closeRoom:!1};n(this,Oe).sendMessagePromise(n(this,qe).leaveRoom,CP.toBinary(s)).then(e=>{var r;(r=hE.fromBinary(e.payload))!=null&&r.closed&&this.logger.warn("Weird state on peer closed and should not happen")}).catch(e=>{this.logger.error("error on sending leave room request",{error:e})}),this.context.getValue("callstats").callEnded(),this.context.getValue("telemetry").destruct()})}activatePeers(s){return l(this,null,function*(){return this.createConsumers(s)})}createConsumers(s){return l(this,null,function*(){return s.length===0?Promise.resolve():n(this,x).createConsumers(s)})}closeConsumers(s){return l(this,null,function*(){if(!s.length)return;const t=s.reduce((e,r)=>{const i=n(this,x).producerIdToConsumerIdMap.get(r.producerId);return i?(e.push(i),e):(this.logger.warn(`consumer not found in close consumers: ${r.producerId}`),e)},[]);yield n(this,x).closeConsumers(t)})}_shareWebcam(s,t){return l(this,null,function*(){var m,T;const e=t==="video/VP9"?W.WEBCAM:W.WEBCAM_BACKUP,r=M(this,_e,Ve).call(this,e);if(r){const v=yield r;if(n(this,x).producers.has(v)){const P=n(this,x).producers.get(v);if(!P.closed)return yield P.replaceTrack({track:s}),yield this.resumeWebcam(e),s;yield this.disableWebcam(t)}return this._shareWebcam(s,t)}const i=[t].concat(Ze.filter(v=>v!==t)),a=M(this,Gc,Jg).call(this,s,i),o=Dn(this.context,"disableSimulcast"),c=(T=(m=this.context)==null?void 0:m.getValue("overrides"))==null?void 0:T.simulcastConfig;!(o||c&&c.disable)&&this.context.getValue("flagsmith").hasFeature(q.ENABLE_CF_SIMULCAST)?(this.logger.info("Simulcast enabled for SFU: CF"),a.encodings=Zk(this.context,s)):this.logger.info("Simulcast disabled for webcam producer, SFU: CF"),this.context.getValue("flagsmith").hasFeature(q.TRACK_HINT)&&(a.track.contentHint=this.context.getValue("flagsmith").getValue(q.TRACK_HINT));const u=()=>{this.logger.info("Disabling video due to the producer closure"),n(this,He).delete(e)},p=n(this,x).createProducer(a,u);return M(this,ri,Xn).call(this,e,p.then(v=>v.id)),p.then(v=>v.track)})}shareWebcam(s){return l(this,null,function*(){var r;if(s===void 0)return null;const t=(r=this.context.getValue("flagsmith").getValue(q.FORCE_VIDEO_CODEC))==null?void 0:r.toString();if(t)return this.logger.debug(`Calling _shareWebcam with forced video codec: ${t}`),this._shareWebcam(s,t);const e=Ze.filter(i=>{var a,o;return((o=(a=n(this,In).sender)==null?void 0:a.video)==null?void 0:o.codecs.findIndex(c=>c.mimeType===i))>=0&&n(this,si).get(i).size>0});return e.length===0&&e.push(Ze[0]),yield Promise.all(e.map(i=>(this.logger.debug(`Calling _shareWebcam with video codec: ${i}`),this._shareWebcam(s,i)))),s})}shareScreen(s){return l(this,null,function*(){const{video:t,audio:e}=s;if(t===void 0)return;const r={track:t,codecOptions:[{name:"VP8"}],appData:{screenShare:!0,e2ee:this.e2ee,supportsRemoteControl:Z.isElectron()},stopTracks:!1},i=()=>{this.logger.info("Disabling screenShare due to the producer closure"),n(this,He).delete(W.SCREENSHARE_VIDEO),n(this,He).delete(W.SCREENSHARE_AUDIO)},a=n(this,x).createProducer(r,i);M(this,ri,Xn).call(this,W.SCREENSHARE_VIDEO,a.then(c=>c.id));let o;if(e){const c={track:e,codecOptions:[{name:"opus"}],appData:{screenShare:!0,e2ee:this.e2ee,supportsRemoteControl:Z.isElectron()},stopTracks:!1,zeroRtpOnPause:!1},d=()=>{};o=n(this,x).createProducer(c,d),M(this,ri,Xn).call(this,W.SCREENSHARE_AUDIO,o.then(u=>u.id))}yield Promise.all([a,o||Promise.resolve()]),this.context.getValue("callstats").screenShareStart()})}shareMic(s){return l(this,null,function*(){try{if(s===void 0)throw new Ye("track undefined");const t=M(this,_e,Ve).call(this,W.MIC);if(t){const a=yield t;if(n(this,x).producers.has(a)){const o=n(this,x).producers.get(a);if(!o.closed){yield o.replaceTrack({track:s}),yield this.resumeMic(),n(this,Ke)&&(n(this,Ke).audioTrack=s,n(this,Ke).producerId=a,n(this,Ke).start());return}yield n(this,x).closeProducer(a,{stopTrack:!1})}yield this.shareMic(s);return}const e=M(this,jc,Gg).call(this,s),r=()=>{n(this,He).delete(W.MIC)},i=n(this,x).createProducer(e,r);M(this,ri,Xn).call(this,W.MIC,i.then(a=>a.id)),yield i.then(a=>{n(this,Ke)&&(n(this,Ke).audioTrack=a.track,n(this,Ke).producerId=a.id,n(this,Ke).start())})}catch(t){throw new _(t)}})}pauseMic(){return l(this,null,function*(){var r;const s=yield M(this,_e,Ve).call(this,W.MIC),t=n(this,x).producers.get(s);if(!t){this.logger.error("pauseMic::could_not_find_mic_producer");return}if(t.paused){this.logger.info("pauseMic::mic_producer_already_paused");return}t.pause(),(r=n(this,Ke))==null||r.stop();const e={producerId:t.id,pause:!0};n(this,Oe).sendMessage(n(this,qe).toggleProducer,bo.toBinary(e))})}pauseWebcam(){return l(this,null,function*(){const s=yield M(this,_e,Ve).call(this,W.WEBCAM),t=yield M(this,_e,Ve).call(this,W.WEBCAM_BACKUP),e=n(this,x).producers.get(s),r=n(this,x).producers.get(t);if(!e&&!r){this.logger.error("pauseWebcam::could_not_find_webcam_producer");return}const i=a=>{const o={producerId:a.id,pause:!0};n(this,Oe).sendMessage(n(this,qe).toggleProducer,bo.toBinary(o))};e&&(e.pause(),i(e)),r&&(r.pause(),i(r))})}resumeMic(){return l(this,null,function*(){const s=yield M(this,_e,Ve).call(this,W.MIC),t=n(this,x).producers.get(s);if(!t){this.logger.error("resumeMic::could_not_find_mic_producer");return}if(!t.pause){this.logger.info("resumeMic::mic_producer_already_resumed");return}t.resume(),t.appData.e2ee&&this.context.getValue("peerSessionStore").emit(E.E2EE_ACTIVE_PRODUCER,t);const e={producerId:t.id,pause:!1};n(this,Oe).sendMessage(n(this,qe).toggleProducer,bo.toBinary(e))})}resumeWebcam(){return l(this,arguments,function*(s=W.WEBCAM){const t=yield M(this,_e,Ve).call(this,s),e=n(this,x).producers.get(t);if(!e){this.logger.error("resumeWebcam::could_not_find_webcam_producer");return}if(!e.paused){this.logger.info("resumeWebcam::webcam_producer_already_resumed");return}e.resume(),e.appData.e2ee&&this.context.getValue("peerSessionStore").emit(E.E2EE_ACTIVE_PRODUCER,e);const r={producerId:e.id,pause:!1};n(this,Oe).sendMessage(n(this,qe).toggleProducer,bo.toBinary(r))})}disableWebcam(s){return l(this,null,function*(){const t=s==="video/VP9"?W.WEBCAM:W.WEBCAM_BACKUP,e=yield M(this,_e,Ve).call(this,t);M(this,Bc,jg).call(this,t),e&&(yield n(this,x).closeProducer(e))})}disableMic(){return l(this,null,function*(){var t;const s=yield M(this,_e,Ve).call(this,W.MIC);s&&(yield n(this,x).closeProducer(s)),(t=n(this,Ke))==null||t.stop(),n(this,He).delete(W.MIC)})}disableScreenShare(){return l(this,null,function*(){this.logger.info("screen_sharing_stopped"),this.context.getValue("callstats").screenShareStop();const s=yield M(this,_e,Ve).call(this,W.SCREENSHARE_VIDEO),t=yield M(this,_e,Ve).call(this,W.SCREENSHARE_AUDIO);s&&(yield n(this,x).closeProducer(s)),t&&(yield n(this,x).closeProducer(t)),n(this,Rs).clear(),n(this,He).delete(W.SCREENSHARE_VIDEO),n(this,He).delete(W.SCREENSHARE_AUDIO)})}muteSelf(){return l(this,null,function*(){this.pauseMic()})}resetVideoProducers(s,t){return l(this,null,function*(){if(s){const e=yield M(this,_e,Ve).call(this,W.WEBCAM),r=yield M(this,_e,Ve).call(this,W.WEBCAM_BACKUP);yield n(this,x).closeProducer(e,{stopTrack:!1}),yield n(this,x).closeProducer(r,{stopTrack:!1}),this.shareWebcam(s)}if(t){const e=yield M(this,_e,Ve).call(this,W.SCREENSHARE_VIDEO);yield n(this,x).closeProducer(e,{stopTrack:!1}),this.shareScreen({video:t})}})}changeDisplayName(s,t){return l(this,null,function*(){const e={displayName:s,participantId:t!=null?t:this.peerId};if(!(yield n(this,x).socketHandler.changeDisplayName(e)))throw new Error("failed to change display name!")})}kick(s){const t={peerIds:[s]};n(this,x).socketHandler.kickPeer(t)}kickAll(){n(this,x).socketHandler.kickAll()}muteAll(s){return l(this,null,function*(){if(!(yield n(this,x).socketHandler.hostControlForAll("audio")))throw new Error("failed to mute all participant")})}muteAllVideo(){return l(this,null,function*(){if(!(yield n(this,x).socketHandler.hostControlForAll("video")))throw new Error("failed to mute all video participant")})}disableAudio(s){return l(this,null,function*(){if(!(yield n(this,x).socketHandler.hostControlForPeer(s,"audio")))throw new Error("failed to mute given participant")})}disableVideo(s){return l(this,null,function*(){if(!(yield n(this,x).socketHandler.hostControlForPeer(s,"video")))throw new Error("failed to mute video of given participant")})}pinPeer(s){return l(this,null,function*(){const t={participantId:s!=null?s:""};try{yield n(this,Oe).sendMessagePromise(n(this,qe).globalPinPeer,$P.toBinary(t))}catch(e){this.logger.error("Error in pinning peer:",{error:e})}})}validateScreenShare(s){return this.peerId===s.peerId&&n(this,x).producers.get(s.producerId)&&n(this,Rs).add(s.consumerPeerId),n(this,Rs).size}switchConsumersToLayer(s,t){return l(this,null,function*(){const e=s.map(r=>this.getConsumers().get(r));n(this,x).switchConsumersToLayer(e,t)})}handleSocketEvents(){return l(this,null,function*(){n(this,Oe).on(n(this,qe).peerProducerCreateBroadcast,({payload:s})=>{var t,e;if(this.mediaJoined)try{const{participantId:r,producerState:i}=FE.fromBinary(s);if(r===this.peerId)return;if(i!=null&&i.mimeType||(i.mimeType=i.kind===ns.AUDIO?"audio/opus":"video/VP8"),i.kind===ns.VIDEO&&!i.screenShare&&((e=(t=n(this,In).receiver)==null?void 0:t.video)==null?void 0:e.codecs.findIndex(a=>a.mimeType===Ze[0]))>=0&&n(this,ti).get(Ze[0]).has(r)&&i.mimeType!==Ze[0]){this.logger.warn(`Ignoring producer: ${i.producerId}`);return}this.logger.info(`producer created broadcast: ${r}, producer state: ${i}`),this.context.getValue("peerSessionStore").emit(E.NEW_PRODUCER,{peerId:r,producer:U(b({},i),{kind:i.kind===ns.AUDIO?"audio":"video",producingPeerId:r})})}catch(r){this.logger.error("error in peer-producer-create-broadcast",{error:r})}}),n(this,Oe).on(n(this,qe).peerProducerToggleBroadcast,({payload:s})=>{if(this.mediaJoined)try{const{participantId:t,initiatorParticipantId:e,producerState:{kind:r,pause:i,producerId:a,screenShare:o}}=Bu.fromBinary(s);if(o)return;const c=r===ns.AUDIO?"audio":"video";if(this.logger.info(`producer toggle broadcast: ${t}, producerId: ${a}, kind:${c}, paused:${i} payload: ${JSON.stringify(Bu.fromBinary(s))}`),t===this.peerId&&e!==this.peerId&&i&&this.context.getValue("peerSessionStore").emit(c==="audio"?E.MUTE_SELF:E.MUTE_SELF_VIDEO),t===this.peerId)return;this.context.getValue("peerSessionStore").emit(E.PRODUCER_TOGGLE,{peerId:t,producerId:a,paused:i,kind:c}),Array.from(this.getConsumers().values()).filter(u=>u.producerId===a).forEach(u=>{u.kind==="video"&&i||u.paused!==i&&(this.logger.debug(`consumer state mismatched for ${u.id}. updating consumer pause state ${u.paused} to ${i}`),i?(u.pause(),this.context.getValue("peerSessionStore").emit(E.CONSUMER_PAUSED,{id:u.id})):(u.resume(),this.context.getValue("peerSessionStore").emit(E.CONSUMER_RESUMED,{id:u.id})))})}catch(t){this.logger.error("error in producer toggle broadcast handler",{error:t})}}),n(this,Oe).on(n(this,qe).peerLeaveBroadcast,({payload:s})=>{if(this.mediaJoined)try{const{participantId:t}=Fd.fromBinary(s);if(t===this.peerId)return;this.logger.info(`peer left broadcast:${t}`),n(this,Rs).delete(t),n(this,x).consumers.forEach(e=>{e.peerId===t&&e.close()}),this.context.getValue("peerSessionStore").emit(E.PEER_CLOSED,{id:t})}catch(t){this.logger.error("error in peer left broadcast",{error:t})}}),n(this,Oe).on(n(this,qe).peerProducerCloseBroadcast,({payload:s})=>{if(this.mediaJoined)try{const{participantId:t,producerState:{producerId:e}}=GE.fromBinary(s);if(t===this.peerId)return;this.logger.info(`producer closed broadcast:${t}`),this.context.getValue("peerSessionStore").emit(E.PRODUCER_CLOSED,{peerId:t,producerId:e});const r=n(this,x).producerIdToConsumerIdMap.get(e);if(!r){this.logger.warn(`no consumer found for producer:${e}`);return}this.logger.info(`closing consumer ${r}, producer id: ${e}`),n(this,x).closeConsumer(r).then(()=>{this.logger.info(`closed consumer: ${r}`),n(this,x).producerIdToConsumerIdMap.delete(e),this.context.getValue("peerSessionStore").emit(E.CONSUMER_CLOSED,{id:r})}).catch(i=>{this.logger.error("error closing consumer",{error:i})})}catch(t){this.logger.error("error on producer close broadcast",{error:t})}}),n(this,Oe).on(n(this,qe).mediaRoomTerminationBroadcastResponse,()=>{!this.mediaJoined&&!n(this,Xr)&&!n(this,Zr)||(this.logger.warn("media hub termination broadcast received, rejoining room"),this.context.getValue("peerSessionStore").emit(E.ROOM_NODE_DISCONNECTED),n(this,so).call(this))})})}handleCallstatsEvents(){this.context.getValue("callstats").onConsumerScore(s=>{s.forEach((t,e)=>{const r=n(this,x).consumers.get(e);r&&this.context.getValue("peerSessionStore").emit(E.CONSUMER_SCORE_UPDATE,{id:e,kind:r.kind,peerId:r.peerId,score:t.score,scoreStats:t})})}),this.context.getValue("callstats").onProducerScore(s=>{s.forEach((t,e)=>{const r=Array.from(n(this,x).producers.values()).find(i=>i.id===e);r&&this.context.getValue("peerSessionStore").emit(E.PRODUCER_SCORE_UPDATE,{id:e,kind:r.kind,appData:r.appData,score:t.score,scoreStats:t})})})}handlePeerCapabilities(s,t){var e,r,i,a;for(let o=0;o<=Ze.length;o+=1){const c=Ze[o];if(((r=(e=t==null?void 0:t.receiver)==null?void 0:e.video)==null?void 0:r.codecs.findIndex(d=>d.mimeType===c))>=0||o===Ze.length-1){n(this,si).get(c).add(s);break}}for(let o=0;o<=Ze.length;o+=1){const c=Ze[o];if(((a=(i=t==null?void 0:t.sender)==null?void 0:i.video)==null?void 0:a.codecs.findIndex(d=>d.mimeType===c))>=0||o===Ze.length-1){n(this,ti).get(c).add(s);break}}}handlePeerLeaving(s){this.context.getValue("flagsmith").hasFeature(q.FORCE_VIDEO_CODEC)||(n(this,ti).forEach(t=>t.delete(s)),n(this,si).forEach((t,e)=>{t.delete(s),!(t.size!==0||e===Ze[0])&&this.disableWebcam(e)}))}},eo=new WeakMap,to=new WeakMap,Oe=new WeakMap,x=new WeakMap,In=new WeakMap,qe=new WeakMap,Xr=new WeakMap,Zr=new WeakMap,ei=new WeakMap,so=new WeakMap,Ct=new WeakMap,Rs=new WeakMap,ro=new WeakMap,ti=new WeakMap,si=new WeakMap,He=new WeakMap,Ke=new WeakMap,ir=new WeakSet,Ci=function(){return this.context.getValue("connectionHandler")},xc=new WeakSet,Lg=function(s,t,e,r){return l(this,null,function*(){f(this,to,s);try{return n(this,Ct)?yield n(this,Ct):yield M(this,io,fl).call(this,s,t,e,r),M(this,$c,Ug).call(this,t),{roomJoined:yield M(this,Lc,$g).call(this)}}catch(i){return this.logger.error("Failed to complete room join",{error:i}),{roomJoined:!1,error:i}}finally{f(this,Ct,null)}})},Lc=new WeakSet,$g=function(){return l(this,null,function*(){try{this.mediaJoined=!0;const{roomState:s}=yield n(this,x).socketHandler.notifySelfJoinComplete();return f(this,eo,s.roomUuid),f(this,Zr,!0),f(this,Xr,!1),!0}catch(s){return this.logger.error("Error completing room join",{error:s}),this.mediaJoined=!1,!1}})},$c=new WeakSet,Ug=function(s){navigator.product!=="ReactNative"&&setTimeout(()=>{try{const e={userId:this.context.getValue("userId"),peerId:this.peerId,roomUUID:s,roomViewType:"groupCall",deviceInfo:U(b({},Z.getDeviceInfo()),{userAgent:navigator.userAgent,memory:navigator.deviceMemory,cpus:navigator.hardwareConcurrency}),sdkName:this.context.getValue("sdkName"),sdkVersion:this.context.getValue("sdkVersion"),metaData:{},permissions:{}};this.context.getValue("callstats").roomJoined(e)}catch(t){this.logger.error("Error reporting room joined analytics",{error:t})}},0)},io=new WeakSet,fl=function(s,t,e,r){return l(this,null,function*(){var i,a;try{(a=n(this,ro))!=null||f(this,ro,M(i=xg,Uc,qg).call(i));const o=M(this,qc,Hg).call(this);yield M(this,Hc,Fg).call(this,s,t,e,o),yield n(this,x).setupTransports({send:!0,recv:!0}),yield M(this,Fc,Bg).call(this,r)}catch(o){throw this.logger.error("Failed to initialize connection",{error:o}),o}})},Uc=new WeakSet,qg=function(){const{ipInfo:s}=De();if(!(s!=null&&s.loc))return;const[t,e]=s.loc.split(",").map(parseFloat);return{latitude:t,longitude:e}},qc=new WeakSet,Hg=function(){var e;const s=(e=this.context.getValue("flagsmith").getValue(q.FORCE_VIDEO_CODEC))==null?void 0:e.toString(),t=zb(s);return f(this,In,t),t},Hc=new WeakSet,Fg=function(s,t,e,r){return l(this,null,function*(){yield mg((i,a)=>l(this,null,function*(){if(!n(this,Oe).isConnected){a(new Error("Socket is not connected"));return}i>0&&this.logger.warn("Retry: send joinRoom message",{debuggingHint:`Retry attempt ${i}`});try{yield n(this,x).socketHandler.joinRoom(t,s,r,e,n(this,ro))}catch(o){throw this.logger.error("Failed to send joinRoom message after retries",{error:o}),o}}),{delayTime:1e3,strategy:"exponential",maxRetryCount:15})})},Fc=new WeakSet,Bg=function(s){return l(this,null,function*(){if(!(!this.context.getValue("flagsmith").hasFeature(q.PRECREATE_PRODUCERS)||!s))try{const e=[];if(s.canProduceVideo===I.MediaProductionPermissionType.Allowed&&e.push(this.shareWebcam(hM(!1))),s.canProduceAudio===I.MediaProductionPermissionType.Allowed){const r=uM(!1);r&&e.push(this.shareMic(r))}e.length>0&&(yield Promise.all(e))}catch(e){this.logger.warn("Failed to precreate producers",{error:e})}})},_e=new WeakSet,Ve=function(s){return n(this,He).get(s)},ri=new WeakSet,Xn=function(s,t){return n(this,He).set(s,t)},Bc=new WeakSet,jg=function(s){return n(this,He).delete(s)},jc=new WeakSet,Gg=function(s){return{track:s,encodings:[{priority:"high"}],codecOptions:[{name:"opus"}],appData:{e2ee:this.e2ee},stopTracks:!1,zeroRtpOnPause:!1}},Gc=new WeakSet,Jg=function(s,t){return{track:s,codecOptions:t?t.map(e=>({name:e.split("/")[1]})):[{name:"VP8"}],appData:{screenShare:!1,e2ee:this.e2ee},stopTracks:!1}},h(Ad,Uc),Ad);let j=xg;J([S.trace("MediaNodeClient.reset",{country:S.location.country})],j.prototype,"reset",1);J([S.trace("MediaNodeClient.joinRoom")],j.prototype,"joinRoom",1);J([S.trace("MediaNodeClient.leaveRoom")],j.prototype,"leaveRoom",1);J([S.trace("MediaNodeClient.activatePeers")],j.prototype,"activatePeers",1);J([S.trace("MediaNodeClient.createConsumers")],j.prototype,"createConsumers",1);J([S.trace("MediaNodeClient.closeConsumers")],j.prototype,"closeConsumers",1);J([S.trace("MediaNodeClient._shareWebcam")],j.prototype,"_shareWebcam",1);J([S.trace("MediaNodeClient.shareWebcam")],j.prototype,"shareWebcam",1);J([S.trace("MediaNodeClient.shareScreen")],j.prototype,"shareScreen",1);J([S.trace("MediaNodeClient.shareMic")],j.prototype,"shareMic",1);J([S.trace("MediaNodeClient.pauseMic")],j.prototype,"pauseMic",1);J([S.trace("MediaNodeClient.pauseWebcam")],j.prototype,"pauseWebcam",1);J([S.trace("MediaNodeClient.resumeMic")],j.prototype,"resumeMic",1);J([S.trace("MediaNodeClient.resumeWebcam")],j.prototype,"resumeWebcam",1);J([S.trace("MediaNodeClient.disableWebcam")],j.prototype,"disableWebcam",1);J([S.trace("MediaNodeClient.disableMic")],j.prototype,"disableMic",1);J([S.trace("MediaNodeClient.disableScreenShare")],j.prototype,"disableScreenShare",1);J([S.trace("MediaNodeClient.muteSelf")],j.prototype,"muteSelf",1);J([S.trace("MediaNodeClient.resetVideoProducers")],j.prototype,"resetVideoProducers",1);J([S.trace("MediaNodeClient.changeDisplayName")],j.prototype,"changeDisplayName",1);J([S.trace("MediaNodeClient.kickPeer")],j.prototype,"kick",1);J([S.trace("MediaNodeClient.kickAllPeers")],j.prototype,"kickAll",1);J([S.trace("MediaNodeClient.muteAll")],j.prototype,"muteAll",1);J([S.trace("MediaNodeClient.muteAllVideo")],j.prototype,"muteAllVideo",1);J([S.trace("MediaNodeClient.disableAudio")],j.prototype,"disableAudio",1);J([S.trace("MediaNodeClient.disableVideo")],j.prototype,"disableVideo",1);J([S.trace("MediaNodeClient.pinPeer")],j.prototype,"pinPeer",1);J([S.trace("MediaNodeClient.validateScreenShare")],j.prototype,"validateScreenShare",1);function Wg(s,t){const e=s.getValue("roomNodeClient");if(e){if(e)return e;throw new Error("Room node client already set up.")}const r=new j(s,t);return s.setValue("roomNodeClient",r),r}function Kg(s){const t=s.getValue("roomNodeClient");try{t==null||t.leaveRoom()}catch(e){s.getValue("logger").error("roomNodeClient::cleanupRoomNodeClient")}s.setValue("roomNodeClient",void 0)}var mM=Object.defineProperty,fM=Object.getOwnPropertyDescriptor,vi=(s,t,e,r)=>{for(var i=r>1?void 0:r?fM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&mM(t,e,i),i},ii,Ht,H,Fe,tt,Nh;const zg=(Nh=class{constructor(s,t,e,r){h(this,Fe);g(this,"self");g(this,"authToken");h(this,ii,void 0);g(this,"viewType");h(this,Ht,void 0);h(this,H,void 0);const{socket:i}=e,a=s.getValue("authToken");this.self=t,f(this,H,s),this.viewType=r,this.authToken=a,f(this,ii,i),f(this,Ht,e),this.setupEvents()}get peerId(){return n(this,H).getValue("peerId")}get telemetry(){return n(this,H).getValue("telemetry")}get logger(){return n(this,H).getValue("logger")}get mediaJoined(){return n(this,H).getValue("connectionHandler").mediaJoined}static init(s,t,e,r,i){return l(this,null,function*(){const a=De(),o=s.getValue("peerId"),c=!!s.getValue("cachedUserDetails"),d=yield Ee.__init__(s,e,r,i,i.name,c);s.setValue("self",d);const u=s.getValue("logger");if(navigator.product!=="ReactNative"){const p=!s.getValue("flagsmith").hasFeature(q.PRECALL_BANDWIDTH_TEST);setTimeout(()=>l(this,null,function*(){const m=yield d.getAllDevices();u.info("populated_full_device_list",{devices:JSON.stringify(m)}),s.getValue("callstats").devices("AUDIO",m==null?void 0:m.filter(T=>T.kind==="audioinput")),s.getValue("callstats").devices("VIDEO",m==null?void 0:m.filter(T=>T.kind==="videoinput")),s.getValue("callstats").devices("SPEAKER",m==null?void 0:m.filter(T=>T.kind==="audiooutput")),u.info("Callstats:: initializing");try{yield s.getValue("callstats").initialize({peerId:o,engineName:Z.getDeviceInfo().engineName,env:s.getValue("env"),iceServers:yield a.getICEServers(),apiBase:s.getValue("apiBase"),flags:s.getValue("flagsmith").getAllFlags(),logger:u,apiHostnames:_p(s),skipConnectivityChecks:p}),u.info("Callstats:: initialized")}catch(T){u.error("Callstats:: initialization failed",{error:T})}}),0)}else u.info("Callstats:: Skipped initialization due to navigator product being ReactNative.");return new zg(s,d,t,i.viewType)})}shareMediaTracks(){return l(this,null,function*(){var c;const{audioTrack:s,videoTrack:t,permissions:e,audioEnabled:r,videoEnabled:i,screenShareEnabled:a,screenShareTracks:o}=this.self;if(e.canProduceAudio===I.MediaProductionPermissionType.Allowed&&r)try{yield n(this,Fe,tt).shareMic(s),this.self.audioEnabled||n(this,Fe,tt).pauseMic()}catch(d){this.self.disableAudio()}if(e.canProduceVideo===I.MediaProductionPermissionType.Allowed&&i)try{const d=yield n(this,Fe,tt).shareWebcam(t);d&&d.id!==t.id&&n(this,H).getValue("flagsmith").hasFeature(q.EXP_RESHARE)&&(yield n(this,Fe,tt).shareWebcam(d)),this.self.videoEnabled||n(this,Fe,tt).pauseWebcam()}catch(d){this.self.disableVideo()}if(e.canProduceScreenshare===I.MediaProductionPermissionType.Allowed&&a)try{yield(c=n(this,Fe,tt))==null?void 0:c.shareScreen({video:o.video,audio:o.audio})}catch(d){this.self.disableScreenShare()}})}kickHandler(s){return l(this,null,function*(){let t="kicked";(s==null?void 0:s.kickType)==="kickAll"&&(t="ended"),this.leaveRoom(t)})}waitlistedHandler(){this.logger.info("SelController.waitlisted"),this.self.waitlistStatus="waiting",this.self.roomState="waitlisted",this.self.emit("waitlisted")}waitlistAcceptHandler(){if(this.logger.info("SelController.waitlistAccepted"),this.self.waitlistStatus==="accepted"){this.logger.warn("SelfController.WAITLIST_ACCEPTED.UserAlreadyAccepted");return}this.self.waitlistStatus="accepted",this.joinRoom()}waitlistRejectedHandler(){if(this.logger.info("SelfController.waitlistRejected"),this.self.waitlistStatus==="rejected"){this.logger.warn("SelfController.WAITLIST_REJECTED.UserAlreadyRejected");return}this.self.waitlistStatus="rejected",this.leaveRoom("rejected")}resetSelf(s){return l(this,null,function*(){n(this,H).getValue("callstats").callEnded(),n(this,Fe,tt).reset(),s&&(yield this.joinRoom(s))})}setupEvents(){n(this,H).getValue("peerSessionStore").on(E.RESET_PRODUCER_STATE,()=>l(this,null,function*(){this.mediaJoined&&this.shareMediaTracks()})),n(this,H).getValue("peerSessionStore").on(E.ROOM_NODE_RECONNECTED,()=>{this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:!0})}),n(this,H).getValue("peerSessionStore").on(E.ROOM_NODE_DISCONNECTED,()=>{this.self.roomState!=="disconnected"&&(this.self.roomState="disconnected",this.self.emit("roomLeft",{state:"disconnected"}))}),n(this,H).getValue("peerSessionStore").on(E.ROOM_NODE_FAILED,()=>{this.self.roomState="failed",this.self.emit("roomLeft",{state:"failed"})}),n(this,H).getValue("peerSessionStore").on(E.SOCKET_SERVICE_RECONNECTED,({wasJoinAttempted:s})=>{s===!1&&(this.self.roomState="init"),this.resetSelf(s)}),n(this,H).getValue("peerSessionStore").on(E.SOCKET_SERVICE_DISCONNECTED,({joinAttempted:s})=>{if(this.self.roomState==="disconnected")return;let{peerId:t}=this;s&&n(this,H).getValue("flagsmith").hasFeature(q.REFRESH_ID_ON_DISCONNECTION)&&(t=As.v4()),n(this,ii).updateURL(t),n(this,H).getValue("telemetry").resetPeerId(t),De().setHeader("tracing-id",t),Ms.remapContext(t,n(this,H)),this.self.roomState="disconnected",this.self.emit("roomLeft",{state:"disconnected"})}),n(this,H).getValue("peerSessionStore").on(E.SOCKET_SERVICE_FAILED,()=>{this.self.roomState="failed",this.self.emit("roomLeft",{state:"failed"})}),n(this,Ht).on(A.waitingRoomRequestAccepted,()=>{this.waitlistAcceptHandler()}),n(this,Ht).on(Uo.updateUserPreset,s=>{s.updatePeersPresets.forEach(t=>{t.userIds===this.self.userId&&n(this,H).getValue("peerSessionStore").emit(E.UPDATE_PERMISSIONS,t.patch)})}),n(this,Ht).on(A.waitingRoomRequestDenied,()=>{this.waitlistRejectedHandler()}),n(this,Ht).on(A.kick,()=>{this.kickHandler({kickType:"kick"})}),n(this,Ht).on(A.kickAll,()=>{this.kickHandler({kickType:"kickAll"})}),n(this,H).getValue("peerSessionStore").onAsync(E.JOIN_MEDIA_ROOM,this.joinMediaRoom.bind(this)),n(this,H).getValue("peerSessionStore").on(E.PRODUCER_SCORE_UPDATE,({score:s,kind:t,appData:e,scoreStats:r})=>{var a;const i=(a=e==null?void 0:e.screenShare)!=null?a:!1;this.self.emit("mediaScoreUpdate",{kind:t,isScreenshare:i,score:s,participantId:this.self.id,scoreStats:r})}),n(this,H).getValue("peerSessionStore").on(E.MUTE_SELF,()=>l(this,null,function*(){this.self.audioEnabled&&(yield this.self.disableAudio(),n(this,H).getValue("callstats").audioOff())})),n(this,H).getValue("peerSessionStore").on(E.MUTE_SELF_VIDEO,()=>l(this,null,function*(){this.self.videoEnabled&&(yield this.self.disableVideo(),n(this,H).getValue("callstats").videoOff())})),n(this,H).getValue("peerSessionStore").onAsync(E.LEAVE_MEDIA_ROOM,this.leaveMediaRoom.bind(this)),n(this,H).getValue("peerSessionStore").on(E.PIP_HANGUP,this.leaveRoom.bind(this))}joinRoom(s=!1){return l(this,null,function*(){try{const{peer:t}=yield n(this,Ht).joinRoom(this.self);n(this,Ht).socket.flush();const e=Ol(t.stageType);if(n(this,H).setValue("stageStatus",e,!1),t.waitlisted){this.waitlistedHandler();return}yield this.joinMediaRoom(s),n(this,H).notify("stageStatus")}catch(t){throw this.logger.error("Error in joinRoom",{error:t}),t}})}leaveRoom(s="left"){return l(this,null,function*(){var t,e;if(this.logger.info(`Leaving room with state: ${s}`),(t=n(this,H).getValue("roomSocketHandler"))==null||t.cleanup(),s==="rejected"){this.self.roomState=s,this.self.emit("roomLeft",{state:s});return}this.self.setIsPinned(!1),n(this,H).setValue("stageStatus","OFF_STAGE",!1),yield this.leaveMediaRoom(s),n(this,H).notify("stageStatus");try{(e=n(this,ii))==null||e.disconnect()}catch(r){this.logger.error("SelfController::leaveRoom::socketDisconnect")}Kg(n(this,H)),this.self.roomState=s,this.self.emit("roomLeft",{state:s}),this.logger.info(`roomLeft event emitted with state: ${s}`)})}joinMediaRoom(s=!1){return l(this,null,function*(){var a,o,c;const{peerId:t,viewType:e,meetingId:r,stageStatus:i}=n(this,H).getAllValues();try{if(e===I.ViewType.Livestream){if(i!=="ON_STAGE"){this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:s});return}Wg(n(this,H),{socket:n(this,ii),peerId:t})}const{canProduceAudio:d,canProduceVideo:u,canProduceScreenshare:p}=this.self.permissions,{roomJoined:m,error:T}=(o=yield(a=n(this,Fe,tt))==null?void 0:a.joinRoom(this.self.name,r,s,s,{canProduceAudio:d,canProduceVideo:u,canProduceScreenshare:p}))!=null?o:{};if(!m)throw this.logger.error("Error:SelfController.mediaRoomJoin",{error:T}),T;i==="ON_STAGE"&&(yield this.shareMediaTracks()),this.self.roomState="joined",this.self.emit("roomJoined",{reconnected:s})}catch(d){throw this.logger.error("Error:SelfController.mediaRoomJoin",{error:d}),new _(`${(c=d==null?void 0:d.message)!=null?c:"could not connect to media servers"}`,"0002")}})}leaveMediaRoom(s){return l(this,null,function*(){const t=n(this,H).getValue("viewType");s!=="connected-meeting"&&(yield this.cleanupSelf()),!(s==="stageLeft"&&t===I.ViewType.Webinar)&&n(this,Fe,tt)&&(n(this,Fe,tt).mediaJoined&&s!=="disconnected"&&(yield n(this,Fe,tt).leaveRoom()),!(s==="stageLeft"&&t===I.ViewType.Livestream)&&(n(this,Fe,tt).mediaJoined=!1))})}cleanupSelf(){return l(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()})}},ii=new WeakMap,Ht=new WeakMap,H=new WeakMap,Fe=new WeakSet,tt=function(){return n(this,H).getValue("roomNodeClient")},Nh);let mr=zg;vi([S.trace("SelfController.resetSelf")],mr.prototype,"resetSelf",1);vi([S.trace("SelfController.setupEvents")],mr.prototype,"setupEvents",1);vi([S.trace("SelfController.joinRoom")],mr.prototype,"joinRoom",1);vi([S.trace("SelfController.leaveRoom")],mr.prototype,"leaveRoom",1);vi([S.trace("SelfController.joinMediaRoom")],mr.prototype,"joinMediaRoom",1);vi([S.trace("SelfController.leaveMediaRoom")],mr.prototype,"leaveMediaRoom",1);vi([S.trace("SelfController.init")],mr,"init",1);var no;class TM{constructor(t){h(this,no,void 0);f(this,no,t)}on(t,e){let r;t===A.roomPeerCount?r=Ju.fromBinary.bind(Ju):r=rh.fromBinary.bind(rh),n(this,no).on(t,({payload:i})=>{if(t===A.roomPeerCount&&!i)return;const a=r(i);e(a)})}}no=new WeakMap;var ao,oo;class yM{constructor(t,e){h(this,ao,void 0);h(this,oo,void 0);f(this,ao,e),f(this,oo,t)}get logger(){return n(this,oo).getValue("logger")}on(t,e){let r,i;switch(t){case A.transcript:{r=Sd.fromBinary.bind(Sd),i=Sd.create();break}default:{this.logger.debug("AISocketHandler switch case hit default, event not accounted for.");break}}n(this,ao).on(t,({payload:a})=>{let o=i;try{o=r(a)}catch(c){this.logger.error("aiSocketHandler::on::binary_decode_error",{error:c})}return e(o)})}}ao=new WeakMap,oo=new WeakMap;var vM=Object.defineProperty,SM=Object.getOwnPropertyDescriptor,jl=(s,t,e,r)=>{for(var i=r>1?void 0:r?SM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&vM(t,e,i),i},ks,On;class od{constructor(t,e){h(this,ks,void 0);h(this,On,void 0);f(this,ks,e),f(this,On,t)}get logger(){return n(this,On).getValue("logger")}get telemetry(){return n(this,On).getValue("telemetry")}getPolls(){return n(this,ks).sendMessagePromise(os.getPolls)}createPoll(t,e,r=!1,i=!1){const a={anonymous:r,hideVotes:i,question:t,options:e};return n(this,ks).sendMessage(os.createPoll,bR.toBinary(a))}votePoll(t,e){const r={index:e,pollId:t};return n(this,ks).sendMessage(os.votePoll,AR.toBinary(r))}on(t,e){let r,i;switch(t){case os.updatePoll:case os.createPoll:case os.votePoll:{r=Rd.fromBinary.bind(Rd),i=Rd.create();break}}n(this,ks).on(t,({payload:a})=>{let o=i;try{o=r(a)}catch(c){this.logger.error("pollSocketHandler::on::binary_decode_error",{error:c})}return e(o)})}removeListeners(t){n(this,ks).removeListeners(t)}}ks=new WeakMap,On=new WeakMap;jl([S.trace("PollSocketHandler.getPolls")],od.prototype,"getPolls",1);jl([S.trace("PollSocketHandler.createPoll")],od.prototype,"createPoll",1);jl([S.trace("PollSocketHandler.votePoll")],od.prototype,"votePoll",1);var PM=Object.defineProperty,EM=Object.getOwnPropertyDescriptor,wM=(s,t,e,r)=>{for(var i=r>1?void 0:r?EM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&PM(t,e,i),i},ct;class Yg{constructor(t,e){g(this,"socket");h(this,ct,void 0);f(this,ct,t),this.socket=e,this.handleSocketEvents(),n(this,ct).setValue("roomSocketHandler",this)}get telemetry(){return n(this,ct).getValue("telemetry")}get logger(){return n(this,ct).getValue("logger")}cleanup(){var t;try{(t=this.socket)==null||t.disconnect()}catch(e){this.logger.error("roomSocketHandler::cleanup")}}joinRoom(t){return l(this,null,function*(){var i;this.socket.joinAttempted=!0;const e={capabilities:[],peer:{displayName:(i=t.name)!=null?i:"Participant",customParticipantId:t.customParticipantId,peerId:t.id,userId:t.userId,displayPictureUrl:t.picture,waitlisted:!1},roomUuid:""},r=this.socket.sendMessagePromise(A.joinRoom,Sw.toBinary(e));try{const{peer:a}=Pi.fromBinary((yield r).payload);n(this,ct).getValue("connectionHandler").socketJoined=!0,n(this,ct).getValue("peerSessionStore").emit(E.SOCKET_SERVICE_ROOM_JOINED,{peer:a});const o=this.getRoomState(),c=this.getRoomPeersNonPaginated(),[{room:d},{peers:u}]=yield Promise.all([o,c]);return n(this,ct).getValue("peerSessionStore").emit(E.ROOM_STATE,d),n(this,ct).getValue("peerSessionStore").emit(E.SOCKET_PEERS,u),{peer:a}}catch(a){throw this.logger.error("RoomSocketHandler.joinRoom.failed",{error:a}),new _("Error: RoomSocketHandler.joinRoom failed.","0002",this.logger,a)}})}getAllAddedParticipants(){return l(this,null,function*(){try{return iC.fromBinary((yield this.socket.sendMessagePromise(A.getAllAddedParticipants)).payload).participants.map(i=>{var a=i,{id:e}=a,r=Co(a,["id"]);return U(b({},r),{userId:e})})}catch(t){return[]}})}getRoomPeers(t,e,r){return l(this,null,function*(){let i;try{const a={seachQuery:t,limit:e,offset:r},o=yield this.socket.sendMessagePromise(A.getRoomPeersInfo,lw.toBinary(a));i=Pd.fromBinary(o.payload)}catch(a){this.logger.error("getRoomPeers::binary_decode_error",{error:a})}return i})}getRoomPeersNonPaginated(){return l(this,null,function*(){let t;try{const e=yield this.socket.sendMessagePromise(A.getRoomPeersInfo);t=Pd.fromBinary(e.payload)}catch(e){this.logger.error("getRoomJoinedPeers::binary_decode_error",{error:e})}return t})}getStagePeers(){return l(this,null,function*(){let t;try{const e=yield this.socket.sendMessagePromise(A.getRoomPeersInfo);t=Pd.fromBinary(e.payload)}catch(e){this.logger.error("getRoomJoinedPeers::binary_decode_error",{error:e})}return t})}getPeerInfo(t){return l(this,null,function*(){let e;try{const r=yield this.socket.sendMessagePromise(A.getPeerInfo,Vp.toBinary({peerId:t}));e=Pi.fromBinary(r.payload)}catch(r){this.logger.error("getPeerInfo::binary_decode_error",{error:r})}return e})}getRoomState(){return l(this,null,function*(){let t=Wu.create();try{const e=yield this.socket.sendMessagePromise(A.getRoomInfo);t=Wu.fromBinary(e.payload)}catch(e){this.logger.error("getRoomState::binary_decode_error",{error:e})}return t})}getRoomStageState(){return l(this,null,function*(){let t=Qu.create();try{const e=yield this.socket.sendMessagePromise(A.getRoomStageState);t=Qu.fromBinary(e.payload)}catch(e){this.logger.error("getRoomStageState::binary_decode_error",{error:e})}return t})}broadcastMessage(t,e){return l(this,null,function*(){const r={type:t,payload:new TextEncoder().encode(JSON.stringify(e)),timestamp:Date.now(),ids:[]};return this.socket.sendMessagePromise(A.broadcastMessage,Bn.toBinary(r))})}broadcastToMeetings(t,e,r){return l(this,null,function*(){const i={type:t,payload:new TextEncoder().encode(JSON.stringify(r)),timestamp:Date.now(),ids:e,broadcastType:1};return this.socket.sendMessagePromise(A.broadcastToEntity,Bn.toBinary(i))})}broadcastToPeers(t,e,r){return l(this,null,function*(){const i={type:t,payload:new TextEncoder().encode(JSON.stringify(r)),timestamp:Date.now(),ids:e,broadcastType:0};return this.socket.sendMessage(A.broadcastToEntity,Bn.toBinary(i))})}leaveRoom(){return l(this,null,function*(){this.socket.joinAttempted=!1,this.socket.sendMessagePromise(A.leaveRoom,Ew.toBinary({}))})}kick(t){return l(this,null,function*(){const e={peerIds:[t]};this.socket.sendMessage(A.kick,Lp.toBinary(e))})}kickAll(t=!1){return l(this,null,function*(){const e={propagateKickAcrossRooms:t};this.socket.sendMessage(A.kickAll,Op.toBinary(e))})}getWaitingRoomRequests(){this.socket.sendMessage(A.getWaitingRoomRequests)}acceptWaitingRoomRequest(t){const e={userIds:t};this.socket.sendMessage(A.acceptWaitingRoomRequests,lC.toBinary(e))}rejectWaitingRoomRequest(t){const e={userIds:t};this.socket.sendMessage(A.denyWaitingRoomRequests,hC.toBinary(e))}updatePermissions(t,e){return l(this,null,function*(){const r={updatePeersPresets:[]};return t.forEach(i=>{r.updatePeersPresets.push({userIds:i,patch:e})}),this.socket.sendMessagePromise(Uo.updateUserPreset,HC.toBinary(r))})}handleSocketEvents(){this.socket.on(A.broadcastMessage,({payload:t})=>{try{const e=Bn.fromBinary(t);n(this,ct).getValue("peerSessionStore").emit(E.ROOM_MESSAGE,{payload:JSON.parse(new TextDecoder().decode(e.payload)),type:e.type,timestamp:e.timestamp})}catch(e){this.logger.error("failed to decode broadcast message:",e)}}),this.socket.on(A.broadcastToEntity,({payload:t})=>{try{const e=Bn.fromBinary(t);n(this,ct).getValue("peerSessionStore").emit(E.MESSAGE,{payload:JSON.parse(new TextDecoder().decode(e.payload)),type:e.type,timestamp:e.timestamp})}catch(e){this.logger.error("failed to decode peer broadcast message:",e)}})}on(t,e){let r,i;switch(t){case A.joinRoom:case A.leaveRoom:case A.kick:case A.kickAll:{r=Pi.fromBinary.bind(Pi),i=Pi.create();break}case A.getWaitingRoomRequests:{r=(a,o)=>a?Yu.fromBinary(a,o):{requests:[]},i=Yu.create();break}case A.recordingPaused:case A.recordingStarted:case A.recordingStopped:{r=ah.fromBinary.bind(ah);break}case Uo.updateUserPreset:{r=Xu.fromBinary.bind(Xu);break}case Bt.peerJoinedBroadcast:case Fs.peerJoinedBroadcast:{r=Hu.fromBinary.bind(Hu);break}case Bt.selfJoinComplete:case Fs.selfJoinComplete:{r=Hd.fromBinary.bind(Hd);break}case Bt.globalPeerPinBroadcast:case Fs.globalPeerPinBroadcast:{r=ju.fromBinary.bind(ju);break}case Bt.selectedPeer:case Fs.selectedPeer:{r=qd.fromBinary.bind(qd);break}case Bt.selectedPeerDiff:case Fs.selectedPeerDiff:{r=qu.fromBinary.bind(qu);break}case Bt.leaveRoom:case Fs.leaveRoom:{r=Fd.fromBinary.bind(Fd);break}}this.socket.on(t,({payload:a})=>{let o=i;if(!r)return e(void 0);try{o=r(a)}catch(c){this.logger.error("roomSocketHandler::on::binary_decode_error",{error:c})}return e(o)})}getUserPermissions(t){return l(this,null,function*(){const e={userIds:[t]};try{const r=yield this.socket.sendMessagePromise(Uo.getUserPresets,NC.toBinary(e)),i=$C.fromBinary(r.payload).peerPresets[0],a=new TextDecoder().decode(i.preset),o=JSON.parse(a).permissions;return{chat:o.chat,polls:o.polls,plugins:o.plugins}}catch(r){throw this.logger.error("Error in getting user preset",{error:r}),r}})}}ct=new WeakMap;wM([S.trace("RoomSocketHandler.joinRoom")],Yg.prototype,"joinRoom",1);var ze;class CM{constructor(t){h(this,ze,void 0);f(this,ze,t)}getStageRequests(){return l(this,null,function*(){const{payload:t}=yield n(this,ze).sendMessagePromise(A.getStageRequests);return t?_d.fromBinary(t):{stageRequests:[]}})}requestAccess(){n(this,ze).sendMessage(A.requestStageAccess)}cancelRequestAccess(){n(this,ze).sendMessage(A.cancelStageRequest)}grantAccess(t){return l(this,null,function*(){const e={userIds:t};n(this,ze).sendMessage(A.grantStageAccess,yR.toBinary(e))})}denyAccess(t){return l(this,null,function*(){const e={userIds:t};n(this,ze).sendMessage(A.denyStageAccess,SR.toBinary(e))})}joinStage(){return n(this,ze).sendMessagePromise(A.joinStage,void 0,void 0,A.peerStageStatusUpdate)}leaveStage(t){const e={userIds:[t]};return n(this,ze).sendMessagePromise(A.leaveStage,nh.toBinary(e),void 0,A.peerStageStatusUpdate)}kick(t){const e={userIds:t};return n(this,ze).sendMessagePromise(A.leaveStage,nh.toBinary(e))}on(t,e){let r;switch(t){case A.grantStageAccess:case A.denyStageAccess:{r=void 0;break}case A.getStagePeers:{r=ih.fromBinary.bind(ih);break}case A.getStageRequests:case A.requestStageAccess:case A.cancelStageRequest:{r=_d.fromBinary.bind(_d);break}case A.peerStageStatusUpdate:{r=Gu.fromBinary.bind(Gu);break}}n(this,ze).on(t,({payload:i,id:a})=>{if(!i||!r)return e(void 0,a);const o=r(i);return e(o,a)})}getPeerInfo(t){return l(this,null,function*(){const e=yield n(this,ze).sendMessagePromise(A.getPeerInfo,Vp.toBinary({peerId:t}));return Pi.fromBinary(e.payload)})}}ze=new WeakMap;var Te,co;class _M{constructor(t,e){h(this,Te,void 0);h(this,co,void 0);f(this,Te,e),f(this,co,t)}get logger(){return n(this,co).getValue("logger")}addPlugin(t,e){n(this,Te).sendMessage($.addPlugin,V_.toBinary({pluginId:t,staggered:e}))}removePlugin(t){n(this,Te).sendMessage($.removePlugin,L_.toBinary({pluginId:t,staggered:!1}))}getActivePlugins(){return l(this,null,function*(){const{payload:t}=yield n(this,Te).sendMessagePromise($.getPlugins);return t?aR.fromBinary(t):{plugins:[]}})}customPluginEventToRoom(t,e,r){const i={pluginId:t,pluginData:new TextEncoder().encode(JSON.stringify(e))};n(this,Te).sendMessage($.customPluginEventToRoom,W_.toBinary(i),r)}customPluginEventToPeers(t,e,r,i){const a={pluginId:t,peerIds:e,pluginData:new TextEncoder().encode(JSON.stringify(r))};n(this,Te).sendMessage($.customPluginEventToPeers,z_.toBinary(a),i)}enablePluginForRoom(t,e){n(this,Te).sendMessage($.enablePluginForRoom,U_.toBinary({pluginId:t}),e)}enablePluginForPeers(t,e,r){n(this,Te).sendMessage($.enablePluginForPeers,B_.toBinary({pluginId:t,peerIds:e}),r)}disablePluginForRoom(t,e){n(this,Te).sendMessage($.disablePluginForRoom,H_.toBinary({pluginId:t}),e)}disablePluginForPeers(t,e,r){n(this,Te).sendMessage($.disablePluginForPeers,G_.toBinary({pluginId:t,peerIds:e}),r)}storeInsertKeys(t,e,r,i){const a={pluginId:t,storeName:e,insertKeys:r.map(o=>({storeKey:o.key,payload:new TextEncoder().encode(JSON.stringify(o.payload))}))};n(this,Te).sendMessage($.storeInsertKeys,Zu.toBinary(a),i)}storeGetKeys(t,e,r,i){const a={pluginId:t,storeName:e,getKeys:r.map(o=>({storeKey:o.key}))};n(this,Te).sendMessage($.storeGetKeys,Z_.toBinary(a),i)}storeDeleteKeys(t,e,r,i){const a={pluginId:t,storeName:e,deleteKeys:r.map(o=>({storeKey:o.key}))};n(this,Te).sendMessage($.storeDeleteKeys,tR.toBinary(a),i)}storeDelete(t,e,r){n(this,Te).sendMessage($.storeDelete,rR.toBinary({pluginId:t,storeName:e}),r)}getPluginDataOld(t,e){this.logger.info("getPluginDataOld",{plugin:{id:t,storeName:e}})}storePluginDataOld(t,e,r){const i={pluginId:t,storeName:e,insertKeys:[{storeKey:r.key,payload:new TextEncoder().encode(JSON.stringify(r))}]};n(this,Te).sendMessage($.storeInsertKeys,Zu.toBinary(i))}on(t,e){let r;switch(t){case $.addPlugin:case $.enablePluginForPeers:case $.enablePluginForRoom:{r=Jd.fromBinary.bind(Jd);break}case $.removePlugin:case $.disablePluginForPeers:case $.disablePluginForRoom:{r=eh.fromBinary.bind(eh);break}case $.customPluginEventToPeers:case $.customPluginEventToRoom:{r=sh.fromBinary.bind(sh);break}case $.storeInsertKeys:case $.storeGetKeys:case $.storeDeleteKeys:case $.storeDelete:{r=th.fromBinary.bind(th);break}}n(this,Te).on(t,({payload:i,id:a})=>{const o=r(i);return e(o,a)})}}Te=new WeakMap,co=new WeakMap;var RM=Object.defineProperty,kM=Object.getOwnPropertyDescriptor,cd=(s,t,e,r)=>{for(var i=r>1?void 0:r?kM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&RM(t,e,i),i};const Th=65535,bM=3e3;var nr,se,re,oe,_t,Re,lo,Tl,uo,yl,Vh;const Qg=(Vh=class{constructor(s,{peerId:t,meetingId:e,authToken:r,capabilities:i}){h(this,re);h(this,lo);h(this,uo);h(this,nr,void 0);h(this,se,void 0);g(this,"roomName");g(this,"authToken");g(this,"capabilities");h(this,_t,void 0);h(this,Re,void 0);var a;if(!t||!e||!r)throw new _("peerId, meetingId, or authToken can not be empty","0404");f(this,_t,void 0),f(this,Re,s),this.capabilities=i,this.roomName=e,this.authToken=r,f(this,nr,M(this,lo,Tl).call(this,t)),f(this,se,new pm(n(this,nr),{autoReconnect:!0,disconnectOnPingTimeout:(a=i.includes("PING"))!=null?a:!1,queueOnDisconnect:!0,flushOnReconnect:!1,logger:this.logger})),this.handleSocketConnectionEvents()}get joinAttempted(){return n(this,re,oe).socketJoinAttempted}set joinAttempted(s){n(this,re,oe).socketJoinAttempted=s}get telemetry(){return n(this,Re).getValue("telemetry")}get logger(){return n(this,Re).getValue("logger")}get peerId(){return n(this,Re).getValue("peerId")}updateURL(s){s!==this.peerId&&(f(this,nr,M(this,lo,Tl).call(this,s)),this.logger.debug("SocketService:: Connection URL updated.")),n(this,se).updateURL(n(this,nr))}static getSocketEdgeDomain(s){return di({servicePrefix:"socket-edge",baseURI:s})}get url(){return n(this,nr)}connect(){return l(this,null,function*(){n(this,re,oe).socketJoinAttempted=!0,yield n(this,se).connect(),n(this,re,oe).socketJoinAttempted=!0,n(this,re,oe).socketState={state:"connected",reconnected:!1,reconnectionAttempt:void 0}})}disconnect(){n(this,re,oe).socketJoinAttempted=!1,n(this,se).disconnect(),n(this,re,oe).socketJoinAttempted=!0,n(this,re,oe).socketState={state:"disconnected",reconnected:!1,reconnectionAttempt:void 0}}get isConnected(){try{return n(this,se).readyState===1}catch(s){return!1}}sendMessage(s,t,e){const r={};return n(this,Re).getValue("telemetry").injectContext(r),n(this,se).send(s,e!=null?e:M(this,uo,yl).call(this),t,new TextEncoder().encode(JSON.stringify(r)))}sendMessagePromise(s,t,e,r){const i=parseInt({}.SOCKET_SERVICE_MESSAGE_REQUEST_TIMEOUT,10)||2e4;return this.sendMessagePromiseWithTimeout({event:s,timeout:i,protobuf:t,messageId:e,resp:r})}sendMessagePromiseWithTimeout({event:s,timeout:t,protobuf:e,messageId:r,resp:i}){const a=i!=null?i:s;return new Promise((o,c)=>{const d=(P,w)=>{n(this,se).removeListener(a,P),n(this,se).removeListener(Th,w),n(this,se).removeListener(Fs.errorResponse,w),n(this,se).removeListener(Bt.errorResponse,w)},u=r!=null?r:M(this,uo,yl).call(this),p={};n(this,Re).getValue("telemetry").injectContext(p);const T=({id:P,payload:w})=>{if(u===P){let C;try{const k=sE.fromBinary(w);C=new Error(k.errorMessage)}catch(k){C=new Error("failed to parse error message",{cause:k});try{const R=rw.fromBinary(w);C=new Error(R.message)}catch(R){C=new Error("failed to parse error message",{cause:R})}}c(C),d(v,T)}},v=({id:P,payload:w})=>{u===P&&(o({id:P,payload:w}),d(v,T))};n(this,se).on(a,v),n(this,se).on(Th,T),n(this,se).on(Fs.errorResponse,T),n(this,se).on(Bt.errorResponse,T),setTimeout(()=>{d(v,T),c(new Error(`request timeout for callback eventId:${s}`))},t),n(this,se).send(s,u,e,new TextEncoder().encode(JSON.stringify(p)))})}on(s,t){n(this,se).on(s,t)}onStateEvent(s,t){n(this,se).on(s,t)}removeListener(s,t){n(this,se).removeListener(s,t)}removeListeners(s){n(this,se).removeListeners(s)}flush(){return n(this,se).flush()}handleSocketConnectionEvents(){this.onStateEvent("connected",()=>l(this,null,function*(){this.logger.info("SocketService::Connected to socket-edge"),n(this,_t)&&(clearTimeout(n(this,_t)),f(this,_t,void 0)),n(this,re,oe).updateSocketConnectionState("connected")})),this.onStateEvent("disconnected",({code:s,reason:t})=>{var i;this.logger.info("SocketService::Disconnected from socket-edge",{error:{code:s,reason:t},country:S.location.country});const{recv:e,send:r}=(i=n(this,re,oe).mediaState)!=null?i:{};e!=null&&e.state&&(e==null?void 0:e.state)!==Oi.CONNECTED||r!=null&&r.state&&(r==null?void 0:r.state)!==Oi.CONNECTED?n(this,Re).getValue("peerSessionStore").emit(E.SOCKET_SERVICE_DISCONNECTED,{joinAttempted:n(this,re,oe).joinAttempted}):f(this,_t,setTimeout(()=>{n(this,Re).getValue("peerSessionStore").emit(E.SOCKET_SERVICE_DISCONNECTED,{joinAttempted:n(this,re,oe).joinAttempted}),f(this,_t,void 0)},bM)),n(this,re,oe).updateSocketConnectionState("disconnected")}),this.onStateEvent("reconnecting",()=>l(this,null,function*(){this.logger.info("SocketService::Reconnecting to socket-edge",{country:S.location.country}),n(this,re,oe).updateSocketConnectionState("reconnecting")})),this.onStateEvent("reconnectAttempt",t=>l(this,[t],function*({attempt:s}){this.logger.info("SocketService::Attempting to reconnect to socket-edge",{socket:{retryAttempt:s}}),n(this,re,oe).updateSocketConnectionState("reconnectAttempt",s)})),this.onStateEvent("reconnectFailure",({attempt:s})=>{this.logger.info("SocketService::Reconnect attempt to socket-edge failed",{socket:{retryAttempt:s}}),n(this,re,oe).updateSocketConnectionState("reconnectFailure",s)}),this.onStateEvent("reconnected",()=>l(this,null,function*(){this.logger.info("SocketService::Reconnected to socket-edge",{connectionState:{joinAttempted:n(this,re,oe).mediaJoinAttempted}}),n(this,_t)&&(clearTimeout(n(this,_t)),f(this,_t,void 0)),n(this,Re).getValue("peerSessionStore").emit(E.SOCKET_SERVICE_RECONNECTED,{wasJoinAttempted:n(this,re,oe).mediaJoinAttempted}),n(this,re,oe).updateSocketConnectionState("reconnected")})),this.onStateEvent("failed",()=>l(this,null,function*(){this.logger.info("SocketService::Failed to connect to socket-edge",{country:S.location.country}),n(this,Re).getValue("peerSessionStore").emit(E.SOCKET_SERVICE_FAILED),n(this,re,oe).updateSocketConnectionState("failed")}))}},nr=new WeakMap,se=new WeakMap,re=new WeakSet,oe=function(){return n(this,Re).getValue("connectionHandler")},_t=new WeakMap,Re=new WeakMap,lo=new WeakSet,Tl=function(s){let t=Qg.getSocketEdgeDomain(n(this,Re).getValue("baseURI"));typeof Dn(n(this,Re),"socket_server_base")=="string"&&(t=Dn(n(this,Re),"socket_server_base"));const e=`wss://${t}`,r=new URL(`${e}/ws`),i=this.peerId,a=U(b({roomID:this.roomName,peerID:s,authToken:this.authToken,useMediaV2:!0},i!==s&&{oldPeerID:i}),{ping:this.capabilities.includes("PING"),capabilities:this.capabilities.map(o=>zo[o]).join(" "),joinWithDetails:!0,useCfWorker:!0,useStartSession:!0});return Object.entries(a).forEach(([o,c])=>{r.searchParams.append(o,c.toString())}),r.href},uo=new WeakSet,yl=function(){return`${this.peerId}-${(Math.random()+1).toString(36).substring(7)}`},Vh);let Po=Qg;cd([S.trace("SocketService.connect")],Po.prototype,"connect",1);cd([S.trace("SocketService.disconnect")],Po.prototype,"disconnect",1);cd([S.trace("SocketService.sendMessagePromise")],Po.prototype,"sendMessagePromise",1);cd([S.trace("SocketService.sendMessagePromiseWithTimeout")],Po.prototype,"sendMessagePromiseWithTimeout",1);class MM{constructor(t){g(this,"socketService");this.socketService=t}handleConnectedRoomsDumpRaw({payload:t}){var a;const e=Aw.fromBinary(t),r=e.meetings.map(o=>{var c;return{id:o.id,title:o.title,participants:(c=o.participants)!=null?c:[]}});return{parentMeeting:{id:e.parentMeeting.id,title:e.parentMeeting.title,participants:(a=e.parentMeeting.participants)!=null?a:[]},meetings:r}}handleTransferPeerRaw({payload:t}){const e=sC.fromBinary(t);return{authToken:e.authToken,meetingId:e.meetingId}}handleMovedPeerRaw({payload:t}){const e=xp.fromBinary(t);return{meetingId:e.meetingId,customParticipantId:e.customParticipantId}}handleConnectedRoomsUpdatedRaw({payload:t}){return zu.fromBinary(t).payloads.map(r=>({id:r.id,title:r.title}))}handleConnectedRoomsDeletedRaw({payload:t}){return Jw.fromBinary(t).payloads}getConnectedRoomsDump(){return l(this,null,function*(){const t=yield this.socketService.sendMessagePromise(A.getConnectedRoomsDump);return this.handleConnectedRoomsDumpRaw(t)})}createConnectedRooms(t){return l(this,null,function*(){const{payload:e}=yield this.socketService.sendMessagePromise(A.createConnectedRooms,Nw.toBinary({payloads:t}));return zu.fromBinary(e).payloads.map(i=>({id:i.id,title:i.title}))})}updateConnectedRooms(t){return l(this,null,function*(){})}disableConnectedRooms(t){return l(this,null,function*(){const e=t.map(i=>({id:i})),r=yield this.socketService.sendMessagePromise(A.deleteConnectedRooms,jw.toBinary({payloads:e}));return this.handleConnectedRoomsDeletedRaw(r)})}movePeersBetweenRooms(t){return l(this,null,function*(){try{const e=yield this.socketService.sendMessagePromise(A.movePeers,Xw.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}}})}}var AM=Object.defineProperty,IM=Object.getOwnPropertyDescriptor,OM=(s,t,e,r)=>{for(var i=r>1?void 0:r?IM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&AM(t,e,i),i},Ft;class Xg extends ut{constructor(e){const r=e.getValue("logger");super(r);g(this,"meetings",[]);g(this,"parentMeeting",null);h(this,Ft,void 0);f(this,Ft,e)}get supportsConnectedMeetings(){return n(this,Ft).getValue("self").id!==""}get isActive(){return this.meetings.length!==0}validateConnectedMeetingsAction(){if(!this.supportsConnectedMeetings)throw new Error(`You are not allowed to perform this action.
|
|
8
|
+
Please connect with our support team to enable connected meetings.`)}getConnectedMeetings(){return l(this,null,function*(){this.validateConnectedMeetingsAction(),this.logger.info("Getting connected meetings dump");const e=yield n(this,Ft).getValue("connectedMeetingsSocketHandler").getConnectedRoomsDump();return this.logger.info("Got connected meetings dump"),e})}createMeetings(e){return l(this,null,function*(){this.validateConnectedMeetingsAction(),this.logger.info(`Creating connected meetings ${JSON.stringify(e)}`);const r=yield n(this,Ft).getValue("connectedMeetingsSocketHandler").createConnectedRooms(e);return this.logger.info(`Created connected meetings ${JSON.stringify(r)}`),r.map(i=>({id:i.id,title:i.title}))})}updateMeetings(e){return l(this,null,function*(){this.validateConnectedMeetingsAction(),this.logger.info(`Updating connected meetings ${JSON.stringify(e)}`),yield n(this,Ft).getValue("connectedMeetingsSocketHandler").updateConnectedRooms(e.map(r=>({meetingId:r.id,title:r.title}))),this.logger.info(`Updated connected meetings ${JSON.stringify(e)}`)})}deleteMeetings(e){return l(this,null,function*(){this.validateConnectedMeetingsAction(),this.logger.info(`Moving participants before deleting connected meetings ${JSON.stringify(e)}`);const r=this.meetings.map(a=>e.includes(a.id)&&a.participants.length!==0?this.moveParticipants(a.id,this.parentMeeting.id,a.participants.map(o=>o.id)):Promise.resolve());this.logger.info(`Moved participants before deleting connected meetings ${JSON.stringify(e)}. Deleting now.`),yield Promise.all(r);const i=yield n(this,Ft).getValue("connectedMeetingsSocketHandler").disableConnectedRooms(e);return this.logger.info(`Deleted connected meetings ${JSON.stringify(e)}`),i})}moveParticipants(e,r,i){return l(this,null,function*(){this.validateConnectedMeetingsAction(),this.logger.info(`Moving connected meetings participants ${JSON.stringify(i)} from ${e} to ${r}`);const a=yield n(this,Ft).getValue("connectedMeetingsSocketHandler").movePeersBetweenRooms({sourceMeetingId:e,destinationMeetingId:r,participants:i.map(o=>({id:o}))});return a.success?(this.logger.info(`Moved connected meetings participants ${JSON.stringify(i)} from ${e} to ${r}`),this.moveSuccessHandler(e,r,i)):this.logger.error(`Failed to move connected meetings participants ${JSON.stringify(i)} from ${e} to ${r}`),a})}moveParticipantsWithCustomPreset(e,r,i){return l(this,null,function*(){this.validateConnectedMeetingsAction(),this.logger.info(`Moving connected meetings participants (custom preset) ${JSON.stringify(i)} from ${e} to ${r}`);const a=yield n(this,Ft).getValue("connectedMeetingsSocketHandler").movePeersBetweenRooms({sourceMeetingId:e,destinationMeetingId:r,participants:i});return a.success?(this.logger.info(`Moved connected meetings participants (custom preset) ${JSON.stringify(i)} from ${e} to ${r}`),this.moveSuccessHandler(e,r,i.map(o=>o.id))):this.logger.error(`Failed to move connected meetings participants (custom preset) ${JSON.stringify(i)} from ${e} to ${r}`),a})}moveSuccessHandler(e,r,i){const a=new Map;[...this.parentMeeting.participants,...this.meetings.flatMap(o=>o.participants)].forEach(o=>a.set(o.id,o)),r===this.parentMeeting.id&&(this.parentMeeting.participants=this.parentMeeting.participants.concat(i.map(o=>a.get(o)))),e===this.parentMeeting.id&&(this.parentMeeting.participants=this.parentMeeting.participants.filter(o=>!i.includes(o.id))),this.meetings=this.meetings.map(o=>{if(r===o.id){const c=o.participants.concat(i.map(d=>a.get(d)));return U(b({},o),{participants:c})}if(e===o.id){const c=o.participants.filter(d=>!i.includes(d.id));return U(b({},o),{participants:c})}return o})}}Ft=new WeakMap;OM([Qe({maxInvocations:60,period:60})],Xg.prototype,"getConnectedMeetings",1);var DM=Object.defineProperty,NM=Object.getOwnPropertyDescriptor,Gl=(s,t,e,r)=>{for(var i=r>1?void 0:r?NM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&DM(t,e,i),i},z,xh;const Zg=(xh=class{constructor(s){g(this,"connectedMeetings");h(this,z,void 0);f(this,z,s),this.connectedMeetings=new Xg(s)}get telemetry(){return n(this,z).getValue("telemetry")}get logger(){return n(this,z).getValue("logger")}static init(s){const t=new Zg(s);return t.connectedMeetings.supportsConnectedMeetings&&(t.setupEvents(),s.getValue("self").once("roomJoined",()=>t.getConnectedMeetings())),t}getConnectedMeetings(){this.connectedMeetings.getConnectedMeetings()}setupEvents(){n(this,z).getValue("connectedMeetingsSocketHandler").socketService.on(A.getConnectedRoomsDump,this.handleConnectedRoomsDump.bind(this)),n(this,z).getValue("connectedMeetingsSocketHandler").socketService.on(A.transferPeer,this.handleTransferPeer.bind(this)),n(this,z).getValue("connectedMeetingsSocketHandler").socketService.on(A.movedPeer,this.handleMovedPeer.bind(this)),n(this,z).getValue("connectedMeetingsSocketHandler").socketService.on(A.connectedRoomsUpdated,this.handleConnectedRoomsUpdated.bind(this)),n(this,z).getValue("connectedMeetingsSocketHandler").socketService.on(A.connectedRoomsDeleted,this.handleConnectedRoomsDeleted.bind(this))}handleTransferPeer(s){this.logger.info("Received backend request to switch connected meetings");const t=n(this,z).getValue("connectedMeetingsSocketHandler").handleTransferPeerRaw(s);return this.logger.info(`Honoring request to switch connected meetings. Going to ${t==null?void 0:t.meetingId}`),this.switchMeeting(t)}switchMeeting(e){return l(this,arguments,function*({authToken:s,meetingId:t}){var a,o,c,d;if(!this.connectedMeetings.supportsConnectedMeetings)throw new Error(`You are not allowed to perform this action.
|
|
9
|
+
Please connect with our support team to enable connected meetings.`);this.logger.info("ConnectedMeetingsController::switchMeeting:: asking ui-kit to show switching breakout UI"),this.connectedMeetings.emit("changingMeeting",t);const r={video:n(this,z).getValue("self").videoEnabled,audio:n(this,z).getValue("self").audioEnabled};try{n(this,z).getValue("self").cleanupEvents(),yield n(this,z).getValue("meeting").leave("connected-meeting")}catch(u){this.logger.error(`ConnectedMeetingsController:: switchMeeting:: issues in leaving previous meeting. Meeting Id: ${(o=(a=n(this,z).getValue("meeting"))==null?void 0:a.meta)==null?void 0:o.meetingId}`,{error:u})}this.logger.info(`ConnectedMeetingsController::switchMeeting:: initializing new meeting. Meeting Id: ${t}`);const i=yield tm.init(U(b({},n(this,z).getValue("options")),{cachedUserDetails:null,defaults:U(b(b({},n(this,z).getValue("options").defaults),r),{mediaHandler:n(this,z).getValue("self")}),authToken:s}));this.logger.info(`ConnectedMeetingsController::switchMeeting:: initialized new meeting. Meeting Id: ${(c=i==null?void 0:i.meta)==null?void 0:c.meetingId}`);try{const{hidden:u}=n(this,z).getValue("self");i.self.setName(n(this,z).getValue("self").name),yield i.join(),u&&i.self.hide()}catch(u){this.logger.error("ConnectedMeetingsController.joinRoom",{error:u})}return this.logger.info(`ConnectedMeetingsController::switchMeeting:: asking ui-kit to show in-meeting ui of newly joined meeting id: ${(d=i==null?void 0:i.meta)==null?void 0:d.meetingId}`),this.connectedMeetings.emit("meetingChanged",i),i})}handleConnectedRoomsDump(s){const t=n(this,z).getValue("connectedMeetingsSocketHandler").handleConnectedRoomsDumpRaw(s);this.connectedMeetings.meetings=t.meetings.map(e=>({id:e.id,title:e.title,participants:e.participants||[]})),this.connectedMeetings.parentMeeting={id:t.parentMeeting.id,title:t.parentMeeting.title,participants:t.parentMeeting.participants},this.emitStateUpdate()}handleMovedPeer(s){return n(this,z).getValue("connectedMeetingsSocketHandler").handleMovedPeerRaw(s)}handleConnectedRoomsUpdated(s){const t=n(this,z).getValue("connectedMeetingsSocketHandler").handleConnectedRoomsUpdatedRaw(s),e=new Map;this.connectedMeetings.meetings.forEach(r=>{e.set(r.id,r)}),t.forEach(r=>{e.has(r.id)?e.get(r.id).title=r.title:e.set(r.id,U(b({},r),{participants:[]}))}),this.connectedMeetings.meetings=Array.from(e.values()),this.emitStateUpdate()}handleConnectedRoomsDeleted(s){const e=n(this,z).getValue("connectedMeetingsSocketHandler").handleConnectedRoomsDeletedRaw(s).map(r=>r.id);this.connectedMeetings.meetings=this.connectedMeetings.meetings.filter(r=>!e.includes(r.id)),this.emitStateUpdate()}emitStateUpdate(){this.connectedMeetings.emit("stateUpdate",{meetings:this.connectedMeetings.meetings,parentMeeting:this.connectedMeetings.parentMeeting})}},z=new WeakMap,xh);let dd=Zg;Gl([S.trace("ConnectedMeetingsController.getConnectedMeetings")],dd.prototype,"getConnectedMeetings",1);Gl([S.trace("ConnectedMeetingsController.setupEvents")],dd.prototype,"setupEvents",1);Gl([S.trace("ConnectedMeetingsController.switchMeeting")],dd.prototype,"switchMeeting",1);var VM=Object.defineProperty,xM=Object.getOwnPropertyDescriptor,ld=(s,t,e,r)=>{for(var i=r>1?void 0:r?xM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&VM(t,e,i),i};const _i=class{constructor(s,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");g(this,"connectedMeetingsController");g(this,"telemetry");g(this,"logger");this.apiBase=s,this.storesManager=t.storesManager,this.metaController=t.metaController,this.selfController=t.selfController,this.chatController=t.chatController,this.pollController=t.pollController,this.stageController=t.stageController,this.pluginController=t.pluginController,this.recordingController=t.recordingController,this.internalsController=t.internalsController,this.participantController=t.participantController,this.livestreamController=t.livestreamController,this.connectedMeetingsController=t.connectedMeetingsController,this.telemetry=e.getValue("telemetry"),this.logger=e.getValue("logger")}static init(s){return l(this,null,function*(){var O,N;const{peerId:t,apiBase:e,authToken:r,meetingId:i,organizationId:a,cachedUserDetails:o,logger:c}=s.getAllValues();if(Kg(s),Z.isSupported()===!1)throw new _("Browser not supported","0010",c,!0);const d=nk(s,{authToken:r,baseURL:e,cachedUserDetails:o});d.setRoomName(i),d.setRoomUUID(i),d.setOrganizationId(a),d.setHeader("tracing-id",t),s.setValue("apiClient",d);const u=new qk(s);s.setValue("connectionHandler",u);const p=_i.createSocketService(s),m=p.connect(),T=d.getUserDetails(),v=d.getPlugins();let P,w="";try{yield _i.setupFlagsmith(s)}catch(L){c.error("Failed to setup flagsmith",{error:L})}try{yield m}catch(L){c.error("[Controller]: Failed to connect to socket server:",{error:L})}try{({meetingTitle:w}=yield d.getRoomNodeData()),P=yield T,c.info("CF SFU is being used."),s.setValue("presetName",P.preset.name)}catch(L){c.error("Failed to get room metadata",{error:L})}const C=tl.init(P.preset,!s.getValue("modules").theme),k=nl.init(s,C.viewType,P.preset.permissions),R=_i.setupControllers(p,s,P,v,w,C,k);Mk(C)&&((O=_i.createRoomNodeClient(s,p).initializeConnection(P.participant.name,i,!1,k))==null||O.catch(te=>{c.error("[Controller]: Failed to queue partial media room promise:",{error:te})})),S.location.country=(N=d.ipInfo)==null?void 0:N.country;const{controllers:D}=yield R;return LS(),new _i(e,D,s)})}static setupFlagsmith(s){return l(this,null,function*(){var u;const{peerId:t,baseURI:e,overrides:r,meetingId:i,organizationId:a,logger:o}=s.getAllValues(),c=xS(i),d=U(b({entity:$d.PEER,clientId:a,isAnonUser:!a,sdkVersion:s.getValue("sdkVersion"),presetName:s.getValue("presetName"),meetingHash:c,roomName:i},Z.getDeviceInfo()),{isReactNative:navigator.isReactNative});try{const p=(u=r==null?void 0:r.whitelabelled_flags_endpoint)==null||u?di({servicePrefix:"flags",baseURI:e}):"edge.api.flagsmith.com";yield s.getValue("flagsmith").identify(`${$d.PEER}_${t}`,JSON.parse(JSON.stringify(d)),!1,5e3,p,o),o.info("flagsmith::allFlags",{flags:JSON.stringify(s.getValue("flagsmith").getAllFlags())},!0)}catch(p){o.error("Failed to fetch flagsmith flags")}})}static setupControllers(s,t,e,r,i,a,o){return l(this,null,function*(){var Yl,Ql,Xl;const c=t.getValue("modules"),{participant:d}=e,u=t.getValue("defaults"),p=t.getValue("logger"),{viewType:m,mediaConstraints:{audio:T}}=a;t.setValue("viewType",m),t.setValue("defaults",b({mediaConfiguration:{audio:{enableHighBitrate:(Yl=T.enableHighBitrate)!=null?Yl:!1,enableStereo:(Ql=T.enableStereo)!=null?Ql:!1}}},u)),t.setValue("maxPreferredStreams",Z.isMobile()?a.maxVideoStreams.mobile:a.maxVideoStreams.desktop);let v,P,w,C,k,R,D,O,N;const L=new yM(t,s),te=new MM(s);t.setValue("connectedMeetingsSocketHandler",te);const Yt=new od(t,s),Un=new xs(t,s),sm=new CM(s),qn=new Yg(t,s),zl=new _M(t,s),rm=new TM(s),At=yield mr.init(t,qn,d,o,a);t.setValue("selfController",At);const im=yield Qp.init(t,At.self,qn,L,i);if(c.participant&&(O=new $s(t,At.self,qn)),(Xl=c.e2ee)!=null&&Xl.enabled&&c.e2ee.manager.init(p,t.getValue("peerSessionStore")),c.chat&&(P=yield kt.init(t,Un,At.self,O.participants)),c.internals&&(k=yield Nl.init(t)),c.livestream&&a.viewType===I.ViewType.Livestream&&t.getValue("flagsmith").hasFeature(q.LIVESTREAM)&&(D=new ag(t,At.self,rm)),c.poll&&(v=yield Wp.init(t,At.self,Yt)),c.recording&&(R=new tg(t,At.self,qn)),c.stage&&(w=new Xp(t,sm,qn,At.self,O.participants)),c.plugin){if(!O)throw new _("The plugin module cannot be initialized without the `participant` module","0102");const hd=yield r;C=yield To.init(t,hd,zl,Un,P==null?void 0:P.chat,At.self,O.participants,i)}if(c.connectedMeetings&&(N=yield dd.init(t)),c.pip){const hd=yield Ud._init(t,At.self);t.setValue("pip",hd)}const nm={storesManager:new Ib(t,zl),pollController:v,selfController:At,metaController:im,chatController:P,stageController:w,pluginController:C,recordingController:R,internalsController:k,livestreamController:D,participantController:O,connectedMeetingsController:N};return{theme:a,permissions:o,controllers:nm}})}static createRoomNodeClient(s,t){const{peerId:e}=s.getAllValues();return Wg(s,{socket:t,peerId:e})}static createSocketService(s){const{peerId:t,meetingId:e,authToken:r}=s.getAllValues(),i=["PING"];return new Po(s,{peerId:t,meetingId:e,authToken:r,capabilities:i})}};let Eo=_i;ld([S.trace("Controller.init")],Eo,"init",1);ld([S.trace("setupFlagsmith")],Eo,"setupFlagsmith",1);ld([S.trace("Controller.createRoomNodeClient")],Eo,"createRoomNodeClient",1);ld([S.trace("Controller.createSocketService")],Eo,"createSocketService",1);class LM{constructor(){g(this,"battery");g(this,"logger");g(this,"init",t=>l(this,null,function*(){this.logger=t;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){t.error("Error getting battery",e)}}));g(this,"updateChargeInfo",()=>{var t;this.logger.log(`Battery charging? ${(t=this.battery)!=null&&t.charging?"Yes":"No"}`)});g(this,"updateLevelInfo",()=>{if(!this.battery){this.logger.log("Battery level: Not known");return}this.logger.log(`Battery level: ${this.battery.level*100}%`)});g(this,"cleanup",()=>{var t,e;"getBattery"in navigator&&((t=this.battery)==null||t.removeEventListener("chargingchange",this.updateChargeInfo),(e=this.battery)==null||e.removeEventListener("levelchange",this.updateLevelInfo))})}}const yh=new LM;function $M(s,t){s.startsWith("eyJ")||console.error("Invalid auth token provided. Ensure you are passing a %cparticipant `authToken`%c — not an Org API Key or an incorrectly formatted token.\nYou get the participant token from the Add Participant API: https://docs.realtime.cloudflare.com/api#/operations/add_participant","font-weight: bold","font-weight: normal");try{const{meetingId:e,orgId:r,participantId:i}=JSON.parse(atob(s.split(".")[1]));if(!e)throw Error(`Received V1 auth token ${s}`);let a=Pr.baseURI.prod;t&&(a=t);const o=`https://${di({servicePrefix:"api",baseURI:a})}`;return{meetingId:e,orgId:r,participantId:i,baseURI:a,apiBase:o}}catch(e){throw new _("Invalid auth token","0004")}}var ar,ni,ai,ho,Jc,em;class UM{constructor(){h(this,Jc);h(this,ar,new Audio);h(this,ni,new MediaStream);h(this,ai,new Map);h(this,ho,void 0);n(this,ar).srcObject=n(this,ni),n(this,ar).autoplay=!0}playTracks(t){return l(this,null,function*(){return t.forEach(e=>{n(this,ai).has(e.id)||(n(this,ni).addTrack(e),n(this,ai).set(e.id,e))}),this.play()})}setSpeakerDevice(t){typeof HTMLAudioElement.prototype.setSinkId=="function"&&n(this,ar).setSinkId(t)}removeTrack(t){const e=n(this,ai).get(t);e&&(n(this,ni).removeTrack(e),n(this,ai).delete(t))}play(){return l(this,null,function*(){return n(this,ar).srcObject=n(this,ni),n(this,ar).play().catch(t=>{M(this,Jc,em).call(this,t)})})}onError(t){f(this,ho,t)}}ar=new WeakMap,ni=new WeakMap,ai=new WeakMap,ho=new WeakMap,Jc=new WeakSet,em=function(t){var e;(e=n(this,ho))==null||e.call(this,t)};var oi;class qM extends UM{constructor(){super();h(this,oi,void 0);f(this,oi,new Map)}addParticipantTrack(e,r){n(this,oi).set(e,r.id),this.playTracks([r])}removeParticipantTrack(e){const r=n(this,oi).get(e);r&&this.removeTrack(r),n(this,oi).delete(e)}}oi=new WeakMap;var HM=Object.defineProperty,FM=Object.getOwnPropertyDescriptor,ud=(s,t,e,r)=>{for(var i=r>1?void 0:r?FM(t,e):t,a=s.length-1,o;a>=0;a--)(o=s[a])&&(i=(r?o(t,e,i):o(i))||i);return r&&i&&HM(t,e,i),i},ye,ci,Lh;let ur=(Lh=class{constructor(t,e){h(this,ye,void 0);h(this,ci,void 0);f(this,ci,t),f(this,ye,e)}get peerId(){return n(this,ci).getValue("peerId")}static initMedia(){return l(this,arguments,function*(t={},e=!1,r=void 0){var d;const i=(d=r==null?void 0:r.peerId)!=null?d:As.v4(),a=Ms.createContext(i,{peerId:i}),o=a.getValue("logger");o.init(a);const c=new gg(a,o);return yield c.init(t,e,a),a.setValue("defaults",{mediaHandler:c}),c})}static init(t){return l(this,null,function*(){var T,v,w,C,k,R;Z.init();const e=(v=(T=t==null?void 0:t.cachedUserDetails)==null?void 0:T.peerId)!=null?v:As.v4(),{authToken:r,baseURI:i}=t,P=$M(r,i),{meetingId:a}=P,o=Co(P,["meetingId"]);window.__zone_symbol__DISABLE_WRAPPING_UNCAUGHT_PROMISE_REJECTION=!0;const c=ur.setupContext(e,t,a,o),d=c.getValue("telemetry"),u=c.getValue("logger");fm(u),yh.init(u),d.init(c,{roomName:a,userId:o.participantId,organizationId:o.orgId,peerId:e},(C=(w=t.modules)==null?void 0:w.tracing)!=null?C:!0),u.init(c),u.info("Client::init::options",{clientInitOptions:U(b({},t),{authToken:`${(k=t.authToken)==null?void 0:k.slice(0,10)}...
|
|
10
|
+
${(R=t.authToken)==null?void 0:R.slice(-10)}`})});const p=yield Eo.init(c),m=new ur(c,p);return c.setValue("meeting",m),m})}static setupContext(t,e,r,i){var d,u;const a=Ms.createContext(t,e),o=b(b({},RS),e==null?void 0:e.modules),c=e.defaults||{audio:!0,video:!0};return a.setValue("options",e),a.setValue("peerId",t),a.setValue("modules",o),a.setValue("sdkName","web-core"),a.setValue("meetingId",r),a.setValue("apiBase",i.apiBase),a.setValue("baseURI",i.baseURI),a.setValue("userId",i.participantId),a.setValue("organizationId",i.orgId),a.setValue("authToken",e.authToken),a.setValue("overrides",(d=e.overrides)!=null?d:{}),a.setValue("env",kS({baseURI:i.baseURI})),a.setValue("defaults",c),a.setValue("onError",e.onError||(()=>{})),a.setValue("cachedUserDetails",jt(e.cachedUserDetails)),a.setValue("sdkVersion","1.2.5-staging.3"),(u=e.modules)!=null&&u.experimentalAudioPlayback&&a.setValue("audioPlayback",new qM),a}join(){return l(this,null,function*(){const{selfController:t}=n(this,ye);return t.self.roomJoined?null:t.joinRoom()})}leave(t){return l(this,null,function*(){yh.cleanup(),n(this,ci).getValue("peerSessionStore").reset();const{selfController:e}=n(this,ye);return e.leaveRoom(t)})}get participants(){var t;return(t=n(this,ye).participantController)==null?void 0:t.participants}get self(){var t;return(t=n(this,ye).selfController)==null?void 0:t.self}get meta(){var t;return(t=n(this,ye).metaController)==null?void 0:t.meta}get ai(){var t;return(t=n(this,ye).metaController)==null?void 0:t.ai}get plugins(){var t;return(t=n(this,ye).pluginController)==null?void 0:t.plugins}get chat(){var t;return(t=n(this,ye).chatController)==null?void 0:t.chat}get polls(){var t;return(t=n(this,ye).pollController)==null?void 0:t.polls}get connectedMeetings(){var t;return(t=n(this,ye).connectedMeetingsController)==null?void 0:t.connectedMeetings}get recording(){var t;return(t=n(this,ye).recordingController)==null?void 0:t.recording}get livestream(){var t;return(t=n(this,ye).livestreamController)==null?void 0:t.livestream}get stage(){var t;return(t=n(this,ye).stageController)==null?void 0:t.stage}get stores(){return n(this,ye).storesManager}get audio(){return n(this,ci).getValue("audioPlayback")}get __internals__(){var t;return(t=n(this,ye).internalsController)==null?void 0:t.internals}joinRoom(){return l(this,null,function*(){return this.join()})}leaveRoom(t){return l(this,null,function*(){return this.leave(t)})}},ye=new WeakMap,ci=new WeakMap,Lh);ud([Ne("0002"),Ls.executeWithLock({methodName:"meeting.join",lockName:"Client.join",timeout:3e3})],ur.prototype,"join",1);ud([Ne("0003")],ur.prototype,"leave",1);ud([Ne("0001"),Ls.executeWithLock({methodName:"Client.init",lockName:"Client.init",timeout:3e3})],ur,"init",1);ur=ud([Ne("0000")],ur);const tm=ur;module.exports=tm;
|