@webex/plugin-meetings 3.0.0-bnr.5 → 3.0.0-next.2

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 (1035) hide show
  1. package/.eslintrc.js +6 -0
  2. package/README.md +58 -8
  3. package/babel.config.js +3 -0
  4. package/dist/annotation/annotation.types.d.ts +42 -0
  5. package/dist/annotation/annotation.types.js +7 -0
  6. package/dist/annotation/annotation.types.js.map +1 -0
  7. package/dist/annotation/constants.d.ts +31 -0
  8. package/dist/annotation/constants.js +41 -0
  9. package/dist/annotation/constants.js.map +1 -0
  10. package/dist/annotation/index.d.ts +117 -0
  11. package/dist/annotation/index.js +357 -0
  12. package/dist/annotation/index.js.map +1 -0
  13. package/dist/breakouts/breakout.js +71 -34
  14. package/dist/breakouts/breakout.js.map +1 -1
  15. package/dist/breakouts/collection.js +1 -2
  16. package/dist/breakouts/collection.js.map +1 -1
  17. package/dist/breakouts/edit-lock-error.js +1 -2
  18. package/dist/breakouts/edit-lock-error.js.map +1 -1
  19. package/dist/breakouts/events.d.ts +8 -0
  20. package/dist/breakouts/events.js +44 -0
  21. package/dist/breakouts/events.js.map +1 -0
  22. package/dist/breakouts/index.js +433 -229
  23. package/dist/breakouts/index.js.map +1 -1
  24. package/dist/breakouts/request.js +1 -2
  25. package/dist/breakouts/request.js.map +1 -1
  26. package/dist/{types/breakouts → breakouts}/utils.d.ts +7 -0
  27. package/dist/breakouts/utils.js +13 -5
  28. package/dist/breakouts/utils.js.map +1 -1
  29. package/dist/common/browser-detection.js +2 -3
  30. package/dist/common/browser-detection.js.map +1 -1
  31. package/dist/common/collection.js +3 -4
  32. package/dist/common/collection.js.map +1 -1
  33. package/dist/common/config.js +1 -2
  34. package/dist/common/config.js.map +1 -1
  35. package/dist/common/errors/captcha-error.js +1 -2
  36. package/dist/common/errors/captcha-error.js.map +1 -1
  37. package/dist/common/errors/intent-to-join.js +1 -2
  38. package/dist/common/errors/intent-to-join.js.map +1 -1
  39. package/dist/common/errors/join-meeting.js +1 -2
  40. package/dist/common/errors/join-meeting.js.map +1 -1
  41. package/dist/common/errors/media.js +1 -2
  42. package/dist/common/errors/media.js.map +1 -1
  43. package/dist/{types/common/errors/permission.d.ts → common/errors/no-meeting-info.d.ts} +1 -1
  44. package/dist/common/errors/no-meeting-info.js +50 -0
  45. package/dist/common/errors/no-meeting-info.js.map +1 -0
  46. package/dist/common/errors/parameter.js +3 -4
  47. package/dist/common/errors/parameter.js.map +1 -1
  48. package/dist/common/errors/password-error.js +1 -2
  49. package/dist/common/errors/password-error.js.map +1 -1
  50. package/dist/common/errors/permission.js +1 -2
  51. package/dist/common/errors/permission.js.map +1 -1
  52. package/dist/common/errors/reclaim-host-role-errors.d.ts +60 -0
  53. package/dist/common/errors/reclaim-host-role-errors.js +154 -0
  54. package/dist/common/errors/reclaim-host-role-errors.js.map +1 -0
  55. package/dist/common/errors/reconnection-in-progress.js +1 -2
  56. package/dist/common/errors/reconnection-in-progress.js.map +1 -1
  57. package/dist/common/errors/reconnection.js +1 -2
  58. package/dist/common/errors/reconnection.js.map +1 -1
  59. package/dist/common/errors/stats.js +1 -2
  60. package/dist/common/errors/stats.js.map +1 -1
  61. package/dist/common/errors/webex-errors.d.ts +20 -8
  62. package/dist/common/errors/webex-errors.js +57 -17
  63. package/dist/common/errors/webex-errors.js.map +1 -1
  64. package/dist/common/errors/webex-meetings-error.js +1 -2
  65. package/dist/common/errors/webex-meetings-error.js.map +1 -1
  66. package/dist/common/events/events-scope.js +1 -2
  67. package/dist/common/events/events-scope.js.map +1 -1
  68. package/dist/common/events/events.js +1 -2
  69. package/dist/common/events/events.js.map +1 -1
  70. package/dist/common/events/trigger-proxy.js +1 -2
  71. package/dist/common/events/trigger-proxy.js.map +1 -1
  72. package/dist/common/events/util.js +1 -2
  73. package/dist/common/events/util.js.map +1 -1
  74. package/dist/common/logs/logger-config.js +1 -2
  75. package/dist/common/logs/logger-config.js.map +1 -1
  76. package/dist/common/logs/logger-proxy.js +2 -3
  77. package/dist/common/logs/logger-proxy.js.map +1 -1
  78. package/dist/common/logs/request.d.ts +3 -1
  79. package/dist/common/logs/request.js +8 -5
  80. package/dist/common/logs/request.js.map +1 -1
  81. package/dist/common/queue.d.ts +9 -7
  82. package/dist/common/queue.js +22 -9
  83. package/dist/common/queue.js.map +1 -1
  84. package/dist/config.d.ts +6 -7
  85. package/dist/config.js +6 -12
  86. package/dist/config.js.map +1 -1
  87. package/dist/constants.d.ts +263 -98
  88. package/dist/constants.js +360 -377
  89. package/dist/constants.js.map +1 -1
  90. package/dist/controls-options-manager/constants.js +3 -6
  91. package/dist/controls-options-manager/constants.js.map +1 -1
  92. package/dist/controls-options-manager/enums.d.ts +11 -1
  93. package/dist/controls-options-manager/enums.js +9 -10
  94. package/dist/controls-options-manager/enums.js.map +1 -1
  95. package/dist/controls-options-manager/index.d.ts +17 -1
  96. package/dist/controls-options-manager/index.js +46 -46
  97. package/dist/controls-options-manager/index.js.map +1 -1
  98. package/dist/{types/controls-options-manager → controls-options-manager}/types.d.ts +7 -1
  99. package/dist/controls-options-manager/types.js.map +1 -1
  100. package/dist/controls-options-manager/util.d.ts +1 -7
  101. package/dist/controls-options-manager/util.js +81 -13
  102. package/dist/controls-options-manager/util.js.map +1 -1
  103. package/dist/index.d.ts +6 -3
  104. package/dist/index.js +70 -25
  105. package/dist/index.js.map +1 -1
  106. package/dist/interceptors/index.d.ts +2 -0
  107. package/dist/interceptors/index.js +15 -0
  108. package/dist/interceptors/index.js.map +1 -0
  109. package/dist/interceptors/locusRetry.d.ts +27 -0
  110. package/dist/interceptors/locusRetry.js +94 -0
  111. package/dist/interceptors/locusRetry.js.map +1 -0
  112. package/dist/interpretation/collection.d.ts +5 -0
  113. package/dist/interpretation/collection.js +22 -0
  114. package/dist/interpretation/collection.js.map +1 -0
  115. package/dist/interpretation/index.d.ts +5 -0
  116. package/dist/interpretation/index.js +379 -0
  117. package/dist/interpretation/index.js.map +1 -0
  118. package/dist/interpretation/siLanguage.d.ts +5 -0
  119. package/dist/interpretation/siLanguage.js +24 -0
  120. package/dist/interpretation/siLanguage.js.map +1 -0
  121. package/dist/locus-info/controlsUtils.js +82 -13
  122. package/dist/locus-info/controlsUtils.js.map +1 -1
  123. package/dist/locus-info/embeddedAppsUtils.js +3 -4
  124. package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
  125. package/dist/locus-info/fullState.js +1 -2
  126. package/dist/locus-info/fullState.js.map +1 -1
  127. package/dist/locus-info/hostUtils.js +1 -2
  128. package/dist/locus-info/hostUtils.js.map +1 -1
  129. package/dist/locus-info/index.d.ts +57 -4
  130. package/dist/locus-info/index.js +350 -77
  131. package/dist/locus-info/index.js.map +1 -1
  132. package/dist/locus-info/infoUtils.js +10 -5
  133. package/dist/locus-info/infoUtils.js.map +1 -1
  134. package/dist/locus-info/mediaSharesUtils.js +58 -3
  135. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  136. package/dist/locus-info/parser.d.ts +66 -6
  137. package/dist/locus-info/parser.js +253 -80
  138. package/dist/locus-info/parser.js.map +1 -1
  139. package/dist/locus-info/selfUtils.js +49 -26
  140. package/dist/locus-info/selfUtils.js.map +1 -1
  141. package/dist/media/index.d.ts +2 -0
  142. package/dist/media/index.js +66 -108
  143. package/dist/media/index.js.map +1 -1
  144. package/dist/media/properties.d.ts +38 -53
  145. package/dist/media/properties.js +76 -128
  146. package/dist/media/properties.js.map +1 -1
  147. package/dist/media/util.js +1 -2
  148. package/dist/media/util.js.map +1 -1
  149. package/dist/mediaQualityMetrics/config.d.ts +239 -231
  150. package/dist/mediaQualityMetrics/config.js +135 -339
  151. package/dist/mediaQualityMetrics/config.js.map +1 -1
  152. package/dist/meeting/in-meeting-actions.d.ts +88 -0
  153. package/dist/meeting/in-meeting-actions.js +79 -5
  154. package/dist/meeting/in-meeting-actions.js.map +1 -1
  155. package/dist/meeting/index.d.ts +710 -517
  156. package/dist/meeting/index.js +4348 -3053
  157. package/dist/meeting/index.js.map +1 -1
  158. package/dist/meeting/locusMediaRequest.d.ts +74 -0
  159. package/dist/meeting/locusMediaRequest.js +291 -0
  160. package/dist/meeting/locusMediaRequest.js.map +1 -0
  161. package/dist/meeting/muteState.d.ts +93 -25
  162. package/dist/meeting/muteState.js +125 -207
  163. package/dist/meeting/muteState.js.map +1 -1
  164. package/dist/meeting/request.d.ts +84 -47
  165. package/dist/meeting/request.js +190 -165
  166. package/dist/meeting/request.js.map +1 -1
  167. package/dist/meeting/state.js +1 -2
  168. package/dist/meeting/state.js.map +1 -1
  169. package/dist/meeting/util.d.ts +118 -1
  170. package/dist/meeting/util.js +680 -447
  171. package/dist/meeting/util.js.map +1 -1
  172. package/dist/meeting/voicea-meeting.d.ts +16 -0
  173. package/dist/meeting/voicea-meeting.js +169 -0
  174. package/dist/meeting/voicea-meeting.js.map +1 -0
  175. package/dist/meeting-info/collection.js +3 -4
  176. package/dist/meeting-info/collection.js.map +1 -1
  177. package/dist/meeting-info/index.d.ts +13 -1
  178. package/dist/meeting-info/index.js +74 -7
  179. package/dist/meeting-info/index.js.map +1 -1
  180. package/dist/meeting-info/meeting-info-v2.d.ts +31 -1
  181. package/dist/meeting-info/meeting-info-v2.js +136 -61
  182. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  183. package/dist/meeting-info/request.js +1 -2
  184. package/dist/meeting-info/request.js.map +1 -1
  185. package/dist/meeting-info/util.js +9 -9
  186. package/dist/meeting-info/util.js.map +1 -1
  187. package/dist/meeting-info/utilv2.js +31 -41
  188. package/dist/meeting-info/utilv2.js.map +1 -1
  189. package/dist/meetings/collection.d.ts +17 -0
  190. package/dist/meetings/collection.js +21 -5
  191. package/dist/meetings/collection.js.map +1 -1
  192. package/dist/meetings/index.d.ts +114 -22
  193. package/dist/meetings/index.js +397 -127
  194. package/dist/meetings/index.js.map +1 -1
  195. package/dist/meetings/meetings.types.d.ts +4 -0
  196. package/dist/meetings/meetings.types.js +7 -0
  197. package/dist/meetings/meetings.types.js.map +1 -0
  198. package/dist/meetings/request.js +2 -3
  199. package/dist/meetings/request.js.map +1 -1
  200. package/dist/meetings/util.js +45 -17
  201. package/dist/meetings/util.js.map +1 -1
  202. package/dist/member/index.d.ts +15 -0
  203. package/dist/member/index.js +35 -2
  204. package/dist/member/index.js.map +1 -1
  205. package/dist/member/member.types.d.ts +11 -0
  206. package/dist/member/member.types.js +17 -0
  207. package/dist/member/member.types.js.map +1 -0
  208. package/dist/{types/member → member}/types.d.ts +11 -0
  209. package/dist/member/types.js +13 -5
  210. package/dist/member/types.js.map +1 -1
  211. package/dist/member/util.js +72 -25
  212. package/dist/member/util.js.map +1 -1
  213. package/dist/members/collection.d.ts +5 -0
  214. package/dist/members/collection.js +1 -2
  215. package/dist/members/collection.js.map +1 -1
  216. package/dist/members/index.d.ts +57 -2
  217. package/dist/members/index.js +29 -9
  218. package/dist/members/index.js.map +1 -1
  219. package/dist/members/request.d.ts +73 -9
  220. package/dist/members/request.js +77 -48
  221. package/dist/members/request.js.map +1 -1
  222. package/dist/{types/members → members}/types.d.ts +1 -0
  223. package/dist/members/types.js +3 -4
  224. package/dist/members/types.js.map +1 -1
  225. package/dist/members/util.d.ts +214 -1
  226. package/dist/members/util.js +320 -319
  227. package/dist/members/util.js.map +1 -1
  228. package/dist/metrics/constants.d.ts +17 -4
  229. package/dist/metrics/constants.js +18 -3
  230. package/dist/metrics/constants.js.map +1 -1
  231. package/dist/metrics/index.d.ts +4 -111
  232. package/dist/metrics/index.js +4 -453
  233. package/dist/metrics/index.js.map +1 -1
  234. package/dist/{types/multistream → multistream}/mediaRequestManager.d.ts +29 -10
  235. package/dist/multistream/mediaRequestManager.js +142 -48
  236. package/dist/multistream/mediaRequestManager.js.map +1 -1
  237. package/dist/{types/multistream → multistream}/receiveSlot.d.ts +3 -3
  238. package/dist/multistream/receiveSlot.js +3 -5
  239. package/dist/multistream/receiveSlot.js.map +1 -1
  240. package/dist/multistream/receiveSlotManager.js +11 -13
  241. package/dist/multistream/receiveSlotManager.js.map +1 -1
  242. package/dist/{types/multistream → multistream}/remoteMedia.d.ts +2 -2
  243. package/dist/multistream/remoteMedia.js +3 -5
  244. package/dist/multistream/remoteMedia.js.map +1 -1
  245. package/dist/{types/multistream → multistream}/remoteMediaGroup.d.ts +2 -0
  246. package/dist/multistream/remoteMediaGroup.js +78 -6
  247. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  248. package/dist/{types/multistream → multistream}/remoteMediaManager.d.ts +39 -1
  249. package/dist/multistream/remoteMediaManager.js +288 -100
  250. package/dist/multistream/remoteMediaManager.js.map +1 -1
  251. package/dist/multistream/sendSlotManager.d.ts +70 -0
  252. package/dist/multistream/sendSlotManager.js +258 -0
  253. package/dist/multistream/sendSlotManager.js.map +1 -0
  254. package/dist/networkQualityMonitor/index.js +1 -2
  255. package/dist/networkQualityMonitor/index.js.map +1 -1
  256. package/dist/personal-meeting-room/index.js +2 -3
  257. package/dist/personal-meeting-room/index.js.map +1 -1
  258. package/dist/personal-meeting-room/request.js +2 -3
  259. package/dist/personal-meeting-room/request.js.map +1 -1
  260. package/dist/personal-meeting-room/util.js +1 -2
  261. package/dist/personal-meeting-room/util.js.map +1 -1
  262. package/dist/reachability/clusterReachability.d.ts +109 -0
  263. package/dist/reachability/clusterReachability.js +357 -0
  264. package/dist/reachability/clusterReachability.js.map +1 -0
  265. package/dist/reachability/index.d.ts +61 -95
  266. package/dist/reachability/index.js +280 -431
  267. package/dist/reachability/index.js.map +1 -1
  268. package/dist/reachability/request.d.ts +7 -3
  269. package/dist/reachability/request.js +18 -13
  270. package/dist/reachability/request.js.map +1 -1
  271. package/dist/reachability/util.d.ts +8 -0
  272. package/dist/reachability/util.js +29 -0
  273. package/dist/reachability/util.js.map +1 -0
  274. package/dist/reactions/constants.js +1 -2
  275. package/dist/reactions/constants.js.map +1 -1
  276. package/dist/reactions/reactions.d.ts +2 -2
  277. package/dist/reactions/reactions.js +2 -4
  278. package/dist/reactions/reactions.js.map +1 -1
  279. package/dist/reactions/reactions.type.d.ts +23 -3
  280. package/dist/reactions/reactions.type.js +6 -8
  281. package/dist/reactions/reactions.type.js.map +1 -1
  282. package/dist/reconnection-manager/index.d.ts +32 -8
  283. package/dist/reconnection-manager/index.js +264 -209
  284. package/dist/reconnection-manager/index.js.map +1 -1
  285. package/dist/recording-controller/enums.js +4 -5
  286. package/dist/recording-controller/enums.js.map +1 -1
  287. package/dist/recording-controller/index.d.ts +15 -1
  288. package/dist/recording-controller/index.js +57 -46
  289. package/dist/recording-controller/index.js.map +1 -1
  290. package/dist/recording-controller/util.d.ts +5 -4
  291. package/dist/recording-controller/util.js +10 -10
  292. package/dist/recording-controller/util.js.map +1 -1
  293. package/dist/roap/index.d.ts +9 -47
  294. package/dist/roap/index.js +53 -31
  295. package/dist/roap/index.js.map +1 -1
  296. package/dist/roap/request.d.ts +16 -12
  297. package/dist/roap/request.js +57 -73
  298. package/dist/roap/request.js.map +1 -1
  299. package/dist/roap/turnDiscovery.d.ts +46 -5
  300. package/dist/roap/turnDiscovery.js +227 -76
  301. package/dist/roap/turnDiscovery.js.map +1 -1
  302. package/dist/rtcMetrics/constants.d.ts +4 -0
  303. package/dist/rtcMetrics/constants.js +11 -0
  304. package/dist/rtcMetrics/constants.js.map +1 -0
  305. package/dist/rtcMetrics/index.d.ts +61 -0
  306. package/dist/rtcMetrics/index.js +177 -0
  307. package/dist/rtcMetrics/index.js.map +1 -0
  308. package/dist/statsAnalyzer/global.d.ts +1 -91
  309. package/dist/statsAnalyzer/global.js +1 -2
  310. package/dist/statsAnalyzer/global.js.map +1 -1
  311. package/dist/statsAnalyzer/index.d.ts +55 -28
  312. package/dist/statsAnalyzer/index.js +371 -319
  313. package/dist/statsAnalyzer/index.js.map +1 -1
  314. package/dist/statsAnalyzer/mqaUtil.d.ts +32 -6
  315. package/dist/statsAnalyzer/mqaUtil.js +295 -162
  316. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  317. package/dist/transcription/index.js +1 -2
  318. package/dist/transcription/index.js.map +1 -1
  319. package/dist/webinar/collection.d.ts +16 -0
  320. package/dist/webinar/collection.js +43 -0
  321. package/dist/webinar/collection.js.map +1 -0
  322. package/dist/webinar/index.d.ts +5 -0
  323. package/dist/webinar/index.js +68 -0
  324. package/dist/webinar/index.js.map +1 -0
  325. package/jest.config.js +3 -0
  326. package/package.json +44 -23
  327. package/process +1 -0
  328. package/src/annotation/annotation.types.ts +50 -0
  329. package/src/annotation/constants.ts +36 -0
  330. package/src/annotation/index.ts +328 -0
  331. package/src/breakouts/README.md +3 -2
  332. package/src/breakouts/breakout.ts +62 -27
  333. package/src/breakouts/events.ts +56 -0
  334. package/src/breakouts/index.ts +244 -64
  335. package/src/breakouts/utils.ts +13 -0
  336. package/src/common/errors/no-meeting-info.ts +24 -0
  337. package/src/common/errors/reclaim-host-role-errors.ts +134 -0
  338. package/src/common/errors/webex-errors.ts +44 -2
  339. package/src/common/logs/logger-proxy.ts +1 -1
  340. package/src/common/logs/request.ts +5 -1
  341. package/src/common/queue.ts +22 -8
  342. package/src/config.ts +5 -13
  343. package/src/constants.ts +190 -24
  344. package/src/controls-options-manager/enums.ts +2 -0
  345. package/src/controls-options-manager/index.ts +13 -10
  346. package/src/controls-options-manager/types.ts +10 -0
  347. package/src/controls-options-manager/util.ts +82 -11
  348. package/src/index.ts +22 -11
  349. package/src/interceptors/index.ts +3 -0
  350. package/src/interceptors/locusRetry.ts +67 -0
  351. package/src/interpretation/README.md +60 -0
  352. package/src/interpretation/collection.ts +19 -0
  353. package/src/interpretation/index.ts +349 -0
  354. package/src/interpretation/siLanguage.ts +18 -0
  355. package/src/locus-info/controlsUtils.ts +81 -0
  356. package/src/locus-info/index.ts +354 -57
  357. package/src/locus-info/infoUtils.ts +10 -2
  358. package/src/locus-info/mediaSharesUtils.ts +64 -0
  359. package/src/locus-info/parser.ts +258 -47
  360. package/src/locus-info/selfUtils.ts +32 -20
  361. package/src/media/index.ts +96 -108
  362. package/src/media/properties.ts +87 -112
  363. package/src/mediaQualityMetrics/config.ts +103 -238
  364. package/src/meeting/in-meeting-actions.ts +128 -4
  365. package/src/meeting/index.ts +3472 -2523
  366. package/src/meeting/locusMediaRequest.ts +313 -0
  367. package/src/meeting/muteState.ts +119 -194
  368. package/src/meeting/request.ts +155 -120
  369. package/src/meeting/util.ts +683 -412
  370. package/src/meeting/voicea-meeting.ts +122 -0
  371. package/src/meeting-info/index.ts +81 -8
  372. package/src/meeting-info/meeting-info-v2.ts +107 -26
  373. package/src/meeting-info/util.ts +13 -10
  374. package/src/meeting-info/utilv2.ts +40 -36
  375. package/src/meetings/collection.ts +13 -0
  376. package/src/meetings/index.ts +361 -116
  377. package/src/meetings/meetings.types.ts +12 -0
  378. package/src/meetings/util.ts +49 -20
  379. package/src/member/index.ts +36 -1
  380. package/src/member/member.types.ts +13 -0
  381. package/src/member/types.ts +14 -0
  382. package/src/member/util.ts +89 -26
  383. package/src/members/index.ts +36 -3
  384. package/src/members/request.ts +61 -21
  385. package/src/members/types.ts +1 -0
  386. package/src/members/util.ts +330 -326
  387. package/src/metrics/constants.ts +16 -0
  388. package/src/metrics/index.ts +1 -474
  389. package/src/multistream/mediaRequestManager.ts +186 -67
  390. package/src/multistream/receiveSlot.ts +4 -4
  391. package/src/multistream/receiveSlotManager.ts +4 -4
  392. package/src/multistream/remoteMedia.ts +2 -2
  393. package/src/multistream/remoteMediaGroup.ts +78 -0
  394. package/src/multistream/remoteMediaManager.ts +174 -18
  395. package/src/multistream/sendSlotManager.ts +199 -0
  396. package/src/reachability/clusterReachability.ts +320 -0
  397. package/src/reachability/index.ts +226 -382
  398. package/src/reachability/request.ts +8 -4
  399. package/src/reachability/util.ts +24 -0
  400. package/src/reconnection-manager/index.ts +95 -82
  401. package/src/recording-controller/index.ts +20 -3
  402. package/src/recording-controller/util.ts +26 -9
  403. package/src/roap/index.ts +52 -23
  404. package/src/roap/request.ts +49 -68
  405. package/src/roap/turnDiscovery.ts +147 -49
  406. package/src/rtcMetrics/constants.ts +3 -0
  407. package/src/rtcMetrics/index.ts +166 -0
  408. package/src/statsAnalyzer/index.ts +430 -428
  409. package/src/statsAnalyzer/mqaUtil.ts +317 -168
  410. package/src/webinar/collection.ts +31 -0
  411. package/src/webinar/index.ts +62 -0
  412. package/test/integration/spec/converged-space-meetings.js +60 -3
  413. package/test/integration/spec/journey.js +322 -263
  414. package/test/integration/spec/space-meeting.js +77 -4
  415. package/test/unit/spec/annotation/index.ts +418 -0
  416. package/test/unit/spec/breakouts/breakout.ts +86 -26
  417. package/test/unit/spec/breakouts/events.ts +89 -0
  418. package/test/unit/spec/breakouts/index.ts +639 -98
  419. package/test/unit/spec/breakouts/utils.js +19 -1
  420. package/test/unit/spec/common/queue.js +31 -2
  421. package/test/unit/spec/controls-options-manager/index.js +8 -1
  422. package/test/unit/spec/controls-options-manager/util.js +576 -397
  423. package/test/unit/spec/fixture/locus.js +1 -0
  424. package/test/unit/spec/interceptors/locusRetry.ts +131 -0
  425. package/test/unit/spec/interpretation/collection.ts +15 -0
  426. package/test/unit/spec/interpretation/index.ts +622 -0
  427. package/test/unit/spec/interpretation/siLanguage.ts +28 -0
  428. package/test/unit/spec/locus-info/controlsUtils.js +195 -1
  429. package/test/unit/spec/locus-info/index.js +1176 -69
  430. package/test/unit/spec/locus-info/infoUtils.js +37 -15
  431. package/test/unit/spec/locus-info/lib/SeqCmp.json +16 -0
  432. package/test/unit/spec/locus-info/mediaSharesUtils.ts +32 -0
  433. package/test/unit/spec/locus-info/parser.js +116 -35
  434. package/test/unit/spec/locus-info/selfConstant.js +19 -0
  435. package/test/unit/spec/locus-info/selfUtils.js +128 -28
  436. package/test/unit/spec/media/index.ts +103 -79
  437. package/test/unit/spec/media/properties.ts +2 -2
  438. package/test/unit/spec/meeting/in-meeting-actions.ts +64 -2
  439. package/test/unit/spec/meeting/index.js +6768 -2199
  440. package/test/unit/spec/meeting/locusMediaRequest.ts +442 -0
  441. package/test/unit/spec/meeting/muteState.js +328 -417
  442. package/test/unit/spec/meeting/request.js +473 -54
  443. package/test/unit/spec/meeting/utils.js +764 -84
  444. package/test/unit/spec/meeting/voicea-meeting.ts +266 -0
  445. package/test/unit/spec/meeting-info/index.js +300 -0
  446. package/test/unit/spec/meeting-info/meetinginfov2.js +411 -25
  447. package/test/unit/spec/meeting-info/utilv2.js +21 -0
  448. package/test/unit/spec/meetings/collection.js +12 -0
  449. package/test/unit/spec/meetings/index.js +1266 -234
  450. package/test/unit/spec/meetings/utils.js +187 -9
  451. package/test/unit/spec/member/index.js +50 -19
  452. package/test/unit/spec/member/util.js +328 -155
  453. package/test/unit/spec/members/index.js +153 -20
  454. package/test/unit/spec/members/request.js +167 -35
  455. package/test/unit/spec/members/utils.js +26 -0
  456. package/test/unit/spec/metrics/index.js +2 -52
  457. package/test/unit/spec/multistream/mediaRequestManager.ts +386 -9
  458. package/test/unit/spec/multistream/receiveSlot.ts +1 -1
  459. package/test/unit/spec/multistream/remoteMediaGroup.ts +345 -0
  460. package/test/unit/spec/multistream/remoteMediaManager.ts +332 -2
  461. package/test/unit/spec/multistream/sendSlotManager.ts +274 -0
  462. package/test/unit/spec/reachability/clusterReachability.ts +279 -0
  463. package/test/unit/spec/reachability/index.ts +525 -94
  464. package/test/unit/spec/reachability/request.js +3 -1
  465. package/test/unit/spec/reachability/util.ts +40 -0
  466. package/test/unit/spec/reconnection-manager/index.js +135 -7
  467. package/test/unit/spec/recording-controller/index.js +293 -218
  468. package/test/unit/spec/recording-controller/util.js +223 -96
  469. package/test/unit/spec/roap/index.ts +180 -83
  470. package/test/unit/spec/roap/request.ts +100 -62
  471. package/test/unit/spec/roap/turnDiscovery.ts +388 -96
  472. package/test/unit/spec/rtcMetrics/index.ts +122 -0
  473. package/test/unit/spec/stats-analyzer/index.js +1225 -12
  474. package/test/unit/spec/webinar/collection.ts +13 -0
  475. package/test/unit/spec/webinar/index.ts +60 -0
  476. package/test/utils/integrationTestUtils.js +46 -0
  477. package/test/utils/testUtils.js +0 -60
  478. package/test/utils/webex-test-users.js +12 -4
  479. package/dist/docs/markdown/index.md +0 -12
  480. package/dist/docs/markdown/plugin-meetings.constants._active_.md +0 -11
  481. package/dist/docs/markdown/plugin-meetings.constants._answer_.md +0 -11
  482. package/dist/docs/markdown/plugin-meetings.constants._call_.md +0 -11
  483. package/dist/docs/markdown/plugin-meetings.constants._conflict_.md +0 -11
  484. package/dist/docs/markdown/plugin-meetings.constants._conversation_url_.md +0 -11
  485. package/dist/docs/markdown/plugin-meetings.constants._created_.md +0 -11
  486. package/dist/docs/markdown/plugin-meetings.constants._error_.md +0 -11
  487. package/dist/docs/markdown/plugin-meetings.constants._forced_.md +0 -11
  488. package/dist/docs/markdown/plugin-meetings.constants._id_.md +0 -11
  489. package/dist/docs/markdown/plugin-meetings.constants._idle_.md +0 -11
  490. package/dist/docs/markdown/plugin-meetings.constants._in_.md +0 -11
  491. package/dist/docs/markdown/plugin-meetings.constants._in_lobby_.md +0 -11
  492. package/dist/docs/markdown/plugin-meetings.constants._in_meeting_.md +0 -11
  493. package/dist/docs/markdown/plugin-meetings.constants._inactive_.md +0 -11
  494. package/dist/docs/markdown/plugin-meetings.constants._incoming_.md +0 -11
  495. package/dist/docs/markdown/plugin-meetings.constants._join_.md +0 -11
  496. package/dist/docs/markdown/plugin-meetings.constants._joined_.md +0 -11
  497. package/dist/docs/markdown/plugin-meetings.constants._left_.md +0 -11
  498. package/dist/docs/markdown/plugin-meetings.constants._locus_id_.md +0 -11
  499. package/dist/docs/markdown/plugin-meetings.constants._meeting_.md +0 -11
  500. package/dist/docs/markdown/plugin-meetings.constants._meeting_center_.md +0 -11
  501. package/dist/docs/markdown/plugin-meetings.constants._meeting_id_.md +0 -11
  502. package/dist/docs/markdown/plugin-meetings.constants._meeting_link_.md +0 -11
  503. package/dist/docs/markdown/plugin-meetings.constants._meeting_uuid_.md +0 -11
  504. package/dist/docs/markdown/plugin-meetings.constants._move_media_.md +0 -11
  505. package/dist/docs/markdown/plugin-meetings.constants._none_.md +0 -11
  506. package/dist/docs/markdown/plugin-meetings.constants._not_in_meeting_.md +0 -11
  507. package/dist/docs/markdown/plugin-meetings.constants._observe_.md +0 -11
  508. package/dist/docs/markdown/plugin-meetings.constants._people_.md +0 -11
  509. package/dist/docs/markdown/plugin-meetings.constants._personal_room_.md +0 -11
  510. package/dist/docs/markdown/plugin-meetings.constants._receive_only_.md +0 -11
  511. package/dist/docs/markdown/plugin-meetings.constants._remove_.md +0 -11
  512. package/dist/docs/markdown/plugin-meetings.constants._requested_.md +0 -11
  513. package/dist/docs/markdown/plugin-meetings.constants._resource_room_.md +0 -11
  514. package/dist/docs/markdown/plugin-meetings.constants._room_.md +0 -11
  515. package/dist/docs/markdown/plugin-meetings.constants._s_line.md +0 -11
  516. package/dist/docs/markdown/plugin-meetings.constants._send_only_.md +0 -11
  517. package/dist/docs/markdown/plugin-meetings.constants._send_receive_.md +0 -11
  518. package/dist/docs/markdown/plugin-meetings.constants._sip_bridge_.md +0 -11
  519. package/dist/docs/markdown/plugin-meetings.constants._sip_uri_.md +0 -11
  520. package/dist/docs/markdown/plugin-meetings.constants._slides_.md +0 -11
  521. package/dist/docs/markdown/plugin-meetings.constants._unknown_.md +0 -11
  522. package/dist/docs/markdown/plugin-meetings.constants._user_.md +0 -11
  523. package/dist/docs/markdown/plugin-meetings.constants._wait_.md +0 -11
  524. package/dist/docs/markdown/plugin-meetings.constants._webex_meeting_.md +0 -11
  525. package/dist/docs/markdown/plugin-meetings.constants.alert.md +0 -11
  526. package/dist/docs/markdown/plugin-meetings.constants.alternate_redirect_true.md +0 -11
  527. package/dist/docs/markdown/plugin-meetings.constants.answer.md +0 -11
  528. package/dist/docs/markdown/plugin-meetings.constants.api.md +0 -14
  529. package/dist/docs/markdown/plugin-meetings.constants.audio.md +0 -11
  530. package/dist/docs/markdown/plugin-meetings.constants.audio_input.md +0 -11
  531. package/dist/docs/markdown/plugin-meetings.constants.audio_status.md +0 -11
  532. package/dist/docs/markdown/plugin-meetings.constants.available_resolutions.md +0 -60
  533. package/dist/docs/markdown/plugin-meetings.constants.bnr_status.md +0 -16
  534. package/dist/docs/markdown/plugin-meetings.constants.breakouts.md +0 -51
  535. package/dist/docs/markdown/plugin-meetings.constants.calendar.md +0 -11
  536. package/dist/docs/markdown/plugin-meetings.constants.calendar_events.md +0 -17
  537. package/dist/docs/markdown/plugin-meetings.constants.calendar_events_api.md +0 -11
  538. package/dist/docs/markdown/plugin-meetings.constants.call.md +0 -11
  539. package/dist/docs/markdown/plugin-meetings.constants.call_removed_reason.md +0 -15
  540. package/dist/docs/markdown/plugin-meetings.constants.claim.md +0 -11
  541. package/dist/docs/markdown/plugin-meetings.constants.cmr_meetings.md +0 -11
  542. package/dist/docs/markdown/plugin-meetings.constants.complete.md +0 -11
  543. package/dist/docs/markdown/plugin-meetings.constants.connection_state.md +0 -18
  544. package/dist/docs/markdown/plugin-meetings.constants.content.md +0 -11
  545. package/dist/docs/markdown/plugin-meetings.constants.controls.md +0 -11
  546. package/dist/docs/markdown/plugin-meetings.constants.conversation_service.md +0 -11
  547. package/dist/docs/markdown/plugin-meetings.constants.conversation_url.md +0 -11
  548. package/dist/docs/markdown/plugin-meetings.constants.correlation_id.md +0 -11
  549. package/dist/docs/markdown/plugin-meetings.constants.decline.md +0 -11
  550. package/dist/docs/markdown/plugin-meetings.constants.default_excluded_stats.md +0 -11
  551. package/dist/docs/markdown/plugin-meetings.constants.default_get_stats_filter.md +0 -13
  552. package/dist/docs/markdown/plugin-meetings.constants.development.md +0 -11
  553. package/dist/docs/markdown/plugin-meetings.constants.dialer_regex.md +0 -15
  554. package/dist/docs/markdown/plugin-meetings.constants.display_hints.md +0 -51
  555. package/dist/docs/markdown/plugin-meetings.constants.embedded_app_types.md +0 -14
  556. package/dist/docs/markdown/plugin-meetings.constants.end.md +0 -11
  557. package/dist/docs/markdown/plugin-meetings.constants.ended.md +0 -11
  558. package/dist/docs/markdown/plugin-meetings.constants.error.md +0 -11
  559. package/dist/docs/markdown/plugin-meetings.constants.error_dictionary.md +0 -62
  560. package/dist/docs/markdown/plugin-meetings.constants.event_triggers.md +0 -82
  561. package/dist/docs/markdown/plugin-meetings.constants.event_types.md +0 -21
  562. package/dist/docs/markdown/plugin-meetings.constants.events.md +0 -26
  563. package/dist/docs/markdown/plugin-meetings.constants.floor_action.md +0 -15
  564. package/dist/docs/markdown/plugin-meetings.constants.full_state.md +0 -17
  565. package/dist/docs/markdown/plugin-meetings.constants.gathering.md +0 -11
  566. package/dist/docs/markdown/plugin-meetings.constants.hecate.md +0 -11
  567. package/dist/docs/markdown/plugin-meetings.constants.host.md +0 -11
  568. package/dist/docs/markdown/plugin-meetings.constants.http_verbs.md +0 -17
  569. package/dist/docs/markdown/plugin-meetings.constants.https_protocol.md +0 -11
  570. package/dist/docs/markdown/plugin-meetings.constants.ice_fail_timeout.md +0 -11
  571. package/dist/docs/markdown/plugin-meetings.constants.ice_gathering_state.md +0 -15
  572. package/dist/docs/markdown/plugin-meetings.constants.ice_state.md +0 -18
  573. package/dist/docs/markdown/plugin-meetings.constants.ice_timeout.md +0 -11
  574. package/dist/docs/markdown/plugin-meetings.constants.intent_to_join.md +0 -11
  575. package/dist/docs/markdown/plugin-meetings.constants.ipv4_regex.md +0 -11
  576. package/dist/docs/markdown/plugin-meetings.constants.join.md +0 -11
  577. package/dist/docs/markdown/plugin-meetings.constants.layout_types.md +0 -13
  578. package/dist/docs/markdown/plugin-meetings.constants.leave.md +0 -11
  579. package/dist/docs/markdown/plugin-meetings.constants.live.md +0 -11
  580. package/dist/docs/markdown/plugin-meetings.constants.local.md +0 -11
  581. package/dist/docs/markdown/plugin-meetings.constants.loci.md +0 -11
  582. package/dist/docs/markdown/plugin-meetings.constants.locus.md +0 -26
  583. package/dist/docs/markdown/plugin-meetings.constants.locus_url.md +0 -11
  584. package/dist/docs/markdown/plugin-meetings.constants.locusevent.md +0 -33
  585. package/dist/docs/markdown/plugin-meetings.constants.locusinfo.md +0 -43
  586. package/dist/docs/markdown/plugin-meetings.constants.max_random_delay_for_meeting_info.md +0 -11
  587. package/dist/docs/markdown/plugin-meetings.constants.md +0 -186
  588. package/dist/docs/markdown/plugin-meetings.constants.media.md +0 -11
  589. package/dist/docs/markdown/plugin-meetings.constants.media_devices.md +0 -15
  590. package/dist/docs/markdown/plugin-meetings.constants.media_peer_connection_name.md +0 -11
  591. package/dist/docs/markdown/plugin-meetings.constants.media_state.md +0 -14
  592. package/dist/docs/markdown/plugin-meetings.constants.media_track_constraint.md +0 -17
  593. package/dist/docs/markdown/plugin-meetings.constants.mediacontent.md +0 -14
  594. package/dist/docs/markdown/plugin-meetings.constants.meet.md +0 -11
  595. package/dist/docs/markdown/plugin-meetings.constants.meet_m.md +0 -11
  596. package/dist/docs/markdown/plugin-meetings.constants.meeting_audio_state_machine.md +0 -20
  597. package/dist/docs/markdown/plugin-meetings.constants.meeting_end_reason.md +0 -14
  598. package/dist/docs/markdown/plugin-meetings.constants.meeting_errors.md +0 -102
  599. package/dist/docs/markdown/plugin-meetings.constants.meeting_info_failure_reason.md +0 -16
  600. package/dist/docs/markdown/plugin-meetings.constants.meeting_removed_reason.md +0 -19
  601. package/dist/docs/markdown/plugin-meetings.constants.meeting_state.md +0 -25
  602. package/dist/docs/markdown/plugin-meetings.constants.meeting_state_machine.md +0 -31
  603. package/dist/docs/markdown/plugin-meetings.constants.meeting_video_state_machine.md +0 -20
  604. package/dist/docs/markdown/plugin-meetings.constants.meetinginfo.md +0 -11
  605. package/dist/docs/markdown/plugin-meetings.constants.meetings.md +0 -11
  606. package/dist/docs/markdown/plugin-meetings.constants.metrics_join_times_max_duration.md +0 -11
  607. package/dist/docs/markdown/plugin-meetings.constants.moderator_false.md +0 -11
  608. package/dist/docs/markdown/plugin-meetings.constants.moderator_true.md +0 -11
  609. package/dist/docs/markdown/plugin-meetings.constants.mqa_inteval.md +0 -11
  610. package/dist/docs/markdown/plugin-meetings.constants.mqa_stats.md +0 -82
  611. package/dist/docs/markdown/plugin-meetings.constants.network_status.md +0 -15
  612. package/dist/docs/markdown/plugin-meetings.constants.network_type.md +0 -16
  613. package/dist/docs/markdown/plugin-meetings.constants.offline.md +0 -11
  614. package/dist/docs/markdown/plugin-meetings.constants.online.md +0 -11
  615. package/dist/docs/markdown/plugin-meetings.constants.participant.md +0 -11
  616. package/dist/docs/markdown/plugin-meetings.constants.participant_deltas.md +0 -22
  617. package/dist/docs/markdown/plugin-meetings.constants.password_status.md +0 -16
  618. package/dist/docs/markdown/plugin-meetings.constants.pc_bail_timeout.md +0 -11
  619. package/dist/docs/markdown/plugin-meetings.constants.peer_connection_state.md +0 -14
  620. package/dist/docs/markdown/plugin-meetings.constants.provisional_type_dial_in.md +0 -11
  621. package/dist/docs/markdown/plugin-meetings.constants.provisional_type_dial_out.md +0 -11
  622. package/dist/docs/markdown/plugin-meetings.constants.pstn_status.md +0 -18
  623. package/dist/docs/markdown/plugin-meetings.constants.quality_levels.md +0 -19
  624. package/dist/docs/markdown/plugin-meetings.constants.reachability.md +0 -15
  625. package/dist/docs/markdown/plugin-meetings.constants.ready.md +0 -11
  626. package/dist/docs/markdown/plugin-meetings.constants.reconnection.md +0 -19
  627. package/dist/docs/markdown/plugin-meetings.constants.recording_state.md +0 -16
  628. package/dist/docs/markdown/plugin-meetings.constants.remote.md +0 -11
  629. package/dist/docs/markdown/plugin-meetings.constants.resource.md +0 -15
  630. package/dist/docs/markdown/plugin-meetings.constants.retry_timeout.md +0 -11
  631. package/dist/docs/markdown/plugin-meetings.constants.roap.md +0 -22
  632. package/dist/docs/markdown/plugin-meetings.constants.self_roles.md +0 -14
  633. package/dist/docs/markdown/plugin-meetings.constants.send_dtmf_endpoint.md +0 -11
  634. package/dist/docs/markdown/plugin-meetings.constants.sendrecv.md +0 -11
  635. package/dist/docs/markdown/plugin-meetings.constants.share.md +0 -11
  636. package/dist/docs/markdown/plugin-meetings.constants.share_peer_connection_name.md +0 -11
  637. package/dist/docs/markdown/plugin-meetings.constants.share_status.md +0 -16
  638. package/dist/docs/markdown/plugin-meetings.constants.share_stopped_reason.md +0 -14
  639. package/dist/docs/markdown/plugin-meetings.constants.sip_uri.md +0 -11
  640. package/dist/docs/markdown/plugin-meetings.constants.stats.md +0 -16
  641. package/dist/docs/markdown/plugin-meetings.constants.type.md +0 -11
  642. package/dist/docs/markdown/plugin-meetings.constants.use_uri_lookup_false.md +0 -11
  643. package/dist/docs/markdown/plugin-meetings.constants.uuid_reg.md +0 -11
  644. package/dist/docs/markdown/plugin-meetings.constants.valid_email_address.md +0 -11
  645. package/dist/docs/markdown/plugin-meetings.constants.valid_pin.md +0 -11
  646. package/dist/docs/markdown/plugin-meetings.constants.valid_pmr_address.md +0 -11
  647. package/dist/docs/markdown/plugin-meetings.constants.valid_pmr_link.md +0 -11
  648. package/dist/docs/markdown/plugin-meetings.constants.video.md +0 -11
  649. package/dist/docs/markdown/plugin-meetings.constants.video_input.md +0 -11
  650. package/dist/docs/markdown/plugin-meetings.constants.video_resolutions.md +0 -24
  651. package/dist/docs/markdown/plugin-meetings.constants.video_status.md +0 -11
  652. package/dist/docs/markdown/plugin-meetings.constants.wbxappapi_service.md +0 -11
  653. package/dist/docs/markdown/plugin-meetings.constants.webex_dot_com.md +0 -11
  654. package/dist/docs/markdown/plugin-meetings.constants.whiteboard.md +0 -11
  655. package/dist/docs/markdown/plugin-meetings.constants.www_dot.md +0 -11
  656. package/dist/docs/markdown/plugin-meetings.md +0 -28
  657. package/dist/docs/markdown/plugin-meetings.meeting.default._constructor_.md +0 -21
  658. package/dist/docs/markdown/plugin-meetings.meeting.default.acknowledge.md +0 -28
  659. package/dist/docs/markdown/plugin-meetings.meeting.default.addmedia.md +0 -28
  660. package/dist/docs/markdown/plugin-meetings.meeting.default.admit.md +0 -32
  661. package/dist/docs/markdown/plugin-meetings.meeting.default.attrs.md +0 -11
  662. package/dist/docs/markdown/plugin-meetings.meeting.default.audio.md +0 -11
  663. package/dist/docs/markdown/plugin-meetings.meeting.default.breakouts.md +0 -11
  664. package/dist/docs/markdown/plugin-meetings.meeting.default.callevents.md +0 -11
  665. package/dist/docs/markdown/plugin-meetings.meeting.default.cancelphoneinvite.md +0 -30
  666. package/dist/docs/markdown/plugin-meetings.meeting.default.canupdatemedia.md +0 -19
  667. package/dist/docs/markdown/plugin-meetings.meeting.default.changevideolayout.md +0 -38
  668. package/dist/docs/markdown/plugin-meetings.meeting.default.clearmeetingdata.md +0 -13
  669. package/dist/docs/markdown/plugin-meetings.meeting.default.closelocalshare.md +0 -21
  670. package/dist/docs/markdown/plugin-meetings.meeting.default.closelocalstream.md +0 -21
  671. package/dist/docs/markdown/plugin-meetings.meeting.default.closepeerconnections.md +0 -21
  672. package/dist/docs/markdown/plugin-meetings.meeting.default.closeremotestream.md +0 -26
  673. package/dist/docs/markdown/plugin-meetings.meeting.default.closeremotetracks.md +0 -19
  674. package/dist/docs/markdown/plugin-meetings.meeting.default.controlsoptionsmanager.md +0 -11
  675. package/dist/docs/markdown/plugin-meetings.meeting.default.conversationurl.md +0 -11
  676. package/dist/docs/markdown/plugin-meetings.meeting.default.correlationid.md +0 -11
  677. package/dist/docs/markdown/plugin-meetings.meeting.default.createmediaconnection.md +0 -26
  678. package/dist/docs/markdown/plugin-meetings.meeting.default.decline.md +0 -28
  679. package/dist/docs/markdown/plugin-meetings.meeting.default.deferjoin.md +0 -11
  680. package/dist/docs/markdown/plugin-meetings.meeting.default.destination.md +0 -11
  681. package/dist/docs/markdown/plugin-meetings.meeting.default.destinationtype.md +0 -11
  682. package/dist/docs/markdown/plugin-meetings.meeting.default.deviceurl.md +0 -11
  683. package/dist/docs/markdown/plugin-meetings.meeting.default.dialindevicestatus.md +0 -11
  684. package/dist/docs/markdown/plugin-meetings.meeting.default.dialinurl.md +0 -11
  685. package/dist/docs/markdown/plugin-meetings.meeting.default.dialoutdevicestatus.md +0 -11
  686. package/dist/docs/markdown/plugin-meetings.meeting.default.dialouturl.md +0 -11
  687. package/dist/docs/markdown/plugin-meetings.meeting.default.disconnectphoneaudio.md +0 -19
  688. package/dist/docs/markdown/plugin-meetings.meeting.default.endcallinitiatejoinreq.md +0 -11
  689. package/dist/docs/markdown/plugin-meetings.meeting.default.endjoinreqresp.md +0 -11
  690. package/dist/docs/markdown/plugin-meetings.meeting.default.endlocalsdpgenremotesdprecvdelay.md +0 -11
  691. package/dist/docs/markdown/plugin-meetings.meeting.default.endmeetingforall.md +0 -21
  692. package/dist/docs/markdown/plugin-meetings.meeting.default.fetchmeetinginfo.md +0 -29
  693. package/dist/docs/markdown/plugin-meetings.meeting.default.fetchmeetinginfotimeoutid.md +0 -11
  694. package/dist/docs/markdown/plugin-meetings.meeting.default.floorgrantpending.md +0 -11
  695. package/dist/docs/markdown/plugin-meetings.meeting.default.forwardevent.md +0 -29
  696. package/dist/docs/markdown/plugin-meetings.meeting.default.getanalyzermetricsprepayload.md +0 -32
  697. package/dist/docs/markdown/plugin-meetings.meeting.default.getcallinitiatejoinreq.md +0 -17
  698. package/dist/docs/markdown/plugin-meetings.meeting.default.getdevices.md +0 -13
  699. package/dist/docs/markdown/plugin-meetings.meeting.default.getjoinreqresp.md +0 -17
  700. package/dist/docs/markdown/plugin-meetings.meeting.default.getlocalsdpgenremotesdprecvdelay.md +0 -17
  701. package/dist/docs/markdown/plugin-meetings.meeting.default.getmediaconnectiondebugid.md +0 -15
  702. package/dist/docs/markdown/plugin-meetings.meeting.default.getmediastreams.md +0 -15
  703. package/dist/docs/markdown/plugin-meetings.meeting.default.getmembers.md +0 -21
  704. package/dist/docs/markdown/plugin-meetings.meeting.default.getsendingmediadelayduration.md +0 -24
  705. package/dist/docs/markdown/plugin-meetings.meeting.default.getsetupdelayduration.md +0 -24
  706. package/dist/docs/markdown/plugin-meetings.meeting.default.getsupporteddevices.md +0 -16
  707. package/dist/docs/markdown/plugin-meetings.meeting.default.gettotaljmt.md +0 -17
  708. package/dist/docs/markdown/plugin-meetings.meeting.default.guest.md +0 -11
  709. package/dist/docs/markdown/plugin-meetings.meeting.default.handledatachannelurlchange.md +0 -26
  710. package/dist/docs/markdown/plugin-meetings.meeting.default.handleroapfailure.md +0 -13
  711. package/dist/docs/markdown/plugin-meetings.meeting.default.hasjoinedonce.md +0 -11
  712. package/dist/docs/markdown/plugin-meetings.meeting.default.haswebsocketconnected.md +0 -11
  713. package/dist/docs/markdown/plugin-meetings.meeting.default.hostid.md +0 -11
  714. package/dist/docs/markdown/plugin-meetings.meeting.default.id.md +0 -11
  715. package/dist/docs/markdown/plugin-meetings.meeting.default.inmeetingactions.md +0 -11
  716. package/dist/docs/markdown/plugin-meetings.meeting.default.invite.md +0 -33
  717. package/dist/docs/markdown/plugin-meetings.meeting.default.isaudioconnected.md +0 -21
  718. package/dist/docs/markdown/plugin-meetings.meeting.default.isaudiomuted.md +0 -21
  719. package/dist/docs/markdown/plugin-meetings.meeting.default.isaudioself.md +0 -21
  720. package/dist/docs/markdown/plugin-meetings.meeting.default.islocalsharelive.md +0 -11
  721. package/dist/docs/markdown/plugin-meetings.meeting.default.ismultistream.md +0 -11
  722. package/dist/docs/markdown/plugin-meetings.meeting.default.isreactionssupported.md +0 -19
  723. package/dist/docs/markdown/plugin-meetings.meeting.default.isroapinprogress.md +0 -11
  724. package/dist/docs/markdown/plugin-meetings.meeting.default.issharing.md +0 -11
  725. package/dist/docs/markdown/plugin-meetings.meeting.default.istranscriptionsupported.md +0 -23
  726. package/dist/docs/markdown/plugin-meetings.meeting.default.isvideoconnected.md +0 -21
  727. package/dist/docs/markdown/plugin-meetings.meeting.default.isvideomuted.md +0 -21
  728. package/dist/docs/markdown/plugin-meetings.meeting.default.isvideoself.md +0 -21
  729. package/dist/docs/markdown/plugin-meetings.meeting.default.join.md +0 -28
  730. package/dist/docs/markdown/plugin-meetings.meeting.default.joinedwith.md +0 -11
  731. package/dist/docs/markdown/plugin-meetings.meeting.default.joinwithmedia.md +0 -36
  732. package/dist/docs/markdown/plugin-meetings.meeting.default.keepalivetimerid.md +0 -11
  733. package/dist/docs/markdown/plugin-meetings.meeting.default.lastvideolayoutinfo.md +0 -11
  734. package/dist/docs/markdown/plugin-meetings.meeting.default.leave.md +0 -31
  735. package/dist/docs/markdown/plugin-meetings.meeting.default.lockmeeting.md +0 -21
  736. package/dist/docs/markdown/plugin-meetings.meeting.default.locusid.md +0 -11
  737. package/dist/docs/markdown/plugin-meetings.meeting.default.locusinfo.md +0 -11
  738. package/dist/docs/markdown/plugin-meetings.meeting.default.locusurl.md +0 -11
  739. package/dist/docs/markdown/plugin-meetings.meeting.default.md +0 -227
  740. package/dist/docs/markdown/plugin-meetings.meeting.default.mediaconnections.md +0 -11
  741. package/dist/docs/markdown/plugin-meetings.meeting.default.mediaid.md +0 -11
  742. package/dist/docs/markdown/plugin-meetings.meeting.default.medianegotiatedevent.md +0 -13
  743. package/dist/docs/markdown/plugin-meetings.meeting.default.mediaproperties.md +0 -11
  744. package/dist/docs/markdown/plugin-meetings.meeting.default.mediarequestmanagers.md +0 -16
  745. package/dist/docs/markdown/plugin-meetings.meeting.default.meetingfinitestatemachine.md +0 -11
  746. package/dist/docs/markdown/plugin-meetings.meeting.default.meetinginfo.md +0 -11
  747. package/dist/docs/markdown/plugin-meetings.meeting.default.meetinginfofailurereason.md +0 -11
  748. package/dist/docs/markdown/plugin-meetings.meeting.default.meetingjoinurl.md +0 -11
  749. package/dist/docs/markdown/plugin-meetings.meeting.default.meetingnumber.md +0 -11
  750. package/dist/docs/markdown/plugin-meetings.meeting.default.meetingrequest.md +0 -11
  751. package/dist/docs/markdown/plugin-meetings.meeting.default.meetingstate.md +0 -11
  752. package/dist/docs/markdown/plugin-meetings.meeting.default.members.md +0 -11
  753. package/dist/docs/markdown/plugin-meetings.meeting.default.movefrom.md +0 -28
  754. package/dist/docs/markdown/plugin-meetings.meeting.default.moveto.md +0 -28
  755. package/dist/docs/markdown/plugin-meetings.meeting.default.mute.md +0 -29
  756. package/dist/docs/markdown/plugin-meetings.meeting.default.muteaudio.md +0 -21
  757. package/dist/docs/markdown/plugin-meetings.meeting.default.mutevideo.md +0 -21
  758. package/dist/docs/markdown/plugin-meetings.meeting.default.namespace.md +0 -11
  759. package/dist/docs/markdown/plugin-meetings.meeting.default.networkqualitymonitor.md +0 -11
  760. package/dist/docs/markdown/plugin-meetings.meeting.default.networkstatus.md +0 -11
  761. package/dist/docs/markdown/plugin-meetings.meeting.default.options.md +0 -11
  762. package/dist/docs/markdown/plugin-meetings.meeting.default.orgid.md +0 -11
  763. package/dist/docs/markdown/plugin-meetings.meeting.default.owner.md +0 -11
  764. package/dist/docs/markdown/plugin-meetings.meeting.default.parsemeetinginfo.md +0 -34
  765. package/dist/docs/markdown/plugin-meetings.meeting.default.partner.md +0 -11
  766. package/dist/docs/markdown/plugin-meetings.meeting.default.passwordstatus.md +0 -11
  767. package/dist/docs/markdown/plugin-meetings.meeting.default.pauserecording.md +0 -21
  768. package/dist/docs/markdown/plugin-meetings.meeting.default.permissiontoken.md +0 -11
  769. package/dist/docs/markdown/plugin-meetings.meeting.default.policy.md +0 -11
  770. package/dist/docs/markdown/plugin-meetings.meeting.default.processnextqueuedmediaupdate.md +0 -13
  771. package/dist/docs/markdown/plugin-meetings.meeting.default.publishtracks.md +0 -33
  772. package/dist/docs/markdown/plugin-meetings.meeting.default.queuedmediaupdates.md +0 -11
  773. package/dist/docs/markdown/plugin-meetings.meeting.default.receiveslotmanager.md +0 -11
  774. package/dist/docs/markdown/plugin-meetings.meeting.default.reconnect.md +0 -28
  775. package/dist/docs/markdown/plugin-meetings.meeting.default.reconnectionmanager.md +0 -11
  776. package/dist/docs/markdown/plugin-meetings.meeting.default.recording.md +0 -11
  777. package/dist/docs/markdown/plugin-meetings.meeting.default.recordingcontroller.md +0 -11
  778. package/dist/docs/markdown/plugin-meetings.meeting.default.refreshcaptcha.md +0 -21
  779. package/dist/docs/markdown/plugin-meetings.meeting.default.remotemediamanager.md +0 -11
  780. package/dist/docs/markdown/plugin-meetings.meeting.default.remove.md +0 -28
  781. package/dist/docs/markdown/plugin-meetings.meeting.default.requiredcaptcha.md +0 -11
  782. package/dist/docs/markdown/plugin-meetings.meeting.default.resource.md +0 -11
  783. package/dist/docs/markdown/plugin-meetings.meeting.default.resourceid.md +0 -11
  784. package/dist/docs/markdown/plugin-meetings.meeting.default.resourceurl.md +0 -11
  785. package/dist/docs/markdown/plugin-meetings.meeting.default.resumerecording.md +0 -21
  786. package/dist/docs/markdown/plugin-meetings.meeting.default.roap.md +0 -11
  787. package/dist/docs/markdown/plugin-meetings.meeting.default.roapseq.md +0 -11
  788. package/dist/docs/markdown/plugin-meetings.meeting.default.selfid.md +0 -11
  789. package/dist/docs/markdown/plugin-meetings.meeting.default.senddtmf.md +0 -28
  790. package/dist/docs/markdown/plugin-meetings.meeting.default.sendreaction.md +0 -29
  791. package/dist/docs/markdown/plugin-meetings.meeting.default.setdisallowunmute.md +0 -26
  792. package/dist/docs/markdown/plugin-meetings.meeting.default.setendcallinitiatejoinreq.md +0 -17
  793. package/dist/docs/markdown/plugin-meetings.meeting.default.setendjoinreqresp.md +0 -17
  794. package/dist/docs/markdown/plugin-meetings.meeting.default.setendlocalsdpgenremotesdprecvdelay.md +0 -17
  795. package/dist/docs/markdown/plugin-meetings.meeting.default.setendsendingmediadelay.md +0 -24
  796. package/dist/docs/markdown/plugin-meetings.meeting.default.setendsetupdelay.md +0 -24
  797. package/dist/docs/markdown/plugin-meetings.meeting.default.setlocalsharetrack.md +0 -28
  798. package/dist/docs/markdown/plugin-meetings.meeting.default.setlocaltracks.md +0 -28
  799. package/dist/docs/markdown/plugin-meetings.meeting.default.setlocalvideoquality.md +0 -26
  800. package/dist/docs/markdown/plugin-meetings.meeting.default.setmeetingquality.md +0 -31
  801. package/dist/docs/markdown/plugin-meetings.meeting.default.setmercurylistener.md +0 -21
  802. package/dist/docs/markdown/plugin-meetings.meeting.default.setmuteall.md +0 -28
  803. package/dist/docs/markdown/plugin-meetings.meeting.default.setmuteonentry.md +0 -26
  804. package/dist/docs/markdown/plugin-meetings.meeting.default.setremotequalitylevel.md +0 -26
  805. package/dist/docs/markdown/plugin-meetings.meeting.default.setsipuri.md +0 -26
  806. package/dist/docs/markdown/plugin-meetings.meeting.default.setstartcallinitiatejoinreq.md +0 -17
  807. package/dist/docs/markdown/plugin-meetings.meeting.default.setstartjoinreqresp.md +0 -17
  808. package/dist/docs/markdown/plugin-meetings.meeting.default.setstartlocalsdpgenremotesdprecvdelay.md +0 -17
  809. package/dist/docs/markdown/plugin-meetings.meeting.default.setstartsendingmediadelay.md +0 -24
  810. package/dist/docs/markdown/plugin-meetings.meeting.default.setstartsetupdelay.md +0 -24
  811. package/dist/docs/markdown/plugin-meetings.meeting.default.setupbreakoutslistener.md +0 -19
  812. package/dist/docs/markdown/plugin-meetings.meeting.default.setupmediaconnectionlisteners.md +0 -11
  813. package/dist/docs/markdown/plugin-meetings.meeting.default.setupstatsanalyzereventhandlers.md +0 -13
  814. package/dist/docs/markdown/plugin-meetings.meeting.default.sharescreen.md +0 -32
  815. package/dist/docs/markdown/plugin-meetings.meeting.default.sharestatus.md +0 -11
  816. package/dist/docs/markdown/plugin-meetings.meeting.default.sipuri.md +0 -11
  817. package/dist/docs/markdown/plugin-meetings.meeting.default.startcallinitiatejoinreq.md +0 -11
  818. package/dist/docs/markdown/plugin-meetings.meeting.default.startjoinreqresp.md +0 -11
  819. package/dist/docs/markdown/plugin-meetings.meeting.default.startkeepalive.md +0 -13
  820. package/dist/docs/markdown/plugin-meetings.meeting.default.startlocalsdpgenremotesdprecvdelay.md +0 -11
  821. package/dist/docs/markdown/plugin-meetings.meeting.default.startrecording.md +0 -21
  822. package/dist/docs/markdown/plugin-meetings.meeting.default.startwhiteboardshare.md +0 -29
  823. package/dist/docs/markdown/plugin-meetings.meeting.default.state.md +0 -11
  824. package/dist/docs/markdown/plugin-meetings.meeting.default.statsanalyzer.md +0 -11
  825. package/dist/docs/markdown/plugin-meetings.meeting.default.stopkeepalive.md +0 -13
  826. package/dist/docs/markdown/plugin-meetings.meeting.default.stopreceivingtranscription.md +0 -19
  827. package/dist/docs/markdown/plugin-meetings.meeting.default.stoprecording.md +0 -21
  828. package/dist/docs/markdown/plugin-meetings.meeting.default.stopshare.md +0 -28
  829. package/dist/docs/markdown/plugin-meetings.meeting.default.stopwhiteboardshare.md +0 -28
  830. package/dist/docs/markdown/plugin-meetings.meeting.default.togglereactions.md +0 -28
  831. package/dist/docs/markdown/plugin-meetings.meeting.default.transcription.md +0 -11
  832. package/dist/docs/markdown/plugin-meetings.meeting.default.transfer.md +0 -29
  833. package/dist/docs/markdown/plugin-meetings.meeting.default.type.md +0 -11
  834. package/dist/docs/markdown/plugin-meetings.meeting.default.unlockmeeting.md +0 -21
  835. package/dist/docs/markdown/plugin-meetings.meeting.default.unmuteaudio.md +0 -21
  836. package/dist/docs/markdown/plugin-meetings.meeting.default.unmutevideo.md +0 -21
  837. package/dist/docs/markdown/plugin-meetings.meeting.default.unpublishtracks.md +0 -26
  838. package/dist/docs/markdown/plugin-meetings.meeting.default.unsetlocalsharetrack.md +0 -21
  839. package/dist/docs/markdown/plugin-meetings.meeting.default.unsetlocalvideotrack.md +0 -21
  840. package/dist/docs/markdown/plugin-meetings.meeting.default.unsetpeerconnections.md +0 -21
  841. package/dist/docs/markdown/plugin-meetings.meeting.default.unsetremotestream.md +0 -26
  842. package/dist/docs/markdown/plugin-meetings.meeting.default.unsetremotetracks.md +0 -19
  843. package/dist/docs/markdown/plugin-meetings.meeting.default.updateaudio.md +0 -34
  844. package/dist/docs/markdown/plugin-meetings.meeting.default.updatellmconnection.md +0 -19
  845. package/dist/docs/markdown/plugin-meetings.meeting.default.updatemedia.md +0 -32
  846. package/dist/docs/markdown/plugin-meetings.meeting.default.updatemediaconnections.md +0 -11
  847. package/dist/docs/markdown/plugin-meetings.meeting.default.updateshare.md +0 -35
  848. package/dist/docs/markdown/plugin-meetings.meeting.default.updatevideo.md +0 -34
  849. package/dist/docs/markdown/plugin-meetings.meeting.default.uploadlogs.md +0 -28
  850. package/dist/docs/markdown/plugin-meetings.meeting.default.usephoneaudio.md +0 -28
  851. package/dist/docs/markdown/plugin-meetings.meeting.default.userid.md +0 -11
  852. package/dist/docs/markdown/plugin-meetings.meeting.default.verifypassword.md +0 -35
  853. package/dist/docs/markdown/plugin-meetings.meeting.default.video.md +0 -11
  854. package/dist/docs/markdown/plugin-meetings.meeting.default.wirelessshare.md +0 -11
  855. package/dist/docs/markdown/plugin-meetings.meeting.md +0 -18
  856. package/dist/docs/markdown/plugin-meetings.meeting.media_update_type.md +0 -17
  857. package/dist/docs/markdown/plugin-meetings.meetings._constructor_.md +0 -22
  858. package/dist/docs/markdown/plugin-meetings.meetings.create.md +0 -30
  859. package/dist/docs/markdown/plugin-meetings.meetings.fetchuserpreferredwebexsite.md +0 -19
  860. package/dist/docs/markdown/plugin-meetings.meetings.geohintinfo.md +0 -11
  861. package/dist/docs/markdown/plugin-meetings.meetings.getallmeetings.md +0 -31
  862. package/dist/docs/markdown/plugin-meetings.meetings.getgeohint.md +0 -19
  863. package/dist/docs/markdown/plugin-meetings.meetings.getlogger.md +0 -19
  864. package/dist/docs/markdown/plugin-meetings.meetings.getmeetingbytype.md +0 -29
  865. package/dist/docs/markdown/plugin-meetings.meetings.getpersonalmeetingroom.md +0 -21
  866. package/dist/docs/markdown/plugin-meetings.meetings.getreachability.md +0 -21
  867. package/dist/docs/markdown/plugin-meetings.meetings.getscheduledmeetings.md +0 -19
  868. package/dist/docs/markdown/plugin-meetings.meetings.loggerrequest.md +0 -11
  869. package/dist/docs/markdown/plugin-meetings.meetings.md +0 -57
  870. package/dist/docs/markdown/plugin-meetings.meetings.media.md +0 -11
  871. package/dist/docs/markdown/plugin-meetings.meetings.meetingcollection.md +0 -11
  872. package/dist/docs/markdown/plugin-meetings.meetings.meetinginfo.md +0 -11
  873. package/dist/docs/markdown/plugin-meetings.meetings.namespace.md +0 -11
  874. package/dist/docs/markdown/plugin-meetings.meetings.personalmeetingroom.md +0 -11
  875. package/dist/docs/markdown/plugin-meetings.meetings.preferredwebexsite.md +0 -11
  876. package/dist/docs/markdown/plugin-meetings.meetings.reachability.md +0 -11
  877. package/dist/docs/markdown/plugin-meetings.meetings.register.md +0 -21
  878. package/dist/docs/markdown/plugin-meetings.meetings.registered.md +0 -11
  879. package/dist/docs/markdown/plugin-meetings.meetings.request.md +0 -11
  880. package/dist/docs/markdown/plugin-meetings.meetings.setreachability.md +0 -21
  881. package/dist/docs/markdown/plugin-meetings.meetings.startreachability.md +0 -21
  882. package/dist/docs/markdown/plugin-meetings.meetings.syncmeetings.md +0 -21
  883. package/dist/docs/markdown/plugin-meetings.meetings.unregister.md +0 -21
  884. package/dist/docs/markdown/plugin-meetings.meetings.uploadlogs.md +0 -34
  885. package/dist/docs/markdown/plugin-meetings.reactions.md +0 -13
  886. package/dist/docs/markdown/plugin-meetings.reactions.reactions.md +0 -11
  887. package/dist/docs/markdown/plugin-meetings.reactions.skintones.md +0 -11
  888. package/dist/docs/markdown/plugin-meetings.remotemedia.getmaxfs.md +0 -26
  889. package/dist/docs/markdown/plugin-meetings.remotemedia.md +0 -31
  890. package/dist/docs/markdown/plugin-meetings.remotemedia.remotemedia._constructor_.md +0 -22
  891. package/dist/docs/markdown/plugin-meetings.remotemedia.remotemedia.csi.md +0 -13
  892. package/dist/docs/markdown/plugin-meetings.remotemedia.remotemedia.id.md +0 -11
  893. package/dist/docs/markdown/plugin-meetings.remotemedia.remotemedia.md +0 -40
  894. package/dist/docs/markdown/plugin-meetings.remotemedia.remotemedia.mediatype.md +0 -13
  895. package/dist/docs/markdown/plugin-meetings.remotemedia.remotemedia.memberid.md +0 -13
  896. package/dist/docs/markdown/plugin-meetings.remotemedia.remotemedia.setsizehint.md +0 -25
  897. package/dist/docs/markdown/plugin-meetings.remotemedia.remotemedia.sourcestate.md +0 -13
  898. package/dist/docs/markdown/plugin-meetings.remotemedia.remotemedia.stream.md +0 -13
  899. package/dist/docs/markdown/plugin-meetings.remotemedia.remotemediaevents.md +0 -14
  900. package/dist/docs/markdown/plugin-meetings.remotemedia.remotemediaid.md +0 -11
  901. package/dist/docs/markdown/plugin-meetings.remotemedia.remotevideoresolution.md +0 -11
  902. package/dist/docs/markdown/plugin-meetings.remotemediagroup.md +0 -12
  903. package/dist/docs/markdown/plugin-meetings.remotemediagroup.remotemediagroup._constructor_.md +0 -24
  904. package/dist/docs/markdown/plugin-meetings.remotemediagroup.remotemediagroup.getremotemedia.md +0 -26
  905. package/dist/docs/markdown/plugin-meetings.remotemediagroup.remotemediagroup.includes.md +0 -27
  906. package/dist/docs/markdown/plugin-meetings.remotemediagroup.remotemediagroup.ispinned.md +0 -22
  907. package/dist/docs/markdown/plugin-meetings.remotemediagroup.remotemediagroup.md +0 -28
  908. package/dist/docs/markdown/plugin-meetings.remotemediagroup.remotemediagroup.pin.md +0 -25
  909. package/dist/docs/markdown/plugin-meetings.remotemediagroup.remotemediagroup.unpin.md +0 -24
  910. package/dist/docs/markdown/plugin-meetings.triggerproxy.md +0 -11
  911. package/dist/docs/metadata/index.api.json +0 -14144
  912. package/dist/docs/metadata/index.api.md +0 -2075
  913. package/dist/docs/metadata/index.d.ts +0 -5594
  914. package/dist/meeting/effectsState.d.ts +0 -42
  915. package/dist/meeting/effectsState.js +0 -260
  916. package/dist/meeting/effectsState.js.map +0 -1
  917. package/dist/metrics/config.d.ts +0 -169
  918. package/dist/metrics/config.js +0 -291
  919. package/dist/metrics/config.js.map +0 -1
  920. package/dist/peer-connection-manager/index.d.ts +0 -6
  921. package/dist/peer-connection-manager/index.js +0 -671
  922. package/dist/peer-connection-manager/index.js.map +0 -1
  923. package/dist/peer-connection-manager/util.d.ts +0 -6
  924. package/dist/peer-connection-manager/util.js +0 -110
  925. package/dist/peer-connection-manager/util.js.map +0 -1
  926. package/dist/plugin-meetings.d.ts +0 -5399
  927. package/dist/roap/collection.d.ts +0 -10
  928. package/dist/roap/collection.js +0 -63
  929. package/dist/roap/collection.js.map +0 -1
  930. package/dist/roap/handler.d.ts +0 -47
  931. package/dist/roap/handler.js +0 -279
  932. package/dist/roap/handler.js.map +0 -1
  933. package/dist/roap/state.d.ts +0 -9
  934. package/dist/roap/state.js +0 -127
  935. package/dist/roap/state.js.map +0 -1
  936. package/dist/roap/util.d.ts +0 -2
  937. package/dist/roap/util.js +0 -76
  938. package/dist/roap/util.js.map +0 -1
  939. package/dist/types/common/browser-detection.d.ts +0 -9
  940. package/dist/types/common/collection.d.ts +0 -48
  941. package/dist/types/common/config.d.ts +0 -2
  942. package/dist/types/common/errors/captcha-error.d.ts +0 -15
  943. package/dist/types/common/errors/intent-to-join.d.ts +0 -16
  944. package/dist/types/common/errors/join-meeting.d.ts +0 -17
  945. package/dist/types/common/errors/media.d.ts +0 -15
  946. package/dist/types/common/errors/parameter.d.ts +0 -15
  947. package/dist/types/common/errors/password-error.d.ts +0 -15
  948. package/dist/types/common/errors/reconnection-in-progress.d.ts +0 -9
  949. package/dist/types/common/errors/reconnection.d.ts +0 -15
  950. package/dist/types/common/errors/stats.d.ts +0 -15
  951. package/dist/types/common/errors/webex-errors.d.ts +0 -69
  952. package/dist/types/common/errors/webex-meetings-error.d.ts +0 -20
  953. package/dist/types/common/events/events-scope.d.ts +0 -17
  954. package/dist/types/common/events/events.d.ts +0 -12
  955. package/dist/types/common/events/trigger-proxy.d.ts +0 -2
  956. package/dist/types/common/events/util.d.ts +0 -2
  957. package/dist/types/common/logs/logger-config.d.ts +0 -2
  958. package/dist/types/common/logs/logger-proxy.d.ts +0 -2
  959. package/dist/types/common/logs/request.d.ts +0 -34
  960. package/dist/types/common/queue.d.ts +0 -32
  961. package/dist/types/config.d.ts +0 -78
  962. package/dist/types/constants.d.ts +0 -957
  963. package/dist/types/controls-options-manager/constants.d.ts +0 -4
  964. package/dist/types/controls-options-manager/enums.d.ts +0 -13
  965. package/dist/types/controls-options-manager/index.d.ts +0 -136
  966. package/dist/types/controls-options-manager/util.d.ts +0 -1
  967. package/dist/types/index.d.ts +0 -7
  968. package/dist/types/locus-info/controlsUtils.d.ts +0 -2
  969. package/dist/types/locus-info/embeddedAppsUtils.d.ts +0 -2
  970. package/dist/types/locus-info/fullState.d.ts +0 -2
  971. package/dist/types/locus-info/hostUtils.d.ts +0 -2
  972. package/dist/types/locus-info/index.d.ts +0 -277
  973. package/dist/types/locus-info/infoUtils.d.ts +0 -2
  974. package/dist/types/locus-info/mediaSharesUtils.d.ts +0 -2
  975. package/dist/types/locus-info/parser.d.ts +0 -212
  976. package/dist/types/locus-info/selfUtils.d.ts +0 -2
  977. package/dist/types/media/index.d.ts +0 -32
  978. package/dist/types/media/properties.d.ts +0 -108
  979. package/dist/types/media/util.d.ts +0 -2
  980. package/dist/types/mediaQualityMetrics/config.d.ts +0 -365
  981. package/dist/types/meeting/effectsState.d.ts +0 -42
  982. package/dist/types/meeting/in-meeting-actions.d.ts +0 -105
  983. package/dist/types/meeting/index.d.ts +0 -1724
  984. package/dist/types/meeting/muteState.d.ts +0 -185
  985. package/dist/types/meeting/request.d.ts +0 -271
  986. package/dist/types/meeting/state.d.ts +0 -9
  987. package/dist/types/meeting/util.d.ts +0 -2
  988. package/dist/types/meeting-info/collection.d.ts +0 -20
  989. package/dist/types/meeting-info/index.d.ts +0 -57
  990. package/dist/types/meeting-info/meeting-info-v2.d.ts +0 -111
  991. package/dist/types/meeting-info/request.d.ts +0 -22
  992. package/dist/types/meeting-info/util.d.ts +0 -2
  993. package/dist/types/meeting-info/utilv2.d.ts +0 -2
  994. package/dist/types/meetings/collection.d.ts +0 -31
  995. package/dist/types/meetings/index.d.ts +0 -316
  996. package/dist/types/meetings/request.d.ts +0 -27
  997. package/dist/types/meetings/util.d.ts +0 -18
  998. package/dist/types/member/index.d.ts +0 -156
  999. package/dist/types/member/util.d.ts +0 -2
  1000. package/dist/types/members/collection.d.ts +0 -29
  1001. package/dist/types/members/index.d.ts +0 -353
  1002. package/dist/types/members/request.d.ts +0 -69
  1003. package/dist/types/members/util.d.ts +0 -2
  1004. package/dist/types/metrics/config.d.ts +0 -171
  1005. package/dist/types/metrics/constants.d.ts +0 -54
  1006. package/dist/types/metrics/index.d.ts +0 -152
  1007. package/dist/types/networkQualityMonitor/index.d.ts +0 -70
  1008. package/dist/types/personal-meeting-room/index.d.ts +0 -47
  1009. package/dist/types/personal-meeting-room/request.d.ts +0 -14
  1010. package/dist/types/personal-meeting-room/util.d.ts +0 -2
  1011. package/dist/types/reachability/index.d.ts +0 -152
  1012. package/dist/types/reachability/request.d.ts +0 -37
  1013. package/dist/types/reactions/reactions.d.ts +0 -4
  1014. package/dist/types/reactions/reactions.type.d.ts +0 -52
  1015. package/dist/types/reconnection-manager/index.d.ts +0 -126
  1016. package/dist/types/recording-controller/enums.d.ts +0 -7
  1017. package/dist/types/recording-controller/index.d.ts +0 -193
  1018. package/dist/types/recording-controller/util.d.ts +0 -13
  1019. package/dist/types/roap/index.d.ts +0 -77
  1020. package/dist/types/roap/request.d.ts +0 -38
  1021. package/dist/types/roap/turnDiscovery.d.ts +0 -74
  1022. package/dist/types/statsAnalyzer/global.d.ts +0 -36
  1023. package/dist/types/statsAnalyzer/index.d.ts +0 -200
  1024. package/dist/types/statsAnalyzer/mqaUtil.d.ts +0 -24
  1025. package/dist/types/transcription/index.d.ts +0 -64
  1026. package/dist/types/tsdoc-metadata.json +0 -11
  1027. package/src/metrics/config.ts +0 -487
  1028. /package/dist/{types/breakouts → breakouts}/breakout.d.ts +0 -0
  1029. /package/dist/{types/breakouts → breakouts}/collection.d.ts +0 -0
  1030. /package/dist/{types/breakouts → breakouts}/edit-lock-error.d.ts +0 -0
  1031. /package/dist/{types/breakouts → breakouts}/index.d.ts +0 -0
  1032. /package/dist/{types/breakouts → breakouts}/request.d.ts +0 -0
  1033. /package/dist/{types/meeting → meeting}/request.type.d.ts +0 -0
  1034. /package/dist/{types/multistream → multistream}/receiveSlotManager.d.ts +0 -0
  1035. /package/dist/{types/reactions → reactions}/constants.d.ts +0 -0
@@ -1,10 +1,7 @@
1
- import {isEmpty} from 'lodash';
2
- import {LocalCameraTrack, LocalMicrophoneTrack} from '@webex/media-helpers';
1
+ import {LocalCameraStream, LocalMicrophoneStream} from '@webex/media-helpers';
3
2
 
3
+ import {cloneDeep} from 'lodash';
4
4
  import {MeetingNotActiveError, UserNotJoinedError} from '../common/errors/webex-errors';
5
- import Metrics from '../metrics';
6
- import {eventType, trigger} from '../metrics/config';
7
- import Media from '../media';
8
5
  import LoggerProxy from '../common/logs/logger-proxy';
9
6
  import {
10
7
  INTENT_TO_JOIN,
@@ -14,514 +11,788 @@ import {
14
11
  PASSWORD_STATUS,
15
12
  DISPLAY_HINTS,
16
13
  FULL_STATE,
14
+ SELF_POLICY,
15
+ EVENT_TRIGGERS,
16
+ LOCAL_SHARE_ERRORS,
17
+ IP_VERSION,
17
18
  } from '../constants';
19
+ import BrowserDetection from '../common/browser-detection';
18
20
  import IntentToJoinError from '../common/errors/intent-to-join';
19
21
  import JoinMeetingError from '../common/errors/join-meeting';
20
22
  import ParameterError from '../common/errors/parameter';
21
23
  import PermissionError from '../common/errors/permission';
22
24
  import PasswordError from '../common/errors/password-error';
23
25
  import CaptchaError from '../common/errors/captcha-error';
26
+ import Trigger from '../common/events/trigger-proxy';
27
+
28
+ const MeetingUtil = {
29
+ parseLocusJoin: (response) => {
30
+ const parsed: any = {};
31
+
32
+ // First todo: add check for existance
33
+ parsed.locus = response.body.locus;
34
+ parsed.mediaConnections = response.body.mediaConnections;
35
+ parsed.locusUrl = parsed.locus.url;
36
+ parsed.locusId = parsed.locus.url.split('/').pop();
37
+ parsed.selfId = parsed.locus.self.id;
38
+
39
+ // we need mediaId before making roap calls
40
+ parsed.mediaConnections.forEach((mediaConnection) => {
41
+ if (mediaConnection.mediaId) {
42
+ parsed.mediaId = mediaConnection.mediaId;
43
+ }
44
+ });
45
+
46
+ return parsed;
47
+ },
48
+
49
+ remoteUpdateAudioVideo: (meeting, audioMuted?: boolean, videoMuted?: boolean) => {
50
+ const webex = meeting.getWebexObject();
51
+ if (!meeting) {
52
+ return Promise.reject(new ParameterError('You need a meeting object.'));
53
+ }
24
54
 
25
- const MeetingUtil: any = {};
55
+ if (!meeting.locusMediaRequest) {
56
+ return Promise.reject(
57
+ new ParameterError(
58
+ 'You need a meeting with a media connection, call Meeting.addMedia() first.'
59
+ )
60
+ );
61
+ }
26
62
 
27
- MeetingUtil.parseLocusJoin = (response) => {
28
- const parsed: any = {};
63
+ // @ts-ignore
64
+ webex.internal.newMetrics.submitClientEvent({
65
+ name: 'client.locus.media.request',
66
+ options: {meetingId: meeting.id},
67
+ });
29
68
 
30
- // First todo: add check for existance
31
- parsed.locus = response.body.locus;
32
- parsed.mediaConnections = response.body.mediaConnections;
33
- parsed.locusUrl = parsed.locus.url;
34
- parsed.locusId = parsed.locus.url.split('/').pop();
35
- parsed.selfId = parsed.locus.self.id;
69
+ return meeting.locusMediaRequest
70
+ .send({
71
+ type: 'LocalMute',
72
+ selfUrl: meeting.selfUrl,
73
+ mediaId: meeting.mediaId,
74
+ sequence: meeting.locusInfo.sequence,
75
+ muteOptions: {
76
+ audioMuted,
77
+ videoMuted,
78
+ },
79
+ })
80
+ .then((response) => {
81
+ // @ts-ignore
82
+ webex.internal.newMetrics.submitClientEvent({
83
+ name: 'client.locus.media.response',
84
+ options: {meetingId: meeting.id},
85
+ });
36
86
 
37
- // we need mediaId before making roap calls
38
- parsed.mediaConnections.forEach((mediaConnection) => {
39
- if (mediaConnection.mediaId) {
40
- parsed.mediaId = mediaConnection.mediaId;
87
+ return response?.body?.locus;
88
+ });
89
+ },
90
+
91
+ hasOwner: (info) => info && info.owner,
92
+
93
+ isOwnerSelf: (owner, selfId) => owner === selfId,
94
+
95
+ isPinOrGuest: (err) => err?.body?.errorCode && INTENT_TO_JOIN.includes(err.body.errorCode),
96
+
97
+ /**
98
+ * Returns the current state of knowledge about whether we are on an ipv4-only or ipv6-only or mixed (ipv4 and ipv6) network.
99
+ * The return value matches the possible values of "ipver" parameter used by the backend APIs.
100
+ *
101
+ * @param {Object} webex webex instance
102
+ * @returns {IP_VERSION|undefined} ipver value to be passed to the backend APIs or undefined if we should not pass any value to the backend
103
+ */
104
+ getIpVersion(webex: any): IP_VERSION | undefined {
105
+ const {supportsIpV4, supportsIpV6} = webex.internal.device.ipNetworkDetector;
106
+
107
+ if (BrowserDetection().isBrowser('firefox')) {
108
+ // our ipv6 solution relies on FQDN ICE candidates, but Firefox doesn't support them,
109
+ // see https://bugzilla.mozilla.org/show_bug.cgi?id=1713128
110
+ // so for Firefox we don't want the backend to activate the "ipv6 feature"
111
+ return undefined;
41
112
  }
42
- });
43
113
 
44
- return parsed;
45
- };
114
+ if (supportsIpV4 && supportsIpV6) {
115
+ return IP_VERSION.ipv4_and_ipv6;
116
+ }
117
+
118
+ if (supportsIpV4) {
119
+ return IP_VERSION.only_ipv4;
120
+ }
46
121
 
47
- MeetingUtil.remoteUpdateAudioVideo = (audioMuted, videoMuted, meeting) => {
48
- if (!meeting) {
49
- return Promise.reject(new ParameterError('You need a meeting object.'));
50
- }
51
- const localMedias = Media.generateLocalMedias(meeting.mediaId, audioMuted, videoMuted);
122
+ if (supportsIpV6) {
123
+ return IP_VERSION.only_ipv6;
124
+ }
52
125
 
53
- if (isEmpty(localMedias)) {
54
- return Promise.reject(
55
- new ParameterError('You need a media id on the meeting to change remote audio.')
56
- );
57
- }
126
+ return IP_VERSION.unknown;
127
+ },
128
+
129
+ joinMeeting: (meeting, options) => {
130
+ if (!meeting) {
131
+ return Promise.reject(new ParameterError('You need a meeting object.'));
132
+ }
133
+ const webex = meeting.getWebexObject();
58
134
 
59
- Metrics.postEvent({event: eventType.MEDIA_REQUEST, meeting});
135
+ // @ts-ignore
136
+ webex.internal.newMetrics.submitClientEvent({
137
+ name: 'client.locus.join.request',
138
+ options: {meetingId: meeting.id},
139
+ });
140
+
141
+ // eslint-disable-next-line no-warning-comments
142
+ // TODO: check if the meeting is in JOINING state
143
+ // if Joining state termintate the request as user might click multiple times
144
+ return meeting.meetingRequest
145
+ .joinMeeting({
146
+ inviteeAddress: meeting.meetingJoinUrl || meeting.sipUri,
147
+ meetingNumber: meeting.meetingNumber,
148
+ deviceUrl: meeting.deviceUrl,
149
+ locusUrl: meeting.locusUrl,
150
+ locusClusterUrl: meeting.meetingInfo?.locusClusterUrl,
151
+ correlationId: meeting.correlationId,
152
+ roapMessage: options.roapMessage,
153
+ permissionToken: meeting.permissionToken,
154
+ resourceId: options.resourceId || null,
155
+ moderator: options.moderator,
156
+ pin: options.pin,
157
+ moveToResource: options.moveToResource,
158
+ preferTranscoding: !meeting.isMultistream,
159
+ asResourceOccupant: options.asResourceOccupant,
160
+ breakoutsSupported: options.breakoutsSupported,
161
+ locale: options.locale,
162
+ deviceCapabilities: options.deviceCapabilities,
163
+ liveAnnotationSupported: options.liveAnnotationSupported,
164
+ ipVersion: MeetingUtil.getIpVersion(meeting.getWebexObject()),
165
+ })
166
+ .then((res) => {
167
+ // @ts-ignore
168
+ webex.internal.newMetrics.submitClientEvent({
169
+ name: 'client.locus.join.response',
170
+ payload: {
171
+ trigger: 'loci-update',
172
+ identifiers: {
173
+ trackingId: res.headers.trackingid,
174
+ },
175
+ },
176
+ options: {
177
+ meetingId: meeting.id,
178
+ mediaConnections: res.body.mediaConnections,
179
+ },
180
+ });
60
181
 
61
- return meeting.meetingRequest
62
- .remoteAudioVideoToggle({
182
+ return MeetingUtil.parseLocusJoin(res);
183
+ });
184
+ },
185
+
186
+ cleanUp: (meeting) => {
187
+ meeting.breakouts.cleanUp();
188
+ meeting.simultaneousInterpretation.cleanUp();
189
+
190
+ // make sure we send last metrics before we close the peerconnection
191
+ const stopStatsAnalyzer = meeting.statsAnalyzer
192
+ ? meeting.statsAnalyzer.stopAnalyzer()
193
+ : Promise.resolve();
194
+
195
+ return stopStatsAnalyzer
196
+ .then(() => meeting.closeRemoteStreams())
197
+ .then(() => meeting.closePeerConnections())
198
+ .then(() => {
199
+ meeting.cleanupLocalStreams();
200
+ meeting.unsetRemoteStreams();
201
+ meeting.unsetPeerConnections();
202
+ meeting.reconnectionManager.cleanUp();
203
+ })
204
+ .then(() => meeting.stopKeepAlive())
205
+ .then(() => {
206
+ if (meeting.config?.enableAutomaticLLM) {
207
+ meeting.updateLLMConnection();
208
+ }
209
+ });
210
+ },
211
+
212
+ disconnectPhoneAudio: (meeting, phoneUrl) => {
213
+ if (meeting.meetingState === FULL_STATE.INACTIVE) {
214
+ return Promise.reject(new MeetingNotActiveError());
215
+ }
216
+
217
+ const options = {
63
218
  locusUrl: meeting.locusUrl,
64
219
  selfId: meeting.selfId,
65
- localMedias,
66
- deviceUrl: meeting.deviceUrl,
67
220
  correlationId: meeting.correlationId,
68
- preferTranscoding: !meeting.isMultistream,
69
- })
70
- .then((response) => {
71
- Metrics.postEvent({event: eventType.MEDIA_RESPONSE, meeting});
221
+ phoneUrl,
222
+ };
72
223
 
73
- return response.body.locus;
224
+ return meeting.meetingRequest.disconnectPhoneAudio(options).catch((err) => {
225
+ LoggerProxy.logger.error(
226
+ `Meeting:util#disconnectPhoneAudio --> An error occured while disconnecting phone audio in meeting ${meeting.id}, error: ${err}`
227
+ );
228
+
229
+ return Promise.reject(err);
74
230
  });
75
- };
231
+ },
232
+
233
+ /**
234
+ * Returns options for leaving a meeting.
235
+ * @param {any} meeting
236
+ * @param {any} options
237
+ * @returns {any} leave options
238
+ */
239
+ prepareLeaveMeetingOptions: (meeting, options: any = {}) => {
240
+ const defaultOptions = {
241
+ locusUrl: meeting.locusUrl,
242
+ selfId: meeting.selfId,
243
+ correlationId: meeting.correlationId,
244
+ resourceId: meeting.resourceId,
245
+ deviceUrl: meeting.deviceUrl,
246
+ };
247
+
248
+ return {...defaultOptions, ...options};
249
+ },
250
+
251
+ // by default will leave on meeting's resourceId
252
+ // if you explicity want it not to leave on resource id, pass
253
+ // {resourceId: null}
254
+ // TODO: chris, you can modify this however you want
255
+ leaveMeeting: (meeting, options: any = {}) => {
256
+ if (meeting.meetingState === FULL_STATE.INACTIVE) {
257
+ // TODO: clean up if the meeting is already inactive
258
+ return Promise.reject(new MeetingNotActiveError());
259
+ }
76
260
 
77
- MeetingUtil.hasOwner = (info) => info && info.owner;
261
+ if (MeetingUtil.isUserInLeftState(meeting.locusInfo)) {
262
+ return Promise.reject(new UserNotJoinedError());
263
+ }
78
264
 
79
- MeetingUtil.isOwnerSelf = (owner, selfId) => owner === selfId;
265
+ const leaveOptions = MeetingUtil.prepareLeaveMeetingOptions(meeting, options);
266
+
267
+ return meeting.meetingRequest
268
+ .leaveMeeting(leaveOptions)
269
+ .then(() => {
270
+ if (options.moveMeeting) {
271
+ return Promise.resolve();
272
+ }
273
+
274
+ return MeetingUtil.cleanUp(meeting);
275
+ })
276
+ .catch((err) => {
277
+ // TODO: If the meeting state comes as LEFT or INACTIVE as response then
278
+ // 1) on leave clean up the meeting or simply do a sync on the meeting
279
+ // 2) If the error says meeting is inactive then destroy the meeting object
280
+ LoggerProxy.logger.error(
281
+ `Meeting:util#leaveMeeting --> An error occured while trying to leave meeting with an id of ${meeting.id}, error: ${err}`
282
+ );
283
+
284
+ return Promise.reject(err);
285
+ });
286
+ },
287
+ declineMeeting: (meeting, reason) =>
288
+ meeting.meetingRequest.declineMeeting({
289
+ locusUrl: meeting.locusUrl,
290
+ deviceUrl: meeting.deviceUrl,
291
+ reason,
292
+ }),
80
293
 
81
- MeetingUtil.isPinOrGuest = (err) =>
82
- err?.body?.errorCode && INTENT_TO_JOIN.includes(err.body.errorCode);
294
+ isUserInLeftState: (locusInfo) => locusInfo.parsedLocus?.self?.state === _LEFT_,
83
295
 
84
- MeetingUtil.joinMeeting = (meeting, options) => {
85
- if (!meeting) {
86
- return Promise.reject(new ParameterError('You need a meeting object.'));
87
- }
296
+ isUserInIdleState: (locusInfo) => locusInfo.parsedLocus?.self?.state === _IDLE_,
88
297
 
89
- Metrics.postEvent({event: eventType.LOCUS_JOIN_REQUEST, meeting});
298
+ isUserInJoinedState: (locusInfo) => locusInfo.parsedLocus?.self?.state === _JOINED_,
90
299
 
91
- // eslint-disable-next-line no-warning-comments
92
- // TODO: check if the meeting is in JOINING state
93
- // if Joining state termintate the request as user might click multiple times
94
- return meeting.meetingRequest
95
- .joinMeeting({
96
- inviteeAddress: meeting.meetingJoinUrl || meeting.sipUri,
97
- meetingNumber: meeting.meetingNumber,
98
- deviceUrl: meeting.deviceUrl,
99
- locusUrl: meeting.locusUrl,
100
- correlationId: meeting.correlationId,
101
- roapMessage: options.roapMessage,
102
- permissionToken: meeting.permissionToken,
103
- resourceId: options.resourceId || null,
104
- moderator: options.moderator,
105
- pin: options.pin,
106
- moveToResource: options.moveToResource,
107
- preferTranscoding: !meeting.isMultistream,
108
- asResourceOccupant: options.asResourceOccupant,
109
- breakoutsSupported: options.breakoutsSupported,
110
- })
111
- .then((res) => {
112
- Metrics.postEvent({
113
- event: eventType.LOCUS_JOIN_RESPONSE,
114
- meeting,
115
- data: {
116
- trigger: trigger.LOCI_UPDATE,
117
- locus: res.body.locus,
118
- mediaConnections: res.body.mediaConnections,
119
- trackingId: res.headers.trackingid,
300
+ isMediaEstablished: (currentMediaStatus) =>
301
+ currentMediaStatus &&
302
+ (currentMediaStatus.audio || currentMediaStatus.video || currentMediaStatus.share),
303
+
304
+ joinMeetingOptions: (meeting, options: any = {}) => {
305
+ const webex = meeting.getWebexObject();
306
+
307
+ meeting.resourceId = meeting.resourceId || options.resourceId;
308
+
309
+ if (meeting.requiredCaptcha) {
310
+ return Promise.reject(new CaptchaError());
311
+ }
312
+ if (meeting.passwordStatus === PASSWORD_STATUS.REQUIRED) {
313
+ return Promise.reject(new PasswordError());
314
+ }
315
+
316
+ if (options.pin) {
317
+ // @ts-ignore
318
+ webex.internal.newMetrics.submitClientEvent({
319
+ name: 'client.pin.collected',
320
+ options: {
321
+ meetingId: meeting.id,
120
322
  },
121
323
  });
324
+ }
122
325
 
123
- return MeetingUtil.parseLocusJoin(res);
124
- });
125
- };
326
+ // normal join meeting, scenario A, D
327
+ return MeetingUtil.joinMeeting(meeting, options)
328
+ .then((response) => {
329
+ meeting.setLocus(response);
330
+
331
+ return Promise.resolve(response);
332
+ })
333
+ .catch((err) => {
334
+ // joining a claimed PMR that is not my own, scenario B
335
+ if (MeetingUtil.isPinOrGuest(err)) {
336
+ // @ts-ignore
337
+ webex.internal.newMetrics.submitClientEvent({
338
+ name: 'client.pin.prompt',
339
+ options: {
340
+ meetingId: meeting.id,
341
+ },
342
+ });
343
+
344
+ // request host pin or non host for unclaimed PMR, start of Scenario C
345
+ // see https://sqbu-github.cisco.com/WebExSquared/locus/wiki/Locus-Lobby-and--IVR-Feature
346
+ return Promise.reject(new IntentToJoinError('Error Joining Meeting', err));
347
+ }
348
+ LoggerProxy.logger.error(
349
+ 'Meeting:util#joinMeetingOptions --> Error joining the call, ',
350
+ err
351
+ );
352
+
353
+ return Promise.reject(new JoinMeetingError(options, 'Error Joining Meeting', err));
354
+ });
355
+ },
356
+
357
+ /**
358
+ * Returns request options for leaving a meeting.
359
+ * @param {any} meeting
360
+ * @param {any} options
361
+ * @returns {any} request options
362
+ */
363
+ buildLeaveFetchRequestOptions: (meeting, options: any = {}) => {
364
+ const leaveOptions = MeetingUtil.prepareLeaveMeetingOptions(meeting, options);
365
+
366
+ return meeting.meetingRequest.buildLeaveMeetingRequestOptions(leaveOptions);
367
+ },
368
+
369
+ getTrack: (stream) => {
370
+ let audioTrack = null;
371
+ let videoTrack = null;
372
+ let audioTracks = null;
373
+ let videoTracks = null;
374
+
375
+ if (!stream) {
376
+ return {audioTrack: null, videoTrack: null};
377
+ }
378
+ if (stream.getAudioTracks) {
379
+ audioTracks = stream.getAudioTracks();
380
+ }
381
+ if (stream.getVideoTracks) {
382
+ videoTracks = stream.getVideoTracks();
383
+ }
126
384
 
127
- MeetingUtil.cleanUp = (meeting) => {
128
- meeting.breakouts.cleanUp();
129
-
130
- // make sure we send last metrics before we close the peerconnection
131
- const stopStatsAnalyzer = meeting.statsAnalyzer
132
- ? meeting.statsAnalyzer.stopAnalyzer()
133
- : Promise.resolve();
134
-
135
- return stopStatsAnalyzer
136
- .then(() => meeting.closeLocalStream())
137
- .then(() => meeting.closeLocalShare())
138
- .then(() => meeting.closeRemoteTracks())
139
- .then(() => meeting.closePeerConnections())
140
- .then(() => {
141
- meeting.unsetLocalVideoTrack();
142
- meeting.unsetLocalShareTrack();
143
- meeting.unsetRemoteTracks();
144
- meeting.unsetPeerConnections();
145
- meeting.reconnectionManager.cleanUp();
146
- })
147
- .then(() => meeting.stopKeepAlive())
148
- .then(() => meeting.updateLLMConnection());
149
- };
385
+ if (audioTracks && audioTracks.length > 0) {
386
+ [audioTrack] = audioTracks;
387
+ }
150
388
 
151
- MeetingUtil.disconnectPhoneAudio = (meeting, phoneUrl) => {
152
- if (meeting.meetingState === FULL_STATE.INACTIVE) {
153
- return Promise.reject(new MeetingNotActiveError());
154
- }
155
-
156
- const options = {
157
- locusUrl: meeting.locusUrl,
158
- selfId: meeting.selfId,
159
- correlationId: meeting.correlationId,
160
- phoneUrl,
161
- };
162
-
163
- return meeting.meetingRequest
164
- .disconnectPhoneAudio(options)
165
- .then((response) => {
166
- if (response?.body?.locus) {
167
- meeting.locusInfo.onFullLocus(response.body.locus);
168
- }
169
- })
170
- .catch((err) => {
171
- LoggerProxy.logger.error(
172
- `Meeting:util#disconnectPhoneAudio --> An error occured while disconnecting phone audio in meeting ${meeting.id}, error: ${err}`
173
- );
389
+ if (videoTracks && videoTracks.length > 0) {
390
+ [videoTrack] = videoTracks;
391
+ }
174
392
 
175
- return Promise.reject(err);
176
- });
177
- };
393
+ return {audioTrack, videoTrack};
394
+ },
178
395
 
179
- // by default will leave on meeting's resourceId
180
- // if you explicity want it not to leave on resource id, pass
181
- // {resourceId: null}
182
- // TODO: chris, you can modify this however you want
183
- MeetingUtil.leaveMeeting = (meeting, options: any = {}) => {
184
- if (meeting.meetingState === FULL_STATE.INACTIVE) {
185
- // TODO: clean up if the meeting is already inactive
186
- return Promise.reject(new MeetingNotActiveError());
187
- }
188
-
189
- if (MeetingUtil.isUserInLeftState(meeting.locusInfo)) {
190
- return Promise.reject(new UserNotJoinedError());
191
- }
192
-
193
- const defaultOptions = {
194
- locusUrl: meeting.locusUrl,
195
- selfId: meeting.selfId,
196
- correlationId: meeting.correlationId,
197
- resourceId: meeting.resourceId,
198
- deviceUrl: meeting.deviceUrl,
199
- };
200
-
201
- const leaveOptions = {...defaultOptions, ...options};
202
-
203
- return meeting.meetingRequest
204
- .leaveMeeting(leaveOptions)
205
- .then((response) => {
206
- if (response && response.body && response.body.locus) {
207
- // && !options.moveMeeting) {
208
- meeting.locusInfo.onFullLocus(response.body.locus);
209
- }
396
+ getModeratorFromLocusInfo: (locusInfo) =>
397
+ locusInfo &&
398
+ locusInfo.parsedLocus &&
399
+ locusInfo.parsedLocus.info &&
400
+ locusInfo.parsedLocus.info &&
401
+ locusInfo.parsedLocus.info.moderator,
210
402
 
211
- return Promise.resolve();
212
- })
213
- .then(() => {
214
- if (options.moveMeeting) {
215
- return Promise.resolve();
216
- }
403
+ getPolicyFromLocusInfo: (locusInfo) =>
404
+ locusInfo &&
405
+ locusInfo.parsedLocus &&
406
+ locusInfo.parsedLocus.info &&
407
+ locusInfo.parsedLocus.info &&
408
+ locusInfo.parsedLocus.info.policy,
217
409
 
218
- return MeetingUtil.cleanUp(meeting);
219
- })
220
- .catch((err) => {
221
- // TODO: If the meeting state comes as LEFT or INACTIVE as response then
222
- // 1) on leave clean up the meeting or simply do a sync on the meeting
223
- // 2) If the error says meeting is inactive then destroy the meeting object
224
- LoggerProxy.logger.error(
225
- `Meeting:util#leaveMeeting --> An error occured while trying to leave meeting with an id of ${meeting.id}, error: ${err}`
226
- );
410
+ getUserDisplayHintsFromLocusInfo: (locusInfo) =>
411
+ locusInfo?.parsedLocus?.info?.userDisplayHints || [],
227
412
 
228
- return Promise.reject(err);
229
- });
230
- };
231
- MeetingUtil.declineMeeting = (meeting, reason) =>
232
- meeting.meetingRequest.declineMeeting({
233
- locusUrl: meeting.locusUrl,
234
- deviceUrl: meeting.deviceUrl,
235
- reason,
236
- });
413
+ canInviteNewParticipants: (displayHints) => displayHints.includes(DISPLAY_HINTS.ADD_GUEST),
237
414
 
238
- MeetingUtil.isUserInLeftState = (locusInfo) => locusInfo.parsedLocus?.self?.state === _LEFT_;
415
+ canAdmitParticipant: (displayHints) =>
416
+ displayHints.includes(DISPLAY_HINTS.ROSTER_WAITING_TO_JOIN),
239
417
 
240
- MeetingUtil.isUserInIdleState = (locusInfo) => locusInfo.parsedLocus?.self?.state === _IDLE_;
418
+ canUserLock: (displayHints) =>
419
+ displayHints.includes(DISPLAY_HINTS.LOCK_CONTROL_LOCK) &&
420
+ displayHints.includes(DISPLAY_HINTS.LOCK_STATUS_UNLOCKED),
241
421
 
242
- MeetingUtil.isUserInJoinedState = (locusInfo) => locusInfo.parsedLocus?.self?.state === _JOINED_;
422
+ canUserUnlock: (displayHints) =>
423
+ displayHints.includes(DISPLAY_HINTS.LOCK_CONTROL_UNLOCK) &&
424
+ displayHints.includes(DISPLAY_HINTS.LOCK_STATUS_LOCKED),
243
425
 
244
- MeetingUtil.isMediaEstablished = (currentMediaStatus) =>
245
- currentMediaStatus &&
246
- (currentMediaStatus.audio || currentMediaStatus.video || currentMediaStatus.share);
426
+ canUserRaiseHand: (displayHints) => displayHints.includes(DISPLAY_HINTS.RAISE_HAND),
247
427
 
248
- MeetingUtil.joinMeetingOptions = (meeting, options: any = {}) => {
249
- meeting.resourceId = meeting.resourceId || options.resourceId;
428
+ canUserLowerAllHands: (displayHints) => displayHints.includes(DISPLAY_HINTS.LOWER_ALL_HANDS),
250
429
 
251
- if (meeting.requiredCaptcha) {
252
- return Promise.reject(new CaptchaError());
253
- }
254
- if (meeting.passwordStatus === PASSWORD_STATUS.REQUIRED) {
255
- return Promise.reject(new PasswordError());
256
- }
430
+ canUserLowerSomeoneElsesHand: (displayHints) =>
431
+ displayHints.includes(DISPLAY_HINTS.LOWER_SOMEONE_ELSES_HAND),
257
432
 
258
- if (options.pin) {
259
- Metrics.postEvent({
260
- event: eventType.PIN_COLLECTED,
261
- meeting,
262
- });
263
- }
264
-
265
- // normal join meeting, scenario A, D
266
- return MeetingUtil.joinMeeting(meeting, options)
267
- .then((response) => {
268
- meeting.setLocus(response);
269
-
270
- return Promise.resolve(response);
271
- })
272
- .catch((err) => {
273
- // joining a claimed PMR that is not my own, scenario B
274
- if (MeetingUtil.isPinOrGuest(err)) {
275
- Metrics.postEvent({
276
- event: eventType.PIN_PROMPT,
277
- meeting,
278
- });
433
+ bothLeaveAndEndMeetingAvailable: (displayHints) =>
434
+ displayHints.includes(DISPLAY_HINTS.LEAVE_TRANSFER_HOST_END_MEETING) ||
435
+ displayHints.includes(DISPLAY_HINTS.LEAVE_END_MEETING),
279
436
 
280
- // request host pin or non host for unclaimed PMR, start of Scenario C
281
- // see https://sqbu-github.cisco.com/WebExSquared/locus/wiki/Locus-Lobby-and--IVR-Feature
282
- return Promise.reject(new IntentToJoinError('Error Joining Meeting', err));
283
- }
284
- LoggerProxy.logger.error('Meeting:util#joinMeetingOptions --> Error joining the call, ', err);
437
+ canManageBreakout: (displayHints) => displayHints.includes(DISPLAY_HINTS.BREAKOUT_MANAGEMENT),
438
+ canBroadcastMessageToBreakout: (displayHints, policies = {}) =>
439
+ displayHints.includes(DISPLAY_HINTS.BROADCAST_MESSAGE_TO_BREAKOUT) &&
440
+ !!policies[SELF_POLICY.SUPPORT_BROADCAST_MESSAGE],
285
441
 
286
- return Promise.reject(new JoinMeetingError(options, 'Error Joining Meeting', err));
287
- });
288
- };
442
+ isSuppressBreakoutSupport: (displayHints) =>
443
+ displayHints.includes(DISPLAY_HINTS.UCF_SUPPRESS_BREAKOUTS_SUPPORT),
289
444
 
290
- MeetingUtil.validateOptions = (options) => {
291
- const {sendVideo, sendAudio, sendShare, localStream, localShare} = options;
445
+ canAdmitLobbyToBreakout: (displayHints) =>
446
+ !displayHints.includes(DISPLAY_HINTS.DISABLE_LOBBY_TO_BREAKOUT),
292
447
 
293
- if (sendVideo && !MeetingUtil.getTrack(localStream).videoTrack) {
294
- return Promise.reject(new ParameterError('please pass valid video streams'));
295
- }
448
+ isBreakoutPreassignmentsEnabled: (displayHints) =>
449
+ !displayHints.includes(DISPLAY_HINTS.DISABLE_BREAKOUT_PREASSIGNMENTS),
296
450
 
297
- if (sendAudio && !MeetingUtil.getTrack(localStream).audioTrack) {
298
- return Promise.reject(new ParameterError('please pass valid audio streams'));
299
- }
451
+ canUserAskForHelp: (displayHints) => !displayHints.includes(DISPLAY_HINTS.DISABLE_ASK_FOR_HELP),
300
452
 
301
- if (sendShare && !MeetingUtil.getTrack(localShare).videoTrack) {
302
- return Promise.reject(new ParameterError('please pass valid share streams'));
303
- }
453
+ lockMeeting: (actions, request, locusUrl) => {
454
+ if (actions && actions.canLock) {
455
+ return request.lockMeeting({locusUrl, lock: true});
456
+ }
304
457
 
305
- return Promise.resolve();
306
- };
458
+ return Promise.reject(new PermissionError('Lock not allowed, due to joined property.'));
459
+ },
307
460
 
308
- MeetingUtil.getTrack = (stream) => {
309
- let audioTrack = null;
310
- let videoTrack = null;
311
- let audioTracks = null;
312
- let videoTracks = null;
313
-
314
- if (!stream) {
315
- return {audioTrack: null, videoTrack: null};
316
- }
317
- if (stream.getAudioTracks) {
318
- audioTracks = stream.getAudioTracks();
319
- }
320
- if (stream.getVideoTracks) {
321
- videoTracks = stream.getVideoTracks();
322
- }
323
-
324
- if (audioTracks && audioTracks.length > 0) {
325
- [audioTrack] = audioTracks;
326
- }
327
-
328
- if (videoTracks && videoTracks.length > 0) {
329
- [videoTrack] = videoTracks;
330
- }
331
-
332
- return {audioTrack, videoTrack};
333
- };
461
+ unlockMeeting: (actions, request, locusUrl) => {
462
+ if (actions && actions.canUnlock) {
463
+ return request.lockMeeting({locusUrl, lock: false});
464
+ }
334
465
 
335
- MeetingUtil.getModeratorFromLocusInfo = (locusInfo) =>
336
- locusInfo &&
337
- locusInfo.parsedLocus &&
338
- locusInfo.parsedLocus.info &&
339
- locusInfo.parsedLocus.info &&
340
- locusInfo.parsedLocus.info.moderator;
466
+ return Promise.reject(new PermissionError('Unlock not allowed, due to joined property.'));
467
+ },
341
468
 
342
- MeetingUtil.getPolicyFromLocusInfo = (locusInfo) =>
343
- locusInfo &&
344
- locusInfo.parsedLocus &&
345
- locusInfo.parsedLocus.info &&
346
- locusInfo.parsedLocus.info &&
347
- locusInfo.parsedLocus.info.policy;
469
+ handleAudioLogging: (audioStream?: LocalMicrophoneStream) => {
470
+ const LOG_HEADER = 'MeetingUtil#handleAudioLogging -->';
348
471
 
349
- MeetingUtil.getUserDisplayHintsFromLocusInfo = (locusInfo) =>
350
- locusInfo?.parsedLocus?.info?.userDisplayHints || [];
472
+ if (audioStream) {
473
+ const settings = audioStream.getSettings();
474
+ const {deviceId} = settings;
351
475
 
352
- MeetingUtil.canInviteNewParticipants = (displayHints) =>
353
- displayHints.includes(DISPLAY_HINTS.ADD_GUEST);
476
+ LoggerProxy.logger.log(LOG_HEADER, `deviceId = ${deviceId}`);
477
+ LoggerProxy.logger.log(LOG_HEADER, 'settings =', JSON.stringify(settings));
478
+ }
479
+ },
354
480
 
355
- MeetingUtil.canAdmitParticipant = (displayHints) =>
356
- displayHints.includes(DISPLAY_HINTS.ROSTER_WAITING_TO_JOIN);
481
+ handleVideoLogging: (videoStream?: LocalCameraStream) => {
482
+ const LOG_HEADER = 'MeetingUtil#handleVideoLogging -->';
357
483
 
358
- MeetingUtil.canUserLock = (displayHints) =>
359
- displayHints.includes(DISPLAY_HINTS.LOCK_CONTROL_LOCK) &&
360
- displayHints.includes(DISPLAY_HINTS.LOCK_STATUS_UNLOCKED);
484
+ if (videoStream) {
485
+ const settings = videoStream.getSettings();
486
+ const {deviceId} = settings;
361
487
 
362
- MeetingUtil.canUserUnlock = (displayHints) =>
363
- displayHints.includes(DISPLAY_HINTS.LOCK_CONTROL_UNLOCK) &&
364
- displayHints.includes(DISPLAY_HINTS.LOCK_STATUS_LOCKED);
488
+ LoggerProxy.logger.log(LOG_HEADER, `deviceId = ${deviceId}`);
489
+ LoggerProxy.logger.log(LOG_HEADER, 'settings =', JSON.stringify(settings));
490
+ }
491
+ },
365
492
 
366
- MeetingUtil.canUserRaiseHand = (displayHints) => displayHints.includes(DISPLAY_HINTS.RAISE_HAND);
493
+ handleDeviceLogging: (devices = []) => {
494
+ const LOG_HEADER = 'MeetingUtil#handleDeviceLogging -->';
367
495
 
368
- MeetingUtil.canUserLowerAllHands = (displayHints) =>
369
- displayHints.includes(DISPLAY_HINTS.LOWER_ALL_HANDS);
496
+ devices.forEach((device) => {
497
+ LoggerProxy.logger.log(LOG_HEADER, `deviceId = ${device.deviceId}`);
498
+ LoggerProxy.logger.log(LOG_HEADER, 'settings', JSON.stringify(device));
499
+ });
500
+ },
370
501
 
371
- MeetingUtil.canUserLowerSomeoneElsesHand = (displayHints) =>
372
- displayHints.includes(DISPLAY_HINTS.LOWER_SOMEONE_ELSES_HAND);
502
+ endMeetingForAll: (meeting) => {
503
+ if (meeting.meetingState === FULL_STATE.INACTIVE) {
504
+ return Promise.reject(new MeetingNotActiveError());
505
+ }
373
506
 
374
- MeetingUtil.bothLeaveAndEndMeetingAvailable = (displayHints) =>
375
- displayHints.includes(DISPLAY_HINTS.LEAVE_TRANSFER_HOST_END_MEETING) ||
376
- displayHints.includes(DISPLAY_HINTS.LEAVE_END_MEETING);
507
+ const endOptions = {
508
+ locusUrl: meeting.locusUrl,
509
+ };
377
510
 
378
- MeetingUtil.canManageBreakout = (displayHints) =>
379
- displayHints.includes(DISPLAY_HINTS.BREAKOUT_MANAGEMENT);
511
+ return meeting.meetingRequest
512
+ .endMeetingForAll(endOptions)
513
+ .then(() => MeetingUtil.cleanUp(meeting))
514
+ .catch((err) => {
515
+ LoggerProxy.logger.error(
516
+ `Meeting:util#endMeetingForAll An error occured while trying to end meeting for all with an id of ${meeting.id}, error: ${err}`
517
+ );
380
518
 
381
- MeetingUtil.isSuppressBreakoutSupport = (displayHints) =>
382
- displayHints.includes(DISPLAY_HINTS.UCF_SUPPRESS_BREAKOUTS_SUPPORT);
519
+ return Promise.reject(err);
520
+ });
521
+ },
383
522
 
384
- MeetingUtil.canAdmitLobbyToBreakout = (displayHints) =>
385
- !displayHints.includes(DISPLAY_HINTS.DISABLE_LOBBY_TO_BREAKOUT);
523
+ canEnableClosedCaption: (displayHints) => displayHints.includes(DISPLAY_HINTS.CAPTION_START),
386
524
 
387
- MeetingUtil.isBreakoutPreassignmentsEnabled = (displayHints) =>
388
- !displayHints.includes(DISPLAY_HINTS.DISABLE_BREAKOUT_PREASSIGNMENTS);
525
+ isSaveTranscriptsEnabled: (displayHints) =>
526
+ displayHints.includes(DISPLAY_HINTS.SAVE_TRANSCRIPTS_ENABLED),
389
527
 
390
- MeetingUtil.canUserAskForHelp = (displayHints) =>
391
- !displayHints.includes(DISPLAY_HINTS.DISABLE_ASK_FOR_HELP);
528
+ canStartTranscribing: (displayHints) =>
529
+ displayHints.includes(DISPLAY_HINTS.TRANSCRIPTION_CONTROL_START),
392
530
 
393
- MeetingUtil.lockMeeting = (actions, request, locusUrl) => {
394
- if (actions && actions.canLock) {
395
- return request.lockMeeting({locusUrl, lock: true});
396
- }
531
+ canStopTranscribing: (displayHints) =>
532
+ displayHints.includes(DISPLAY_HINTS.TRANSCRIPTION_CONTROL_STOP),
397
533
 
398
- return Promise.reject(new PermissionError('Lock not allowed, due to joined property.'));
399
- };
534
+ isClosedCaptionActive: (displayHints) =>
535
+ displayHints.includes(DISPLAY_HINTS.CAPTION_STATUS_ACTIVE),
400
536
 
401
- MeetingUtil.unlockMeeting = (actions, request, locusUrl) => {
402
- if (actions && actions.canUnlock) {
403
- return request.lockMeeting({locusUrl, lock: false});
404
- }
537
+ isWebexAssistantActive: (displayHints) =>
538
+ displayHints.includes(DISPLAY_HINTS.WEBEX_ASSISTANT_STATUS_ACTIVE),
405
539
 
406
- return Promise.reject(new PermissionError('Unlock not allowed, due to joined property.'));
407
- };
540
+ canViewCaptionPanel: (displayHints) => displayHints.includes(DISPLAY_HINTS.ENABLE_CAPTION_PANEL),
408
541
 
409
- MeetingUtil.handleAudioLogging = (audioTrack: LocalMicrophoneTrack | null) => {
410
- const LOG_HEADER = 'MeetingUtil#handleAudioLogging -->';
542
+ isRealTimeTranslationEnabled: (displayHints) =>
543
+ displayHints.includes(DISPLAY_HINTS.DISPLAY_REAL_TIME_TRANSLATION),
411
544
 
412
- if (audioTrack) {
413
- const settings = audioTrack.underlyingTrack.getSettings();
414
- const {deviceId} = settings;
545
+ canSelectSpokenLanguages: (displayHints) =>
546
+ displayHints.includes(DISPLAY_HINTS.DISPLAY_NON_ENGLISH_ASR),
415
547
 
416
- LoggerProxy.logger.log(LOG_HEADER, `deviceId = ${deviceId}`);
417
- LoggerProxy.logger.log(LOG_HEADER, 'settings =', JSON.stringify(settings));
418
- }
419
- };
548
+ waitingForOthersToJoin: (displayHints) => displayHints.includes(DISPLAY_HINTS.WAITING_FOR_OTHERS),
549
+
550
+ canSendReactions: (originalValue, displayHints) => {
551
+ if (displayHints.includes(DISPLAY_HINTS.REACTIONS_ACTIVE)) {
552
+ return true;
553
+ }
554
+ if (displayHints.includes(DISPLAY_HINTS.REACTIONS_INACTIVE)) {
555
+ return false;
556
+ }
420
557
 
421
- MeetingUtil.handleVideoLogging = (videoTrack: LocalCameraTrack | null) => {
422
- const LOG_HEADER = 'MeetingUtil#handleVideoLogging -->';
558
+ return originalValue;
559
+ },
560
+ canUserRenameSelfAndObserved: (displayHints) =>
561
+ displayHints.includes(DISPLAY_HINTS.CAN_RENAME_SELF_AND_OBSERVED),
423
562
 
424
- if (videoTrack) {
425
- const settings = videoTrack.underlyingTrack.getSettings();
426
- const {deviceId} = settings;
563
+ canUserRenameOthers: (displayHints) => displayHints.includes(DISPLAY_HINTS.CAN_RENAME_OTHERS),
427
564
 
428
- LoggerProxy.logger.log(LOG_HEADER, `deviceId = ${deviceId}`);
429
- LoggerProxy.logger.log(LOG_HEADER, 'settings =', JSON.stringify(settings));
430
- }
431
- };
565
+ canShareWhiteBoard: (displayHints) => displayHints.includes(DISPLAY_HINTS.SHARE_WHITEBOARD),
432
566
 
433
- MeetingUtil.handleDeviceLogging = (devices = []) => {
434
- const LOG_HEADER = 'MeetingUtil#handleDeviceLogging -->';
567
+ /**
568
+ * Adds the current locus sequence information to a request body
569
+ * @param {Object} meeting The meeting object
570
+ * @param {Object} requestBody The body of a request to locus
571
+ * @returns {void}
572
+ */
573
+ addSequence: (meeting, requestBody) => {
574
+ const sequence = meeting?.locusInfo?.sequence;
435
575
 
436
- devices.forEach((device) => {
437
- LoggerProxy.logger.log(LOG_HEADER, `deviceId = ${device.deviceId}`);
438
- LoggerProxy.logger.log(LOG_HEADER, 'settings', JSON.stringify(device));
439
- });
440
- };
576
+ if (!sequence) {
577
+ return;
578
+ }
579
+
580
+ requestBody.sequence = sequence;
581
+ },
582
+
583
+ /**
584
+ * Updates the locus info for the meeting with the delta locus
585
+ * returned from requests that include the sequence information
586
+ * Returns the original response object
587
+ * @param {Object} meeting The meeting object
588
+ * @param {Object} response The response of the http request
589
+ * @returns {Object}
590
+ */
591
+ updateLocusWithDelta: (meeting, response) => {
592
+ if (!meeting) {
593
+ return response;
594
+ }
595
+
596
+ const locus = response?.body?.locus;
597
+
598
+ if (locus) {
599
+ meeting.locusInfo.handleLocusDelta(locus, meeting);
600
+ }
441
601
 
442
- MeetingUtil.endMeetingForAll = (meeting) => {
443
- if (meeting.meetingState === FULL_STATE.INACTIVE) {
444
- return Promise.reject(new MeetingNotActiveError());
445
- }
602
+ return response;
603
+ },
446
604
 
447
- const endOptions = {
448
- locusUrl: meeting.locusUrl,
449
- };
605
+ generateBuildLocusDeltaRequestOptions: (originalMeeting) => {
606
+ const meetingRef = new WeakRef(originalMeeting);
450
607
 
451
- return meeting.meetingRequest
452
- .endMeetingForAll(endOptions)
453
- .then((response) => {
454
- if (response && response.body && response.body.locus) {
455
- meeting.locusInfo.onFullLocus(response.body.locus);
608
+ const buildLocusDeltaRequestOptions = (originalOptions) => {
609
+ const meeting = meetingRef.deref();
610
+
611
+ if (!meeting) {
612
+ return originalOptions;
456
613
  }
457
614
 
458
- return Promise.resolve();
459
- })
460
- .then(() => MeetingUtil.cleanUp(meeting))
461
- .catch((err) => {
462
- LoggerProxy.logger.error(
463
- `Meeting:util#endMeetingForAll An error occured while trying to end meeting for all with an id of ${meeting.id}, error: ${err}`
464
- );
615
+ const options = cloneDeep(originalOptions);
465
616
 
466
- return Promise.reject(err);
467
- });
468
- };
617
+ if (!options.body) {
618
+ options.body = {};
619
+ }
469
620
 
470
- MeetingUtil.canEnableClosedCaption = (displayHints) =>
471
- displayHints.includes(DISPLAY_HINTS.CAPTION_START);
621
+ MeetingUtil.addSequence(meeting, options.body);
472
622
 
473
- MeetingUtil.isSaveTranscriptsEnabled = (displayHints) =>
474
- displayHints.includes(DISPLAY_HINTS.SAVE_TRANSCRIPTS_ENABLED);
623
+ return options;
624
+ };
475
625
 
476
- MeetingUtil.canStartTranscribing = (displayHints) =>
477
- displayHints.includes(DISPLAY_HINTS.TRANSCRIPTION_CONTROL_START);
626
+ return buildLocusDeltaRequestOptions;
627
+ },
478
628
 
479
- MeetingUtil.canStopTranscribing = (displayHints) =>
480
- displayHints.includes(DISPLAY_HINTS.TRANSCRIPTION_CONTROL_STOP);
629
+ generateLocusDeltaRequest: (originalMeeting) => {
630
+ const meetingRef = new WeakRef(originalMeeting);
481
631
 
482
- MeetingUtil.isClosedCaptionActive = (displayHints) =>
483
- displayHints.includes(DISPLAY_HINTS.CAPTION_STATUS_ACTIVE);
632
+ const buildLocusDeltaRequestOptions =
633
+ MeetingUtil.generateBuildLocusDeltaRequestOptions(originalMeeting);
484
634
 
485
- MeetingUtil.isWebexAssistantActive = (displayHints) =>
486
- displayHints.includes(DISPLAY_HINTS.WEBEX_ASSISTANT_STATUS_ACTIVE);
635
+ const locusDeltaRequest = (originalOptions) => {
636
+ const meeting = meetingRef.deref();
487
637
 
488
- MeetingUtil.canViewCaptionPanel = (displayHints) =>
489
- displayHints.includes(DISPLAY_HINTS.ENABLE_CAPTION_PANEL);
638
+ if (!meeting) {
639
+ return Promise.resolve();
640
+ }
490
641
 
491
- MeetingUtil.isRealTimeTranslationEnabled = (displayHints) =>
492
- displayHints.includes(DISPLAY_HINTS.DISPLAY_REAL_TIME_TRANSLATION);
642
+ const options = buildLocusDeltaRequestOptions(originalOptions);
493
643
 
494
- MeetingUtil.canSelectSpokenLanguages = (displayHints) =>
495
- displayHints.includes(DISPLAY_HINTS.DISPLAY_NON_ENGLISH_ASR);
644
+ return meeting
645
+ .request(options)
646
+ .then((response) => MeetingUtil.updateLocusWithDelta(meeting, response));
647
+ };
496
648
 
497
- MeetingUtil.waitingForOthersToJoin = (displayHints) =>
498
- displayHints.includes(DISPLAY_HINTS.WAITING_FOR_OTHERS);
649
+ return locusDeltaRequest;
650
+ },
499
651
 
500
- MeetingUtil.canEnableReactions = (originalValue, displayHints) => {
501
- if (displayHints.includes(DISPLAY_HINTS.ENABLE_REACTIONS)) {
502
- return true;
503
- }
504
- if (displayHints.includes(DISPLAY_HINTS.DISABLE_REACTIONS)) {
505
- return false;
506
- }
652
+ selfSupportsFeature: (feature: SELF_POLICY, userPolicies: Record<SELF_POLICY, boolean>) => {
653
+ if (!userPolicies) {
654
+ return true;
655
+ }
507
656
 
508
- return originalValue;
509
- };
657
+ return userPolicies[feature];
658
+ },
510
659
 
511
- MeetingUtil.canSendReactions = (originalValue, displayHints) => {
512
- if (displayHints.includes(DISPLAY_HINTS.REACTIONS_ACTIVE)) {
513
- return true;
514
- }
515
- if (displayHints.includes(DISPLAY_HINTS.REACTIONS_INACTIVE)) {
516
- return false;
517
- }
660
+ parseInterpretationInfo: (meeting, meetingInfo) => {
661
+ if (!meeting || !meetingInfo) {
662
+ return;
663
+ }
664
+ const siInfo = meetingInfo.simultaneousInterpretation;
665
+ meeting.simultaneousInterpretation.updateMeetingSIEnabled(
666
+ !!meetingInfo.turnOnSimultaneousInterpretation,
667
+ !!siInfo?.currentSIInterpreter
668
+ );
669
+ const hostSIEnabled = !!(
670
+ meetingInfo.turnOnSimultaneousInterpretation &&
671
+ meetingInfo?.meetingSiteSetting?.enableHostInterpreterControlSI
672
+ );
673
+ meeting.simultaneousInterpretation.updateHostSIEnabled(hostSIEnabled);
518
674
 
519
- return originalValue;
520
- };
521
- MeetingUtil.canUserRenameSelfAndObserved = (displayHints) =>
522
- displayHints.includes(DISPLAY_HINTS.CAN_RENAME_SELF_AND_OBSERVED);
675
+ function renameKey(obj, oldKey, newKey) {
676
+ if (oldKey in obj) {
677
+ obj[newKey] = obj[oldKey];
678
+ delete obj[oldKey];
679
+ }
680
+ }
681
+ if (siInfo) {
682
+ const lanuagesInfo = cloneDeep(siInfo.siLanguages);
683
+ for (const language of lanuagesInfo) {
684
+ renameKey(language, 'languageCode', 'languageName');
685
+ renameKey(language, 'languageGroupId', 'languageCode');
686
+ }
687
+ if (!meeting.simultaneousInterpretation?.siLanguages?.length) {
688
+ meeting.simultaneousInterpretation.updateInterpretation({siLanguages: lanuagesInfo});
689
+ }
690
+ }
691
+ Trigger.trigger(
692
+ meeting,
693
+ {
694
+ file: 'meeting/util',
695
+ function: 'parseInterpretationInfo',
696
+ },
697
+ EVENT_TRIGGERS.MEETING_INTERPRETATION_UPDATE
698
+ );
699
+ },
700
+
701
+ /**
702
+ * Returns a CA-recognized error payload for the specified raw error message/reason.
703
+ *
704
+ * New errors can be added to this function for handling in the future
705
+ *
706
+ * @param {String} reason the raw error message
707
+ * @returns {Array<object>} an array of payload objects
708
+ */
709
+ getChangeMeetingFloorErrorPayload: (reason: string) => {
710
+ const errorPayload = {
711
+ errorDescription: reason,
712
+ name: 'locus.response',
713
+ shownToUser: false,
714
+ };
715
+ if (reason.includes(LOCAL_SHARE_ERRORS.UNDEFINED)) {
716
+ return [
717
+ {
718
+ ...errorPayload,
719
+ fatal: true,
720
+ category: 'signaling',
721
+ errorCode: 1100,
722
+ },
723
+ ];
724
+ }
725
+ if (reason.includes(LOCAL_SHARE_ERRORS.DEVICE_NOT_JOINED)) {
726
+ return [
727
+ {
728
+ ...errorPayload,
729
+ fatal: true,
730
+ category: 'signaling',
731
+ errorCode: 4050,
732
+ },
733
+ ];
734
+ }
735
+ if (reason.includes(LOCAL_SHARE_ERRORS.NO_MEDIA_FOR_DEVICE)) {
736
+ return [
737
+ {
738
+ ...errorPayload,
739
+ fatal: true,
740
+ category: 'media',
741
+ errorCode: 2048,
742
+ },
743
+ ];
744
+ }
745
+ if (reason.includes(LOCAL_SHARE_ERRORS.NO_CONFLUENCE_ID)) {
746
+ return [
747
+ {
748
+ ...errorPayload,
749
+ fatal: true,
750
+ category: 'signaling',
751
+ errorCode: 4064,
752
+ },
753
+ ];
754
+ }
755
+ if (reason.includes(LOCAL_SHARE_ERRORS.CONTENT_SHARING_DISABLED)) {
756
+ return [
757
+ {
758
+ ...errorPayload,
759
+ fatal: true,
760
+ category: 'expected',
761
+ errorCode: 4065,
762
+ },
763
+ ];
764
+ }
765
+ if (reason.includes(LOCAL_SHARE_ERRORS.LOCUS_PARTICIPANT_DNE)) {
766
+ return [
767
+ {
768
+ ...errorPayload,
769
+ fatal: true,
770
+ category: 'signaling',
771
+ errorCode: 4066,
772
+ },
773
+ ];
774
+ }
775
+ if (reason.includes(LOCAL_SHARE_ERRORS.CONTENT_REQUEST_WHILE_PENDING_WHITEBOARD)) {
776
+ return [
777
+ {
778
+ ...errorPayload,
779
+ fatal: true,
780
+ category: 'expected',
781
+ errorCode: 4067,
782
+ },
783
+ ];
784
+ }
523
785
 
524
- MeetingUtil.canUserRenameOthers = (displayHints) =>
525
- displayHints.includes(DISPLAY_HINTS.CAN_RENAME_OTHERS);
786
+ // return unknown error
787
+ return [
788
+ {
789
+ ...errorPayload,
790
+ fatal: true,
791
+ category: 'signaling',
792
+ errorCode: 1100,
793
+ },
794
+ ];
795
+ },
796
+ };
526
797
 
527
798
  export default MeetingUtil;