@webex/calling 3.11.0 → 3.12.0-mobius-socket.1
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/CallHistory/CallHistory.js +596 -0
- package/dist/CallHistory/CallHistory.js.map +1 -0
- package/dist/CallHistory/CallHistory.test.js +916 -0
- package/dist/CallHistory/CallHistory.test.js.map +1 -0
- package/dist/CallHistory/callHistoryFixtures.js +650 -0
- package/dist/CallHistory/callHistoryFixtures.js.map +1 -0
- package/dist/CallHistory/constants.js +38 -0
- package/dist/CallHistory/constants.js.map +1 -0
- package/dist/CallHistory/types.js +7 -0
- package/dist/CallHistory/types.js.map +1 -0
- package/dist/CallSettings/CallSettings.js +311 -0
- package/dist/CallSettings/CallSettings.js.map +1 -0
- package/dist/CallSettings/CallSettings.test.js +122 -0
- package/dist/CallSettings/CallSettings.test.js.map +1 -0
- package/dist/CallSettings/UcmBackendConnector.js +308 -0
- package/dist/CallSettings/UcmBackendConnector.js.map +1 -0
- package/dist/CallSettings/UcmBackendConnector.test.js +411 -0
- package/dist/CallSettings/UcmBackendConnector.test.js.map +1 -0
- package/dist/CallSettings/WxCallBackendConnector.js +597 -0
- package/dist/CallSettings/WxCallBackendConnector.js.map +1 -0
- package/dist/CallSettings/WxCallBackendConnector.test.js +904 -0
- package/dist/CallSettings/WxCallBackendConnector.test.js.map +1 -0
- package/dist/CallSettings/constants.js +31 -0
- package/dist/CallSettings/constants.js.map +1 -0
- package/dist/CallSettings/testFixtures.js +68 -0
- package/dist/CallSettings/testFixtures.js.map +1 -0
- package/dist/CallSettings/types.js +7 -0
- package/dist/CallSettings/types.js.map +1 -0
- package/dist/CallingClient/CallingClient.js +1346 -0
- package/dist/CallingClient/CallingClient.js.map +1 -0
- package/dist/CallingClient/CallingClient.test.js +1352 -0
- package/dist/CallingClient/CallingClient.test.js.map +1 -0
- package/dist/CallingClient/callRecordFixtures.js +101 -0
- package/dist/CallingClient/callRecordFixtures.js.map +1 -0
- package/dist/CallingClient/calling/CallerId/index.js +275 -0
- package/dist/CallingClient/calling/CallerId/index.js.map +1 -0
- package/dist/CallingClient/calling/CallerId/index.test.js +275 -0
- package/dist/CallingClient/calling/CallerId/index.test.js.map +1 -0
- package/dist/CallingClient/calling/CallerId/types.js +7 -0
- package/dist/CallingClient/calling/CallerId/types.js.map +1 -0
- package/dist/CallingClient/calling/call.js +3489 -0
- package/dist/CallingClient/calling/call.js.map +1 -0
- package/dist/CallingClient/calling/call.test.js +3653 -0
- package/dist/CallingClient/calling/call.test.js.map +1 -0
- package/dist/CallingClient/calling/callManager.js +481 -0
- package/dist/CallingClient/calling/callManager.js.map +1 -0
- package/dist/CallingClient/calling/callManager.test.js +776 -0
- package/dist/CallingClient/calling/callManager.test.js.map +1 -0
- package/dist/CallingClient/calling/index.js +30 -0
- package/dist/CallingClient/calling/index.js.map +1 -0
- package/dist/CallingClient/calling/types.js +76 -0
- package/dist/CallingClient/calling/types.js.map +1 -0
- package/dist/CallingClient/callingClientFixtures.js +143 -0
- package/dist/CallingClient/callingClientFixtures.js.map +1 -0
- package/dist/CallingClient/constants.js +249 -0
- package/dist/CallingClient/constants.js.map +1 -0
- package/dist/CallingClient/line/index.js +332 -0
- package/dist/CallingClient/line/index.js.map +1 -0
- package/dist/CallingClient/line/line.test.js +342 -0
- package/dist/CallingClient/line/line.test.js.map +1 -0
- package/dist/CallingClient/line/types.js +21 -0
- package/dist/CallingClient/line/types.js.map +1 -0
- package/dist/CallingClient/registration/index.js +19 -0
- package/dist/CallingClient/registration/index.js.map +1 -0
- package/dist/CallingClient/registration/register.js +1713 -0
- package/dist/CallingClient/registration/register.js.map +1 -0
- package/dist/CallingClient/registration/register.test.js +1894 -0
- package/dist/CallingClient/registration/register.test.js.map +1 -0
- package/dist/CallingClient/registration/registerFixtures.js +36 -0
- package/dist/CallingClient/registration/registerFixtures.js.map +1 -0
- package/dist/CallingClient/registration/types.js +7 -0
- package/dist/CallingClient/registration/types.js.map +1 -0
- package/dist/CallingClient/registration/webWorker.js +132 -0
- package/dist/CallingClient/registration/webWorker.js.map +1 -0
- package/dist/CallingClient/registration/webWorker.test.js +303 -0
- package/dist/CallingClient/registration/webWorker.test.js.map +1 -0
- package/dist/CallingClient/registration/webWorkerStr.js +15 -0
- package/dist/CallingClient/registration/webWorkerStr.js.map +1 -0
- package/dist/CallingClient/types.js +7 -0
- package/dist/CallingClient/types.js.map +1 -0
- package/dist/CallingClient/utils/constants.js +46 -0
- package/dist/CallingClient/utils/constants.js.map +1 -0
- package/dist/CallingClient/utils/index.js +63 -0
- package/dist/CallingClient/utils/index.js.map +1 -0
- package/dist/CallingClient/utils/mobiusSocketMapper.js +106 -0
- package/dist/CallingClient/utils/mobiusSocketMapper.js.map +1 -0
- package/dist/CallingClient/utils/request.js +267 -0
- package/dist/CallingClient/utils/request.js.map +1 -0
- package/dist/CallingClient/utils/types.js +7 -0
- package/dist/CallingClient/utils/types.js.map +1 -0
- package/dist/CallingClient/utils/wsFeatureFlag.js +20 -0
- package/dist/CallingClient/utils/wsFeatureFlag.js.map +1 -0
- package/dist/CallingClient/windowsChromiumIceWarmupUtils.js +142 -0
- package/dist/CallingClient/windowsChromiumIceWarmupUtils.js.map +1 -0
- package/dist/Contacts/ContactsClient.js +1206 -0
- package/dist/Contacts/ContactsClient.js.map +1 -0
- package/dist/Contacts/ContactsClient.test.js +1004 -0
- package/dist/Contacts/ContactsClient.test.js.map +1 -0
- package/dist/Contacts/constants.js +40 -0
- package/dist/Contacts/constants.js.map +1 -0
- package/dist/Contacts/contactFixtures.js +430 -0
- package/dist/Contacts/contactFixtures.js.map +1 -0
- package/dist/Contacts/types.js +43 -0
- package/dist/Contacts/types.js.map +1 -0
- package/dist/Errors/catalog/CallError.js +89 -0
- package/dist/Errors/catalog/CallError.js.map +1 -0
- package/dist/Errors/catalog/CallingDeviceError.js +83 -0
- package/dist/Errors/catalog/CallingDeviceError.js.map +1 -0
- package/dist/Errors/catalog/ExtendedError.js +42 -0
- package/dist/Errors/catalog/ExtendedError.js.map +1 -0
- package/dist/Errors/catalog/LineError.js +85 -0
- package/dist/Errors/catalog/LineError.js.map +1 -0
- package/dist/Errors/index.js +28 -0
- package/dist/Errors/index.js.map +1 -0
- package/dist/Errors/types.js +59 -0
- package/dist/Errors/types.js.map +1 -0
- package/dist/Events/impl/index.js +79 -0
- package/dist/Events/impl/index.js.map +1 -0
- package/dist/Events/types.js +97 -0
- package/dist/Events/types.js.map +1 -0
- package/dist/Logger/index.js +228 -0
- package/dist/Logger/index.js.map +1 -0
- package/dist/Logger/index.test.js +87 -0
- package/dist/Logger/index.test.js.map +1 -0
- package/dist/Logger/types.js +34 -0
- package/dist/Logger/types.js.map +1 -0
- package/dist/Metrics/index.js +534 -0
- package/dist/Metrics/index.js.map +1 -0
- package/dist/Metrics/index.test.js +463 -0
- package/dist/Metrics/index.test.js.map +1 -0
- package/dist/Metrics/types.js +64 -0
- package/dist/Metrics/types.js.map +1 -0
- package/dist/SDKConnector/index.js +134 -0
- package/dist/SDKConnector/index.js.map +1 -0
- package/dist/SDKConnector/index.test.js +9 -0
- package/dist/SDKConnector/index.test.js.map +1 -0
- package/dist/SDKConnector/types.js +7 -0
- package/dist/SDKConnector/types.js.map +1 -0
- package/dist/SDKConnector/utils.js +39 -0
- package/dist/SDKConnector/utils.js.map +1 -0
- package/dist/SDKConnector/utils.test.js +9 -0
- package/dist/SDKConnector/utils.test.js.map +1 -0
- package/dist/Voicemail/BroadworksBackendConnector.js +699 -0
- package/dist/Voicemail/BroadworksBackendConnector.js.map +1 -0
- package/dist/Voicemail/BroadworksBackendConnector.test.js +820 -0
- package/dist/Voicemail/BroadworksBackendConnector.test.js.map +1 -0
- package/dist/Voicemail/UcmBackendConnector.js +628 -0
- package/dist/Voicemail/UcmBackendConnector.js.map +1 -0
- package/dist/Voicemail/UcmBackendConnector.test.js +738 -0
- package/dist/Voicemail/UcmBackendConnector.test.js.map +1 -0
- package/dist/Voicemail/Voicemail.js +472 -0
- package/dist/Voicemail/Voicemail.js.map +1 -0
- package/dist/Voicemail/Voicemail.test.js +391 -0
- package/dist/Voicemail/Voicemail.test.js.map +1 -0
- package/dist/Voicemail/WxCallBackendConnector.js +657 -0
- package/dist/Voicemail/WxCallBackendConnector.js.map +1 -0
- package/dist/Voicemail/WxCallBackendConnector.test.js +1225 -0
- package/dist/Voicemail/WxCallBackendConnector.test.js.map +1 -0
- package/dist/Voicemail/constants.js +61 -0
- package/dist/Voicemail/constants.js.map +1 -0
- package/dist/Voicemail/types.js +7 -0
- package/dist/Voicemail/types.js.map +1 -0
- package/dist/Voicemail/voicemailFixture.js +524 -0
- package/dist/Voicemail/voicemailFixture.js.map +1 -0
- package/dist/api.js +157 -0
- package/dist/api.js.map +1 -0
- package/dist/common/Utils.js +1542 -0
- package/dist/common/Utils.js.map +1 -0
- package/dist/common/Utils.test.js +1989 -0
- package/dist/common/Utils.test.js.map +1 -0
- package/dist/common/constants.js +62 -0
- package/dist/common/constants.js.map +1 -0
- package/dist/common/index.js +19 -0
- package/dist/common/index.js.map +1 -0
- package/dist/common/testUtil.js +988 -0
- package/dist/common/testUtil.js.map +1 -0
- package/dist/common/types.js +75 -0
- package/dist/common/types.js.map +1 -0
- package/dist/index.js +321 -0
- package/dist/index.js.map +1 -0
- package/dist/module/CallHistory/CallHistory.js +28 -17
- package/dist/module/CallingClient/CallingClient.js +157 -4
- package/dist/module/CallingClient/calling/call.js +12 -8
- package/dist/module/CallingClient/calling/callManager.js +29 -10
- package/dist/module/CallingClient/calling/types.js +2 -0
- package/dist/module/CallingClient/constants.js +8 -0
- package/dist/module/CallingClient/registration/register.js +46 -16
- package/dist/module/CallingClient/utils/constants.js +30 -0
- package/dist/module/CallingClient/utils/index.js +5 -0
- package/dist/module/CallingClient/utils/mobiusSocketMapper.js +56 -0
- package/dist/module/CallingClient/utils/request.js +112 -0
- package/dist/module/CallingClient/utils/types.js +1 -0
- package/dist/module/CallingClient/utils/wsFeatureFlag.js +5 -0
- package/dist/module/Events/types.js +0 -10
- package/dist/module/SDKConnector/index.js +17 -0
- package/dist/module/common/Utils.js +35 -4
- package/dist/module/common/testUtil.js +3 -0
- package/dist/types/CallHistory/CallHistory.d.ts.map +1 -1
- package/dist/types/CallingClient/CallingClient.d.ts +10 -1
- package/dist/types/CallingClient/CallingClient.d.ts.map +1 -1
- package/dist/types/CallingClient/calling/call.d.ts +1 -0
- package/dist/types/CallingClient/calling/call.d.ts.map +1 -1
- package/dist/types/CallingClient/calling/callManager.d.ts +5 -4
- package/dist/types/CallingClient/calling/callManager.d.ts.map +1 -1
- package/dist/types/CallingClient/calling/types.d.ts +21 -9
- package/dist/types/CallingClient/calling/types.d.ts.map +1 -1
- package/dist/types/CallingClient/constants.d.ts +8 -0
- package/dist/types/CallingClient/constants.d.ts.map +1 -1
- package/dist/types/CallingClient/registration/register.d.ts +3 -1
- package/dist/types/CallingClient/registration/register.d.ts.map +1 -1
- package/dist/types/CallingClient/registration/types.d.ts +2 -1
- package/dist/types/CallingClient/registration/types.d.ts.map +1 -1
- package/dist/types/CallingClient/registration/webWorker.d.ts.map +1 -1
- package/dist/types/CallingClient/types.d.ts +3 -1
- package/dist/types/CallingClient/types.d.ts.map +1 -1
- package/dist/types/CallingClient/utils/constants.d.ts +30 -0
- package/dist/types/CallingClient/utils/constants.d.ts.map +1 -0
- package/dist/types/CallingClient/utils/index.d.ts +6 -0
- package/dist/types/CallingClient/utils/index.d.ts.map +1 -0
- package/dist/types/CallingClient/utils/mobiusSocketMapper.d.ts +4 -0
- package/dist/types/CallingClient/utils/mobiusSocketMapper.d.ts.map +1 -0
- package/dist/types/CallingClient/utils/request.d.ts +20 -0
- package/dist/types/CallingClient/utils/request.d.ts.map +1 -0
- package/dist/types/CallingClient/utils/types.d.ts +23 -0
- package/dist/types/CallingClient/utils/types.d.ts.map +1 -0
- package/dist/types/CallingClient/utils/wsFeatureFlag.d.ts +4 -0
- package/dist/types/CallingClient/utils/wsFeatureFlag.d.ts.map +1 -0
- package/dist/types/Events/types.d.ts +0 -10
- package/dist/types/Events/types.d.ts.map +1 -1
- package/dist/types/SDKConnector/index.d.ts +2 -0
- package/dist/types/SDKConnector/index.d.ts.map +1 -1
- package/dist/types/SDKConnector/types.d.ts +11 -0
- package/dist/types/SDKConnector/types.d.ts.map +1 -1
- package/dist/types/common/Utils.d.ts +4 -1
- package/dist/types/common/Utils.d.ts.map +1 -1
- package/dist/types/common/testUtil.d.ts +3 -0
- package/dist/types/common/testUtil.d.ts.map +1 -1
- package/dist/types/common/types.d.ts +5 -0
- package/dist/types/common/types.d.ts.map +1 -1
- package/package.json +8 -4
|
@@ -0,0 +1,1346 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _typeof = require("@babel/runtime-corejs2/helpers/typeof");
|
|
4
|
+
var _Reflect$construct = require("@babel/runtime-corejs2/core-js/reflect/construct");
|
|
5
|
+
var _Array$from = require("@babel/runtime-corejs2/core-js/array/from");
|
|
6
|
+
var _Symbol = require("@babel/runtime-corejs2/core-js/symbol");
|
|
7
|
+
var _Symbol$iterator = require("@babel/runtime-corejs2/core-js/symbol/iterator");
|
|
8
|
+
var _Array$isArray = require("@babel/runtime-corejs2/core-js/array/is-array");
|
|
9
|
+
var _WeakMap = require("@babel/runtime-corejs2/core-js/weak-map");
|
|
10
|
+
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
11
|
+
var _Object$getOwnPropertyDescriptor = require("@babel/runtime-corejs2/core-js/object/get-own-property-descriptor");
|
|
12
|
+
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
|
|
13
|
+
_Object$defineProperty(exports, "__esModule", {
|
|
14
|
+
value: true
|
|
15
|
+
});
|
|
16
|
+
exports.createClient = exports.CallingClient = void 0;
|
|
17
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime-corejs2/regenerator"));
|
|
18
|
+
var _values = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/values"));
|
|
19
|
+
var _keys = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/keys"));
|
|
20
|
+
var _stringify = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/json/stringify"));
|
|
21
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/toConsumableArray"));
|
|
22
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/asyncToGenerator"));
|
|
23
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
|
|
24
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
|
|
25
|
+
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/possibleConstructorReturn"));
|
|
26
|
+
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/getPrototypeOf"));
|
|
27
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/inherits"));
|
|
28
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
|
|
29
|
+
var Media = _interopRequireWildcard(require("@webex/internal-media-core"));
|
|
30
|
+
var _internalPluginMobiusSocket = require("@webex/internal-plugin-mobius-socket");
|
|
31
|
+
var _asyncMutex = require("async-mutex");
|
|
32
|
+
var _constants = require("../common/constants");
|
|
33
|
+
var _Utils = require("../common/Utils");
|
|
34
|
+
var _types = require("../Logger/types");
|
|
35
|
+
var _SDKConnector = _interopRequireDefault(require("../SDKConnector"));
|
|
36
|
+
var _impl = require("../Events/impl");
|
|
37
|
+
var _types2 = require("../Events/types");
|
|
38
|
+
var _types3 = require("../common/types");
|
|
39
|
+
var _types4 = require("./calling/types");
|
|
40
|
+
var _Logger = _interopRequireDefault(require("../Logger"));
|
|
41
|
+
var _callManager = require("./calling/callManager");
|
|
42
|
+
var _constants2 = require("./constants");
|
|
43
|
+
var _line = _interopRequireDefault(require("./line"));
|
|
44
|
+
var _types5 = require("../Metrics/types");
|
|
45
|
+
var _Metrics = require("../Metrics");
|
|
46
|
+
var _windowsChromiumIceWarmupUtils = _interopRequireDefault(require("./windowsChromiumIceWarmupUtils"));
|
|
47
|
+
var _request = require("./utils/request");
|
|
48
|
+
var _utils = require("./utils");
|
|
49
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof _WeakMap) var r = new _WeakMap(), n = new _WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t11 in e) "default" !== _t11 && {}.hasOwnProperty.call(e, _t11) && ((i = (o = _Object$defineProperty) && _Object$getOwnPropertyDescriptor(e, _t11)) && (i.get || i.set) ? o(f, _t11, i) : f[_t11] = e[_t11]); return f; })(e, t); }
|
|
50
|
+
function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof _Symbol && r[_Symbol$iterator] || r["@@iterator"]; if (!t) { if (_Array$isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; }
|
|
51
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? _Array$from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
52
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
53
|
+
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2.default)(o), (0, _possibleConstructorReturn2.default)(t, _isNativeReflectConstruct() ? _Reflect$construct(o, e || [], (0, _getPrototypeOf2.default)(t).constructor) : o.apply(t, e)); }
|
|
54
|
+
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } /* eslint-disable no-underscore-dangle */ /* eslint-disable valid-jsdoc */ /* eslint-disable @typescript-eslint/no-shadow */ // @ts-ignore - JS module without type declarations
|
|
55
|
+
/**
|
|
56
|
+
* The `CallingClient` module provides a set of APIs for line registration and calling functionalities within the SDK.
|
|
57
|
+
*
|
|
58
|
+
* The following code snippet demonstrates how to create an instance of `CallingClient` using a `webex` instance and `callingConfig`:
|
|
59
|
+
*
|
|
60
|
+
* @example
|
|
61
|
+
* ```javascript
|
|
62
|
+
* const callingClient = createClient(webex, callingConfig);
|
|
63
|
+
* ```
|
|
64
|
+
*/
|
|
65
|
+
var CallingClient = exports.CallingClient = /*#__PURE__*/function (_Eventing) {
|
|
66
|
+
/**
|
|
67
|
+
* @ignore
|
|
68
|
+
*/
|
|
69
|
+
function CallingClient(webex, config) {
|
|
70
|
+
var _this$sdkConfig, _this$sdkConfig$servi, _this$sdkConfig2, _this$sdkConfig2$logg, _config$isMobiusSocke;
|
|
71
|
+
var _this;
|
|
72
|
+
(0, _classCallCheck2.default)(this, CallingClient);
|
|
73
|
+
_this = _callSuper(this, CallingClient);
|
|
74
|
+
(0, _defineProperty2.default)(_this, "sdkConnector", void 0);
|
|
75
|
+
(0, _defineProperty2.default)(_this, "webex", void 0);
|
|
76
|
+
(0, _defineProperty2.default)(_this, "mutex", void 0);
|
|
77
|
+
(0, _defineProperty2.default)(_this, "callManager", void 0);
|
|
78
|
+
(0, _defineProperty2.default)(_this, "metricManager", void 0);
|
|
79
|
+
(0, _defineProperty2.default)(_this, "sdkConfig", void 0);
|
|
80
|
+
(0, _defineProperty2.default)(_this, "primaryMobiusUris", void 0);
|
|
81
|
+
(0, _defineProperty2.default)(_this, "backupMobiusUris", void 0);
|
|
82
|
+
(0, _defineProperty2.default)(_this, "primaryWssMobiusUris", void 0);
|
|
83
|
+
(0, _defineProperty2.default)(_this, "backupWssMobiusUris", void 0);
|
|
84
|
+
(0, _defineProperty2.default)(_this, "mobiusClusters", void 0);
|
|
85
|
+
(0, _defineProperty2.default)(_this, "mobiusHost", void 0);
|
|
86
|
+
(0, _defineProperty2.default)(_this, "mediaEngine", void 0);
|
|
87
|
+
(0, _defineProperty2.default)(_this, "lineDict", {});
|
|
88
|
+
(0, _defineProperty2.default)(_this, "apiRequest", void 0);
|
|
89
|
+
(0, _defineProperty2.default)(_this, "isMobiusSocketEnabled", void 0);
|
|
90
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
91
|
+
(0, _defineProperty2.default)(_this, "mobiusSocket", void 0);
|
|
92
|
+
(0, _defineProperty2.default)(_this, "isNetworkDown", false);
|
|
93
|
+
(0, _defineProperty2.default)(_this, "networkDownTimestamp", '');
|
|
94
|
+
(0, _defineProperty2.default)(_this, "networkUpTimestamp", '');
|
|
95
|
+
(0, _defineProperty2.default)(_this, "mercuryDownTimestamp", '');
|
|
96
|
+
(0, _defineProperty2.default)(_this, "mercuryUpTimestamp", '');
|
|
97
|
+
(0, _defineProperty2.default)(_this, "handleNetworkOffline", /*#__PURE__*/(0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee() {
|
|
98
|
+
var line;
|
|
99
|
+
return _regenerator.default.wrap(function (_context) {
|
|
100
|
+
while (1) switch (_context.prev = _context.next) {
|
|
101
|
+
case 0:
|
|
102
|
+
_this.networkDownTimestamp = new Date().toISOString();
|
|
103
|
+
_context.next = 1;
|
|
104
|
+
return _this.checkNetworkReachability();
|
|
105
|
+
case 1:
|
|
106
|
+
_this.isNetworkDown = !_context.sent;
|
|
107
|
+
_Logger.default.warn("Network has gone down, wait for it to come back up", {
|
|
108
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
109
|
+
method: _constants2.METHODS.NETWORK_OFFLINE
|
|
110
|
+
});
|
|
111
|
+
if (_this.isNetworkDown) {
|
|
112
|
+
line = (0, _values.default)(_this.lineDict)[0];
|
|
113
|
+
line.registration.clearKeepaliveTimer();
|
|
114
|
+
}
|
|
115
|
+
case 2:
|
|
116
|
+
case "end":
|
|
117
|
+
return _context.stop();
|
|
118
|
+
}
|
|
119
|
+
}, _callee);
|
|
120
|
+
})));
|
|
121
|
+
// Wondering if we should keep this for timestamp recording purpose
|
|
122
|
+
(0, _defineProperty2.default)(_this, "handleNetworkOnline", function () {
|
|
123
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
124
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
125
|
+
method: _constants2.METHODS.NETWORK_ONLINE
|
|
126
|
+
});
|
|
127
|
+
_this.networkUpTimestamp = new Date().toISOString();
|
|
128
|
+
});
|
|
129
|
+
(0, _defineProperty2.default)(_this, "handleMercuryOffline", function () {
|
|
130
|
+
_Logger.default.warn("Mercury down, waiting for connection to be up", {
|
|
131
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
132
|
+
method: _constants2.METHODS.MERCURY_OFFLINE
|
|
133
|
+
});
|
|
134
|
+
_this.mercuryDownTimestamp = new Date().toISOString();
|
|
135
|
+
_this.metricManager.submitConnectionMetrics(_types5.METRIC_EVENT.CONNECTION_ERROR, _types5.CONNECTION_ACTION.MERCURY_DOWN, _types5.METRIC_TYPE.BEHAVIORAL, _this.mercuryDownTimestamp, _this.mercuryUpTimestamp);
|
|
136
|
+
});
|
|
137
|
+
(0, _defineProperty2.default)(_this, "handleMercuryOnline", /*#__PURE__*/(0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee3() {
|
|
138
|
+
var callCheckInterval;
|
|
139
|
+
return _regenerator.default.wrap(function (_context3) {
|
|
140
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
141
|
+
case 0:
|
|
142
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
143
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
144
|
+
method: _constants2.METHODS.MERCURY_ONLINE
|
|
145
|
+
});
|
|
146
|
+
_this.mercuryUpTimestamp = new Date().toISOString();
|
|
147
|
+
if (!_this.isNetworkDown) {
|
|
148
|
+
_context3.next = 2;
|
|
149
|
+
break;
|
|
150
|
+
}
|
|
151
|
+
callCheckInterval = setInterval(/*#__PURE__*/(0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee2() {
|
|
152
|
+
var line;
|
|
153
|
+
return _regenerator.default.wrap(function (_context2) {
|
|
154
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
155
|
+
case 0:
|
|
156
|
+
if ((0, _keys.default)(_this.callManager.getActiveCalls()).length) {
|
|
157
|
+
_context2.next = 3;
|
|
158
|
+
break;
|
|
159
|
+
}
|
|
160
|
+
clearInterval(callCheckInterval);
|
|
161
|
+
line = (0, _values.default)(_this.lineDict)[0];
|
|
162
|
+
if (!(line.getStatus() !== _types3.RegistrationStatus.IDLE)) {
|
|
163
|
+
_context2.next = 2;
|
|
164
|
+
break;
|
|
165
|
+
}
|
|
166
|
+
_context2.next = 1;
|
|
167
|
+
return line.registration.handleConnectionRestoration(_this.isNetworkDown);
|
|
168
|
+
case 1:
|
|
169
|
+
_this.isNetworkDown = _context2.sent;
|
|
170
|
+
_context2.next = 3;
|
|
171
|
+
break;
|
|
172
|
+
case 2:
|
|
173
|
+
_this.isNetworkDown = false;
|
|
174
|
+
case 3:
|
|
175
|
+
case "end":
|
|
176
|
+
return _context2.stop();
|
|
177
|
+
}
|
|
178
|
+
}, _callee2);
|
|
179
|
+
})), _constants2.NETWORK_FLAP_TIMEOUT);
|
|
180
|
+
if (!(0, _keys.default)(_this.callManager.getActiveCalls()).length) {
|
|
181
|
+
_context3.next = 1;
|
|
182
|
+
break;
|
|
183
|
+
}
|
|
184
|
+
_context3.next = 1;
|
|
185
|
+
return _this.checkCallStatus();
|
|
186
|
+
case 1:
|
|
187
|
+
_this.metricManager.submitConnectionMetrics(_types5.METRIC_EVENT.CONNECTION_ERROR, _types5.CONNECTION_ACTION.NETWORK_FLAP, _types5.METRIC_TYPE.BEHAVIORAL, _this.networkDownTimestamp, _this.networkUpTimestamp);
|
|
188
|
+
_context3.next = 4;
|
|
189
|
+
break;
|
|
190
|
+
case 2:
|
|
191
|
+
if (!(0, _keys.default)(_this.callManager.getActiveCalls()).length) {
|
|
192
|
+
_context3.next = 3;
|
|
193
|
+
break;
|
|
194
|
+
}
|
|
195
|
+
_context3.next = 3;
|
|
196
|
+
return _this.checkCallStatus();
|
|
197
|
+
case 3:
|
|
198
|
+
_this.metricManager.submitConnectionMetrics(_types5.METRIC_EVENT.CONNECTION_ERROR, _types5.CONNECTION_ACTION.MERCURY_UP, _types5.METRIC_TYPE.BEHAVIORAL, _this.mercuryDownTimestamp, _this.mercuryUpTimestamp);
|
|
199
|
+
case 4:
|
|
200
|
+
case "end":
|
|
201
|
+
return _context3.stop();
|
|
202
|
+
}
|
|
203
|
+
}, _callee3);
|
|
204
|
+
})));
|
|
205
|
+
// private unregisterMobiusSocketListener() {
|
|
206
|
+
// log.info(METHOD_START_MESSAGE, {
|
|
207
|
+
// file: CALLING_CLIENT_FILE,
|
|
208
|
+
// method: METHODS.UNREGISTER_MOBIUS_SOCKET_LISTENER,
|
|
209
|
+
// });
|
|
210
|
+
// this.sdkConnector.unregisterMobiusSocketListener('async_event');
|
|
211
|
+
// }
|
|
212
|
+
(0, _defineProperty2.default)(_this, "handleMobiusAsyncEvent", /*#__PURE__*/function () {
|
|
213
|
+
var _ref4 = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee4(event) {
|
|
214
|
+
var eventType;
|
|
215
|
+
return _regenerator.default.wrap(function (_context4) {
|
|
216
|
+
while (1) switch (_context4.prev = _context4.next) {
|
|
217
|
+
case 0:
|
|
218
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
219
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
220
|
+
method: _constants2.METHODS.HANDLE_MOBIUS_ASYNC_EVENT
|
|
221
|
+
});
|
|
222
|
+
eventType = event === null || event === void 0 ? void 0 : event.data.eventType;
|
|
223
|
+
if (eventType) {
|
|
224
|
+
_context4.next = 1;
|
|
225
|
+
break;
|
|
226
|
+
}
|
|
227
|
+
_Logger.default.warn('Dropping unsupported mobius socket payload', {
|
|
228
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
229
|
+
method: _constants2.METHODS.HANDLE_MOBIUS_ASYNC_EVENT
|
|
230
|
+
});
|
|
231
|
+
return _context4.abrupt("return");
|
|
232
|
+
case 1:
|
|
233
|
+
if (!(eventType === _types4.MobiusEventType.REGISTRATION_DOWN)) {
|
|
234
|
+
_context4.next = 2;
|
|
235
|
+
break;
|
|
236
|
+
}
|
|
237
|
+
return _context4.abrupt("return");
|
|
238
|
+
case 2:
|
|
239
|
+
if (eventType.startsWith('mobius.')) {
|
|
240
|
+
_this.callManager.dequeueWsEvents(event);
|
|
241
|
+
}
|
|
242
|
+
case 3:
|
|
243
|
+
case "end":
|
|
244
|
+
return _context4.stop();
|
|
245
|
+
}
|
|
246
|
+
}, _callee4);
|
|
247
|
+
}));
|
|
248
|
+
return function (_x) {
|
|
249
|
+
return _ref4.apply(this, arguments);
|
|
250
|
+
};
|
|
251
|
+
}());
|
|
252
|
+
/**
|
|
253
|
+
* Handler registered for ALL_CALLS_CLEARED event emitted by callManager.
|
|
254
|
+
*
|
|
255
|
+
* If re-register attempt was deferred earlier due to active call(s), then it
|
|
256
|
+
* will be attempted here on receiving a notification from callManager that all
|
|
257
|
+
* calls are cleaned up.
|
|
258
|
+
*/
|
|
259
|
+
(0, _defineProperty2.default)(_this, "callsClearedHandler", /*#__PURE__*/(0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee6() {
|
|
260
|
+
var registration;
|
|
261
|
+
return _regenerator.default.wrap(function (_context6) {
|
|
262
|
+
while (1) switch (_context6.prev = _context6.next) {
|
|
263
|
+
case 0:
|
|
264
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
265
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
266
|
+
method: _constants2.METHODS.CALLS_CLEARED_HANDLER
|
|
267
|
+
});
|
|
268
|
+
// this is a temporary logic to get registration obj
|
|
269
|
+
// it will change once we have proper lineId and multiple lines as well
|
|
270
|
+
registration = (0, _values.default)(_this.lineDict)[0].registration;
|
|
271
|
+
if (registration.isDeviceRegistered()) {
|
|
272
|
+
_context6.next = 1;
|
|
273
|
+
break;
|
|
274
|
+
}
|
|
275
|
+
_context6.next = 1;
|
|
276
|
+
return _this.mutex.runExclusive(/*#__PURE__*/(0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee5() {
|
|
277
|
+
return _regenerator.default.wrap(function (_context5) {
|
|
278
|
+
while (1) switch (_context5.prev = _context5.next) {
|
|
279
|
+
case 0:
|
|
280
|
+
if (!registration.isReconnectPending()) {
|
|
281
|
+
_context5.next = 1;
|
|
282
|
+
break;
|
|
283
|
+
}
|
|
284
|
+
_Logger.default.info('All calls cleared, reconnecting', {
|
|
285
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
286
|
+
method: _constants2.CALLS_CLEARED_HANDLER_UTIL
|
|
287
|
+
});
|
|
288
|
+
_context5.next = 1;
|
|
289
|
+
return registration.reconnectOnFailure(_constants2.CALLS_CLEARED_HANDLER_UTIL);
|
|
290
|
+
case 1:
|
|
291
|
+
case "end":
|
|
292
|
+
return _context5.stop();
|
|
293
|
+
}
|
|
294
|
+
}, _callee5);
|
|
295
|
+
})));
|
|
296
|
+
case 1:
|
|
297
|
+
case "end":
|
|
298
|
+
return _context6.stop();
|
|
299
|
+
}
|
|
300
|
+
}, _callee6);
|
|
301
|
+
})));
|
|
302
|
+
_this.sdkConnector = _SDKConnector.default;
|
|
303
|
+
if (!_this.sdkConnector.getWebex()) {
|
|
304
|
+
var _config$logger;
|
|
305
|
+
_SDKConnector.default.setWebex(webex);
|
|
306
|
+
if (config !== null && config !== void 0 && (_config$logger = config.logger) !== null && _config$logger !== void 0 && _config$logger.level && webex.logger.config) {
|
|
307
|
+
webex.logger.config.level = config.logger.level; // override the webex logger level
|
|
308
|
+
}
|
|
309
|
+
_Logger.default.setWebexLogger(webex.logger);
|
|
310
|
+
}
|
|
311
|
+
_this.mutex = new _asyncMutex.Mutex();
|
|
312
|
+
_this.webex = _this.sdkConnector.getWebex();
|
|
313
|
+
_this.sdkConfig = config;
|
|
314
|
+
var serviceData = (_this$sdkConfig = _this.sdkConfig) !== null && _this$sdkConfig !== void 0 && (_this$sdkConfig$servi = _this$sdkConfig.serviceData) !== null && _this$sdkConfig$servi !== void 0 && _this$sdkConfig$servi.indicator ? _this.sdkConfig.serviceData : {
|
|
315
|
+
indicator: _types3.ServiceIndicator.CALLING,
|
|
316
|
+
domain: ''
|
|
317
|
+
};
|
|
318
|
+
var logLevel = (_this$sdkConfig2 = _this.sdkConfig) !== null && _this$sdkConfig2 !== void 0 && (_this$sdkConfig2$logg = _this$sdkConfig2.logger) !== null && _this$sdkConfig2$logg !== void 0 && _this$sdkConfig2$logg.level ? _this.sdkConfig.logger.level : _types.LOGGER.ERROR;
|
|
319
|
+
_Logger.default.setLogger(logLevel, _constants2.CALLING_CLIENT_FILE);
|
|
320
|
+
(0, _Utils.validateServiceData)(serviceData);
|
|
321
|
+
_this.isMobiusSocketEnabled = (0, _utils.isMobiusWssEnabled)(_this.webex) || ((_config$isMobiusSocke = config === null || config === void 0 ? void 0 : config.isMobiusSocketEnabled) !== null && _config$isMobiusSocke !== void 0 ? _config$isMobiusSocke : false);
|
|
322
|
+
_this.callManager = (0, _callManager.getCallManager)(_this.webex, serviceData.indicator, _this.isMobiusSocketEnabled);
|
|
323
|
+
_this.metricManager = (0, _Metrics.getMetricManager)(_this.webex, serviceData.indicator);
|
|
324
|
+
_this.mediaEngine = Media;
|
|
325
|
+
var adaptedLogger = {
|
|
326
|
+
log: function log() {
|
|
327
|
+
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
328
|
+
args[_key] = arguments[_key];
|
|
329
|
+
}
|
|
330
|
+
return webex.logger.log(args.join(' : '));
|
|
331
|
+
},
|
|
332
|
+
error: function error() {
|
|
333
|
+
for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
|
|
334
|
+
args[_key2] = arguments[_key2];
|
|
335
|
+
}
|
|
336
|
+
return webex.logger.error(args.join(' : '));
|
|
337
|
+
},
|
|
338
|
+
warn: function warn() {
|
|
339
|
+
for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
|
|
340
|
+
args[_key3] = arguments[_key3];
|
|
341
|
+
}
|
|
342
|
+
return webex.logger.warn(args.join(' : '));
|
|
343
|
+
},
|
|
344
|
+
info: function info() {
|
|
345
|
+
for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {
|
|
346
|
+
args[_key4] = arguments[_key4];
|
|
347
|
+
}
|
|
348
|
+
return webex.logger.info(args.join(' : '));
|
|
349
|
+
},
|
|
350
|
+
trace: function trace() {
|
|
351
|
+
for (var _len5 = arguments.length, args = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {
|
|
352
|
+
args[_key5] = arguments[_key5];
|
|
353
|
+
}
|
|
354
|
+
return webex.logger.trace(args.join(' : '));
|
|
355
|
+
},
|
|
356
|
+
debug: function debug() {
|
|
357
|
+
for (var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {
|
|
358
|
+
args[_key6] = arguments[_key6];
|
|
359
|
+
}
|
|
360
|
+
return webex.logger.debug(args.join(' : '));
|
|
361
|
+
}
|
|
362
|
+
};
|
|
363
|
+
_this.mediaEngine.setLogger(adaptedLogger);
|
|
364
|
+
_this.primaryMobiusUris = [];
|
|
365
|
+
_this.backupMobiusUris = [];
|
|
366
|
+
_this.primaryWssMobiusUris = [];
|
|
367
|
+
_this.backupWssMobiusUris = [];
|
|
368
|
+
_this.mobiusClusters = _this.webex.internal.services.getMobiusClusters();
|
|
369
|
+
_this.mobiusHost = '';
|
|
370
|
+
if (_this.isMobiusSocketEnabled) {
|
|
371
|
+
_this.mobiusSocket = (0, _internalPluginMobiusSocket.getMobiusSocketInstance)(_this.webex);
|
|
372
|
+
}
|
|
373
|
+
_this.apiRequest = _request.APIRequest.getInstance({
|
|
374
|
+
webex: _this.webex,
|
|
375
|
+
isMobiusSocketEnabled: _this.isMobiusSocketEnabled
|
|
376
|
+
});
|
|
377
|
+
_this.registerSessionsListener();
|
|
378
|
+
_this.registerCallsClearedListener();
|
|
379
|
+
return _this;
|
|
380
|
+
}
|
|
381
|
+
|
|
382
|
+
/**
|
|
383
|
+
* Initializes the `CallingClient` by performing the following steps:
|
|
384
|
+
*
|
|
385
|
+
* 1. Retrieves list of servers.
|
|
386
|
+
* 2. Creates a line.
|
|
387
|
+
* 3. Sets up network change detection.
|
|
388
|
+
*
|
|
389
|
+
* This method should be called once to initialize the `callingClient`.
|
|
390
|
+
*
|
|
391
|
+
* @returns A promise that resolves when the initialization is complete.
|
|
392
|
+
* @ignore
|
|
393
|
+
*/
|
|
394
|
+
(0, _inherits2.default)(CallingClient, _Eventing);
|
|
395
|
+
return (0, _createClass2.default)(CallingClient, [{
|
|
396
|
+
key: "init",
|
|
397
|
+
value: (function () {
|
|
398
|
+
var _init = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee7() {
|
|
399
|
+
var _window, _window$navigator;
|
|
400
|
+
var ua, _t;
|
|
401
|
+
return _regenerator.default.wrap(function (_context7) {
|
|
402
|
+
while (1) switch (_context7.prev = _context7.next) {
|
|
403
|
+
case 0:
|
|
404
|
+
if (!(typeof window !== 'undefined' && (_window = window) !== null && _window !== void 0 && (_window$navigator = _window.navigator) !== null && _window$navigator !== void 0 && _window$navigator.userAgent)) {
|
|
405
|
+
_context7.next = 4;
|
|
406
|
+
break;
|
|
407
|
+
}
|
|
408
|
+
ua = window.navigator.userAgent;
|
|
409
|
+
if (!ua.toLowerCase().includes('windows')) {
|
|
410
|
+
_context7.next = 4;
|
|
411
|
+
break;
|
|
412
|
+
}
|
|
413
|
+
_Logger.default.info('Starting ICE warmup for Windows Chromium based browser', {
|
|
414
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
415
|
+
method: 'init'
|
|
416
|
+
});
|
|
417
|
+
_context7.prev = 1;
|
|
418
|
+
_context7.next = 2;
|
|
419
|
+
return (0, _windowsChromiumIceWarmupUtils.default)({
|
|
420
|
+
iceServers: [],
|
|
421
|
+
timeoutMs: 1000
|
|
422
|
+
});
|
|
423
|
+
case 2:
|
|
424
|
+
_Logger.default.info("ICE warmup completed", {
|
|
425
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
426
|
+
method: 'init'
|
|
427
|
+
});
|
|
428
|
+
_context7.next = 4;
|
|
429
|
+
break;
|
|
430
|
+
case 3:
|
|
431
|
+
_context7.prev = 3;
|
|
432
|
+
_t = _context7["catch"](1);
|
|
433
|
+
_Logger.default.warn("ICE warmup failed: ".concat(_t), {
|
|
434
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
435
|
+
method: 'init'
|
|
436
|
+
});
|
|
437
|
+
case 4:
|
|
438
|
+
_context7.next = 5;
|
|
439
|
+
return this.getMobiusServers();
|
|
440
|
+
case 5:
|
|
441
|
+
if (!this.isMobiusSocketEnabled) {
|
|
442
|
+
_context7.next = 7;
|
|
443
|
+
break;
|
|
444
|
+
}
|
|
445
|
+
_context7.next = 6;
|
|
446
|
+
return this.connectToMobiusSocket();
|
|
447
|
+
case 6:
|
|
448
|
+
this.registerMobiusSocketListener();
|
|
449
|
+
case 7:
|
|
450
|
+
_context7.next = 8;
|
|
451
|
+
return this.createLine();
|
|
452
|
+
case 8:
|
|
453
|
+
this.setupNetworkEventListeners();
|
|
454
|
+
case 9:
|
|
455
|
+
case "end":
|
|
456
|
+
return _context7.stop();
|
|
457
|
+
}
|
|
458
|
+
}, _callee7, this, [[1, 3]]);
|
|
459
|
+
}));
|
|
460
|
+
function init() {
|
|
461
|
+
return _init.apply(this, arguments);
|
|
462
|
+
}
|
|
463
|
+
return init;
|
|
464
|
+
}()
|
|
465
|
+
/**
|
|
466
|
+
* Ping a reliable external endpoint with a short timeout to infer connectivity.
|
|
467
|
+
*/
|
|
468
|
+
)
|
|
469
|
+
}, {
|
|
470
|
+
key: "checkNetworkReachability",
|
|
471
|
+
value: (function () {
|
|
472
|
+
var _checkNetworkReachability = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee8() {
|
|
473
|
+
var controller, timeoutId, _t2;
|
|
474
|
+
return _regenerator.default.wrap(function (_context8) {
|
|
475
|
+
while (1) switch (_context8.prev = _context8.next) {
|
|
476
|
+
case 0:
|
|
477
|
+
_context8.prev = 0;
|
|
478
|
+
controller = new AbortController();
|
|
479
|
+
timeoutId = setTimeout(function () {
|
|
480
|
+
return controller.abort();
|
|
481
|
+
}, 3000); // Using a common connectivity check endpoint that returns 204 with minimal payload.
|
|
482
|
+
// no-cors mode yields an opaque response but a successful fetch implies reachability.
|
|
483
|
+
_context8.next = 1;
|
|
484
|
+
return fetch('https://www.google.com/generate_204', {
|
|
485
|
+
method: 'GET',
|
|
486
|
+
cache: 'no-cache',
|
|
487
|
+
mode: 'no-cors',
|
|
488
|
+
signal: controller.signal
|
|
489
|
+
});
|
|
490
|
+
case 1:
|
|
491
|
+
clearTimeout(timeoutId);
|
|
492
|
+
return _context8.abrupt("return", true);
|
|
493
|
+
case 2:
|
|
494
|
+
_context8.prev = 2;
|
|
495
|
+
_t2 = _context8["catch"](0);
|
|
496
|
+
_Logger.default.warn("Network connectivity probe failed: ".concat(_t2), {
|
|
497
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
498
|
+
method: 'pingExternal'
|
|
499
|
+
});
|
|
500
|
+
return _context8.abrupt("return", false);
|
|
501
|
+
case 3:
|
|
502
|
+
case "end":
|
|
503
|
+
return _context8.stop();
|
|
504
|
+
}
|
|
505
|
+
}, _callee8, null, [[0, 2]]);
|
|
506
|
+
}));
|
|
507
|
+
function checkNetworkReachability() {
|
|
508
|
+
return _checkNetworkReachability.apply(this, arguments);
|
|
509
|
+
}
|
|
510
|
+
return checkNetworkReachability;
|
|
511
|
+
}())
|
|
512
|
+
}, {
|
|
513
|
+
key: "checkCallStatus",
|
|
514
|
+
value: function () {
|
|
515
|
+
var _checkCallStatus = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee9() {
|
|
516
|
+
var loggerContext, calls, _iterator, _step, _loop, _t3;
|
|
517
|
+
return _regenerator.default.wrap(function (_context0) {
|
|
518
|
+
while (1) switch (_context0.prev = _context0.next) {
|
|
519
|
+
case 0:
|
|
520
|
+
loggerContext = {
|
|
521
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
522
|
+
method: 'checkCallStatus'
|
|
523
|
+
};
|
|
524
|
+
calls = (0, _values.default)(this.callManager.getActiveCalls());
|
|
525
|
+
_iterator = _createForOfIteratorHelper(calls);
|
|
526
|
+
_context0.prev = 1;
|
|
527
|
+
_loop = /*#__PURE__*/_regenerator.default.mark(function _loop() {
|
|
528
|
+
var call;
|
|
529
|
+
return _regenerator.default.wrap(function (_context9) {
|
|
530
|
+
while (1) switch (_context9.prev = _context9.next) {
|
|
531
|
+
case 0:
|
|
532
|
+
call = _step.value;
|
|
533
|
+
call.postStatus().then(function () {
|
|
534
|
+
_Logger.default.info("Call is active", loggerContext);
|
|
535
|
+
/*
|
|
536
|
+
* Media Renegotiation Possibility if call keepalive succeeds,
|
|
537
|
+
* for cases like WebRTC disconnect and media inactivity.
|
|
538
|
+
*/
|
|
539
|
+
}).catch(function (err) {
|
|
540
|
+
_Logger.default.warn("Call Keepalive failed: ".concat(err), loggerContext);
|
|
541
|
+
call.sendCallStateMachineEvt({
|
|
542
|
+
type: 'E_SEND_CALL_DISCONNECT'
|
|
543
|
+
});
|
|
544
|
+
});
|
|
545
|
+
case 1:
|
|
546
|
+
case "end":
|
|
547
|
+
return _context9.stop();
|
|
548
|
+
}
|
|
549
|
+
}, _loop);
|
|
550
|
+
});
|
|
551
|
+
_iterator.s();
|
|
552
|
+
case 2:
|
|
553
|
+
if ((_step = _iterator.n()).done) {
|
|
554
|
+
_context0.next = 4;
|
|
555
|
+
break;
|
|
556
|
+
}
|
|
557
|
+
return _context0.delegateYield(_loop(), "t0", 3);
|
|
558
|
+
case 3:
|
|
559
|
+
_context0.next = 2;
|
|
560
|
+
break;
|
|
561
|
+
case 4:
|
|
562
|
+
_context0.next = 6;
|
|
563
|
+
break;
|
|
564
|
+
case 5:
|
|
565
|
+
_context0.prev = 5;
|
|
566
|
+
_t3 = _context0["catch"](1);
|
|
567
|
+
_iterator.e(_t3);
|
|
568
|
+
case 6:
|
|
569
|
+
_context0.prev = 6;
|
|
570
|
+
_iterator.f();
|
|
571
|
+
return _context0.finish(6);
|
|
572
|
+
case 7:
|
|
573
|
+
case "end":
|
|
574
|
+
return _context0.stop();
|
|
575
|
+
}
|
|
576
|
+
}, _callee9, this, [[1, 5, 6, 7]]);
|
|
577
|
+
}));
|
|
578
|
+
function checkCallStatus() {
|
|
579
|
+
return _checkCallStatus.apply(this, arguments);
|
|
580
|
+
}
|
|
581
|
+
return checkCallStatus;
|
|
582
|
+
}()
|
|
583
|
+
}, {
|
|
584
|
+
key: "setupNetworkEventListeners",
|
|
585
|
+
value: function setupNetworkEventListeners() {
|
|
586
|
+
var _this2 = this;
|
|
587
|
+
if (typeof window !== 'undefined' && window.addEventListener) {
|
|
588
|
+
window.addEventListener('online', this.handleNetworkOnline);
|
|
589
|
+
window.addEventListener('offline', this.handleNetworkOffline);
|
|
590
|
+
}
|
|
591
|
+
this.webex.internal.mercury.on('offline', function () {
|
|
592
|
+
_this2.handleMercuryOffline();
|
|
593
|
+
});
|
|
594
|
+
this.webex.internal.mercury.on('online', function () {
|
|
595
|
+
_this2.handleMercuryOnline();
|
|
596
|
+
});
|
|
597
|
+
}
|
|
598
|
+
|
|
599
|
+
/**
|
|
600
|
+
* Fetches countryCode and region of the client.
|
|
601
|
+
*/
|
|
602
|
+
}, {
|
|
603
|
+
key: "getClientRegionInfo",
|
|
604
|
+
value: (function () {
|
|
605
|
+
var _getClientRegionInfo = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee0() {
|
|
606
|
+
var _this3 = this;
|
|
607
|
+
var abort, regionInfo, _response$headers, _response$headers$tra, _response$headers2, response, clientRegionInfo, _t4;
|
|
608
|
+
return _regenerator.default.wrap(function (_context1) {
|
|
609
|
+
while (1) switch (_context1.prev = _context1.next) {
|
|
610
|
+
case 0:
|
|
611
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
612
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
613
|
+
method: _constants2.METHODS.GET_CLIENT_REGION_INFO
|
|
614
|
+
});
|
|
615
|
+
regionInfo = {};
|
|
616
|
+
_context1.prev = 1;
|
|
617
|
+
_context1.next = 2;
|
|
618
|
+
return this.webex.request({
|
|
619
|
+
uri: "".concat(_constants2.DISCOVERY_URL),
|
|
620
|
+
method: _types3.HTTP_METHODS.GET,
|
|
621
|
+
addAuthHeader: false,
|
|
622
|
+
headers: (0, _defineProperty2.default)({}, _constants2.SPARK_USER_AGENT, null)
|
|
623
|
+
});
|
|
624
|
+
case 2:
|
|
625
|
+
response = _context1.sent;
|
|
626
|
+
clientRegionInfo = response.body;
|
|
627
|
+
regionInfo.clientRegion = (clientRegionInfo === null || clientRegionInfo === void 0 ? void 0 : clientRegionInfo.clientRegion) || '';
|
|
628
|
+
regionInfo.countryCode = (clientRegionInfo === null || clientRegionInfo === void 0 ? void 0 : clientRegionInfo.countryCode) || '';
|
|
629
|
+
_Logger.default.log("Successfully fetched Client region info: ".concat(regionInfo.clientRegion, ", countryCode: ").concat(regionInfo.countryCode, ", and response trackingid: ").concat(response === null || response === void 0 ? void 0 : (_response$headers = response.headers) === null || _response$headers === void 0 ? void 0 : _response$headers.trackingid), {
|
|
630
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
631
|
+
method: _constants2.METHODS.GET_CLIENT_REGION_INFO
|
|
632
|
+
});
|
|
633
|
+
this.metricManager.submitRegionInfoMetric(_types5.METRIC_EVENT.MOBIUS_DISCOVERY, _types5.MOBIUS_SERVER_ACTION.REGION_INFO, _types5.METRIC_TYPE.BEHAVIORAL, this.mobiusHost, clientRegionInfo.clientRegion, clientRegionInfo.countryCode, (_response$headers$tra = response === null || response === void 0 ? void 0 : (_response$headers2 = response.headers) === null || _response$headers2 === void 0 ? void 0 : _response$headers2.trackingid) !== null && _response$headers$tra !== void 0 ? _response$headers$tra : '');
|
|
634
|
+
_context1.next = 6;
|
|
635
|
+
break;
|
|
636
|
+
case 3:
|
|
637
|
+
_context1.prev = 3;
|
|
638
|
+
_t4 = _context1["catch"](1);
|
|
639
|
+
_Logger.default.error("Failed to get client region info: ".concat((0, _stringify.default)(_t4)), {
|
|
640
|
+
method: _constants2.METHODS.GET_CLIENT_REGION_INFO,
|
|
641
|
+
file: _constants2.CALLING_CLIENT_FILE
|
|
642
|
+
});
|
|
643
|
+
|
|
644
|
+
// eslint-disable-next-line no-await-in-loop
|
|
645
|
+
_context1.next = 4;
|
|
646
|
+
return (0, _Utils.handleCallingClientErrors)(_t4, function (clientError) {
|
|
647
|
+
var _headers$trackingId, _headers2;
|
|
648
|
+
_this3.metricManager.submitRegistrationMetric(_types5.METRIC_EVENT.REGISTRATION_ERROR, _types5.REG_ACTION.REGISTER, _types5.METRIC_TYPE.BEHAVIORAL, _constants2.GET_MOBIUS_SERVERS_UTIL, 'UNKNOWN', (_headers$trackingId = (_headers2 = _t4.headers) === null || _headers2 === void 0 ? void 0 : _headers2.trackingId) !== null && _headers$trackingId !== void 0 ? _headers$trackingId : '', undefined, clientError);
|
|
649
|
+
_this3.emit(_types2.CALLING_CLIENT_EVENT_KEYS.ERROR, clientError);
|
|
650
|
+
}, {
|
|
651
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL,
|
|
652
|
+
file: _constants2.CALLING_CLIENT_FILE
|
|
653
|
+
});
|
|
654
|
+
case 4:
|
|
655
|
+
abort = _context1.sent;
|
|
656
|
+
regionInfo.clientRegion = '';
|
|
657
|
+
regionInfo.countryCode = '';
|
|
658
|
+
if (!abort) {
|
|
659
|
+
_context1.next = 6;
|
|
660
|
+
break;
|
|
661
|
+
}
|
|
662
|
+
_context1.next = 5;
|
|
663
|
+
return (0, _Utils.uploadLogs)();
|
|
664
|
+
case 5:
|
|
665
|
+
return _context1.abrupt("return", regionInfo);
|
|
666
|
+
case 6:
|
|
667
|
+
return _context1.abrupt("return", regionInfo);
|
|
668
|
+
case 7:
|
|
669
|
+
case "end":
|
|
670
|
+
return _context1.stop();
|
|
671
|
+
}
|
|
672
|
+
}, _callee0, this, [[1, 3]]);
|
|
673
|
+
}));
|
|
674
|
+
function getClientRegionInfo() {
|
|
675
|
+
return _getClientRegionInfo.apply(this, arguments);
|
|
676
|
+
}
|
|
677
|
+
return getClientRegionInfo;
|
|
678
|
+
}()
|
|
679
|
+
/**
|
|
680
|
+
* Local method for finding the mobius servers.
|
|
681
|
+
*/
|
|
682
|
+
)
|
|
683
|
+
}, {
|
|
684
|
+
key: "getMobiusServers",
|
|
685
|
+
value: (function () {
|
|
686
|
+
var _getMobiusServers = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee1() {
|
|
687
|
+
var _this$sdkConfig3,
|
|
688
|
+
_this$sdkConfig3$disc,
|
|
689
|
+
_this$sdkConfig4,
|
|
690
|
+
_this$sdkConfig4$disc,
|
|
691
|
+
_this4 = this;
|
|
692
|
+
var useDefault, clientRegion, countryCode, _this$sdkConfig5, _this$sdkConfig5$disc, _this$sdkConfig6, _this$sdkConfig6$disc, _this$webex$internal$, regionInfo, _iterator2, _step2, _loop2, _ret, _t6;
|
|
693
|
+
return _regenerator.default.wrap(function (_context11) {
|
|
694
|
+
while (1) switch (_context11.prev = _context11.next) {
|
|
695
|
+
case 0:
|
|
696
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
697
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
698
|
+
method: _constants2.METHODS.GET_MOBIUS_SERVERS
|
|
699
|
+
});
|
|
700
|
+
/* Following operations are performed in a synchronous way ->
|
|
701
|
+
1. Get RegionInfo
|
|
702
|
+
2. Get Mobius Server with that RegionInfo
|
|
703
|
+
3. Check whether Mobius server was found without any error
|
|
704
|
+
4. If there is error , we don't need to send registration
|
|
705
|
+
5. Otherwise send registration
|
|
706
|
+
*/
|
|
707
|
+
useDefault = false;
|
|
708
|
+
if (!((_this$sdkConfig3 = this.sdkConfig) !== null && _this$sdkConfig3 !== void 0 && (_this$sdkConfig3$disc = _this$sdkConfig3.discovery) !== null && _this$sdkConfig3$disc !== void 0 && _this$sdkConfig3$disc.country && (_this$sdkConfig4 = this.sdkConfig) !== null && _this$sdkConfig4 !== void 0 && (_this$sdkConfig4$disc = _this$sdkConfig4.discovery) !== null && _this$sdkConfig4$disc !== void 0 && _this$sdkConfig4$disc.region)) {
|
|
709
|
+
_context11.next = 1;
|
|
710
|
+
break;
|
|
711
|
+
}
|
|
712
|
+
_Logger.default.log('Updating region and country from the SDK config', {
|
|
713
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
714
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL
|
|
715
|
+
});
|
|
716
|
+
clientRegion = (_this$sdkConfig5 = this.sdkConfig) === null || _this$sdkConfig5 === void 0 ? void 0 : (_this$sdkConfig5$disc = _this$sdkConfig5.discovery) === null || _this$sdkConfig5$disc === void 0 ? void 0 : _this$sdkConfig5$disc.region;
|
|
717
|
+
countryCode = (_this$sdkConfig6 = this.sdkConfig) === null || _this$sdkConfig6 === void 0 ? void 0 : (_this$sdkConfig6$disc = _this$sdkConfig6.discovery) === null || _this$sdkConfig6$disc === void 0 ? void 0 : _this$sdkConfig6$disc.country;
|
|
718
|
+
this.mobiusHost = ((_this$webex$internal$ = this.webex.internal.services._serviceUrls) === null || _this$webex$internal$ === void 0 ? void 0 : _this$webex$internal$.mobius) || this.webex.internal.services.get(this.webex.internal.services._activeServices.mobius);
|
|
719
|
+
_context11.next = 3;
|
|
720
|
+
break;
|
|
721
|
+
case 1:
|
|
722
|
+
_Logger.default.log('Updating region and country through Region discovery', {
|
|
723
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
724
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL
|
|
725
|
+
});
|
|
726
|
+
_context11.next = 2;
|
|
727
|
+
return this.getClientRegionInfo();
|
|
728
|
+
case 2:
|
|
729
|
+
regionInfo = _context11.sent;
|
|
730
|
+
clientRegion = regionInfo.clientRegion;
|
|
731
|
+
countryCode = regionInfo.countryCode;
|
|
732
|
+
case 3:
|
|
733
|
+
if (!(clientRegion && countryCode)) {
|
|
734
|
+
_context11.next = 12;
|
|
735
|
+
break;
|
|
736
|
+
}
|
|
737
|
+
_Logger.default.log("Found Region: ".concat(clientRegion, " and country: ").concat(countryCode, ", going to fetch Mobius server"), {
|
|
738
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
739
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL
|
|
740
|
+
});
|
|
741
|
+
_iterator2 = _createForOfIteratorHelper(this.mobiusClusters);
|
|
742
|
+
_context11.prev = 4;
|
|
743
|
+
_loop2 = /*#__PURE__*/_regenerator.default.mark(function _loop2() {
|
|
744
|
+
var mobius, _response$headers3, _response$headers$tra2, _response$headers4, response, mobiusServers, mobiusUris, abort, _t5;
|
|
745
|
+
return _regenerator.default.wrap(function (_context10) {
|
|
746
|
+
while (1) switch (_context10.prev = _context10.next) {
|
|
747
|
+
case 0:
|
|
748
|
+
mobius = _step2.value;
|
|
749
|
+
if (mobius.host) {
|
|
750
|
+
_this4.mobiusHost = "https://".concat(mobius.host).concat(_constants2.API_V1);
|
|
751
|
+
} else {
|
|
752
|
+
_this4.mobiusHost = mobius;
|
|
753
|
+
}
|
|
754
|
+
_context10.prev = 1;
|
|
755
|
+
_context10.next = 2;
|
|
756
|
+
return _this4.webex.request({
|
|
757
|
+
uri: "".concat(_this4.mobiusHost).concat(_constants2.URL_ENDPOINT, "?regionCode=").concat(clientRegion, "&countryCode=").concat(countryCode),
|
|
758
|
+
method: _types3.HTTP_METHODS.GET,
|
|
759
|
+
headers: (0, _defineProperty2.default)((0, _defineProperty2.default)({}, _constants2.CISCO_DEVICE_URL, _this4.webex.internal.device.url), _constants2.SPARK_USER_AGENT, _constants2.CALLING_USER_AGENT),
|
|
760
|
+
service: _types3.ALLOWED_SERVICES.MOBIUS
|
|
761
|
+
});
|
|
762
|
+
case 2:
|
|
763
|
+
response = _context10.sent;
|
|
764
|
+
_Logger.default.log("Mobius Server found for the region. Response trackingId: ".concat(response === null || response === void 0 ? void 0 : (_response$headers3 = response.headers) === null || _response$headers3 === void 0 ? void 0 : _response$headers3.trackingid), {
|
|
765
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
766
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL
|
|
767
|
+
});
|
|
768
|
+
mobiusServers = response.body; // Metrics for mobius servers
|
|
769
|
+
_this4.metricManager.submitMobiusServersMetric(_types5.METRIC_EVENT.MOBIUS_DISCOVERY, _types5.MOBIUS_SERVER_ACTION.MOBIUS_SERVERS, _types5.METRIC_TYPE.BEHAVIORAL, mobiusServers, (_response$headers$tra2 = response === null || response === void 0 ? void 0 : (_response$headers4 = response.headers) === null || _response$headers4 === void 0 ? void 0 : _response$headers4.trackingid) !== null && _response$headers$tra2 !== void 0 ? _response$headers$tra2 : '');
|
|
770
|
+
|
|
771
|
+
/* update arrays of Mobius Uris. */
|
|
772
|
+
mobiusUris = (0, _Utils.filterMobiusUris)(mobiusServers, _this4.mobiusHost);
|
|
773
|
+
_this4.primaryMobiusUris = mobiusUris.primary;
|
|
774
|
+
_this4.backupMobiusUris = mobiusUris.backup;
|
|
775
|
+
_this4.primaryWssMobiusUris = mobiusUris.primaryWss;
|
|
776
|
+
_this4.backupWssMobiusUris = mobiusUris.backupWss;
|
|
777
|
+
_Logger.default.log("Final list of Mobius Servers, primary: ".concat(mobiusUris.primary, " and backup: ").concat(mobiusUris.backup), {
|
|
778
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
779
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL
|
|
780
|
+
});
|
|
781
|
+
return _context10.abrupt("return", 0);
|
|
782
|
+
case 3:
|
|
783
|
+
_context10.prev = 3;
|
|
784
|
+
_t5 = _context10["catch"](1);
|
|
785
|
+
_Logger.default.error("Failed to get Mobius servers: ".concat((0, _stringify.default)(_t5)), {
|
|
786
|
+
method: _constants2.METHODS.GET_MOBIUS_SERVERS,
|
|
787
|
+
file: _constants2.CALLING_CLIENT_FILE
|
|
788
|
+
});
|
|
789
|
+
|
|
790
|
+
// eslint-disable-next-line no-await-in-loop
|
|
791
|
+
_context10.next = 4;
|
|
792
|
+
return (0, _Utils.handleCallingClientErrors)(_t5, function (clientError) {
|
|
793
|
+
var _headers$trackingId2, _headers4;
|
|
794
|
+
_this4.metricManager.submitRegistrationMetric(_types5.METRIC_EVENT.REGISTRATION_ERROR, _types5.REG_ACTION.REGISTER, _types5.METRIC_TYPE.BEHAVIORAL, _constants2.GET_MOBIUS_SERVERS_UTIL, 'UNKNOWN', (_headers$trackingId2 = (_headers4 = _t5.headers) === null || _headers4 === void 0 ? void 0 : _headers4.trackingId) !== null && _headers$trackingId2 !== void 0 ? _headers$trackingId2 : '', undefined, clientError);
|
|
795
|
+
_this4.emit(_types2.CALLING_CLIENT_EVENT_KEYS.ERROR, clientError);
|
|
796
|
+
}, {
|
|
797
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL,
|
|
798
|
+
file: _constants2.CALLING_CLIENT_FILE
|
|
799
|
+
});
|
|
800
|
+
case 4:
|
|
801
|
+
abort = _context10.sent;
|
|
802
|
+
if (!abort) {
|
|
803
|
+
_context10.next = 6;
|
|
804
|
+
break;
|
|
805
|
+
}
|
|
806
|
+
useDefault = true;
|
|
807
|
+
// eslint-disable-next-line no-await-in-loop
|
|
808
|
+
_context10.next = 5;
|
|
809
|
+
return (0, _Utils.uploadLogs)();
|
|
810
|
+
case 5:
|
|
811
|
+
return _context10.abrupt("return", 0);
|
|
812
|
+
case 6:
|
|
813
|
+
case "end":
|
|
814
|
+
return _context10.stop();
|
|
815
|
+
}
|
|
816
|
+
}, _loop2, null, [[1, 3]]);
|
|
817
|
+
});
|
|
818
|
+
_iterator2.s();
|
|
819
|
+
case 5:
|
|
820
|
+
if ((_step2 = _iterator2.n()).done) {
|
|
821
|
+
_context11.next = 8;
|
|
822
|
+
break;
|
|
823
|
+
}
|
|
824
|
+
return _context11.delegateYield(_loop2(), "t0", 6);
|
|
825
|
+
case 6:
|
|
826
|
+
_ret = _context11.t0;
|
|
827
|
+
if (!(_ret === 0)) {
|
|
828
|
+
_context11.next = 7;
|
|
829
|
+
break;
|
|
830
|
+
}
|
|
831
|
+
return _context11.abrupt("continue", 8);
|
|
832
|
+
case 7:
|
|
833
|
+
_context11.next = 5;
|
|
834
|
+
break;
|
|
835
|
+
case 8:
|
|
836
|
+
_context11.next = 10;
|
|
837
|
+
break;
|
|
838
|
+
case 9:
|
|
839
|
+
_context11.prev = 9;
|
|
840
|
+
_t6 = _context11["catch"](4);
|
|
841
|
+
_iterator2.e(_t6);
|
|
842
|
+
case 10:
|
|
843
|
+
_context11.prev = 10;
|
|
844
|
+
_iterator2.f();
|
|
845
|
+
return _context11.finish(10);
|
|
846
|
+
case 11:
|
|
847
|
+
_context11.next = 13;
|
|
848
|
+
break;
|
|
849
|
+
case 12:
|
|
850
|
+
/* Setting this to true because region info is possibly undefined */
|
|
851
|
+
useDefault = true;
|
|
852
|
+
case 13:
|
|
853
|
+
/* Use a default URL if Mobius discovery fails either because of region info failure
|
|
854
|
+
* or because the discovered Mobius couldn't be reached
|
|
855
|
+
*/
|
|
856
|
+
|
|
857
|
+
if (useDefault) {
|
|
858
|
+
_Logger.default.warn("Couldn't resolve the region and country code. Defaulting to the catalog entries to discover mobius servers", {
|
|
859
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
860
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL
|
|
861
|
+
});
|
|
862
|
+
this.mobiusHost = "https://".concat(this.mobiusClusters[0].host).concat(_constants2.API_V1);
|
|
863
|
+
this.primaryMobiusUris = ["".concat(this.mobiusHost).concat(_constants2.URL_ENDPOINT)];
|
|
864
|
+
}
|
|
865
|
+
case 14:
|
|
866
|
+
case "end":
|
|
867
|
+
return _context11.stop();
|
|
868
|
+
}
|
|
869
|
+
}, _callee1, this, [[4, 9, 10, 11]]);
|
|
870
|
+
}));
|
|
871
|
+
function getMobiusServers() {
|
|
872
|
+
return _getMobiusServers.apply(this, arguments);
|
|
873
|
+
}
|
|
874
|
+
return getMobiusServers;
|
|
875
|
+
}()
|
|
876
|
+
/**
|
|
877
|
+
* Connects to the Mobius WebSocket using WSS URIs discovered during Mobius server discovery.
|
|
878
|
+
* Attempts primary WSS URIs first, then falls back to backup WSS URIs.
|
|
879
|
+
* If all attempts fail, logs a warning and continues without a socket connection.
|
|
880
|
+
*/
|
|
881
|
+
)
|
|
882
|
+
}, {
|
|
883
|
+
key: "connectToMobiusSocket",
|
|
884
|
+
value: (function () {
|
|
885
|
+
var _connectToMobiusSocket = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee10() {
|
|
886
|
+
var loggerContext, _iterator3, _step3, wssUri, _iterator4, _step4, _wssUri, _t7, _t8, _t9, _t0;
|
|
887
|
+
return _regenerator.default.wrap(function (_context12) {
|
|
888
|
+
while (1) switch (_context12.prev = _context12.next) {
|
|
889
|
+
case 0:
|
|
890
|
+
loggerContext = {
|
|
891
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
892
|
+
method: _constants2.METHODS.CONNECT_TO_MOBIUS_SOCKET
|
|
893
|
+
};
|
|
894
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, loggerContext);
|
|
895
|
+
if (!(!this.primaryWssMobiusUris.length && !this.backupWssMobiusUris.length)) {
|
|
896
|
+
_context12.next = 1;
|
|
897
|
+
break;
|
|
898
|
+
}
|
|
899
|
+
_Logger.default.warn('No WSS URIs available from Mobius discovery, skipping socket connection', loggerContext);
|
|
900
|
+
return _context12.abrupt("return");
|
|
901
|
+
case 1:
|
|
902
|
+
if (!this.primaryWssMobiusUris.length) {
|
|
903
|
+
_context12.next = 12;
|
|
904
|
+
break;
|
|
905
|
+
}
|
|
906
|
+
_Logger.default.log("Attempting Mobius socket connection using primary WSS URIs (".concat(this.primaryWssMobiusUris.length, " available)"), loggerContext);
|
|
907
|
+
_iterator3 = _createForOfIteratorHelper(this.primaryWssMobiusUris);
|
|
908
|
+
_context12.prev = 2;
|
|
909
|
+
_iterator3.s();
|
|
910
|
+
case 3:
|
|
911
|
+
if ((_step3 = _iterator3.n()).done) {
|
|
912
|
+
_context12.next = 8;
|
|
913
|
+
break;
|
|
914
|
+
}
|
|
915
|
+
wssUri = _step3.value;
|
|
916
|
+
_context12.prev = 4;
|
|
917
|
+
_Logger.default.log("Trying primary WSS URI: ".concat(wssUri), loggerContext);
|
|
918
|
+
// eslint-disable-next-line no-await-in-loop
|
|
919
|
+
_context12.next = 5;
|
|
920
|
+
return this.mobiusSocket.connect(wssUri);
|
|
921
|
+
case 5:
|
|
922
|
+
_Logger.default.log("Successfully connected to Mobius socket on primary WSS URI: ".concat(wssUri), loggerContext);
|
|
923
|
+
return _context12.abrupt("return");
|
|
924
|
+
case 6:
|
|
925
|
+
_context12.prev = 6;
|
|
926
|
+
_t7 = _context12["catch"](4);
|
|
927
|
+
_Logger.default.warn("Primary WSS URI connection failed for ".concat(wssUri, ": ").concat(_t7), loggerContext);
|
|
928
|
+
case 7:
|
|
929
|
+
_context12.next = 3;
|
|
930
|
+
break;
|
|
931
|
+
case 8:
|
|
932
|
+
_context12.next = 10;
|
|
933
|
+
break;
|
|
934
|
+
case 9:
|
|
935
|
+
_context12.prev = 9;
|
|
936
|
+
_t8 = _context12["catch"](2);
|
|
937
|
+
_iterator3.e(_t8);
|
|
938
|
+
case 10:
|
|
939
|
+
_context12.prev = 10;
|
|
940
|
+
_iterator3.f();
|
|
941
|
+
return _context12.finish(10);
|
|
942
|
+
case 11:
|
|
943
|
+
_Logger.default.warn('All primary WSS URI connection attempts failed', loggerContext);
|
|
944
|
+
_context12.next = 13;
|
|
945
|
+
break;
|
|
946
|
+
case 12:
|
|
947
|
+
_Logger.default.warn('No primary WSS URIs available, skipping to backup', loggerContext);
|
|
948
|
+
case 13:
|
|
949
|
+
if (!this.backupWssMobiusUris.length) {
|
|
950
|
+
_context12.next = 24;
|
|
951
|
+
break;
|
|
952
|
+
}
|
|
953
|
+
_Logger.default.log("Attempting Mobius socket connection using backup WSS URIs (".concat(this.backupWssMobiusUris.length, " available)"), loggerContext);
|
|
954
|
+
_iterator4 = _createForOfIteratorHelper(this.backupWssMobiusUris);
|
|
955
|
+
_context12.prev = 14;
|
|
956
|
+
_iterator4.s();
|
|
957
|
+
case 15:
|
|
958
|
+
if ((_step4 = _iterator4.n()).done) {
|
|
959
|
+
_context12.next = 20;
|
|
960
|
+
break;
|
|
961
|
+
}
|
|
962
|
+
_wssUri = _step4.value;
|
|
963
|
+
_context12.prev = 16;
|
|
964
|
+
_Logger.default.log("Trying backup WSS URI: ".concat(_wssUri), loggerContext);
|
|
965
|
+
// eslint-disable-next-line no-await-in-loop
|
|
966
|
+
_context12.next = 17;
|
|
967
|
+
return this.mobiusSocket.connect(_wssUri);
|
|
968
|
+
case 17:
|
|
969
|
+
_Logger.default.log("Successfully connected to Mobius socket on backup WSS URI: ".concat(_wssUri), loggerContext);
|
|
970
|
+
return _context12.abrupt("return");
|
|
971
|
+
case 18:
|
|
972
|
+
_context12.prev = 18;
|
|
973
|
+
_t9 = _context12["catch"](16);
|
|
974
|
+
_Logger.default.warn("Backup WSS URI connection failed for ".concat(_wssUri, ": ").concat(_t9), loggerContext);
|
|
975
|
+
case 19:
|
|
976
|
+
_context12.next = 15;
|
|
977
|
+
break;
|
|
978
|
+
case 20:
|
|
979
|
+
_context12.next = 22;
|
|
980
|
+
break;
|
|
981
|
+
case 21:
|
|
982
|
+
_context12.prev = 21;
|
|
983
|
+
_t0 = _context12["catch"](14);
|
|
984
|
+
_iterator4.e(_t0);
|
|
985
|
+
case 22:
|
|
986
|
+
_context12.prev = 22;
|
|
987
|
+
_iterator4.f();
|
|
988
|
+
return _context12.finish(22);
|
|
989
|
+
case 23:
|
|
990
|
+
_Logger.default.warn('All backup WSS URI connection attempts failed', loggerContext);
|
|
991
|
+
_context12.next = 25;
|
|
992
|
+
break;
|
|
993
|
+
case 24:
|
|
994
|
+
_Logger.default.warn('No backup WSS URIs available', loggerContext);
|
|
995
|
+
case 25:
|
|
996
|
+
// MOBIUS WSS TODO: See if we need to throw an error here if all connection attempts fail
|
|
997
|
+
_Logger.default.warn('All Mobius socket connection attempts exhausted for both primary and backup, continuing without socket', loggerContext);
|
|
998
|
+
case 26:
|
|
999
|
+
case "end":
|
|
1000
|
+
return _context12.stop();
|
|
1001
|
+
}
|
|
1002
|
+
}, _callee10, this, [[2, 9, 10, 11], [4, 6], [14, 21, 22, 23], [16, 18]]);
|
|
1003
|
+
}));
|
|
1004
|
+
function connectToMobiusSocket() {
|
|
1005
|
+
return _connectToMobiusSocket.apply(this, arguments);
|
|
1006
|
+
}
|
|
1007
|
+
return connectToMobiusSocket;
|
|
1008
|
+
}())
|
|
1009
|
+
}, {
|
|
1010
|
+
key: "registerMobiusSocketListener",
|
|
1011
|
+
value: function registerMobiusSocketListener() {
|
|
1012
|
+
var _this5 = this;
|
|
1013
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
1014
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
1015
|
+
method: _constants2.METHODS.REGISTER_MOBIUS_SOCKET_LISTENER
|
|
1016
|
+
});
|
|
1017
|
+
this.sdkConnector.registerMobiusSocketListener('async_event', function (event) {
|
|
1018
|
+
_this5.handleMobiusAsyncEvent(event);
|
|
1019
|
+
});
|
|
1020
|
+
_Logger.default.info('Successfully registered listener for Mobius events', {
|
|
1021
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
1022
|
+
method: _constants2.METHODS.REGISTER_MOBIUS_SOCKET_LISTENER
|
|
1023
|
+
});
|
|
1024
|
+
}
|
|
1025
|
+
}, {
|
|
1026
|
+
key: "registerCallsClearedListener",
|
|
1027
|
+
value:
|
|
1028
|
+
/**
|
|
1029
|
+
* Registers a listener/handler for ALL_CALLS_CLEARED
|
|
1030
|
+
* event emitted by callManager when all the calls
|
|
1031
|
+
* present on sdk are cleaned up.
|
|
1032
|
+
*/
|
|
1033
|
+
function registerCallsClearedListener() {
|
|
1034
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
1035
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
1036
|
+
method: _constants2.METHODS.REGISTER_CALLS_CLEARED_LISTENER
|
|
1037
|
+
});
|
|
1038
|
+
this.callManager.on(_types2.CALLING_CLIENT_EVENT_KEYS.ALL_CALLS_CLEARED, this.callsClearedHandler);
|
|
1039
|
+
}
|
|
1040
|
+
}, {
|
|
1041
|
+
key: "getLoggingLevel",
|
|
1042
|
+
value:
|
|
1043
|
+
/**
|
|
1044
|
+
* To get the current log Level.
|
|
1045
|
+
* @ignore
|
|
1046
|
+
*/
|
|
1047
|
+
function getLoggingLevel() {
|
|
1048
|
+
return _Logger.default.getLogLevel();
|
|
1049
|
+
}
|
|
1050
|
+
|
|
1051
|
+
/**
|
|
1052
|
+
* To return the `sdkConnector` instance that was used during sdk initialisation.
|
|
1053
|
+
* @ignore
|
|
1054
|
+
*/
|
|
1055
|
+
}, {
|
|
1056
|
+
key: "getSDKConnector",
|
|
1057
|
+
value: function getSDKConnector() {
|
|
1058
|
+
return this.sdkConnector;
|
|
1059
|
+
}
|
|
1060
|
+
}, {
|
|
1061
|
+
key: "registerSessionsListener",
|
|
1062
|
+
value: function registerSessionsListener() {
|
|
1063
|
+
var _this6 = this;
|
|
1064
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
1065
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
1066
|
+
method: _constants2.METHODS.REGISTER_SESSIONS_LISTENER
|
|
1067
|
+
});
|
|
1068
|
+
this.sdkConnector.registerListener(_types2.MOBIUS_EVENT_KEYS.CALL_SESSION_EVENT_INCLUSIVE, /*#__PURE__*/function () {
|
|
1069
|
+
var _ref7 = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee11(event) {
|
|
1070
|
+
var sessionArr, i;
|
|
1071
|
+
return _regenerator.default.wrap(function (_context13) {
|
|
1072
|
+
while (1) switch (_context13.prev = _context13.next) {
|
|
1073
|
+
case 0:
|
|
1074
|
+
if (!(event && event.data.userSessions.userSessions)) {
|
|
1075
|
+
_context13.next = 2;
|
|
1076
|
+
break;
|
|
1077
|
+
}
|
|
1078
|
+
sessionArr = event === null || event === void 0 ? void 0 : event.data.userSessions.userSessions;
|
|
1079
|
+
if (!(sessionArr.length === 1)) {
|
|
1080
|
+
_context13.next = 1;
|
|
1081
|
+
break;
|
|
1082
|
+
}
|
|
1083
|
+
if (!(sessionArr[0].sessionType !== _types2.SessionType.WEBEX_CALLING)) {
|
|
1084
|
+
_context13.next = 1;
|
|
1085
|
+
break;
|
|
1086
|
+
}
|
|
1087
|
+
return _context13.abrupt("return");
|
|
1088
|
+
case 1:
|
|
1089
|
+
for (i = 0; i < sessionArr.length; i += 1) {
|
|
1090
|
+
if (sessionArr[i].sessionType !== _types2.SessionType.WEBEX_CALLING) {
|
|
1091
|
+
sessionArr.splice(i, 1);
|
|
1092
|
+
}
|
|
1093
|
+
}
|
|
1094
|
+
_this6.emit(_types2.CALLING_CLIENT_EVENT_KEYS.USER_SESSION_INFO, event);
|
|
1095
|
+
case 2:
|
|
1096
|
+
case "end":
|
|
1097
|
+
return _context13.stop();
|
|
1098
|
+
}
|
|
1099
|
+
}, _callee11);
|
|
1100
|
+
}));
|
|
1101
|
+
return function (_x2) {
|
|
1102
|
+
return _ref7.apply(this, arguments);
|
|
1103
|
+
};
|
|
1104
|
+
}());
|
|
1105
|
+
}
|
|
1106
|
+
|
|
1107
|
+
/**
|
|
1108
|
+
* Creates line object inside calling client per user
|
|
1109
|
+
* NOTE: currently multiple lines are not supported
|
|
1110
|
+
*/
|
|
1111
|
+
}, {
|
|
1112
|
+
key: "createLine",
|
|
1113
|
+
value: (function () {
|
|
1114
|
+
var _createLine = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee12() {
|
|
1115
|
+
var _this$sdkConfig7, _this$sdkConfig8;
|
|
1116
|
+
var line;
|
|
1117
|
+
return _regenerator.default.wrap(function (_context14) {
|
|
1118
|
+
while (1) switch (_context14.prev = _context14.next) {
|
|
1119
|
+
case 0:
|
|
1120
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
1121
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
1122
|
+
method: _constants2.METHODS.CREATE_LINE
|
|
1123
|
+
});
|
|
1124
|
+
line = new _line.default(this.webex.internal.device.userId, this.webex.internal.device.url, this.mutex, this.apiRequest.isSocketEnabled() ? (0, _Utils.normalizeMobiusUris)(this.primaryWssMobiusUris) : this.primaryMobiusUris, this.apiRequest.isSocketEnabled() ? (0, _Utils.normalizeMobiusUris)(this.backupWssMobiusUris) : this.backupMobiusUris, this.getLoggingLevel(), (_this$sdkConfig7 = this.sdkConfig) === null || _this$sdkConfig7 === void 0 ? void 0 : _this$sdkConfig7.serviceData, (_this$sdkConfig8 = this.sdkConfig) === null || _this$sdkConfig8 === void 0 ? void 0 : _this$sdkConfig8.jwe);
|
|
1125
|
+
this.lineDict[line.lineId] = line;
|
|
1126
|
+
case 1:
|
|
1127
|
+
case "end":
|
|
1128
|
+
return _context14.stop();
|
|
1129
|
+
}
|
|
1130
|
+
}, _callee12, this);
|
|
1131
|
+
}));
|
|
1132
|
+
function createLine() {
|
|
1133
|
+
return _createLine.apply(this, arguments);
|
|
1134
|
+
}
|
|
1135
|
+
return createLine;
|
|
1136
|
+
}()
|
|
1137
|
+
/**
|
|
1138
|
+
* Retrieves details of all the Line objects belonging to a User
|
|
1139
|
+
* NOTE: currently multiple lines are not supported
|
|
1140
|
+
*/
|
|
1141
|
+
)
|
|
1142
|
+
}, {
|
|
1143
|
+
key: "getLines",
|
|
1144
|
+
value: function getLines() {
|
|
1145
|
+
return this.lineDict;
|
|
1146
|
+
}
|
|
1147
|
+
|
|
1148
|
+
/**
|
|
1149
|
+
* Fetches the list of devices for a given user from Mobius.
|
|
1150
|
+
*/
|
|
1151
|
+
}, {
|
|
1152
|
+
key: "getDevices",
|
|
1153
|
+
value: (function () {
|
|
1154
|
+
var _getDevices = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee13(userId) {
|
|
1155
|
+
var userid, mobiusUrls, finalError, _iterator5, _step5, mobiusUrl, normalizedMobiusUrl, uri, _body$devices, response, body, _t1, _t10;
|
|
1156
|
+
return _regenerator.default.wrap(function (_context15) {
|
|
1157
|
+
while (1) switch (_context15.prev = _context15.next) {
|
|
1158
|
+
case 0:
|
|
1159
|
+
userid = userId || this.webex.internal.device.userId;
|
|
1160
|
+
if (userid) {
|
|
1161
|
+
_context15.next = 1;
|
|
1162
|
+
break;
|
|
1163
|
+
}
|
|
1164
|
+
throw new Error('userId is required to fetch devices');
|
|
1165
|
+
case 1:
|
|
1166
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
1167
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
1168
|
+
method: _constants2.METHODS.GET_DEVICES
|
|
1169
|
+
});
|
|
1170
|
+
mobiusUrls = [].concat((0, _toConsumableArray2.default)(this.primaryMobiusUris), (0, _toConsumableArray2.default)(this.backupMobiusUris));
|
|
1171
|
+
if (!(mobiusUrls.length === 0)) {
|
|
1172
|
+
_context15.next = 2;
|
|
1173
|
+
break;
|
|
1174
|
+
}
|
|
1175
|
+
throw new Error('Mobius URLs are not available');
|
|
1176
|
+
case 2:
|
|
1177
|
+
_iterator5 = _createForOfIteratorHelper(mobiusUrls);
|
|
1178
|
+
_context15.prev = 3;
|
|
1179
|
+
_iterator5.s();
|
|
1180
|
+
case 4:
|
|
1181
|
+
if ((_step5 = _iterator5.n()).done) {
|
|
1182
|
+
_context15.next = 10;
|
|
1183
|
+
break;
|
|
1184
|
+
}
|
|
1185
|
+
mobiusUrl = _step5.value;
|
|
1186
|
+
normalizedMobiusUrl = mobiusUrl.replace(/\/+$/, '/');
|
|
1187
|
+
uri = "".concat(normalizedMobiusUrl).concat(_constants2.DEVICES_ENDPOINT_RESOURCE, "?userid=").concat(encodeURIComponent(userid));
|
|
1188
|
+
_context15.prev = 5;
|
|
1189
|
+
_context15.next = 6;
|
|
1190
|
+
return this.apiRequest.makeRequest({
|
|
1191
|
+
uri: uri,
|
|
1192
|
+
method: _types3.HTTP_METHODS.GET,
|
|
1193
|
+
service: _types3.ALLOWED_SERVICES.MOBIUS,
|
|
1194
|
+
headers: (0, _defineProperty2.default)((0, _defineProperty2.default)({}, _constants2.CISCO_DEVICE_URL, this.webex.internal.device.url), _constants2.SPARK_USER_AGENT, _constants2.CALLING_USER_AGENT)
|
|
1195
|
+
});
|
|
1196
|
+
case 6:
|
|
1197
|
+
response = _context15.sent;
|
|
1198
|
+
if (!(response.statusCode !== 200)) {
|
|
1199
|
+
_context15.next = 7;
|
|
1200
|
+
break;
|
|
1201
|
+
}
|
|
1202
|
+
throw new Error("API call failed with ".concat(response.statusCode));
|
|
1203
|
+
case 7:
|
|
1204
|
+
body = response.body; // Hydrate registration deviceInfo for deregister/restore flows
|
|
1205
|
+
(0, _values.default)(this.lineDict)[0].registration.setDeviceInfo(body);
|
|
1206
|
+
(0, _values.default)(this.lineDict)[0].registration.setActiveMobiusUrl(normalizedMobiusUrl);
|
|
1207
|
+
return _context15.abrupt("return", (_body$devices = body.devices) !== null && _body$devices !== void 0 ? _body$devices : []);
|
|
1208
|
+
case 8:
|
|
1209
|
+
_context15.prev = 8;
|
|
1210
|
+
_t1 = _context15["catch"](5);
|
|
1211
|
+
finalError = _t1;
|
|
1212
|
+
case 9:
|
|
1213
|
+
_context15.next = 4;
|
|
1214
|
+
break;
|
|
1215
|
+
case 10:
|
|
1216
|
+
_context15.next = 12;
|
|
1217
|
+
break;
|
|
1218
|
+
case 11:
|
|
1219
|
+
_context15.prev = 11;
|
|
1220
|
+
_t10 = _context15["catch"](3);
|
|
1221
|
+
_iterator5.e(_t10);
|
|
1222
|
+
case 12:
|
|
1223
|
+
_context15.prev = 12;
|
|
1224
|
+
_iterator5.f();
|
|
1225
|
+
return _context15.finish(12);
|
|
1226
|
+
case 13:
|
|
1227
|
+
_Logger.default.error("Failed to fetch devices for userId ".concat(userId, ": ").concat((0, _stringify.default)(finalError)), {
|
|
1228
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
1229
|
+
method: _constants2.METHODS.GET_DEVICES
|
|
1230
|
+
});
|
|
1231
|
+
throw finalError;
|
|
1232
|
+
case 14:
|
|
1233
|
+
case "end":
|
|
1234
|
+
return _context15.stop();
|
|
1235
|
+
}
|
|
1236
|
+
}, _callee13, this, [[3, 11, 12, 13], [5, 8]]);
|
|
1237
|
+
}));
|
|
1238
|
+
function getDevices(_x3) {
|
|
1239
|
+
return _getDevices.apply(this, arguments);
|
|
1240
|
+
}
|
|
1241
|
+
return getDevices;
|
|
1242
|
+
}()
|
|
1243
|
+
/**
|
|
1244
|
+
* Retrieves call objects for all the active calls present in the client
|
|
1245
|
+
*/
|
|
1246
|
+
)
|
|
1247
|
+
}, {
|
|
1248
|
+
key: "getActiveCalls",
|
|
1249
|
+
value: function getActiveCalls() {
|
|
1250
|
+
var activeCalls = {};
|
|
1251
|
+
var calls = this.callManager.getActiveCalls();
|
|
1252
|
+
(0, _keys.default)(calls).forEach(function (correlationId) {
|
|
1253
|
+
var call = calls[correlationId];
|
|
1254
|
+
if (!activeCalls[call.lineId]) {
|
|
1255
|
+
activeCalls[call.lineId] = [];
|
|
1256
|
+
}
|
|
1257
|
+
activeCalls[call.lineId].push(call);
|
|
1258
|
+
});
|
|
1259
|
+
return activeCalls;
|
|
1260
|
+
}
|
|
1261
|
+
|
|
1262
|
+
/**
|
|
1263
|
+
* Retrieves call object for the connected call in the client
|
|
1264
|
+
*/
|
|
1265
|
+
}, {
|
|
1266
|
+
key: "getConnectedCall",
|
|
1267
|
+
value: function getConnectedCall() {
|
|
1268
|
+
var connectCall;
|
|
1269
|
+
var calls = this.callManager.getActiveCalls();
|
|
1270
|
+
(0, _keys.default)(calls).forEach(function (correlationId) {
|
|
1271
|
+
if (calls[correlationId].isConnected() && !calls[correlationId].isHeld()) {
|
|
1272
|
+
connectCall = calls[correlationId];
|
|
1273
|
+
}
|
|
1274
|
+
});
|
|
1275
|
+
return connectCall;
|
|
1276
|
+
}
|
|
1277
|
+
|
|
1278
|
+
/**
|
|
1279
|
+
* Uploads logs to help troubleshoot SDK issues.
|
|
1280
|
+
*
|
|
1281
|
+
* This method collects the current SDK logs including network requests, WebSocket
|
|
1282
|
+
* messages, and client-side events, then securely submits them to Webex's diagnostics
|
|
1283
|
+
* service. The returned tracking ID, feedbackID can be provided to Webex support for faster
|
|
1284
|
+
* issue resolution.
|
|
1285
|
+
* @returns Promise<UploadLogsResponse>
|
|
1286
|
+
* @throws Error
|
|
1287
|
+
*/
|
|
1288
|
+
}, {
|
|
1289
|
+
key: "uploadLogs",
|
|
1290
|
+
value: (function () {
|
|
1291
|
+
var _uploadLogs2 = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee14() {
|
|
1292
|
+
var result;
|
|
1293
|
+
return _regenerator.default.wrap(function (_context16) {
|
|
1294
|
+
while (1) switch (_context16.prev = _context16.next) {
|
|
1295
|
+
case 0:
|
|
1296
|
+
_context16.next = 1;
|
|
1297
|
+
return (0, _Utils.uploadLogs)({}, true);
|
|
1298
|
+
case 1:
|
|
1299
|
+
result = _context16.sent;
|
|
1300
|
+
if (result) {
|
|
1301
|
+
_context16.next = 2;
|
|
1302
|
+
break;
|
|
1303
|
+
}
|
|
1304
|
+
throw new Error('Failed to upload logs: No response received.');
|
|
1305
|
+
case 2:
|
|
1306
|
+
return _context16.abrupt("return", result);
|
|
1307
|
+
case 3:
|
|
1308
|
+
case "end":
|
|
1309
|
+
return _context16.stop();
|
|
1310
|
+
}
|
|
1311
|
+
}, _callee14);
|
|
1312
|
+
}));
|
|
1313
|
+
function uploadLogs() {
|
|
1314
|
+
return _uploadLogs2.apply(this, arguments);
|
|
1315
|
+
}
|
|
1316
|
+
return uploadLogs;
|
|
1317
|
+
}())
|
|
1318
|
+
}]);
|
|
1319
|
+
}(_impl.Eventing);
|
|
1320
|
+
/**
|
|
1321
|
+
* Create the `CallingClient` instance using the `webex` object and callingSdk `config`
|
|
1322
|
+
* @param webex - A webex instance.
|
|
1323
|
+
* @param config - Config to start the CallingClient with.
|
|
1324
|
+
*/
|
|
1325
|
+
var createClient = exports.createClient = /*#__PURE__*/function () {
|
|
1326
|
+
var _ref8 = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee15(webex, config) {
|
|
1327
|
+
var callingClientInstance;
|
|
1328
|
+
return _regenerator.default.wrap(function (_context17) {
|
|
1329
|
+
while (1) switch (_context17.prev = _context17.next) {
|
|
1330
|
+
case 0:
|
|
1331
|
+
callingClientInstance = new CallingClient(webex, config);
|
|
1332
|
+
_context17.next = 1;
|
|
1333
|
+
return callingClientInstance.init();
|
|
1334
|
+
case 1:
|
|
1335
|
+
return _context17.abrupt("return", callingClientInstance);
|
|
1336
|
+
case 2:
|
|
1337
|
+
case "end":
|
|
1338
|
+
return _context17.stop();
|
|
1339
|
+
}
|
|
1340
|
+
}, _callee15);
|
|
1341
|
+
}));
|
|
1342
|
+
return function createClient(_x4, _x5) {
|
|
1343
|
+
return _ref8.apply(this, arguments);
|
|
1344
|
+
};
|
|
1345
|
+
}();
|
|
1346
|
+
//# sourceMappingURL=CallingClient.js.map
|