@webex/plugin-meetings 2.35.3 → 2.35.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/common/browser-detection.js.map +1 -1
- package/dist/common/collection.js.map +1 -1
- package/dist/common/config.js.map +1 -1
- package/dist/common/errors/captcha-error.js +7 -0
- package/dist/common/errors/captcha-error.js.map +1 -1
- package/dist/common/errors/intent-to-join.js +8 -0
- package/dist/common/errors/intent-to-join.js.map +1 -1
- package/dist/common/errors/join-meeting.js +8 -0
- package/dist/common/errors/join-meeting.js.map +1 -1
- package/dist/common/errors/media.js +7 -0
- package/dist/common/errors/media.js.map +1 -1
- package/dist/common/errors/parameter.js.map +1 -1
- package/dist/common/errors/password-error.js +7 -0
- package/dist/common/errors/password-error.js.map +1 -1
- package/dist/common/errors/permission.js +7 -0
- package/dist/common/errors/permission.js.map +1 -1
- package/dist/common/errors/reconnection-in-progress.js.map +1 -1
- package/dist/common/errors/reconnection.js +7 -0
- package/dist/common/errors/reconnection.js.map +1 -1
- package/dist/common/errors/stats.js +7 -0
- package/dist/common/errors/stats.js.map +1 -1
- package/dist/common/errors/webex-errors.js.map +1 -1
- package/dist/common/errors/webex-meetings-error.js +5 -2
- package/dist/common/errors/webex-meetings-error.js.map +1 -1
- package/dist/common/events/events-scope.js.map +1 -1
- package/dist/common/events/events.js.map +1 -1
- package/dist/common/events/trigger-proxy.js.map +1 -1
- package/dist/common/events/util.js.map +1 -1
- package/dist/common/logs/logger-config.js.map +1 -1
- package/dist/common/logs/logger-proxy.js.map +1 -1
- package/dist/common/logs/request.js +3 -0
- package/dist/common/logs/request.js.map +1 -1
- package/dist/common/queue.js.map +1 -1
- package/dist/config.js.map +1 -1
- package/dist/constants.js.map +1 -1
- package/dist/locus-info/controlsUtils.js.map +1 -1
- package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
- package/dist/locus-info/fullState.js.map +1 -1
- package/dist/locus-info/hostUtils.js.map +1 -1
- package/dist/locus-info/index.js +43 -5
- package/dist/locus-info/index.js.map +1 -1
- package/dist/locus-info/infoUtils.js.map +1 -1
- package/dist/locus-info/mediaSharesUtils.js.map +1 -1
- package/dist/locus-info/parser.js +12 -3
- package/dist/locus-info/parser.js.map +1 -1
- package/dist/locus-info/selfUtils.js.map +1 -1
- package/dist/media/index.js.map +1 -1
- package/dist/media/properties.js +12 -0
- package/dist/media/properties.js.map +1 -1
- package/dist/media/util.js.map +1 -1
- package/dist/mediaQualityMetrics/config.js.map +1 -1
- package/dist/meeting/effectsState.js +8 -1
- package/dist/meeting/effectsState.js.map +1 -1
- package/dist/meeting/index.js +151 -32
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/muteState.js +6 -0
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +54 -24
- package/dist/meeting/request.js.map +1 -1
- package/dist/meeting/state.js.map +1 -1
- package/dist/meeting/util.js.map +1 -1
- package/dist/meeting-info/collection.js +4 -1
- package/dist/meeting-info/collection.js.map +1 -1
- package/dist/meeting-info/index.js +5 -0
- package/dist/meeting-info/index.js.map +1 -1
- package/dist/meeting-info/meeting-info-v2.js +14 -2
- package/dist/meeting-info/meeting-info-v2.js.map +1 -1
- package/dist/meeting-info/request.js +3 -0
- package/dist/meeting-info/request.js.map +1 -1
- package/dist/meeting-info/util.js.map +1 -1
- package/dist/meeting-info/utilv2.js.map +1 -1
- package/dist/meetings/collection.js +4 -1
- package/dist/meetings/collection.js.map +1 -1
- package/dist/meetings/index.js +72 -20
- package/dist/meetings/index.js.map +1 -1
- package/dist/meetings/request.js +4 -0
- package/dist/meetings/request.js.map +1 -1
- package/dist/meetings/util.js.map +1 -1
- package/dist/member/index.js +30 -7
- package/dist/member/index.js.map +1 -1
- package/dist/member/util.js +2 -1
- package/dist/member/util.js.map +1 -1
- package/dist/members/collection.js +1 -0
- package/dist/members/collection.js.map +1 -1
- package/dist/members/index.js +12 -1
- package/dist/members/index.js.map +1 -1
- package/dist/members/request.js +19 -9
- package/dist/members/request.js.map +1 -1
- package/dist/members/util.js.map +1 -1
- package/dist/metrics/config.js.map +1 -1
- package/dist/metrics/constants.js.map +1 -1
- package/dist/metrics/index.js +8 -0
- package/dist/metrics/index.js.map +1 -1
- package/dist/networkQualityMonitor/index.js +10 -2
- package/dist/networkQualityMonitor/index.js.map +1 -1
- package/dist/peer-connection-manager/index.js +11 -4
- package/dist/peer-connection-manager/index.js.map +1 -1
- package/dist/personal-meeting-room/index.js +11 -0
- package/dist/personal-meeting-room/index.js.map +1 -1
- package/dist/personal-meeting-room/request.js +2 -1
- package/dist/personal-meeting-room/request.js.map +1 -1
- package/dist/personal-meeting-room/util.js.map +1 -1
- package/dist/reachability/index.js +17 -7
- package/dist/reachability/index.js.map +1 -1
- package/dist/reachability/request.js +1 -0
- package/dist/reachability/request.js.map +1 -1
- package/dist/reconnection-manager/index.js +21 -2
- package/dist/reconnection-manager/index.js.map +1 -1
- package/dist/roap/collection.js +1 -0
- package/dist/roap/collection.js.map +1 -1
- package/dist/roap/handler.js +14 -2
- package/dist/roap/handler.js.map +1 -1
- package/dist/roap/index.js +11 -1
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +7 -2
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/state.js.map +1 -1
- package/dist/roap/turnDiscovery.js +9 -1
- package/dist/roap/turnDiscovery.js.map +1 -1
- package/dist/roap/util.js.map +1 -1
- package/dist/statsAnalyzer/global.js.map +1 -1
- package/dist/statsAnalyzer/index.js +19 -1
- package/dist/statsAnalyzer/index.js.map +1 -1
- package/dist/statsAnalyzer/mqaUtil.js +9 -3
- package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
- package/dist/transcription/index.js +10 -3
- package/dist/transcription/index.js.map +1 -1
- package/package.json +17 -17
- package/src/common/{browser-detection.js → browser-detection.ts} +1 -1
- package/src/common/collection.ts +6 -6
- package/src/common/{config.js → config.ts} +1 -1
- package/src/common/errors/{captcha-error.js → captcha-error.ts} +5 -1
- package/src/common/errors/{intent-to-join.js → intent-to-join.ts} +6 -1
- package/src/common/errors/{join-meeting.js → join-meeting.ts} +6 -1
- package/src/common/errors/{media.js → media.ts} +5 -1
- package/src/common/errors/parameter.ts +3 -2
- package/src/common/errors/{password-error.js → password-error.ts} +5 -1
- package/src/common/errors/{permission.js → permission.ts} +5 -1
- package/src/common/errors/{reconnection-in-progress.js → reconnection-in-progress.ts} +0 -0
- package/src/common/errors/{reconnection.js → reconnection.ts} +5 -1
- package/src/common/errors/{stats.js → stats.ts} +5 -1
- package/src/common/errors/{webex-errors.js → webex-errors.ts} +1 -2
- package/src/common/errors/{webex-meetings-error.js → webex-meetings-error.ts} +3 -1
- package/src/common/events/{events-scope.js → events-scope.ts} +1 -1
- package/src/common/events/{events.js → events.ts} +0 -0
- package/src/common/events/{trigger-proxy.js → trigger-proxy.ts} +1 -2
- package/src/common/events/{util.js → util.ts} +1 -1
- package/src/common/logs/{logger-config.js → logger-config.ts} +1 -2
- package/src/common/logs/{logger-proxy.js → logger-proxy.ts} +1 -1
- package/src/common/logs/{request.js → request.ts} +12 -2
- package/src/common/queue.ts +1 -2
- package/src/{config.js → config.ts} +1 -0
- package/src/constants.ts +1 -0
- package/src/locus-info/{controlsUtils.js → controlsUtils.ts} +4 -4
- package/src/locus-info/{embeddedAppsUtils.js → embeddedAppsUtils.ts} +5 -6
- package/src/locus-info/{fullState.js → fullState.ts} +1 -1
- package/src/locus-info/{hostUtils.js → hostUtils.ts} +5 -5
- package/src/locus-info/{index.js → index.ts} +67 -32
- package/src/locus-info/{infoUtils.js → infoUtils.ts} +3 -4
- package/src/locus-info/{mediaSharesUtils.js → mediaSharesUtils.ts} +13 -13
- package/src/locus-info/{parser.js → parser.ts} +22 -12
- package/src/locus-info/{selfUtils.js → selfUtils.ts} +17 -19
- package/src/media/{index.js → index.ts} +108 -39
- package/src/media/{properties.js → properties.ts} +16 -4
- package/src/media/{util.js → util.ts} +2 -3
- package/src/mediaQualityMetrics/{config.js → config.ts} +1 -1
- package/src/meeting/{effectsState.js → effectsState.ts} +12 -6
- package/src/meeting/{index.js → index.ts} +323 -147
- package/src/meeting/{muteState.js → muteState.ts} +16 -11
- package/src/meeting/{request.js → request.ts} +124 -36
- package/src/meeting/{state.js → state.ts} +6 -6
- package/src/meeting/{util.js → util.ts} +4 -4
- package/src/meeting-info/{collection.js → collection.ts} +4 -1
- package/src/meeting-info/{index.js → index.ts} +10 -6
- package/src/meeting-info/{meeting-info-v2.js → meeting-info-v2.ts} +28 -10
- package/src/meeting-info/{request.js → request.ts} +6 -2
- package/src/meeting-info/{util.js → util.ts} +6 -5
- package/src/meeting-info/{utilv2.js → utilv2.ts} +8 -7
- package/src/meetings/{collection.js → collection.ts} +5 -2
- package/src/meetings/{index.js → index.ts} +88 -22
- package/src/meetings/{request.js → request.ts} +6 -1
- package/src/meetings/{util.js → util.ts} +5 -3
- package/src/member/{index.js → index.ts} +46 -15
- package/src/member/{util.js → util.ts} +17 -16
- package/src/members/{collection.js → collection.ts} +2 -1
- package/src/members/{index.js → index.ts} +39 -26
- package/src/members/{request.js → request.ts} +16 -5
- package/src/members/{util.js → util.ts} +7 -7
- package/src/metrics/{config.js → config.ts} +0 -2
- package/src/metrics/{constants.js → constants.ts} +0 -0
- package/src/metrics/{index.js → index.ts} +27 -8
- package/src/networkQualityMonitor/{index.js → index.ts} +18 -3
- package/src/peer-connection-manager/{index.js → index.ts} +72 -28
- package/src/personal-meeting-room/{index.js → index.ts} +17 -4
- package/src/personal-meeting-room/{request.js → request.ts} +3 -1
- package/src/personal-meeting-room/{util.js → util.ts} +1 -1
- package/src/reachability/{index.js → index.ts} +28 -17
- package/src/reachability/request.ts +4 -2
- package/src/reconnection-manager/{index.js → index.ts} +42 -13
- package/src/roap/{collection.js → collection.ts} +1 -0
- package/src/roap/{handler.js → handler.ts} +15 -4
- package/src/roap/{index.js → index.ts} +23 -10
- package/src/roap/{request.js → request.ts} +19 -3
- package/src/roap/{state.js → state.ts} +3 -2
- package/src/roap/turnDiscovery.ts +14 -5
- package/src/roap/{util.js → util.ts} +1 -2
- package/src/statsAnalyzer/{global.js → global.ts} +0 -0
- package/src/statsAnalyzer/{index.js → index.ts} +36 -17
- package/src/statsAnalyzer/{mqaUtil.js → mqaUtil.ts} +6 -1
- package/src/transcription/{index.js → index.ts} +16 -11
- package/test/integration/spec/space-meeting.js +1 -2
- package/test/unit/spec/roap/util.js +1 -1
|
@@ -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","setRemoteVideoConstraints","sdp","level","QUALITY_LEVELS","HIGH","maxFs","REMOTE_VIDEO_CONSTRAINTS","MAX_FS","ParameterError","modifiedSdp","PeerConnectionUtils","adjustH264Profile","setStartBitrateOnRemoteSdp","startBitrate","replace","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","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 REMOTE_VIDEO_CONSTRAINTS\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 setRemoteVideoConstraints = (sdp, level = QUALITY_LEVELS.HIGH) => {\n const maxFs = REMOTE_VIDEO_CONSTRAINTS.MAX_FS[level];\n\n if (!maxFs) {\n throw new ParameterError(`setRemoteVideoConstraints: unable to set max framesize, value for level \"${level}\" is not defined`);\n }\n\n const modifiedSdp = PeerConnectionUtils.adjustH264Profile(sdp, maxFs);\n\n return modifiedSdp;\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 = PeerConnectionUtils.convertCLineToIpv4(peerConnection.sdp);\n peerConnection.sdp = setRemoteVideoConstraints(peerConnection.sdp, remoteQualityLevel);\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 = PeerConnectionUtils.convertCLineToIpv4(peerConnection.sdp);\n peerConnection.sdp = setRemoteVideoConstraints(peerConnection.sdp, remoteQualityLevel);\n\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","setRemoteVideoConstraints","sdp","level","QUALITY_LEVELS","HIGH","maxFs","REMOTE_VIDEO_CONSTRAINTS","MAX_FS","ParameterError","modifiedSdp","PeerConnectionUtils","adjustH264Profile","setStartBitrateOnRemoteSdp","startBitrate","replace","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","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.ts"],"sourcesContent":["// 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 REMOTE_VIDEO_CONSTRAINTS\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: any = {};\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: any, index: number) => {\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 setRemoteVideoConstraints = (sdp: string, level: string = QUALITY_LEVELS.HIGH) => {\n const maxFs = REMOTE_VIDEO_CONSTRAINTS.MAX_FS[level];\n\n if (!maxFs) {\n throw new ParameterError(`setRemoteVideoConstraints: unable to set max framesize, value for level \"${level}\" is not defined`);\n }\n\n const modifiedSdp = PeerConnectionUtils.adjustH264Profile(sdp, maxFs);\n\n return modifiedSdp;\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: string) => {\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: string) => {\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: string) => {\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: any) => {\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 = (\n peerConnection: any,\n {\n remoteQualityLevel,\n }: {\n remoteQualityLevel: string;\n }\n) =>\n new Promise<void>((resolve, reject) => {\n const now = Date.now();\n const doneGatheringIceCandidate = () => {\n // @ts-ignore\n const miliseconds = parseInt(Math.abs(Date.now() - now), 4);\n\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = PeerConnectionUtils.convertCLineToIpv4(peerConnection.sdp);\n peerConnection.sdp = setRemoteVideoConstraints(peerConnection.sdp, remoteQualityLevel);\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 // @ts-ignore\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 // @ts-ignore\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: any, track: any) => {\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: any, stream: any) => {\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 = (peerConnection: any, typeStr: string, remoteSdp: string, meetingId: string) => {\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 = (\n peerConnection: any,\n {\n meetingId,\n remoteQualityLevel,\n enableRtx,\n enableExtmap,\n }: {\n meetingId: string;\n remoteQualityLevel: string;\n enableRtx: string;\n enableExtmap: string;\n }\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 // @ts-ignore\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: any) => peerConnection\n// @ts-ignore\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 // @ts-ignore\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 = (\n params: {\n offerToReceiveAudio: boolean;\n offerToReceiveVideo: boolean;\n offerSdp: string;\n stream: MediaStream;\n peerConnection: any\n },\n {\n meetingId,\n remoteQualityLevel,\n }: {\n meetingId: string;\n remoteQualityLevel: string;\n }\n) => {\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 = (\n params: {\n peerConnection: any;\n sdpConstraints: object;\n offerSdp: any;\n },\n {\n meetingId,\n remoteQualityLevel,\n }: {\n meetingId: string;\n remoteQualityLevel: string;\n }\n) => {\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 = PeerConnectionUtils.convertCLineToIpv4(peerConnection.sdp);\n peerConnection.sdp = setRemoteVideoConstraints(peerConnection.sdp, remoteQualityLevel);\n\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: any) => {\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 // @ts-ignore\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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"}
|
|
@@ -66,6 +66,15 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
|
|
|
66
66
|
* @memberof PersonalMeetingRoom
|
|
67
67
|
*/
|
|
68
68
|
|
|
69
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "link", void 0);
|
|
70
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "meetingInfo", void 0);
|
|
71
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "name", void 0);
|
|
72
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "personalMeetingRoomRequest", void 0);
|
|
73
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "pmr", void 0);
|
|
74
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "sipUri", void 0);
|
|
75
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "userId", void 0);
|
|
76
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "meetingLink", void 0);
|
|
77
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "number", void 0);
|
|
69
78
|
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "namespace", _constants.MEETINGS);
|
|
70
79
|
_this.pmr = null;
|
|
71
80
|
/**
|
|
@@ -120,6 +129,7 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
|
|
|
120
129
|
* @private
|
|
121
130
|
* @memberof PersonalMeetingRoom
|
|
122
131
|
*/
|
|
132
|
+
// @ts-ignore
|
|
123
133
|
|
|
124
134
|
_this.personalMeetingRoomRequest = new _request.default({}, options);
|
|
125
135
|
return _this;
|
|
@@ -142,6 +152,7 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
|
|
|
142
152
|
|
|
143
153
|
var preferred = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
|
|
144
154
|
var options = {
|
|
155
|
+
// @ts-ignore
|
|
145
156
|
userId: this.webex.internal.device.userId,
|
|
146
157
|
passcode: pin,
|
|
147
158
|
meetingAddress: link,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["PersonalMeetingRoom","attrs","options","MEETINGS","pmr","sipUri","link","userId","name","meetingInfo","personalMeetingRoomRequest","PersonalMeetingRoomRequest","pin","preferred","webex","internal","device","passcode","meetingAddress","claimPmr","then","body","set","reject","ParameterError","sipMeetingUri","meetingLink","webExMeetingLink","owner","meetingName","number","meetingNumber","type","_PERSONAL_ROOM_","fetchMeetingInfo","isPmr","TypeError","StatelessWebexPlugin"],"sources":["index.
|
|
1
|
+
{"version":3,"names":["PersonalMeetingRoom","attrs","options","MEETINGS","pmr","sipUri","link","userId","name","meetingInfo","personalMeetingRoomRequest","PersonalMeetingRoomRequest","pin","preferred","webex","internal","device","passcode","meetingAddress","claimPmr","then","body","set","reject","ParameterError","sipMeetingUri","meetingLink","webExMeetingLink","owner","meetingName","number","meetingNumber","type","_PERSONAL_ROOM_","fetchMeetingInfo","isPmr","TypeError","StatelessWebexPlugin"],"sources":["index.ts"],"sourcesContent":["// @ts-ignore\nimport {StatelessWebexPlugin} from '@webex/webex-core';\n\nimport {MEETINGS, _PERSONAL_ROOM_} from '../constants';\nimport ParameterError from '../common/errors/parameter';\n\nimport PersonalMeetingRoomRequest from './request';\n\n\n/**\n * @class PersonalMeetingRoom\n */\nexport default class PersonalMeetingRoom extends StatelessWebexPlugin {\n link: any;\n meetingInfo: any;\n name: any;\n personalMeetingRoomRequest: any;\n pmr: any;\n sipUri: any;\n userId: any;\n meetingLink: any;\n number: any;\n\n namespace = MEETINGS;\n\n /**\n *\n * @param {Object} attrs\n * @param {Object} options\n */\n constructor(attrs: any, options: any) {\n super({}, options);\n /**\n * The pmr server object\n * @instance\n * @type {Object}\n * @public\n * @memberof PersonalMeetingRoom\n */\n this.pmr = null;\n /**\n * The pmr sip Uri\n * @instance\n * @type {String}\n * @public\n * @memberof PersonalMeetingRoom\n */\n this.sipUri = null;\n /**\n * The pmr link\n * @instance\n * @type {String}\n * @public\n * @memberof PersonalMeetingRoom\n */\n this.link = null;\n /**\n * The pmr server object\n * @instance\n * @type {Object}\n * @public\n * @memberof PersonalMeetingRoom\n */\n this.userId = null;\n /**\n * The pmr name\n * @instance\n * @type {String}\n * @public\n * @memberof PersonalMeetingRoom\n */\n this.name = null;\n /**\n * The meeting info request server interface\n * @instance\n * @type {MeetingInfo}\n * @private\n * @memberof PersonalMeetingRoom\n */\n this.meetingInfo = attrs.meetingInfo;\n /**\n * The pmr server request interface\n * @instance\n * @type {Object}\n * @private\n * @memberof PersonalMeetingRoom\n */\n // @ts-ignore\n this.personalMeetingRoomRequest = new PersonalMeetingRoomRequest({}, options);\n }\n\n /**\n * claims a pmr and updates the cached PMR values\n * @param {String} link\n * @param {String} pin\n * @param {Boolean} [preferred] defaults to true to set this claimed PMR as the preferred\n * @returns {Promise}\n * @public\n * @memberof PersonalMeetingRoom\n */\n public claim(link: string, pin: string, preferred: boolean = true) {\n const options = {\n // @ts-ignore\n userId: this.webex.internal.device.userId,\n passcode: pin,\n meetingAddress: link,\n preferred\n };\n\n return this.personalMeetingRoomRequest.claimPmr(options).then((pmr) => {\n if (pmr && pmr.body) {\n this.set(pmr.body);\n }\n else {\n return Promise.reject(new ParameterError('No PMR body provided. PMR values not updated.'));\n }\n\n return pmr.body;\n });\n }\n\n /**\n * @param {Object} body the response body from meeting info request\n * @returns {undefined}\n * @private\n * @memberof PersonalMeetingRoom\n */\n private set(body: any) {\n this.pmr = body;\n this.sipUri = body.sipMeetingUri;\n this.meetingLink = body.webExMeetingLink || body.meetingLink;\n this.userId = body.owner;\n this.name = body.meetingName;\n this.number = body.meetingNumber;\n }\n\n /**\n * TODO: implement TTL for syncing and caching so to not request again and again\n * @param {Object} options\n * @returns {Promise}\n * @public\n * @memberof PersonalMeetingRoom\n */\n public get() {\n const options = {\n type: _PERSONAL_ROOM_\n\n };\n\n return this.meetingInfo.fetchMeetingInfo(options).then((pmr) => {\n if (pmr && pmr.body && pmr.body.isPmr) {\n this.set(pmr.body);\n }\n else {\n return Promise.reject(new TypeError('The PMR requested is NOT a PMR. PMR values not set.'));\n }\n\n return pmr.body;\n });\n }\n}\n"],"mappings":"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"}
|
|
@@ -88,7 +88,8 @@ var PersonalMeetingRoomRequest = /*#__PURE__*/function (_StatelessWebexPlugin) {
|
|
|
88
88
|
return _promise.default.reject(new _parameter.default('The PMR link provided was of an invalid format'));
|
|
89
89
|
}
|
|
90
90
|
|
|
91
|
-
var request = _util.default.getClaimedRequestParams(validLink, validPin, options);
|
|
91
|
+
var request = _util.default.getClaimedRequestParams(validLink, validPin, options); // @ts-ignore
|
|
92
|
+
|
|
92
93
|
|
|
93
94
|
return this.request(request);
|
|
94
95
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["PersonalMeetingRoomRequest","MEETINGS","options","userId","passcode","meetingAddress","preferred","ParameterError","validPin","PersonalMeetingRoomUtil","getClaimPmrPin","reject","validLink","getClaimPmrLink","request","getClaimedRequestParams","StatelessWebexPlugin"],"sources":["request.
|
|
1
|
+
{"version":3,"names":["PersonalMeetingRoomRequest","MEETINGS","options","userId","passcode","meetingAddress","preferred","ParameterError","validPin","PersonalMeetingRoomUtil","getClaimPmrPin","reject","validLink","getClaimPmrLink","request","getClaimedRequestParams","StatelessWebexPlugin"],"sources":["request.ts"],"sourcesContent":["// @ts-ignore\nimport {StatelessWebexPlugin} from '@webex/webex-core';\n\nimport {MEETINGS} from '../constants';\nimport ParameterError from '../common/errors/parameter';\n\nimport PersonalMeetingRoomUtil from './util';\n\n\n/**\n * @class MeetingInfoRequest\n */\nexport default class PersonalMeetingRoomRequest extends StatelessWebexPlugin {\n namespace = MEETINGS;\n\n /**\n *\n * @param {Object} options with format of {userId, passcode, meetingAddress, preferred}\n * @returns {Promise} returns a promise that resolves/rejects the result of the request\n * @memberof PersonalMeetingRoomRequest\n */\n claimPmr(options: any) {\n if (!options || !options.userId || !options.passcode || !options.meetingAddress || !options.preferred) {\n throw new ParameterError('Claiming a PMR should be done with userId, passcode, preferred, and meetingAddress in options.');\n }\n const validPin = PersonalMeetingRoomUtil.getClaimPmrPin(options.passcode);\n\n if (!validPin) {\n return Promise.reject(new ParameterError('The host pin provided was of an invalid format'));\n }\n const validLink = PersonalMeetingRoomUtil.getClaimPmrLink(options.meetingAddress);\n\n if (!validLink) {\n return Promise.reject(new ParameterError('The PMR link provided was of an invalid format'));\n }\n const request = PersonalMeetingRoomUtil.getClaimedRequestParams(validLink, validPin, options);\n\n // @ts-ignore\n return this.request(request);\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA;;AAEA;;AACA;;AAEA;;;;;;AAGA;AACA;AACA;IACqBA,0B;;;;;;;;;;;;;;;4FACPC,mB;;;;;;;IAEZ;AACF;AACA;AACA;AACA;AACA;IACE,kBAASC,OAAT,EAAuB;MACrB,IAAI,CAACA,OAAD,IAAY,CAACA,OAAO,CAACC,MAArB,IAA+B,CAACD,OAAO,CAACE,QAAxC,IAAoD,CAACF,OAAO,CAACG,cAA7D,IAA+E,CAACH,OAAO,CAACI,SAA5F,EAAuG;QACrG,MAAM,IAAIC,kBAAJ,CAAmB,gGAAnB,CAAN;MACD;;MACD,IAAMC,QAAQ,GAAGC,aAAA,CAAwBC,cAAxB,CAAuCR,OAAO,CAACE,QAA/C,CAAjB;;MAEA,IAAI,CAACI,QAAL,EAAe;QACb,OAAO,iBAAQG,MAAR,CAAe,IAAIJ,kBAAJ,CAAmB,gDAAnB,CAAf,CAAP;MACD;;MACD,IAAMK,SAAS,GAAGH,aAAA,CAAwBI,eAAxB,CAAwCX,OAAO,CAACG,cAAhD,CAAlB;;MAEA,IAAI,CAACO,SAAL,EAAgB;QACd,OAAO,iBAAQD,MAAR,CAAe,IAAIJ,kBAAJ,CAAmB,gDAAnB,CAAf,CAAP;MACD;;MACD,IAAMO,OAAO,GAAGL,aAAA,CAAwBM,uBAAxB,CAAgDH,SAAhD,EAA2DJ,QAA3D,EAAqEN,OAArE,CAAhB,CAdqB,CAgBrB;;;MACA,OAAO,KAAKY,OAAL,CAAaA,OAAb,CAAP;IACD;;;EA3BqDE,+B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["PersonalMeetingRoomUtil","getClaimPmrLink","pmrLink","validator","VALID_PMR_ADDRESS","test","match","VALID_PMR_LINK","WEBEX_DOT_COM","getClaimPmrPin","hostPin","VALID_PIN","getClaimedRequestParams","link","pin","options","method","HTTP_VERBS","POST","api","HECATE","resource","CMR_MEETINGS","CLAIM","body","userId","passcode","preferred","meetingAddress"],"sources":["util.
|
|
1
|
+
{"version":3,"names":["PersonalMeetingRoomUtil","getClaimPmrLink","pmrLink","validator","VALID_PMR_ADDRESS","test","match","VALID_PMR_LINK","WEBEX_DOT_COM","getClaimPmrPin","hostPin","VALID_PIN","getClaimedRequestParams","link","pin","options","method","HTTP_VERBS","POST","api","HECATE","resource","CMR_MEETINGS","CLAIM","body","userId","passcode","preferred","meetingAddress"],"sources":["util.ts"],"sourcesContent":["import {\n HTTP_VERBS,\n VALID_PIN,\n VALID_PMR_ADDRESS,\n VALID_PMR_LINK,\n CMR_MEETINGS,\n CLAIM,\n HECATE,\n WEBEX_DOT_COM\n} from '../constants';\n\nconst PersonalMeetingRoomUtil: any = {};\n\nPersonalMeetingRoomUtil.getClaimPmrLink = (pmrLink) => {\n let validator = VALID_PMR_ADDRESS.test(pmrLink);\n\n if (validator) {\n return pmrLink;\n }\n validator = pmrLink.match(VALID_PMR_LINK);\n if (validator) {\n // userId + '@' + site + '.webex.com'\n return `${validator[4]}@${validator[2]}.${WEBEX_DOT_COM}`;\n }\n\n return null;\n};\n\nPersonalMeetingRoomUtil.getClaimPmrPin = (hostPin) => {\n if (VALID_PIN.test(hostPin)) {\n return hostPin;\n }\n\n return null;\n};\n\nPersonalMeetingRoomUtil.getClaimedRequestParams = (link, pin, options) => ({\n method: HTTP_VERBS.POST,\n api: HECATE,\n resource: `/${CMR_MEETINGS}/${CLAIM}`,\n body: {\n userId: options.userId,\n passcode: pin,\n preferred: options.preferred,\n meetingAddress: link\n }\n});\n\nexport default PersonalMeetingRoomUtil;\n"],"mappings":";;;;;;;;;;AAAA;;AAWA,IAAMA,uBAA4B,GAAG,EAArC;;AAEAA,uBAAuB,CAACC,eAAxB,GAA0C,UAACC,OAAD,EAAa;EACrD,IAAIC,SAAS,GAAGC,4BAAA,CAAkBC,IAAlB,CAAuBH,OAAvB,CAAhB;;EAEA,IAAIC,SAAJ,EAAe;IACb,OAAOD,OAAP;EACD;;EACDC,SAAS,GAAGD,OAAO,CAACI,KAAR,CAAcC,yBAAd,CAAZ;;EACA,IAAIJ,SAAJ,EAAe;IACb;IACA,iBAAUA,SAAS,CAAC,CAAD,CAAnB,cAA0BA,SAAS,CAAC,CAAD,CAAnC,cAA0CK,wBAA1C;EACD;;EAED,OAAO,IAAP;AACD,CAbD;;AAeAR,uBAAuB,CAACS,cAAxB,GAAyC,UAACC,OAAD,EAAa;EACpD,IAAIC,oBAAA,CAAUN,IAAV,CAAeK,OAAf,CAAJ,EAA6B;IAC3B,OAAOA,OAAP;EACD;;EAED,OAAO,IAAP;AACD,CAND;;AAQAV,uBAAuB,CAACY,uBAAxB,GAAkD,UAACC,IAAD,EAAOC,GAAP,EAAYC,OAAZ;EAAA,OAAyB;IACzEC,MAAM,EAAEC,qBAAA,CAAWC,IADsD;IAEzEC,GAAG,EAAEC,iBAFoE;IAGzEC,QAAQ,aAAMC,uBAAN,cAAsBC,gBAAtB,CAHiE;IAIzEC,IAAI,EAAE;MACJC,MAAM,EAAEV,OAAO,CAACU,MADZ;MAEJC,QAAQ,EAAEZ,GAFN;MAGJa,SAAS,EAAEZ,OAAO,CAACY,SAHf;MAIJC,cAAc,EAAEf;IAJZ;EAJmE,CAAzB;AAAA,CAAlD;;eAYeb,uB"}
|
|
@@ -22,8 +22,6 @@ var _keys = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/objec
|
|
|
22
22
|
|
|
23
23
|
var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
|
|
24
24
|
|
|
25
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
|
|
26
|
-
|
|
27
25
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/toConsumableArray"));
|
|
28
26
|
|
|
29
27
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/asyncToGenerator"));
|
|
@@ -32,6 +30,8 @@ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/he
|
|
|
32
30
|
|
|
33
31
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
|
|
34
32
|
|
|
33
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
|
|
34
|
+
|
|
35
35
|
var _uniq2 = _interopRequireDefault(require("lodash/uniq"));
|
|
36
36
|
|
|
37
37
|
var _loggerProxy = _interopRequireDefault(require("../common/logs/logger-proxy"));
|
|
@@ -55,6 +55,9 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
55
55
|
*/
|
|
56
56
|
function Reachability(webex) {
|
|
57
57
|
(0, _classCallCheck2.default)(this, Reachability);
|
|
58
|
+
(0, _defineProperty2.default)(this, "webex", void 0);
|
|
59
|
+
(0, _defineProperty2.default)(this, "reachabilityRequest", void 0);
|
|
60
|
+
(0, _defineProperty2.default)(this, "clusterLatencyResults", void 0);
|
|
58
61
|
this.webex = webex;
|
|
59
62
|
/**
|
|
60
63
|
* internal request object for the server
|
|
@@ -218,7 +221,8 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
218
221
|
config = cluster.config;
|
|
219
222
|
|
|
220
223
|
try {
|
|
221
|
-
var peerConnection = new window.RTCPeerConnection(config);
|
|
224
|
+
var peerConnection = new window.RTCPeerConnection(config); // @ts-ignore
|
|
225
|
+
|
|
222
226
|
peerConnection.key = key;
|
|
223
227
|
return peerConnection;
|
|
224
228
|
} catch (peerConnectionError) {
|
|
@@ -276,6 +280,7 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
276
280
|
|
|
277
281
|
case 5:
|
|
278
282
|
description = _context2.sent;
|
|
283
|
+
// @ts-ignore
|
|
279
284
|
peerConnection.begin = (0, _now.default)();
|
|
280
285
|
peerConnection.setLocalDescription(description);
|
|
281
286
|
return _context2.abrupt("return", _this.iceGatheringState(peerConnection, cluster.isVideoMesh ? VIDEO_MESH_TIMEOUT : DEFAULT_TIMEOUT).catch(function (iceGatheringStateError) {
|
|
@@ -340,7 +345,8 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
340
345
|
var COMPLETE = _constants.ICE_GATHERING_STATE.COMPLETE;
|
|
341
346
|
|
|
342
347
|
if (peerConnection.iceConnectionState === COMPLETE) {
|
|
343
|
-
var elapsed = _this2.getElapsedTime(peerConnection);
|
|
348
|
+
var elapsed = _this2.getElapsedTime(peerConnection); // @ts-ignore
|
|
349
|
+
|
|
344
350
|
|
|
345
351
|
_loggerProxy.default.logger.log("Reachability:index#onIceGatheringStateChange --> Successfully pinged ".concat(peerConnection.key, ":"), elapsed);
|
|
346
352
|
|
|
@@ -366,7 +372,8 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
366
372
|
var SERVER_REFLEXIVE = 'srflx';
|
|
367
373
|
|
|
368
374
|
if (e.candidate && String(e.candidate.type).toLowerCase() === SERVER_REFLEXIVE) {
|
|
369
|
-
var elapsed = _this3.getElapsedTime(peerConnection);
|
|
375
|
+
var elapsed = _this3.getElapsedTime(peerConnection); // @ts-ignore
|
|
376
|
+
|
|
370
377
|
|
|
371
378
|
_loggerProxy.default.logger.log("Reachability:index#onIceCandidate --> Successfully pinged ".concat(peerConnection.key, ":"), elapsed);
|
|
372
379
|
|
|
@@ -404,6 +411,7 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
404
411
|
set: function set(target, property, value) {
|
|
405
412
|
// only intercept elapsed property
|
|
406
413
|
if (property === ELAPSED) {
|
|
414
|
+
// @ts-ignore
|
|
407
415
|
resolve({
|
|
408
416
|
clusterId: peerConnection.key,
|
|
409
417
|
elapsed: value
|
|
@@ -531,7 +539,8 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
531
539
|
|
|
532
540
|
var REACHABLE = 'reachable';
|
|
533
541
|
var UNREACHABLE = 'unreachable';
|
|
534
|
-
var CLOSED = _constants.CONNECTION_STATE.CLOSED;
|
|
542
|
+
var CLOSED = _constants.CONNECTION_STATE.CLOSED; // @ts-ignore
|
|
543
|
+
|
|
535
544
|
var key = peerConnection.key;
|
|
536
545
|
var resultKey = elapsed === null ? UNREACHABLE : REACHABLE;
|
|
537
546
|
var intialState = (_intialState = {}, (0, _defineProperty2.default)(_intialState, REACHABLE, 0), (0, _defineProperty2.default)(_intialState, UNREACHABLE, 0), _intialState);
|
|
@@ -547,7 +556,8 @@ var Reachability = /*#__PURE__*/function () {
|
|
|
547
556
|
// an event other than onIceCandidate
|
|
548
557
|
|
|
549
558
|
peerConnection.onicecandidate = null;
|
|
550
|
-
peerConnection.close();
|
|
559
|
+
peerConnection.close(); // @ts-ignore
|
|
560
|
+
|
|
551
561
|
peerConnection.elapsed = elapsed;
|
|
552
562
|
}
|
|
553
563
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["DEFAULT_TIMEOUT","VIDEO_MESH_TIMEOUT","Reachability","webex","reachabilityRequest","ReachabilityRequest","clusterLatencyResults","setup","window","localStorage","removeItem","REACHABILITY","LoggerProxy","logger","error","getClusters","clusters","performReachabilityCheck","results","setItem","log","reachable","reachabilityData","getItem","reachabilityResults","JSON","parse","some","result","udp","tcp","e","cluster","iceServers","map","url","username","credential","urls","iceCandidatePoolSize","iceTransportPolicy","key","config","peerConnection","RTCPeerConnection","peerConnectionError","startTime","begin","clusterList","buildPeerConnectionConfig","createPeerConnection","createOffer","offerToReceiveAudio","description","setLocalDescription","iceGatheringState","isVideoMesh","catch","iceGatheringStateError","all","then","parseIceResultsToReachabilityResults","reachabilityLatencyResults","logUnreachableClusters","unreachableList","forEach","unreachable","push","onicegatheringstatechange","COMPLETE","ICE_GATHERING_STATE","iceConnectionState","elapsed","getElapsedTime","setLatencyAndClose","onicecandidate","SERVER_REFLEXIVE","candidate","String","type","toLowerCase","timeout","ELAPSED","resolve","peerConnectionProxy","Proxy","get","target","property","targetMember","bind","set","value","clusterId","Reflect","handleIceGatheringStateChange","handleOnIceCandidate","setTimeout","CLOSED","CONNECTION_STATE","connectionState","list","getUnreachablClusters","iceResults","reachabilityMap","latencyResult","latencyInMilliseconds","toString","length","getLocalSDPForClusters","localSDPData","REACHABLE","UNREACHABLE","resultKey","intialState","close"],"sources":["index.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\n/* eslint-disable class-methods-use-this */\n/* globals window */\nimport _ from 'lodash';\n\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport {\n ICE_GATHERING_STATE,\n CONNECTION_STATE,\n REACHABILITY\n} from '../constants';\n\nimport ReachabilityRequest from './request';\n\nconst DEFAULT_TIMEOUT = 3000;\nconst VIDEO_MESH_TIMEOUT = 1000;\n\n/**\n * @class Reachability\n * @export\n */\nexport default class Reachability {\n /**\n * Creates an instance of Reachability.\n * @param {object} webex\n * @memberof Reachability\n */\n constructor(webex) {\n this.webex = webex;\n\n /**\n * internal request object for the server\n * @instance\n * @type {Array}\n * @private\n * @memberof Reachability\n */\n this.reachabilityRequest = new ReachabilityRequest(this.webex);\n\n /**\n * internal object of clusters latency results\n * @instance\n * @type {object}\n * @private\n * @memberof Reachability\n */\n this.clusterLatencyResults = {};\n }\n\n\n /**\n * fetches reachability data\n * @returns {Object} reachability data\n * @public\n * @async\n * @memberof Reachability\n */\n async gatherReachability() {\n this.setup();\n\n // Remove stored reachability results to ensure no stale data\n if (window?.localStorage?.removeItem) {\n window.localStorage.removeItem(REACHABILITY.localStorage);\n }\n else {\n LoggerProxy.logger.error('Reachability:index#gatherReachability --> Error in accessing LocalStorage.');\n\n return {};\n }\n\n // Fetch clusters and measure latency\n try {\n const clusters = await this.reachabilityRequest.getClusters();\n\n // Perform Reachability Check\n const results = await this.performReachabilityCheck(clusters);\n\n window.localStorage.setItem(REACHABILITY.localStorage, JSON.stringify(results));\n\n LoggerProxy.logger.log('Reachability:index#gatherReachability --> Reachability checks completed');\n\n return results;\n }\n catch (getClusterError) {\n LoggerProxy.logger.error(`Reachability:index#gatherReachability --> Error in calling getClusters(): ${getClusterError}`);\n\n return {};\n }\n }\n\n /**\n * fetches reachability data and checks for cluster reachability\n * @returns {boolean}\n * @public\n * @memberof Reachability\n */\n isAnyClusterReachable() {\n let reachable = false;\n const reachabilityData = window.localStorage.getItem(REACHABILITY.localStorage);\n\n if (reachabilityData) {\n try {\n const reachabilityResults = JSON.parse(reachabilityData);\n\n reachable = Object.values(reachabilityResults).some((result) => result.udp?.reachable === 'true' || result.tcp?.reachable === 'true');\n }\n catch (e) {\n LoggerProxy.logger.error(`Roap:request#attachReachabilityData --> Error in parsing reachability data: ${e}`);\n }\n }\n\n return reachable;\n }\n\n\n /**\n * Generate peerConnection config settings\n * @param {object} cluster\n * @returns {object} peerConnectionConfig\n * @private\n * @memberof Reachability\n */\n buildPeerConnectionConfig(cluster) {\n const iceServers = _.uniq([\n ...cluster.udp,\n ...cluster.tcp\n ]).map((url) => ({\n username: '',\n credential: '',\n urls: [url]\n }));\n\n return {\n iceServers: [\n ...iceServers\n ],\n iceCandidatePoolSize: '0',\n iceTransportPolicy: 'all'\n };\n }\n\n\n /**\n * Creates an RTCPeerConnection\n * @param {object} cluster\n * @returns {RTCPeerConnection} peerConnection\n * @private\n * @memberof Reachability\n */\n createPeerConnection(cluster) {\n const {key, config} = cluster;\n\n try {\n const peerConnection = new window.RTCPeerConnection(config);\n\n peerConnection.key = key;\n\n return peerConnection;\n }\n catch (peerConnectionError) {\n LoggerProxy.logger.log(`Reachability:index#createPeerConnection --> Error creating peerConnection: ${peerConnectionError}`);\n\n return null;\n }\n }\n\n\n /**\n * Gets total elapsed time\n * @param {RTCPeerConnection} peerConnection\n * @returns {Number} Milliseconds\n * @private\n * @memberof Reachability\n */\n getElapsedTime(peerConnection) {\n const startTime = peerConnection.begin;\n\n delete peerConnection.begin;\n\n return Date.now() - startTime;\n }\n\n\n /**\n * creates offer and generates localSDP\n * @param {object} clusterList cluster List\n * @returns {Promise} Reachability latency results\n * @private\n * @memberof Reachability\n */\n getLocalSDPForClusters(clusterList) {\n let clusters = [...Object.keys(clusterList)];\n\n clusters = clusters.map(async (key) => {\n const cluster = clusterList[key];\n const config = this.buildPeerConnectionConfig(cluster);\n const peerConnection = this.createPeerConnection({key, config});\n const description = await peerConnection.createOffer({offerToReceiveAudio: true});\n\n peerConnection.begin = Date.now();\n peerConnection.setLocalDescription(description);\n\n return this.iceGatheringState(peerConnection, cluster.isVideoMesh ? VIDEO_MESH_TIMEOUT : DEFAULT_TIMEOUT)\n .catch((iceGatheringStateError) => {\n LoggerProxy.logger.log(`Reachability:index#getLocalSDPForClusters --> Error in getLocalSDP : ${iceGatheringStateError}`);\n });\n });\n\n return Promise.all(clusters)\n .then(this.parseIceResultsToReachabilityResults)\n .then((reachabilityLatencyResults) => {\n this.logUnreachableClusters();\n\n // return results\n return reachabilityLatencyResults;\n });\n }\n\n\n /**\n * Get list of all unreachable clusters\n * @returns {array} Unreachable clusters\n * @private\n * @memberof Reachability\n */\n getUnreachablClusters() {\n const unreachableList = [];\n const clusters = this.clusterLatencyResults;\n\n Object.keys(clusters).forEach((key) => {\n const cluster = clusters[key];\n\n if (cluster.unreachable && !cluster.reachable) {\n unreachableList.push(key);\n }\n });\n\n return unreachableList;\n }\n\n\n /**\n * Attach an event handler for the icegatheringstatechange\n * event and measure latency.\n * @param {RTCPeerConnection} peerConnection\n * @returns {undefined}\n * @private\n * @memberof Reachability\n */\n handleIceGatheringStateChange(peerConnection) {\n peerConnection.onicegatheringstatechange = () => {\n const {COMPLETE} = ICE_GATHERING_STATE;\n\n if (peerConnection.iceConnectionState === COMPLETE) {\n const elapsed = this.getElapsedTime(peerConnection);\n\n LoggerProxy.logger.log(`Reachability:index#onIceGatheringStateChange --> Successfully pinged ${peerConnection.key}:`, elapsed);\n this.setLatencyAndClose(peerConnection, elapsed);\n }\n };\n }\n\n\n /**\n * Attach an event handler for the icecandidate\n * event and measure latency.\n * @param {RTCPeerConnection} peerConnection\n * @returns {undefined}\n * @private\n * @memberof Reachability\n */\n handleOnIceCandidate(peerConnection) {\n peerConnection.onicecandidate = (e) => {\n const SERVER_REFLEXIVE = 'srflx';\n\n if (e.candidate && String(e.candidate.type).toLowerCase() === SERVER_REFLEXIVE) {\n const elapsed = this.getElapsedTime(peerConnection);\n\n LoggerProxy.logger.log(`Reachability:index#onIceCandidate --> Successfully pinged ${peerConnection.key}:`, elapsed);\n this.setLatencyAndClose(peerConnection, elapsed);\n }\n };\n }\n\n /**\n * An event handler on an RTCPeerConnection when the state of the ICE\n * candidate gathering process changes. Used to measure connection\n * speed.\n * @private\n * @param {RTCPeerConnection} peerConnection\n * @param {number} timeout\n * @returns {Promise}\n */\n iceGatheringState(peerConnection, timeout) {\n const ELAPSED = 'elapsed';\n\n return new Promise((resolve) => {\n const peerConnectionProxy = new window.Proxy(peerConnection, {\n get(target, property) {\n const targetMember = target[property];\n\n if (typeof (targetMember) === 'function') {\n return targetMember.bind(target);\n }\n\n return targetMember;\n },\n set: (target, property, value) => {\n // only intercept elapsed property\n if (property === ELAPSED) {\n resolve({clusterId: peerConnection.key, elapsed: value});\n\n return true;\n }\n\n // pass thru\n return window.Reflect.set(target, property, value);\n }\n });\n\n // Using peerConnection proxy so handle functions below\n // won't be coupled to our promise implementation\n this.handleIceGatheringStateChange(peerConnectionProxy);\n this.handleOnIceCandidate(peerConnectionProxy);\n\n // Set maximum timeout\n window.setTimeout(() => {\n const {CLOSED} = CONNECTION_STATE;\n\n // Close any open peerConnections\n if (peerConnectionProxy.connectionState !== CLOSED) {\n this.setLatencyAndClose(peerConnectionProxy, null);\n }\n }, timeout);\n });\n }\n\n\n /**\n * Make a log of unreachable clusters.\n * @returns {undefined}\n * @private\n * @memberof Reachability\n */\n logUnreachableClusters() {\n const list = this.getUnreachablClusters();\n\n list.forEach((cluster) => {\n LoggerProxy.logger.log(`Reachability:index#logUnreachableClusters --> No ice candidate for ${cluster}.`);\n });\n }\n\n\n /**\n * Calculates time to establish connection\n * @param {array} iceResults iceResults\n * @returns {object} reachabilityMap\n * @private\n * @memberof Reachability\n */\n parseIceResultsToReachabilityResults(iceResults) {\n const reachabilityMap = {};\n\n iceResults.forEach(({clusterId, elapsed}) => {\n let latencyResult;\n\n if (elapsed === null) {\n latencyResult = {reachable: 'false'};\n }\n else {\n latencyResult = {\n reachable: 'true',\n latencyInMilliseconds: (elapsed).toString()\n };\n }\n\n reachabilityMap[clusterId] = {\n udp: latencyResult,\n tcp: latencyResult\n };\n });\n\n return reachabilityMap;\n }\n\n\n /**\n * fetches reachability data\n * @param {object} clusterList\n * @returns {Promise<localSDPData>} reachability check results\n * @private\n * @memberof Reachability\n */\n performReachabilityCheck(clusterList) {\n if (!clusterList || !Object.keys(clusterList).length) {\n return Promise.resolve({});\n }\n\n return new Promise((resolve) => {\n this.getLocalSDPForClusters(clusterList)\n .then((localSDPData) => {\n if (!localSDPData || !Object.keys(localSDPData).length) {\n // TODO: handle the error condition properly and try retry\n LoggerProxy.logger.log('Reachability:index#performReachabilityCheck --> Local SDP is empty or has missing elements..returning');\n resolve({});\n }\n else {\n resolve(localSDPData);\n }\n })\n .catch((error) => {\n LoggerProxy.logger.error(`Reachability:index#performReachabilityCheck --> Error in getLocalSDPForClusters: ${error}`);\n resolve({});\n });\n });\n }\n\n\n /**\n * Records latency and closes the peerConnection\n * @param {RTCPeerConnection} peerConnection\n * @param {number} elapsed Latency in milliseconds\n * @returns {undefined}\n * @private\n * @memberof Reachability\n */\n setLatencyAndClose(peerConnection, elapsed) {\n const REACHABLE = 'reachable';\n const UNREACHABLE = 'unreachable';\n const {CLOSED} = CONNECTION_STATE;\n const {key} = peerConnection;\n const resultKey = elapsed === null ? UNREACHABLE : REACHABLE;\n const intialState = {[REACHABLE]: 0, [UNREACHABLE]: 0};\n\n if (peerConnection.connectionState === CLOSED) {\n LoggerProxy.logger.log(`Reachability:index#setLatencyAndClose --> Attempting to set latency of ${elapsed} on closed peerConnection.`);\n\n return;\n }\n\n this.clusterLatencyResults[key] = this.clusterLatencyResults[key] || intialState;\n this.clusterLatencyResults[key][resultKey] += 1;\n\n // Set to null in case this fired from\n // an event other than onIceCandidate\n peerConnection.onicecandidate = null;\n peerConnection.close();\n peerConnection.elapsed = elapsed;\n }\n\n\n /**\n * utility function\n * @returns {undefined}\n * @private\n * @memberof Reachability\n */\n setup() {\n this.clusterLatencyResults = {};\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["DEFAULT_TIMEOUT","VIDEO_MESH_TIMEOUT","Reachability","webex","reachabilityRequest","ReachabilityRequest","clusterLatencyResults","setup","window","localStorage","removeItem","REACHABILITY","LoggerProxy","logger","error","getClusters","clusters","performReachabilityCheck","results","setItem","log","reachable","reachabilityData","getItem","reachabilityResults","JSON","parse","some","result","udp","tcp","e","cluster","iceServers","map","url","username","credential","urls","iceCandidatePoolSize","iceTransportPolicy","key","config","peerConnection","RTCPeerConnection","peerConnectionError","startTime","begin","clusterList","buildPeerConnectionConfig","createPeerConnection","createOffer","offerToReceiveAudio","description","setLocalDescription","iceGatheringState","isVideoMesh","catch","iceGatheringStateError","all","then","parseIceResultsToReachabilityResults","reachabilityLatencyResults","logUnreachableClusters","unreachableList","forEach","unreachable","push","onicegatheringstatechange","COMPLETE","ICE_GATHERING_STATE","iceConnectionState","elapsed","getElapsedTime","setLatencyAndClose","onicecandidate","SERVER_REFLEXIVE","candidate","String","type","toLowerCase","timeout","ELAPSED","resolve","peerConnectionProxy","Proxy","get","target","property","targetMember","bind","set","value","clusterId","Reflect","handleIceGatheringStateChange","handleOnIceCandidate","setTimeout","CLOSED","CONNECTION_STATE","connectionState","list","getUnreachablClusters","iceResults","reachabilityMap","latencyResult","latencyInMilliseconds","toString","length","getLocalSDPForClusters","localSDPData","REACHABLE","UNREACHABLE","resultKey","intialState","close"],"sources":["index.ts"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\n/* eslint-disable class-methods-use-this */\n/* globals window */\nimport _ from 'lodash';\n\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport {\n ICE_GATHERING_STATE,\n CONNECTION_STATE,\n REACHABILITY\n} from '../constants';\n\nimport ReachabilityRequest from './request';\n\nconst DEFAULT_TIMEOUT = 3000;\nconst VIDEO_MESH_TIMEOUT = 1000;\n\n/**\n * @class Reachability\n * @export\n */\nexport default class Reachability {\n webex: object;\n reachabilityRequest: any;\n clusterLatencyResults: any;\n\n /**\n * Creates an instance of Reachability.\n * @param {object} webex\n * @memberof Reachability\n */\n constructor(webex: object) {\n this.webex = webex;\n\n /**\n * internal request object for the server\n * @instance\n * @type {Array}\n * @private\n * @memberof Reachability\n */\n this.reachabilityRequest = new ReachabilityRequest(this.webex);\n\n /**\n * internal object of clusters latency results\n * @instance\n * @type {object}\n * @private\n * @memberof Reachability\n */\n this.clusterLatencyResults = {};\n }\n\n\n /**\n * fetches reachability data\n * @returns {Object} reachability data\n * @public\n * @async\n * @memberof Reachability\n */\n public async gatherReachability() {\n this.setup();\n\n // Remove stored reachability results to ensure no stale data\n if (window?.localStorage?.removeItem) {\n window.localStorage.removeItem(REACHABILITY.localStorage);\n }\n else {\n LoggerProxy.logger.error('Reachability:index#gatherReachability --> Error in accessing LocalStorage.');\n\n return {};\n }\n\n // Fetch clusters and measure latency\n try {\n const clusters = await this.reachabilityRequest.getClusters();\n\n // Perform Reachability Check\n const results = await this.performReachabilityCheck(clusters);\n\n window.localStorage.setItem(REACHABILITY.localStorage, JSON.stringify(results));\n\n LoggerProxy.logger.log('Reachability:index#gatherReachability --> Reachability checks completed');\n\n return results;\n }\n catch (getClusterError) {\n LoggerProxy.logger.error(`Reachability:index#gatherReachability --> Error in calling getClusters(): ${getClusterError}`);\n\n return {};\n }\n }\n\n /**\n * fetches reachability data and checks for cluster reachability\n * @returns {boolean}\n * @public\n * @memberof Reachability\n */\n isAnyClusterReachable() {\n let reachable = false;\n const reachabilityData = window.localStorage.getItem(REACHABILITY.localStorage);\n\n if (reachabilityData) {\n try {\n const reachabilityResults = JSON.parse(reachabilityData);\n\n reachable = Object.values(reachabilityResults).some((result: any) => result.udp?.reachable === 'true' || result.tcp?.reachable === 'true');\n }\n catch (e) {\n LoggerProxy.logger.error(`Roap:request#attachReachabilityData --> Error in parsing reachability data: ${e}`);\n }\n }\n\n return reachable;\n }\n\n\n /**\n * Generate peerConnection config settings\n * @param {object} cluster\n * @returns {object} peerConnectionConfig\n * @private\n * @memberof Reachability\n */\n private buildPeerConnectionConfig(cluster: any) {\n const iceServers = _.uniq([\n ...cluster.udp,\n ...cluster.tcp\n ]).map((url) => ({\n username: '',\n credential: '',\n urls: [url]\n }));\n\n return {\n iceServers: [\n ...iceServers\n ],\n iceCandidatePoolSize: '0',\n iceTransportPolicy: 'all'\n };\n }\n\n\n /**\n * Creates an RTCPeerConnection\n * @param {object} cluster\n * @returns {RTCPeerConnection} peerConnection\n * @private\n * @memberof Reachability\n */\n private createPeerConnection(cluster: any) {\n const {key, config} = cluster;\n\n try {\n const peerConnection = new window.RTCPeerConnection(config);\n\n // @ts-ignore\n peerConnection.key = key;\n\n return peerConnection;\n }\n catch (peerConnectionError) {\n LoggerProxy.logger.log(`Reachability:index#createPeerConnection --> Error creating peerConnection: ${peerConnectionError}`);\n\n return null;\n }\n }\n\n\n /**\n * Gets total elapsed time\n * @param {RTCPeerConnection} peerConnection\n * @returns {Number} Milliseconds\n * @private\n * @memberof Reachability\n */\n private getElapsedTime(peerConnection: any) {\n const startTime = peerConnection.begin;\n\n delete peerConnection.begin;\n\n return Date.now() - startTime;\n }\n\n\n /**\n * creates offer and generates localSDP\n * @param {object} clusterList cluster List\n * @returns {Promise} Reachability latency results\n * @private\n * @memberof Reachability\n */\n private getLocalSDPForClusters(clusterList: object) {\n let clusters: any[] = [...Object.keys(clusterList)];\n\n clusters = clusters.map(async (key) => {\n const cluster = clusterList[key];\n const config = this.buildPeerConnectionConfig(cluster);\n const peerConnection = this.createPeerConnection({key, config});\n const description = await peerConnection.createOffer({offerToReceiveAudio: true});\n\n // @ts-ignore\n peerConnection.begin = Date.now();\n peerConnection.setLocalDescription(description);\n\n return this.iceGatheringState(peerConnection, cluster.isVideoMesh ? VIDEO_MESH_TIMEOUT : DEFAULT_TIMEOUT)\n .catch((iceGatheringStateError) => {\n LoggerProxy.logger.log(`Reachability:index#getLocalSDPForClusters --> Error in getLocalSDP : ${iceGatheringStateError}`);\n });\n });\n\n return Promise.all(clusters)\n .then(this.parseIceResultsToReachabilityResults)\n .then((reachabilityLatencyResults) => {\n this.logUnreachableClusters();\n\n // return results\n return reachabilityLatencyResults;\n });\n }\n\n\n /**\n * Get list of all unreachable clusters\n * @returns {array} Unreachable clusters\n * @private\n * @memberof Reachability\n */\n private getUnreachablClusters() {\n const unreachableList = [];\n const clusters = this.clusterLatencyResults;\n\n Object.keys(clusters).forEach((key) => {\n const cluster = clusters[key];\n\n if (cluster.unreachable && !cluster.reachable) {\n unreachableList.push(key);\n }\n });\n\n return unreachableList;\n }\n\n\n /**\n * Attach an event handler for the icegatheringstatechange\n * event and measure latency.\n * @param {RTCPeerConnection} peerConnection\n * @returns {undefined}\n * @private\n * @memberof Reachability\n */\n private handleIceGatheringStateChange(peerConnection: RTCPeerConnection) {\n peerConnection.onicegatheringstatechange = () => {\n const {COMPLETE} = ICE_GATHERING_STATE;\n\n if (peerConnection.iceConnectionState === COMPLETE) {\n const elapsed = this.getElapsedTime(peerConnection);\n\n // @ts-ignore\n LoggerProxy.logger.log(`Reachability:index#onIceGatheringStateChange --> Successfully pinged ${peerConnection.key}:`, elapsed);\n this.setLatencyAndClose(peerConnection, elapsed);\n }\n };\n }\n\n\n /**\n * Attach an event handler for the icecandidate\n * event and measure latency.\n * @param {RTCPeerConnection} peerConnection\n * @returns {undefined}\n * @private\n * @memberof Reachability\n */\n private handleOnIceCandidate(peerConnection: RTCPeerConnection) {\n peerConnection.onicecandidate = (e) => {\n const SERVER_REFLEXIVE = 'srflx';\n\n if (e.candidate && String(e.candidate.type).toLowerCase() === SERVER_REFLEXIVE) {\n const elapsed = this.getElapsedTime(peerConnection);\n\n // @ts-ignore\n LoggerProxy.logger.log(`Reachability:index#onIceCandidate --> Successfully pinged ${peerConnection.key}:`, elapsed);\n this.setLatencyAndClose(peerConnection, elapsed);\n }\n };\n }\n\n /**\n * An event handler on an RTCPeerConnection when the state of the ICE\n * candidate gathering process changes. Used to measure connection\n * speed.\n * @private\n * @param {RTCPeerConnection} peerConnection\n * @param {number} timeout\n * @returns {Promise}\n */\n private iceGatheringState(peerConnection: RTCPeerConnection, timeout: number) {\n const ELAPSED = 'elapsed';\n\n return new Promise((resolve) => {\n const peerConnectionProxy = new window.Proxy(peerConnection, {\n get(target, property) {\n const targetMember = target[property];\n\n if (typeof (targetMember) === 'function') {\n return targetMember.bind(target);\n }\n\n return targetMember;\n },\n set: (target, property, value) => {\n // only intercept elapsed property\n if (property === ELAPSED) {\n // @ts-ignore\n resolve({clusterId: peerConnection.key, elapsed: value});\n\n return true;\n }\n\n // pass thru\n return window.Reflect.set(target, property, value);\n }\n });\n\n // Using peerConnection proxy so handle functions below\n // won't be coupled to our promise implementation\n this.handleIceGatheringStateChange(peerConnectionProxy);\n this.handleOnIceCandidate(peerConnectionProxy);\n\n // Set maximum timeout\n window.setTimeout(() => {\n const {CLOSED} = CONNECTION_STATE;\n\n // Close any open peerConnections\n if (peerConnectionProxy.connectionState !== CLOSED) {\n this.setLatencyAndClose(peerConnectionProxy, null);\n }\n }, timeout);\n });\n }\n\n\n /**\n * Make a log of unreachable clusters.\n * @returns {undefined}\n * @private\n * @memberof Reachability\n */\n private logUnreachableClusters() {\n const list = this.getUnreachablClusters();\n\n list.forEach((cluster) => {\n LoggerProxy.logger.log(`Reachability:index#logUnreachableClusters --> No ice candidate for ${cluster}.`);\n });\n }\n\n\n /**\n * Calculates time to establish connection\n * @param {array} iceResults iceResults\n * @returns {object} reachabilityMap\n * @private\n * @memberof Reachability\n */\n private parseIceResultsToReachabilityResults(iceResults: Array<any>) {\n const reachabilityMap = {};\n\n iceResults.forEach(({clusterId, elapsed}) => {\n let latencyResult;\n\n if (elapsed === null) {\n latencyResult = {reachable: 'false'};\n }\n else {\n latencyResult = {\n reachable: 'true',\n latencyInMilliseconds: (elapsed).toString()\n };\n }\n\n reachabilityMap[clusterId] = {\n udp: latencyResult,\n tcp: latencyResult\n };\n });\n\n return reachabilityMap;\n }\n\n\n /**\n * fetches reachability data\n * @param {object} clusterList\n * @returns {Promise<localSDPData>} reachability check results\n * @private\n * @memberof Reachability\n */\n private performReachabilityCheck(clusterList: object) {\n if (!clusterList || !Object.keys(clusterList).length) {\n return Promise.resolve({});\n }\n\n return new Promise((resolve) => {\n this.getLocalSDPForClusters(clusterList)\n .then((localSDPData) => {\n if (!localSDPData || !Object.keys(localSDPData).length) {\n // TODO: handle the error condition properly and try retry\n LoggerProxy.logger.log('Reachability:index#performReachabilityCheck --> Local SDP is empty or has missing elements..returning');\n resolve({});\n }\n else {\n resolve(localSDPData);\n }\n })\n .catch((error) => {\n LoggerProxy.logger.error(`Reachability:index#performReachabilityCheck --> Error in getLocalSDPForClusters: ${error}`);\n resolve({});\n });\n });\n }\n\n\n /**\n * Records latency and closes the peerConnection\n * @param {RTCPeerConnection} peerConnection\n * @param {number} elapsed Latency in milliseconds\n * @returns {undefined}\n * @private\n * @memberof Reachability\n */\n private setLatencyAndClose(peerConnection: RTCPeerConnection, elapsed: number) {\n const REACHABLE = 'reachable';\n const UNREACHABLE = 'unreachable';\n const {CLOSED} = CONNECTION_STATE;\n // @ts-ignore\n const {key} = peerConnection;\n const resultKey = elapsed === null ? UNREACHABLE : REACHABLE;\n const intialState = {[REACHABLE]: 0, [UNREACHABLE]: 0};\n\n if (peerConnection.connectionState === CLOSED) {\n LoggerProxy.logger.log(`Reachability:index#setLatencyAndClose --> Attempting to set latency of ${elapsed} on closed peerConnection.`);\n\n return;\n }\n\n this.clusterLatencyResults[key] = this.clusterLatencyResults[key] || intialState;\n this.clusterLatencyResults[key][resultKey] += 1;\n\n // Set to null in case this fired from\n // an event other than onIceCandidate\n peerConnection.onicecandidate = null;\n peerConnection.close();\n // @ts-ignore\n peerConnection.elapsed = elapsed;\n }\n\n\n /**\n * utility function\n * @returns {undefined}\n * @private\n * @memberof Reachability\n */\n private setup() {\n this.clusterLatencyResults = {};\n }\n}\n"],"mappings":"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"}
|
|
@@ -37,6 +37,7 @@ function ReachabilityRequest(webex) {
|
|
|
37
37
|
var _this = this;
|
|
38
38
|
|
|
39
39
|
(0, _classCallCheck2.default)(this, ReachabilityRequest);
|
|
40
|
+
(0, _defineProperty2.default)(this, "webex", void 0);
|
|
40
41
|
(0, _defineProperty2.default)(this, "getClusters", function () {
|
|
41
42
|
return _this.webex.request({
|
|
42
43
|
method: _constants.HTTP_VERBS.GET,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["ReachabilityRequest","webex","request","method","HTTP_VERBS","GET","shouldRefreshAccessToken","api","API","CALLIOPEDISCOVERY","resource","RESOURCE","CLUSTERS","then","res","clusters","body","forEach","key","isVideoMesh","clusterClasses","hybridMedia","includes","LoggerProxy","logger","log","localSDPList","POST","REACHABILITY","offers"],"sources":["request.ts"],"sourcesContent":["import LoggerProxy from '../common/logs/logger-proxy';\nimport {\n HTTP_VERBS,\n RESOURCE,\n API\n} from '../constants';\n\nexport interface ClusterNode {\n isVideoMesh: boolean;\n udp: Array<string>;\n tcp: Array<string>;\n xtls: Array<string>;\n}\n\nexport type ClusterList = {\n [key:string]: ClusterNode;\n}\n\n/**\n * @class ReachabilityRequest\n */\nclass ReachabilityRequest {\n /**\n * Creates an instance of ReachabilityRequest.\n * @param {object} webex\n * @memberof ReachabilityRequest\n */\n constructor(webex) {\n this.webex = webex;\n }\n\n /**\n * gets the cluster information\n *\n * @param {boolean} includeVideoMesh whether to include the video mesh clusters in the result or not\n * @returns {Promise}\n */\n getClusters = (): Promise<ClusterList> => this.webex.request({\n method: HTTP_VERBS.GET,\n shouldRefreshAccessToken: false,\n api: API.CALLIOPEDISCOVERY,\n resource: RESOURCE.CLUSTERS\n })\n .then((res) => {\n const {clusters} = res.body;\n\n Object.keys(clusters).forEach((key) => {\n clusters[key].isVideoMesh = res.body.clusterClasses?.hybridMedia?.includes(key);\n });\n\n LoggerProxy.logger.log(`Reachability:request#getClusters --> get clusters successful:${JSON.stringify(clusters)}`);\n\n return clusters;\n });\n\n /**\n * gets remote SDP For Clusters\n * @param {Object} localSDPList localSDPs for the cluster\n * @returns {Object}\n */\n remoteSDPForClusters = (localSDPList) => this.webex.request({\n method: HTTP_VERBS.POST,\n shouldRefreshAccessToken: false,\n api: API.CALLIOPEDISCOVERY,\n resource: RESOURCE.REACHABILITY,\n body: {offers: localSDPList}\n })\n .then((res) => {\n LoggerProxy.logger.log('Reachability:request#remoteSDPForClusters --> Remote SDPs got succcessfully');\n\n return res.body;\n });\n}\n\nexport default ReachabilityRequest;\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AAiBA;AACA;AACA;IACMA,mB;
|
|
1
|
+
{"version":3,"names":["ReachabilityRequest","webex","request","method","HTTP_VERBS","GET","shouldRefreshAccessToken","api","API","CALLIOPEDISCOVERY","resource","RESOURCE","CLUSTERS","then","res","clusters","body","forEach","key","isVideoMesh","clusterClasses","hybridMedia","includes","LoggerProxy","logger","log","localSDPList","POST","REACHABILITY","offers"],"sources":["request.ts"],"sourcesContent":["import LoggerProxy from '../common/logs/logger-proxy';\nimport {\n HTTP_VERBS,\n RESOURCE,\n API\n} from '../constants';\n\nexport interface ClusterNode {\n isVideoMesh: boolean;\n udp: Array<string>;\n tcp: Array<string>;\n xtls: Array<string>;\n}\n\nexport type ClusterList = {\n [key:string]: ClusterNode;\n}\n\n/**\n * @class ReachabilityRequest\n */\nclass ReachabilityRequest {\n webex: any;\n\n /**\n * Creates an instance of ReachabilityRequest.\n * @param {object} webex\n * @memberof ReachabilityRequest\n */\n constructor(webex: object) {\n this.webex = webex;\n }\n\n /**\n * gets the cluster information\n *\n * @param {boolean} includeVideoMesh whether to include the video mesh clusters in the result or not\n * @returns {Promise}\n */\n getClusters = (): Promise<ClusterList> => this.webex.request({\n method: HTTP_VERBS.GET,\n shouldRefreshAccessToken: false,\n api: API.CALLIOPEDISCOVERY,\n resource: RESOURCE.CLUSTERS\n })\n .then((res) => {\n const {clusters} = res.body;\n\n Object.keys(clusters).forEach((key) => {\n clusters[key].isVideoMesh = res.body.clusterClasses?.hybridMedia?.includes(key);\n });\n\n LoggerProxy.logger.log(`Reachability:request#getClusters --> get clusters successful:${JSON.stringify(clusters)}`);\n\n return clusters;\n });\n\n /**\n * gets remote SDP For Clusters\n * @param {Object} localSDPList localSDPs for the cluster\n * @returns {Object}\n */\n remoteSDPForClusters = (localSDPList: object) => this.webex.request({\n method: HTTP_VERBS.POST,\n shouldRefreshAccessToken: false,\n api: API.CALLIOPEDISCOVERY,\n resource: RESOURCE.REACHABILITY,\n body: {offers: localSDPList}\n })\n .then((res) => {\n LoggerProxy.logger.log('Reachability:request#remoteSDPForClusters --> Remote SDPs got succcessfully');\n\n return res.body;\n });\n}\n\nexport default ReachabilityRequest;\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AAiBA;AACA;AACA;IACMA,mB;AAGJ;AACF;AACA;AACA;AACA;AACE,6BAAYC,KAAZ,EAA2B;EAAA;;EAAA;EAAA;EAAA,mDAUb;IAAA,OAA4B,KAAI,CAACA,KAAL,CAAWC,OAAX,CAAmB;MAC3DC,MAAM,EAAEC,qBAAA,CAAWC,GADwC;MAE3DC,wBAAwB,EAAE,KAFiC;MAG3DC,GAAG,EAAEC,cAAA,CAAIC,iBAHkD;MAI3DC,QAAQ,EAAEC,mBAAA,CAASC;IAJwC,CAAnB,EAMvCC,IANuC,CAMlC,UAACC,GAAD,EAAS;MACb,IAAOC,QAAP,GAAmBD,GAAG,CAACE,IAAvB,CAAOD,QAAP;MAEA,mBAAYA,QAAZ,EAAsBE,OAAtB,CAA8B,UAACC,GAAD,EAAS;QAAA;;QACrCH,QAAQ,CAACG,GAAD,CAAR,CAAcC,WAAd,4BAA4BL,GAAG,CAACE,IAAJ,CAASI,cAArC,oFAA4B,sBAAyBC,WAArD,2DAA4B,uBAAsCC,QAAtC,CAA+CJ,GAA/C,CAA5B;MACD,CAFD;;MAIAK,oBAAA,CAAYC,MAAZ,CAAmBC,GAAnB,wEAAuF,wBAAeV,QAAf,CAAvF;;MAEA,OAAOA,QAAP;IACD,CAhBuC,CAA5B;EAAA,CAVa;EAAA,4DAiCJ,UAACW,YAAD;IAAA,OAA0B,KAAI,CAACzB,KAAL,CAAWC,OAAX,CAAmB;MAClEC,MAAM,EAAEC,qBAAA,CAAWuB,IAD+C;MAElErB,wBAAwB,EAAE,KAFwC;MAGlEC,GAAG,EAAEC,cAAA,CAAIC,iBAHyD;MAIlEC,QAAQ,EAAEC,mBAAA,CAASiB,YAJ+C;MAKlEZ,IAAI,EAAE;QAACa,MAAM,EAAEH;MAAT;IAL4D,CAAnB,EAO9Cb,IAP8C,CAOzC,UAACC,GAAD,EAAS;MACbS,oBAAA,CAAYC,MAAZ,CAAmBC,GAAnB,CAAuB,6EAAvB;;MAEA,OAAOX,GAAG,CAACE,IAAX;IACD,CAX8C,CAA1B;EAAA,CAjCI;EACzB,KAAKf,KAAL,GAAaA,KAAb;AACD;AAED;AACF;AACA;AACA;AACA;AACA;;eAsCeD,mB"}
|