@webex/plugin-meetings 3.0.0-beta.7 → 3.0.0-beta.71

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (506) hide show
  1. package/UPGRADING.md +9 -9
  2. package/browsers.js +19 -24
  3. package/dist/breakouts/breakout.js +178 -0
  4. package/dist/breakouts/breakout.js.map +1 -0
  5. package/dist/breakouts/collection.js +23 -0
  6. package/dist/breakouts/collection.js.map +1 -0
  7. package/dist/breakouts/edit-lock-error.js +52 -0
  8. package/dist/breakouts/edit-lock-error.js.map +1 -0
  9. package/dist/breakouts/index.js +843 -0
  10. package/dist/breakouts/index.js.map +1 -0
  11. package/dist/breakouts/request.js +78 -0
  12. package/dist/breakouts/request.js.map +1 -0
  13. package/dist/breakouts/utils.js +56 -0
  14. package/dist/breakouts/utils.js.map +1 -0
  15. package/dist/common/browser-detection.js +1 -20
  16. package/dist/common/browser-detection.js.map +1 -1
  17. package/dist/common/collection.js +5 -20
  18. package/dist/common/collection.js.map +1 -1
  19. package/dist/common/config.js +0 -7
  20. package/dist/common/config.js.map +1 -1
  21. package/dist/common/errors/captcha-error.js +10 -24
  22. package/dist/common/errors/captcha-error.js.map +1 -1
  23. package/dist/common/errors/intent-to-join.js +11 -24
  24. package/dist/common/errors/intent-to-join.js.map +1 -1
  25. package/dist/common/errors/join-meeting.js +12 -25
  26. package/dist/common/errors/join-meeting.js.map +1 -1
  27. package/dist/common/errors/media.js +10 -24
  28. package/dist/common/errors/media.js.map +1 -1
  29. package/dist/common/errors/parameter.js +5 -33
  30. package/dist/common/errors/parameter.js.map +1 -1
  31. package/dist/common/errors/password-error.js +10 -24
  32. package/dist/common/errors/password-error.js.map +1 -1
  33. package/dist/common/errors/permission.js +9 -23
  34. package/dist/common/errors/permission.js.map +1 -1
  35. package/dist/common/errors/reconnection-in-progress.js +0 -17
  36. package/dist/common/errors/reconnection-in-progress.js.map +1 -1
  37. package/dist/common/errors/reconnection.js +10 -24
  38. package/dist/common/errors/reconnection.js.map +1 -1
  39. package/dist/common/errors/stats.js +10 -24
  40. package/dist/common/errors/stats.js.map +1 -1
  41. package/dist/common/errors/webex-errors.js +6 -41
  42. package/dist/common/errors/webex-errors.js.map +1 -1
  43. package/dist/common/errors/webex-meetings-error.js +5 -25
  44. package/dist/common/errors/webex-meetings-error.js.map +1 -1
  45. package/dist/common/events/events-scope.js +0 -22
  46. package/dist/common/events/events-scope.js.map +1 -1
  47. package/dist/common/events/events.js +0 -23
  48. package/dist/common/events/events.js.map +1 -1
  49. package/dist/common/events/trigger-proxy.js +0 -12
  50. package/dist/common/events/trigger-proxy.js.map +1 -1
  51. package/dist/common/events/util.js +0 -15
  52. package/dist/common/events/util.js.map +1 -1
  53. package/dist/common/logs/logger-config.js +0 -4
  54. package/dist/common/logs/logger-config.js.map +1 -1
  55. package/dist/common/logs/logger-proxy.js +1 -8
  56. package/dist/common/logs/logger-proxy.js.map +1 -1
  57. package/dist/common/logs/request.js +37 -60
  58. package/dist/common/logs/request.js.map +1 -1
  59. package/dist/common/queue.js +4 -14
  60. package/dist/common/queue.js.map +1 -1
  61. package/dist/config.js +6 -6
  62. package/dist/config.js.map +1 -1
  63. package/dist/constants.js +143 -52
  64. package/dist/constants.js.map +1 -1
  65. package/dist/controls-options-manager/constants.js +14 -0
  66. package/dist/controls-options-manager/constants.js.map +1 -0
  67. package/dist/controls-options-manager/enums.js +16 -0
  68. package/dist/controls-options-manager/enums.js.map +1 -0
  69. package/dist/controls-options-manager/index.js +261 -0
  70. package/dist/controls-options-manager/index.js.map +1 -0
  71. package/dist/controls-options-manager/util.js +39 -0
  72. package/dist/controls-options-manager/util.js.map +1 -0
  73. package/dist/index.js +11 -18
  74. package/dist/index.js.map +1 -1
  75. package/dist/locus-info/controlsUtils.js +31 -29
  76. package/dist/locus-info/controlsUtils.js.map +1 -1
  77. package/dist/locus-info/embeddedAppsUtils.js +3 -26
  78. package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
  79. package/dist/locus-info/fullState.js +0 -15
  80. package/dist/locus-info/fullState.js.map +1 -1
  81. package/dist/locus-info/hostUtils.js +4 -12
  82. package/dist/locus-info/hostUtils.js.map +1 -1
  83. package/dist/locus-info/index.js +237 -198
  84. package/dist/locus-info/index.js.map +1 -1
  85. package/dist/locus-info/infoUtils.js +3 -37
  86. package/dist/locus-info/infoUtils.js.map +1 -1
  87. package/dist/locus-info/mediaSharesUtils.js +12 -38
  88. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  89. package/dist/locus-info/parser.js +92 -118
  90. package/dist/locus-info/parser.js.map +1 -1
  91. package/dist/locus-info/selfUtils.js +80 -89
  92. package/dist/locus-info/selfUtils.js.map +1 -1
  93. package/dist/media/index.js +56 -146
  94. package/dist/media/index.js.map +1 -1
  95. package/dist/media/properties.js +83 -117
  96. package/dist/media/properties.js.map +1 -1
  97. package/dist/media/util.js +2 -9
  98. package/dist/media/util.js.map +1 -1
  99. package/dist/mediaQualityMetrics/config.js +505 -495
  100. package/dist/mediaQualityMetrics/config.js.map +1 -1
  101. package/dist/meeting/in-meeting-actions.js +31 -14
  102. package/dist/meeting/in-meeting-actions.js.map +1 -1
  103. package/dist/meeting/index.js +2225 -2244
  104. package/dist/meeting/index.js.map +1 -1
  105. package/dist/meeting/muteState.js +102 -100
  106. package/dist/meeting/muteState.js.map +1 -1
  107. package/dist/meeting/request.js +308 -264
  108. package/dist/meeting/request.js.map +1 -1
  109. package/dist/meeting/request.type.js +7 -0
  110. package/dist/meeting/request.type.js.map +1 -0
  111. package/dist/meeting/state.js +21 -31
  112. package/dist/meeting/state.js.map +1 -1
  113. package/dist/meeting/util.js +63 -217
  114. package/dist/meeting/util.js.map +1 -1
  115. package/dist/meeting-info/collection.js +6 -25
  116. package/dist/meeting-info/collection.js.map +1 -1
  117. package/dist/meeting-info/index.js +14 -32
  118. package/dist/meeting-info/index.js.map +1 -1
  119. package/dist/meeting-info/meeting-info-v2.js +193 -268
  120. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  121. package/dist/meeting-info/request.js +3 -15
  122. package/dist/meeting-info/request.js.map +1 -1
  123. package/dist/meeting-info/util.js +98 -183
  124. package/dist/meeting-info/util.js.map +1 -1
  125. package/dist/meeting-info/utilv2.js +137 -228
  126. package/dist/meeting-info/utilv2.js.map +1 -1
  127. package/dist/meetings/collection.js +26 -19
  128. package/dist/meetings/collection.js.map +1 -1
  129. package/dist/meetings/index.js +565 -552
  130. package/dist/meetings/index.js.map +1 -1
  131. package/dist/meetings/request.js +26 -41
  132. package/dist/meetings/request.js.map +1 -1
  133. package/dist/meetings/util.js +151 -155
  134. package/dist/meetings/util.js.map +1 -1
  135. package/dist/member/index.js +100 -85
  136. package/dist/member/index.js.map +1 -1
  137. package/dist/member/types.js +15 -0
  138. package/dist/member/types.js.map +1 -0
  139. package/dist/member/util.js +90 -68
  140. package/dist/member/util.js.map +1 -1
  141. package/dist/members/collection.js +13 -12
  142. package/dist/members/collection.js.map +1 -1
  143. package/dist/members/index.js +152 -204
  144. package/dist/members/index.js.map +1 -1
  145. package/dist/members/request.js +35 -39
  146. package/dist/members/request.js.map +1 -1
  147. package/dist/members/types.js +15 -0
  148. package/dist/members/types.js.map +1 -0
  149. package/dist/members/util.js +76 -46
  150. package/dist/members/util.js.map +1 -1
  151. package/dist/metrics/config.js +4 -14
  152. package/dist/metrics/config.js.map +1 -1
  153. package/dist/metrics/constants.js +1 -6
  154. package/dist/metrics/constants.js.map +1 -1
  155. package/dist/metrics/index.js +59 -156
  156. package/dist/metrics/index.js.map +1 -1
  157. package/dist/multistream/mediaRequestManager.js +116 -52
  158. package/dist/multistream/mediaRequestManager.js.map +1 -1
  159. package/dist/multistream/receiveSlot.js +58 -65
  160. package/dist/multistream/receiveSlot.js.map +1 -1
  161. package/dist/multistream/receiveSlotManager.js +58 -93
  162. package/dist/multistream/receiveSlotManager.js.map +1 -1
  163. package/dist/multistream/remoteMedia.js +55 -74
  164. package/dist/multistream/remoteMedia.js.map +1 -1
  165. package/dist/multistream/remoteMediaGroup.js +6 -40
  166. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  167. package/dist/multistream/remoteMediaManager.js +466 -442
  168. package/dist/multistream/remoteMediaManager.js.map +1 -1
  169. package/dist/networkQualityMonitor/index.js +40 -59
  170. package/dist/networkQualityMonitor/index.js.map +1 -1
  171. package/dist/personal-meeting-room/index.js +21 -45
  172. package/dist/personal-meeting-room/index.js.map +1 -1
  173. package/dist/personal-meeting-room/request.js +1 -31
  174. package/dist/personal-meeting-room/request.js.map +1 -1
  175. package/dist/personal-meeting-room/util.js +0 -13
  176. package/dist/personal-meeting-room/util.js.map +1 -1
  177. package/dist/reachability/index.js +192 -191
  178. package/dist/reachability/index.js.map +1 -1
  179. package/dist/reachability/request.js +15 -23
  180. package/dist/reachability/request.js.map +1 -1
  181. package/dist/reactions/constants.js +13 -0
  182. package/dist/reactions/constants.js.map +1 -0
  183. package/dist/reactions/reactions.js +109 -0
  184. package/dist/reactions/reactions.js.map +1 -0
  185. package/dist/reactions/reactions.type.js +36 -0
  186. package/dist/reactions/reactions.type.js.map +1 -0
  187. package/dist/reconnection-manager/index.js +342 -460
  188. package/dist/reconnection-manager/index.js.map +1 -1
  189. package/dist/recording-controller/enums.js +17 -0
  190. package/dist/recording-controller/enums.js.map +1 -0
  191. package/dist/recording-controller/index.js +343 -0
  192. package/dist/recording-controller/index.js.map +1 -0
  193. package/dist/recording-controller/util.js +63 -0
  194. package/dist/recording-controller/util.js.map +1 -0
  195. package/dist/roap/index.js +48 -70
  196. package/dist/roap/index.js.map +1 -1
  197. package/dist/roap/request.js +143 -131
  198. package/dist/roap/request.js.map +1 -1
  199. package/dist/roap/turnDiscovery.js +91 -98
  200. package/dist/roap/turnDiscovery.js.map +1 -1
  201. package/dist/statsAnalyzer/global.js +1 -95
  202. package/dist/statsAnalyzer/global.js.map +1 -1
  203. package/dist/statsAnalyzer/index.js +372 -455
  204. package/dist/statsAnalyzer/index.js.map +1 -1
  205. package/dist/statsAnalyzer/mqaUtil.js +143 -87
  206. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  207. package/dist/transcription/index.js +22 -47
  208. package/dist/transcription/index.js.map +1 -1
  209. package/dist/types/breakouts/breakout.d.ts +8 -0
  210. package/dist/types/breakouts/collection.d.ts +5 -0
  211. package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
  212. package/dist/types/breakouts/index.d.ts +5 -0
  213. package/dist/types/breakouts/request.d.ts +22 -0
  214. package/dist/types/breakouts/utils.d.ts +8 -0
  215. package/dist/types/common/browser-detection.d.ts +9 -0
  216. package/dist/types/common/collection.d.ts +48 -0
  217. package/dist/types/common/config.d.ts +2 -0
  218. package/dist/types/common/errors/captcha-error.d.ts +15 -0
  219. package/dist/types/common/errors/intent-to-join.d.ts +16 -0
  220. package/dist/types/common/errors/join-meeting.d.ts +17 -0
  221. package/dist/types/common/errors/media.d.ts +15 -0
  222. package/dist/types/common/errors/parameter.d.ts +15 -0
  223. package/dist/types/common/errors/password-error.d.ts +15 -0
  224. package/dist/types/common/errors/permission.d.ts +14 -0
  225. package/dist/types/common/errors/reconnection-in-progress.d.ts +9 -0
  226. package/dist/types/common/errors/reconnection.d.ts +15 -0
  227. package/dist/types/common/errors/stats.d.ts +15 -0
  228. package/dist/types/common/errors/webex-errors.d.ts +69 -0
  229. package/dist/types/common/errors/webex-meetings-error.d.ts +20 -0
  230. package/dist/types/common/events/events-scope.d.ts +17 -0
  231. package/dist/types/common/events/events.d.ts +12 -0
  232. package/dist/types/common/events/trigger-proxy.d.ts +2 -0
  233. package/dist/types/common/events/util.d.ts +2 -0
  234. package/dist/types/common/logs/logger-config.d.ts +2 -0
  235. package/dist/types/common/logs/logger-proxy.d.ts +2 -0
  236. package/dist/types/common/logs/request.d.ts +34 -0
  237. package/dist/types/common/queue.d.ts +32 -0
  238. package/dist/types/config.d.ts +77 -0
  239. package/dist/types/constants.d.ts +944 -0
  240. package/dist/types/controls-options-manager/constants.d.ts +4 -0
  241. package/dist/types/controls-options-manager/enums.d.ts +6 -0
  242. package/dist/types/controls-options-manager/index.d.ts +128 -0
  243. package/dist/types/controls-options-manager/util.d.ts +9 -0
  244. package/dist/types/index.d.ts +6 -0
  245. package/dist/types/locus-info/controlsUtils.d.ts +2 -0
  246. package/dist/types/locus-info/embeddedAppsUtils.d.ts +2 -0
  247. package/dist/types/locus-info/fullState.d.ts +2 -0
  248. package/dist/types/locus-info/hostUtils.d.ts +2 -0
  249. package/dist/types/locus-info/index.d.ts +276 -0
  250. package/dist/types/locus-info/infoUtils.d.ts +2 -0
  251. package/dist/types/locus-info/mediaSharesUtils.d.ts +2 -0
  252. package/dist/types/locus-info/parser.d.ts +212 -0
  253. package/dist/types/locus-info/selfUtils.d.ts +2 -0
  254. package/dist/types/media/index.d.ts +32 -0
  255. package/dist/types/media/properties.d.ts +108 -0
  256. package/dist/types/media/util.d.ts +2 -0
  257. package/dist/types/mediaQualityMetrics/config.d.ts +365 -0
  258. package/dist/types/meeting/in-meeting-actions.d.ts +101 -0
  259. package/dist/types/meeting/index.d.ts +1720 -0
  260. package/dist/types/meeting/muteState.d.ts +132 -0
  261. package/dist/types/meeting/request.d.ts +271 -0
  262. package/dist/types/meeting/request.type.d.ts +11 -0
  263. package/dist/types/meeting/state.d.ts +9 -0
  264. package/dist/types/meeting/util.d.ts +2 -0
  265. package/dist/types/meeting-info/collection.d.ts +20 -0
  266. package/dist/types/meeting-info/index.d.ts +57 -0
  267. package/dist/types/meeting-info/meeting-info-v2.d.ts +93 -0
  268. package/dist/types/meeting-info/request.d.ts +22 -0
  269. package/dist/types/meeting-info/util.d.ts +2 -0
  270. package/dist/types/meeting-info/utilv2.d.ts +2 -0
  271. package/dist/types/meetings/collection.d.ts +31 -0
  272. package/dist/types/meetings/index.d.ts +315 -0
  273. package/dist/types/meetings/request.d.ts +27 -0
  274. package/dist/types/meetings/util.d.ts +18 -0
  275. package/dist/types/member/index.d.ts +156 -0
  276. package/dist/types/member/types.d.ts +21 -0
  277. package/dist/types/member/util.d.ts +2 -0
  278. package/dist/types/members/collection.d.ts +29 -0
  279. package/dist/types/members/index.d.ts +343 -0
  280. package/dist/types/members/request.d.ts +58 -0
  281. package/dist/types/members/types.d.ts +24 -0
  282. package/dist/types/members/util.d.ts +2 -0
  283. package/dist/types/metrics/config.d.ts +171 -0
  284. package/dist/types/metrics/constants.d.ts +53 -0
  285. package/dist/types/metrics/index.d.ts +152 -0
  286. package/dist/types/multistream/mediaRequestManager.d.ts +68 -0
  287. package/dist/types/multistream/receiveSlot.d.ts +68 -0
  288. package/dist/types/multistream/receiveSlotManager.d.ts +49 -0
  289. package/dist/types/multistream/remoteMedia.d.ts +100 -0
  290. package/dist/types/multistream/remoteMediaGroup.d.ts +56 -0
  291. package/dist/types/multistream/remoteMediaManager.d.ts +263 -0
  292. package/dist/types/networkQualityMonitor/index.d.ts +70 -0
  293. package/dist/types/personal-meeting-room/index.d.ts +47 -0
  294. package/dist/types/personal-meeting-room/request.d.ts +14 -0
  295. package/dist/types/personal-meeting-room/util.d.ts +2 -0
  296. package/dist/types/reachability/index.d.ts +152 -0
  297. package/dist/types/reachability/request.d.ts +37 -0
  298. package/dist/types/reactions/constants.d.ts +3 -0
  299. package/dist/types/reactions/reactions.d.ts +4 -0
  300. package/dist/types/reactions/reactions.type.d.ts +52 -0
  301. package/dist/types/reconnection-manager/index.d.ts +126 -0
  302. package/dist/types/recording-controller/enums.d.ts +7 -0
  303. package/dist/types/recording-controller/index.d.ts +193 -0
  304. package/dist/types/recording-controller/util.d.ts +13 -0
  305. package/dist/types/roap/index.d.ts +77 -0
  306. package/dist/types/roap/request.d.ts +38 -0
  307. package/dist/types/roap/turnDiscovery.d.ts +74 -0
  308. package/dist/types/statsAnalyzer/global.d.ts +36 -0
  309. package/dist/types/statsAnalyzer/index.d.ts +195 -0
  310. package/dist/types/statsAnalyzer/mqaUtil.d.ts +24 -0
  311. package/dist/types/transcription/index.d.ts +64 -0
  312. package/internal-README.md +7 -6
  313. package/package.json +27 -21
  314. package/src/breakouts/README.md +219 -0
  315. package/src/breakouts/breakout.ts +153 -0
  316. package/src/breakouts/collection.ts +19 -0
  317. package/src/breakouts/edit-lock-error.ts +25 -0
  318. package/src/breakouts/index.ts +745 -0
  319. package/src/breakouts/request.ts +55 -0
  320. package/src/breakouts/utils.ts +44 -0
  321. package/src/common/{browser-detection.js → browser-detection.ts} +9 -6
  322. package/src/common/collection.ts +9 -7
  323. package/src/common/{config.js → config.ts} +1 -1
  324. package/src/common/errors/{captcha-error.js → captcha-error.ts} +11 -7
  325. package/src/common/errors/{intent-to-join.js → intent-to-join.ts} +12 -7
  326. package/src/common/errors/{join-meeting.js → join-meeting.ts} +17 -8
  327. package/src/common/errors/{media.js → media.ts} +11 -7
  328. package/src/common/errors/parameter.ts +11 -7
  329. package/src/common/errors/{password-error.js → password-error.ts} +11 -7
  330. package/src/common/errors/{permission.js → permission.ts} +10 -6
  331. package/src/common/errors/{reconnection.js → reconnection.ts} +11 -7
  332. package/src/common/errors/{stats.js → stats.ts} +11 -7
  333. package/src/common/errors/{webex-errors.js → webex-errors.ts} +8 -7
  334. package/src/common/errors/{webex-meetings-error.js → webex-meetings-error.ts} +4 -2
  335. package/src/common/events/{events-scope.js → events-scope.ts} +6 -2
  336. package/src/common/events/{events.js → events.ts} +5 -1
  337. package/src/common/events/{trigger-proxy.js → trigger-proxy.ts} +9 -5
  338. package/src/common/events/{util.js → util.ts} +2 -3
  339. package/src/common/logs/{logger-config.js → logger-config.ts} +1 -2
  340. package/src/common/logs/logger-proxy.ts +44 -0
  341. package/src/common/logs/{request.js → request.ts} +22 -9
  342. package/src/common/queue.ts +1 -2
  343. package/src/{config.js → config.ts} +17 -12
  344. package/src/constants.ts +92 -5
  345. package/src/controls-options-manager/constants.ts +5 -0
  346. package/src/controls-options-manager/enums.ts +7 -0
  347. package/src/controls-options-manager/index.ts +240 -0
  348. package/src/controls-options-manager/util.ts +30 -0
  349. package/src/index.js +4 -1
  350. package/src/locus-info/controlsUtils.ts +141 -0
  351. package/src/locus-info/{embeddedAppsUtils.js → embeddedAppsUtils.ts} +5 -6
  352. package/src/locus-info/{fullState.js → fullState.ts} +16 -12
  353. package/src/locus-info/{hostUtils.js → hostUtils.ts} +9 -8
  354. package/src/locus-info/{index.js → index.ts} +211 -71
  355. package/src/locus-info/{infoUtils.js → infoUtils.ts} +19 -8
  356. package/src/locus-info/{mediaSharesUtils.js → mediaSharesUtils.ts} +17 -17
  357. package/src/locus-info/{parser.js → parser.ts} +67 -79
  358. package/src/locus-info/{selfUtils.js → selfUtils.ts} +183 -67
  359. package/src/media/{index.js → index.ts} +179 -176
  360. package/src/media/{properties.js → properties.ts} +60 -37
  361. package/src/media/{util.js → util.ts} +2 -2
  362. package/src/mediaQualityMetrics/config.ts +384 -0
  363. package/src/meeting/in-meeting-actions.ts +67 -3
  364. package/src/meeting/{index.js → index.ts} +2605 -1605
  365. package/src/meeting/{muteState.js → muteState.ts} +138 -73
  366. package/src/meeting/{request.js → request.ts} +326 -142
  367. package/src/meeting/request.type.ts +13 -0
  368. package/src/meeting/{state.js → state.ts} +50 -35
  369. package/src/meeting/{util.js → util.ts} +131 -115
  370. package/src/meeting-info/{collection.js → collection.ts} +6 -2
  371. package/src/meeting-info/{index.js → index.ts} +42 -36
  372. package/src/meeting-info/meeting-info-v2.ts +273 -0
  373. package/src/meeting-info/{request.js → request.ts} +14 -4
  374. package/src/meeting-info/{util.js → util.ts} +60 -51
  375. package/src/meeting-info/{utilv2.js → utilv2.ts} +65 -58
  376. package/src/meetings/{collection.js → collection.ts} +26 -3
  377. package/src/meetings/index.ts +1275 -0
  378. package/src/meetings/{request.js → request.ts} +34 -25
  379. package/src/meetings/{util.js → util.ts} +99 -33
  380. package/src/member/{index.js → index.ts} +124 -56
  381. package/src/member/types.ts +24 -0
  382. package/src/member/{util.js → util.ts} +105 -25
  383. package/src/members/{collection.js → collection.ts} +10 -2
  384. package/src/members/{index.js → index.ts} +281 -144
  385. package/src/members/{request.js → request.ts} +80 -16
  386. package/src/members/types.ts +28 -0
  387. package/src/members/{util.js → util.ts} +108 -55
  388. package/src/metrics/{config.js → config.ts} +255 -92
  389. package/src/metrics/{constants.js → constants.ts} +0 -6
  390. package/src/metrics/{index.js → index.ts} +110 -94
  391. package/src/multistream/mediaRequestManager.ts +144 -40
  392. package/src/multistream/receiveSlot.ts +69 -26
  393. package/src/multistream/receiveSlotManager.ts +50 -38
  394. package/src/multistream/remoteMedia.ts +30 -4
  395. package/src/multistream/remoteMediaGroup.ts +4 -3
  396. package/src/multistream/remoteMediaManager.ts +230 -66
  397. package/src/networkQualityMonitor/{index.js → index.ts} +41 -29
  398. package/src/personal-meeting-room/{index.js → index.ts} +28 -19
  399. package/src/personal-meeting-room/{request.js → request.ts} +13 -4
  400. package/src/personal-meeting-room/{util.js → util.ts} +4 -4
  401. package/src/reachability/{index.js → index.ts} +157 -94
  402. package/src/reachability/request.ts +46 -35
  403. package/src/reactions/constants.ts +4 -0
  404. package/src/reactions/reactions.ts +104 -0
  405. package/src/reactions/reactions.type.ts +62 -0
  406. package/src/reconnection-manager/{index.js → index.ts} +228 -120
  407. package/src/recording-controller/enums.ts +8 -0
  408. package/src/recording-controller/index.ts +315 -0
  409. package/src/recording-controller/util.ts +58 -0
  410. package/src/roap/{index.js → index.ts} +77 -60
  411. package/src/roap/request.ts +172 -0
  412. package/src/roap/turnDiscovery.ts +81 -41
  413. package/src/statsAnalyzer/global.ts +37 -0
  414. package/src/statsAnalyzer/index.ts +1242 -0
  415. package/src/statsAnalyzer/mqaUtil.ts +291 -0
  416. package/src/transcription/{index.js → index.ts} +46 -39
  417. package/test/integration/spec/converged-space-meetings.js +176 -0
  418. package/test/integration/spec/journey.js +665 -464
  419. package/test/integration/spec/space-meeting.js +320 -206
  420. package/test/integration/spec/transcription.js +7 -8
  421. package/test/unit/spec/breakouts/breakout.ts +178 -0
  422. package/test/unit/spec/breakouts/collection.ts +15 -0
  423. package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
  424. package/test/unit/spec/breakouts/index.ts +1252 -0
  425. package/test/unit/spec/breakouts/request.ts +104 -0
  426. package/test/unit/spec/breakouts/utils.js +54 -0
  427. package/test/unit/spec/common/browser-detection.js +9 -28
  428. package/test/unit/spec/controls-options-manager/index.js +204 -0
  429. package/test/unit/spec/controls-options-manager/util.js +86 -0
  430. package/test/unit/spec/fixture/locus.js +92 -90
  431. package/test/unit/spec/locus-info/controlsUtils.js +133 -34
  432. package/test/unit/spec/locus-info/embeddedAppsUtils.js +8 -6
  433. package/test/unit/spec/locus-info/index.js +303 -2
  434. package/test/unit/spec/locus-info/infoUtils.js +41 -32
  435. package/test/unit/spec/locus-info/lib/BasicSeqCmp.json +88 -430
  436. package/test/unit/spec/locus-info/lib/SeqCmp.json +513 -685
  437. package/test/unit/spec/locus-info/parser.js +3 -9
  438. package/test/unit/spec/locus-info/selfConstant.js +101 -103
  439. package/test/unit/spec/locus-info/selfUtils.js +165 -12
  440. package/test/unit/spec/media/index.ts +72 -8
  441. package/test/unit/spec/media/properties.ts +9 -9
  442. package/test/unit/spec/meeting/in-meeting-actions.ts +29 -2
  443. package/test/unit/spec/meeting/index.js +2503 -802
  444. package/test/unit/spec/meeting/muteState.js +146 -61
  445. package/test/unit/spec/meeting/request.js +141 -43
  446. package/test/unit/spec/meeting/utils.js +135 -164
  447. package/test/unit/spec/meeting-info/meetinginfov2.js +100 -73
  448. package/test/unit/spec/meeting-info/request.js +7 -9
  449. package/test/unit/spec/meeting-info/util.js +11 -12
  450. package/test/unit/spec/meeting-info/utilv2.js +110 -74
  451. package/test/unit/spec/meetings/collection.js +15 -1
  452. package/test/unit/spec/meetings/index.js +622 -263
  453. package/test/unit/spec/meetings/utils.js +65 -14
  454. package/test/unit/spec/member/index.js +24 -1
  455. package/test/unit/spec/member/util.js +359 -32
  456. package/test/unit/spec/members/index.js +294 -54
  457. package/test/unit/spec/members/request.js +50 -20
  458. package/test/unit/spec/members/utils.js +147 -4
  459. package/test/unit/spec/metrics/index.js +16 -21
  460. package/test/unit/spec/multistream/mediaRequestManager.ts +369 -68
  461. package/test/unit/spec/multistream/receiveSlot.ts +76 -17
  462. package/test/unit/spec/multistream/receiveSlotManager.ts +60 -38
  463. package/test/unit/spec/multistream/remoteMedia.ts +32 -2
  464. package/test/unit/spec/multistream/remoteMediaGroup.ts +5 -5
  465. package/test/unit/spec/multistream/remoteMediaManager.ts +549 -65
  466. package/test/unit/spec/networkQualityMonitor/index.js +24 -18
  467. package/test/unit/spec/personal-meeting-room/personal-meeting-room.js +2 -7
  468. package/test/unit/spec/reachability/index.ts +176 -27
  469. package/test/unit/spec/reachability/request.js +66 -0
  470. package/test/unit/spec/reconnection-manager/index.js +58 -30
  471. package/test/unit/spec/recording-controller/index.js +231 -0
  472. package/test/unit/spec/recording-controller/util.js +102 -0
  473. package/test/unit/spec/roap/index.ts +12 -8
  474. package/test/unit/spec/roap/request.ts +217 -0
  475. package/test/unit/spec/roap/turnDiscovery.ts +72 -49
  476. package/test/unit/spec/stats-analyzer/index.js +108 -57
  477. package/test/utils/cmr.js +44 -42
  478. package/test/utils/constants.js +9 -0
  479. package/test/utils/testUtils.js +98 -77
  480. package/test/utils/webex-config.js +22 -18
  481. package/test/utils/webex-test-users.js +57 -50
  482. package/tsconfig.json +6 -0
  483. package/dist/media/internal-media-core-wrapper.js +0 -22
  484. package/dist/media/internal-media-core-wrapper.js.map +0 -1
  485. package/dist/meeting/effectsState.js +0 -327
  486. package/dist/meeting/effectsState.js.map +0 -1
  487. package/dist/multistream/multistreamMedia.js +0 -116
  488. package/dist/multistream/multistreamMedia.js.map +0 -1
  489. package/dist/peer-connection-manager/util.js +0 -124
  490. package/dist/peer-connection-manager/util.js.map +0 -1
  491. package/src/common/logs/logger-proxy.js +0 -33
  492. package/src/locus-info/controlsUtils.js +0 -102
  493. package/src/media/internal-media-core-wrapper.ts +0 -9
  494. package/src/mediaQualityMetrics/config.js +0 -382
  495. package/src/meeting/effectsState.js +0 -205
  496. package/src/meeting-info/meeting-info-v2.js +0 -255
  497. package/src/meetings/index.js +0 -1015
  498. package/src/multistream/multistreamMedia.ts +0 -92
  499. package/src/peer-connection-manager/util.ts +0 -117
  500. package/src/roap/request.js +0 -127
  501. package/src/statsAnalyzer/global.js +0 -133
  502. package/src/statsAnalyzer/index.js +0 -1006
  503. package/src/statsAnalyzer/mqaUtil.js +0 -173
  504. package/test/unit/spec/meeting/effectsState.js +0 -291
  505. package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -389
  506. /package/src/common/errors/{reconnection-in-progress.js → reconnection-in-progress.ts} +0 -0
@@ -82,6 +82,7 @@ describe('plugin-meetings', () => {
82
82
  meetingContainerUrl: 'http://new-url.com',
83
83
  },
84
84
  entryExitTone: {enabled: true, mode: 'foo'},
85
+ video: {enabled: true},
85
86
  };
86
87
  });
87
88
 
@@ -277,6 +278,25 @@ describe('plugin-meetings', () => {
277
278
  );
278
279
  });
279
280
 
281
+ it('should update the breakout state', () => {
282
+ locusInfo.emitScoped = sinon.stub();
283
+ newControls.breakout = 'new breakout';
284
+
285
+ locusInfo.updateControls(newControls);
286
+
287
+ assert.calledWith(
288
+ locusInfo.emitScoped,
289
+ {
290
+ file: 'locus-info',
291
+ function: 'updateControls',
292
+ },
293
+ LOCUSINFO.EVENTS.CONTROLS_MEETING_BREAKOUT_UPDATED,
294
+ {
295
+ breakout: 'new breakout',
296
+ }
297
+ );
298
+ });
299
+
280
300
  it('should update the transcript state', () => {
281
301
  locusInfo.emitScoped = sinon.stub();
282
302
  locusInfo.controls = {
@@ -398,6 +418,39 @@ describe('plugin-meetings', () => {
398
418
  assert.notEqual(x.args[1], LOCUSINFO.EVENTS.CONTROLS_ENTRY_EXIT_TONE_UPDATED);
399
419
  });
400
420
  });
421
+
422
+ it('should update videoEnabled when changed', () => {
423
+ locusInfo.controls = {};
424
+
425
+ locusInfo.emitScoped = sinon.stub();
426
+ locusInfo.updateControls(newControls);
427
+
428
+ assert.calledWith(
429
+ locusInfo.emitScoped,
430
+ {
431
+ file: 'locus-info',
432
+ function: 'updateControls',
433
+ },
434
+ LOCUSINFO.EVENTS.SELF_REMOTE_VIDEO_MUTE_STATUS_UPDATED,
435
+ {unmuteAllowed: true}
436
+ );
437
+
438
+ assert.equal(mockMeeting.unmuteVideoAllowed, true);
439
+ });
440
+
441
+ it('should not update videoEnabled when unchanged', () => {
442
+ locusInfo.controls = {videoEnabled: true};
443
+
444
+ locusInfo.emitScoped = sinon.stub();
445
+ locusInfo.updateControls(newControls);
446
+
447
+ locusInfo.emitScoped.getCalls().forEach((x) => {
448
+ // check that no calls in emitScoped are for SELF_REMOTE_VIDEO_MUTE_STATUS_UPDATED
449
+ assert.notEqual(x.args[1], LOCUSINFO.EVENTS.SELF_REMOTE_VIDEO_MUTE_STATUS_UPDATED);
450
+ });
451
+
452
+ assert.equal(mockMeeting.unmuteVideoAllowed, undefined);
453
+ });
401
454
  });
402
455
 
403
456
  describe('#updateParticipants()', () => {
@@ -451,6 +504,7 @@ describe('plugin-meetings', () => {
451
504
  selfIdentity: '123',
452
505
  selfId: '2',
453
506
  hostId: '3',
507
+ isReplace: undefined,
454
508
  }
455
509
  );
456
510
  // note: in a real use case, recordingId, selfId, and hostId would all be the same
@@ -458,6 +512,43 @@ describe('plugin-meetings', () => {
458
512
  // are being correctly grabbed from locusInfo.parsedLocus within updateParticipants
459
513
  });
460
514
 
515
+ it('should call with breakout control info', () => {
516
+ locusInfo.parsedLocus = {
517
+ controls: {
518
+ record: {
519
+ modifiedBy: '1',
520
+ },
521
+ },
522
+ self: {
523
+ selfIdentity: '123',
524
+ selfId: '2',
525
+ },
526
+ host: {
527
+ hostId: '3',
528
+ },
529
+ };
530
+
531
+ locusInfo.emitScoped = sinon.stub();
532
+ locusInfo.updateParticipants({}, true);
533
+
534
+ assert.calledWith(
535
+ locusInfo.emitScoped,
536
+ {
537
+ file: 'locus-info',
538
+ function: 'updateParticipants',
539
+ },
540
+ EVENTS.LOCUS_INFO_UPDATE_PARTICIPANTS,
541
+ {
542
+ participants: {},
543
+ recordingId: '1',
544
+ selfIdentity: '123',
545
+ selfId: '2',
546
+ hostId: '3',
547
+ isReplace: true,
548
+ }
549
+ );
550
+ });
551
+
461
552
  it('should update the deltaParticipants object', () => {
462
553
  const prev = locusInfo.deltaParticipants;
463
554
 
@@ -664,6 +755,143 @@ describe('plugin-meetings', () => {
664
755
  );
665
756
  });
666
757
 
758
+ describe('SELF_REMOTE_VIDEO_MUTE_STATUS_UPDATED', () => {
759
+ it('should emit event when video muted on entry', () => {
760
+ // usually "previous self" is just undefined when we get first self from locus
761
+ locusInfo.self = undefined;
762
+ const selfWithMutedByOthers = cloneDeep(self);
763
+
764
+ // remoteVideoMuted
765
+ selfWithMutedByOthers.controls.video.muted = true;
766
+
767
+ locusInfo.webex.internal.device.url = self.deviceUrl;
768
+ locusInfo.emitScoped = sinon.stub();
769
+ locusInfo.updateSelf(selfWithMutedByOthers, []);
770
+
771
+ assert.calledWith(
772
+ locusInfo.emitScoped,
773
+ {
774
+ file: 'locus-info',
775
+ function: 'updateSelf',
776
+ },
777
+ LOCUSINFO.EVENTS.SELF_REMOTE_VIDEO_MUTE_STATUS_UPDATED,
778
+ {muted: true}
779
+ );
780
+
781
+ // but sometimes "previous self" is defined, but without controls.audio.muted, so we test this here:
782
+ locusInfo.self = cloneDeep(self);
783
+ locusInfo.self.controls.video = {};
784
+
785
+ locusInfo.updateSelf(selfWithMutedByOthers, []);
786
+ assert.calledWith(
787
+ locusInfo.emitScoped,
788
+ {
789
+ file: 'locus-info',
790
+ function: 'updateSelf',
791
+ },
792
+ LOCUSINFO.EVENTS.SELF_REMOTE_VIDEO_MUTE_STATUS_UPDATED,
793
+ {muted: true}
794
+ );
795
+ });
796
+
797
+ it('should not emit event when not muted on entry', () => {
798
+ locusInfo.self = undefined;
799
+ const selfWithMutedByOthersFalse = cloneDeep(self);
800
+
801
+ selfWithMutedByOthersFalse.controls.video.muted = false;
802
+
803
+ locusInfo.webex.internal.device.url = self.deviceUrl;
804
+ locusInfo.emitScoped = sinon.stub();
805
+ locusInfo.updateSelf(selfWithMutedByOthersFalse, []);
806
+
807
+ // we might get some calls to emitScoped, but we need to check that none of them are for SELF_REMOTE_VIDEO_MUTE_STATUS_UPDATED
808
+ locusInfo.emitScoped.getCalls().forEach((x) => {
809
+ assert.notEqual(x.args[1], LOCUSINFO.EVENTS.SELF_REMOTE_VIDEO_MUTE_STATUS_UPDATED);
810
+ });
811
+ });
812
+
813
+ it('should emit event when remoteVideoMuted changed', () => {
814
+ locusInfo.self = self;
815
+ const selfWithMutedByOthers = cloneDeep(self);
816
+
817
+ selfWithMutedByOthers.controls.video.muted = true;
818
+
819
+ locusInfo.webex.internal.device.url = self.deviceUrl;
820
+ locusInfo.emitScoped = sinon.stub();
821
+ locusInfo.updateSelf(selfWithMutedByOthers, []);
822
+
823
+ assert.calledWith(
824
+ locusInfo.emitScoped,
825
+ {
826
+ file: 'locus-info',
827
+ function: 'updateSelf',
828
+ },
829
+ LOCUSINFO.EVENTS.SELF_REMOTE_VIDEO_MUTE_STATUS_UPDATED,
830
+ {muted: true}
831
+ );
832
+ });
833
+ });
834
+
835
+ it('should trigger SELF_MEETING_BREAKOUTS_CHANGED when breakouts changed', () => {
836
+ locusInfo.self = self;
837
+ const selfWithBreakoutsChanged = cloneDeep(self);
838
+
839
+ selfWithBreakoutsChanged.controls.breakout.sessions.active[0].name = 'new name';
840
+
841
+ locusInfo.emitScoped = sinon.stub();
842
+ locusInfo.updateSelf(selfWithBreakoutsChanged, []);
843
+
844
+ assert.calledWith(
845
+ locusInfo.emitScoped,
846
+ {
847
+ file: 'locus-info',
848
+ function: 'updateSelf',
849
+ },
850
+ LOCUSINFO.EVENTS.SELF_MEETING_BREAKOUTS_CHANGED,
851
+ {
852
+ breakoutSessions: {
853
+ active: [
854
+ {
855
+ name: 'new name',
856
+ groupId: '0e73abb8-5584-49d8-be8d-806d2a8247ca',
857
+ sessionId: '1cf41ab1-2e57-4d95-b7e9-5613acddfb0f',
858
+ sessionType: 'BREAKOUT',
859
+ },
860
+ ],
861
+ allowed: [
862
+ {
863
+ name: 'Breakout session 2',
864
+ groupId: '0e73abb8-5584-49d8-be8d-806d2a8247ca',
865
+ sessionId: '1cf41ab1-2e57-4d95-b7e9-5613acddfb0f',
866
+ sessionType: 'BREAKOUT',
867
+ },
868
+ ],
869
+ },
870
+ }
871
+ );
872
+ });
873
+
874
+ it('should trigger upgradeToModeratorOrCohost for breakouts', () => {
875
+
876
+ locusInfo.self = self;
877
+ const upgradeToModeratorOrCohost = cloneDeep(self);
878
+ upgradeToModeratorOrCohost.roles = ['ATTENDEE','COHOST'];
879
+
880
+ locusInfo.webex.internal.device.url = self.deviceUrl;
881
+ locusInfo.emitScoped = sinon.stub();
882
+ locusInfo.updateSelf(upgradeToModeratorOrCohost, []);
883
+
884
+ assert.neverCalledWith(
885
+ locusInfo.emitScoped,
886
+ {
887
+ file: 'locus-info',
888
+ function: 'updateSelf',
889
+ },
890
+ LOCUSINFO.EVENTS.SELF_MODERATOR_OR_COHOST_UPGRADE,
891
+ self
892
+ );
893
+ });
894
+
667
895
  it('should trigger SELF_REMOTE_MUTE_STATUS_UPDATED if muted and disallowUnmute changed', () => {
668
896
  locusInfo.self = self;
669
897
  const selfWithMutedByOthersAndDissalowUnmute = cloneDeep(self);
@@ -967,8 +1195,7 @@ describe('plugin-meetings', () => {
967
1195
 
968
1196
  if (expected) {
969
1197
  assert.calledWith(...expectedArgs);
970
- }
971
- else {
1198
+ } else {
972
1199
  assert.neverCalledWith(...expectedArgs);
973
1200
  }
974
1201
  locusInfo.emitScoped.resetHistory();
@@ -1148,6 +1375,55 @@ describe('plugin-meetings', () => {
1148
1375
  assert.isFunction(locusParser.onDeltaAction);
1149
1376
  });
1150
1377
 
1378
+ it('#updateLocusInfo ignores breakout LEFT message', () => {
1379
+ const newLocus = {
1380
+ self: {
1381
+ reason: 'MOVED',
1382
+ state: 'LEFT',
1383
+ },
1384
+ };
1385
+
1386
+ locusInfo.updateControls = sinon.stub();
1387
+ locusInfo.updateConversationUrl = sinon.stub();
1388
+ locusInfo.updateCreated = sinon.stub();
1389
+ locusInfo.updateFullState = sinon.stub();
1390
+ locusInfo.updateHostInfo = sinon.stub();
1391
+ locusInfo.updateMeetingInfo = sinon.stub();
1392
+ locusInfo.updateMediaShares = sinon.stub();
1393
+ locusInfo.updateParticipantsUrl = sinon.stub();
1394
+ locusInfo.updateReplace = sinon.stub();
1395
+ locusInfo.updateSelf = sinon.stub();
1396
+ locusInfo.updateLocusUrl = sinon.stub();
1397
+ locusInfo.updateAclUrl = sinon.stub();
1398
+ locusInfo.updateBasequence = sinon.stub();
1399
+ locusInfo.updateSequence = sinon.stub();
1400
+ locusInfo.updateMemberShip = sinon.stub();
1401
+ locusInfo.updateIdentifiers = sinon.stub();
1402
+ locusInfo.updateEmbeddedApps = sinon.stub();
1403
+ locusInfo.compareAndUpdate = sinon.stub();
1404
+
1405
+ locusInfo.updateLocusInfo(newLocus);
1406
+
1407
+ assert.notCalled(locusInfo.updateControls);
1408
+ assert.notCalled(locusInfo.updateConversationUrl);
1409
+ assert.notCalled(locusInfo.updateCreated);
1410
+ assert.notCalled(locusInfo.updateFullState);
1411
+ assert.notCalled(locusInfo.updateHostInfo);
1412
+ assert.notCalled(locusInfo.updateMeetingInfo);
1413
+ assert.notCalled(locusInfo.updateMediaShares);
1414
+ assert.notCalled(locusInfo.updateParticipantsUrl);
1415
+ assert.notCalled(locusInfo.updateReplace);
1416
+ assert.notCalled(locusInfo.updateSelf);
1417
+ assert.notCalled(locusInfo.updateLocusUrl);
1418
+ assert.notCalled(locusInfo.updateAclUrl);
1419
+ assert.notCalled(locusInfo.updateBasequence);
1420
+ assert.notCalled(locusInfo.updateSequence);
1421
+ assert.notCalled(locusInfo.updateMemberShip);
1422
+ assert.notCalled(locusInfo.updateIdentifiers);
1423
+ assert.notCalled(locusInfo.updateEmbeddedApps);
1424
+ assert.notCalled(locusInfo.compareAndUpdate);
1425
+ });
1426
+
1151
1427
  it('onFullLocus() updates the working-copy of locus parser', () => {
1152
1428
  const eventType = 'fakeEvent';
1153
1429
 
@@ -1227,6 +1503,31 @@ describe('plugin-meetings', () => {
1227
1503
  assert.calledOnce(locusInfo.locusParser.resume);
1228
1504
  });
1229
1505
  });
1506
+
1507
+ it('onDeltaLocus handle delta data', () => {
1508
+ fakeLocus.participants = {};
1509
+ const fakeBreakout = {
1510
+ sessionId: 'sessionId',
1511
+ groupId: 'groupId',
1512
+ };
1513
+
1514
+ fakeLocus.controls = {
1515
+ breakout: fakeBreakout
1516
+ };
1517
+ locusInfo.controls = {
1518
+ breakout: {
1519
+ sessionId: 'sessionId',
1520
+ groupId: 'groupId',
1521
+ }
1522
+ }
1523
+ locusInfo.updateParticipants = sinon.stub();
1524
+ locusInfo.onDeltaLocus(fakeLocus);
1525
+ assert.calledWith(locusInfo.updateParticipants, {}, false);
1526
+
1527
+ fakeBreakout.sessionId = 'sessionId2';
1528
+ locusInfo.onDeltaLocus(fakeLocus);
1529
+ assert.calledWith(locusInfo.updateParticipants, {}, false);
1530
+ });
1230
1531
  });
1231
1532
 
1232
1533
  describe('#handleOneonOneEvent', () => {
@@ -1,20 +1,15 @@
1
1
  import {assert} from '@webex/test-helper-chai';
2
2
  import Sinon from 'sinon';
3
-
4
3
  import InfoUtils from '@webex/plugin-meetings/src/locus-info/infoUtils';
5
4
 
6
-
7
5
  describe('plugin-meetings', () => {
8
6
  describe('infoUtils', () => {
9
7
  const info = {
10
8
  displayHints: {
11
- moderator: [
12
- 'HINT_1',
13
- 'HINT_2'
14
- ],
9
+ moderator: ['HINT_1', 'HINT_2'],
15
10
  joined: ['HINT_3'],
16
- coHost: ['HINT_4']
17
- }
11
+ coHost: ['HINT_4'],
12
+ },
18
13
  };
19
14
 
20
15
  describe('getInfos', () => {
@@ -35,28 +30,28 @@ describe('plugin-meetings', () => {
35
30
  policy: {HINT_3: true},
36
31
  moderator: {HINT_1: true, HINT_2: true, LOWER_SOMEONE_ELSES_HAND: true},
37
32
  coHost: {HINT_4: true, LOWER_SOMEONE_ELSES_HAND: true},
38
- userDisplayHints: ['HINT_3', 'HINT_1', 'HINT_2', 'LOWER_SOMEONE_ELSES_HAND']
33
+ userDisplayHints: ['HINT_3', 'HINT_1', 'HINT_2', 'LOWER_SOMEONE_ELSES_HAND'],
39
34
  });
40
35
 
41
36
  assert.deepEqual(InfoUtils.parse(info, ['MODERATOR', 'COHOST']), {
42
37
  policy: {HINT_3: true},
43
38
  moderator: {HINT_1: true, HINT_2: true, LOWER_SOMEONE_ELSES_HAND: true},
44
39
  coHost: {HINT_4: true, LOWER_SOMEONE_ELSES_HAND: true},
45
- userDisplayHints: ['HINT_3', 'HINT_4', 'LOWER_SOMEONE_ELSES_HAND', 'HINT_1', 'HINT_2']
40
+ userDisplayHints: ['HINT_3', 'HINT_4', 'LOWER_SOMEONE_ELSES_HAND', 'HINT_1', 'HINT_2'],
46
41
  });
47
42
 
48
43
  assert.deepEqual(InfoUtils.parse(info, ['COHOST']), {
49
44
  policy: {HINT_3: true},
50
45
  moderator: {HINT_1: true, HINT_2: true, LOWER_SOMEONE_ELSES_HAND: true},
51
46
  coHost: {HINT_4: true, LOWER_SOMEONE_ELSES_HAND: true},
52
- userDisplayHints: ['HINT_3', 'HINT_4', 'LOWER_SOMEONE_ELSES_HAND']
47
+ userDisplayHints: ['HINT_3', 'HINT_4', 'LOWER_SOMEONE_ELSES_HAND'],
53
48
  });
54
49
 
55
50
  assert.deepEqual(InfoUtils.parse(info, []), {
56
51
  policy: {HINT_3: true},
57
52
  moderator: {HINT_1: true, HINT_2: true, LOWER_SOMEONE_ELSES_HAND: true},
58
53
  coHost: {HINT_4: true, LOWER_SOMEONE_ELSES_HAND: true},
59
- userDisplayHints: ['HINT_3']
54
+ userDisplayHints: ['HINT_3'],
60
55
  });
61
56
  });
62
57
 
@@ -65,39 +60,47 @@ describe('plugin-meetings', () => {
65
60
  policy: {HINT_3: true},
66
61
  moderator: {HINT_1: true, HINT_2: true, LOWER_SOMEONE_ELSES_HAND: true},
67
62
  coHost: {HINT_4: true, LOWER_SOMEONE_ELSES_HAND: true},
68
- userDisplayHints: ['HINT_1', 'HINT_2', 'LOWER_SOMEONE_ELSES_HAND']
63
+ userDisplayHints: ['HINT_1', 'HINT_2', 'LOWER_SOMEONE_ELSES_HAND'],
69
64
  });
70
65
 
71
66
  assert.deepEqual(InfoUtils.parse(info, ['MODERATOR'], true), {
72
67
  policy: {HINT_3: true},
73
68
  moderator: {HINT_1: true, HINT_2: true, LOWER_SOMEONE_ELSES_HAND: true},
74
69
  coHost: {HINT_4: true, LOWER_SOMEONE_ELSES_HAND: true},
75
- userDisplayHints: ['HINT_3', 'HINT_1', 'HINT_2', 'LOWER_SOMEONE_ELSES_HAND']
70
+ userDisplayHints: ['HINT_3', 'HINT_1', 'HINT_2', 'LOWER_SOMEONE_ELSES_HAND'],
71
+ });
72
+ });
73
+
74
+ it('only adds datachannel url when present', () => {
75
+ assert.deepEqual(InfoUtils.parse({datachannelUrl: 'some url'}, []), {
76
+ coHost: {LOWER_SOMEONE_ELSES_HAND: true},
77
+ moderator: {LOWER_SOMEONE_ELSES_HAND: true},
78
+ datachannelUrl: 'some url',
79
+ policy: {},
80
+ userDisplayHints: [],
81
+ });
82
+
83
+ assert.deepEqual(InfoUtils.parse({}, []), {
84
+ coHost: {LOWER_SOMEONE_ELSES_HAND: true},
85
+ moderator: {LOWER_SOMEONE_ELSES_HAND: true},
86
+ policy: {},
87
+ userDisplayHints: [],
76
88
  });
77
89
  });
78
90
  });
79
91
 
80
92
  describe('parseDisplayHintsSection', () => {
81
93
  it('returns the correct hints', () => {
82
- assert.deepEqual(
83
- InfoUtils.parseDisplayHintSection(info, 'moderator'),
84
- {HINT_1: true, HINT_2: true}
85
- );
94
+ assert.deepEqual(InfoUtils.parseDisplayHintSection(info, 'moderator'), {
95
+ HINT_1: true,
96
+ HINT_2: true,
97
+ });
86
98
 
87
- assert.deepEqual(
88
- InfoUtils.parseDisplayHintSection(info, 'joined'),
89
- {HINT_3: true}
90
- );
99
+ assert.deepEqual(InfoUtils.parseDisplayHintSection(info, 'joined'), {HINT_3: true});
91
100
 
92
- assert.deepEqual(
93
- InfoUtils.parseDisplayHintSection({}, 'joined'),
94
- {}
95
- );
101
+ assert.deepEqual(InfoUtils.parseDisplayHintSection({}, 'joined'), {});
96
102
 
97
- assert.deepEqual(
98
- InfoUtils.parseDisplayHintSection({displayHints: {}}, 'joined'),
99
- {}
100
- );
103
+ assert.deepEqual(InfoUtils.parseDisplayHintSection({displayHints: {}}, 'joined'), {});
101
104
 
102
105
  assert.deepEqual(
103
106
  InfoUtils.parseDisplayHintSection({displayHints: {joined: {}}}, 'joined'),
@@ -122,7 +125,10 @@ describe('plugin-meetings', () => {
122
125
 
123
126
  assert.calledWith(parseDisplayHintSectionSpy, info, 'moderator');
124
127
 
125
- assert.deepEqual(result, {...parseDisplayHintSectionSpy.firstCall.returnValue, LOWER_SOMEONE_ELSES_HAND: true});
128
+ assert.deepEqual(result, {
129
+ ...parseDisplayHintSectionSpy.firstCall.returnValue,
130
+ LOWER_SOMEONE_ELSES_HAND: true,
131
+ });
126
132
  });
127
133
 
128
134
  it('parsePolicy calls parseDisplayHintSection correctly and returns the result', () => {
@@ -138,7 +144,10 @@ describe('plugin-meetings', () => {
138
144
 
139
145
  assert.calledWith(parseDisplayHintSectionSpy, info, 'coHost');
140
146
 
141
- assert.deepEqual(result, {...parseDisplayHintSectionSpy.firstCall.returnValue, LOWER_SOMEONE_ELSES_HAND: true});
147
+ assert.deepEqual(result, {
148
+ ...parseDisplayHintSectionSpy.firstCall.returnValue,
149
+ LOWER_SOMEONE_ELSES_HAND: true,
150
+ });
142
151
  });
143
152
  });
144
153
  });