@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.
- package/README.md +46 -8
- package/UPGRADING.md +9 -9
- package/browsers.js +19 -24
- package/dist/annotation/annotation.types.js +7 -0
- package/dist/annotation/annotation.types.js.map +1 -0
- package/dist/annotation/constants.js +49 -0
- package/dist/annotation/constants.js.map +1 -0
- package/dist/annotation/index.js +342 -0
- package/dist/annotation/index.js.map +1 -0
- package/dist/breakouts/breakout.js +216 -0
- package/dist/breakouts/breakout.js.map +1 -0
- package/dist/breakouts/collection.js +23 -0
- package/dist/breakouts/collection.js.map +1 -0
- package/dist/breakouts/edit-lock-error.js +52 -0
- package/dist/breakouts/edit-lock-error.js.map +1 -0
- package/dist/breakouts/events.js +45 -0
- package/dist/breakouts/events.js.map +1 -0
- package/dist/breakouts/index.js +1048 -0
- package/dist/breakouts/index.js.map +1 -0
- package/dist/breakouts/request.js +78 -0
- package/dist/breakouts/request.js.map +1 -0
- package/dist/breakouts/utils.js +67 -0
- package/dist/breakouts/utils.js.map +1 -0
- package/dist/common/browser-detection.js +1 -20
- package/dist/common/browser-detection.js.map +1 -1
- package/dist/common/collection.js +5 -20
- package/dist/common/collection.js.map +1 -1
- package/dist/common/config.js +0 -7
- package/dist/common/config.js.map +1 -1
- package/dist/common/errors/captcha-error.js +10 -24
- package/dist/common/errors/captcha-error.js.map +1 -1
- package/dist/common/errors/intent-to-join.js +11 -24
- package/dist/common/errors/intent-to-join.js.map +1 -1
- package/dist/common/errors/join-meeting.js +12 -25
- package/dist/common/errors/join-meeting.js.map +1 -1
- package/dist/common/errors/media.js +10 -24
- package/dist/common/errors/media.js.map +1 -1
- package/dist/common/errors/no-meeting-info.js +51 -0
- package/dist/common/errors/no-meeting-info.js.map +1 -0
- package/dist/common/errors/parameter.js +5 -33
- package/dist/common/errors/parameter.js.map +1 -1
- package/dist/common/errors/password-error.js +10 -24
- package/dist/common/errors/password-error.js.map +1 -1
- package/dist/common/errors/permission.js +9 -23
- package/dist/common/errors/permission.js.map +1 -1
- package/dist/common/errors/reclaim-host-role-errors.js +158 -0
- package/dist/common/errors/reclaim-host-role-errors.js.map +1 -0
- package/dist/common/errors/reconnection-in-progress.js +0 -17
- package/dist/common/errors/reconnection-in-progress.js.map +1 -1
- package/dist/common/errors/reconnection.js +10 -24
- package/dist/common/errors/reconnection.js.map +1 -1
- package/dist/common/errors/stats.js +10 -24
- package/dist/common/errors/stats.js.map +1 -1
- package/dist/common/errors/webex-errors.js +54 -48
- package/dist/common/errors/webex-errors.js.map +1 -1
- package/dist/common/errors/webex-meetings-error.js +5 -25
- package/dist/common/errors/webex-meetings-error.js.map +1 -1
- package/dist/common/events/events-scope.js +0 -22
- package/dist/common/events/events-scope.js.map +1 -1
- package/dist/common/events/events.js +0 -23
- package/dist/common/events/events.js.map +1 -1
- package/dist/common/events/trigger-proxy.js +0 -12
- package/dist/common/events/trigger-proxy.js.map +1 -1
- package/dist/common/events/util.js +0 -15
- package/dist/common/events/util.js.map +1 -1
- package/dist/common/logs/logger-config.js +0 -4
- package/dist/common/logs/logger-config.js.map +1 -1
- package/dist/common/logs/logger-proxy.js +1 -8
- package/dist/common/logs/logger-proxy.js.map +1 -1
- package/dist/common/logs/request.js +41 -60
- package/dist/common/logs/request.js.map +1 -1
- package/dist/common/queue.js +28 -23
- package/dist/common/queue.js.map +1 -1
- package/dist/config.js +9 -15
- package/dist/config.js.map +1 -1
- package/dist/constants.js +315 -68
- package/dist/constants.js.map +1 -1
- package/dist/controls-options-manager/constants.js +14 -0
- package/dist/controls-options-manager/constants.js.map +1 -0
- package/dist/controls-options-manager/enums.js +27 -0
- package/dist/controls-options-manager/enums.js.map +1 -0
- package/dist/controls-options-manager/index.js +297 -0
- package/dist/controls-options-manager/index.js.map +1 -0
- package/dist/controls-options-manager/types.js +7 -0
- package/dist/controls-options-manager/types.js.map +1 -0
- package/dist/controls-options-manager/util.js +319 -0
- package/dist/controls-options-manager/util.js.map +1 -0
- package/dist/index.js +114 -17
- package/dist/index.js.map +1 -1
- package/dist/interpretation/collection.js +23 -0
- package/dist/interpretation/collection.js.map +1 -0
- package/dist/interpretation/index.js +366 -0
- package/dist/interpretation/index.js.map +1 -0
- package/dist/interpretation/siLanguage.js +25 -0
- package/dist/interpretation/siLanguage.js.map +1 -0
- package/dist/locus-info/controlsUtils.js +101 -29
- package/dist/locus-info/controlsUtils.js.map +1 -1
- package/dist/locus-info/embeddedAppsUtils.js +3 -26
- package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
- package/dist/locus-info/fullState.js +0 -15
- package/dist/locus-info/fullState.js.map +1 -1
- package/dist/locus-info/hostUtils.js +4 -12
- package/dist/locus-info/hostUtils.js.map +1 -1
- package/dist/locus-info/index.js +561 -246
- package/dist/locus-info/index.js.map +1 -1
- package/dist/locus-info/infoUtils.js +10 -38
- package/dist/locus-info/infoUtils.js.map +1 -1
- package/dist/locus-info/mediaSharesUtils.js +68 -38
- package/dist/locus-info/mediaSharesUtils.js.map +1 -1
- package/dist/locus-info/parser.js +314 -163
- package/dist/locus-info/parser.js.map +1 -1
- package/dist/locus-info/selfUtils.js +110 -92
- package/dist/locus-info/selfUtils.js.map +1 -1
- package/dist/media/index.js +103 -231
- package/dist/media/index.js.map +1 -1
- package/dist/media/properties.js +137 -222
- package/dist/media/properties.js.map +1 -1
- package/dist/media/util.js +2 -9
- package/dist/media/util.js.map +1 -1
- package/dist/mediaQualityMetrics/config.js +505 -495
- package/dist/mediaQualityMetrics/config.js.map +1 -1
- package/dist/meeting/in-meeting-actions.js +93 -14
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +4624 -3740
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/locusMediaRequest.js +292 -0
- package/dist/meeting/locusMediaRequest.js.map +1 -0
- package/dist/meeting/muteState.js +249 -184
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +400 -346
- package/dist/meeting/request.js.map +1 -1
- package/dist/meeting/request.type.js +7 -0
- package/dist/meeting/request.type.js.map +1 -0
- package/dist/meeting/state.js +21 -31
- package/dist/meeting/state.js.map +1 -1
- package/dist/meeting/util.js +598 -586
- package/dist/meeting/util.js.map +1 -1
- package/dist/meeting-info/collection.js +6 -25
- package/dist/meeting-info/collection.js.map +1 -1
- package/dist/meeting-info/index.js +87 -39
- package/dist/meeting-info/index.js.map +1 -1
- package/dist/meeting-info/meeting-info-v2.js +349 -283
- package/dist/meeting-info/meeting-info-v2.js.map +1 -1
- package/dist/meeting-info/request.js +3 -15
- package/dist/meeting-info/request.js.map +1 -1
- package/dist/meeting-info/util.js +98 -183
- package/dist/meeting-info/util.js.map +1 -1
- package/dist/meeting-info/utilv2.js +143 -234
- package/dist/meeting-info/utilv2.js.map +1 -1
- package/dist/meetings/collection.js +26 -19
- package/dist/meetings/collection.js.map +1 -1
- package/dist/meetings/index.js +813 -596
- package/dist/meetings/index.js.map +1 -1
- package/dist/meetings/meetings.types.js +7 -0
- package/dist/meetings/meetings.types.js.map +1 -0
- package/dist/meetings/request.js +26 -41
- package/dist/meetings/request.js.map +1 -1
- package/dist/meetings/util.js +183 -156
- package/dist/meetings/util.js.map +1 -1
- package/dist/member/index.js +135 -85
- package/dist/member/index.js.map +1 -1
- package/dist/member/types.js +25 -0
- package/dist/member/types.js.map +1 -0
- package/dist/member/util.js +158 -88
- package/dist/member/util.js.map +1 -1
- package/dist/members/collection.js +13 -12
- package/dist/members/collection.js.map +1 -1
- package/dist/members/index.js +194 -204
- package/dist/members/index.js.map +1 -1
- package/dist/members/request.js +113 -68
- package/dist/members/request.js.map +1 -1
- package/dist/members/types.js +15 -0
- package/dist/members/types.js.map +1 -0
- package/dist/members/util.js +324 -259
- package/dist/members/util.js.map +1 -1
- package/dist/metrics/constants.js +14 -7
- package/dist/metrics/constants.js.map +1 -1
- package/dist/metrics/index.js +11 -558
- package/dist/metrics/index.js.map +1 -1
- package/dist/multistream/mediaRequestManager.js +263 -50
- package/dist/multistream/mediaRequestManager.js.map +1 -1
- package/dist/multistream/receiveSlot.js +58 -65
- package/dist/multistream/receiveSlot.js.map +1 -1
- package/dist/multistream/receiveSlotManager.js +76 -95
- package/dist/multistream/receiveSlotManager.js.map +1 -1
- package/dist/multistream/remoteMedia.js +62 -76
- package/dist/multistream/remoteMedia.js.map +1 -1
- package/dist/multistream/remoteMediaGroup.js +66 -43
- package/dist/multistream/remoteMediaGroup.js.map +1 -1
- package/dist/multistream/remoteMediaManager.js +536 -439
- package/dist/multistream/remoteMediaManager.js.map +1 -1
- package/dist/multistream/sendSlotManager.js +233 -0
- package/dist/multistream/sendSlotManager.js.map +1 -0
- package/dist/networkQualityMonitor/index.js +40 -59
- package/dist/networkQualityMonitor/index.js.map +1 -1
- package/dist/personal-meeting-room/index.js +21 -45
- package/dist/personal-meeting-room/index.js.map +1 -1
- package/dist/personal-meeting-room/request.js +1 -31
- package/dist/personal-meeting-room/request.js.map +1 -1
- package/dist/personal-meeting-room/util.js +0 -13
- package/dist/personal-meeting-room/util.js.map +1 -1
- package/dist/reachability/index.js +322 -200
- package/dist/reachability/index.js.map +1 -1
- package/dist/reachability/request.js +20 -26
- package/dist/reachability/request.js.map +1 -1
- package/dist/reactions/constants.js +13 -0
- package/dist/reactions/constants.js.map +1 -0
- package/dist/reactions/reactions.js +109 -0
- package/dist/reactions/reactions.js.map +1 -0
- package/dist/reactions/reactions.type.js +36 -0
- package/dist/reactions/reactions.type.js.map +1 -0
- package/dist/reconnection-manager/index.js +388 -476
- package/dist/reconnection-manager/index.js.map +1 -1
- package/dist/recording-controller/enums.js +17 -0
- package/dist/recording-controller/enums.js.map +1 -0
- package/dist/recording-controller/index.js +362 -0
- package/dist/recording-controller/index.js.map +1 -0
- package/dist/recording-controller/util.js +64 -0
- package/dist/recording-controller/util.js.map +1 -0
- package/dist/roap/index.js +99 -94
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +131 -135
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/turnDiscovery.js +151 -101
- package/dist/roap/turnDiscovery.js.map +1 -1
- package/dist/rtcMetrics/constants.js +12 -0
- package/dist/rtcMetrics/constants.js.map +1 -0
- package/dist/rtcMetrics/index.js +117 -0
- package/dist/rtcMetrics/index.js.map +1 -0
- package/dist/statsAnalyzer/global.js +1 -95
- package/dist/statsAnalyzer/global.js.map +1 -1
- package/dist/statsAnalyzer/index.js +416 -497
- package/dist/statsAnalyzer/index.js.map +1 -1
- package/dist/statsAnalyzer/mqaUtil.js +145 -88
- package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
- package/dist/transcription/index.js +22 -47
- package/dist/transcription/index.js.map +1 -1
- package/dist/types/annotation/annotation.types.d.ts +42 -0
- package/dist/types/annotation/constants.d.ts +31 -0
- package/dist/types/annotation/index.d.ts +117 -0
- package/dist/types/breakouts/breakout.d.ts +8 -0
- package/dist/types/breakouts/collection.d.ts +5 -0
- package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
- package/dist/types/breakouts/events.d.ts +8 -0
- package/dist/types/breakouts/index.d.ts +5 -0
- package/dist/types/breakouts/request.d.ts +22 -0
- package/dist/types/breakouts/utils.d.ts +15 -0
- package/dist/types/common/browser-detection.d.ts +9 -0
- package/dist/types/common/collection.d.ts +48 -0
- package/dist/types/common/config.d.ts +2 -0
- package/dist/types/common/errors/captcha-error.d.ts +15 -0
- package/dist/types/common/errors/intent-to-join.d.ts +16 -0
- package/dist/types/common/errors/join-meeting.d.ts +17 -0
- package/dist/types/common/errors/media.d.ts +15 -0
- package/dist/types/common/errors/no-meeting-info.d.ts +14 -0
- package/dist/types/common/errors/parameter.d.ts +15 -0
- package/dist/types/common/errors/password-error.d.ts +15 -0
- package/dist/types/common/errors/permission.d.ts +14 -0
- package/dist/types/common/errors/reclaim-host-role-errors.d.ts +60 -0
- package/dist/types/common/errors/reconnection-in-progress.d.ts +9 -0
- package/dist/types/common/errors/reconnection.d.ts +15 -0
- package/dist/types/common/errors/stats.d.ts +15 -0
- package/dist/types/common/errors/webex-errors.d.ts +93 -0
- package/dist/types/common/errors/webex-meetings-error.d.ts +20 -0
- package/dist/types/common/events/events-scope.d.ts +17 -0
- package/dist/types/common/events/events.d.ts +12 -0
- package/dist/types/common/events/trigger-proxy.d.ts +2 -0
- package/dist/types/common/events/util.d.ts +2 -0
- package/dist/types/common/logs/logger-config.d.ts +2 -0
- package/dist/types/common/logs/logger-proxy.d.ts +2 -0
- package/dist/types/common/logs/request.d.ts +36 -0
- package/dist/types/common/queue.d.ts +34 -0
- package/dist/types/config.d.ts +71 -0
- package/dist/types/constants.d.ts +1066 -0
- package/dist/types/controls-options-manager/constants.d.ts +4 -0
- package/dist/types/controls-options-manager/enums.d.ts +15 -0
- package/dist/types/controls-options-manager/index.d.ts +136 -0
- package/dist/types/controls-options-manager/types.d.ts +43 -0
- package/dist/types/controls-options-manager/util.d.ts +1 -0
- package/dist/types/index.d.ts +7 -0
- package/dist/types/interpretation/collection.d.ts +5 -0
- package/dist/types/interpretation/index.d.ts +5 -0
- package/dist/types/interpretation/siLanguage.d.ts +5 -0
- package/dist/types/locus-info/controlsUtils.d.ts +2 -0
- package/dist/types/locus-info/embeddedAppsUtils.d.ts +2 -0
- package/dist/types/locus-info/fullState.d.ts +2 -0
- package/dist/types/locus-info/hostUtils.d.ts +2 -0
- package/dist/types/locus-info/index.d.ts +322 -0
- package/dist/types/locus-info/infoUtils.d.ts +2 -0
- package/dist/types/locus-info/mediaSharesUtils.d.ts +2 -0
- package/dist/types/locus-info/parser.d.ts +273 -0
- package/dist/types/locus-info/selfUtils.d.ts +2 -0
- package/dist/types/media/index.d.ts +34 -0
- package/dist/types/media/properties.d.ts +93 -0
- package/dist/types/media/util.d.ts +2 -0
- package/dist/types/mediaQualityMetrics/config.d.ts +365 -0
- package/dist/types/meeting/in-meeting-actions.d.ts +163 -0
- package/dist/types/meeting/index.d.ts +1676 -0
- package/dist/types/meeting/locusMediaRequest.d.ts +74 -0
- package/dist/types/meeting/muteState.d.ts +184 -0
- package/dist/types/meeting/request.d.ts +290 -0
- package/dist/types/meeting/request.type.d.ts +11 -0
- package/dist/types/meeting/state.d.ts +9 -0
- package/dist/types/meeting/util.d.ts +102 -0
- package/dist/types/meeting-info/collection.d.ts +20 -0
- package/dist/types/meeting-info/index.d.ts +69 -0
- package/dist/types/meeting-info/meeting-info-v2.d.ts +123 -0
- package/dist/types/meeting-info/request.d.ts +22 -0
- package/dist/types/meeting-info/util.d.ts +2 -0
- package/dist/types/meeting-info/utilv2.d.ts +2 -0
- package/dist/types/meetings/collection.d.ts +31 -0
- package/dist/types/meetings/index.d.ts +367 -0
- package/dist/types/meetings/meetings.types.d.ts +4 -0
- package/dist/types/meetings/request.d.ts +27 -0
- package/dist/types/meetings/util.d.ts +18 -0
- package/dist/types/member/index.d.ts +160 -0
- package/dist/types/member/types.d.ts +32 -0
- package/dist/types/member/util.d.ts +2 -0
- package/dist/types/members/collection.d.ts +29 -0
- package/dist/types/members/index.d.ts +353 -0
- package/dist/types/members/request.d.ts +114 -0
- package/dist/types/members/types.d.ts +25 -0
- package/dist/types/members/util.d.ts +215 -0
- package/dist/types/metrics/constants.d.ts +65 -0
- package/dist/types/metrics/index.d.ts +45 -0
- package/dist/types/multistream/mediaRequestManager.d.ts +118 -0
- package/dist/types/multistream/receiveSlot.d.ts +68 -0
- package/dist/types/multistream/receiveSlotManager.d.ts +56 -0
- package/dist/types/multistream/remoteMedia.d.ts +72 -0
- package/dist/types/multistream/remoteMediaGroup.d.ts +47 -0
- package/dist/types/multistream/remoteMediaManager.d.ts +285 -0
- package/dist/types/multistream/sendSlotManager.d.ts +61 -0
- package/dist/types/networkQualityMonitor/index.d.ts +70 -0
- package/dist/types/personal-meeting-room/index.d.ts +47 -0
- package/dist/types/personal-meeting-room/request.d.ts +14 -0
- package/dist/types/personal-meeting-room/util.d.ts +2 -0
- package/dist/types/reachability/index.d.ts +194 -0
- package/dist/types/reachability/request.d.ts +39 -0
- package/dist/types/reactions/constants.d.ts +3 -0
- package/dist/types/reactions/reactions.d.ts +4 -0
- package/dist/types/reactions/reactions.type.d.ts +52 -0
- package/dist/types/reconnection-manager/index.d.ts +126 -0
- package/dist/types/recording-controller/enums.d.ts +7 -0
- package/dist/types/recording-controller/index.d.ts +207 -0
- package/dist/types/recording-controller/util.d.ts +14 -0
- package/dist/types/roap/index.d.ts +78 -0
- package/dist/types/roap/request.d.ts +39 -0
- package/dist/types/roap/turnDiscovery.d.ts +92 -0
- package/dist/types/rtcMetrics/constants.d.ts +4 -0
- package/dist/types/rtcMetrics/index.d.ts +47 -0
- package/dist/types/statsAnalyzer/global.d.ts +36 -0
- package/dist/types/statsAnalyzer/index.d.ts +201 -0
- package/dist/types/statsAnalyzer/mqaUtil.d.ts +24 -0
- package/dist/types/transcription/index.d.ts +64 -0
- package/dist/types/webinar/collection.d.ts +16 -0
- package/dist/types/webinar/index.d.ts +5 -0
- package/dist/webinar/collection.js +44 -0
- package/dist/webinar/collection.js.map +1 -0
- package/dist/webinar/index.js +69 -0
- package/dist/webinar/index.js.map +1 -0
- package/internal-README.md +7 -6
- package/package.json +29 -21
- package/src/annotation/annotation.types.ts +50 -0
- package/src/annotation/constants.ts +36 -0
- package/src/annotation/index.ts +328 -0
- package/src/breakouts/README.md +220 -0
- package/src/breakouts/breakout.ts +188 -0
- package/src/breakouts/collection.ts +19 -0
- package/src/breakouts/edit-lock-error.ts +25 -0
- package/src/breakouts/events.ts +56 -0
- package/src/breakouts/index.ts +925 -0
- package/src/breakouts/request.ts +55 -0
- package/src/breakouts/utils.ts +57 -0
- package/src/common/{browser-detection.js → browser-detection.ts} +9 -6
- package/src/common/collection.ts +9 -7
- package/src/common/{config.js → config.ts} +1 -1
- package/src/common/errors/{captcha-error.js → captcha-error.ts} +11 -7
- package/src/common/errors/{intent-to-join.js → intent-to-join.ts} +12 -7
- package/src/common/errors/{join-meeting.js → join-meeting.ts} +17 -8
- package/src/common/errors/{media.js → media.ts} +11 -7
- package/src/common/errors/no-meeting-info.ts +24 -0
- package/src/common/errors/parameter.ts +11 -7
- package/src/common/errors/{password-error.js → password-error.ts} +11 -7
- package/src/common/errors/{permission.js → permission.ts} +10 -6
- package/src/common/errors/reclaim-host-role-errors.ts +134 -0
- package/src/common/errors/{reconnection.js → reconnection.ts} +11 -7
- package/src/common/errors/{stats.js → stats.ts} +11 -7
- package/src/common/errors/{webex-errors.js → webex-errors.ts} +51 -8
- package/src/common/errors/{webex-meetings-error.js → webex-meetings-error.ts} +4 -2
- package/src/common/events/{events-scope.js → events-scope.ts} +6 -2
- package/src/common/events/{events.js → events.ts} +5 -1
- package/src/common/events/{trigger-proxy.js → trigger-proxy.ts} +9 -5
- package/src/common/events/{util.js → util.ts} +2 -3
- package/src/common/logs/{logger-config.js → logger-config.ts} +1 -2
- package/src/common/logs/logger-proxy.ts +44 -0
- package/src/common/logs/{request.js → request.ts} +26 -9
- package/src/common/queue.ts +22 -9
- package/src/{config.js → config.ts} +18 -19
- package/src/constants.ts +260 -22
- package/src/controls-options-manager/constants.ts +5 -0
- package/src/controls-options-manager/enums.ts +18 -0
- package/src/controls-options-manager/index.ts +278 -0
- package/src/controls-options-manager/types.ts +59 -0
- package/src/controls-options-manager/util.ts +300 -0
- package/src/index.ts +40 -0
- package/src/interpretation/README.md +60 -0
- package/src/interpretation/collection.ts +19 -0
- package/src/interpretation/index.ts +332 -0
- package/src/interpretation/siLanguage.ts +18 -0
- package/src/locus-info/controlsUtils.ts +222 -0
- package/src/locus-info/{embeddedAppsUtils.js → embeddedAppsUtils.ts} +5 -6
- package/src/locus-info/{fullState.js → fullState.ts} +16 -12
- package/src/locus-info/{hostUtils.js → hostUtils.ts} +9 -8
- package/src/locus-info/{index.js → index.ts} +557 -119
- package/src/locus-info/{infoUtils.js → infoUtils.ts} +29 -10
- package/src/locus-info/{mediaSharesUtils.js → mediaSharesUtils.ts} +81 -17
- package/src/locus-info/{parser.js → parser.ts} +303 -104
- package/src/locus-info/{selfUtils.js → selfUtils.ts} +199 -68
- package/src/media/index.ts +458 -0
- package/src/media/properties.ts +283 -0
- package/src/media/{util.js → util.ts} +2 -2
- package/src/mediaQualityMetrics/config.ts +384 -0
- package/src/meeting/in-meeting-actions.ts +191 -3
- package/src/meeting/index.ts +7882 -0
- package/src/meeting/locusMediaRequest.ts +313 -0
- package/src/meeting/muteState.ts +451 -0
- package/src/meeting/{request.js → request.ts} +421 -220
- package/src/meeting/request.type.ts +13 -0
- package/src/meeting/{state.js → state.ts} +50 -35
- package/src/meeting/util.ts +697 -0
- package/src/meeting-info/{collection.js → collection.ts} +6 -2
- package/src/meeting-info/index.ts +210 -0
- package/src/meeting-info/meeting-info-v2.ts +429 -0
- package/src/meeting-info/{request.js → request.ts} +14 -4
- package/src/meeting-info/{util.js → util.ts} +60 -51
- package/src/meeting-info/{utilv2.js → utilv2.ts} +78 -71
- package/src/meetings/{collection.js → collection.ts} +26 -3
- package/src/meetings/index.ts +1470 -0
- package/src/meetings/meetings.types.ts +12 -0
- package/src/meetings/{request.js → request.ts} +34 -25
- package/src/meetings/{util.js → util.ts} +132 -37
- package/src/member/{index.js → index.ts} +160 -56
- package/src/member/types.ts +38 -0
- package/src/member/util.ts +397 -0
- package/src/members/{collection.js → collection.ts} +10 -2
- package/src/members/{index.js → index.ts} +351 -146
- package/src/members/request.ts +255 -0
- package/src/members/types.ts +29 -0
- package/src/members/util.ts +353 -0
- package/src/metrics/{constants.js → constants.ts} +12 -6
- package/src/metrics/index.ts +73 -0
- package/src/multistream/mediaRequestManager.ts +337 -63
- package/src/multistream/receiveSlot.ts +69 -26
- package/src/multistream/receiveSlotManager.ts +66 -42
- package/src/multistream/remoteMedia.ts +40 -5
- package/src/multistream/remoteMediaGroup.ts +63 -3
- package/src/multistream/remoteMediaManager.ts +300 -66
- package/src/multistream/sendSlotManager.ts +170 -0
- package/src/networkQualityMonitor/{index.js → index.ts} +41 -29
- package/src/personal-meeting-room/{index.js → index.ts} +28 -19
- package/src/personal-meeting-room/{request.js → request.ts} +13 -4
- package/src/personal-meeting-room/{util.js → util.ts} +4 -4
- package/src/reachability/index.ts +671 -0
- package/src/reachability/request.ts +50 -35
- package/src/reactions/constants.ts +4 -0
- package/src/reactions/reactions.ts +104 -0
- package/src/reactions/reactions.type.ts +62 -0
- package/src/reconnection-manager/{index.js → index.ts} +258 -138
- package/src/recording-controller/enums.ts +8 -0
- package/src/recording-controller/index.ts +332 -0
- package/src/recording-controller/util.ts +75 -0
- package/src/roap/{index.js → index.ts} +127 -79
- package/src/roap/request.ts +153 -0
- package/src/roap/turnDiscovery.ts +109 -47
- package/src/rtcMetrics/constants.ts +3 -0
- package/src/rtcMetrics/index.ts +100 -0
- package/src/statsAnalyzer/global.ts +37 -0
- package/src/statsAnalyzer/index.ts +1250 -0
- package/src/statsAnalyzer/mqaUtil.ts +292 -0
- package/src/transcription/{index.js → index.ts} +46 -39
- package/src/webinar/collection.ts +31 -0
- package/src/webinar/index.ts +62 -0
- package/test/integration/spec/converged-space-meetings.js +233 -0
- package/test/integration/spec/journey.js +790 -530
- package/test/integration/spec/space-meeting.js +391 -204
- package/test/integration/spec/transcription.js +7 -8
- package/test/unit/spec/annotation/index.ts +418 -0
- package/test/unit/spec/breakouts/breakout.ts +237 -0
- package/test/unit/spec/breakouts/collection.ts +15 -0
- package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
- package/test/unit/spec/breakouts/events.ts +89 -0
- package/test/unit/spec/breakouts/index.ts +1790 -0
- package/test/unit/spec/breakouts/request.ts +104 -0
- package/test/unit/spec/breakouts/utils.js +72 -0
- package/test/unit/spec/common/browser-detection.js +9 -28
- package/test/unit/spec/common/queue.js +31 -2
- package/test/unit/spec/controls-options-manager/index.js +287 -0
- package/test/unit/spec/controls-options-manager/util.js +582 -0
- package/test/unit/spec/fixture/locus.js +93 -90
- package/test/unit/spec/interpretation/collection.ts +15 -0
- package/test/unit/spec/interpretation/index.ts +589 -0
- package/test/unit/spec/interpretation/siLanguage.ts +28 -0
- package/test/unit/spec/locus-info/controlsUtils.js +325 -32
- package/test/unit/spec/locus-info/embeddedAppsUtils.js +8 -6
- package/test/unit/spec/locus-info/index.js +1390 -17
- package/test/unit/spec/locus-info/infoUtils.js +71 -40
- package/test/unit/spec/locus-info/lib/BasicSeqCmp.json +88 -430
- package/test/unit/spec/locus-info/lib/SeqCmp.json +529 -685
- package/test/unit/spec/locus-info/mediaSharesUtils.ts +32 -0
- package/test/unit/spec/locus-info/parser.js +119 -44
- package/test/unit/spec/locus-info/selfConstant.js +120 -103
- package/test/unit/spec/locus-info/selfUtils.js +296 -12
- package/test/unit/spec/media/index.ts +128 -77
- package/test/unit/spec/media/properties.ts +11 -11
- package/test/unit/spec/meeting/in-meeting-actions.ts +92 -3
- package/test/unit/spec/meeting/index.js +7433 -2752
- package/test/unit/spec/meeting/locusMediaRequest.ts +442 -0
- package/test/unit/spec/meeting/muteState.js +420 -211
- package/test/unit/spec/meeting/request.js +545 -79
- package/test/unit/spec/meeting/utils.js +722 -174
- package/test/unit/spec/meeting-info/index.js +300 -0
- package/test/unit/spec/meeting-info/meetinginfov2.js +624 -76
- package/test/unit/spec/meeting-info/request.js +7 -9
- package/test/unit/spec/meeting-info/util.js +11 -12
- package/test/unit/spec/meeting-info/utilv2.js +131 -74
- package/test/unit/spec/meetings/collection.js +15 -1
- package/test/unit/spec/meetings/index.js +1365 -377
- package/test/unit/spec/meetings/utils.js +216 -14
- package/test/unit/spec/member/index.js +61 -7
- package/test/unit/spec/member/util.js +526 -26
- package/test/unit/spec/members/index.js +536 -55
- package/test/unit/spec/members/request.js +228 -40
- package/test/unit/spec/members/utils.js +217 -4
- package/test/unit/spec/metrics/index.js +12 -66
- package/test/unit/spec/multistream/mediaRequestManager.ts +1012 -109
- package/test/unit/spec/multistream/receiveSlot.ts +77 -18
- package/test/unit/spec/multistream/receiveSlotManager.ts +69 -39
- package/test/unit/spec/multistream/remoteMedia.ts +40 -2
- package/test/unit/spec/multistream/remoteMediaGroup.ts +271 -5
- package/test/unit/spec/multistream/remoteMediaManager.ts +738 -65
- package/test/unit/spec/multistream/sendSlotManager.ts +242 -0
- package/test/unit/spec/networkQualityMonitor/index.js +24 -18
- package/test/unit/spec/personal-meeting-room/personal-meeting-room.js +2 -7
- package/test/unit/spec/reachability/index.ts +598 -26
- package/test/unit/spec/reachability/request.js +68 -0
- package/test/unit/spec/reconnection-manager/index.js +181 -12
- package/test/unit/spec/recording-controller/index.js +307 -0
- package/test/unit/spec/recording-controller/util.js +229 -0
- package/test/unit/spec/roap/index.ts +179 -64
- package/test/unit/spec/roap/request.ts +232 -0
- package/test/unit/spec/roap/turnDiscovery.ts +123 -58
- package/test/unit/spec/rtcMetrics/index.ts +73 -0
- package/test/unit/spec/stats-analyzer/index.js +199 -60
- package/test/unit/spec/webinar/collection.ts +13 -0
- package/test/unit/spec/webinar/index.ts +60 -0
- package/test/utils/cmr.js +44 -42
- package/test/utils/constants.js +9 -0
- package/test/utils/integrationTestUtils.js +46 -0
- package/test/utils/testUtils.js +63 -99
- package/test/utils/webex-config.js +22 -18
- package/test/utils/webex-test-users.js +57 -50
- package/tsconfig.json +6 -0
- package/dist/media/internal-media-core-wrapper.js +0 -22
- package/dist/media/internal-media-core-wrapper.js.map +0 -1
- package/dist/meeting/effectsState.js +0 -327
- package/dist/meeting/effectsState.js.map +0 -1
- package/dist/metrics/config.js +0 -301
- package/dist/metrics/config.js.map +0 -1
- package/dist/multistream/multistreamMedia.js +0 -116
- package/dist/multistream/multistreamMedia.js.map +0 -1
- package/dist/peer-connection-manager/util.js +0 -124
- package/dist/peer-connection-manager/util.js.map +0 -1
- package/src/common/logs/logger-proxy.js +0 -33
- package/src/index.js +0 -15
- package/src/locus-info/controlsUtils.js +0 -102
- package/src/media/index.js +0 -459
- package/src/media/internal-media-core-wrapper.ts +0 -9
- package/src/media/properties.js +0 -289
- package/src/mediaQualityMetrics/config.js +0 -382
- package/src/meeting/effectsState.js +0 -205
- package/src/meeting/index.js +0 -6284
- package/src/meeting/muteState.js +0 -318
- package/src/meeting/util.js +0 -506
- package/src/meeting-info/index.js +0 -131
- package/src/meeting-info/meeting-info-v2.js +0 -255
- package/src/meetings/index.js +0 -1015
- package/src/member/util.js +0 -254
- package/src/members/request.js +0 -131
- package/src/members/util.js +0 -258
- package/src/metrics/config.js +0 -324
- package/src/metrics/index.js +0 -530
- package/src/multistream/multistreamMedia.ts +0 -92
- package/src/peer-connection-manager/util.ts +0 -117
- package/src/reachability/index.js +0 -464
- package/src/roap/request.js +0 -127
- package/src/statsAnalyzer/global.js +0 -133
- package/src/statsAnalyzer/index.js +0 -1006
- package/src/statsAnalyzer/mqaUtil.js +0 -173
- package/test/unit/spec/meeting/effectsState.js +0 -291
- package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -389
- /package/src/common/errors/{reconnection-in-progress.js → reconnection-in-progress.ts} +0 -0
|
@@ -1,144 +1,194 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
4
|
-
|
|
5
4
|
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
|
|
6
|
-
|
|
7
5
|
_Object$defineProperty(exports, "__esModule", {
|
|
8
6
|
value: true
|
|
9
7
|
});
|
|
10
|
-
|
|
11
|
-
exports.default = void 0;
|
|
12
|
-
|
|
8
|
+
exports.createMuteState = exports.MuteState = void 0;
|
|
13
9
|
var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
|
|
14
|
-
|
|
15
10
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
|
|
16
|
-
|
|
17
11
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
|
|
18
|
-
|
|
12
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
|
|
19
13
|
var _loggerProxy = _interopRequireDefault(require("../common/logs/logger-proxy"));
|
|
20
|
-
|
|
21
14
|
var _parameter = _interopRequireDefault(require("../common/errors/parameter"));
|
|
22
|
-
|
|
23
|
-
var _permission = _interopRequireDefault(require("../common/errors/permission"));
|
|
24
|
-
|
|
25
|
-
var _media = _interopRequireDefault(require("../media"));
|
|
26
|
-
|
|
27
|
-
var _util = _interopRequireDefault(require("../meeting/util"));
|
|
28
|
-
|
|
15
|
+
var _util = _interopRequireDefault(require("./util"));
|
|
29
16
|
var _constants = require("../constants");
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
*/
|
|
34
|
-
var createMuteState = function createMuteState(type, meeting, mediaDirection) {
|
|
35
|
-
if (type === _constants.AUDIO && !mediaDirection.sendAudio) {
|
|
36
|
-
return null;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
if (type === _constants.VIDEO && !mediaDirection.sendVideo) {
|
|
40
|
-
return null;
|
|
41
|
-
}
|
|
17
|
+
// eslint-disable-next-line import/prefer-default-export
|
|
18
|
+
var createMuteState = function createMuteState(type, meeting, enabled) {
|
|
19
|
+
// todo: remove the meeting argument (SPARK-399695)
|
|
42
20
|
|
|
43
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));
|
|
44
|
-
|
|
45
|
-
return
|
|
22
|
+
var muteState = new MuteState(type, meeting, enabled);
|
|
23
|
+
return muteState;
|
|
46
24
|
};
|
|
25
|
+
|
|
47
26
|
/** The purpose of this class is to manage the local and remote mute state and make sure that the server state always matches
|
|
48
27
|
the last requested state by the client.
|
|
49
28
|
|
|
50
29
|
More info about Locus muting API: https://sqbu-github.cisco.com/pages/WebExSquared/locus/guides/mute.html#
|
|
51
|
-
*/
|
|
52
|
-
|
|
53
30
|
|
|
31
|
+
This class is exported only for unit tests. It should never be instantiated directly with new MuteState(), instead createMuteState() should be called
|
|
32
|
+
*/
|
|
33
|
+
exports.createMuteState = createMuteState;
|
|
54
34
|
var MuteState = /*#__PURE__*/function () {
|
|
55
35
|
/**
|
|
56
36
|
* Constructor
|
|
57
37
|
*
|
|
58
38
|
* @param {String} type - audio or video
|
|
59
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
|
|
60
41
|
*/
|
|
61
|
-
function MuteState(type, meeting) {
|
|
42
|
+
function MuteState(type, meeting, enabled) {
|
|
43
|
+
var _meeting$remoteVideoM, _meeting$unmuteVideoA;
|
|
62
44
|
(0, _classCallCheck2.default)(this, MuteState);
|
|
63
|
-
|
|
45
|
+
(0, _defineProperty2.default)(this, "state", void 0);
|
|
46
|
+
(0, _defineProperty2.default)(this, "type", void 0);
|
|
47
|
+
(0, _defineProperty2.default)(this, "ignoreMuteStateChange", void 0);
|
|
64
48
|
if (type !== _constants.AUDIO && type !== _constants.VIDEO) {
|
|
65
49
|
throw new _parameter.default('Mute state is designed for handling audio or video only');
|
|
66
50
|
}
|
|
67
|
-
|
|
68
51
|
this.type = type;
|
|
52
|
+
this.ignoreMuteStateChange = false;
|
|
69
53
|
this.state = {
|
|
70
54
|
client: {
|
|
71
|
-
|
|
55
|
+
enabled: enabled,
|
|
56
|
+
localMute: true
|
|
72
57
|
},
|
|
73
58
|
server: {
|
|
74
|
-
localMute:
|
|
75
|
-
//
|
|
76
|
-
remoteMute: type === _constants.AUDIO ? meeting.remoteMuted : false,
|
|
77
|
-
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
|
|
78
63
|
},
|
|
79
64
|
syncToServerInProgress: false
|
|
80
|
-
};
|
|
81
|
-
|
|
82
|
-
this.pendingPromiseResolve = null;
|
|
83
|
-
this.pendingPromiseReject = null;
|
|
65
|
+
};
|
|
84
66
|
}
|
|
67
|
+
|
|
85
68
|
/**
|
|
86
|
-
*
|
|
87
|
-
* at the point that this request becomese superseded by another client request.
|
|
88
|
-
*
|
|
89
|
-
* The client doesn't have to wait for the returned promise to resolve before calling handleClientRequest() again. If
|
|
90
|
-
* handleClientRequest() is called again before the previous one resolved, the MuteState class will make sure that eventually
|
|
91
|
-
* 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.
|
|
92
70
|
*
|
|
93
|
-
* @
|
|
94
|
-
* @
|
|
95
|
-
* @param {Object} [meeting] the meeting object
|
|
96
|
-
* @param {Boolean} [mute] true for muting, false for unmuting request
|
|
97
|
-
* @returns {Promise}
|
|
71
|
+
* @param {Object} meeting - the meeting object
|
|
72
|
+
* @returns {void}
|
|
98
73
|
*/
|
|
99
|
-
|
|
100
|
-
|
|
101
74
|
(0, _createClass2.default)(MuteState, [{
|
|
102
|
-
key: "
|
|
103
|
-
value: function
|
|
104
|
-
var
|
|
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;
|
|
92
|
+
}
|
|
93
|
+
this.applyClientStateToServer(meeting);
|
|
94
|
+
}
|
|
105
95
|
|
|
106
|
-
|
|
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);
|
|
109
|
+
}
|
|
107
110
|
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
111
|
+
/**
|
|
112
|
+
* Enables/disables audio/video
|
|
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
|
+
}
|
|
112
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
|
+
}
|
|
113
146
|
|
|
147
|
+
/**
|
|
148
|
+
* This method should be called when the local stream mute state is changed
|
|
149
|
+
* @public
|
|
150
|
+
* @memberof MuteState
|
|
151
|
+
* @param {Object} [meeting] the meeting object
|
|
152
|
+
* @param {Boolean} [mute] true for muting, false for unmuting request
|
|
153
|
+
* @returns {void}
|
|
154
|
+
*/
|
|
155
|
+
}, {
|
|
156
|
+
key: "handleLocalStreamMuteStateChange",
|
|
157
|
+
value: function handleLocalStreamMuteStateChange(meeting, mute) {
|
|
158
|
+
if (this.ignoreMuteStateChange) {
|
|
159
|
+
return;
|
|
160
|
+
}
|
|
161
|
+
_loggerProxy.default.logger.info("Meeting:muteState#handleLocalStreamMuteStateChange --> ".concat(this.type, ": local stream new mute state: ").concat(mute));
|
|
114
162
|
this.state.client.localMute = mute;
|
|
115
|
-
this.
|
|
116
|
-
return new _promise.default(function (resolve, reject) {
|
|
117
|
-
if (_this.pendingPromiseResolve) {
|
|
118
|
-
// resolve the last promise we returned to the client as the client has issued a new request that has superseded the previous one
|
|
119
|
-
_this.pendingPromiseResolve();
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
_this.pendingPromiseResolve = resolve;
|
|
123
|
-
_this.pendingPromiseReject = reject;
|
|
124
|
-
|
|
125
|
-
_this.applyClientStateToServer(meeting);
|
|
126
|
-
});
|
|
163
|
+
this.applyClientStateToServer(meeting);
|
|
127
164
|
}
|
|
165
|
+
|
|
128
166
|
/**
|
|
129
|
-
* Applies the current mute state to the local
|
|
167
|
+
* Applies the current mute state to the local stream (by enabling or disabling it accordingly)
|
|
130
168
|
*
|
|
131
169
|
* @public
|
|
132
170
|
* @param {Object} [meeting] the meeting object
|
|
171
|
+
* @param {ServerMuteReason} reason - reason why we're applying our client state to the local stream
|
|
133
172
|
* @memberof MuteState
|
|
134
173
|
* @returns {void}
|
|
135
174
|
*/
|
|
136
|
-
|
|
137
175
|
}, {
|
|
138
176
|
key: "applyClientStateLocally",
|
|
139
|
-
value: function applyClientStateLocally(meeting) {
|
|
140
|
-
|
|
177
|
+
value: function applyClientStateLocally(meeting, reason) {
|
|
178
|
+
this.muteLocalStream(meeting, this.state.client.localMute, reason);
|
|
141
179
|
}
|
|
180
|
+
|
|
181
|
+
/** Returns true if client is locally muted - it takes into account not just the client local mute state,
|
|
182
|
+
* but also whether audio/video is enabled at all
|
|
183
|
+
*
|
|
184
|
+
* @returns {boolean}
|
|
185
|
+
*/
|
|
186
|
+
}, {
|
|
187
|
+
key: "getClientLocalMuteState",
|
|
188
|
+
value: function getClientLocalMuteState() {
|
|
189
|
+
return this.state.client.enabled ? this.state.client.localMute : true;
|
|
190
|
+
}
|
|
191
|
+
|
|
142
192
|
/**
|
|
143
193
|
* Updates the server local and remote mute values so that they match the current client desired state.
|
|
144
194
|
*
|
|
@@ -147,62 +197,45 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
147
197
|
* @memberof MuteState
|
|
148
198
|
* @returns {void}
|
|
149
199
|
*/
|
|
150
|
-
|
|
151
200
|
}, {
|
|
152
201
|
key: "applyClientStateToServer",
|
|
153
202
|
value: function applyClientStateToServer(meeting) {
|
|
154
|
-
var
|
|
155
|
-
|
|
203
|
+
var _this = this;
|
|
156
204
|
if (this.state.syncToServerInProgress) {
|
|
157
205
|
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": request to server in progress, we need to wait for it to complete"));
|
|
158
|
-
|
|
159
206
|
return;
|
|
160
207
|
}
|
|
161
|
-
|
|
162
|
-
var localMuteRequiresSync =
|
|
163
|
-
var remoteMuteRequiresSync = !
|
|
164
|
-
|
|
165
|
-
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": localMuteRequiresSync: ").concat(localMuteRequiresSync, " (").concat(this.state.client.localMute, " ?= ").concat(this.state.server.localMute, ")"));
|
|
166
|
-
|
|
208
|
+
var localMuteState = this.getClientLocalMuteState();
|
|
209
|
+
var localMuteRequiresSync = localMuteState !== this.state.server.localMute;
|
|
210
|
+
var remoteMuteRequiresSync = !localMuteState && this.state.server.remoteMute;
|
|
211
|
+
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": localMuteRequiresSync: ").concat(localMuteRequiresSync, " (").concat(localMuteState, " ?= ").concat(this.state.server.localMute, ")"));
|
|
167
212
|
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": remoteMuteRequiresSync: ").concat(remoteMuteRequiresSync));
|
|
168
|
-
|
|
169
213
|
if (!localMuteRequiresSync && !remoteMuteRequiresSync) {
|
|
170
214
|
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": client state already matching server state, nothing to do"));
|
|
171
|
-
|
|
172
|
-
if (this.pendingPromiseResolve) {
|
|
173
|
-
this.pendingPromiseResolve();
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
this.pendingPromiseResolve = null;
|
|
177
|
-
this.pendingPromiseReject = null;
|
|
178
215
|
return;
|
|
179
216
|
}
|
|
217
|
+
this.state.syncToServerInProgress = true;
|
|
180
218
|
|
|
181
|
-
|
|
182
|
-
|
|
219
|
+
// first sync local mute with server
|
|
183
220
|
var localMuteSyncPromise = localMuteRequiresSync ? this.sendLocalMuteRequestToServer(meeting) : _promise.default.resolve();
|
|
184
221
|
localMuteSyncPromise.then(function () {
|
|
185
|
-
return (
|
|
186
|
-
|
|
222
|
+
return (
|
|
223
|
+
// then follow it up with remote mute sync
|
|
224
|
+
remoteMuteRequiresSync ? _this.sendRemoteMuteRequestToServer(meeting) : _promise.default.resolve()
|
|
187
225
|
);
|
|
188
226
|
}).then(function () {
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(_this2.type, ": sync with server completed")); // need to check if a new sync is required, because this.state.client may have changed while we were doing the current sync
|
|
227
|
+
_this.state.syncToServerInProgress = false;
|
|
228
|
+
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(_this.type, ": sync with server completed"));
|
|
192
229
|
|
|
193
|
-
|
|
194
|
-
|
|
230
|
+
// need to check if a new sync is required, because this.state.client may have changed while we were doing the current sync
|
|
231
|
+
_this.applyClientStateToServer(meeting);
|
|
195
232
|
}).catch(function (e) {
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
_this2.pendingPromiseReject(e);
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
_this2.pendingPromiseResolve = null;
|
|
203
|
-
_this2.pendingPromiseReject = null;
|
|
233
|
+
_this.state.syncToServerInProgress = false;
|
|
234
|
+
_loggerProxy.default.logger.warn("Meeting:muteState#applyClientStateToServer --> ".concat(_this.type, ": error: ").concat(e));
|
|
235
|
+
_this.applyServerMuteToLocalStream(meeting, 'clientRequestFailed');
|
|
204
236
|
});
|
|
205
237
|
}
|
|
238
|
+
|
|
206
239
|
/**
|
|
207
240
|
* Sets the local mute value in the server
|
|
208
241
|
*
|
|
@@ -211,31 +244,26 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
211
244
|
* @memberof MuteState
|
|
212
245
|
* @returns {Promise}
|
|
213
246
|
*/
|
|
214
|
-
|
|
215
247
|
}, {
|
|
216
248
|
key: "sendLocalMuteRequestToServer",
|
|
217
249
|
value: function sendLocalMuteRequestToServer(meeting) {
|
|
218
|
-
var
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
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;
|
|
223
|
-
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;
|
|
224
|
-
|
|
250
|
+
var _this2 = this;
|
|
251
|
+
var audioMuted = this.type === _constants.AUDIO ? this.getClientLocalMuteState() : undefined;
|
|
252
|
+
var videoMuted = this.type === _constants.VIDEO ? this.getClientLocalMuteState() : undefined;
|
|
225
253
|
_loggerProxy.default.logger.info("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(this.type, ": sending local mute (audio=").concat(audioMuted, ", video=").concat(videoMuted, ") to server"));
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
254
|
+
return _util.default.remoteUpdateAudioVideo(meeting, audioMuted, videoMuted).then(function (locus) {
|
|
255
|
+
_loggerProxy.default.logger.info("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(_this2.type, ": local mute (audio=").concat(audioMuted, ", video=").concat(videoMuted, ") applied to server"));
|
|
256
|
+
_this2.state.server.localMute = _this2.type === _constants.AUDIO ? audioMuted : videoMuted;
|
|
257
|
+
if (locus) {
|
|
258
|
+
meeting.locusInfo.handleLocusDelta(locus, meeting);
|
|
259
|
+
}
|
|
232
260
|
return locus;
|
|
233
261
|
}).catch(function (remoteUpdateError) {
|
|
234
|
-
_loggerProxy.default.logger.warn("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(
|
|
235
|
-
|
|
262
|
+
_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));
|
|
236
263
|
return _promise.default.reject(remoteUpdateError);
|
|
237
264
|
});
|
|
238
265
|
}
|
|
266
|
+
|
|
239
267
|
/**
|
|
240
268
|
* Sets the remote mute value in the server
|
|
241
269
|
*
|
|
@@ -244,50 +272,77 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
244
272
|
* @memberof MuteState
|
|
245
273
|
* @returns {Promise}
|
|
246
274
|
*/
|
|
247
|
-
|
|
248
275
|
}, {
|
|
249
276
|
key: "sendRemoteMuteRequestToServer",
|
|
250
277
|
value: function sendRemoteMuteRequestToServer(meeting) {
|
|
251
|
-
var
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
}).catch(function (remoteUpdateError) {
|
|
263
|
-
_loggerProxy.default.logger.warn("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(_this4.type, ": failed to apply remote mute ").concat(remoteMute, " to server: ").concat(remoteUpdateError));
|
|
278
|
+
var _this3 = this;
|
|
279
|
+
var remoteMute = this.getClientLocalMuteState();
|
|
280
|
+
_loggerProxy.default.logger.info("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(this.type, ": sending remote mute:").concat(remoteMute, " to server"));
|
|
281
|
+
return meeting.members.muteMember(meeting.members.selfId, remoteMute, this.type === _constants.AUDIO).then(function () {
|
|
282
|
+
_loggerProxy.default.logger.info("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(_this3.type, ": remote mute:").concat(remoteMute, " applied to server"));
|
|
283
|
+
_this3.state.server.remoteMute = remoteMute;
|
|
284
|
+
}).catch(function (remoteUpdateError) {
|
|
285
|
+
_loggerProxy.default.logger.warn("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(_this3.type, ": failed to apply remote mute ").concat(remoteMute, " to server: ").concat(remoteUpdateError));
|
|
286
|
+
return _promise.default.reject(remoteUpdateError);
|
|
287
|
+
});
|
|
288
|
+
}
|
|
264
289
|
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
290
|
+
/** Sets the mute state of the local stream according to what server thinks is our state
|
|
291
|
+
* @param {Object} meeting - the meeting object
|
|
292
|
+
* @param {ServerMuteReason} serverMuteReason - reason why we're applying server mute to the local stream
|
|
293
|
+
* @returns {void}
|
|
294
|
+
*/
|
|
295
|
+
}, {
|
|
296
|
+
key: "applyServerMuteToLocalStream",
|
|
297
|
+
value: function applyServerMuteToLocalStream(meeting, serverMuteReason) {
|
|
298
|
+
var muted = this.state.server.localMute || this.state.server.remoteMute;
|
|
268
299
|
|
|
300
|
+
// update the local stream mute state, but not this.state.client.localMute
|
|
301
|
+
this.muteLocalStream(meeting, muted, serverMuteReason);
|
|
302
|
+
}
|
|
269
303
|
|
|
270
|
-
|
|
271
|
-
|
|
304
|
+
/** Applies the current value for unmute allowed to the underlying stream
|
|
305
|
+
*
|
|
306
|
+
* @param {Meeting} meeting
|
|
307
|
+
* @returns {void}
|
|
308
|
+
*/
|
|
309
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
310
|
+
}, {
|
|
311
|
+
key: "applyUnmuteAllowedToStream",
|
|
312
|
+
value: function applyUnmuteAllowedToStream(meeting) {
|
|
313
|
+
if (this.type === _constants.AUDIO) {
|
|
314
|
+
var _meeting$mediaPropert5;
|
|
315
|
+
(_meeting$mediaPropert5 = meeting.mediaProperties.audioStream) === null || _meeting$mediaPropert5 === void 0 ? void 0 : _meeting$mediaPropert5.setUnmuteAllowed(this.state.server.unmuteAllowed);
|
|
316
|
+
} else {
|
|
317
|
+
var _meeting$mediaPropert6;
|
|
318
|
+
(_meeting$mediaPropert6 = meeting.mediaProperties.videoStream) === null || _meeting$mediaPropert6 === void 0 ? void 0 : _meeting$mediaPropert6.setUnmuteAllowed(this.state.server.unmuteAllowed);
|
|
319
|
+
}
|
|
272
320
|
}
|
|
321
|
+
|
|
273
322
|
/**
|
|
274
323
|
* This method should be called whenever the server remote mute state is changed
|
|
275
324
|
*
|
|
276
325
|
* @public
|
|
277
326
|
* @memberof MuteState
|
|
327
|
+
* @param {Meeting} meeting
|
|
278
328
|
* @param {Boolean} [muted] true if user is remotely muted, false otherwise
|
|
279
329
|
* @param {Boolean} [unmuteAllowed] indicates if user is allowed to unmute self (false when "hard mute" feature is used)
|
|
280
330
|
* @returns {undefined}
|
|
281
331
|
*/
|
|
282
|
-
|
|
283
332
|
}, {
|
|
284
333
|
key: "handleServerRemoteMuteUpdate",
|
|
285
|
-
value: function handleServerRemoteMuteUpdate(muted, unmuteAllowed) {
|
|
334
|
+
value: function handleServerRemoteMuteUpdate(meeting, muted, unmuteAllowed) {
|
|
286
335
|
_loggerProxy.default.logger.info("Meeting:muteState#handleServerRemoteMuteUpdate --> ".concat(this.type, ": updating server remoteMute to (").concat(muted, ")"));
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
336
|
+
if (unmuteAllowed !== undefined) {
|
|
337
|
+
this.state.server.unmuteAllowed = unmuteAllowed;
|
|
338
|
+
this.applyUnmuteAllowedToStream(meeting);
|
|
339
|
+
}
|
|
340
|
+
if (muted !== undefined) {
|
|
341
|
+
this.state.server.remoteMute = muted;
|
|
342
|
+
this.applyServerMuteToLocalStream(meeting, 'remotelyMuted');
|
|
343
|
+
}
|
|
290
344
|
}
|
|
345
|
+
|
|
291
346
|
/**
|
|
292
347
|
* This method should be called whenever we receive from the server a requirement to locally unmute
|
|
293
348
|
*
|
|
@@ -296,66 +351,76 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
296
351
|
* @param {Object} [meeting] the meeting object
|
|
297
352
|
* @returns {undefined}
|
|
298
353
|
*/
|
|
299
|
-
|
|
300
354
|
}, {
|
|
301
355
|
key: "handleServerLocalUnmuteRequired",
|
|
302
356
|
value: function handleServerLocalUnmuteRequired(meeting) {
|
|
303
|
-
|
|
357
|
+
if (!this.state.client.enabled) {
|
|
358
|
+
_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"));
|
|
359
|
+
} else {
|
|
360
|
+
_loggerProxy.default.logger.info("Meeting:muteState#handleServerLocalUnmuteRequired --> ".concat(this.type, ": localAudioUnmuteRequired received -> doing local unmute"));
|
|
361
|
+
}
|
|
304
362
|
|
|
363
|
+
// 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
|
|
305
364
|
this.state.server.remoteMute = false;
|
|
306
365
|
this.state.client.localMute = false;
|
|
307
|
-
|
|
308
|
-
if (this.pendingPromiseReject) {
|
|
309
|
-
this.pendingPromiseReject(new Error('Server requested local unmute - this overrides any client request in progress'));
|
|
310
|
-
this.pendingPromiseResolve = null;
|
|
311
|
-
this.pendingPromiseReject = null;
|
|
312
|
-
}
|
|
313
|
-
|
|
314
|
-
this.applyClientStateLocally(meeting);
|
|
366
|
+
this.applyClientStateLocally(meeting, 'localUnmuteRequired');
|
|
315
367
|
this.applyClientStateToServer(meeting);
|
|
316
368
|
}
|
|
369
|
+
|
|
317
370
|
/**
|
|
318
|
-
* Returns true if the user is locally or remotely muted
|
|
371
|
+
* Returns true if the user is locally or remotely muted.
|
|
372
|
+
* It only checks the mute status, ignoring the fact whether audio/video is enabled.
|
|
319
373
|
*
|
|
320
374
|
* @public
|
|
321
375
|
* @memberof MuteState
|
|
322
376
|
* @returns {Boolean}
|
|
323
377
|
*/
|
|
324
|
-
|
|
325
378
|
}, {
|
|
326
379
|
key: "isMuted",
|
|
327
380
|
value: function isMuted() {
|
|
328
381
|
return this.state.client.localMute || this.state.server.localMute || this.state.server.remoteMute;
|
|
329
382
|
}
|
|
383
|
+
|
|
330
384
|
/**
|
|
331
|
-
* Returns true if the user is
|
|
385
|
+
* Returns true if the user is remotely muted
|
|
332
386
|
*
|
|
333
387
|
* @public
|
|
334
388
|
* @memberof MuteState
|
|
335
389
|
* @returns {Boolean}
|
|
336
390
|
*/
|
|
337
|
-
|
|
338
391
|
}, {
|
|
339
|
-
key: "
|
|
340
|
-
value: function
|
|
341
|
-
return this.state.
|
|
342
|
-
}
|
|
392
|
+
key: "isRemotelyMuted",
|
|
393
|
+
value: function isRemotelyMuted() {
|
|
394
|
+
return this.state.server.remoteMute;
|
|
395
|
+
}
|
|
343
396
|
|
|
397
|
+
/**
|
|
398
|
+
* Returns true if unmute is allowed
|
|
399
|
+
*
|
|
400
|
+
* @public
|
|
401
|
+
* @memberof MuteState
|
|
402
|
+
* @returns {Boolean}
|
|
403
|
+
*/
|
|
344
404
|
}, {
|
|
345
|
-
key: "
|
|
346
|
-
|
|
347
|
-
return this.
|
|
348
|
-
}
|
|
405
|
+
key: "isUnmuteAllowed",
|
|
406
|
+
value: function isUnmuteAllowed() {
|
|
407
|
+
return this.state.server.unmuteAllowed;
|
|
408
|
+
}
|
|
349
409
|
|
|
410
|
+
/**
|
|
411
|
+
* Returns true if the user is locally muted or audio/video is disabled
|
|
412
|
+
*
|
|
413
|
+
* @public
|
|
414
|
+
* @memberof MuteState
|
|
415
|
+
* @returns {Boolean}
|
|
416
|
+
*/
|
|
350
417
|
}, {
|
|
351
|
-
key: "
|
|
352
|
-
|
|
353
|
-
return this.
|
|
418
|
+
key: "isLocallyMuted",
|
|
419
|
+
value: function isLocallyMuted() {
|
|
420
|
+
return this.getClientLocalMuteState();
|
|
354
421
|
}
|
|
355
422
|
}]);
|
|
356
423
|
return MuteState;
|
|
357
424
|
}();
|
|
358
|
-
|
|
359
|
-
var _default = createMuteState;
|
|
360
|
-
exports.default = _default;
|
|
425
|
+
exports.MuteState = MuteState;
|
|
361
426
|
//# sourceMappingURL=muteState.js.map
|