@webex/calling 3.11.0 → 3.12.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/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 +1119 -0
- package/dist/CallingClient/CallingClient.js.map +1 -0
- package/dist/CallingClient/CallingClient.test.js +1266 -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 +3486 -0
- package/dist/CallingClient/calling/call.js.map +1 -0
- package/dist/CallingClient/calling/call.test.js +3612 -0
- package/dist/CallingClient/calling/call.test.js.map +1 -0
- package/dist/CallingClient/calling/callManager.js +460 -0
- package/dist/CallingClient/calling/callManager.js.map +1 -0
- package/dist/CallingClient/calling/callManager.test.js +741 -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 +74 -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 +243 -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 +327 -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 +1686 -0
- package/dist/CallingClient/registration/register.js.map +1 -0
- package/dist/CallingClient/registration/register.test.js +1885 -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 +130 -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/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 +107 -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 +102 -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 +1483 -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 +983 -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 +43 -1
- package/dist/module/CallingClient/calling/call.js +3 -2
- package/dist/module/CallingClient/constants.js +2 -0
- package/dist/module/CallingClient/registration/register.js +8 -0
- package/dist/types/CallHistory/CallHistory.d.ts.map +1 -1
- package/dist/types/CallingClient/CallingClient.d.ts +2 -1
- package/dist/types/CallingClient/CallingClient.d.ts.map +1 -1
- package/dist/types/CallingClient/calling/call.d.ts.map +1 -1
- package/dist/types/CallingClient/constants.d.ts +2 -0
- package/dist/types/CallingClient/constants.d.ts.map +1 -1
- package/dist/types/CallingClient/registration/register.d.ts +2 -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/types.d.ts +2 -1
- package/dist/types/CallingClient/types.d.ts.map +1 -1
- package/dist/types/common/types.d.ts +4 -0
- package/dist/types/common/types.d.ts.map +1 -1
- package/package.json +4 -4
|
@@ -0,0 +1,1119 @@
|
|
|
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 _asyncMutex = require("async-mutex");
|
|
31
|
+
var _constants = require("../common/constants");
|
|
32
|
+
var _Utils = require("../common/Utils");
|
|
33
|
+
var _types = require("../Logger/types");
|
|
34
|
+
var _SDKConnector = _interopRequireDefault(require("../SDKConnector"));
|
|
35
|
+
var _impl = require("../Events/impl");
|
|
36
|
+
var _types2 = require("../Events/types");
|
|
37
|
+
var _types3 = require("../common/types");
|
|
38
|
+
var _Logger = _interopRequireDefault(require("../Logger"));
|
|
39
|
+
var _callManager = require("./calling/callManager");
|
|
40
|
+
var _constants2 = require("./constants");
|
|
41
|
+
var _line = _interopRequireDefault(require("./line"));
|
|
42
|
+
var _types4 = require("../Metrics/types");
|
|
43
|
+
var _Metrics = require("../Metrics");
|
|
44
|
+
var _windowsChromiumIceWarmupUtils = _interopRequireDefault(require("./windowsChromiumIceWarmupUtils"));
|
|
45
|
+
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 _t9 in e) "default" !== _t9 && {}.hasOwnProperty.call(e, _t9) && ((i = (o = _Object$defineProperty) && _Object$getOwnPropertyDescriptor(e, _t9)) && (i.get || i.set) ? o(f, _t9, i) : f[_t9] = e[_t9]); return f; })(e, t); }
|
|
46
|
+
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; } } }; }
|
|
47
|
+
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; } }
|
|
48
|
+
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; }
|
|
49
|
+
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)); }
|
|
50
|
+
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 */
|
|
51
|
+
/**
|
|
52
|
+
* The `CallingClient` module provides a set of APIs for line registration and calling functionalities within the SDK.
|
|
53
|
+
*
|
|
54
|
+
* The following code snippet demonstrates how to create an instance of `CallingClient` using a `webex` instance and `callingConfig`:
|
|
55
|
+
*
|
|
56
|
+
* @example
|
|
57
|
+
* ```javascript
|
|
58
|
+
* const callingClient = createClient(webex, callingConfig);
|
|
59
|
+
* ```
|
|
60
|
+
*/
|
|
61
|
+
var CallingClient = exports.CallingClient = /*#__PURE__*/function (_Eventing) {
|
|
62
|
+
/**
|
|
63
|
+
* @ignore
|
|
64
|
+
*/
|
|
65
|
+
function CallingClient(webex, config) {
|
|
66
|
+
var _this$sdkConfig, _this$sdkConfig$servi, _this$sdkConfig2, _this$sdkConfig2$logg;
|
|
67
|
+
var _this;
|
|
68
|
+
(0, _classCallCheck2.default)(this, CallingClient);
|
|
69
|
+
_this = _callSuper(this, CallingClient);
|
|
70
|
+
(0, _defineProperty2.default)(_this, "sdkConnector", void 0);
|
|
71
|
+
(0, _defineProperty2.default)(_this, "webex", void 0);
|
|
72
|
+
(0, _defineProperty2.default)(_this, "mutex", void 0);
|
|
73
|
+
(0, _defineProperty2.default)(_this, "callManager", void 0);
|
|
74
|
+
(0, _defineProperty2.default)(_this, "metricManager", void 0);
|
|
75
|
+
(0, _defineProperty2.default)(_this, "sdkConfig", void 0);
|
|
76
|
+
(0, _defineProperty2.default)(_this, "primaryMobiusUris", void 0);
|
|
77
|
+
(0, _defineProperty2.default)(_this, "backupMobiusUris", void 0);
|
|
78
|
+
(0, _defineProperty2.default)(_this, "mobiusClusters", void 0);
|
|
79
|
+
(0, _defineProperty2.default)(_this, "mobiusHost", void 0);
|
|
80
|
+
(0, _defineProperty2.default)(_this, "mediaEngine", void 0);
|
|
81
|
+
(0, _defineProperty2.default)(_this, "lineDict", {});
|
|
82
|
+
(0, _defineProperty2.default)(_this, "isNetworkDown", false);
|
|
83
|
+
(0, _defineProperty2.default)(_this, "networkDownTimestamp", '');
|
|
84
|
+
(0, _defineProperty2.default)(_this, "networkUpTimestamp", '');
|
|
85
|
+
(0, _defineProperty2.default)(_this, "mercuryDownTimestamp", '');
|
|
86
|
+
(0, _defineProperty2.default)(_this, "mercuryUpTimestamp", '');
|
|
87
|
+
(0, _defineProperty2.default)(_this, "handleNetworkOffline", /*#__PURE__*/(0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee() {
|
|
88
|
+
var line;
|
|
89
|
+
return _regenerator.default.wrap(function (_context) {
|
|
90
|
+
while (1) switch (_context.prev = _context.next) {
|
|
91
|
+
case 0:
|
|
92
|
+
_this.networkDownTimestamp = new Date().toISOString();
|
|
93
|
+
_context.next = 1;
|
|
94
|
+
return _this.checkNetworkReachability();
|
|
95
|
+
case 1:
|
|
96
|
+
_this.isNetworkDown = !_context.sent;
|
|
97
|
+
_Logger.default.warn("Network has gone down, wait for it to come back up", {
|
|
98
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
99
|
+
method: _constants2.METHODS.NETWORK_OFFLINE
|
|
100
|
+
});
|
|
101
|
+
if (_this.isNetworkDown) {
|
|
102
|
+
line = (0, _values.default)(_this.lineDict)[0];
|
|
103
|
+
line.registration.clearKeepaliveTimer();
|
|
104
|
+
}
|
|
105
|
+
case 2:
|
|
106
|
+
case "end":
|
|
107
|
+
return _context.stop();
|
|
108
|
+
}
|
|
109
|
+
}, _callee);
|
|
110
|
+
})));
|
|
111
|
+
// Wondering if we should keep this for timestamp recording purpose
|
|
112
|
+
(0, _defineProperty2.default)(_this, "handleNetworkOnline", function () {
|
|
113
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
114
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
115
|
+
method: _constants2.METHODS.NETWORK_ONLINE
|
|
116
|
+
});
|
|
117
|
+
_this.networkUpTimestamp = new Date().toISOString();
|
|
118
|
+
});
|
|
119
|
+
(0, _defineProperty2.default)(_this, "handleMercuryOffline", function () {
|
|
120
|
+
_Logger.default.warn("Mercury down, waiting for connection to be up", {
|
|
121
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
122
|
+
method: _constants2.METHODS.MERCURY_OFFLINE
|
|
123
|
+
});
|
|
124
|
+
_this.mercuryDownTimestamp = new Date().toISOString();
|
|
125
|
+
_this.metricManager.submitConnectionMetrics(_types4.METRIC_EVENT.CONNECTION_ERROR, _types4.CONNECTION_ACTION.MERCURY_DOWN, _types4.METRIC_TYPE.BEHAVIORAL, _this.mercuryDownTimestamp, _this.mercuryUpTimestamp);
|
|
126
|
+
});
|
|
127
|
+
(0, _defineProperty2.default)(_this, "handleMercuryOnline", /*#__PURE__*/(0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee3() {
|
|
128
|
+
var callCheckInterval;
|
|
129
|
+
return _regenerator.default.wrap(function (_context3) {
|
|
130
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
131
|
+
case 0:
|
|
132
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
133
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
134
|
+
method: _constants2.METHODS.MERCURY_ONLINE
|
|
135
|
+
});
|
|
136
|
+
_this.mercuryUpTimestamp = new Date().toISOString();
|
|
137
|
+
if (!_this.isNetworkDown) {
|
|
138
|
+
_context3.next = 2;
|
|
139
|
+
break;
|
|
140
|
+
}
|
|
141
|
+
callCheckInterval = setInterval(/*#__PURE__*/(0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee2() {
|
|
142
|
+
var line;
|
|
143
|
+
return _regenerator.default.wrap(function (_context2) {
|
|
144
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
145
|
+
case 0:
|
|
146
|
+
if ((0, _keys.default)(_this.callManager.getActiveCalls()).length) {
|
|
147
|
+
_context2.next = 3;
|
|
148
|
+
break;
|
|
149
|
+
}
|
|
150
|
+
clearInterval(callCheckInterval);
|
|
151
|
+
line = (0, _values.default)(_this.lineDict)[0];
|
|
152
|
+
if (!(line.getStatus() !== _types3.RegistrationStatus.IDLE)) {
|
|
153
|
+
_context2.next = 2;
|
|
154
|
+
break;
|
|
155
|
+
}
|
|
156
|
+
_context2.next = 1;
|
|
157
|
+
return line.registration.handleConnectionRestoration(_this.isNetworkDown);
|
|
158
|
+
case 1:
|
|
159
|
+
_this.isNetworkDown = _context2.sent;
|
|
160
|
+
_context2.next = 3;
|
|
161
|
+
break;
|
|
162
|
+
case 2:
|
|
163
|
+
_this.isNetworkDown = false;
|
|
164
|
+
case 3:
|
|
165
|
+
case "end":
|
|
166
|
+
return _context2.stop();
|
|
167
|
+
}
|
|
168
|
+
}, _callee2);
|
|
169
|
+
})), _constants2.NETWORK_FLAP_TIMEOUT);
|
|
170
|
+
if (!(0, _keys.default)(_this.callManager.getActiveCalls()).length) {
|
|
171
|
+
_context3.next = 1;
|
|
172
|
+
break;
|
|
173
|
+
}
|
|
174
|
+
_context3.next = 1;
|
|
175
|
+
return _this.checkCallStatus();
|
|
176
|
+
case 1:
|
|
177
|
+
_this.metricManager.submitConnectionMetrics(_types4.METRIC_EVENT.CONNECTION_ERROR, _types4.CONNECTION_ACTION.NETWORK_FLAP, _types4.METRIC_TYPE.BEHAVIORAL, _this.networkDownTimestamp, _this.networkUpTimestamp);
|
|
178
|
+
_context3.next = 4;
|
|
179
|
+
break;
|
|
180
|
+
case 2:
|
|
181
|
+
if (!(0, _keys.default)(_this.callManager.getActiveCalls()).length) {
|
|
182
|
+
_context3.next = 3;
|
|
183
|
+
break;
|
|
184
|
+
}
|
|
185
|
+
_context3.next = 3;
|
|
186
|
+
return _this.checkCallStatus();
|
|
187
|
+
case 3:
|
|
188
|
+
_this.metricManager.submitConnectionMetrics(_types4.METRIC_EVENT.CONNECTION_ERROR, _types4.CONNECTION_ACTION.MERCURY_UP, _types4.METRIC_TYPE.BEHAVIORAL, _this.mercuryDownTimestamp, _this.mercuryUpTimestamp);
|
|
189
|
+
case 4:
|
|
190
|
+
case "end":
|
|
191
|
+
return _context3.stop();
|
|
192
|
+
}
|
|
193
|
+
}, _callee3);
|
|
194
|
+
})));
|
|
195
|
+
/**
|
|
196
|
+
* Handler registered for ALL_CALLS_CLEARED event emitted by callManager.
|
|
197
|
+
*
|
|
198
|
+
* If re-register attempt was deferred earlier due to active call(s), then it
|
|
199
|
+
* will be attempted here on receiving a notification from callManager that all
|
|
200
|
+
* calls are cleaned up.
|
|
201
|
+
*/
|
|
202
|
+
(0, _defineProperty2.default)(_this, "callsClearedHandler", /*#__PURE__*/(0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee5() {
|
|
203
|
+
var registration;
|
|
204
|
+
return _regenerator.default.wrap(function (_context5) {
|
|
205
|
+
while (1) switch (_context5.prev = _context5.next) {
|
|
206
|
+
case 0:
|
|
207
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
208
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
209
|
+
method: _constants2.METHODS.CALLS_CLEARED_HANDLER
|
|
210
|
+
});
|
|
211
|
+
// this is a temporary logic to get registration obj
|
|
212
|
+
// it will change once we have proper lineId and multiple lines as well
|
|
213
|
+
registration = (0, _values.default)(_this.lineDict)[0].registration;
|
|
214
|
+
if (registration.isDeviceRegistered()) {
|
|
215
|
+
_context5.next = 1;
|
|
216
|
+
break;
|
|
217
|
+
}
|
|
218
|
+
_context5.next = 1;
|
|
219
|
+
return _this.mutex.runExclusive(/*#__PURE__*/(0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee4() {
|
|
220
|
+
return _regenerator.default.wrap(function (_context4) {
|
|
221
|
+
while (1) switch (_context4.prev = _context4.next) {
|
|
222
|
+
case 0:
|
|
223
|
+
if (!registration.isReconnectPending()) {
|
|
224
|
+
_context4.next = 1;
|
|
225
|
+
break;
|
|
226
|
+
}
|
|
227
|
+
_Logger.default.info('All calls cleared, reconnecting', {
|
|
228
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
229
|
+
method: _constants2.CALLS_CLEARED_HANDLER_UTIL
|
|
230
|
+
});
|
|
231
|
+
_context4.next = 1;
|
|
232
|
+
return registration.reconnectOnFailure(_constants2.CALLS_CLEARED_HANDLER_UTIL);
|
|
233
|
+
case 1:
|
|
234
|
+
case "end":
|
|
235
|
+
return _context4.stop();
|
|
236
|
+
}
|
|
237
|
+
}, _callee4);
|
|
238
|
+
})));
|
|
239
|
+
case 1:
|
|
240
|
+
case "end":
|
|
241
|
+
return _context5.stop();
|
|
242
|
+
}
|
|
243
|
+
}, _callee5);
|
|
244
|
+
})));
|
|
245
|
+
_this.sdkConnector = _SDKConnector.default;
|
|
246
|
+
if (!_this.sdkConnector.getWebex()) {
|
|
247
|
+
var _config$logger;
|
|
248
|
+
_SDKConnector.default.setWebex(webex);
|
|
249
|
+
if (config !== null && config !== void 0 && (_config$logger = config.logger) !== null && _config$logger !== void 0 && _config$logger.level && webex.logger.config) {
|
|
250
|
+
webex.logger.config.level = config.logger.level; // override the webex logger level
|
|
251
|
+
}
|
|
252
|
+
_Logger.default.setWebexLogger(webex.logger);
|
|
253
|
+
}
|
|
254
|
+
_this.mutex = new _asyncMutex.Mutex();
|
|
255
|
+
_this.webex = _this.sdkConnector.getWebex();
|
|
256
|
+
_this.sdkConfig = config;
|
|
257
|
+
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 : {
|
|
258
|
+
indicator: _types3.ServiceIndicator.CALLING,
|
|
259
|
+
domain: ''
|
|
260
|
+
};
|
|
261
|
+
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;
|
|
262
|
+
_Logger.default.setLogger(logLevel, _constants2.CALLING_CLIENT_FILE);
|
|
263
|
+
(0, _Utils.validateServiceData)(serviceData);
|
|
264
|
+
_this.callManager = (0, _callManager.getCallManager)(_this.webex, serviceData.indicator);
|
|
265
|
+
_this.metricManager = (0, _Metrics.getMetricManager)(_this.webex, serviceData.indicator);
|
|
266
|
+
_this.mediaEngine = Media;
|
|
267
|
+
var adaptedLogger = {
|
|
268
|
+
log: function log() {
|
|
269
|
+
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
270
|
+
args[_key] = arguments[_key];
|
|
271
|
+
}
|
|
272
|
+
return webex.logger.log(args.join(' : '));
|
|
273
|
+
},
|
|
274
|
+
error: function error() {
|
|
275
|
+
for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
|
|
276
|
+
args[_key2] = arguments[_key2];
|
|
277
|
+
}
|
|
278
|
+
return webex.logger.error(args.join(' : '));
|
|
279
|
+
},
|
|
280
|
+
warn: function warn() {
|
|
281
|
+
for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
|
|
282
|
+
args[_key3] = arguments[_key3];
|
|
283
|
+
}
|
|
284
|
+
return webex.logger.warn(args.join(' : '));
|
|
285
|
+
},
|
|
286
|
+
info: function info() {
|
|
287
|
+
for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {
|
|
288
|
+
args[_key4] = arguments[_key4];
|
|
289
|
+
}
|
|
290
|
+
return webex.logger.info(args.join(' : '));
|
|
291
|
+
},
|
|
292
|
+
trace: function trace() {
|
|
293
|
+
for (var _len5 = arguments.length, args = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {
|
|
294
|
+
args[_key5] = arguments[_key5];
|
|
295
|
+
}
|
|
296
|
+
return webex.logger.trace(args.join(' : '));
|
|
297
|
+
},
|
|
298
|
+
debug: function debug() {
|
|
299
|
+
for (var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {
|
|
300
|
+
args[_key6] = arguments[_key6];
|
|
301
|
+
}
|
|
302
|
+
return webex.logger.debug(args.join(' : '));
|
|
303
|
+
}
|
|
304
|
+
};
|
|
305
|
+
_this.mediaEngine.setLogger(adaptedLogger);
|
|
306
|
+
_this.primaryMobiusUris = [];
|
|
307
|
+
_this.backupMobiusUris = [];
|
|
308
|
+
_this.mobiusClusters = _this.webex.internal.services.getMobiusClusters();
|
|
309
|
+
_this.mobiusHost = '';
|
|
310
|
+
_this.registerSessionsListener();
|
|
311
|
+
_this.registerCallsClearedListener();
|
|
312
|
+
return _this;
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
/**
|
|
316
|
+
* Initializes the `CallingClient` by performing the following steps:
|
|
317
|
+
*
|
|
318
|
+
* 1. Retrieves list of servers.
|
|
319
|
+
* 2. Creates a line.
|
|
320
|
+
* 3. Sets up network change detection.
|
|
321
|
+
*
|
|
322
|
+
* This method should be called once to initialize the `callingClient`.
|
|
323
|
+
*
|
|
324
|
+
* @returns A promise that resolves when the initialization is complete.
|
|
325
|
+
* @ignore
|
|
326
|
+
*/
|
|
327
|
+
(0, _inherits2.default)(CallingClient, _Eventing);
|
|
328
|
+
return (0, _createClass2.default)(CallingClient, [{
|
|
329
|
+
key: "init",
|
|
330
|
+
value: (function () {
|
|
331
|
+
var _init = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee6() {
|
|
332
|
+
var _window, _window$navigator;
|
|
333
|
+
var ua, _t;
|
|
334
|
+
return _regenerator.default.wrap(function (_context6) {
|
|
335
|
+
while (1) switch (_context6.prev = _context6.next) {
|
|
336
|
+
case 0:
|
|
337
|
+
if (!(typeof window !== 'undefined' && (_window = window) !== null && _window !== void 0 && (_window$navigator = _window.navigator) !== null && _window$navigator !== void 0 && _window$navigator.userAgent)) {
|
|
338
|
+
_context6.next = 4;
|
|
339
|
+
break;
|
|
340
|
+
}
|
|
341
|
+
ua = window.navigator.userAgent;
|
|
342
|
+
if (!ua.toLowerCase().includes('windows')) {
|
|
343
|
+
_context6.next = 4;
|
|
344
|
+
break;
|
|
345
|
+
}
|
|
346
|
+
_Logger.default.info('Starting ICE warmup for Windows Chromium based browser', {
|
|
347
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
348
|
+
method: 'init'
|
|
349
|
+
});
|
|
350
|
+
_context6.prev = 1;
|
|
351
|
+
_context6.next = 2;
|
|
352
|
+
return (0, _windowsChromiumIceWarmupUtils.default)({
|
|
353
|
+
iceServers: [],
|
|
354
|
+
timeoutMs: 1000
|
|
355
|
+
});
|
|
356
|
+
case 2:
|
|
357
|
+
_Logger.default.info("ICE warmup completed", {
|
|
358
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
359
|
+
method: 'init'
|
|
360
|
+
});
|
|
361
|
+
_context6.next = 4;
|
|
362
|
+
break;
|
|
363
|
+
case 3:
|
|
364
|
+
_context6.prev = 3;
|
|
365
|
+
_t = _context6["catch"](1);
|
|
366
|
+
_Logger.default.warn("ICE warmup failed: ".concat(_t), {
|
|
367
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
368
|
+
method: 'init'
|
|
369
|
+
});
|
|
370
|
+
case 4:
|
|
371
|
+
_context6.next = 5;
|
|
372
|
+
return this.getMobiusServers();
|
|
373
|
+
case 5:
|
|
374
|
+
_context6.next = 6;
|
|
375
|
+
return this.createLine();
|
|
376
|
+
case 6:
|
|
377
|
+
this.setupNetworkEventListeners();
|
|
378
|
+
case 7:
|
|
379
|
+
case "end":
|
|
380
|
+
return _context6.stop();
|
|
381
|
+
}
|
|
382
|
+
}, _callee6, this, [[1, 3]]);
|
|
383
|
+
}));
|
|
384
|
+
function init() {
|
|
385
|
+
return _init.apply(this, arguments);
|
|
386
|
+
}
|
|
387
|
+
return init;
|
|
388
|
+
}()
|
|
389
|
+
/**
|
|
390
|
+
* Ping a reliable external endpoint with a short timeout to infer connectivity.
|
|
391
|
+
*/
|
|
392
|
+
)
|
|
393
|
+
}, {
|
|
394
|
+
key: "checkNetworkReachability",
|
|
395
|
+
value: (function () {
|
|
396
|
+
var _checkNetworkReachability = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee7() {
|
|
397
|
+
var controller, timeoutId, _t2;
|
|
398
|
+
return _regenerator.default.wrap(function (_context7) {
|
|
399
|
+
while (1) switch (_context7.prev = _context7.next) {
|
|
400
|
+
case 0:
|
|
401
|
+
_context7.prev = 0;
|
|
402
|
+
controller = new AbortController();
|
|
403
|
+
timeoutId = setTimeout(function () {
|
|
404
|
+
return controller.abort();
|
|
405
|
+
}, 3000); // Using a common connectivity check endpoint that returns 204 with minimal payload.
|
|
406
|
+
// no-cors mode yields an opaque response but a successful fetch implies reachability.
|
|
407
|
+
_context7.next = 1;
|
|
408
|
+
return fetch('https://www.google.com/generate_204', {
|
|
409
|
+
method: 'GET',
|
|
410
|
+
cache: 'no-cache',
|
|
411
|
+
mode: 'no-cors',
|
|
412
|
+
signal: controller.signal
|
|
413
|
+
});
|
|
414
|
+
case 1:
|
|
415
|
+
clearTimeout(timeoutId);
|
|
416
|
+
return _context7.abrupt("return", true);
|
|
417
|
+
case 2:
|
|
418
|
+
_context7.prev = 2;
|
|
419
|
+
_t2 = _context7["catch"](0);
|
|
420
|
+
_Logger.default.warn("Network connectivity probe failed: ".concat(_t2), {
|
|
421
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
422
|
+
method: 'pingExternal'
|
|
423
|
+
});
|
|
424
|
+
return _context7.abrupt("return", false);
|
|
425
|
+
case 3:
|
|
426
|
+
case "end":
|
|
427
|
+
return _context7.stop();
|
|
428
|
+
}
|
|
429
|
+
}, _callee7, null, [[0, 2]]);
|
|
430
|
+
}));
|
|
431
|
+
function checkNetworkReachability() {
|
|
432
|
+
return _checkNetworkReachability.apply(this, arguments);
|
|
433
|
+
}
|
|
434
|
+
return checkNetworkReachability;
|
|
435
|
+
}())
|
|
436
|
+
}, {
|
|
437
|
+
key: "checkCallStatus",
|
|
438
|
+
value: function () {
|
|
439
|
+
var _checkCallStatus = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee8() {
|
|
440
|
+
var loggerContext, calls, _iterator, _step, _loop, _t3;
|
|
441
|
+
return _regenerator.default.wrap(function (_context9) {
|
|
442
|
+
while (1) switch (_context9.prev = _context9.next) {
|
|
443
|
+
case 0:
|
|
444
|
+
loggerContext = {
|
|
445
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
446
|
+
method: 'checkCallStatus'
|
|
447
|
+
};
|
|
448
|
+
calls = (0, _values.default)(this.callManager.getActiveCalls());
|
|
449
|
+
_iterator = _createForOfIteratorHelper(calls);
|
|
450
|
+
_context9.prev = 1;
|
|
451
|
+
_loop = /*#__PURE__*/_regenerator.default.mark(function _loop() {
|
|
452
|
+
var call;
|
|
453
|
+
return _regenerator.default.wrap(function (_context8) {
|
|
454
|
+
while (1) switch (_context8.prev = _context8.next) {
|
|
455
|
+
case 0:
|
|
456
|
+
call = _step.value;
|
|
457
|
+
call.postStatus().then(function () {
|
|
458
|
+
_Logger.default.info("Call is active", loggerContext);
|
|
459
|
+
/*
|
|
460
|
+
* Media Renegotiation Possibility if call keepalive succeeds,
|
|
461
|
+
* for cases like WebRTC disconnect and media inactivity.
|
|
462
|
+
*/
|
|
463
|
+
}).catch(function (err) {
|
|
464
|
+
_Logger.default.warn("Call Keepalive failed: ".concat(err), loggerContext);
|
|
465
|
+
call.sendCallStateMachineEvt({
|
|
466
|
+
type: 'E_SEND_CALL_DISCONNECT'
|
|
467
|
+
});
|
|
468
|
+
});
|
|
469
|
+
case 1:
|
|
470
|
+
case "end":
|
|
471
|
+
return _context8.stop();
|
|
472
|
+
}
|
|
473
|
+
}, _loop);
|
|
474
|
+
});
|
|
475
|
+
_iterator.s();
|
|
476
|
+
case 2:
|
|
477
|
+
if ((_step = _iterator.n()).done) {
|
|
478
|
+
_context9.next = 4;
|
|
479
|
+
break;
|
|
480
|
+
}
|
|
481
|
+
return _context9.delegateYield(_loop(), "t0", 3);
|
|
482
|
+
case 3:
|
|
483
|
+
_context9.next = 2;
|
|
484
|
+
break;
|
|
485
|
+
case 4:
|
|
486
|
+
_context9.next = 6;
|
|
487
|
+
break;
|
|
488
|
+
case 5:
|
|
489
|
+
_context9.prev = 5;
|
|
490
|
+
_t3 = _context9["catch"](1);
|
|
491
|
+
_iterator.e(_t3);
|
|
492
|
+
case 6:
|
|
493
|
+
_context9.prev = 6;
|
|
494
|
+
_iterator.f();
|
|
495
|
+
return _context9.finish(6);
|
|
496
|
+
case 7:
|
|
497
|
+
case "end":
|
|
498
|
+
return _context9.stop();
|
|
499
|
+
}
|
|
500
|
+
}, _callee8, this, [[1, 5, 6, 7]]);
|
|
501
|
+
}));
|
|
502
|
+
function checkCallStatus() {
|
|
503
|
+
return _checkCallStatus.apply(this, arguments);
|
|
504
|
+
}
|
|
505
|
+
return checkCallStatus;
|
|
506
|
+
}()
|
|
507
|
+
}, {
|
|
508
|
+
key: "setupNetworkEventListeners",
|
|
509
|
+
value: function setupNetworkEventListeners() {
|
|
510
|
+
var _this2 = this;
|
|
511
|
+
if (typeof window !== 'undefined' && window.addEventListener) {
|
|
512
|
+
window.addEventListener('online', this.handleNetworkOnline);
|
|
513
|
+
window.addEventListener('offline', this.handleNetworkOffline);
|
|
514
|
+
}
|
|
515
|
+
this.webex.internal.mercury.on('offline', function () {
|
|
516
|
+
_this2.handleMercuryOffline();
|
|
517
|
+
});
|
|
518
|
+
this.webex.internal.mercury.on('online', function () {
|
|
519
|
+
_this2.handleMercuryOnline();
|
|
520
|
+
});
|
|
521
|
+
}
|
|
522
|
+
|
|
523
|
+
/**
|
|
524
|
+
* Fetches countryCode and region of the client.
|
|
525
|
+
*/
|
|
526
|
+
}, {
|
|
527
|
+
key: "getClientRegionInfo",
|
|
528
|
+
value: (function () {
|
|
529
|
+
var _getClientRegionInfo = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee9() {
|
|
530
|
+
var _this3 = this;
|
|
531
|
+
var abort, regionInfo, _response$headers, _response$headers$tra, _response$headers2, response, clientRegionInfo, _t4;
|
|
532
|
+
return _regenerator.default.wrap(function (_context0) {
|
|
533
|
+
while (1) switch (_context0.prev = _context0.next) {
|
|
534
|
+
case 0:
|
|
535
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
536
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
537
|
+
method: _constants2.METHODS.GET_CLIENT_REGION_INFO
|
|
538
|
+
});
|
|
539
|
+
regionInfo = {};
|
|
540
|
+
_context0.prev = 1;
|
|
541
|
+
_context0.next = 2;
|
|
542
|
+
return this.webex.request({
|
|
543
|
+
uri: "".concat(_constants2.DISCOVERY_URL),
|
|
544
|
+
method: _types3.HTTP_METHODS.GET,
|
|
545
|
+
addAuthHeader: false,
|
|
546
|
+
headers: (0, _defineProperty2.default)({}, _constants2.SPARK_USER_AGENT, null)
|
|
547
|
+
});
|
|
548
|
+
case 2:
|
|
549
|
+
response = _context0.sent;
|
|
550
|
+
clientRegionInfo = response.body;
|
|
551
|
+
regionInfo.clientRegion = (clientRegionInfo === null || clientRegionInfo === void 0 ? void 0 : clientRegionInfo.clientRegion) || '';
|
|
552
|
+
regionInfo.countryCode = (clientRegionInfo === null || clientRegionInfo === void 0 ? void 0 : clientRegionInfo.countryCode) || '';
|
|
553
|
+
_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), {
|
|
554
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
555
|
+
method: _constants2.METHODS.GET_CLIENT_REGION_INFO
|
|
556
|
+
});
|
|
557
|
+
this.metricManager.submitRegionInfoMetric(_types4.METRIC_EVENT.MOBIUS_DISCOVERY, _types4.MOBIUS_SERVER_ACTION.REGION_INFO, _types4.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 : '');
|
|
558
|
+
_context0.next = 6;
|
|
559
|
+
break;
|
|
560
|
+
case 3:
|
|
561
|
+
_context0.prev = 3;
|
|
562
|
+
_t4 = _context0["catch"](1);
|
|
563
|
+
_Logger.default.error("Failed to get client region info: ".concat((0, _stringify.default)(_t4)), {
|
|
564
|
+
method: _constants2.METHODS.GET_CLIENT_REGION_INFO,
|
|
565
|
+
file: _constants2.CALLING_CLIENT_FILE
|
|
566
|
+
});
|
|
567
|
+
|
|
568
|
+
// eslint-disable-next-line no-await-in-loop
|
|
569
|
+
_context0.next = 4;
|
|
570
|
+
return (0, _Utils.handleCallingClientErrors)(_t4, function (clientError) {
|
|
571
|
+
var _headers$trackingId, _headers2;
|
|
572
|
+
_this3.metricManager.submitRegistrationMetric(_types4.METRIC_EVENT.REGISTRATION_ERROR, _types4.REG_ACTION.REGISTER, _types4.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);
|
|
573
|
+
_this3.emit(_types2.CALLING_CLIENT_EVENT_KEYS.ERROR, clientError);
|
|
574
|
+
}, {
|
|
575
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL,
|
|
576
|
+
file: _constants2.CALLING_CLIENT_FILE
|
|
577
|
+
});
|
|
578
|
+
case 4:
|
|
579
|
+
abort = _context0.sent;
|
|
580
|
+
regionInfo.clientRegion = '';
|
|
581
|
+
regionInfo.countryCode = '';
|
|
582
|
+
if (!abort) {
|
|
583
|
+
_context0.next = 6;
|
|
584
|
+
break;
|
|
585
|
+
}
|
|
586
|
+
_context0.next = 5;
|
|
587
|
+
return (0, _Utils.uploadLogs)();
|
|
588
|
+
case 5:
|
|
589
|
+
return _context0.abrupt("return", regionInfo);
|
|
590
|
+
case 6:
|
|
591
|
+
return _context0.abrupt("return", regionInfo);
|
|
592
|
+
case 7:
|
|
593
|
+
case "end":
|
|
594
|
+
return _context0.stop();
|
|
595
|
+
}
|
|
596
|
+
}, _callee9, this, [[1, 3]]);
|
|
597
|
+
}));
|
|
598
|
+
function getClientRegionInfo() {
|
|
599
|
+
return _getClientRegionInfo.apply(this, arguments);
|
|
600
|
+
}
|
|
601
|
+
return getClientRegionInfo;
|
|
602
|
+
}()
|
|
603
|
+
/**
|
|
604
|
+
* Local method for finding the mobius servers.
|
|
605
|
+
*/
|
|
606
|
+
)
|
|
607
|
+
}, {
|
|
608
|
+
key: "getMobiusServers",
|
|
609
|
+
value: (function () {
|
|
610
|
+
var _getMobiusServers = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee0() {
|
|
611
|
+
var _this$sdkConfig3,
|
|
612
|
+
_this$sdkConfig3$disc,
|
|
613
|
+
_this$sdkConfig4,
|
|
614
|
+
_this$sdkConfig4$disc,
|
|
615
|
+
_this4 = this;
|
|
616
|
+
var useDefault, clientRegion, countryCode, _this$sdkConfig5, _this$sdkConfig5$disc, _this$sdkConfig6, _this$sdkConfig6$disc, _this$webex$internal$, regionInfo, _iterator2, _step2, _loop2, _ret, _t6;
|
|
617
|
+
return _regenerator.default.wrap(function (_context10) {
|
|
618
|
+
while (1) switch (_context10.prev = _context10.next) {
|
|
619
|
+
case 0:
|
|
620
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
621
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
622
|
+
method: _constants2.METHODS.GET_MOBIUS_SERVERS
|
|
623
|
+
});
|
|
624
|
+
/* Following operations are performed in a synchronous way ->
|
|
625
|
+
1. Get RegionInfo
|
|
626
|
+
2. Get Mobius Server with that RegionInfo
|
|
627
|
+
3. Check whether Mobius server was found without any error
|
|
628
|
+
4. If there is error , we don't need to send registration
|
|
629
|
+
5. Otherwise send registration
|
|
630
|
+
*/
|
|
631
|
+
useDefault = false;
|
|
632
|
+
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)) {
|
|
633
|
+
_context10.next = 1;
|
|
634
|
+
break;
|
|
635
|
+
}
|
|
636
|
+
_Logger.default.log('Updating region and country from the SDK config', {
|
|
637
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
638
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL
|
|
639
|
+
});
|
|
640
|
+
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;
|
|
641
|
+
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;
|
|
642
|
+
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);
|
|
643
|
+
_context10.next = 3;
|
|
644
|
+
break;
|
|
645
|
+
case 1:
|
|
646
|
+
_Logger.default.log('Updating region and country through Region discovery', {
|
|
647
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
648
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL
|
|
649
|
+
});
|
|
650
|
+
_context10.next = 2;
|
|
651
|
+
return this.getClientRegionInfo();
|
|
652
|
+
case 2:
|
|
653
|
+
regionInfo = _context10.sent;
|
|
654
|
+
clientRegion = regionInfo.clientRegion;
|
|
655
|
+
countryCode = regionInfo.countryCode;
|
|
656
|
+
case 3:
|
|
657
|
+
if (!(clientRegion && countryCode)) {
|
|
658
|
+
_context10.next = 12;
|
|
659
|
+
break;
|
|
660
|
+
}
|
|
661
|
+
_Logger.default.log("Found Region: ".concat(clientRegion, " and country: ").concat(countryCode, ", going to fetch Mobius server"), {
|
|
662
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
663
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL
|
|
664
|
+
});
|
|
665
|
+
_iterator2 = _createForOfIteratorHelper(this.mobiusClusters);
|
|
666
|
+
_context10.prev = 4;
|
|
667
|
+
_loop2 = /*#__PURE__*/_regenerator.default.mark(function _loop2() {
|
|
668
|
+
var mobius, _response$headers3, _response$headers$tra2, _response$headers4, response, mobiusServers, mobiusUris, abort, _t5;
|
|
669
|
+
return _regenerator.default.wrap(function (_context1) {
|
|
670
|
+
while (1) switch (_context1.prev = _context1.next) {
|
|
671
|
+
case 0:
|
|
672
|
+
mobius = _step2.value;
|
|
673
|
+
if (mobius.host) {
|
|
674
|
+
_this4.mobiusHost = "https://".concat(mobius.host).concat(_constants2.API_V1);
|
|
675
|
+
} else {
|
|
676
|
+
_this4.mobiusHost = mobius;
|
|
677
|
+
}
|
|
678
|
+
_context1.prev = 1;
|
|
679
|
+
_context1.next = 2;
|
|
680
|
+
return _this4.webex.request({
|
|
681
|
+
uri: "".concat(_this4.mobiusHost).concat(_constants2.URL_ENDPOINT, "?regionCode=").concat(clientRegion, "&countryCode=").concat(countryCode),
|
|
682
|
+
method: _types3.HTTP_METHODS.GET,
|
|
683
|
+
headers: (0, _defineProperty2.default)((0, _defineProperty2.default)({}, _constants2.CISCO_DEVICE_URL, _this4.webex.internal.device.url), _constants2.SPARK_USER_AGENT, _constants2.CALLING_USER_AGENT),
|
|
684
|
+
service: _types3.ALLOWED_SERVICES.MOBIUS
|
|
685
|
+
});
|
|
686
|
+
case 2:
|
|
687
|
+
response = _context1.sent;
|
|
688
|
+
_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), {
|
|
689
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
690
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL
|
|
691
|
+
});
|
|
692
|
+
mobiusServers = response.body; // Metrics for mobius servers
|
|
693
|
+
_this4.metricManager.submitMobiusServersMetric(_types4.METRIC_EVENT.MOBIUS_DISCOVERY, _types4.MOBIUS_SERVER_ACTION.MOBIUS_SERVERS, _types4.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 : '');
|
|
694
|
+
|
|
695
|
+
/* update arrays of Mobius Uris. */
|
|
696
|
+
mobiusUris = (0, _Utils.filterMobiusUris)(mobiusServers, _this4.mobiusHost);
|
|
697
|
+
_this4.primaryMobiusUris = mobiusUris.primary;
|
|
698
|
+
_this4.backupMobiusUris = mobiusUris.backup;
|
|
699
|
+
_Logger.default.log("Final list of Mobius Servers, primary: ".concat(mobiusUris.primary, " and backup: ").concat(mobiusUris.backup), {
|
|
700
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
701
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL
|
|
702
|
+
});
|
|
703
|
+
return _context1.abrupt("return", 0);
|
|
704
|
+
case 3:
|
|
705
|
+
_context1.prev = 3;
|
|
706
|
+
_t5 = _context1["catch"](1);
|
|
707
|
+
_Logger.default.error("Failed to get Mobius servers: ".concat((0, _stringify.default)(_t5)), {
|
|
708
|
+
method: _constants2.METHODS.GET_MOBIUS_SERVERS,
|
|
709
|
+
file: _constants2.CALLING_CLIENT_FILE
|
|
710
|
+
});
|
|
711
|
+
|
|
712
|
+
// eslint-disable-next-line no-await-in-loop
|
|
713
|
+
_context1.next = 4;
|
|
714
|
+
return (0, _Utils.handleCallingClientErrors)(_t5, function (clientError) {
|
|
715
|
+
var _headers$trackingId2, _headers4;
|
|
716
|
+
_this4.metricManager.submitRegistrationMetric(_types4.METRIC_EVENT.REGISTRATION_ERROR, _types4.REG_ACTION.REGISTER, _types4.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);
|
|
717
|
+
_this4.emit(_types2.CALLING_CLIENT_EVENT_KEYS.ERROR, clientError);
|
|
718
|
+
}, {
|
|
719
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL,
|
|
720
|
+
file: _constants2.CALLING_CLIENT_FILE
|
|
721
|
+
});
|
|
722
|
+
case 4:
|
|
723
|
+
abort = _context1.sent;
|
|
724
|
+
if (!abort) {
|
|
725
|
+
_context1.next = 6;
|
|
726
|
+
break;
|
|
727
|
+
}
|
|
728
|
+
useDefault = true;
|
|
729
|
+
// eslint-disable-next-line no-await-in-loop
|
|
730
|
+
_context1.next = 5;
|
|
731
|
+
return (0, _Utils.uploadLogs)();
|
|
732
|
+
case 5:
|
|
733
|
+
return _context1.abrupt("return", 0);
|
|
734
|
+
case 6:
|
|
735
|
+
case "end":
|
|
736
|
+
return _context1.stop();
|
|
737
|
+
}
|
|
738
|
+
}, _loop2, null, [[1, 3]]);
|
|
739
|
+
});
|
|
740
|
+
_iterator2.s();
|
|
741
|
+
case 5:
|
|
742
|
+
if ((_step2 = _iterator2.n()).done) {
|
|
743
|
+
_context10.next = 8;
|
|
744
|
+
break;
|
|
745
|
+
}
|
|
746
|
+
return _context10.delegateYield(_loop2(), "t0", 6);
|
|
747
|
+
case 6:
|
|
748
|
+
_ret = _context10.t0;
|
|
749
|
+
if (!(_ret === 0)) {
|
|
750
|
+
_context10.next = 7;
|
|
751
|
+
break;
|
|
752
|
+
}
|
|
753
|
+
return _context10.abrupt("continue", 8);
|
|
754
|
+
case 7:
|
|
755
|
+
_context10.next = 5;
|
|
756
|
+
break;
|
|
757
|
+
case 8:
|
|
758
|
+
_context10.next = 10;
|
|
759
|
+
break;
|
|
760
|
+
case 9:
|
|
761
|
+
_context10.prev = 9;
|
|
762
|
+
_t6 = _context10["catch"](4);
|
|
763
|
+
_iterator2.e(_t6);
|
|
764
|
+
case 10:
|
|
765
|
+
_context10.prev = 10;
|
|
766
|
+
_iterator2.f();
|
|
767
|
+
return _context10.finish(10);
|
|
768
|
+
case 11:
|
|
769
|
+
_context10.next = 13;
|
|
770
|
+
break;
|
|
771
|
+
case 12:
|
|
772
|
+
/* Setting this to true because region info is possibly undefined */
|
|
773
|
+
useDefault = true;
|
|
774
|
+
case 13:
|
|
775
|
+
/* Use a default URL if Mobius discovery fails either because of region info failure
|
|
776
|
+
* or because the discovered Mobius couldn't be reached
|
|
777
|
+
*/
|
|
778
|
+
|
|
779
|
+
if (useDefault) {
|
|
780
|
+
_Logger.default.warn("Couldn't resolve the region and country code. Defaulting to the catalog entries to discover mobius servers", {
|
|
781
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
782
|
+
method: _constants2.GET_MOBIUS_SERVERS_UTIL
|
|
783
|
+
});
|
|
784
|
+
this.mobiusHost = "https://".concat(this.mobiusClusters[0].host).concat(_constants2.API_V1);
|
|
785
|
+
this.primaryMobiusUris = ["".concat(this.mobiusHost).concat(_constants2.URL_ENDPOINT)];
|
|
786
|
+
}
|
|
787
|
+
case 14:
|
|
788
|
+
case "end":
|
|
789
|
+
return _context10.stop();
|
|
790
|
+
}
|
|
791
|
+
}, _callee0, this, [[4, 9, 10, 11]]);
|
|
792
|
+
}));
|
|
793
|
+
function getMobiusServers() {
|
|
794
|
+
return _getMobiusServers.apply(this, arguments);
|
|
795
|
+
}
|
|
796
|
+
return getMobiusServers;
|
|
797
|
+
}()
|
|
798
|
+
/**
|
|
799
|
+
* Registers a listener/handler for ALL_CALLS_CLEARED
|
|
800
|
+
* event emitted by callManager when all the calls
|
|
801
|
+
* present on sdk are cleaned up.
|
|
802
|
+
*/
|
|
803
|
+
)
|
|
804
|
+
}, {
|
|
805
|
+
key: "registerCallsClearedListener",
|
|
806
|
+
value: function registerCallsClearedListener() {
|
|
807
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
808
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
809
|
+
method: _constants2.METHODS.REGISTER_CALLS_CLEARED_LISTENER
|
|
810
|
+
});
|
|
811
|
+
this.callManager.on(_types2.CALLING_CLIENT_EVENT_KEYS.ALL_CALLS_CLEARED, this.callsClearedHandler);
|
|
812
|
+
}
|
|
813
|
+
}, {
|
|
814
|
+
key: "getLoggingLevel",
|
|
815
|
+
value:
|
|
816
|
+
/**
|
|
817
|
+
* To get the current log Level.
|
|
818
|
+
* @ignore
|
|
819
|
+
*/
|
|
820
|
+
function getLoggingLevel() {
|
|
821
|
+
return _Logger.default.getLogLevel();
|
|
822
|
+
}
|
|
823
|
+
|
|
824
|
+
/**
|
|
825
|
+
* To return the `sdkConnector` instance that was used during sdk initialisation.
|
|
826
|
+
* @ignore
|
|
827
|
+
*/
|
|
828
|
+
}, {
|
|
829
|
+
key: "getSDKConnector",
|
|
830
|
+
value: function getSDKConnector() {
|
|
831
|
+
return this.sdkConnector;
|
|
832
|
+
}
|
|
833
|
+
}, {
|
|
834
|
+
key: "registerSessionsListener",
|
|
835
|
+
value: function registerSessionsListener() {
|
|
836
|
+
var _this5 = this;
|
|
837
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
838
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
839
|
+
method: _constants2.METHODS.REGISTER_SESSIONS_LISTENER
|
|
840
|
+
});
|
|
841
|
+
this.sdkConnector.registerListener(_types2.MOBIUS_EVENT_KEYS.CALL_SESSION_EVENT_INCLUSIVE, /*#__PURE__*/function () {
|
|
842
|
+
var _ref6 = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee1(event) {
|
|
843
|
+
var sessionArr, i;
|
|
844
|
+
return _regenerator.default.wrap(function (_context11) {
|
|
845
|
+
while (1) switch (_context11.prev = _context11.next) {
|
|
846
|
+
case 0:
|
|
847
|
+
if (!(event && event.data.userSessions.userSessions)) {
|
|
848
|
+
_context11.next = 2;
|
|
849
|
+
break;
|
|
850
|
+
}
|
|
851
|
+
sessionArr = event === null || event === void 0 ? void 0 : event.data.userSessions.userSessions;
|
|
852
|
+
if (!(sessionArr.length === 1)) {
|
|
853
|
+
_context11.next = 1;
|
|
854
|
+
break;
|
|
855
|
+
}
|
|
856
|
+
if (!(sessionArr[0].sessionType !== _types2.SessionType.WEBEX_CALLING)) {
|
|
857
|
+
_context11.next = 1;
|
|
858
|
+
break;
|
|
859
|
+
}
|
|
860
|
+
return _context11.abrupt("return");
|
|
861
|
+
case 1:
|
|
862
|
+
for (i = 0; i < sessionArr.length; i += 1) {
|
|
863
|
+
if (sessionArr[i].sessionType !== _types2.SessionType.WEBEX_CALLING) {
|
|
864
|
+
sessionArr.splice(i, 1);
|
|
865
|
+
}
|
|
866
|
+
}
|
|
867
|
+
_this5.emit(_types2.CALLING_CLIENT_EVENT_KEYS.USER_SESSION_INFO, event);
|
|
868
|
+
case 2:
|
|
869
|
+
case "end":
|
|
870
|
+
return _context11.stop();
|
|
871
|
+
}
|
|
872
|
+
}, _callee1);
|
|
873
|
+
}));
|
|
874
|
+
return function (_x) {
|
|
875
|
+
return _ref6.apply(this, arguments);
|
|
876
|
+
};
|
|
877
|
+
}());
|
|
878
|
+
}
|
|
879
|
+
|
|
880
|
+
/**
|
|
881
|
+
* Creates line object inside calling client per user
|
|
882
|
+
* NOTE: currently multiple lines are not supported
|
|
883
|
+
*/
|
|
884
|
+
}, {
|
|
885
|
+
key: "createLine",
|
|
886
|
+
value: (function () {
|
|
887
|
+
var _createLine = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee10() {
|
|
888
|
+
var _this$sdkConfig7, _this$sdkConfig8;
|
|
889
|
+
var line;
|
|
890
|
+
return _regenerator.default.wrap(function (_context12) {
|
|
891
|
+
while (1) switch (_context12.prev = _context12.next) {
|
|
892
|
+
case 0:
|
|
893
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
894
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
895
|
+
method: _constants2.METHODS.CREATE_LINE
|
|
896
|
+
});
|
|
897
|
+
line = new _line.default(this.webex.internal.device.userId, this.webex.internal.device.url, this.mutex, this.primaryMobiusUris, 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);
|
|
898
|
+
this.lineDict[line.lineId] = line;
|
|
899
|
+
case 1:
|
|
900
|
+
case "end":
|
|
901
|
+
return _context12.stop();
|
|
902
|
+
}
|
|
903
|
+
}, _callee10, this);
|
|
904
|
+
}));
|
|
905
|
+
function createLine() {
|
|
906
|
+
return _createLine.apply(this, arguments);
|
|
907
|
+
}
|
|
908
|
+
return createLine;
|
|
909
|
+
}()
|
|
910
|
+
/**
|
|
911
|
+
* Retrieves details of all the Line objects belonging to a User
|
|
912
|
+
* NOTE: currently multiple lines are not supported
|
|
913
|
+
*/
|
|
914
|
+
)
|
|
915
|
+
}, {
|
|
916
|
+
key: "getLines",
|
|
917
|
+
value: function getLines() {
|
|
918
|
+
return this.lineDict;
|
|
919
|
+
}
|
|
920
|
+
|
|
921
|
+
/**
|
|
922
|
+
* Fetches the list of devices for a given user from Mobius.
|
|
923
|
+
*/
|
|
924
|
+
}, {
|
|
925
|
+
key: "getDevices",
|
|
926
|
+
value: (function () {
|
|
927
|
+
var _getDevices = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee11(userId) {
|
|
928
|
+
var userid, mobiusUrls, finalError, _iterator3, _step3, mobiusUrl, normalizedMobiusUrl, uri, _body$devices, response, body, _t7, _t8;
|
|
929
|
+
return _regenerator.default.wrap(function (_context13) {
|
|
930
|
+
while (1) switch (_context13.prev = _context13.next) {
|
|
931
|
+
case 0:
|
|
932
|
+
userid = userId || this.webex.internal.device.userId;
|
|
933
|
+
if (userid) {
|
|
934
|
+
_context13.next = 1;
|
|
935
|
+
break;
|
|
936
|
+
}
|
|
937
|
+
throw new Error('userId is required to fetch devices');
|
|
938
|
+
case 1:
|
|
939
|
+
_Logger.default.info(_constants.METHOD_START_MESSAGE, {
|
|
940
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
941
|
+
method: _constants2.METHODS.GET_DEVICES
|
|
942
|
+
});
|
|
943
|
+
mobiusUrls = [].concat((0, _toConsumableArray2.default)(this.primaryMobiusUris), (0, _toConsumableArray2.default)(this.backupMobiusUris));
|
|
944
|
+
if (!(mobiusUrls.length === 0)) {
|
|
945
|
+
_context13.next = 2;
|
|
946
|
+
break;
|
|
947
|
+
}
|
|
948
|
+
throw new Error('Mobius URLs are not available');
|
|
949
|
+
case 2:
|
|
950
|
+
_iterator3 = _createForOfIteratorHelper(mobiusUrls);
|
|
951
|
+
_context13.prev = 3;
|
|
952
|
+
_iterator3.s();
|
|
953
|
+
case 4:
|
|
954
|
+
if ((_step3 = _iterator3.n()).done) {
|
|
955
|
+
_context13.next = 10;
|
|
956
|
+
break;
|
|
957
|
+
}
|
|
958
|
+
mobiusUrl = _step3.value;
|
|
959
|
+
normalizedMobiusUrl = mobiusUrl.replace(/\/+$/, '/');
|
|
960
|
+
uri = "".concat(normalizedMobiusUrl).concat(_constants2.DEVICES_ENDPOINT_RESOURCE, "?userid=").concat(encodeURIComponent(userid));
|
|
961
|
+
_context13.prev = 5;
|
|
962
|
+
_context13.next = 6;
|
|
963
|
+
return this.webex.request({
|
|
964
|
+
uri: uri,
|
|
965
|
+
method: _types3.HTTP_METHODS.GET,
|
|
966
|
+
service: _types3.ALLOWED_SERVICES.MOBIUS,
|
|
967
|
+
headers: (0, _defineProperty2.default)((0, _defineProperty2.default)({}, _constants2.CISCO_DEVICE_URL, this.webex.internal.device.url), _constants2.SPARK_USER_AGENT, _constants2.CALLING_USER_AGENT)
|
|
968
|
+
});
|
|
969
|
+
case 6:
|
|
970
|
+
response = _context13.sent;
|
|
971
|
+
if (!(response.statusCode !== 200)) {
|
|
972
|
+
_context13.next = 7;
|
|
973
|
+
break;
|
|
974
|
+
}
|
|
975
|
+
throw new Error("API call failed with ".concat(response.statusCode));
|
|
976
|
+
case 7:
|
|
977
|
+
body = response.body; // Hydrate registration deviceInfo for deregister/restore flows
|
|
978
|
+
(0, _values.default)(this.lineDict)[0].registration.setDeviceInfo(body);
|
|
979
|
+
(0, _values.default)(this.lineDict)[0].registration.setActiveMobiusUrl(normalizedMobiusUrl);
|
|
980
|
+
return _context13.abrupt("return", (_body$devices = body.devices) !== null && _body$devices !== void 0 ? _body$devices : []);
|
|
981
|
+
case 8:
|
|
982
|
+
_context13.prev = 8;
|
|
983
|
+
_t7 = _context13["catch"](5);
|
|
984
|
+
finalError = _t7;
|
|
985
|
+
case 9:
|
|
986
|
+
_context13.next = 4;
|
|
987
|
+
break;
|
|
988
|
+
case 10:
|
|
989
|
+
_context13.next = 12;
|
|
990
|
+
break;
|
|
991
|
+
case 11:
|
|
992
|
+
_context13.prev = 11;
|
|
993
|
+
_t8 = _context13["catch"](3);
|
|
994
|
+
_iterator3.e(_t8);
|
|
995
|
+
case 12:
|
|
996
|
+
_context13.prev = 12;
|
|
997
|
+
_iterator3.f();
|
|
998
|
+
return _context13.finish(12);
|
|
999
|
+
case 13:
|
|
1000
|
+
_Logger.default.error("Failed to fetch devices for userId ".concat(userId, ": ").concat((0, _stringify.default)(finalError)), {
|
|
1001
|
+
file: _constants2.CALLING_CLIENT_FILE,
|
|
1002
|
+
method: _constants2.METHODS.GET_DEVICES
|
|
1003
|
+
});
|
|
1004
|
+
throw finalError;
|
|
1005
|
+
case 14:
|
|
1006
|
+
case "end":
|
|
1007
|
+
return _context13.stop();
|
|
1008
|
+
}
|
|
1009
|
+
}, _callee11, this, [[3, 11, 12, 13], [5, 8]]);
|
|
1010
|
+
}));
|
|
1011
|
+
function getDevices(_x2) {
|
|
1012
|
+
return _getDevices.apply(this, arguments);
|
|
1013
|
+
}
|
|
1014
|
+
return getDevices;
|
|
1015
|
+
}()
|
|
1016
|
+
/**
|
|
1017
|
+
* Retrieves call objects for all the active calls present in the client
|
|
1018
|
+
*/
|
|
1019
|
+
)
|
|
1020
|
+
}, {
|
|
1021
|
+
key: "getActiveCalls",
|
|
1022
|
+
value: function getActiveCalls() {
|
|
1023
|
+
var activeCalls = {};
|
|
1024
|
+
var calls = this.callManager.getActiveCalls();
|
|
1025
|
+
(0, _keys.default)(calls).forEach(function (correlationId) {
|
|
1026
|
+
var call = calls[correlationId];
|
|
1027
|
+
if (!activeCalls[call.lineId]) {
|
|
1028
|
+
activeCalls[call.lineId] = [];
|
|
1029
|
+
}
|
|
1030
|
+
activeCalls[call.lineId].push(call);
|
|
1031
|
+
});
|
|
1032
|
+
return activeCalls;
|
|
1033
|
+
}
|
|
1034
|
+
|
|
1035
|
+
/**
|
|
1036
|
+
* Retrieves call object for the connected call in the client
|
|
1037
|
+
*/
|
|
1038
|
+
}, {
|
|
1039
|
+
key: "getConnectedCall",
|
|
1040
|
+
value: function getConnectedCall() {
|
|
1041
|
+
var connectCall;
|
|
1042
|
+
var calls = this.callManager.getActiveCalls();
|
|
1043
|
+
(0, _keys.default)(calls).forEach(function (correlationId) {
|
|
1044
|
+
if (calls[correlationId].isConnected() && !calls[correlationId].isHeld()) {
|
|
1045
|
+
connectCall = calls[correlationId];
|
|
1046
|
+
}
|
|
1047
|
+
});
|
|
1048
|
+
return connectCall;
|
|
1049
|
+
}
|
|
1050
|
+
|
|
1051
|
+
/**
|
|
1052
|
+
* Uploads logs to help troubleshoot SDK issues.
|
|
1053
|
+
*
|
|
1054
|
+
* This method collects the current SDK logs including network requests, WebSocket
|
|
1055
|
+
* messages, and client-side events, then securely submits them to Webex's diagnostics
|
|
1056
|
+
* service. The returned tracking ID, feedbackID can be provided to Webex support for faster
|
|
1057
|
+
* issue resolution.
|
|
1058
|
+
* @returns Promise<UploadLogsResponse>
|
|
1059
|
+
* @throws Error
|
|
1060
|
+
*/
|
|
1061
|
+
}, {
|
|
1062
|
+
key: "uploadLogs",
|
|
1063
|
+
value: (function () {
|
|
1064
|
+
var _uploadLogs2 = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee12() {
|
|
1065
|
+
var result;
|
|
1066
|
+
return _regenerator.default.wrap(function (_context14) {
|
|
1067
|
+
while (1) switch (_context14.prev = _context14.next) {
|
|
1068
|
+
case 0:
|
|
1069
|
+
_context14.next = 1;
|
|
1070
|
+
return (0, _Utils.uploadLogs)({}, true);
|
|
1071
|
+
case 1:
|
|
1072
|
+
result = _context14.sent;
|
|
1073
|
+
if (result) {
|
|
1074
|
+
_context14.next = 2;
|
|
1075
|
+
break;
|
|
1076
|
+
}
|
|
1077
|
+
throw new Error('Failed to upload logs: No response received.');
|
|
1078
|
+
case 2:
|
|
1079
|
+
return _context14.abrupt("return", result);
|
|
1080
|
+
case 3:
|
|
1081
|
+
case "end":
|
|
1082
|
+
return _context14.stop();
|
|
1083
|
+
}
|
|
1084
|
+
}, _callee12);
|
|
1085
|
+
}));
|
|
1086
|
+
function uploadLogs() {
|
|
1087
|
+
return _uploadLogs2.apply(this, arguments);
|
|
1088
|
+
}
|
|
1089
|
+
return uploadLogs;
|
|
1090
|
+
}())
|
|
1091
|
+
}]);
|
|
1092
|
+
}(_impl.Eventing);
|
|
1093
|
+
/**
|
|
1094
|
+
* Create the `CallingClient` instance using the `webex` object and callingSdk `config`
|
|
1095
|
+
* @param webex - A webex instance.
|
|
1096
|
+
* @param config - Config to start the CallingClient with.
|
|
1097
|
+
*/
|
|
1098
|
+
var createClient = exports.createClient = /*#__PURE__*/function () {
|
|
1099
|
+
var _ref7 = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee13(webex, config) {
|
|
1100
|
+
var callingClientInstance;
|
|
1101
|
+
return _regenerator.default.wrap(function (_context15) {
|
|
1102
|
+
while (1) switch (_context15.prev = _context15.next) {
|
|
1103
|
+
case 0:
|
|
1104
|
+
callingClientInstance = new CallingClient(webex, config);
|
|
1105
|
+
_context15.next = 1;
|
|
1106
|
+
return callingClientInstance.init();
|
|
1107
|
+
case 1:
|
|
1108
|
+
return _context15.abrupt("return", callingClientInstance);
|
|
1109
|
+
case 2:
|
|
1110
|
+
case "end":
|
|
1111
|
+
return _context15.stop();
|
|
1112
|
+
}
|
|
1113
|
+
}, _callee13);
|
|
1114
|
+
}));
|
|
1115
|
+
return function createClient(_x3, _x4) {
|
|
1116
|
+
return _ref7.apply(this, arguments);
|
|
1117
|
+
};
|
|
1118
|
+
}();
|
|
1119
|
+
//# sourceMappingURL=CallingClient.js.map
|