@webex/plugin-meetings 3.0.0-beta.16 → 3.0.0-beta.160

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 (408) hide show
  1. package/README.md +45 -1
  2. package/dist/annotation/annotation.types.js +7 -0
  3. package/dist/annotation/annotation.types.js.map +1 -0
  4. package/dist/annotation/constants.js +49 -0
  5. package/dist/annotation/constants.js.map +1 -0
  6. package/dist/annotation/index.js +359 -0
  7. package/dist/annotation/index.js.map +1 -0
  8. package/dist/breakouts/breakout.js +212 -0
  9. package/dist/breakouts/breakout.js.map +1 -0
  10. package/dist/breakouts/collection.js +23 -0
  11. package/dist/breakouts/collection.js.map +1 -0
  12. package/dist/breakouts/edit-lock-error.js +52 -0
  13. package/dist/breakouts/edit-lock-error.js.map +1 -0
  14. package/dist/breakouts/events.js +43 -0
  15. package/dist/breakouts/events.js.map +1 -0
  16. package/dist/breakouts/index.js +1046 -0
  17. package/dist/breakouts/index.js.map +1 -0
  18. package/dist/breakouts/request.js +78 -0
  19. package/dist/breakouts/request.js.map +1 -0
  20. package/dist/breakouts/utils.js +67 -0
  21. package/dist/breakouts/utils.js.map +1 -0
  22. package/dist/common/errors/webex-errors.js +3 -2
  23. package/dist/common/errors/webex-errors.js.map +1 -1
  24. package/dist/common/logs/logger-proxy.js +1 -1
  25. package/dist/common/logs/logger-proxy.js.map +1 -1
  26. package/dist/config.js +6 -8
  27. package/dist/config.js.map +1 -1
  28. package/dist/constants.js +165 -26
  29. package/dist/constants.js.map +1 -1
  30. package/dist/controls-options-manager/constants.js +14 -0
  31. package/dist/controls-options-manager/constants.js.map +1 -0
  32. package/dist/controls-options-manager/enums.js +27 -0
  33. package/dist/controls-options-manager/enums.js.map +1 -0
  34. package/dist/controls-options-manager/index.js +297 -0
  35. package/dist/controls-options-manager/index.js.map +1 -0
  36. package/dist/controls-options-manager/types.js +7 -0
  37. package/dist/controls-options-manager/types.js.map +1 -0
  38. package/dist/controls-options-manager/util.js +300 -0
  39. package/dist/controls-options-manager/util.js.map +1 -0
  40. package/dist/index.js +77 -0
  41. package/dist/index.js.map +1 -1
  42. package/dist/locus-info/controlsUtils.js +91 -2
  43. package/dist/locus-info/controlsUtils.js.map +1 -1
  44. package/dist/locus-info/index.js +298 -24
  45. package/dist/locus-info/index.js.map +1 -1
  46. package/dist/locus-info/mediaSharesUtils.js +43 -1
  47. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  48. package/dist/locus-info/parser.js +2 -1
  49. package/dist/locus-info/parser.js.map +1 -1
  50. package/dist/locus-info/selfUtils.js +88 -14
  51. package/dist/locus-info/selfUtils.js.map +1 -1
  52. package/dist/media/index.js +39 -134
  53. package/dist/media/index.js.map +1 -1
  54. package/dist/media/properties.js +19 -97
  55. package/dist/media/properties.js.map +1 -1
  56. package/dist/mediaQualityMetrics/config.js +505 -493
  57. package/dist/mediaQualityMetrics/config.js.map +1 -1
  58. package/dist/meeting/in-meeting-actions.js +79 -1
  59. package/dist/meeting/in-meeting-actions.js.map +1 -1
  60. package/dist/meeting/index.js +2275 -2152
  61. package/dist/meeting/index.js.map +1 -1
  62. package/dist/meeting/locusMediaRequest.js +291 -0
  63. package/dist/meeting/locusMediaRequest.js.map +1 -0
  64. package/dist/meeting/muteState.js +229 -124
  65. package/dist/meeting/muteState.js.map +1 -1
  66. package/dist/meeting/request.js +191 -167
  67. package/dist/meeting/request.js.map +1 -1
  68. package/dist/meeting/request.type.js.map +1 -1
  69. package/dist/meeting/util.js +443 -443
  70. package/dist/meeting/util.js.map +1 -1
  71. package/dist/meeting-info/meeting-info-v2.js +157 -49
  72. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  73. package/dist/meeting-info/utilv2.js +20 -5
  74. package/dist/meeting-info/utilv2.js.map +1 -1
  75. package/dist/meetings/collection.js +22 -0
  76. package/dist/meetings/collection.js.map +1 -1
  77. package/dist/meetings/index.js +365 -73
  78. package/dist/meetings/index.js.map +1 -1
  79. package/dist/meetings/meetings.types.js +7 -0
  80. package/dist/meetings/meetings.types.js.map +1 -0
  81. package/dist/meetings/request.js +16 -12
  82. package/dist/meetings/request.js.map +1 -1
  83. package/dist/meetings/util.js +88 -1
  84. package/dist/meetings/util.js.map +1 -1
  85. package/dist/member/index.js +41 -0
  86. package/dist/member/index.js.map +1 -1
  87. package/dist/member/types.js +15 -0
  88. package/dist/member/types.js.map +1 -0
  89. package/dist/member/util.js +86 -3
  90. package/dist/member/util.js.map +1 -1
  91. package/dist/members/collection.js +10 -0
  92. package/dist/members/collection.js.map +1 -1
  93. package/dist/members/index.js +94 -11
  94. package/dist/members/index.js.map +1 -1
  95. package/dist/members/request.js +109 -39
  96. package/dist/members/request.js.map +1 -1
  97. package/dist/members/types.js +15 -0
  98. package/dist/members/types.js.map +1 -0
  99. package/dist/members/util.js +316 -233
  100. package/dist/members/util.js.map +1 -1
  101. package/dist/metrics/config.js +50 -14
  102. package/dist/metrics/config.js.map +1 -1
  103. package/dist/metrics/constants.js +3 -5
  104. package/dist/metrics/constants.js.map +1 -1
  105. package/dist/metrics/index.js +48 -29
  106. package/dist/metrics/index.js.map +1 -1
  107. package/dist/multistream/mediaRequestManager.js +265 -36
  108. package/dist/multistream/mediaRequestManager.js.map +1 -1
  109. package/dist/multistream/receiveSlot.js +52 -19
  110. package/dist/multistream/receiveSlot.js.map +1 -1
  111. package/dist/multistream/receiveSlotManager.js +53 -33
  112. package/dist/multistream/receiveSlotManager.js.map +1 -1
  113. package/dist/multistream/remoteMedia.js +44 -18
  114. package/dist/multistream/remoteMedia.js.map +1 -1
  115. package/dist/multistream/remoteMediaGroup.js +60 -3
  116. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  117. package/dist/multistream/remoteMediaManager.js +322 -103
  118. package/dist/multistream/remoteMediaManager.js.map +1 -1
  119. package/dist/networkQualityMonitor/index.js +4 -2
  120. package/dist/networkQualityMonitor/index.js.map +1 -1
  121. package/dist/reachability/index.js +117 -60
  122. package/dist/reachability/index.js.map +1 -1
  123. package/dist/reachability/request.js +12 -5
  124. package/dist/reachability/request.js.map +1 -1
  125. package/dist/reactions/constants.js +13 -0
  126. package/dist/reactions/constants.js.map +1 -0
  127. package/dist/reactions/reactions.js +2 -2
  128. package/dist/reactions/reactions.js.map +1 -1
  129. package/dist/reactions/reactions.type.js +18 -18
  130. package/dist/reactions/reactions.type.js.map +1 -1
  131. package/dist/reconnection-manager/index.js +190 -145
  132. package/dist/reconnection-manager/index.js.map +1 -1
  133. package/dist/recording-controller/enums.js +17 -0
  134. package/dist/recording-controller/enums.js.map +1 -0
  135. package/dist/recording-controller/index.js +343 -0
  136. package/dist/recording-controller/index.js.map +1 -0
  137. package/dist/recording-controller/util.js +63 -0
  138. package/dist/recording-controller/util.js.map +1 -0
  139. package/dist/roap/index.js +21 -29
  140. package/dist/roap/index.js.map +1 -1
  141. package/dist/roap/request.js +127 -92
  142. package/dist/roap/request.js.map +1 -1
  143. package/dist/roap/turnDiscovery.js +135 -53
  144. package/dist/roap/turnDiscovery.js.map +1 -1
  145. package/dist/statsAnalyzer/global.js +1 -93
  146. package/dist/statsAnalyzer/global.js.map +1 -1
  147. package/dist/statsAnalyzer/index.js +329 -314
  148. package/dist/statsAnalyzer/index.js.map +1 -1
  149. package/dist/statsAnalyzer/mqaUtil.js +103 -54
  150. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  151. package/dist/types/annotation/annotation.types.d.ts +43 -0
  152. package/dist/types/annotation/constants.d.ts +31 -0
  153. package/dist/types/annotation/index.d.ts +124 -0
  154. package/dist/types/breakouts/breakout.d.ts +8 -0
  155. package/dist/types/breakouts/collection.d.ts +5 -0
  156. package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
  157. package/dist/types/breakouts/events.d.ts +2 -0
  158. package/dist/types/breakouts/index.d.ts +5 -0
  159. package/dist/types/breakouts/request.d.ts +22 -0
  160. package/dist/types/breakouts/utils.d.ts +15 -0
  161. package/dist/types/common/browser-detection.d.ts +9 -0
  162. package/dist/types/common/collection.d.ts +48 -0
  163. package/dist/types/common/config.d.ts +2 -0
  164. package/dist/types/common/errors/captcha-error.d.ts +15 -0
  165. package/dist/types/common/errors/intent-to-join.d.ts +16 -0
  166. package/dist/types/common/errors/join-meeting.d.ts +17 -0
  167. package/dist/types/common/errors/media.d.ts +15 -0
  168. package/dist/types/common/errors/parameter.d.ts +15 -0
  169. package/dist/types/common/errors/password-error.d.ts +15 -0
  170. package/dist/types/common/errors/permission.d.ts +14 -0
  171. package/dist/types/common/errors/reconnection-in-progress.d.ts +9 -0
  172. package/dist/types/common/errors/reconnection.d.ts +15 -0
  173. package/dist/types/common/errors/stats.d.ts +15 -0
  174. package/dist/types/common/errors/webex-errors.d.ts +69 -0
  175. package/dist/types/common/errors/webex-meetings-error.d.ts +20 -0
  176. package/dist/types/common/events/events-scope.d.ts +17 -0
  177. package/dist/types/common/events/events.d.ts +12 -0
  178. package/dist/types/common/events/trigger-proxy.d.ts +2 -0
  179. package/dist/types/common/events/util.d.ts +2 -0
  180. package/dist/types/common/logs/logger-config.d.ts +2 -0
  181. package/dist/types/common/logs/logger-proxy.d.ts +2 -0
  182. package/dist/types/common/logs/request.d.ts +34 -0
  183. package/dist/types/common/queue.d.ts +32 -0
  184. package/dist/types/config.d.ts +72 -0
  185. package/dist/types/constants.d.ts +978 -0
  186. package/dist/types/controls-options-manager/constants.d.ts +4 -0
  187. package/dist/types/controls-options-manager/enums.d.ts +15 -0
  188. package/dist/types/controls-options-manager/index.d.ts +136 -0
  189. package/dist/types/controls-options-manager/types.d.ts +43 -0
  190. package/dist/types/controls-options-manager/util.d.ts +1 -0
  191. package/dist/types/index.d.ts +7 -0
  192. package/dist/types/locus-info/controlsUtils.d.ts +2 -0
  193. package/dist/types/locus-info/embeddedAppsUtils.d.ts +2 -0
  194. package/dist/types/locus-info/fullState.d.ts +2 -0
  195. package/dist/types/locus-info/hostUtils.d.ts +2 -0
  196. package/dist/types/locus-info/index.d.ts +315 -0
  197. package/dist/types/locus-info/infoUtils.d.ts +2 -0
  198. package/dist/types/locus-info/mediaSharesUtils.d.ts +2 -0
  199. package/dist/types/locus-info/parser.d.ts +212 -0
  200. package/dist/types/locus-info/selfUtils.d.ts +2 -0
  201. package/dist/types/media/index.d.ts +34 -0
  202. package/dist/types/media/properties.d.ts +86 -0
  203. package/dist/types/media/util.d.ts +2 -0
  204. package/dist/types/mediaQualityMetrics/config.d.ts +365 -0
  205. package/dist/types/meeting/in-meeting-actions.d.ts +149 -0
  206. package/dist/types/meeting/index.d.ts +1516 -0
  207. package/dist/types/meeting/locusMediaRequest.d.ts +70 -0
  208. package/dist/types/meeting/muteState.d.ts +184 -0
  209. package/dist/types/meeting/request.d.ts +270 -0
  210. package/dist/types/meeting/request.type.d.ts +11 -0
  211. package/dist/types/meeting/state.d.ts +9 -0
  212. package/dist/types/meeting/util.d.ts +75 -0
  213. package/dist/types/meeting-info/collection.d.ts +20 -0
  214. package/dist/types/meeting-info/index.d.ts +57 -0
  215. package/dist/types/meeting-info/meeting-info-v2.d.ts +122 -0
  216. package/dist/types/meeting-info/request.d.ts +22 -0
  217. package/dist/types/meeting-info/util.d.ts +2 -0
  218. package/dist/types/meeting-info/utilv2.d.ts +2 -0
  219. package/dist/types/meetings/collection.d.ts +31 -0
  220. package/dist/types/meetings/index.d.ts +364 -0
  221. package/dist/types/meetings/meetings.types.d.ts +4 -0
  222. package/dist/types/meetings/request.d.ts +27 -0
  223. package/dist/types/meetings/util.d.ts +18 -0
  224. package/dist/types/member/index.d.ts +157 -0
  225. package/dist/types/member/types.d.ts +21 -0
  226. package/dist/types/member/util.d.ts +2 -0
  227. package/dist/types/members/collection.d.ts +29 -0
  228. package/dist/types/members/index.d.ts +353 -0
  229. package/dist/types/members/request.d.ts +114 -0
  230. package/dist/types/members/types.d.ts +24 -0
  231. package/dist/types/members/util.d.ts +210 -0
  232. package/dist/types/metrics/config.d.ts +195 -0
  233. package/dist/types/metrics/constants.d.ts +55 -0
  234. package/dist/types/metrics/index.d.ts +169 -0
  235. package/dist/types/multistream/mediaRequestManager.d.ts +118 -0
  236. package/dist/types/multistream/receiveSlot.d.ts +68 -0
  237. package/dist/types/multistream/receiveSlotManager.d.ts +56 -0
  238. package/dist/types/multistream/remoteMedia.d.ts +72 -0
  239. package/dist/types/multistream/remoteMediaGroup.d.ts +47 -0
  240. package/dist/types/multistream/remoteMediaManager.d.ts +277 -0
  241. package/dist/types/networkQualityMonitor/index.d.ts +70 -0
  242. package/dist/types/personal-meeting-room/index.d.ts +47 -0
  243. package/dist/types/personal-meeting-room/request.d.ts +14 -0
  244. package/dist/types/personal-meeting-room/util.d.ts +2 -0
  245. package/dist/types/reachability/index.d.ts +152 -0
  246. package/dist/types/reachability/request.d.ts +37 -0
  247. package/dist/types/reactions/constants.d.ts +3 -0
  248. package/dist/types/reactions/reactions.d.ts +4 -0
  249. package/dist/types/reactions/reactions.type.d.ts +52 -0
  250. package/dist/types/reconnection-manager/index.d.ts +126 -0
  251. package/dist/types/recording-controller/enums.d.ts +7 -0
  252. package/dist/types/recording-controller/index.d.ts +193 -0
  253. package/dist/types/recording-controller/util.d.ts +13 -0
  254. package/dist/types/roap/index.d.ts +77 -0
  255. package/dist/types/roap/request.d.ts +36 -0
  256. package/dist/types/roap/turnDiscovery.d.ts +91 -0
  257. package/dist/types/statsAnalyzer/global.d.ts +36 -0
  258. package/dist/types/statsAnalyzer/index.d.ts +200 -0
  259. package/dist/types/statsAnalyzer/mqaUtil.d.ts +24 -0
  260. package/dist/types/transcription/index.d.ts +64 -0
  261. package/package.json +28 -21
  262. package/src/annotation/annotation.types.ts +52 -0
  263. package/src/annotation/constants.ts +36 -0
  264. package/src/annotation/index.ts +343 -0
  265. package/src/breakouts/README.md +220 -0
  266. package/src/breakouts/breakout.ts +180 -0
  267. package/src/breakouts/collection.ts +19 -0
  268. package/src/breakouts/edit-lock-error.ts +25 -0
  269. package/src/breakouts/events.ts +37 -0
  270. package/src/breakouts/index.ts +921 -0
  271. package/src/breakouts/request.ts +55 -0
  272. package/src/breakouts/utils.ts +57 -0
  273. package/src/common/errors/webex-errors.ts +6 -2
  274. package/src/common/logs/logger-proxy.ts +1 -1
  275. package/src/config.ts +5 -7
  276. package/src/constants.ts +155 -20
  277. package/src/controls-options-manager/constants.ts +5 -0
  278. package/src/controls-options-manager/enums.ts +18 -0
  279. package/src/controls-options-manager/index.ts +278 -0
  280. package/src/controls-options-manager/types.ts +59 -0
  281. package/src/controls-options-manager/util.ts +286 -0
  282. package/src/index.ts +34 -0
  283. package/src/locus-info/controlsUtils.ts +108 -0
  284. package/src/locus-info/index.ts +310 -21
  285. package/src/locus-info/mediaSharesUtils.ts +48 -0
  286. package/src/locus-info/parser.ts +2 -1
  287. package/src/locus-info/selfUtils.ts +80 -2
  288. package/src/media/index.ts +70 -142
  289. package/src/media/properties.ts +41 -104
  290. package/src/mediaQualityMetrics/config.ts +379 -377
  291. package/src/meeting/in-meeting-actions.ts +156 -0
  292. package/src/meeting/index.ts +1744 -1767
  293. package/src/meeting/locusMediaRequest.ts +309 -0
  294. package/src/meeting/muteState.ts +228 -132
  295. package/src/meeting/request.ts +100 -91
  296. package/src/meeting/request.type.ts +2 -0
  297. package/src/meeting/util.ts +421 -421
  298. package/src/meeting-info/meeting-info-v2.ts +134 -13
  299. package/src/meeting-info/utilv2.ts +13 -3
  300. package/src/meetings/collection.ts +20 -0
  301. package/src/meetings/index.ts +385 -83
  302. package/src/meetings/meetings.types.ts +12 -0
  303. package/src/meetings/request.ts +3 -1
  304. package/src/meetings/util.ts +103 -4
  305. package/src/member/index.ts +40 -0
  306. package/src/member/types.ts +24 -0
  307. package/src/member/util.ts +81 -1
  308. package/src/members/collection.ts +8 -0
  309. package/src/members/index.ts +108 -6
  310. package/src/members/request.ts +98 -17
  311. package/src/members/types.ts +28 -0
  312. package/src/members/util.ts +319 -240
  313. package/src/metrics/config.ts +49 -10
  314. package/src/metrics/constants.ts +2 -4
  315. package/src/metrics/index.ts +43 -27
  316. package/src/multistream/mediaRequestManager.ts +337 -63
  317. package/src/multistream/receiveSlot.ts +68 -26
  318. package/src/multistream/receiveSlotManager.ts +61 -38
  319. package/src/multistream/remoteMedia.ts +29 -3
  320. package/src/multistream/remoteMediaGroup.ts +61 -2
  321. package/src/multistream/remoteMediaManager.ts +260 -66
  322. package/src/networkQualityMonitor/index.ts +6 -6
  323. package/src/reachability/index.ts +75 -25
  324. package/src/reachability/request.ts +10 -5
  325. package/src/reactions/constants.ts +4 -0
  326. package/src/reactions/reactions.ts +4 -4
  327. package/src/reactions/reactions.type.ts +28 -3
  328. package/src/reconnection-manager/index.ts +53 -32
  329. package/src/recording-controller/enums.ts +8 -0
  330. package/src/recording-controller/index.ts +315 -0
  331. package/src/recording-controller/util.ts +58 -0
  332. package/src/roap/index.ts +21 -30
  333. package/src/roap/request.ts +51 -52
  334. package/src/roap/turnDiscovery.ts +51 -27
  335. package/src/statsAnalyzer/global.ts +1 -94
  336. package/src/statsAnalyzer/index.ts +380 -390
  337. package/src/statsAnalyzer/mqaUtil.ts +106 -99
  338. package/test/integration/spec/converged-space-meetings.js +233 -0
  339. package/test/integration/spec/journey.js +331 -254
  340. package/test/integration/spec/space-meeting.js +77 -4
  341. package/test/unit/spec/annotation/index.ts +436 -0
  342. package/test/unit/spec/breakouts/breakout.ts +233 -0
  343. package/test/unit/spec/breakouts/collection.ts +15 -0
  344. package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
  345. package/test/unit/spec/breakouts/events.ts +77 -0
  346. package/test/unit/spec/breakouts/index.ts +1790 -0
  347. package/test/unit/spec/breakouts/request.ts +104 -0
  348. package/test/unit/spec/breakouts/utils.js +72 -0
  349. package/test/unit/spec/controls-options-manager/index.js +287 -0
  350. package/test/unit/spec/controls-options-manager/util.js +518 -0
  351. package/test/unit/spec/fixture/locus.js +1 -0
  352. package/test/unit/spec/locus-info/controlsUtils.js +303 -30
  353. package/test/unit/spec/locus-info/index.js +616 -4
  354. package/test/unit/spec/locus-info/mediaSharesUtils.ts +22 -0
  355. package/test/unit/spec/locus-info/selfConstant.js +38 -0
  356. package/test/unit/spec/locus-info/selfUtils.js +249 -0
  357. package/test/unit/spec/media/index.ts +118 -22
  358. package/test/unit/spec/media/properties.ts +9 -9
  359. package/test/unit/spec/meeting/in-meeting-actions.ts +76 -0
  360. package/test/unit/spec/meeting/index.js +2496 -1375
  361. package/test/unit/spec/meeting/locusMediaRequest.ts +436 -0
  362. package/test/unit/spec/meeting/muteState.js +370 -208
  363. package/test/unit/spec/meeting/request.js +354 -42
  364. package/test/unit/spec/meeting/utils.js +268 -156
  365. package/test/unit/spec/meeting-info/meetinginfov2.js +383 -5
  366. package/test/unit/spec/meeting-info/utilv2.js +21 -0
  367. package/test/unit/spec/meetings/collection.js +14 -0
  368. package/test/unit/spec/meetings/index.js +866 -120
  369. package/test/unit/spec/meetings/utils.js +206 -2
  370. package/test/unit/spec/member/index.js +24 -0
  371. package/test/unit/spec/member/util.js +384 -32
  372. package/test/unit/spec/members/index.js +320 -1
  373. package/test/unit/spec/members/request.js +206 -27
  374. package/test/unit/spec/members/utils.js +184 -0
  375. package/test/unit/spec/metrics/index.js +98 -0
  376. package/test/unit/spec/multistream/mediaRequestManager.ts +1012 -109
  377. package/test/unit/spec/multistream/receiveSlot.ts +77 -18
  378. package/test/unit/spec/multistream/receiveSlotManager.ts +69 -39
  379. package/test/unit/spec/multistream/remoteMedia.ts +32 -2
  380. package/test/unit/spec/multistream/remoteMediaGroup.ts +271 -5
  381. package/test/unit/spec/multistream/remoteMediaManager.ts +672 -65
  382. package/test/unit/spec/networkQualityMonitor/index.js +4 -4
  383. package/test/unit/spec/reachability/index.ts +176 -25
  384. package/test/unit/spec/reachability/request.js +66 -0
  385. package/test/unit/spec/reconnection-manager/index.js +46 -13
  386. package/test/unit/spec/recording-controller/index.js +231 -0
  387. package/test/unit/spec/recording-controller/util.js +102 -0
  388. package/test/unit/spec/roap/index.ts +21 -51
  389. package/test/unit/spec/roap/request.ts +187 -0
  390. package/test/unit/spec/roap/turnDiscovery.ts +73 -34
  391. package/test/unit/spec/stats-analyzer/index.js +94 -43
  392. package/test/utils/constants.js +9 -0
  393. package/test/utils/integrationTestUtils.js +46 -0
  394. package/test/utils/testUtils.js +0 -45
  395. package/test/utils/webex-config.js +4 -0
  396. package/test/utils/webex-test-users.js +7 -3
  397. package/tsconfig.json +6 -0
  398. package/dist/media/internal-media-core-wrapper.js +0 -18
  399. package/dist/media/internal-media-core-wrapper.js.map +0 -1
  400. package/dist/meeting/effectsState.js +0 -262
  401. package/dist/meeting/effectsState.js.map +0 -1
  402. package/dist/multistream/multistreamMedia.js +0 -106
  403. package/dist/multistream/multistreamMedia.js.map +0 -1
  404. package/src/index.js +0 -15
  405. package/src/media/internal-media-core-wrapper.ts +0 -9
  406. package/src/meeting/effectsState.ts +0 -211
  407. package/src/multistream/multistreamMedia.ts +0 -93
  408. package/test/unit/spec/meeting/effectsState.js +0 -281
@@ -1,8 +1,17 @@
1
1
  import {assert} from '@webex/test-helper-chai';
2
+ import sinon from 'sinon';
2
3
 
3
4
  import MeetingsUtil from '@webex/plugin-meetings/src/meetings/util';
5
+ import Metrics from '@webex/plugin-meetings/src/metrics';
6
+ import BEHAVIORAL_METRICS from '@webex/plugin-meetings/src/metrics/constants';
4
7
 
5
8
  describe('plugin-meetings', () => {
9
+ beforeEach(() => {
10
+ sinon.stub(Metrics, 'sendBehavioralMetric');
11
+ });
12
+ afterEach(() => {
13
+ sinon.restore();
14
+ });
6
15
  describe('Meetings utils function', () => {
7
16
  describe('#parseDefaultSiteFromMeetingPreferences', () => {
8
17
  it('should return the default true site from user preferences', () => {
@@ -33,7 +42,7 @@ describe('plugin-meetings', () => {
33
42
  );
34
43
  });
35
44
 
36
- it('should work fine if no default true site', () => {
45
+ it('should take the first site if none are default', () => {
37
46
  const userPreferences = {
38
47
  sites: [
39
48
  {
@@ -51,7 +60,10 @@ describe('plugin-meetings', () => {
51
60
  ],
52
61
  };
53
62
 
54
- assert.equal(MeetingsUtil.parseDefaultSiteFromMeetingPreferences(userPreferences), '');
63
+ assert.equal(
64
+ MeetingsUtil.parseDefaultSiteFromMeetingPreferences(userPreferences),
65
+ 'site1-example.webex.com'
66
+ );
55
67
  });
56
68
 
57
69
  it('should work fine if sites an empty array', () => {
@@ -62,5 +74,197 @@ describe('plugin-meetings', () => {
62
74
  assert.equal(MeetingsUtil.parseDefaultSiteFromMeetingPreferences(userPreferences), '');
63
75
  });
64
76
  });
77
+
78
+ describe('#getThisDevice', () => {
79
+ it('return null if no devices in self', () => {
80
+ const newLocus = {};
81
+ assert.equal(MeetingsUtil.getThisDevice(newLocus, '123'), null);
82
+ });
83
+ it('return null if no matched device in self', () => {
84
+ const newLocus = {
85
+ self: {
86
+ devices: [{state: 'JOINED', url: '456'}]
87
+ }
88
+ };
89
+ assert.equal(MeetingsUtil.getThisDevice(newLocus, '123'), null);
90
+ });
91
+ it('return the device match with current device', () => {
92
+ const newLocus = {
93
+ self: {
94
+ devices: [{state: 'JOINED', url: '123'}]
95
+ }
96
+ };
97
+ assert.deepEqual(MeetingsUtil.getThisDevice(newLocus, '123'), {state: 'JOINED', url: '123'});
98
+ })
99
+ });
100
+
101
+ describe('#isBreakoutLocusDTO', () => {
102
+ it('returns false is no breakout in locus.controls', () => {
103
+ const newLocus = {
104
+ controls: {}
105
+ };
106
+
107
+ assert.equal(MeetingsUtil.isBreakoutLocusDTO(newLocus), false);
108
+ });
109
+
110
+ it('returns is breakout locus DTO if sessionType is BREAKOUT', () => {
111
+ const newLocus = {
112
+ controls: {
113
+ breakout: {
114
+ sessionType: 'BREAKOUT',
115
+ },
116
+ },
117
+ };
118
+ assert.equal(MeetingsUtil.isBreakoutLocusDTO(newLocus), true);
119
+ });
120
+
121
+ it('returns is not breakout locus DTO if sessionType is MAIN', () => {
122
+ const newLocus = {
123
+ controls: {
124
+ breakout: {
125
+ sessionType: 'MAIN',
126
+ },
127
+ },
128
+ };
129
+ assert.equal(MeetingsUtil.isBreakoutLocusDTO(newLocus), false);
130
+ });
131
+ });
132
+
133
+ describe('#joinedOnThisDevice', () => {
134
+ it('return false if no devices in self', () => {
135
+ const newLocus = {};
136
+ assert.equal(MeetingsUtil.joinedOnThisDevice(null, newLocus, '123'), false);
137
+ });
138
+ it('return true if joined on this device', () => {
139
+ const newLocus = {
140
+ self: {
141
+ devices: [{state: 'JOINED', correlationId: '111', url: '123'}]
142
+ }
143
+ };
144
+ const meeting = {
145
+ correlationId: '111'
146
+ };
147
+
148
+ assert.equal(MeetingsUtil.joinedOnThisDevice(meeting, newLocus, '123'), true);
149
+ });
150
+ it('return true if selfMoved on this device', () => {
151
+ const newLocus = {
152
+ self: {
153
+ devices: [{state: 'LEFT', reason: 'MOVED', correlationId: '111', url: '123'}]
154
+ }
155
+ };
156
+ const meeting = {
157
+ correlationId: '111'
158
+ };
159
+
160
+ assert.equal(MeetingsUtil.joinedOnThisDevice(meeting, newLocus, '123'), true);
161
+ });
162
+ });
163
+
164
+ describe("#handleRoapMercury", () => {
165
+ it('it sends the correct behaviour metric', () => {
166
+ const roapMessageReceived = sinon.stub();
167
+ const envelope = {
168
+ data: {
169
+ message:{
170
+ seq: "seq",
171
+ messageType: 'messageType',
172
+ tieBreaker: 'tieBreaker',
173
+ errorType: 'errorType',
174
+ errorCause: 'errorCause',
175
+ sdps: [{id:'sdp-1'}]
176
+ },
177
+ correlationId: 'correlationId',
178
+ eventType: 'locus.message.roap',
179
+ }
180
+ };
181
+ const meetingCollection = {
182
+ getByKey: () => ({
183
+ id: 'meeting-id',
184
+ mediaProperties: {
185
+ webrtcMediaConnection: {
186
+ roapMessageReceived
187
+ }
188
+ }
189
+ })
190
+ };
191
+
192
+ MeetingsUtil.handleRoapMercury(envelope, meetingCollection);
193
+ assert.calledWith(Metrics.sendBehavioralMetric, BEHAVIORAL_METRICS.ROAP_MERCURY_EVENT_RECEIVED, {
194
+ correlation_id: 'correlationId',
195
+ seq: "seq",
196
+ message_type: 'messageType',
197
+ error_type: 'errorType',
198
+ error_cause: 'errorCause',
199
+ })
200
+ assert.calledWith(roapMessageReceived, {
201
+ seq: "seq",
202
+ messageType: 'messageType',
203
+ errorType: 'errorType',
204
+ tieBreaker: 'tieBreaker',
205
+ errorCause: 'errorCause',
206
+ sdp: {id:'sdp-1'}
207
+ })
208
+
209
+ });
210
+ })
211
+ });
212
+
213
+ describe('#isValidBreakoutLocus', () => {
214
+ it('returns false if is not breakout locus', () => {
215
+ const newLocus = {
216
+ controls: {}
217
+ };
218
+
219
+ assert.equal(MeetingsUtil.isValidBreakoutLocus(newLocus), false);
220
+ });
221
+
222
+ it('returns false if fullState is inactive', () => {
223
+ const newLocus = {
224
+ controls: {
225
+ breakout: {
226
+ sessionType: 'BREAKOUT',
227
+ },
228
+ },
229
+ fullState: {
230
+ state: 'INACTIVE'
231
+ }
232
+ };
233
+ assert.equal(MeetingsUtil.isValidBreakoutLocus(newLocus), false);
234
+ });
235
+
236
+ it('returns false if self is not joined', () => {
237
+ const newLocus = {
238
+ controls: {
239
+ breakout: {
240
+ sessionType: 'BREAKOUT',
241
+ },
242
+ },
243
+ fullState: {
244
+ state: 'ACTIVE'
245
+ },
246
+ self: {
247
+ state: 'LEFT'
248
+ }
249
+ };
250
+ assert.equal(MeetingsUtil.isValidBreakoutLocus(newLocus), false);
251
+ });
252
+
253
+ it('returns true if self is JOINED and fullState is active', () => {
254
+ const newLocus = {
255
+ controls: {
256
+ breakout: {
257
+ sessionType: 'BREAKOUT',
258
+ },
259
+ },
260
+ fullState: {
261
+ state: 'ACTIVE'
262
+ },
263
+ self: {
264
+ state: 'JOINED'
265
+ }
266
+ };
267
+ assert.equal(MeetingsUtil.isValidBreakoutLocus(newLocus), true);
268
+ });
65
269
  });
66
270
  });
@@ -19,4 +19,28 @@ describe('member', () => {
19
19
 
20
20
  assert.calledOnceWithExactly(MemberUtil.isHandRaised, participant);
21
21
  });
22
+
23
+ describe('roles', () => {
24
+ it('checks that processParticipant calls processRoles', () => {
25
+ const participant = {};
26
+
27
+ const member = new Member({});
28
+
29
+ sinon.spy(member, 'processRoles');
30
+ member.processParticipant(participant);
31
+
32
+ assert.calledOnceWithExactly(member.processRoles, participant);
33
+ });
34
+
35
+ it('checks that processRoles calls extractControlRoles', () => {
36
+ const participant = {};
37
+
38
+ const member = new Member({});
39
+
40
+ sinon.spy(MemberUtil, 'extractControlRoles');
41
+ member.processParticipant(participant);
42
+
43
+ assert.calledOnceWithExactly(MemberUtil.extractControlRoles, participant);
44
+ });
45
+ })
22
46
  });
@@ -1,49 +1,401 @@
1
1
  import {assert} from '@webex/test-helper-chai';
2
-
3
2
  import MemberUtil from '@webex/plugin-meetings/src/member/util';
3
+ import { ServerRoles } from '../../../../src/member/types';
4
+
5
+ describe('plugin-meetings', () => {
6
+ describe('isHandRaised', () => {
7
+ it('throws error when there is no participant', () => {
8
+ assert.throws(() => {
9
+ MemberUtil.isHandRaised();
10
+ }, 'Raise hand could not be processed, participant is undefined.');
11
+ });
12
+
13
+ it('returns false when controls is not there', () => {
14
+ const participant = {};
15
+
16
+ assert.isFalse(MemberUtil.isHandRaised(participant));
17
+ });
18
+
19
+ it('returns false when hand is not there in controls', () => {
20
+ const participant = {
21
+ controls: {},
22
+ };
23
+
24
+ assert.isFalse(MemberUtil.isHandRaised(participant));
25
+ });
26
+
27
+ it('returns true when hand raised is true', () => {
28
+ const participant = {
29
+ controls: {
30
+ hand: {
31
+ raised: true,
32
+ },
33
+ },
34
+ };
4
35
 
5
- describe('isHandRaised', () => {
6
- it('throws error when there is no participant', () => {
7
- assert.throws(() => {
8
- MemberUtil.isHandRaised();
9
- }, 'Raise hand could not be processed, participant is undefined.');
36
+ assert.isTrue(MemberUtil.isHandRaised(participant));
37
+ });
38
+
39
+ it('returns false when hand raised is false', () => {
40
+ const participant = {
41
+ controls: {
42
+ hand: {
43
+ raised: false,
44
+ },
45
+ },
46
+ };
47
+
48
+ assert.isFalse(MemberUtil.isHandRaised(participant));
49
+ });
10
50
  });
11
51
 
12
- it('returns false when controls is not there', () => {
13
- const participant = {};
52
+ describe('MemberUtil.extractControlRoles', () => {
53
+ it('happy path extract control roles', () => {
54
+ const participant = {
55
+ controls: {
56
+ role: {
57
+ roles: [
58
+ {type: 'PRESENTER', hasRole: true},
59
+ {type: 'COHOST', hasRole: true},
60
+ {type: 'MODERATOR', hasRole: true},
61
+ ]
62
+ }
63
+ }
64
+ }
14
65
 
15
- assert.isFalse(MemberUtil.isHandRaised(participant));
66
+ assert.deepEqual(MemberUtil.extractControlRoles(participant), {cohost: true, moderator: true, presenter: true});
67
+ });
16
68
  });
17
69
 
18
- it('returns false when hand is not there in controls', () => {
19
- const participant = {
20
- controls: {},
21
- };
70
+ describe('MemberUtil.getControlsRoles', () => {
71
+ it('getControlsRoles', () => {
72
+ const participant = {
73
+ controls: {
74
+ role: {
75
+ roles: [
76
+ {type: 'PRESENTER', hasRole: true},
77
+ ]
78
+ }
79
+ }
80
+ }
22
81
 
23
- assert.isFalse(MemberUtil.isHandRaised(participant));
82
+ assert.deepEqual(MemberUtil.getControlsRoles(participant), [{type: 'PRESENTER', hasRole: true}]);
83
+ });
24
84
  });
25
85
 
26
- it('returns true when hand raised is true', () => {
27
- const participant = {
28
- controls: {
29
- hand: {
30
- raised: true,
31
- },
32
- },
33
- };
86
+ describe('MemberUtil.hasRole', () => {
87
+ describe('PRESENTER', () => {
88
+ it('getControlsRoles PRESENTER true', () => {
89
+ const participant = {
90
+ controls: {
91
+ role: {
92
+ roles: [
93
+ {type: 'PRESENTER', hasRole: true},
94
+ ]
95
+ }
96
+ }
97
+ }
98
+
99
+ assert.isTrue(MemberUtil.hasRole(participant, ServerRoles.Presenter));
100
+ });
101
+
102
+ it('getControlsRoles PRESENTER false', () => {
103
+ const participant = {
104
+ controls: {
105
+ role: {
106
+ roles: [
107
+ {type: 'PRESENTER', hasRole: false},
108
+ ]
109
+ }
110
+ }
111
+ }
112
+
113
+ assert.isFalse(MemberUtil.hasRole(participant, ServerRoles.Presenter));
114
+ });
34
115
 
35
- assert.isTrue(MemberUtil.isHandRaised(participant));
116
+ it('getControlsRoles PRESENTER undefined', () => {
117
+ const participant = {
118
+ controls: {
119
+ role: {
120
+ roles: [
121
+ {},
122
+ ]
123
+ }
124
+ }
125
+ }
126
+
127
+ assert.isFalse(MemberUtil.hasRole(participant, ServerRoles.Presenter));
128
+ });
129
+ })
130
+
131
+ describe('MODERATOR', () => {
132
+ it('getControlsRoles MODERATOR true', () => {
133
+ const participant = {
134
+ controls: {
135
+ role: {
136
+ roles: [
137
+ {type: 'MODERATOR', hasRole: true},
138
+ ]
139
+ }
140
+ }
141
+ }
142
+
143
+ assert.isTrue(MemberUtil.hasRole(participant, ServerRoles.Moderator));
144
+ });
145
+
146
+ it('getControlsRoles MODERATOR false', () => {
147
+ const participant = {
148
+ controls: {
149
+ role: {
150
+ roles: [
151
+ {type: 'MODERATOR', hasRole: false},
152
+ ]
153
+ }
154
+ }
155
+ }
156
+
157
+ assert.isFalse(MemberUtil.hasRole(participant, ServerRoles.Moderator));
158
+ });
159
+
160
+ it('getControlsRoles MODERATOR undefined', () => {
161
+ const participant = {
162
+ controls: {
163
+ role: {
164
+ roles: [
165
+ {},
166
+ ]
167
+ }
168
+ }
169
+ }
170
+
171
+ assert.isFalse(MemberUtil.hasRole(participant, ServerRoles.Moderator));
172
+ });
173
+ })
174
+
175
+ describe('COHOST', () => {
176
+ it('getControlsRoles COHOST true', () => {
177
+ const participant = {
178
+ controls: {
179
+ role: {
180
+ roles: [
181
+ {type: 'COHOST', hasRole: true},
182
+ ]
183
+ }
184
+ }
185
+ }
186
+
187
+ assert.isTrue(MemberUtil.hasRole(participant, ServerRoles.Cohost));
188
+ });
189
+
190
+ it('getControlsRoles COHOST false', () => {
191
+ const participant = {
192
+ controls: {
193
+ role: {
194
+ roles: [
195
+ {type: 'COHOST', hasRole: false},
196
+ ]
197
+ }
198
+ }
199
+ }
200
+
201
+ assert.isFalse(MemberUtil.hasRole(participant, ServerRoles.Cohost));
202
+ });
203
+
204
+ it('getControlsRoles COHOST undefined', () => {
205
+ const participant = {
206
+ controls: {
207
+ role: {
208
+ roles: [
209
+ {},
210
+ ]
211
+ }
212
+ }
213
+ }
214
+
215
+ assert.isFalse(MemberUtil.hasRole(participant, ServerRoles.Cohost));
216
+ });
217
+ })
36
218
  });
37
219
 
38
- it('returns false when hand raised is false', () => {
39
- const participant = {
40
- controls: {
41
- hand: {
42
- raised: false,
43
- },
44
- },
45
- };
220
+ describe('MemberUtil.is<Role>', () => {
221
+ describe('PRESENTER', () => {
222
+ it('getControlsRoles PRESENTER true', () => {
223
+ const participant = {
224
+ controls: {
225
+ role: {
226
+ roles: [
227
+ {type: 'PRESENTER', hasRole: true},
228
+ ]
229
+ }
230
+ }
231
+ }
232
+
233
+ assert.isTrue(MemberUtil.hasPresenter(participant, ServerRoles.Presenter));
234
+ });
235
+
236
+ it('getControlsRoles PRESENTER false', () => {
237
+ const participant = {
238
+ controls: {
239
+ role: {
240
+ roles: [
241
+ {type: 'PRESENTER', hasRole: false},
242
+ ]
243
+ }
244
+ }
245
+ }
246
+
247
+ assert.isFalse(MemberUtil.hasPresenter(participant));
248
+ });
249
+
250
+ it('getControlsRoles PRESENTER undefined', () => {
251
+ const participant = {
252
+ controls: {
253
+ role: {
254
+ roles: [
255
+ {},
256
+ ]
257
+ }
258
+ }
259
+ }
260
+
261
+ assert.isFalse(MemberUtil.hasPresenter(participant));
262
+ });
263
+ })
264
+
265
+ describe('MODERATOR', () => {
266
+ it('getControlsRoles MODERATOR true', () => {
267
+ const participant = {
268
+ controls: {
269
+ role: {
270
+ roles: [
271
+ {type: 'MODERATOR', hasRole: true},
272
+ ]
273
+ }
274
+ }
275
+ }
276
+
277
+ assert.isTrue(MemberUtil.hasModerator(participant));
278
+ });
279
+
280
+ it('getControlsRoles MODERATOR false', () => {
281
+ const participant = {
282
+ controls: {
283
+ role: {
284
+ roles: [
285
+ {type: 'MODERATOR', hasRole: false},
286
+ ]
287
+ }
288
+ }
289
+ }
290
+
291
+ assert.isFalse(MemberUtil.hasModerator(participant));
292
+ });
293
+
294
+ it('getControlsRoles MODERATOR undefined', () => {
295
+ const participant = {
296
+ controls: {
297
+ role: {
298
+ roles: [
299
+ {},
300
+ ]
301
+ }
302
+ }
303
+ }
304
+
305
+ assert.isFalse(MemberUtil.hasModerator(participant));
306
+ });
307
+ })
308
+
309
+ describe('COHOST', () => {
310
+ it('getControlsRoles COHOST true', () => {
311
+ const participant = {
312
+ controls: {
313
+ role: {
314
+ roles: [
315
+ {type: 'COHOST', hasRole: true},
316
+ ]
317
+ }
318
+ }
319
+ }
320
+
321
+ assert.isTrue(MemberUtil.hasCohost(participant));
322
+ });
323
+
324
+ it('getControlsRoles COHOST false', () => {
325
+ const participant = {
326
+ controls: {
327
+ role: {
328
+ roles: [
329
+ {type: 'COHOST', hasRole: false},
330
+ ]
331
+ }
332
+ }
333
+ }
334
+
335
+ assert.isFalse(MemberUtil.hasCohost(participant));
336
+ });
337
+
338
+ it('getControlsRoles COHOST undefined', () => {
339
+ const participant = {
340
+ controls: {
341
+ role: {
342
+ roles: [
343
+ {},
344
+ ]
345
+ }
346
+ }
347
+ }
348
+
349
+ assert.isFalse(MemberUtil.hasCohost(participant));
350
+ });
351
+ })
352
+ });
353
+
354
+ describe('MemberUtil.isBreakoutsSupported', () => {
355
+ it('throws error when there is no participant', () => {
356
+ assert.throws(() => {
357
+ MemberUtil.isBreakoutsSupported();
358
+ }, 'Breakout support could not be processed, participant is undefined.');
359
+ });
360
+
361
+ it('returns true when hand breakouts are supported', () => {
362
+ const participant = {
363
+ doesNotSupportBreakouts: false
364
+ };
365
+
366
+ assert.isTrue(MemberUtil.isBreakoutsSupported(participant));
367
+ });
368
+
369
+ it('returns false when hand breakouts are not supported', () => {
370
+ const participant = {
371
+ doesNotSupportBreakouts: true
372
+ };
373
+
374
+ assert.isFalse(MemberUtil.isBreakoutsSupported(participant));
375
+ });
376
+ });
377
+
378
+ describe('MemberUtil.isLiveAnnotationSupported', () => {
379
+ it('throws error when there is no participant', () => {
380
+ assert.throws(() => {
381
+ MemberUtil.isLiveAnnotationSupported();
382
+ }, 'LiveAnnotation support could not be processed, participant is undefined.');
383
+ });
384
+
385
+ it('returns true when hand live annotation are supported', () => {
386
+ const participant = {
387
+ annotatorAssignmentNotAllowed: false
388
+ };
389
+
390
+ assert.isTrue(MemberUtil.isLiveAnnotationSupported(participant));
391
+ });
392
+
393
+ it('returns false when hand live annotation are not supported', () => {
394
+ const participant = {
395
+ annotatorAssignmentNotAllowed: true
396
+ };
46
397
 
47
- assert.isFalse(MemberUtil.isHandRaised(participant));
398
+ assert.isFalse(MemberUtil.isLiveAnnotationSupported(participant));
399
+ });
48
400
  });
49
401
  });