@webex/plugin-meetings 3.8.0 → 3.8.1-next.10

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 (361) hide show
  1. package/README.md +26 -13
  2. package/dist/breakouts/breakout.js +1 -1
  3. package/dist/breakouts/index.js +70 -6
  4. package/dist/breakouts/index.js.map +1 -1
  5. package/dist/common/errors/webex-errors.js +12 -2
  6. package/dist/common/errors/webex-errors.js.map +1 -1
  7. package/dist/config.js +5 -1
  8. package/dist/config.js.map +1 -1
  9. package/dist/constants.js +28 -123
  10. package/dist/constants.js.map +1 -1
  11. package/dist/controls-options-manager/enums.js +3 -0
  12. package/dist/controls-options-manager/enums.js.map +1 -1
  13. package/dist/controls-options-manager/types.js.map +1 -1
  14. package/dist/controls-options-manager/util.js +78 -0
  15. package/dist/controls-options-manager/util.js.map +1 -1
  16. package/dist/interpretation/index.js +4 -4
  17. package/dist/interpretation/index.js.map +1 -1
  18. package/dist/interpretation/siLanguage.js +1 -1
  19. package/dist/locus-info/controlsUtils.js +37 -11
  20. package/dist/locus-info/controlsUtils.js.map +1 -1
  21. package/dist/locus-info/index.js +92 -12
  22. package/dist/locus-info/index.js.map +1 -1
  23. package/dist/locus-info/selfUtils.js +432 -418
  24. package/dist/locus-info/selfUtils.js.map +1 -1
  25. package/dist/media/index.js +17 -17
  26. package/dist/media/index.js.map +1 -1
  27. package/dist/media/properties.js +94 -6
  28. package/dist/media/properties.js.map +1 -1
  29. package/dist/meeting/brbState.js +9 -2
  30. package/dist/meeting/brbState.js.map +1 -1
  31. package/dist/meeting/in-meeting-actions.js +21 -1
  32. package/dist/meeting/in-meeting-actions.js.map +1 -1
  33. package/dist/meeting/index.js +678 -344
  34. package/dist/meeting/index.js.map +1 -1
  35. package/dist/meeting/locusMediaRequest.js +21 -22
  36. package/dist/meeting/locusMediaRequest.js.map +1 -1
  37. package/dist/meeting/muteState.js +4 -4
  38. package/dist/meeting/muteState.js.map +1 -1
  39. package/dist/meeting/request.js +30 -0
  40. package/dist/meeting/request.js.map +1 -1
  41. package/dist/meeting/request.type.js.map +1 -1
  42. package/dist/meeting/util.js +13 -2
  43. package/dist/meeting/util.js.map +1 -1
  44. package/dist/meeting-info/meeting-info-v2.js +373 -68
  45. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  46. package/dist/meeting-info/utilv2.js +5 -1
  47. package/dist/meeting-info/utilv2.js.map +1 -1
  48. package/dist/meetings/index.js +136 -1
  49. package/dist/meetings/index.js.map +1 -1
  50. package/dist/meetings/util.js +14 -0
  51. package/dist/meetings/util.js.map +1 -1
  52. package/dist/member/index.js +55 -9
  53. package/dist/member/index.js.map +1 -1
  54. package/dist/member/types.js +3 -0
  55. package/dist/member/types.js.map +1 -1
  56. package/dist/member/util.js +335 -353
  57. package/dist/member/util.js.map +1 -1
  58. package/dist/members/collection.js.map +1 -1
  59. package/dist/members/index.js +137 -29
  60. package/dist/members/index.js.map +1 -1
  61. package/dist/members/request.js +38 -0
  62. package/dist/members/request.js.map +1 -1
  63. package/dist/members/util.js +36 -1
  64. package/dist/members/util.js.map +1 -1
  65. package/dist/metrics/constants.js +10 -0
  66. package/dist/metrics/constants.js.map +1 -1
  67. package/dist/multistream/remoteMediaManager.js +40 -8
  68. package/dist/multistream/remoteMediaManager.js.map +1 -1
  69. package/dist/reachability/clusterReachability.js +63 -27
  70. package/dist/reachability/clusterReachability.js.map +1 -1
  71. package/dist/reachability/index.js +107 -47
  72. package/dist/reachability/index.js.map +1 -1
  73. package/dist/reachability/reachability.types.js +14 -0
  74. package/dist/reachability/reachability.types.js.map +1 -1
  75. package/dist/reachability/request.js +19 -3
  76. package/dist/reachability/request.js.map +1 -1
  77. package/dist/reconnection-manager/index.js +2 -2
  78. package/dist/reconnection-manager/index.js.map +1 -1
  79. package/dist/recording-controller/util.js +5 -5
  80. package/dist/recording-controller/util.js.map +1 -1
  81. package/dist/roap/index.js.map +1 -1
  82. package/dist/roap/turnDiscovery.js +45 -27
  83. package/dist/roap/turnDiscovery.js.map +1 -1
  84. package/dist/roap/types.js +17 -0
  85. package/dist/roap/types.js.map +1 -0
  86. package/dist/types/common/errors/webex-errors.d.ts +7 -1
  87. package/dist/types/config.d.ts +3 -0
  88. package/dist/types/constants.d.ts +20 -85
  89. package/dist/types/controls-options-manager/enums.d.ts +4 -1
  90. package/dist/types/controls-options-manager/types.d.ts +10 -1
  91. package/dist/types/locus-info/index.d.ts +3 -3
  92. package/dist/types/locus-info/selfUtils.d.ts +216 -1
  93. package/dist/types/media/properties.d.ts +15 -0
  94. package/dist/types/meeting/in-meeting-actions.d.ts +20 -0
  95. package/dist/types/meeting/index.d.ts +65 -1
  96. package/dist/types/meeting/muteState.d.ts +0 -1
  97. package/dist/types/meeting/request.d.ts +12 -1
  98. package/dist/types/meeting/request.type.d.ts +6 -0
  99. package/dist/types/meeting/util.d.ts +3 -1
  100. package/dist/types/meeting-info/meeting-info-v2.d.ts +82 -1
  101. package/dist/types/meetings/index.d.ts +57 -0
  102. package/dist/types/member/index.d.ts +21 -6
  103. package/dist/types/member/types.d.ts +73 -14
  104. package/dist/types/member/util.d.ts +156 -1
  105. package/dist/types/members/collection.d.ts +6 -5
  106. package/dist/types/members/index.d.ts +32 -43
  107. package/dist/types/members/request.d.ts +26 -0
  108. package/dist/types/members/util.d.ts +27 -0
  109. package/dist/types/metrics/constants.d.ts +10 -0
  110. package/dist/types/multistream/remoteMediaManager.d.ts +10 -1
  111. package/dist/types/reachability/clusterReachability.d.ts +15 -7
  112. package/dist/types/reachability/index.d.ts +10 -1
  113. package/dist/types/reachability/reachability.types.d.ts +5 -0
  114. package/dist/types/roap/index.d.ts +3 -2
  115. package/dist/types/roap/turnDiscovery.d.ts +5 -17
  116. package/dist/types/roap/types.d.ts +16 -0
  117. package/dist/webinar/index.js +2 -2
  118. package/dist/webinar/index.js.map +1 -1
  119. package/package.json +24 -23
  120. package/src/breakouts/index.ts +69 -0
  121. package/src/common/errors/webex-errors.ts +8 -1
  122. package/src/config.ts +3 -0
  123. package/src/constants.ts +30 -90
  124. package/src/controls-options-manager/enums.ts +3 -0
  125. package/src/controls-options-manager/types.ts +16 -1
  126. package/src/controls-options-manager/util.ts +93 -0
  127. package/src/interpretation/index.ts +3 -3
  128. package/src/locus-info/controlsUtils.ts +59 -14
  129. package/src/locus-info/index.ts +97 -13
  130. package/src/locus-info/selfUtils.ts +496 -442
  131. package/src/media/index.ts +23 -21
  132. package/src/media/properties.ts +96 -0
  133. package/src/meeting/brbState.ts +11 -2
  134. package/src/meeting/in-meeting-actions.ts +40 -0
  135. package/src/meeting/index.ts +470 -105
  136. package/src/meeting/locusMediaRequest.ts +27 -22
  137. package/src/meeting/muteState.ts +4 -4
  138. package/src/meeting/request.ts +36 -1
  139. package/src/meeting/request.type.ts +7 -0
  140. package/src/meeting/util.ts +11 -2
  141. package/src/meeting-info/meeting-info-v2.ts +254 -8
  142. package/src/meeting-info/utilv2.ts +5 -0
  143. package/src/meetings/index.ts +148 -1
  144. package/src/meetings/util.ts +18 -0
  145. package/src/member/index.ts +68 -22
  146. package/src/member/types.ts +82 -16
  147. package/src/member/util.ts +357 -350
  148. package/src/members/collection.ts +4 -3
  149. package/src/members/index.ts +137 -18
  150. package/src/members/request.ts +44 -0
  151. package/src/members/util.ts +43 -1
  152. package/src/metrics/constants.ts +10 -0
  153. package/src/multistream/remoteMediaManager.ts +32 -10
  154. package/src/reachability/clusterReachability.ts +73 -26
  155. package/src/reachability/index.ts +62 -1
  156. package/src/reachability/reachability.types.ts +6 -0
  157. package/src/reachability/request.ts +7 -0
  158. package/src/reconnection-manager/index.ts +2 -2
  159. package/src/recording-controller/util.ts +17 -13
  160. package/src/roap/index.ts +3 -7
  161. package/src/roap/turnDiscovery.ts +34 -39
  162. package/src/roap/types.ts +23 -0
  163. package/src/webinar/index.ts +1 -1
  164. package/test/unit/spec/breakouts/index.ts +167 -95
  165. package/test/unit/spec/controls-options-manager/util.js +178 -0
  166. package/test/unit/spec/interpretation/index.ts +39 -1
  167. package/test/unit/spec/locus-info/controlsUtils.js +155 -9
  168. package/test/unit/spec/locus-info/index.js +209 -73
  169. package/test/unit/spec/locus-info/selfUtils.js +98 -24
  170. package/test/unit/spec/media/index.ts +150 -18
  171. package/test/unit/spec/media/properties.ts +130 -0
  172. package/test/unit/spec/meeting/brbState.ts +40 -2
  173. package/test/unit/spec/meeting/in-meeting-actions.ts +23 -4
  174. package/test/unit/spec/meeting/index.js +804 -139
  175. package/test/unit/spec/meeting/locusMediaRequest.ts +95 -87
  176. package/test/unit/spec/meeting/muteState.js +73 -2
  177. package/test/unit/spec/meeting/request.js +32 -1
  178. package/test/unit/spec/meeting/utils.js +119 -18
  179. package/test/unit/spec/meeting-info/meetinginfov2.js +484 -114
  180. package/test/unit/spec/meeting-info/utilv2.js +19 -0
  181. package/test/unit/spec/meetings/index.js +146 -2
  182. package/test/unit/spec/member/index.js +7 -0
  183. package/test/unit/spec/member/util.js +24 -0
  184. package/test/unit/spec/members/index.js +304 -78
  185. package/test/unit/spec/members/request.js +68 -22
  186. package/test/unit/spec/members/utils.js +75 -0
  187. package/test/unit/spec/multistream/remoteMediaManager.ts +397 -118
  188. package/test/unit/spec/reachability/clusterReachability.ts +88 -56
  189. package/test/unit/spec/reachability/index.ts +97 -0
  190. package/test/unit/spec/reachability/request.js +47 -2
  191. package/test/unit/spec/reconnection-manager/index.js +4 -4
  192. package/test/unit/spec/roap/turnDiscovery.ts +110 -28
  193. package/test/unit/spec/webinar/index.ts +5 -0
  194. package/dist/annotation/annotation.types.d.ts +0 -42
  195. package/dist/annotation/constants.d.ts +0 -31
  196. package/dist/annotation/index.d.ts +0 -117
  197. package/dist/breakouts/breakout.d.ts +0 -8
  198. package/dist/breakouts/collection.d.ts +0 -5
  199. package/dist/breakouts/edit-lock-error.d.ts +0 -15
  200. package/dist/breakouts/events.d.ts +0 -8
  201. package/dist/breakouts/index.d.ts +0 -5
  202. package/dist/breakouts/request.d.ts +0 -22
  203. package/dist/breakouts/utils.d.ts +0 -15
  204. package/dist/common/browser-detection.d.ts +0 -9
  205. package/dist/common/collection.d.ts +0 -48
  206. package/dist/common/config.d.ts +0 -2
  207. package/dist/common/errors/captcha-error.d.ts +0 -15
  208. package/dist/common/errors/intent-to-join.d.ts +0 -16
  209. package/dist/common/errors/join-meeting.d.ts +0 -17
  210. package/dist/common/errors/media.d.ts +0 -15
  211. package/dist/common/errors/no-meeting-info.d.ts +0 -14
  212. package/dist/common/errors/parameter.d.ts +0 -15
  213. package/dist/common/errors/password-error.d.ts +0 -15
  214. package/dist/common/errors/permission.d.ts +0 -14
  215. package/dist/common/errors/reclaim-host-role-error.js +0 -149
  216. package/dist/common/errors/reclaim-host-role-error.js.map +0 -1
  217. package/dist/common/errors/reclaim-host-role-errors.d.ts +0 -60
  218. package/dist/common/errors/reconnection-in-progress.d.ts +0 -9
  219. package/dist/common/errors/reconnection-in-progress.js +0 -33
  220. package/dist/common/errors/reconnection-in-progress.js.map +0 -1
  221. package/dist/common/errors/reconnection.d.ts +0 -15
  222. package/dist/common/errors/stats.d.ts +0 -15
  223. package/dist/common/errors/webex-errors.d.ts +0 -93
  224. package/dist/common/errors/webex-meetings-error.d.ts +0 -20
  225. package/dist/common/events/events-scope.d.ts +0 -17
  226. package/dist/common/events/events.d.ts +0 -12
  227. package/dist/common/events/trigger-proxy.d.ts +0 -2
  228. package/dist/common/events/util.d.ts +0 -2
  229. package/dist/common/logs/logger-config.d.ts +0 -2
  230. package/dist/common/logs/logger-proxy.d.ts +0 -2
  231. package/dist/common/logs/request.d.ts +0 -36
  232. package/dist/common/queue.d.ts +0 -34
  233. package/dist/config.d.ts +0 -72
  234. package/dist/constants.d.ts +0 -1088
  235. package/dist/controls-options-manager/constants.d.ts +0 -4
  236. package/dist/controls-options-manager/enums.d.ts +0 -15
  237. package/dist/controls-options-manager/index.d.ts +0 -136
  238. package/dist/controls-options-manager/types.d.ts +0 -43
  239. package/dist/controls-options-manager/util.d.ts +0 -1
  240. package/dist/index.d.ts +0 -7
  241. package/dist/interceptors/index.d.ts +0 -2
  242. package/dist/interceptors/locusRetry.d.ts +0 -27
  243. package/dist/interpretation/collection.d.ts +0 -5
  244. package/dist/interpretation/index.d.ts +0 -5
  245. package/dist/interpretation/siLanguage.d.ts +0 -5
  246. package/dist/locus-info/controlsUtils.d.ts +0 -2
  247. package/dist/locus-info/embeddedAppsUtils.d.ts +0 -2
  248. package/dist/locus-info/fullState.d.ts +0 -2
  249. package/dist/locus-info/hostUtils.d.ts +0 -2
  250. package/dist/locus-info/index.d.ts +0 -322
  251. package/dist/locus-info/infoUtils.d.ts +0 -2
  252. package/dist/locus-info/mediaSharesUtils.d.ts +0 -2
  253. package/dist/locus-info/parser.d.ts +0 -272
  254. package/dist/locus-info/selfUtils.d.ts +0 -2
  255. package/dist/media/index.d.ts +0 -34
  256. package/dist/media/properties.d.ts +0 -93
  257. package/dist/media/util.d.ts +0 -2
  258. package/dist/mediaQualityMetrics/config.d.ts +0 -241
  259. package/dist/mediaQualityMetrics/config.js +0 -502
  260. package/dist/mediaQualityMetrics/config.js.map +0 -1
  261. package/dist/meeting/effectsState.js +0 -260
  262. package/dist/meeting/effectsState.js.map +0 -1
  263. package/dist/meeting/in-meeting-actions.d.ts +0 -167
  264. package/dist/meeting/index.d.ts +0 -1825
  265. package/dist/meeting/locusMediaRequest.d.ts +0 -74
  266. package/dist/meeting/muteState.d.ts +0 -178
  267. package/dist/meeting/request.d.ts +0 -295
  268. package/dist/meeting/request.type.d.ts +0 -11
  269. package/dist/meeting/state.d.ts +0 -9
  270. package/dist/meeting/util.d.ts +0 -119
  271. package/dist/meeting/voicea-meeting.d.ts +0 -16
  272. package/dist/meeting-info/collection.d.ts +0 -20
  273. package/dist/meeting-info/index.d.ts +0 -69
  274. package/dist/meeting-info/meeting-info-v2.d.ts +0 -123
  275. package/dist/meeting-info/request.d.ts +0 -22
  276. package/dist/meeting-info/util.d.ts +0 -2
  277. package/dist/meeting-info/utilv2.d.ts +0 -2
  278. package/dist/meetings/collection.d.ts +0 -40
  279. package/dist/meetings/index.d.ts +0 -390
  280. package/dist/meetings/meetings.types.d.ts +0 -4
  281. package/dist/meetings/request.d.ts +0 -27
  282. package/dist/meetings/util.d.ts +0 -18
  283. package/dist/member/index.d.ts +0 -160
  284. package/dist/member/member.types.js +0 -17
  285. package/dist/member/member.types.js.map +0 -1
  286. package/dist/member/types.d.ts +0 -32
  287. package/dist/member/util.d.ts +0 -2
  288. package/dist/members/collection.d.ts +0 -29
  289. package/dist/members/index.d.ts +0 -353
  290. package/dist/members/request.d.ts +0 -114
  291. package/dist/members/types.d.ts +0 -25
  292. package/dist/members/util.d.ts +0 -215
  293. package/dist/metrics/config.js +0 -276
  294. package/dist/metrics/config.js.map +0 -1
  295. package/dist/metrics/constants.d.ts +0 -70
  296. package/dist/metrics/index.d.ts +0 -45
  297. package/dist/multistream/mediaRequestManager.d.ts +0 -119
  298. package/dist/multistream/receiveSlot.d.ts +0 -68
  299. package/dist/multistream/receiveSlotManager.d.ts +0 -56
  300. package/dist/multistream/remoteMedia.d.ts +0 -72
  301. package/dist/multistream/remoteMediaGroup.d.ts +0 -49
  302. package/dist/multistream/remoteMediaManager.d.ts +0 -300
  303. package/dist/multistream/sendSlotManager.d.ts +0 -69
  304. package/dist/networkQualityMonitor/index.d.ts +0 -70
  305. package/dist/networkQualityMonitor/index.js +0 -221
  306. package/dist/networkQualityMonitor/index.js.map +0 -1
  307. package/dist/peer-connection-manager/index.js +0 -671
  308. package/dist/peer-connection-manager/index.js.map +0 -1
  309. package/dist/peer-connection-manager/util.js +0 -109
  310. package/dist/peer-connection-manager/util.js.map +0 -1
  311. package/dist/personal-meeting-room/index.d.ts +0 -47
  312. package/dist/personal-meeting-room/request.d.ts +0 -14
  313. package/dist/personal-meeting-room/util.d.ts +0 -2
  314. package/dist/reachability/clusterReachability.d.ts +0 -109
  315. package/dist/reachability/index.d.ts +0 -105
  316. package/dist/reachability/request.d.ts +0 -39
  317. package/dist/reachability/util.d.ts +0 -8
  318. package/dist/reactions/constants.d.ts +0 -3
  319. package/dist/reactions/reactions.d.ts +0 -4
  320. package/dist/reactions/reactions.type.d.ts +0 -52
  321. package/dist/reconnection-manager/index.d.ts +0 -136
  322. package/dist/recording-controller/enums.d.ts +0 -7
  323. package/dist/recording-controller/index.d.ts +0 -207
  324. package/dist/recording-controller/util.d.ts +0 -14
  325. package/dist/roap/collection.js +0 -62
  326. package/dist/roap/collection.js.map +0 -1
  327. package/dist/roap/handler.js +0 -275
  328. package/dist/roap/handler.js.map +0 -1
  329. package/dist/roap/index.d.ts +0 -86
  330. package/dist/roap/request.d.ts +0 -39
  331. package/dist/roap/state.js +0 -126
  332. package/dist/roap/state.js.map +0 -1
  333. package/dist/roap/turnDiscovery.d.ts +0 -155
  334. package/dist/roap/util.js +0 -75
  335. package/dist/roap/util.js.map +0 -1
  336. package/dist/rtcMetrics/constants.d.ts +0 -4
  337. package/dist/rtcMetrics/constants.js +0 -11
  338. package/dist/rtcMetrics/constants.js.map +0 -1
  339. package/dist/rtcMetrics/index.d.ts +0 -61
  340. package/dist/rtcMetrics/index.js +0 -197
  341. package/dist/rtcMetrics/index.js.map +0 -1
  342. package/dist/statsAnalyzer/global.d.ts +0 -36
  343. package/dist/statsAnalyzer/global.js +0 -126
  344. package/dist/statsAnalyzer/global.js.map +0 -1
  345. package/dist/statsAnalyzer/index.d.ts +0 -217
  346. package/dist/statsAnalyzer/index.js +0 -1013
  347. package/dist/statsAnalyzer/index.js.map +0 -1
  348. package/dist/statsAnalyzer/mqaUtil.d.ts +0 -48
  349. package/dist/statsAnalyzer/mqaUtil.js +0 -179
  350. package/dist/statsAnalyzer/mqaUtil.js.map +0 -1
  351. package/dist/transcription/index.d.ts +0 -64
  352. package/dist/types/common/errors/reconnection-in-progress.d.ts +0 -9
  353. package/dist/types/mediaQualityMetrics/config.d.ts +0 -241
  354. package/dist/types/networkQualityMonitor/index.d.ts +0 -70
  355. package/dist/types/rtcMetrics/constants.d.ts +0 -4
  356. package/dist/types/rtcMetrics/index.d.ts +0 -71
  357. package/dist/types/statsAnalyzer/global.d.ts +0 -36
  358. package/dist/types/statsAnalyzer/index.d.ts +0 -217
  359. package/dist/types/statsAnalyzer/mqaUtil.d.ts +0 -48
  360. package/dist/webinar/collection.d.ts +0 -16
  361. package/dist/webinar/index.d.ts +0 -5
@@ -1,671 +0,0 @@
1
- "use strict";
2
-
3
- var _Array$from = require("@babel/runtime-corejs2/core-js/array/from");
4
- var _Symbol = require("@babel/runtime-corejs2/core-js/symbol");
5
- var _Symbol$iterator = require("@babel/runtime-corejs2/core-js/symbol/iterator");
6
- var _Array$isArray = require("@babel/runtime-corejs2/core-js/array/is-array");
7
- var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
8
- var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
9
- _Object$defineProperty(exports, "__esModule", {
10
- value: true
11
- });
12
- exports.default = void 0;
13
- var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
14
- var _now = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/date/now"));
15
- var _parseInt2 = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/parse-int"));
16
- var _window = _interopRequireDefault(require("global/window"));
17
- var _sdpTransform = _interopRequireDefault(require("sdp-transform"));
18
- var _metrics = _interopRequireDefault(require("../metrics"));
19
- var _loggerProxy = _interopRequireDefault(require("../common/logs/logger-proxy"));
20
- var _config = _interopRequireDefault(require("../common/config"));
21
- var _constants = require("../constants");
22
- var _constants2 = _interopRequireDefault(require("../metrics/constants"));
23
- var _config2 = require("../metrics/config");
24
- var _media = _interopRequireDefault(require("../common/errors/media"));
25
- var _parameter = _interopRequireDefault(require("../common/errors/parameter"));
26
- var _webexErrors = require("../common/errors/webex-errors");
27
- var _browserDetection = _interopRequireDefault(require("../common/browser-detection"));
28
- var _util = _interopRequireDefault(require("./util"));
29
- function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof _Symbol && r[_Symbol$iterator] || r["@@iterator"]; if (!t) { if (_Array$isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; }
30
- function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? _Array$from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
31
- function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } // We need to figure out how to pass a webex logger instance to these util files
32
- /* globals RTCSessionDescription */ // https://github.com/clux/sdp-transform
33
- var _BrowserDetection = (0, _browserDetection.default)(),
34
- isBrowser = _BrowserDetection.isBrowser;
35
-
36
- /**
37
- * @export
38
- * @public
39
- */
40
- var pc = {};
41
-
42
- /**
43
- * munges the bandwidth limit into the sdp
44
- * @param {String} sdpLines
45
- * @param {Number} index
46
- * @returns {String}
47
- */
48
- var insertBandwidthLimit = function insertBandwidthLimit(sdpLines, index) {
49
- // eslint-disable-next-line no-warning-comments
50
- // TODO convert to sdp parser
51
- var limit;
52
- var periodicKeyFrame = '';
53
- if (sdpLines[index].search(_constants.AUDIO) !== -1) {
54
- limit = _config.default.meetings.bandwidth.audio;
55
- } else {
56
- limit = _config.default.meetings.bandwidth.video;
57
- periodicKeyFrame = _constants.SDP.PERIODIC_KEYFRAME;
58
- sdpLines.splice(index + 2, 0, periodicKeyFrame);
59
- }
60
- sdpLines.splice(index + 1, 0, "".concat(_constants.SDP.B_LINE, ":").concat(limit));
61
- return sdpLines;
62
- };
63
-
64
- /**
65
- * needed for calliope max-fs
66
- * @param {String} sdp
67
- * @param {String} [level=QUALITY_LEVELS.HIGH] quality level for max-fs
68
- * @returns {String}
69
- */
70
- var setRemoteVideoConstraints = function setRemoteVideoConstraints(sdp) {
71
- var level = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : _constants.QUALITY_LEVELS.HIGH;
72
- var maxFs = _constants.REMOTE_VIDEO_CONSTRAINTS.MAX_FS[level];
73
- if (!maxFs) {
74
- throw new _parameter.default("setRemoteVideoConstraints: unable to set max framesize, value for level \"".concat(level, "\" is not defined"));
75
- }
76
- var modifiedSdp = _util.default.adjustH264Profile(sdp, maxFs);
77
- return modifiedSdp;
78
- };
79
- var setStartBitrateOnRemoteSdp = function setStartBitrateOnRemoteSdp(sdp) {
80
- if (_config.default.meetings.bandwidth.startBitrate) {
81
- sdp = sdp.replace(/(\na=fmtp:(\d+).*profile-level-id=.*)/gi, "$1;x-google-start-bitrate=".concat(_config.default.meetings.bandwidth.startBitrate));
82
- }
83
- return sdp;
84
- };
85
-
86
- /**
87
- * checks that sdp has h264 codec in it
88
- * @param {String} sdp
89
- * @returns {boolean}
90
- */
91
- var checkH264Support = function checkH264Support(sdp) {
92
- // eslint-disable-next-line no-warning-comments
93
- // TODO convert to sdp parser to read rtp.codec
94
- var videoPresent = sdp.match(/\nm=video.*/g);
95
- var h264Present = sdp.match(/\na=rtpmap:\d+\sH264.*/g);
96
- if (videoPresent) {
97
- return !!h264Present;
98
- }
99
- return true;
100
- };
101
-
102
- /**
103
- * validates the sdp, checks port, candidates, and ice info
104
- * @param {String} sdp
105
- * @returns {String}
106
- */
107
- var isSdpInvalid = function isSdpInvalid(sdp) {
108
- var parsedSdp = _sdpTransform.default.parse(sdp);
109
- var _iterator = _createForOfIteratorHelper(parsedSdp.media),
110
- _step;
111
- try {
112
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
113
- var _mediaLine$candidates;
114
- var mediaLine = _step.value;
115
- if (!mediaLine.candidates || ((_mediaLine$candidates = mediaLine.candidates) === null || _mediaLine$candidates === void 0 ? void 0 : _mediaLine$candidates.length) === 0) {
116
- _loggerProxy.default.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Ice candidate never completed');
117
- return 'iceCandidate: Ice gathering never completed';
118
- }
119
- if (_constants.SDP.BAD_MEDIA_PORTS.includes(mediaLine.port)) {
120
- _loggerProxy.default.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: Found invalid port number for the ice candidate');
121
- return 'iceCandidate: Found invalid port number for the ice candidate';
122
- }
123
- if (!mediaLine.icePwd || !mediaLine.iceUfrag) {
124
- _loggerProxy.default.logger.error('PeerConnectionManager:index#isSdpInvalid --> iceCandidate: ice ufrag and password not found');
125
- return 'iceCandidate: ice ufrag and password not found';
126
- }
127
- }
128
- } catch (err) {
129
- _iterator.e(err);
130
- } finally {
131
- _iterator.f();
132
- }
133
- return '';
134
- };
135
-
136
- /**
137
- * munges the bandwidth into the sdp
138
- * @param {String} sdp
139
- * @returns {String}
140
- */
141
- var limitBandwidth = function limitBandwidth(sdp) {
142
- // TODO convert to sdp parser
143
- var offerSdp = sdp;
144
- var sdpLines = offerSdp.split(_constants.SDP.CARRIAGE_RETURN);
145
- for (var i = 0; i < sdpLines.length; i += 1) {
146
- if (sdpLines[i].search(_constants.SDP.M_LINE) !== -1) {
147
- sdpLines = insertBandwidthLimit(sdpLines, i);
148
- }
149
- }
150
- offerSdp = sdpLines.join(_constants.SDP.CARRIAGE_RETURN);
151
- return offerSdp;
152
- };
153
-
154
- /**
155
- * makes sure the screen pc sdp has content:slides for server
156
- * @param {RTCPeerConnection} screenPc
157
- * @returns {RTCPeerConnection}
158
- */
159
- pc.setContentSlides = function (screenPc) {
160
- if (screenPc && screenPc.sdp) {
161
- screenPc.sdp += "".concat(_constants.SDP.A_CONTENT_SLIDES).concat(_constants.SDP.CARRIAGE_RETURN);
162
- }
163
- return screenPc;
164
- };
165
-
166
- /**
167
- * handles ice trickling and establishes ICE connection onto peer connection object
168
- * @param {Object} peerConnection
169
- * @param {Object} options
170
- * @param {String} options.remoteQualityLevel
171
- * @returns {Promise.RTCPeerConnection}
172
- */
173
- pc.iceCandidate = function (peerConnection, _ref) {
174
- var remoteQualityLevel = _ref.remoteQualityLevel;
175
- return new _promise.default(function (resolve, reject) {
176
- var now = (0, _now.default)();
177
- var doneGatheringIceCandidate = function doneGatheringIceCandidate() {
178
- // @ts-ignore
179
- var miliseconds = (0, _parseInt2.default)(Math.abs((0, _now.default)() - now), 4);
180
- peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);
181
- peerConnection.sdp = _util.default.convertCLineToIpv4(peerConnection.sdp);
182
- peerConnection.sdp = setRemoteVideoConstraints(peerConnection.sdp, remoteQualityLevel);
183
- var invalidSdpPresent = isSdpInvalid(peerConnection.sdp);
184
- if (invalidSdpPresent) {
185
- _loggerProxy.default.logger.error('PeerConnectionManager:index#iceCandidate --> SDP not valid after waiting.');
186
- reject(new _webexErrors.InvalidSdpError(invalidSdpPresent));
187
- }
188
- _loggerProxy.default.logger.log("PeerConnectionManager:index#iceCandidate --> Time to gather ice candidate ".concat(miliseconds, " miliseconds"));
189
- resolve();
190
- };
191
-
192
- // If ice has already been gathered
193
- if (peerConnection.iceGatheringState === _constants.COMPLETE) {
194
- doneGatheringIceCandidate();
195
- }
196
- peerConnection.onIceGatheringStateChange = function () {
197
- if (peerConnection.iceGatheringState === _constants.COMPLETE) {
198
- // @ts-ignore
199
- doneGatheringIceCandidate(peerConnection);
200
- }
201
- if (peerConnection.iceGatheringState === _constants.GATHERING) {
202
- _loggerProxy.default.logger.log('PeerConnectionManager:index#onIceGatheringStateChange --> Ice state changed to gathering');
203
- }
204
- };
205
- peerConnection.onicecandidate = function (evt) {
206
- if (evt.candidate === null) {
207
- // @ts-ignore
208
- doneGatheringIceCandidate(peerConnection);
209
- } else {
210
- var _evt$candidate, _evt$candidate2, _evt$candidate3, _evt$candidate4;
211
- _loggerProxy.default.logger.log("PeerConnectionManager:index#onicecandidate --> Candidate ".concat((_evt$candidate = evt.candidate) === null || _evt$candidate === void 0 ? void 0 : _evt$candidate.type, " ").concat((_evt$candidate2 = evt.candidate) === null || _evt$candidate2 === void 0 ? void 0 : _evt$candidate2.protocol, " ").concat((_evt$candidate3 = evt.candidate) === null || _evt$candidate3 === void 0 ? void 0 : _evt$candidate3.address, ":").concat((_evt$candidate4 = evt.candidate) === null || _evt$candidate4 === void 0 ? void 0 : _evt$candidate4.port));
212
- }
213
- };
214
- peerConnection.onicecandidateerror = function (event) {
215
- // we can often get ICE candidate errors (for example when failing to communicate with a TURN server)
216
- // they don't mean that the whole ICE connection will fail, so it's OK to ignore them
217
- _loggerProxy.default.logger.error('PeerConnectionManager:index#onicecandidateerror --> ignoring ice error:', event);
218
- };
219
- });
220
- };
221
-
222
- /**
223
- * swapping tracks
224
- * @param {Object} peerConnection
225
- * @param {Object} track
226
- * @returns {undefined}
227
- */
228
- pc.replaceTrack = function (peerConnection, track) {
229
- try {
230
- var senders = peerConnection.getSenders();
231
- if (senders.length > 0) {
232
- senders.forEach(function (sender) {
233
- if (sender.track && sender.track.kind === track.kind) {
234
- sender.replaceTrack(track);
235
- }
236
- });
237
- }
238
- } catch (err) {
239
- _loggerProxy.default.logger.error("PeerConnectionManager:index#replaceTrack --> Error replacing track, ".concat(err));
240
- }
241
- };
242
-
243
- /**
244
- * adding streams to peerConnection
245
- * @param {Object} peerConnection
246
- * @param {Object} stream
247
- * @returns {undefined}
248
- */
249
- pc.addStream = function (peerConnection, stream) {
250
- try {
251
- if (stream && !isBrowser('edge')) {
252
- var tracksPresent = peerConnection.getSenders && peerConnection.getSenders().find(function (sender) {
253
- return sender.track != null;
254
- });
255
- if (tracksPresent) {
256
- stream.getTracks().forEach(function (track) {
257
- pc.replaceTrack(peerConnection, track);
258
- });
259
- return;
260
- }
261
- stream.getTracks().forEach(function (track) {
262
- peerConnection.addTrack(track, stream);
263
- });
264
- // // TODO : may come back disable addTracks for chrome they are moving back to addStream
265
- // // https://bugs.chromium.org/p/chromium/issues/detail?id=764414
266
- // // https://bugs.chromium.org/p/chromium/issues/detail?id=738918#c7
267
- // peerConnection.addStream(stream);
268
- } else if (isBrowser('edge')) {
269
- peerConnection.addStream(stream);
270
- }
271
- } catch (err) {
272
- _loggerProxy.default.logger.error("PeerConnectionManager:index#addStream --> Error adding stream, error: ".concat(_config2.error));
273
- }
274
- };
275
-
276
- /**
277
- * setting the remote description
278
- * @param {Object} peerConnection
279
- * @param {String} typeStr
280
- * @param {String} remoteSdp
281
- * @param {String} meetingId
282
- * @returns {undefined}
283
- */
284
- pc.setRemoteSessionDetails = function (peerConnection, typeStr, remoteSdp, meetingId) {
285
- _loggerProxy.default.logger.log("PeerConnectionManager:index#setRemoteSessionDetails --> Setting the remote description type: ".concat(typeStr, "State: ").concat(peerConnection.signalingState));
286
- var sdp = remoteSdp;
287
-
288
- // making sure that the remoteDescription is only set when there is a answer for offer
289
- // or there is a offer from the server
290
-
291
- if (!sdp) {
292
- _metrics.default.postEvent({
293
- event: _config2.eventType.REMOTE_SDP_RECEIVED,
294
- meetingId: meetingId,
295
- data: {
296
- canProceed: false,
297
- errors: [_metrics.default.generateErrorPayload(2001, true, _config2.error.name.MEDIA_ENGINE, 'missing remoteSdp')]
298
- }
299
- });
300
- }
301
- if (peerConnection.signalingState === _constants.SDP.HAVE_LOCAL_OFFER || peerConnection.signalingState === _constants.SDP.STABLE && typeStr === _constants.SDP.OFFER) {
302
- sdp = setStartBitrateOnRemoteSdp(sdp);
303
- if (!peerConnection.enableExtmap) {
304
- sdp = sdp.replace(/\na=extmap.*/g, '');
305
- }
306
-
307
- // remove any xtls candidates
308
- sdp = sdp.replace(/^a=candidate:.*xTLS.*\r\n/gim, '');
309
- return peerConnection.setRemoteDescription(new _window.default.RTCSessionDescription({
310
- type: typeStr,
311
- sdp: sdp
312
- })).then(function () {
313
- if (peerConnection.signalingState === _constants.SDP.STABLE) {
314
- _metrics.default.postEvent({
315
- event: _config2.eventType.REMOTE_SDP_RECEIVED,
316
- meetingId: meetingId
317
- });
318
- }
319
- })
320
- // eslint-disable-next-line @typescript-eslint/no-shadow
321
- .catch(function (error) {
322
- _loggerProxy.default.logger.error("Peer-connection-manager:index#setRemoteDescription --> ".concat(error, " missing remotesdp"));
323
- var metricName = _constants2.default.PEERCONNECTION_FAILURE;
324
- var data = {
325
- correlation_id: meetingId,
326
- reason: error.message,
327
- stack: error.stack
328
- };
329
- var metadata = {
330
- type: error.name
331
- };
332
- _metrics.default.sendBehavioralMetric(metricName, data, metadata);
333
- return _metrics.default.postEvent({
334
- event: _config2.eventType.REMOTE_SDP_RECEIVED,
335
- meetingId: meetingId,
336
- data: {
337
- canProceed: false,
338
- errors: [_metrics.default.generateErrorPayload(2001, true, error.name.MEDIA_ENGINE, 'missing remoteSdp')]
339
- }
340
- });
341
- });
342
- }
343
- return _promise.default.reject(new _media.default('PeerConnection in wrong state'));
344
- };
345
-
346
- /**
347
- * Create offer with a valid parameter
348
- * @param {Object} peerConnection
349
- * @param {Object} meetingProperties
350
- * @param {string} meetingProperties.meetingId
351
- * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH
352
- * @param {string} meetingProperties.enableRtx
353
- * @param {string} meetingProperties.enableExtmap
354
- * @returns {RTCPeerConnection}
355
- */
356
- pc.createOffer = function (peerConnection, _ref2) {
357
- var meetingId = _ref2.meetingId,
358
- remoteQualityLevel = _ref2.remoteQualityLevel,
359
- enableRtx = _ref2.enableRtx,
360
- enableExtmap = _ref2.enableExtmap;
361
- _loggerProxy.default.logger.log('PeerConnectionManager:index#createOffer --> creating a new offer');
362
-
363
- // saving the extMap State to use in setRemoteDescription
364
-
365
- peerConnection.enableExtmap = enableExtmap;
366
- return peerConnection.createOffer().then(function (description) {
367
- // bug https://bugs.chromium.org/p/chromium/issues/detail?id=1020642
368
- // chrome currently generates RTX line irrespective of whether the server side supports it
369
- // we are removing apt as well because its associated with rtx line
370
-
371
- if (!enableRtx) {
372
- description.sdp = description.sdp.replace(/\r\na=rtpmap:\d+ rtx\/\d+/g, '');
373
- description.sdp = description.sdp.replace(/\r\na=fmtp:\d+ apt=\d+/g, '');
374
- }
375
- return peerConnection.setLocalDescription(description);
376
- }).then(function () {
377
- return pc.iceCandidate(peerConnection, {
378
- remoteQualityLevel: remoteQualityLevel
379
- });
380
- }).then(function () {
381
- if (!checkH264Support(peerConnection.sdp)) {
382
- throw new _media.default('openH264 is downloading please Wait. Upload logs if not working on second try');
383
- }
384
- if (!enableExtmap) {
385
- peerConnection.sdp = peerConnection.sdp.replace(/\na=extmap.*/g, '');
386
- }
387
- pc.setContentSlides(peerConnection);
388
- _metrics.default.postEvent({
389
- event: _config2.eventType.LOCAL_SDP_GENERATED,
390
- meetingId: meetingId
391
- });
392
- return peerConnection;
393
- })
394
- // eslint-disable-next-line @typescript-eslint/no-shadow
395
- .catch(function (error) {
396
- _loggerProxy.default.logger.error("Peer-connection-manager:index#createOffer --> ".concat(error));
397
- if (error instanceof _webexErrors.InvalidSdpError) {
398
- _metrics.default.sendBehavioralMetric(_constants2.default.INVALID_ICE_CANDIDATE, {
399
- correlation_id: meetingId,
400
- code: error.code,
401
- reason: error.message
402
- });
403
- } else {
404
- var metricName = _constants2.default.PEERCONNECTION_FAILURE;
405
- var data = {
406
- correlation_id: meetingId,
407
- reason: error.message,
408
- stack: error.stack
409
- };
410
- var metadata = {
411
- type: error.name
412
- };
413
- _metrics.default.sendBehavioralMetric(metricName, data, metadata);
414
- }
415
- _metrics.default.postEvent({
416
- event: _config2.eventType.LOCAL_SDP_GENERATED,
417
- meetingId: meetingId,
418
- data: {
419
- canProceed: false,
420
- errors: [
421
- // @ts-ignore
422
- _metrics.default.generateErrorPayload(2001, true, error.name.MEDIA_ENGINE)]
423
- }
424
- });
425
- pc.close(peerConnection);
426
- throw error;
427
- });
428
- };
429
-
430
- /**
431
- * rollBack local description in peerconnection
432
- * @param {Object} peerConnection
433
- * @returns {Promise.RTCPeerConnection}
434
- */
435
- pc.rollBackLocalDescription = function (peerConnection) {
436
- return peerConnection
437
- // @ts-ignore
438
- .setLocalDescription(new RTCSessionDescription({
439
- type: _constants.SDP.ROLLBACK
440
- })).then(function () {
441
- return peerConnection;
442
- }).catch(function (err) {
443
- _loggerProxy.default.logger.error("Peer-connection-manager:index#setLocalDescription --> ".concat(err, " "));
444
-
445
- // @ts-ignore
446
- return _promise.default.error(err);
447
- });
448
- };
449
-
450
- /**
451
- * @param {Object} params {
452
- * @param {Boolean} params.offerToReceiveAudio
453
- * @param {Boolean} params.offerToReceiveVideo
454
- * @param {string} params.offerSdp
455
- * @param {MediaStream} params.stream
456
- * @param {Object} meetingProperties
457
- * @param {string} meetingProperties.meetingId
458
- * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH
459
- * @returns {Promise.<Array>} [MediaSDP, ScreenSDP]
460
- */
461
- pc.updatePeerConnection = function (params, _ref3) {
462
- var meetingId = _ref3.meetingId,
463
- remoteQualityLevel = _ref3.remoteQualityLevel;
464
- _loggerProxy.default.logger.log("PeerConnectionManager:index#updatePeerConnection --> updating the peerConnection with params: ".concat(params));
465
- var peerConnection = params.peerConnection,
466
- offerSdp = params.offerSdp;
467
- return pc.createAnswer({
468
- peerConnection: peerConnection,
469
- offerSdp: offerSdp[0]
470
- }, {
471
- meetingId: meetingId,
472
- remoteQualityLevel: remoteQualityLevel
473
- }).then(function (peerconnection) {
474
- // The content slides should also be set when we are sending inactive
475
- pc.setContentSlides(peerconnection);
476
- return _promise.default.resolve([peerconnection.sdp]);
477
- });
478
- };
479
-
480
- /**
481
- * @param {Object} params
482
- * @param {Object} params.peerConnection
483
- * @param {Object} params.sdpConstraints
484
- * @param {Object} meetingProperties
485
- * @param {string} meetingProperties.meetingId
486
- * @param {string} meetingProperties.remoteQualityLevel LOW|MEDIUM|HIGH
487
- * @returns {RTCPeerConnection} peerConnection
488
- */
489
- pc.createAnswer = function (params, _ref4) {
490
- var meetingId = _ref4.meetingId,
491
- remoteQualityLevel = _ref4.remoteQualityLevel;
492
- var peerConnection = params.peerConnection;
493
-
494
- // TODO: Some times to many mercury event comes at the same time
495
- // Need to maintain state of peerconnection
496
- if (peerConnection.signalingState === _constants.SDP.HAVE_REMOTE_OFFER) {
497
- return _promise.default.resolve(peerConnection);
498
- }
499
- return pc.setRemoteSessionDetails(peerConnection, _constants.OFFER, params.offerSdp, meetingId).then(function () {
500
- return peerConnection.createAnswer(params.sdpConstraints);
501
- }).then(function (answer) {
502
- return peerConnection.setLocalDescription(answer);
503
- }).then(function () {
504
- return pc.iceCandidate(peerConnection, {
505
- remoteQualityLevel: remoteQualityLevel
506
- });
507
- }).then(function () {
508
- peerConnection.sdp = limitBandwidth(peerConnection.localDescription.sdp);
509
- peerConnection.sdp = _util.default.convertCLineToIpv4(peerConnection.sdp);
510
- peerConnection.sdp = setRemoteVideoConstraints(peerConnection.sdp, remoteQualityLevel);
511
- if (!checkH264Support(peerConnection.sdp)) {
512
- throw new _media.default('openH264 is downloading please Wait. Upload logs if not working on second try');
513
- }
514
- return peerConnection;
515
- })
516
- // eslint-disable-next-line @typescript-eslint/no-shadow
517
- .catch(function (error) {
518
- if (error instanceof _webexErrors.InvalidSdpError) {
519
- _metrics.default.sendBehavioralMetric(_constants2.default.INVALID_ICE_CANDIDATE, {
520
- correlation_id: meetingId
521
- });
522
- } else {
523
- var metricName = _constants2.default.PEERCONNECTION_FAILURE;
524
- var data = {
525
- correlation_id: meetingId,
526
- reason: error.message,
527
- stack: error.stack
528
- };
529
- var metadata = {
530
- type: error.name
531
- };
532
- _metrics.default.sendBehavioralMetric(metricName, data, metadata);
533
- }
534
- _loggerProxy.default.logger.error("PeerConnectionManager:index#setRemoteSessionDetails --> Error creating remote session, error: ".concat(error));
535
- });
536
- };
537
-
538
- /**
539
- * shut down the peer connection
540
- * @param {Object} peerConnection
541
- * @returns {undefined}
542
- */
543
- pc.close = function (peerConnection) {
544
- // peerConnection.close() fails on firefox on network changes and gives a Dom exception
545
- // To avoid this we have added a try catch block.
546
- // Please refer to https://bugzilla.mozilla.org/show_bug.cgi?id=1274407 for more information
547
- _loggerProxy.default.logger.log('PeerConnectionManager:index#close --> pc: close() -> attempting to close the peer connection');
548
- if (peerConnection && peerConnection.connectionState === _constants.PEER_CONNECTION_STATE.CLOSED) {
549
- _loggerProxy.default.logger.log('PeerConnectionManager:index#close --> pc: close() -> connection already closed');
550
- return _promise.default.resolve();
551
- }
552
- _loggerProxy.default.logger.log('PeerConnectionManager:index#close --> pc: close() -> closing the mediaPeerConnection');
553
- return _promise.default.resolve().then(function () {
554
- if (peerConnection && peerConnection.close) {
555
- peerConnection.close();
556
- }
557
- });
558
- };
559
- pc.setPeerConnectionEvents = function (meeting) {
560
- // In case ICE fail
561
- var peerConnection = meeting.mediaProperties.peerConnection;
562
- var connectionFailed = function connectionFailed() {
563
- if (meeting.reconnectionManager.iceState.resolve) {
564
- // DISCONNECTED state triggers first then it goes to FAILED STATE
565
- // sometimes the failed state can happen before 10 seconds (Which is the timer for the reconnect for ice disconnect)
566
- meeting.reconnectionManager.iceState.resolve();
567
- }
568
- meeting.reconnect({
569
- networkDisconnect: true
570
- });
571
- _metrics.default.postEvent({
572
- event: _config2.eventType.ICE_END,
573
- meeting: meeting,
574
- data: {
575
- canProceed: false,
576
- errors: [
577
- // @ts-ignore
578
- _metrics.default.generateErrorPayload(2004, false, _config2.error.name.MEDIA_ENGINE)]
579
- }
580
- });
581
- meeting.uploadLogs({
582
- file: 'peer-connection-manager/index',
583
- function: 'connectionFailed'
584
- });
585
- _metrics.default.sendBehavioralMetric(_constants2.default.CONNECTION_FAILURE, {
586
- correlation_id: meeting.correlationId,
587
- locus_id: meeting.locusId
588
- });
589
- };
590
- peerConnection.oniceconnectionstatechange = function () {
591
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CHANGE.');
592
- switch (peerConnection.iceConnectionState) {
593
- case _constants.ICE_STATE.CHECKING:
594
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CHECKING.');
595
- _metrics.default.postEvent({
596
- event: _config2.eventType.ICE_START,
597
- meeting: meeting
598
- });
599
- break;
600
- case _constants.ICE_STATE.COMPLETED:
601
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE COMPLETED.');
602
- break;
603
- case _constants.ICE_STATE.CONNECTED:
604
- // Ice connection state goes to connected when both client and server sends STUN packets and
605
- // Established connected between them. Firefox does not trigger COMPLETED and only trigger CONNECTED
606
- _metrics.default.postEvent({
607
- event: _config2.eventType.ICE_END,
608
- meeting: meeting
609
- });
610
- _metrics.default.sendBehavioralMetric(_constants2.default.CONNECTION_SUCCESS, {
611
- correlation_id: meeting.correlationId,
612
- locus_id: meeting.locusId
613
- });
614
- meeting.setNetworkStatus(_constants.NETWORK_STATUS.CONNECTED);
615
- meeting.reconnectionManager.iceReconnected();
616
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CONNECTED.');
617
- break;
618
- case _constants.ICE_STATE.CLOSED:
619
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE CLOSED.');
620
- break;
621
- case _constants.ICE_STATE.DISCONNECTED:
622
- meeting.setNetworkStatus(_constants.NETWORK_STATUS.DISCONNECTED);
623
- meeting.reconnectionManager.waitForIceReconnect().catch(function () {
624
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE DISCONNECTED. Automatic Reconnection Timed Out.');
625
- connectionFailed();
626
- });
627
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE DISCONNECTED.');
628
- break;
629
- case _constants.ICE_STATE.FAILED:
630
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> ICE STATE FAILED.');
631
- // notify of ice failure
632
- // Ice failure is the only indicator currently for identifying the actual connection drop
633
- // Firefox takes sometime 10-15 seconds to go to failed state
634
- connectionFailed();
635
- break;
636
- default:
637
- break;
638
- }
639
- };
640
- peerConnection.onconnectionstatechange = function () {
641
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CHANGE.');
642
- switch (peerConnection.connectionState) {
643
- case _constants.CONNECTION_STATE.NEW:
644
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE NEW.');
645
- break;
646
- case _constants.CONNECTION_STATE.CONNECTING:
647
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CONNECTING.');
648
- break;
649
- case _constants.CONNECTION_STATE.CONNECTED:
650
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CONNECTED.');
651
- break;
652
- case _constants.CONNECTION_STATE.CLOSED:
653
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE CLOSED.');
654
- break;
655
- case _constants.CONNECTION_STATE.DISCONNECTED:
656
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE DISCONNECTED.');
657
- break;
658
- case _constants.CONNECTION_STATE.FAILED:
659
- _loggerProxy.default.logger.info('PeerConnectionManager:index#setPeerConnectionEvents --> CONNECTION STATE FAILED.');
660
- // Special case happens only on chrome where there is no ICE FAILED event
661
- // only CONNECTION FAILED event gets triggered
662
-
663
- connectionFailed();
664
- break;
665
- default:
666
- break;
667
- }
668
- };
669
- };
670
- var _default = exports.default = pc;
671
- //# sourceMappingURL=index.js.map