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

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 (601) hide show
  1. package/README.md +46 -8
  2. package/UPGRADING.md +9 -9
  3. package/browsers.js +19 -24
  4. package/dist/annotation/annotation.types.js +7 -0
  5. package/dist/annotation/annotation.types.js.map +1 -0
  6. package/dist/annotation/constants.js +49 -0
  7. package/dist/annotation/constants.js.map +1 -0
  8. package/dist/annotation/index.js +342 -0
  9. package/dist/annotation/index.js.map +1 -0
  10. package/dist/breakouts/breakout.js +216 -0
  11. package/dist/breakouts/breakout.js.map +1 -0
  12. package/dist/breakouts/collection.js +23 -0
  13. package/dist/breakouts/collection.js.map +1 -0
  14. package/dist/breakouts/edit-lock-error.js +52 -0
  15. package/dist/breakouts/edit-lock-error.js.map +1 -0
  16. package/dist/breakouts/events.js +45 -0
  17. package/dist/breakouts/events.js.map +1 -0
  18. package/dist/breakouts/index.js +1048 -0
  19. package/dist/breakouts/index.js.map +1 -0
  20. package/dist/breakouts/request.js +78 -0
  21. package/dist/breakouts/request.js.map +1 -0
  22. package/dist/breakouts/utils.js +67 -0
  23. package/dist/breakouts/utils.js.map +1 -0
  24. package/dist/common/browser-detection.js +1 -20
  25. package/dist/common/browser-detection.js.map +1 -1
  26. package/dist/common/collection.js +5 -20
  27. package/dist/common/collection.js.map +1 -1
  28. package/dist/common/config.js +0 -7
  29. package/dist/common/config.js.map +1 -1
  30. package/dist/common/errors/captcha-error.js +10 -24
  31. package/dist/common/errors/captcha-error.js.map +1 -1
  32. package/dist/common/errors/intent-to-join.js +11 -24
  33. package/dist/common/errors/intent-to-join.js.map +1 -1
  34. package/dist/common/errors/join-meeting.js +12 -25
  35. package/dist/common/errors/join-meeting.js.map +1 -1
  36. package/dist/common/errors/media.js +10 -24
  37. package/dist/common/errors/media.js.map +1 -1
  38. package/dist/common/errors/no-meeting-info.js +51 -0
  39. package/dist/common/errors/no-meeting-info.js.map +1 -0
  40. package/dist/common/errors/parameter.js +5 -33
  41. package/dist/common/errors/parameter.js.map +1 -1
  42. package/dist/common/errors/password-error.js +10 -24
  43. package/dist/common/errors/password-error.js.map +1 -1
  44. package/dist/common/errors/permission.js +9 -23
  45. package/dist/common/errors/permission.js.map +1 -1
  46. package/dist/common/errors/reclaim-host-role-errors.js +158 -0
  47. package/dist/common/errors/reclaim-host-role-errors.js.map +1 -0
  48. package/dist/common/errors/reconnection-in-progress.js +0 -17
  49. package/dist/common/errors/reconnection-in-progress.js.map +1 -1
  50. package/dist/common/errors/reconnection.js +10 -24
  51. package/dist/common/errors/reconnection.js.map +1 -1
  52. package/dist/common/errors/stats.js +10 -24
  53. package/dist/common/errors/stats.js.map +1 -1
  54. package/dist/common/errors/webex-errors.js +54 -48
  55. package/dist/common/errors/webex-errors.js.map +1 -1
  56. package/dist/common/errors/webex-meetings-error.js +5 -25
  57. package/dist/common/errors/webex-meetings-error.js.map +1 -1
  58. package/dist/common/events/events-scope.js +0 -22
  59. package/dist/common/events/events-scope.js.map +1 -1
  60. package/dist/common/events/events.js +0 -23
  61. package/dist/common/events/events.js.map +1 -1
  62. package/dist/common/events/trigger-proxy.js +0 -12
  63. package/dist/common/events/trigger-proxy.js.map +1 -1
  64. package/dist/common/events/util.js +0 -15
  65. package/dist/common/events/util.js.map +1 -1
  66. package/dist/common/logs/logger-config.js +0 -4
  67. package/dist/common/logs/logger-config.js.map +1 -1
  68. package/dist/common/logs/logger-proxy.js +1 -8
  69. package/dist/common/logs/logger-proxy.js.map +1 -1
  70. package/dist/common/logs/request.js +41 -60
  71. package/dist/common/logs/request.js.map +1 -1
  72. package/dist/common/queue.js +28 -23
  73. package/dist/common/queue.js.map +1 -1
  74. package/dist/config.js +9 -15
  75. package/dist/config.js.map +1 -1
  76. package/dist/constants.js +315 -68
  77. package/dist/constants.js.map +1 -1
  78. package/dist/controls-options-manager/constants.js +14 -0
  79. package/dist/controls-options-manager/constants.js.map +1 -0
  80. package/dist/controls-options-manager/enums.js +27 -0
  81. package/dist/controls-options-manager/enums.js.map +1 -0
  82. package/dist/controls-options-manager/index.js +297 -0
  83. package/dist/controls-options-manager/index.js.map +1 -0
  84. package/dist/controls-options-manager/types.js +7 -0
  85. package/dist/controls-options-manager/types.js.map +1 -0
  86. package/dist/controls-options-manager/util.js +319 -0
  87. package/dist/controls-options-manager/util.js.map +1 -0
  88. package/dist/index.js +114 -17
  89. package/dist/index.js.map +1 -1
  90. package/dist/interpretation/collection.js +23 -0
  91. package/dist/interpretation/collection.js.map +1 -0
  92. package/dist/interpretation/index.js +366 -0
  93. package/dist/interpretation/index.js.map +1 -0
  94. package/dist/interpretation/siLanguage.js +25 -0
  95. package/dist/interpretation/siLanguage.js.map +1 -0
  96. package/dist/locus-info/controlsUtils.js +101 -29
  97. package/dist/locus-info/controlsUtils.js.map +1 -1
  98. package/dist/locus-info/embeddedAppsUtils.js +3 -26
  99. package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
  100. package/dist/locus-info/fullState.js +0 -15
  101. package/dist/locus-info/fullState.js.map +1 -1
  102. package/dist/locus-info/hostUtils.js +4 -12
  103. package/dist/locus-info/hostUtils.js.map +1 -1
  104. package/dist/locus-info/index.js +561 -246
  105. package/dist/locus-info/index.js.map +1 -1
  106. package/dist/locus-info/infoUtils.js +10 -38
  107. package/dist/locus-info/infoUtils.js.map +1 -1
  108. package/dist/locus-info/mediaSharesUtils.js +68 -38
  109. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  110. package/dist/locus-info/parser.js +314 -163
  111. package/dist/locus-info/parser.js.map +1 -1
  112. package/dist/locus-info/selfUtils.js +110 -92
  113. package/dist/locus-info/selfUtils.js.map +1 -1
  114. package/dist/media/index.js +103 -231
  115. package/dist/media/index.js.map +1 -1
  116. package/dist/media/properties.js +137 -222
  117. package/dist/media/properties.js.map +1 -1
  118. package/dist/media/util.js +2 -9
  119. package/dist/media/util.js.map +1 -1
  120. package/dist/mediaQualityMetrics/config.js +505 -495
  121. package/dist/mediaQualityMetrics/config.js.map +1 -1
  122. package/dist/meeting/in-meeting-actions.js +93 -14
  123. package/dist/meeting/in-meeting-actions.js.map +1 -1
  124. package/dist/meeting/index.js +4624 -3740
  125. package/dist/meeting/index.js.map +1 -1
  126. package/dist/meeting/locusMediaRequest.js +292 -0
  127. package/dist/meeting/locusMediaRequest.js.map +1 -0
  128. package/dist/meeting/muteState.js +249 -184
  129. package/dist/meeting/muteState.js.map +1 -1
  130. package/dist/meeting/request.js +400 -346
  131. package/dist/meeting/request.js.map +1 -1
  132. package/dist/meeting/request.type.js +7 -0
  133. package/dist/meeting/request.type.js.map +1 -0
  134. package/dist/meeting/state.js +21 -31
  135. package/dist/meeting/state.js.map +1 -1
  136. package/dist/meeting/util.js +598 -586
  137. package/dist/meeting/util.js.map +1 -1
  138. package/dist/meeting-info/collection.js +6 -25
  139. package/dist/meeting-info/collection.js.map +1 -1
  140. package/dist/meeting-info/index.js +87 -39
  141. package/dist/meeting-info/index.js.map +1 -1
  142. package/dist/meeting-info/meeting-info-v2.js +349 -283
  143. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  144. package/dist/meeting-info/request.js +3 -15
  145. package/dist/meeting-info/request.js.map +1 -1
  146. package/dist/meeting-info/util.js +98 -183
  147. package/dist/meeting-info/util.js.map +1 -1
  148. package/dist/meeting-info/utilv2.js +143 -234
  149. package/dist/meeting-info/utilv2.js.map +1 -1
  150. package/dist/meetings/collection.js +26 -19
  151. package/dist/meetings/collection.js.map +1 -1
  152. package/dist/meetings/index.js +813 -596
  153. package/dist/meetings/index.js.map +1 -1
  154. package/dist/meetings/meetings.types.js +7 -0
  155. package/dist/meetings/meetings.types.js.map +1 -0
  156. package/dist/meetings/request.js +26 -41
  157. package/dist/meetings/request.js.map +1 -1
  158. package/dist/meetings/util.js +183 -156
  159. package/dist/meetings/util.js.map +1 -1
  160. package/dist/member/index.js +135 -85
  161. package/dist/member/index.js.map +1 -1
  162. package/dist/member/types.js +25 -0
  163. package/dist/member/types.js.map +1 -0
  164. package/dist/member/util.js +158 -88
  165. package/dist/member/util.js.map +1 -1
  166. package/dist/members/collection.js +13 -12
  167. package/dist/members/collection.js.map +1 -1
  168. package/dist/members/index.js +194 -204
  169. package/dist/members/index.js.map +1 -1
  170. package/dist/members/request.js +113 -68
  171. package/dist/members/request.js.map +1 -1
  172. package/dist/members/types.js +15 -0
  173. package/dist/members/types.js.map +1 -0
  174. package/dist/members/util.js +324 -259
  175. package/dist/members/util.js.map +1 -1
  176. package/dist/metrics/constants.js +14 -7
  177. package/dist/metrics/constants.js.map +1 -1
  178. package/dist/metrics/index.js +11 -558
  179. package/dist/metrics/index.js.map +1 -1
  180. package/dist/multistream/mediaRequestManager.js +263 -50
  181. package/dist/multistream/mediaRequestManager.js.map +1 -1
  182. package/dist/multistream/receiveSlot.js +58 -65
  183. package/dist/multistream/receiveSlot.js.map +1 -1
  184. package/dist/multistream/receiveSlotManager.js +76 -95
  185. package/dist/multistream/receiveSlotManager.js.map +1 -1
  186. package/dist/multistream/remoteMedia.js +62 -76
  187. package/dist/multistream/remoteMedia.js.map +1 -1
  188. package/dist/multistream/remoteMediaGroup.js +66 -43
  189. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  190. package/dist/multistream/remoteMediaManager.js +536 -439
  191. package/dist/multistream/remoteMediaManager.js.map +1 -1
  192. package/dist/multistream/sendSlotManager.js +233 -0
  193. package/dist/multistream/sendSlotManager.js.map +1 -0
  194. package/dist/networkQualityMonitor/index.js +40 -59
  195. package/dist/networkQualityMonitor/index.js.map +1 -1
  196. package/dist/personal-meeting-room/index.js +21 -45
  197. package/dist/personal-meeting-room/index.js.map +1 -1
  198. package/dist/personal-meeting-room/request.js +1 -31
  199. package/dist/personal-meeting-room/request.js.map +1 -1
  200. package/dist/personal-meeting-room/util.js +0 -13
  201. package/dist/personal-meeting-room/util.js.map +1 -1
  202. package/dist/reachability/index.js +322 -200
  203. package/dist/reachability/index.js.map +1 -1
  204. package/dist/reachability/request.js +20 -26
  205. package/dist/reachability/request.js.map +1 -1
  206. package/dist/reactions/constants.js +13 -0
  207. package/dist/reactions/constants.js.map +1 -0
  208. package/dist/reactions/reactions.js +109 -0
  209. package/dist/reactions/reactions.js.map +1 -0
  210. package/dist/reactions/reactions.type.js +36 -0
  211. package/dist/reactions/reactions.type.js.map +1 -0
  212. package/dist/reconnection-manager/index.js +388 -476
  213. package/dist/reconnection-manager/index.js.map +1 -1
  214. package/dist/recording-controller/enums.js +17 -0
  215. package/dist/recording-controller/enums.js.map +1 -0
  216. package/dist/recording-controller/index.js +362 -0
  217. package/dist/recording-controller/index.js.map +1 -0
  218. package/dist/recording-controller/util.js +64 -0
  219. package/dist/recording-controller/util.js.map +1 -0
  220. package/dist/roap/index.js +99 -94
  221. package/dist/roap/index.js.map +1 -1
  222. package/dist/roap/request.js +131 -135
  223. package/dist/roap/request.js.map +1 -1
  224. package/dist/roap/turnDiscovery.js +151 -101
  225. package/dist/roap/turnDiscovery.js.map +1 -1
  226. package/dist/rtcMetrics/constants.js +12 -0
  227. package/dist/rtcMetrics/constants.js.map +1 -0
  228. package/dist/rtcMetrics/index.js +117 -0
  229. package/dist/rtcMetrics/index.js.map +1 -0
  230. package/dist/statsAnalyzer/global.js +1 -95
  231. package/dist/statsAnalyzer/global.js.map +1 -1
  232. package/dist/statsAnalyzer/index.js +416 -497
  233. package/dist/statsAnalyzer/index.js.map +1 -1
  234. package/dist/statsAnalyzer/mqaUtil.js +145 -88
  235. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  236. package/dist/transcription/index.js +22 -47
  237. package/dist/transcription/index.js.map +1 -1
  238. package/dist/types/annotation/annotation.types.d.ts +42 -0
  239. package/dist/types/annotation/constants.d.ts +31 -0
  240. package/dist/types/annotation/index.d.ts +117 -0
  241. package/dist/types/breakouts/breakout.d.ts +8 -0
  242. package/dist/types/breakouts/collection.d.ts +5 -0
  243. package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
  244. package/dist/types/breakouts/events.d.ts +8 -0
  245. package/dist/types/breakouts/index.d.ts +5 -0
  246. package/dist/types/breakouts/request.d.ts +22 -0
  247. package/dist/types/breakouts/utils.d.ts +15 -0
  248. package/dist/types/common/browser-detection.d.ts +9 -0
  249. package/dist/types/common/collection.d.ts +48 -0
  250. package/dist/types/common/config.d.ts +2 -0
  251. package/dist/types/common/errors/captcha-error.d.ts +15 -0
  252. package/dist/types/common/errors/intent-to-join.d.ts +16 -0
  253. package/dist/types/common/errors/join-meeting.d.ts +17 -0
  254. package/dist/types/common/errors/media.d.ts +15 -0
  255. package/dist/types/common/errors/no-meeting-info.d.ts +14 -0
  256. package/dist/types/common/errors/parameter.d.ts +15 -0
  257. package/dist/types/common/errors/password-error.d.ts +15 -0
  258. package/dist/types/common/errors/permission.d.ts +14 -0
  259. package/dist/types/common/errors/reclaim-host-role-errors.d.ts +60 -0
  260. package/dist/types/common/errors/reconnection-in-progress.d.ts +9 -0
  261. package/dist/types/common/errors/reconnection.d.ts +15 -0
  262. package/dist/types/common/errors/stats.d.ts +15 -0
  263. package/dist/types/common/errors/webex-errors.d.ts +93 -0
  264. package/dist/types/common/errors/webex-meetings-error.d.ts +20 -0
  265. package/dist/types/common/events/events-scope.d.ts +17 -0
  266. package/dist/types/common/events/events.d.ts +12 -0
  267. package/dist/types/common/events/trigger-proxy.d.ts +2 -0
  268. package/dist/types/common/events/util.d.ts +2 -0
  269. package/dist/types/common/logs/logger-config.d.ts +2 -0
  270. package/dist/types/common/logs/logger-proxy.d.ts +2 -0
  271. package/dist/types/common/logs/request.d.ts +36 -0
  272. package/dist/types/common/queue.d.ts +34 -0
  273. package/dist/types/config.d.ts +71 -0
  274. package/dist/types/constants.d.ts +1066 -0
  275. package/dist/types/controls-options-manager/constants.d.ts +4 -0
  276. package/dist/types/controls-options-manager/enums.d.ts +15 -0
  277. package/dist/types/controls-options-manager/index.d.ts +136 -0
  278. package/dist/types/controls-options-manager/types.d.ts +43 -0
  279. package/dist/types/controls-options-manager/util.d.ts +1 -0
  280. package/dist/types/index.d.ts +7 -0
  281. package/dist/types/interpretation/collection.d.ts +5 -0
  282. package/dist/types/interpretation/index.d.ts +5 -0
  283. package/dist/types/interpretation/siLanguage.d.ts +5 -0
  284. package/dist/types/locus-info/controlsUtils.d.ts +2 -0
  285. package/dist/types/locus-info/embeddedAppsUtils.d.ts +2 -0
  286. package/dist/types/locus-info/fullState.d.ts +2 -0
  287. package/dist/types/locus-info/hostUtils.d.ts +2 -0
  288. package/dist/types/locus-info/index.d.ts +322 -0
  289. package/dist/types/locus-info/infoUtils.d.ts +2 -0
  290. package/dist/types/locus-info/mediaSharesUtils.d.ts +2 -0
  291. package/dist/types/locus-info/parser.d.ts +273 -0
  292. package/dist/types/locus-info/selfUtils.d.ts +2 -0
  293. package/dist/types/media/index.d.ts +34 -0
  294. package/dist/types/media/properties.d.ts +93 -0
  295. package/dist/types/media/util.d.ts +2 -0
  296. package/dist/types/mediaQualityMetrics/config.d.ts +365 -0
  297. package/dist/types/meeting/in-meeting-actions.d.ts +163 -0
  298. package/dist/types/meeting/index.d.ts +1676 -0
  299. package/dist/types/meeting/locusMediaRequest.d.ts +74 -0
  300. package/dist/types/meeting/muteState.d.ts +184 -0
  301. package/dist/types/meeting/request.d.ts +290 -0
  302. package/dist/types/meeting/request.type.d.ts +11 -0
  303. package/dist/types/meeting/state.d.ts +9 -0
  304. package/dist/types/meeting/util.d.ts +102 -0
  305. package/dist/types/meeting-info/collection.d.ts +20 -0
  306. package/dist/types/meeting-info/index.d.ts +69 -0
  307. package/dist/types/meeting-info/meeting-info-v2.d.ts +123 -0
  308. package/dist/types/meeting-info/request.d.ts +22 -0
  309. package/dist/types/meeting-info/util.d.ts +2 -0
  310. package/dist/types/meeting-info/utilv2.d.ts +2 -0
  311. package/dist/types/meetings/collection.d.ts +31 -0
  312. package/dist/types/meetings/index.d.ts +367 -0
  313. package/dist/types/meetings/meetings.types.d.ts +4 -0
  314. package/dist/types/meetings/request.d.ts +27 -0
  315. package/dist/types/meetings/util.d.ts +18 -0
  316. package/dist/types/member/index.d.ts +160 -0
  317. package/dist/types/member/types.d.ts +32 -0
  318. package/dist/types/member/util.d.ts +2 -0
  319. package/dist/types/members/collection.d.ts +29 -0
  320. package/dist/types/members/index.d.ts +353 -0
  321. package/dist/types/members/request.d.ts +114 -0
  322. package/dist/types/members/types.d.ts +25 -0
  323. package/dist/types/members/util.d.ts +215 -0
  324. package/dist/types/metrics/constants.d.ts +65 -0
  325. package/dist/types/metrics/index.d.ts +45 -0
  326. package/dist/types/multistream/mediaRequestManager.d.ts +118 -0
  327. package/dist/types/multistream/receiveSlot.d.ts +68 -0
  328. package/dist/types/multistream/receiveSlotManager.d.ts +56 -0
  329. package/dist/types/multistream/remoteMedia.d.ts +72 -0
  330. package/dist/types/multistream/remoteMediaGroup.d.ts +47 -0
  331. package/dist/types/multistream/remoteMediaManager.d.ts +285 -0
  332. package/dist/types/multistream/sendSlotManager.d.ts +61 -0
  333. package/dist/types/networkQualityMonitor/index.d.ts +70 -0
  334. package/dist/types/personal-meeting-room/index.d.ts +47 -0
  335. package/dist/types/personal-meeting-room/request.d.ts +14 -0
  336. package/dist/types/personal-meeting-room/util.d.ts +2 -0
  337. package/dist/types/reachability/index.d.ts +194 -0
  338. package/dist/types/reachability/request.d.ts +39 -0
  339. package/dist/types/reactions/constants.d.ts +3 -0
  340. package/dist/types/reactions/reactions.d.ts +4 -0
  341. package/dist/types/reactions/reactions.type.d.ts +52 -0
  342. package/dist/types/reconnection-manager/index.d.ts +126 -0
  343. package/dist/types/recording-controller/enums.d.ts +7 -0
  344. package/dist/types/recording-controller/index.d.ts +207 -0
  345. package/dist/types/recording-controller/util.d.ts +14 -0
  346. package/dist/types/roap/index.d.ts +78 -0
  347. package/dist/types/roap/request.d.ts +39 -0
  348. package/dist/types/roap/turnDiscovery.d.ts +92 -0
  349. package/dist/types/rtcMetrics/constants.d.ts +4 -0
  350. package/dist/types/rtcMetrics/index.d.ts +47 -0
  351. package/dist/types/statsAnalyzer/global.d.ts +36 -0
  352. package/dist/types/statsAnalyzer/index.d.ts +201 -0
  353. package/dist/types/statsAnalyzer/mqaUtil.d.ts +24 -0
  354. package/dist/types/transcription/index.d.ts +64 -0
  355. package/dist/types/webinar/collection.d.ts +16 -0
  356. package/dist/types/webinar/index.d.ts +5 -0
  357. package/dist/webinar/collection.js +44 -0
  358. package/dist/webinar/collection.js.map +1 -0
  359. package/dist/webinar/index.js +69 -0
  360. package/dist/webinar/index.js.map +1 -0
  361. package/internal-README.md +7 -6
  362. package/package.json +29 -21
  363. package/src/annotation/annotation.types.ts +50 -0
  364. package/src/annotation/constants.ts +36 -0
  365. package/src/annotation/index.ts +328 -0
  366. package/src/breakouts/README.md +220 -0
  367. package/src/breakouts/breakout.ts +188 -0
  368. package/src/breakouts/collection.ts +19 -0
  369. package/src/breakouts/edit-lock-error.ts +25 -0
  370. package/src/breakouts/events.ts +56 -0
  371. package/src/breakouts/index.ts +925 -0
  372. package/src/breakouts/request.ts +55 -0
  373. package/src/breakouts/utils.ts +57 -0
  374. package/src/common/{browser-detection.js → browser-detection.ts} +9 -6
  375. package/src/common/collection.ts +9 -7
  376. package/src/common/{config.js → config.ts} +1 -1
  377. package/src/common/errors/{captcha-error.js → captcha-error.ts} +11 -7
  378. package/src/common/errors/{intent-to-join.js → intent-to-join.ts} +12 -7
  379. package/src/common/errors/{join-meeting.js → join-meeting.ts} +17 -8
  380. package/src/common/errors/{media.js → media.ts} +11 -7
  381. package/src/common/errors/no-meeting-info.ts +24 -0
  382. package/src/common/errors/parameter.ts +11 -7
  383. package/src/common/errors/{password-error.js → password-error.ts} +11 -7
  384. package/src/common/errors/{permission.js → permission.ts} +10 -6
  385. package/src/common/errors/reclaim-host-role-errors.ts +134 -0
  386. package/src/common/errors/{reconnection.js → reconnection.ts} +11 -7
  387. package/src/common/errors/{stats.js → stats.ts} +11 -7
  388. package/src/common/errors/{webex-errors.js → webex-errors.ts} +51 -8
  389. package/src/common/errors/{webex-meetings-error.js → webex-meetings-error.ts} +4 -2
  390. package/src/common/events/{events-scope.js → events-scope.ts} +6 -2
  391. package/src/common/events/{events.js → events.ts} +5 -1
  392. package/src/common/events/{trigger-proxy.js → trigger-proxy.ts} +9 -5
  393. package/src/common/events/{util.js → util.ts} +2 -3
  394. package/src/common/logs/{logger-config.js → logger-config.ts} +1 -2
  395. package/src/common/logs/logger-proxy.ts +44 -0
  396. package/src/common/logs/{request.js → request.ts} +26 -9
  397. package/src/common/queue.ts +22 -9
  398. package/src/{config.js → config.ts} +18 -19
  399. package/src/constants.ts +260 -22
  400. package/src/controls-options-manager/constants.ts +5 -0
  401. package/src/controls-options-manager/enums.ts +18 -0
  402. package/src/controls-options-manager/index.ts +278 -0
  403. package/src/controls-options-manager/types.ts +59 -0
  404. package/src/controls-options-manager/util.ts +300 -0
  405. package/src/index.ts +40 -0
  406. package/src/interpretation/README.md +60 -0
  407. package/src/interpretation/collection.ts +19 -0
  408. package/src/interpretation/index.ts +332 -0
  409. package/src/interpretation/siLanguage.ts +18 -0
  410. package/src/locus-info/controlsUtils.ts +222 -0
  411. package/src/locus-info/{embeddedAppsUtils.js → embeddedAppsUtils.ts} +5 -6
  412. package/src/locus-info/{fullState.js → fullState.ts} +16 -12
  413. package/src/locus-info/{hostUtils.js → hostUtils.ts} +9 -8
  414. package/src/locus-info/{index.js → index.ts} +557 -119
  415. package/src/locus-info/{infoUtils.js → infoUtils.ts} +29 -10
  416. package/src/locus-info/{mediaSharesUtils.js → mediaSharesUtils.ts} +81 -17
  417. package/src/locus-info/{parser.js → parser.ts} +303 -104
  418. package/src/locus-info/{selfUtils.js → selfUtils.ts} +199 -68
  419. package/src/media/index.ts +458 -0
  420. package/src/media/properties.ts +283 -0
  421. package/src/media/{util.js → util.ts} +2 -2
  422. package/src/mediaQualityMetrics/config.ts +384 -0
  423. package/src/meeting/in-meeting-actions.ts +191 -3
  424. package/src/meeting/index.ts +7882 -0
  425. package/src/meeting/locusMediaRequest.ts +313 -0
  426. package/src/meeting/muteState.ts +451 -0
  427. package/src/meeting/{request.js → request.ts} +421 -220
  428. package/src/meeting/request.type.ts +13 -0
  429. package/src/meeting/{state.js → state.ts} +50 -35
  430. package/src/meeting/util.ts +697 -0
  431. package/src/meeting-info/{collection.js → collection.ts} +6 -2
  432. package/src/meeting-info/index.ts +210 -0
  433. package/src/meeting-info/meeting-info-v2.ts +429 -0
  434. package/src/meeting-info/{request.js → request.ts} +14 -4
  435. package/src/meeting-info/{util.js → util.ts} +60 -51
  436. package/src/meeting-info/{utilv2.js → utilv2.ts} +78 -71
  437. package/src/meetings/{collection.js → collection.ts} +26 -3
  438. package/src/meetings/index.ts +1470 -0
  439. package/src/meetings/meetings.types.ts +12 -0
  440. package/src/meetings/{request.js → request.ts} +34 -25
  441. package/src/meetings/{util.js → util.ts} +132 -37
  442. package/src/member/{index.js → index.ts} +160 -56
  443. package/src/member/types.ts +38 -0
  444. package/src/member/util.ts +397 -0
  445. package/src/members/{collection.js → collection.ts} +10 -2
  446. package/src/members/{index.js → index.ts} +351 -146
  447. package/src/members/request.ts +255 -0
  448. package/src/members/types.ts +29 -0
  449. package/src/members/util.ts +353 -0
  450. package/src/metrics/{constants.js → constants.ts} +12 -6
  451. package/src/metrics/index.ts +73 -0
  452. package/src/multistream/mediaRequestManager.ts +337 -63
  453. package/src/multistream/receiveSlot.ts +69 -26
  454. package/src/multistream/receiveSlotManager.ts +66 -42
  455. package/src/multistream/remoteMedia.ts +40 -5
  456. package/src/multistream/remoteMediaGroup.ts +63 -3
  457. package/src/multistream/remoteMediaManager.ts +300 -66
  458. package/src/multistream/sendSlotManager.ts +170 -0
  459. package/src/networkQualityMonitor/{index.js → index.ts} +41 -29
  460. package/src/personal-meeting-room/{index.js → index.ts} +28 -19
  461. package/src/personal-meeting-room/{request.js → request.ts} +13 -4
  462. package/src/personal-meeting-room/{util.js → util.ts} +4 -4
  463. package/src/reachability/index.ts +671 -0
  464. package/src/reachability/request.ts +50 -35
  465. package/src/reactions/constants.ts +4 -0
  466. package/src/reactions/reactions.ts +104 -0
  467. package/src/reactions/reactions.type.ts +62 -0
  468. package/src/reconnection-manager/{index.js → index.ts} +258 -138
  469. package/src/recording-controller/enums.ts +8 -0
  470. package/src/recording-controller/index.ts +332 -0
  471. package/src/recording-controller/util.ts +75 -0
  472. package/src/roap/{index.js → index.ts} +127 -79
  473. package/src/roap/request.ts +153 -0
  474. package/src/roap/turnDiscovery.ts +109 -47
  475. package/src/rtcMetrics/constants.ts +3 -0
  476. package/src/rtcMetrics/index.ts +100 -0
  477. package/src/statsAnalyzer/global.ts +37 -0
  478. package/src/statsAnalyzer/index.ts +1250 -0
  479. package/src/statsAnalyzer/mqaUtil.ts +292 -0
  480. package/src/transcription/{index.js → index.ts} +46 -39
  481. package/src/webinar/collection.ts +31 -0
  482. package/src/webinar/index.ts +62 -0
  483. package/test/integration/spec/converged-space-meetings.js +233 -0
  484. package/test/integration/spec/journey.js +790 -530
  485. package/test/integration/spec/space-meeting.js +391 -204
  486. package/test/integration/spec/transcription.js +7 -8
  487. package/test/unit/spec/annotation/index.ts +418 -0
  488. package/test/unit/spec/breakouts/breakout.ts +237 -0
  489. package/test/unit/spec/breakouts/collection.ts +15 -0
  490. package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
  491. package/test/unit/spec/breakouts/events.ts +89 -0
  492. package/test/unit/spec/breakouts/index.ts +1790 -0
  493. package/test/unit/spec/breakouts/request.ts +104 -0
  494. package/test/unit/spec/breakouts/utils.js +72 -0
  495. package/test/unit/spec/common/browser-detection.js +9 -28
  496. package/test/unit/spec/common/queue.js +31 -2
  497. package/test/unit/spec/controls-options-manager/index.js +287 -0
  498. package/test/unit/spec/controls-options-manager/util.js +582 -0
  499. package/test/unit/spec/fixture/locus.js +93 -90
  500. package/test/unit/spec/interpretation/collection.ts +15 -0
  501. package/test/unit/spec/interpretation/index.ts +589 -0
  502. package/test/unit/spec/interpretation/siLanguage.ts +28 -0
  503. package/test/unit/spec/locus-info/controlsUtils.js +325 -32
  504. package/test/unit/spec/locus-info/embeddedAppsUtils.js +8 -6
  505. package/test/unit/spec/locus-info/index.js +1390 -17
  506. package/test/unit/spec/locus-info/infoUtils.js +71 -40
  507. package/test/unit/spec/locus-info/lib/BasicSeqCmp.json +88 -430
  508. package/test/unit/spec/locus-info/lib/SeqCmp.json +529 -685
  509. package/test/unit/spec/locus-info/mediaSharesUtils.ts +32 -0
  510. package/test/unit/spec/locus-info/parser.js +119 -44
  511. package/test/unit/spec/locus-info/selfConstant.js +120 -103
  512. package/test/unit/spec/locus-info/selfUtils.js +296 -12
  513. package/test/unit/spec/media/index.ts +128 -77
  514. package/test/unit/spec/media/properties.ts +11 -11
  515. package/test/unit/spec/meeting/in-meeting-actions.ts +92 -3
  516. package/test/unit/spec/meeting/index.js +7433 -2752
  517. package/test/unit/spec/meeting/locusMediaRequest.ts +442 -0
  518. package/test/unit/spec/meeting/muteState.js +420 -211
  519. package/test/unit/spec/meeting/request.js +545 -79
  520. package/test/unit/spec/meeting/utils.js +722 -174
  521. package/test/unit/spec/meeting-info/index.js +300 -0
  522. package/test/unit/spec/meeting-info/meetinginfov2.js +624 -76
  523. package/test/unit/spec/meeting-info/request.js +7 -9
  524. package/test/unit/spec/meeting-info/util.js +11 -12
  525. package/test/unit/spec/meeting-info/utilv2.js +131 -74
  526. package/test/unit/spec/meetings/collection.js +15 -1
  527. package/test/unit/spec/meetings/index.js +1365 -377
  528. package/test/unit/spec/meetings/utils.js +216 -14
  529. package/test/unit/spec/member/index.js +61 -7
  530. package/test/unit/spec/member/util.js +526 -26
  531. package/test/unit/spec/members/index.js +536 -55
  532. package/test/unit/spec/members/request.js +228 -40
  533. package/test/unit/spec/members/utils.js +217 -4
  534. package/test/unit/spec/metrics/index.js +12 -66
  535. package/test/unit/spec/multistream/mediaRequestManager.ts +1012 -109
  536. package/test/unit/spec/multistream/receiveSlot.ts +77 -18
  537. package/test/unit/spec/multistream/receiveSlotManager.ts +69 -39
  538. package/test/unit/spec/multistream/remoteMedia.ts +40 -2
  539. package/test/unit/spec/multistream/remoteMediaGroup.ts +271 -5
  540. package/test/unit/spec/multistream/remoteMediaManager.ts +738 -65
  541. package/test/unit/spec/multistream/sendSlotManager.ts +242 -0
  542. package/test/unit/spec/networkQualityMonitor/index.js +24 -18
  543. package/test/unit/spec/personal-meeting-room/personal-meeting-room.js +2 -7
  544. package/test/unit/spec/reachability/index.ts +598 -26
  545. package/test/unit/spec/reachability/request.js +68 -0
  546. package/test/unit/spec/reconnection-manager/index.js +181 -12
  547. package/test/unit/spec/recording-controller/index.js +307 -0
  548. package/test/unit/spec/recording-controller/util.js +229 -0
  549. package/test/unit/spec/roap/index.ts +179 -64
  550. package/test/unit/spec/roap/request.ts +232 -0
  551. package/test/unit/spec/roap/turnDiscovery.ts +123 -58
  552. package/test/unit/spec/rtcMetrics/index.ts +73 -0
  553. package/test/unit/spec/stats-analyzer/index.js +199 -60
  554. package/test/unit/spec/webinar/collection.ts +13 -0
  555. package/test/unit/spec/webinar/index.ts +60 -0
  556. package/test/utils/cmr.js +44 -42
  557. package/test/utils/constants.js +9 -0
  558. package/test/utils/integrationTestUtils.js +46 -0
  559. package/test/utils/testUtils.js +63 -99
  560. package/test/utils/webex-config.js +22 -18
  561. package/test/utils/webex-test-users.js +57 -50
  562. package/tsconfig.json +6 -0
  563. package/dist/media/internal-media-core-wrapper.js +0 -22
  564. package/dist/media/internal-media-core-wrapper.js.map +0 -1
  565. package/dist/meeting/effectsState.js +0 -327
  566. package/dist/meeting/effectsState.js.map +0 -1
  567. package/dist/metrics/config.js +0 -301
  568. package/dist/metrics/config.js.map +0 -1
  569. package/dist/multistream/multistreamMedia.js +0 -116
  570. package/dist/multistream/multistreamMedia.js.map +0 -1
  571. package/dist/peer-connection-manager/util.js +0 -124
  572. package/dist/peer-connection-manager/util.js.map +0 -1
  573. package/src/common/logs/logger-proxy.js +0 -33
  574. package/src/index.js +0 -15
  575. package/src/locus-info/controlsUtils.js +0 -102
  576. package/src/media/index.js +0 -459
  577. package/src/media/internal-media-core-wrapper.ts +0 -9
  578. package/src/media/properties.js +0 -289
  579. package/src/mediaQualityMetrics/config.js +0 -382
  580. package/src/meeting/effectsState.js +0 -205
  581. package/src/meeting/index.js +0 -6284
  582. package/src/meeting/muteState.js +0 -318
  583. package/src/meeting/util.js +0 -506
  584. package/src/meeting-info/index.js +0 -131
  585. package/src/meeting-info/meeting-info-v2.js +0 -255
  586. package/src/meetings/index.js +0 -1015
  587. package/src/member/util.js +0 -254
  588. package/src/members/request.js +0 -131
  589. package/src/members/util.js +0 -258
  590. package/src/metrics/config.js +0 -324
  591. package/src/metrics/index.js +0 -530
  592. package/src/multistream/multistreamMedia.ts +0 -92
  593. package/src/peer-connection-manager/util.ts +0 -117
  594. package/src/reachability/index.js +0 -464
  595. package/src/roap/request.js +0 -127
  596. package/src/statsAnalyzer/global.js +0 -133
  597. package/src/statsAnalyzer/index.js +0 -1006
  598. package/src/statsAnalyzer/mqaUtil.js +0 -173
  599. package/test/unit/spec/meeting/effectsState.js +0 -291
  600. package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -389
  601. /package/src/common/errors/{reconnection-in-progress.js → reconnection-in-progress.ts} +0 -0
@@ -12,14 +12,22 @@ import {
12
12
  _PERSONAL_ROOM_,
13
13
  _CONVERSATION_URL_,
14
14
  _SIP_URI_,
15
- WBXAPPAPI_SERVICE
15
+ WBXAPPAPI_SERVICE,
16
+ _LOCUS_ID_,
16
17
  } from '@webex/plugin-meetings/src/constants';
17
18
 
18
19
  import Meetings from '@webex/plugin-meetings/src/meetings';
19
- import MeetingInfo, {MeetingInfoV2PasswordError, MeetingInfoV2CaptchaError, MeetingInfoV2AdhocMeetingError} from '@webex/plugin-meetings/src/meeting-info/meeting-info-v2';
20
+ import MeetingInfo, {
21
+ MeetingInfoV2PasswordError,
22
+ MeetingInfoV2CaptchaError,
23
+ MeetingInfoV2AdhocMeetingError,
24
+ MeetingInfoV2PolicyError,
25
+ } from '@webex/plugin-meetings/src/meeting-info/meeting-info-v2';
20
26
  import MeetingInfoUtil from '@webex/plugin-meetings/src/meeting-info/utilv2';
21
27
  import Metrics from '@webex/plugin-meetings/src/metrics';
22
28
  import BEHAVIORAL_METRICS from '@webex/plugin-meetings/src/metrics/constants';
29
+ import {forEach} from 'lodash';
30
+ import { request } from 'express';
23
31
 
24
32
  describe('plugin-meetings', () => {
25
33
  const conversation = {
@@ -32,16 +40,15 @@ describe('plugin-meetings', () => {
32
40
  {
33
41
  id: '344ea183-9d5d-4e77-aed',
34
42
  emailAddress: 'testUser1@cisco.com',
35
- entryUUID: '344ea183-9d5d-4e77-'
36
-
43
+ entryUUID: '344ea183-9d5d-4e77-',
37
44
  },
38
45
  {
39
46
  id: '40b446fe-175c-4628-8a9d',
40
47
  emailAddress: 'testUser2@cisco.com',
41
- entryUUID: '40b446fe-175c-4628'
42
- }
43
- ]
44
- }
48
+ entryUUID: '40b446fe-175c-4628',
49
+ },
50
+ ],
51
+ },
45
52
  };
46
53
  let webex;
47
54
  let meetingInfo = null;
@@ -59,32 +66,33 @@ describe('plugin-meetings', () => {
59
66
  children: {
60
67
  device: Device,
61
68
  mercury: Mercury,
62
- meetings: Meetings
63
- }
69
+ meetings: Meetings,
70
+ },
64
71
  });
65
72
 
66
73
  webex.meetings.preferredWebexSite = 'go.webex.com';
67
- webex.config.meetings = {experimental: {enableUnifiedMeetings: true, enableAdhocMeetings: true}};
74
+ webex.config.meetings = {
75
+ experimental: {enableUnifiedMeetings: true, enableAdhocMeetings: true},
76
+ };
68
77
 
69
78
  Object.assign(webex.internal, {
70
79
  device: {
71
80
  deviceType: 'FAKE_DEVICE',
72
81
  register: sinon.stub().returns(Promise.resolve()),
73
82
  unregister: sinon.stub().returns(Promise.resolve()),
74
- userId: '01824b9b-adef-4b10-b5c1-8a2fe2fb7c0e'
83
+ userId: '01824b9b-adef-4b10-b5c1-8a2fe2fb7c0e',
75
84
  },
76
85
  mercury: {
77
86
  connect: sinon.stub().returns(Promise.resolve()),
78
87
  disconnect: sinon.stub().returns(Promise.resolve()),
79
88
  on: () => {},
80
- off: () => {}
89
+ off: () => {},
81
90
  },
82
91
  conversation: {
83
- get: sinon.stub().returns(Promise.resolve(conversation))
84
- }
92
+ get: sinon.stub().returns(Promise.resolve(conversation)),
93
+ },
85
94
  });
86
95
 
87
-
88
96
  meetingInfo = new MeetingInfo(webex);
89
97
  });
90
98
 
@@ -93,17 +101,22 @@ describe('plugin-meetings', () => {
93
101
  const body = {meetingKey: '1234323'};
94
102
  const requestResponse = {statusCode: 200, body};
95
103
 
96
- sinon.stub(MeetingInfoUtil, 'getDestinationType').returns(Promise.resolve({type: 'MEETING_ID', destination: '123456'}));
104
+ sinon
105
+ .stub(MeetingInfoUtil, 'getDestinationType')
106
+ .returns(Promise.resolve({type: 'MEETING_ID', destination: '123456'}));
97
107
  sinon.stub(MeetingInfoUtil, 'getRequestBody').returns(Promise.resolve(body));
98
108
  webex.request.resolves(requestResponse);
99
109
 
100
110
  const result = await meetingInfo.fetchMeetingInfo({
101
111
  type: _MEETING_ID_,
102
- destination: '1234323'
112
+ destination: '1234323',
103
113
  });
104
114
 
105
115
  assert.calledWith(webex.request, {
106
- method: 'POST', service: WBXAPPAPI_SERVICE, resource: 'meetingInfo', body: {meetingKey: '1234323'}
116
+ method: 'POST',
117
+ service: WBXAPPAPI_SERVICE,
118
+ resource: 'meetingInfo',
119
+ body: {meetingKey: '1234323'},
107
120
  });
108
121
  assert.deepEqual(result, requestResponse);
109
122
 
@@ -111,20 +124,25 @@ describe('plugin-meetings', () => {
111
124
  MeetingInfoUtil.getRequestBody.restore();
112
125
  });
113
126
 
114
- it('should fetch meeting info for the personal meeting room type', async () => {
127
+ it('should fetch meeting info for the personal meeting room type', async () => {
115
128
  const body = {meetingKey: '1234323'};
116
129
  const requestResponse = {statusCode: 200, body};
117
130
 
118
- sinon.stub(MeetingInfoUtil, 'getDestinationType').returns(Promise.resolve({type: 'MEETING_ID', destination: '123456'}));
131
+ sinon
132
+ .stub(MeetingInfoUtil, 'getDestinationType')
133
+ .returns(Promise.resolve({type: 'MEETING_ID', destination: '123456'}));
119
134
  sinon.stub(MeetingInfoUtil, 'getRequestBody').returns(Promise.resolve(body));
120
135
  webex.request.resolves(requestResponse);
121
136
 
122
137
  const result = await meetingInfo.fetchMeetingInfo({
123
- type: _PERSONAL_ROOM_
138
+ type: _PERSONAL_ROOM_,
124
139
  });
125
140
 
126
141
  assert.calledWith(webex.request, {
127
- method: 'POST', service: WBXAPPAPI_SERVICE, resource: 'meetingInfo', body: {meetingKey: '1234323'}
142
+ method: 'POST',
143
+ service: WBXAPPAPI_SERVICE,
144
+ resource: 'meetingInfo',
145
+ body: {meetingKey: '1234323'},
128
146
  });
129
147
  assert.deepEqual(result, requestResponse);
130
148
 
@@ -136,20 +154,28 @@ describe('plugin-meetings', () => {
136
154
  const body = {meetingKey: '1234323'};
137
155
  const requestResponse = {statusCode: 200, body};
138
156
 
139
- sinon.stub(MeetingInfoUtil, 'getDestinationType').returns(Promise.resolve({type: _SIP_URI_, destination: 'example@something.webex.com'}));
157
+ sinon
158
+ .stub(MeetingInfoUtil, 'getDestinationType')
159
+ .returns(Promise.resolve({type: _SIP_URI_, destination: 'example@something.webex.com'}));
140
160
  sinon.stub(MeetingInfoUtil, 'getRequestBody').returns(Promise.resolve(body));
141
161
  sinon.stub(MeetingInfoUtil, 'getDirectMeetingInfoURI').returns('https://example.com');
142
162
  webex.request.resolves(requestResponse);
143
163
 
144
- const result = await meetingInfo.fetchMeetingInfo(
145
- 'example@something.webex.com',
146
- _SIP_URI_,
147
- );
164
+ const result = await meetingInfo.fetchMeetingInfo('example@something.webex.com', _SIP_URI_);
148
165
 
149
- assert.calledWith(MeetingInfoUtil.getDestinationType, {destination: 'example@something.webex.com', type: _SIP_URI_, webex});
150
- assert.calledWith(MeetingInfoUtil.getDirectMeetingInfoURI, {destination: 'example@something.webex.com', type: _SIP_URI_});
166
+ assert.calledWith(MeetingInfoUtil.getDestinationType, {
167
+ destination: 'example@something.webex.com',
168
+ type: _SIP_URI_,
169
+ webex,
170
+ });
171
+ assert.calledWith(MeetingInfoUtil.getDirectMeetingInfoURI, {
172
+ destination: 'example@something.webex.com',
173
+ type: _SIP_URI_,
174
+ });
151
175
  assert.calledWith(webex.request, {
152
- method: 'POST', uri: 'https://example.com', body: {meetingKey: '1234323'}
176
+ method: 'POST',
177
+ uri: 'https://example.com',
178
+ body: {meetingKey: '1234323'},
153
179
  });
154
180
  assert.deepEqual(result, requestResponse);
155
181
 
@@ -163,7 +189,10 @@ describe('plugin-meetings', () => {
163
189
 
164
190
  webex.request.resolves(requestResponse);
165
191
 
166
- const result = await meetingInfo.fetchMeetingInfo('1234323', _MEETING_ID_, 'abc', {id: '999', code: 'aabbcc11'});
192
+ const result = await meetingInfo.fetchMeetingInfo('1234323', _MEETING_ID_, 'abc', {
193
+ id: '999',
194
+ code: 'aabbcc11',
195
+ });
167
196
 
168
197
  assert.calledWith(webex.request, {
169
198
  method: 'POST',
@@ -175,14 +204,95 @@ describe('plugin-meetings', () => {
175
204
  meetingKey: '1234323',
176
205
  password: 'abc',
177
206
  captchaID: '999',
178
- captchaVerifyCode: 'aabbcc11'
179
- }
207
+ captchaVerifyCode: 'aabbcc11',
208
+ },
209
+ });
210
+ assert.deepEqual(result, requestResponse);
211
+ assert(Metrics.sendBehavioralMetric.calledOnce);
212
+ assert.calledWith(
213
+ Metrics.sendBehavioralMetric,
214
+ BEHAVIORAL_METRICS.FETCH_MEETING_INFO_V1_SUCCESS
215
+ );
216
+ });
217
+
218
+ it('should fetch meeting info with provided installedOrgID', async () => {
219
+ const requestResponse = {statusCode: 200, body: {meetingKey: '1234323'}};
220
+ const installedOrgID = '123456';
221
+
222
+ webex.request.resolves(requestResponse);
223
+
224
+ const result = await meetingInfo.fetchMeetingInfo('1234323', _MEETING_ID_, null, null, installedOrgID);
225
+
226
+ assert.calledWith(webex.request, {
227
+ method: 'POST',
228
+ service: WBXAPPAPI_SERVICE,
229
+ resource: 'meetingInfo',
230
+ body: {
231
+ supportHostKey: true,
232
+ supportCountryList: true,
233
+ meetingKey: '1234323',
234
+ installedOrgID,
235
+ },
236
+ });
237
+ assert.deepEqual(result, requestResponse);
238
+ assert(Metrics.sendBehavioralMetric.calledOnce);
239
+ assert.calledWith(
240
+ Metrics.sendBehavioralMetric,
241
+ BEHAVIORAL_METRICS.FETCH_MEETING_INFO_V1_SUCCESS
242
+ );
243
+ });
244
+
245
+ it('should fetch meeting info with provided locusId', async () => {
246
+ const requestResponse = {statusCode: 200, body: {meetingKey: '1234323'}};
247
+ const locusId = 'eccd5c1b-d42d-35e3-a1b9-3021030a6d84';
248
+
249
+ webex.request.resolves(requestResponse);
250
+
251
+ const result = await meetingInfo.fetchMeetingInfo('1234323', _MEETING_ID_, null, null, null, locusId);
252
+
253
+ assert.calledWith(webex.request, {
254
+ method: 'POST',
255
+ service: WBXAPPAPI_SERVICE,
256
+ resource: 'meetingInfo',
257
+ body: {
258
+ supportHostKey: true,
259
+ supportCountryList: true,
260
+ meetingKey: '1234323',
261
+ locusId,
262
+ },
263
+ });
264
+ assert.deepEqual(result, requestResponse);
265
+ assert(Metrics.sendBehavioralMetric.calledOnce);
266
+ assert.calledWith(
267
+ Metrics.sendBehavioralMetric,
268
+ BEHAVIORAL_METRICS.FETCH_MEETING_INFO_V1_SUCCESS
269
+ );
270
+ });
271
+
272
+ it('should fetch meeting info with provided extraParams', async () => {
273
+ const requestResponse = {statusCode: 200, body: {meetingKey: '1234323'}};
274
+ const extraParams = {mtid: 'm9fe0afd8c435e892afcce9ea25b97046', joinTXId: 'TSmrX61wNF'}
275
+
276
+ webex.request.resolves(requestResponse);
277
+
278
+ const result = await meetingInfo.fetchMeetingInfo('1234323', _MEETING_ID_, null, null, null, null, extraParams);
279
+
280
+ assert.calledWith(webex.request, {
281
+ method: 'POST',
282
+ service: WBXAPPAPI_SERVICE,
283
+ resource: 'meetingInfo',
284
+ body: {
285
+ supportHostKey: true,
286
+ supportCountryList: true,
287
+ meetingKey: '1234323',
288
+ ...extraParams,
289
+ },
180
290
  });
181
291
  assert.deepEqual(result, requestResponse);
182
292
  assert(Metrics.sendBehavioralMetric.calledOnce);
183
293
  assert.calledWith(
184
294
  Metrics.sendBehavioralMetric,
185
- BEHAVIORAL_METRICS.FETCH_MEETING_INFO_V1_SUCCESS,
295
+ BEHAVIORAL_METRICS.FETCH_MEETING_INFO_V1_SUCCESS
186
296
  );
187
297
  });
188
298
 
@@ -195,6 +305,29 @@ describe('plugin-meetings', () => {
195
305
  meetingInfo.createAdhocSpaceMeeting.restore();
196
306
  });
197
307
 
308
+ it('create adhoc meeting when conversationUrl and installedOrgID passed with enableAdhocMeetings toggle', async () => {
309
+ sinon.stub(meetingInfo, 'createAdhocSpaceMeeting').returns(Promise.resolve());
310
+
311
+ const installedOrgID = '12345'
312
+
313
+ await meetingInfo.fetchMeetingInfo(
314
+ 'conversationUrl',
315
+ _CONVERSATION_URL_,
316
+ null,
317
+ null,
318
+ installedOrgID
319
+ );
320
+
321
+ assert.calledOnceWithExactly(
322
+ meetingInfo.createAdhocSpaceMeeting,
323
+ 'conversationUrl',
324
+ installedOrgID
325
+ );
326
+ assert.notCalled(webex.request);
327
+ meetingInfo.createAdhocSpaceMeeting.restore();
328
+ });
329
+
330
+
198
331
  it('should not call createAdhocSpaceMeeting if enableAdhocMeetings toggle is off', async () => {
199
332
  webex.config.meetings.experimental.enableAdhocMeetings = false;
200
333
  sinon.stub(meetingInfo, 'createAdhocSpaceMeeting').returns(Promise.resolve());
@@ -220,32 +353,331 @@ describe('plugin-meetings', () => {
220
353
  it('should throw an error MeetingInfoV2AdhocMeetingError if not able to start adhoc meeting for a conversation', async () => {
221
354
  webex.config.meetings.experimental.enableAdhocMeetings = true;
222
355
 
223
- webex.request = sinon.stub().rejects({statusCode: 403, body: {code: 400000}});
356
+ webex.request = sinon.stub().rejects({stack: 'a stack', message: 'a message', statusCode: 403, body: {code: 400000}});
224
357
  try {
225
358
  await meetingInfo.createAdhocSpaceMeeting('conversationUrl');
226
- }
227
- catch (err) {
359
+ } catch (err) {
228
360
  assert.instanceOf(err, MeetingInfoV2AdhocMeetingError);
229
- assert.deepEqual(err.message, 'Failed starting the adhoc meeting, Please contact support team , code=400000');
361
+ assert.deepEqual(
362
+ err.message,
363
+ 'Failed starting the adhoc meeting, Please contact support team , code=400000'
364
+ );
230
365
  assert.equal(err.wbxAppApiCode, 400000);
366
+ assert(Metrics.sendBehavioralMetric.calledOnce);
367
+ assert.calledWith(
368
+ Metrics.sendBehavioralMetric,
369
+ BEHAVIORAL_METRICS.ADHOC_MEETING_FAILURE,
370
+ {reason: 'a message', stack: 'a stack'}
371
+ );
231
372
  }
232
373
  });
233
374
 
375
+ forEach(
376
+ [
377
+ {errorCode: 403049, sendCAevents: false},
378
+ {errorCode: 403049, sendCAevents: true},
379
+ {errorCode: 403049},
380
+ {errorCode: 403104, sendCAevents: false},
381
+ {errorCode: 403104, sendCAevents: true},
382
+ {errorCode: 403104},
383
+ {errorCode: 403103, sendCAevents: false},
384
+ {errorCode: 403103, sendCAevents: true},
385
+ {errorCode: 403103},
386
+ {errorCode: 403048, sendCAevents: false},
387
+ {errorCode: 403048, sendCAevents: true},
388
+ {errorCode: 403048},
389
+ {errorCode: 403102, sendCAevents: false},
390
+ {errorCode: 403102, sendCAevents: true},
391
+ {errorCode: 403102},
392
+ {errorCode: 403101, sendCAevents: false},
393
+ {errorCode: 403101, sendCAevents: true},
394
+ {errorCode: 403101},
395
+ ],
396
+ ({errorCode, sendCAevents}) => {
397
+ it(`should throw a MeetingInfoV2PolicyError for error code ${errorCode}`, async () => {
398
+ const message = 'a message';
399
+ const meetingInfoData = 'meeting info';
400
+
401
+ webex.request = sinon.stub().rejects({
402
+ statusCode: 403,
403
+ body: {message, code: errorCode, data: {meetingInfo: meetingInfoData}},
404
+ url: 'http://api-url.com',
405
+ });
406
+ try {
407
+ await meetingInfo.fetchMeetingInfo(
408
+ '1234323',
409
+ _MEETING_ID_,
410
+ 'abc',
411
+ {
412
+ id: '999',
413
+ code: 'aabbcc11',
414
+ },
415
+ null,
416
+ null,
417
+ {},
418
+ {meetingId: 'meeting-id', sendCAevents}
419
+ );
420
+ assert.fail('fetchMeetingInfo should have thrown, but has not done that');
421
+ } catch (err) {
422
+ const submitInternalEventCalls = webex.internal.newMetrics.submitInternalEvent.getCalls();
423
+ const submitClientEventCalls = webex.internal.newMetrics.submitClientEvent.getCalls();
424
+
425
+ if (sendCAevents) {
426
+ assert.deepEqual(submitInternalEventCalls[0].args[0], {
427
+ name: 'internal.client.meetinginfo.request',
428
+ });
429
+
430
+ assert.deepEqual(submitClientEventCalls[0].args[0], {
431
+ name: 'client.meetinginfo.request',
432
+ options: {
433
+ meetingId: 'meeting-id'
434
+ },
435
+ });
436
+
437
+ assert.deepEqual(submitInternalEventCalls[1].args[0], {
438
+ name: 'internal.client.meetinginfo.response',
439
+ });
440
+
441
+ assert.deepEqual(submitClientEventCalls[1].args[0], {
442
+ name: 'client.meetinginfo.response',
443
+ payload: {
444
+ identifiers: {
445
+ meetingLookupUrl: 'http://api-url.com',
446
+ },
447
+ },
448
+ options: {
449
+ meetingId: 'meeting-id',
450
+ rawError: {
451
+ statusCode: 403,
452
+ body: {message, code: errorCode, data: {meetingInfo: meetingInfoData}},
453
+ url: 'http://api-url.com',
454
+ },
455
+ },
456
+ });
457
+ } else {
458
+ assert.notCalled(webex.internal.newMetrics.submitClientEvent);
459
+ }
460
+
461
+ assert.instanceOf(err, MeetingInfoV2PolicyError);
462
+ assert.deepEqual(err.message, `${message}, code=${errorCode}`);
463
+ assert.equal(err.wbxAppApiCode, errorCode);
464
+ assert.deepEqual(err.meetingInfo, meetingInfoData);
465
+ assert(Metrics.sendBehavioralMetric.calledOnce);
466
+ assert.calledWith(
467
+ Metrics.sendBehavioralMetric,
468
+ BEHAVIORAL_METRICS.MEETING_INFO_POLICY_ERROR,
469
+ {code: errorCode}
470
+ );
471
+ }
472
+ });
473
+ }
474
+ );
475
+
476
+ forEach(
477
+ [
478
+ {meetingId: '123', sendCAevents: true, shouldSendCAevents: true},
479
+ {sendCAevents: true, shouldSendCAevents: false},
480
+ {meetingId: '123', sendCAevents: false, shouldSendCAevents: false},
481
+ {shouldSendCAevents: false},
482
+ {meetingId: '123', sendCAevents: true, shouldSendCAevents: true, confIdStr: '999'},
483
+ ],
484
+ ({meetingId, sendCAevents, shouldSendCAevents, confIdStr}) => {
485
+ it('should send CA metric if meetingId is provided and send CA events is authorized', async () => {
486
+ const requestResponse = {statusCode: 200, body: {meetingKey: '1234323', meetingId: '123', confID: '321'}};
487
+ if (confIdStr) {
488
+ requestResponse.body.confIdStr = confIdStr;
489
+ }
490
+ const extraParams = {mtid: 'm9fe0afd8c435e892afcce9ea25b97046', joinTXId: 'TSmrX61wNF'}
491
+
492
+ webex.request.resolves(requestResponse);
493
+
494
+ const result = await meetingInfo.fetchMeetingInfo(
495
+ '1234323',
496
+ _MEETING_ID_,
497
+ null,
498
+ null,
499
+ null,
500
+ null,
501
+ extraParams,
502
+ {meetingId, sendCAevents}
503
+ );
504
+
505
+ assert.calledWith(webex.request, {
506
+ method: 'POST',
507
+ service: WBXAPPAPI_SERVICE,
508
+ resource: 'meetingInfo',
509
+ body: {
510
+ supportHostKey: true,
511
+ supportCountryList: true,
512
+ meetingKey: '1234323',
513
+ ...extraParams,
514
+ },
515
+ });
516
+ assert.deepEqual(result, requestResponse);
517
+ assert(Metrics.sendBehavioralMetric.calledOnce);
518
+ assert.calledWith(
519
+ Metrics.sendBehavioralMetric,
520
+ BEHAVIORAL_METRICS.FETCH_MEETING_INFO_V1_SUCCESS
521
+ );
522
+
523
+ const submitInternalEventCalls = webex.internal.newMetrics.submitInternalEvent.getCalls();
524
+ const submitClientEventCalls = webex.internal.newMetrics.submitClientEvent.getCalls();
525
+
526
+ if(shouldSendCAevents) {
527
+ assert.deepEqual(submitInternalEventCalls[0].args[0], {
528
+ name: 'internal.client.meetinginfo.request',
529
+ });
530
+ assert.deepEqual(submitClientEventCalls[0].args[0], {
531
+ name: 'client.meetinginfo.request',
532
+ options: {
533
+ meetingId,
534
+ }
535
+ });
536
+
537
+ assert.deepEqual(submitInternalEventCalls[1].args[0], {
538
+ name: 'internal.client.meetinginfo.response',
539
+ });
540
+ assert.deepEqual(submitClientEventCalls[1].args[0], {
541
+ name: 'client.meetinginfo.response',
542
+ payload: {
543
+ identifiers: {
544
+ meetingLookupUrl: result?.url,
545
+ },
546
+ },
547
+ options: {
548
+ meetingId,
549
+ globalMeetingId: requestResponse.body?.meetingId,
550
+ webexConferenceIdStr: confIdStr ? requestResponse.body?.confIdStr : requestResponse.body?.confID,
551
+ }
552
+ });
553
+ } else {
554
+ assert.notCalled(webex.internal.newMetrics.submitClientEvent);
555
+ assert.notCalled(webex.internal.newMetrics.submitInternalEvent);
556
+ }
557
+ })
558
+ }
559
+ )
560
+
561
+ it('should send CA metric if meetingId is provided and send CA events is authorized', async () => {
562
+ const requestResponse = {statusCode: 200, body: {meetingKey: '1234323', confID: '123', meetingId: '321'}};
563
+ const extraParams = {mtid: 'm9fe0afd8c435e892afcce9ea25b97046', joinTXId: 'TSmrX61wNF'}
564
+
565
+ webex.request.resolves(requestResponse);
566
+
567
+ const result = await meetingInfo.fetchMeetingInfo(
568
+ '1234323',
569
+ _MEETING_ID_,
570
+ null,
571
+ null,
572
+ null,
573
+ null,
574
+ extraParams,
575
+ {meetingId: 'meetingId', sendCAevents: true}
576
+ );
577
+
578
+ assert.calledWith(webex.request, {
579
+ method: 'POST',
580
+ service: WBXAPPAPI_SERVICE,
581
+ resource: 'meetingInfo',
582
+ body: {
583
+ supportHostKey: true,
584
+ supportCountryList: true,
585
+ meetingKey: '1234323',
586
+ ...extraParams,
587
+ },
588
+ });
589
+ assert.deepEqual(result, requestResponse);
590
+ assert(Metrics.sendBehavioralMetric.calledOnce);
591
+ assert.calledWith(
592
+ Metrics.sendBehavioralMetric,
593
+ BEHAVIORAL_METRICS.FETCH_MEETING_INFO_V1_SUCCESS
594
+ );
595
+
596
+ const submitInternalEventCalls = webex.internal.newMetrics.submitInternalEvent.getCalls();
597
+ const submitClientEventCalls = webex.internal.newMetrics.submitClientEvent.getCalls();
598
+
599
+ assert.deepEqual(submitInternalEventCalls[0].args[0], {
600
+ name: 'internal.client.meetinginfo.request',
601
+ });
602
+ assert.deepEqual(submitClientEventCalls[0].args[0], {
603
+ name: 'client.meetinginfo.request',
604
+ options: {
605
+ meetingId: 'meetingId',
606
+ }
607
+ });
608
+
609
+ assert.deepEqual(submitInternalEventCalls[1].args[0], {
610
+ name: 'internal.client.meetinginfo.response',
611
+ });
612
+ assert.deepEqual(submitClientEventCalls[1].args[0], {
613
+ name: 'client.meetinginfo.response',
614
+ payload: {
615
+ identifiers: {
616
+ meetingLookupUrl: result?.url,
617
+ },
618
+ },
619
+ options: {
620
+ meetingId: 'meetingId',
621
+ globalMeetingId: requestResponse.body?.meetingId,
622
+ webexConferenceIdStr: requestResponse.body?.confID,
623
+ }
624
+ });
625
+ });
626
+
627
+ forEach(
628
+ [
629
+ {sendCAevents: true},
630
+ {sendCAevents: false},
631
+ ],
632
+ ({sendCAevents}) => {
633
+ it(`should not send CA metric if meetingId is not provided disregarding if sendCAevents is ${sendCAevents}`, async () => {
634
+ const message = 'a message';
635
+ const meetingInfoData = 'meeting info';
636
+
637
+ webex.request = sinon.stub().rejects({
638
+ statusCode: 403,
639
+ body: {message, code: 403102, data: {meetingInfo: meetingInfoData}},
640
+ url: 'http://api-url.com',
641
+ });
642
+ try {
643
+ await meetingInfo.fetchMeetingInfo(
644
+ '1234323',
645
+ _MEETING_ID_,
646
+ 'abc',
647
+ {
648
+ id: '999',
649
+ code: 'aabbcc11',
650
+ },
651
+ null,
652
+ null,
653
+ undefined,
654
+ {meetingId: undefined, sendCAevents}
655
+ );
656
+ assert.fail('fetchMeetingInfo should have thrown, but has not done that');
657
+ } catch (err) {
658
+ assert.notCalled(webex.internal.newMetrics.submitClientEvent);
659
+ assert.notCalled(webex.internal.newMetrics.submitInternalEvent);
660
+ }
661
+ });
662
+ }
663
+ );
664
+
234
665
  it('should throw MeetingInfoV2PasswordError for 403 response', async () => {
235
666
  const FAKE_MEETING_INFO = {blablabla: 'some_fake_meeting_info'};
236
667
 
237
- webex.request = sinon.stub().rejects({statusCode: 403, body: {code: 403000, data: {meetingInfo: FAKE_MEETING_INFO}}});
668
+ webex.request = sinon
669
+ .stub()
670
+ .rejects({statusCode: 403, body: {code: 403000, data: {meetingInfo: FAKE_MEETING_INFO}}});
238
671
 
239
672
  try {
240
- await meetingInfo.fetchMeetingInfo('1234323', _MEETING_ID_, 'abc', {id: '999', code: 'aabbcc11'});
673
+ await meetingInfo.fetchMeetingInfo('1234323', _MEETING_ID_, 'abc', {
674
+ id: '999',
675
+ code: 'aabbcc11',
676
+ });
241
677
  assert.fail('fetchMeetingInfo should have thrown, but has not done that');
242
- }
243
- catch (err) {
678
+ } catch (err) {
244
679
  assert(Metrics.sendBehavioralMetric.calledOnce);
245
- assert.calledWith(
246
- Metrics.sendBehavioralMetric,
247
- BEHAVIORAL_METRICS.VERIFY_PASSWORD_ERROR,
248
- );
680
+ assert.calledWith(Metrics.sendBehavioralMetric, BEHAVIORAL_METRICS.VERIFY_PASSWORD_ERROR);
249
681
  assert.instanceOf(err, MeetingInfoV2PasswordError);
250
682
  assert.deepEqual(err.meetingInfo, FAKE_MEETING_INFO);
251
683
  assert.equal(err.wbxAppApiCode, 403000);
@@ -254,34 +686,34 @@ describe('plugin-meetings', () => {
254
686
 
255
687
  describe('should throw MeetingInfoV2CaptchaError for 423 response', () => {
256
688
  const runTest = async (wbxAppApiCode, expectedIsPasswordRequired) => {
257
- webex.request = sinon.stub().rejects(
258
- {
259
- statusCode: 423,
260
- body: {
261
- code: wbxAppApiCode,
262
- captchaID: 'fake_captcha_id',
263
- verificationImageURL: 'fake_image_url',
264
- verificationAudioURL: 'fake_audio_url',
265
- refreshURL: 'fake_refresh_url'
266
- }
267
- }
268
- );
689
+ webex.request = sinon.stub().rejects({
690
+ statusCode: 423,
691
+ body: {
692
+ code: wbxAppApiCode,
693
+ captchaID: 'fake_captcha_id',
694
+ verificationImageURL: 'fake_image_url',
695
+ verificationAudioURL: 'fake_audio_url',
696
+ refreshURL: 'fake_refresh_url',
697
+ },
698
+ });
269
699
  try {
270
- await meetingInfo.fetchMeetingInfo('1234323', _MEETING_ID_, 'abc', {id: '999', code: 'aabbcc11'});
700
+ await meetingInfo.fetchMeetingInfo('1234323', _MEETING_ID_, 'abc', {
701
+ id: '999',
702
+ code: 'aabbcc11',
703
+ });
271
704
  assert.fail('fetchMeetingInfo should have thrown, but has not done that');
272
- }
273
- catch (err) {
705
+ } catch (err) {
274
706
  assert(Metrics.sendBehavioralMetric.calledOnce);
275
707
  assert.calledWith(
276
708
  Metrics.sendBehavioralMetric,
277
- BEHAVIORAL_METRICS.VERIFY_CAPTCHA_ERROR,
709
+ BEHAVIORAL_METRICS.VERIFY_CAPTCHA_ERROR
278
710
  );
279
711
  assert.instanceOf(err, MeetingInfoV2CaptchaError);
280
712
  assert.deepEqual(err.captchaInfo, {
281
713
  captchaId: 'fake_captcha_id',
282
714
  verificationImageURL: 'fake_image_url',
283
715
  verificationAudioURL: 'fake_audio_url',
284
- refreshURL: 'fake_refresh_url'
716
+ refreshURL: 'fake_refresh_url',
285
717
  });
286
718
  assert.equal(err.wbxAppApiCode, wbxAppApiCode);
287
719
  assert.equal(err.isPasswordRequired, expectedIsPasswordRequired);
@@ -300,28 +732,76 @@ describe('plugin-meetings', () => {
300
732
  await runTest(423001, false);
301
733
  });
302
734
  });
303
- });
304
735
 
736
+ it('should throw an error and not fetch with an "empty" body', async () => {
737
+ const body = {supportHostKey: 'foo', supportCountryList: 'bar'};
738
+ const requestResponse = {statusCode: 200, body};
739
+
740
+ sinon
741
+ .stub(MeetingInfoUtil, 'getDestinationType')
742
+ .returns(Promise.resolve({type: _LOCUS_ID_, destination: '123456'}));
743
+ sinon.stub(MeetingInfoUtil, 'getRequestBody').returns(Promise.resolve(body));
744
+ webex.request.resolves(requestResponse);
745
+
746
+ try {
747
+ await meetingInfo.fetchMeetingInfo({
748
+ type: _LOCUS_ID_,
749
+ });
750
+ assert.fail('fetchMeetingInfo should have thrown, but has not done that');
751
+ } catch (err) {
752
+ assert.calledWith(
753
+ Metrics.sendBehavioralMetric,
754
+ BEHAVIORAL_METRICS.FETCH_MEETING_INFO_V1_FAILURE,
755
+ {
756
+ reason: 'Not enough information to fetch meeting info',
757
+ destinationType: _LOCUS_ID_,
758
+ webExMeetingId: undefined,
759
+ sipUri: undefined,
760
+ }
761
+ );
762
+ assert(Metrics.sendBehavioralMetric.calledOnce);
763
+ assert.calledWith(
764
+ Metrics.sendBehavioralMetric,
765
+ BEHAVIORAL_METRICS.FETCH_MEETING_INFO_V1_FAILURE
766
+ );
767
+ assert.deepEqual(err.message, 'Not enough information to fetch meeting info');
768
+ }
769
+
770
+ MeetingInfoUtil.getDestinationType.restore();
771
+ MeetingInfoUtil.getRequestBody.restore();
772
+ });
773
+ });
305
774
 
306
775
  describe('createAdhocSpaceMeeting', () => {
307
- it('Make a request to /instantSpace when conversationUrl', async () => {
308
- const conversationUrl = 'https://conversationUrl/xxx';
776
+ const conversationUrl = 'https://conversationUrl/xxx';
777
+ const installedOrgID = '12345';
778
+
779
+ const setup = () => {
309
780
  const invitee = [];
310
781
 
311
782
  invitee.push({
312
783
  email: conversation.participants.items[0].emailAddress,
313
- ciUserUuid: conversation.participants.items[0].entryUUID
784
+ ciUserUuid: conversation.participants.items[0].entryUUID,
314
785
  });
315
786
 
316
787
  invitee.push({
317
788
  email: conversation.participants.items[1].emailAddress,
318
- ciUserUuid: conversation.participants.items[1].entryUUID
789
+ ciUserUuid: conversation.participants.items[1].entryUUID,
319
790
  });
320
791
 
321
- await meetingInfo.createAdhocSpaceMeeting(conversationUrl);
792
+ return {invitee}
793
+ }
794
+
795
+ it('Make a request to /spaceInstant when conversationUrl', async () => {
796
+ const {invitee} = setup();
322
797
 
323
- assert.calledWith(webex.internal.conversation.get, {url: conversationUrl},
324
- {includeParticipants: true, disableTransform: true});
798
+ const result = await meetingInfo.createAdhocSpaceMeeting(conversationUrl);
799
+
800
+ assert.calledWith(
801
+ webex.internal.conversation.get,
802
+ {url: conversationUrl},
803
+ {includeParticipants: true, disableTransform: true}
804
+ );
325
805
 
326
806
  assert.calledWith(webex.request, {
327
807
  method: 'POST',
@@ -331,15 +811,83 @@ describe('plugin-meetings', () => {
331
811
  spaceUrl: conversation.url,
332
812
  keyUrl: conversation.encryptionKeyUrl,
333
813
  kroUrl: conversation.kmsResourceObjectUrl,
334
- invitees: invitee
335
- }
814
+ invitees: invitee,
815
+ },
336
816
  });
337
817
  assert(Metrics.sendBehavioralMetric.calledOnce);
818
+ assert.calledWith(Metrics.sendBehavioralMetric, BEHAVIORAL_METRICS.ADHOC_MEETING_SUCCESS);
819
+ assert.deepEqual(result, {
820
+ body: {},
821
+ statusCode: 200
822
+ });
823
+ });
824
+
825
+ it('Make a request to /spaceInstant when conversationUrl with installed org ID', async () => {
826
+ const {invitee} = setup();
827
+
828
+ await meetingInfo.createAdhocSpaceMeeting(conversationUrl, installedOrgID);
829
+
338
830
  assert.calledWith(
339
- Metrics.sendBehavioralMetric,
340
- BEHAVIORAL_METRICS.ADHOC_MEETING_SUCCESS,
831
+ webex.internal.conversation.get,
832
+ {url: conversationUrl},
833
+ {includeParticipants: true, disableTransform: true}
341
834
  );
835
+
836
+ assert.calledWith(webex.request, {
837
+ method: 'POST',
838
+ uri: 'https://go.webex.com/wbxappapi/v2/meetings/spaceInstant',
839
+ body: {
840
+ title: conversation.displayName,
841
+ spaceUrl: conversation.url,
842
+ keyUrl: conversation.encryptionKeyUrl,
843
+ kroUrl: conversation.kmsResourceObjectUrl,
844
+ invitees: invitee,
845
+ installedOrgID,
846
+ },
847
+ });
848
+ assert(Metrics.sendBehavioralMetric.calledOnce);
849
+ assert.calledWith(Metrics.sendBehavioralMetric, BEHAVIORAL_METRICS.ADHOC_MEETING_SUCCESS);
342
850
  });
851
+
852
+
853
+ forEach(
854
+ [
855
+ {errorCode: 403049},
856
+ {errorCode: 403104},
857
+ {errorCode: 403103},
858
+ {errorCode: 403048},
859
+ {errorCode: 403102},
860
+ {errorCode: 403101},
861
+ ],
862
+ ({errorCode}) => {
863
+ it(`should throw a MeetingInfoV2PolicyError for error code ${errorCode}`, async () => {
864
+ const message = 'a message';
865
+ const meetingInfoData = 'meeting info';
866
+
867
+ webex.request = sinon.stub().rejects({
868
+ statusCode: 403,
869
+ body: {message, code: errorCode, data: {meetingInfo: meetingInfoData}},
870
+ });
871
+ try {
872
+ await meetingInfo.createAdhocSpaceMeeting(conversationUrl, installedOrgID);
873
+ assert.fail('createAdhocSpaceMeeting should have thrown, but has not done that');
874
+ } catch (err) {
875
+ assert.instanceOf(err, MeetingInfoV2PolicyError);
876
+ assert.deepEqual(err.message, `${message}, code=${errorCode}`);
877
+ assert.equal(err.wbxAppApiCode, errorCode);
878
+ assert.deepEqual(err.meetingInfo, meetingInfoData);
879
+
880
+ assert(Metrics.sendBehavioralMetric.calledOnce);
881
+ assert.calledWith(
882
+ Metrics.sendBehavioralMetric,
883
+ BEHAVIORAL_METRICS.MEETING_INFO_POLICY_ERROR,
884
+ {code: errorCode}
885
+ );
886
+
887
+ }
888
+ });
889
+ }
890
+ );
343
891
  });
344
892
  });
345
893
  });