@webex/plugin-meetings 3.0.0-beta.375 → 3.0.0-beta.377
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/breakouts/breakout.js +1 -1
- package/dist/breakouts/index.js +1 -1
- package/dist/interpretation/index.js +1 -1
- package/dist/interpretation/siLanguage.js +1 -1
- package/dist/meetings/index.js +6 -1
- package/dist/meetings/index.js.map +1 -1
- package/dist/reconnection-manager/index.js +22 -26
- package/dist/reconnection-manager/index.js.map +1 -1
- package/dist/types/meetings/index.d.ts +1 -1
- package/dist/webinar/index.js +1 -1
- package/package.json +19 -19
- package/src/meetings/index.ts +10 -1
- package/src/reconnection-manager/index.ts +11 -13
- package/test/unit/spec/meetings/index.js +21 -0
- package/test/unit/spec/reconnection-manager/index.js +1 -11
package/dist/breakouts/index.js
CHANGED
|
@@ -1041,7 +1041,7 @@ var Breakouts = _webexCore.WebexPlugin.extend({
|
|
|
1041
1041
|
this.trigger(_constants.BREAKOUTS.EVENTS.ASK_RETURN_TO_MAIN);
|
|
1042
1042
|
}
|
|
1043
1043
|
},
|
|
1044
|
-
version: "3.0.0-beta.
|
|
1044
|
+
version: "3.0.0-beta.377"
|
|
1045
1045
|
});
|
|
1046
1046
|
var _default = Breakouts;
|
|
1047
1047
|
exports.default = _default;
|
package/dist/meetings/index.js
CHANGED
|
@@ -1327,7 +1327,7 @@ var Meetings = /*#__PURE__*/function (_WebexPlugin) {
|
|
|
1327
1327
|
}
|
|
1328
1328
|
|
|
1329
1329
|
/**
|
|
1330
|
-
*
|
|
1330
|
+
* Syncs all the meetings from server. Does nothing and returns immediately if unverified guest.
|
|
1331
1331
|
* @param {boolean} keepOnlyLocusMeetings - whether the sync should keep only locus meetings or any other meeting in meetingCollection
|
|
1332
1332
|
* @returns {Promise<void>}
|
|
1333
1333
|
* @public
|
|
@@ -1340,6 +1340,11 @@ var Meetings = /*#__PURE__*/function (_WebexPlugin) {
|
|
|
1340
1340
|
var _ref3 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
|
|
1341
1341
|
_ref3$keepOnlyLocusMe = _ref3.keepOnlyLocusMeetings,
|
|
1342
1342
|
keepOnlyLocusMeetings = _ref3$keepOnlyLocusMe === void 0 ? true : _ref3$keepOnlyLocusMe;
|
|
1343
|
+
// @ts-ignore
|
|
1344
|
+
if (this.webex.credentials.isUnverifiedGuest) {
|
|
1345
|
+
_loggerProxy.default.logger.info('Meetings:index#syncMeetings --> skipping meeting sync as unverified guest');
|
|
1346
|
+
return _promise.default.resolve();
|
|
1347
|
+
}
|
|
1343
1348
|
return this.request.getActiveMeetings().then(function (locusArray) {
|
|
1344
1349
|
var activeLocusUrl = [];
|
|
1345
1350
|
if (locusArray !== null && locusArray !== void 0 && locusArray.loci && locusArray.loci.length > 0) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["mediaLogger","MediaLogger","LoggerProxy","logger","info","log","error","warn","trace","debug","Meetings","args","MEETINGS","options","authToken","webex","credentials","supertoken","access_token","mediaHelpersModule","NoiseReductionEffect","VirtualBackgroundEffect","mediaHelpers","request","Request","parent","loggerRequest","LoggerRequest","meetingCollection","MeetingCollection","personalMeetingRoom","reachability","Reachability","registered","preferredWebexSite","media","getUserMedia","Media","onReady","meeting","newLocus","breakoutUrl","controls","breakout","url","breakoutLocus","getActiveBreakoutLocus","isSelfJoined","self","state","_JOINED_","isSelfMoved","_LEFT_","reason","_MOVED_","deviceFromNewLocus","MeetingsUtil","getThisDevice","internal","device","isResourceMovedOnThisDevice","isNewLocusJoinThisDevice","joinedOnThisDevice","isBreakoutLocusJoinThisDevice","joinedWith","correlationId","breakoutReplaceAt","replaces","length","replaceAt","newLocusReplaceAt","removed","isNewLocusAsBreakout","isBreakoutLocusDTO","fullState","active","isNeedHandleMainLocus","data","getByKey","LOCUS_URL","locusUrl","CORRELATION_ID","checkForCorrelationId","locus","SIP_URI","callbackInfo","callbackAddress","isUnifiedSpaceMeeting","undefined","CONVERSATION_URL","conversationUrl","MEETINGNUMBER","webExMeetingId","useRandomDelayForInfo","getCorrespondingMeetingByLocus","locusInfo","updateMainSessionLocusCache","isNeedHandleLocusDTO","LOCUS","STATE","INACTIVE","create","_LOCUS_ID_","then","newMeeting","initialSetup","checkHandleBreakoutLocus","catch","e","finally","getMeetingByType","_ID_","id","newMetrics","submitClientEvent","name","payload","trigger","meetingId","Trigger","file","function","EVENT_TRIGGERS","MEETING_ADDED","type","_MEETING_","_JOIN_","_INCOMING_","parse","envelope","eventType","LOCUSEVENT","MESSAGE_ROAP","handleLocusEvent","MEETINGS_NETWORK_DISCONNECTED","mercury","on","LOCUS_MERCURY","handleLocusMercury","ROAP","ROAP_MERCURY","handleRoapMercury","ONLINE","syncMeetings","keepOnlyLocusMeetings","OFFLINE","handleMercuryOffline","off","once","READY","StaticConfig","set","config","LoggerConfig","logging","setLogger","meetingInfo","experimental","enableUnifiedMeetings","MeetingInfoV2","MeetingInfo","PersonalMeetingRoom","MEETINGS_READY","checkH264Support","disableNotifications","Metrics","changeState","enableAdhocMeetings","newValue","enableTcpReachability","sendBehavioralMetric","BEHAVIORAL_METRICS","MEETINGS_REGISTRATION_STEP","step","canAuthorize","reject","Error","resolve","all","fetchUserPreferredWebexSite","getGeoHint","startReachability","message","register","connect","call","listenForEvents","MEETINGS_REGISTERED","MEETINGS_REGISTRATION_SUCCESS","MEETINGS_REGISTRATION_FAILED","stack","stopListeningForEvents","disconnect","unregister","MEETINGS_UNREGISTERED","uploadLogs","uploadResult","UPLOAD_LOGS_SUCCESS","MEETING_LOG_UPLOAD_SUCCESS","details","uploadError","MEETING_LOG_UPLOAD_FAILURE","UPLOAD_LOGS_FAILURE","code","getReachability","gatherReachability","fetchGeoHint","res","geoHintInfo","getMeetingPreferences","parseDefaultSiteFromMeetingPreferences","user","get","userPreferences","userPreferencesItems","preferredWebExSite","MeetingUtil","cleanUp","delete","MEETING_REMOVED","destination","infoExtraParams","failOnMissingMeetingInfo","callStateForMetrics","meetingLookupUrl","fetchInfoOptions","SpaceIDDeprecatedError","targetDest","_CONVERSATION_URL_","foundMeeting","foundMeetingIsNotCalendarMeeting","scheduledMeeting","createMeeting","createdMeeting","EVENTS","DESTROY_MEETING","autoUploadLogs","callStart","lastActive","locussessionid","sessionId","feedbackId","locusId","autoupload","destroy","REQUEST_UPLOAD_LOGS","meetingInstance","setCallStateForMetrics","Meeting","userId","deviceUrl","orgId","meetingInfoProvider","destinationType","waitingTime","startTime","startTimeDate","Date","startTimeDatestamp","getTime","timeToStart","maxWaitingTime","Math","max","min","MAX_RANDOM_DELAY_FOR_MEETING_INFO","round","random","isMeetingActive","meetingInfoOptions","extraParams","sendCAevents","injectMeetingInfo","fetchMeetingInfoTimeoutId","setTimeout","fetchMeetingInfo","parseMeetingInfo","CaptchaError","PasswordError","PermissionError","MEETING_REMOVED_REASON","MISSING_MEETING_INFO","NoMeetingInfoError","sipUri","setSipUri","meetingAddedType","getMeetingAddedType","value","getAll","getActiveMeetings","locusArray","activeLocusUrl","loci","lociToUpdate","sortLocusArrayToUpdate","forEach","push","meetingsCollection","includes","NO_MEETINGS_TO_SYNC","mainLoci","filter","breakoutLoci","isValidBreakoutLocus","breakoutLocusForHandleLater","associateMainLocus","find","mainLocus","existCorrespondingMeeting","newCreatedLocus","existIndex","findIndex","associateBreakoutLocus","splice","scheduled","getActiveWebrtcMeeting","WebexPlugin"],"sources":["index.ts"],"sourcesContent":["/* eslint no-shadow: [\"error\", { \"allow\": [\"eventType\"] }] */\n\nimport '@webex/internal-plugin-mercury';\nimport '@webex/internal-plugin-conversation';\nimport '@webex/internal-plugin-metrics';\n// @ts-ignore\nimport {WebexPlugin} from '@webex/webex-core';\nimport {setLogger} from '@webex/internal-media-core';\n\nimport * as mediaHelpersModule from '@webex/media-helpers';\n\nimport 'webrtc-adapter';\n\nimport Metrics from '../metrics';\nimport LoggerConfig from '../common/logs/logger-config';\nimport StaticConfig from '../common/config';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport LoggerRequest from '../common/logs/request';\nimport Trigger from '../common/events/trigger-proxy';\nimport Media from '../media';\nimport MeetingUtil from '../meeting/util';\nimport {\n MEETINGS,\n EVENTS,\n EVENT_TRIGGERS,\n READY,\n LOCUSEVENT,\n LOCUS_URL,\n MAX_RANDOM_DELAY_FOR_MEETING_INFO,\n ROAP,\n ONLINE,\n OFFLINE,\n _MEETING_,\n _JOIN_,\n _LOCUS_ID_,\n _INCOMING_,\n LOCUS,\n CORRELATION_ID,\n SIP_URI,\n _LEFT_,\n _ID_,\n MEETING_REMOVED_REASON,\n _CONVERSATION_URL_,\n CONVERSATION_URL,\n MEETINGNUMBER,\n _JOINED_,\n _MOVED_,\n} from '../constants';\nimport BEHAVIORAL_METRICS from '../metrics/constants';\nimport MeetingInfo from '../meeting-info';\nimport MeetingInfoV2 from '../meeting-info/meeting-info-v2';\nimport Meeting, {CallStateForMetrics} from '../meeting';\nimport PersonalMeetingRoom from '../personal-meeting-room';\nimport Reachability from '../reachability';\nimport Request from './request';\nimport PasswordError from '../common/errors/password-error';\nimport CaptchaError from '../common/errors/captcha-error';\n\nimport MeetingCollection from './collection';\nimport MeetingsUtil from './util';\nimport PermissionError from '../common/errors/permission';\nimport {INoiseReductionEffect, IVirtualBackgroundEffect} from './meetings.types';\nimport {SpaceIDDeprecatedError} from '../common/errors/webex-errors';\nimport NoMeetingInfoError from '../common/errors/no-meeting-info';\n\nlet mediaLogger;\n\nclass MediaLogger {\n info(...args) {\n LoggerProxy.logger.info(...args);\n }\n\n log(...args) {\n LoggerProxy.logger.log(...args);\n }\n\n error(...args) {\n LoggerProxy.logger.error(...args);\n }\n\n warn(...args) {\n LoggerProxy.logger.warn(...args);\n }\n\n trace(...args) {\n LoggerProxy.logger.trace(...args);\n }\n\n debug(...args) {\n LoggerProxy.logger.debug(...args);\n }\n}\n/**\n * Meetings Ready Event\n * Emitted when the meetings instance on webex is ready\n * @event meetings:ready\n * @instance\n * @memberof Meetings\n */\n\n/**\n * Meetings Network Disconnected Event\n * Emitted when the meetings instance is disconnected from\n * the internal mercury server\n * @event network:disconnected\n * @instance\n * @memberof Meetings\n */\n\n/**\n * Meetings Registered Event\n * Emitted when the meetings instance has been registered and listening\n * @event meetings:registered\n * @instance\n * @memberof Meetings\n */\n\n/**\n * Meeting Removed Event\n * Emitted when a meeting was removed from the cache of meetings\n * @event meeting:removed\n * @instance\n * @type {Object}\n * @property {String} meetingId the removed meeting\n * @property {Object} response the server response\n * @property {String} type what type of meeting it was\n * @memberof Meetings\n */\n\n/**\n * Meeting Added Event\n * Emitted when a meeting was added to the cache of meetings\n * @event meeting:added\n * @instance\n * @type {Object}\n * @property {String} meetingId the added meeting\n * @property {String} type what type of meeting it was\n * @memberof Meetings\n */\n\n/**\n * Maintain a cache of meetings and sync with services.\n * @class\n */\nexport default class Meetings extends WebexPlugin {\n loggerRequest: any;\n media: any;\n meetingCollection: any;\n personalMeetingRoom: any;\n preferredWebexSite: any;\n reachability: Reachability;\n registered: any;\n request: any;\n geoHintInfo: any;\n meetingInfo: any;\n mediaHelpers: any;\n breakoutLocusForHandleLater: any;\n namespace = MEETINGS;\n\n /**\n * Initializes the Meetings Plugin\n * @constructor\n * @public\n * @memberof Meetings\n */\n constructor(...args) {\n super(...args);\n\n /**\n * The webrtc-core media helpers. This is a temporary solution required for the SDK sample app\n * to be able to call media helper functions.\n *\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n this.mediaHelpers = mediaHelpersModule;\n\n /**\n * The Meetings request to interact with server\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.request = new Request({}, {parent: this.webex});\n /**\n * Log upload request helper\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.loggerRequest = new LoggerRequest({webex: this.webex});\n this.meetingCollection = new MeetingCollection();\n /**\n * The PersonalMeetingRoom object to interact with server\n * @instance\n * @type {Object}\n * @public\n * @memberof Meetings\n */\n this.personalMeetingRoom = null;\n\n /**\n * The Reachability object to interact with server\n * starts as null\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.reachability = new Reachability(this.webex);\n\n /**\n * If the meetings plugin has been registered and listening via {@link Meetings#register}\n * @instance\n * @type {Boolean}\n * @public\n * @memberof Meetings\n */\n this.registered = false;\n\n /**\n * This values indicates the preferred webex site the user will start there meeting, getsits value from {@link Meetings#register}\n * @instance\n * @type {String}\n * @private\n * @memberof Meetings\n */\n this.preferredWebexSite = '';\n\n /**\n * The public interface for the internal Media util files. These are helpful to expose outside the context\n * of a meeting so that a user can access media without creating a meeting instance.\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n this.media = {\n getUserMedia: Media.getUserMedia,\n };\n\n this.onReady();\n }\n\n /**\n * check whether you need to handle this main session's locus data or not\n * @param {Object} meeting current meeting data\n * @param {Object} newLocus new locus data\n * @returns {boolean}\n * @private\n * @memberof Meetings\n */\n private isNeedHandleMainLocus(meeting: any, newLocus: any) {\n const breakoutUrl = newLocus.controls?.breakout?.url;\n const breakoutLocus = this.meetingCollection.getActiveBreakoutLocus(breakoutUrl);\n\n const isSelfJoined = newLocus?.self?.state === _JOINED_;\n const isSelfMoved = newLocus?.self?.state === _LEFT_ && newLocus?.self?.reason === _MOVED_;\n // @ts-ignore\n const deviceFromNewLocus = MeetingsUtil.getThisDevice(newLocus, this.webex.internal.device.url);\n const isResourceMovedOnThisDevice =\n deviceFromNewLocus?.state === _LEFT_ && deviceFromNewLocus?.reason === _MOVED_;\n\n const isNewLocusJoinThisDevice = MeetingsUtil.joinedOnThisDevice(\n meeting,\n newLocus,\n // @ts-ignore\n this.webex.internal.device.url\n );\n const isBreakoutLocusJoinThisDevice =\n breakoutLocus?.joinedWith?.correlationId &&\n breakoutLocus.joinedWith.correlationId === meeting?.correlationId;\n\n if (isSelfJoined && isNewLocusJoinThisDevice) {\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> self this device shown as JOINED in the main session'\n );\n if (breakoutLocus?.joinedWith && deviceFromNewLocus) {\n const breakoutReplaceAt =\n breakoutLocus.joinedWith.replaces?.length > 0\n ? breakoutLocus.joinedWith.replaces[0].replaceAt\n : '';\n const newLocusReplaceAt =\n deviceFromNewLocus.replaces?.length > 0 ? deviceFromNewLocus.replaces[0].replaceAt : '';\n if (breakoutReplaceAt && newLocusReplaceAt && breakoutReplaceAt > newLocusReplaceAt) {\n LoggerProxy.logger.log(\n `Meetings:index#isNeedHandleMainLocus --> this is expired main joined status locus_dto replacedAt ${newLocusReplaceAt} bo replacedAt ${breakoutReplaceAt}`\n );\n\n return false;\n }\n }\n\n return true;\n }\n if (isBreakoutLocusJoinThisDevice) {\n LoggerProxy.logger.log(\n `Meetings:index#isNeedHandleMainLocus --> there is active breakout session and joined on this device, and don't need to handle main session: ${breakoutUrl}`\n );\n\n return false;\n }\n if (isSelfMoved && (newLocus?.self?.removed || isResourceMovedOnThisDevice)) {\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> self moved main locus with self removed status or with device resource moved, not need to handle'\n );\n\n return false;\n }\n if (isSelfJoined && isResourceMovedOnThisDevice) {\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> self device left&moved in main locus with self joined status, not need to handle'\n );\n\n return false;\n }\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> this is a normal main session locusDTO update case'\n );\n\n return true;\n }\n\n /**\n * check whether you need to handle this locus data or not\n * @param {Object} meeting old locus data\n * @param {Object} newLocus new locus data\n * @returns {boolean}\n * @private\n * @memberof Meetings\n */\n private isNeedHandleLocusDTO(meeting: any, newLocus: any) {\n if (newLocus) {\n const isNewLocusAsBreakout = MeetingsUtil.isBreakoutLocusDTO(newLocus);\n const isSelfMoved = newLocus?.self?.state === _LEFT_ && newLocus?.self?.reason === _MOVED_;\n if (!meeting) {\n if (isNewLocusAsBreakout) {\n LoggerProxy.logger.log(\n `Meetings:index#isNeedHandleLocusDTO --> the first breakout session locusDTO active status: ${newLocus.fullState?.active}`\n );\n\n return newLocus.self?.state === _JOINED_;\n }\n\n return this.isNeedHandleMainLocus(meeting, newLocus);\n }\n if (!isNewLocusAsBreakout) {\n return this.isNeedHandleMainLocus(meeting, newLocus);\n }\n\n return !isSelfMoved;\n }\n\n return true;\n }\n\n /**\n * get corresponding meeting object by locus data\n * @param {Object} data a locus event\n * @param {String} data.locusUrl\n * @param {Object} data.locus\n * @returns {Object}\n * @private\n * @memberof Meetings\n */\n getCorrespondingMeetingByLocus(data) {\n // getting meeting by correlationId. This will happen for the new event\n // Either the locus\n // TODO : Add check for the callBack Address\n return (\n this.meetingCollection.getByKey(LOCUS_URL, data.locusUrl) ||\n // @ts-ignore\n this.meetingCollection.getByKey(\n CORRELATION_ID,\n // @ts-ignore\n MeetingsUtil.checkForCorrelationId(this.webex.internal.device.url, data.locus)\n ) ||\n this.meetingCollection.getByKey(\n SIP_URI,\n data.locus.self &&\n data.locus.self.callbackInfo &&\n data.locus.self.callbackInfo.callbackAddress\n ) ||\n (data.locus.info?.isUnifiedSpaceMeeting\n ? undefined\n : this.meetingCollection.getByKey(CONVERSATION_URL, data.locus.conversationUrl)) ||\n this.meetingCollection.getByKey(MEETINGNUMBER, data.locus?.info?.webExMeetingId)\n );\n }\n\n /**\n * handle locus events and takes meeting actions with them as they come in\n * @param {Object} data a locus event\n * @param {String} data.locusUrl\n * @param {Object} data.locus\n * @param {Boolean} useRandomDelayForInfo whether a random delay should be added to fetching meeting info\n * @param {String} data.eventType\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private handleLocusEvent(data: {locusUrl: string; locus: any}, useRandomDelayForInfo = false) {\n let meeting = this.getCorrespondingMeetingByLocus(data);\n\n // Special case when locus has got replaced, This only happend once if a replace locus exists\n // https://sqbu-github.cisco.com/WebExSquared/locus/wiki/Locus-changing-mid-call\n\n if (!meeting && data.locus?.replaces?.length > 0) {\n // Always the last element in the replace is the active one\n meeting = this.meetingCollection.getByKey(\n LOCUS_URL,\n data.locus.replaces[data.locus.replaces.length - 1].locusUrl\n );\n }\n\n if (meeting && !MeetingsUtil.isBreakoutLocusDTO(data.locus)) {\n meeting.locusInfo.updateMainSessionLocusCache(data.locus);\n }\n if (!this.isNeedHandleLocusDTO(meeting, data.locus)) {\n LoggerProxy.logger.log(\n `Meetings:index#handleLocusEvent --> doesn't need to process locus event`\n );\n\n return;\n }\n if (!meeting) {\n // TODO: create meeting when we get a meeting object\n // const checkForEnded = (locus) => {\n // TODO: you already ended the meeting but you got an event later\n // Mainly for 1:1 Callsor meeting\n // Happens mainly after refresh\n\n // 1:1 Meeting\n // 1) You ended a call before but you got a mercury event\n // Make sure end the call and cleanup the meeting only if the mercury\n // event says so\n // 2) Maintain lastSync time in the meetings object which helps to compare\n // If the meeting came befor or after the sync . ANy meeting start time before the sync time is invalid\n\n // For space Meeting\n // Check the locus object and see who has joined\n\n // };\n // rather then locus object change to locus url\n\n if (\n data.locus &&\n data.locus.fullState &&\n data.locus.fullState.state === LOCUS.STATE.INACTIVE\n ) {\n // just ignore the event as its already ended and not active\n LoggerProxy.logger.warn(\n 'Meetings:index#handleLocusEvent --> Locus event received for meeting, after it was ended.'\n );\n\n return;\n }\n\n // When its wireless share or guest and user leaves the meeting we dont have to keep the meeting object\n // Any future events will be neglected\n\n if (\n data.locus &&\n data.locus.self &&\n data.locus.self.state === _LEFT_ &&\n data.locus.self.removed === true\n ) {\n // just ignore the event as its already ended and not active\n LoggerProxy.logger.warn(\n 'Meetings:index#handleLocusEvent --> Locus event received for meeting, after it was ended.'\n );\n\n return;\n }\n\n this.create(data.locus, _LOCUS_ID_, useRandomDelayForInfo)\n .then((newMeeting) => {\n meeting = newMeeting;\n\n // It's a new meeting so initialize the locus data\n meeting.locusInfo.initialSetup(data.locus);\n this.checkHandleBreakoutLocus(data.locus);\n })\n .catch((e) => {\n LoggerProxy.logger.error(e);\n })\n .finally(() => {\n // There will be cases where locus event comes in gets created and deleted because its a 1:1 and meeting gets deleted\n // because the other user left so before sending 'added' event make sure it exists in the collection\n\n if (this.getMeetingByType(_ID_, meeting.id)) {\n // @ts-ignore\n this.webex.internal.newMetrics.submitClientEvent({\n name: 'client.call.remote-started',\n payload: {\n trigger: 'mercury-event',\n },\n options: {\n meetingId: meeting.id,\n },\n });\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'handleLocusEvent',\n },\n EVENT_TRIGGERS.MEETING_ADDED,\n {\n meeting,\n type: meeting.type === _MEETING_ ? _JOIN_ : _INCOMING_,\n }\n );\n } else {\n // Meeting got added but was not found in the collection. It might have got destroyed\n LoggerProxy.logger.warn(\n 'Meetings:index#handleLocusEvent --> Created and destroyed meeting object before sending an event'\n );\n }\n });\n } else {\n meeting.locusInfo.parse(meeting, data);\n }\n }\n\n /**\n * handles locus events through mercury that are not roap\n * @param {Object} envelope\n * @param {Object} envelope.data\n * @param {String} envelope.data.eventType\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private handleLocusMercury(envelope: {data: any}) {\n const {data} = envelope;\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const {eventType} = data;\n\n if (eventType && eventType !== LOCUSEVENT.MESSAGE_ROAP) {\n this.handleLocusEvent(data, true);\n }\n }\n\n /**\n * handles mecury offline event\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private handleMercuryOffline() {\n Trigger.trigger(\n this,\n {\n file: 'meetings/index',\n function: 'handleMercuryOffline',\n },\n EVENT_TRIGGERS.MEETINGS_NETWORK_DISCONNECTED\n );\n }\n\n /**\n * registers for locus and roap mercury events\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private listenForEvents() {\n // @ts-ignore\n this.webex.internal.mercury.on(LOCUSEVENT.LOCUS_MERCURY, (envelope) => {\n this.handleLocusMercury(envelope);\n });\n // @ts-ignore\n this.webex.internal.mercury.on(ROAP.ROAP_MERCURY, (envelope) => {\n MeetingsUtil.handleRoapMercury(envelope, this.meetingCollection);\n });\n\n // @ts-ignore\n this.webex.internal.mercury.on(ONLINE, () => {\n this.syncMeetings({keepOnlyLocusMeetings: false});\n });\n\n // @ts-ignore\n this.webex.internal.mercury.on(OFFLINE, () => {\n this.handleMercuryOffline();\n });\n }\n\n /**\n * stops listening for locus and roap mercury events\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private stopListeningForEvents() {\n // @ts-ignore\n this.webex.internal.mercury.off(LOCUSEVENT.LOCUS_MERCURY);\n // @ts-ignore\n this.webex.internal.mercury.off(ROAP.ROAP_MERCURY);\n // @ts-ignore\n this.webex.internal.mercury.off(ONLINE);\n }\n\n /**\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private onReady() {\n // @ts-ignore\n this.webex.once(READY, () => {\n // @ts-ignore\n StaticConfig.set(this.config);\n // @ts-ignore\n LoggerConfig.set(this.config.logging);\n // @ts-ignore\n LoggerProxy.set(this.webex.logger);\n\n mediaLogger = new MediaLogger();\n setLogger(mediaLogger);\n\n /**\n * The MeetingInfo object to interact with server\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.meetingInfo = this.config.experimental.enableUnifiedMeetings\n ? // @ts-ignore\n new MeetingInfoV2(this.webex)\n : // @ts-ignore\n new MeetingInfo(this.webex);\n // @ts-ignore\n this.personalMeetingRoom = new PersonalMeetingRoom(\n {meetingInfo: this.meetingInfo},\n // @ts-ignore\n {parent: this.webex}\n );\n\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'onReady',\n },\n EVENT_TRIGGERS.MEETINGS_READY\n );\n\n MeetingsUtil.checkH264Support({disableNotifications: true});\n // @ts-ignore\n Metrics.initialSetup(this.webex);\n });\n }\n\n /**\n * API to toggle unified meetings\n * @param {Boolean} changeState\n * @private\n * @memberof Meetings\n * @returns {undefined}\n */\n private _toggleUnifiedMeetings(changeState: boolean) {\n if (typeof changeState !== 'boolean') {\n return;\n }\n // @ts-ignore\n if (this.config?.experimental?.enableUnifiedMeetings !== changeState) {\n // @ts-ignore\n this.config.experimental.enableUnifiedMeetings = changeState;\n // @ts-ignore\n this.meetingInfo = changeState ? new MeetingInfoV2(this.webex) : new MeetingInfo(this.webex);\n }\n }\n\n /**\n * API to toggle starting adhoc meeting\n * @param {Boolean} changeState\n * @private\n * @memberof Meetings\n * @returns {undefined}\n */\n private _toggleAdhocMeetings(changeState: boolean) {\n if (typeof changeState !== 'boolean') {\n return;\n }\n // @ts-ignore\n if (this.config?.experimental?.enableAdhocMeetings !== changeState) {\n // @ts-ignore\n this.config.experimental.enableAdhocMeetings = changeState;\n }\n }\n\n /**\n * API to toggle TCP reachability, needs to be called before webex.meetings.register()\n * @param {Boolean} newValue\n * @private\n * @memberof Meetings\n * @returns {undefined}\n */\n private _toggleTcpReachability(newValue: boolean) {\n if (typeof newValue !== 'boolean') {\n return;\n }\n // @ts-ignore\n if (this.config.experimental.enableTcpReachability !== newValue) {\n // @ts-ignore\n this.config.experimental.enableTcpReachability = newValue;\n }\n }\n\n /**\n * Explicitly sets up the meetings plugin by registering\n * the device, connecting to mercury, and listening for locus events.\n *\n * @returns {Promise}\n * @public\n * @memberof Meetings\n */\n public register() {\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_STEP, {\n step: '[sdk] begin registration',\n });\n\n // @ts-ignore\n if (!this.webex.canAuthorize) {\n LoggerProxy.logger.error(\n 'Meetings:index#register --> ERROR, Unable to register, SDK cannot authorize'\n );\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_STEP, {\n step: '[sdk] cannot authorize',\n });\n\n return Promise.reject(new Error('SDK cannot authorize'));\n }\n\n if (this.registered) {\n LoggerProxy.logger.info(\n 'Meetings:index#register --> INFO, Meetings plugin already registered'\n );\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_STEP, {\n step: '[sdk] already registered',\n });\n\n return Promise.resolve();\n }\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_STEP, {\n step: '[sdk] begin Promise.all()',\n });\n\n return Promise.all([\n this.fetchUserPreferredWebexSite(),\n this.getGeoHint(),\n this.startReachability().catch((error) => {\n LoggerProxy.logger.error(`Meetings:index#register --> GDM error, ${error.message}`);\n }),\n // @ts-ignore\n this.webex.internal.device\n .register()\n // @ts-ignore\n .then(() =>\n LoggerProxy.logger.info(\n // @ts-ignore\n `Meetings:index#register --> INFO, Device registered ${this.webex.internal.device.url}`\n )\n )\n // @ts-ignore\n .then(() => this.webex.internal.mercury.connect()),\n MeetingsUtil.checkH264Support.call(this),\n ])\n .then(() => {\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_STEP, {\n step: '[sdk] end Promise.all()',\n });\n this.listenForEvents();\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'register',\n },\n EVENT_TRIGGERS.MEETINGS_REGISTERED\n );\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_STEP, {\n step: '[sdk] registration complete, triggered MEETINGS_REGISTERED event',\n });\n this.registered = true;\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_SUCCESS);\n })\n .catch((error) => {\n LoggerProxy.logger.error(\n `Meetings:index#register --> ERROR, Unable to register, ${error.message}`\n );\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_FAILED, {\n reason: error.message,\n stack: error.stack,\n });\n\n return Promise.reject(error);\n });\n }\n\n /**\n * Explicitly tears down the meetings plugin by deregistering\n * the device, disconnecting from mercury, and stops listening to locus events\n *\n * @returns {Promise}\n * @public\n * @memberof Meetings\n */\n unregister() {\n if (!this.registered) {\n LoggerProxy.logger.info(\n 'Meetings:index#unregister --> INFO, Meetings plugin already unregistered'\n );\n\n return Promise.resolve();\n }\n\n this.stopListeningForEvents();\n\n return (\n // @ts-ignore\n this.webex.internal.mercury\n .disconnect()\n // @ts-ignore\n .then(() => this.webex.internal.device.unregister())\n .then(() => {\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'unregister',\n },\n EVENT_TRIGGERS.MEETINGS_UNREGISTERED\n );\n this.registered = false;\n })\n );\n }\n\n /**\n * Creates a noise reduction effect\n *\n * @param {INoiseReductionEffect} options optional custom effect options\n * @returns {Promise<effect>} noise reduction effect.\n * @public\n * @memberof Meetings\n */\n createNoiseReductionEffect = async (options?: INoiseReductionEffect) => {\n // @ts-ignore\n const authToken = this.webex.credentials.supertoken.access_token;\n\n return new mediaHelpersModule.NoiseReductionEffect({authToken, ...options});\n };\n\n /**\n * Creates a virtual background effect\n *\n * @param {IVirtualBackgroundEffect} options optional custom effect options\n * @returns {Promise<effect>} virtual background effect.\n * @public\n * @memberof Meetings\n */\n createVirtualBackgroundEffect = async (options?: IVirtualBackgroundEffect) => {\n // @ts-ignore\n const authToken = this.webex.credentials.supertoken.access_token;\n\n return new mediaHelpersModule.VirtualBackgroundEffect({authToken, ...options});\n };\n\n /**\n * Uploads logs to the webex services for tracking\n * @param {Object} [options={}]\n * @param {String} [options.callStart] Call Start Time\n * @param {String} [options.feedbackId] ID used for tracking\n * @param {String} [options.locusId]\n * @param {String} [options.correlationId]\n * @param {String} [options.meetingId] webex meeting ID\n * @param {String} [options.userId] userId\n * @param {String} [options.orgId] org id\n * @returns {String} feedback ID logs were submitted under\n */\n uploadLogs(\n options: {\n autoupload?: boolean;\n callStart?: string;\n feedbackId?: string;\n locussessionid?: string;\n locusId?: string;\n correlationId?: string;\n meetingId?: string;\n userId?: string;\n orgId?: string;\n } = {}\n ) {\n LoggerProxy.logger.info('Meetings:index#uploadLogs --> uploading logs');\n\n return this.loggerRequest\n .uploadLogs(options)\n .then((uploadResult) => {\n LoggerProxy.logger.info(\n 'Meetings:index#uploadLogs --> Upload logs for meeting completed.',\n uploadResult\n );\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.UPLOAD_LOGS_SUCCESS, options);\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'uploadLogs',\n },\n EVENT_TRIGGERS.MEETING_LOG_UPLOAD_SUCCESS,\n {\n meetingId: options.meetingId,\n details: uploadResult,\n }\n );\n\n return uploadResult;\n })\n .catch((uploadError) => {\n LoggerProxy.logger.error(\n 'Meetings:index#uploadLogs --> Unable to upload logs for meeting',\n uploadError\n );\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'uploadLogs',\n },\n EVENT_TRIGGERS.MEETING_LOG_UPLOAD_FAILURE,\n {\n meetingId: options.meetingId,\n reason: uploadError,\n }\n );\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.UPLOAD_LOGS_FAILURE, {\n ...options,\n reason: uploadError.message,\n stack: uploadError.stack,\n code: uploadError.code,\n });\n });\n }\n\n /**\n * gets the reachability instance for Meetings\n * @returns {Reachability}\n * @public\n * @memberof Meetings\n */\n getReachability() {\n return this.reachability;\n }\n\n /**\n * initializes and starts gathering reachability for Meetings\n * @returns {Promise}\n * @public\n * @memberof Meetings\n */\n startReachability() {\n return this.getReachability().gatherReachability();\n }\n\n /**\n * Get geoHint for info for meetings\n * @returns {Promise}\n * @private\n * @memberof Meetings\n */\n getGeoHint() {\n return this.request.fetchGeoHint().then((res) => {\n this.geoHintInfo = res;\n });\n }\n\n /**\n * Fetch user preferred webex site information\n * This also has other infomation about the user\n * @returns {Promise}\n * @private\n * @memberof Meetings\n */\n fetchUserPreferredWebexSite() {\n return this.request.getMeetingPreferences().then((res) => {\n if (res) {\n this.preferredWebexSite = MeetingsUtil.parseDefaultSiteFromMeetingPreferences(res);\n }\n\n // fall back to getting the preferred site from the user information\n if (!this.preferredWebexSite) {\n // @ts-ignore\n return this.webex.internal.user\n .get()\n .then((user) => {\n const preferredWebexSite =\n user?.userPreferences?.userPreferencesItems?.preferredWebExSite;\n if (preferredWebexSite) {\n this.preferredWebexSite = preferredWebexSite;\n } else {\n throw new Error('site not found');\n }\n })\n .catch(() => {\n LoggerProxy.logger.error(\n 'Failed to fetch preferred site from user - no site will be set'\n );\n });\n }\n\n return Promise.resolve();\n });\n }\n\n /**\n * gets the personal meeting room instance, for saved PMR values for this user\n * @returns {PersonalMeetingRoom}\n * @public\n * @memberof Meetings\n */\n\n getPersonalMeetingRoom() {\n return this.personalMeetingRoom;\n }\n\n /**\n * @param {Meeting} meeting\n * @param {Object} reason\n * @param {String} type\n * @returns {Undefined}\n * @private\n * @memberof Meetings\n */\n private destroy(meeting: Meeting, reason: object) {\n MeetingUtil.cleanUp(meeting);\n this.meetingCollection.delete(meeting.id);\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'destroy',\n },\n EVENT_TRIGGERS.MEETING_REMOVED,\n {\n meetingId: meeting.id,\n reason,\n }\n );\n }\n\n /**\n * Create a meeting or return an existing meeting.\n *\n * When meeting info passed it should be complete, e.g.: fetched after password or captcha provided\n *\n * @param {string} destination - sipURL, phonenumber, or locus object}\n * @param {string} [type] - the optional specified type, such as locusId\n * @param {Boolean} useRandomDelayForInfo - whether a random delay should be added to fetching meeting info\n * @param {Object} infoExtraParams extra parameters to be provided when fetching meeting info\n * @param {string} correlationId - the optional specified correlationId (callStateForMetrics.correlationId can be provided instead)\n * @param {Boolean} failOnMissingMeetingInfo - whether to throw an error if meeting info fails to fetch (for calls that are not 1:1 or content share)\n * @param {CallStateForMetrics} callStateForMetrics - information about call state for metrics\n * @param {Object} [meetingInfo] - Pre-fetched complete meeting info\n * @param {String} [meetingLookupUrl] - meeting info prefetch url\n * @returns {Promise<Meeting>} A new Meeting.\n * @public\n * @memberof Meetings\n */\n public create(\n destination: string,\n type: string = null,\n useRandomDelayForInfo = false,\n infoExtraParams = {},\n correlationId: string = undefined,\n failOnMissingMeetingInfo = false,\n callStateForMetrics: CallStateForMetrics = undefined,\n meetingInfo = undefined,\n meetingLookupUrl = undefined\n ) {\n // TODO: type should be from a dictionary\n\n // Validate meeting information based on the provided destination and\n // type. This must be performed prior to determining if the meeting is\n // found in the collection, as we mutate the destination for hydra person\n // id values.\n if (correlationId) {\n callStateForMetrics = {...(callStateForMetrics || {}), correlationId};\n }\n\n return (\n this.meetingInfo\n .fetchInfoOptions(destination, type)\n // Catch a failure to fetch info options.\n .catch((error) => {\n LoggerProxy.logger.error(\n `Meetings:index#create --> ERROR, unable to determine info options: ${error.message}`\n );\n if (error instanceof SpaceIDDeprecatedError) {\n throw new SpaceIDDeprecatedError();\n }\n })\n .then((options: any = {}) => {\n // Normalize the destination.\n const targetDest = options.destination || destination;\n\n // check for the conversation URL then sip Url\n let meeting = null;\n\n if (type === _CONVERSATION_URL_ || options.type === _CONVERSATION_URL_) {\n const foundMeeting = this.meetingCollection.getByKey(CONVERSATION_URL, targetDest);\n\n if (foundMeeting) {\n const foundMeetingIsNotCalendarMeeting = !foundMeeting.locusInfo.scheduledMeeting;\n\n // If the found meeting is not a calendar meeting, return that meeting.\n // This allows for the creation of instant-meetings when calendar meetings are present.\n if (foundMeetingIsNotCalendarMeeting) {\n meeting = foundMeeting;\n }\n }\n }\n\n // Attempt to collect the meeting if it exists.\n if (!meeting) {\n meeting = this.meetingCollection.getByKey(SIP_URI, targetDest);\n }\n\n // Validate if a meeting was found.\n if (!meeting) {\n // Create a meeting based on the normalized destination and type.\n return this.createMeeting(\n targetDest,\n type,\n useRandomDelayForInfo,\n infoExtraParams,\n callStateForMetrics,\n failOnMissingMeetingInfo,\n meetingInfo,\n meetingLookupUrl\n ).then((createdMeeting: any) => {\n // If the meeting was successfully created.\n if (createdMeeting && createdMeeting.on) {\n // Create a destruction event for the meeting.\n createdMeeting.on(EVENTS.DESTROY_MEETING, (payload) => {\n // @ts-ignore\n if (this.config.autoUploadLogs) {\n this.uploadLogs({\n callStart: createdMeeting.locusInfo?.fullState?.lastActive,\n locussessionid: createdMeeting.locusInfo?.fullState?.sessionId,\n correlationId: createdMeeting.correlationId,\n feedbackId: createdMeeting.correlationId,\n locusId: createdMeeting.locusId,\n meetingId: createdMeeting.locusInfo?.info?.webExMeetingId,\n autoupload: true,\n }).then(() => this.destroy(createdMeeting, payload.reason));\n } else {\n this.destroy(createdMeeting, payload.reason);\n }\n });\n\n createdMeeting.on(EVENTS.REQUEST_UPLOAD_LOGS, (meetingInstance) => {\n // @ts-ignore\n if (this.config.autoUploadLogs) {\n this.uploadLogs({\n callStart: meetingInstance?.locusInfo?.fullState?.lastActive,\n locussessionid: meetingInstance?.locusInfo?.fullState?.sessionId,\n correlationId: meetingInstance.correlationId,\n feedbackId: meetingInstance.correlationId,\n locusId: meetingInstance.locusId,\n meetingId: meetingInstance.locusInfo?.info?.webExMeetingId,\n autoupload: true,\n });\n }\n });\n } else {\n LoggerProxy.logger.error(\n `Meetings:index#create --> ERROR, meeting does not have on method, will not be destroyed, meeting cleanup impossible for meeting: ${meeting}`\n );\n }\n\n // Return the newly created meeting.\n return Promise.resolve(createdMeeting);\n });\n }\n meeting.setCallStateForMetrics(callStateForMetrics);\n\n // Return the existing meeting.\n return Promise.resolve(meeting);\n })\n );\n }\n\n /**\n * Create meeting\n *\n * When meeting info passed it should be complete, e.g.: fetched after password or captcha provided\n *\n * @param {String} destination see create()\n * @param {String} type see create()\n * @param {Boolean} useRandomDelayForInfo whether a random delay should be added to fetching meeting info\n * @param {Object} infoExtraParams extra parameters to be provided when fetching meeting info\n * @param {CallStateForMetrics} callStateForMetrics - information about call state for metrics\n * @param {Boolean} failOnMissingMeetingInfo - whether to throw an error if meeting info fails to fetch (for calls that are not 1:1 or content share)\n * @param {Object} [meetingInfo] - Pre-fetched complete meeting info\n * @param {String} [meetingLookupUrl] - meeting info prefetch url\n * @returns {Promise} a new meeting instance complete with meeting info and destination\n * @private\n * @memberof Meetings\n */\n private async createMeeting(\n destination: any,\n type: string = null,\n useRandomDelayForInfo = false,\n infoExtraParams = {},\n callStateForMetrics: CallStateForMetrics = undefined,\n failOnMissingMeetingInfo = false,\n meetingInfo = undefined,\n meetingLookupUrl = undefined\n ) {\n const meeting = new Meeting(\n {\n // @ts-ignore\n userId: this.webex.internal.device.userId,\n // @ts-ignore\n deviceUrl: this.webex.internal.device.url,\n // @ts-ignore\n orgId: this.webex.internal.device.orgId,\n locus: type === _LOCUS_ID_ ? destination : null, // pass the locus object if present\n meetingInfoProvider: this.meetingInfo,\n destination,\n destinationType: type,\n callStateForMetrics,\n },\n {\n // @ts-ignore\n parent: this.webex,\n }\n );\n\n this.meetingCollection.set(meeting);\n\n try {\n // if no participant has joined the scheduled meeting (meaning meeting is not active) and we get a locusEvent,\n // it means the meeting will start in 5-6 min. In that case, we want to fetchMeetingInfo\n // between 5 and 2 min (random between 3 minutes) before the meeting starts\n // to avoid a spike in traffic to the wbxappi service\n let waitingTime = 0;\n\n if (destination.meeting) {\n const {startTime} = destination.meeting;\n const startTimeDate = new Date(startTime);\n const startTimeDatestamp = startTimeDate.getTime();\n const timeToStart = startTimeDatestamp - Date.now();\n const maxWaitingTime = Math.max(\n Math.min(timeToStart, MAX_RANDOM_DELAY_FOR_MEETING_INFO),\n 0\n );\n\n waitingTime = Math.round(Math.random() * maxWaitingTime);\n }\n const isMeetingActive = !!destination.fullState?.active;\n // @ts-ignore\n const {enableUnifiedMeetings} = this.config.experimental;\n const meetingInfoOptions = {\n extraParams: infoExtraParams,\n sendCAevents: !!callStateForMetrics?.correlationId, // if client sends correlation id as argument of public create(), then it means that this meeting creation is part of a pre-join intent from user\n };\n\n if (meetingInfo) {\n meeting.injectMeetingInfo(meetingInfo, meetingInfoOptions, meetingLookupUrl);\n } else if (\n enableUnifiedMeetings &&\n !isMeetingActive &&\n useRandomDelayForInfo &&\n waitingTime > 0\n ) {\n meeting.fetchMeetingInfoTimeoutId = setTimeout(\n () => meeting.fetchMeetingInfo(meetingInfoOptions),\n waitingTime\n );\n meeting.parseMeetingInfo(undefined, destination);\n } else {\n await meeting.fetchMeetingInfo(meetingInfoOptions);\n }\n } catch (err) {\n if (\n !(err instanceof CaptchaError) &&\n !(err instanceof PasswordError) &&\n !(err instanceof PermissionError)\n ) {\n LoggerProxy.logger.info(\n `Meetings:index#createMeeting --> Info Unable to fetch meeting info for ${destination}.`\n );\n if (failOnMissingMeetingInfo) {\n LoggerProxy.logger.info(\n `Meetings:index#createMeeting --> Destroying meeting due to missing meeting info.`\n );\n // @ts-ignore\n this.destroy(meeting, MEETING_REMOVED_REASON.MISSING_MEETING_INFO);\n throw new NoMeetingInfoError();\n }\n // if there is no meeting info and no error should be thrown then we assume its a 1:1 call or wireless share\n LoggerProxy.logger.info(\n 'Meetings:index#createMeeting --> Info assuming this destination is a 1:1 or wireless share'\n );\n }\n LoggerProxy.logger.debug(\n `Meetings:index#createMeeting --> Debug ${err} fetching /meetingInfo for creation.`\n );\n } finally {\n // For type LOCUS_ID we need to parse the locus object to get the information\n // about the caller and callee\n // Meeting Added event will be created in `handleLocusEvent`\n if (type !== _LOCUS_ID_) {\n if (!meeting.sipUri) {\n meeting.setSipUri(destination);\n }\n\n // TODO: check if we have to move this to parser\n const meetingAddedType = MeetingsUtil.getMeetingAddedType(type);\n\n // We typically shouldn't need to trigger both and event and return a promise.\n // Is this a special case? We want to make the public API usage as simple as possible.\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'createMeeting',\n },\n EVENT_TRIGGERS.MEETING_ADDED,\n {\n meeting,\n type: meetingAddedType,\n }\n );\n }\n }\n\n return meeting;\n\n // Create the meeting calling the necessary service endpoints.\n\n // Internally, there are many more destinations:\n //\n // - locusID\n // - meetingURL\n // - globalMeetingID, e.g, *00*meetingID\n // - meetingID\n // - meetingURL\n // - PSTN\n // - phone number\n //\n // Our job is to determine the appropriate one\n // and its corresponding service so that developers\n // need only sipURL to get a meeting\n // and its ID, but have the option to use createWithType()\n // and specify those types to get meetingInfo\n }\n\n /**\n * get a specifc meeting given it's type matched to the value, i.e., locus url\n * @param {String} type\n * @param {Object} value\n * @returns {Meeting}\n * @public\n * @memberof Meetings\n */\n public getMeetingByType(type: string, value: object) {\n return this.meetingCollection.getByKey(type, value);\n }\n\n /**\n * Get all meetings.\n * @param {object} options\n * @param {object} options.startDate - get meetings after this start date\n * @param {object} options.endDate - get meetings before this end date\n * @returns {Object} All currently active meetings.\n * @public\n * @memberof Meetings\n */\n public getAllMeetings(\n options: {\n startDate: object;\n endDate: object;\n } = {} as any\n ) {\n // Options may include other parameters to filter this collection\n // of meetings.\n return this.meetingCollection.getAll(options);\n }\n\n /**\n * syncs all the meeting from server\n * @param {boolean} keepOnlyLocusMeetings - whether the sync should keep only locus meetings or any other meeting in meetingCollection\n * @returns {Promise<void>}\n * @public\n * @memberof Meetings\n */\n public syncMeetings({keepOnlyLocusMeetings = true} = {}): Promise<void> {\n return this.request\n .getActiveMeetings()\n .then((locusArray) => {\n const activeLocusUrl = [];\n\n if (locusArray?.loci && locusArray.loci.length > 0) {\n const lociToUpdate = this.sortLocusArrayToUpdate(locusArray.loci);\n lociToUpdate.forEach((locus) => {\n activeLocusUrl.push(locus.url);\n this.handleLocusEvent({\n locus,\n locusUrl: locus.url,\n });\n });\n }\n const meetingsCollection = this.meetingCollection.getAll();\n\n if (Object.keys(meetingsCollection).length > 0) {\n // Sometimes the mercury events are lost after mercury reconnect\n // Remove any Locus meetings that are not returned by Locus\n // (they had a locusUrl previously but are no longer active) in the sync\n for (const meeting of Object.values(meetingsCollection)) {\n // @ts-ignore\n const {locusUrl} = meeting;\n if ((keepOnlyLocusMeetings || locusUrl) && !activeLocusUrl.includes(locusUrl)) {\n // destroy function also uploads logs\n // @ts-ignore\n this.destroy(meeting, MEETING_REMOVED_REASON.NO_MEETINGS_TO_SYNC);\n }\n }\n }\n })\n .catch((error) => {\n LoggerProxy.logger.error(\n `Meetings:index#syncMeetings --> failed to sync meetings, ${error}`\n );\n throw new Error(error);\n });\n }\n\n /**\n * sort out locus array for initial creating\n * @param {Array} loci original locus array\n * @returns {undefined}\n * @public\n * @memberof Meetings\n */\n sortLocusArrayToUpdate(loci: any[]) {\n const mainLoci = loci.filter((locus) => !MeetingsUtil.isBreakoutLocusDTO(locus));\n const breakoutLoci = loci.filter((locus) => MeetingsUtil.isValidBreakoutLocus(locus));\n this.breakoutLocusForHandleLater = [];\n const lociToUpdate = [...mainLoci];\n breakoutLoci.forEach((breakoutLocus) => {\n const associateMainLocus = mainLoci.find(\n (mainLocus) => mainLocus.controls?.breakout?.url === breakoutLocus.controls?.breakout?.url\n );\n const existCorrespondingMeeting = this.getCorrespondingMeetingByLocus({\n locus: breakoutLocus,\n locusUrl: breakoutLocus.url,\n });\n\n if (associateMainLocus && !existCorrespondingMeeting) {\n // if exists both main session and breakout session locus of the same non-exist meeting, handle main locus first,\n // after meeting create with main locus, then handle the associate breakout locus.\n // if only handle breakout locus, will miss some date\n this.breakoutLocusForHandleLater.push(breakoutLocus);\n } else {\n lociToUpdate.push(breakoutLocus);\n }\n });\n\n return lociToUpdate;\n }\n\n /**\n * check breakout locus which waiting for main locus's meeting to be created, then handle the breakout locus\n * @param {Object} newCreatedLocus the locus which just create meeting object of it\n * @returns {undefined}\n * @public\n * @memberof Meetings\n */\n checkHandleBreakoutLocus(newCreatedLocus) {\n if (\n !newCreatedLocus ||\n !this.breakoutLocusForHandleLater ||\n !this.breakoutLocusForHandleLater.length\n ) {\n return;\n }\n if (MeetingsUtil.isBreakoutLocusDTO(newCreatedLocus)) {\n return;\n }\n const existIndex = this.breakoutLocusForHandleLater.findIndex(\n (breakoutLocus) =>\n breakoutLocus.controls?.breakout?.url === newCreatedLocus.controls?.breakout?.url\n );\n\n if (existIndex < 0) {\n return;\n }\n\n const associateBreakoutLocus = this.breakoutLocusForHandleLater[existIndex];\n this.handleLocusEvent({locus: associateBreakoutLocus, locusUrl: associateBreakoutLocus.url});\n this.breakoutLocusForHandleLater.splice(existIndex, 1);\n }\n\n /**\n * Get all scheduled meetings.\n * @param {object} options\n * @param {object} options.startDate - get meetings after this start date\n * @param {object} options.endDate - get meetings before this end date\n * @returns {Object} All scheduled meetings.\n * @memberof Meetings\n */\n getScheduledMeetings() {\n return this.meetingCollection.getAll({scheduled: true});\n }\n\n /**\n * Get the logger instance for plugin-meetings\n * @returns {Logger}\n */\n getLogger() {\n return LoggerProxy.get();\n }\n\n /**\n * Returns the first meeting it finds that has the webrtc media connection created.\n * Useful for debugging in the console.\n *\n * @private\n * @returns {Meeting} Meeting object that has a webrtc media connection, else undefined\n */\n getActiveWebrtcMeeting() {\n return this.meetingCollection.getActiveWebrtcMeeting();\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["mediaLogger","MediaLogger","LoggerProxy","logger","info","log","error","warn","trace","debug","Meetings","args","MEETINGS","options","authToken","webex","credentials","supertoken","access_token","mediaHelpersModule","NoiseReductionEffect","VirtualBackgroundEffect","mediaHelpers","request","Request","parent","loggerRequest","LoggerRequest","meetingCollection","MeetingCollection","personalMeetingRoom","reachability","Reachability","registered","preferredWebexSite","media","getUserMedia","Media","onReady","meeting","newLocus","breakoutUrl","controls","breakout","url","breakoutLocus","getActiveBreakoutLocus","isSelfJoined","self","state","_JOINED_","isSelfMoved","_LEFT_","reason","_MOVED_","deviceFromNewLocus","MeetingsUtil","getThisDevice","internal","device","isResourceMovedOnThisDevice","isNewLocusJoinThisDevice","joinedOnThisDevice","isBreakoutLocusJoinThisDevice","joinedWith","correlationId","breakoutReplaceAt","replaces","length","replaceAt","newLocusReplaceAt","removed","isNewLocusAsBreakout","isBreakoutLocusDTO","fullState","active","isNeedHandleMainLocus","data","getByKey","LOCUS_URL","locusUrl","CORRELATION_ID","checkForCorrelationId","locus","SIP_URI","callbackInfo","callbackAddress","isUnifiedSpaceMeeting","undefined","CONVERSATION_URL","conversationUrl","MEETINGNUMBER","webExMeetingId","useRandomDelayForInfo","getCorrespondingMeetingByLocus","locusInfo","updateMainSessionLocusCache","isNeedHandleLocusDTO","LOCUS","STATE","INACTIVE","create","_LOCUS_ID_","then","newMeeting","initialSetup","checkHandleBreakoutLocus","catch","e","finally","getMeetingByType","_ID_","id","newMetrics","submitClientEvent","name","payload","trigger","meetingId","Trigger","file","function","EVENT_TRIGGERS","MEETING_ADDED","type","_MEETING_","_JOIN_","_INCOMING_","parse","envelope","eventType","LOCUSEVENT","MESSAGE_ROAP","handleLocusEvent","MEETINGS_NETWORK_DISCONNECTED","mercury","on","LOCUS_MERCURY","handleLocusMercury","ROAP","ROAP_MERCURY","handleRoapMercury","ONLINE","syncMeetings","keepOnlyLocusMeetings","OFFLINE","handleMercuryOffline","off","once","READY","StaticConfig","set","config","LoggerConfig","logging","setLogger","meetingInfo","experimental","enableUnifiedMeetings","MeetingInfoV2","MeetingInfo","PersonalMeetingRoom","MEETINGS_READY","checkH264Support","disableNotifications","Metrics","changeState","enableAdhocMeetings","newValue","enableTcpReachability","sendBehavioralMetric","BEHAVIORAL_METRICS","MEETINGS_REGISTRATION_STEP","step","canAuthorize","reject","Error","resolve","all","fetchUserPreferredWebexSite","getGeoHint","startReachability","message","register","connect","call","listenForEvents","MEETINGS_REGISTERED","MEETINGS_REGISTRATION_SUCCESS","MEETINGS_REGISTRATION_FAILED","stack","stopListeningForEvents","disconnect","unregister","MEETINGS_UNREGISTERED","uploadLogs","uploadResult","UPLOAD_LOGS_SUCCESS","MEETING_LOG_UPLOAD_SUCCESS","details","uploadError","MEETING_LOG_UPLOAD_FAILURE","UPLOAD_LOGS_FAILURE","code","getReachability","gatherReachability","fetchGeoHint","res","geoHintInfo","getMeetingPreferences","parseDefaultSiteFromMeetingPreferences","user","get","userPreferences","userPreferencesItems","preferredWebExSite","MeetingUtil","cleanUp","delete","MEETING_REMOVED","destination","infoExtraParams","failOnMissingMeetingInfo","callStateForMetrics","meetingLookupUrl","fetchInfoOptions","SpaceIDDeprecatedError","targetDest","_CONVERSATION_URL_","foundMeeting","foundMeetingIsNotCalendarMeeting","scheduledMeeting","createMeeting","createdMeeting","EVENTS","DESTROY_MEETING","autoUploadLogs","callStart","lastActive","locussessionid","sessionId","feedbackId","locusId","autoupload","destroy","REQUEST_UPLOAD_LOGS","meetingInstance","setCallStateForMetrics","Meeting","userId","deviceUrl","orgId","meetingInfoProvider","destinationType","waitingTime","startTime","startTimeDate","Date","startTimeDatestamp","getTime","timeToStart","maxWaitingTime","Math","max","min","MAX_RANDOM_DELAY_FOR_MEETING_INFO","round","random","isMeetingActive","meetingInfoOptions","extraParams","sendCAevents","injectMeetingInfo","fetchMeetingInfoTimeoutId","setTimeout","fetchMeetingInfo","parseMeetingInfo","CaptchaError","PasswordError","PermissionError","MEETING_REMOVED_REASON","MISSING_MEETING_INFO","NoMeetingInfoError","sipUri","setSipUri","meetingAddedType","getMeetingAddedType","value","getAll","isUnverifiedGuest","getActiveMeetings","locusArray","activeLocusUrl","loci","lociToUpdate","sortLocusArrayToUpdate","forEach","push","meetingsCollection","includes","NO_MEETINGS_TO_SYNC","mainLoci","filter","breakoutLoci","isValidBreakoutLocus","breakoutLocusForHandleLater","associateMainLocus","find","mainLocus","existCorrespondingMeeting","newCreatedLocus","existIndex","findIndex","associateBreakoutLocus","splice","scheduled","getActiveWebrtcMeeting","WebexPlugin"],"sources":["index.ts"],"sourcesContent":["/* eslint no-shadow: [\"error\", { \"allow\": [\"eventType\"] }] */\n\nimport '@webex/internal-plugin-mercury';\nimport '@webex/internal-plugin-conversation';\nimport '@webex/internal-plugin-metrics';\n// @ts-ignore\nimport {WebexPlugin} from '@webex/webex-core';\nimport {setLogger} from '@webex/internal-media-core';\n\nimport * as mediaHelpersModule from '@webex/media-helpers';\n\nimport 'webrtc-adapter';\n\nimport Metrics from '../metrics';\nimport LoggerConfig from '../common/logs/logger-config';\nimport StaticConfig from '../common/config';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport LoggerRequest from '../common/logs/request';\nimport Trigger from '../common/events/trigger-proxy';\nimport Media from '../media';\nimport MeetingUtil from '../meeting/util';\nimport {\n MEETINGS,\n EVENTS,\n EVENT_TRIGGERS,\n READY,\n LOCUSEVENT,\n LOCUS_URL,\n MAX_RANDOM_DELAY_FOR_MEETING_INFO,\n ROAP,\n ONLINE,\n OFFLINE,\n _MEETING_,\n _JOIN_,\n _LOCUS_ID_,\n _INCOMING_,\n LOCUS,\n CORRELATION_ID,\n SIP_URI,\n _LEFT_,\n _ID_,\n MEETING_REMOVED_REASON,\n _CONVERSATION_URL_,\n CONVERSATION_URL,\n MEETINGNUMBER,\n _JOINED_,\n _MOVED_,\n} from '../constants';\nimport BEHAVIORAL_METRICS from '../metrics/constants';\nimport MeetingInfo from '../meeting-info';\nimport MeetingInfoV2 from '../meeting-info/meeting-info-v2';\nimport Meeting, {CallStateForMetrics} from '../meeting';\nimport PersonalMeetingRoom from '../personal-meeting-room';\nimport Reachability from '../reachability';\nimport Request from './request';\nimport PasswordError from '../common/errors/password-error';\nimport CaptchaError from '../common/errors/captcha-error';\n\nimport MeetingCollection from './collection';\nimport MeetingsUtil from './util';\nimport PermissionError from '../common/errors/permission';\nimport {INoiseReductionEffect, IVirtualBackgroundEffect} from './meetings.types';\nimport {SpaceIDDeprecatedError} from '../common/errors/webex-errors';\nimport NoMeetingInfoError from '../common/errors/no-meeting-info';\n\nlet mediaLogger;\n\nclass MediaLogger {\n info(...args) {\n LoggerProxy.logger.info(...args);\n }\n\n log(...args) {\n LoggerProxy.logger.log(...args);\n }\n\n error(...args) {\n LoggerProxy.logger.error(...args);\n }\n\n warn(...args) {\n LoggerProxy.logger.warn(...args);\n }\n\n trace(...args) {\n LoggerProxy.logger.trace(...args);\n }\n\n debug(...args) {\n LoggerProxy.logger.debug(...args);\n }\n}\n/**\n * Meetings Ready Event\n * Emitted when the meetings instance on webex is ready\n * @event meetings:ready\n * @instance\n * @memberof Meetings\n */\n\n/**\n * Meetings Network Disconnected Event\n * Emitted when the meetings instance is disconnected from\n * the internal mercury server\n * @event network:disconnected\n * @instance\n * @memberof Meetings\n */\n\n/**\n * Meetings Registered Event\n * Emitted when the meetings instance has been registered and listening\n * @event meetings:registered\n * @instance\n * @memberof Meetings\n */\n\n/**\n * Meeting Removed Event\n * Emitted when a meeting was removed from the cache of meetings\n * @event meeting:removed\n * @instance\n * @type {Object}\n * @property {String} meetingId the removed meeting\n * @property {Object} response the server response\n * @property {String} type what type of meeting it was\n * @memberof Meetings\n */\n\n/**\n * Meeting Added Event\n * Emitted when a meeting was added to the cache of meetings\n * @event meeting:added\n * @instance\n * @type {Object}\n * @property {String} meetingId the added meeting\n * @property {String} type what type of meeting it was\n * @memberof Meetings\n */\n\n/**\n * Maintain a cache of meetings and sync with services.\n * @class\n */\nexport default class Meetings extends WebexPlugin {\n loggerRequest: any;\n media: any;\n meetingCollection: any;\n personalMeetingRoom: any;\n preferredWebexSite: any;\n reachability: Reachability;\n registered: any;\n request: any;\n geoHintInfo: any;\n meetingInfo: any;\n mediaHelpers: any;\n breakoutLocusForHandleLater: any;\n namespace = MEETINGS;\n\n /**\n * Initializes the Meetings Plugin\n * @constructor\n * @public\n * @memberof Meetings\n */\n constructor(...args) {\n super(...args);\n\n /**\n * The webrtc-core media helpers. This is a temporary solution required for the SDK sample app\n * to be able to call media helper functions.\n *\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n this.mediaHelpers = mediaHelpersModule;\n\n /**\n * The Meetings request to interact with server\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.request = new Request({}, {parent: this.webex});\n /**\n * Log upload request helper\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.loggerRequest = new LoggerRequest({webex: this.webex});\n this.meetingCollection = new MeetingCollection();\n /**\n * The PersonalMeetingRoom object to interact with server\n * @instance\n * @type {Object}\n * @public\n * @memberof Meetings\n */\n this.personalMeetingRoom = null;\n\n /**\n * The Reachability object to interact with server\n * starts as null\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.reachability = new Reachability(this.webex);\n\n /**\n * If the meetings plugin has been registered and listening via {@link Meetings#register}\n * @instance\n * @type {Boolean}\n * @public\n * @memberof Meetings\n */\n this.registered = false;\n\n /**\n * This values indicates the preferred webex site the user will start there meeting, getsits value from {@link Meetings#register}\n * @instance\n * @type {String}\n * @private\n * @memberof Meetings\n */\n this.preferredWebexSite = '';\n\n /**\n * The public interface for the internal Media util files. These are helpful to expose outside the context\n * of a meeting so that a user can access media without creating a meeting instance.\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n this.media = {\n getUserMedia: Media.getUserMedia,\n };\n\n this.onReady();\n }\n\n /**\n * check whether you need to handle this main session's locus data or not\n * @param {Object} meeting current meeting data\n * @param {Object} newLocus new locus data\n * @returns {boolean}\n * @private\n * @memberof Meetings\n */\n private isNeedHandleMainLocus(meeting: any, newLocus: any) {\n const breakoutUrl = newLocus.controls?.breakout?.url;\n const breakoutLocus = this.meetingCollection.getActiveBreakoutLocus(breakoutUrl);\n\n const isSelfJoined = newLocus?.self?.state === _JOINED_;\n const isSelfMoved = newLocus?.self?.state === _LEFT_ && newLocus?.self?.reason === _MOVED_;\n // @ts-ignore\n const deviceFromNewLocus = MeetingsUtil.getThisDevice(newLocus, this.webex.internal.device.url);\n const isResourceMovedOnThisDevice =\n deviceFromNewLocus?.state === _LEFT_ && deviceFromNewLocus?.reason === _MOVED_;\n\n const isNewLocusJoinThisDevice = MeetingsUtil.joinedOnThisDevice(\n meeting,\n newLocus,\n // @ts-ignore\n this.webex.internal.device.url\n );\n const isBreakoutLocusJoinThisDevice =\n breakoutLocus?.joinedWith?.correlationId &&\n breakoutLocus.joinedWith.correlationId === meeting?.correlationId;\n\n if (isSelfJoined && isNewLocusJoinThisDevice) {\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> self this device shown as JOINED in the main session'\n );\n if (breakoutLocus?.joinedWith && deviceFromNewLocus) {\n const breakoutReplaceAt =\n breakoutLocus.joinedWith.replaces?.length > 0\n ? breakoutLocus.joinedWith.replaces[0].replaceAt\n : '';\n const newLocusReplaceAt =\n deviceFromNewLocus.replaces?.length > 0 ? deviceFromNewLocus.replaces[0].replaceAt : '';\n if (breakoutReplaceAt && newLocusReplaceAt && breakoutReplaceAt > newLocusReplaceAt) {\n LoggerProxy.logger.log(\n `Meetings:index#isNeedHandleMainLocus --> this is expired main joined status locus_dto replacedAt ${newLocusReplaceAt} bo replacedAt ${breakoutReplaceAt}`\n );\n\n return false;\n }\n }\n\n return true;\n }\n if (isBreakoutLocusJoinThisDevice) {\n LoggerProxy.logger.log(\n `Meetings:index#isNeedHandleMainLocus --> there is active breakout session and joined on this device, and don't need to handle main session: ${breakoutUrl}`\n );\n\n return false;\n }\n if (isSelfMoved && (newLocus?.self?.removed || isResourceMovedOnThisDevice)) {\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> self moved main locus with self removed status or with device resource moved, not need to handle'\n );\n\n return false;\n }\n if (isSelfJoined && isResourceMovedOnThisDevice) {\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> self device left&moved in main locus with self joined status, not need to handle'\n );\n\n return false;\n }\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> this is a normal main session locusDTO update case'\n );\n\n return true;\n }\n\n /**\n * check whether you need to handle this locus data or not\n * @param {Object} meeting old locus data\n * @param {Object} newLocus new locus data\n * @returns {boolean}\n * @private\n * @memberof Meetings\n */\n private isNeedHandleLocusDTO(meeting: any, newLocus: any) {\n if (newLocus) {\n const isNewLocusAsBreakout = MeetingsUtil.isBreakoutLocusDTO(newLocus);\n const isSelfMoved = newLocus?.self?.state === _LEFT_ && newLocus?.self?.reason === _MOVED_;\n if (!meeting) {\n if (isNewLocusAsBreakout) {\n LoggerProxy.logger.log(\n `Meetings:index#isNeedHandleLocusDTO --> the first breakout session locusDTO active status: ${newLocus.fullState?.active}`\n );\n\n return newLocus.self?.state === _JOINED_;\n }\n\n return this.isNeedHandleMainLocus(meeting, newLocus);\n }\n if (!isNewLocusAsBreakout) {\n return this.isNeedHandleMainLocus(meeting, newLocus);\n }\n\n return !isSelfMoved;\n }\n\n return true;\n }\n\n /**\n * get corresponding meeting object by locus data\n * @param {Object} data a locus event\n * @param {String} data.locusUrl\n * @param {Object} data.locus\n * @returns {Object}\n * @private\n * @memberof Meetings\n */\n getCorrespondingMeetingByLocus(data) {\n // getting meeting by correlationId. This will happen for the new event\n // Either the locus\n // TODO : Add check for the callBack Address\n return (\n this.meetingCollection.getByKey(LOCUS_URL, data.locusUrl) ||\n // @ts-ignore\n this.meetingCollection.getByKey(\n CORRELATION_ID,\n // @ts-ignore\n MeetingsUtil.checkForCorrelationId(this.webex.internal.device.url, data.locus)\n ) ||\n this.meetingCollection.getByKey(\n SIP_URI,\n data.locus.self &&\n data.locus.self.callbackInfo &&\n data.locus.self.callbackInfo.callbackAddress\n ) ||\n (data.locus.info?.isUnifiedSpaceMeeting\n ? undefined\n : this.meetingCollection.getByKey(CONVERSATION_URL, data.locus.conversationUrl)) ||\n this.meetingCollection.getByKey(MEETINGNUMBER, data.locus?.info?.webExMeetingId)\n );\n }\n\n /**\n * handle locus events and takes meeting actions with them as they come in\n * @param {Object} data a locus event\n * @param {String} data.locusUrl\n * @param {Object} data.locus\n * @param {Boolean} useRandomDelayForInfo whether a random delay should be added to fetching meeting info\n * @param {String} data.eventType\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private handleLocusEvent(data: {locusUrl: string; locus: any}, useRandomDelayForInfo = false) {\n let meeting = this.getCorrespondingMeetingByLocus(data);\n\n // Special case when locus has got replaced, This only happend once if a replace locus exists\n // https://sqbu-github.cisco.com/WebExSquared/locus/wiki/Locus-changing-mid-call\n\n if (!meeting && data.locus?.replaces?.length > 0) {\n // Always the last element in the replace is the active one\n meeting = this.meetingCollection.getByKey(\n LOCUS_URL,\n data.locus.replaces[data.locus.replaces.length - 1].locusUrl\n );\n }\n\n if (meeting && !MeetingsUtil.isBreakoutLocusDTO(data.locus)) {\n meeting.locusInfo.updateMainSessionLocusCache(data.locus);\n }\n if (!this.isNeedHandleLocusDTO(meeting, data.locus)) {\n LoggerProxy.logger.log(\n `Meetings:index#handleLocusEvent --> doesn't need to process locus event`\n );\n\n return;\n }\n if (!meeting) {\n // TODO: create meeting when we get a meeting object\n // const checkForEnded = (locus) => {\n // TODO: you already ended the meeting but you got an event later\n // Mainly for 1:1 Callsor meeting\n // Happens mainly after refresh\n\n // 1:1 Meeting\n // 1) You ended a call before but you got a mercury event\n // Make sure end the call and cleanup the meeting only if the mercury\n // event says so\n // 2) Maintain lastSync time in the meetings object which helps to compare\n // If the meeting came befor or after the sync . ANy meeting start time before the sync time is invalid\n\n // For space Meeting\n // Check the locus object and see who has joined\n\n // };\n // rather then locus object change to locus url\n\n if (\n data.locus &&\n data.locus.fullState &&\n data.locus.fullState.state === LOCUS.STATE.INACTIVE\n ) {\n // just ignore the event as its already ended and not active\n LoggerProxy.logger.warn(\n 'Meetings:index#handleLocusEvent --> Locus event received for meeting, after it was ended.'\n );\n\n return;\n }\n\n // When its wireless share or guest and user leaves the meeting we dont have to keep the meeting object\n // Any future events will be neglected\n\n if (\n data.locus &&\n data.locus.self &&\n data.locus.self.state === _LEFT_ &&\n data.locus.self.removed === true\n ) {\n // just ignore the event as its already ended and not active\n LoggerProxy.logger.warn(\n 'Meetings:index#handleLocusEvent --> Locus event received for meeting, after it was ended.'\n );\n\n return;\n }\n\n this.create(data.locus, _LOCUS_ID_, useRandomDelayForInfo)\n .then((newMeeting) => {\n meeting = newMeeting;\n\n // It's a new meeting so initialize the locus data\n meeting.locusInfo.initialSetup(data.locus);\n this.checkHandleBreakoutLocus(data.locus);\n })\n .catch((e) => {\n LoggerProxy.logger.error(e);\n })\n .finally(() => {\n // There will be cases where locus event comes in gets created and deleted because its a 1:1 and meeting gets deleted\n // because the other user left so before sending 'added' event make sure it exists in the collection\n\n if (this.getMeetingByType(_ID_, meeting.id)) {\n // @ts-ignore\n this.webex.internal.newMetrics.submitClientEvent({\n name: 'client.call.remote-started',\n payload: {\n trigger: 'mercury-event',\n },\n options: {\n meetingId: meeting.id,\n },\n });\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'handleLocusEvent',\n },\n EVENT_TRIGGERS.MEETING_ADDED,\n {\n meeting,\n type: meeting.type === _MEETING_ ? _JOIN_ : _INCOMING_,\n }\n );\n } else {\n // Meeting got added but was not found in the collection. It might have got destroyed\n LoggerProxy.logger.warn(\n 'Meetings:index#handleLocusEvent --> Created and destroyed meeting object before sending an event'\n );\n }\n });\n } else {\n meeting.locusInfo.parse(meeting, data);\n }\n }\n\n /**\n * handles locus events through mercury that are not roap\n * @param {Object} envelope\n * @param {Object} envelope.data\n * @param {String} envelope.data.eventType\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private handleLocusMercury(envelope: {data: any}) {\n const {data} = envelope;\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const {eventType} = data;\n\n if (eventType && eventType !== LOCUSEVENT.MESSAGE_ROAP) {\n this.handleLocusEvent(data, true);\n }\n }\n\n /**\n * handles mecury offline event\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private handleMercuryOffline() {\n Trigger.trigger(\n this,\n {\n file: 'meetings/index',\n function: 'handleMercuryOffline',\n },\n EVENT_TRIGGERS.MEETINGS_NETWORK_DISCONNECTED\n );\n }\n\n /**\n * registers for locus and roap mercury events\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private listenForEvents() {\n // @ts-ignore\n this.webex.internal.mercury.on(LOCUSEVENT.LOCUS_MERCURY, (envelope) => {\n this.handleLocusMercury(envelope);\n });\n // @ts-ignore\n this.webex.internal.mercury.on(ROAP.ROAP_MERCURY, (envelope) => {\n MeetingsUtil.handleRoapMercury(envelope, this.meetingCollection);\n });\n\n // @ts-ignore\n this.webex.internal.mercury.on(ONLINE, () => {\n this.syncMeetings({keepOnlyLocusMeetings: false});\n });\n\n // @ts-ignore\n this.webex.internal.mercury.on(OFFLINE, () => {\n this.handleMercuryOffline();\n });\n }\n\n /**\n * stops listening for locus and roap mercury events\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private stopListeningForEvents() {\n // @ts-ignore\n this.webex.internal.mercury.off(LOCUSEVENT.LOCUS_MERCURY);\n // @ts-ignore\n this.webex.internal.mercury.off(ROAP.ROAP_MERCURY);\n // @ts-ignore\n this.webex.internal.mercury.off(ONLINE);\n }\n\n /**\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private onReady() {\n // @ts-ignore\n this.webex.once(READY, () => {\n // @ts-ignore\n StaticConfig.set(this.config);\n // @ts-ignore\n LoggerConfig.set(this.config.logging);\n // @ts-ignore\n LoggerProxy.set(this.webex.logger);\n\n mediaLogger = new MediaLogger();\n setLogger(mediaLogger);\n\n /**\n * The MeetingInfo object to interact with server\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.meetingInfo = this.config.experimental.enableUnifiedMeetings\n ? // @ts-ignore\n new MeetingInfoV2(this.webex)\n : // @ts-ignore\n new MeetingInfo(this.webex);\n // @ts-ignore\n this.personalMeetingRoom = new PersonalMeetingRoom(\n {meetingInfo: this.meetingInfo},\n // @ts-ignore\n {parent: this.webex}\n );\n\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'onReady',\n },\n EVENT_TRIGGERS.MEETINGS_READY\n );\n\n MeetingsUtil.checkH264Support({disableNotifications: true});\n // @ts-ignore\n Metrics.initialSetup(this.webex);\n });\n }\n\n /**\n * API to toggle unified meetings\n * @param {Boolean} changeState\n * @private\n * @memberof Meetings\n * @returns {undefined}\n */\n private _toggleUnifiedMeetings(changeState: boolean) {\n if (typeof changeState !== 'boolean') {\n return;\n }\n // @ts-ignore\n if (this.config?.experimental?.enableUnifiedMeetings !== changeState) {\n // @ts-ignore\n this.config.experimental.enableUnifiedMeetings = changeState;\n // @ts-ignore\n this.meetingInfo = changeState ? new MeetingInfoV2(this.webex) : new MeetingInfo(this.webex);\n }\n }\n\n /**\n * API to toggle starting adhoc meeting\n * @param {Boolean} changeState\n * @private\n * @memberof Meetings\n * @returns {undefined}\n */\n private _toggleAdhocMeetings(changeState: boolean) {\n if (typeof changeState !== 'boolean') {\n return;\n }\n // @ts-ignore\n if (this.config?.experimental?.enableAdhocMeetings !== changeState) {\n // @ts-ignore\n this.config.experimental.enableAdhocMeetings = changeState;\n }\n }\n\n /**\n * API to toggle TCP reachability, needs to be called before webex.meetings.register()\n * @param {Boolean} newValue\n * @private\n * @memberof Meetings\n * @returns {undefined}\n */\n private _toggleTcpReachability(newValue: boolean) {\n if (typeof newValue !== 'boolean') {\n return;\n }\n // @ts-ignore\n if (this.config.experimental.enableTcpReachability !== newValue) {\n // @ts-ignore\n this.config.experimental.enableTcpReachability = newValue;\n }\n }\n\n /**\n * Explicitly sets up the meetings plugin by registering\n * the device, connecting to mercury, and listening for locus events.\n *\n * @returns {Promise}\n * @public\n * @memberof Meetings\n */\n public register() {\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_STEP, {\n step: '[sdk] begin registration',\n });\n\n // @ts-ignore\n if (!this.webex.canAuthorize) {\n LoggerProxy.logger.error(\n 'Meetings:index#register --> ERROR, Unable to register, SDK cannot authorize'\n );\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_STEP, {\n step: '[sdk] cannot authorize',\n });\n\n return Promise.reject(new Error('SDK cannot authorize'));\n }\n\n if (this.registered) {\n LoggerProxy.logger.info(\n 'Meetings:index#register --> INFO, Meetings plugin already registered'\n );\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_STEP, {\n step: '[sdk] already registered',\n });\n\n return Promise.resolve();\n }\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_STEP, {\n step: '[sdk] begin Promise.all()',\n });\n\n return Promise.all([\n this.fetchUserPreferredWebexSite(),\n this.getGeoHint(),\n this.startReachability().catch((error) => {\n LoggerProxy.logger.error(`Meetings:index#register --> GDM error, ${error.message}`);\n }),\n // @ts-ignore\n this.webex.internal.device\n .register()\n // @ts-ignore\n .then(() =>\n LoggerProxy.logger.info(\n // @ts-ignore\n `Meetings:index#register --> INFO, Device registered ${this.webex.internal.device.url}`\n )\n )\n // @ts-ignore\n .then(() => this.webex.internal.mercury.connect()),\n MeetingsUtil.checkH264Support.call(this),\n ])\n .then(() => {\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_STEP, {\n step: '[sdk] end Promise.all()',\n });\n this.listenForEvents();\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'register',\n },\n EVENT_TRIGGERS.MEETINGS_REGISTERED\n );\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_STEP, {\n step: '[sdk] registration complete, triggered MEETINGS_REGISTERED event',\n });\n this.registered = true;\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_SUCCESS);\n })\n .catch((error) => {\n LoggerProxy.logger.error(\n `Meetings:index#register --> ERROR, Unable to register, ${error.message}`\n );\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_FAILED, {\n reason: error.message,\n stack: error.stack,\n });\n\n return Promise.reject(error);\n });\n }\n\n /**\n * Explicitly tears down the meetings plugin by deregistering\n * the device, disconnecting from mercury, and stops listening to locus events\n *\n * @returns {Promise}\n * @public\n * @memberof Meetings\n */\n unregister() {\n if (!this.registered) {\n LoggerProxy.logger.info(\n 'Meetings:index#unregister --> INFO, Meetings plugin already unregistered'\n );\n\n return Promise.resolve();\n }\n\n this.stopListeningForEvents();\n\n return (\n // @ts-ignore\n this.webex.internal.mercury\n .disconnect()\n // @ts-ignore\n .then(() => this.webex.internal.device.unregister())\n .then(() => {\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'unregister',\n },\n EVENT_TRIGGERS.MEETINGS_UNREGISTERED\n );\n this.registered = false;\n })\n );\n }\n\n /**\n * Creates a noise reduction effect\n *\n * @param {INoiseReductionEffect} options optional custom effect options\n * @returns {Promise<effect>} noise reduction effect.\n * @public\n * @memberof Meetings\n */\n createNoiseReductionEffect = async (options?: INoiseReductionEffect) => {\n // @ts-ignore\n const authToken = this.webex.credentials.supertoken.access_token;\n\n return new mediaHelpersModule.NoiseReductionEffect({authToken, ...options});\n };\n\n /**\n * Creates a virtual background effect\n *\n * @param {IVirtualBackgroundEffect} options optional custom effect options\n * @returns {Promise<effect>} virtual background effect.\n * @public\n * @memberof Meetings\n */\n createVirtualBackgroundEffect = async (options?: IVirtualBackgroundEffect) => {\n // @ts-ignore\n const authToken = this.webex.credentials.supertoken.access_token;\n\n return new mediaHelpersModule.VirtualBackgroundEffect({authToken, ...options});\n };\n\n /**\n * Uploads logs to the webex services for tracking\n * @param {Object} [options={}]\n * @param {String} [options.callStart] Call Start Time\n * @param {String} [options.feedbackId] ID used for tracking\n * @param {String} [options.locusId]\n * @param {String} [options.correlationId]\n * @param {String} [options.meetingId] webex meeting ID\n * @param {String} [options.userId] userId\n * @param {String} [options.orgId] org id\n * @returns {String} feedback ID logs were submitted under\n */\n uploadLogs(\n options: {\n autoupload?: boolean;\n callStart?: string;\n feedbackId?: string;\n locussessionid?: string;\n locusId?: string;\n correlationId?: string;\n meetingId?: string;\n userId?: string;\n orgId?: string;\n } = {}\n ) {\n LoggerProxy.logger.info('Meetings:index#uploadLogs --> uploading logs');\n\n return this.loggerRequest\n .uploadLogs(options)\n .then((uploadResult) => {\n LoggerProxy.logger.info(\n 'Meetings:index#uploadLogs --> Upload logs for meeting completed.',\n uploadResult\n );\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.UPLOAD_LOGS_SUCCESS, options);\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'uploadLogs',\n },\n EVENT_TRIGGERS.MEETING_LOG_UPLOAD_SUCCESS,\n {\n meetingId: options.meetingId,\n details: uploadResult,\n }\n );\n\n return uploadResult;\n })\n .catch((uploadError) => {\n LoggerProxy.logger.error(\n 'Meetings:index#uploadLogs --> Unable to upload logs for meeting',\n uploadError\n );\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'uploadLogs',\n },\n EVENT_TRIGGERS.MEETING_LOG_UPLOAD_FAILURE,\n {\n meetingId: options.meetingId,\n reason: uploadError,\n }\n );\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.UPLOAD_LOGS_FAILURE, {\n ...options,\n reason: uploadError.message,\n stack: uploadError.stack,\n code: uploadError.code,\n });\n });\n }\n\n /**\n * gets the reachability instance for Meetings\n * @returns {Reachability}\n * @public\n * @memberof Meetings\n */\n getReachability() {\n return this.reachability;\n }\n\n /**\n * initializes and starts gathering reachability for Meetings\n * @returns {Promise}\n * @public\n * @memberof Meetings\n */\n startReachability() {\n return this.getReachability().gatherReachability();\n }\n\n /**\n * Get geoHint for info for meetings\n * @returns {Promise}\n * @private\n * @memberof Meetings\n */\n getGeoHint() {\n return this.request.fetchGeoHint().then((res) => {\n this.geoHintInfo = res;\n });\n }\n\n /**\n * Fetch user preferred webex site information\n * This also has other infomation about the user\n * @returns {Promise}\n * @private\n * @memberof Meetings\n */\n fetchUserPreferredWebexSite() {\n return this.request.getMeetingPreferences().then((res) => {\n if (res) {\n this.preferredWebexSite = MeetingsUtil.parseDefaultSiteFromMeetingPreferences(res);\n }\n\n // fall back to getting the preferred site from the user information\n if (!this.preferredWebexSite) {\n // @ts-ignore\n return this.webex.internal.user\n .get()\n .then((user) => {\n const preferredWebexSite =\n user?.userPreferences?.userPreferencesItems?.preferredWebExSite;\n if (preferredWebexSite) {\n this.preferredWebexSite = preferredWebexSite;\n } else {\n throw new Error('site not found');\n }\n })\n .catch(() => {\n LoggerProxy.logger.error(\n 'Failed to fetch preferred site from user - no site will be set'\n );\n });\n }\n\n return Promise.resolve();\n });\n }\n\n /**\n * gets the personal meeting room instance, for saved PMR values for this user\n * @returns {PersonalMeetingRoom}\n * @public\n * @memberof Meetings\n */\n\n getPersonalMeetingRoom() {\n return this.personalMeetingRoom;\n }\n\n /**\n * @param {Meeting} meeting\n * @param {Object} reason\n * @param {String} type\n * @returns {Undefined}\n * @private\n * @memberof Meetings\n */\n private destroy(meeting: Meeting, reason: object) {\n MeetingUtil.cleanUp(meeting);\n this.meetingCollection.delete(meeting.id);\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'destroy',\n },\n EVENT_TRIGGERS.MEETING_REMOVED,\n {\n meetingId: meeting.id,\n reason,\n }\n );\n }\n\n /**\n * Create a meeting or return an existing meeting.\n *\n * When meeting info passed it should be complete, e.g.: fetched after password or captcha provided\n *\n * @param {string} destination - sipURL, phonenumber, or locus object}\n * @param {string} [type] - the optional specified type, such as locusId\n * @param {Boolean} useRandomDelayForInfo - whether a random delay should be added to fetching meeting info\n * @param {Object} infoExtraParams extra parameters to be provided when fetching meeting info\n * @param {string} correlationId - the optional specified correlationId (callStateForMetrics.correlationId can be provided instead)\n * @param {Boolean} failOnMissingMeetingInfo - whether to throw an error if meeting info fails to fetch (for calls that are not 1:1 or content share)\n * @param {CallStateForMetrics} callStateForMetrics - information about call state for metrics\n * @param {Object} [meetingInfo] - Pre-fetched complete meeting info\n * @param {String} [meetingLookupUrl] - meeting info prefetch url\n * @returns {Promise<Meeting>} A new Meeting.\n * @public\n * @memberof Meetings\n */\n public create(\n destination: string,\n type: string = null,\n useRandomDelayForInfo = false,\n infoExtraParams = {},\n correlationId: string = undefined,\n failOnMissingMeetingInfo = false,\n callStateForMetrics: CallStateForMetrics = undefined,\n meetingInfo = undefined,\n meetingLookupUrl = undefined\n ) {\n // TODO: type should be from a dictionary\n\n // Validate meeting information based on the provided destination and\n // type. This must be performed prior to determining if the meeting is\n // found in the collection, as we mutate the destination for hydra person\n // id values.\n if (correlationId) {\n callStateForMetrics = {...(callStateForMetrics || {}), correlationId};\n }\n\n return (\n this.meetingInfo\n .fetchInfoOptions(destination, type)\n // Catch a failure to fetch info options.\n .catch((error) => {\n LoggerProxy.logger.error(\n `Meetings:index#create --> ERROR, unable to determine info options: ${error.message}`\n );\n if (error instanceof SpaceIDDeprecatedError) {\n throw new SpaceIDDeprecatedError();\n }\n })\n .then((options: any = {}) => {\n // Normalize the destination.\n const targetDest = options.destination || destination;\n\n // check for the conversation URL then sip Url\n let meeting = null;\n\n if (type === _CONVERSATION_URL_ || options.type === _CONVERSATION_URL_) {\n const foundMeeting = this.meetingCollection.getByKey(CONVERSATION_URL, targetDest);\n\n if (foundMeeting) {\n const foundMeetingIsNotCalendarMeeting = !foundMeeting.locusInfo.scheduledMeeting;\n\n // If the found meeting is not a calendar meeting, return that meeting.\n // This allows for the creation of instant-meetings when calendar meetings are present.\n if (foundMeetingIsNotCalendarMeeting) {\n meeting = foundMeeting;\n }\n }\n }\n\n // Attempt to collect the meeting if it exists.\n if (!meeting) {\n meeting = this.meetingCollection.getByKey(SIP_URI, targetDest);\n }\n\n // Validate if a meeting was found.\n if (!meeting) {\n // Create a meeting based on the normalized destination and type.\n return this.createMeeting(\n targetDest,\n type,\n useRandomDelayForInfo,\n infoExtraParams,\n callStateForMetrics,\n failOnMissingMeetingInfo,\n meetingInfo,\n meetingLookupUrl\n ).then((createdMeeting: any) => {\n // If the meeting was successfully created.\n if (createdMeeting && createdMeeting.on) {\n // Create a destruction event for the meeting.\n createdMeeting.on(EVENTS.DESTROY_MEETING, (payload) => {\n // @ts-ignore\n if (this.config.autoUploadLogs) {\n this.uploadLogs({\n callStart: createdMeeting.locusInfo?.fullState?.lastActive,\n locussessionid: createdMeeting.locusInfo?.fullState?.sessionId,\n correlationId: createdMeeting.correlationId,\n feedbackId: createdMeeting.correlationId,\n locusId: createdMeeting.locusId,\n meetingId: createdMeeting.locusInfo?.info?.webExMeetingId,\n autoupload: true,\n }).then(() => this.destroy(createdMeeting, payload.reason));\n } else {\n this.destroy(createdMeeting, payload.reason);\n }\n });\n\n createdMeeting.on(EVENTS.REQUEST_UPLOAD_LOGS, (meetingInstance) => {\n // @ts-ignore\n if (this.config.autoUploadLogs) {\n this.uploadLogs({\n callStart: meetingInstance?.locusInfo?.fullState?.lastActive,\n locussessionid: meetingInstance?.locusInfo?.fullState?.sessionId,\n correlationId: meetingInstance.correlationId,\n feedbackId: meetingInstance.correlationId,\n locusId: meetingInstance.locusId,\n meetingId: meetingInstance.locusInfo?.info?.webExMeetingId,\n autoupload: true,\n });\n }\n });\n } else {\n LoggerProxy.logger.error(\n `Meetings:index#create --> ERROR, meeting does not have on method, will not be destroyed, meeting cleanup impossible for meeting: ${meeting}`\n );\n }\n\n // Return the newly created meeting.\n return Promise.resolve(createdMeeting);\n });\n }\n meeting.setCallStateForMetrics(callStateForMetrics);\n\n // Return the existing meeting.\n return Promise.resolve(meeting);\n })\n );\n }\n\n /**\n * Create meeting\n *\n * When meeting info passed it should be complete, e.g.: fetched after password or captcha provided\n *\n * @param {String} destination see create()\n * @param {String} type see create()\n * @param {Boolean} useRandomDelayForInfo whether a random delay should be added to fetching meeting info\n * @param {Object} infoExtraParams extra parameters to be provided when fetching meeting info\n * @param {CallStateForMetrics} callStateForMetrics - information about call state for metrics\n * @param {Boolean} failOnMissingMeetingInfo - whether to throw an error if meeting info fails to fetch (for calls that are not 1:1 or content share)\n * @param {Object} [meetingInfo] - Pre-fetched complete meeting info\n * @param {String} [meetingLookupUrl] - meeting info prefetch url\n * @returns {Promise} a new meeting instance complete with meeting info and destination\n * @private\n * @memberof Meetings\n */\n private async createMeeting(\n destination: any,\n type: string = null,\n useRandomDelayForInfo = false,\n infoExtraParams = {},\n callStateForMetrics: CallStateForMetrics = undefined,\n failOnMissingMeetingInfo = false,\n meetingInfo = undefined,\n meetingLookupUrl = undefined\n ) {\n const meeting = new Meeting(\n {\n // @ts-ignore\n userId: this.webex.internal.device.userId,\n // @ts-ignore\n deviceUrl: this.webex.internal.device.url,\n // @ts-ignore\n orgId: this.webex.internal.device.orgId,\n locus: type === _LOCUS_ID_ ? destination : null, // pass the locus object if present\n meetingInfoProvider: this.meetingInfo,\n destination,\n destinationType: type,\n callStateForMetrics,\n },\n {\n // @ts-ignore\n parent: this.webex,\n }\n );\n\n this.meetingCollection.set(meeting);\n\n try {\n // if no participant has joined the scheduled meeting (meaning meeting is not active) and we get a locusEvent,\n // it means the meeting will start in 5-6 min. In that case, we want to fetchMeetingInfo\n // between 5 and 2 min (random between 3 minutes) before the meeting starts\n // to avoid a spike in traffic to the wbxappi service\n let waitingTime = 0;\n\n if (destination.meeting) {\n const {startTime} = destination.meeting;\n const startTimeDate = new Date(startTime);\n const startTimeDatestamp = startTimeDate.getTime();\n const timeToStart = startTimeDatestamp - Date.now();\n const maxWaitingTime = Math.max(\n Math.min(timeToStart, MAX_RANDOM_DELAY_FOR_MEETING_INFO),\n 0\n );\n\n waitingTime = Math.round(Math.random() * maxWaitingTime);\n }\n const isMeetingActive = !!destination.fullState?.active;\n // @ts-ignore\n const {enableUnifiedMeetings} = this.config.experimental;\n const meetingInfoOptions = {\n extraParams: infoExtraParams,\n sendCAevents: !!callStateForMetrics?.correlationId, // if client sends correlation id as argument of public create(), then it means that this meeting creation is part of a pre-join intent from user\n };\n\n if (meetingInfo) {\n meeting.injectMeetingInfo(meetingInfo, meetingInfoOptions, meetingLookupUrl);\n } else if (\n enableUnifiedMeetings &&\n !isMeetingActive &&\n useRandomDelayForInfo &&\n waitingTime > 0\n ) {\n meeting.fetchMeetingInfoTimeoutId = setTimeout(\n () => meeting.fetchMeetingInfo(meetingInfoOptions),\n waitingTime\n );\n meeting.parseMeetingInfo(undefined, destination);\n } else {\n await meeting.fetchMeetingInfo(meetingInfoOptions);\n }\n } catch (err) {\n if (\n !(err instanceof CaptchaError) &&\n !(err instanceof PasswordError) &&\n !(err instanceof PermissionError)\n ) {\n LoggerProxy.logger.info(\n `Meetings:index#createMeeting --> Info Unable to fetch meeting info for ${destination}.`\n );\n if (failOnMissingMeetingInfo) {\n LoggerProxy.logger.info(\n `Meetings:index#createMeeting --> Destroying meeting due to missing meeting info.`\n );\n // @ts-ignore\n this.destroy(meeting, MEETING_REMOVED_REASON.MISSING_MEETING_INFO);\n throw new NoMeetingInfoError();\n }\n // if there is no meeting info and no error should be thrown then we assume its a 1:1 call or wireless share\n LoggerProxy.logger.info(\n 'Meetings:index#createMeeting --> Info assuming this destination is a 1:1 or wireless share'\n );\n }\n LoggerProxy.logger.debug(\n `Meetings:index#createMeeting --> Debug ${err} fetching /meetingInfo for creation.`\n );\n } finally {\n // For type LOCUS_ID we need to parse the locus object to get the information\n // about the caller and callee\n // Meeting Added event will be created in `handleLocusEvent`\n if (type !== _LOCUS_ID_) {\n if (!meeting.sipUri) {\n meeting.setSipUri(destination);\n }\n\n // TODO: check if we have to move this to parser\n const meetingAddedType = MeetingsUtil.getMeetingAddedType(type);\n\n // We typically shouldn't need to trigger both and event and return a promise.\n // Is this a special case? We want to make the public API usage as simple as possible.\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'createMeeting',\n },\n EVENT_TRIGGERS.MEETING_ADDED,\n {\n meeting,\n type: meetingAddedType,\n }\n );\n }\n }\n\n return meeting;\n\n // Create the meeting calling the necessary service endpoints.\n\n // Internally, there are many more destinations:\n //\n // - locusID\n // - meetingURL\n // - globalMeetingID, e.g, *00*meetingID\n // - meetingID\n // - meetingURL\n // - PSTN\n // - phone number\n //\n // Our job is to determine the appropriate one\n // and its corresponding service so that developers\n // need only sipURL to get a meeting\n // and its ID, but have the option to use createWithType()\n // and specify those types to get meetingInfo\n }\n\n /**\n * get a specifc meeting given it's type matched to the value, i.e., locus url\n * @param {String} type\n * @param {Object} value\n * @returns {Meeting}\n * @public\n * @memberof Meetings\n */\n public getMeetingByType(type: string, value: object) {\n return this.meetingCollection.getByKey(type, value);\n }\n\n /**\n * Get all meetings.\n * @param {object} options\n * @param {object} options.startDate - get meetings after this start date\n * @param {object} options.endDate - get meetings before this end date\n * @returns {Object} All currently active meetings.\n * @public\n * @memberof Meetings\n */\n public getAllMeetings(\n options: {\n startDate: object;\n endDate: object;\n } = {} as any\n ) {\n // Options may include other parameters to filter this collection\n // of meetings.\n return this.meetingCollection.getAll(options);\n }\n\n /**\n * Syncs all the meetings from server. Does nothing and returns immediately if unverified guest.\n * @param {boolean} keepOnlyLocusMeetings - whether the sync should keep only locus meetings or any other meeting in meetingCollection\n * @returns {Promise<void>}\n * @public\n * @memberof Meetings\n */\n public syncMeetings({keepOnlyLocusMeetings = true} = {}): Promise<void> {\n // @ts-ignore\n if (this.webex.credentials.isUnverifiedGuest) {\n LoggerProxy.logger.info(\n 'Meetings:index#syncMeetings --> skipping meeting sync as unverified guest'\n );\n\n return Promise.resolve();\n }\n\n return this.request\n .getActiveMeetings()\n .then((locusArray) => {\n const activeLocusUrl = [];\n\n if (locusArray?.loci && locusArray.loci.length > 0) {\n const lociToUpdate = this.sortLocusArrayToUpdate(locusArray.loci);\n lociToUpdate.forEach((locus) => {\n activeLocusUrl.push(locus.url);\n this.handleLocusEvent({\n locus,\n locusUrl: locus.url,\n });\n });\n }\n const meetingsCollection = this.meetingCollection.getAll();\n\n if (Object.keys(meetingsCollection).length > 0) {\n // Sometimes the mercury events are lost after mercury reconnect\n // Remove any Locus meetings that are not returned by Locus\n // (they had a locusUrl previously but are no longer active) in the sync\n for (const meeting of Object.values(meetingsCollection)) {\n // @ts-ignore\n const {locusUrl} = meeting;\n if ((keepOnlyLocusMeetings || locusUrl) && !activeLocusUrl.includes(locusUrl)) {\n // destroy function also uploads logs\n // @ts-ignore\n this.destroy(meeting, MEETING_REMOVED_REASON.NO_MEETINGS_TO_SYNC);\n }\n }\n }\n })\n .catch((error) => {\n LoggerProxy.logger.error(\n `Meetings:index#syncMeetings --> failed to sync meetings, ${error}`\n );\n throw new Error(error);\n });\n }\n\n /**\n * sort out locus array for initial creating\n * @param {Array} loci original locus array\n * @returns {undefined}\n * @public\n * @memberof Meetings\n */\n sortLocusArrayToUpdate(loci: any[]) {\n const mainLoci = loci.filter((locus) => !MeetingsUtil.isBreakoutLocusDTO(locus));\n const breakoutLoci = loci.filter((locus) => MeetingsUtil.isValidBreakoutLocus(locus));\n this.breakoutLocusForHandleLater = [];\n const lociToUpdate = [...mainLoci];\n breakoutLoci.forEach((breakoutLocus) => {\n const associateMainLocus = mainLoci.find(\n (mainLocus) => mainLocus.controls?.breakout?.url === breakoutLocus.controls?.breakout?.url\n );\n const existCorrespondingMeeting = this.getCorrespondingMeetingByLocus({\n locus: breakoutLocus,\n locusUrl: breakoutLocus.url,\n });\n\n if (associateMainLocus && !existCorrespondingMeeting) {\n // if exists both main session and breakout session locus of the same non-exist meeting, handle main locus first,\n // after meeting create with main locus, then handle the associate breakout locus.\n // if only handle breakout locus, will miss some date\n this.breakoutLocusForHandleLater.push(breakoutLocus);\n } else {\n lociToUpdate.push(breakoutLocus);\n }\n });\n\n return lociToUpdate;\n }\n\n /**\n * check breakout locus which waiting for main locus's meeting to be created, then handle the breakout locus\n * @param {Object} newCreatedLocus the locus which just create meeting object of it\n * @returns {undefined}\n * @public\n * @memberof Meetings\n */\n checkHandleBreakoutLocus(newCreatedLocus) {\n if (\n !newCreatedLocus ||\n !this.breakoutLocusForHandleLater ||\n !this.breakoutLocusForHandleLater.length\n ) {\n return;\n }\n if (MeetingsUtil.isBreakoutLocusDTO(newCreatedLocus)) {\n return;\n }\n const existIndex = this.breakoutLocusForHandleLater.findIndex(\n (breakoutLocus) =>\n breakoutLocus.controls?.breakout?.url === newCreatedLocus.controls?.breakout?.url\n );\n\n if (existIndex < 0) {\n return;\n }\n\n const associateBreakoutLocus = this.breakoutLocusForHandleLater[existIndex];\n this.handleLocusEvent({locus: associateBreakoutLocus, locusUrl: associateBreakoutLocus.url});\n this.breakoutLocusForHandleLater.splice(existIndex, 1);\n }\n\n /**\n * Get all scheduled meetings.\n * @param {object} options\n * @param {object} options.startDate - get meetings after this start date\n * @param {object} options.endDate - get meetings before this end date\n * @returns {Object} All scheduled meetings.\n * @memberof Meetings\n */\n getScheduledMeetings() {\n return this.meetingCollection.getAll({scheduled: true});\n }\n\n /**\n * Get the logger instance for plugin-meetings\n * @returns {Logger}\n */\n getLogger() {\n return LoggerProxy.get();\n }\n\n /**\n * Returns the first meeting it finds that has the webrtc media connection created.\n * Useful for debugging in the console.\n *\n * @private\n * @returns {Meeting} Meeting object that has a webrtc media connection, else undefined\n */\n getActiveWebrtcMeeting() {\n return this.meetingCollection.getActiveWebrtcMeeting();\n }\n}\n"],"mappings":"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"}
|
|
@@ -492,67 +492,63 @@ var ReconnectionManager = /*#__PURE__*/function () {
|
|
|
492
492
|
this.status = _constants.RECONNECTION.STATE.FAILURE;
|
|
493
493
|
throw _context3.t0;
|
|
494
494
|
case 19:
|
|
495
|
-
|
|
496
|
-
_context3.next = 30;
|
|
497
|
-
break;
|
|
498
|
-
}
|
|
499
|
-
_context3.prev = 20;
|
|
495
|
+
_context3.prev = 19;
|
|
500
496
|
_loggerProxy.default.logger.info('ReconnectionManager:index#executeReconnection --> Updating meeting data from server.');
|
|
501
|
-
_context3.next =
|
|
497
|
+
_context3.next = 23;
|
|
502
498
|
return this.webex.meetings.syncMeetings({
|
|
503
499
|
keepOnlyLocusMeetings: false
|
|
504
500
|
});
|
|
505
|
-
case
|
|
506
|
-
_context3.next =
|
|
501
|
+
case 23:
|
|
502
|
+
_context3.next = 29;
|
|
507
503
|
break;
|
|
508
|
-
case
|
|
509
|
-
_context3.prev =
|
|
510
|
-
_context3.t1 = _context3["catch"](
|
|
504
|
+
case 25:
|
|
505
|
+
_context3.prev = 25;
|
|
506
|
+
_context3.t1 = _context3["catch"](19);
|
|
511
507
|
_loggerProxy.default.logger.info('ReconnectionManager:index#executeReconnection --> Unable to sync meetings, reconnecting.', _context3.t1);
|
|
512
508
|
throw new NeedsRetryError(_context3.t1);
|
|
513
|
-
case
|
|
509
|
+
case 29:
|
|
514
510
|
if (!(!this.meeting || !this.webex.meetings.getMeetingByType(_constants._ID_, this.meeting.id))) {
|
|
515
|
-
_context3.next =
|
|
511
|
+
_context3.next = 32;
|
|
516
512
|
break;
|
|
517
513
|
}
|
|
518
514
|
_loggerProxy.default.logger.info('ReconnectionManager:index#executeReconnection --> Meeting got deleted due to inactivity or ended remotely.');
|
|
519
515
|
throw new Error('Unable to rejoin a meeting already ended or inactive.');
|
|
520
|
-
case
|
|
516
|
+
case 32:
|
|
521
517
|
_loggerProxy.default.logger.info("ReconnectionManager:index#executeReconnection --> Current state of meeting is ".concat(this.meeting.state));
|
|
522
518
|
|
|
523
519
|
// If the meeting state was left, no longer reconnect media
|
|
524
520
|
if (!(this.meeting.state === _constants._LEFT_)) {
|
|
525
|
-
_context3.next =
|
|
521
|
+
_context3.next = 37;
|
|
526
522
|
break;
|
|
527
523
|
}
|
|
528
524
|
if (!(this.meeting.type === _constants._CALL_)) {
|
|
529
|
-
_context3.next =
|
|
525
|
+
_context3.next = 36;
|
|
530
526
|
break;
|
|
531
527
|
}
|
|
532
528
|
throw new Error('Unable to rejoin a call in LEFT state.');
|
|
533
|
-
case
|
|
529
|
+
case 36:
|
|
534
530
|
throw new NeedsRejoinError({
|
|
535
531
|
wasSharing: wasSharing
|
|
536
532
|
});
|
|
537
|
-
case
|
|
538
|
-
_context3.prev =
|
|
539
|
-
_context3.next =
|
|
533
|
+
case 37:
|
|
534
|
+
_context3.prev = 37;
|
|
535
|
+
_context3.next = 40;
|
|
540
536
|
return this.reconnectMedia();
|
|
541
|
-
case
|
|
537
|
+
case 40:
|
|
542
538
|
media = _context3.sent;
|
|
543
539
|
_loggerProxy.default.logger.log('ReconnectionManager:index#executeReconnection --> webRTC media connection renewed and local sdp offer sent');
|
|
544
540
|
return _context3.abrupt("return", media);
|
|
545
|
-
case
|
|
546
|
-
_context3.prev =
|
|
547
|
-
_context3.t2 = _context3["catch"](
|
|
541
|
+
case 45:
|
|
542
|
+
_context3.prev = 45;
|
|
543
|
+
_context3.t2 = _context3["catch"](37);
|
|
548
544
|
_loggerProxy.default.logger.error('ReconnectionManager:index#executeReconnection --> failed to renew webRTC media connection or initiate offer');
|
|
549
545
|
this.status = _constants.RECONNECTION.STATE.FAILURE;
|
|
550
546
|
throw _context3.t2;
|
|
551
|
-
case
|
|
547
|
+
case 50:
|
|
552
548
|
case "end":
|
|
553
549
|
return _context3.stop();
|
|
554
550
|
}
|
|
555
|
-
}, _callee3, this, [[8, 14], [
|
|
551
|
+
}, _callee3, this, [[8, 14], [19, 25], [37, 45]]);
|
|
556
552
|
}));
|
|
557
553
|
function executeReconnection(_x2) {
|
|
558
554
|
return _executeReconnection.apply(this, arguments);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["NeedsRetryError","Error","NeedsRejoinError","wasSharing","error","ReconnectionManager","meeting","iceState","disconnected","resolve","timer","undefined","timeoutDuration","config","reconnection","iceReconnectionTimeout","status","RECONNECTION","STATE","DEFAULT_STATUS","tryCount","DEFAULT_TRY_COUNT","webex","maxRejoinAttempts","rejoinAttempts","autoRejoinEnabled","autoRejoin","reset","clearTimeout","LoggerProxy","logger","log","resetReconnectionTimer","reject","setTimeout","reason","unpublishStreams","mediaProperties","shareVideoStream","shareAudioStream","Trigger","trigger","file","function","EVENT_TRIGGERS","MEETING_STOPPED_SHARING_LOCAL","IN_PROGRESS","enabled","COMPLETE","info","ReconnectInProgress","ReconnectionError","networkDisconnect","networkRetry","id","validate","internal","newMetrics","submitClientEvent","name","options","meetingId","meetings","startReachability","executeReconnection","media","reconnect","message","payload","errors","category","errorCode","fatal","shownToUser","rejoinMeeting","shareStatus","SHARE_STATUS","LOCAL_SHARE_ACTIVE","stopLocalShareStream","SHARE_STOPPED_REASON","MEDIA_RECONNECTION","reconnectMercuryWebSocket","device","url","FAILURE","credentials","isUnverifiedGuest","syncMeetings","keepOnlyLocusMeetings","getMeetingByType","_ID_","state","_LEFT_","type","_CALL_","reconnectMedia","join","rejoin","MEETING_REJOIN","Metrics","sendBehavioralMetric","BEHAVIORAL_METRICS","MEETING_MAX_REJOIN_FAILURE","locus_id","locusUrl","split","pop","stack","roap","doTurnDiscovery","turnServerResult","iceServers","turnServerInfo","push","urls","username","credential","password","webrtcMediaConnection","isMultistream","mediaRequestManagers","forEach","mediaRequestManager","clearPreviousRequests","commit","mercury","connected","disconnect","connect"],"sources":["index.ts"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\n/* eslint-disable no-warning-comments */\n\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport Trigger from '../common/events/trigger-proxy';\nimport {\n EVENT_TRIGGERS,\n RECONNECTION,\n SHARE_STATUS,\n SHARE_STOPPED_REASON,\n _CALL_,\n _LEFT_,\n _ID_,\n RECONNECTION_STATE,\n} from '../constants';\nimport BEHAVIORAL_METRICS from '../metrics/constants';\nimport ReconnectInProgress from '../common/errors/reconnection-in-progress';\nimport Metrics from '../metrics';\nimport Meeting from '../meeting';\nimport {MediaRequestManager} from '../multistream/mediaRequestManager';\nimport ReconnectionError from '../common/errors/reconnection';\n\n/**\n * Used to indicate that the reconnect logic needs to be retried.\n *\n * @class NeedsRetryError\n * @extends {Error}\n */\nclass NeedsRetryError extends Error {}\n\n/**\n * Used to indicate that the meeting needs to be rejoined, not just media reconnected\n *\n * @class NeedsRejoinError\n * @extends {Error}\n */\nclass NeedsRejoinError extends Error {\n wasSharing: any;\n\n /**\n * Creates an instance of NeedsRejoinError.\n * @param {Object} params\n * @param {boolean} params.wasSharing\n * @param {Error} params.error\n * @memberof NeedsRejoinError\n */\n constructor({\n wasSharing,\n error = new Error('Meeting needs to be rejoined'),\n }: {\n wasSharing?: boolean;\n error?: Error;\n }) {\n // @ts-ignore\n super(error);\n\n this.wasSharing = wasSharing;\n }\n}\n\n/**\n * @export\n * @class ReconnectionManager\n */\nexport default class ReconnectionManager {\n autoRejoinEnabled: any;\n iceState: any;\n maxRejoinAttempts: any;\n meeting: any;\n rejoinAttempts: any;\n shareStatus: any;\n status: any;\n tryCount: any;\n webex: any;\n /**\n * @param {Meeting} meeting\n */\n constructor(meeting: Meeting) {\n /**\n * Stores ICE reconnection state data.\n *\n * @instance\n * @type {Object}\n * @private\n * @memberof ReconnectionManager\n */\n this.iceState = {\n disconnected: false,\n resolve: () => {},\n timer: undefined,\n // @ts-ignore\n timeoutDuration: meeting.config.reconnection.iceReconnectionTimeout,\n };\n\n /**\n * @instance\n * @type {RECONNECTION_STATE}\n * @private\n * @memberof ReconnectionManager\n */\n this.status = RECONNECTION.STATE.DEFAULT_STATUS;\n /**\n * @instance\n * @type {Number}\n * @private\n * @memberof ReconnectionManager\n */\n this.tryCount = RECONNECTION.STATE.DEFAULT_TRY_COUNT;\n /**\n * @instance\n * @type {Object}\n * @private\n * @memberof ReconnectionManager\n */\n // TODO : change this logic to not save the meeting instance\n // It gets complicated when meeting ends on remote side , We have a old meeting instance which is not up to date\n // @ts-ignore\n this.webex = meeting.webex;\n /**\n * @instance\n * @type {Meeting}\n * @private\n * @memberof ReconnectionManager\n */\n // TODO: try removing the circular dependency for meeting and reconnection manager\n // try moving this to meetings collection\n this.meeting = meeting;\n\n // @ts-ignore\n this.maxRejoinAttempts = meeting.config.reconnection.maxRejoinAttempts;\n this.rejoinAttempts = RECONNECTION.STATE.DEFAULT_TRY_COUNT;\n // @ts-ignore\n this.autoRejoinEnabled = meeting.config.reconnection.autoRejoin;\n\n // Make sure reconnection state is in default\n this.reset();\n }\n\n /**\n * @public\n * @memberof ReconnectionManager\n * @returns {void}\n */\n resetReconnectionTimer() {\n this.iceState.resolve();\n this.iceState.resolve = () => {};\n\n if (this.iceState.timer) {\n clearTimeout(this.iceState.timer);\n delete this.iceState.timer;\n }\n }\n\n /**\n * Sets the iceState to connected and clears any disconnect timeouts and\n * related timeout data within the iceState.\n *\n * @returns {undefined}\n * @public\n * @memberof ReconnectionManager\n */\n public iceReconnected() {\n if (this.iceState.disconnected) {\n LoggerProxy.logger.log('ReconnectionManager:index#iceReconnected --> ice has reconnected');\n\n this.resetReconnectionTimer();\n\n this.iceState.disconnected = false;\n }\n }\n\n /**\n * Set the iceState to disconnected and generates a timeout that waits for the\n * iceState to reconnect and then resolves. If the ice state is already\n * processing a reconnect, it immediately resolves. Rejects if the timeout\n * duration is reached.\n *\n * @returns {Promise<undefined>}\n * @public\n * @memberof ReconnectionManager\n */\n public waitForIceReconnect() {\n if (!this.iceState.disconnected) {\n LoggerProxy.logger.log(\n 'ReconnectionManager:index#waitForIceReconnect --> waiting for ice reconnect'\n );\n\n this.iceState.disconnected = true;\n\n return new Promise<void>((resolve, reject) => {\n this.iceState.timer = setTimeout(() => {\n if (this.iceState.disconnected === false) {\n resolve();\n } else {\n this.iceState.disconnected = false;\n reject(\n new Error(`ice reconnection did not occur in ${this.iceState.timeoutDuration}ms`)\n );\n }\n }, this.iceState.timeoutDuration);\n\n this.iceState.resolve = resolve;\n });\n }\n\n // return a resolved promise to prevent multiple catch executions of reconnect\n return Promise.resolve();\n }\n\n /**\n * @returns {undefined}\n * @public\n * @memberof ReconnectionManager\n */\n public reset() {\n this.status = RECONNECTION.STATE.DEFAULT_STATUS;\n this.tryCount = RECONNECTION.STATE.DEFAULT_TRY_COUNT;\n this.rejoinAttempts = RECONNECTION.STATE.DEFAULT_TRY_COUNT;\n }\n\n /**\n * @returns {undefined}\n * @public\n * @memberof ReconnectionManager\n */\n public cleanUp() {\n this.reset();\n }\n\n /**\n * Stop the local share stream.\n *\n * @param {string} reason a {@link SHARE_STOPPED_REASON}\n * @returns {undefined}\n * @private\n * @memberof ReconnectionManager\n */\n private async stopLocalShareStream(reason: string) {\n await this.meeting.unpublishStreams([\n this.meeting.mediaProperties.shareVideoStream,\n this.meeting.mediaProperties.shareAudioStream,\n ]);\n Trigger.trigger(\n this.meeting,\n {\n file: 'reconnection-manager/index',\n function: 'stopLocalShareStream',\n },\n EVENT_TRIGGERS.MEETING_STOPPED_SHARING_LOCAL,\n {\n reason,\n }\n );\n }\n\n /**\n * @public\n * @memberof ReconnectionManager\n * @returns {Boolean} true if reconnection operation is in progress\n */\n isReconnectInProgress() {\n return this.status === RECONNECTION.STATE.IN_PROGRESS;\n }\n\n /**\n * Sets the reconnection status\n *\n * @public\n * @param {RECONNECTION_STATE} status\n * @memberof ReconnectionManager\n * @returns {undefined}\n */\n public setStatus(status: RECONNECTION_STATE) {\n this.status = status;\n }\n\n /**\n * @returns {Boolean}\n * @throws {ReconnectionError}\n * @private\n * @memberof ReconnectionManager\n */\n private validate() {\n if (this.meeting.config.reconnection.enabled) {\n if (\n this.status === RECONNECTION.STATE.DEFAULT_STATUS ||\n this.status === RECONNECTION.STATE.COMPLETE\n ) {\n return true;\n }\n\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#validate --> Reconnection already in progress.'\n );\n\n throw new ReconnectInProgress('Reconnection already in progress.');\n }\n\n LoggerProxy.logger.info('ReconnectionManager:index#validate --> Reconnection is not enabled.');\n\n throw new ReconnectionError('Reconnection is not enabled.');\n }\n\n /**\n * Initiates a media reconnect for the active meeting\n * @param {Object} reconnectOptions\n * @param {boolean} [reconnectOptions.networkDisconnect=false] indicates if a network disconnect event happened\n * @param {boolean} [reconnectOptions.networkRetry=false] indicates if we are retrying the reconnect\n * @returns {Promise}\n * @public\n * @memberof ReconnectionManager\n */\n public async reconnect({\n networkDisconnect = false,\n networkRetry = false,\n }: {\n networkDisconnect?: boolean;\n networkRetry?: boolean;\n } = {}) {\n LoggerProxy.logger.info(\n `ReconnectionManager:index#reconnect --> Reconnection start for meeting ${this.meeting.id}.`\n );\n // First, validate that we can reconnect, if not, it will throw an error\n try {\n this.validate();\n } catch (error) {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnect --> Reconnection unable to begin.',\n error\n );\n throw error;\n }\n\n if (!networkRetry) {\n // Only log START metrics on the initial reconnect\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnect --> Sending reconnect start metric.'\n );\n\n // @ts-ignore\n this.webex.internal.newMetrics.submitClientEvent({\n name: 'client.media.reconnecting',\n options: {\n meetingId: this.meeting.id,\n },\n });\n }\n\n try {\n await this.webex.meetings.startReachability();\n } catch (err) {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnect --> Reachability failed, continuing with reconnection attempt, err: ',\n err\n );\n }\n\n try {\n const media = await this.executeReconnection({networkDisconnect});\n\n return media;\n } catch (reconnectError) {\n if (reconnectError instanceof NeedsRetryError) {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnect --> Reconnection not successful, retrying.'\n );\n // Reset our reconnect status since we are looping back to the beginning\n this.status = RECONNECTION.STATE.DEFAULT_STATUS;\n\n // This is a network retry, so we should not log START metrics again\n return this.reconnect({networkDisconnect: true, networkRetry: true});\n }\n\n // Reconnect has failed\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#reconnect --> Reconnection failed.',\n reconnectError.message\n );\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnect --> Sending reconnect abort metric.'\n );\n\n // send call aborted event with catogery as expected as we are trying to rejoin\n // @ts-ignore\n this.webex.internal.newMetrics.submitClientEvent({\n name: 'client.call.aborted',\n payload: {\n errors: [\n {\n category: 'expected',\n errorCode: 2008,\n fatal: true,\n name: 'media-engine',\n shownToUser: false,\n },\n ],\n },\n options: {\n meetingId: this.meeting.id,\n },\n });\n\n if (reconnectError instanceof NeedsRejoinError && this.autoRejoinEnabled) {\n return this.rejoinMeeting(reconnectError.wasSharing);\n }\n\n throw reconnectError;\n }\n }\n\n /**\n * @param {Object} reconnectOptions\n * @param {boolean} [reconnectOptions.networkDisconnect=false] indicates if a network disconnect event happened\n * @returns {Promise}\n * @throws {NeedsRetryError}\n * @private\n * @memberof ReconnectionManager\n */\n private async executeReconnection({networkDisconnect = false}: {networkDisconnect?: boolean}) {\n this.status = RECONNECTION.STATE.IN_PROGRESS;\n\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#executeReconnection --> Attempting to reconnect to meeting.'\n );\n\n const wasSharing = this.meeting.shareStatus === SHARE_STATUS.LOCAL_SHARE_ACTIVE;\n\n if (wasSharing) {\n await this.stopLocalShareStream(SHARE_STOPPED_REASON.MEDIA_RECONNECTION);\n }\n\n if (networkDisconnect) {\n try {\n await this.reconnectMercuryWebSocket();\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#executeReconnection --> Websocket reconnected.',\n this.webex.internal.device.url\n );\n } catch (error) {\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#executeReconnection --> Unable to reconnect to websocket, giving up.'\n );\n this.status = RECONNECTION.STATE.FAILURE;\n throw error;\n }\n }\n\n if (!this.webex.credentials.isUnverifiedGuest) {\n try {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#executeReconnection --> Updating meeting data from server.'\n );\n await this.webex.meetings.syncMeetings({keepOnlyLocusMeetings: false});\n } catch (syncError) {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#executeReconnection --> Unable to sync meetings, reconnecting.',\n syncError\n );\n throw new NeedsRetryError(syncError);\n }\n }\n\n // TODO: try to improve this logic as the reconnection manager saves the instance of deleted meeting object\n // So that on rejoin it known what parametrs it was using\n if (!this.meeting || !this.webex.meetings.getMeetingByType(_ID_, this.meeting.id)) {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#executeReconnection --> Meeting got deleted due to inactivity or ended remotely.'\n );\n\n throw new Error('Unable to rejoin a meeting already ended or inactive.');\n }\n\n LoggerProxy.logger.info(\n `ReconnectionManager:index#executeReconnection --> Current state of meeting is ${this.meeting.state}`\n );\n\n // If the meeting state was left, no longer reconnect media\n if (this.meeting.state === _LEFT_) {\n if (this.meeting.type === _CALL_) {\n throw new Error('Unable to rejoin a call in LEFT state.');\n }\n\n throw new NeedsRejoinError({wasSharing});\n }\n\n try {\n const media = await this.reconnectMedia();\n\n LoggerProxy.logger.log(\n 'ReconnectionManager:index#executeReconnection --> webRTC media connection renewed and local sdp offer sent'\n );\n\n return media;\n } catch (error) {\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#executeReconnection --> failed to renew webRTC media connection or initiate offer'\n );\n this.status = RECONNECTION.STATE.FAILURE;\n\n throw error;\n }\n }\n\n /**\n * Rejoins a meeting after detecting the member was in a LEFT state\n *\n * @async\n * @param {boolean} wasSharing\n * @returns {Promise}\n */\n async rejoinMeeting(wasSharing = false) {\n try {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#rejoinMeeting --> attemping meeting rejoin'\n );\n\n await this.meeting.join({rejoin: true});\n LoggerProxy.logger.info('ReconnectionManager:index#rejoinMeeting --> meeting rejoined');\n\n if (wasSharing) {\n await this.stopLocalShareStream(SHARE_STOPPED_REASON.MEETING_REJOIN);\n }\n } catch (joinError) {\n this.rejoinAttempts += 1;\n if (this.rejoinAttempts <= this.maxRejoinAttempts) {\n LoggerProxy.logger.info(\n `ReconnectionManager:index#rejoinMeeting --> Unable to rejoin meeting, attempt #${this.rejoinAttempts}, retrying.`,\n joinError\n );\n this.rejoinMeeting();\n } else {\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#rejoinMeeting --> Unable to rejoin meeting after max attempts.',\n joinError\n );\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETING_MAX_REJOIN_FAILURE, {\n locus_id: this.meeting.locusUrl.split('/').pop(),\n reason: joinError.message,\n stack: joinError.stack,\n });\n this.status = RECONNECTION.STATE.FAILURE;\n throw joinError;\n }\n }\n\n try {\n await this.reconnectMedia();\n } catch (mediaError) {\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#rejoinMeeting --> Unable to reestablish media after rejoining.',\n mediaError\n );\n throw mediaError;\n }\n }\n\n /**\n * @returns {Promise}\n * @private\n * @memberof ReconnectionManager\n */\n async reconnectMedia() {\n LoggerProxy.logger.log('ReconnectionManager:index#reconnectMedia --> do turn discovery');\n\n // do the TURN server discovery again and ignore reachability results since the TURN server might change\n const turnServerResult = await this.meeting.roap.doTurnDiscovery(this.meeting, true, true);\n\n const iceServers = [];\n\n if (turnServerResult.turnServerInfo) {\n iceServers.push({\n urls: turnServerResult.turnServerInfo.url,\n username: turnServerResult.turnServerInfo.username || '',\n credential: turnServerResult.turnServerInfo.password || '',\n });\n }\n\n LoggerProxy.logger.log(\n 'ReconnectionManager:index#reconnectMedia --> renew webRTC media connection and send local sdp offer'\n );\n\n await this.meeting.mediaProperties.webrtcMediaConnection.reconnect(iceServers);\n\n // resend media requests\n if (this.meeting.isMultistream) {\n Object.values(this.meeting.mediaRequestManagers).forEach(\n (mediaRequestManager: MediaRequestManager) => {\n mediaRequestManager.clearPreviousRequests();\n mediaRequestManager.commit();\n }\n );\n }\n }\n\n /**\n * Attempt to Reconnect Mercury Websocket\n * @returns {Promise}\n * @private\n * @memberof ReconnectionManager\n */\n private async reconnectMercuryWebSocket() {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Reconnecting websocket.'\n );\n // First, attempt to disconnect if we think we are already connected.\n if (this.webex.internal.mercury.connected) {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Disconnecting existing websocket.'\n );\n try {\n await this.webex.internal.mercury.disconnect();\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Websocket disconnected successfully.'\n );\n } catch (disconnectError) {\n // If we can't disconnect, the sdk is in such a bad state that reconnecting is not going to happen.\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Unable to disconnect from websocket, giving up.',\n disconnectError\n );\n throw disconnectError;\n }\n }\n\n try {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Connecting websocket.'\n );\n await this.webex.internal.mercury.connect();\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Websocket connected successfully.'\n );\n } catch (connectError) {\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Unable to connect to websocket, giving up.',\n connectError\n );\n\n throw connectError;\n }\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["NeedsRetryError","Error","NeedsRejoinError","wasSharing","error","ReconnectionManager","meeting","iceState","disconnected","resolve","timer","undefined","timeoutDuration","config","reconnection","iceReconnectionTimeout","status","RECONNECTION","STATE","DEFAULT_STATUS","tryCount","DEFAULT_TRY_COUNT","webex","maxRejoinAttempts","rejoinAttempts","autoRejoinEnabled","autoRejoin","reset","clearTimeout","LoggerProxy","logger","log","resetReconnectionTimer","reject","setTimeout","reason","unpublishStreams","mediaProperties","shareVideoStream","shareAudioStream","Trigger","trigger","file","function","EVENT_TRIGGERS","MEETING_STOPPED_SHARING_LOCAL","IN_PROGRESS","enabled","COMPLETE","info","ReconnectInProgress","ReconnectionError","networkDisconnect","networkRetry","id","validate","internal","newMetrics","submitClientEvent","name","options","meetingId","meetings","startReachability","executeReconnection","media","reconnect","message","payload","errors","category","errorCode","fatal","shownToUser","rejoinMeeting","shareStatus","SHARE_STATUS","LOCAL_SHARE_ACTIVE","stopLocalShareStream","SHARE_STOPPED_REASON","MEDIA_RECONNECTION","reconnectMercuryWebSocket","device","url","FAILURE","syncMeetings","keepOnlyLocusMeetings","getMeetingByType","_ID_","state","_LEFT_","type","_CALL_","reconnectMedia","join","rejoin","MEETING_REJOIN","Metrics","sendBehavioralMetric","BEHAVIORAL_METRICS","MEETING_MAX_REJOIN_FAILURE","locus_id","locusUrl","split","pop","stack","roap","doTurnDiscovery","turnServerResult","iceServers","turnServerInfo","push","urls","username","credential","password","webrtcMediaConnection","isMultistream","mediaRequestManagers","forEach","mediaRequestManager","clearPreviousRequests","commit","mercury","connected","disconnect","connect"],"sources":["index.ts"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\n/* eslint-disable no-warning-comments */\n\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport Trigger from '../common/events/trigger-proxy';\nimport {\n EVENT_TRIGGERS,\n RECONNECTION,\n SHARE_STATUS,\n SHARE_STOPPED_REASON,\n _CALL_,\n _LEFT_,\n _ID_,\n RECONNECTION_STATE,\n} from '../constants';\nimport BEHAVIORAL_METRICS from '../metrics/constants';\nimport ReconnectInProgress from '../common/errors/reconnection-in-progress';\nimport Metrics from '../metrics';\nimport Meeting from '../meeting';\nimport {MediaRequestManager} from '../multistream/mediaRequestManager';\nimport ReconnectionError from '../common/errors/reconnection';\n\n/**\n * Used to indicate that the reconnect logic needs to be retried.\n *\n * @class NeedsRetryError\n * @extends {Error}\n */\nclass NeedsRetryError extends Error {}\n\n/**\n * Used to indicate that the meeting needs to be rejoined, not just media reconnected\n *\n * @class NeedsRejoinError\n * @extends {Error}\n */\nclass NeedsRejoinError extends Error {\n wasSharing: any;\n\n /**\n * Creates an instance of NeedsRejoinError.\n * @param {Object} params\n * @param {boolean} params.wasSharing\n * @param {Error} params.error\n * @memberof NeedsRejoinError\n */\n constructor({\n wasSharing,\n error = new Error('Meeting needs to be rejoined'),\n }: {\n wasSharing?: boolean;\n error?: Error;\n }) {\n // @ts-ignore\n super(error);\n\n this.wasSharing = wasSharing;\n }\n}\n\n/**\n * @export\n * @class ReconnectionManager\n */\nexport default class ReconnectionManager {\n autoRejoinEnabled: any;\n iceState: any;\n maxRejoinAttempts: any;\n meeting: any;\n rejoinAttempts: any;\n shareStatus: any;\n status: any;\n tryCount: any;\n webex: any;\n /**\n * @param {Meeting} meeting\n */\n constructor(meeting: Meeting) {\n /**\n * Stores ICE reconnection state data.\n *\n * @instance\n * @type {Object}\n * @private\n * @memberof ReconnectionManager\n */\n this.iceState = {\n disconnected: false,\n resolve: () => {},\n timer: undefined,\n // @ts-ignore\n timeoutDuration: meeting.config.reconnection.iceReconnectionTimeout,\n };\n\n /**\n * @instance\n * @type {RECONNECTION_STATE}\n * @private\n * @memberof ReconnectionManager\n */\n this.status = RECONNECTION.STATE.DEFAULT_STATUS;\n /**\n * @instance\n * @type {Number}\n * @private\n * @memberof ReconnectionManager\n */\n this.tryCount = RECONNECTION.STATE.DEFAULT_TRY_COUNT;\n /**\n * @instance\n * @type {Object}\n * @private\n * @memberof ReconnectionManager\n */\n // TODO : change this logic to not save the meeting instance\n // It gets complicated when meeting ends on remote side , We have a old meeting instance which is not up to date\n // @ts-ignore\n this.webex = meeting.webex;\n /**\n * @instance\n * @type {Meeting}\n * @private\n * @memberof ReconnectionManager\n */\n // TODO: try removing the circular dependency for meeting and reconnection manager\n // try moving this to meetings collection\n this.meeting = meeting;\n\n // @ts-ignore\n this.maxRejoinAttempts = meeting.config.reconnection.maxRejoinAttempts;\n this.rejoinAttempts = RECONNECTION.STATE.DEFAULT_TRY_COUNT;\n // @ts-ignore\n this.autoRejoinEnabled = meeting.config.reconnection.autoRejoin;\n\n // Make sure reconnection state is in default\n this.reset();\n }\n\n /**\n * @public\n * @memberof ReconnectionManager\n * @returns {void}\n */\n resetReconnectionTimer() {\n this.iceState.resolve();\n this.iceState.resolve = () => {};\n\n if (this.iceState.timer) {\n clearTimeout(this.iceState.timer);\n delete this.iceState.timer;\n }\n }\n\n /**\n * Sets the iceState to connected and clears any disconnect timeouts and\n * related timeout data within the iceState.\n *\n * @returns {undefined}\n * @public\n * @memberof ReconnectionManager\n */\n public iceReconnected() {\n if (this.iceState.disconnected) {\n LoggerProxy.logger.log('ReconnectionManager:index#iceReconnected --> ice has reconnected');\n\n this.resetReconnectionTimer();\n\n this.iceState.disconnected = false;\n }\n }\n\n /**\n * Set the iceState to disconnected and generates a timeout that waits for the\n * iceState to reconnect and then resolves. If the ice state is already\n * processing a reconnect, it immediately resolves. Rejects if the timeout\n * duration is reached.\n *\n * @returns {Promise<undefined>}\n * @public\n * @memberof ReconnectionManager\n */\n public waitForIceReconnect() {\n if (!this.iceState.disconnected) {\n LoggerProxy.logger.log(\n 'ReconnectionManager:index#waitForIceReconnect --> waiting for ice reconnect'\n );\n\n this.iceState.disconnected = true;\n\n return new Promise<void>((resolve, reject) => {\n this.iceState.timer = setTimeout(() => {\n if (this.iceState.disconnected === false) {\n resolve();\n } else {\n this.iceState.disconnected = false;\n reject(\n new Error(`ice reconnection did not occur in ${this.iceState.timeoutDuration}ms`)\n );\n }\n }, this.iceState.timeoutDuration);\n\n this.iceState.resolve = resolve;\n });\n }\n\n // return a resolved promise to prevent multiple catch executions of reconnect\n return Promise.resolve();\n }\n\n /**\n * @returns {undefined}\n * @public\n * @memberof ReconnectionManager\n */\n public reset() {\n this.status = RECONNECTION.STATE.DEFAULT_STATUS;\n this.tryCount = RECONNECTION.STATE.DEFAULT_TRY_COUNT;\n this.rejoinAttempts = RECONNECTION.STATE.DEFAULT_TRY_COUNT;\n }\n\n /**\n * @returns {undefined}\n * @public\n * @memberof ReconnectionManager\n */\n public cleanUp() {\n this.reset();\n }\n\n /**\n * Stop the local share stream.\n *\n * @param {string} reason a {@link SHARE_STOPPED_REASON}\n * @returns {undefined}\n * @private\n * @memberof ReconnectionManager\n */\n private async stopLocalShareStream(reason: string) {\n await this.meeting.unpublishStreams([\n this.meeting.mediaProperties.shareVideoStream,\n this.meeting.mediaProperties.shareAudioStream,\n ]);\n Trigger.trigger(\n this.meeting,\n {\n file: 'reconnection-manager/index',\n function: 'stopLocalShareStream',\n },\n EVENT_TRIGGERS.MEETING_STOPPED_SHARING_LOCAL,\n {\n reason,\n }\n );\n }\n\n /**\n * @public\n * @memberof ReconnectionManager\n * @returns {Boolean} true if reconnection operation is in progress\n */\n isReconnectInProgress() {\n return this.status === RECONNECTION.STATE.IN_PROGRESS;\n }\n\n /**\n * Sets the reconnection status\n *\n * @public\n * @param {RECONNECTION_STATE} status\n * @memberof ReconnectionManager\n * @returns {undefined}\n */\n public setStatus(status: RECONNECTION_STATE) {\n this.status = status;\n }\n\n /**\n * @returns {Boolean}\n * @throws {ReconnectionError}\n * @private\n * @memberof ReconnectionManager\n */\n private validate() {\n if (this.meeting.config.reconnection.enabled) {\n if (\n this.status === RECONNECTION.STATE.DEFAULT_STATUS ||\n this.status === RECONNECTION.STATE.COMPLETE\n ) {\n return true;\n }\n\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#validate --> Reconnection already in progress.'\n );\n\n throw new ReconnectInProgress('Reconnection already in progress.');\n }\n\n LoggerProxy.logger.info('ReconnectionManager:index#validate --> Reconnection is not enabled.');\n\n throw new ReconnectionError('Reconnection is not enabled.');\n }\n\n /**\n * Initiates a media reconnect for the active meeting\n * @param {Object} reconnectOptions\n * @param {boolean} [reconnectOptions.networkDisconnect=false] indicates if a network disconnect event happened\n * @param {boolean} [reconnectOptions.networkRetry=false] indicates if we are retrying the reconnect\n * @returns {Promise}\n * @public\n * @memberof ReconnectionManager\n */\n public async reconnect({\n networkDisconnect = false,\n networkRetry = false,\n }: {\n networkDisconnect?: boolean;\n networkRetry?: boolean;\n } = {}) {\n LoggerProxy.logger.info(\n `ReconnectionManager:index#reconnect --> Reconnection start for meeting ${this.meeting.id}.`\n );\n // First, validate that we can reconnect, if not, it will throw an error\n try {\n this.validate();\n } catch (error) {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnect --> Reconnection unable to begin.',\n error\n );\n throw error;\n }\n\n if (!networkRetry) {\n // Only log START metrics on the initial reconnect\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnect --> Sending reconnect start metric.'\n );\n\n // @ts-ignore\n this.webex.internal.newMetrics.submitClientEvent({\n name: 'client.media.reconnecting',\n options: {\n meetingId: this.meeting.id,\n },\n });\n }\n\n try {\n await this.webex.meetings.startReachability();\n } catch (err) {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnect --> Reachability failed, continuing with reconnection attempt, err: ',\n err\n );\n }\n\n try {\n const media = await this.executeReconnection({networkDisconnect});\n\n return media;\n } catch (reconnectError) {\n if (reconnectError instanceof NeedsRetryError) {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnect --> Reconnection not successful, retrying.'\n );\n // Reset our reconnect status since we are looping back to the beginning\n this.status = RECONNECTION.STATE.DEFAULT_STATUS;\n\n // This is a network retry, so we should not log START metrics again\n return this.reconnect({networkDisconnect: true, networkRetry: true});\n }\n\n // Reconnect has failed\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#reconnect --> Reconnection failed.',\n reconnectError.message\n );\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnect --> Sending reconnect abort metric.'\n );\n\n // send call aborted event with catogery as expected as we are trying to rejoin\n // @ts-ignore\n this.webex.internal.newMetrics.submitClientEvent({\n name: 'client.call.aborted',\n payload: {\n errors: [\n {\n category: 'expected',\n errorCode: 2008,\n fatal: true,\n name: 'media-engine',\n shownToUser: false,\n },\n ],\n },\n options: {\n meetingId: this.meeting.id,\n },\n });\n\n if (reconnectError instanceof NeedsRejoinError && this.autoRejoinEnabled) {\n return this.rejoinMeeting(reconnectError.wasSharing);\n }\n\n throw reconnectError;\n }\n }\n\n /**\n * @param {Object} reconnectOptions\n * @param {boolean} [reconnectOptions.networkDisconnect=false] indicates if a network disconnect event happened\n * @returns {Promise}\n * @throws {NeedsRetryError}\n * @private\n * @memberof ReconnectionManager\n */\n private async executeReconnection({networkDisconnect = false}: {networkDisconnect?: boolean}) {\n this.status = RECONNECTION.STATE.IN_PROGRESS;\n\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#executeReconnection --> Attempting to reconnect to meeting.'\n );\n\n const wasSharing = this.meeting.shareStatus === SHARE_STATUS.LOCAL_SHARE_ACTIVE;\n\n if (wasSharing) {\n await this.stopLocalShareStream(SHARE_STOPPED_REASON.MEDIA_RECONNECTION);\n }\n\n if (networkDisconnect) {\n try {\n await this.reconnectMercuryWebSocket();\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#executeReconnection --> Websocket reconnected.',\n this.webex.internal.device.url\n );\n } catch (error) {\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#executeReconnection --> Unable to reconnect to websocket, giving up.'\n );\n this.status = RECONNECTION.STATE.FAILURE;\n throw error;\n }\n }\n\n try {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#executeReconnection --> Updating meeting data from server.'\n );\n await this.webex.meetings.syncMeetings({keepOnlyLocusMeetings: false});\n } catch (syncError) {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#executeReconnection --> Unable to sync meetings, reconnecting.',\n syncError\n );\n throw new NeedsRetryError(syncError);\n }\n\n // TODO: try to improve this logic as the reconnection manager saves the instance of deleted meeting object\n // So that on rejoin it known what parametrs it was using\n if (!this.meeting || !this.webex.meetings.getMeetingByType(_ID_, this.meeting.id)) {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#executeReconnection --> Meeting got deleted due to inactivity or ended remotely.'\n );\n\n throw new Error('Unable to rejoin a meeting already ended or inactive.');\n }\n\n LoggerProxy.logger.info(\n `ReconnectionManager:index#executeReconnection --> Current state of meeting is ${this.meeting.state}`\n );\n\n // If the meeting state was left, no longer reconnect media\n if (this.meeting.state === _LEFT_) {\n if (this.meeting.type === _CALL_) {\n throw new Error('Unable to rejoin a call in LEFT state.');\n }\n\n throw new NeedsRejoinError({wasSharing});\n }\n\n try {\n const media = await this.reconnectMedia();\n\n LoggerProxy.logger.log(\n 'ReconnectionManager:index#executeReconnection --> webRTC media connection renewed and local sdp offer sent'\n );\n\n return media;\n } catch (error) {\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#executeReconnection --> failed to renew webRTC media connection or initiate offer'\n );\n this.status = RECONNECTION.STATE.FAILURE;\n\n throw error;\n }\n }\n\n /**\n * Rejoins a meeting after detecting the member was in a LEFT state\n *\n * @async\n * @param {boolean} wasSharing\n * @returns {Promise}\n */\n async rejoinMeeting(wasSharing = false) {\n try {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#rejoinMeeting --> attemping meeting rejoin'\n );\n\n await this.meeting.join({rejoin: true});\n LoggerProxy.logger.info('ReconnectionManager:index#rejoinMeeting --> meeting rejoined');\n\n if (wasSharing) {\n await this.stopLocalShareStream(SHARE_STOPPED_REASON.MEETING_REJOIN);\n }\n } catch (joinError) {\n this.rejoinAttempts += 1;\n if (this.rejoinAttempts <= this.maxRejoinAttempts) {\n LoggerProxy.logger.info(\n `ReconnectionManager:index#rejoinMeeting --> Unable to rejoin meeting, attempt #${this.rejoinAttempts}, retrying.`,\n joinError\n );\n this.rejoinMeeting();\n } else {\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#rejoinMeeting --> Unable to rejoin meeting after max attempts.',\n joinError\n );\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETING_MAX_REJOIN_FAILURE, {\n locus_id: this.meeting.locusUrl.split('/').pop(),\n reason: joinError.message,\n stack: joinError.stack,\n });\n this.status = RECONNECTION.STATE.FAILURE;\n throw joinError;\n }\n }\n\n try {\n await this.reconnectMedia();\n } catch (mediaError) {\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#rejoinMeeting --> Unable to reestablish media after rejoining.',\n mediaError\n );\n throw mediaError;\n }\n }\n\n /**\n * @returns {Promise}\n * @private\n * @memberof ReconnectionManager\n */\n async reconnectMedia() {\n LoggerProxy.logger.log('ReconnectionManager:index#reconnectMedia --> do turn discovery');\n\n // do the TURN server discovery again and ignore reachability results since the TURN server might change\n const turnServerResult = await this.meeting.roap.doTurnDiscovery(this.meeting, true, true);\n\n const iceServers = [];\n\n if (turnServerResult.turnServerInfo) {\n iceServers.push({\n urls: turnServerResult.turnServerInfo.url,\n username: turnServerResult.turnServerInfo.username || '',\n credential: turnServerResult.turnServerInfo.password || '',\n });\n }\n\n LoggerProxy.logger.log(\n 'ReconnectionManager:index#reconnectMedia --> renew webRTC media connection and send local sdp offer'\n );\n\n await this.meeting.mediaProperties.webrtcMediaConnection.reconnect(iceServers);\n\n // resend media requests\n if (this.meeting.isMultistream) {\n Object.values(this.meeting.mediaRequestManagers).forEach(\n (mediaRequestManager: MediaRequestManager) => {\n mediaRequestManager.clearPreviousRequests();\n mediaRequestManager.commit();\n }\n );\n }\n }\n\n /**\n * Attempt to Reconnect Mercury Websocket\n * @returns {Promise}\n * @private\n * @memberof ReconnectionManager\n */\n private async reconnectMercuryWebSocket() {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Reconnecting websocket.'\n );\n // First, attempt to disconnect if we think we are already connected.\n if (this.webex.internal.mercury.connected) {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Disconnecting existing websocket.'\n );\n try {\n await this.webex.internal.mercury.disconnect();\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Websocket disconnected successfully.'\n );\n } catch (disconnectError) {\n // If we can't disconnect, the sdk is in such a bad state that reconnecting is not going to happen.\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Unable to disconnect from websocket, giving up.',\n disconnectError\n );\n throw disconnectError;\n }\n }\n\n try {\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Connecting websocket.'\n );\n await this.webex.internal.mercury.connect();\n LoggerProxy.logger.info(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Websocket connected successfully.'\n );\n } catch (connectError) {\n LoggerProxy.logger.error(\n 'ReconnectionManager:index#reconnectMercuryWebSocket --> Unable to connect to websocket, giving up.',\n connectError\n );\n\n throw connectError;\n }\n }\n}\n"],"mappings":"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"}
|
|
@@ -339,7 +339,7 @@ export default class Meetings extends WebexPlugin {
|
|
|
339
339
|
endDate: object;
|
|
340
340
|
}): any;
|
|
341
341
|
/**
|
|
342
|
-
*
|
|
342
|
+
* Syncs all the meetings from server. Does nothing and returns immediately if unverified guest.
|
|
343
343
|
* @param {boolean} keepOnlyLocusMeetings - whether the sync should keep only locus meetings or any other meeting in meetingCollection
|
|
344
344
|
* @returns {Promise<void>}
|
|
345
345
|
* @public
|
package/dist/webinar/index.js
CHANGED
|
@@ -62,7 +62,7 @@ var Webinar = _webexCore.WebexPlugin.extend({
|
|
|
62
62
|
updateCanManageWebcast: function updateCanManageWebcast(canManageWebcast) {
|
|
63
63
|
this.set('canManageWebcast', canManageWebcast);
|
|
64
64
|
},
|
|
65
|
-
version: "3.0.0-beta.
|
|
65
|
+
version: "3.0.0-beta.377"
|
|
66
66
|
});
|
|
67
67
|
var _default = Webinar;
|
|
68
68
|
exports.default = _default;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webex/plugin-meetings",
|
|
3
|
-
"version": "3.0.0-beta.
|
|
3
|
+
"version": "3.0.0-beta.377",
|
|
4
4
|
"description": "",
|
|
5
5
|
"license": "Cisco EULA (https://www.cisco.com/c/en/us/products/end-user-license-agreement.html)",
|
|
6
6
|
"contributors": [
|
|
@@ -33,12 +33,12 @@
|
|
|
33
33
|
},
|
|
34
34
|
"devDependencies": {
|
|
35
35
|
"@peculiar/webcrypto": "^1.4.3",
|
|
36
|
-
"@webex/plugin-meetings": "3.0.0-beta.
|
|
37
|
-
"@webex/test-helper-chai": "3.0.0-beta.
|
|
38
|
-
"@webex/test-helper-mocha": "3.0.0-beta.
|
|
39
|
-
"@webex/test-helper-mock-webex": "3.0.0-beta.
|
|
40
|
-
"@webex/test-helper-retry": "3.0.0-beta.
|
|
41
|
-
"@webex/test-helper-test-users": "3.0.0-beta.
|
|
36
|
+
"@webex/plugin-meetings": "3.0.0-beta.377",
|
|
37
|
+
"@webex/test-helper-chai": "3.0.0-beta.377",
|
|
38
|
+
"@webex/test-helper-mocha": "3.0.0-beta.377",
|
|
39
|
+
"@webex/test-helper-mock-webex": "3.0.0-beta.377",
|
|
40
|
+
"@webex/test-helper-retry": "3.0.0-beta.377",
|
|
41
|
+
"@webex/test-helper-test-users": "3.0.0-beta.377",
|
|
42
42
|
"chai": "^4.3.4",
|
|
43
43
|
"chai-as-promised": "^7.1.1",
|
|
44
44
|
"jsdom-global": "3.0.2",
|
|
@@ -47,19 +47,19 @@
|
|
|
47
47
|
"typescript": "^4.7.4"
|
|
48
48
|
},
|
|
49
49
|
"dependencies": {
|
|
50
|
-
"@webex/common": "3.0.0-beta.
|
|
50
|
+
"@webex/common": "3.0.0-beta.377",
|
|
51
51
|
"@webex/internal-media-core": "2.2.7",
|
|
52
|
-
"@webex/internal-plugin-conversation": "3.0.0-beta.
|
|
53
|
-
"@webex/internal-plugin-device": "3.0.0-beta.
|
|
54
|
-
"@webex/internal-plugin-llm": "3.0.0-beta.
|
|
55
|
-
"@webex/internal-plugin-mercury": "3.0.0-beta.
|
|
56
|
-
"@webex/internal-plugin-metrics": "3.0.0-beta.
|
|
57
|
-
"@webex/internal-plugin-support": "3.0.0-beta.
|
|
58
|
-
"@webex/internal-plugin-user": "3.0.0-beta.
|
|
59
|
-
"@webex/media-helpers": "3.0.0-beta.
|
|
60
|
-
"@webex/plugin-people": "3.0.0-beta.
|
|
61
|
-
"@webex/plugin-rooms": "3.0.0-beta.
|
|
62
|
-
"@webex/webex-core": "3.0.0-beta.
|
|
52
|
+
"@webex/internal-plugin-conversation": "3.0.0-beta.377",
|
|
53
|
+
"@webex/internal-plugin-device": "3.0.0-beta.377",
|
|
54
|
+
"@webex/internal-plugin-llm": "3.0.0-beta.377",
|
|
55
|
+
"@webex/internal-plugin-mercury": "3.0.0-beta.377",
|
|
56
|
+
"@webex/internal-plugin-metrics": "3.0.0-beta.377",
|
|
57
|
+
"@webex/internal-plugin-support": "3.0.0-beta.377",
|
|
58
|
+
"@webex/internal-plugin-user": "3.0.0-beta.377",
|
|
59
|
+
"@webex/media-helpers": "3.0.0-beta.377",
|
|
60
|
+
"@webex/plugin-people": "3.0.0-beta.377",
|
|
61
|
+
"@webex/plugin-rooms": "3.0.0-beta.377",
|
|
62
|
+
"@webex/webex-core": "3.0.0-beta.377",
|
|
63
63
|
"ampersand-collection": "^2.0.2",
|
|
64
64
|
"bowser": "^2.11.0",
|
|
65
65
|
"btoa": "^1.2.1",
|
package/src/meetings/index.ts
CHANGED
|
@@ -1406,13 +1406,22 @@ export default class Meetings extends WebexPlugin {
|
|
|
1406
1406
|
}
|
|
1407
1407
|
|
|
1408
1408
|
/**
|
|
1409
|
-
*
|
|
1409
|
+
* Syncs all the meetings from server. Does nothing and returns immediately if unverified guest.
|
|
1410
1410
|
* @param {boolean} keepOnlyLocusMeetings - whether the sync should keep only locus meetings or any other meeting in meetingCollection
|
|
1411
1411
|
* @returns {Promise<void>}
|
|
1412
1412
|
* @public
|
|
1413
1413
|
* @memberof Meetings
|
|
1414
1414
|
*/
|
|
1415
1415
|
public syncMeetings({keepOnlyLocusMeetings = true} = {}): Promise<void> {
|
|
1416
|
+
// @ts-ignore
|
|
1417
|
+
if (this.webex.credentials.isUnverifiedGuest) {
|
|
1418
|
+
LoggerProxy.logger.info(
|
|
1419
|
+
'Meetings:index#syncMeetings --> skipping meeting sync as unverified guest'
|
|
1420
|
+
);
|
|
1421
|
+
|
|
1422
|
+
return Promise.resolve();
|
|
1423
|
+
}
|
|
1424
|
+
|
|
1416
1425
|
return this.request
|
|
1417
1426
|
.getActiveMeetings()
|
|
1418
1427
|
.then((locusArray) => {
|
|
@@ -448,19 +448,17 @@ export default class ReconnectionManager {
|
|
|
448
448
|
}
|
|
449
449
|
}
|
|
450
450
|
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
throw new NeedsRetryError(syncError);
|
|
463
|
-
}
|
|
451
|
+
try {
|
|
452
|
+
LoggerProxy.logger.info(
|
|
453
|
+
'ReconnectionManager:index#executeReconnection --> Updating meeting data from server.'
|
|
454
|
+
);
|
|
455
|
+
await this.webex.meetings.syncMeetings({keepOnlyLocusMeetings: false});
|
|
456
|
+
} catch (syncError) {
|
|
457
|
+
LoggerProxy.logger.info(
|
|
458
|
+
'ReconnectionManager:index#executeReconnection --> Unable to sync meetings, reconnecting.',
|
|
459
|
+
syncError
|
|
460
|
+
);
|
|
461
|
+
throw new NeedsRetryError(syncError);
|
|
464
462
|
}
|
|
465
463
|
|
|
466
464
|
// TODO: try to improve this logic as the reconnection manager saves the instance of deleted meeting object
|
|
@@ -511,6 +511,27 @@ describe('plugin-meetings', () => {
|
|
|
511
511
|
it('should have #syncMeetings', () => {
|
|
512
512
|
assert.exists(webex.meetings.syncMeetings);
|
|
513
513
|
});
|
|
514
|
+
it('should do nothing and return a resolved promise if unverified guest', async () => {
|
|
515
|
+
webex.meetings.request.getActiveMeetings = sinon.stub().returns(
|
|
516
|
+
Promise.resolve({
|
|
517
|
+
loci: [
|
|
518
|
+
{
|
|
519
|
+
url: url1,
|
|
520
|
+
},
|
|
521
|
+
],
|
|
522
|
+
})
|
|
523
|
+
);
|
|
524
|
+
webex.credentials.isUnverifiedGuest = true;
|
|
525
|
+
LoggerProxy.logger.info = sinon.stub();
|
|
526
|
+
|
|
527
|
+
await webex.meetings.syncMeetings();
|
|
528
|
+
|
|
529
|
+
assert.notCalled(webex.meetings.request.getActiveMeetings);
|
|
530
|
+
assert.calledWith(
|
|
531
|
+
LoggerProxy.logger.info,
|
|
532
|
+
'Meetings:index#syncMeetings --> skipping meeting sync as unverified guest'
|
|
533
|
+
);
|
|
534
|
+
});
|
|
514
535
|
describe('succesful requests', () => {
|
|
515
536
|
beforeEach(() => {
|
|
516
537
|
webex.meetings.request.getActiveMeetings = sinon.stub().returns(
|
|
@@ -90,7 +90,7 @@ describe('plugin-meetings', () => {
|
|
|
90
90
|
sandbox.reset();
|
|
91
91
|
});
|
|
92
92
|
|
|
93
|
-
it('
|
|
93
|
+
it('calls syncMeetings', async () => {
|
|
94
94
|
const rm = new ReconnectionManager(fakeMeeting);
|
|
95
95
|
|
|
96
96
|
await rm.reconnect();
|
|
@@ -99,16 +99,6 @@ describe('plugin-meetings', () => {
|
|
|
99
99
|
assert.calledWith(rm.webex.meetings.syncMeetings, {keepOnlyLocusMeetings: false});
|
|
100
100
|
});
|
|
101
101
|
|
|
102
|
-
it('does not sync meetings if it is an unverified guest', async () => {
|
|
103
|
-
const rm = new ReconnectionManager(fakeMeeting);
|
|
104
|
-
|
|
105
|
-
rm.webex.credentials.isUnverifiedGuest = true;
|
|
106
|
-
|
|
107
|
-
await rm.reconnect();
|
|
108
|
-
|
|
109
|
-
assert.notCalled(rm.webex.meetings.syncMeetings);
|
|
110
|
-
});
|
|
111
|
-
|
|
112
102
|
it('calls startReachability on reconnect', async () => {
|
|
113
103
|
const rm = new ReconnectionManager(fakeMeeting);
|
|
114
104
|
|