@webex/plugin-meetings 3.0.0-beta.6 → 3.0.0-beta.61

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 (506) hide show
  1. package/UPGRADING.md +9 -9
  2. package/browsers.js +19 -24
  3. package/dist/breakouts/breakout.js +137 -0
  4. package/dist/breakouts/breakout.js.map +1 -0
  5. package/dist/breakouts/collection.js +23 -0
  6. package/dist/breakouts/collection.js.map +1 -0
  7. package/dist/breakouts/edit-lock-error.js +52 -0
  8. package/dist/breakouts/edit-lock-error.js.map +1 -0
  9. package/dist/breakouts/index.js +725 -0
  10. package/dist/breakouts/index.js.map +1 -0
  11. package/dist/breakouts/request.js +78 -0
  12. package/dist/breakouts/request.js.map +1 -0
  13. package/dist/breakouts/utils.js +52 -0
  14. package/dist/breakouts/utils.js.map +1 -0
  15. package/dist/common/browser-detection.js +1 -20
  16. package/dist/common/browser-detection.js.map +1 -1
  17. package/dist/common/collection.js +5 -20
  18. package/dist/common/collection.js.map +1 -1
  19. package/dist/common/config.js +0 -7
  20. package/dist/common/config.js.map +1 -1
  21. package/dist/common/errors/captcha-error.js +10 -24
  22. package/dist/common/errors/captcha-error.js.map +1 -1
  23. package/dist/common/errors/intent-to-join.js +11 -24
  24. package/dist/common/errors/intent-to-join.js.map +1 -1
  25. package/dist/common/errors/join-meeting.js +12 -25
  26. package/dist/common/errors/join-meeting.js.map +1 -1
  27. package/dist/common/errors/media.js +10 -24
  28. package/dist/common/errors/media.js.map +1 -1
  29. package/dist/common/errors/parameter.js +5 -33
  30. package/dist/common/errors/parameter.js.map +1 -1
  31. package/dist/common/errors/password-error.js +10 -24
  32. package/dist/common/errors/password-error.js.map +1 -1
  33. package/dist/common/errors/permission.js +9 -23
  34. package/dist/common/errors/permission.js.map +1 -1
  35. package/dist/common/errors/reconnection-in-progress.js +0 -17
  36. package/dist/common/errors/reconnection-in-progress.js.map +1 -1
  37. package/dist/common/errors/reconnection.js +10 -24
  38. package/dist/common/errors/reconnection.js.map +1 -1
  39. package/dist/common/errors/stats.js +10 -24
  40. package/dist/common/errors/stats.js.map +1 -1
  41. package/dist/common/errors/webex-errors.js +6 -41
  42. package/dist/common/errors/webex-errors.js.map +1 -1
  43. package/dist/common/errors/webex-meetings-error.js +5 -25
  44. package/dist/common/errors/webex-meetings-error.js.map +1 -1
  45. package/dist/common/events/events-scope.js +0 -22
  46. package/dist/common/events/events-scope.js.map +1 -1
  47. package/dist/common/events/events.js +0 -23
  48. package/dist/common/events/events.js.map +1 -1
  49. package/dist/common/events/trigger-proxy.js +0 -12
  50. package/dist/common/events/trigger-proxy.js.map +1 -1
  51. package/dist/common/events/util.js +0 -15
  52. package/dist/common/events/util.js.map +1 -1
  53. package/dist/common/logs/logger-config.js +0 -4
  54. package/dist/common/logs/logger-config.js.map +1 -1
  55. package/dist/common/logs/logger-proxy.js +1 -8
  56. package/dist/common/logs/logger-proxy.js.map +1 -1
  57. package/dist/common/logs/request.js +37 -60
  58. package/dist/common/logs/request.js.map +1 -1
  59. package/dist/common/queue.js +4 -14
  60. package/dist/common/queue.js.map +1 -1
  61. package/dist/config.js +6 -6
  62. package/dist/config.js.map +1 -1
  63. package/dist/constants.js +135 -51
  64. package/dist/constants.js.map +1 -1
  65. package/dist/controls-options-manager/constants.js +14 -0
  66. package/dist/controls-options-manager/constants.js.map +1 -0
  67. package/dist/controls-options-manager/enums.js +16 -0
  68. package/dist/controls-options-manager/enums.js.map +1 -0
  69. package/dist/controls-options-manager/index.js +259 -0
  70. package/dist/controls-options-manager/index.js.map +1 -0
  71. package/dist/controls-options-manager/util.js +39 -0
  72. package/dist/controls-options-manager/util.js.map +1 -0
  73. package/dist/index.js +11 -18
  74. package/dist/index.js.map +1 -1
  75. package/dist/locus-info/controlsUtils.js +17 -30
  76. package/dist/locus-info/controlsUtils.js.map +1 -1
  77. package/dist/locus-info/embeddedAppsUtils.js +3 -26
  78. package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
  79. package/dist/locus-info/fullState.js +0 -15
  80. package/dist/locus-info/fullState.js.map +1 -1
  81. package/dist/locus-info/hostUtils.js +4 -12
  82. package/dist/locus-info/hostUtils.js.map +1 -1
  83. package/dist/locus-info/index.js +220 -192
  84. package/dist/locus-info/index.js.map +1 -1
  85. package/dist/locus-info/infoUtils.js +3 -37
  86. package/dist/locus-info/infoUtils.js.map +1 -1
  87. package/dist/locus-info/mediaSharesUtils.js +12 -38
  88. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  89. package/dist/locus-info/parser.js +92 -118
  90. package/dist/locus-info/parser.js.map +1 -1
  91. package/dist/locus-info/selfUtils.js +61 -90
  92. package/dist/locus-info/selfUtils.js.map +1 -1
  93. package/dist/media/index.js +56 -146
  94. package/dist/media/index.js.map +1 -1
  95. package/dist/media/properties.js +83 -117
  96. package/dist/media/properties.js.map +1 -1
  97. package/dist/media/util.js +2 -9
  98. package/dist/media/util.js.map +1 -1
  99. package/dist/mediaQualityMetrics/config.js +505 -495
  100. package/dist/mediaQualityMetrics/config.js.map +1 -1
  101. package/dist/meeting/in-meeting-actions.js +31 -14
  102. package/dist/meeting/in-meeting-actions.js.map +1 -1
  103. package/dist/meeting/index.js +2214 -2243
  104. package/dist/meeting/index.js.map +1 -1
  105. package/dist/meeting/muteState.js +102 -100
  106. package/dist/meeting/muteState.js.map +1 -1
  107. package/dist/meeting/request.js +308 -264
  108. package/dist/meeting/request.js.map +1 -1
  109. package/dist/meeting/request.type.js +7 -0
  110. package/dist/meeting/request.type.js.map +1 -0
  111. package/dist/meeting/state.js +21 -31
  112. package/dist/meeting/state.js.map +1 -1
  113. package/dist/meeting/util.js +63 -217
  114. package/dist/meeting/util.js.map +1 -1
  115. package/dist/meeting-info/collection.js +6 -25
  116. package/dist/meeting-info/collection.js.map +1 -1
  117. package/dist/meeting-info/index.js +14 -32
  118. package/dist/meeting-info/index.js.map +1 -1
  119. package/dist/meeting-info/meeting-info-v2.js +193 -268
  120. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  121. package/dist/meeting-info/request.js +3 -15
  122. package/dist/meeting-info/request.js.map +1 -1
  123. package/dist/meeting-info/util.js +98 -183
  124. package/dist/meeting-info/util.js.map +1 -1
  125. package/dist/meeting-info/utilv2.js +137 -228
  126. package/dist/meeting-info/utilv2.js.map +1 -1
  127. package/dist/meetings/collection.js +5 -20
  128. package/dist/meetings/collection.js.map +1 -1
  129. package/dist/meetings/index.js +493 -560
  130. package/dist/meetings/index.js.map +1 -1
  131. package/dist/meetings/request.js +26 -41
  132. package/dist/meetings/request.js.map +1 -1
  133. package/dist/meetings/util.js +116 -155
  134. package/dist/meetings/util.js.map +1 -1
  135. package/dist/member/index.js +100 -85
  136. package/dist/member/index.js.map +1 -1
  137. package/dist/member/types.js +15 -0
  138. package/dist/member/types.js.map +1 -0
  139. package/dist/member/util.js +90 -68
  140. package/dist/member/util.js.map +1 -1
  141. package/dist/members/collection.js +3 -12
  142. package/dist/members/collection.js.map +1 -1
  143. package/dist/members/index.js +131 -203
  144. package/dist/members/index.js.map +1 -1
  145. package/dist/members/request.js +35 -39
  146. package/dist/members/request.js.map +1 -1
  147. package/dist/members/types.js +15 -0
  148. package/dist/members/types.js.map +1 -0
  149. package/dist/members/util.js +76 -46
  150. package/dist/members/util.js.map +1 -1
  151. package/dist/metrics/config.js +1 -13
  152. package/dist/metrics/config.js.map +1 -1
  153. package/dist/metrics/constants.js +1 -6
  154. package/dist/metrics/constants.js.map +1 -1
  155. package/dist/metrics/index.js +54 -156
  156. package/dist/metrics/index.js.map +1 -1
  157. package/dist/multistream/mediaRequestManager.js +74 -52
  158. package/dist/multistream/mediaRequestManager.js.map +1 -1
  159. package/dist/multistream/receiveSlot.js +58 -65
  160. package/dist/multistream/receiveSlot.js.map +1 -1
  161. package/dist/multistream/receiveSlotManager.js +58 -93
  162. package/dist/multistream/receiveSlotManager.js.map +1 -1
  163. package/dist/multistream/remoteMedia.js +62 -76
  164. package/dist/multistream/remoteMedia.js.map +1 -1
  165. package/dist/multistream/remoteMediaGroup.js +6 -40
  166. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  167. package/dist/multistream/remoteMediaManager.js +466 -442
  168. package/dist/multistream/remoteMediaManager.js.map +1 -1
  169. package/dist/networkQualityMonitor/index.js +40 -59
  170. package/dist/networkQualityMonitor/index.js.map +1 -1
  171. package/dist/personal-meeting-room/index.js +21 -45
  172. package/dist/personal-meeting-room/index.js.map +1 -1
  173. package/dist/personal-meeting-room/request.js +1 -31
  174. package/dist/personal-meeting-room/request.js.map +1 -1
  175. package/dist/personal-meeting-room/util.js +0 -13
  176. package/dist/personal-meeting-room/util.js.map +1 -1
  177. package/dist/reachability/index.js +192 -191
  178. package/dist/reachability/index.js.map +1 -1
  179. package/dist/reachability/request.js +15 -23
  180. package/dist/reachability/request.js.map +1 -1
  181. package/dist/reactions/constants.js +13 -0
  182. package/dist/reactions/constants.js.map +1 -0
  183. package/dist/reactions/reactions.js +109 -0
  184. package/dist/reactions/reactions.js.map +1 -0
  185. package/dist/reactions/reactions.type.js +36 -0
  186. package/dist/reactions/reactions.type.js.map +1 -0
  187. package/dist/reconnection-manager/index.js +342 -460
  188. package/dist/reconnection-manager/index.js.map +1 -1
  189. package/dist/recording-controller/enums.js +17 -0
  190. package/dist/recording-controller/enums.js.map +1 -0
  191. package/dist/recording-controller/index.js +343 -0
  192. package/dist/recording-controller/index.js.map +1 -0
  193. package/dist/recording-controller/util.js +63 -0
  194. package/dist/recording-controller/util.js.map +1 -0
  195. package/dist/roap/index.js +48 -70
  196. package/dist/roap/index.js.map +1 -1
  197. package/dist/roap/request.js +143 -131
  198. package/dist/roap/request.js.map +1 -1
  199. package/dist/roap/turnDiscovery.js +91 -98
  200. package/dist/roap/turnDiscovery.js.map +1 -1
  201. package/dist/statsAnalyzer/global.js +1 -95
  202. package/dist/statsAnalyzer/global.js.map +1 -1
  203. package/dist/statsAnalyzer/index.js +372 -455
  204. package/dist/statsAnalyzer/index.js.map +1 -1
  205. package/dist/statsAnalyzer/mqaUtil.js +143 -87
  206. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  207. package/dist/transcription/index.js +22 -47
  208. package/dist/transcription/index.js.map +1 -1
  209. package/dist/types/breakouts/breakout.d.ts +8 -0
  210. package/dist/types/breakouts/collection.d.ts +5 -0
  211. package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
  212. package/dist/types/breakouts/index.d.ts +5 -0
  213. package/dist/types/breakouts/request.d.ts +22 -0
  214. package/dist/types/breakouts/utils.d.ts +8 -0
  215. package/dist/types/common/browser-detection.d.ts +9 -0
  216. package/dist/types/common/collection.d.ts +48 -0
  217. package/dist/types/common/config.d.ts +2 -0
  218. package/dist/types/common/errors/captcha-error.d.ts +15 -0
  219. package/dist/types/common/errors/intent-to-join.d.ts +16 -0
  220. package/dist/types/common/errors/join-meeting.d.ts +17 -0
  221. package/dist/types/common/errors/media.d.ts +15 -0
  222. package/dist/types/common/errors/parameter.d.ts +15 -0
  223. package/dist/types/common/errors/password-error.d.ts +15 -0
  224. package/dist/types/common/errors/permission.d.ts +14 -0
  225. package/dist/types/common/errors/reconnection-in-progress.d.ts +9 -0
  226. package/dist/types/common/errors/reconnection.d.ts +15 -0
  227. package/dist/types/common/errors/stats.d.ts +15 -0
  228. package/dist/types/common/errors/webex-errors.d.ts +69 -0
  229. package/dist/types/common/errors/webex-meetings-error.d.ts +20 -0
  230. package/dist/types/common/events/events-scope.d.ts +17 -0
  231. package/dist/types/common/events/events.d.ts +12 -0
  232. package/dist/types/common/events/trigger-proxy.d.ts +2 -0
  233. package/dist/types/common/events/util.d.ts +2 -0
  234. package/dist/types/common/logs/logger-config.d.ts +2 -0
  235. package/dist/types/common/logs/logger-proxy.d.ts +2 -0
  236. package/dist/types/common/logs/request.d.ts +34 -0
  237. package/dist/types/common/queue.d.ts +32 -0
  238. package/dist/types/config.d.ts +77 -0
  239. package/dist/types/constants.d.ts +939 -0
  240. package/dist/types/controls-options-manager/constants.d.ts +4 -0
  241. package/dist/types/controls-options-manager/enums.d.ts +6 -0
  242. package/dist/types/controls-options-manager/index.d.ts +128 -0
  243. package/dist/types/controls-options-manager/util.d.ts +9 -0
  244. package/dist/types/index.d.ts +6 -0
  245. package/dist/types/locus-info/controlsUtils.d.ts +2 -0
  246. package/dist/types/locus-info/embeddedAppsUtils.d.ts +2 -0
  247. package/dist/types/locus-info/fullState.d.ts +2 -0
  248. package/dist/types/locus-info/hostUtils.d.ts +2 -0
  249. package/dist/types/locus-info/index.d.ts +276 -0
  250. package/dist/types/locus-info/infoUtils.d.ts +2 -0
  251. package/dist/types/locus-info/mediaSharesUtils.d.ts +2 -0
  252. package/dist/types/locus-info/parser.d.ts +212 -0
  253. package/dist/types/locus-info/selfUtils.d.ts +2 -0
  254. package/dist/types/media/index.d.ts +32 -0
  255. package/dist/types/media/properties.d.ts +108 -0
  256. package/dist/types/media/util.d.ts +2 -0
  257. package/dist/types/mediaQualityMetrics/config.d.ts +365 -0
  258. package/dist/types/meeting/in-meeting-actions.d.ts +101 -0
  259. package/dist/types/meeting/index.d.ts +1719 -0
  260. package/dist/types/meeting/muteState.d.ts +132 -0
  261. package/dist/types/meeting/request.d.ts +271 -0
  262. package/dist/types/meeting/request.type.d.ts +11 -0
  263. package/dist/types/meeting/state.d.ts +9 -0
  264. package/dist/types/meeting/util.d.ts +2 -0
  265. package/dist/types/meeting-info/collection.d.ts +20 -0
  266. package/dist/types/meeting-info/index.d.ts +57 -0
  267. package/dist/types/meeting-info/meeting-info-v2.d.ts +93 -0
  268. package/dist/types/meeting-info/request.d.ts +22 -0
  269. package/dist/types/meeting-info/util.d.ts +2 -0
  270. package/dist/types/meeting-info/utilv2.d.ts +2 -0
  271. package/dist/types/meetings/collection.d.ts +23 -0
  272. package/dist/types/meetings/index.d.ts +297 -0
  273. package/dist/types/meetings/request.d.ts +27 -0
  274. package/dist/types/meetings/util.d.ts +18 -0
  275. package/dist/types/member/index.d.ts +156 -0
  276. package/dist/types/member/types.d.ts +21 -0
  277. package/dist/types/member/util.d.ts +2 -0
  278. package/dist/types/members/collection.d.ts +24 -0
  279. package/dist/types/members/index.d.ts +335 -0
  280. package/dist/types/members/request.d.ts +58 -0
  281. package/dist/types/members/types.d.ts +24 -0
  282. package/dist/types/members/util.d.ts +2 -0
  283. package/dist/types/metrics/config.d.ts +169 -0
  284. package/dist/types/metrics/constants.d.ts +53 -0
  285. package/dist/types/metrics/index.d.ts +152 -0
  286. package/dist/types/multistream/mediaRequestManager.d.ts +51 -0
  287. package/dist/types/multistream/receiveSlot.d.ts +68 -0
  288. package/dist/types/multistream/receiveSlotManager.d.ts +49 -0
  289. package/dist/types/multistream/remoteMedia.d.ts +100 -0
  290. package/dist/types/multistream/remoteMediaGroup.d.ts +56 -0
  291. package/dist/types/multistream/remoteMediaManager.d.ts +263 -0
  292. package/dist/types/networkQualityMonitor/index.d.ts +70 -0
  293. package/dist/types/personal-meeting-room/index.d.ts +47 -0
  294. package/dist/types/personal-meeting-room/request.d.ts +14 -0
  295. package/dist/types/personal-meeting-room/util.d.ts +2 -0
  296. package/dist/types/reachability/index.d.ts +152 -0
  297. package/dist/types/reachability/request.d.ts +37 -0
  298. package/dist/types/reactions/constants.d.ts +3 -0
  299. package/dist/types/reactions/reactions.d.ts +4 -0
  300. package/dist/types/reactions/reactions.type.d.ts +52 -0
  301. package/dist/types/reconnection-manager/index.d.ts +126 -0
  302. package/dist/types/recording-controller/enums.d.ts +7 -0
  303. package/dist/types/recording-controller/index.d.ts +193 -0
  304. package/dist/types/recording-controller/util.d.ts +13 -0
  305. package/dist/types/roap/index.d.ts +77 -0
  306. package/dist/types/roap/request.d.ts +38 -0
  307. package/dist/types/roap/turnDiscovery.d.ts +74 -0
  308. package/dist/types/statsAnalyzer/global.d.ts +36 -0
  309. package/dist/types/statsAnalyzer/index.d.ts +195 -0
  310. package/dist/types/statsAnalyzer/mqaUtil.d.ts +24 -0
  311. package/dist/types/transcription/index.d.ts +64 -0
  312. package/internal-README.md +7 -6
  313. package/package.json +27 -21
  314. package/src/breakouts/README.md +208 -0
  315. package/src/breakouts/breakout.ts +129 -0
  316. package/src/breakouts/collection.ts +19 -0
  317. package/src/breakouts/edit-lock-error.ts +25 -0
  318. package/src/breakouts/index.ts +659 -0
  319. package/src/breakouts/request.ts +55 -0
  320. package/src/breakouts/utils.ts +39 -0
  321. package/src/common/{browser-detection.js → browser-detection.ts} +9 -6
  322. package/src/common/collection.ts +9 -7
  323. package/src/common/{config.js → config.ts} +1 -1
  324. package/src/common/errors/{captcha-error.js → captcha-error.ts} +11 -7
  325. package/src/common/errors/{intent-to-join.js → intent-to-join.ts} +12 -7
  326. package/src/common/errors/{join-meeting.js → join-meeting.ts} +17 -8
  327. package/src/common/errors/{media.js → media.ts} +11 -7
  328. package/src/common/errors/parameter.ts +11 -7
  329. package/src/common/errors/{password-error.js → password-error.ts} +11 -7
  330. package/src/common/errors/{permission.js → permission.ts} +10 -6
  331. package/src/common/errors/{reconnection.js → reconnection.ts} +11 -7
  332. package/src/common/errors/{stats.js → stats.ts} +11 -7
  333. package/src/common/errors/{webex-errors.js → webex-errors.ts} +8 -7
  334. package/src/common/errors/{webex-meetings-error.js → webex-meetings-error.ts} +4 -2
  335. package/src/common/events/{events-scope.js → events-scope.ts} +6 -2
  336. package/src/common/events/{events.js → events.ts} +5 -1
  337. package/src/common/events/{trigger-proxy.js → trigger-proxy.ts} +9 -5
  338. package/src/common/events/{util.js → util.ts} +2 -3
  339. package/src/common/logs/{logger-config.js → logger-config.ts} +1 -2
  340. package/src/common/logs/logger-proxy.ts +44 -0
  341. package/src/common/logs/{request.js → request.ts} +22 -9
  342. package/src/common/queue.ts +1 -2
  343. package/src/{config.js → config.ts} +17 -12
  344. package/src/constants.ts +87 -5
  345. package/src/controls-options-manager/constants.ts +5 -0
  346. package/src/controls-options-manager/enums.ts +7 -0
  347. package/src/controls-options-manager/index.ts +234 -0
  348. package/src/controls-options-manager/util.ts +30 -0
  349. package/src/index.js +4 -1
  350. package/src/locus-info/controlsUtils.ts +122 -0
  351. package/src/locus-info/{embeddedAppsUtils.js → embeddedAppsUtils.ts} +5 -6
  352. package/src/locus-info/{fullState.js → fullState.ts} +16 -12
  353. package/src/locus-info/{hostUtils.js → hostUtils.ts} +9 -8
  354. package/src/locus-info/{index.js → index.ts} +192 -67
  355. package/src/locus-info/{infoUtils.js → infoUtils.ts} +19 -8
  356. package/src/locus-info/{mediaSharesUtils.js → mediaSharesUtils.ts} +17 -17
  357. package/src/locus-info/{parser.js → parser.ts} +67 -79
  358. package/src/locus-info/{selfUtils.js → selfUtils.ts} +157 -68
  359. package/src/media/{index.js → index.ts} +179 -176
  360. package/src/media/{properties.js → properties.ts} +60 -37
  361. package/src/media/{util.js → util.ts} +2 -2
  362. package/src/mediaQualityMetrics/config.ts +384 -0
  363. package/src/meeting/in-meeting-actions.ts +67 -3
  364. package/src/meeting/{index.js → index.ts} +2581 -1588
  365. package/src/meeting/{muteState.js → muteState.ts} +138 -73
  366. package/src/meeting/{request.js → request.ts} +326 -142
  367. package/src/meeting/request.type.ts +13 -0
  368. package/src/meeting/{state.js → state.ts} +50 -35
  369. package/src/meeting/{util.js → util.ts} +131 -115
  370. package/src/meeting-info/{collection.js → collection.ts} +6 -2
  371. package/src/meeting-info/{index.js → index.ts} +42 -36
  372. package/src/meeting-info/meeting-info-v2.ts +273 -0
  373. package/src/meeting-info/{request.js → request.ts} +14 -4
  374. package/src/meeting-info/{util.js → util.ts} +60 -51
  375. package/src/meeting-info/{utilv2.js → utilv2.ts} +65 -58
  376. package/src/meetings/{collection.js → collection.ts} +6 -3
  377. package/src/meetings/index.ts +1167 -0
  378. package/src/meetings/{request.js → request.ts} +34 -25
  379. package/src/meetings/{util.js → util.ts} +58 -32
  380. package/src/member/{index.js → index.ts} +124 -56
  381. package/src/member/types.ts +24 -0
  382. package/src/member/{util.js → util.ts} +105 -25
  383. package/src/members/{collection.js → collection.ts} +2 -2
  384. package/src/members/{index.js → index.ts} +258 -144
  385. package/src/members/{request.js → request.ts} +80 -16
  386. package/src/members/types.ts +28 -0
  387. package/src/members/{util.js → util.ts} +108 -55
  388. package/src/metrics/{config.js → config.ts} +253 -92
  389. package/src/metrics/{constants.js → constants.ts} +0 -6
  390. package/src/metrics/{index.js → index.ts} +105 -94
  391. package/src/multistream/mediaRequestManager.ts +101 -39
  392. package/src/multistream/receiveSlot.ts +69 -26
  393. package/src/multistream/receiveSlotManager.ts +50 -38
  394. package/src/multistream/remoteMedia.ts +40 -5
  395. package/src/multistream/remoteMediaGroup.ts +4 -3
  396. package/src/multistream/remoteMediaManager.ts +230 -66
  397. package/src/networkQualityMonitor/{index.js → index.ts} +41 -29
  398. package/src/personal-meeting-room/{index.js → index.ts} +28 -19
  399. package/src/personal-meeting-room/{request.js → request.ts} +13 -4
  400. package/src/personal-meeting-room/{util.js → util.ts} +4 -4
  401. package/src/reachability/{index.js → index.ts} +157 -94
  402. package/src/reachability/request.ts +46 -35
  403. package/src/reactions/constants.ts +4 -0
  404. package/src/reactions/reactions.ts +104 -0
  405. package/src/reactions/reactions.type.ts +62 -0
  406. package/src/reconnection-manager/{index.js → index.ts} +228 -120
  407. package/src/recording-controller/enums.ts +8 -0
  408. package/src/recording-controller/index.ts +315 -0
  409. package/src/recording-controller/util.ts +58 -0
  410. package/src/roap/{index.js → index.ts} +77 -60
  411. package/src/roap/request.ts +172 -0
  412. package/src/roap/turnDiscovery.ts +81 -41
  413. package/src/statsAnalyzer/global.ts +37 -0
  414. package/src/statsAnalyzer/index.ts +1242 -0
  415. package/src/statsAnalyzer/mqaUtil.ts +291 -0
  416. package/src/transcription/{index.js → index.ts} +46 -39
  417. package/test/integration/spec/converged-space-meetings.js +176 -0
  418. package/test/integration/spec/journey.js +665 -464
  419. package/test/integration/spec/space-meeting.js +320 -206
  420. package/test/integration/spec/transcription.js +7 -8
  421. package/test/unit/spec/breakouts/breakout.ts +146 -0
  422. package/test/unit/spec/breakouts/collection.ts +15 -0
  423. package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
  424. package/test/unit/spec/breakouts/index.ts +944 -0
  425. package/test/unit/spec/breakouts/request.ts +104 -0
  426. package/test/unit/spec/breakouts/utils.js +47 -0
  427. package/test/unit/spec/common/browser-detection.js +9 -28
  428. package/test/unit/spec/controls-options-manager/index.js +180 -0
  429. package/test/unit/spec/controls-options-manager/util.js +86 -0
  430. package/test/unit/spec/fixture/locus.js +92 -90
  431. package/test/unit/spec/locus-info/controlsUtils.js +112 -34
  432. package/test/unit/spec/locus-info/embeddedAppsUtils.js +8 -6
  433. package/test/unit/spec/locus-info/index.js +219 -2
  434. package/test/unit/spec/locus-info/infoUtils.js +41 -32
  435. package/test/unit/spec/locus-info/lib/BasicSeqCmp.json +88 -430
  436. package/test/unit/spec/locus-info/lib/SeqCmp.json +513 -685
  437. package/test/unit/spec/locus-info/parser.js +3 -9
  438. package/test/unit/spec/locus-info/selfConstant.js +101 -103
  439. package/test/unit/spec/locus-info/selfUtils.js +128 -12
  440. package/test/unit/spec/media/index.ts +72 -8
  441. package/test/unit/spec/media/properties.ts +9 -9
  442. package/test/unit/spec/meeting/in-meeting-actions.ts +29 -2
  443. package/test/unit/spec/meeting/index.js +2490 -802
  444. package/test/unit/spec/meeting/muteState.js +146 -61
  445. package/test/unit/spec/meeting/request.js +141 -43
  446. package/test/unit/spec/meeting/utils.js +135 -164
  447. package/test/unit/spec/meeting-info/meetinginfov2.js +100 -73
  448. package/test/unit/spec/meeting-info/request.js +7 -9
  449. package/test/unit/spec/meeting-info/util.js +11 -12
  450. package/test/unit/spec/meeting-info/utilv2.js +110 -74
  451. package/test/unit/spec/meetings/collection.js +1 -1
  452. package/test/unit/spec/meetings/index.js +439 -257
  453. package/test/unit/spec/meetings/utils.js +14 -12
  454. package/test/unit/spec/member/index.js +24 -1
  455. package/test/unit/spec/member/util.js +359 -32
  456. package/test/unit/spec/members/index.js +256 -54
  457. package/test/unit/spec/members/request.js +50 -20
  458. package/test/unit/spec/members/utils.js +147 -4
  459. package/test/unit/spec/metrics/index.js +16 -21
  460. package/test/unit/spec/multistream/mediaRequestManager.ts +318 -64
  461. package/test/unit/spec/multistream/receiveSlot.ts +76 -17
  462. package/test/unit/spec/multistream/receiveSlotManager.ts +60 -38
  463. package/test/unit/spec/multistream/remoteMedia.ts +40 -2
  464. package/test/unit/spec/multistream/remoteMediaGroup.ts +5 -5
  465. package/test/unit/spec/multistream/remoteMediaManager.ts +607 -65
  466. package/test/unit/spec/networkQualityMonitor/index.js +24 -18
  467. package/test/unit/spec/personal-meeting-room/personal-meeting-room.js +2 -7
  468. package/test/unit/spec/reachability/index.ts +176 -27
  469. package/test/unit/spec/reachability/request.js +66 -0
  470. package/test/unit/spec/reconnection-manager/index.js +58 -30
  471. package/test/unit/spec/recording-controller/index.js +231 -0
  472. package/test/unit/spec/recording-controller/util.js +102 -0
  473. package/test/unit/spec/roap/index.ts +12 -8
  474. package/test/unit/spec/roap/request.ts +217 -0
  475. package/test/unit/spec/roap/turnDiscovery.ts +72 -49
  476. package/test/unit/spec/stats-analyzer/index.js +108 -57
  477. package/test/utils/cmr.js +44 -42
  478. package/test/utils/constants.js +9 -0
  479. package/test/utils/testUtils.js +98 -77
  480. package/test/utils/webex-config.js +22 -18
  481. package/test/utils/webex-test-users.js +57 -50
  482. package/tsconfig.json +6 -0
  483. package/dist/media/internal-media-core-wrapper.js +0 -22
  484. package/dist/media/internal-media-core-wrapper.js.map +0 -1
  485. package/dist/meeting/effectsState.js +0 -327
  486. package/dist/meeting/effectsState.js.map +0 -1
  487. package/dist/multistream/multistreamMedia.js +0 -116
  488. package/dist/multistream/multistreamMedia.js.map +0 -1
  489. package/dist/peer-connection-manager/util.js +0 -124
  490. package/dist/peer-connection-manager/util.js.map +0 -1
  491. package/src/common/logs/logger-proxy.js +0 -33
  492. package/src/locus-info/controlsUtils.js +0 -102
  493. package/src/media/internal-media-core-wrapper.ts +0 -9
  494. package/src/mediaQualityMetrics/config.js +0 -382
  495. package/src/meeting/effectsState.js +0 -205
  496. package/src/meeting-info/meeting-info-v2.js +0 -255
  497. package/src/meetings/index.js +0 -1015
  498. package/src/multistream/multistreamMedia.ts +0 -92
  499. package/src/peer-connection-manager/util.ts +0 -117
  500. package/src/roap/request.js +0 -127
  501. package/src/statsAnalyzer/global.js +0 -133
  502. package/src/statsAnalyzer/index.js +0 -1006
  503. package/src/statsAnalyzer/mqaUtil.js +0 -173
  504. package/test/unit/spec/meeting/effectsState.js +0 -291
  505. package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -389
  506. /package/src/common/errors/{reconnection-in-progress.js → reconnection-in-progress.ts} +0 -0
@@ -0,0 +1,725 @@
1
+ "use strict";
2
+
3
+ var _Object$keys = require("@babel/runtime-corejs2/core-js/object/keys");
4
+ var _Object$getOwnPropertySymbols = require("@babel/runtime-corejs2/core-js/object/get-own-property-symbols");
5
+ var _Object$getOwnPropertyDescriptor = require("@babel/runtime-corejs2/core-js/object/get-own-property-descriptor");
6
+ var _Object$getOwnPropertyDescriptors = require("@babel/runtime-corejs2/core-js/object/get-own-property-descriptors");
7
+ var _Object$defineProperties = require("@babel/runtime-corejs2/core-js/object/define-properties");
8
+ var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
9
+ var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
10
+ _Object$defineProperty(exports, "__esModule", {
11
+ value: true
12
+ });
13
+ exports.default = void 0;
14
+ var _regenerator = _interopRequireDefault(require("@babel/runtime-corejs2/regenerator"));
15
+ var _values = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/values"));
16
+ var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
17
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/asyncToGenerator"));
18
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
19
+ var _forEach2 = _interopRequireDefault(require("lodash/forEach"));
20
+ var _debounce2 = _interopRequireDefault(require("lodash/debounce"));
21
+ var _webexCore = require("@webex/webex-core");
22
+ var _loggerProxy = _interopRequireDefault(require("../common/logs/logger-proxy"));
23
+ var _constants = require("../constants");
24
+ var _breakout = _interopRequireDefault(require("./breakout"));
25
+ var _collection = _interopRequireDefault(require("./collection"));
26
+ var _request = _interopRequireDefault(require("./request"));
27
+ var _utils = require("./utils");
28
+ function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
29
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
30
+ /**
31
+ * @class Breakouts
32
+ */
33
+ var Breakouts = _webexCore.WebexPlugin.extend({
34
+ namespace: _constants.MEETINGS,
35
+ breakoutRequest: _request.default,
36
+ collections: {
37
+ breakouts: _collection.default
38
+ },
39
+ props: {
40
+ allowBackToMain: 'boolean',
41
+ // only present when in a breakout session
42
+ delayCloseTime: 'number',
43
+ // appears once breakouts start
44
+ enableBreakoutSession: 'boolean',
45
+ // appears from the moment you enable breakouts
46
+ groupId: 'string',
47
+ // appears from the moment you enable breakouts
48
+ name: 'string',
49
+ // only present when in a breakout session
50
+ sessionId: 'string',
51
+ // appears from the moment you enable breakouts
52
+ sessionType: 'string',
53
+ // appears from the moment you enable breakouts
54
+ startTime: 'string',
55
+ // appears once breakouts start
56
+ status: 'string',
57
+ // only present when in a breakout session
58
+ url: 'string',
59
+ // appears from the moment you enable breakouts
60
+ locusUrl: 'string',
61
+ // the current locus url
62
+ breakoutServiceUrl: 'string',
63
+ // the current breakout resource url
64
+ mainLocusUrl: 'string',
65
+ // the locus url of the main session
66
+ groups: 'array',
67
+ // appears when create breakouts
68
+ editLock: 'object',
69
+ // appears when getBreakout info editlock = true
70
+ intervalID: 'number'
71
+ },
72
+ children: {
73
+ currentBreakoutSession: _breakout.default
74
+ },
75
+ derived: {
76
+ isInMainSession: {
77
+ deps: ['sessionType'],
78
+ /**
79
+ * Returns true if the user is in the main session
80
+ * @returns {boolean}
81
+ */
82
+ fn: function fn() {
83
+ return this.sessionType === _constants.BREAKOUTS.SESSION_TYPES.MAIN;
84
+ }
85
+ },
86
+ breakoutGroupId: {
87
+ deps: ['groups'],
88
+ /**
89
+ * Returns the actived group id
90
+ * @returns {boolean}
91
+ */
92
+ fn: function fn() {
93
+ var _this$groups;
94
+ if ((_this$groups = this.groups) !== null && _this$groups !== void 0 && _this$groups.length) {
95
+ return this.groups[0].id;
96
+ }
97
+ return '';
98
+ }
99
+ }
100
+ },
101
+ /**
102
+ * initialize for the breakouts
103
+ * @returns {void}
104
+ */
105
+ initialize: function initialize() {
106
+ var _this = this;
107
+ this.listenTo(this, 'change:status', function () {
108
+ if (_this.status === _constants.BREAKOUTS.STATUS.CLOSING) {
109
+ _this.trigger(_constants.BREAKOUTS.EVENTS.BREAKOUTS_CLOSING);
110
+ }
111
+ });
112
+ this.debouncedQueryRosters = (0, _debounce2.default)(this.queryRosters, 10, {
113
+ leading: true,
114
+ trailing: false
115
+ });
116
+ this.listenTo(this.breakouts, 'add', function () {
117
+ _this.debouncedQueryRosters();
118
+ });
119
+ this.listenToBroadcastMessages();
120
+ this.listenToBreakoutRosters();
121
+ // @ts-ignore
122
+ this.breakoutRequest = new _request.default({
123
+ webex: this.webex
124
+ });
125
+ },
126
+ /**
127
+ * Calls this to clean up listeners
128
+ * @returns {void}
129
+ */
130
+ cleanUp: function cleanUp() {
131
+ this.stopListening();
132
+ },
133
+ /**
134
+ * Update the current locus url of the meeting
135
+ * @param {string} locusUrl // locus url
136
+ * @returns {void}
137
+ */
138
+ locusUrlUpdate: function locusUrlUpdate(locusUrl) {
139
+ this.set('locusUrl', locusUrl);
140
+ var isInMainSession = this.isInMainSession,
141
+ mainLocusUrl = this.mainLocusUrl;
142
+ if (isInMainSession || !mainLocusUrl) {
143
+ this.set('mainLocusUrl', locusUrl);
144
+ }
145
+ },
146
+ /**
147
+ * Update the current breakout resource url
148
+ * @param {string} breakoutServiceUrl
149
+ * @returns {void}
150
+ */
151
+ breakoutServiceUrlUpdate: function breakoutServiceUrlUpdate(breakoutServiceUrl) {
152
+ this.set('breakoutServiceUrl', "".concat(breakoutServiceUrl, "/breakout/"));
153
+ },
154
+ /**
155
+ * The initial roster lists need to be queried because you don't
156
+ * get a breakout.roster event when you join the meeting
157
+ * @returns {void}
158
+ */
159
+ queryRosters: function queryRosters() {
160
+ var _this2 = this;
161
+ this.webex.request({
162
+ uri: "".concat(this.url, "/roster"),
163
+ qs: {
164
+ locusUrl: btoa(this.locusUrl)
165
+ }
166
+ }).then(function (result) {
167
+ var rosters = result.body.rosters;
168
+ rosters === null || rosters === void 0 ? void 0 : rosters.forEach(function (_ref) {
169
+ var locus = _ref.locus;
170
+ _this2.handleRosterUpdate(locus);
171
+ });
172
+ _this2.trigger(_constants.BREAKOUTS.EVENTS.MEMBERS_UPDATE);
173
+ }).catch(function (error) {
174
+ _loggerProxy.default.logger.error('Meeting:breakouts#queryRosters failed', error);
175
+ });
176
+ },
177
+ /**
178
+ *
179
+ * @param {Object} locus // locus object
180
+ * @returns {void}
181
+ */
182
+ handleRosterUpdate: function handleRosterUpdate(locus) {
183
+ var _locus$controls, _locus$controls$break;
184
+ var sessionId = (_locus$controls = locus.controls) === null || _locus$controls === void 0 ? void 0 : (_locus$controls$break = _locus$controls.breakout) === null || _locus$controls$break === void 0 ? void 0 : _locus$controls$break.sessionId;
185
+ var session = this.breakouts.get(sessionId);
186
+ if (!session) {
187
+ return;
188
+ }
189
+ session.parseRoster(locus);
190
+ },
191
+ /**
192
+ * Sets up listener for broadcast messages sent to the breakout session
193
+ * @returns {void}
194
+ */
195
+ listenToBroadcastMessages: function listenToBroadcastMessages() {
196
+ var _this3 = this;
197
+ this.listenTo(this.webex.internal.llm, 'event:breakout.message', function (event) {
198
+ var _event$data = event.data,
199
+ senderUserId = _event$data.senderUserId,
200
+ sentTime = _event$data.sentTime,
201
+ message = _event$data.message;
202
+ _this3.trigger(_constants.BREAKOUTS.EVENTS.MESSAGE, {
203
+ senderUserId: senderUserId,
204
+ sentTime: sentTime,
205
+ message: message,
206
+ // FIXME: This is only the current sessionId
207
+ // We'd need to check that the dataChannelUrl is still the same
208
+ // to guarantee that this message was sent to this session
209
+ sessionId: _this3.currentBreakoutSession.sessionId
210
+ });
211
+ });
212
+ },
213
+ /**
214
+ * Sets up a listener for roster messags from mecury
215
+ * @returns {void}
216
+ */
217
+ listenToBreakoutRosters: function listenToBreakoutRosters() {
218
+ var _this4 = this;
219
+ this.listenTo(this.webex.internal.mercury, 'event:breakout.roster', function (event) {
220
+ _this4.handleRosterUpdate(event.data.locus);
221
+ _this4.trigger(_constants.BREAKOUTS.EVENTS.MEMBERS_UPDATE);
222
+ });
223
+ },
224
+ /**
225
+ * Updates the information about the current breakout
226
+ * @param {Object} params
227
+ * @returns {void}
228
+ */
229
+ updateBreakout: function updateBreakout(params) {
230
+ var _this$set;
231
+ this.set(params);
232
+ this.set('groups', params.groups);
233
+ this.set('currentBreakoutSession', (_this$set = {
234
+ sessionId: params.sessionId,
235
+ groupId: params.groupId,
236
+ name: params.name,
237
+ current: true,
238
+ sessionType: params.sessionType,
239
+ url: params.url
240
+ }, (0, _defineProperty2.default)(_this$set, _constants.BREAKOUTS.SESSION_STATES.ACTIVE, false), (0, _defineProperty2.default)(_this$set, _constants.BREAKOUTS.SESSION_STATES.ALLOWED, false), (0, _defineProperty2.default)(_this$set, _constants.BREAKOUTS.SESSION_STATES.ALLOWED, false), (0, _defineProperty2.default)(_this$set, _constants.BREAKOUTS.SESSION_STATES.ASSIGNED_CURRENT, false), (0, _defineProperty2.default)(_this$set, _constants.BREAKOUTS.SESSION_STATES.REQUESTED, false), _this$set));
241
+ this.set('enableBreakoutSession', params.enableBreakoutSession);
242
+ },
243
+ /**
244
+ * Updates the information about available breakouts
245
+ * @param {Object} payload
246
+ * @returns {void}
247
+ */
248
+ updateBreakoutSessions: function updateBreakoutSessions(payload) {
249
+ var _this5 = this;
250
+ var breakouts = {};
251
+ if (payload.breakoutSessions) {
252
+ (0, _forEach2.default)(_constants.BREAKOUTS.SESSION_STATES, function (state) {
253
+ (0, _forEach2.default)(payload.breakoutSessions[state], function (breakout) {
254
+ var sessionId = breakout.sessionId;
255
+ if (!breakouts[sessionId]) {
256
+ breakouts[sessionId] = breakout;
257
+ breakouts[sessionId][_constants.BREAKOUTS.SESSION_STATES.ACTIVE] = false;
258
+ breakouts[sessionId][_constants.BREAKOUTS.SESSION_STATES.ASSIGNED] = false;
259
+ breakouts[sessionId][_constants.BREAKOUTS.SESSION_STATES.ALLOWED] = false;
260
+ breakouts[sessionId][_constants.BREAKOUTS.SESSION_STATES.ASSIGNED_CURRENT] = false;
261
+ breakouts[sessionId][_constants.BREAKOUTS.SESSION_STATES.REQUESTED] = false;
262
+ }
263
+ breakouts[sessionId][state] = true;
264
+ });
265
+ });
266
+ }
267
+ (0, _forEach2.default)(breakouts, function (breakout) {
268
+ // eslint-disable-next-line no-param-reassign
269
+ breakout.url = _this5.url;
270
+ });
271
+ this.breakouts.set((0, _values.default)(breakouts));
272
+ },
273
+ /**
274
+ * get main session
275
+ * @returns {Breakout}
276
+ */
277
+ getMainSession: function getMainSession() {
278
+ if (this.isInMainSession) {
279
+ return this.currentBreakoutSession;
280
+ }
281
+ var mainSession = this.breakouts.filter(function (breakout) {
282
+ return breakout.isMain;
283
+ })[0];
284
+ if (!mainSession) {
285
+ throw new Error('no main session found');
286
+ }
287
+ return mainSession;
288
+ },
289
+ /**
290
+ * Host/CoHost ask all participants return to main session
291
+ * @returns {Promise}
292
+ */
293
+ askAllToReturn: function askAllToReturn() {
294
+ var mainSession = this.getMainSession();
295
+ return this.webex.request({
296
+ method: _constants.HTTP_VERBS.POST,
297
+ uri: "".concat(this.url, "/requestMove"),
298
+ body: {
299
+ groupId: mainSession.groupId,
300
+ sessionId: mainSession.sessionId
301
+ }
302
+ });
303
+ },
304
+ /**
305
+ * Broadcast message to all breakout session's participants
306
+ * @param {String} message
307
+ * @param {Object} options
308
+ * @returns {Promise}
309
+ */
310
+ broadcast: function broadcast(message, options) {
311
+ var breakoutGroupId = this.breakoutGroupId;
312
+ if (!breakoutGroupId) {
313
+ throw new Error('Cannot broadcast, no breakout session found');
314
+ }
315
+ return this.breakoutRequest.broadcast({
316
+ url: this.url,
317
+ message: message,
318
+ options: options,
319
+ groupId: breakoutGroupId
320
+ });
321
+ },
322
+ /**
323
+ * Make enable breakout resource
324
+ * @returns {Promise}
325
+ */
326
+ enableBreakouts: function enableBreakouts() {
327
+ if (this.breakoutServiceUrl) {
328
+ // @ts-ignore
329
+ return this.webex.request({
330
+ method: _constants.HTTP_VERBS.POST,
331
+ uri: this.breakoutServiceUrl,
332
+ body: {
333
+ locusUrl: this.locusUrl
334
+ }
335
+ }).catch(function (err) {
336
+ _loggerProxy.default.logger.error("Meeting:request#touchBreakout --> Error provisioning error ".concat(err));
337
+ throw err;
338
+ });
339
+ }
340
+ return _promise.default.reject(new Error("enableBreakouts: the breakoutServiceUrl is empty"));
341
+ },
342
+ /**
343
+ * Make the meeting enable or disable breakout session
344
+ * @param {boolean} enable
345
+ * @returns {Promise}
346
+ */
347
+ toggleBreakout: function toggleBreakout(enable) {
348
+ var _this6 = this;
349
+ return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {
350
+ var info;
351
+ return _regenerator.default.wrap(function _callee$(_context) {
352
+ while (1) switch (_context.prev = _context.next) {
353
+ case 0:
354
+ if (!(_this6.enableBreakoutSession === undefined)) {
355
+ _context.next = 10;
356
+ break;
357
+ }
358
+ _context.next = 3;
359
+ return _this6.enableBreakouts();
360
+ case 3:
361
+ info = _context.sent;
362
+ if (enable) {
363
+ _context.next = 8;
364
+ break;
365
+ }
366
+ // if enable is false, updateBreakout set the param then set enableBreakoutSession as false
367
+ _this6.updateBreakout(info.body);
368
+ _context.next = 8;
369
+ return _this6.doToggleBreakout(enable);
370
+ case 8:
371
+ _context.next = 12;
372
+ break;
373
+ case 10:
374
+ _context.next = 12;
375
+ return _this6.doToggleBreakout(enable);
376
+ case 12:
377
+ case "end":
378
+ return _context.stop();
379
+ }
380
+ }, _callee);
381
+ }))();
382
+ },
383
+ /**
384
+ * do toggle meeting breakout session enable or disable
385
+ * @param {boolean} enable
386
+ * @returns {Promise}
387
+ */
388
+ doToggleBreakout: function doToggleBreakout(enable) {
389
+ // @ts-ignore
390
+ return this.webex.request({
391
+ method: _constants.HTTP_VERBS.PUT,
392
+ uri: this.url,
393
+ body: {
394
+ enableBreakoutSession: enable
395
+ }
396
+ });
397
+ },
398
+ /**
399
+ * Create new breakout sessions
400
+ * @param {object} sessions -- breakout session group
401
+ * @returns {Promise}
402
+ */
403
+ create: function create(sessions) {
404
+ var _this7 = this;
405
+ return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {
406
+ var _breakInfo$body;
407
+ var bodyInfo, breakInfo;
408
+ return _regenerator.default.wrap(function _callee2$(_context2) {
409
+ while (1) switch (_context2.prev = _context2.next) {
410
+ case 0:
411
+ // @ts-ignore
412
+ bodyInfo = _this7.editLock && !!_this7.editLock.token ? {
413
+ groups: [{
414
+ sessions: sessions
415
+ }],
416
+ editlock: {
417
+ token: _this7.editLock.token
418
+ }
419
+ } : {
420
+ groups: [{
421
+ sessions: sessions
422
+ }]
423
+ };
424
+ _context2.next = 3;
425
+ return _this7.webex.request({
426
+ method: _constants.HTTP_VERBS.PUT,
427
+ uri: _this7.url,
428
+ body: bodyInfo
429
+ }).catch(function (error) {
430
+ return _promise.default.reject((0, _utils.boServiceErrorHandler)(error, 'Breakouts#create --> Edit lock token mismatch'));
431
+ });
432
+ case 3:
433
+ breakInfo = _context2.sent;
434
+ if ((_breakInfo$body = breakInfo.body) !== null && _breakInfo$body !== void 0 && _breakInfo$body.groups) {
435
+ _this7.set('groups', breakInfo.body.groups);
436
+ }
437
+
438
+ // clear edit lock info after save breakout session info
439
+ _this7._clearEditLockInfo();
440
+ return _context2.abrupt("return", _promise.default.resolve(breakInfo));
441
+ case 7:
442
+ case "end":
443
+ return _context2.stop();
444
+ }
445
+ }, _callee2);
446
+ }))();
447
+ },
448
+ /**
449
+ * Delete all breakout sessions
450
+ * @returns {Promise}
451
+ */
452
+ clearSessions: function clearSessions() {
453
+ var _this8 = this;
454
+ return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3() {
455
+ var _breakInfo$body2;
456
+ var bodyInfo, breakInfo;
457
+ return _regenerator.default.wrap(function _callee3$(_context3) {
458
+ while (1) switch (_context3.prev = _context3.next) {
459
+ case 0:
460
+ // @ts-ignore
461
+ bodyInfo = _this8.editLock && !!_this8.editLock.token ? {
462
+ groups: [{
463
+ action: _constants.BREAKOUTS.ACTION.DELETE
464
+ }],
465
+ editlock: {
466
+ token: _this8.editLock.token
467
+ }
468
+ } : {
469
+ groups: [{
470
+ action: _constants.BREAKOUTS.ACTION.DELETE
471
+ }]
472
+ };
473
+ _context3.next = 3;
474
+ return _this8.webex.request({
475
+ method: _constants.HTTP_VERBS.PUT,
476
+ uri: _this8.url,
477
+ body: bodyInfo
478
+ }).catch(function (error) {
479
+ return _promise.default.reject((0, _utils.boServiceErrorHandler)(error, 'Breakouts#clearSessions --> Edit lock token mismatch'));
480
+ });
481
+ case 3:
482
+ breakInfo = _context3.sent;
483
+ if ((_breakInfo$body2 = breakInfo.body) !== null && _breakInfo$body2 !== void 0 && _breakInfo$body2.groups) {
484
+ _this8.set('groups', breakInfo.body.groups);
485
+ }
486
+ return _context3.abrupt("return", _promise.default.resolve(breakInfo));
487
+ case 6:
488
+ case "end":
489
+ return _context3.stop();
490
+ }
491
+ }, _callee3);
492
+ }))();
493
+ },
494
+ /**
495
+ * Host or cohost starts breakout sessions
496
+ * @param {object} params
497
+ * @returns {Promise}
498
+ */
499
+ start: function start() {
500
+ var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
501
+ var action = _constants.BREAKOUTS.ACTION.START;
502
+ var payload = _objectSpread({
503
+ id: this.breakoutGroupId,
504
+ action: action,
505
+ allowBackToMain: false,
506
+ allowToJoinLater: false,
507
+ duration: _constants.BREAKOUTS.DEFAULT_DURATION
508
+ }, params);
509
+ return this.request({
510
+ method: _constants.HTTP_VERBS.PUT,
511
+ uri: this.url,
512
+ body: {
513
+ groups: [payload]
514
+ }
515
+ }).catch(function (error) {
516
+ return _promise.default.reject((0, _utils.boServiceErrorHandler)(error, 'Breakouts#start --> Edit lock token mismatch'));
517
+ });
518
+ },
519
+ /**
520
+ * Host or cohost ends breakout sessions
521
+ * @param {object} params
522
+ * @returns {Promise}
523
+ */
524
+ end: function end() {
525
+ var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
526
+ var delayCloseTime = this.delayCloseTime,
527
+ id = this.breakoutGroupId;
528
+ var action = _constants.BREAKOUTS.ACTION.CLOSE;
529
+ var payload = _objectSpread({
530
+ id: id,
531
+ action: action,
532
+ delayCloseTime: delayCloseTime
533
+ }, params);
534
+ return this.request({
535
+ method: _constants.HTTP_VERBS.PUT,
536
+ uri: this.url,
537
+ body: {
538
+ groups: [payload]
539
+ }
540
+ }).catch(function (error) {
541
+ return _promise.default.reject((0, _utils.boServiceErrorHandler)(error, 'Breakouts#end --> Edit lock token mismatch'));
542
+ });
543
+ },
544
+ /**
545
+ * get existed breakout sessions
546
+ * @param {boolean} editlock -- lock operations of the breakout sessions
547
+ * @returns {Promise}
548
+ */
549
+ getBreakout: function getBreakout(editlock) {
550
+ var _this9 = this;
551
+ return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4() {
552
+ var _breakout$body, _breakout$body2;
553
+ var breakout;
554
+ return _regenerator.default.wrap(function _callee4$(_context4) {
555
+ while (1) switch (_context4.prev = _context4.next) {
556
+ case 0:
557
+ _context4.next = 2;
558
+ return _this9.request({
559
+ method: _constants.HTTP_VERBS.GET,
560
+ uri: _this9.url + (editlock ? "?editlock=".concat(editlock) : '')
561
+ });
562
+ case 2:
563
+ breakout = _context4.sent;
564
+ if ((_breakout$body = breakout.body) !== null && _breakout$body !== void 0 && _breakout$body.groups) {
565
+ _this9.set('groups', breakout.body.groups);
566
+ }
567
+ if ((_breakout$body2 = breakout.body) !== null && _breakout$body2 !== void 0 && _breakout$body2.editlock && editlock) {
568
+ _this9.set('editLock', breakout.body.editlock);
569
+ }
570
+ return _context4.abrupt("return", breakout);
571
+ case 6:
572
+ case "end":
573
+ return _context4.stop();
574
+ }
575
+ }, _callee4);
576
+ }))();
577
+ },
578
+ /**
579
+ * enable and edit lock breakout
580
+ * @returns {void}
581
+ */
582
+ enableAndLockBreakout: function enableAndLockBreakout() {
583
+ var _this10 = this;
584
+ return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5() {
585
+ var info;
586
+ return _regenerator.default.wrap(function _callee5$(_context5) {
587
+ while (1) switch (_context5.prev = _context5.next) {
588
+ case 0:
589
+ if (!_this10.enableBreakoutSession) {
590
+ _context5.next = 4;
591
+ break;
592
+ }
593
+ _this10.lockBreakout();
594
+ _context5.next = 8;
595
+ break;
596
+ case 4:
597
+ _context5.next = 6;
598
+ return _this10.enableBreakouts();
599
+ case 6:
600
+ info = _context5.sent;
601
+ if (info.body) {
602
+ _this10.lockBreakout();
603
+ }
604
+ case 8:
605
+ case "end":
606
+ return _context5.stop();
607
+ }
608
+ }, _callee5);
609
+ }))();
610
+ },
611
+ /**
612
+ * send breakout edit lock
613
+ * @returns {void}
614
+ */
615
+ lockBreakout: function lockBreakout() {
616
+ var _this11 = this;
617
+ return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee6() {
618
+ var _breakout$body3, breakout;
619
+ return _regenerator.default.wrap(function _callee6$(_context6) {
620
+ while (1) switch (_context6.prev = _context6.next) {
621
+ case 0:
622
+ if (!(_this11.editLock && !!_this11.editLock.token)) {
623
+ _context6.next = 8;
624
+ break;
625
+ }
626
+ if (!(_this11.editLock.state === _constants.BREAKOUTS.EDIT_LOCK_STATUS.LOCKED)) {
627
+ _context6.next = 5;
628
+ break;
629
+ }
630
+ throw new Error('Breakout already locked');
631
+ case 5:
632
+ _this11.keepEditLockAlive();
633
+ case 6:
634
+ _context6.next = 12;
635
+ break;
636
+ case 8:
637
+ _context6.next = 10;
638
+ return _this11.getBreakout(true);
639
+ case 10:
640
+ breakout = _context6.sent;
641
+ if ((_breakout$body3 = breakout.body) !== null && _breakout$body3 !== void 0 && _breakout$body3.editlock) {
642
+ _this11.keepEditLockAlive();
643
+ }
644
+ case 12:
645
+ case "end":
646
+ return _context6.stop();
647
+ }
648
+ }, _callee6);
649
+ }))();
650
+ },
651
+ /**
652
+ * keep edit lock alive
653
+ * @returns {void}
654
+ */
655
+ keepEditLockAlive: function keepEditLockAlive() {
656
+ var _this12 = this;
657
+ if (this.editLock && !!this.editLock.token) {
658
+ var ttl = this.editLock.ttl < 30 ? _constants.BREAKOUTS.DEFAULT_TTL : this.editLock.ttl;
659
+ this.intervalID = window.setInterval(function () {
660
+ _this12.request({
661
+ method: _constants.HTTP_VERBS.PUT,
662
+ uri: "".concat(_this12.url, "/editlock/").concat(_this12.editLock.token)
663
+ }).catch(function (error) {
664
+ _this12._clearEditLockInfo();
665
+ return _promise.default.reject((0, _utils.boServiceErrorHandler)(error, 'Breakouts#keepEditLockAlive'));
666
+ });
667
+ }, ttl / 2 * 1000);
668
+ }
669
+ },
670
+ /**
671
+ * unlock edit breakout
672
+ * @returns {void}
673
+ */
674
+ unLockEditBreakout: function unLockEditBreakout() {
675
+ var _this13 = this;
676
+ this.request({
677
+ method: _constants.HTTP_VERBS.DELETE,
678
+ uri: "".concat(this.url, "/editlock/").concat(this.editLock.token)
679
+ }).then(function () {
680
+ _this13._clearEditLockInfo();
681
+ }).catch(function (error) {
682
+ return _promise.default.reject((0, _utils.boServiceErrorHandler)(error, 'Breakouts#unLockEditBreakout'));
683
+ });
684
+ },
685
+ /**
686
+ * clear interval and edit lock info
687
+ * @private
688
+ * @returns {void}
689
+ */
690
+ _clearEditLockInfo: function _clearEditLockInfo() {
691
+ if (this.intervalID) {
692
+ clearInterval(this.intervalID);
693
+ }
694
+ this.set('editLock', {});
695
+ },
696
+ /**
697
+ * assign participants to breakout session
698
+ * @param {Array} sessions
699
+ * @returns {void}
700
+ */
701
+ assign: function assign(sessions) {
702
+ var internalSessions = sessions.map(function (item) {
703
+ return {
704
+ id: item.id,
705
+ assigned: item.memberIds,
706
+ assignedEmails: item.emails,
707
+ anyoneCanJoin: !!item.anyone
708
+ };
709
+ });
710
+ return this.request({
711
+ method: _constants.HTTP_VERBS.PUT,
712
+ uri: this.url,
713
+ body: {
714
+ groups: [{
715
+ id: this.breakoutGroupId,
716
+ sessions: internalSessions
717
+ }]
718
+ }
719
+ });
720
+ },
721
+ version: "3.0.0-beta.61"
722
+ });
723
+ var _default = Breakouts;
724
+ exports.default = _default;
725
+ //# sourceMappingURL=index.js.map