@webex/calling 3.11.0 → 3.12.0-mobius-socket.1

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