@webex/plugin-meetings 3.0.0-beta.41 → 3.0.0-beta.410

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 (398) hide show
  1. package/README.md +58 -8
  2. package/dist/annotation/annotation.types.js +7 -0
  3. package/dist/annotation/annotation.types.js.map +1 -0
  4. package/dist/annotation/constants.js +49 -0
  5. package/dist/annotation/constants.js.map +1 -0
  6. package/dist/annotation/index.js +342 -0
  7. package/dist/annotation/index.js.map +1 -0
  8. package/dist/breakouts/breakout.js +94 -15
  9. package/dist/breakouts/breakout.js.map +1 -1
  10. package/dist/breakouts/events.js +45 -0
  11. package/dist/breakouts/events.js.map +1 -0
  12. package/dist/breakouts/index.js +625 -123
  13. package/dist/breakouts/index.js.map +1 -1
  14. package/dist/breakouts/utils.js +27 -8
  15. package/dist/breakouts/utils.js.map +1 -1
  16. package/dist/common/errors/no-meeting-info.js +51 -0
  17. package/dist/common/errors/no-meeting-info.js.map +1 -0
  18. package/dist/common/errors/reclaim-host-role-errors.js +158 -0
  19. package/dist/common/errors/reclaim-host-role-errors.js.map +1 -0
  20. package/dist/common/errors/webex-errors.js +48 -7
  21. package/dist/common/errors/webex-errors.js.map +1 -1
  22. package/dist/common/logs/logger-proxy.js +1 -1
  23. package/dist/common/logs/logger-proxy.js.map +1 -1
  24. package/dist/common/logs/request.js +5 -1
  25. package/dist/common/logs/request.js.map +1 -1
  26. package/dist/common/queue.js +24 -9
  27. package/dist/common/queue.js.map +1 -1
  28. package/dist/config.js +6 -10
  29. package/dist/config.js.map +1 -1
  30. package/dist/constants.js +247 -34
  31. package/dist/constants.js.map +1 -1
  32. package/dist/controls-options-manager/enums.js +14 -2
  33. package/dist/controls-options-manager/enums.js.map +1 -1
  34. package/dist/controls-options-manager/index.js +109 -15
  35. package/dist/controls-options-manager/index.js.map +1 -1
  36. package/dist/controls-options-manager/types.js +7 -0
  37. package/dist/controls-options-manager/types.js.map +1 -0
  38. package/dist/controls-options-manager/util.js +309 -18
  39. package/dist/controls-options-manager/util.js.map +1 -1
  40. package/dist/index.js +116 -2
  41. package/dist/index.js.map +1 -1
  42. package/dist/interceptors/index.js +15 -0
  43. package/dist/interceptors/index.js.map +1 -0
  44. package/dist/interceptors/locusRetry.js +93 -0
  45. package/dist/interceptors/locusRetry.js.map +1 -0
  46. package/dist/interpretation/collection.js +23 -0
  47. package/dist/interpretation/collection.js.map +1 -0
  48. package/dist/interpretation/index.js +380 -0
  49. package/dist/interpretation/index.js.map +1 -0
  50. package/dist/interpretation/siLanguage.js +25 -0
  51. package/dist/interpretation/siLanguage.js.map +1 -0
  52. package/dist/locus-info/controlsUtils.js +91 -2
  53. package/dist/locus-info/controlsUtils.js.map +1 -1
  54. package/dist/locus-info/index.js +386 -62
  55. package/dist/locus-info/index.js.map +1 -1
  56. package/dist/locus-info/infoUtils.js +7 -1
  57. package/dist/locus-info/infoUtils.js.map +1 -1
  58. package/dist/locus-info/mediaSharesUtils.js +71 -1
  59. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  60. package/dist/locus-info/parser.js +249 -72
  61. package/dist/locus-info/parser.js.map +1 -1
  62. package/dist/locus-info/selfUtils.js +89 -14
  63. package/dist/locus-info/selfUtils.js.map +1 -1
  64. package/dist/media/index.js +65 -102
  65. package/dist/media/index.js.map +1 -1
  66. package/dist/media/properties.js +73 -124
  67. package/dist/media/properties.js.map +1 -1
  68. package/dist/mediaQualityMetrics/config.js +135 -330
  69. package/dist/mediaQualityMetrics/config.js.map +1 -1
  70. package/dist/meeting/in-meeting-actions.js +86 -2
  71. package/dist/meeting/in-meeting-actions.js.map +1 -1
  72. package/dist/meeting/index.js +4531 -2994
  73. package/dist/meeting/index.js.map +1 -1
  74. package/dist/meeting/locusMediaRequest.js +292 -0
  75. package/dist/meeting/locusMediaRequest.js.map +1 -0
  76. package/dist/meeting/muteState.js +236 -136
  77. package/dist/meeting/muteState.js.map +1 -1
  78. package/dist/meeting/request.js +189 -155
  79. package/dist/meeting/request.js.map +1 -1
  80. package/dist/meeting/util.js +676 -417
  81. package/dist/meeting/util.js.map +1 -1
  82. package/dist/meeting/voicea-meeting.js +172 -0
  83. package/dist/meeting/voicea-meeting.js.map +1 -0
  84. package/dist/meeting-info/index.js +73 -7
  85. package/dist/meeting-info/index.js.map +1 -1
  86. package/dist/meeting-info/meeting-info-v2.js +201 -57
  87. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  88. package/dist/meeting-info/util.js +8 -7
  89. package/dist/meeting-info/util.js.map +1 -1
  90. package/dist/meeting-info/utilv2.js +44 -40
  91. package/dist/meeting-info/utilv2.js.map +1 -1
  92. package/dist/meetings/collection.js +39 -0
  93. package/dist/meetings/collection.js.map +1 -1
  94. package/dist/meetings/index.js +484 -119
  95. package/dist/meetings/index.js.map +1 -1
  96. package/dist/meetings/meetings.types.js +7 -0
  97. package/dist/meetings/meetings.types.js.map +1 -0
  98. package/dist/meetings/request.js +2 -0
  99. package/dist/meetings/request.js.map +1 -1
  100. package/dist/meetings/util.js +73 -7
  101. package/dist/meetings/util.js.map +1 -1
  102. package/dist/member/index.js +57 -0
  103. package/dist/member/index.js.map +1 -1
  104. package/dist/member/types.js +25 -0
  105. package/dist/member/types.js.map +1 -0
  106. package/dist/member/util.js +132 -25
  107. package/dist/member/util.js.map +1 -1
  108. package/dist/members/collection.js +10 -0
  109. package/dist/members/collection.js.map +1 -1
  110. package/dist/members/index.js +100 -5
  111. package/dist/members/index.js.map +1 -1
  112. package/dist/members/request.js +106 -38
  113. package/dist/members/request.js.map +1 -1
  114. package/dist/members/types.js +15 -0
  115. package/dist/members/types.js.map +1 -0
  116. package/dist/members/util.js +326 -232
  117. package/dist/members/util.js.map +1 -1
  118. package/dist/metrics/constants.js +18 -1
  119. package/dist/metrics/constants.js.map +1 -1
  120. package/dist/metrics/index.js +1 -446
  121. package/dist/metrics/index.js.map +1 -1
  122. package/dist/multistream/mediaRequestManager.js +223 -32
  123. package/dist/multistream/mediaRequestManager.js.map +1 -1
  124. package/dist/multistream/receiveSlot.js +10 -0
  125. package/dist/multistream/receiveSlot.js.map +1 -1
  126. package/dist/multistream/receiveSlotManager.js +39 -36
  127. package/dist/multistream/receiveSlotManager.js.map +1 -1
  128. package/dist/multistream/remoteMedia.js +3 -1
  129. package/dist/multistream/remoteMedia.js.map +1 -1
  130. package/dist/multistream/remoteMediaGroup.js +76 -5
  131. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  132. package/dist/multistream/remoteMediaManager.js +366 -104
  133. package/dist/multistream/remoteMediaManager.js.map +1 -1
  134. package/dist/multistream/sendSlotManager.js +255 -0
  135. package/dist/multistream/sendSlotManager.js.map +1 -0
  136. package/dist/reachability/clusterReachability.js +356 -0
  137. package/dist/reachability/clusterReachability.js.map +1 -0
  138. package/dist/reachability/index.js +263 -390
  139. package/dist/reachability/index.js.map +1 -1
  140. package/dist/reachability/request.js +6 -4
  141. package/dist/reachability/request.js.map +1 -1
  142. package/dist/reachability/util.js +29 -0
  143. package/dist/reachability/util.js.map +1 -0
  144. package/dist/reconnection-manager/index.js +266 -202
  145. package/dist/reconnection-manager/index.js.map +1 -1
  146. package/dist/recording-controller/index.js +21 -2
  147. package/dist/recording-controller/index.js.map +1 -1
  148. package/dist/recording-controller/util.js +9 -8
  149. package/dist/recording-controller/util.js.map +1 -1
  150. package/dist/roap/index.js +66 -28
  151. package/dist/roap/index.js.map +1 -1
  152. package/dist/roap/request.js +48 -64
  153. package/dist/roap/request.js.map +1 -1
  154. package/dist/roap/turnDiscovery.js +407 -79
  155. package/dist/roap/turnDiscovery.js.map +1 -1
  156. package/dist/rtcMetrics/constants.js +12 -0
  157. package/dist/rtcMetrics/constants.js.map +1 -0
  158. package/dist/rtcMetrics/index.js +179 -0
  159. package/dist/rtcMetrics/index.js.map +1 -0
  160. package/dist/statsAnalyzer/index.js +389 -304
  161. package/dist/statsAnalyzer/index.js.map +1 -1
  162. package/dist/statsAnalyzer/mqaUtil.js +296 -156
  163. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  164. package/dist/types/annotation/annotation.types.d.ts +42 -0
  165. package/dist/types/annotation/constants.d.ts +31 -0
  166. package/dist/types/annotation/index.d.ts +117 -0
  167. package/dist/types/breakouts/events.d.ts +8 -0
  168. package/dist/types/breakouts/utils.d.ts +9 -2
  169. package/dist/types/common/errors/no-meeting-info.d.ts +14 -0
  170. package/dist/types/common/errors/reclaim-host-role-errors.d.ts +60 -0
  171. package/dist/types/common/errors/webex-errors.d.ts +25 -1
  172. package/dist/types/common/logs/request.d.ts +2 -0
  173. package/dist/types/common/queue.d.ts +9 -7
  174. package/dist/types/config.d.ts +2 -7
  175. package/dist/types/constants.d.ts +204 -32
  176. package/dist/types/controls-options-manager/enums.d.ts +11 -1
  177. package/dist/types/controls-options-manager/index.d.ts +17 -1
  178. package/dist/types/controls-options-manager/types.d.ts +43 -0
  179. package/dist/types/controls-options-manager/util.d.ts +1 -7
  180. package/dist/types/index.d.ts +6 -5
  181. package/dist/types/interceptors/index.d.ts +2 -0
  182. package/dist/types/interceptors/locusRetry.d.ts +27 -0
  183. package/dist/types/interpretation/collection.d.ts +5 -0
  184. package/dist/types/interpretation/index.d.ts +5 -0
  185. package/dist/types/interpretation/siLanguage.d.ts +5 -0
  186. package/dist/types/locus-info/index.d.ts +57 -4
  187. package/dist/types/locus-info/parser.d.ts +66 -6
  188. package/dist/types/media/index.d.ts +2 -0
  189. package/dist/types/media/properties.d.ts +34 -49
  190. package/dist/types/mediaQualityMetrics/config.d.ts +99 -223
  191. package/dist/types/meeting/in-meeting-actions.d.ts +86 -2
  192. package/dist/types/meeting/index.d.ts +630 -505
  193. package/dist/types/meeting/locusMediaRequest.d.ts +74 -0
  194. package/dist/types/meeting/muteState.d.ts +88 -26
  195. package/dist/types/meeting/request.d.ts +67 -43
  196. package/dist/types/meeting/util.d.ts +117 -1
  197. package/dist/types/meeting/voicea-meeting.d.ts +16 -0
  198. package/dist/types/meeting-info/index.d.ts +13 -1
  199. package/dist/types/meeting-info/meeting-info-v2.d.ts +31 -1
  200. package/dist/types/meetings/collection.d.ts +17 -0
  201. package/dist/types/meetings/index.d.ts +113 -21
  202. package/dist/types/meetings/meetings.types.d.ts +4 -0
  203. package/dist/types/member/index.d.ts +14 -0
  204. package/dist/types/member/types.d.ts +32 -0
  205. package/dist/types/members/collection.d.ts +5 -0
  206. package/dist/types/members/index.d.ts +35 -2
  207. package/dist/types/members/request.d.ts +73 -9
  208. package/dist/types/members/types.d.ts +25 -0
  209. package/dist/types/members/util.d.ts +214 -1
  210. package/dist/types/metrics/constants.d.ts +17 -0
  211. package/dist/types/metrics/index.d.ts +4 -111
  212. package/dist/types/multistream/mediaRequestManager.d.ts +71 -3
  213. package/dist/types/multistream/receiveSlot.d.ts +7 -3
  214. package/dist/types/multistream/receiveSlotManager.d.ts +14 -4
  215. package/dist/types/multistream/remoteMedia.d.ts +3 -31
  216. package/dist/types/multistream/remoteMediaGroup.d.ts +2 -9
  217. package/dist/types/multistream/remoteMediaManager.d.ts +61 -2
  218. package/dist/types/multistream/sendSlotManager.d.ts +69 -0
  219. package/dist/types/reachability/clusterReachability.d.ts +109 -0
  220. package/dist/types/reachability/index.d.ts +60 -95
  221. package/dist/types/reachability/request.d.ts +3 -1
  222. package/dist/types/reachability/util.d.ts +8 -0
  223. package/dist/types/reconnection-manager/index.d.ts +19 -0
  224. package/dist/types/recording-controller/index.d.ts +15 -1
  225. package/dist/types/recording-controller/util.d.ts +5 -4
  226. package/dist/types/roap/index.d.ts +11 -2
  227. package/dist/types/roap/request.d.ts +9 -8
  228. package/dist/types/roap/turnDiscovery.d.ts +90 -9
  229. package/dist/types/rtcMetrics/constants.d.ts +4 -0
  230. package/dist/types/rtcMetrics/index.d.ts +61 -0
  231. package/dist/types/statsAnalyzer/index.d.ts +34 -12
  232. package/dist/types/statsAnalyzer/mqaUtil.d.ts +28 -4
  233. package/dist/types/webinar/collection.d.ts +16 -0
  234. package/dist/types/webinar/index.d.ts +5 -0
  235. package/dist/webinar/collection.js +44 -0
  236. package/dist/webinar/collection.js.map +1 -0
  237. package/dist/webinar/index.js +69 -0
  238. package/dist/webinar/index.js.map +1 -0
  239. package/package.json +22 -19
  240. package/src/annotation/annotation.types.ts +50 -0
  241. package/src/annotation/constants.ts +36 -0
  242. package/src/annotation/index.ts +328 -0
  243. package/src/breakouts/README.md +27 -6
  244. package/src/breakouts/breakout.ts +67 -9
  245. package/src/breakouts/events.ts +56 -0
  246. package/src/breakouts/index.ts +494 -73
  247. package/src/breakouts/utils.ts +26 -8
  248. package/src/common/errors/no-meeting-info.ts +24 -0
  249. package/src/common/errors/reclaim-host-role-errors.ts +134 -0
  250. package/src/common/errors/webex-errors.ts +44 -2
  251. package/src/common/logs/logger-proxy.ts +1 -1
  252. package/src/common/logs/request.ts +5 -1
  253. package/src/common/queue.ts +22 -8
  254. package/src/config.ts +6 -13
  255. package/src/constants.ts +234 -22
  256. package/src/controls-options-manager/enums.ts +12 -0
  257. package/src/controls-options-manager/index.ts +116 -21
  258. package/src/controls-options-manager/types.ts +59 -0
  259. package/src/controls-options-manager/util.ts +294 -14
  260. package/src/index.ts +45 -0
  261. package/src/interceptors/index.ts +3 -0
  262. package/src/interceptors/locusRetry.ts +67 -0
  263. package/src/interpretation/README.md +60 -0
  264. package/src/interpretation/collection.ts +19 -0
  265. package/src/interpretation/index.ts +349 -0
  266. package/src/interpretation/siLanguage.ts +18 -0
  267. package/src/locus-info/controlsUtils.ts +108 -0
  268. package/src/locus-info/index.ts +417 -59
  269. package/src/locus-info/infoUtils.ts +10 -2
  270. package/src/locus-info/mediaSharesUtils.ts +80 -0
  271. package/src/locus-info/parser.ts +258 -47
  272. package/src/locus-info/selfUtils.ts +81 -5
  273. package/src/media/index.ts +100 -108
  274. package/src/media/properties.ts +88 -117
  275. package/src/mediaQualityMetrics/config.ts +103 -238
  276. package/src/meeting/in-meeting-actions.ts +171 -3
  277. package/src/meeting/index.ts +3929 -2622
  278. package/src/meeting/locusMediaRequest.ts +313 -0
  279. package/src/meeting/muteState.ts +237 -136
  280. package/src/meeting/request.ts +173 -122
  281. package/src/meeting/util.ts +690 -395
  282. package/src/meeting/voicea-meeting.ts +122 -0
  283. package/src/meeting-info/index.ts +81 -8
  284. package/src/meeting-info/meeting-info-v2.ts +166 -16
  285. package/src/meeting-info/util.ts +13 -10
  286. package/src/meeting-info/utilv2.ts +47 -37
  287. package/src/meetings/collection.ts +33 -0
  288. package/src/meetings/index.ts +507 -127
  289. package/src/meetings/meetings.types.ts +12 -0
  290. package/src/meetings/request.ts +2 -0
  291. package/src/meetings/util.ts +81 -12
  292. package/src/member/index.ts +57 -0
  293. package/src/member/types.ts +38 -0
  294. package/src/member/util.ts +141 -25
  295. package/src/members/collection.ts +8 -0
  296. package/src/members/index.ts +133 -7
  297. package/src/members/request.ts +97 -17
  298. package/src/members/types.ts +29 -0
  299. package/src/members/util.ts +333 -240
  300. package/src/metrics/constants.ts +17 -0
  301. package/src/metrics/index.ts +1 -469
  302. package/src/multistream/mediaRequestManager.ts +271 -56
  303. package/src/multistream/receiveSlot.ts +11 -4
  304. package/src/multistream/receiveSlotManager.ts +34 -24
  305. package/src/multistream/remoteMedia.ts +5 -3
  306. package/src/multistream/remoteMediaGroup.ts +78 -0
  307. package/src/multistream/remoteMediaManager.ts +248 -45
  308. package/src/multistream/sendSlotManager.ts +198 -0
  309. package/src/reachability/clusterReachability.ts +320 -0
  310. package/src/reachability/index.ts +229 -346
  311. package/src/reachability/request.ts +8 -4
  312. package/src/reachability/util.ts +24 -0
  313. package/src/reconnection-manager/index.ts +128 -97
  314. package/src/recording-controller/index.ts +20 -3
  315. package/src/recording-controller/util.ts +26 -9
  316. package/src/roap/index.ts +76 -25
  317. package/src/roap/request.ts +48 -67
  318. package/src/roap/turnDiscovery.ts +331 -67
  319. package/src/rtcMetrics/constants.ts +3 -0
  320. package/src/rtcMetrics/index.ts +166 -0
  321. package/src/statsAnalyzer/index.ts +496 -419
  322. package/src/statsAnalyzer/mqaUtil.ts +317 -170
  323. package/src/webinar/collection.ts +31 -0
  324. package/src/webinar/index.ts +62 -0
  325. package/test/integration/spec/converged-space-meetings.js +60 -3
  326. package/test/integration/spec/journey.js +321 -262
  327. package/test/integration/spec/space-meeting.js +76 -3
  328. package/test/unit/spec/annotation/index.ts +418 -0
  329. package/test/unit/spec/breakouts/breakout.ts +119 -28
  330. package/test/unit/spec/breakouts/events.ts +89 -0
  331. package/test/unit/spec/breakouts/index.ts +1204 -118
  332. package/test/unit/spec/breakouts/utils.js +27 -2
  333. package/test/unit/spec/common/queue.js +31 -2
  334. package/test/unit/spec/controls-options-manager/index.js +163 -0
  335. package/test/unit/spec/controls-options-manager/util.js +576 -60
  336. package/test/unit/spec/fixture/locus.js +1 -0
  337. package/test/unit/spec/interceptors/locusRetry.ts +131 -0
  338. package/test/unit/spec/interpretation/collection.ts +15 -0
  339. package/test/unit/spec/interpretation/index.ts +625 -0
  340. package/test/unit/spec/interpretation/siLanguage.ts +28 -0
  341. package/test/unit/spec/locus-info/controlsUtils.js +316 -43
  342. package/test/unit/spec/locus-info/index.js +1372 -37
  343. package/test/unit/spec/locus-info/infoUtils.js +37 -15
  344. package/test/unit/spec/locus-info/lib/SeqCmp.json +16 -0
  345. package/test/unit/spec/locus-info/mediaSharesUtils.ts +41 -0
  346. package/test/unit/spec/locus-info/parser.js +116 -35
  347. package/test/unit/spec/locus-info/selfConstant.js +27 -4
  348. package/test/unit/spec/locus-info/selfUtils.js +203 -17
  349. package/test/unit/spec/media/index.ts +178 -81
  350. package/test/unit/spec/media/properties.ts +2 -2
  351. package/test/unit/spec/meeting/in-meeting-actions.ts +85 -3
  352. package/test/unit/spec/meeting/index.js +7835 -2501
  353. package/test/unit/spec/meeting/locusMediaRequest.ts +442 -0
  354. package/test/unit/spec/meeting/muteState.js +549 -207
  355. package/test/unit/spec/meeting/request.js +494 -54
  356. package/test/unit/spec/meeting/utils.js +827 -74
  357. package/test/unit/spec/meeting/voicea-meeting.ts +266 -0
  358. package/test/unit/spec/meeting-info/index.js +300 -0
  359. package/test/unit/spec/meeting-info/meetinginfov2.js +535 -9
  360. package/test/unit/spec/meeting-info/utilv2.js +21 -0
  361. package/test/unit/spec/meetings/collection.js +26 -0
  362. package/test/unit/spec/meetings/index.js +1489 -219
  363. package/test/unit/spec/meetings/utils.js +229 -2
  364. package/test/unit/spec/member/index.js +61 -6
  365. package/test/unit/spec/member/util.js +510 -34
  366. package/test/unit/spec/members/index.js +432 -1
  367. package/test/unit/spec/members/request.js +206 -27
  368. package/test/unit/spec/members/utils.js +210 -0
  369. package/test/unit/spec/metrics/index.js +2 -52
  370. package/test/unit/spec/multistream/mediaRequestManager.ts +782 -114
  371. package/test/unit/spec/multistream/receiveSlot.ts +9 -1
  372. package/test/unit/spec/multistream/receiveSlotManager.ts +32 -30
  373. package/test/unit/spec/multistream/remoteMedia.ts +2 -0
  374. package/test/unit/spec/multistream/remoteMediaGroup.ts +344 -0
  375. package/test/unit/spec/multistream/remoteMediaManager.ts +524 -0
  376. package/test/unit/spec/multistream/sendSlotManager.ts +274 -0
  377. package/test/unit/spec/reachability/clusterReachability.ts +279 -0
  378. package/test/unit/spec/reachability/index.ts +551 -14
  379. package/test/unit/spec/reachability/request.js +3 -1
  380. package/test/unit/spec/reachability/util.ts +40 -0
  381. package/test/unit/spec/reconnection-manager/index.js +171 -11
  382. package/test/unit/spec/recording-controller/index.js +293 -218
  383. package/test/unit/spec/recording-controller/util.js +223 -96
  384. package/test/unit/spec/roap/index.ts +233 -81
  385. package/test/unit/spec/roap/request.ts +100 -62
  386. package/test/unit/spec/roap/turnDiscovery.ts +682 -108
  387. package/test/unit/spec/rtcMetrics/index.ts +122 -0
  388. package/test/unit/spec/stats-analyzer/index.js +1431 -12
  389. package/test/unit/spec/webinar/collection.ts +13 -0
  390. package/test/unit/spec/webinar/index.ts +60 -0
  391. package/test/utils/integrationTestUtils.js +46 -0
  392. package/test/utils/testUtils.js +0 -57
  393. package/test/utils/webex-test-users.js +12 -4
  394. package/dist/metrics/config.js +0 -289
  395. package/dist/metrics/config.js.map +0 -1
  396. package/dist/types/metrics/config.d.ts +0 -169
  397. package/src/index.js +0 -18
  398. package/src/metrics/config.ts +0 -485
@@ -5,36 +5,30 @@ var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequ
5
5
  _Object$defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.createMuteState = void 0;
8
+ exports.createMuteState = exports.MuteState = void 0;
9
9
  var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
10
10
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
11
11
  var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
12
12
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
13
13
  var _loggerProxy = _interopRequireDefault(require("../common/logs/logger-proxy"));
14
14
  var _parameter = _interopRequireDefault(require("../common/errors/parameter"));
15
- var _permission = _interopRequireDefault(require("../common/errors/permission"));
16
15
  var _util = _interopRequireDefault(require("./util"));
17
16
  var _constants = require("../constants");
18
- /* Certain aspects of server interaction for video muting are not implemented as we currently don't support remote muting of video.
19
- If we ever need to support it, search for REMOTE_MUTE_VIDEO_MISSING_IMPLEMENTATION string to find the places that need updating
20
- */
21
-
22
17
  // eslint-disable-next-line import/prefer-default-export
23
- var createMuteState = function createMuteState(type, meeting, mediaDirection) {
24
- if (type === _constants.AUDIO && !mediaDirection.sendAudio) {
25
- return null;
26
- }
27
- if (type === _constants.VIDEO && !mediaDirection.sendVideo) {
28
- return null;
29
- }
18
+ var createMuteState = function createMuteState(type, meeting, enabled) {
19
+ // todo: remove the meeting argument (SPARK-399695)
20
+
30
21
  _loggerProxy.default.logger.info("Meeting:muteState#createMuteState --> ".concat(type, ": creating MuteState for meeting id ").concat(meeting === null || meeting === void 0 ? void 0 : meeting.id));
31
- return new MuteState(type, meeting);
22
+ var muteState = new MuteState(type, meeting, enabled);
23
+ return muteState;
32
24
  };
33
25
 
34
26
  /** The purpose of this class is to manage the local and remote mute state and make sure that the server state always matches
35
27
  the last requested state by the client.
36
28
 
37
29
  More info about Locus muting API: https://sqbu-github.cisco.com/pages/WebExSquared/locus/guides/mute.html#
30
+
31
+ This class is exported only for unit tests. It should never be instantiated directly with new MuteState(), instead createMuteState() should be called
38
32
  */
39
33
  exports.createMuteState = createMuteState;
40
34
  var MuteState = /*#__PURE__*/function () {
@@ -43,90 +37,172 @@ var MuteState = /*#__PURE__*/function () {
43
37
  *
44
38
  * @param {String} type - audio or video
45
39
  * @param {Object} meeting - the meeting object (used for reading current remote mute status)
40
+ * @param {boolean} enabled - whether the client audio/video is enabled at all
46
41
  */
47
- function MuteState(type, meeting) {
42
+ function MuteState(type, meeting, enabled) {
43
+ var _meeting$remoteVideoM, _meeting$unmuteVideoA;
48
44
  (0, _classCallCheck2.default)(this, MuteState);
49
- (0, _defineProperty2.default)(this, "pendingPromiseReject", void 0);
50
- (0, _defineProperty2.default)(this, "pendingPromiseResolve", void 0);
51
45
  (0, _defineProperty2.default)(this, "state", void 0);
52
46
  (0, _defineProperty2.default)(this, "type", void 0);
47
+ (0, _defineProperty2.default)(this, "ignoreMuteStateChange", void 0);
53
48
  if (type !== _constants.AUDIO && type !== _constants.VIDEO) {
54
49
  throw new _parameter.default('Mute state is designed for handling audio or video only');
55
50
  }
56
51
  this.type = type;
52
+ this.ignoreMuteStateChange = false;
57
53
  this.state = {
58
54
  client: {
59
- localMute: false
55
+ enabled: enabled,
56
+ localMute: true
60
57
  },
61
58
  server: {
62
- localMute: false,
63
- // initial values available only for audio (REMOTE_MUTE_VIDEO_MISSING_IMPLEMENTATION)
64
- remoteMute: type === _constants.AUDIO ? meeting.remoteMuted : false,
65
- unmuteAllowed: type === _constants.AUDIO ? meeting.unmuteAllowed : true
59
+ localMute: true,
60
+ // because remoteVideoMuted and unmuteVideoAllowed are updated seperately, they might be undefined
61
+ remoteMute: type === _constants.AUDIO ? meeting.remoteMuted : (_meeting$remoteVideoM = meeting.remoteVideoMuted) !== null && _meeting$remoteVideoM !== void 0 ? _meeting$remoteVideoM : false,
62
+ unmuteAllowed: type === _constants.AUDIO ? meeting.unmuteAllowed : (_meeting$unmuteVideoA = meeting.unmuteVideoAllowed) !== null && _meeting$unmuteVideoA !== void 0 ? _meeting$unmuteVideoA : true
66
63
  },
67
64
  syncToServerInProgress: false
68
65
  };
69
- // these 2 hold the resolve, reject methods for the promise we returned to the client in last handleClientRequest() call
70
- this.pendingPromiseResolve = null;
71
- this.pendingPromiseReject = null;
72
66
  }
73
67
 
74
68
  /**
75
- * Handles mute/unmute request from the client/user. Returns a promise that's resolved once the server update is completed or
76
- * at the point that this request becomese superseded by another client request.
77
- *
78
- * The client doesn't have to wait for the returned promise to resolve before calling handleClientRequest() again. If
79
- * handleClientRequest() is called again before the previous one resolved, the MuteState class will make sure that eventually
80
- * the server state will match the last requested state from the client.
69
+ * Starts the mute state machine. Needs to be called after a new MuteState instance is created.
81
70
  *
82
- * @public
83
- * @memberof MuteState
84
- * @param {Object} [meeting] the meeting object
85
- * @param {Boolean} [mute] true for muting, false for unmuting request
86
- * @returns {Promise}
71
+ * @param {Object} meeting - the meeting object
72
+ * @returns {void}
87
73
  */
88
74
  (0, _createClass2.default)(MuteState, [{
89
- key: "handleClientRequest",
90
- value: function handleClientRequest(meeting, mute) {
91
- var _this = this;
92
- _loggerProxy.default.logger.info("Meeting:muteState#handleClientRequest --> ".concat(this.type, ": user requesting new mute state: ").concat(mute));
93
- if (!mute && !this.state.server.unmuteAllowed) {
94
- return _promise.default.reject(new _permission.default('User is not allowed to unmute self (hard mute feature is being used)'));
75
+ key: "init",
76
+ value: function init(meeting) {
77
+ var _meeting$mediaPropert, _meeting$mediaPropert2;
78
+ this.applyUnmuteAllowedToStream(meeting);
79
+
80
+ // if we are remotely muted, we need to apply that to the local stream now (mute on-entry)
81
+ if (this.state.server.remoteMute) {
82
+ this.muteLocalStream(meeting, this.state.server.remoteMute, 'remotelyMuted');
83
+ }
84
+ var initialMute = this.type === _constants.AUDIO ? (_meeting$mediaPropert = meeting.mediaProperties.audioStream) === null || _meeting$mediaPropert === void 0 ? void 0 : _meeting$mediaPropert.muted : (_meeting$mediaPropert2 = meeting.mediaProperties.videoStream) === null || _meeting$mediaPropert2 === void 0 ? void 0 : _meeting$mediaPropert2.muted;
85
+ _loggerProxy.default.logger.info("Meeting:muteState#init --> ".concat(this.type, ": local stream initial mute state: ").concat(initialMute));
86
+ if (initialMute !== undefined) {
87
+ this.state.client.localMute = initialMute;
88
+ } else {
89
+ // there is no stream, so it's like we are locally muted
90
+ // (this is important especially for transcoded meetings, in which the SDP m-line direction always stays "sendrecv")
91
+ this.state.client.localMute = true;
95
92
  }
93
+ this.applyClientStateToServer(meeting);
94
+ }
96
95
 
97
- // we don't check if we're already in the same state, because even if we were, we would still have to apply the mute state locally,
98
- // because the client may have changed the audio/vidoe tracks
99
- this.state.client.localMute = mute;
100
- this.applyClientStateLocally(meeting);
101
- return new _promise.default(function (resolve, reject) {
102
- if (_this.pendingPromiseResolve) {
103
- // resolve the last promise we returned to the client as the client has issued a new request that has superseded the previous one
104
- _this.pendingPromiseResolve();
105
- }
106
- _this.pendingPromiseResolve = resolve;
107
- _this.pendingPromiseReject = reject;
108
- _this.applyClientStateToServer(meeting);
109
- });
96
+ /**
97
+ * This method needs to be called whenever the local audio/video stream has changed.
98
+ * It reapplies the remote mute state onto the new stream and also reads the current
99
+ * local mute state from the stream and updates the internal state machine and sends
100
+ * any required requests to the server.
101
+ *
102
+ * @param {Object} meeting - the meeting object
103
+ * @returns {void}
104
+ */
105
+ }, {
106
+ key: "handleLocalStreamChange",
107
+ value: function handleLocalStreamChange(meeting) {
108
+ return this.init(meeting);
110
109
  }
111
110
 
112
111
  /**
113
- * Applies the current mute state to the local track (by enabling or disabling it accordingly)
112
+ * Enables/disables audio/video
114
113
  *
114
+ * @param {Object} meeting - the meeting object
115
+ * @param {boolean} enable
116
+ * @returns {void}
117
+ */
118
+ }, {
119
+ key: "enable",
120
+ value: function enable(meeting, _enable) {
121
+ this.state.client.enabled = _enable;
122
+ this.applyClientStateToServer(meeting);
123
+ }
124
+
125
+ /**
126
+ * Mutes/unmutes local stream
127
+ *
128
+ * @param {Object} meeting - the meeting object
129
+ * @param {Boolean} mute - true to mute the stream, false to unmute it
130
+ * @param {ServerMuteReason} reason - reason for muting/unmuting
131
+ * @returns {void}
132
+ */
133
+ }, {
134
+ key: "muteLocalStream",
135
+ value: function muteLocalStream(meeting, mute, reason) {
136
+ this.ignoreMuteStateChange = true;
137
+ if (this.type === _constants.AUDIO) {
138
+ var _meeting$mediaPropert3;
139
+ (_meeting$mediaPropert3 = meeting.mediaProperties.audioStream) === null || _meeting$mediaPropert3 === void 0 ? void 0 : _meeting$mediaPropert3.setServerMuted(mute, reason);
140
+ } else {
141
+ var _meeting$mediaPropert4;
142
+ (_meeting$mediaPropert4 = meeting.mediaProperties.videoStream) === null || _meeting$mediaPropert4 === void 0 ? void 0 : _meeting$mediaPropert4.setServerMuted(mute, reason);
143
+ }
144
+ this.ignoreMuteStateChange = false;
145
+ }
146
+
147
+ /**
148
+ * This method should be called when the local stream mute state is changed
115
149
  * @public
116
- * @param {Object} [meeting] the meeting object
117
150
  * @memberof MuteState
151
+ * @param {Object} [meeting] the meeting object
152
+ * @param {Boolean} [mute] true for muting, false for unmuting request
118
153
  * @returns {void}
119
154
  */
120
155
  }, {
121
- key: "applyClientStateLocally",
122
- value: function applyClientStateLocally(meeting) {
156
+ key: "handleLocalStreamMuteStateChange",
157
+ value: function handleLocalStreamMuteStateChange(meeting) {
158
+ if (this.ignoreMuteStateChange) {
159
+ return;
160
+ }
161
+
162
+ // either user or system may have triggered a mute state change, but localMute should reflect both
163
+ var newMuteState;
164
+ var userMuteState;
165
+ var systemMuteState;
123
166
  if (this.type === _constants.AUDIO) {
124
- var _meeting$mediaPropert;
125
- (_meeting$mediaPropert = meeting.mediaProperties.audioTrack) === null || _meeting$mediaPropert === void 0 ? void 0 : _meeting$mediaPropert.setMuted(this.state.client.localMute);
167
+ var _meeting$mediaPropert5, _meeting$mediaPropert6, _meeting$mediaPropert7;
168
+ newMuteState = (_meeting$mediaPropert5 = meeting.mediaProperties.audioStream) === null || _meeting$mediaPropert5 === void 0 ? void 0 : _meeting$mediaPropert5.muted;
169
+ userMuteState = (_meeting$mediaPropert6 = meeting.mediaProperties.audioStream) === null || _meeting$mediaPropert6 === void 0 ? void 0 : _meeting$mediaPropert6.userMuted;
170
+ systemMuteState = (_meeting$mediaPropert7 = meeting.mediaProperties.audioStream) === null || _meeting$mediaPropert7 === void 0 ? void 0 : _meeting$mediaPropert7.systemMuted;
126
171
  } else {
127
- var _meeting$mediaPropert2;
128
- (_meeting$mediaPropert2 = meeting.mediaProperties.videoTrack) === null || _meeting$mediaPropert2 === void 0 ? void 0 : _meeting$mediaPropert2.setMuted(this.state.client.localMute);
172
+ var _meeting$mediaPropert8, _meeting$mediaPropert9, _meeting$mediaPropert10;
173
+ newMuteState = (_meeting$mediaPropert8 = meeting.mediaProperties.videoStream) === null || _meeting$mediaPropert8 === void 0 ? void 0 : _meeting$mediaPropert8.muted;
174
+ userMuteState = (_meeting$mediaPropert9 = meeting.mediaProperties.videoStream) === null || _meeting$mediaPropert9 === void 0 ? void 0 : _meeting$mediaPropert9.userMuted;
175
+ systemMuteState = (_meeting$mediaPropert10 = meeting.mediaProperties.videoStream) === null || _meeting$mediaPropert10 === void 0 ? void 0 : _meeting$mediaPropert10.systemMuted;
129
176
  }
177
+ _loggerProxy.default.logger.info("Meeting:muteState#handleLocalStreamMuteStateChange --> ".concat(this.type, ": local stream new mute state: ").concat(newMuteState, " (user mute: ").concat(userMuteState, ", system mute: ").concat(systemMuteState, ")"));
178
+ this.state.client.localMute = newMuteState;
179
+ this.applyClientStateToServer(meeting);
180
+ }
181
+
182
+ /**
183
+ * Applies the current mute state to the local stream (by enabling or disabling it accordingly)
184
+ *
185
+ * @public
186
+ * @param {Object} [meeting] the meeting object
187
+ * @param {ServerMuteReason} reason - reason why we're applying our client state to the local stream
188
+ * @memberof MuteState
189
+ * @returns {void}
190
+ */
191
+ }, {
192
+ key: "applyClientStateLocally",
193
+ value: function applyClientStateLocally(meeting, reason) {
194
+ this.muteLocalStream(meeting, this.state.client.localMute, reason);
195
+ }
196
+
197
+ /** Returns true if client is locally muted - it takes into account not just the client local mute state,
198
+ * but also whether audio/video is enabled at all
199
+ *
200
+ * @returns {boolean}
201
+ */
202
+ }, {
203
+ key: "getClientLocalMuteState",
204
+ value: function getClientLocalMuteState() {
205
+ return this.state.client.enabled ? this.state.client.localMute : true;
130
206
  }
131
207
 
132
208
  /**
@@ -140,22 +216,18 @@ var MuteState = /*#__PURE__*/function () {
140
216
  }, {
141
217
  key: "applyClientStateToServer",
142
218
  value: function applyClientStateToServer(meeting) {
143
- var _this2 = this;
219
+ var _this = this;
144
220
  if (this.state.syncToServerInProgress) {
145
221
  _loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": request to server in progress, we need to wait for it to complete"));
146
222
  return;
147
223
  }
148
- var localMuteRequiresSync = this.state.client.localMute !== this.state.server.localMute;
149
- var remoteMuteRequiresSync = !this.state.client.localMute && this.state.server.remoteMute;
150
- _loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": localMuteRequiresSync: ").concat(localMuteRequiresSync, " (").concat(this.state.client.localMute, " ?= ").concat(this.state.server.localMute, ")"));
224
+ var localMuteState = this.getClientLocalMuteState();
225
+ var localMuteRequiresSync = localMuteState !== this.state.server.localMute;
226
+ var remoteMuteRequiresSync = !localMuteState && this.state.server.remoteMute;
227
+ _loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": localMuteRequiresSync: ").concat(localMuteRequiresSync, " (").concat(localMuteState, " ?= ").concat(this.state.server.localMute, ")"));
151
228
  _loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": remoteMuteRequiresSync: ").concat(remoteMuteRequiresSync));
152
229
  if (!localMuteRequiresSync && !remoteMuteRequiresSync) {
153
230
  _loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": client state already matching server state, nothing to do"));
154
- if (this.pendingPromiseResolve) {
155
- this.pendingPromiseResolve();
156
- }
157
- this.pendingPromiseResolve = null;
158
- this.pendingPromiseReject = null;
159
231
  return;
160
232
  }
161
233
  this.state.syncToServerInProgress = true;
@@ -165,21 +237,20 @@ var MuteState = /*#__PURE__*/function () {
165
237
  localMuteSyncPromise.then(function () {
166
238
  return (
167
239
  // then follow it up with remote mute sync
168
- remoteMuteRequiresSync ? _this2.sendRemoteMuteRequestToServer(meeting) : _promise.default.resolve()
240
+ remoteMuteRequiresSync ? _this.sendRemoteMuteRequestToServer(meeting) : _promise.default.resolve()
169
241
  );
170
242
  }).then(function () {
171
- _this2.state.syncToServerInProgress = false;
172
- _loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(_this2.type, ": sync with server completed"));
243
+ _this.state.syncToServerInProgress = false;
244
+ _loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(_this.type, ": sync with server completed"));
173
245
 
174
246
  // need to check if a new sync is required, because this.state.client may have changed while we were doing the current sync
175
- _this2.applyClientStateToServer(meeting);
247
+ _this.applyClientStateToServer(meeting);
176
248
  }).catch(function (e) {
177
- _this2.state.syncToServerInProgress = false;
178
- if (_this2.pendingPromiseReject) {
179
- _this2.pendingPromiseReject(e);
180
- }
181
- _this2.pendingPromiseResolve = null;
182
- _this2.pendingPromiseReject = null;
249
+ _this.state.syncToServerInProgress = false;
250
+ _loggerProxy.default.logger.warn("Meeting:muteState#applyClientStateToServer --> ".concat(_this.type, ": error: ").concat(e));
251
+
252
+ // failed to apply client state to server, so revert stream mute state to server state
253
+ _this.muteLocalStream(meeting, _this.state.server.localMute || _this.state.server.remoteMute, 'clientRequestFailed');
183
254
  });
184
255
  }
185
256
 
@@ -194,19 +265,19 @@ var MuteState = /*#__PURE__*/function () {
194
265
  }, {
195
266
  key: "sendLocalMuteRequestToServer",
196
267
  value: function sendLocalMuteRequestToServer(meeting) {
197
- var _meeting$audio,
198
- _meeting$video,
199
- _this3 = this;
200
- var audioMuted = this.type === _constants.AUDIO ? this.state.client.localMute : (_meeting$audio = meeting.audio) === null || _meeting$audio === void 0 ? void 0 : _meeting$audio.state.client.localMute;
201
- var videoMuted = this.type === _constants.VIDEO ? this.state.client.localMute : (_meeting$video = meeting.video) === null || _meeting$video === void 0 ? void 0 : _meeting$video.state.client.localMute;
268
+ var _this2 = this;
269
+ var audioMuted = this.type === _constants.AUDIO ? this.getClientLocalMuteState() : undefined;
270
+ var videoMuted = this.type === _constants.VIDEO ? this.getClientLocalMuteState() : undefined;
202
271
  _loggerProxy.default.logger.info("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(this.type, ": sending local mute (audio=").concat(audioMuted, ", video=").concat(videoMuted, ") to server"));
203
- return _util.default.remoteUpdateAudioVideo(audioMuted, videoMuted, meeting).then(function (locus) {
204
- _loggerProxy.default.logger.info("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(_this3.type, ": local mute (audio=").concat(audioMuted, ", video=").concat(videoMuted, ") applied to server"));
205
- _this3.state.server.localMute = _this3.type === _constants.AUDIO ? audioMuted : videoMuted;
206
- meeting.locusInfo.onFullLocus(locus);
272
+ return _util.default.remoteUpdateAudioVideo(meeting, audioMuted, videoMuted).then(function (locus) {
273
+ _loggerProxy.default.logger.info("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(_this2.type, ": local mute (audio=").concat(audioMuted, ", video=").concat(videoMuted, ") applied to server"));
274
+ _this2.state.server.localMute = _this2.type === _constants.AUDIO ? audioMuted : videoMuted;
275
+ if (locus) {
276
+ meeting.locusInfo.handleLocusDelta(locus, meeting);
277
+ }
207
278
  return locus;
208
279
  }).catch(function (remoteUpdateError) {
209
- _loggerProxy.default.logger.warn("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(_this3.type, ": failed to apply local mute (audio=").concat(audioMuted, ", video=").concat(videoMuted, ") to server: ").concat(remoteUpdateError));
280
+ _loggerProxy.default.logger.warn("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(_this2.type, ": failed to apply local mute (audio=").concat(audioMuted, ", video=").concat(videoMuted, ") to server: ").concat(remoteUpdateError));
210
281
  return _promise.default.reject(remoteUpdateError);
211
282
  });
212
283
  }
@@ -222,22 +293,34 @@ var MuteState = /*#__PURE__*/function () {
222
293
  }, {
223
294
  key: "sendRemoteMuteRequestToServer",
224
295
  value: function sendRemoteMuteRequestToServer(meeting) {
225
- var _this4 = this;
296
+ var _this3 = this;
297
+ var remoteMute = this.getClientLocalMuteState();
298
+ _loggerProxy.default.logger.info("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(this.type, ": sending remote mute:").concat(remoteMute, " to server"));
299
+ return meeting.members.muteMember(meeting.members.selfId, remoteMute, this.type === _constants.AUDIO).then(function () {
300
+ _loggerProxy.default.logger.info("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(_this3.type, ": remote mute:").concat(remoteMute, " applied to server"));
301
+ _this3.state.server.remoteMute = remoteMute;
302
+ }).catch(function (remoteUpdateError) {
303
+ _loggerProxy.default.logger.warn("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(_this3.type, ": failed to apply remote mute ").concat(remoteMute, " to server: ").concat(remoteUpdateError));
304
+ return _promise.default.reject(remoteUpdateError);
305
+ });
306
+ }
307
+
308
+ /** Applies the current value for unmute allowed to the underlying stream
309
+ *
310
+ * @param {Meeting} meeting
311
+ * @returns {void}
312
+ */
313
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
314
+ }, {
315
+ key: "applyUnmuteAllowedToStream",
316
+ value: function applyUnmuteAllowedToStream(meeting) {
226
317
  if (this.type === _constants.AUDIO) {
227
- var remoteMute = this.state.client.localMute;
228
- _loggerProxy.default.logger.info("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(this.type, ": sending remote mute:").concat(remoteMute, " to server"));
229
- return meeting.members.muteMember(meeting.members.selfId, remoteMute).then(function () {
230
- _loggerProxy.default.logger.info("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(_this4.type, ": remote mute:").concat(remoteMute, " applied to server"));
231
- _this4.state.server.remoteMute = remoteMute;
232
- }).catch(function (remoteUpdateError) {
233
- _loggerProxy.default.logger.warn("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(_this4.type, ": failed to apply remote mute ").concat(remoteMute, " to server: ").concat(remoteUpdateError));
234
- return _promise.default.reject(remoteUpdateError);
235
- });
318
+ var _meeting$mediaPropert11;
319
+ (_meeting$mediaPropert11 = meeting.mediaProperties.audioStream) === null || _meeting$mediaPropert11 === void 0 ? void 0 : _meeting$mediaPropert11.setUnmuteAllowed(this.state.server.unmuteAllowed);
320
+ } else {
321
+ var _meeting$mediaPropert12;
322
+ (_meeting$mediaPropert12 = meeting.mediaProperties.videoStream) === null || _meeting$mediaPropert12 === void 0 ? void 0 : _meeting$mediaPropert12.setUnmuteAllowed(this.state.server.unmuteAllowed);
236
323
  }
237
-
238
- // for now we don't need to support remote muting of video (REMOTE_MUTE_VIDEO_MISSING_IMPLEMENTATION)
239
- this.state.server.remoteMute = this.state.client.localMute;
240
- return _promise.default.resolve();
241
324
  }
242
325
 
243
326
  /**
@@ -245,16 +328,23 @@ var MuteState = /*#__PURE__*/function () {
245
328
  *
246
329
  * @public
247
330
  * @memberof MuteState
331
+ * @param {Meeting} meeting
248
332
  * @param {Boolean} [muted] true if user is remotely muted, false otherwise
249
333
  * @param {Boolean} [unmuteAllowed] indicates if user is allowed to unmute self (false when "hard mute" feature is used)
250
334
  * @returns {undefined}
251
335
  */
252
336
  }, {
253
337
  key: "handleServerRemoteMuteUpdate",
254
- value: function handleServerRemoteMuteUpdate(muted, unmuteAllowed) {
338
+ value: function handleServerRemoteMuteUpdate(meeting, muted, unmuteAllowed) {
255
339
  _loggerProxy.default.logger.info("Meeting:muteState#handleServerRemoteMuteUpdate --> ".concat(this.type, ": updating server remoteMute to (").concat(muted, ")"));
256
- this.state.server.remoteMute = muted;
257
- this.state.server.unmuteAllowed = unmuteAllowed;
340
+ if (unmuteAllowed !== undefined) {
341
+ this.state.server.unmuteAllowed = unmuteAllowed;
342
+ this.applyUnmuteAllowedToStream(meeting);
343
+ }
344
+ if (muted !== undefined) {
345
+ this.state.server.remoteMute = muted;
346
+ this.muteLocalStream(meeting, muted, 'remotelyMuted');
347
+ }
258
348
  }
259
349
 
260
350
  /**
@@ -268,20 +358,30 @@ var MuteState = /*#__PURE__*/function () {
268
358
  }, {
269
359
  key: "handleServerLocalUnmuteRequired",
270
360
  value: function handleServerLocalUnmuteRequired(meeting) {
271
- _loggerProxy.default.logger.info("Meeting:muteState#handleServerLocalUnmuteRequired --> ".concat(this.type, ": localAudioUnmuteRequired received -> doing local unmute"));
361
+ if (!this.state.client.enabled) {
362
+ _loggerProxy.default.logger.warn("Meeting:muteState#handleServerLocalUnmuteRequired --> ".concat(this.type, ": localAudioUnmuteRequired received while ").concat(this.type, " is disabled -> local unmute will not result in ").concat(this.type, " being sent"));
363
+ } else {
364
+ _loggerProxy.default.logger.info("Meeting:muteState#handleServerLocalUnmuteRequired --> ".concat(this.type, ": localAudioUnmuteRequired received -> doing local unmute"));
365
+ }
366
+
367
+ // todo: I'm seeing "you can now unmute yourself " popup when this happens - but same thing happens on web.w.c so we can ignore for now
272
368
  this.state.server.remoteMute = false;
273
- this.state.client.localMute = false;
274
- if (this.pendingPromiseReject) {
275
- this.pendingPromiseReject(new Error('Server requested local unmute - this overrides any client request in progress'));
276
- this.pendingPromiseResolve = null;
277
- this.pendingPromiseReject = null;
369
+
370
+ // change user mute state to false, but keep localMute true if overall mute state is still true
371
+ this.muteLocalStream(meeting, false, 'localUnmuteRequired');
372
+ if (this.type === _constants.AUDIO) {
373
+ var _meeting$mediaPropert13;
374
+ this.state.client.localMute = (_meeting$mediaPropert13 = meeting.mediaProperties.audioStream) === null || _meeting$mediaPropert13 === void 0 ? void 0 : _meeting$mediaPropert13.muted;
375
+ } else {
376
+ var _meeting$mediaPropert14;
377
+ this.state.client.localMute = (_meeting$mediaPropert14 = meeting.mediaProperties.videoStream) === null || _meeting$mediaPropert14 === void 0 ? void 0 : _meeting$mediaPropert14.muted;
278
378
  }
279
- this.applyClientStateLocally(meeting);
280
379
  this.applyClientStateToServer(meeting);
281
380
  }
282
381
 
283
382
  /**
284
- * Returns true if the user is locally or remotely muted
383
+ * Returns true if the user is locally or remotely muted.
384
+ * It only checks the mute status, ignoring the fact whether audio/video is enabled.
285
385
  *
286
386
  * @public
287
387
  * @memberof MuteState
@@ -294,45 +394,45 @@ var MuteState = /*#__PURE__*/function () {
294
394
  }
295
395
 
296
396
  /**
297
- * Returns true if the user is locally muted
397
+ * Returns true if the user is remotely muted
298
398
  *
299
399
  * @public
300
400
  * @memberof MuteState
301
401
  * @returns {Boolean}
302
402
  */
303
403
  }, {
304
- key: "isLocallyMuted",
305
- value: function isLocallyMuted() {
306
- return this.state.client.localMute || this.state.server.localMute;
404
+ key: "isRemotelyMuted",
405
+ value: function isRemotelyMuted() {
406
+ return this.state.server.remoteMute;
307
407
  }
308
408
 
309
409
  /**
310
- * Returns true if the user is muted as a result of the client request (and not remotely muted)
410
+ * Returns true if unmute is allowed
311
411
  *
312
412
  * @public
313
413
  * @memberof MuteState
314
414
  * @returns {Boolean}
315
415
  */
316
416
  }, {
317
- key: "isSelf",
318
- value: function isSelf() {
319
- return this.state.client.localMute && !this.state.server.remoteMute;
320
- }
321
-
322
- // defined for backwards compatibility with the old AudioStateMachine/VideoStateMachine classes
323
- }, {
324
- key: "muted",
325
- get: function get() {
326
- return this.isMuted();
417
+ key: "isUnmuteAllowed",
418
+ value: function isUnmuteAllowed() {
419
+ return this.state.server.unmuteAllowed;
327
420
  }
328
421
 
329
- // defined for backwards compatibility with the old AudioStateMachine/VideoStateMachine classes
422
+ /**
423
+ * Returns true if the user is locally muted or audio/video is disabled
424
+ *
425
+ * @public
426
+ * @memberof MuteState
427
+ * @returns {Boolean}
428
+ */
330
429
  }, {
331
- key: "self",
332
- get: function get() {
333
- return this.isSelf();
430
+ key: "isLocallyMuted",
431
+ value: function isLocallyMuted() {
432
+ return this.getClientLocalMuteState();
334
433
  }
335
434
  }]);
336
435
  return MuteState;
337
436
  }();
437
+ exports.MuteState = MuteState;
338
438
  //# sourceMappingURL=muteState.js.map