@webex/plugin-meetings 3.0.0-beta.3 → 3.0.0-beta.30

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 (493) 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/index.js +374 -0
  8. package/dist/breakouts/index.js.map +1 -0
  9. package/dist/breakouts/request.js +78 -0
  10. package/dist/breakouts/request.js.map +1 -0
  11. package/dist/breakouts/utils.js +23 -0
  12. package/dist/breakouts/utils.js.map +1 -0
  13. package/dist/common/browser-detection.js +1 -20
  14. package/dist/common/browser-detection.js.map +1 -1
  15. package/dist/common/collection.js +5 -20
  16. package/dist/common/collection.js.map +1 -1
  17. package/dist/common/config.js +0 -7
  18. package/dist/common/config.js.map +1 -1
  19. package/dist/common/errors/captcha-error.js +10 -24
  20. package/dist/common/errors/captcha-error.js.map +1 -1
  21. package/dist/common/errors/intent-to-join.js +11 -24
  22. package/dist/common/errors/intent-to-join.js.map +1 -1
  23. package/dist/common/errors/join-meeting.js +12 -25
  24. package/dist/common/errors/join-meeting.js.map +1 -1
  25. package/dist/common/errors/media.js +10 -24
  26. package/dist/common/errors/media.js.map +1 -1
  27. package/dist/common/errors/parameter.js +5 -33
  28. package/dist/common/errors/parameter.js.map +1 -1
  29. package/dist/common/errors/password-error.js +10 -24
  30. package/dist/common/errors/password-error.js.map +1 -1
  31. package/dist/common/errors/permission.js +9 -23
  32. package/dist/common/errors/permission.js.map +1 -1
  33. package/dist/common/errors/reconnection-in-progress.js +0 -17
  34. package/dist/common/errors/reconnection-in-progress.js.map +1 -1
  35. package/dist/common/errors/reconnection.js +10 -24
  36. package/dist/common/errors/reconnection.js.map +1 -1
  37. package/dist/common/errors/stats.js +10 -24
  38. package/dist/common/errors/stats.js.map +1 -1
  39. package/dist/common/errors/webex-errors.js +6 -41
  40. package/dist/common/errors/webex-errors.js.map +1 -1
  41. package/dist/common/errors/webex-meetings-error.js +5 -25
  42. package/dist/common/errors/webex-meetings-error.js.map +1 -1
  43. package/dist/common/events/events-scope.js +0 -22
  44. package/dist/common/events/events-scope.js.map +1 -1
  45. package/dist/common/events/events.js +0 -23
  46. package/dist/common/events/events.js.map +1 -1
  47. package/dist/common/events/trigger-proxy.js +0 -12
  48. package/dist/common/events/trigger-proxy.js.map +1 -1
  49. package/dist/common/events/util.js +0 -15
  50. package/dist/common/events/util.js.map +1 -1
  51. package/dist/common/logs/logger-config.js +0 -4
  52. package/dist/common/logs/logger-config.js.map +1 -1
  53. package/dist/common/logs/logger-proxy.js +1 -8
  54. package/dist/common/logs/logger-proxy.js.map +1 -1
  55. package/dist/common/logs/request.js +37 -60
  56. package/dist/common/logs/request.js.map +1 -1
  57. package/dist/common/queue.js +4 -14
  58. package/dist/common/queue.js.map +1 -1
  59. package/dist/config.js +6 -6
  60. package/dist/config.js.map +1 -1
  61. package/dist/constants.js +92 -49
  62. package/dist/constants.js.map +1 -1
  63. package/dist/controls-options-manager/constants.js +14 -0
  64. package/dist/controls-options-manager/constants.js.map +1 -0
  65. package/dist/controls-options-manager/enums.js +15 -0
  66. package/dist/controls-options-manager/enums.js.map +1 -0
  67. package/dist/controls-options-manager/index.js +203 -0
  68. package/dist/controls-options-manager/index.js.map +1 -0
  69. package/dist/controls-options-manager/util.js +28 -0
  70. package/dist/controls-options-manager/util.js.map +1 -0
  71. package/dist/index.js +4 -18
  72. package/dist/index.js.map +1 -1
  73. package/dist/locus-info/controlsUtils.js +12 -29
  74. package/dist/locus-info/controlsUtils.js.map +1 -1
  75. package/dist/locus-info/embeddedAppsUtils.js +3 -26
  76. package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
  77. package/dist/locus-info/fullState.js +0 -15
  78. package/dist/locus-info/fullState.js.map +1 -1
  79. package/dist/locus-info/hostUtils.js +4 -12
  80. package/dist/locus-info/hostUtils.js.map +1 -1
  81. package/dist/locus-info/index.js +186 -192
  82. package/dist/locus-info/index.js.map +1 -1
  83. package/dist/locus-info/infoUtils.js +3 -37
  84. package/dist/locus-info/infoUtils.js.map +1 -1
  85. package/dist/locus-info/mediaSharesUtils.js +12 -38
  86. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  87. package/dist/locus-info/parser.js +92 -118
  88. package/dist/locus-info/parser.js.map +1 -1
  89. package/dist/locus-info/selfUtils.js +34 -91
  90. package/dist/locus-info/selfUtils.js.map +1 -1
  91. package/dist/media/index.js +64 -137
  92. package/dist/media/index.js.map +1 -1
  93. package/dist/media/properties.js +80 -114
  94. package/dist/media/properties.js.map +1 -1
  95. package/dist/media/util.js +2 -9
  96. package/dist/media/util.js.map +1 -1
  97. package/dist/mediaQualityMetrics/config.js +505 -495
  98. package/dist/mediaQualityMetrics/config.js.map +1 -1
  99. package/dist/meeting/effectsState.js +125 -190
  100. package/dist/meeting/effectsState.js.map +1 -1
  101. package/dist/meeting/in-meeting-actions.js +13 -14
  102. package/dist/meeting/in-meeting-actions.js.map +1 -1
  103. package/dist/meeting/index.js +2142 -2101
  104. package/dist/meeting/index.js.map +1 -1
  105. package/dist/meeting/muteState.js +39 -80
  106. package/dist/meeting/muteState.js.map +1 -1
  107. package/dist/meeting/request.js +224 -230
  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 +43 -215
  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 +490 -560
  130. package/dist/meetings/index.js.map +1 -1
  131. package/dist/meetings/request.js +24 -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 +78 -86
  136. package/dist/member/index.js.map +1 -1
  137. package/dist/member/util.js +31 -68
  138. package/dist/member/util.js.map +1 -1
  139. package/dist/members/collection.js +3 -12
  140. package/dist/members/collection.js.map +1 -1
  141. package/dist/members/index.js +94 -200
  142. package/dist/members/index.js.map +1 -1
  143. package/dist/members/request.js +16 -39
  144. package/dist/members/request.js.map +1 -1
  145. package/dist/members/util.js +9 -38
  146. package/dist/members/util.js.map +1 -1
  147. package/dist/metrics/config.js +0 -2
  148. package/dist/metrics/config.js.map +1 -1
  149. package/dist/metrics/constants.js +1 -2
  150. package/dist/metrics/constants.js.map +1 -1
  151. package/dist/metrics/index.js +55 -135
  152. package/dist/metrics/index.js.map +1 -1
  153. package/dist/multistream/mediaRequestManager.js +57 -33
  154. package/dist/multistream/mediaRequestManager.js.map +1 -1
  155. package/dist/multistream/receiveSlot.js +30 -50
  156. package/dist/multistream/receiveSlot.js.map +1 -1
  157. package/dist/multistream/receiveSlotManager.js +60 -82
  158. package/dist/multistream/receiveSlotManager.js.map +1 -1
  159. package/dist/multistream/remoteMedia.js +18 -58
  160. package/dist/multistream/remoteMedia.js.map +1 -1
  161. package/dist/multistream/remoteMediaGroup.js +6 -40
  162. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  163. package/dist/multistream/remoteMediaManager.js +360 -413
  164. package/dist/multistream/remoteMediaManager.js.map +1 -1
  165. package/dist/networkQualityMonitor/index.js +40 -59
  166. package/dist/networkQualityMonitor/index.js.map +1 -1
  167. package/dist/personal-meeting-room/index.js +21 -45
  168. package/dist/personal-meeting-room/index.js.map +1 -1
  169. package/dist/personal-meeting-room/request.js +1 -31
  170. package/dist/personal-meeting-room/request.js.map +1 -1
  171. package/dist/personal-meeting-room/util.js +0 -13
  172. package/dist/personal-meeting-room/util.js.map +1 -1
  173. package/dist/reachability/index.js +138 -182
  174. package/dist/reachability/index.js.map +1 -1
  175. package/dist/reachability/request.js +3 -18
  176. package/dist/reachability/request.js.map +1 -1
  177. package/dist/reactions/constants.js +13 -0
  178. package/dist/reactions/constants.js.map +1 -0
  179. package/dist/reactions/reactions.js +109 -0
  180. package/dist/reactions/reactions.js.map +1 -0
  181. package/dist/reactions/reactions.type.js +36 -0
  182. package/dist/reactions/reactions.type.js.map +1 -0
  183. package/dist/reconnection-manager/index.js +322 -455
  184. package/dist/reconnection-manager/index.js.map +1 -1
  185. package/dist/recording-controller/enums.js +17 -0
  186. package/dist/recording-controller/enums.js.map +1 -0
  187. package/dist/recording-controller/index.js +343 -0
  188. package/dist/recording-controller/index.js.map +1 -0
  189. package/dist/recording-controller/util.js +63 -0
  190. package/dist/recording-controller/util.js.map +1 -0
  191. package/dist/roap/index.js +39 -64
  192. package/dist/roap/index.js.map +1 -1
  193. package/dist/roap/request.js +94 -113
  194. package/dist/roap/request.js.map +1 -1
  195. package/dist/roap/turnDiscovery.js +85 -94
  196. package/dist/roap/turnDiscovery.js.map +1 -1
  197. package/dist/statsAnalyzer/global.js +1 -95
  198. package/dist/statsAnalyzer/global.js.map +1 -1
  199. package/dist/statsAnalyzer/index.js +357 -449
  200. package/dist/statsAnalyzer/index.js.map +1 -1
  201. package/dist/statsAnalyzer/mqaUtil.js +137 -81
  202. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  203. package/dist/transcription/index.js +22 -47
  204. package/dist/transcription/index.js.map +1 -1
  205. package/dist/types/breakouts/breakout.d.ts +8 -0
  206. package/dist/types/breakouts/collection.d.ts +5 -0
  207. package/dist/types/breakouts/index.d.ts +5 -0
  208. package/dist/types/breakouts/request.d.ts +22 -0
  209. package/dist/types/breakouts/utils.d.ts +1 -0
  210. package/dist/types/common/browser-detection.d.ts +9 -0
  211. package/dist/types/common/collection.d.ts +48 -0
  212. package/dist/types/common/config.d.ts +2 -0
  213. package/dist/types/common/errors/captcha-error.d.ts +15 -0
  214. package/dist/types/common/errors/intent-to-join.d.ts +16 -0
  215. package/dist/types/common/errors/join-meeting.d.ts +17 -0
  216. package/dist/types/common/errors/media.d.ts +15 -0
  217. package/dist/types/common/errors/parameter.d.ts +15 -0
  218. package/dist/types/common/errors/password-error.d.ts +15 -0
  219. package/dist/types/common/errors/permission.d.ts +14 -0
  220. package/dist/types/common/errors/reconnection-in-progress.d.ts +9 -0
  221. package/dist/types/common/errors/reconnection.d.ts +15 -0
  222. package/dist/types/common/errors/stats.d.ts +15 -0
  223. package/dist/types/common/errors/webex-errors.d.ts +69 -0
  224. package/dist/types/common/errors/webex-meetings-error.d.ts +20 -0
  225. package/dist/types/common/events/events-scope.d.ts +17 -0
  226. package/dist/types/common/events/events.d.ts +12 -0
  227. package/dist/types/common/events/trigger-proxy.d.ts +2 -0
  228. package/dist/types/common/events/util.d.ts +2 -0
  229. package/dist/types/common/logs/logger-config.d.ts +2 -0
  230. package/dist/types/common/logs/logger-proxy.d.ts +2 -0
  231. package/dist/types/common/logs/request.d.ts +34 -0
  232. package/dist/types/common/queue.d.ts +32 -0
  233. package/dist/types/config.d.ts +77 -0
  234. package/dist/types/constants.d.ts +899 -0
  235. package/dist/types/controls-options-manager/constants.d.ts +4 -0
  236. package/dist/types/controls-options-manager/enums.d.ts +5 -0
  237. package/dist/types/controls-options-manager/index.d.ts +120 -0
  238. package/dist/types/controls-options-manager/util.d.ts +7 -0
  239. package/dist/types/index.d.ts +5 -0
  240. package/dist/types/locus-info/controlsUtils.d.ts +2 -0
  241. package/dist/types/locus-info/embeddedAppsUtils.d.ts +2 -0
  242. package/dist/types/locus-info/fullState.d.ts +2 -0
  243. package/dist/types/locus-info/hostUtils.d.ts +2 -0
  244. package/dist/types/locus-info/index.d.ts +269 -0
  245. package/dist/types/locus-info/infoUtils.d.ts +2 -0
  246. package/dist/types/locus-info/mediaSharesUtils.d.ts +2 -0
  247. package/dist/types/locus-info/parser.d.ts +212 -0
  248. package/dist/types/locus-info/selfUtils.d.ts +2 -0
  249. package/dist/types/media/index.d.ts +32 -0
  250. package/dist/types/media/properties.d.ts +107 -0
  251. package/dist/types/media/util.d.ts +2 -0
  252. package/dist/types/mediaQualityMetrics/config.d.ts +365 -0
  253. package/dist/types/meeting/effectsState.d.ts +42 -0
  254. package/dist/types/meeting/in-meeting-actions.d.ts +83 -0
  255. package/dist/types/meeting/index.d.ts +1724 -0
  256. package/dist/types/meeting/muteState.d.ts +108 -0
  257. package/dist/types/meeting/request.d.ts +261 -0
  258. package/dist/types/meeting/request.type.d.ts +11 -0
  259. package/dist/types/meeting/state.d.ts +9 -0
  260. package/dist/types/meeting/util.d.ts +2 -0
  261. package/dist/types/meeting-info/collection.d.ts +20 -0
  262. package/dist/types/meeting-info/index.d.ts +57 -0
  263. package/dist/types/meeting-info/meeting-info-v2.d.ts +93 -0
  264. package/dist/types/meeting-info/request.d.ts +22 -0
  265. package/dist/types/meeting-info/util.d.ts +2 -0
  266. package/dist/types/meeting-info/utilv2.d.ts +2 -0
  267. package/dist/types/meetings/collection.d.ts +23 -0
  268. package/dist/types/meetings/index.d.ts +297 -0
  269. package/dist/types/meetings/request.d.ts +27 -0
  270. package/dist/types/meetings/util.d.ts +18 -0
  271. package/dist/types/member/index.d.ts +146 -0
  272. package/dist/types/member/util.d.ts +2 -0
  273. package/dist/types/members/collection.d.ts +24 -0
  274. package/dist/types/members/index.d.ts +320 -0
  275. package/dist/types/members/request.d.ts +50 -0
  276. package/dist/types/members/util.d.ts +2 -0
  277. package/dist/types/metrics/config.d.ts +178 -0
  278. package/dist/types/metrics/constants.d.ts +57 -0
  279. package/dist/types/metrics/index.d.ts +160 -0
  280. package/dist/types/multistream/mediaRequestManager.d.ts +50 -0
  281. package/dist/types/multistream/receiveSlot.d.ts +66 -0
  282. package/dist/types/multistream/receiveSlotManager.d.ts +46 -0
  283. package/dist/types/multistream/remoteMedia.d.ts +93 -0
  284. package/dist/types/multistream/remoteMediaGroup.d.ts +56 -0
  285. package/dist/types/multistream/remoteMediaManager.d.ts +241 -0
  286. package/dist/types/networkQualityMonitor/index.d.ts +70 -0
  287. package/dist/types/personal-meeting-room/index.d.ts +47 -0
  288. package/dist/types/personal-meeting-room/request.d.ts +14 -0
  289. package/dist/types/personal-meeting-room/util.d.ts +2 -0
  290. package/dist/types/reachability/index.d.ts +140 -0
  291. package/dist/types/reachability/request.d.ts +35 -0
  292. package/dist/types/reactions/constants.d.ts +3 -0
  293. package/dist/types/reactions/reactions.d.ts +4 -0
  294. package/dist/types/reactions/reactions.type.d.ts +52 -0
  295. package/dist/types/reconnection-manager/index.d.ts +117 -0
  296. package/dist/types/recording-controller/enums.d.ts +7 -0
  297. package/dist/types/recording-controller/index.d.ts +193 -0
  298. package/dist/types/recording-controller/util.d.ts +13 -0
  299. package/dist/types/roap/index.d.ts +77 -0
  300. package/dist/types/roap/request.d.ts +35 -0
  301. package/dist/types/roap/turnDiscovery.d.ts +74 -0
  302. package/dist/types/statsAnalyzer/global.d.ts +36 -0
  303. package/dist/types/statsAnalyzer/index.d.ts +195 -0
  304. package/dist/types/statsAnalyzer/mqaUtil.d.ts +24 -0
  305. package/dist/types/transcription/index.d.ts +64 -0
  306. package/internal-README.md +7 -6
  307. package/package.json +25 -20
  308. package/src/breakouts/README.md +190 -0
  309. package/src/breakouts/breakout.ts +130 -0
  310. package/src/breakouts/collection.ts +19 -0
  311. package/src/breakouts/index.ts +353 -0
  312. package/src/breakouts/request.ts +55 -0
  313. package/src/breakouts/utils.ts +15 -0
  314. package/src/common/{browser-detection.js → browser-detection.ts} +9 -6
  315. package/src/common/collection.ts +9 -7
  316. package/src/common/{config.js → config.ts} +1 -1
  317. package/src/common/errors/{captcha-error.js → captcha-error.ts} +11 -7
  318. package/src/common/errors/{intent-to-join.js → intent-to-join.ts} +12 -7
  319. package/src/common/errors/{join-meeting.js → join-meeting.ts} +17 -8
  320. package/src/common/errors/{media.js → media.ts} +11 -7
  321. package/src/common/errors/parameter.ts +11 -7
  322. package/src/common/errors/{password-error.js → password-error.ts} +11 -7
  323. package/src/common/errors/{permission.js → permission.ts} +10 -6
  324. package/src/common/errors/{reconnection.js → reconnection.ts} +11 -7
  325. package/src/common/errors/{stats.js → stats.ts} +11 -7
  326. package/src/common/errors/{webex-errors.js → webex-errors.ts} +8 -7
  327. package/src/common/errors/{webex-meetings-error.js → webex-meetings-error.ts} +4 -2
  328. package/src/common/events/{events-scope.js → events-scope.ts} +6 -2
  329. package/src/common/events/{events.js → events.ts} +5 -1
  330. package/src/common/events/{trigger-proxy.js → trigger-proxy.ts} +9 -5
  331. package/src/common/events/{util.js → util.ts} +2 -3
  332. package/src/common/logs/{logger-config.js → logger-config.ts} +1 -2
  333. package/src/common/logs/logger-proxy.ts +44 -0
  334. package/src/common/logs/{request.js → request.ts} +22 -9
  335. package/src/common/queue.ts +1 -2
  336. package/src/{config.js → config.ts} +17 -12
  337. package/src/constants.ts +44 -4
  338. package/src/controls-options-manager/constants.ts +5 -0
  339. package/src/controls-options-manager/enums.ts +6 -0
  340. package/src/controls-options-manager/index.ts +183 -0
  341. package/src/controls-options-manager/util.ts +20 -0
  342. package/src/index.js +2 -1
  343. package/src/locus-info/controlsUtils.ts +114 -0
  344. package/src/locus-info/{embeddedAppsUtils.js → embeddedAppsUtils.ts} +5 -6
  345. package/src/locus-info/{fullState.js → fullState.ts} +16 -12
  346. package/src/locus-info/{hostUtils.js → hostUtils.ts} +9 -8
  347. package/src/locus-info/{index.js → index.ts} +150 -66
  348. package/src/locus-info/{infoUtils.js → infoUtils.ts} +19 -8
  349. package/src/locus-info/{mediaSharesUtils.js → mediaSharesUtils.ts} +17 -17
  350. package/src/locus-info/{parser.js → parser.ts} +67 -79
  351. package/src/locus-info/{selfUtils.js → selfUtils.ts} +123 -68
  352. package/src/media/{index.js → index.ts} +176 -157
  353. package/src/media/{properties.js → properties.ts} +48 -31
  354. package/src/media/{util.js → util.ts} +2 -2
  355. package/src/mediaQualityMetrics/config.ts +384 -0
  356. package/src/meeting/{effectsState.js → effectsState.ts} +47 -41
  357. package/src/meeting/in-meeting-actions.ts +31 -3
  358. package/src/meeting/{index.js → index.ts} +2479 -1466
  359. package/src/meeting/{muteState.js → muteState.ts} +80 -45
  360. package/src/meeting/{request.js → request.ts} +292 -142
  361. package/src/meeting/request.type.ts +13 -0
  362. package/src/meeting/{state.js → state.ts} +50 -35
  363. package/src/meeting/{util.js → util.ts} +112 -115
  364. package/src/meeting-info/{collection.js → collection.ts} +6 -2
  365. package/src/meeting-info/{index.js → index.ts} +42 -36
  366. package/src/meeting-info/meeting-info-v2.ts +273 -0
  367. package/src/meeting-info/{request.js → request.ts} +14 -4
  368. package/src/meeting-info/{util.js → util.ts} +60 -51
  369. package/src/meeting-info/{utilv2.js → utilv2.ts} +65 -58
  370. package/src/meetings/{collection.js → collection.ts} +6 -3
  371. package/src/meetings/index.ts +1159 -0
  372. package/src/meetings/{request.js → request.ts} +32 -25
  373. package/src/meetings/{util.js → util.ts} +58 -32
  374. package/src/member/{index.js → index.ts} +102 -56
  375. package/src/member/{util.js → util.ts} +52 -25
  376. package/src/members/{collection.js → collection.ts} +2 -2
  377. package/src/members/{index.js → index.ts} +221 -142
  378. package/src/members/{request.js → request.ts} +60 -16
  379. package/src/members/{util.js → util.ts} +50 -48
  380. package/src/metrics/{config.js → config.ts} +254 -83
  381. package/src/metrics/{constants.js → constants.ts} +0 -2
  382. package/src/metrics/{index.js → index.ts} +106 -74
  383. package/src/multistream/mediaRequestManager.ts +79 -15
  384. package/src/multistream/receiveSlot.ts +42 -13
  385. package/src/multistream/receiveSlotManager.ts +35 -21
  386. package/src/multistream/remoteMedia.ts +15 -5
  387. package/src/multistream/remoteMediaGroup.ts +4 -3
  388. package/src/multistream/remoteMediaManager.ts +152 -36
  389. package/src/networkQualityMonitor/{index.js → index.ts} +41 -29
  390. package/src/personal-meeting-room/{index.js → index.ts} +28 -19
  391. package/src/personal-meeting-room/{request.js → request.ts} +13 -4
  392. package/src/personal-meeting-room/{util.js → util.ts} +4 -4
  393. package/src/reachability/{index.js → index.ts} +99 -83
  394. package/src/reachability/request.ts +39 -33
  395. package/src/reactions/constants.ts +4 -0
  396. package/src/reactions/reactions.ts +104 -0
  397. package/src/reactions/reactions.type.ts +62 -0
  398. package/src/reconnection-manager/{index.js → index.ts} +195 -102
  399. package/src/recording-controller/enums.ts +8 -0
  400. package/src/recording-controller/index.ts +315 -0
  401. package/src/recording-controller/util.ts +58 -0
  402. package/src/roap/{index.js → index.ts} +73 -56
  403. package/src/roap/request.ts +157 -0
  404. package/src/roap/turnDiscovery.ts +77 -37
  405. package/src/statsAnalyzer/global.ts +37 -0
  406. package/src/statsAnalyzer/index.ts +1234 -0
  407. package/src/statsAnalyzer/mqaUtil.ts +293 -0
  408. package/src/transcription/{index.js → index.ts} +46 -39
  409. package/test/integration/spec/converged-space-meetings.js +176 -0
  410. package/test/integration/spec/journey.js +664 -463
  411. package/test/integration/spec/space-meeting.js +320 -206
  412. package/test/integration/spec/transcription.js +7 -8
  413. package/test/unit/spec/breakouts/breakout.ts +147 -0
  414. package/test/unit/spec/breakouts/collection.ts +15 -0
  415. package/test/unit/spec/breakouts/index.ts +464 -0
  416. package/test/unit/spec/breakouts/request.ts +104 -0
  417. package/test/unit/spec/breakouts/utils.js +21 -0
  418. package/test/unit/spec/common/browser-detection.js +9 -28
  419. package/test/unit/spec/controls-options-manager/index.js +124 -0
  420. package/test/unit/spec/controls-options-manager/util.js +66 -0
  421. package/test/unit/spec/fixture/locus.js +92 -90
  422. package/test/unit/spec/locus-info/controlsUtils.js +25 -5
  423. package/test/unit/spec/locus-info/embeddedAppsUtils.js +8 -6
  424. package/test/unit/spec/locus-info/index.js +104 -2
  425. package/test/unit/spec/locus-info/infoUtils.js +41 -32
  426. package/test/unit/spec/locus-info/lib/BasicSeqCmp.json +88 -430
  427. package/test/unit/spec/locus-info/lib/SeqCmp.json +513 -685
  428. package/test/unit/spec/locus-info/parser.js +3 -9
  429. package/test/unit/spec/locus-info/selfConstant.js +97 -103
  430. package/test/unit/spec/locus-info/selfUtils.js +105 -12
  431. package/test/unit/spec/media/index.ts +31 -47
  432. package/test/unit/spec/media/properties.ts +9 -9
  433. package/test/unit/spec/meeting/effectsState.js +39 -45
  434. package/test/unit/spec/meeting/in-meeting-actions.ts +13 -2
  435. package/test/unit/spec/meeting/index.js +2214 -746
  436. package/test/unit/spec/meeting/muteState.js +43 -34
  437. package/test/unit/spec/meeting/request.js +115 -44
  438. package/test/unit/spec/meeting/utils.js +104 -171
  439. package/test/unit/spec/meeting-info/meetinginfov2.js +100 -73
  440. package/test/unit/spec/meeting-info/request.js +7 -9
  441. package/test/unit/spec/meeting-info/util.js +11 -12
  442. package/test/unit/spec/meeting-info/utilv2.js +110 -74
  443. package/test/unit/spec/meetings/collection.js +1 -1
  444. package/test/unit/spec/meetings/index.js +439 -257
  445. package/test/unit/spec/meetings/utils.js +14 -12
  446. package/test/unit/spec/member/index.js +0 -1
  447. package/test/unit/spec/member/util.js +31 -7
  448. package/test/unit/spec/members/index.js +104 -54
  449. package/test/unit/spec/members/request.js +29 -20
  450. package/test/unit/spec/members/utils.js +8 -5
  451. package/test/unit/spec/metrics/index.js +16 -21
  452. package/test/unit/spec/multistream/mediaRequestManager.ts +312 -50
  453. package/test/unit/spec/multistream/receiveSlot.ts +57 -6
  454. package/test/unit/spec/multistream/receiveSlotManager.ts +41 -13
  455. package/test/unit/spec/multistream/remoteMedia.ts +10 -2
  456. package/test/unit/spec/multistream/remoteMediaGroup.ts +5 -5
  457. package/test/unit/spec/multistream/remoteMediaManager.ts +412 -65
  458. package/test/unit/spec/networkQualityMonitor/index.js +24 -18
  459. package/test/unit/spec/personal-meeting-room/personal-meeting-room.js +2 -7
  460. package/test/unit/spec/reachability/index.ts +58 -26
  461. package/test/unit/spec/reconnection-manager/index.js +102 -9
  462. package/test/unit/spec/recording-controller/index.js +231 -0
  463. package/test/unit/spec/recording-controller/util.js +102 -0
  464. package/test/unit/spec/roap/index.ts +2 -1
  465. package/test/unit/spec/roap/request.ts +114 -0
  466. package/test/unit/spec/roap/turnDiscovery.ts +64 -45
  467. package/test/unit/spec/stats-analyzer/index.js +86 -57
  468. package/test/utils/cmr.js +44 -42
  469. package/test/utils/constants.js +9 -0
  470. package/test/utils/testUtils.js +96 -80
  471. package/test/utils/webex-config.js +22 -18
  472. package/test/utils/webex-test-users.js +57 -50
  473. package/tsconfig.json +6 -0
  474. package/dist/media/internal-media-core-wrapper.js +0 -22
  475. package/dist/media/internal-media-core-wrapper.js.map +0 -1
  476. package/dist/multistream/multistreamMedia.js +0 -116
  477. package/dist/multistream/multistreamMedia.js.map +0 -1
  478. package/dist/peer-connection-manager/util.js +0 -124
  479. package/dist/peer-connection-manager/util.js.map +0 -1
  480. package/src/common/logs/logger-proxy.js +0 -33
  481. package/src/locus-info/controlsUtils.js +0 -102
  482. package/src/media/internal-media-core-wrapper.ts +0 -9
  483. package/src/mediaQualityMetrics/config.js +0 -382
  484. package/src/meeting-info/meeting-info-v2.js +0 -255
  485. package/src/meetings/index.js +0 -1015
  486. package/src/multistream/multistreamMedia.ts +0 -92
  487. package/src/peer-connection-manager/util.ts +0 -117
  488. package/src/roap/request.js +0 -127
  489. package/src/statsAnalyzer/global.js +0 -133
  490. package/src/statsAnalyzer/index.js +0 -1006
  491. package/src/statsAnalyzer/mqaUtil.js +0 -173
  492. package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -389
  493. /package/src/common/errors/{reconnection-in-progress.js → reconnection-in-progress.ts} +0 -0
@@ -0,0 +1,130 @@
1
+ /*!
2
+ * Copyright (c) 2015-2023 Cisco Systems, Inc. See LICENSE file.
3
+ */
4
+
5
+ import {WebexPlugin} from '@webex/webex-core';
6
+
7
+ import {HTTP_VERBS, MEETINGS} from '../constants';
8
+ import LocusInfo from '../locus-info';
9
+ import Members from '../members';
10
+ import BreakoutRequest from './request';
11
+
12
+ /**
13
+ * @class
14
+ */
15
+ const Breakout = WebexPlugin.extend({
16
+ idAttribute: 'sessionId',
17
+
18
+ namespace: MEETINGS,
19
+
20
+ breakoutRequest: BreakoutRequest,
21
+ props: {
22
+ active: ['boolean', false, false], // this session is active
23
+ allowed: ['boolean', false, false], // allowed to join this session
24
+ assigned: ['boolean', false, false], // assigned to this session, but not necessarily joined yet
25
+ assignedCurrent: ['boolean', false, false], // assigned AND current session
26
+ requested: ['boolean', false, false], // requested by the host to join this session
27
+ current: ['boolean', false, false], // the current joined session
28
+ name: 'string',
29
+ sessionId: 'string',
30
+ sessionType: 'string',
31
+ groupId: 'string',
32
+ url: 'string', // where to send requests to
33
+ },
34
+
35
+ derived: {
36
+ isMain: {
37
+ deps: ['sessionType'],
38
+ /**
39
+ * If the breakout has no name, assume it is the main session
40
+ * @returns {boolean}
41
+ */
42
+ fn() {
43
+ return this.sessionType === 'MAIN';
44
+ },
45
+ },
46
+ },
47
+
48
+ initialize() {
49
+ this.members = new Members({}, {parent: this.webex});
50
+ // @ts-ignore
51
+ this.breakoutRequest = new BreakoutRequest({webex: this.webex});
52
+ },
53
+
54
+ /**
55
+ * Joins the breakout session
56
+ * @returns {Promise}
57
+ */
58
+ join() {
59
+ return this.request({
60
+ method: HTTP_VERBS.POST,
61
+ uri: `${this.url}/move`,
62
+ body: {
63
+ groupId: this.groupId,
64
+ sessionId: this.sessionId,
65
+ },
66
+ });
67
+ },
68
+
69
+ /**
70
+ * Leaves the breakout session to return to the main session
71
+ * @returns {Promise}
72
+ * @throws {Error} if an attempt is made to leave the main session or if the main session cannot be found
73
+ */
74
+ leave() {
75
+ if (this.isMain) {
76
+ throw new Error('Cannot leave the main session');
77
+ }
78
+
79
+ const mainSession = this.parent.breakouts.filter((breakout) => breakout.isMain)[0];
80
+
81
+ if (!mainSession) {
82
+ throw new Error('Cannot leave, no main session found');
83
+ }
84
+
85
+ return mainSession.join();
86
+ },
87
+
88
+ /**
89
+ * Sends a help request for the current breakout
90
+ * @returns {Promise}
91
+ */
92
+ askForHelp() {
93
+ return this.request({
94
+ method: HTTP_VERBS.POST,
95
+ uri: `${this.url}/help`,
96
+ body: {
97
+ groupId: this.groupId,
98
+ sessionId: this.sessionId,
99
+ },
100
+ });
101
+ },
102
+
103
+ /**
104
+ * Parses the participants from the locus object
105
+ * @param locus Locus object
106
+ * @returns {void}
107
+ */
108
+
109
+ parseRoster(locus) {
110
+ this.members.locusParticipantsUpdate(locus);
111
+ },
112
+
113
+ /**
114
+ * Broadcast message to this breakout session's participants
115
+ * @param {String} message
116
+ * @param {Object} options
117
+ * @returns {Promise}
118
+ */
119
+ broadcast(message, options) {
120
+ return this.breakoutRequest.broadcast({
121
+ url: this.url,
122
+ message,
123
+ options,
124
+ groupId: this.groupId,
125
+ sessionId: this.sessionId,
126
+ });
127
+ },
128
+ });
129
+
130
+ export default Breakout;
@@ -0,0 +1,19 @@
1
+ /*!
2
+ * Copyright (c) 2015-2023 Cisco Systems, Inc. See LICENSE file.
3
+ */
4
+
5
+ import AmpCollection from 'ampersand-collection';
6
+
7
+ import {MEETINGS} from '../constants';
8
+
9
+ import Breakout from './breakout';
10
+
11
+ const BreakoutCollection = AmpCollection.extend({
12
+ model: Breakout,
13
+
14
+ namespace: MEETINGS,
15
+
16
+ mainIndex: 'sessionId',
17
+ });
18
+
19
+ export default BreakoutCollection;
@@ -0,0 +1,353 @@
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, HTTP_VERBS, MEETINGS} from '../constants';
9
+
10
+ import Breakout from './breakout';
11
+ import BreakoutCollection from './collection';
12
+ import BreakoutRequest from './request';
13
+
14
+ /**
15
+ * @class Breakouts
16
+ */
17
+ const Breakouts = WebexPlugin.extend({
18
+ namespace: MEETINGS,
19
+ breakoutRequest: BreakoutRequest,
20
+ collections: {
21
+ breakouts: BreakoutCollection,
22
+ },
23
+
24
+ props: {
25
+ allowBackToMain: 'boolean', // only present when in a breakout session
26
+ delayCloseTime: 'number', // appears once breakouts start
27
+ enableBreakoutSession: 'boolean', // appears from the moment you enable breakouts
28
+ groupId: 'string', // appears from the moment you enable breakouts
29
+ name: 'string', // only present when in a breakout session
30
+ sessionId: 'string', // appears from the moment you enable breakouts
31
+ sessionType: 'string', // appears from the moment you enable breakouts
32
+ startTime: 'string', // appears once breakouts start
33
+ status: 'string', // only present when in a breakout session
34
+ url: 'string', // appears from the moment you enable breakouts
35
+ locusUrl: 'string', // the current locus url
36
+ breakoutServiceUrl: 'string', // the current breakout resouce url
37
+ },
38
+
39
+ children: {
40
+ currentBreakoutSession: Breakout,
41
+ },
42
+
43
+ derived: {
44
+ isInMainSession: {
45
+ deps: ['sessionType'],
46
+ /**
47
+ * Returns true if the user is in the main session
48
+ * @returns {boolean}
49
+ */
50
+ fn() {
51
+ return this.sessionType === BREAKOUTS.SESSION_TYPES.MAIN;
52
+ },
53
+ },
54
+ },
55
+
56
+ /**
57
+ * initialize for the breakouts
58
+ * @returns {void}
59
+ */
60
+ initialize() {
61
+ this.listenTo(this, 'change:status', () => {
62
+ if (this.status === BREAKOUTS.STATUS.CLOSING) {
63
+ this.trigger(BREAKOUTS.EVENTS.BREAKOUTS_CLOSING);
64
+ }
65
+ });
66
+ this.debouncedQueryRosters = debounce(this.queryRosters, 10, {
67
+ leading: true,
68
+ trailing: false,
69
+ });
70
+ this.listenTo(this.breakouts, 'add', () => {
71
+ this.debouncedQueryRosters();
72
+ });
73
+ this.listenToBroadcastMessages();
74
+ this.listenToBreakoutRosters();
75
+ // @ts-ignore
76
+ this.breakoutRequest = new BreakoutRequest({webex: this.webex});
77
+ },
78
+
79
+ /**
80
+ * Calls this to clean up listeners
81
+ * @returns {void}
82
+ */
83
+ cleanUp() {
84
+ this.stopListening();
85
+ },
86
+
87
+ /**
88
+ * Update the current locus url of the meeting
89
+ * @param {string} locusUrl // locus url
90
+ * @returns {void}
91
+ */
92
+ locusUrlUpdate(locusUrl) {
93
+ this.set('locusUrl', locusUrl);
94
+ },
95
+
96
+ /**
97
+ * Update the current breakout resouce url
98
+ * @param {string} breakoutServiceUrl
99
+ * @returns {void}
100
+ */
101
+ breakoutServiceUrlUpdate(breakoutServiceUrl) {
102
+ this.set('breakoutServiceUrl', `${breakoutServiceUrl}/breakout/`);
103
+ },
104
+
105
+ /**
106
+ * The initial roster lists need to be queried because you don't
107
+ * get a breakout.roster event when you join the meeting
108
+ * @returns {void}
109
+ */
110
+ queryRosters() {
111
+ this.webex
112
+ .request({uri: `${this.url}/roster`, qs: {locusUrl: btoa(this.locusUrl)}})
113
+ .then((result) => {
114
+ const {
115
+ body: {rosters},
116
+ } = result;
117
+
118
+ rosters.forEach(({locus}) => {
119
+ this.handleRosterUpdate(locus);
120
+ });
121
+
122
+ this.trigger(BREAKOUTS.EVENTS.MEMBERS_UPDATE);
123
+ })
124
+ .catch((error) => {
125
+ LoggerProxy.logger.error('Meeting:breakouts#queryRosters failed', error);
126
+ });
127
+ },
128
+
129
+ /**
130
+ *
131
+ * @param {Object} locus // locus object
132
+ * @returns {void}
133
+ */
134
+ handleRosterUpdate(locus) {
135
+ const sessionId = locus.controls?.breakout?.sessionId;
136
+
137
+ const session = this.breakouts.get(sessionId);
138
+
139
+ if (!session) {
140
+ return;
141
+ }
142
+
143
+ session.parseRoster(locus);
144
+ },
145
+
146
+ /**
147
+ * Sets up listener for broadcast messages sent to the breakout session
148
+ * @returns {void}
149
+ */
150
+ listenToBroadcastMessages() {
151
+ this.listenTo(this.webex.internal.llm, 'event:breakout.message', (event) => {
152
+ const {
153
+ data: {senderUserId, sentTime, message},
154
+ } = event;
155
+
156
+ this.trigger(BREAKOUTS.EVENTS.MESSAGE, {
157
+ senderUserId,
158
+ sentTime,
159
+ message,
160
+ // FIXME: This is only the current sessionId
161
+ // We'd need to check that the dataChannelUrl is still the same
162
+ // to guarantee that this message was sent to this session
163
+ sessionId: this.currentBreakoutSession.sessionId,
164
+ });
165
+ });
166
+ },
167
+
168
+ /**
169
+ * Sets up a listener for roster messags from mecury
170
+ * @returns {void}
171
+ */
172
+ listenToBreakoutRosters() {
173
+ this.listenTo(this.webex.internal.mercury, 'event:breakout.roster', (event) => {
174
+ this.handleRosterUpdate(event.data.locus);
175
+ this.trigger(BREAKOUTS.EVENTS.MEMBERS_UPDATE);
176
+ });
177
+ },
178
+
179
+ /**
180
+ * Updates the information about the current breakout
181
+ * @param {Object} params
182
+ * @returns {void}
183
+ */
184
+ updateBreakout(params) {
185
+ this.set(params);
186
+
187
+ this.set('currentBreakoutSession', {
188
+ sessionId: params.sessionId,
189
+ groupId: params.groupId,
190
+ name: params.name,
191
+ current: true,
192
+ sessionType: params.sessionType,
193
+ url: params.url,
194
+ [BREAKOUTS.SESSION_STATES.ACTIVE]: false,
195
+ [BREAKOUTS.SESSION_STATES.ALLOWED]: false,
196
+ [BREAKOUTS.SESSION_STATES.ALLOWED]: false,
197
+ [BREAKOUTS.SESSION_STATES.ASSIGNED_CURRENT]: false,
198
+ [BREAKOUTS.SESSION_STATES.REQUESTED]: false,
199
+ });
200
+
201
+ this.set('enableBreakoutSession', params.enableBreakoutSession);
202
+ },
203
+
204
+ /**
205
+ * Updates the information about available breakouts
206
+ * @param {Object} payload
207
+ * @returns {void}
208
+ */
209
+ updateBreakoutSessions(payload) {
210
+ const breakouts = {};
211
+
212
+ if (payload.breakoutSessions) {
213
+ forEach(BREAKOUTS.SESSION_STATES, (state) => {
214
+ forEach(payload.breakoutSessions[state], (breakout) => {
215
+ const {sessionId} = breakout;
216
+
217
+ if (!breakouts[sessionId]) {
218
+ breakouts[sessionId] = breakout;
219
+ breakouts[sessionId][BREAKOUTS.SESSION_STATES.ACTIVE] = false;
220
+ breakouts[sessionId][BREAKOUTS.SESSION_STATES.ASSIGNED] = false;
221
+ breakouts[sessionId][BREAKOUTS.SESSION_STATES.ALLOWED] = false;
222
+ breakouts[sessionId][BREAKOUTS.SESSION_STATES.ASSIGNED_CURRENT] = false;
223
+ breakouts[sessionId][BREAKOUTS.SESSION_STATES.REQUESTED] = false;
224
+ }
225
+
226
+ breakouts[sessionId][state] = true;
227
+ });
228
+ });
229
+ }
230
+
231
+ forEach(breakouts, (breakout: typeof Breakout) => {
232
+ // eslint-disable-next-line no-param-reassign
233
+ breakout.url = this.url;
234
+ });
235
+
236
+ this.breakouts.set(Object.values(breakouts));
237
+ },
238
+ /**
239
+ * get main session
240
+ * @returns {Breakout}
241
+ */
242
+ getMainSession() {
243
+ if (this.isInMainSession) {
244
+ return this.currentBreakoutSession;
245
+ }
246
+
247
+ const mainSession = this.breakouts.filter((breakout) => breakout.isMain)[0];
248
+ if (!mainSession) {
249
+ throw new Error('no main session found');
250
+ }
251
+
252
+ return mainSession;
253
+ },
254
+ /**
255
+ * Host/CoHost ask all participants return to main session
256
+ * @returns {Promise}
257
+ */
258
+ askAllToReturn() {
259
+ const mainSession = this.getMainSession();
260
+
261
+ return this.webex.request({
262
+ method: HTTP_VERBS.POST,
263
+ uri: `${this.url}/requestMove`,
264
+ body: {
265
+ groupId: mainSession.groupId,
266
+ sessionId: mainSession.sessionId,
267
+ },
268
+ });
269
+ },
270
+
271
+ /**
272
+ * Broadcast message to all breakout session's participants
273
+ * @param {String} message
274
+ * @param {Object} options
275
+ * @returns {Promise}
276
+ */
277
+ broadcast(message, options) {
278
+ const breakoutGroupId = this.isInMainSession
279
+ ? this.breakouts.filter((breakout) => !breakout.isMain)[0]?.groupId
280
+ : this.groupId;
281
+ if (!breakoutGroupId) {
282
+ throw new Error('Cannot broadcast, no breakout session found');
283
+ }
284
+
285
+ return this.breakoutRequest.broadcast({
286
+ url: this.url,
287
+ message,
288
+ options,
289
+ groupId: breakoutGroupId,
290
+ });
291
+ },
292
+ /**
293
+ * Make enable breakout resource
294
+ * @returns {Promise}
295
+ */
296
+ enableBreakouts() {
297
+ if (this.breakoutServiceUrl) {
298
+ // @ts-ignore
299
+ return this.webex
300
+ .request({
301
+ method: HTTP_VERBS.POST,
302
+ uri: this.breakoutServiceUrl,
303
+ body: {
304
+ locusUrl: this.locusUrl,
305
+ },
306
+ })
307
+ .catch((err) => {
308
+ LoggerProxy.logger.error(
309
+ `Meeting:request#touchBreakout --> Error provisioning error ${err}`
310
+ );
311
+ throw err;
312
+ });
313
+ }
314
+
315
+ return Promise.reject(new Error(`enableBreakouts: the breakoutServiceUrl is empty`));
316
+ },
317
+
318
+ /**
319
+ * Make the meeting enbale or disable breakout session
320
+ * @param {boolean} enable
321
+ * @returns {Promise}
322
+ */
323
+ async toggleBreakout(enable) {
324
+ if (this.enableBreakoutSession === undefined) {
325
+ const info = await this.enableBreakouts();
326
+ if (!enable) {
327
+ // if enable is false, updateBreakout set the param then set enableBreakoutSession as false
328
+ this.updateBreakout(info.body);
329
+ await this.doToggleBreakout(enable);
330
+ }
331
+ } else {
332
+ await this.doToggleBreakout(enable);
333
+ }
334
+ },
335
+
336
+ /**
337
+ * do toggle meeting breakout session enable or disable
338
+ * @param {boolean} enable
339
+ * @returns {Promise}
340
+ */
341
+ doToggleBreakout(enable) {
342
+ // @ts-ignore
343
+ return this.webex.request({
344
+ method: HTTP_VERBS.PUT,
345
+ uri: this.url,
346
+ body: {
347
+ enableBreakoutSession: enable,
348
+ },
349
+ });
350
+ },
351
+ });
352
+
353
+ export default Breakouts;
@@ -0,0 +1,55 @@
1
+ import {StatelessWebexPlugin} from '@webex/webex-core';
2
+ import LoggerProxy from '../common/logs/logger-proxy';
3
+ import {getBroadcastRoles} from './utils';
4
+ import {HTTP_VERBS} from '../constants';
5
+
6
+ /**
7
+ * @class BreakoutRequest
8
+ */
9
+ export default class BreakoutRequest extends StatelessWebexPlugin {
10
+ /**
11
+ * Broadcast message to all breakout session's participants
12
+ * @param {String} url
13
+ * @param {String} message
14
+ * @param {Object} options
15
+ * @param {string} groupId
16
+ * @param {string} sessionId
17
+ * @returns {Promise}
18
+ */
19
+ broadcast({
20
+ url,
21
+ message,
22
+ options,
23
+ groupId,
24
+ sessionId,
25
+ }: {
26
+ url: string;
27
+ message: string;
28
+ options?: object;
29
+ groupId: string;
30
+ sessionId?: string;
31
+ }) {
32
+ const roles = getBroadcastRoles(options);
33
+ const params = {
34
+ id: groupId,
35
+ recipientRoles: roles.length ? roles : undefined,
36
+ sessions: sessionId ? [{id: sessionId}] : undefined,
37
+ };
38
+
39
+ // @ts-ignore
40
+ return this.request({
41
+ method: HTTP_VERBS.POST,
42
+ uri: `${url}/message`,
43
+ body: {
44
+ message,
45
+ groups: [params],
46
+ },
47
+ }).catch((error) => {
48
+ if (error.body && error.body.errorCode === 201409036 && error.statusCode === 409) {
49
+ LoggerProxy.logger.info(`Breakouts#broadcast --> no joined participants`);
50
+ } else {
51
+ throw error;
52
+ }
53
+ });
54
+ }
55
+ }
@@ -0,0 +1,15 @@
1
+ // eslint-disable-next-line import/prefer-default-export
2
+ export const getBroadcastRoles = (options): string[] => {
3
+ const recipientRoles = [];
4
+ if (!options || (!options.cohosts && !options.presenters)) {
5
+ return recipientRoles;
6
+ }
7
+ if (options.cohosts) {
8
+ recipientRoles.push('COHOST');
9
+ }
10
+ if (options.presenters) {
11
+ recipientRoles.push('PRESENTER');
12
+ }
13
+
14
+ return recipientRoles;
15
+ };
@@ -1,3 +1,5 @@
1
+ /* eslint-disable @typescript-eslint/no-var-requires */
2
+
1
3
  import bowser from 'bowser';
2
4
  import {memoize} from 'lodash';
3
5
  import window from 'global/window';
@@ -9,7 +11,7 @@ const mockDetectionObject = {
9
11
  /* eslint-enable global-require */
10
12
  getBrowserName: () => '',
11
13
  getBrowserVersion: () => '',
12
- isBrowser: () => false
14
+ isBrowser: () => false,
13
15
  };
14
16
 
15
17
  const createDetectionObject = (results) => {
@@ -26,11 +28,12 @@ const createDetectionObject = (results) => {
26
28
  getOSVersion,
27
29
  getBrowserName,
28
30
  getBrowserVersion,
29
- isBrowser
31
+ isBrowser,
30
32
  };
31
33
  };
32
34
 
33
- export default memoize((agent) => (agent || window.navigator?.userAgent ?
34
- createDetectionObject(bowser.getParser(agent || window.navigator.userAgent)) :
35
- mockDetectionObject
36
- ));
35
+ export default memoize((agent?: any) =>
36
+ agent || window.navigator?.userAgent
37
+ ? createDetectionObject(bowser.getParser(agent || window.navigator.userAgent))
38
+ : mockDetectionObject
39
+ );
@@ -13,7 +13,7 @@ export default class Collection {
13
13
  * @param {String} property
14
14
  * @memberof Collection
15
15
  */
16
- constructor(property) {
16
+ constructor(property: string) {
17
17
  if (!property || !isString(property)) {
18
18
  throw new ParameterError('Collection expects a string to use as a property name.');
19
19
  }
@@ -41,8 +41,10 @@ export default class Collection {
41
41
  * @public
42
42
  * @memberof Collection
43
43
  */
44
- get(id) {
45
- return this[this.propertyName] && this[this.propertyName][id] ? this[this.propertyName][id] : null;
44
+ public get(id: string) {
45
+ return this[this.propertyName] && this[this.propertyName][id]
46
+ ? this[this.propertyName][id]
47
+ : null;
46
48
  }
47
49
 
48
50
  /**
@@ -52,7 +54,7 @@ export default class Collection {
52
54
  * @public
53
55
  * @memberof Collection
54
56
  */
55
- set(id, value) {
57
+ public set(id: string, value: any) {
56
58
  this[this.propertyName][id] = value;
57
59
 
58
60
  return this.get(id);
@@ -65,7 +67,7 @@ export default class Collection {
65
67
  * @public
66
68
  * @memberof Collection
67
69
  */
68
- delete(id) {
70
+ public delete(id: string) {
69
71
  delete this[this.propertyName][id];
70
72
  }
71
73
 
@@ -74,7 +76,7 @@ export default class Collection {
74
76
  * @public
75
77
  * @memberof Collection
76
78
  */
77
- getAll() {
79
+ public getAll() {
78
80
  return this[this.propertyName];
79
81
  }
80
82
 
@@ -84,7 +86,7 @@ export default class Collection {
84
86
  * @public
85
87
  * @memberof Collection
86
88
  */
87
- setAll(set) {
89
+ public setAll(set: object) {
88
90
  this[this.propertyName] = set;
89
91
 
90
92
  return this.getAll();
@@ -1,4 +1,4 @@
1
- const StaticConfig = {};
1
+ const StaticConfig: any = {};
2
2
 
3
3
  StaticConfig.set = (options) => {
4
4
  const values = {};
@@ -4,18 +4,22 @@ import {ERROR_DICTIONARY} from '../../constants';
4
4
  * Extended Error object to signify captcha related errors
5
5
  */
6
6
  export default class CaptchaError extends Error {
7
+ code: any;
8
+ error: any;
9
+ sdkMessage: any;
10
+
7
11
  /**
8
- *
9
- * @constructor
10
- * @param {String} [message]
11
- * @param {Object} [error]
12
- */
13
- constructor(message = ERROR_DICTIONARY.CAPTCHA.MESSAGE, error = null) {
12
+ *
13
+ * @constructor
14
+ * @param {String} [message]
15
+ * @param {Object} [error]
16
+ */
17
+ constructor(message: string = ERROR_DICTIONARY.CAPTCHA.MESSAGE, error: any = null) {
14
18
  super(message);
15
19
  this.name = ERROR_DICTIONARY.CAPTCHA.NAME;
16
20
  this.sdkMessage = ERROR_DICTIONARY.CAPTCHA.MESSAGE;
17
21
  this.error = error;
18
- this.stack = error ? error.stack : (new Error()).stack;
22
+ this.stack = error ? error.stack : new Error().stack;
19
23
  this.code = ERROR_DICTIONARY.CAPTCHA.CODE;
20
24
  }
21
25
  }