@webex/calling 3.12.0-mobius-socket.11 → 3.12.0-mobius-socket.12
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/CallingClient/line/line.test.js +1 -1
- package/dist/CallingClient/line/line.test.js.map +1 -1
- package/dist/CallingClient/registration/register.js +76 -43
- package/dist/CallingClient/registration/register.js.map +1 -1
- package/dist/CallingClient/registration/types.js.map +1 -1
- package/dist/common/Utils.js +70 -30
- package/dist/common/Utils.js.map +1 -1
- package/dist/module/CallingClient/registration/register.js +30 -7
- package/dist/module/common/Utils.js +17 -4
- package/dist/types/CallingClient/registration/register.d.ts.map +1 -1
- package/dist/types/CallingClient/registration/types.d.ts +1 -1
- package/dist/types/CallingClient/registration/types.d.ts.map +1 -1
- package/dist/types/common/Utils.d.ts +4 -1
- package/dist/types/common/Utils.d.ts.map +1 -1
- package/package.json +2 -1
|
@@ -180,6 +180,16 @@ export class Registration {
|
|
|
180
180
|
}
|
|
181
181
|
async restorePreviousRegistration(caller) {
|
|
182
182
|
let abort = false;
|
|
183
|
+
if (this.apiRequest.isSocketEnabled()) {
|
|
184
|
+
log.info(`Disconnecting from Mobius socket to restore previous registration.`, {
|
|
185
|
+
file: REGISTRATION_FILE,
|
|
186
|
+
method: 'restorePreviousRegistration',
|
|
187
|
+
});
|
|
188
|
+
await this.apiRequest.disconnectFromMobiusSocket({
|
|
189
|
+
code: 3050,
|
|
190
|
+
reason: 'done (permanent)',
|
|
191
|
+
});
|
|
192
|
+
}
|
|
183
193
|
if (this.activeMobiusUrl) {
|
|
184
194
|
abort = await this.attemptRegistrationWithServers(caller, [this.activeMobiusUrl]);
|
|
185
195
|
if (this.retryAfter) {
|
|
@@ -193,7 +203,7 @@ export class Registration {
|
|
|
193
203
|
abort = await this.attemptRegistrationWithServers(caller, this.backupMobiusUris);
|
|
194
204
|
}
|
|
195
205
|
else {
|
|
196
|
-
this.restartRegistration(caller);
|
|
206
|
+
await this.restartRegistration(caller);
|
|
197
207
|
}
|
|
198
208
|
this.retryAfter = undefined;
|
|
199
209
|
return true;
|
|
@@ -287,6 +297,13 @@ export class Registration {
|
|
|
287
297
|
log.log(`Scheduled retry with primary in ${interval} seconds, number of attempts : ${attempt}`, loggerContext);
|
|
288
298
|
}
|
|
289
299
|
else if (this.backupMobiusUris.length) {
|
|
300
|
+
if (this.apiRequest.isSocketEnabled()) {
|
|
301
|
+
log.info('Disconnecting from primary Mobius socket for failover to backup servers', loggerContext);
|
|
302
|
+
await this.apiRequest.disconnectFromMobiusSocket({
|
|
303
|
+
code: 3050,
|
|
304
|
+
reason: 'done (permanent)',
|
|
305
|
+
});
|
|
306
|
+
}
|
|
290
307
|
this.saveFailoverState({
|
|
291
308
|
attempt,
|
|
292
309
|
timeElapsed,
|
|
@@ -587,18 +604,17 @@ export class Registration {
|
|
|
587
604
|
break;
|
|
588
605
|
}
|
|
589
606
|
catch (err) {
|
|
590
|
-
connectedWebSocketUrl = undefined;
|
|
591
|
-
await this.apiRequest.disconnectFromMobiusSocket({ code: 3050, reason: 'done (permanent)' });
|
|
592
607
|
const body = err;
|
|
593
|
-
|
|
594
|
-
if (
|
|
608
|
+
const { finalError, shouldDisconnect } = await handleRegistrationErrors(body, (clientError, isFinalError) => {
|
|
609
|
+
if (isFinalError) {
|
|
595
610
|
this.lineEmitter(LINE_EVENTS.ERROR, undefined, clientError);
|
|
596
611
|
}
|
|
597
612
|
else {
|
|
598
613
|
this.lineEmitter(LINE_EVENTS.UNREGISTERED);
|
|
599
614
|
}
|
|
600
615
|
this.metricManager.submitRegistrationMetric(METRIC_EVENT.REGISTRATION_ERROR, REG_ACTION.REGISTER, METRIC_TYPE.BEHAVIORAL, caller, serverType, body.headers?.trackingid ?? '', undefined, clientError);
|
|
601
|
-
}, { method: caller, file: REGISTRATION_FILE }, (retryAfter, retryCaller) => this.handle429Retry(retryAfter, retryCaller), this.restoreRegistrationCallBack());
|
|
616
|
+
}, { method: caller, file: REGISTRATION_FILE }, (retryAfter, retryCaller) => this.handle429Retry(retryAfter, retryCaller), this.restoreRegistrationCallBack(), servers.length);
|
|
617
|
+
abort = finalError;
|
|
602
618
|
if (this.registrationStatus === RegistrationStatus.ACTIVE) {
|
|
603
619
|
log.info(`[${caller}] : Device is already restored, active mobius url: ${this.activeMobiusUrl}`, {
|
|
604
620
|
file: REGISTRATION_FILE,
|
|
@@ -606,6 +622,13 @@ export class Registration {
|
|
|
606
622
|
});
|
|
607
623
|
break;
|
|
608
624
|
}
|
|
625
|
+
if (shouldDisconnect && this.apiRequest.isSocketEnabled()) {
|
|
626
|
+
connectedWebSocketUrl = undefined;
|
|
627
|
+
await this.apiRequest.disconnectFromMobiusSocket({
|
|
628
|
+
code: 3050,
|
|
629
|
+
reason: 'done (permanent)',
|
|
630
|
+
});
|
|
631
|
+
}
|
|
609
632
|
if (abort) {
|
|
610
633
|
this.setStatus(RegistrationStatus.INACTIVE);
|
|
611
634
|
await uploadLogs();
|
|
@@ -666,7 +689,7 @@ export class Registration {
|
|
|
666
689
|
if (event.data.type === WorkerMessageType.KEEPALIVE_FAILURE) {
|
|
667
690
|
const error = event.data.err;
|
|
668
691
|
log.warn(`Keep-alive missed ${event.data.keepAliveRetryCount} times. Status -> ${error.statusCode} `, logContext);
|
|
669
|
-
const abort = await handleRegistrationErrors(error, (clientError, finalError) => {
|
|
692
|
+
const { finalError: abort } = await handleRegistrationErrors(error, (clientError, finalError) => {
|
|
670
693
|
if (finalError) {
|
|
671
694
|
this.lineEmitter(LINE_EVENTS.ERROR, undefined, clientError);
|
|
672
695
|
}
|
|
@@ -106,7 +106,8 @@ export function emitFinalFailure(emitterCb, loggerContext, message) {
|
|
|
106
106
|
'An unknown error occurred. Wait a moment and try again. Please contact the administrator if the problem persists.', RegistrationStatus.INACTIVE, clientError);
|
|
107
107
|
emitterCb(clientError);
|
|
108
108
|
}
|
|
109
|
-
export async function handleRegistrationErrors(err, emitterCb, loggerContext, retry429Cb, restoreRegCb) {
|
|
109
|
+
export async function handleRegistrationErrors(err, emitterCb, loggerContext, retry429Cb, restoreRegCb, serverCount = 1) {
|
|
110
|
+
let shouldDisconnect = false;
|
|
110
111
|
const lineError = createLineError('', {}, ERROR_TYPE.DEFAULT, RegistrationStatus.INACTIVE);
|
|
111
112
|
const errorCode = Number(err.statusCode);
|
|
112
113
|
let finalError = false;
|
|
@@ -117,6 +118,7 @@ export async function handleRegistrationErrors(err, emitterCb, loggerContext, re
|
|
|
117
118
|
log.warn(`400 Bad Request`, loggerContext);
|
|
118
119
|
updateLineErrorContext(loggerContext, ERROR_TYPE.BAD_REQUEST, 'Invalid input. Please verify the required parameters, sign out and then sign back in with the valid data', RegistrationStatus.INACTIVE, lineError);
|
|
119
120
|
emitterCb(lineError, finalError);
|
|
121
|
+
shouldDisconnect = serverCount > 1;
|
|
120
122
|
break;
|
|
121
123
|
}
|
|
122
124
|
case ERROR_CODE.UNAUTHORIZED: {
|
|
@@ -124,6 +126,7 @@ export async function handleRegistrationErrors(err, emitterCb, loggerContext, re
|
|
|
124
126
|
log.warn(`401 Unauthorized`, loggerContext);
|
|
125
127
|
updateLineErrorContext(loggerContext, ERROR_TYPE.TOKEN_ERROR, 'User is unauthorized due to an expired token. Sign out, then sign back in.', RegistrationStatus.INACTIVE, lineError);
|
|
126
128
|
emitterCb(lineError, finalError);
|
|
129
|
+
shouldDisconnect = serverCount > 1;
|
|
127
130
|
break;
|
|
128
131
|
}
|
|
129
132
|
case ERROR_CODE.DEVICE_NOT_FOUND: {
|
|
@@ -131,6 +134,7 @@ export async function handleRegistrationErrors(err, emitterCb, loggerContext, re
|
|
|
131
134
|
log.warn(`404 Device Not Found`, loggerContext);
|
|
132
135
|
updateLineErrorContext(loggerContext, ERROR_TYPE.NOT_FOUND, 'Webex Calling is unable to find your device. Sign out, then sign back in', RegistrationStatus.INACTIVE, lineError);
|
|
133
136
|
emitterCb(lineError, finalError);
|
|
137
|
+
shouldDisconnect = serverCount > 1;
|
|
134
138
|
break;
|
|
135
139
|
}
|
|
136
140
|
case ERROR_CODE.TOO_MANY_REQUESTS: {
|
|
@@ -139,20 +143,23 @@ export async function handleRegistrationErrors(err, emitterCb, loggerContext, re
|
|
|
139
143
|
const caller = loggerContext.method || 'handleErrors';
|
|
140
144
|
if (retry429Cb && err.headers) {
|
|
141
145
|
const retryAfter = Number(err.headers['retry-after']);
|
|
142
|
-
retry429Cb(retryAfter, caller);
|
|
146
|
+
await retry429Cb(retryAfter, caller);
|
|
143
147
|
}
|
|
148
|
+
shouldDisconnect = false;
|
|
144
149
|
break;
|
|
145
150
|
}
|
|
146
151
|
case ERROR_CODE.INTERNAL_SERVER_ERROR: {
|
|
147
152
|
log.warn(`500 Internal Server Error`, loggerContext);
|
|
148
153
|
updateLineErrorContext(loggerContext, ERROR_TYPE.SERVER_ERROR, 'An unknown error occurred while placing the request. Wait a moment and try again.', RegistrationStatus.INACTIVE, lineError);
|
|
149
154
|
emitterCb(lineError, finalError);
|
|
155
|
+
shouldDisconnect = serverCount > 1;
|
|
150
156
|
break;
|
|
151
157
|
}
|
|
152
158
|
case ERROR_CODE.SERVICE_UNAVAILABLE: {
|
|
153
159
|
log.warn(`503 Service Unavailable`, loggerContext);
|
|
154
160
|
updateLineErrorContext(loggerContext, ERROR_TYPE.SERVICE_UNAVAILABLE, 'An error occurred on the server while processing the request. Wait a moment and try again.', RegistrationStatus.INACTIVE, lineError);
|
|
155
161
|
emitterCb(lineError, finalError);
|
|
162
|
+
shouldDisconnect = serverCount > 1;
|
|
156
163
|
break;
|
|
157
164
|
}
|
|
158
165
|
case ERROR_CODE.FORBIDDEN: {
|
|
@@ -162,7 +169,8 @@ export async function handleRegistrationErrors(err, emitterCb, loggerContext, re
|
|
|
162
169
|
log.warn('Error response has no body, throwing default error', loggerContext);
|
|
163
170
|
updateLineErrorContext(loggerContext, ERROR_TYPE.FORBIDDEN_ERROR, 'An unauthorized action has been received. This action has been blocked. Please contact the administrator if this persists.', RegistrationStatus.INACTIVE, lineError);
|
|
164
171
|
emitterCb(lineError, finalError);
|
|
165
|
-
|
|
172
|
+
shouldDisconnect = serverCount > 1;
|
|
173
|
+
return { finalError, shouldDisconnect };
|
|
166
174
|
}
|
|
167
175
|
const code = Number(errorBody.errorCode);
|
|
168
176
|
log.warn(`Error code found : ${code}`, loggerContext);
|
|
@@ -174,6 +182,7 @@ export async function handleRegistrationErrors(err, emitterCb, loggerContext, re
|
|
|
174
182
|
const caller = loggerContext.method || 'handleErrors';
|
|
175
183
|
await restoreRegCb(errorBody, caller);
|
|
176
184
|
}
|
|
185
|
+
shouldDisconnect = false;
|
|
177
186
|
break;
|
|
178
187
|
}
|
|
179
188
|
case DEVICE_ERROR_CODE.DEVICE_CREATION_DISABLED: {
|
|
@@ -182,6 +191,7 @@ export async function handleRegistrationErrors(err, emitterCb, loggerContext, re
|
|
|
182
191
|
updateLineErrorContext(loggerContext, ERROR_TYPE.FORBIDDEN_ERROR, errorMessage, RegistrationStatus.INACTIVE, lineError);
|
|
183
192
|
log.warn(errorMessage, loggerContext);
|
|
184
193
|
emitterCb(lineError, true);
|
|
194
|
+
shouldDisconnect = true;
|
|
185
195
|
break;
|
|
186
196
|
}
|
|
187
197
|
case DEVICE_ERROR_CODE.DEVICE_CREATION_FAILED: {
|
|
@@ -189,6 +199,7 @@ export async function handleRegistrationErrors(err, emitterCb, loggerContext, re
|
|
|
189
199
|
updateLineErrorContext(loggerContext, ERROR_TYPE.FORBIDDEN_ERROR, errorMessage, RegistrationStatus.INACTIVE, lineError);
|
|
190
200
|
log.warn(errorMessage, loggerContext);
|
|
191
201
|
emitterCb(lineError, finalError);
|
|
202
|
+
shouldDisconnect = serverCount > 1;
|
|
192
203
|
break;
|
|
193
204
|
}
|
|
194
205
|
default: {
|
|
@@ -196,6 +207,7 @@ export async function handleRegistrationErrors(err, emitterCb, loggerContext, re
|
|
|
196
207
|
updateLineErrorContext(loggerContext, ERROR_TYPE.FORBIDDEN_ERROR, errorMessage, RegistrationStatus.INACTIVE, lineError);
|
|
197
208
|
log.warn(errorMessage, loggerContext);
|
|
198
209
|
emitterCb(lineError, finalError);
|
|
210
|
+
shouldDisconnect = serverCount > 1;
|
|
199
211
|
}
|
|
200
212
|
}
|
|
201
213
|
break;
|
|
@@ -204,9 +216,10 @@ export async function handleRegistrationErrors(err, emitterCb, loggerContext, re
|
|
|
204
216
|
updateLineErrorContext(loggerContext, ERROR_TYPE.DEFAULT, 'Unknown error', RegistrationStatus.INACTIVE, lineError);
|
|
205
217
|
log.warn(`Unknown Error`, loggerContext);
|
|
206
218
|
emitterCb(lineError, finalError);
|
|
219
|
+
shouldDisconnect = serverCount > 1;
|
|
207
220
|
}
|
|
208
221
|
}
|
|
209
|
-
return finalError;
|
|
222
|
+
return { finalError, shouldDisconnect };
|
|
210
223
|
}
|
|
211
224
|
export async function handleCallingClientErrors(err, emitterCb, loggerContext) {
|
|
212
225
|
const clientError = createClientError('', {}, ERROR_TYPE.DEFAULT, RegistrationStatus.INACTIVE);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"register.d.ts","sourceRoot":"","sources":["../../../../src/CallingClient/registration/register.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,KAAK,EAAC,MAAM,aAAa,CAAC;AAelC,OAAO,EAAC,MAAM,EAAC,MAAM,oBAAoB,CAAC;AAE1C,OAAO,EAAqB,aAAa,EAAC,MAAM,SAAS,CAAC;AAE1D,OAAO,EAEL,OAAO,EAEP,WAAW,EACX,kBAAkB,EAClB,WAAW,EAIZ,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAgB,QAAQ,EAAC,MAAM,0BAA0B,CAAC;AA6BjE,OAAO,EAAc,mBAAmB,EAAC,MAAM,eAAe,CAAC;AAO/D,qBAAa,YAAa,YAAW,aAAa;IAChD,OAAO,CAAC,YAAY,CAAgB;IAEpC,OAAO,CAAC,KAAK,CAAW;IAExB,OAAO,CAAC,MAAM,CAAM;IAEpB,OAAO,CAAC,WAAW,CAAc;IAEjC,OAAO,CAAC,wBAAwB,CAAS;IACzC,OAAO,CAAC,kBAAkB,CAAqB;IAC/C,OAAO,CAAC,aAAa,CAAC,CAAiB;IACvC,OAAO,CAAC,eAAe,CAAU;IAEjC,OAAO,CAAC,mBAAmB,CAAS;IACpC,OAAO,CAAC,mBAAmB,CAAS;IACpC,OAAO,CAAC,KAAK,CAAQ;IACrB,OAAO,CAAC,aAAa,CAAiB;IACtC,OAAO,CAAC,WAAW,CAAsB;IACzC,OAAO,CAAC,WAAW,CAAe;IAClC,OAAO,CAAC,UAAU,CAAmB;IACrC,OAAO,CAAC,iBAAiB,CAAW;IACpC,OAAO,CAAC,gBAAgB,CAAW;IACnC,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,gBAAgB,CAAS;IACjC,OAAO,CAAC,GAAG,CAAC,CAAS;IACrB,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,mBAAmB,CAAS;IACpC,OAAO,CAAC,UAAU,CAAqB;IACvC,OAAO,CAAC,iBAAiB,CAAS;IAClC,OAAO,CAAC,SAAS,CAAqB;IACtC,OAAO,CAAC,UAAU,CAAa;gBAK7B,KAAK,EAAE,QAAQ,EACf,WAAW,EAAE,WAAW,EACxB,KAAK,EAAE,KAAK,EACZ,WAAW,EAAE,mBAAmB,EAChC,QAAQ,EAAE,MAAM,EAChB,GAAG,CAAC,EAAE,MAAM;IA2Bd,OAAO,CAAC,mBAAmB;IAI3B,OAAO,CAAC,iBAAiB;IAWzB,OAAO,CAAC,kBAAkB;YAWZ,cAAc;IA0BrB,kBAAkB,IAAI,MAAM;IAI5B,kBAAkB,CAAC,GAAG,EAAE,MAAM;IAY9B,aAAa,CAAC,WAAW,EAAE,OAAO,GAAG,IAAI;IAUzC,gBAAgB,CAAC,iBAAiB,EAAE,MAAM,EAAE,EAAE,gBAAgB,EAAE,MAAM,EAAE;YAUjE,kBAAkB;YAyClB,gBAAgB;YAuBhB,2BAA2B;
|
|
1
|
+
{"version":3,"file":"register.d.ts","sourceRoot":"","sources":["../../../../src/CallingClient/registration/register.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,7 +3,7 @@ export type Header = {
|
|
|
3
3
|
[key: string]: string;
|
|
4
4
|
};
|
|
5
5
|
export type restoreRegistrationCallBack = (restoreData: IDeviceInfo, caller: string) => Promise<boolean>;
|
|
6
|
-
export type retry429CallBack = (retryAfter: number, caller: string) => void
|
|
6
|
+
export type retry429CallBack = (retryAfter: number, caller: string) => Promise<void>;
|
|
7
7
|
export type FailoverCacheState = {
|
|
8
8
|
attempt: number;
|
|
9
9
|
timeElapsed: number;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/CallingClient/registration/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAC,MAAM,oBAAoB,CAAC;AAE5E,MAAM,MAAM,MAAM,GAAG;IACnB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,2BAA2B,GAAG,CACxC,WAAW,EAAE,WAAW,EACxB,MAAM,EAAE,MAAM,KACX,OAAO,CAAC,OAAO,CAAC,CAAC;AAEtB,MAAM,MAAM,gBAAgB,GAAG,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/CallingClient/registration/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAC,MAAM,oBAAoB,CAAC;AAE5E,MAAM,MAAM,MAAM,GAAG;IACnB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,2BAA2B,GAAG,CACxC,WAAW,EAAE,WAAW,EACxB,MAAM,EAAE,MAAM,KACX,OAAO,CAAC,OAAO,CAAC,CAAC;AAEtB,MAAM,MAAM,gBAAgB,GAAG,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;AAErF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,UAAU,EAAE,SAAS,GAAG,QAAQ,CAAC;CAClC,CAAC;AAKF,MAAM,WAAW,aAAa;IAO5B,gBAAgB,CAAC,iBAAiB,EAAE,MAAM,EAAE,EAAE,gBAAgB,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;IAMhF,mBAAmB,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAMrC,kBAAkB,IAAI,OAAO,CAAC;IAO9B,SAAS,CAAC,KAAK,EAAE,kBAAkB,GAAG,IAAI,CAAC;IAM3C,SAAS,IAAI,kBAAkB,CAAC;IAMhC,aAAa,IAAI,WAAW,CAAC;IAK7B,mBAAmB,IAAI,IAAI,CAAC;IAK5B,UAAU,IAAI,IAAI,CAAC;IAOnB,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAC;IAMtC,kBAAkB,IAAI,MAAM,CAAC;IAO7B,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMlD,kBAAkB,IAAI,OAAO,CAAC;IAQ9B,2BAA2B,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAK9D,aAAa,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI,CAAC;CACpC"}
|
|
@@ -17,7 +17,10 @@ export declare function filterMobiusUris(mobiusServers: MobiusServers, defaultMo
|
|
|
17
17
|
backupWss: string[];
|
|
18
18
|
};
|
|
19
19
|
export declare function emitFinalFailure(emitterCb: LineErrorEmitterCallback, loggerContext: LogContext, message?: string): void;
|
|
20
|
-
export declare function handleRegistrationErrors(err: WebexRequestPayload, emitterCb: LineErrorEmitterCallback, loggerContext: LogContext, retry429Cb?: retry429CallBack, restoreRegCb?: restoreRegistrationCallBack): Promise<
|
|
20
|
+
export declare function handleRegistrationErrors(err: WebexRequestPayload, emitterCb: LineErrorEmitterCallback, loggerContext: LogContext, retry429Cb?: retry429CallBack, restoreRegCb?: restoreRegistrationCallBack, serverCount?: number): Promise<{
|
|
21
|
+
finalError: boolean;
|
|
22
|
+
shouldDisconnect: boolean;
|
|
23
|
+
}>;
|
|
21
24
|
export declare function handleCallingClientErrors(err: WebexRequestPayload, emitterCb: CallingClientErrorEmitterCallback, loggerContext: LogContext): Promise<boolean>;
|
|
22
25
|
export declare function handleCallErrors(emitterCb: CallErrorEmitterCallBack, errorLayer: ERROR_LAYER, retryCb: RetryCallBack, correlationId: CorrelationId, err: WebexRequestPayload, caller: string, file: string): Promise<boolean>;
|
|
23
26
|
export declare function serviceErrorCodeHandler(err: WebexRequestPayload, loggerContext: LogContext): Promise<JanusResponseEvent | VoicemailResponseEvent | CallSettingResponse | ContactResponse | UpdateMissedCallsResponse | UCMLinesResponse | DeleteCallHistoryRecordsResponse>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Utils.d.ts","sourceRoot":"","sources":["../../../src/common/Utils.ts"],"names":[],"mappings":"AAOA,OAAO,EAAC,2BAA2B,EAAE,gBAAgB,EAAC,MAAM,qCAAqC,CAAC;AAClG,OAAO,EAAC,iCAAiC,EAAC,MAAM,wBAAwB,CAAC;AACzE,OAAO,EAAC,UAAU,EAAC,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EACL,wBAAwB,EACxB,YAAY,EAEZ,aAAa,EAId,MAAM,gCAAgC,CAAC;AAExC,OAAO,EAQL,WAAW,EAEZ,MAAM,iBAAiB,CAAC;AACzB,OAAO,EACL,eAAe,EACf,aAAa,EACb,UAAU,EACV,kBAAkB,EAGlB,YAAY,EACZ,aAAa,EAGb,IAAI,EACJ,WAAW,EAEX,kBAAkB,EAClB,mBAAmB,EACpB,MAAM,SAAS,CAAC;AA+CjB,OAAO,EACL,gCAAgC,EAChC,kBAAkB,EAClB,gBAAgB,EAChB,yBAAyB,EAC1B,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EACL,sBAAsB,EACtB,WAAW,EACX,gBAAgB,EAChB,iBAAiB,EAClB,MAAM,oBAAoB,CAAC;AA0B5B,OAAO,EAAQ,QAAQ,EAAC,MAAM,uBAAuB,CAAC;AAEtD,OAAO,EAAC,mBAAmB,EAAC,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAC,eAAe,EAAC,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAC,wBAAwB,EAAC,MAAM,6BAA6B,CAAC;AAGrE,wBAAgB,gBAAgB,CAAC,aAAa,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM;;;;;EAoFtF;AAkFD,wBAAgB,gBAAgB,CAC9B,SAAS,EAAE,wBAAwB,EACnC,aAAa,EAAE,UAAU,EACzB,OAAO,CAAC,EAAE,MAAM,QAkBjB;AAkBD,wBAAsB,wBAAwB,CAC5C,GAAG,EAAE,mBAAmB,EACxB,SAAS,EAAE,wBAAwB,EACnC,aAAa,EAAE,UAAU,EACzB,UAAU,CAAC,EAAE,gBAAgB,EAC7B,YAAY,CAAC,EAAE,2BAA2B,
|
|
1
|
+
{"version":3,"file":"Utils.d.ts","sourceRoot":"","sources":["../../../src/common/Utils.ts"],"names":[],"mappings":"AAOA,OAAO,EAAC,2BAA2B,EAAE,gBAAgB,EAAC,MAAM,qCAAqC,CAAC;AAClG,OAAO,EAAC,iCAAiC,EAAC,MAAM,wBAAwB,CAAC;AACzE,OAAO,EAAC,UAAU,EAAC,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EACL,wBAAwB,EACxB,YAAY,EAEZ,aAAa,EAId,MAAM,gCAAgC,CAAC;AAExC,OAAO,EAQL,WAAW,EAEZ,MAAM,iBAAiB,CAAC;AACzB,OAAO,EACL,eAAe,EACf,aAAa,EACb,UAAU,EACV,kBAAkB,EAGlB,YAAY,EACZ,aAAa,EAGb,IAAI,EACJ,WAAW,EAEX,kBAAkB,EAClB,mBAAmB,EACpB,MAAM,SAAS,CAAC;AA+CjB,OAAO,EACL,gCAAgC,EAChC,kBAAkB,EAClB,gBAAgB,EAChB,yBAAyB,EAC1B,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EACL,sBAAsB,EACtB,WAAW,EACX,gBAAgB,EAChB,iBAAiB,EAClB,MAAM,oBAAoB,CAAC;AA0B5B,OAAO,EAAQ,QAAQ,EAAC,MAAM,uBAAuB,CAAC;AAEtD,OAAO,EAAC,mBAAmB,EAAC,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAC,eAAe,EAAC,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAC,wBAAwB,EAAC,MAAM,6BAA6B,CAAC;AAGrE,wBAAgB,gBAAgB,CAAC,aAAa,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM;;;;;EAoFtF;AAkFD,wBAAgB,gBAAgB,CAC9B,SAAS,EAAE,wBAAwB,EACnC,aAAa,EAAE,UAAU,EACzB,OAAO,CAAC,EAAE,MAAM,QAkBjB;AAkBD,wBAAsB,wBAAwB,CAC5C,GAAG,EAAE,mBAAmB,EACxB,SAAS,EAAE,wBAAwB,EACnC,aAAa,EAAE,UAAU,EACzB,UAAU,CAAC,EAAE,gBAAgB,EAC7B,YAAY,CAAC,EAAE,2BAA2B,EAC1C,WAAW,SAAI,GACd,OAAO,CAAC;IAAC,UAAU,EAAE,OAAO,CAAC;IAAC,gBAAgB,EAAE,OAAO,CAAA;CAAC,CAAC,CA6M3D;AASD,wBAAsB,yBAAyB,CAC7C,GAAG,EAAE,mBAAmB,EACxB,SAAS,EAAE,iCAAiC,EAC5C,aAAa,EAAE,UAAU,GACxB,OAAO,CAAC,OAAO,CAAC,CA2ClB;AAgBD,wBAAsB,gBAAgB,CACpC,SAAS,EAAE,wBAAwB,EACnC,UAAU,EAAE,WAAW,EACvB,OAAO,EAAE,aAAa,EACtB,aAAa,EAAE,aAAa,EAC5B,GAAG,EAAE,mBAAmB,EACxB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,GACX,OAAO,CAAC,OAAO,CAAC,CAuNlB;AAUD,wBAAsB,uBAAuB,CAC3C,GAAG,EAAE,mBAAmB,EACxB,aAAa,EAAE,UAAU,GACxB,OAAO,CACN,kBAAkB,GAClB,sBAAsB,GACtB,mBAAmB,GACnB,eAAe,GACf,yBAAyB,GACzB,gBAAgB,GAChB,gCAAgC,CACnC,CA+HA;AAMD,wBAAgB,2BAA2B,CAAC,KAAK,EAAE,cAAc,GAAG,YAAY,CAwM/E;AAQD,eAAO,MAAM,YAAY,SAAU,MAAM,qBAGrC,CAAC;AAQL,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,QAAQ,GAAG,eAAe,CAwBlE;AAUD,wBAAsB,oBAAoB,CACxC,KAAK,EAAE,QAAQ,EACf,aAAa,EAAE,UAAU,EACzB,cAAc,EAAE,eAAe,gBAkEhC;AASD,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAE,eAAe,WAWnF;AASD,wBAAgB,sBAAsB,CACpC,gBAAgB,EAAE,WAAW,EAAE,EAC/B,SAAS,EAAE,IAAI,GACd,WAAW,EAAE,CAef;AAQD,wBAAsB,SAAS,CAAC,MAAM,EAAE,MAAM,gCAgC7C;AAOD,wBAAsB,sBAAsB,CAAC,MAAM,EAAE,MAAM,+BAuD1D;AAOD,wBAAsB,qBAAqB,CAAC,IAAI,EAAE,MAAM,+BAgDvD;AAOD,wBAAsB,cAAc,CAClC,gBAAgB,EAAE,gBAAgB,GACjC,OAAO,CAAC,kBAAkB,GAAG,IAAI,CAAC,CAWpC;AAQD,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,MAAM,EAAE,gBAAgB,EAAE,WAAW,EAAE,QAIlF;AAWD,wBAAgB,kBAAkB,CAChC,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,MAAM,EACnB,aAAa,EAAE,UAAU,GACxB,iBAAiB,CAwBnB;AASD,wBAAgB,eAAe,CAAC,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,GAAG,MAAM,CAE1E;AA6CD,wBAAgB,mBAAmB,CAAC,WAAW,EAAE,WAAW,QAW3D;AAQD,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAoEpD;AASD,wBAAsB,UAAU,CAC9B,QAAQ,GAAE,YAAiB,EAC3B,UAAU,UAAQ,GACjB,OAAO,CAAC,kBAAkB,GAAG,SAAS,CAAC,CA8DzC;AAED,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAE5D"}
|
package/package.json
CHANGED
|
@@ -77,6 +77,7 @@
|
|
|
77
77
|
"@typescript-eslint/eslint-plugin": "5.38.1",
|
|
78
78
|
"@typescript-eslint/parser": "5.38.1",
|
|
79
79
|
"@web/dev-server": "0.4.5",
|
|
80
|
+
"@webex/test-helper-chai": "3.12.0-mobius-socket.1",
|
|
80
81
|
"@webex/test-helper-mock-web-socket": "3.12.0-mobius-socket.1",
|
|
81
82
|
"@webex/test-helper-mock-webex": "3.12.0-mobius-socket.1",
|
|
82
83
|
"chai": "4.3.4",
|
|
@@ -148,5 +149,5 @@
|
|
|
148
149
|
"staticpath": "docs",
|
|
149
150
|
"noprompt": true
|
|
150
151
|
},
|
|
151
|
-
"version": "3.12.0-mobius-socket.
|
|
152
|
+
"version": "3.12.0-mobius-socket.12"
|
|
152
153
|
}
|