@vkontakte/calls-sdk 2.8.6-dev.8abbf3b2.0 → 2.8.6-dev.8ff8b375.0
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/calls-sdk.cjs.js +8 -8
- package/calls-sdk.esm.js +8 -8
- package/classes/Conversation.d.ts +2 -1
- package/classes/Logger.d.ts +3 -0
- package/classes/SignalingActor.d.ts +9 -0
- package/classes/codec/IEncoder.d.ts +0 -1
- package/classes/screenshare/BaseStreamBuilder.d.ts +1 -1
- package/classes/transport/Statistics.d.ts +23 -10
- package/default/Signaling.d.ts +6 -6
- package/enums/ChatRoomEventType.d.ts +1 -1
- package/enums/ConversationOption.d.ts +3 -3
- package/enums/RecordRole.d.ts +1 -1
- package/enums/SignalingTransportStat.d.ts +17 -0
- package/enums/Stat.d.ts +22 -22
- package/package.json +1 -1
- package/static/ApiTransport.d.ts +1 -1
- package/static/Params.d.ts +0 -7
- package/static/SimulcastInfo.d.ts +1 -1
- package/utils/Lz4.d.ts +1 -1
- package/utils/MsgPackerBufferUtils.d.ts +1 -1
- package/worker/LibVPxDecoderWorker.d.ts +0 -1
- package/worker/LibVPxEncoderWorker.d.ts +0 -1
- package/worker/WebCodecsDecoderWorker.d.ts +0 -1
- package/worker/WebCodecsEncoderWorker.d.ts +0 -1
package/calls-sdk.cjs.js
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @vkontakte/calls-sdk v2.8.6-dev.
|
|
3
|
-
*
|
|
2
|
+
* @vkontakte/calls-sdk v2.8.6-dev.8ff8b375.0
|
|
3
|
+
* Tue, 15 Jul 2025 10:31:13 GMT
|
|
4
4
|
* https://st.mycdn.me/static/callssdk/2-8-6/doc/
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
-
"use strict";var po=Object.create;var Ei=Object.defineProperty;var uo=Object.getOwnPropertyDescriptor;var ho=Object.getOwnPropertyNames;var mo=Object.getPrototypeOf,fo=Object.prototype.hasOwnProperty;var go=(a,i,e)=>i in a?Ei(a,i,{enumerable:!0,configurable:!0,writable:!0,value:e}):a[i]=e;var Sn=(a,i)=>()=>(i||a((i={exports:{}}).exports,i),i.exports),_o=(a,i)=>{for(var e in i)Ei(a,e,{get:i[e],enumerable:!0})},ma=(a,i,e,t)=>{if(i&&typeof i=="object"||typeof i=="function")for(let r of ho(i))!fo.call(a,r)&&r!==e&&Ei(a,r,{get:()=>i[r],enumerable:!(t=uo(i,r))||t.enumerable});return a};var zt=(a,i,e)=>(e=a!=null?po(mo(a)):{},ma(i||!a||!a.__esModule?Ei(e,"default",{value:a,enumerable:!0}):e,a)),So=a=>ma(Ei({},"__esModule",{value:!0}),a);var le=(a,i,e)=>go(a,typeof i!="symbol"?i+"":i,e);var Xa=Sn((pf,Qa)=>{var ci=1e3,di=ci*60,li=di*60,Vt=li*24,Cc=Vt*7,Rc=Vt*365.25;Qa.exports=function(a,i){i=i||{};var e=typeof a;if(e==="string"&&a.length>0)return yc(a);if(e==="number"&&isFinite(a))return i.long?wc(a):Pc(a);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(a))};function yc(a){if(a=String(a),!(a.length>100)){var i=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(a);if(i){var e=parseFloat(i[1]),t=(i[2]||"ms").toLowerCase();switch(t){case"years":case"year":case"yrs":case"yr":case"y":return e*Rc;case"weeks":case"week":case"w":return e*Cc;case"days":case"day":case"d":return e*Vt;case"hours":case"hour":case"hrs":case"hr":case"h":return e*li;case"minutes":case"minute":case"mins":case"min":case"m":return e*di;case"seconds":case"second":case"secs":case"sec":case"s":return e*ci;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return e;default:return}}}}function Pc(a){var i=Math.abs(a);return i>=Vt?Math.round(a/Vt)+"d":i>=li?Math.round(a/li)+"h":i>=di?Math.round(a/di)+"m":i>=ci?Math.round(a/ci)+"s":a+"ms"}function wc(a){var i=Math.abs(a);return i>=Vt?Dr(a,i,Vt,"day"):i>=li?Dr(a,i,li,"hour"):i>=di?Dr(a,i,di,"minute"):i>=ci?Dr(a,i,ci,"second"):a+" ms"}function Dr(a,i,e,t){var r=i>=e*1.5;return Math.round(a/e)+" "+t+(r?"s":"")}});var es=Sn((uf,Za)=>{function Mc(a){e.debug=e,e.default=e,e.coerce=d,e.disable=s,e.enable=r,e.enabled=o,e.humanize=Xa(),e.destroy=p,Object.keys(a).forEach(u=>{e[u]=a[u]}),e.names=[],e.skips=[],e.formatters={};function i(u){let h=0;for(let g=0;g<u.length;g++)h=(h<<5)-h+u.charCodeAt(g),h|=0;return e.colors[Math.abs(h)%e.colors.length]}e.selectColor=i;function e(u){let h,g=null,b,w;function B(...W){if(!B.enabled)return;let Q=B,ue=Number(new Date),we=ue-(h||ue);Q.diff=we,Q.prev=h,Q.curr=ue,h=ue,W[0]=e.coerce(W[0]),typeof W[0]!="string"&&W.unshift("%O");let z=0;W[0]=W[0].replace(/%([a-zA-Z%])/g,(Ee,Ct)=>{if(Ee==="%%")return"%";z++;let Si=e.formatters[Ct];if(typeof Si=="function"){let Qi=W[z];Ee=Si.call(Q,Qi),W.splice(z,1),z--}return Ee}),e.formatArgs.call(Q,W),(Q.log||e.log).apply(Q,W)}return B.namespace=u,B.useColors=e.useColors(),B.color=e.selectColor(u),B.extend=t,B.destroy=e.destroy,Object.defineProperty(B,"enabled",{enumerable:!0,configurable:!1,get:()=>g!==null?g:(b!==e.namespaces&&(b=e.namespaces,w=e.enabled(u)),w),set:W=>{g=W}}),typeof e.init=="function"&&e.init(B),B}function t(u,h){let g=e(this.namespace+(typeof h>"u"?":":h)+u);return g.log=this.log,g}function r(u){e.save(u),e.namespaces=u,e.names=[],e.skips=[];let h=(typeof u=="string"?u:"").trim().replace(/\s+/g,",").split(",").filter(Boolean);for(let g of h)g[0]==="-"?e.skips.push(g.slice(1)):e.names.push(g)}function n(u,h){let g=0,b=0,w=-1,B=0;for(;g<u.length;)if(b<h.length&&(h[b]===u[g]||h[b]==="*"))h[b]==="*"?(w=b,B=g,b++):(g++,b++);else if(w!==-1)b=w+1,B++,g=B;else return!1;for(;b<h.length&&h[b]==="*";)b++;return b===h.length}function s(){let u=[...e.names,...e.skips.map(h=>"-"+h)].join(",");return e.enable(""),u}function o(u){for(let h of e.skips)if(n(u,h))return!1;for(let h of e.names)if(n(u,h))return!0;return!1}function d(u){return u instanceof Error?u.stack||u.message:u}function p(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return e.enable(e.load()),e}Za.exports=Mc});var ts=Sn((Be,kr)=>{Be.formatArgs=Dc;Be.save=kc;Be.load=Oc;Be.useColors=Ac;Be.storage=xc();Be.destroy=(()=>{let a=!1;return()=>{a||(a=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})();Be.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function Ac(){if(typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs))return!0;if(typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))return!1;let a;return typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&(a=navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/))&&parseInt(a[1],10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function Dc(a){if(a[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+a[0]+(this.useColors?"%c ":" ")+"+"+kr.exports.humanize(this.diff),!this.useColors)return;let i="color: "+this.color;a.splice(1,0,i,"color: inherit");let e=0,t=0;a[0].replace(/%[a-zA-Z%]/g,r=>{r!=="%%"&&(e++,r==="%c"&&(t=e))}),a.splice(t,0,i)}Be.log=console.debug||console.log||(()=>{});function kc(a){try{a?Be.storage.setItem("debug",a):Be.storage.removeItem("debug")}catch{}}function Oc(){let a;try{a=Be.storage.getItem("debug")||Be.storage.getItem("DEBUG")}catch{}return!a&&typeof process<"u"&&"env"in process&&(a=void 0),a}function xc(){try{return localStorage}catch{}}kr.exports=es()(Be);var{formatters:Nc}=kr.exports;Nc.j=function(a){try{return JSON.stringify(a)}catch(i){return"[UnexpectedJSONParseError]: "+i.message}}});var rp={};_o(rp,{Api:()=>_i,ApiExternal:()=>hn,ArrayDequeue:()=>un,AuthData:()=>be,BaseLogger:()=>Pt,CallDirection:()=>Ne,CallType:()=>ct,ChatRoomEventType:()=>Yr,ConversationFeature:()=>Qr,ConversationOption:()=>Wt,DebugMessageType:()=>Hn,ExternalIdType:()=>Xr,FacingMode:()=>St,FatalError:()=>re,HangupReason:()=>G,HangupType:()=>D,MediaOption:()=>se,MediaTrackKind:()=>Ge,MediaType:()=>si,MuteState:()=>We,ParticipantState:()=>Y,ParticipantStateDataValue:()=>ea,ParticipantStatus:()=>dr,RecordRole:()=>Qs,RoomsEventType:()=>hi,Signaling:()=>jt,SignalingCommandType:()=>x,SignalingConnectionType:()=>Ke,SignalingNotification:()=>L,TransportTopology:()=>tt,UserRole:()=>ht,UserType:()=>ie,VolumeDetector:()=>Et,acceptCall:()=>Ld,acceptPromotion:()=>Gl,activateRooms:()=>Pl,addMovie:()=>bl,addParticipant:()=>jd,addParticipantInternal:()=>Wd,authorize:()=>Nd,browser:()=>yd,callInternal:()=>Xs,callTo:()=>Od,captureScreen:()=>Kd,captureVmoji:()=>qd,changeAudioEffect:()=>Nl,changeConversationOptions:()=>ol,changeDevice:()=>Hd,changeParticipantState:()=>Xd,changePriorities:()=>Qd,changeVideoEffect:()=>xl,chatHistory:()=>dl,chatMessage:()=>cl,chatMessageInternal:()=>ao,createJoinLink:()=>hl,customData:()=>ll,customDataInternal:()=>so,debug:()=>Dl,debugMessage:()=>kl,declineCall:()=>Ud,enableFeatureForRoles:()=>Jl,enableVideoSuspend:()=>al,enableVideoSuspendSuggest:()=>sl,feedback:()=>ql,forceRelayPolicy:()=>_l,getAnonymTokenByLink:()=>fl,getAudienceModeHands:()=>Vl,getParticipantListChunk:()=>Hl,getParticipants:()=>Kl,getStreamInfo:()=>Tl,getWaitingHall:()=>Fl,grantRoles:()=>tl,grantRolesInternal:()=>io,hangup:()=>Vd,init:()=>kd,joinCall:()=>Bd,joinCallByLink:()=>Fd,joinCallInternal:()=>eo,logClientEvent:()=>zl,muteParticipant:()=>il,muteParticipantInternal:()=>ro,pinParticipant:()=>rl,pinParticipantInternal:()=>no,processPush:()=>xd,processPushInternal:()=>Zs,promoteParticipant:()=>jl,publishStream:()=>Il,putHandsDown:()=>Zd,recordSetConf:()=>El,removeHistoryRecords:()=>Yl,removeJoinLink:()=>ml,removeMovie:()=>Rl,removeParticipant:()=>Gd,removeParticipantInternal:()=>to,removeRooms:()=>Ml,requestAsr:()=>Zl,requestPromotion:()=>Wl,setAudioEffects:()=>Ad,setAudioStream:()=>Ll,setLocalResolution:()=>Yd,setLogger:()=>wd,setMediaModifiers:()=>nl,setStatisticsInterval:()=>Al,setVideoEffects:()=>Md,setVideoStream:()=>$d,setVmoji:()=>Dd,setVmojiFill:()=>Bl,setVmojiSvg:()=>Ul,setVolume:()=>gl,startAsr:()=>Ql,startAudienceConversation:()=>ul,startConversation:()=>pl,startStream:()=>Sl,startUrlSharing:()=>ep,stopAsr:()=>Xl,stopStream:()=>vl,stopUrlSharing:()=>tp,switchRoom:()=>wl,toggleLocalAudio:()=>Jd,toggleLocalVideo:()=>zd,updateDisplayLayout:()=>el,updateMovie:()=>Cl,updateRooms:()=>yl,uploadDebugLogs:()=>Ol,userFeedbackStats:()=>$l,utils:()=>Pd,version:()=>ip});module.exports=So(rp);var ta=zt(require("webrtc-adapter"));var Pt=class{log(i,e,t=!1){}destroy(){}};var ne=class{constructor(){this._handlers={};this._listeners=[]}_triggerEvent(i,...e){if(this._handlers.hasOwnProperty(i))for(let t of this._handlers[i])t.apply(this,e)}addEventListener(i,e){if(typeof e!="function")throw new Error("Listener should be a function");return this._handlers.hasOwnProperty(i)||(this._handlers[i]=[]),this._handlers[i].push(e),{dispose:this.removeEventListener.bind(this,i,e)}}removeEventListener(i,e){if(!this._handlers.hasOwnProperty(i))return;e||delete this._handlers[i];let t=this._handlers[i].indexOf(e);t>=0&&this._handlers[i].splice(t,1)}subscribe(i,e,t){let r=i.addEventListener(e,t);this._listeners.push(r)}unsubscribe(){this._listeners.forEach(i=>{i.dispose()})}};var Ti=class extends ne{get ready(){return!0}setParticipantIdRegistry(i){}requestRealloc(){}setEndpoint(i){}setWebTransportEndpoint(i){}setConversationId(i){}readyToSend(i=!0){}cleanup(){}requestTestMode(i,e){}getNextCommandSequenceNumber(){return 0}};var fa=(ee=>(ee.CANCELED="CANCELED",ee.REJECTED="REJECTED",ee.REMOVED="REMOVED",ee.HUNGUP="HUNGUP",ee.MISSED="MISSED",ee.BUSY="BUSY",ee.FAILED="FAILED",ee.NETWORK_ERROR="NETWORK_ERROR",ee.KILLED="KILLED",ee.BANNED="BANNED",ee.HAS_ACTIVE_CALL="HAS_ACTIVE_CALL",ee.CALLER_IS_BLOCKED="CALLER_IS_BLOCKED",ee.NOT_FRIENDS="NOT_FRIENDS",ee.CALLEE_IS_OFFLINE="CALLEE_IS_OFFLINE",ee.CALLER_IS_REJECTED="CALLER_IS_REJECTED",ee.UNKNOWN_ERROR="UNKNOWN_ERROR",ee.UNSUPPORTED="UNSUPPORTED",ee.OLD_VERSION="OLD_VERSION",ee.SERVICE_DISABLED="SERVICE_DISABLED",ee.EXTERNAL_API_ERROR="EXTERNAL_API_ERROR",ee.SOCKET_CLOSED="SOCKET_CLOSED",ee.ENDED="ENDED",ee.KILLED_WITHOUT_DELETE="KILLED_WITHOUT_DELETE",ee.ANOTHER_DEVICE="ANOTHER_DEVICE",ee.NOT_FOUND="NOT_FOUND",ee.VCHAT_DETAILED_ERROR="VCHAT_DETAILED_ERROR",ee))(fa||{}),D=fa;var G=class a extends Error{constructor(i,e){super(),this.name="HangupReason",this.code=e&&e.code||0,this.remote=e&&e.remote||!1,this.custom_error=e?.custom_error??null,Object.values(D).indexOf(i)>-1?this.hangup=i:this.error=i;let t=[];this.error&&t.push("error"),this.remote&&t.push("remote"),this.code&&t.push(`code: ${this.code}`),e&&e.message&&t.push(`message: '${e.message}'`),this.message=i+(t.length?` (${t.join(", ")})`:""),Error.captureStackTrace&&Error.captureStackTrace(this,a)}};var R=class a extends Pt{constructor(e,t){super();this._batchInterval=3e3;this._batchedLogItems=[];this._batchedClientStats=[];this._batchedClientEvents=[];this._batchTimeout=null;this._serverTimeDelta=0;this._api=e,this._externalLogger=t,this._calculateServerTimeDelta()}_sendLogItems(e){this._api.log(e)}_sendClientStats(e){this._api.logClientStats(e)}_sendClientEvents(e){this._api.logClientEvents(e)}_sendBatch(){this._stopTimeout();let e=!1;this._batchedLogItems.length>0&&(this._sendLogItems(this._batchedLogItems),this._batchedLogItems=[],e=!0),this._batchedClientStats.length>0&&(this._sendClientStats(this._batchedClientStats),this._batchedClientStats=[],e=!0),this._batchedClientEvents.length>0&&(this._sendClientEvents(this._batchedClientEvents),this._batchedClientEvents=[],e=!0),e&&this._startTimeout()}_startTimeout(){this._batchTimeout=window.setTimeout(()=>this._sendBatch(),this._batchInterval)}_stopTimeout(){this._batchTimeout&&(clearTimeout(this._batchTimeout),this._batchTimeout=null)}async _calculateServerTimeDelta(){try{let e=await this._api.getServerTime();this._serverTimeDelta=Date.now()-e}catch{}}_now(){return Date.now()-this._serverTimeDelta}log(e,t,r=!1){let n={};typeof t<"u"&&(n.param=t),this._logInternal(e,n,r),this._externalLogger&&this._externalLogger.log(e,t,r)}logCustom(e,t,r=!1){this._logInternal(e,t,r)}logClientStats(e,t=!1){let r=Object.assign(e,{vcid:U.id(),timestamp:this._now()});Object.keys(r).forEach(n=>{r[n]===void 0&&delete r[n]}),this._batchedClientStats.push(r),(t||!this._batchTimeout)&&this._sendBatch()}logClientEvent(e,t=!1){let r=Object.assign(e,{vcid:U.id(),timestamp:this._now()});this._batchedClientEvents.push(r),(t||!this._batchTimeout)&&this._sendBatch()}_logInternal(e,t,r){let n={type:1,time:0,operation:e,timestamp:this._now(),custom:Object.assign(t,{vcid:U.id()}),uid:this._api.getUserId()};this._batchedLogItems.push(n),(r||!this._batchTimeout)&&this._sendBatch()}destroy(){this._sendBatch(),this._stopTimeout(),this._externalLogger&&this._externalLogger.destroy()}static create(e,t){a._instance||(a._instance=new a(e,t))}static log(e,t,r=!1){a._instance&&a._instance.log(e,t,r)}static logCustom(e,t,r=!1){a._instance&&a._instance.logCustom(e,t,r)}static logClientStats(e,t=!1){a._instance&&a._instance.logClientStats(e,t)}static logClientEvent(e,t=!1){a._instance&&a._instance.logClientEvent(e,t)}static destroy(){a._instance&&a._instance.destroy(),a._instance=null}};var N=require("messagepack");var ga=(O=>(O.RECOVER="recover",O.ACCEPT_CALL="accept-call",O.ADD_PARTICIPANT="add-participant",O.REMOVE_PARTICIPANT="remove-participant",O.HANGUP="hangup",O.TRANSMIT_DATA="transmit-data",O.ACCEPT_PRODUCER="accept-producer",O.ALLOCATE_CONSUMER="allocate-consumer",O.CHANGE_MEDIA_SETTINGS="change-media-settings",O.CHANGE_PARTICIPANT_STATE="change-participant-state",O.CHANGE_STREAM_PRIORITIES="change-streams-priorities",O.UPDATE_DISPLAY_LAYOUT="update-display-layout",O.REPORT_PERF_STAT="report-perf-stat",O.REPORT_SHARING_STAT="report-sharing-stat",O.REPORT_NETWORK_STAT="report-network-stat",O.RECORD_START="record-start",O.RECORD_STOP="record-stop",O.RECORD_PUBLISH="record-publish",O.RECORD_SET_CONF="record-set-conf",O.RECORD_GET_STATUS="record-get-status",O.SWITCH_MICRO="switch-micro",O.SWITCH_TOPOLOGY="switch-topology",O.REQUEST_REALLOC="request-realloc",O.CHAT_MESSAGE="chat-message",O.CHAT_HISTORY="chat-history",O.CUSTOM_DATA="custom-data",O.GRANT_ROLES="grant-roles",O.MUTE_PARTICIPANT="mute-participant",O.ENABLE_FEATURE_FOR_ROLES="enable-feature-for-roles",O.PIN_PARTICIPANT="pin-participant",O.UPDATE_MEDIA_MODIFIERS="update-media-modifiers",O.CHANGE_OPTIONS="change-options",O.GET_WAITING_HALL="get-waiting-hall",O.GET_PARTICIPANT_LIST_CHUNK="get-participant-list-chunk",O.GET_PARTICIPANTS="get-participants",O.PROMOTE_PARTICIPANT="promote-participant",O.REQUEST_TEST_MODE="request-test-mode",O.ADD_MOVIE="add-movie",O.UPDATE_MOVIE="update-movie",O.REMOVE_MOVIE="remove-movie",O.START_URL_SHARING="start-url-sharing",O.STOP_URL_SHARING="stop-url-sharing",O.GET_ROOMS="get-rooms",O.UPDATE_ROOMS="update-rooms",O.ACTIVATE_ROOMS="activate-rooms",O.REMOVE_ROOMS="remove-rooms",O.SWITCH_ROOM="switch-room",O.FEEDBACK="feedback",O.ASR_START="asr-start",O.ASR_STOP="asr-stop",O.REQUEST_ASR="request-asr",O.REQUEST_PROMOTION="request-promotion",O.ACCEPT_PROMOTION="accept-promotion",O.GET_HAND_QUEUE="get-hand-queue",O.ENABLE_VIDEO_SUSPEND="enable-video-suspend",O.ENABLE_VIDEO_SUSPEND_SUGGEST="enable-video-suspend-suggest",O.PUT_HANDS_DOWN="put-hands-down",O.CHANGE_SIMULCAST="change-simulcast",O))(ga||{}),x=ga;var _a=(W=>(W.MIC_CAMERA_PERMISSION="mic_camera",W.CAMERA_PERMISSION="camera",W.MIC_PERMISSION="mic",W.CAMERA_ACCESS="cameralock",W.MIC_ACCESS="miclock",W.MIC_NOT_FOUND="nomic",W.SCREEN_PERMISSION="screenpermission",W.SCREEN_ACCESS="screenlock",W.CONNECTION="connection",W.NETWORK="network",W.UNKNOWN="unknown",W.UNSUPPORTED="unsupported",W.SIGNALING_FAILED="signalingfailed",W.API="api",W.AUTH="auth",W.OVERCONSTRAINED="overconstrained",W))(_a||{}),re=_a;var Sa=(s=>(s.AUDIO="AUDIO",s.VIDEO="VIDEO",s.SCREEN_SHARING="SCREEN_SHARING",s.MOVIE_SHARING="MOVIE_SHARING",s.AUDIO_SHARING="AUDIO_SHARING",s.ANIMOJI="ANIMOJI",s))(Sa||{}),se=Sa;var va=(v=>(v.ERROR="callError",v.DEVICES="callDevices",v.CALL_SPEC_ERROR="callSpecError",v.ICE_CONNECTION_STATE="callIceConnectionState",v.ICE_CONNECTION_TYPE="callIceConnectionType",v.ICE_RESTART="callIceRestart",v.PUSH="callPush",v.OUTGOING_CALL="callStart",v.CALL_FINISH="call_finish",v.OUTGOING_MULTIPARTY_CALL="callStartMultiparty",v.JOIN_CONVERSATION="callJoinConversation",v.ACCEPTED_OUTGOING="callAcceptedOutgoing",v.ACCEPT_INCOMING="callAcceptIncoming",v.DECLINE_INCOMING="callDeclineIncoming",v.ACCEPT_CONCURRENT="callAcceptConcurrent",v.HANGUP="callHangup",v.CODEC_USAGE="codec_usage",v.MEDIA_STATUS="callMediaStatus",v.DEVICE_CHANGED="callDeviceChanged",v.SOCKET_ACTION="callSocketAction",v.ADD_PARTICIPANT="callAddParticipant",v.REMOVE_PARTICIPANT="callRemoveParticipant",v.POOR_CONNECTION="callPoorConnection",v.TOPOLOGY_CHANGE_REQUESTED="callTopologyChangeRequested",v.RELAY_POLICY="callForceRelay",v.PAT_ALLOCATED="patAllocate",v.PAT_DEALLOCATED="patDeallocate",v.PAT_ERROR="patError",v.PAT_WAITING_TIME_ERROR="patWaitingTimeError",v.PAT_OUTDATED_RESPONSE="patOutdatedResponse",v.SIGNALING_CONNECTED="signaling_connected",v.RECONNECT="callReconnect",v.SCREENSHARE_FIRST_FRAME="screen_share_first_frame",v.SCREENSHARE_FREEZE_DURATION="callScreenshareFreezeDuration",v.FIRST_MEDIA_RECEIVED="first_media_received",v.CALL_EVENTUAL_STAT="callEventualStat",v.CALL_DECLINED_OR_HANGED_LOCALLY="CallDeclinedOrHangedLocally",v.USER_FEEDBACK_RECEIVED="UserFeedbackReceived",v.CALL_START="call_start",v.WEBSOCKET_CONNECTED="websocket_connected",v.WEBSOCKET_RECONNECTED="websocket_reconnected",v.WEBSOCKET_FAILED_PINGS="websocket_failed_pings",v.WEBSOCKET_FAILED_EXCEPTION="websocket_failed_exception",v.WEBSOCKET_TIMEOUT="websocket_timeout",v.WEBSOCKET_RESTART="websocket_restart",v.WEBTRANSPORT_CONNECTED="webtransport_connected",v.WEBTRANSPORT_RECONNECTED="webtransport_reconnected",v.WEBTRANSPORT_FAILED_PINGS="webtransport_failed_pings",v.WEBTRANSPORT_FAILED_EXCEPTION="webtransport_failed_exception",v.WEBTRANSPORT_TIMEOUT="webtransport_timeout",v.WEBTRANSPORT_RESTART="webtransport_restart",v))(va||{}),T=va;var vn=zt(require("@vkontakte/libvpx"));var ze=class{constructor(){this._worker=null}async _createWorker(i,e,t=[],r={},n=[]){return new Promise((s,o)=>{let d=t.join(","),p=new Blob([i,`exports.default(${d});`],{type:"application/javascript; charset=utf-8"}),u=window.URL.createObjectURL(p);this._worker=new Worker(u),this._worker.onmessage=h=>{switch(h.data.type){case"ready":s();break;case"error":o(h.data.error);break;case"frame":e(h.data);break;case"debug":c.debug(h.data.message);break;case"log_error":R.log(T.ERROR,h.data.message);break}},this._sendToWorker("init",r,n)})}_removeWorker(){this._worker?.terminate(),this._worker=null}_sendToWorker(i,e={},t=[]){this._worker?.postMessage(Object.assign({type:i},e),t)}static isBrowserSupported(){throw new Error("Not implemented")}};var wt=class extends ze{async init(i,e){c.debug("LibVPxDecoder started"),await this._createWorker('"use strict";var exports=(()=>{var d=Object.defineProperty;var y=Object.getOwnPropertyDescriptor;var x=Object.getOwnPropertyNames;var E=Object.prototype.hasOwnProperty;var R=(o,t)=>{for(var e in t)d(o,e,{get:t[e],enumerable:!0})},h=(o,t,e,a)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of x(t))!E.call(o,s)&&s!==e&&d(o,s,{get:()=>t[s],enumerable:!(a=y(t,s))||a.enumerable});return o};var V=o=>h(d({},"__esModule",{value:!0}),o);var D={};R(D,{default:()=>M});var M=(o,t)=>{let e=null,a=null,s=!0;function c(){return o({locateFile:t}).then(r=>a=r)}function f(r,u,n,m){if(!a){self.postMessage({type:"log_error",message:"decoder-init-fail-libvpx"}),self.postMessage({type:"frame",error:"Fatal initialization error"});return}if(s!==n&&(s=n,e&&(e=null,self.postMessage({type:"debug",message:`LibVPxDecoder codec changed to ${n?"VP9":"VP8"} - reinitialize`}))),!e&&(self.postMessage({type:"debug",message:`LibVPxDecoder codec ${n?"VP9":"VP8"}`}),e=new a.VpxDecoder,e.debug(m),!e.init(n?a.VpxType.VP9:a.VpxType.VP8))){e=null,self.postMessage({type:"frame",error:"Decoder failed to create"});return}try{e.allocateBuffer(u.byteLength).set(new Uint8Array(u))}catch(i){self.postMessage({type:"debug",message:i}),e=null,self.postMessage({type:"frame",error:String(i)});return}if(!(e.decode()&&e.nextImage())){self.postMessage({type:"frame",error:"Decode failed"});return}let l=e.getImageBuffer();if(!l){self.postMessage({type:"frame",error:"No decoded data"});return}let b=e.getImageWidth(),g=e.getImageHeight();e.nextImage()&&(self.postMessage({type:"debug",message:"LibVPxDecoder dropped frame"}),self.postMessage({type:"log_error",message:"LibVPxDecoder-drop"}));let p=new Uint8ClampedArray(l.byteLength);p.set(l),self.postMessage({type:"frame",data:p.buffer,width:b,height:g},[p.buffer])}c().then(()=>{self.onmessage=r=>{switch(r.data.type){case"frame":f(r.data.timestamp,r.data.data,r.data.isVP9,r.data.debug);break}},self.postMessage({type:"ready"})}).catch(r=>{self.postMessage({type:"error",error:String(r)})})};return V(D);})();\n',t=>{if(t.error)c.warn("LibVPxDecoder",t.error),e(t.error);else{let r=new ImageData(new Uint8ClampedArray(t.data),t.width,t.height);i(r)}},[vn.default,vn.default.getUrl])}decodeFrame(i,e,t,r){this._sendToWorker("frame",{timestamp:i,data:e.buffer,isVP9:t,keyFrame:r,debug:c.enabled()},[e.buffer])}destroy(){this._removeWorker(),c.debug("LibVPxDecoder destroyed")}static isBrowserSupported(){return"WebAssembly"in window&&"Worker"in window}};var nt=class extends ze{async init(i,e){c.debug("WebCodecsDecoder started"),await this._createWorker('"use strict";var exports=(()=>{var i=Object.defineProperty;var D=Object.getOwnPropertyDescriptor;var R=Object.getOwnPropertyNames;var y=Object.prototype.hasOwnProperty;var C=(o,e)=>{for(var n in e)i(o,n,{get:e[n],enumerable:!0})},A=(o,e,n,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of R(e))!y.call(o,t)&&t!==n&&i(o,t,{get:()=>e[t],enumerable:!(a=D(e,t))||a.enumerable});return o};var V=o=>A(i({},"__esModule",{value:!0}),o);var F={};C(F,{default:()=>k});var k=o=>{let e=null,n=!0,a=null,t=!1,f=1e3/15*2;function p(){self.postMessage({type:"ready"})}function m(r,b,d,c=!1){if(!e||n!==d){if(!c){self.postMessage({type:"frame",error:"WebCodecsDecoder dropped frame - waiting for keyframe"});return}n=d,e?self.postMessage({type:"debug",message:`WebCodecsDecoder codec changed to ${d?"VP9":"VP8"}`}):(self.postMessage({type:"debug",message:`WebCodecsDecoder codec ${d?"VP9":"VP8"}`}),e=new VideoDecoder({output:s=>{l();let g=o?[s]:[];self.postMessage({type:"frame",data:s},g),s.close()},error:s=>{l(),e&&e.state!=="closed"&&e.close(),e=null,self.postMessage({type:"frame",error:"WebCodecsDecoder failed, reinitialize: "+String(s)})}})),e.configure(u(d))}if(t&&!c){self.postMessage({type:"frame",error:"WebCodecsDecoder dropped frame after reset - waiting for keyframe"});return}t=!1;let E=new EncodedVideoChunk({type:c?"key":"delta",timestamp:r,data:b});e.decode(E),a=setTimeout(()=>{t=!0,e?.reset(),e?.configure(u(d)),self.postMessage({type:"frame",error:"WebCodecsDecoder reset because of decode timeout"})},f)}self.onmessage=r=>{switch(r.data.type){case"init":p();break;case"frame":m(r.data.timestamp,r.data.data,r.data.isVP9,r.data.keyFrame);break}};function l(){a&&clearTimeout(a),a=null}function u(r){return{codec:r?"vp09.00.50.08":"vp8"}}};return V(F);})();\n',t=>{t.error?(c.warn("WebCodecsDecoder",t.error),e(t.error)):(i(t.data),t.data.close())},[P.baseChromeVersion()>=92||P.browserName()==="Safari"])}decodeFrame(i,e,t,r=!1){this._sendToWorker("frame",{timestamp:i,data:e.buffer,isVP9:t,keyFrame:r},[e.buffer])}destroy(){this._removeWorker(),c.debug("WebCodecsDecoder destroyed")}static isBrowserSupported(){return"VideoDecoder"in window&&"Worker"in window&&"VideoFrame"in window&&!P.isBrokenVP9Decoder()&&P.browserName()!=="Firefox"}};var Mt=class{constructor(i=null,e=0){this._counter=0;this._interval=0;this._lastCalculationTime=Date.now();this._onCalculated=null;this._onCalculated=i,e&&(this._interval=window.setInterval(()=>this.calculate(),e))}increment(i=1){this._counter+=i}calculate(){let i=Date.now(),e=i-this._lastCalculationTime,t=Math.round(this._counter*1e3/e);return this._counter=0,this._lastCalculationTime=i,this._onCalculated?.(t),t}destroy(){window.clearInterval(this._interval),this._interval=0}};var Pa=require("bit-buffer");var Ia=(e=>(e.USER="USER",e.GROUP="GROUP",e))(Ia||{}),ie=Ia;var gt={HEIGHT:720,WIDTH:1280,BITRATE:1e6},bi="L1T2",Ta=[{dimension:320,bitrate:18e4},{dimension:520,bitrate:4e5},{dimension:640,bitrate:5e5},{dimension:960,bitrate:9e5},{dimension:1280,bitrate:12e5},{dimension:1920,bitrate:25e5},{dimension:2560,bitrate:35e5},{dimension:3840,bitrate:5e6}],vo={h:1,m:2,l:4};function ba(a,i){return!a||!i?a===i:a.streams.length===i.streams.length?a.streams.every((e,t)=>I.isObjectsEquals(e,i.streams[t])):!1}function Ea(a,i){for(let e of i)if(a<=e.dimension)return e.bitrate;return length>0?i[length-1].bitrate:Ta[0].bitrate}function Ci(a=gt.WIDTH,i=gt.HEIGHT,e=Ta){let t=["h","m","l"],r=Math.max(a,i),n=1;r>=960?n=3:r>=480&&(n=2);let s={streams:[]},o=30,d=Ea(r,e)??gt.BITRATE;for(let p=0;p<n;p++){let u=t[p];s.streams.push({rid:u,width:a,height:i,fps:o,bitrate:d}),a=Math.round(a/2),i=Math.round(i/2),d=Ea(Math.max(a,i),e)??Math.round(d/2)}return s}function er(a){return vo[a]??1}var Ca=typeof Object.fromEntries=="function"?Object.fromEntries:function(a){if(!a||!a[Symbol.iterator])throw new Error("Object.fromEntries() requires a single iterable argument");let i={};for(let[e,t]of a)i[e]=t;return i};async function Ra(a){return new Promise((i,e)=>{let t=new FileReader;t.onload=r=>{i(r.target?.result)},t.onerror=e,t.readAsArrayBuffer(a)})}var Jt=":",ir="d",Io=533,tr="a=fmtp:",Eo="sps-pps-idr-in-keyframe=1",In;($e=>{let a=/[\r\n]+/,i=`\r
|
|
8
|
-
`;function e(
|
|
9
|
-
`);for(let A of y)if(A.startsWith("a=fingerprint")){let H=A.split(" ");if(H.length===2){C=H[1];break}}if(!C)return BigInt(-1);let v=C.split(":"),_=BigInt(0);for(let A=Math.min(7,v.length-1);A>=0;A--){let H=BigInt(parseInt(v[A],16));_<<=BigInt(8),_|=H}return BigInt.asIntN(64,_)}$e.sdpFingerprint=na;async function aa(m){return new Promise(C=>window.setTimeout(C,m))}$e.delay=aa;function sa(m,C,y){let v=[];return m.getSenders().forEach(_=>Xi(C,_,_.track,y,v)),v}$e.applySettings=sa;function Xi(m,C,y,v,_){if(!RTCRtpSender.prototype.getParameters||!RTCRtpSender.prototype.setParameters||!m||!y||y.kind!=="video")return;let A=y.getSettings();if(!A)return;let H=m.maxBitrateK?m.maxBitrateK*1024:null,F=A.width,X=A.height,_e=F&&X&&m.maxDimension?Math.max(1,Math.max(F,X)/m.maxDimension):null,O=m.maxFramerate||null;if(F&&X&&m.maxDimension&&m.maxDimension>Math.max(F,X)){let de=Math.round(F*X/256),Le=(Math.round(de*Io/1e4)+1)*1e4;H=H===null?Le:Math.min(Le,H)}let ve=m.degradationPreference||"balanced",fe=v[y.id];if(fe&&fe.bitrate===H&&fe.scaleResolutionDownBy===_e&&fe.maxFramerate===O&&fe.degradationPreference===ve){_[y.id]=fe;return}_[y.id]={bitrate:H,scaleResolutionDownBy:_e,maxFramerate:O,degradationPreference:ve};let Ie=C.getParameters();if(Ie.encodings||(Ie.encodings=[{}]),Ie.encodings.length>1&&F&&X&&m.maxDimension){let de=Math.round(m.maxDimension*1.35),Le=Math.max(F,X),Rt=Ci(F,X,m?.bitrates?.generic),$t=Rt.streams.length;c.log(`applyVideoTrackSettings: maxDim=${m.maxDimension} targetDim=${de} track=${F}x${X} sim=${JSON.stringify(Rt)}`),Ie.encodings.forEach((rt,Ii)=>{rt.scaleResolutionDownBy=er(rt.rid);let ua=Math.round(Le/rt.scaleResolutionDownBy);Ii<$t-1?rt.active=ua<de:Ii>=$t?rt.active=!1:rt.active=!0,Ii<$t?rt.maxBitrate=Rt.streams[Ii].bitrate:rt.maxBitrate=0,rt.scalabilityMode=bi})}else Ie.encodings.forEach(de=>{m?.scalabilityMode&&(de.scalabilityMode=m.scalabilityMode),H?de.maxBitrate=H:delete de.maxBitrate,_e?de.scaleResolutionDownBy=_e:delete de.scaleResolutionDownBy,O?de.maxFramerate=O:delete de.maxFramerate});if(Ie.degradationPreference=ve,Ie.encodings.length>0){C.setParameters?.(Ie).catch(Le=>{c.error("Failed to set sender parameters",Ie,Le)});let de=C.getParameters();c.log(`applyVideoTrackSettings: actual encodings= ${JSON.stringify(de.encodings)}`)}}$e.applyVideoTrackSettings=Xi;function mn(m,C){Array.isArray(C)||(C=[C]);for(let y of C)if(m.includes(y))return!0;return!1}$e.includesOneOf=mn;function oa(m){return Object.entries(m.participantState?.state||{}).reduce((C,[y,v])=>(m.participantState&&(C[y]={ts:m.participantState.stateUpdateTs[y],state:v}),C),{})}$e.mapParticipantState=oa;function ca(m){let C=m.map(y=>({uid:y.externalId,mediaSettings:y.mediaSettings,status:y.status,muteStates:y.muteStates,unmuteOptions:y.unmuteOptions,participantState:y.participantState,markers:y.markers,movieShareInfos:y.movieShareInfos}));return l.filterObservers?C.filter(y=>!y.uid.observer):C}$e.mapSharedParticipants=ca;function da(m,C){let y=Object.keys(m),v=Object.keys(C);if(y.length!==v.length)return!1;for(let _ of y)if(!v.hasOwnProperty(_)||m[_].state!==C[_].state||m[_].ts!==C[_].ts)return!1;return!0}$e.isEqualParticipantState=da;function fn(m,C,y=!1){let v=Object.keys(m),_=Object.keys(C);if(v.length!==_.length)return!1;for(let A of v){if(!C.hasOwnProperty(A))return!1;let H=m[A],F=C[A];if(y&&me(H)&&me(F))return fn(H,F,y);if(H!==F)return!1}return!0}$e.isObjectsEquals=fn;function la(m,C){if(m.length!==C.length)return!1;for(let y of m)if(C.indexOf(y)<0)return!1;return!0}$e.isArraysEquals=la;function pa(m){return!Object.keys(m).length}$e.isEmptyObject=pa;function he(m,C){if(!m&&!C)return 0;if(!m||!C)return m?-1:1;return v(C.rank,m.rank)||v(m.ts,C.ts)||y(m,C);function y(_,A){let H={[ie.USER]:0,[ie.GROUP]:1},{compositeUserId:F,deviceIdx:X}=vi(_.id),{compositeUserId:_e,deviceIdx:O}=vi(A.id),{id:ve,type:fe}=ee(F),{id:Ie,type:de}=ee(_e);return v(H[fe],H[de])||v(ve,Ie)||v(X,O)}function v(_,A){return _<A?-1:_===A?0:1}}$e.participantMarkerCompare=he;function V(m,C){let y=Object.entries(m).filter(([,v])=>Array.isArray(C)?!C.includes(v):v!==C);return Ca(y)}$e.objectFilterOutValues=V;function te(m,C,y){let v=y;for(let _ in m)m.hasOwnProperty(_)&&(v=C(v,m[_],_));return v}$e.objectReduce=te,$e.setImmediate=(()=>{let m=1,C={},y=null;return typeof MessageChannel<"u"&&(y=new MessageChannel,y.port1.onmessage=v=>{let _=v.data;C[_]&&(C[_](),delete C[_])}),function(v){if(y&&document.visibilityState==="hidden"){let A=m;return m=m>=Number.MAX_SAFE_INTEGER?1:m+1,C[A]=v,y.port2.postMessage(A),()=>{C[A]&&delete C[A]}}let _=setTimeout(v,0);return()=>clearTimeout(_)}})();function me(m){return m!==null&&typeof m=="object"&&!Array.isArray(m)}$e.isObject=me;function lt(m,C,y,v){function _(F,X){let _e=0,O=F.length,ve=!1;for(let fe=0;fe<F.length;fe++)if(F[fe].startsWith("m=video")&&(_e=fe),F[fe].startsWith("a=mid:"+X)&&(ve=!0),ve&&F[fe].startsWith("m=")){O=fe;break}return{start:_e,end:O}}function A(F,X,_e,O,ve,fe,Ie){let de="a=rid:"+O+" send";for(let Le=X;Le<_e;Le++)if(F[Le]===de){let $t=de+" max-width="+fe+";max-height="+Ie+";max-br="+ve;F[Le]=$t}}let H=C?.sender;if(H&&H.track&&C.mid){let F=m.split(a),{start:X,end:_e}=_(F,C.mid),O=H.getParameters();if(O.encodings)return O.encodings.forEach(ve=>{let fe=ve.rid,Ie=ve.maxBitrate,de=ve.scaleResolutionDownBy;if(y&&v&&de){let Le=""+Math.round(y/de),Rt=""+Math.round(v/de);A(F,X,_e,fe,Ie,Le,Rt)}}),F.join(i)}return m}$e.patchSimulcastAnswerSdp=lt})(In||(In={}));var I=In;var To=1e3;function oe(a,i,e=0){return i in a&&a[i]?a[i]:e}function En(...a){return i=>{for(let e of a)if(e(i))return!0;return!1}}function _t(a,i){return e=>e[a]===i}function bo(a){return(i,e)=>e[a]-i[a]}function Ri(a,i){return i.reduce((e,t)=>(e[t[a]]=t,e),{})}function Co(a){let i={},e=[];for(let t of a)i[t.id]||(i[t.id]=!0,e.push(t));return e}function Tn(a){return Object.keys(a).filter(i=>a[i]!==void 0).map(i=>[i,a[i]]).reduce((i,e)=>(i[e[0]]=I.isObject(e[1])?Tn(e[1]):e[1],i),{})}function Ro(a){let i=[];for(let e of a)e.forEach(t=>i.push(t));return i}async function yo(a){let i=[];return RTCRtpReceiver.prototype.getStats?(i.push(...a.getReceivers().map(e=>e.getStats())),i.push(...a.getSenders().map(e=>e.getStats()))):i.push(a.getStats()),Promise.all(i).then(Ro).then(Co)}function Po(a){let i=a.filter(_t("type","candidate-pair")).sort(bo("priority")).find(En(_t("nominated",!0),_t("selected",!0)));if(!i)return{timestamp:0,availableOutgoingBitrate:0,totalRoundTripTime:0,currentRoundTripTime:0,bytesSent:0,bytesReceived:0};let e={timestamp:i.timestamp,availableOutgoingBitrate:i.availableOutgoingBitrate||0,totalRoundTripTime:i.totalRoundTripTime||0,currentRoundTripTime:i.currentRoundTripTime||0,bytesSent:i.bytesSent||0,bytesReceived:i.bytesReceived||0},t=a.find(_t("id",i.remoteCandidateId));t&&Object.assign(e,{remote:{type:t.candidateType,address:t.ip||t.address,port:t.port,protocol:t.protocol}});let r=a.find(_t("id",i.localCandidateId));return r&&Object.assign(e,{local:{type:r.candidateType,address:r.ip||r.address,port:r.port,protocol:r.protocol,relayProtocol:r.relayProtocol,networkType:r.networkType}}),Tn(e)}function ya(a,i,e=!1){let t=Ri("id",a),r=e?a.filter(En(_t("type","remote-inbound-rtp"))):a.filter(En(_t("type","inbound-rtp"),_t("type","outbound-rtp")));return P.browserName()==="Firefox"&&(r=Object.values(r.reduce((n,s)=>{if(!n[s.ssrc])n[s.ssrc]=s;else{let o=Object.assign({},n[s.ssrc],s),d=n[s.ssrc].isRemote?s:n[s.ssrc];o.id=d.id,o.type=d.type,delete o.isRemote,delete o.remoteId,n[o.ssrc]=o}return n},{}))),r.map(n=>{let s=Number(n.ssrc),o=n.mediaType||n.kind,d=n.remoteId||n.trackId,p=n.type,u=n.codecId;if(!p||!s||!o)return null;let h={ssrc:s,type:p,kind:o,bytesReceived:oe(n,"bytesReceived"),bytesSent:oe(n,"bytesSent"),headerBytesReceived:oe(n,"headerBytesReceived"),headerBytesSent:oe(n,"headerBytesSent"),jitter:oe(n,"jitter"),packetsLost:oe(n,"packetsLost"),packetsReceived:oe(n,"packetsReceived"),packetsSent:oe(n,"packetsSent"),fractionLost:oe(n,"fractionLost"),pliCount:oe(n,"pliCount"),firCount:oe(n,"firCount"),nackCount:oe(n,"nackCount"),userId:i[s],freezeCount:oe(n,"freezeCount",0),totalFreezesDuration:oe(n,"totalFreezesDuration",0)},g="mid"in n&&typeof n.mid=="string"?n.mid:void 0,b="rid"in n&&typeof n.rid=="string"?n.rid:void 0;if(g&&(h.mid=g),b&&(h.rid=b),o==="video"){let w=oe(n,"framesDecoded"),B=oe(n,"totalInterFrameDelay"),W=oe(n,"totalSquaredInterFrameDelay"),Q=oe(n,"encoderImplementation"),ue=oe(n,"decoderImplementation");Q&&(h.encoderImplementation=Q),ue&&(h.decoderImplementation=ue),h.interframeDelayVariance=(W-B*B/w)/w}if(o==="video"&&h.type==="outbound-rtp"&&(h.totalEncodeTime=oe(n,"totalEncodeTime")??0),o==="audio"&&(h.totalSamplesReceived=oe(n,"totalSamplesReceived"),h.concealedSamples=oe(n,"concealedSamples"),h.insertedSamplesForDeceleration=oe(n,"insertedSamplesForDeceleration"),h.removedSamplesForAcceleration=oe(n,"removedSamplesForAcceleration"),h.silentConcealedSamples=oe(n,"silentConcealedSamples"),h.concealmentEvents=oe(n,"concealmentEvents"),h.totalAudioEnergy=oe(n,"totalAudioEnergy")),u&&t[u]){let w=t[u];h.clockRate=w.clockRate,h.mimeType=w.mimeType,o==="audio"&&w.sdpFmtpLine&&(h.sdpFmtpLine=w.sdpFmtpLine)}if(d&&t[d]){let w=t[d];h.frameHeight=w.frameHeight,h.frameWidth=w.frameWidth,h.framesDecoded=w.framesDecoded,h.framesReceived=w.framesReceived,h.framesDropped=w.framesDropped}return Tn(h)}).filter(n=>!!n)}function wo(a,i,e=!1){if(!i||!i.rtps||!a.rtps)return a;let t,r;e&&(t=Ri("ssrc",a?.remoteRtps||[]),r=Ri("ssrc",i?.remoteRtps||[]));let n=Ri("ssrc",a.rtps),s=Ri("ssrc",i.rtps),o=(a.timestamp-i.timestamp)/1e3;return!n||!s||Object.keys(n).forEach(d=>{let p=n[d],u=s[d];if(!(!p||!u)){if(p.bytesReceived&&p.bytesReceived>u.bytesReceived&&(p.bandwidth=Math.round((p.bytesReceived-u.bytesReceived)/o),p.bandwidth+=Math.round((p.headerBytesReceived-u.headerBytesReceived)/o)),p.bytesSent&&p.bytesSent>u.bytesSent&&(p.bandwidth=Math.round((p.bytesSent-u.bytesSent)/o),p.bandwidth+=Math.round((p.headerBytesSent-u.headerBytesSent)/o)),p.packetsReceived)if(p.packetsReceived>u.packetsReceived||p.packetsLost>u.packetsLost){let h=p.packetsLost-u.packetsLost,g=p.packetsReceived-u.packetsReceived;p.packetLoss=parseFloat((100*h/(h+g)).toFixed(2))}else p.packetLoss=0;if(p.freezeCount>u.freezeCount&&(p.freezeCountDelta=p.freezeCount-u.freezeCount),p.totalFreezesDuration>u.totalFreezesDuration){let h=p.totalFreezesDuration-u.totalFreezesDuration;p.totalFreezesDurationDelta=h}if(p.framesDropped&&u.framesDropped&&p.framesDropped>u.framesDropped&&(p.framesDroppedDelta=parseFloat(((p.framesDropped-u.framesDropped)/o).toFixed(0))),e&&p.type==="outbound-rtp"&&p.kind==="video"){let h=t?.[d],g=r?.[d],b=W=>W??0,w=Math.max(0,b(h?.packetsLost)-b(g?.packetsLost)),B=Math.max(1,p.packetsSent-u.packetsSent);a.transport.averageNetStat={currentRoundTripTime:(a.transport.currentRoundTripTime+i.transport.currentRoundTripTime)/2*1e3,lostPercent:Math.round(w/B*100)}}}}),a}async function yi(a,i,e={},t=!1){let r=await yo(a),n={timestamp:Date.now(),transport:Po(r),rtps:ya(r,e)};return t&&(n.remoteRtps=ya(r,e,!0)),i?wo(n,i,t):(await I.delay(To),yi(a,n,e,t))}function Je(a){performance.clearMarks(a),performance.mark(a)}function bn(a){performance.clearMarks(a)}function Yt(a){let i=performance.getEntriesByName(a)[0];if(typeof i>"u")return null;let e=Math.round(performance.now()-i.startTime);return performance.clearMarks(a),e}function Qt(a){return`${T.SCREENSHARE_FIRST_FRAME}_${Mo(a)}`}function Mo(a){return typeof a=="string"?a:JSON.stringify(a)}var Ye=class Ye{constructor(){this._eventualLogs=new Set}static create(){Ye._instance=new Ye}static logCallStat(i){if(Ye._instance?._eventualLogs.size){for(let e of Ye._instance._eventualLogs)Object.assign(e,{call_topology:i.call_topology,local_address:i.local_address,local_connection_type:i.local_connection_type,network_type:i.network_type,remote_address:i.remote_address,remote_connection_type:i.remote_connection_type,transport:i.transport}),R.logClientStats(e);Ye._instance._eventualLogs.clear()}R.logClientStats(i)}static logEventualStat(i){i.value===void 0&&(i.value=Yt(i.name)),i.value!==null&&Ye._instance?._eventualLogs.add(i)}static destroy(){Ye._instance?._destroy(),Ye._instance=null}_destroy(){this._eventualLogs.clear()}};Ye._instance=null;var Me=Ye;var rr=class{constructor(i){this._firstFrameReceived=!1;this._participantId=i}measure(i,e){if(this._firstFrameReceived)return;this._firstFrameReceived=!0;let t=Qt(this._participantId),r=Yt(t);r!==null&&Me.logEventualStat({name:T.SCREENSHARE_FIRST_FRAME,value:r,width:i,height:e})}};var Ao=65536,Xt=class a{constructor(i,e,t){this._chunks=[];this._participantId=i,this._onStream=e,this._onStat=t,this._statScreenShareFirstFrame=new rr(i)}appendChunk(i){let e=this._chunks.length;if(i.start)this._measureFreezeDuration(!1),this._measureFreezeDuration(!0),e&&(c.warn("[FrameBuilder] Cleanup buffer",Array.prototype.slice.call(this._chunks)),this._chunks=[]);else if(!e||(this._chunks[e-1].sequence+1)%Ao!==i.sequence){c.warn("[FrameBuilder] Got incorrect chunk");return}if(this._chunks.push(i),i.end){let t=this._processFrameData(),{width:r,height:n}=a.getFrameSize(t);this._processFrame({timestamp:i.timestamp,frameData:t,isVP9:i.isVP9,keyframe:i.keyframe,width:r,height:n}),this._statScreenShareFirstFrame.measure(r,n)}}destroy(){bn(T.SCREENSHARE_FREEZE_DURATION),bn(Qt(this._participantId)),this._chunks=[]}_processFrameData(){let i=this._chunks;this._chunks=[];let e=i.reduce((n,s)=>n+s.data.byteLength,0),t=new Uint8Array(e),r=0;for(let n of i)t.set(new Uint8Array(n.data),r),r+=n.data.byteLength;return t}static getFrameSize(i){let e={width:0,height:0},t=new Pa.BitStream(i.buffer);t.bigEndian=!0,t.index+=2;let r=t.readBits(1),s=t.readBits(1)<<1|r;return s===3&&t.index++,t.readBits(1)===1||t.readBits(1)!==0||(t.index++,t.index++,t.index+=24,s>=2&&t.index++,t.readBits(3)!==7?(t.index++,(s===1||s===3)&&(t.index+=3)):(s===1||s===3)&&t.index++,e.width=t.readBits(16)+1,e.height=t.readBits(16)+1),e}static isBrowserSupported(){throw new Error("Method `isBrowserSupported` is not implemented")}_measureFreezeDuration(i){if(i){Je(T.SCREENSHARE_FREEZE_DURATION);return}let e=Yt(T.SCREENSHARE_FREEZE_DURATION);e!==null&&e>1e3&&this._onStat({freeze_duration:e})}};var At=class{constructor(i){this._onStream=i}async drawFrame(i){throw new Error("Method `drawFrame` is not supported by this implementation")}async drawImage(i){throw new Error("Method `drawImage` is not supported by this implementation")}static isBrowserSupported(){throw new Error("Method `isBrowserSupported` is not implemented")}};var Zt=class extends At{constructor(e){super(e);this._canvas=null;this._canvasContext=null;this._stream=null;this._track=null;c.debug("CanvasRenderer started"),this._useImageBitmap="ImageBitmap"in window}_createStream(e,t){this._canvas||(this._canvas=document.createElement("canvas"),this._canvas.width=e,this._canvas.height=t,this._canvas.style.pointerEvents="none",this._canvas.style.visibility="hidden",this._canvas.style.position="absolute",this._canvas.style.width="160px",this._canvas.style.height="90px",this._canvas.style.bottom="0",this._canvas.style.right="0",this._canvas.style.zIndex="5000",document.body.appendChild(this._canvas),this._useImageBitmap?this._canvasContext=this._canvas.getContext("bitmaprenderer"):this._canvasContext=this._canvas.getContext("2d"),this._stream=this._canvas.captureStream(0),this._track=this._stream.getVideoTracks()[0],this._track.contentHint="text")}_removeStream(){this._stream&&(this._stream.getTracks().forEach(e=>e.stop()),this._stream=null,this._track=null),this._canvasContext=null;try{this._canvas&&document.body.removeChild(this._canvas)}catch{}this._canvas=null}_requestCanvasFrame(){this._track&&this._track.requestFrame?this._track.requestFrame():this._stream&&this._stream.requestFrame&&this._stream.requestFrame()}async _drawImage(e){this._track||(this._createStream(e.width,e.height),this._onStream(this._stream));let t=this._canvas;if(t.width=e.width,t.height=e.height,this._useImageBitmap){let r;e instanceof ImageBitmap?r=e:r=await createImageBitmap(e,0,0,e.width,e.height),this._canvasContext.transferFromImageBitmap(r),r.close()}else{let r=this._canvasContext;r.clearRect(0,0,t.width,t.height),r.putImageData(e,0,0)}this._requestCanvasFrame()}async drawFrame(e){let t="createImageBitmap"in e?await e.createImageBitmap():await createImageBitmap(e);await this._drawImage(t)}async drawImage(e){await this._drawImage(e)}destroy(){this._removeStream(),c.debug("CanvasRenderer destroyed")}static isBrowserSupported(){return("CanvasCaptureMediaStream"in window||"CanvasCaptureMediaStreamTrack"in window)&&!(P.browserName()==="Safari"&&Number(P.browserVersion())===15)&&!(P.browserName()==="Firefox"&&Number(P.browserVersion())<60)}};var Dt=class extends At{constructor(i){super(i),c.debug("TrackGeneratorRenderer started"),this._generator=new MediaStreamTrackGenerator({kind:"video"}),this._writer=this._generator.writable.getWriter(),this._stream=new MediaStream([this._generator]),this._onStream(this._stream)}async drawFrame(i){await this._writer.write(i)}destroy(){this._writer.releaseLock(),this._generator.writable.close().then(()=>this._generator.stop()),c.debug("TrackGeneratorRenderer destroyed")}static isBrowserSupported(){return"VideoFrame"in window&&"MediaStreamTrackGenerator"in window&&nt.isBrowserSupported()}};var ei=class extends Xt{constructor(e,t,r){super(e,t,r);this._decoderReady=!1;this._decoderBusy=!1;this._decoderQueue=[];c.debug(`StreamBuilder started for participant [${e}]`),Dt.isBrowserSupported()?this._renderer=new Dt(t):this._renderer=new Zt(t),nt.isBrowserSupported()?this._decoder=new nt:this._decoder=new wt;let n=async o=>{this._decoderBusy=!1,"VideoFrame"in window&&o instanceof VideoFrame?await this._renderer.drawFrame(o):await this._renderer.drawImage(o),this._fpsMeter.increment(),this._decodeQueue()},s=o=>{this._decoderBusy=!1,this._decodeQueue()};this._decoder.init(n,s).then(()=>{this._decoderReady=!0,this._decodeQueue()}),this._fpsMeter=new Mt(o=>c.log(`[StreamBuilder][${e}] fps: ${o}`),2e4)}_processFrame(e){e.keyframe&&(this._decoderQueue=[]),this._decoderQueue.push(e),this._decodeQueue()}_decodeQueue(){if(!this._decoderReady||this._decoderBusy)return;let e=this._decoderQueue.shift();e&&(this._decoderBusy=!0,this._decoder.decodeFrame(e.timestamp,e.frameData,e.isVP9,e.keyframe))}destroy(){super.destroy(),this._fpsMeter.destroy(),this._decoder.destroy(),this._renderer.destroy(),c.debug(`StreamBuilder destroyed for participant ${this._participantId}`)}static isBrowserSupported(){return Zt.isBrowserSupported()||Dt.isBrowserSupported()}};function wa(a,i,e,t,r,n,s){let o=0;i&&(o|=1),e&&(o|=2),t&&(o|=4),s||(o|=8);let d=new ArrayBuffer(11),p=new DataView(d);if(p.setUint8(0,1),p.setUint16(1,r),p.setUint32(3,a),p.setUint8(7,n?1:0),p.setUint16(8,0),p.setUint8(10,o),!s)return d;let u=new Uint8Array(d.byteLength+s.byteLength);return u.set(new Uint8Array(d),0),u.set(new Uint8Array(s),d.byteLength),u.buffer}function Ma(a){let i=new DataView(a),e=i.getUint8(0),t=i.getUint16(1),r=i.getUint32(3),n=i.getUint8(7)===1,s=i.getUint16(8),o=i.getUint8(10),d=!!(o&1),p=!!(o&2),u=!!(o&4),h=!!(o&8);if(e!==1)throw new Error(`Unexpected protocol version. Got ${e}, expected 1`);return{timestamp:r,start:d,end:p,keyframe:u,sequence:t,isVP9:n,ssrc:s,eos:h,data:a.slice(11)}}function Aa(a){if(!a||!a.byteLength||a.byteLength!==4)return!1;let i=new DataView(a);return!(i.getUint8(0)!==1||i.getUint8(1)!==1||i.getUint16(2)!==0)}function Da(a){if(!a||!a.byteLength||a.byteLength!==10)return null;let i=new DataView(a);if(i.getUint8(0)!==1||i.getUint8(1)!==2||i.getUint16(2)!==0)return null;let n=i.getUint16(4),s=i.getUint32(6);return{seq:n,ts2:s}}var k=zt(require("simple-ebml-builder"));var Do=2**15-1,Cn=1,ko=5,Oo=5;var Rn=class a{constructor(i){this._sourceBuffer=null;this._queue=[];this._clearBufferTill=0;this._mediaSource=new MediaSource,this._codec=i;let e=()=>{this._mediaSource.removeEventListener("sourceopen",e),this._initBuffer(),this._handleQueue()};this._mediaSource.addEventListener("sourceopen",e,!1)}_handleQueue(){if(!this._sourceBuffer||this._sourceBuffer.updating||!this._queue.length)return;if(this._clearBufferTill&&this._sourceBuffer.buffered.length){let t=this._sourceBuffer.buffered.start(0);t<this._clearBufferTill&&(this._sourceBuffer.remove(t,this._clearBufferTill),c.debug(`[WebmBuilder] SourceBuffer cleanup from ${t} to ${this._clearBufferTill}`)),this._clearBufferTill=0;return}let i=this._queue;this._queue=[];let e=a._buildQueue(i);this._sourceBuffer.appendBuffer(e)}static _buildQueue(i){if(i.length){if(i.length===1)return k.build(i[0])}else return new Uint8Array;let e=i.reduce((n,s)=>n+s.countSize(),0),t=new Uint8Array(e),r=0;for(let n of i){let s=k.build(n);t.set(s,r),r+=s.byteLength}return t}_initBuffer(){this._sourceBuffer=this._mediaSource.addSourceBuffer(`video/webm; codecs="${this._codec}"`),this._sourceBuffer.mode="sequence",this._sourceBuffer.addEventListener("updateend",()=>this._handleQueue())}changeType(i){return this._codec=i,this._sourceBuffer?.changeType(i)}append(i,e=!1){this._queue.push(i),e&&this._handleQueue()}cleanup(){this._mediaSource?.readyState==="open"&&this._sourceBuffer?.abort();let i=this._sourceBuffer?.buffered,e=i?.length;if(!e)return;let t=i.start(0),r=Math.max(0,i.end(e-1)-ko);r-t>Oo&&(this._clearBufferTill=r)}destroy(){this._queue=[],this._mediaSource.readyState==="open"&&(this._sourceBuffer?.abort(),this._mediaSource.endOfStream()),this._sourceBuffer=null,this._clearBufferTill=0}get codec(){return this._codec}get mediaSource(){return this._mediaSource}get buffered(){return this._sourceBuffer?.buffered}},kt=class a extends Xt{constructor(e,t,r){super(e,t,r);this._mediaBuffer=null;this._video=null;this._stream=null;this._earliestTimestamp=0;this._clusterStartTime=0;this._lastFrameTimestamp=0;c.debug(`[WebmBuilder] started for participant [${e}]`)}static _intToU16BE(e){return new Uint8Array([e>>8,e])}static _genWebmHeader(){return k.element(k.ID.EBML,[k.element(k.ID.EBMLVersion,k.number(1)),k.element(k.ID.EBMLReadVersion,k.number(1)),k.element(k.ID.EBMLMaxIDLength,k.number(4)),k.element(k.ID.EBMLMaxSizeLength,k.number(8)),k.element(k.ID.DocType,k.string("webm")),k.element(k.ID.DocTypeVersion,k.number(2)),k.element(k.ID.DocTypeReadVersion,k.number(2))])}static _genSegmentHeader(e,t,r){let n=k.element(k.ID.Info,[k.element(k.ID.TimecodeScale,k.number(1e6)),k.element(k.ID.MuxingApp,k.string("vk-webm-builder")),k.element(k.ID.WritingApp,k.string("vk-webm-builder"))]),s=[k.element(k.ID.PixelWidth,k.number(e)),k.element(k.ID.PixelHeight,k.number(t))],o=k.element(k.ID.Tracks,k.element(k.ID.TrackEntry,[k.element(k.ID.TrackNumber,k.number(Cn)),k.element(k.ID.TrackUID,k.number(Cn)),k.element(k.ID.TrackType,k.number(1)),k.element(k.ID.FlagLacing,k.number(0)),k.element(k.ID.DefaultDuration,k.number(1e9)),k.element(k.ID.CodecID,k.string(`V_${r.toUpperCase()}`)),k.element(k.ID.Video,s)]));return k.unknownSizeElement(k.ID.Segment,[n,o])}static _genClusterHeader(e){return k.unknownSizeElement(k.ID.Cluster,[k.element(k.ID.Timecode,k.number(Math.round(e)))])}_createVideo(e){this._mediaBuffer=new Rn(e),this._video=document.createElement("video"),this._video.autoplay=!0,this._video.controls=!1,this._video.muted=!0,this._video.style.pointerEvents="none",this._video.style.visibility="hidden",this._video.style.position="absolute",this._video.style.width="160px",this._video.style.height="90px",this._video.style.bottom="0",this._video.style.right="0",this._video.style.zIndex="5000",this._video.src=URL.createObjectURL(this._mediaBuffer.mediaSource),document.body.appendChild(this._video);let t=()=>{if(this._video?.src){c.warn(`[WebmBuilder] Video paused for participant [${this._participantId}], try to play again`);let r=this._video.seekable;r.length&&(this._video.currentTime=r.end(r.length-1)-.1),this._video.play().catch(()=>{})}};this._video.onpause=t,this._video.onwaiting=t,this._video.onstalled=t,this._video.onerror=()=>c.warn(`[WebmBuilder] Video Error for participant [${this._participantId}]`,this._video?.error),this._stream=this._video.captureStream(),this._onStream(this._stream)}_processFrame(e){let t=e.isVP9?"vp9":"vp8";this._mediaBuffer?this._mediaBuffer.codec!==t&&this._mediaBuffer.changeType(t):this._createVideo(t);let r=e.timestamp;if(r<=this._lastFrameTimestamp&&(r=this._lastFrameTimestamp+10,c.debug(`[WebmBuilder] Fixup timestamp for participant [${this._participantId}]`)),this._lastFrameTimestamp=r,this._earliestTimestamp)r-=this._earliestTimestamp;else{if(!e.keyframe)return;this._earliestTimestamp=r,r=0}if(e.keyframe){this._clusterStartTime=r,this._mediaBuffer?.cleanup(),c.debug(`[WebmBuilder] Segment header for participant [${this._participantId}]`);let o=a._genWebmHeader();this._mediaBuffer?.append(o);let d=a._genSegmentHeader(e.width,e.height,t);this._mediaBuffer?.append(d)}let n=Math.round(r-this._clusterStartTime);if(n>Do&&(this._clusterStartTime=r,n=0),n===0){c.debug(`[WebmBuilder] Cluster header for participant [${this._participantId}]`);let o=a._genClusterHeader(this._clusterStartTime);this._mediaBuffer?.append(o)}let s=k.element(k.ID.SimpleBlock,[k.vintEncodedNumber(Cn),k.bytes(a._intToU16BE(n)),k.number((e.keyframe?1:0)<<7),k.bytes(e.frameData)]);this._mediaBuffer?.append(s,!0)}destroy(){super.destroy(),this._video&&(this._video.onpause=null,this._video.onwaiting=null,this._video.onstalled=null,this._video.onerror=null,this._video.pause(),this._video.src="",document.body.removeChild(this._video)),this._mediaBuffer&&(this._mediaBuffer.destroy(),this._mediaBuffer=null),this._stream&&(this._stream.getTracks().forEach(e=>e.stop()),this._stream=null),c.debug(`[WebmBuilder] destroyed for participant [${this._participantId}]`)}static isBrowserSupported(){return"captureStream"in window.HTMLVideoElement?.prototype&&window.MediaSource?.isTypeSupported('video/webm; codecs="vp8"')&&window.MediaSource?.isTypeSupported('video/webm; codecs="vp9"')}};var Ot=class{constructor(i,e,t,r,n){this._participantIdRegistry=null;this._streamBuilders={};this._onStream=()=>{};this._onEos=()=>{};c.debug("ScreenCaptureReceiver started"),this._datachannel=i,this._participantIdRegistry=e,this._onStream=t,this._onEos=r,this._onStat=n,this._datachannel.onmessage=s=>this._onDataChannelMessage(s.data)}_onDataChannelMessage(i){let e=Ma(i),t=this._participantIdRegistry?.getStreamDescription(e.ssrc)?.participantId;if(!t){c.warn(`Participant id for ssrc ${e.ssrc} not found in registry`);return}if(e.eos){this.close(t),this._onEos(t);return}let r=this._streamBuilders[t];if(!r){let n=s=>this._onStream(t,s);l.screenShareWebmBuilder&&kt.isBrowserSupported()?r=new kt(t,n,this._onStat):r=new ei(t,n,this._onStat),this._streamBuilders[t]=r}r.appendChunk(e)}close(i){let e=this._streamBuilders[i];e&&(e.destroy(),delete this._streamBuilders[i])}destroy(){this._datachannel.onbufferedamountlow=null,this._datachannel.onmessage=null,this._onStream=()=>{},Object.values(this._streamBuilders).forEach(i=>i.destroy()),this._streamBuilders={},this._participantIdRegistry=null,c.debug("ScreenCaptureReceiver destroyed")}static isBrowserSupported(){return(nt.isBrowserSupported()||wt.isBrowserSupported())&&(ei.isBrowserSupported()||kt.isBrowserSupported())}};var yn=class{constructor(i,e,t){this._next=t,t&&(t.prev=this),this._prev=e,e&&(e.next=this),this._data=i}get prev(){return this._prev}set prev(i){this._prev=i}get next(){return this._next}set next(i){this._next=i}get data(){return this._data}},Pi=class{constructor(){this._head=null;this._tail=null;this._length=0}get length(){return this._length}push(...i){for(let e of i)this._tail=new yn(e,this._tail,null),this._head||(this._head=this._tail),this._length++}merge(i){this._tail&&(this._tail.next=i._head),this._head||(this._head=i._head),this._tail=i._tail,this._length+=i._length,i.clear()}shift(){if(!this._length||!this._head)return null;let i=this._head;return this._head=i.next,this._head&&(i.next=null,this._head.prev=null),this._length--,this.length===1?this._tail=this._head:this.length||(this._head=this._tail=null),i.data}bisect(){if(this.length){let i=this.length>1?Math.floor(this.length/2):1;for(let e=0;e<i;e++)this.shift()}}head(){return this._head?.data||null}tail(){return this._tail?.data||null}clear(){this._head=null,this._tail=null,this._length=0}toString(){let i=[],e=this._head;for(;e!==null;)i.push(e.data),e=e.next;return i.length?JSON.stringify(i,(t,r)=>r instanceof Error?String(r):r):""}};var Pn=zt(require("@vkontakte/libvpx"));var xo=1e3,ti=class extends ze{constructor(e,t,r,n){super();this._video=null;this._imageCapture=null;this._canvas=null;this._canvasCtx=null;this._frameReadTimeout=0;this._lastFrame=null;this._sourceTrack=e,this._onFrame=t,this._useCongestionControl=r,this._maxBitrate=n,this._useImageCapture="ImageCapture"in window&&ImageCapture.prototype.grabFrame!==void 0&&"ImageBitmap"in window,(e.readyState!=="live"||!e.enabled||e.muted)&&(this._useImageCapture=!1)}_createDom(){this._canvas||(this._canvas=document.createElement("canvas"),this._canvas.style.pointerEvents="none",this._canvas.style.visibility="hidden",this._canvas.style.position="absolute",this._canvas.style.width="160px",this._canvas.style.height="90px",this._canvas.style.bottom="0",this._canvas.style.right="160px",this._canvas.style.zIndex="5000",this._canvasCtx=this._canvas.getContext("2d"),document.body.appendChild(this._canvas)),!this._video&&!this._useImageCapture&&(this._video=document.createElement("video"),this._video.controls=!1,this._video.autoplay=!1,this._video.preload="auto",this._video.muted=!0,this._video.style.pointerEvents="none",this._video.style.visibility="hidden",this._video.style.position="absolute",this._video.style.width="160px",this._video.style.height="90px",this._video.style.bottom="0",this._video.style.right="0",this._video.style.zIndex="5000",document.body.appendChild(this._video))}_removeDom(){try{this._canvas&&document.body.removeChild(this._canvas),this._video&&document.body.removeChild(this._video)}catch{}this._canvasCtx=null,this._canvas=null,this._video=null}async _createStream(e){if(!this._canvas)throw new Error("Canvas not found");if(!this._video&&!this._useImageCapture)throw new Error("Video element not found");return new Promise((t,r)=>{if(this._useImageCapture)this._imageCapture=new ImageCapture(e),t();else{let n=this._video;n.srcObject=new MediaStream([e]),n.onloadeddata=d=>t(),n.onerror=()=>r(new Error("Video element error"));let s=n.play(),o=()=>r(new Error("Autoplay is disabled"));s?s.catch(o):o()}})}_removeStream(){window.clearTimeout(this._frameReadTimeout),this._lastFrame?.close(),this._video&&(this._video.pause(),this._video.srcObject=null),this._imageCapture&&(this._imageCapture=null)}_drawFrameVideo(){if(!this._canvas||!this._canvasCtx||!this._video)throw new Error("Fatal error");this._video.paused&&this._video.play();let e=this._video.videoWidth,t=this._video.videoHeight;return this._canvas.width=this._video.width=e,this._canvas.height=this._video.height=t,this._canvasCtx.clearRect(0,0,e,t),this._canvasCtx.drawImage(this._video,0,0,e,t),this._canvasCtx.getImageData(0,0,e,t)}async _getFrameBitmap(){if(!this._imageCapture)throw new Error("Destroyed");return this._imageCapture.grabFrame()}_drawFrameData(e){if(!this._canvas||!this._canvasCtx)throw new Error("Destroyed");let t=e.width,r=e.height;return this._canvas.width=t,this._canvas.height=r,this._canvasCtx.clearRect(0,0,t,r),this._canvasCtx.drawImage(e,0,0,t,r),this._canvasCtx?.getImageData(0,0,t,r)}async init(){this._createDom();let e=this._sourceTrack.getSettings().width,t=this._sourceTrack.getSettings().height;c.debug(`LibVPxEncoder started ${e}x${t}, codec ${this.isVP9()?"VP9":"VP8"}`),await this._createStream(this._sourceTrack),await this._createWorker(`"use strict";var exports=(()=>{var u=Object.defineProperty;var R=Object.getOwnPropertyDescriptor;var y=Object.getOwnPropertyNames;var x=Object.prototype.hasOwnProperty;var V=(a,r)=>{for(var s in r)u(a,s,{get:r[s],enumerable:!0})},h=(a,r,s,i)=>{if(r&&typeof r=="object"||typeof r=="function")for(let e of y(r))!x.call(a,e)&&e!==s&&u(a,e,{get:()=>r[e],enumerable:!(i=R(r,e))||i.enumerable});return a};var A=a=>h(u({},"__esModule",{value:!0}),a);var M={};V(M,{default:()=>F});var F=(a,r,s,i)=>{let e;function m(t,o){return a({locateFile:r}).then(n=>{if(e=new n.VpxEncoder,e.debug(o),!e.init(t?n.VpxType.VP9:n.VpxType.VP8))throw self.postMessage({type:"log_error",message:"encoder-init-fail-libvpx"}),new Error("LibVPxEncoder failed to create");if(s){let d=Math.round(i/1e3);e.setTargetBitrate(d)}else e.setMaxQuantizer(10),e.setTargetBitrate(1024)})}function E(t,o,n,p){let d=e.allocateImage(t,o);if(!d){self.postMessage({type:"frame",error:"No buffer data"});return}d.set(new Uint8Array(n));let l=Math.round(performance.now()),f=150;if(!e.encode(l,f,p)){self.postMessage({type:"frame",error:"Encode failed"});return}let b=e.readFrame();if(!b){self.postMessage({type:"frame",error:"No encoded data"});return}e.readFrame()&&(self.postMessage({type:"debug",message:"LibVPxEncoder dropped frame"}),self.postMessage({type:"log_error",message:"LibVPxEncoder-drop"}));let c=new Uint8Array(b.byteLength);c.set(b),self.postMessage({type:"frame",frameType:p?"key":"delta",timestamp:l,duration:f,width:t,height:o,data:c.buffer},[c.buffer])}function g(t,o){let n=Math.round(t/1e3);e.setTargetBitrate(n)}self.onmessage=t=>{switch(t.data.type){case"init":m(t.data.isVP9,t.data.debug).then(()=>self.postMessage({type:"ready"})).catch(o=>self.postMessage({type:"error",error:String(o)}));break;case"frame":E(t.data.width,t.data.height,t.data.imageData,t.data.keyFrame);break;case"set_bitrate":g(t.data.bitrate,t.data.useCbr);break}}};return A(M);})();
|
|
10
|
-
`,
|
|
11
|
-
`,r=>{r.error?this._onFrame(null,r.error):this._onFrame({type:r.frameType,timestamp:r.timestamp,duration:r.duration,data:r.data,byteLength:r.data?.byteLength,width:r.width,height:r.height})},[],{readable:t,width:i,height:e,isVP9:this.isVP9(),framerate:this._frameRate,useCongestionControl:this._useCongestionControl,maxBitrate:this._maxBitrate,useCbr:this._useCbr},[t])}requestFrame(i=!1){this._sendToWorker("frame",{keyFrame:i})}setBitrate(i,e,t){this._sendToWorker("set_bitrate",{bitrate:i,useCbr:e,fps:t})}isVP9(){return!0}destroy(){this._removeWorker(),c.debug("WebCodecsEncoder destroyed")}static isBrowserSupported(){return"VideoEncoder"in window&&"Worker"in window&&"EncodedVideoChunk"in window&&"MediaStreamTrackProcessor"in window}};var No=2100,Lo=600,Uo=1.2,ka=.8,Bo=2e3,Fo=8e3,wn=8e3,Vo=16e3,jo=4,Wo=2e3,nr=(t=>(t[t.NONE=0]="NONE",t[t.UP=1]="UP",t[t.DOWN=2]="DOWN",t))(nr||{}),wi=class{constructor(i,e,t,r,n,s,o){this._upPenalty=0;this._delayAvgShort=-1;this._delayAvgLong=-1;this._minDelay=Number.MAX_VALUE;this._maxDelay=0;this._largeDelayDuration=0;this._frames=0;this._fps=0;this._onCongestion=i,this._ccEnabled=r,this._minBitrate=e,this._maxBitrate=t,this._fastSharing=n,this._targetFps=o,s>0?this._highDelayThreshold=s:this._highDelayThreshold=No,n&&(this._highDelayThreshold=Lo),this._trendDelayThreshold=Math.round(this._highDelayThreshold/3),this._targetBitrate=this._maxBitrate,this._probing=!1;let d=Date.now();this._lastDown=0,this._lastUp=d,this._lastProbing=d,this._lastCheckDelay=0,this._lastFpsCalcMs=0}checkDelay(i,e,t){let r=Date.now();if(this._calcFps(r),this._calcDelay(e,r),this._delayAvgShort<=0||this._delayAvgLong<=0||!this._ccEnabled)return;let n=0,s=this._delayAvgShort-this._delayAvgLong,o=Math.round(Math.abs(s)*100/this._delayAvgLong),d=s>40&&o>30&&this._delayAvgShort>this._trendDelayThreshold,p=this._delayAvgShort>this._highDelayThreshold;d||p?n=2:Math.abs(s)<40&&o<10&&!p&&(n=1);let u=Math.round(this._targetBitrate/1e3),h=t;i%20===0&&c.debug(`#${i}: cc: delay=${e} short=${this._delayAvgShort} long=${this._delayAvgLong} delta=${s} percent=${o} -> ${nr[n]} tr=${u} br=${t}`);let g=r-this._lastDown;if(n===2&&g>Bo){this._probing&&(this._upPenalty=Math.min(++this._upPenalty,jo),this._probing=!1);let Q=ka*h*1e3;if(Q>=this._targetBitrate&&(Q=this._targetBitrate*ka),Q=Math.max(Q,this._minBitrate),Q<this._targetBitrate){let ue=Math.round(Q/1e3),we=Math.round(this._upPenalty*wn/1e3);c.log(`#${i}: cc: delay=${e} short=${this._delayAvgShort} long=${this._delayAvgLong} delta=${s} percent=${o} -> ${nr[n]}`),c.log(`#${i}: cc: DOWN delay=${e} bitrate=${h} target=${u} -> newBitrate=${ue} penalty=${we}s`),this._setBitrate(Q,!0),this._targetBitrate=Q}this._lastDown=r}let b=r-this._lastUp,w=Fo+this._upPenalty*wn;if(n===1&&b>w&&g>w){let Q=Math.min(this._targetBitrate*Uo,this._maxBitrate);if(Q>this._targetBitrate){let ue=Math.round(Q/1e3),we=Math.round(this._targetBitrate/1e3),z=Math.round(this._upPenalty*wn/1e3);c.log(`#${i}: cc: delay=${e} short=${this._delayAvgShort} long=${this._delayAvgLong} delta=${s} percent=${o} -> ${nr[n]}`),c.log(`#${i}: cc: UP bitrate=${h} target=${we} -> newBitrate=${ue} penalty=${z}s`),this._setBitrate(Q,!1),this._targetBitrate=Q,this._probing=!0,this._lastProbing=r,this._lastUp=r}}let B=r-this._lastProbing;this._probing&&B>Vo&&(this._probing=!1);let W=r-this._lastDown;this._upPenalty>0&&W>3*w&&(c.log(`#${i}: cc: UP reset penalty: oldPenalty=${this._upPenalty}`),this._upPenalty=0)}_setBitrate(i,e){this._fastSharing&&(e=!0);let t=this._targetFps;this._fps>0&&(t=this._fps),this._onCongestion(i,e,t)}_calcDelay(i,e){if(!(i<=0)){if(this._delayAvgShort===-1&&(this._delayAvgShort=i,this._delayAvgLong=i),this._delayAvgShort=Math.round((this._delayAvgShort*3+i)/4),this._delayAvgLong=Math.round((this._delayAvgLong*23+i)/24),i>0&&i<this._minDelay?this._minDelay=i:i>this._maxDelay&&(this._maxDelay=i),this._lastCheckDelay===0&&(this._lastCheckDelay=e),i>Wo){let t=e-this._lastCheckDelay;this._largeDelayDuration+=t}this._lastCheckDelay=e}}reconfigure(i,e){this._minBitrate=i,this._maxBitrate=e}getStat(){if(this._minDelay===Number.MAX_VALUE||this._maxDelay===0||this._delayAvgLong<=0)return null;let i={minDelay:this._minDelay,maxDelay:this._maxDelay,avgDelay:this._delayAvgLong,largeDelayDuration:this._largeDelayDuration};return this._minDelay=Number.MAX_VALUE,this._maxDelay=0,this._largeDelayDuration=0,i}_calcFps(i){this._frames++;let e=i-this._lastFpsCalcMs;if(e>5e3){this._lastFpsCalcMs=i;let t=this._fps,r=this._frames*1e3/e;this._fps===0?this._fps=Math.round(r):this._fps=Math.round((this._fps*3+r)/4),this._frames=0,this._fps!==t&&c.log(`cc: fps=${this._fps}`)}}};var Mi=class{constructor(i){this._size=0;this._head=0;this._tail=0;this._maxSize=i,this._buffer=new Array(i)}add(i,e,t,r,n){this._tail===this._head&&this._size>0&&(this._head=++this._head%this._maxSize);let s=this._tail;return this._buffer[this._tail]={seq:i,ts:e,size:t,sent:Date.now(),start:r,end:n,ts2:-1,recv:-1},this._tail=++this._tail%this._maxSize,this._size++,s}update(i,e){let t=this.get(i);return t===null?null:(t.ts2=e,t.recv=Date.now(),t)}get(i){let e=this._head;for(let t=0;t<this._maxSize;t++){let r=this._buffer[e];if(i===r?.seq)return r;if(e=++e%this._maxSize,e===this._tail)break}return null}getServerBitrateK(i){let e=0,t=0,r=-1,n=-1,s=this._tail;for(let o=0;o<this._maxSize;o++){s>0?--s:s=this._maxSize-1;let d=this._buffer[s];if(!d||(n===-1&&(n=d.ts2,t=0),n>=0&&(t+=d.size),r=d.ts2,n-r>=i)||s===this._head)break}if(r>=0&&n>=0){let o=n-r;e=Math.round(o>0?t*8/o:0)}return e}getCurrentDelay(){let i=this._tail;for(let e=0;e<this._maxSize;e++){i>0?--i:i=this._maxSize-1;let t=this._buffer[i];if(!t)break;if(t.recv>=0&&t.sent>=0)return t.recv-t.sent;if(i===this._head)break}return 0}getMaxBandwidth(){let i=0,e=0,t=-1,r=-1,n=this._tail;for(let s=0;s<this._maxSize;s++){n>0?--n:n=this._maxSize-1;let o=this._buffer[n];if(o){if(r===-1&&o.end&&!o.start&&(r=o.ts2,e=0),t===-1&&r>=0&&o.start&&!o.end&&(t=o.ts2),t>=0&&r>=0){let d=r-t;i=d>0?e*8/d:0;break}if(r>=0&&(e+=o.size),n===this._head)break}}return Math.round(i)}clear(){this._buffer.fill(void 0),this._size=0,this._head=0,this._tail=0}};var Mn=65536,Ho=50,Ko=400,qo=1e6,$o=3e5,zo=3e4,Jo=2e3,Yo=5,ar=0,Nt=class{constructor(i,e,t,r){this._destroyed=!1;this._needKeyframe=!0;this._frameNum=0;this._feedback=new Mi(1024);this._lastSentFrameSeq=0;this._lastDeliveredFrameSeq=0;this._lastFrameDelay=0;this._lastFramerateReduced=Date.now();this._lastSharingStat=Date.now();this._queue=new Pi;c.debug("ScreenCaptureSender started"),this.DATA_SIZE=l.consumerScreenDataChannelPacketSize-11,this._datachannel=e,this._signaling=t,this._fastSharing=r,this._congestionControlEnabled=l.screenShareCongestionControl||this._fastSharing,this._width=i.getSettings().width,this._height=i.getSettings().height,this._maxFrameDelay=this._fastSharing?l.screenShareCongestionControlThreshold:l.screenShareCongestionControlThreshold*2;let n=l.getScreenFrameRate(this._fastSharing),{minBitrate:s,maxBitrate:o}=this._calcMinMaxBitrate(this._width,this._height),d=this._onCongestionCallback.bind(this);c.log(`ScreenCaptureSender: CongestionControl: enabled=${this._congestionControlEnabled} minBitrate=${Math.round(s/1e3)}k maxBitrate=${Math.round(o/1e3)}k delayThreshold=${l.screenShareCongestionControlThreshold}`),this._congestionControl=new wi(d,s,o,this._congestionControlEnabled,this._fastSharing,l.screenShareCongestionControlThreshold,n);let p=(u,h)=>{if(this._destroyed)return;if(!u){c.warn("requestFrame failed, keyFrame: "+this._needKeyframe,h),this._needKeyframe=!0,this._handleQueue();return}(u.width!==this._width||u.height!==this._height)&&(this._width=u.width,this._height=u.height,this._onResize(this._width,this._height));let g=this._sliceFrame(u);this._queue.merge(g),this._handleQueue(),this._sendSharingStat()};if(xt.isBrowserSupported()){let u=this._fastSharing;this._encoder=new xt(i,p,this._congestionControlEnabled,o,u,n)}else this._encoder=new ti(i,p,this._congestionControlEnabled,o);this._datachannel.onmessage=u=>{Aa(u.data)&&(c.debug(`[${this._datachannel.label}] Requested keyframe`),this._needKeyframe=!0);let h=Da(u.data);h!==null&&this._checkCcFeedback(h)},this._encoder.init().then(()=>this._handleQueue()).catch(u=>c.warn("ScreenCaptureSender init failed",u)),this._fpsMeter=new Mt(u=>c.log(`[ScreenCaptureSender] fps: ${u}`),5e3)}_handleQueue(){if(this._destroyed)return;let i=this._queue.shift();if(!i){if((this._lastSentFrameSeq-this._lastDeliveredFrameSeq+Mn)%Mn>Yo&&this._lastFrameDelay>this._maxFrameDelay){let r=Date.now();r-this._lastFramerateReduced>Jo&&(this._lastFramerateReduced=r,c.debug(`[ScreenCaptureSender] reduce framerate: delay=${this._lastFrameDelay} maxDelay=${this._maxFrameDelay}`))}else this._requestFrame();return}if(!this._sendFrameChunk(i)){this._needKeyframe=this._needKeyframe||!this._cleanupQueue(),I.setImmediate(()=>this._handleQueue());return}if(i.isLast){this._frameNum++,this._fpsMeter.increment(),i.isKey&&c.debug(`#${this._frameNum}: sharing: send keyframe size=${Math.round(i.frameSize/1e3)}k`);let t=this._feedback.getCurrentDelay(),r=this._feedback.getServerBitrateK(2e3);t>0&&this._congestionControl.checkDelay(this._frameNum,t,r)}else I.setImmediate(()=>this._handleQueue())}_cleanupQueue(){let i=this._queue.head();for(;i;){if(i.isFirst&&i.isKey)return!0;this._queue.shift(),i=this._queue.head()}return!1}_requestFrame(){this._destroyed||(this._encoder.requestFrame(this._needKeyframe),this._needKeyframe=!1)}_sliceFrame(i){let e=i.type==="key",t=i.data.byteLength,r=new Pi;for(let n=0;n<t;n+=this.DATA_SIZE){let s=i.data.slice(n,n+this.DATA_SIZE),o=n===0,d=t<=n+s.byteLength,p=this._wrapHeader(i.timestamp,o,d,e,s);r.push({data:p.data,sequence:p.sequence,frameSize:t,isFirst:o,isLast:d,isKey:e,timestamp:i.timestamp})}return r}_wrapHeader(i,e,t,r,n){let s=wa(i,e,t,r,ar,this._encoder.isVP9(),n),o={sequence:ar,data:s};return ar=(ar+1)%Mn,o}_stopPacket(){return this._wrapHeader(Date.now(),!1,!1,!1,null).data}_sendFrameChunk(i){if(!this._datachannel||this._datachannel.readyState!=="open")return!1;try{return this._datachannel.send(i.data),this._feedback.add(i.sequence,i.timestamp,i.data.byteLength,i.isFirst,i.isLast),i.isLast&&(this._lastSentFrameSeq=i.sequence),!0}catch(e){return c.warn("Error sending chunk to DataChannel",e),!1}}destroy(){this._queue.clear(),this._fpsMeter.destroy(),this._datachannel.onmessage=null,this._feedback.clear(),this._datachannel.readyState==="open"&&this._datachannel.send(this._stopPacket()),this._destroyed=!0,this._encoder.destroy(),c.debug("ScreenCaptureSender destroyed")}static isBrowserSupported(){return xt.isBrowserSupported()||ti.isBrowserSupported()}_onCongestionCallback(i,e,t){this._encoder.setBitrate(i,e,t)}_onResize(i,e){let{minBitrate:t,maxBitrate:r}=this._calcMinMaxBitrate(i,e),n=Math.round(t/1e3),s=Math.round(r/1e3);c.log(`cc: resize to ${i}x${e}, minBitrate=${n} maxBitrate=${s}`),this._congestionControl.reconfigure(t,r)}_calcMinMaxBitrate(i,e){(i===void 0||i<640)&&(i=640),(e===void 0||e<360)&&(e=360);let t=i*e/256,r=Math.max($o,Math.min(qo,Math.round(t*Ho))),n=Math.round(t*Ko);return{minBitrate:r,maxBitrate:n}}_checkCcFeedback(i){let e=this._feedback.update(i.seq,i.ts2);if(e===null)c.debug(`cc: update failed, seq=${i.seq}`);else if(e.end){this._lastDeliveredFrameSeq=e.seq;let t=e.recv-e.sent;t>0&&(this._lastFrameDelay=t),this._handleQueue()}}_sendSharingStat(){let i=Date.now();if(i-this._lastSharingStat>zo){let t=this._congestionControl.getStat();t!==null&&(c.debug(`cc: send stats: ${JSON.stringify(t)}`),this._signaling.reportSharingStat(t)),this._lastSharingStat=i}}};var be=class a{static get sessionKey(){return a._sessionKey}static set sessionKey(i){a._sessionKey=i}static get sessionSecretKey(){return a._sessionSecretKey}static set sessionSecretKey(i){a._sessionSecretKey=i}static get accessToken(){return a._accessToken}static set accessToken(i){a._accessToken=i}static isEmpty(){return!a._sessionKey}};var f=class f{static set(i){i.hasOwnProperty("voiceParams")&&(Object.assign(f._params.voiceParams,i.voiceParams),delete i.voiceParams),i.hasOwnProperty("specListenerParams")&&(Object.assign(f._params.specListenerParams,i.specListenerParams),delete i.specListenerParams),i.hasOwnProperty("apiAuth")&&(be.accessToken=i.apiAuth.accessToken,be.sessionKey=i.apiAuth.sessionKey,be.sessionSecretKey=i.apiAuth.sessionSecretKey),Object.assign(f._params,I.objectFilterOutValues(i,void 0))}static get(i){return f._params[i]}static get appName(){return"ok.calls.sdk.js"}static get appVersion(){return 1.1}static get sdkVersion(){return"2.8.6-dev.8abbf3b2.0"}static get debug(){return f._params.debug}static get protocolVersion(){return f._params.joinFromMultipleDevices?6:5}static get platform(){return f._params.platform}static set platform(i){f._params.platform=i}static get clientStatsPlatform(){return f._params.clientStatsPlatform}static set clientStatsPlatform(i){f._params.clientStatsPlatform=i}static get clientType(){return f._params.clientType}static set clientType(i){f._params.clientType=i}static get externalUserType(){return f._params.externalUserType}static set externalUserType(i){f._params.externalUserType=i}static get device(){return f._params.device}static get apiKey(){return f._params.apiKey}static get apiEnv(){return f._params.apiEnv}static get apiBaseUrl(){return f._params.apiBaseUrl}static set apiBaseUrl(i){f._params.apiBaseUrl=i}static apiEndpoint(i){switch(i??f.apiEnv){case"AUTO":case"PROD":return"https://api.mycdn.me";case"CALLS":return"https://calls.okcdn.ru";case"PROD_OK":return"https://api.ok.ru";case"TEST":return"https://apitest.ok.ru/api";case"VIDEOTEST":return"https://videotestapi.ok.ru/api";case"CALLSTEST":return"https://calls-test.okcdn.ru/api";default:return f._params.apiEnv}}static get authToken(){return f._params.authToken}static set authToken(i){f._params.authToken=i}static get anonymToken(){return f._params.anonymToken}static set anonymToken(i){f._params.anonymToken=i}static get domain(){return f._params.domain}static get externalDomain(){return f._params.externalDomain}static get iceServers(){return f._params.iceServers}static set iceServers(i){f._params.iceServers=i}static get wssBase(){return f._params.wssBase}static set wssBase(i){f._params.wssBase=i}static get wtsBase(){return f._params.wtsBase}static set wtsBase(i){f._params.wtsBase=i}static get wssToken(){return f._params.wssToken}static set wssToken(i){f._params.wssToken=i}static get signalingReconnectDelay(){return f._params.signalingReconnectDelay}static get signalingReconnectMaxDelay(){return f._params.signalingReconnectMaxDelay}static get signalingReconnectMaxCount(){return f._params.signalingReconnectMaxCount}static get waitConnectionDelay(){return f._params.waitConnectionDelay}static get waitResponseDelay(){return f._params.waitResponseDelay}static get waitMessageDelay(){return f._params.waitMessageDelay}static get waitAnotherTabDelay(){return f._params.waitAnotherTabDelay}static get debugLog(){return f._params.debugLog}static get forceRelayPolicy(){return f._params.forceRelayPolicy}static set forceRelayPolicy(i){f._params.forceRelayPolicy=i}static get videoMinWidth(){return f._params.videoMinWidth}static get videoMaxWidth(){return f._params.videoMaxWidth}static set videoMaxWidth(i){f._params.videoMaxWidth=i}static get videoMinHeight(){return f._params.videoMinHeight}static get videoMaxHeight(){return f._params.videoMaxHeight}static set videoMaxHeight(i){f._params.videoMaxHeight=i}static get videoAspectRatio(){return f._params.videoAspectRatio}static get videoFrameRate(){return f._params.videoFrameRate}static get videoFacingMode(){return f._params.videoFacingMode||(P.isMobile()?"user":null)}static set videoFacingMode(i){f._params.videoFacingMode=i}static get displaySurface(){return f._params.displaySurface}static get audioEffects(){return f._params.audioEffects}static set audioEffects(i){f._params.audioEffects=i,f._params.audioEffects?.setLogger((e,...t)=>c.send(e,...t))}static get videoEffects(){return f._params.videoEffects}static set videoEffects(i){f._params.videoEffects=i,f._params.videoEffects?.setLogger((e,...t)=>c.send(e,...t))}static get videoEffectMaxWidth(){return f._params.videoEffectMaxWidth}static set videoEffectMaxWidth(i){f._params.videoEffectMaxWidth=i}static get videoEffectMaxHeight(){return f._params.videoEffectMaxHeight}static set videoEffectMaxHeight(i){f._params.videoEffectMaxHeight=i}static get vmoji(){return f._params.vmoji?.isBrowserSupported()?f._params.vmoji:null}static set vmoji(i){f._params.vmoji=i}static get vmojiOptions(){return f._params.vmojiOptions||{protocolVersion:1,renderingOptions:{}}}static set vmojiOptions(i){f._params.vmojiOptions=i}static get voiceParams(){return f._params.voiceParams}static get specListenerParams(){return f._params.specListenerParams}static get iceRestartWaitTime(){return f._params.iceRestartWaitTime}static get transportConnectionWaitTime(){return f._params.transportConnectionWaitTime}static get statisticsInterval(){return f._params.statisticsInterval}static set statisticsInterval(i){f._params.statisticsInterval=i}static get networkStatisticsInterval(){return f._params.networkStatisticsInterval}static get perfStatReportEnabled(){return f._params.perfStatReportEnabled}static get callStatReportEnabled(){return f._params.callStatReportEnabled}static get clientEventsLoggingEnabled(){return f._params.clientEventsLoggingEnabled}static get enableLogPerfStatReport(){return f._params.enableLogPerfStatReport}static get producerNotificationDataChannel(){return f._params.producerNotificationDataChannel}static get producerCommandDataChannel(){return f._params.producerCommandDataChannel}static get consumerScreenDataChannel(){return f._params.consumerScreenDataChannel&&Nt.isBrowserSupported()}static get producerScreenDataChannel(){return f._params.producerScreenDataChannel&&f.producerNotificationDataChannel&&Ot.isBrowserSupported()}static get asrDataChannel(){return f._params.asrDataChannel&&f.producerNotificationDataChannel}static get consumerScreenDataChannelPacketSize(){return f._params.consumerScreenDataChannelPacketSize}static get screenShareWebmBuilder(){return f._params.screenShareWebmBuilder}static get noiseSuppression(){return f._params.noiseSuppression}static set noiseSuppression(i){f._params.noiseSuppression=i}static get preferH264(){return f._params.preferH264}static get preferVP9(){return f._params.preferVP9}static get audioNack(){return f._params.audioNack}static get consumerScreenTrack(){return f._params.consumerScreenTrack&&f.consumerScreenDataChannel}static get producerScreenTrack(){return f._params.producerScreenTrack}static get movieShare(){return f._params.movieShare&&f.videoTracksCount>0}static get videoTracksCount(){return f.producerNotificationDataChannel?Number(f._params.videoTracksCount):0}static get breakVideoPayloadTypes(){return f._params.breakVideoPayloadTypes}static get useCallsToContacts(){return f._params.useCallsToContacts}static get useParticipantListChunk(){return f._params.useParticipantListChunk&&f.videoTracksCount>0}static get useRooms(){return f._params.useRooms}static get useChatRooms(){return f._params.useChatRooms}static get participantListChunkInitIndex(){return f._params.participantListChunkInitIndex??0}static get participantListChunkInitCount(){return f._params.participantListChunkInitCount??null}static get serverAudioRed(){return f._params.serverAudioRed}static get p2pAudioRed(){return f._params.p2pAudioRed}static get h264spsPpsIdrInKeyframe(){return f._params.h264spsPpsIdrInKeyframe}static get filterObservers(){return f._params.filterObservers}static get muteMode(){return f._params.muteMode}static get preserveAudioTracks(){return f._params.preserveAudioTracks}static get audioShare(){return P.isAudioShareSupported()&&f._params.audioShare}static get fastScreenShare(){return f._params.fastScreenShare}static get screenShareCongestionControl(){return f._params.screenShareCongestionControl}static get screenShareCongestionControlThreshold(){return f._params.screenShareCongestionControlThreshold}static get fastScreenShareWidth(){return f._params.fastScreenShareWidth}static get fastScreenShareHeight(){return f._params.fastScreenShareHeight}static get newMuteRules(){return f._params.newMuteRules}static get videoSuspend(){return f._params.videoSuspend}static get enumerateDevicesDelay(){return f._params.enumerateDevicesDelay}static getScreenFrameRate(i){return i?f._params.fastScreenShareFrameRate:f._params.screenFrameRate}static get switchVideoAtBadNetwork(){return f._params.switchVideoAtBadNetwork}static get enableVideoEffectsFpsDegradation(){return f._params.enableVideoEffectsFpsDegradation}static get removeTrackWarmup(){return f._params.removeTrackWarmup}static get simulcast(){return f._params.simulcast}static set simulcast(i){f._params.simulcast=i}static get webtransport(){return f._params.webtransport}static set webtransport(i){f._params.webtransport=i}static get webtransportFF(){return f._params.webtransportFF}static set webtransportFF(i){f._params.webtransportFF=i}static toJSON(){return{apiKey:f._params.apiKey,apiEnv:f._params.apiEnv,audioShare:f._params.audioShare,useCallsToContacts:f._params.useCallsToContacts,useParticipantListChunk:f._params.useParticipantListChunk,useRooms:f._params.useRooms,useChatRooms:f._params.useChatRooms,fastScreenShare:f._params.fastScreenShare,participantListChunkInitCount:f._params.participantListChunkInitCount,screenShareCongestionControl:f._params.screenShareCongestionControl,screenShareCongestionControlThreshold:f._params.screenShareCongestionControlThreshold,videoTracksCount:f._params.videoTracksCount,asrDataChannel:f._params.asrDataChannel,videoMaxHeight:f._params.videoMaxHeight,videoMaxWidth:f._params.videoMaxWidth,videoEffectMaxHeight:f._params.videoEffectMaxHeight,videoEffectMaxWidth:f._params.videoEffectMaxWidth,videoSuspend:f._params.videoSuspend,debugLog:f._params.debugLog,callStatReportEnabled:f._params.callStatReportEnabled,joinFromMultipleDevices:f._params.joinFromMultipleDevices,movieShare:f._params.movieShare,newMuteRules:f._params.newMuteRules,clientType:f._params.clientType,clientStatsPlatform:f._params.clientStatsPlatform,consumerScreenDataChannelPacketSize:f._params.consumerScreenDataChannelPacketSize,switchVideoAtBadNetwork:f._params.switchVideoAtBadNetwork,simulcast:f._params.simulcast,webtransport:f._params.webtransport,webtransportFF:f._params.webtransportFF}}};f._params={platform:"WEB",clientStatsPlatform:"",clientType:"PORTAL",externalUserType:"",device:"browser",apiKey:"",authToken:"",anonymToken:"",apiEnv:"AUTO",apiBaseUrl:null,domain:"",externalDomain:"",iceServers:[],wssBase:"",wtsBase:"",wssToken:"",signalingReconnectDelay:1e3,signalingReconnectMaxDelay:5e3,signalingReconnectMaxCount:10,waitConnectionDelay:1e4,waitResponseDelay:1e4,waitMessageDelay:15e3,waitAnotherTabDelay:200,debugLog:!1,debug:!1,forceRelayPolicy:!1,videoMinWidth:428,videoMinHeight:240,videoMaxWidth:1280,videoMaxHeight:720,videoAspectRatio:16/9,videoFrameRate:25,screenFrameRate:15,videoFacingMode:null,displaySurface:"monitor",audioEffects:null,videoEffects:null,videoEffectMaxWidth:640,videoEffectMaxHeight:360,vmoji:null,vmojiOptions:null,iceRestartWaitTime:2e4,transportConnectionWaitTime:5e3,statisticsInterval:5e3,networkStatisticsInterval:2e4,perfStatReportEnabled:!0,callStatReportEnabled:!1,clientEventsLoggingEnabled:!1,enableLogPerfStatReport:!1,voiceParams:{smoothing:.8,minFreq:200,maxFreq:5e3,interval:500,threshold:.35,speakerLevelMultiplier:1.8},specListenerParams:{connectionTimeout:1e4,volumeTimeout:1e4},producerNotificationDataChannel:!0,producerCommandDataChannel:!0,consumerScreenDataChannel:!0,producerScreenDataChannel:!0,asrDataChannel:!1,consumerScreenDataChannelPacketSize:64*1024,screenShareWebmBuilder:!1,noiseSuppression:!0,preferH264:!1,preferVP9:!1,audioNack:!0,consumerScreenTrack:!0,producerScreenTrack:!0,videoTracksCount:30,movieShare:!1,useCallsToContacts:!1,useParticipantListChunk:!1,useRooms:!1,useChatRooms:!1,participantListChunkInitIndex:0,participantListChunkInitCount:null,serverAudioRed:!0,p2pAudioRed:!0,h264spsPpsIdrInKeyframe:!0,breakVideoPayloadTypes:!1,joinFromMultipleDevices:!1,filterObservers:!1,muteMode:!1,preserveAudioTracks:!1,audioShare:!1,fastScreenShare:!1,screenShareCongestionControl:!1,screenShareCongestionControlThreshold:2100,fastScreenShareFrameRate:24,fastScreenShareWidth:1280,fastScreenShareHeight:720,newMuteRules:!1,videoSuspend:!1,enumerateDevicesDelay:2e3,switchVideoAtBadNetwork:!1,enableVideoEffectsFpsDegradation:!1,removeTrackWarmup:!1,simulcast:!1,webtransport:!1,webtransportFF:!1};var l=f;function Oa(a,i){return!(a.isAudioEnabled!==i.isAudioEnabled||a.isVideoEnabled!==i.isVideoEnabled||a.isScreenSharingEnabled!==i.isScreenSharingEnabled||a.isFastScreenSharingEnabled!==i.isFastScreenSharingEnabled||a.isAudioSharingEnabled!==i.isAudioSharingEnabled||a.isAnimojiEnabled!==i.isAnimojiEnabled)}function Ce(a){return Object.assign({isAudioEnabled:!1,isVideoEnabled:!1,isScreenSharingEnabled:!1,isFastScreenSharingEnabled:!1,isAudioSharingEnabled:!1,isAnimojiEnabled:!1},a||{})}var xa=a=>a.stop(),Ai=a=>a.getTracks().forEach(xa),Na=a=>a.getVideoTracks().forEach(xa);async function sr(a,i){try{let e=typeof i.width=="number"?i.width:void 0,t=typeof i.height=="number"?i.height:void 0;await a.applyConstraints({...i,...e&&{width:{max:e,ideal:e}},...t&&{height:{max:t,ideal:t}}})}catch(e){c.warn("setVideoConstraints failed",e)}}var or=class extends ne{constructor(){super(...arguments);this.FPS_LIMITS=[13,20,Math.max(l.videoFrameRate,25)];this.THRESHOLD=.8;this.HISTORY_LENGTH=10;this._fpsMeterUnsubscribe=null;this._fpsHistory={cursor:0,arr:[]};this._fpsLimitCursor=this.FPS_LIMITS.length-1}get fpsLimit(){return this.FPS_LIMITS[this._fpsLimitCursor]}watch(e){this._cleanup();try{e&&(this._assertsVideoEffect(e),this._fpsMeterUnsubscribe=e.addFpsMeterListener(this._handleFpsMeter.bind(this)))}catch(t){c.warn("VideoEffectsFpsLimiter error",t)}}_handleFpsMeter(e){if(this._fpsHistory.arr[this._fpsHistory.cursor]=e,this._fpsHistory.cursor=(this._fpsHistory.cursor+1)%this.HISTORY_LENGTH,this._fpsHistory.arr.length===this.HISTORY_LENGTH&&this._fpsLimitCursor){let t=this._fpsHistory.arr.reduce((n,s)=>n+s,0)/this.HISTORY_LENGTH,r=this.FPS_LIMITS[this._fpsLimitCursor];t<r*this.THRESHOLD&&(this._fpsLimitCursor=Math.max(0,this._fpsLimitCursor-1)),r!==this.fpsLimit&&this._triggerEvent("fps-limit",this.fpsLimit)}}_assertsVideoEffect(e){if(!("addFpsMeterListener"in e))throw new Error("Outdated VideoEffect version")}addEventListener(e,t){return super.addEventListener(e,t)}_cleanup(){this._fpsMeterUnsubscribe?.(),this._fpsMeterUnsubscribe=null}destroy(){this._cleanup(),super.unsubscribe()}};var Ge=(r=>(r.audio="audio",r.video="video",r.screen="screen",r.audioshare="audioshare",r))(Ge||{});var cr=class extends ne{constructor(){super();this._stream=null;this._screenTrack=null;this._audioShareTrack=null;this._sendVideoTrack=null;this._cameraVideoTrack=null;this._micAudioTrack=null;this._audioEffectsTrack=null;this._mediaSettings=Ce();this._videoStatusOnScreenCapturingEnabled=!1;this._effect=null;this._audioEffectParams=null;this._animojiEnabled=!1;this._initDeviceChangeListener(),l.audioShare&&(this._audioShareTrack=this.getSilentAudioShareTrack()),l.enableVideoEffectsFpsDegradation&&(this._videoEffectsFpsLimiter=new or,this._videoEffectsFpsLimiter.addEventListener("fps-limit",this.handleVideoEffectsLowFps.bind(this)))}async request(e=[se.AUDIO],t=!0){if(this._stream)return;let r=e.includes(se.VIDEO),n=e.includes(se.AUDIO),s=e.includes(se.ANIMOJI);if(!P.isBrowserSupported())throw new G(re.UNSUPPORTED);try{this._stream=await P.getUserMedia(r,n,t),this._cameraVideoTrack?.stop(),this._cameraVideoTrack=this._stream.getVideoTracks()[0],this._micAudioTrack?.stop(),this._micAudioTrack=this._stream.getAudioTracks()[0],this._audioEffectsTrack?.stop(),this._mediaSettings.isVideoEnabled=r&&this._stream.getVideoTracks().filter(o=>o.enabled).length>0||!1,this._mediaSettings.isAudioEnabled=n&&this._stream.getAudioTracks().filter(o=>o.enabled).length>0||!1,this._mediaSettings.isAnimojiEnabled=s&&!this._mediaSettings.isVideoEnabled||!1,this._animojiEnabled=s,this._triggerEvent("SOURCE_READY")}catch(o){throw new G(o)}}getStream(){return this._stream}getScreenTrack(){return this._screenTrack}getSendVideoTrack(e=!1){return this._sendVideoTrack&&!e?this._sendVideoTrack:this._stream?this._stream.getVideoTracks()[0]:null}getSendAudioTrack(){return this._stream?.getAudioTracks().find(t=>!t.contentHint)||null}get isAnimojiRequested(){return this._animojiEnabled&&!this._mediaSettings.isVideoEnabled}addTrackToPeerConnection(e,t,r){let n=this.getStream(),s=this.getSendAudioTrack(),o=this.getSendVideoTrack(r);if(!n||!s&&!o&&!t)throw new Error("No local stream found");s&&!t&&e.addTrack(s,n),o&&!t&&e.addTrack(o,n)}getMediaSettings(){return this._mediaSettings}async changeDevice(e){switch(e){case"videoinput":if(this._mediaSettings.isVideoEnabled)return this._changeVideoInput();break;case"audioinput":if(this._mediaSettings.isAudioEnabled)return this._changeAudioInput();break;default:return Promise.reject(re.UNKNOWN)}}stopVideoTrack(){this._mediaSettings.isVideoEnabled&&(this._stopEffect(),this._stream&&Na(this._stream),this._cameraVideoTrack?.stop())}async setVideoStream(e,t){return t?this._changeScreen(!1,!1,e):this._changeVideoInput(e)}_initDeviceChangeListener(){!navigator.mediaDevices||!navigator.mediaDevices.enumerateDevices||!navigator.mediaDevices.addEventListener||(this._onDeviceChange=async e=>{if(!this._stream)return;let t=P.getSavedMicrophone(),r=P.getSavedCamera(),n=this._mediaSettings.isAudioEnabled&&t?.groupId!==e.microphone?.groupId,s=this._mediaSettings.isVideoEnabled&&r?.groupId!==e.camera?.groupId;try{n&&await this._changeAudioInput(),s&&await this._changeVideoInput()}catch{}},P.addEventListener("devicechange",this._onDeviceChange))}_destroyDeviceChangeListener(){this._onDeviceChange&&P.removeEventListener("devicechange",this._onDeviceChange)}async _changeVideoInput(e){try{let t=e?"stream":"video",r=e||await P._getUserVideo(!!this._effect,this._frameRate);if(this._cameraVideoTrack?.stop(),this._cameraVideoTrack=r.getVideoTracks()[0],!this._stream)Ai(r);else{l.consumerScreenTrack||await this._disableScreenCapture();let n=await this._setEffect(this._effect,this._cameraVideoTrack);R.log(T.DEVICE_CHANGED,t),c.log("Video stream changed"),await this._replaceLocalTrack(n),this._mediaSettings.isVideoEnabled=!0,this._triggerEvent("SOURCE_CHANGED",{kind:"video"})}}catch(t){throw R.log(T.ERROR,"change_video"),c.warn("Camera change failed",t),t}}async setAudioStream(e){return this._changeAudioInput(e)}async _changeAudioInput(e=null){try{let t=e||await P.getUserAudio();if(this._micAudioTrack?.stop(),this._micAudioTrack=t.getAudioTracks()[0],!this._stream)Ai(t);else{let r=await this._applyAudioEffect();R.log(T.DEVICE_CHANGED,"audio"),c.log("Audio stream changed",r),await this._replaceLocalTrack(r),this._mediaSettings.isAudioEnabled=!0,this._triggerEvent("SOURCE_CHANGED",{kind:"audio"})}}catch(t){throw R.log(T.ERROR,"change_audio"),c.error("Microphone change failed",t),t}}async _changeScreen(e,t,r){try{if(r=r||await P.getScreenMedia(e,t),!this._stream)Ai(r);else{let n=r.getVideoTracks()[0];if(n.addEventListener("ended",()=>{this._mediaSettings.isScreenSharingEnabled&&this.disableScreenCapturing()},!1),l.consumerScreenTrack||this._stopEffect(),R.log(T.DEVICE_CHANGED,"screen"),c.log("Screen capturing started"),this._screenTrack=n,this._mediaSettings.isScreenSharingEnabled=!0,this._mediaSettings.isFastScreenSharingEnabled=e,l.consumerScreenTrack||(this._videoStatusOnScreenCapturingEnabled=this._mediaSettings.isVideoEnabled,this._mediaSettings.isVideoEnabled=!0,this._sendVideoTrack=l.consumerScreenDataChannel?P.getBlackMediaTrack(l.videoMinWidth,l.videoMinHeight):n,await this._replaceLocalTrack(n,this._sendVideoTrack)),r.getAudioTracks().length>0){let s=r.getAudioTracks()[0];s.contentHint="music",this._audioShareTrack=s,await this._replaceLocalTrack(s),this._mediaSettings.isAudioSharingEnabled=!0}t&&!this._mediaSettings.isAudioSharingEnabled&&c.debug("Audio share requested but not captured"),this._triggerEvent("SCREEN_STATUS",{track:n}),this._triggerEvent("SOURCE_CHANGED",{kind:"screen"})}}catch(n){throw R.log(T.ERROR,"screen"),c.warn("Screen capturing failed",n),n}}async _disableScreenCapture(){this._sendVideoTrack&&(this._sendVideoTrack.stop(),this._sendVideoTrack=null),this._screenTrack&&(this._screenTrack.stop(),this._screenTrack=null),await this.stopAudioShareTrack(),this._mediaSettings.isScreenSharingEnabled&&(this._mediaSettings.isScreenSharingEnabled=!1,this._mediaSettings.isFastScreenSharingEnabled=!1,this._triggerEvent("SCREEN_STATUS",{track:null}),this._triggerEvent("SOURCE_CHANGED",{kind:"screen"}))}async disableAudioShare(){await this.stopAudioShareTrack(),this._triggerEvent("SCREEN_STATUS",{track:null}),this._triggerEvent("SOURCE_CHANGED",{kind:"audioshare"})}async stopAudioShareTrack(){if(this._audioShareTrack){this._audioShareTrack.stop();let e=this.getSilentAudioShareTrack();await this._replaceLocalTrack(e),this._mediaSettings.isAudioSharingEnabled=!1}}async _applyAudioEffect(){if(!l.audioEffects||!this._audioEffectParams)return l.audioEffects?.pause(),this._micAudioTrack;l.audioEffects.isInitialized||await l.audioEffects.init(),l.audioEffects.resume(),l.audioEffects.setEffects(this._audioEffectParams.effects,this._audioEffectParams.isPreset),l.audioEffects.setSource(this._micAudioTrack);let e=l.audioEffects.outputStream.getAudioTracks()[0];return(!this._audioEffectsTrack||this._audioEffectsTrack.id!==e.id)&&(this._audioEffectsTrack=e),this._audioEffectsTrack}getSilentAudioShareTrack(){let e=P.getSilentMediaTrack();return e.contentHint="music",e.stop(),e}async _replaceLocalTrack(e,t){if(!this._stream)return;let r=this._stream.getTracks().find(n=>n.kind===e.kind&&n.contentHint===e.contentHint);r?.id!==e.id&&(r?(r!==this._audioEffectsTrack&&r.stop(),this._stream?.removeTrack(r),this._stream?.addTrack(e),this._triggerEvent("TRACK_REPLACED",e,t)):(this._stream.addTrack(e),this._triggerEvent("TRACK_REPLACED",e,t)))}async _setEffect(e,t){if(this._videoEffectsFpsLimiter?.watch(l.videoEffects),!l.videoEffects)return t;try{return l.videoEffects.setEffect(e,t)}catch(r){return c.warn("Video effect failed",r),t}}_stopEffect(){if(l.videoEffects)try{l.videoEffects.stopEffect()}catch(e){c.warn("Video effect failed",e)}}destroy(){this._destroyDeviceChangeListener(),l.videoEffects&&(this._effect=null,l.videoEffects.destroy()),l.audioEffects&&l.audioEffects.destroy(),this._stream&&(Ai(this._stream),this._stream=null),this._cameraVideoTrack?.stop(),this._micAudioTrack?.stop(),this._audioEffectsTrack?.stop(),this._disableScreenCapture(),P.getAudioContext()?.suspend().catch(t=>c.error(t)),this._videoEffectsFpsLimiter?.destroy()}async toggleScreenCapturing(e){if(e.captureScreen){await this._changeScreen(e.fastScreenSharing,e.captureAudio);return}return l.consumerScreenTrack?this._disableScreenCapture():(e.captureAudio||await this.disableAudioShare(),this._videoStatusOnScreenCapturingEnabled?this._changeVideoInput():this.toggleVideo(!1))}async disableScreenCapturing(){return this.toggleScreenCapturing({captureScreen:!1,fastScreenSharing:!1,captureAudio:!1})}async toggleVideo(e){if(!this._stream)return;l.consumerScreenTrack||await this._disableScreenCapture(),this._cameraVideoTrack?.stop();let t;if(e){let r=await P._getUserVideo(!!this._effect,this._frameRate);this._cameraVideoTrack=r.getVideoTracks()[0],t=await this._setEffect(this._effect,this._cameraVideoTrack)}else t=P.getBlackMediaTrack(l.videoMinWidth,l.videoMinHeight),this._stopEffect();if(this._mediaSettings.isVideoEnabled=e,await this._replaceLocalTrack(t),this._animojiEnabled){this._triggerEvent("ANIMOJI_STATUS",!e);return}this._triggerEvent("SOURCE_CHANGED",{kind:"video"})}async toggleAudio(e){if(!this._stream)return;this._micAudioTrack?.stop();let t=async(r,n)=>{await this._replaceLocalTrack(r),this._mediaSettings.isAudioEnabled=n,this._triggerEvent("SOURCE_CHANGED",{kind:"audio"})};if(e)try{let r=await P.getUserAudio();this._micAudioTrack=r.getAudioTracks()[0],t(await this._applyAudioEffect(),!0)}catch(r){throw l.audioEffects?.pause(),t(P.getSilentMediaTrack(),!1),typeof r=="string"?new Error(r):r}else l.audioEffects?.pause(),t(P.getSilentMediaTrack(),!1)}toggleAnimojiCapturing(e){this._animojiEnabled=e,this._mediaSettings.isVideoEnabled||this._triggerEvent("ANIMOJI_STATUS",e)}onAnimojiSender(e){this._mediaSettings.isAnimojiEnabled=e,this._triggerEvent("SOURCE_CHANGED",{kind:"video"})}async setResolution({video:e,effect:t}){if(!l.consumerScreenTrack&&this._mediaSettings.isScreenSharingEnabled||!this._mediaSettings.isVideoEnabled)return;if(!this._stream)throw new Error("Local stream not found");if(!this._cameraVideoTrack)throw new Error("Local video track not found");let r=this._effect&&t||e;await this._applyVideoConstraints(this._cameraVideoTrack,r)}getCameraVideoTrack(){return this._cameraVideoTrack}async updateNoiseSuppression(){if(!this._stream||!this._mediaSettings.isAudioEnabled)return;let e=this._stream.getAudioTracks().find(t=>!t.contentHint);if(!e)throw new Error("Local audio track not found");if(e.enabled)return e.applyConstraints({noiseSuppression:l.noiseSuppression})}async videoEffect(e){if(!l.videoEffects)throw new Error("Video Effects library is not set");if(!l.consumerScreenTrack&&this._mediaSettings.isScreenSharingEnabled)throw new Error("Can't apply effect to screensharing");if(R.log(T.DEVICE_CHANGED,`effect_${e?.effect||"none"}`),!this._mediaSettings.isVideoEnabled){this._effect=e;return}if(this._stream&&e!==this._effect&&this._cameraVideoTrack){let t=this._effect;this._effect=e;try{let r=this._cameraVideoTrack.clone(),n=new MediaStream([r]);await this._applyVideoConstraints(r),await this._changeVideoInput(n)}catch(r){this._effect=t;let n=this._cameraVideoTrack.clone(),s=new MediaStream([n]);throw await this._changeVideoInput(s),r}}}async audioEffect(e){if(!l.audioEffects)throw new Error("Audio Effects library is not set");if(!this._mediaSettings.isAudioEnabled){this._audioEffectParams=e;return}if(this._stream&&(!e&&this._audioEffectParams||e&&!this._audioEffectParams||!I.isArraysEquals(e?.effects||[],this._audioEffectParams?.effects||[]))&&this._micAudioTrack){let t=this._audioEffectParams;this._audioEffectParams=e;try{let r=this._micAudioTrack.clone(),n=new MediaStream([r]);await this._changeAudioInput(n)}catch(r){this._audioEffectParams=t;let n=this._micAudioTrack.clone(),s=new MediaStream([n]);throw await this._changeAudioInput(s),r}}}getAudioShareTrack(){return this._audioShareTrack}handleVideoEffectsLowFps(e){this._mediaSettings.isVideoEnabled&&this._cameraVideoTrack&&e<l.videoFrameRate&&this._applyVideoConstraints(this._cameraVideoTrack).catch(t=>{c.warn("MediaSource handleVideoEffectsLowFps error",t)})}get _frameRate(){let e=this._videoEffectsFpsLimiter?.fpsLimit??l.videoFrameRate;return this._effect?Math.min(e,l.videoFrameRate):void 0}async _applyVideoConstraints(e,t){await sr(e,{width:this._effect?l.videoEffectMaxWidth:l.videoMaxWidth,height:this._effect?l.videoEffectMaxHeight:l.videoMaxHeight,...this._frameRate&&{frameRate:{ideal:this._frameRate}},...t})}};var Di=class{static isSupported(){return P.browserName()!=="Firefox"&&"permissions"in navigator&&"PermissionStatus"in window}async init(i){try{let[e,t]=await Promise.all([navigator.permissions.query({name:"camera"}),navigator.permissions.query({name:"microphone"})]);this._cameraPermissionStatus=e,this._microphonePermissionStatus=t,this._listener=i,this._cameraPermissionStatus.onchange=r=>this.handlePermissionChange(r),this._microphonePermissionStatus.onchange=r=>this.handlePermissionChange(r)}catch(e){c.warn("NavigatorPermissions init error",e)}}handlePermissionChange(i){let e=i.target;if(e instanceof PermissionStatus){let{name:t,state:r}=e;switch(t){case"audio_capture":this._listener("microphone",r);break;case"video_capture":this._listener("camera",r);break}}}getPermissionState(i){let e=null;switch(i){case"camera":e=this._cameraPermissionStatus.state;break;case"microphone":e=this._microphonePermissionStatus.state;break}return e}};var dr=(d=>(d.WAITING_HALL="WAITING_HALL",d.WAITING="WAITING",d.CONNECTING="CONNECTING",d.CONNECTED="CONNECTED",d.RECONNECT="RECONNECT",d.ERROR="ERROR",d.HANGUP="HANGUP",d.PERMISSIONS="PERMISSIONS",d))(dr||{});function j(a,...i){let e=l.get(a);typeof e=="function"&&setTimeout(e,0,...i)}function pe(a,i,...e){if(l.filterObservers){if(Array.isArray(i)){if(i=i.filter(t=>!t.observer),!i.length)return}else if(i.observer)return}j(a,i,...e)}function Re(a){return Object.assign({},a)}function Lt(a){return a.slice()}var An;(_p=>{function a(S,M){j("onLocalStream",S,Re(M))}_p.onLocalStream=a;function i(S,M){j("onScreenStream",S,Re(M))}_p.onScreenStream=i;function e(S,M){j("onVmojiStream",S,Re(M))}_p.onVmojiStream=e;function t(S){j("onVmojiError",S)}_p.onVmojiError=t;function r(S,M){j("onLocalStreamUpdate",Re(S),M)}_p.onLocalStreamUpdate=r;function n(S){c.debug("Local status:",S),j("onLocalStatus",S)}_p.onLocalStatus=n;function s(S,M){pe("onRemoteStream",S,M)}_p.onRemoteStream=s;function o(S,M){pe("onRemoteLive",S,M)}_p.onRemoteLive=o;function d(S,M){pe("onLocalLive",S,M)}_p.onLocalLive=d;function p(S,M){pe("onRemoteLiveUpdate",S,M)}_p.onRemoteLiveUpdate=p;function u(S,M){pe("onLocalLiveUpdate",S,M)}_p.onLocalLiveUpdate=u;function h(S,M){pe("onRemoteScreenStream",S,M)}_p.onRemoteScreenStream=h;function g(S,M){pe("onRemoteVmojiStream",S,M)}_p.onRemoteVmojiStream=g;function b(S,M,K){pe("onRemoteStreamSuspended",S,M,K)}_p.onRemoteStreamSuspended=b;function w(S,M,K,Ve,yt){pe("onConversation",S,Re(M),Re(K),Ve,yt)}_p.onConversation=w;function B(S){S&&j("onConversationParticipantListChunk",S)}_p.onConversationParticipantListChunk=B;function W(S,M,K){pe("onRemoteMediaSettings",S,Re(M),K)}_p.onRemoteMediaSettings=W;function Q(S,M){pe("onLocalMediaSettings",S,Re(M))}_p.onLocalMediaSettings=Q;function ue(S,M,K){pe("onRemoteSharedMovieInfo",S,Re(M),K)}_p.onRemoteSharedMovieInfo=ue;function we(S,M,K){pe("onRemoteSharedMovieStoppedInfo",S,Re(M),K)}_p.onRemoteSharedMovieStoppedInfo=we;function z(S,M,K){pe("onLocalSharedMovieInfo",S,Re(M),K)}_p.onLocalSharedMovieInfo=z;function Ae(S,M,K){pe("onLocalSharedMovieStoppedInfo",S,Re(M),K)}_p.onLocalSharedMovieStoppedInfo=Ae;function Ee(S,M,K){pe("onRemoteSharedUrl",S,M,K)}_p.onRemoteSharedUrl=Ee;function Ct(S,M){pe("onParticipantAdded",S,M)}_p.onParticipantAdded=Ct;function Si(S,M){pe("onParticipantJoined",S,M)}_p.onParticipantJoined=Si;function Qi(S){j("onLocalParticipantState",Re(S))}_p.onLocalParticipantState=Qi;function ee(S,M,K){pe("onRemoteParticipantState",S,Re(M),K)}_p.onRemoteParticipantState=ee;function vi(S,M){j("onRemoteParticipantsState",S,M)}_p.onRemoteParticipantsState=vi;function ia(S,M,K=null){c.debug("Remote status:",M,S),pe("onRemoteStatus",S,M,K)}_p.onRemoteStatus=ia;function ra(){j("onPermissionsRequested")}_p.onPermissionsRequested=ra;function na(S,M){j("onPermissionsError",S,M)}_p.onPermissionsError=na;function aa(S,M){pe("onRemoteRemoved",S,M)}_p.onRemoteRemoved=aa;function sa(S,M,K){j("onCallState",S,M,Re(K))}_p.onCallState=sa;function Xi(S,M){j("onDeviceSwitched",S,M)}_p.onDeviceSwitched=Xi;function mn(S,M,K,Ve=!1,yt=!1,gn=null,_n=null,oo,ha,co=null){let lo=ha?Lt(ha):void 0;j("onMuteStates",Re(S),Lt(M),Lt(K),Ve,yt,gn,_n,oo,lo,co)}_p.onMuteStates=mn;function oa(S,M,K=!1){pe("onRolesChanged",S,Lt(M),K)}_p.onRolesChanged=oa;function ca(S,M=!1){j("onLocalRolesChanged",Lt(S),M)}_p.onLocalRolesChanged=ca;function da(S,M,K,Ve){pe("onPinnedParticipant",S,M,K,Ve)}_p.onPinnedParticipant=da;function fn(S,M){j("onLocalPin",S,M)}_p.onLocalPin=fn;function la(S){j("onOptionsChanged",Lt(S))}_p.onOptionsChanged=la;function pa(){j("onCallAccepted")}_p.onCallAccepted=pa;function he(S){pe("onAcceptedCall",S)}_p.onAcceptedCall=he;function V(){j("onRateNeeded")}_p.onRateNeeded=V;function te(S){pe("onSpeakerChanged",S)}_p.onSpeakerChanged=te;function ae(S){j("onVolumesDetected",Lt(S))}_p.onVolumesDetected=ae;function me(S,M){j("onLocalVolume",S,M)}_p.onLocalVolume=me;function lt(S,M){j("onJoinStatus",S,M)}_p.onJoinStatus=lt;function $e(S,M){j("onHangup",S,M)}_p.onHangup=$e;function m(S){j("onMultipartyChatCreated",Re(S))}_p.onMultipartyChatCreated=m;function C(){j("onDeviceChange")}_p.onDeviceChange=C;function y(S){j("onFingerprintChange",S)}_p.onFingerprintChange=y;function v(){j("onTokenExpired")}_p.onTokenExpired=v;function _(S,M,K=!1){j("onChatMessage",S,M,K)}_p.onChatMessage=_;function A(S,M,K=!1){j("onCustomData",S,M,K)}_p.onCustomData=A;function H(S,M,K,Ve,yt,gn,_n=null){j("onRecordStarted",S,M,K,Ve,yt,gn,_n)}_p.onRecordStarted=H;function F(S=null){j("onRecordStopped",S)}_p.onRecordStopped=F;function X(S){j("onLocalNetworkStatusChanged",S)}_p.onLocalNetworkStatusChanged=X;function _e(S){j("onNetworkStatusChanged",S)}_p.onNetworkStatusChanged=_e;function O(S,...M){j("onDebugMessage",S,...M)}_p.onDebugMessage=O;function ve(S,M){let K=Object.assign({},S,{memory:M});j("onStatistics",K)}_p.onStatistics=ve;function fe(){j("onAutoplayError")}_p.onAutoplayError=fe;function Ie(S,M,K,Ve,yt){j("onChatRoomUpdated",S,M,K,Ve,yt)}_p.onChatRoomUpdated=Ie;function de(S){j("onPromoted",S)}_p.onPromoted=de;function Le(S){j("onRemoteMixedAudioStream",S)}_p.onRemoteMixedAudioStream=Le;function Rt(S){j("onJoinLinkChanged",S)}_p.onJoinLinkChanged=Rt;function $t(S){j("onRoomsUpdated",S)}_p.onRoomsUpdated=$t;function rt(S,M,K,Ve){j("onRoomUpdated",S,M,K,Ve)}_p.onRoomUpdated=rt;function Ii(S){j("onRoomParticipantsUpdated",S)}_p.onRoomParticipantsUpdated=Ii;function ua(S){j("onRoomSwitched",S)}_p.onRoomSwitched=ua;function np(S){j("onRoomStart",S)}_p.onRoomStart=np;function ap(S,M=null){j("onFeedback",S,M)}_p.onFeedback=ap;function sp(S){j("onFeaturesPerRoleChanged",S)}_p.onFeaturesPerRoleChanged=sp;function op(S){j("onParticipantVmojiUpdate",S)}_p.onParticipantVmojiUpdate=op;function cp(S,M){j("onAsrSet",S,M)}_p.onAsrSet=cp;function dp(S,M,K){j("onAsrStarted",S,M,K)}_p.onAsrStarted=dp;function lp(S){j("onAsrStopped",S)}_p.onAsrStopped=lp;function pp(S,M,K,Ve){j("onAsrTranscription",S,M,K,Ve)}_p.onAsrTranscription=pp;function up(S,M){j("onParticipantIdChanged",S,M)}_p.onParticipantIdChanged=up;function hp(S){j("onVideoSuspendSuggest",S)}_p.onVideoSuspendSuggest=hp;function mp(S){j("onSignalingMessage",typeof S=="string"?S:Re(S))}_p.onSignalingMessage=mp;function fp(S){j("onPromotionApproved",S)}_p.onPromotionApproved=fp;function gp(){j("onPeerRegistered")}_p.onPeerRegistered=gp})(An||(An={}));var E=An;var kn="_okcls_",ii=(()=>{try{let a=Date.now().toString(),i=window.localStorage,e=!1;return i.setItem(a,a),e=i.getItem(a)===a,i.removeItem(a),e?i:null}catch{return null}})();function Qo(a){let i=ii?ii.getItem(kn+a):null;if(i===null)return null;try{return JSON.parse(i)}catch{return null}}function Xo(a,i){try{ii&&ii.setItem(kn+a,JSON.stringify(i))}catch{}}function Zo(a){ii&&ii.removeItem(kn+a)}var Dn;(t=>{function a(r){return Qo(r)||null}t.get=a;function i(r,n){Xo(r,n)}t.set=i;function e(r){Zo(r)}t.remove=e})(Dn||(Dn={}));var vt=Dn;var Ut=null,lr=null,gr=null,Sr=[],vr=[],_r=[],Qe=null,Xe=null,Ir=null,Er=!1,Tr=!1,pr,ri,ur,On=null,xn="",hr=[],mr=null,La=navigator.appVersion,ec=navigator.appName,je=navigator.userAgent,pt={},St=(e=>(e.USER="user",e.ENVIRONMENT="environment",e))(St||{});(i=>{function a(e){return Object.values(i).includes(e)}i.contains=a})(St||(St={}));var Ft=class{constructor(i,e=!1,t=l.videoMaxWidth,r=l.videoMaxHeight,n=l.videoFrameRate){this.isVideoRequested=()=>this.needVideo;this.supportedConstraints=navigator.mediaDevices.getSupportedConstraints();let s=!1;if(i){s={noiseSuppression:l.noiseSuppression,echoCancellation:!0,autoGainControl:!0};let d=ye.getMicrophones(),p,u;if(Xe&&(u=Xe.groupId,p=Xe.deviceId),typeof i=="string")u=d.find(g=>g.deviceId===i)?.groupId,p=i;else if(!Xe&&ye.os()==="MacOS"&&d.find(h=>h.label.includes("iPhone"))){let h=d.find(g=>!g.label.includes("Virtual")&&!g.label.includes("iPhone"));h&&(u=h.groupId,p=h.deviceId)}u&&this.supportedConstraints.groupId?s.groupId={exact:u}:p&&(s.deviceId={exact:p})}let o=!1;if(e){o={width:{min:l.videoMinWidth,max:t,ideal:t},height:{min:l.videoMinHeight,max:r,ideal:r},aspectRatio:{ideal:l.videoAspectRatio},frameRate:{ideal:n}};let d=ye.getCameras(),p,u;if(Qe&&(u=Qe.groupId,p=Qe.deviceId),typeof e=="string")u=d.find(g=>g.deviceId===e)?.groupId,p=e;else if(!Qe&&ye.os()==="MacOS"&&d.find(h=>h.label.includes("iPhone"))){let h=d.find(g=>!g.label.includes("Virtual")&&!g.label.includes("iPhone"));h&&(u=h.groupId,p=h.deviceId)}u&&this.supportedConstraints.groupId?o.groupId={exact:u}:p&&(o.deviceId={exact:p}),l.videoFacingMode&&(o.facingMode={ideal:l.videoFacingMode},delete o.deviceId,delete o.groupId)}this.audio=s,this.video=o,this.needVideo=!!o,this.lastSimplifyWasReached=!1}getNative(){return Object.assign({},{audio:this.audio,video:this.video})}simplify(){return typeof this.video=="object"&&(this.video.width||this.video.height?(delete this.video.width,delete this.video.height):this.video.aspectRatio?delete this.video.aspectRatio:this.video.frameRate?delete this.video.frameRate:(this.video.deviceId||this.video.groupId||this.video.facingMode)&&(delete this.video.deviceId,delete this.video.groupId,delete this.video.facingMode)),typeof this.audio=="object"&&(this.audio.echoCancellation||this.audio.autoGainControl||this.audio.noiseSuppression?(delete this.audio.echoCancellation,delete this.audio.autoGainControl,delete this.audio.noiseSuppression):(this.audio.deviceId||this.audio.groupId)&&(delete this.audio.deviceId,delete this.audio.groupId)),this.video===!0&&this.audio===!0?this.video=!1:this.video===!1&&this.audio===!0?(this.audio=!1,this.video=this.needVideo):this.video===!0&&this.audio===!1&&(this.video=!1),this.video&&!Object.keys(this.video).length&&(this.video=!0),this.audio&&!Object.keys(this.audio).length&&(this.audio=!0),!this.audio&&!this.video&&(this.lastSimplifyWasReached=!0,this.audio=!this.isVideoRequested(),this.video=this.isVideoRequested()),this}canSimplify(){let i=typeof this.video=="object"&&(this.video.width||this.video.height||this.video.aspectRatio||this.video.frameRate||this.video.facingMode||this.video.deviceId||this.video.groupId)||this.video;return!!(typeof this.audio=="object"&&(this.audio.deviceId||this.audio.groupId||this.audio.noiseSuppression||this.audio.echoCancellation||this.audio.autoGainControl)||this.audio||i)&&!this.lastSimplifyWasReached}isVideo(){return!!this.video}isAudio(){return!!this.audio}},Nn=class extends Ft{constructor(i,e,t,r){if(super(!1,!0),this.captureController="CaptureController"in window?new CaptureController:null,typeof this.video=="object"?(delete this.video.deviceId,delete this.video.groupId,delete this.video.aspectRatio,delete this.video.frameRate,delete this.video.facingMode):this.video={},this.video.cursor="motion",this.video.width=i,this.video.height=e,this.video.frameRate=t,this.video.displaySurface=l.displaySurface,ye.browserName()==="Safari"){let n=Number(ye.browserVersion());n===16?(this.video.width={max:i},this.video.height={max:e}):n===17&&(delete this.video.width,delete this.video.height)}r&&(this.audio={noiseSuppression:!1,echoCancellation:!1,autoGainControl:!1})}getNative(){return Object.assign(super.getNative(),{systemAudio:"exclude",controller:this.captureController})}},Bt=class Bt{constructor(){this._lockId=Math.round(Math.random()*99998)+1}busy(){if(Bt._lockId)throw R.log(T.ERROR,"change_device"),c.warn("Device change failed: MediaSource is busy"),new Error("MediaSource is busy");Bt._lockId=this._lockId}free(){Bt._lockId===this._lockId&&(Bt._lockId=0)}};Bt._lockId=0;var br=Bt;async function Ua(){Tr=!1,Er=!1,Ut=null;let a={camera:ye.getSavedCamera(),microphone:ye.getSavedMicrophone(),output:ye.getSavedOutput()};await Ln(),tc("devicechange",a),E.onDeviceChange()}function tc(a,...i){if(pt[a])for(let e of pt[a])e(...i)}async function Ln(){return Ut||(!navigator.mediaDevices||!navigator.mediaDevices.enumerateDevices?[]:(!lr&&navigator.mediaDevices.addEventListener&&(lr=I.debounce(Ua,l.enumerateDevicesDelay),navigator.mediaDevices.addEventListener("devicechange",lr)),!gr&&Di.isSupported()&&(gr=new Di,await gr.init((a,i)=>{switch(i){case"denied":case"prompt":lr?.();break}})),Ut=navigator.mediaDevices.enumerateDevices().then(a=>{Sr=a.filter(r=>r.kind==="videoinput"?(r.label&&(Er=!0),!0):!1),vr=a.filter(r=>r.kind==="audioinput"?(r.label?Tr=!0:ye.isMobile()&&ye.browserName()==="Firefox"&&(Tr=Er),!0):!1),_r=a.filter(r=>r.kind==="audiooutput");let i=Qe?.deviceId??vt.get("videoinput"),e=Xe?.deviceId??vt.get("audioinput"),t=Ir?.deviceId??vt.get("audiooutput");return Qe=Sr.find(r=>r.deviceId===i)||null,Xe=vr.find(r=>r.deviceId===e)||null,Ir=_r.find(r=>r.deviceId===t)||_r[0]||null,Ut=Promise.resolve(a),a}).catch(()=>(Ut=null,[]))))}function ic(a){if(Qe&&Xe)return;let i=(e,t)=>{let r=t.getSettings()?.deviceId;return e.find(n=>n.deviceId===r||n.label===t.label)||null};a?.getTracks().forEach(e=>{!Xe&&e.kind==="audio"?Xe=i(ye.getMicrophones(),e):!Qe&&e.kind==="video"&&(Qe=i(ye.getCameras(),e))})}async function ki(a,i){c.debug("Try to get media",JSON.parse(JSON.stringify(a.getNative())));let e=(!a.isVideo()||ye.hasCameraPermission())&&(!a.isAudio()||ye.hasMicrophonePermission());!e&&!i&&E.onPermissionsRequested();let t=new br;try{t.busy();let r=await navigator.mediaDevices.getUserMedia(a.getNative());return t.free(),e||await Ua(),ic(r),r}catch(r){switch(t.free(),c.error("getUserMedia error",r),r.name){case"PermissionDeniedError":case"PermissionDismissedError":case"NotAllowedError":case"SecurityError":case"DOMException":case"NotFoundError":i=a.isVideoRequested()?re.CAMERA_PERMISSION:re.MIC_PERMISSION;break;case"OverconstrainedError":i=re.OVERCONSTRAINED;break;case"TypeError":i=re.UNKNOWN;break;case"AbortError":case"NotReadableError":i=a.isVideoRequested()?re.CAMERA_ACCESS:re.MIC_ACCESS;break;case"Error":if(r.message==="MediaSource is busy"){i=a.isVideoRequested()?re.CAMERA_ACCESS:re.MIC_ACCESS;break}}if(a.canSimplify())return ki(a.simplify(),i);let n=i||re.UNKNOWN;throw E.onPermissionsError(n,r),n}}async function rc(a){c.debug("Try to get screen",JSON.parse(JSON.stringify(a.getNative())));let i=new br;try{i.busy();let e=await navigator.mediaDevices.getDisplayMedia(a.getNative()),t=e?.getVideoTracks()[0];if(t){let r=t.getSettings()?.displaySurface;if(c.debug(`Got display media track: ${t.id} (${r})`),t.contentHint="text",a.captureController&&(r==="browser"||r==="window"))try{a.captureController.setFocusBehavior("no-focus-change")}catch(n){c.warn("Failed to set focus behavior",n)}}return e}catch(e){switch(e.name){case"PermissionDeniedError":case"NotAllowedError":case"SecurityError":throw re.SCREEN_PERMISSION;default:throw re.SCREEN_ACCESS}}finally{i.free()}}function fr(){return hr.length||(hr=(()=>{let a,i=!1,e=0,t="0",r=je.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i)||[];if(/trident/i.test(r[1]))return a=/\brv[ :]+(\d+)/g.exec(je),["IE",a&&a[1]||"Unknown",i,e,t];if(r[1]==="Safari"){if(a=je.match(/\bEdge\/(\d+)/),a)return["Edge",a[1]||"Unknown",i,e,t];if(a=je.match(/\bCriOS\/(\d+)/),a)return["Chrome",a[1],!0,Number(a[1]),t];if(a=je.match(/\bFxiOS\/(\d+)/),a)return["Firefox",a[1],!1,e,t];if(a=je.match(/\bYaBrowser\/(\d+)/),a)return["Yandex",a[1],!1,e,t];if(a=je.match(/\bOPT\/(\d+)/),a)return["Opera",a[1],!1,e,t]}if(r[1]==="Chrome"){if(i=!0,e=Number(r[2]),a=je.match(/\bOPR\/(\d+)/),a)return["Opera",a[1]||"Unknown",i,e,t];if(a=je.match(/\bYaBrowser\/(\d+)/),a)return["Yandex",a[1]||"Unknown",i,e,t];if(a=je.match(/\bSferum\/((\d+)(?:\.\d+)*)/),a)return["Sferum",a[1]||"Unknown",i,e,t];if(a=je.match(/\bEdge?\/(\d+)/),a)return["Edge",a[1]||"Unknown",i,e,t];if(typeof window.opr<"u"&&/^(.+\.)?ok.ru$/.test(window.location.host))return["Opera","Hidden",i,e,t]}return a=je.match(/version\/(\d+)(?:(?:\.)(\d+))?/i),a&&a[2]!==void 0&&(t=a[2]),[r[2]?r[1]:ec,a&&a[1]||r[2]||La,i,e,t]})()),hr}var ye;(he=>{async function a(){if(!l.removeTrackWarmup){if(Ut)return;let V=()=>{he.getSilentMediaTrack(),document.removeEventListener("click",V),document.removeEventListener("touchstart",V)};document.addEventListener("click",V),document.addEventListener("touchstart",V)}await Ln()}he.init=a;function i(){return Sr}he.getCameras=i;function e(){return vr}he.getMicrophones=e;function t(){return _r}he.getOutput=t;function r(){return Sr.length>0}he.hasCamera=r;function n(){return vr.length>0}he.hasMicrophone=n;function s(){return Qe}he.getSavedCamera=s;function o(){return Xe}he.getSavedMicrophone=o;function d(){return Ir}he.getSavedOutput=d;function p(){return l.videoFacingMode}he.getVideoFacingMode=p;function u(){return Er}he.hasCameraPermission=u;function h(){return Tr}he.hasMicrophonePermission=h;function g(){return gr?.getPermissionState("microphone")??null}he.getMicrophonePermissionState=g;function b(V=!1){return h()?r()&&V?u():!0:!1}he.hasPermissions=b;async function w(V=!1,te=!0,ae=!0){let me=n()&&te,lt=r()&&V,$e;if(!me&&!lt)$e=new MediaStream;else try{$e=await ki(new Ft(me,lt))}catch{$e=new MediaStream}return!$e.getVideoTracks().length&&ae&&$e.addTrack(he.getBlackMediaTrack()),!$e.getAudioTracks().length&&ae&&$e.addTrack(he.getSilentMediaTrack()),$e}he.getUserMedia=w;async function B(V,te){let ae=V?l.fastScreenShareWidth:window.screen.width,me=V?l.fastScreenShareHeight:window.screen.height,lt=l.getScreenFrameRate(V);return rc(new Nn(ae,me,lt,te))}he.getScreenMedia=B;async function W(V=!1,te){let ae=V?l.videoEffectMaxWidth:l.videoMaxWidth,me=V?l.videoEffectMaxHeight:l.videoMaxHeight;return ki(new Ft(!1,!0,ae,me,te))}he._getUserVideo=W;async function Q(V,te){let ae=te?.width||l.videoMaxWidth,me=te?.height||l.videoMaxHeight;return ki(new Ft(!1,V||!0,ae,me))}he.getUserVideo=Q;async function ue(V){return ki(new Ft(V||!0,!1))}he.getUserAudio=ue;async function we(V,te){let[ae]=V.getVideoTracks();if(!ae)throw new Error("Video track not found in stream");return sr(ae,te)}he.setResolution=we;async function z(V,te){let me=(await Ln()).find(lt=>lt.kind===V&<.deviceId===te);return me?(V==="videoinput"?Qe=me:V==="audioinput"?Xe=me:V==="audiooutput"&&(Ir=me),vt.set(V,te),me):null}he._saveDeviceId=z;function Ae(){if(!ur||ur.readyState==="ended"){let V=he.getAudioContext(),te=V.createMediaStreamDestination(),ae=V.createGain();ae.gain.value=1e-5,ae.connect(te),ae.connect(V.destination);let me=V.createOscillator();me.type="sine",me.frequency.value=0,me.connect(ae),me.start(),ur=te.stream.getAudioTracks()[0]}return Object.assign(ur.clone(),{enabled:!1})}he.getSilentMediaTrack=Ae;function Ee(V=l.videoMinWidth,te=l.videoMinHeight){ri||(ri=document.createElement("canvas")),ri.width=V,ri.height=te;let ae=ri.getContext("2d");return ae.rect(0,0,V,te),ae.fillStyle="black",ae.fill(),(!pr||pr.readyState==="ended")&&(pr=ri.captureStream(l.videoFrameRate).getVideoTracks()[0]),Object.assign(pr.clone(),{enabled:!1})}he.getBlackMediaTrack=Ee;function Ct(){if(Xi()==="Edge"&&Number(mn())<70)return!1;try{let V=window;return"mediaDevices"in V.navigator&&"getUserMedia"in V.navigator.mediaDevices&&V.RTCPeerConnection&&V.RTCIceCandidate&&V.RTCSessionDescription&&V.HTMLCanvasElement&&V.HTMLCanvasElement.prototype.captureStream&&V.RTCRtpSender&&V.RTCRtpSender.prototype.replaceTrack&&V.RTCRtpSender.prototype.getParameters&&"sendBeacon"in navigator&&!0||!1}catch{return!1}}he.isBrowserSupported=Ct;function Si(){return!!navigator.mediaDevices.getDisplayMedia}he.isScreenCapturingSupported=Si;function Qi(){let V=he.browserName()==="Safari"&&he.browserVersion()==="15"&&he.browserSubVersion()==="1",te=he.browserName()==="Opera",ae=he.browserName()==="Yandex";return V||te||ae}he.isBrokenH264Decoder=Qi;function ee(){return he.browserName()==="Yandex"&&he.os()==="Windows"||l.simulcast}he.isBrokenVP9Encoder=ee;function vi(){return he.browserName()==="Safari"&&Number(he.browserVersion())===17&&[4,5,6].includes(Number(he.browserSubVersion()))}he.isBrokenVP9Decoder=vi;function ia(){return he.browserName()==="Firefox"&&Number(he.browserVersion())<60}he.isOldDataChannelDescription=ia;function ra(){return!(he.baseChromeVersion()&&he.isMobile())}he.canPreferH264=ra;function na(){return!(he.browserName()==="Firefox"||he.browserName()==="Safari")}he.isSimulcastSupportedByBrowser=na;function aa(){return xn||(xn=(()=>{let V={Windows:/Win/,Android:/Android/,OpenBSD:/OpenBSD/,SunOS:/SunOS/,Linux:/(Linux|X11)/,iPad:/(iPad)/,iPhone:/(iPhone)/,iPod:/(iPod)/,MacOS:/(MacPPC|MacIntel|Mac_PowerPC|Macintosh|Mac OS X)/,QNX:/QNX/,UNIX:/UNIX/,BeOS:/BeOS/,OS2:/OS\/2/,Bot:/(nuhk|Googlebot|Yammybot|Openbot|Slurp|MSNBot|Ask Jeeves\/Teoma|ia_archiver)/};for(let te in V)if(V.hasOwnProperty(te)&&V[te].test(je))return te;return"Unknown"})()),xn}he.os=aa;function sa(){return On===null&&(On=/Mobile|mini|Fennec|Android|iP(ad|od|hone)/.test(La)),On}he.isMobile=sa;function Xi(){return fr()[0]}he.browserName=Xi;function mn(){return fr()[1]}he.browserVersion=mn;function oa(){return fr()[3]}he.baseChromeVersion=oa;function ca(){return mr||(mr=new(window.AudioContext||window.webkitAudioContext)),mr.resume().catch(()=>{c.warn("Failed to resume AudioContext")}),mr}he.getAudioContext=ca;function da(){return fr()[4]}he.browserSubVersion=da;function fn(){return he.baseChromeVersion()>=105&&!he.isMobile()}he.isAudioShareSupported=fn;function la(V,te){pt[V]||(pt[V]=[]),pt[V].push(te)}he.addEventListener=la;function pa(V,te){if(pt[V])if(!te)delete pt[V];else{let ae=pt[V].indexOf(te);ae>-1&&pt[V].splice(ae,1)}}he.removeEventListener=pa})(ye||(ye={}));var P=ye;var He=class He{static get startTime(){return He._list[0]?.t||0}static get endTime(){let i=He._list;return i[i.length-1]?.t||0}static startSession(){He._list=[]}static get conversationId(){return He._conversationId}static set conversationId(i){He._conversationId=i}static add(i){He._list.push(i)}static _createContextLogs(){let i=[[`Calls SDK ${l.sdkVersion}`,l.toJSON()],["UserAgent:",navigator.userAgent],["Screen resolution:",`${window.screen.width}x${window.screen.height}`],["Permissions:",`Camera: ${P.hasCameraPermission()}, Mic: ${P.hasMicrophonePermission()}`]],e=new Date,t=e.getTime(),r=e.toLocaleString("ru-RU",{dateStyle:"short",timeStyle:"long"});return i.map(n=>({h:r,t,l:"LOG",d:n}))}static collectLogs(){let i=He._list;return i.length===0?[]:[...He._createContextLogs(),...i]}};He._list=[],He._conversationId=null;var Ue=He;var Cr=class{constructor(){this._items=[]}get length(){return this._items.length}push(...i){this._items.push(...i)}merge(i){this._items.push(...i._items)}shift(){return this._items.shift()||null}bisect(){let i=this.length>1?Math.floor(this.length/2):1;this._items=this._items.slice(i)}head(){return this._items[0]||null}tail(){let i=this._items.length;return i?this._items[i-1]:null}clear(){this._items=[]}toString(){return this._items.length?JSON.stringify(this._items,(i,e)=>e instanceof Error?String(e):e):""}};var Un=2*1024*1024,Ba=512*1024,ni=100*1024,nc=5,Fn="_okcls_logs_session_",ac=3e4,Vn=class{constructor(){this._items=[];this._itemsSize=0;this._storageSize=Un;try{let i=window.localStorage;for(let e of Object.keys(i)){if(e.indexOf(Fn)!==0)continue;let t=i.getItem(e);if(!t){Fa(e);continue}let r=ja(t);this.add(e,r)}}catch(i){console.error("Storage is blocked",i),this._storageSize=0}this._items.sort((i,e)=>i.date-e.date),this.cleanup(ni)}get size(){return this._itemsSize}get length(){return this._items.length}get available(){return Math.max(this._storageSize-this._itemsSize,0)}get items(){return this._items}set storageSize(i){this._storageSize=Math.min(i,this._storageSize,Un)}add(i,e){let t=parseInt(i.replace(Fn,""),10);this._itemsSize+=e,this._items.push({key:i,size:e,date:t})}deleteOldestItem(){let i=this._items.shift();i&&(Fa(i.key),this._itemsSize-=i.size)}cleanup(i){for(;this.length&&(this.size>Un||this.length>nc-1||this.size+i>this.available);)this.deleteOldestItem()}};function Va(){return`${Fn}${Date.now()}`}function ja(a){return new Blob([a]).size}function Fa(a){try{window.localStorage.removeItem(a)}catch(i){console.error("Failed to remove log from storage",i)}}function Rr(){let a=It.toString();if(!xe.available||!a)return;let i=ja(a);if(i>Ba){It.bisect(),Rr();return}xe.cleanup(ni+i);try{window.localStorage.setItem(yr,a)}catch(e){if(console.warn("Failed to write log to storage",e),xe.storageSize=xe.size+i,xe.cleanup(ni+i),xe.available>=ni+i){Rr();return}if(i>ni){It.bisect(),Rr();return}xe.storageSize=0;return}i>Ba&&(xe.add(yr,i),yr=Va(),It.clear(),xe.cleanup(ni))}function jn(){!xe.available||!It.length||Rr()}function sc(a=!1){let i=[];try{let r=window.localStorage;for(let s of xe.items){let o=r.getItem(s.key);i.push(o)}let n=It.toString();n&&i.push(n)}catch(r){console.error("Storage is blocked",r)}let e=`[${i.join(",")}]`;if(a)return e;let t=`logs_${Date.now()}.json`;return oc(e,t),t}function oc(a,i){let e=document.createElement("a"),t=new Blob([a],{type:"text/json"});e.href=URL.createObjectURL(t),e.download=i,e.click()}function Wa(a,i){if(!xe.available)return;let e=new Date,t={t:e.getTime(),l:a,d:i,h:e.toLocaleString("ru-RU",{dateStyle:"short",timeStyle:"long"})};It.push(t),Ue.add(t),Bn||(Bn=window.setTimeout(()=>{Bn=null,jn()},ac))}function Wn(){xe||(xe=new Vn,It=new Cr,yr=Va(),window.addEventListener("beforeunload",jn))}var xe,It,yr,Bn=null;window.__VKCallsSDKLogs__=(a=!1)=>(xe||Wn(),jn(),sc(a));var Hn=(r=>(r.DEBUG="DEBUG",r.LOG="LOG",r.WARN="WARN",r.ERROR="ERROR",r))(Hn||{}),Gn;(z=>{let a="📞",i=(Ae,...Ee)=>{E.onDebugMessage(Ae,...Ee)},e=!1,t=(Ae,Ee)=>(...Ct)=>{Ae(...Ct),Wa(Ee,Ct)},r=console.debug.bind(console,a),n=console.log.bind(console,a),s=console.warn.bind(console,a),o=console.error.bind(console,a),d=i.bind(null,"DEBUG"),p=i.bind(null,"LOG"),u=i.bind(null,"WARN"),h=i.bind(null,"ERROR");z.debug=d,z.log=p,z.warn=u,z.error=h;function W(){return e}z.enabled=W;function Q(Ae){e=Ae,l.debugLog&&Wn(),Ae?(z.debug=l.debugLog?t(r,"DEBUG"):r,z.log=l.debugLog?t(n,"LOG"):n,z.warn=l.debugLog?t(s,"WARN"):s,z.error=l.debugLog?t(o,"ERROR"):o):(z.debug=l.debugLog?t(d,"DEBUG"):d,z.log=l.debugLog?t(p,"LOG"):p,z.warn=l.debugLog?t(u,"WARN"):u,z.error=l.debugLog?t(h,"ERROR"):h)}z.toggle=Q;function ue(Ae,...Ee){switch(Ae){case"DEBUG":(0,z.debug)(...Ee);break;case"LOG":(0,z.log)(...Ee);break;case"WARN":(0,z.warn)(...Ee);break;case"ERROR":(0,z.error)(...Ee);break}}z.send=ue;function we(Ae,...Ee){}z.test=we})(Gn||(Gn={}));var c=Gn;var dc="kf";function ai(a){return a.stopStream}function Kn(a){return a.keyFrameRequested}function Ga(a){if(ai(a))return"ss";if(Kn(a))return dc;let i="";return a.priority!==void 0&&(i+="p="+a.priority),a.width!==void 0&&a.height!==void 0&&(i!==""&&(i+=":"),i+="sz="+Math.round(a.width)+"x"+Math.round(a.height)),a.fit!==void 0&&(i!==""&&(i+=":"),i+="fit="+a.fit),i}var si=(s=>(s.CAMERA="CAMERA",s.SCREEN="SCREEN",s.STREAM="STREAM",s.MOVIE="MOVIE",s.ANIMOJI="ANIMOJI",s.SHARED_URL="SHARED_URL",s))(si||{}),Ha="s",Ka="m";function at(a){return a.participantId+(a.mediaType?Jt+Ha+a.mediaType:"")+(a.streamName?Jt+Ka+a.streamName:"")}function Oi(a){let i=a.split(Jt),e=i.shift();if(!e)throw new Error("Illegal stream description: "+a);let t=null,r,n=0;for(let o of i)switch(o.charAt(0)){case Ha:t=lc(o.slice(1));break;case Ka:r=o.slice(1);break;case ir:n=Number.parseInt(o.slice(1),10);break;default:throw new Error("Unexpected parameter type "+o.charAt(0)+" in stream description "+a)}return{participantId:I.compose(e,n),mediaType:t,streamName:r}}function lc(a){for(let i of Object.keys(si))if(i===a)return si[i];return null}function st(){let a=new DataView(new ArrayBuffer(64)),i=0;function e(t){if(i+t>a.byteLength){let r=new Uint8Array(Math.max(i+t,a.byteLength+64));r.set(new Uint8Array(a.buffer.slice(0,i))),a=new DataView(r.buffer)}}return{put(t){if(e(t.byteLength),pc(t)){let r=t.buffer;new Uint8Array(a.buffer).set(new Uint8Array(r),i)}else new Uint8Array(a.buffer).set(new Uint8Array(t),i);i+=t.byteLength},putI8(t){e(1),a.setInt8(i,t),++i},putI16(t){e(2),a.setInt16(i,t),i+=2},putI32(t){e(4),a.setInt32(i,t),i+=4},putI64(t){e(8);let r=t<0;r&&(t=-t);let n=t/4294967296|0,s=t%4294967296|0;r&&(s=~s+1|0,n=s===0?~n+1|0:~n),a.setUint32(i,n),a.setUint32(i+4,s),i+=8},putUi8(t){e(1),a.setUint8(i,t),++i},putUi16(t){e(2),a.setUint16(i,t),i+=2},putUi32(t){e(4),a.setUint32(i,t),i+=4},putUi64(t){e(8),a.setUint32(i,t/4294967296|0),a.setUint32(i+4,t%4294967296),i+=8},putF(t){e(8),a.setFloat64(i,t),i+=8},ui8array(){return new Uint8Array(a.buffer.slice(0,i))}}}function pc(a){return a.buffer!==void 0}function Pr(a){let i=ArrayBuffer.isView(a)?new DataView(a.buffer,a.byteOffset,a.byteLength):new DataView(a),e=0;return{peek(){return i.getUint8(e)},get(t){e+=t;let r=i.byteOffset;return i.buffer.slice(r+e-t,r+e)},getI8(){return i.getInt8(e++)},getI16(){return e+=2,i.getInt16(e-2)},getI32(){return e+=4,i.getInt32(e-4)},getI64(){e+=8;let t=i.getInt32(e-8),r=i.getUint32(e-4);return t*4294967296+r},getUi8(){return i.getUint8(e++)},getUi16(){return e+=2,i.getUint16(e-2)},getUi32(){return e+=4,i.getUint32(e-4)},getUi64(){e+=8;let t=i.getUint32(e-8),r=i.getUint32(e-4);return t*4294967296+r},getF32(){return e+=4,i.getFloat32(e-4)},getF64(){return e+=8,i.getFloat64(e-8)}}}var qa=0,$a=1,uc=2,hc=3,mc=4,fc=5,gc=6,_c=7,Sc=0,vc=1,Ic=2,ut=0,Ec=0,Tc=0,bc=1,wr=class{constructor(){this.participantIdRegistry=null}setParticipantIdRegistry(i){this.participantIdRegistry=i}serializeUpdateDisplayLayout(i,e){let t=st();N.Int.enc(t,qa),N.Int.enc(t,ut),N.Int.enc(t,i),N.Nil.enc(t,null);let r=[];for(let n in e)e.hasOwnProperty(n)&&this.writeLayout(e,n,r);return N.Arr.enc(t,r),N.Nil.enc(t,null),t.ui8array()}writeLayout(i,e,t){let r=i[e],n=st();if(this.writeStreamDesc(e,n),ai(r))N.Int.enc(n,vc);else if(Kn(r))N.Int.enc(n,Ic);else if(N.Int.enc(n,Sc),r.priority!==void 0?N.Int.enc(n,r.priority):N.Nil.enc(n,null),r.width!==void 0&&r.height!==void 0?(N.Int.enc(n,Math.round(r.width)),N.Int.enc(n,Math.round(r.height))):(N.Nil.enc(n,null),N.Nil.enc(n,null)),r.fit!==void 0)switch(r.fit){case"cv":N.Int.enc(n,Tc);break;case"cn":N.Int.enc(n,bc);break;default:N.Nil.enc(n,null)}else N.Nil.enc(n,null);t.push(n.ui8array())}writeStreamDesc(i,e){if(this.participantIdRegistry){let t=this.participantIdRegistry.getCompactId(i);if(t!==void 0){N.Int.enc(e,t);return}}N.Str.enc(e,i)}serializePerfStatReport(i,e){let t=st();return N.Int.enc(t,$a),N.Int.enc(t,ut),N.Int.enc(t,i),N.Int.enc(t,e.framesDecoded),N.Int.enc(t,e.framesReceived),t.ui8array()}serializeSharingStatReport(i,e){let t=st();return N.Int.enc(t,uc),N.Int.enc(t,ut),N.Int.enc(t,i),N.Int.enc(t,e.minDelay),N.Int.enc(t,e.maxDelay),N.Int.enc(t,e.avgDelay),N.Int.enc(t,e.largeDelayDuration),t.ui8array()}serializeRequestAsr(i,e){let t=st();return N.Int.enc(t,hc),N.Int.enc(t,ut),N.Int.enc(t,i),N.Bool.enc(t,e.request),t.ui8array()}serializeNetworkStatReport(i,e){let t=st();return N.Int.enc(t,mc),N.Int.enc(t,ut),N.Int.enc(t,i),N.Int.enc(t,e.timestamp),N.Int.enc(t,e.sendBitrate),t.ui8array()}serializeEnableVideoSuspend(i,e){let t=st();return N.Int.enc(t,fc),N.Int.enc(t,ut),N.Int.enc(t,i),N.Bool.enc(t,e.enabled),t.ui8array()}serializeEnableVideoSuspendSuggest(i,e){let t=st();return N.Int.enc(t,gc),N.Int.enc(t,ut),N.Int.enc(t,i),N.Bool.enc(t,e.enabled),t.ui8array()}serializeChangeSimulcast(i,e){let t=st();N.Int.enc(t,_c),N.Int.enc(t,ut),N.Int.enc(t,i);let r=e.simulcastInfo.streams.length;N.Int.enc(t,e.mediaSource),N.Int.enc(t,r);for(let n of e.simulcastInfo.streams)N.Str.enc(t,n.rid),N.Int.enc(t,n.width),N.Int.enc(t,n.height),N.Int.enc(t,n.fps),N.Int.enc(t,n.bitrate/1e3);return t.ui8array()}async deserializeCommandResponse(i){let e;if(i instanceof Blob){let s="arrayBuffer"in Blob.prototype?await i.arrayBuffer():await Ra(i);e=Pr(s)}else e=Pr(i);let t=N.Int.dec(e),r=N.Int.dec(e);if(r!==ut){c.warn("Unsupported version for command type: "+t+", version "+r);return}if(N.Int.dec(e)!==Ec){c.warn("Error code: "+t+"received for command type: "+t+", version "+r);return}switch(t){case qa:return this.deserializeUpdateDisplayLayoutResponse(e);case $a:return this.deserializeReportPerfStatResponse(e);default:c.warn("unsupported command response commandType: "+t);return}}deserializeUpdateDisplayLayoutResponse(i){let e=N.Int.dec(i),t=N.Arr.dec(i),r={};return t.forEach(n=>{let s=Pr(n),o=N.Any.dec(s);if(typeof o=="string")r[o]=N.Int.dec(s);else{let d=o,p=at(this.participantIdRegistry?.getStreamDescription(d));r[p]=N.Int.dec(s)}}),{type:"response",sequence:e,response:x.UPDATE_DISPLAY_LAYOUT.toString(),errorCodeByParticipantId:r}}deserializeReportPerfStatResponse(i){let e=N.Int.dec(i),t=N.Int.dec(i);return{type:"response",sequence:e,response:x.REPORT_PERF_STAT.toString(),estimatedPerformanceIndex:t}}};var za=(r=>(r.START="start",r.ACCEPT="accept",r.JOIN="join",r.RETRY="retry",r))(za||{}),Ke=za;var Ja=(t=>(t.NOTIFICATION="NOTIFICATION",t.FAILED="FAILED",t.RECONNECT="RECONNECT",t))(Ja||{}),De=Ja;var Ya=(_=>(_.TRANSMITTED_DATA="transmitted-data",_.ACCEPTED_CALL="accepted-call",_.HUNGUP="hungup",_.PARTICIPANT_ADDED="participant-added",_.PARTICIPANT_JOINED="participant-joined",_.CLOSED_CONVERSATION="closed-conversation",_.MEDIA_SETTINGS_CHANGED="media-settings-changed",_.PARTICIPANT_STATE_CHANGED="participant-state-changed",_.PARTICIPANTS_STATE_CHANGED="participants-state-changed",_.RATE_CALL_DATA="rate-call-data",_.FEATURE_SET_CHANGED="feature-set-changed",_.TOPOLOGY_CHANGED="topology-changed",_.PRODUCER_UPDATED="producer-updated",_.CONSUMER_ANSWERED="consumer-answered",_.MULTIPARTY_CHAT_CREATED="multiparty-chat-created",_.FORCE_MEDIA_SETTINGS_CHANGE="force-media-settings-change",_.SETTINGS_UPDATE="settings-update",_.VIDEO_QUALITY_UPDATE="video-quality-update",_.REGISTERED_PEER="registered-peer",_.SWITCH_MICRO="switch-micro",_.RECORD_STARTED="record-started",_.RECORD_STOPPED="record-stopped",_.REALLOC_CON="realloc-con",_.AUDIO_ACTIVITY="audio-activity",_.SPEAKER_CHANGED="speaker-changed",_.STALLED_ACTIVITY="stalled-activity",_.CHAT_MESSAGE="chat-message",_.CUSTOM_DATA="custom-data",_.ROLES_CHANGED="roles-changed",_.MUTE_PARTICIPANT="mute-participant",_.PIN_PARTICIPANT="pin-participant",_.OPTIONS_CHANGED="options-changed",_.NETWORK_STATUS="network-status",_.PARTICIPANT_SOURCES_UPDATE="participant-sources-update",_.PROMOTE_PARTICIPANT="promote-participant",_.CHAT_ROOM_UPDATED="chat-room-updated",_.PROMOTION_APPROVED="promotion-approved",_.JOIN_LINK_CHANGED="join-link-changed",_.FEEDBACK="feedback",_.MOVIE_UPDATE_NOTIFICATION="movie-update-notification",_.MOVIE_SHARE_STARTED="movie-share-started",_.MOVIE_SHARE_STOPPED="movie-share-stopped",_.URL_SHARING_INFO_UPDATED="url-sharing-info-updated",_.ROOM_UPDATED="room-updated",_.ROOMS_UPDATED="rooms-updated",_.ROOM_PARTICIPANTS_UPDATED="room-participants-updated",_.FEATURES_PER_ROLE_CHANGED="features-per-role-changed",_.PARTICIPANT_ANIMOJI_CHANGED="participant-animoji-changed",_.ASR_STARTED="asr-started",_.ASR_STOPPED="asr-stopped",_.DECORATIVE_PARTICIPANT_ID_CHANGED="decorative-participant-id-changed",_.VIDEO_SUSPEND_SUGGEST="video-suspend-suggest",_))(Ya||{}),L=Ya;var Mr=class{constructor(i,e){if(!i)throw new Error("no URL supplied");let t=new URL(i);if(t.protocol!=="https:")throw new Error("URL is not supported for webtransport");let r=t.hostname,n=t.port;n===""&&(n="443");let{sessionint:s,client:o}=this.createClient({host:r,port:n,...e});this.ready=s.ready,this.closed=s.closed,this.draining=s.draining,this.datagrams=s.datagrams,this.incomingBidirectionalStreams=s.incomingBidirectionalStreams,this.incomingUnidirectionalStreams=s.incomingUnidirectionalStreams,this.sessionint=s,this.startUpConnection({client:o,sessionint:s,ourl:t})}createClient(i){throw new Error("Implement createClient")}startUpConnection({client:i,sessionint:e,ourl:t}){throw new Error("Implement startUpConnection")}get reliability(){let i=this.sessionint;if(!i)throw new Error("Http3WTSession was undefined");return i.reliability}get congestionControl(){let i=this.sessionint;if(!i)throw new Error("Http3WTSession was undefined");return i.congestionControl}get supportsReliableOnly(){throw new Error("Implement supportsReliableOnly")}getStats(){let i=this.sessionint;if(!i)throw new Error("Http3WTSession was undefined");return i.getStats()}close(i){let e=this.sessionint;if(!e)throw new Error("Http3WTSession was undefined");return e.close(i)}createBidirectionalStream(i){let e=this.sessionint;if(!e)throw new Error("Http3WTSession was undefined");return e.createBidirectionalStream(i)}createUnidirectionalStream(i){let e=this.sessionint;if(!e)throw new Error("Http3WTSession was undefined");return e.createUnidirectionalStream(i)}get protocol(){let i=this.sessionint;if(i)return i.protocol}};var oi=globalThis.ReadableStream,Ar=globalThis.WritableStream;var Or=zt(ts(),1);function ge(a){let i=!!(typeof process>"u"||process.env.DEBUG_TRACE);return Object.assign((0,Or.default)(a),{error:(0,Or.default)(`${a}:error`),trace:i?(0,Or.default)(`${a}:trace`):()=>{}})}var Se=class extends Error{constructor(i){super(i),this.name=this[Symbol.toStringTag]="WebTransportError"}};var is=!0;try{let a=new ReadableStream({start:i=>{},type:"bytes"})}catch{is=!1}var xr=is;var Lc=typeof process<"u"?process.pid:0,Ze=ge(`webtransport:http3wtstream(${Lc})`),Nr=class{constructor(i){if(this.objint=i.object,this.objint.jsobj=this,this.parentobj=i.parentobj,this.transport=i.transport,this.bidirectional=i.bidirectional,this.incoming=i.incoming,this.closed=!1,this._sendGroup=i.sendGroup,this._sendOrder=i.sendOrder,this.objint.sendInitialParameters&&this.objint.sendInitialParameters(),this.pendingoperation=null,this.pendingres=null,this.readable,this.writable,this.pendingoperationRead=null,this.pendingresRead=null,this.bidirectional||this.incoming){let e={start:t=>{this.readableController=t,this.objint.startReading()},pull:async t=>{if(this.readableclosed)return Promise.resolve();this.pendingoperationRead=new Promise((r,n)=>{this.pendingresRead=r}),this.objint.startReading(),await this.pendingoperationRead},cancel:t=>{let r=new Promise((s,o)=>{this.cancelres=s}),n=0;return t&&t.code&&(t.code<0?n=0:t.code>255?n=255:n=t.code),this.readableclosed=!0,this.objint.stopSending(n),r},type:"bytes",autoAllocateChunkSize:4096};xr||delete e.type,this.readable=new oi(e),this.readable.getStats=()=>Promise.resolve({timestamp:0,bytesReceived:0n,bytesRead:0n}),this.parentobj.addReceiveStream(this.readable,this.readableController)}(this.bidirectional||!this.incoming)&&(this.writable=new Ar({start:e=>{this.writableController=e},write:(e,t)=>{if(this.writableclosed)return Promise.resolve();let r=e;if(r instanceof ArrayBuffer&&(r=new Uint8Array(r)),r instanceof Uint8Array)return r.byteLength===0?void 0:(this.pendingoperation=new Promise((n,s)=>{this.pendingres=n}),this.objint.writeChunk(r),this.pendingoperation);throw Ze.trace("chunk info:",e),new Error("chunk is not of instanceof Uint8Array or Arraybuffer")},close:()=>this.writableclosed?Promise.resolve():(this.objint.streamFinal(),this.pendingoperation=new Promise((e,t)=>{this.pendingres=e}),this.pendingoperation),abort:e=>{if(this.writableclosed)return new Promise((n,s)=>{n()});let t=0;e&&e.code&&(e.code<0?t=0:e.code>255?t=255:t=e.code);let r=new Promise((n,s)=>{this.abortres=n});return this.objint.resetStream(t),r}},{highWaterMark:4}),this.writable.getStats=()=>Promise.resolve({timestamp:0,bytesWritten:0n,bytesSent:0n,bytesAcknowledged:0n}),Object.defineProperties(this.writable,{sendOrder:{get:()=>this._sendOrder,set:e=>{e!==this._sendOrder&&(this._sendOrder=i.sendOrder,this.updateSendOrderAndGroup())}},sendGroup:{get:()=>this._sendGroup,set:e=>{e!==this._sendGroup&&(this._sendGroup=e,this.updateSendOrderAndGroup())}}}),this.parentobj.addSendStream(this.writable,this.writableController)),this.cancelres=null,this.pendingres=null,this.abortres=null,this.finaldrain_=!1}getReadBuffer({byteSize:i}){let e=this.readableController.byobRequest;if(e){let t=e?.view;if(!(t instanceof Uint8Array))throw new Error("byob view is not a Uint8Array");return{buffer:t,byob:e,readBytes:0,fin:!1}}else return{buffer:new Uint8Array(i),byob:void 0,readBytes:0,fin:!1}}commitReadBuffer({buffer:i,byob:e,drained:t,readBytes:r,fin:n}){this.readableclosed||(e&&r!==void 0?e.respond(r):i&&this.readableController.enqueue(i));let s={};if(r!==void 0&&r>0&&!this.readableclosed&&(Ze.trace("commitReadbuffer",r),this.pendingoperationRead&&t)){this.readableController.desiredSize!=null&&!this.finaldrain_&&this.readableController.desiredSize<0&&(s.stopReading=!0);let o=this.pendingresRead;this.pendingoperationRead=null,this.pendingresRead=null,o&&o()}if(n){if(this.cancelres){let o=this.cancelres;this.cancelres=null,o()}this.readableclosed||(this.readableController.close(),this.readableclosed=!0)}return s}updateSendOrderAndGroup(){this.objint.updateSendOrderAndGroup({sendOrder:this._sendOrder,sendGroupId:this._sendGroup._sendGroupId})}onStreamRecvSignal(i){Ze("callback",i?.nettask),Ze.trace("onStreamRecvSignal",i);let e=!0,t=this.parentobj.state;switch((t==="closed"||t==="failed")&&(Ze("no parent cleanup as parent was closed or failed"),e=!1),i.nettask){case"resetStream":this.readable?(this.finalDrain(),e&&this.parentobj.removeReceiveStream(this.readable,this.readableController),this.readableclosed=!0,this.readableController.error(new Se("Resetstream with code:"+(i.code||0)))):Ze.error("resetStream without readable");break;case"stopSending":this.writable?(e&&this.parentobj.removeSendStream(this.writable,this.writableController),this.writableclosed=!0,this.writableController.error(new Se("StopSending with code:"+(i.code||0)))):Ze.error("stopSending without writable");break;default:Ze.error("unhandled onStreamRecvSignal")}if(this.pendingoperation){let r=this.pendingres;this.pendingoperation=null,this.pendingres=null,r?.()}if(this.pendingoperationRead){let r=this.pendingresRead;this.pendingoperationRead=null,this.pendingresRead=null,r?.()}}finalDrain(){this.finaldrain_=!0,this.objint.drainReads()}onStreamWrite(i){if(this.pendingoperation){let e=this.pendingres;this.pendingoperation=null,this.pendingres=null,e?.()}}onStreamNetworkFinish(i){switch(Ze("callback",i?.nettask),Ze.trace("networkfinish args",i),i.nettask){case"stopSending":if(this.cancelres){let e=this.cancelres;this.cancelres=null,e()}this.stopSendingRecv=!0;break;case"resetStream":if(this.abortres){let e=this.abortres;this.abortres=null,e(),this.readable&&this.parentobj.removeReceiveStream(this.readable,this.readableController),this.writable&&this.parentobj.removeSendStream(this.writable,this.writableController),this.readableclosed=!0,this.parentobj.removeStreamObj(this)}break;case"streamFinal":if(this.pendingoperation){let e=this.pendingres;this.pendingoperation=null,this.pendingres=null,e?.()}break;default:Ze.error("onStreamNetworkFinish unknown task",i.nettask)}}};var rs=typeof process<"u"?process.pid:0,xi=ge(`webtransport:httpwtsession(${rs})`),Lr=class{constructor(i){i.object&&(this.objint=i.object,this.objint.jsobj=this,this.objint.sendInitialParameters&&this.objint.sendInitialParameters()),this.parentobj=i.parentobj,this.state="connecting",this.readyResolve=null,this.closeHook=null,this.header=i.header,this.userData=i.userData,this.peerAddress_=i.peerAddress,this.ready=new Promise((t,r)=>{this.readyResolve=t,this.readyReject=r}),this.reliability="pending",this.congestionControl="default",this.closed=new Promise((t,r)=>{this.closedResolve=t,this.closedReject=r}),this.draining=new Promise((t,r)=>{this.drainingResolve=t,this.drainingReject=r}),this.incomingBidirectionalStreams=new oi({start:t=>{this.incomBiDiController=t}}),this.incomingUnidirectionalStreams=new oi({start:t=>{this.incomUniDiController=t}});let e={start:t=>{this.incomDatagramController=t},type:"bytes"};xr||delete e.type,this._lastGetMaxDatagramSize=0,this.datagrams={readable:new oi(e),createWritable:t=>{let r=t?.sendOrder??0n,n=t?.sendGroup,s=new Ar({start:o=>{this.outgoDatagramController=o},write:(o,d)=>{if(this.state==="closed")throw new Error("Session is closed");if(o instanceof Uint8Array){if(this.objint==null)throw new Error("this.objint is not set");let{code:p,message:u}=this.objint.writeDatagram(o);if(p!=="success"&&p!=="blocked"&&p!=="tooBig")throw new Se(p+":"+u)}else throw new Error("chunk is not of type Uint8Array")},close:()=>{}});return Object.defineProperties(s,{sendOrder:{get:()=>r,set:o=>{r=o}},sendGroup:{get:()=>n,set:o=>{o!==n&&(n=o)}}}),s},get writable(){return this.datagramwritablepolyfilled_||console.warn("datagrams.writable is deprecated"),this.datagramwritablepolyfilled_||(this.datagramwritablepolyfilled_=this.createWritable())},get maxDatagramSize(){return this._getMaxDatagramSize()},_getMaxDatagramSize:()=>(this.objint&&(this._lastGetMaxDatagramSize=this.objint.getMaxDatagramSize()),this._lastGetMaxDatagramSize)},this.resolveBiDi=[],this.resolveUniDi=[],this.rejectBiDi=[],this.rejectUniDi=[],this.resolveSessionStats=[],this.rejectSessionStats=[],this.resolveDatagramStats=[],this.rejectDatagramStats=[],this.sendStreams=new Set,this.receiveStreams=new Set,this.streamObjs=new Set,this.sendStreamsController=new Set,this.receiveStreamsController=new Set,this._sendGroupNum=1n,this._sendGroupIndex=new Map,this._selectedProtocol=void 0}setSessionObj(i,e){i&&(this.objint=i,this.objint.jsobj=this,this.reliable=!!e,this.objint.sendInitialParameters&&this.objint.sendInitialParameters())}get protocol(){return this._selectedProtocol}getStats(){if(this.objint==null)throw new Error("this.objint not set");let i=new Promise((e,t)=>{this.resolveSessionStats.push(e),this.rejectSessionStats.push(t)});return this.objint.orderSessionStats(),i}onSessionStats({timestamp:i,expiredOutgoing:e=BigInt(0),lostOutgoing:t=BigInt(0),minRtt:r=0,smoothedRtt:n=0,rttVariation:s=0,estimatedSendRateBps:o}){let d=this.resolveSessionStats.pop();this.rejectSessionStats.pop(),d&&d({timestamp:i,bytesSent:BigInt(0),packetsSent:BigInt(0),packetsLost:BigInt(0),numOutgoingStreamsCreated:0,numIncomingStreamsCreated:0,bytesReceived:BigInt(0),packetsReceived:BigInt(0),smoothedRtt:n,rttVariation:s,minRtt:r,estimatedSendRate:o,datagrams:{timestamp:i,expiredOutgoing:e,droppedIncoming:BigInt(0),lostOutgoing:t}})}onDatagramStats({timestamp:i,expiredOutgoing:e=BigInt(0),lostOutgoing:t=BigInt(0)}){let r=this.resolveDatagramStats.pop();this.rejectDatagramStats.pop(),r&&r({timestamp:i,expiredOutgoing:e,droppedIncoming:BigInt(0),lostOutgoing:t})}notifySessionDraining(){if(this.objint==null)throw new Error("this.objint not set");this.objint.notifySessionDraining()}addStreamObj(i){this.streamObjs.add(i)}removeStreamObj(i){this.streamObjs.delete(i)}addSendStream(i,e){this.sendStreams.add(i),this.sendStreamsController.add(e)}removeSendStream(i,e){this.sendStreams.delete(i),this.sendStreamsController.delete(e)}addReceiveStream(i,e){this.receiveStreams.add(i),this.receiveStreamsController.add(e)}removeReceiveStream(i,e){this.receiveStreams.delete(i),this.receiveStreamsController.delete(e)}createBidirectionalStream(i){if(this.objint==null)throw new Error("this.objint not set");let e=new Promise((r,n)=>{this.resolveBiDi.push(r),this.rejectBiDi.push(n)});if(!this.objint.orderBidiStream({sendGroup:i?.sendGroup||null,sendOrder:BigInt(i?.sendOrder||0n),waitUntilAvailable:i?.waitUntilAvailable||!1})){let r=this.rejectBiDi.pop();this.resolveBiDi.pop(),r&&r(new DOMException("No streams available","QuotaExceededError"))}return e}createUnidirectionalStream(i){if(this.objint==null)throw new Error("this.objint not set");let e=new Promise((r,n)=>{this.resolveUniDi.push(r),this.rejectUniDi.push(n)});if(!this.objint.orderUnidiStream({sendGroup:i?.sendGroup||null,sendOrder:i?.sendOrder||0n,waitUntilAvailable:i?.waitUntilAvailable||!1})){let r=this.rejectUniDi.pop();this.resolveUniDi.pop(),r&&r(new DOMException("No streams available","QuotaExceededError"))}return e}close(i){xi("closeinfo",i),!(this.state==="closed"||this.state==="failed")&&this.objint&&this.objint.close({code:i?.closeCode??0,reason:i?.reason.substring(0,1023)??""})}createSendGroup(){if(this.state==="closed"||this.state==="failed")throw new Error("InvalidState");let i=this._sendGroupNum++,e={_sendGroupId:i,getStats:async()=>({bytesWritten:0n,bytesSent:0n,bytesAcknowledged:0n})};return this._sendGroupIndex.set(i,e),e}onReady({protocol:i}){i&&(this._selectedProtocol=i),this.state="connected",this.reliable?this.reliability="reliable-only":this.reliability="supports-unreliable",this.readyResolve&&this.readyResolve(),delete this.readyResolve}onClose(i){if(delete this.objint,this.state!=="connected"){xi.error('session was closed before state was "connected" - it was "%s"',this.state),this.state="failed",this.closeHook&&(this.closeHook(),delete this.closeHook);let r=new Se("Opening handshake failed.");this.readyReject(r),this.closedReject(r);return}xi("onClose"),this.streamObjs.forEach(r=>r.finalDrain());let e=new Se("Session closed");for(let r of this.rejectBiDi)r(e);for(let r of this.rejectUniDi)r(e);for(let r of this.rejectSessionStats)r(e);for(let r of this.rejectDatagramStats)r(e);this.resolveBiDi=[],this.resolveUniDi=[],this.rejectBiDi=[],this.rejectUniDi=[],this.resolveSessionStats=[],this.rejectSessionStats=[],this.resolveDatagramStats=[],this.rejectDatagramStats=[],this.incomBiDiController.close(),this.incomUniDiController.close(),this.incomDatagramController.close(),this.state="closed";let t=new Se(`Session closed (on process ${rs}) with code `+i.errorcode+" and reason"+i.error);this.sendStreamsController.forEach(r=>r.error(t)),this.receiveStreamsController.forEach(r=>r.error(t)),this.streamObjs.forEach(r=>r.readableclosed=!0),this.sendStreams.clear(),this.receiveStreams.clear(),this.sendStreamsController.clear(),this.receiveStreamsController.clear(),this.streamObjs.clear(),this.closedResolve&&this.closedResolve({closeCode:i.errorcode,reason:i.error?i.error:""}),this.closeHook&&(this.closeHook(),delete this.closeHook)}onStream(i){let e=new Nr({object:i.stream,parentobj:this,transport:this.parentobj,bidirectional:i.bidirectional,incoming:i.incoming,sendGroup:this._sendGroupIndex.get(i.sendGroupId||0n),sendOrder:i.sendOrder});if(this.addStreamObj(e),i.incoming)i.bidirectional?this.incomBiDiController.enqueue(e):this.incomUniDiController.enqueue(e.readable);else if(i.bidirectional){if(this.resolveBiDi.length===0)throw new Error("Got bidirectional stream without asking for it");this.rejectBiDi.shift();let t=this.resolveBiDi.shift();t!=null&&e.readable!=null&&e.writable!=null&&t({readable:e.readable,writable:e.writable})}else{if(this.resolveUniDi.length===0)throw new Error("Got unidirectional stream without asking for it");this.rejectUniDi.shift();let t=this.resolveUniDi.shift();t!=null&&e.writable!=null&&t(e.writable)}}onDatagramReceived(i){if(xi.trace("datagram received",i.datagram),i.datagram.byteLength===0){xi.trace("zerolength datagram dropped");return}if(this.incomDatagramController.byobRequest){let e=this.incomDatagramController.byobRequest,t=e?.view;if(!(t instanceof Uint8Array))throw new Error("byob view is not a Uint8Array");if(t.byteLength<i.datagram.byteLength)throw new Error("supplied view is not large enough.");new Uint8Array(t.buffer,0+t.byteOffset,i.datagram.byteLength).set(i.datagram),e.respond(i.datagram.byteLength)}else this.incomDatagramController.enqueue(new Uint8Array(i.datagram))}onGoAwayReceived(i){this.drainingResolve&&this.drainingResolve(void 0),this.state="draining"}get peerAddress(){return this.peerAddress_}};var Uc=typeof process<"u"?process.pid:0,ns=ge(`webtransport:httpclient(${Uc})`),Ur=class{constructor(i){this.args=i,this.sessionProm=null,this.sessionobj=new Promise((e,t)=>{this.sessionProm={resolve:e,reject:t}}).catch(()=>{}),this.sessionobjint=null,this.closeHookSession=this.closeHookSession.bind(this),this.webtransportProm=null,this.quicconnectedProm=null,this._quicConnectTimeout=i.quicConnectTimeout??8e3,this._webTransportConnectTimeout=i.webTransportConnectTimeout??2e3}async handleConnection({createTransport:i,path:e}){i&&this.createTransportInt({path:e}),this.quicconnected=new Promise((r,n)=>{this.quicconnectedProm={resolve:r,reject:n}}),this.webtransport=new Promise((r,n)=>{this.webtransportProm={resolve:r,reject:n}});let t=setTimeout(()=>{this.quicconnectedProm&&(ns.error("quic connection timeout"),this.quicconnectedProm.reject(new Se("Opening handshake failed.")),delete this.quicconnectedProm)},this._quicConnectTimeout);try{await this.quicconnected}finally{clearTimeout(t)}}async createWTSession(i,e){let t=setTimeout(()=>{this.webtransportProm&&(ns.error("webtransport connection timeout"),this.webtransportProm.reject(new Se("Opening handshake failed.")),delete this.webtransportProm)},this._webTransportConnectTimeout);await this.webtransport,clearTimeout(t),this.sessionobjint=i,this.transportInt.openWTSession(e);let r=await this.sessionobj;return delete this.sessionobj,r}closeHookSession(){this.transportInt!=null&&this.transportInt.closeClient(),this.stopped=!0}onClientError(i){this.sessionobjint!=null&&this.sessionobjint.onClose(i)}onClientConnected(i){if(this.transportIntSwitchToReliable=void 0,this.quicconnectedProm)i.success?this.quicconnectedProm.resolve():this.quicconnectedProm.reject(new Se("Opening handshake failed.")),delete this.quicconnectedProm;else if(i.success)throw new Se("Client connected with no pending promise")}onClientWebTransportSupport(i){this.webtransportProm&&(this.webtransportProm.resolve(),delete this.webtransportProm)}onHttpWTSessionVisitor(i){if(i.session&&this.sessionProm&&this.sessionobjint)this.sessionobjint.setSessionObj(i.session,!!i.reliable),i.session.jsobj.closeHook=this.closeHookSession,delete this.sessionobjint,this.sessionProm.resolve(i.session),delete this.sessionProm;else throw new Se("Http3WTSessionVisitor no object session or nor sessionprom")}createTransportInt(i){let e=i?.path;if(this.transportInt==null){try{if(this.args?.forceReliable||!this.args.createUnreliableClient)this.transportInt=this.args.createReliableClient(this);else if(this.transportInt=this.args.createUnreliableClient(this),!this.args?.requireUnreliable){let t=this.args;this.transportIntSwitchToReliable=()=>{this.transportInt!=null&&this.transportInt.closeClient(),this.transportInt=t.createReliableClient(this),this.transportInt.jsobj=this,this.transportInt.createTransport&&this.transportInt.createTransport({path:e}),this.transportIntSwitchToReliable=void 0}}}catch(t){let r=new Se("Opening handshake failed.");throw r.stack=t.stack,r}delete this.args,this.transportInt.jsobj=this,this.transportInt.createTransport&&this.transportInt.createTransport({path:e})}}};var Bc=typeof process<"u"?process.pid:0,ke=ge(`webtransport:flowcontroller(${Bc})`),Br=class Br{constructor({tocontrol:i,sendWindowOffset:e,receiveWindowOffset:t,receiveWindowSizeLimit:r,shouldAutoTuneReceiveWindow:n,sessionFlowController:s}){this.tocontrol=i,this.bytesSent=0n,this.sendWindowOffset=BigInt(e),this.bytesConsumed=0n,this.highestReceivedByteOffset=0n,this.receiveWindowOffset=BigInt(t),this.receiveWindowSize=BigInt(t),this.receiveWindowSizeLimit=BigInt(r),this.autoTuneReceiveWindow=n,this.sessionFlowController=s,this.lastBlockedSendWindowOffset=0n,this.prevWindowUpdateTime=void 0,ke("Created flow controller , setting initial receive window offset to: "+this.receiveWindowOffset+", max receive window to: "+this.receiveWindowSize+", max receive window limit to: "+this.receiveWindowSizeLimit+", setting send window offset to: "+this.sendWindowOffset)}addBytesConsumed(i){this.bytesConsumed+=BigInt(i),ke(" consumed "+i+" bytes."),this.maybeSendWindowUpdate()}updateHighestReceivedOffset(i){return ke(" highest byte offset increased from "+this.highestReceivedByteOffset," to ",this.highestReceivedByteOffset+BigInt(i)),this.highestReceivedByteOffset+=BigInt(i),!0}addBytesSent(i){let e=BigInt(i);if(this.bytesSent+e>this.sendWindowOffset){ke(" Trying to send an extra "+e+" bytes, when bytes_sent = "+this.bytesSent+", and send_window_offset_ = "+this.sendWindowOffset),this.bytesSent=this.sendWindowOffset,this.tocontrol.closeConnection({code:63,reason:this.sendWindowOffset-(this.bytesSent+e)+"bytes over send window offset"});return}this.bytesSent+=e,ke(" sent "+e+" bytes.")}flowControlViolation(){return this.highestReceivedByteOffset>this.receiveWindowOffset?(ke("Flow control violation on , receive window offset: "+this.receiveWindowOffset+", highest received byte offset: "+this.highestReceivedByteOffset),!0):!1}maybeIncreaseMaxWindowSize(){let i=Date.now(),e=this.prevWindowUpdateTime;if(this.prevWindowUpdateTime=i,!e){ke("first window update for ");return}if(!this.autoTuneReceiveWindow)return;let t=this.tocontrol.smoothedRtt();if(t===0){ke("rtt zero for ");return}let r=i-e,n=2*t;if(r>=n)return;let s=this.receiveWindowSize;this.increaseWindowSize(),this.receiveWindowSize>s?(ke("New max window increase for "+ +" after "+r+" us, and RTT is "+t+"us. max wndw: "+this.receiveWindowSize),this.sessionFlowController!==void 0&&this.sessionFlowController.ensureWindowAtLeast(BigInt(Br.kSessionFlowControlMultiplier*Number(this.receiveWindowSize)))):ke("Max window at limit for after "+r+" us, and RTT is "+t+"us. Limit size: "+this.receiveWindowSize)}increaseWindowSize(){this.receiveWindowSize*=2n,this.receiveWindowSize=this.receiveWindowSize>this.receiveWindowSizeLimit?this.receiveWindowSizeLimit:this.receiveWindowSize}windowUpdateThreshold(){return this.receiveWindowSize/2n}maybeSendWindowUpdate(){if(!this.tocontrol.connected())return;let i=this.receiveWindowOffset-this.bytesConsumed,e=this.windowUpdateThreshold();if(this.prevWindowUpdateTime||(this.prevWindowUpdateTime=Date.now()),i>=e){ke("Not sending WindowUpdate for , available window: "+i+" >= threshold: "+e);return}this.maybeIncreaseMaxWindowSize(),this.updateReceiveWindowOffsetAndSendWindowUpdate(i)}updateReceiveWindowOffsetAndSendWindowUpdate(i){this.receiveWindowOffset+=this.receiveWindowSize-i,ke("Sending WindowUpdate frame for , consumed bytes: "+this.bytesConsumed+", available window: "+i+", and threshold: "+this.windowUpdateThreshold()+", and receive window size: "+this.receiveWindowSize+". New receive window offset is: "+this.receiveWindowOffset),this.sendWindowUpdate()}maybeSendBlocked(){this.sendWindowSize()!==0n||this.lastBlockedSendWindowOffset>=this.sendWindowOffset||(ke(" is flow control blocked. Send window: "+this.sendWindowSize()+", bytes sent: "+this.bytesSent+", send limit: "+this.sendWindowOffset),this.lastBlockedSendWindowOffset=this.sendWindowOffset,this.tocontrol.sendBlocked(this.lastBlockedSendWindowOffset))}updateSendWindowOffset(i){if(i<=this.sendWindowOffset)return!1;ke("UpdateSendWindowOffset for with new offset "+i+" current offset: "+this.sendWindowOffset+" bytes_sent: "+this.bytesSent);let e=this.isBlocked();return this.sendWindowOffset=i,e}ensureWindowAtLeast(i){if(this.receiveWindowSizeLimit>=i)return;let e=this.receiveWindowOffset-this.bytesConsumed;this.increaseWindowSize(),this.updateReceiveWindowOffsetAndSendWindowUpdate(e)}isBlocked(){return this.sendWindowSize()===0n}sendWindowSize(){return this.bytesSent>this.sendWindowOffset?0n:this.sendWindowOffset-this.bytesSent}updateReceiveWindowSize(i){if(ke("UpdateReceiveWindowSize for : "+i),this.receiveWindowSize!==this.receiveWindowOffset){ke("receive_window_size_:"+this.receiveWindowSize+" != receive_window_offset:"+this.receiveWindowOffset);return}this.receiveWindowSize=i,this.receiveWindowOffset=i}sendWindowUpdate(){this.tocontrol.sendWindowUpdate(this.receiveWindowOffset)}};le(Br,"kSessionFlowControlMultiplier",1.5);var pi=Br;var Fc=typeof process<"u"?process.pid:0,as=ge(`webtransport:http2webtransportstream(${Fc})`),Fr=a=>setTimeout(a,0);typeof process<"u"&&(Fr=process.nextTick);var Vr=class{constructor({streamid:i,unidirectional:e,incoming:t,capsuleParser:r,sendWindowOffset:n,receiveWindowOffset:s,shouldAutoTuneReceiveWindow:o,receiveWindowSizeLimit:d,sessionFlowController:p,streamIdManager:u}){this.jsobj=void 0,this.streamid=i,this.incomdata=[],this.capsuleParser=r,this.outgochunks=[],this.flowController=new pi({tocontrol:this,sendWindowOffset:n,receiveWindowOffset:s,shouldAutoTuneReceiveWindow:o,receiveWindowSizeLimit:d,sessionFlowController:p}),this.sessionFlowController=p,this.streamIdManager=u,this.final=!1,this.finalmessagesend=!1,this.stopReading_=!0,this.drainReads_=!0,this.recvBytes=0,this.outgoingClosed_=!1,this.incomingClosed_=!1,e&&(t?this.outgoingClosed_=!0:this.incomingClosed_=!0)}sendInitialParameters(){this.flowController.sendWindowUpdate()}recvData({data:i,fin:e}){if(this.incomdata.push({data:i,fin:e}),i&&i?.byteLength>0){let t=this.flowController.updateHighestReceivedOffset(i?.byteLength);if(this.sessionFlowController.updateHighestReceivedOffset(i?.byteLength)&&t&&(this.flowController.flowControlViolation()||this.sessionFlowController.flowControlViolation())){this.closeConnection({code:63,reason:"Flow control violation after increasing offset"});return}}this.processRead(),this.incomdata.length>0&&(this.stopReading_||this.processRead())}processRead(){if(!this.jsobj)return;let i,e=0;for(;this.incomdata.length>0&&(!this.stopReading_||this.drainReads_);){i||this.incomdata.reduce((n,s)=>n+(s&&s.data?.byteLength||0),0)>0&&(i=this.jsobj.getReadBuffer({byteSize:this.incomdata.reduce((n,s)=>n+(s&&s.data?.byteLength||0),0)}),i.readBytes=0,e=0);let t=this.incomdata.shift();if(t?.data&&t.data.byteLength>0&&i&&i.buffer){let r=Math.min(i.buffer.byteLength-e,t.data.byteLength),n=new Uint8Array(t.data.buffer,t.data.byteOffset,r);if(new Uint8Array(i.buffer.buffer,e,r).set(n),e+=r,i.readBytes+=r,i.drained=!0,t.data.byteLength!==r?(i.drained=!1,this.incomdata.unshift({data:new Uint8Array(t.data.buffer,t.data.byteOffset+r,t.data.byteLength-r),fin:t.fin}),i.fin=!1):i.fin||(i.fin=t.fin),this.incomdata.length>0&&(i.drained=!1),e===i.buffer.byteLength||this.incomdata.length===0){this.flowController.addBytesConsumed(i.readBytes||0),this.sessionFlowController.addBytesConsumed(i.readBytes||0);let{stopReading:o}=this.jsobj.commitReadBuffer(i);o&&(this.stopReading_=!0),i=void 0,e=0}this.recvBytes+=r}else t?.fin&&this.jsobj.commitReadBuffer({fin:!0})}}startReading(){this.stopReading_=!1,this.processRead()}drainReads(){this.drainReads_=!0,this.stopReading_=!1,this.processRead()}stopReading(){this.stopReading_=!0}onStreamSignal(i){switch(i){case"resetStream":this.closeIncoming();break;case"stopSending":this.closeOutgoing();break}}closeIncoming(){this.incomingClosed_=!0,this.outgoingClosed_&&this.onClose()}closeOutgoing(){this.outgoingClosed_=!0,this.incomingClosed_&&this.onClose()}onClose(){this.streamIdManager.onStreamClosed(this.streamid)}stopSending(i){this.closeIncoming(),this.capsuleParser.writeCapsule({type:J.WT_STOP_SENDING,headerVints:[this.streamid,i],payload:void 0}),Fr(()=>this.jsobj.onStreamNetworkFinish({nettask:"stopSending"}))}onFin(){this.closeIncoming()}resetStream(i){this.closeOutgoing(),this.capsuleParser.writeCapsule({type:J.WT_RESET_STREAM,headerVints:[this.streamid,i],payload:void 0}),Fr(()=>this.jsobj.onStreamNetworkFinish({nettask:"resetStream"}))}writeChunk(i){this.outgochunks.push({buf:i,fin:!1}),this.capsuleParser.scheduler.Schedule(this.streamid),this.capsuleParser.scheduleDrainWrites()}hasPendingData(){return this.outgochunks.length>0}drainWrites(){let i=!1;for(;this.outgochunks.length>0&&(!this.capsuleParser.blocked||this.final||!this.capsuleParser.shouldYieldStream(this.streamid))&&this.flowController.sendWindowSize()>0n&&this.sessionFlowController.sendWindowSize()>0n;){let e=this.outgochunks.shift(),t=!0;if(e){let r=e.buf;if(r){if(r.byteLength===0&&!e.fin)throw new Se("Trying to send zero length capsule without a fin");let n=this.sessionFlowController.sendWindowSize(),s=this.flowController.sendWindowSize();if(r?.byteLength>s||r?.byteLength>n){let o=n>s?Number(s):Number(n);{let d=new Uint8Array(r.buffer,r.byteOffset+o,r.byteLength-o),p=new Uint8Array(r.byteLength-o);p.set(d),this.outgochunks.unshift({fin:e.fin,buf:p}),t=!1}e.fin=!1,r=e.buf=new Uint8Array(r.buffer,r.byteOffset,o)}}this.capsuleParser.writeCapsule({type:e?.fin?J.WT_STREAM_WFIN:J.WT_STREAM_WOFIN,headerVints:[this.streamid],payload:r}),i||(i=!!e?.fin),r&&(this.flowController.addBytesSent(r?.byteLength),this.sessionFlowController.addBytesSent(r?.byteLength))}t&&this.jsobj.onStreamWrite({success:!0})}if(i){this.capsuleParser.removeStream(this.streamid);return}!(!this.capsuleParser.blocked||this.final||!this.capsuleParser.shouldYieldStream(this.streamid))&&this.outgochunks.length>0&&this.capsuleParser.scheduleDrainWriteStream(this.streamid),this.final&&this.outgochunks.length===0&&!this.finalmessagesend&&(Fr(()=>{this.jsobj.onStreamNetworkFinish({nettask:"streamFinal"})}),this.finalmessagesend=!0)}streamFinal(){this.final=!0,this.outgochunks.push({fin:!0}),this.capsuleParser.scheduleDrainWriteStream(this.streamid),this.capsuleParser.scheduleDrainWrites()}updateSendOrderAndGroup({sendOrder:i,sendGroupId:e}){this.capsuleParser.streamUpdateSendOrderAndGroup(this.streamid,{sendOrder:i,sendGroupId:e})}sendWindowUpdate(i){as("sendwindow offset stream:",i),this.capsuleParser.writeCapsule({type:J.WT_MAX_STREAM_DATA,headerVints:[this.streamid,i],payload:void 0})}sendBlocked(i){this.capsuleParser.writeCapsule({type:J.WT_STREAM_DATA_BLOCKED,headerVints:[this.streamid,i],payload:void 0})}reportBlocked(i){as("Stream id: ",this.streamid," was blocked at:",i)}connected(){return this.jsobj.parentobj.state==="connected"}closeConnection({code:i,reason:e}){this.jsobj.parentobj?.objint&&this.jsobj.parentobj.objint.closeConnection({code:i,reason:e})}smoothedRtt(){if(this.jsobj.parentobj?.objint)return this.jsobj.parentobj.objint.smoothedRtt()}};function Ni(a){return a.toString()}function Pe(a){return a.toString()}var qn=class{constructor(i){this.priority=i,this.currentSequenceNumber=void 0}scheduled(){return typeof this.currentSequenceNumber<"u"}};function Vc(a,i){return a.priority>i.priority?-1:a.priority===i.priority?a.sequenceNumber>i.sequenceNumber?-1:a.sequenceNumber===i.sequenceNumber?0:1:1}function ss(a,i){return Vc(a.scheduleKey,i.scheduleKey)}var jr=class a{constructor(){this.streams_={},this.schedule_=[],this.currentWriteSequenceNumber_=0}HasRegistered(){return Object.keys(this.streams_).length!==0}HasScheduled(){return Object.keys(this.schedule_).length!==0}NumScheduled(){return Object.keys(this.schedule_).length}NumRegistered(){return Object.keys(this.streams_).length}NumScheduledInPriorityRange(i,e){let t=typeof e<"u"?this.schedule_.findIndex(n=>n.scheduleKey.priority<=e):0;return(typeof i<"u"?this.schedule_.findIndex(n=>n.scheduleKey.priority>=i):this.schedule_.length)-t}ShouldYield(i){let e=this.streams_[Pe(i)];if(!e)throw new Error("ID not registered");if(this.schedule_.length===0)return!1;let t=this.schedule_[0];return a.StreamId(t)==i?!1:t.scheduleKey.priority>=e.priority}GetPriorityFor(i){let e=this.streams_[Pe(i)];if(e)return e.priority}PopFront(){if(this.schedule_.length===0)return;let i=this.schedule_[0];i.fullStreamEntry.streamEntry.currentSequenceNumber=void 0;let e=a.StreamId(i);return this.schedule_.shift(),e}Register(i,e){if(this.streams_[Pe(i)])throw new Error("ID already registered");this.streams_[Pe(i)]=new qn(e.sendOrder)}Unregister(i){let e=this.streams_[Pe(i)];if(!e)throw new Error("Stream not registered");e.scheduled()&&this.DescheduleStream(e),delete this.streams_[Pe(i)]}UpdatePriority(i,e){let t=this.streams_[Pe(i)];if(!t)return new Error("ID not registered");let r;t.scheduled()&&(r=this.DescheduleStream(t).scheduleKey.sequenceNumber),t.priority=e,r&&(this.schedule_.push({scheduleKey:{priority:t.priority,sequenceNumber:r},fullStreamEntry:{iD:i,streamEntry:t}}),this.schedule_.sort(ss))}Schedule(i){let e=this.streams_[Pe(i)];if(!e)return new Error("ID not registered");if(e.scheduled())return;let t={scheduleKey:{priority:e.priority,sequenceNumber:--this.currentWriteSequenceNumber_},fullStreamEntry:{iD:i,streamEntry:e}};this.schedule_.push(t),this.schedule_.sort(ss),e.currentSequenceNumber=t.scheduleKey.sequenceNumber}Deschedule(i){let e=this.streams_[Pe(i)];if(!e)throw new Error("Stream not registered");if(!e.scheduled())throw new Error("Stream not scheduled");this.DescheduleStream(e),e.currentSequenceNumber=void 0}IsScheduled(i){let e=this.streams_[Pe(i)];return e?e.scheduled():!1}static StreamId(i){return i.fullStreamEntry.iD}DescheduleStream(i){let e=this.schedule_.findIndex(r=>i.priority===r.scheduleKey.priority&&i.currentSequenceNumber===r.fullStreamEntry.streamEntry.currentSequenceNumber);if(e===-1)throw new Error("Calling DescheduleStream() on an entry that is not in the schedule at the expected key.");let t=this.schedule_[e];return this.schedule_.splice(e,1),t}},Wr=class{constructor(){this.activeGroups_=new jr,this.perGroupSchedulers_={},this.streamToGroupMap_={}}HasRegistered(){return this.activeGroups_.HasRegistered()}HasScheduled(){return this.activeGroups_.HasScheduled()}NumScheduled(){let i=0;for(let[,e]of Object.entries(this.perGroupSchedulers_))i+=e.NumScheduled();return i}Register(i,e){if(this.streamToGroupMap_[Pe(i)])throw new Error("Provided stream ID already registered");this.perGroupSchedulers_[Ni(e.sendGroupId)]||(this.perGroupSchedulers_[Ni(e.sendGroupId)]=new jr,this.activeGroups_.Register(e.sendGroupId,e));let t=this.perGroupSchedulers_[Ni(e.sendGroupId)];this.streamToGroupMap_[Pe(i)]={sendGroupId:e.sendGroupId,perGroupScheduler:t},t.Register(i,e)}Unregister(i){let e=this.streamToGroupMap_[Pe(i)];if(!e)throw new Error("Stream ID not registered");let t=e.sendGroupId,r=e.perGroupScheduler;delete this.streamToGroupMap_[Pe(i)],r.Unregister(i),r.HasRegistered()||(delete this.perGroupSchedulers_[Ni(t)],this.activeGroups_.Unregister(t))}UpdateSendOrder(i,e){let t=this.SchedulerForStream(i);if(!t)throw new Error("Stream ID not registered");return t.UpdatePriority(i,e)}UpdateSendGroup(i,e){let t=this.SchedulerForStream(i);if(!t)throw new Error("Stream ID not registered");let r=t.IsScheduled(i),n=t.GetPriorityFor(i);if(!n)throw new Error("Stream registered at the top level scheduler, but not at the per-group one");this.Unregister(i),this.Register(i,{sendGroupId:e,sendOrder:n}),r&&this.Schedule(i)}ShouldYield(i){let e=this.streamToGroupMap_[Pe(i)];if(!e)throw new Error("Stream ID not registered");let{sendGroupId:t,perGroupScheduler:r}=e;return this.activeGroups_.ShouldYield(t)?!0:r.ShouldYield(i)}GetPriorityFor(i){let e=this.streamToGroupMap_[Pe(i)];if(!e)return null;let{sendGroupId:t,perGroupScheduler:r}=e,n=r.GetPriorityFor(i);return n?{sendGroupId:t,sendOrder:n}:null}PopFront(){let i=this.activeGroups_.PopFront();if(typeof i>"u")return;let e=this.perGroupSchedulers_[Ni(i)];if(!e)throw new Error("Scheduled a group with no per-group scheduler attached");let t=e.PopFront();if(!(typeof t>"u"))return e.HasScheduled()&&this.activeGroups_.Schedule(i),t}Schedule(i){let e=this.streamToGroupMap_[Pe(i)];if(!e)return new Error("Stream ID not registered");let{sendGroupId:t,perGroupScheduler:r}=e;return this.activeGroups_.Schedule(t),r.Schedule(i)}IsScheduled(i){let e=this.SchedulerForStream(i);return e?e.IsScheduled(i):!1}SchedulerForStream(i){let e=this.streamToGroupMap_[Pe(i)];if(e)return e.perGroupScheduler}};var jc=typeof process<"u"?process.pid:0,$n=ge(`webtransport:parserbase(${jc})`);function zn(a){return BigInt(a)<64n?1:BigInt(a)<16384n?2:BigInt(a)<1073741824n?4:8}var Te=class Te{constructor({nativesession:i,isclient:e,initialStreamSendWindowOffsetBidi:t,initialStreamSendWindowOffsetUnidi:r,initialStreamReceiveWindowOffset:n,streamShouldAutoTuneReceiveWindow:s,streamReceiveWindowSizeLimit:o}){this.session=i,this.isclient=e,this.blocked=!1,this.initialStreamSendWindowOffsetUnidi=r,this.initialStreamSendWindowOffsetBidi=t,this.initialStreamReceiveWindowOffset=n,this.streamShouldAutoTuneReceiveWindow=s,this.streamReceiveWindowSizeLimit=o,this.wtstreams=new Map,this.scheduler=new Wr}parseData(i){throw new Error("Implement parseData in derived Class")}writeCapsule({type:i,headerVints:e,payload:t,end:r}){throw new Error("Implement writeCapsule in derived Class")}initialParametersMandatory(){throw new Error("Implement initialParametersMandatory in derived Class")}sendClose({code:i,reason:e}){let r=new TextEncoder().encode("AAAA"+e);r[0]=i>>24&255,r[1]=i>>16&255,r[2]=i>>8&255,r[3]=i&255,this.writeCapsule({type:Te.CLOSE_WEBTRANSPORT_SESSION,headerVints:[],payload:r,end:()=>{this.closeHttp2Stream(i)}})}newStream(i,e){let t=this.isclient?!(i&0x1n):!!(i&0x1n),r=i&0x2n?this.session.streamIdMngrUni:this.session.streamIdMngrBi;if(t){let o=r.maybeIncreaseLargestPeerStreamId(i);if(o.error){this.session.closeConnection({code:20,reason:o.error});return}}let n=!!(i&0x2n),s=new Vr({streamid:i,unidirectional:n,incoming:t,capsuleParser:this,sendWindowOffset:n?this.initialStreamSendWindowOffsetUnidi:this.initialStreamSendWindowOffsetBidi,receiveWindowOffset:this.initialStreamReceiveWindowOffset,shouldAutoTuneReceiveWindow:this.streamShouldAutoTuneReceiveWindow,receiveWindowSizeLimit:this.streamReceiveWindowSizeLimit,sessionFlowController:this.session.flowController,streamIdManager:r});return this.wtstreams.set(i,s),this.scheduler.Register(i,e),this.session.jsobj.onStream({bidirectional:!(i&0x2n),incoming:t,stream:s,sendGroupId:e.sendGroupId,sendOrder:e.sendOrder}),s}scheduleDrainWrites(){if(this._scheduledDrainWriteCall)return;let i=Promise.resolve();this._scheduledDrainWriteCall=i,i.then(()=>{delete this._scheduledDrainWriteCall,this.drainWrites()}).catch(e=>$n("Error in drainWrites",e))}drainWrites(){for(this.blocked||this.session.drainWrites();!this.blocked;){let i=this.scheduler.PopFront();if(typeof i>"u")break;let e=this.wtstreams.get(i);if(!e)break;e.drainWrites()}}onMaxData(i){if(i&&this.session.flowController.updateSendWindowOffset(i)){let e=!1;this.wtstreams.forEach((t,r)=>{t.hasPendingData()&&(e=!0,this.scheduleDrainWriteStream(r))}),e&&this.drainWrites()}}onMaxStreamData(i,e){let t=this.wtstreams.get(i);t&&e&&t.flowController.updateSendWindowOffset(e)&&(this.scheduleDrainWriteStream(i),this.drainWrites())}onMaxStreamUniDi(i){typeof i>"u"||(this.session.streamIdMngrUni.maybeAllowNewOutgoingStreams(i),this.session.trySendingUnidirectionalStreams())}onMaxStreamBiDi(i){typeof i>"u"||(this.session.streamIdMngrBi.maybeAllowNewOutgoingStreams(i),this.session.trySendingBidirectionalStreams())}onDataBlocked(i){$n("Session received blocked frame "+i)}onStreamDataBlocked(i,e){$n("Stream "+i+" received blocked frame "+e)}onStreamsBlockedBidi(i){if(typeof i>"u")return;let e=this.session.streamIdMngrBi.onStreamsBlockedFrame(i);e.error&&this.session.closeConnection({code:105,reason:e.error})}onStreamsBlockedUnidi(i){if(typeof i>"u")return;let e=this.session.streamIdMngrUni.onStreamsBlockedFrame(i);e.error&&this.session.closeConnection({code:105,reason:e.error})}onCloseWebTransportSession({code:i,reason:e}){this.session.jsobj.onClose({errorcode:i,error:e}),this.closeHttp2Stream(i)}onDrain(){this.session.jsobj.onGoAwayReceived()}shouldYieldStream(i){return this.scheduler.ShouldYield(i)}scheduleDrainWriteStream(i){this.scheduler.Schedule(i)}removeStream(i){this.scheduler.Unregister(i)}streamUpdateSendOrderAndGroup(i,{sendOrder:e,sendGroupId:t}){this.scheduler.UpdateSendGroup(i,t),this.scheduler.UpdateSendOrder(i,e)}closeHttp2Stream(i){throw new Error("Implement closeHttp2Stream in derived Class")}};le(Te,"PADDING",420171064),le(Te,"WT_RESET_STREAM",420171065),le(Te,"WT_STOP_SENDING",420171066),le(Te,"WT_STREAM_WOFIN",420171067),le(Te,"WT_STREAM_WFIN",420171068),le(Te,"WT_MAX_DATA",420171069),le(Te,"WT_MAX_STREAM_DATA",420171070),le(Te,"WT_MAX_STREAMS_BIDI",420171071),le(Te,"WT_MAX_STREAMS_UNIDI",420171072),le(Te,"WT_DATA_BLOCKED",420171073),le(Te,"WT_STREAM_DATA_BLOCKED",420171074),le(Te,"WT_STREAMS_BLOCKED_UNIDI",420171075),le(Te,"WT_STREAMS_BLOCKED_BIDI",420171076),le(Te,"CLOSE_WEBTRANSPORT_SESSION",10307),le(Te,"DRAIN_WEBTRANSPORT_SESSION",30894),le(Te,"DATAGRAM",0);var J=Te;function os(){return(0xffffffffn>>2n)+1n}var Wc=typeof process<"u"?process.pid:0,cs=ge(`webtransport:streamidmanager(${Wc})`),Li=class{constructor({delegate:i,unidirectional:e,isclient:t,maxAllowedOutgoingStreams:r,maxAllowedIncomingStreams:n}){this.delegate=i,this.unidirectional=e,this.isclient=t,this.outgoingMaxStreams=BigInt(r),this.nextOutgoingStreamId=this.getFirstOutgoingStreamId(),this.outgoingStreamCount=0n,this.incomingActualMaxStreams=BigInt(n),this.incomingAdvertisedMaxStreams=BigInt(n),this.incomingInitialMaxOpenStreams=BigInt(n),this.incomingStreamCount=0n,this.availableStreams=new Set,this.largestPeerCreatedStreamId=BigInt(Number.MAX_SAFE_INTEGER),this.stopIncreasingIncomingMaxStreams=!1}onStreamsBlockedFrame(i){return i>this.incomingAdvertisedMaxStreams?{error:"StreamsBlockedFrame's stream count "+i+" exceeds incoming max stream "+this.incomingAdvertisedMaxStreams}:this.incomingAdvertisedMaxStreams===this.incomingActualMaxStreams?{success:!0}:(i<this.incomingActualMaxStreams&&this.delegate.canSendMaxStreams()&&this.sendMaxStreamsFrame(),{success:!0})}maybeAllowNewOutgoingStreams(i){if(i<=this.outgoingMaxStreams)return!1;let e=os();return i<e?this.outgoingMaxStreams=i:this.outgoingMaxStreams=e,!0}setMaxOpenIncomingStreams(i){if(this.incomingStreamCount>0)throw new Error("non-zero incoming stream count "+this.incomingStreamCount+ +" when setting max incoming stream to "+i);this.incomingInitialMaxOpenStreams!==i&&cs(this.unidirectional?"unidirectional ":"bidirectional: ","incoming stream limit changed from ",this.incomingInitialMaxOpenStreams," to ",i),this.incomingActualMaxStreams=i,this.incomingAdvertisedMaxStreams=i,this.incomingInitialMaxOpenStreams=i}maybeSendMaxStreamsFrame(){let i=2n;i>0n&&this.incomingAdvertisedMaxStreams-this.incomingStreamCount>this.incomingInitialMaxOpenStreams/i||this.delegate.canSendMaxStreams()&&this.incomingAdvertisedMaxStreams<this.incomingActualMaxStreams&&this.sendMaxStreamsFrame()}sendMaxStreamsFrame(){if(this.incomingAdvertisedMaxStreams>=this.incomingActualMaxStreams)throw new Error("this.incomingAdvertisedMaxStreams >= this.incomingActualMaxStreams"+this.incomingAdvertisedMaxStreams+"vs."+this.incomingActualMaxStreams);this.incomingAdvertisedMaxStreams=this.incomingActualMaxStreams,this.delegate.sendMaxStreams(this.incomingAdvertisedMaxStreams,this.unidirectional)}sendMaxStreamsFrameInitial(){this.delegate.sendMaxStreams(this.incomingAdvertisedMaxStreams,this.unidirectional)}onStreamClosed(i){this.isclient&&i&0x1n||!this.isclient&&!(i&0x1n)||this.incomingActualMaxStreams!==os()&&(this.stopIncreasingIncomingMaxStreams||(this.incomingActualMaxStreams++,this.maybeSendMaxStreamsFrame()))}getNextOutgoingStreamId(){if(this.outgoingStreamCount>=this.outgoingMaxStreams)throw new Error("Attempt to allocate a new outgoing stream that would exceed the limit ("+ +Number(this.outgoingMaxStreams)+")");let i=this.nextOutgoingStreamId;return this.nextOutgoingStreamId+=1n<<2n,this.outgoingStreamCount++,i}canOpenNextOutgoingStream(){return this.outgoingStreamCount<this.outgoingMaxStreams}isMaxStreamSet(){return this.outgoingMaxStreams>0n}maybeIncreaseLargestPeerStreamId(i){if(this.availableStreams.has(i))return this.availableStreams.delete(i),!0;let e=1n<<2n,t=this.largestPeerCreatedStreamId===BigInt(Number.MAX_SAFE_INTEGER)?this.getFirstIncomingStreamId():this.largestPeerCreatedStreamId+e,r=(i-t)/e+1n;if(this.incomingStreamCount+r>this.incomingAdvertisedMaxStreams)return cs("Failed to create a new incoming stream with id:"+i+", reaching MAX_STREAMS limit: "+this.incomingAdvertisedMaxStreams+"."),{error:"Stream id "+i+" would exceed stream count limit "+this.incomingAdvertisedMaxStreams};for(let n=t;n<i;n+=e)this.availableStreams.add(n);return this.incomingStreamCount+=r,this.largestPeerCreatedStreamId=i,!0}isAvailableStream(i){return this.isclient&&i&1||!this.isclient&&!(i&1)?i>=this.nextOutgoingStreamId:this.largestPeerCreatedStreamId===BigInt(Number.MAX_SAFE_INTEGER)||i>this.largestPeerCreatedStreamId||this.availableStreams.has(i)}getFirstOutgoingStreamId(){let i=0n;return this.isclient&&(i|=0x1n),this.unidirectional&&(i|=0x2n),i}getFirstIncomingStreamId(){let i=0n;return this.isclient||(i|=0x1n),this.unidirectional&&(i|=0x2n),i}get availableIncomingStreams(){return this.incomingAdvertisedMaxStreams-this.incomingStreamCount}};var Gc=typeof process<"u"?process.pid:0,Hc=ge(`webtransport:http2webtransportsession(${Gc})`),Jn=a=>setTimeout(a,0);typeof process<"u"&&(Jn=process.nextTick);var Gr=class{constructor({stream:i,ws:e,isclient:t,createParser:r,sendWindowOffset:n,receiveWindowOffset:s,shouldAutoTuneReceiveWindow:o,receiveWindowSizeLimit:d,initialBidirectionalSendStreams:p,initialBidirectionalReceiveStreams:u,initialUnidirectionalSendStreams:h,initialUnidirectionalReceiveStreams:g}){if(this.jsobj=void 0,i)this.stream=i;else if(e)this.ws=e;else throw new Error("Neither stream or websocket supplied");this.capsParser=r(this),this.isclient=t,this.flowController=new pi({tocontrol:this,sendWindowOffset:n,receiveWindowOffset:s,shouldAutoTuneReceiveWindow:o,receiveWindowSizeLimit:d}),this.streamIdMngrUni=new Li({delegate:this,unidirectional:!0,isclient:t,maxAllowedIncomingStreams:g,maxAllowedOutgoingStreams:h}),this.streamIdMngrBi=new Li({delegate:this,unidirectional:!1,isclient:t,maxAllowedIncomingStreams:u,maxAllowedOutgoingStreams:p}),this.datagramsWaiting_=[],this.orderUniStreams=[],this.orderBiStreams=[],i&&(t?i.on("response",b=>{Jn(()=>{if(b[":status"]===200){let w={};i&&b["wt-protocol"]&&(w.protocol=b["wt-protocol"]),this.jsobj.onReady(w)}else this.jsobj.onClose({errorcode:b[":status"],error:"Session stream errored"})})}):Jn(()=>{this.jsobj.onReady({})}))}sendInitialParameters(){let i=!1;process&&process.version&&parseInt(process.version.split(".")[0].substring(1))>=20&&(i=!0),(!i||this.capsParser.initialParametersMandatory())&&(this.flowController.sendWindowUpdate(),this.streamIdMngrBi.sendMaxStreamsFrameInitial(),this.streamIdMngrUni.sendMaxStreamsFrameInitial())}drainWrites(){for(;!this.capsParser.blocked&&this.datagramsWaiting_.length>0;){let i=this.datagramsWaiting_.shift();this.capsParser.writeCapsule({type:J.DATAGRAM,headerVints:[],payload:i})}this.datagramsWaiting_.length>0&&this.capsParser.scheduleDrainWrites()}writeDatagram(i){return i.byteLength>this.getMaxDatagramSize()?{code:"tooBig"}:this.capsParser.blocked?(this.datagramsWaiting_.push(i),this.capsParser.scheduleDrainWrites(),{code:"blocked"}):(this.capsParser.writeCapsule({type:J.DATAGRAM,headerVints:[],payload:i}),{code:"success"})}trySendingUnidirectionalStreams(){for(;this.orderUniStreams.length>0&&this.streamIdMngrUni.canOpenNextOutgoingStream();){let i=this.streamIdMngrUni.getNextOutgoingStreamId(),e=this.orderUniStreams.pop();this.capsParser.writeCapsule({type:J.WT_STREAM_WOFIN,headerVints:[i],payload:void 0}),this.capsParser.newStream(i,e||{sendGroupId:0n,sendOrder:0n})}}orderUnidiStream({sendGroup:i,sendOrder:e,waitUntilAvailable:t}){let r=this.streamIdMngrUni.canOpenNextOutgoingStream(),n=this.streamIdMngrUni.isMaxStreamSet();return r||t||!n?(this.orderUniStreams.push({sendGroupId:i?._sendGroupId||0n,sendOrder:e??0n}),this.trySendingUnidirectionalStreams(),!0):!1}trySendingBidirectionalStreams(){for(;this.orderBiStreams.length>0&&this.streamIdMngrBi.canOpenNextOutgoingStream();){let i=this.streamIdMngrBi.getNextOutgoingStreamId(),e=this.orderBiStreams.pop();this.capsParser.writeCapsule({type:J.WT_STREAM_WOFIN,headerVints:[i],payload:void 0}),this.capsParser.newStream(i,e||{sendGroupId:0n,sendOrder:0n})}}orderBidiStream({sendGroup:i,sendOrder:e,waitUntilAvailable:t}){let r=this.streamIdMngrBi.canOpenNextOutgoingStream(),n=this.streamIdMngrBi.isMaxStreamSet();return r||t||!n?(this.orderBiStreams.push({sendGroupId:i?._sendGroupId||0n,sendOrder:e??0n}),this.trySendingBidirectionalStreams(),!0):!1}orderSessionStats(){this.jsobj.onSessionStats({timestamp:0,expiredOutgoing:0n,lostOutgoing:0n,minRtt:0,smoothedRtt:0,rttVariation:0,estimatedSendRateBps:0n})}orderDatagramStats(){this.jsobj.onDatagramStats({timestamp:0,expiredOutgoing:0n,lostOutgoing:0n})}getMaxDatagramSize(){return 16384}notifySessionDraining(){}close({code:i,reason:e}){this.capsParser.sendClose({code:i,reason:e})}sendWindowUpdate(i){this.capsParser.writeCapsule({type:J.WT_MAX_DATA,headerVints:[i],payload:void 0})}reportBlocked(i){Hc("Session was blocked at:",i)}sendBlocked(i){this.capsParser.writeCapsule({type:J.WT_DATA_BLOCKED,headerVints:[i],payload:void 0})}connected(){return this.jsobj.state==="connected"}closeConnection({code:i,reason:e}){this.jsobj.onClose({errorcode:i,error:e}),this.close({code:i,reason:e})}smoothedRtt(){let i;return this.stream?i=this.stream.session?.WTrtt||25:this.ws&&(i=navigator?.connection?.rtt||25),i=Math.ceil(i/25)*25,i}canSendMaxStreams(){return!0}sendMaxStreams(i,e){this.capsParser.writeCapsule({type:e?J.WT_MAX_STREAMS_UNIDI:J.WT_MAX_STREAMS_BIDI,headerVints:[i],payload:void 0})}};var Kc=ge("webtransport:http2:browserparser");function Fe(a){if(a.offset+1>a.size)return;let i=BigInt(a.buffer[a.offset]);a.offset++;let t=1<<(Number(i)>>>6);if(!(a.offset+t-1>a.size)){i=i&0x3fn;for(let r=0;r<t-1;r++)i=i<<8n|BigInt(a.buffer[a.offset]),a.offset++;return i}}function qc(a){if(a.offset+4>a.size)return;let i=a.buffer[a.offset];return a.offset++,i=i<<8|a.buffer[a.offset],a.offset++,i=i<<8|a.buffer[a.offset],a.offset++,i=i<<8|a.buffer[a.offset],a.offset++,i}function ds(a,i){let e=8n,t=0xc0n,r=BigInt(i);r<64n?(e=1n,t=0x0n):r<16384n?(e=2n,t=0x40n):r<1073741824n&&(e=4n,t=0x80n),a.buffer[a.offset]=Number(t|r>>(e-1n)*8n&0xffn),a.offset++;for(let n=e-2n;n>=0n;n--)a.buffer[a.offset]=Number(r>>n*8n&0xffn),a.offset++}var ot=class extends J{constructor({ws:i,nativesession:e,isclient:t,initialStreamSendWindowOffsetUnidi:r,initialStreamSendWindowOffsetBidi:n,initialStreamReceiveWindowOffset:s,streamShouldAutoTuneReceiveWindow:o,streamReceiveWindowSizeLimit:d}){super({nativesession:e,isclient:t,initialStreamSendWindowOffsetUnidi:r,initialStreamSendWindowOffsetBidi:n,initialStreamReceiveWindowOffset:s,streamShouldAutoTuneReceiveWindow:o,streamReceiveWindowSizeLimit:d}),this.ws=i,this.saveddata=void 0,this.rtype=void 0,this.closesend=!1,this.ws.addEventListener("message",p=>{p.data instanceof ArrayBuffer?this.parseData(new Uint8Array(p.data,0,p.data.byteLength)):Kc("Illegal text frame",p.data)})}parseData(i){let e={offset:0,size:i.byteLength,buffer:i},t=e.size,r=Fe(e);if(typeof r>"u")return;let n=Number(r);switch(n){case J.PADDING:break;case J.WT_RESET_STREAM:case J.WT_STOP_SENDING:{let s=Fe(e);if(typeof s<"u"){let o=this.wtstreams.get(s),d=Fe(e);o&&typeof d<"u"&&(o.onStreamSignal(n===J.WT_RESET_STREAM?"resetStream":"stopSending"),o.jsobj.onStreamRecvSignal({code:Number(d),nettask:n===J.WT_RESET_STREAM?"resetStream":"stopSending"}))}}break;case J.WT_STREAM_WOFIN:case J.WT_STREAM_WFIN:{let s=Fe(e);if(typeof s<"u"){let o=this.wtstreams.get(s);if(!o&&(o=this.newStream(s,{sendOrder:0n,sendGroupId:0n}),!o))return;if(t-e.offset>=0){let d=n===J.WT_STREAM_WFIN;d&&o.onFin(),o.recvData({data:new Uint8Array(e.buffer.buffer,e.buffer.byteOffset+e.offset,t-e.offset),fin:d})}}}break;case J.WT_MAX_DATA:this.onMaxData(Fe(e));break;case J.WT_MAX_STREAM_DATA:{let s=Fe(e),o=Fe(e);typeof s<"u"&&typeof o<"u"&&this.onMaxStreamData(s,o)}break;case J.WT_MAX_STREAMS_BIDI:this.onMaxStreamBiDi(Fe(e));break;case J.WT_MAX_STREAMS_UNIDI:this.onMaxStreamUniDi(Fe(e));break;case J.WT_DATA_BLOCKED:this.onDataBlocked(Fe(e));break;case J.WT_STREAM_DATA_BLOCKED:{let s=Fe(e),o=Fe(e);typeof s<"u"&&typeof o<"u"&&this.onStreamDataBlocked(s,o)}break;case J.WT_STREAMS_BLOCKED_UNIDI:this.onStreamsBlockedUnidi(Fe(e));break;case J.WT_STREAMS_BLOCKED_BIDI:this.onStreamsBlockedBidi(Fe(e));break;case J.CLOSE_WEBTRANSPORT_SESSION:{let s=qc(e)||0,d=new TextDecoder().decode(new Uint8Array(e.buffer.buffer,e.buffer.byteOffset+e.offset,t-e.offset));this.onCloseWebTransportSession({code:s,reason:d})}break;case J.DRAIN_WEBTRANSPORT_SESSION:this.onDrain();break;case J.DATAGRAM:this.session.jsobj.onDatagramReceived({datagram:new Uint8Array(e.buffer.buffer,e.buffer.byteOffset+e.offset,t-e.offset)});break;default:}e.offset=t}writeCapsule({type:i,headerVints:e,payload:t,end:r}){let n=0;for(let u in e)n+=zn(e[u]);n+=zn(i);let s=n;t&&(n+=t.byteLength);let o=new Uint8Array(n),d={offset:0,size:o.length,buffer:o};ds(d,i);for(let u in e)ds(d,e[u]);let p=new Uint8Array(o.buffer,o.byteOffset+s);return t&&p.set(t),this.ws.send(o),r&&r(),!1}closeHttp2Stream(i){this.ws.close(1e3)}initialParametersMandatory(){return!0}};le(ot,"WS_CONTINUE",0),le(ot,"WS_TEXT",1),le(ot,"WS_BINARY",2),le(ot,"WS_CLOSE",8),le(ot,"WS_PING",9),le(ot,"WS_PONG",10);var Yn=["kDraft1","kDraft2"];var ls=ge("webtransport:http2:browser"),Hr=class{constructor(i){this.port=i?.port||443,this.hostname=i?.host||"localhost",this.protocols=i?.protocols||[],this.initialStreamFlowControlWindow=i?.initialStreamFlowControlWindow||16*1024,this.initialSessionFlowControlWindow=i?.initialSessionFlowControlWindow||16*1024,this.initialBidirectionalStreams=i?.initialBidirectionalSendStreams||100,this.initialUnidirectionalStreams=i?.initialUnidirectionalSendStreams||100,this.streamShouldAutoTuneReceiveWindow=i.streamShouldAutoTuneReceiveWindow||!0,this.streamFlowControlWindowSizeLimit=i?.streamFlowControlWindowSizeLimit||6*1024*1024,this.sessionShouldAutoTuneReceiveWindow=i.sessionShouldAutoTuneReceiveWindow||!0,this.sessionFlowControlWindowSizeLimit=i?.sessionFlowControlWindowSizeLimit||15*1024*1024,this.jsobj=void 0,this.clientInt=void 0,this._webtransportProtocol=void 0}createTransport({path:i}){try{let e="wss://"+this.hostname+":"+this.port;i&&(e=e+"/"+i);let t=Yn.map(r=>"webtransport_"+r);if(this.protocols.length>0){let r=t;t=t.filter(n=>n!=="kDraft1").map(n=>this.protocols.map(s=>n+"_"+s)).flat(1),t.push(...r)}this.clientInt=new WebSocket(e,t)}catch(e){ls("Failed on WebTransport/Websocket:",e),this.jsobj.onClientConnected({success:!1});return}this.clientInt.binaryType="arraybuffer",this.clientInt.addEventListener("open",e=>{let t=this.clientInt?.protocol;t||(this.clientInt&&this.clientInt.close(),this.jsobj.onClientConnected({success:!1}));let r=t.split("_");!(r.length===2||r.length>=3)||r[0]!=="webtransport"||!Yn.includes(r[1])?(this.clientInt&&this.clientInt.close(),this.jsobj.onClientConnected({success:!1})):(this._webtransportProtocol=r.length>=3?r.slice(2).join("_"):void 0,this.jsobj.onClientWebTransportSupport(r.length>=3?{selectedProtocol:r.slice(2).join("_")}:{}),this.jsobj.onClientConnected({success:!0}))}),this.clientInt.addEventListener("error",e=>{ls("Failed on WebTransport/Websocket:",e),!this.jsobj?.sessionobjint||this.jsobj?.sessionobjint?.state==="connecting"?this.jsobj.onClientConnected({success:!1}):this?.jsobj?.sessionobjint?.objint&&this.jsobj.sessionobjint.close({closeCode:0,reason:e.toString()})})}openWTSession(i){if(!this.clientInt)throw new Error("clientInt not present");let e,t={session:new Gr({ws:this.clientInt,isclient:!0,createParser:r=>{e=r;let n=new ot({ws:this.clientInt,nativesession:r,isclient:!0,initialStreamSendWindowOffsetBidi:0,initialStreamSendWindowOffsetUnidi:0,initialStreamReceiveWindowOffset:this.initialStreamFlowControlWindow,streamShouldAutoTuneReceiveWindow:this.streamShouldAutoTuneReceiveWindow,streamReceiveWindowSizeLimit:this.streamFlowControlWindowSizeLimit});return this.clientInt&&this.clientInt.addEventListener("close",s=>{let o=s.code,d="Session WebSocket closed";if(s.reason){let p=s.reason.split(":");p.length>1&&(o=parseInt(p[0]),p=p.slice(1)),d=p.join(":")}else switch(o){case 1001:d="Going Away";break;case 1002:d="Protocol error";break;case 1003:d="Unsupported data";break;case 1004:d="Reserved";break;case 1005:d="No Status Rcvd";break;case 1006:d="Abnormal Closure";break;case 1007:d="Invalid frame payload data";break;case 1008:d="Policy Violation";break;case 1009:d="Message Too Big";break;case 1010:d="Mandatory Ext.";break;case 1011:d="Internal error";break;case 1012:d="Service Restart";break;case 1013:d="Try Again Later";break;case 1014:d="Bad Gateway";break;case 1015:d="TLS handshake";break;case 1e3:default:d="";break}r.jsobj.onClose({errorcode:o,error:d})}),n},sendWindowOffset:0,receiveWindowOffset:this.initialSessionFlowControlWindow,shouldAutoTuneReceiveWindow:this.sessionShouldAutoTuneReceiveWindow,receiveWindowSizeLimit:this.sessionFlowControlWindowSizeLimit,initialBidirectionalSendStreams:this.initialBidirectionalStreams,initialBidirectionalReceiveStreams:this.initialBidirectionalStreams,initialUnidirectionalSendStreams:this.initialUnidirectionalStreams,initialUnidirectionalReceiveStreams:this.initialUnidirectionalStreams}),reliable:!0};this.jsobj.onHttpWTSessionVisitor(t),e.jsobj.onReady(this._webtransportProtocol?{protocol:this._webtransportProtocol}:{})}closeClient(){this.clientInt&&this.clientInt.readyState===1&&this.clientInt.close()}};var $c=ge("webtransport:browser()"),ps=!1,us=!1;if(globalThis.WebTransport){us=!0;try{let a=new WebTransport("https://127.0.0.1:23333/test",{serverCertificateHashes:[]});a.ready.then(()=>{try{a.close()}catch{}}).catch(()=>{})}catch(a){a?.name==="NotSupportedError"&&($c("serverCertificateHashesNotSupported"),ps=!0)}}var Kr=class extends Mr{startUpConnection({client:i,sessionint:e,ourl:t}){let r=t.pathname+(t.search??"");i.handleConnection({createTransport:!0,path:r}).then(()=>i.createWTSession(e,r)).catch(n=>{i.closeHookSession(),e.readyReject(n),e.closedReject(n)})}get supportsReliableOnly(){return!0}createClient(i){this.curtype="websocket";let e=new Ur({createReliableClient:r=>new Hr({...i}),...i}),t=new Lr({parentobj:e});return{client:e,sessionint:t}}},Ui=class{constructor(i,e){this.curtype="native",this.closeset=!1,this.allowFallback=!0,this.initiatedFallback=!1,this.args=e,this.closed=new Promise((r,n)=>{this.closeRes=r,this.closeRej=n}),this.ready=new Promise((r,n)=>{this.readyRes=r,this.readyRej=n}),this.draining=new Promise((r,n)=>{this.drainingRes=r,this.drainingRej=n});let t=()=>{this.initiatedFallback=!0,this.curtype="websocket",this.curtransport=new Kr(i,e),this.curtransport.ready.then(r=>this.readyRes(r)).catch(r=>this.readyRej(r)),this.curtransport.closed.then(r=>this.closeRes(r)).catch(r=>this.closeRej(r)),this.curtransport.draining.then(r=>this.drainingRes(r)).catch(r=>this.drainingRej(r))};us&&(!e?.serverCertificateHashes||!ps)?(this.curtransport=new WebTransport(i,e),setTimeout(()=>{if(this.allowFallback&&!this.closeset&&!this.initiatedFallback&&!this.curtransport?.supportsReliableOnly){let r=this.curtransport;r&&r.ready.then(async()=>{r.close()}).catch(()=>{}),t()}},2e3),this.curtransport.ready.then(r=>{this.allowFallback=!1,this.readyRes(r)}).catch(r=>{this.allowFallback&&!this.closeset?!this.initiatedFallback&&!this.curtransport?.supportsReliableOnly&&t():this.readyRej(r)}),this.curtransport.closed.then(r=>{this.curtype==="native"&&this.closeRes(r)}).catch(r=>{this.allowFallback&&!this.closeset?!this.initiatedFallback&&!this.curtransport?.supportsReliableOnly&&t():this.closeRej(r)}),this.curtransport.draining&&this.curtransport.draining.then(r=>{this.curtype==="native"&&this.drainingRes(r)}).catch(r=>{this.curtype==="native"&&this.drainingRej(r)})):t(),this.datagrams={get writable(){return this.datagramwritablepolyfilled_||console.warn("datagrams.writable is deprecated"),this.datagramwritablepolyfilled_||(this.datagramwritablepolyfilled_=this.createWritable())}},Object.defineProperties(this.datagrams,{maxDatagramSize:{get:()=>this.curtransport.datagrams.maxDatagramSize}}),this.datagrams.readable=new ReadableStream({start:async r=>{await this.ready,this.datagramsReader=this.curtransport.datagrams.readable.getReader()},pull:async r=>{let{value:n,done:s}=await this.datagramsReader.read();n&&r.enqueue(n),s&&r.close()},cancel:async r=>{await this.datagramsReader.cancel(r)}}),this.datagrams.createWritable=r=>{if(this.curtransport.datagrams.createWritable)return this.curtransport.datagrams.createWritable(r);if(!this.curtransport.datagrams.writable)throw new Se("No way to send out datagrams");let n=r?.sendOrder,s=r?.sendGroup,o=new WritableStream({start:async d=>{await this.ready,this.datagramsWriter||(this.datagramsWriter=this.curtransport.datagrams.writable.getWriter())},write:async(d,p)=>{await this.datagramsWriter.write(d)},abort:async d=>{await this.datagramsWriter.abort(d)},close:async()=>{await this.datagramsWriter.close()}});return Object.defineProperties(o,{sendOrder:{get:()=>n,set:d=>{n=d}},sendGroup:{get:()=>s,set:d=>{d!==s&&(s=d)}}}),o},this.incomingBidirectionalStreams=new ReadableStream({start:async r=>{await this.ready,this.incomingBidirectionalStreamsReader=this.curtransport.incomingBidirectionalStreams.getReader()},pull:async r=>{let{value:n,done:s}=await this.incomingBidirectionalStreamsReader.read();n&&r.enqueue(n),s&&r.close()},cancel:async r=>{await this.incomingBidirectionalStreamsReader.cancel(r)}}),this.incomingUnidirectionalStreams=new ReadableStream({start:async r=>{await this.ready,this.incomingUnidirectionalStreamsReader=this.curtransport.incomingUnidirectionalStreams.getReader()},pull:async r=>{let{value:n,done:s}=await this.incomingUnidirectionalStreamsReader.read();n&&r.enqueue(n),s&&r.close()},cancel:async r=>{await this.incomingUnidirectionalStreamsReader.cancel(r)}})}get congestionControl(){return this.curtransport?.congestionControl||void 0}get reliability(){return this.curtransport?.reliability||void 0}get supportsReliableOnly(){return!0}get protocol(){return this.curtransport?.protocol||void 0}getStats(){return this.curtransport.getStats()}close(i){this.closeset=!0,this.curtransport.close(i)}async createBidirectionalStream(i){return await this.ready,await this.curtransport.createBidirectionalStream(i)}async createUnidirectionalStream(i){return await this.ready,await this.curtransport.createUnidirectionalStream(i)}};var qe=zt(require("fflate"));var zc=63n,Jc=16383n;var Yc=4611686018427387903n,qr=class{encode(i){let e=typeof i=="number"?BigInt(i):i;if(e<=zc)return new Uint8Array([Number(e)]);if(e<=Jc)return new Uint8Array([64|Number(e>>8n),Number(e&0xffn)]);if(e<=BigInt(1073741823))return new Uint8Array([128|Number(e>>24n),Number(e>>16n&0xffn),Number(e>>8n&0xffn),Number(e&0xffn)]);if(e<=Yc)return new Uint8Array([192|Number(e>>56n),Number(e>>48n&0xffn),Number(e>>40n&0xffn),Number(e>>32n&0xffn),Number(e>>24n&0xffn),Number(e>>16n&0xffn),Number(e>>8n&0xffn),Number(e&0xffn)]);throw new RangeError("Number is too large to encode using varint")}},$r=class{decode(i){let e=this.getNumBytesForLengthInteger(i);if(e<0)throw new Error("Invalid length prefix");if(i.length<e)return null;let t=BigInt(0);switch(e){case 1:t=BigInt(i[0]&63);break;case 2:t=BigInt(i[0]&63)<<8n|BigInt(i[1]);break;case 4:t=BigInt(i[0]&63)<<24n|BigInt(i[1])<<16n|BigInt(i[2])<<8n|BigInt(i[3]);break;case 8:t=BigInt(i[0]&63)<<56n|BigInt(i[1])<<48n|BigInt(i[2])<<40n|BigInt(i[3])<<32n|BigInt(i[4])<<24n|BigInt(i[5])<<16n|BigInt(i[6])<<8n|BigInt(i[7]);break}return t}getNumBytesForLengthInteger(i){let e=i[0]&192;return e===0?1:e===64?2:e===128?4:e===192?8:-1}};var zr=class{constructor(i){this.encoder=new TextEncoder,this.lengthEncoder=new qr,this.compression=i??null}encode(i){let e=this.encoder.encode(i);e=this.compress(e);let t=this.lengthEncoder.encode(e.length),r=new Uint8Array(t.length+e.length);return r.set(t),r.set(e,t.length),r}compress(i){if(!this.compression)return i;switch(this.compression){case"gzip":return qe.gzipSync(i);case"deflate":return qe.zlibSync(i);case"deflate-raw":return qe.deflateSync(i);default:return i}}},Jr=class{constructor(i){this.decoder=new TextDecoder,this.lengthDecoder=new $r,this.compression=i??null,this.buffer=new Uint8Array(0),this.expectedLength=null,this.offset=0}decode(i){let e=[];for(this.buffer=new Uint8Array([...this.buffer,...i]);this.buffer.length>0;){if(this.expectedLength===null){if(this.expectedLength=this.readLength(this.buffer),this.expectedLength===null)return e;this.offset=this.lengthPrefixLength}if(this.buffer.length-this.offset<this.expectedLength)return e;let t=this.buffer.subarray(this.offset,this.offset+this.expectedLength);t=this.decompress(t),e.push(this.decoder.decode(t)),this.buffer=this.buffer.subarray(this.offset+this.expectedLength),this.expectedLength=null,this.offset=0}return e}readLength(i){if(i.length===0)return 0;if(this.lengthPrefixLength=this.lengthDecoder.getNumBytesForLengthInteger(i),this.lengthPrefixLength<0)throw new Error("Invalid length prefix");let e=this.lengthDecoder.decode(i.subarray(0,this.lengthPrefixLength));return e===null?null:Number(e)}decompress(i){if(!this.compression)return i;switch(this.compression){case"gzip":return qe.gunzipSync(i);case"deflate":return qe.unzlibSync(i);case"deflate-raw":return qe.inflateSync(i);default:return i}}};var ui=class{constructor(i,e={}){this.stream=null;this.writer=null;this.reader=null;this.onopen=null;this.onmessage=null;this.onerror=null;this.onclose=null;this.readyState=WebSocket.CONNECTING;this.url=i,this.options=e,this.readyState=WebSocket.CONNECTING,this.compression=this.getCompressionTypeFromUrl(i),this.encoder=new zr(this.compression),this.decoder=new Jr(this.compression),this.connect()}getCompressionTypeFromUrl(i){try{let t=new URL(i).searchParams.get("compression");switch(t){case"gzip":case"deflate":case"deflate-raw":return t;default:return null}}catch(e){return c.log("Exception while parsing compression",e),null}}async connect(){try{this.webTransport=new Ui(this.url,{...this.options}),await this.webTransport.ready,c.debug("[WebTransport] WebTransport connected to "+this.url),this.stream=await this.webTransport.createBidirectionalStream(),this.writer=this.stream.writable.getWriter(),this.reader=this.stream.readable.getReader(),this.readyState=WebSocket.OPEN,this.onopen?.(new Event("open")),await this.readLoop()}catch(i){c.error("[WebTransport] WebTransport connection failed. This will cause fallback to WebSocket",i),this.readyState=WebSocket.CLOSED,this.onerror?.(new Event("error")),this.onclose?.(new CloseEvent("close",{code:1006,reason:"Connection Failed"}))}}async readLoop(){if(this.reader)try{for(;;){let{done:i,value:e}=await this.reader.read();if(i){this.close(1e3,"Stream Closed");break}e&&this.decoder.decode(e).forEach(r=>{this.onmessage?.(new MessageEvent("message",{data:r}))})}}catch(i){c.error("[WebTransport] Stream read failed",i),this.readyState=WebSocket.CLOSED,this.onerror?.(new Event("error"))}}async send(i){if(this.readyState!==WebSocket.OPEN){c.warn("[WebTransport] Attempt to send data before webtransport is open");return}if(!this.writer){c.warn("[WebTransport] Attempt to send data before stream is ready");return}try{await this.writer.ready;let e=this.encoder.encode(i);await this.writer.write(e)}catch(e){c.error("[WebTransport] Failed to send data",e),this.onerror?.(new Event("error")),this.close(1006,"Failed to send data")}}close(i=1e3,e){if(!(this.readyState===WebSocket.CLOSED||this.readyState===WebSocket.CLOSING)){this.readyState=WebSocket.CLOSING,this.reader?.cancel();try{this.webTransport.close()}catch(t){c.warn("[WebTransport] already closed. Did we get a STOP_SENDING? ignore",t)}this.readyState=WebSocket.CLOSED,this.onclose?.(new CloseEvent("close",{code:i,reason:e})),this.webTransport.closed.then(()=>{this.writer=null,this.reader=null,this.stream=null})}}static isBrowserSupported(){return P.browserName()==="Firefox"?l.webtransportFF:P.browserName()!=="Safari"}};var hs="open",ms=[()=>l.producerScreenTrack,()=>l.videoTracksCount>0,()=>!0,()=>!0,()=>l.consumerScreenTrack,()=>!0,()=>l.movieShare,()=>l.useParticipantListChunk,()=>l.useRooms,()=>!!l.vmoji,()=>l.useCallsToContacts,()=>l.useChatRooms],Qc=10,Xc=["service-unavailable","conversation-ended","invalid-token"];var fs={connected:{wt:T.WEBTRANSPORT_CONNECTED,ws:T.WEBSOCKET_CONNECTED},reconnected:{wt:T.WEBTRANSPORT_RECONNECTED,ws:T.WEBSOCKET_RECONNECTED},failed_pings:{wt:T.WEBTRANSPORT_FAILED_PINGS,ws:T.WEBSOCKET_FAILED_PINGS},failed_exception:{wt:T.WEBTRANSPORT_FAILED_EXCEPTION,ws:T.WEBSOCKET_FAILED_EXCEPTION},timeout:{wt:T.WEBTRANSPORT_TIMEOUT,ws:T.WEBSOCKET_TIMEOUT},restart:{wt:T.WEBTRANSPORT_RESTART,ws:T.WEBSOCKET_RESTART}},Oe=class Oe extends Ti{constructor(){super(...arguments);this.socket=null;this.sequence=1;this.lastStamp=0;this.websocketCommandsQueue=[];this.datachannelCommandsQueue=[];this.incomingCache=[];this.responseHandlers={};this.reconnectCount=0;this.wtEndpoint=null;this.conversationResolve=null;this.conversationReject=null;this.connected=!1;this.listenersReady=!1;this.postfix="&platform="+l.platform+"&appVersion="+l.appVersion+"&version="+l.protocolVersion+"&device="+l.device+"&capabilities="+Oe._getCapabilityFlags();this.peerId=null;this.conversationId=null;this.reconnectTimer=0;this.connectionMessageWaitTimer=0;this.doctorTimer=0;this.participantIdRegistry=null;this.producerNotificationDataChannel=null;this.producerCommandDataChannel=null;this.producerCommandDataChannelEnabled=!1;this.producerCommandSerializationService=new wr}static _getCapabilityFlags(){let e=0;for(let t=0;t<ms.length;t++)ms[t]()&&(e|=1<<t);return e.toString(16).toUpperCase()}get ready(){return this.socket!==null}setEndpoint(e){this.endpoint=e}setWebTransportEndpoint(e){this.wtEndpoint=e}setConversationId(e){this.conversationId=e}setParticipantIdRegistry(e){this.participantIdRegistry=e,this.producerCommandSerializationService.setParticipantIdRegistry(e)}setProducerNotificationDataChannel(e){this.producerNotificationDataChannel=e,this.producerNotificationDataChannel.onmessage=t=>{let r=this.participantIdRegistry?.handleMessage(t.data);r&&this._handleMessage(r)}}setProducerCommandDataChannel(e){this.producerCommandDataChannel=e,this.producerCommandDataChannel.onmessage=t=>{this.producerCommandSerializationService.deserializeCommandResponse(t.data).then(r=>{r&&this._handleMessage(r)}).catch(r=>{c.warn("[signaling] cannot parse message at producerCommandDataChannel",r)})},this._handleCommandsQueue(this.datachannelCommandsQueue)}useCommandDataChannel(e){this.producerCommandDataChannelEnabled=e}cleanup(){this.datachannelCommandsQueue=[],this.incomingCache=[]}async connect(e){return this.postfix+=`&clientType=${l.clientType}`,new Promise((t,r)=>{if(this.socket&&this.socket.readyState<WebSocket.CLOSING){R.log(T.SOCKET_ACTION,"already_opened"),r(Error("Socket already opened"));return}this.conversationResolve=n=>{t(n),this.conversationResolve=null,this.conversationReject=null},this.conversationReject=n=>{r(n),this.conversationResolve=null,this.conversationReject=null},this._connect(e,this.isWebTransportAvailable())})}async _send(e,t={},r=!0,n=0){if(t.participantId){let s=I.decomposeParticipantId(t.participantId),o=I.decomposeId(s.compositeUserId);t=Object.assign({},t,{participantId:o.id,participantType:o.type}),s.deviceIdx&&(t.deviceIdx=s.deviceIdx)}return this._sendRaw(e,t,r,n)}async _sendRaw(e,t={},r=!0,n=0){let s=o=>{if(this._isDataChannelCommand(e))this.datachannelCommandsQueue.push(o),this.producerCommandDataChannel?.readyState===hs&&this._handleCommandsQueue(this.datachannelCommandsQueue);else{if(!this.socket){R.log(T.SOCKET_ACTION,"not_opened"),c.warn("[signaling] socket is not opened"),o.reject(new Error(`Socket not opened [${e}]`),!0);return}this.socket.readyState>WebSocket.OPEN&&(R.log(T.SOCKET_ACTION,"invalid_state"),c.warn(`[signaling] socket is not opened, state ${this.socket.readyState}`)),this.websocketCommandsQueue.push(o),this.socket&&this.socket.readyState===WebSocket.OPEN&&this._handleCommandsQueue(this.websocketCommandsQueue)}};return new Promise((o,d)=>{let p=(h,g=!1)=>{!n||g?d(h):(c.debug("[signaling] resending a signaling message",e,u.sequence),n--,s(u))},u={sequence:this.sequence++,name:e,params:t,responseTimer:0,needResponse:r,resolve:o,reject:p};s(u)})}_isDataChannelCommand(e){return this.producerCommandDataChannelEnabled?e===x.UPDATE_DISPLAY_LAYOUT||e===x.REPORT_PERF_STAT||e===x.REPORT_SHARING_STAT||e===x.REQUEST_ASR||e===x.ENABLE_VIDEO_SUSPEND||e===x.ENABLE_VIDEO_SUSPEND_SUGGEST||e===x.REPORT_NETWORK_STAT||e===x.CHANGE_SIMULCAST:!1}getNextCommandSequenceNumber(){return this.sequence}async hangup(e){return this._send(x.HANGUP,{reason:e}).catch(()=>{})}async sendCandidate(e,t){return this._send(x.TRANSMIT_DATA,{participantId:e,data:{candidate:t}},!1)}async requestTestMode(e,t){return this._send(x.REQUEST_TEST_MODE,{consumer:e,producer:t})}async sendSdp(e,t,r){let n=Object.assign({sdp:t},r);return this._send(x.TRANSMIT_DATA,{participantId:e,data:n})}async acceptCall(e){return this._send(x.ACCEPT_CALL,{mediaSettings:e})}async changeMediaSettings(e){return this._send(x.CHANGE_MEDIA_SETTINGS,{mediaSettings:e},!0,Qc)}async changeParticipantState(e,t){let r={participantState:{state:e}};return t&&(r.participantId=t),this._sendRaw(x.CHANGE_PARTICIPANT_STATE,r)}async putHandsDown(){return this._send(x.PUT_HANDS_DOWN)}async addParticipant(e,t){return this._send(x.ADD_PARTICIPANT,{externalIds:e,...t})}async addParticipantLegacy(e,t){return this._send(x.ADD_PARTICIPANT,{participantIds:e,...t})}async removeParticipant(e,t=!1){return this._send(x.REMOVE_PARTICIPANT,{participantId:e,ban:t})}async allocateConsumer(e,t){let r={capabilities:t};return e&&(r.description=e.sdp),this._send(x.ALLOCATE_CONSUMER,r)}async acceptProducer(e,t){let r={description:e.sdp};return t&&(r.ssrcs=t),this._send(x.ACCEPT_PRODUCER,r)}async changePriorities(e){return this._send(x.CHANGE_STREAM_PRIORITIES,{typedPriorities:e}).catch(()=>{})}async updateDisplayLayout(e){return this._send(x.UPDATE_DISPLAY_LAYOUT,e)}async addMovie(e){return this._send(x.ADD_MOVIE,e)}async updateMovie(e){return this._send(x.UPDATE_MOVIE,e)}async removeMovie(e){return this._send(x.REMOVE_MOVIE,e)}startUrlSharing(e){return this._send(x.START_URL_SHARING,{sharedUrl:e})}stopUrlSharing(){return this._send(x.STOP_URL_SHARING)}async updateRooms(e,t){return this._send(x.UPDATE_ROOMS,{rooms:e,assignRandomly:t})}async activateRooms(e,t){return this._send(x.ACTIVATE_ROOMS,{roomIds:e,deactivate:t})}async switchRoom(e,t){return this._sendRaw(x.SWITCH_ROOM,{toRoomId:e,participantId:t})}async getRooms(e){return this._sendRaw(x.GET_ROOMS,{withParticipants:e})}async removeRooms(e){return this._send(x.REMOVE_ROOMS,{roomIds:e})}async startStream(e){return this._send(x.RECORD_START,e)}async stopStream(e={roomId:null}){return this._send(x.RECORD_STOP,e)}async publishStream(e={roomId:null}){return this._send(x.RECORD_PUBLISH,e)}async recordSetConf(e={hideParticipantCount:!1,roomId:null}){let t={options:{hideParticipantCount:e.hideParticipantCount},roomId:e.roomId};return e.king&&(t.king=e.king),e.pawns?.length&&(t.pawns=e.pawns.join(",")),this._send(x.RECORD_SET_CONF,t)}async getRecordStatus(){return this._send(x.RECORD_GET_STATUS)}async switchTopology(e,t=!1){return this._send(x.SWITCH_TOPOLOGY,{topology:e,force:t})}async requestRealloc(){return this._send(x.REQUEST_REALLOC)}async reportPerfStat(e){return this._send(x.REPORT_PERF_STAT,e)}async reportSharingStat(e){return this._send(x.REPORT_SHARING_STAT,e,!1)}async reportNetworkStat(e){return this._send(x.REPORT_NETWORK_STAT,e,!1)}async chatMessage(e,t=null){return this._send(x.CHAT_MESSAGE,{message:e,participantId:t})}async chatHistory(e){return this._send(x.CHAT_HISTORY,{count:e})}async customData(e,t){return this._send(x.CUSTOM_DATA,{data:e,participantId:t})}async grantRoles(e,t,r){let n={participantId:e,roles:t};return r&&(n.revoke=!0),this._sendRaw(x.GRANT_ROLES,n)}async muteParticipant(e,t,r,n=null){return this._sendRaw(x.MUTE_PARTICIPANT,{participantId:e,muteStates:t,requestedMedia:r,roomId:n})}async enableFeatureForRoles(e,t){return this._sendRaw(x.ENABLE_FEATURE_FOR_ROLES,{feature:e,roles:t})}async pinParticipant(e,t,r){let n={participantId:e,roomId:r};return t&&(n.unpin=!0),this._sendRaw(x.PIN_PARTICIPANT,n)}async updateMediaModifiers(e){return this._send(x.UPDATE_MEDIA_MODIFIERS,{mediaModifiers:e})}async enableVideoSuspend(e){return this._send(x.ENABLE_VIDEO_SUSPEND,{enabled:e},!1)}async enableVideoSuspendSuggest(e){return this._send(x.ENABLE_VIDEO_SUSPEND_SUGGEST,{enabled:e},!1)}async changeSimulcast(e){return this._send(x.CHANGE_SIMULCAST,e,!1)}async changeOptions(e){return this._send(x.CHANGE_OPTIONS,{options:e})}async getWaitingHall(e=null,t,r=!1){let n={};return e&&(n.fromId=e),t&&(n.count=t),r&&(n.backward=r),this._send(x.GET_WAITING_HALL,n)}async promoteParticipant(e,t=!1){let r={};return e&&(r.participantId=e),t&&(r.demote=t),this._sendRaw(x.PROMOTE_PARTICIPANT,r)}async requestPromotion(e=!1){let t={};return e&&(t.unrequest=e),this._send(x.REQUEST_PROMOTION,t)}async acceptPromotion(e=!1){let t={};return e&&(t.reject=e),this._send(x.ACCEPT_PROMOTION,t)}async feedback(e){return this._sendRaw(x.FEEDBACK,{key:e})}async getHandQueue(){return this._send(x.GET_HAND_QUEUE)}close(){this.socket&&this.socket.readyState<WebSocket.CLOSING&&this._closeSocket(),this._stopWaitConnectionMessage(),this._stopDoctor(),clearTimeout(this.reconnectTimer)}readyToSend(e=!0){this.listenersReady=e,this._handleCachedMessages()}async getParticipantListChunk(e){return this._send(x.GET_PARTICIPANT_LIST_CHUNK,e)}async getParticipants(e){return this._send(x.GET_PARTICIPANTS,{externalIds:e})}getPeerId(){return this.peerId}async startAsr(e){return this._send(x.ASR_START,e)}async stopAsr(e){return this._send(x.ASR_STOP,e)}async requestAsr(e){return this._send(x.REQUEST_ASR,{request:e},!1)}_connect(e,t){if(this.socket&&this.socket.readyState<WebSocket.CLOSING)return;this.connectionType=e;let r="";e&&(r+=`&tgt=${e}`),e===Ke.RETRY&&this.lastStamp&&(r+=`&recoverTs=${this.lastStamp}`),r=n(r),t?(r+="&compression=deflate-raw",c.debug("[signaling] connecting to wt "+this.wtEndpoint+this.postfix+r),this.socket=new ui(this.wtEndpoint+this.postfix+r)):(c.debug("[signaling] connecting to ws "+this.endpoint+this.postfix+r),this.socket=new WebSocket(this.endpoint+this.postfix+r)),this._markTransportStat(e===Ke.RETRY?"reconnected":"connected"),this.socket.onopen=this._onOpen.bind(this),this.socket.onmessage=this._onMessage.bind(this),this.socket.onerror=this._onError.bind(this),this.socket.onclose=this._onClose.bind(this),this._startDoctor();function n(s){if(!l.useParticipantListChunk)return s;let o=l.participantListChunkInitIndex;s+=`&partIdx=${o}`;let d=l.participantListChunkInitCount;return d!==null&&(s+=`&partCount=${d}`),s}}_disconnect(e){this.socket&&this.socket.readyState<WebSocket.CLOSING&&(this.socket.onopen=null,this.socket.onmessage=null,this.socket.onerror=null,this.socket.onclose=null,this.socket.close(e),this.socket=null),this._stopWaitConnectionMessage(),this._stopDoctor(),clearTimeout(this.reconnectTimer)}_onOpen(){c.debug("[signaling] socket opened"),R.log(T.SOCKET_ACTION,"opened"),this._waitConnectionMessage(),this._startDoctor(),this._logTransportStat(this.connectionType===Ke.RETRY?"reconnected":"connected")}_onMessage(e){if(this._startDoctor(),e.data==="ping"){this._markTransportStat("failed_pings"),E.onSignalingMessage(e.data),this.socket&&this.socket.readyState===WebSocket.OPEN&&this.socket.send("pong");return}try{let t=JSON.parse(e.data);E.onSignalingMessage(t),this._handleMessage(t)}catch(t){R.log(T.SOCKET_ACTION,"parse_error"),c.error("[signaling] unable to parse message",t,e.data)}}_handleMessage(e){switch(e.type){case"notification":e.notification==="connection"?(c.debug("[signaling] signaling connected",e),this.connected=!0,this.reconnectCount=0,this.endpoint=e.endpoint,e.peerId&&this.peerId!==e.peerId.id&&(this.postfix+=`&peerId=${e.peerId.id}`,this.peerId=e.peerId.id),this._stopWaitConnectionMessage(),this.conversationResolve?this.conversationResolve(e):(this._logTransportStat("restart"),this._triggerEvent(De.RECONNECT,e),e.conversation.topology&&this._triggerEvent(De.NOTIFICATION,{type:"notification",notification:L.TOPOLOGY_CHANGED,topology:e.conversation.topology})),this.lastStamp&&this._handleCachedMessages(),e.recoverMessages?.forEach(t=>{t.notification===L.ACCEPTED_CALL&&t.peerId.id===this.peerId&&t.peerId.type==="WEB_TRANSPORT"||this._handleMessage(t)}),this._handleCommandsQueue(this.websocketCommandsQueue)):!this.connected||!this.listenersReady?this.incomingCache.push(e):this._triggerEvent(De.NOTIFICATION,e);break;case"response":this._handleCommandResponse(!0,e);break;case"error":this._handleErrorMessage(e);break;default:R.log(T.SOCKET_ACTION,"unknown_message"),c.warn("[signaling] unhandled message",e)}this.lastStamp=e.stamp||this.lastStamp}_handleErrorMessage(e){R.log(T.SOCKET_ACTION,`error-${e.error}`);let t=e.error?Xc.includes(e.error):!1;switch(c.debug(`[signaling] error message [${e.sequence}]`,e),e.sequence&&this.responseHandlers[e.sequence]&&this._handleCommandResponse(!1,e),e.error){case"service-unavailable":this._reconnect();break;case"conversation-ended":this.conversationReject?this.conversationReject(new G(e.reason||re.SIGNALING_FAILED,{message:`Conversation ended: ${e.error}`,remote:!0})):this._triggerEvent(De.NOTIFICATION,{notification:L.CLOSED_CONVERSATION,reason:e.reason});break;case"participant-not-found":case"invalid-token":this._throwError(new Error(`Signaling error: ${e.error}`));break;default:if(!t)break;this.connected?this._throwError(new Error(`Signaling error: ${e.error}`)):e.sequence||(this.conversationReject?.(new G(e.reason||re.SIGNALING_FAILED,{message:`Unable to connect to the signaling: ${e.error}`,remote:!0})),this._closeSocket())}}_handleCachedMessages(){let e=[...this.incomingCache];for(this.incomingCache=[];e.length>0;){let t=e.shift();this._handleMessage(t)}}_throwError(e){this._triggerEvent(De.FAILED,e)}_onError(e){R.log(T.SOCKET_ACTION,"error"),c.error("[signaling] signaling error",e),this._logTransportStat("failed_exception",{string_value:JSON.stringify(e)})}_onClose(e){R.log(T.SOCKET_ACTION,"closed"),c.debug("[signaling] connection closed",{code:e.code,reason:e.reason}),this.connected=!1,this._stopDoctor(),this.socket&&this.reconnectCount++<Oe.RECONNECT_MAX_COUNT?this._reconnect():this.socket&&this._closeSocket(new Error("Connection closed"))}_closeSocket(e=null){this.socket&&(this._disconnect(),Object.values(this.responseHandlers).forEach(t=>{window.clearTimeout(t.responseTimer),e&&t.reject(new Error("Connection closed"),!0)}),this.websocketCommandsQueue=[],this.responseHandlers={},this.lastStamp=0,e&&this._throwError(new Error("Connection closed")))}_reconnect(){let e=Math.min(Oe.RECONNECT_MAX_DELAY,Oe.RECONNECT_DELAY*Math.pow(2,this.reconnectCount-1));c.log(`[signaling] reconnect websocket after ${e}ms (${this.reconnectCount})`),R.log(T.SOCKET_ACTION,"reconnect"),this.reconnectTimer=window.setTimeout(this._connect.bind(this,Ke.RETRY,!1),e)}_handleCommandResponse(e,t){if(!this.responseHandlers.hasOwnProperty(t.sequence))return;let r=this.responseHandlers[t.sequence];window.clearTimeout(r.responseTimer),c.debug(`[signaling] command response [${t.sequence}]`,t),e?(delete this.responseHandlers[t.sequence],r.resolve(t)):t.type==="error"?(delete this.responseHandlers[t.sequence],R.log(T.SOCKET_ACTION,"response-error"),r.reject(new Error(t.error||`Response error [${r.name}]`),!0)):this.socket?.readyState===WebSocket.OPEN?(delete this.responseHandlers[t.sequence],R.log(T.SOCKET_ACTION,"response-timeout"),r.reject(new Error(t.error||`Response timeout [${r.name}]`))):r.responseTimer=window.setTimeout(()=>this._handleCommandResponse(e,t),Oe.WAIT_RESPONSE_DELAY)}_handleCommandsQueue(e){for(;e.length>0;){let t=e.shift();if(c.debug(`[signaling] command send [${t.sequence}]`,`'${t.name}'`,t.params),this._isDataChannelCommand(t.name)){if(this.producerCommandDataChannel?.readyState!==hs){t.reject(new Error(`Invalid data channel state: ${this.producerCommandDataChannel?.readyState}`));return}this._startResponseTimer(t);let r=this._serializeBinary(t);r!==null&&this.producerCommandDataChannel.send(r)}else{if(!this.socket||this.socket.readyState!==WebSocket.OPEN){t.reject(new Error("Invalid state or socket already closed"));continue}this._startResponseTimer(t),this.socket.send(this._serializeJson(t))}}}_startResponseTimer(e){if(!e.needResponse){e.resolve({type:"response",sequence:e.sequence,response:e.name});return}e.responseTimer=window.setTimeout(()=>this._handleCommandResponse(!1,{response:e.name,sequence:e.sequence,type:"timeout"}),Oe.WAIT_RESPONSE_DELAY),this.responseHandlers[e.sequence]=e}_serializeBinary(e){switch(e.name){case x.UPDATE_DISPLAY_LAYOUT:return this.producerCommandSerializationService.serializeUpdateDisplayLayout(e.sequence,e.params);case x.REPORT_PERF_STAT:return this.producerCommandSerializationService.serializePerfStatReport(e.sequence,e.params);case x.REPORT_SHARING_STAT:return this.producerCommandSerializationService.serializeSharingStatReport(e.sequence,e.params);case x.REQUEST_ASR:return this.producerCommandSerializationService.serializeRequestAsr(e.sequence,e.params);case x.REPORT_NETWORK_STAT:return this.producerCommandSerializationService.serializeNetworkStatReport(e.sequence,e.params);case x.ENABLE_VIDEO_SUSPEND:return this.producerCommandSerializationService.serializeEnableVideoSuspend(e.sequence,e.params);case x.ENABLE_VIDEO_SUSPEND_SUGGEST:return this.producerCommandSerializationService.serializeEnableVideoSuspendSuggest(e.sequence,e.params);case x.CHANGE_SIMULCAST:return this.producerCommandSerializationService.serializeChangeSimulcast(e.sequence,e.params)}return c.warn("[signaling] cannot get binary data for data channel command: "+e.name),null}_serializeJson(e){let t;e.name===x.UPDATE_DISPLAY_LAYOUT?t=this._convertDisplayLayout(e.params):t=e.params;let r=Object.assign({command:e.name,sequence:e.sequence},t);return JSON.stringify(r)}_convertDisplayLayout(e){let t=e,r={};for(let n in t)t.hasOwnProperty(n)&&(r[n]=Ga(t[n]));return{layouts:r}}_waitConnectionMessage(){this.connectionMessageWaitTimer=window.setTimeout(()=>{this.conversationReject&&this.conversationReject(new G(re.SIGNALING_FAILED,{message:"Unable to connect to the signaling: connection timeout",remote:!0}))},Oe.WAIT_CONNECTION_DELAY)}_stopWaitConnectionMessage(){window.clearTimeout(this.connectionMessageWaitTimer),this.connectionMessageWaitTimer=0}_startDoctor(){this._stopDoctor(),this.doctorTimer=window.setTimeout(()=>{this.isWebTransportAvailable()?c.warn("[signaling] socket is dead. Fallback to WebSocket. Trying to connect"):c.warn("[signaling] socket is dead, trying to reconnect"),this._logTransportStat("failed_pings"),this._disconnect(4e3),this._connect(Ke.RETRY,!1)},Oe.WAIT_MESSAGE_DELAY)}_stopDoctor(){window.clearTimeout(this.doctorTimer),this.doctorTimer=0}isWebTransportAvailable(){return ui.isBrowserSupported()&&this.wtEndpoint!==null&&l.webtransport}_getSocketType(){return this.socket instanceof ui?"wt":"ws"}_markTransportStat(e){let t=this._getSocketType(),r=fs[e][t];Je(r)}_logTransportStat(e,t){let r=this._getSocketType(),n=fs[e][r];Me.logEventualStat({name:n,...t})}};Oe.RECONNECT_DELAY=l.signalingReconnectDelay,Oe.RECONNECT_MAX_DELAY=l.signalingReconnectMaxDelay,Oe.RECONNECT_MAX_COUNT=l.signalingReconnectMaxCount,Oe.WAIT_CONNECTION_DELAY=l.waitConnectionDelay,Oe.WAIT_RESPONSE_DELAY=l.waitResponseDelay,Oe.WAIT_MESSAGE_DELAY=l.waitMessageDelay;var jt=Oe;var gs=(t=>(t.INCOMING="INCOMING",t.OUTGOING="OUTGOING",t.JOINING="JOINING",t))(gs||{}),Ne=gs;var _s=(t=>(t.USER="USER",t.GROUP="GROUP",t.CHAT="CHAT",t))(_s||{}),ct=_s;var Ss=(e=>(e.ATTENDEE="ATTENDEE",e.HAND_UP="HAND_UP",e))(Ss||{}),Yr=Ss;var vs=(t=>(t.ADD_PARTICIPANT="ADD_PARTICIPANT",t.RECORD="RECORD",t.MOVIE_SHARE="MOVIE_SHARE",t))(vs||{}),Qr=vs;var Is=(s=>(s.REQUIRE_AUTH_TO_JOIN="REQUIRE_AUTH_TO_JOIN",s.AUDIENCE_MODE="AUDIENCE_MODE",s.WAITING_HALL="WAITING_HALL",s.ASR="ASR",s.FEEDBACK="FEEDBACK",s.RECURRING="RECURRING",s))(Is||{}),Wt=Is;function Es(a,i){if(a.length!==i.length)return!1;for(let e of a)if(!i.includes(e))return!1;return!0}function Ts(a,i){let e=new Set(a);for(let[t,r]of Object.entries(i))r?e.add(t):e.delete(t);return Array.from(e)}var bs=(t=>(t.UNMUTE="UNMUTE",t.MUTE="MUTE",t.MUTE_PERMANENT="MUTE_PERMANENT",t))(bs||{}),We=bs;var Cs=(r=>(r.CALLED="CALLED",r.ACCEPTED="ACCEPTED",r.REJECTED="REJECTED",r.HUNGUP="HUNGUP",r))(Cs||{}),Y=Cs;var Rs=(r=>(r.UPDATE="UPDATE",r.REMOVE="REMOVE",r.ACTIVATE="ACTIVATE",r.TIMEOUT="TIMEOUT",r))(Rs||{}),hi=Rs;var ys=(e=>(e.AUDIO_MIX="audio-mix",e.PARTICIPANT_AGNOSTIC_TRACK_PREFIX="pat",e))(ys||{}),et=ys;var Ps=(e=>(e.NO_AVAILABLE_TRACKS="no-available-tracks",e.UNKNOWN_ERROR="unknown-error",e))(Ps||{}),ws=Ps;function Ms(a){switch(a){case 1:return"no-available-tracks";default:return"unknown-error"}}var As=(e=>(e.CREATOR="CREATOR",e.ADMIN="ADMIN",e))(As||{}),ht=As;function Bi(a,i){if(a.length!==i.length)return!1;for(let e of a)if(!i.includes(e))return!1;return!0}var Xr=(t=>(t.USER="USER",t.ANONYM="ANONYM",t.GROUP="GROUP",t))(Xr||{}),q;(u=>{function a(h){return h.length?typeof h[0]=="object"?h:h.map(g=>i(g)):[]}u.fromIds=a;function i(h,g="USER",b=0){return{id:h,type:g,deviceIdx:b}}u.fromId=i;function e(h,g=!0){let b=g?h.decorativeExternalUserId:h.externalId,w=h.deviceIdx??0;if(b)return t(b,w)}u.fromSignalingParticipant=e;function t(h,g=0){return{id:h.id,type:h.type==="ANONYM"?"ANONYM":"USER",deviceIdx:g}}u.fromSignaling=t;function r(h){return h.id}u.toSignaling=r;function n(h){let g=h.deviceIdx||0;return`{"id":"${h.id}","type":"${h.type}","deviceIdx":${g}}`}u.toString=n;function s(h,g="USER",b=0){return n(i(h,g,b))}u.fromIdToString=s;function o(h){try{return JSON.parse(h)}catch{throw new Error(`Failed to parse ExternalId from string '${h}'`)}}u.fromString=o;function d(h,g){return h.id===g.id&&h.type===g.type&&h.deviceIdx===g.deviceIdx}u.compare=d;function p(h){return h?.deviceIdx||0}u.getDeviceIdx=p})(q||(q={}));var{isObject:Ds,isObjectsEquals:Zc}=I;function Qn(a,i){return a===null||i===null?a===null&&i===null:a.maxDimension!==i.maxDimension||a.maxBitrateK!==i.maxBitrateK||a.maxFramerate!==i.maxFramerate||a.degradationPreference!==i.degradationPreference||a.scalabilityMode!==i.scalabilityMode||Ds(a.bitrates)&&Ds(i.bitrates)&&!Zc(a.bitrates,i.bitrates,!0)?!1:a.bitrates===i.bitrates}function Zr(a,i){return!(!Qn(a.camera,i.camera)||!Qn(a.screenSharing,i.screenSharing))}function Xn(a,i){return{camera:Object.assign({},a.camera,i.camera),screenSharing:Object.assign({},a.screenSharing,i.screenSharing)}}function ks(a){try{return btoa(JSON.stringify(a))}catch(i){c.warn("WaitingParticipant: failed convert to string",a,i)}return null}function Os(a){try{return JSON.parse(atob(a))}catch(i){c.warn("WaitingParticipant: failed convert from string",a,i)}return null}function xs(a,i){let e=new Uint8Array(i),t=0,r=0;for(;t<a.length&&r<i;){let n=a[t++],s=n>>4,o=n&15;if(s===15){let u;do u=a[t++],s+=u;while(u===255)}for(let u=0;u<s&&!(r>=i);u++)e[r++]=a[t++];if(t>=a.length||r>=i)break;let d=a[t]|a[t+1]<<8;if(t+=2,o===15){let u;do u=a[t++],o+=u;while(u===255)}o+=4;let p=r-d;for(let u=0;u<o&&!(r>=i);u++)e[r++]=e[p+u]}return e}var en=(a,i)=>I.objectReduce(a,(e,t,r)=>(t===i&&e.push(r),e),[]);function Ns(a){if(a.conversation?.muteStates)return a.conversation.muteStates;if(a.muteState&&a.muteOptions)return a.muteOptions.reduce((i,e)=>(i[e]=a.muteState,i),{})}function ed(a,i){switch(a){case se.AUDIO:return!!i.isAudioEnabled;case se.AUDIO_SHARING:return!!i.isAudioSharingEnabled;case se.VIDEO:return!!i.isVideoEnabled;case se.SCREEN_SHARING:return!!i.isFastScreenSharingEnabled||!!i.isScreenSharingEnabled;default:return!1}}function Ls(a,i){return I.objectReduce(a,(e,t,r)=>{switch(t){case We.MUTE:case We.MUTE_PERMANENT:{ed(r,i)||(e[r]=t);break}default:e[r]=t;break}return e},{})}function Us(a){let{muteStates:i={},mediaSettings:e}=a;return Ls(i,e)}function Bs(a,i){let e=a.conversation.participants.find(r=>I.comparePeerId(r.peerId,a.peerId));if(!e)return i;let{mediaSettings:t}=e;return Ls(i,t)}var mi=class{constructor(i){this._fixNoPacketsApplied=!1;this._fixNoPacketsChecked=!1;this._fixTooManyPacketsApplied=!1;this._fixTooManyPacketsSucceeded=!1;this._fixTooManyPacketsFailed=!1;this._toggleAudioPromise=null;this._fixNoPacketsAppliedVideo=!1;this._mediaSource=i}_fixAudioDeviceNoPackets(i){if(!(this._fixNoPacketsApplied&&this._fixNoPacketsChecked)){if(this._fixNoPacketsApplied&&!this._fixNoPacketsChecked){this._fixNoPacketsChecked=!0,R.log(T.ERROR,`audio_device_recover_${i.bandwidth?"success":"fail"}`);return}!this._fixNoPacketsApplied&&!i.bandwidth&&(this._fixNoPacketsApplied=!0,R.log(T.ERROR,"audio_device_recover"),c.log("[AudioFix] Trying to fix RV (no packets)"),this._toggleAudioPromise=this._mediaSource.toggleAudio(P.getMicrophonePermissionState()!=="denied"))}}_fixAudioDeviceTooManyPackets(i){if(this._fixTooManyPacketsSucceeded||this._fixTooManyPacketsFailed)return;let e=75,t=Date.now();if(!this._lastPacketsSentTime)i.packetsSent>0&&(this._lastPacketsSentTime=t,this._lastPacketsSent=i.packetsSent);else if(t-this._lastPacketsSentTime>500){let r=(i.packetsSent-this._lastPacketsSent)*1e3/(t-this._lastPacketsSentTime);this._lastPacketsSentTime=t,this._lastPacketsSent=i.packetsSent,this._fixTooManyPacketsApplied?r>e?(c.log("[AudioFix] Failed to fix RV"),R.log(T.ERROR,"audio_device_recover_rv_fail"),this._fixTooManyPacketsFailed=!0):t-this._fixTooManyPacketsTime>6e4&&(c.log("[AudioFix] Fixed RV"),R.log(T.ERROR,"audio_device_recover_rv_success"),this._fixTooManyPacketsSucceeded=!0):r>e&&(this._fixTooManyPacketsApplied=!0,R.log(T.ERROR,"audio_device_recover"),c.log("[AudioFix] Trying to fix RV (too many packets)"),this._mediaSource.toggleAudio(!0),this._fixTooManyPacketsTime=t)}}fix(i){if(!this._mediaSource)return;let e=i.find(t=>t.kind==="audio");e&&(this._fixAudioDeviceNoPackets(e),this._fixAudioDeviceTooManyPackets(e))}fixVideo(i){if(!this._mediaSource||this._fixNoPacketsAppliedVideo||!this._toggleAudioPromise)return;let e=i.find(t=>t.kind==="video");e&&!e.bandwidth&&(this._fixNoPacketsAppliedVideo=!0,this._toggleAudioPromise.then(()=>{this._mediaSource.getMediaSettings().isVideoEnabled&&this._mediaSource.toggleVideo(!0)}))}};var Fi=class{constructor(i){this._output=null;this._volume=1;this._features={setSinkId:!!Audio.prototype.setSinkId};this._statFirstMediaReceived=i}add(i){this.destroy(),this._output={},this._output.audioTrack=i,this._initAudioElement()}remove(i){!this._output||this._output.audioTrack!==i||this.destroy()}get volume(){return this._volume}set volume(i){this._volume=Math.max(0,Math.min(1,i)),this._output&&this._output.audioElement&&(this._output.audioElement.volume=this._volume)}_initAudioElement(){if(l.muteMode||!this._output?.audioTrack)return;let i=P.browserName()!=="Safari"||P.isMobile(),e=document.createElement(i?"audio":"video");e.muted=!1,e.volume=this._volume,e.preload="auto";let t=()=>{c.warn("[audio] Error on play audio"),E.onAutoplayError()},r=s=>{e.srcObject=new MediaStream([s]),e.load();let o=e.play();o&&o.catch(t)},n=()=>{c.debug("[audio] Recover audio playback");let s=this._output?.audioTrack;s?r(s):c.warn("[audio] Broken audio track")};e.onpause=n,e.onstalled=n,e.onerror=n,e.onloadeddata=()=>{this._statFirstMediaReceived.measure()},r(this._output.audioTrack),this._output.audioElement=e}_stopAudioElement(){this._output?.audioElement&&(this._output.audioElement.pause(),this._output.audioElement.srcObject=null),this._output?.audioTrack?.stop()}destroy(){this._output&&(this._stopAudioElement(),this._output=null)}async changeOutput(){try{if(!this._features.setSinkId)throw new Error('Feature "setSinkId" is not supported');if(!this._output?.audioElement)return;let i=P.getSavedOutput();i&&await this._output.audioElement.setSinkId?.(i.deviceId)}catch(i){throw R.log(T.ERROR,"change_output"),c.error("[audio] Output change failed",i),i}}};var td=90,id=3,Vi=class extends ne{constructor(){super(...arguments);this._lastMemoryStat={percent:0,bytes:0}}onRemoteDataStats(e,t){this._calcMemory(),e.inbound.rtps.map(r=>{let n=typeof r.userId=="string"&&t[r.userId]||null;r.userId=n?.externalId}),E.onStatistics(e,this._lastMemoryStat)}_calcMemory(){let e=window?.performance?.memory;if(!e||!e.usedJSHeapSize||!e.jsHeapSizeLimit)return;let t=Number((100*e.usedJSHeapSize/e.jsHeapSizeLimit).toFixed(2)),r=Number((e.usedJSHeapSize/1024/1024).toFixed(1));t>td?c.warn(`High memory usage: ${t}% (${r} MiB)`):(!this._lastMemoryStat.percent||Math.abs(t-this._lastMemoryStat.percent)>=id)&&(c.debug(`Memory usage: ${t}% (${r} MiB)`),this._lastMemoryStat.percent=t,this._lastMemoryStat.bytes=e.usedJSHeapSize)}};var rd=44100,Et=class{constructor(i,e){this._analyser=null;this._gainNode=null;this._fftBins=null;this._mediaStreamSource=null;this._lastSmoothedLevel=0;this._trackId=i,this._track=e,this._stream=new MediaStream([e]);try{let t=P.getAudioContext();this._gainNode=t.createGain(),this._gainNode.gain.value=1e-5,this._gainNode.connect(t.destination),this._analyser=t.createAnalyser(),this._analyser.fftSize=1024,this._analyser.smoothingTimeConstant=0,this._analyser.connect(this._gainNode),this._fftBins=new Uint8Array(this._analyser.frequencyBinCount),this._mediaStreamSource=t.createMediaStreamSource(this._stream),this._mediaStreamSource.connect(this._analyser)}catch{}}get track(){return this._track}get trackId(){return this._trackId}_getBins(){if(!this._fftBins||!this._analyser)return new Uint8Array;this._analyser.getByteFrequencyData(this._fftBins);let i=rd/this._fftBins.length,e=Math.ceil(l.voiceParams.minFreq/i),t=Math.floor(l.voiceParams.maxFreq/i);return this._fftBins.subarray(e,t)}getLevel(){let i=this._getBins(),t=i.reduce((n,s)=>n+s,0)/i.length/255,r=this._lastSmoothedLevel*l.voiceParams.smoothing+t*(1-l.voiceParams.smoothing);return this._lastSmoothedLevel=r,{real:t,smoothed:r}}destroy(){this._mediaStreamSource&&(this._mediaStreamSource.disconnect(),this._mediaStreamSource=null),this._gainNode&&(this._gainNode.disconnect(),this._gainNode=null),this._analyser&&(this._analyser.disconnect(),this._analyser=null,this._fftBins=null,this._lastSmoothedLevel=0),this._stream.removeTrack(this._track)}};var ji=class extends ne{constructor(e){super();this._detector=null;this._interval=null;let t=()=>{this._detector&&E.onLocalVolume(this._detector.getLevel().real,e.getMediaSettings().isAudioEnabled),this._interval=window.setTimeout(t,l.voiceParams.interval)};this._interval=window.setTimeout(t,l.voiceParams.interval);let r=()=>{let n=e.getSendAudioTrack();n&&this.init(n)};this.subscribe(e,"SOURCE_CHANGED",n=>{n.kind==="audio"&&e.getMediaSettings().isAudioEnabled&&r()}),this.subscribe(e,"SOURCE_READY",r),r()}init(e){this._stopDetector(),this._detector=new Et("local",e.clone())}_stopDetector(){this._detector&&(this._detector.track.stop(),this._detector.destroy(),this._detector=null)}destroy(){this.unsubscribe(),this._interval&&(window.clearTimeout(this._interval),this._interval=null),this._stopDetector()}};var Fs=(s=>(s.producerNotification="producerNotification",s.producerCommand="producerCommand",s.consumerScreenShare="consumerScreenShare",s.producerScreenShare="producerScreenShare",s.asr="asr",s.animoji="animoji",s))(Fs||{}),mt=Fs;var Tt=class Tt{constructor(){this._codecUsages=new Map;this.getCurrentTransportTopology=()=>{}}static create(i){let e=new Tt;e.getCurrentTransportTopology=i,Tt._instance=e}static reportUsage(i){let e=Tt._instance,t=e?.getCurrentTransportTopology();if(!e||!t)return;let r=i.rtps.filter(n=>n.type==="outbound-rtp"&&!n.mid?.endsWith("s"));l.simulcast&&(r=r.reduce((n,s)=>{if(s.kind!=="video")return n.concat(s);let o=n.find(d=>d.kind==="video");return o?o.totalEncodeTime=(o.totalEncodeTime??0)+(s.totalEncodeTime??0):n.push(s),n},[])),r.forEach(n=>{let s=n.kind,o=n.mimeType;if((s==="audio"||s==="video")&&o){let d=n.encoderImplementation,p=[o,"encoder",d].filter(Boolean).join("/");e.saveUsage({kind:s,codecName:p,totalEncodeTime:(n.totalEncodeTime??0)*1e3,audioCodecParams:n.sdpFmtpLine,topology:t})}})}saveUsage({kind:i,codecName:e,totalEncodeTime:t,audioCodecParams:r,topology:n}){let s=this._codecUsages.get(i);if(s&&s.codecName!==e&&this.report(s),s&&s.codecName===e){this._codecUsages.set(i,{...s,totalEncodeTime:t,topology:n});return}this._codecUsages.set(i,{kind:i,codecName:e,audioCodecParams:r,totalEncodeTime:t,topology:n})}report(i){if(i.kind==="video"&&i.totalEncodeTime===0)return;let e={name:T.CODEC_USAGE,codec_implementation:i.codecName,value:i.totalEncodeTime,call_topology:i.topology==="DIRECT"?"D":"S"};i.audioCodecParams&&(e.string_value=i.audioCodecParams),R.logClientStats(e)}static destroy(){Tt._instance?._destroy(),Tt._instance=null}_destroy(){this._codecUsages.forEach(i=>{this.report(i)}),this._codecUsages.clear()}};Tt._instance=null;var dt=Tt;var Gt=class extends ne{constructor(e,t){super();this._state="IDLE";this._pc=null;this._signaling=e,this._mediaSource=t}getState(){return this._state||"IDLE"}};var Vs="videochat-epi",nd=5e3,ad=500,bt=class extends ne{constructor(e,t,r=!1){super();this._previousPerfStatReportTimestamp=0;this._previousNetworkStatReportTimestamp=Date.now();this._previousCallStatReportTimestamp=Date.now();this._previousCallStatReport=null;this._screenShareStats=[];this._handleScreenSharingStat=e=>{this._screenShareStats.push(e)};this._handleTransportStateChanged=e=>{(this._directTopology&&e==="CONNECTED"||!this._directTopology&&e==="OPENED")&&(this._previousNetworkStatReportTimestamp=Date.now(),this._previousCallStatReportTimestamp=Date.now())};this._signaling=t,this._directTopology=r,this.subscribe(e,"REMOTE_DATA_STATS",this._handleStats.bind(this)),this.subscribe(e,"SCREEN_SHARING_STAT",this._handleScreenSharingStat.bind(this)),this.subscribe(e,"STATE_CHANGED",this._handleTransportStateChanged.bind(this))}destroy(){this.unsubscribe()}static getEstimatedPerformanceIndex(){try{let e=parseInt(localStorage.getItem(Vs)||"",10);return isNaN(e)?0:e}catch{return 0}}async _handleStats(e){if(!e.inbound||!e.inbound.rtps)return;let t=Date.now();!this._directTopology&&l.perfStatReportEnabled&&this._previousPerfStatReportTimestamp+nd<=t&&(await this.reportPerfStats(e),this._previousPerfStatReportTimestamp=t);let r=e.outbound.transport.local?.protocol==="tcp";!this._directTopology&&r&&this._previousNetworkStatReportTimestamp+ad<=t&&(await this.reportNetworkStats(e),this._previousNetworkStatReportTimestamp=t),l.callStatReportEnabled&&this._previousCallStatReportTimestamp+l.statisticsInterval<=t&&(this._reportCallStats(e),this._previousCallStatReportTimestamp=t)}async reportPerfStats(e){let t=e.inbound.rtps.reduce((r,n)=>(n.kind==="video"&&(r.framesDecoded+=n.framesDecoded||0,r.framesReceived+=n.framesReceived||0),r),{framesDecoded:0,framesReceived:0});if(t.framesDecoded)try{let r=await this._signaling.reportPerfStat(t);localStorage.setItem(Vs,r.estimatedPerformanceIndex)}catch{}}async reportNetworkStats(e){let t={timestamp:e.outbound.transport.timestamp,sendBitrate:e.outbound.rtps.reduce((r,n)=>r+(n.bandwidth??0)*8,0)};if(t.timestamp)try{await this._signaling.reportNetworkStat(t)}catch{}}_reportCallStats(e){let t={call_topology:this._directTopology?"D":"S",stat_time_delta:0,nack_received:0,pli_received:0,fir_received:0,frames_dropped:0,jitter_video:0,jitter_audio:0,interframe_delay_variance:0,nack_sent:0,pli_sent:0,fir_sent:0,total_audio_samples_received:0,concealed_audio_samples:0,silent_concealed_audio_samples:0,inserted_audio_samples_for_deceleration:0,removed_audio_samples_for_acceleration:0,audio_concealment_events:0,total_audio_energy:0,inbound_video_count:0,inbound_audio_count:0,packets_lost_video:0,packets_sent_video:0,packets_lost_audio:0,packets_sent_audio:0,freeze_count:0,total_freezes_duration:0,rtt:Math.round(e.inbound.transport.currentRoundTripTime*1e3),ss_freeze_count:0,ss_total_freezes_duration:0,local_address:Ws(e.inbound.transport.local),local_connection_type:e.inbound.transport.local?.type,network_type:e.inbound.transport.local?.networkType,transport:e.inbound.transport.local?.protocol,remote_address:Ws(e.inbound.transport.remote),remote_connection_type:e.inbound.transport.remote?.type};this._previousCallStatReport||(this._previousCallStatReport=Object.assign({},t));let r=!1,n=!1;for(e.inbound.rtps.reduce((p,u)=>(u.kind==="video"?(r=!0,u.framesReceived&&(p.jitter_video=p.jitter_video*p.inbound_video_count/(p.inbound_video_count+1)+u.jitter*1e3/(p.inbound_video_count+1),p.interframe_delay_variance=p.interframe_delay_variance*p.inbound_video_count/(p.inbound_video_count+1)+(u.interframeDelayVariance||0)*1e6/(p.inbound_video_count+1),p.inbound_video_count++),p.frames_dropped+=u.framesDropped||0,p.nack_sent+=u.nackCount,p.pli_sent+=u.pliCount,p.fir_sent+=u.firCount,p.freeze_count+=u.freezeCountDelta||0,p.total_freezes_duration+=u.totalFreezesDurationDelta||0):(n=!0,u.totalSamplesReceived&&(p.jitter_audio=p.jitter_audio*p.inbound_audio_count/(p.inbound_audio_count+1)+u.jitter*1e3/(p.inbound_audio_count+1),p.total_audio_energy=p.total_audio_energy*p.inbound_audio_count/(p.inbound_audio_count+1)+(u.totalAudioEnergy||0)/(p.inbound_audio_count+1),p.inbound_audio_count++),p.total_audio_samples_received+=u.totalSamplesReceived||0,p.inserted_audio_samples_for_deceleration+=u.insertedSamplesForDeceleration||0,p.removed_audio_samples_for_acceleration+=u.removedSamplesForAcceleration||0,p.concealed_audio_samples+=u.concealedSamples||0,p.silent_concealed_audio_samples+=u.silentConcealedSamples||0,p.audio_concealment_events+=u.concealmentEvents||0),p),t),e.outbound.rtps.reduce((p,u)=>(u.kind==="video"?(p.nack_received+=u.nackCount,p.pli_received+=u.pliCount,p.fir_received+=u.firCount,p.packets_sent_video+=u.packetsSent):p.packets_sent_audio+=u.packetsSent,p),t),e.remoteInbound.rtps.reduce((p,u)=>(u.kind==="video"?p.packets_lost_video+=u.packetsLost:p.packets_lost_audio+=u.packetsLost,p),t);this._screenShareStats.length;){let p=this._screenShareStats.pop();p?.freeze_duration&&(t.ss_freeze_count+=1,t.ss_total_freezes_duration+=p.freeze_duration)}let s={call_topology:t.call_topology,stat_time_delta:Math.max(0,Date.now()-this._previousCallStatReportTimestamp),nack_sent:Math.max(0,t.nack_sent-this._previousCallStatReport.nack_sent),nack_received:Math.max(0,t.nack_received-this._previousCallStatReport.nack_received),pli_sent:Math.max(0,t.pli_sent-this._previousCallStatReport.pli_sent),pli_received:Math.max(0,t.pli_received-this._previousCallStatReport.pli_received),fir_sent:Math.max(0,t.fir_sent-this._previousCallStatReport.fir_sent),fir_received:Math.max(0,t.fir_received-this._previousCallStatReport.fir_received),frames_dropped:Math.max(0,t.frames_dropped-this._previousCallStatReport.frames_dropped),rtt:Math.max(0,t.rtt)};if(navigator.hardwareConcurrency&&(s.cpu_hardware_concurrency=navigator.hardwareConcurrency),r&&!rn(t.jitter_video)&&(s.jitter_video=Math.round(t.jitter_video)),n&&!rn(t.jitter_audio)&&(s.jitter_audio=Math.round(t.jitter_audio)),r&&!rn(t.interframe_delay_variance)&&(s.interframe_delay_variance=t.interframe_delay_variance),t.freeze_count&&t.total_freezes_duration&&(s.freeze_count=t.freeze_count,s.total_freezes_duration=Math.round(t.total_freezes_duration*1e3)),t.ss_freeze_count&&t.ss_total_freezes_duration&&(s.ss_freeze_count=t.ss_freeze_count,s.ss_total_freezes_duration=t.ss_total_freezes_duration),n&&!rn(t.total_audio_samples_received)){let p=Math.max(0,t.total_audio_samples_received-this._previousCallStatReport.total_audio_samples_received),u=Math.max(0,t.inserted_audio_samples_for_deceleration-this._previousCallStatReport.inserted_audio_samples_for_deceleration),h=Math.max(0,t.removed_audio_samples_for_acceleration-this._previousCallStatReport.removed_audio_samples_for_acceleration),g=Math.max(0,t.concealed_audio_samples-this._previousCallStatReport.concealed_audio_samples),b=Math.max(0,t.silent_concealed_audio_samples-this._previousCallStatReport.silent_concealed_audio_samples),w=Math.max(0,t.audio_concealment_events-this._previousCallStatReport.audio_concealment_events);s.inserted_audio_samples_for_deceleration=Ht(u/p*1e3),s.removed_audio_samples_for_acceleration=Ht(h/p*1e3),s.concealed_audio_samples=Ht(g/p*1e3),s.concealed_silent_audio_samples=Ht(b/p*1e3),s.concealment_audio_avg_size=Ht(g/w),s.total_audio_energy=t.total_audio_energy}js(t,"local_address","local_connection_type","network_type","transport")&&(s.local_address=t.local_address,s.local_connection_type=t.local_connection_type,s.network_type=t.network_type,s.transport=t.transport),js(t,"remote_address","remote_connection_type")&&(s.remote_address=t.remote_address,s.remote_connection_type=t.remote_connection_type);let o=Math.max(0,t.packets_sent_video-this._previousCallStatReport.packets_sent_video),d=Math.max(0,t.packets_sent_audio-this._previousCallStatReport.packets_sent_audio);if(o>0){let p=Math.max(0,t.packets_lost_video-this._previousCallStatReport.packets_lost_video);s.video_loss=Ht(p/o*100)}if(d>0){let p=Math.max(0,t.packets_lost_audio-this._previousCallStatReport.packets_lost_audio);s.audio_loss=Ht(p/d*100)}Me.logCallStat(s),l.enableLogPerfStatReport&&c.log("Sent call stats",s),this._previousCallStatReport=t}};function js(a,...i){for(let e of i)if(!a.hasOwnProperty(e)||a[e]===void 0)return!1;return!0}function Ws(a,i=!1){if(a?.address)return a.address+(i?`:${a.port}`:"")}function rn(a){return a===void 0}function Ht(a){return Number.isNaN(a)?0:a}var Gi=class{constructor(i,e=null){this.value=NaN;this.weightUp=i,this.weightDown=e??i}set(i){this.value=i}update(i){return this.value=this.getNext(i),this.value}getNext(i){if(isNaN(this.value))return i;let e=i<this.value?this.weightDown:this.weightUp;return this.value*(1-e)+i*e}getValue(){return this.value}};var Gs=.25,Hs=.35,sd=85,od=.1,cd=1.5,dd=.1,ld=1,pd=.6,ud=.3;var Hi=class extends ne{constructor(e){super();this._networkLimits={badNet:{loss:3,rtt:1e3},goodNet:{loss:.5,rtt:600}};this._lastStatSentTimestamp=0;this._currentState="good";this._signaling=e,this._localNetworkStat={rtt:new Gi(Gs,Gs),loss:new Gi(Hs,Hs),bitrate:0},this._remoteNetworkStat={rtt:0,loss:0,bitrate:0},this._lastNetworkStat={rtt:0,loss:0,date:0}}_calcRttRating(e){let t=typeof e=="number"?e:e.getValue(),r=1;if(isNaN(t))return r;let n=Math.round((t-this._networkLimits.goodNet.rtt)/sd);for(let s=0;s<n;s++)r*=1-od;return r}_calcLossRating(e){let t=typeof e=="number"?e:e.getValue(),r=1;if(isNaN(t))return r;let n=Math.round((t-this._networkLimits.goodNet.loss)/cd);for(let s=0;s<n;s++)r*=1-dd;return r}_calcBitrateRating(e,t){if(!e||!t)return 1;let n=1-(1-Math.min(e,t)/Math.max(e,t))*ld;return Math.min(n,1)}_calcUDPRating({rtt:e,loss:t}){return this._calcRttRating(e)*this._calcLossRating(t)}_calcRating(e,t,r){return r?this._calcBitrateRating(e.bitrate,t.bitrate):this._calcUDPRating(e)*this._calcUDPRating(t)}_getNetworkState(e){return isNaN(e)||e>=pd?"good":e>=ud?"medium":"bad"}updateSettings(e){Object.assign(this._networkLimits.badNet,e?.badNet||{}),Object.assign(this._networkLimits.goodNet,e?.goodNet||{})}reportLocal(e){if(!this._signaling.ready)return;let t=e.outbound.transport.local?.protocol==="tcp",r=Math.max(0,Math.round(e.outbound.transport.currentRoundTripTime*1e3)||0),n=e.inbound.rtps.reduce((h,g)=>Math.max(h,g.packetLoss||0),0),s={rtt:this._localNetworkStat.rtt.update(r),loss:this._localNetworkStat.loss.update(n)};if(t){let h=e.outbound.rtps.reduce((g,b)=>g+(b.bandwidth??0)*8,0);s.bitrate=h,this._localNetworkStat.bitrate=h}let o=Date.now(),d=this._calcRating(this._localNetworkStat,this._remoteNetworkStat,t),p=Math.max(Math.round(d*10)/10,.1),u=this._getNetworkState(p);(t||u!==this._currentState||o-this._lastStatSentTimestamp>l.networkStatisticsInterval)&&(this._lastStatSentTimestamp=o,this._signaling.customData({sdk:Object.assign({type:"bad-net"},s)},null).catch(h=>{c.warn("Unable to send [bad-net]",h)})),this._currentState=u,this._triggerEvent("NETWORK_STATUS",p)}reportRemote(e){let{rtt:t,loss:r,bitrate:n}=e||{};this._remoteNetworkStat.rtt=t||0,this._remoteNetworkStat.loss=r||0,this._remoteNetworkStat.bitrate=n||0}};var hd=30*1e3,Ki=class a extends Gt{constructor(e,t,r,n,s){super(r,n);this._remoteSDP={};this._remoteCandidates={};this._lastRemoteSDP=null;this._animojiDataChannel=null;this._animojiReceiver=null;this._animojiSender=null;this._remoteAnimojiVersion=1;this._isOpen=!1;this._remotePeerId=null;this._statInterval=null;this._settingsInterval=null;this._failedOnCreate=null;this._remoteStream=null;this._iceRestartTimeout=null;this._reconnectionTimeout=null;this._reconnectionPrevented=!1;this._fingerprint=null;this._neverConnected=!0;this._prevConsumerSettings={};this._networkLimitsForVideo={bad:{loss:4,rtt:1e3},good:{loss:2,rtt:700}};this._videoMaxDimensionsForNet={worst:320,bad:640,good:1280};this._lastVideoMaxDimension=this._videoMaxDimensionsForNet.good;this._lastBadConnection=0;if(this._participantId=e,this._isMaster=t,this._serverSettings=s,this._perfStatReporter=new bt(this,r,!0),this._directStatReporter=new Hi(r),this.subscribe(this._signaling,De.NOTIFICATION,this._onSignalingNotification.bind(this)),this.subscribe(this._mediaSource,"TRACK_REPLACED",this._onReplacedTrack.bind(this)),this.subscribe(this._mediaSource,"SOURCE_CHANGED",this._applySettings.bind(this)),this.subscribe(this._directStatReporter,"NETWORK_STATUS",this._onNetworkStatus.bind(this)),this._pc=new RTCPeerConnection({iceServers:l.iceServers,iceTransportPolicy:l.forceRelayPolicy?"relay":"all"},{optional:[{googSuspendBelowMinBitrate:!1}]}),this._pc.onicecandidate=this._handleIceCandidate.bind(this),this._pc.ontrack=this._onAddTrack.bind(this),this._pc.oniceconnectionstatechange=this._onIceConnectionStateChange.bind(this),this._pc.onconnectionstatechange=this._onConnectionStateChange.bind(this),this._pc.onsignalingstatechange=this._onSignalingStateChange.bind(this),this._prevConsumerSettings={},l.vmoji&&this._createDataChannel(this._pc,mt.animoji,o=>{this._animojiDataChannel=o,this._animojiDataChannel.binaryType="arraybuffer",this._animojiReceiver?.setDataChannel(this._animojiDataChannel),this._animojiSender?.setDataChannel(this._animojiDataChannel)}),this._isMaster){try{this._mediaSource.addTrackToPeerConnection(this._pc,!1,!0),this._applySettings()}catch(o){R.log(T.ERROR,"addTrack-direct"),c.error("Unable to add media source tracks",o,{participantId:this._participantId}),this._failedOnCreate=o;return}this._createOffer(!1).catch(o=>{this._state==="IDLE"?this._failedOnCreate=o:this.close(o)})}this._startSettingsInterval()}get participantId(){return this._participantId}updateStatisticsInterval(){this._stopStatInterval(),this._isDeadConnection()||this._startStatInterval()}_isDeadConnection(){return["IDLE","CLOSED","FAILED"].includes(this.getState())}async open(e=null){if(this._isOpen){c.warn("DirectTransport: Already opened",{participantId:this._participantId});return}if(this._failedOnCreate){this.close(this._failedOnCreate);return}if(c.debug("DirectTransport: Open transport",{participantId:this._participantId}),this._isOpen=!0,this._remotePeerId=e,!this._isMaster)try{this._mediaSource.addTrackToPeerConnection(this._pc,!1,!0),this._applySettings()}catch(r){R.log(T.ERROR,"addTrack-direct"),c.error("DirectTransport: Unable to add media source tracks",r,{participantId:this._participantId}),this.close(r);return}this._setState("OPENED");let t=e;if(!e){let r=Object.keys(this._remoteSDP);t=r[r.length-1]}if(t&&this._remoteSDP[t])try{await this._setRemoteDescription(t,this._remoteSDP[t])}catch{this.close();return}this._remoteSDP={},this._remoteCandidates={}}updateSettings(e){Zr(e,this._serverSettings)||(this._serverSettings=e,this._applySettings())}preventRestart(){this._reconnectionPrevented=!0}allowRestart(){this._reconnectionPrevented=!1}setAnimojiTransport(e,t){if(l.vmoji&&(this._animojiReceiver=e,this._animojiSender=t,e.setParticipantId(this._participantId),this._animojiDataChannel)){e.setDataChannel(this._animojiDataChannel),t.setDataChannel(this._animojiDataChannel);return}}close(e){this._isOpen&&(this._isOpen=!1,this._stopReconnection(),this._remoteStream&&(this._remoteStream.getTracks().forEach(t=>{t.stop(),this._triggerEvent("REMOTE_TRACK_REMOVED",this._remoteStream,t)}),this._remoteStream=null),this._stopStatInterval(),this._stopSettingsInterval(),this._pc&&(this._animojiDataChannel&&(this._animojiDataChannel.onopen=null,this._animojiDataChannel.onmessage=null,this._animojiDataChannel.onerror=null,this._animojiDataChannel.close()),this._pc.onicecandidate=null,this._pc.ontrack=null,this._pc.oniceconnectionstatechange=null,this._pc.onconnectionstatechange=null,this._pc.onsignalingstatechange=null,this._pc.close(),this._pc=null),this._onNetworkStatus(1),this.unsubscribe(),e?(c.error("DirectTransport: Closed",e,{participantId:this._participantId}),this._setState("FAILED")):(c.debug("DirectTransport: Closed",{participantId:this._participantId}),this._setState("CLOSED")),this._triggerEvent("PEER_CONNECTION_CLOSED"))}_setState(e){this._state!==e&&(c.debug(`DirectTransport: State changed to ${e}`,{participantId:this._participantId}),this._state=e,this._triggerEvent("STATE_CHANGED",e))}_onSignalingNotification(e){switch(e.notification){case L.TRANSMITTED_DATA:this._handleTransmittedData(e);break;case L.SETTINGS_UPDATE:this._directStatReporter.updateSettings(e.settings);break;case L.CUSTOM_DATA:e.data.hasOwnProperty("sdk")&&this._directStatReporter.reportRemote(e.data?.sdk);break}}_handleTransmittedData(e){let t=e.data,r=I.getPeerIdString(e.peerId);I.composeMessageId(e)===this._participantId&&(t.candidate&&t.candidate.candidate?this._addIceCandidate(r,t.candidate).catch(this.close.bind(this)):t.sdp&&(this._remoteAnimojiVersion=t.animojiVersion||1,this._setRemoteDescription(r,t.sdp).catch(this.close.bind(this))))}async _addIceCandidate(e,t){if(this._isOpen&&(!this._remotePeerId||this._remotePeerId===e)&&this._pc&&this._pc.remoteDescription){c.debug("Add remote ice candidate",{participantId:this._participantId,candidate:t});try{await this._pc.addIceCandidate(new RTCIceCandidate(t))}catch(r){throw R.log(T.ERROR,"addIceCandidate-direct"),c.error("Unable to add remote ice candidate",r,{participantId:this._participantId,candidate:t}),r}}else c.debug("Cache remote ice candidate",{participantId:this._participantId,candidate:t}),this._remoteCandidates[e]=this._remoteCandidates[e]||[],this._remoteCandidates[e].push(t)}async _setRemoteCandidates(e){if(!this._remoteCandidates[e]){c.log(`No cached candidates found for peer ${e}`);return}let t=this._remoteCandidates[e];this._remoteCandidates[e]=[];for(let r of t)try{await this._addIceCandidate(e,r)}catch{}}async _setRemoteDescription(e,t){if(this._isOpen&&(!this._remotePeerId||this._remotePeerId===e)&&this._pc){if(this._lastRemoteSDP?.sdp===t.sdp)return;this._lastRemoteSDP=t,t=a._patchRemoteDescription(t),c.debug("Add remote description",{participantId:this._participantId,sdp:t}),this._calcFingerprint(t.sdp);try{await this._pc.setRemoteDescription(t),await this._setRemoteCandidates(e),this._processAnimojiProtocolVersion(this._remoteAnimojiVersion)}catch(r){throw R.log(T.ERROR,"setRemoteDescription-direct"),c.error("Unable to set remote description",r,{participantId:this._participantId,sdp:t}),r}}else this._remoteSDP[e]=t}_processAnimojiProtocolVersion(e){let t=Math.min(e,l.vmojiOptions?.protocolVersion||1);this._animojiSender?.setProtocolVersion(t)}_onAddTrack(e){c.debug("Added remote track",{participantId:this._participantId,kind:e.track.kind}),this._remoteStream?this._remoteStream.addTrack(e.track):(this._remoteStream=new MediaStream([e.track]),this._remoteStream.onremovetrack=t=>{this._triggerEvent("REMOTE_TRACK_REMOVED",this._remoteStream,t.track)}),this._triggerEvent("REMOTE_TRACK_ADDED",this._remoteStream,e.track)}async _handleIceCandidate(e){e.candidate&&this._signaling.ready&&(c.debug("Local ice candidate",{participantId:this._participantId,candidate:e.candidate}),await this._signaling.sendCandidate(this._participantId,e.candidate))}_onSignalingStateChange(){c.debug(`DirectTransport: Signaling state changed to ${this._pc?.signalingState}`,{participantId:this._participantId});let e={animojiVersion:l.vmojiOptions.protocolVersion||1};switch(this._pc?.signalingState){case"have-local-offer":let t=this._pc.localDescription;t?this._signaling.sendSdp(this._participantId,t,e).catch(this.close.bind(this)):this.close(new Error);break;case"have-remote-offer":this._createAnswer().then(r=>this._signaling.sendSdp(this._participantId,r,e)).catch(this.close.bind(this));break}}_onIceConnectionStateChange(){switch(c.debug(`DirectTransport: Ice Connection state changed to ${this._pc?.iceConnectionState}`,{participantId:this._participantId}),this._pc?.iceConnectionState){case"checking":let e=this.getState();e==="IDLE"||e==="OPENED"?this._setState("CONNECTING"):this._setState("RECONNECTING");break}}_onConnectionStateChange(){switch(c.debug(`DirectTransport: Connection state changed to ${this._pc?.connectionState}`,{participantId:this._participantId}),R.log(T.ICE_CONNECTION_STATE,this._pc?.connectionState),this._pc?.connectionState){case"connected":this._neverConnected=!1,this._setState("CONNECTED"),this._stopReconnection(),I.getPeerConnectionHostInfo(this._pc).then(e=>{e?.local&&(R.log(T.ICE_CONNECTION_TYPE,e.local.type),c.debug("Selected ICE candidates",e))}),this._startStatInterval();break;case"failed":case"disconnected":this._reconnectionPrevented?this.close(new Error(`Ice connection ${this._pc.connectionState}`)):(this._setState("RECONNECTING"),this._startReconnection());break;case"closed":this.close(new Error("Ice connection closed"));break}}_startReconnection(){this._reconnectionTimeout||this._iceRestartTimeout||(c.log("Waiting for reconnection...",{participantId:this._participantId}),this._reconnectionTimeout=window.setTimeout(()=>{this._reconnectionTimeout=null,this._neverConnected?this._requestTopologySwitch():this._startIceRestart()},l.transportConnectionWaitTime))}_requestTopologySwitch(){this._isMaster&&this._signaling.ready&&(c.log("Switch topology DIRECT to SERVER",{participantId:this._participantId}),this._signaling.switchTopology("SERVER"))}_stopReconnection(){this._reconnectionTimeout&&(clearTimeout(this._reconnectionTimeout),this._reconnectionTimeout=null),this._iceRestartTimeout&&(clearTimeout(this._iceRestartTimeout),this._iceRestartTimeout=null)}_startIceRestart(){this._isMaster?(R.log(T.ICE_RESTART),c.log("Ice restart",{participantId:this._participantId}),this._createOffer(!0).catch(this.close.bind(this))):c.debug("Waiting for ice restart...",{participantId:this._participantId}),this._iceRestartTimeout=window.setTimeout(()=>{this._iceRestartTimeout=null,c.error("Ice restart failed",{participantId:this._participantId}),R.log(T.ERROR,"iceRestart-direct"),this._requestTopologySwitch()},l.iceRestartWaitTime)}async _createOffer(e){let t={iceRestart:e,offerToReceiveAudio:!0,offerToReceiveVideo:!0};c.debug("Create offer",{participantId:this._participantId,options:t});let r;try{r=await this._pc?.createOffer(t),c.debug("Created offer",{participantId:this._participantId,offer:r}),r=a._patchLocalDescription(r)}catch(n){throw c.error("Unable to create offer",n,{participantId:this._participantId}),R.log(T.ERROR,"createOffer-direct"),n}try{return c.debug("Set local description",{participantId:this._participantId,offer:r}),this._calcFingerprint(r.sdp),await this._pc?.setLocalDescription(r),r}catch(n){throw c.error("Unable to set local description",n,{participantId:this._participantId}),R.log(T.ERROR,"setLocalDescription-direct"),n}}async _createAnswer(){c.debug("Create answer",{participantId:this._participantId});let e;try{e=await this._pc?.createAnswer(),c.debug("Created answer",{participantId:this._participantId,answer:e}),e=a._patchLocalDescription(e)}catch(t){throw c.error("Unable to create answer",t,{participantId:this._participantId}),R.log(T.ERROR,"createAnswer-direct"),t}try{return c.debug("Set local description",{participantId:this._participantId,answer:e}),this._calcFingerprint(e.sdp),await this._pc?.setLocalDescription(e),e}catch(t){throw c.error("Unable to set local description",t,{participantId:this._participantId}),R.log(T.ERROR,"setLocalDescription-direct"),t}}static _patchLocalDescription(e){let t=!!P.baseChromeVersion();return e.sdp=I.patchLocalSDP(e.sdp,l.preferH264&&P.canPreferH264(),P.isBrokenH264Decoder(),l.preferVP9,l.h264spsPpsIdrInKeyframe,t&&l.audioNack,l.p2pAudioRed),e}static _patchRemoteDescription(e){return e.sdp=I.patchRemoteSDP(e.sdp,!1,!1,!1,l.preferVP9,P.isBrokenVP9Encoder(),P.isBrokenVP9Decoder()),e}_onReplacedTrack(e){this._pc&&(this._pc.getSenders().forEach(t=>{t.track&&t.track.kind===e.kind&&t.track.contentHint===e.contentHint&&t.replaceTrack(e).catch(r=>{c.error("DirectTransport: Unable to replace track",r,{participantId:this._participantId}),R.log(T.ERROR,"replaceTrack-direct")})}),this._applySettings())}_startStatInterval(){if(this._statInterval)return;let e=()=>{if(this._isDeadConnection()){this._stopStatInterval();return}yi(this._pc,this._lastStat,void 0,!0).then(t=>{this._lastStat=t,dt.reportUsage(t);let r={inbound:{topology:"DIRECT",transport:t.transport,rtps:t.rtps.filter(n=>n.type==="inbound-rtp"?(n.userId=this._participantId,!0):!1)},outbound:{topology:"DIRECT",transport:t.transport,rtps:t.rtps.filter(n=>n.type==="outbound-rtp")},remoteInbound:{topology:"DIRECT",transport:t.transport,rtps:t.remoteRtps??[]}};this._checkPPTNetwork(r),this._directStatReporter.reportLocal(r),this._triggerEvent("REMOTE_DATA_STATS",r),this._statInterval=window.setTimeout(e,l.statisticsInterval)})};this._statInterval=window.setTimeout(e,l.statisticsInterval)}async _isSVCSupported(e,t){let r=this._mediaSource.getSendVideoTrack(),n=e.outbound.rtps.find(d=>d.kind==="video");if(!n?.mimeType||!n?.bandwidth||!r)return!1;let s=r.getSettings();if(!s.width||!s.height||!s.frameRate)return!1;let o={type:P.browserName()==="Firefox"?"transmission":"webrtc",video:{contentType:n.mimeType,width:s.width,height:s.height,bitrate:n.bandwidth,framerate:s.frameRate,scalabilityMode:t}};try{return(await navigator.mediaCapabilities.encodingInfo(o)).supported||!1}catch(d){return c.warn("Failed to get encodingInfo",o,d),!1}}async _checkPPTNetwork(e){if(!l.switchVideoAtBadNetwork||!e.inbound.transport.averageNetStat)return;let{averageNetStat:t}=e.inbound.transport,r=t.currentRoundTripTime<=this._networkLimitsForVideo.good.rtt&&t.lostPercent<=this._networkLimitsForVideo.good.loss,n=t.currentRoundTripTime>=this._networkLimitsForVideo.bad.rtt||t.lostPercent>=this._networkLimitsForVideo.bad.loss,s=t.currentRoundTripTime<this._networkLimitsForVideo.bad.rtt,o=this._videoMaxDimensionsForNet.good,d="L1T1";if(n?(this._lastBadConnection=Date.now(),s?(o=this._videoMaxDimensionsForNet.bad,d="L1T2"):(o=this._videoMaxDimensionsForNet.worst,d="L1T3")):r&&(o=this._videoMaxDimensionsForNet.good,d="L1T1"),!(o<this._lastVideoMaxDimension||Date.now()-this._lastBadConnection>hd)||this._lastVideoMaxDimension===o)return;let u=this._serverSettings.camera;if(!u||!await this._isSVCSupported(e,d))return;c.debug("Switch outbound video frame size and scalabilityMode",{scalabilityMode:d,averageNetStat:t,nextVideoMaxDimension:o}),this._lastVideoMaxDimension=o;let g={...this._serverSettings,camera:{...u,scalabilityMode:d,maxDimension:this._lastVideoMaxDimension}};this.updateSettings(g)}_stopStatInterval(){this._statInterval&&(window.clearTimeout(this._statInterval),this._statInterval=null)}_onNetworkStatus(e){let t={};t[this._participantId]=t[""]=e,this._triggerEvent("NETWORK_STATUS",t)}_startSettingsInterval(){if(this._settingsInterval)return;let t=()=>{if(!this._pc){this._stopSettingsInterval();return}this._applySettings(),this._settingsInterval=window.setTimeout(t,2e3)};this._settingsInterval=window.setTimeout(t,2e3)}_stopSettingsInterval(){this._settingsInterval&&(window.clearTimeout(this._settingsInterval),this._settingsInterval=null)}_calcFingerprint(e){let t=I.sdpFingerprint(e);if(t===null){c.warn("Fingerprint calculation is unsupported");return}this._fingerprint===null?this._fingerprint=t:(E.onFingerprintChange((this._fingerprint^t).toString()),this._fingerprint=null)}_applySettings(){let e=this._mediaSource.getMediaSettings().isScreenSharingEnabled?this._serverSettings.screenSharing:this._serverSettings.camera;e&&this._pc?.connectionState==="connected"&&(this._prevConsumerSettings=I.applySettings(this._pc,e,this._prevConsumerSettings))}_createDataChannel(e,t,r){c.debug(`[${t}] data channel opening`);let n=e.createDataChannel(t,{negotiated:!0,id:1});n.onopen=()=>{let s=n.readyState;s==="open"?(c.debug(`[${t}] data channel opened`),n.onerror=o=>{c.error(`[${t}] data channel error`,o)},r(n)):c.error(`[${t}] data channel open failed, state [${s}]`)}}};var md=16,nn=class a{constructor(i,e,t){c.debug("AsrReceiver started"),this._datachannel=i,this._participantIdRegistry=e,this._asrCallback=t,this._textDecoder=new TextDecoder,this._datachannel.onmessage=r=>this._onDataChannelMessage(r.data)}static parse(i){let e=new DataView(i),t=e.getUint8(0),r=e.getUint8(1);if(r!==0)throw new Error(`Unsupported message type. Message type: ${r}`);let n=e.getUint16(2),s=e.getUint32(4),o=e.getUint32(8),d=e.getUint32(12);if(t!==1)throw new Error(`Unexpected protocol version. Got ${t}, expected 1`);return{sequence:n,ssrc:s,timestamp:o,duration:d,data:i.slice(md)}}_onDataChannelMessage(i){let e=a.parse(i),t=this._participantIdRegistry?.getStreamDescription(e.ssrc)?.participantId;if(!t){c.warn(`Participant id for ssrc ${e.ssrc} not found in registry`);return}let r={participantId:t,text:this._textDecoder.decode(e.data),timestamp:e.timestamp,duration:e.duration};this._asrCallback(r)}destroy(){this._datachannel.onmessage=null}};var ft=require("messagepack");var an=class{constructor(){this.streamDescriptionByCompactId=new Map;this.compactIdByStreamDescription=new Map}getStreamDescription(i){return this.streamDescriptionByCompactId.get(i)}getCompactId(i){return this.compactIdByStreamDescription.get(i)}handleMessage(i){let e=new Uint8Array(i),t=e[0],r=e.subarray(1);switch(t){case 1:let n=(0,ft.decode)(r);return Object.entries(n).forEach(([b,w])=>{let B=Oi(b);this.streamDescriptionByCompactId.set(w,B),this.compactIdByStreamDescription.set(b,w)}),null;case 2:case 4:let s=(0,ft.decode)(r),o=[];for(let b of s){let w=this.getStreamDescription(b);w&&o.push(w.participantId)}return t===2?{type:"notification",notification:L.AUDIO_ACTIVITY,activeParticipants:o}:{type:"notification",notification:L.STALLED_ACTIVITY,stalledParticipants:o};case 3:let d=(0,ft.decode)(r);return{type:"notification",notification:L.SPEAKER_CHANGED,speaker:this.getStreamDescription(d)?.participantId};case 5:let p=(0,ft.decode)(r);return{type:"notification",notification:L.VIDEO_QUALITY_UPDATE,quality:{maxBitrate:p[0],maxDimension:p[1]}};case 6:let u=(0,ft.decode)(r),h={};for(let[b,w]of Object.entries(u)){let B=this.getStreamDescription(Number(b))?.participantId;B&&(h[B]=w/100)}return{type:"notification",notification:L.NETWORK_STATUS,statuses:h};case 7:return this._createParticipantSourcesUpdateNotification(r);case 8:{let w=(0,ft.decode)(r).map(B=>{let[W,Q,ue,we,z,Ae,Ee]=B;return{participantId:this.getStreamDescription(W)?.participantId,gain:Q,pause:ue,offset:we,mute:z,liveStatus:Ae,startTimeMs:Ee}});return{type:"notification",notification:L.MOVIE_UPDATE_NOTIFICATION,data:w}}case 9:let g=(0,ft.decode)(r);return{type:"notification",notification:L.VIDEO_SUSPEND_SUGGEST,bandwidth:g};default:return c.debug("unsupported message type: "+t),null}}_createParticipantSourcesUpdateNotification(i){let e=(0,ft.decode)(i),t=[];for(let[r,n]of Object.entries(e)){let s=n[0],o=n[1],d=n[2],p=!!n[3],u=n[4]!==null?!!n[4]:void 0,h;if(s!==null){if(h=this.getStreamDescription(s),!h){c.error(`could not uncompress participant ID ${s}`);continue}}else h=null;if(d===null){c.error("unexpected null sequenceNumber",r,n);continue}let g=et.PARTICIPANT_AGNOSTIC_TRACK_PREFIX+"-"+r,b=o?o>>>0:null;t.push({participantStreamDescription:h,streamId:g,rtpTimestamp:b,sequenceNumber:d,fastScreenShare:p,suspend:u})}return{type:"notification",notification:L.PARTICIPANT_SOURCES_UPDATE,participantUpdateInfos:t}}};var fd=90,gd=4294967295,qi=class a extends Gt{constructor(e,t,r){super(e,t);this._producerNotification=null;this._producerCommand=null;this._producerScreen=null;this._consumerScreen=null;this._asr=null;this._animojiDataChannel=null;this._animojiReceiver=null;this._animojiSender=null;this._isOpen=!1;this._observer=!1;this._reconnectionPrevented=!1;this._statInterval=null;this._settingsInterval=null;this._statBytes={};this._ssrcMap={};this._ssrcMapUpdated=!1;this._producerOfferIsProcessing=!1;this._producerNextOffer=null;this._lastStat=null;this._prevConsumerSettings={};this._asrTrack=null;this._captureSender=null;this._captureReceiver=null;this._participantIdRegistry=null;this._disabledSenders=new Set;this._rtpReceiversByStreamId={};this._producerSessionId="";this._newAudioShareTrack=null;this._simulcastInfo=null;this.subscribe(this._signaling,De.NOTIFICATION,this._onSignalingNotification.bind(this)),this.subscribe(this._mediaSource,"TRACK_REPLACED",this._onReplacedTrack.bind(this)),this.subscribe(this._mediaSource,"SOURCE_CHANGED",this._applyConsumerSettings.bind(this)),this.subscribe(this._mediaSource,"SCREEN_STATUS",this._onScreenSharingStatus.bind(this)),this._createPerfStatsReporter(),this._serverSettings=r,c.debug("ServerTransport: Created")}updateStatisticsInterval(){this._stopStatInterval();let e=this.getState();e!=="IDLE"&&e!=="CLOSED"&&e!=="FAILED"&&this._startStatInterval()}open(e=!1){if(this._isOpen){c.log("ServerTransport: Already opened connections");return}this._isOpen=!0,this._observer=e,this._openConnection()}close(e){this._isOpen&&(this._isOpen=!1,this._closeConnection(),this.unsubscribe(),e?(c.error("ServerTransport: Closed",e),this._setState("FAILED")):(c.debug("ServerTransport: Closed"),this._setState("CLOSED")))}removeParticipant(e){this._captureReceiver?.close(e)}preventRestart(){this._reconnectionPrevented=!0}allowRestart(){this._reconnectionPrevented=!1}updateSettings(e){Zr(e,this._serverSettings)||(this._serverSettings=e,this._applyConsumerSettings())}setAnimojiTransport(e,t){if(l.vmoji&&(this._animojiReceiver=e,this._animojiSender=t,this._participantIdRegistry&&e.setParticipantIdRegistry(this._participantIdRegistry),this._animojiDataChannel)){e.setDataChannel(this._animojiDataChannel),t.setDataChannel(this._animojiDataChannel);return}}async onCameraResolutionChanged(){l.simulcast&&P.isSimulcastSupportedByBrowser()&&await this._changeSimulcastInfo(!0,!1)}_createPerfStatsReporter(){this._perfStatReporter?.destroy(),this._perfStatReporter=new bt(this,this._signaling)}_closeConnection(){this._stopStatInterval(),this._stopSettingsInterval(),this._removeAsrTrack(),this._removeCaptureSender(),this._removeCaptureReceiver(),this._simulcastInfo=null,this._pc&&(this._rtpReceiversByStreamId={},this._disabledSenders.forEach(e=>e.track?.stop()),this._disabledSenders.clear(),this._pc.ontrack=null,this._pc.onconnectionstatechange=null,this._pc.onsignalingstatechange=null,this._participantIdRegistry=null,a._closeDataChannel(this._producerNotification),a._closeDataChannel(this._producerCommand),a._closeDataChannel(this._producerScreen),a._closeDataChannel(this._consumerScreen),a._closeDataChannel(this._asr),a._closeDataChannel(this._animojiDataChannel),this._pc.close(),this._pc=null,this._producerOfferIsProcessing=!1,this._producerNextOffer=null),this._triggerEvent("PEER_CONNECTION_CLOSED")}static _closeDataChannel(e){e&&(e.onopen=null,e.onmessage=null,e.onerror=null,e.close())}_createDataChannel(e,t,r){c.debug(`[${t}] data channel opening`);let n=e.createDataChannel(t,{ordered:!0});n.onopen=()=>{let s=n.readyState;s==="open"?(c.debug(`[${t}] data channel opened`),r(n)):c.error(`[${t}] data channel open failed, state [${s}]`)},n.onerror=s=>{let o=s.error;c.error(`[${t}] data channel error`,o?.errorDetail,o?.message)}}_openConnection(e=!1){c.debug("ServerTransport: Open single connection"),this._pc=new RTCPeerConnection({},{optional:[{googSuspendBelowMinBitrate:!1}]}),this._pc.ontrack=this._onAddTrack.bind(this,this._pc),this._pc.onconnectionstatechange=I.debounce(t=>{this._pc&&this._onConnectionStateChange(this._pc,t)},500),this._pc.onsignalingstatechange=a._onSignalingStateChange.bind(this,this._pc),this._participantIdRegistry=new an,this._signaling.setParticipantIdRegistry(this._participantIdRegistry),l.producerNotificationDataChannel&&this._createDataChannel(this._pc,mt.producerNotification,t=>{this._producerNotification=t,this._producerNotification.binaryType="arraybuffer",this._signaling.setProducerNotificationDataChannel(t)}),l.producerCommandDataChannel&&(this._signaling.useCommandDataChannel(!0),this._createDataChannel(this._pc,mt.producerCommand,t=>{this._producerCommand=t,this._signaling.setProducerCommandDataChannel(t)})),l.producerScreenDataChannel&&this._createDataChannel(this._pc,mt.producerScreenShare,t=>{this._producerScreen=t,this._producerScreen.binaryType="arraybuffer",this._createCaptureReceiver()}),l.asrDataChannel&&this._createDataChannel(this._pc,mt.asr,t=>{this._asr=t,this._asr.binaryType="arraybuffer",this._removeAsrTrack(),this._asrTrack=new nn(t,this._participantIdRegistry,r=>{this._onAsrTranscription(r)})}),l.vmoji&&this._createDataChannel(this._pc,mt.animoji,t=>{this._animojiDataChannel=t,this._animojiDataChannel.binaryType="arraybuffer",this._animojiReceiver?.setDataChannel(t),this._animojiReceiver?.setParticipantIdRegistry(this._participantIdRegistry),this._animojiSender?.setDataChannel(t),this._animojiSender?.setProtocolVersion(l.vmojiOptions.protocolVersion||1)}),this._newAudioShareTrack=this._mediaSource.getAudioShareTrack();try{this._mediaSource.addTrackToPeerConnection(this._pc,this._observer,!1),this._prevConsumerSettings={},this._applyConsumerSettings()}catch(t){c.error("ServerTransport: Unable to add media source tracks",t),R.log(T.ERROR,"addTrack-single"),this.close(t);return}l.consumerScreenDataChannel&&this._createDataChannel(this._pc,mt.consumerScreenShare,t=>{this._consumerScreen=t,this._consumerScreen.binaryType="arraybuffer";let r=this._mediaSource.getScreenTrack();r&&this._createCaptureSender(r)}),e||this._allocateConsumer(),this._setState("OPENED"),this._startStatInterval(),this._startSettingsInterval()}_removeAsrTrack(){this._asrTrack?.destroy(),this._asrTrack=null}_reconnect(){this.getState()!=="OPENED"&&(this._setState("RECONNECTING"),this._closeConnection(),this._openConnection(!0))}_signalActiveParticipants(e){this._triggerEvent("SIGNALLED_ACTIVE_PARTICIPANTS",e)}_signalStalledParticipants(e){this._triggerEvent("SIGNALLED_STALLED_PARTICIPANTS",e)}_signalSpeakerChanged(e){this._triggerEvent("SIGNALLED_SPEAKER_CHANGED",e)}_signalNetworkStatus(e){this._triggerEvent("NETWORK_STATUS",e)}_updateSSRCMap(e){e&&e.sdp.split(`
|
|
12
|
-
`).forEach(t=>{let r=`a=ssrc:([0-9]+) label:(audio|video)-((?:[ug]?[\\d]+)|(?:mix)|(?:${et.PARTICIPANT_AGNOSTIC_TRACK_PREFIX}-[0-9]+))`,n=new RegExp(r).exec(t);n&&(this._ssrcMap[n[1]]=n[3],this._ssrcMapUpdated=!0)})}_createCaptureSender(e){let t=this._mediaSource.getMediaSettings();!e||!l.consumerScreenDataChannel||!this._consumerScreen||!t.isScreenSharingEnabled||(this._captureSender&&this._removeCaptureSender(),this._captureSender=new Nt(e,this._consumerScreen,this._signaling,t.isFastScreenSharingEnabled))}_removeCaptureSender(){this._captureSender?.destroy(),this._captureSender=null}_createCaptureReceiver(){!l.producerScreenDataChannel||!this._producerScreen||(this._captureReceiver&&this._removeCaptureReceiver(),this._captureReceiver=new Ot(this._producerScreen,this._participantIdRegistry,(e,t)=>{this._triggerEvent("REMOTE_STREAM_SECOND",e,t)},e=>{this._triggerEvent("REMOTE_STREAM_SECOND",e,null)},e=>{this._triggerEvent("SCREEN_SHARING_STAT",e)}))}_removeCaptureReceiver(){this._captureReceiver?.destroy(),this._captureReceiver=null}_applyConsumerSettings(){let e=this._mediaSource.getMediaSettings().isScreenSharingEnabled&&!l.consumerScreenDataChannel?this._serverSettings.screenSharing:this._serverSettings.camera;if(e&&this._pc){let t=[];this._pc.getSenders().forEach(r=>{if(!r.track||r.track.kind!=="video")return;let n=!this._disabledSenders.has(r),s=e.maxDimension!==0;if(n&&!s){c.log("Disabling video upload"),this._disabledSenders.add(r),r.replaceTrack(P.getBlackMediaTrack()).catch(d=>{c.error("Could not disable video upload",d)});return}let o=this._mediaSource.getSendVideoTrack();if(!n&&s&&o){c.log("Enabling video upload"),this._disabledSenders.delete(r);let d=r.track;d.enabled=o.enabled,r.replaceTrack(o).then(()=>d.stop()).catch(p=>{c.error("Could not enable video upload",p)})}I.applyVideoTrackSettings(e,r,o??r.track,this._prevConsumerSettings,t)}),this._prevConsumerSettings=t}}_onScreenSharingStatus(e){e.track?this._createCaptureSender(e.track):this._removeCaptureSender()}_setState(e){this._state!==e&&(this._state=e,this._triggerEvent("STATE_CHANGED",e))}_startStatInterval(){if(this._statInterval)return;let e=()=>{if(!this._pc){this._stopStatInterval();return}this._collectStat().then(t=>{this._reportStats(t),this._detectStaleTracks(t),dt.reportUsage(t)}).catch(()=>{}),this._statInterval=window.setTimeout(e,l.statisticsInterval)};this._statInterval=window.setTimeout(e,l.statisticsInterval)}_stopStatInterval(){this._statInterval&&(window.clearTimeout(this._statInterval),this._statInterval=null),this._statBytes={}}_startSettingsInterval(){if(this._settingsInterval)return;let t=()=>{if(!this._pc){this._stopSettingsInterval();return}this._applyConsumerSettings(),this._settingsInterval=window.setTimeout(t,2e3)};this._settingsInterval=window.setTimeout(t,2e3)}_stopSettingsInterval(){this._settingsInterval&&(window.clearTimeout(this._settingsInterval),this._settingsInterval=null)}async _collectStat(){if(!this._pc)return Promise.reject();this._ssrcMapUpdated&&(this._lastStat=null,this._ssrcMapUpdated=!1,this._createPerfStatsReporter());let e=await yi(this._pc,this._lastStat,this._ssrcMap,!0);return this._lastStat=e,e}_reportStats(e){this._triggerEvent("REMOTE_DATA_STATS",{inbound:{topology:"SERVER",transport:e.transport,rtps:e.rtps.filter(t=>t.type==="inbound-rtp")},outbound:{topology:"SERVER",transport:e.transport,rtps:e.rtps.filter(t=>t.type==="outbound-rtp")},remoteInbound:{topology:"SERVER",transport:e.transport,rtps:e.remoteRtps??[]}})}_detectStaleTracks(e){let t=e.rtps.find(o=>o.type==="inbound-rtp"&&o.kind==="audio"&&this._ssrcMap[o.ssrc]==="mix");if(!t)return;let r=et.AUDIO_MIX,n=this._statBytes[r],s=!1;if(n){let o=t.bytesReceived-n.bytesReceived;o>=0&&o<=5&&(s=!0),n.stalled!==s&&this._triggerEvent("AUDIO_MIX_STALL",s)}this._statBytes[r]={bytesReceived:t.bytesReceived,stalled:s}}_allocateConsumer(){if(!this._signaling.ready)return;let e={estimatedPerformanceIndex:bt.getEstimatedPerformanceIndex(),audioMix:!0,consumerUpdate:!0,producerNotificationDataChannelVersion:l.producerNotificationDataChannel?8:0,producerCommandDataChannelVersion:l.producerCommandDataChannel?3:0,consumerScreenDataChannelVersion:l.consumerScreenDataChannel?1:0,producerScreenDataChannelVersion:l.producerScreenDataChannel?1:0,asrDataChannelVersion:l.asrDataChannel?1:0,animojiDataChannelVersion:l.vmoji?l.vmojiOptions.protocolVersion:1,animojiBackendRender:!l.vmojiOptions.renderingOptions.useFullClientRendering,onDemandTracks:!0,unifiedPlan:!0,singleSession:!0,videoTracksCount:l.videoTracksCount,red:l.serverAudioRed,audioShare:l.audioShare,fastScreenShare:l.fastScreenShare,videoSuspend:l.videoSuspend,simulcast:l.simulcast&&P.isSimulcastSupportedByBrowser()};!l.videoTracksCount&&!this._observer&&c.warn("Setting videoTracksCount to 0 is deprecated"),this._signaling.allocateConsumer(null,e)}async _processOffer(e){if(!this._pc)throw new Error("Interrupt allocation");let t=l.simulcast&&P.isSimulcastSupportedByBrowser(),r=t;try{await this._pc.setRemoteDescription(e)}catch(o){throw c.error("[single] unable to set remote offer",o),R.log(T.ERROR,"setRemoteDescription-single"),o}let n=this._findFirstSimTransceiver();if(t)if(n){c.log(`_processOffer: caps.simulcast=${l.simulcast} mid=${n.mid} dir=${n.direction}`);let o=this._mediaSource.getStream(),d=await this._setupSimulcastTransceiver(o,n);c.log("_processOffer: simulcastInfo",d),d||(c.log(`_processOffer: simulcast transceiver not found in server offer mid=${n.mid}, disable simulcast`),r=!1)}else c.log("_processOffer: simulcast transceiver not found in server offer, disable simulcast"),r=!1;let s;try{if(await this._handleTracks(),c.debug("[single] create local answer"),!this._pc)throw new Error("Interrupt allocation");s=await this._pc.createAnswer()}catch(o){throw c.error("[single] unable to create answer",o),R.log(T.ERROR,"createAnswer-single"),o}try{if(!this._pc)throw new Error("Interrupt allocation");s.sdp=I.patchLocalSDP(s.sdp,!1,P.isBrokenH264Decoder(),!1,l.h264spsPpsIdrInKeyframe),c.debug("[single] set local answer",{answer:s}),await this._pc.setLocalDescription(s)}catch(o){throw c.error("[single] unable to set local answer",o),R.log(T.ERROR,"setLocalDescription-single"),o}if(r&&n){s.sdp=I.patchSimulcastAnswerSdp(s.sdp,n,gt.WIDTH,gt.HEIGHT);for(let o of this._pc.getTransceivers())o.mid===null&&o.stop()}try{c.debug("[single] transmit local answer",{answer:s}),this._updateSSRCMap(e),await this._signaling.acceptProducer(s,Object.keys(this._ssrcMap)),c.debug("[single] remote offer has been processed")}catch(o){c.warn("[single] unable to send local answer",o),R.log(T.ERROR,"acceptProducer")}r&&await this._changeSimulcastInfo(!0,!0)}_findFirstSimTransceiver(){if(!this._pc)return null;for(let e of this._pc.getTransceivers()){let t=e.sender?.track?e.sender.track?.kind:e.receiver?.track?.kind;if(!e.sender||t!=="video")continue;let r=e.sender.getParameters();if(!(!r.encodings||r.encodings.length<=1))return e}return null}async _setupSimulcastTransceiver(e,t){if(!t?.sender||!e)return null;t.direction="sendonly";let r=e.getVideoTracks()[0];await t.sender.replaceTrack(r),t.sender.setStreams(e);let n=t.sender.getParameters();if(!n.encodings||n.encodings.length<=1)return c.log(`_setup:sim: mid=${t.mid} dir=${t.direction}: wrong encodings:${JSON.stringify(n.encodings)}`),null;let s=Ci(gt.WIDTH,gt.HEIGHT,this._serverSettings.camera?.bitrates?.generic),o=0,d=1;for(let u of n.encodings)u.scalabilityMode=bi,u.active=!0,o>=s.streams.length?u.maxBitrate=0:u.maxBitrate=s.streams[o].bitrate,u.scaleResolutionDownBy=d,d=d*2,o++;await t.sender.setParameters(n);let p=r.getSettings();return c.log(`_setup:sim: mid=${t.mid} dir=${t.direction} track=${p.width}x${p.height} encodings=${JSON.stringify(n.encodings)}`),!0}async _acceptProducer(e){if(this._producerOfferIsProcessing){this._producerNextOffer=e,c.debug("[single] wait until other remote offer is processed");return}this._producerOfferIsProcessing=!0;let t={type:"offer",sdp:I.patchRemoteSDP(e,P.isOldDataChannelDescription(),!1,!1,!1,P.isBrokenVP9Encoder(),P.isBrokenVP9Decoder())};if(c.debug("[single] set remote offer",{offer:t}),!this._pc)throw new Error("Interrupt allocation");try{if(await this._processOffer(t),this._producerOfferIsProcessing=!1,this._producerNextOffer){c.debug("[single] there is other unprocessed remote offer, process it");let r=this._producerNextOffer;this._producerNextOffer=null,await this._acceptProducer(r)}}catch(r){this.close(r)}}async _handleTracks(){if(!this._newAudioShareTrack||this._observer)return;let e=this._pc?.getTransceivers().find(t=>t.mid?.endsWith("s"));if(!e||!e.sender){c.warn("Cannot find audioshare transceiver");return}e.sender.track!==null&&c.warn("Unexpected track assigned to audioshare");try{e.direction="sendonly",await e.sender.replaceTrack(this._newAudioShareTrack),this._newAudioShareTrack=null}catch(t){c.error("ServerTransport: Unable to replace track",t),R.log(T.ERROR,"replaceTrack-single")}}async _onSignalingNotification(e){if(this._isOpen)switch(e.notification){case L.PRODUCER_UPDATED:await this._onProducerUpdated(e);break;case L.REALLOC_CON:this._reconnect();break;case L.AUDIO_ACTIVITY:this._signalActiveParticipants(e.activeParticipants);break;case L.SPEAKER_CHANGED:this._signalSpeakerChanged(e.speaker);break;case L.STALLED_ACTIVITY:this._signalStalledParticipants(e.stalledParticipants);break;case L.NETWORK_STATUS:this._signalNetworkStatus(e.statuses);break}}_onAsrTranscription(e){this._triggerEvent("ASR_TRANSCRIPTION",e)}async _onProducerUpdated(e){this._producerSessionId&&this._producerSessionId!==e.sessionId&&this._reconnect(),l.breakVideoPayloadTypes&&(c.log("test mode enabled, video switched off"),this._signaling.requestTestMode("breakVideoPayloadTypes",null)),this._producerSessionId=e.sessionId,await this._acceptProducer(e.description)}_onAddTrack(e,t){c.debug("[single] remote track (added)",{track:t.track});let r=t.streams[0];r?(r.onremovetrack||(r.onremovetrack=s=>{this._triggerEvent("REMOTE_TRACK_REMOVED",r.id,r,s.track)}),r.getTracks().find(s=>s.id===t.track.id)||r.addTrack(t.track),this._rtpReceiversByStreamId[r.id]=t.receiver,this._triggerEvent("REMOTE_TRACK_ADDED",r.id,r,t.track)):c.error("[single] unable to get media stream from track event")}static _onSignalingStateChange(e,t){c.debug("[single] signaling state changed",{state:e.signalingState},t)}_onConnectionStateChange(e,t){switch(c.debug("[single] connection state changed",{state:e.connectionState},t),R.log(T.ICE_CONNECTION_STATE,e.connectionState),e.connectionState){case"failed":this._reconnectionPrevented?this.close(new Error("Ice connection failed")):(R.logCustom(T.RECONNECT,{param:1}),this._reconnect());break;case"connecting":let r=this.getState();r==="IDLE"||r==="OPENED"?this._setState("CONNECTING"):e.iceConnectionState==="checking"&&this._setState("RECONNECTING");break;case"disconnected":this._reconnectionPrevented?this.close(new Error("Ice connection disconnected")):this._setState("RECONNECTING");break;case"connected":this._setState("CONNECTED"),I.getPeerConnectionHostInfo(e).then(n=>{n?.local&&(R.log(T.ICE_CONNECTION_TYPE,n.local.type),c.debug("Selected ICE candidates",n))}),R.logCustom(T.RECONNECT,{param:0});break}}_onReplacedTrack(e,t){if(this._pc){l.consumerScreenDataChannel&&t&&(e=t);let r=(n,s)=>{n.replaceTrack(s).catch(o=>{c.error("ServerTransport: Unable to replace track",o),R.log(T.ERROR,"replaceTrack-single")})};if(c.log(`_onReplacedTrack: newTrack=${e.getSettings().width}x${e.getSettings().height}`),l.simulcast&&P.isSimulcastSupportedByBrowser()&&e.kind==="video"){let s=this._pc?.getTransceivers().find(o=>o.direction==="sendonly"&&o.sender?.track?.kind==="video")?.sender;s?.track?(r(s,e),e.getSettings().width&&e.getSettings().height&&this._changeSimulcastInfo(!1,!1)):c.warn("_onReplacedTrack: simulcast video transceiver not found")}else{let n=this._pc?.getSenders().find(s=>s.track&&s.track.kind===e.kind&&!this._disabledSenders.has(s)&&s.track.contentHint===e.contentHint);n?.track?r(n,e):e.kind==="audio"&&e.contentHint==="music"&&(this._newAudioShareTrack=e)}}this._applyConsumerSettings()}getStreamWaitingTimeMs(e,t){if(!this._pc)return R.log(T.PAT_WAITING_TIME_ERROR,"noConnection"),c.error("Cannot get stream waiting time, peer connection is not initialized"),0;if(!RTCRtpReceiver.prototype.getSynchronizationSources)return R.log(T.PAT_WAITING_TIME_ERROR,"oldBrowser"),c.error("Cannot get stream waiting time, RTCRtpReceiver.getSynchronizationSources is not supported"),0;let r=this._rtpReceiversByStreamId[e];if(!r)return R.log(T.PAT_WAITING_TIME_ERROR,"noReceiver"),c.error(`Cannot get stream waiting time, cannot find RTP receiver by stream ID: ${e}`),0;let n=r.getSynchronizationSources();if(!n||!n.length)return c.log(`Cannot get stream waiting time, ${e} receiver has no synchronization sources`),0;let o=n[0].rtpTimestamp;if(!Number.isInteger(o))return R.log(T.PAT_WAITING_TIME_ERROR,"timestampNotInteger"),c.error(`Cannot get stream waiting time, ${e} receiver's RTP timestamp is not an integer: ${o}`),0;let d=t-o&gd,p=Math.ceil(d/fd);return Math.min(100,Math.max(0,p))}async _changeSimulcastInfo(e,t){let r=this._mediaSource.getMediaSettings().isVideoEnabled,n=this._findFirstSimTransceiver();if(!l.simulcast||!P.isSimulcastSupportedByBrowser()||!r||!n||!n.sender)return;let s=this._mediaSource.getStream();if(!s)return;let o=s.getVideoTracks()[0],d=o.getSettings().width,p=o.getSettings().height,u=Ci(d,p,this._serverSettings.camera?.bitrates?.generic),h=t||!ba(this._simulcastInfo,u);if(!u.streams.length||!h)return;let g=n.sender.getParameters();if(g.encodings||(g.encodings=[{}]),!(g.encodings.length<=1)){if(c.log(`_changeSimulcastInfo: ${d}x${p} command: ${JSON.stringify(u)} `),e){let b=0;for(let w of g.encodings)w.scaleResolutionDownBy=er(w.rid),w.scalabilityMode=bi,b>=u.streams.length?(w.maxBitrate=0,w.active=!1):(w.active=!0,w.maxBitrate=u.streams[b].bitrate),b++;await n.sender.setParameters?.(g).catch(w=>{c.error("Failed to set sender parameters",g,w)}),c.log(`_changeSimulcastInfo: actual encodings: ${JSON.stringify(g.encodings)} `)}if(this._simulcastInfo=u,u.streams){let b={mediaSource:1,simulcastInfo:u};await this._signaling.changeSimulcast(b)}}}};var tt=(e=>(e.DIRECT="DIRECT",e.SERVER="SERVER",e))(tt||{}),sn=class extends ne{constructor(e,t,r,n){super();this._allocated=[];this._opened=[];this._directTransport=null;this._serverTransport=null;this._dtListeners=[];this._stListeners=[];this._states={};this._localState="IDLE";this._animojiReceiver=null;this._animojiSender=null;this._signaling=t,this._mediaSource=r,this._topology=e,this._serverSettings=n,this.subscribe(this._signaling,De.NOTIFICATION,this._onSignalingNotification.bind(this)),this.subscribe(this._mediaSource,"ANIMOJI_STATUS",this._onAnimojiStatus.bind(this)),this.subscribe(this._mediaSource,"SOURCE_CHANGED",this._onSourceChanged.bind(this)),this._createAnimojiTransport(),e==="SERVER"&&(this._serverTransport=this._createServerTransport())}updateSettings(e){c.log("Update transport settings",e),this._serverSettings=e,this._directTransport&&this._directTransport.updateSettings(e),this._serverTransport&&this._serverTransport.updateSettings(e)}updateStatisticsInterval(){this._directTransport&&this._directTransport.updateStatisticsInterval(),this._serverTransport&&this._serverTransport.updateStatisticsInterval()}allocate(e,t=!1){if(c.log(`Trying allocate participant [${e}]`),this._allocated.indexOf(e)!==-1){c.warn(`The participant [${e}] has already had allocated transport`);return}this._allocated.push(e),this._topology==="DIRECT"&&!this._directTransport&&(this._directTransport=this._createDirectTransport(e,t)),this._topology==="SERVER"&&!this._serverTransport&&(this._serverTransport=this._createServerTransport())}open(e,t=null,r=!1,n=!1){c.log("Trying open participant",{participantIds:e});let s=n;for(let o of e){if(this._opened.indexOf(o)!==-1){c.warn(`The participant [${o}] has already had opened transport`);continue}if(this._allocated.indexOf(o)===-1){c.warn(`The participant [${o}] has no allocated transport`);continue}this._opened.push(o),s=!0}s&&(this._topology==="DIRECT"&&this._directTransport&&this._directTransport.open(t),this._topology==="SERVER"&&this._serverTransport&&(this._serverTransport.open(r),this._setStates(e,this._serverTransport.getState()),this._setLocalState(this._serverTransport.getState())),c.debug("The transport has been opened",e))}close(e){let t=this._allocated.indexOf(e),r=this._opened.indexOf(e);t<0&&c.warn(`The participant [${e}] transport has already deallocated`),this._topology==="DIRECT"&&this._directTransport&&r>=0&&this._releaseDirectTransport(),this._topology==="SERVER"&&(this._serverTransport?.removeParticipant(e),this._setStates([e],"CLOSED")),r>=0&&this._opened.splice(r,1),t>=0&&this._allocated.splice(t,1),delete this._states[e]}destroy(){this.unsubscribe();for(let e of this._dtListeners)e.dispose();for(let e of this._stListeners)e.dispose();this._removeAnimojiTransport(),l.audioEffects?.destroy(),this._directTransport?.close(),this._directTransport=null,this._serverTransport?.close(),this._serverTransport=null,this._allocated=[],this._opened=[]}getTopology(){return this._topology}isAllocated(e){return this._allocated.indexOf(e)>=0}allocated(){return this._allocated.slice()}opened(){return this._opened.slice()}getState(){return this._topology==="SERVER"?this._serverTransport?.getState():this._directTransport?.getState()}getStates(){return this._states}setAnimojiSvg(e,t){l.vmoji&&t.isMe&&l.vmoji.AnimojiPreviewGenerator?.setSvgData(t),(!(t.svg instanceof ArrayBuffer)||t.svg.byteLength!==0)&&this._animojiReceiver?.setParticipantSvg(e,t)}setAnimojiFill(e){this._animojiSender?.setFill(e)}async onCameraResolutionChanged(){this._topology==="SERVER"&&this._serverTransport&&await this._serverTransport.onCameraResolutionChanged()}_setStates(e,t){let r=e.filter(n=>this._states[n]!==t?(this._states[n]=t,!0):!1);r.length&&this._triggerEvent("STATE_CHANGED",r,t)}_setLocalState(e){this._localState!==e&&(this._localState=e,this._triggerEvent("LOCAL_STATE_CHANGED",e))}_onSignalingNotification(e){if(e.notification===L.TOPOLOGY_CHANGED)return this._onTopologyChanged(e)}_onTopologyChanged(e){if(e.topology!==this._topology){if(c.log(`Topology changed ${this._topology} -> ${e.topology}`),R.log(T.TOPOLOGY_CHANGE_REQUESTED,e.topology),this._topology=e.topology,this._topology==="SERVER"&&(this._serverTransport?this._serverTransport.allowRestart():(this._serverTransport=this._createServerTransport(),this._opened.length>0&&(this._directTransport?.preventRestart(),this._serverTransport.open()))),this._topology==="DIRECT"){let t=e.offerTo||[],r=e.offerToTypes||[],n=e.offerToDeviceIdxs||[],s=t.length&&r.length?I.composeParticipantId(t[0],r[0],n[0]):null;if(this._serverTransport&&this._serverTransport.preventRestart(),!this._allocated||this._allocated.length===0){c.error("Topology changed to DIRECT, but the list of allocated participants is empty");return}this._allocated.length>1&&c.warn("Topology changed to DIRECT, but the allocated participants count more then one");let o=this._allocated[0];if(this._directTransport)this._directTransport.allowRestart();else{let d=s===o;this._directTransport=this._createDirectTransport(o,d)}this._opened.indexOf(o)>=0&&this._directTransport.open()}this._triggerEvent("TOPOLOGY_CHANGED",this._topology)}}_createDirectTransport(e,t=!1){let r=new Ki(e,t,this._signaling,this._mediaSource,this._serverSettings);return this._dtListeners.length>0&&c.warn(`The list of direct listeners for the participant [${e}] is not empty`),this._dtListeners=[],this._dtListeners.push(r.addEventListener("REMOTE_TRACK_ADDED",this._onRemoteTrackAdded.bind(this,e)),r.addEventListener("REMOTE_TRACK_REMOVED",this._onRemoteTrackRemoved.bind(this,e)),r.addEventListener("REMOTE_DATA_STATS",this._onRemoteDataStats.bind(this)),r.addEventListener("STATE_CHANGED",this._onDirectTransportChanged.bind(this)),r.addEventListener("NETWORK_STATUS",this._onTransportNetworkStatus.bind(this)),r.addEventListener("PEER_CONNECTION_CLOSED",this._onPeerConnectionClosed.bind(this,"DIRECT"))),this._animojiReceiver&&this._animojiSender&&r.setAnimojiTransport(this._animojiReceiver,this._animojiSender),r}_createServerTransport(){let e=new qi(this._signaling,this._mediaSource,this._serverSettings);return this._stListeners.length>0&&c.warn("The list of server transport listeners is not empty"),this._stListeners=[],this._stListeners.push(e.addEventListener("REMOTE_TRACK_ADDED",this._onRemoteTrackAdded.bind(this)),e.addEventListener("REMOTE_TRACK_REMOVED",this._onRemoteTrackRemoved.bind(this)),e.addEventListener("AUDIO_MIX_STALL",this._onServerAudioMixStall.bind(this)),e.addEventListener("REMOTE_DATA_STATS",this._onRemoteDataStats.bind(this)),e.addEventListener("STATE_CHANGED",this._onServerTransportChanged.bind(this)),e.addEventListener("SIGNALLED_ACTIVE_PARTICIPANTS",this._onTransportActiveParticipants.bind(this)),e.addEventListener("SIGNALLED_SPEAKER_CHANGED",this._onTransportSpeakerChanged.bind(this)),e.addEventListener("SIGNALLED_STALLED_PARTICIPANTS",this._onTransportStalledParticipants.bind(this)),e.addEventListener("NETWORK_STATUS",this._onTransportNetworkStatus.bind(this)),e.addEventListener("REMOTE_STREAM_SECOND",this._onRemoteStreamSecond.bind(this)),e.addEventListener("PEER_CONNECTION_CLOSED",this._onPeerConnectionClosed.bind(this,"SERVER")),e.addEventListener("ASR_TRANSCRIPTION",this._onAsrTranscription.bind(this))),this._animojiReceiver&&this._animojiSender&&e.setAnimojiTransport(this._animojiReceiver,this._animojiSender),e}_releaseDirectTransport(){this._directTransport?.close(),this._directTransport=null;for(let e of this._dtListeners)e.dispose();this._dtListeners=[]}_releaseServerTransport(){this._serverTransport?.close(),this._serverTransport=null;for(let e of this._stListeners)e.dispose();this._stListeners=[]}_setLocalNoiseSuppression(e){l.noiseSuppression!==e&&(l.noiseSuppression=e,this._mediaSource?.updateNoiseSuppression())}_onDirectTransportChanged(e){let t=this._directTransport?.participantId;if(e==="CONNECTED"&&this._topology==="DIRECT"&&this._releaseServerTransport(),(e==="CLOSED"||e==="FAILED")&&(this._releaseDirectTransport(),this._topology==="DIRECT")){let r=this._opened.indexOf(t);r>=0&&this._opened.splice(r,1);let n=this._allocated.indexOf(t);n>=0&&this._allocated.splice(n,1)}this._topology==="DIRECT"&&t&&(this._setStates([t],e),this._setLocalState(e))}_onServerTransportChanged(e){let t=this._opened.slice();e==="CONNECTED"&&this._topology==="SERVER"&&this._releaseDirectTransport(),(e==="CLOSED"||e==="FAILED")&&(this._releaseServerTransport(),this._topology==="SERVER"&&(this._allocated=[],this._opened=[])),this._topology==="SERVER"&&(this._setStates(t,e),this._setLocalState(e))}_onTransportActiveParticipants(e){this._topology==="SERVER"&&this._triggerEvent("SIGNALLED_ACTIVE_PARTICIPANTS",e)}_onTransportStalledParticipants(e){this._topology==="SERVER"&&this._triggerEvent("SIGNALLED_STALLED_PARTICIPANTS",e)}_onTransportSpeakerChanged(e){this._topology==="SERVER"&&this._triggerEvent("SIGNALLED_SPEAKER_CHANGED",e)}_onTransportNetworkStatus(e){this._triggerEvent("NETWORK_STATUS",e)}_onRemoteStreamSecond(e,t){this._triggerEvent("REMOTE_STREAM_SECOND",e,t)}_onPeerConnectionClosed(e){this._triggerEvent("PEER_CONNECTION_CLOSED",e)}_onServerAudioMixStall(e){this._topology==="SERVER"&&this._triggerEvent("AUDIO_MIX_STALL",e)}_onRemoteDataStats(e){this._triggerEvent("REMOTE_DATA_STATS",e)}_onRemoteTrackAdded(e,t,r){this._triggerEvent("REMOTE_TRACK_ADDED",e,t,r)}_onRemoteTrackRemoved(e,t,r){this._triggerEvent("REMOTE_TRACK_REMOVED",e,t,r)}_onAsrTranscription(e){this._triggerEvent("ASR_TRANSCRIPTION",e)}_onSourceChanged(){let e=this._mediaSource.getStream();e&&this._animojiSender?.setStream(e)}_onAnimojiStream(e,t){this._triggerEvent("ANIMOJI_STREAM",e,t)}_onAnimojiStatus(e){e?this._animojiSender?.resume():this._animojiSender?.pause(),this._mediaSource.onAnimojiSender(e)}_createAnimojiTransport(){if(!l.vmoji)return;this._animojiReceiver=new l.vmoji.AnimojiReceiver((t,r)=>this._onAnimojiStream(t,r),t=>this._onAnimojiStream(t,null),t=>{this._triggerEvent("ANIMOJI_ERROR",t)},l.vmojiOptions.renderingOptions);let e=this._mediaSource.getStream();this._animojiSender=new l.vmoji.AnimojiSender(e,this._signaling.getPeerId(),l.vmojiOptions.protocolVersion,{requested:this._mediaSource.isAnimojiRequested,useAI:l.vmojiOptions.renderingOptions.useAI}),this._animojiSender.onLocalData=t=>this._animojiReceiver?.receive(t)}_removeAnimojiTransport(){this._animojiSender?.destroy(),this._animojiSender=null,this._animojiReceiver?.destroy(),this._animojiReceiver=null}getStreamWaitingTimeMs(e,t){return this._topology!=="SERVER"?(R.log(T.PAT_WAITING_TIME_ERROR,"wrongTopology"),c.error(`Cannot get stream waiting time, incorrect topology: ${this._topology}`),0):this._serverTransport?this._serverTransport.getStreamWaitingTimeMs(e,t):(R.log(T.PAT_WAITING_TIME_ERROR,"noTransport"),c.error("Cannot get stream waiting time, server transport is not initialized"),0)}};var on=class extends ne{constructor(e){super();this._detector=null;this._interval=null;this.subscribe(e,"REMOTE_TRACK_ADDED",this._onRemoteTrackAdded.bind(this)),this.subscribe(e,"REMOTE_TRACK_REMOVED",this._onRemoteTrackRemoved.bind(this)),this.subscribe(e,"SIGNALLED_ACTIVE_PARTICIPANTS",this._onSignalledActiveParticipants.bind(this)),this.subscribe(e,"TOPOLOGY_CHANGED",this._onTopologyChanged.bind(this))}destroy(){this._interval&&(window.clearTimeout(this._interval),this._interval=null),this.unsubscribe(),this._detector?.destroy(),this._detector=null}_onRemoteTrackAdded(e,t,r){if(r.kind==="audio"&&(this._detector?.destroy(),this._detector=new Et(e,r),!this._interval)){let n=()=>{this._collectVolumes(),this._interval=window.setTimeout(n,l.voiceParams.interval)};this._interval=window.setTimeout(n,l.voiceParams.interval)}}_onRemoteTrackRemoved(e,t,r){r.kind==="audio"&&(!this._detector||this._detector.track!==r||(this._detector.destroy(),this._detector=null))}_collectVolumes(){if(!this._detector)return;let e={},t=this._detector.trackId,r=this._detector.getLevel();if(t===et.AUDIO_MIX){if(this._activeParticipants)for(let n of this._activeParticipants)e[n]=r}else e[t]=r;this._triggerEvent("VOLUMES_DETECTED",e)}_onSignalledActiveParticipants(e){this._activeParticipants=e}_onTopologyChanged(e){e==="DIRECT"&&(this._activeParticipants=null)}};var cn=class extends ne{constructor(e,t,r){super();this._speakerId=null;this._serverSideSpeakerDetection=!1;this._serverSideSpeakerDetection=r==="SERVER",this.subscribe(e,"VOLUMES_DETECTED",this._onVolumesDetected.bind(this)),this.subscribe(t,"SIGNALLED_SPEAKER_CHANGED",this._onServerSpeakerChanged.bind(this)),this.subscribe(t,"TOPOLOGY_CHANGED",this._onTopologyChanged.bind(this))}destroy(){this.unsubscribe()}_onVolumesDetected(e){if(this._serverSideSpeakerDetection)return;let t=0,r=null;if(Object.keys(e).forEach(n=>{let s=e[n].smoothed;s>t&&s>l.voiceParams.threshold&&(t=s,r=n)}),r&&r!==this._speakerId){let n=this._speakerId&&e.hasOwnProperty(this._speakerId)?e[this._speakerId].smoothed:0;t>n*l.voiceParams.speakerLevelMultiplier&&(this._speakerId=r,this._triggerEvent("SPEAKER_CHANGED",r))}}_onServerSpeakerChanged(e){this._serverSideSpeakerDetection&&this._triggerEvent("SPEAKER_CHANGED",e)}_onTopologyChanged(e){this._serverSideSpeakerDetection=e==="SERVER"}};var $i=class extends ne{constructor(e,t,r){super();this._volumes={};this._participants={};this._connectionTimeout=0;this._volumeTimeout=0;this._transport=e,this._participants=r,this.subscribe(e,"STATE_CHANGED",this._onTransportStateChanged.bind(this)),this.subscribe(t,"VOLUMES_DETECTED",this._onVolumesDetected.bind(this))}destroy(){this.unsubscribe(),this._connectionTimeout&&window.clearTimeout(this._connectionTimeout),this._volumeTimeout&&window.clearTimeout(this._volumeTimeout)}onChangeRemoteMediaSettings(e,t){t.isAudioEnabled||(this._volumes[e]=1),t.isAudioEnabled&&(this._volumes[e]=0)}_onTransportStateChanged(e,t){t==="OPENED"&&(this._connectionTimeout||(this._connectionTimeout=window.setTimeout(this._onConnectionTimeout.bind(this),l.specListenerParams.connectionTimeout)),this._volumeTimeout||(this._volumeTimeout=window.setTimeout(this._onVolumeTimeout.bind(this),l.specListenerParams.volumeTimeout))),t==="FAILED"&&this._connectionTimeout&&(c.warn("Transport failed, send callSpecError"),R.log(T.CALL_SPEC_ERROR,`${this._transport.getTopology()}_CONNECTION_TIMEOUT`))}_onVolumesDetected(e){Object.keys(e).forEach(t=>{this._volumes[t]=Math.max(e[t].real,this._volumes[t]||0)})}_onConnectionTimeout(){let e=r=>r!=="CONNECTED";Object.values(this._transport.getStates()).filter(e).length>0&&(c.warn("There is not connected transport, send callSpecError"),R.log(T.CALL_SPEC_ERROR,`${this._transport.getTopology()}_CONNECTION_TIMEOUT`)),this._connectionTimeout=0}_onVolumeTimeout(){let e=[];Object.keys(this._volumes).forEach(t=>{if(this._volumes[t]>0)return;let r="UNKNOWN",n=this._participants[t];n&&n.platform&&(r=n.platform),e.indexOf(r)<0&&(e.push(r),R.log(T.CALL_SPEC_ERROR,`${this._transport.getTopology()}_VOLUME_TIMEOUT_${r}`))}),e.length&&c.warn("There is silent participant, send callSpecError"),this._volumeTimeout=0}};var dn=class a{static correctHangupReason(i){switch(i){case D.HUNGUP:return"hangup";case D.CANCELED:return"canceled";case D.REJECTED:return"rejected";case D.BUSY:return"busy";case D.FAILED:return"failed";case D.MISSED:return"missed";case D.ANOTHER_DEVICE:return"another_device";case D.REMOVED:return"removed";case D.BANNED:return"banned";case D.VCHAT_DETAILED_ERROR:return"error";default:return"hangup"}}static sendHangupEvent(i,e){if(![D.HUNGUP,D.CANCELED,D.REJECTED,D.FAILED,D.BUSY,D.MISSED,D.ANOTHER_DEVICE,D.REMOVED,D.BANNED,D.VCHAT_DETAILED_ERROR].includes(i.hangup))return;let r=i.custom_error?.vchat_detailed_api_error.code;R.logClientStats({name:T.CALL_FINISH,reason:a.correctHangupReason(i.hangup),call_topology:e==="DIRECT"?"D":"S",...r&&{string_value:r}})}};var ln=class{constructor(){this._isCallMarked=!1;this._isFinished=!1;this._callType=null}markAcceptCall(i){this.mark(i==="DIRECT"?"direct_incoming":"server_incoming")}markAcceptedCall(i){i==="DIRECT"&&this.mark("direct_outgoing")}markParticipantJoined(i){i==="DIRECT"&&this.mark("server_change_topology")}markOnJoin(i){i==="SERVER"&&this.mark("server_join_server")}mark(i){this._isCallMarked||(this._isCallMarked=!0,this._callType=i,Je(T.FIRST_MEDIA_RECEIVED))}measure(){this._isFinished||(this._isFinished=!0,this._callType&&Me.logEventualStat({name:T.FIRST_MEDIA_RECEIVED,call_type:this._callType}))}};var _d=1e3,Sd=1e4;var vd=15,$=class $ extends ne{constructor(e,t){super();this._mediaSource=null;this._conversation=null;this._myLastRequestedLayouts={};this._state="IDLE";this._participantState=Y.CALLED;this._participants={};this._pendingParticipants=new Map;this._transport=null;this._debugInfo=null;this._volumesDetector=null;this._speakerDetector=null;this._localVolumeDetector=null;this._specListener=null;this._activeSpeakerId=null;this._lastSignalledActiveSpeakerId=null;this._isRealTimeAsrRequested=!1;this._serverSettings={camera:null,screenSharing:null};this._lastStalled={};this._audioMixStalled=!1;this._audioFix=null;this._streamByStreamId=new Map;this._streamIdByStreamDescription=new Map;this._streamWaitTimerByStreamDescription=new Map;this._sequenceNumberByStreamDescription=new Map;this._cooldownTimestampByStreamDescription=new Map;this._cooldownQueueCleanupTimer=null;this._changeMediaSettings=I.debounce(async e=>{if(this._signaling.ready)try{await this._signaling.changeMediaSettings(e)}catch(t){if(c.warn("changeMediaSettings failed with error",t),t.message==="chatRoom.maxShareCountExceeded")return this.toggleScreenCapturing({captureScreen:!1,fastScreenSharing:!1,captureAudio:!1})}},100);R.create(e,t),Me.create(),dt.create(()=>this._transport?.getTopology()),this._api=e,this._signaling=new jt,this._onUnload=()=>{this._conversation&&this._api&&(this._api.hangupConversation(this._conversation.id),l.clientEventsLoggingEnabled&&R.logClientEvent({event_type:T.CALL_DECLINED_OR_HANGED_LOCALLY,reason:"none"},!0)),R.destroy(),Me.destroy(),dt.destroy()},window.addEventListener("unload",this._onUnload),this._statFirstMediaReceived=new ln,this._audioOutput=new Fi(this._statFirstMediaReceived),l.videoTracksCount>0&&(this._cooldownQueueCleanupTimer=window.setInterval(this._cleanupCooldownQueue.bind(this),_d))}static current(){return $._current}static hangupAfterInit(){$._activationMutex&&!$._current&&($._delayedHangup=!0)}static id(){return $._current?._conversation?.id||null}async onStart({opponentIds:e,opponentType:t,mediaOptions:r,payload:n="",joiningAllowed:s=!1,requireAuthToJoin:o=!1,onlyAdminCanShareMovie:d,externalIds:p,onFastStart:u}){if($._activationMutex)throw R.log(T.ERROR,"startCall"),c.warn("Conversation: there is already running activation"),new G(D.FAILED);let h=Date.now();$._activationMutex=!0,Ue.startSession();try{this._mediaSource=this._createMediaSource(),await this._mediaSource.request(r);let g=this._mediaSource.getMediaSettings();t===ct.CHAT||e&&e.length>1?this._logWithMediaSettings(T.OUTGOING_MULTIPARTY_CALL,g):this._logWithMediaSettings(T.OUTGOING_CALL,g);let b=await this._startConversation({opponentIds:e,opponentType:t,direction:Ne.OUTGOING,mediaOptions:r,payload:n,joiningAllowed:s,requireAuthToJoin:o,onlyAdminCanShareMovie:d,externalIds:p,startedTime:h,onFastStart:u});if(!this._conversation)throw new G(D.UNKNOWN_ERROR);if(this._participantState=Y.ACCEPTED,this._changeMediaSettings(g),await this._processConnection(b),await this._allocateTransport(),this._createSpeakerDetector(),await this._createSpecListener(),this._signaling.readyToSend(),$._delayedHangup)throw new G(D.CANCELED);return c.debug("Outgoing call",{opponentIds:e,opponentType:t,mediaOptions:r}),await this._processConnectionSharedMovieInfo(b),await this._processConversationUrlSharingInfo(b),E.onLocalStream(this._mediaSource.getStream(),this._mediaSource.getMediaSettings()),E.onConversation(this._conversation.externalId,this._conversation.mediaModifiers,this._getMuteStatesForCurrentRoom(),await this._getMainRoomParticipants()),await this._onConversationParticipantListChunk(b),await this._processPinnedParticipants(b),E.onLocalStatus("WAITING"),this._toggleJoinAvailability(),this._changeFeatureSet(),this._changeNeedRate(),$._current=this,this._conversation.concurrent&&await this._acceptConcurrent(),this._conversation}catch(g){throw this._close(g,"Unable to start conversation"),g}finally{$._activationMutex=!1}}async onJoin(e){if($._activationMutex)throw R.log(T.ERROR,"joinCall"),c.warn("Conversation: there is already running activation"),new G(D.FAILED);let t=Date.now();$._activationMutex=!0,this._state="PROCESSING",Ue.startSession();try{let r=!!e.observedIds?.length;if(r&&l.videoTracksCount>0)throw c.error("Observer mode: please set videoTracksCount=0"),new G(D.UNSUPPORTED);this._mediaSource=this._createMediaSource(),await this._mediaSource.request(e.mediaOptions,!r);let n=this._mediaSource.getMediaSettings();this._logWithMediaSettings(T.JOIN_CONVERSATION,n);let s=await this._joinConversation(e,t);if(!this._conversation)throw new G(D.UNKNOWN_ERROR);return this._conversation.observer=r,E.onLocalStream(this._mediaSource.getStream(),n),this._conversation.waitingHall?(c.log("In waiting hall"),$._current=this,$._activationMutex=!1,this._signaling.readyToSend(),E.onLocalStatus("WAITING_HALL"),this._conversation):this._onJoinPart2(s)}catch(r){throw $._activationMutex=!1,this._close(r,"Unable to join conversation"),r}}async _onJoinPart2(e){c.debug("Join conversation part 2"),$._activationMutex=!0;try{if(this._participantState=Y.ACCEPTED,!this._conversation||!this._mediaSource)throw new G(D.UNKNOWN_ERROR);if(this._statFirstMediaReceived.markOnJoin(this._conversation.topology),!this._conversation.observer&&!this._isAudienceModeListener()&&this._changeMediaSettings(this._mediaSource.getMediaSettings()),await this._processConnection(e),await this._allocateTransport(),this._createSpeakerDetector(),await this._createSpecListener(),this._signaling.readyToSend(),this._state==="CLOSE")return this._conversation;if($._delayedHangup)throw new G(D.CANCELED);await this._processConnectionSharedMovieInfo(e),await this._processConversationUrlSharingInfo(e),await this._processConnectionAsrInfo(e);let t=await this._extractExternalRoomsData(e.rooms?.rooms,e.rooms?.roomId);return E.onConversation(this._conversation.externalId,this._conversation.mediaModifiers,this._getMuteStatesForCurrentRoom(),await this._getMainRoomParticipants(),t),await this._onConversationParticipantListChunk(e),await this._processPinnedParticipants(e),E.onLocalStatus("WAITING"),this._toggleJoinAvailability(),this._changeNeedRate(),this._state="ACTIVE",this._changeFeatureSet(),$._current=this,this._openTransport(Object.values(await this._getParticipants()),!1),this._conversation.audienceMode&&!this._conversation.restricted&&this._forceOpenTransportForAloneInCall(),this._conversation.recordsInfoByRoom.get(e?.rooms?.roomId??null)&&this._forceOpenTransportForAloneInCall(),this._conversation}catch(t){throw this._close(t,"Unable to join conversation"),t}finally{$._activationMutex=!1}}async _extractExternalRooms(e){let t=e.map(this._convertRoomToExternal.bind(this));return(await Promise.all(t)).filter(n=>!!n)}async _extractExternalRoomsData(e,t){if(!e||!e.length)return;let r={rooms:await this._extractExternalRooms(e)};return t&&(r.roomId=t),r}async onPush(e,t=ie.USER,r,n,s){if($._activationMutex)throw c.warn("Conversation: there is already running activation"),new G(D.REJECTED);$._activationMutex=!0;try{let o=Date.now(),d=await this._prepareConversation(e,t,r,n,s);if(this._mediaSource=this._createMediaSource(),!this._conversation)throw new G(D.UNKNOWN_ERROR);if(!d.conversation.participants.find(u=>u.state===Y.CALLED&&u.id===this._conversation?.userId))throw c.log("Push rejected (there is an active call)"),R.log(T.PUSH,"rejected"),new G(D.REJECTED);if(Ue.startSession(),await this._processConnection(d),this._extractConnectionUrlSharingInfo(d),await this._allocateTransport(),this._createSpeakerDetector(),await this._createSpecListener(),await this._processPinnedParticipants(d),this._signaling.readyToSend(),this._logCallStartEvent(o,Ne.INCOMING),R.log(T.PUSH,"accepted"),$._current=this,$._delayedHangup)throw new G(D.CANCELED);$._activationMutex=!1}catch(o){throw $._activationMutex=!1,this._close(o,"Unable to handle inbound call push"),o}}_isInWaitingHall(e){return!e.conversation||(e.conversation.options||[]).indexOf(Wt.WAITING_HALL)<0?!1:this._isRestricted(e)}_isRestricted(e){let t=(e.conversation.participants||[]).find(r=>I.comparePeerId(r.peerId,e.peerId));return t&&t.restricted||!1}_isAudienceMode(e){return e.conversation?.options?.includes(Wt.AUDIENCE_MODE)||!1}_isAudienceModeListener(){return this._conversation?.audienceMode&&this._conversation?.restricted}async _acceptConcurrent(){if(!this._mediaSource||!this._conversation||!this._transport)throw new G(D.UNKNOWN_ERROR);this._state="PROCESSING";let e=this._mediaSource.getMediaSettings();this._logWithMediaSettings(T.ACCEPT_CONCURRENT,e),c.debug("Concurrent call",{conversationId:this._conversation.id});try{this._statFirstMediaReceived.markAcceptCall(this._transport.getTopology()),await this._signaling.acceptCall(this._mediaSource.getMediaSettings()),E.onCallAccepted(),this._state="ACTIVE",this._participantState=Y.ACCEPTED,this._changeFeatureSet(),this._openTransport(Object.values(await this._getParticipants()),!0)}catch(t){this._close(t,"Unable to accept concurrent call")}}async _getMainRoomParticipants(){let e=await this._getParticipants();return I.mapSharedParticipants(Object.values(e).filter(t=>!t.isInRoom))}_decodeExternalConversationParams(e){let[t,r]=e.split(":"),n=parseInt(t,10);if(isNaN(n))throw new Error("Invalid original length in prefix");let s=atob(r),o=new Uint8Array(s.length);for(let d=0;d<s.length;d++)o[d]=s.charCodeAt(d);try{let p=xs(o,n).reduce((ue,we)=>(ue+=String.fromCharCode(we),ue),""),{srcp:u,stne:h,tkn:g,trne:b,trnp:w,trnu:B,wse:W,wte:Q}=JSON.parse(p);return{token:g,endpoint:W,wt_endpoint:Q,turn_server:{urls:b.split(","),username:B,credential:w},stun_server:{urls:h.split(",")},client_type:u}}catch(d){throw this._close(d,"Can't decompress conversation params"),d}}_logCallStartEvent(e,t){let r={[Ne.OUTGOING]:"outgoing",[Ne.INCOMING]:"incoming",[Ne.JOINING]:"join"};Me.logEventualStat({name:T.CALL_START,value:Date.now()-e,string_value:JSON.stringify({labels:[r[t],"warmup_start"]})})}async accept(e){if(this._state!=="IDLE")throw R.log(T.ERROR,"acceptIncoming"),c.error("Unable to accept a call - invalid state"),new Error("Unable to accept a call - invalid state");if(!this._mediaSource||!this._conversation||!this._transport)throw new G(D.UNKNOWN_ERROR);this._state="PROCESSING",c.debug("Accept incoming call",e);try{await this._mediaSource.request(e);let t=this._mediaSource.getMediaSettings();this._logWithMediaSettings(T.ACCEPT_INCOMING,t),this._changeMediaSettings(t),this._statFirstMediaReceived.markAcceptCall(this._transport.getTopology()),await this._signaling.acceptCall(t),this._participantState=Y.ACCEPTED;let r=this._getMuteStatesForCurrentRoom(),n=Object.keys(r);n.length&&this._onMuteParticipant({muteStates:r,mediaOptions:n,muteAll:!0,stateUpdated:!0}),this._registerParticipantLocalMuteState({muteStates:this._conversation.muteStatesPersonal});let s=await this._signaling.getRooms(this._isCallAdmin());if(s.rooms?.rooms){let d=await this._getParticipants();s.rooms.rooms.forEach(p=>{p.participantIds?.forEach(u=>{d[u]&&(d[u].isInRoom=!0)})})}this._conversation.roomId=s.rooms?.roomId||null;let o=await this._extractExternalRoomsData(s.rooms?.rooms,s.rooms?.roomId);if(E.onCallAccepted(),E.onLocalStream(this._mediaSource.getStream(),t),E.onConversation(this._conversation.externalId,this._conversation.mediaModifiers,this._getMuteStatesForCurrentRoom(),await this._getMainRoomParticipants(),o),l.useParticipantListChunk){let d=await this._getInitialParticiapntListChunk(),p=await this._getParticipants();d?.participants?.forEach(u=>{let h=I.composeId(u),g=p[h];g&&(g.movieShareInfos=u.movieShareInfos)}),await this._onConversationParticipantListChunk({participants:d})}return E.onLocalStatus("WAITING"),this._toggleJoinAvailability(),this._changeNeedRate(),this._state="ACTIVE",this._changeFeatureSet(),this._openTransport(Object.values(await this._getParticipants()),!0),await this._processConversationUrlSharingInfo(),await this._processConnectionAsrInfo(),this._conversation}catch(t){throw this._close(t,"Unable to accept call"),t}}async decline(){if(this._state!=="IDLE")throw R.log(T.ERROR,"declineIncoming"),c.error("Unable to decline a call - invalid state"),new Error("Unable to decline a call - invalid state");this._state="PROCESSING",c.debug("Decline incoming call"),this._logWithMediaSettings(T.DECLINE_INCOMING,this._mediaSource?.getMediaSettings()),this._participantState=Y.HUNGUP,this._signaling.ready&&await this._signaling.hangup(D.REJECTED),this._close(new G(D.REJECTED))}async hangup(){c.debug("Hangup");let e=this._state==="ACTIVE"?D.HUNGUP:D.CANCELED;R.log(T.HANGUP,e),this._signaling.ready?(await this._signaling.hangup(e),this._close(new G(e))):E.onHangup(new G(D.HUNGUP),this._conversation&&this._conversation.id)}async addParticipant(e,t){if(!this._signaling.ready){this._close(new G(D.UNKNOWN_ERROR),"Unable to add participant");return}let r=await this._signaling.addParticipant(e.map(q.toSignaling),t),n=null;r.type==="error"&&(r.error==="call-unfeasible"?n=r.status:n=D.UNKNOWN_ERROR);let s=r.participants;for(let o of s)await this._onAddParticipant(I.composeId(o),o,n)}async addParticipantLegacy(e,t){if(!this._signaling.ready){this._close(new G(D.UNKNOWN_ERROR),"Unable to add participant");return}let r=await this._signaling.addParticipantLegacy(e,t),n=null;r.type==="error"&&(r.error==="call-unfeasible"?n=r.status:n=D.UNKNOWN_ERROR);let s=r.participants;for(let o of s)await this._onAddParticipant(I.composeId(o),o,n)}async removeParticipant(e,t=!1){this._signaling.ready&&(await this._signaling.removeParticipant(e,t),this._onRemoveParticipant(e))}setVolume(e){this._audioOutput.volume=e}updateStatisticsInterval(){this._transport&&this._transport.updateStatisticsInterval()}_openTransport(e,t){if(!this._transport)return;let r=[];for(let n of e)(n.state===Y.CALLED||n.state===Y.ACCEPTED)&&(this._transport.isAllocated(n.id)||this._transport.allocate(n.id,t)),n.state===Y.ACCEPTED&&r.push(n.id);r.length&&this._transport.open(r,null,!!this._conversation?.observer)}async _close(e,t){t&&c.error(t,e),c.debug("Close conversation",e),dn.sendHangupEvent(e,this._transport?.getTopology()),dt.destroy(),this._signaling.readyToSend(!1),e.error?this._signaling.ready&&this._signaling.hangup(D.FAILED):R.log(T.ERROR,e.hangup),$._activationMutex=!1;let r=this._conversation&&this._conversation.id;if([D.CANCELED,D.NOT_FRIENDS,D.CALLEE_IS_OFFLINE,D.CALLER_IS_BLOCKED,D.CALLER_IS_REJECTED].indexOf(e.hangup)!==-1||e.hangup===D.REJECTED&&!e.remote){E.onHangup(e,r),this.destroy();return}if(e.hangup===D.HUNGUP&&(!e.remote||this._isCalledState())){E.onHangup(e,r),this.destroy();return}if(e.hangup===D.MISSED&&!e.remote){E.onHangup(e,r),this.destroy();return}if(this._cooldownQueueCleanupTimer!==null&&(window.clearInterval(this._cooldownQueueCleanupTimer),this._cooldownQueueCleanupTimer=null),(e.hangup===D.SOCKET_CLOSED||e.hangup===D.NOT_FOUND)&&$._current&&!this._conversation){this._cleanupSignaling(),this._cleanupMediaSource();return}if(e.hangup===D.BUSY&&!e.remote){this._cleanupSignaling(),this._cleanupMediaSource();return}this._state="CLOSE",this._participantState=Y.HUNGUP,this._changeFeatureSet(),this._cleanupMediaSource(),await this._cleanupParticipants(),this._cleanupParticipantAgnosticStreams(),this._cleanupTransport(),this._cleanupSpeakerDetector(),this._cleanupSpecListener(),this._cleanupSignaling(),this._api.cleanup(),R.destroy(),Me.destroy(),this._conversation=null,this._myLastRequestedLayouts={},$._current=null,$._delayedHangup=!1,E.onHangup(e||new G(D.UNKNOWN_ERROR),r)}async destroy(){let e=this._conversation&&this._conversation.id;c.debug("Destroy conversation",{conversationId:e}),this._cooldownQueueCleanupTimer!==null&&(window.clearInterval(this._cooldownQueueCleanupTimer),this._cooldownQueueCleanupTimer=null),this._state="CLOSE",this._participantState=Y.HUNGUP,this._cleanupMediaSource(),await this._cleanupParticipants(),this._cleanupParticipantAgnosticStreams(),this._cleanupTransport(),this._cleanupSpeakerDetector(),this._cleanupSpecListener(),this._cleanupSignaling(),this._api.cleanup(),this._cleanupListeners(),R.destroy(),Me.destroy(),this._conversation=null,this._myLastRequestedLayouts={},$._current=null,$._delayedHangup=!1}async _getConversationParams(e){let t=await this._api.getConversationParams(e);c.debug("Api.getConversationParams",t);let r=[],{turn_server:n,stun_server:s}=t;if(s&&r.push(s),n&&n.urls){let o=n.urls.filter((d,p,u)=>u.indexOf(d)===p);o.push(`${o[o.length-1]}?transport=tcp`),r.push({urls:o,username:n.username,credential:n.credential})}return l.iceServers=r,l.wssBase=t.endpoint,t.wt_endpoint&&(l.wtsBase=t.wt_endpoint),l.wssToken=t.token,t.client_type&&(l.clientType=t.client_type),t.external_user_type&&(l.externalUserType=t.external_user_type),t}_setConversationParams({turn_server:e,stun_server:t,endpoint:r,wt_endpoint:n,token:s,client_type:o}){let d=[];if(t&&d.push(t),e&&e.urls){let p=e.urls.filter((u,h,g)=>g.indexOf(u)===h);p.push(`${p[p.length-1]}?transport=tcp`),d.push({urls:p,username:e.username,credential:e.credential})}l.iceServers=d,l.wssBase=r,l.wssToken=s,n&&(l.wtsBase=n),o&&(l.clientType=o)}_addGeoParamsToEndpoint(e,t){return t.isp_as_no&&(e+=`&ispAsNo=${t.isp_as_no}`),t.isp_as_org&&(e+=`&ispAsOrg=${t.isp_as_org}`),t.loc_cc&&(e+=`&locCc=${t.loc_cc}`),t.loc_reg&&(e+=`&locReg=${t.loc_reg}`),e}async _startConversation({opponentIds:e,opponentType:t,direction:r,mediaOptions:n,payload:s="",joiningAllowed:o=!1,requireAuthToJoin:d=!1,onlyAdminCanShareMovie:p,externalIds:u,startedTime:h,onFastStart:g}){Je(T.SIGNALING_CONNECTED);let b=I.uuid();c.debug("Conversation: start",{conversationId:b,opponentIds:e,opponentType:t,direction:r});let w=n.includes(se.VIDEO),B;if(g)try{let Q={deviceId:this._api.deviceId(),sdkVersion:l.sdkVersion,clientAppKey:l.apiKey,platform:l.platform,protocolVersion:l.protocolVersion,domainId:l.domain},ue=JSON.stringify(Q),we=await g({internalParams:ue,conversationId:b,externalIds:u,opponentType:t,mediaOptions:n,isVideo:w,joiningAllowed:o,requireAuthToJoin:d}),z=JSON.parse(we.internalCallerParams);B={endpoint:z.endpoint,wt_endpoint:z.wtEndpoint,id:b,is_concurrent:z.isConcurrent,client_type:z.clientType,rejected_participants:we.rejectedParticipants,stun_server:z.stun,turn_server:z.turn,token:new URL(z.endpoint).searchParams.get("token")??""},c.debug("FastStart",B)}catch{throw new G(D.UNKNOWN_ERROR,{message:"Cannot parse internal params"})}else B=await this._api.startConversation(b,e,t,w,s,o,d,{onlyAdminCanShareMovie:p},u),c.debug("Api.startConversation",B);this._setConversationParams(B);let W=await this._connectSignaling(Ke.START,B);return await this._setConversation(B,W,r),this._logCallStartEvent(h,Ne.OUTGOING),W}async _joinConversation(e,t){Je(T.SIGNALING_CONNECTED);let{conversationId:r,mediaOptions:n,chatId:s,joinLink:o,observedIds:d,payload:p}=e;c.debug("Conversation: join",{conversationId:r,joinLink:o,observedIds:d});let u=n.includes(se.VIDEO),h;if(r)h=await this._api.joinConversation(r,u,s);else if(o)h=await this._api.joinConversationByLink(o,u,d,p);else throw new G(D.UNKNOWN_ERROR);c.debug("Api.joinConversation",h),this._setConversationParams(h);let g=await this._connectSignaling(Ke.JOIN,h);return await this._setConversation(h,g,Ne.JOINING),this._logCallStartEvent(t,Ne.JOINING),g}async _prepareConversation(e,t=ie.USER,r,n,s){Je(T.SIGNALING_CONNECTED),c.debug("Conversation: push",{conversationId:e,type:t,peerId:r});let o=this._api.getUserId();if(!o)throw new G(D.UNKNOWN_ERROR);let d=0,p="",u="",h={id:e,peerId:r,endpoint:p,wt_endpoint:u,is_concurrent:!1,p2p_forbidden:!1,device_idx:0,token:""};if(n){let b=this._decodeExternalConversationParams(n);this._setConversationParams(b),p=s??`${l.wssBase}?userId=${o}&entityType=${t}&deviceIdx=${d}&conversationId=${e}&token=${l.wssToken}`,h.token=b.token,h.endpoint=p,l.wtsBase&&(u=`${l.wtsBase}?userId=${o}&entityType=${t}&deviceIdx=${d}&conversationId=${e}&token=${l.wssToken}`,h.wt_endpoint=u)}else{let b=await this._getConversationParams(e);d=b.device_idx||0,p=s??`${l.wssBase}?userId=${o}&entityType=${t}&deviceIdx=${d}&conversationId=${e}&token=${l.wssToken}`,p=this._addGeoParamsToEndpoint(p,b),h.token=b.token,h.endpoint=p,h.device_idx=d,l.wtsBase&&(u=`${l.wtsBase}?userId=${o}&entityType=${t}&deviceIdx=${d}&conversationId=${e}&token=${l.wssToken}`,u=this._addGeoParamsToEndpoint(u,b),h.wt_endpoint=u)}let g=await this._connectSignaling(Ke.ACCEPT,h);return $._current&&($._current._participantState===Y.ACCEPTED||$._current._participantState===Y.CALLED)?(c.log("Push rejected (busy)"),R.log(T.PUSH,"busy"),this._signaling.ready&&this._signaling.hangup(D.BUSY),Promise.reject(new G(D.BUSY))):($._current&&($._current.destroy(),$._current=null),await this._setConversation(h,g,Ne.INCOMING,t),g)}async _createParticipant(e,t){let r=Object.assign({id:null,externalId:null,mediaSettings:Ce(),participantState:{},state:Y.CALLED,status:null,remoteStream:null,mediaSource:null,platform:null,clientType:null,roles:[],networkRating:1,lastRequestedLayouts:{},muteStates:{},unmuteOptions:[],observedIds:[],isInRoom:!1,markers:null},e);return r.externalId||(r.externalId=await this._getParticipantId(t??r.id)),this._api.cacheExternalId(t??r.id,r.externalId),t&&this._api.mapDecorativeId(t,r.id),r.observedIds?.length&&(r.externalId.observer=!0),e.markers&&(r.markers=this._denormalizeMarkers(r.id,e.markers)),r}async _getParticipantId(e){try{return await this._api.userId(e)}catch(t){throw this._close(new G(D.NETWORK_ERROR),t),t}}async _setConversation(e,t,r,n=ie.USER){let{participants:s}=t.conversation;s.forEach(u=>{let h=I.composeId(u),g=q.fromSignalingParticipant(u,!1);if(g){this._api.cacheExternalId(h,g);let b=I.composeDecorativeId(u),w=q.fromSignalingParticipant(u);b&&w&&(this._api.cacheExternalId(b,w),this._api.mapDecorativeId(u.decorativeUserId,u.id))}});let o=this._api.getUserId(),d=e.device_idx||0;if(!o){let u=(t.conversation.participants||[]).find(h=>I.comparePeerId(h.peerId,t.peerId));if(!u)throw new G(D.UNKNOWN_ERROR);o=Number(u.id),u.idType&&(n=u.idType),u.deviceIdx&&(d=u.deviceIdx),this._api.setUserId(o)}let p=I.composeParticipantId(o,n,d);this._conversation={userId:o,compositeUserId:p,externalId:await this._getExternalIdByParticipantId(p),acceptTime:t.conversation.acceptTime,features:t.conversation.features||[],featuresPerRole:t.conversation.featuresPerRole,id:t.conversation.id||e.id,participantsLimit:t.conversation.participantsLimit||30,topology:t.conversation.topology||"DIRECT",direction:r,concurrent:t.isConcurrent||e.is_concurrent||!1,needRate:!1,chatId:t.conversation.multichatId,roles:[],recordsInfoByRoom:new Map,asrInfoByRoom:new Map,muteStates:new Map,muteStatesPersonal:{},joinLink:e.join_link??t.conversation.joinLink,pinnedParticipantIdByRoom:new Map,mediaModifiers:t.mediaModifiers,options:[],networkRating:1,waitingHall:this._isInWaitingHall(t),observer:!1,asrInfo:t.conversation.asrInfo||null,roomId:t.rooms?.roomId||null,audienceMode:this._isAudienceMode(t),restricted:this._isRestricted(t),urlSharingInfoByRoom:new Map},Ue.conversationId=t.conversation.id||e.id,this._signaling.setConversationId(this._conversation.id),e.p2p_forbidden&&(l.forceRelayPolicy=e.p2p_forbidden),R.log(T.RELAY_POLICY,l.forceRelayPolicy?"1":"0"),this._changeFeatureSet(),this._logDevices()}_updateConversation(e){if(!this._conversation)throw new G(D.UNKNOWN_ERROR);this._conversation.acceptTime=e.conversation.acceptTime,this._conversation.features=e.conversation.features||[],this._conversation.featuresPerRole=e.conversation.featuresPerRole,this._conversation.participantsLimit=e.conversation.participantsLimit||30,this._conversation.topology=e.conversation.topology||"DIRECT",this._conversation.concurrent=e.isConcurrent||!1,this._conversation.chatId=e.conversation.multichatId,this._conversation.mediaModifiers=e.mediaModifiers,this._conversation.waitingHall=!1}_createMediaSource(){let e=new cr;return this.subscribe(e,"SOURCE_CHANGED",this._onLocalMediaStreamChanged.bind(this)),this.subscribe(e,"SCREEN_STATUS",this._onScreenSharingStatus.bind(this)),this._audioFix=new mi(e),e}async _connectSignaling(e,t){this._signaling.setEndpoint(t.endpoint),this._signaling.setWebTransportEndpoint(t.wt_endpoint??null),this.subscribe(this._signaling,De.NOTIFICATION,this._onSignalingNotification.bind(this)),this.subscribe(this._signaling,De.FAILED,this._onSignalingFailed.bind(this)),this.subscribe(this._signaling,De.RECONNECT,this._onSignalingReconnect.bind(this));let r=await this._signaling.connect(e,t);return Me.logEventualStat({name:T.SIGNALING_CONNECTED}),r}async _processConnection(e){await this._registerConnectionParticipants(e),this._processRooms(e),this._processMuteStates(e),this._processRecordInfos(e),this._onOptionsChanged(e.conversation.options),e.chatRoom&&e.chatRoom.totalCount&&this._onChatRoomUpdated(Yr.ATTENDEE,e.chatRoom.totalCount,e.chatRoom.firstParticipants,null,null)}async _onConversationParticipantListChunk(e){let t=e.participants;t&&E.onConversationParticipantListChunk(await this._participantListChunkToExternalChunk(this._createParticipantListChunk(t)))}_createParticipantListChunk(e){return{...{participants:[],countBefore:0,countAfter:0,markerFound:!1},...e}}async _participantListChunkToExternalChunk(e){let t=await this._getParticipants(),r=I.mapSharedParticipants(e.participants.reduce((n,s)=>{let o=I.composeId(s);return t[o]&&n.push(t[o]),n},[]));return{...e,participants:r}}async _registerConnectionParticipants(e){await this._registerParticipants(e.conversation.participants),e.participants?.participants&&await this._registerParticipants(e.participants?.participants);let t=e?.rooms?.rooms??[];for(let r of t)await this._registerParticipants(r?.participants?.participants??[],!0)}async _registerParticipants(e,t=!1){if(!this._conversation)return;let r=e[0]?.externalId?.type;r&&(l.externalUserType=r);let n=await this._getParticipants();for(let s of e){let o=I.composeId(s);if(c.test("Conversation:RegisterParticipant",o),this._isMe(o)){this._conversation.roles=s.roles||[],this._conversation.roles.length&&(c.debug(`Local roles changed: ${s.roles}`),E.onLocalRolesChanged(this._conversation.roles,!0)),this._registerParticipantLocalMuteState(s);continue}if(s.state===Y.HUNGUP||s.state===Y.REJECTED){n[s.id]&&await this._removeParticipant(n[s.id],D.HUNGUP);continue}let d=I.composeDecorativeId(s);this._registerParticipant({id:o,externalId:q.fromSignalingParticipant(s),mediaSettings:Ce(s.mediaSettings),participantState:I.mapParticipantState(s),state:s.state,roles:s.roles||[],status:"WAITING",muteStates:s.muteStates||{},unmuteOptions:s.unmuteOptions||[],observedIds:s.observedIds||[],markers:this._denormalizeMarkers(o,s.markers),movieShareInfos:s.movieShareInfos,isInRoom:t},d);let p=await this._getParticipant(o);p&&s.roles&&s.roles.length&&(c.debug(`Roles for participant [${o}] changed: ${s.roles}`),E.onRolesChanged(p.externalId,s.roles,!0))}}_registerParticipantLocalMuteState({muteStates:e,unmuteOptions:t}){if(!e)return;let r=async()=>{let n=en(e,We.MUTE),s=en(e,We.MUTE_PERMANENT);for(let o of[n,s])o.length&&await this._onMuteParticipant({muteStates:e,unmuteOptions:t,mediaOptions:o,stateUpdated:!0})};I.setImmediate(()=>r().catch(n=>c.error(n)))}_getStatusByTransportState(e){let t=null;return e==="CONNECTED"?t="CONNECTED":e==="CONNECTING"||e==="OPENED"?t="CONNECTING":e==="RECONNECTING"&&(t="RECONNECT"),t}_registerParticipantInCache(e){return this._participants[e.id]=e,e}async _getExistedParticipantByIdOrCreate(e){let r=(await this._getParticipants())[e];if(r)return r;let n=this._api.getDecorativeIdByInitialId(I.decomposeId(e).id),s=n?I.composeUserId(n):void 0;return this._createParticipant({id:e},s)}async _getExternalIdByParticipantId(e){if(this._isMe(e))return this._conversation?.externalId;if(l.useParticipantListChunk)return(await this._getExistedParticipantByIdOrCreate(e)).externalId;let t=await this._getParticipants();if(t[e]?.externalId)return t[e].externalId;{let r=await this._getParticipantId(e);return this._api.cacheExternalId(e,r),r}}async _registerParticipantAndSetMarkersIfChunkEnabled(e,t){if(l.useParticipantListChunk){let n=this._registerParticipantInCache(await this._getExistedParticipantByIdOrCreate(e));return n.markers=this._denormalizeMarkers(n.id,t),n}return(await this._getParticipants())[e]}_warnParticipantNotInConversation(e){c.warn(`Participant [${e}] isn't in conversation`)}_denormalizeMarkers(e,t){if(!t)return null;let r=Object.values(t).find(n=>"ts"in n&&"rank"in n);return Object.entries(t).reduce((n,[s,o])=>(n[s]={...r,...o,id:e},n),{})}_processRooms(e){let t=e.rooms?.roomId??null;this._onRoomSwitched(t,!0)}_processMuteStates(e,t=!1){let r=Ns(e);this._setMuteStatesForRoomId(r,null);for(let d of e.rooms?.rooms??[])this._setMuteStatesForRoomId(d.muteStates,d.id);let n=this._getMuteStatesForCurrentRoom();t&&(n=Bs(e,n));let s=Object.keys(n),o=this._conversation?.roomId;s.length&&this._onMuteParticipant({muteStates:n,mediaOptions:s,muteAll:!0,stateUpdated:!0,roomId:o},t)}_processRecordInfos(e){this._onRecordInfo(e.conversation?.recordInfo??null);for(let t of e.rooms?.rooms??[])this._onRecordInfo(t.recordInfo??null,t.id)}async _processPinnedParticipants(e){e.conversation.pinnedParticipantId?await this._onPinParticipant(e.conversation.pinnedParticipantId):this._conversation?.pinnedParticipantIdByRoom.delete(null);for(let t of e.rooms?.rooms??[])t.pinnedParticipantId?await this._onPinParticipant(t.pinnedParticipantId,!1,void 0,t.id):this._conversation?.pinnedParticipantIdByRoom.delete(t.id)}async _allocateTransport(){if(!this._conversation||!this._mediaSource)return;this._transport=new sn(this._conversation.topology,this._signaling,this._mediaSource,this._serverSettings),this._debugInfo=new Vi,this.subscribe(this._transport,"STATE_CHANGED",this._onTransportStateChanged.bind(this)),this.subscribe(this._transport,"LOCAL_STATE_CHANGED",this._onTransportLocalStateChanged.bind(this)),this.subscribe(this._transport,"REMOTE_TRACK_ADDED",this._onRemoteTrackAdded.bind(this)),this.subscribe(this._transport,"REMOTE_TRACK_REMOVED",this._onRemoteTrackRemoved.bind(this)),this.subscribe(this._transport,"AUDIO_MIX_STALL",this._onAudioMixStall.bind(this)),this.subscribe(this._transport,"REMOTE_DATA_STATS",this._onRemoteDataStats.bind(this)),this.subscribe(this._transport,"SIGNALLED_STALLED_PARTICIPANTS",this._onRemoteSignalledStall.bind(this)),this.subscribe(this._transport,"TOPOLOGY_CHANGED",this._onTopologyChanged.bind(this)),this.subscribe(this._transport,"NETWORK_STATUS",this._onNetworkStatus.bind(this)),this.subscribe(this._transport,"REMOTE_STREAM_SECOND",this._onRemoteStreamSecond.bind(this)),this.subscribe(this._transport,"PEER_CONNECTION_CLOSED",this._onPeerConnectionClosed.bind(this)),this.subscribe(this._transport,"ASR_TRANSCRIPTION",this._onAsrTranscription.bind(this)),this.subscribe(this._transport,"ANIMOJI_STREAM",this._onAnimojiStream.bind(this)),this.subscribe(this._transport,"ANIMOJI_ERROR",this._onAnimojiError.bind(this));let e=this._conversation.direction===Ne.OUTGOING&&!this._conversation.concurrent,t=await this._getParticipants();for(let r of Object.values(t))(r.state===Y.ACCEPTED||r.state===Y.CALLED)&&this._transport.allocate(r.id,e)}_createSpeakerDetector(){this._transport&&this._conversation&&(this._volumesDetector=new on(this._transport),this.subscribe(this._volumesDetector,"VOLUMES_DETECTED",this._onVolumesDetected.bind(this)),this._speakerDetector=new cn(this._volumesDetector,this._transport,this._conversation.topology),this.subscribe(this._speakerDetector,"SPEAKER_CHANGED",this._onSpeakerChanged.bind(this)),this._localVolumeDetector=new ji(this._mediaSource))}async _createSpecListener(){this._transport&&this._volumesDetector&&(this._specListener=new $i(this._transport,this._volumesDetector,await this._getParticipants()))}_logDevices(){let e=P.getCameras().length,t=P.getMicrophones().length;c.debug("Cameras: "+e+(P.hasCameraPermission()?"✔":"✖")+", Microphones: "+t+(P.hasMicrophonePermission()?"✔":"✖")),R.log(T.DEVICES,`${e}_${t}`)}_logWithMediaSettings(e,t){R.log(e,[t?.isAudioEnabled&&"audio",t?.isVideoEnabled&&"video"].filter(Boolean).join("_"))}async _removeParticipant(e,t){if(e.state===Y.CALLED||e.state===Y.ACCEPTED||this._state==="CLOSE")return;e.id===this._lastSignalledActiveSpeakerId&&(this._lastSignalledActiveSpeakerId=null);let r=await this._getParticipants();if(r[e.id]){t===D.HUNGUP?this._setParticipantsStatus([e],"HANGUP"):this._setParticipantsStatus([e],"ERROR",t),e.mediaSource?.disconnect(),this._conversation&&this._conversation.pinnedParticipantIdByRoom.get(null)===e.id&&this._conversation.pinnedParticipantIdByRoom.delete(null),this._conversation&&this._conversation.roomId&&this._conversation.pinnedParticipantIdByRoom.get(this._conversation.roomId)===e.id&&this._conversation.pinnedParticipantIdByRoom.delete(this._conversation.roomId);for(let[n,s]of Object.entries(e.lastRequestedLayouts))this._streamIdByStreamDescription.delete(n),this._sequenceNumberByStreamDescription.delete(n),this._cooldownTimestampByStreamDescription.delete(n),this._streamWaitTimerByStreamDescription.has(n)&&(window.clearTimeout(this._streamWaitTimerByStreamDescription.get(n)),this._streamWaitTimerByStreamDescription.delete(n)),this._sendUpdateDisplayLayout({[n]:{stopStream:!0}});this._api.unmapDecorativeId(e.id),delete r[e.id],E.onRemoteRemoved(e.externalId,e.markers)}}_cleanupListeners(){this.unsubscribe(),window.removeEventListener("unload",this._onUnload)}_cleanupMediaSource(){this._mediaSource&&(this._mediaSource.destroy(),this._mediaSource=null)}async _cleanupParticipants(){Object.values(await this._getParticipants()).forEach(e=>{e.remoteStream?.getTracks().forEach(t=>t.stop()),e.remoteAudioTrack?.stop(),e.secondStream?.getTracks().forEach(t=>t.stop()),e.mediaSource?.disconnect()}),this._participants={},this._audioOutput&&this._audioOutput.destroy()}_cleanupParticipantAgnosticStreams(){c.debug("cleaning up participant-agnostic streams"),this._streamByStreamId.forEach(e=>{e.getTracks().forEach(t=>{t.stop()})}),this._streamByStreamId=new Map,this._streamWaitTimerByStreamDescription.forEach(e=>{window.clearTimeout(e)}),this._streamWaitTimerByStreamDescription=new Map,this._streamIdByStreamDescription=new Map,this._sequenceNumberByStreamDescription=new Map,this._cooldownTimestampByStreamDescription=new Map}_cleanupTransport(){this._transport&&(this._transport.destroy(),this._transport=null),this._debugInfo&&(this._debugInfo=null)}_cleanupSpeakerDetector(){this._speakerDetector&&(this._speakerDetector.destroy(),this._speakerDetector=null),this._volumesDetector&&(this._volumesDetector.destroy(),this._volumesDetector=null),this._localVolumeDetector&&(this._localVolumeDetector.destroy(),this._localVolumeDetector=null)}_cleanupSpecListener(){this._specListener&&(this._specListener.destroy(),this._specListener=null)}_cleanupSignaling(){this._signaling.close(),this._signaling.cleanup()}async _onAddParticipant(e,t,r){c.debug(`Add new participant [${e}]`);let n=await this._getParticipant(e);if(n&&(n.state===Y.ACCEPTED||n.state===Y.CALLED)){c.warn(`Participant [${n.id}:${n.state}] is already in conversation`);return}if(!n){let s=I.composeDecorativeId(t);this._registerParticipant({id:e,externalId:q.fromSignalingParticipant(t),mediaSettings:Ce(t.mediaSettings),state:t.state,roles:t.roles||[],muteStates:t.muteStates||{},unmuteOptions:t.unmuteOptions||[],observedIds:t.observedIds||[]},s),n=await this._getParticipant(e)}this._setParticipantsStatus([n],"WAITING"),r?(n.state=Y.HUNGUP,await this._removeParticipant(n,r)):this._transport&&(n.state=Y.CALLED,this._transport.allocate(n.id,!0),R.log(T.ADD_PARTICIPANT),this._invokeRolesChangedCallbackIfNeeded(n))}async _onRemoveParticipant(e){c.debug(`Remove participant [${e}]`);let t=[],r=await this._getParticipants();for(let n=0;n<=vd;n++){let s=I.compose(e,n),o=r[s];o&&t.push(o)}if(!t.length){this._warnParticipantNotInConversation(e);return}if(this._transport)for(let n of t)this._transport.close(n.id);R.log(T.REMOVE_PARTICIPANT)}async changeDevice(e){return e==="audiooutput"?this._audioOutput.changeOutput():this._mediaSource?this._mediaSource.changeDevice(e):Promise.reject(re.UNKNOWN)}stopVideoTrack(){return this._mediaSource?.stopVideoTrack()}async toggleScreenCapturing(e){return this._mediaSource?this._mediaSource.toggleScreenCapturing(e):Promise.reject(re.UNKNOWN)}async disableScreenCapturing(){return this._mediaSource?this._mediaSource.disableScreenCapturing():Promise.reject(re.UNKNOWN)}toggleAnimojiCapturing(e){this._mediaSource&&this._mediaSource.toggleAnimojiCapturing(e)}setAnimojiSvg(e,t=null,r=null){if(!this._transport||!this._conversation)return;let n=!t,s=t??this._conversation.compositeUserId;if(e instanceof ArrayBuffer){let o=r??this._conversation.externalId.id;this._transport.setAnimojiSvg(s,{svg:e,userId:o,isMe:n});return}this._transport.setAnimojiSvg(s,{svg:e,isMe:n})}setAnimojiFill(e){this._transport?.setAnimojiFill(e)}async setVideoStream(e,t=!1){if(this._mediaSource)return this._mediaSource.setVideoStream(e,t)}async setAudioStream(e){if(this._mediaSource)return this._mediaSource.setAudioStream(e)}async toggleLocalVideo(e){if(this._mediaSource)return R.log(T.MEDIA_STATUS,e?"video_1":"video_0"),this._mediaSource.toggleVideo(e)}async toggleLocalAudio(e){if(this._mediaSource)return R.log(T.MEDIA_STATUS,e?"audio_1":"audio_0"),this._mediaSource.toggleAudio(e)}async changePriorities(e){if(e.length<2||!this._signaling.ready)return;let t={},r={};for(let s of e){let o=typeof s.uid=="object"?s.uid:q.fromId(s.uid),d=q.toString(o);r[d]=s.priority}let n=await this._getParticipants();for(let s of Object.values(n)){let o=q.toString(s.externalId);r.hasOwnProperty(o)&&(t[s.id]=r[o])}await this._signaling.changePriorities(t)}async changeParticipantState(e,t){for(let[r,n]of Object.entries(e))if(r.length>5||n.length>5)throw new Error("key/value max length is 5 chars, mappings with empty values (null or empty string) are discarded");t&&!this._isCallAdmin()&&(t=void 0),await this._signaling.changeParticipantState(e,t)}async putHandsDown(){this._checkAdminRole(),await this._signaling.putHandsDown()}async requestKeyFrame(e){let t={};return t[at(e)]={keyFrameRequested:!0},this._signaling.updateDisplayLayout(t)}async requestTestMode(e,t){return this._signaling.requestTestMode(e,t)}async updateDisplayLayout(e){if(e.length<1||!this._signaling.ready||this._transport?.getTopology()!=="SERVER")return;c.log(`Update display layout request [${this._signaling.getNextCommandSequenceNumber()}]`,e);let t={},r=await this._getParticipants();for(let s of e){let o=typeof s.uid=="object"?s.uid:q.fromId(s.uid),d=this._api.getCachedOkIdByExternalId(o);if(!d){let h=q.toString(o);c.log(`Unknown participant external ID ${h}`);continue}let p=at({participantId:d,mediaType:s.mediaType,streamName:s.streamName}),u=r[d];u?u.lastRequestedLayouts[p]=s:this._isMe(d)&&(this._myLastRequestedLayouts[p]=s),ai(s)?(this._isMe(d)&&delete this._myLastRequestedLayouts[p],this._streamIdByStreamDescription.has(p)&&!this._cooldownTimestampByStreamDescription.has(p)&&this._cooldownTimestampByStreamDescription.set(p,Date.now())):(this._cooldownTimestampByStreamDescription.delete(p),!this._streamIdByStreamDescription.has(p)&&l.videoTracksCount>0&&this._streamIdByStreamDescription.set(p,null),t[p]=s),s.mediaType==="SCREEN"&&!ai(s)&&Je(Qt(d))}let n=this._cooldownTimestampByStreamDescription.keys();for(;this._streamIdByStreamDescription.size>l.videoTracksCount;){let s=n.next();if(s.done){c.error("Cannot accommodate all streaming requests: tracks available "+l.videoTracksCount+"; requested streams: "+Array.from(this._streamIdByStreamDescription.keys()));break}await this._stopStreaming(s.value),t[s.value]={stopStream:!0}}await this._sendUpdateDisplayLayout(t)}async feedback(e){return this._signaling.feedback(e)}userFeedbackStats(e,t,r){if(this._conversation)if(!l.clientEventsLoggingEnabled)this._api.sendUserFeedbackStats(this._conversation.id,e,t,r);else{let n={event_type:T.USER_FEEDBACK_RECEIVED,user_response:e};t!==void 0&&(n.reason=t),r!==void 0&&(n.group_call_users_count=r),R.logClientEvent(n,!0)}}sendClientEvent(e,t={},r=!1){let n={event_type:e,...t};R.logClientEvent(n,r)}async _stopStreaming(e){if(this._cooldownTimestampByStreamDescription.delete(e),this._sequenceNumberByStreamDescription.set(e,this._signaling.getNextCommandSequenceNumber()),this._streamWaitTimerByStreamDescription.has(e)&&(c.log("Client asked to stop streaming before stream became available",e),window.clearTimeout(this._streamWaitTimerByStreamDescription.get(e)),this._streamWaitTimerByStreamDescription.delete(e)),this._streamIdByStreamDescription.get(e)){let r=await this._getParticipants(),n=Oi(e),s=r[n.participantId],o=this._conversation?.externalId,d=this._isMe(n.participantId);if(s||d){switch(n.mediaType){case"STREAM":case"MOVIE":{if(n.streamName){let p={stream:null,streamName:n.streamName,mediaType:n.mediaType};d?E.onLocalLive(o,p):E.onRemoteLive(s.externalId,p)}break}case"CAMERA":{E.onRemoteStream(s.externalId,null);break}case"SCREEN":{E.onRemoteScreenStream(s.externalId,null);break}}R.log(T.PAT_DEALLOCATED)}else c.log(`Cannot find participant to stop streaming: ${n.participantId}`)}this._streamIdByStreamDescription.delete(e)}async _sendUpdateDisplayLayout(e){if(Object.keys(e).length===0)return;c.log(`Update display layout send [${this._signaling.getNextCommandSequenceNumber()}]`,e);let t=await this._signaling.updateDisplayLayout(e);if(!t)return;let r=[],n=await this._getParticipants();for(let[s,o]of Object.entries(t.errorCodeByParticipantId||{})){let d=Oi(s),p=n[d.participantId];if(p){let u;typeof o!="number"?(c.warn(`Unexpected error code ${o} received for participant ${d.participantId}`),u=ws.UNKNOWN_ERROR):u=Ms(o),r.push({externalId:p.externalId,errorReason:u})}}if(r&&r.length)throw new Zn("Could not allocate one or more participants",r)}async _cleanupCooldownQueue(){let e={},t=this._cooldownTimestampByStreamDescription.entries();do{let r=t.next();if(r.done)break;let n=r.value;if(n[1]+Sd>Date.now())break;let o=n[0];await this._stopStreaming(o),e[o]={stopStream:!0}}while(!0);this._sendUpdateDisplayLayout(e)}_onParticipantSourcesUpdate(e){if(this._conversation){let t=e.participantUpdateInfos;c.log("Received participant sources update notification",t);for(let r of t)this._waitForStreamIfNeeded(r)}}async _onParticipantPromoted(e){this._conversation&&this._conversation.audienceMode?(c.log("Promoted in audience mode",!e.demote),this._conversation.restricted=e.demote,this._processRecordInfos(e),!e.demote&&this._mediaSource&&this._changeMediaSettings(this._mediaSource.getMediaSettings())):(c.log("Promoted in waiting hall",!e.demote),e.demote?(c.log("Kicked from waiting hall"),this._close(new G(D.REMOVED))):(this._updateConversation(e),await this._onJoinPart2(e))),E.onPromoted(e.demote)}async _onChatRoomUpdated(e,t=0,r=[],n,s){c.log(`Chat room updated: ${e}`);let o=[],d=[],p=[],u=[],h=[];if(r.length&&r.forEach(w=>{if(w.externalId){let B=q.fromSignaling(w.externalId);h.push(B),this._api.cacheExternalId(w.id.id,B)}else{let B=I.decomposeId(w.id.id).id;o.push(B),u.push(B)}}),n?.length&&n.forEach(w=>{let B=I.decomposeId(w).id;o.push(B),d.push(B)}),s?.length&&s.forEach(w=>{let B=I.decomposeId(w).id;o.push(B),p.push(B)}),!o.length){E.onChatRoomUpdated(e,t,h,[],[]);return}if(u.length){let w=await this._api.getExternalIdsByOkIds(u);h.push(...w)}let g=await this._api.getExternalIdsByOkIds(d),b=await this._api.getExternalIdsByOkIds(p);E.onChatRoomUpdated(e,t,h,g,b)}async _onSharedMovieUpdate(e){let t=this._conversation?.externalId;for(let r of e.data)if(this._isMe(r.participantId))E.onLocalLiveUpdate(t,r);else{let s=await this._getExternalIdByParticipantId(r.participantId);s&&E.onRemoteLiveUpdate(s,r)}}async _onSharedMovieInfoStarted(e){c.log(`Shared movie started data received: ${e.notification}`),await this._processSharedMovieInfo(e.movieShareInfo,e.roomId)}async _processSharedMovieInfos(e,t=null){e&&await Promise.all(e.map(r=>this._processSharedMovieInfo(r,t)))}async _processSharedMovieInfo(e,t=null){if(!e)return;let r=this._conversation?.externalId;if(this._isMe(e.initiatorId))E.onLocalSharedMovieInfo(r,e,t);else{let s=await this._getExternalIdByParticipantId(e.initiatorId);s&&E.onRemoteSharedMovieInfo(s,e,t)}this._forceOpenTransportForAloneInCall()}async _processConnectionSharedMovieInfo(e){let t=e.conversation.participants.find(r=>this._isMe(I.composeId(r)));await this._processSharedMovieInfos(t?.movieShareInfos,e?.rooms?.roomId??null)}async _processConnectionAsrInfo(e){let t=e?.conversation.asrInfo??this._conversation?.asrInfo;if(t&&this._conversation?.asrInfoByRoom.set(null,t),e?.rooms?.rooms)for(let s of e.rooms.rooms)s.asrInfo&&this._conversation?.asrInfoByRoom.set(s.id,s.asrInfo);let r=e?.rooms?.roomId??this._conversation?.roomId??null,n=this._conversation?.asrInfoByRoom.get(r);if(n){let s=await this._getExternalIdByParticipantId(n.initiatorId);s&&E.onAsrSet({externalId:s,movieId:n.movieId},r)}else r&&E.onAsrSet(null,r)}async _processConversationUrlSharingInfo(e){if(!this._conversation)return;e&&this._extractConnectionUrlSharingInfo(e);let{urlSharingInfoByRoom:t}=this._conversation,r=this._conversation.roomId,n=t.get(r);if(n&&!this._isMe(n.initiatorId)){let s=await this._getExternalIdByParticipantId(n.initiatorId);s&&E.onRemoteSharedUrl(s,n.sharedUrl,r)}}_extractConnectionUrlSharingInfo(e){if(!this._conversation)return;let{urlSharingInfoByRoom:t}=this._conversation;if(e.conversation.urlSharingInfo?t.set(null,e.conversation.urlSharingInfo):t.delete(null),e.rooms?.rooms)for(let r of e.rooms.rooms)r.urlSharingInfo?t.set(r.id,r.urlSharingInfo):t.delete(r.id)}async _onSharedMovieInfoStopped(e){c.log(`Shared movie stopped data received: ${e.notification}`);let t=this._conversation?.externalId,{initiatorId:r,movieId:n,source:s,roomId:o=null}=e,d={initiatorId:r,movieId:n,source:s};if(this._isMe(r))E.onLocalSharedMovieStoppedInfo(t,d,o);else{let u=await this._getExternalIdByParticipantId(r);if(u){let g=(await this._getParticipants())[r];g?.movieShareInfos&&(g.movieShareInfos=g.movieShareInfos.filter(b=>b&&b.movieId!==n)),E.onRemoteSharedMovieStoppedInfo(u,d,o)}}}async _onUrlSharingInfoUpdated(e){if(c.log(`Shared URL data received: ${e.notification}`),!this._conversation)return;let{urlSharingInfoByRoom:t,roomId:r}=this._conversation,{initiatorId:n,sharedUrl:s,roomId:o=null}=e;if(s?t.set(o,{sharedUrl:s,initiatorId:n}):t.delete(o),!(!s&&o!==r&&t.has(r))&&(!s||!this._isMe(n))){let d=await this._getExternalIdByParticipantId(n);d&&E.onRemoteSharedUrl(d,s,o)}}_onFeaturesPerRoleChanged(e){c.log(`Features per role changed: ${e.notification}`),E.onFeaturesPerRoleChanged(e.featuresPerRole)}async _waitForStreamIfNeeded(e){let t=this._matchStreamDescription(e.participantStreamDescription);if(!t)return;let{mediaType:r,participantId:n}=t;if(r==="ANIMOJI")return;let s=await this._getParticipant(n);if(l.producerScreenDataChannel&&r==="SCREEN"&&!e.fastScreenShare){c.log("skipping participant-sources-update notification since screenshare will be received over datachannel");return}let o=at(t),d=this._sequenceNumberByStreamDescription.get(o);if(d&&d>e.sequenceNumber){c.warn(`Participant ${n} received outdated PAT response: sequence number ${e.sequenceNumber}; last sent sequence number for given participant is ${d}`),R.log(T.PAT_OUTDATED_RESPONSE);return}s&&e.suspend!==void 0&&r&&(c.debug(`participant-sources-update: mediaType=${r}, suspend=${e.suspend}`),E.onRemoteStreamSuspended(s.externalId,r,e.suspend));let p=e.streamId,u=e.rtpTimestamp?this._getWaitingTime(p,e.rtpTimestamp):0;if(u<=0){this._streamWaitTimerByStreamDescription.delete(o);let h=this._conversation?.externalId,g=this._isMe(n);if(!s&&!g){R.log(T.PAT_ERROR,"participantMissing"),c.error(`Could not find participant by ID: ${n}`);return}let b=g?h:s.externalId,w=this._streamByStreamId.get(p);if(!w){R.log(T.PAT_ERROR,"streamNotFound"),c.error(`Could not find stream by ID: ${p}`);return}R.log(T.PAT_ALLOCATED),this._streamIdByStreamDescription.set(o,p);let B=e.participantStreamDescription?.mediaType;if(B==="STREAM"||B==="MOVIE"){if(e.participantStreamDescription?.streamName){let W={streamName:e.participantStreamDescription.streamName,stream:w,mediaType:B};g?E.onLocalLive(b,W):E.onRemoteLive(b,W)}}else if(l.producerScreenTrack&&B==="SCREEN")E.onRemoteScreenStream(s.externalId,w);else if(!g){let W=(l.producerScreenTrack?null:s.secondStream)||w;E.onRemoteStream(s.externalId,W)}}else{c.debug(`Waiting for ${u} until stream ${p} for ${o} is switched`);let h=window.setTimeout(this._waitForStreamIfNeeded.bind(this,e),u);this._streamWaitTimerByStreamDescription.set(o,h)}}_matchStreamDescription(e){if(!e)return null;if(this._streamIdByStreamDescription.has(at(e)))return e;let t=e.participantId;if(e.mediaType){let r={participantId:t,mediaType:null};if(this._streamIdByStreamDescription.has(at(r)))return r}else{let r={participantId:t,mediaType:"CAMERA"};if(this._streamIdByStreamDescription.has(at(r)))return r;let n={participantId:t,mediaType:"SCREEN"};if(this._streamIdByStreamDescription.has(at(n)))return n}return c.error("Received unrequested allocation",e),null}_getWaitingTime(e,t){if(this._transport)return this._transport.getStreamWaitingTimeMs(e,t);throw new Error("transport is not initialized")}_isCallAdmin(){return this._conversation?I.includesOneOf(this._conversation.roles,[ht.ADMIN,ht.CREATOR]):!1}_checkAdminRole(){if(this._conversation&&!I.includesOneOf(this._conversation.roles,[ht.ADMIN,ht.CREATOR]))throw new Error("You don't have the required permission")}_isCalledState(){return this._participantState===Y.CALLED}async grantRoles(e,t,r){this._checkAdminRole(),await this._signaling.grantRoles(e,t,r)}async startAsr(e){await this._signaling.startAsr(e)}async stopAsr(e){await this._signaling.stopAsr(e)}async requestAsr(e){this._isRealTimeAsrRequested=e,e&&this._forceOpenTransportForAloneInCall(),await this._signaling.requestAsr(e)}async muteParticipant(e=null,t,r=[],n=null){this._checkAdminRole(),await this._signaling.muteParticipant(e,t,r,n)}async enableFeatureForRoles(e,t){await this._signaling.enableFeatureForRoles(e,t)}async pinParticipant(e,t,r=null){this._checkAdminRole(),await this._signaling.pinParticipant(e,t,r),this._conversation?.pinnedParticipantIdByRoom.set(r,t?null:e)}async updateMediaModifiers(e){this._signaling.ready&&this._conversation&&(this._conversation.mediaModifiers=e,await this._signaling.updateMediaModifiers(e))}async enableVideoSuspend(e){this._signaling.ready&&this._conversation&&this._transport?.getTopology()==="SERVER"&&await this._signaling.enableVideoSuspend(e)}async enableVideoSuspendSuggest(e){this._signaling.ready&&this._conversation&&this._transport?.getTopology()==="SERVER"&&await this._signaling.enableVideoSuspendSuggest(e)}async changeOptions(e){if(this._signaling.ready&&this._conversation){this._checkAdminRole(),await this._signaling.changeOptions(e);let t=Ts(this._conversation.options,e);this._onOptionsChanged(t)}}async getWaitingHall(e,t,r){if(!this._signaling)return Promise.reject();let n=null;if(e&&(n=Os(e),n)){let u=this._api.getDecorativeIdByInitialId(n.id);n.id=u?I.composeUserId(u):n.id}let s=await this._signaling.getWaitingHall(n,t,r);if(s.error)return Promise.reject(s.message);let o=s.participants||[],{externalIds:d}=await this._resolveWaitingHallExternalIds(o),p=null;return o.length&&s.hasMore&&(p=ks(o[o.length-1].id)),{participants:d,pageMarker:p,totalCount:s.totalCount||0}}async _resolveWaitingHallExternalIds(e){let t=new Map,r=[],n=[];if(e.length){let s=[];e.forEach(o=>{if(t.set(o.id.id,o.id.addedTs),o.externalId){let d=q.fromSignaling(o.externalId);r.push(o.id.addedTs),n.push(d),this._api.cacheExternalId(o.id.id,d)}else s.push(I.decomposeId(o.id.id).id)}),s.length&&!n.length&&(n=await this._api.getExternalIdsByOkIds(s),r=n.map(o=>{let d=this._api.getCachedOkIdByExternalId(o);return(d?t.get(d):void 0)||Date.now()}))}return{externalIds:n,timestamps:r}}async getAudienceModeHands(){if(!this._signaling.ready)throw new Error("Signaling is not ready");let e=await this._signaling.getHandQueue();if(e.error)return Promise.reject(e.message);let t=e.participants||[],{externalIds:r,timestamps:n}=await this._resolveWaitingHallExternalIds(t);return{timestamps:n,participants:r,totalCount:e.totalCount||0}}async promoteParticipant(e,t){if(this._signaling&&this._conversation)try{if(!I.includesOneOf(this._conversation.options,[Wt.WAITING_HALL,Wt.AUDIENCE_MODE]))throw new Error("Unable to promote a participant in the conversation with current options");if(this._checkAdminRole(),!e&&t)throw new Error("participantId is required");await this._signaling.promoteParticipant(e,t)}catch(r){throw c.warn(`Failed to promote participant ${e}. ${r}`),r}}async requestPromotion(e=!1){this._signaling.ready&&await this._signaling.requestPromotion(e)}async acceptPromotion(e=!1){this._signaling.ready&&await this._signaling.acceptPromotion(e)}async chatMessage(e,t=null){this._signaling.ready&&await this._signaling.chatMessage(e,t)}async chatHistory(e){if(this._signaling.ready){let t=await this._signaling.chatHistory(e);for(let r=t.messages.length-1;r>=0;r--){let n=t.messages[r];await this._onChatMessage(n)}}}async customData(e,t=null){this._signaling.ready&&await this._signaling.customData(e,t)}async createJoinLink(){if(this._conversation){let t=(await this._api.createJoinLink(this._conversation.id)).join_link;if(t)return this._conversation.joinLink=t,t}return Promise.reject()}async removeJoinLink(){if(this._conversation&&(await this._api.removeJoinLink(this._conversation.id)).success){delete this._conversation.joinLink;return}return Promise.reject()}async addMovie({movieId:e,gain:t,metadata:r,lang:n}){let s={movieId:e,lang:n};(t||t===0)&&(s.gain=t),r&&(s.metadata=r);let o=await this._signaling.addMovie(s);if(o.error)throw new Error(o.error);return{movieId:o.movieId,streamType:o.streamType}}async updateMovie(e){let t=await this._signaling.updateMovie(e);if(t.error)throw new Error(t.error)}async removeMovie(e){let t={movieId:e},r=await this._signaling.removeMovie(t);if(r.error)throw new Error(r.error)}async startUrlSharing(e){let t=await this._signaling.startUrlSharing(e);if(t.error)throw new Error(t.error)}async stopUrlSharing(){let e=await this._signaling.stopUrlSharing();if(e.error)throw new Error(e.error)}async updateRooms(e,t){let r=await this._signaling.updateRooms(e,t);if(r.error)throw new Error(r.error)}async activateRooms(e,t){let r=await this._signaling.activateRooms(e,t);if(r.error)throw new Error(r.error)}async switchRoom(e,t){let r=await this._signaling.switchRoom(e,t);if(r.error)throw new Error(r.error)}async removeRooms(e){let t=await this._signaling.removeRooms(e);if(t.error)throw new Error(t.error)}async startStream(e=!1,t=null,r=null,n="DIRECT_LINK",s=null,o=null){let d={movieId:r,name:t,privacy:n,groupId:s,roomId:o,streamMovie:!e},p=await this._signaling.startStream(d);if(p.error)return Promise.reject(p.message)}async stopStream(e=null){if((await this._signaling.stopStream({roomId:e})).error)return Promise.reject()}async publishStream(e=null){if((await this._signaling.publishStream({roomId:e})).error)return Promise.reject()}async recordSetConf(e,t,r=!1,n=null){let s=await this._signaling.recordSetConf({king:e,pawns:t,hideParticipantCount:r,roomId:n});if(s.error)throw new Error(s.error)}async getStreamInfo(){let e=await this._signaling.getRecordStatus();return{movieId:e.recordMovieId,preview:e.recordMoviePreviewUrl}}async setLocalResolution({video:e,effect:t}){if(e.width<l.videoMinWidth||e.height<l.videoMinHeight)throw new Error("Sizes received are less than the `videoMinWidth` or `videoMinHeight`");if(t){if(t.width<l.videoMinWidth||t.height<l.videoMinHeight)throw new Error("Sizes of effect received are less than the `videoMinWidth` or `videoMinHeight`");l.videoEffectMaxHeight=t.height,l.videoEffectMaxWidth=t.width}l.videoMaxWidth=e.width,l.videoMaxHeight=e.height,c.debug("Set local video resolution:",`video ${e.width}x${e.height}`+(t?`, effect ${t.width}x${t.height}`:"")),this._mediaSource&&(await this._mediaSource.setResolution({video:e,effect:t}),this._transport&&await this._transport.onCameraResolutionChanged())}async videoEffect(e){return this._mediaSource?.videoEffect(e)}async audioEffect(e,t){return this._mediaSource?.audioEffect(e?{effects:e,isPreset:t}:null)}_convertExternalIdsToServerExternalIds(e){return e.map(t=>({id:t.id,type:l.externalUserType}))}async getParticipants(e){let t=this._convertExternalIdsToServerExternalIds(e.externalIds),r=await this._signaling.getParticipants(t);if(r.error)throw new Error(r.error);let n=r.participants,s=this._transport?.getState();return Promise.all(n.map(async o=>{let d=I.composeId(o);return this._createParticipant({id:d,externalId:q.fromSignalingParticipant(o),mediaSettings:Ce(o.mediaSettings),participantState:I.mapParticipantState(o),state:o.state,roles:o.roles||[],status:this._getStatusByTransportState(s)??"WAITING",muteStates:o.muteStates||{},unmuteOptions:o.unmuteOptions||[],observedIds:o.observedIds||[],markers:this._denormalizeMarkers(d,o.markers)},o.decorativeUserId)})).then(I.mapSharedParticipants)}async getParticipantListChunk(e){c.log("Request participant list chunk",e);let t=await this._signaling.getParticipantListChunk(e);if(t.error)throw new Error(t.error);let r=this._createParticipantListChunk(t.chunk),n=await this._getParticipants(),s=r.participants.filter(d=>{let p=I.composeId(d);return!n[p]});await this._registerParticipants(s);let o=this._transport?.getState();return r.participants.forEach(d=>{let p=I.composeId(d),u=n[p];u.status=this._getStatusByTransportState(o)??"WAITING",u.movieShareInfos=d.movieShareInfos,Object.assign(u.mediaSettings,Ce(d.mediaSettings)),Object.assign(u.muteStates,d.muteStates),u.unmuteOptions=d.unmuteOptions??u.unmuteOptions,this._openTransport([u],!0)}),this._participantListChunkToExternalChunk(r)}async _getInitialParticiapntListChunk(){let e=l.participantListChunkInitIndex,t=l.participantListChunkInitCount,n=await this._signaling.getParticipantListChunk({listType:"GRID",fromIdx:e,count:t});return c.debug("Get initial participant list chunk",n.chunk),n.chunk}_onLocalMediaStreamChanged(e){if(!this._conversation||!this._mediaSource)return;let t=this._mediaSource.getMediaSettings();c.debug("Local media stream changed",t),e.kind==="audio"&&this._mediaSource&&(this._audioFix=new mi(this._mediaSource)),E.onLocalStreamUpdate(t,e.kind),!this._conversation?.waitingHall&&!this._conversation?.observer&&!this._isAudienceModeListener()&&this._changeMediaSettings(t)}_onScreenSharingStatus(e){let t=this._mediaSource?.getMediaSettings();if(c.log("Screen sharing changed",e.track,t),l.consumerScreenTrack){let r=e.track?new MediaStream([e.track]):null;E.onScreenStream(r,t)}}async _changeRemoteMediaSettings(e,t){c.debug(`Remote media settings changed [${e}]`,t);let r=this._conversation?.externalId;if(this._isMe(e)&&r){E.onLocalMediaSettings(r,t);return}let s=await this._getParticipant(e);if(!s){this._warnParticipantNotInConversation(e);return}s.mediaSettings=t,this._state==="ACTIVE"&&E.onRemoteMediaSettings(s.externalId,t,s.markers),this._specListener&&this._specListener.onChangeRemoteMediaSettings(e,t)}_changeLocalParticipantState(e){c.debug("Local participant state force changed by admin",e),this._state==="ACTIVE"&&E.onLocalParticipantState(e)}async _changeRemoteParticipantState(e,t){c.debug(`Remote participant state changed [${e}]`,t);let r=await this._getParticipant(e);if(!r){this._warnParticipantNotInConversation(e);return}r.participantState=t||{},this._state==="ACTIVE"&&E.onRemoteParticipantState(r.externalId,r.participantState,r.markers)}async _changeMultipleParticipantState(e,t){c.debug("Multiple participants state changed",e);let r=[],n,s=await this._getParticipants();e.forEach((o,d)=>{if(this._isMe(d))n=o;else{let p=s[d];if(!p){this._warnParticipantNotInConversation(d);return}p.participantState=o,r.push({externalId:p.externalId,participantState:{...o},markers:p.markers})}}),this._state==="ACTIVE"&&(n&&E.onLocalParticipantState(n),r.length&&E.onRemoteParticipantsState(r,t))}_invokeRolesChangedCallbackIfNeeded(e){this._state==="ACTIVE"&&e.roles&&e.roles.length&&(c.debug(`Roles for participant [${e.id}] changed: ${e.roles}`),E.onRolesChanged(e.externalId,e.roles,!0))}_onSignalingNotification(e){switch(e.notification){case L.ACCEPTED_CALL:return this._onAcceptedCall(e);case L.HUNGUP:return this._onHungup(e);case L.PARTICIPANT_ADDED:return this._onAddedParticipant(e);case L.PARTICIPANT_JOINED:return this._onJoinedParticipant(e);case L.CLOSED_CONVERSATION:return this._onClosedConversation(e);case L.MEDIA_SETTINGS_CHANGED:return this._onMediaSettingsChanged(e);case L.PARTICIPANT_STATE_CHANGED:return this._onParticipantStateChanged(e);case L.PARTICIPANTS_STATE_CHANGED:return this._onParticipantsStateChanged(e);case L.RATE_CALL_DATA:return this._onNeedRate();case L.FEATURE_SET_CHANGED:return this._onFeatureSetChanged(e);case L.MULTIPARTY_CHAT_CREATED:return this._onMultipartyChatCreated(e);case L.FORCE_MEDIA_SETTINGS_CHANGE:return this._onForceMediaSettingsChange(e);case L.SETTINGS_UPDATE:return this._onSettingsUpdate(e);case L.VIDEO_QUALITY_UPDATE:return this._onVideoQualityUpdate(e);case L.REGISTERED_PEER:return this._onPeerRegistered(e);case L.SWITCH_MICRO:return this._onMicSwitched(e);case L.CHAT_MESSAGE:return this._onChatMessage(e);case L.CUSTOM_DATA:return this._onCustomData(e);case L.RECORD_STARTED:return this._onRecordInfo(e.recordInfo,e.roomId);case L.RECORD_STOPPED:return this._onRecordInfo(null,e.roomId);case L.ROLES_CHANGED:return this._onRolesChanged(e.participantId,e.roles||[]);case L.MUTE_PARTICIPANT:return this._onMuteParticipant(e);case L.PIN_PARTICIPANT:return this._onPinParticipant(e.participantId,e.unpin,e.markers,e.roomId);case L.OPTIONS_CHANGED:return this._onOptionsChanged(e.options||[]);case L.PARTICIPANT_SOURCES_UPDATE:return this._onParticipantSourcesUpdate(e);case L.PROMOTE_PARTICIPANT:return this._onParticipantPromoted(e);case L.CHAT_ROOM_UPDATED:return this._onChatRoomUpdated(e.eventType,e.totalCount,e.firstParticipants,e.addedParticipantIds,e.removedParticipantIds);case L.JOIN_LINK_CHANGED:return this._onJoinLinkChanged(e);case L.FEEDBACK:return this._onFeedback(e);case L.MOVIE_UPDATE_NOTIFICATION:return this._onSharedMovieUpdate(e);case L.MOVIE_SHARE_STARTED:return this._onSharedMovieInfoStarted(e);case L.MOVIE_SHARE_STOPPED:return this._onSharedMovieInfoStopped(e);case L.URL_SHARING_INFO_UPDATED:return this._onUrlSharingInfoUpdated(e);case L.ROOMS_UPDATED:return this._onRoomsUpdated(e);case L.ROOM_UPDATED:return this._onRoomUpdated(e);case L.ROOM_PARTICIPANTS_UPDATED:return this._onRoomParticipantsUpdated(e);case L.FEATURES_PER_ROLE_CHANGED:return this._onFeaturesPerRoleChanged(e);case L.PARTICIPANT_ANIMOJI_CHANGED:return this._onParticipantAnimojiChanged(e);case L.ASR_STARTED:return this._onAsrStart(e);case L.ASR_STOPPED:return this._onAsrStop(e);case L.PROMOTION_APPROVED:return this._onPromotionApproved(e);case L.DECORATIVE_PARTICIPANT_ID_CHANGED:return this._onDecorativeParticipantIdChanged(e);case L.VIDEO_SUSPEND_SUGGEST:return this._onVideoSuspendSuggest(e)}}async _onPromotionApproved(e){let t=await this._getExternalIdByParticipantId(e.adminId);if(!t){this._warnParticipantNotInConversation(e.adminId);return}E.onPromotionApproved(t)}async _onSignalingReconnect(e){if(!this._conversation)return;e.conversation.acceptTime&&(this._conversation.acceptTime=e.conversation.acceptTime),e.conversation.participantsLimit&&(this._conversation.participantsLimit=e.conversation.participantsLimit),e.conversation.features&&(this._conversation.features=e.conversation.features,this._conversation.featuresPerRole=e.conversation.featuresPerRole,this._changeFeatureSet()),await this._processPinnedParticipants(e),e.conversation.state;let t=null;if(e.conversation.participants){let s=Object.keys(await this._getParticipants()),o=[];for(let p of e.conversation.participants){let u=I.composeId(p),h=p.roles||[];if(this._isMe(u)){Bi(this._conversation.roles,h)||this._onRolesChanged(u,h),t=()=>{this._registerParticipantLocalMuteState({muteStates:Us(p),unmuteOptions:p.unmuteOptions})};continue}o.push(u);let g=await this._getParticipant(u);if(!g)await this._onJoinedParticipant({participantId:p.id,participant:p,mediaSettings:p.mediaSettings});else{let b=Ce(p.mediaSettings);Oa(b,g.mediaSettings)||await this._changeRemoteMediaSettings(u,b);let w=I.mapParticipantState(p),B=g.participantState;I.isEqualParticipantState(w,B)||await this._changeRemoteParticipantState(u,w),Bi(h,g.roles)||this._onRolesChanged(g.id,h)}}let d=await this._getParticipants();for(let p of s)o.indexOf(p)<0&&this._removeParticipant(d[p],D.HUNGUP)}let r=e.rooms?.roomId??null;this._conversation.roomId!==r?this._onRoomSwitched(r).then(t):(this._processMuteStates(e,!0),t?.()),this._processRecordInfos(e),this._onOptionsChanged(e.conversation.options)}_onSignalingFailed(e){c.error("Signaling failed",e),this._close(e)}async _onAcceptedCall(e){let t=I.composeMessageId(e),r=I.getPeerIdString(e.peerId);if(c.debug(`Participant accepted call [${t}]`),this._statFirstMediaReceived.markAcceptedCall(this._transport?.getTopology()),this._conversation&&this._isMe(t)){this._close(new G(D.MISSED),"Call accepted on other device");return}let n=await this._getParticipant(t);if(!n){let o=this._api.getDecorativeIdByInitialId(t),d=o?I.composeUserId(o,e.participantType):void 0;n=this._registerParticipantInCache(await this._createParticipant({id:t,mediaSettings:Ce(e.mediaSettings)},d))}n.state=Y.ACCEPTED,n.mediaSettings=Ce(e.mediaSettings),this._logWithMediaSettings(T.ACCEPTED_OUTGOING,n.mediaSettings),this._conversation&&this._conversation.direction===Ne.OUTGOING&&(this._state==="IDLE"||this._state==="PROCESSING")&&(this._state="ACTIVE",this._changeFeatureSet()),this._state==="ACTIVE"&&this._transport&&this._transport.open([n.id],r),await this._changeRemoteMediaSettings(t,n.mediaSettings),await this._changeRemoteParticipantState(t);let s=Object.keys(n.muteStates);s.length&&this._onMuteParticipant({muteStates:n.muteStates,mediaOptions:s,stateUpdated:!0,participantId:t}),this._state==="ACTIVE"&&E.onAcceptedCall(n.externalId)}async _onHungup(e){c.debug(`Participant hungup [${e.participantId}]`,{reason:e.reason});let t=I.composeMessageId(e);if(this._conversation&&this._isMe(t)){this._close(new G(e.reason,{remote:!0}));return}await this._registerParticipantAndSetMarkersIfChunkEnabled(t,e.markers);let r=await this._getParticipant(t);if(!r){this._warnParticipantNotInConversation(t);return}this._transport&&this._transport.close(t),r.state=e.reason===D.REJECTED?Y.REJECTED:Y.HUNGUP,this._state!=="CLOSE"&&this._removeParticipant(r,D.HUNGUP)}async _onAddedParticipant(e){c.debug(`Participant added [${e.participantId}]`);let t=I.composeMessageId(e),r=await this._getParticipant(t);if(r&&r.state!==Y.HUNGUP&&r.state!==Y.REJECTED){c.debug(`Participant [${t}] is already in conversation and is active`);return}if(!r){let{participant:n}=e,s=n.decorativeUserId;this._registerParticipant({id:t,externalId:q.fromSignalingParticipant(n),mediaSettings:Ce(n.mediaSettings),state:n.state,participantState:I.mapParticipantState(n),roles:n.roles||[],muteStates:n.muteStates||{},unmuteOptions:n.unmuteOptions||[],observedIds:n.observedIds||[]},s),r=await this._getParticipant(t)}r.state=Y.CALLED,r.mediaSettings=Ce(e.participant?.mediaSettings),r.participantState=I.mapParticipantState(e.participant),r.roles=e.participant?.roles||[],this._setParticipantsStatus([r],"WAITING"),this._state!=="IDLE"&&this._transport&&this._transport.allocate(r.id,!0),E.onParticipantAdded(r.externalId,r.markers),await this._changeRemoteMediaSettings(t,r.mediaSettings),await this._changeRemoteParticipantState(t,r.participantState),this._invokeRolesChangedCallbackIfNeeded(r)}async _onJoinedParticipant(e){c.debug(`Participant joined [${e.participantId}]`),this._statFirstMediaReceived.markParticipantJoined(this._transport?.getTopology());let t=I.composeMessageId(e),r=await this._getParticipant(t);if(r&&r.state===Y.ACCEPTED){c.warn(`Participant [${t}] is already in conversation and is active`);return}if(!r){let{participant:s}=e,o=s.decorativeUserId;this._registerParticipant({id:t,externalId:q.fromSignalingParticipant(s),mediaSettings:Ce(s.mediaSettings),state:s.state,participantState:I.mapParticipantState(s),roles:s.roles||[],muteStates:s.muteStates||{},movieShareInfos:s.movieShareInfos,unmuteOptions:s.unmuteOptions||[],observedIds:s.observedIds||[],markers:this._denormalizeMarkers(t,s.markers)},o),r=await this._getParticipant(t)}this._conversation&&this._conversation.direction===Ne.OUTGOING&&(this._state==="IDLE"||this._state==="PROCESSING")&&(this._state="ACTIVE",this._changeFeatureSet()),r.state=Y.ACCEPTED,r.mediaSettings=Ce(e.mediaSettings),r.participantState=I.mapParticipantState(e.participant),r.roles=e.participant.roles||[],this._transport?.isAllocated(r.id)?this._setParticipantsStatus([r],"CONNECTED"):this._setParticipantsStatus([r],"WAITING"),this._state!=="IDLE"&&this._transport&&(this._transport.isAllocated(r.id)||this._transport.allocate(r.id,!0),this._transport.open([r.id],null,!!this._conversation?.observer)),E.onParticipantJoined(r.externalId,r.markers),await this._changeRemoteMediaSettings(t,r.mediaSettings),await this._changeRemoteParticipantState(t,r.participantState),this._invokeRolesChangedCallbackIfNeeded(r);let n=Object.keys(r.muteStates);n.length&&this._onMuteParticipant({muteStates:r.muteStates,mediaOptions:n,stateUpdated:!0,participantId:t}),await this._processSharedMovieInfos(r.movieShareInfos)}_onClosedConversation(e){this._toggleJoinAvailability(),this._close(new G(e.reason,{remote:!0}))}async _onMediaSettingsChanged(e){let t=I.composeMessageId(e);await this._registerParticipantAndSetMarkersIfChunkEnabled(t,e.markers),await this._changeRemoteMediaSettings(t,Ce(e.mediaSettings))}async _onParticipantStateChanged(e){let t=I.composeMessageId(e),r=I.mapParticipantState(e);this._isMe(t)?this._changeLocalParticipantState(r):(await this._registerParticipantAndSetMarkersIfChunkEnabled(t,e.markers),await this._changeRemoteParticipantState(t,r))}async _onParticipantsStateChanged(e){let{participants:t,roomId:r}=e,n=t.map(({id:d,markers:p})=>this._registerParticipantAndSetMarkersIfChunkEnabled(d,p));await Promise.all(n);let s=new Map,o=t.map(({id:d,participantState:p})=>this._getExternalIdByParticipantId(d).then(u=>[d,u&&I.mapParticipantState({participantState:p})]));try{(await Promise.all(o)).forEach(([p,u])=>{u&&s.set(p,u)}),await this._changeMultipleParticipantState(s,r)}catch(d){c.warn(`_onParticipantsStateChanged: Failed to get external ids. ${d}`)}}_onNeedRate(){this._conversation&&(this._conversation.needRate=!0,this._changeNeedRate())}_onFeatureSetChanged(e){this._conversation&&(this._conversation.features=e.features,this._conversation.featuresPerRole=e.featuresPerRole,this._changeFeatureSet())}_onMultipartyChatCreated(e){this._conversation&&(this._conversation.chatId=e.chatId,this._toggleJoinAvailability(),E.onMultipartyChatCreated(this._conversation))}async _onForceMediaSettingsChange(e){if(!this._mediaSource)return;let t=this._mediaSource.getMediaSettings(),r=Ce(e.mediaSettings);t.isAudioEnabled!==r.isAudioEnabled&&await this._mediaSource.toggleAudio(r.isAudioEnabled),t.isVideoEnabled!==r.isVideoEnabled&&await this._mediaSource.toggleVideo(r.isVideoEnabled),l.consumerScreenTrack&&t.isScreenSharingEnabled!==r.isScreenSharingEnabled&&await this._mediaSource.toggleScreenCapturing({captureScreen:r.isScreenSharingEnabled,fastScreenSharing:r.isFastScreenSharingEnabled,captureAudio:r.isAudioSharingEnabled})}_onSettingsUpdate(e){c.debug("Got settings update notification",e);let t={camera:e.camera,screenSharing:e.screenSharing};this._serverSettings=Xn(this._serverSettings,t),this._transport&&this._transport.updateSettings(this._serverSettings)}_onVideoQualityUpdate(e){c.debug("Got video quality update notification",e);let t=Math.round(e.quality.maxBitrate/1024),r=e.quality.maxDimension,n={camera:Object.assign({},this._serverSettings.camera,{maxBitrateK:t,maxDimension:r}),screenSharing:null};this._serverSettings=Xn(this._serverSettings,n),this._transport&&this._transport.updateSettings(this._serverSettings)}async _onPeerRegistered(e){let t=I.composeMessageId(e),r=await this._getParticipant(t);r&&(r.clientType=e.clientType,r.platform=e.platform),E.onPeerRegistered()}async _onMicSwitched(e){E.onDeviceSwitched(se.AUDIO,!e.mute),await this.toggleLocalAudio(!e.mute)}async _onChatMessage(e){let t=I.composeMessageId(e),r=await this._getExternalIdByParticipantId(t);if(!r){this._warnParticipantNotInConversation(t);return}E.onChatMessage(e.message,r,e.direct)}async _onCustomData(e){if(e.data.hasOwnProperty("sdk"))return;let t=I.composeMessageId(e),r=await this._getExternalIdByParticipantId(t);if(!r){this._warnParticipantNotInConversation(t);return}E.onCustomData(e.data,r,e.direct)}async _onRecordInfo(e,t=null){if(!this._conversation)return;let r=this._conversation.recordsInfoByRoom.get(t),n=!1;if(!r!=!e?n=!0:r&&e&&(n=r.recordMovieId!==e.recordMovieId||r.recordStartTime!==e.recordStartTime),n)if(this._conversation.recordsInfoByRoom.set(t,e),e){let s=await this._getExternalIdByParticipantId(e.initiator);s?E.onRecordStarted(s,e.recordMovieId,e.recordStartTime,e.recordType,e.recordExternalMovieId,e.recordExternalOwnerId,t):this._warnParticipantNotInConversation(e.initiator)}else E.onRecordStopped(t);e&&this._forceOpenTransportForAloneInCall()}async _changePinnedParticipantForRoom(){if(!this._conversation)return;let e=this._conversation.roomId,t=this._conversation.pinnedParticipantIdByRoom.get(e);if(t&&!this._isMe(t)){let r=await this._getExternalIdByParticipantId(t);r&&E.onPinnedParticipant(r,!1,null,e)}}async _changeRecordInfoForRoom(){if(!this._conversation)return;let e=this._conversation.roomId,t=this._conversation.recordsInfoByRoom.get(e);if(t){let r=await this._getExternalIdByParticipantId(t.initiator);r?E.onRecordStarted(r,t.recordMovieId,t.recordStartTime,t.recordType,t.recordExternalMovieId,t.recordExternalOwnerId,e):this._warnParticipantNotInConversation(t.initiator)}else E.onRecordStopped(e)}async _changeAsrInfoForRoom(){if(!this._conversation)return;let e=this._conversation.roomId,t=this._conversation.asrInfoByRoom.get(e);if(t){let r=await this._getExternalIdByParticipantId(t.initiatorId);r&&E.onAsrSet({externalId:r,movieId:t.movieId},e)}else E.onAsrSet(null,e)}async _changeUrlSharingInfoForRoom(){if(!this._conversation)return;let{roomId:e}=this._conversation,{urlSharingInfoByRoom:t}=this._conversation,r=t.get(e);if(r){let n=await this._getExternalIdByParticipantId(r.initiatorId);n&&E.onRemoteSharedUrl(n,r.sharedUrl,e)}}async _onParticipantAnimojiChanged(e){if(this._conversation){let t=await this._getExternalIdByParticipantId(e.participantId);if(!t){this._warnParticipantNotInConversation(e.participantId);return}E.onParticipantVmojiUpdate(t)}}async _onAsrStart(e){if(!this._conversation)return;let t=e.asrInfo,r=e.roomId||null;this._conversation.asrInfoByRoom.set(r,t);let n=await this._getExternalIdByParticipantId(t.initiatorId);if(!n){this._warnParticipantNotInConversation(t.initiatorId);return}E.onAsrStarted(n,t.movieId,r),this._forceOpenTransportForAloneInCall()}_onAsrStop(e){if(!this._conversation)return;let t=e.roomId||null;t===null&&(this._conversation.asrInfo=null),this._conversation.asrInfoByRoom.delete(t),E.onAsrStopped(t)}async _onAsrTranscription(e){if(!this._conversation)return;let t=await this._getExternalIdByParticipantId(e.participantId);if(!t){this._warnParticipantNotInConversation(e.participantId);return}E.onAsrTranscription(t,e.text,e.timestamp,e.duration)}async _onRolesChanged(e,t){if(this._conversation&&this._isMe(e)&&!Bi(this._conversation.roles,t)){c.debug(`Local roles changed: ${t}`),this._conversation.roles=t,E.onLocalRolesChanged(t),this._processMuteState({mediaOptions:en(this._getMuteStatesForCurrentRoom(),We.MUTE_PERMANENT),stateUpdated:!0}),I.includesOneOf(t,[ht.ADMIN,ht.CREATOR])?this._refreshRooms(!0):t.length||this._onRoomSwitched(null);return}let r=await this._getParticipant(e);r&&!Bi(r.roles,t)&&(c.debug(`Roles for participant [${e}] changed: ${t}`),r.roles=t,E.onRolesChanged(r.externalId,t))}async _onMuteParticipant(e,t=!1){if(!this._conversation)return;let{muteAll:r,muteStates:n={},unmuteOptions:s=[],mediaOptions:o=[],roomId:d=null}=e,p=e.adminId?await this._getParticipant(e.adminId):null;if(e.participantId&&!this._isMe(e.participantId)){if(!this._isCallAdmin()){c.warn(`Not admin got mute states for participant [${e.participantId}]`);return}let u=await this._getParticipant(e.participantId);u&&(c.debug(`Mute states for participant [${e.participantId}] changed`,n),E.onMuteStates(n,s,o,r,e.unmute,u.externalId,p?.externalId,e.stateUpdated,e.requestedMedia,e.roomId));return}if(e.requestedMedia?.length||(r&&!t?this._setMuteStatesForRoomId(n,d):r||(this._conversation.muteStatesPersonal=n)),e.adminId&&this._isMe(e.adminId)){r&&E.onMuteStates(n,s,o,r,e.unmute,null,this._conversation.externalId,e.stateUpdated,e.requestedMedia,e.roomId);return}await this._processMuteState({mediaOptions:o,muteAll:r,unmute:e.unmute,adminId:e.adminId,stateUpdated:e.stateUpdated,requestedMedia:e.requestedMedia,roomId:e.roomId,unmuteOptions:s,muteStates:n})}_changeMuteStatesForRoom(e,t){if(!this._conversation)return;let r=this._getMuteStatesForRoomId(t),n=this._getMuteStatesForRoomId(e),s=Object.keys(r),o=Object.keys(n);this._processMuteState({mediaOptions:Array.from(new Set([...s,...o])),roomId:e,muteAll:!0,stateUpdated:!0})}async _processMuteState(e){if(!this._conversation||!this._mediaSource||this._participantState!==Y.ACCEPTED)return;let{mediaOptions:t=[],muteAll:r,unmute:n,stateUpdated:s,requestedMedia:o,roomId:d=null,unmuteOptions:p=[]}=e,u=e.adminId?await this._getParticipant(e.adminId):null,h=Object.assign({},e.muteStates??this._getMuteStatesForRoomId(d)),g=this._mediaSource.getMediaSettings(),b=Object.entries(h);for(let[w,B]of b){let W=l.newMuteRules&&this._isCallAdmin()&&r;if(!(B!==We.MUTE&&B!==We.MUTE_PERMANENT||W)&&(this._isCallAdmin()&&B===We.MUTE_PERMANENT&&!r&&(h[w]=We.MUTE),!(!t.includes(w)||n)))switch(w){case se.VIDEO:g.isVideoEnabled&&(E.onDeviceSwitched(se.VIDEO,!1),await this.toggleLocalVideo(!1));break;case se.AUDIO:g.isAudioEnabled&&(E.onDeviceSwitched(se.AUDIO,!1),await this.toggleLocalAudio(!1));break;case se.SCREEN_SHARING:g.isScreenSharingEnabled&&(E.onDeviceSwitched(se.SCREEN_SHARING,!1),await this.disableScreenCapturing());break;case se.AUDIO_SHARING:g.isAudioSharingEnabled&&(E.onDeviceSwitched(se.AUDIO_SHARING,!1),await this.toggleScreenCapturing({captureScreen:g.isScreenSharingEnabled,fastScreenSharing:g.isFastScreenSharingEnabled,captureAudio:!1}));break}}E.onMuteStates(h,p,t,r,n,null,u?.externalId,s,o,d)}async _onPinParticipant(e,t=!1,r,n=null){if(!this._conversation)return;let s=this._conversation.pinnedParticipantIdByRoom.get(n);if(s&&s!==e)if(this._isMe(s))E.onLocalPin(!0,n);else{let o=await this._getExternalIdByParticipantId(s);o&&E.onPinnedParticipant(o,!0,this._denormalizeMarkers(e,r),n)}if(this._isMe(e))E.onLocalPin(t,n);else{let o=await this._getExternalIdByParticipantId(e);o&&E.onPinnedParticipant(o,t,this._denormalizeMarkers(e,r),n)}this._conversation.pinnedParticipantIdByRoom.set(n,t?null:e)}_onOptionsChanged(e){this._conversation&&!Es(this._conversation.options,e)&&(this._conversation.options=e,E.onOptionsChanged(e))}async _onNetworkStatus(e){if(this._conversation){let t=[],r=await this._getParticipants();for(let[n,s]of Object.entries(e)){let o;if(this._isMe(n)||n==="")o=this._conversation.networkRating;else if(r[n])o=r[n].networkRating;else continue;if(o!==s)if(this._isMe(n)||n==="")this._conversation.networkRating=s,E.onLocalNetworkStatusChanged(s);else{let d=r[n];d.networkRating=s,t.push({uid:d.externalId,rating:s})}}if(t.length===0)return;c.log("Received network status update: ",e),E.onNetworkStatusChanged(t)}}async _onRemoteStreamSecond(e,t){let r=await this._getParticipant(e);if(r){if(l.producerScreenTrack){E.onRemoteScreenStream(r.externalId,t);return}if(r.secondStream=t,l.videoTracksCount>0){let n=e;if(!this._streamIdByStreamDescription.has(n)){c.error("Received remote stream notification for a participant that has no track associated with it",n);return}let s=this._streamIdByStreamDescription.get(n);if(!s||this._streamWaitTimerByStreamDescription.has(n)){c.log("Delaying secondary stream start/stop until main stream becomes available",n);return}let o=this._streamByStreamId.get(s);if(!o){R.log(T.PAT_ERROR,"streamNotFound"),c.error(`Could not find stream by ID: ${s}`);return}E.onRemoteStream(r.externalId,r.secondStream||o)}else{let n=t||r.remoteStream;n&&E.onRemoteStream(r.externalId,n)}}}async _onAnimojiStream(e,t){if(this._isMe(e)&&this._mediaSource){E.onVmojiStream(t,this._mediaSource.getMediaSettings());return}let r=await this._getParticipant(e);r&&E.onRemoteVmojiStream(r.externalId,t)}async _onAnimojiError(e){try{let t=await this._getExternalIdByParticipantId(e.participantId);t&&(delete e.participantId,E.onVmojiError({...e,externalId:t}))}catch(t){c.warn("_onAnimojiError failed",t)}}_onPeerConnectionClosed(e){e==="SERVER"&&this._cleanupParticipantAgnosticStreams()}_changeFeatureSet(){if(this._conversation){let e=this._state==="ACTIVE",t=this._conversation.features.includes(Qr.ADD_PARTICIPANT);E.onCallState(e,t,this._conversation)}}_changeNeedRate(){this._conversation&&this._conversation.needRate&&E.onRateNeeded()}async _onVolumesDetected(e){let t=[];for(let[r,n]of Object.entries(e)){let s=await this._getParticipant(r);s&&s.externalId&&t.push({uid:s.externalId,volume:n.real})}E.onVolumesDetected(t)}async _onSpeakerChanged(e){this._activeSpeakerId=e;let t=await this._getParticipant(e);t&&this._lastSignalledActiveSpeakerId!==e&&(E.onSpeakerChanged(t.externalId),this._lastSignalledActiveSpeakerId=e)}async _onTransportStateChanged(e,t){c.debug(`Transport state has changed: ${t}`,e);let r=this._getStatusByTransportState(t);if(!r)return;let n=await this._getParticipants(),s=e.reduce((o,d)=>{if(d in n){let p=n[d];o.push(p),t==="CONNECTED"&&(p.remoteStream||(p.mediaSettings&&this._changeRemoteMediaSettings(d,p.mediaSettings),this._changeRemoteParticipantState(d,p.participantState)),this._updateDisplayLayoutFromCache(d))}else this._warnParticipantNotInConversation(d);return o},[]);s.length&&this._setParticipantsStatus(s,r)}async _onTransportLocalStateChanged(e){if(c.debug(`Local transport state has changed: ${e}`),e==="CONNECTED"&&(E.onLocalStatus("CONNECTED"),this._transport?.getTopology()==="SERVER")){let t=Object.values(this._myLastRequestedLayouts);await this.updateDisplayLayout(t)}e==="CONNECTING"&&E.onLocalStatus("CONNECTING"),e==="RECONNECTING"&&E.onLocalStatus("RECONNECT"),e==="FAILED"&&this._transport&&this._transport.allocated().length===0&&(this._signaling.ready&&await this._signaling.hangup(D.FAILED),this._close(new G(D.FAILED),"Transport failed"))}async _onRemoteTrackAdded(e,t,r){if(e.endsWith(et.AUDIO_MIX))c.debug("Remote audio mix track added"),this._audioOutput.add(r),E.onRemoteMixedAudioStream(t);else if(e.startsWith(et.PARTICIPANT_AGNOSTIC_TRACK_PREFIX))c.debug(`Participant-agnostic track added: ${e}`),this._streamByStreamId.set(e,t);else{c.debug(`Remote track added on the participant [${e}]`,{kind:r.kind});let n=await this._getParticipant(e);if(!n){let s=this._api.getDecorativeIdByInitialId(e),o=s?I.composeUserId(s):void 0;c.warn(`Conversation: track added before participant [id: ${e}, decorativeId: ${o}]`),this._registerParticipant({id:e},o),n=await this._getParticipant(e),this._setParticipantsStatus([n],"WAITING"),this._activeSpeakerId===e&&this._lastSignalledActiveSpeakerId!==e&&(E.onSpeakerChanged(n.externalId),this._lastSignalledActiveSpeakerId=e)}if(this._transport&&!this._transport.isAllocated(n.id)&&this._transport.allocate(n.id,!1),r.kind==="audio"&&(this._audioOutput.add(r),l.preserveAudioTracks||(n.remoteAudioTrack=r,t.removeTrack(r))),n.remoteStream!==t&&t.getTracks().length){if(n.remoteStream=t,n.secondStream)return;E.onRemoteStream(n.externalId,t)}n.mediaSettings&&this._changeRemoteMediaSettings(e,n.mediaSettings)}}_onRemoteTrackRemoved(e,t,r){switch(c.debug(`[${e}] remote track (removed)`,{track:r}),r.kind){case"audio":this._removeAudioTrack(e,t,r);break;case"video":case"screen":this._removeVideoTrack(e,t,r);break}}async _removeAudioTrack(e,t,r){if(e!==et.AUDIO_MIX){let n=await this._getParticipant(e);if(!n||n.remoteStream&&n.remoteStream!==t)return}this._audioOutput.remove(r)}_removeVideoTrack(e,t,r){}_onTopologyChanged(e){e==="DIRECT"&&(this._onRemoteSignalledStall([]),this._onAudioMixStall(!1)),this._conversation&&(this._conversation.topology=e,this._changeFeatureSet(),this._isRealTimeAsrRequested&&this._forceOpenTransportForAloneInCall())}_onAudioMixStall(e){this._audioMixStalled!==e&&(this._audioMixStalled=e,c.debug("Audio mix stalled:",e),E.onLocalStatus(e?"RECONNECT":"CONNECTED"))}async _onRemoteSignalledStall(e){let t={},r=[],n=[];c.debug("Participants stalled:",e);let s=await this._getParticipants();for(let o of e){if(t[o]=!0,!this._lastStalled[o]){let d=s[o];d&&r.push(d)}delete this._lastStalled[o]}for(let o of Object.keys(this._lastStalled)){let d=s[o];d&&n.push(d)}r.length&&this._setParticipantsStatus(r,"RECONNECT"),n.length&&this._setParticipantsStatus(n,"CONNECTED"),this._lastStalled=t}async _onRemoteDataStats(e){this._debugInfo&&this._debugInfo.onRemoteDataStats(e,await this._getParticipants()),this._fixAudioDevice(e.outbound.rtps),this._fixVideoDevice(e.outbound.rtps)}_fixAudioDevice(e){!P.hasMicrophone()||!this._audioFix||!this._mediaSource?.getMediaSettings().isAudioEnabled||this._audioFix.fix(e)}_fixVideoDevice(e){!P.hasCamera()||!this._audioFix||!this._mediaSource?.getMediaSettings().isVideoEnabled||this._audioFix.fixVideo(e)}_toggleJoinAvailability(){let e=this._conversation&&this._conversation.chatId,t=e&&this._state!=="CLOSE"||!1;e&&(c.debug("Toggle join availability",{available:t,chatId:e}),E.onJoinStatus(t,e))}async _updateDisplayLayoutFromCache(e){if(this._transport?.getTopology()!=="SERVER")return;let t=await this._getParticipant(e);t&&t.lastRequestedLayouts&&Object.keys(t.lastRequestedLayouts).length&&await this.updateDisplayLayout(Object.values(t.lastRequestedLayouts))}_setParticipantsStatus(e,t,r=null){if(!e.length)return;let n=e.reduce((s,o)=>(o.status!==t&&(o.status=t,s.push(o.externalId)),s),[]);n.length&&E.onRemoteStatus(n,t,r)}_onJoinLinkChanged(e){E.onJoinLinkChanged(e.joinLink)}async _onRoomsUpdated(e){if(this._isCalledState())return;let t={};for(let r of Object.keys(hi)){let n=e.updates[r];n&&(t[r]={rooms:await Promise.all(n?.rooms?.map(this._convertRoomToExternal.bind(this))||[]),roomIds:n?.roomIds,deactivated:n?.deactivated})}E.onRoomsUpdated(t)}async _onRoomUpdated(e){let t=await this._convertRoomToExternal(e.room||null);e.events.some(r=>r===hi.UPDATE)&&(e.muteStates!==void 0&&this._setMuteStatesForRoomId(e.muteStates,e.roomId),e.recordInfo!==void 0&&this._conversation?.recordsInfoByRoom.set(e.roomId,e.recordInfo),e.asrInfo!==void 0&&this._conversation?.asrInfoByRoom.set(e.roomId,e.asrInfo)),this._isCalledState()||E.onRoomUpdated(e.events,e.roomId,t,e.deactivate||null)}async _convertRoomToExternal(e){if(!e)return null;let t=await Promise.all(e.participantIds?.map(o=>this._getExternalIdByParticipantId(o))||[]),r=await Promise.all(e.addParticipantIds?.map(o=>this._getExternalIdByParticipantId(o))||[]),n=await Promise.all(e.removeParticipantIds?.map?.(o=>this._getExternalIdByParticipantId(o))||[]),s=e.pinnedParticipantId?await this._getExternalIdByParticipantId(e.pinnedParticipantId):void 0;return{id:e.id,name:e.name,participantCount:e.participantCount,participantIds:t,addParticipantIds:r,removeParticipantIds:n,participants:e.participants?.participants?await this._participantListChunkToExternalChunk(e.participants):void 0,active:e.active,muteStates:e.muteStates,pinnedParticipantId:s,countdownSec:e.countdownSec,timeoutMs:e.timeoutMs}}async _onRoomParticipantsUpdated(e){let t=this._transport?.getState(),r=e.roomId??null,n=e.addedParticipantIds?.map(b=>I.decomposeId(b).id)||[],s=await this._api.getExternalIdsByOkIds(n),o=e.addedParticipants;if(s.length&&o?.length!==s.length&&!this._isCalledState()){let b=this._convertExternalIdsToServerExternalIds(s);o=(await this._signaling.getParticipants(b)).participants}let d=await Promise.all(o?.map(async b=>{let w=I.composeId(b);return this._createParticipant({id:w,externalId:q.fromSignalingParticipant(b),mediaSettings:Ce(b.mediaSettings),participantState:I.mapParticipantState(b),state:b.state,roles:b.roles||[],status:this._getStatusByTransportState(t)??"WAITING",muteStates:b.muteStates||{},unmuteOptions:b.unmuteOptions||[],observedIds:b.observedIds||[],markers:this._denormalizeMarkers(w,b.markers),isInRoom:r!==null},b.decorativeUserId)})||[]),p=!1;for(let b of d)b.id===this._conversation?.compositeUserId&&(p=!0),this._registerParticipantInCache(b);this._transport?.getState()==="IDLE"&&!this._isCalledState()&&this._openTransport(d,!0);let u=[],h=[];if(e?.removedParticipantMarkers){for(let b of e.removedParticipantMarkers)if(b.GRID?.id){let w=this._getExternalIdByParticipantId(b.GRID.id);h.push(w)}u=await Promise.all(h)}if(p&&await this._onRoomSwitched(r),u){let b=this._conversation?.pinnedParticipantIdByRoom.get(r);if(b){let w=await this._getExternalIdByParticipantId(b);if(w){for(let B of u)if(q.compare(w,B)){this._conversation?.pinnedParticipantIdByRoom.delete(r);break}}}}let g={roomId:r,participantCount:e.participantCount,addedParticipantIds:s,addedParticipants:I.mapSharedParticipants(d),removedParticipantMarkers:e?.removedParticipantMarkers,removedParticipantIds:u};this._isCalledState()||E.onRoomParticipantsUpdated(g)}async _onRoomSwitched(e,t=!1){if(!this._conversation||this._conversation.roomId===e)return;let r=this._conversation.roomId;if(this._conversation.roomId=e,t&&!this._isCalledState()){E.onRoomStart(e);return}this._isCalledState()||E.onRoomSwitched(e),e!==null&&!this._isCallAdmin()&&await this._refreshRooms(!1),this._changePinnedParticipantForRoom(),this._changeRecordInfoForRoom(),this._changeMuteStatesForRoom(e,r),await this._changeAsrInfoForRoom(),await this._changeUrlSharingInfoForRoom()}async _refreshRooms(e){let t;this._isCalledState()||(t=await this._signaling.getRooms(e));let r=t?.rooms?.rooms??[],n=[];for(let s of r){let o=s.id??null;if(this._setMuteStatesForRoomId(s.muteStates,o),this._conversation?.recordsInfoByRoom.set(o,s.recordInfo??null),this._conversation?.pinnedParticipantIdByRoom.set(o,s.pinnedParticipantId??null),s.asrInfo&&this._conversation?.asrInfoByRoom.set(o,s.asrInfo),s.urlSharingInfo?this._conversation?.urlSharingInfoByRoom.set(o,s.urlSharingInfo):this._conversation?.urlSharingInfoByRoom.delete(o),e){let d=await this._getParticipants();await this._registerParticipants(s?.participants?.participants?.filter(u=>!d[I.composeId(u)])||[],!0);let p=await this._convertRoomToExternal(s);p&&n.push(p)}}n.length&&!this._isCalledState()&&E.onRoomsUpdated({[hi.UPDATE]:{rooms:n}})}async _onFeedback(e){let t=[];for(let r of e.feedback){let n={...r,items:[]};for(let s of r.items){let o=await this._getExternalIdByParticipantId(s.participantId);o?n.items.push({...s,participantId:o}):this._warnParticipantNotInConversation(s.participantId)}t.push(n)}E.onFeedback(t,e.roomId)}async _onDecorativeParticipantIdChanged(e){if(!this._conversation||!e.decorativeParticipantId||!e.decorativeExternalParticipantId)return;let{participantId:t,decorativeParticipantId:r,decorativeExternalParticipantId:n}=e,s=this._isMe(t);c.debug(`Decorative participant id changed [${t}]`,e);let o=await this._getExternalIdByParticipantId(t);if(!o){this._warnParticipantNotInConversation(t);return}let d=q.fromSignaling(n,o.deviceIdx);if(E.onParticipantIdChanged(o,d),this._api.cacheExternalId(r,d),this._api.mapDecorativeId(r,t),s)this._conversation.externalId=d;else{let p=await this._getParticipants();p[t].externalId=d}}_onVideoSuspendSuggest(e){!this._conversation||this._conversation.topology!=="SERVER"||(c.debug("Video suspend suggested",e),E.onVideoSuspendSuggest(e.bandwidth))}_isMe(e){return e===this._conversation?.compositeUserId}_getMuteStatesForRoomId(e=null){return this._conversation?.muteStates.get(e)??{}}_getMuteStatesForCurrentRoom(){return this._getMuteStatesForRoomId(this._conversation?.roomId)}_setMuteStatesForRoomId(e={},t=null){this._conversation?.muteStates.set(t,e)}_forceOpenTransportForAloneInCall(){this._transport?.getTopology()==="SERVER"&&this._transport?.getState()==="IDLE"&&!this._isCalledState()&&this._transport.open(this._transport.allocated(),null,!!this._conversation?.observer,!0)}_registerParticipant(e,t){this._pendingParticipants.set(e.id,this._createParticipant(e,t))}async _getParticipants(){if(this._pendingParticipants.size)for(let e of this._pendingParticipants.values()){let t=await e;this._pendingParticipants.delete(t.id),this._participants[t.id]=t}return this._participants}async _getParticipant(e){return(await this._getParticipants())[e]}};$._delayedHangup=!1;var U=$,Zn=class a extends Error{constructor(i,e){super(i),Object.setPrototypeOf(this,a.prototype),this.participantErrors=e}};var qt=null,fi=null;function qs(){qt=null,fi=null}function Id(a){return a?.endsWith("/")?a.slice(0,-1):a}async function pn(a=null,i){let e=Id(a??l.apiBaseUrl);if(e)return e;if((i??l.apiEnv)!=="AUTO")return l.apiEndpoint(i);try{let t=atob("aHR0cHM6Ly9kbnMuZ29vZ2xlL3Jlc29sdmU/bmFtZT12aWRlby5fZW5kcG9pbnQub2sucnUmdHlwZT1UWFQ="),s=(await(await fetch(t,{method:"GET",mode:"cors",cache:"no-cache"})).json())?.Answer[0]?.data;if(!s)throw new Error("Wrong DNS response");return c.debug("Resolved API endpoint",s),s}catch(t){return c.warn("Failed to resolve API endpoint using DNS, default is used",t),l.apiEndpoint(i)}}async function $s(){return qt||fi||(fi=pn(),qt=await fi,fi=null,qt)}async function gi(a,i={},e=!1){if(!window.Blob||!window.navigator.sendBeacon)return;await $s();let t=Js(a,i,e),r=new window.Blob([t],{type:"application/x-www-form-urlencoded"});window.navigator.sendBeacon(`${qt}/fb.do`,r)}async function zi(a,i={},e=!1,t){await $s();let r=Js(a,i,e);return Ed(r,t)}async function Ed(a,i){return new Promise((e,t)=>{let r=new XMLHttpRequest;r.open("POST",`${i??qt}/fb.do`,!0),r.setRequestHeader("Content-type","application/x-www-form-urlencoded"),r.onreadystatechange=()=>{if(r.readyState!==XMLHttpRequest.DONE)return;let n;try{n=JSON.parse(r.responseText)}catch{n={result:r.responseText}}r.status!==200||n.hasOwnProperty("error_msg")?t(n):e(n)},r.send(a)})}async function zs(a,i){try{let e=await fetch(a,{method:"POST",body:i});if(!e.ok)throw new Error(`HTTP error! status: ${e.status}`);let t=await e.text();c.debug("Form data sent successfully",t)}catch(e){throw c.warn("Failed to send form data",e),e}}function Js(a,i={},e=!1){i.method=a,i.format="JSON",i.application_key||(i.application_key=l.apiKey),e||(be.sessionKey?i.session_key=be.sessionKey:be.accessToken&&(i.access_token=be.accessToken));for(let[r,n]of Object.entries(i))typeof n=="object"&&(i[r]=JSON.stringify(n));let t="";for(let[r,n]of Object.entries(i))t&&(t+="&"),t+=`${r}=${encodeURIComponent(n)}`;return t}var Ji=class{async createJoinLink(i){return{join_link:"nop"}}async removeJoinLink(i){return{success:!0}}async getAnonymTokenByLink(i,e){return""}log(i){}logClientStats(i){}logClientEvents(i){}getCachedOkIdByExternalId(i){return null}cacheExternalId(i,e){}mapDecorativeId(i,e){}unmapDecorativeId(i){}getDecorativeIdByInitialId(i){}replaceByInitialIdIdIfExists(i){return typeof i=="string"?parseInt(i,10):i}hangupConversation(i){}sendUserFeedbackStats(i,e,t,r){}async removeHistoryRecords(i){}async getServerTime(){return Date.now()}cleanup(){}};var bd=10,Cd=700,Rd=3e3,_i=class extends Ji{constructor(){super(...arguments);this._userId=null;this._externalUidsCache=new Map;this._decorativeIdToInitialId=new Map;this._initialIdToDecorativeId=new Map}async _callUnsafe(e,t={},r=!1){let n=async s=>{try{return await zi(e,t,r)}catch(o){if(!o.hasOwnProperty("error_msg")&&(s++,c.debug(`${e} network error, attempt ${s}...`),s<bd))return await I.delay(Math.min(s*Cd,Rd)),n(s);throw c.warn(e,"error",o),o}};return n(0)}async _call(e,t={},r=!1){try{return await this._callUnsafe(e,t,r)}catch(n){c.warn("Api call error",n);let s=re.API;switch(n.error_code){case 102:case 103:case 104:return await this.authorize(),this._callUnsafe(e,t,r)}let o={message:n.error_msg,code:n.error_code};switch(n.custom_error&&(o.custom_error=n.custom_error),n.error_code){case 1101:s=D.SERVICE_DISABLED;break;case 300:s=D.NOT_FOUND;break;case 1102:s=D.CALLEE_IS_OFFLINE;break;case 1103:s=D.NOT_FRIENDS;break;case 1104:case 1106:s=D.EXTERNAL_API_ERROR;break;case 1113:s=D.CALLER_IS_REJECTED;break;case 1114:s=D.VCHAT_DETAILED_ERROR;break}throw new G(s,o)}}async userId(e){let t=I.extractOkId(e);if(be.isEmpty())return q.fromId(String(t));this._externalUidsCache.has(t)||await this._getExternalIdsByOkIds([t]);let r=this.getDecorativeIdByInitialId(t);return r&&(t=r),q.fromString(this._externalUidsCache.get(t))}async authorize(){if(this._ensureUuid(),!l.apiKey)throw new G(re.API,{message:"Required argument apiAppKey not passed"});let e={session_data:{version:2,device_id:this._uuid,client_version:l.appVersion,client_type:"SDK_JS"}};return l.authToken&&(e.session_data.auth_token=l.authToken,e.session_data.version=3),this._callUnsafe("auth.anonymLogin",e,!0).then(t=>{t.uid&&(this._userId=Number(t.uid)),be.sessionKey=t.session_key,be.sessionSecretKey=t.session_secret_key}).catch(t=>{throw t.error_code===401&&E.onTokenExpired(),new G(re.AUTH,{message:t.error_msg,code:t.error_code})})}log(e){let t={collector:"ok.mobile.apps.video",data:JSON.stringify({application:`${l.appName}:${l.sdkVersion}`,platform:l.platform,items:e})};gi("log.externalLog",t)}logClientStats(e){let t={app_version:String(l.appVersion),sdk_type:"WEB",sdk_version:l.sdkVersion,version:1,items:e};l.clientStatsPlatform&&(t.platform=l.clientStatsPlatform);let r={data:JSON.stringify(t)};gi("vchat.clientStats",r)}logClientEvents(e){let t={app_version:String(l.appVersion),sdk_type:"WEB",sdk_version:l.sdkVersion,version:1,items:e};l.clientStatsPlatform&&(t.platform=l.clientStatsPlatform);let r={data:JSON.stringify(t)};gi("vchat.clientEvents",r)}async uploadDebugLogs(e,t,r,n){let s={conversationId:e,webrtcPlatform:l.platform,startTime:t,endTime:r},o=await this._callUnsafe("vchat.getLogUploadUrl",s),d=new FormData,p=new Blob([n],{type:"application/json"});d.append("file",p,"log.json");let u=new URL(o.upload_url);return u.searchParams.append("size",p.size.toString()),zs(u.toString(),d)}async joinConversation(e,t=!1,r){let n={conversationId:e,isVideo:t,protocolVersion:l.protocolVersion};return r&&(n.chatId=r),this._call("vchat.joinConversation",n)}async createConversation(e,t="",r=!1,{onlyAdminCanShareMovie:n,audienceMode:s,audioOnly:o}={},d){let p=this._preareStartConversationData({conversationId:e,isVideo:!1,joiningAllowed:!0,payload:t,requireAuthToJoin:r,onlyAdminCanShareMovie:n,audienceMode:s,audioOnly:o,speakerIds:d});return this._startConversation(p)}async startConversation(e,t,r,n=!1,s="",o=!1,d=!1,{onlyAdminCanShareMovie:p}={},u){let h=this._preareStartConversationData({conversationId:e,isVideo:n,joiningAllowed:o,payload:s,requireAuthToJoin:d,onlyAdminCanShareMovie:p,externalIds:u});if(t&&t.length)switch(r){case ct.USER:h.uids=t.join(",");break;case ct.GROUP:h.gid=t[0];break;case ct.CHAT:h.chatId=t[0];break}return this._startConversation(h)}_ensureUuid(){if(!this._uuid){let e=vt.get("uuid");e||(e=I.uuid(),vt.set("uuid",e)),this._uuid=String(e)}}deviceId(){return this._ensureUuid(),this._uuid}_preareStartConversationData({conversationId:e,isVideo:t,payload:r="",joiningAllowed:n=!1,requireAuthToJoin:s=!1,onlyAdminCanShareMovie:o,audienceMode:d=!1,audioOnly:p=!1,speakerIds:u=[],externalIds:h}){let g={conversationId:e,isVideo:t,protocolVersion:l.protocolVersion};if(n&&(g.createJoinLink=!0),r&&(g.payload=r),l.domain&&(g.domainId=l.domain),l.externalDomain&&(g.externalDomain=l.externalDomain),s&&(g.requireAuthToJoin=!0),o!==void 0&&(g.onlyAdminCanShareMovie=o),d&&(g.audienceMode=d),p&&(g.audioOnly=p),u.length){let b=u.map(w=>I.composeUserId(w));g.speakerIds=b.join(",")}return h&&(g.externalIds=h.map(q.toSignaling).join(",")),g}async _startConversation(e){return this._call("vchat.startConversation",e)}async createJoinLink(e){return this._call("vchat.createJoinLink",{conversationId:e})}async removeJoinLink(e){return this._call("vchat.removeJoinLink",{conversationId:e})}async getAnonymTokenByLink(e,t){let r={joinLink:e};t&&(r.anonymName=t);let n=await this._call("vchat.getAnonymTokenByLink",r);return this._userId=Number(n.uid),n.token}async joinConversationByLink(e,t=!1,r,n){let s={joinLink:e,isVideo:t,protocolVersion:l.protocolVersion};return r?.length&&(s.observedIds=r.join(",")),l.anonymToken&&(s.anonymToken=l.anonymToken),n&&(s.payload=n),this._call("vchat.joinConversationByLink",s)}async getOkIdsByExternalIds(e){let t=[],r=[],n=new Map,s=Array.from(this._externalUidsCache.keys()),o=Array.from(this._externalUidsCache.values());for(let p of e){let u=q.toString(p),h=o.indexOf(u);h>-1?t.push(this.replaceByInitialIdIdIfExists(s[h])):(n.set(String(p.id),u),r.push({id:p.id,ok_anonym:p.type==="ANONYM"}))}return r.length&&(await this._call("vchat.getOkIdsByExternalIds",{externalIds:r})).ids.forEach((p,u)=>{let h=Number(p.ok_user_id),g=String(p.external_user_id.id);n.has(g)&&(this.cacheExternalId(h,q.fromString(n.get(g))),t.push(h))}),t}async getParticipantIdsByExternalIds(e){await this.getOkIdsByExternalIds(e);let t=new Map,r=Array.from(this._externalUidsCache.keys()),n=Array.from(this._externalUidsCache.values());for(let s of e){let o=q.toString(s),d=n.indexOf(o);if(d>-1){let p=I.composeParticipantId(this.replaceByInitialIdIdIfExists(r[d]),ie.USER,s.deviceIdx);t.set(s,p)}}return t}async getExternalIdsByOkIds(e){let t=[],r=[];for(let s of e)if(this._externalUidsCache.has(s)){let o=this.getDecorativeIdByInitialId(s),d=this._externalUidsCache.get(o??s);t.push(q.fromString(d))}else r.push(s);if(!r.length)return t;let n=await this._getExternalIdsByOkIds(r);return Array.from(n.values())}getCachedOkIdByExternalId(e){let t=Array.from(this._externalUidsCache.keys()),r=Array.from(this._externalUidsCache.values()),n=q.toString(e),s=r.indexOf(n);return s>-1?I.composeParticipantId(this.replaceByInitialIdIdIfExists(t[s]),ie.USER,e.deviceIdx):s>-1?I.composeParticipantId(t[s],ie.USER,e.deviceIdx):null}cacheExternalId(e,t){let r=I.extractOkId(e);this._externalUidsCache.set(r,q.toString(t))}mapDecorativeId(e,t){let r=I.extractOkId(e),n=I.extractOkId(t);this._decorativeIdToInitialId.set(r,n),this._initialIdToDecorativeId.set(n,r)}unmapDecorativeId(e){let t=I.extractOkId(e),r=this.getDecorativeIdByInitialId(t);r&&this._decorativeIdToInitialId.delete(r),this._initialIdToDecorativeId.delete(t)}getDecorativeIdByInitialId(e){let t=I.extractOkId(e);return this._initialIdToDecorativeId.get(t)}replaceByInitialIdIdIfExists(e){let t=I.extractOkId(e);return this._decorativeIdToInitialId.get(t)??t}async getConversationParams(e){let t={};return l.anonymToken&&(t.anonymToken=l.anonymToken),e&&(t.conversationId=e),this._call("vchat.getConversationParams",t)}getUserId(){return this._userId}setUserId(e){this._userId=e}hangupConversation(e){let t={conversationId:e,reason:D.HUNGUP};l.anonymToken&&(t.anonymToken=l.anonymToken),gi("vchat.hangupConversation",t)}sendUserFeedbackStats(e,t,r,n){let s={collector:"app.vchat.events.product",data:JSON.stringify({application:`${l.appName}:${l.sdkVersion}`,platform:l.platform,items:[{type:1,operation:T.USER_FEEDBACK_RECEIVED,timestamp:Date.now(),custom:{vcid:e,user_response:t,reason:r,group_call_users_count:n}}]})};gi("log.externalLog",s)}async removeHistoryRecords(e){await this._call("vchat.removeHistoryRecords",{recordIds:e.join(",")})}cleanup(){this._decorativeIdToInitialId=new Map,this._initialIdToDecorativeId=new Map}async _getExternalIdsByOkIds(e){let t=new Map;e=e.map(r=>this.getDecorativeIdByInitialId(r)??r);try{let r=await this._call("vchat.getExternalIdsByOkIds",{uids:e.join(",")}),n=(s,o)=>{for(let[d,p]of Object.entries(s)){let u=Number(d),h=q.fromId(p,o);t.set(u,h),this.cacheExternalId(u,h)}};r.external_ids&&n(r.external_ids,"USER"),r.anonym_ids&&n(r.anonym_ids,"ANONYM");for(let s of e){let o=Number(s);if(!t.has(o)){let d=q.fromId(String(o));t.set(o,d),this.cacheExternalId(o,d)}}return t}catch{return t}}async getServerTime(){return(await this._call("system.getInfo")).serverTime}};var Ys=(e=>(e.KING="KING",e.PAWN="PAWN",e))(Ys||{}),Qs=Ys;var ea=(e=>(e.OFF="0",e.ON="1",e))(ea||{});var un=class{constructor(i){this._queue=new Array(i).fill(null),this._readCursor=this._writeCursor=this._left=0,this._moveReadCursor=!1}get length(){return this._queue.length}get left(){return this._left}toArray(){return Array.from(this._queue)}add(i){this._moveReadCursor&&(this._readCursor=this.nextCursor(this._readCursor)),this._queue[this._writeCursor]===null&&(this._left+=1),this._queue[this._writeCursor]=i,this._writeCursor=this.nextCursor(this._writeCursor),this._moveReadCursor=this._writeCursor===this._readCursor}nextCursor(i){return(i+1)%this._queue.length}next(){let i=this._queue[this._readCursor];return i&&(this._moveReadCursor=!1,this._queue[this._readCursor]=null,this._readCursor=this.nextCursor(this._readCursor),this._left-=1),i}};var hn=class{constructor(i,e,t,r=null){this._uuid=I.uuid(),this._apiKey=e,this._callToken=t,this._apiEnv=i,this._baseApiUrl=r}async authorize(){let i={session_data:{device_id:this._uuid,client_version:l.appVersion,client_type:"SDK_JS",auth_token:this._callToken,version:3},application_key:this._apiKey},e=await pn(this._baseApiUrl,this._apiEnv),t=await zi("auth.anonymLogin",i,!0,e);return I.isObject(t)&&!("error_msg"in t)?(this._sessionKey=t.session_key,!0):!1}async hangupConversation(i){let e={conversationId:i,reason:D.HUNGUP,application_key:this._apiKey,session_key:this._sessionKey},t=await pn(this._baseApiUrl,this._apiEnv);await zi("vchat.hangupConversation",e,!0,t)}};var ce,Yi=null,yd={getCameras:P.getCameras,getMicrophones:P.getMicrophones,getOutput:P.getOutput,getVideoFacingMode:P.getVideoFacingMode,hasCamera:P.hasCamera,hasMicrophone:P.hasMicrophone,getSavedCamera:P.getSavedCamera,getSavedMicrophone:P.getSavedMicrophone,getSavedOutput:P.getSavedOutput,hasCameraPermission:P.hasCameraPermission,hasMicrophonePermission:P.hasMicrophonePermission,hasPermissions:P.hasPermissions,getUserMedia:P.getUserMedia,getUserVideo:P.getUserVideo,getUserAudio:P.getUserAudio,setResolution:P.setResolution,isBrowserSupported:P.isBrowserSupported,isScreenCapturingSupported:P.isScreenCapturingSupported,os:P.os,isMobile:P.isMobile,browserName:P.browserName,browserVersion:P.browserVersion,baseChromeVersion:P.baseChromeVersion,getAudioContext:P.getAudioContext,isAudioShareSupported:P.isAudioShareSupported},Pd={participantMarkerCompare:I.participantMarkerCompare};function wd(a){Yi=a}function Md(a){l.videoEffects=a}function Ad(a){l.audioEffects=a}function Dd(a,i=null,e={},t=1){l.vmoji=a,l.vmojiOptions={protocolVersion:t,renderingOptions:e},i&&a.setSDK(i)}async function kd(a){if(l.set(a),ce||(ce=new _i),ta.default.disableLog(!l.debug),c.toggle(l.debug),c.log(`Calls SDK ${l.sdkVersion}`,a),await P.init(),!P.isBrowserSupported())throw new G(re.UNSUPPORTED);c.log("UserAgent:",navigator.userAgent),c.log("Screen resolution:",`${window.screen.width}x${window.screen.height}`),c.log("Permissions:",`Camera: ${P.hasCameraPermission()}, Mic: ${P.hasMicrophonePermission()}`),c.log("Simulcast:",`${a.simulcast} => ${l.simulcast}`)}async function Od(a,i=[se.AUDIO],e="",t=!1,r=!1,n,s){let o=[];return Array.isArray(a)?o=a.length?a:[]:a&&(o=[a]),Xs([],ct.USER,i,e,t,r,n,o,s)}async function Xs(a,i=ct.USER,e,t="",r=!1,n=!1,s,o,d){if(U.current())throw c.error("There is already active call"),new G(D.FAILED);return new U(ce,Yi).onStart({opponentIds:a,opponentType:i,mediaOptions:e,payload:t,joiningAllowed:r,requireAuthToJoin:n,onlyAdminCanShareMovie:s,externalIds:o,onFastStart:d})}async function xd(a,i){return Zs(a,ie.USER,void 0,i)}async function Zs(a,i=ie.USER,e,t,r,n){if(a===U.id())throw new Error("Push has already been processed");return n&&ce.setUserId(n),new U(ce,Yi).onPush(a,i,e,t,r)}async function Nd(a,i){return a&&(l.authToken=a),i!==void 0&&l.apiBaseUrl!==i&&(l.apiBaseUrl=i,qs()),ce.authorize()}async function Ld(a=[se.AUDIO]){return it().accept(a)}async function Ud(){let a=U.current();if(a)return a.decline()}async function Bd(a,i=[se.AUDIO]){return eo(a,i)}async function eo(a,i,e){if(U.current())throw c.error("There is already active call"),new G(D.FAILED);return new U(ce,Yi).onJoin({conversationId:a,mediaOptions:i,chatId:e})}async function Fd(a,i=[se.AUDIO],e,t,r){if(U.current())throw c.error("There is already active call"),new G(D.FAILED);return e&&(l.anonymToken=e),new U(ce,Yi).onJoin({joinLink:a,mediaOptions:i,observedIds:t,payload:r})}async function Vd(){let a=U.current();if(a)return a.hangup();U.hangupAfterInit()}async function jd(a,i){let e=Array.isArray(a)?a:[a],t=U.current();t&&await t.addParticipant(e,i)}async function Wd(a,i){let e=U.current();if(e){let t=a.map(r=>I.composeUserId(r));await e.addParticipantLegacy(t,i)}}async function Gd(a,i=!1){let e=await ce.getOkIdsByExternalIds([a]);return to(e[0],i)}async function to(a,i=!1){let e=U.current();if(e)try{await e.removeParticipant(I.composeUserId(a),i)}catch(t){c.warn(`Failed to remove participant ${a}. Perhaps he is no longer on the call. ${t}`)}}async function Hd(a,i){let e=U.current();if(a==="videoinput"&&St.contains(i))return l.videoFacingMode=i,e?(P.isMobile()&&e.stopVideoTrack(),e.changeDevice(a)):void 0;if(!await P._saveDeviceId(a,i))throw new Error(`Device not found: ${i}`);if(e)return e.changeDevice(a)}async function Kd(a){let i=typeof a=="object"?{...a,fastScreenSharing:a.captureScreen&&a.fastScreenSharing,captureAudio:a.captureScreen&&a.captureAudio&&l.audioShare}:{captureScreen:a,fastScreenSharing:!1,captureAudio:!1},e=U.current();return e?e.toggleScreenCapturing(i):Promise.reject()}function qd(a){let i=U.current();i&&i.toggleAnimojiCapturing(a)}async function $d(a,i=!1){let e=U.current();e&&await e.setVideoStream(a,i)}async function zd(a){let i=U.current();i&&await i.toggleLocalVideo(a)}async function Jd(a){let i=U.current();i&&await i.toggleLocalAudio(a)}async function Yd(a){let i=U.current();if(i)return i.setLocalResolution(a)}async function Qd(a){let i=U.current();i&&await i.changePriorities(a)}async function Xd(a,i){let e=U.current();if(e){let t;if(i){let[r]=await ce.getOkIdsByExternalIds([i]);t=I.composeParticipantId(r,ie.USER,i.deviceIdx)}await e.changeParticipantState(a,t)}}async function Zd(){let a=U.current();a&&await a.putHandsDown()}async function el(a){let i=U.current();i&&await i.updateDisplayLayout(a)}async function tl(a,i,e=!1){let t=await ce.getOkIdsByExternalIds([a]);return io(t[0],q.getDeviceIdx(a),i,e)}async function io(a,i,e,t=!1){let r=U.current();r&&await r.grantRoles(I.composeParticipantId(a,ie.USER,i),e,t)}async function il({externalId:a=null,muteStates:i,requestedMedia:e=[],roomId:t=null}){let r=null;return a&&(r=(await ce.getOkIdsByExternalIds([a]))[0]),ro({uid:r,muteStates:i,requestedMedia:e,deviceIdx:q.getDeviceIdx(a),roomId:t})}async function ro({uid:a=null,muteStates:i,requestedMedia:e=[],deviceIdx:t=0,roomId:r=null}){let n=U.current();if(n){let s=a?I.composeParticipantId(a,ie.USER,t):null;await n.muteParticipant(s,i,e,r)}}async function rl(a,i=!1,e=null){let t=await ce.getOkIdsByExternalIds([a]);return no(t[0],i,q.getDeviceIdx(a),e)}async function no(a,i=!1,e=0,t=null){let r=U.current();r&&await r.pinParticipant(I.composeParticipantId(a,ie.USER,e),i,t)}async function nl(a){let i=U.current();i&&await i.updateMediaModifiers(a)}async function al(a){let i=U.current();i&&await i.enableVideoSuspend(a)}async function sl(a){let i=U.current();i&&await i.enableVideoSuspendSuggest(a)}async function ol(a){let i=U.current();i&&await i.changeOptions(a)}async function cl(a,i=null){let e=null;return i&&(e=(await ce.getOkIdsByExternalIds([i]))[0]),ao(a,e)}async function ao(a,i=null){let e=U.current();if(e){let t=i?I.composeUserId(i):null;await e.chatMessage(a,t)}}async function dl(a=10){let i=U.current();if(i)return i.chatHistory(a)}async function ll(a,i=null){let e=null;return i&&(e=(await ce.getOkIdsByExternalIds([i]))[0]),so(a,e,q.getDeviceIdx(i))}async function so(a,i=null,e=0){let t=U.current();if(t){let r=i?I.composeParticipantId(i,ie.USER,e):null;await t.customData(a,r)}}async function pl(a="",i=!1,{onlyAdminCanShareMovie:e=!1}={}){return(await ce.createConversation(I.uuid(),a,i,{onlyAdminCanShareMovie:e})).join_link}async function ul(a="",i=!1,{onlyAdminCanShareMovie:e=!1,audioOnly:t=!1}={},r){let n=q.fromIds(r),s=await ce.getOkIdsByExternalIds(n);return(await ce.createConversation(I.uuid(),a,i,{onlyAdminCanShareMovie:e,audienceMode:!0,audioOnly:t},s)).join_link}async function hl(){let a=U.current();return a?a.createJoinLink():Promise.reject()}async function ml(){let a=U.current();return a?a.removeJoinLink():Promise.reject()}async function fl(a,i){return ce.getAnonymTokenByLink(a,i)}function gl(a){let i=U.current();i&&i.setVolume(a)}function _l(a){l.forceRelayPolicy=a}async function Sl(a=!1,i=null,e=null,t="DIRECT_LINK",r=null,n=null){let s=U.current();return s?s.startStream(a,i,e,t,r,n):Promise.reject()}async function vl(a=null){let i=U.current();return i?i.stopStream(a):Promise.reject()}async function Il(a=null){let i=U.current();return i?i.publishStream(a):Promise.reject()}async function El(a,i,e=!1,t=null){let r=U.current();if(!r)return Promise.reject();let n,s,o=[];if(i?.length&&o.push(...i),a&&o.push(a),o.length){let d=await ce.getParticipantIdsByExternalIds(o);a&&(n=d.get(a),d.delete(a)),s=Array.from(d.values())}return r.recordSetConf(n,s,e,t)}async function Tl(){let a=U.current();return a?a.getStreamInfo():Promise.reject()}async function bl(a){let i=U.current();return i?i.addMovie(a):Promise.reject()}async function Cl(a){let i=U.current();return i?i.updateMovie(a):Promise.reject()}async function Rl(a){let i=U.current();return i?i.removeMovie(a):Promise.reject()}async function yl(a,i){let e=U.current();if(e){let t=[];for(let r of a){let n,s;r.addParticipantIds&&(n=(await ce.getOkIdsByExternalIds(r.addParticipantIds)).map(o=>I.composeUserId(o))),r.removeParticipantIds&&(s=(await ce.getOkIdsByExternalIds(r.removeParticipantIds)).map(o=>I.composeUserId(o))),t.push({id:r.id,name:r.name,participantCount:r.participantCount,addParticipantIds:n,removeParticipantIds:s,countdownSec:r.countdownSec})}return e.updateRooms(t,i)}return Promise.reject()}async function Pl(a,i){let e=U.current();return e?e.activateRooms(a,i):Promise.reject()}async function wl(a=null,i=null){let e=U.current();if(!e)return Promise.reject();let t;if(i){let r=await ce.getOkIdsByExternalIds([i]),n=q.getDeviceIdx(i);t=I.composeParticipantId(r[0],ie.USER,n)}return e.switchRoom(a,t)}async function Ml(a){let i=U.current();return i?i.removeRooms(a):Promise.reject()}function Al(a){l.statisticsInterval=a;let i=U.current();if(i)return i.updateStatisticsInterval()}function Dl(a){ta.default.disableLog(!a),c.toggle(a)}function kl(a,...i){l.debugLog&&c.send(a,"[external]",...i)}async function Ol(){let a=Ue.conversationId;if(!a)throw c.error("[uploadDebugLogs]","No conversation id found"),new Error("No conversation id found");let i=Ue.collectLogs();if(i.length===0)throw c.error("[uploadDebugLogs]","No logs found"),new Error("No logs found");let e=Ue.startTime,t=Ue.endTime;try{return ce?.uploadDebugLogs(a,e,t,JSON.stringify(i))}catch(r){throw c.error("[uploadDebugLogs]","Error while uploading logs",r),new Error("Error while uploading logs",{cause:r})}}async function xl(a){let i=U.current();if(i)return i.videoEffect(a)}async function Nl(a,i){let e=U.current();if(e)return e.audioEffect(a.length>0?a:null,i)}async function Ll(a){let i=U.current();i&&await i.setAudioStream(a)}async function Ul(a,i=null,e=null){let t=U.current();if(!t)return;let r=e??i?.id,n=null;if(i){let o=(await ce.getOkIdsByExternalIds([i]))[0];if(!o)throw new Error("Could not get user id to set animoji svg");n=I.composeParticipantId(o,ie.USER,q.getDeviceIdx(i))}t.setAnimojiSvg(a,n,r)}function Bl(a){let i=U.current();i&&i.setAnimojiFill(a)}async function Fl(a=null,i,e=!1){return it().getWaitingHall(a,i,e)}async function Vl(){return it().getAudienceModeHands()}async function jl(a,i=!1){let e=it(),t;if(a){let[r]=await ce.getOkIdsByExternalIds([a]);t=I.composeUserId(r)}return e.promoteParticipant(t,i)}async function Wl(a=!1){return it().requestPromotion(a)}async function Gl(a=!1){return it().acceptPromotion(a)}async function Hl(a){return it().getParticipantListChunk(a)}async function Kl(a){return it().getParticipants(a)}async function ql(a){return it().feedback(a)}function $l(a,i,e){return it().userFeedbackStats(a,i,e)}function zl(a,i={},e=!1){let t=U.current();t&&t.sendClientEvent(a,i,e)}async function Jl(a,i){return it().enableFeatureForRoles(a,i)}function it(){let a=U.current();if(!a)throw new Error("Conversation not found");return a}async function Yl(a){await ce.removeHistoryRecords(a)}async function Ql(a){let i=U.current();i&&await i.startAsr(a)}async function Xl(a){let i=U.current();i&&await i.stopAsr(a)}async function Zl(a){let i=U.current();i&&await i.requestAsr(a)}async function ep(a){let i=U.current();return i?i.startUrlSharing(a):Promise.reject()}async function tp(){let a=U.current();return a?a.stopUrlSharing():Promise.reject()}function ip(){return l.sdkVersion}
|
|
7
|
+
"use strict";var cs=Object.create;var ii=Object.defineProperty;var ds=Object.getOwnPropertyDescriptor;var ls=Object.getOwnPropertyNames;var ps=Object.getPrototypeOf,us=Object.prototype.hasOwnProperty;var ms=(n,r,e)=>r in n?ii(n,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):n[r]=e;var hs=(n,r)=>{for(var e in r)ii(n,e,{get:r[e],enumerable:!0})},Ca=(n,r,e,t)=>{if(r&&typeof r=="object"||typeof r=="function")for(let i of ls(r))!us.call(n,i)&&i!==e&&ii(n,i,{get:()=>r[i],enumerable:!(t=ds(r,i))||t.enumerable});return n};var ri=(n,r,e)=>(e=n!=null?cs(ps(n)):{},Ca(r||!n||!n.__esModule?ii(e,"default",{value:n,enumerable:!0}):e,n)),_s=n=>Ca(ii({},"__esModule",{value:!0}),n);var c=(n,r,e)=>ms(n,typeof r!="symbol"?r+"":r,e);var wd={};hs(wd,{Api:()=>Xt,ApiExternal:()=>yr,ArrayDequeue:()=>Pr,AuthData:()=>Ie,BaseLogger:()=>ft,CallDirection:()=>De,CallType:()=>Ze,ChatRoomEventType:()=>dr,ConversationFeature:()=>lr,ConversationOption:()=>Dt,DebugMessageType:()=>ia,ExternalIdType:()=>pr,FacingMode:()=>dt,FatalError:()=>ie,HangupReason:()=>G,HangupType:()=>w,MediaOption:()=>se,MediaTrackKind:()=>Le,MediaType:()=>$t,MuteState:()=>Ne,ParticipantState:()=>J,ParticipantStateDataValue:()=>ca,ParticipantStatus:()=>Fi,RecordRole:()=>Jn,RoomsEventType:()=>zt,Signaling:()=>At,SignalingCommandType:()=>N,SignalingConnectionType:()=>Fe,SignalingNotification:()=>U,TransportTopology:()=>qe,UserRole:()=>at,UserType:()=>te,VolumeDetector:()=>ut,acceptCall:()=>lc,acceptPromotion:()=>fd,activateRooms:()=>td,addMovie:()=>Qc,addParticipant:()=>_c,addParticipantInternal:()=>gc,authorize:()=>dc,browser:()=>ec,callInternal:()=>Yn,callTo:()=>oc,captureScreen:()=>vc,captureVmoji:()=>Ic,changeAudioEffect:()=>dd,changeConversationOptions:()=>Nc,changeDevice:()=>Sc,changeParticipantState:()=>yc,changePriorities:()=>Pc,changeVideoEffect:()=>cd,chatHistory:()=>Uc,chatMessage:()=>Lc,chatMessageInternal:()=>rs,createJoinLink:()=>jc,customData:()=>Bc,customDataInternal:()=>as,debug:()=>nd,debugMessage:()=>sd,declineCall:()=>pc,enableFeatureForRoles:()=>Rd,enableVideoSuspend:()=>Oc,enableVideoSuspendSuggest:()=>xc,feedback:()=>Id,forceRelayPolicy:()=>Kc,getAnonymTokenByLink:()=>Gc,getAudienceModeHands:()=>hd,getParticipantListChunk:()=>Sd,getParticipants:()=>vd,getStreamInfo:()=>Yc,getWaitingHall:()=>md,grantRoles:()=>Ac,grantRolesInternal:()=>es,hangup:()=>hc,init:()=>sc,joinCall:()=>uc,joinCallByLink:()=>mc,joinCallInternal:()=>Xn,logClientEvent:()=>Td,muteParticipant:()=>Dc,muteParticipantInternal:()=>ts,pinParticipant:()=>wc,pinParticipantInternal:()=>is,processPush:()=>cc,processPushInternal:()=>Qn,promoteParticipant:()=>_d,publishStream:()=>zc,putHandsDown:()=>bc,recordSetConf:()=>Jc,removeHistoryRecords:()=>Cd,removeJoinLink:()=>Hc,removeMovie:()=>Zc,removeParticipant:()=>fc,removeParticipantInternal:()=>Zn,removeRooms:()=>rd,requestAsr:()=>bd,requestPromotion:()=>gd,setAudioEffects:()=>ac,setAudioStream:()=>ld,setLocalResolution:()=>Cc,setLogger:()=>ic,setMediaModifiers:()=>kc,setStatisticsInterval:()=>ad,setVideoEffects:()=>rc,setVideoStream:()=>Ec,setVmoji:()=>nc,setVmojiFill:()=>ud,setVmojiSvg:()=>pd,setVolume:()=>Wc,startAsr:()=>Pd,startAudienceConversation:()=>Vc,startConversation:()=>Fc,startStream:()=>$c,startUrlSharing:()=>Md,stopAsr:()=>yd,stopStream:()=>qc,stopUrlSharing:()=>Ad,switchRoom:()=>id,toggleLocalAudio:()=>Rc,toggleLocalVideo:()=>Tc,updateDisplayLayout:()=>Mc,updateMovie:()=>Xc,updateRooms:()=>ed,uploadDebugLogs:()=>od,userFeedbackStats:()=>Ed,utils:()=>tc,version:()=>Dd});module.exports=_s(wd);var da=ri(require("webrtc-adapter"));var ft=class{log(r,e,t=!1){}destroy(){}};var re=class{constructor(){c(this,"_handlers",{});c(this,"_listeners",[])}_triggerEvent(r,...e){if(this._handlers.hasOwnProperty(r))for(let t of this._handlers[r])t.apply(this,e)}addEventListener(r,e){if(typeof e!="function")throw new Error("Listener should be a function");return this._handlers.hasOwnProperty(r)||(this._handlers[r]=[]),this._handlers[r].push(e),{dispose:this.removeEventListener.bind(this,r,e)}}removeEventListener(r,e){if(!this._handlers.hasOwnProperty(r))return;e||delete this._handlers[r];let t=this._handlers[r].indexOf(e);t>=0&&this._handlers[r].splice(t,1)}subscribe(r,e,t){let i=r.addEventListener(e,t);this._listeners.push(i)}unsubscribe(){this._listeners.forEach(r=>{r.dispose()})}};var ai=class extends re{get ready(){return!0}setParticipantIdRegistry(r){}requestRealloc(){}setEndpoint(r){}setWebTransportEndpoint(r){}setConversationId(r){}readyToSend(r=!0){}cleanup(){}requestTestMode(r,e){}getNextCommandSequenceNumber(){return 0}};var Pa=(Z=>(Z.CANCELED="CANCELED",Z.REJECTED="REJECTED",Z.REMOVED="REMOVED",Z.HUNGUP="HUNGUP",Z.MISSED="MISSED",Z.BUSY="BUSY",Z.FAILED="FAILED",Z.NETWORK_ERROR="NETWORK_ERROR",Z.KILLED="KILLED",Z.BANNED="BANNED",Z.HAS_ACTIVE_CALL="HAS_ACTIVE_CALL",Z.CALLER_IS_BLOCKED="CALLER_IS_BLOCKED",Z.NOT_FRIENDS="NOT_FRIENDS",Z.CALLEE_IS_OFFLINE="CALLEE_IS_OFFLINE",Z.CALLER_IS_REJECTED="CALLER_IS_REJECTED",Z.UNKNOWN_ERROR="UNKNOWN_ERROR",Z.UNSUPPORTED="UNSUPPORTED",Z.OLD_VERSION="OLD_VERSION",Z.SERVICE_DISABLED="SERVICE_DISABLED",Z.EXTERNAL_API_ERROR="EXTERNAL_API_ERROR",Z.SOCKET_CLOSED="SOCKET_CLOSED",Z.ENDED="ENDED",Z.KILLED_WITHOUT_DELETE="KILLED_WITHOUT_DELETE",Z.ANOTHER_DEVICE="ANOTHER_DEVICE",Z.NOT_FOUND="NOT_FOUND",Z.VCHAT_DETAILED_ERROR="VCHAT_DETAILED_ERROR",Z))(Pa||{}),w=Pa;var G=class n extends Error{constructor(e,t){super();c(this,"message");c(this,"hangup");c(this,"error");c(this,"code");c(this,"remote");c(this,"custom_error");this.name="HangupReason",this.code=t&&t.code||0,this.remote=t&&t.remote||!1,this.custom_error=t?.custom_error??null,Object.values(w).indexOf(e)>-1?this.hangup=e:this.error=e;let i=[];this.error&&i.push("error"),this.remote&&i.push("remote"),this.code&&i.push(`code: ${this.code}`),t&&t.message&&i.push(`message: '${t.message}'`),this.message=e+(i.length?` (${i.join(", ")})`:""),Error.captureStackTrace&&Error.captureStackTrace(this,n)}};var ge=class ge extends ft{constructor(e,t){super();c(this,"_externalLogger");c(this,"_api");c(this,"_batchInterval",3e3);c(this,"_batchedLogItems",[]);c(this,"_batchedClientStats",[]);c(this,"_batchedClientEvents",[]);c(this,"_batchTimeout",null);c(this,"_serverTimeDelta",0);this._api=e,this._externalLogger=t,this._calculateServerTimeDelta()}static setConversationIdProvider(e){ge._conversationIdProvider=e}_getConversationId(){if(ge._conversationIdProvider)try{return ge._conversationIdProvider()}catch{return null}return null}_sendLogItems(e){this._api.log(e)}_sendClientStats(e){this._api.logClientStats(e)}_sendClientEvents(e){this._api.logClientEvents(e)}_sendBatch(){this._stopTimeout();let e=!1;this._batchedLogItems.length>0&&(this._sendLogItems(this._batchedLogItems),this._batchedLogItems=[],e=!0),this._batchedClientStats.length>0&&(this._sendClientStats(this._batchedClientStats),this._batchedClientStats=[],e=!0),this._batchedClientEvents.length>0&&(this._sendClientEvents(this._batchedClientEvents),this._batchedClientEvents=[],e=!0),e&&this._startTimeout()}_startTimeout(){this._batchTimeout=window.setTimeout(()=>this._sendBatch(),this._batchInterval)}_stopTimeout(){this._batchTimeout&&(clearTimeout(this._batchTimeout),this._batchTimeout=null)}async _calculateServerTimeDelta(){try{let e=await this._api.getServerTime();this._serverTimeDelta=Date.now()-e}catch{}}_now(){return Date.now()-this._serverTimeDelta}log(e,t,i=!1){let a={};typeof t<"u"&&(a.param=t),this._logInternal(e,a,i),this._externalLogger&&this._externalLogger.log(e,t,i)}logCustom(e,t,i=!1){this._logInternal(e,t,i)}logClientStats(e,t=!1){let i=Object.assign(e,{vcid:this._getConversationId(),timestamp:this._now()});Object.keys(i).forEach(a=>{i[a]===void 0&&delete i[a]}),this._batchedClientStats.push(i),(t||!this._batchTimeout)&&this._sendBatch()}logClientEvent(e,t=!1){let i=Object.assign(e,{vcid:this._getConversationId(),timestamp:this._now()});this._batchedClientEvents.push(i),(t||!this._batchTimeout)&&this._sendBatch()}_logInternal(e,t,i){let a={type:1,time:0,operation:e,timestamp:this._now(),custom:Object.assign(t,{vcid:this._getConversationId()}),uid:this._api.getUserId()};this._batchedLogItems.push(a),(i||!this._batchTimeout)&&this._sendBatch()}destroy(){this._sendBatch(),this._stopTimeout(),this._externalLogger&&this._externalLogger.destroy()}static create(e,t){ge._instance||(ge._instance=new ge(e,t))}static log(e,t,i=!1){ge._instance&&ge._instance.log(e,t,i)}static logCustom(e,t,i=!1){ge._instance&&ge._instance.logCustom(e,t,i)}static logClientStats(e,t=!1){ge._instance&&ge._instance.logClientStats(e,t)}static logClientEvent(e,t=!1){ge._instance&&ge._instance.logClientEvent(e,t)}static destroy(){ge._instance&&ge._instance.destroy(),ge._instance=null}};c(ge,"_instance"),c(ge,"_conversationIdProvider",null);var P=ge;var L=require("messagepack");var ya=(x=>(x.RECOVER="recover",x.ACCEPT_CALL="accept-call",x.ADD_PARTICIPANT="add-participant",x.REMOVE_PARTICIPANT="remove-participant",x.HANGUP="hangup",x.TRANSMIT_DATA="transmit-data",x.ACCEPT_PRODUCER="accept-producer",x.ALLOCATE_CONSUMER="allocate-consumer",x.CHANGE_MEDIA_SETTINGS="change-media-settings",x.CHANGE_PARTICIPANT_STATE="change-participant-state",x.CHANGE_STREAM_PRIORITIES="change-streams-priorities",x.UPDATE_DISPLAY_LAYOUT="update-display-layout",x.REPORT_PERF_STAT="report-perf-stat",x.REPORT_SHARING_STAT="report-sharing-stat",x.REPORT_NETWORK_STAT="report-network-stat",x.RECORD_START="record-start",x.RECORD_STOP="record-stop",x.RECORD_PUBLISH="record-publish",x.RECORD_SET_CONF="record-set-conf",x.RECORD_GET_STATUS="record-get-status",x.SWITCH_MICRO="switch-micro",x.SWITCH_TOPOLOGY="switch-topology",x.REQUEST_REALLOC="request-realloc",x.CHAT_MESSAGE="chat-message",x.CHAT_HISTORY="chat-history",x.CUSTOM_DATA="custom-data",x.GRANT_ROLES="grant-roles",x.MUTE_PARTICIPANT="mute-participant",x.ENABLE_FEATURE_FOR_ROLES="enable-feature-for-roles",x.PIN_PARTICIPANT="pin-participant",x.UPDATE_MEDIA_MODIFIERS="update-media-modifiers",x.CHANGE_OPTIONS="change-options",x.GET_WAITING_HALL="get-waiting-hall",x.GET_PARTICIPANT_LIST_CHUNK="get-participant-list-chunk",x.GET_PARTICIPANTS="get-participants",x.PROMOTE_PARTICIPANT="promote-participant",x.REQUEST_TEST_MODE="request-test-mode",x.ADD_MOVIE="add-movie",x.UPDATE_MOVIE="update-movie",x.REMOVE_MOVIE="remove-movie",x.START_URL_SHARING="start-url-sharing",x.STOP_URL_SHARING="stop-url-sharing",x.GET_ROOMS="get-rooms",x.UPDATE_ROOMS="update-rooms",x.ACTIVATE_ROOMS="activate-rooms",x.REMOVE_ROOMS="remove-rooms",x.SWITCH_ROOM="switch-room",x.FEEDBACK="feedback",x.ASR_START="asr-start",x.ASR_STOP="asr-stop",x.REQUEST_ASR="request-asr",x.REQUEST_PROMOTION="request-promotion",x.ACCEPT_PROMOTION="accept-promotion",x.GET_HAND_QUEUE="get-hand-queue",x.ENABLE_VIDEO_SUSPEND="enable-video-suspend",x.ENABLE_VIDEO_SUSPEND_SUGGEST="enable-video-suspend-suggest",x.PUT_HANDS_DOWN="put-hands-down",x.CHANGE_SIMULCAST="change-simulcast",x))(ya||{}),N=ya;var ba=(z=>(z.MIC_CAMERA_PERMISSION="mic_camera",z.CAMERA_PERMISSION="camera",z.MIC_PERMISSION="mic",z.CAMERA_ACCESS="cameralock",z.MIC_ACCESS="miclock",z.MIC_NOT_FOUND="nomic",z.SCREEN_PERMISSION="screenpermission",z.SCREEN_ACCESS="screenlock",z.CONNECTION="connection",z.NETWORK="network",z.UNKNOWN="unknown",z.UNSUPPORTED="unsupported",z.SIGNALING_FAILED="signalingfailed",z.API="api",z.AUTH="auth",z.OVERCONSTRAINED="overconstrained",z))(ba||{}),ie=ba;var Ma=(s=>(s.AUDIO="AUDIO",s.VIDEO="VIDEO",s.SCREEN_SHARING="SCREEN_SHARING",s.MOVIE_SHARING="MOVIE_SHARING",s.AUDIO_SHARING="AUDIO_SHARING",s.ANIMOJI="ANIMOJI",s))(Ma||{}),se=Ma;var Aa=(v=>(v.ERROR="callError",v.DEVICES="callDevices",v.CALL_SPEC_ERROR="callSpecError",v.ICE_CONNECTION_STATE="callIceConnectionState",v.ICE_CONNECTION_TYPE="callIceConnectionType",v.ICE_RESTART="callIceRestart",v.PUSH="callPush",v.OUTGOING_CALL="callStart",v.CALL_FINISH="call_finish",v.OUTGOING_MULTIPARTY_CALL="callStartMultiparty",v.JOIN_CONVERSATION="callJoinConversation",v.ACCEPTED_OUTGOING="callAcceptedOutgoing",v.ACCEPT_INCOMING="callAcceptIncoming",v.DECLINE_INCOMING="callDeclineIncoming",v.ACCEPT_CONCURRENT="callAcceptConcurrent",v.HANGUP="callHangup",v.CODEC_USAGE="codec_usage",v.MEDIA_STATUS="callMediaStatus",v.DEVICE_CHANGED="callDeviceChanged",v.SOCKET_ACTION="callSocketAction",v.ADD_PARTICIPANT="callAddParticipant",v.REMOVE_PARTICIPANT="callRemoveParticipant",v.POOR_CONNECTION="callPoorConnection",v.TOPOLOGY_CHANGE_REQUESTED="callTopologyChangeRequested",v.RELAY_POLICY="callForceRelay",v.PAT_ALLOCATED="patAllocate",v.PAT_DEALLOCATED="patDeallocate",v.PAT_ERROR="patError",v.PAT_WAITING_TIME_ERROR="patWaitingTimeError",v.PAT_OUTDATED_RESPONSE="patOutdatedResponse",v.SIGNALING_CONNECTED="signaling_connected",v.RECONNECT="callReconnect",v.SCREENSHARE_FIRST_FRAME="screen_share_first_frame",v.SCREENSHARE_FREEZE_DURATION="callScreenshareFreezeDuration",v.FIRST_MEDIA_RECEIVED="first_media_received",v.CALL_EVENTUAL_STAT="callEventualStat",v.CALL_DECLINED_OR_HANGED_LOCALLY="CallDeclinedOrHangedLocally",v.USER_FEEDBACK_RECEIVED="UserFeedbackReceived",v.CALL_START="call_start",v.WEBSOCKET_CONNECTED="websocket_connected",v.WEBSOCKET_RECONNECTED="websocket_reconnected",v.WEBSOCKET_FAILED_PINGS="websocket_failed_pings",v.WEBSOCKET_FAILED_EXCEPTION="websocket_failed_exception",v.WEBSOCKET_TIMEOUT="websocket_timeout",v.WEBSOCKET_RESTART="websocket_restart",v.WEBTRANSPORT_CONNECTED="webtransport_connected",v.WEBTRANSPORT_RECONNECTED="webtransport_reconnected",v.WEBTRANSPORT_FAILED_PINGS="webtransport_failed_pings",v.WEBTRANSPORT_FAILED_EXCEPTION="webtransport_failed_exception",v.WEBTRANSPORT_TIMEOUT="webtransport_timeout",v.WEBTRANSPORT_RESTART="webtransport_restart",v))(Aa||{}),T=Aa;var wr=ri(require("@vkontakte/libvpx"));var He=class{constructor(){c(this,"_worker",null)}async _createWorker(r,e,t=[],i={},a=[]){return new Promise((s,o)=>{let u=t.join(","),p=new Blob([r,`exports.default(${u});`],{type:"application/javascript; charset=utf-8"}),m=window.URL.createObjectURL(p);this._worker=new Worker(m),this._worker.onmessage=h=>{switch(h.data.type){case"ready":s();break;case"error":o(h.data.error);break;case"frame":e(h.data);break;case"debug":d.debug(h.data.message);break;case"log_error":P.log(T.ERROR,h.data.message);break}},this._sendToWorker("init",i,a)})}_removeWorker(){this._worker?.terminate(),this._worker=null}_sendToWorker(r,e={},t=[]){this._worker?.postMessage(Object.assign({type:r},e),t)}static isBrowserSupported(){throw new Error("Not implemented")}};var St=class extends He{async init(r,e){d.debug("LibVPxDecoder started"),await this._createWorker('"use strict";var exports=(()=>{var d=Object.defineProperty;var y=Object.getOwnPropertyDescriptor;var x=Object.getOwnPropertyNames;var E=Object.prototype.hasOwnProperty;var R=(o,t)=>{for(var e in t)d(o,e,{get:t[e],enumerable:!0})},h=(o,t,e,a)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of x(t))!E.call(o,s)&&s!==e&&d(o,s,{get:()=>t[s],enumerable:!(a=y(t,s))||a.enumerable});return o};var V=o=>h(d({},"__esModule",{value:!0}),o);var D={};R(D,{default:()=>M});var M=(o,t)=>{let e=null,a=null,s=!0;function c(){return o({locateFile:t}).then(r=>a=r)}function f(r,u,n,m){if(!a){self.postMessage({type:"log_error",message:"decoder-init-fail-libvpx"}),self.postMessage({type:"frame",error:"Fatal initialization error"});return}if(s!==n&&(s=n,e&&(e=null,self.postMessage({type:"debug",message:`LibVPxDecoder codec changed to ${n?"VP9":"VP8"} - reinitialize`}))),!e&&(self.postMessage({type:"debug",message:`LibVPxDecoder codec ${n?"VP9":"VP8"}`}),e=new a.VpxDecoder,e.debug(m),!e.init(n?a.VpxType.VP9:a.VpxType.VP8))){e=null,self.postMessage({type:"frame",error:"Decoder failed to create"});return}try{e.allocateBuffer(u.byteLength).set(new Uint8Array(u))}catch(i){self.postMessage({type:"debug",message:i}),e=null,self.postMessage({type:"frame",error:String(i)});return}if(!(e.decode()&&e.nextImage())){self.postMessage({type:"frame",error:"Decode failed"});return}let l=e.getImageBuffer();if(!l){self.postMessage({type:"frame",error:"No decoded data"});return}let b=e.getImageWidth(),g=e.getImageHeight();e.nextImage()&&(self.postMessage({type:"debug",message:"LibVPxDecoder dropped frame"}),self.postMessage({type:"log_error",message:"LibVPxDecoder-drop"}));let p=new Uint8ClampedArray(l.byteLength);p.set(l),self.postMessage({type:"frame",data:p.buffer,width:b,height:g},[p.buffer])}c().then(()=>{self.onmessage=r=>{switch(r.data.type){case"frame":f(r.data.timestamp,r.data.data,r.data.isVP9,r.data.debug);break}},self.postMessage({type:"ready"})}).catch(r=>{self.postMessage({type:"error",error:String(r)})})};return V(D);})();\n',t=>{if(t.error)d.warn("LibVPxDecoder",t.error),e(t.error);else{let i=new ImageData(new Uint8ClampedArray(t.data),t.width,t.height);r(i)}},[wr.default,wr.default.getUrl])}decodeFrame(r,e,t,i){this._sendToWorker("frame",{timestamp:r,data:e.buffer,isVP9:t,keyFrame:i,debug:d.enabled()},[e.buffer])}destroy(){this._removeWorker(),d.debug("LibVPxDecoder destroyed")}static isBrowserSupported(){return"WebAssembly"in window&&"Worker"in window}};var Ye=class extends He{async init(r,e){d.debug("WebCodecsDecoder started"),await this._createWorker('"use strict";var exports=(()=>{var i=Object.defineProperty;var D=Object.getOwnPropertyDescriptor;var R=Object.getOwnPropertyNames;var y=Object.prototype.hasOwnProperty;var C=(o,e)=>{for(var n in e)i(o,n,{get:e[n],enumerable:!0})},A=(o,e,n,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of R(e))!y.call(o,t)&&t!==n&&i(o,t,{get:()=>e[t],enumerable:!(a=D(e,t))||a.enumerable});return o};var V=o=>A(i({},"__esModule",{value:!0}),o);var F={};C(F,{default:()=>k});var k=o=>{let e=null,n=!0,a=null,t=!1,f=1e3/15*2;function p(){self.postMessage({type:"ready"})}function m(r,b,d,c=!1){if(!e||n!==d){if(!c){self.postMessage({type:"frame",error:"WebCodecsDecoder dropped frame - waiting for keyframe"});return}n=d,e?self.postMessage({type:"debug",message:`WebCodecsDecoder codec changed to ${d?"VP9":"VP8"}`}):(self.postMessage({type:"debug",message:`WebCodecsDecoder codec ${d?"VP9":"VP8"}`}),e=new VideoDecoder({output:s=>{l();let g=o?[s]:[];self.postMessage({type:"frame",data:s},g),s.close()},error:s=>{l(),e&&e.state!=="closed"&&e.close(),e=null,self.postMessage({type:"frame",error:"WebCodecsDecoder failed, reinitialize: "+String(s)})}})),e.configure(u(d))}if(t&&!c){self.postMessage({type:"frame",error:"WebCodecsDecoder dropped frame after reset - waiting for keyframe"});return}t=!1;let E=new EncodedVideoChunk({type:c?"key":"delta",timestamp:r,data:b});e.decode(E),a=setTimeout(()=>{t=!0,e?.reset(),e?.configure(u(d)),self.postMessage({type:"frame",error:"WebCodecsDecoder reset because of decode timeout"})},f)}self.onmessage=r=>{switch(r.data.type){case"init":p();break;case"frame":m(r.data.timestamp,r.data.data,r.data.isVP9,r.data.keyFrame);break}};function l(){a&&clearTimeout(a),a=null}function u(r){return{codec:r?"vp09.00.50.08":"vp8"}}};return V(F);})();\n',t=>{t.error?(d.warn("WebCodecsDecoder",t.error),e(t.error)):(r(t.data),t.data.close())},[b.baseChromeVersion()>=92||b.browserName()==="Safari"])}decodeFrame(r,e,t,i=!1){this._sendToWorker("frame",{timestamp:r,data:e.buffer,isVP9:t,keyFrame:i},[e.buffer])}destroy(){this._removeWorker(),d.debug("WebCodecsDecoder destroyed")}static isBrowserSupported(){return"VideoDecoder"in window&&"Worker"in window&&"VideoFrame"in window&&!b.isBrokenVP9Decoder()&&b.browserName()!=="Firefox"}};var vt=class{constructor(r=null,e=0){c(this,"_counter",0);c(this,"_interval",0);c(this,"_lastCalculationTime",Date.now());c(this,"_onCalculated",null);this._onCalculated=r,e&&(this._interval=window.setInterval(()=>this.calculate(),e))}increment(r=1){this._counter+=r}calculate(){let r=Date.now(),e=r-this._lastCalculationTime,t=Math.round(this._counter*1e3/e);return this._counter=0,this._lastCalculationTime=r,this._onCalculated?.(t),t}destroy(){window.clearInterval(this._interval),this._interval=0}};var ja=require("bit-buffer");var Da=(e=>(e.USER="USER",e.GROUP="GROUP",e))(Da||{}),te=Da;var ot={HEIGHT:720,WIDTH:1280,BITRATE:1e6},ni="L1T2",ka=[{dimension:320,bitrate:18e4},{dimension:520,bitrate:4e5},{dimension:640,bitrate:5e5},{dimension:960,bitrate:9e5},{dimension:1280,bitrate:12e5},{dimension:1920,bitrate:25e5},{dimension:2560,bitrate:35e5},{dimension:3840,bitrate:5e6}],gs={h:1,m:2,l:4};function Oa(n,r){return!n||!r?n===r:n.streams.length===r.streams.length?n.streams.every((e,t)=>I.isObjectsEquals(e,r.streams[t])):!1}function wa(n,r){for(let e of r)if(n<=e.dimension)return e.bitrate;return length>0?r[length-1].bitrate:ka[0].bitrate}function si(n=ot.WIDTH,r=ot.HEIGHT,e=ka){let t=["h","m","l"],i=Math.max(n,r),a=1;i>=960?a=3:i>=480&&(a=2);let s={streams:[]},o=30,u=wa(i,e)??ot.BITRATE;for(let p=0;p<a;p++){let m=t[p];s.streams.push({rid:m,width:n,height:r,fps:o,bitrate:u}),n=Math.round(n/2),r=Math.round(r/2),u=wa(Math.max(n,r),e)??Math.round(u/2)}return s}function Di(n){return n?gs[n]??1:1}var xa=typeof Object.fromEntries=="function"?Object.fromEntries:function(n){if(!n||!n[Symbol.iterator])throw new Error("Object.fromEntries() requires a single iterable argument");let r={};for(let[e,t]of n)r[e]=t;return r};async function Na(n){return new Promise((r,e)=>{let t=new FileReader;t.onload=i=>{r(i.target?.result)},t.onerror=e,t.readAsArrayBuffer(n)})}var Lt=":",ki="d",fs=533,wi="a=fmtp:",Ss="sps-pps-idr-in-keyframe=1",kr;(je=>{let n=/[\r\n]+/,r=`\r
|
|
8
|
+
`;function e(_,C){let y=new RegExp("a=rtpmap:(\\d+) ([a-zA-Z0-9-]+)\\/\\d+"),v,f=[];for(v=0;v<_.length;++v){let D=_[v].match(y);D&&D.length===3&&D[2]===C&&f.push(D[1])}return f}function t(_,C,y){let v=_.split(" "),f=v.slice(0,3),D;for(D=3;D<v.length;D++)y.includes(v[D])&&f.push(v[D]);for(D=3;D<v.length;D++)!y.includes(v[D])&&!C.includes(v[D])&&f.push(v[D]);return f.join(" ")}function i(_,C,y,v){let f,D="m="+C;for(f=0;f<_.length;++f)_[f].startsWith(D)&&(_[f]=t(_[f],y,v))}function a(_,C){let y=new RegExp(wi+"(\\d+)");for(let v=0;v<_.length;++v){let f=_[v].match(y);if(f&&f.length===2&&C.includes(f[1])){let D=_[v].trim()===wi+f[1]?" ":";";_[v]+=D+Ss}}}function s(_,C){let y=e(_,C);if(!y.length)return;let v=y.slice(0),f=new RegExp(wi+"(\\d+) apt=(\\d+)"),D;for(D=0;D<_.length;++D){let F=_[D].match(f);F&&F.length===3&&v.includes(F[2])&&v.push(F[1])}let W=new RegExp("a=(rtpmap|rtcp-fb|fmtp):(\\d+) .*");for(D=_.length;D--;){let F=_[D].match(W);F&&F.length===3&&v.includes(F[2])&&_.splice(D,1)}i(_,"video",v,[])}function o(_,C,y,v){let f=new RegExp("a=rtpmap:(\\d+) ([a-zA-Z0-9-]+)\\/\\d+"),D,W=[];for(D=C;D<y;++D){let Y=_[D].match(f);Y&&Y.length===3&&Y[2]===v&&W.push(Y[1])}if(!W.length)return W;let F=new RegExp(wi+"(\\d+) apt=(\\d+)");for(D=C;D<y;++D){let Y=_[D].match(F);Y&&Y.length===3&&W.includes(Y[2])&&W.push(Y[1])}return W}function u(_,C,y,v){let f=o(_,C,y,v);if(!f.length)return y+1;let D=new RegExp("a=(rtpmap|rtcp-fb|fmtp):(\\d+) .*"),W=0,F=y;for(;F>=C;){let Y=_[F].match(D);Y&&Y.length===3&&f.includes(Y[2])&&(_.splice(F,1),W++),F--}return _[C]=t(_[C],f,[]),y-W+1}function p(_,C,y,v){let f=-1,D=-1,W=!1;for(let F=0;F<_.length;++F)if(f>=0&&_[F].startsWith("m=")&&(D=F-1,W&&(F=u(_,f,D,C)),f=-1,D=-1,W=!1),_[F].startsWith("m=video")&&(f=F),f>=0){let Y=y==="remote"&&v==="encoder"||y==="local"&&v==="decoder"?"recvonly":"sendonly";(_[F].startsWith(`a=${Y}`)||_[F].startsWith("a=sendrecv"))&&(W=!0)}D=_.length-1,f>=0&&W&&u(_,f,D,C)}function m(_,C,y){let v=e(_,"H264");C&&i(_,"video",[],v),y&&a(_,v)}function h(_){let C=e(_,"VP9");i(_,"video",[],C)}function R(_,C,y,v,f,D=!1,W=!1){if(!C&&!y&&!v&&!W&&!D&&!f)return _;function F(x){let fe=["a=rtcp-fb:111 nack","a=rtcp-fb:111 nack pli"],he="a=rtcp-fb:111",Se=x.findIndex(de=>de.startsWith(he));return~Se&&(x[Se]=x[Se]+r+fe.join(r)),x}function Y(x){let fe=e(x,"red");fe.length>0&&i(x,"audio",[],fe)}let _e=_.split(n);return y?p(_e,"H264","local","decoder"):(C||f)&&m(_e,C,f),v&&h(_e),W&&Y(_e),D&&F(_e),_e.join(r)}je.patchLocalSDP=R;function M(_,C,y,v,f,D,W){C&&(_=_.replace("m=application 9 UDP/DTLS/SCTP webrtc-datachannel","m=application 9 DTLS/SCTP 5000").replace("a=sctp-port:5000","a=sctpmap:5000 webrtc-datachannel 256"));let F=_.split(n);return v?s(F,"H264"):y&&m(F,y,!1),D&&W?s(F,"VP9"):D?p(F,"VP9","remote","encoder"):W?p(F,"VP9","remote","decoder"):f&&h(F),F.join(r)}je.patchRemoteSDP=M;function k(_){return _?`${_.type||"WEB_SOCKET"}_${_.id}`:"_"}je.getPeerIdString=k;function H(_,C){return _&&_.id===C.id&&(_.type||"WEB_SOCKET")===(C.type||"WEB_SOCKET")}je.comparePeerId=H;async function z(_){let C={local:null,remote:null};if(!_||!_.getStats)return C;try{let y=await _.getStats(null),v=null;if(y.forEach(f=>{f.type==="transport"&&f.selectedCandidatePairId?v=y.get(f.selectedCandidatePairId):f.type==="candidate-pair"&&f.state==="succeeded"&&!v&&(!f.hasOwnProperty("selected")||f.selected)&&(v=f)}),v?.localCandidateId){let f=y.get(v.localCandidateId);f&&(C.local={type:f.candidateType,ip:f.ip||f.ipAddress,port:f.port||f.portNumber})}if(v?.remoteCandidateId){let f=y.get(v.remoteCandidateId);f&&(C.remote={type:f.candidateType,ip:f.ip||f.ipAddress,port:f.port||f.portNumber})}return C}catch{return C}}je.getPeerConnectionHostInfo=z;let ae=/^[0-9]+$/,ve=/^([gu])([0-9]+)$/;function ye(_,C=te.USER){let y=String(_);return ve.test(y)?(d.warn(`Already composite id [${_}] type supplied [${C}]`),y):C===te.GROUP?"g"+y:C===te.USER?"u"+y:(d.warn(`Unknown type [${C}] for id [${_}]`),y.match(ae)?"u"+y:y)}je.composeUserId=ye;function X(_,C,y=0){let v=ye(_,C);return be(v,y)}je.composeParticipantId=X;function be(_,C){return C?_+Lt+ki+C:_}je.compose=be;function Me(_){return X(_.id,_.idType||te.USER,_.deviceIdx)}je.composeId=Me;function Zt(_){if(_.decorativeUserId)return X(_.decorativeUserId,_.idType||te.USER,_.deviceIdx)}je.composeDecorativeId=Zt;function la(_){return _.participant?Me(_.participant):X(_.participantId,_.participantType||te.USER,_.deviceIdx)}je.composeMessageId=la;function pa(_){return typeof _=="string"?Z(ei(_).compositeUserId).id:_}je.extractOkId=pa;function Z(_){let C=String(_),y=C.match(ve);return y?{id:Number(y[2]),type:y[1]==="g"?te.GROUP:te.USER}:(d.warn(`Unsupported compositeId [${_}]`),{id:Number(C),type:te.USER})}je.decomposeId=Z;function ei(_){let C=_.split(Lt+ki);return{compositeUserId:C[0],deviceIdx:C.length>1?parseInt(C[1],10):0}}je.decomposeParticipantId=ei;function ua(){let _=window.crypto?.randomUUID?.();if(_)return _;let C="0123456789abcdefghijklmnopqrstuvwxyz".split(""),y=new Array(36),v=0,f,D;for(D=0;D<36;D++)D===8||D===13||D===18||D===23?y[D]="-":D===14?y[D]="4":(v<=2&&(v=33554432+Math.random()*16777216|0),f=v&15,v=v>>4,y[D]=C[D===19?f&3|8:f]);return y.join("")}je.uuid=ua;function ma(_,C){let y;function v(...f){let D=this;y&&window.clearTimeout(y),y=window.setTimeout(()=>{_.apply(D,f)},C)}return v}je.debounce=ma;function ha(_){if(!window.BigInt)return null;let C="",y=_.split(`
|
|
9
|
+
`);for(let D of y)if(D.startsWith("a=fingerprint")){let W=D.split(" ");if(W.length===2){C=W[1];break}}if(!C)return BigInt(-1);let v=C.split(":"),f=BigInt(0);for(let D=Math.min(7,v.length-1);D>=0;D--){let W=BigInt(parseInt(v[D],16));f<<=BigInt(8),f|=W}return BigInt.asIntN(64,f)}je.sdpFingerprint=ha;async function _a(_){return new Promise(C=>window.setTimeout(C,_))}je.delay=_a;function ga(_,C,y){let v=[];return _.getSenders().forEach(f=>Mi(C,f,f.track,y,v)),v}je.applySettings=ga;function Mi(_,C,y,v,f){if(!RTCRtpSender.prototype.getParameters||!RTCRtpSender.prototype.setParameters||!_||!y||y.kind!=="video")return;let D=y.getSettings();if(!D)return;let W=_.maxBitrateK?_.maxBitrateK*1024:null,F=D.width,Y=D.height,_e=F&&Y&&_.maxDimension?Math.max(1,Math.max(F,Y)/_.maxDimension):null,x=_.maxFramerate||null;if(F&&Y&&_.maxDimension&&_.maxDimension>Math.max(F,Y)){let de=Math.round(F*Y/256),we=(Math.round(de*fs/1e4)+1)*1e4;W=W===null?we:Math.min(we,W)}let fe=_.degradationPreference||"balanced",he=v[y.id];if(he&&he.bitrate===W&&he.scaleResolutionDownBy===_e&&he.maxFramerate===x&&he.degradationPreference===fe){f[y.id]=he;return}f[y.id]={bitrate:W,scaleResolutionDownBy:_e,maxFramerate:x,degradationPreference:fe};let Se=C.getParameters();if(Se.encodings||(Se.encodings=[{}]),Se.encodings.length>1&&F&&Y&&_.maxDimension){let de=Math.round(_.maxDimension*1.35),we=Math.max(F,Y),_t=si(F,Y,_?.bitrates?.generic),Nt=_t.streams.length;d.log(`applyVideoTrackSettings: maxDim=${_.maxDimension} targetDim=${de} track=${F}x${Y} sim=${JSON.stringify(_t)}`),Se.encodings.forEach((Je,ti)=>{Je.scaleResolutionDownBy=Di(Je.rid);let Ta=Math.round(we/Je.scaleResolutionDownBy);ti<Nt-1?Je.active=Ta<de:ti>=Nt?Je.active=!1:Je.active=!0,ti<Nt?Je.maxBitrate=_t.streams[ti].bitrate:Je.maxBitrate=0,Je.scalabilityMode=ni})}else Se.encodings.forEach(de=>{_?.scalabilityMode&&(de.scalabilityMode=_.scalabilityMode),W?de.maxBitrate=W:delete de.maxBitrate,_e?de.scaleResolutionDownBy=_e:delete de.scaleResolutionDownBy,x?de.maxFramerate=x:delete de.maxFramerate});if(Se.degradationPreference=fe,Se.encodings.length>0){C.setParameters?.(Se).catch(we=>{d.error("Failed to set sender parameters",Se,we)});let de=C.getParameters();d.log(`applyVideoTrackSettings: actual encodings= ${JSON.stringify(de.encodings)}`)}}je.applyVideoTrackSettings=Mi;function br(_,C){Array.isArray(C)||(C=[C]);for(let y of C)if(_.includes(y))return!0;return!1}je.includesOneOf=br;function fa(_){return Object.entries(_.participantState?.state||{}).reduce((C,[y,v])=>(_.participantState&&(C[y]={ts:_.participantState.stateUpdateTs[y],state:v}),C),{})}je.mapParticipantState=fa;function Sa(_){let C=_.map(y=>({uid:y.externalId,mediaSettings:y.mediaSettings,status:y.status,muteStates:y.muteStates,unmuteOptions:y.unmuteOptions,participantState:y.participantState,markers:y.markers,movieShareInfos:y.movieShareInfos}));return l.filterObservers?C.filter(y=>!y.uid.observer):C}je.mapSharedParticipants=Sa;function va(_,C){let y=Object.keys(_),v=Object.keys(C);if(y.length!==v.length)return!1;for(let f of y)if(!v.hasOwnProperty(f)||_[f].state!==C[f].state||_[f].ts!==C[f].ts)return!1;return!0}je.isEqualParticipantState=va;function Mr(_,C,y=!1){let v=Object.keys(_),f=Object.keys(C);if(v.length!==f.length)return!1;for(let D of v){if(!C.hasOwnProperty(D))return!1;let W=_[D],F=C[D];if(y&&ue(W)&&ue(F))return Mr(W,F,y);if(W!==F)return!1}return!0}je.isObjectsEquals=Mr;function Ia(_,C){if(_.length!==C.length)return!1;for(let y of _)if(C.indexOf(y)<0)return!1;return!0}je.isArraysEquals=Ia;function Ea(_){return!Object.keys(_).length}je.isEmptyObject=Ea;function me(_,C){if(!_&&!C)return 0;if(!_||!C)return _?-1:1;return v(C.rank,_.rank)||v(_.ts,C.ts)||y(_,C);function y(f,D){let W={[te.USER]:0,[te.GROUP]:1},{compositeUserId:F,deviceIdx:Y}=ei(f.id),{compositeUserId:_e,deviceIdx:x}=ei(D.id),{id:fe,type:he}=Z(F),{id:Se,type:de}=Z(_e);return v(W[he],W[de])||v(fe,Se)||v(Y,x)}function v(f,D){return f<D?-1:f===D?0:1}}je.participantMarkerCompare=me;function V(_,C){let y=Object.entries(_).filter(([,v])=>Array.isArray(C)?!C.includes(v):v!==C);return xa(y)}je.objectFilterOutValues=V;function ee(_,C,y){let v=y;for(let f in _)_.hasOwnProperty(f)&&(v=C(v,_[f],f));return v}je.objectReduce=ee,je.setImmediate=(()=>{let _=1,C={},y=null;return typeof MessageChannel<"u"&&(y=new MessageChannel,y.port1.onmessage=v=>{let f=v.data;C[f]&&(C[f](),delete C[f])}),function(v){if(y&&document.visibilityState==="hidden"){let D=_;return _=_>=Number.MAX_SAFE_INTEGER?1:_+1,C[D]=v,y.port2.postMessage(D),()=>{C[D]&&delete C[D]}}let f=setTimeout(v,0);return()=>clearTimeout(f)}})();function ue(_){return _!==null&&typeof _=="object"&&!Array.isArray(_)}je.isObject=ue;function tt(_,C,y,v){function f(F,Y){let _e=0,x=F.length,fe=!1;for(let he=0;he<F.length;he++)if(F[he].startsWith("m=video")&&(_e=he),F[he].startsWith("a=mid:"+Y)&&(fe=!0),fe&&F[he].startsWith("m=")){x=he;break}return{start:_e,end:x}}function D(F,Y,_e,x,fe,he,Se){let de="a=rid:"+x+" send";for(let we=Y;we<_e;we++)if(F[we]===de){let Nt=de+" max-width="+he+";max-height="+Se+";max-br="+fe;F[we]=Nt}}let W=C?.sender;if(W&&W.track&&C.mid){let F=_.split(n),{start:Y,end:_e}=f(F,C.mid),x=W.getParameters();if(x.encodings)return x.encodings.forEach(fe=>{let he=fe.rid,Se=fe.maxBitrate,de=fe.scaleResolutionDownBy;if(y&&v&&de){let we=""+Math.round(y/de),_t=""+Math.round(v/de);D(F,Y,_e,he,Se,we,_t)}}),F.join(r)}return _}je.patchSimulcastAnswerSdp=tt})(kr||(kr={}));var I=kr;var vs=1e3;function oe(n,r,e=0){return r in n&&n[r]?n[r]:e}function Or(...n){return r=>{for(let e of n)if(e(r))return!0;return!1}}function ct(n,r){return e=>e[n]===r}function Is(n){return(r,e)=>e[n]-r[n]}function oi(n,r){return r.reduce((e,t)=>(e[t[n]]=t,e),{})}function La(n){let r={},e=[];for(let t of n)r[t.id]||(r[t.id]=!0,e.push(t));return e}function Nr(n){return Object.keys(n).filter(r=>n[r]!==void 0).map(r=>[r,n[r]]).reduce((r,e)=>(r[e[0]]=I.isObject(e[1])?Nr(e[1]):e[1],r),{})}function Ua(n){let r=[];for(let e of n)e.forEach(t=>r.push(t));return r}async function Es(n){let r=[];return RTCRtpReceiver.prototype.getStats?(r.push(...n.getReceivers().map(e=>e.getStats())),r.push(...n.getSenders().map(e=>e.getStats()))):r.push(n.getStats()),Promise.all(r).then(Ua).then(La)}function Ba(n){let r=n.filter(ct("type","candidate-pair")).sort(Is("priority")).find(Or(ct("nominated",!0),ct("selected",!0)));if(!r)return{timestamp:0,availableOutgoingBitrate:0,totalRoundTripTime:0,currentRoundTripTime:0,bytesSent:0,bytesReceived:0};let e={timestamp:r.timestamp,availableOutgoingBitrate:r.availableOutgoingBitrate||0,totalRoundTripTime:r.totalRoundTripTime||0,currentRoundTripTime:r.currentRoundTripTime||0,bytesSent:r.bytesSent||0,bytesReceived:r.bytesReceived||0},t=n.find(ct("id",r.remoteCandidateId));t&&Object.assign(e,{remote:{type:t.candidateType,address:t.ip||t.address,port:t.port,protocol:t.protocol}});let i=n.find(ct("id",r.localCandidateId));return i&&Object.assign(e,{local:{type:i.candidateType,address:i.ip||i.address,port:i.port,protocol:i.protocol,relayProtocol:i.relayProtocol,networkType:i.networkType}}),Nr(e)}function xr(n,r,e=!1){let t=oi("id",n),i=e?n.filter(Or(ct("type","remote-inbound-rtp"))):n.filter(Or(ct("type","inbound-rtp"),ct("type","outbound-rtp")));return b.browserName()==="Firefox"&&(i=Object.values(i.reduce((a,s)=>{if(!a[s.ssrc])a[s.ssrc]=s;else{let o=Object.assign({},a[s.ssrc],s),u=a[s.ssrc].isRemote?s:a[s.ssrc];o.id=u.id,o.type=u.type,delete o.isRemote,delete o.remoteId,a[o.ssrc]=o}return a},{}))),i.map(a=>{let s=Number(a.ssrc),o=a.mediaType||a.kind,u=a.remoteId||a.trackId,p=a.type,m=a.codecId;if(!p||!s||!o)return null;let h={ssrc:s,type:p,kind:o,bytesReceived:oe(a,"bytesReceived"),bytesSent:oe(a,"bytesSent"),headerBytesReceived:oe(a,"headerBytesReceived"),headerBytesSent:oe(a,"headerBytesSent"),jitter:oe(a,"jitter"),packetsLost:oe(a,"packetsLost"),packetsReceived:oe(a,"packetsReceived"),packetsSent:oe(a,"packetsSent"),fractionLost:oe(a,"fractionLost"),pliCount:oe(a,"pliCount"),firCount:oe(a,"firCount"),nackCount:oe(a,"nackCount"),userId:r[s],freezeCount:oe(a,"freezeCount",0),totalFreezesDuration:oe(a,"totalFreezesDuration",0)},R="mid"in a&&typeof a.mid=="string"?a.mid:void 0,M="rid"in a&&typeof a.rid=="string"?a.rid:void 0;if(R&&(h.mid=R),M&&(h.rid=M),o==="video"){let k=oe(a,"framesDecoded"),H=oe(a,"totalInterFrameDelay"),z=oe(a,"totalSquaredInterFrameDelay"),ae=oe(a,"encoderImplementation"),ve=oe(a,"decoderImplementation");ae&&(h.encoderImplementation=ae),ve&&(h.decoderImplementation=ve),h.interframeDelayVariance=(z-H*H/k)/k}if(o==="video"&&h.type==="outbound-rtp"&&(h.totalEncodeTime=oe(a,"totalEncodeTime")??0),o==="audio"&&(h.totalSamplesReceived=oe(a,"totalSamplesReceived"),h.concealedSamples=oe(a,"concealedSamples"),h.insertedSamplesForDeceleration=oe(a,"insertedSamplesForDeceleration"),h.removedSamplesForAcceleration=oe(a,"removedSamplesForAcceleration"),h.silentConcealedSamples=oe(a,"silentConcealedSamples"),h.concealmentEvents=oe(a,"concealmentEvents"),h.totalAudioEnergy=oe(a,"totalAudioEnergy")),m&&t[m]){let k=t[m];h.clockRate=k.clockRate,h.mimeType=k.mimeType,o==="audio"&&k.sdpFmtpLine&&(h.sdpFmtpLine=k.sdpFmtpLine)}if(u&&t[u]){let k=t[u];h.frameHeight=k.frameHeight,h.frameWidth=k.frameWidth,h.framesDecoded=k.framesDecoded,h.framesReceived=k.framesReceived,h.framesDropped=k.framesDropped}return Nr(h)}).filter(a=>!!a)}function Fa(n,r,e=!1){if(!r||!r.rtps||!n.rtps)return n;let t,i;e&&(t=oi("ssrc",n?.remoteRtps||[]),i=oi("ssrc",r?.remoteRtps||[]));let a=oi("ssrc",n.rtps),s=oi("ssrc",r.rtps),o=(n.timestamp-r.timestamp)/1e3;return!a||!s||Object.keys(a).forEach(u=>{let p=a[u],m=s[u];if(!(!p||!m)){if(p.bytesReceived&&p.bytesReceived>m.bytesReceived&&(p.bandwidth=Math.round((p.bytesReceived-m.bytesReceived)/o),p.bandwidth+=Math.round((p.headerBytesReceived-m.headerBytesReceived)/o)),p.bytesSent&&p.bytesSent>m.bytesSent&&(p.bandwidth=Math.round((p.bytesSent-m.bytesSent)/o),p.bandwidth+=Math.round((p.headerBytesSent-m.headerBytesSent)/o)),p.packetsReceived)if(p.packetsReceived>m.packetsReceived||p.packetsLost>m.packetsLost){let h=p.packetsLost-m.packetsLost,R=p.packetsReceived-m.packetsReceived;p.packetLoss=parseFloat((100*h/(h+R)).toFixed(2))}else p.packetLoss=0;if(p.freezeCount>m.freezeCount&&(p.freezeCountDelta=p.freezeCount-m.freezeCount),p.totalFreezesDuration>m.totalFreezesDuration){let h=p.totalFreezesDuration-m.totalFreezesDuration;p.totalFreezesDurationDelta=h}if(p.framesDropped&&m.framesDropped&&p.framesDropped>m.framesDropped&&(p.framesDroppedDelta=parseFloat(((p.framesDropped-m.framesDropped)/o).toFixed(0))),e&&p.type==="outbound-rtp"&&p.kind==="video"){let h=t?.[u],R=i?.[u],M=z=>z??0,k=Math.max(0,M(h?.packetsLost)-M(R?.packetsLost)),H=Math.max(1,p.packetsSent-m.packetsSent);n.transport.averageNetStat={currentRoundTripTime:(n.transport.currentRoundTripTime+r.transport.currentRoundTripTime)/2*1e3,lostPercent:Math.round(k/H*100)}}}}),n}async function Va(n,r,e={},t=!1){let i=await Es(n),a={timestamp:Date.now(),transport:Ba(i),rtps:xr(i,e)};return t&&(a.remoteRtps=xr(i,e,!0)),r?Fa(a,r,t):(await I.delay(vs),Va(n,a,e,t))}function Ts(n){performance.clearMarks(n),performance.mark(n)}function Rs(n){performance.clearMarks(n)}function Cs(n){let r=performance.getEntriesByName(n)[0];if(typeof r>"u")return null;let e=Math.round(performance.now()-r.startTime);return performance.clearMarks(n),e}function Ps(n){return`${T.SCREENSHARE_FIRST_FRAME}_${ys(n)}`}function ys(n){return typeof n=="string"?n:JSON.stringify(n)}var le={distinctById:La,rtcStatsToArray:Ua,extractTransport:Ba,extractRtps:xr,delta:Fa,collectStats:Va,setMark:Ts,clearMark:Rs,measureMark:Cs,getMarkNameScreenshareFirstFrame:Ps};var Ge=class Ge{constructor(){c(this,"_eventualLogs",new Set)}static create(){Ge._instance=new Ge}static logCallStat(r){if(Ge._instance?._eventualLogs.size){for(let e of Ge._instance._eventualLogs)Object.assign(e,{call_topology:r.call_topology,local_address:r.local_address,local_connection_type:r.local_connection_type,network_type:r.network_type,remote_address:r.remote_address,remote_connection_type:r.remote_connection_type,transport:r.transport}),P.logClientStats(e);Ge._instance._eventualLogs.clear()}P.logClientStats(r)}static logEventualStat(r){r.value===void 0&&(r.value=le.measureMark(r.name)),r.value!==null&&Ge._instance?._eventualLogs.add(r)}static destroy(){Ge._instance?._destroy(),Ge._instance=null}_destroy(){this._eventualLogs.clear()}};c(Ge,"_instance",null);var Ce=Ge;var Oi=class{constructor(r){c(this,"_participantId");c(this,"_firstFrameReceived",!1);this._participantId=r}measure(r,e){if(this._firstFrameReceived)return;this._firstFrameReceived=!0;let t=le.getMarkNameScreenshareFirstFrame(this._participantId),i=le.measureMark(t);i!==null&&Ce.logEventualStat({name:T.SCREENSHARE_FIRST_FRAME,value:i,width:r,height:e})}};var bs=65536,Ut=class n{constructor(r,e,t){c(this,"_participantId");c(this,"_onStream");c(this,"_onStat");c(this,"_statScreenShareFirstFrame");c(this,"_chunks",[]);this._participantId=r,this._onStream=e,this._onStat=t,this._statScreenShareFirstFrame=new Oi(r)}appendChunk(r){let e=this._chunks.length;if(r.start)this._measureFreezeDuration(!1),this._measureFreezeDuration(!0),e&&(d.warn("[FrameBuilder] Cleanup buffer",Array.prototype.slice.call(this._chunks)),this._chunks=[]);else if(!e||(this._chunks[e-1].sequence+1)%bs!==r.sequence){d.warn("[FrameBuilder] Got incorrect chunk");return}if(this._chunks.push(r),r.end){let t=this._processFrameData(),{width:i,height:a}=n.getFrameSize(t);this._processFrame({timestamp:r.timestamp,frameData:t,isVP9:r.isVP9,keyframe:r.keyframe,width:i,height:a}),this._statScreenShareFirstFrame.measure(i,a)}}destroy(){le.clearMark(T.SCREENSHARE_FREEZE_DURATION),le.clearMark(le.getMarkNameScreenshareFirstFrame(this._participantId)),this._chunks=[]}_processFrameData(){let r=this._chunks;this._chunks=[];let e=r.reduce((a,s)=>a+s.data.byteLength,0),t=new Uint8Array(e),i=0;for(let a of r)t.set(new Uint8Array(a.data),i),i+=a.data.byteLength;return t}static getFrameSize(r){let e={width:0,height:0},t=new ja.BitStream(r.buffer);t.bigEndian=!0,t.index+=2;let i=t.readBits(1),s=t.readBits(1)<<1|i;return s===3&&t.index++,t.readBits(1)===1||t.readBits(1)!==0||(t.index++,t.index++,t.index+=24,s>=2&&t.index++,t.readBits(3)!==7?(t.index++,(s===1||s===3)&&(t.index+=3)):(s===1||s===3)&&t.index++,e.width=t.readBits(16)+1,e.height=t.readBits(16)+1),e}static isBrowserSupported(){throw new Error("Method `isBrowserSupported` is not implemented")}_measureFreezeDuration(r){if(r){le.setMark(T.SCREENSHARE_FREEZE_DURATION);return}let e=le.measureMark(T.SCREENSHARE_FREEZE_DURATION);e!==null&&e>1e3&&this._onStat({freeze_duration:e})}};var It=class{constructor(r){c(this,"_onStream");this._onStream=r}async drawFrame(r){throw new Error("Method `drawFrame` is not supported by this implementation")}async drawImage(r){throw new Error("Method `drawImage` is not supported by this implementation")}static isBrowserSupported(){throw new Error("Method `isBrowserSupported` is not implemented")}};var Bt=class extends It{constructor(e){super(e);c(this,"_useImageBitmap");c(this,"_canvas",null);c(this,"_canvasContext",null);c(this,"_stream",null);c(this,"_track",null);d.debug("CanvasRenderer started"),this._useImageBitmap="ImageBitmap"in window}_createStream(e,t){this._canvas||(this._canvas=document.createElement("canvas"),this._canvas.width=e,this._canvas.height=t,this._canvas.style.pointerEvents="none",this._canvas.style.visibility="hidden",this._canvas.style.position="absolute",this._canvas.style.width="160px",this._canvas.style.height="90px",this._canvas.style.bottom="0",this._canvas.style.right="0",this._canvas.style.zIndex="5000",document.body.appendChild(this._canvas),this._useImageBitmap?this._canvasContext=this._canvas.getContext("bitmaprenderer"):this._canvasContext=this._canvas.getContext("2d"),this._stream=this._canvas.captureStream(0),this._track=this._stream.getVideoTracks()[0],this._track.contentHint="text")}_removeStream(){this._stream&&(this._stream.getTracks().forEach(e=>e.stop()),this._stream=null,this._track=null),this._canvasContext=null;try{this._canvas&&document.body.removeChild(this._canvas)}catch{}this._canvas=null}_requestCanvasFrame(){this._track&&this._track.requestFrame?this._track.requestFrame():this._stream&&this._stream.requestFrame&&this._stream.requestFrame()}async _drawImage(e){this._track||(this._createStream(e.width,e.height),this._onStream(this._stream));let t=this._canvas;if(t.width=e.width,t.height=e.height,this._useImageBitmap){let i;e instanceof ImageBitmap?i=e:i=await createImageBitmap(e,0,0,e.width,e.height),this._canvasContext.transferFromImageBitmap(i),i.close()}else{let i=this._canvasContext;i.clearRect(0,0,t.width,t.height),i.putImageData(e,0,0)}this._requestCanvasFrame()}async drawFrame(e){let t="createImageBitmap"in e?await e.createImageBitmap():await createImageBitmap(e);await this._drawImage(t)}async drawImage(e){await this._drawImage(e)}destroy(){this._removeStream(),d.debug("CanvasRenderer destroyed")}static isBrowserSupported(){return("CanvasCaptureMediaStream"in window||"CanvasCaptureMediaStreamTrack"in window)&&!(b.browserName()==="Safari"&&Number(b.browserVersion())===15)&&!(b.browserName()==="Firefox"&&Number(b.browserVersion())<60)}};var Et=class extends It{constructor(e){super(e);c(this,"_generator");c(this,"_writer");c(this,"_stream");d.debug("TrackGeneratorRenderer started"),this._generator=new MediaStreamTrackGenerator({kind:"video"}),this._writer=this._generator.writable.getWriter(),this._stream=new MediaStream([this._generator]),this._onStream(this._stream)}async drawFrame(e){await this._writer.write(e)}destroy(){this._writer.releaseLock(),this._generator.writable.close().then(()=>this._generator.stop()),d.debug("TrackGeneratorRenderer destroyed")}static isBrowserSupported(){return"VideoFrame"in window&&"MediaStreamTrackGenerator"in window&&Ye.isBrowserSupported()}};var Ft=class extends Ut{constructor(e,t,i){super(e,t,i);c(this,"_renderer");c(this,"_decoder");c(this,"_decoderReady",!1);c(this,"_decoderBusy",!1);c(this,"_decoderQueue",[]);c(this,"_fpsMeter");d.debug(`StreamBuilder started for participant [${e}]`),Et.isBrowserSupported()?this._renderer=new Et(t):this._renderer=new Bt(t),Ye.isBrowserSupported()?this._decoder=new Ye:this._decoder=new St;let a=async o=>{this._decoderBusy=!1,"VideoFrame"in window&&o instanceof VideoFrame?await this._renderer.drawFrame(o):await this._renderer.drawImage(o),this._fpsMeter.increment(),this._decodeQueue()},s=o=>{this._decoderBusy=!1,this._decodeQueue()};this._decoder.init(a,s).then(()=>{this._decoderReady=!0,this._decodeQueue()}),this._fpsMeter=new vt(o=>d.log(`[StreamBuilder][${e}] fps: ${o}`),2e4)}_processFrame(e){e.keyframe&&(this._decoderQueue=[]),this._decoderQueue.push(e),this._decodeQueue()}_decodeQueue(){if(!this._decoderReady||this._decoderBusy)return;let e=this._decoderQueue.shift();e&&(this._decoderBusy=!0,this._decoder.decodeFrame(e.timestamp,e.frameData,e.isVP9,e.keyframe))}destroy(){super.destroy(),this._fpsMeter.destroy(),this._decoder.destroy(),this._renderer.destroy(),d.debug(`StreamBuilder destroyed for participant ${this._participantId}`)}static isBrowserSupported(){return Bt.isBrowserSupported()||Et.isBrowserSupported()}};function Ha(n,r,e,t,i,a,s){let o=0;r&&(o|=1),e&&(o|=2),t&&(o|=4),s||(o|=8);let u=new ArrayBuffer(11),p=new DataView(u);if(p.setUint8(0,1),p.setUint16(1,i),p.setUint32(3,n),p.setUint8(7,a?1:0),p.setUint16(8,0),p.setUint8(10,o),!s)return u;let m=new Uint8Array(u.byteLength+s.byteLength);return m.set(new Uint8Array(u),0),m.set(new Uint8Array(s),u.byteLength),m.buffer}function Ga(n){let r=new DataView(n),e=r.getUint8(0),t=r.getUint16(1),i=r.getUint32(3),a=r.getUint8(7)===1,s=r.getUint16(8),o=r.getUint8(10),u=!!(o&1),p=!!(o&2),m=!!(o&4),h=!!(o&8);if(e!==1)throw new Error(`Unexpected protocol version. Got ${e}, expected 1`);return{timestamp:i,start:u,end:p,keyframe:m,sequence:t,isVP9:a,ssrc:s,eos:h,data:n.slice(11)}}function Wa(n){if(!n||!n.byteLength||n.byteLength!==4)return!1;let r=new DataView(n);return!(r.getUint8(0)!==1||r.getUint8(1)!==1||r.getUint16(2)!==0)}function Ka(n){if(!n||!n.byteLength||n.byteLength!==10)return null;let r=new DataView(n);if(r.getUint8(0)!==1||r.getUint8(1)!==2||r.getUint16(2)!==0)return null;let a=r.getUint16(4),s=r.getUint32(6);return{seq:a,ts2:s}}var O=ri(require("simple-ebml-builder"));var Ms=2**15-1,Lr=1,As=5,Ds=5;var Ur=class n{constructor(r){c(this,"_mediaSource");c(this,"_codec");c(this,"_sourceBuffer",null);c(this,"_queue",[]);c(this,"_clearBufferTill",0);this._mediaSource=new MediaSource,this._codec=r;let e=()=>{this._mediaSource.removeEventListener("sourceopen",e),this._initBuffer(),this._handleQueue()};this._mediaSource.addEventListener("sourceopen",e,!1)}_handleQueue(){if(!this._sourceBuffer||this._sourceBuffer.updating||!this._queue.length)return;if(this._clearBufferTill&&this._sourceBuffer.buffered.length){let t=this._sourceBuffer.buffered.start(0);t<this._clearBufferTill&&(this._sourceBuffer.remove(t,this._clearBufferTill),d.debug(`[WebmBuilder] SourceBuffer cleanup from ${t} to ${this._clearBufferTill}`)),this._clearBufferTill=0;return}let r=this._queue;this._queue=[];let e=n._buildQueue(r);this._sourceBuffer.appendBuffer(e)}static _buildQueue(r){if(r.length){if(r.length===1)return O.build(r[0])}else return new Uint8Array;let e=r.reduce((a,s)=>a+s.countSize(),0),t=new Uint8Array(e),i=0;for(let a of r){let s=O.build(a);t.set(s,i),i+=s.byteLength}return t}_initBuffer(){this._sourceBuffer=this._mediaSource.addSourceBuffer(`video/webm; codecs="${this._codec}"`),this._sourceBuffer.mode="sequence",this._sourceBuffer.addEventListener("updateend",()=>this._handleQueue())}changeType(r){return this._codec=r,this._sourceBuffer?.changeType(r)}append(r,e=!1){this._queue.push(r),e&&this._handleQueue()}cleanup(){this._mediaSource?.readyState==="open"&&this._sourceBuffer?.abort();let r=this._sourceBuffer?.buffered,e=r?.length;if(!e)return;let t=r.start(0),i=Math.max(0,r.end(e-1)-As);i-t>Ds&&(this._clearBufferTill=i)}destroy(){this._queue=[],this._mediaSource.readyState==="open"&&(this._sourceBuffer?.abort(),this._mediaSource.endOfStream()),this._sourceBuffer=null,this._clearBufferTill=0}get codec(){return this._codec}get mediaSource(){return this._mediaSource}get buffered(){return this._sourceBuffer?.buffered}},Tt=class n extends Ut{constructor(e,t,i){super(e,t,i);c(this,"_mediaBuffer",null);c(this,"_video",null);c(this,"_stream",null);c(this,"_earliestTimestamp",0);c(this,"_clusterStartTime",0);c(this,"_lastFrameTimestamp",0);d.debug(`[WebmBuilder] started for participant [${e}]`)}static _intToU16BE(e){return new Uint8Array([e>>8,e])}static _genWebmHeader(){return O.element(O.ID.EBML,[O.element(O.ID.EBMLVersion,O.number(1)),O.element(O.ID.EBMLReadVersion,O.number(1)),O.element(O.ID.EBMLMaxIDLength,O.number(4)),O.element(O.ID.EBMLMaxSizeLength,O.number(8)),O.element(O.ID.DocType,O.string("webm")),O.element(O.ID.DocTypeVersion,O.number(2)),O.element(O.ID.DocTypeReadVersion,O.number(2))])}static _genSegmentHeader(e,t,i){let a=O.element(O.ID.Info,[O.element(O.ID.TimecodeScale,O.number(1e6)),O.element(O.ID.MuxingApp,O.string("vk-webm-builder")),O.element(O.ID.WritingApp,O.string("vk-webm-builder"))]),s=[O.element(O.ID.PixelWidth,O.number(e)),O.element(O.ID.PixelHeight,O.number(t))],o=O.element(O.ID.Tracks,O.element(O.ID.TrackEntry,[O.element(O.ID.TrackNumber,O.number(Lr)),O.element(O.ID.TrackUID,O.number(Lr)),O.element(O.ID.TrackType,O.number(1)),O.element(O.ID.FlagLacing,O.number(0)),O.element(O.ID.DefaultDuration,O.number(1e9)),O.element(O.ID.CodecID,O.string(`V_${i.toUpperCase()}`)),O.element(O.ID.Video,s)]));return O.unknownSizeElement(O.ID.Segment,[a,o])}static _genClusterHeader(e){return O.unknownSizeElement(O.ID.Cluster,[O.element(O.ID.Timecode,O.number(Math.round(e)))])}_createVideo(e){this._mediaBuffer=new Ur(e),this._video=document.createElement("video"),this._video.autoplay=!0,this._video.controls=!1,this._video.muted=!0,this._video.style.pointerEvents="none",this._video.style.visibility="hidden",this._video.style.position="absolute",this._video.style.width="160px",this._video.style.height="90px",this._video.style.bottom="0",this._video.style.right="0",this._video.style.zIndex="5000",this._video.src=URL.createObjectURL(this._mediaBuffer.mediaSource),document.body.appendChild(this._video);let t=()=>{if(this._video?.src){d.warn(`[WebmBuilder] Video paused for participant [${this._participantId}], try to play again`);let i=this._video.seekable;i.length&&(this._video.currentTime=i.end(i.length-1)-.1),this._video.play().catch(()=>{})}};this._video.onpause=t,this._video.onwaiting=t,this._video.onstalled=t,this._video.onerror=()=>d.warn(`[WebmBuilder] Video Error for participant [${this._participantId}]`,this._video?.error),this._stream=this._video.captureStream(),this._onStream(this._stream)}_processFrame(e){let t=e.isVP9?"vp9":"vp8";this._mediaBuffer?this._mediaBuffer.codec!==t&&this._mediaBuffer.changeType(t):this._createVideo(t);let i=e.timestamp;if(i<=this._lastFrameTimestamp&&(i=this._lastFrameTimestamp+10,d.debug(`[WebmBuilder] Fixup timestamp for participant [${this._participantId}]`)),this._lastFrameTimestamp=i,this._earliestTimestamp)i-=this._earliestTimestamp;else{if(!e.keyframe)return;this._earliestTimestamp=i,i=0}if(e.keyframe){this._clusterStartTime=i,this._mediaBuffer?.cleanup(),d.debug(`[WebmBuilder] Segment header for participant [${this._participantId}]`);let o=n._genWebmHeader();this._mediaBuffer?.append(o);let u=n._genSegmentHeader(e.width,e.height,t);this._mediaBuffer?.append(u)}let a=Math.round(i-this._clusterStartTime);if(a>Ms&&(this._clusterStartTime=i,a=0),a===0){d.debug(`[WebmBuilder] Cluster header for participant [${this._participantId}]`);let o=n._genClusterHeader(this._clusterStartTime);this._mediaBuffer?.append(o)}let s=O.element(O.ID.SimpleBlock,[O.vintEncodedNumber(Lr),O.bytes(n._intToU16BE(a)),O.number((e.keyframe?1:0)<<7),O.bytes(e.frameData)]);this._mediaBuffer?.append(s,!0)}destroy(){super.destroy(),this._video&&(this._video.onpause=null,this._video.onwaiting=null,this._video.onstalled=null,this._video.onerror=null,this._video.pause(),this._video.src="",document.body.removeChild(this._video)),this._mediaBuffer&&(this._mediaBuffer.destroy(),this._mediaBuffer=null),this._stream&&(this._stream.getTracks().forEach(e=>e.stop()),this._stream=null),d.debug(`[WebmBuilder] destroyed for participant [${this._participantId}]`)}static isBrowserSupported(){return"captureStream"in window.HTMLVideoElement?.prototype&&window.MediaSource?.isTypeSupported('video/webm; codecs="vp8"')&&window.MediaSource?.isTypeSupported('video/webm; codecs="vp9"')}};var Rt=class{constructor(r,e,t,i,a){c(this,"_datachannel");c(this,"_participantIdRegistry",null);c(this,"_streamBuilders",{});c(this,"_onStream",()=>{});c(this,"_onEos",()=>{});c(this,"_onStat");d.debug("ScreenCaptureReceiver started"),this._datachannel=r,this._participantIdRegistry=e,this._onStream=t,this._onEos=i,this._onStat=a,this._datachannel.onmessage=s=>this._onDataChannelMessage(s.data)}_onDataChannelMessage(r){let e=Ga(r),t=this._participantIdRegistry?.getStreamDescription(e.ssrc)?.participantId;if(!t){d.warn(`Participant id for ssrc ${e.ssrc} not found in registry`);return}if(e.eos){this.close(t),this._onEos(t);return}let i=this._streamBuilders[t];if(!i){let a=s=>this._onStream(t,s);l.screenShareWebmBuilder&&Tt.isBrowserSupported()?i=new Tt(t,a,this._onStat):i=new Ft(t,a,this._onStat),this._streamBuilders[t]=i}i.appendChunk(e)}close(r){let e=this._streamBuilders[r];e&&(e.destroy(),delete this._streamBuilders[r])}destroy(){this._datachannel.onbufferedamountlow=null,this._datachannel.onmessage=null,this._onStream=()=>{},Object.values(this._streamBuilders).forEach(r=>r.destroy()),this._streamBuilders={},this._participantIdRegistry=null,d.debug("ScreenCaptureReceiver destroyed")}static isBrowserSupported(){return(Ye.isBrowserSupported()||St.isBrowserSupported())&&(Ft.isBrowserSupported()||Tt.isBrowserSupported())}};var Br=class{constructor(r,e,t){c(this,"_prev");c(this,"_next");c(this,"_data");this._next=t,t&&(t.prev=this),this._prev=e,e&&(e.next=this),this._data=r}get prev(){return this._prev}set prev(r){this._prev=r}get next(){return this._next}set next(r){this._next=r}get data(){return this._data}},ci=class{constructor(){c(this,"_head",null);c(this,"_tail",null);c(this,"_length",0)}get length(){return this._length}push(...r){for(let e of r)this._tail=new Br(e,this._tail,null),this._head||(this._head=this._tail),this._length++}merge(r){this._tail&&(this._tail.next=r._head),this._head||(this._head=r._head),this._tail=r._tail,this._length+=r._length,r.clear()}shift(){if(!this._length||!this._head)return null;let r=this._head;return this._head=r.next,this._head&&(r.next=null,this._head.prev=null),this._length--,this.length===1?this._tail=this._head:this.length||(this._head=this._tail=null),r.data}bisect(){if(this.length){let r=this.length>1?Math.floor(this.length/2):1;for(let e=0;e<r;e++)this.shift()}}head(){return this._head?.data||null}tail(){return this._tail?.data||null}clear(){this._head=null,this._tail=null,this._length=0}toString(){let r=[],e=this._head;for(;e!==null;)r.push(e.data),e=e.next;return r.length?JSON.stringify(r,(t,i)=>i instanceof Error?String(i):i):""}};var Fr=ri(require("@vkontakte/libvpx"));var ws=1e3,Vt=class extends He{constructor(e,t,i,a){super();c(this,"_sourceTrack");c(this,"_onFrame");c(this,"_useCongestionControl");c(this,"_maxBitrate");c(this,"_useImageCapture");c(this,"_video",null);c(this,"_imageCapture",null);c(this,"_canvas",null);c(this,"_canvasCtx",null);c(this,"_frameReadTimeout",0);c(this,"_lastFrame",null);this._sourceTrack=e,this._onFrame=t,this._useCongestionControl=i,this._maxBitrate=a,this._useImageCapture="ImageCapture"in window&&ImageCapture.prototype.grabFrame!==void 0&&"ImageBitmap"in window,(e.readyState!=="live"||!e.enabled||e.muted)&&(this._useImageCapture=!1)}_createDom(){this._canvas||(this._canvas=document.createElement("canvas"),this._canvas.style.pointerEvents="none",this._canvas.style.visibility="hidden",this._canvas.style.position="absolute",this._canvas.style.width="160px",this._canvas.style.height="90px",this._canvas.style.bottom="0",this._canvas.style.right="160px",this._canvas.style.zIndex="5000",this._canvasCtx=this._canvas.getContext("2d"),document.body.appendChild(this._canvas)),!this._video&&!this._useImageCapture&&(this._video=document.createElement("video"),this._video.controls=!1,this._video.autoplay=!1,this._video.preload="auto",this._video.muted=!0,this._video.style.pointerEvents="none",this._video.style.visibility="hidden",this._video.style.position="absolute",this._video.style.width="160px",this._video.style.height="90px",this._video.style.bottom="0",this._video.style.right="0",this._video.style.zIndex="5000",document.body.appendChild(this._video))}_removeDom(){try{this._canvas&&document.body.removeChild(this._canvas),this._video&&document.body.removeChild(this._video)}catch{}this._canvasCtx=null,this._canvas=null,this._video=null}async _createStream(e){if(!this._canvas)throw new Error("Canvas not found");if(!this._video&&!this._useImageCapture)throw new Error("Video element not found");return new Promise((t,i)=>{if(this._useImageCapture)this._imageCapture=new ImageCapture(e),t();else{let a=this._video;a.srcObject=new MediaStream([e]),a.onloadeddata=u=>t(),a.onerror=()=>i(new Error("Video element error"));let s=a.play(),o=()=>i(new Error("Autoplay is disabled"));s?s.catch(o):o()}})}_removeStream(){window.clearTimeout(this._frameReadTimeout),this._lastFrame?.close(),this._video&&(this._video.pause(),this._video.srcObject=null),this._imageCapture&&(this._imageCapture=null)}_drawFrameVideo(){if(!this._canvas||!this._canvasCtx||!this._video)throw new Error("Fatal error");this._video.paused&&this._video.play();let e=this._video.videoWidth,t=this._video.videoHeight;return this._canvas.width=this._video.width=e,this._canvas.height=this._video.height=t,this._canvasCtx.clearRect(0,0,e,t),this._canvasCtx.drawImage(this._video,0,0,e,t),this._canvasCtx.getImageData(0,0,e,t)}async _getFrameBitmap(){if(!this._imageCapture)throw new Error("Destroyed");return this._imageCapture.grabFrame()}_drawFrameData(e){if(!this._canvas||!this._canvasCtx)throw new Error("Destroyed");let t=e.width,i=e.height;return this._canvas.width=t,this._canvas.height=i,this._canvasCtx.clearRect(0,0,t,i),this._canvasCtx.drawImage(e,0,0,t,i),this._canvasCtx?.getImageData(0,0,t,i)}async init(){this._createDom();let e=this._sourceTrack.getSettings().width,t=this._sourceTrack.getSettings().height;d.debug(`LibVPxEncoder started ${e}x${t}, codec ${this.isVP9()?"VP9":"VP8"}`),await this._createStream(this._sourceTrack),await this._createWorker(`"use strict";var exports=(()=>{var u=Object.defineProperty;var R=Object.getOwnPropertyDescriptor;var y=Object.getOwnPropertyNames;var x=Object.prototype.hasOwnProperty;var V=(a,r)=>{for(var s in r)u(a,s,{get:r[s],enumerable:!0})},h=(a,r,s,i)=>{if(r&&typeof r=="object"||typeof r=="function")for(let e of y(r))!x.call(a,e)&&e!==s&&u(a,e,{get:()=>r[e],enumerable:!(i=R(r,e))||i.enumerable});return a};var A=a=>h(u({},"__esModule",{value:!0}),a);var M={};V(M,{default:()=>F});var F=(a,r,s,i)=>{let e;function m(t,o){return a({locateFile:r}).then(n=>{if(e=new n.VpxEncoder,e.debug(o),!e.init(t?n.VpxType.VP9:n.VpxType.VP8))throw self.postMessage({type:"log_error",message:"encoder-init-fail-libvpx"}),new Error("LibVPxEncoder failed to create");if(s){let d=Math.round(i/1e3);e.setTargetBitrate(d)}else e.setMaxQuantizer(10),e.setTargetBitrate(1024)})}function E(t,o,n,p){let d=e.allocateImage(t,o);if(!d){self.postMessage({type:"frame",error:"No buffer data"});return}d.set(new Uint8Array(n));let l=Math.round(performance.now()),f=150;if(!e.encode(l,f,p)){self.postMessage({type:"frame",error:"Encode failed"});return}let b=e.readFrame();if(!b){self.postMessage({type:"frame",error:"No encoded data"});return}e.readFrame()&&(self.postMessage({type:"debug",message:"LibVPxEncoder dropped frame"}),self.postMessage({type:"log_error",message:"LibVPxEncoder-drop"}));let c=new Uint8Array(b.byteLength);c.set(b),self.postMessage({type:"frame",frameType:p?"key":"delta",timestamp:l,duration:f,width:t,height:o,data:c.buffer},[c.buffer])}function g(t,o){let n=Math.round(t/1e3);e.setTargetBitrate(n)}self.onmessage=t=>{switch(t.data.type){case"init":m(t.data.isVP9,t.data.debug).then(()=>self.postMessage({type:"ready"})).catch(o=>self.postMessage({type:"error",error:String(o)}));break;case"frame":E(t.data.width,t.data.height,t.data.imageData,t.data.keyFrame);break;case"set_bitrate":g(t.data.bitrate,t.data.useCbr);break}}};return A(M);})();
|
|
10
|
+
`,i=>{i.error?this._onFrame(null,i.error):this._onFrame({type:i.frameType,timestamp:i.timestamp,duration:i.duration,data:i.data,byteLength:i.data?.byteLength,width:i.width,height:i.height})},[Fr.default,Fr.default.getUrl,this._useCongestionControl,this._maxBitrate],{isVP9:this.isVP9(),debug:d.enabled()})}_encode(e,t){let i=e.data.buffer;this._sendToWorker("frame",{width:e.width,height:e.height,imageData:i,keyFrame:t},[i])}_requestFrameVideo(e){let t=this._drawFrameVideo();this._encode(t,e)}_requestFrameBitmap(e){window.clearTimeout(this._frameReadTimeout),this._frameReadTimeout=window.setTimeout(()=>{if(this._lastFrame){let t=this._drawFrameData(this._lastFrame);this._encode(t,e)}else this._onFrame(null)},ws),this._getFrameBitmap().then(t=>{window.clearTimeout(this._frameReadTimeout),this._lastFrame?.close(),this._lastFrame=t;let i=this._drawFrameData(t);this._encode(i,e)}).catch(()=>{})}requestFrame(e=!1){this._useImageCapture?this._requestFrameBitmap(e):this._requestFrameVideo(e)}setBitrate(e,t,i){this._sendToWorker("set_bitrate",{bitrate:e,useCbr:t})}isVP9(){return!1}destroy(){this._removeWorker(),this._removeStream(),this._removeDom(),d.debug("LibVPxEncoder destroyed")}static isBrowserSupported(){return"WebAssembly"in window&&"Worker"in window&&("CanvasCaptureMediaStream"in window||"CanvasCaptureMediaStreamTrack"in window)}};var Ct=class extends He{constructor(e,t,i,a,s,o){super();c(this,"_sourceTrack");c(this,"_trackProcessor");c(this,"_onFrame");c(this,"_useCongestionControl");c(this,"_maxBitrate");c(this,"_useCbr");c(this,"_frameRate");this._sourceTrack=e,this._onFrame=t,this._useCongestionControl=i,this._maxBitrate=a,this._useCbr=s,this._frameRate=o,this._trackProcessor=new MediaStreamTrackProcessor({track:e})}async init(){let e=this._sourceTrack.getSettings().width,t=this._sourceTrack.getSettings().height,i=this._trackProcessor.readable;d.debug(`WebCodecsEncoder started ${e}x${t}, codec ${this.isVP9()?"VP9":"VP8"}`),await this._createWorker(`"use strict";var exports=(()=>{var p=Object.defineProperty;var T=Object.getOwnPropertyDescriptor;var B=Object.getOwnPropertyNames;var x=Object.prototype.hasOwnProperty;var _=(a,t)=>{for(var n in t)p(a,n,{get:t[n],enumerable:!0})},I=(a,t,n,i)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of B(t))!x.call(a,o)&&o!==n&&p(a,o,{get:()=>t[o],enumerable:!(i=T(t,o))||i.enumerable});return a};var M=a=>I(p({},"__esModule",{value:!0}),a);var O={};_(O,{default:()=>S});var S=()=>{let t,n,i,o,g,m,d=null,f=0,b=!1,u=0,F,V,c=!1,l=!1;function h(e){t=e.readable,n=t.getReader(),i=e.width,o=e.height,g=e.isVP9,m=e.framerate,F=e.useCongestionControl,V=e.maxBitrate,F&&(u=V,c=e.useCbr),E(),self.postMessage({type:"ready"})}function A(e){e&&!l&&(l=!0),self.clearTimeout(f),f=self.setTimeout(()=>{d&&y(d,l)},1e3),!b&&(b=!0,n.read().finally(()=>{b=!1,self.clearTimeout(f)}).then(({done:r,value:s})=>{if(d?.close(),d=null,!(r||!s)){if(!R){n.releaseLock(),t.cancel();return}d=s,y(s,l)}}))}function y(e,r){(e.codedWidth!==i||e.codedHeight!==o)&&(i=e.codedWidth,o=e.codedHeight,E(),l=!0),R.encode(e,{keyFrame:r}),r&&(l=!1)}function E(){let e={framerate:m,codec:g?"vp09.00.50.08":"vp8",width:i,height:o,latencyMode:"realtime",bitrateMode:c?"constant":"variable"};u>0&&(e.bitrate=u),R.configure(e)}function C(e,r,s){u=e,c=r,m=s,E()}let R=new VideoEncoder({output:e=>{let r;e.data?r=e.data:(r=new ArrayBuffer(e.byteLength),e.copyTo(r)),self.postMessage({type:"frame",frameType:e.type,timestamp:e.timestamp,duration:e.duration,width:i,height:o,data:r},[r])},error:e=>{self.postMessage({type:"frame",error:String(e)})}});self.onmessage=e=>{switch(e.data.type){case"init":h(e.data);break;case"frame":A(e.data.keyFrame);break;case"set_bitrate":C(e.data.bitrate,e.data.useCbr,e.data.fps);break}}};return M(O);})();
|
|
11
|
+
`,a=>{a.error?this._onFrame(null,a.error):this._onFrame({type:a.frameType,timestamp:a.timestamp,duration:a.duration,data:a.data,byteLength:a.data?.byteLength,width:a.width,height:a.height})},[],{readable:i,width:e,height:t,isVP9:this.isVP9(),framerate:this._frameRate,useCongestionControl:this._useCongestionControl,maxBitrate:this._maxBitrate,useCbr:this._useCbr},[i])}requestFrame(e=!1){this._sendToWorker("frame",{keyFrame:e})}setBitrate(e,t,i){this._sendToWorker("set_bitrate",{bitrate:e,useCbr:t,fps:i})}isVP9(){return!0}destroy(){this._removeWorker(),d.debug("WebCodecsEncoder destroyed")}static isBrowserSupported(){return"VideoEncoder"in window&&"Worker"in window&&"EncodedVideoChunk"in window&&"MediaStreamTrackProcessor"in window}};var ks=2100,Os=600,xs=1.2,$a=.8,Ns=2e3,Ls=8e3,Vr=8e3,Us=16e3,Bs=4,Fs=2e3,xi=(t=>(t[t.NONE=0]="NONE",t[t.UP=1]="UP",t[t.DOWN=2]="DOWN",t))(xi||{}),di=class{constructor(r,e,t,i,a,s,o){c(this,"_onCongestion");c(this,"_ccEnabled");c(this,"_fastSharing");c(this,"_trendDelayThreshold");c(this,"_highDelayThreshold");c(this,"_targetFps");c(this,"_minBitrate");c(this,"_maxBitrate");c(this,"_targetBitrate");c(this,"_lastDown");c(this,"_lastUp");c(this,"_lastProbing");c(this,"_lastCheckDelay");c(this,"_upPenalty",0);c(this,"_probing");c(this,"_delayAvgShort",-1);c(this,"_delayAvgLong",-1);c(this,"_minDelay",Number.MAX_VALUE);c(this,"_maxDelay",0);c(this,"_largeDelayDuration",0);c(this,"_lastFpsCalcMs");c(this,"_frames",0);c(this,"_fps",0);this._onCongestion=r,this._ccEnabled=i,this._minBitrate=e,this._maxBitrate=t,this._fastSharing=a,this._targetFps=o,s>0?this._highDelayThreshold=s:this._highDelayThreshold=ks,a&&(this._highDelayThreshold=Os),this._trendDelayThreshold=Math.round(this._highDelayThreshold/3),this._targetBitrate=this._maxBitrate,this._probing=!1;let u=Date.now();this._lastDown=0,this._lastUp=u,this._lastProbing=u,this._lastCheckDelay=0,this._lastFpsCalcMs=0}checkDelay(r,e,t){let i=Date.now();if(this._calcFps(i),this._calcDelay(e,i),this._delayAvgShort<=0||this._delayAvgLong<=0||!this._ccEnabled)return;let a=0,s=this._delayAvgShort-this._delayAvgLong,o=Math.round(Math.abs(s)*100/this._delayAvgLong),u=s>40&&o>30&&this._delayAvgShort>this._trendDelayThreshold,p=this._delayAvgShort>this._highDelayThreshold;u||p?a=2:Math.abs(s)<40&&o<10&&!p&&(a=1);let m=Math.round(this._targetBitrate/1e3),h=t;r%20===0&&d.debug(`#${r}: cc: delay=${e} short=${this._delayAvgShort} long=${this._delayAvgLong} delta=${s} percent=${o} -> ${xi[a]} tr=${m} br=${t}`);let R=i-this._lastDown;if(a===2&&R>Ns){this._probing&&(this._upPenalty=Math.min(++this._upPenalty,Bs),this._probing=!1);let ae=$a*h*1e3;if(ae>=this._targetBitrate&&(ae=this._targetBitrate*$a),ae=Math.max(ae,this._minBitrate),ae<this._targetBitrate){let ve=Math.round(ae/1e3),ye=Math.round(this._upPenalty*Vr/1e3);d.log(`#${r}: cc: delay=${e} short=${this._delayAvgShort} long=${this._delayAvgLong} delta=${s} percent=${o} -> ${xi[a]}`),d.log(`#${r}: cc: DOWN delay=${e} bitrate=${h} target=${m} -> newBitrate=${ve} penalty=${ye}s`),this._setBitrate(ae,!0),this._targetBitrate=ae}this._lastDown=i}let M=i-this._lastUp,k=Ls+this._upPenalty*Vr;if(a===1&&M>k&&R>k){let ae=Math.min(this._targetBitrate*xs,this._maxBitrate);if(ae>this._targetBitrate){let ve=Math.round(ae/1e3),ye=Math.round(this._targetBitrate/1e3),X=Math.round(this._upPenalty*Vr/1e3);d.log(`#${r}: cc: delay=${e} short=${this._delayAvgShort} long=${this._delayAvgLong} delta=${s} percent=${o} -> ${xi[a]}`),d.log(`#${r}: cc: UP bitrate=${h} target=${ye} -> newBitrate=${ve} penalty=${X}s`),this._setBitrate(ae,!1),this._targetBitrate=ae,this._probing=!0,this._lastProbing=i,this._lastUp=i}}let H=i-this._lastProbing;this._probing&&H>Us&&(this._probing=!1);let z=i-this._lastDown;this._upPenalty>0&&z>3*k&&(d.log(`#${r}: cc: UP reset penalty: oldPenalty=${this._upPenalty}`),this._upPenalty=0)}_setBitrate(r,e){this._fastSharing&&(e=!0);let t=this._targetFps;this._fps>0&&(t=this._fps),this._onCongestion(r,e,t)}_calcDelay(r,e){if(!(r<=0)){if(this._delayAvgShort===-1&&(this._delayAvgShort=r,this._delayAvgLong=r),this._delayAvgShort=Math.round((this._delayAvgShort*3+r)/4),this._delayAvgLong=Math.round((this._delayAvgLong*23+r)/24),r>0&&r<this._minDelay?this._minDelay=r:r>this._maxDelay&&(this._maxDelay=r),this._lastCheckDelay===0&&(this._lastCheckDelay=e),r>Fs){let t=e-this._lastCheckDelay;this._largeDelayDuration+=t}this._lastCheckDelay=e}}reconfigure(r,e){this._minBitrate=r,this._maxBitrate=e}getStat(){if(this._minDelay===Number.MAX_VALUE||this._maxDelay===0||this._delayAvgLong<=0)return null;let r={minDelay:this._minDelay,maxDelay:this._maxDelay,avgDelay:this._delayAvgLong,largeDelayDuration:this._largeDelayDuration};return this._minDelay=Number.MAX_VALUE,this._maxDelay=0,this._largeDelayDuration=0,r}_calcFps(r){this._frames++;let e=r-this._lastFpsCalcMs;if(e>5e3){this._lastFpsCalcMs=r;let t=this._fps,i=this._frames*1e3/e;this._fps===0?this._fps=Math.round(i):this._fps=Math.round((this._fps*3+i)/4),this._frames=0,this._fps!==t&&d.log(`cc: fps=${this._fps}`)}}};var li=class{constructor(r){c(this,"_maxSize");c(this,"_size",0);c(this,"_buffer");c(this,"_head",0);c(this,"_tail",0);this._maxSize=r,this._buffer=new Array(r)}add(r,e,t,i,a){this._tail===this._head&&this._size>0&&(this._head=++this._head%this._maxSize);let s=this._tail;return this._buffer[this._tail]={seq:r,ts:e,size:t,sent:Date.now(),start:i,end:a,ts2:-1,recv:-1},this._tail=++this._tail%this._maxSize,this._size++,s}update(r,e){let t=this.get(r);return t===null?null:(t.ts2=e,t.recv=Date.now(),t)}get(r){let e=this._head;for(let t=0;t<this._maxSize;t++){let i=this._buffer[e];if(r===i?.seq)return i;if(e=++e%this._maxSize,e===this._tail)break}return null}getServerBitrateK(r){let e=0,t=0,i=-1,a=-1,s=this._tail;for(let o=0;o<this._maxSize;o++){s>0?--s:s=this._maxSize-1;let u=this._buffer[s];if(!u||(a===-1&&(a=u.ts2,t=0),a>=0&&(t+=u.size),i=u.ts2,a-i>=r)||s===this._head)break}if(i>=0&&a>=0){let o=a-i;e=Math.round(o>0?t*8/o:0)}return e}getCurrentDelay(){let r=this._tail;for(let e=0;e<this._maxSize;e++){r>0?--r:r=this._maxSize-1;let t=this._buffer[r];if(!t)break;if(t.recv>=0&&t.sent>=0)return t.recv-t.sent;if(r===this._head)break}return 0}getMaxBandwidth(){let r=0,e=0,t=-1,i=-1,a=this._tail;for(let s=0;s<this._maxSize;s++){a>0?--a:a=this._maxSize-1;let o=this._buffer[a];if(o){if(i===-1&&o.end&&!o.start&&(i=o.ts2,e=0),t===-1&&i>=0&&o.start&&!o.end&&(t=o.ts2),t>=0&&i>=0){let u=i-t;r=u>0?e*8/u:0;break}if(i>=0&&(e+=o.size),a===this._head)break}}return Math.round(r)}clear(){this._buffer.fill(void 0),this._size=0,this._head=0,this._tail=0}};var jr=65536,js=50,Hs=400,Gs=1e6,Ws=3e5,Ks=3e4,$s=2e3,qs=5,Ni=0,Pt=class{constructor(r,e,t,i){c(this,"_encoder");c(this,"_datachannel");c(this,"_signaling");c(this,"_fastSharing");c(this,"_destroyed",!1);c(this,"_needKeyframe",!0);c(this,"DATA_SIZE");c(this,"_congestionControl");c(this,"_frameNum",0);c(this,"_width");c(this,"_height");c(this,"_feedback",new li(1024));c(this,"_lastSentFrameSeq",0);c(this,"_lastDeliveredFrameSeq",0);c(this,"_lastFrameDelay",0);c(this,"_lastFramerateReduced",Date.now());c(this,"_lastSharingStat",Date.now());c(this,"_congestionControlEnabled");c(this,"_queue",new ci);c(this,"_fpsMeter");c(this,"_maxFrameDelay");d.debug("ScreenCaptureSender started"),this.DATA_SIZE=l.consumerScreenDataChannelPacketSize-11,this._datachannel=e,this._signaling=t,this._fastSharing=i,this._congestionControlEnabled=l.screenShareCongestionControl||this._fastSharing,this._width=r.getSettings().width,this._height=r.getSettings().height,this._maxFrameDelay=this._fastSharing?l.screenShareCongestionControlThreshold:l.screenShareCongestionControlThreshold*2;let a=l.getScreenFrameRate(this._fastSharing),{minBitrate:s,maxBitrate:o}=this._calcMinMaxBitrate(this._width,this._height),u=this._onCongestionCallback.bind(this);d.log(`ScreenCaptureSender: CongestionControl: enabled=${this._congestionControlEnabled} minBitrate=${Math.round(s/1e3)}k maxBitrate=${Math.round(o/1e3)}k delayThreshold=${l.screenShareCongestionControlThreshold}`),this._congestionControl=new di(u,s,o,this._congestionControlEnabled,this._fastSharing,l.screenShareCongestionControlThreshold,a);let p=(m,h)=>{if(this._destroyed)return;if(!m){d.warn("requestFrame failed, keyFrame: "+this._needKeyframe,h),this._needKeyframe=!0,this._handleQueue();return}(m.width!==this._width||m.height!==this._height)&&(this._width=m.width,this._height=m.height,this._onResize(this._width,this._height));let R=this._sliceFrame(m);this._queue.merge(R),this._handleQueue(),this._sendSharingStat()};if(Ct.isBrowserSupported()){let m=this._fastSharing;this._encoder=new Ct(r,p,this._congestionControlEnabled,o,m,a)}else this._encoder=new Vt(r,p,this._congestionControlEnabled,o);this._datachannel.onmessage=m=>{Wa(m.data)&&(d.debug(`[${this._datachannel.label}] Requested keyframe`),this._needKeyframe=!0);let h=Ka(m.data);h!==null&&this._checkCcFeedback(h)},this._encoder.init().then(()=>this._handleQueue()).catch(m=>d.warn("ScreenCaptureSender init failed",m)),this._fpsMeter=new vt(m=>d.log(`[ScreenCaptureSender] fps: ${m}`),5e3)}_handleQueue(){if(this._destroyed)return;let r=this._queue.shift();if(!r){if((this._lastSentFrameSeq-this._lastDeliveredFrameSeq+jr)%jr>qs&&this._lastFrameDelay>this._maxFrameDelay){let i=Date.now();i-this._lastFramerateReduced>$s&&(this._lastFramerateReduced=i,d.debug(`[ScreenCaptureSender] reduce framerate: delay=${this._lastFrameDelay} maxDelay=${this._maxFrameDelay}`))}else this._requestFrame();return}if(!this._sendFrameChunk(r)){this._needKeyframe=this._needKeyframe||!this._cleanupQueue(),I.setImmediate(()=>this._handleQueue());return}if(r.isLast){this._frameNum++,this._fpsMeter.increment(),r.isKey&&d.debug(`#${this._frameNum}: sharing: send keyframe size=${Math.round(r.frameSize/1e3)}k`);let t=this._feedback.getCurrentDelay(),i=this._feedback.getServerBitrateK(2e3);t>0&&this._congestionControl.checkDelay(this._frameNum,t,i)}else I.setImmediate(()=>this._handleQueue())}_cleanupQueue(){let r=this._queue.head();for(;r;){if(r.isFirst&&r.isKey)return!0;this._queue.shift(),r=this._queue.head()}return!1}_requestFrame(){this._destroyed||(this._encoder.requestFrame(this._needKeyframe),this._needKeyframe=!1)}_sliceFrame(r){let e=r.type==="key",t=r.data.byteLength,i=new ci;for(let a=0;a<t;a+=this.DATA_SIZE){let s=r.data.slice(a,a+this.DATA_SIZE),o=a===0,u=t<=a+s.byteLength,p=this._wrapHeader(r.timestamp,o,u,e,s);i.push({data:p.data,sequence:p.sequence,frameSize:t,isFirst:o,isLast:u,isKey:e,timestamp:r.timestamp})}return i}_wrapHeader(r,e,t,i,a){let s=Ha(r,e,t,i,Ni,this._encoder.isVP9(),a),o={sequence:Ni,data:s};return Ni=(Ni+1)%jr,o}_stopPacket(){return this._wrapHeader(Date.now(),!1,!1,!1,null).data}_sendFrameChunk(r){if(!this._datachannel||this._datachannel.readyState!=="open")return!1;try{return this._datachannel.send(r.data),this._feedback.add(r.sequence,r.timestamp,r.data.byteLength,r.isFirst,r.isLast),r.isLast&&(this._lastSentFrameSeq=r.sequence),!0}catch(e){return d.warn("Error sending chunk to DataChannel",e),!1}}destroy(){this._queue.clear(),this._fpsMeter.destroy(),this._datachannel.onmessage=null,this._feedback.clear(),this._datachannel.readyState==="open"&&this._datachannel.send(this._stopPacket()),this._destroyed=!0,this._encoder.destroy(),d.debug("ScreenCaptureSender destroyed")}static isBrowserSupported(){return Ct.isBrowserSupported()||Vt.isBrowserSupported()}_onCongestionCallback(r,e,t){this._encoder.setBitrate(r,e,t)}_onResize(r,e){let{minBitrate:t,maxBitrate:i}=this._calcMinMaxBitrate(r,e),a=Math.round(t/1e3),s=Math.round(i/1e3);d.log(`cc: resize to ${r}x${e}, minBitrate=${a} maxBitrate=${s}`),this._congestionControl.reconfigure(t,i)}_calcMinMaxBitrate(r,e){(r===void 0||r<640)&&(r=640),(e===void 0||e<360)&&(e=360);let t=r*e/256,i=Math.max(Ws,Math.min(Gs,Math.round(t*js))),a=Math.round(t*Hs);return{minBitrate:i,maxBitrate:a}}_checkCcFeedback(r){let e=this._feedback.update(r.seq,r.ts2);if(e===null)d.debug(`cc: update failed, seq=${r.seq}`);else if(e.end){this._lastDeliveredFrameSeq=e.seq;let t=e.recv-e.sent;t>0&&(this._lastFrameDelay=t),this._handleQueue()}}_sendSharingStat(){let r=Date.now();if(r-this._lastSharingStat>Ks){let t=this._congestionControl.getStat();t!==null&&(d.debug(`cc: send stats: ${JSON.stringify(t)}`),this._signaling.reportSharingStat(t)),this._lastSharingStat=r}}};var Ue=class Ue{static get sessionKey(){return Ue._sessionKey}static set sessionKey(r){Ue._sessionKey=r}static get sessionSecretKey(){return Ue._sessionSecretKey}static set sessionSecretKey(r){Ue._sessionSecretKey=r}static get accessToken(){return Ue._accessToken}static set accessToken(r){Ue._accessToken=r}static isEmpty(){return!Ue._sessionKey}};c(Ue,"_sessionKey"),c(Ue,"_sessionSecretKey"),c(Ue,"_accessToken");var Ie=Ue;var g=class g{static set(r){r.hasOwnProperty("voiceParams")&&(Object.assign(g._params.voiceParams,r.voiceParams),delete r.voiceParams),r.hasOwnProperty("specListenerParams")&&(Object.assign(g._params.specListenerParams,r.specListenerParams),delete r.specListenerParams),r.hasOwnProperty("apiAuth")&&(Ie.accessToken=r.apiAuth.accessToken,Ie.sessionKey=r.apiAuth.sessionKey,Ie.sessionSecretKey=r.apiAuth.sessionSecretKey),Object.assign(g._params,I.objectFilterOutValues(r,void 0))}static get(r){return g._params[r]}static get appName(){return"ok.calls.sdk.js"}static get appVersion(){return 1.1}static get sdkVersion(){return"2.8.6-dev.8ff8b375.0"}static get debug(){return g._params.debug}static get protocolVersion(){return g._params.joinFromMultipleDevices?6:5}static get platform(){return g._params.platform}static set platform(r){g._params.platform=r}static get clientStatsPlatform(){return g._params.clientStatsPlatform}static set clientStatsPlatform(r){g._params.clientStatsPlatform=r}static get clientType(){return g._params.clientType}static set clientType(r){g._params.clientType=r}static get externalUserType(){return g._params.externalUserType}static set externalUserType(r){g._params.externalUserType=r}static get device(){return g._params.device}static get apiKey(){return g._params.apiKey}static get apiEnv(){return g._params.apiEnv}static get apiBaseUrl(){return g._params.apiBaseUrl}static set apiBaseUrl(r){g._params.apiBaseUrl=r}static apiEndpoint(r){switch(r??g.apiEnv){case"AUTO":case"PROD":return"https://api.mycdn.me";case"CALLS":return"https://calls.okcdn.ru";case"PROD_OK":return"https://api.ok.ru";case"TEST":return"https://apitest.ok.ru/api";case"VIDEOTEST":return"https://videotestapi.ok.ru/api";case"CALLSTEST":return"https://calls-test.okcdn.ru/api";default:return g._params.apiEnv}}static get authToken(){return g._params.authToken}static set authToken(r){g._params.authToken=r}static get anonymToken(){return g._params.anonymToken}static set anonymToken(r){g._params.anonymToken=r}static get domain(){return g._params.domain}static get externalDomain(){return g._params.externalDomain}static get iceServers(){return g._params.iceServers}static set iceServers(r){g._params.iceServers=r}static get wssBase(){return g._params.wssBase}static set wssBase(r){g._params.wssBase=r}static get wtsBase(){return g._params.wtsBase}static set wtsBase(r){g._params.wtsBase=r}static get wssToken(){return g._params.wssToken}static set wssToken(r){g._params.wssToken=r}static get signalingReconnectDelay(){return g._params.signalingReconnectDelay}static get signalingReconnectMaxDelay(){return g._params.signalingReconnectMaxDelay}static get signalingReconnectMaxCount(){return g._params.signalingReconnectMaxCount}static get waitConnectionDelay(){return g._params.waitConnectionDelay}static get waitResponseDelay(){return g._params.waitResponseDelay}static get waitMessageDelay(){return g._params.waitMessageDelay}static get waitAnotherTabDelay(){return g._params.waitAnotherTabDelay}static get debugLog(){return g._params.debugLog}static get forceRelayPolicy(){return g._params.forceRelayPolicy}static set forceRelayPolicy(r){g._params.forceRelayPolicy=r}static get videoMinWidth(){return g._params.videoMinWidth}static get videoMaxWidth(){return g._params.videoMaxWidth}static set videoMaxWidth(r){g._params.videoMaxWidth=r}static get videoMinHeight(){return g._params.videoMinHeight}static get videoMaxHeight(){return g._params.videoMaxHeight}static set videoMaxHeight(r){g._params.videoMaxHeight=r}static get videoAspectRatio(){return g._params.videoAspectRatio}static get videoFrameRate(){return g._params.videoFrameRate}static get videoFacingMode(){return g._params.videoFacingMode||(b.isMobile()?"user":null)}static set videoFacingMode(r){g._params.videoFacingMode=r}static get displaySurface(){return g._params.displaySurface}static get audioEffects(){return g._params.audioEffects}static set audioEffects(r){g._params.audioEffects=r,g._params.audioEffects?.setLogger((e,...t)=>d.send(e,...t))}static get videoEffects(){return g._params.videoEffects}static set videoEffects(r){g._params.videoEffects=r,g._params.videoEffects?.setLogger((e,...t)=>d.send(e,...t))}static get videoEffectMaxWidth(){return g._params.videoEffectMaxWidth}static set videoEffectMaxWidth(r){g._params.videoEffectMaxWidth=r}static get videoEffectMaxHeight(){return g._params.videoEffectMaxHeight}static set videoEffectMaxHeight(r){g._params.videoEffectMaxHeight=r}static get vmoji(){return g._params.vmoji?.isBrowserSupported()?g._params.vmoji:null}static set vmoji(r){g._params.vmoji=r}static get vmojiOptions(){return g._params.vmojiOptions||{protocolVersion:1,renderingOptions:{}}}static set vmojiOptions(r){g._params.vmojiOptions=r}static get voiceParams(){return g._params.voiceParams}static get specListenerParams(){return g._params.specListenerParams}static get iceRestartWaitTime(){return g._params.iceRestartWaitTime}static get transportConnectionWaitTime(){return g._params.transportConnectionWaitTime}static get statisticsInterval(){return g._params.statisticsInterval}static set statisticsInterval(r){g._params.statisticsInterval=r}static get networkStatisticsInterval(){return g._params.networkStatisticsInterval}static get perfStatReportEnabled(){return g._params.perfStatReportEnabled}static get callStatReportEnabled(){return g._params.callStatReportEnabled}static get clientEventsLoggingEnabled(){return g._params.clientEventsLoggingEnabled}static get enableLogPerfStatReport(){return g._params.enableLogPerfStatReport}static get producerNotificationDataChannel(){return g._params.producerNotificationDataChannel}static get producerCommandDataChannel(){return g._params.producerCommandDataChannel}static get consumerScreenDataChannel(){return g._params.consumerScreenDataChannel&&Pt.isBrowserSupported()}static get producerScreenDataChannel(){return g._params.producerScreenDataChannel&&g.producerNotificationDataChannel&&Rt.isBrowserSupported()}static get asrDataChannel(){return g._params.asrDataChannel&&g.producerNotificationDataChannel}static get consumerScreenDataChannelPacketSize(){return g._params.consumerScreenDataChannelPacketSize}static get screenShareWebmBuilder(){return g._params.screenShareWebmBuilder}static get noiseSuppression(){return g._params.noiseSuppression}static set noiseSuppression(r){g._params.noiseSuppression=r}static get preferH264(){return g._params.preferH264}static get preferVP9(){return g._params.preferVP9}static get audioNack(){return g._params.audioNack}static get consumerScreenTrack(){return g._params.consumerScreenTrack&&g.consumerScreenDataChannel}static get producerScreenTrack(){return g._params.producerScreenTrack}static get movieShare(){return g._params.movieShare&&g.videoTracksCount>0}static get videoTracksCount(){return g.producerNotificationDataChannel?Number(g._params.videoTracksCount):0}static get breakVideoPayloadTypes(){return g._params.breakVideoPayloadTypes}static get useCallsToContacts(){return g._params.useCallsToContacts}static get useParticipantListChunk(){return g._params.useParticipantListChunk&&g.videoTracksCount>0}static get useRooms(){return g._params.useRooms}static get useChatRooms(){return g._params.useChatRooms}static get participantListChunkInitIndex(){return g._params.participantListChunkInitIndex??0}static get participantListChunkInitCount(){return g._params.participantListChunkInitCount??null}static get serverAudioRed(){return g._params.serverAudioRed}static get p2pAudioRed(){return g._params.p2pAudioRed}static get h264spsPpsIdrInKeyframe(){return g._params.h264spsPpsIdrInKeyframe}static get filterObservers(){return g._params.filterObservers}static get muteMode(){return g._params.muteMode}static get preserveAudioTracks(){return g._params.preserveAudioTracks}static get audioShare(){return b.isAudioShareSupported()&&g._params.audioShare}static get fastScreenShare(){return g._params.fastScreenShare}static get screenShareCongestionControl(){return g._params.screenShareCongestionControl}static get screenShareCongestionControlThreshold(){return g._params.screenShareCongestionControlThreshold}static get fastScreenShareWidth(){return g._params.fastScreenShareWidth}static get fastScreenShareHeight(){return g._params.fastScreenShareHeight}static get newMuteRules(){return g._params.newMuteRules}static get videoSuspend(){return g._params.videoSuspend}static get enumerateDevicesDelay(){return g._params.enumerateDevicesDelay}static getScreenFrameRate(r){return r?g._params.fastScreenShareFrameRate:g._params.screenFrameRate}static get switchVideoAtBadNetwork(){return g._params.switchVideoAtBadNetwork}static get enableVideoEffectsFpsDegradation(){return g._params.enableVideoEffectsFpsDegradation}static get simulcast(){return g._params.simulcast}static set simulcast(r){g._params.simulcast=r}static get webtransport(){return g._params.webtransport}static set webtransport(r){g._params.webtransport=r}static get webtransportFF(){return g._params.webtransportFF}static set webtransportFF(r){g._params.webtransportFF=r}static toJSON(){return{apiKey:g._params.apiKey,apiEnv:g._params.apiEnv,audioShare:g._params.audioShare,useCallsToContacts:g._params.useCallsToContacts,useParticipantListChunk:g._params.useParticipantListChunk,useRooms:g._params.useRooms,useChatRooms:g._params.useChatRooms,fastScreenShare:g._params.fastScreenShare,participantListChunkInitCount:g._params.participantListChunkInitCount,screenShareCongestionControl:g._params.screenShareCongestionControl,screenShareCongestionControlThreshold:g._params.screenShareCongestionControlThreshold,videoTracksCount:g._params.videoTracksCount,asrDataChannel:g._params.asrDataChannel,videoMaxHeight:g._params.videoMaxHeight,videoMaxWidth:g._params.videoMaxWidth,videoEffectMaxHeight:g._params.videoEffectMaxHeight,videoEffectMaxWidth:g._params.videoEffectMaxWidth,videoSuspend:g._params.videoSuspend,debugLog:g._params.debugLog,callStatReportEnabled:g._params.callStatReportEnabled,joinFromMultipleDevices:g._params.joinFromMultipleDevices,movieShare:g._params.movieShare,newMuteRules:g._params.newMuteRules,clientType:g._params.clientType,clientStatsPlatform:g._params.clientStatsPlatform,consumerScreenDataChannelPacketSize:g._params.consumerScreenDataChannelPacketSize,switchVideoAtBadNetwork:g._params.switchVideoAtBadNetwork,simulcast:g._params.simulcast,webtransport:g._params.webtransport,webtransportFF:g._params.webtransportFF}}};c(g,"_params",{platform:"WEB",clientStatsPlatform:"",clientType:"PORTAL",externalUserType:"",device:"browser",apiKey:"",authToken:"",anonymToken:"",apiEnv:"AUTO",apiBaseUrl:null,domain:"",externalDomain:"",iceServers:[],wssBase:"",wtsBase:"",wssToken:"",signalingReconnectDelay:1e3,signalingReconnectMaxDelay:5e3,signalingReconnectMaxCount:10,waitConnectionDelay:1e4,waitResponseDelay:1e4,waitMessageDelay:15e3,waitAnotherTabDelay:200,debugLog:!1,debug:!1,forceRelayPolicy:!1,videoMinWidth:428,videoMinHeight:240,videoMaxWidth:1280,videoMaxHeight:720,videoAspectRatio:16/9,videoFrameRate:25,screenFrameRate:15,videoFacingMode:null,displaySurface:"monitor",audioEffects:null,videoEffects:null,videoEffectMaxWidth:640,videoEffectMaxHeight:360,vmoji:null,vmojiOptions:null,iceRestartWaitTime:2e4,transportConnectionWaitTime:5e3,statisticsInterval:5e3,networkStatisticsInterval:2e4,perfStatReportEnabled:!0,callStatReportEnabled:!1,clientEventsLoggingEnabled:!1,enableLogPerfStatReport:!1,voiceParams:{smoothing:.8,minFreq:200,maxFreq:5e3,interval:500,threshold:.35,speakerLevelMultiplier:1.8},specListenerParams:{connectionTimeout:1e4,volumeTimeout:1e4},producerNotificationDataChannel:!0,producerCommandDataChannel:!0,consumerScreenDataChannel:!0,producerScreenDataChannel:!0,asrDataChannel:!1,consumerScreenDataChannelPacketSize:64*1024,screenShareWebmBuilder:!1,noiseSuppression:!0,preferH264:!1,preferVP9:!1,audioNack:!0,consumerScreenTrack:!0,producerScreenTrack:!0,videoTracksCount:30,movieShare:!1,useCallsToContacts:!1,useParticipantListChunk:!1,useRooms:!1,useChatRooms:!1,participantListChunkInitIndex:0,participantListChunkInitCount:null,serverAudioRed:!0,p2pAudioRed:!0,h264spsPpsIdrInKeyframe:!0,breakVideoPayloadTypes:!1,joinFromMultipleDevices:!1,filterObservers:!1,muteMode:!1,preserveAudioTracks:!1,audioShare:!1,fastScreenShare:!1,screenShareCongestionControl:!1,screenShareCongestionControlThreshold:2100,fastScreenShareFrameRate:24,fastScreenShareWidth:1280,fastScreenShareHeight:720,newMuteRules:!1,videoSuspend:!1,enumerateDevicesDelay:2e3,switchVideoAtBadNetwork:!1,enableVideoEffectsFpsDegradation:!1,simulcast:!1,webtransport:!1,webtransportFF:!1});var l=g;function qa(n,r){return!(n.isAudioEnabled!==r.isAudioEnabled||n.isVideoEnabled!==r.isVideoEnabled||n.isScreenSharingEnabled!==r.isScreenSharingEnabled||n.isFastScreenSharingEnabled!==r.isFastScreenSharingEnabled||n.isAudioSharingEnabled!==r.isAudioSharingEnabled||n.isAnimojiEnabled!==r.isAnimojiEnabled)}function Ee(n){return Object.assign({isAudioEnabled:!1,isVideoEnabled:!1,isScreenSharingEnabled:!1,isFastScreenSharingEnabled:!1,isAudioSharingEnabled:!1,isAnimojiEnabled:!1},n||{})}var za=n=>n.stop(),pi=n=>n.getTracks().forEach(za),Ja=n=>n.getVideoTracks().forEach(za);async function Li(n,r){try{let e=typeof r.width=="number"?r.width:void 0,t=typeof r.height=="number"?r.height:void 0;await n.applyConstraints({...r,...e&&{width:{max:e,ideal:e}},...t&&{height:{max:t,ideal:t}}})}catch(e){d.warn("setVideoConstraints failed",e)}}var Ui=class extends re{constructor(){super(...arguments);c(this,"FPS_LIMITS",[13,20,Math.max(l.videoFrameRate,25)]);c(this,"THRESHOLD",.8);c(this,"HISTORY_LENGTH",10);c(this,"_fpsMeterUnsubscribe",null);c(this,"_fpsHistory",{cursor:0,arr:[]});c(this,"_fpsLimitCursor",this.FPS_LIMITS.length-1)}get fpsLimit(){return this.FPS_LIMITS[this._fpsLimitCursor]}watch(e){this._cleanup();try{e&&(this._assertsVideoEffect(e),this._fpsMeterUnsubscribe=e.addFpsMeterListener(this._handleFpsMeter.bind(this)))}catch(t){d.warn("VideoEffectsFpsLimiter error",t)}}_handleFpsMeter(e){if(this._fpsHistory.arr[this._fpsHistory.cursor]=e,this._fpsHistory.cursor=(this._fpsHistory.cursor+1)%this.HISTORY_LENGTH,this._fpsHistory.arr.length===this.HISTORY_LENGTH&&this._fpsLimitCursor){let t=this._fpsHistory.arr.reduce((a,s)=>a+s,0)/this.HISTORY_LENGTH,i=this.FPS_LIMITS[this._fpsLimitCursor];t<i*this.THRESHOLD&&(this._fpsLimitCursor=Math.max(0,this._fpsLimitCursor-1)),i!==this.fpsLimit&&this._triggerEvent("fps-limit",this.fpsLimit)}}_assertsVideoEffect(e){if(!("addFpsMeterListener"in e))throw new Error("Outdated VideoEffect version")}addEventListener(e,t){return super.addEventListener(e,t)}_cleanup(){this._fpsMeterUnsubscribe?.(),this._fpsMeterUnsubscribe=null}destroy(){this._cleanup(),super.unsubscribe()}};var Le=(i=>(i.audio="audio",i.video="video",i.screen="screen",i.audioshare="audioshare",i))(Le||{});var Bi=class extends re{constructor(){super();c(this,"_stream",null);c(this,"_screenTrack",null);c(this,"_audioShareTrack",null);c(this,"_sendVideoTrack",null);c(this,"_cameraVideoTrack",null);c(this,"_micAudioTrack",null);c(this,"_audioEffectsTrack",null);c(this,"_mediaSettings",Ee());c(this,"_videoStatusOnScreenCapturingEnabled",!1);c(this,"_effect",null);c(this,"_audioEffectParams",null);c(this,"_onDeviceChange");c(this,"_animojiEnabled",!1);c(this,"_videoEffectsFpsLimiter");this._initDeviceChangeListener(),l.audioShare&&(this._audioShareTrack=this.getSilentAudioShareTrack()),l.enableVideoEffectsFpsDegradation&&(this._videoEffectsFpsLimiter=new Ui,this._videoEffectsFpsLimiter.addEventListener("fps-limit",this.handleVideoEffectsLowFps.bind(this)))}async request(e=[se.AUDIO],t=!0){if(this._stream)return;let i=e.includes(se.VIDEO),a=e.includes(se.AUDIO),s=e.includes(se.ANIMOJI);if(!b.isBrowserSupported())throw new G(ie.UNSUPPORTED);try{this._stream=await b.getUserMedia(i,a,t),this._cameraVideoTrack?.stop(),this._cameraVideoTrack=this._stream.getVideoTracks()[0],this._micAudioTrack?.stop(),this._micAudioTrack=this._stream.getAudioTracks()[0],this._audioEffectsTrack?.stop(),this._mediaSettings.isVideoEnabled=i&&this._stream.getVideoTracks().filter(o=>o.enabled).length>0||!1,this._mediaSettings.isAudioEnabled=a&&this._stream.getAudioTracks().filter(o=>o.enabled).length>0||!1,this._mediaSettings.isAnimojiEnabled=s&&!this._mediaSettings.isVideoEnabled||!1,this._animojiEnabled=s,this._triggerEvent("SOURCE_READY")}catch(o){throw new G(o)}}getStream(){return this._stream}getScreenTrack(){return this._screenTrack}getSendVideoTrack(e=!1){return this._sendVideoTrack&&!e?this._sendVideoTrack:this._stream?this._stream.getVideoTracks()[0]:null}getSendAudioTrack(){return this._stream?.getAudioTracks().find(t=>!t.contentHint)||null}get isAnimojiRequested(){return this._animojiEnabled&&!this._mediaSettings.isVideoEnabled}addTrackToPeerConnection(e,t,i){let a=this.getStream(),s=this.getSendAudioTrack(),o=this.getSendVideoTrack(i);if(!a||!s&&!o&&!t)throw new Error("No local stream found");s&&!t&&e.addTrack(s,a),o&&!t&&e.addTrack(o,a)}getMediaSettings(){return this._mediaSettings}async changeDevice(e){switch(e){case"videoinput":if(this._mediaSettings.isVideoEnabled)return this._changeVideoInput();break;case"audioinput":if(this._mediaSettings.isAudioEnabled)return this._changeAudioInput();break;default:return Promise.reject(ie.UNKNOWN)}}stopVideoTrack(){this._mediaSettings.isVideoEnabled&&(this._stopEffect(),this._stream&&Ja(this._stream),this._cameraVideoTrack?.stop())}async setVideoStream(e,t){return t?this._changeScreen(!1,!1,e):this._changeVideoInput(e)}_initDeviceChangeListener(){!navigator.mediaDevices||!navigator.mediaDevices.enumerateDevices||!navigator.mediaDevices.addEventListener||(this._onDeviceChange=async e=>{if(!this._stream)return;let t=b.getSavedMicrophone(),i=b.getSavedCamera(),a=this._mediaSettings.isAudioEnabled&&t?.groupId!==e.microphone?.groupId,s=this._mediaSettings.isVideoEnabled&&i?.groupId!==e.camera?.groupId;try{a&&await this._changeAudioInput(),s&&await this._changeVideoInput()}catch{}},b.addEventListener("devicechange",this._onDeviceChange))}_destroyDeviceChangeListener(){this._onDeviceChange&&b.removeEventListener("devicechange",this._onDeviceChange)}async _changeVideoInput(e){try{let t=e?"stream":"video",i=e||await b._getUserVideo(!!this._effect,this._frameRate);if(this._cameraVideoTrack?.stop(),this._cameraVideoTrack=i.getVideoTracks()[0],!this._stream)pi(i);else{l.consumerScreenTrack||await this._disableScreenCapture();let a=await this._setEffect(this._effect,this._cameraVideoTrack);P.log(T.DEVICE_CHANGED,t),d.log("Video stream changed"),await this._replaceLocalTrack(a),this._mediaSettings.isVideoEnabled=!0,this._triggerEvent("SOURCE_CHANGED",{kind:"video"})}}catch(t){throw P.log(T.ERROR,"change_video"),d.warn("Camera change failed",t),t}}async setAudioStream(e){return this._changeAudioInput(e)}async _changeAudioInput(e=null){try{let t=e||await b.getUserAudio();if(this._micAudioTrack?.stop(),this._micAudioTrack=t.getAudioTracks()[0],!this._stream)pi(t);else{let i=await this._applyAudioEffect();P.log(T.DEVICE_CHANGED,"audio"),d.log("Audio stream changed",i),await this._replaceLocalTrack(i),this._mediaSettings.isAudioEnabled=!0,this._triggerEvent("SOURCE_CHANGED",{kind:"audio"})}}catch(t){throw P.log(T.ERROR,"change_audio"),d.error("Microphone change failed",t),t}}async _changeScreen(e,t,i){try{if(i=i||await b.getScreenMedia(e,t),!this._stream)pi(i);else{let a=i.getVideoTracks()[0];if(a.addEventListener("ended",()=>{this._mediaSettings.isScreenSharingEnabled&&this.disableScreenCapturing()},!1),l.consumerScreenTrack||this._stopEffect(),P.log(T.DEVICE_CHANGED,"screen"),d.log("Screen capturing started"),this._screenTrack=a,this._mediaSettings.isScreenSharingEnabled=!0,this._mediaSettings.isFastScreenSharingEnabled=e,l.consumerScreenTrack||(this._videoStatusOnScreenCapturingEnabled=this._mediaSettings.isVideoEnabled,this._mediaSettings.isVideoEnabled=!0,this._sendVideoTrack=l.consumerScreenDataChannel?b.getBlackMediaTrack(l.videoMinWidth,l.videoMinHeight):a,await this._replaceLocalTrack(a,this._sendVideoTrack)),i.getAudioTracks().length>0){let s=i.getAudioTracks()[0];s.contentHint="music",this._audioShareTrack=s,await this._replaceLocalTrack(s),this._mediaSettings.isAudioSharingEnabled=!0}t&&!this._mediaSettings.isAudioSharingEnabled&&d.debug("Audio share requested but not captured"),this._triggerEvent("SCREEN_STATUS",{track:a}),this._triggerEvent("SOURCE_CHANGED",{kind:"screen"})}}catch(a){throw P.log(T.ERROR,"screen"),d.warn("Screen capturing failed",a),a}}async _disableScreenCapture(){this._sendVideoTrack&&(this._sendVideoTrack.stop(),this._sendVideoTrack=null),this._screenTrack&&(this._screenTrack.stop(),this._screenTrack=null),await this.stopAudioShareTrack(),this._mediaSettings.isScreenSharingEnabled&&(this._mediaSettings.isScreenSharingEnabled=!1,this._mediaSettings.isFastScreenSharingEnabled=!1,this._triggerEvent("SCREEN_STATUS",{track:null}),this._triggerEvent("SOURCE_CHANGED",{kind:"screen"}))}async disableAudioShare(){await this.stopAudioShareTrack(),this._triggerEvent("SCREEN_STATUS",{track:null}),this._triggerEvent("SOURCE_CHANGED",{kind:"audioshare"})}async stopAudioShareTrack(){if(this._audioShareTrack){this._audioShareTrack.stop();let e=this.getSilentAudioShareTrack();await this._replaceLocalTrack(e),this._mediaSettings.isAudioSharingEnabled=!1}}async _applyAudioEffect(){if(!l.audioEffects||!this._audioEffectParams)return l.audioEffects?.pause(),this._micAudioTrack;l.audioEffects.isInitialized||await l.audioEffects.init(),l.audioEffects.resume(),l.audioEffects.setEffects(this._audioEffectParams.effects,this._audioEffectParams.isPreset),l.audioEffects.setSource(this._micAudioTrack);let e=l.audioEffects.outputStream.getAudioTracks()[0];return(!this._audioEffectsTrack||this._audioEffectsTrack.id!==e.id)&&(this._audioEffectsTrack=e),this._audioEffectsTrack}getSilentAudioShareTrack(){let e=b.getSilentMediaTrack();return e.contentHint="music",e.stop(),e}async _replaceLocalTrack(e,t){if(!this._stream)return;let i=this._stream.getTracks().find(a=>a.kind===e.kind&&a.contentHint===e.contentHint);i?.id!==e.id&&(i?(i!==this._audioEffectsTrack&&i.stop(),this._stream?.removeTrack(i),this._stream?.addTrack(e),this._triggerEvent("TRACK_REPLACED",e,t)):(this._stream.addTrack(e),this._triggerEvent("TRACK_REPLACED",e,t)))}async _setEffect(e,t){if(this._videoEffectsFpsLimiter?.watch(l.videoEffects),!l.videoEffects)return t;try{return l.videoEffects.setEffect(e,t)}catch(i){return d.warn("Video effect failed",i),t}}_stopEffect(){if(l.videoEffects)try{l.videoEffects.stopEffect()}catch(e){d.warn("Video effect failed",e)}}destroy(){this._destroyDeviceChangeListener(),l.videoEffects&&(this._effect=null,l.videoEffects.destroy()),l.audioEffects&&l.audioEffects.destroy(),this._stream&&(pi(this._stream),this._stream=null),this._cameraVideoTrack?.stop(),this._micAudioTrack?.stop(),this._audioEffectsTrack?.stop(),this._disableScreenCapture(),b.getAudioContext()?.suspend().catch(t=>d.error(t)),this._videoEffectsFpsLimiter?.destroy()}async toggleScreenCapturing(e){if(e.captureScreen){await this._changeScreen(e.fastScreenSharing,e.captureAudio);return}return l.consumerScreenTrack?this._disableScreenCapture():(e.captureAudio||await this.disableAudioShare(),this._videoStatusOnScreenCapturingEnabled?this._changeVideoInput():this.toggleVideo(!1))}async disableScreenCapturing(){return this.toggleScreenCapturing({captureScreen:!1,fastScreenSharing:!1,captureAudio:!1})}async toggleVideo(e){if(!this._stream)return;l.consumerScreenTrack||await this._disableScreenCapture(),this._cameraVideoTrack?.stop();let t;if(e){let i=await b._getUserVideo(!!this._effect,this._frameRate);this._cameraVideoTrack=i.getVideoTracks()[0],t=await this._setEffect(this._effect,this._cameraVideoTrack)}else t=b.getBlackMediaTrack(l.videoMinWidth,l.videoMinHeight),this._stopEffect();if(this._mediaSettings.isVideoEnabled=e,await this._replaceLocalTrack(t),this._animojiEnabled){this._triggerEvent("ANIMOJI_STATUS",!e);return}this._triggerEvent("SOURCE_CHANGED",{kind:"video"})}async toggleAudio(e){if(!this._stream)return;this._micAudioTrack?.stop();let t=async(i,a)=>{await this._replaceLocalTrack(i),this._mediaSettings.isAudioEnabled=a,this._triggerEvent("SOURCE_CHANGED",{kind:"audio"})};if(e)try{let i=await b.getUserAudio();this._micAudioTrack=i.getAudioTracks()[0],t(await this._applyAudioEffect(),!0)}catch(i){throw l.audioEffects?.pause(),t(b.getSilentMediaTrack(),!1),typeof i=="string"?new Error(i):i}else l.audioEffects?.pause(),t(b.getSilentMediaTrack(),!1)}toggleAnimojiCapturing(e){this._animojiEnabled=e,this._mediaSettings.isVideoEnabled||this._triggerEvent("ANIMOJI_STATUS",e)}onAnimojiSender(e){this._mediaSettings.isAnimojiEnabled=e,this._triggerEvent("SOURCE_CHANGED",{kind:"video"})}async setResolution({video:e,effect:t}){if(!l.consumerScreenTrack&&this._mediaSettings.isScreenSharingEnabled||!this._mediaSettings.isVideoEnabled)return;if(!this._stream)throw new Error("Local stream not found");if(!this._cameraVideoTrack)throw new Error("Local video track not found");let i=this._effect&&t||e;await this._applyVideoConstraints(this._cameraVideoTrack,i)}getCameraVideoTrack(){return this._cameraVideoTrack}async updateNoiseSuppression(){if(!this._stream||!this._mediaSettings.isAudioEnabled)return;let e=this._stream.getAudioTracks().find(t=>!t.contentHint);if(!e)throw new Error("Local audio track not found");if(e.enabled)return e.applyConstraints({noiseSuppression:l.noiseSuppression})}async videoEffect(e){if(!l.videoEffects)throw new Error("Video Effects library is not set");if(!l.consumerScreenTrack&&this._mediaSettings.isScreenSharingEnabled)throw new Error("Can't apply effect to screensharing");if(P.log(T.DEVICE_CHANGED,`effect_${e?.effect||"none"}`),!this._mediaSettings.isVideoEnabled){this._effect=e;return}if(this._stream&&e!==this._effect&&this._cameraVideoTrack){let t=this._effect;this._effect=e;try{let i=this._cameraVideoTrack.clone(),a=new MediaStream([i]);await this._applyVideoConstraints(i),await this._changeVideoInput(a)}catch(i){this._effect=t;let a=this._cameraVideoTrack.clone(),s=new MediaStream([a]);throw await this._changeVideoInput(s),i}}}async audioEffect(e){if(!l.audioEffects)throw new Error("Audio Effects library is not set");if(!this._mediaSettings.isAudioEnabled){this._audioEffectParams=e;return}if(this._stream&&(!e&&this._audioEffectParams||e&&!this._audioEffectParams||!I.isArraysEquals(e?.effects||[],this._audioEffectParams?.effects||[]))&&this._micAudioTrack){let t=this._audioEffectParams;this._audioEffectParams=e;try{let i=this._micAudioTrack.clone(),a=new MediaStream([i]);await this._changeAudioInput(a)}catch(i){this._audioEffectParams=t;let a=this._micAudioTrack.clone(),s=new MediaStream([a]);throw await this._changeAudioInput(s),i}}}getAudioShareTrack(){return this._audioShareTrack}handleVideoEffectsLowFps(e){this._mediaSettings.isVideoEnabled&&this._cameraVideoTrack&&e<l.videoFrameRate&&this._applyVideoConstraints(this._cameraVideoTrack).catch(t=>{d.warn("MediaSource handleVideoEffectsLowFps error",t)})}get _frameRate(){let e=this._videoEffectsFpsLimiter?.fpsLimit??l.videoFrameRate;return this._effect?Math.min(e,l.videoFrameRate):void 0}async _applyVideoConstraints(e,t){await Li(e,{width:this._effect?l.videoEffectMaxWidth:l.videoMaxWidth,height:this._effect?l.videoEffectMaxHeight:l.videoMaxHeight,...this._frameRate&&{frameRate:{ideal:this._frameRate}},...t})}};var ui=class{constructor(){c(this,"_cameraPermissionStatus");c(this,"_microphonePermissionStatus");c(this,"_listener")}static isSupported(){return b.browserName()!=="Firefox"&&"permissions"in navigator&&"PermissionStatus"in window}async init(r){try{let[e,t]=await Promise.all([navigator.permissions.query({name:"camera"}),navigator.permissions.query({name:"microphone"})]);this._cameraPermissionStatus=e,this._microphonePermissionStatus=t,this._listener=r,this._cameraPermissionStatus.onchange=i=>this.handlePermissionChange(i),this._microphonePermissionStatus.onchange=i=>this.handlePermissionChange(i)}catch(e){d.warn("NavigatorPermissions init error",e)}}handlePermissionChange(r){let e=r.target;if(e instanceof PermissionStatus){let{name:t,state:i}=e;switch(t){case"audio_capture":this._listener("microphone",i);break;case"video_capture":this._listener("camera",i);break}}}getPermissionState(r){let e=null;switch(r){case"camera":e=this._cameraPermissionStatus.state;break;case"microphone":e=this._microphonePermissionStatus.state;break}return e}};var Fi=(u=>(u.WAITING_HALL="WAITING_HALL",u.WAITING="WAITING",u.CONNECTING="CONNECTING",u.CONNECTED="CONNECTED",u.RECONNECT="RECONNECT",u.ERROR="ERROR",u.HANGUP="HANGUP",u.PERMISSIONS="PERMISSIONS",u))(Fi||{});function j(n,...r){let e=l.get(n);typeof e=="function"&&setTimeout(e,0,...r)}function pe(n,r,...e){if(l.filterObservers){if(Array.isArray(r)){if(r=r.filter(t=>!t.observer),!r.length)return}else if(r.observer)return}j(n,r,...e)}function Te(n){return Object.assign({},n)}function yt(n){return n.slice()}var Hr;(Kd=>{function n(S,A){j("onLocalStream",S,Te(A))}Kd.onLocalStream=n;function r(S,A){j("onScreenStream",S,Te(A))}Kd.onScreenStream=r;function e(S,A){j("onVmojiStream",S,Te(A))}Kd.onVmojiStream=e;function t(S){j("onVmojiError",S)}Kd.onVmojiError=t;function i(S,A){j("onLocalStreamUpdate",Te(S),A)}Kd.onLocalStreamUpdate=i;function a(S){d.debug("Local status:",S),j("onLocalStatus",S)}Kd.onLocalStatus=a;function s(S,A){pe("onRemoteStream",S,A)}Kd.onRemoteStream=s;function o(S,A){pe("onRemoteLive",S,A)}Kd.onRemoteLive=o;function u(S,A){pe("onLocalLive",S,A)}Kd.onLocalLive=u;function p(S,A){pe("onRemoteLiveUpdate",S,A)}Kd.onRemoteLiveUpdate=p;function m(S,A){pe("onLocalLiveUpdate",S,A)}Kd.onLocalLiveUpdate=m;function h(S,A){pe("onRemoteScreenStream",S,A)}Kd.onRemoteScreenStream=h;function R(S,A){pe("onRemoteVmojiStream",S,A)}Kd.onRemoteVmojiStream=R;function M(S,A,K){pe("onRemoteStreamSuspended",S,A,K)}Kd.onRemoteStreamSuspended=M;function k(S,A,K,Oe,gt){pe("onConversation",S,Te(A),Te(K),Oe,gt)}Kd.onConversation=k;function H(S){S&&j("onConversationParticipantListChunk",S)}Kd.onConversationParticipantListChunk=H;function z(S,A,K){pe("onRemoteMediaSettings",S,Te(A),K)}Kd.onRemoteMediaSettings=z;function ae(S,A){pe("onLocalMediaSettings",S,Te(A))}Kd.onLocalMediaSettings=ae;function ve(S,A,K){pe("onRemoteSharedMovieInfo",S,Te(A),K)}Kd.onRemoteSharedMovieInfo=ve;function ye(S,A,K){pe("onRemoteSharedMovieStoppedInfo",S,Te(A),K)}Kd.onRemoteSharedMovieStoppedInfo=ye;function X(S,A,K){pe("onLocalSharedMovieInfo",S,Te(A),K)}Kd.onLocalSharedMovieInfo=X;function be(S,A,K){pe("onLocalSharedMovieStoppedInfo",S,Te(A),K)}Kd.onLocalSharedMovieStoppedInfo=be;function Me(S,A,K){pe("onRemoteSharedUrl",S,A,K)}Kd.onRemoteSharedUrl=Me;function Zt(S,A){pe("onParticipantAdded",S,A)}Kd.onParticipantAdded=Zt;function la(S,A){pe("onParticipantJoined",S,A)}Kd.onParticipantJoined=la;function pa(S){j("onLocalParticipantState",Te(S))}Kd.onLocalParticipantState=pa;function Z(S,A,K){pe("onRemoteParticipantState",S,Te(A),K)}Kd.onRemoteParticipantState=Z;function ei(S,A){j("onRemoteParticipantsState",S,A)}Kd.onRemoteParticipantsState=ei;function ua(S,A,K=null){d.debug("Remote status:",A,S),pe("onRemoteStatus",S,A,K)}Kd.onRemoteStatus=ua;function ma(){j("onPermissionsRequested")}Kd.onPermissionsRequested=ma;function ha(S,A){j("onPermissionsError",S,A)}Kd.onPermissionsError=ha;function _a(S,A){pe("onRemoteRemoved",S,A)}Kd.onRemoteRemoved=_a;function ga(S,A,K){j("onCallState",S,A,Te(K))}Kd.onCallState=ga;function Mi(S,A){j("onDeviceSwitched",S,A)}Kd.onDeviceSwitched=Mi;function br(S,A,K,Oe=!1,gt=!1,Ar=null,Dr=null,ns,Ra,ss=null){let os=Ra?yt(Ra):void 0;j("onMuteStates",Te(S),yt(A),yt(K),Oe,gt,Ar,Dr,ns,os,ss)}Kd.onMuteStates=br;function fa(S,A,K=!1){pe("onRolesChanged",S,yt(A),K)}Kd.onRolesChanged=fa;function Sa(S,A=!1){j("onLocalRolesChanged",yt(S),A)}Kd.onLocalRolesChanged=Sa;function va(S,A,K,Oe){pe("onPinnedParticipant",S,A,K,Oe)}Kd.onPinnedParticipant=va;function Mr(S,A){j("onLocalPin",S,A)}Kd.onLocalPin=Mr;function Ia(S){j("onOptionsChanged",yt(S))}Kd.onOptionsChanged=Ia;function Ea(){j("onCallAccepted")}Kd.onCallAccepted=Ea;function me(S){pe("onAcceptedCall",S)}Kd.onAcceptedCall=me;function V(){j("onRateNeeded")}Kd.onRateNeeded=V;function ee(S){pe("onSpeakerChanged",S)}Kd.onSpeakerChanged=ee;function ne(S){j("onVolumesDetected",yt(S))}Kd.onVolumesDetected=ne;function ue(S,A){j("onLocalVolume",S,A)}Kd.onLocalVolume=ue;function tt(S,A){j("onJoinStatus",S,A)}Kd.onJoinStatus=tt;function je(S,A){j("onHangup",S,A)}Kd.onHangup=je;function _(S){j("onMultipartyChatCreated",Te(S))}Kd.onMultipartyChatCreated=_;function C(){j("onDeviceChange")}Kd.onDeviceChange=C;function y(S){j("onFingerprintChange",S)}Kd.onFingerprintChange=y;function v(){j("onTokenExpired")}Kd.onTokenExpired=v;function f(S,A,K=!1){j("onChatMessage",S,A,K)}Kd.onChatMessage=f;function D(S,A,K=!1){j("onCustomData",S,A,K)}Kd.onCustomData=D;function W(S,A,K,Oe,gt,Ar,Dr=null){j("onRecordStarted",S,A,K,Oe,gt,Ar,Dr)}Kd.onRecordStarted=W;function F(S=null){j("onRecordStopped",S)}Kd.onRecordStopped=F;function Y(S){j("onLocalNetworkStatusChanged",S)}Kd.onLocalNetworkStatusChanged=Y;function _e(S){j("onNetworkStatusChanged",S)}Kd.onNetworkStatusChanged=_e;function x(S,...A){j("onDebugMessage",S,...A)}Kd.onDebugMessage=x;function fe(S,A){let K=Object.assign({},S,{memory:A});j("onStatistics",K)}Kd.onStatistics=fe;function he(){j("onAutoplayError")}Kd.onAutoplayError=he;function Se(S,A,K,Oe,gt){j("onChatRoomUpdated",S,A,K,Oe,gt)}Kd.onChatRoomUpdated=Se;function de(S){j("onPromoted",S)}Kd.onPromoted=de;function we(S){j("onRemoteMixedAudioStream",S)}Kd.onRemoteMixedAudioStream=we;function _t(S){j("onJoinLinkChanged",S)}Kd.onJoinLinkChanged=_t;function Nt(S){j("onRoomsUpdated",S)}Kd.onRoomsUpdated=Nt;function Je(S,A,K,Oe){j("onRoomUpdated",S,A,K,Oe)}Kd.onRoomUpdated=Je;function ti(S){j("onRoomParticipantsUpdated",S)}Kd.onRoomParticipantsUpdated=ti;function Ta(S){j("onRoomSwitched",S)}Kd.onRoomSwitched=Ta;function kd(S){j("onRoomStart",S)}Kd.onRoomStart=kd;function Od(S,A=null){j("onFeedback",S,A)}Kd.onFeedback=Od;function xd(S){j("onFeaturesPerRoleChanged",S)}Kd.onFeaturesPerRoleChanged=xd;function Nd(S){j("onParticipantVmojiUpdate",S)}Kd.onParticipantVmojiUpdate=Nd;function Ld(S,A){j("onAsrSet",S,A)}Kd.onAsrSet=Ld;function Ud(S,A,K){j("onAsrStarted",S,A,K)}Kd.onAsrStarted=Ud;function Bd(S){j("onAsrStopped",S)}Kd.onAsrStopped=Bd;function Fd(S,A,K,Oe){j("onAsrTranscription",S,A,K,Oe)}Kd.onAsrTranscription=Fd;function Vd(S,A){j("onParticipantIdChanged",S,A)}Kd.onParticipantIdChanged=Vd;function jd(S){j("onVideoSuspendSuggest",S)}Kd.onVideoSuspendSuggest=jd;function Hd(S){j("onSignalingMessage",typeof S=="string"?S:Te(S))}Kd.onSignalingMessage=Hd;function Gd(S){j("onPromotionApproved",S)}Kd.onPromotionApproved=Gd;function Wd(){j("onPeerRegistered")}Kd.onPeerRegistered=Wd})(Hr||(Hr={}));var E=Hr;var Wr="_okcls_",jt=(()=>{try{let n=Date.now().toString(),r=window.localStorage,e=!1;return r.setItem(n,n),e=r.getItem(n)===n,r.removeItem(n),e?r:null}catch{return null}})();function zs(n){let r=jt?jt.getItem(Wr+n):null;if(r===null)return null;try{return JSON.parse(r)}catch{return null}}function Js(n,r){try{jt&&jt.setItem(Wr+n,JSON.stringify(r))}catch{}}function Ys(n){jt&&jt.removeItem(Wr+n)}var Gr;(t=>{function n(i){return zs(i)||null}t.get=n;function r(i,a){Js(i,a)}t.set=r;function e(i){Ys(i)}t.remove=e})(Gr||(Gr={}));var lt=Gr;var Gt=null,Vi=null,$i=null,zi=[],Ji=[],qi=[],We=null,Ke=null,Yi=null,Qi=!1,Xi=!1,ji,Ht,Hi,Kr=null,$r="",Gi=[],Wi=null,Ya=navigator.appVersion,Qs=navigator.appName,xe=navigator.userAgent,it={},dt=(e=>(e.USER="user",e.ENVIRONMENT="environment",e))(dt||{});(r=>{function n(e){return Object.values(r).includes(e)}r.contains=n})(dt||(dt={}));var Mt=class{constructor(r,e=!1,t=l.videoMaxWidth,i=l.videoMaxHeight,a=l.videoFrameRate){c(this,"audio");c(this,"video");c(this,"needVideo");c(this,"lastSimplifyWasReached");c(this,"supportedConstraints");c(this,"isVideoRequested",()=>this.needVideo);this.supportedConstraints=navigator.mediaDevices.getSupportedConstraints();let s=!1;if(r){s={noiseSuppression:l.noiseSuppression,echoCancellation:!0,autoGainControl:!0};let u=Re.getMicrophones(),p,m;if(Ke&&(m=Ke.groupId,p=Ke.deviceId),typeof r=="string")m=u.find(R=>R.deviceId===r)?.groupId,p=r;else if(!Ke&&Re.os()==="MacOS"&&u.find(h=>h.label.includes("iPhone"))){let h=u.find(R=>!R.label.includes("Virtual")&&!R.label.includes("iPhone"));h&&(m=h.groupId,p=h.deviceId)}m&&this.supportedConstraints.groupId?s.groupId={exact:m}:p&&(s.deviceId={exact:p})}let o=!1;if(e){o={width:{min:l.videoMinWidth,max:t,ideal:t},height:{min:l.videoMinHeight,max:i,ideal:i},aspectRatio:{ideal:l.videoAspectRatio},frameRate:{ideal:a}};let u=Re.getCameras(),p,m;if(We&&(m=We.groupId,p=We.deviceId),typeof e=="string")m=u.find(R=>R.deviceId===e)?.groupId,p=e;else if(!We&&Re.os()==="MacOS"&&u.find(h=>h.label.includes("iPhone"))){let h=u.find(R=>!R.label.includes("Virtual")&&!R.label.includes("iPhone"));h&&(m=h.groupId,p=h.deviceId)}m&&this.supportedConstraints.groupId?o.groupId={exact:m}:p&&(o.deviceId={exact:p}),l.videoFacingMode&&(o.facingMode={ideal:l.videoFacingMode},delete o.deviceId,delete o.groupId)}this.audio=s,this.video=o,this.needVideo=!!o,this.lastSimplifyWasReached=!1}getNative(){return Object.assign({},{audio:this.audio,video:this.video})}simplify(){return typeof this.video=="object"&&(this.video.width||this.video.height?(delete this.video.width,delete this.video.height):this.video.aspectRatio?delete this.video.aspectRatio:this.video.frameRate?delete this.video.frameRate:(this.video.deviceId||this.video.groupId||this.video.facingMode)&&(delete this.video.deviceId,delete this.video.groupId,delete this.video.facingMode)),typeof this.audio=="object"&&(this.audio.echoCancellation||this.audio.autoGainControl||this.audio.noiseSuppression?(delete this.audio.echoCancellation,delete this.audio.autoGainControl,delete this.audio.noiseSuppression):(this.audio.deviceId||this.audio.groupId)&&(delete this.audio.deviceId,delete this.audio.groupId)),this.video===!0&&this.audio===!0?this.video=!1:this.video===!1&&this.audio===!0?(this.audio=!1,this.video=this.needVideo):this.video===!0&&this.audio===!1&&(this.video=!1),this.video&&!Object.keys(this.video).length&&(this.video=!0),this.audio&&!Object.keys(this.audio).length&&(this.audio=!0),!this.audio&&!this.video&&(this.lastSimplifyWasReached=!0,this.audio=!this.isVideoRequested(),this.video=this.isVideoRequested()),this}canSimplify(){let r=typeof this.video=="object"&&(this.video.width||this.video.height||this.video.aspectRatio||this.video.frameRate||this.video.facingMode||this.video.deviceId||this.video.groupId)||this.video;return!!(typeof this.audio=="object"&&(this.audio.deviceId||this.audio.groupId||this.audio.noiseSuppression||this.audio.echoCancellation||this.audio.autoGainControl)||this.audio||r)&&!this.lastSimplifyWasReached}isVideo(){return!!this.video}isAudio(){return!!this.audio}},qr=class extends Mt{constructor(e,t,i,a){super(!1,!0);c(this,"captureController");if(this.captureController="CaptureController"in window?new CaptureController:null,typeof this.video=="object"?(delete this.video.deviceId,delete this.video.groupId,delete this.video.aspectRatio,delete this.video.frameRate,delete this.video.facingMode):this.video={},this.video.cursor="motion",this.video.width=e,this.video.height=t,this.video.frameRate=i,this.video.displaySurface=l.displaySurface,Re.browserName()==="Safari"){let s=Number(Re.browserVersion());s===16?(this.video.width={max:e},this.video.height={max:t}):s===17&&(delete this.video.width,delete this.video.height)}a&&(this.audio={noiseSuppression:!1,echoCancellation:!1,autoGainControl:!1})}getNative(){return Object.assign(super.getNative(),{systemAudio:"exclude",controller:this.captureController})}},bt=class bt{constructor(){c(this,"_lockId",Math.round(Math.random()*99998)+1)}busy(){if(bt._lockId)throw P.log(T.ERROR,"change_device"),d.warn("Device change failed: MediaSource is busy"),new Error("MediaSource is busy");bt._lockId=this._lockId}free(){bt._lockId===this._lockId&&(bt._lockId=0)}};c(bt,"_lockId",0);var Zi=bt;async function Qa(){Xi=!1,Qi=!1,Gt=null;let n={camera:Re.getSavedCamera(),microphone:Re.getSavedMicrophone(),output:Re.getSavedOutput()};await zr(),Xs("devicechange",n),E.onDeviceChange()}function Xs(n,...r){if(it[n])for(let e of it[n])e(...r)}async function zr(){return Gt||(!navigator.mediaDevices||!navigator.mediaDevices.enumerateDevices?[]:(!Vi&&navigator.mediaDevices.addEventListener&&(Vi=I.debounce(Qa,l.enumerateDevicesDelay),navigator.mediaDevices.addEventListener("devicechange",Vi)),!$i&&ui.isSupported()&&($i=new ui,await $i.init((n,r)=>{switch(r){case"denied":case"prompt":Vi?.();break}})),Gt=navigator.mediaDevices.enumerateDevices().then(n=>{zi=n.filter(i=>i.kind==="videoinput"?(i.label&&(Qi=!0),!0):!1),Ji=n.filter(i=>i.kind==="audioinput"?(i.label?Xi=!0:Re.isMobile()&&Re.browserName()==="Firefox"&&(Xi=Qi),!0):!1),qi=n.filter(i=>i.kind==="audiooutput");let r=We?.deviceId??lt.get("videoinput"),e=Ke?.deviceId??lt.get("audioinput"),t=Yi?.deviceId??lt.get("audiooutput");return We=zi.find(i=>i.deviceId===r)||null,Ke=Ji.find(i=>i.deviceId===e)||null,Yi=qi.find(i=>i.deviceId===t)||qi[0]||null,Gt=Promise.resolve(n),n}).catch(()=>(Gt=null,[]))))}function Zs(n){if(We&&Ke)return;let r=(e,t)=>{let i=t.getSettings()?.deviceId;return e.find(a=>a.deviceId===i||a.label===t.label)||null};n?.getTracks().forEach(e=>{!Ke&&e.kind==="audio"?Ke=r(Re.getMicrophones(),e):!We&&e.kind==="video"&&(We=r(Re.getCameras(),e))})}async function mi(n,r){d.debug("Try to get media",JSON.parse(JSON.stringify(n.getNative())));let e=(!n.isVideo()||Re.hasCameraPermission())&&(!n.isAudio()||Re.hasMicrophonePermission());!e&&!r&&E.onPermissionsRequested();let t=new Zi;try{t.busy();let i=await navigator.mediaDevices.getUserMedia(n.getNative());return t.free(),e||await Qa(),Zs(i),i}catch(i){switch(t.free(),d.error("getUserMedia error",i),i.name){case"PermissionDeniedError":case"PermissionDismissedError":case"NotAllowedError":case"SecurityError":case"DOMException":case"NotFoundError":r=n.isVideoRequested()?ie.CAMERA_PERMISSION:ie.MIC_PERMISSION;break;case"OverconstrainedError":r=ie.OVERCONSTRAINED;break;case"TypeError":r=ie.UNKNOWN;break;case"AbortError":case"NotReadableError":r=n.isVideoRequested()?ie.CAMERA_ACCESS:ie.MIC_ACCESS;break;case"Error":if(i.message==="MediaSource is busy"){r=n.isVideoRequested()?ie.CAMERA_ACCESS:ie.MIC_ACCESS;break}}if(n.canSimplify())return mi(n.simplify(),r);let a=r||ie.UNKNOWN;throw E.onPermissionsError(a,i),a}}async function eo(n){d.debug("Try to get screen",JSON.parse(JSON.stringify(n.getNative())));let r=new Zi;try{r.busy();let e=await navigator.mediaDevices.getDisplayMedia(n.getNative()),t=e?.getVideoTracks()[0];if(t){let i=t.getSettings()?.displaySurface;if(d.debug(`Got display media track: ${t.id} (${i})`),t.contentHint="text",n.captureController&&(i==="browser"||i==="window"))try{n.captureController.setFocusBehavior("no-focus-change")}catch(a){d.warn("Failed to set focus behavior",a)}}return e}catch(e){switch(e.name){case"PermissionDeniedError":case"NotAllowedError":case"SecurityError":throw ie.SCREEN_PERMISSION;default:throw ie.SCREEN_ACCESS}}finally{r.free()}}function Ki(){return Gi.length||(Gi=(()=>{let n,r=!1,e=0,t="0",i=xe.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i)||[];if(/trident/i.test(i[1]))return n=/\brv[ :]+(\d+)/g.exec(xe),["IE",n&&n[1]||"Unknown",r,e,t];if(i[1]==="Safari"){if(n=xe.match(/\bEdge\/(\d+)/),n)return["Edge",n[1]||"Unknown",r,e,t];if(n=xe.match(/\bCriOS\/(\d+)/),n)return["Chrome",n[1],!0,Number(n[1]),t];if(n=xe.match(/\bFxiOS\/(\d+)/),n)return["Firefox",n[1],!1,e,t];if(n=xe.match(/\bYaBrowser\/(\d+)/),n)return["Yandex",n[1],!1,e,t];if(n=xe.match(/\bOPT\/(\d+)/),n)return["Opera",n[1],!1,e,t]}if(i[1]==="Chrome"){if(r=!0,e=Number(i[2]),n=xe.match(/\bOPR\/(\d+)/),n)return["Opera",n[1]||"Unknown",r,e,t];if(n=xe.match(/\bYaBrowser\/(\d+)/),n)return["Yandex",n[1]||"Unknown",r,e,t];if(n=xe.match(/\bSferum\/((\d+)(?:\.\d+)*)/),n)return["Sferum",n[1]||"Unknown",r,e,t];if(n=xe.match(/\bEdge?\/(\d+)/),n)return["Edge",n[1]||"Unknown",r,e,t];if(typeof window.opr<"u"&&/^(.+\.)?ok.ru$/.test(window.location.host))return["Opera","Hidden",r,e,t]}return n=xe.match(/version\/(\d+)(?:(?:\.)(\d+))?/i),n&&n[2]!==void 0&&(t=n[2]),[i[2]?i[1]:Qs,n&&n[1]||i[2]||Ya,r,e,t]})()),Gi}var Re;(me=>{async function n(){await zr()}me.init=n;function r(){return zi}me.getCameras=r;function e(){return Ji}me.getMicrophones=e;function t(){return qi}me.getOutput=t;function i(){return zi.length>0}me.hasCamera=i;function a(){return Ji.length>0}me.hasMicrophone=a;function s(){return We}me.getSavedCamera=s;function o(){return Ke}me.getSavedMicrophone=o;function u(){return Yi}me.getSavedOutput=u;function p(){return l.videoFacingMode}me.getVideoFacingMode=p;function m(){return Qi}me.hasCameraPermission=m;function h(){return Xi}me.hasMicrophonePermission=h;function R(){return $i?.getPermissionState("microphone")??null}me.getMicrophonePermissionState=R;function M(V=!1){return h()?i()&&V?m():!0:!1}me.hasPermissions=M;async function k(V=!1,ee=!0,ne=!0){let ue=a()&&ee,tt=i()&&V,je;if(!ue&&!tt)je=new MediaStream;else try{je=await mi(new Mt(ue,tt))}catch{je=new MediaStream}return!je.getVideoTracks().length&&ne&&je.addTrack(me.getBlackMediaTrack()),!je.getAudioTracks().length&&ne&&je.addTrack(me.getSilentMediaTrack()),je}me.getUserMedia=k;async function H(V,ee){let ne=V?l.fastScreenShareWidth:window.screen.width,ue=V?l.fastScreenShareHeight:window.screen.height,tt=l.getScreenFrameRate(V);return eo(new qr(ne,ue,tt,ee))}me.getScreenMedia=H;async function z(V=!1,ee){let ne=V?l.videoEffectMaxWidth:l.videoMaxWidth,ue=V?l.videoEffectMaxHeight:l.videoMaxHeight;return mi(new Mt(!1,!0,ne,ue,ee))}me._getUserVideo=z;async function ae(V,ee){let ne=ee?.width||l.videoMaxWidth,ue=ee?.height||l.videoMaxHeight;return mi(new Mt(!1,V||!0,ne,ue))}me.getUserVideo=ae;async function ve(V){return mi(new Mt(V||!0,!1))}me.getUserAudio=ve;async function ye(V,ee){let[ne]=V.getVideoTracks();if(!ne)throw new Error("Video track not found in stream");return Li(ne,ee)}me.setResolution=ye;async function X(V,ee){let ue=(await zr()).find(tt=>tt.kind===V&&tt.deviceId===ee);return ue?(V==="videoinput"?We=ue:V==="audioinput"?Ke=ue:V==="audiooutput"&&(Yi=ue),lt.set(V,ee),ue):null}me._saveDeviceId=X;function be(){if(!Hi||Hi.readyState==="ended"){let V=me.getAudioContext(),ee=V.createMediaStreamDestination(),ne=V.createGain();ne.gain.value=1e-5,ne.connect(ee),ne.connect(V.destination);let ue=V.createOscillator();ue.type="sine",ue.frequency.value=0,ue.connect(ne),ue.start(),Hi=ee.stream.getAudioTracks()[0]}return Object.assign(Hi.clone(),{enabled:!1})}me.getSilentMediaTrack=be;function Me(V=l.videoMinWidth,ee=l.videoMinHeight){Ht||(Ht=document.createElement("canvas")),Ht.width=V,Ht.height=ee;let ne=Ht.getContext("2d");return ne.rect(0,0,V,ee),ne.fillStyle="black",ne.fill(),(!ji||ji.readyState==="ended")&&(ji=Ht.captureStream(l.videoFrameRate).getVideoTracks()[0]),Object.assign(ji.clone(),{enabled:!1})}me.getBlackMediaTrack=Me;function Zt(){if(Mi()==="Edge"&&Number(br())<70)return!1;try{let V=window;return"mediaDevices"in V.navigator&&"getUserMedia"in V.navigator.mediaDevices&&V.RTCPeerConnection&&V.RTCIceCandidate&&V.RTCSessionDescription&&V.HTMLCanvasElement&&V.HTMLCanvasElement.prototype.captureStream&&V.RTCRtpSender&&V.RTCRtpSender.prototype.replaceTrack&&V.RTCRtpSender.prototype.getParameters&&"sendBeacon"in navigator&&!0||!1}catch{return!1}}me.isBrowserSupported=Zt;function la(){return!!navigator.mediaDevices.getDisplayMedia}me.isScreenCapturingSupported=la;function pa(){let V=me.browserName()==="Safari"&&me.browserVersion()==="15"&&me.browserSubVersion()==="1",ee=me.browserName()==="Opera",ne=me.browserName()==="Yandex";return V||ee||ne}me.isBrokenH264Decoder=pa;function Z(){return me.browserName()==="Yandex"&&me.os()==="Windows"||l.simulcast}me.isBrokenVP9Encoder=Z;function ei(){return me.browserName()==="Safari"&&Number(me.browserVersion())===17&&[4,5,6].includes(Number(me.browserSubVersion()))}me.isBrokenVP9Decoder=ei;function ua(){return me.browserName()==="Firefox"&&Number(me.browserVersion())<60}me.isOldDataChannelDescription=ua;function ma(){return!(me.baseChromeVersion()&&me.isMobile())}me.canPreferH264=ma;function ha(){return!(me.browserName()==="Firefox"||me.browserName()==="Safari")}me.isSimulcastSupportedByBrowser=ha;function _a(){return $r||($r=(()=>{let V={Windows:/Win/,Android:/Android/,OpenBSD:/OpenBSD/,SunOS:/SunOS/,Linux:/(Linux|X11)/,iPad:/(iPad)/,iPhone:/(iPhone)/,iPod:/(iPod)/,MacOS:/(MacPPC|MacIntel|Mac_PowerPC|Macintosh|Mac OS X)/,QNX:/QNX/,UNIX:/UNIX/,BeOS:/BeOS/,OS2:/OS\/2/,Bot:/(nuhk|Googlebot|Yammybot|Openbot|Slurp|MSNBot|Ask Jeeves\/Teoma|ia_archiver)/};for(let ee in V)if(V.hasOwnProperty(ee)&&V[ee].test(xe))return ee;return"Unknown"})()),$r}me.os=_a;function ga(){return Kr===null&&(Kr=/Mobile|mini|Fennec|Android|iP(ad|od|hone)/.test(Ya)),Kr}me.isMobile=ga;function Mi(){return Ki()[0]}me.browserName=Mi;function br(){return Ki()[1]}me.browserVersion=br;function fa(){return Ki()[3]}me.baseChromeVersion=fa;function Sa(){return Wi||(Wi=new(window.AudioContext||window.webkitAudioContext)),Wi.resume().catch(()=>{d.warn("Failed to resume AudioContext")}),Wi}me.getAudioContext=Sa;function va(){return Ki()[4]}me.browserSubVersion=va;function Mr(){return me.baseChromeVersion()>=105&&!me.isMobile()}me.isAudioShareSupported=Mr;function Ia(V,ee){it[V]||(it[V]=[]),it[V].push(ee)}me.addEventListener=Ia;function Ea(V,ee){if(it[V])if(!ee)delete it[V];else{let ne=it[V].indexOf(ee);ne>-1&&it[V].splice(ne,1)}}me.removeEventListener=Ea})(Re||(Re={}));var b=Re;var Be=class Be{static get startTime(){return Be._list[0]?.t||0}static get endTime(){let r=Be._list;return r[r.length-1]?.t||0}static startSession(){Be._list=[]}static get conversationId(){return Be._conversationId}static set conversationId(r){Be._conversationId=r}static add(r){Be._list.push(r)}static _createContextLogs(){let r=[[`Calls SDK ${l.sdkVersion}`,l.toJSON()],["UserAgent:",navigator.userAgent],["Screen resolution:",`${window.screen.width}x${window.screen.height}`],["Permissions:",`Camera: ${b.hasCameraPermission()}, Mic: ${b.hasMicrophonePermission()}`]],e=new Date,t=e.getTime(),i=e.toLocaleString("ru-RU",{dateStyle:"short",timeStyle:"long"});return r.map(a=>({h:i,t,l:"LOG",d:a}))}static collectLogs(){let r=Be._list;return r.length===0?[]:[...Be._createContextLogs(),...r]}};c(Be,"_list",[]),c(Be,"_conversationId",null);var ke=Be;var er=class{constructor(){c(this,"_items",[])}get length(){return this._items.length}push(...r){this._items.push(...r)}merge(r){this._items.push(...r._items)}shift(){return this._items.shift()||null}bisect(){let r=this.length>1?Math.floor(this.length/2):1;this._items=this._items.slice(r)}head(){return this._items[0]||null}tail(){let r=this._items.length;return r?this._items[r-1]:null}clear(){this._items=[]}toString(){return this._items.length?JSON.stringify(this._items,(r,e)=>e instanceof Error?String(e):e):""}};var Jr=2*1024*1024,Xa=512*1024,Wt=100*1024,to=5,Qr="_okcls_logs_session_",io=3e4,Xr=class{constructor(){c(this,"_items",[]);c(this,"_itemsSize",0);c(this,"_storageSize",Jr);try{let r=window.localStorage;for(let e of Object.keys(r)){if(e.indexOf(Qr)!==0)continue;let t=r.getItem(e);if(!t){Za(e);continue}let i=tn(t);this.add(e,i)}}catch(r){console.error("Storage is blocked",r),this._storageSize=0}this._items.sort((r,e)=>r.date-e.date),this.cleanup(Wt)}get size(){return this._itemsSize}get length(){return this._items.length}get available(){return Math.max(this._storageSize-this._itemsSize,0)}get items(){return this._items}set storageSize(r){this._storageSize=Math.min(r,this._storageSize,Jr)}add(r,e){let t=parseInt(r.replace(Qr,""),10);this._itemsSize+=e,this._items.push({key:r,size:e,date:t})}deleteOldestItem(){let r=this._items.shift();r&&(Za(r.key),this._itemsSize-=r.size)}cleanup(r){for(;this.length&&(this.size>Jr||this.length>to-1||this.size+r>this.available);)this.deleteOldestItem()}};function en(){return`${Qr}${Date.now()}`}function tn(n){return new Blob([n]).size}function Za(n){try{window.localStorage.removeItem(n)}catch(r){console.error("Failed to remove log from storage",r)}}function tr(){let n=pt.toString();if(!Ae.available||!n)return;let r=tn(n);if(r>Xa){pt.bisect(),tr();return}Ae.cleanup(Wt+r);try{window.localStorage.setItem(ir,n)}catch(e){if(console.warn("Failed to write log to storage",e),Ae.storageSize=Ae.size+r,Ae.cleanup(Wt+r),Ae.available>=Wt+r){tr();return}if(r>Wt){pt.bisect(),tr();return}Ae.storageSize=0;return}r>Xa&&(Ae.add(ir,r),ir=en(),pt.clear(),Ae.cleanup(Wt))}function Zr(){!Ae.available||!pt.length||tr()}function ro(n=!1){let r=[];try{let i=window.localStorage;for(let s of Ae.items){let o=i.getItem(s.key);r.push(o)}let a=pt.toString();a&&r.push(a)}catch(i){console.error("Storage is blocked",i)}let e=`[${r.join(",")}]`;if(n)return e;let t=`logs_${Date.now()}.json`;return ao(e,t),t}function ao(n,r){let e=document.createElement("a"),t=new Blob([n],{type:"text/json"});e.href=URL.createObjectURL(t),e.download=r,e.click()}function rn(n,r){if(!Ae.available)return;let e=new Date,t={t:e.getTime(),l:n,d:r,h:e.toLocaleString("ru-RU",{dateStyle:"short",timeStyle:"long"})};pt.push(t),ke.add(t),Yr||(Yr=window.setTimeout(()=>{Yr=null,Zr()},io))}function ea(){Ae||(Ae=new Xr,pt=new er,ir=en(),window.addEventListener("beforeunload",Zr))}var Ae,pt,ir,Yr=null;window.__VKCallsSDKLogs__=(n=!1)=>(Ae||ea(),Zr(),ro(n));var ia=(i=>(i.DEBUG="DEBUG",i.LOG="LOG",i.WARN="WARN",i.ERROR="ERROR",i))(ia||{}),ta;(X=>{let n="📞",r=(be,...Me)=>{E.onDebugMessage(be,...Me)},e=!1,t=(be,Me)=>(...Zt)=>{be(...Zt),rn(Me,Zt)},i=console.debug.bind(console,n),a=console.log.bind(console,n),s=console.warn.bind(console,n),o=console.error.bind(console,n),u=r.bind(null,"DEBUG"),p=r.bind(null,"LOG"),m=r.bind(null,"WARN"),h=r.bind(null,"ERROR");X.debug=u,X.log=p,X.warn=m,X.error=h;function z(){return e}X.enabled=z;function ae(be){e=be,l.debugLog&&ea(),be?(X.debug=l.debugLog?t(i,"DEBUG"):i,X.log=l.debugLog?t(a,"LOG"):a,X.warn=l.debugLog?t(s,"WARN"):s,X.error=l.debugLog?t(o,"ERROR"):o):(X.debug=l.debugLog?t(u,"DEBUG"):u,X.log=l.debugLog?t(p,"LOG"):p,X.warn=l.debugLog?t(m,"WARN"):m,X.error=l.debugLog?t(h,"ERROR"):h)}X.toggle=ae;function ve(be,...Me){switch(be){case"DEBUG":(0,X.debug)(...Me);break;case"LOG":(0,X.log)(...Me);break;case"WARN":(0,X.warn)(...Me);break;case"ERROR":(0,X.error)(...Me);break}}X.send=ve;function ye(be,...Me){}X.test=ye})(ta||(ta={}));var d=ta;var so="kf";function Kt(n){return n.stopStream}function ra(n){return n.keyFrameRequested}function an(n){if(Kt(n))return"ss";if(ra(n))return so;let r="";return n.priority!==void 0&&(r+="p="+n.priority),n.width!==void 0&&n.height!==void 0&&(r!==""&&(r+=":"),r+="sz="+Math.round(n.width)+"x"+Math.round(n.height)),n.fit!==void 0&&(r!==""&&(r+=":"),r+="fit="+n.fit),r}var $t=(s=>(s.CAMERA="CAMERA",s.SCREEN="SCREEN",s.STREAM="STREAM",s.MOVIE="MOVIE",s.ANIMOJI="ANIMOJI",s.SHARED_URL="SHARED_URL",s))($t||{}),nn="s",sn="m";function Qe(n){return n.participantId+(n.mediaType?Lt+nn+n.mediaType:"")+(n.streamName?Lt+sn+n.streamName:"")}function hi(n){let r=n.split(Lt),e=r.shift();if(!e)throw new Error("Illegal stream description: "+n);let t=null,i,a=0;for(let o of r)switch(o.charAt(0)){case nn:t=oo(o.slice(1));break;case sn:i=o.slice(1);break;case ki:a=Number.parseInt(o.slice(1),10);break;default:throw new Error("Unexpected parameter type "+o.charAt(0)+" in stream description "+n)}return{participantId:I.compose(e,a),mediaType:t,streamName:i}}function oo(n){for(let r of Object.keys($t))if(r===n)return $t[r];return null}function Xe(){let n=new DataView(new ArrayBuffer(64)),r=0;function e(t){if(r+t>n.byteLength){let i=new Uint8Array(Math.max(r+t,n.byteLength+64));i.set(new Uint8Array(n.buffer.slice(0,r))),n=new DataView(i.buffer)}}return{put(t){if(e(t.byteLength),co(t)){let i=t.buffer;new Uint8Array(n.buffer).set(new Uint8Array(i),r)}else new Uint8Array(n.buffer).set(new Uint8Array(t),r);r+=t.byteLength},putI8(t){e(1),n.setInt8(r,t),++r},putI16(t){e(2),n.setInt16(r,t),r+=2},putI32(t){e(4),n.setInt32(r,t),r+=4},putI64(t){e(8);let i=t<0;i&&(t=-t);let a=t/4294967296|0,s=t%4294967296|0;i&&(s=~s+1|0,a=s===0?~a+1|0:~a),n.setUint32(r,a),n.setUint32(r+4,s),r+=8},putUi8(t){e(1),n.setUint8(r,t),++r},putUi16(t){e(2),n.setUint16(r,t),r+=2},putUi32(t){e(4),n.setUint32(r,t),r+=4},putUi64(t){e(8),n.setUint32(r,t/4294967296|0),n.setUint32(r+4,t%4294967296),r+=8},putF(t){e(8),n.setFloat64(r,t),r+=8},ui8array(){return new Uint8Array(n.buffer.slice(0,r))}}}function co(n){return n.buffer!==void 0}function rr(n){let r=ArrayBuffer.isView(n)?new DataView(n.buffer,n.byteOffset,n.byteLength):new DataView(n),e=0;return{peek(){return r.getUint8(e)},get(t){e+=t;let i=r.byteOffset;return r.buffer.slice(i+e-t,i+e)},getI8(){return r.getInt8(e++)},getI16(){return e+=2,r.getInt16(e-2)},getI32(){return e+=4,r.getInt32(e-4)},getI64(){e+=8;let t=r.getInt32(e-8),i=r.getUint32(e-4);return t*4294967296+i},getUi8(){return r.getUint8(e++)},getUi16(){return e+=2,r.getUint16(e-2)},getUi32(){return e+=4,r.getUint32(e-4)},getUi64(){e+=8;let t=r.getUint32(e-8),i=r.getUint32(e-4);return t*4294967296+i},getF32(){return e+=4,r.getFloat32(e-4)},getF64(){return e+=8,r.getFloat64(e-8)}}}var on=0,cn=1,lo=2,po=3,uo=4,mo=5,ho=6,_o=7,go=0,fo=1,So=2,rt=0,vo=0,Io=0,Eo=1,ar=class{constructor(){c(this,"participantIdRegistry",null)}setParticipantIdRegistry(r){this.participantIdRegistry=r}serializeUpdateDisplayLayout(r,e){let t=Xe();L.Int.enc(t,on),L.Int.enc(t,rt),L.Int.enc(t,r),L.Nil.enc(t,null);let i=[];for(let a in e)e.hasOwnProperty(a)&&this.writeLayout(e,a,i);return L.Arr.enc(t,i),L.Nil.enc(t,null),t.ui8array().buffer}writeLayout(r,e,t){let i=r[e],a=Xe();if(this.writeStreamDesc(e,a),Kt(i))L.Int.enc(a,fo);else if(ra(i))L.Int.enc(a,So);else if(L.Int.enc(a,go),i.priority!==void 0?L.Int.enc(a,i.priority):L.Nil.enc(a,null),i.width!==void 0&&i.height!==void 0?(L.Int.enc(a,Math.round(i.width)),L.Int.enc(a,Math.round(i.height))):(L.Nil.enc(a,null),L.Nil.enc(a,null)),i.fit!==void 0)switch(i.fit){case"cv":L.Int.enc(a,Io);break;case"cn":L.Int.enc(a,Eo);break;default:L.Nil.enc(a,null)}else L.Nil.enc(a,null);t.push(a.ui8array().buffer)}writeStreamDesc(r,e){if(this.participantIdRegistry){let t=this.participantIdRegistry.getCompactId(r);if(t!==void 0){L.Int.enc(e,t);return}}L.Str.enc(e,r)}serializePerfStatReport(r,e){let t=Xe();return L.Int.enc(t,cn),L.Int.enc(t,rt),L.Int.enc(t,r),L.Int.enc(t,e.framesDecoded),L.Int.enc(t,e.framesReceived),t.ui8array().buffer}serializeSharingStatReport(r,e){let t=Xe();return L.Int.enc(t,lo),L.Int.enc(t,rt),L.Int.enc(t,r),L.Int.enc(t,e.minDelay),L.Int.enc(t,e.maxDelay),L.Int.enc(t,e.avgDelay),L.Int.enc(t,e.largeDelayDuration),t.ui8array().buffer}serializeRequestAsr(r,e){let t=Xe();return L.Int.enc(t,po),L.Int.enc(t,rt),L.Int.enc(t,r),L.Bool.enc(t,e.request),t.ui8array().buffer}serializeNetworkStatReport(r,e){let t=Xe();return L.Int.enc(t,uo),L.Int.enc(t,rt),L.Int.enc(t,r),L.Int.enc(t,e.timestamp),L.Int.enc(t,e.sendBitrate),t.ui8array().buffer}serializeEnableVideoSuspend(r,e){let t=Xe();return L.Int.enc(t,mo),L.Int.enc(t,rt),L.Int.enc(t,r),L.Bool.enc(t,e.enabled),t.ui8array().buffer}serializeEnableVideoSuspendSuggest(r,e){let t=Xe();return L.Int.enc(t,ho),L.Int.enc(t,rt),L.Int.enc(t,r),L.Bool.enc(t,e.enabled),t.ui8array().buffer}serializeChangeSimulcast(r,e){let t=Xe();L.Int.enc(t,_o),L.Int.enc(t,rt),L.Int.enc(t,r);let i=e.simulcastInfo.streams.length;L.Int.enc(t,e.mediaSource),L.Int.enc(t,i);for(let a of e.simulcastInfo.streams)L.Str.enc(t,a.rid),L.Int.enc(t,a.width),L.Int.enc(t,a.height),L.Int.enc(t,a.fps),L.Int.enc(t,a.bitrate/1e3);return t.ui8array().buffer}async deserializeCommandResponse(r){let e;if(r instanceof Blob){let s="arrayBuffer"in Blob.prototype?await r.arrayBuffer():await Na(r);e=rr(s)}else e=rr(r);let t=L.Int.dec(e),i=L.Int.dec(e);if(i!==rt){d.warn("Unsupported version for command type: "+t+", version "+i);return}if(L.Int.dec(e)!==vo){d.warn("Error code: "+t+"received for command type: "+t+", version "+i);return}switch(t){case on:return this.deserializeUpdateDisplayLayoutResponse(e);case cn:return this.deserializeReportPerfStatResponse(e);default:d.warn("unsupported command response commandType: "+t);return}}deserializeUpdateDisplayLayoutResponse(r){let e=L.Int.dec(r),t=L.Arr.dec(r),i={};return t.forEach(a=>{let s=rr(a),o=L.Any.dec(s);if(typeof o=="string")i[o]=L.Int.dec(s);else{let u=o,p=Qe(this.participantIdRegistry?.getStreamDescription(u));i[p]=L.Int.dec(s)}}),{type:"response",sequence:e,response:N.UPDATE_DISPLAY_LAYOUT.toString(),errorCodeByParticipantId:i}}deserializeReportPerfStatResponse(r){let e=L.Int.dec(r),t=L.Int.dec(r);return{type:"response",sequence:e,response:N.REPORT_PERF_STAT.toString(),estimatedPerformanceIndex:t}}};var dn=(i=>(i.START="start",i.ACCEPT="accept",i.JOIN="join",i.RETRY="retry",i))(dn||{}),Fe=dn;var ln=(t=>(t.NOTIFICATION="NOTIFICATION",t.FAILED="FAILED",t.RECONNECT="RECONNECT",t))(ln||{}),Pe=ln;var pn=(f=>(f.TRANSMITTED_DATA="transmitted-data",f.ACCEPTED_CALL="accepted-call",f.HUNGUP="hungup",f.PARTICIPANT_ADDED="participant-added",f.PARTICIPANT_JOINED="participant-joined",f.CLOSED_CONVERSATION="closed-conversation",f.MEDIA_SETTINGS_CHANGED="media-settings-changed",f.PARTICIPANT_STATE_CHANGED="participant-state-changed",f.PARTICIPANTS_STATE_CHANGED="participants-state-changed",f.RATE_CALL_DATA="rate-call-data",f.FEATURE_SET_CHANGED="feature-set-changed",f.TOPOLOGY_CHANGED="topology-changed",f.PRODUCER_UPDATED="producer-updated",f.CONSUMER_ANSWERED="consumer-answered",f.MULTIPARTY_CHAT_CREATED="multiparty-chat-created",f.FORCE_MEDIA_SETTINGS_CHANGE="force-media-settings-change",f.SETTINGS_UPDATE="settings-update",f.VIDEO_QUALITY_UPDATE="video-quality-update",f.REGISTERED_PEER="registered-peer",f.SWITCH_MICRO="switch-micro",f.RECORD_STARTED="record-started",f.RECORD_STOPPED="record-stopped",f.REALLOC_CON="realloc-con",f.AUDIO_ACTIVITY="audio-activity",f.SPEAKER_CHANGED="speaker-changed",f.STALLED_ACTIVITY="stalled-activity",f.CHAT_MESSAGE="chat-message",f.CUSTOM_DATA="custom-data",f.ROLES_CHANGED="roles-changed",f.MUTE_PARTICIPANT="mute-participant",f.PIN_PARTICIPANT="pin-participant",f.OPTIONS_CHANGED="options-changed",f.NETWORK_STATUS="network-status",f.PARTICIPANT_SOURCES_UPDATE="participant-sources-update",f.PROMOTE_PARTICIPANT="promote-participant",f.CHAT_ROOM_UPDATED="chat-room-updated",f.PROMOTION_APPROVED="promotion-approved",f.JOIN_LINK_CHANGED="join-link-changed",f.FEEDBACK="feedback",f.MOVIE_UPDATE_NOTIFICATION="movie-update-notification",f.MOVIE_SHARE_STARTED="movie-share-started",f.MOVIE_SHARE_STOPPED="movie-share-stopped",f.URL_SHARING_INFO_UPDATED="url-sharing-info-updated",f.ROOM_UPDATED="room-updated",f.ROOMS_UPDATED="rooms-updated",f.ROOM_PARTICIPANTS_UPDATED="room-participants-updated",f.FEATURES_PER_ROLE_CHANGED="features-per-role-changed",f.PARTICIPANT_ANIMOJI_CHANGED="participant-animoji-changed",f.ASR_STARTED="asr-started",f.ASR_STOPPED="asr-stopped",f.DECORATIVE_PARTICIPANT_ID_CHANGED="decorative-participant-id-changed",f.VIDEO_SUSPEND_SUGGEST="video-suspend-suggest",f))(pn||{}),U=pn;var aa={connected:{wt:T.WEBTRANSPORT_CONNECTED,ws:T.WEBSOCKET_CONNECTED},reconnected:{wt:T.WEBTRANSPORT_RECONNECTED,ws:T.WEBSOCKET_RECONNECTED},failed_pings:{wt:T.WEBTRANSPORT_FAILED_PINGS,ws:T.WEBSOCKET_FAILED_PINGS},failed_exception:{wt:T.WEBTRANSPORT_FAILED_EXCEPTION,ws:T.WEBSOCKET_FAILED_EXCEPTION},timeout:{wt:T.WEBTRANSPORT_TIMEOUT,ws:T.WEBSOCKET_TIMEOUT},restart:{wt:T.WEBTRANSPORT_RESTART,ws:T.WEBSOCKET_RESTART}};var Ve=ri(require("fflate"));var To=63n,Ro=16383n;var Co=4611686018427387903n,nr=class{encode(r){let e=typeof r=="number"?BigInt(r):r;if(e<=To)return new Uint8Array([Number(e)]);if(e<=Ro)return new Uint8Array([64|Number(e>>8n),Number(e&0xffn)]);if(e<=BigInt(1073741823))return new Uint8Array([128|Number(e>>24n),Number(e>>16n&0xffn),Number(e>>8n&0xffn),Number(e&0xffn)]);if(e<=Co)return new Uint8Array([192|Number(e>>56n),Number(e>>48n&0xffn),Number(e>>40n&0xffn),Number(e>>32n&0xffn),Number(e>>24n&0xffn),Number(e>>16n&0xffn),Number(e>>8n&0xffn),Number(e&0xffn)]);throw new RangeError("Number is too large to encode using varint")}},sr=class{decode(r){let e=this.getNumBytesForLengthInteger(r);if(e<0)throw new Error("Invalid length prefix");if(r.length<e)return null;let t=BigInt(0);switch(e){case 1:t=BigInt(r[0]&63);break;case 2:t=BigInt(r[0]&63)<<8n|BigInt(r[1]);break;case 4:t=BigInt(r[0]&63)<<24n|BigInt(r[1])<<16n|BigInt(r[2])<<8n|BigInt(r[3]);break;case 8:t=BigInt(r[0]&63)<<56n|BigInt(r[1])<<48n|BigInt(r[2])<<40n|BigInt(r[3])<<32n|BigInt(r[4])<<24n|BigInt(r[5])<<16n|BigInt(r[6])<<8n|BigInt(r[7]);break}return t}getNumBytesForLengthInteger(r){let e=r[0]&192;return e===0?1:e===64?2:e===128?4:e===192?8:-1}};var or=class{constructor(r){c(this,"encoder");c(this,"compression");c(this,"lengthEncoder");this.encoder=new TextEncoder,this.lengthEncoder=new nr,this.compression=r??null}encode(r){let e=this.encoder.encode(r);e=this.compress(e);let t=this.lengthEncoder.encode(e.length),i=new Uint8Array(t.length+e.length);return i.set(t),i.set(e,t.length),i}compress(r){if(!this.compression)return r;switch(this.compression){case"gzip":return Ve.gzipSync(r);case"deflate":return Ve.zlibSync(r);case"deflate-raw":return Ve.deflateSync(r);default:return r}}},cr=class{constructor(r){c(this,"decoder");c(this,"compression");c(this,"lengthDecoder");c(this,"buffer");c(this,"expectedLength");c(this,"offset");c(this,"lengthPrefixLength");this.decoder=new TextDecoder,this.lengthDecoder=new sr,this.compression=r??null,this.buffer=new Uint8Array(0),this.expectedLength=null,this.offset=0}decode(r){let e=[];for(this.buffer=new Uint8Array([...this.buffer,...r]);this.buffer.length>0;){if(this.expectedLength===null){if(this.expectedLength=this.readLength(this.buffer),this.expectedLength===null)return e;this.offset=this.lengthPrefixLength}if(this.buffer.length-this.offset<this.expectedLength)return e;let t=this.buffer.subarray(this.offset,this.offset+this.expectedLength);t=this.decompress(t),e.push(this.decoder.decode(t)),this.buffer=this.buffer.subarray(this.offset+this.expectedLength),this.expectedLength=null,this.offset=0}return e}readLength(r){if(r.length===0)return 0;if(this.lengthPrefixLength=this.lengthDecoder.getNumBytesForLengthInteger(r),this.lengthPrefixLength<0)throw new Error("Invalid length prefix");let e=this.lengthDecoder.decode(r.subarray(0,this.lengthPrefixLength));return e===null?null:Number(e)}decompress(r){if(!this.compression)return r;switch(this.compression){case"gzip":return Ve.gunzipSync(r);case"deflate":return Ve.unzlibSync(r);case"deflate-raw":return Ve.inflateSync(r);default:return r}}};var qt=class{constructor(r,e={}){c(this,"webTransport");c(this,"stream",null);c(this,"writer",null);c(this,"reader",null);c(this,"url");c(this,"options");c(this,"compression");c(this,"encoder");c(this,"decoder");c(this,"onopen",null);c(this,"onmessage",null);c(this,"onerror",null);c(this,"onclose",null);c(this,"readyState",WebSocket.CONNECTING);this.url=r,this.options=e,this.readyState=WebSocket.CONNECTING,this.compression=this.getCompressionTypeFromUrl(r),this.encoder=new or(this.compression),this.decoder=new cr(this.compression),this.connect()}getCompressionTypeFromUrl(r){try{let t=new URL(r).searchParams.get("compression");switch(t){case"gzip":case"deflate":case"deflate-raw":return t;default:return null}}catch(e){return d.log("Exception while parsing compression",e),null}}async connect(){try{this.webTransport=new WebTransport(this.url,{...this.options}),await this.webTransport.ready,d.debug("[WebTransport] WebTransport connected to "+this.url),this.stream=await this.webTransport.createBidirectionalStream(),this.writer=this.stream.writable.getWriter(),this.reader=this.stream.readable.getReader(),this.readyState=WebSocket.OPEN,this.onopen?.(new Event("open")),await this.readLoop()}catch(r){d.error("[WebTransport] WebTransport connection failed. This will cause fallback to WebSocket",r),this.readyState=WebSocket.CLOSED,this.onerror?.(new Event("error")),this.onclose?.(new CloseEvent("close",{code:1006,reason:"Connection Failed"}))}}async readLoop(){if(this.reader)try{for(;;){let{done:r,value:e}=await this.reader.read();if(r){this.close(1e3,"Stream Closed");break}e&&this.decoder.decode(e).forEach(i=>{this.onmessage?.(new MessageEvent("message",{data:i}))})}}catch(r){d.error("[WebTransport] Stream read failed",r),this.readyState=WebSocket.CLOSED,this.onerror?.(new Event("error"))}}async send(r){if(this.readyState!==WebSocket.OPEN){d.warn("[WebTransport] Attempt to send data before webtransport is open");return}if(!this.writer){d.warn("[WebTransport] Attempt to send data before stream is ready");return}try{await this.writer.ready;let e=this.encoder.encode(r);await this.writer.write(e)}catch(e){d.error("[WebTransport] Failed to send data",e),this.onerror?.(new Event("error")),this.close(1006,"Failed to send data")}}close(r=1e3,e){if(!(this.readyState===WebSocket.CLOSED||this.readyState===WebSocket.CLOSING)){this.readyState=WebSocket.CLOSING,this.reader?.cancel();try{this.webTransport.close()}catch(t){d.warn("[WebTransport] already closed. Did we get a STOP_SENDING? ignore",t)}this.readyState=WebSocket.CLOSED,this.onclose?.(new CloseEvent("close",{code:r,reason:e})),this.webTransport.closed.then(()=>{this.writer=null,this.reader=null,this.stream=null})}}static isBrowserSupported(){return b.browserName()==="Firefox"?l.webtransportFF:b.browserName()!=="Safari"}};var un="open",mn=[()=>l.producerScreenTrack,()=>l.videoTracksCount>0,()=>!0,()=>!0,()=>l.consumerScreenTrack,()=>!0,()=>l.movieShare,()=>l.useParticipantListChunk,()=>l.useRooms,()=>!!l.vmoji,()=>l.useCallsToContacts,()=>l.useChatRooms],Po=10,yo=["service-unavailable","conversation-ended","invalid-token"],At=class n extends ai{constructor(){super(...arguments);c(this,"socket",null);c(this,"sequence",1);c(this,"lastStamp",0);c(this,"websocketCommandsQueue",[]);c(this,"datachannelCommandsQueue",[]);c(this,"incomingCache",[]);c(this,"responseHandlers",{});c(this,"connectionType");c(this,"reconnectCount",0);c(this,"endpoint");c(this,"wtEndpoint",null);c(this,"conversationResolve",null);c(this,"conversationReject",null);c(this,"connected",!1);c(this,"listenersReady",!1);c(this,"postfix","&platform="+l.platform+"&appVersion="+l.appVersion+"&version="+l.protocolVersion+"&device="+l.device+"&capabilities="+n._getCapabilityFlags());c(this,"peerId",null);c(this,"conversationId",null);c(this,"reconnectTimer",0);c(this,"connectionMessageWaitTimer",0);c(this,"doctorTimer",0);c(this,"participantIdRegistry",null);c(this,"producerNotificationDataChannel",null);c(this,"producerCommandDataChannel",null);c(this,"producerCommandDataChannelEnabled",!1);c(this,"producerCommandSerializationService",new ar)}static get RECONNECT_DELAY(){return l.signalingReconnectDelay}static get RECONNECT_MAX_DELAY(){return l.signalingReconnectMaxDelay}static get RECONNECT_MAX_COUNT(){return l.signalingReconnectMaxCount}static get WAIT_CONNECTION_DELAY(){return l.waitConnectionDelay}static get WAIT_RESPONSE_DELAY(){return l.waitResponseDelay}static get WAIT_MESSAGE_DELAY(){return l.waitMessageDelay}static _getCapabilityFlags(){let e=0;for(let t=0;t<mn.length;t++)mn[t]()&&(e|=1<<t);return e.toString(16).toUpperCase()}get ready(){return this.socket!==null}setEndpoint(e){this.endpoint=e}setWebTransportEndpoint(e){this.wtEndpoint=e}setConversationId(e){this.conversationId=e}setParticipantIdRegistry(e){this.participantIdRegistry=e,this.producerCommandSerializationService.setParticipantIdRegistry(e)}setProducerNotificationDataChannel(e){this.producerNotificationDataChannel=e,this.producerNotificationDataChannel.onmessage=t=>{let i=this.participantIdRegistry?.handleMessage(t.data);i&&this._handleMessage(i)}}setProducerCommandDataChannel(e){this.producerCommandDataChannel=e,this.producerCommandDataChannel.onmessage=t=>{this.producerCommandSerializationService.deserializeCommandResponse(t.data).then(i=>{i&&this._handleMessage(i)}).catch(i=>{d.warn("[signaling] cannot parse message at producerCommandDataChannel",i)})},this._handleCommandsQueue(this.datachannelCommandsQueue)}useCommandDataChannel(e){this.producerCommandDataChannelEnabled=e}cleanup(){this.datachannelCommandsQueue=[],this.incomingCache=[]}async connect(e){return this.postfix+=`&clientType=${l.clientType}`,new Promise((t,i)=>{if(this.socket&&this.socket.readyState<WebSocket.CLOSING){P.log(T.SOCKET_ACTION,"already_opened"),i(Error("Socket already opened"));return}this.conversationResolve=a=>{t(a),this.conversationResolve=null,this.conversationReject=null},this.conversationReject=a=>{i(a),this.conversationResolve=null,this.conversationReject=null},this._connect(e,this.isWebTransportAvailable())})}async _send(e,t={},i=!0,a=0){if(t.participantId){let s=I.decomposeParticipantId(t.participantId),o=I.decomposeId(s.compositeUserId);t=Object.assign({},t,{participantId:o.id,participantType:o.type}),s.deviceIdx&&(t.deviceIdx=s.deviceIdx)}return this._sendRaw(e,t,i,a)}async _sendRaw(e,t={},i=!0,a=0){let s=o=>{if(this._isDataChannelCommand(e))this.datachannelCommandsQueue.push(o),this.producerCommandDataChannel?.readyState===un&&this._handleCommandsQueue(this.datachannelCommandsQueue);else{if(!this.socket){P.log(T.SOCKET_ACTION,"not_opened"),d.warn("[signaling] socket is not opened"),o.reject(new Error(`Socket not opened [${e}]`),!0);return}this.socket.readyState>WebSocket.OPEN&&(P.log(T.SOCKET_ACTION,"invalid_state"),d.warn(`[signaling] socket is not opened, state ${this.socket.readyState}`)),this.websocketCommandsQueue.push(o),this.socket&&this.socket.readyState===WebSocket.OPEN&&this._handleCommandsQueue(this.websocketCommandsQueue)}};return new Promise((o,u)=>{let p=(h,R=!1)=>{!a||R?u(h):(d.debug("[signaling] resending a signaling message",e,m.sequence),a--,s(m))},m={sequence:this.sequence++,name:e,params:t,responseTimer:0,needResponse:i,resolve:o,reject:p};s(m)})}_isDataChannelCommand(e){return this.producerCommandDataChannelEnabled?e===N.UPDATE_DISPLAY_LAYOUT||e===N.REPORT_PERF_STAT||e===N.REPORT_SHARING_STAT||e===N.REQUEST_ASR||e===N.ENABLE_VIDEO_SUSPEND||e===N.ENABLE_VIDEO_SUSPEND_SUGGEST||e===N.REPORT_NETWORK_STAT||e===N.CHANGE_SIMULCAST:!1}getNextCommandSequenceNumber(){return this.sequence}async hangup(e){return this._send(N.HANGUP,{reason:e}).catch(()=>{})}async sendCandidate(e,t){return this._send(N.TRANSMIT_DATA,{participantId:e,data:{candidate:t}},!1)}async requestTestMode(e,t){return this._send(N.REQUEST_TEST_MODE,{consumer:e,producer:t})}async sendSdp(e,t,i){let a=Object.assign({sdp:t},i);return this._send(N.TRANSMIT_DATA,{participantId:e,data:a})}async acceptCall(e){return this._send(N.ACCEPT_CALL,{mediaSettings:e})}async changeMediaSettings(e){return this._send(N.CHANGE_MEDIA_SETTINGS,{mediaSettings:e},!0,Po)}async changeParticipantState(e,t){let i={participantState:{state:e}};return t&&(i.participantId=t),this._sendRaw(N.CHANGE_PARTICIPANT_STATE,i)}async putHandsDown(){return this._send(N.PUT_HANDS_DOWN)}async addParticipant(e,t){return this._send(N.ADD_PARTICIPANT,{externalIds:e,...t})}async addParticipantLegacy(e,t){return this._send(N.ADD_PARTICIPANT,{participantIds:e,...t})}async removeParticipant(e,t=!1){return this._send(N.REMOVE_PARTICIPANT,{participantId:e,ban:t})}async allocateConsumer(e,t){let i={capabilities:t};return e&&(i.description=e.sdp),this._send(N.ALLOCATE_CONSUMER,i)}async acceptProducer(e,t){let i={description:e.sdp};return t&&(i.ssrcs=t),this._send(N.ACCEPT_PRODUCER,i)}async changePriorities(e){return this._send(N.CHANGE_STREAM_PRIORITIES,{typedPriorities:e}).catch(()=>{})}async updateDisplayLayout(e){return this._send(N.UPDATE_DISPLAY_LAYOUT,e)}async addMovie(e){return this._send(N.ADD_MOVIE,e)}async updateMovie(e){return this._send(N.UPDATE_MOVIE,e)}async removeMovie(e){return this._send(N.REMOVE_MOVIE,e)}startUrlSharing(e){return this._send(N.START_URL_SHARING,{sharedUrl:e})}stopUrlSharing(){return this._send(N.STOP_URL_SHARING)}async updateRooms(e,t){return this._send(N.UPDATE_ROOMS,{rooms:e,assignRandomly:t})}async activateRooms(e,t){return this._send(N.ACTIVATE_ROOMS,{roomIds:e,deactivate:t})}async switchRoom(e,t){return this._sendRaw(N.SWITCH_ROOM,{toRoomId:e,participantId:t})}async getRooms(e){return this._sendRaw(N.GET_ROOMS,{withParticipants:e})}async removeRooms(e){return this._send(N.REMOVE_ROOMS,{roomIds:e})}async startStream(e){return this._send(N.RECORD_START,e)}async stopStream(e={roomId:null}){return this._send(N.RECORD_STOP,e)}async publishStream(e={roomId:null}){return this._send(N.RECORD_PUBLISH,e)}async recordSetConf(e={hideParticipantCount:!1,roomId:null}){let t={options:{hideParticipantCount:e.hideParticipantCount},roomId:e.roomId};return e.king&&(t.king=e.king),e.pawns?.length&&(t.pawns=e.pawns.join(",")),this._send(N.RECORD_SET_CONF,t)}async getRecordStatus(){return this._send(N.RECORD_GET_STATUS)}async switchTopology(e,t=!1){return this._send(N.SWITCH_TOPOLOGY,{topology:e,force:t})}async requestRealloc(){return this._send(N.REQUEST_REALLOC)}async reportPerfStat(e){return this._send(N.REPORT_PERF_STAT,e)}async reportSharingStat(e){return this._send(N.REPORT_SHARING_STAT,e,!1)}async reportNetworkStat(e){return this._send(N.REPORT_NETWORK_STAT,e,!1)}async chatMessage(e,t=null){return this._send(N.CHAT_MESSAGE,{message:e,participantId:t})}async chatHistory(e){return this._send(N.CHAT_HISTORY,{count:e})}async customData(e,t){return this._send(N.CUSTOM_DATA,{data:e,participantId:t})}async grantRoles(e,t,i){let a={participantId:e,roles:t};return i&&(a.revoke=!0),this._sendRaw(N.GRANT_ROLES,a)}async muteParticipant(e,t,i,a=null){return this._sendRaw(N.MUTE_PARTICIPANT,{participantId:e,muteStates:t,requestedMedia:i,roomId:a})}async enableFeatureForRoles(e,t){return this._sendRaw(N.ENABLE_FEATURE_FOR_ROLES,{feature:e,roles:t})}async pinParticipant(e,t,i){let a={participantId:e,roomId:i};return t&&(a.unpin=!0),this._sendRaw(N.PIN_PARTICIPANT,a)}async updateMediaModifiers(e){return this._send(N.UPDATE_MEDIA_MODIFIERS,{mediaModifiers:e})}async enableVideoSuspend(e){return this._send(N.ENABLE_VIDEO_SUSPEND,{enabled:e},!1)}async enableVideoSuspendSuggest(e){return this._send(N.ENABLE_VIDEO_SUSPEND_SUGGEST,{enabled:e},!1)}async changeSimulcast(e){return this._send(N.CHANGE_SIMULCAST,e,!1)}async changeOptions(e){return this._send(N.CHANGE_OPTIONS,{options:e})}async getWaitingHall(e=null,t,i=!1){let a={};return e&&(a.fromId=e),t&&(a.count=t),i&&(a.backward=i),this._send(N.GET_WAITING_HALL,a)}async promoteParticipant(e,t=!1){let i={};return e&&(i.participantId=e),t&&(i.demote=t),this._sendRaw(N.PROMOTE_PARTICIPANT,i)}async requestPromotion(e=!1){let t={};return e&&(t.unrequest=e),this._send(N.REQUEST_PROMOTION,t)}async acceptPromotion(e=!1){let t={};return e&&(t.reject=e),this._send(N.ACCEPT_PROMOTION,t)}async feedback(e){return this._sendRaw(N.FEEDBACK,{key:e})}async getHandQueue(){return this._send(N.GET_HAND_QUEUE)}close(){this.socket&&this.socket.readyState<WebSocket.CLOSING&&this._closeSocket(),this._stopWaitConnectionMessage(),this._stopDoctor(),clearTimeout(this.reconnectTimer)}readyToSend(e=!0){this.listenersReady=e,this._handleCachedMessages()}async getParticipantListChunk(e){return this._send(N.GET_PARTICIPANT_LIST_CHUNK,e)}async getParticipants(e){return this._send(N.GET_PARTICIPANTS,{externalIds:e})}getPeerId(){return this.peerId}async startAsr(e){return this._send(N.ASR_START,e)}async stopAsr(e){return this._send(N.ASR_STOP,e)}async requestAsr(e){return this._send(N.REQUEST_ASR,{request:e},!1)}_connect(e,t){if(this.socket&&this.socket.readyState<WebSocket.CLOSING)return;this.connectionType=e;let i="";e&&(i+=`&tgt=${e}`),e===Fe.RETRY&&this.lastStamp&&(i+=`&recoverTs=${this.lastStamp}`),i=a(i),t?(i+="&compression=deflate-raw",d.debug("[signaling] connecting to wt "+this.wtEndpoint+this.postfix+i),this.socket=new qt(this.wtEndpoint+this.postfix+i)):(d.debug("[signaling] connecting to ws "+this.endpoint+this.postfix+i),this.socket=new WebSocket(this.endpoint+this.postfix+i)),this._markTransportStat(e===Fe.RETRY?"reconnected":"connected"),this.socket.onopen=this._onOpen.bind(this),this.socket.onmessage=this._onMessage.bind(this),this.socket.onerror=this._onError.bind(this),this.socket.onclose=this._onClose.bind(this),this._startDoctor();function a(s){if(!l.useParticipantListChunk)return s;let o=l.participantListChunkInitIndex;s+=`&partIdx=${o}`;let u=l.participantListChunkInitCount;return u!==null&&(s+=`&partCount=${u}`),s}}_disconnect(e){this.socket&&this.socket.readyState<WebSocket.CLOSING&&(this.socket.onopen=null,this.socket.onmessage=null,this.socket.onerror=null,this.socket.onclose=null,this.socket.close(e),this.socket=null),this._stopWaitConnectionMessage(),this._stopDoctor(),clearTimeout(this.reconnectTimer)}_onOpen(){d.debug("[signaling] socket opened"),P.log(T.SOCKET_ACTION,"opened"),this._waitConnectionMessage(),this._startDoctor(),this._logTransportStat(this.connectionType===Fe.RETRY?"reconnected":"connected")}_onMessage(e){if(this._startDoctor(),e.data==="ping"){this._markTransportStat("failed_pings"),E.onSignalingMessage(e.data),this.socket&&this.socket.readyState===WebSocket.OPEN&&this.socket.send("pong");return}try{let t=JSON.parse(e.data);E.onSignalingMessage(t),this._handleMessage(t)}catch(t){P.log(T.SOCKET_ACTION,"parse_error"),d.error("[signaling] unable to parse message",t,e.data)}}_handleMessage(e){switch(e.type){case"notification":e.notification==="connection"?(d.debug("[signaling] signaling connected",e),this.connected=!0,this.reconnectCount=0,this.endpoint=e.endpoint,e.peerId&&this.peerId!==e.peerId.id&&(this.postfix+=`&peerId=${e.peerId.id}`,this.peerId=e.peerId.id),this._stopWaitConnectionMessage(),this.conversationResolve?this.conversationResolve(e):(this._logTransportStat("restart"),this._triggerEvent(Pe.RECONNECT,e),e.conversation.topology&&this._triggerEvent(Pe.NOTIFICATION,{type:"notification",notification:U.TOPOLOGY_CHANGED,topology:e.conversation.topology})),this.lastStamp&&this._handleCachedMessages(),e.recoverMessages?.forEach(t=>{t.notification===U.ACCEPTED_CALL&&t.peerId.id===this.peerId&&t.peerId.type==="WEB_TRANSPORT"||this._handleMessage(t)}),this._handleCommandsQueue(this.websocketCommandsQueue)):!this.connected||!this.listenersReady?this.incomingCache.push(e):this._triggerEvent(Pe.NOTIFICATION,e);break;case"response":this._handleCommandResponse(!0,e);break;case"error":this._handleErrorMessage(e);break;default:P.log(T.SOCKET_ACTION,"unknown_message"),d.warn("[signaling] unhandled message",e)}this.lastStamp=e.stamp||this.lastStamp}_handleErrorMessage(e){P.log(T.SOCKET_ACTION,`error-${e.error}`);let t=e.error?yo.includes(e.error):!1;switch(d.debug(`[signaling] error message [${e.sequence}]`,e),e.sequence&&this.responseHandlers[e.sequence]&&this._handleCommandResponse(!1,e),e.error){case"service-unavailable":this._reconnect();break;case"conversation-ended":this.conversationReject?this.conversationReject(new G(e.reason||ie.SIGNALING_FAILED,{message:`Conversation ended: ${e.error}`,remote:!0})):this._triggerEvent(Pe.NOTIFICATION,{notification:U.CLOSED_CONVERSATION,reason:e.reason});break;case"participant-not-found":case"invalid-token":this._throwError(new Error(`Signaling error: ${e.error}`));break;default:if(!t)break;this.connected?this._throwError(new Error(`Signaling error: ${e.error}`)):e.sequence||(this.conversationReject?.(new G(e.reason||ie.SIGNALING_FAILED,{message:`Unable to connect to the signaling: ${e.error}`,remote:!0})),this._closeSocket())}}_handleCachedMessages(){let e=[...this.incomingCache];for(this.incomingCache=[];e.length>0;){let t=e.shift();this._handleMessage(t)}}_throwError(e){this._triggerEvent(Pe.FAILED,e)}_onError(e){P.log(T.SOCKET_ACTION,"error"),d.error("[signaling] signaling error",e),this._logTransportStat("failed_exception",{string_value:JSON.stringify(e)})}_onClose(e){P.log(T.SOCKET_ACTION,"closed"),d.debug("[signaling] connection closed",{code:e.code,reason:e.reason}),this.connected=!1,this._stopDoctor(),this.socket&&this.reconnectCount++<n.RECONNECT_MAX_COUNT?this._reconnect():this.socket&&this._closeSocket(new Error("Connection closed"))}_closeSocket(e=null){this.socket&&(this._disconnect(),Object.values(this.responseHandlers).forEach(t=>{window.clearTimeout(t.responseTimer),e&&t.reject(new Error("Connection closed"),!0)}),this.websocketCommandsQueue=[],this.responseHandlers={},this.lastStamp=0,e&&this._throwError(new Error("Connection closed")))}_reconnect(){let e=Math.min(n.RECONNECT_MAX_DELAY,n.RECONNECT_DELAY*Math.pow(2,this.reconnectCount-1));d.log(`[signaling] reconnect websocket after ${e}ms (${this.reconnectCount})`),P.log(T.SOCKET_ACTION,"reconnect"),this.reconnectTimer=window.setTimeout(this._connect.bind(this,Fe.RETRY,!1),e)}_handleCommandResponse(e,t){if(!this.responseHandlers.hasOwnProperty(t.sequence))return;let i=this.responseHandlers[t.sequence];window.clearTimeout(i.responseTimer),d.debug(`[signaling] command response [${t.sequence}]`,t),e?(delete this.responseHandlers[t.sequence],i.resolve(t)):t.type==="error"?(delete this.responseHandlers[t.sequence],P.log(T.SOCKET_ACTION,"response-error"),i.reject(new Error(t.error||`Response error [${i.name}]`),!0)):this.socket?.readyState===WebSocket.OPEN?(delete this.responseHandlers[t.sequence],P.log(T.SOCKET_ACTION,"response-timeout"),i.reject(new Error(t.error||`Response timeout [${i.name}]`))):i.responseTimer=window.setTimeout(()=>this._handleCommandResponse(e,t),n.WAIT_RESPONSE_DELAY)}_handleCommandsQueue(e){for(;e.length>0;){let t=e.shift();if(d.debug(`[signaling] command send [${t.sequence}]`,`'${t.name}'`,t.params),this._isDataChannelCommand(t.name)){if(this.producerCommandDataChannel?.readyState!==un){t.reject(new Error(`Invalid data channel state: ${this.producerCommandDataChannel?.readyState}`));return}this._startResponseTimer(t);let i=this._serializeBinary(t);i!==null&&this.producerCommandDataChannel.send(i)}else{if(!this.socket||this.socket.readyState!==WebSocket.OPEN){t.reject(new Error("Invalid state or socket already closed"));continue}this._startResponseTimer(t),this.socket.send(this._serializeJson(t))}}}_startResponseTimer(e){if(!e.needResponse){e.resolve({type:"response",sequence:e.sequence,response:e.name});return}e.responseTimer=window.setTimeout(()=>this._handleCommandResponse(!1,{response:e.name,sequence:e.sequence,type:"timeout"}),n.WAIT_RESPONSE_DELAY),this.responseHandlers[e.sequence]=e}_serializeBinary(e){switch(e.name){case N.UPDATE_DISPLAY_LAYOUT:return this.producerCommandSerializationService.serializeUpdateDisplayLayout(e.sequence,e.params);case N.REPORT_PERF_STAT:return this.producerCommandSerializationService.serializePerfStatReport(e.sequence,e.params);case N.REPORT_SHARING_STAT:return this.producerCommandSerializationService.serializeSharingStatReport(e.sequence,e.params);case N.REQUEST_ASR:return this.producerCommandSerializationService.serializeRequestAsr(e.sequence,e.params);case N.REPORT_NETWORK_STAT:return this.producerCommandSerializationService.serializeNetworkStatReport(e.sequence,e.params);case N.ENABLE_VIDEO_SUSPEND:return this.producerCommandSerializationService.serializeEnableVideoSuspend(e.sequence,e.params);case N.ENABLE_VIDEO_SUSPEND_SUGGEST:return this.producerCommandSerializationService.serializeEnableVideoSuspendSuggest(e.sequence,e.params);case N.CHANGE_SIMULCAST:return this.producerCommandSerializationService.serializeChangeSimulcast(e.sequence,e.params)}return d.warn("[signaling] cannot get binary data for data channel command: "+e.name),null}_serializeJson(e){let t;e.name===N.UPDATE_DISPLAY_LAYOUT?t=this._convertDisplayLayout(e.params):t=e.params;let i=Object.assign({command:e.name,sequence:e.sequence},t);return JSON.stringify(i)}_convertDisplayLayout(e){let t=e,i={};for(let a in t)t.hasOwnProperty(a)&&(i[a]=an(t[a]));return{layouts:i}}_waitConnectionMessage(){this.connectionMessageWaitTimer=window.setTimeout(()=>{this.conversationReject&&this.conversationReject(new G(ie.SIGNALING_FAILED,{message:"Unable to connect to the signaling: connection timeout",remote:!0}))},n.WAIT_CONNECTION_DELAY)}_stopWaitConnectionMessage(){window.clearTimeout(this.connectionMessageWaitTimer),this.connectionMessageWaitTimer=0}_startDoctor(){this._stopDoctor(),this.doctorTimer=window.setTimeout(()=>{this.isWebTransportAvailable()?d.warn("[signaling] socket is dead. Fallback to WebSocket. Trying to connect"):d.warn("[signaling] socket is dead, trying to reconnect"),this._logTransportStat("failed_pings"),this._disconnect(4e3),this._connect(Fe.RETRY,!1)},n.WAIT_MESSAGE_DELAY)}_stopDoctor(){window.clearTimeout(this.doctorTimer),this.doctorTimer=0}isWebTransportAvailable(){return qt.isBrowserSupported()&&this.wtEndpoint!==null&&l.webtransport}_getSocketType(){return this.socket instanceof qt?"wt":"ws"}_markTransportStat(e){let t=this._getSocketType(),i=aa[e][t];le.setMark(i)}_logTransportStat(e,t){let i=this._getSocketType(),a=aa[e][i];Ce.logEventualStat({name:a,...t})}};var hn=(t=>(t.INCOMING="INCOMING",t.OUTGOING="OUTGOING",t.JOINING="JOINING",t))(hn||{}),De=hn;var _n=(t=>(t.USER="USER",t.GROUP="GROUP",t.CHAT="CHAT",t))(_n||{}),Ze=_n;var gn=(e=>(e.ATTENDEE="ATTENDEE",e.HAND_UP="HAND_UP",e))(gn||{}),dr=gn;var fn=(t=>(t.ADD_PARTICIPANT="ADD_PARTICIPANT",t.RECORD="RECORD",t.MOVIE_SHARE="MOVIE_SHARE",t))(fn||{}),lr=fn;var Sn=(s=>(s.REQUIRE_AUTH_TO_JOIN="REQUIRE_AUTH_TO_JOIN",s.AUDIENCE_MODE="AUDIENCE_MODE",s.WAITING_HALL="WAITING_HALL",s.ASR="ASR",s.FEEDBACK="FEEDBACK",s.RECURRING="RECURRING",s))(Sn||{}),Dt=Sn;function vn(n,r){if(n.length!==r.length)return!1;for(let e of n)if(!r.includes(e))return!1;return!0}function In(n,r){let e=new Set(n);for(let[t,i]of Object.entries(r))i?e.add(t):e.delete(t);return Array.from(e)}var En=(t=>(t.UNMUTE="UNMUTE",t.MUTE="MUTE",t.MUTE_PERMANENT="MUTE_PERMANENT",t))(En||{}),Ne=En;var Tn=(i=>(i.CALLED="CALLED",i.ACCEPTED="ACCEPTED",i.REJECTED="REJECTED",i.HUNGUP="HUNGUP",i))(Tn||{}),J=Tn;var Rn=(i=>(i.UPDATE="UPDATE",i.REMOVE="REMOVE",i.ACTIVATE="ACTIVATE",i.TIMEOUT="TIMEOUT",i))(Rn||{}),zt=Rn;var Cn=(e=>(e.AUDIO_MIX="audio-mix",e.PARTICIPANT_AGNOSTIC_TRACK_PREFIX="pat",e))(Cn||{}),$e=Cn;var Pn=(e=>(e.NO_AVAILABLE_TRACKS="no-available-tracks",e.UNKNOWN_ERROR="unknown-error",e))(Pn||{}),yn=Pn;function bn(n){switch(n){case 1:return"no-available-tracks";default:return"unknown-error"}}var Mn=(e=>(e.CREATOR="CREATOR",e.ADMIN="ADMIN",e))(Mn||{}),at=Mn;function _i(n,r){if(n.length!==r.length)return!1;for(let e of n)if(!r.includes(e))return!1;return!0}var pr=(t=>(t.USER="USER",t.ANONYM="ANONYM",t.GROUP="GROUP",t))(pr||{}),q;(m=>{function n(h){return h.length?typeof h[0]=="object"?h:h.map(R=>r(R)):[]}m.fromIds=n;function r(h,R="USER",M=0){return{id:h,type:R,deviceIdx:M}}m.fromId=r;function e(h,R=!0){let M=R?h.decorativeExternalUserId:h.externalId,k=h.deviceIdx??0;if(M)return t(M,k)}m.fromSignalingParticipant=e;function t(h,R=0){return{id:h.id,type:h.type==="ANONYM"?"ANONYM":"USER",deviceIdx:R}}m.fromSignaling=t;function i(h){return h.id}m.toSignaling=i;function a(h){let R=h.deviceIdx||0;return`{"id":"${h.id}","type":"${h.type}","deviceIdx":${R}}`}m.toString=a;function s(h,R="USER",M=0){return a(r(h,R,M))}m.fromIdToString=s;function o(h){try{return JSON.parse(h)}catch{throw new Error(`Failed to parse ExternalId from string '${h}'`)}}m.fromString=o;function u(h,R){return h.id===R.id&&h.type===R.type&&h.deviceIdx===R.deviceIdx}m.compare=u;function p(h){return h?.deviceIdx||0}m.getDeviceIdx=p})(q||(q={}));var{isObject:An,isObjectsEquals:bo}=I;function na(n,r){return n===null||r===null?n===null&&r===null:n.maxDimension!==r.maxDimension||n.maxBitrateK!==r.maxBitrateK||n.maxFramerate!==r.maxFramerate||n.degradationPreference!==r.degradationPreference||n.scalabilityMode!==r.scalabilityMode||An(n.bitrates)&&An(r.bitrates)&&!bo(n.bitrates,r.bitrates,!0)?!1:n.bitrates===r.bitrates}function ur(n,r){return!(!na(n.camera,r.camera)||!na(n.screenSharing,r.screenSharing))}function sa(n,r){return{camera:Object.assign({},n.camera,r.camera),screenSharing:Object.assign({},n.screenSharing,r.screenSharing)}}function Dn(n){try{return btoa(JSON.stringify(n))}catch(r){d.warn("WaitingParticipant: failed convert to string",n,r)}return null}function wn(n){try{return JSON.parse(atob(n))}catch(r){d.warn("WaitingParticipant: failed convert from string",n,r)}return null}var mr=(n,r)=>I.objectReduce(n,(e,t,i)=>(t===r&&e.push(i),e),[]);function kn(n){if(n.conversation?.muteStates)return n.conversation.muteStates;if(n.muteState&&n.muteOptions)return n.muteOptions.reduce((r,e)=>(r[e]=n.muteState,r),{})}function Mo(n,r){switch(n){case se.AUDIO:return!!r.isAudioEnabled;case se.AUDIO_SHARING:return!!r.isAudioSharingEnabled;case se.VIDEO:return!!r.isVideoEnabled;case se.SCREEN_SHARING:return!!r.isFastScreenSharingEnabled||!!r.isScreenSharingEnabled;default:return!1}}function On(n,r){return I.objectReduce(n,(e,t,i)=>{switch(t){case Ne.MUTE:case Ne.MUTE_PERMANENT:{Mo(i,r)||(e[i]=t);break}default:e[i]=t;break}return e},{})}function xn(n){let{muteStates:r={},mediaSettings:e}=n;return On(r,e)}function Nn(n,r){let e=n.conversation.participants.find(i=>I.comparePeerId(i.peerId,n.peerId));if(!e)return r;let{mediaSettings:t}=e;return On(r,t)}function Ln(n,r){let e=new Uint8Array(r),t=0,i=0;for(;t<n.length&&i<r;){let a=n[t++],s=a>>4,o=a&15;if(s===15){let m;do m=n[t++],s+=m;while(m===255)}for(let m=0;m<s&&!(i>=r);m++)e[i++]=n[t++];if(t>=n.length||i>=r)break;let u=n[t]|n[t+1]<<8;if(t+=2,o===15){let m;do m=n[t++],o+=m;while(m===255)}o+=4;let p=i-u;for(let m=0;m<o&&!(i>=r);m++)e[i++]=e[p+m]}return e}var Jt=class{constructor(r){c(this,"_fixNoPacketsApplied",!1);c(this,"_fixNoPacketsChecked",!1);c(this,"_fixTooManyPacketsApplied",!1);c(this,"_fixTooManyPacketsSucceeded",!1);c(this,"_fixTooManyPacketsFailed",!1);c(this,"_fixTooManyPacketsTime");c(this,"_mediaSource");c(this,"_lastPacketsSent");c(this,"_lastPacketsSentTime");c(this,"_toggleAudioPromise",null);c(this,"_fixNoPacketsAppliedVideo",!1);this._mediaSource=r}_fixAudioDeviceNoPackets(r){if(!(this._fixNoPacketsApplied&&this._fixNoPacketsChecked)){if(this._fixNoPacketsApplied&&!this._fixNoPacketsChecked){this._fixNoPacketsChecked=!0,P.log(T.ERROR,`audio_device_recover_${r.bandwidth?"success":"fail"}`);return}!this._fixNoPacketsApplied&&!r.bandwidth&&(this._fixNoPacketsApplied=!0,P.log(T.ERROR,"audio_device_recover"),d.log("[AudioFix] Trying to fix RV (no packets)"),this._toggleAudioPromise=this._mediaSource.toggleAudio(b.getMicrophonePermissionState()!=="denied"))}}_fixAudioDeviceTooManyPackets(r){if(this._fixTooManyPacketsSucceeded||this._fixTooManyPacketsFailed)return;let e=75,t=Date.now();if(!this._lastPacketsSentTime)r.packetsSent>0&&(this._lastPacketsSentTime=t,this._lastPacketsSent=r.packetsSent);else if(t-this._lastPacketsSentTime>500){let i=(r.packetsSent-this._lastPacketsSent)*1e3/(t-this._lastPacketsSentTime);this._lastPacketsSentTime=t,this._lastPacketsSent=r.packetsSent,this._fixTooManyPacketsApplied?i>e?(d.log("[AudioFix] Failed to fix RV"),P.log(T.ERROR,"audio_device_recover_rv_fail"),this._fixTooManyPacketsFailed=!0):t-this._fixTooManyPacketsTime>6e4&&(d.log("[AudioFix] Fixed RV"),P.log(T.ERROR,"audio_device_recover_rv_success"),this._fixTooManyPacketsSucceeded=!0):i>e&&(this._fixTooManyPacketsApplied=!0,P.log(T.ERROR,"audio_device_recover"),d.log("[AudioFix] Trying to fix RV (too many packets)"),this._mediaSource.toggleAudio(!0),this._fixTooManyPacketsTime=t)}}fix(r){if(!this._mediaSource)return;let e=r.find(t=>t.kind==="audio");e&&(this._fixAudioDeviceNoPackets(e),this._fixAudioDeviceTooManyPackets(e))}fixVideo(r){if(!this._mediaSource||this._fixNoPacketsAppliedVideo||!this._toggleAudioPromise)return;let e=r.find(t=>t.kind==="video");e&&!e.bandwidth&&(this._fixNoPacketsAppliedVideo=!0,this._toggleAudioPromise.then(()=>{this._mediaSource.getMediaSettings().isVideoEnabled&&this._mediaSource.toggleVideo(!0)}))}};var gi=class{constructor(r){c(this,"_output",null);c(this,"_volume",1);c(this,"_features",{setSinkId:!!Audio.prototype.setSinkId});c(this,"_statFirstMediaReceived");this._statFirstMediaReceived=r}add(r){this.destroy(),this._output={},this._output.audioTrack=r,this._initAudioElement()}remove(r){!this._output||this._output.audioTrack!==r||this.destroy()}get volume(){return this._volume}set volume(r){this._volume=Math.max(0,Math.min(1,r)),this._output&&this._output.audioElement&&(this._output.audioElement.volume=this._volume)}_initAudioElement(){if(l.muteMode||!this._output?.audioTrack)return;let r=b.browserName()!=="Safari"||b.isMobile(),e=document.createElement(r?"audio":"video");e.muted=!1,e.volume=this._volume,e.preload="auto";let t=()=>{d.warn("[audio] Error on play audio"),E.onAutoplayError()},i=s=>{e.srcObject=new MediaStream([s]),e.load();let o=e.play();o&&o.catch(t)},a=()=>{d.debug("[audio] Recover audio playback");let s=this._output?.audioTrack;s?i(s):d.warn("[audio] Broken audio track")};e.onpause=a,e.onstalled=a,e.onerror=a,e.onloadeddata=()=>{this._statFirstMediaReceived.measure()},i(this._output.audioTrack),this._output.audioElement=e}_stopAudioElement(){this._output?.audioElement&&(this._output.audioElement.pause(),this._output.audioElement.srcObject=null),this._output?.audioTrack?.stop()}destroy(){this._output&&(this._stopAudioElement(),this._output=null)}async changeOutput(){try{if(!this._features.setSinkId)throw new Error('Feature "setSinkId" is not supported');if(!this._output?.audioElement)return;let r=b.getSavedOutput();r&&await this._output.audioElement.setSinkId?.(r.deviceId)}catch(r){throw P.log(T.ERROR,"change_output"),d.error("[audio] Output change failed",r),r}}};var Ao=90,Do=3,fi=class extends re{constructor(){super(...arguments);c(this,"_lastMemoryStat",{percent:0,bytes:0})}onRemoteDataStats(e,t){this._calcMemory(),e.inbound.rtps.map(i=>{let a=typeof i.userId=="string"&&t[i.userId]||null;i.userId=a?.externalId}),E.onStatistics(e,this._lastMemoryStat)}_calcMemory(){let e=window?.performance?.memory;if(!e||!e.usedJSHeapSize||!e.jsHeapSizeLimit)return;let t=Number((100*e.usedJSHeapSize/e.jsHeapSizeLimit).toFixed(2)),i=Number((e.usedJSHeapSize/1024/1024).toFixed(1));t>Ao?d.warn(`High memory usage: ${t}% (${i} MiB)`):(!this._lastMemoryStat.percent||Math.abs(t-this._lastMemoryStat.percent)>=Do)&&(d.debug(`Memory usage: ${t}% (${i} MiB)`),this._lastMemoryStat.percent=t,this._lastMemoryStat.bytes=e.usedJSHeapSize)}};var wo=44100,ut=class{constructor(r,e){c(this,"_analyser",null);c(this,"_gainNode",null);c(this,"_fftBins",null);c(this,"_mediaStreamSource",null);c(this,"_lastSmoothedLevel",0);c(this,"_trackId");c(this,"_track");c(this,"_stream");this._trackId=r,this._track=e,this._stream=new MediaStream([e]);try{let t=b.getAudioContext();this._gainNode=t.createGain(),this._gainNode.gain.value=1e-5,this._gainNode.connect(t.destination),this._analyser=t.createAnalyser(),this._analyser.fftSize=1024,this._analyser.smoothingTimeConstant=0,this._analyser.connect(this._gainNode),this._fftBins=new Uint8Array(this._analyser.frequencyBinCount),this._mediaStreamSource=t.createMediaStreamSource(this._stream),this._mediaStreamSource.connect(this._analyser)}catch{}}get track(){return this._track}get trackId(){return this._trackId}_getBins(){if(!this._fftBins||!this._analyser)return new Uint8Array;this._analyser.getByteFrequencyData(this._fftBins);let r=wo/this._fftBins.length,e=Math.ceil(l.voiceParams.minFreq/r),t=Math.floor(l.voiceParams.maxFreq/r);return this._fftBins.subarray(e,t)}getLevel(){let r=this._getBins(),t=r.reduce((a,s)=>a+s,0)/r.length/255,i=this._lastSmoothedLevel*l.voiceParams.smoothing+t*(1-l.voiceParams.smoothing);return this._lastSmoothedLevel=i,{real:t,smoothed:i}}destroy(){this._mediaStreamSource&&(this._mediaStreamSource.disconnect(),this._mediaStreamSource=null),this._gainNode&&(this._gainNode.disconnect(),this._gainNode=null),this._analyser&&(this._analyser.disconnect(),this._analyser=null,this._fftBins=null,this._lastSmoothedLevel=0),this._stream.removeTrack(this._track)}};var Si=class extends re{constructor(e){super();c(this,"_detector",null);c(this,"_interval",null);let t=()=>{this._detector&&E.onLocalVolume(this._detector.getLevel().real,e.getMediaSettings().isAudioEnabled),this._interval=window.setTimeout(t,l.voiceParams.interval)};this._interval=window.setTimeout(t,l.voiceParams.interval);let i=()=>{let a=e.getSendAudioTrack();a&&this.init(a)};this.subscribe(e,"SOURCE_CHANGED",a=>{a.kind==="audio"&&e.getMediaSettings().isAudioEnabled&&i()}),this.subscribe(e,"SOURCE_READY",i),i()}init(e){this._stopDetector(),this._detector=new ut("local",e.clone())}_stopDetector(){this._detector&&(this._detector.track.stop(),this._detector.destroy(),this._detector=null)}destroy(){this.unsubscribe(),this._interval&&(window.clearTimeout(this._interval),this._interval=null),this._stopDetector()}};var _r=class{constructor(r){this.processor=r;c(this,"queue",[]);c(this,"isProcessing",!1)}add(r){this.queue.push(r),this.processQueue()}async processQueue(){if(!this.isProcessing){for(this.isProcessing=!0;this.queue.length;){let r=this.queue.shift();if(r)try{await this.processor(r)}catch{d.error(`Can't process message ${JSON.stringify(r)}`)}}this.isProcessing=!1}}};var Un=(s=>(s.producerNotification="producerNotification",s.producerCommand="producerCommand",s.consumerScreenShare="consumerScreenShare",s.producerScreenShare="producerScreenShare",s.asr="asr",s.animoji="animoji",s))(Un||{}),nt=Un;var mt=class mt{constructor(){c(this,"_codecUsages",new Map);c(this,"getCurrentTransportTopology",()=>{})}static create(r){let e=new mt;e.getCurrentTransportTopology=r,mt._instance=e}static reportUsage(r){let e=mt._instance,t=e?.getCurrentTransportTopology();if(!e||!t)return;let i=r.rtps.filter(a=>a.type==="outbound-rtp"&&!a.mid?.endsWith("s"));l.simulcast&&(i=i.reduce((a,s)=>{if(s.kind!=="video")return a.concat(s);let o=a.find(u=>u.kind==="video");return o?o.totalEncodeTime=(o.totalEncodeTime??0)+(s.totalEncodeTime??0):a.push(s),a},[])),i.forEach(a=>{let s=a.kind,o=a.mimeType;if((s==="audio"||s==="video")&&o){let u=a.encoderImplementation,p=[o,"encoder",u].filter(Boolean).join("/");e.saveUsage({kind:s,codecName:p,totalEncodeTime:(a.totalEncodeTime??0)*1e3,audioCodecParams:a.sdpFmtpLine,topology:t})}})}saveUsage({kind:r,codecName:e,totalEncodeTime:t,audioCodecParams:i,topology:a}){let s=this._codecUsages.get(r);if(s&&s.codecName!==e&&this.report(s),s&&s.codecName===e){this._codecUsages.set(r,{...s,totalEncodeTime:t,topology:a});return}this._codecUsages.set(r,{kind:r,codecName:e,audioCodecParams:i,totalEncodeTime:t,topology:a})}report(r){if(r.kind==="video"&&r.totalEncodeTime===0)return;let e={name:T.CODEC_USAGE,codec_implementation:r.codecName,value:r.totalEncodeTime,call_topology:r.topology==="DIRECT"?"D":"S"};r.audioCodecParams&&(e.string_value=r.audioCodecParams),P.logClientStats(e)}static destroy(){mt._instance?._destroy(),mt._instance=null}_destroy(){this._codecUsages.forEach(r=>{this.report(r)}),this._codecUsages.clear()}};c(mt,"_instance",null);var et=mt;var wt=class extends re{constructor(e,t){super();c(this,"_signaling");c(this,"_mediaSource");c(this,"_state","IDLE");c(this,"_pc",null);this._signaling=e,this._mediaSource=t}getState(){return this._state||"IDLE"}};var Bn="videochat-epi",ko=5e3,Oo=500,ht=class extends re{constructor(e,t,i=!1){super();c(this,"_previousPerfStatReportTimestamp",0);c(this,"_previousNetworkStatReportTimestamp",Date.now());c(this,"_previousCallStatReportTimestamp",Date.now());c(this,"_previousCallStatReport",null);c(this,"_screenShareStats",[]);c(this,"_signaling");c(this,"_directTopology");c(this,"_handleScreenSharingStat",e=>{this._screenShareStats.push(e)});c(this,"_handleTransportStateChanged",e=>{(this._directTopology&&e==="CONNECTED"||!this._directTopology&&e==="OPENED")&&(this._previousNetworkStatReportTimestamp=Date.now(),this._previousCallStatReportTimestamp=Date.now())});this._signaling=t,this._directTopology=i,this.subscribe(e,"REMOTE_DATA_STATS",this._handleStats.bind(this)),this.subscribe(e,"SCREEN_SHARING_STAT",this._handleScreenSharingStat.bind(this)),this.subscribe(e,"STATE_CHANGED",this._handleTransportStateChanged.bind(this))}destroy(){this.unsubscribe()}static getEstimatedPerformanceIndex(){try{let e=parseInt(localStorage.getItem(Bn)||"",10);return isNaN(e)?0:e}catch{return 0}}async _handleStats(e){if(!e.inbound||!e.inbound.rtps)return;let t=Date.now();!this._directTopology&&l.perfStatReportEnabled&&this._previousPerfStatReportTimestamp+ko<=t&&(await this.reportPerfStats(e),this._previousPerfStatReportTimestamp=t);let i=e.outbound.transport.local?.protocol==="tcp";!this._directTopology&&i&&this._previousNetworkStatReportTimestamp+Oo<=t&&(await this.reportNetworkStats(e),this._previousNetworkStatReportTimestamp=t),l.callStatReportEnabled&&this._previousCallStatReportTimestamp+l.statisticsInterval<=t&&(this._reportCallStats(e),this._previousCallStatReportTimestamp=t)}async reportPerfStats(e){let t=e.inbound.rtps.reduce((i,a)=>(a.kind==="video"&&(i.framesDecoded+=a.framesDecoded||0,i.framesReceived+=a.framesReceived||0),i),{framesDecoded:0,framesReceived:0});if(t.framesDecoded)try{let i=await this._signaling.reportPerfStat(t);localStorage.setItem(Bn,i.estimatedPerformanceIndex)}catch{}}async reportNetworkStats(e){let t={timestamp:e.outbound.transport.timestamp,sendBitrate:e.outbound.rtps.reduce((i,a)=>i+(a.bandwidth??0)*8,0)};if(t.timestamp)try{await this._signaling.reportNetworkStat(t)}catch{}}_reportCallStats(e){let t={call_topology:this._directTopology?"D":"S",stat_time_delta:0,nack_received:0,pli_received:0,fir_received:0,frames_dropped:0,jitter_video:0,jitter_audio:0,interframe_delay_variance:0,nack_sent:0,pli_sent:0,fir_sent:0,total_audio_samples_received:0,concealed_audio_samples:0,silent_concealed_audio_samples:0,inserted_audio_samples_for_deceleration:0,removed_audio_samples_for_acceleration:0,audio_concealment_events:0,total_audio_energy:0,inbound_video_count:0,inbound_audio_count:0,packets_lost_video:0,packets_sent_video:0,packets_lost_audio:0,packets_sent_audio:0,freeze_count:0,total_freezes_duration:0,rtt:Math.round(e.inbound.transport.currentRoundTripTime*1e3),ss_freeze_count:0,ss_total_freezes_duration:0,local_address:Vn(e.inbound.transport.local),local_connection_type:e.inbound.transport.local?.type,network_type:e.inbound.transport.local?.networkType,transport:e.inbound.transport.local?.protocol,remote_address:Vn(e.inbound.transport.remote),remote_connection_type:e.inbound.transport.remote?.type};this._previousCallStatReport||(this._previousCallStatReport=Object.assign({},t));let i=!1,a=!1;for(e.inbound.rtps.reduce((p,m)=>(m.kind==="video"?(i=!0,m.framesReceived&&(p.jitter_video=p.jitter_video*p.inbound_video_count/(p.inbound_video_count+1)+m.jitter*1e3/(p.inbound_video_count+1),p.interframe_delay_variance=p.interframe_delay_variance*p.inbound_video_count/(p.inbound_video_count+1)+(m.interframeDelayVariance||0)*1e6/(p.inbound_video_count+1),p.inbound_video_count++),p.frames_dropped+=m.framesDropped||0,p.nack_sent+=m.nackCount,p.pli_sent+=m.pliCount,p.fir_sent+=m.firCount,p.freeze_count+=m.freezeCountDelta||0,p.total_freezes_duration+=m.totalFreezesDurationDelta||0):(a=!0,m.totalSamplesReceived&&(p.jitter_audio=p.jitter_audio*p.inbound_audio_count/(p.inbound_audio_count+1)+m.jitter*1e3/(p.inbound_audio_count+1),p.total_audio_energy=p.total_audio_energy*p.inbound_audio_count/(p.inbound_audio_count+1)+(m.totalAudioEnergy||0)/(p.inbound_audio_count+1),p.inbound_audio_count++),p.total_audio_samples_received+=m.totalSamplesReceived||0,p.inserted_audio_samples_for_deceleration+=m.insertedSamplesForDeceleration||0,p.removed_audio_samples_for_acceleration+=m.removedSamplesForAcceleration||0,p.concealed_audio_samples+=m.concealedSamples||0,p.silent_concealed_audio_samples+=m.silentConcealedSamples||0,p.audio_concealment_events+=m.concealmentEvents||0),p),t),e.outbound.rtps.reduce((p,m)=>(m.kind==="video"?(p.nack_received+=m.nackCount,p.pli_received+=m.pliCount,p.fir_received+=m.firCount,p.packets_sent_video+=m.packetsSent):p.packets_sent_audio+=m.packetsSent,p),t),e.remoteInbound.rtps.reduce((p,m)=>(m.kind==="video"?p.packets_lost_video+=m.packetsLost:p.packets_lost_audio+=m.packetsLost,p),t);this._screenShareStats.length;){let p=this._screenShareStats.pop();p?.freeze_duration&&(t.ss_freeze_count+=1,t.ss_total_freezes_duration+=p.freeze_duration)}let s={call_topology:t.call_topology,stat_time_delta:Math.max(0,Date.now()-this._previousCallStatReportTimestamp),nack_sent:Math.max(0,t.nack_sent-this._previousCallStatReport.nack_sent),nack_received:Math.max(0,t.nack_received-this._previousCallStatReport.nack_received),pli_sent:Math.max(0,t.pli_sent-this._previousCallStatReport.pli_sent),pli_received:Math.max(0,t.pli_received-this._previousCallStatReport.pli_received),fir_sent:Math.max(0,t.fir_sent-this._previousCallStatReport.fir_sent),fir_received:Math.max(0,t.fir_received-this._previousCallStatReport.fir_received),frames_dropped:Math.max(0,t.frames_dropped-this._previousCallStatReport.frames_dropped),rtt:Math.max(0,t.rtt)};if(navigator.hardwareConcurrency&&(s.cpu_hardware_concurrency=navigator.hardwareConcurrency),i&&!gr(t.jitter_video)&&(s.jitter_video=Math.round(t.jitter_video)),a&&!gr(t.jitter_audio)&&(s.jitter_audio=Math.round(t.jitter_audio)),i&&!gr(t.interframe_delay_variance)&&(s.interframe_delay_variance=t.interframe_delay_variance),t.freeze_count&&t.total_freezes_duration&&(s.freeze_count=t.freeze_count,s.total_freezes_duration=Math.round(t.total_freezes_duration*1e3)),t.ss_freeze_count&&t.ss_total_freezes_duration&&(s.ss_freeze_count=t.ss_freeze_count,s.ss_total_freezes_duration=t.ss_total_freezes_duration),a&&!gr(t.total_audio_samples_received)){let p=Math.max(0,t.total_audio_samples_received-this._previousCallStatReport.total_audio_samples_received),m=Math.max(0,t.inserted_audio_samples_for_deceleration-this._previousCallStatReport.inserted_audio_samples_for_deceleration),h=Math.max(0,t.removed_audio_samples_for_acceleration-this._previousCallStatReport.removed_audio_samples_for_acceleration),R=Math.max(0,t.concealed_audio_samples-this._previousCallStatReport.concealed_audio_samples),M=Math.max(0,t.silent_concealed_audio_samples-this._previousCallStatReport.silent_concealed_audio_samples),k=Math.max(0,t.audio_concealment_events-this._previousCallStatReport.audio_concealment_events);s.inserted_audio_samples_for_deceleration=kt(m/p*1e3),s.removed_audio_samples_for_acceleration=kt(h/p*1e3),s.concealed_audio_samples=kt(R/p*1e3),s.concealed_silent_audio_samples=kt(M/p*1e3),s.concealment_audio_avg_size=kt(R/k),s.total_audio_energy=t.total_audio_energy}Fn(t,"local_address","local_connection_type","network_type","transport")&&(s.local_address=t.local_address,s.local_connection_type=t.local_connection_type,s.network_type=t.network_type,s.transport=t.transport),Fn(t,"remote_address","remote_connection_type")&&(s.remote_address=t.remote_address,s.remote_connection_type=t.remote_connection_type);let o=Math.max(0,t.packets_sent_video-this._previousCallStatReport.packets_sent_video),u=Math.max(0,t.packets_sent_audio-this._previousCallStatReport.packets_sent_audio);if(o>0){let p=Math.max(0,t.packets_lost_video-this._previousCallStatReport.packets_lost_video);s.video_loss=kt(p/o*100)}if(u>0){let p=Math.max(0,t.packets_lost_audio-this._previousCallStatReport.packets_lost_audio);s.audio_loss=kt(p/u*100)}Ce.logCallStat(s),l.enableLogPerfStatReport&&d.log("Sent call stats",s),this._previousCallStatReport=t}};function Fn(n,...r){for(let e of r)if(!n.hasOwnProperty(e)||n[e]===void 0)return!1;return!0}function Vn(n,r=!1){if(n?.address)return n.address+(r?`:${n.port}`:"")}function gr(n){return n===void 0}function kt(n){return Number.isNaN(n)?0:n}var Ii=class{constructor(r,e=null){c(this,"weightUp");c(this,"weightDown");c(this,"value",NaN);this.weightUp=r,this.weightDown=e??r}set(r){this.value=r}update(r){return this.value=this.getNext(r),this.value}getNext(r){if(isNaN(this.value))return r;let e=r<this.value?this.weightDown:this.weightUp;return this.value*(1-e)+r*e}getValue(){return this.value}};var jn=.25,Hn=.35,xo=85,No=.1,Lo=1.5,Uo=.1,Bo=1,Fo=.6,Vo=.3;var Ei=class extends re{constructor(e){super();c(this,"_signaling");c(this,"_localNetworkStat");c(this,"_remoteNetworkStat");c(this,"_lastNetworkStat");c(this,"_networkLimits",{badNet:{loss:3,rtt:1e3},goodNet:{loss:.5,rtt:600}});c(this,"_lastStatSentTimestamp",0);c(this,"_currentState","good");this._signaling=e,this._localNetworkStat={rtt:new Ii(jn,jn),loss:new Ii(Hn,Hn),bitrate:0},this._remoteNetworkStat={rtt:0,loss:0,bitrate:0},this._lastNetworkStat={rtt:0,loss:0,date:0}}_calcRttRating(e){let t=typeof e=="number"?e:e.getValue(),i=1;if(isNaN(t))return i;let a=Math.round((t-this._networkLimits.goodNet.rtt)/xo);for(let s=0;s<a;s++)i*=1-No;return i}_calcLossRating(e){let t=typeof e=="number"?e:e.getValue(),i=1;if(isNaN(t))return i;let a=Math.round((t-this._networkLimits.goodNet.loss)/Lo);for(let s=0;s<a;s++)i*=1-Uo;return i}_calcBitrateRating(e,t){if(!e||!t)return 1;let a=1-(1-Math.min(e,t)/Math.max(e,t))*Bo;return Math.min(a,1)}_calcUDPRating({rtt:e,loss:t}){return this._calcRttRating(e)*this._calcLossRating(t)}_calcRating(e,t,i){return i?this._calcBitrateRating(e.bitrate,t.bitrate):this._calcUDPRating(e)*this._calcUDPRating(t)}_getNetworkState(e){return isNaN(e)||e>=Fo?"good":e>=Vo?"medium":"bad"}updateSettings(e){Object.assign(this._networkLimits.badNet,e?.badNet||{}),Object.assign(this._networkLimits.goodNet,e?.goodNet||{})}reportLocal(e){if(!this._signaling.ready)return;let t=e.outbound.transport.local?.protocol==="tcp",i=Math.max(0,Math.round(e.outbound.transport.currentRoundTripTime*1e3)||0),a=e.inbound.rtps.reduce((h,R)=>Math.max(h,R.packetLoss||0),0),s={rtt:this._localNetworkStat.rtt.update(i),loss:this._localNetworkStat.loss.update(a)};if(t){let h=e.outbound.rtps.reduce((R,M)=>R+(M.bandwidth??0)*8,0);s.bitrate=h,this._localNetworkStat.bitrate=h}let o=Date.now(),u=this._calcRating(this._localNetworkStat,this._remoteNetworkStat,t),p=Math.max(Math.round(u*10)/10,.1),m=this._getNetworkState(p);(t||m!==this._currentState||o-this._lastStatSentTimestamp>l.networkStatisticsInterval)&&(this._lastStatSentTimestamp=o,this._signaling.customData({sdk:Object.assign({type:"bad-net"},s)},null).catch(h=>{d.warn("Unable to send [bad-net]",h)})),this._currentState=m,this._triggerEvent("NETWORK_STATUS",p)}reportRemote(e){let{rtt:t,loss:i,bitrate:a}=e||{};this._remoteNetworkStat.rtt=t||0,this._remoteNetworkStat.loss=i||0,this._remoteNetworkStat.bitrate=a||0}};var jo=30*1e3,Ti=class n extends wt{constructor(e,t,i,a,s){super(i,a);c(this,"_participantId");c(this,"_isMaster");c(this,"_remoteSDP",{});c(this,"_remoteCandidates",{});c(this,"_lastRemoteSDP",null);c(this,"_animojiDataChannel",null);c(this,"_animojiReceiver",null);c(this,"_animojiSender",null);c(this,"_remoteAnimojiVersion",1);c(this,"_isOpen",!1);c(this,"_remotePeerId",null);c(this,"_statInterval",null);c(this,"_settingsInterval",null);c(this,"_failedOnCreate",null);c(this,"_remoteStream",null);c(this,"_iceRestartTimeout",null);c(this,"_reconnectionTimeout",null);c(this,"_reconnectionPrevented",!1);c(this,"_lastStat");c(this,"_fingerprint",null);c(this,"_neverConnected",!0);c(this,"_serverSettings");c(this,"_prevConsumerSettings",{});c(this,"_networkLimitsForVideo",{bad:{loss:4,rtt:1e3},good:{loss:2,rtt:700}});c(this,"_videoMaxDimensionsForNet",{worst:320,bad:640,good:1280});c(this,"_lastVideoMaxDimension",this._videoMaxDimensionsForNet.good);c(this,"_lastBadConnection",0);c(this,"_perfStatReporter");c(this,"_directStatReporter");if(this._participantId=e,this._isMaster=t,this._serverSettings=s,this._perfStatReporter=new ht(this,i,!0),this._directStatReporter=new Ei(i),this.subscribe(this._signaling,Pe.NOTIFICATION,this._onSignalingNotification.bind(this)),this.subscribe(this._mediaSource,"TRACK_REPLACED",this._onReplacedTrack.bind(this)),this.subscribe(this._mediaSource,"SOURCE_CHANGED",this._applySettings.bind(this)),this.subscribe(this._directStatReporter,"NETWORK_STATUS",this._onNetworkStatus.bind(this)),this._pc=new RTCPeerConnection({iceServers:l.iceServers,iceTransportPolicy:l.forceRelayPolicy?"relay":"all"},{optional:[{googSuspendBelowMinBitrate:!1}]}),this._pc.onicecandidate=this._handleIceCandidate.bind(this),this._pc.ontrack=this._onAddTrack.bind(this),this._pc.oniceconnectionstatechange=this._onIceConnectionStateChange.bind(this),this._pc.onconnectionstatechange=this._onConnectionStateChange.bind(this),this._pc.onsignalingstatechange=this._onSignalingStateChange.bind(this),this._prevConsumerSettings={},l.vmoji&&this._createDataChannel(this._pc,nt.animoji,o=>{this._animojiDataChannel=o,this._animojiDataChannel.binaryType="arraybuffer",this._animojiReceiver?.setDataChannel(this._animojiDataChannel),this._animojiSender?.setDataChannel(this._animojiDataChannel)}),this._isMaster){try{this._mediaSource.addTrackToPeerConnection(this._pc,!1,!0),this._applySettings()}catch(o){P.log(T.ERROR,"addTrack-direct"),d.error("Unable to add media source tracks",o,{participantId:this._participantId}),this._failedOnCreate=o;return}this._createOffer(!1).catch(o=>{this._state==="IDLE"?this._failedOnCreate=o:this.close(o)})}this._startSettingsInterval()}get participantId(){return this._participantId}updateStatisticsInterval(){this._stopStatInterval(),this._isDeadConnection()||this._startStatInterval()}_isDeadConnection(){return["IDLE","CLOSED","FAILED"].includes(this.getState())}async open(e=null){if(this._isOpen){d.warn("DirectTransport: Already opened",{participantId:this._participantId});return}if(this._failedOnCreate){this.close(this._failedOnCreate);return}if(d.debug("DirectTransport: Open transport",{participantId:this._participantId}),this._isOpen=!0,this._remotePeerId=e,!this._isMaster)try{this._mediaSource.addTrackToPeerConnection(this._pc,!1,!0),this._applySettings()}catch(i){P.log(T.ERROR,"addTrack-direct"),d.error("DirectTransport: Unable to add media source tracks",i,{participantId:this._participantId}),this.close(i);return}this._setState("OPENED");let t=e;if(!e){let i=Object.keys(this._remoteSDP);t=i[i.length-1]}if(t&&this._remoteSDP[t])try{await this._setRemoteDescription(t,this._remoteSDP[t])}catch{this.close();return}this._remoteSDP={},this._remoteCandidates={}}updateSettings(e){ur(e,this._serverSettings)||(this._serverSettings=e,this._applySettings())}preventRestart(){this._reconnectionPrevented=!0}allowRestart(){this._reconnectionPrevented=!1}setAnimojiTransport(e,t){if(l.vmoji&&(this._animojiReceiver=e,this._animojiSender=t,e.setParticipantId(this._participantId),this._animojiDataChannel)){e.setDataChannel(this._animojiDataChannel),t.setDataChannel(this._animojiDataChannel);return}}close(e){this._isOpen&&(this._isOpen=!1,this._stopReconnection(),this._remoteStream&&(this._remoteStream.getTracks().forEach(t=>{t.stop(),this._triggerEvent("REMOTE_TRACK_REMOVED",this._remoteStream,t)}),this._remoteStream=null),this._stopStatInterval(),this._stopSettingsInterval(),this._pc&&(this._animojiDataChannel&&(this._animojiDataChannel.onopen=null,this._animojiDataChannel.onmessage=null,this._animojiDataChannel.onerror=null,this._animojiDataChannel.close()),this._pc.onicecandidate=null,this._pc.ontrack=null,this._pc.oniceconnectionstatechange=null,this._pc.onconnectionstatechange=null,this._pc.onsignalingstatechange=null,this._pc.close(),this._pc=null),this._onNetworkStatus(1),this.unsubscribe(),e?(d.error("DirectTransport: Closed",e,{participantId:this._participantId}),this._setState("FAILED")):(d.debug("DirectTransport: Closed",{participantId:this._participantId}),this._setState("CLOSED")),this._triggerEvent("PEER_CONNECTION_CLOSED"))}_setState(e){this._state!==e&&(d.debug(`DirectTransport: State changed to ${e}`,{participantId:this._participantId}),this._state=e,this._triggerEvent("STATE_CHANGED",e))}_onSignalingNotification(e){switch(e.notification){case U.TRANSMITTED_DATA:this._handleTransmittedData(e);break;case U.SETTINGS_UPDATE:this._directStatReporter.updateSettings(e.settings);break;case U.CUSTOM_DATA:e.data.hasOwnProperty("sdk")&&this._directStatReporter.reportRemote(e.data?.sdk);break}}_handleTransmittedData(e){let t=e.data,i=I.getPeerIdString(e.peerId);I.composeMessageId(e)===this._participantId&&(t.candidate&&t.candidate.candidate?this._addIceCandidate(i,t.candidate).catch(this.close.bind(this)):t.sdp&&(this._remoteAnimojiVersion=t.animojiVersion||1,this._setRemoteDescription(i,t.sdp).catch(this.close.bind(this))))}async _addIceCandidate(e,t){if(this._isOpen&&(!this._remotePeerId||this._remotePeerId===e)&&this._pc&&this._pc.remoteDescription){d.debug("Add remote ice candidate",{participantId:this._participantId,candidate:t});try{await this._pc.addIceCandidate(new RTCIceCandidate(t))}catch(i){throw P.log(T.ERROR,"addIceCandidate-direct"),d.error("Unable to add remote ice candidate",i,{participantId:this._participantId,candidate:t}),i}}else d.debug("Cache remote ice candidate",{participantId:this._participantId,candidate:t}),this._remoteCandidates[e]=this._remoteCandidates[e]||[],this._remoteCandidates[e].push(t)}async _setRemoteCandidates(e){if(!this._remoteCandidates[e]){d.log(`No cached candidates found for peer ${e}`);return}let t=this._remoteCandidates[e];this._remoteCandidates[e]=[];for(let i of t)try{await this._addIceCandidate(e,i)}catch{}}async _setRemoteDescription(e,t){if(this._isOpen&&(!this._remotePeerId||this._remotePeerId===e)&&this._pc){if(this._lastRemoteSDP?.sdp===t.sdp)return;this._lastRemoteSDP=t,t=n._patchRemoteDescription(t),d.debug("Add remote description",{participantId:this._participantId,sdp:t}),this._calcFingerprint(t.sdp);try{await this._pc.setRemoteDescription(t),await this._setRemoteCandidates(e),this._processAnimojiProtocolVersion(this._remoteAnimojiVersion)}catch(i){throw P.log(T.ERROR,"setRemoteDescription-direct"),d.error("Unable to set remote description",i,{participantId:this._participantId,sdp:t}),i}}else this._remoteSDP[e]=t}_processAnimojiProtocolVersion(e){let t=Math.min(e,l.vmojiOptions?.protocolVersion||1);this._animojiSender?.setProtocolVersion(t)}_onAddTrack(e){d.debug("Added remote track",{participantId:this._participantId,kind:e.track.kind}),this._remoteStream?this._remoteStream.addTrack(e.track):(this._remoteStream=new MediaStream([e.track]),this._remoteStream.onremovetrack=t=>{this._triggerEvent("REMOTE_TRACK_REMOVED",this._remoteStream,t.track)}),this._triggerEvent("REMOTE_TRACK_ADDED",this._remoteStream,e.track)}async _handleIceCandidate(e){e.candidate&&this._signaling.ready&&(d.debug("Local ice candidate",{participantId:this._participantId,candidate:e.candidate}),await this._signaling.sendCandidate(this._participantId,e.candidate))}_onSignalingStateChange(){d.debug(`DirectTransport: Signaling state changed to ${this._pc?.signalingState}`,{participantId:this._participantId});let e={animojiVersion:l.vmojiOptions.protocolVersion||1};switch(this._pc?.signalingState){case"have-local-offer":let t=this._pc.localDescription;t?this._signaling.sendSdp(this._participantId,t,e).catch(this.close.bind(this)):this.close(new Error);break;case"have-remote-offer":this._createAnswer().then(i=>this._signaling.sendSdp(this._participantId,i,e)).catch(this.close.bind(this));break}}_onIceConnectionStateChange(){switch(d.debug(`DirectTransport: Ice Connection state changed to ${this._pc?.iceConnectionState}`,{participantId:this._participantId}),this._pc?.iceConnectionState){case"checking":let e=this.getState();e==="IDLE"||e==="OPENED"?this._setState("CONNECTING"):this._setState("RECONNECTING");break}}_onConnectionStateChange(){switch(d.debug(`DirectTransport: Connection state changed to ${this._pc?.connectionState}`,{participantId:this._participantId}),P.log(T.ICE_CONNECTION_STATE,this._pc?.connectionState),this._pc?.connectionState){case"connected":this._neverConnected=!1,this._setState("CONNECTED"),this._stopReconnection(),I.getPeerConnectionHostInfo(this._pc).then(e=>{e?.local&&(P.log(T.ICE_CONNECTION_TYPE,e.local.type),d.debug("Selected ICE candidates",e))}),this._startStatInterval();break;case"failed":case"disconnected":this._reconnectionPrevented?this.close(new Error(`Ice connection ${this._pc.connectionState}`)):(this._setState("RECONNECTING"),this._startReconnection());break;case"closed":this.close(new Error("Ice connection closed"));break}}_startReconnection(){this._reconnectionTimeout||this._iceRestartTimeout||(d.log("Waiting for reconnection...",{participantId:this._participantId}),this._reconnectionTimeout=window.setTimeout(()=>{this._reconnectionTimeout=null,this._neverConnected?this._requestTopologySwitch():this._startIceRestart()},l.transportConnectionWaitTime))}_requestTopologySwitch(){this._isMaster&&this._signaling.ready&&(d.log("Switch topology DIRECT to SERVER",{participantId:this._participantId}),this._signaling.switchTopology("SERVER"))}_stopReconnection(){this._reconnectionTimeout&&(clearTimeout(this._reconnectionTimeout),this._reconnectionTimeout=null),this._iceRestartTimeout&&(clearTimeout(this._iceRestartTimeout),this._iceRestartTimeout=null)}_startIceRestart(){this._isMaster?(P.log(T.ICE_RESTART),d.log("Ice restart",{participantId:this._participantId}),this._createOffer(!0).catch(this.close.bind(this))):d.debug("Waiting for ice restart...",{participantId:this._participantId}),this._iceRestartTimeout=window.setTimeout(()=>{this._iceRestartTimeout=null,d.error("Ice restart failed",{participantId:this._participantId}),P.log(T.ERROR,"iceRestart-direct"),this._requestTopologySwitch()},l.iceRestartWaitTime)}async _createOffer(e){let t={iceRestart:e,offerToReceiveAudio:!0,offerToReceiveVideo:!0};d.debug("Create offer",{participantId:this._participantId,options:t});let i;try{i=await this._pc?.createOffer(t),d.debug("Created offer",{participantId:this._participantId,offer:i}),i=n._patchLocalDescription(i)}catch(a){throw d.error("Unable to create offer",a,{participantId:this._participantId}),P.log(T.ERROR,"createOffer-direct"),a}try{return d.debug("Set local description",{participantId:this._participantId,offer:i}),this._calcFingerprint(i.sdp),await this._pc?.setLocalDescription(i),i}catch(a){throw d.error("Unable to set local description",a,{participantId:this._participantId}),P.log(T.ERROR,"setLocalDescription-direct"),a}}async _createAnswer(){d.debug("Create answer",{participantId:this._participantId});let e;try{e=await this._pc?.createAnswer(),d.debug("Created answer",{participantId:this._participantId,answer:e}),e=n._patchLocalDescription(e)}catch(t){throw d.error("Unable to create answer",t,{participantId:this._participantId}),P.log(T.ERROR,"createAnswer-direct"),t}try{return d.debug("Set local description",{participantId:this._participantId,answer:e}),this._calcFingerprint(e.sdp),await this._pc?.setLocalDescription(e),e}catch(t){throw d.error("Unable to set local description",t,{participantId:this._participantId}),P.log(T.ERROR,"setLocalDescription-direct"),t}}static _patchLocalDescription(e){let t=!!b.baseChromeVersion();return e.sdp=I.patchLocalSDP(e.sdp,l.preferH264&&b.canPreferH264(),b.isBrokenH264Decoder(),l.preferVP9,l.h264spsPpsIdrInKeyframe,t&&l.audioNack,l.p2pAudioRed),e}static _patchRemoteDescription(e){return e.sdp=I.patchRemoteSDP(e.sdp,!1,!1,!1,l.preferVP9,b.isBrokenVP9Encoder(),b.isBrokenVP9Decoder()),e}_onReplacedTrack(e){this._pc&&(this._pc.getSenders().forEach(t=>{t.track&&t.track.kind===e.kind&&t.track.contentHint===e.contentHint&&t.replaceTrack(e).catch(i=>{d.error("DirectTransport: Unable to replace track",i,{participantId:this._participantId}),P.log(T.ERROR,"replaceTrack-direct")})}),this._applySettings())}_startStatInterval(){if(this._statInterval)return;let e=()=>{if(this._isDeadConnection()){this._stopStatInterval();return}le.collectStats(this._pc,this._lastStat,void 0,!0).then(t=>{this._lastStat=t,et.reportUsage(t);let i={inbound:{topology:"DIRECT",transport:t.transport,rtps:t.rtps.filter(a=>a.type==="inbound-rtp"?(a.userId=this._participantId,!0):!1)},outbound:{topology:"DIRECT",transport:t.transport,rtps:t.rtps.filter(a=>a.type==="outbound-rtp")},remoteInbound:{topology:"DIRECT",transport:t.transport,rtps:t.remoteRtps??[]}};this._checkPPTNetwork(i),this._directStatReporter.reportLocal(i),this._triggerEvent("REMOTE_DATA_STATS",i),this._statInterval=window.setTimeout(e,l.statisticsInterval)})};this._statInterval=window.setTimeout(e,l.statisticsInterval)}async _isSVCSupported(e,t){let i=this._mediaSource.getSendVideoTrack(),a=e.outbound.rtps.find(u=>u.kind==="video");if(!a?.mimeType||!a?.bandwidth||!i)return!1;let s=i.getSettings();if(!s.width||!s.height||!s.frameRate)return!1;let o={type:b.browserName()==="Firefox"?"transmission":"webrtc",video:{contentType:a.mimeType,width:s.width,height:s.height,bitrate:a.bandwidth,framerate:s.frameRate,scalabilityMode:t}};try{return(await navigator.mediaCapabilities.encodingInfo(o)).supported||!1}catch(u){return d.warn("Failed to get encodingInfo",o,u),!1}}async _checkPPTNetwork(e){if(!l.switchVideoAtBadNetwork||!e.inbound.transport.averageNetStat)return;let{averageNetStat:t}=e.inbound.transport,i=t.currentRoundTripTime<=this._networkLimitsForVideo.good.rtt&&t.lostPercent<=this._networkLimitsForVideo.good.loss,a=t.currentRoundTripTime>=this._networkLimitsForVideo.bad.rtt||t.lostPercent>=this._networkLimitsForVideo.bad.loss,s=t.currentRoundTripTime<this._networkLimitsForVideo.bad.rtt,o=this._videoMaxDimensionsForNet.good,u="L1T1";if(a?(this._lastBadConnection=Date.now(),s?(o=this._videoMaxDimensionsForNet.bad,u="L1T2"):(o=this._videoMaxDimensionsForNet.worst,u="L1T3")):i&&(o=this._videoMaxDimensionsForNet.good,u="L1T1"),!(o<this._lastVideoMaxDimension||Date.now()-this._lastBadConnection>jo)||this._lastVideoMaxDimension===o)return;let m=this._serverSettings.camera;if(!m||!await this._isSVCSupported(e,u))return;d.debug("Switch outbound video frame size and scalabilityMode",{scalabilityMode:u,averageNetStat:t,nextVideoMaxDimension:o}),this._lastVideoMaxDimension=o;let R={...this._serverSettings,camera:{...m,scalabilityMode:u,maxDimension:this._lastVideoMaxDimension}};this.updateSettings(R)}_stopStatInterval(){this._statInterval&&(window.clearTimeout(this._statInterval),this._statInterval=null)}_onNetworkStatus(e){let t={};t[this._participantId]=t[""]=e,this._triggerEvent("NETWORK_STATUS",t)}_startSettingsInterval(){if(this._settingsInterval)return;let t=()=>{if(!this._pc){this._stopSettingsInterval();return}this._applySettings(),this._settingsInterval=window.setTimeout(t,2e3)};this._settingsInterval=window.setTimeout(t,2e3)}_stopSettingsInterval(){this._settingsInterval&&(window.clearTimeout(this._settingsInterval),this._settingsInterval=null)}_calcFingerprint(e){let t=I.sdpFingerprint(e);if(t===null){d.warn("Fingerprint calculation is unsupported");return}this._fingerprint===null?this._fingerprint=t:(E.onFingerprintChange((this._fingerprint^t).toString()),this._fingerprint=null)}_applySettings(){let e=this._mediaSource.getMediaSettings().isScreenSharingEnabled?this._serverSettings.screenSharing:this._serverSettings.camera;e&&this._pc?.connectionState==="connected"&&(this._prevConsumerSettings=I.applySettings(this._pc,e,this._prevConsumerSettings))}_createDataChannel(e,t,i){d.debug(`[${t}] data channel opening`);let a=e.createDataChannel(t,{negotiated:!0,id:1});a.onopen=()=>{let s=a.readyState;s==="open"?(d.debug(`[${t}] data channel opened`),a.onerror=o=>{d.error(`[${t}] data channel error`,o)},i(a)):d.error(`[${t}] data channel open failed, state [${s}]`)}}};var Ho=16,fr=class n{constructor(r,e,t){c(this,"_datachannel");c(this,"_participantIdRegistry");c(this,"_asrCallback");c(this,"_textDecoder");d.debug("AsrReceiver started"),this._datachannel=r,this._participantIdRegistry=e,this._asrCallback=t,this._textDecoder=new TextDecoder,this._datachannel.onmessage=i=>this._onDataChannelMessage(i.data)}static parse(r){let e=new DataView(r),t=e.getUint8(0),i=e.getUint8(1);if(i!==0)throw new Error(`Unsupported message type. Message type: ${i}`);let a=e.getUint16(2),s=e.getUint32(4),o=e.getUint32(8),u=e.getUint32(12);if(t!==1)throw new Error(`Unexpected protocol version. Got ${t}, expected 1`);return{sequence:a,ssrc:s,timestamp:o,duration:u,data:r.slice(Ho)}}_onDataChannelMessage(r){let e=n.parse(r),t=this._participantIdRegistry?.getStreamDescription(e.ssrc)?.participantId;if(!t){d.warn(`Participant id for ssrc ${e.ssrc} not found in registry`);return}let i={participantId:t,text:this._textDecoder.decode(e.data),timestamp:e.timestamp,duration:e.duration};this._asrCallback(i)}destroy(){this._datachannel.onmessage=null}};var st=require("messagepack");var Sr=class{constructor(){c(this,"streamDescriptionByCompactId",new Map);c(this,"compactIdByStreamDescription",new Map)}getStreamDescription(r){return this.streamDescriptionByCompactId.get(r)}getCompactId(r){return this.compactIdByStreamDescription.get(r)}handleMessage(r){let e=new Uint8Array(r),t=e[0],i=e.subarray(1);switch(t){case 1:let a=(0,st.decode)(i);return Object.entries(a).forEach(([M,k])=>{let H=hi(M);this.streamDescriptionByCompactId.set(k,H),this.compactIdByStreamDescription.set(M,k)}),null;case 2:case 4:let s=(0,st.decode)(i),o=[];for(let M of s){let k=this.getStreamDescription(M);k&&o.push(k.participantId)}return t===2?{type:"notification",notification:U.AUDIO_ACTIVITY,activeParticipants:o}:{type:"notification",notification:U.STALLED_ACTIVITY,stalledParticipants:o};case 3:let u=(0,st.decode)(i);return{type:"notification",notification:U.SPEAKER_CHANGED,speaker:this.getStreamDescription(u)?.participantId};case 5:let p=(0,st.decode)(i);return{type:"notification",notification:U.VIDEO_QUALITY_UPDATE,quality:{maxBitrate:p[0],maxDimension:p[1]}};case 6:let m=(0,st.decode)(i),h={};for(let[M,k]of Object.entries(m)){let H=this.getStreamDescription(Number(M))?.participantId;H&&(h[H]=k/100)}return{type:"notification",notification:U.NETWORK_STATUS,statuses:h};case 7:return this._createParticipantSourcesUpdateNotification(i);case 8:{let k=(0,st.decode)(i).map(H=>{let[z,ae,ve,ye,X,be,Me]=H;return{participantId:this.getStreamDescription(z)?.participantId,gain:ae,pause:ve,offset:ye,mute:X,liveStatus:be,startTimeMs:Me}});return{type:"notification",notification:U.MOVIE_UPDATE_NOTIFICATION,data:k}}case 9:let R=(0,st.decode)(i);return{type:"notification",notification:U.VIDEO_SUSPEND_SUGGEST,bandwidth:R};default:return d.debug("unsupported message type: "+t),null}}_createParticipantSourcesUpdateNotification(r){let e=(0,st.decode)(r),t=[];for(let[i,a]of Object.entries(e)){let s=a[0],o=a[1],u=a[2],p=!!a[3],m=a[4]!==null?!!a[4]:void 0,h;if(s!==null){if(h=this.getStreamDescription(s),!h){d.error(`could not uncompress participant ID ${s}`);continue}}else h=null;if(u===null){d.error("unexpected null sequenceNumber",i,a);continue}let R=$e.PARTICIPANT_AGNOSTIC_TRACK_PREFIX+"-"+i,M=o?o>>>0:null;t.push({participantStreamDescription:h,streamId:R,rtpTimestamp:M,sequenceNumber:u,fastScreenShare:p,suspend:m})}return{type:"notification",notification:U.PARTICIPANT_SOURCES_UPDATE,participantUpdateInfos:t}}};var Go=90,Wo=4294967295,Ri=class n extends wt{constructor(e,t,i){super(e,t);c(this,"_producerNotification",null);c(this,"_producerCommand",null);c(this,"_producerScreen",null);c(this,"_consumerScreen",null);c(this,"_asr",null);c(this,"_animojiDataChannel",null);c(this,"_animojiReceiver",null);c(this,"_animojiSender",null);c(this,"_isOpen",!1);c(this,"_observer",!1);c(this,"_reconnectionPrevented",!1);c(this,"_statInterval",null);c(this,"_settingsInterval",null);c(this,"_statBytes",{});c(this,"_ssrcMap",{});c(this,"_ssrcMapUpdated",!1);c(this,"_perfStatReporter");c(this,"_producerOfferIsProcessing",!1);c(this,"_producerNextOffer",null);c(this,"_lastStat",null);c(this,"_serverSettings");c(this,"_prevConsumerSettings",{});c(this,"_asrTrack",null);c(this,"_captureSender",null);c(this,"_captureReceiver",null);c(this,"_participantIdRegistry",null);c(this,"_disabledSenders",new Set);c(this,"_rtpReceiversByStreamId",{});c(this,"_producerSessionId","");c(this,"_newAudioShareTrack",null);c(this,"_simulcastInfo",null);this.subscribe(this._signaling,Pe.NOTIFICATION,this._onSignalingNotification.bind(this)),this.subscribe(this._mediaSource,"TRACK_REPLACED",this._onReplacedTrack.bind(this)),this.subscribe(this._mediaSource,"SOURCE_CHANGED",this._applyConsumerSettings.bind(this)),this.subscribe(this._mediaSource,"SCREEN_STATUS",this._onScreenSharingStatus.bind(this)),this._createPerfStatsReporter(),this._serverSettings=i,d.debug("ServerTransport: Created")}updateStatisticsInterval(){this._stopStatInterval();let e=this.getState();e!=="IDLE"&&e!=="CLOSED"&&e!=="FAILED"&&this._startStatInterval()}open(e=!1){if(this._isOpen){d.log("ServerTransport: Already opened connections");return}this._isOpen=!0,this._observer=e,this._openConnection()}close(e){this._isOpen&&(this._isOpen=!1,this._closeConnection(),this.unsubscribe(),e?(d.error("ServerTransport: Closed",e),this._setState("FAILED")):(d.debug("ServerTransport: Closed"),this._setState("CLOSED")))}removeParticipant(e){this._captureReceiver?.close(e)}preventRestart(){this._reconnectionPrevented=!0}allowRestart(){this._reconnectionPrevented=!1}updateSettings(e){ur(e,this._serverSettings)||(this._serverSettings=e,this._applyConsumerSettings())}setAnimojiTransport(e,t){if(l.vmoji&&(this._animojiReceiver=e,this._animojiSender=t,this._participantIdRegistry&&e.setParticipantIdRegistry(this._participantIdRegistry),this._animojiDataChannel)){e.setDataChannel(this._animojiDataChannel),t.setDataChannel(this._animojiDataChannel);return}}async onCameraResolutionChanged(){l.simulcast&&b.isSimulcastSupportedByBrowser()&&await this._changeSimulcastInfo(!0,!1)}_createPerfStatsReporter(){this._perfStatReporter?.destroy(),this._perfStatReporter=new ht(this,this._signaling)}_closeConnection(){this._stopStatInterval(),this._stopSettingsInterval(),this._removeAsrTrack(),this._removeCaptureSender(),this._removeCaptureReceiver(),this._simulcastInfo=null,this._pc&&(this._rtpReceiversByStreamId={},this._disabledSenders.forEach(e=>e.track?.stop()),this._disabledSenders.clear(),this._pc.ontrack=null,this._pc.onconnectionstatechange=null,this._pc.onsignalingstatechange=null,this._participantIdRegistry=null,n._closeDataChannel(this._producerNotification),n._closeDataChannel(this._producerCommand),n._closeDataChannel(this._producerScreen),n._closeDataChannel(this._consumerScreen),n._closeDataChannel(this._asr),n._closeDataChannel(this._animojiDataChannel),this._pc.close(),this._pc=null,this._producerOfferIsProcessing=!1,this._producerNextOffer=null),this._triggerEvent("PEER_CONNECTION_CLOSED")}static _closeDataChannel(e){e&&(e.onopen=null,e.onmessage=null,e.onerror=null,e.close())}_createDataChannel(e,t,i){d.debug(`[${t}] data channel opening`);let a=e.createDataChannel(t,{ordered:!0});a.onopen=()=>{let s=a.readyState;s==="open"?(d.debug(`[${t}] data channel opened`),i(a)):d.error(`[${t}] data channel open failed, state [${s}]`)},a.onerror=s=>{let o=s.error;d.error(`[${t}] data channel error`,o?.errorDetail,o?.message)}}_openConnection(e=!1){d.debug("ServerTransport: Open single connection"),this._pc=new RTCPeerConnection({},{optional:[{googSuspendBelowMinBitrate:!1}]}),this._pc.ontrack=this._onAddTrack.bind(this,this._pc),this._pc.onconnectionstatechange=I.debounce(t=>{this._pc&&this._onConnectionStateChange(this._pc,t)},500),this._pc.onsignalingstatechange=n._onSignalingStateChange.bind(this,this._pc),this._participantIdRegistry=new Sr,this._signaling.setParticipantIdRegistry(this._participantIdRegistry),l.producerNotificationDataChannel&&this._createDataChannel(this._pc,nt.producerNotification,t=>{this._producerNotification=t,this._producerNotification.binaryType="arraybuffer",this._signaling.setProducerNotificationDataChannel(t)}),l.producerCommandDataChannel&&(this._signaling.useCommandDataChannel(!0),this._createDataChannel(this._pc,nt.producerCommand,t=>{this._producerCommand=t,this._signaling.setProducerCommandDataChannel(t)})),l.producerScreenDataChannel&&this._createDataChannel(this._pc,nt.producerScreenShare,t=>{this._producerScreen=t,this._producerScreen.binaryType="arraybuffer",this._createCaptureReceiver()}),l.asrDataChannel&&this._createDataChannel(this._pc,nt.asr,t=>{this._asr=t,this._asr.binaryType="arraybuffer",this._removeAsrTrack(),this._asrTrack=new fr(t,this._participantIdRegistry,i=>{this._onAsrTranscription(i)})}),l.vmoji&&this._createDataChannel(this._pc,nt.animoji,t=>{this._animojiDataChannel=t,this._animojiDataChannel.binaryType="arraybuffer",this._animojiReceiver?.setDataChannel(t),this._animojiReceiver?.setParticipantIdRegistry(this._participantIdRegistry),this._animojiSender?.setDataChannel(t),this._animojiSender?.setProtocolVersion(l.vmojiOptions.protocolVersion||1)}),this._newAudioShareTrack=this._mediaSource.getAudioShareTrack();try{this._mediaSource.addTrackToPeerConnection(this._pc,this._observer,!1),this._prevConsumerSettings={},this._applyConsumerSettings()}catch(t){d.error("ServerTransport: Unable to add media source tracks",t),P.log(T.ERROR,"addTrack-single"),this.close(t);return}l.consumerScreenDataChannel&&this._createDataChannel(this._pc,nt.consumerScreenShare,t=>{this._consumerScreen=t,this._consumerScreen.binaryType="arraybuffer";let i=this._mediaSource.getScreenTrack();i&&this._createCaptureSender(i)}),e||this._allocateConsumer(),this._setState("OPENED"),this._startStatInterval(),this._startSettingsInterval()}_removeAsrTrack(){this._asrTrack?.destroy(),this._asrTrack=null}_reconnect(){this.getState()!=="OPENED"&&(this._setState("RECONNECTING"),this._closeConnection(),this._openConnection(!0))}_signalActiveParticipants(e){this._triggerEvent("SIGNALLED_ACTIVE_PARTICIPANTS",e)}_signalStalledParticipants(e){this._triggerEvent("SIGNALLED_STALLED_PARTICIPANTS",e)}_signalSpeakerChanged(e){this._triggerEvent("SIGNALLED_SPEAKER_CHANGED",e)}_signalNetworkStatus(e){this._triggerEvent("NETWORK_STATUS",e)}_updateSSRCMap(e){e&&e.sdp.split(`
|
|
12
|
+
`).forEach(t=>{let i=`a=ssrc:([0-9]+) label:(audio|video)-((?:[ug]?[\\d]+)|(?:mix)|(?:${$e.PARTICIPANT_AGNOSTIC_TRACK_PREFIX}-[0-9]+))`,a=new RegExp(i).exec(t);a&&(this._ssrcMap[a[1]]=a[3],this._ssrcMapUpdated=!0)})}_createCaptureSender(e){let t=this._mediaSource.getMediaSettings();!e||!l.consumerScreenDataChannel||!this._consumerScreen||!t.isScreenSharingEnabled||(this._captureSender&&this._removeCaptureSender(),this._captureSender=new Pt(e,this._consumerScreen,this._signaling,t.isFastScreenSharingEnabled))}_removeCaptureSender(){this._captureSender?.destroy(),this._captureSender=null}_createCaptureReceiver(){!l.producerScreenDataChannel||!this._producerScreen||(this._captureReceiver&&this._removeCaptureReceiver(),this._captureReceiver=new Rt(this._producerScreen,this._participantIdRegistry,(e,t)=>{this._triggerEvent("REMOTE_STREAM_SECOND",e,t)},e=>{this._triggerEvent("REMOTE_STREAM_SECOND",e,null)},e=>{this._triggerEvent("SCREEN_SHARING_STAT",e)}))}_removeCaptureReceiver(){this._captureReceiver?.destroy(),this._captureReceiver=null}_applyConsumerSettings(){let e=this._mediaSource.getMediaSettings().isScreenSharingEnabled&&!l.consumerScreenDataChannel?this._serverSettings.screenSharing:this._serverSettings.camera;if(e&&this._pc){let t=[];this._pc.getSenders().forEach(i=>{if(!i.track||i.track.kind!=="video")return;let a=!this._disabledSenders.has(i),s=e.maxDimension!==0;if(a&&!s){d.log("Disabling video upload"),this._disabledSenders.add(i),i.replaceTrack(b.getBlackMediaTrack()).catch(u=>{d.error("Could not disable video upload",u)});return}let o=this._mediaSource.getSendVideoTrack();if(!a&&s&&o){d.log("Enabling video upload"),this._disabledSenders.delete(i);let u=i.track;u.enabled=o.enabled,i.replaceTrack(o).then(()=>u.stop()).catch(p=>{d.error("Could not enable video upload",p)})}I.applyVideoTrackSettings(e,i,o??i.track,this._prevConsumerSettings,t)}),this._prevConsumerSettings=t}}_onScreenSharingStatus(e){e.track?this._createCaptureSender(e.track):this._removeCaptureSender()}_setState(e){this._state!==e&&(this._state=e,this._triggerEvent("STATE_CHANGED",e))}_startStatInterval(){if(this._statInterval)return;let e=()=>{if(!this._pc){this._stopStatInterval();return}this._collectStat().then(t=>{this._reportStats(t),this._detectStaleTracks(t),et.reportUsage(t)}).catch(()=>{}),this._statInterval=window.setTimeout(e,l.statisticsInterval)};this._statInterval=window.setTimeout(e,l.statisticsInterval)}_stopStatInterval(){this._statInterval&&(window.clearTimeout(this._statInterval),this._statInterval=null),this._statBytes={}}_startSettingsInterval(){if(this._settingsInterval)return;let t=()=>{if(!this._pc){this._stopSettingsInterval();return}this._applyConsumerSettings(),this._settingsInterval=window.setTimeout(t,2e3)};this._settingsInterval=window.setTimeout(t,2e3)}_stopSettingsInterval(){this._settingsInterval&&(window.clearTimeout(this._settingsInterval),this._settingsInterval=null)}async _collectStat(){if(!this._pc)return Promise.reject();this._ssrcMapUpdated&&(this._lastStat=null,this._ssrcMapUpdated=!1,this._createPerfStatsReporter());let e=await le.collectStats(this._pc,this._lastStat,this._ssrcMap,!0);return this._lastStat=e,e}_reportStats(e){this._triggerEvent("REMOTE_DATA_STATS",{inbound:{topology:"SERVER",transport:e.transport,rtps:e.rtps.filter(t=>t.type==="inbound-rtp")},outbound:{topology:"SERVER",transport:e.transport,rtps:e.rtps.filter(t=>t.type==="outbound-rtp")},remoteInbound:{topology:"SERVER",transport:e.transport,rtps:e.remoteRtps??[]}})}_detectStaleTracks(e){let t=e.rtps.find(o=>o.type==="inbound-rtp"&&o.kind==="audio"&&this._ssrcMap[o.ssrc]==="mix");if(!t)return;let i=$e.AUDIO_MIX,a=this._statBytes[i],s=!1;if(a){let o=t.bytesReceived-a.bytesReceived;o>=0&&o<=5&&(s=!0),a.stalled!==s&&this._triggerEvent("AUDIO_MIX_STALL",s)}this._statBytes[i]={bytesReceived:t.bytesReceived,stalled:s}}_allocateConsumer(){if(!this._signaling.ready)return;let e={estimatedPerformanceIndex:ht.getEstimatedPerformanceIndex(),audioMix:!0,consumerUpdate:!0,producerNotificationDataChannelVersion:l.producerNotificationDataChannel?8:0,producerCommandDataChannelVersion:l.producerCommandDataChannel?3:0,consumerScreenDataChannelVersion:l.consumerScreenDataChannel?1:0,producerScreenDataChannelVersion:l.producerScreenDataChannel?1:0,asrDataChannelVersion:l.asrDataChannel?1:0,animojiDataChannelVersion:l.vmoji?l.vmojiOptions.protocolVersion:1,animojiBackendRender:!l.vmojiOptions.renderingOptions.useFullClientRendering,onDemandTracks:!0,unifiedPlan:!0,singleSession:!0,videoTracksCount:l.videoTracksCount,red:l.serverAudioRed,audioShare:l.audioShare,fastScreenShare:l.fastScreenShare,videoSuspend:l.videoSuspend,simulcast:l.simulcast&&b.isSimulcastSupportedByBrowser()};!l.videoTracksCount&&!this._observer&&d.warn("Setting videoTracksCount to 0 is deprecated"),this._signaling.allocateConsumer(null,e)}async _processOffer(e){if(!this._pc)throw new Error("Interrupt allocation");let t=l.simulcast&&b.isSimulcastSupportedByBrowser(),i=t;try{await this._pc.setRemoteDescription(e)}catch(o){throw d.error("[single] unable to set remote offer",o),P.log(T.ERROR,"setRemoteDescription-single"),o}let a=this._findFirstSimTransceiver();if(t)if(a){d.log(`_processOffer: caps.simulcast=${l.simulcast} mid=${a.mid} dir=${a.direction}`);let o=this._mediaSource.getStream(),u=await this._setupSimulcastTransceiver(o,a);d.log("_processOffer: simulcastInfo",u),u||(d.log(`_processOffer: simulcast transceiver not found in server offer mid=${a.mid}, disable simulcast`),i=!1)}else d.log("_processOffer: simulcast transceiver not found in server offer, disable simulcast"),i=!1;let s;try{if(await this._handleTracks(),d.debug("[single] create local answer"),!this._pc)throw new Error("Interrupt allocation");s=await this._pc.createAnswer()}catch(o){throw d.error("[single] unable to create answer",o),P.log(T.ERROR,"createAnswer-single"),o}try{if(!this._pc)throw new Error("Interrupt allocation");s.sdp=I.patchLocalSDP(s.sdp,!1,b.isBrokenH264Decoder(),!1,l.h264spsPpsIdrInKeyframe),d.debug("[single] set local answer",{answer:s}),await this._pc.setLocalDescription(s)}catch(o){throw d.error("[single] unable to set local answer",o),P.log(T.ERROR,"setLocalDescription-single"),o}if(i&&a){s.sdp=I.patchSimulcastAnswerSdp(s.sdp,a,ot.WIDTH,ot.HEIGHT);for(let o of this._pc.getTransceivers())o.mid===null&&o.stop()}try{d.debug("[single] transmit local answer",{answer:s}),this._updateSSRCMap(e),await this._signaling.acceptProducer(s,Object.keys(this._ssrcMap)),d.debug("[single] remote offer has been processed")}catch(o){d.warn("[single] unable to send local answer",o),P.log(T.ERROR,"acceptProducer")}i&&await this._changeSimulcastInfo(!0,!0)}_findFirstSimTransceiver(){if(!this._pc)return null;for(let e of this._pc.getTransceivers()){let t=e.sender?.track?e.sender.track?.kind:e.receiver?.track?.kind;if(!e.sender||t!=="video")continue;let i=e.sender.getParameters();if(!(!i.encodings||i.encodings.length<=1))return e}return null}async _setupSimulcastTransceiver(e,t){if(!t?.sender||!e)return null;t.direction="sendonly";let i=e.getVideoTracks()[0];await t.sender.replaceTrack(i),t.sender.setStreams(e);let a=t.sender.getParameters();if(!a.encodings||a.encodings.length<=1)return d.log(`_setup:sim: mid=${t.mid} dir=${t.direction}: wrong encodings:${JSON.stringify(a.encodings)}`),null;let s=si(ot.WIDTH,ot.HEIGHT,this._serverSettings.camera?.bitrates?.generic),o=0,u=1;for(let m of a.encodings)m.scalabilityMode=ni,m.active=!0,o>=s.streams.length?m.maxBitrate=0:m.maxBitrate=s.streams[o].bitrate,m.scaleResolutionDownBy=u,u=u*2,o++;await t.sender.setParameters(a);let p=i.getSettings();return d.log(`_setup:sim: mid=${t.mid} dir=${t.direction} track=${p.width}x${p.height} encodings=${JSON.stringify(a.encodings)}`),!0}async _acceptProducer(e){if(this._producerOfferIsProcessing){this._producerNextOffer=e,d.debug("[single] wait until other remote offer is processed");return}this._producerOfferIsProcessing=!0;let t={type:"offer",sdp:I.patchRemoteSDP(e,b.isOldDataChannelDescription(),!1,!1,!1,b.isBrokenVP9Encoder(),b.isBrokenVP9Decoder())};if(d.debug("[single] set remote offer",{offer:t}),!this._pc)throw new Error("Interrupt allocation");try{if(await this._processOffer(t),this._producerOfferIsProcessing=!1,this._producerNextOffer){d.debug("[single] there is other unprocessed remote offer, process it");let i=this._producerNextOffer;this._producerNextOffer=null,await this._acceptProducer(i)}}catch(i){this.close(i)}}async _handleTracks(){if(!this._newAudioShareTrack||this._observer)return;let e=this._pc?.getTransceivers().find(t=>t.mid?.endsWith("s"));if(!e||!e.sender){d.warn("Cannot find audioshare transceiver");return}e.sender.track!==null&&d.warn("Unexpected track assigned to audioshare");try{e.direction="sendonly",await e.sender.replaceTrack(this._newAudioShareTrack),this._newAudioShareTrack=null}catch(t){d.error("ServerTransport: Unable to replace track",t),P.log(T.ERROR,"replaceTrack-single")}}async _onSignalingNotification(e){if(this._isOpen)switch(e.notification){case U.PRODUCER_UPDATED:await this._onProducerUpdated(e);break;case U.REALLOC_CON:this._reconnect();break;case U.AUDIO_ACTIVITY:this._signalActiveParticipants(e.activeParticipants);break;case U.SPEAKER_CHANGED:this._signalSpeakerChanged(e.speaker);break;case U.STALLED_ACTIVITY:this._signalStalledParticipants(e.stalledParticipants);break;case U.NETWORK_STATUS:this._signalNetworkStatus(e.statuses);break}}_onAsrTranscription(e){this._triggerEvent("ASR_TRANSCRIPTION",e)}async _onProducerUpdated(e){this._producerSessionId&&this._producerSessionId!==e.sessionId&&this._reconnect(),l.breakVideoPayloadTypes&&(d.log("test mode enabled, video switched off"),this._signaling.requestTestMode("breakVideoPayloadTypes",null)),this._producerSessionId=e.sessionId,await this._acceptProducer(e.description)}_onAddTrack(e,t){d.debug("[single] remote track (added)",{track:t.track});let i=t.streams[0];i?(i.onremovetrack||(i.onremovetrack=s=>{this._triggerEvent("REMOTE_TRACK_REMOVED",i.id,i,s.track)}),i.getTracks().find(s=>s.id===t.track.id)||i.addTrack(t.track),this._rtpReceiversByStreamId[i.id]=t.receiver,this._triggerEvent("REMOTE_TRACK_ADDED",i.id,i,t.track)):d.error("[single] unable to get media stream from track event")}static _onSignalingStateChange(e,t){d.debug("[single] signaling state changed",{state:e.signalingState},t)}_onConnectionStateChange(e,t){switch(d.debug("[single] connection state changed",{state:e.connectionState},t),P.log(T.ICE_CONNECTION_STATE,e.connectionState),e.connectionState){case"failed":this._reconnectionPrevented?this.close(new Error("Ice connection failed")):(P.logCustom(T.RECONNECT,{param:1}),this._reconnect());break;case"connecting":let i=this.getState();i==="IDLE"||i==="OPENED"?this._setState("CONNECTING"):e.iceConnectionState==="checking"&&this._setState("RECONNECTING");break;case"disconnected":this._reconnectionPrevented?this.close(new Error("Ice connection disconnected")):this._setState("RECONNECTING");break;case"connected":this._setState("CONNECTED"),I.getPeerConnectionHostInfo(e).then(a=>{a?.local&&(P.log(T.ICE_CONNECTION_TYPE,a.local.type),d.debug("Selected ICE candidates",a))}),P.logCustom(T.RECONNECT,{param:0});break}}_onReplacedTrack(e,t){if(this._pc){l.consumerScreenDataChannel&&t&&(e=t);let i=(a,s)=>{a.replaceTrack(s).catch(o=>{d.error("ServerTransport: Unable to replace track",o),P.log(T.ERROR,"replaceTrack-single")})};if(d.log(`_onReplacedTrack: newTrack=${e.getSettings().width}x${e.getSettings().height}`),l.simulcast&&b.isSimulcastSupportedByBrowser()&&e.kind==="video"){let s=this._pc?.getTransceivers().find(o=>o.direction==="sendonly"&&o.sender?.track?.kind==="video")?.sender;s?.track?(i(s,e),e.getSettings().width&&e.getSettings().height&&this._changeSimulcastInfo(!1,!1)):d.warn("_onReplacedTrack: simulcast video transceiver not found")}else{let a=this._pc?.getSenders().find(s=>s.track&&s.track.kind===e.kind&&!this._disabledSenders.has(s)&&s.track.contentHint===e.contentHint);a?.track?i(a,e):e.kind==="audio"&&e.contentHint==="music"&&(this._newAudioShareTrack=e)}}this._applyConsumerSettings()}getStreamWaitingTimeMs(e,t){if(!this._pc)return P.log(T.PAT_WAITING_TIME_ERROR,"noConnection"),d.error("Cannot get stream waiting time, peer connection is not initialized"),0;if(!RTCRtpReceiver.prototype.getSynchronizationSources)return P.log(T.PAT_WAITING_TIME_ERROR,"oldBrowser"),d.error("Cannot get stream waiting time, RTCRtpReceiver.getSynchronizationSources is not supported"),0;let i=this._rtpReceiversByStreamId[e];if(!i)return P.log(T.PAT_WAITING_TIME_ERROR,"noReceiver"),d.error(`Cannot get stream waiting time, cannot find RTP receiver by stream ID: ${e}`),0;let a=i.getSynchronizationSources();if(!a||!a.length)return d.log(`Cannot get stream waiting time, ${e} receiver has no synchronization sources`),0;let o=a[0].rtpTimestamp;if(!Number.isInteger(o))return P.log(T.PAT_WAITING_TIME_ERROR,"timestampNotInteger"),d.error(`Cannot get stream waiting time, ${e} receiver's RTP timestamp is not an integer: ${o}`),0;let u=t-o&Wo,p=Math.ceil(u/Go);return Math.min(100,Math.max(0,p))}async _changeSimulcastInfo(e,t){let i=this._mediaSource.getMediaSettings().isVideoEnabled,a=this._findFirstSimTransceiver();if(!l.simulcast||!b.isSimulcastSupportedByBrowser()||!i||!a||!a.sender)return;let s=this._mediaSource.getStream();if(!s)return;let o=s.getVideoTracks()[0],u=o.getSettings().width,p=o.getSettings().height,m=si(u,p,this._serverSettings.camera?.bitrates?.generic),h=t||!Oa(this._simulcastInfo,m);if(!m.streams.length||!h)return;let R=a.sender.getParameters();if(R.encodings||(R.encodings=[{}]),!(R.encodings.length<=1)){if(d.log(`_changeSimulcastInfo: ${u}x${p} command: ${JSON.stringify(m)} `),e){let M=0;for(let k of R.encodings)k.scaleResolutionDownBy=Di(k.rid),k.scalabilityMode=ni,M>=m.streams.length?(k.maxBitrate=0,k.active=!1):(k.active=!0,k.maxBitrate=m.streams[M].bitrate),M++;await a.sender.setParameters?.(R).catch(k=>{d.error("Failed to set sender parameters",R,k)}),d.log(`_changeSimulcastInfo: actual encodings: ${JSON.stringify(R.encodings)} `)}if(this._simulcastInfo=m,m.streams){let M={mediaSource:1,simulcastInfo:m};await this._signaling.changeSimulcast(M)}}}};var qe=(e=>(e.DIRECT="DIRECT",e.SERVER="SERVER",e))(qe||{}),vr=class extends re{constructor(e,t,i,a){super();c(this,"_signaling");c(this,"_mediaSource");c(this,"_topology");c(this,"_allocated",[]);c(this,"_opened",[]);c(this,"_directTransport",null);c(this,"_serverTransport",null);c(this,"_serverSettings");c(this,"_dtListeners",[]);c(this,"_stListeners",[]);c(this,"_states",{});c(this,"_localState","IDLE");c(this,"_animojiReceiver",null);c(this,"_animojiSender",null);this._signaling=t,this._mediaSource=i,this._topology=e,this._serverSettings=a,this.subscribe(this._signaling,Pe.NOTIFICATION,this._onSignalingNotification.bind(this)),this.subscribe(this._mediaSource,"ANIMOJI_STATUS",this._onAnimojiStatus.bind(this)),this.subscribe(this._mediaSource,"SOURCE_CHANGED",this._onSourceChanged.bind(this)),this._createAnimojiTransport(),e==="SERVER"&&(this._serverTransport=this._createServerTransport())}updateSettings(e){d.log("Update transport settings",e),this._serverSettings=e,this._directTransport&&this._directTransport.updateSettings(e),this._serverTransport&&this._serverTransport.updateSettings(e)}updateStatisticsInterval(){this._directTransport&&this._directTransport.updateStatisticsInterval(),this._serverTransport&&this._serverTransport.updateStatisticsInterval()}allocate(e,t=!1){if(d.log(`Trying allocate participant [${e}]`),this._allocated.indexOf(e)!==-1){d.warn(`The participant [${e}] has already had allocated transport`);return}this._allocated.push(e),this._topology==="DIRECT"&&!this._directTransport&&(this._directTransport=this._createDirectTransport(e,t)),this._topology==="SERVER"&&!this._serverTransport&&(this._serverTransport=this._createServerTransport())}open(e,t=null,i=!1,a=!1){d.log("Trying open participant",{participantIds:e});let s=a;for(let o of e){if(this._opened.indexOf(o)!==-1){d.warn(`The participant [${o}] has already had opened transport`);continue}if(this._allocated.indexOf(o)===-1){d.warn(`The participant [${o}] has no allocated transport`);continue}this._opened.push(o),s=!0}s&&(this._topology==="DIRECT"&&this._directTransport&&this._directTransport.open(t),this._topology==="SERVER"&&this._serverTransport&&(this._serverTransport.open(i),this._setStates(e,this._serverTransport.getState()),this._setLocalState(this._serverTransport.getState())),d.debug("The transport has been opened",e))}close(e){let t=this._allocated.indexOf(e),i=this._opened.indexOf(e);t<0&&d.warn(`The participant [${e}] transport has already deallocated`),this._topology==="DIRECT"&&this._directTransport&&i>=0&&this._releaseDirectTransport(),this._topology==="SERVER"&&(this._serverTransport?.removeParticipant(e),this._setStates([e],"CLOSED")),i>=0&&this._opened.splice(i,1),t>=0&&this._allocated.splice(t,1),delete this._states[e]}destroy(){this.unsubscribe();for(let e of this._dtListeners)e.dispose();for(let e of this._stListeners)e.dispose();this._removeAnimojiTransport(),l.audioEffects?.destroy(),this._directTransport?.close(),this._directTransport=null,this._serverTransport?.close(),this._serverTransport=null,this._allocated=[],this._opened=[]}getTopology(){return this._topology}isAllocated(e){return this._allocated.indexOf(e)>=0}allocated(){return this._allocated.slice()}opened(){return this._opened.slice()}getState(){return this._topology==="SERVER"?this._serverTransport?.getState():this._directTransport?.getState()}getStates(){return this._states}setAnimojiSvg(e,t){l.vmoji&&t.isMe&&l.vmoji.AnimojiPreviewGenerator?.setSvgData(t),(!(t.svg instanceof ArrayBuffer)||t.svg.byteLength!==0)&&this._animojiReceiver?.setParticipantSvg(e,t)}setAnimojiFill(e){this._animojiSender?.setFill(e)}async onCameraResolutionChanged(){this._topology==="SERVER"&&this._serverTransport&&await this._serverTransport.onCameraResolutionChanged()}_setStates(e,t){let i=e.filter(a=>this._states[a]!==t?(this._states[a]=t,!0):!1);i.length&&this._triggerEvent("STATE_CHANGED",i,t)}_setLocalState(e){this._localState!==e&&(this._localState=e,this._triggerEvent("LOCAL_STATE_CHANGED",e))}_onSignalingNotification(e){if(e.notification===U.TOPOLOGY_CHANGED)return this._onTopologyChanged(e)}_onTopologyChanged(e){if(e.topology!==this._topology){if(d.log(`Topology changed ${this._topology} -> ${e.topology}`),P.log(T.TOPOLOGY_CHANGE_REQUESTED,e.topology),this._topology=e.topology,this._topology==="SERVER"&&(this._serverTransport?this._serverTransport.allowRestart():(this._serverTransport=this._createServerTransport(),this._opened.length>0&&(this._directTransport?.preventRestart(),this._serverTransport.open()))),this._topology==="DIRECT"){let t=e.offerTo||[],i=e.offerToTypes||[],a=e.offerToDeviceIdxs||[],s=t.length&&i.length?I.composeParticipantId(t[0],i[0],a[0]):null;if(this._serverTransport&&this._serverTransport.preventRestart(),!this._allocated||this._allocated.length===0){d.error("Topology changed to DIRECT, but the list of allocated participants is empty");return}this._allocated.length>1&&d.warn("Topology changed to DIRECT, but the allocated participants count more then one");let o=this._allocated[0];if(this._directTransport)this._directTransport.allowRestart();else{let u=s===o;this._directTransport=this._createDirectTransport(o,u)}this._opened.indexOf(o)>=0&&this._directTransport.open()}this._triggerEvent("TOPOLOGY_CHANGED",this._topology)}}_createDirectTransport(e,t=!1){let i=new Ti(e,t,this._signaling,this._mediaSource,this._serverSettings);return this._dtListeners.length>0&&d.warn(`The list of direct listeners for the participant [${e}] is not empty`),this._dtListeners=[],this._dtListeners.push(i.addEventListener("REMOTE_TRACK_ADDED",this._onRemoteTrackAdded.bind(this,e)),i.addEventListener("REMOTE_TRACK_REMOVED",this._onRemoteTrackRemoved.bind(this,e)),i.addEventListener("REMOTE_DATA_STATS",this._onRemoteDataStats.bind(this)),i.addEventListener("STATE_CHANGED",this._onDirectTransportChanged.bind(this)),i.addEventListener("NETWORK_STATUS",this._onTransportNetworkStatus.bind(this)),i.addEventListener("PEER_CONNECTION_CLOSED",this._onPeerConnectionClosed.bind(this,"DIRECT"))),this._animojiReceiver&&this._animojiSender&&i.setAnimojiTransport(this._animojiReceiver,this._animojiSender),i}_createServerTransport(){let e=new Ri(this._signaling,this._mediaSource,this._serverSettings);return this._stListeners.length>0&&d.warn("The list of server transport listeners is not empty"),this._stListeners=[],this._stListeners.push(e.addEventListener("REMOTE_TRACK_ADDED",this._onRemoteTrackAdded.bind(this)),e.addEventListener("REMOTE_TRACK_REMOVED",this._onRemoteTrackRemoved.bind(this)),e.addEventListener("AUDIO_MIX_STALL",this._onServerAudioMixStall.bind(this)),e.addEventListener("REMOTE_DATA_STATS",this._onRemoteDataStats.bind(this)),e.addEventListener("STATE_CHANGED",this._onServerTransportChanged.bind(this)),e.addEventListener("SIGNALLED_ACTIVE_PARTICIPANTS",this._onTransportActiveParticipants.bind(this)),e.addEventListener("SIGNALLED_SPEAKER_CHANGED",this._onTransportSpeakerChanged.bind(this)),e.addEventListener("SIGNALLED_STALLED_PARTICIPANTS",this._onTransportStalledParticipants.bind(this)),e.addEventListener("NETWORK_STATUS",this._onTransportNetworkStatus.bind(this)),e.addEventListener("REMOTE_STREAM_SECOND",this._onRemoteStreamSecond.bind(this)),e.addEventListener("PEER_CONNECTION_CLOSED",this._onPeerConnectionClosed.bind(this,"SERVER")),e.addEventListener("ASR_TRANSCRIPTION",this._onAsrTranscription.bind(this))),this._animojiReceiver&&this._animojiSender&&e.setAnimojiTransport(this._animojiReceiver,this._animojiSender),e}_releaseDirectTransport(){this._directTransport?.close(),this._directTransport=null;for(let e of this._dtListeners)e.dispose();this._dtListeners=[]}_releaseServerTransport(){this._serverTransport?.close(),this._serverTransport=null;for(let e of this._stListeners)e.dispose();this._stListeners=[]}_setLocalNoiseSuppression(e){l.noiseSuppression!==e&&(l.noiseSuppression=e,this._mediaSource?.updateNoiseSuppression())}_onDirectTransportChanged(e){let t=this._directTransport?.participantId;if(e==="CONNECTED"&&this._topology==="DIRECT"&&this._releaseServerTransport(),(e==="CLOSED"||e==="FAILED")&&(this._releaseDirectTransport(),this._topology==="DIRECT")){let i=this._opened.indexOf(t);i>=0&&this._opened.splice(i,1);let a=this._allocated.indexOf(t);a>=0&&this._allocated.splice(a,1)}this._topology==="DIRECT"&&t&&(this._setStates([t],e),this._setLocalState(e))}_onServerTransportChanged(e){let t=this._opened.slice();e==="CONNECTED"&&this._topology==="SERVER"&&this._releaseDirectTransport(),(e==="CLOSED"||e==="FAILED")&&(this._releaseServerTransport(),this._topology==="SERVER"&&(this._allocated=[],this._opened=[])),this._topology==="SERVER"&&(this._setStates(t,e),this._setLocalState(e))}_onTransportActiveParticipants(e){this._topology==="SERVER"&&this._triggerEvent("SIGNALLED_ACTIVE_PARTICIPANTS",e)}_onTransportStalledParticipants(e){this._topology==="SERVER"&&this._triggerEvent("SIGNALLED_STALLED_PARTICIPANTS",e)}_onTransportSpeakerChanged(e){this._topology==="SERVER"&&this._triggerEvent("SIGNALLED_SPEAKER_CHANGED",e)}_onTransportNetworkStatus(e){this._triggerEvent("NETWORK_STATUS",e)}_onRemoteStreamSecond(e,t){this._triggerEvent("REMOTE_STREAM_SECOND",e,t)}_onPeerConnectionClosed(e){this._triggerEvent("PEER_CONNECTION_CLOSED",e)}_onServerAudioMixStall(e){this._topology==="SERVER"&&this._triggerEvent("AUDIO_MIX_STALL",e)}_onRemoteDataStats(e){this._triggerEvent("REMOTE_DATA_STATS",e)}_onRemoteTrackAdded(e,t,i){this._triggerEvent("REMOTE_TRACK_ADDED",e,t,i)}_onRemoteTrackRemoved(e,t,i){this._triggerEvent("REMOTE_TRACK_REMOVED",e,t,i)}_onAsrTranscription(e){this._triggerEvent("ASR_TRANSCRIPTION",e)}_onSourceChanged(){let e=this._mediaSource.getStream();e&&this._animojiSender?.setStream(e)}_onAnimojiStream(e,t){this._triggerEvent("ANIMOJI_STREAM",e,t)}_onAnimojiStatus(e){e?this._animojiSender?.resume():this._animojiSender?.pause(),this._mediaSource.onAnimojiSender(e)}_createAnimojiTransport(){if(!l.vmoji)return;this._animojiReceiver=new l.vmoji.AnimojiReceiver((t,i)=>this._onAnimojiStream(t,i),t=>this._onAnimojiStream(t,null),t=>{this._triggerEvent("ANIMOJI_ERROR",t)},l.vmojiOptions.renderingOptions);let e=this._mediaSource.getStream();this._animojiSender=new l.vmoji.AnimojiSender(e,this._signaling.getPeerId(),l.vmojiOptions.protocolVersion,{requested:this._mediaSource.isAnimojiRequested,useAI:l.vmojiOptions.renderingOptions.useAI}),this._animojiSender.onLocalData=t=>this._animojiReceiver?.receive(t)}_removeAnimojiTransport(){this._animojiSender?.destroy(),this._animojiSender=null,this._animojiReceiver?.destroy(),this._animojiReceiver=null}getStreamWaitingTimeMs(e,t){return this._topology!=="SERVER"?(P.log(T.PAT_WAITING_TIME_ERROR,"wrongTopology"),d.error(`Cannot get stream waiting time, incorrect topology: ${this._topology}`),0):this._serverTransport?this._serverTransport.getStreamWaitingTimeMs(e,t):(P.log(T.PAT_WAITING_TIME_ERROR,"noTransport"),d.error("Cannot get stream waiting time, server transport is not initialized"),0)}};var Ir=class extends re{constructor(e){super();c(this,"_detector",null);c(this,"_interval",null);c(this,"_activeParticipants");this.subscribe(e,"REMOTE_TRACK_ADDED",this._onRemoteTrackAdded.bind(this)),this.subscribe(e,"REMOTE_TRACK_REMOVED",this._onRemoteTrackRemoved.bind(this)),this.subscribe(e,"SIGNALLED_ACTIVE_PARTICIPANTS",this._onSignalledActiveParticipants.bind(this)),this.subscribe(e,"TOPOLOGY_CHANGED",this._onTopologyChanged.bind(this))}destroy(){this._interval&&(window.clearTimeout(this._interval),this._interval=null),this.unsubscribe(),this._detector?.destroy(),this._detector=null}_onRemoteTrackAdded(e,t,i){if(i.kind==="audio"&&(this._detector?.destroy(),this._detector=new ut(e,i),!this._interval)){let a=()=>{this._collectVolumes(),this._interval=window.setTimeout(a,l.voiceParams.interval)};this._interval=window.setTimeout(a,l.voiceParams.interval)}}_onRemoteTrackRemoved(e,t,i){i.kind==="audio"&&(!this._detector||this._detector.track!==i||(this._detector.destroy(),this._detector=null))}_collectVolumes(){if(!this._detector)return;let e={},t=this._detector.trackId,i=this._detector.getLevel();if(t===$e.AUDIO_MIX){if(this._activeParticipants)for(let a of this._activeParticipants)e[a]=i}else e[t]=i;this._triggerEvent("VOLUMES_DETECTED",e)}_onSignalledActiveParticipants(e){this._activeParticipants=e}_onTopologyChanged(e){e==="DIRECT"&&(this._activeParticipants=null)}};var Er=class extends re{constructor(e,t,i){super();c(this,"_speakerId",null);c(this,"_serverSideSpeakerDetection",!1);this._serverSideSpeakerDetection=i==="SERVER",this.subscribe(e,"VOLUMES_DETECTED",this._onVolumesDetected.bind(this)),this.subscribe(t,"SIGNALLED_SPEAKER_CHANGED",this._onServerSpeakerChanged.bind(this)),this.subscribe(t,"TOPOLOGY_CHANGED",this._onTopologyChanged.bind(this))}destroy(){this.unsubscribe()}_onVolumesDetected(e){if(this._serverSideSpeakerDetection)return;let t=0,i=null;if(Object.keys(e).forEach(a=>{let s=e[a].smoothed;s>t&&s>l.voiceParams.threshold&&(t=s,i=a)}),i&&i!==this._speakerId){let a=this._speakerId&&e.hasOwnProperty(this._speakerId)?e[this._speakerId].smoothed:0;t>a*l.voiceParams.speakerLevelMultiplier&&(this._speakerId=i,this._triggerEvent("SPEAKER_CHANGED",i))}}_onServerSpeakerChanged(e){this._serverSideSpeakerDetection&&this._triggerEvent("SPEAKER_CHANGED",e)}_onTopologyChanged(e){this._serverSideSpeakerDetection=e==="SERVER"}};var Ci=class extends re{constructor(e,t,i){super();c(this,"_transport");c(this,"_volumes",{});c(this,"_participants",{});c(this,"_connectionTimeout",0);c(this,"_volumeTimeout",0);this._transport=e,this._participants=i,this.subscribe(e,"STATE_CHANGED",this._onTransportStateChanged.bind(this)),this.subscribe(t,"VOLUMES_DETECTED",this._onVolumesDetected.bind(this))}destroy(){this.unsubscribe(),this._connectionTimeout&&window.clearTimeout(this._connectionTimeout),this._volumeTimeout&&window.clearTimeout(this._volumeTimeout)}onChangeRemoteMediaSettings(e,t){t.isAudioEnabled||(this._volumes[e]=1),t.isAudioEnabled&&(this._volumes[e]=0)}_onTransportStateChanged(e,t){t==="OPENED"&&(this._connectionTimeout||(this._connectionTimeout=window.setTimeout(this._onConnectionTimeout.bind(this),l.specListenerParams.connectionTimeout)),this._volumeTimeout||(this._volumeTimeout=window.setTimeout(this._onVolumeTimeout.bind(this),l.specListenerParams.volumeTimeout))),t==="FAILED"&&this._connectionTimeout&&(d.warn("Transport failed, send callSpecError"),P.log(T.CALL_SPEC_ERROR,`${this._transport.getTopology()}_CONNECTION_TIMEOUT`))}_onVolumesDetected(e){Object.keys(e).forEach(t=>{this._volumes[t]=Math.max(e[t].real,this._volumes[t]||0)})}_onConnectionTimeout(){let e=i=>i!=="CONNECTED";Object.values(this._transport.getStates()).filter(e).length>0&&(d.warn("There is not connected transport, send callSpecError"),P.log(T.CALL_SPEC_ERROR,`${this._transport.getTopology()}_CONNECTION_TIMEOUT`)),this._connectionTimeout=0}_onVolumeTimeout(){let e=[];Object.keys(this._volumes).forEach(t=>{if(this._volumes[t]>0)return;let i="UNKNOWN",a=this._participants[t];a&&a.platform&&(i=a.platform),e.indexOf(i)<0&&(e.push(i),P.log(T.CALL_SPEC_ERROR,`${this._transport.getTopology()}_VOLUME_TIMEOUT_${i}`))}),e.length&&d.warn("There is silent participant, send callSpecError"),this._volumeTimeout=0}};var Tr=class n{static correctHangupReason(r){switch(r){case w.HUNGUP:return"hangup";case w.CANCELED:return"canceled";case w.REJECTED:return"rejected";case w.BUSY:return"busy";case w.FAILED:return"failed";case w.MISSED:return"missed";case w.ANOTHER_DEVICE:return"another_device";case w.REMOVED:return"removed";case w.BANNED:return"banned";case w.VCHAT_DETAILED_ERROR:return"error";default:return"hangup"}}static sendHangupEvent(r,e){if(![w.HUNGUP,w.CANCELED,w.REJECTED,w.FAILED,w.BUSY,w.MISSED,w.ANOTHER_DEVICE,w.REMOVED,w.BANNED,w.VCHAT_DETAILED_ERROR].includes(r.hangup))return;let i=r.custom_error?.vchat_detailed_api_error.code;P.logClientStats({name:T.CALL_FINISH,reason:n.correctHangupReason(r.hangup),call_topology:e==="DIRECT"?"D":"S",...i&&{string_value:i}})}};var Rr=class{constructor(){c(this,"_isCallMarked",!1);c(this,"_isFinished",!1);c(this,"_callType",null)}markAcceptCall(r){this.mark(r==="DIRECT"?"direct_incoming":"server_incoming")}markAcceptedCall(r){r==="DIRECT"&&this.mark("direct_outgoing")}markParticipantJoined(r){r==="DIRECT"&&this.mark("server_change_topology")}markOnJoin(r){r==="SERVER"&&this.mark("server_join_server")}mark(r){this._isCallMarked||(this._isCallMarked=!0,this._callType=r,le.setMark(T.FIRST_MEDIA_RECEIVED))}measure(){this._isFinished||(this._isFinished=!0,this._callType&&Ce.logEventualStat({name:T.FIRST_MEDIA_RECEIVED,call_type:this._callType}))}};var Ko=1e3,$o=1e4;var qo=15,$=class $ extends re{constructor(e,t){super();c(this,"_api");c(this,"_signaling");c(this,"_signalingActor");c(this,"_mediaSource",null);c(this,"_conversation",null);c(this,"_myLastRequestedLayouts",{});c(this,"_state","IDLE");c(this,"_participantState",J.CALLED);c(this,"_participants",{});c(this,"_pendingParticipants",new Map);c(this,"_transport",null);c(this,"_debugInfo",null);c(this,"_volumesDetector",null);c(this,"_speakerDetector",null);c(this,"_localVolumeDetector",null);c(this,"_specListener",null);c(this,"_activeSpeakerId",null);c(this,"_lastSignalledActiveSpeakerId",null);c(this,"_isRealTimeAsrRequested",!1);c(this,"_serverSettings",{camera:null,screenSharing:null});c(this,"_onUnload");c(this,"_audioOutput");c(this,"_lastStalled",{});c(this,"_audioMixStalled",!1);c(this,"_audioFix",null);c(this,"_streamByStreamId",new Map);c(this,"_streamIdByStreamDescription",new Map);c(this,"_streamWaitTimerByStreamDescription",new Map);c(this,"_sequenceNumberByStreamDescription",new Map);c(this,"_cooldownTimestampByStreamDescription",new Map);c(this,"_cooldownQueueCleanupTimer",null);c(this,"_statFirstMediaReceived");c(this,"_changeMediaSettings",I.debounce(async e=>{if(this._signaling.ready)try{await this._signaling.changeMediaSettings(e)}catch(t){if(d.warn("changeMediaSettings failed with error",t),t.message==="chatRoom.maxShareCountExceeded")return this.toggleScreenCapturing({captureScreen:!1,fastScreenSharing:!1,captureAudio:!1})}},100));P.create(e,t),P.setConversationIdProvider(()=>this._conversation?.id||null),Ce.create(),et.create(()=>this._transport?.getTopology()),this._api=e,this._signaling=new At,this._signalingActor=new _r(this._onSignalingNotification.bind(this)),this._onUnload=()=>{this._conversation&&this._api&&(this._api.hangupConversation(this._conversation.id),l.clientEventsLoggingEnabled&&P.logClientEvent({event_type:T.CALL_DECLINED_OR_HANGED_LOCALLY,reason:"none"},!0)),P.destroy(),Ce.destroy(),et.destroy()},window.addEventListener("unload",this._onUnload),this._statFirstMediaReceived=new Rr,this._audioOutput=new gi(this._statFirstMediaReceived),l.videoTracksCount>0&&(this._cooldownQueueCleanupTimer=window.setInterval(this._cleanupCooldownQueue.bind(this),Ko))}static current(){return $._current}static hangupAfterInit(){$._activationMutex&&!$._current&&($._delayedHangup=!0)}static id(){return $._current?._conversation?.id||null}async onStart({opponentIds:e,opponentType:t,mediaOptions:i,payload:a="",joiningAllowed:s=!1,requireAuthToJoin:o=!1,onlyAdminCanShareMovie:u,externalIds:p,onFastStart:m}){if($._activationMutex)throw P.log(T.ERROR,"startCall"),d.warn("Conversation: there is already running activation"),new G(w.FAILED);let h=Date.now();$._activationMutex=!0,ke.startSession();try{this._mediaSource=this._createMediaSource(),await this._mediaSource.request(i);let R=this._mediaSource.getMediaSettings();t===Ze.CHAT||e&&e.length>1?this._logWithMediaSettings(T.OUTGOING_MULTIPARTY_CALL,R):this._logWithMediaSettings(T.OUTGOING_CALL,R);let M=await this._startConversation({opponentIds:e,opponentType:t,direction:De.OUTGOING,mediaOptions:i,payload:a,joiningAllowed:s,requireAuthToJoin:o,onlyAdminCanShareMovie:u,externalIds:p,startedTime:h,onFastStart:m});if(!this._conversation)throw new G(w.UNKNOWN_ERROR);if(this._participantState=J.ACCEPTED,this._changeMediaSettings(R),await this._processConnection(M),await this._allocateTransport(),this._createSpeakerDetector(),await this._createSpecListener(),this._signaling.readyToSend(),$._delayedHangup)throw new G(w.CANCELED);return d.debug("Outgoing call",{opponentIds:e,opponentType:t,mediaOptions:i}),await this._processConnectionSharedMovieInfo(M),await this._processConversationUrlSharingInfo(M),E.onLocalStream(this._mediaSource.getStream(),this._mediaSource.getMediaSettings()),E.onConversation(this._conversation.externalId,this._conversation.mediaModifiers,this._getMuteStatesForCurrentRoom(),await this._getMainRoomParticipants()),await this._onConversationParticipantListChunk(M),await this._processPinnedParticipants(M),E.onLocalStatus("WAITING"),this._toggleJoinAvailability(),this._changeFeatureSet(),this._changeNeedRate(),$._current=this,this._conversation.concurrent&&await this._acceptConcurrent(),this._conversation}catch(R){throw this._close(R,"Unable to start conversation"),R}finally{$._activationMutex=!1}}async onJoin(e){if($._activationMutex)throw P.log(T.ERROR,"joinCall"),d.warn("Conversation: there is already running activation"),new G(w.FAILED);let t=Date.now();$._activationMutex=!0,this._state="PROCESSING",ke.startSession();try{let i=!!e.observedIds?.length;if(i&&l.videoTracksCount>0)throw d.error("Observer mode: please set videoTracksCount=0"),new G(w.UNSUPPORTED);this._mediaSource=this._createMediaSource(),await this._mediaSource.request(e.mediaOptions,!i);let a=this._mediaSource.getMediaSettings();this._logWithMediaSettings(T.JOIN_CONVERSATION,a);let s=await this._joinConversation(e,t);if(!this._conversation)throw new G(w.UNKNOWN_ERROR);return this._conversation.observer=i,E.onLocalStream(this._mediaSource.getStream(),a),this._conversation.waitingHall?(d.log("In waiting hall"),$._current=this,$._activationMutex=!1,this._signaling.readyToSend(),E.onLocalStatus("WAITING_HALL"),this._conversation):this._onJoinPart2(s)}catch(i){throw $._activationMutex=!1,this._close(i,"Unable to join conversation"),i}}async _onJoinPart2(e){d.debug("Join conversation part 2"),$._activationMutex=!0;try{if(this._participantState=J.ACCEPTED,!this._conversation||!this._mediaSource)throw new G(w.UNKNOWN_ERROR);if(this._statFirstMediaReceived.markOnJoin(this._conversation.topology),!this._conversation.observer&&!this._isAudienceModeListener()&&this._changeMediaSettings(this._mediaSource.getMediaSettings()),await this._processConnection(e),await this._allocateTransport(),this._createSpeakerDetector(),await this._createSpecListener(),this._signaling.readyToSend(),this._state==="CLOSE")return this._conversation;if($._delayedHangup)throw new G(w.CANCELED);await this._processConnectionSharedMovieInfo(e),await this._processConversationUrlSharingInfo(e),await this._processConnectionAsrInfo(e);let t=await this._extractExternalRoomsData(e.rooms?.rooms,e.rooms?.roomId);return E.onConversation(this._conversation.externalId,this._conversation.mediaModifiers,this._getMuteStatesForCurrentRoom(),await this._getMainRoomParticipants(),t),await this._onConversationParticipantListChunk(e),await this._processPinnedParticipants(e),E.onLocalStatus("WAITING"),this._toggleJoinAvailability(),this._changeNeedRate(),this._state="ACTIVE",this._changeFeatureSet(),$._current=this,this._openTransport(Object.values(await this._getParticipants()),!1),this._conversation.audienceMode&&!this._conversation.restricted&&this._forceOpenTransportForAloneInCall(),this._conversation.recordsInfoByRoom.get(e?.rooms?.roomId??null)&&this._forceOpenTransportForAloneInCall(),this._conversation}catch(t){throw this._close(t,"Unable to join conversation"),t}finally{$._activationMutex=!1}}async _extractExternalRooms(e){let t=e.map(this._convertRoomToExternal.bind(this));return(await Promise.all(t)).filter(a=>!!a)}async _extractExternalRoomsData(e,t){if(!e||!e.length)return;let i={rooms:await this._extractExternalRooms(e)};return t&&(i.roomId=t),i}async onPush(e,t=te.USER,i,a,s){if($._activationMutex)throw d.warn("Conversation: there is already running activation"),new G(w.REJECTED);$._activationMutex=!0;try{let o=Date.now(),u=await this._prepareConversation(e,t,i,a,s);if(this._mediaSource=this._createMediaSource(),!this._conversation)throw new G(w.UNKNOWN_ERROR);if(!u.conversation.participants.find(m=>m.state===J.CALLED&&m.id===this._conversation?.userId))throw d.log("Push rejected (there is an active call)"),P.log(T.PUSH,"rejected"),new G(w.REJECTED);if(ke.startSession(),await this._processConnection(u),this._extractConnectionUrlSharingInfo(u),await this._allocateTransport(),this._createSpeakerDetector(),await this._createSpecListener(),await this._processPinnedParticipants(u),this._signaling.readyToSend(),this._logCallStartEvent(o,De.INCOMING),P.log(T.PUSH,"accepted"),$._current=this,$._delayedHangup)throw new G(w.CANCELED);$._activationMutex=!1}catch(o){throw $._activationMutex=!1,this._close(o,"Unable to handle inbound call push"),o}}_isInWaitingHall(e){return!e.conversation||(e.conversation.options||[]).indexOf(Dt.WAITING_HALL)<0?!1:this._isRestricted(e)}_isRestricted(e){let t=(e.conversation.participants||[]).find(i=>I.comparePeerId(i.peerId,e.peerId));return t&&t.restricted||!1}_isAudienceMode(e){return e.conversation?.options?.includes(Dt.AUDIENCE_MODE)||!1}_isAudienceModeListener(){return this._conversation?.audienceMode&&this._conversation?.restricted}async _acceptConcurrent(){if(!this._mediaSource||!this._conversation||!this._transport)throw new G(w.UNKNOWN_ERROR);this._state="PROCESSING";let e=this._mediaSource.getMediaSettings();this._logWithMediaSettings(T.ACCEPT_CONCURRENT,e),d.debug("Concurrent call",{conversationId:this._conversation.id});try{this._statFirstMediaReceived.markAcceptCall(this._transport.getTopology()),await this._signaling.acceptCall(this._mediaSource.getMediaSettings()),E.onCallAccepted(),this._state="ACTIVE",this._participantState=J.ACCEPTED,this._changeFeatureSet(),this._openTransport(Object.values(await this._getParticipants()),!0)}catch(t){this._close(t,"Unable to accept concurrent call")}}async _getMainRoomParticipants(){let e=await this._getParticipants();return I.mapSharedParticipants(Object.values(e).filter(t=>!t.isInRoom))}_decodeExternalConversationParams(e){let[t,i]=e.split(":"),a=parseInt(t,10);if(isNaN(a))throw new Error("Invalid original length in prefix");let s=atob(i),o=new Uint8Array(s.length);for(let u=0;u<s.length;u++)o[u]=s.charCodeAt(u);try{let p=Ln(o,a).reduce((ve,ye)=>(ve+=String.fromCharCode(ye),ve),""),{srcp:m,stne:h,tkn:R,trne:M,trnp:k,trnu:H,wse:z,wte:ae}=JSON.parse(p);return{token:R,endpoint:z,wt_endpoint:ae,turn_server:{urls:M.split(","),username:H,credential:k},stun_server:{urls:h.split(",")},client_type:m}}catch(u){throw this._close(u,"Can't decompress conversation params"),u}}_logCallStartEvent(e,t){let i={[De.OUTGOING]:"outgoing",[De.INCOMING]:"incoming",[De.JOINING]:"join"};Ce.logEventualStat({name:T.CALL_START,value:Date.now()-e,string_value:JSON.stringify({labels:[i[t],"warmup_start"]})})}async accept(e){if(this._state!=="IDLE")throw P.log(T.ERROR,"acceptIncoming"),d.error("Unable to accept a call - invalid state"),new Error("Unable to accept a call - invalid state");if(!this._mediaSource||!this._conversation||!this._transport)throw new G(w.UNKNOWN_ERROR);this._state="PROCESSING",d.debug("Accept incoming call",e);try{await this._mediaSource.request(e);let t=this._mediaSource.getMediaSettings();this._logWithMediaSettings(T.ACCEPT_INCOMING,t),this._changeMediaSettings(t),this._statFirstMediaReceived.markAcceptCall(this._transport.getTopology()),await this._signaling.acceptCall(t),this._participantState=J.ACCEPTED;let i=this._getMuteStatesForCurrentRoom(),a=Object.keys(i);a.length&&this._onMuteParticipant({muteStates:i,mediaOptions:a,muteAll:!0,stateUpdated:!0}),this._registerParticipantLocalMuteState({muteStates:this._conversation.muteStatesPersonal});let s=await this._signaling.getRooms(this._isCallAdmin());if(s.rooms?.rooms){let u=await this._getParticipants();s.rooms.rooms.forEach(p=>{p.participantIds?.forEach(m=>{u[m]&&(u[m].isInRoom=!0)})})}this._conversation.roomId=s.rooms?.roomId||null;let o=await this._extractExternalRoomsData(s.rooms?.rooms,s.rooms?.roomId);if(E.onCallAccepted(),E.onLocalStream(this._mediaSource.getStream(),t),E.onConversation(this._conversation.externalId,this._conversation.mediaModifiers,this._getMuteStatesForCurrentRoom(),await this._getMainRoomParticipants(),o),l.useParticipantListChunk){let u=await this._getInitialParticiapntListChunk(),p=await this._getParticipants();u?.participants?.forEach(m=>{let h=I.composeId(m),R=p[h];R&&(R.movieShareInfos=m.movieShareInfos)}),await this._onConversationParticipantListChunk({participants:u})}return E.onLocalStatus("WAITING"),this._toggleJoinAvailability(),this._changeNeedRate(),this._state="ACTIVE",this._changeFeatureSet(),this._openTransport(Object.values(await this._getParticipants()),!0),await this._processConversationUrlSharingInfo(),await this._processConnectionAsrInfo(),this._conversation}catch(t){throw this._close(t,"Unable to accept call"),t}}async decline(){if(this._state!=="IDLE")throw P.log(T.ERROR,"declineIncoming"),d.error("Unable to decline a call - invalid state"),new Error("Unable to decline a call - invalid state");this._state="PROCESSING",d.debug("Decline incoming call"),this._logWithMediaSettings(T.DECLINE_INCOMING,this._mediaSource?.getMediaSettings()),this._participantState=J.HUNGUP,this._signaling.ready&&await this._signaling.hangup(w.REJECTED),this._close(new G(w.REJECTED))}async hangup(){d.debug("Hangup");let e=this._state==="ACTIVE"?w.HUNGUP:w.CANCELED;P.log(T.HANGUP,e),this._signaling.ready?(await this._signaling.hangup(e),this._close(new G(e))):E.onHangup(new G(w.HUNGUP),this._conversation&&this._conversation.id)}async addParticipant(e,t){if(!this._signaling.ready){this._close(new G(w.UNKNOWN_ERROR),"Unable to add participant");return}let i=await this._signaling.addParticipant(e.map(q.toSignaling),t),a=null;i.type==="error"&&(i.error==="call-unfeasible"?a=i.status:a=w.UNKNOWN_ERROR);let s=i.participants;for(let o of s)await this._onAddParticipant(I.composeId(o),o,a)}async addParticipantLegacy(e,t){if(!this._signaling.ready){this._close(new G(w.UNKNOWN_ERROR),"Unable to add participant");return}let i=await this._signaling.addParticipantLegacy(e,t),a=null;i.type==="error"&&(i.error==="call-unfeasible"?a=i.status:a=w.UNKNOWN_ERROR);let s=i.participants;for(let o of s)await this._onAddParticipant(I.composeId(o),o,a)}async removeParticipant(e,t=!1){this._signaling.ready&&(await this._signaling.removeParticipant(e,t),this._onRemoveParticipant(e))}setVolume(e){this._audioOutput.volume=e}updateStatisticsInterval(){this._transport&&this._transport.updateStatisticsInterval()}_openTransport(e,t){if(!this._transport)return;let i=[];for(let a of e)(a.state===J.CALLED||a.state===J.ACCEPTED)&&(this._transport.isAllocated(a.id)||this._transport.allocate(a.id,t)),a.state===J.ACCEPTED&&i.push(a.id);i.length&&this._transport.open(i,null,!!this._conversation?.observer)}async _close(e,t){t&&d.error(t,e),d.debug("Close conversation",e),Tr.sendHangupEvent(e,this._transport?.getTopology()),et.destroy(),this._signaling.readyToSend(!1),e.error?this._signaling.ready&&this._signaling.hangup(w.FAILED):P.log(T.ERROR,e.hangup),$._activationMutex=!1;let i=this._conversation&&this._conversation.id;if([w.CANCELED,w.NOT_FRIENDS,w.CALLEE_IS_OFFLINE,w.CALLER_IS_BLOCKED,w.CALLER_IS_REJECTED].indexOf(e.hangup)!==-1||e.hangup===w.REJECTED&&!e.remote){E.onHangup(e,i),this.destroy();return}if(e.hangup===w.HUNGUP&&(!e.remote||this._isCalledState())){E.onHangup(e,i),this.destroy();return}if(e.hangup===w.MISSED&&!e.remote){E.onHangup(e,i),this.destroy();return}if(this._cooldownQueueCleanupTimer!==null&&(window.clearInterval(this._cooldownQueueCleanupTimer),this._cooldownQueueCleanupTimer=null),(e.hangup===w.SOCKET_CLOSED||e.hangup===w.NOT_FOUND)&&$._current&&!this._conversation){this._cleanupSignaling(),this._cleanupMediaSource();return}if(e.hangup===w.BUSY&&!e.remote){this._cleanupSignaling(),this._cleanupMediaSource();return}this._state="CLOSE",this._participantState=J.HUNGUP,this._changeFeatureSet(),this._cleanupMediaSource(),await this._cleanupParticipants(),this._cleanupParticipantAgnosticStreams(),this._cleanupTransport(),this._cleanupSpeakerDetector(),this._cleanupSpecListener(),this._cleanupSignaling(),this._api.cleanup(),P.destroy(),Ce.destroy(),this._conversation=null,this._myLastRequestedLayouts={},$._current=null,$._delayedHangup=!1,E.onHangup(e||new G(w.UNKNOWN_ERROR),i)}async destroy(){let e=this._conversation&&this._conversation.id;d.debug("Destroy conversation",{conversationId:e}),this._cooldownQueueCleanupTimer!==null&&(window.clearInterval(this._cooldownQueueCleanupTimer),this._cooldownQueueCleanupTimer=null),this._state="CLOSE",this._participantState=J.HUNGUP,this._cleanupMediaSource(),await this._cleanupParticipants(),this._cleanupParticipantAgnosticStreams(),this._cleanupTransport(),this._cleanupSpeakerDetector(),this._cleanupSpecListener(),this._cleanupSignaling(),this._api.cleanup(),this._cleanupListeners(),P.destroy(),Ce.destroy(),this._conversation=null,this._myLastRequestedLayouts={},$._current=null,$._delayedHangup=!1}async _getConversationParams(e){let t=await this._api.getConversationParams(e);d.debug("Api.getConversationParams",t);let i=[],{turn_server:a,stun_server:s}=t;if(s&&i.push(s),a&&a.urls){let o=a.urls.filter((u,p,m)=>m.indexOf(u)===p);o.push(`${o[o.length-1]}?transport=tcp`),i.push({urls:o,username:a.username,credential:a.credential})}return l.iceServers=i,l.wssBase=t.endpoint,t.wt_endpoint&&(l.wtsBase=t.wt_endpoint),l.wssToken=t.token,t.client_type&&(l.clientType=t.client_type),t.external_user_type&&(l.externalUserType=t.external_user_type),t}_setConversationParams({turn_server:e,stun_server:t,endpoint:i,wt_endpoint:a,token:s,client_type:o}){let u=[];if(t&&u.push(t),e&&e.urls){let p=e.urls.filter((m,h,R)=>R.indexOf(m)===h);p.push(`${p[p.length-1]}?transport=tcp`),u.push({urls:p,username:e.username,credential:e.credential})}l.iceServers=u,l.wssBase=i,l.wssToken=s,a&&(l.wtsBase=a),o&&(l.clientType=o)}_addGeoParamsToEndpoint(e,t){return t.isp_as_no&&(e+=`&ispAsNo=${t.isp_as_no}`),t.isp_as_org&&(e+=`&ispAsOrg=${t.isp_as_org}`),t.loc_cc&&(e+=`&locCc=${t.loc_cc}`),t.loc_reg&&(e+=`&locReg=${t.loc_reg}`),e}async _startConversation({opponentIds:e,opponentType:t,direction:i,mediaOptions:a,payload:s="",joiningAllowed:o=!1,requireAuthToJoin:u=!1,onlyAdminCanShareMovie:p,externalIds:m,startedTime:h,onFastStart:R}){le.setMark(T.SIGNALING_CONNECTED);let M=I.uuid();d.debug("Conversation: start",{conversationId:M,opponentIds:e,opponentType:t,direction:i});let k=a.includes(se.VIDEO),H;if(R)try{let ae={deviceId:this._api.deviceId(),sdkVersion:l.sdkVersion,clientAppKey:l.apiKey,platform:l.platform,protocolVersion:l.protocolVersion,domainId:l.domain},ve=JSON.stringify(ae),ye=await R({internalParams:ve,conversationId:M,externalIds:m,opponentType:t,mediaOptions:a,isVideo:k,joiningAllowed:o,requireAuthToJoin:u}),X=JSON.parse(ye.internalCallerParams);H={endpoint:X.endpoint,wt_endpoint:X.wtEndpoint,id:M,is_concurrent:X.isConcurrent,client_type:X.clientType,rejected_participants:ye.rejectedParticipants,stun_server:X.stun,turn_server:X.turn,token:new URL(X.endpoint).searchParams.get("token")??""},d.debug("FastStart",H)}catch{throw new G(w.UNKNOWN_ERROR,{message:"Cannot parse internal params"})}else H=await this._api.startConversation(M,e,t,k,s,o,u,{onlyAdminCanShareMovie:p},m),d.debug("Api.startConversation",H);this._setConversationParams(H);let z=await this._connectSignaling(Fe.START,H);return await this._setConversation(H,z,i),this._logCallStartEvent(h,De.OUTGOING),z}async _joinConversation(e,t){le.setMark(T.SIGNALING_CONNECTED);let{conversationId:i,mediaOptions:a,chatId:s,joinLink:o,observedIds:u,payload:p}=e;d.debug("Conversation: join",{conversationId:i,joinLink:o,observedIds:u});let m=a.includes(se.VIDEO),h;if(i)h=await this._api.joinConversation(i,m,s);else if(o)h=await this._api.joinConversationByLink(o,m,u,p);else throw new G(w.UNKNOWN_ERROR);d.debug("Api.joinConversation",h),this._setConversationParams(h);let R=await this._connectSignaling(Fe.JOIN,h);return await this._setConversation(h,R,De.JOINING),this._logCallStartEvent(t,De.JOINING),R}async _prepareConversation(e,t=te.USER,i,a,s){le.setMark(T.SIGNALING_CONNECTED),d.debug("Conversation: push",{conversationId:e,type:t,peerId:i});let o=this._api.getUserId();if(!o)throw new G(w.UNKNOWN_ERROR);let u=0,p="",m="",h={id:e,peerId:i,endpoint:p,wt_endpoint:m,is_concurrent:!1,p2p_forbidden:!1,device_idx:0,token:""};if(a){let M=this._decodeExternalConversationParams(a);this._setConversationParams(M),p=s??`${l.wssBase}?userId=${o}&entityType=${t}&deviceIdx=${u}&conversationId=${e}&token=${l.wssToken}`,h.token=M.token,h.endpoint=p,l.wtsBase&&(m=`${l.wtsBase}?userId=${o}&entityType=${t}&deviceIdx=${u}&conversationId=${e}&token=${l.wssToken}`,h.wt_endpoint=m)}else{let M=await this._getConversationParams(e);u=M.device_idx||0,p=s??`${l.wssBase}?userId=${o}&entityType=${t}&deviceIdx=${u}&conversationId=${e}&token=${l.wssToken}`,p=this._addGeoParamsToEndpoint(p,M),h.token=M.token,h.endpoint=p,h.device_idx=u,l.wtsBase&&(m=`${l.wtsBase}?userId=${o}&entityType=${t}&deviceIdx=${u}&conversationId=${e}&token=${l.wssToken}`,m=this._addGeoParamsToEndpoint(m,M),h.wt_endpoint=m)}let R=await this._connectSignaling(Fe.ACCEPT,h);return $._current&&($._current._participantState===J.ACCEPTED||$._current._participantState===J.CALLED)?(d.log("Push rejected (busy)"),P.log(T.PUSH,"busy"),this._signaling.ready&&this._signaling.hangup(w.BUSY),Promise.reject(new G(w.BUSY))):($._current&&($._current.destroy(),$._current=null),await this._setConversation(h,R,De.INCOMING,t),R)}async _createParticipant(e,t){let i=Object.assign({id:null,externalId:null,mediaSettings:Ee(),participantState:{},state:J.CALLED,status:null,remoteStream:null,mediaSource:null,platform:null,clientType:null,roles:[],networkRating:1,lastRequestedLayouts:{},muteStates:{},unmuteOptions:[],observedIds:[],isInRoom:!1,markers:null},e);return i.externalId||(i.externalId=await this._getParticipantId(t??i.id)),this._api.cacheExternalId(t??i.id,i.externalId),t&&this._api.mapDecorativeId(t,i.id),i.observedIds?.length&&(i.externalId.observer=!0),e.markers&&(i.markers=this._denormalizeMarkers(i.id,e.markers)),i}async _getParticipantId(e){try{return await this._api.userId(e)}catch(t){throw this._close(new G(w.NETWORK_ERROR),t),t}}async _setConversation(e,t,i,a=te.USER){let{participants:s}=t.conversation;s.forEach(m=>{let h=I.composeId(m),R=q.fromSignalingParticipant(m,!1);if(R){this._api.cacheExternalId(h,R);let M=I.composeDecorativeId(m),k=q.fromSignalingParticipant(m);M&&k&&(this._api.cacheExternalId(M,k),this._api.mapDecorativeId(m.decorativeUserId,m.id))}});let o=this._api.getUserId(),u=e.device_idx||0;if(!o){let m=(t.conversation.participants||[]).find(h=>I.comparePeerId(h.peerId,t.peerId));if(!m)throw new G(w.UNKNOWN_ERROR);o=Number(m.id),m.idType&&(a=m.idType),m.deviceIdx&&(u=m.deviceIdx),this._api.setUserId(o)}let p=I.composeParticipantId(o,a,u);this._conversation={userId:o,compositeUserId:p,externalId:await this._getExternalIdByParticipantId(p),acceptTime:t.conversation.acceptTime,features:t.conversation.features||[],featuresPerRole:t.conversation.featuresPerRole,id:t.conversation.id||e.id,participantsLimit:t.conversation.participantsLimit||30,topology:t.conversation.topology||"DIRECT",direction:i,concurrent:t.isConcurrent||e.is_concurrent||!1,needRate:!1,chatId:t.conversation.multichatId,roles:[],recordsInfoByRoom:new Map,asrInfoByRoom:new Map,muteStates:new Map,muteStatesPersonal:{},joinLink:e.join_link??t.conversation.joinLink,pinnedParticipantIdByRoom:new Map,mediaModifiers:t.mediaModifiers,options:[],networkRating:1,waitingHall:this._isInWaitingHall(t),observer:!1,asrInfo:t.conversation.asrInfo||null,roomId:t.rooms?.roomId||null,audienceMode:this._isAudienceMode(t),restricted:this._isRestricted(t),urlSharingInfoByRoom:new Map},ke.conversationId=t.conversation.id||e.id,this._signaling.setConversationId(this._conversation.id),e.p2p_forbidden&&(l.forceRelayPolicy=e.p2p_forbidden),P.log(T.RELAY_POLICY,l.forceRelayPolicy?"1":"0"),this._changeFeatureSet(),this._logDevices()}_updateConversation(e){if(!this._conversation)throw new G(w.UNKNOWN_ERROR);this._conversation.acceptTime=e.conversation.acceptTime,this._conversation.features=e.conversation.features||[],this._conversation.featuresPerRole=e.conversation.featuresPerRole,this._conversation.participantsLimit=e.conversation.participantsLimit||30,this._conversation.topology=e.conversation.topology||"DIRECT",this._conversation.concurrent=e.isConcurrent||!1,this._conversation.chatId=e.conversation.multichatId,this._conversation.mediaModifiers=e.mediaModifiers,this._conversation.waitingHall=!1}_createMediaSource(){let e=new Bi;return this.subscribe(e,"SOURCE_CHANGED",this._onLocalMediaStreamChanged.bind(this)),this.subscribe(e,"SCREEN_STATUS",this._onScreenSharingStatus.bind(this)),this._audioFix=new Jt(e),e}async _connectSignaling(e,t){this._signaling.setEndpoint(t.endpoint),this._signaling.setWebTransportEndpoint(t.wt_endpoint??null),this.subscribe(this._signaling,Pe.NOTIFICATION,a=>this._signalingActor.add(a)),this.subscribe(this._signaling,Pe.FAILED,this._onSignalingFailed.bind(this)),this.subscribe(this._signaling,Pe.RECONNECT,this._onSignalingReconnect.bind(this));let i=await this._signaling.connect(e,t);return Ce.logEventualStat({name:T.SIGNALING_CONNECTED}),i}async _processConnection(e){await this._registerConnectionParticipants(e),this._processRooms(e),this._processMuteStates(e),this._processRecordInfos(e),this._onOptionsChanged(e.conversation.options),e.chatRoom&&e.chatRoom.totalCount&&this._onChatRoomUpdated(dr.ATTENDEE,e.chatRoom.totalCount,e.chatRoom.firstParticipants,null,null)}async _onConversationParticipantListChunk(e){let t=e.participants;t&&E.onConversationParticipantListChunk(await this._participantListChunkToExternalChunk(this._createParticipantListChunk(t)))}_createParticipantListChunk(e){return{...{participants:[],countBefore:0,countAfter:0,markerFound:!1},...e}}async _participantListChunkToExternalChunk(e){let t=await this._getParticipants(),i=I.mapSharedParticipants(e.participants.reduce((a,s)=>{let o=I.composeId(s);return t[o]&&a.push(t[o]),a},[]));return{...e,participants:i}}async _registerConnectionParticipants(e){await this._registerParticipants(e.conversation.participants),e.participants?.participants&&await this._registerParticipants(e.participants?.participants);let t=e?.rooms?.rooms??[];for(let i of t)await this._registerParticipants(i?.participants?.participants??[],!0)}async _registerParticipants(e,t=!1){if(!this._conversation)return;let i=e[0]?.externalId?.type;i&&(l.externalUserType=i);let a=await this._getParticipants();for(let s of e){let o=I.composeId(s);if(d.test("Conversation:RegisterParticipant",o),this._isMe(o)){this._conversation.roles=s.roles||[],this._conversation.roles.length&&(d.debug(`Local roles changed: ${s.roles}`),E.onLocalRolesChanged(this._conversation.roles,!0)),this._registerParticipantLocalMuteState(s);continue}if(s.state===J.HUNGUP||s.state===J.REJECTED){a[s.id]&&await this._removeParticipant(a[s.id],w.HUNGUP);continue}let u=I.composeDecorativeId(s);this._registerParticipant({id:o,externalId:q.fromSignalingParticipant(s),mediaSettings:Ee(s.mediaSettings),participantState:I.mapParticipantState(s),state:s.state,roles:s.roles||[],status:"WAITING",muteStates:s.muteStates||{},unmuteOptions:s.unmuteOptions||[],observedIds:s.observedIds||[],markers:this._denormalizeMarkers(o,s.markers),movieShareInfos:s.movieShareInfos,isInRoom:t},u);let p=await this._getParticipant(o);p&&s.roles&&s.roles.length&&(d.debug(`Roles for participant [${o}] changed: ${s.roles}`),E.onRolesChanged(p.externalId,s.roles,!0))}}_registerParticipantLocalMuteState({muteStates:e,unmuteOptions:t}){if(!e)return;let i=async()=>{let a=mr(e,Ne.MUTE),s=mr(e,Ne.MUTE_PERMANENT);for(let o of[a,s])o.length&&await this._onMuteParticipant({muteStates:e,unmuteOptions:t,mediaOptions:o,stateUpdated:!0})};I.setImmediate(()=>i().catch(a=>d.error(a)))}_getStatusByTransportState(e){let t=null;return e==="CONNECTED"?t="CONNECTED":e==="CONNECTING"||e==="OPENED"?t="CONNECTING":e==="RECONNECTING"&&(t="RECONNECT"),t}_registerParticipantInCache(e){return this._participants[e.id]=e,e}async _getExistedParticipantByIdOrCreate(e){let i=(await this._getParticipants())[e];if(i)return i;let a=this._api.getDecorativeIdByInitialId(I.decomposeId(e).id),s=a?I.composeUserId(a):void 0;return this._createParticipant({id:e},s)}async _getExternalIdByParticipantId(e){if(this._isMe(e))return this._conversation?.externalId;if(l.useParticipantListChunk)return(await this._getExistedParticipantByIdOrCreate(e)).externalId;let t=await this._getParticipants();if(t[e]?.externalId)return t[e].externalId;{let i=await this._getParticipantId(e);return this._api.cacheExternalId(e,i),i}}async _registerParticipantAndSetMarkersIfChunkEnabled(e,t){if(l.useParticipantListChunk){let a=this._registerParticipantInCache(await this._getExistedParticipantByIdOrCreate(e));return a.markers=this._denormalizeMarkers(a.id,t),a}return(await this._getParticipants())[e]}_warnParticipantNotInConversation(e){d.warn(`Participant [${e}] isn't in conversation`)}_denormalizeMarkers(e,t){if(!t)return null;let i=Object.values(t).find(a=>"ts"in a&&"rank"in a);return Object.entries(t).reduce((a,[s,o])=>(a[s]={...i,...o,id:e},a),{})}_processRooms(e){let t=e.rooms?.roomId??null;this._onRoomSwitched(t,!0)}_processMuteStates(e,t=!1){let i=kn(e);this._setMuteStatesForRoomId(i,null);for(let u of e.rooms?.rooms??[])this._setMuteStatesForRoomId(u.muteStates,u.id);let a=this._getMuteStatesForCurrentRoom();t&&(a=Nn(e,a));let s=Object.keys(a),o=this._conversation?.roomId;s.length&&this._onMuteParticipant({muteStates:a,mediaOptions:s,muteAll:!0,stateUpdated:!0,roomId:o},t)}_processRecordInfos(e){this._onRecordInfo(e.conversation?.recordInfo??null);for(let t of e.rooms?.rooms??[])this._onRecordInfo(t.recordInfo??null,t.id)}async _processPinnedParticipants(e){e.conversation.pinnedParticipantId?await this._onPinParticipant(e.conversation.pinnedParticipantId):this._conversation?.pinnedParticipantIdByRoom.delete(null);for(let t of e.rooms?.rooms??[])t.pinnedParticipantId?await this._onPinParticipant(t.pinnedParticipantId,!1,void 0,t.id):this._conversation?.pinnedParticipantIdByRoom.delete(t.id)}async _allocateTransport(){if(!this._conversation||!this._mediaSource)return;this._transport=new vr(this._conversation.topology,this._signaling,this._mediaSource,this._serverSettings),this._debugInfo=new fi,this.subscribe(this._transport,"STATE_CHANGED",this._onTransportStateChanged.bind(this)),this.subscribe(this._transport,"LOCAL_STATE_CHANGED",this._onTransportLocalStateChanged.bind(this)),this.subscribe(this._transport,"REMOTE_TRACK_ADDED",this._onRemoteTrackAdded.bind(this)),this.subscribe(this._transport,"REMOTE_TRACK_REMOVED",this._onRemoteTrackRemoved.bind(this)),this.subscribe(this._transport,"AUDIO_MIX_STALL",this._onAudioMixStall.bind(this)),this.subscribe(this._transport,"REMOTE_DATA_STATS",this._onRemoteDataStats.bind(this)),this.subscribe(this._transport,"SIGNALLED_STALLED_PARTICIPANTS",this._onRemoteSignalledStall.bind(this)),this.subscribe(this._transport,"TOPOLOGY_CHANGED",this._onTopologyChanged.bind(this)),this.subscribe(this._transport,"NETWORK_STATUS",this._onNetworkStatus.bind(this)),this.subscribe(this._transport,"REMOTE_STREAM_SECOND",this._onRemoteStreamSecond.bind(this)),this.subscribe(this._transport,"PEER_CONNECTION_CLOSED",this._onPeerConnectionClosed.bind(this)),this.subscribe(this._transport,"ASR_TRANSCRIPTION",this._onAsrTranscription.bind(this)),this.subscribe(this._transport,"ANIMOJI_STREAM",this._onAnimojiStream.bind(this)),this.subscribe(this._transport,"ANIMOJI_ERROR",this._onAnimojiError.bind(this));let e=this._conversation.direction===De.OUTGOING&&!this._conversation.concurrent,t=await this._getParticipants();for(let i of Object.values(t))(i.state===J.ACCEPTED||i.state===J.CALLED)&&this._transport.allocate(i.id,e)}_createSpeakerDetector(){this._transport&&this._conversation&&(this._volumesDetector=new Ir(this._transport),this.subscribe(this._volumesDetector,"VOLUMES_DETECTED",this._onVolumesDetected.bind(this)),this._speakerDetector=new Er(this._volumesDetector,this._transport,this._conversation.topology),this.subscribe(this._speakerDetector,"SPEAKER_CHANGED",this._onSpeakerChanged.bind(this)),this._localVolumeDetector=new Si(this._mediaSource))}async _createSpecListener(){this._transport&&this._volumesDetector&&(this._specListener=new Ci(this._transport,this._volumesDetector,await this._getParticipants()))}_logDevices(){let e=b.getCameras().length,t=b.getMicrophones().length;d.debug("Cameras: "+e+(b.hasCameraPermission()?"✔":"✖")+", Microphones: "+t+(b.hasMicrophonePermission()?"✔":"✖")),P.log(T.DEVICES,`${e}_${t}`)}_logWithMediaSettings(e,t){P.log(e,[t?.isAudioEnabled&&"audio",t?.isVideoEnabled&&"video"].filter(Boolean).join("_"))}async _removeParticipant(e,t){if(e.state===J.CALLED||e.state===J.ACCEPTED||this._state==="CLOSE")return;e.id===this._lastSignalledActiveSpeakerId&&(this._lastSignalledActiveSpeakerId=null);let i=await this._getParticipants();if(i[e.id]){t===w.HUNGUP?this._setParticipantsStatus([e],"HANGUP"):this._setParticipantsStatus([e],"ERROR",t),e.mediaSource?.disconnect(),this._conversation&&this._conversation.pinnedParticipantIdByRoom.get(null)===e.id&&this._conversation.pinnedParticipantIdByRoom.delete(null),this._conversation&&this._conversation.roomId&&this._conversation.pinnedParticipantIdByRoom.get(this._conversation.roomId)===e.id&&this._conversation.pinnedParticipantIdByRoom.delete(this._conversation.roomId);for(let[a,s]of Object.entries(e.lastRequestedLayouts))this._streamIdByStreamDescription.delete(a),this._sequenceNumberByStreamDescription.delete(a),this._cooldownTimestampByStreamDescription.delete(a),this._streamWaitTimerByStreamDescription.has(a)&&(window.clearTimeout(this._streamWaitTimerByStreamDescription.get(a)),this._streamWaitTimerByStreamDescription.delete(a)),this._sendUpdateDisplayLayout({[a]:{stopStream:!0}});this._api.unmapDecorativeId(e.id),delete i[e.id],E.onRemoteRemoved(e.externalId,e.markers)}}_cleanupListeners(){this.unsubscribe(),window.removeEventListener("unload",this._onUnload)}_cleanupMediaSource(){this._mediaSource&&(this._mediaSource.destroy(),this._mediaSource=null)}async _cleanupParticipants(){Object.values(await this._getParticipants()).forEach(e=>{e.remoteStream?.getTracks().forEach(t=>t.stop()),e.remoteAudioTrack?.stop(),e.secondStream?.getTracks().forEach(t=>t.stop()),e.mediaSource?.disconnect()}),this._participants={},this._audioOutput&&this._audioOutput.destroy()}_cleanupParticipantAgnosticStreams(){d.debug("cleaning up participant-agnostic streams"),this._streamByStreamId.forEach(e=>{e.getTracks().forEach(t=>{t.stop()})}),this._streamByStreamId=new Map,this._streamWaitTimerByStreamDescription.forEach(e=>{window.clearTimeout(e)}),this._streamWaitTimerByStreamDescription=new Map,this._streamIdByStreamDescription=new Map,this._sequenceNumberByStreamDescription=new Map,this._cooldownTimestampByStreamDescription=new Map}_cleanupTransport(){this._transport&&(this._transport.destroy(),this._transport=null),this._debugInfo&&(this._debugInfo=null)}_cleanupSpeakerDetector(){this._speakerDetector&&(this._speakerDetector.destroy(),this._speakerDetector=null),this._volumesDetector&&(this._volumesDetector.destroy(),this._volumesDetector=null),this._localVolumeDetector&&(this._localVolumeDetector.destroy(),this._localVolumeDetector=null)}_cleanupSpecListener(){this._specListener&&(this._specListener.destroy(),this._specListener=null)}_cleanupSignaling(){this._signaling.close(),this._signaling.cleanup()}async _onAddParticipant(e,t,i){d.debug(`Add new participant [${e}]`);let a=await this._getParticipant(e);if(a&&(a.state===J.ACCEPTED||a.state===J.CALLED)){d.warn(`Participant [${a.id}:${a.state}] is already in conversation`);return}if(!a){let s=I.composeDecorativeId(t);this._registerParticipant({id:e,externalId:q.fromSignalingParticipant(t),mediaSettings:Ee(t.mediaSettings),state:t.state,roles:t.roles||[],muteStates:t.muteStates||{},unmuteOptions:t.unmuteOptions||[],observedIds:t.observedIds||[]},s),a=await this._getParticipant(e)}this._setParticipantsStatus([a],"WAITING"),i?(a.state=J.HUNGUP,await this._removeParticipant(a,i)):this._transport&&(a.state=J.CALLED,this._transport.allocate(a.id,!0),P.log(T.ADD_PARTICIPANT),this._invokeRolesChangedCallbackIfNeeded(a))}async _onRemoveParticipant(e){d.debug(`Remove participant [${e}]`);let t=[],i=await this._getParticipants();for(let a=0;a<=qo;a++){let s=I.compose(e,a),o=i[s];o&&t.push(o)}if(!t.length){this._warnParticipantNotInConversation(e);return}if(this._transport)for(let a of t)this._transport.close(a.id);P.log(T.REMOVE_PARTICIPANT)}async changeDevice(e){return e==="audiooutput"?this._audioOutput.changeOutput():this._mediaSource?this._mediaSource.changeDevice(e):Promise.reject(ie.UNKNOWN)}stopVideoTrack(){return this._mediaSource?.stopVideoTrack()}async toggleScreenCapturing(e){return this._mediaSource?this._mediaSource.toggleScreenCapturing(e):Promise.reject(ie.UNKNOWN)}async disableScreenCapturing(){return this._mediaSource?this._mediaSource.disableScreenCapturing():Promise.reject(ie.UNKNOWN)}toggleAnimojiCapturing(e){this._mediaSource&&this._mediaSource.toggleAnimojiCapturing(e)}setAnimojiSvg(e,t=null,i=null){if(!this._transport||!this._conversation)return;let a=!t,s=t??this._conversation.compositeUserId;if(e instanceof ArrayBuffer){let o=i??this._conversation.externalId.id;this._transport.setAnimojiSvg(s,{svg:e,userId:o,isMe:a});return}this._transport.setAnimojiSvg(s,{svg:e,isMe:a})}setAnimojiFill(e){this._transport?.setAnimojiFill(e)}async setVideoStream(e,t=!1){if(this._mediaSource)return this._mediaSource.setVideoStream(e,t)}async setAudioStream(e){if(this._mediaSource)return this._mediaSource.setAudioStream(e)}async toggleLocalVideo(e){if(this._mediaSource)return P.log(T.MEDIA_STATUS,e?"video_1":"video_0"),this._mediaSource.toggleVideo(e)}async toggleLocalAudio(e){if(this._mediaSource)return P.log(T.MEDIA_STATUS,e?"audio_1":"audio_0"),this._mediaSource.toggleAudio(e)}async changePriorities(e){if(e.length<2||!this._signaling.ready)return;let t={},i={};for(let s of e){let o=typeof s.uid=="object"?s.uid:q.fromId(s.uid),u=q.toString(o);i[u]=s.priority}let a=await this._getParticipants();for(let s of Object.values(a)){let o=q.toString(s.externalId);i.hasOwnProperty(o)&&(t[s.id]=i[o])}await this._signaling.changePriorities(t)}async changeParticipantState(e,t){for(let[i,a]of Object.entries(e))if(i.length>5||a.length>5)throw new Error("key/value max length is 5 chars, mappings with empty values (null or empty string) are discarded");t&&!this._isCallAdmin()&&(t=void 0),await this._signaling.changeParticipantState(e,t)}async putHandsDown(){this._checkAdminRole(),await this._signaling.putHandsDown()}async requestKeyFrame(e){let t={};return t[Qe(e)]={keyFrameRequested:!0},this._signaling.updateDisplayLayout(t)}async requestTestMode(e,t){return this._signaling.requestTestMode(e,t)}async updateDisplayLayout(e){if(e.length<1||!this._signaling.ready||this._transport?.getTopology()!=="SERVER")return;d.log(`Update display layout request [${this._signaling.getNextCommandSequenceNumber()}]`,e);let t={},i=await this._getParticipants();for(let s of e){let o=typeof s.uid=="object"?s.uid:q.fromId(s.uid),u=this._api.getCachedOkIdByExternalId(o);if(!u){let h=q.toString(o);d.log(`Unknown participant external ID ${h}`);continue}let p=Qe({participantId:u,mediaType:s.mediaType,streamName:s.streamName}),m=i[u];m?m.lastRequestedLayouts[p]=s:this._isMe(u)&&(this._myLastRequestedLayouts[p]=s),Kt(s)?(this._isMe(u)&&delete this._myLastRequestedLayouts[p],this._streamIdByStreamDescription.has(p)&&!this._cooldownTimestampByStreamDescription.has(p)&&this._cooldownTimestampByStreamDescription.set(p,Date.now())):(this._cooldownTimestampByStreamDescription.delete(p),!this._streamIdByStreamDescription.has(p)&&l.videoTracksCount>0&&this._streamIdByStreamDescription.set(p,null),t[p]=s),s.mediaType==="SCREEN"&&!Kt(s)&&le.setMark(le.getMarkNameScreenshareFirstFrame(u))}let a=this._cooldownTimestampByStreamDescription.keys();for(;this._streamIdByStreamDescription.size>l.videoTracksCount;){let s=a.next();if(s.done){d.error("Cannot accommodate all streaming requests: tracks available "+l.videoTracksCount+"; requested streams: "+Array.from(this._streamIdByStreamDescription.keys()));break}await this._stopStreaming(s.value),t[s.value]={stopStream:!0}}await this._sendUpdateDisplayLayout(t)}async feedback(e){return this._signaling.feedback(e)}userFeedbackStats(e,t,i){if(this._conversation)if(!l.clientEventsLoggingEnabled)this._api.sendUserFeedbackStats(this._conversation.id,e,t,i);else{let a={event_type:T.USER_FEEDBACK_RECEIVED,user_response:e};t!==void 0&&(a.reason=t),i!==void 0&&(a.group_call_users_count=i),P.logClientEvent(a,!0)}}sendClientEvent(e,t={},i=!1){let a={event_type:e,...t};P.logClientEvent(a,i)}async _stopStreaming(e){if(this._cooldownTimestampByStreamDescription.delete(e),this._sequenceNumberByStreamDescription.set(e,this._signaling.getNextCommandSequenceNumber()),this._streamWaitTimerByStreamDescription.has(e)&&(d.log("Client asked to stop streaming before stream became available",e),window.clearTimeout(this._streamWaitTimerByStreamDescription.get(e)),this._streamWaitTimerByStreamDescription.delete(e)),this._streamIdByStreamDescription.get(e)){let i=await this._getParticipants(),a=hi(e),s=i[a.participantId],o=this._conversation?.externalId,u=this._isMe(a.participantId);if(s||u){switch(a.mediaType){case"STREAM":case"MOVIE":{if(a.streamName){let p={stream:null,streamName:a.streamName,mediaType:a.mediaType};u?E.onLocalLive(o,p):E.onRemoteLive(s.externalId,p)}break}case"CAMERA":{E.onRemoteStream(s.externalId,null);break}case"SCREEN":{E.onRemoteScreenStream(s.externalId,null);break}}P.log(T.PAT_DEALLOCATED)}else d.log(`Cannot find participant to stop streaming: ${a.participantId}`)}this._streamIdByStreamDescription.delete(e)}async _sendUpdateDisplayLayout(e){if(Object.keys(e).length===0)return;d.log(`Update display layout send [${this._signaling.getNextCommandSequenceNumber()}]`,e);let t=await this._signaling.updateDisplayLayout(e);if(!t)return;let i=[],a=await this._getParticipants();for(let[s,o]of Object.entries(t.errorCodeByParticipantId||{})){let u=hi(s),p=a[u.participantId];if(p){let m;typeof o!="number"?(d.warn(`Unexpected error code ${o} received for participant ${u.participantId}`),m=yn.UNKNOWN_ERROR):m=bn(o),i.push({externalId:p.externalId,errorReason:m})}}if(i&&i.length)throw new oa("Could not allocate one or more participants",i)}async _cleanupCooldownQueue(){let e={},t=this._cooldownTimestampByStreamDescription.entries();do{let i=t.next();if(i.done)break;let a=i.value;if(a[1]+$o>Date.now())break;let o=a[0];await this._stopStreaming(o),e[o]={stopStream:!0}}while(!0);this._sendUpdateDisplayLayout(e)}_onParticipantSourcesUpdate(e){if(this._conversation){let t=e.participantUpdateInfos;d.log("Received participant sources update notification",t);for(let i of t)this._waitForStreamIfNeeded(i)}}async _onParticipantPromoted(e){this._conversation&&this._conversation.audienceMode?(d.log("Promoted in audience mode",!e.demote),this._conversation.restricted=e.demote,this._processRecordInfos(e),!e.demote&&this._mediaSource&&this._changeMediaSettings(this._mediaSource.getMediaSettings())):(d.log("Promoted in waiting hall",!e.demote),e.demote?(d.log("Kicked from waiting hall"),this._close(new G(w.REMOVED))):(this._updateConversation(e),await this._onJoinPart2(e))),E.onPromoted(e.demote)}async _onChatRoomUpdated(e,t=0,i=[],a,s){d.log(`Chat room updated: ${e}`);let o=[],u=[],p=[],m=[],h=[];if(i.length&&i.forEach(k=>{if(k.externalId){let H=q.fromSignaling(k.externalId);h.push(H),this._api.cacheExternalId(k.id.id,H)}else{let H=I.decomposeId(k.id.id).id;o.push(H),m.push(H)}}),a?.length&&a.forEach(k=>{let H=I.decomposeId(k).id;o.push(H),u.push(H)}),s?.length&&s.forEach(k=>{let H=I.decomposeId(k).id;o.push(H),p.push(H)}),!o.length){E.onChatRoomUpdated(e,t,h,[],[]);return}if(m.length){let k=await this._api.getExternalIdsByOkIds(m);h.push(...k)}let R=await this._api.getExternalIdsByOkIds(u),M=await this._api.getExternalIdsByOkIds(p);E.onChatRoomUpdated(e,t,h,R,M)}async _onSharedMovieUpdate(e){let t=this._conversation?.externalId;for(let i of e.data)if(this._isMe(i.participantId))E.onLocalLiveUpdate(t,i);else{let s=await this._getExternalIdByParticipantId(i.participantId);s&&E.onRemoteLiveUpdate(s,i)}}async _onSharedMovieInfoStarted(e){d.log(`Shared movie started data received: ${e.notification}`),await this._processSharedMovieInfo(e.movieShareInfo,e.roomId)}async _processSharedMovieInfos(e,t=null){e&&await Promise.all(e.map(i=>this._processSharedMovieInfo(i,t)))}async _processSharedMovieInfo(e,t=null){if(!e)return;let i=this._conversation?.externalId;if(this._isMe(e.initiatorId))E.onLocalSharedMovieInfo(i,e,t);else{let s=await this._getExternalIdByParticipantId(e.initiatorId);s&&E.onRemoteSharedMovieInfo(s,e,t)}this._forceOpenTransportForAloneInCall()}async _processConnectionSharedMovieInfo(e){let t=e.conversation.participants.find(i=>this._isMe(I.composeId(i)));await this._processSharedMovieInfos(t?.movieShareInfos,e?.rooms?.roomId??null)}async _processConnectionAsrInfo(e){let t=e?.conversation.asrInfo??this._conversation?.asrInfo;if(t&&this._conversation?.asrInfoByRoom.set(null,t),e?.rooms?.rooms)for(let s of e.rooms.rooms)s.asrInfo&&this._conversation?.asrInfoByRoom.set(s.id,s.asrInfo);let i=e?.rooms?.roomId??this._conversation?.roomId??null,a=this._conversation?.asrInfoByRoom.get(i);if(a){let s=await this._getExternalIdByParticipantId(a.initiatorId);s&&E.onAsrSet({externalId:s,movieId:a.movieId},i)}else i&&E.onAsrSet(null,i)}async _processConversationUrlSharingInfo(e){if(!this._conversation)return;e&&this._extractConnectionUrlSharingInfo(e);let{urlSharingInfoByRoom:t}=this._conversation,i=this._conversation.roomId,a=t.get(i);if(a&&!this._isMe(a.initiatorId)){let s=await this._getExternalIdByParticipantId(a.initiatorId);s&&E.onRemoteSharedUrl(s,a.sharedUrl,i)}}_extractConnectionUrlSharingInfo(e){if(!this._conversation)return;let{urlSharingInfoByRoom:t}=this._conversation;if(e.conversation.urlSharingInfo?t.set(null,e.conversation.urlSharingInfo):t.delete(null),e.rooms?.rooms)for(let i of e.rooms.rooms)i.urlSharingInfo?t.set(i.id,i.urlSharingInfo):t.delete(i.id)}async _onSharedMovieInfoStopped(e){d.log(`Shared movie stopped data received: ${e.notification}`);let t=this._conversation?.externalId,{initiatorId:i,movieId:a,source:s,roomId:o=null}=e,u={initiatorId:i,movieId:a,source:s};if(this._isMe(i))E.onLocalSharedMovieStoppedInfo(t,u,o);else{let m=await this._getExternalIdByParticipantId(i);if(m){let R=(await this._getParticipants())[i];R?.movieShareInfos&&(R.movieShareInfos=R.movieShareInfos.filter(M=>M&&M.movieId!==a)),E.onRemoteSharedMovieStoppedInfo(m,u,o)}}}async _onUrlSharingInfoUpdated(e){if(d.log(`Shared URL data received: ${e.notification}`),!this._conversation)return;let{urlSharingInfoByRoom:t,roomId:i}=this._conversation,{initiatorId:a,sharedUrl:s,roomId:o=null}=e;if(s?t.set(o,{sharedUrl:s,initiatorId:a}):t.delete(o),!(!s&&o!==i&&t.has(i))&&(!s||!this._isMe(a))){let u=await this._getExternalIdByParticipantId(a);u&&E.onRemoteSharedUrl(u,s,o)}}_onFeaturesPerRoleChanged(e){d.log(`Features per role changed: ${e.notification}`),E.onFeaturesPerRoleChanged(e.featuresPerRole)}async _waitForStreamIfNeeded(e){let t=this._matchStreamDescription(e.participantStreamDescription);if(!t)return;let{mediaType:i,participantId:a}=t;if(i==="ANIMOJI")return;let s=await this._getParticipant(a);if(l.producerScreenDataChannel&&i==="SCREEN"&&!e.fastScreenShare){d.log("skipping participant-sources-update notification since screenshare will be received over datachannel");return}let o=Qe(t),u=this._sequenceNumberByStreamDescription.get(o);if(u&&u>e.sequenceNumber){d.warn(`Participant ${a} received outdated PAT response: sequence number ${e.sequenceNumber}; last sent sequence number for given participant is ${u}`),P.log(T.PAT_OUTDATED_RESPONSE);return}s&&e.suspend!==void 0&&i&&(d.debug(`participant-sources-update: mediaType=${i}, suspend=${e.suspend}`),E.onRemoteStreamSuspended(s.externalId,i,e.suspend));let p=e.streamId,m=e.rtpTimestamp?this._getWaitingTime(p,e.rtpTimestamp):0;if(m<=0){this._streamWaitTimerByStreamDescription.delete(o);let h=this._conversation?.externalId,R=this._isMe(a);if(!s&&!R){P.log(T.PAT_ERROR,"participantMissing"),d.error(`Could not find participant by ID: ${a}`);return}let M=R?h:s.externalId,k=this._streamByStreamId.get(p);if(!k){P.log(T.PAT_ERROR,"streamNotFound"),d.error(`Could not find stream by ID: ${p}`);return}P.log(T.PAT_ALLOCATED),this._streamIdByStreamDescription.set(o,p);let H=e.participantStreamDescription?.mediaType;if(H==="STREAM"||H==="MOVIE"){if(e.participantStreamDescription?.streamName){let z={streamName:e.participantStreamDescription.streamName,stream:k,mediaType:H};R?E.onLocalLive(M,z):E.onRemoteLive(M,z)}}else if(l.producerScreenTrack&&H==="SCREEN")E.onRemoteScreenStream(s.externalId,k);else if(!R){let z=(l.producerScreenTrack?null:s.secondStream)||k;E.onRemoteStream(s.externalId,z)}}else{d.debug(`Waiting for ${m} until stream ${p} for ${o} is switched`);let h=window.setTimeout(this._waitForStreamIfNeeded.bind(this,e),m);this._streamWaitTimerByStreamDescription.set(o,h)}}_matchStreamDescription(e){if(!e)return null;if(this._streamIdByStreamDescription.has(Qe(e)))return e;let t=e.participantId;if(e.mediaType){let i={participantId:t,mediaType:null};if(this._streamIdByStreamDescription.has(Qe(i)))return i}else{let i={participantId:t,mediaType:"CAMERA"};if(this._streamIdByStreamDescription.has(Qe(i)))return i;let a={participantId:t,mediaType:"SCREEN"};if(this._streamIdByStreamDescription.has(Qe(a)))return a}return d.error("Received unrequested allocation",e),null}_getWaitingTime(e,t){if(this._transport)return this._transport.getStreamWaitingTimeMs(e,t);throw new Error("transport is not initialized")}_isCallAdmin(){return this._conversation?I.includesOneOf(this._conversation.roles,[at.ADMIN,at.CREATOR]):!1}_checkAdminRole(){if(this._conversation&&!I.includesOneOf(this._conversation.roles,[at.ADMIN,at.CREATOR]))throw new Error("You don't have the required permission")}_isCalledState(){return this._participantState===J.CALLED}async grantRoles(e,t,i){this._checkAdminRole(),await this._signaling.grantRoles(e,t,i)}async startAsr(e){await this._signaling.startAsr(e)}async stopAsr(e){await this._signaling.stopAsr(e)}async requestAsr(e){this._isRealTimeAsrRequested=e,e&&this._forceOpenTransportForAloneInCall(),await this._signaling.requestAsr(e)}async muteParticipant(e=null,t,i=[],a=null){this._checkAdminRole(),await this._signaling.muteParticipant(e,t,i,a)}async enableFeatureForRoles(e,t){await this._signaling.enableFeatureForRoles(e,t)}async pinParticipant(e,t,i=null){this._checkAdminRole(),await this._signaling.pinParticipant(e,t,i),this._conversation?.pinnedParticipantIdByRoom.set(i,t?null:e)}async updateMediaModifiers(e){this._signaling.ready&&this._conversation&&(this._conversation.mediaModifiers=e,await this._signaling.updateMediaModifiers(e))}async enableVideoSuspend(e){this._signaling.ready&&this._conversation&&this._transport?.getTopology()==="SERVER"&&await this._signaling.enableVideoSuspend(e)}async enableVideoSuspendSuggest(e){this._signaling.ready&&this._conversation&&this._transport?.getTopology()==="SERVER"&&await this._signaling.enableVideoSuspendSuggest(e)}async changeOptions(e){if(this._signaling.ready&&this._conversation){this._checkAdminRole(),await this._signaling.changeOptions(e);let t=In(this._conversation.options,e);this._onOptionsChanged(t)}}async getWaitingHall(e,t,i){if(!this._signaling)return Promise.reject();let a=null;if(e&&(a=wn(e),a)){let m=this._api.getDecorativeIdByInitialId(a.id);a.id=m?I.composeUserId(m):a.id}let s=await this._signaling.getWaitingHall(a,t,i);if(s.error)return Promise.reject(s.message);let o=s.participants||[],{externalIds:u}=await this._resolveWaitingHallExternalIds(o),p=null;return o.length&&s.hasMore&&(p=Dn(o[o.length-1].id)),{participants:u,pageMarker:p,totalCount:s.totalCount||0}}async _resolveWaitingHallExternalIds(e){let t=new Map,i=[],a=[];if(e.length){let s=[];e.forEach(o=>{if(t.set(o.id.id,o.id.addedTs),o.externalId){let u=q.fromSignaling(o.externalId);i.push(o.id.addedTs),a.push(u),this._api.cacheExternalId(o.id.id,u)}else s.push(I.decomposeId(o.id.id).id)}),s.length&&!a.length&&(a=await this._api.getExternalIdsByOkIds(s),i=a.map(o=>{let u=this._api.getCachedOkIdByExternalId(o);return(u?t.get(u):void 0)||Date.now()}))}return{externalIds:a,timestamps:i}}async getAudienceModeHands(){if(!this._signaling.ready)throw new Error("Signaling is not ready");let e=await this._signaling.getHandQueue();if(e.error)return Promise.reject(e.message);let t=e.participants||[],{externalIds:i,timestamps:a}=await this._resolveWaitingHallExternalIds(t);return{timestamps:a,participants:i,totalCount:e.totalCount||0}}async promoteParticipant(e,t){if(this._signaling&&this._conversation)try{if(!I.includesOneOf(this._conversation.options,[Dt.WAITING_HALL,Dt.AUDIENCE_MODE]))throw new Error("Unable to promote a participant in the conversation with current options");if(this._checkAdminRole(),!e&&t)throw new Error("participantId is required");await this._signaling.promoteParticipant(e,t)}catch(i){throw d.warn(`Failed to promote participant ${e}. ${i}`),i}}async requestPromotion(e=!1){this._signaling.ready&&await this._signaling.requestPromotion(e)}async acceptPromotion(e=!1){this._signaling.ready&&await this._signaling.acceptPromotion(e)}async chatMessage(e,t=null){this._signaling.ready&&await this._signaling.chatMessage(e,t)}async chatHistory(e){if(this._signaling.ready){let t=await this._signaling.chatHistory(e);for(let i=t.messages.length-1;i>=0;i--){let a=t.messages[i];await this._onChatMessage(a)}}}async customData(e,t=null){this._signaling.ready&&await this._signaling.customData(e,t)}async createJoinLink(){if(this._conversation){let t=(await this._api.createJoinLink(this._conversation.id)).join_link;if(t)return this._conversation.joinLink=t,t}return Promise.reject()}async removeJoinLink(){if(this._conversation&&(await this._api.removeJoinLink(this._conversation.id)).success){delete this._conversation.joinLink;return}return Promise.reject()}async addMovie({movieId:e,gain:t,metadata:i,lang:a}){let s={movieId:e,lang:a};(t||t===0)&&(s.gain=t),i&&(s.metadata=i);let o=await this._signaling.addMovie(s);if(o.error)throw new Error(o.error);return{movieId:o.movieId,streamType:o.streamType}}async updateMovie(e){let t=await this._signaling.updateMovie(e);if(t.error)throw new Error(t.error)}async removeMovie(e){let t={movieId:e},i=await this._signaling.removeMovie(t);if(i.error)throw new Error(i.error)}async startUrlSharing(e){let t=await this._signaling.startUrlSharing(e);if(t.error)throw new Error(t.error)}async stopUrlSharing(){let e=await this._signaling.stopUrlSharing();if(e.error)throw new Error(e.error)}async updateRooms(e,t){let i=await this._signaling.updateRooms(e,t);if(i.error)throw new Error(i.error)}async activateRooms(e,t){let i=await this._signaling.activateRooms(e,t);if(i.error)throw new Error(i.error)}async switchRoom(e,t){let i=await this._signaling.switchRoom(e,t);if(i.error)throw new Error(i.error)}async removeRooms(e){let t=await this._signaling.removeRooms(e);if(t.error)throw new Error(t.error)}async startStream(e=!1,t=null,i=null,a="DIRECT_LINK",s=null,o=null){let u={movieId:i,name:t,privacy:a,groupId:s,roomId:o,streamMovie:!e},p=await this._signaling.startStream(u);if(p.error)return Promise.reject(p.message)}async stopStream(e=null){if((await this._signaling.stopStream({roomId:e})).error)return Promise.reject()}async publishStream(e=null){if((await this._signaling.publishStream({roomId:e})).error)return Promise.reject()}async recordSetConf(e,t,i=!1,a=null){let s=await this._signaling.recordSetConf({king:e,pawns:t,hideParticipantCount:i,roomId:a});if(s.error)throw new Error(s.error)}async getStreamInfo(){let e=await this._signaling.getRecordStatus();return{movieId:e.recordMovieId,preview:e.recordMoviePreviewUrl}}async setLocalResolution({video:e,effect:t}){if(e.width<l.videoMinWidth||e.height<l.videoMinHeight)throw new Error("Sizes received are less than the `videoMinWidth` or `videoMinHeight`");if(t){if(t.width<l.videoMinWidth||t.height<l.videoMinHeight)throw new Error("Sizes of effect received are less than the `videoMinWidth` or `videoMinHeight`");l.videoEffectMaxHeight=t.height,l.videoEffectMaxWidth=t.width}l.videoMaxWidth=e.width,l.videoMaxHeight=e.height,d.debug("Set local video resolution:",`video ${e.width}x${e.height}`+(t?`, effect ${t.width}x${t.height}`:"")),this._mediaSource&&(await this._mediaSource.setResolution({video:e,effect:t}),this._transport&&await this._transport.onCameraResolutionChanged())}async videoEffect(e){return this._mediaSource?.videoEffect(e)}async audioEffect(e,t){return this._mediaSource?.audioEffect(e?{effects:e,isPreset:t}:null)}_convertExternalIdsToServerExternalIds(e){return e.map(t=>({id:t.id,type:l.externalUserType}))}async getParticipants(e){let t=this._convertExternalIdsToServerExternalIds(e.externalIds),i=await this._signaling.getParticipants(t);if(i.error)throw new Error(i.error);let a=i.participants,s=this._transport?.getState();return Promise.all(a.map(async o=>{let u=I.composeId(o);return this._createParticipant({id:u,externalId:q.fromSignalingParticipant(o),mediaSettings:Ee(o.mediaSettings),participantState:I.mapParticipantState(o),state:o.state,roles:o.roles||[],status:this._getStatusByTransportState(s)??"WAITING",muteStates:o.muteStates||{},unmuteOptions:o.unmuteOptions||[],observedIds:o.observedIds||[],markers:this._denormalizeMarkers(u,o.markers)},o.decorativeUserId)})).then(I.mapSharedParticipants)}async getParticipantListChunk(e){d.log("Request participant list chunk",e);let t=await this._signaling.getParticipantListChunk(e);if(t.error)throw new Error(t.error);let i=this._createParticipantListChunk(t.chunk),a=await this._getParticipants(),s=i.participants.filter(u=>{let p=I.composeId(u);return!a[p]});await this._registerParticipants(s);let o=this._transport?.getState();return i.participants.forEach(u=>{let p=I.composeId(u),m=a[p];m.status=this._getStatusByTransportState(o)??"WAITING",m.movieShareInfos=u.movieShareInfos,Object.assign(m.mediaSettings,Ee(u.mediaSettings)),Object.assign(m.muteStates,u.muteStates),m.unmuteOptions=u.unmuteOptions??m.unmuteOptions,this._openTransport([m],!0)}),this._participantListChunkToExternalChunk(i)}async _getInitialParticiapntListChunk(){let e=l.participantListChunkInitIndex,t=l.participantListChunkInitCount,a=await this._signaling.getParticipantListChunk({listType:"GRID",fromIdx:e,count:t});return d.debug("Get initial participant list chunk",a.chunk),a.chunk}_onLocalMediaStreamChanged(e){if(!this._conversation||!this._mediaSource)return;let t=this._mediaSource.getMediaSettings();d.debug("Local media stream changed",t),e.kind==="audio"&&this._mediaSource&&(this._audioFix=new Jt(this._mediaSource)),E.onLocalStreamUpdate(t,e.kind),!this._conversation?.waitingHall&&!this._conversation?.observer&&!this._isAudienceModeListener()&&this._changeMediaSettings(t)}_onScreenSharingStatus(e){let t=this._mediaSource?.getMediaSettings();if(d.log("Screen sharing changed",e.track,t),l.consumerScreenTrack){let i=e.track?new MediaStream([e.track]):null;E.onScreenStream(i,t)}}async _changeRemoteMediaSettings(e,t){d.debug(`Remote media settings changed [${e}]`,t);let i=this._conversation?.externalId;if(this._isMe(e)&&i){E.onLocalMediaSettings(i,t);return}let s=await this._getParticipant(e);if(!s){this._warnParticipantNotInConversation(e);return}s.mediaSettings=t,this._state==="ACTIVE"&&E.onRemoteMediaSettings(s.externalId,t,s.markers),this._specListener&&this._specListener.onChangeRemoteMediaSettings(e,t)}_changeLocalParticipantState(e){d.debug("Local participant state force changed by admin",e),this._state==="ACTIVE"&&E.onLocalParticipantState(e)}async _changeRemoteParticipantState(e,t){d.debug(`Remote participant state changed [${e}]`,t);let i=await this._getParticipant(e);if(!i){this._warnParticipantNotInConversation(e);return}i.participantState=t||{},this._state==="ACTIVE"&&E.onRemoteParticipantState(i.externalId,i.participantState,i.markers)}async _changeMultipleParticipantState(e,t){d.debug("Multiple participants state changed",e);let i=[],a,s=await this._getParticipants();e.forEach((o,u)=>{if(this._isMe(u))a=o;else{let p=s[u];if(!p){this._warnParticipantNotInConversation(u);return}p.participantState=o,i.push({externalId:p.externalId,participantState:{...o},markers:p.markers})}}),this._state==="ACTIVE"&&(a&&E.onLocalParticipantState(a),i.length&&E.onRemoteParticipantsState(i,t))}_invokeRolesChangedCallbackIfNeeded(e){this._state==="ACTIVE"&&e.roles&&e.roles.length&&(d.debug(`Roles for participant [${e.id}] changed: ${e.roles}`),E.onRolesChanged(e.externalId,e.roles,!0))}_onSignalingNotification(e){switch(e.notification){case U.ACCEPTED_CALL:return this._onAcceptedCall(e);case U.HUNGUP:return this._onHungup(e);case U.PARTICIPANT_ADDED:return this._onAddedParticipant(e);case U.PARTICIPANT_JOINED:return this._onJoinedParticipant(e);case U.CLOSED_CONVERSATION:return this._onClosedConversation(e);case U.MEDIA_SETTINGS_CHANGED:return this._onMediaSettingsChanged(e);case U.PARTICIPANT_STATE_CHANGED:return this._onParticipantStateChanged(e);case U.PARTICIPANTS_STATE_CHANGED:return this._onParticipantsStateChanged(e);case U.RATE_CALL_DATA:return this._onNeedRate();case U.FEATURE_SET_CHANGED:return this._onFeatureSetChanged(e);case U.MULTIPARTY_CHAT_CREATED:return this._onMultipartyChatCreated(e);case U.FORCE_MEDIA_SETTINGS_CHANGE:return this._onForceMediaSettingsChange(e);case U.SETTINGS_UPDATE:return this._onSettingsUpdate(e);case U.VIDEO_QUALITY_UPDATE:return this._onVideoQualityUpdate(e);case U.REGISTERED_PEER:return this._onPeerRegistered(e);case U.SWITCH_MICRO:return this._onMicSwitched(e);case U.CHAT_MESSAGE:return this._onChatMessage(e);case U.CUSTOM_DATA:return this._onCustomData(e);case U.RECORD_STARTED:return this._onRecordInfo(e.recordInfo,e.roomId);case U.RECORD_STOPPED:return this._onRecordInfo(null,e.roomId);case U.ROLES_CHANGED:return this._onRolesChanged(e.participantId,e.roles||[]);case U.MUTE_PARTICIPANT:return this._onMuteParticipant(e);case U.PIN_PARTICIPANT:return this._onPinParticipant(e.participantId,e.unpin,e.markers,e.roomId);case U.OPTIONS_CHANGED:return this._onOptionsChanged(e.options||[]);case U.PARTICIPANT_SOURCES_UPDATE:return this._onParticipantSourcesUpdate(e);case U.PROMOTE_PARTICIPANT:return this._onParticipantPromoted(e);case U.CHAT_ROOM_UPDATED:return this._onChatRoomUpdated(e.eventType,e.totalCount,e.firstParticipants,e.addedParticipantIds,e.removedParticipantIds);case U.JOIN_LINK_CHANGED:return this._onJoinLinkChanged(e);case U.FEEDBACK:return this._onFeedback(e);case U.MOVIE_UPDATE_NOTIFICATION:return this._onSharedMovieUpdate(e);case U.MOVIE_SHARE_STARTED:return this._onSharedMovieInfoStarted(e);case U.MOVIE_SHARE_STOPPED:return this._onSharedMovieInfoStopped(e);case U.URL_SHARING_INFO_UPDATED:return this._onUrlSharingInfoUpdated(e);case U.ROOMS_UPDATED:return this._onRoomsUpdated(e);case U.ROOM_UPDATED:return this._onRoomUpdated(e);case U.ROOM_PARTICIPANTS_UPDATED:return this._onRoomParticipantsUpdated(e);case U.FEATURES_PER_ROLE_CHANGED:return this._onFeaturesPerRoleChanged(e);case U.PARTICIPANT_ANIMOJI_CHANGED:return this._onParticipantAnimojiChanged(e);case U.ASR_STARTED:return this._onAsrStart(e);case U.ASR_STOPPED:return this._onAsrStop(e);case U.PROMOTION_APPROVED:return this._onPromotionApproved(e);case U.DECORATIVE_PARTICIPANT_ID_CHANGED:return this._onDecorativeParticipantIdChanged(e);case U.VIDEO_SUSPEND_SUGGEST:return this._onVideoSuspendSuggest(e)}}async _onPromotionApproved(e){let t=await this._getExternalIdByParticipantId(e.adminId);if(!t){this._warnParticipantNotInConversation(e.adminId);return}E.onPromotionApproved(t)}async _onSignalingReconnect(e){if(!this._conversation)return;e.conversation.acceptTime&&(this._conversation.acceptTime=e.conversation.acceptTime),e.conversation.participantsLimit&&(this._conversation.participantsLimit=e.conversation.participantsLimit),e.conversation.features&&(this._conversation.features=e.conversation.features,this._conversation.featuresPerRole=e.conversation.featuresPerRole,this._changeFeatureSet()),await this._processPinnedParticipants(e),e.conversation.state;let t=null;if(e.conversation.participants){let s=Object.keys(await this._getParticipants()),o=[];for(let p of e.conversation.participants){let m=I.composeId(p),h=p.roles||[];if(this._isMe(m)){_i(this._conversation.roles,h)||this._onRolesChanged(m,h),t=()=>{this._registerParticipantLocalMuteState({muteStates:xn(p),unmuteOptions:p.unmuteOptions})};continue}o.push(m);let R=await this._getParticipant(m);if(!R)await this._onJoinedParticipant({participantId:p.id,participant:p,mediaSettings:p.mediaSettings});else{let M=Ee(p.mediaSettings);qa(M,R.mediaSettings)||await this._changeRemoteMediaSettings(m,M);let k=I.mapParticipantState(p),H=R.participantState;I.isEqualParticipantState(k,H)||await this._changeRemoteParticipantState(m,k),_i(h,R.roles)||this._onRolesChanged(R.id,h)}}let u=await this._getParticipants();for(let p of s)o.indexOf(p)<0&&this._removeParticipant(u[p],w.HUNGUP)}let i=e.rooms?.roomId??null;this._conversation.roomId!==i?this._onRoomSwitched(i).then(t):(this._processMuteStates(e,!0),t?.()),this._processRecordInfos(e),this._onOptionsChanged(e.conversation.options)}_onSignalingFailed(e){d.error("Signaling failed",e),this._close(e)}async _onAcceptedCall(e){let t=I.composeMessageId(e),i=I.getPeerIdString(e.peerId);if(d.debug(`Participant accepted call [${t}]`),this._statFirstMediaReceived.markAcceptedCall(this._transport?.getTopology()),this._conversation&&this._isMe(t)){this._close(new G(w.MISSED),"Call accepted on other device");return}let a=await this._getParticipant(t);if(!a){let o=this._api.getDecorativeIdByInitialId(t),u=o?I.composeUserId(o,e.participantType):void 0;a=this._registerParticipantInCache(await this._createParticipant({id:t,mediaSettings:Ee(e.mediaSettings)},u))}a.state=J.ACCEPTED,a.mediaSettings=Ee(e.mediaSettings),this._logWithMediaSettings(T.ACCEPTED_OUTGOING,a.mediaSettings),this._conversation&&this._conversation.direction===De.OUTGOING&&(this._state==="IDLE"||this._state==="PROCESSING")&&(this._state="ACTIVE",this._changeFeatureSet()),this._state==="ACTIVE"&&this._transport&&this._transport.open([a.id],i),await this._changeRemoteMediaSettings(t,a.mediaSettings),await this._changeRemoteParticipantState(t);let s=Object.keys(a.muteStates);s.length&&this._onMuteParticipant({muteStates:a.muteStates,mediaOptions:s,stateUpdated:!0,participantId:t}),this._state==="ACTIVE"&&E.onAcceptedCall(a.externalId)}async _onHungup(e){d.debug(`Participant hungup [${e.participantId}]`,{reason:e.reason});let t=I.composeMessageId(e);if(this._conversation&&this._isMe(t)){this._close(new G(e.reason,{remote:!0}));return}await this._registerParticipantAndSetMarkersIfChunkEnabled(t,e.markers);let i=await this._getParticipant(t);if(!i){this._warnParticipantNotInConversation(t);return}this._transport&&this._transport.close(t),i.state=e.reason===w.REJECTED?J.REJECTED:J.HUNGUP,this._state!=="CLOSE"&&this._removeParticipant(i,w.HUNGUP)}async _onAddedParticipant(e){d.debug(`Participant added [${e.participantId}]`);let t=I.composeMessageId(e),i=await this._getParticipant(t);if(i&&i.state!==J.HUNGUP&&i.state!==J.REJECTED){d.debug(`Participant [${t}] is already in conversation and is active`);return}if(!i){let{participant:a}=e,s=a.decorativeUserId;this._registerParticipant({id:t,externalId:q.fromSignalingParticipant(a),mediaSettings:Ee(a.mediaSettings),state:a.state,participantState:I.mapParticipantState(a),roles:a.roles||[],muteStates:a.muteStates||{},unmuteOptions:a.unmuteOptions||[],observedIds:a.observedIds||[]},s),i=await this._getParticipant(t)}i.state=J.CALLED,i.mediaSettings=Ee(e.participant?.mediaSettings),i.participantState=I.mapParticipantState(e.participant),i.roles=e.participant?.roles||[],this._setParticipantsStatus([i],"WAITING"),this._state!=="IDLE"&&this._transport&&this._transport.allocate(i.id,!0),E.onParticipantAdded(i.externalId,i.markers),await this._changeRemoteMediaSettings(t,i.mediaSettings),await this._changeRemoteParticipantState(t,i.participantState),this._invokeRolesChangedCallbackIfNeeded(i)}async _onJoinedParticipant(e){d.debug(`Participant joined [${e.participantId}]`),this._statFirstMediaReceived.markParticipantJoined(this._transport?.getTopology());let t=I.composeMessageId(e),i=await this._getParticipant(t);if(i&&i.state===J.ACCEPTED){d.warn(`Participant [${t}] is already in conversation and is active`);return}if(!i){let{participant:s}=e,o=s.decorativeUserId;this._registerParticipant({id:t,externalId:q.fromSignalingParticipant(s),mediaSettings:Ee(s.mediaSettings),state:s.state,participantState:I.mapParticipantState(s),roles:s.roles||[],muteStates:s.muteStates||{},movieShareInfos:s.movieShareInfos,unmuteOptions:s.unmuteOptions||[],observedIds:s.observedIds||[],markers:this._denormalizeMarkers(t,s.markers)},o),i=await this._getParticipant(t)}this._conversation&&this._conversation.direction===De.OUTGOING&&(this._state==="IDLE"||this._state==="PROCESSING")&&(this._state="ACTIVE",this._changeFeatureSet()),i.state=J.ACCEPTED,i.mediaSettings=Ee(e.mediaSettings),i.participantState=I.mapParticipantState(e.participant),i.roles=e.participant.roles||[],this._transport?.isAllocated(i.id)?this._setParticipantsStatus([i],"CONNECTED"):this._setParticipantsStatus([i],"WAITING"),this._state!=="IDLE"&&this._transport&&(this._transport.isAllocated(i.id)||this._transport.allocate(i.id,!0),this._transport.open([i.id],null,!!this._conversation?.observer)),E.onParticipantJoined(i.externalId,i.markers),await this._changeRemoteMediaSettings(t,i.mediaSettings),await this._changeRemoteParticipantState(t,i.participantState),this._invokeRolesChangedCallbackIfNeeded(i);let a=Object.keys(i.muteStates);a.length&&this._onMuteParticipant({muteStates:i.muteStates,mediaOptions:a,stateUpdated:!0,participantId:t}),await this._processSharedMovieInfos(i.movieShareInfos)}_onClosedConversation(e){this._toggleJoinAvailability(),this._close(new G(e.reason,{remote:!0}))}async _onMediaSettingsChanged(e){let t=I.composeMessageId(e);await this._registerParticipantAndSetMarkersIfChunkEnabled(t,e.markers),await this._changeRemoteMediaSettings(t,Ee(e.mediaSettings))}async _onParticipantStateChanged(e){let t=I.composeMessageId(e),i=I.mapParticipantState(e);this._isMe(t)?this._changeLocalParticipantState(i):(await this._registerParticipantAndSetMarkersIfChunkEnabled(t,e.markers),await this._changeRemoteParticipantState(t,i))}async _onParticipantsStateChanged(e){let{participants:t,roomId:i}=e,a=t.map(({id:u,markers:p})=>this._registerParticipantAndSetMarkersIfChunkEnabled(u,p));await Promise.all(a);let s=new Map,o=t.map(({id:u,participantState:p})=>this._getExternalIdByParticipantId(u).then(m=>[u,m&&I.mapParticipantState({participantState:p})]));try{(await Promise.all(o)).forEach(([p,m])=>{m&&s.set(p,m)}),await this._changeMultipleParticipantState(s,i)}catch(u){d.warn(`_onParticipantsStateChanged: Failed to get external ids. ${u}`)}}_onNeedRate(){this._conversation&&(this._conversation.needRate=!0,this._changeNeedRate())}_onFeatureSetChanged(e){this._conversation&&(this._conversation.features=e.features,this._conversation.featuresPerRole=e.featuresPerRole,this._changeFeatureSet())}_onMultipartyChatCreated(e){this._conversation&&(this._conversation.chatId=e.chatId,this._toggleJoinAvailability(),E.onMultipartyChatCreated(this._conversation))}async _onForceMediaSettingsChange(e){if(!this._mediaSource)return;let t=this._mediaSource.getMediaSettings(),i=Ee(e.mediaSettings);t.isAudioEnabled!==i.isAudioEnabled&&await this._mediaSource.toggleAudio(i.isAudioEnabled),t.isVideoEnabled!==i.isVideoEnabled&&await this._mediaSource.toggleVideo(i.isVideoEnabled),l.consumerScreenTrack&&t.isScreenSharingEnabled!==i.isScreenSharingEnabled&&await this._mediaSource.toggleScreenCapturing({captureScreen:i.isScreenSharingEnabled,fastScreenSharing:i.isFastScreenSharingEnabled,captureAudio:i.isAudioSharingEnabled})}_onSettingsUpdate(e){d.debug("Got settings update notification",e);let t={camera:e.camera,screenSharing:e.screenSharing};this._serverSettings=sa(this._serverSettings,t),this._transport&&this._transport.updateSettings(this._serverSettings)}_onVideoQualityUpdate(e){d.debug("Got video quality update notification",e);let t=Math.round(e.quality.maxBitrate/1024),i=e.quality.maxDimension,a={camera:Object.assign({},this._serverSettings.camera,{maxBitrateK:t,maxDimension:i}),screenSharing:null};this._serverSettings=sa(this._serverSettings,a),this._transport&&this._transport.updateSettings(this._serverSettings)}async _onPeerRegistered(e){let t=I.composeMessageId(e),i=await this._getParticipant(t);i&&(i.clientType=e.clientType,i.platform=e.platform),E.onPeerRegistered()}async _onMicSwitched(e){E.onDeviceSwitched(se.AUDIO,!e.mute),await this.toggleLocalAudio(!e.mute)}async _onChatMessage(e){let t=I.composeMessageId(e),i=await this._getExternalIdByParticipantId(t);if(!i){this._warnParticipantNotInConversation(t);return}E.onChatMessage(e.message,i,e.direct)}async _onCustomData(e){if(e.data.hasOwnProperty("sdk"))return;let t=I.composeMessageId(e),i=await this._getExternalIdByParticipantId(t);if(!i){this._warnParticipantNotInConversation(t);return}E.onCustomData(e.data,i,e.direct)}async _onRecordInfo(e,t=null){if(!this._conversation)return;let i=this._conversation.recordsInfoByRoom.get(t),a=!1;if(!i!=!e?a=!0:i&&e&&(a=i.recordMovieId!==e.recordMovieId||i.recordStartTime!==e.recordStartTime),a)if(this._conversation.recordsInfoByRoom.set(t,e),e){let s=await this._getExternalIdByParticipantId(e.initiator);s?E.onRecordStarted(s,e.recordMovieId,e.recordStartTime,e.recordType,e.recordExternalMovieId,e.recordExternalOwnerId,t):this._warnParticipantNotInConversation(e.initiator)}else E.onRecordStopped(t);e&&this._forceOpenTransportForAloneInCall()}async _changePinnedParticipantForRoom(){if(!this._conversation)return;let e=this._conversation.roomId,t=this._conversation.pinnedParticipantIdByRoom.get(e);if(t&&!this._isMe(t)){let i=await this._getExternalIdByParticipantId(t);i&&E.onPinnedParticipant(i,!1,null,e)}}async _changeRecordInfoForRoom(){if(!this._conversation)return;let e=this._conversation.roomId,t=this._conversation.recordsInfoByRoom.get(e);if(t){let i=await this._getExternalIdByParticipantId(t.initiator);i?E.onRecordStarted(i,t.recordMovieId,t.recordStartTime,t.recordType,t.recordExternalMovieId,t.recordExternalOwnerId,e):this._warnParticipantNotInConversation(t.initiator)}else E.onRecordStopped(e)}async _changeAsrInfoForRoom(){if(!this._conversation)return;let e=this._conversation.roomId,t=this._conversation.asrInfoByRoom.get(e);if(t){let i=await this._getExternalIdByParticipantId(t.initiatorId);i&&E.onAsrSet({externalId:i,movieId:t.movieId},e)}else E.onAsrSet(null,e)}async _changeUrlSharingInfoForRoom(){if(!this._conversation)return;let{roomId:e}=this._conversation,{urlSharingInfoByRoom:t}=this._conversation,i=t.get(e);if(i){let a=await this._getExternalIdByParticipantId(i.initiatorId);a&&E.onRemoteSharedUrl(a,i.sharedUrl,e)}}async _onParticipantAnimojiChanged(e){if(this._conversation){let t=await this._getExternalIdByParticipantId(e.participantId);if(!t){this._warnParticipantNotInConversation(e.participantId);return}E.onParticipantVmojiUpdate(t)}}async _onAsrStart(e){if(!this._conversation)return;let t=e.asrInfo,i=e.roomId||null;this._conversation.asrInfoByRoom.set(i,t);let a=await this._getExternalIdByParticipantId(t.initiatorId);if(!a){this._warnParticipantNotInConversation(t.initiatorId);return}E.onAsrStarted(a,t.movieId,i),this._forceOpenTransportForAloneInCall()}_onAsrStop(e){if(!this._conversation)return;let t=e.roomId||null;t===null&&(this._conversation.asrInfo=null),this._conversation.asrInfoByRoom.delete(t),E.onAsrStopped(t)}async _onAsrTranscription(e){if(!this._conversation)return;let t=await this._getExternalIdByParticipantId(e.participantId);if(!t){this._warnParticipantNotInConversation(e.participantId);return}E.onAsrTranscription(t,e.text,e.timestamp,e.duration)}async _onRolesChanged(e,t){if(this._conversation&&this._isMe(e)&&!_i(this._conversation.roles,t)){d.debug(`Local roles changed: ${t}`),this._conversation.roles=t,E.onLocalRolesChanged(t),this._processMuteState({mediaOptions:mr(this._getMuteStatesForCurrentRoom(),Ne.MUTE_PERMANENT),stateUpdated:!0}),I.includesOneOf(t,[at.ADMIN,at.CREATOR])?this._refreshRooms(!0):t.length||this._onRoomSwitched(null);return}let i=await this._getParticipant(e);i&&!_i(i.roles,t)&&(d.debug(`Roles for participant [${e}] changed: ${t}`),i.roles=t,E.onRolesChanged(i.externalId,t))}async _onMuteParticipant(e,t=!1){if(!this._conversation)return;let{muteAll:i,muteStates:a={},unmuteOptions:s=[],mediaOptions:o=[],roomId:u=null}=e,p=e.adminId?await this._getParticipant(e.adminId):null;if(e.participantId&&!this._isMe(e.participantId)){if(!this._isCallAdmin()){d.warn(`Not admin got mute states for participant [${e.participantId}]`);return}let m=await this._getParticipant(e.participantId);m&&(d.debug(`Mute states for participant [${e.participantId}] changed`,a),E.onMuteStates(a,s,o,i,e.unmute,m.externalId,p?.externalId,e.stateUpdated,e.requestedMedia,e.roomId));return}if(e.requestedMedia?.length||(i&&!t?this._setMuteStatesForRoomId(a,u):i||(this._conversation.muteStatesPersonal=a)),e.adminId&&this._isMe(e.adminId)){i&&E.onMuteStates(a,s,o,i,e.unmute,null,this._conversation.externalId,e.stateUpdated,e.requestedMedia,e.roomId);return}await this._processMuteState({mediaOptions:o,muteAll:i,unmute:e.unmute,adminId:e.adminId,stateUpdated:e.stateUpdated,requestedMedia:e.requestedMedia,roomId:e.roomId,unmuteOptions:s,muteStates:a})}_changeMuteStatesForRoom(e,t){if(!this._conversation)return;let i=this._getMuteStatesForRoomId(t),a=this._getMuteStatesForRoomId(e),s=Object.keys(i),o=Object.keys(a);this._processMuteState({mediaOptions:Array.from(new Set([...s,...o])),roomId:e,muteAll:!0,stateUpdated:!0})}async _processMuteState(e){if(!this._conversation||!this._mediaSource||this._participantState!==J.ACCEPTED)return;let{mediaOptions:t=[],muteAll:i,unmute:a,stateUpdated:s,requestedMedia:o,roomId:u=null,unmuteOptions:p=[]}=e,m=e.adminId?await this._getParticipant(e.adminId):null,h=Object.assign({},e.muteStates??this._getMuteStatesForRoomId(u)),R=this._mediaSource.getMediaSettings(),M=Object.entries(h);for(let[k,H]of M){let z=l.newMuteRules&&this._isCallAdmin()&&i;if(!(H!==Ne.MUTE&&H!==Ne.MUTE_PERMANENT||z)&&(this._isCallAdmin()&&H===Ne.MUTE_PERMANENT&&!i&&(h[k]=Ne.MUTE),!(!t.includes(k)||a)))switch(k){case se.VIDEO:R.isVideoEnabled&&(E.onDeviceSwitched(se.VIDEO,!1),await this.toggleLocalVideo(!1));break;case se.AUDIO:R.isAudioEnabled&&(E.onDeviceSwitched(se.AUDIO,!1),await this.toggleLocalAudio(!1));break;case se.SCREEN_SHARING:R.isScreenSharingEnabled&&(E.onDeviceSwitched(se.SCREEN_SHARING,!1),await this.disableScreenCapturing());break;case se.AUDIO_SHARING:R.isAudioSharingEnabled&&(E.onDeviceSwitched(se.AUDIO_SHARING,!1),await this.toggleScreenCapturing({captureScreen:R.isScreenSharingEnabled,fastScreenSharing:R.isFastScreenSharingEnabled,captureAudio:!1}));break}}E.onMuteStates(h,p,t,i,a,null,m?.externalId,s,o,u)}async _onPinParticipant(e,t=!1,i,a=null){if(!this._conversation)return;let s=this._conversation.pinnedParticipantIdByRoom.get(a);if(s&&s!==e)if(this._isMe(s))E.onLocalPin(!0,a);else{let o=await this._getExternalIdByParticipantId(s);o&&E.onPinnedParticipant(o,!0,this._denormalizeMarkers(e,i),a)}if(this._isMe(e))E.onLocalPin(t,a);else{let o=await this._getExternalIdByParticipantId(e);o&&E.onPinnedParticipant(o,t,this._denormalizeMarkers(e,i),a)}this._conversation.pinnedParticipantIdByRoom.set(a,t?null:e)}_onOptionsChanged(e){this._conversation&&!vn(this._conversation.options,e)&&(this._conversation.options=e,E.onOptionsChanged(e))}async _onNetworkStatus(e){if(this._conversation){let t=[],i=await this._getParticipants();for(let[a,s]of Object.entries(e)){let o;if(this._isMe(a)||a==="")o=this._conversation.networkRating;else if(i[a])o=i[a].networkRating;else continue;if(o!==s)if(this._isMe(a)||a==="")this._conversation.networkRating=s,E.onLocalNetworkStatusChanged(s);else{let u=i[a];u.networkRating=s,t.push({uid:u.externalId,rating:s})}}if(t.length===0)return;d.log("Received network status update: ",e),E.onNetworkStatusChanged(t)}}async _onRemoteStreamSecond(e,t){let i=await this._getParticipant(e);if(i){if(l.producerScreenTrack){E.onRemoteScreenStream(i.externalId,t);return}if(i.secondStream=t,l.videoTracksCount>0){let a=e;if(!this._streamIdByStreamDescription.has(a)){d.error("Received remote stream notification for a participant that has no track associated with it",a);return}let s=this._streamIdByStreamDescription.get(a);if(!s||this._streamWaitTimerByStreamDescription.has(a)){d.log("Delaying secondary stream start/stop until main stream becomes available",a);return}let o=this._streamByStreamId.get(s);if(!o){P.log(T.PAT_ERROR,"streamNotFound"),d.error(`Could not find stream by ID: ${s}`);return}E.onRemoteStream(i.externalId,i.secondStream||o)}else{let a=t||i.remoteStream;a&&E.onRemoteStream(i.externalId,a)}}}async _onAnimojiStream(e,t){if(this._isMe(e)&&this._mediaSource){E.onVmojiStream(t,this._mediaSource.getMediaSettings());return}let i=await this._getParticipant(e);i&&E.onRemoteVmojiStream(i.externalId,t)}async _onAnimojiError(e){try{let t=await this._getExternalIdByParticipantId(e.participantId);t&&(delete e.participantId,E.onVmojiError({...e,externalId:t}))}catch(t){d.warn("_onAnimojiError failed",t)}}_onPeerConnectionClosed(e){e==="SERVER"&&this._cleanupParticipantAgnosticStreams()}_changeFeatureSet(){if(this._conversation){let e=this._state==="ACTIVE",t=this._conversation.features.includes(lr.ADD_PARTICIPANT);E.onCallState(e,t,this._conversation)}}_changeNeedRate(){this._conversation&&this._conversation.needRate&&E.onRateNeeded()}async _onVolumesDetected(e){let t=[];for(let[i,a]of Object.entries(e)){let s=await this._getParticipant(i);s&&s.externalId&&t.push({uid:s.externalId,volume:a.real})}E.onVolumesDetected(t)}async _onSpeakerChanged(e){this._activeSpeakerId=e;let t=await this._getParticipant(e);t&&this._lastSignalledActiveSpeakerId!==e&&(E.onSpeakerChanged(t.externalId),this._lastSignalledActiveSpeakerId=e)}async _onTransportStateChanged(e,t){d.debug(`Transport state has changed: ${t}`,e);let i=this._getStatusByTransportState(t);if(!i)return;let a=await this._getParticipants(),s=e.reduce((o,u)=>{if(u in a){let p=a[u];o.push(p),t==="CONNECTED"&&(p.remoteStream||(p.mediaSettings&&this._changeRemoteMediaSettings(u,p.mediaSettings),this._changeRemoteParticipantState(u,p.participantState)),this._updateDisplayLayoutFromCache(u))}else this._warnParticipantNotInConversation(u);return o},[]);s.length&&this._setParticipantsStatus(s,i)}async _onTransportLocalStateChanged(e){if(d.debug(`Local transport state has changed: ${e}`),e==="CONNECTED"&&(E.onLocalStatus("CONNECTED"),this._transport?.getTopology()==="SERVER")){let t=Object.values(this._myLastRequestedLayouts);await this.updateDisplayLayout(t)}e==="CONNECTING"&&E.onLocalStatus("CONNECTING"),e==="RECONNECTING"&&E.onLocalStatus("RECONNECT"),e==="FAILED"&&this._transport&&this._transport.allocated().length===0&&(this._signaling.ready&&await this._signaling.hangup(w.FAILED),this._close(new G(w.FAILED),"Transport failed"))}async _onRemoteTrackAdded(e,t,i){if(e.endsWith($e.AUDIO_MIX))d.debug("Remote audio mix track added"),this._audioOutput.add(i),E.onRemoteMixedAudioStream(t);else if(e.startsWith($e.PARTICIPANT_AGNOSTIC_TRACK_PREFIX))d.debug(`Participant-agnostic track added: ${e}`),this._streamByStreamId.set(e,t);else{d.debug(`Remote track added on the participant [${e}]`,{kind:i.kind});let a=await this._getParticipant(e);if(!a){let s=this._api.getDecorativeIdByInitialId(e),o=s?I.composeUserId(s):void 0;d.warn(`Conversation: track added before participant [id: ${e}, decorativeId: ${o}]`),this._registerParticipant({id:e},o),a=await this._getParticipant(e),this._setParticipantsStatus([a],"WAITING"),this._activeSpeakerId===e&&this._lastSignalledActiveSpeakerId!==e&&(E.onSpeakerChanged(a.externalId),this._lastSignalledActiveSpeakerId=e)}if(this._transport&&!this._transport.isAllocated(a.id)&&this._transport.allocate(a.id,!1),i.kind==="audio"&&(this._audioOutput.add(i),l.preserveAudioTracks||(a.remoteAudioTrack=i,t.removeTrack(i))),a.remoteStream!==t&&t.getTracks().length){if(a.remoteStream=t,a.secondStream)return;E.onRemoteStream(a.externalId,t)}a.mediaSettings&&this._changeRemoteMediaSettings(e,a.mediaSettings)}}_onRemoteTrackRemoved(e,t,i){switch(d.debug(`[${e}] remote track (removed)`,{track:i}),i.kind){case"audio":this._removeAudioTrack(e,t,i);break;case"video":case"screen":this._removeVideoTrack(e,t,i);break}}async _removeAudioTrack(e,t,i){if(e!==$e.AUDIO_MIX){let a=await this._getParticipant(e);if(!a||a.remoteStream&&a.remoteStream!==t)return}this._audioOutput.remove(i)}_removeVideoTrack(e,t,i){}_onTopologyChanged(e){e==="DIRECT"&&(this._onRemoteSignalledStall([]),this._onAudioMixStall(!1)),this._conversation&&(this._conversation.topology=e,this._changeFeatureSet(),this._isRealTimeAsrRequested&&this._forceOpenTransportForAloneInCall())}_onAudioMixStall(e){this._audioMixStalled!==e&&(this._audioMixStalled=e,d.debug("Audio mix stalled:",e),E.onLocalStatus(e?"RECONNECT":"CONNECTED"))}async _onRemoteSignalledStall(e){let t={},i=[],a=[];d.debug("Participants stalled:",e);let s=await this._getParticipants();for(let o of e){if(t[o]=!0,!this._lastStalled[o]){let u=s[o];u&&i.push(u)}delete this._lastStalled[o]}for(let o of Object.keys(this._lastStalled)){let u=s[o];u&&a.push(u)}i.length&&this._setParticipantsStatus(i,"RECONNECT"),a.length&&this._setParticipantsStatus(a,"CONNECTED"),this._lastStalled=t}async _onRemoteDataStats(e){this._debugInfo&&this._debugInfo.onRemoteDataStats(e,await this._getParticipants()),this._fixAudioDevice(e.outbound.rtps),this._fixVideoDevice(e.outbound.rtps)}_fixAudioDevice(e){!b.hasMicrophone()||!this._audioFix||!this._mediaSource?.getMediaSettings().isAudioEnabled||this._audioFix.fix(e)}_fixVideoDevice(e){!b.hasCamera()||!this._audioFix||!this._mediaSource?.getMediaSettings().isVideoEnabled||this._audioFix.fixVideo(e)}_toggleJoinAvailability(){let e=this._conversation&&this._conversation.chatId,t=e&&this._state!=="CLOSE"||!1;e&&(d.debug("Toggle join availability",{available:t,chatId:e}),E.onJoinStatus(t,e))}async _updateDisplayLayoutFromCache(e){if(this._transport?.getTopology()!=="SERVER")return;let t=await this._getParticipant(e);t&&t.lastRequestedLayouts&&Object.keys(t.lastRequestedLayouts).length&&await this.updateDisplayLayout(Object.values(t.lastRequestedLayouts))}_setParticipantsStatus(e,t,i=null){if(!e.length)return;let a=e.reduce((s,o)=>(o.status!==t&&(o.status=t,s.push(o.externalId)),s),[]);a.length&&E.onRemoteStatus(a,t,i)}_onJoinLinkChanged(e){E.onJoinLinkChanged(e.joinLink)}async _onRoomsUpdated(e){if(this._isCalledState())return;let t={};for(let i of Object.keys(zt)){let a=e.updates[i];a&&(t[i]={rooms:await Promise.all(a?.rooms?.map(this._convertRoomToExternal.bind(this))||[]),roomIds:a?.roomIds,deactivated:a?.deactivated})}E.onRoomsUpdated(t)}async _onRoomUpdated(e){let t=await this._convertRoomToExternal(e.room||null);e.events.some(i=>i===zt.UPDATE)&&(e.muteStates!==void 0&&this._setMuteStatesForRoomId(e.muteStates,e.roomId),e.recordInfo!==void 0&&this._conversation?.recordsInfoByRoom.set(e.roomId,e.recordInfo),e.asrInfo!==void 0&&this._conversation?.asrInfoByRoom.set(e.roomId,e.asrInfo)),this._isCalledState()||E.onRoomUpdated(e.events,e.roomId,t,e.deactivate||null)}async _convertRoomToExternal(e){if(!e)return null;let t=await Promise.all(e.participantIds?.map(o=>this._getExternalIdByParticipantId(o))||[]),i=await Promise.all(e.addParticipantIds?.map(o=>this._getExternalIdByParticipantId(o))||[]),a=await Promise.all(e.removeParticipantIds?.map?.(o=>this._getExternalIdByParticipantId(o))||[]),s=e.pinnedParticipantId?await this._getExternalIdByParticipantId(e.pinnedParticipantId):void 0;return{id:e.id,name:e.name,participantCount:e.participantCount,participantIds:t,addParticipantIds:i,removeParticipantIds:a,participants:e.participants?.participants?await this._participantListChunkToExternalChunk(e.participants):void 0,active:e.active,muteStates:e.muteStates,pinnedParticipantId:s,countdownSec:e.countdownSec,timeoutMs:e.timeoutMs}}async _onRoomParticipantsUpdated(e){let t=this._transport?.getState(),i=e.roomId??null,a=e.addedParticipantIds?.map(M=>I.decomposeId(M).id)||[],s=await this._api.getExternalIdsByOkIds(a),o=e.addedParticipants;if(s.length&&o?.length!==s.length&&!this._isCalledState()){let M=this._convertExternalIdsToServerExternalIds(s);o=(await this._signaling.getParticipants(M)).participants}let u=await Promise.all(o?.map(async M=>{let k=I.composeId(M);return this._createParticipant({id:k,externalId:q.fromSignalingParticipant(M),mediaSettings:Ee(M.mediaSettings),participantState:I.mapParticipantState(M),state:M.state,roles:M.roles||[],status:this._getStatusByTransportState(t)??"WAITING",muteStates:M.muteStates||{},unmuteOptions:M.unmuteOptions||[],observedIds:M.observedIds||[],markers:this._denormalizeMarkers(k,M.markers),isInRoom:i!==null},M.decorativeUserId)})||[]),p=!1;for(let M of u)M.id===this._conversation?.compositeUserId&&(p=!0),this._registerParticipantInCache(M);this._transport?.getState()==="IDLE"&&!this._isCalledState()&&this._openTransport(u,!0);let m=[],h=[];if(e?.removedParticipantMarkers){for(let M of e.removedParticipantMarkers)if(M.GRID?.id){let k=this._getExternalIdByParticipantId(M.GRID.id);h.push(k)}m=await Promise.all(h)}if(p&&await this._onRoomSwitched(i),m){let M=this._conversation?.pinnedParticipantIdByRoom.get(i);if(M){let k=await this._getExternalIdByParticipantId(M);if(k){for(let H of m)if(q.compare(k,H)){this._conversation?.pinnedParticipantIdByRoom.delete(i);break}}}}let R={roomId:i,participantCount:e.participantCount,addedParticipantIds:s,addedParticipants:I.mapSharedParticipants(u),removedParticipantMarkers:e?.removedParticipantMarkers,removedParticipantIds:m};this._isCalledState()||E.onRoomParticipantsUpdated(R)}async _onRoomSwitched(e,t=!1){if(!this._conversation||this._conversation.roomId===e)return;let i=this._conversation.roomId;if(this._conversation.roomId=e,t&&!this._isCalledState()){E.onRoomStart(e);return}this._isCalledState()||E.onRoomSwitched(e),e!==null&&!this._isCallAdmin()&&await this._refreshRooms(!1),this._changePinnedParticipantForRoom(),this._changeRecordInfoForRoom(),this._changeMuteStatesForRoom(e,i),await this._changeAsrInfoForRoom(),await this._changeUrlSharingInfoForRoom()}async _refreshRooms(e){let t;this._isCalledState()||(t=await this._signaling.getRooms(e));let i=t?.rooms?.rooms??[],a=[];for(let s of i){let o=s.id??null;if(this._setMuteStatesForRoomId(s.muteStates,o),this._conversation?.recordsInfoByRoom.set(o,s.recordInfo??null),this._conversation?.pinnedParticipantIdByRoom.set(o,s.pinnedParticipantId??null),s.asrInfo&&this._conversation?.asrInfoByRoom.set(o,s.asrInfo),s.urlSharingInfo?this._conversation?.urlSharingInfoByRoom.set(o,s.urlSharingInfo):this._conversation?.urlSharingInfoByRoom.delete(o),e){let u=await this._getParticipants();await this._registerParticipants(s?.participants?.participants?.filter(m=>!u[I.composeId(m)])||[],!0);let p=await this._convertRoomToExternal(s);p&&a.push(p)}}a.length&&!this._isCalledState()&&E.onRoomsUpdated({[zt.UPDATE]:{rooms:a}})}async _onFeedback(e){let t=[];for(let i of e.feedback){let a={...i,items:[]};for(let s of i.items){let o=await this._getExternalIdByParticipantId(s.participantId);o?a.items.push({...s,participantId:o}):this._warnParticipantNotInConversation(s.participantId)}t.push(a)}E.onFeedback(t,e.roomId)}async _onDecorativeParticipantIdChanged(e){if(!this._conversation||!e.decorativeParticipantId||!e.decorativeExternalParticipantId)return;let{participantId:t,decorativeParticipantId:i,decorativeExternalParticipantId:a}=e,s=this._isMe(t);d.debug(`Decorative participant id changed [${t}]`,e);let o=await this._getExternalIdByParticipantId(t);if(!o){this._warnParticipantNotInConversation(t);return}let u=q.fromSignaling(a,o.deviceIdx);if(E.onParticipantIdChanged(o,u),this._api.cacheExternalId(i,u),this._api.mapDecorativeId(i,t),s)this._conversation.externalId=u;else{let p=await this._getParticipants();p[t].externalId=u}}_onVideoSuspendSuggest(e){!this._conversation||this._conversation.topology!=="SERVER"||(d.debug("Video suspend suggested",e),E.onVideoSuspendSuggest(e.bandwidth))}_isMe(e){return e===this._conversation?.compositeUserId}_getMuteStatesForRoomId(e=null){return this._conversation?.muteStates.get(e)??{}}_getMuteStatesForCurrentRoom(){return this._getMuteStatesForRoomId(this._conversation?.roomId)}_setMuteStatesForRoomId(e={},t=null){this._conversation?.muteStates.set(t,e)}_forceOpenTransportForAloneInCall(){this._transport?.getTopology()==="SERVER"&&this._transport?.getState()==="IDLE"&&!this._isCalledState()&&this._transport.open(this._transport.allocated(),null,!!this._conversation?.observer,!0)}_registerParticipant(e,t){this._pendingParticipants.set(e.id,this._createParticipant(e,t))}async _getParticipants(){if(this._pendingParticipants.size)for(let e of this._pendingParticipants.values()){let t=await e;this._pendingParticipants.delete(t.id),this._participants[t.id]=t}return this._participants}async _getParticipant(e){return(await this._getParticipants())[e]}};c($,"_current"),c($,"_activationMutex"),c($,"_delayedHangup",!1);var B=$,oa=class n extends Error{constructor(e,t){super(e);c(this,"participantErrors");Object.setPrototypeOf(this,n.prototype),this.participantErrors=t}};var xt=null,Yt=null;function Wn(){xt=null,Yt=null}function zo(n){return n?.endsWith("/")?n.slice(0,-1):n}async function Cr(n=null,r){let e=zo(n??l.apiBaseUrl);if(e)return e;if((r??l.apiEnv)!=="AUTO")return l.apiEndpoint(r);try{let t=atob("aHR0cHM6Ly9kbnMuZ29vZ2xlL3Jlc29sdmU/bmFtZT12aWRlby5fZW5kcG9pbnQub2sucnUmdHlwZT1UWFQ="),s=(await(await fetch(t,{method:"GET",mode:"cors",cache:"no-cache"})).json())?.Answer[0]?.data;if(!s)throw new Error("Wrong DNS response");return d.debug("Resolved API endpoint",s),s}catch(t){return d.warn("Failed to resolve API endpoint using DNS, default is used",t),l.apiEndpoint(r)}}async function Kn(){return xt||Yt||(Yt=Cr(),xt=await Yt,Yt=null,xt)}async function Qt(n,r={},e=!1){if(!window.Blob||!window.navigator.sendBeacon)return;await Kn();let t=qn(n,r,e),i=new window.Blob([t],{type:"application/x-www-form-urlencoded"});window.navigator.sendBeacon(`${xt}/fb.do`,i)}async function Pi(n,r={},e=!1,t){await Kn();let i=qn(n,r,e);return Jo(i,t)}async function Jo(n,r){let e=`${r??xt}/fb.do`,t=await fetch(e,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:n}),i=await t.text(),a;try{a=JSON.parse(i)}catch{a={result:i}}if(!t.ok||a.hasOwnProperty("error_msg"))throw a;return a}async function $n(n,r){try{let e=await fetch(n,{method:"POST",body:r});if(!e.ok)throw new Error(`HTTP error! status: ${e.status}`);let t=await e.text();d.debug("Form data sent successfully",t)}catch(e){throw d.warn("Failed to send form data",e),e}}function qn(n,r={},e=!1){r.method=n,r.format="JSON",r.application_key||(r.application_key=l.apiKey),e||(Ie.sessionKey?r.session_key=Ie.sessionKey:Ie.accessToken&&(r.access_token=Ie.accessToken));for(let[i,a]of Object.entries(r))typeof a=="object"&&(r[i]=JSON.stringify(a));let t="";for(let[i,a]of Object.entries(r))t&&(t+="&"),t+=`${i}=${encodeURIComponent(a)}`;return t}var yi=class{async createJoinLink(r){return{join_link:"nop"}}async removeJoinLink(r){return{success:!0}}async getAnonymTokenByLink(r,e){return""}log(r){}logClientStats(r){}logClientEvents(r){}getCachedOkIdByExternalId(r){return null}cacheExternalId(r,e){}mapDecorativeId(r,e){}unmapDecorativeId(r){}getDecorativeIdByInitialId(r){}replaceByInitialIdIdIfExists(r){return typeof r=="string"?parseInt(r,10):r}hangupConversation(r){}sendUserFeedbackStats(r,e,t,i){}async removeHistoryRecords(r){}async getServerTime(){return Date.now()}cleanup(){}};var Qo=10,Xo=700,Zo=3e3,Xt=class extends yi{constructor(){super(...arguments);c(this,"_userId",null);c(this,"_uuid");c(this,"_externalUidsCache",new Map);c(this,"_decorativeIdToInitialId",new Map);c(this,"_initialIdToDecorativeId",new Map)}async _callUnsafe(e,t={},i=!1){let a=async s=>{try{return await Pi(e,t,i)}catch(o){if(!o.hasOwnProperty("error_msg")&&(s++,d.debug(`${e} network error, attempt ${s}...`),s<Qo))return await I.delay(Math.min(s*Xo,Zo)),a(s);throw d.warn(e,"error",o),o}};return a(0)}async _call(e,t={},i=!1){try{return await this._callUnsafe(e,t,i)}catch(a){d.warn("Api call error",a);let s=ie.API;switch(a.error_code){case 102:case 103:case 104:return await this.authorize(),this._callUnsafe(e,t,i)}let o={message:a.error_msg,code:a.error_code};switch(a.custom_error&&(o.custom_error=a.custom_error),a.error_code){case 1101:s=w.SERVICE_DISABLED;break;case 300:s=w.NOT_FOUND;break;case 1102:s=w.CALLEE_IS_OFFLINE;break;case 1103:s=w.NOT_FRIENDS;break;case 1104:case 1106:s=w.EXTERNAL_API_ERROR;break;case 1113:s=w.CALLER_IS_REJECTED;break;case 1114:s=w.VCHAT_DETAILED_ERROR;break}throw new G(s,o)}}async userId(e){let t=I.extractOkId(e);if(Ie.isEmpty())return q.fromId(String(t));this._externalUidsCache.has(t)||await this._getExternalIdsByOkIds([t]);let i=this.getDecorativeIdByInitialId(t);return i&&(t=i),q.fromString(this._externalUidsCache.get(t))}async authorize(){if(this._ensureUuid(),!l.apiKey)throw new G(ie.API,{message:"Required argument apiAppKey not passed"});let e={session_data:{version:2,device_id:this._uuid,client_version:l.appVersion,client_type:"SDK_JS"}};return l.authToken&&(e.session_data.auth_token=l.authToken,e.session_data.version=3),this._callUnsafe("auth.anonymLogin",e,!0).then(t=>{t.uid&&(this._userId=Number(t.uid)),Ie.sessionKey=t.session_key,Ie.sessionSecretKey=t.session_secret_key}).catch(t=>{throw t.error_code===401&&E.onTokenExpired(),new G(ie.AUTH,{message:t.error_msg,code:t.error_code})})}log(e){let t={collector:"ok.mobile.apps.video",data:JSON.stringify({application:`${l.appName}:${l.sdkVersion}`,platform:l.platform,items:e})};Qt("log.externalLog",t)}logClientStats(e){let t={app_version:String(l.appVersion),sdk_type:"WEB",sdk_version:l.sdkVersion,version:1,items:e};l.clientStatsPlatform&&(t.platform=l.clientStatsPlatform);let i={data:JSON.stringify(t)};Qt("vchat.clientStats",i)}logClientEvents(e){let t={app_version:String(l.appVersion),sdk_type:"WEB",sdk_version:l.sdkVersion,version:1,items:e};l.clientStatsPlatform&&(t.platform=l.clientStatsPlatform);let i={data:JSON.stringify(t)};Qt("vchat.clientEvents",i)}async uploadDebugLogs(e,t,i,a){let s={conversationId:e,webrtcPlatform:l.platform,startTime:t,endTime:i},o=await this._callUnsafe("vchat.getLogUploadUrl",s),u=new FormData,p=new Blob([a],{type:"application/json"});u.append("file",p,"log.json");let m=new URL(o.upload_url);return m.searchParams.append("size",p.size.toString()),$n(m.toString(),u)}async joinConversation(e,t=!1,i){let a={conversationId:e,isVideo:t,protocolVersion:l.protocolVersion};return i&&(a.chatId=i),this._call("vchat.joinConversation",a)}async createConversation(e,t="",i=!1,{onlyAdminCanShareMovie:a,audienceMode:s,audioOnly:o}={},u){let p=this._preareStartConversationData({conversationId:e,isVideo:!1,joiningAllowed:!0,payload:t,requireAuthToJoin:i,onlyAdminCanShareMovie:a,audienceMode:s,audioOnly:o,speakerIds:u});return this._startConversation(p)}async startConversation(e,t,i,a=!1,s="",o=!1,u=!1,{onlyAdminCanShareMovie:p}={},m){let h=this._preareStartConversationData({conversationId:e,isVideo:a,joiningAllowed:o,payload:s,requireAuthToJoin:u,onlyAdminCanShareMovie:p,externalIds:m});if(t&&t.length)switch(i){case Ze.USER:h.uids=t.join(",");break;case Ze.GROUP:h.gid=t[0];break;case Ze.CHAT:h.chatId=t[0];break}return this._startConversation(h)}_ensureUuid(){if(!this._uuid){let e=lt.get("uuid");e||(e=I.uuid(),lt.set("uuid",e)),this._uuid=String(e)}}deviceId(){return this._ensureUuid(),this._uuid}_preareStartConversationData({conversationId:e,isVideo:t,payload:i="",joiningAllowed:a=!1,requireAuthToJoin:s=!1,onlyAdminCanShareMovie:o,audienceMode:u=!1,audioOnly:p=!1,speakerIds:m=[],externalIds:h}){let R={conversationId:e,isVideo:t,protocolVersion:l.protocolVersion};if(a&&(R.createJoinLink=!0),i&&(R.payload=i),l.domain&&(R.domainId=l.domain),l.externalDomain&&(R.externalDomain=l.externalDomain),s&&(R.requireAuthToJoin=!0),o!==void 0&&(R.onlyAdminCanShareMovie=o),u&&(R.audienceMode=u),p&&(R.audioOnly=p),m.length){let M=m.map(k=>I.composeUserId(k));R.speakerIds=M.join(",")}return h&&(R.externalIds=h.map(q.toSignaling).join(",")),R}async _startConversation(e){return this._call("vchat.startConversation",e)}async createJoinLink(e){return this._call("vchat.createJoinLink",{conversationId:e})}async removeJoinLink(e){return this._call("vchat.removeJoinLink",{conversationId:e})}async getAnonymTokenByLink(e,t){let i={joinLink:e};t&&(i.anonymName=t);let a=await this._call("vchat.getAnonymTokenByLink",i);return this._userId=Number(a.uid),a.token}async joinConversationByLink(e,t=!1,i,a){let s={joinLink:e,isVideo:t,protocolVersion:l.protocolVersion};return i?.length&&(s.observedIds=i.join(",")),l.anonymToken&&(s.anonymToken=l.anonymToken),a&&(s.payload=a),this._call("vchat.joinConversationByLink",s)}async getOkIdsByExternalIds(e){let t=[],i=[],a=new Map,s=Array.from(this._externalUidsCache.keys()),o=Array.from(this._externalUidsCache.values());for(let p of e){let m=q.toString(p),h=o.indexOf(m);h>-1?t.push(this.replaceByInitialIdIdIfExists(s[h])):(a.set(String(p.id),m),i.push({id:p.id,ok_anonym:p.type==="ANONYM"}))}return i.length&&(await this._call("vchat.getOkIdsByExternalIds",{externalIds:i})).ids.forEach((p,m)=>{let h=Number(p.ok_user_id),R=String(p.external_user_id.id);a.has(R)&&(this.cacheExternalId(h,q.fromString(a.get(R))),t.push(h))}),t}async getParticipantIdsByExternalIds(e){await this.getOkIdsByExternalIds(e);let t=new Map,i=Array.from(this._externalUidsCache.keys()),a=Array.from(this._externalUidsCache.values());for(let s of e){let o=q.toString(s),u=a.indexOf(o);if(u>-1){let p=I.composeParticipantId(this.replaceByInitialIdIdIfExists(i[u]),te.USER,s.deviceIdx);t.set(s,p)}}return t}async getExternalIdsByOkIds(e){let t=[],i=[];for(let s of e)if(this._externalUidsCache.has(s)){let o=this.getDecorativeIdByInitialId(s),u=this._externalUidsCache.get(o??s);t.push(q.fromString(u))}else i.push(s);if(!i.length)return t;let a=await this._getExternalIdsByOkIds(i);return Array.from(a.values())}getCachedOkIdByExternalId(e){let t=Array.from(this._externalUidsCache.keys()),i=Array.from(this._externalUidsCache.values()),a=q.toString(e),s=i.indexOf(a);return s>-1?I.composeParticipantId(this.replaceByInitialIdIdIfExists(t[s]),te.USER,e.deviceIdx):s>-1?I.composeParticipantId(t[s],te.USER,e.deviceIdx):null}cacheExternalId(e,t){let i=I.extractOkId(e);this._externalUidsCache.set(i,q.toString(t))}mapDecorativeId(e,t){let i=I.extractOkId(e),a=I.extractOkId(t);this._decorativeIdToInitialId.set(i,a),this._initialIdToDecorativeId.set(a,i)}unmapDecorativeId(e){let t=I.extractOkId(e),i=this.getDecorativeIdByInitialId(t);i&&this._decorativeIdToInitialId.delete(i),this._initialIdToDecorativeId.delete(t)}getDecorativeIdByInitialId(e){let t=I.extractOkId(e);return this._initialIdToDecorativeId.get(t)}replaceByInitialIdIdIfExists(e){let t=I.extractOkId(e);return this._decorativeIdToInitialId.get(t)??t}async getConversationParams(e){let t={};return l.anonymToken&&(t.anonymToken=l.anonymToken),e&&(t.conversationId=e),this._call("vchat.getConversationParams",t)}getUserId(){return this._userId}setUserId(e){this._userId=e}hangupConversation(e){let t={conversationId:e,reason:w.HUNGUP};l.anonymToken&&(t.anonymToken=l.anonymToken),Qt("vchat.hangupConversation",t)}sendUserFeedbackStats(e,t,i,a){let s={collector:"app.vchat.events.product",data:JSON.stringify({application:`${l.appName}:${l.sdkVersion}`,platform:l.platform,items:[{type:1,operation:T.USER_FEEDBACK_RECEIVED,timestamp:Date.now(),custom:{vcid:e,user_response:t,reason:i,group_call_users_count:a}}]})};Qt("log.externalLog",s)}async removeHistoryRecords(e){await this._call("vchat.removeHistoryRecords",{recordIds:e.join(",")})}cleanup(){this._decorativeIdToInitialId=new Map,this._initialIdToDecorativeId=new Map}async _getExternalIdsByOkIds(e){let t=new Map;e=e.map(i=>this.getDecorativeIdByInitialId(i)??i);try{let i=await this._call("vchat.getExternalIdsByOkIds",{uids:e.join(",")}),a=(s,o)=>{for(let[u,p]of Object.entries(s)){let m=Number(u),h=q.fromId(p,o);t.set(m,h),this.cacheExternalId(m,h)}};i.external_ids&&a(i.external_ids,"USER"),i.anonym_ids&&a(i.anonym_ids,"ANONYM");for(let s of e){let o=Number(s);if(!t.has(o)){let u=q.fromId(String(o));t.set(o,u),this.cacheExternalId(o,u)}}return t}catch{return t}}async getServerTime(){return(await this._call("system.getInfo")).serverTime}};var zn=(e=>(e.KING="KING",e.PAWN="PAWN",e))(zn||{}),Jn=zn;var ca=(e=>(e.OFF="0",e.ON="1",e))(ca||{});var Pr=class{constructor(r){c(this,"_queue");c(this,"_readCursor");c(this,"_writeCursor");c(this,"_moveReadCursor");c(this,"_left");this._queue=new Array(r).fill(null),this._readCursor=this._writeCursor=this._left=0,this._moveReadCursor=!1}get length(){return this._queue.length}get left(){return this._left}toArray(){return Array.from(this._queue)}add(r){this._moveReadCursor&&(this._readCursor=this.nextCursor(this._readCursor)),this._queue[this._writeCursor]===null&&(this._left+=1),this._queue[this._writeCursor]=r,this._writeCursor=this.nextCursor(this._writeCursor),this._moveReadCursor=this._writeCursor===this._readCursor}nextCursor(r){return(r+1)%this._queue.length}next(){let r=this._queue[this._readCursor];return r&&(this._moveReadCursor=!1,this._queue[this._readCursor]=null,this._readCursor=this.nextCursor(this._readCursor),this._left-=1),r}};var yr=class{constructor(r,e,t,i=null){c(this,"_uuid");c(this,"_apiKey");c(this,"_callToken");c(this,"_apiEnv");c(this,"_baseApiUrl");c(this,"_sessionKey");this._uuid=I.uuid(),this._apiKey=e,this._callToken=t,this._apiEnv=r,this._baseApiUrl=i}async authorize(){let r={session_data:{device_id:this._uuid,client_version:l.appVersion,client_type:"SDK_JS",auth_token:this._callToken,version:3},application_key:this._apiKey},e=await Cr(this._baseApiUrl,this._apiEnv),t=await Pi("auth.anonymLogin",r,!0,e);return I.isObject(t)&&!("error_msg"in t)?(this._sessionKey=t.session_key,!0):!1}async hangupConversation(r){let e={conversationId:r,reason:w.HUNGUP,application_key:this._apiKey,session_key:this._sessionKey},t=await Cr(this._baseApiUrl,this._apiEnv);await Pi("vchat.hangupConversation",e,!0,t)}};var ce,bi=null,ec={getCameras:b.getCameras,getMicrophones:b.getMicrophones,getOutput:b.getOutput,getVideoFacingMode:b.getVideoFacingMode,hasCamera:b.hasCamera,hasMicrophone:b.hasMicrophone,getSavedCamera:b.getSavedCamera,getSavedMicrophone:b.getSavedMicrophone,getSavedOutput:b.getSavedOutput,hasCameraPermission:b.hasCameraPermission,hasMicrophonePermission:b.hasMicrophonePermission,hasPermissions:b.hasPermissions,getUserMedia:b.getUserMedia,getUserVideo:b.getUserVideo,getUserAudio:b.getUserAudio,setResolution:b.setResolution,isBrowserSupported:b.isBrowserSupported,isScreenCapturingSupported:b.isScreenCapturingSupported,os:b.os,isMobile:b.isMobile,browserName:b.browserName,browserVersion:b.browserVersion,baseChromeVersion:b.baseChromeVersion,getAudioContext:b.getAudioContext,isAudioShareSupported:b.isAudioShareSupported},tc={participantMarkerCompare:I.participantMarkerCompare};function ic(n){bi=n}function rc(n){l.videoEffects=n}function ac(n){l.audioEffects=n}function nc(n,r=null,e={},t=1){l.vmoji=n,l.vmojiOptions={protocolVersion:t,renderingOptions:e},r&&n.setSDK(r)}async function sc(n){if(l.set(n),ce||(ce=new Xt),da.default.disableLog(!l.debug),d.toggle(l.debug),d.log(`Calls SDK ${l.sdkVersion}`,n),await b.init(),!b.isBrowserSupported())throw new G(ie.UNSUPPORTED);d.log("UserAgent:",navigator.userAgent),d.log("Screen resolution:",`${window.screen.width}x${window.screen.height}`),d.log("Permissions:",`Camera: ${b.hasCameraPermission()}, Mic: ${b.hasMicrophonePermission()}`),d.log("Simulcast:",`${n.simulcast} => ${l.simulcast}`)}async function oc(n,r=[se.AUDIO],e="",t=!1,i=!1,a,s){let o=[];return Array.isArray(n)?o=n.length?n:[]:n&&(o=[n]),Yn([],Ze.USER,r,e,t,i,a,o,s)}async function Yn(n,r=Ze.USER,e,t="",i=!1,a=!1,s,o,u){if(B.current())throw d.error("There is already active call"),new G(w.FAILED);return new B(ce,bi).onStart({opponentIds:n,opponentType:r,mediaOptions:e,payload:t,joiningAllowed:i,requireAuthToJoin:a,onlyAdminCanShareMovie:s,externalIds:o,onFastStart:u})}async function cc(n,r){return Qn(n,te.USER,void 0,r)}async function Qn(n,r=te.USER,e,t,i,a){if(n===B.id())throw new Error("Push has already been processed");return a&&ce.setUserId(a),new B(ce,bi).onPush(n,r,e,t,i)}async function dc(n,r){return n&&(l.authToken=n),r!==void 0&&l.apiBaseUrl!==r&&(l.apiBaseUrl=r,Wn()),ce.authorize()}async function lc(n=[se.AUDIO]){return ze().accept(n)}async function pc(){let n=B.current();if(n)return n.decline()}async function uc(n,r=[se.AUDIO]){return Xn(n,r)}async function Xn(n,r,e){if(B.current())throw d.error("There is already active call"),new G(w.FAILED);return new B(ce,bi).onJoin({conversationId:n,mediaOptions:r,chatId:e})}async function mc(n,r=[se.AUDIO],e,t,i){if(B.current())throw d.error("There is already active call"),new G(w.FAILED);return e&&(l.anonymToken=e),new B(ce,bi).onJoin({joinLink:n,mediaOptions:r,observedIds:t,payload:i})}async function hc(){let n=B.current();if(n)return n.hangup();B.hangupAfterInit()}async function _c(n,r){let e=Array.isArray(n)?n:[n],t=B.current();t&&await t.addParticipant(e,r)}async function gc(n,r){let e=B.current();if(e){let t=n.map(i=>I.composeUserId(i));await e.addParticipantLegacy(t,r)}}async function fc(n,r=!1){let e=await ce.getOkIdsByExternalIds([n]);return Zn(e[0],r)}async function Zn(n,r=!1){let e=B.current();if(e)try{await e.removeParticipant(I.composeUserId(n),r)}catch(t){d.warn(`Failed to remove participant ${n}. Perhaps he is no longer on the call. ${t}`)}}async function Sc(n,r){let e=B.current();if(n==="videoinput"&&dt.contains(r))return l.videoFacingMode=r,e?(b.isMobile()&&e.stopVideoTrack(),e.changeDevice(n)):void 0;if(!await b._saveDeviceId(n,r))throw new Error(`Device not found: ${r}`);if(e)return e.changeDevice(n)}async function vc(n){let r=typeof n=="object"?{...n,fastScreenSharing:n.captureScreen&&n.fastScreenSharing,captureAudio:n.captureScreen&&n.captureAudio&&l.audioShare}:{captureScreen:n,fastScreenSharing:!1,captureAudio:!1},e=B.current();return e?e.toggleScreenCapturing(r):Promise.reject()}function Ic(n){let r=B.current();r&&r.toggleAnimojiCapturing(n)}async function Ec(n,r=!1){let e=B.current();e&&await e.setVideoStream(n,r)}async function Tc(n){let r=B.current();r&&await r.toggleLocalVideo(n)}async function Rc(n){let r=B.current();r&&await r.toggleLocalAudio(n)}async function Cc(n){let r=B.current();if(r)return r.setLocalResolution(n)}async function Pc(n){let r=B.current();r&&await r.changePriorities(n)}async function yc(n,r){let e=B.current();if(e){let t;if(r){let[i]=await ce.getOkIdsByExternalIds([r]);t=I.composeParticipantId(i,te.USER,r.deviceIdx)}await e.changeParticipantState(n,t)}}async function bc(){let n=B.current();n&&await n.putHandsDown()}async function Mc(n){let r=B.current();r&&await r.updateDisplayLayout(n)}async function Ac(n,r,e=!1){let t=await ce.getOkIdsByExternalIds([n]);return es(t[0],q.getDeviceIdx(n),r,e)}async function es(n,r,e,t=!1){let i=B.current();i&&await i.grantRoles(I.composeParticipantId(n,te.USER,r),e,t)}async function Dc({externalId:n=null,muteStates:r,requestedMedia:e=[],roomId:t=null}){let i=null;return n&&(i=(await ce.getOkIdsByExternalIds([n]))[0]),ts({uid:i,muteStates:r,requestedMedia:e,deviceIdx:q.getDeviceIdx(n),roomId:t})}async function ts({uid:n=null,muteStates:r,requestedMedia:e=[],deviceIdx:t=0,roomId:i=null}){let a=B.current();if(a){let s=n?I.composeParticipantId(n,te.USER,t):null;await a.muteParticipant(s,r,e,i)}}async function wc(n,r=!1,e=null){let t=await ce.getOkIdsByExternalIds([n]);return is(t[0],r,q.getDeviceIdx(n),e)}async function is(n,r=!1,e=0,t=null){let i=B.current();i&&await i.pinParticipant(I.composeParticipantId(n,te.USER,e),r,t)}async function kc(n){let r=B.current();r&&await r.updateMediaModifiers(n)}async function Oc(n){let r=B.current();r&&await r.enableVideoSuspend(n)}async function xc(n){let r=B.current();r&&await r.enableVideoSuspendSuggest(n)}async function Nc(n){let r=B.current();r&&await r.changeOptions(n)}async function Lc(n,r=null){let e=null;return r&&(e=(await ce.getOkIdsByExternalIds([r]))[0]),rs(n,e)}async function rs(n,r=null){let e=B.current();if(e){let t=r?I.composeUserId(r):null;await e.chatMessage(n,t)}}async function Uc(n=10){let r=B.current();if(r)return r.chatHistory(n)}async function Bc(n,r=null){let e=null;return r&&(e=(await ce.getOkIdsByExternalIds([r]))[0]),as(n,e,q.getDeviceIdx(r))}async function as(n,r=null,e=0){let t=B.current();if(t){let i=r?I.composeParticipantId(r,te.USER,e):null;await t.customData(n,i)}}async function Fc(n="",r=!1,{onlyAdminCanShareMovie:e=!1}={}){return(await ce.createConversation(I.uuid(),n,r,{onlyAdminCanShareMovie:e})).join_link}async function Vc(n="",r=!1,{onlyAdminCanShareMovie:e=!1,audioOnly:t=!1}={},i){let a=q.fromIds(i),s=await ce.getOkIdsByExternalIds(a);return(await ce.createConversation(I.uuid(),n,r,{onlyAdminCanShareMovie:e,audienceMode:!0,audioOnly:t},s)).join_link}async function jc(){let n=B.current();return n?n.createJoinLink():Promise.reject()}async function Hc(){let n=B.current();return n?n.removeJoinLink():Promise.reject()}async function Gc(n,r){return ce.getAnonymTokenByLink(n,r)}function Wc(n){let r=B.current();r&&r.setVolume(n)}function Kc(n){l.forceRelayPolicy=n}async function $c(n=!1,r=null,e=null,t="DIRECT_LINK",i=null,a=null){let s=B.current();return s?s.startStream(n,r,e,t,i,a):Promise.reject()}async function qc(n=null){let r=B.current();return r?r.stopStream(n):Promise.reject()}async function zc(n=null){let r=B.current();return r?r.publishStream(n):Promise.reject()}async function Jc(n,r,e=!1,t=null){let i=B.current();if(!i)return Promise.reject();let a,s,o=[];if(r?.length&&o.push(...r),n&&o.push(n),o.length){let u=await ce.getParticipantIdsByExternalIds(o);n&&(a=u.get(n),u.delete(n)),s=Array.from(u.values())}return i.recordSetConf(a,s,e,t)}async function Yc(){let n=B.current();return n?n.getStreamInfo():Promise.reject()}async function Qc(n){let r=B.current();return r?r.addMovie(n):Promise.reject()}async function Xc(n){let r=B.current();return r?r.updateMovie(n):Promise.reject()}async function Zc(n){let r=B.current();return r?r.removeMovie(n):Promise.reject()}async function ed(n,r){let e=B.current();if(e){let t=[];for(let i of n){let a,s;i.addParticipantIds&&(a=(await ce.getOkIdsByExternalIds(i.addParticipantIds)).map(o=>I.composeUserId(o))),i.removeParticipantIds&&(s=(await ce.getOkIdsByExternalIds(i.removeParticipantIds)).map(o=>I.composeUserId(o))),t.push({id:i.id,name:i.name,participantCount:i.participantCount,addParticipantIds:a,removeParticipantIds:s,countdownSec:i.countdownSec})}return e.updateRooms(t,r)}return Promise.reject()}async function td(n,r){let e=B.current();return e?e.activateRooms(n,r):Promise.reject()}async function id(n=null,r=null){let e=B.current();if(!e)return Promise.reject();let t;if(r){let i=await ce.getOkIdsByExternalIds([r]),a=q.getDeviceIdx(r);t=I.composeParticipantId(i[0],te.USER,a)}return e.switchRoom(n,t)}async function rd(n){let r=B.current();return r?r.removeRooms(n):Promise.reject()}function ad(n){l.statisticsInterval=n;let r=B.current();if(r)return r.updateStatisticsInterval()}function nd(n){da.default.disableLog(!n),d.toggle(n)}function sd(n,...r){l.debugLog&&d.send(n,"[external]",...r)}async function od(){let n=ke.conversationId;if(!n)throw d.error("[uploadDebugLogs]","No conversation id found"),new Error("No conversation id found");let r=ke.collectLogs();if(r.length===0)throw d.error("[uploadDebugLogs]","No logs found"),new Error("No logs found");let e=ke.startTime,t=ke.endTime;try{return ce?.uploadDebugLogs(n,e,t,JSON.stringify(r))}catch(i){throw d.error("[uploadDebugLogs]","Error while uploading logs",i),new Error("Error while uploading logs",{cause:i})}}async function cd(n){let r=B.current();if(r)return r.videoEffect(n)}async function dd(n,r){let e=B.current();if(e)return e.audioEffect(n.length>0?n:null,r)}async function ld(n){let r=B.current();r&&await r.setAudioStream(n)}async function pd(n,r=null,e=null){let t=B.current();if(!t)return;let i=e??r?.id,a=null;if(r){let o=(await ce.getOkIdsByExternalIds([r]))[0];if(!o)throw new Error("Could not get user id to set animoji svg");a=I.composeParticipantId(o,te.USER,q.getDeviceIdx(r))}t.setAnimojiSvg(n,a,i)}function ud(n){let r=B.current();r&&r.setAnimojiFill(n)}async function md(n=null,r,e=!1){return ze().getWaitingHall(n,r,e)}async function hd(){return ze().getAudienceModeHands()}async function _d(n,r=!1){let e=ze(),t;if(n){let[i]=await ce.getOkIdsByExternalIds([n]);t=I.composeUserId(i)}return e.promoteParticipant(t,r)}async function gd(n=!1){return ze().requestPromotion(n)}async function fd(n=!1){return ze().acceptPromotion(n)}async function Sd(n){return ze().getParticipantListChunk(n)}async function vd(n){return ze().getParticipants(n)}async function Id(n){return ze().feedback(n)}function Ed(n,r,e){return ze().userFeedbackStats(n,r,e)}function Td(n,r={},e=!1){let t=B.current();t&&t.sendClientEvent(n,r,e)}async function Rd(n,r){return ze().enableFeatureForRoles(n,r)}function ze(){let n=B.current();if(!n)throw new Error("Conversation not found");return n}async function Cd(n){await ce.removeHistoryRecords(n)}async function Pd(n){let r=B.current();r&&await r.startAsr(n)}async function yd(n){let r=B.current();r&&await r.stopAsr(n)}async function bd(n){let r=B.current();r&&await r.requestAsr(n)}async function Md(n){let r=B.current();return r?r.startUrlSharing(n):Promise.reject()}async function Ad(){let n=B.current();return n?n.stopUrlSharing():Promise.reject()}function Dd(){return l.sdkVersion}
|