@webex/plugin-meetings 2.60.0 → 2.60.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 (539) hide show
  1. package/README.md +58 -8
  2. package/dist/annotation/annotation.types.d.ts +42 -0
  3. package/dist/annotation/annotation.types.js +7 -0
  4. package/dist/annotation/annotation.types.js.map +1 -0
  5. package/dist/annotation/constants.d.ts +31 -0
  6. package/dist/annotation/constants.js +41 -0
  7. package/dist/annotation/constants.js.map +1 -0
  8. package/dist/annotation/index.d.ts +117 -0
  9. package/dist/annotation/index.js +357 -0
  10. package/dist/annotation/index.js.map +1 -0
  11. package/dist/breakouts/breakout.d.ts +8 -0
  12. package/dist/breakouts/breakout.js +215 -0
  13. package/dist/breakouts/breakout.js.map +1 -0
  14. package/dist/breakouts/collection.d.ts +5 -0
  15. package/dist/breakouts/collection.js +22 -0
  16. package/dist/breakouts/collection.js.map +1 -0
  17. package/dist/breakouts/edit-lock-error.d.ts +15 -0
  18. package/dist/breakouts/edit-lock-error.js +51 -0
  19. package/dist/breakouts/edit-lock-error.js.map +1 -0
  20. package/dist/breakouts/events.d.ts +8 -0
  21. package/dist/breakouts/events.js +44 -0
  22. package/dist/breakouts/events.js.map +1 -0
  23. package/dist/breakouts/index.d.ts +5 -0
  24. package/dist/breakouts/index.js +1047 -0
  25. package/dist/breakouts/index.js.map +1 -0
  26. package/dist/breakouts/request.d.ts +22 -0
  27. package/dist/breakouts/request.js +77 -0
  28. package/dist/breakouts/request.js.map +1 -0
  29. package/dist/breakouts/utils.d.ts +15 -0
  30. package/dist/breakouts/utils.js +64 -0
  31. package/dist/breakouts/utils.js.map +1 -0
  32. package/dist/common/browser-detection.js +2 -3
  33. package/dist/common/browser-detection.js.map +1 -1
  34. package/dist/common/collection.js +3 -4
  35. package/dist/common/collection.js.map +1 -1
  36. package/dist/common/config.js +1 -2
  37. package/dist/common/config.js.map +1 -1
  38. package/dist/common/errors/captcha-error.js +1 -2
  39. package/dist/common/errors/captcha-error.js.map +1 -1
  40. package/dist/common/errors/intent-to-join.js +1 -2
  41. package/dist/common/errors/intent-to-join.js.map +1 -1
  42. package/dist/common/errors/join-meeting.js +1 -2
  43. package/dist/common/errors/join-meeting.js.map +1 -1
  44. package/dist/common/errors/media.js +1 -2
  45. package/dist/common/errors/media.js.map +1 -1
  46. package/dist/common/errors/no-meeting-info.d.ts +14 -0
  47. package/dist/common/errors/no-meeting-info.js +50 -0
  48. package/dist/common/errors/no-meeting-info.js.map +1 -0
  49. package/dist/common/errors/parameter.js +3 -4
  50. package/dist/common/errors/parameter.js.map +1 -1
  51. package/dist/common/errors/password-error.js +1 -2
  52. package/dist/common/errors/password-error.js.map +1 -1
  53. package/dist/common/errors/permission.js +1 -2
  54. package/dist/common/errors/permission.js.map +1 -1
  55. package/dist/common/errors/{reclaim-host-role-error.js → reclaim-host-role-errors.js} +7 -11
  56. package/dist/common/errors/reclaim-host-role-errors.js.map +1 -0
  57. package/dist/common/errors/reconnection-in-progress.js +1 -2
  58. package/dist/common/errors/reconnection-in-progress.js.map +1 -1
  59. package/dist/common/errors/reconnection.js +1 -2
  60. package/dist/common/errors/reconnection.js.map +1 -1
  61. package/dist/common/errors/stats.js +1 -2
  62. package/dist/common/errors/stats.js.map +1 -1
  63. package/dist/common/errors/webex-errors.d.ts +20 -8
  64. package/dist/common/errors/webex-errors.js +48 -28
  65. package/dist/common/errors/webex-errors.js.map +1 -1
  66. package/dist/common/errors/webex-meetings-error.js +1 -2
  67. package/dist/common/errors/webex-meetings-error.js.map +1 -1
  68. package/dist/common/events/events-scope.js +1 -2
  69. package/dist/common/events/events-scope.js.map +1 -1
  70. package/dist/common/events/events.js +1 -2
  71. package/dist/common/events/events.js.map +1 -1
  72. package/dist/common/events/trigger-proxy.js +1 -2
  73. package/dist/common/events/trigger-proxy.js.map +1 -1
  74. package/dist/common/events/util.js +1 -2
  75. package/dist/common/events/util.js.map +1 -1
  76. package/dist/common/logs/logger-config.js +1 -2
  77. package/dist/common/logs/logger-config.js.map +1 -1
  78. package/dist/common/logs/logger-proxy.js +2 -3
  79. package/dist/common/logs/logger-proxy.js.map +1 -1
  80. package/dist/common/logs/request.d.ts +3 -1
  81. package/dist/common/logs/request.js +8 -5
  82. package/dist/common/logs/request.js.map +1 -1
  83. package/dist/common/queue.d.ts +9 -7
  84. package/dist/common/queue.js +22 -9
  85. package/dist/common/queue.js.map +1 -1
  86. package/dist/config.d.ts +6 -7
  87. package/dist/config.js +8 -10
  88. package/dist/config.js.map +1 -1
  89. package/dist/constants.d.ts +234 -100
  90. package/dist/constants.js +433 -444
  91. package/dist/constants.js.map +1 -1
  92. package/dist/controls-options-manager/constants.js +3 -6
  93. package/dist/controls-options-manager/constants.js.map +1 -1
  94. package/dist/controls-options-manager/enums.d.ts +11 -1
  95. package/dist/controls-options-manager/enums.js +15 -6
  96. package/dist/controls-options-manager/enums.js.map +1 -1
  97. package/dist/controls-options-manager/index.d.ts +17 -1
  98. package/dist/controls-options-manager/index.js +127 -38
  99. package/dist/controls-options-manager/index.js.map +1 -1
  100. package/dist/controls-options-manager/types.d.ts +43 -0
  101. package/dist/controls-options-manager/types.js +7 -0
  102. package/dist/controls-options-manager/types.js.map +1 -0
  103. package/dist/controls-options-manager/util.d.ts +1 -7
  104. package/dist/controls-options-manager/util.js +309 -19
  105. package/dist/controls-options-manager/util.js.map +1 -1
  106. package/dist/index.d.ts +6 -3
  107. package/dist/index.js +121 -5
  108. package/dist/index.js.map +1 -1
  109. package/dist/interceptors/index.d.ts +2 -0
  110. package/dist/interceptors/index.js +15 -0
  111. package/dist/interceptors/index.js.map +1 -0
  112. package/dist/interceptors/locusRetry.d.ts +27 -0
  113. package/dist/interceptors/locusRetry.js +94 -0
  114. package/dist/interceptors/locusRetry.js.map +1 -0
  115. package/dist/interpretation/collection.d.ts +5 -0
  116. package/dist/interpretation/collection.js +22 -0
  117. package/dist/interpretation/collection.js.map +1 -0
  118. package/dist/interpretation/index.d.ts +5 -0
  119. package/dist/interpretation/index.js +365 -0
  120. package/dist/interpretation/index.js.map +1 -0
  121. package/dist/interpretation/siLanguage.d.ts +5 -0
  122. package/dist/interpretation/siLanguage.js +24 -0
  123. package/dist/interpretation/siLanguage.js.map +1 -0
  124. package/dist/locus-info/controlsUtils.js +100 -11
  125. package/dist/locus-info/controlsUtils.js.map +1 -1
  126. package/dist/locus-info/embeddedAppsUtils.js +3 -4
  127. package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
  128. package/dist/locus-info/fullState.js +1 -2
  129. package/dist/locus-info/fullState.js.map +1 -1
  130. package/dist/locus-info/hostUtils.js +1 -2
  131. package/dist/locus-info/hostUtils.js.map +1 -1
  132. package/dist/locus-info/index.d.ts +57 -4
  133. package/dist/locus-info/index.js +425 -84
  134. package/dist/locus-info/index.js.map +1 -1
  135. package/dist/locus-info/infoUtils.js +13 -5
  136. package/dist/locus-info/infoUtils.js.map +1 -1
  137. package/dist/locus-info/mediaSharesUtils.js +58 -3
  138. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  139. package/dist/locus-info/parser.d.ts +66 -6
  140. package/dist/locus-info/parser.js +253 -80
  141. package/dist/locus-info/parser.js.map +1 -1
  142. package/dist/locus-info/selfUtils.js +97 -13
  143. package/dist/locus-info/selfUtils.js.map +1 -1
  144. package/dist/media/index.d.ts +2 -0
  145. package/dist/media/index.js +107 -319
  146. package/dist/media/index.js.map +1 -1
  147. package/dist/media/properties.d.ts +38 -53
  148. package/dist/media/properties.js +96 -153
  149. package/dist/media/properties.js.map +1 -1
  150. package/dist/media/util.js +1 -22
  151. package/dist/media/util.js.map +1 -1
  152. package/dist/mediaQualityMetrics/config.d.ts +234 -230
  153. package/dist/mediaQualityMetrics/config.js +302 -498
  154. package/dist/mediaQualityMetrics/config.js.map +1 -1
  155. package/dist/meeting/in-meeting-actions.d.ts +88 -0
  156. package/dist/meeting/in-meeting-actions.js +94 -3
  157. package/dist/meeting/in-meeting-actions.js.map +1 -1
  158. package/dist/meeting/index.d.ts +705 -520
  159. package/dist/meeting/index.js +5047 -3089
  160. package/dist/meeting/index.js.map +1 -1
  161. package/dist/meeting/locusMediaRequest.d.ts +74 -0
  162. package/dist/meeting/locusMediaRequest.js +291 -0
  163. package/dist/meeting/locusMediaRequest.js.map +1 -0
  164. package/dist/meeting/muteState.d.ts +93 -25
  165. package/dist/meeting/muteState.js +224 -133
  166. package/dist/meeting/muteState.js.map +1 -1
  167. package/dist/meeting/request.d.ts +82 -47
  168. package/dist/meeting/request.js +304 -199
  169. package/dist/meeting/request.js.map +1 -1
  170. package/dist/meeting/request.type.d.ts +11 -0
  171. package/dist/meeting/request.type.js +7 -0
  172. package/dist/meeting/request.type.js.map +1 -0
  173. package/dist/meeting/state.js +1 -2
  174. package/dist/meeting/state.js.map +1 -1
  175. package/dist/meeting/util.d.ts +118 -1
  176. package/dist/meeting/util.js +676 -435
  177. package/dist/meeting/util.js.map +1 -1
  178. package/dist/meeting/voicea-meeting.d.ts +20 -0
  179. package/dist/meeting/voicea-meeting.js +201 -0
  180. package/dist/meeting/voicea-meeting.js.map +1 -0
  181. package/dist/meeting-info/collection.js +3 -4
  182. package/dist/meeting-info/collection.js.map +1 -1
  183. package/dist/meeting-info/index.d.ts +13 -1
  184. package/dist/meeting-info/index.js +74 -7
  185. package/dist/meeting-info/index.js.map +1 -1
  186. package/dist/meeting-info/meeting-info-v2.d.ts +31 -1
  187. package/dist/meeting-info/meeting-info-v2.js +200 -63
  188. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  189. package/dist/meeting-info/request.js +1 -2
  190. package/dist/meeting-info/request.js.map +1 -1
  191. package/dist/meeting-info/util.js +2 -3
  192. package/dist/meeting-info/util.js.map +1 -1
  193. package/dist/meeting-info/utilv2.js +39 -41
  194. package/dist/meeting-info/utilv2.js.map +1 -1
  195. package/dist/meetings/collection.d.ts +17 -0
  196. package/dist/meetings/collection.js +42 -4
  197. package/dist/meetings/collection.js.map +1 -1
  198. package/dist/meetings/index.d.ts +114 -20
  199. package/dist/meetings/index.js +540 -126
  200. package/dist/meetings/index.js.map +1 -1
  201. package/dist/meetings/meetings.types.d.ts +4 -0
  202. package/dist/meetings/meetings.types.js +7 -0
  203. package/dist/meetings/meetings.types.js.map +1 -0
  204. package/dist/meetings/request.js +4 -3
  205. package/dist/meetings/request.js.map +1 -1
  206. package/dist/meetings/util.js +107 -6
  207. package/dist/meetings/util.js.map +1 -1
  208. package/dist/member/index.d.ts +13 -1
  209. package/dist/member/index.js +45 -2
  210. package/dist/member/index.js.map +1 -1
  211. package/dist/member/member.types.js +3 -4
  212. package/dist/member/member.types.js.map +1 -1
  213. package/dist/member/types.d.ts +32 -0
  214. package/dist/member/types.js +23 -0
  215. package/dist/member/types.js.map +1 -0
  216. package/dist/member/util.js +120 -29
  217. package/dist/member/util.js.map +1 -1
  218. package/dist/members/collection.d.ts +5 -0
  219. package/dist/members/collection.js +11 -2
  220. package/dist/members/collection.js.map +1 -1
  221. package/dist/members/index.d.ts +56 -11
  222. package/dist/members/index.js +174 -47
  223. package/dist/members/index.js.map +1 -1
  224. package/dist/members/request.d.ts +67 -11
  225. package/dist/members/request.js +102 -54
  226. package/dist/members/request.js.map +1 -1
  227. package/dist/members/types.js +3 -4
  228. package/dist/members/types.js.map +1 -1
  229. package/dist/members/util.d.ts +214 -1
  230. package/dist/members/util.js +327 -284
  231. package/dist/members/util.js.map +1 -1
  232. package/dist/metrics/constants.d.ts +15 -6
  233. package/dist/metrics/constants.js +17 -9
  234. package/dist/metrics/constants.js.map +1 -1
  235. package/dist/metrics/index.d.ts +4 -111
  236. package/dist/metrics/index.js +4 -452
  237. package/dist/metrics/index.js.map +1 -1
  238. package/dist/multistream/mediaRequestManager.d.ts +118 -0
  239. package/dist/multistream/mediaRequestManager.js +344 -0
  240. package/dist/multistream/mediaRequestManager.js.map +1 -0
  241. package/dist/multistream/receiveSlot.d.ts +68 -0
  242. package/dist/multistream/receiveSlot.js +200 -0
  243. package/dist/multistream/receiveSlot.js.map +1 -0
  244. package/dist/multistream/receiveSlotManager.d.ts +56 -0
  245. package/dist/multistream/receiveSlotManager.js +174 -0
  246. package/dist/multistream/receiveSlotManager.js.map +1 -0
  247. package/dist/multistream/remoteMedia.d.ts +72 -0
  248. package/dist/multistream/remoteMedia.js +268 -0
  249. package/dist/multistream/remoteMedia.js.map +1 -0
  250. package/dist/multistream/remoteMediaGroup.d.ts +47 -0
  251. package/dist/multistream/remoteMediaGroup.js +267 -0
  252. package/dist/multistream/remoteMediaGroup.js.map +1 -0
  253. package/dist/multistream/remoteMediaManager.d.ts +285 -0
  254. package/dist/multistream/remoteMediaManager.js +1211 -0
  255. package/dist/multistream/remoteMediaManager.js.map +1 -0
  256. package/dist/multistream/sendSlotManager.d.ts +61 -0
  257. package/dist/multistream/sendSlotManager.js +236 -0
  258. package/dist/multistream/sendSlotManager.js.map +1 -0
  259. package/dist/networkQualityMonitor/index.js +5 -4
  260. package/dist/networkQualityMonitor/index.js.map +1 -1
  261. package/dist/personal-meeting-room/index.js +2 -3
  262. package/dist/personal-meeting-room/index.js.map +1 -1
  263. package/dist/personal-meeting-room/request.js +2 -3
  264. package/dist/personal-meeting-room/request.js.map +1 -1
  265. package/dist/personal-meeting-room/util.js +1 -2
  266. package/dist/personal-meeting-room/util.js.map +1 -1
  267. package/dist/reachability/clusterReachability.d.ts +109 -0
  268. package/dist/reachability/clusterReachability.js +357 -0
  269. package/dist/reachability/clusterReachability.js.map +1 -0
  270. package/dist/reachability/index.d.ts +61 -95
  271. package/dist/reachability/index.js +304 -392
  272. package/dist/reachability/index.js.map +1 -1
  273. package/dist/reachability/request.d.ts +7 -3
  274. package/dist/reachability/request.js +18 -10
  275. package/dist/reachability/request.js.map +1 -1
  276. package/dist/reachability/util.d.ts +8 -0
  277. package/dist/reachability/util.js +29 -0
  278. package/dist/reachability/util.js.map +1 -0
  279. package/dist/reactions/constants.d.ts +3 -0
  280. package/dist/reactions/constants.js +12 -0
  281. package/dist/reactions/constants.js.map +1 -0
  282. package/dist/reactions/reactions.d.ts +2 -2
  283. package/dist/reactions/reactions.js +4 -6
  284. package/dist/reactions/reactions.js.map +1 -1
  285. package/dist/reactions/reactions.type.d.ts +23 -3
  286. package/dist/reactions/reactions.type.js +21 -23
  287. package/dist/reactions/reactions.type.js.map +1 -1
  288. package/dist/reconnection-manager/index.d.ts +32 -8
  289. package/dist/reconnection-manager/index.js +285 -232
  290. package/dist/reconnection-manager/index.js.map +1 -1
  291. package/dist/recording-controller/enums.js +4 -5
  292. package/dist/recording-controller/enums.js.map +1 -1
  293. package/dist/recording-controller/index.d.ts +15 -1
  294. package/dist/recording-controller/index.js +57 -46
  295. package/dist/recording-controller/index.js.map +1 -1
  296. package/dist/recording-controller/util.d.ts +5 -4
  297. package/dist/recording-controller/util.js +10 -10
  298. package/dist/recording-controller/util.js.map +1 -1
  299. package/dist/roap/index.d.ts +9 -47
  300. package/dist/roap/index.js +100 -238
  301. package/dist/roap/index.js.map +1 -1
  302. package/dist/roap/request.d.ts +18 -12
  303. package/dist/roap/request.js +126 -180
  304. package/dist/roap/request.js.map +1 -1
  305. package/dist/roap/turnDiscovery.d.ts +27 -16
  306. package/dist/roap/turnDiscovery.js +115 -105
  307. package/dist/roap/turnDiscovery.js.map +1 -1
  308. package/dist/rtcMetrics/constants.d.ts +4 -0
  309. package/dist/rtcMetrics/constants.js +11 -0
  310. package/dist/rtcMetrics/constants.js.map +1 -0
  311. package/dist/rtcMetrics/index.d.ts +54 -0
  312. package/dist/rtcMetrics/index.js +140 -0
  313. package/dist/rtcMetrics/index.js.map +1 -0
  314. package/dist/statsAnalyzer/global.d.ts +1 -83
  315. package/dist/statsAnalyzer/global.js +2 -85
  316. package/dist/statsAnalyzer/global.js.map +1 -1
  317. package/dist/statsAnalyzer/index.d.ts +50 -30
  318. package/dist/statsAnalyzer/index.js +436 -511
  319. package/dist/statsAnalyzer/index.js.map +1 -1
  320. package/dist/statsAnalyzer/mqaUtil.d.ts +8 -6
  321. package/dist/statsAnalyzer/mqaUtil.js +130 -90
  322. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  323. package/dist/transcription/index.js +1 -2
  324. package/dist/transcription/index.js.map +1 -1
  325. package/dist/webinar/collection.d.ts +16 -0
  326. package/dist/webinar/collection.js +43 -0
  327. package/dist/webinar/collection.js.map +1 -0
  328. package/dist/webinar/index.d.ts +5 -0
  329. package/dist/webinar/index.js +68 -0
  330. package/dist/webinar/index.js.map +1 -0
  331. package/package.json +39 -26
  332. package/src/annotation/annotation.types.ts +50 -0
  333. package/src/annotation/constants.ts +36 -0
  334. package/src/annotation/index.ts +328 -0
  335. package/src/breakouts/README.md +220 -0
  336. package/src/breakouts/breakout.ts +188 -0
  337. package/src/breakouts/collection.ts +19 -0
  338. package/src/breakouts/edit-lock-error.ts +25 -0
  339. package/src/breakouts/events.ts +56 -0
  340. package/src/breakouts/index.ts +925 -0
  341. package/src/breakouts/request.ts +55 -0
  342. package/src/breakouts/utils.ts +57 -0
  343. package/src/common/errors/no-meeting-info.ts +24 -0
  344. package/src/common/errors/webex-errors.ts +36 -12
  345. package/src/common/logs/logger-proxy.ts +1 -1
  346. package/src/common/logs/request.ts +5 -1
  347. package/src/common/queue.ts +22 -8
  348. package/src/config.ts +6 -7
  349. package/src/constants.ts +265 -100
  350. package/src/controls-options-manager/enums.ts +12 -0
  351. package/src/controls-options-manager/index.ts +116 -21
  352. package/src/controls-options-manager/types.ts +59 -0
  353. package/src/controls-options-manager/util.ts +294 -14
  354. package/src/index.ts +44 -0
  355. package/src/interceptors/index.ts +3 -0
  356. package/src/interceptors/locusRetry.ts +67 -0
  357. package/src/interpretation/README.md +60 -0
  358. package/src/interpretation/collection.ts +19 -0
  359. package/src/interpretation/index.ts +332 -0
  360. package/src/interpretation/siLanguage.ts +18 -0
  361. package/src/locus-info/controlsUtils.ts +110 -0
  362. package/src/locus-info/index.ts +450 -61
  363. package/src/locus-info/infoUtils.ts +14 -2
  364. package/src/locus-info/mediaSharesUtils.ts +64 -0
  365. package/src/locus-info/parser.ts +258 -47
  366. package/src/locus-info/selfUtils.ts +85 -2
  367. package/src/media/index.ts +153 -370
  368. package/src/media/properties.ts +106 -136
  369. package/src/media/util.ts +0 -21
  370. package/src/mediaQualityMetrics/config.ts +244 -377
  371. package/src/meeting/in-meeting-actions.ts +176 -0
  372. package/src/meeting/index.ts +4306 -2581
  373. package/src/meeting/locusMediaRequest.ts +313 -0
  374. package/src/meeting/muteState.ts +224 -138
  375. package/src/meeting/request.ts +214 -127
  376. package/src/meeting/request.type.ts +13 -0
  377. package/src/meeting/util.ts +687 -423
  378. package/src/meeting/voicea-meeting.ts +161 -0
  379. package/src/meeting-info/index.ts +81 -8
  380. package/src/meeting-info/meeting-info-v2.ts +163 -13
  381. package/src/meeting-info/util.ts +1 -1
  382. package/src/meeting-info/utilv2.ts +28 -28
  383. package/src/meetings/collection.ts +33 -0
  384. package/src/meetings/index.ts +529 -127
  385. package/src/meetings/meetings.types.ts +12 -0
  386. package/src/meetings/request.ts +2 -0
  387. package/src/meetings/util.ts +116 -5
  388. package/src/member/index.ts +43 -1
  389. package/src/member/types.ts +38 -0
  390. package/src/member/util.ts +125 -28
  391. package/src/members/collection.ts +8 -0
  392. package/src/members/index.ts +187 -52
  393. package/src/members/request.ts +87 -27
  394. package/src/members/util.ts +332 -291
  395. package/src/metrics/constants.ts +15 -6
  396. package/src/metrics/index.ts +1 -471
  397. package/src/multistream/mediaRequestManager.ts +440 -0
  398. package/src/multistream/receiveSlot.ts +184 -0
  399. package/src/multistream/receiveSlotManager.ts +166 -0
  400. package/src/multistream/remoteMedia.ts +254 -0
  401. package/src/multistream/remoteMediaGroup.ts +284 -0
  402. package/src/multistream/remoteMediaManager.ts +1145 -0
  403. package/src/multistream/sendSlotManager.ts +170 -0
  404. package/src/networkQualityMonitor/index.ts +6 -6
  405. package/src/reachability/clusterReachability.ts +320 -0
  406. package/src/reachability/index.ts +246 -347
  407. package/src/reachability/request.ts +17 -8
  408. package/src/reachability/util.ts +24 -0
  409. package/src/reactions/constants.ts +4 -0
  410. package/src/reactions/reactions.ts +4 -4
  411. package/src/reactions/reactions.type.ts +30 -4
  412. package/src/reconnection-manager/index.ts +168 -156
  413. package/src/recording-controller/index.ts +20 -3
  414. package/src/recording-controller/util.ts +26 -9
  415. package/src/roap/index.ts +96 -241
  416. package/src/roap/request.ts +74 -148
  417. package/src/roap/turnDiscovery.ts +62 -56
  418. package/src/rtcMetrics/constants.ts +3 -0
  419. package/src/rtcMetrics/index.ts +124 -0
  420. package/src/statsAnalyzer/global.ts +1 -84
  421. package/src/statsAnalyzer/index.ts +479 -645
  422. package/src/statsAnalyzer/mqaUtil.ts +128 -126
  423. package/src/webinar/collection.ts +31 -0
  424. package/src/webinar/index.ts +62 -0
  425. package/test/integration/spec/converged-space-meetings.js +233 -0
  426. package/test/integration/spec/journey.js +320 -264
  427. package/test/integration/spec/space-meeting.js +77 -4
  428. package/test/unit/spec/annotation/index.ts +418 -0
  429. package/test/unit/spec/breakouts/breakout.ts +237 -0
  430. package/test/unit/spec/breakouts/collection.ts +15 -0
  431. package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
  432. package/test/unit/spec/breakouts/events.ts +89 -0
  433. package/test/unit/spec/breakouts/index.ts +1790 -0
  434. package/test/unit/spec/breakouts/request.ts +104 -0
  435. package/test/unit/spec/breakouts/utils.js +72 -0
  436. package/test/unit/spec/common/queue.js +31 -2
  437. package/test/unit/spec/controls-options-manager/index.js +163 -0
  438. package/test/unit/spec/controls-options-manager/util.js +576 -60
  439. package/test/unit/spec/fixture/locus.js +1 -0
  440. package/test/unit/spec/interceptors/locusRetry.ts +131 -0
  441. package/test/unit/spec/interpretation/collection.ts +15 -0
  442. package/test/unit/spec/interpretation/index.ts +589 -0
  443. package/test/unit/spec/interpretation/siLanguage.ts +28 -0
  444. package/test/unit/spec/locus-info/controlsUtils.js +323 -30
  445. package/test/unit/spec/locus-info/index.js +1438 -16
  446. package/test/unit/spec/locus-info/infoUtils.js +54 -16
  447. package/test/unit/spec/locus-info/lib/SeqCmp.json +16 -0
  448. package/test/unit/spec/locus-info/lib/selfConstant.js +48 -0
  449. package/test/unit/spec/locus-info/mediaSharesUtils.ts +32 -0
  450. package/test/unit/spec/locus-info/parser.js +116 -35
  451. package/test/unit/spec/locus-info/selfUtils.js +275 -0
  452. package/test/unit/spec/media/index.ts +290 -0
  453. package/test/unit/spec/media/properties.ts +75 -84
  454. package/test/unit/spec/meeting/in-meeting-actions.ts +86 -0
  455. package/test/unit/spec/meeting/index.js +8886 -2815
  456. package/test/unit/spec/meeting/locusMediaRequest.ts +442 -0
  457. package/test/unit/spec/meeting/muteState.js +409 -213
  458. package/test/unit/spec/meeting/request.js +523 -43
  459. package/test/unit/spec/meeting/utils.js +834 -24
  460. package/test/unit/spec/meeting-info/index.js +300 -0
  461. package/test/unit/spec/meeting-info/meetinginfov2.js +527 -5
  462. package/test/unit/spec/meeting-info/utilv2.js +21 -0
  463. package/test/unit/spec/meetings/collection.js +26 -0
  464. package/test/unit/spec/meetings/index.js +1446 -217
  465. package/test/unit/spec/meetings/utils.js +202 -2
  466. package/test/unit/spec/member/index.js +32 -9
  467. package/test/unit/spec/member/util.js +499 -61
  468. package/test/unit/spec/members/index.js +394 -5
  469. package/test/unit/spec/members/request.js +206 -27
  470. package/test/unit/spec/members/utils.js +173 -38
  471. package/test/unit/spec/metrics/index.js +1 -50
  472. package/test/unit/spec/multistream/mediaRequestManager.ts +1418 -0
  473. package/test/unit/spec/multistream/receiveSlot.ts +163 -0
  474. package/test/unit/spec/multistream/receiveSlotManager.ts +203 -0
  475. package/test/unit/spec/multistream/remoteMedia.ts +255 -0
  476. package/test/unit/spec/multistream/remoteMediaGroup.ts +662 -0
  477. package/test/unit/spec/multistream/remoteMediaManager.ts +1924 -0
  478. package/test/unit/spec/multistream/sendSlotManager.ts +242 -0
  479. package/test/unit/spec/networkQualityMonitor/index.js +4 -4
  480. package/test/unit/spec/reachability/clusterReachability.ts +279 -0
  481. package/test/unit/spec/reachability/index.ts +532 -24
  482. package/test/unit/spec/reachability/request.js +68 -0
  483. package/test/unit/spec/reachability/util.ts +40 -0
  484. package/test/unit/spec/reconnection-manager/index.js +163 -24
  485. package/test/unit/spec/recording-controller/index.js +293 -218
  486. package/test/unit/spec/recording-controller/util.js +223 -96
  487. package/test/unit/spec/roap/index.ts +187 -77
  488. package/test/unit/spec/roap/request.ts +255 -0
  489. package/test/unit/spec/roap/turnDiscovery.ts +86 -48
  490. package/test/unit/spec/rtcMetrics/index.ts +93 -0
  491. package/test/unit/spec/stats-analyzer/index.js +644 -165
  492. package/test/unit/spec/webinar/collection.ts +13 -0
  493. package/test/unit/spec/webinar/index.ts +60 -0
  494. package/test/utils/constants.js +9 -0
  495. package/test/utils/integrationTestUtils.js +46 -0
  496. package/test/utils/testUtils.js +0 -45
  497. package/test/utils/webex-config.js +4 -0
  498. package/test/utils/webex-test-users.js +7 -3
  499. package/dist/common/errors/reclaim-host-role-error.js.map +0 -1
  500. package/dist/meeting/effectsState.d.ts +0 -42
  501. package/dist/meeting/effectsState.js +0 -260
  502. package/dist/meeting/effectsState.js.map +0 -1
  503. package/dist/metrics/config.d.ts +0 -169
  504. package/dist/metrics/config.js +0 -289
  505. package/dist/metrics/config.js.map +0 -1
  506. package/dist/peer-connection-manager/index.d.ts +0 -6
  507. package/dist/peer-connection-manager/index.js +0 -671
  508. package/dist/peer-connection-manager/index.js.map +0 -1
  509. package/dist/peer-connection-manager/util.d.ts +0 -6
  510. package/dist/peer-connection-manager/util.js +0 -110
  511. package/dist/peer-connection-manager/util.js.map +0 -1
  512. package/dist/roap/collection.d.ts +0 -10
  513. package/dist/roap/collection.js +0 -63
  514. package/dist/roap/collection.js.map +0 -1
  515. package/dist/roap/handler.d.ts +0 -47
  516. package/dist/roap/handler.js +0 -279
  517. package/dist/roap/handler.js.map +0 -1
  518. package/dist/roap/state.d.ts +0 -9
  519. package/dist/roap/state.js +0 -127
  520. package/dist/roap/state.js.map +0 -1
  521. package/dist/roap/util.d.ts +0 -2
  522. package/dist/roap/util.js +0 -76
  523. package/dist/roap/util.js.map +0 -1
  524. package/src/index.js +0 -15
  525. package/src/meeting/effectsState.ts +0 -209
  526. package/src/metrics/config.ts +0 -485
  527. package/src/peer-connection-manager/index.ts +0 -847
  528. package/src/peer-connection-manager/util.ts +0 -119
  529. package/src/roap/collection.ts +0 -62
  530. package/src/roap/handler.ts +0 -294
  531. package/src/roap/state.ts +0 -156
  532. package/src/roap/util.ts +0 -100
  533. package/test/unit/spec/meeting/effectsState.js +0 -281
  534. package/test/unit/spec/peerconnection-manager/index.js +0 -218
  535. package/test/unit/spec/peerconnection-manager/utils.js +0 -49
  536. package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -388
  537. package/test/unit/spec/roap/util.js +0 -30
  538. /package/dist/common/errors/{reclaim-host-role-error.d.ts → reclaim-host-role-errors.d.ts} +0 -0
  539. /package/src/common/errors/{reclaim-host-role-error.ts → reclaim-host-role-errors.ts} +0 -0
@@ -0,0 +1,662 @@
1
+ import EventEmitter from 'events';
2
+
3
+ import {MediaType} from '@webex/internal-media-core';
4
+ import {RemoteMediaGroup} from '@webex/plugin-meetings/src/multistream/remoteMediaGroup';
5
+ import {RemoteMedia} from '@webex/plugin-meetings/src/multistream/remoteMedia';
6
+ import {ReceiveSlot} from '@webex/plugin-meetings/src/multistream/receiveSlot';
7
+ import sinon from 'sinon';
8
+ import {assert} from '@webex/test-helper-chai';
9
+
10
+ class FakeSlot extends EventEmitter {
11
+ public mediaType: MediaType;
12
+
13
+ public id: string;
14
+
15
+ constructor(mediaType: MediaType, id: string) {
16
+ super();
17
+ this.mediaType = mediaType;
18
+ this.id = id;
19
+ }
20
+ }
21
+
22
+ describe('RemoteMediaGroup', () => {
23
+ const NUM_SLOTS = 10;
24
+
25
+ let fakeMediaRequestManager;
26
+ let fakeReceiveSlots;
27
+
28
+ let activeSpeakerRequestCounter;
29
+ let receiverSelectedRequestCounter;
30
+
31
+ beforeEach(() => {
32
+ activeSpeakerRequestCounter = 0;
33
+ receiverSelectedRequestCounter = 0;
34
+
35
+ fakeMediaRequestManager = {
36
+ addRequest: sinon.stub().callsFake((mediaRequest) => {
37
+ if (mediaRequest.policyInfo.policy === 'active-speaker') {
38
+ activeSpeakerRequestCounter += 1;
39
+
40
+ return `fake active speaker request ${activeSpeakerRequestCounter}`;
41
+ }
42
+ receiverSelectedRequestCounter += 1;
43
+
44
+ return `fake receiver selected request ${receiverSelectedRequestCounter}`;
45
+ }),
46
+ cancelRequest: sinon.stub(),
47
+ commit: sinon.stub(),
48
+ };
49
+
50
+ fakeReceiveSlots = Array(NUM_SLOTS)
51
+ .fill(null)
52
+ .map((_, index) => new FakeSlot(MediaType.VideoMain, `fake receive slot ${index}`));
53
+ });
54
+
55
+ const getLastActiveSpeakerRequestId = () =>
56
+ `fake active speaker request ${activeSpeakerRequestCounter}`;
57
+
58
+ const resetHistory = () => {
59
+ fakeMediaRequestManager.addRequest.resetHistory();
60
+ fakeMediaRequestManager.cancelRequest.resetHistory();
61
+ fakeMediaRequestManager.commit.resetHistory();
62
+ };
63
+
64
+ describe('constructor', () => {
65
+ it('creates a list or RemoteMedia objects and sends the active speaker media request', () => {
66
+ const group = new RemoteMediaGroup(fakeMediaRequestManager, fakeReceiveSlots, 211, true, {
67
+ resolution: 'medium',
68
+ preferLiveVideo: true,
69
+ });
70
+
71
+ assert.strictEqual(group.getRemoteMedia().length, NUM_SLOTS);
72
+ assert.strictEqual(group.getRemoteMedia('all').length, NUM_SLOTS);
73
+ assert.strictEqual(group.getRemoteMedia('unpinned').length, NUM_SLOTS);
74
+ assert.strictEqual(group.getRemoteMedia('pinned').length, 0);
75
+
76
+ assert.strictEqual(
77
+ group.getRemoteMedia('all').every((item) => item instanceof RemoteMedia),
78
+ true
79
+ );
80
+
81
+ assert.calledOnce(fakeMediaRequestManager.addRequest);
82
+ assert.calledWith(
83
+ fakeMediaRequestManager.addRequest,
84
+ sinon.match({
85
+ policyInfo: sinon.match({
86
+ policy: 'active-speaker',
87
+ priority: 211,
88
+ }),
89
+ receiveSlots: fakeReceiveSlots,
90
+ codecInfo: sinon.match({
91
+ codec: 'h264',
92
+ maxFs: 3600,
93
+ }),
94
+ }),
95
+ true
96
+ );
97
+ });
98
+ });
99
+
100
+ describe('setPreferLiveVideo', () => {
101
+ it('updates prefer live video', () => {
102
+
103
+ const group = new RemoteMediaGroup(fakeMediaRequestManager, fakeReceiveSlots, 255, true, {
104
+ resolution: 'medium',
105
+ preferLiveVideo: false,
106
+ });
107
+ fakeMediaRequestManager.addRequest.resetHistory();
108
+ group.setPreferLiveVideo(true, false);
109
+
110
+ assert.calledOnce(fakeMediaRequestManager.cancelRequest);
111
+
112
+ assert.calledOnce(fakeMediaRequestManager.addRequest);
113
+
114
+ assert.calledWith(
115
+ fakeMediaRequestManager.addRequest,
116
+ sinon.match({
117
+ policyInfo: sinon.match({
118
+ policy: 'active-speaker',
119
+ priority: 255,
120
+ preferLiveVideo: true
121
+ }),
122
+ receiveSlots: fakeReceiveSlots,
123
+ codecInfo: sinon.match({
124
+ codec: 'h264',
125
+ maxFs: 3600,
126
+ }),
127
+ }),
128
+ false,
129
+ );
130
+ });
131
+
132
+ it('does not call add request when prefer live video has not changed', () => {
133
+ const group = new RemoteMediaGroup(fakeMediaRequestManager, fakeReceiveSlots, 255, true, {
134
+ resolution: 'medium',
135
+ preferLiveVideo: true,
136
+ });
137
+ fakeMediaRequestManager.addRequest.resetHistory();
138
+ group.setPreferLiveVideo(true, false);
139
+
140
+ assert.notCalled(fakeMediaRequestManager.cancelRequest);
141
+
142
+ assert.notCalled(fakeMediaRequestManager.addRequest);
143
+ });
144
+
145
+ });
146
+
147
+ describe('setActiveSpeakerCsis', () => {
148
+ it('checks when there is a csi and remote media is not in pinned array', () => {
149
+ const PINNED_INDEX = 2;
150
+ const CSI = 11111;
151
+
152
+ const group = new RemoteMediaGroup(fakeMediaRequestManager, fakeReceiveSlots, 255, true, {
153
+ resolution: 'medium',
154
+ preferLiveVideo: true,
155
+ });
156
+
157
+ // initially nothing should be pinned
158
+ assert.strictEqual(group.getRemoteMedia().length, NUM_SLOTS); // by default should return 'all'
159
+ assert.strictEqual(group.getRemoteMedia('all').length, NUM_SLOTS);
160
+ assert.strictEqual(group.getRemoteMedia('unpinned').length, NUM_SLOTS);
161
+ assert.strictEqual(group.getRemoteMedia('pinned').length, 0);
162
+
163
+ const remoteMedia = group.getRemoteMedia('all')[PINNED_INDEX];
164
+
165
+ resetHistory();
166
+
167
+ group.setActiveSpeakerCsis([{remoteMedia, csi: CSI}], false);
168
+
169
+ assert.strictEqual(group.getRemoteMedia().length, NUM_SLOTS); // by default should return 'all'
170
+ assert.strictEqual(group.getRemoteMedia('all').length, NUM_SLOTS);
171
+ assert.strictEqual(group.getRemoteMedia('unpinned').length, NUM_SLOTS - 1);
172
+ assert.strictEqual(group.getRemoteMedia('pinned').length, 1);
173
+
174
+ assert.strictEqual(group.isPinned(remoteMedia), true);
175
+ // now check that correct media requests were sent...
176
+
177
+ const expectedReceiverSelectedSlots = [fakeReceiveSlots[PINNED_INDEX]];
178
+ const expectedActiveSpeakerReceiveSlots = fakeReceiveSlots.filter(
179
+ (_, idx) => idx !== PINNED_INDEX
180
+ );
181
+
182
+ // the previous active speaker media request for the group should have been cancelled
183
+ assert.calledOnce(fakeMediaRequestManager.cancelRequest);
184
+ assert.calledWith(fakeMediaRequestManager.cancelRequest, 'fake active speaker request 1');
185
+ // a new one should be sent for active speaker and for receiver selected
186
+ assert.calledTwice(fakeMediaRequestManager.addRequest);
187
+ assert.calledWith(
188
+ fakeMediaRequestManager.addRequest,
189
+ sinon.match({
190
+ policyInfo: sinon.match({
191
+ policy: 'active-speaker',
192
+ priority: 255,
193
+ }),
194
+ receiveSlots: expectedActiveSpeakerReceiveSlots,
195
+ codecInfo: sinon.match({
196
+ codec: 'h264',
197
+ maxFs: 3600,
198
+ }),
199
+ })
200
+ );
201
+ assert.calledWith(
202
+ fakeMediaRequestManager.addRequest,
203
+ sinon.match({
204
+ policyInfo: sinon.match({
205
+ policy: 'receiver-selected',
206
+ csi: CSI,
207
+ }),
208
+ receiveSlots: expectedReceiverSelectedSlots,
209
+ codecInfo: sinon.match({
210
+ codec: 'h264',
211
+ maxFs: 3600,
212
+ }),
213
+ })
214
+ );
215
+ assert.notCalled(fakeMediaRequestManager.commit);
216
+ });
217
+
218
+ it('checks when there is csi and remoteMedia is in pinned array', () => {
219
+ const PINNED_INDEX = 4;
220
+
221
+ const group = new RemoteMediaGroup(fakeMediaRequestManager, fakeReceiveSlots, 255, true, {
222
+ resolution: 'medium',
223
+ preferLiveVideo: true,
224
+ });
225
+
226
+ // take one instance of remote media from the group
227
+ const remoteMedia = group.getRemoteMedia('all')[PINNED_INDEX];
228
+
229
+ resetHistory();
230
+
231
+ // pin it so that it is in pinned array
232
+ group.setActiveSpeakerCsis([{remoteMedia, csi: 1234}], false);
233
+
234
+ assert.strictEqual(group.getRemoteMedia().length, NUM_SLOTS); // by default should return 'all'
235
+ assert.strictEqual(group.getRemoteMedia('all').length, NUM_SLOTS);
236
+ assert.strictEqual(group.getRemoteMedia('unpinned').length, NUM_SLOTS - 1);
237
+ assert.strictEqual(group.getRemoteMedia('pinned').length, 1);
238
+
239
+ resetHistory();
240
+ // normally this would result in the underlying receive slot csi to be updated, because we're using fake
241
+ // receive slots, we have to do that manually:
242
+ fakeReceiveSlots[PINNED_INDEX].csi = 1234;
243
+ const expectedReceiverSelectedSlots = [fakeReceiveSlots[PINNED_INDEX]];
244
+
245
+ // pin again to same CSI
246
+ group.setActiveSpeakerCsis([{remoteMedia, csi: 1234}], false);
247
+
248
+ assert.strictEqual(group.getRemoteMedia().length, NUM_SLOTS); // by default should return 'all'
249
+ assert.strictEqual(group.getRemoteMedia('all').length, NUM_SLOTS);
250
+ assert.strictEqual(group.getRemoteMedia('unpinned').length, NUM_SLOTS - 1);
251
+ assert.strictEqual(group.getRemoteMedia('pinned').length, 1);
252
+
253
+ assert.strictEqual(group.isPinned(remoteMedia), true);
254
+
255
+ assert.calledTwice(fakeMediaRequestManager.cancelRequest);
256
+ assert.calledWith(fakeMediaRequestManager.cancelRequest, 'fake receiver selected request 1');
257
+
258
+ assert.calledWith(
259
+ fakeMediaRequestManager.addRequest,
260
+ sinon.match({
261
+ policyInfo: sinon.match({
262
+ policy: 'receiver-selected',
263
+ csi: 1234,
264
+ }),
265
+ receiveSlots: expectedReceiverSelectedSlots,
266
+ codecInfo: sinon.match({
267
+ codec: 'h264',
268
+ maxFs: 3600,
269
+ }),
270
+ })
271
+ );
272
+ assert.notCalled(fakeMediaRequestManager.commit);
273
+ });
274
+
275
+ it('checks setActiveSpeakerCsis with array of remoteMedia to pin and unpin', () => {
276
+ const PINNED_INDEX = 2;
277
+ const PINNED_INDEX2 = 0;
278
+ const CSI = 11111;
279
+ const CSI2 = 12345;
280
+
281
+ const group = new RemoteMediaGroup(fakeMediaRequestManager, fakeReceiveSlots, 255, true, {
282
+ resolution: 'medium',
283
+ preferLiveVideo: true,
284
+ });
285
+
286
+ // initially nothing should be pinned
287
+ assert.strictEqual(group.getRemoteMedia().length, NUM_SLOTS); // by default should return 'all'
288
+ assert.strictEqual(group.getRemoteMedia('all').length, NUM_SLOTS);
289
+ assert.strictEqual(group.getRemoteMedia('unpinned').length, NUM_SLOTS);
290
+ assert.strictEqual(group.getRemoteMedia('pinned').length, 0);
291
+
292
+ const remoteMedia = group.getRemoteMedia('all')[PINNED_INDEX];
293
+
294
+ const remoteMedia2 = group.getRemoteMedia('all')[PINNED_INDEX2];
295
+
296
+ const remoteMedisCsis = [{remoteMedia, csi: CSI}, {remoteMedia: remoteMedia2, csi: CSI2}];
297
+
298
+ group.setActiveSpeakerCsis(remoteMedisCsis, false);
299
+
300
+ assert.strictEqual(group.getRemoteMedia().length, NUM_SLOTS);
301
+ assert.strictEqual(group.getRemoteMedia('all').length, NUM_SLOTS);
302
+ assert.strictEqual(group.getRemoteMedia('unpinned').length, NUM_SLOTS - 2);
303
+ assert.strictEqual(group.getRemoteMedia('pinned').length, 2);
304
+
305
+ assert.strictEqual(group.isPinned(remoteMedia), true);
306
+ assert.strictEqual(group.isPinned(remoteMedia2), true);
307
+
308
+ resetHistory();
309
+
310
+ group.setActiveSpeakerCsis([{remoteMedia}], false);
311
+
312
+ // one pane should still remain pinned
313
+ assert.strictEqual(group.getRemoteMedia().length, NUM_SLOTS);
314
+ assert.strictEqual(group.getRemoteMedia('all').length, NUM_SLOTS);
315
+ assert.strictEqual(group.getRemoteMedia('unpinned').length, NUM_SLOTS - 1);
316
+ assert.strictEqual(group.getRemoteMedia('pinned').length, 1);
317
+ assert.strictEqual(group.isPinned(remoteMedia), false);
318
+ assert.strictEqual(group.isPinned(remoteMedia2), true);
319
+
320
+ assert.calledTwice(fakeMediaRequestManager.cancelRequest);
321
+ assert.calledWith(fakeMediaRequestManager.cancelRequest, 'fake receiver selected request 1');
322
+ assert.notCalled(fakeMediaRequestManager.commit);
323
+ });
324
+
325
+ it('check commit is only called once', () => {
326
+ const PINNED_INDEX = 2;
327
+ const PINNED_INDEX2 = 0;
328
+ const CSI = 11111;
329
+ const CSI2 = 12345;
330
+
331
+ const group = new RemoteMediaGroup(fakeMediaRequestManager, fakeReceiveSlots, 255, true, {
332
+ resolution: 'medium',
333
+ preferLiveVideo: true,
334
+ });
335
+
336
+ const remoteMedia = group.getRemoteMedia('all')[PINNED_INDEX];
337
+
338
+ resetHistory();
339
+
340
+ const remoteMedia2 = group.getRemoteMedia('all')[PINNED_INDEX2];
341
+
342
+ const remoteMedisCsis = [{remoteMedia, csi: CSI}, {remoteMedia: remoteMedia2, csi: CSI2}, {remoteMedia}];
343
+
344
+ group.setActiveSpeakerCsis(remoteMedisCsis, true);
345
+
346
+ assert.calledOnce(fakeMediaRequestManager.commit);
347
+ });
348
+
349
+ it('throws when remoteMedia id is not in unpinned and pinned array - csi is there', () => {
350
+ const group = new RemoteMediaGroup(fakeMediaRequestManager, fakeReceiveSlots, 255, true, {
351
+ resolution: 'medium',
352
+ preferLiveVideo: true,
353
+ });
354
+ assert.throws(() => group.setActiveSpeakerCsis([{remoteMedia: {id: 'r1'} as any, csi: 123}], false), 'failed to pin a remote media object r1, because it is not found in this remote media group');
355
+ });
356
+
357
+ it('throws when remoteMedia id is not in unpinned and pinned array - csi is not there', () => {
358
+ const group = new RemoteMediaGroup(fakeMediaRequestManager, fakeReceiveSlots, 255, true, {
359
+ resolution: 'medium',
360
+ preferLiveVideo: true,
361
+ });
362
+ assert.throws(() => group.setActiveSpeakerCsis([{remoteMedia: {id: 'r1'} as any}], false), 'failed to unpin a remote media object r1, because it is not found in this remote media group');
363
+ });
364
+ });
365
+
366
+ describe('pinning', () => {
367
+ it('works as expected', () => {
368
+ const PINNED_INDEX = 2;
369
+ const PINNED_INDEX2 = 0;
370
+ const CSI = 11111;
371
+ const CSI2 = 12345;
372
+
373
+ const group = new RemoteMediaGroup(fakeMediaRequestManager, fakeReceiveSlots, 255, true, {
374
+ resolution: 'medium',
375
+ preferLiveVideo: true,
376
+ });
377
+
378
+ // initially nothing should be pinned
379
+ assert.strictEqual(group.getRemoteMedia().length, NUM_SLOTS); // by default should return 'all'
380
+ assert.strictEqual(group.getRemoteMedia('all').length, NUM_SLOTS);
381
+ assert.strictEqual(group.getRemoteMedia('unpinned').length, NUM_SLOTS);
382
+ assert.strictEqual(group.getRemoteMedia('pinned').length, 0);
383
+
384
+ // take one instance of remote media from the group
385
+ const remoteMedia = group.getRemoteMedia('all')[PINNED_INDEX];
386
+
387
+ resetHistory();
388
+
389
+ // pin it
390
+ group.pin(remoteMedia, CSI);
391
+
392
+ assert.strictEqual(group.getRemoteMedia().length, NUM_SLOTS); // by default should return 'all'
393
+ assert.strictEqual(group.getRemoteMedia('all').length, NUM_SLOTS);
394
+ assert.strictEqual(group.getRemoteMedia('unpinned').length, NUM_SLOTS - 1);
395
+ assert.strictEqual(group.getRemoteMedia('pinned').length, 1);
396
+
397
+ assert.strictEqual(group.isPinned(remoteMedia), true);
398
+
399
+ // now check that correct media requests were sent...
400
+
401
+ const expectedReceiverSelectedSlots = [fakeReceiveSlots[PINNED_INDEX]];
402
+ const expectedActiveSpeakerReceiveSlots = fakeReceiveSlots.filter(
403
+ (_, idx) => idx !== PINNED_INDEX
404
+ );
405
+
406
+ // the previous active speaker media request for the group should have been cancelled
407
+ assert.calledOnce(fakeMediaRequestManager.cancelRequest);
408
+ assert.calledWith(fakeMediaRequestManager.cancelRequest, 'fake active speaker request 1');
409
+ // a new one should be sent for active speaker and for receiver selected
410
+ assert.calledTwice(fakeMediaRequestManager.addRequest);
411
+ assert.calledWith(
412
+ fakeMediaRequestManager.addRequest,
413
+ sinon.match({
414
+ policyInfo: sinon.match({
415
+ policy: 'active-speaker',
416
+ priority: 255,
417
+ }),
418
+ receiveSlots: expectedActiveSpeakerReceiveSlots,
419
+ codecInfo: sinon.match({
420
+ codec: 'h264',
421
+ maxFs: 3600,
422
+ }),
423
+ })
424
+ );
425
+ assert.calledWith(
426
+ fakeMediaRequestManager.addRequest,
427
+ sinon.match({
428
+ policyInfo: sinon.match({
429
+ policy: 'receiver-selected',
430
+ csi: CSI,
431
+ }),
432
+ receiveSlots: expectedReceiverSelectedSlots,
433
+ codecInfo: sinon.match({
434
+ codec: 'h264',
435
+ maxFs: 3600,
436
+ }),
437
+ })
438
+ );
439
+
440
+ resetHistory();
441
+
442
+ // pin another video
443
+ const remoteMedia2 = group.getRemoteMedia('all')[PINNED_INDEX2];
444
+
445
+ group.pin(remoteMedia2, CSI2);
446
+
447
+ assert.strictEqual(group.getRemoteMedia().length, NUM_SLOTS);
448
+ assert.strictEqual(group.getRemoteMedia('all').length, NUM_SLOTS);
449
+ assert.strictEqual(group.getRemoteMedia('unpinned').length, NUM_SLOTS - 2);
450
+ assert.strictEqual(group.getRemoteMedia('pinned').length, 2);
451
+
452
+ assert.strictEqual(group.isPinned(remoteMedia2), true);
453
+
454
+ // now check that correct media requests were sent...
455
+ const expectedReceiverSelectedSlots2 = [fakeReceiveSlots[PINNED_INDEX2]];
456
+ const expectedActiveSpeakerReceiveSlots2 = fakeReceiveSlots.filter(
457
+ (_, idx) => idx !== PINNED_INDEX && idx !== PINNED_INDEX2
458
+ );
459
+
460
+ // the previous active speaker media request for the group should have been cancelled
461
+ assert.calledOnce(fakeMediaRequestManager.cancelRequest);
462
+ assert.calledWith(fakeMediaRequestManager.cancelRequest, 'fake active speaker request 2');
463
+ // a new one should be sent for active speaker and for receiver selected
464
+ assert.calledTwice(fakeMediaRequestManager.addRequest);
465
+ assert.calledWith(
466
+ fakeMediaRequestManager.addRequest,
467
+ sinon.match({
468
+ policyInfo: sinon.match({
469
+ policy: 'active-speaker',
470
+ priority: 255,
471
+ }),
472
+ receiveSlots: expectedActiveSpeakerReceiveSlots2,
473
+ codecInfo: sinon.match({
474
+ codec: 'h264',
475
+ maxFs: 3600,
476
+ }),
477
+ })
478
+ );
479
+ assert.calledWith(
480
+ fakeMediaRequestManager.addRequest,
481
+ sinon.match({
482
+ policyInfo: sinon.match({
483
+ policy: 'receiver-selected',
484
+ csi: CSI2,
485
+ }),
486
+ receiveSlots: expectedReceiverSelectedSlots2,
487
+ codecInfo: sinon.match({
488
+ codec: 'h264',
489
+ maxFs: 3600,
490
+ }),
491
+ })
492
+ );
493
+
494
+ resetHistory();
495
+
496
+ // now unpin the video pane that was first pinned
497
+ group.unpin(remoteMedia);
498
+
499
+ // one pane should still remain pinned
500
+ assert.strictEqual(group.getRemoteMedia().length, NUM_SLOTS);
501
+ assert.strictEqual(group.getRemoteMedia('all').length, NUM_SLOTS);
502
+ assert.strictEqual(group.getRemoteMedia('unpinned').length, NUM_SLOTS - 1);
503
+ assert.strictEqual(group.getRemoteMedia('pinned').length, 1);
504
+
505
+ assert.strictEqual(group.isPinned(remoteMedia), false);
506
+
507
+ // the previous requests for the group and the individual remote media should have been cancelled
508
+ assert.calledTwice(fakeMediaRequestManager.cancelRequest);
509
+ assert.calledWith(fakeMediaRequestManager.cancelRequest, 'fake active speaker request 3');
510
+ assert.calledWith(fakeMediaRequestManager.cancelRequest, 'fake receiver selected request 1');
511
+
512
+ // a new one should be sent for active speaker
513
+ assert.calledOnce(fakeMediaRequestManager.addRequest);
514
+ assert.calledWith(
515
+ fakeMediaRequestManager.addRequest,
516
+ sinon.match({
517
+ policyInfo: sinon.match({
518
+ policy: 'active-speaker',
519
+ priority: 255,
520
+ }),
521
+ codecInfo: sinon.match({
522
+ codec: 'h264',
523
+ maxFs: 3600,
524
+ }),
525
+ })
526
+ );
527
+ // checking that the receiveSlots array passed in to addRequest() has the right length without
528
+ // being strict on the order of elements in it:
529
+ const receiveSlotsArg = fakeMediaRequestManager.addRequest.getCall(0).args[0].receiveSlots;
530
+
531
+ assert.strictEqual(receiveSlotsArg.length, fakeReceiveSlots.length - 1);
532
+ });
533
+
534
+ it('works as expected when pin() is called on already pinned RemoteMedia', () => {
535
+ const PINNED_INDEX = 4;
536
+
537
+ const group = new RemoteMediaGroup(fakeMediaRequestManager, fakeReceiveSlots, 255, true, {
538
+ resolution: 'medium',
539
+ preferLiveVideo: true,
540
+ });
541
+
542
+ // take one instance of remote media from the group
543
+ const remoteMedia = group.getRemoteMedia('all')[PINNED_INDEX];
544
+
545
+ resetHistory();
546
+
547
+ // pin it
548
+ group.pin(remoteMedia, 1234);
549
+
550
+ resetHistory();
551
+ // normally this would result in the underlying receive slot csi to be updated, because we're using fake
552
+ // receive slots, we have to do that manually:
553
+ fakeReceiveSlots[PINNED_INDEX].csi = 1234;
554
+
555
+ // pin again to same CSI
556
+ group.pin(remoteMedia, 1234);
557
+
558
+ assert.notCalled(fakeMediaRequestManager.addRequest);
559
+ assert.notCalled(fakeMediaRequestManager.cancelRequest);
560
+ assert.notCalled(fakeMediaRequestManager.commit);
561
+
562
+ // again, this time without even specifying the csi
563
+ group.pin(remoteMedia);
564
+
565
+ assert.notCalled(fakeMediaRequestManager.addRequest);
566
+ assert.notCalled(fakeMediaRequestManager.cancelRequest);
567
+ assert.notCalled(fakeMediaRequestManager.commit);
568
+
569
+ // pin it again but to a different CSI
570
+ group.pin(remoteMedia, 2345);
571
+
572
+ // it should trigger a new receiver selected media request
573
+ assert.calledOnce(fakeMediaRequestManager.addRequest);
574
+ assert.calledWith(
575
+ fakeMediaRequestManager.addRequest,
576
+ sinon.match({
577
+ policyInfo: sinon.match({
578
+ policy: 'receiver-selected',
579
+ csi: 2345,
580
+ }),
581
+ receiveSlots: [fakeReceiveSlots[PINNED_INDEX]],
582
+ codecInfo: sinon.match({
583
+ codec: 'h264',
584
+ maxFs: 3600,
585
+ }),
586
+ })
587
+ );
588
+ });
589
+ });
590
+
591
+ describe('stop()', () => {
592
+ it('stops all RemoteMedia in the group', () => {
593
+ const group = new RemoteMediaGroup(fakeMediaRequestManager, fakeReceiveSlots, 255, true, {
594
+ resolution: 'medium',
595
+ preferLiveVideo: true,
596
+ });
597
+ const stopStubs: any[] = [];
598
+
599
+ group.getRemoteMedia('all').forEach((remoteMedia) => {
600
+ stopStubs.push(sinon.stub(remoteMedia, 'stop'));
601
+ });
602
+
603
+ // pin a few remote media instances
604
+ group.pin(group.getRemoteMedia('unpinned')[2], 12345);
605
+ group.pin(group.getRemoteMedia('unpinned')[1], 12345);
606
+ group.pin(group.getRemoteMedia('unpinned')[0], 12345);
607
+
608
+ assert.strictEqual(group.getRemoteMedia('unpinned').length, NUM_SLOTS - 3);
609
+ assert.strictEqual(group.getRemoteMedia('pinned').length, 3);
610
+
611
+ resetHistory();
612
+
613
+ group.stop(true);
614
+
615
+ // check that all remote media (including pinned ones) have been stopped
616
+ stopStubs.forEach((stub) => {
617
+ assert.calledOnce(stub);
618
+ assert.calledWith(stub, false);
619
+ });
620
+
621
+ // and that we've cancelled the media request for this group
622
+ assert.calledOnce(fakeMediaRequestManager.cancelRequest);
623
+ assert.calledWith(fakeMediaRequestManager.cancelRequest, getLastActiveSpeakerRequestId());
624
+ assert.calledOnce(fakeMediaRequestManager.commit);
625
+ });
626
+ });
627
+
628
+ describe('includes()', () => {
629
+ it('checks if a given RemoteMedia belongs to the group', () => {
630
+ const group = new RemoteMediaGroup(fakeMediaRequestManager, fakeReceiveSlots, 255, true, {
631
+ resolution: 'medium',
632
+ preferLiveVideo: true,
633
+ });
634
+
635
+ const unpinnedRemoteMediaFromGroup = group.getRemoteMedia('all')[0];
636
+ const otherRemoteMedia = new RemoteMedia(
637
+ new FakeSlot(MediaType.VideoMain, 'other slot') as unknown as ReceiveSlot,
638
+ fakeMediaRequestManager
639
+ );
640
+
641
+ group.pin(group.getRemoteMedia('all')[1], 12345);
642
+ const pinnedRemoteMedia = group.getRemoteMedia('pinned')[0];
643
+
644
+ // by default includes() uses 'all' filter
645
+ assert.strictEqual(group.includes(unpinnedRemoteMediaFromGroup), true);
646
+ assert.strictEqual(group.includes(otherRemoteMedia), false);
647
+ assert.strictEqual(group.includes(pinnedRemoteMedia), true);
648
+
649
+ assert.strictEqual(group.includes(unpinnedRemoteMediaFromGroup, 'all'), true);
650
+ assert.strictEqual(group.includes(otherRemoteMedia, 'all'), false);
651
+ assert.strictEqual(group.includes(pinnedRemoteMedia, 'all'), true);
652
+
653
+ assert.strictEqual(group.includes(unpinnedRemoteMediaFromGroup, 'pinned'), false);
654
+ assert.strictEqual(group.includes(otherRemoteMedia, 'pinned'), false);
655
+ assert.strictEqual(group.includes(pinnedRemoteMedia, 'pinned'), true);
656
+
657
+ assert.strictEqual(group.includes(unpinnedRemoteMediaFromGroup, 'unpinned'), true);
658
+ assert.strictEqual(group.includes(pinnedRemoteMedia, 'unpinned'), false);
659
+ assert.strictEqual(group.includes(otherRemoteMedia, 'unpinned'), false);
660
+ });
661
+ });
662
+ });