@webex/plugin-meetings 1.146.1 → 1.147.0
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/config.js +1 -0
- package/dist/config.js.map +1 -1
- package/dist/media/index.js +16 -8
- package/dist/media/index.js.map +1 -1
- package/dist/meeting/index.js +4 -2
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/util.js +2 -1
- package/dist/meeting/util.js.map +1 -1
- package/dist/peer-connection-manager/index.js +8 -7
- package/dist/peer-connection-manager/index.js.map +1 -1
- package/dist/reconnection-manager/index.js +2 -1
- package/dist/reconnection-manager/index.js.map +1 -1
- package/package.json +5 -5
- package/src/config.js +1 -0
- package/src/media/index.js +58 -10
- package/src/meeting/index.js +4 -2
- package/src/meeting/util.js +2 -1
- package/src/peer-connection-manager/index.js +13 -9
- package/src/reconnection-manager/index.js +2 -1
package/dist/meeting/util.js
CHANGED
|
@@ -347,7 +347,8 @@ MeetingUtil.updateTransceiver = function (options, meetingOptions) {
|
|
|
347
347
|
return _media.default.updateTransceiver({
|
|
348
348
|
meetingId: meetingOptions.meeting.id,
|
|
349
349
|
remoteQualityLevel: meetingOptions.mediaProperties.remoteQualityLevel,
|
|
350
|
-
enableRtx: meetingOptions.meeting.config.enableRtx
|
|
350
|
+
enableRtx: meetingOptions.meeting.config.enableRtx,
|
|
351
|
+
enableExtmap: meetingOptions.meeting.config.enableExtmap
|
|
351
352
|
}, peerConnection, transceiver, {
|
|
352
353
|
track: track,
|
|
353
354
|
type: type,
|
package/dist/meeting/util.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["util.js"],"names":["MeetingUtil","parseLocusJoin","response","parsed","locus","body","mediaConnections","locusUrl","url","locusId","split","pop","selfId","self","id","forEach","mediaConnection","mediaId","remoteUpdateAudioVideo","audioMuted","videoMuted","meeting","reject","ParameterError","localMedias","Media","generateLocalMedias","Metrics","postEvent","event","eventType","MEDIA_REQUEST","meetingRequest","remoteAudioVideoToggle","deviceUrl","correlationId","then","MEDIA_RESPONSE","hasOwner","info","owner","isOwnerSelf","isPinOrGuest","err","errorCode","INTENT_TO_JOIN","joinMeeting","options","LOCUS_JOIN_REQUEST","sipUri","meetingNumber","roapMessage","resourceId","moderator","pin","moveToResource","preferTranscoding","asResourceOccupant","res","LOCUS_JOIN_RESPONSE","data","trigger","LOCI_UPDATE","trackingId","headers","trackingid","cleanUp","statsAnalyzer","stopAnalyzer","closeLocalStream","closeLocalShare","closeRemoteTracks","closePeerConnections","unsetLocalVideoTrack","unsetLocalShareTrack","unsetRemoteTracks","unsetPeerConnections","cleanMQAInterval","reconnectionManager","roap","stop","roapSeq","leavePstn","dialInUrl","meetingState","FULL_STATE","INACTIVE","MeetingNotActiveError","locusInfo","onFullLocus","catch","LoggerProxy","logger","error","leaveMeeting","isUserInLeftState","UserNotJoinedError","defaultOptions","leaveOptions","resolve","moveMeeting","declineMeeting","reason","parsedLocus","state","_LEFT_","isUserInIdleState","_IDLE_","isUserInJoinedState","_JOINED_","isMediaEstablished","currentMediaStatus","audio","video","share","joinMeetingOptions","PIN_COLLECTED","setLocus","meetingInfo","PIN_PROMPT","IntentToJoinError","JoinMeetingError","updateTransceiver","meetingOptions","type","sendTrack","receiveTrack","track","transceiver","peerConnection","previousMediaDirection","undefined","meetingId","remoteQualityLevel","mediaProperties","enableRtx","config","sendRoapMediaRequest","sdp","e","sender","replaceTrack","validateOptions","sendVideo","sendAudio","sendShare","localStream","localShare","getTrack","videoTrack","audioTrack","stream","audioTracks","videoTracks","getAudioTracks","getVideoTracks","length","getModeratorFromLocusInfo","getPolicyFromLocusInfo","policy","canUserLock","joined","LOCK_CONTROL_LOCK","LOCK_STATUS_UNLOCKED","canUserUnlock","LOCK_CONTROL_UNLOCK","LOCK_STATUS_LOCKED","canUserRecord","RECORDING_CONTROL_START","canUserPause","RECORDING_CONTROL_PAUSE","canUserResume","RECORDING_CONTROL_RESUME","canUserStop","RECORDING_CONTROL_STOP","startRecording","request","recordMeeting","recording","paused","PermissionError","pauseRecording","resumeRecording","stopRecording","lockMeeting","actions","canLock","lock","unlockMeeting","canUnlock","startInternalStats","internalStats","useConfig","senders","correlate","history","onEvent","kind","stat","Trigger","file","function","EVENT_TRIGGERS","MEETING_MEDIA_LOCAL_STARTED","mediaType","AUDIO","SENDING_MEDIA_START","SENDING_MEDIA_STOP","onData","VIDEO","SHARE","SENDING_SHARE_START","SENDING_SHARE_STOP","receivers","MEETING_MEDIA_REMOTE_STARTED","RECEIVING_MEDIA_START","RECEIVING_MEDIA_STOP","StatsUtil","generateOptions","STATS","CONFIG","WebRTCStats","attrs","handleAudioLogging","LOG_HEADER","settings","getSettings","deviceId","log","handleVideoLogging","handleDeviceLogging","devices","device"],"mappings":"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","sourcesContent":["import {isEmpty} from 'lodash';\n\nimport {MeetingNotActiveError, UserNotJoinedError} from '../common/errors/webex-errors';\nimport StatsUtil from '../stats/util';\nimport Metrics from '../metrics';\nimport {eventType, trigger, mediaType} from '../metrics/config';\nimport Media from '../media';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport WebRTCStats from '../stats/index';\nimport {INTENT_TO_JOIN,\n _LEFT_,\n _IDLE_,\n _JOINED_,\n STATS,\n EVENT_TRIGGERS\n , FULL_STATE} from '../constants';\nimport Trigger from '../common/events/trigger-proxy';\nimport IntentToJoinError from '../common/errors/intent-to-join';\nimport JoinMeetingError from '../common/errors/join-meeting';\nimport ParameterError from '../common/errors/parameter';\nimport PermissionError from '../common/errors/permission';\n\n\nconst MeetingUtil = {};\n\nMeetingUtil.parseLocusJoin = (response) => {\n const parsed = {};\n\n // First todo: add check for existance\n parsed.locus = response.body.locus;\n parsed.mediaConnections = response.body.mediaConnections;\n parsed.locusUrl = parsed.locus.url;\n parsed.locusId = parsed.locus.url.split('/').pop();\n parsed.selfId = parsed.locus.self.id;\n\n // we need mediaId before making roap calls\n parsed.mediaConnections.forEach((mediaConnection) => {\n if (mediaConnection.mediaId) {\n parsed.mediaId = mediaConnection.mediaId;\n }\n });\n\n return parsed;\n};\n\nMeetingUtil.remoteUpdateAudioVideo = (audioMuted, videoMuted, meeting) => {\n if (!meeting) {\n return Promise.reject(new ParameterError('You need a meeting object.'));\n }\n const localMedias = Media.generateLocalMedias(meeting.mediaId, audioMuted, videoMuted);\n\n if (isEmpty(localMedias)) {\n return Promise.reject(new ParameterError('You need a media id on the meeting to change remote audio.'));\n }\n\n Metrics.postEvent({event: eventType.MEDIA_REQUEST, meeting});\n\n return meeting.meetingRequest.remoteAudioVideoToggle({\n locusUrl: meeting.locusUrl,\n selfId: meeting.selfId,\n localMedias,\n deviceUrl: meeting.deviceUrl,\n correlationId: meeting.correlationId\n }).then((response) => {\n Metrics.postEvent({event: eventType.MEDIA_RESPONSE, meeting});\n\n return response.body.locus;\n });\n};\n\nMeetingUtil.hasOwner = (info) => info && info.owner;\n\nMeetingUtil.isOwnerSelf = (owner, selfId) => owner === selfId;\n\nMeetingUtil.isPinOrGuest = (err) => {\n if (err && err.body && err.body.errorCode === INTENT_TO_JOIN) {\n return true;\n }\n\n return false;\n};\n\nMeetingUtil.joinMeeting = (meeting, options) => {\n if (!meeting) {\n return Promise.reject(new ParameterError('You need a meeting object.'));\n }\n\n Metrics.postEvent({event: eventType.LOCUS_JOIN_REQUEST, meeting});\n\n // eslint-disable-next-line no-warning-comments\n // TODO: check if the meeting is in JOINING state\n // if Joining state termintate the request as user might click multiple times\n return meeting.meetingRequest\n .joinMeeting({\n sipUri: meeting.sipUri,\n meetingNumber: meeting.meetingNumber,\n deviceUrl: meeting.deviceUrl,\n locusUrl: meeting.locusUrl,\n correlationId: meeting.correlationId,\n roapMessage: options.roapMessage,\n resourceId: options.resourceId || null,\n moderator: options.moderator,\n pin: options.pin,\n moveToResource: options.moveToResource,\n preferTranscoding: options.preferTranscoding,\n asResourceOccupant: options.asResourceOccupant\n })\n .then((res) => {\n Metrics.postEvent({\n event: eventType.LOCUS_JOIN_RESPONSE,\n meeting,\n data: {\n trigger: trigger.LOCI_UPDATE,\n locus: res.body.locus,\n mediaConnections: res.body.mediaConnections,\n trackingId: res.headers.trackingid\n }\n });\n\n return MeetingUtil.parseLocusJoin(res);\n });\n};\n\nMeetingUtil.cleanUp = (meeting) => {\n // make sure we send last metrics before we close the peerconnection\n if (meeting.statsAnalyzer) meeting.statsAnalyzer.stopAnalyzer();\n\n return meeting.closeLocalStream()\n .then(() => meeting.closeLocalShare())\n .then(() => meeting.closeRemoteTracks())\n .then(() => meeting.closePeerConnections())\n .then(() => {\n meeting.unsetLocalVideoTrack();\n meeting.unsetLocalShareTrack();\n meeting.unsetRemoteTracks();\n meeting.unsetPeerConnections();\n meeting.cleanMQAInterval();\n meeting.reconnectionManager.cleanUp();\n })\n .then(() => meeting.roap.stop(meeting.correlationId, meeting.roapSeq));\n};\n\nMeetingUtil.leavePstn = (meeting, dialInUrl) => {\n if (meeting.meetingState === FULL_STATE.INACTIVE) {\n return Promise.reject(new MeetingNotActiveError());\n }\n\n const options = {\n locusUrl: meeting.locusUrl,\n selfId: meeting.selfId,\n correlationId: meeting.correlationId,\n dialInUrl\n };\n\n return meeting.meetingRequest\n .leavePstn(options)\n .then((response) => {\n if (response?.body?.locus) {\n meeting.locusInfo.onFullLocus(response.body.locus);\n }\n })\n .catch((err) => {\n LoggerProxy.logger.error(\n `Meeting:util#leavePstn --> An error occured while trying to leave pstn with an id of ${\n meeting.id\n }, error: ${err}`\n );\n\n return Promise.reject(err);\n });\n};\n\n// by default will leave on meeting's resourceId\n// if you explicity want it not to leave on resource id, pass\n// {resourceId: null}\n// TODO: chris, you can modify this however you want\nMeetingUtil.leaveMeeting = (meeting, options = {}) => {\n if (meeting.meetingState === FULL_STATE.INACTIVE) {\n // TODO: clean up if the meeting is already inactive\n return Promise.reject(new MeetingNotActiveError());\n }\n\n if (MeetingUtil.isUserInLeftState(meeting.locusInfo)) {\n return Promise.reject(new UserNotJoinedError());\n }\n\n const defaultOptions = {\n locusUrl: meeting.locusUrl,\n selfId: meeting.selfId,\n correlationId: meeting.correlationId,\n resourceId: meeting.resourceId,\n deviceUrl: meeting.deviceUrl\n };\n\n const leaveOptions = {...defaultOptions, ...options};\n\n return meeting.meetingRequest\n .leaveMeeting(leaveOptions)\n .then((response) => {\n if (response && response.body && response.body.locus) { // && !options.moveMeeting) {\n meeting.locusInfo.onFullLocus(response.body.locus);\n }\n\n return Promise.resolve();\n })\n .then(() => {\n if (options.moveMeeting) {\n return Promise.resolve();\n }\n\n return MeetingUtil.cleanUp(meeting);\n })\n .catch((err) => {\n // TODO: If the meeting state comes as LEFT or INACTIVE as response then\n // 1) on leave clean up the meeting or simply do a sync on the meeting\n // 2) If the error says meeting is inactive then destroy the meeting object\n LoggerProxy.logger.error(\n `Meeting:util#leaveMeeting --> An error occured while trying to leave meeting with an id of ${\n meeting.id\n }, error: ${err}`\n );\n\n return Promise.reject(err);\n });\n};\nMeetingUtil.declineMeeting = (meeting, reason) =>\n meeting.meetingRequest.declineMeeting({\n locusUrl: meeting.locusUrl,\n deviceUrl: meeting.deviceUrl,\n reason\n });\n\nMeetingUtil.isUserInLeftState = (locusInfo) =>\n locusInfo.parsedLocus?.self?.state === _LEFT_;\n\nMeetingUtil.isUserInIdleState = (locusInfo) =>\n locusInfo.parsedLocus?.self?.state === _IDLE_;\n\nMeetingUtil.isUserInJoinedState = (locusInfo) =>\n locusInfo.parsedLocus?.self?.state === _JOINED_;\n\nMeetingUtil.isMediaEstablished = (currentMediaStatus) =>\n currentMediaStatus && (currentMediaStatus.audio || currentMediaStatus.video || currentMediaStatus.share);\n\n\nMeetingUtil.joinMeetingOptions = (meeting, options = {}) => {\n meeting.resourceId = meeting.resourceId || options.resourceId;\n\n if (options.pin) {\n Metrics.postEvent({\n event: eventType.PIN_COLLECTED,\n meeting\n });\n }\n\n // normal join meeting, scenario A, D\n return MeetingUtil.joinMeeting(meeting, options)\n .then((response) => {\n meeting.setLocus(response);\n\n return Promise.resolve(response);\n })\n .catch((err) => {\n // joining a claimed PMR that is not my own, scenario B\n if (MeetingUtil.isPinOrGuest(err)) {\n if (MeetingUtil.hasOwner(meeting.meetingInfo)) {\n return MeetingUtil.joinMeeting(meeting, options).then((response) => {\n meeting.setLocus(response);\n\n return Promise.resolve();\n });\n }\n\n Metrics.postEvent({\n event: eventType.PIN_PROMPT,\n meeting\n });\n\n // request host pin or non host for unclaimed PMR, start of Scenario C\n // see https://sqbu-github.cisco.com/WebExSquared/locus/wiki/Locus-Lobby-and--IVR-Feature\n return Promise.reject(new IntentToJoinError('Error Joining Meeting', err));\n }\n LoggerProxy.logger.error('Meeting:util#joinMeetingOptions --> Error joining the call, ', err);\n\n return Promise.reject(new JoinMeetingError(options, 'Error Joining Meeting', err));\n });\n};\n\nMeetingUtil.updateTransceiver = (options, meetingOptions) => {\n const {\n type,\n sendTrack,\n receiveTrack,\n track,\n transceiver,\n peerConnection,\n previousMediaDirection\n } = options;\n\n if ((sendTrack !== undefined && sendTrack !== previousMediaDirection.sendTrack) ||\n (receiveTrack !== undefined && receiveTrack !== previousMediaDirection.receiveTrack)) {\n return Media.updateTransceiver({\n meetingId: meetingOptions.meeting.id,\n remoteQualityLevel: meetingOptions.mediaProperties.remoteQualityLevel,\n enableRtx: meetingOptions.meeting.config.enableRtx\n }, peerConnection, transceiver,\n {\n track,\n type,\n receiveTrack,\n sendTrack\n })\n .then(() => meetingOptions.meeting.roap\n .sendRoapMediaRequest({\n sdp: meetingOptions.mediaProperties.peerConnection.sdp,\n roapSeq: meetingOptions.meeting.roapSeq,\n meeting: meetingOptions.meeting // or can pass meeting ID\n }))\n .catch((e) => {\n LoggerProxy.logger.error(`Meeting:util#updateTransceiver --> Error updating the ${type} streams with error: ${e}`);\n });\n } if (track) {\n transceiver.sender.replaceTrack(track);\n\n return Promise.resolve();\n }\n\n return Promise.reject(new ParameterError('update Failed: please pass valid parameter'));\n};\n\nMeetingUtil.validateOptions = (options) => {\n const {\n sendVideo, sendAudio, sendShare, localStream, localShare\n } = options;\n\n if (sendVideo && !MeetingUtil.getTrack(localStream).videoTrack) {\n return Promise.reject(new ParameterError('please pass valid video streams'));\n }\n\n if (sendAudio && !MeetingUtil.getTrack(localStream).audioTrack) {\n return Promise.reject(new ParameterError('please pass valid audio streams'));\n }\n\n if (sendShare && !MeetingUtil.getTrack(localShare).videoTrack) {\n return Promise.reject(new ParameterError('please pass valid share streams'));\n }\n\n return Promise.resolve();\n};\n\nMeetingUtil.getTrack = (stream) => {\n let audioTrack = null;\n let videoTrack = null;\n let audioTracks = null;\n let videoTracks = null;\n\n if (!stream) {\n return {audioTrack: null, videoTrack: null};\n }\n if (stream.getAudioTracks) {\n audioTracks = stream.getAudioTracks();\n }\n if (stream.getVideoTracks) {\n videoTracks = stream.getVideoTracks();\n }\n\n if (audioTracks && audioTracks.length > 0) {\n [audioTrack] = audioTracks;\n }\n\n if (videoTracks && videoTracks.length > 0) {\n [videoTrack] = videoTracks;\n }\n\n return {audioTrack, videoTrack};\n};\n\nMeetingUtil.getModeratorFromLocusInfo = (locusInfo) =>\n locusInfo &&\n locusInfo.parsedLocus &&\n locusInfo.parsedLocus.info &&\n locusInfo.parsedLocus.info &&\n locusInfo.parsedLocus.info.moderator;\n\nMeetingUtil.getPolicyFromLocusInfo = (locusInfo) =>\n locusInfo &&\n locusInfo.parsedLocus &&\n locusInfo.parsedLocus.info &&\n locusInfo.parsedLocus.info &&\n locusInfo.parsedLocus.info.policy;\n\nMeetingUtil.canUserLock = (moderator, joined) => {\n if (moderator.LOCK_CONTROL_LOCK && joined.LOCK_STATUS_UNLOCKED) {\n return true;\n }\n\n return false;\n};\n\nMeetingUtil.canUserUnlock = (moderator, joined) => {\n if (moderator.LOCK_CONTROL_UNLOCK && joined.LOCK_STATUS_LOCKED) {\n return true;\n }\n\n return false;\n};\n\nMeetingUtil.canUserRecord = (moderator) => moderator.RECORDING_CONTROL_START;\n\nMeetingUtil.canUserPause = (moderator) => moderator.RECORDING_CONTROL_PAUSE;\n\nMeetingUtil.canUserResume = (moderator) => moderator.RECORDING_CONTROL_RESUME;\n\nMeetingUtil.canUserStop = (moderator) => moderator.RECORDING_CONTROL_STOP;\n\nMeetingUtil.startRecording = (request, locusUrl, locusInfo) => {\n const moderator = MeetingUtil.getModeratorFromLocusInfo(locusInfo);\n\n if (moderator && MeetingUtil.canUserRecord(moderator)) {\n return request.recordMeeting({locusUrl, recording: true, paused: false});\n }\n\n return Promise.reject(new PermissionError('Start recording not allowed, due to moderator property.'));\n};\n\nMeetingUtil.pauseRecording = (request, locusUrl, locusInfo) => {\n const moderator = MeetingUtil.getModeratorFromLocusInfo(locusInfo);\n\n if (moderator && MeetingUtil.canUserPause(moderator)) {\n return request.recordMeeting({locusUrl, recording: true, paused: true});\n }\n\n return Promise.reject(new PermissionError('Pause recording not allowed, due to moderator property.'));\n};\n\nMeetingUtil.resumeRecording = (request, locusUrl, locusInfo) => {\n const moderator = MeetingUtil.getModeratorFromLocusInfo(locusInfo);\n\n if (moderator && MeetingUtil.canUserResume(moderator)) {\n return request.recordMeeting({locusUrl, recording: true, paused: false});\n }\n\n return Promise.reject(new PermissionError('Resume recording not allowed, due to moderator property.'));\n};\n\nMeetingUtil.stopRecording = (request, locusUrl, locusInfo) => {\n const moderator = MeetingUtil.getModeratorFromLocusInfo(locusInfo);\n\n if (moderator && MeetingUtil.canUserStop(moderator)) {\n return request.recordMeeting({locusUrl, recording: false, paused: false});\n }\n\n return Promise.reject(new PermissionError('Stop recording not allowed, due to moderator property.'));\n};\n\nMeetingUtil.lockMeeting = (actions, request, locusUrl) => {\n if (actions && actions.canLock) {\n return request.lockMeeting({locusUrl, lock: true});\n }\n\n return Promise.reject(new PermissionError('Lock not allowed, due to joined property.'));\n};\n\nMeetingUtil.unlockMeeting = (actions, request, locusUrl) => {\n if (actions && actions.canUnlock) {\n return request.lockMeeting({locusUrl, lock: false});\n }\n\n return Promise.reject(new PermissionError('Unlock not allowed, due to joined property.'));\n};\n\nMeetingUtil.startInternalStats = (meeting) => {\n if (!meeting.internalStats) {\n const options = {\n useConfig: true,\n senders: [\n {\n id: 'mainAudio',\n correlate: 'audio',\n history: true,\n onEvent: (event) => {\n // TODO: we don't need checks like this since it comes from the transceiver\n // refactor event linkage to use callbacks instead of events\n if (event.kind === 'audio' && event.stat === 'bytesSent') {\n Trigger.trigger(\n meeting,\n {\n file: 'meeting/util',\n function: 'startInternalStats'\n },\n EVENT_TRIGGERS.MEETING_MEDIA_LOCAL_STARTED,\n {\n type: mediaType.AUDIO\n }\n );\n Metrics.postEvent({\n event: eventType.SENDING_MEDIA_START,\n meeting,\n data: {\n mediaType: mediaType.AUDIO\n }\n });\n }\n else if (event.stop && event.stat === 'bytesSent') {\n Metrics.postEvent({\n event: eventType.SENDING_MEDIA_STOP,\n meeting,\n data: {\n mediaType: mediaType.AUDIO\n }\n });\n }\n },\n onData: () => {}\n },\n {\n id: 'mainVideo',\n correlate: 'video',\n history: true,\n onEvent: (event) => {\n if (event.kind === 'video' && event.stat === 'bytesSent') {\n Trigger.trigger(\n meeting,\n {\n file: 'meeting/util',\n function: 'startInternalStats'\n },\n EVENT_TRIGGERS.MEETING_MEDIA_LOCAL_STARTED,\n {\n type: mediaType.VIDEO\n }\n );\n Metrics.postEvent({\n event: eventType.SENDING_MEDIA_START,\n meeting,\n data: {\n mediaType: mediaType.VIDEO\n }\n });\n }\n else if (event.stop && event.stat === 'bytesSent') {\n Metrics.postEvent({\n event: eventType.SENDING_MEDIA_STOP,\n meeting,\n data: {\n mediaType: mediaType.VIDEO\n }\n });\n }\n },\n onData: () => {}\n },\n {\n id: 'mainShare',\n correlate: 'video',\n onEvent: (event) => {\n if (event.kind === 'share' && event.stat === 'bytesSent') {\n Trigger.trigger(\n meeting,\n {\n file: 'meeting/util',\n function: 'startInternalStats'\n },\n EVENT_TRIGGERS.MEETING_MEDIA_LOCAL_STARTED,\n {\n type: mediaType.SHARE\n }\n );\n Metrics.postEvent({\n event: eventType.SENDING_SHARE_START,\n meeting,\n data: {\n mediaType: mediaType.SHARE\n }\n });\n }\n else if (event.stop && event.stat === 'bytesSent') {\n Metrics.postEvent({\n event: eventType.SENDING_SHARE_STOP,\n meeting,\n data: {\n mediaType: mediaType.SHARE\n }\n });\n }\n },\n onData: () => {}\n }\n ],\n receivers: [\n {\n id: 'mainAudio',\n correlate: 'audio',\n history: true,\n onEvent: (event) => {\n if (event.kind === 'audio' && event.stat === 'bytesReceived') {\n Trigger.trigger(\n meeting,\n {\n file: 'meeting/util',\n function: 'startInternalStats'\n },\n EVENT_TRIGGERS.MEETING_MEDIA_REMOTE_STARTED,\n {\n type: mediaType.AUDIO\n }\n );\n Metrics.postEvent({\n event: eventType.RECEIVING_MEDIA_START,\n meeting,\n data: {\n mediaType: mediaType.AUDIO\n }\n });\n }\n else if (event.stop && event.stat === 'bytesReceived') {\n Metrics.postEvent({\n event: eventType.RECEIVING_MEDIA_STOP,\n meeting,\n data: {\n mediaType: mediaType.AUDIO\n }\n });\n }\n },\n onData: () => {}\n },\n {\n id: 'mainVideo',\n correlate: 'video',\n history: true,\n onEvent: (event) => {\n if (event.kind === 'video' && event.stat === 'bytesReceived') {\n Trigger.trigger(\n meeting,\n {\n file: 'meeting/util',\n function: 'startInternalStats'\n },\n EVENT_TRIGGERS.MEETING_MEDIA_REMOTE_STARTED,\n {\n type: mediaType.VIDEO\n }\n );\n Metrics.postEvent({\n event: eventType.RECEIVING_MEDIA_START,\n meeting,\n data: {\n mediaType: mediaType.VIDEO\n }\n });\n }\n else if (event.stop && event.stat === 'bytesReceived') {\n Metrics.postEvent({\n event: eventType.RECEIVING_MEDIA_STOP,\n meeting,\n data: {\n mediaType: mediaType.VIDEO\n }\n });\n }\n },\n onData: () => {}\n },\n {\n id: 'mainShare',\n correlate: 'video',\n onEvent: (event) => {\n if (event.kind === 'share' && event.stat === 'bytesReceived') {\n Trigger.trigger(\n meeting,\n {\n file: 'meeting/util',\n function: 'startInternalStats'\n },\n EVENT_TRIGGERS.MEETING_MEDIA_REMOTE_STARTED,\n {\n type: mediaType.SHARE\n }\n );\n Metrics.postEvent({\n event: eventType.RECEIVING_MEDIA_START,\n meeting,\n data: {\n mediaType: mediaType.SHARE\n }\n });\n }\n else if (event.stop && event.stat === 'bytesReceived') {\n Metrics.postEvent({\n event: eventType.RECEIVING_MEDIA_STOP,\n meeting,\n data: {\n mediaType: mediaType.SHARE\n }\n });\n }\n },\n onData: () => {}\n }\n ]\n };\n\n StatsUtil.generateOptions(options, STATS.CONFIG, meeting);\n\n options.config = STATS.CONFIG;\n\n // pass the attrs and options for the webex instance\n meeting.internalStats = new WebRTCStats(meeting.attrs, meeting.options, options);\n }\n\n return meeting.internalStats;\n};\n\nMeetingUtil.handleAudioLogging = (audioTrack) => {\n const LOG_HEADER = 'MeetingUtil#handleAudioLogging -->';\n\n if (audioTrack) {\n const settings = audioTrack.getSettings();\n const {deviceId} = settings;\n\n LoggerProxy.logger.log(LOG_HEADER, `deviceId = ${deviceId}`);\n LoggerProxy.logger.log(LOG_HEADER, 'settings =', JSON.stringify(settings));\n }\n};\n\nMeetingUtil.handleVideoLogging = (videoTrack) => {\n const LOG_HEADER = 'MeetingUtil#handleVideoLogging -->';\n\n if (videoTrack) {\n const settings = videoTrack.getSettings();\n const {deviceId} = settings;\n\n LoggerProxy.logger.log(LOG_HEADER, `deviceId = ${deviceId}`);\n LoggerProxy.logger.log(LOG_HEADER, 'settings =', JSON.stringify(settings));\n }\n};\n\nMeetingUtil.handleDeviceLogging = (devices = []) => {\n const LOG_HEADER = 'MeetingUtil#handleDeviceLogging -->';\n\n devices.forEach((device) => {\n LoggerProxy.logger.log(LOG_HEADER, `deviceId = ${device.deviceId}`);\n LoggerProxy.logger.log(LOG_HEADER, 'settings', JSON.stringify(device));\n });\n};\n\nexport default MeetingUtil;\n"]}
|
|
1
|
+
{"version":3,"sources":["util.js"],"names":["MeetingUtil","parseLocusJoin","response","parsed","locus","body","mediaConnections","locusUrl","url","locusId","split","pop","selfId","self","id","forEach","mediaConnection","mediaId","remoteUpdateAudioVideo","audioMuted","videoMuted","meeting","reject","ParameterError","localMedias","Media","generateLocalMedias","Metrics","postEvent","event","eventType","MEDIA_REQUEST","meetingRequest","remoteAudioVideoToggle","deviceUrl","correlationId","then","MEDIA_RESPONSE","hasOwner","info","owner","isOwnerSelf","isPinOrGuest","err","errorCode","INTENT_TO_JOIN","joinMeeting","options","LOCUS_JOIN_REQUEST","sipUri","meetingNumber","roapMessage","resourceId","moderator","pin","moveToResource","preferTranscoding","asResourceOccupant","res","LOCUS_JOIN_RESPONSE","data","trigger","LOCI_UPDATE","trackingId","headers","trackingid","cleanUp","statsAnalyzer","stopAnalyzer","closeLocalStream","closeLocalShare","closeRemoteTracks","closePeerConnections","unsetLocalVideoTrack","unsetLocalShareTrack","unsetRemoteTracks","unsetPeerConnections","cleanMQAInterval","reconnectionManager","roap","stop","roapSeq","leavePstn","dialInUrl","meetingState","FULL_STATE","INACTIVE","MeetingNotActiveError","locusInfo","onFullLocus","catch","LoggerProxy","logger","error","leaveMeeting","isUserInLeftState","UserNotJoinedError","defaultOptions","leaveOptions","resolve","moveMeeting","declineMeeting","reason","parsedLocus","state","_LEFT_","isUserInIdleState","_IDLE_","isUserInJoinedState","_JOINED_","isMediaEstablished","currentMediaStatus","audio","video","share","joinMeetingOptions","PIN_COLLECTED","setLocus","meetingInfo","PIN_PROMPT","IntentToJoinError","JoinMeetingError","updateTransceiver","meetingOptions","type","sendTrack","receiveTrack","track","transceiver","peerConnection","previousMediaDirection","undefined","meetingId","remoteQualityLevel","mediaProperties","enableRtx","config","enableExtmap","sendRoapMediaRequest","sdp","e","sender","replaceTrack","validateOptions","sendVideo","sendAudio","sendShare","localStream","localShare","getTrack","videoTrack","audioTrack","stream","audioTracks","videoTracks","getAudioTracks","getVideoTracks","length","getModeratorFromLocusInfo","getPolicyFromLocusInfo","policy","canUserLock","joined","LOCK_CONTROL_LOCK","LOCK_STATUS_UNLOCKED","canUserUnlock","LOCK_CONTROL_UNLOCK","LOCK_STATUS_LOCKED","canUserRecord","RECORDING_CONTROL_START","canUserPause","RECORDING_CONTROL_PAUSE","canUserResume","RECORDING_CONTROL_RESUME","canUserStop","RECORDING_CONTROL_STOP","startRecording","request","recordMeeting","recording","paused","PermissionError","pauseRecording","resumeRecording","stopRecording","lockMeeting","actions","canLock","lock","unlockMeeting","canUnlock","startInternalStats","internalStats","useConfig","senders","correlate","history","onEvent","kind","stat","Trigger","file","function","EVENT_TRIGGERS","MEETING_MEDIA_LOCAL_STARTED","mediaType","AUDIO","SENDING_MEDIA_START","SENDING_MEDIA_STOP","onData","VIDEO","SHARE","SENDING_SHARE_START","SENDING_SHARE_STOP","receivers","MEETING_MEDIA_REMOTE_STARTED","RECEIVING_MEDIA_START","RECEIVING_MEDIA_STOP","StatsUtil","generateOptions","STATS","CONFIG","WebRTCStats","attrs","handleAudioLogging","LOG_HEADER","settings","getSettings","deviceId","log","handleVideoLogging","handleDeviceLogging","devices","device"],"mappings":"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","sourcesContent":["import {isEmpty} from 'lodash';\n\nimport {MeetingNotActiveError, UserNotJoinedError} from '../common/errors/webex-errors';\nimport StatsUtil from '../stats/util';\nimport Metrics from '../metrics';\nimport {eventType, trigger, mediaType} from '../metrics/config';\nimport Media from '../media';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport WebRTCStats from '../stats/index';\nimport {INTENT_TO_JOIN,\n _LEFT_,\n _IDLE_,\n _JOINED_,\n STATS,\n EVENT_TRIGGERS\n , FULL_STATE} from '../constants';\nimport Trigger from '../common/events/trigger-proxy';\nimport IntentToJoinError from '../common/errors/intent-to-join';\nimport JoinMeetingError from '../common/errors/join-meeting';\nimport ParameterError from '../common/errors/parameter';\nimport PermissionError from '../common/errors/permission';\n\n\nconst MeetingUtil = {};\n\nMeetingUtil.parseLocusJoin = (response) => {\n const parsed = {};\n\n // First todo: add check for existance\n parsed.locus = response.body.locus;\n parsed.mediaConnections = response.body.mediaConnections;\n parsed.locusUrl = parsed.locus.url;\n parsed.locusId = parsed.locus.url.split('/').pop();\n parsed.selfId = parsed.locus.self.id;\n\n // we need mediaId before making roap calls\n parsed.mediaConnections.forEach((mediaConnection) => {\n if (mediaConnection.mediaId) {\n parsed.mediaId = mediaConnection.mediaId;\n }\n });\n\n return parsed;\n};\n\nMeetingUtil.remoteUpdateAudioVideo = (audioMuted, videoMuted, meeting) => {\n if (!meeting) {\n return Promise.reject(new ParameterError('You need a meeting object.'));\n }\n const localMedias = Media.generateLocalMedias(meeting.mediaId, audioMuted, videoMuted);\n\n if (isEmpty(localMedias)) {\n return Promise.reject(new ParameterError('You need a media id on the meeting to change remote audio.'));\n }\n\n Metrics.postEvent({event: eventType.MEDIA_REQUEST, meeting});\n\n return meeting.meetingRequest.remoteAudioVideoToggle({\n locusUrl: meeting.locusUrl,\n selfId: meeting.selfId,\n localMedias,\n deviceUrl: meeting.deviceUrl,\n correlationId: meeting.correlationId\n }).then((response) => {\n Metrics.postEvent({event: eventType.MEDIA_RESPONSE, meeting});\n\n return response.body.locus;\n });\n};\n\nMeetingUtil.hasOwner = (info) => info && info.owner;\n\nMeetingUtil.isOwnerSelf = (owner, selfId) => owner === selfId;\n\nMeetingUtil.isPinOrGuest = (err) => {\n if (err && err.body && err.body.errorCode === INTENT_TO_JOIN) {\n return true;\n }\n\n return false;\n};\n\nMeetingUtil.joinMeeting = (meeting, options) => {\n if (!meeting) {\n return Promise.reject(new ParameterError('You need a meeting object.'));\n }\n\n Metrics.postEvent({event: eventType.LOCUS_JOIN_REQUEST, meeting});\n\n // eslint-disable-next-line no-warning-comments\n // TODO: check if the meeting is in JOINING state\n // if Joining state termintate the request as user might click multiple times\n return meeting.meetingRequest\n .joinMeeting({\n sipUri: meeting.sipUri,\n meetingNumber: meeting.meetingNumber,\n deviceUrl: meeting.deviceUrl,\n locusUrl: meeting.locusUrl,\n correlationId: meeting.correlationId,\n roapMessage: options.roapMessage,\n resourceId: options.resourceId || null,\n moderator: options.moderator,\n pin: options.pin,\n moveToResource: options.moveToResource,\n preferTranscoding: options.preferTranscoding,\n asResourceOccupant: options.asResourceOccupant\n })\n .then((res) => {\n Metrics.postEvent({\n event: eventType.LOCUS_JOIN_RESPONSE,\n meeting,\n data: {\n trigger: trigger.LOCI_UPDATE,\n locus: res.body.locus,\n mediaConnections: res.body.mediaConnections,\n trackingId: res.headers.trackingid\n }\n });\n\n return MeetingUtil.parseLocusJoin(res);\n });\n};\n\nMeetingUtil.cleanUp = (meeting) => {\n // make sure we send last metrics before we close the peerconnection\n if (meeting.statsAnalyzer) meeting.statsAnalyzer.stopAnalyzer();\n\n return meeting.closeLocalStream()\n .then(() => meeting.closeLocalShare())\n .then(() => meeting.closeRemoteTracks())\n .then(() => meeting.closePeerConnections())\n .then(() => {\n meeting.unsetLocalVideoTrack();\n meeting.unsetLocalShareTrack();\n meeting.unsetRemoteTracks();\n meeting.unsetPeerConnections();\n meeting.cleanMQAInterval();\n meeting.reconnectionManager.cleanUp();\n })\n .then(() => meeting.roap.stop(meeting.correlationId, meeting.roapSeq));\n};\n\nMeetingUtil.leavePstn = (meeting, dialInUrl) => {\n if (meeting.meetingState === FULL_STATE.INACTIVE) {\n return Promise.reject(new MeetingNotActiveError());\n }\n\n const options = {\n locusUrl: meeting.locusUrl,\n selfId: meeting.selfId,\n correlationId: meeting.correlationId,\n dialInUrl\n };\n\n return meeting.meetingRequest\n .leavePstn(options)\n .then((response) => {\n if (response?.body?.locus) {\n meeting.locusInfo.onFullLocus(response.body.locus);\n }\n })\n .catch((err) => {\n LoggerProxy.logger.error(\n `Meeting:util#leavePstn --> An error occured while trying to leave pstn with an id of ${\n meeting.id\n }, error: ${err}`\n );\n\n return Promise.reject(err);\n });\n};\n\n// by default will leave on meeting's resourceId\n// if you explicity want it not to leave on resource id, pass\n// {resourceId: null}\n// TODO: chris, you can modify this however you want\nMeetingUtil.leaveMeeting = (meeting, options = {}) => {\n if (meeting.meetingState === FULL_STATE.INACTIVE) {\n // TODO: clean up if the meeting is already inactive\n return Promise.reject(new MeetingNotActiveError());\n }\n\n if (MeetingUtil.isUserInLeftState(meeting.locusInfo)) {\n return Promise.reject(new UserNotJoinedError());\n }\n\n const defaultOptions = {\n locusUrl: meeting.locusUrl,\n selfId: meeting.selfId,\n correlationId: meeting.correlationId,\n resourceId: meeting.resourceId,\n deviceUrl: meeting.deviceUrl\n };\n\n const leaveOptions = {...defaultOptions, ...options};\n\n return meeting.meetingRequest\n .leaveMeeting(leaveOptions)\n .then((response) => {\n if (response && response.body && response.body.locus) { // && !options.moveMeeting) {\n meeting.locusInfo.onFullLocus(response.body.locus);\n }\n\n return Promise.resolve();\n })\n .then(() => {\n if (options.moveMeeting) {\n return Promise.resolve();\n }\n\n return MeetingUtil.cleanUp(meeting);\n })\n .catch((err) => {\n // TODO: If the meeting state comes as LEFT or INACTIVE as response then\n // 1) on leave clean up the meeting or simply do a sync on the meeting\n // 2) If the error says meeting is inactive then destroy the meeting object\n LoggerProxy.logger.error(\n `Meeting:util#leaveMeeting --> An error occured while trying to leave meeting with an id of ${\n meeting.id\n }, error: ${err}`\n );\n\n return Promise.reject(err);\n });\n};\nMeetingUtil.declineMeeting = (meeting, reason) =>\n meeting.meetingRequest.declineMeeting({\n locusUrl: meeting.locusUrl,\n deviceUrl: meeting.deviceUrl,\n reason\n });\n\nMeetingUtil.isUserInLeftState = (locusInfo) =>\n locusInfo.parsedLocus?.self?.state === _LEFT_;\n\nMeetingUtil.isUserInIdleState = (locusInfo) =>\n locusInfo.parsedLocus?.self?.state === _IDLE_;\n\nMeetingUtil.isUserInJoinedState = (locusInfo) =>\n locusInfo.parsedLocus?.self?.state === _JOINED_;\n\nMeetingUtil.isMediaEstablished = (currentMediaStatus) =>\n currentMediaStatus && (currentMediaStatus.audio || currentMediaStatus.video || currentMediaStatus.share);\n\n\nMeetingUtil.joinMeetingOptions = (meeting, options = {}) => {\n meeting.resourceId = meeting.resourceId || options.resourceId;\n\n if (options.pin) {\n Metrics.postEvent({\n event: eventType.PIN_COLLECTED,\n meeting\n });\n }\n\n // normal join meeting, scenario A, D\n return MeetingUtil.joinMeeting(meeting, options)\n .then((response) => {\n meeting.setLocus(response);\n\n return Promise.resolve(response);\n })\n .catch((err) => {\n // joining a claimed PMR that is not my own, scenario B\n if (MeetingUtil.isPinOrGuest(err)) {\n if (MeetingUtil.hasOwner(meeting.meetingInfo)) {\n return MeetingUtil.joinMeeting(meeting, options).then((response) => {\n meeting.setLocus(response);\n\n return Promise.resolve();\n });\n }\n\n Metrics.postEvent({\n event: eventType.PIN_PROMPT,\n meeting\n });\n\n // request host pin or non host for unclaimed PMR, start of Scenario C\n // see https://sqbu-github.cisco.com/WebExSquared/locus/wiki/Locus-Lobby-and--IVR-Feature\n return Promise.reject(new IntentToJoinError('Error Joining Meeting', err));\n }\n LoggerProxy.logger.error('Meeting:util#joinMeetingOptions --> Error joining the call, ', err);\n\n return Promise.reject(new JoinMeetingError(options, 'Error Joining Meeting', err));\n });\n};\n\nMeetingUtil.updateTransceiver = (options, meetingOptions) => {\n const {\n type,\n sendTrack,\n receiveTrack,\n track,\n transceiver,\n peerConnection,\n previousMediaDirection\n } = options;\n\n if ((sendTrack !== undefined && sendTrack !== previousMediaDirection.sendTrack) ||\n (receiveTrack !== undefined && receiveTrack !== previousMediaDirection.receiveTrack)) {\n return Media.updateTransceiver({\n meetingId: meetingOptions.meeting.id,\n remoteQualityLevel: meetingOptions.mediaProperties.remoteQualityLevel,\n enableRtx: meetingOptions.meeting.config.enableRtx,\n enableExtmap: meetingOptions.meeting.config.enableExtmap\n }, peerConnection, transceiver,\n {\n track,\n type,\n receiveTrack,\n sendTrack\n })\n .then(() => meetingOptions.meeting.roap\n .sendRoapMediaRequest({\n sdp: meetingOptions.mediaProperties.peerConnection.sdp,\n roapSeq: meetingOptions.meeting.roapSeq,\n meeting: meetingOptions.meeting // or can pass meeting ID\n }))\n .catch((e) => {\n LoggerProxy.logger.error(`Meeting:util#updateTransceiver --> Error updating the ${type} streams with error: ${e}`);\n });\n } if (track) {\n transceiver.sender.replaceTrack(track);\n\n return Promise.resolve();\n }\n\n return Promise.reject(new ParameterError('update Failed: please pass valid parameter'));\n};\n\nMeetingUtil.validateOptions = (options) => {\n const {\n sendVideo, sendAudio, sendShare, localStream, localShare\n } = options;\n\n if (sendVideo && !MeetingUtil.getTrack(localStream).videoTrack) {\n return Promise.reject(new ParameterError('please pass valid video streams'));\n }\n\n if (sendAudio && !MeetingUtil.getTrack(localStream).audioTrack) {\n return Promise.reject(new ParameterError('please pass valid audio streams'));\n }\n\n if (sendShare && !MeetingUtil.getTrack(localShare).videoTrack) {\n return Promise.reject(new ParameterError('please pass valid share streams'));\n }\n\n return Promise.resolve();\n};\n\nMeetingUtil.getTrack = (stream) => {\n let audioTrack = null;\n let videoTrack = null;\n let audioTracks = null;\n let videoTracks = null;\n\n if (!stream) {\n return {audioTrack: null, videoTrack: null};\n }\n if (stream.getAudioTracks) {\n audioTracks = stream.getAudioTracks();\n }\n if (stream.getVideoTracks) {\n videoTracks = stream.getVideoTracks();\n }\n\n if (audioTracks && audioTracks.length > 0) {\n [audioTrack] = audioTracks;\n }\n\n if (videoTracks && videoTracks.length > 0) {\n [videoTrack] = videoTracks;\n }\n\n return {audioTrack, videoTrack};\n};\n\nMeetingUtil.getModeratorFromLocusInfo = (locusInfo) =>\n locusInfo &&\n locusInfo.parsedLocus &&\n locusInfo.parsedLocus.info &&\n locusInfo.parsedLocus.info &&\n locusInfo.parsedLocus.info.moderator;\n\nMeetingUtil.getPolicyFromLocusInfo = (locusInfo) =>\n locusInfo &&\n locusInfo.parsedLocus &&\n locusInfo.parsedLocus.info &&\n locusInfo.parsedLocus.info &&\n locusInfo.parsedLocus.info.policy;\n\nMeetingUtil.canUserLock = (moderator, joined) => {\n if (moderator.LOCK_CONTROL_LOCK && joined.LOCK_STATUS_UNLOCKED) {\n return true;\n }\n\n return false;\n};\n\nMeetingUtil.canUserUnlock = (moderator, joined) => {\n if (moderator.LOCK_CONTROL_UNLOCK && joined.LOCK_STATUS_LOCKED) {\n return true;\n }\n\n return false;\n};\n\nMeetingUtil.canUserRecord = (moderator) => moderator.RECORDING_CONTROL_START;\n\nMeetingUtil.canUserPause = (moderator) => moderator.RECORDING_CONTROL_PAUSE;\n\nMeetingUtil.canUserResume = (moderator) => moderator.RECORDING_CONTROL_RESUME;\n\nMeetingUtil.canUserStop = (moderator) => moderator.RECORDING_CONTROL_STOP;\n\nMeetingUtil.startRecording = (request, locusUrl, locusInfo) => {\n const moderator = MeetingUtil.getModeratorFromLocusInfo(locusInfo);\n\n if (moderator && MeetingUtil.canUserRecord(moderator)) {\n return request.recordMeeting({locusUrl, recording: true, paused: false});\n }\n\n return Promise.reject(new PermissionError('Start recording not allowed, due to moderator property.'));\n};\n\nMeetingUtil.pauseRecording = (request, locusUrl, locusInfo) => {\n const moderator = MeetingUtil.getModeratorFromLocusInfo(locusInfo);\n\n if (moderator && MeetingUtil.canUserPause(moderator)) {\n return request.recordMeeting({locusUrl, recording: true, paused: true});\n }\n\n return Promise.reject(new PermissionError('Pause recording not allowed, due to moderator property.'));\n};\n\nMeetingUtil.resumeRecording = (request, locusUrl, locusInfo) => {\n const moderator = MeetingUtil.getModeratorFromLocusInfo(locusInfo);\n\n if (moderator && MeetingUtil.canUserResume(moderator)) {\n return request.recordMeeting({locusUrl, recording: true, paused: false});\n }\n\n return Promise.reject(new PermissionError('Resume recording not allowed, due to moderator property.'));\n};\n\nMeetingUtil.stopRecording = (request, locusUrl, locusInfo) => {\n const moderator = MeetingUtil.getModeratorFromLocusInfo(locusInfo);\n\n if (moderator && MeetingUtil.canUserStop(moderator)) {\n return request.recordMeeting({locusUrl, recording: false, paused: false});\n }\n\n return Promise.reject(new PermissionError('Stop recording not allowed, due to moderator property.'));\n};\n\nMeetingUtil.lockMeeting = (actions, request, locusUrl) => {\n if (actions && actions.canLock) {\n return request.lockMeeting({locusUrl, lock: true});\n }\n\n return Promise.reject(new PermissionError('Lock not allowed, due to joined property.'));\n};\n\nMeetingUtil.unlockMeeting = (actions, request, locusUrl) => {\n if (actions && actions.canUnlock) {\n return request.lockMeeting({locusUrl, lock: false});\n }\n\n return Promise.reject(new PermissionError('Unlock not allowed, due to joined property.'));\n};\n\nMeetingUtil.startInternalStats = (meeting) => {\n if (!meeting.internalStats) {\n const options = {\n useConfig: true,\n senders: [\n {\n id: 'mainAudio',\n correlate: 'audio',\n history: true,\n onEvent: (event) => {\n // TODO: we don't need checks like this since it comes from the transceiver\n // refactor event linkage to use callbacks instead of events\n if (event.kind === 'audio' && event.stat === 'bytesSent') {\n Trigger.trigger(\n meeting,\n {\n file: 'meeting/util',\n function: 'startInternalStats'\n },\n EVENT_TRIGGERS.MEETING_MEDIA_LOCAL_STARTED,\n {\n type: mediaType.AUDIO\n }\n );\n Metrics.postEvent({\n event: eventType.SENDING_MEDIA_START,\n meeting,\n data: {\n mediaType: mediaType.AUDIO\n }\n });\n }\n else if (event.stop && event.stat === 'bytesSent') {\n Metrics.postEvent({\n event: eventType.SENDING_MEDIA_STOP,\n meeting,\n data: {\n mediaType: mediaType.AUDIO\n }\n });\n }\n },\n onData: () => {}\n },\n {\n id: 'mainVideo',\n correlate: 'video',\n history: true,\n onEvent: (event) => {\n if (event.kind === 'video' && event.stat === 'bytesSent') {\n Trigger.trigger(\n meeting,\n {\n file: 'meeting/util',\n function: 'startInternalStats'\n },\n EVENT_TRIGGERS.MEETING_MEDIA_LOCAL_STARTED,\n {\n type: mediaType.VIDEO\n }\n );\n Metrics.postEvent({\n event: eventType.SENDING_MEDIA_START,\n meeting,\n data: {\n mediaType: mediaType.VIDEO\n }\n });\n }\n else if (event.stop && event.stat === 'bytesSent') {\n Metrics.postEvent({\n event: eventType.SENDING_MEDIA_STOP,\n meeting,\n data: {\n mediaType: mediaType.VIDEO\n }\n });\n }\n },\n onData: () => {}\n },\n {\n id: 'mainShare',\n correlate: 'video',\n onEvent: (event) => {\n if (event.kind === 'share' && event.stat === 'bytesSent') {\n Trigger.trigger(\n meeting,\n {\n file: 'meeting/util',\n function: 'startInternalStats'\n },\n EVENT_TRIGGERS.MEETING_MEDIA_LOCAL_STARTED,\n {\n type: mediaType.SHARE\n }\n );\n Metrics.postEvent({\n event: eventType.SENDING_SHARE_START,\n meeting,\n data: {\n mediaType: mediaType.SHARE\n }\n });\n }\n else if (event.stop && event.stat === 'bytesSent') {\n Metrics.postEvent({\n event: eventType.SENDING_SHARE_STOP,\n meeting,\n data: {\n mediaType: mediaType.SHARE\n }\n });\n }\n },\n onData: () => {}\n }\n ],\n receivers: [\n {\n id: 'mainAudio',\n correlate: 'audio',\n history: true,\n onEvent: (event) => {\n if (event.kind === 'audio' && event.stat === 'bytesReceived') {\n Trigger.trigger(\n meeting,\n {\n file: 'meeting/util',\n function: 'startInternalStats'\n },\n EVENT_TRIGGERS.MEETING_MEDIA_REMOTE_STARTED,\n {\n type: mediaType.AUDIO\n }\n );\n Metrics.postEvent({\n event: eventType.RECEIVING_MEDIA_START,\n meeting,\n data: {\n mediaType: mediaType.AUDIO\n }\n });\n }\n else if (event.stop && event.stat === 'bytesReceived') {\n Metrics.postEvent({\n event: eventType.RECEIVING_MEDIA_STOP,\n meeting,\n data: {\n mediaType: mediaType.AUDIO\n }\n });\n }\n },\n onData: () => {}\n },\n {\n id: 'mainVideo',\n correlate: 'video',\n history: true,\n onEvent: (event) => {\n if (event.kind === 'video' && event.stat === 'bytesReceived') {\n Trigger.trigger(\n meeting,\n {\n file: 'meeting/util',\n function: 'startInternalStats'\n },\n EVENT_TRIGGERS.MEETING_MEDIA_REMOTE_STARTED,\n {\n type: mediaType.VIDEO\n }\n );\n Metrics.postEvent({\n event: eventType.RECEIVING_MEDIA_START,\n meeting,\n data: {\n mediaType: mediaType.VIDEO\n }\n });\n }\n else if (event.stop && event.stat === 'bytesReceived') {\n Metrics.postEvent({\n event: eventType.RECEIVING_MEDIA_STOP,\n meeting,\n data: {\n mediaType: mediaType.VIDEO\n }\n });\n }\n },\n onData: () => {}\n },\n {\n id: 'mainShare',\n correlate: 'video',\n onEvent: (event) => {\n if (event.kind === 'share' && event.stat === 'bytesReceived') {\n Trigger.trigger(\n meeting,\n {\n file: 'meeting/util',\n function: 'startInternalStats'\n },\n EVENT_TRIGGERS.MEETING_MEDIA_REMOTE_STARTED,\n {\n type: mediaType.SHARE\n }\n );\n Metrics.postEvent({\n event: eventType.RECEIVING_MEDIA_START,\n meeting,\n data: {\n mediaType: mediaType.SHARE\n }\n });\n }\n else if (event.stop && event.stat === 'bytesReceived') {\n Metrics.postEvent({\n event: eventType.RECEIVING_MEDIA_STOP,\n meeting,\n data: {\n mediaType: mediaType.SHARE\n }\n });\n }\n },\n onData: () => {}\n }\n ]\n };\n\n StatsUtil.generateOptions(options, STATS.CONFIG, meeting);\n\n options.config = STATS.CONFIG;\n\n // pass the attrs and options for the webex instance\n meeting.internalStats = new WebRTCStats(meeting.attrs, meeting.options, options);\n }\n\n return meeting.internalStats;\n};\n\nMeetingUtil.handleAudioLogging = (audioTrack) => {\n const LOG_HEADER = 'MeetingUtil#handleAudioLogging -->';\n\n if (audioTrack) {\n const settings = audioTrack.getSettings();\n const {deviceId} = settings;\n\n LoggerProxy.logger.log(LOG_HEADER, `deviceId = ${deviceId}`);\n LoggerProxy.logger.log(LOG_HEADER, 'settings =', JSON.stringify(settings));\n }\n};\n\nMeetingUtil.handleVideoLogging = (videoTrack) => {\n const LOG_HEADER = 'MeetingUtil#handleVideoLogging -->';\n\n if (videoTrack) {\n const settings = videoTrack.getSettings();\n const {deviceId} = settings;\n\n LoggerProxy.logger.log(LOG_HEADER, `deviceId = ${deviceId}`);\n LoggerProxy.logger.log(LOG_HEADER, 'settings =', JSON.stringify(settings));\n }\n};\n\nMeetingUtil.handleDeviceLogging = (devices = []) => {\n const LOG_HEADER = 'MeetingUtil#handleDeviceLogging -->';\n\n devices.forEach((device) => {\n LoggerProxy.logger.log(LOG_HEADER, `deviceId = ${device.deviceId}`);\n LoggerProxy.logger.log(LOG_HEADER, 'settings', JSON.stringify(device));\n });\n};\n\nexport default MeetingUtil;\n"]}
|
|
@@ -227,7 +227,6 @@ pc.iceCandidate = function (peerConnection, _ref) {
|
|
|
227
227
|
var timeout = setTimeout(function () {
|
|
228
228
|
peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);
|
|
229
229
|
peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);
|
|
230
|
-
peerConnection.sdp = peerConnection.sdp.replace(/\na=extmap.*/g, '');
|
|
231
230
|
|
|
232
231
|
if (isSdpInvalid(peerConnection.sdp)) {
|
|
233
232
|
setTimeout(function () {
|
|
@@ -254,7 +253,6 @@ pc.iceCandidate = function (peerConnection, _ref) {
|
|
|
254
253
|
if (!evt.candidate && !peerConnection.sdp) {
|
|
255
254
|
peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);
|
|
256
255
|
peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);
|
|
257
|
-
peerConnection.sdp = peerConnection.sdp.replace(/\na=extmap.*/g, '');
|
|
258
256
|
|
|
259
257
|
if (evt.candidate === null && !isSdpInvalid(peerConnection.sdp)) {
|
|
260
258
|
clearTimeout(timeout);
|
|
@@ -335,8 +333,7 @@ pc.addStream = function (peerConnection, stream) {
|
|
|
335
333
|
pc.setRemoteSessionDetails = function (peerConnection, typeStr, remoteSdp, meetingId) {
|
|
336
334
|
_loggerProxy.default.logger.log("PeerConnectionManager:index#setRemoteSessionDetails --> Setting the remote description type: ".concat(typeStr, "State: ").concat(peerConnection.signalingState));
|
|
337
335
|
|
|
338
|
-
var sdp = remoteSdp;
|
|
339
|
-
sdp = sdp.replace(/\na=extmap.*/g, ''); // making sure that the remoteDescription is only set when there is a answer for offer
|
|
336
|
+
var sdp = remoteSdp; // making sure that the remoteDescription is only set when there is a answer for offer
|
|
340
337
|
// or there is a offer from the server
|
|
341
338
|
|
|
342
339
|
if (!sdp) {
|
|
@@ -396,6 +393,7 @@ pc.setRemoteSessionDetails = function (peerConnection, typeStr, remoteSdp, meeti
|
|
|
396
393
|
* @param {string} meetingProperties.meetingId
|
|
397
394
|
* @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH
|
|
398
395
|
* @param {string} meetingProperties.enableRtx
|
|
396
|
+
* @param {string} meetingProperties.enableExtmap
|
|
399
397
|
* @returns {RTCPeerConnection}
|
|
400
398
|
*/
|
|
401
399
|
|
|
@@ -403,7 +401,8 @@ pc.setRemoteSessionDetails = function (peerConnection, typeStr, remoteSdp, meeti
|
|
|
403
401
|
pc.createOffer = function (peerConnection, _ref2) {
|
|
404
402
|
var meetingId = _ref2.meetingId,
|
|
405
403
|
remoteQualityLevel = _ref2.remoteQualityLevel,
|
|
406
|
-
enableRtx = _ref2.enableRtx
|
|
404
|
+
enableRtx = _ref2.enableRtx,
|
|
405
|
+
enableExtmap = _ref2.enableExtmap;
|
|
407
406
|
|
|
408
407
|
_loggerProxy.default.logger.log('PeerConnectionManager:index#createOffer --> creating a new offer');
|
|
409
408
|
|
|
@@ -429,7 +428,10 @@ pc.createOffer = function (peerConnection, _ref2) {
|
|
|
429
428
|
throw new _media.default('openH264 is downloading please Wait. Upload logs if not working on second try');
|
|
430
429
|
}
|
|
431
430
|
|
|
432
|
-
|
|
431
|
+
if (!enableExtmap) {
|
|
432
|
+
peerConnection.sdp = peerConnection.sdp.replace(/\na=extmap.*/g, '');
|
|
433
|
+
}
|
|
434
|
+
|
|
433
435
|
pc.setContentSlides(peerConnection);
|
|
434
436
|
|
|
435
437
|
_metrics.default.postEvent({
|
|
@@ -562,7 +564,6 @@ pc.createAnswer = function (params, _ref4) {
|
|
|
562
564
|
throw new _media.default('openH264 is downloading please Wait. Upload logs if not working on second try');
|
|
563
565
|
}
|
|
564
566
|
|
|
565
|
-
peerConnection.sdp = peerConnection.sdp.replace(/\na=extmap.*/g, '');
|
|
566
567
|
return peerConnection;
|
|
567
568
|
}).catch(function (error) {
|
|
568
569
|
if (error instanceof _webexErrors.InvalidSdpError) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["index.js"],"names":["isBrowser","pc","insertBandwidthLimit","sdpLines","index","limit","periodicKeyFrame","search","AUDIO","StaticConfig","meetings","bandwidth","audio","video","SDP","PERIODIC_KEYFRAME","splice","B_LINE","setMaxFs","sdp","level","QUALITY_LEVELS","HIGH","MAX_FRAMESIZES","ParameterError","replaceSdp","maxFsLine","MAX_FS","replace","checkH264Support","videoPresent","match","h264Present","isSdpInvalid","parsedSdp","sdpTransform","parse","media","mediaLine","candidates","length","LoggerProxy","logger","error","hostCandidate","filter","candidate","type","HOST","ip","IPV4_REGEX","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","timeout","setTimeout","localDescription","invalidSdpPresent","InvalidSdpError","RETRY_TIMEOUT","ICE_TIMEOUT","onicecandidate","evt","clearTimeout","replaceTrack","track","senders","getSenders","forEach","sender","kind","err","addStream","stream","tracksPresent","find","getTracks","addTrack","setRemoteSessionDetails","typeStr","remoteSdp","meetingId","log","signalingState","Metrics","postEvent","event","eventType","REMOTE_SDP_RECEIVED","data","canProceed","errors","generateErrorPayload","name","MEDIA_ENGINE","HAVE_LOCAL_OFFER","STABLE","OFFER","setRemoteDescription","window","RTCSessionDescription","then","remoteDescription","catch","metricName","METRICS_OPERATIONAL_MEASURES","PEERCONNECTION_FAILURE","correlation_id","reason","message","stack","metadata","sendOperationalMetric","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","setNetworkStatus","NETWORK_STATUS","iceReconnected","DISCONNECTED","waitForIceReconnect","FAILED","onconnectionstatechange","CONNECTION_STATE","NEW","CONNECTING"],"mappings":"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","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 RETRY_TIMEOUT,\n ICE_TIMEOUT,\n HOST,\n AUDIO,\n SDP,\n ICE_STATE,\n CONNECTION_STATE,\n NETWORK_STATUS,\n PEER_CONNECTION_STATE,\n OFFER,\n QUALITY_LEVELS,\n MAX_FRAMESIZES,\n METRICS_OPERATIONAL_MEASURES,\n IPV4_REGEX\n} from '../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\nconst {isBrowser} = BrowserDetection();\n\n/**\n * @export\n * @public\n */\nconst pc = {};\n\n/**\n * munges the bandwidth limit into the sdp\n * @param {String} sdpLines\n * @param {Number} index\n * @returns {String}\n */\nconst insertBandwidthLimit = (sdpLines, index) => {\n // eslint-disable-next-line no-warning-comments\n // TODO convert to sdp parser\n let limit;\n let periodicKeyFrame = '';\n\n if (sdpLines[index].search(AUDIO) !== -1) {\n limit = StaticConfig.meetings.bandwidth.audio;\n }\n else {\n limit = StaticConfig.meetings.bandwidth.video;\n periodicKeyFrame = SDP.PERIODIC_KEYFRAME;\n sdpLines.splice(index + 2, 0, periodicKeyFrame);\n }\n sdpLines.splice(index + 1, 0, `${SDP.B_LINE}:${limit}`);\n\n return sdpLines;\n};\n\n/**\n * needed for calliope max-fs\n * @param {String} sdp\n * @param {String} [level=QUALITY_LEVELS.HIGH] quality level for max-fs\n * @returns {String}\n */\nconst setMaxFs = (sdp, level = QUALITY_LEVELS.HIGH) => {\n if (!MAX_FRAMESIZES[level]) {\n throw new ParameterError(`setMaxFs: unable to set max framesize, value for level \"${level}\" is not defined`);\n }\n // eslint-disable-next-line no-warning-comments\n // TODO convert with sdp parser, no munging\n let replaceSdp = sdp;\n const maxFsLine = `${SDP.MAX_FS}${MAX_FRAMESIZES[level]}`;\n\n replaceSdp = replaceSdp.replace(/(\\na=fmtp:(\\d+).*level-asymmetry-allowed=1.*)/gi, `$1;${maxFsLine}`);\n\n return replaceSdp;\n};\n\n/**\n * checks that sdp has h264 codec in it\n * @param {String} sdp\n * @returns {boolean}\n */\nconst checkH264Support = (sdp) => {\n // eslint-disable-next-line no-warning-comments\n // TODO convert to sdp parser to read rtp.codec\n const videoPresent = sdp.match(/\\nm=video.*/g);\n const h264Present = sdp.match(/\\na=rtpmap:\\d+\\sH264.*/g);\n\n if (videoPresent) {\n return !!h264Present;\n }\n\n return true;\n};\n\n/**\n * validates the sdp, checks port, candidates, and ice info\n * @param {String} sdp\n * @returns {String}\n */\nconst isSdpInvalid = (sdp) => {\n const parsedSdp = sdpTransform.parse(sdp);\n\n for (const mediaLine of parsedSdp.media) {\n if (mediaLine.candidates && mediaLine.candidates.length === 0) {\n LoggerProxy.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Ice candadate never completed');\n\n return 'iceCandidate: Ice candadate never completed';\n }\n // Sometimes the candidates might be there but only IPV6 we need to makes sure we have IPV4\n const hostCandidate = mediaLine.candidates.filter((candidate) => !!(candidate.type === HOST && candidate.ip.match(IPV4_REGEX)));\n\n if (hostCandidate.length === 0) {\n LoggerProxy.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: no IPV4 candidate present');\n\n return 'iceCandidate: no IPV4 candidate present';\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 // TODO: we dont need timeout as we can check the api state and validate.\n const timeout = setTimeout(() => {\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);\n peerConnection.sdp = peerConnection.sdp.replace(/\\na=extmap.*/g, '');\n\n if (isSdpInvalid(peerConnection.sdp)) {\n setTimeout(() => {\n // peerconnection does gather ice candidate IP but in some cases due to firewall\n // or proxy the ice candidate does not get gathered so we need to wait and then retry\n // if still not valid then throw an error saying missing ice candidate\n // if ice candidate still not present after retry\n const invalidSdpPresent = isSdpInvalid(peerConnection.sdp);\n\n if (!invalidSdpPresent) {\n resolve(peerConnection);\n }\n else {\n LoggerProxy.logger.error('PeerConnectionManager:index#iceCandidate --> SDP not valid after waiting.');\n reject(new InvalidSdpError(invalidSdpPresent));\n }\n }, RETRY_TIMEOUT);\n }\n else {\n resolve(peerConnection);\n }\n }, ICE_TIMEOUT);\n\n peerConnection.onicecandidate = (evt) => {\n if (!evt.candidate && !peerConnection.sdp) {\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);\n peerConnection.sdp = peerConnection.sdp.replace(/\\na=extmap.*/g, '');\n\n if (evt.candidate === null && !isSdpInvalid(peerConnection.sdp)) {\n clearTimeout(timeout);\n resolve(peerConnection);\n }\n }\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 = (peerConnection, typeStr, remoteSdp, meetingId) => {\n LoggerProxy.logger.log(`PeerConnectionManager:index#setRemoteSessionDetails --> Setting the remote description type: ${typeStr}State: ${peerConnection.signalingState}`);\n let sdp = remoteSdp;\n\n sdp = sdp.replace(/\\na=extmap.*/g, '');\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 return peerConnection.setRemoteDescription(\n new window.RTCSessionDescription({\n type: typeStr,\n sdp\n })\n )\n .then(() => {\n if (!peerConnection.remoteDescription) {\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 = METRICS_OPERATIONAL_MEASURES.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.sendOperationalMetric(metricName, data, metadata);\n\n return Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId,\n data: {\n canProceed: false,\n errors: [Metrics.generateErrorPayload(2001, true,\n error.name.MEDIA_ENGINE, 'missing remoteSdp')]\n }\n });\n });\n }\n\n return Promise.reject(new MediaError('PeerConnection in wrong state'));\n};\n\n/**\n * create offer with a valid paramater\n * @param {Object} peerConnection\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @param {string} meetingProperties.enableRtx\n * @returns {RTCPeerConnection}\n */\npc.createOffer = (peerConnection, {meetingId, remoteQualityLevel, enableRtx}) => {\n LoggerProxy.logger.log('PeerConnectionManager:index#createOffer --> creating a new offer');\n\n return peerConnection\n .createOffer()\n .then((description) => {\n // bug https://bugs.chromium.org/p/chromium/issues/detail?id=1020642\n // chrome currently generates RTX line irrespective of weither the server side supports it\n // we are removing apt as well because its associated with rtx line\n\n if (!enableRtx) {\n description.sdp = description.sdp.replace(/\\r\\na=rtpmap:\\d+ rtx\\/\\d+/g, '');\n description.sdp = description.sdp.replace(/\\r\\na=fmtp:\\d+ apt=\\d+/g, '');\n }\n\n return peerConnection.setLocalDescription(description);\n })\n .then(() => pc.iceCandidate(peerConnection, {remoteQualityLevel}))\n .then(() => {\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);\n if (!checkH264Support(peerConnection.sdp)) {\n throw new MediaError('openH264 is downloading please Wait. Upload logs if not working on second try');\n }\n peerConnection.sdp = peerConnection.sdp.replace(/\\na=extmap.*/g, '');\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.sendOperationalMetric(\n METRICS_OPERATIONAL_MEASURES.INVALID_ICE_CANDIDATE,\n {\n correlation_id: meetingId,\n code: error.code,\n reason: error.message\n }\n );\n }\n else {\n const metricName = METRICS_OPERATIONAL_MEASURES.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.sendOperationalMetric(metricName, data, metadata);\n }\n\n Metrics.postEvent({\n event: eventType.LOCAL_SDP_GENERATED,\n meetingId,\n data: {\n canProceed: false,\n errors: [\n Metrics.generateErrorPayload(2001, true,\n error.name.MEDIA_ENGINE)]\n }\n });\n pc.close(peerConnection);\n throw error;\n });\n};\n\n/**\n * rollBack local description in peerconnection\n * @param {Object} peerConnection\n * @returns {Promise.RTCPeerConnection}\n */\npc.rollBackLocalDescription = (peerConnection) => peerConnection\n .setLocalDescription(new RTCSessionDescription({type: SDP.ROLLBACK}))\n .then(() => peerConnection)\n .catch((err) => {\n LoggerProxy.logger.error(`Peer-connection-manager:index#setLocalDescription --> ${err} `);\n\n return Promise.error(err);\n });\n\n/**\n * @param {Object} params {\n * @param {Boolean} params.offerToReceiveAudio\n * @param {Boolean} params.offerToReceiveVideo\n * @param {string} params.offerSdp\n * @param {MediaStream} params.stream\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @returns {Promise.<Array>} [MediaSDP, ScreenSDP]\n */\npc.updatePeerConnection = (params, {meetingId, remoteQualityLevel}) => {\n LoggerProxy.logger.log(`PeerConnectionManager:index#updatePeerConnection --> updating the peerConnection with params: ${params}`);\n\n const {peerConnection, offerSdp} = params;\n\n return pc.createAnswer({\n peerConnection,\n offerSdp: offerSdp[0]\n }, {meetingId, remoteQualityLevel}).then((peerconnection) => {\n // The content slides should also be set when we are sending inactive\n pc.setContentSlides(peerconnection);\n\n return Promise.resolve([peerconnection.sdp]);\n });\n};\n\n/**\n * @param {Object} params\n * @param {Object} params.peerConnection\n * @param {Object} params.sdpConstraints\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @returns {RTCPeerConnection} peerConnection\n */\npc.createAnswer = (params, {meetingId, remoteQualityLevel}) => {\n const {peerConnection} = params;\n\n // TODO: Some times to many mercury event comes at the same time\n // Need to maintain state of peerconnection\n if (peerConnection.signalingState === SDP.HAVE_REMOTE_OFFER) {\n return Promise.resolve(peerConnection);\n }\n\n return pc.setRemoteSessionDetails(peerConnection, OFFER, params.offerSdp, meetingId)\n .then(() => peerConnection.createAnswer(params.sdpConstraints))\n .then((answer) =>\n\n peerConnection.setLocalDescription(answer))\n .then(() => pc.iceCandidate(peerConnection, {remoteQualityLevel}))\n .then(() => {\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);\n if (!checkH264Support(peerConnection.sdp)) {\n throw new MediaError('openH264 is downloading please Wait. Upload logs if not working on second try');\n }\n\n peerConnection.sdp = peerConnection.sdp.replace(/\\na=extmap.*/g, '');\n\n return peerConnection;\n })\n .catch((error) => {\n if (error instanceof InvalidSdpError) {\n Metrics.sendOperationalMetric(\n METRICS_OPERATIONAL_MEASURES.INVALID_ICE_CANDIDATE,\n {\n correlation_id: meetingId\n }\n );\n }\n else {\n const metricName = METRICS_OPERATIONAL_MEASURES.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.sendOperationalMetric(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.sendOperationalMetric(\n METRICS_OPERATIONAL_MEASURES.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 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"]}
|
|
1
|
+
{"version":3,"sources":["index.js"],"names":["isBrowser","pc","insertBandwidthLimit","sdpLines","index","limit","periodicKeyFrame","search","AUDIO","StaticConfig","meetings","bandwidth","audio","video","SDP","PERIODIC_KEYFRAME","splice","B_LINE","setMaxFs","sdp","level","QUALITY_LEVELS","HIGH","MAX_FRAMESIZES","ParameterError","replaceSdp","maxFsLine","MAX_FS","replace","checkH264Support","videoPresent","match","h264Present","isSdpInvalid","parsedSdp","sdpTransform","parse","media","mediaLine","candidates","length","LoggerProxy","logger","error","hostCandidate","filter","candidate","type","HOST","ip","IPV4_REGEX","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","timeout","setTimeout","localDescription","invalidSdpPresent","InvalidSdpError","RETRY_TIMEOUT","ICE_TIMEOUT","onicecandidate","evt","clearTimeout","replaceTrack","track","senders","getSenders","forEach","sender","kind","err","addStream","stream","tracksPresent","find","getTracks","addTrack","setRemoteSessionDetails","typeStr","remoteSdp","meetingId","log","signalingState","Metrics","postEvent","event","eventType","REMOTE_SDP_RECEIVED","data","canProceed","errors","generateErrorPayload","name","MEDIA_ENGINE","HAVE_LOCAL_OFFER","STABLE","OFFER","setRemoteDescription","window","RTCSessionDescription","then","remoteDescription","catch","metricName","METRICS_OPERATIONAL_MEASURES","PEERCONNECTION_FAILURE","correlation_id","reason","message","stack","metadata","sendOperationalMetric","MediaError","createOffer","enableRtx","enableExtmap","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","setNetworkStatus","NETWORK_STATUS","iceReconnected","DISCONNECTED","waitForIceReconnect","FAILED","onconnectionstatechange","CONNECTION_STATE","NEW","CONNECTING"],"mappings":"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","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 RETRY_TIMEOUT,\n ICE_TIMEOUT,\n HOST,\n AUDIO,\n SDP,\n ICE_STATE,\n CONNECTION_STATE,\n NETWORK_STATUS,\n PEER_CONNECTION_STATE,\n OFFER,\n QUALITY_LEVELS,\n MAX_FRAMESIZES,\n METRICS_OPERATIONAL_MEASURES,\n IPV4_REGEX\n} from '../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\nconst {isBrowser} = BrowserDetection();\n\n/**\n * @export\n * @public\n */\nconst pc = {};\n\n/**\n * munges the bandwidth limit into the sdp\n * @param {String} sdpLines\n * @param {Number} index\n * @returns {String}\n */\nconst insertBandwidthLimit = (sdpLines, index) => {\n // eslint-disable-next-line no-warning-comments\n // TODO convert to sdp parser\n let limit;\n let periodicKeyFrame = '';\n\n if (sdpLines[index].search(AUDIO) !== -1) {\n limit = StaticConfig.meetings.bandwidth.audio;\n }\n else {\n limit = StaticConfig.meetings.bandwidth.video;\n periodicKeyFrame = SDP.PERIODIC_KEYFRAME;\n sdpLines.splice(index + 2, 0, periodicKeyFrame);\n }\n sdpLines.splice(index + 1, 0, `${SDP.B_LINE}:${limit}`);\n\n return sdpLines;\n};\n\n/**\n * needed for calliope max-fs\n * @param {String} sdp\n * @param {String} [level=QUALITY_LEVELS.HIGH] quality level for max-fs\n * @returns {String}\n */\nconst setMaxFs = (sdp, level = QUALITY_LEVELS.HIGH) => {\n if (!MAX_FRAMESIZES[level]) {\n throw new ParameterError(`setMaxFs: unable to set max framesize, value for level \"${level}\" is not defined`);\n }\n // eslint-disable-next-line no-warning-comments\n // TODO convert with sdp parser, no munging\n let replaceSdp = sdp;\n const maxFsLine = `${SDP.MAX_FS}${MAX_FRAMESIZES[level]}`;\n\n replaceSdp = replaceSdp.replace(/(\\na=fmtp:(\\d+).*level-asymmetry-allowed=1.*)/gi, `$1;${maxFsLine}`);\n\n return replaceSdp;\n};\n\n/**\n * checks that sdp has h264 codec in it\n * @param {String} sdp\n * @returns {boolean}\n */\nconst checkH264Support = (sdp) => {\n // eslint-disable-next-line no-warning-comments\n // TODO convert to sdp parser to read rtp.codec\n const videoPresent = sdp.match(/\\nm=video.*/g);\n const h264Present = sdp.match(/\\na=rtpmap:\\d+\\sH264.*/g);\n\n if (videoPresent) {\n return !!h264Present;\n }\n\n return true;\n};\n\n/**\n * validates the sdp, checks port, candidates, and ice info\n * @param {String} sdp\n * @returns {String}\n */\nconst isSdpInvalid = (sdp) => {\n const parsedSdp = sdpTransform.parse(sdp);\n\n for (const mediaLine of parsedSdp.media) {\n if (mediaLine.candidates && mediaLine.candidates.length === 0) {\n LoggerProxy.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Ice candadate never completed');\n\n return 'iceCandidate: Ice candadate never completed';\n }\n // Sometimes the candidates might be there but only IPV6 we need to makes sure we have IPV4\n const hostCandidate = mediaLine.candidates.filter((candidate) => !!(candidate.type === HOST && candidate.ip.match(IPV4_REGEX)));\n\n if (hostCandidate.length === 0) {\n LoggerProxy.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: no IPV4 candidate present');\n\n return 'iceCandidate: no IPV4 candidate present';\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 // TODO: we dont need timeout as we can check the api state and validate.\n const timeout = setTimeout(() => {\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);\n\n if (isSdpInvalid(peerConnection.sdp)) {\n setTimeout(() => {\n // peerconnection does gather ice candidate IP but in some cases due to firewall\n // or proxy the ice candidate does not get gathered so we need to wait and then retry\n // if still not valid then throw an error saying missing ice candidate\n // if ice candidate still not present after retry\n const invalidSdpPresent = isSdpInvalid(peerConnection.sdp);\n\n if (!invalidSdpPresent) {\n resolve(peerConnection);\n }\n else {\n LoggerProxy.logger.error('PeerConnectionManager:index#iceCandidate --> SDP not valid after waiting.');\n reject(new InvalidSdpError(invalidSdpPresent));\n }\n }, RETRY_TIMEOUT);\n }\n else {\n resolve(peerConnection);\n }\n }, ICE_TIMEOUT);\n\n peerConnection.onicecandidate = (evt) => {\n if (!evt.candidate && !peerConnection.sdp) {\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);\n\n if (evt.candidate === null && !isSdpInvalid(peerConnection.sdp)) {\n clearTimeout(timeout);\n resolve(peerConnection);\n }\n }\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 = (peerConnection, typeStr, remoteSdp, meetingId) => {\n LoggerProxy.logger.log(`PeerConnectionManager:index#setRemoteSessionDetails --> Setting the remote description type: ${typeStr}State: ${peerConnection.signalingState}`);\n const 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 return peerConnection.setRemoteDescription(\n new window.RTCSessionDescription({\n type: typeStr,\n sdp\n })\n )\n .then(() => {\n if (!peerConnection.remoteDescription) {\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 = METRICS_OPERATIONAL_MEASURES.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.sendOperationalMetric(metricName, data, metadata);\n\n return Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId,\n data: {\n canProceed: false,\n errors: [Metrics.generateErrorPayload(2001, true,\n error.name.MEDIA_ENGINE, 'missing remoteSdp')]\n }\n });\n });\n }\n\n return Promise.reject(new MediaError('PeerConnection in wrong state'));\n};\n\n/**\n * create offer with a valid paramater\n * @param {Object} peerConnection\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @param {string} meetingProperties.enableRtx\n * @param {string} meetingProperties.enableExtmap\n * @returns {RTCPeerConnection}\n */\npc.createOffer = (peerConnection, {\n meetingId,\n remoteQualityLevel,\n enableRtx,\n enableExtmap\n}) => {\n LoggerProxy.logger.log('PeerConnectionManager:index#createOffer --> creating a new offer');\n\n return peerConnection\n .createOffer()\n .then((description) => {\n // bug https://bugs.chromium.org/p/chromium/issues/detail?id=1020642\n // chrome currently generates RTX line irrespective of weither the server side supports it\n // we are removing apt as well because its associated with rtx line\n\n if (!enableRtx) {\n description.sdp = description.sdp.replace(/\\r\\na=rtpmap:\\d+ rtx\\/\\d+/g, '');\n description.sdp = description.sdp.replace(/\\r\\na=fmtp:\\d+ apt=\\d+/g, '');\n }\n\n return peerConnection.setLocalDescription(description);\n })\n .then(() => pc.iceCandidate(peerConnection, {remoteQualityLevel}))\n .then(() => {\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);\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.sendOperationalMetric(\n METRICS_OPERATIONAL_MEASURES.INVALID_ICE_CANDIDATE,\n {\n correlation_id: meetingId,\n code: error.code,\n reason: error.message\n }\n );\n }\n else {\n const metricName = METRICS_OPERATIONAL_MEASURES.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.sendOperationalMetric(metricName, data, metadata);\n }\n\n Metrics.postEvent({\n event: eventType.LOCAL_SDP_GENERATED,\n meetingId,\n data: {\n canProceed: false,\n errors: [\n Metrics.generateErrorPayload(2001, true,\n error.name.MEDIA_ENGINE)]\n }\n });\n pc.close(peerConnection);\n throw error;\n });\n};\n\n/**\n * rollBack local description in peerconnection\n * @param {Object} peerConnection\n * @returns {Promise.RTCPeerConnection}\n */\npc.rollBackLocalDescription = (peerConnection) => peerConnection\n .setLocalDescription(new RTCSessionDescription({type: SDP.ROLLBACK}))\n .then(() => peerConnection)\n .catch((err) => {\n LoggerProxy.logger.error(`Peer-connection-manager:index#setLocalDescription --> ${err} `);\n\n return Promise.error(err);\n });\n\n/**\n * @param {Object} params {\n * @param {Boolean} params.offerToReceiveAudio\n * @param {Boolean} params.offerToReceiveVideo\n * @param {string} params.offerSdp\n * @param {MediaStream} params.stream\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @returns {Promise.<Array>} [MediaSDP, ScreenSDP]\n */\npc.updatePeerConnection = (params, {meetingId, remoteQualityLevel}) => {\n LoggerProxy.logger.log(`PeerConnectionManager:index#updatePeerConnection --> updating the peerConnection with params: ${params}`);\n\n const {peerConnection, offerSdp} = params;\n\n return pc.createAnswer({\n peerConnection,\n offerSdp: offerSdp[0]\n }, {meetingId, remoteQualityLevel}).then((peerconnection) => {\n // The content slides should also be set when we are sending inactive\n pc.setContentSlides(peerconnection);\n\n return Promise.resolve([peerconnection.sdp]);\n });\n};\n\n/**\n * @param {Object} params\n * @param {Object} params.peerConnection\n * @param {Object} params.sdpConstraints\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @returns {RTCPeerConnection} peerConnection\n */\npc.createAnswer = (params, {meetingId, remoteQualityLevel}) => {\n const {peerConnection} = params;\n\n // TODO: Some times to many mercury event comes at the same time\n // Need to maintain state of peerconnection\n if (peerConnection.signalingState === SDP.HAVE_REMOTE_OFFER) {\n return Promise.resolve(peerConnection);\n }\n\n return pc.setRemoteSessionDetails(peerConnection, OFFER, params.offerSdp, meetingId)\n .then(() => peerConnection.createAnswer(params.sdpConstraints))\n .then((answer) =>\n\n peerConnection.setLocalDescription(answer))\n .then(() => pc.iceCandidate(peerConnection, {remoteQualityLevel}))\n .then(() => {\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = setMaxFs(peerConnection.sdp, remoteQualityLevel);\n 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.sendOperationalMetric(\n METRICS_OPERATIONAL_MEASURES.INVALID_ICE_CANDIDATE,\n {\n correlation_id: meetingId\n }\n );\n }\n else {\n const metricName = METRICS_OPERATIONAL_MEASURES.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.sendOperationalMetric(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.sendOperationalMetric(\n METRICS_OPERATIONAL_MEASURES.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 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"]}
|
|
@@ -689,7 +689,8 @@ var ReconnectionManager = /*#__PURE__*/function () {
|
|
|
689
689
|
return _media.default.attachMedia(this.meeting.mediaProperties, {
|
|
690
690
|
meetingId: this.meeting.id,
|
|
691
691
|
remoteQualityLevel: this.meeting.mediaProperties.remoteQualityLevel,
|
|
692
|
-
enableRtx: this.meeting.config.enableRtx
|
|
692
|
+
enableRtx: this.meeting.config.enableRtx,
|
|
693
|
+
enableExtmap: this.meeting.config.enableExtmap
|
|
693
694
|
}).then(function (peerConnection) {
|
|
694
695
|
return _this4.meeting.setRemoteStream(peerConnection);
|
|
695
696
|
}).then(function () {
|