@webex/calling 3.8.0-next.32 → 3.8.0-next.34
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/CallHistory/CallHistory.js +100 -63
- package/dist/CallHistory/CallHistory.js.map +1 -1
- package/dist/CallHistory/CallHistory.test.js +115 -19
- package/dist/CallHistory/CallHistory.test.js.map +1 -1
- package/dist/CallHistory/constants.js +9 -1
- package/dist/CallHistory/constants.js.map +1 -1
- package/dist/CallSettings/CallSettings.js +46 -13
- package/dist/CallSettings/CallSettings.js.map +1 -1
- package/dist/CallSettings/UcmBackendConnector.js +62 -18
- package/dist/CallSettings/UcmBackendConnector.js.map +1 -1
- package/dist/CallSettings/UcmBackendConnector.test.js +70 -7
- package/dist/CallSettings/UcmBackendConnector.test.js.map +1 -1
- package/dist/CallSettings/WxCallBackendConnector.js +153 -103
- package/dist/CallSettings/WxCallBackendConnector.js.map +1 -1
- package/dist/CallSettings/WxCallBackendConnector.test.js +52 -15
- package/dist/CallSettings/WxCallBackendConnector.test.js.map +1 -1
- package/dist/CallSettings/constants.js +15 -1
- package/dist/CallSettings/constants.js.map +1 -1
- package/dist/CallingClient/CallingClient.js +148 -107
- package/dist/CallingClient/CallingClient.js.map +1 -1
- package/dist/CallingClient/CallingClient.test.js +53 -24
- package/dist/CallingClient/CallingClient.test.js.map +1 -1
- package/dist/CallingClient/calling/call.js +251 -189
- package/dist/CallingClient/calling/call.js.map +1 -1
- package/dist/CallingClient/calling/call.test.js +96 -41
- package/dist/CallingClient/calling/call.test.js.map +1 -1
- package/dist/CallingClient/calling/callManager.js +73 -48
- package/dist/CallingClient/calling/callManager.js.map +1 -1
- package/dist/CallingClient/calling/callManager.test.js +96 -37
- package/dist/CallingClient/calling/callManager.test.js.map +1 -1
- package/dist/CallingClient/constants.js +101 -1
- package/dist/CallingClient/constants.js.map +1 -1
- package/dist/CallingClient/line/index.js +47 -18
- package/dist/CallingClient/line/index.js.map +1 -1
- package/dist/CallingClient/registration/register.js +151 -115
- package/dist/CallingClient/registration/register.js.map +1 -1
- package/dist/CallingClient/registration/register.test.js +43 -21
- package/dist/CallingClient/registration/register.test.js.map +1 -1
- package/dist/Contacts/ContactsClient.js +156 -102
- package/dist/Contacts/ContactsClient.js.map +1 -1
- package/dist/Contacts/ContactsClient.test.js +197 -49
- package/dist/Contacts/ContactsClient.test.js.map +1 -1
- package/dist/Contacts/constants.js +11 -1
- package/dist/Contacts/constants.js.map +1 -1
- package/dist/Events/impl/index.js +1 -1
- package/dist/Events/impl/index.js.map +1 -1
- package/dist/Metrics/index.js +93 -39
- package/dist/Metrics/index.js.map +1 -1
- package/dist/Metrics/types.js +4 -1
- package/dist/Metrics/types.js.map +1 -1
- package/dist/SDKConnector/types.js.map +1 -1
- package/dist/Voicemail/BroadworksBackendConnector.js +154 -91
- package/dist/Voicemail/BroadworksBackendConnector.js.map +1 -1
- package/dist/Voicemail/BroadworksBackendConnector.test.js +99 -19
- package/dist/Voicemail/BroadworksBackendConnector.test.js.map +1 -1
- package/dist/Voicemail/UcmBackendConnector.js +105 -54
- package/dist/Voicemail/UcmBackendConnector.js.map +1 -1
- package/dist/Voicemail/UcmBackendConnector.test.js +127 -17
- package/dist/Voicemail/UcmBackendConnector.test.js.map +1 -1
- package/dist/Voicemail/Voicemail.js +198 -79
- package/dist/Voicemail/Voicemail.js.map +1 -1
- package/dist/Voicemail/Voicemail.test.js +188 -23
- package/dist/Voicemail/Voicemail.test.js.map +1 -1
- package/dist/Voicemail/WxCallBackendConnector.js +123 -76
- package/dist/Voicemail/WxCallBackendConnector.js.map +1 -1
- package/dist/Voicemail/WxCallBackendConnector.test.js +69 -6
- package/dist/Voicemail/WxCallBackendConnector.test.js.map +1 -1
- package/dist/Voicemail/constants.js +25 -1
- package/dist/Voicemail/constants.js.map +1 -1
- package/dist/common/Utils.js +113 -64
- package/dist/common/Utils.js.map +1 -1
- package/dist/common/Utils.test.js +154 -21
- package/dist/common/Utils.test.js.map +1 -1
- package/dist/common/constants.js +2 -1
- package/dist/common/constants.js.map +1 -1
- package/dist/common/types.js.map +1 -1
- package/dist/module/CallHistory/CallHistory.js +32 -13
- package/dist/module/CallHistory/constants.js +6 -0
- package/dist/module/CallSettings/CallSettings.js +36 -3
- package/dist/module/CallSettings/UcmBackendConnector.js +50 -5
- package/dist/module/CallSettings/WxCallBackendConnector.js +54 -18
- package/dist/module/CallSettings/constants.js +12 -0
- package/dist/module/CallingClient/CallingClient.js +52 -14
- package/dist/module/CallingClient/calling/call.js +172 -121
- package/dist/module/CallingClient/calling/callManager.js +51 -26
- package/dist/module/CallingClient/constants.js +98 -0
- package/dist/module/CallingClient/line/index.js +37 -8
- package/dist/module/CallingClient/registration/register.js +37 -11
- package/dist/module/Contacts/ContactsClient.js +65 -21
- package/dist/module/Contacts/constants.js +10 -0
- package/dist/module/Events/impl/index.js +1 -1
- package/dist/module/Metrics/index.js +49 -1
- package/dist/module/Metrics/types.js +3 -0
- package/dist/module/Voicemail/BroadworksBackendConnector.js +66 -17
- package/dist/module/Voicemail/UcmBackendConnector.js +51 -11
- package/dist/module/Voicemail/Voicemail.js +109 -9
- package/dist/module/Voicemail/WxCallBackendConnector.js +50 -17
- package/dist/module/Voicemail/constants.js +21 -0
- package/dist/module/common/Utils.js +26 -4
- package/dist/module/common/constants.js +1 -0
- package/dist/types/CallHistory/CallHistory.d.ts.map +1 -1
- package/dist/types/CallHistory/constants.d.ts +6 -0
- package/dist/types/CallHistory/constants.d.ts.map +1 -1
- package/dist/types/CallSettings/CallSettings.d.ts.map +1 -1
- package/dist/types/CallSettings/UcmBackendConnector.d.ts.map +1 -1
- package/dist/types/CallSettings/WxCallBackendConnector.d.ts.map +1 -1
- package/dist/types/CallSettings/constants.d.ts +12 -0
- package/dist/types/CallSettings/constants.d.ts.map +1 -1
- package/dist/types/CallingClient/CallingClient.d.ts +2 -3
- package/dist/types/CallingClient/CallingClient.d.ts.map +1 -1
- package/dist/types/CallingClient/calling/call.d.ts.map +1 -1
- package/dist/types/CallingClient/calling/callManager.d.ts.map +1 -1
- package/dist/types/CallingClient/constants.d.ts +98 -0
- package/dist/types/CallingClient/constants.d.ts.map +1 -1
- package/dist/types/CallingClient/line/index.d.ts.map +1 -1
- package/dist/types/CallingClient/registration/register.d.ts.map +1 -1
- package/dist/types/Contacts/ContactsClient.d.ts.map +1 -1
- package/dist/types/Contacts/constants.d.ts +10 -0
- package/dist/types/Contacts/constants.d.ts.map +1 -1
- package/dist/types/Metrics/index.d.ts +1 -1
- package/dist/types/Metrics/index.d.ts.map +1 -1
- package/dist/types/Metrics/types.d.ts +5 -1
- package/dist/types/Metrics/types.d.ts.map +1 -1
- package/dist/types/SDKConnector/types.d.ts +8 -2
- package/dist/types/SDKConnector/types.d.ts.map +1 -1
- package/dist/types/Voicemail/BroadworksBackendConnector.d.ts.map +1 -1
- package/dist/types/Voicemail/UcmBackendConnector.d.ts.map +1 -1
- package/dist/types/Voicemail/Voicemail.d.ts +1 -1
- package/dist/types/Voicemail/Voicemail.d.ts.map +1 -1
- package/dist/types/Voicemail/WxCallBackendConnector.d.ts.map +1 -1
- package/dist/types/Voicemail/constants.d.ts +21 -0
- package/dist/types/Voicemail/constants.d.ts.map +1 -1
- package/dist/types/common/Utils.d.ts +2 -2
- package/dist/types/common/Utils.d.ts.map +1 -1
- package/dist/types/common/constants.d.ts +1 -0
- package/dist/types/common/constants.d.ts.map +1 -1
- package/dist/types/common/types.d.ts +12 -0
- package/dist/types/common/types.d.ts.map +1 -1
- package/package.json +3 -3
package/dist/common/Utils.js
CHANGED
|
@@ -5,9 +5,13 @@ var _Array$from = require("@babel/runtime-corejs2/core-js/array/from");
|
|
|
5
5
|
var _Symbol = require("@babel/runtime-corejs2/core-js/symbol");
|
|
6
6
|
var _Symbol$iterator = require("@babel/runtime-corejs2/core-js/symbol/iterator");
|
|
7
7
|
var _Array$isArray = require("@babel/runtime-corejs2/core-js/array/is-array");
|
|
8
|
-
var
|
|
9
|
-
var _Object$
|
|
8
|
+
var _Object$keys2 = require("@babel/runtime-corejs2/core-js/object/keys");
|
|
9
|
+
var _Object$getOwnPropertySymbols = require("@babel/runtime-corejs2/core-js/object/get-own-property-symbols");
|
|
10
10
|
var _Object$getOwnPropertyDescriptor = require("@babel/runtime-corejs2/core-js/object/get-own-property-descriptor");
|
|
11
|
+
var _Object$getOwnPropertyDescriptors = require("@babel/runtime-corejs2/core-js/object/get-own-property-descriptors");
|
|
12
|
+
var _Object$defineProperties = require("@babel/runtime-corejs2/core-js/object/define-properties");
|
|
13
|
+
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
14
|
+
var _WeakMap = require("@babel/runtime-corejs2/core-js/weak-map");
|
|
11
15
|
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
|
|
12
16
|
_Object$defineProperty(exports, "__esModule", {
|
|
13
17
|
value: true
|
|
@@ -43,9 +47,11 @@ var _parseInt2 = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/
|
|
|
43
47
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
|
|
44
48
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/asyncToGenerator"));
|
|
45
49
|
var platform = _interopRequireWildcard(require("platform"));
|
|
50
|
+
var _types = require("../Metrics/types");
|
|
51
|
+
var _Metrics = require("../Metrics");
|
|
46
52
|
var _CallError = require("../Errors/catalog/CallError");
|
|
47
|
-
var
|
|
48
|
-
var
|
|
53
|
+
var _types2 = require("../Errors/types");
|
|
54
|
+
var _types3 = require("./types");
|
|
49
55
|
var _Logger = _interopRequireDefault(require("../Logger"));
|
|
50
56
|
var _CallingDeviceError = require("../Errors/catalog/CallingDeviceError");
|
|
51
57
|
var _constants = require("../CallingClient/constants");
|
|
@@ -54,6 +60,8 @@ var _SDKConnector = _interopRequireDefault(require("../SDKConnector"));
|
|
|
54
60
|
var _LineError = require("../Errors/catalog/LineError");
|
|
55
61
|
function _getRequireWildcardCache(e) { if ("function" != typeof _WeakMap) return null; var r = new _WeakMap(), t = new _WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
56
62
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = _Object$defineProperty && _Object$getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? _Object$getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? _Object$defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
63
|
+
function ownKeys(e, r) { var t = _Object$keys2(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
64
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
57
65
|
function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof _Symbol !== "undefined" && o[_Symbol$iterator] || o["@@iterator"]; if (!it) { if (_Array$isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, 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 normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
|
|
58
66
|
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return _Array$from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
59
67
|
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } /* eslint-disable no-fallthrough */ /* eslint-disable no-underscore-dangle */ /* eslint-disable @typescript-eslint/no-shadow */
|
|
@@ -189,8 +197,8 @@ function updateErrorContext(errContext, type, message, clientError) {
|
|
|
189
197
|
* @param file - File name from where error got reported.
|
|
190
198
|
*/
|
|
191
199
|
function emitFinalFailure(emitterCb, loggerContext) {
|
|
192
|
-
var clientError = (0, _LineError.createLineError)('', {},
|
|
193
|
-
updateLineErrorContext(loggerContext,
|
|
200
|
+
var clientError = (0, _LineError.createLineError)('', {}, _types2.ERROR_TYPE.DEFAULT, _types3.RegistrationStatus.INACTIVE);
|
|
201
|
+
updateLineErrorContext(loggerContext, _types2.ERROR_TYPE.SERVICE_UNAVAILABLE, 'An unknown error occurred. Wait a moment and try again. Please contact the administrator if the problem persists.', _types3.RegistrationStatus.INACTIVE, clientError);
|
|
194
202
|
emitterCb(clientError);
|
|
195
203
|
}
|
|
196
204
|
|
|
@@ -226,30 +234,30 @@ function _handleRegistrationErrors() {
|
|
|
226
234
|
return _regenerator.default.wrap(function _callee$(_context) {
|
|
227
235
|
while (1) switch (_context.prev = _context.next) {
|
|
228
236
|
case 0:
|
|
229
|
-
lineError = (0, _LineError.createLineError)('', {},
|
|
237
|
+
lineError = (0, _LineError.createLineError)('', {}, _types2.ERROR_TYPE.DEFAULT, _types3.RegistrationStatus.INACTIVE);
|
|
230
238
|
errorCode = Number(err.statusCode);
|
|
231
239
|
finalError = false;
|
|
232
240
|
_Logger.default.warn("Status code: -> ".concat(errorCode), loggerContext);
|
|
233
241
|
_context.t0 = errorCode;
|
|
234
|
-
_context.next = _context.t0 ===
|
|
242
|
+
_context.next = _context.t0 === _types2.ERROR_CODE.BAD_REQUEST ? 7 : _context.t0 === _types2.ERROR_CODE.UNAUTHORIZED ? 12 : _context.t0 === _types2.ERROR_CODE.DEVICE_NOT_FOUND ? 17 : _context.t0 === _types2.ERROR_CODE.TOO_MANY_REQUESTS ? 22 : _context.t0 === _types2.ERROR_CODE.INTERNAL_SERVER_ERROR ? 26 : _context.t0 === _types2.ERROR_CODE.SERVICE_UNAVAILABLE ? 30 : _context.t0 === _types2.ERROR_CODE.FORBIDDEN ? 34 : 69;
|
|
235
243
|
break;
|
|
236
244
|
case 7:
|
|
237
245
|
finalError = true;
|
|
238
246
|
_Logger.default.warn("400 Bad Request", loggerContext);
|
|
239
|
-
updateLineErrorContext(loggerContext,
|
|
247
|
+
updateLineErrorContext(loggerContext, _types2.ERROR_TYPE.SERVER_ERROR, 'Invalid input. Please verify the required parameters, sign out and then sign back in with the valid data', _types3.RegistrationStatus.INACTIVE, lineError);
|
|
240
248
|
emitterCb(lineError, finalError);
|
|
241
249
|
return _context.abrupt("break", 72);
|
|
242
250
|
case 12:
|
|
243
251
|
// Return it to the Caller
|
|
244
252
|
finalError = true;
|
|
245
253
|
_Logger.default.warn("401 Unauthorized", loggerContext);
|
|
246
|
-
updateLineErrorContext(loggerContext,
|
|
254
|
+
updateLineErrorContext(loggerContext, _types2.ERROR_TYPE.TOKEN_ERROR, 'User is unauthorized due to an expired token. Sign out, then sign back in.', _types3.RegistrationStatus.INACTIVE, lineError);
|
|
247
255
|
emitterCb(lineError, finalError);
|
|
248
256
|
return _context.abrupt("break", 72);
|
|
249
257
|
case 17:
|
|
250
258
|
finalError = true;
|
|
251
259
|
_Logger.default.warn("404 Device Not Found", loggerContext);
|
|
252
|
-
updateLineErrorContext(loggerContext,
|
|
260
|
+
updateLineErrorContext(loggerContext, _types2.ERROR_TYPE.NOT_FOUND, 'Webex Calling is unable to find your device. Sign out, then sign back in', _types3.RegistrationStatus.INACTIVE, lineError);
|
|
253
261
|
emitterCb(lineError, finalError);
|
|
254
262
|
return _context.abrupt("break", 72);
|
|
255
263
|
case 22:
|
|
@@ -262,12 +270,12 @@ function _handleRegistrationErrors() {
|
|
|
262
270
|
return _context.abrupt("break", 72);
|
|
263
271
|
case 26:
|
|
264
272
|
_Logger.default.warn("500 Internal Server Error", loggerContext);
|
|
265
|
-
updateLineErrorContext(loggerContext,
|
|
273
|
+
updateLineErrorContext(loggerContext, _types2.ERROR_TYPE.SERVER_ERROR, 'An unknown error occurred while placing the request. Wait a moment and try again.', _types3.RegistrationStatus.INACTIVE, lineError);
|
|
266
274
|
emitterCb(lineError, finalError);
|
|
267
275
|
return _context.abrupt("break", 72);
|
|
268
276
|
case 30:
|
|
269
277
|
_Logger.default.warn("503 Service Unavailable", loggerContext);
|
|
270
|
-
updateLineErrorContext(loggerContext,
|
|
278
|
+
updateLineErrorContext(loggerContext, _types2.ERROR_TYPE.SERVICE_UNAVAILABLE, 'An error occurred on the server while processing the request. Wait a moment and try again.', _types3.RegistrationStatus.INACTIVE, lineError);
|
|
271
279
|
emitterCb(lineError, finalError);
|
|
272
280
|
return _context.abrupt("break", 72);
|
|
273
281
|
case 34:
|
|
@@ -278,14 +286,14 @@ function _handleRegistrationErrors() {
|
|
|
278
286
|
break;
|
|
279
287
|
}
|
|
280
288
|
_Logger.default.warn('Error response has no body, throwing default error', loggerContext);
|
|
281
|
-
updateLineErrorContext(loggerContext,
|
|
289
|
+
updateLineErrorContext(loggerContext, _types2.ERROR_TYPE.FORBIDDEN_ERROR, 'An unauthorized action has been received. This action has been blocked. Please contact the administrator if this persists.', _types3.RegistrationStatus.INACTIVE, lineError);
|
|
282
290
|
emitterCb(lineError, finalError);
|
|
283
291
|
return _context.abrupt("return", finalError);
|
|
284
292
|
case 41:
|
|
285
293
|
code = Number(errorBody.errorCode);
|
|
286
294
|
_Logger.default.warn("Error code found : ".concat(code), loggerContext);
|
|
287
295
|
_context.t1 = code;
|
|
288
|
-
_context.next = _context.t1 ===
|
|
296
|
+
_context.next = _context.t1 === _types2.DEVICE_ERROR_CODE.DEVICE_LIMIT_EXCEEDED ? 46 : _context.t1 === _types2.DEVICE_ERROR_CODE.DEVICE_CREATION_DISABLED ? 53 : _context.t1 === _types2.DEVICE_ERROR_CODE.DEVICE_CREATION_FAILED ? 59 : 64;
|
|
289
297
|
break;
|
|
290
298
|
case 46:
|
|
291
299
|
errorMessage = 'User device limit exceeded';
|
|
@@ -302,25 +310,25 @@ function _handleRegistrationErrors() {
|
|
|
302
310
|
case 53:
|
|
303
311
|
_errorMessage = 'User is not configured for WebRTC calling. Please contact the administrator to resolve this issue.';
|
|
304
312
|
finalError = true;
|
|
305
|
-
updateLineErrorContext(loggerContext,
|
|
313
|
+
updateLineErrorContext(loggerContext, _types2.ERROR_TYPE.FORBIDDEN_ERROR, _errorMessage, _types3.RegistrationStatus.INACTIVE, lineError);
|
|
306
314
|
_Logger.default.warn(_errorMessage, loggerContext);
|
|
307
315
|
emitterCb(lineError, true);
|
|
308
316
|
return _context.abrupt("break", 68);
|
|
309
317
|
case 59:
|
|
310
318
|
_errorMessage2 = 'An unknown error occurred while provisioning the device. Wait a moment and try again.';
|
|
311
|
-
updateLineErrorContext(loggerContext,
|
|
319
|
+
updateLineErrorContext(loggerContext, _types2.ERROR_TYPE.FORBIDDEN_ERROR, _errorMessage2, _types3.RegistrationStatus.INACTIVE, lineError);
|
|
312
320
|
_Logger.default.warn(_errorMessage2, loggerContext);
|
|
313
321
|
emitterCb(lineError, finalError);
|
|
314
322
|
return _context.abrupt("break", 68);
|
|
315
323
|
case 64:
|
|
316
324
|
_errorMessage3 = 'An unknown error occurred. Wait a moment and try again. Please contact the administrator if the problem persists.';
|
|
317
|
-
updateLineErrorContext(loggerContext,
|
|
325
|
+
updateLineErrorContext(loggerContext, _types2.ERROR_TYPE.FORBIDDEN_ERROR, _errorMessage3, _types3.RegistrationStatus.INACTIVE, lineError);
|
|
318
326
|
_Logger.default.warn(_errorMessage3, loggerContext);
|
|
319
327
|
emitterCb(lineError, finalError);
|
|
320
328
|
case 68:
|
|
321
329
|
return _context.abrupt("break", 72);
|
|
322
330
|
case 69:
|
|
323
|
-
updateLineErrorContext(loggerContext,
|
|
331
|
+
updateLineErrorContext(loggerContext, _types2.ERROR_TYPE.DEFAULT, 'Unknown error', _types3.RegistrationStatus.INACTIVE, lineError);
|
|
324
332
|
_Logger.default.warn("Unknown Error", loggerContext);
|
|
325
333
|
emitterCb(lineError, finalError);
|
|
326
334
|
case 72:
|
|
@@ -354,25 +362,28 @@ function _handleCallingClientErrors() {
|
|
|
354
362
|
return _regenerator.default.wrap(function _callee2$(_context2) {
|
|
355
363
|
while (1) switch (_context2.prev = _context2.next) {
|
|
356
364
|
case 0:
|
|
357
|
-
clientError = (0, _CallingDeviceError.createClientError)('', {},
|
|
365
|
+
clientError = (0, _CallingDeviceError.createClientError)('', {}, _types2.ERROR_TYPE.DEFAULT, _types3.RegistrationStatus.INACTIVE);
|
|
358
366
|
errorCode = Number(err.statusCode);
|
|
359
367
|
finalError = false;
|
|
360
368
|
_Logger.default.warn("Status code: -> ".concat(errorCode), loggerContext);
|
|
361
369
|
_context2.t0 = errorCode;
|
|
362
|
-
_context2.next = _context2.t0 ===
|
|
370
|
+
_context2.next = _context2.t0 === _types2.ERROR_CODE.INTERNAL_SERVER_ERROR ? 7 : 11;
|
|
363
371
|
break;
|
|
364
372
|
case 7:
|
|
365
373
|
_Logger.default.warn("500 Internal Server Error", loggerContext);
|
|
366
|
-
updateErrorContext(loggerContext,
|
|
374
|
+
updateErrorContext(loggerContext, _types2.ERROR_TYPE.SERVER_ERROR, 'An unknown error occurred while placing the request. Wait a moment and try again.', clientError);
|
|
367
375
|
emitterCb(clientError, finalError);
|
|
368
376
|
return _context2.abrupt("break", 14);
|
|
369
377
|
case 11:
|
|
370
|
-
updateErrorContext(loggerContext,
|
|
378
|
+
updateErrorContext(loggerContext, _types2.ERROR_TYPE.DEFAULT, 'Unknown error', clientError);
|
|
371
379
|
_Logger.default.warn("Unknown Error", loggerContext);
|
|
372
380
|
emitterCb(clientError, finalError);
|
|
373
381
|
case 14:
|
|
382
|
+
_context2.next = 16;
|
|
383
|
+
return uploadLogs();
|
|
384
|
+
case 16:
|
|
374
385
|
return _context2.abrupt("return", finalError);
|
|
375
|
-
case
|
|
386
|
+
case 17:
|
|
376
387
|
case "end":
|
|
377
388
|
return _context2.stop();
|
|
378
389
|
}
|
|
@@ -401,15 +412,15 @@ function _handleCallErrors() {
|
|
|
401
412
|
file: file,
|
|
402
413
|
method: caller
|
|
403
414
|
};
|
|
404
|
-
callError = (0, _CallError.createCallError)('', loggerContext,
|
|
415
|
+
callError = (0, _CallError.createCallError)('', loggerContext, _types2.ERROR_TYPE.DEFAULT, '', errorLayer);
|
|
405
416
|
errorCode = Number(err.statusCode);
|
|
406
417
|
_Logger.default.warn("Status code: ->".concat(errorCode), loggerContext);
|
|
407
418
|
_context3.t0 = errorCode;
|
|
408
|
-
_context3.next = _context3.t0 ===
|
|
419
|
+
_context3.next = _context3.t0 === _types2.ERROR_CODE.UNAUTHORIZED ? 7 : _context3.t0 === _types2.ERROR_CODE.FORBIDDEN ? 11 : _context3.t0 === _types2.ERROR_CODE.SERVICE_UNAVAILABLE ? 11 : _context3.t0 === _types2.ERROR_CODE.DEVICE_NOT_FOUND ? 48 : _context3.t0 === _types2.ERROR_CODE.INTERNAL_SERVER_ERROR ? 52 : 56;
|
|
409
420
|
break;
|
|
410
421
|
case 7:
|
|
411
422
|
_Logger.default.warn("401 Unauthorized", loggerContext);
|
|
412
|
-
updateCallErrorContext(loggerContext,
|
|
423
|
+
updateCallErrorContext(loggerContext, _types2.ERROR_TYPE.TOKEN_ERROR, 'User is unauthorized due to an expired token. Sign out, then sign back in.', correlationId, callError);
|
|
413
424
|
emitterCb(callError);
|
|
414
425
|
return _context3.abrupt("break", 57);
|
|
415
426
|
case 11:
|
|
@@ -419,7 +430,7 @@ function _handleCallErrors() {
|
|
|
419
430
|
break;
|
|
420
431
|
}
|
|
421
432
|
_Logger.default.warn('Error response has no body, throwing default error', loggerContext);
|
|
422
|
-
updateCallErrorContext(loggerContext, err.statusCode === 403 ?
|
|
433
|
+
updateCallErrorContext(loggerContext, err.statusCode === 403 ? _types2.ERROR_TYPE.FORBIDDEN_ERROR : _types2.ERROR_TYPE.SERVICE_UNAVAILABLE, err.statusCode === 403 ? 'An unauthorized action has been received. This action has been blocked. Please contact the administrator if this persists.' : 'An error occurred on the server while processing the request. Wait a moment and try again.', correlationId, callError);
|
|
423
434
|
emitterCb(callError);
|
|
424
435
|
return _context3.abrupt("return");
|
|
425
436
|
case 17:
|
|
@@ -435,7 +446,7 @@ function _handleCallErrors() {
|
|
|
435
446
|
/* Handling various Error codes */
|
|
436
447
|
code = Number(errorBody.errorCode);
|
|
437
448
|
_context3.t1 = code;
|
|
438
|
-
_context3.next = _context3.t1 ===
|
|
449
|
+
_context3.next = _context3.t1 === _types2.CALL_ERROR_CODE.INVALID_STATUS_UPDATE ? 26 : _context3.t1 === _types2.CALL_ERROR_CODE.DEVICE_NOT_REGISTERED ? 28 : _context3.t1 === _types2.CALL_ERROR_CODE.CALL_NOT_FOUND ? 30 : _context3.t1 === _types2.CALL_ERROR_CODE.ERROR_PROCESSING ? 32 : _context3.t1 === _types2.CALL_ERROR_CODE.USER_BUSY ? 34 : _context3.t1 === _types2.CALL_ERROR_CODE.PARSING_ERROR ? 36 : _context3.t1 === _types2.CALL_ERROR_CODE.NOT_ACCEPTABLE ? 38 : _context3.t1 === _types2.CALL_ERROR_CODE.CALL_REJECTED ? 40 : _context3.t1 === _types2.CALL_ERROR_CODE.NOT_AVAILABLE ? 42 : 44;
|
|
439
450
|
break;
|
|
440
451
|
case 26:
|
|
441
452
|
message = 'An invalid status update has been received for the call. Wait a moment and try again.';
|
|
@@ -469,17 +480,17 @@ function _handleCallErrors() {
|
|
|
469
480
|
case 45:
|
|
470
481
|
/* We just emit the errors to the app */
|
|
471
482
|
|
|
472
|
-
updateCallErrorContext(loggerContext, err.statusCode === 403 ?
|
|
483
|
+
updateCallErrorContext(loggerContext, err.statusCode === 403 ? _types2.ERROR_TYPE.FORBIDDEN_ERROR : _types2.ERROR_TYPE.SERVICE_UNAVAILABLE, message, correlationId, callError);
|
|
473
484
|
emitterCb(callError);
|
|
474
485
|
return _context3.abrupt("break", 57);
|
|
475
486
|
case 48:
|
|
476
487
|
_Logger.default.warn("404 Call Not Found", loggerContext);
|
|
477
|
-
updateCallErrorContext(loggerContext,
|
|
488
|
+
updateCallErrorContext(loggerContext, _types2.ERROR_TYPE.NOT_FOUND, 'Call is no longer active. Wait a moment and try again.', correlationId, callError);
|
|
478
489
|
emitterCb(callError);
|
|
479
490
|
return _context3.abrupt("break", 57);
|
|
480
491
|
case 52:
|
|
481
492
|
_Logger.default.warn("500 Internal Server Error", loggerContext);
|
|
482
|
-
updateCallErrorContext(loggerContext,
|
|
493
|
+
updateCallErrorContext(loggerContext, _types2.ERROR_TYPE.SERVER_ERROR, 'An unknown error occurred in the call. Wait a moment and try again.', correlationId, callError);
|
|
483
494
|
emitterCb(callError);
|
|
484
495
|
return _context3.abrupt("break", 57);
|
|
485
496
|
case 56:
|
|
@@ -508,7 +519,7 @@ function _serviceErrorCodeHandler() {
|
|
|
508
519
|
errorCode = Number(err.statusCode);
|
|
509
520
|
failureMessage = 'FAILURE';
|
|
510
521
|
_context4.t0 = errorCode;
|
|
511
|
-
_context4.next = _context4.t0 ===
|
|
522
|
+
_context4.next = _context4.t0 === _types2.ERROR_CODE.BAD_REQUEST ? 5 : _context4.t0 === _types2.ERROR_CODE.UNAUTHORIZED ? 8 : _context4.t0 === _types2.ERROR_CODE.FORBIDDEN ? 11 : _context4.t0 === _types2.ERROR_CODE.DEVICE_NOT_FOUND ? 14 : _context4.t0 === _types2.ERROR_CODE.REQUEST_TIMEOUT ? 17 : _context4.t0 === _types2.ERROR_CODE.NOT_IMPLEMENTED ? 20 : _context4.t0 === _types2.ERROR_CODE.INTERNAL_SERVER_ERROR ? 23 : _context4.t0 === _types2.ERROR_CODE.SERVICE_UNAVAILABLE ? 26 : 29;
|
|
512
523
|
break;
|
|
513
524
|
case 5:
|
|
514
525
|
_Logger.default.warn("400 Bad request", loggerContext);
|
|
@@ -840,17 +851,17 @@ function getCallingBackEnd(webex) {
|
|
|
840
851
|
if (webex.internal.device.callingBehavior === _constants2.NATIVE_WEBEX_TEAMS_CALLING) {
|
|
841
852
|
for (var i = 0; i < entModels.length; i += 1) {
|
|
842
853
|
if (entModels[i][_constants2.VALUES][_constants2.KEY] === _constants2.ENTITLEMENT_BASIC || entModels[i][_constants2.VALUES][_constants2.KEY] === _constants2.ENTITLEMENT_STANDARD) {
|
|
843
|
-
callingBackend =
|
|
854
|
+
callingBackend = _types3.CALLING_BACKEND.WXC;
|
|
844
855
|
break;
|
|
845
856
|
} else if (entModels[i][_constants2.VALUES][_constants2.KEY] === _constants2.ENTITLEMENT_BROADWORKS_CONN) {
|
|
846
|
-
callingBackend =
|
|
857
|
+
callingBackend = _types3.CALLING_BACKEND.BWRKS;
|
|
847
858
|
break;
|
|
848
859
|
}
|
|
849
860
|
}
|
|
850
861
|
} else if (webex.internal.device.callingBehavior === _constants2.NATIVE_SIP_CALL_TO_UCM) {
|
|
851
|
-
callingBackend =
|
|
862
|
+
callingBackend = _types3.CALLING_BACKEND.UCM;
|
|
852
863
|
} else {
|
|
853
|
-
callingBackend =
|
|
864
|
+
callingBackend = _types3.CALLING_BACKEND.INVALID;
|
|
854
865
|
}
|
|
855
866
|
return callingBackend;
|
|
856
867
|
}
|
|
@@ -881,13 +892,13 @@ function _getXsiActionEndpoint() {
|
|
|
881
892
|
case 0:
|
|
882
893
|
_context5.prev = 0;
|
|
883
894
|
_context5.t0 = callingBackend;
|
|
884
|
-
_context5.next = _context5.t0 ===
|
|
895
|
+
_context5.next = _context5.t0 === _types3.CALLING_BACKEND.WXC ? 4 : _context5.t0 === _types3.CALLING_BACKEND.BWRKS ? 10 : 18;
|
|
885
896
|
break;
|
|
886
897
|
case 4:
|
|
887
898
|
_context5.next = 6;
|
|
888
899
|
return webex.request({
|
|
889
900
|
uri: "".concat(webex.internal.services._serviceUrls.hydra, "/").concat(_constants2.XSI_ACTION_ENDPOINT_ORG_URL_PARAM),
|
|
890
|
-
method:
|
|
901
|
+
method: _types3.HTTP_METHODS.GET
|
|
891
902
|
});
|
|
892
903
|
case 6:
|
|
893
904
|
userIdResponse = _context5.sent;
|
|
@@ -898,7 +909,7 @@ function _getXsiActionEndpoint() {
|
|
|
898
909
|
_context5.next = 12;
|
|
899
910
|
return webex.request({
|
|
900
911
|
uri: "".concat(webex.internal.services._serviceUrls.wdm, "/").concat(_constants2.DEVICES),
|
|
901
|
-
method:
|
|
912
|
+
method: _types3.HTTP_METHODS.GET
|
|
902
913
|
});
|
|
903
914
|
case 12:
|
|
904
915
|
bwTokenResponse = _context5.sent;
|
|
@@ -932,7 +943,7 @@ function _getXsiActionEndpoint() {
|
|
|
932
943
|
}
|
|
933
944
|
function getVgActionEndpoint(webex, callingBackend) {
|
|
934
945
|
try {
|
|
935
|
-
if (callingBackend && callingBackend ===
|
|
946
|
+
if (callingBackend && callingBackend === _types3.CALLING_BACKEND.UCM) {
|
|
936
947
|
return webex.internal.services._serviceUrls['ucmgmt-gateway'];
|
|
937
948
|
}
|
|
938
949
|
throw new Error('Calling backend is not identified, exiting....');
|
|
@@ -951,11 +962,11 @@ function getVgActionEndpoint(webex, callingBackend) {
|
|
|
951
962
|
*/
|
|
952
963
|
function getSortedVoicemailList(voiceMessageList, sortOrder) {
|
|
953
964
|
/* istanbul ignore else */
|
|
954
|
-
if (sortOrder ===
|
|
965
|
+
if (sortOrder === _types3.SORT.DESC) {
|
|
955
966
|
voiceMessageList.sort(function (voiceMail, nextVoiceMail) {
|
|
956
967
|
return nextVoiceMail[_constants2.TIME][_constants2.PLACEHOLDER_KEY] - voiceMail[_constants2.TIME][_constants2.PLACEHOLDER_KEY];
|
|
957
968
|
});
|
|
958
|
-
} else if (sortOrder ===
|
|
969
|
+
} else if (sortOrder === _types3.SORT.ASC) {
|
|
959
970
|
voiceMessageList.sort(function (voiceMail, nextVoiceMail) {
|
|
960
971
|
return voiceMail[_constants2.TIME][_constants2.PLACEHOLDER_KEY] - nextVoiceMail[_constants2.TIME][_constants2.PLACEHOLDER_KEY];
|
|
961
972
|
});
|
|
@@ -995,7 +1006,7 @@ function _scimQuery() {
|
|
|
995
1006
|
query = scimUrl + encodeURIComponent(filter);
|
|
996
1007
|
return _context6.abrupt("return", webex.request({
|
|
997
1008
|
uri: query,
|
|
998
|
-
method:
|
|
1009
|
+
method: _types3.HTTP_METHODS.GET,
|
|
999
1010
|
headers: (0, _defineProperty2.default)((0, _defineProperty2.default)({}, _constants.CISCO_DEVICE_URL, webex.internal.device.url), _constants.SPARK_USER_AGENT, _constants.CALLING_USER_AGENT)
|
|
1000
1011
|
}));
|
|
1001
1012
|
case 8:
|
|
@@ -1235,7 +1246,7 @@ function inferIdFromUuid(id, decodeType) {
|
|
|
1235
1246
|
* @returns True if validation is successful else false.
|
|
1236
1247
|
*/
|
|
1237
1248
|
function isValidServiceIndicator(indicator) {
|
|
1238
|
-
return (0, _values.default)(
|
|
1249
|
+
return (0, _values.default)(_types3.ServiceIndicator).some(function (v) {
|
|
1239
1250
|
return v === indicator;
|
|
1240
1251
|
});
|
|
1241
1252
|
}
|
|
@@ -1256,7 +1267,7 @@ function isValidServiceDomain(serviceData) {
|
|
|
1256
1267
|
var regexp = /^[a-z0-9]+([-.]{1}[a-z0-9]+)*\.[a-z]{2,6}$/i;
|
|
1257
1268
|
var domain = serviceData.domain;
|
|
1258
1269
|
if (!domain) {
|
|
1259
|
-
return serviceData.indicator ===
|
|
1270
|
+
return serviceData.indicator === _types3.ServiceIndicator.CALLING || serviceData.indicator === _types3.ServiceIndicator.GUEST_CALLING;
|
|
1260
1271
|
}
|
|
1261
1272
|
return regexp.test(domain);
|
|
1262
1273
|
}
|
|
@@ -1269,7 +1280,7 @@ function isValidServiceDomain(serviceData) {
|
|
|
1269
1280
|
* @param serviceData - Input service data to be validated.
|
|
1270
1281
|
*/
|
|
1271
1282
|
function validateServiceData(serviceData) {
|
|
1272
|
-
var allowedValues = (0, _values.default)(
|
|
1283
|
+
var allowedValues = (0, _values.default)(_types3.ServiceIndicator);
|
|
1273
1284
|
var formattedValues = allowedValues.join(', ').replace(/,([^,]*)$/, ' and$1');
|
|
1274
1285
|
if (!isValidServiceIndicator(serviceData.indicator)) {
|
|
1275
1286
|
throw new Error("Invalid service indicator, Allowed values are: ".concat(formattedValues));
|
|
@@ -1336,40 +1347,78 @@ function modifySdpForIPv4(sdp) {
|
|
|
1336
1347
|
/**
|
|
1337
1348
|
* Uploads logs to backend.
|
|
1338
1349
|
*
|
|
1339
|
-
* @param
|
|
1340
|
-
* @param
|
|
1350
|
+
* @param metaData - Metadata to be uploaded.
|
|
1351
|
+
* @param throwError - Whether to throw exception on failure (default: false).
|
|
1352
|
+
* @returns Promise containing upload response if successful.
|
|
1341
1353
|
*/
|
|
1342
1354
|
function uploadLogs() {
|
|
1343
1355
|
return _uploadLogs.apply(this, arguments);
|
|
1344
1356
|
}
|
|
1345
1357
|
function _uploadLogs() {
|
|
1346
1358
|
_uploadLogs = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee10() {
|
|
1347
|
-
var
|
|
1348
|
-
|
|
1359
|
+
var metaData,
|
|
1360
|
+
throwError,
|
|
1361
|
+
webex,
|
|
1362
|
+
feedbackId,
|
|
1363
|
+
response,
|
|
1364
|
+
errorLog,
|
|
1349
1365
|
_args10 = arguments;
|
|
1350
1366
|
return _regenerator.default.wrap(function _callee10$(_context10) {
|
|
1351
1367
|
while (1) switch (_context10.prev = _context10.next) {
|
|
1352
1368
|
case 0:
|
|
1353
|
-
|
|
1354
|
-
|
|
1355
|
-
|
|
1356
|
-
|
|
1357
|
-
|
|
1358
|
-
|
|
1359
|
-
|
|
1360
|
-
|
|
1369
|
+
metaData = _args10.length > 0 && _args10[0] !== undefined ? _args10[0] : {};
|
|
1370
|
+
throwError = _args10.length > 1 && _args10[1] !== undefined ? _args10[1] : false;
|
|
1371
|
+
webex = _SDKConnector.default.getWebex();
|
|
1372
|
+
feedbackId = crypto.randomUUID();
|
|
1373
|
+
_context10.prev = 4;
|
|
1374
|
+
_context10.next = 7;
|
|
1375
|
+
return webex.internal.support.submitLogs(_objectSpread(_objectSpread({}, metaData), {}, {
|
|
1376
|
+
feedbackId: feedbackId
|
|
1377
|
+
}), undefined,
|
|
1378
|
+
// we dont send logs but take from webex logger
|
|
1379
|
+
{
|
|
1380
|
+
type: 'diff'
|
|
1381
|
+
} // this is to take the diff logs from previous upload
|
|
1382
|
+
);
|
|
1361
1383
|
case 7:
|
|
1362
|
-
|
|
1363
|
-
|
|
1364
|
-
_Logger.default.error(_context10.t0, {
|
|
1384
|
+
response = _context10.sent;
|
|
1385
|
+
_Logger.default.info("Logs uploaded successfully with feedbackId: ".concat(feedbackId), {
|
|
1365
1386
|
file: _constants.UTILS_FILE,
|
|
1366
1387
|
method: 'uploadLogs'
|
|
1367
1388
|
});
|
|
1368
|
-
|
|
1389
|
+
(0, _Metrics.getMetricManager)().submitUploadLogsMetric(_types.METRIC_EVENT.UPLOAD_LOGS_SUCCESS, _types.UPLOAD_LOGS_ACTION, _types.METRIC_TYPE.BEHAVIORAL, response === null || response === void 0 ? void 0 : response.trackingid, feedbackId, metaData === null || metaData === void 0 ? void 0 : metaData.correlationId);
|
|
1390
|
+
return _context10.abrupt("return", _objectSpread(_objectSpread(_objectSpread(_objectSpread({
|
|
1391
|
+
trackingid: response.trackingid
|
|
1392
|
+
}, response.url ? {
|
|
1393
|
+
url: response.url
|
|
1394
|
+
} : {}), response.userId ? {
|
|
1395
|
+
userId: response.userId
|
|
1396
|
+
} : {}), response.correlationId ? {
|
|
1397
|
+
correlationId: response.correlationId
|
|
1398
|
+
} : {}), {}, {
|
|
1399
|
+
feedbackId: feedbackId
|
|
1400
|
+
}));
|
|
1401
|
+
case 13:
|
|
1402
|
+
_context10.prev = 13;
|
|
1403
|
+
_context10.t0 = _context10["catch"](4);
|
|
1404
|
+
errorLog = new Error("Failed to upload Logs ".concat(_context10.t0));
|
|
1405
|
+
_Logger.default.error(errorLog, {
|
|
1406
|
+
file: _constants.UTILS_FILE,
|
|
1407
|
+
method: 'uploadLogs'
|
|
1408
|
+
});
|
|
1409
|
+
(0, _Metrics.getMetricManager)().submitUploadLogsMetric(_types.METRIC_EVENT.UPLOAD_LOGS_FAILED, _types.UPLOAD_LOGS_ACTION, _types.METRIC_TYPE.BEHAVIORAL, feedbackId, metaData === null || metaData === void 0 ? void 0 : metaData.correlationId, errorLog.message);
|
|
1410
|
+
if (!throwError) {
|
|
1411
|
+
_context10.next = 20;
|
|
1412
|
+
break;
|
|
1413
|
+
}
|
|
1414
|
+
throw _context10.t0;
|
|
1415
|
+
case 20:
|
|
1416
|
+
return _context10.abrupt("return", undefined);
|
|
1417
|
+
case 21:
|
|
1369
1418
|
case "end":
|
|
1370
1419
|
return _context10.stop();
|
|
1371
1420
|
}
|
|
1372
|
-
}, _callee10, null, [[
|
|
1421
|
+
}, _callee10, null, [[4, 13]]);
|
|
1373
1422
|
}));
|
|
1374
1423
|
return _uploadLogs.apply(this, arguments);
|
|
1375
1424
|
}
|