@webex/plugin-meetings 3.0.0-beta.15 → 3.0.0-beta.150

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 (480) hide show
  1. package/README.md +45 -1
  2. package/dist/annotation/annotation.types.js +7 -0
  3. package/dist/annotation/annotation.types.js.map +1 -0
  4. package/dist/annotation/constants.js +49 -0
  5. package/dist/annotation/constants.js.map +1 -0
  6. package/dist/annotation/index.js +359 -0
  7. package/dist/annotation/index.js.map +1 -0
  8. package/dist/breakouts/breakout.js +193 -0
  9. package/dist/breakouts/breakout.js.map +1 -0
  10. package/dist/breakouts/collection.js +23 -0
  11. package/dist/breakouts/collection.js.map +1 -0
  12. package/dist/breakouts/edit-lock-error.js +52 -0
  13. package/dist/breakouts/edit-lock-error.js.map +1 -0
  14. package/dist/breakouts/events.js +43 -0
  15. package/dist/breakouts/events.js.map +1 -0
  16. package/dist/breakouts/index.js +1012 -0
  17. package/dist/breakouts/index.js.map +1 -0
  18. package/dist/breakouts/request.js +78 -0
  19. package/dist/breakouts/request.js.map +1 -0
  20. package/dist/breakouts/utils.js +67 -0
  21. package/dist/breakouts/utils.js.map +1 -0
  22. package/dist/common/browser-detection.js +1 -21
  23. package/dist/common/browser-detection.js.map +1 -1
  24. package/dist/common/collection.js +5 -20
  25. package/dist/common/collection.js.map +1 -1
  26. package/dist/common/config.js +0 -7
  27. package/dist/common/config.js.map +1 -1
  28. package/dist/common/errors/captcha-error.js +0 -21
  29. package/dist/common/errors/captcha-error.js.map +1 -1
  30. package/dist/common/errors/intent-to-join.js +0 -21
  31. package/dist/common/errors/intent-to-join.js.map +1 -1
  32. package/dist/common/errors/join-meeting.js +0 -21
  33. package/dist/common/errors/join-meeting.js.map +1 -1
  34. package/dist/common/errors/media.js +0 -21
  35. package/dist/common/errors/media.js.map +1 -1
  36. package/dist/common/errors/parameter.js +0 -28
  37. package/dist/common/errors/parameter.js.map +1 -1
  38. package/dist/common/errors/password-error.js +0 -21
  39. package/dist/common/errors/password-error.js.map +1 -1
  40. package/dist/common/errors/permission.js +0 -21
  41. package/dist/common/errors/permission.js.map +1 -1
  42. package/dist/common/errors/reconnection-in-progress.js +0 -17
  43. package/dist/common/errors/reconnection-in-progress.js.map +1 -1
  44. package/dist/common/errors/reconnection.js +0 -21
  45. package/dist/common/errors/reconnection.js.map +1 -1
  46. package/dist/common/errors/stats.js +0 -21
  47. package/dist/common/errors/stats.js.map +1 -1
  48. package/dist/common/errors/webex-errors.js +9 -43
  49. package/dist/common/errors/webex-errors.js.map +1 -1
  50. package/dist/common/errors/webex-meetings-error.js +1 -24
  51. package/dist/common/errors/webex-meetings-error.js.map +1 -1
  52. package/dist/common/events/events-scope.js +0 -22
  53. package/dist/common/events/events-scope.js.map +1 -1
  54. package/dist/common/events/events.js +0 -23
  55. package/dist/common/events/events.js.map +1 -1
  56. package/dist/common/events/trigger-proxy.js +0 -12
  57. package/dist/common/events/trigger-proxy.js.map +1 -1
  58. package/dist/common/events/util.js +0 -15
  59. package/dist/common/events/util.js.map +1 -1
  60. package/dist/common/logs/logger-config.js +0 -4
  61. package/dist/common/logs/logger-config.js.map +1 -1
  62. package/dist/common/logs/logger-proxy.js +1 -8
  63. package/dist/common/logs/logger-proxy.js.map +1 -1
  64. package/dist/common/logs/request.js +35 -61
  65. package/dist/common/logs/request.js.map +1 -1
  66. package/dist/common/queue.js +4 -14
  67. package/dist/common/queue.js.map +1 -1
  68. package/dist/config.js +7 -13
  69. package/dist/config.js.map +1 -1
  70. package/dist/constants.js +208 -64
  71. package/dist/constants.js.map +1 -1
  72. package/dist/controls-options-manager/constants.js +14 -0
  73. package/dist/controls-options-manager/constants.js.map +1 -0
  74. package/dist/controls-options-manager/enums.js +27 -0
  75. package/dist/controls-options-manager/enums.js.map +1 -0
  76. package/dist/controls-options-manager/index.js +297 -0
  77. package/dist/controls-options-manager/index.js.map +1 -0
  78. package/dist/controls-options-manager/types.js +7 -0
  79. package/dist/controls-options-manager/types.js.map +1 -0
  80. package/dist/controls-options-manager/util.js +300 -0
  81. package/dist/controls-options-manager/util.js.map +1 -0
  82. package/dist/index.js +78 -17
  83. package/dist/index.js.map +1 -1
  84. package/dist/locus-info/controlsUtils.js +100 -29
  85. package/dist/locus-info/controlsUtils.js.map +1 -1
  86. package/dist/locus-info/embeddedAppsUtils.js +3 -26
  87. package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
  88. package/dist/locus-info/fullState.js +0 -15
  89. package/dist/locus-info/fullState.js.map +1 -1
  90. package/dist/locus-info/hostUtils.js +4 -12
  91. package/dist/locus-info/hostUtils.js.map +1 -1
  92. package/dist/locus-info/index.js +387 -208
  93. package/dist/locus-info/index.js.map +1 -1
  94. package/dist/locus-info/infoUtils.js +0 -38
  95. package/dist/locus-info/infoUtils.js.map +1 -1
  96. package/dist/locus-info/mediaSharesUtils.js +54 -38
  97. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  98. package/dist/locus-info/parser.js +90 -126
  99. package/dist/locus-info/parser.js.map +1 -1
  100. package/dist/locus-info/selfUtils.js +93 -92
  101. package/dist/locus-info/selfUtils.js.map +1 -1
  102. package/dist/media/index.js +70 -219
  103. package/dist/media/index.js.map +1 -1
  104. package/dist/media/properties.js +74 -198
  105. package/dist/media/properties.js.map +1 -1
  106. package/dist/media/util.js +1 -8
  107. package/dist/media/util.js.map +1 -1
  108. package/dist/mediaQualityMetrics/config.js +505 -495
  109. package/dist/mediaQualityMetrics/config.js.map +1 -1
  110. package/dist/meeting/in-meeting-actions.js +79 -14
  111. package/dist/meeting/in-meeting-actions.js.map +1 -1
  112. package/dist/meeting/index.js +2685 -3324
  113. package/dist/meeting/index.js.map +1 -1
  114. package/dist/meeting/locusMediaRequest.js +291 -0
  115. package/dist/meeting/locusMediaRequest.js.map +1 -0
  116. package/dist/meeting/muteState.js +243 -185
  117. package/dist/meeting/muteState.js.map +1 -1
  118. package/dist/meeting/request.js +296 -342
  119. package/dist/meeting/request.js.map +1 -1
  120. package/dist/meeting/request.type.js +0 -1
  121. package/dist/meeting/request.type.js.map +1 -1
  122. package/dist/meeting/state.js +16 -26
  123. package/dist/meeting/state.js.map +1 -1
  124. package/dist/meeting/util.js +446 -585
  125. package/dist/meeting/util.js.map +1 -1
  126. package/dist/meeting-info/collection.js +3 -25
  127. package/dist/meeting-info/collection.js.map +1 -1
  128. package/dist/meeting-info/index.js +8 -31
  129. package/dist/meeting-info/index.js.map +1 -1
  130. package/dist/meeting-info/meeting-info-v2.js +261 -242
  131. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  132. package/dist/meeting-info/request.js +1 -16
  133. package/dist/meeting-info/request.js.map +1 -1
  134. package/dist/meeting-info/util.js +98 -183
  135. package/dist/meeting-info/util.js.map +1 -1
  136. package/dist/meeting-info/utilv2.js +156 -232
  137. package/dist/meeting-info/utilv2.js.map +1 -1
  138. package/dist/meetings/collection.js +24 -20
  139. package/dist/meetings/collection.js.map +1 -1
  140. package/dist/meetings/index.js +526 -372
  141. package/dist/meetings/index.js.map +1 -1
  142. package/dist/meetings/meetings.types.js +7 -0
  143. package/dist/meetings/meetings.types.js.map +1 -0
  144. package/dist/meetings/request.js +21 -40
  145. package/dist/meetings/request.js.map +1 -1
  146. package/dist/meetings/util.js +172 -141
  147. package/dist/meetings/util.js.map +1 -1
  148. package/dist/member/index.js +58 -57
  149. package/dist/member/index.js.map +1 -1
  150. package/dist/member/types.js +15 -0
  151. package/dist/member/types.js.map +1 -0
  152. package/dist/member/util.js +101 -69
  153. package/dist/member/util.js.map +1 -1
  154. package/dist/members/collection.js +12 -12
  155. package/dist/members/collection.js.map +1 -1
  156. package/dist/members/index.js +123 -162
  157. package/dist/members/index.js.map +1 -1
  158. package/dist/members/request.js +120 -85
  159. package/dist/members/request.js.map +1 -1
  160. package/dist/members/types.js +15 -0
  161. package/dist/members/types.js.map +1 -0
  162. package/dist/members/util.js +314 -260
  163. package/dist/members/util.js.map +1 -1
  164. package/dist/metrics/config.js +50 -16
  165. package/dist/metrics/config.js.map +1 -1
  166. package/dist/metrics/constants.js +4 -7
  167. package/dist/metrics/constants.js.map +1 -1
  168. package/dist/metrics/index.js +75 -147
  169. package/dist/metrics/index.js.map +1 -1
  170. package/dist/multistream/mediaRequestManager.js +170 -50
  171. package/dist/multistream/mediaRequestManager.js.map +1 -1
  172. package/dist/multistream/receiveSlot.js +58 -65
  173. package/dist/multistream/receiveSlot.js.map +1 -1
  174. package/dist/multistream/receiveSlotManager.js +73 -94
  175. package/dist/multistream/receiveSlotManager.js.map +1 -1
  176. package/dist/multistream/remoteMedia.js +55 -74
  177. package/dist/multistream/remoteMedia.js.map +1 -1
  178. package/dist/multistream/remoteMediaGroup.js +66 -43
  179. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  180. package/dist/multistream/remoteMediaManager.js +502 -442
  181. package/dist/multistream/remoteMediaManager.js.map +1 -1
  182. package/dist/networkQualityMonitor/index.js +24 -51
  183. package/dist/networkQualityMonitor/index.js.map +1 -1
  184. package/dist/personal-meeting-room/index.js +3 -38
  185. package/dist/personal-meeting-room/index.js.map +1 -1
  186. package/dist/personal-meeting-room/request.js +2 -33
  187. package/dist/personal-meeting-room/request.js.map +1 -1
  188. package/dist/personal-meeting-room/util.js +0 -13
  189. package/dist/personal-meeting-room/util.js.map +1 -1
  190. package/dist/reachability/index.js +190 -199
  191. package/dist/reachability/index.js.map +1 -1
  192. package/dist/reachability/request.js +14 -23
  193. package/dist/reachability/request.js.map +1 -1
  194. package/dist/reactions/constants.js +13 -0
  195. package/dist/reactions/constants.js.map +1 -0
  196. package/dist/reactions/reactions.js +2 -4
  197. package/dist/reactions/reactions.js.map +1 -1
  198. package/dist/reactions/reactions.type.js +18 -24
  199. package/dist/reactions/reactions.type.js.map +1 -1
  200. package/dist/reconnection-manager/index.js +356 -476
  201. package/dist/reconnection-manager/index.js.map +1 -1
  202. package/dist/recording-controller/enums.js +17 -0
  203. package/dist/recording-controller/enums.js.map +1 -0
  204. package/dist/recording-controller/index.js +343 -0
  205. package/dist/recording-controller/index.js.map +1 -0
  206. package/dist/recording-controller/util.js +63 -0
  207. package/dist/recording-controller/util.js.map +1 -0
  208. package/dist/roap/index.js +32 -75
  209. package/dist/roap/index.js.map +1 -1
  210. package/dist/roap/request.js +129 -136
  211. package/dist/roap/request.js.map +1 -1
  212. package/dist/roap/turnDiscovery.js +143 -103
  213. package/dist/roap/turnDiscovery.js.map +1 -1
  214. package/dist/statsAnalyzer/global.js +1 -95
  215. package/dist/statsAnalyzer/global.js.map +1 -1
  216. package/dist/statsAnalyzer/index.js +369 -462
  217. package/dist/statsAnalyzer/index.js.map +1 -1
  218. package/dist/statsAnalyzer/mqaUtil.js +144 -94
  219. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  220. package/dist/transcription/index.js +9 -44
  221. package/dist/transcription/index.js.map +1 -1
  222. package/dist/types/annotation/annotation.types.d.ts +43 -0
  223. package/dist/types/annotation/constants.d.ts +31 -0
  224. package/dist/types/annotation/index.d.ts +124 -0
  225. package/dist/types/breakouts/breakout.d.ts +8 -0
  226. package/dist/types/breakouts/collection.d.ts +5 -0
  227. package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
  228. package/dist/types/breakouts/events.d.ts +2 -0
  229. package/dist/types/breakouts/index.d.ts +5 -0
  230. package/dist/types/breakouts/request.d.ts +22 -0
  231. package/dist/types/breakouts/utils.d.ts +15 -0
  232. package/dist/types/common/browser-detection.d.ts +9 -0
  233. package/dist/types/common/collection.d.ts +48 -0
  234. package/dist/types/common/config.d.ts +2 -0
  235. package/dist/types/common/errors/captcha-error.d.ts +15 -0
  236. package/dist/types/common/errors/intent-to-join.d.ts +16 -0
  237. package/dist/types/common/errors/join-meeting.d.ts +17 -0
  238. package/dist/types/common/errors/media.d.ts +15 -0
  239. package/dist/types/common/errors/parameter.d.ts +15 -0
  240. package/dist/types/common/errors/password-error.d.ts +15 -0
  241. package/dist/types/common/errors/permission.d.ts +14 -0
  242. package/dist/types/common/errors/reconnection-in-progress.d.ts +9 -0
  243. package/dist/types/common/errors/reconnection.d.ts +15 -0
  244. package/dist/types/common/errors/stats.d.ts +15 -0
  245. package/dist/types/common/errors/webex-errors.d.ts +69 -0
  246. package/dist/types/common/errors/webex-meetings-error.d.ts +20 -0
  247. package/dist/types/common/events/events-scope.d.ts +17 -0
  248. package/dist/types/common/events/events.d.ts +12 -0
  249. package/dist/types/common/events/trigger-proxy.d.ts +2 -0
  250. package/dist/types/common/events/util.d.ts +2 -0
  251. package/dist/types/common/logs/logger-config.d.ts +2 -0
  252. package/dist/types/common/logs/logger-proxy.d.ts +2 -0
  253. package/dist/types/common/logs/request.d.ts +34 -0
  254. package/dist/types/common/queue.d.ts +32 -0
  255. package/dist/types/config.d.ts +72 -0
  256. package/dist/types/constants.d.ts +978 -0
  257. package/dist/types/controls-options-manager/constants.d.ts +4 -0
  258. package/dist/types/controls-options-manager/enums.d.ts +15 -0
  259. package/dist/types/controls-options-manager/index.d.ts +136 -0
  260. package/dist/types/controls-options-manager/types.d.ts +43 -0
  261. package/dist/types/controls-options-manager/util.d.ts +1 -0
  262. package/dist/types/index.d.ts +7 -0
  263. package/dist/types/locus-info/controlsUtils.d.ts +2 -0
  264. package/dist/types/locus-info/embeddedAppsUtils.d.ts +2 -0
  265. package/dist/types/locus-info/fullState.d.ts +2 -0
  266. package/dist/types/locus-info/hostUtils.d.ts +2 -0
  267. package/dist/types/locus-info/index.d.ts +315 -0
  268. package/dist/types/locus-info/infoUtils.d.ts +2 -0
  269. package/dist/types/locus-info/mediaSharesUtils.d.ts +2 -0
  270. package/dist/types/locus-info/parser.d.ts +212 -0
  271. package/dist/types/locus-info/selfUtils.d.ts +2 -0
  272. package/dist/types/media/index.d.ts +34 -0
  273. package/dist/types/media/properties.d.ts +86 -0
  274. package/dist/types/media/util.d.ts +2 -0
  275. package/dist/types/mediaQualityMetrics/config.d.ts +365 -0
  276. package/dist/types/meeting/in-meeting-actions.d.ts +149 -0
  277. package/dist/types/meeting/index.d.ts +1509 -0
  278. package/dist/types/meeting/locusMediaRequest.d.ts +70 -0
  279. package/dist/types/meeting/muteState.d.ts +184 -0
  280. package/dist/types/meeting/request.d.ts +270 -0
  281. package/dist/types/meeting/request.type.d.ts +11 -0
  282. package/dist/types/meeting/state.d.ts +9 -0
  283. package/dist/types/meeting/util.d.ts +75 -0
  284. package/dist/types/meeting-info/collection.d.ts +20 -0
  285. package/dist/types/meeting-info/index.d.ts +57 -0
  286. package/dist/types/meeting-info/meeting-info-v2.d.ts +122 -0
  287. package/dist/types/meeting-info/request.d.ts +22 -0
  288. package/dist/types/meeting-info/util.d.ts +2 -0
  289. package/dist/types/meeting-info/utilv2.d.ts +2 -0
  290. package/dist/types/meetings/collection.d.ts +31 -0
  291. package/dist/types/meetings/index.d.ts +364 -0
  292. package/dist/types/meetings/meetings.types.d.ts +4 -0
  293. package/dist/types/meetings/request.d.ts +27 -0
  294. package/dist/types/meetings/util.d.ts +18 -0
  295. package/dist/types/member/index.d.ts +157 -0
  296. package/dist/types/member/types.d.ts +21 -0
  297. package/dist/types/member/util.d.ts +2 -0
  298. package/dist/types/members/collection.d.ts +29 -0
  299. package/dist/types/members/index.d.ts +353 -0
  300. package/dist/types/members/request.d.ts +114 -0
  301. package/dist/types/members/types.d.ts +24 -0
  302. package/dist/types/members/util.d.ts +210 -0
  303. package/dist/types/metrics/config.d.ts +195 -0
  304. package/dist/types/metrics/constants.d.ts +55 -0
  305. package/dist/types/metrics/index.d.ts +169 -0
  306. package/dist/types/multistream/mediaRequestManager.d.ts +104 -0
  307. package/dist/types/multistream/receiveSlot.d.ts +68 -0
  308. package/dist/types/multistream/receiveSlotManager.d.ts +56 -0
  309. package/dist/types/multistream/remoteMedia.d.ts +72 -0
  310. package/dist/types/multistream/remoteMediaGroup.d.ts +47 -0
  311. package/dist/types/multistream/remoteMediaManager.d.ts +277 -0
  312. package/dist/types/networkQualityMonitor/index.d.ts +70 -0
  313. package/dist/types/personal-meeting-room/index.d.ts +47 -0
  314. package/dist/types/personal-meeting-room/request.d.ts +14 -0
  315. package/dist/types/personal-meeting-room/util.d.ts +2 -0
  316. package/dist/types/reachability/index.d.ts +152 -0
  317. package/dist/types/reachability/request.d.ts +37 -0
  318. package/dist/types/reactions/constants.d.ts +3 -0
  319. package/dist/types/reactions/reactions.d.ts +4 -0
  320. package/dist/types/reactions/reactions.type.d.ts +52 -0
  321. package/dist/types/reconnection-manager/index.d.ts +126 -0
  322. package/dist/types/recording-controller/enums.d.ts +7 -0
  323. package/dist/types/recording-controller/index.d.ts +193 -0
  324. package/dist/types/recording-controller/util.d.ts +13 -0
  325. package/dist/types/roap/index.d.ts +77 -0
  326. package/dist/types/roap/request.d.ts +36 -0
  327. package/dist/types/roap/turnDiscovery.d.ts +91 -0
  328. package/dist/types/statsAnalyzer/global.d.ts +36 -0
  329. package/dist/types/statsAnalyzer/index.d.ts +200 -0
  330. package/dist/types/statsAnalyzer/mqaUtil.d.ts +24 -0
  331. package/dist/types/transcription/index.d.ts +64 -0
  332. package/package.json +28 -21
  333. package/src/annotation/annotation.types.ts +52 -0
  334. package/src/annotation/constants.ts +36 -0
  335. package/src/annotation/index.ts +343 -0
  336. package/src/breakouts/README.md +220 -0
  337. package/src/breakouts/breakout.ts +163 -0
  338. package/src/breakouts/collection.ts +19 -0
  339. package/src/breakouts/edit-lock-error.ts +25 -0
  340. package/src/breakouts/events.ts +37 -0
  341. package/src/breakouts/index.ts +888 -0
  342. package/src/breakouts/request.ts +55 -0
  343. package/src/breakouts/utils.ts +57 -0
  344. package/src/common/errors/webex-errors.ts +6 -2
  345. package/src/common/logs/logger-proxy.ts +1 -1
  346. package/src/config.ts +5 -7
  347. package/src/constants.ts +155 -20
  348. package/src/controls-options-manager/constants.ts +5 -0
  349. package/src/controls-options-manager/enums.ts +18 -0
  350. package/src/controls-options-manager/index.ts +278 -0
  351. package/src/controls-options-manager/types.ts +59 -0
  352. package/src/controls-options-manager/util.ts +286 -0
  353. package/src/index.ts +34 -0
  354. package/src/locus-info/controlsUtils.ts +108 -0
  355. package/src/locus-info/index.ts +310 -21
  356. package/src/locus-info/mediaSharesUtils.ts +48 -0
  357. package/src/locus-info/parser.ts +2 -1
  358. package/src/locus-info/selfUtils.ts +71 -1
  359. package/src/media/index.ts +70 -142
  360. package/src/media/properties.ts +41 -104
  361. package/src/mediaQualityMetrics/config.ts +379 -377
  362. package/src/meeting/in-meeting-actions.ts +156 -0
  363. package/src/meeting/index.ts +1730 -1768
  364. package/src/meeting/locusMediaRequest.ts +309 -0
  365. package/src/meeting/muteState.ts +228 -132
  366. package/src/meeting/request.ts +100 -91
  367. package/src/meeting/request.type.ts +2 -0
  368. package/src/meeting/util.ts +421 -421
  369. package/src/meeting-info/meeting-info-v2.ts +134 -13
  370. package/src/meeting-info/utilv2.ts +13 -3
  371. package/src/meetings/collection.ts +20 -0
  372. package/src/meetings/index.ts +375 -83
  373. package/src/meetings/meetings.types.ts +9 -0
  374. package/src/meetings/request.ts +3 -1
  375. package/src/meetings/util.ts +103 -4
  376. package/src/member/index.ts +40 -0
  377. package/src/member/types.ts +24 -0
  378. package/src/member/util.ts +81 -1
  379. package/src/members/collection.ts +8 -0
  380. package/src/members/index.ts +108 -6
  381. package/src/members/request.ts +98 -17
  382. package/src/members/types.ts +28 -0
  383. package/src/members/util.ts +319 -240
  384. package/src/metrics/config.ts +49 -10
  385. package/src/metrics/constants.ts +2 -4
  386. package/src/metrics/index.ts +43 -27
  387. package/src/multistream/mediaRequestManager.ts +210 -45
  388. package/src/multistream/receiveSlot.ts +68 -26
  389. package/src/multistream/receiveSlotManager.ts +61 -38
  390. package/src/multistream/remoteMedia.ts +29 -3
  391. package/src/multistream/remoteMediaGroup.ts +61 -2
  392. package/src/multistream/remoteMediaManager.ts +260 -66
  393. package/src/networkQualityMonitor/index.ts +6 -6
  394. package/src/reachability/index.ts +75 -25
  395. package/src/reachability/request.ts +10 -5
  396. package/src/reactions/constants.ts +4 -0
  397. package/src/reactions/reactions.ts +4 -4
  398. package/src/reactions/reactions.type.ts +28 -3
  399. package/src/reconnection-manager/index.ts +53 -32
  400. package/src/recording-controller/enums.ts +8 -0
  401. package/src/recording-controller/index.ts +315 -0
  402. package/src/recording-controller/util.ts +58 -0
  403. package/src/roap/index.ts +21 -30
  404. package/src/roap/request.ts +51 -52
  405. package/src/roap/turnDiscovery.ts +51 -27
  406. package/src/statsAnalyzer/global.ts +1 -94
  407. package/src/statsAnalyzer/index.ts +380 -390
  408. package/src/statsAnalyzer/mqaUtil.ts +106 -99
  409. package/test/integration/spec/converged-space-meetings.js +233 -0
  410. package/test/integration/spec/journey.js +332 -255
  411. package/test/integration/spec/space-meeting.js +78 -5
  412. package/test/integration/spec/transcription.js +1 -1
  413. package/test/unit/spec/annotation/index.ts +436 -0
  414. package/test/unit/spec/breakouts/breakout.ts +203 -0
  415. package/test/unit/spec/breakouts/collection.ts +15 -0
  416. package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
  417. package/test/unit/spec/breakouts/events.ts +77 -0
  418. package/test/unit/spec/breakouts/index.ts +1715 -0
  419. package/test/unit/spec/breakouts/request.ts +104 -0
  420. package/test/unit/spec/breakouts/utils.js +72 -0
  421. package/test/unit/spec/controls-options-manager/index.js +287 -0
  422. package/test/unit/spec/controls-options-manager/util.js +518 -0
  423. package/test/unit/spec/fixture/locus.js +1 -0
  424. package/test/unit/spec/locus-info/controlsUtils.js +303 -30
  425. package/test/unit/spec/locus-info/index.js +615 -4
  426. package/test/unit/spec/locus-info/mediaSharesUtils.ts +22 -0
  427. package/test/unit/spec/locus-info/selfConstant.js +38 -0
  428. package/test/unit/spec/locus-info/selfUtils.js +200 -0
  429. package/test/unit/spec/media/index.ts +118 -22
  430. package/test/unit/spec/media/properties.ts +9 -9
  431. package/test/unit/spec/meeting/in-meeting-actions.ts +76 -0
  432. package/test/unit/spec/meeting/index.js +2394 -1381
  433. package/test/unit/spec/meeting/locusMediaRequest.ts +436 -0
  434. package/test/unit/spec/meeting/muteState.js +370 -208
  435. package/test/unit/spec/meeting/request.js +354 -42
  436. package/test/unit/spec/meeting/utils.js +268 -156
  437. package/test/unit/spec/meeting-info/meetinginfov2.js +383 -5
  438. package/test/unit/spec/meeting-info/utilv2.js +21 -0
  439. package/test/unit/spec/meetings/collection.js +14 -0
  440. package/test/unit/spec/meetings/index.js +842 -128
  441. package/test/unit/spec/meetings/utils.js +206 -2
  442. package/test/unit/spec/member/index.js +24 -0
  443. package/test/unit/spec/member/util.js +384 -32
  444. package/test/unit/spec/members/index.js +320 -1
  445. package/test/unit/spec/members/request.js +206 -27
  446. package/test/unit/spec/members/utils.js +184 -0
  447. package/test/unit/spec/metrics/index.js +98 -0
  448. package/test/unit/spec/multistream/mediaRequestManager.ts +676 -105
  449. package/test/unit/spec/multistream/receiveSlot.ts +77 -18
  450. package/test/unit/spec/multistream/receiveSlotManager.ts +69 -39
  451. package/test/unit/spec/multistream/remoteMedia.ts +32 -2
  452. package/test/unit/spec/multistream/remoteMediaGroup.ts +271 -5
  453. package/test/unit/spec/multistream/remoteMediaManager.ts +672 -65
  454. package/test/unit/spec/networkQualityMonitor/index.js +4 -4
  455. package/test/unit/spec/reachability/index.ts +176 -25
  456. package/test/unit/spec/reachability/request.js +66 -0
  457. package/test/unit/spec/reconnection-manager/index.js +46 -13
  458. package/test/unit/spec/recording-controller/index.js +231 -0
  459. package/test/unit/spec/recording-controller/util.js +102 -0
  460. package/test/unit/spec/roap/index.ts +21 -51
  461. package/test/unit/spec/roap/request.ts +187 -0
  462. package/test/unit/spec/roap/turnDiscovery.ts +73 -34
  463. package/test/unit/spec/stats-analyzer/index.js +94 -43
  464. package/test/utils/constants.js +9 -0
  465. package/test/utils/integrationTestUtils.js +46 -0
  466. package/test/utils/testUtils.js +0 -45
  467. package/test/utils/webex-config.js +4 -0
  468. package/test/utils/webex-test-users.js +7 -3
  469. package/tsconfig.json +6 -0
  470. package/dist/media/internal-media-core-wrapper.js +0 -22
  471. package/dist/media/internal-media-core-wrapper.js.map +0 -1
  472. package/dist/meeting/effectsState.js +0 -334
  473. package/dist/meeting/effectsState.js.map +0 -1
  474. package/dist/multistream/multistreamMedia.js +0 -117
  475. package/dist/multistream/multistreamMedia.js.map +0 -1
  476. package/src/index.js +0 -15
  477. package/src/media/internal-media-core-wrapper.ts +0 -9
  478. package/src/meeting/effectsState.ts +0 -211
  479. package/src/multistream/multistreamMedia.ts +0 -93
  480. package/test/unit/spec/meeting/effectsState.js +0 -281
@@ -0,0 +1,888 @@
1
+ /*!
2
+ * Copyright (c) 2015-2023 Cisco Systems, Inc. See LICENSE file.
3
+ */
4
+ import {WebexPlugin} from '@webex/webex-core';
5
+ import {debounce, forEach} from 'lodash';
6
+ import LoggerProxy from '../common/logs/logger-proxy';
7
+
8
+ import {BREAKOUTS, MEETINGS, HTTP_VERBS, _ID_} from '../constants';
9
+
10
+ import Breakout from './breakout';
11
+ import BreakoutCollection from './collection';
12
+ import BreakoutRequest from './request';
13
+ import breakoutEvent from './events';
14
+ import {boServiceErrorHandler, isSessionTypeChangedFromSessionToMain} from './utils';
15
+
16
+ /**
17
+ * @class Breakouts
18
+ */
19
+ const Breakouts = WebexPlugin.extend({
20
+ namespace: MEETINGS,
21
+ breakoutRequest: BreakoutRequest,
22
+ collections: {
23
+ breakouts: BreakoutCollection,
24
+ },
25
+
26
+ props: {
27
+ allowBackToMain: 'boolean', // only present when in a breakout session
28
+ delayCloseTime: 'number', // appears once breakouts start
29
+ enableBreakoutSession: 'boolean', // appears from the moment you enable breakouts
30
+ hasBreakoutPreAssignments: 'boolean', // appears from the moment you enable breakouts
31
+ groupId: 'string', // appears from the moment you enable breakouts
32
+ name: 'string', // only present when in a breakout session
33
+ sessionId: 'string', // appears from the moment you enable breakouts
34
+ sessionType: 'string', // appears from the moment you enable breakouts
35
+ startTime: 'string', // appears once breakouts start
36
+ status: 'string', // only present when in a breakout session
37
+ url: 'string', // appears from the moment you enable breakouts
38
+ locusUrl: 'string', // the current locus url
39
+ breakoutServiceUrl: 'string', // the current breakout resource url
40
+ mainLocusUrl: 'string', // the locus url of the main session
41
+ groups: 'array', // appears when create breakouts
42
+ manageGroups: 'array', // appears when manage breakouts
43
+ preAssignments: 'array', // appears when getPreAssignments info hasBreakoutPreAssignments = true
44
+ editLock: 'object', // appears when getBreakout info editlock = true
45
+ intervalID: 'number',
46
+ meetingId: 'string',
47
+ canManageBreakouts: 'boolean', // appear the ability to manage breakouts
48
+ },
49
+ children: {
50
+ currentBreakoutSession: Breakout,
51
+ },
52
+
53
+ derived: {
54
+ isInMainSession: {
55
+ cache: false,
56
+ deps: ['sessionType'],
57
+ /**
58
+ * Returns true if the user is in the main session
59
+ * @returns {boolean}
60
+ */
61
+ fn() {
62
+ return this.sessionType === BREAKOUTS.SESSION_TYPES.MAIN;
63
+ },
64
+ },
65
+ isActiveBreakout: {
66
+ cache: false, // fix issue: sometimes the derived will not change even if the deps changed
67
+ deps: ['sessionType', 'status'],
68
+ /**
69
+ * Returns true if the breakout status is active
70
+ * @returns {boolean}
71
+ */
72
+ fn() {
73
+ return (
74
+ this.sessionType === BREAKOUTS.SESSION_TYPES.BREAKOUT &&
75
+ (this.status === BREAKOUTS.STATUS.OPEN || this.status === BREAKOUTS.STATUS.CLOSING)
76
+ );
77
+ },
78
+ },
79
+ breakoutGroupId: {
80
+ cache: false,
81
+ deps: ['manageGroups'],
82
+ /**
83
+ * Returns the active group id
84
+ * @returns {boolean}
85
+ */
86
+ fn() {
87
+ if (this.manageGroups?.length) {
88
+ return this.manageGroups[0].status !== BREAKOUTS.STATUS.CLOSED
89
+ ? this.manageGroups[0].id
90
+ : '';
91
+ }
92
+
93
+ return '';
94
+ },
95
+ },
96
+ breakoutStatus: {
97
+ cache: true,
98
+ deps: ['isInMainSession', 'status', 'groups'],
99
+ /**
100
+ * Returns the breakout status
101
+ * @returns {boolean}
102
+ */
103
+ fn() {
104
+ return this.isInMainSession ? this.groups?.[0]?.status : this.status;
105
+ },
106
+ },
107
+ shouldQueryPreAssignments: {
108
+ cache: false,
109
+ deps: ['canManageBreakouts', 'enableBreakoutSession', 'hasBreakoutPreAssignments'],
110
+ /**
111
+ * Returns should query preAssignments or not
112
+ * @returns {boolean}
113
+ */
114
+ fn() {
115
+ return !!(
116
+ this.canManageBreakouts &&
117
+ this.enableBreakoutSession &&
118
+ this.hasBreakoutPreAssignments
119
+ );
120
+ },
121
+ },
122
+ },
123
+
124
+ /**
125
+ * initialize for the breakouts
126
+ * @returns {void}
127
+ */
128
+ initialize() {
129
+ this.listenTo(this, 'change:breakoutStatus', () => {
130
+ if (this.breakoutStatus === BREAKOUTS.STATUS.CLOSING) {
131
+ this.trigger(BREAKOUTS.EVENTS.BREAKOUTS_CLOSING);
132
+ }
133
+ });
134
+ this.listenTo(this, 'change:shouldQueryPreAssignments', () => {
135
+ if (this.shouldQueryPreAssignments && !this.preAssignments) {
136
+ this.queryPreAssignments();
137
+ }
138
+ });
139
+ this.debouncedQueryRosters = debounce(this.queryRosters, 10, {
140
+ leading: true,
141
+ trailing: false,
142
+ });
143
+ this.listenTo(this.breakouts, 'add', (breakout) => {
144
+ this.debouncedQueryRosters();
145
+ this.triggerReturnToMainEvent(breakout);
146
+ });
147
+ this.listenTo(this.breakouts, 'change:requestedLastModifiedTime', (breakout) => {
148
+ this.triggerReturnToMainEvent(breakout);
149
+ });
150
+ this.listenToCurrentSessionTypeChange();
151
+ this.listenToBroadcastMessages();
152
+ this.listenToBreakoutRosters();
153
+ this.listenToBreakoutHelp();
154
+ // @ts-ignore
155
+ this.breakoutRequest = new BreakoutRequest({webex: this.webex});
156
+ },
157
+
158
+ /**
159
+ * Calls this to clean up listeners
160
+ * @returns {void}
161
+ */
162
+ cleanUp() {
163
+ this.stopListening();
164
+ },
165
+
166
+ /**
167
+ * Update the current locus url of the meeting
168
+ * @param {string} locusUrl // locus url
169
+ * @returns {void}
170
+ */
171
+ locusUrlUpdate(locusUrl) {
172
+ this.set('locusUrl', locusUrl);
173
+ const {isInMainSession, mainLocusUrl} = this;
174
+ if (isInMainSession || !mainLocusUrl) {
175
+ this.set('mainLocusUrl', locusUrl);
176
+ }
177
+ },
178
+
179
+ /**
180
+ * Update whether self is moderator/cohost or not
181
+ * @param {boolean} canManageBreakouts
182
+ * @returns {void}
183
+ */
184
+ updateCanManageBreakouts(canManageBreakouts) {
185
+ this.set('canManageBreakouts', canManageBreakouts);
186
+ },
187
+
188
+ /**
189
+ * Update the current breakout resource url
190
+ * @param {string} breakoutServiceUrl
191
+ * @returns {void}
192
+ */
193
+ breakoutServiceUrlUpdate(breakoutServiceUrl) {
194
+ this.set('breakoutServiceUrl', `${breakoutServiceUrl}/breakout/`);
195
+ },
196
+
197
+ /**
198
+ * The initial roster lists need to be queried because you don't
199
+ * get a breakout.roster event when you join the meeting
200
+ * @returns {void}
201
+ */
202
+ queryRosters() {
203
+ this.webex
204
+ .request({uri: `${this.url}/roster`, qs: {locusUrl: btoa(this.locusUrl)}})
205
+ .then((result) => {
206
+ const {
207
+ body: {rosters},
208
+ } = result;
209
+
210
+ rosters?.forEach(({locus}) => {
211
+ this.handleRosterUpdate(locus);
212
+ });
213
+
214
+ this.trigger(BREAKOUTS.EVENTS.MEMBERS_UPDATE);
215
+ })
216
+ .catch((error) => {
217
+ LoggerProxy.logger.error('Meeting:breakouts#queryRosters failed', error);
218
+ });
219
+ },
220
+
221
+ /**
222
+ *
223
+ * @param {Object} locus // locus object
224
+ * @returns {void}
225
+ */
226
+ handleRosterUpdate(locus) {
227
+ const sessionId = locus.controls?.breakout?.sessionId;
228
+
229
+ const session = this.breakouts.get(sessionId);
230
+
231
+ if (!session) {
232
+ return;
233
+ }
234
+
235
+ session.parseRoster(locus);
236
+ },
237
+ /**
238
+ *Sets up listener for currentBreakoutSession sessionType changed
239
+ * @returns {void}
240
+ */
241
+ listenToCurrentSessionTypeChange(): void {
242
+ this.listenTo(
243
+ this.currentBreakoutSession,
244
+ 'change:sessionType',
245
+ (currentBreakoutSession, sessionType) => {
246
+ if (isSessionTypeChangedFromSessionToMain(currentBreakoutSession, sessionType)) {
247
+ this.trigger(BREAKOUTS.EVENTS.LEAVE_BREAKOUT);
248
+ }
249
+ }
250
+ );
251
+ },
252
+
253
+ /**
254
+ * Sets up listener for broadcast messages sent to the breakout session
255
+ * @returns {void}
256
+ */
257
+ listenToBroadcastMessages() {
258
+ this.listenTo(this.webex.internal.llm, 'event:breakout.message', (event) => {
259
+ const {
260
+ data: {senderUserId, sentTime, message},
261
+ } = event;
262
+
263
+ this.trigger(BREAKOUTS.EVENTS.MESSAGE, {
264
+ senderUserId,
265
+ sentTime,
266
+ message,
267
+ // FIXME: This is only the current sessionId
268
+ // We'd need to check that the dataChannelUrl is still the same
269
+ // to guarantee that this message was sent to this session
270
+ sessionId: this.currentBreakoutSession.sessionId,
271
+ });
272
+ });
273
+ },
274
+
275
+ /**
276
+ * Sets up a listener for roster messags from mecury
277
+ * @returns {void}
278
+ */
279
+ listenToBreakoutRosters() {
280
+ this.listenTo(this.webex.internal.mercury, 'event:breakout.roster', (event) => {
281
+ this.handleRosterUpdate(event.data.locus);
282
+ this.trigger(BREAKOUTS.EVENTS.MEMBERS_UPDATE);
283
+ });
284
+ },
285
+
286
+ /**
287
+ * Sets up a listener for ask help notify from mecury
288
+ * @returns {void}
289
+ */
290
+ listenToBreakoutHelp() {
291
+ this.listenTo(this.webex.internal.mercury, 'event:breakout.help', (event) => {
292
+ const {
293
+ data: {participant, sessionId},
294
+ } = event;
295
+ this.trigger(BREAKOUTS.EVENTS.ASK_FOR_HELP, {participant, sessionId});
296
+ });
297
+ },
298
+
299
+ /**
300
+ * Updates the information about the current breakout
301
+ * @param {Object} params
302
+ * @returns {void}
303
+ */
304
+ updateBreakout(params) {
305
+ this.set(params);
306
+
307
+ // These values are set manually so they are unset when they are not included in params
308
+ this.set('groups', params.groups);
309
+ this.set('startTime', params.startTime);
310
+ this.set('status', params.status);
311
+
312
+ this.set('currentBreakoutSession', {
313
+ sessionId: params.sessionId,
314
+ groupId: params.groupId,
315
+ name: params.name,
316
+ current: true,
317
+ sessionType: params.sessionType,
318
+ url: params.url,
319
+ [BREAKOUTS.SESSION_STATES.ACTIVE]: false,
320
+ [BREAKOUTS.SESSION_STATES.ALLOWED]: false,
321
+ [BREAKOUTS.SESSION_STATES.ALLOWED]: false,
322
+ [BREAKOUTS.SESSION_STATES.ASSIGNED_CURRENT]: false,
323
+ [BREAKOUTS.SESSION_STATES.REQUESTED]: false,
324
+ });
325
+
326
+ if (
327
+ this.currentBreakoutSession.previous('sessionId') !== this.currentBreakoutSession.sessionId ||
328
+ this.currentBreakoutSession.previous('groupId') !== this.currentBreakoutSession.groupId
329
+ ) {
330
+ // should report joined session changed
331
+ const meeting = this.webex.meetings.getMeetingByType(_ID_, this.meetingId);
332
+ breakoutEvent.onBreakoutJoinResponse({
333
+ currentSession: this.currentBreakoutSession,
334
+ meeting,
335
+ breakoutMoveId: params.breakoutMoveId,
336
+ });
337
+ }
338
+ },
339
+
340
+ /**
341
+ * Updates the information about available breakouts
342
+ * @param {Object} payload
343
+ * @returns {void}
344
+ */
345
+ updateBreakoutSessions(payload) {
346
+ const breakouts = {};
347
+
348
+ if (payload.breakoutSessions) {
349
+ forEach(BREAKOUTS.SESSION_STATES, (state) => {
350
+ forEach(payload.breakoutSessions[state], (breakout) => {
351
+ const {sessionId} = breakout;
352
+
353
+ if (!breakouts[sessionId]) {
354
+ breakouts[sessionId] = breakout;
355
+ breakouts[sessionId][BREAKOUTS.SESSION_STATES.ACTIVE] = false;
356
+ breakouts[sessionId][BREAKOUTS.SESSION_STATES.ASSIGNED] = false;
357
+ breakouts[sessionId][BREAKOUTS.SESSION_STATES.ALLOWED] = false;
358
+ breakouts[sessionId][BREAKOUTS.SESSION_STATES.ASSIGNED_CURRENT] = false;
359
+ breakouts[sessionId][BREAKOUTS.SESSION_STATES.REQUESTED] = false;
360
+ }
361
+
362
+ breakouts[sessionId][state] = true;
363
+
364
+ if (state === BREAKOUTS.SESSION_STATES.REQUESTED) {
365
+ breakouts[sessionId].requestedLastModifiedTime = breakout.modifiedAt;
366
+ }
367
+ });
368
+ });
369
+ }
370
+
371
+ forEach(breakouts, (breakout: typeof Breakout) => {
372
+ // eslint-disable-next-line no-param-reassign
373
+ breakout.url = this.url;
374
+ });
375
+
376
+ this.breakouts.set(Object.values(breakouts));
377
+ },
378
+ /**
379
+ * get main session
380
+ * @returns {Breakout}
381
+ */
382
+ getMainSession() {
383
+ if (this.isInMainSession) {
384
+ return this.currentBreakoutSession;
385
+ }
386
+
387
+ const mainSession = this.breakouts.filter((breakout) => breakout.isMain)[0];
388
+ if (!mainSession) {
389
+ throw new Error('no main session found');
390
+ }
391
+
392
+ return mainSession;
393
+ },
394
+ /**
395
+ * Host/CoHost ask all participants return to main session
396
+ * @returns {Promise}
397
+ */
398
+ askAllToReturn() {
399
+ const mainSession = this.getMainSession();
400
+
401
+ return this.webex.request({
402
+ method: HTTP_VERBS.POST,
403
+ uri: `${this.url}/requestMove`,
404
+ body: {
405
+ groupId: mainSession.groupId,
406
+ sessionId: mainSession.sessionId,
407
+ },
408
+ });
409
+ },
410
+
411
+ /**
412
+ * Broadcast message to all breakout session's participants
413
+ * @param {String} message
414
+ * @param {Object} options
415
+ * @returns {Promise}
416
+ */
417
+ broadcast(message, options) {
418
+ const {breakoutGroupId} = this;
419
+ if (!breakoutGroupId) {
420
+ throw new Error('Cannot broadcast, no breakout session found');
421
+ }
422
+
423
+ return this.breakoutRequest.broadcast({
424
+ url: this.url,
425
+ message,
426
+ options,
427
+ groupId: breakoutGroupId,
428
+ });
429
+ },
430
+ /**
431
+ * Make enable breakout resource
432
+ * @returns {Promise}
433
+ */
434
+ enableBreakouts() {
435
+ if (this.breakoutServiceUrl) {
436
+ // @ts-ignore
437
+ return this.webex
438
+ .request({
439
+ method: HTTP_VERBS.POST,
440
+ uri: this.breakoutServiceUrl,
441
+ body: {
442
+ locusUrl: this.locusUrl,
443
+ },
444
+ })
445
+ .catch((err) => {
446
+ LoggerProxy.logger.error(
447
+ `Meeting:request#touchBreakout --> Error provisioning error ${err}`
448
+ );
449
+ throw err;
450
+ });
451
+ }
452
+
453
+ return Promise.reject(new Error(`enableBreakouts: the breakoutServiceUrl is empty`));
454
+ },
455
+
456
+ /**
457
+ * Make the meeting enable or disable breakout session
458
+ * @param {boolean} enable
459
+ * @returns {Promise}
460
+ */
461
+ async toggleBreakout(enable) {
462
+ if (this.enableBreakoutSession === undefined) {
463
+ const info = await this.enableBreakouts();
464
+ // first time enable, set the initial data
465
+ this.updateBreakout(info?.body);
466
+ if (!enable) {
467
+ await this.doToggleBreakout(enable);
468
+ }
469
+ } else {
470
+ await this.doToggleBreakout(enable);
471
+ }
472
+ },
473
+
474
+ /**
475
+ * do toggle meeting breakout session enable or disable
476
+ * @param {boolean} enable
477
+ * @returns {Promise}
478
+ */
479
+ doToggleBreakout(enable) {
480
+ const body = {
481
+ ...(this.editLock && !!this.editLock.token ? {editlock: {token: this.editLock.token}} : {}),
482
+ ...{enableBreakoutSession: enable},
483
+ };
484
+
485
+ // @ts-ignore
486
+ return this.webex.request({
487
+ method: HTTP_VERBS.PUT,
488
+ uri: this.url,
489
+ body,
490
+ });
491
+ },
492
+
493
+ /**
494
+ * set groups to manageGroups prop
495
+ * @param {Object} breakoutInfo -- breakout groups
496
+ * @returns {void}
497
+ */
498
+ _setManageGroups(breakoutInfo) {
499
+ if (breakoutInfo?.body?.groups) {
500
+ this.set('manageGroups', breakoutInfo.body.groups);
501
+ }
502
+ },
503
+
504
+ /**
505
+ * Create new breakout sessions
506
+ * @param {object} params -- breakout session group
507
+ * @returns {Promise}
508
+ */
509
+ async create(params) {
510
+ const payload = {...params};
511
+ const body = {
512
+ ...(this.editLock && !!this.editLock.token ? {editlock: {token: this.editLock.token}} : {}),
513
+ ...{groups: [payload]},
514
+ };
515
+ // @ts-ignore
516
+ const breakoutInfo = await this.webex
517
+ .request({
518
+ method: HTTP_VERBS.PUT,
519
+ uri: this.url,
520
+ body,
521
+ })
522
+ .catch((error) => {
523
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#create'));
524
+ });
525
+
526
+ this._setManageGroups(breakoutInfo);
527
+
528
+ // clear edit lock info after save breakout session info
529
+ this._clearEditLockInfo();
530
+
531
+ return breakoutInfo;
532
+ },
533
+
534
+ /**
535
+ * Delete all breakout sessions
536
+ * @returns {Promise}
537
+ */
538
+ async clearSessions() {
539
+ const body = {
540
+ ...(this.editLock && !!this.editLock.token ? {editlock: {token: this.editLock.token}} : {}),
541
+ ...{groups: [{action: BREAKOUTS.ACTION.DELETE}]},
542
+ };
543
+ // @ts-ignore
544
+ const breakoutInfo = await this.webex
545
+ .request({
546
+ method: HTTP_VERBS.PUT,
547
+ uri: this.url,
548
+ body,
549
+ })
550
+ .catch((error) => {
551
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#clearSessions'));
552
+ });
553
+
554
+ this._setManageGroups(breakoutInfo);
555
+
556
+ return breakoutInfo;
557
+ },
558
+
559
+ /**
560
+ * Host or cohost starts breakout sessions
561
+ * @param {object} params
562
+ * @returns {Promise}
563
+ */
564
+ async start(params = {}) {
565
+ const action = BREAKOUTS.ACTION.START;
566
+ const payload = {
567
+ id: this.breakoutGroupId,
568
+ action,
569
+ allowBackToMain: false,
570
+ allowToJoinLater: false,
571
+ ...params,
572
+ };
573
+
574
+ const body = {
575
+ ...(this.editLock && !!this.editLock.token
576
+ ? {editlock: {token: this.editLock.token, refresh: true}}
577
+ : {}),
578
+ ...{groups: [payload]},
579
+ };
580
+
581
+ const breakoutInfo = await this.request({
582
+ method: HTTP_VERBS.PUT,
583
+ uri: this.url,
584
+ body,
585
+ }).catch((error) => {
586
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#start'));
587
+ });
588
+
589
+ this._setManageGroups(breakoutInfo);
590
+
591
+ return breakoutInfo;
592
+ },
593
+
594
+ /**
595
+ * Host or cohost ends breakout sessions
596
+ * @param {object} params
597
+ * @returns {Promise}
598
+ */
599
+ async end(params = {}) {
600
+ const {delayCloseTime, breakoutGroupId: id} = this;
601
+ const action = BREAKOUTS.ACTION.CLOSE;
602
+ const payload = {
603
+ id,
604
+ action,
605
+ delayCloseTime,
606
+ ...params,
607
+ };
608
+
609
+ const body = {
610
+ ...(this.editLock && !!this.editLock.token
611
+ ? {editlock: {token: this.editLock.token, refresh: true}}
612
+ : {}),
613
+ ...{groups: [payload]},
614
+ };
615
+
616
+ const breakoutInfo = await this.request({
617
+ method: HTTP_VERBS.PUT,
618
+ uri: this.url,
619
+ body,
620
+ }).catch((error) => {
621
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#end'));
622
+ });
623
+
624
+ this._setManageGroups(breakoutInfo);
625
+
626
+ return breakoutInfo;
627
+ },
628
+
629
+ /**
630
+ * Host or cohost update breakout sessions
631
+ * @param {Object} params
632
+ * @param {String} params.id
633
+ * @param {Boolean} unlockEdit
634
+ * @returns {Promise}
635
+ */
636
+ async update(params: {id: string}, unlockEdit?: boolean) {
637
+ if (!params.id) {
638
+ return Promise.reject(new Error('Missing breakout group id'));
639
+ }
640
+ const payload = {...params};
641
+
642
+ const body = {
643
+ ...(this.editLock?.token
644
+ ? {editlock: {token: this.editLock.token, refresh: !unlockEdit}}
645
+ : {}),
646
+ ...{groups: [payload]},
647
+ };
648
+
649
+ const breakoutInfo = await this.request({
650
+ method: HTTP_VERBS.PUT,
651
+ uri: this.url,
652
+ body,
653
+ }).catch((error) => {
654
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#update'));
655
+ });
656
+
657
+ if (unlockEdit) {
658
+ this._clearEditLockInfo();
659
+ }
660
+
661
+ this._setManageGroups(breakoutInfo);
662
+
663
+ return breakoutInfo;
664
+ },
665
+
666
+ /**
667
+ * get existed breakout sessions
668
+ * @param {boolean} editlock -- lock operations of the breakout sessions
669
+ * @returns {Promise}
670
+ */
671
+ async getBreakout(editlock) {
672
+ const breakout = await this.request({
673
+ method: HTTP_VERBS.GET,
674
+ uri: this.url + (editlock ? `?editlock=${editlock}` : ''),
675
+ });
676
+
677
+ this._setManageGroups(breakout);
678
+ if (editlock && breakout.body?.editlock?.token) {
679
+ this.set('editLock', breakout.body.editlock);
680
+ this.keepEditLockAlive();
681
+ }
682
+
683
+ return breakout;
684
+ },
685
+
686
+ /**
687
+ * enable and edit lock breakout
688
+ * @returns {void}
689
+ */
690
+ async enableAndLockBreakout() {
691
+ if (this.enableBreakoutSession) {
692
+ this.lockBreakout();
693
+ } else {
694
+ const info = await this.enableBreakouts();
695
+
696
+ if (info.body) {
697
+ this.lockBreakout();
698
+ }
699
+ }
700
+ },
701
+
702
+ /**
703
+ * breakout edit locked by yourself or not
704
+ * @returns {boolean}
705
+ */
706
+ hasBreakoutLocked() {
707
+ return (
708
+ this.editLock &&
709
+ this.editLock.token &&
710
+ this.editLock.state === BREAKOUTS.EDIT_LOCK_STATUS.LOCKED
711
+ );
712
+ },
713
+
714
+ /**
715
+ * send breakout edit lock
716
+ * @returns {void}
717
+ */
718
+ async lockBreakout() {
719
+ if (this.editLock && !!this.editLock.token) {
720
+ if (this.editLock.state === BREAKOUTS.EDIT_LOCK_STATUS.LOCKED) {
721
+ throw new Error('Breakout already locked');
722
+ } else {
723
+ this.keepEditLockAlive();
724
+ }
725
+ } else {
726
+ const breakout = await this.getBreakout(true);
727
+ if (breakout.body?.editlock) {
728
+ this.keepEditLockAlive();
729
+ }
730
+ }
731
+ },
732
+
733
+ /**
734
+ * keep edit lock alive
735
+ * @returns {void}
736
+ */
737
+ keepEditLockAlive() {
738
+ if (this.editLock && !!this.editLock.token) {
739
+ const ttl = this.editLock.ttl < 30 ? BREAKOUTS.DEFAULT_TTL : this.editLock.ttl;
740
+ if (this.intervalID) {
741
+ window.clearInterval(this.intervalID);
742
+ }
743
+
744
+ this.intervalID = window.setInterval(() => {
745
+ this.request({
746
+ method: HTTP_VERBS.PUT,
747
+ uri: `${this.url}/editlock/${this.editLock.token}`,
748
+ }).catch((error) => {
749
+ this._clearEditLockInfo();
750
+
751
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#keepEditLockAlive'));
752
+ });
753
+ }, (ttl / 2) * 1000);
754
+ }
755
+ },
756
+
757
+ /**
758
+ * unlock edit breakout
759
+ * @returns {void}
760
+ */
761
+ unLockEditBreakout() {
762
+ if (this.editLock && !!this.editLock.token) {
763
+ this.request({
764
+ method: HTTP_VERBS.DELETE,
765
+ uri: `${this.url}/editlock/${this.editLock.token}`,
766
+ })
767
+ .then(() => {
768
+ this._clearEditLockInfo();
769
+ })
770
+ .catch((error) => {
771
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#unLockEditBreakout'));
772
+ });
773
+ }
774
+ },
775
+
776
+ /**
777
+ * clear interval and edit lock info
778
+ * @private
779
+ * @returns {void}
780
+ */
781
+ _clearEditLockInfo() {
782
+ if (this.intervalID) {
783
+ clearInterval(this.intervalID);
784
+ }
785
+ this.set('editLock', {});
786
+ },
787
+
788
+ /**
789
+ * assign participants to breakout session
790
+ * @param {Array} sessions
791
+ * @returns {void}
792
+ */
793
+ assign(sessions: any[]) {
794
+ const internalSessions = sessions.map((item) => {
795
+ return {
796
+ id: item.id,
797
+ assigned: item.memberIds,
798
+ assignedEmails: item.emails,
799
+ anyoneCanJoin: !!item.anyone,
800
+ };
801
+ });
802
+
803
+ const body = {
804
+ ...(this.editLock && !!this.editLock.token
805
+ ? {editlock: {token: this.editLock.token, refresh: true}}
806
+ : {}),
807
+ ...{
808
+ groups: [
809
+ {
810
+ id: this.breakoutGroupId,
811
+ sessions: internalSessions,
812
+ },
813
+ ],
814
+ },
815
+ };
816
+
817
+ return this.request({
818
+ method: HTTP_VERBS.PUT,
819
+ uri: this.url,
820
+ body,
821
+ });
822
+ },
823
+
824
+ /**
825
+ * query preAssignments
826
+ * @returns {void}
827
+ */
828
+ queryPreAssignments() {
829
+ this.webex
830
+ .request({uri: `${this.url}/preassignments`, qs: {locusUrl: btoa(this.locusUrl)}})
831
+ .then((result) => {
832
+ if (result.body?.groups) {
833
+ this.set('preAssignments', result.body.groups);
834
+ this.trigger(BREAKOUTS.EVENTS.PRE_ASSIGNMENTS_UPDATE);
835
+ }
836
+ })
837
+ .catch((error) => {
838
+ LoggerProxy.logger.error('Meeting:breakouts#queryPreAssignments failed', error);
839
+ });
840
+ },
841
+ /**
842
+ * assign participants dynamically after breakout sessions started,
843
+ * but currently it only used for admitting participants from lobby into breakout directly
844
+ * @param {Array} sessions
845
+ * @returns {void}
846
+ */
847
+ dynamicAssign(sessions: any[]) {
848
+ const updatedSessions = sessions.map((item) => {
849
+ return {
850
+ id: item.id,
851
+ participants: item.participants,
852
+ targetState: item.targetState,
853
+ };
854
+ });
855
+
856
+ const body = {
857
+ groups: [
858
+ {
859
+ id: this.breakoutGroupId,
860
+ sessions: updatedSessions,
861
+ },
862
+ ],
863
+ editlock: null,
864
+ };
865
+
866
+ if (this.editLock && this.editLock.token) {
867
+ body.editlock = this.editLock;
868
+ }
869
+
870
+ return this.request({
871
+ method: HTTP_VERBS.PUT,
872
+ uri: `${this.url}/dynamicAssign`,
873
+ body,
874
+ });
875
+ },
876
+ /**
877
+ * trigger ASK_RETURN_TO_MAIN event when main session requested
878
+ * @param {Object} breakout
879
+ * @returns {void}
880
+ */
881
+ triggerReturnToMainEvent(breakout) {
882
+ if (breakout.isMain && breakout.requested) {
883
+ this.trigger(BREAKOUTS.EVENTS.ASK_RETURN_TO_MAIN);
884
+ }
885
+ },
886
+ });
887
+
888
+ export default Breakouts;