@webex/plugin-meetings 2.29.2 → 2.29.5
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/README.md +2 -1
- package/dist/common/collection.js +1 -1
- package/dist/common/collection.js.map +1 -1
- package/dist/meeting/index.js +2 -1
- package/dist/meeting/index.js.map +1 -1
- package/dist/metrics/index.js +4 -0
- package/dist/metrics/index.js.map +1 -1
- package/dist/peer-connection-manager/index.js +3 -3
- package/dist/peer-connection-manager/index.js.map +1 -1
- package/dist/reachability/index.js +17 -13
- package/dist/reachability/index.js.map +1 -1
- package/dist/reachability/request.js +16 -7
- package/dist/reachability/request.js.map +1 -1
- package/internal-README.md +18 -9
- package/package.json +59 -41
- package/src/common/collection.ts +1 -1
- package/src/meeting/index.js +1 -1
- package/src/metrics/index.js +3 -0
- package/src/peer-connection-manager/index.js +3 -3
- package/src/reachability/index.js +12 -8
- package/src/reachability/{request.js → request.ts} +23 -6
- package/test/integration/spec/journey.js +2 -0
- package/test/integration/spec/space-meeting.js +1 -1
- package/test/unit/spec/meeting/index.js +3 -1
- package/test/.eslintrc.json +0 -6
package/dist/metrics/index.js
CHANGED
|
@@ -292,6 +292,10 @@ var Metrics = /*#__PURE__*/function () {
|
|
|
292
292
|
if (options.joinTimes) {
|
|
293
293
|
payload.event.joinTimes = options.joinTimes;
|
|
294
294
|
}
|
|
295
|
+
|
|
296
|
+
if (options.isRoapCallEnabled) {
|
|
297
|
+
payload.event.isRoapCallEnabled = options.isRoapCallEnabled;
|
|
298
|
+
}
|
|
295
299
|
}
|
|
296
300
|
|
|
297
301
|
return payload;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["OSMap","OS_NAME","chrome","macOS","MAC","Windows","WINDOWS","iOS","IOS","Android","ANDROID","Linux","LINUX","BrowserDetection","getOSName","getOSVersion","getBrowserName","getBrowserVersion","anonymizeIPAddress","localIp","anonymize","triggerTimers","event","meeting","data","eventType","CALL_INITIATED","setStartCallInitiateJoinReq","LOCUS_JOIN_REQUEST","setEndCallInitiateJoinReq","setStartJoinReqResp","LOCUS_JOIN_RESPONSE","setEndJoinReqResp","setStartSetupDelay","mediaType","AUDIO","VIDEO","setStartSendingMediaDelay","RECEIVING_MEDIA_START","setEndSetupDelay","SENDING_MEDIA_START","setEndSendingMediaDelay","LOCAL_SDP_GENERATED","setStartLocalSDPGenRemoteSDPRecvDelay","REMOTE_SDP_RECEIVED","setEndLocalSDPGenRemoteSDPRecvDelay","Metrics","instance","_events","meetingCollection","keys","webex","options","meetingId","indexOf","LoggerProxy","logger","error","get","callEvents","MEDIA_QUALITY","sendMediaQualityAnalyzerMetrics","push","sendCallAnalyzerMetrics","info","identifiers","payload","eventId","uuid","v4","version","origin","name","networkType","userAgent","userAgentToString","clientInfo","clientType","clientVersion","CLIENT_NAME","localNetworkPrefix","meetings","geoHintInfo","clientAddress","osVersion","subClientType","os","getOsName","browser","browserVersion","originTime","triggered","Date","toISOString","senderCountryCode","countryCode","canProceed","eventData","webClientDomain","window","location","hostname","Object","prototype","hasOwnProperty","call","errors","trigger","pstnAudioType","mediaCapabilities","recoveredBy","joinTimes","OTHERS","audioSetupDelay","videoSetupDelay","UNKNOWN","intervals","intervalData","sourceMetadata","applicationSoftwareType","applicationSoftwareVersion","mediaEngineSoftwareType","mediaEngineSoftwareVersion","startTime","err","showToUser","errorCode","statusCode","body","ERROR_CODE","MEETING_ERRORS","FREE_USER_MAX_PARTICIPANTS_EXCEEDED","PAID_USER_MAX_PARTICIPANTS_EXCEEDED","SERVICE_MAX_PARTICIPANTS_EXCEEDED","INACTIVE","EXCEEDED_MAX_JOINED_PARTICIPANTS","EXCEEDED_SERVICE_MAX_PARTICIPANTS","MEETING_IS_LOCKED","MEETING_IS_TERMINATING","MEETING_REQUIRE_MODERATOR_PIN_INTENT","MEETING_REQUIRE_MODERATOR_PIN","MEETING_REQUIRE_MODERATOR_ROLE","JOIN_RESTRICTED_USER","GET_RESTRICTED_USER","CREATE_MEDIA_RESTRICTED_USER","JOIN_RESTRICTED_USER_NOT_IN_ROOM","MEETING_NOT_FOUND","NOT_WEBEX_SITE","INVALID_JOIN_TIME","PHONE_NUMBER_NOT_A_NUMBER","PHONE_NUMBER_TOO_LONG","INVALID_DIALABLE_KEY","ONE_ON_ONE_TO_SELF_NOT_ALLOWED","REMOVED_PARTICIPANT","MEETING_LINK_NOT_FOUND","PHONE_NUMBER_TOO_SHORT_AFTER_IDD","INVALID_INVITEE_ADDRESS","PMR_ACCOUNT_LOCKED","RESOURCE_GUEST_FORBIDDEN","PMR_ACCOUNT_SUSPENDED","EMPTY_PHONE_NUMBER_OR_COUNTRY_CODE","INVALID_SINCE_OR_SEQUENCE_HASH_IN_REQUEST","CONVERSATION_NOT_FOUND","RECORDING_CONTROL_NOT_SUPPORTED","RECORDING_NOT_STARTED","RECORDING_NOT_ENABLED","generateErrorPayload","LOCUS_RESPONSE","shownToUser","errorPayload","category","errorDescription","fatal","notFatalErrorList","OTHER","errorData","httpCode","userAgentOption","browserInfo","util","format","metrics","clientName","toLowerCase","split","osInfo","process","env","NODE_ENV","metricName","metricFields","metricTags","internal","submitClientMetrics","type","config","fields","tags"],"sources":["index.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\nimport util from 'util';\n\nimport {includes} from 'lodash';\nimport uuid from 'uuid';\nimport window from 'global/window';\nimport anonymize from 'ip-anonymize';\n\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport {MEETING_ERRORS} from '../constants';\nimport BrowserDetection from '../common/browser-detection';\n\nimport {\n error, eventType, errorCodes as ERROR_CODE, OS_NAME, UNKNOWN, CLIENT_NAME,\n mediaType\n} from './config';\n\nconst OSMap = {\n 'Chrome OS': OS_NAME.chrome,\n macOS: OS_NAME.MAC,\n Windows: OS_NAME.WINDOWS,\n iOS: OS_NAME.IOS,\n Android: OS_NAME.ANDROID,\n Linux: OS_NAME.LINUX\n};\n\nconst {\n getOSName,\n getOSVersion,\n getBrowserName,\n getBrowserVersion\n} = BrowserDetection();\n\n// Apply a CIDR /28 format to the IPV4 and /96 to the IPV6 addresses\n// For reference : https://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing\nconst anonymizeIPAddress = (localIp) => anonymize(localIp, 28, 96);\n\nconst triggerTimers = ({event, meeting, data}) => {\n switch (event) {\n case eventType.CALL_INITIATED:\n meeting.setStartCallInitiateJoinReq();\n break;\n case eventType.LOCUS_JOIN_REQUEST:\n meeting.setEndCallInitiateJoinReq();\n meeting.setStartJoinReqResp();\n break;\n case eventType.LOCUS_JOIN_RESPONSE:\n meeting.setEndJoinReqResp();\n meeting.setStartSetupDelay(mediaType.AUDIO);\n meeting.setStartSetupDelay(mediaType.VIDEO);\n meeting.setStartSendingMediaDelay(mediaType.AUDIO);\n meeting.setStartSendingMediaDelay(mediaType.VIDEO);\n break;\n case eventType.RECEIVING_MEDIA_START:\n meeting.setEndSetupDelay(data.mediaType);\n break;\n case eventType.SENDING_MEDIA_START:\n meeting.setEndSendingMediaDelay(data.mediaType);\n break;\n case eventType.LOCAL_SDP_GENERATED:\n meeting.setStartLocalSDPGenRemoteSDPRecvDelay();\n break;\n case eventType.REMOTE_SDP_RECEIVED:\n meeting.setEndLocalSDPGenRemoteSDPRecvDelay();\n break;\n default:\n break;\n }\n};\n\n/**\n * @description Metrics handles all the call metrics events\n * @export\n * @class Metrics\n */\nclass Metrics {\n /**\n * Create Metrics Object\n * @constructor\n * @public\n * @memberof Meetings\n */\n constructor() {\n if (!Metrics.instance) {\n /**\n * @instance\n * @type {Array}\n * @private\n * @memberof Metrics\n */\n this._events = [];\n /**\n * @instance\n * @type {MeetingCollection}\n * @private\n * @memberof Metrics\n */\n this.meetingCollection = null;\n /**\n * @instance\n * @type {MeetingCollection}\n * @private\n * @memberof Metrics\n */\n this.keys = Object.values(eventType);\n /**\n * @instance\n * @type {Metrics}\n * @private\n * @memberof Metrics\n */\n Metrics.instance = this;\n }\n\n return Metrics.instance;\n }\n\n /**\n * Initializes the Metrics singleton with a meeting Collection.\n *\n * @param {Object} meetingCollection meetings object\n * @param {Object} webex webex SDK object\n *\n * @returns {void}\n */\n initialSetup(meetingCollection, webex) {\n this.meetingCollection = meetingCollection;\n this.webex = webex;\n }\n\n /**\n * poste Meeting event metrics\n * @param {object} options {meetingId/meeting} as a json object\n * @param {Meeting} options.meeting Meeting object\n * @param {String} options.meetingId\n * @param {object} options.data\n * @param {object} options.event\n * @returns {object} null\n */\n postEvent(options) {\n const {meetingId, data = {}, event} = options;\n let {meeting} = options;\n\n if (this.keys.indexOf(event) === -1) {\n LoggerProxy.logger.error(`Metrics:index#postEvent --> Event ${event} doesn't exist in dictionary`);\n }\n\n if (!meeting && meetingId) {\n meeting = this.meetingCollection.get(meetingId);\n options.meeting = meeting;\n }\n\n if (meeting) {\n triggerTimers(options);\n\n if (!meeting.callEvents) {\n meeting.callEvents = [];\n }\n if (event === eventType.MEDIA_QUALITY) {\n data.event = event;\n meeting.sendMediaQualityAnalyzerMetrics(data);\n }\n else {\n meeting.callEvents.push(event);\n data.event = event;\n meeting.sendCallAnalyzerMetrics(data);\n }\n }\n\n else {\n LoggerProxy.logger.info(`Metrics:index#postEvent --> Event received for meetingId:${meetingId}, but meeting not found in collection.`);\n }\n }\n\n /**\n * Docs for Call analyzer metrics\n * https://sqbu-github.cisco.com/WebExSquared/call-analyzer/wiki\n * https://sqbu-github.cisco.com/WebExSquared/event-dictionary/blob/master/diagnostic-events.raml\n */\n\n initPayload(eventType, identifiers, options) {\n const payload = {\n eventId: uuid.v4(),\n version: 1,\n origin: {\n name: 'endpoint',\n networkType: 'unknown',\n userAgent: this.userAgentToString(),\n clientInfo: {\n clientType: options.clientType,\n clientVersion: `${CLIENT_NAME}/${this.webex.version}`,\n localNetworkPrefix: anonymizeIPAddress(this.webex.meetings.geoHintInfo?.clientAddress),\n osVersion: getOSVersion() || 'unknown',\n subClientType: options.subClientType,\n os: this.getOsName(),\n browser: getBrowserName(),\n browserVersion: getBrowserVersion()\n }\n },\n originTime: {\n triggered: new Date().toISOString()\n },\n senderCountryCode: this.webex.meetings.geoHintInfo?.countryCode,\n event: {\n name: eventType,\n canProceed: true,\n identifiers,\n eventData: {webClientDomain: window.location.hostname}\n }\n };\n\n // TODO: more options should be checked and some of them should be mandatory in certain conditions\n if (options) {\n if (Object.prototype.hasOwnProperty.call(options, 'canProceed')) {\n payload.event.canProceed = options.canProceed;\n }\n if (options.errors) {\n payload.event.errors = options.errors;\n }\n if (options.mediaType) {\n payload.event.mediaType = options.mediaType;\n }\n if (options.trigger) {\n payload.event.trigger = options.trigger;\n }\n if (options.pstnAudioType) {\n payload.event.pstnAudioType = options.pstnAudioType;\n }\n if (options.mediaCapabilities) {\n payload.event.mediaCapabilities = options.mediaCapabilities;\n }\n if (options.recoveredBy) {\n payload.event.recoveredBy = options.recoveredBy;\n }\n if (options.joinTimes) {\n payload.event.joinTimes = options.joinTimes;\n }\n }\n\n return payload;\n }\n\n /**\n * returns metrics friendly OS versions\n * @param {String} osName Os name\n * @returns {String}\n * @private\n * @memberof Metrics\n */\n getOsName() {\n return OSMap[getOSName()] ?? OS_NAME.OTHERS;\n }\n\n /**\n * get the payload specific for a media quality event through call analyzer\n * @param {String} eventType the event name\n * @param {Object} identifiers contains the identifiers needed for CA\n * @param {String} identifiers.correlationId\n * @param {String} identifiers.locusUrl\n * @param {String} identifiers.locusId\n * @param {Object} options\n * @param {Object} options.intervalData\n * @param {String} options.clientType\n * @returns {Object}\n * @public\n * @memberof Metrics\n */\n initMediaPayload(eventType, identifiers, options = {}) {\n const {audioSetupDelay, videoSetupDelay, joinTimes} = options;\n\n const payload = {\n eventId: uuid.v4(),\n version: 1,\n origin: {\n audioSetupDelay,\n videoSetupDelay,\n name: 'endpoint',\n networkType: options.networkType || UNKNOWN,\n userAgent: this.userAgentToString(),\n clientInfo: {\n clientType: options.clientType, // TODO: Only clientType: 'TEAMS_CLIENT' is whitelisted\n clientVersion: `${CLIENT_NAME}/${this.webex.version}`,\n localNetworkPrefix: anonymizeIPAddress(this.webex.meetings.geoHintInfo?.clientAddress),\n os: this.getOsName(),\n osVersion: getOSVersion() || UNKNOWN,\n subClientType: options.subClientType,\n browser: getBrowserName(),\n browserVersion: getBrowserVersion()\n }\n },\n originTime: {\n triggered: new Date().toISOString()\n },\n senderCountryCode: this.webex.meetings.geoHintInfo?.countryCode,\n event: {\n name: eventType,\n canProceed: true,\n identifiers,\n intervals: [options.intervalData],\n joinTimes,\n eventData: {\n webClientDomain: window.location.hostname\n },\n sourceMetadata: {\n applicationSoftwareType: CLIENT_NAME,\n applicationSoftwareVersion: this.webex.version,\n mediaEngineSoftwareType: getBrowserName() || 'browser',\n mediaEngineSoftwareVersion: getOSVersion() || UNKNOWN,\n startTime: new Date().toISOString()\n }\n }\n };\n\n return payload;\n }\n\n /**\n * This function Parses a Locus error and returns a diagnostic event payload.\n * It should keep updating from:\n * https://sqbu-github.cisco.com/WebExSquared/spark-client-framework/blob/master/spark-client-framework/Adapters/TelephonyAdapter/TelephonyAdapter.cpp#L920\n *\n * @param {Object} err the error Object from Locus response\n * @param {boolean} showToUser true if a toast is shown to user\n * @returns {{showToUser: boolean, category: string, errorDescription: string,\n * errorCode: number, errorData: *, fatal: boolean, name: string}}\n */\n parseLocusError(err, showToUser) {\n let errorCode;\n\n if (err && err.statusCode && err.statusCode >= 500) {\n errorCode = 1003;\n }\n else if (err && err.body && err.body.errorCode) {\n // locus error codes: https://sqbu-github.cisco.com/WebExSquared/locus/blob/master/server/src/main/resources/locus-error-codes.properties\n switch (ERROR_CODE[err.body.errorCode]) {\n case MEETING_ERRORS.FREE_USER_MAX_PARTICIPANTS_EXCEEDED:\n errorCode = 3007;\n break;\n case MEETING_ERRORS.PAID_USER_MAX_PARTICIPANTS_EXCEEDED:\n case MEETING_ERRORS.SERVICE_MAX_PARTICIPANTS_EXCEEDED:\n errorCode = 3002;\n break;\n case MEETING_ERRORS.INACTIVE:\n errorCode = 4001;\n break;\n case MEETING_ERRORS.EXCEEDED_MAX_JOINED_PARTICIPANTS:\n case MEETING_ERRORS.EXCEEDED_SERVICE_MAX_PARTICIPANTS:\n errorCode = 3001;\n break;\n case MEETING_ERRORS.MEETING_IS_LOCKED:\n errorCode = 4002;\n break;\n case MEETING_ERRORS.MEETING_IS_TERMINATING:\n errorCode = 4003;\n break;\n case MEETING_ERRORS.MEETING_REQUIRE_MODERATOR_PIN_INTENT:\n errorCode = 4004;\n break;\n case MEETING_ERRORS.MEETING_REQUIRE_MODERATOR_PIN:\n errorCode = 4005;\n break;\n case MEETING_ERRORS.MEETING_REQUIRE_MODERATOR_ROLE:\n errorCode = 4006;\n break;\n case MEETING_ERRORS.JOIN_RESTRICTED_USER:\n case MEETING_ERRORS.GET_RESTRICTED_USER:\n case MEETING_ERRORS.CREATE_MEDIA_RESTRICTED_USER:\n errorCode = 3005;\n break;\n case MEETING_ERRORS.JOIN_RESTRICTED_USER_NOT_IN_ROOM:\n errorCode = 4007;\n break;\n case MEETING_ERRORS.MEETING_NOT_FOUND:\n errorCode = 4011;\n break;\n case MEETING_ERRORS.NOT_WEBEX_SITE:\n errorCode = 4012;\n break;\n case MEETING_ERRORS.INVALID_JOIN_TIME:\n errorCode = 4013;\n break;\n case MEETING_ERRORS.PHONE_NUMBER_NOT_A_NUMBER:\n errorCode = 4016;\n break;\n case MEETING_ERRORS.PHONE_NUMBER_TOO_LONG:\n errorCode = 4017;\n break;\n case MEETING_ERRORS.INVALID_DIALABLE_KEY:\n errorCode = 4018;\n break;\n case MEETING_ERRORS.ONE_ON_ONE_TO_SELF_NOT_ALLOWED:\n errorCode = 4019;\n break;\n case MEETING_ERRORS.REMOVED_PARTICIPANT:\n errorCode = 4020;\n break;\n case MEETING_ERRORS.MEETING_LINK_NOT_FOUND:\n errorCode = 4021;\n break;\n case MEETING_ERRORS.PHONE_NUMBER_TOO_SHORT_AFTER_IDD:\n errorCode = 4022;\n break;\n case MEETING_ERRORS.INVALID_INVITEE_ADDRESS:\n errorCode = 4023;\n break;\n case MEETING_ERRORS.PMR_ACCOUNT_LOCKED:\n errorCode = 4024;\n break;\n case MEETING_ERRORS.RESOURCE_GUEST_FORBIDDEN:\n errorCode = 4025;\n break;\n case MEETING_ERRORS.PMR_ACCOUNT_SUSPENDED:\n errorCode = 4026;\n break;\n case MEETING_ERRORS.EMPTY_PHONE_NUMBER_OR_COUNTRY_CODE:\n errorCode = 4027;\n break;\n case MEETING_ERRORS.INVALID_SINCE_OR_SEQUENCE_HASH_IN_REQUEST:\n errorCode = 1006;\n break;\n case MEETING_ERRORS.CONVERSATION_NOT_FOUND:\n errorCode = 4028;\n break;\n case MEETING_ERRORS.RECORDING_CONTROL_NOT_SUPPORTED:\n case MEETING_ERRORS.RECORDING_NOT_STARTED:\n case MEETING_ERRORS.RECORDING_NOT_ENABLED:\n errorCode = 4029;\n break;\n default:\n errorCode = 4008;\n }\n }\n else {\n errorCode = 4008;\n }\n\n return this.generateErrorPayload(\n errorCode, showToUser, error.name.LOCUS_RESPONSE, err\n );\n }\n\n\n generateErrorPayload(errorCode, shownToUser, name, err) {\n if (error.errors[errorCode]) {\n const errorPayload = {\n shownToUser: shownToUser || false,\n category: error.errors[errorCode][2],\n errorDescription: error.errors[errorCode][0],\n errorCode,\n fatal: !includes(error.notFatalErrorList, errorCode),\n name: name || error.name.OTHER\n };\n\n if (err && err.body) {\n errorPayload.errorData = err.body;\n }\n\n if (err && err.statusCode) {\n errorPayload.httpCode = err.statusCode;\n }\n\n return errorPayload;\n }\n\n return null;\n }\n\n /**\n * Returns a formated string of the user agent.\n *\n * @returns {string} formatted user agent information\n */\n userAgentToString() {\n let userAgentOption;\n let browserInfo;\n const clientInfo = util.format('client=%s', `${this.webex.meetings?.metrics?.clientName}`);\n\n if (['chrome', 'firefox', 'msie', 'msedge', 'safari'].indexOf(getBrowserName().toLowerCase()) !== -1) {\n browserInfo = util.format('browser=%s', `${getBrowserName().toLowerCase()}/${getBrowserVersion().split('.')[0]}`);\n }\n const osInfo = util.format('os=%s', `${getOSName()}/${getOSVersion().split('.')[0]}`);\n\n if (browserInfo) {\n userAgentOption = `(${browserInfo}`;\n }\n if (osInfo) {\n userAgentOption = userAgentOption ? `${userAgentOption}; ${clientInfo}; ${osInfo}` : `${clientInfo}; (${osInfo}`;\n }\n if (userAgentOption) {\n userAgentOption += ')';\n\n return util.format('webex-js-sdk/%s %s', `${process.env.NODE_ENV}-${this.webex.version}`, userAgentOption);\n }\n\n return util.format('webex-js-sdk/%s', `${process.env.NODE_ENV}-${this.webex.version}`);\n }\n\n /**\n * Uploads given metric to the Metrics service as an Behavioral metric.\n * Metadata about the environment such as browser, OS, SDK and their versions\n * are automatically added when the metric is sent.\n *\n * The Metrics service will send an Behavioral metric to InfluxDB for\n * aggregation.\n * See https://confluence-eng-gpk2.cisco.com/conf/display/WBXT/Getting+started+with+Metrics+Service.\n *\n * @param {string} metricName Name of the metric (measurement) to send\n * @param {Object} metricFields Key-valye pairs of data or values about this metric\n * @param {Object} metricTags Key-value pairs of metric metadata\n *\n * @returns {void}\n */\n sendBehavioralMetric(metricName, metricFields = {}, metricTags = {}) {\n this.webex.internal.metrics.submitClientMetrics(metricName, {\n type: this.webex.config.metrics.type,\n fields: metricFields,\n tags: metricTags\n });\n }\n}\n\n// Export Metrics singleton ---------------------------------------------------\nconst instance = new Metrics();\n\nexport default instance;\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["OSMap","OS_NAME","chrome","macOS","MAC","Windows","WINDOWS","iOS","IOS","Android","ANDROID","Linux","LINUX","BrowserDetection","getOSName","getOSVersion","getBrowserName","getBrowserVersion","anonymizeIPAddress","localIp","anonymize","triggerTimers","event","meeting","data","eventType","CALL_INITIATED","setStartCallInitiateJoinReq","LOCUS_JOIN_REQUEST","setEndCallInitiateJoinReq","setStartJoinReqResp","LOCUS_JOIN_RESPONSE","setEndJoinReqResp","setStartSetupDelay","mediaType","AUDIO","VIDEO","setStartSendingMediaDelay","RECEIVING_MEDIA_START","setEndSetupDelay","SENDING_MEDIA_START","setEndSendingMediaDelay","LOCAL_SDP_GENERATED","setStartLocalSDPGenRemoteSDPRecvDelay","REMOTE_SDP_RECEIVED","setEndLocalSDPGenRemoteSDPRecvDelay","Metrics","instance","_events","meetingCollection","keys","webex","options","meetingId","indexOf","LoggerProxy","logger","error","get","callEvents","MEDIA_QUALITY","sendMediaQualityAnalyzerMetrics","push","sendCallAnalyzerMetrics","info","identifiers","payload","eventId","uuid","v4","version","origin","name","networkType","userAgent","userAgentToString","clientInfo","clientType","clientVersion","CLIENT_NAME","localNetworkPrefix","meetings","geoHintInfo","clientAddress","osVersion","subClientType","os","getOsName","browser","browserVersion","originTime","triggered","Date","toISOString","senderCountryCode","countryCode","canProceed","eventData","webClientDomain","window","location","hostname","Object","prototype","hasOwnProperty","call","errors","trigger","pstnAudioType","mediaCapabilities","recoveredBy","joinTimes","isRoapCallEnabled","OTHERS","audioSetupDelay","videoSetupDelay","UNKNOWN","intervals","intervalData","sourceMetadata","applicationSoftwareType","applicationSoftwareVersion","mediaEngineSoftwareType","mediaEngineSoftwareVersion","startTime","err","showToUser","errorCode","statusCode","body","ERROR_CODE","MEETING_ERRORS","FREE_USER_MAX_PARTICIPANTS_EXCEEDED","PAID_USER_MAX_PARTICIPANTS_EXCEEDED","SERVICE_MAX_PARTICIPANTS_EXCEEDED","INACTIVE","EXCEEDED_MAX_JOINED_PARTICIPANTS","EXCEEDED_SERVICE_MAX_PARTICIPANTS","MEETING_IS_LOCKED","MEETING_IS_TERMINATING","MEETING_REQUIRE_MODERATOR_PIN_INTENT","MEETING_REQUIRE_MODERATOR_PIN","MEETING_REQUIRE_MODERATOR_ROLE","JOIN_RESTRICTED_USER","GET_RESTRICTED_USER","CREATE_MEDIA_RESTRICTED_USER","JOIN_RESTRICTED_USER_NOT_IN_ROOM","MEETING_NOT_FOUND","NOT_WEBEX_SITE","INVALID_JOIN_TIME","PHONE_NUMBER_NOT_A_NUMBER","PHONE_NUMBER_TOO_LONG","INVALID_DIALABLE_KEY","ONE_ON_ONE_TO_SELF_NOT_ALLOWED","REMOVED_PARTICIPANT","MEETING_LINK_NOT_FOUND","PHONE_NUMBER_TOO_SHORT_AFTER_IDD","INVALID_INVITEE_ADDRESS","PMR_ACCOUNT_LOCKED","RESOURCE_GUEST_FORBIDDEN","PMR_ACCOUNT_SUSPENDED","EMPTY_PHONE_NUMBER_OR_COUNTRY_CODE","INVALID_SINCE_OR_SEQUENCE_HASH_IN_REQUEST","CONVERSATION_NOT_FOUND","RECORDING_CONTROL_NOT_SUPPORTED","RECORDING_NOT_STARTED","RECORDING_NOT_ENABLED","generateErrorPayload","LOCUS_RESPONSE","shownToUser","errorPayload","category","errorDescription","fatal","notFatalErrorList","OTHER","errorData","httpCode","userAgentOption","browserInfo","util","format","metrics","clientName","toLowerCase","split","osInfo","process","env","NODE_ENV","metricName","metricFields","metricTags","internal","submitClientMetrics","type","config","fields","tags"],"sources":["index.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\nimport util from 'util';\n\nimport {includes} from 'lodash';\nimport uuid from 'uuid';\nimport window from 'global/window';\nimport anonymize from 'ip-anonymize';\n\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport {MEETING_ERRORS} from '../constants';\nimport BrowserDetection from '../common/browser-detection';\n\nimport {\n error, eventType, errorCodes as ERROR_CODE, OS_NAME, UNKNOWN, CLIENT_NAME,\n mediaType\n} from './config';\n\nconst OSMap = {\n 'Chrome OS': OS_NAME.chrome,\n macOS: OS_NAME.MAC,\n Windows: OS_NAME.WINDOWS,\n iOS: OS_NAME.IOS,\n Android: OS_NAME.ANDROID,\n Linux: OS_NAME.LINUX\n};\n\nconst {\n getOSName,\n getOSVersion,\n getBrowserName,\n getBrowserVersion\n} = BrowserDetection();\n\n// Apply a CIDR /28 format to the IPV4 and /96 to the IPV6 addresses\n// For reference : https://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing\nconst anonymizeIPAddress = (localIp) => anonymize(localIp, 28, 96);\n\nconst triggerTimers = ({event, meeting, data}) => {\n switch (event) {\n case eventType.CALL_INITIATED:\n meeting.setStartCallInitiateJoinReq();\n break;\n case eventType.LOCUS_JOIN_REQUEST:\n meeting.setEndCallInitiateJoinReq();\n meeting.setStartJoinReqResp();\n break;\n case eventType.LOCUS_JOIN_RESPONSE:\n meeting.setEndJoinReqResp();\n meeting.setStartSetupDelay(mediaType.AUDIO);\n meeting.setStartSetupDelay(mediaType.VIDEO);\n meeting.setStartSendingMediaDelay(mediaType.AUDIO);\n meeting.setStartSendingMediaDelay(mediaType.VIDEO);\n break;\n case eventType.RECEIVING_MEDIA_START:\n meeting.setEndSetupDelay(data.mediaType);\n break;\n case eventType.SENDING_MEDIA_START:\n meeting.setEndSendingMediaDelay(data.mediaType);\n break;\n case eventType.LOCAL_SDP_GENERATED:\n meeting.setStartLocalSDPGenRemoteSDPRecvDelay();\n break;\n case eventType.REMOTE_SDP_RECEIVED:\n meeting.setEndLocalSDPGenRemoteSDPRecvDelay();\n break;\n default:\n break;\n }\n};\n\n/**\n * @description Metrics handles all the call metrics events\n * @export\n * @class Metrics\n */\nclass Metrics {\n /**\n * Create Metrics Object\n * @constructor\n * @public\n * @memberof Meetings\n */\n constructor() {\n if (!Metrics.instance) {\n /**\n * @instance\n * @type {Array}\n * @private\n * @memberof Metrics\n */\n this._events = [];\n /**\n * @instance\n * @type {MeetingCollection}\n * @private\n * @memberof Metrics\n */\n this.meetingCollection = null;\n /**\n * @instance\n * @type {MeetingCollection}\n * @private\n * @memberof Metrics\n */\n this.keys = Object.values(eventType);\n /**\n * @instance\n * @type {Metrics}\n * @private\n * @memberof Metrics\n */\n Metrics.instance = this;\n }\n\n return Metrics.instance;\n }\n\n /**\n * Initializes the Metrics singleton with a meeting Collection.\n *\n * @param {Object} meetingCollection meetings object\n * @param {Object} webex webex SDK object\n *\n * @returns {void}\n */\n initialSetup(meetingCollection, webex) {\n this.meetingCollection = meetingCollection;\n this.webex = webex;\n }\n\n /**\n * poste Meeting event metrics\n * @param {object} options {meetingId/meeting} as a json object\n * @param {Meeting} options.meeting Meeting object\n * @param {String} options.meetingId\n * @param {object} options.data\n * @param {object} options.event\n * @returns {object} null\n */\n postEvent(options) {\n const {meetingId, data = {}, event} = options;\n let {meeting} = options;\n\n if (this.keys.indexOf(event) === -1) {\n LoggerProxy.logger.error(`Metrics:index#postEvent --> Event ${event} doesn't exist in dictionary`);\n }\n\n if (!meeting && meetingId) {\n meeting = this.meetingCollection.get(meetingId);\n options.meeting = meeting;\n }\n\n if (meeting) {\n triggerTimers(options);\n\n if (!meeting.callEvents) {\n meeting.callEvents = [];\n }\n if (event === eventType.MEDIA_QUALITY) {\n data.event = event;\n meeting.sendMediaQualityAnalyzerMetrics(data);\n }\n else {\n meeting.callEvents.push(event);\n data.event = event;\n meeting.sendCallAnalyzerMetrics(data);\n }\n }\n\n else {\n LoggerProxy.logger.info(`Metrics:index#postEvent --> Event received for meetingId:${meetingId}, but meeting not found in collection.`);\n }\n }\n\n /**\n * Docs for Call analyzer metrics\n * https://sqbu-github.cisco.com/WebExSquared/call-analyzer/wiki\n * https://sqbu-github.cisco.com/WebExSquared/event-dictionary/blob/master/diagnostic-events.raml\n */\n\n initPayload(eventType, identifiers, options) {\n const payload = {\n eventId: uuid.v4(),\n version: 1,\n origin: {\n name: 'endpoint',\n networkType: 'unknown',\n userAgent: this.userAgentToString(),\n clientInfo: {\n clientType: options.clientType,\n clientVersion: `${CLIENT_NAME}/${this.webex.version}`,\n localNetworkPrefix: anonymizeIPAddress(this.webex.meetings.geoHintInfo?.clientAddress),\n osVersion: getOSVersion() || 'unknown',\n subClientType: options.subClientType,\n os: this.getOsName(),\n browser: getBrowserName(),\n browserVersion: getBrowserVersion()\n }\n },\n originTime: {\n triggered: new Date().toISOString()\n },\n senderCountryCode: this.webex.meetings.geoHintInfo?.countryCode,\n event: {\n name: eventType,\n canProceed: true,\n identifiers,\n eventData: {webClientDomain: window.location.hostname}\n }\n };\n\n // TODO: more options should be checked and some of them should be mandatory in certain conditions\n if (options) {\n if (Object.prototype.hasOwnProperty.call(options, 'canProceed')) {\n payload.event.canProceed = options.canProceed;\n }\n if (options.errors) {\n payload.event.errors = options.errors;\n }\n if (options.mediaType) {\n payload.event.mediaType = options.mediaType;\n }\n if (options.trigger) {\n payload.event.trigger = options.trigger;\n }\n if (options.pstnAudioType) {\n payload.event.pstnAudioType = options.pstnAudioType;\n }\n if (options.mediaCapabilities) {\n payload.event.mediaCapabilities = options.mediaCapabilities;\n }\n if (options.recoveredBy) {\n payload.event.recoveredBy = options.recoveredBy;\n }\n if (options.joinTimes) {\n payload.event.joinTimes = options.joinTimes;\n }\n if (options.isRoapCallEnabled) {\n payload.event.isRoapCallEnabled = options.isRoapCallEnabled;\n }\n }\n\n return payload;\n }\n\n /**\n * returns metrics friendly OS versions\n * @param {String} osName Os name\n * @returns {String}\n * @private\n * @memberof Metrics\n */\n getOsName() {\n return OSMap[getOSName()] ?? OS_NAME.OTHERS;\n }\n\n /**\n * get the payload specific for a media quality event through call analyzer\n * @param {String} eventType the event name\n * @param {Object} identifiers contains the identifiers needed for CA\n * @param {String} identifiers.correlationId\n * @param {String} identifiers.locusUrl\n * @param {String} identifiers.locusId\n * @param {Object} options\n * @param {Object} options.intervalData\n * @param {String} options.clientType\n * @returns {Object}\n * @public\n * @memberof Metrics\n */\n initMediaPayload(eventType, identifiers, options = {}) {\n const {audioSetupDelay, videoSetupDelay, joinTimes} = options;\n\n const payload = {\n eventId: uuid.v4(),\n version: 1,\n origin: {\n audioSetupDelay,\n videoSetupDelay,\n name: 'endpoint',\n networkType: options.networkType || UNKNOWN,\n userAgent: this.userAgentToString(),\n clientInfo: {\n clientType: options.clientType, // TODO: Only clientType: 'TEAMS_CLIENT' is whitelisted\n clientVersion: `${CLIENT_NAME}/${this.webex.version}`,\n localNetworkPrefix: anonymizeIPAddress(this.webex.meetings.geoHintInfo?.clientAddress),\n os: this.getOsName(),\n osVersion: getOSVersion() || UNKNOWN,\n subClientType: options.subClientType,\n browser: getBrowserName(),\n browserVersion: getBrowserVersion()\n }\n },\n originTime: {\n triggered: new Date().toISOString()\n },\n senderCountryCode: this.webex.meetings.geoHintInfo?.countryCode,\n event: {\n name: eventType,\n canProceed: true,\n identifiers,\n intervals: [options.intervalData],\n joinTimes,\n eventData: {\n webClientDomain: window.location.hostname\n },\n sourceMetadata: {\n applicationSoftwareType: CLIENT_NAME,\n applicationSoftwareVersion: this.webex.version,\n mediaEngineSoftwareType: getBrowserName() || 'browser',\n mediaEngineSoftwareVersion: getOSVersion() || UNKNOWN,\n startTime: new Date().toISOString()\n }\n }\n };\n\n return payload;\n }\n\n /**\n * This function Parses a Locus error and returns a diagnostic event payload.\n * It should keep updating from:\n * https://sqbu-github.cisco.com/WebExSquared/spark-client-framework/blob/master/spark-client-framework/Adapters/TelephonyAdapter/TelephonyAdapter.cpp#L920\n *\n * @param {Object} err the error Object from Locus response\n * @param {boolean} showToUser true if a toast is shown to user\n * @returns {{showToUser: boolean, category: string, errorDescription: string,\n * errorCode: number, errorData: *, fatal: boolean, name: string}}\n */\n parseLocusError(err, showToUser) {\n let errorCode;\n\n if (err && err.statusCode && err.statusCode >= 500) {\n errorCode = 1003;\n }\n else if (err && err.body && err.body.errorCode) {\n // locus error codes: https://sqbu-github.cisco.com/WebExSquared/locus/blob/master/server/src/main/resources/locus-error-codes.properties\n switch (ERROR_CODE[err.body.errorCode]) {\n case MEETING_ERRORS.FREE_USER_MAX_PARTICIPANTS_EXCEEDED:\n errorCode = 3007;\n break;\n case MEETING_ERRORS.PAID_USER_MAX_PARTICIPANTS_EXCEEDED:\n case MEETING_ERRORS.SERVICE_MAX_PARTICIPANTS_EXCEEDED:\n errorCode = 3002;\n break;\n case MEETING_ERRORS.INACTIVE:\n errorCode = 4001;\n break;\n case MEETING_ERRORS.EXCEEDED_MAX_JOINED_PARTICIPANTS:\n case MEETING_ERRORS.EXCEEDED_SERVICE_MAX_PARTICIPANTS:\n errorCode = 3001;\n break;\n case MEETING_ERRORS.MEETING_IS_LOCKED:\n errorCode = 4002;\n break;\n case MEETING_ERRORS.MEETING_IS_TERMINATING:\n errorCode = 4003;\n break;\n case MEETING_ERRORS.MEETING_REQUIRE_MODERATOR_PIN_INTENT:\n errorCode = 4004;\n break;\n case MEETING_ERRORS.MEETING_REQUIRE_MODERATOR_PIN:\n errorCode = 4005;\n break;\n case MEETING_ERRORS.MEETING_REQUIRE_MODERATOR_ROLE:\n errorCode = 4006;\n break;\n case MEETING_ERRORS.JOIN_RESTRICTED_USER:\n case MEETING_ERRORS.GET_RESTRICTED_USER:\n case MEETING_ERRORS.CREATE_MEDIA_RESTRICTED_USER:\n errorCode = 3005;\n break;\n case MEETING_ERRORS.JOIN_RESTRICTED_USER_NOT_IN_ROOM:\n errorCode = 4007;\n break;\n case MEETING_ERRORS.MEETING_NOT_FOUND:\n errorCode = 4011;\n break;\n case MEETING_ERRORS.NOT_WEBEX_SITE:\n errorCode = 4012;\n break;\n case MEETING_ERRORS.INVALID_JOIN_TIME:\n errorCode = 4013;\n break;\n case MEETING_ERRORS.PHONE_NUMBER_NOT_A_NUMBER:\n errorCode = 4016;\n break;\n case MEETING_ERRORS.PHONE_NUMBER_TOO_LONG:\n errorCode = 4017;\n break;\n case MEETING_ERRORS.INVALID_DIALABLE_KEY:\n errorCode = 4018;\n break;\n case MEETING_ERRORS.ONE_ON_ONE_TO_SELF_NOT_ALLOWED:\n errorCode = 4019;\n break;\n case MEETING_ERRORS.REMOVED_PARTICIPANT:\n errorCode = 4020;\n break;\n case MEETING_ERRORS.MEETING_LINK_NOT_FOUND:\n errorCode = 4021;\n break;\n case MEETING_ERRORS.PHONE_NUMBER_TOO_SHORT_AFTER_IDD:\n errorCode = 4022;\n break;\n case MEETING_ERRORS.INVALID_INVITEE_ADDRESS:\n errorCode = 4023;\n break;\n case MEETING_ERRORS.PMR_ACCOUNT_LOCKED:\n errorCode = 4024;\n break;\n case MEETING_ERRORS.RESOURCE_GUEST_FORBIDDEN:\n errorCode = 4025;\n break;\n case MEETING_ERRORS.PMR_ACCOUNT_SUSPENDED:\n errorCode = 4026;\n break;\n case MEETING_ERRORS.EMPTY_PHONE_NUMBER_OR_COUNTRY_CODE:\n errorCode = 4027;\n break;\n case MEETING_ERRORS.INVALID_SINCE_OR_SEQUENCE_HASH_IN_REQUEST:\n errorCode = 1006;\n break;\n case MEETING_ERRORS.CONVERSATION_NOT_FOUND:\n errorCode = 4028;\n break;\n case MEETING_ERRORS.RECORDING_CONTROL_NOT_SUPPORTED:\n case MEETING_ERRORS.RECORDING_NOT_STARTED:\n case MEETING_ERRORS.RECORDING_NOT_ENABLED:\n errorCode = 4029;\n break;\n default:\n errorCode = 4008;\n }\n }\n else {\n errorCode = 4008;\n }\n\n return this.generateErrorPayload(\n errorCode, showToUser, error.name.LOCUS_RESPONSE, err\n );\n }\n\n\n generateErrorPayload(errorCode, shownToUser, name, err) {\n if (error.errors[errorCode]) {\n const errorPayload = {\n shownToUser: shownToUser || false,\n category: error.errors[errorCode][2],\n errorDescription: error.errors[errorCode][0],\n errorCode,\n fatal: !includes(error.notFatalErrorList, errorCode),\n name: name || error.name.OTHER\n };\n\n if (err && err.body) {\n errorPayload.errorData = err.body;\n }\n\n if (err && err.statusCode) {\n errorPayload.httpCode = err.statusCode;\n }\n\n return errorPayload;\n }\n\n return null;\n }\n\n /**\n * Returns a formated string of the user agent.\n *\n * @returns {string} formatted user agent information\n */\n userAgentToString() {\n let userAgentOption;\n let browserInfo;\n const clientInfo = util.format('client=%s', `${this.webex.meetings?.metrics?.clientName}`);\n\n if (['chrome', 'firefox', 'msie', 'msedge', 'safari'].indexOf(getBrowserName().toLowerCase()) !== -1) {\n browserInfo = util.format('browser=%s', `${getBrowserName().toLowerCase()}/${getBrowserVersion().split('.')[0]}`);\n }\n const osInfo = util.format('os=%s', `${getOSName()}/${getOSVersion().split('.')[0]}`);\n\n if (browserInfo) {\n userAgentOption = `(${browserInfo}`;\n }\n if (osInfo) {\n userAgentOption = userAgentOption ? `${userAgentOption}; ${clientInfo}; ${osInfo}` : `${clientInfo}; (${osInfo}`;\n }\n if (userAgentOption) {\n userAgentOption += ')';\n\n return util.format('webex-js-sdk/%s %s', `${process.env.NODE_ENV}-${this.webex.version}`, userAgentOption);\n }\n\n return util.format('webex-js-sdk/%s', `${process.env.NODE_ENV}-${this.webex.version}`);\n }\n\n /**\n * Uploads given metric to the Metrics service as an Behavioral metric.\n * Metadata about the environment such as browser, OS, SDK and their versions\n * are automatically added when the metric is sent.\n *\n * The Metrics service will send an Behavioral metric to InfluxDB for\n * aggregation.\n * See https://confluence-eng-gpk2.cisco.com/conf/display/WBXT/Getting+started+with+Metrics+Service.\n *\n * @param {string} metricName Name of the metric (measurement) to send\n * @param {Object} metricFields Key-valye pairs of data or values about this metric\n * @param {Object} metricTags Key-value pairs of metric metadata\n *\n * @returns {void}\n */\n sendBehavioralMetric(metricName, metricFields = {}, metricTags = {}) {\n this.webex.internal.metrics.submitClientMetrics(metricName, {\n type: this.webex.config.metrics.type,\n fields: metricFields,\n tags: metricTags\n });\n }\n}\n\n// Export Metrics singleton ---------------------------------------------------\nconst instance = new Metrics();\n\nexport default instance;\n"],"mappings":"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"}
|
|
@@ -158,7 +158,7 @@ var isSdpInvalid = function isSdpInvalid(sdp) {
|
|
|
158
158
|
var mediaLine = _step.value;
|
|
159
159
|
|
|
160
160
|
if (!mediaLine.candidates || ((_mediaLine$candidates = mediaLine.candidates) === null || _mediaLine$candidates === void 0 ? void 0 : _mediaLine$candidates.length) === 0) {
|
|
161
|
-
_loggerProxy.default.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Ice
|
|
161
|
+
_loggerProxy.default.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Ice candidate never completed');
|
|
162
162
|
|
|
163
163
|
return 'iceCandidate: Ice gathering never completed';
|
|
164
164
|
}
|
|
@@ -415,7 +415,7 @@ pc.setRemoteSessionDetails = function (peerConnection, typeStr, remoteSdp, meeti
|
|
|
415
415
|
return _promise.default.reject(new _media.default('PeerConnection in wrong state'));
|
|
416
416
|
};
|
|
417
417
|
/**
|
|
418
|
-
*
|
|
418
|
+
* Create offer with a valid parameter
|
|
419
419
|
* @param {Object} peerConnection
|
|
420
420
|
* @param {Object} meetingProperties
|
|
421
421
|
* @param {string} meetingProperties.meetingId
|
|
@@ -438,7 +438,7 @@ pc.createOffer = function (peerConnection, _ref2) {
|
|
|
438
438
|
peerConnection.enableExtmap = enableExtmap;
|
|
439
439
|
return peerConnection.createOffer().then(function (description) {
|
|
440
440
|
// bug https://bugs.chromium.org/p/chromium/issues/detail?id=1020642
|
|
441
|
-
// chrome currently generates RTX line irrespective of
|
|
441
|
+
// chrome currently generates RTX line irrespective of whether the server side supports it
|
|
442
442
|
// we are removing apt as well because its associated with rtx line
|
|
443
443
|
if (!enableRtx) {
|
|
444
444
|
description.sdp = description.sdp.replace(/\r\na=rtpmap:\d+ rtx\/\d+/g, '');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["BrowserDetection","isBrowser","pc","insertBandwidthLimit","sdpLines","index","limit","periodicKeyFrame","search","AUDIO","StaticConfig","meetings","bandwidth","audio","video","SDP","PERIODIC_KEYFRAME","splice","B_LINE","setMaxFs","sdp","level","QUALITY_LEVELS","HIGH","MAX_FRAMESIZES","ParameterError","replaceSdp","maxFsLine","MAX_FS","replace","setStartBitrateOnRemoteSdp","startBitrate","checkH264Support","videoPresent","match","h264Present","isSdpInvalid","parsedSdp","sdpTransform","parse","media","mediaLine","candidates","length","LoggerProxy","logger","error","BAD_MEDIA_PORTS","includes","port","icePwd","iceUfrag","limitBandwidth","offerSdp","split","CARRIAGE_RETURN","i","M_LINE","join","setContentSlides","screenPc","A_CONTENT_SLIDES","iceCandidate","peerConnection","remoteQualityLevel","resolve","reject","now","doneGatheringIceCandidate","miliseconds","Math","abs","localDescription","PeerConnectionUtils","convertCLineToIpv4","invalidSdpPresent","InvalidSdpError","log","iceGatheringState","COMPLETE","onIceGatheringStateChange","GATHERING","onicecandidate","evt","candidate","type","protocol","address","onicecandidateerror","event","replaceTrack","track","senders","getSenders","forEach","sender","kind","err","addStream","stream","tracksPresent","find","getTracks","addTrack","setRemoteSessionDetails","typeStr","remoteSdp","meetingId","signalingState","Metrics","postEvent","eventType","REMOTE_SDP_RECEIVED","data","canProceed","errors","generateErrorPayload","name","MEDIA_ENGINE","HAVE_LOCAL_OFFER","STABLE","OFFER","enableExtmap","setRemoteDescription","window","RTCSessionDescription","then","catch","metricName","BEHAVIORAL_METRICS","PEERCONNECTION_FAILURE","correlation_id","reason","message","stack","metadata","sendBehavioralMetric","MediaError","createOffer","enableRtx","description","setLocalDescription","LOCAL_SDP_GENERATED","INVALID_ICE_CANDIDATE","code","close","rollBackLocalDescription","ROLLBACK","updatePeerConnection","params","createAnswer","peerconnection","HAVE_REMOTE_OFFER","sdpConstraints","answer","connectionState","PEER_CONNECTION_STATE","CLOSED","setPeerConnectionEvents","meeting","mediaProperties","connectionFailed","reconnectionManager","iceState","reconnect","networkDisconnect","ICE_END","uploadLogs","file","function","CONNECTION_FAILURE","correlationId","locus_id","locusId","oniceconnectionstatechange","info","iceConnectionState","ICE_STATE","CHECKING","ICE_START","COMPLETED","CONNECTED","CONNECTION_SUCCESS","setNetworkStatus","NETWORK_STATUS","iceReconnected","DISCONNECTED","waitForIceReconnect","FAILED","onconnectionstatechange","CONNECTION_STATE","NEW","CONNECTING"],"sources":["index.js"],"sourcesContent":["\n// We need to figure out how to pass a webex logger instance to these util files\n\n/* globals RTCSessionDescription */\n\nimport window from 'global/window';\nimport sdpTransform from 'sdp-transform'; // https://github.com/clux/sdp-transform\n\nimport Metrics from '../metrics';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport StaticConfig from '../common/config';\nimport {\n COMPLETE,\n GATHERING,\n AUDIO,\n SDP,\n ICE_STATE,\n CONNECTION_STATE,\n NETWORK_STATUS,\n PEER_CONNECTION_STATE,\n OFFER,\n QUALITY_LEVELS,\n MAX_FRAMESIZES\n} from '../constants';\nimport BEHAVIORAL_METRICS from '../metrics/constants';\nimport {error, eventType} from '../metrics/config';\nimport MediaError from '../common/errors/media';\nimport ParameterError from '../common/errors/parameter';\nimport {InvalidSdpError} from '../common/errors/webex-errors';\nimport BrowserDetection from '../common/browser-detection';\n\nimport PeerConnectionUtils from './util';\n\nconst {isBrowser} = BrowserDetection();\n\n/**\n * @export\n * @public\n */\nconst pc = {};\n\n/**\n * munges the bandwidth limit into the sdp\n * @param {String} sdpLines\n * @param {Number} index\n * @returns {String}\n */\nconst insertBandwidthLimit = (sdpLines, index) => {\n // eslint-disable-next-line no-warning-comments\n // TODO convert to sdp parser\n let limit;\n let periodicKeyFrame = '';\n\n if (sdpLines[index].search(AUDIO) !== -1) {\n limit = StaticConfig.meetings.bandwidth.audio;\n }\n else {\n limit = StaticConfig.meetings.bandwidth.video;\n periodicKeyFrame = SDP.PERIODIC_KEYFRAME;\n sdpLines.splice(index + 2, 0, periodicKeyFrame);\n }\n sdpLines.splice(index + 1, 0, `${SDP.B_LINE}:${limit}`);\n\n return sdpLines;\n};\n\n/**\n * needed for calliope max-fs\n * @param {String} sdp\n * @param {String} [level=QUALITY_LEVELS.HIGH] quality level for max-fs\n * @returns {String}\n */\nconst setMaxFs = (sdp, level = QUALITY_LEVELS.HIGH) => {\n if (!MAX_FRAMESIZES[level]) {\n throw new ParameterError(`setMaxFs: unable to set max framesize, value for level \"${level}\" is not defined`);\n }\n // eslint-disable-next-line no-warning-comments\n // TODO convert with sdp parser, no munging\n let replaceSdp = sdp;\n const maxFsLine = `${SDP.MAX_FS}${MAX_FRAMESIZES[level]}`;\n\n replaceSdp = replaceSdp.replace(/(\\na=fmtp:(\\d+).*profile-level-id=.*)/gi, `$1;${maxFsLine}`);\n\n return replaceSdp;\n};\n\n\nconst setStartBitrateOnRemoteSdp = (sdp) => {\n if (StaticConfig.meetings.bandwidth.startBitrate) {\n sdp = sdp.replace(/(\\na=fmtp:(\\d+).*profile-level-id=.*)/gi, `$1;x-google-start-bitrate=${StaticConfig.meetings.bandwidth.startBitrate}`);\n }\n\n return sdp;\n};\n\n/**\n * checks that sdp has h264 codec in it\n * @param {String} sdp\n * @returns {boolean}\n */\nconst checkH264Support = (sdp) => {\n // eslint-disable-next-line no-warning-comments\n // TODO convert to sdp parser to read rtp.codec\n const videoPresent = sdp.match(/\\nm=video.*/g);\n const h264Present = sdp.match(/\\na=rtpmap:\\d+\\sH264.*/g);\n\n if (videoPresent) {\n return !!h264Present;\n }\n\n return true;\n};\n\n/**\n * validates the sdp, checks port, candidates, and ice info\n * @param {String} sdp\n * @returns {String}\n */\nconst isSdpInvalid = (sdp) => {\n const parsedSdp = sdpTransform.parse(sdp);\n\n for (const mediaLine of parsedSdp.media) {\n if (!mediaLine.candidates || mediaLine.candidates?.length === 0) {\n LoggerProxy.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Ice candadate never completed');\n\n return 'iceCandidate: Ice gathering never completed';\n }\n\n if (SDP.BAD_MEDIA_PORTS.includes(mediaLine.port)) {\n LoggerProxy.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Found invalid port number for the ice candidate');\n\n return 'iceCandidate: Found invalid port number for the ice candidate';\n }\n if (!mediaLine.icePwd || !mediaLine.iceUfrag) {\n LoggerProxy.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: ice ufrag and password not found');\n\n return 'iceCandidate: ice ufrag and password not found';\n }\n }\n\n return '';\n};\n\n/**\n * munges the bandwidth into the sdp\n * @param {String} sdp\n * @returns {String}\n */\nconst limitBandwidth = (sdp) => {\n // TODO convert to sdp parser\n let offerSdp = sdp;\n let sdpLines = offerSdp.split(SDP.CARRIAGE_RETURN);\n\n for (let i = 0; i < sdpLines.length; i += 1) {\n if (sdpLines[i].search(SDP.M_LINE) !== -1) {\n sdpLines = insertBandwidthLimit(sdpLines, i);\n }\n }\n offerSdp = sdpLines.join(SDP.CARRIAGE_RETURN);\n\n return offerSdp;\n};\n\n/**\n * makes sure the screen pc sdp has content:slides for server\n * @param {RTCPeerConnection} screenPc\n * @returns {RTCPeerConnection}\n */\npc.setContentSlides = (screenPc) => {\n if (screenPc && screenPc.sdp) {\n screenPc.sdp += `${SDP.A_CONTENT_SLIDES}${SDP.CARRIAGE_RETURN}`;\n }\n\n return screenPc;\n};\n\n/**\n * handles ice trickling and establishes ICE connection onto peer connection object\n * @param {Object} peerConnection\n * @param {Object} options\n * @param {String} options.remoteQualityLevel\n * @returns {Promise.RTCPeerConnection}\n */\npc.iceCandidate = (peerConnection, {remoteQualityLevel}) =>\n new Promise((resolve, reject) => {\n const now = Date.now();\n const doneGatheringIceCandidate = () => {\n const miliseconds = parseInt(Math.abs(Date.now() - now), 4);\n\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);\n peerConnection.sdp = PeerConnectionUtils.convertCLineToIpv4(peerConnection.sdp);\n\n const invalidSdpPresent = isSdpInvalid(peerConnection.sdp);\n\n if (invalidSdpPresent) {\n LoggerProxy.logger.error('PeerConnectionManager:index#iceCandidate --> SDP not valid after waiting.');\n reject(new InvalidSdpError(invalidSdpPresent));\n }\n LoggerProxy.logger.log(`PeerConnectionManager:index#iceCandidate --> Time to gather ice candidate ${miliseconds} miliseconds`);\n\n\n resolve();\n };\n\n // If ice has already been gathered\n if (peerConnection.iceGatheringState === COMPLETE) {\n doneGatheringIceCandidate();\n }\n\n peerConnection.onIceGatheringStateChange = () => {\n if (peerConnection.iceGatheringState === COMPLETE) {\n doneGatheringIceCandidate(peerConnection);\n }\n if (peerConnection.iceGatheringState === GATHERING) {\n LoggerProxy.logger.log('PeerConnectionManager:index#onIceGatheringStateChange --> Ice state changed to gathering');\n }\n };\n\n peerConnection.onicecandidate = (evt) => {\n if (evt.candidate === null) {\n doneGatheringIceCandidate(peerConnection);\n }\n else {\n LoggerProxy.logger.log(`PeerConnectionManager:index#onicecandidate --> Candidate ${evt.candidate?.type} ${evt.candidate?.protocol} ${evt.candidate?.address}:${evt.candidate?.port}`);\n }\n };\n\n peerConnection.onicecandidateerror = (event) => {\n // we can often get ICE candidate errors (for example when failing to communicate with a TURN server)\n // they don't mean that the whole ICE connection will fail, so it's OK to ignore them\n LoggerProxy.logger.error('PeerConnectionManager:index#onicecandidateerror --> ignoring ice error:', event);\n };\n });\n\n/**\n * swapping tracks\n * @param {Object} peerConnection\n * @param {Object} track\n * @returns {undefined}\n */\npc.replaceTrack = (peerConnection, track) => {\n try {\n const senders = peerConnection.getSenders();\n\n if (senders.length > 0) {\n senders.forEach((sender) => {\n if (sender.track && sender.track.kind === track.kind) {\n sender.replaceTrack(track);\n }\n });\n }\n }\n catch (err) {\n LoggerProxy.logger.error(`PeerConnectionManager:index#replaceTrack --> Error replacing track, ${err}`);\n }\n};\n\n/**\n * adding streams to peerConnection\n * @param {Object} peerConnection\n * @param {Object} stream\n * @returns {undefined}\n */\npc.addStream = (peerConnection, stream) => {\n try {\n if (stream && !isBrowser('edge')) {\n const tracksPresent = peerConnection.getSenders && peerConnection.getSenders().find((sender) => sender.track != null);\n\n if (tracksPresent) {\n stream.getTracks().forEach((track) => {\n pc.replaceTrack(peerConnection, track);\n });\n\n return;\n }\n stream.getTracks().forEach((track) => {\n peerConnection.addTrack(track, stream);\n });\n // // TODO : may come back disable addTracks for chrome they are moving back to addStream\n // // https://bugs.chromium.org/p/chromium/issues/detail?id=764414\n // // https://bugs.chromium.org/p/chromium/issues/detail?id=738918#c7\n // peerConnection.addStream(stream);\n }\n else if (isBrowser('edge')) {\n peerConnection.addStream(stream);\n }\n }\n catch (err) {\n LoggerProxy.logger.error(`PeerConnectionManager:index#addStream --> Error adding stream, error: ${error}`);\n }\n};\n\n/**\n * setting the remote description\n * @param {Object} peerConnection\n * @param {String} typeStr\n * @param {String} remoteSdp\n * @param {String} meetingId\n * @returns {undefined}\n */\npc.setRemoteSessionDetails = (\n peerConnection,\n typeStr,\n remoteSdp,\n meetingId,\n) => {\n LoggerProxy.logger.log(`PeerConnectionManager:index#setRemoteSessionDetails --> Setting the remote description type: ${typeStr}State: ${peerConnection.signalingState}`);\n let sdp = remoteSdp;\n\n // making sure that the remoteDescription is only set when there is a answer for offer\n // or there is a offer from the server\n\n if (!sdp) {\n Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId,\n data: {\n canProceed: false,\n errors: [Metrics.generateErrorPayload(2001, true,\n error.name.MEDIA_ENGINE, 'missing remoteSdp')]\n }\n });\n }\n if (peerConnection.signalingState === SDP.HAVE_LOCAL_OFFER || (peerConnection.signalingState === SDP.STABLE && typeStr === SDP.OFFER)) {\n sdp = setStartBitrateOnRemoteSdp(sdp);\n\n if (!peerConnection.enableExtmap) {\n sdp = sdp.replace(/\\na=extmap.*/g, '');\n }\n\n // remove any xtls candidates\n sdp = sdp.replace(/^a=candidate:.*xTLS.*\\r\\n/gim, '');\n\n return peerConnection.setRemoteDescription(\n new window.RTCSessionDescription({\n type: typeStr,\n sdp\n })\n )\n .then(() => {\n if (peerConnection.signalingState === SDP.STABLE) {\n Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId\n });\n }\n })\n .catch((error) => {\n LoggerProxy.logger.error(`Peer-connection-manager:index#setRemoteDescription --> ${error} missing remotesdp`);\n\n\n const metricName = BEHAVIORAL_METRICS.PEERCONNECTION_FAILURE;\n const data = {\n correlation_id: meetingId,\n reason: error.message,\n stack: error.stack\n };\n const metadata = {\n type: error.name\n };\n\n Metrics.sendBehavioralMetric(metricName, data, metadata);\n\n return Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId,\n data: {\n canProceed: false,\n errors: [Metrics.generateErrorPayload(2001, true,\n error.name.MEDIA_ENGINE, 'missing remoteSdp')]\n }\n });\n });\n }\n\n return Promise.reject(new MediaError('PeerConnection in wrong state'));\n};\n\n/**\n * create offer with a valid paramater\n * @param {Object} peerConnection\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @param {string} meetingProperties.enableRtx\n * @param {string} meetingProperties.enableExtmap\n * @returns {RTCPeerConnection}\n */\npc.createOffer = (peerConnection, {\n meetingId,\n remoteQualityLevel,\n enableRtx,\n enableExtmap\n}) => {\n LoggerProxy.logger.log('PeerConnectionManager:index#createOffer --> creating a new offer');\n\n // saving the extMap State to use in setRemoteDescription\n\n peerConnection.enableExtmap = enableExtmap;\n\n return peerConnection\n .createOffer()\n .then((description) => {\n // bug https://bugs.chromium.org/p/chromium/issues/detail?id=1020642\n // chrome currently generates RTX line irrespective of weither the server side supports it\n // we are removing apt as well because its associated with rtx line\n\n if (!enableRtx) {\n description.sdp = description.sdp.replace(/\\r\\na=rtpmap:\\d+ rtx\\/\\d+/g, '');\n description.sdp = description.sdp.replace(/\\r\\na=fmtp:\\d+ apt=\\d+/g, '');\n }\n\n return peerConnection.setLocalDescription(description);\n })\n .then(() => pc.iceCandidate(peerConnection, {remoteQualityLevel}))\n .then(() => {\n if (!checkH264Support(peerConnection.sdp)) {\n throw new MediaError('openH264 is downloading please Wait. Upload logs if not working on second try');\n }\n\n if (!enableExtmap) {\n peerConnection.sdp = peerConnection.sdp.replace(/\\na=extmap.*/g, '');\n }\n\n pc.setContentSlides(peerConnection);\n\n Metrics.postEvent({\n event: eventType.LOCAL_SDP_GENERATED,\n meetingId\n });\n\n return peerConnection;\n })\n .catch((error) => {\n LoggerProxy.logger.error(`Peer-connection-manager:index#createOffer --> ${error}`);\n if (error instanceof InvalidSdpError) {\n Metrics.sendBehavioralMetric(\n BEHAVIORAL_METRICS.INVALID_ICE_CANDIDATE,\n {\n correlation_id: meetingId,\n code: error.code,\n reason: error.message\n }\n );\n }\n else {\n const metricName = BEHAVIORAL_METRICS.PEERCONNECTION_FAILURE;\n const data = {\n correlation_id: meetingId,\n reason: error.message,\n stack: error.stack\n };\n const metadata = {\n type: error.name\n };\n\n Metrics.sendBehavioralMetric(metricName, data, metadata);\n }\n\n Metrics.postEvent({\n event: eventType.LOCAL_SDP_GENERATED,\n meetingId,\n data: {\n canProceed: false,\n errors: [\n Metrics.generateErrorPayload(2001, true,\n error.name.MEDIA_ENGINE)]\n }\n });\n pc.close(peerConnection);\n throw error;\n });\n};\n\n/**\n * rollBack local description in peerconnection\n * @param {Object} peerConnection\n * @returns {Promise.RTCPeerConnection}\n */\npc.rollBackLocalDescription = (peerConnection) => peerConnection\n .setLocalDescription(new RTCSessionDescription({type: SDP.ROLLBACK}))\n .then(() => peerConnection)\n .catch((err) => {\n LoggerProxy.logger.error(`Peer-connection-manager:index#setLocalDescription --> ${err} `);\n\n return Promise.error(err);\n });\n\n/**\n * @param {Object} params {\n * @param {Boolean} params.offerToReceiveAudio\n * @param {Boolean} params.offerToReceiveVideo\n * @param {string} params.offerSdp\n * @param {MediaStream} params.stream\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @returns {Promise.<Array>} [MediaSDP, ScreenSDP]\n */\npc.updatePeerConnection = (params, {meetingId, remoteQualityLevel}) => {\n LoggerProxy.logger.log(`PeerConnectionManager:index#updatePeerConnection --> updating the peerConnection with params: ${params}`);\n\n const {peerConnection, offerSdp} = params;\n\n return pc.createAnswer({\n peerConnection,\n offerSdp: offerSdp[0]\n }, {meetingId, remoteQualityLevel}).then((peerconnection) => {\n // The content slides should also be set when we are sending inactive\n pc.setContentSlides(peerconnection);\n\n return Promise.resolve([peerconnection.sdp]);\n });\n};\n\n/**\n * @param {Object} params\n * @param {Object} params.peerConnection\n * @param {Object} params.sdpConstraints\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @returns {RTCPeerConnection} peerConnection\n */\npc.createAnswer = (params, {meetingId, remoteQualityLevel}) => {\n const {peerConnection} = params;\n\n // TODO: Some times to many mercury event comes at the same time\n // Need to maintain state of peerconnection\n if (peerConnection.signalingState === SDP.HAVE_REMOTE_OFFER) {\n return Promise.resolve(peerConnection);\n }\n\n return pc.setRemoteSessionDetails(peerConnection, OFFER, params.offerSdp, meetingId)\n .then(() => peerConnection.createAnswer(params.sdpConstraints))\n .then((answer) =>\n\n peerConnection.setLocalDescription(answer))\n .then(() => pc.iceCandidate(peerConnection, {remoteQualityLevel}))\n .then(() => {\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);\n peerConnection.sdp = PeerConnectionUtils.convertCLineToIpv4(peerConnection.sdp);\n if (!checkH264Support(peerConnection.sdp)) {\n throw new MediaError('openH264 is downloading please Wait. Upload logs if not working on second try');\n }\n\n return peerConnection;\n })\n .catch((error) => {\n if (error instanceof InvalidSdpError) {\n Metrics.sendBehavioralMetric(\n BEHAVIORAL_METRICS.INVALID_ICE_CANDIDATE,\n {\n correlation_id: meetingId\n }\n );\n }\n else {\n const metricName = BEHAVIORAL_METRICS.PEERCONNECTION_FAILURE;\n const data = {\n correlation_id: meetingId,\n reason: error.message,\n stack: error.stack\n };\n const metadata = {\n type: error.name\n };\n\n Metrics.sendBehavioralMetric(metricName, data, metadata);\n }\n\n LoggerProxy.logger.error(`PeerConnectionManager:index#setRemoteSessionDetails --> Error creating remote session, error: ${error}`);\n });\n};\n\n/**\n * shut down the peer connection\n * @param {Object} peerConnection\n * @returns {undefined}\n */\npc.close = (peerConnection) => {\n // peerConnection.close() fails on firefox on network changes and gives a Dom exception\n // To avoid this we have added a try catch block.\n // Please refer to https://bugzilla.mozilla.org/show_bug.cgi?id=1274407 for more information\n LoggerProxy.logger.log('PeerConnectionManager:index#close --> pc: close() -> attempting to close the peer connection');\n\n if (peerConnection && peerConnection.connectionState === PEER_CONNECTION_STATE.CLOSED) {\n LoggerProxy.logger.log('PeerConnectionManager:index#close --> pc: close() -> connection already closed');\n\n return Promise.resolve();\n }\n LoggerProxy.logger.log('PeerConnectionManager:index#close --> pc: close() -> closing the mediaPeerConnection');\n\n return Promise.resolve()\n .then(() => {\n if (peerConnection && peerConnection.close) {\n peerConnection.close();\n }\n });\n};\n\n\npc.setPeerConnectionEvents = (meeting) => {\n // In case ICE fail\n const {peerConnection} = meeting.mediaProperties;\n\n const connectionFailed = () => {\n if (meeting.reconnectionManager.iceState.resolve) {\n // DISCONNECTED state triggers first then it goes to FAILED STATE\n // sometimes the failed state can happen before 10 seconds (Which is the timer for the reconnect for ice disconnect)\n meeting.reconnectionManager.iceState.resolve();\n }\n\n meeting.reconnect({networkDisconnect: true});\n Metrics.postEvent({\n event: eventType.ICE_END,\n meeting,\n data: {\n canProceed: false,\n errors: [\n Metrics.generateErrorPayload(\n 2004, false, error.name.MEDIA_ENGINE\n )]\n }\n });\n\n meeting.uploadLogs({\n file: 'peer-connection-manager/index',\n function: 'connectionFailed'\n });\n\n Metrics.sendBehavioralMetric(\n BEHAVIORAL_METRICS.CONNECTION_FAILURE,\n {\n correlation_id: meeting.correlationId,\n locus_id: meeting.locusId\n }\n );\n };\n\n peerConnection.oniceconnectionstatechange = () => {\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CHANGE.');\n switch (peerConnection.iceConnectionState) {\n case ICE_STATE.CHECKING:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CHECKING.');\n Metrics.postEvent({event: eventType.ICE_START, meeting});\n break;\n case ICE_STATE.COMPLETED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE COMPLETED.');\n break;\n case ICE_STATE.CONNECTED:\n // Ice connection state goes to connected when both client and server sends STUN packets and\n // Established connected between them. Firefox does not trigger COMPLETED and only trigger CONNECTED\n Metrics.postEvent({event: eventType.ICE_END, meeting});\n Metrics.sendBehavioralMetric(\n BEHAVIORAL_METRICS.CONNECTION_SUCCESS,\n {\n correlation_id: meeting.correlationId,\n locus_id: meeting.locusId\n }\n );\n meeting.setNetworkStatus(NETWORK_STATUS.CONNECTED);\n meeting.reconnectionManager.iceReconnected();\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CONNECTED.');\n break;\n case ICE_STATE.CLOSED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CLOSED.');\n break;\n case ICE_STATE.DISCONNECTED:\n meeting.setNetworkStatus(NETWORK_STATUS.DISCONNECTED);\n meeting.reconnectionManager.waitForIceReconnect()\n .catch(() => {\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE DISCONNECTED. Automatic Reconnection Timed Out.');\n\n connectionFailed();\n });\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE DISCONNECTED.');\n break;\n case ICE_STATE.FAILED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE FAILED.');\n // notify of ice failure\n // Ice failure is the only indicator currently for identifying the actual connection drop\n // Firefox takes sometime 10-15 seconds to go to failed state\n connectionFailed();\n break;\n default:\n break;\n }\n };\n\n peerConnection.onconnectionstatechange = () => {\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CHANGE.');\n switch (peerConnection.connectionState) {\n case CONNECTION_STATE.NEW:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE NEW.');\n break;\n case CONNECTION_STATE.CONNECTING:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CONNECTING.');\n break;\n case CONNECTION_STATE.CONNECTED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CONNECTED.');\n break;\n case CONNECTION_STATE.CLOSED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CLOSED.');\n break;\n case CONNECTION_STATE.DISCONNECTED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE DISCONNECTED.');\n break;\n case CONNECTION_STATE.FAILED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE FAILED.');\n // Special case happens only on chrome where there is no ICE FAILED event\n // only CONNECTION FAILED event gets triggered\n\n connectionFailed();\n break;\n default:\n break;\n }\n };\n};\n\nexport default pc;\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["BrowserDetection","isBrowser","pc","insertBandwidthLimit","sdpLines","index","limit","periodicKeyFrame","search","AUDIO","StaticConfig","meetings","bandwidth","audio","video","SDP","PERIODIC_KEYFRAME","splice","B_LINE","setMaxFs","sdp","level","QUALITY_LEVELS","HIGH","MAX_FRAMESIZES","ParameterError","replaceSdp","maxFsLine","MAX_FS","replace","setStartBitrateOnRemoteSdp","startBitrate","checkH264Support","videoPresent","match","h264Present","isSdpInvalid","parsedSdp","sdpTransform","parse","media","mediaLine","candidates","length","LoggerProxy","logger","error","BAD_MEDIA_PORTS","includes","port","icePwd","iceUfrag","limitBandwidth","offerSdp","split","CARRIAGE_RETURN","i","M_LINE","join","setContentSlides","screenPc","A_CONTENT_SLIDES","iceCandidate","peerConnection","remoteQualityLevel","resolve","reject","now","doneGatheringIceCandidate","miliseconds","Math","abs","localDescription","PeerConnectionUtils","convertCLineToIpv4","invalidSdpPresent","InvalidSdpError","log","iceGatheringState","COMPLETE","onIceGatheringStateChange","GATHERING","onicecandidate","evt","candidate","type","protocol","address","onicecandidateerror","event","replaceTrack","track","senders","getSenders","forEach","sender","kind","err","addStream","stream","tracksPresent","find","getTracks","addTrack","setRemoteSessionDetails","typeStr","remoteSdp","meetingId","signalingState","Metrics","postEvent","eventType","REMOTE_SDP_RECEIVED","data","canProceed","errors","generateErrorPayload","name","MEDIA_ENGINE","HAVE_LOCAL_OFFER","STABLE","OFFER","enableExtmap","setRemoteDescription","window","RTCSessionDescription","then","catch","metricName","BEHAVIORAL_METRICS","PEERCONNECTION_FAILURE","correlation_id","reason","message","stack","metadata","sendBehavioralMetric","MediaError","createOffer","enableRtx","description","setLocalDescription","LOCAL_SDP_GENERATED","INVALID_ICE_CANDIDATE","code","close","rollBackLocalDescription","ROLLBACK","updatePeerConnection","params","createAnswer","peerconnection","HAVE_REMOTE_OFFER","sdpConstraints","answer","connectionState","PEER_CONNECTION_STATE","CLOSED","setPeerConnectionEvents","meeting","mediaProperties","connectionFailed","reconnectionManager","iceState","reconnect","networkDisconnect","ICE_END","uploadLogs","file","function","CONNECTION_FAILURE","correlationId","locus_id","locusId","oniceconnectionstatechange","info","iceConnectionState","ICE_STATE","CHECKING","ICE_START","COMPLETED","CONNECTED","CONNECTION_SUCCESS","setNetworkStatus","NETWORK_STATUS","iceReconnected","DISCONNECTED","waitForIceReconnect","FAILED","onconnectionstatechange","CONNECTION_STATE","NEW","CONNECTING"],"sources":["index.js"],"sourcesContent":["\n// We need to figure out how to pass a webex logger instance to these util files\n\n/* globals RTCSessionDescription */\n\nimport window from 'global/window';\nimport sdpTransform from 'sdp-transform'; // https://github.com/clux/sdp-transform\n\nimport Metrics from '../metrics';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport StaticConfig from '../common/config';\nimport {\n COMPLETE,\n GATHERING,\n AUDIO,\n SDP,\n ICE_STATE,\n CONNECTION_STATE,\n NETWORK_STATUS,\n PEER_CONNECTION_STATE,\n OFFER,\n QUALITY_LEVELS,\n MAX_FRAMESIZES\n} from '../constants';\nimport BEHAVIORAL_METRICS from '../metrics/constants';\nimport {error, eventType} from '../metrics/config';\nimport MediaError from '../common/errors/media';\nimport ParameterError from '../common/errors/parameter';\nimport {InvalidSdpError} from '../common/errors/webex-errors';\nimport BrowserDetection from '../common/browser-detection';\n\nimport PeerConnectionUtils from './util';\n\nconst {isBrowser} = BrowserDetection();\n\n/**\n * @export\n * @public\n */\nconst pc = {};\n\n/**\n * munges the bandwidth limit into the sdp\n * @param {String} sdpLines\n * @param {Number} index\n * @returns {String}\n */\nconst insertBandwidthLimit = (sdpLines, index) => {\n // eslint-disable-next-line no-warning-comments\n // TODO convert to sdp parser\n let limit;\n let periodicKeyFrame = '';\n\n if (sdpLines[index].search(AUDIO) !== -1) {\n limit = StaticConfig.meetings.bandwidth.audio;\n }\n else {\n limit = StaticConfig.meetings.bandwidth.video;\n periodicKeyFrame = SDP.PERIODIC_KEYFRAME;\n sdpLines.splice(index + 2, 0, periodicKeyFrame);\n }\n sdpLines.splice(index + 1, 0, `${SDP.B_LINE}:${limit}`);\n\n return sdpLines;\n};\n\n/**\n * needed for calliope max-fs\n * @param {String} sdp\n * @param {String} [level=QUALITY_LEVELS.HIGH] quality level for max-fs\n * @returns {String}\n */\nconst setMaxFs = (sdp, level = QUALITY_LEVELS.HIGH) => {\n if (!MAX_FRAMESIZES[level]) {\n throw new ParameterError(`setMaxFs: unable to set max framesize, value for level \"${level}\" is not defined`);\n }\n // eslint-disable-next-line no-warning-comments\n // TODO convert with sdp parser, no munging\n let replaceSdp = sdp;\n const maxFsLine = `${SDP.MAX_FS}${MAX_FRAMESIZES[level]}`;\n\n replaceSdp = replaceSdp.replace(/(\\na=fmtp:(\\d+).*profile-level-id=.*)/gi, `$1;${maxFsLine}`);\n\n return replaceSdp;\n};\n\n\nconst setStartBitrateOnRemoteSdp = (sdp) => {\n if (StaticConfig.meetings.bandwidth.startBitrate) {\n sdp = sdp.replace(/(\\na=fmtp:(\\d+).*profile-level-id=.*)/gi, `$1;x-google-start-bitrate=${StaticConfig.meetings.bandwidth.startBitrate}`);\n }\n\n return sdp;\n};\n\n/**\n * checks that sdp has h264 codec in it\n * @param {String} sdp\n * @returns {boolean}\n */\nconst checkH264Support = (sdp) => {\n // eslint-disable-next-line no-warning-comments\n // TODO convert to sdp parser to read rtp.codec\n const videoPresent = sdp.match(/\\nm=video.*/g);\n const h264Present = sdp.match(/\\na=rtpmap:\\d+\\sH264.*/g);\n\n if (videoPresent) {\n return !!h264Present;\n }\n\n return true;\n};\n\n/**\n * validates the sdp, checks port, candidates, and ice info\n * @param {String} sdp\n * @returns {String}\n */\nconst isSdpInvalid = (sdp) => {\n const parsedSdp = sdpTransform.parse(sdp);\n\n for (const mediaLine of parsedSdp.media) {\n if (!mediaLine.candidates || mediaLine.candidates?.length === 0) {\n LoggerProxy.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Ice candidate never completed');\n\n return 'iceCandidate: Ice gathering never completed';\n }\n\n if (SDP.BAD_MEDIA_PORTS.includes(mediaLine.port)) {\n LoggerProxy.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Found invalid port number for the ice candidate');\n\n return 'iceCandidate: Found invalid port number for the ice candidate';\n }\n if (!mediaLine.icePwd || !mediaLine.iceUfrag) {\n LoggerProxy.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: ice ufrag and password not found');\n\n return 'iceCandidate: ice ufrag and password not found';\n }\n }\n\n return '';\n};\n\n/**\n * munges the bandwidth into the sdp\n * @param {String} sdp\n * @returns {String}\n */\nconst limitBandwidth = (sdp) => {\n // TODO convert to sdp parser\n let offerSdp = sdp;\n let sdpLines = offerSdp.split(SDP.CARRIAGE_RETURN);\n\n for (let i = 0; i < sdpLines.length; i += 1) {\n if (sdpLines[i].search(SDP.M_LINE) !== -1) {\n sdpLines = insertBandwidthLimit(sdpLines, i);\n }\n }\n offerSdp = sdpLines.join(SDP.CARRIAGE_RETURN);\n\n return offerSdp;\n};\n\n/**\n * makes sure the screen pc sdp has content:slides for server\n * @param {RTCPeerConnection} screenPc\n * @returns {RTCPeerConnection}\n */\npc.setContentSlides = (screenPc) => {\n if (screenPc && screenPc.sdp) {\n screenPc.sdp += `${SDP.A_CONTENT_SLIDES}${SDP.CARRIAGE_RETURN}`;\n }\n\n return screenPc;\n};\n\n/**\n * handles ice trickling and establishes ICE connection onto peer connection object\n * @param {Object} peerConnection\n * @param {Object} options\n * @param {String} options.remoteQualityLevel\n * @returns {Promise.RTCPeerConnection}\n */\npc.iceCandidate = (peerConnection, {remoteQualityLevel}) =>\n new Promise((resolve, reject) => {\n const now = Date.now();\n const doneGatheringIceCandidate = () => {\n const miliseconds = parseInt(Math.abs(Date.now() - now), 4);\n\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);\n peerConnection.sdp = PeerConnectionUtils.convertCLineToIpv4(peerConnection.sdp);\n\n const invalidSdpPresent = isSdpInvalid(peerConnection.sdp);\n\n if (invalidSdpPresent) {\n LoggerProxy.logger.error('PeerConnectionManager:index#iceCandidate --> SDP not valid after waiting.');\n reject(new InvalidSdpError(invalidSdpPresent));\n }\n LoggerProxy.logger.log(`PeerConnectionManager:index#iceCandidate --> Time to gather ice candidate ${miliseconds} miliseconds`);\n\n\n resolve();\n };\n\n // If ice has already been gathered\n if (peerConnection.iceGatheringState === COMPLETE) {\n doneGatheringIceCandidate();\n }\n\n peerConnection.onIceGatheringStateChange = () => {\n if (peerConnection.iceGatheringState === COMPLETE) {\n doneGatheringIceCandidate(peerConnection);\n }\n if (peerConnection.iceGatheringState === GATHERING) {\n LoggerProxy.logger.log('PeerConnectionManager:index#onIceGatheringStateChange --> Ice state changed to gathering');\n }\n };\n\n peerConnection.onicecandidate = (evt) => {\n if (evt.candidate === null) {\n doneGatheringIceCandidate(peerConnection);\n }\n else {\n LoggerProxy.logger.log(`PeerConnectionManager:index#onicecandidate --> Candidate ${evt.candidate?.type} ${evt.candidate?.protocol} ${evt.candidate?.address}:${evt.candidate?.port}`);\n }\n };\n\n peerConnection.onicecandidateerror = (event) => {\n // we can often get ICE candidate errors (for example when failing to communicate with a TURN server)\n // they don't mean that the whole ICE connection will fail, so it's OK to ignore them\n LoggerProxy.logger.error('PeerConnectionManager:index#onicecandidateerror --> ignoring ice error:', event);\n };\n });\n\n/**\n * swapping tracks\n * @param {Object} peerConnection\n * @param {Object} track\n * @returns {undefined}\n */\npc.replaceTrack = (peerConnection, track) => {\n try {\n const senders = peerConnection.getSenders();\n\n if (senders.length > 0) {\n senders.forEach((sender) => {\n if (sender.track && sender.track.kind === track.kind) {\n sender.replaceTrack(track);\n }\n });\n }\n }\n catch (err) {\n LoggerProxy.logger.error(`PeerConnectionManager:index#replaceTrack --> Error replacing track, ${err}`);\n }\n};\n\n/**\n * adding streams to peerConnection\n * @param {Object} peerConnection\n * @param {Object} stream\n * @returns {undefined}\n */\npc.addStream = (peerConnection, stream) => {\n try {\n if (stream && !isBrowser('edge')) {\n const tracksPresent = peerConnection.getSenders && peerConnection.getSenders().find((sender) => sender.track != null);\n\n if (tracksPresent) {\n stream.getTracks().forEach((track) => {\n pc.replaceTrack(peerConnection, track);\n });\n\n return;\n }\n stream.getTracks().forEach((track) => {\n peerConnection.addTrack(track, stream);\n });\n // // TODO : may come back disable addTracks for chrome they are moving back to addStream\n // // https://bugs.chromium.org/p/chromium/issues/detail?id=764414\n // // https://bugs.chromium.org/p/chromium/issues/detail?id=738918#c7\n // peerConnection.addStream(stream);\n }\n else if (isBrowser('edge')) {\n peerConnection.addStream(stream);\n }\n }\n catch (err) {\n LoggerProxy.logger.error(`PeerConnectionManager:index#addStream --> Error adding stream, error: ${error}`);\n }\n};\n\n/**\n * setting the remote description\n * @param {Object} peerConnection\n * @param {String} typeStr\n * @param {String} remoteSdp\n * @param {String} meetingId\n * @returns {undefined}\n */\npc.setRemoteSessionDetails = (\n peerConnection,\n typeStr,\n remoteSdp,\n meetingId,\n) => {\n LoggerProxy.logger.log(`PeerConnectionManager:index#setRemoteSessionDetails --> Setting the remote description type: ${typeStr}State: ${peerConnection.signalingState}`);\n let sdp = remoteSdp;\n\n // making sure that the remoteDescription is only set when there is a answer for offer\n // or there is a offer from the server\n\n if (!sdp) {\n Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId,\n data: {\n canProceed: false,\n errors: [Metrics.generateErrorPayload(2001, true,\n error.name.MEDIA_ENGINE, 'missing remoteSdp')]\n }\n });\n }\n if (peerConnection.signalingState === SDP.HAVE_LOCAL_OFFER || (peerConnection.signalingState === SDP.STABLE && typeStr === SDP.OFFER)) {\n sdp = setStartBitrateOnRemoteSdp(sdp);\n\n if (!peerConnection.enableExtmap) {\n sdp = sdp.replace(/\\na=extmap.*/g, '');\n }\n\n // remove any xtls candidates\n sdp = sdp.replace(/^a=candidate:.*xTLS.*\\r\\n/gim, '');\n\n return peerConnection.setRemoteDescription(\n new window.RTCSessionDescription({\n type: typeStr,\n sdp\n })\n )\n .then(() => {\n if (peerConnection.signalingState === SDP.STABLE) {\n Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId\n });\n }\n })\n .catch((error) => {\n LoggerProxy.logger.error(`Peer-connection-manager:index#setRemoteDescription --> ${error} missing remotesdp`);\n\n\n const metricName = BEHAVIORAL_METRICS.PEERCONNECTION_FAILURE;\n const data = {\n correlation_id: meetingId,\n reason: error.message,\n stack: error.stack\n };\n const metadata = {\n type: error.name\n };\n\n Metrics.sendBehavioralMetric(metricName, data, metadata);\n\n return Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId,\n data: {\n canProceed: false,\n errors: [Metrics.generateErrorPayload(2001, true,\n error.name.MEDIA_ENGINE, 'missing remoteSdp')]\n }\n });\n });\n }\n\n return Promise.reject(new MediaError('PeerConnection in wrong state'));\n};\n\n/**\n * Create offer with a valid parameter\n * @param {Object} peerConnection\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @param {string} meetingProperties.enableRtx\n * @param {string} meetingProperties.enableExtmap\n * @returns {RTCPeerConnection}\n */\npc.createOffer = (peerConnection, {\n meetingId,\n remoteQualityLevel,\n enableRtx,\n enableExtmap\n}) => {\n LoggerProxy.logger.log('PeerConnectionManager:index#createOffer --> creating a new offer');\n\n // saving the extMap State to use in setRemoteDescription\n\n peerConnection.enableExtmap = enableExtmap;\n\n return peerConnection\n .createOffer()\n .then((description) => {\n // bug https://bugs.chromium.org/p/chromium/issues/detail?id=1020642\n // chrome currently generates RTX line irrespective of whether the server side supports it\n // we are removing apt as well because its associated with rtx line\n\n if (!enableRtx) {\n description.sdp = description.sdp.replace(/\\r\\na=rtpmap:\\d+ rtx\\/\\d+/g, '');\n description.sdp = description.sdp.replace(/\\r\\na=fmtp:\\d+ apt=\\d+/g, '');\n }\n\n return peerConnection.setLocalDescription(description);\n })\n .then(() => pc.iceCandidate(peerConnection, {remoteQualityLevel}))\n .then(() => {\n if (!checkH264Support(peerConnection.sdp)) {\n throw new MediaError('openH264 is downloading please Wait. Upload logs if not working on second try');\n }\n\n if (!enableExtmap) {\n peerConnection.sdp = peerConnection.sdp.replace(/\\na=extmap.*/g, '');\n }\n\n pc.setContentSlides(peerConnection);\n\n Metrics.postEvent({\n event: eventType.LOCAL_SDP_GENERATED,\n meetingId\n });\n\n return peerConnection;\n })\n .catch((error) => {\n LoggerProxy.logger.error(`Peer-connection-manager:index#createOffer --> ${error}`);\n if (error instanceof InvalidSdpError) {\n Metrics.sendBehavioralMetric(\n BEHAVIORAL_METRICS.INVALID_ICE_CANDIDATE,\n {\n correlation_id: meetingId,\n code: error.code,\n reason: error.message\n }\n );\n }\n else {\n const metricName = BEHAVIORAL_METRICS.PEERCONNECTION_FAILURE;\n const data = {\n correlation_id: meetingId,\n reason: error.message,\n stack: error.stack\n };\n const metadata = {\n type: error.name\n };\n\n Metrics.sendBehavioralMetric(metricName, data, metadata);\n }\n\n Metrics.postEvent({\n event: eventType.LOCAL_SDP_GENERATED,\n meetingId,\n data: {\n canProceed: false,\n errors: [\n Metrics.generateErrorPayload(2001, true,\n error.name.MEDIA_ENGINE)]\n }\n });\n pc.close(peerConnection);\n throw error;\n });\n};\n\n/**\n * rollBack local description in peerconnection\n * @param {Object} peerConnection\n * @returns {Promise.RTCPeerConnection}\n */\npc.rollBackLocalDescription = (peerConnection) => peerConnection\n .setLocalDescription(new RTCSessionDescription({type: SDP.ROLLBACK}))\n .then(() => peerConnection)\n .catch((err) => {\n LoggerProxy.logger.error(`Peer-connection-manager:index#setLocalDescription --> ${err} `);\n\n return Promise.error(err);\n });\n\n/**\n * @param {Object} params {\n * @param {Boolean} params.offerToReceiveAudio\n * @param {Boolean} params.offerToReceiveVideo\n * @param {string} params.offerSdp\n * @param {MediaStream} params.stream\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @returns {Promise.<Array>} [MediaSDP, ScreenSDP]\n */\npc.updatePeerConnection = (params, {meetingId, remoteQualityLevel}) => {\n LoggerProxy.logger.log(`PeerConnectionManager:index#updatePeerConnection --> updating the peerConnection with params: ${params}`);\n\n const {peerConnection, offerSdp} = params;\n\n return pc.createAnswer({\n peerConnection,\n offerSdp: offerSdp[0]\n }, {meetingId, remoteQualityLevel}).then((peerconnection) => {\n // The content slides should also be set when we are sending inactive\n pc.setContentSlides(peerconnection);\n\n return Promise.resolve([peerconnection.sdp]);\n });\n};\n\n/**\n * @param {Object} params\n * @param {Object} params.peerConnection\n * @param {Object} params.sdpConstraints\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @returns {RTCPeerConnection} peerConnection\n */\npc.createAnswer = (params, {meetingId, remoteQualityLevel}) => {\n const {peerConnection} = params;\n\n // TODO: Some times to many mercury event comes at the same time\n // Need to maintain state of peerconnection\n if (peerConnection.signalingState === SDP.HAVE_REMOTE_OFFER) {\n return Promise.resolve(peerConnection);\n }\n\n return pc.setRemoteSessionDetails(peerConnection, OFFER, params.offerSdp, meetingId)\n .then(() => peerConnection.createAnswer(params.sdpConstraints))\n .then((answer) =>\n\n peerConnection.setLocalDescription(answer))\n .then(() => pc.iceCandidate(peerConnection, {remoteQualityLevel}))\n .then(() => {\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);\n peerConnection.sdp = PeerConnectionUtils.convertCLineToIpv4(peerConnection.sdp);\n if (!checkH264Support(peerConnection.sdp)) {\n throw new MediaError('openH264 is downloading please Wait. Upload logs if not working on second try');\n }\n\n return peerConnection;\n })\n .catch((error) => {\n if (error instanceof InvalidSdpError) {\n Metrics.sendBehavioralMetric(\n BEHAVIORAL_METRICS.INVALID_ICE_CANDIDATE,\n {\n correlation_id: meetingId\n }\n );\n }\n else {\n const metricName = BEHAVIORAL_METRICS.PEERCONNECTION_FAILURE;\n const data = {\n correlation_id: meetingId,\n reason: error.message,\n stack: error.stack\n };\n const metadata = {\n type: error.name\n };\n\n Metrics.sendBehavioralMetric(metricName, data, metadata);\n }\n\n LoggerProxy.logger.error(`PeerConnectionManager:index#setRemoteSessionDetails --> Error creating remote session, error: ${error}`);\n });\n};\n\n/**\n * shut down the peer connection\n * @param {Object} peerConnection\n * @returns {undefined}\n */\npc.close = (peerConnection) => {\n // peerConnection.close() fails on firefox on network changes and gives a Dom exception\n // To avoid this we have added a try catch block.\n // Please refer to https://bugzilla.mozilla.org/show_bug.cgi?id=1274407 for more information\n LoggerProxy.logger.log('PeerConnectionManager:index#close --> pc: close() -> attempting to close the peer connection');\n\n if (peerConnection && peerConnection.connectionState === PEER_CONNECTION_STATE.CLOSED) {\n LoggerProxy.logger.log('PeerConnectionManager:index#close --> pc: close() -> connection already closed');\n\n return Promise.resolve();\n }\n LoggerProxy.logger.log('PeerConnectionManager:index#close --> pc: close() -> closing the mediaPeerConnection');\n\n return Promise.resolve()\n .then(() => {\n if (peerConnection && peerConnection.close) {\n peerConnection.close();\n }\n });\n};\n\n\npc.setPeerConnectionEvents = (meeting) => {\n // In case ICE fail\n const {peerConnection} = meeting.mediaProperties;\n\n const connectionFailed = () => {\n if (meeting.reconnectionManager.iceState.resolve) {\n // DISCONNECTED state triggers first then it goes to FAILED STATE\n // sometimes the failed state can happen before 10 seconds (Which is the timer for the reconnect for ice disconnect)\n meeting.reconnectionManager.iceState.resolve();\n }\n\n meeting.reconnect({networkDisconnect: true});\n Metrics.postEvent({\n event: eventType.ICE_END,\n meeting,\n data: {\n canProceed: false,\n errors: [\n Metrics.generateErrorPayload(\n 2004, false, error.name.MEDIA_ENGINE\n )]\n }\n });\n\n meeting.uploadLogs({\n file: 'peer-connection-manager/index',\n function: 'connectionFailed'\n });\n\n Metrics.sendBehavioralMetric(\n BEHAVIORAL_METRICS.CONNECTION_FAILURE,\n {\n correlation_id: meeting.correlationId,\n locus_id: meeting.locusId\n }\n );\n };\n\n peerConnection.oniceconnectionstatechange = () => {\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CHANGE.');\n switch (peerConnection.iceConnectionState) {\n case ICE_STATE.CHECKING:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CHECKING.');\n Metrics.postEvent({event: eventType.ICE_START, meeting});\n break;\n case ICE_STATE.COMPLETED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE COMPLETED.');\n break;\n case ICE_STATE.CONNECTED:\n // Ice connection state goes to connected when both client and server sends STUN packets and\n // Established connected between them. Firefox does not trigger COMPLETED and only trigger CONNECTED\n Metrics.postEvent({event: eventType.ICE_END, meeting});\n Metrics.sendBehavioralMetric(\n BEHAVIORAL_METRICS.CONNECTION_SUCCESS,\n {\n correlation_id: meeting.correlationId,\n locus_id: meeting.locusId\n }\n );\n meeting.setNetworkStatus(NETWORK_STATUS.CONNECTED);\n meeting.reconnectionManager.iceReconnected();\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CONNECTED.');\n break;\n case ICE_STATE.CLOSED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CLOSED.');\n break;\n case ICE_STATE.DISCONNECTED:\n meeting.setNetworkStatus(NETWORK_STATUS.DISCONNECTED);\n meeting.reconnectionManager.waitForIceReconnect()\n .catch(() => {\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE DISCONNECTED. Automatic Reconnection Timed Out.');\n\n connectionFailed();\n });\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE DISCONNECTED.');\n break;\n case ICE_STATE.FAILED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE FAILED.');\n // notify of ice failure\n // Ice failure is the only indicator currently for identifying the actual connection drop\n // Firefox takes sometime 10-15 seconds to go to failed state\n connectionFailed();\n break;\n default:\n break;\n }\n };\n\n peerConnection.onconnectionstatechange = () => {\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CHANGE.');\n switch (peerConnection.connectionState) {\n case CONNECTION_STATE.NEW:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE NEW.');\n break;\n case CONNECTION_STATE.CONNECTING:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CONNECTING.');\n break;\n case CONNECTION_STATE.CONNECTED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CONNECTED.');\n break;\n case CONNECTION_STATE.CLOSED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CLOSED.');\n break;\n case CONNECTION_STATE.DISCONNECTED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE DISCONNECTED.');\n break;\n case CONNECTION_STATE.FAILED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE FAILED.');\n // Special case happens only on chrome where there is no ICE FAILED event\n // only CONNECTION FAILED event gets triggered\n\n connectionFailed();\n break;\n default:\n break;\n }\n };\n};\n\nexport default pc;\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAKA;;AACA;;AAEA;;AACA;;AACA;;AACA;;AAaA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;;;;;;;AAEA,wBAAoB,IAAAA,yBAAA,GAApB;AAAA,IAAOC,SAAP,qBAAOA,SAAP;AAEA;AACA;AACA;AACA;;;AACA,IAAMC,EAAE,GAAG,EAAX;AAEA;AACA;AACA;AACA;AACA;AACA;;AACA,IAAMC,oBAAoB,GAAG,SAAvBA,oBAAuB,CAACC,QAAD,EAAWC,KAAX,EAAqB;EAChD;EACA;EACA,IAAIC,KAAJ;EACA,IAAIC,gBAAgB,GAAG,EAAvB;;EAEA,IAAIH,QAAQ,CAACC,KAAD,CAAR,CAAgBG,MAAhB,CAAuBC,gBAAvB,MAAkC,CAAC,CAAvC,EAA0C;IACxCH,KAAK,GAAGI,eAAA,CAAaC,QAAb,CAAsBC,SAAtB,CAAgCC,KAAxC;EACD,CAFD,MAGK;IACHP,KAAK,GAAGI,eAAA,CAAaC,QAAb,CAAsBC,SAAtB,CAAgCE,KAAxC;IACAP,gBAAgB,GAAGQ,cAAA,CAAIC,iBAAvB;IACAZ,QAAQ,CAACa,MAAT,CAAgBZ,KAAK,GAAG,CAAxB,EAA2B,CAA3B,EAA8BE,gBAA9B;EACD;;EACDH,QAAQ,CAACa,MAAT,CAAgBZ,KAAK,GAAG,CAAxB,EAA2B,CAA3B,YAAiCU,cAAA,CAAIG,MAArC,cAA+CZ,KAA/C;EAEA,OAAOF,QAAP;AACD,CAjBD;AAmBA;AACA;AACA;AACA;AACA;AACA;;;AACA,IAAMe,QAAQ,GAAG,SAAXA,QAAW,CAACC,GAAD,EAAsC;EAAA,IAAhCC,KAAgC,uEAAxBC,yBAAA,CAAeC,IAAS;;EACrD,IAAI,CAACC,yBAAA,CAAeH,KAAf,CAAL,EAA4B;IAC1B,MAAM,IAAII,kBAAJ,oEAA8EJ,KAA9E,uBAAN;EACD,CAHoD,CAIrD;EACA;;;EACA,IAAIK,UAAU,GAAGN,GAAjB;EACA,IAAMO,SAAS,aAAMZ,cAAA,CAAIa,MAAV,SAAmBJ,yBAAA,CAAeH,KAAf,CAAnB,CAAf;EAEAK,UAAU,GAAGA,UAAU,CAACG,OAAX,CAAmB,yCAAnB,eAAoEF,SAApE,EAAb;EAEA,OAAOD,UAAP;AACD,CAZD;;AAeA,IAAMI,0BAA0B,GAAG,SAA7BA,0BAA6B,CAACV,GAAD,EAAS;EAC1C,IAAIV,eAAA,CAAaC,QAAb,CAAsBC,SAAtB,CAAgCmB,YAApC,EAAkD;IAChDX,GAAG,GAAGA,GAAG,CAACS,OAAJ,CAAY,yCAAZ,sCAAoFnB,eAAA,CAAaC,QAAb,CAAsBC,SAAtB,CAAgCmB,YAApH,EAAN;EACD;;EAED,OAAOX,GAAP;AACD,CAND;AAQA;AACA;AACA;AACA;AACA;;;AACA,IAAMY,gBAAgB,GAAG,SAAnBA,gBAAmB,CAACZ,GAAD,EAAS;EAChC;EACA;EACA,IAAMa,YAAY,GAAGb,GAAG,CAACc,KAAJ,CAAU,cAAV,CAArB;EACA,IAAMC,WAAW,GAAGf,GAAG,CAACc,KAAJ,CAAU,yBAAV,CAApB;;EAEA,IAAID,YAAJ,EAAkB;IAChB,OAAO,CAAC,CAACE,WAAT;EACD;;EAED,OAAO,IAAP;AACD,CAXD;AAaA;AACA;AACA;AACA;AACA;;;AACA,IAAMC,YAAY,GAAG,SAAfA,YAAe,CAAChB,GAAD,EAAS;EAC5B,IAAMiB,SAAS,GAAGC,qBAAA,CAAaC,KAAb,CAAmBnB,GAAnB,CAAlB;;EAD4B,2CAGJiB,SAAS,CAACG,KAHN;EAAA;;EAAA;IAG5B,oDAAyC;MAAA;;MAAA,IAA9BC,SAA8B;;MACvC,IAAI,CAACA,SAAS,CAACC,UAAX,IAAyB,0BAAAD,SAAS,CAACC,UAAV,gFAAsBC,MAAtB,MAAiC,CAA9D,EAAiE;QAC/DC,oBAAA,CAAYC,MAAZ,CAAmBC,KAAnB,CAAyB,0FAAzB;;QAEA,OAAO,6CAAP;MACD;;MAED,IAAI/B,cAAA,CAAIgC,eAAJ,CAAoBC,QAApB,CAA6BP,SAAS,CAACQ,IAAvC,CAAJ,EAAkD;QAChDL,oBAAA,CAAYC,MAAZ,CAAmBC,KAAnB,CAAyB,4GAAzB;;QAEA,OAAO,+DAAP;MACD;;MACD,IAAI,CAACL,SAAS,CAACS,MAAX,IAAqB,CAACT,SAAS,CAACU,QAApC,EAA8C;QAC5CP,oBAAA,CAAYC,MAAZ,CAAmBC,KAAnB,CAAyB,6FAAzB;;QAEA,OAAO,gDAAP;MACD;IACF;EApB2B;IAAA;EAAA;IAAA;EAAA;;EAsB5B,OAAO,EAAP;AACD,CAvBD;AAyBA;AACA;AACA;AACA;AACA;;;AACA,IAAMM,cAAc,GAAG,SAAjBA,cAAiB,CAAChC,GAAD,EAAS;EAC9B;EACA,IAAIiC,QAAQ,GAAGjC,GAAf;EACA,IAAIhB,QAAQ,GAAGiD,QAAQ,CAACC,KAAT,CAAevC,cAAA,CAAIwC,eAAnB,CAAf;;EAEA,KAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGpD,QAAQ,CAACuC,MAA7B,EAAqCa,CAAC,IAAI,CAA1C,EAA6C;IAC3C,IAAIpD,QAAQ,CAACoD,CAAD,CAAR,CAAYhD,MAAZ,CAAmBO,cAAA,CAAI0C,MAAvB,MAAmC,CAAC,CAAxC,EAA2C;MACzCrD,QAAQ,GAAGD,oBAAoB,CAACC,QAAD,EAAWoD,CAAX,CAA/B;IACD;EACF;;EACDH,QAAQ,GAAGjD,QAAQ,CAACsD,IAAT,CAAc3C,cAAA,CAAIwC,eAAlB,CAAX;EAEA,OAAOF,QAAP;AACD,CAbD;AAeA;AACA;AACA;AACA;AACA;;;AACAnD,EAAE,CAACyD,gBAAH,GAAsB,UAACC,QAAD,EAAc;EAClC,IAAIA,QAAQ,IAAIA,QAAQ,CAACxC,GAAzB,EAA8B;IAC5BwC,QAAQ,CAACxC,GAAT,cAAmBL,cAAA,CAAI8C,gBAAvB,SAA0C9C,cAAA,CAAIwC,eAA9C;EACD;;EAED,OAAOK,QAAP;AACD,CAND;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACA1D,EAAE,CAAC4D,YAAH,GAAkB,UAACC,cAAD;EAAA,IAAkBC,kBAAlB,QAAkBA,kBAAlB;EAAA,OAChB,qBAAY,UAACC,OAAD,EAAUC,MAAV,EAAqB;IAC/B,IAAMC,GAAG,GAAG,mBAAZ;;IACA,IAAMC,yBAAyB,GAAG,SAA5BA,yBAA4B,GAAM;MACtC,IAAMC,WAAW,GAAG,wBAASC,IAAI,CAACC,GAAL,CAAS,sBAAaJ,GAAtB,CAAT,EAAqC,CAArC,CAApB;MAEAJ,cAAc,CAAC3C,GAAf,GAAqBgC,cAAc,CAACW,cAAc,CAACS,gBAAf,CAAgCpD,GAAjC,CAAnC;MACA2C,cAAc,CAAC3C,GAAf,GAAqBD,QAAQ,CAAC4C,cAAc,CAAC3C,GAAhB,EAAqB4C,kBAArB,CAA7B;MACAD,cAAc,CAAC3C,GAAf,GAAqBqD,aAAA,CAAoBC,kBAApB,CAAuCX,cAAc,CAAC3C,GAAtD,CAArB;MAEA,IAAMuD,iBAAiB,GAAGvC,YAAY,CAAC2B,cAAc,CAAC3C,GAAhB,CAAtC;;MAEA,IAAIuD,iBAAJ,EAAuB;QACrB/B,oBAAA,CAAYC,MAAZ,CAAmBC,KAAnB,CAAyB,2EAAzB;;QACAoB,MAAM,CAAC,IAAIU,4BAAJ,CAAoBD,iBAApB,CAAD,CAAN;MACD;;MACD/B,oBAAA,CAAYC,MAAZ,CAAmBgC,GAAnB,qFAAoGR,WAApG;;MAGAJ,OAAO;IACR,CAjBD,CAF+B,CAqB/B;;;IACA,IAAIF,cAAc,CAACe,iBAAf,KAAqCC,mBAAzC,EAAmD;MACjDX,yBAAyB;IAC1B;;IAEDL,cAAc,CAACiB,yBAAf,GAA2C,YAAM;MAC/C,IAAIjB,cAAc,CAACe,iBAAf,KAAqCC,mBAAzC,EAAmD;QACjDX,yBAAyB,CAACL,cAAD,CAAzB;MACD;;MACD,IAAIA,cAAc,CAACe,iBAAf,KAAqCG,oBAAzC,EAAoD;QAClDrC,oBAAA,CAAYC,MAAZ,CAAmBgC,GAAnB,CAAuB,0FAAvB;MACD;IACF,CAPD;;IASAd,cAAc,CAACmB,cAAf,GAAgC,UAACC,GAAD,EAAS;MACvC,IAAIA,GAAG,CAACC,SAAJ,KAAkB,IAAtB,EAA4B;QAC1BhB,yBAAyB,CAACL,cAAD,CAAzB;MACD,CAFD,MAGK;QAAA;;QACHnB,oBAAA,CAAYC,MAAZ,CAAmBgC,GAAnB,sFAAmFM,GAAG,CAACC,SAAvF,mDAAmF,eAAeC,IAAlG,iCAA0GF,GAAG,CAACC,SAA9G,oDAA0G,gBAAeE,QAAzH,iCAAqIH,GAAG,CAACC,SAAzI,oDAAqI,gBAAeG,OAApJ,iCAA+JJ,GAAG,CAACC,SAAnK,oDAA+J,gBAAenC,IAA9K;MACD;IACF,CAPD;;IASAc,cAAc,CAACyB,mBAAf,GAAqC,UAACC,KAAD,EAAW;MAC9C;MACA;MACA7C,oBAAA,CAAYC,MAAZ,CAAmBC,KAAnB,CAAyB,yEAAzB,EAAoG2C,KAApG;IACD,CAJD;EAKD,CAjDD,CADgB;AAAA,CAAlB;AAoDA;AACA;AACA;AACA;AACA;AACA;;;AACAvF,EAAE,CAACwF,YAAH,GAAkB,UAAC3B,cAAD,EAAiB4B,KAAjB,EAA2B;EAC3C,IAAI;IACF,IAAMC,OAAO,GAAG7B,cAAc,CAAC8B,UAAf,EAAhB;;IAEA,IAAID,OAAO,CAACjD,MAAR,GAAiB,CAArB,EAAwB;MACtBiD,OAAO,CAACE,OAAR,CAAgB,UAACC,MAAD,EAAY;QAC1B,IAAIA,MAAM,CAACJ,KAAP,IAAgBI,MAAM,CAACJ,KAAP,CAAaK,IAAb,KAAsBL,KAAK,CAACK,IAAhD,EAAsD;UACpDD,MAAM,CAACL,YAAP,CAAoBC,KAApB;QACD;MACF,CAJD;IAKD;EACF,CAVD,CAWA,OAAOM,GAAP,EAAY;IACVrD,oBAAA,CAAYC,MAAZ,CAAmBC,KAAnB,+EAAgGmD,GAAhG;EACD;AACF,CAfD;AAiBA;AACA;AACA;AACA;AACA;AACA;;;AACA/F,EAAE,CAACgG,SAAH,GAAe,UAACnC,cAAD,EAAiBoC,MAAjB,EAA4B;EACzC,IAAI;IACF,IAAIA,MAAM,IAAI,CAAClG,SAAS,CAAC,MAAD,CAAxB,EAAkC;MAChC,IAAMmG,aAAa,GAAGrC,cAAc,CAAC8B,UAAf,IAA6B9B,cAAc,CAAC8B,UAAf,GAA4BQ,IAA5B,CAAiC,UAACN,MAAD;QAAA,OAAYA,MAAM,CAACJ,KAAP,IAAgB,IAA5B;MAAA,CAAjC,CAAnD;;MAEA,IAAIS,aAAJ,EAAmB;QACjBD,MAAM,CAACG,SAAP,GAAmBR,OAAnB,CAA2B,UAACH,KAAD,EAAW;UACpCzF,EAAE,CAACwF,YAAH,CAAgB3B,cAAhB,EAAgC4B,KAAhC;QACD,CAFD;QAIA;MACD;;MACDQ,MAAM,CAACG,SAAP,GAAmBR,OAAnB,CAA2B,UAACH,KAAD,EAAW;QACpC5B,cAAc,CAACwC,QAAf,CAAwBZ,KAAxB,EAA+BQ,MAA/B;MACD,CAFD,EAVgC,CAahC;MACA;MACA;MACA;IACD,CAjBD,MAkBK,IAAIlG,SAAS,CAAC,MAAD,CAAb,EAAuB;MAC1B8D,cAAc,CAACmC,SAAf,CAAyBC,MAAzB;IACD;EACF,CAtBD,CAuBA,OAAOF,GAAP,EAAY;IACVrD,oBAAA,CAAYC,MAAZ,CAAmBC,KAAnB,iFAAkGA,cAAlG;EACD;AACF,CA3BD;AA6BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACA5C,EAAE,CAACsG,uBAAH,GAA6B,UAC3BzC,cAD2B,EAE3B0C,OAF2B,EAG3BC,SAH2B,EAI3BC,SAJ2B,EAKxB;EACH/D,oBAAA,CAAYC,MAAZ,CAAmBgC,GAAnB,wGAAuH4B,OAAvH,oBAAwI1C,cAAc,CAAC6C,cAAvJ;;EACA,IAAIxF,GAAG,GAAGsF,SAAV,CAFG,CAIH;EACA;;EAEA,IAAI,CAACtF,GAAL,EAAU;IACRyF,gBAAA,CAAQC,SAAR,CAAkB;MAChBrB,KAAK,EAAEsB,kBAAA,CAAUC,mBADD;MAEhBL,SAAS,EAATA,SAFgB;MAGhBM,IAAI,EAAE;QACJC,UAAU,EAAE,KADR;QAEJC,MAAM,EAAE,CAACN,gBAAA,CAAQO,oBAAR,CAA6B,IAA7B,EAAmC,IAAnC,EACPtE,cAAA,CAAMuE,IAAN,CAAWC,YADJ,EACkB,mBADlB,CAAD;MAFJ;IAHU,CAAlB;EASD;;EACD,IAAIvD,cAAc,CAAC6C,cAAf,KAAkC7F,cAAA,CAAIwG,gBAAtC,IAA2DxD,cAAc,CAAC6C,cAAf,KAAkC7F,cAAA,CAAIyG,MAAtC,IAAgDf,OAAO,KAAK1F,cAAA,CAAI0G,KAA/H,EAAuI;IACrIrG,GAAG,GAAGU,0BAA0B,CAACV,GAAD,CAAhC;;IAEA,IAAI,CAAC2C,cAAc,CAAC2D,YAApB,EAAkC;MAChCtG,GAAG,GAAGA,GAAG,CAACS,OAAJ,CAAY,eAAZ,EAA6B,EAA7B,CAAN;IACD,CALoI,CAOrI;;;IACAT,GAAG,GAAGA,GAAG,CAACS,OAAJ,CAAY,8BAAZ,EAA4C,EAA5C,CAAN;IAEA,OAAOkC,cAAc,CAAC4D,oBAAf,CACL,IAAIC,eAAA,CAAOC,qBAAX,CAAiC;MAC/BxC,IAAI,EAAEoB,OADyB;MAE/BrF,GAAG,EAAHA;IAF+B,CAAjC,CADK,EAMJ0G,IANI,CAMC,YAAM;MACV,IAAI/D,cAAc,CAAC6C,cAAf,KAAkC7F,cAAA,CAAIyG,MAA1C,EAAkD;QAChDX,gBAAA,CAAQC,SAAR,CAAkB;UAChBrB,KAAK,EAAEsB,kBAAA,CAAUC,mBADD;UAEhBL,SAAS,EAATA;QAFgB,CAAlB;MAID;IACF,CAbI,EAcJoB,KAdI,CAcE,UAACjF,KAAD,EAAW;MAChBF,oBAAA,CAAYC,MAAZ,CAAmBC,KAAnB,kEAAmFA,KAAnF;;MAGA,IAAMkF,UAAU,GAAGC,mBAAA,CAAmBC,sBAAtC;MACA,IAAMjB,IAAI,GAAG;QACXkB,cAAc,EAAExB,SADL;QAEXyB,MAAM,EAAEtF,KAAK,CAACuF,OAFH;QAGXC,KAAK,EAAExF,KAAK,CAACwF;MAHF,CAAb;MAKA,IAAMC,QAAQ,GAAG;QACflD,IAAI,EAAEvC,KAAK,CAACuE;MADG,CAAjB;;MAIAR,gBAAA,CAAQ2B,oBAAR,CAA6BR,UAA7B,EAAyCf,IAAzC,EAA+CsB,QAA/C;;MAEA,OAAO1B,gBAAA,CAAQC,SAAR,CAAkB;QACvBrB,KAAK,EAAEsB,kBAAA,CAAUC,mBADM;QAEvBL,SAAS,EAATA,SAFuB;QAGvBM,IAAI,EAAE;UACJC,UAAU,EAAE,KADR;UAEJC,MAAM,EAAE,CAACN,gBAAA,CAAQO,oBAAR,CAA6B,IAA7B,EAAmC,IAAnC,EACPtE,KAAK,CAACuE,IAAN,CAAWC,YADJ,EACkB,mBADlB,CAAD;QAFJ;MAHiB,CAAlB,CAAP;IASD,CAvCI,CAAP;EAwCD;;EAED,OAAO,iBAAQpD,MAAR,CAAe,IAAIuE,cAAJ,CAAe,+BAAf,CAAf,CAAP;AACD,CA5ED;AA8EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACAvI,EAAE,CAACwI,WAAH,GAAiB,UAAC3E,cAAD,SAKX;EAAA,IAJJ4C,SAII,SAJJA,SAII;EAAA,IAHJ3C,kBAGI,SAHJA,kBAGI;EAAA,IAFJ2E,SAEI,SAFJA,SAEI;EAAA,IADJjB,YACI,SADJA,YACI;;EACJ9E,oBAAA,CAAYC,MAAZ,CAAmBgC,GAAnB,CAAuB,kEAAvB,EADI,CAGJ;;;EAEAd,cAAc,CAAC2D,YAAf,GAA8BA,YAA9B;EAEA,OAAO3D,cAAc,CAClB2E,WADI,GAEJZ,IAFI,CAEC,UAACc,WAAD,EAAiB;IACrB;IACA;IACA;IAEA,IAAI,CAACD,SAAL,EAAgB;MACdC,WAAW,CAACxH,GAAZ,GAAkBwH,WAAW,CAACxH,GAAZ,CAAgBS,OAAhB,CAAwB,4BAAxB,EAAsD,EAAtD,CAAlB;MACA+G,WAAW,CAACxH,GAAZ,GAAkBwH,WAAW,CAACxH,GAAZ,CAAgBS,OAAhB,CAAwB,yBAAxB,EAAmD,EAAnD,CAAlB;IACD;;IAED,OAAOkC,cAAc,CAAC8E,mBAAf,CAAmCD,WAAnC,CAAP;EACD,CAbI,EAcJd,IAdI,CAcC;IAAA,OAAM5H,EAAE,CAAC4D,YAAH,CAAgBC,cAAhB,EAAgC;MAACC,kBAAkB,EAAlBA;IAAD,CAAhC,CAAN;EAAA,CAdD,EAeJ8D,IAfI,CAeC,YAAM;IACV,IAAI,CAAC9F,gBAAgB,CAAC+B,cAAc,CAAC3C,GAAhB,CAArB,EAA2C;MACzC,MAAM,IAAIqH,cAAJ,CAAe,+EAAf,CAAN;IACD;;IAED,IAAI,CAACf,YAAL,EAAmB;MACjB3D,cAAc,CAAC3C,GAAf,GAAqB2C,cAAc,CAAC3C,GAAf,CAAmBS,OAAnB,CAA2B,eAA3B,EAA4C,EAA5C,CAArB;IACD;;IAED3B,EAAE,CAACyD,gBAAH,CAAoBI,cAApB;;IAEA8C,gBAAA,CAAQC,SAAR,CAAkB;MAChBrB,KAAK,EAAEsB,kBAAA,CAAU+B,mBADD;MAEhBnC,SAAS,EAATA;IAFgB,CAAlB;;IAKA,OAAO5C,cAAP;EACD,CAhCI,EAiCJgE,KAjCI,CAiCE,UAACjF,KAAD,EAAW;IAChBF,oBAAA,CAAYC,MAAZ,CAAmBC,KAAnB,yDAA0EA,KAA1E;;IACA,IAAIA,KAAK,YAAY8B,4BAArB,EAAsC;MACpCiC,gBAAA,CAAQ2B,oBAAR,CACEP,mBAAA,CAAmBc,qBADrB,EAEE;QACEZ,cAAc,EAAExB,SADlB;QAEEqC,IAAI,EAAElG,KAAK,CAACkG,IAFd;QAGEZ,MAAM,EAAEtF,KAAK,CAACuF;MAHhB,CAFF;IAQD,CATD,MAUK;MACH,IAAML,UAAU,GAAGC,mBAAA,CAAmBC,sBAAtC;MACA,IAAMjB,IAAI,GAAG;QACXkB,cAAc,EAAExB,SADL;QAEXyB,MAAM,EAAEtF,KAAK,CAACuF,OAFH;QAGXC,KAAK,EAAExF,KAAK,CAACwF;MAHF,CAAb;MAKA,IAAMC,QAAQ,GAAG;QACflD,IAAI,EAAEvC,KAAK,CAACuE;MADG,CAAjB;;MAIAR,gBAAA,CAAQ2B,oBAAR,CAA6BR,UAA7B,EAAyCf,IAAzC,EAA+CsB,QAA/C;IACD;;IAED1B,gBAAA,CAAQC,SAAR,CAAkB;MAChBrB,KAAK,EAAEsB,kBAAA,CAAU+B,mBADD;MAEhBnC,SAAS,EAATA,SAFgB;MAGhBM,IAAI,EAAE;QACJC,UAAU,EAAE,KADR;QAEJC,MAAM,EAAE,CACNN,gBAAA,CAAQO,oBAAR,CAA6B,IAA7B,EAAmC,IAAnC,EACEtE,KAAK,CAACuE,IAAN,CAAWC,YADb,CADM;MAFJ;IAHU,CAAlB;;IAUApH,EAAE,CAAC+I,KAAH,CAASlF,cAAT;IACA,MAAMjB,KAAN;EACD,CAvEI,CAAP;AAwED,CApFD;AAsFA;AACA;AACA;AACA;AACA;;;AACA5C,EAAE,CAACgJ,wBAAH,GAA8B,UAACnF,cAAD;EAAA,OAAoBA,cAAc,CAC7D8E,mBAD+C,CAC3B,IAAIhB,qBAAJ,CAA0B;IAACxC,IAAI,EAAEtE,cAAA,CAAIoI;EAAX,CAA1B,CAD2B,EAE/CrB,IAF+C,CAE1C;IAAA,OAAM/D,cAAN;EAAA,CAF0C,EAG/CgE,KAH+C,CAGzC,UAAC9B,GAAD,EAAS;IACdrD,oBAAA,CAAYC,MAAZ,CAAmBC,KAAnB,iEAAkFmD,GAAlF;;IAEA,OAAO,iBAAQnD,KAAR,CAAcmD,GAAd,CAAP;EACD,CAP+C,CAApB;AAAA,CAA9B;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACA/F,EAAE,CAACkJ,oBAAH,GAA0B,UAACC,MAAD,SAA6C;EAAA,IAAnC1C,SAAmC,SAAnCA,SAAmC;EAAA,IAAxB3C,kBAAwB,SAAxBA,kBAAwB;;EACrEpB,oBAAA,CAAYC,MAAZ,CAAmBgC,GAAnB,yGAAwHwE,MAAxH;;EAEA,IAAOtF,cAAP,GAAmCsF,MAAnC,CAAOtF,cAAP;EAAA,IAAuBV,QAAvB,GAAmCgG,MAAnC,CAAuBhG,QAAvB;EAEA,OAAOnD,EAAE,CAACoJ,YAAH,CAAgB;IACrBvF,cAAc,EAAdA,cADqB;IAErBV,QAAQ,EAAEA,QAAQ,CAAC,CAAD;EAFG,CAAhB,EAGJ;IAACsD,SAAS,EAATA,SAAD;IAAY3C,kBAAkB,EAAlBA;EAAZ,CAHI,EAG6B8D,IAH7B,CAGkC,UAACyB,cAAD,EAAoB;IAC3D;IACArJ,EAAE,CAACyD,gBAAH,CAAoB4F,cAApB;IAEA,OAAO,iBAAQtF,OAAR,CAAgB,CAACsF,cAAc,CAACnI,GAAhB,CAAhB,CAAP;EACD,CARM,CAAP;AASD,CAdD;AAgBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACAlB,EAAE,CAACoJ,YAAH,GAAkB,UAACD,MAAD,SAA6C;EAAA,IAAnC1C,SAAmC,SAAnCA,SAAmC;EAAA,IAAxB3C,kBAAwB,SAAxBA,kBAAwB;EAC7D,IAAOD,cAAP,GAAyBsF,MAAzB,CAAOtF,cAAP,CAD6D,CAG7D;EACA;;EACA,IAAIA,cAAc,CAAC6C,cAAf,KAAkC7F,cAAA,CAAIyI,iBAA1C,EAA6D;IAC3D,OAAO,iBAAQvF,OAAR,CAAgBF,cAAhB,CAAP;EACD;;EAED,OAAO7D,EAAE,CAACsG,uBAAH,CAA2BzC,cAA3B,EAA2C0D,gBAA3C,EAAkD4B,MAAM,CAAChG,QAAzD,EAAmEsD,SAAnE,EACJmB,IADI,CACC;IAAA,OAAM/D,cAAc,CAACuF,YAAf,CAA4BD,MAAM,CAACI,cAAnC,CAAN;EAAA,CADD,EAEJ3B,IAFI,CAEC,UAAC4B,MAAD;IAAA,OAEJ3F,cAAc,CAAC8E,mBAAf,CAAmCa,MAAnC,CAFI;EAAA,CAFD,EAKJ5B,IALI,CAKC;IAAA,OAAM5H,EAAE,CAAC4D,YAAH,CAAgBC,cAAhB,EAAgC;MAACC,kBAAkB,EAAlBA;IAAD,CAAhC,CAAN;EAAA,CALD,EAMJ8D,IANI,CAMC,YAAM;IACV/D,cAAc,CAAC3C,GAAf,GAAqBgC,cAAc,CAACW,cAAc,CAACS,gBAAf,CAAgCpD,GAAjC,CAAnC;IACA2C,cAAc,CAAC3C,GAAf,GAAqBD,QAAQ,CAAC4C,cAAc,CAAC3C,GAAhB,EAAqB4C,kBAArB,CAA7B;IACAD,cAAc,CAAC3C,GAAf,GAAqBqD,aAAA,CAAoBC,kBAApB,CAAuCX,cAAc,CAAC3C,GAAtD,CAArB;;IACA,IAAI,CAACY,gBAAgB,CAAC+B,cAAc,CAAC3C,GAAhB,CAArB,EAA2C;MACzC,MAAM,IAAIqH,cAAJ,CAAe,+EAAf,CAAN;IACD;;IAED,OAAO1E,cAAP;EACD,CAfI,EAgBJgE,KAhBI,CAgBE,UAACjF,KAAD,EAAW;IAChB,IAAIA,KAAK,YAAY8B,4BAArB,EAAsC;MACpCiC,gBAAA,CAAQ2B,oBAAR,CACEP,mBAAA,CAAmBc,qBADrB,EAEE;QACEZ,cAAc,EAAExB;MADlB,CAFF;IAMD,CAPD,MAQK;MACH,IAAMqB,UAAU,GAAGC,mBAAA,CAAmBC,sBAAtC;MACA,IAAMjB,IAAI,GAAG;QACXkB,cAAc,EAAExB,SADL;QAEXyB,MAAM,EAAEtF,KAAK,CAACuF,OAFH;QAGXC,KAAK,EAAExF,KAAK,CAACwF;MAHF,CAAb;MAKA,IAAMC,QAAQ,GAAG;QACflD,IAAI,EAAEvC,KAAK,CAACuE;MADG,CAAjB;;MAIAR,gBAAA,CAAQ2B,oBAAR,CAA6BR,UAA7B,EAAyCf,IAAzC,EAA+CsB,QAA/C;IACD;;IAED3F,oBAAA,CAAYC,MAAZ,CAAmBC,KAAnB,yGAA0HA,KAA1H;EACD,CAxCI,CAAP;AAyCD,CAlDD;AAoDA;AACA;AACA;AACA;AACA;;;AACA5C,EAAE,CAAC+I,KAAH,GAAW,UAAClF,cAAD,EAAoB;EAC7B;EACA;EACA;EACAnB,oBAAA,CAAYC,MAAZ,CAAmBgC,GAAnB,CAAuB,8FAAvB;;EAEA,IAAId,cAAc,IAAIA,cAAc,CAAC4F,eAAf,KAAmCC,gCAAA,CAAsBC,MAA/E,EAAuF;IACrFjH,oBAAA,CAAYC,MAAZ,CAAmBgC,GAAnB,CAAuB,gFAAvB;;IAEA,OAAO,iBAAQZ,OAAR,EAAP;EACD;;EACDrB,oBAAA,CAAYC,MAAZ,CAAmBgC,GAAnB,CAAuB,sFAAvB;;EAEA,OAAO,iBAAQZ,OAAR,GACJ6D,IADI,CACC,YAAM;IACV,IAAI/D,cAAc,IAAIA,cAAc,CAACkF,KAArC,EAA4C;MAC1ClF,cAAc,CAACkF,KAAf;IACD;EACF,CALI,CAAP;AAMD,CAnBD;;AAsBA/I,EAAE,CAAC4J,uBAAH,GAA6B,UAACC,OAAD,EAAa;EACxC;EACA,IAAOhG,cAAP,GAAyBgG,OAAO,CAACC,eAAjC,CAAOjG,cAAP;;EAEA,IAAMkG,gBAAgB,GAAG,SAAnBA,gBAAmB,GAAM;IAC7B,IAAIF,OAAO,CAACG,mBAAR,CAA4BC,QAA5B,CAAqClG,OAAzC,EAAkD;MAChD;MACA;MACA8F,OAAO,CAACG,mBAAR,CAA4BC,QAA5B,CAAqClG,OAArC;IACD;;IAED8F,OAAO,CAACK,SAAR,CAAkB;MAACC,iBAAiB,EAAE;IAApB,CAAlB;;IACAxD,gBAAA,CAAQC,SAAR,CAAkB;MAChBrB,KAAK,EAAEsB,kBAAA,CAAUuD,OADD;MAEhBP,OAAO,EAAPA,OAFgB;MAGhB9C,IAAI,EAAE;QACJC,UAAU,EAAE,KADR;QAEJC,MAAM,EAAE,CACNN,gBAAA,CAAQO,oBAAR,CACE,IADF,EACQ,KADR,EACetE,cAAA,CAAMuE,IAAN,CAAWC,YAD1B,CADM;MAFJ;IAHU,CAAlB;;IAYAyC,OAAO,CAACQ,UAAR,CAAmB;MACjBC,IAAI,EAAE,+BADW;MAEjBC,QAAQ,EAAE;IAFO,CAAnB;;IAKA5D,gBAAA,CAAQ2B,oBAAR,CACEP,mBAAA,CAAmByC,kBADrB,EAEE;MACEvC,cAAc,EAAE4B,OAAO,CAACY,aAD1B;MAEEC,QAAQ,EAAEb,OAAO,CAACc;IAFpB,CAFF;EAOD,CAhCD;;EAkCA9G,cAAc,CAAC+G,0BAAf,GAA4C,YAAM;IAChDlI,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,2EAAxB;;IACA,QAAQhH,cAAc,CAACiH,kBAAvB;MACE,KAAKC,oBAAA,CAAUC,QAAf;QACEtI,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,6EAAxB;;QACAlE,gBAAA,CAAQC,SAAR,CAAkB;UAACrB,KAAK,EAAEsB,kBAAA,CAAUoE,SAAlB;UAA6BpB,OAAO,EAAPA;QAA7B,CAAlB;;QACA;;MACF,KAAKkB,oBAAA,CAAUG,SAAf;QACExI,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,8EAAxB;;QACA;;MACF,KAAKE,oBAAA,CAAUI,SAAf;QACE;QACA;QACAxE,gBAAA,CAAQC,SAAR,CAAkB;UAACrB,KAAK,EAAEsB,kBAAA,CAAUuD,OAAlB;UAA2BP,OAAO,EAAPA;QAA3B,CAAlB;;QACAlD,gBAAA,CAAQ2B,oBAAR,CACEP,mBAAA,CAAmBqD,kBADrB,EAEE;UACEnD,cAAc,EAAE4B,OAAO,CAACY,aAD1B;UAEEC,QAAQ,EAAEb,OAAO,CAACc;QAFpB,CAFF;;QAOAd,OAAO,CAACwB,gBAAR,CAAyBC,yBAAA,CAAeH,SAAxC;QACAtB,OAAO,CAACG,mBAAR,CAA4BuB,cAA5B;;QACA7I,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,8EAAxB;;QACA;;MACF,KAAKE,oBAAA,CAAUpB,MAAf;QACEjH,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,2EAAxB;;QACA;;MACF,KAAKE,oBAAA,CAAUS,YAAf;QACE3B,OAAO,CAACwB,gBAAR,CAAyBC,yBAAA,CAAeE,YAAxC;QACA3B,OAAO,CAACG,mBAAR,CAA4ByB,mBAA5B,GACG5D,KADH,CACS,YAAM;UACXnF,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,mHAAxB;;UAEAd,gBAAgB;QACjB,CALH;;QAMArH,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,iFAAxB;;QACA;;MACF,KAAKE,oBAAA,CAAUW,MAAf;QACEhJ,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,2EAAxB,EADF,CAEE;QACA;QACA;;;QACAd,gBAAgB;QAChB;;MACF;QACE;IA5CJ;EA8CD,CAhDD;;EAkDAlG,cAAc,CAAC8H,uBAAf,GAAyC,YAAM;IAC7CjJ,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,kFAAxB;;IACA,QAAQhH,cAAc,CAAC4F,eAAvB;MACE,KAAKmC,2BAAA,CAAiBC,GAAtB;QACEnJ,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,+EAAxB;;QACA;;MACF,KAAKe,2BAAA,CAAiBE,UAAtB;QACEpJ,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,sFAAxB;;QACA;;MACF,KAAKe,2BAAA,CAAiBT,SAAtB;QACEzI,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,qFAAxB;;QACA;;MACF,KAAKe,2BAAA,CAAiBjC,MAAtB;QACEjH,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,kFAAxB;;QACA;;MACF,KAAKe,2BAAA,CAAiBJ,YAAtB;QACE9I,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,wFAAxB;;QACA;;MACF,KAAKe,2BAAA,CAAiBF,MAAtB;QACEhJ,oBAAA,CAAYC,MAAZ,CAAmBkI,IAAnB,CAAwB,kFAAxB,EADF,CAEE;QACA;;;QAEAd,gBAAgB;QAChB;;MACF;QACE;IAxBJ;EA0BD,CA5BD;AA6BD,CArHD;;eAuHe/J,E"}
|
|
@@ -38,10 +38,13 @@ var _constants = require("../constants");
|
|
|
38
38
|
|
|
39
39
|
var _request = _interopRequireDefault(require("./request"));
|
|
40
40
|
|
|
41
|
+
var DEFAULT_TIMEOUT = 3000;
|
|
42
|
+
var VIDEO_MESH_TIMEOUT = 1000;
|
|
41
43
|
/**
|
|
42
44
|
* @class Reachability
|
|
43
45
|
* @export
|
|
44
46
|
*/
|
|
47
|
+
|
|
45
48
|
var Reachability = /*#__PURE__*/function () {
|
|
46
49
|
/**
|
|
47
50
|
* Creates an instance of Reachability.
|
|
@@ -119,22 +122,25 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
119
122
|
case 13:
|
|
120
123
|
results = _context.sent;
|
|
121
124
|
window.localStorage.setItem(_constants.REACHABILITY.localStorage, (0, _stringify.default)(results));
|
|
125
|
+
|
|
126
|
+
_loggerProxy.default.logger.log('Reachability:index#gatherReachability --> Reachability checks completed');
|
|
127
|
+
|
|
122
128
|
return _context.abrupt("return", results);
|
|
123
129
|
|
|
124
|
-
case
|
|
125
|
-
_context.prev =
|
|
130
|
+
case 19:
|
|
131
|
+
_context.prev = 19;
|
|
126
132
|
_context.t0 = _context["catch"](7);
|
|
127
133
|
|
|
128
134
|
_loggerProxy.default.logger.error("Reachability:index#gatherReachability --> Error in calling getClusters(): ".concat(_context.t0));
|
|
129
135
|
|
|
130
136
|
return _context.abrupt("return", {});
|
|
131
137
|
|
|
132
|
-
case
|
|
138
|
+
case 23:
|
|
133
139
|
case "end":
|
|
134
140
|
return _context.stop();
|
|
135
141
|
}
|
|
136
142
|
}
|
|
137
|
-
}, _callee, this, [[7,
|
|
143
|
+
}, _callee, this, [[7, 19]]);
|
|
138
144
|
}));
|
|
139
145
|
|
|
140
146
|
function gatherReachability() {
|
|
@@ -186,7 +192,7 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
186
192
|
peerConnection.key = key;
|
|
187
193
|
return peerConnection;
|
|
188
194
|
} catch (peerConnectionError) {
|
|
189
|
-
_loggerProxy.default.logger.log("Reachability:index#
|
|
195
|
+
_loggerProxy.default.logger.log("Reachability:index#createPeerConnection --> Error creating peerConnection: ".concat(peerConnectionError));
|
|
190
196
|
|
|
191
197
|
return null;
|
|
192
198
|
}
|
|
@@ -242,7 +248,7 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
242
248
|
description = _context2.sent;
|
|
243
249
|
peerConnection.begin = (0, _now.default)();
|
|
244
250
|
peerConnection.setLocalDescription(description);
|
|
245
|
-
return _context2.abrupt("return", _this.iceGatheringState(peerConnection).catch(function (iceGatheringStateError) {
|
|
251
|
+
return _context2.abrupt("return", _this.iceGatheringState(peerConnection, cluster.isVideoMesh ? VIDEO_MESH_TIMEOUT : DEFAULT_TIMEOUT).catch(function (iceGatheringStateError) {
|
|
246
252
|
_loggerProxy.default.logger.log("Reachability:index#getLocalSDPForClusters --> Error in getLocalSDP : ".concat(iceGatheringStateError));
|
|
247
253
|
}));
|
|
248
254
|
|
|
@@ -344,16 +350,16 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
344
350
|
* speed.
|
|
345
351
|
* @private
|
|
346
352
|
* @param {RTCPeerConnection} peerConnection
|
|
353
|
+
* @param {number} timeout
|
|
347
354
|
* @returns {Promise}
|
|
348
355
|
*/
|
|
349
356
|
|
|
350
357
|
}, {
|
|
351
358
|
key: "iceGatheringState",
|
|
352
|
-
value: function iceGatheringState(peerConnection) {
|
|
359
|
+
value: function iceGatheringState(peerConnection, timeout) {
|
|
353
360
|
var _this4 = this;
|
|
354
361
|
|
|
355
362
|
var ELAPSED = 'elapsed';
|
|
356
|
-
var waitTime = 5e3;
|
|
357
363
|
return new _promise.default(function (resolve) {
|
|
358
364
|
var peerConnectionProxy = new window.Proxy(peerConnection, {
|
|
359
365
|
get: function get(target, property) {
|
|
@@ -387,14 +393,12 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
387
393
|
|
|
388
394
|
|
|
389
395
|
window.setTimeout(function () {
|
|
390
|
-
var CLOSED =
|
|
391
|
-
CONNECTION_STATE: _constants.CONNECTION_STATE
|
|
392
|
-
}; // Close any open peerConnections
|
|
396
|
+
var CLOSED = _constants.CONNECTION_STATE.CLOSED; // Close any open peerConnections
|
|
393
397
|
|
|
394
398
|
if (peerConnectionProxy.connectionState !== CLOSED) {
|
|
395
399
|
_this4.setLatencyAndClose(peerConnectionProxy, null);
|
|
396
400
|
}
|
|
397
|
-
},
|
|
401
|
+
}, timeout);
|
|
398
402
|
});
|
|
399
403
|
}
|
|
400
404
|
/**
|
|
@@ -409,7 +413,7 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
409
413
|
value: function logUnreachableClusters() {
|
|
410
414
|
var list = this.getUnreachablClusters();
|
|
411
415
|
list.forEach(function (cluster) {
|
|
412
|
-
_loggerProxy.default.logger.log("Reachability:index#
|
|
416
|
+
_loggerProxy.default.logger.log("Reachability:index#logUnreachableClusters --> No ice candidate for ".concat(cluster, "."));
|
|
413
417
|
});
|
|
414
418
|
}
|
|
415
419
|
/**
|