sip-connector 6.24.0 → 6.24.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,5 +1,5 @@
1
- import { l as c, B as V, N as $, E as P, s as q, S as nn } from "./SipConnector-1HoiCnsj.js";
2
- import { f as un, g as ln, i as Sn, c as dn, a as mn, d as fn, b as Cn, e as En, h as gn } from "./SipConnector-1HoiCnsj.js";
1
+ import { l as c, B as V, N as $, E as P, s as q, S as nn } from "./SipConnector-BmPmOGi6.js";
2
+ import { f as un, g as ln, i as Sn, c as dn, a as mn, d as fn, b as Cn, e as En, h as gn } from "./SipConnector-BmPmOGi6.js";
3
3
  import { debounce as J } from "ts-debounce";
4
4
  import { isCanceledError as Q } from "@krivega/cancelable-promise";
5
5
  import { default as hn } from "debug";
@@ -37,25 +37,25 @@ const G = "purgatory", A = (e) => e === G, k = (e) => () => (c("getRemoteStreams
37
37
  degradationPreference: a,
38
38
  ontrack: M
39
39
  }), p = () => {
40
- const { remoteCallerData: d } = e;
41
- return d.incomingNumber;
40
+ const { remoteCallerData: l } = e;
41
+ return l.incomingNumber;
42
42
  };
43
43
  let _ = !1, i;
44
- const l = (c("subscribeEnterConference: onEnterConference", f), C ?? f ? e.onSession("enterRoom", (d) => {
45
- c("enterRoom", { _room: d, isSuccessProgressCall: _ }), i = d, A(i) ? C && C() : f && f({ isSuccessProgressCall: _ });
44
+ const S = (c("subscribeEnterConference: onEnterConference", f), C ?? f ? e.onSession("enterRoom", (l) => {
45
+ c("enterRoom", { _room: l, isSuccessProgressCall: _ }), i = l, A(i) ? C && C() : f && f({ isSuccessProgressCall: _ });
46
46
  }) : () => {
47
- }), h = (d) => (c("onSuccess"), _ = !0, R(), g && g({ isPurgatory: A(i) }), e.onceRaceSession(["ended", "failed"], () => {
48
- l(), y && y();
49
- }), d), b = (d) => {
50
- throw c("onFail"), T && T(), l(), d;
47
+ }), h = (l) => (c("onSuccess"), _ = !0, R(), g && g({ isPurgatory: A(i) }), e.onceRaceSession(["ended", "failed"], () => {
48
+ S(), y && y();
49
+ }), l), b = (l) => {
50
+ throw c("onFail"), T && T(), S(), l;
51
51
  }, O = () => {
52
52
  c("onFinish"), E && E();
53
53
  };
54
54
  if (c("onBeforeProgressCall"), m) {
55
- const d = p();
56
- m(d);
55
+ const l = p();
56
+ m(l);
57
57
  }
58
- return v().then(h).catch(b).finally(O);
58
+ return v().then(h).catch((l) => b(l)).finally(O);
59
59
  }, ne = (e) => async (t) => {
60
60
  const {
61
61
  conference: s,
@@ -85,17 +85,17 @@ const G = "purgatory", A = (e) => e === G, k = (e) => () => (c("getRemoteStreams
85
85
  ontrack: v
86
86
  }));
87
87
  let _ = !1, i;
88
- const l = (c("subscribeEnterConference: onEnterConference", T), f ?? T ? e.onSession("enterRoom", (d) => {
89
- c("enterRoom", { _room: d, isSuccessProgressCall: _ }), i = d, A(i) ? f && f() : T && T({ isSuccessProgressCall: _ });
88
+ const S = (c("subscribeEnterConference: onEnterConference", T), f ?? T ? e.onSession("enterRoom", (l) => {
89
+ c("enterRoom", { _room: l, isSuccessProgressCall: _ }), i = l, A(i) ? f && f() : T && T({ isSuccessProgressCall: _ });
90
90
  }) : () => {
91
- }), h = (d) => (c("onSuccess"), _ = !0, M(), C && C({ isPurgatory: A(i) }), e.onceRaceSession(["ended", "failed"], () => {
92
- l(), R && R();
93
- }), d), b = (d) => {
94
- throw c("onFail"), E && E(), l(), d;
91
+ }), h = (l) => (c("onSuccess"), _ = !0, M(), C && C({ isPurgatory: A(i) }), e.onceRaceSession(["ended", "failed"], () => {
92
+ S(), R && R();
93
+ }), l), b = (l) => {
94
+ throw c("onFail"), E && E(), S(), l;
95
95
  }, O = () => {
96
96
  c("onFinish"), y && y();
97
97
  };
98
- return c("onBeforeProgressCall"), g && g(s), p().then(h).catch(b).finally(O);
98
+ return c("onBeforeProgressCall"), g && g(s), p().then(h).catch((l) => b(l)).finally(O);
99
99
  }, w = (e) => {
100
100
  if (!Q(e))
101
101
  throw e;
@@ -124,7 +124,7 @@ const G = "purgatory", A = (e) => e === G, k = (e) => () => (c("getRemoteStreams
124
124
  user: m,
125
125
  register: C
126
126
  }).then((E) => (c("connectToServer then"), { ua: E, isSuccessful: !0 })).catch(async (E) => (c("connectToServer catch: error", E), T === !0 ? e.disconnect().then(() => w(E)).catch(() => w(E)) : w(E)));
127
- }, se = (e) => async () => (c("disconnectFromServer"), e.disconnect().then(() => (c("disconnectFromServer: then"), !1)).catch((n) => (c("disconnectFromServer: catch", n), !1))), F = (e) => {
127
+ }, se = (e) => async () => (c("disconnectFromServer"), e.disconnect().then(() => (c("disconnectFromServer: then"), { isSuccessful: !0 })).catch((n) => (c("disconnectFromServer: catch", n), { isSuccessful: !1 }))), F = (e) => {
128
128
  const { url: n, cause: t } = e;
129
129
  let s = n;
130
130
  return (t === V || t === $) && (s = `${e.message.to.uri.user}@${e.message.to.uri.host}`), s;
@@ -214,7 +214,9 @@ const re = (e = new Error()) => {
214
214
  maxBitrate: e
215
215
  })), Re = ({ sipConnector: e }) => async ({ isP2P: t = !1 } = {}) => (c("stopShareSipConnector"), e.stopPresentation({
216
216
  isP2P: t
217
- }).catch(c)), he = 1e6, ye = ({
217
+ }).catch((s) => {
218
+ c(s);
219
+ })), he = 1e6, ye = ({
218
220
  sipConnector: e,
219
221
  maxBitrate: n = he
220
222
  }) => async ({
@@ -275,13 +277,13 @@ const re = (e = new Error()) => {
275
277
  onStartMicForced: p,
276
278
  onStartMicNotForced: _,
277
279
  onStopMicForced: i,
278
- onStopMicNotForced: S
280
+ onStopMicNotForced: d
279
281
  }) => {
280
- const l = n(
282
+ const S = n(
281
283
  y,
282
284
  R
283
285
  );
284
- a = t(l);
286
+ a = t(S);
285
287
  const h = n(
286
288
  M,
287
289
  v
@@ -289,7 +291,7 @@ const re = (e = new Error()) => {
289
291
  u = s(h);
290
292
  const b = n(p, _);
291
293
  m = r(b);
292
- const O = n(i, S);
294
+ const O = n(i, d);
293
295
  g = o(O);
294
296
  }, f = () => {
295
297
  a(), u(), m(), g();
@@ -362,10 +364,10 @@ const re = (e = new Error()) => {
362
364
  noRejectIsNotActual: e = !1,
363
365
  noRunIsNotActual: n = !1
364
366
  } = {}) => {
365
- const t = [], s = [], r = ({ task: i, index: S }) => {
366
- s.push({ task: i, index: S });
367
- }, o = (i, { task: S, index: l }) => {
368
- const h = s.find(({ task: b, index: O }) => S === b && l === O);
367
+ const t = [], s = [], r = ({ task: i, index: d }) => {
368
+ s.push({ task: i, index: d });
369
+ }, o = (i, { task: d, index: S }) => {
370
+ const h = s.find(({ task: b, index: O }) => d === b && S === O);
369
371
  if (!h)
370
372
  throw new Error("Task not found");
371
373
  if (h.promise)
@@ -373,38 +375,38 @@ const re = (e = new Error()) => {
373
375
  h.promise = i;
374
376
  }, a = ({
375
377
  task: i,
376
- index: S
378
+ index: d
377
379
  }) => {
378
- const l = s.find(({ task: h, index: b }) => i === h && S === b);
379
- if (l)
380
- return l.promise;
380
+ const S = s.find(({ task: h, index: b }) => i === h && d === b);
381
+ if (S)
382
+ return S.promise;
381
383
  }, u = ({ task: i }) => {
382
- const S = I(s);
383
- return (S == null ? void 0 : S.task) === i;
384
- }, m = ({ task: i, index: S }) => (r({ task: i, index: S }), async () => {
385
- let l = a({ task: i, index: S });
384
+ const d = I(s);
385
+ return (d == null ? void 0 : d.task) === i;
386
+ }, m = ({ task: i, index: d }) => (r({ task: i, index: d }), async () => {
387
+ let S = a({ task: i, index: d });
386
388
  const h = u({ task: i });
387
- return !l && n && !h ? Promise.resolve() : (l || (l = i({ isActual: h }), o(l, { task: i, index: S })), l);
389
+ return !S && n && !h ? Promise.resolve() : (S || (S = i({ isActual: h }), o(S, { task: i, index: d })), S);
388
390
  }), g = ({
389
391
  resolve: i,
390
- reject: S
391
- }) => ({ results: l, isSuccessful: h }) => {
392
- const b = l.length, O = t.length;
392
+ reject: d
393
+ }) => ({ results: S, isSuccessful: h }) => {
394
+ const b = S.length, O = t.length;
393
395
  if (b === O) {
394
- const d = I(l);
396
+ const l = I(S);
395
397
  if (h) {
396
- i(d);
398
+ i(l);
397
399
  return;
398
400
  }
399
- S(d);
401
+ d(l);
400
402
  return;
401
403
  }
402
404
  if (e) {
403
- const d = I(l);
404
- i(d);
405
+ const l = I(S);
406
+ i(l);
405
407
  return;
406
408
  }
407
- S(xe);
409
+ d(xe);
408
410
  };
409
411
  let C = !1;
410
412
  const f = () => {
@@ -414,15 +416,15 @@ const re = (e = new Error()) => {
414
416
  }, E = () => C, y = async () => (f(), Ue(t, E)), R = async () => {
415
417
  if (t.length === 0)
416
418
  throw Le;
417
- return new Promise((i, S) => {
418
- const l = g({ resolve: i, reject: S });
419
- y().then(l).catch(l);
419
+ return new Promise((i, d) => {
420
+ const S = g({ resolve: i, reject: d });
421
+ y().then(S).catch(S);
420
422
  });
421
423
  }, M = (i) => {
422
424
  if (typeof i != "function")
423
425
  throw Ve;
424
- const S = t.length;
425
- return t.push(m({ task: i, index: S })), R;
426
+ const d = t.length;
427
+ return t.push(m({ task: i, index: d })), R;
426
428
  }, v = async (i) => (M(i), R()), p = () => {
427
429
  t.length = 0, s.length = 0;
428
430
  }, _ = () => {
@@ -1,7 +1,7 @@
1
1
  /// <reference types="jest" />
2
2
  import RTCPeerConnectionMock from '../../__fixtures__/RTCPeerConnectionMock';
3
3
  declare const data: {
4
- mediaStream: import("webrtc-mock/dist/MediaStreamMock").default;
4
+ mediaStream: import("webrtc-mock").MediaStreamMock;
5
5
  conference: string;
6
6
  setOutgoingCall: jest.Mock<any, any, any>;
7
7
  setRemoteStreams: jest.Mock<any, any, any>;
@@ -1,3 +1,4 @@
1
+ import { URI } from '@krivega/jssip';
1
2
  export declare const LOCKED_SIP_WEB_SOCKET_SERVER_URL = "LOCKED_SIP_WEB_SOCKET_SERVER_URL";
2
3
  export declare const dataForConnectionWithAuthorization: {
3
4
  password: string;
@@ -98,11 +99,11 @@ export declare const dataForConnectionWithAuthorizationPasswordChanged: {
98
99
  };
99
100
  export declare const uaConfigurationWithAuthorization: {
100
101
  password: string;
101
- uri: string;
102
+ uri: URI;
102
103
  display_name: string;
103
104
  register: boolean;
104
105
  session_timers: boolean;
105
- sockets: import("../../__fixtures__/WebSocketInterface.mock").default[];
106
+ sockets: import("src/__fixtures__/WebSocketInterface.mock").default[];
106
107
  user_agent: string;
107
108
  sdp_semantics: string;
108
109
  register_expires: number;
@@ -111,11 +112,11 @@ export declare const uaConfigurationWithAuthorization: {
111
112
  };
112
113
  export declare const uaConfigurationWithAuthorizationPasswordChanged: {
113
114
  password: string;
114
- uri: string;
115
+ uri: URI;
115
116
  display_name: string;
116
117
  register: boolean;
117
118
  session_timers: boolean;
118
- sockets: import("../../__fixtures__/WebSocketInterface.mock").default[];
119
+ sockets: import("src/__fixtures__/WebSocketInterface.mock").default[];
119
120
  user_agent: string;
120
121
  sdp_semantics: string;
121
122
  register_expires: number;
@@ -125,5 +126,5 @@ export declare const uaConfigurationWithAuthorizationPasswordChanged: {
125
126
  export declare const oneWord = "a";
126
127
  export declare const twoWord = "ab";
127
128
  export declare const thirdWord = "abc";
128
- export declare const uriWithName: (name: string) => string;
129
+ export declare const uriWithName: (name: string, url?: string) => URI;
129
130
  export { uaConfigurationWithoutAuthorization, uaConfigurationWithoutAuthorizationWithoutDisplayName, } from '../../__fixtures__';
@@ -1,9 +1,3 @@
1
- /**
2
- * Determines if it has valid uri.
3
- *
4
- * @param {string} uri The uri for check
5
- * @param {string} url The base url
6
- * @returns {boolean} True if has valid uri, False otherwise.
7
- */
8
- declare const hasValidUri: (uri: string, url?: string) => boolean;
1
+ import type { URI } from '@krivega/jssip';
2
+ declare const hasValidUri: ({ scheme, user, host }: URI, url?: string) => boolean;
9
3
  export default hasValidUri;
@@ -7,5 +7,5 @@ declare const resolveInitUaPromised: (sipConnector: SipConnector) => (state: {
7
7
  name: string;
8
8
  password: string;
9
9
  isRegisteredUser: boolean;
10
- }) => Promise<unknown>;
10
+ }) => Promise<boolean>;
11
11
  export default resolveInitUaPromised;
@@ -1,3 +1,7 @@
1
1
  import type SipConnector from '../SipConnector';
2
- declare const resolveDisconnectFromServer: (sipConnector: SipConnector) => () => Promise<boolean>;
2
+ declare const resolveDisconnectFromServer: (sipConnector: SipConnector) => () => Promise<{
3
+ isSuccessful: boolean;
4
+ } | {
5
+ isSuccessful: boolean;
6
+ }>;
3
7
  export default resolveDisconnectFromServer;
@@ -1,3 +1,3 @@
1
- export declare const PURGATORY_CONFERENCE_NUMBER: "purgatory";
1
+ export declare const PURGATORY_CONFERENCE_NUMBER = "purgatory";
2
2
  declare const hasPurgatory: (room?: string) => boolean;
3
3
  export default hasPurgatory;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "sip-connector",
3
- "version": "6.24.0",
3
+ "version": "6.24.2",
4
4
  "description": "Module for connect to Vinteo server",
5
5
  "keywords": [
6
6
  "webrtc",
@@ -63,27 +63,27 @@
63
63
  },
64
64
  "dependencies": {
65
65
  "@krivega/cancelable-promise": "^1.1.0",
66
- "@krivega/jssip": "^3.23.3",
66
+ "@krivega/jssip": "^3.23.8",
67
67
  "debug": "^4.3.4",
68
68
  "events-constructor": "^1.2.2",
69
- "sequent-promises": "^1.0.0",
69
+ "sequent-promises": "^1.0.2",
70
70
  "stack-promises": "^1.0.2",
71
71
  "ts-debounce": "^4.0.0",
72
72
  "webrtc-mock": "^1.0.2"
73
73
  },
74
74
  "devDependencies": {
75
- "@babel/preset-typescript": "^7.23.3",
76
- "@commitlint/cli": "^18.6.1",
77
- "@commitlint/config-conventional": "^18.6.2",
75
+ "@babel/preset-typescript": "^7.24.1",
76
+ "@commitlint/cli": "^19.2.1",
77
+ "@commitlint/config-conventional": "^19.1.0",
78
78
  "@nabla/vite-plugin-eslint": "^2.0.2",
79
79
  "@types/debug": "^4.1.12",
80
80
  "@types/jest": "^29.5.12",
81
- "@typescript-eslint/eslint-plugin": "^7.1.0",
82
- "@typescript-eslint/parser": "^7.1.0",
81
+ "@typescript-eslint/eslint-plugin": "^7.3.1",
82
+ "@typescript-eslint/parser": "^7.3.1",
83
83
  "cross-env": "^7.0.3",
84
84
  "eslint": "^8.57.0",
85
85
  "eslint-config-airbnb-base": "^15.0.0",
86
- "eslint-config-airbnb-typescript": "^17.1.0",
86
+ "eslint-config-airbnb-typescript": "^18.0.0",
87
87
  "eslint-config-prettier": "^9.1.0",
88
88
  "eslint-import-resolver-typescript": "^3.6.1",
89
89
  "eslint-plugin-flowtype": "^8.0.3",
@@ -102,10 +102,10 @@
102
102
  "ts-jest": "^29.1.2",
103
103
  "ts-node": "^10.9.2",
104
104
  "tsc-files": "^1.1.4",
105
- "typescript": "^5.3.3",
106
- "vite": "^5.1.4",
105
+ "typescript": "^5.4.2",
106
+ "vite": "^5.2.1",
107
107
  "vite-plugin-dts": "^3.7.3",
108
- "vite-tsconfig-paths": "^4.3.1"
108
+ "vite-tsconfig-paths": "^4.3.2"
109
109
  },
110
110
  "peerDependencies": {
111
111
  "@krivega/cancelable-promise": "^1.1.0",
@@ -1 +0,0 @@
1
- "use strict";var Rt=Object.defineProperty;var It=(r,e,t)=>e in r?Rt(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t;var i=(r,e,t)=>(It(r,typeof e!="symbol"?e+"":e,t),t);const S=require("@krivega/cancelable-promise"),Pe=require("events-constructor"),B=require("debug"),mt="Connection Error",He="Request Timeout",ft="SIP Failure Code",Ot="Internal Error",Dt="Busy",V="Rejected",Mt="Redirected",Pt="Unavailable",qe="Not Found",pt="Address Incomplete",vt="Incompatible SDP",bt="Missing SDP",wt="Authentication Error",ke="Terminated",yt="WebRTC Error",We="Canceled",Ut="No Answer",Lt="Expires",Ht="No ACK",qt="Dialog Error",kt="User Denied Media Access",Fe="Bad Media Description",Wt="RTP Timeout",Ft=Object.freeze(Object.defineProperty({__proto__:null,ADDRESS_INCOMPLETE:pt,AUTHENTICATION_ERROR:wt,BAD_MEDIA_DESCRIPTION:Fe,BUSY:Dt,BYE:ke,CANCELED:We,CONNECTION_ERROR:mt,DIALOG_ERROR:qt,EXPIRES:Lt,INCOMPATIBLE_SDP:vt,INTERNAL_ERROR:Ot,MISSING_SDP:bt,NOT_FOUND:qe,NO_ACK:Ht,NO_ANSWER:Ut,REDIRECTED:Mt,REJECTED:V,REQUEST_TIMEOUT:He,RTP_TIMEOUT:Wt,SIP_FAILURE_CODE:ft,UNAVAILABLE:Pt,USER_DENIED_MEDIA_ACCESS:kt,WEBRTC_ERROR:yt},Symbol.toStringTag,{value:"Module"})),Y="incomingCall",x="declinedIncomingCall",G="failedIncomingCall",$="terminatedIncomingCall",H="connecting",I="connected",T="disconnected",M="newRTCSession",m="registered",X="unregistered",f="registrationFailed",Be="newMessage",J="sipEvent",z="availableSecondRemoteStream",Q="notAvailableSecondRemoteStream",K="mustStopPresentation",P="shareState",j="enterRoom",Z="useLicense",ee="peerconnection:confirmed",te="peerconnection:ontrack",p="channels",ne="channels:notify",se="ended:fromserver",ie="main-cam-control",re="admin-stop-main-cam",oe="admin-start-main-cam",ae="admin-stop-mic",ce="admin-start-mic",v="admin-force-sync-media-state",Ee="participant:added-to-list-moderators",_e="participant:removed-from-list-moderators",he="participant:move-request-to-stream",de="participation:accepting-word-request",le="participation:cancelling-word-request",ue="webcast:started",Te="webcast:stopped",Se="account:changed",Ne="account:deleted",ge="conference:participant-token-issued",O="ended",Ve="sending",Ye="reinvite",xe="replaces",Ge="refer",$e="progress",Xe="accepted",b="confirmed",w="peerconnection",C="failed",Je="muted",ze="unmuted",Ce="newDTMF",Ae="newInfo",Qe="hold",Ke="unhold",je="update",Ze="sdp",et="icecandidate",tt="getusermediafailed",nt="peerconnection:createofferfailed",st="peerconnection:createanswerfailed",it="peerconnection:setlocaldescriptionfailed",rt="peerconnection:setremotedescriptionfailed",ot="presentation:start",at="presentation:started",ct="presentation:end",Re="presentation:ended",y="presentation:failed",Bt=Object.freeze(Object.defineProperty({__proto__:null,ACCEPTED:Xe,ACCOUNT_CHANGED:Se,ACCOUNT_DELETED:Ne,ADMIN_FORCE_SYNC_MEDIA_STATE:v,ADMIN_START_MAIN_CAM:oe,ADMIN_START_MIC:ce,ADMIN_STOP_MAIN_CAM:re,ADMIN_STOP_MIC:ae,AVAILABLE_SECOND_REMOTE_STREAM_EVENT:z,CHANNELS:p,CHANNELS_NOTIFY:ne,CONFERENCE_PARTICIPANT_TOKEN_ISSUED:ge,CONFIRMED:b,CONNECTED:I,CONNECTING:H,DECLINED_INCOMING_CALL:x,DISCONNECTED:T,ENDED:O,ENDED_FROM_SERVER:se,ENTER_ROOM:j,FAILED:C,FAILED_INCOMING_CALL:G,GET_USER_MEDIA_FAILED:tt,HOLD:Qe,ICE_CANDIDATE:et,INCOMING_CALL:Y,MAIN_CAM_CONTROL:ie,MUST_STOP_PRESENTATION_EVENT:K,MUTED:Je,NEW_DTMF:Ce,NEW_INFO:Ae,NEW_MESSAGE:Be,NEW_RTC_SESSION:M,NOT_AVAILABLE_SECOND_REMOTE_STREAM_EVENT:Q,PARTICIPANT_ADDED_TO_LIST_MODERATORS:Ee,PARTICIPANT_MOVE_REQUEST_TO_STREAM:he,PARTICIPANT_REMOVED_FROM_LIST_MODERATORS:_e,PARTICIPATION_ACCEPTING_WORD_REQUEST:de,PARTICIPATION_CANCELLING_WORD_REQUEST:le,PEER_CONNECTION:w,PEER_CONNECTION_CONFIRMED:ee,PEER_CONNECTION_CREATE_ANSWER_FAILED:st,PEER_CONNECTION_CREATE_OFFER_FAILED:nt,PEER_CONNECTION_ONTRACK:te,PEER_CONNECTION_SET_LOCAL_DESCRIPTION_FAILED:it,PEER_CONNECTION_SET_REMOTE_DESCRIPTION_FAILED:rt,PRESENTATION_END:ct,PRESENTATION_ENDED:Re,PRESENTATION_FAILED:y,PRESENTATION_START:ot,PRESENTATION_STARTED:at,PROGRESS:$e,REFER:Ge,REGISTERED:m,REGISTRATION_FAILED:f,REINVITE:Ye,REPLACES:xe,SDP:Ze,SENDING:Ve,SHARE_STATE:P,SIP_EVENT:J,TERMINATED_INCOMING_CALL:$,UNHOLD:Ke,UNMUTED:ze,UNREGISTERED:X,UPDATE:je,USE_LICENSE:Z,WEBCAST_STARTED:ue,WEBCAST_STOPPED:Te},Symbol.toStringTag,{value:"Module"})),Et=[Y,x,$,G,de,le,he,ne,ge,Se,Ne,ue,Te,Ee,_e],Ie=[H,I,T,M,m,X,f,Be,J],_t=[z,Q,K,P,j,Z,ee,te,p,se,ie,oe,re,ae,ce,v],me=[O,H,Ve,Ye,xe,Ge,$e,Xe,b,w,C,Je,ze,Ce,Ae,Qe,Ke,je,Ze,et,tt,nt,st,it,rt,ot,at,ct,Re,y],fe=[...Ie,...Et],Oe=[...me,..._t],Vt=Object.freeze(Object.defineProperty({__proto__:null,SESSION_EVENT_NAMES:Oe,SESSION_JSSIP_EVENT_NAMES:me,SESSION_SYNTHETICS_EVENT_NAMES:_t,UA_EVENT_NAMES:fe,UA_JSSIP_EVENT_NAMES:Ie,UA_SYNTHETICS_EVENT_NAMES:Et},Symbol.toStringTag,{value:"Module"})),Yt=r=>{const e=[];return r&&e.push(`X-Vinteo-Remote: ${r}`),e},xt="content-type",Gt="x-webrtc-enter-room",q="application/vinteo.webrtc.sharedesktop",$t="application/vinteo.webrtc.roomname",Xt="application/vinteo.webrtc.channels",Jt="application/vinteo.webrtc.mediastate",zt="application/vinteo.webrtc.refusal",pe="application/vinteo.webrtc.maincam",Qt="application/vinteo.webrtc.mic",Kt="application/vinteo.webrtc.uselic",jt="X-WEBRTC-USE-LICENSE",ve="X-WEBRTC-INPUT-CHANNELS",be="X-WEBRTC-OUTPUT-CHANNELS",Zt="X-WEBRTC-MAINCAM",en="X-WEBRTC-MIC",we="X-WEBRTC-SYNC",tn="X-WEBRTC-MAINCAM-RESOLUTION",nn="X-WEBRTC-MEDIA-STATE",sn="X-Vinteo-Media-Type",rn="X-Vinteo-MainCam-State",on="X-Vinteo-Mic-State",an="application/vinteo.webrtc.notify",cn="X-VINTEO-NOTIFY",D="x-webrtc-share-state",En=`${D}: LETMESTARTPRESENTATION`,_n=`${D}: STOPPRESENTATION`,ht="YOUCANRECEIVECONTENT",dt="CONTENTEND",hn="YOUMUSTSTOPSENDCONTENT",dn=`${D}: ${ht}`,ln=`${D}: ${dt}`,un="X-WEBRTC-REQUEST-ENABLE-MEDIA-DEVICE",Tn=`${un}: LETMESTARTMAINCAM`,De="sip-connector",W=B(De),Sn=()=>{B.enable(De)},Nn=()=>{B.enable(`-${De}`)};var A=(r=>(r.PAUSE_MAIN_CAM="PAUSEMAINCAM",r.RESUME_MAIN_CAM="RESUMEMAINCAM",r.MAX_MAIN_CAM_RESOLUTION="MAXMAINCAMRESOLUTION",r.ADMIN_STOP_MAIN_CAM="ADMINSTOPMAINCAM",r.ADMIN_START_MAIN_CAM="ADMINSTARTMAINCAM",r))(A||{}),U=(r=>(r.ADMIN_STOP_MIC="ADMINSTOPMIC",r.ADMIN_START_MIC="ADMINSTARTMIC",r))(U||{}),L=(r=>(r.ADMIN_SYNC_FORCED="1",r.ADMIN_SYNC_NOT_FORCED="0",r))(L||{}),lt=(r=>(r.AUDIO="AUDIO",r.VIDEO="VIDEO",r.AUDIOPLUSPRESENTATION="AUDIOPLUSPRESENTATION",r))(lt||{});function ye(r){return e=>`sip:${e}@${r}`}const gn=(r,e)=>()=>Math.floor(Math.random()*(e-r))+r,Ue=r=>r.trim().replaceAll(" ","_"),Cn=gn(1e5,99999999),k=(r,{videoMode:e,audioMode:t}={})=>{if(!r||e==="recvonly"&&t==="recvonly")return;const n=t==="recvonly"?[]:r.getAudioTracks(),s=e==="recvonly"?[]:r.getVideoTracks(),o=[...n,...s],a=new MediaStream(o);return a.getTracks=()=>[...a.getAudioTracks(),...a.getVideoTracks()],a},An=r=>r.some(t=>{const{kind:n}=t;return n==="video"}),Rn="Error decline with 603",In=r=>r.message===Rn,mn=(r,e)=>r.find(t=>t.track&&e.getTracks().includes(t.track)),ut=1,Tt=r=>(e,t)=>t!==void 0&&e!==t||t===void 0&&e!==r,fn=Tt(ut),On=(r,e)=>{const t=r===void 0?void 0:Math.max(r,ut);if(t!==void 0&&fn(t,e))return t},Dn=Tt(),Mn=(r,e)=>{if(Dn(r,e))return r},St=async(r,e,t)=>{const n=r.getParameters();(n.encodings===void 0||n.encodings.length===0)&&(n.encodings=[{}]);const[s]=n.encodings,o=s.scaleResolutionDownBy,a=On(e.scaleResolutionDownBy,o);let c=!1;a!==void 0&&(n.encodings[0].scaleResolutionDownBy=a,c=!0);const E=s.maxBitrate,h=Mn(e.maxBitrate,E);return h!==void 0&&(n.encodings[0].maxBitrate=h,c=!0),c?(t&&t(n),r.setParameters(n).then(()=>({parameters:n,isChanged:c}))):{parameters:n,isChanged:c}},Pn=async(r,e,t)=>{const n=mn(r,e);if(n)return St(n,{maxBitrate:t})},pn=486,vn=487,F="local",Le="remote",bn=(r=new Error)=>{const{originator:e,cause:t}=r;return S.isCanceledError(r)?!0:typeof t=="string"?t===He||t===V||e===F&&(t===We||t===ke):!1},N="SipConnector",wn="channels",yn="WebcastStarted",Un="WebcastStopped",Ln="accountChanged",Hn="accountDeleted",qn="addedToListModerators",kn="removedFromListModerators",Wn="ParticipationRequestAccepted",Fn="ParticipationRequestRejected",Bn="ParticipantMovedToWebcast",Vn="ConferenceParticipantTokenIssued";class Yn{constructor({JsSIP:e}){i(this,"_isRegisterConfig",!1);i(this,"_connectionConfiguration",{});i(this,"_remoteStreams",{});i(this,"JsSIP");i(this,"_sessionEvents");i(this,"_uaEvents");i(this,"_cancelableConnect");i(this,"_cancelableInitUa");i(this,"_cancelableDisconnect");i(this,"_cancelableSet");i(this,"_cancelableCall");i(this,"_cancelableAnswer");i(this,"_cancelableSendDTMF");i(this,"getSipServerUrl",e=>e);i(this,"promisePendingStartPresentation");i(this,"promisePendingStopPresentation");i(this,"ua");i(this,"session");i(this,"incomingSession");i(this,"_streamPresentationCurrent");i(this,"socket");i(this,"connect",async e=>(this._cancelRequests(),this._cancelableConnect.request(e)));i(this,"initUa",async e=>this._cancelableInitUa.request(e));i(this,"set",async e=>this._cancelableSet.request(e));i(this,"call",async e=>this._cancelableCall.request(e));i(this,"disconnect",async()=>(this._cancelRequests(),this._disconnectWithoutCancelRequests()));i(this,"answerToIncomingCall",async e=>this._cancelableAnswer.request(e));i(this,"sendDTMF",async e=>this._cancelableSendDTMF.request(e));i(this,"hangUp",async()=>(this._cancelRequests(),this._hangUpWithoutCancelRequests()));i(this,"tryRegister",async()=>{if(!this.isRegisterConfig)throw new Error("Config is not registered");this._uaEvents.trigger(H,void 0);try{await this.unregister()}catch(e){W("tryRegister",e)}return this.register()});i(this,"declineToIncomingCall",async({statusCode:e=vn}={})=>new Promise((t,n)=>{if(!this.isAvailableIncomingCall){n(new Error("no incomingSession"));return}const s=this.incomingSession,o=this.remoteCallerData;this._cancelableCall.cancelRequest(),this._cancelableAnswer.cancelRequest(),this.removeIncomingSession(),this._uaEvents.trigger(x,o),t(s.terminate({status_code:e}))}));i(this,"busyIncomingCall",async()=>this.declineToIncomingCall({statusCode:pn}));i(this,"removeIncomingSession",()=>{delete this.incomingSession});i(this,"handleNewRTCSession",({originator:e,session:t})=>{if(e===Le){this.incomingSession=t;const n=this.remoteCallerData;t.on(C,s=>{this.removeIncomingSession(),s.originator===F?this._uaEvents.trigger($,n):this._uaEvents.trigger(G,n)}),this._uaEvents.trigger(Y,n)}});i(this,"_connect",async e=>this.initUa(e).then(async()=>this._start()));i(this,"_initUa",async({user:e,password:t,sipServerUrl:n,sipWebSocketServerURL:s,remoteAddress:o,sdpSemantics:a,sessionTimers:c,registerExpires:E,connectionRecoveryMinInterval:h,connectionRecoveryMaxInterval:_,userAgent:u,displayName:l="",register:d=!1,extraHeaders:g=[]})=>{if(!n)throw new Error("sipServerUrl is required");if(!s)throw new Error("sipWebSocketServerURL is required");if(d&&!e)throw new Error("user is required for authorized connection");if(d&&!t)throw new Error("password is required for authorized connection");this._connectionConfiguration={sipServerUrl:n,displayName:l,register:d,user:e,password:t},this.getSipServerUrl=ye(n),this.socket=new this.JsSIP.WebSocketInterface(s),this.ua&&await this._disconnectWithoutCancelRequests(),this._isRegisterConfig=!!d;const{socket:R}=this;this.ua=this._createUa({user:e,password:t,socket:R,displayName:l,register:d,sdpSemantics:a,sessionTimers:c,registerExpires:E,connectionRecoveryMinInterval:h,connectionRecoveryMaxInterval:_,userAgent:u,getSipServerUrl:this.getSipServerUrl}),this._uaEvents.eachTriggers((gt,Ct)=>{const Me=Ie.find(At=>At===Ct);Me&&this.ua&&this.ua.on(Me,gt)});const Nt=[...Yt(o),...g];return this.ua.registrator().setExtraHeaders(Nt),this.ua});i(this,"_createUa",({user:e,password:t,socket:n,displayName:s,getSipServerUrl:o,register:a=!1,sdpSemantics:c="plan-b",sessionTimers:E=!1,registerExpires:h=60*5,connectionRecoveryMinInterval:_=2,connectionRecoveryMaxInterval:u=6,userAgent:l})=>{if(a&&!t)throw new Error("password is required for authorized connection");const d=a&&e?e.trim():`${Cn()}`,g=o(d),R={password:t,register:a,uri:g,display_name:Ue(s),user_agent:l,sdp_semantics:c,sockets:[n],session_timers:E,register_expires:h,connection_recovery_min_interval:_,connection_recovery_max_interval:u};return new this.JsSIP.UA(R)});i(this,"_start",async()=>new Promise((e,t)=>{const{ua:n}=this;if(!n){t(new Error("this.ua is not initialized"));return}const s=()=>{c(),e(n)},o=E=>{c(),t(E)},a=()=>{this.isRegisterConfig?(this.on(m,s),this.on(f,o)):this.on(I,s),this.on(T,o)},c=()=>{this.off(m,s),this.off(f,o),this.off(I,s),this.off(T,o)};a(),this.on(M,this.handleNewRTCSession),n.start()}));i(this,"_set",async({displayName:e,password:t})=>new Promise((n,s)=>{const{ua:o}=this;if(!o){s(new Error("this.ua is not initialized"));return}let a=!1,c=!1;e!==void 0&&e!==this._connectionConfiguration.displayName&&(a=o.set("display_name",Ue(e)),this._connectionConfiguration.displayName=e),t!==void 0&&t!==this._connectionConfiguration.password&&(c=o.set("password",t),this._connectionConfiguration.password=t);const E=a||c;c&&this.isRegisterConfig?this.register().then(()=>{n(E)}).catch(s):E?n(E):s(new Error("nothing changed"))}));i(this,"_disconnectWithoutCancelRequests",async()=>this._cancelableDisconnect.request());i(this,"_disconnect",async()=>{this.off(M,this.handleNewRTCSession);const e=new Promise(t=>{this.once(T,()=>{delete this.ua,t()})});return this.ua?(await this._hangUpWithoutCancelRequests(),this.ua?this.ua.stop():this._uaEvents.trigger(T,void 0)):this._uaEvents.trigger(T,void 0),e});i(this,"_call",async({number:e,mediaStream:t,extraHeaders:n=[],ontrack:s,iceServers:o,videoMode:a,audioMode:c,degradationPreference:E,offerToReceiveAudio:h=!0,offerToReceiveVideo:_=!0})=>new Promise((u,l)=>{const{ua:d}=this;if(!d){l(new Error("this.ua is not initialized"));return}this._connectionConfiguration.number=e,this._connectionConfiguration.answer=!1,this._handleCall({ontrack:s}).then(u).catch(l),this.session=d.call(this.getSipServerUrl(e),{extraHeaders:n,mediaStream:k(t,{videoMode:a,audioMode:c}),eventHandlers:this._sessionEvents.triggers,videoMode:a,audioMode:c,degradationPreference:E,pcConfig:{iceServers:o},rtcOfferConstraints:{offerToReceiveAudio:h,offerToReceiveVideo:_}})}));i(this,"_answer",async({mediaStream:e,ontrack:t,extraHeaders:n=[],iceServers:s,videoMode:o,audioMode:a,degradationPreference:c})=>new Promise((E,h)=>{if(!this.isAvailableIncomingCall){h(new Error("no incomingSession"));return}this.session=this.incomingSession,this.removeIncomingSession();const{session:_}=this;if(!_){h(new Error("No session established"));return}this._sessionEvents.eachTriggers((l,d)=>{const g=me.find(R=>R===d);g&&_.on(g,l)}),this._connectionConfiguration.answer=!0,this._connectionConfiguration.number=_.remote_identity.uri.user,this._handleCall({ontrack:t}).then(E).catch(h);const u=k(e,{videoMode:o,audioMode:a});_.answer({extraHeaders:n,videoMode:o,audioMode:a,degradationPreference:c,mediaStream:u,pcConfig:{iceServers:s}})}));i(this,"_handleCall",async({ontrack:e})=>new Promise((t,n)=>{const s=()=>{this.onSession(w,_),this.onSession(b,u)},o=()=>{this.offSession(w,_),this.offSession(b,u)},a=()=>{this.onSession(C,E),this.onSession(O,E)},c=()=>{this.offSession(C,E),this.offSession(O,E)},E=l=>{o(),c(),n(l)};let h;const _=({peerconnection:l})=>{h=l,h.ontrack=d=>{this._sessionEvents.trigger(te,h),e&&e(d)}},u=()=>{h&&this._sessionEvents.trigger(ee,h),o(),c(),t(h)};s(),a()}));i(this,"_restoreSession",()=>{this._resetPresentation(),delete this._connectionConfiguration.number,delete this.session,this._remoteStreams={}});i(this,"_sendDTMF",async e=>new Promise((t,n)=>{const{session:s}=this;if(!s){n(new Error("No session established"));return}this.onceSession(Ce,({originator:o})=>{o===F&&t()}),s.sendDTMF(e,{duration:120,interToneGap:600})}));i(this,"_hangUpWithoutCancelRequests",async()=>{if(this.ua&&this.session){const{session:e}=this;this._streamPresentationCurrent&&await this.stopPresentation(),this._restoreSession(),e.isEnded()||e.terminate()}});i(this,"_handleShareState",e=>{switch(e){case ht:{this._sessionEvents.trigger(z,void 0);break}case dt:{this._sessionEvents.trigger(Q,void 0);break}case hn:{this._sessionEvents.trigger(K,void 0);break}}});i(this,"_maybeTriggerChannels",e=>{const t=e.getHeader(ve),n=e.getHeader(be);if(t&&n){const s={inputChannels:t,outputChannels:n};this._sessionEvents.trigger(p,s)}});i(this,"_handleNotify",e=>{switch(e.cmd){case wn:{const t=e;this._triggerChannelsNotify(t);break}case yn:{const t=e;this._triggerWebcastStartedNotify(t);break}case Un:{const t=e;this._triggerWebcastStoppedNotify(t);break}case qn:{const t=e;this._triggerAddedToListModeratorsNotify(t);break}case kn:{const t=e;this._triggerRemovedFromListModeratorsNotify(t);break}case Wn:{const t=e;this._triggerParticipationAcceptingWordRequest(t);break}case Fn:{const t=e;this._triggerParticipationCancellingWordRequest(t);break}case Bn:{const t=e;this._triggerParticipantMoveRequestToStream(t);break}case Ln:{this._triggerAccountChangedNotify();break}case Hn:{this._triggerAccountDeletedNotify();break}case Vn:{const t=e;this._triggerConferenceParticipantTokenIssued(t);break}default:W("unknown cmd",e.cmd)}});i(this,"_triggerRemovedFromListModeratorsNotify",({conference:e})=>{const t={conference:e};this._uaEvents.trigger(_e,t)});i(this,"_triggerAddedToListModeratorsNotify",({conference:e})=>{const t={conference:e};this._uaEvents.trigger(Ee,t)});i(this,"_triggerWebcastStartedNotify",({body:{conference:e,type:t}})=>{const n={conference:e,type:t};this._uaEvents.trigger(ue,n)});i(this,"_triggerWebcastStoppedNotify",({body:{conference:e,type:t}})=>{const n={conference:e,type:t};this._uaEvents.trigger(Te,n)});i(this,"_triggerAccountChangedNotify",()=>{this._uaEvents.trigger(Se,void 0)});i(this,"_triggerAccountDeletedNotify",()=>{this._uaEvents.trigger(Ne,void 0)});i(this,"_triggerConferenceParticipantTokenIssued",({body:{conference:e,participant:t,jwt:n}})=>{const s={conference:e,participant:t,jwt:n};this._uaEvents.trigger(ge,s)});i(this,"_triggerChannelsNotify",e=>{const t=e.input,n=e.output,s={inputChannels:t,outputChannels:n};this._uaEvents.trigger(ne,s)});i(this,"_triggerParticipationAcceptingWordRequest",({body:{conference:e}})=>{const t={conference:e};this._uaEvents.trigger(de,t)});i(this,"_triggerParticipationCancellingWordRequest",({body:{conference:e}})=>{const t={conference:e};this._uaEvents.trigger(le,t)});i(this,"_triggerParticipantMoveRequestToStream",({body:{conference:e}})=>{const t={conference:e};this._uaEvents.trigger(he,t)});i(this,"_triggerEnterRoom",e=>{const t=e.getHeader(Gt);this._sessionEvents.trigger(j,t)});i(this,"_triggerShareState",e=>{const t=e.getHeader(D);this._sessionEvents.trigger(P,t)});i(this,"_triggerMainCamControl",e=>{const t=e.getHeader(Zt),n=e.getHeader(we),s=n===L.ADMIN_SYNC_FORCED;if(t===A.ADMIN_START_MAIN_CAM)this._sessionEvents.trigger(oe,{isSyncForced:s});else if(t===A.ADMIN_STOP_MAIN_CAM)this._sessionEvents.trigger(re,{isSyncForced:s});else if((t===A.RESUME_MAIN_CAM||t===A.PAUSE_MAIN_CAM)&&n)this._sessionEvents.trigger(v,{isSyncForced:s});else{const o=e.getHeader(tn);this._sessionEvents.trigger(ie,{mainCam:t,resolutionMainCam:o})}});i(this,"_triggerMicControl",e=>{const t=e.getHeader(en),s=e.getHeader(we)===L.ADMIN_SYNC_FORCED;t===U.ADMIN_START_MIC?this._sessionEvents.trigger(ce,{isSyncForced:s}):t===U.ADMIN_STOP_MIC&&this._sessionEvents.trigger(ae,{isSyncForced:s})});i(this,"_triggerUseLicense",e=>{const t=e.getHeader(jt);this._sessionEvents.trigger(Z,t)});i(this,"_handleNewInfo",e=>{const{originator:t}=e;if(t!=="remote")return;const{request:n}=e,s=n.getHeader(xt);if(s)switch(s){case $t:{this._triggerEnterRoom(n),this._maybeTriggerChannels(n);break}case an:{this._maybeHandleNotify(n);break}case q:{this._triggerShareState(n);break}case pe:{this._triggerMainCamControl(n);break}case Qt:{this._triggerMicControl(n);break}case Kt:{this._triggerUseLicense(n);break}}});i(this,"_handleSipEvent",({request:e})=>{this._maybeHandleNotify(e)});i(this,"_maybeHandleNotify",e=>{const t=e.getHeader(cn);if(t){const n=JSON.parse(t);this._handleNotify(n)}});i(this,"_handleEnded",e=>{const{originator:t}=e;t===Le&&this._sessionEvents.trigger(se,e),this._restoreSession()});this.JsSIP=e,this._sessionEvents=new Pe(Oe),this._uaEvents=new Pe(fe),this._cancelableConnect=new S.CancelableRequest(this._connect,{moduleName:N,afterCancelRequest:()=>{this._cancelableInitUa.cancelRequest(),this._cancelableDisconnect.cancelRequest()}}),this._cancelableInitUa=new S.CancelableRequest(this._initUa,{moduleName:N}),this._cancelableDisconnect=new S.CancelableRequest(this._disconnect,{moduleName:N}),this._cancelableSet=new S.CancelableRequest(this._set,{moduleName:N}),this._cancelableCall=new S.CancelableRequest(this._call,{moduleName:N}),this._cancelableAnswer=new S.CancelableRequest(this._answer,{moduleName:N}),this._cancelableSendDTMF=new S.CancelableRequest(this._sendDTMF,{moduleName:N}),this.onSession(P,this._handleShareState),this.onSession(Ae,this._handleNewInfo),this.on(J,this._handleSipEvent),this.onSession(C,this._handleEnded),this.onSession(O,this._handleEnded)}async register(){return new Promise((e,t)=>{this.isRegisterConfig&&this.ua?(this.ua.on(m,e),this.ua.on(f,t),this.ua.register()):t(new Error("Config is not registered"))})}async unregister(){return new Promise((e,t)=>{this.isRegistered&&this.ua?(this.ua.on(X,e),this.ua.unregister()):t(new Error("ua is not registered"))})}async sendOptions(e,t,n){if(!this.ua)throw new Error("is not connected");return new Promise((s,o)=>{try{this.ua.sendOptions(e,t,{extraHeaders:n,eventHandlers:{succeeded:()=>{s()},failed:o}})}catch(a){o(a)}})}async ping(e,t){var s;if(!((s=this.ua)!=null&&s.configuration.uri))throw new Error("is not connected");const n=this.ua.configuration.uri;return this.sendOptions(n,e,t)}async checkTelephony({userAgent:e,displayName:t,sipServerUrl:n,sipWebSocketServerURL:s,sdpSemantics:o}){return new Promise((a,c)=>{const E=ye(n),h=new this.JsSIP.WebSocketInterface(s),_=this._createUa({socket:h,displayName:t,sdpSemantics:o,userAgent:e,getSipServerUrl:E}),u=()=>{const d=new Error("Telephony is not available");c(d)};_.once(T,u);const l=()=>{_.removeAllListeners(),_.once(T,a),_.stop()};_.once(I,l),_.start()})}async replaceMediaStream(e,t){if(!this.session)throw new Error("No session established");return this.session.replaceMediaStream(e,t)}async askPermissionToEnableCam(e={}){if(!this.session)throw new Error("No session established");const t=[Tn];return this.session.sendInfo(pe,void 0,{noTerminateWhenError:!0,...e,extraHeaders:t}).catch(n=>{if(In(n))throw n})}get isPendingPresentation(){return!!this.promisePendingStartPresentation||!!this.promisePendingStopPresentation}async _sendPresentation(e,t,{maxBitrate:n,degradationPreference:s,isNeedReinvite:o=!0,isP2P:a=!1}){const c=k(t);this._streamPresentationCurrent=c;const E=a?[dn]:[En],h=e.sendInfo(q,void 0,{extraHeaders:E}).then(async()=>e.startPresentation(c,o,s)).then(async()=>{const{connection:_}=this;if(!_||n===void 0)return;const u=_.getSenders();await Pn(u,t,n)}).then(()=>t).catch(_=>{throw this._sessionEvents.trigger(y,_),_});return this.promisePendingStartPresentation=h,h.finally(()=>{this.promisePendingStartPresentation=void 0})}async startPresentation(e,{isNeedReinvite:t=!0,isP2P:n=!1,maxBitrate:s,degradationPreference:o}={}){const a=this.establishedSession;if(!a)throw new Error("No session established");if(this._streamPresentationCurrent)throw new Error("Presentation is already started");return this._sendPresentation(a,e,{isNeedReinvite:t,isP2P:n,maxBitrate:s,degradationPreference:o})}async stopPresentation({isP2P:e=!1}={}){const t=this._streamPresentationCurrent;let n=this.promisePendingStartPresentation??Promise.resolve();const s=e?[ln]:[_n],o=this.establishedSession;return o&&t&&(n=n.then(async()=>o.sendInfo(q,void 0,{extraHeaders:s})).then(async()=>o.stopPresentation(t)).catch(a=>{throw this._sessionEvents.trigger(y,a),a})),!o&&t&&this._sessionEvents.trigger(Re,t),this.promisePendingStopPresentation=n,n.finally(()=>{this._resetPresentation()})}async updatePresentation(e,{isP2P:t=!1,maxBitrate:n,degradationPreference:s}={}){const o=this.establishedSession;if(!o)throw new Error("No session established");if(!this._streamPresentationCurrent)throw new Error("Presentation has not started yet");return this.promisePendingStartPresentation&&await this.promisePendingStartPresentation,this._sendPresentation(o,e,{isP2P:t,maxBitrate:n,degradationPreference:s,isNeedReinvite:!1})}_resetPresentation(){delete this._streamPresentationCurrent,this.promisePendingStartPresentation=void 0,this.promisePendingStopPresentation=void 0}on(e,t){return this._uaEvents.on(e,t)}once(e,t){return this._uaEvents.once(e,t)}onceRace(e,t){return this._uaEvents.onceRace(e,t)}async wait(e){return this._uaEvents.wait(e)}off(e,t){this._uaEvents.off(e,t)}onSession(e,t){return this._sessionEvents.on(e,t)}onceSession(e,t){return this._sessionEvents.once(e,t)}onceRaceSession(e,t){return this._sessionEvents.onceRace(e,t)}async waitSession(e){return this._sessionEvents.wait(e)}offSession(e,t){this._sessionEvents.off(e,t)}isConfigured(){return!!this.ua}getConnectionConfiguration(){return{...this._connectionConfiguration}}getRemoteStreams(){if(!this.connection)return;const t=this.connection.getReceivers().map(({track:n})=>n);return An(t)?this._generateStreams(t):this._generateAudioStreams(t)}get connection(){var t;return(t=this.session)==null?void 0:t.connection}get remoteCallerData(){var e,t,n,s,o,a;return{displayName:(t=(e=this.incomingSession)==null?void 0:e.remote_identity)==null?void 0:t.display_name,host:(s=(n=this.incomingSession)==null?void 0:n.remote_identity)==null?void 0:s.uri.host,incomingNumber:(a=(o=this.incomingSession)==null?void 0:o.remote_identity)==null?void 0:a.uri.user,session:this.incomingSession}}get requested(){return this._cancelableConnect.requested||this._cancelableInitUa.requested||this._cancelableCall.requested||this._cancelableAnswer.requested}get establishedSession(){return this.session&&this.session.isEstablished()?this.session:void 0}get isRegistered(){return!!this.ua&&this.ua.isRegistered()}get isRegisterConfig(){return!!this.ua&&this._isRegisterConfig}get isCallActive(){return!!(this.ua&&this.session)}get isAvailableIncomingCall(){return!!this.incomingSession}_generateStream(e,t){const{id:n}=e,s=this._remoteStreams[n]||new MediaStream;return t&&s.addTrack(t),s.addTrack(e),this._remoteStreams[n]=s,s}_generateAudioStream(e){const{id:t}=e,n=this._remoteStreams[t]||new MediaStream;return n.addTrack(e),this._remoteStreams[t]=n,n}_generateStreams(e){const t=[];return e.forEach((n,s)=>{if(n.kind==="audio")return;const o=n,a=e[s-1];let c;a&&a.kind==="audio"&&(c=a);const E=this._generateStream(o,c);t.push(E)}),t}_generateAudioStreams(e){return e.map(n=>this._generateAudioStream(n))}_cancelRequests(){this._cancelActionsRequests(),this._cancelCallRequests(),this._cancelConnectRequests()}_cancelConnectRequests(){this._cancelableConnect.cancelRequest()}_cancelCallRequests(){this._cancelableCall.cancelRequest(),this._cancelableAnswer.cancelRequest()}_cancelActionsRequests(){this._cancelableAnswer.cancelRequest(),this._cancelableSendDTMF.cancelRequest()}async waitChannels(){return this.waitSession(p)}async waitSyncMediaState(){return this.waitSession(v)}async sendChannels({inputChannels:e,outputChannels:t}){if(!this.session)throw new Error("No session established");const n=`${ve}: ${e}`,s=`${be}: ${t}`,o=[n,s];return this.session.sendInfo(Xt,void 0,{extraHeaders:o})}async sendMediaState({cam:e,mic:t},n={}){if(!this.session)throw new Error("No session established");const s=`${nn}: currentstate`,o=`${rn}: ${Number(e)}`,a=`${on}: ${Number(t)}`,c=[s,o,a];return this.session.sendInfo(Jt,void 0,{noTerminateWhenError:!0,...n,extraHeaders:c})}async _sendRefusalToTurnOn(e,t={}){if(!this.session)throw new Error("No session established");const c=[`${sn}: ${e==="mic"?0:1}`];return this.session.sendInfo(zt,void 0,{noTerminateWhenError:!0,...t,extraHeaders:c})}async sendRefusalToTurnOnMic(e={}){if(!this.session)throw new Error("No session established");return this._sendRefusalToTurnOn("mic",{noTerminateWhenError:!0,...e})}async sendRefusalToTurnOnCam(e={}){if(!this.session)throw new Error("No session established");return this._sendRefusalToTurnOn("cam",{noTerminateWhenError:!0,...e})}}exports.BAD_MEDIA_DESCRIPTION=Fe;exports.EEventsMainCAM=A;exports.EEventsMic=U;exports.EEventsSyncMediaState=L;exports.EUseLicense=lt;exports.NOT_FOUND=qe;exports.REJECTED=V;exports.SESSION_EVENT_NAMES=Oe;exports.SipConnector=Yn;exports.UA_EVENT_NAMES=fe;exports.causes=Ft;exports.constants=Bt;exports.disableDebug=Nn;exports.enableDebug=Sn;exports.eventNames=Vt;exports.hasCanceledCallError=bn;exports.logger=W;exports.setEncodingsToSender=St;