@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.
Files changed (188) hide show
  1. package/dist/CallHistory/CallHistory.js +596 -0
  2. package/dist/CallHistory/CallHistory.js.map +1 -0
  3. package/dist/CallHistory/CallHistory.test.js +916 -0
  4. package/dist/CallHistory/CallHistory.test.js.map +1 -0
  5. package/dist/CallHistory/callHistoryFixtures.js +650 -0
  6. package/dist/CallHistory/callHistoryFixtures.js.map +1 -0
  7. package/dist/CallHistory/constants.js +38 -0
  8. package/dist/CallHistory/constants.js.map +1 -0
  9. package/dist/CallHistory/types.js +7 -0
  10. package/dist/CallHistory/types.js.map +1 -0
  11. package/dist/CallSettings/CallSettings.js +311 -0
  12. package/dist/CallSettings/CallSettings.js.map +1 -0
  13. package/dist/CallSettings/CallSettings.test.js +122 -0
  14. package/dist/CallSettings/CallSettings.test.js.map +1 -0
  15. package/dist/CallSettings/UcmBackendConnector.js +308 -0
  16. package/dist/CallSettings/UcmBackendConnector.js.map +1 -0
  17. package/dist/CallSettings/UcmBackendConnector.test.js +411 -0
  18. package/dist/CallSettings/UcmBackendConnector.test.js.map +1 -0
  19. package/dist/CallSettings/WxCallBackendConnector.js +597 -0
  20. package/dist/CallSettings/WxCallBackendConnector.js.map +1 -0
  21. package/dist/CallSettings/WxCallBackendConnector.test.js +904 -0
  22. package/dist/CallSettings/WxCallBackendConnector.test.js.map +1 -0
  23. package/dist/CallSettings/constants.js +31 -0
  24. package/dist/CallSettings/constants.js.map +1 -0
  25. package/dist/CallSettings/testFixtures.js +68 -0
  26. package/dist/CallSettings/testFixtures.js.map +1 -0
  27. package/dist/CallSettings/types.js +7 -0
  28. package/dist/CallSettings/types.js.map +1 -0
  29. package/dist/CallingClient/CallingClient.js +1119 -0
  30. package/dist/CallingClient/CallingClient.js.map +1 -0
  31. package/dist/CallingClient/CallingClient.test.js +1266 -0
  32. package/dist/CallingClient/CallingClient.test.js.map +1 -0
  33. package/dist/CallingClient/callRecordFixtures.js +101 -0
  34. package/dist/CallingClient/callRecordFixtures.js.map +1 -0
  35. package/dist/CallingClient/calling/CallerId/index.js +275 -0
  36. package/dist/CallingClient/calling/CallerId/index.js.map +1 -0
  37. package/dist/CallingClient/calling/CallerId/index.test.js +275 -0
  38. package/dist/CallingClient/calling/CallerId/index.test.js.map +1 -0
  39. package/dist/CallingClient/calling/CallerId/types.js +7 -0
  40. package/dist/CallingClient/calling/CallerId/types.js.map +1 -0
  41. package/dist/CallingClient/calling/call.js +3486 -0
  42. package/dist/CallingClient/calling/call.js.map +1 -0
  43. package/dist/CallingClient/calling/call.test.js +3612 -0
  44. package/dist/CallingClient/calling/call.test.js.map +1 -0
  45. package/dist/CallingClient/calling/callManager.js +460 -0
  46. package/dist/CallingClient/calling/callManager.js.map +1 -0
  47. package/dist/CallingClient/calling/callManager.test.js +741 -0
  48. package/dist/CallingClient/calling/callManager.test.js.map +1 -0
  49. package/dist/CallingClient/calling/index.js +30 -0
  50. package/dist/CallingClient/calling/index.js.map +1 -0
  51. package/dist/CallingClient/calling/types.js +74 -0
  52. package/dist/CallingClient/calling/types.js.map +1 -0
  53. package/dist/CallingClient/callingClientFixtures.js +143 -0
  54. package/dist/CallingClient/callingClientFixtures.js.map +1 -0
  55. package/dist/CallingClient/constants.js +243 -0
  56. package/dist/CallingClient/constants.js.map +1 -0
  57. package/dist/CallingClient/line/index.js +332 -0
  58. package/dist/CallingClient/line/index.js.map +1 -0
  59. package/dist/CallingClient/line/line.test.js +327 -0
  60. package/dist/CallingClient/line/line.test.js.map +1 -0
  61. package/dist/CallingClient/line/types.js +21 -0
  62. package/dist/CallingClient/line/types.js.map +1 -0
  63. package/dist/CallingClient/registration/index.js +19 -0
  64. package/dist/CallingClient/registration/index.js.map +1 -0
  65. package/dist/CallingClient/registration/register.js +1686 -0
  66. package/dist/CallingClient/registration/register.js.map +1 -0
  67. package/dist/CallingClient/registration/register.test.js +1885 -0
  68. package/dist/CallingClient/registration/register.test.js.map +1 -0
  69. package/dist/CallingClient/registration/registerFixtures.js +36 -0
  70. package/dist/CallingClient/registration/registerFixtures.js.map +1 -0
  71. package/dist/CallingClient/registration/types.js +7 -0
  72. package/dist/CallingClient/registration/types.js.map +1 -0
  73. package/dist/CallingClient/registration/webWorker.js +130 -0
  74. package/dist/CallingClient/registration/webWorker.js.map +1 -0
  75. package/dist/CallingClient/registration/webWorker.test.js +303 -0
  76. package/dist/CallingClient/registration/webWorker.test.js.map +1 -0
  77. package/dist/CallingClient/registration/webWorkerStr.js +15 -0
  78. package/dist/CallingClient/registration/webWorkerStr.js.map +1 -0
  79. package/dist/CallingClient/types.js +7 -0
  80. package/dist/CallingClient/types.js.map +1 -0
  81. package/dist/CallingClient/windowsChromiumIceWarmupUtils.js +142 -0
  82. package/dist/CallingClient/windowsChromiumIceWarmupUtils.js.map +1 -0
  83. package/dist/Contacts/ContactsClient.js +1206 -0
  84. package/dist/Contacts/ContactsClient.js.map +1 -0
  85. package/dist/Contacts/ContactsClient.test.js +1004 -0
  86. package/dist/Contacts/ContactsClient.test.js.map +1 -0
  87. package/dist/Contacts/constants.js +40 -0
  88. package/dist/Contacts/constants.js.map +1 -0
  89. package/dist/Contacts/contactFixtures.js +430 -0
  90. package/dist/Contacts/contactFixtures.js.map +1 -0
  91. package/dist/Contacts/types.js +43 -0
  92. package/dist/Contacts/types.js.map +1 -0
  93. package/dist/Errors/catalog/CallError.js +89 -0
  94. package/dist/Errors/catalog/CallError.js.map +1 -0
  95. package/dist/Errors/catalog/CallingDeviceError.js +83 -0
  96. package/dist/Errors/catalog/CallingDeviceError.js.map +1 -0
  97. package/dist/Errors/catalog/ExtendedError.js +42 -0
  98. package/dist/Errors/catalog/ExtendedError.js.map +1 -0
  99. package/dist/Errors/catalog/LineError.js +85 -0
  100. package/dist/Errors/catalog/LineError.js.map +1 -0
  101. package/dist/Errors/index.js +28 -0
  102. package/dist/Errors/index.js.map +1 -0
  103. package/dist/Errors/types.js +59 -0
  104. package/dist/Errors/types.js.map +1 -0
  105. package/dist/Events/impl/index.js +79 -0
  106. package/dist/Events/impl/index.js.map +1 -0
  107. package/dist/Events/types.js +107 -0
  108. package/dist/Events/types.js.map +1 -0
  109. package/dist/Logger/index.js +228 -0
  110. package/dist/Logger/index.js.map +1 -0
  111. package/dist/Logger/index.test.js +87 -0
  112. package/dist/Logger/index.test.js.map +1 -0
  113. package/dist/Logger/types.js +34 -0
  114. package/dist/Logger/types.js.map +1 -0
  115. package/dist/Metrics/index.js +534 -0
  116. package/dist/Metrics/index.js.map +1 -0
  117. package/dist/Metrics/index.test.js +463 -0
  118. package/dist/Metrics/index.test.js.map +1 -0
  119. package/dist/Metrics/types.js +64 -0
  120. package/dist/Metrics/types.js.map +1 -0
  121. package/dist/SDKConnector/index.js +102 -0
  122. package/dist/SDKConnector/index.js.map +1 -0
  123. package/dist/SDKConnector/index.test.js +9 -0
  124. package/dist/SDKConnector/index.test.js.map +1 -0
  125. package/dist/SDKConnector/types.js +7 -0
  126. package/dist/SDKConnector/types.js.map +1 -0
  127. package/dist/SDKConnector/utils.js +39 -0
  128. package/dist/SDKConnector/utils.js.map +1 -0
  129. package/dist/SDKConnector/utils.test.js +9 -0
  130. package/dist/SDKConnector/utils.test.js.map +1 -0
  131. package/dist/Voicemail/BroadworksBackendConnector.js +699 -0
  132. package/dist/Voicemail/BroadworksBackendConnector.js.map +1 -0
  133. package/dist/Voicemail/BroadworksBackendConnector.test.js +820 -0
  134. package/dist/Voicemail/BroadworksBackendConnector.test.js.map +1 -0
  135. package/dist/Voicemail/UcmBackendConnector.js +628 -0
  136. package/dist/Voicemail/UcmBackendConnector.js.map +1 -0
  137. package/dist/Voicemail/UcmBackendConnector.test.js +738 -0
  138. package/dist/Voicemail/UcmBackendConnector.test.js.map +1 -0
  139. package/dist/Voicemail/Voicemail.js +472 -0
  140. package/dist/Voicemail/Voicemail.js.map +1 -0
  141. package/dist/Voicemail/Voicemail.test.js +391 -0
  142. package/dist/Voicemail/Voicemail.test.js.map +1 -0
  143. package/dist/Voicemail/WxCallBackendConnector.js +657 -0
  144. package/dist/Voicemail/WxCallBackendConnector.js.map +1 -0
  145. package/dist/Voicemail/WxCallBackendConnector.test.js +1225 -0
  146. package/dist/Voicemail/WxCallBackendConnector.test.js.map +1 -0
  147. package/dist/Voicemail/constants.js +61 -0
  148. package/dist/Voicemail/constants.js.map +1 -0
  149. package/dist/Voicemail/types.js +7 -0
  150. package/dist/Voicemail/types.js.map +1 -0
  151. package/dist/Voicemail/voicemailFixture.js +524 -0
  152. package/dist/Voicemail/voicemailFixture.js.map +1 -0
  153. package/dist/api.js +157 -0
  154. package/dist/api.js.map +1 -0
  155. package/dist/common/Utils.js +1483 -0
  156. package/dist/common/Utils.js.map +1 -0
  157. package/dist/common/Utils.test.js +1989 -0
  158. package/dist/common/Utils.test.js.map +1 -0
  159. package/dist/common/constants.js +62 -0
  160. package/dist/common/constants.js.map +1 -0
  161. package/dist/common/index.js +19 -0
  162. package/dist/common/index.js.map +1 -0
  163. package/dist/common/testUtil.js +983 -0
  164. package/dist/common/testUtil.js.map +1 -0
  165. package/dist/common/types.js +75 -0
  166. package/dist/common/types.js.map +1 -0
  167. package/dist/index.js +321 -0
  168. package/dist/index.js.map +1 -0
  169. package/dist/module/CallHistory/CallHistory.js +28 -17
  170. package/dist/module/CallingClient/CallingClient.js +43 -1
  171. package/dist/module/CallingClient/calling/call.js +3 -2
  172. package/dist/module/CallingClient/constants.js +2 -0
  173. package/dist/module/CallingClient/registration/register.js +8 -0
  174. package/dist/types/CallHistory/CallHistory.d.ts.map +1 -1
  175. package/dist/types/CallingClient/CallingClient.d.ts +2 -1
  176. package/dist/types/CallingClient/CallingClient.d.ts.map +1 -1
  177. package/dist/types/CallingClient/calling/call.d.ts.map +1 -1
  178. package/dist/types/CallingClient/constants.d.ts +2 -0
  179. package/dist/types/CallingClient/constants.d.ts.map +1 -1
  180. package/dist/types/CallingClient/registration/register.d.ts +2 -1
  181. package/dist/types/CallingClient/registration/register.d.ts.map +1 -1
  182. package/dist/types/CallingClient/registration/types.d.ts +2 -1
  183. package/dist/types/CallingClient/registration/types.d.ts.map +1 -1
  184. package/dist/types/CallingClient/types.d.ts +2 -1
  185. package/dist/types/CallingClient/types.d.ts.map +1 -1
  186. package/dist/types/common/types.d.ts +4 -0
  187. package/dist/types/common/types.d.ts.map +1 -1
  188. 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