@webex/plugin-meetings 2.37.0 → 2.37.1

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.
Files changed (308) hide show
  1. package/UPGRADING.md +9 -9
  2. package/browsers.js +19 -24
  3. package/dist/common/browser-detection.js +1 -20
  4. package/dist/common/browser-detection.js.map +1 -1
  5. package/dist/common/collection.js +5 -20
  6. package/dist/common/collection.js.map +1 -1
  7. package/dist/common/config.js +0 -7
  8. package/dist/common/config.js.map +1 -1
  9. package/dist/common/errors/captcha-error.js +5 -26
  10. package/dist/common/errors/captcha-error.js.map +1 -1
  11. package/dist/common/errors/intent-to-join.js +5 -26
  12. package/dist/common/errors/intent-to-join.js.map +1 -1
  13. package/dist/common/errors/join-meeting.js +6 -27
  14. package/dist/common/errors/join-meeting.js.map +1 -1
  15. package/dist/common/errors/media.js +5 -26
  16. package/dist/common/errors/media.js.map +1 -1
  17. package/dist/common/errors/parameter.js +5 -33
  18. package/dist/common/errors/parameter.js.map +1 -1
  19. package/dist/common/errors/password-error.js +5 -26
  20. package/dist/common/errors/password-error.js.map +1 -1
  21. package/dist/common/errors/permission.js +4 -25
  22. package/dist/common/errors/permission.js.map +1 -1
  23. package/dist/common/errors/reconnection-in-progress.js +0 -17
  24. package/dist/common/errors/reconnection-in-progress.js.map +1 -1
  25. package/dist/common/errors/reconnection.js +5 -26
  26. package/dist/common/errors/reconnection.js.map +1 -1
  27. package/dist/common/errors/stats.js +5 -26
  28. package/dist/common/errors/stats.js.map +1 -1
  29. package/dist/common/errors/webex-errors.js +7 -46
  30. package/dist/common/errors/webex-errors.js.map +1 -1
  31. package/dist/common/errors/webex-meetings-error.js +1 -24
  32. package/dist/common/errors/webex-meetings-error.js.map +1 -1
  33. package/dist/common/events/events-scope.js +0 -22
  34. package/dist/common/events/events-scope.js.map +1 -1
  35. package/dist/common/events/events.js +0 -23
  36. package/dist/common/events/events.js.map +1 -1
  37. package/dist/common/events/trigger-proxy.js +0 -12
  38. package/dist/common/events/trigger-proxy.js.map +1 -1
  39. package/dist/common/events/util.js +0 -15
  40. package/dist/common/events/util.js.map +1 -1
  41. package/dist/common/logs/logger-config.js +0 -4
  42. package/dist/common/logs/logger-config.js.map +1 -1
  43. package/dist/common/logs/logger-proxy.js +1 -8
  44. package/dist/common/logs/logger-proxy.js.map +1 -1
  45. package/dist/common/logs/request.js +35 -61
  46. package/dist/common/logs/request.js.map +1 -1
  47. package/dist/common/queue.js +4 -14
  48. package/dist/common/queue.js.map +1 -1
  49. package/dist/config.js +1 -5
  50. package/dist/config.js.map +1 -1
  51. package/dist/constants.js +46 -42
  52. package/dist/constants.js.map +1 -1
  53. package/dist/index.js +1 -17
  54. package/dist/index.js.map +1 -1
  55. package/dist/locus-info/controlsUtils.js +10 -28
  56. package/dist/locus-info/controlsUtils.js.map +1 -1
  57. package/dist/locus-info/embeddedAppsUtils.js +3 -26
  58. package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
  59. package/dist/locus-info/fullState.js +0 -15
  60. package/dist/locus-info/fullState.js.map +1 -1
  61. package/dist/locus-info/hostUtils.js +4 -12
  62. package/dist/locus-info/hostUtils.js.map +1 -1
  63. package/dist/locus-info/index.js +101 -193
  64. package/dist/locus-info/index.js.map +1 -1
  65. package/dist/locus-info/infoUtils.js +0 -37
  66. package/dist/locus-info/infoUtils.js.map +1 -1
  67. package/dist/locus-info/mediaSharesUtils.js +12 -38
  68. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  69. package/dist/locus-info/parser.js +87 -123
  70. package/dist/locus-info/parser.js.map +1 -1
  71. package/dist/locus-info/selfUtils.js +16 -81
  72. package/dist/locus-info/selfUtils.js.map +1 -1
  73. package/dist/media/index.js +74 -137
  74. package/dist/media/index.js.map +1 -1
  75. package/dist/media/properties.js +64 -110
  76. package/dist/media/properties.js.map +1 -1
  77. package/dist/media/util.js +3 -17
  78. package/dist/media/util.js.map +1 -1
  79. package/dist/mediaQualityMetrics/config.js +10 -12
  80. package/dist/mediaQualityMetrics/config.js.map +1 -1
  81. package/dist/meeting/effectsState.js +120 -192
  82. package/dist/meeting/effectsState.js.map +1 -1
  83. package/dist/meeting/in-meeting-actions.js +0 -13
  84. package/dist/meeting/in-meeting-actions.js.map +1 -1
  85. package/dist/meeting/index.js +812 -1487
  86. package/dist/meeting/index.js.map +1 -1
  87. package/dist/meeting/muteState.js +31 -78
  88. package/dist/meeting/muteState.js.map +1 -1
  89. package/dist/meeting/request.js +157 -227
  90. package/dist/meeting/request.js.map +1 -1
  91. package/dist/meeting/state.js +21 -31
  92. package/dist/meeting/state.js.map +1 -1
  93. package/dist/meeting/util.js +25 -169
  94. package/dist/meeting/util.js.map +1 -1
  95. package/dist/meeting-info/collection.js +3 -25
  96. package/dist/meeting-info/collection.js.map +1 -1
  97. package/dist/meeting-info/index.js +10 -33
  98. package/dist/meeting-info/index.js.map +1 -1
  99. package/dist/meeting-info/meeting-info-v2.js +179 -268
  100. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  101. package/dist/meeting-info/request.js +1 -16
  102. package/dist/meeting-info/request.js.map +1 -1
  103. package/dist/meeting-info/util.js +98 -183
  104. package/dist/meeting-info/util.js.map +1 -1
  105. package/dist/meeting-info/utilv2.js +137 -228
  106. package/dist/meeting-info/utilv2.js.map +1 -1
  107. package/dist/meetings/collection.js +3 -21
  108. package/dist/meetings/collection.js.map +1 -1
  109. package/dist/meetings/index.js +451 -570
  110. package/dist/meetings/index.js.map +1 -1
  111. package/dist/meetings/request.js +7 -30
  112. package/dist/meetings/request.js.map +1 -1
  113. package/dist/meetings/util.js +94 -148
  114. package/dist/meetings/util.js.map +1 -1
  115. package/dist/member/index.js +49 -89
  116. package/dist/member/index.js.map +1 -1
  117. package/dist/member/util.js +17 -68
  118. package/dist/member/util.js.map +1 -1
  119. package/dist/members/collection.js +2 -12
  120. package/dist/members/collection.js.map +1 -1
  121. package/dist/members/index.js +68 -184
  122. package/dist/members/index.js.map +1 -1
  123. package/dist/members/request.js +21 -56
  124. package/dist/members/request.js.map +1 -1
  125. package/dist/members/util.js +9 -38
  126. package/dist/members/util.js.map +1 -1
  127. package/dist/metrics/config.js +0 -2
  128. package/dist/metrics/config.js.map +1 -1
  129. package/dist/metrics/constants.js +1 -2
  130. package/dist/metrics/constants.js.map +1 -1
  131. package/dist/metrics/index.js +48 -136
  132. package/dist/metrics/index.js.map +1 -1
  133. package/dist/networkQualityMonitor/index.js +28 -57
  134. package/dist/networkQualityMonitor/index.js.map +1 -1
  135. package/dist/peer-connection-manager/index.js +60 -190
  136. package/dist/peer-connection-manager/index.js.map +1 -1
  137. package/dist/peer-connection-manager/util.js +10 -24
  138. package/dist/peer-connection-manager/util.js.map +1 -1
  139. package/dist/personal-meeting-room/index.js +10 -45
  140. package/dist/personal-meeting-room/index.js.map +1 -1
  141. package/dist/personal-meeting-room/request.js +2 -33
  142. package/dist/personal-meeting-room/request.js.map +1 -1
  143. package/dist/personal-meeting-room/util.js +0 -13
  144. package/dist/personal-meeting-room/util.js.map +1 -1
  145. package/dist/reachability/index.js +100 -166
  146. package/dist/reachability/index.js.map +1 -1
  147. package/dist/reachability/request.js +2 -18
  148. package/dist/reachability/request.js.map +1 -1
  149. package/dist/reactions/reactions.js +0 -2
  150. package/dist/reactions/reactions.js.map +1 -1
  151. package/dist/reactions/reactions.type.js +0 -5
  152. package/dist/reactions/reactions.type.js.map +1 -1
  153. package/dist/reconnection-manager/index.js +294 -468
  154. package/dist/reconnection-manager/index.js.map +1 -1
  155. package/dist/roap/collection.js +1 -12
  156. package/dist/roap/collection.js.map +1 -1
  157. package/dist/roap/handler.js +15 -85
  158. package/dist/roap/handler.js.map +1 -1
  159. package/dist/roap/index.js +42 -94
  160. package/dist/roap/index.js.map +1 -1
  161. package/dist/roap/request.js +81 -148
  162. package/dist/roap/request.js.map +1 -1
  163. package/dist/roap/state.js +2 -39
  164. package/dist/roap/state.js.map +1 -1
  165. package/dist/roap/turnDiscovery.js +8 -52
  166. package/dist/roap/turnDiscovery.js.map +1 -1
  167. package/dist/roap/util.js +0 -26
  168. package/dist/roap/util.js.map +1 -1
  169. package/dist/statsAnalyzer/global.js +0 -2
  170. package/dist/statsAnalyzer/global.js.map +1 -1
  171. package/dist/statsAnalyzer/index.js +68 -168
  172. package/dist/statsAnalyzer/index.js.map +1 -1
  173. package/dist/statsAnalyzer/mqaUtil.js +54 -53
  174. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  175. package/dist/transcription/index.js +13 -45
  176. package/dist/transcription/index.js.map +1 -1
  177. package/internal-README.md +7 -6
  178. package/package.json +17 -17
  179. package/src/common/browser-detection.ts +9 -6
  180. package/src/common/collection.ts +3 -1
  181. package/src/common/errors/captcha-error.ts +6 -6
  182. package/src/common/errors/intent-to-join.ts +6 -6
  183. package/src/common/errors/join-meeting.ts +12 -8
  184. package/src/common/errors/media.ts +6 -6
  185. package/src/common/errors/parameter.ts +9 -6
  186. package/src/common/errors/password-error.ts +6 -6
  187. package/src/common/errors/permission.ts +5 -5
  188. package/src/common/errors/reconnection.ts +6 -6
  189. package/src/common/errors/stats.ts +6 -6
  190. package/src/common/errors/webex-errors.ts +7 -5
  191. package/src/common/errors/webex-meetings-error.ts +1 -1
  192. package/src/common/events/events-scope.ts +5 -1
  193. package/src/common/events/events.ts +5 -1
  194. package/src/common/events/trigger-proxy.ts +8 -3
  195. package/src/common/events/util.ts +1 -2
  196. package/src/common/logs/logger-proxy.ts +21 -10
  197. package/src/common/logs/request.ts +11 -8
  198. package/src/config.ts +11 -11
  199. package/src/constants.ts +138 -119
  200. package/src/index.js +1 -1
  201. package/src/locus-info/controlsUtils.ts +34 -24
  202. package/src/locus-info/fullState.ts +15 -11
  203. package/src/locus-info/hostUtils.ts +4 -3
  204. package/src/locus-info/index.ts +25 -34
  205. package/src/locus-info/infoUtils.ts +12 -4
  206. package/src/locus-info/mediaSharesUtils.ts +4 -4
  207. package/src/locus-info/parser.ts +45 -68
  208. package/src/locus-info/selfUtils.ts +106 -57
  209. package/src/media/index.ts +118 -109
  210. package/src/media/properties.ts +26 -20
  211. package/src/media/util.ts +2 -2
  212. package/src/mediaQualityMetrics/config.ts +46 -46
  213. package/src/meeting/effectsState.ts +35 -35
  214. package/src/meeting/in-meeting-actions.ts +7 -3
  215. package/src/meeting/index.ts +1435 -1210
  216. package/src/meeting/muteState.ts +62 -31
  217. package/src/meeting/request.ts +160 -113
  218. package/src/meeting/state.ts +45 -30
  219. package/src/meeting/util.ts +131 -90
  220. package/src/meeting-info/collection.ts +2 -1
  221. package/src/meeting-info/index.ts +32 -30
  222. package/src/meeting-info/meeting-info-v2.ts +106 -108
  223. package/src/meeting-info/request.ts +9 -3
  224. package/src/meeting-info/util.ts +54 -46
  225. package/src/meeting-info/utilv2.ts +59 -53
  226. package/src/meetings/collection.ts +1 -1
  227. package/src/meetings/index.ts +513 -441
  228. package/src/meetings/request.ts +26 -24
  229. package/src/meetings/util.ts +26 -23
  230. package/src/member/index.ts +55 -49
  231. package/src/member/util.ts +26 -13
  232. package/src/members/collection.ts +0 -1
  233. package/src/members/index.ts +172 -121
  234. package/src/members/request.ts +46 -14
  235. package/src/members/util.ts +44 -42
  236. package/src/metrics/config.ts +254 -81
  237. package/src/metrics/constants.ts +0 -2
  238. package/src/metrics/index.ts +84 -71
  239. package/src/networkQualityMonitor/index.ts +20 -23
  240. package/src/peer-connection-manager/index.ts +321 -241
  241. package/src/peer-connection-manager/util.ts +4 -2
  242. package/src/personal-meeting-room/index.ts +12 -16
  243. package/src/personal-meeting-room/request.ts +10 -3
  244. package/src/personal-meeting-room/util.ts +3 -3
  245. package/src/reachability/index.ts +61 -59
  246. package/src/reachability/request.ts +36 -32
  247. package/src/reactions/reactions.ts +4 -4
  248. package/src/reactions/reactions.type.ts +2 -3
  249. package/src/reconnection-manager/index.ts +159 -98
  250. package/src/roap/collection.ts +2 -4
  251. package/src/roap/handler.ts +63 -32
  252. package/src/roap/index.ts +78 -58
  253. package/src/roap/request.ts +69 -54
  254. package/src/roap/state.ts +17 -11
  255. package/src/roap/turnDiscovery.ts +60 -31
  256. package/src/roap/util.ts +39 -31
  257. package/src/statsAnalyzer/global.ts +30 -33
  258. package/src/statsAnalyzer/index.ts +397 -169
  259. package/src/statsAnalyzer/mqaUtil.ts +178 -72
  260. package/src/transcription/index.ts +34 -32
  261. package/test/integration/spec/journey.js +666 -462
  262. package/test/integration/spec/space-meeting.js +318 -203
  263. package/test/integration/spec/transcription.js +6 -7
  264. package/test/unit/spec/common/browser-detection.js +9 -28
  265. package/test/unit/spec/fixture/locus.js +92 -90
  266. package/test/unit/spec/locus-info/controlsUtils.js +5 -5
  267. package/test/unit/spec/locus-info/embeddedAppsUtils.js +8 -6
  268. package/test/unit/spec/locus-info/index.js +1 -2
  269. package/test/unit/spec/locus-info/infoUtils.js +24 -31
  270. package/test/unit/spec/locus-info/lib/BasicSeqCmp.json +88 -430
  271. package/test/unit/spec/locus-info/lib/SeqCmp.json +513 -685
  272. package/test/unit/spec/locus-info/parser.js +3 -9
  273. package/test/unit/spec/locus-info/selfConstant.js +72 -103
  274. package/test/unit/spec/locus-info/selfUtils.js +21 -12
  275. package/test/unit/spec/meeting/effectsState.js +33 -45
  276. package/test/unit/spec/meeting/in-meeting-actions.ts +2 -3
  277. package/test/unit/spec/meeting/index.js +1141 -649
  278. package/test/unit/spec/meeting/muteState.js +42 -33
  279. package/test/unit/spec/meeting/request.js +56 -45
  280. package/test/unit/spec/meeting/utils.js +66 -49
  281. package/test/unit/spec/meeting-info/meetinginfov2.js +100 -73
  282. package/test/unit/spec/meeting-info/request.js +7 -9
  283. package/test/unit/spec/meeting-info/util.js +11 -12
  284. package/test/unit/spec/meeting-info/utilv2.js +110 -74
  285. package/test/unit/spec/meetings/collection.js +1 -1
  286. package/test/unit/spec/meetings/index.js +438 -257
  287. package/test/unit/spec/meetings/utils.js +14 -12
  288. package/test/unit/spec/member/index.js +0 -1
  289. package/test/unit/spec/member/util.js +5 -6
  290. package/test/unit/spec/members/index.js +84 -35
  291. package/test/unit/spec/members/request.js +29 -20
  292. package/test/unit/spec/members/utils.js +8 -5
  293. package/test/unit/spec/metrics/index.js +16 -21
  294. package/test/unit/spec/networkQualityMonitor/index.js +21 -15
  295. package/test/unit/spec/peerconnection-manager/index.js +88 -58
  296. package/test/unit/spec/peerconnection-manager/utils.js +5 -4
  297. package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +7 -8
  298. package/test/unit/spec/personal-meeting-room/personal-meeting-room.js +2 -7
  299. package/test/unit/spec/reachability/index.ts +9 -11
  300. package/test/unit/spec/reconnection-manager/index.js +14 -17
  301. package/test/unit/spec/roap/index.ts +18 -8
  302. package/test/unit/spec/roap/turnDiscovery.ts +22 -19
  303. package/test/unit/spec/roap/util.js +3 -3
  304. package/test/unit/spec/stats-analyzer/index.js +29 -24
  305. package/test/utils/cmr.js +44 -42
  306. package/test/utils/testUtils.js +83 -74
  307. package/test/utils/webex-config.js +18 -18
  308. package/test/utils/webex-test-users.js +53 -50
@@ -1 +1 @@
1
- {"version":3,"names":["BrowserDetection","isBrowser","pc","insertBandwidthLimit","sdpLines","index","limit","periodicKeyFrame","search","AUDIO","StaticConfig","meetings","bandwidth","audio","video","SDP","PERIODIC_KEYFRAME","splice","B_LINE","setRemoteVideoConstraints","sdp","level","QUALITY_LEVELS","HIGH","maxFs","REMOTE_VIDEO_CONSTRAINTS","MAX_FS","ParameterError","modifiedSdp","PeerConnectionUtils","adjustH264Profile","setStartBitrateOnRemoteSdp","startBitrate","replace","checkH264Support","videoPresent","match","h264Present","isSdpInvalid","parsedSdp","sdpTransform","parse","media","mediaLine","candidates","length","LoggerProxy","logger","error","BAD_MEDIA_PORTS","includes","port","icePwd","iceUfrag","limitBandwidth","offerSdp","split","CARRIAGE_RETURN","i","M_LINE","join","setContentSlides","screenPc","A_CONTENT_SLIDES","iceCandidate","peerConnection","remoteQualityLevel","resolve","reject","now","doneGatheringIceCandidate","miliseconds","Math","abs","localDescription","convertCLineToIpv4","invalidSdpPresent","InvalidSdpError","log","iceGatheringState","COMPLETE","onIceGatheringStateChange","GATHERING","onicecandidate","evt","candidate","type","protocol","address","onicecandidateerror","event","replaceTrack","track","senders","getSenders","forEach","sender","kind","err","addStream","stream","tracksPresent","find","getTracks","addTrack","setRemoteSessionDetails","typeStr","remoteSdp","meetingId","signalingState","Metrics","postEvent","eventType","REMOTE_SDP_RECEIVED","data","canProceed","errors","generateErrorPayload","name","MEDIA_ENGINE","HAVE_LOCAL_OFFER","STABLE","OFFER","enableExtmap","setRemoteDescription","window","RTCSessionDescription","then","catch","metricName","BEHAVIORAL_METRICS","PEERCONNECTION_FAILURE","correlation_id","reason","message","stack","metadata","sendBehavioralMetric","MediaError","createOffer","enableRtx","description","setLocalDescription","LOCAL_SDP_GENERATED","INVALID_ICE_CANDIDATE","code","close","rollBackLocalDescription","ROLLBACK","updatePeerConnection","params","createAnswer","peerconnection","HAVE_REMOTE_OFFER","sdpConstraints","answer","connectionState","PEER_CONNECTION_STATE","CLOSED","setPeerConnectionEvents","meeting","mediaProperties","connectionFailed","reconnectionManager","iceState","reconnect","networkDisconnect","ICE_END","uploadLogs","file","function","CONNECTION_FAILURE","correlationId","locus_id","locusId","oniceconnectionstatechange","info","iceConnectionState","ICE_STATE","CHECKING","ICE_START","COMPLETED","CONNECTED","CONNECTION_SUCCESS","setNetworkStatus","NETWORK_STATUS","iceReconnected","DISCONNECTED","waitForIceReconnect","FAILED","onconnectionstatechange","CONNECTION_STATE","NEW","CONNECTING"],"sources":["index.ts"],"sourcesContent":["// We need to figure out how to pass a webex logger instance to these util files\n\n/* globals RTCSessionDescription */\n\nimport window from 'global/window';\nimport sdpTransform from 'sdp-transform'; // https://github.com/clux/sdp-transform\n\nimport Metrics from '../metrics';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport StaticConfig from '../common/config';\nimport {\n COMPLETE,\n GATHERING,\n AUDIO,\n SDP,\n ICE_STATE,\n CONNECTION_STATE,\n NETWORK_STATUS,\n PEER_CONNECTION_STATE,\n OFFER,\n QUALITY_LEVELS,\n REMOTE_VIDEO_CONSTRAINTS\n} from '../constants';\nimport BEHAVIORAL_METRICS from '../metrics/constants';\nimport {error, eventType} from '../metrics/config';\nimport MediaError from '../common/errors/media';\nimport ParameterError from '../common/errors/parameter';\nimport {InvalidSdpError} from '../common/errors/webex-errors';\nimport BrowserDetection from '../common/browser-detection';\n\nimport PeerConnectionUtils from './util';\n\nconst {isBrowser} = BrowserDetection();\n\n/**\n * @export\n * @public\n */\nconst pc: any = {};\n\n/**\n * munges the bandwidth limit into the sdp\n * @param {String} sdpLines\n * @param {Number} index\n * @returns {String}\n */\nconst insertBandwidthLimit = (sdpLines: any, index: number) => {\n // eslint-disable-next-line no-warning-comments\n // TODO convert to sdp parser\n let limit;\n let periodicKeyFrame = '';\n\n if (sdpLines[index].search(AUDIO) !== -1) {\n limit = StaticConfig.meetings.bandwidth.audio;\n }\n else {\n limit = StaticConfig.meetings.bandwidth.video;\n periodicKeyFrame = SDP.PERIODIC_KEYFRAME;\n sdpLines.splice(index + 2, 0, periodicKeyFrame);\n }\n sdpLines.splice(index + 1, 0, `${SDP.B_LINE}:${limit}`);\n\n return sdpLines;\n};\n\n/**\n * needed for calliope max-fs\n * @param {String} sdp\n * @param {String} [level=QUALITY_LEVELS.HIGH] quality level for max-fs\n * @returns {String}\n */\nconst setRemoteVideoConstraints = (sdp: string, level: string = QUALITY_LEVELS.HIGH) => {\n const maxFs = REMOTE_VIDEO_CONSTRAINTS.MAX_FS[level];\n\n if (!maxFs) {\n throw new ParameterError(`setRemoteVideoConstraints: unable to set max framesize, value for level \"${level}\" is not defined`);\n }\n\n const modifiedSdp = PeerConnectionUtils.adjustH264Profile(sdp, maxFs);\n\n return modifiedSdp;\n};\n\n\nconst setStartBitrateOnRemoteSdp = (sdp) => {\n if (StaticConfig.meetings.bandwidth.startBitrate) {\n sdp = sdp.replace(/(\\na=fmtp:(\\d+).*profile-level-id=.*)/gi, `$1;x-google-start-bitrate=${StaticConfig.meetings.bandwidth.startBitrate}`);\n }\n\n return sdp;\n};\n\n/**\n * checks that sdp has h264 codec in it\n * @param {String} sdp\n * @returns {boolean}\n */\nconst checkH264Support = (sdp: string) => {\n // eslint-disable-next-line no-warning-comments\n // TODO convert to sdp parser to read rtp.codec\n const videoPresent = sdp.match(/\\nm=video.*/g);\n const h264Present = sdp.match(/\\na=rtpmap:\\d+\\sH264.*/g);\n\n if (videoPresent) {\n return !!h264Present;\n }\n\n return true;\n};\n\n/**\n * validates the sdp, checks port, candidates, and ice info\n * @param {String} sdp\n * @returns {String}\n */\nconst isSdpInvalid = (sdp: string) => {\n const parsedSdp = sdpTransform.parse(sdp);\n\n for (const mediaLine of parsedSdp.media) {\n if (!mediaLine.candidates || mediaLine.candidates?.length === 0) {\n LoggerProxy.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Ice candidate never completed');\n\n return 'iceCandidate: Ice gathering never completed';\n }\n\n if (SDP.BAD_MEDIA_PORTS.includes(mediaLine.port)) {\n LoggerProxy.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Found invalid port number for the ice candidate');\n\n return 'iceCandidate: Found invalid port number for the ice candidate';\n }\n if (!mediaLine.icePwd || !mediaLine.iceUfrag) {\n LoggerProxy.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: ice ufrag and password not found');\n\n return 'iceCandidate: ice ufrag and password not found';\n }\n }\n\n return '';\n};\n\n/**\n * munges the bandwidth into the sdp\n * @param {String} sdp\n * @returns {String}\n */\nconst limitBandwidth = (sdp: string) => {\n // TODO convert to sdp parser\n let offerSdp = sdp;\n let sdpLines = offerSdp.split(SDP.CARRIAGE_RETURN);\n\n for (let i = 0; i < sdpLines.length; i += 1) {\n if (sdpLines[i].search(SDP.M_LINE) !== -1) {\n sdpLines = insertBandwidthLimit(sdpLines, i);\n }\n }\n offerSdp = sdpLines.join(SDP.CARRIAGE_RETURN);\n\n return offerSdp;\n};\n\n/**\n * makes sure the screen pc sdp has content:slides for server\n * @param {RTCPeerConnection} screenPc\n * @returns {RTCPeerConnection}\n */\npc.setContentSlides = (screenPc: any) => {\n if (screenPc && screenPc.sdp) {\n screenPc.sdp += `${SDP.A_CONTENT_SLIDES}${SDP.CARRIAGE_RETURN}`;\n }\n\n return screenPc;\n};\n\n/**\n * handles ice trickling and establishes ICE connection onto peer connection object\n * @param {Object} peerConnection\n * @param {Object} options\n * @param {String} options.remoteQualityLevel\n * @returns {Promise.RTCPeerConnection}\n */\npc.iceCandidate = (\n peerConnection: any,\n {\n remoteQualityLevel,\n }: {\n remoteQualityLevel: string;\n }\n) =>\n new Promise<void>((resolve, reject) => {\n const now = Date.now();\n const doneGatheringIceCandidate = () => {\n // @ts-ignore\n const miliseconds = parseInt(Math.abs(Date.now() - now), 4);\n\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = PeerConnectionUtils.convertCLineToIpv4(peerConnection.sdp);\n peerConnection.sdp = setRemoteVideoConstraints(peerConnection.sdp, remoteQualityLevel);\n\n const invalidSdpPresent = isSdpInvalid(peerConnection.sdp);\n\n if (invalidSdpPresent) {\n LoggerProxy.logger.error('PeerConnectionManager:index#iceCandidate --> SDP not valid after waiting.');\n reject(new InvalidSdpError(invalidSdpPresent));\n }\n LoggerProxy.logger.log(`PeerConnectionManager:index#iceCandidate --> Time to gather ice candidate ${miliseconds} miliseconds`);\n\n\n resolve();\n };\n\n // If ice has already been gathered\n if (peerConnection.iceGatheringState === COMPLETE) {\n doneGatheringIceCandidate();\n }\n\n peerConnection.onIceGatheringStateChange = () => {\n if (peerConnection.iceGatheringState === COMPLETE) {\n // @ts-ignore\n doneGatheringIceCandidate(peerConnection);\n }\n if (peerConnection.iceGatheringState === GATHERING) {\n LoggerProxy.logger.log('PeerConnectionManager:index#onIceGatheringStateChange --> Ice state changed to gathering');\n }\n };\n\n peerConnection.onicecandidate = (evt) => {\n if (evt.candidate === null) {\n // @ts-ignore\n doneGatheringIceCandidate(peerConnection);\n }\n else {\n LoggerProxy.logger.log(`PeerConnectionManager:index#onicecandidate --> Candidate ${evt.candidate?.type} ${evt.candidate?.protocol} ${evt.candidate?.address}:${evt.candidate?.port}`);\n }\n };\n\n peerConnection.onicecandidateerror = (event) => {\n // we can often get ICE candidate errors (for example when failing to communicate with a TURN server)\n // they don't mean that the whole ICE connection will fail, so it's OK to ignore them\n LoggerProxy.logger.error('PeerConnectionManager:index#onicecandidateerror --> ignoring ice error:', event);\n };\n });\n\n/**\n * swapping tracks\n * @param {Object} peerConnection\n * @param {Object} track\n * @returns {undefined}\n */\npc.replaceTrack = (peerConnection: any, track: any) => {\n try {\n const senders = peerConnection.getSenders();\n\n if (senders.length > 0) {\n senders.forEach((sender) => {\n if (sender.track && sender.track.kind === track.kind) {\n sender.replaceTrack(track);\n }\n });\n }\n }\n catch (err) {\n LoggerProxy.logger.error(`PeerConnectionManager:index#replaceTrack --> Error replacing track, ${err}`);\n }\n};\n\n/**\n * adding streams to peerConnection\n * @param {Object} peerConnection\n * @param {Object} stream\n * @returns {undefined}\n */\npc.addStream = (peerConnection: any, stream: any) => {\n try {\n if (stream && !isBrowser('edge')) {\n const tracksPresent = peerConnection.getSenders && peerConnection.getSenders().find((sender) => sender.track != null);\n\n if (tracksPresent) {\n stream.getTracks().forEach((track) => {\n pc.replaceTrack(peerConnection, track);\n });\n\n return;\n }\n stream.getTracks().forEach((track) => {\n peerConnection.addTrack(track, stream);\n });\n // // TODO : may come back disable addTracks for chrome they are moving back to addStream\n // // https://bugs.chromium.org/p/chromium/issues/detail?id=764414\n // // https://bugs.chromium.org/p/chromium/issues/detail?id=738918#c7\n // peerConnection.addStream(stream);\n }\n else if (isBrowser('edge')) {\n peerConnection.addStream(stream);\n }\n }\n catch (err) {\n LoggerProxy.logger.error(`PeerConnectionManager:index#addStream --> Error adding stream, error: ${error}`);\n }\n};\n\n/**\n * setting the remote description\n * @param {Object} peerConnection\n * @param {String} typeStr\n * @param {String} remoteSdp\n * @param {String} meetingId\n * @returns {undefined}\n */\npc.setRemoteSessionDetails = (peerConnection: any, typeStr: string, remoteSdp: string, meetingId: string) => {\n LoggerProxy.logger.log(`PeerConnectionManager:index#setRemoteSessionDetails --> Setting the remote description type: ${typeStr}State: ${peerConnection.signalingState}`);\n let sdp = remoteSdp;\n\n // making sure that the remoteDescription is only set when there is a answer for offer\n // or there is a offer from the server\n\n if (!sdp) {\n Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId,\n data: {\n canProceed: false,\n errors: [Metrics.generateErrorPayload(2001, true,\n error.name.MEDIA_ENGINE, 'missing remoteSdp')]\n }\n });\n }\n if (peerConnection.signalingState === SDP.HAVE_LOCAL_OFFER || (peerConnection.signalingState === SDP.STABLE && typeStr === SDP.OFFER)) {\n sdp = setStartBitrateOnRemoteSdp(sdp);\n\n if (!peerConnection.enableExtmap) {\n sdp = sdp.replace(/\\na=extmap.*/g, '');\n }\n\n // remove any xtls candidates\n sdp = sdp.replace(/^a=candidate:.*xTLS.*\\r\\n/gim, '');\n\n return peerConnection.setRemoteDescription(\n new window.RTCSessionDescription({\n type: typeStr,\n sdp\n })\n )\n .then(() => {\n if (peerConnection.signalingState === SDP.STABLE) {\n Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId\n });\n }\n })\n .catch((error) => {\n LoggerProxy.logger.error(`Peer-connection-manager:index#setRemoteDescription --> ${error} missing remotesdp`);\n\n\n const metricName = BEHAVIORAL_METRICS.PEERCONNECTION_FAILURE;\n const data = {\n correlation_id: meetingId,\n reason: error.message,\n stack: error.stack\n };\n const metadata = {\n type: error.name\n };\n\n Metrics.sendBehavioralMetric(metricName, data, metadata);\n\n return Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId,\n data: {\n canProceed: false,\n errors: [Metrics.generateErrorPayload(2001, true,\n error.name.MEDIA_ENGINE, 'missing remoteSdp')]\n }\n });\n });\n }\n\n return Promise.reject(new MediaError('PeerConnection in wrong state'));\n};\n\n/**\n * Create offer with a valid parameter\n * @param {Object} peerConnection\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @param {string} meetingProperties.enableRtx\n * @param {string} meetingProperties.enableExtmap\n * @returns {RTCPeerConnection}\n */\npc.createOffer = (\n peerConnection: any,\n {\n meetingId,\n remoteQualityLevel,\n enableRtx,\n enableExtmap,\n }: {\n meetingId: string;\n remoteQualityLevel: string;\n enableRtx: string;\n enableExtmap: string;\n }\n) => {\n LoggerProxy.logger.log('PeerConnectionManager:index#createOffer --> creating a new offer');\n\n // saving the extMap State to use in setRemoteDescription\n\n peerConnection.enableExtmap = enableExtmap;\n\n return peerConnection\n .createOffer()\n .then((description) => {\n // bug https://bugs.chromium.org/p/chromium/issues/detail?id=1020642\n // chrome currently generates RTX line irrespective of whether the server side supports it\n // we are removing apt as well because its associated with rtx line\n\n if (!enableRtx) {\n description.sdp = description.sdp.replace(/\\r\\na=rtpmap:\\d+ rtx\\/\\d+/g, '');\n description.sdp = description.sdp.replace(/\\r\\na=fmtp:\\d+ apt=\\d+/g, '');\n }\n\n return peerConnection.setLocalDescription(description);\n })\n .then(() => pc.iceCandidate(peerConnection, {remoteQualityLevel}))\n .then(() => {\n if (!checkH264Support(peerConnection.sdp)) {\n throw new MediaError('openH264 is downloading please Wait. Upload logs if not working on second try');\n }\n\n if (!enableExtmap) {\n peerConnection.sdp = peerConnection.sdp.replace(/\\na=extmap.*/g, '');\n }\n\n pc.setContentSlides(peerConnection);\n\n Metrics.postEvent({\n event: eventType.LOCAL_SDP_GENERATED,\n meetingId\n });\n\n return peerConnection;\n })\n .catch((error) => {\n LoggerProxy.logger.error(`Peer-connection-manager:index#createOffer --> ${error}`);\n if (error instanceof InvalidSdpError) {\n Metrics.sendBehavioralMetric(\n BEHAVIORAL_METRICS.INVALID_ICE_CANDIDATE,\n {\n correlation_id: meetingId,\n code: error.code,\n reason: error.message\n }\n );\n }\n else {\n const metricName = BEHAVIORAL_METRICS.PEERCONNECTION_FAILURE;\n const data = {\n correlation_id: meetingId,\n reason: error.message,\n stack: error.stack\n };\n const metadata = {\n type: error.name\n };\n\n Metrics.sendBehavioralMetric(metricName, data, metadata);\n }\n\n Metrics.postEvent({\n event: eventType.LOCAL_SDP_GENERATED,\n meetingId,\n data: {\n canProceed: false,\n errors: [\n // @ts-ignore\n Metrics.generateErrorPayload(2001, true,\n error.name.MEDIA_ENGINE)]\n }\n });\n pc.close(peerConnection);\n throw error;\n });\n};\n\n/**\n * rollBack local description in peerconnection\n * @param {Object} peerConnection\n * @returns {Promise.RTCPeerConnection}\n */\npc.rollBackLocalDescription = (peerConnection: any) => peerConnection\n// @ts-ignore\n .setLocalDescription(new RTCSessionDescription({type: SDP.ROLLBACK}))\n .then(() => peerConnection)\n .catch((err) => {\n LoggerProxy.logger.error(`Peer-connection-manager:index#setLocalDescription --> ${err} `);\n\n // @ts-ignore\n return Promise.error(err);\n });\n\n/**\n * @param {Object} params {\n * @param {Boolean} params.offerToReceiveAudio\n * @param {Boolean} params.offerToReceiveVideo\n * @param {string} params.offerSdp\n * @param {MediaStream} params.stream\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @returns {Promise.<Array>} [MediaSDP, ScreenSDP]\n */\npc.updatePeerConnection = (\n params: {\n offerToReceiveAudio: boolean;\n offerToReceiveVideo: boolean;\n offerSdp: string;\n stream: MediaStream;\n peerConnection: any\n },\n {\n meetingId,\n remoteQualityLevel,\n }: {\n meetingId: string;\n remoteQualityLevel: string;\n }\n) => {\n LoggerProxy.logger.log(`PeerConnectionManager:index#updatePeerConnection --> updating the peerConnection with params: ${params}`);\n\n const {peerConnection, offerSdp} = params;\n\n return pc.createAnswer({\n peerConnection,\n offerSdp: offerSdp[0]\n }, {meetingId, remoteQualityLevel}).then((peerconnection) => {\n // The content slides should also be set when we are sending inactive\n pc.setContentSlides(peerconnection);\n\n return Promise.resolve([peerconnection.sdp]);\n });\n};\n\n/**\n * @param {Object} params\n * @param {Object} params.peerConnection\n * @param {Object} params.sdpConstraints\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @returns {RTCPeerConnection} peerConnection\n */\npc.createAnswer = (\n params: {\n peerConnection: any;\n sdpConstraints: object;\n offerSdp: any;\n },\n {\n meetingId,\n remoteQualityLevel,\n }: {\n meetingId: string;\n remoteQualityLevel: string;\n }\n) => {\n const {peerConnection} = params;\n\n // TODO: Some times to many mercury event comes at the same time\n // Need to maintain state of peerconnection\n if (peerConnection.signalingState === SDP.HAVE_REMOTE_OFFER) {\n return Promise.resolve(peerConnection);\n }\n\n return pc.setRemoteSessionDetails(peerConnection, OFFER, params.offerSdp, meetingId)\n .then(() => peerConnection.createAnswer(params.sdpConstraints))\n .then((answer) =>\n\n peerConnection.setLocalDescription(answer))\n .then(() => pc.iceCandidate(peerConnection, {remoteQualityLevel}))\n .then(() => {\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = PeerConnectionUtils.convertCLineToIpv4(peerConnection.sdp);\n peerConnection.sdp = setRemoteVideoConstraints(peerConnection.sdp, remoteQualityLevel);\n\n if (!checkH264Support(peerConnection.sdp)) {\n throw new MediaError('openH264 is downloading please Wait. Upload logs if not working on second try');\n }\n\n return peerConnection;\n })\n .catch((error) => {\n if (error instanceof InvalidSdpError) {\n Metrics.sendBehavioralMetric(\n BEHAVIORAL_METRICS.INVALID_ICE_CANDIDATE,\n {\n correlation_id: meetingId\n }\n );\n }\n else {\n const metricName = BEHAVIORAL_METRICS.PEERCONNECTION_FAILURE;\n const data = {\n correlation_id: meetingId,\n reason: error.message,\n stack: error.stack\n };\n const metadata = {\n type: error.name\n };\n\n Metrics.sendBehavioralMetric(metricName, data, metadata);\n }\n\n LoggerProxy.logger.error(`PeerConnectionManager:index#setRemoteSessionDetails --> Error creating remote session, error: ${error}`);\n });\n};\n\n/**\n * shut down the peer connection\n * @param {Object} peerConnection\n * @returns {undefined}\n */\npc.close = (peerConnection: any) => {\n // peerConnection.close() fails on firefox on network changes and gives a Dom exception\n // To avoid this we have added a try catch block.\n // Please refer to https://bugzilla.mozilla.org/show_bug.cgi?id=1274407 for more information\n LoggerProxy.logger.log('PeerConnectionManager:index#close --> pc: close() -> attempting to close the peer connection');\n\n if (peerConnection && peerConnection.connectionState === PEER_CONNECTION_STATE.CLOSED) {\n LoggerProxy.logger.log('PeerConnectionManager:index#close --> pc: close() -> connection already closed');\n\n return Promise.resolve();\n }\n LoggerProxy.logger.log('PeerConnectionManager:index#close --> pc: close() -> closing the mediaPeerConnection');\n\n return Promise.resolve()\n .then(() => {\n if (peerConnection && peerConnection.close) {\n peerConnection.close();\n }\n });\n};\n\n\npc.setPeerConnectionEvents = (meeting) => {\n // In case ICE fail\n const {peerConnection} = meeting.mediaProperties;\n\n const connectionFailed = () => {\n if (meeting.reconnectionManager.iceState.resolve) {\n // DISCONNECTED state triggers first then it goes to FAILED STATE\n // sometimes the failed state can happen before 10 seconds (Which is the timer for the reconnect for ice disconnect)\n meeting.reconnectionManager.iceState.resolve();\n }\n\n meeting.reconnect({networkDisconnect: true});\n Metrics.postEvent({\n event: eventType.ICE_END,\n meeting,\n data: {\n canProceed: false,\n errors: [\n // @ts-ignore\n Metrics.generateErrorPayload(\n 2004, false, error.name.MEDIA_ENGINE\n )]\n }\n });\n\n meeting.uploadLogs({\n file: 'peer-connection-manager/index',\n function: 'connectionFailed'\n });\n\n Metrics.sendBehavioralMetric(\n BEHAVIORAL_METRICS.CONNECTION_FAILURE,\n {\n correlation_id: meeting.correlationId,\n locus_id: meeting.locusId\n }\n );\n };\n\n peerConnection.oniceconnectionstatechange = () => {\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CHANGE.');\n switch (peerConnection.iceConnectionState) {\n case ICE_STATE.CHECKING:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CHECKING.');\n Metrics.postEvent({event: eventType.ICE_START, meeting});\n break;\n case ICE_STATE.COMPLETED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE COMPLETED.');\n break;\n case ICE_STATE.CONNECTED:\n // Ice connection state goes to connected when both client and server sends STUN packets and\n // Established connected between them. Firefox does not trigger COMPLETED and only trigger CONNECTED\n Metrics.postEvent({event: eventType.ICE_END, meeting});\n Metrics.sendBehavioralMetric(\n BEHAVIORAL_METRICS.CONNECTION_SUCCESS,\n {\n correlation_id: meeting.correlationId,\n locus_id: meeting.locusId\n }\n );\n meeting.setNetworkStatus(NETWORK_STATUS.CONNECTED);\n meeting.reconnectionManager.iceReconnected();\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CONNECTED.');\n break;\n case ICE_STATE.CLOSED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CLOSED.');\n break;\n case ICE_STATE.DISCONNECTED:\n meeting.setNetworkStatus(NETWORK_STATUS.DISCONNECTED);\n meeting.reconnectionManager.waitForIceReconnect()\n .catch(() => {\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE DISCONNECTED. Automatic Reconnection Timed Out.');\n\n connectionFailed();\n });\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE DISCONNECTED.');\n break;\n case ICE_STATE.FAILED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE FAILED.');\n // notify of ice failure\n // Ice failure is the only indicator currently for identifying the actual connection drop\n // Firefox takes sometime 10-15 seconds to go to failed state\n connectionFailed();\n break;\n default:\n break;\n }\n };\n\n peerConnection.onconnectionstatechange = () => {\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CHANGE.');\n switch (peerConnection.connectionState) {\n case CONNECTION_STATE.NEW:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE NEW.');\n break;\n case CONNECTION_STATE.CONNECTING:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CONNECTING.');\n break;\n case CONNECTION_STATE.CONNECTED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CONNECTED.');\n break;\n case CONNECTION_STATE.CLOSED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CLOSED.');\n break;\n case CONNECTION_STATE.DISCONNECTED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE DISCONNECTED.');\n break;\n case CONNECTION_STATE.FAILED:\n LoggerProxy.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE FAILED.');\n // Special case happens only on chrome where there is no ICE FAILED event\n // only CONNECTION FAILED event gets triggered\n\n connectionFailed();\n break;\n default:\n break;\n }\n };\n};\n\nexport default pc;\n"],"mappings":"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"}
1
+ {"version":3,"names":["BrowserDetection","isBrowser","pc","insertBandwidthLimit","sdpLines","index","limit","periodicKeyFrame","search","AUDIO","StaticConfig","meetings","bandwidth","audio","video","SDP","PERIODIC_KEYFRAME","splice","B_LINE","setRemoteVideoConstraints","sdp","level","QUALITY_LEVELS","HIGH","maxFs","REMOTE_VIDEO_CONSTRAINTS","MAX_FS","ParameterError","modifiedSdp","PeerConnectionUtils","adjustH264Profile","setStartBitrateOnRemoteSdp","startBitrate","replace","checkH264Support","videoPresent","match","h264Present","isSdpInvalid","parsedSdp","sdpTransform","parse","media","mediaLine","candidates","length","LoggerProxy","logger","error","BAD_MEDIA_PORTS","includes","port","icePwd","iceUfrag","limitBandwidth","offerSdp","split","CARRIAGE_RETURN","i","M_LINE","join","setContentSlides","screenPc","A_CONTENT_SLIDES","iceCandidate","peerConnection","remoteQualityLevel","resolve","reject","now","doneGatheringIceCandidate","miliseconds","Math","abs","localDescription","convertCLineToIpv4","invalidSdpPresent","InvalidSdpError","log","iceGatheringState","COMPLETE","onIceGatheringStateChange","GATHERING","onicecandidate","evt","candidate","type","protocol","address","onicecandidateerror","event","replaceTrack","track","senders","getSenders","forEach","sender","kind","err","addStream","stream","tracksPresent","find","getTracks","addTrack","setRemoteSessionDetails","typeStr","remoteSdp","meetingId","signalingState","Metrics","postEvent","eventType","REMOTE_SDP_RECEIVED","data","canProceed","errors","generateErrorPayload","name","MEDIA_ENGINE","HAVE_LOCAL_OFFER","STABLE","OFFER","enableExtmap","setRemoteDescription","window","RTCSessionDescription","then","catch","metricName","BEHAVIORAL_METRICS","PEERCONNECTION_FAILURE","correlation_id","reason","message","stack","metadata","sendBehavioralMetric","MediaError","createOffer","enableRtx","description","setLocalDescription","LOCAL_SDP_GENERATED","INVALID_ICE_CANDIDATE","code","close","rollBackLocalDescription","ROLLBACK","updatePeerConnection","params","createAnswer","peerconnection","HAVE_REMOTE_OFFER","sdpConstraints","answer","connectionState","PEER_CONNECTION_STATE","CLOSED","setPeerConnectionEvents","meeting","mediaProperties","connectionFailed","reconnectionManager","iceState","reconnect","networkDisconnect","ICE_END","uploadLogs","file","function","CONNECTION_FAILURE","correlationId","locus_id","locusId","oniceconnectionstatechange","info","iceConnectionState","ICE_STATE","CHECKING","ICE_START","COMPLETED","CONNECTED","CONNECTION_SUCCESS","setNetworkStatus","NETWORK_STATUS","iceReconnected","DISCONNECTED","waitForIceReconnect","FAILED","onconnectionstatechange","CONNECTION_STATE","NEW","CONNECTING"],"sources":["index.ts"],"sourcesContent":["// We need to figure out how to pass a webex logger instance to these util files\n\n/* globals RTCSessionDescription */\n\nimport window from 'global/window';\nimport sdpTransform from 'sdp-transform'; // https://github.com/clux/sdp-transform\n\nimport Metrics from '../metrics';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport StaticConfig from '../common/config';\nimport {\n COMPLETE,\n GATHERING,\n AUDIO,\n SDP,\n ICE_STATE,\n CONNECTION_STATE,\n NETWORK_STATUS,\n PEER_CONNECTION_STATE,\n OFFER,\n QUALITY_LEVELS,\n REMOTE_VIDEO_CONSTRAINTS,\n} from '../constants';\nimport BEHAVIORAL_METRICS from '../metrics/constants';\nimport {error, eventType} from '../metrics/config';\nimport MediaError from '../common/errors/media';\nimport ParameterError from '../common/errors/parameter';\nimport {InvalidSdpError} from '../common/errors/webex-errors';\nimport BrowserDetection from '../common/browser-detection';\n\nimport PeerConnectionUtils from './util';\n\nconst {isBrowser} = BrowserDetection();\n\n/**\n * @export\n * @public\n */\nconst pc: any = {};\n\n/**\n * munges the bandwidth limit into the sdp\n * @param {String} sdpLines\n * @param {Number} index\n * @returns {String}\n */\nconst insertBandwidthLimit = (sdpLines: any, index: number) => {\n // eslint-disable-next-line no-warning-comments\n // TODO convert to sdp parser\n let limit;\n let periodicKeyFrame = '';\n\n if (sdpLines[index].search(AUDIO) !== -1) {\n limit = StaticConfig.meetings.bandwidth.audio;\n } else {\n limit = StaticConfig.meetings.bandwidth.video;\n periodicKeyFrame = SDP.PERIODIC_KEYFRAME;\n sdpLines.splice(index + 2, 0, periodicKeyFrame);\n }\n sdpLines.splice(index + 1, 0, `${SDP.B_LINE}:${limit}`);\n\n return sdpLines;\n};\n\n/**\n * needed for calliope max-fs\n * @param {String} sdp\n * @param {String} [level=QUALITY_LEVELS.HIGH] quality level for max-fs\n * @returns {String}\n */\nconst setRemoteVideoConstraints = (sdp: string, level: string = QUALITY_LEVELS.HIGH) => {\n const maxFs = REMOTE_VIDEO_CONSTRAINTS.MAX_FS[level];\n\n if (!maxFs) {\n throw new ParameterError(\n `setRemoteVideoConstraints: unable to set max framesize, value for level \"${level}\" is not defined`\n );\n }\n\n const modifiedSdp = PeerConnectionUtils.adjustH264Profile(sdp, maxFs);\n\n return modifiedSdp;\n};\n\nconst setStartBitrateOnRemoteSdp = (sdp) => {\n if (StaticConfig.meetings.bandwidth.startBitrate) {\n sdp = sdp.replace(\n /(\\na=fmtp:(\\d+).*profile-level-id=.*)/gi,\n `$1;x-google-start-bitrate=${StaticConfig.meetings.bandwidth.startBitrate}`\n );\n }\n\n return sdp;\n};\n\n/**\n * checks that sdp has h264 codec in it\n * @param {String} sdp\n * @returns {boolean}\n */\nconst checkH264Support = (sdp: string) => {\n // eslint-disable-next-line no-warning-comments\n // TODO convert to sdp parser to read rtp.codec\n const videoPresent = sdp.match(/\\nm=video.*/g);\n const h264Present = sdp.match(/\\na=rtpmap:\\d+\\sH264.*/g);\n\n if (videoPresent) {\n return !!h264Present;\n }\n\n return true;\n};\n\n/**\n * validates the sdp, checks port, candidates, and ice info\n * @param {String} sdp\n * @returns {String}\n */\nconst isSdpInvalid = (sdp: string) => {\n const parsedSdp = sdpTransform.parse(sdp);\n\n for (const mediaLine of parsedSdp.media) {\n if (!mediaLine.candidates || mediaLine.candidates?.length === 0) {\n LoggerProxy.logger.error(\n 'PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Ice candidate never completed'\n );\n\n return 'iceCandidate: Ice gathering never completed';\n }\n\n if (SDP.BAD_MEDIA_PORTS.includes(mediaLine.port)) {\n LoggerProxy.logger.error(\n 'PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Found invalid port number for the ice candidate'\n );\n\n return 'iceCandidate: Found invalid port number for the ice candidate';\n }\n if (!mediaLine.icePwd || !mediaLine.iceUfrag) {\n LoggerProxy.logger.error(\n 'PeerConnectionManager:index#isSdpInvalid --> iceCandidate: ice ufrag and password not found'\n );\n\n return 'iceCandidate: ice ufrag and password not found';\n }\n }\n\n return '';\n};\n\n/**\n * munges the bandwidth into the sdp\n * @param {String} sdp\n * @returns {String}\n */\nconst limitBandwidth = (sdp: string) => {\n // TODO convert to sdp parser\n let offerSdp = sdp;\n let sdpLines = offerSdp.split(SDP.CARRIAGE_RETURN);\n\n for (let i = 0; i < sdpLines.length; i += 1) {\n if (sdpLines[i].search(SDP.M_LINE) !== -1) {\n sdpLines = insertBandwidthLimit(sdpLines, i);\n }\n }\n offerSdp = sdpLines.join(SDP.CARRIAGE_RETURN);\n\n return offerSdp;\n};\n\n/**\n * makes sure the screen pc sdp has content:slides for server\n * @param {RTCPeerConnection} screenPc\n * @returns {RTCPeerConnection}\n */\npc.setContentSlides = (screenPc: any) => {\n if (screenPc && screenPc.sdp) {\n screenPc.sdp += `${SDP.A_CONTENT_SLIDES}${SDP.CARRIAGE_RETURN}`;\n }\n\n return screenPc;\n};\n\n/**\n * handles ice trickling and establishes ICE connection onto peer connection object\n * @param {Object} peerConnection\n * @param {Object} options\n * @param {String} options.remoteQualityLevel\n * @returns {Promise.RTCPeerConnection}\n */\npc.iceCandidate = (\n peerConnection: any,\n {\n remoteQualityLevel,\n }: {\n remoteQualityLevel: string;\n }\n) =>\n new Promise<void>((resolve, reject) => {\n const now = Date.now();\n const doneGatheringIceCandidate = () => {\n // @ts-ignore\n const miliseconds = parseInt(Math.abs(Date.now() - now), 4);\n\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = PeerConnectionUtils.convertCLineToIpv4(peerConnection.sdp);\n peerConnection.sdp = setRemoteVideoConstraints(peerConnection.sdp, remoteQualityLevel);\n\n const invalidSdpPresent = isSdpInvalid(peerConnection.sdp);\n\n if (invalidSdpPresent) {\n LoggerProxy.logger.error(\n 'PeerConnectionManager:index#iceCandidate --> SDP not valid after waiting.'\n );\n reject(new InvalidSdpError(invalidSdpPresent));\n }\n LoggerProxy.logger.log(\n `PeerConnectionManager:index#iceCandidate --> Time to gather ice candidate ${miliseconds} miliseconds`\n );\n\n resolve();\n };\n\n // If ice has already been gathered\n if (peerConnection.iceGatheringState === COMPLETE) {\n doneGatheringIceCandidate();\n }\n\n peerConnection.onIceGatheringStateChange = () => {\n if (peerConnection.iceGatheringState === COMPLETE) {\n // @ts-ignore\n doneGatheringIceCandidate(peerConnection);\n }\n if (peerConnection.iceGatheringState === GATHERING) {\n LoggerProxy.logger.log(\n 'PeerConnectionManager:index#onIceGatheringStateChange --> Ice state changed to gathering'\n );\n }\n };\n\n peerConnection.onicecandidate = (evt) => {\n if (evt.candidate === null) {\n // @ts-ignore\n doneGatheringIceCandidate(peerConnection);\n } else {\n LoggerProxy.logger.log(\n `PeerConnectionManager:index#onicecandidate --> Candidate ${evt.candidate?.type} ${evt.candidate?.protocol} ${evt.candidate?.address}:${evt.candidate?.port}`\n );\n }\n };\n\n peerConnection.onicecandidateerror = (event) => {\n // we can often get ICE candidate errors (for example when failing to communicate with a TURN server)\n // they don't mean that the whole ICE connection will fail, so it's OK to ignore them\n LoggerProxy.logger.error(\n 'PeerConnectionManager:index#onicecandidateerror --> ignoring ice error:',\n event\n );\n };\n });\n\n/**\n * swapping tracks\n * @param {Object} peerConnection\n * @param {Object} track\n * @returns {undefined}\n */\npc.replaceTrack = (peerConnection: any, track: any) => {\n try {\n const senders = peerConnection.getSenders();\n\n if (senders.length > 0) {\n senders.forEach((sender) => {\n if (sender.track && sender.track.kind === track.kind) {\n sender.replaceTrack(track);\n }\n });\n }\n } catch (err) {\n LoggerProxy.logger.error(\n `PeerConnectionManager:index#replaceTrack --> Error replacing track, ${err}`\n );\n }\n};\n\n/**\n * adding streams to peerConnection\n * @param {Object} peerConnection\n * @param {Object} stream\n * @returns {undefined}\n */\npc.addStream = (peerConnection: any, stream: any) => {\n try {\n if (stream && !isBrowser('edge')) {\n const tracksPresent =\n peerConnection.getSenders &&\n 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 } else if (isBrowser('edge')) {\n peerConnection.addStream(stream);\n }\n } catch (err) {\n LoggerProxy.logger.error(\n `PeerConnectionManager:index#addStream --> Error adding stream, error: ${error}`\n );\n }\n};\n\n/**\n * setting the remote description\n * @param {Object} peerConnection\n * @param {String} typeStr\n * @param {String} remoteSdp\n * @param {String} meetingId\n * @returns {undefined}\n */\npc.setRemoteSessionDetails = (\n peerConnection: any,\n typeStr: string,\n remoteSdp: string,\n meetingId: string\n) => {\n LoggerProxy.logger.log(\n `PeerConnectionManager:index#setRemoteSessionDetails --> Setting the remote description type: ${typeStr}State: ${peerConnection.signalingState}`\n );\n let sdp = remoteSdp;\n\n // making sure that the remoteDescription is only set when there is a answer for offer\n // or there is a offer from the server\n\n if (!sdp) {\n Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId,\n data: {\n canProceed: false,\n errors: [\n Metrics.generateErrorPayload(2001, true, error.name.MEDIA_ENGINE, 'missing remoteSdp'),\n ],\n },\n });\n }\n if (\n peerConnection.signalingState === SDP.HAVE_LOCAL_OFFER ||\n (peerConnection.signalingState === SDP.STABLE && typeStr === SDP.OFFER)\n ) {\n sdp = setStartBitrateOnRemoteSdp(sdp);\n\n if (!peerConnection.enableExtmap) {\n sdp = sdp.replace(/\\na=extmap.*/g, '');\n }\n\n // remove any xtls candidates\n sdp = sdp.replace(/^a=candidate:.*xTLS.*\\r\\n/gim, '');\n\n return (\n peerConnection\n .setRemoteDescription(\n new window.RTCSessionDescription({\n type: typeStr,\n sdp,\n })\n )\n .then(() => {\n if (peerConnection.signalingState === SDP.STABLE) {\n Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId,\n });\n }\n })\n // eslint-disable-next-line @typescript-eslint/no-shadow\n .catch((error) => {\n LoggerProxy.logger.error(\n `Peer-connection-manager:index#setRemoteDescription --> ${error} missing remotesdp`\n );\n\n const metricName = BEHAVIORAL_METRICS.PEERCONNECTION_FAILURE;\n const data = {\n correlation_id: meetingId,\n reason: error.message,\n stack: error.stack,\n };\n const metadata = {\n type: error.name,\n };\n\n Metrics.sendBehavioralMetric(metricName, data, metadata);\n\n return Metrics.postEvent({\n event: eventType.REMOTE_SDP_RECEIVED,\n meetingId,\n data: {\n canProceed: false,\n errors: [\n Metrics.generateErrorPayload(\n 2001,\n true,\n error.name.MEDIA_ENGINE,\n 'missing remoteSdp'\n ),\n ],\n },\n });\n })\n );\n }\n\n return Promise.reject(new MediaError('PeerConnection in wrong state'));\n};\n\n/**\n * Create offer with a valid parameter\n * @param {Object} peerConnection\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @param {string} meetingProperties.enableRtx\n * @param {string} meetingProperties.enableExtmap\n * @returns {RTCPeerConnection}\n */\npc.createOffer = (\n peerConnection: any,\n {\n meetingId,\n remoteQualityLevel,\n enableRtx,\n enableExtmap,\n }: {\n meetingId: string;\n remoteQualityLevel: string;\n enableRtx: string;\n enableExtmap: string;\n }\n) => {\n LoggerProxy.logger.log('PeerConnectionManager:index#createOffer --> creating a new offer');\n\n // saving the extMap State to use in setRemoteDescription\n\n peerConnection.enableExtmap = enableExtmap;\n\n return (\n peerConnection\n .createOffer()\n .then((description) => {\n // bug https://bugs.chromium.org/p/chromium/issues/detail?id=1020642\n // chrome currently generates RTX line irrespective of whether the server side supports it\n // we are removing apt as well because its associated with rtx line\n\n if (!enableRtx) {\n description.sdp = description.sdp.replace(/\\r\\na=rtpmap:\\d+ rtx\\/\\d+/g, '');\n description.sdp = description.sdp.replace(/\\r\\na=fmtp:\\d+ apt=\\d+/g, '');\n }\n\n return peerConnection.setLocalDescription(description);\n })\n .then(() => pc.iceCandidate(peerConnection, {remoteQualityLevel}))\n .then(() => {\n if (!checkH264Support(peerConnection.sdp)) {\n throw new MediaError(\n 'openH264 is downloading please Wait. Upload logs if not working on second try'\n );\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 // eslint-disable-next-line @typescript-eslint/no-shadow\n .catch((error) => {\n LoggerProxy.logger.error(`Peer-connection-manager:index#createOffer --> ${error}`);\n if (error instanceof InvalidSdpError) {\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.INVALID_ICE_CANDIDATE, {\n correlation_id: meetingId,\n code: error.code,\n reason: error.message,\n });\n } else {\n const metricName = BEHAVIORAL_METRICS.PEERCONNECTION_FAILURE;\n const data = {\n correlation_id: meetingId,\n reason: error.message,\n stack: error.stack,\n };\n const metadata = {\n type: error.name,\n };\n\n Metrics.sendBehavioralMetric(metricName, data, metadata);\n }\n\n Metrics.postEvent({\n event: eventType.LOCAL_SDP_GENERATED,\n meetingId,\n data: {\n canProceed: false,\n errors: [\n // @ts-ignore\n Metrics.generateErrorPayload(2001, true, error.name.MEDIA_ENGINE),\n ],\n },\n });\n pc.close(peerConnection);\n throw error;\n })\n );\n};\n\n/**\n * rollBack local description in peerconnection\n * @param {Object} peerConnection\n * @returns {Promise.RTCPeerConnection}\n */\npc.rollBackLocalDescription = (peerConnection: any) =>\n peerConnection\n // @ts-ignore\n .setLocalDescription(new RTCSessionDescription({type: SDP.ROLLBACK}))\n .then(() => peerConnection)\n .catch((err) => {\n LoggerProxy.logger.error(`Peer-connection-manager:index#setLocalDescription --> ${err} `);\n\n // @ts-ignore\n return Promise.error(err);\n });\n\n/**\n * @param {Object} params {\n * @param {Boolean} params.offerToReceiveAudio\n * @param {Boolean} params.offerToReceiveVideo\n * @param {string} params.offerSdp\n * @param {MediaStream} params.stream\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @returns {Promise.<Array>} [MediaSDP, ScreenSDP]\n */\npc.updatePeerConnection = (\n params: {\n offerToReceiveAudio: boolean;\n offerToReceiveVideo: boolean;\n offerSdp: string;\n stream: MediaStream;\n peerConnection: any;\n },\n {\n meetingId,\n remoteQualityLevel,\n }: {\n meetingId: string;\n remoteQualityLevel: string;\n }\n) => {\n LoggerProxy.logger.log(\n `PeerConnectionManager:index#updatePeerConnection --> updating the peerConnection with params: ${params}`\n );\n\n const {peerConnection, offerSdp} = params;\n\n return pc\n .createAnswer(\n {\n peerConnection,\n offerSdp: offerSdp[0],\n },\n {meetingId, remoteQualityLevel}\n )\n .then((peerconnection) => {\n // The content slides should also be set when we are sending inactive\n pc.setContentSlides(peerconnection);\n\n return Promise.resolve([peerconnection.sdp]);\n });\n};\n\n/**\n * @param {Object} params\n * @param {Object} params.peerConnection\n * @param {Object} params.sdpConstraints\n * @param {Object} meetingProperties\n * @param {string} meetingProperties.meetingId\n * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH\n * @returns {RTCPeerConnection} peerConnection\n */\npc.createAnswer = (\n params: {\n peerConnection: any;\n sdpConstraints: object;\n offerSdp: any;\n },\n {\n meetingId,\n remoteQualityLevel,\n }: {\n meetingId: string;\n remoteQualityLevel: string;\n }\n) => {\n const {peerConnection} = params;\n\n // TODO: Some times to many mercury event comes at the same time\n // Need to maintain state of peerconnection\n if (peerConnection.signalingState === SDP.HAVE_REMOTE_OFFER) {\n return Promise.resolve(peerConnection);\n }\n\n return (\n pc\n .setRemoteSessionDetails(peerConnection, OFFER, params.offerSdp, meetingId)\n .then(() => peerConnection.createAnswer(params.sdpConstraints))\n .then((answer) => peerConnection.setLocalDescription(answer))\n .then(() => pc.iceCandidate(peerConnection, {remoteQualityLevel}))\n .then(() => {\n peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);\n peerConnection.sdp = PeerConnectionUtils.convertCLineToIpv4(peerConnection.sdp);\n peerConnection.sdp = setRemoteVideoConstraints(peerConnection.sdp, remoteQualityLevel);\n\n if (!checkH264Support(peerConnection.sdp)) {\n throw new MediaError(\n 'openH264 is downloading please Wait. Upload logs if not working on second try'\n );\n }\n\n return peerConnection;\n })\n // eslint-disable-next-line @typescript-eslint/no-shadow\n .catch((error) => {\n if (error instanceof InvalidSdpError) {\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.INVALID_ICE_CANDIDATE, {\n correlation_id: meetingId,\n });\n } else {\n const metricName = BEHAVIORAL_METRICS.PEERCONNECTION_FAILURE;\n const data = {\n correlation_id: meetingId,\n reason: error.message,\n stack: error.stack,\n };\n const metadata = {\n type: error.name,\n };\n\n Metrics.sendBehavioralMetric(metricName, data, metadata);\n }\n\n LoggerProxy.logger.error(\n `PeerConnectionManager:index#setRemoteSessionDetails --> Error creating remote session, error: ${error}`\n );\n })\n );\n};\n\n/**\n * shut down the peer connection\n * @param {Object} peerConnection\n * @returns {undefined}\n */\npc.close = (peerConnection: any) => {\n // peerConnection.close() fails on firefox on network changes and gives a Dom exception\n // To avoid this we have added a try catch block.\n // Please refer to https://bugzilla.mozilla.org/show_bug.cgi?id=1274407 for more information\n LoggerProxy.logger.log(\n 'PeerConnectionManager:index#close --> pc: close() -> attempting to close the peer connection'\n );\n\n if (peerConnection && peerConnection.connectionState === PEER_CONNECTION_STATE.CLOSED) {\n LoggerProxy.logger.log(\n 'PeerConnectionManager:index#close --> pc: close() -> connection already closed'\n );\n\n return Promise.resolve();\n }\n LoggerProxy.logger.log(\n 'PeerConnectionManager:index#close --> pc: close() -> closing the mediaPeerConnection'\n );\n\n return Promise.resolve().then(() => {\n if (peerConnection && peerConnection.close) {\n peerConnection.close();\n }\n });\n};\n\npc.setPeerConnectionEvents = (meeting) => {\n // In case ICE fail\n const {peerConnection} = meeting.mediaProperties;\n\n const connectionFailed = () => {\n if (meeting.reconnectionManager.iceState.resolve) {\n // DISCONNECTED state triggers first then it goes to FAILED STATE\n // sometimes the failed state can happen before 10 seconds (Which is the timer for the reconnect for ice disconnect)\n meeting.reconnectionManager.iceState.resolve();\n }\n\n meeting.reconnect({networkDisconnect: true});\n Metrics.postEvent({\n event: eventType.ICE_END,\n meeting,\n data: {\n canProceed: false,\n errors: [\n // @ts-ignore\n Metrics.generateErrorPayload(2004, false, error.name.MEDIA_ENGINE),\n ],\n },\n });\n\n meeting.uploadLogs({\n file: 'peer-connection-manager/index',\n function: 'connectionFailed',\n });\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.CONNECTION_FAILURE, {\n correlation_id: meeting.correlationId,\n locus_id: meeting.locusId,\n });\n };\n\n peerConnection.oniceconnectionstatechange = () => {\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CHANGE.'\n );\n switch (peerConnection.iceConnectionState) {\n case ICE_STATE.CHECKING:\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CHECKING.'\n );\n Metrics.postEvent({event: eventType.ICE_START, meeting});\n break;\n case ICE_STATE.COMPLETED:\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE COMPLETED.'\n );\n break;\n case ICE_STATE.CONNECTED:\n // Ice connection state goes to connected when both client and server sends STUN packets and\n // Established connected between them. Firefox does not trigger COMPLETED and only trigger CONNECTED\n Metrics.postEvent({event: eventType.ICE_END, meeting});\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.CONNECTION_SUCCESS, {\n correlation_id: meeting.correlationId,\n locus_id: meeting.locusId,\n });\n meeting.setNetworkStatus(NETWORK_STATUS.CONNECTED);\n meeting.reconnectionManager.iceReconnected();\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CONNECTED.'\n );\n break;\n case ICE_STATE.CLOSED:\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CLOSED.'\n );\n break;\n case ICE_STATE.DISCONNECTED:\n meeting.setNetworkStatus(NETWORK_STATUS.DISCONNECTED);\n meeting.reconnectionManager.waitForIceReconnect().catch(() => {\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE DISCONNECTED. Automatic Reconnection Timed Out.'\n );\n\n connectionFailed();\n });\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE DISCONNECTED.'\n );\n break;\n case ICE_STATE.FAILED:\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE FAILED.'\n );\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(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CHANGE.'\n );\n switch (peerConnection.connectionState) {\n case CONNECTION_STATE.NEW:\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE NEW.'\n );\n break;\n case CONNECTION_STATE.CONNECTING:\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CONNECTING.'\n );\n break;\n case CONNECTION_STATE.CONNECTED:\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CONNECTED.'\n );\n break;\n case CONNECTION_STATE.CLOSED:\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CLOSED.'\n );\n break;\n case CONNECTION_STATE.DISCONNECTED:\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE DISCONNECTED.'\n );\n break;\n case CONNECTION_STATE.FAILED:\n LoggerProxy.logger.info(\n 'PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE FAILED.'\n );\n // Special case happens only on chrome where there is no ICE FAILED event\n // only CONNECTION FAILED event gets triggered\n\n connectionFailed();\n break;\n default:\n break;\n }\n };\n};\n\nexport default pc;\n"],"mappings":"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"}
@@ -1,23 +1,17 @@
1
1
  "use strict";
2
2
 
3
3
  var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
4
-
5
4
  var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
6
-
7
5
  _Object$defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
-
11
8
  exports.default = void 0;
12
-
13
9
  var _parseInt2 = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/parse-int"));
14
-
15
10
  var _keys = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/keys"));
16
-
17
11
  var _tsSdp = require("@webex/ts-sdp");
12
+ var PeerConnectionUtils = {};
18
13
 
19
- var PeerConnectionUtils = {}; // max-fs values for all H264 profile levels
20
-
14
+ // max-fs values for all H264 profile levels
21
15
  var maxFsForProfileLevel = {
22
16
  10: 99,
23
17
  11: 396,
@@ -40,28 +34,28 @@ var maxFsForProfileLevel = {
40
34
  62: 139264
41
35
  };
42
36
  var framesPerSecond = 30;
37
+
43
38
  /**
44
39
  * Convert C line to IPv4
45
40
  * @param {string} sdp
46
41
  * @returns {string}
47
42
  */
48
-
49
43
  PeerConnectionUtils.convertCLineToIpv4 = function (sdp) {
50
- var replaceSdp = sdp; // TODO: remove this once linus supports Ipv6 c line.currently linus rejects SDP with c line having ipv6 candidates we are
44
+ var replaceSdp = sdp;
45
+
46
+ // TODO: remove this once linus supports Ipv6 c line.currently linus rejects SDP with c line having ipv6 candidates we are
51
47
  // mocking ipv6 to ipv4 candidates
52
48
  // https://jira-eng-gpk2.cisco.com/jira/browse/SPARK-299232
53
-
54
49
  replaceSdp = replaceSdp.replace(/c=IN IP6 .*/gi, 'c=IN IP4 0.0.0.0');
55
50
  return replaceSdp;
56
51
  };
52
+
57
53
  /**
58
54
  * estimate profile levels for max-fs & max-mbps values
59
55
  * @param {string} sdp
60
56
  * @param {number} maxFsValue
61
57
  * @returns {string}
62
58
  */
63
-
64
-
65
59
  PeerConnectionUtils.adjustH264Profile = function (sdp, maxFsValue) {
66
60
  // converting with ts-sdp parser, no munging
67
61
  var parsedSdp = (0, _tsSdp.parse)(sdp);
@@ -69,47 +63,40 @@ PeerConnectionUtils.adjustH264Profile = function (sdp, maxFsValue) {
69
63
  if (media.type === 'video') {
70
64
  media.codecs.forEach(function (codec) {
71
65
  var _codec$name;
72
-
73
66
  if (((_codec$name = codec.name) === null || _codec$name === void 0 ? void 0 : _codec$name.toUpperCase()) === 'H264') {
74
67
  // there should really be just 1 fmtp line, but just in case, we process all of them
75
68
  codec.fmtParams = codec.fmtParams.map(function (fmtp) {
76
69
  var parsedRegex = fmtp.match(/(.*)profile-level-id=(\w{4})(\w{2})(.*)/);
77
-
78
70
  if (parsedRegex && parsedRegex.length === 5) {
79
71
  var stuffBeforeProfileLevelId = parsedRegex[1];
80
72
  var profile = parsedRegex[2].toLowerCase();
81
73
  var levelId = (0, _parseInt2.default)(parsedRegex[3], 16);
82
74
  var stuffAfterProfileLevelId = parsedRegex[4];
83
-
84
75
  if (!maxFsForProfileLevel[levelId]) {
85
76
  throw new Error("found unsupported h264 profile level id value in the SDP: ".concat(levelId));
86
77
  }
87
-
88
78
  if (maxFsForProfileLevel[levelId] === maxFsValue) {
89
79
  // profile level already matches our desired max-fs value, so we don't need to do anything
90
80
  return fmtp;
91
81
  }
92
-
93
82
  if (maxFsForProfileLevel[levelId] < maxFsValue) {
94
83
  // profile level has too low max-fs, so we need to override it (this is upgrading)
95
84
  return "".concat(fmtp, ";max-fs=").concat(maxFsValue, ";max-mbps=").concat(maxFsValue * framesPerSecond);
96
- } // profile level has too high max-fs value, so we need to use a lower level
97
- // find highest level that has the matching maxFs
85
+ }
98
86
 
87
+ // profile level has too high max-fs value, so we need to use a lower level
99
88
 
89
+ // find highest level that has the matching maxFs
100
90
  var newLevelId = (0, _keys.default)(maxFsForProfileLevel).reverse().find(function (key) {
101
91
  return maxFsForProfileLevel[key] === maxFsValue;
102
92
  });
103
-
104
93
  if (newLevelId) {
105
94
  // Object.keys returns keys as strings, so we need to parse it to an int again and then convert to hex
106
95
  var newLevelIdHex = (0, _parseInt2.default)(newLevelId, 10).toString(16);
107
96
  return "".concat(stuffBeforeProfileLevelId, "profile-level-id=").concat(profile).concat(newLevelIdHex, ";max-mbps=").concat(maxFsValue * framesPerSecond).concat(stuffAfterProfileLevelId);
108
97
  }
109
-
110
98
  throw new Error("unsupported maxFsValue: ".concat(maxFsValue));
111
99
  }
112
-
113
100
  return fmtp;
114
101
  });
115
102
  }
@@ -118,7 +105,6 @@ PeerConnectionUtils.adjustH264Profile = function (sdp, maxFsValue) {
118
105
  });
119
106
  return parsedSdp.toString();
120
107
  };
121
-
122
108
  var _default = PeerConnectionUtils;
123
109
  exports.default = _default;
124
110
  //# sourceMappingURL=util.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["PeerConnectionUtils","maxFsForProfileLevel","framesPerSecond","convertCLineToIpv4","sdp","replaceSdp","replace","adjustH264Profile","maxFsValue","parsedSdp","parse","avMedia","forEach","media","type","codecs","codec","name","toUpperCase","fmtParams","map","fmtp","parsedRegex","match","length","stuffBeforeProfileLevelId","profile","toLowerCase","levelId","stuffAfterProfileLevelId","Error","newLevelId","reverse","find","key","newLevelIdHex","toString"],"sources":["util.ts"],"sourcesContent":["import { parse } from '@webex/ts-sdp';\n\ninterface IPeerConnectionUtils {\n convertCLineToIpv4: (sdp: string) => string;\n adjustH264Profile: (sdp: string, maxFsValue: number) => string;\n}\n\nconst PeerConnectionUtils = {} as IPeerConnectionUtils;\n\n// max-fs values for all H264 profile levels\nconst maxFsForProfileLevel = {\n 10: 99,\n 11: 396,\n 12: 396,\n 13: 396,\n 20: 396,\n 21: 792,\n 22: 1620,\n 30: 1620,\n 31: 3600,\n 32: 5120,\n 40: 8192,\n 41: 8192,\n 42: 8704,\n 50: 22080,\n 51: 36864,\n 52: 36864,\n 60: 139264,\n 61: 139264,\n 62: 139264,\n};\n\nconst framesPerSecond = 30;\n\n/**\n * Convert C line to IPv4\n * @param {string} sdp\n * @returns {string}\n */\nPeerConnectionUtils.convertCLineToIpv4 = (sdp: string) => {\n let replaceSdp = sdp;\n\n // TODO: remove this once linus supports Ipv6 c line.currently linus rejects SDP with c line having ipv6 candidates we are\n // mocking ipv6 to ipv4 candidates\n // https://jira-eng-gpk2.cisco.com/jira/browse/SPARK-299232\n replaceSdp = replaceSdp.replace(/c=IN IP6 .*/gi, 'c=IN IP4 0.0.0.0');\n\n return replaceSdp;\n};\n\n/**\n * estimate profile levels for max-fs & max-mbps values\n * @param {string} sdp\n * @param {number} maxFsValue\n * @returns {string}\n */\nPeerConnectionUtils.adjustH264Profile = (sdp: string, maxFsValue: number) => {\n // converting with ts-sdp parser, no munging\n const parsedSdp = parse(sdp);\n\n parsedSdp.avMedia.forEach((media) => {\n if (media.type === 'video') {\n media.codecs.forEach((codec) => {\n if (codec.name?.toUpperCase() === 'H264') {\n // there should really be just 1 fmtp line, but just in case, we process all of them\n codec.fmtParams = codec.fmtParams.map((fmtp) => {\n const parsedRegex = fmtp.match(/(.*)profile-level-id=(\\w{4})(\\w{2})(.*)/);\n\n if (parsedRegex && parsedRegex.length === 5) {\n const stuffBeforeProfileLevelId = parsedRegex[1];\n const profile = parsedRegex[2].toLowerCase();\n const levelId = parseInt(parsedRegex[3], 16);\n const stuffAfterProfileLevelId = parsedRegex[4];\n\n if (!maxFsForProfileLevel[levelId]) {\n throw new Error(\n `found unsupported h264 profile level id value in the SDP: ${levelId}`\n );\n }\n\n if (maxFsForProfileLevel[levelId] === maxFsValue) {\n // profile level already matches our desired max-fs value, so we don't need to do anything\n return fmtp;\n }\n if (maxFsForProfileLevel[levelId] < maxFsValue) {\n // profile level has too low max-fs, so we need to override it (this is upgrading)\n return `${fmtp};max-fs=${maxFsValue};max-mbps=${maxFsValue * framesPerSecond}`;\n }\n\n // profile level has too high max-fs value, so we need to use a lower level\n\n // find highest level that has the matching maxFs\n const newLevelId = Object.keys(maxFsForProfileLevel)\n .reverse()\n .find((key) => maxFsForProfileLevel[key] === maxFsValue);\n\n if (newLevelId) {\n // Object.keys returns keys as strings, so we need to parse it to an int again and then convert to hex\n const newLevelIdHex = parseInt(newLevelId, 10).toString(16);\n\n return `${stuffBeforeProfileLevelId}profile-level-id=${profile}${newLevelIdHex};max-mbps=${maxFsValue * framesPerSecond}${stuffAfterProfileLevelId}`;\n }\n\n throw new Error(`unsupported maxFsValue: ${maxFsValue}`);\n }\n\n return fmtp;\n });\n }\n });\n }\n });\n\n return parsedSdp.toString();\n};\n\nexport default PeerConnectionUtils;\n"],"mappings":"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"}
1
+ {"version":3,"names":["PeerConnectionUtils","maxFsForProfileLevel","framesPerSecond","convertCLineToIpv4","sdp","replaceSdp","replace","adjustH264Profile","maxFsValue","parsedSdp","parse","avMedia","forEach","media","type","codecs","codec","name","toUpperCase","fmtParams","map","fmtp","parsedRegex","match","length","stuffBeforeProfileLevelId","profile","toLowerCase","levelId","stuffAfterProfileLevelId","Error","newLevelId","reverse","find","key","newLevelIdHex","toString"],"sources":["util.ts"],"sourcesContent":["import {parse} from '@webex/ts-sdp';\n\ninterface IPeerConnectionUtils {\n convertCLineToIpv4: (sdp: string) => string;\n adjustH264Profile: (sdp: string, maxFsValue: number) => string;\n}\n\nconst PeerConnectionUtils = {} as IPeerConnectionUtils;\n\n// max-fs values for all H264 profile levels\nconst maxFsForProfileLevel = {\n 10: 99,\n 11: 396,\n 12: 396,\n 13: 396,\n 20: 396,\n 21: 792,\n 22: 1620,\n 30: 1620,\n 31: 3600,\n 32: 5120,\n 40: 8192,\n 41: 8192,\n 42: 8704,\n 50: 22080,\n 51: 36864,\n 52: 36864,\n 60: 139264,\n 61: 139264,\n 62: 139264,\n};\n\nconst framesPerSecond = 30;\n\n/**\n * Convert C line to IPv4\n * @param {string} sdp\n * @returns {string}\n */\nPeerConnectionUtils.convertCLineToIpv4 = (sdp: string) => {\n let replaceSdp = sdp;\n\n // TODO: remove this once linus supports Ipv6 c line.currently linus rejects SDP with c line having ipv6 candidates we are\n // mocking ipv6 to ipv4 candidates\n // https://jira-eng-gpk2.cisco.com/jira/browse/SPARK-299232\n replaceSdp = replaceSdp.replace(/c=IN IP6 .*/gi, 'c=IN IP4 0.0.0.0');\n\n return replaceSdp;\n};\n\n/**\n * estimate profile levels for max-fs & max-mbps values\n * @param {string} sdp\n * @param {number} maxFsValue\n * @returns {string}\n */\nPeerConnectionUtils.adjustH264Profile = (sdp: string, maxFsValue: number) => {\n // converting with ts-sdp parser, no munging\n const parsedSdp = parse(sdp);\n\n parsedSdp.avMedia.forEach((media) => {\n if (media.type === 'video') {\n media.codecs.forEach((codec) => {\n if (codec.name?.toUpperCase() === 'H264') {\n // there should really be just 1 fmtp line, but just in case, we process all of them\n codec.fmtParams = codec.fmtParams.map((fmtp) => {\n const parsedRegex = fmtp.match(/(.*)profile-level-id=(\\w{4})(\\w{2})(.*)/);\n\n if (parsedRegex && parsedRegex.length === 5) {\n const stuffBeforeProfileLevelId = parsedRegex[1];\n const profile = parsedRegex[2].toLowerCase();\n const levelId = parseInt(parsedRegex[3], 16);\n const stuffAfterProfileLevelId = parsedRegex[4];\n\n if (!maxFsForProfileLevel[levelId]) {\n throw new Error(\n `found unsupported h264 profile level id value in the SDP: ${levelId}`\n );\n }\n\n if (maxFsForProfileLevel[levelId] === maxFsValue) {\n // profile level already matches our desired max-fs value, so we don't need to do anything\n return fmtp;\n }\n if (maxFsForProfileLevel[levelId] < maxFsValue) {\n // profile level has too low max-fs, so we need to override it (this is upgrading)\n return `${fmtp};max-fs=${maxFsValue};max-mbps=${maxFsValue * framesPerSecond}`;\n }\n\n // profile level has too high max-fs value, so we need to use a lower level\n\n // find highest level that has the matching maxFs\n const newLevelId = Object.keys(maxFsForProfileLevel)\n .reverse()\n .find((key) => maxFsForProfileLevel[key] === maxFsValue);\n\n if (newLevelId) {\n // Object.keys returns keys as strings, so we need to parse it to an int again and then convert to hex\n const newLevelIdHex = parseInt(newLevelId, 10).toString(16);\n\n return `${stuffBeforeProfileLevelId}profile-level-id=${profile}${newLevelIdHex};max-mbps=${\n maxFsValue * framesPerSecond\n }${stuffAfterProfileLevelId}`;\n }\n\n throw new Error(`unsupported maxFsValue: ${maxFsValue}`);\n }\n\n return fmtp;\n });\n }\n });\n }\n });\n\n return parsedSdp.toString();\n};\n\nexport default PeerConnectionUtils;\n"],"mappings":"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"}
@@ -1,53 +1,32 @@
1
1
  "use strict";
2
2
 
3
3
  var _Reflect$construct = require("@babel/runtime-corejs2/core-js/reflect/construct");
4
-
5
4
  var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
6
-
7
5
  var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
8
-
9
6
  _Object$defineProperty(exports, "__esModule", {
10
7
  value: true
11
8
  });
12
-
13
9
  exports.default = void 0;
14
-
15
10
  var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
16
-
17
11
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
18
-
19
12
  var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
20
-
21
13
  var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/assertThisInitialized"));
22
-
23
14
  var _inherits2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/inherits"));
24
-
25
15
  var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/possibleConstructorReturn"));
26
-
27
16
  var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/getPrototypeOf"));
28
-
29
17
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
30
-
31
18
  var _webexCore = require("@webex/webex-core");
32
-
33
19
  var _constants = require("../constants");
34
-
35
20
  var _parameter = _interopRequireDefault(require("../common/errors/parameter"));
36
-
37
21
  var _request = _interopRequireDefault(require("./request"));
38
-
39
22
  function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = _Reflect$construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; }
40
-
41
23
  function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !_Reflect$construct) return false; if (_Reflect$construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
42
-
43
24
  /**
44
25
  * @class PersonalMeetingRoom
45
26
  */
46
27
  var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
47
28
  (0, _inherits2.default)(PersonalMeetingRoom, _StatelessWebexPlugin);
48
-
49
29
  var _super = _createSuper(PersonalMeetingRoom);
50
-
51
30
  /**
52
31
  *
53
32
  * @param {Object} attrs
@@ -55,7 +34,6 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
55
34
  */
56
35
  function PersonalMeetingRoom(attrs, options) {
57
36
  var _this;
58
-
59
37
  (0, _classCallCheck2.default)(this, PersonalMeetingRoom);
60
38
  _this = _super.call(this, {}, options);
61
39
  /**
@@ -64,8 +42,7 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
64
42
  * @type {Object}
65
43
  * @public
66
44
  * @memberof PersonalMeetingRoom
67
- */
68
-
45
+ */
69
46
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "link", void 0);
70
47
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "meetingInfo", void 0);
71
48
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "name", void 0);
@@ -83,8 +60,7 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
83
60
  * @type {String}
84
61
  * @public
85
62
  * @memberof PersonalMeetingRoom
86
- */
87
-
63
+ */
88
64
  _this.sipUri = null;
89
65
  /**
90
66
  * The pmr link
@@ -92,8 +68,7 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
92
68
  * @type {String}
93
69
  * @public
94
70
  * @memberof PersonalMeetingRoom
95
- */
96
-
71
+ */
97
72
  _this.link = null;
98
73
  /**
99
74
  * The pmr server object
@@ -101,8 +76,7 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
101
76
  * @type {Object}
102
77
  * @public
103
78
  * @memberof PersonalMeetingRoom
104
- */
105
-
79
+ */
106
80
  _this.userId = null;
107
81
  /**
108
82
  * The pmr name
@@ -110,8 +84,7 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
110
84
  * @type {String}
111
85
  * @public
112
86
  * @memberof PersonalMeetingRoom
113
- */
114
-
87
+ */
115
88
  _this.name = null;
116
89
  /**
117
90
  * The meeting info request server interface
@@ -119,8 +92,7 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
119
92
  * @type {MeetingInfo}
120
93
  * @private
121
94
  * @memberof PersonalMeetingRoom
122
- */
123
-
95
+ */
124
96
  _this.meetingInfo = attrs.meetingInfo;
125
97
  /**
126
98
  * The pmr server request interface
@@ -128,12 +100,12 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
128
100
  * @type {Object}
129
101
  * @private
130
102
  * @memberof PersonalMeetingRoom
131
- */
103
+ */
132
104
  // @ts-ignore
133
-
134
105
  _this.personalMeetingRoomRequest = new _request.default({}, options);
135
106
  return _this;
136
107
  }
108
+
137
109
  /**
138
110
  * claims a pmr and updates the cached PMR values
139
111
  * @param {String} link
@@ -143,13 +115,10 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
143
115
  * @public
144
116
  * @memberof PersonalMeetingRoom
145
117
  */
146
-
147
-
148
118
  (0, _createClass2.default)(PersonalMeetingRoom, [{
149
119
  key: "claim",
150
120
  value: function claim(link, pin) {
151
121
  var _this2 = this;
152
-
153
122
  var preferred = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
154
123
  var options = {
155
124
  // @ts-ignore
@@ -164,17 +133,16 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
164
133
  } else {
165
134
  return _promise.default.reject(new _parameter.default('No PMR body provided. PMR values not updated.'));
166
135
  }
167
-
168
136
  return pmr.body;
169
137
  });
170
138
  }
139
+
171
140
  /**
172
141
  * @param {Object} body the response body from meeting info request
173
142
  * @returns {undefined}
174
143
  * @private
175
144
  * @memberof PersonalMeetingRoom
176
145
  */
177
-
178
146
  }, {
179
147
  key: "set",
180
148
  value: function set(body) {
@@ -185,6 +153,7 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
185
153
  this.name = body.meetingName;
186
154
  this.number = body.meetingNumber;
187
155
  }
156
+
188
157
  /**
189
158
  * TODO: implement TTL for syncing and caching so to not request again and again
190
159
  * @param {Object} options
@@ -192,12 +161,10 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
192
161
  * @public
193
162
  * @memberof PersonalMeetingRoom
194
163
  */
195
-
196
164
  }, {
197
165
  key: "get",
198
166
  value: function get() {
199
167
  var _this3 = this;
200
-
201
168
  var options = {
202
169
  type: _constants._PERSONAL_ROOM_
203
170
  };
@@ -207,13 +174,11 @@ var PersonalMeetingRoom = /*#__PURE__*/function (_StatelessWebexPlugin) {
207
174
  } else {
208
175
  return _promise.default.reject(new TypeError('The PMR requested is NOT a PMR. PMR values not set.'));
209
176
  }
210
-
211
177
  return pmr.body;
212
178
  });
213
179
  }
214
180
  }]);
215
181
  return PersonalMeetingRoom;
216
182
  }(_webexCore.StatelessWebexPlugin);
217
-
218
183
  exports.default = PersonalMeetingRoom;
219
184
  //# sourceMappingURL=index.js.map