@webex/plugin-meetings 3.0.0-beta.1 → 3.0.0-beta.104
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/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 +48 -0
- package/dist/annotation/constants.js.map +1 -0
- package/dist/annotation/index.js +357 -0
- package/dist/annotation/index.js.map +1 -0
- package/dist/breakouts/breakout.js +176 -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 +43 -0
- package/dist/breakouts/events.js.map +1 -0
- package/dist/breakouts/index.js +919 -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/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/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 +10 -69
- 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 +37 -60
- package/dist/common/logs/request.js.map +1 -1
- package/dist/common/queue.js +4 -14
- package/dist/common/queue.js.map +1 -1
- package/dist/config.js +7 -6
- package/dist/config.js.map +1 -1
- package/dist/constants.js +184 -122
- 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 +25 -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 +250 -0
- package/dist/controls-options-manager/util.js.map +1 -0
- package/dist/index.js +72 -17
- package/dist/index.js.map +1 -1
- package/dist/locus-info/controlsUtils.js +56 -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 +362 -208
- package/dist/locus-info/index.js.map +1 -1
- package/dist/locus-info/infoUtils.js +3 -37
- package/dist/locus-info/infoUtils.js.map +1 -1
- package/dist/locus-info/mediaSharesUtils.js +12 -38
- package/dist/locus-info/mediaSharesUtils.js.map +1 -1
- package/dist/locus-info/parser.js +92 -118
- package/dist/locus-info/parser.js.map +1 -1
- package/dist/locus-info/selfUtils.js +99 -91
- package/dist/locus-info/selfUtils.js.map +1 -1
- package/dist/media/index.js +113 -337
- package/dist/media/index.js.map +1 -1
- package/dist/media/properties.js +96 -135
- package/dist/media/properties.js.map +1 -1
- package/dist/media/util.js +1 -35
- 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 +59 -14
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +2909 -2398
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/muteState.js +257 -112
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +330 -264
- 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 +63 -261
- 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 +14 -32
- package/dist/meeting-info/index.js.map +1 -1
- package/dist/meeting-info/meeting-info-v2.js +273 -280
- 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 +155 -232
- 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 +741 -548
- package/dist/meetings/index.js.map +1 -1
- package/dist/meetings/request.js +26 -41
- package/dist/meetings/request.js.map +1 -1
- package/dist/meetings/util.js +194 -149
- package/dist/meetings/util.js.map +1 -1
- package/dist/member/index.js +100 -85
- package/dist/member/index.js.map +1 -1
- package/dist/member/types.js +15 -0
- package/dist/member/types.js.map +1 -0
- package/dist/member/util.js +90 -68
- 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 +227 -188
- package/dist/members/index.js.map +1 -1
- package/dist/members/request.js +54 -39
- 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 +107 -44
- package/dist/members/util.js.map +1 -1
- package/dist/metrics/config.js +5 -14
- package/dist/metrics/config.js.map +1 -1
- package/dist/metrics/constants.js +3 -7
- package/dist/metrics/constants.js.map +1 -1
- package/dist/metrics/index.js +67 -159
- package/dist/metrics/index.js.map +1 -1
- package/dist/multistream/mediaRequestManager.js +250 -0
- package/dist/multistream/mediaRequestManager.js.map +1 -0
- package/dist/multistream/receiveSlot.js +202 -0
- package/dist/multistream/receiveSlot.js.map +1 -0
- package/dist/multistream/receiveSlotManager.js +176 -0
- package/dist/multistream/receiveSlotManager.js.map +1 -0
- package/dist/multistream/remoteMedia.js +270 -0
- package/dist/multistream/remoteMedia.js.map +1 -0
- package/dist/multistream/remoteMediaGroup.js +209 -0
- package/dist/multistream/remoteMediaGroup.js.map +1 -0
- package/dist/multistream/remoteMediaManager.js +1137 -0
- package/dist/multistream/remoteMediaManager.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 +192 -191
- package/dist/reachability/index.js.map +1 -1
- package/dist/reachability/request.js +15 -23
- 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 +386 -527
- 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 +343 -0
- package/dist/recording-controller/index.js.map +1 -0
- package/dist/recording-controller/util.js +63 -0
- package/dist/recording-controller/util.js.map +1 -0
- package/dist/roap/index.js +84 -286
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +138 -238
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/turnDiscovery.js +164 -102
- package/dist/roap/turnDiscovery.js.map +1 -1
- package/dist/statsAnalyzer/global.js +1 -93
- package/dist/statsAnalyzer/global.js.map +1 -1
- package/dist/statsAnalyzer/index.js +399 -470
- package/dist/statsAnalyzer/index.js.map +1 -1
- package/dist/statsAnalyzer/mqaUtil.js +143 -87
- 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 +34 -0
- package/dist/types/annotation/constants.d.ts +31 -0
- package/dist/types/annotation/index.d.ts +124 -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 +2 -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/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/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 +69 -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 +34 -0
- package/dist/types/common/queue.d.ts +32 -0
- package/dist/types/config.d.ts +78 -0
- package/dist/types/constants.d.ts +968 -0
- package/dist/types/controls-options-manager/constants.d.ts +4 -0
- package/dist/types/controls-options-manager/enums.d.ts +13 -0
- package/dist/types/controls-options-manager/index.d.ts +136 -0
- package/dist/types/controls-options-manager/types.d.ts +37 -0
- package/dist/types/controls-options-manager/util.d.ts +1 -0
- package/dist/types/index.d.ts +7 -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 +315 -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 +212 -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 +108 -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 +129 -0
- package/dist/types/meeting/index.d.ts +1748 -0
- package/dist/types/meeting/muteState.d.ts +185 -0
- package/dist/types/meeting/request.d.ts +275 -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 +2 -0
- package/dist/types/meeting-info/collection.d.ts +20 -0
- package/dist/types/meeting-info/index.d.ts +57 -0
- package/dist/types/meeting-info/meeting-info-v2.d.ts +112 -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 +345 -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 +156 -0
- package/dist/types/member/types.d.ts +21 -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 +69 -0
- package/dist/types/members/types.d.ts +24 -0
- package/dist/types/members/util.d.ts +2 -0
- package/dist/types/metrics/config.d.ts +172 -0
- package/dist/types/metrics/constants.d.ts +54 -0
- package/dist/types/metrics/index.d.ts +152 -0
- package/dist/types/multistream/mediaRequestManager.d.ts +101 -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 +263 -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 +152 -0
- package/dist/types/reachability/request.d.ts +37 -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 +193 -0
- package/dist/types/recording-controller/util.d.ts +13 -0
- package/dist/types/roap/index.d.ts +77 -0
- package/dist/types/roap/request.d.ts +38 -0
- package/dist/types/roap/turnDiscovery.d.ts +88 -0
- package/dist/types/statsAnalyzer/global.d.ts +36 -0
- package/dist/types/statsAnalyzer/index.d.ts +200 -0
- package/dist/types/statsAnalyzer/mqaUtil.d.ts +24 -0
- package/dist/types/transcription/index.d.ts +64 -0
- package/internal-README.md +7 -6
- package/package.json +29 -21
- package/src/annotation/annotation.types.ts +41 -0
- package/src/annotation/constants.ts +36 -0
- package/src/annotation/index.ts +339 -0
- package/src/breakouts/README.md +219 -0
- package/src/breakouts/breakout.ts +141 -0
- package/src/breakouts/collection.ts +19 -0
- package/src/breakouts/edit-lock-error.ts +25 -0
- package/src/breakouts/events.ts +37 -0
- package/src/breakouts/index.ts +823 -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/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/{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} +8 -25
- 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} +22 -9
- package/src/common/queue.ts +1 -2
- package/src/{config.js → config.ts} +18 -12
- package/src/constants.ts +256 -183
- package/src/controls-options-manager/constants.ts +5 -0
- package/src/controls-options-manager/enums.ts +16 -0
- package/src/controls-options-manager/index.ts +278 -0
- package/src/controls-options-manager/types.ts +49 -0
- package/src/controls-options-manager/util.ts +229 -0
- package/src/index.ts +33 -0
- package/src/locus-info/controlsUtils.ts +169 -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} +331 -80
- package/src/locus-info/{infoUtils.js → infoUtils.ts} +19 -8
- package/src/locus-info/{mediaSharesUtils.js → mediaSharesUtils.ts} +17 -17
- package/src/locus-info/{parser.js → parser.ts} +67 -79
- package/src/locus-info/{selfUtils.js → selfUtils.ts} +196 -67
- package/src/media/index.ts +488 -0
- package/src/media/{properties.js → properties.ts} +67 -54
- package/src/media/util.ts +16 -0
- package/src/mediaQualityMetrics/config.ts +384 -0
- package/src/meeting/in-meeting-actions.ts +123 -3
- package/src/meeting/{index.js → index.ts} +3334 -1775
- package/src/meeting/muteState.ts +526 -0
- package/src/meeting/{request.js → request.ts} +350 -142
- package/src/meeting/request.type.ts +13 -0
- package/src/meeting/{state.js → state.ts} +50 -35
- package/src/meeting/{util.js → util.ts} +126 -159
- package/src/meeting-info/{collection.js → collection.ts} +6 -2
- package/src/meeting-info/{index.js → index.ts} +42 -36
- package/src/meeting-info/meeting-info-v2.ts +345 -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} +76 -60
- package/src/meetings/{collection.js → collection.ts} +26 -3
- package/src/meetings/index.ts +1394 -0
- package/src/meetings/{request.js → request.ts} +34 -25
- package/src/meetings/util.ts +288 -0
- package/src/member/{index.js → index.ts} +124 -56
- package/src/member/types.ts +24 -0
- package/src/member/{util.js → util.ts} +105 -25
- package/src/members/{collection.js → collection.ts} +10 -2
- package/src/members/{index.js → index.ts} +359 -139
- package/src/members/request.ts +215 -0
- package/src/members/types.ts +28 -0
- package/src/members/{util.js → util.ts} +145 -54
- package/src/metrics/{config.js → config.ts} +256 -92
- package/src/metrics/{constants.js → constants.ts} +1 -6
- package/src/metrics/{index.js → index.ts} +116 -97
- package/src/multistream/mediaRequestManager.ts +324 -0
- package/src/multistream/receiveSlot.ts +184 -0
- package/src/multistream/receiveSlotManager.ts +166 -0
- package/src/multistream/remoteMedia.ts +254 -0
- package/src/multistream/remoteMediaGroup.ts +225 -0
- package/src/multistream/remoteMediaManager.ts +1075 -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.js → index.ts} +157 -94
- package/src/reachability/request.ts +46 -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} +261 -163
- package/src/recording-controller/enums.ts +8 -0
- package/src/recording-controller/index.ts +315 -0
- package/src/recording-controller/util.ts +58 -0
- package/src/roap/index.ts +241 -0
- package/src/roap/request.ts +172 -0
- package/src/roap/turnDiscovery.ts +127 -53
- package/src/statsAnalyzer/global.ts +37 -0
- package/src/statsAnalyzer/index.ts +1273 -0
- package/src/statsAnalyzer/mqaUtil.ts +291 -0
- package/src/transcription/{index.js → index.ts} +46 -39
- package/test/integration/spec/converged-space-meetings.js +177 -0
- package/test/integration/spec/journey.js +666 -464
- package/test/integration/spec/space-meeting.js +321 -206
- package/test/integration/spec/transcription.js +7 -8
- package/test/unit/spec/annotation/index.ts +435 -0
- package/test/unit/spec/breakouts/breakout.ts +184 -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 +77 -0
- package/test/unit/spec/breakouts/index.ts +1504 -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/controls-options-manager/index.js +287 -0
- package/test/unit/spec/controls-options-manager/util.js +403 -0
- package/test/unit/spec/fixture/locus.js +92 -90
- package/test/unit/spec/locus-info/controlsUtils.js +177 -32
- package/test/unit/spec/locus-info/embeddedAppsUtils.js +8 -6
- package/test/unit/spec/locus-info/index.js +493 -3
- package/test/unit/spec/locus-info/infoUtils.js +41 -32
- package/test/unit/spec/locus-info/lib/BasicSeqCmp.json +88 -430
- package/test/unit/spec/locus-info/lib/SeqCmp.json +513 -685
- package/test/unit/spec/locus-info/parser.js +3 -9
- package/test/unit/spec/locus-info/selfConstant.js +110 -103
- package/test/unit/spec/locus-info/selfUtils.js +236 -12
- package/test/unit/spec/media/index.ts +303 -0
- package/test/unit/spec/media/properties.ts +73 -82
- package/test/unit/spec/meeting/in-meeting-actions.ts +58 -3
- package/test/unit/spec/meeting/index.js +3127 -975
- package/test/unit/spec/meeting/muteState.js +375 -70
- package/test/unit/spec/meeting/request.js +217 -43
- package/test/unit/spec/meeting/utils.js +205 -163
- package/test/unit/spec/meeting-info/meetinginfov2.js +268 -74
- 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 +1052 -333
- package/test/unit/spec/meetings/utils.js +163 -14
- package/test/unit/spec/member/index.js +24 -1
- package/test/unit/spec/member/util.js +359 -32
- package/test/unit/spec/members/index.js +547 -37
- package/test/unit/spec/members/request.js +76 -20
- package/test/unit/spec/members/utils.js +191 -4
- package/test/unit/spec/metrics/index.js +46 -20
- package/test/unit/spec/multistream/mediaRequestManager.ts +1060 -0
- package/test/unit/spec/multistream/receiveSlot.ts +163 -0
- package/test/unit/spec/multistream/receiveSlotManager.ts +203 -0
- package/test/unit/spec/multistream/remoteMedia.ts +255 -0
- package/test/unit/spec/multistream/remoteMediaGroup.ts +396 -0
- package/test/unit/spec/multistream/remoteMediaManager.ts +1793 -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 +176 -27
- package/test/unit/spec/reachability/request.js +66 -0
- package/test/unit/spec/reconnection-manager/index.js +106 -9
- package/test/unit/spec/recording-controller/index.js +231 -0
- package/test/unit/spec/recording-controller/util.js +102 -0
- package/test/unit/spec/roap/index.ts +78 -45
- package/test/unit/spec/roap/request.ts +217 -0
- package/test/unit/spec/roap/turnDiscovery.ts +93 -49
- package/test/unit/spec/stats-analyzer/index.js +118 -65
- package/test/utils/cmr.js +44 -42
- package/test/utils/constants.js +9 -0
- package/test/utils/integrationTestUtils.js +64 -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/meeting/effectsState.js +0 -327
- package/dist/meeting/effectsState.js.map +0 -1
- package/dist/peer-connection-manager/index.js +0 -794
- package/dist/peer-connection-manager/index.js.map +0 -1
- package/dist/peer-connection-manager/util.js +0 -124
- package/dist/peer-connection-manager/util.js.map +0 -1
- package/dist/roap/collection.js +0 -73
- package/dist/roap/collection.js.map +0 -1
- package/dist/roap/handler.js +0 -337
- package/dist/roap/handler.js.map +0 -1
- package/dist/roap/state.js +0 -164
- package/dist/roap/state.js.map +0 -1
- package/dist/roap/util.js +0 -102
- package/dist/roap/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 -593
- package/src/media/util.js +0 -38
- package/src/mediaQualityMetrics/config.js +0 -382
- package/src/meeting/effectsState.js +0 -205
- package/src/meeting/muteState.js +0 -318
- package/src/meeting-info/meeting-info-v2.js +0 -255
- package/src/meetings/index.js +0 -986
- package/src/meetings/util.js +0 -176
- package/src/members/request.js +0 -131
- package/src/peer-connection-manager/index.js +0 -723
- package/src/peer-connection-manager/util.ts +0 -117
- package/src/roap/collection.js +0 -63
- package/src/roap/handler.js +0 -252
- package/src/roap/index.js +0 -380
- package/src/roap/request.js +0 -198
- package/src/roap/state.js +0 -149
- package/src/roap/util.js +0 -93
- package/src/statsAnalyzer/global.js +0 -131
- package/src/statsAnalyzer/index.js +0 -1020
- package/src/statsAnalyzer/mqaUtil.js +0 -173
- package/test/unit/spec/meeting/effectsState.js +0 -293
- package/test/unit/spec/peerconnection-manager/index.js +0 -188
- package/test/unit/spec/peerconnection-manager/utils.js +0 -48
- package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -389
- package/test/unit/spec/roap/util.js +0 -30
- /package/src/common/errors/{reconnection-in-progress.js → reconnection-in-progress.ts} +0 -0
|
@@ -1,116 +1,177 @@
|
|
|
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 = 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
15
|
var _permission = _interopRequireDefault(require("../common/errors/permission"));
|
|
24
|
-
|
|
25
|
-
var _media = _interopRequireDefault(require("../media"));
|
|
26
|
-
|
|
27
|
-
var _util = _interopRequireDefault(require("../meeting/util"));
|
|
28
|
-
|
|
16
|
+
var _util = _interopRequireDefault(require("./util"));
|
|
29
17
|
var _constants = require("../constants");
|
|
30
|
-
|
|
31
18
|
/* Certain aspects of server interaction for video muting are not implemented as we currently don't support remote muting of video.
|
|
32
19
|
If we ever need to support it, search for REMOTE_MUTE_VIDEO_MISSING_IMPLEMENTATION string to find the places that need updating
|
|
33
20
|
*/
|
|
34
|
-
|
|
21
|
+
|
|
22
|
+
// eslint-disable-next-line import/prefer-default-export
|
|
23
|
+
var createMuteState = function createMuteState(type, meeting, mediaDirection, sdkOwnsLocalTrack) {
|
|
24
|
+
// todo: remove mediaDirection argument (SPARK-399695)
|
|
25
|
+
// todo: remove the meeting argument (SPARK-399695)
|
|
35
26
|
if (type === _constants.AUDIO && !mediaDirection.sendAudio) {
|
|
36
27
|
return null;
|
|
37
28
|
}
|
|
38
|
-
|
|
39
29
|
if (type === _constants.VIDEO && !mediaDirection.sendVideo) {
|
|
40
30
|
return null;
|
|
41
31
|
}
|
|
42
|
-
|
|
43
32
|
_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
|
-
|
|
33
|
+
var muteState = new MuteState(type, meeting, sdkOwnsLocalTrack);
|
|
34
|
+
muteState.init(meeting);
|
|
35
|
+
return muteState;
|
|
46
36
|
};
|
|
37
|
+
|
|
47
38
|
/** The purpose of this class is to manage the local and remote mute state and make sure that the server state always matches
|
|
48
39
|
the last requested state by the client.
|
|
49
40
|
|
|
50
41
|
More info about Locus muting API: https://sqbu-github.cisco.com/pages/WebExSquared/locus/guides/mute.html#
|
|
51
42
|
*/
|
|
52
|
-
|
|
53
|
-
|
|
43
|
+
exports.createMuteState = createMuteState;
|
|
54
44
|
var MuteState = /*#__PURE__*/function () {
|
|
45
|
+
// todo: remove this when doing SPARK-399695
|
|
46
|
+
|
|
55
47
|
/**
|
|
56
48
|
* Constructor
|
|
57
49
|
*
|
|
58
50
|
* @param {String} type - audio or video
|
|
59
51
|
* @param {Object} meeting - the meeting object (used for reading current remote mute status)
|
|
52
|
+
* @param {boolean} sdkOwnsLocalTrack - if false, then client app owns the local track (for now that's the case only for multistream meetings)
|
|
60
53
|
*/
|
|
61
|
-
function MuteState(type, meeting) {
|
|
54
|
+
function MuteState(type, meeting, sdkOwnsLocalTrack) {
|
|
55
|
+
var _meeting$remoteVideoM, _meeting$unmuteVideoA;
|
|
62
56
|
(0, _classCallCheck2.default)(this, MuteState);
|
|
63
|
-
|
|
57
|
+
(0, _defineProperty2.default)(this, "pendingPromiseReject", void 0);
|
|
58
|
+
(0, _defineProperty2.default)(this, "pendingPromiseResolve", void 0);
|
|
59
|
+
(0, _defineProperty2.default)(this, "state", void 0);
|
|
60
|
+
(0, _defineProperty2.default)(this, "type", void 0);
|
|
61
|
+
(0, _defineProperty2.default)(this, "sdkOwnsLocalTrack", void 0);
|
|
62
|
+
(0, _defineProperty2.default)(this, "ignoreMuteStateChange", void 0);
|
|
64
63
|
if (type !== _constants.AUDIO && type !== _constants.VIDEO) {
|
|
65
64
|
throw new _parameter.default('Mute state is designed for handling audio or video only');
|
|
66
65
|
}
|
|
67
|
-
|
|
68
66
|
this.type = type;
|
|
67
|
+
this.sdkOwnsLocalTrack = sdkOwnsLocalTrack;
|
|
68
|
+
this.ignoreMuteStateChange = false;
|
|
69
69
|
this.state = {
|
|
70
70
|
client: {
|
|
71
71
|
localMute: false
|
|
72
72
|
},
|
|
73
73
|
server: {
|
|
74
74
|
localMute: false,
|
|
75
|
-
//
|
|
76
|
-
remoteMute: type === _constants.AUDIO ? meeting.remoteMuted : false,
|
|
77
|
-
unmuteAllowed: type === _constants.AUDIO ? meeting.unmuteAllowed : true
|
|
75
|
+
// because remoteVideoMuted and unmuteVideoAllowed are updated seperately, they might be undefined
|
|
76
|
+
remoteMute: type === _constants.AUDIO ? meeting.remoteMuted : (_meeting$remoteVideoM = meeting.remoteVideoMuted) !== null && _meeting$remoteVideoM !== void 0 ? _meeting$remoteVideoM : false,
|
|
77
|
+
unmuteAllowed: type === _constants.AUDIO ? meeting.unmuteAllowed : (_meeting$unmuteVideoA = meeting.unmuteVideoAllowed) !== null && _meeting$unmuteVideoA !== void 0 ? _meeting$unmuteVideoA : true
|
|
78
78
|
},
|
|
79
79
|
syncToServerInProgress: false
|
|
80
|
-
};
|
|
81
|
-
|
|
80
|
+
};
|
|
81
|
+
// these 2 hold the resolve, reject methods for the promise we returned to the client in last handleClientRequest() call
|
|
82
82
|
this.pendingPromiseResolve = null;
|
|
83
83
|
this.pendingPromiseReject = null;
|
|
84
84
|
}
|
|
85
|
+
|
|
85
86
|
/**
|
|
86
|
-
*
|
|
87
|
-
* at the point that this request becomese superseded by another client request.
|
|
87
|
+
* Starts the mute state machine. Needs to be called after a new MuteState instance is created.
|
|
88
88
|
*
|
|
89
|
-
*
|
|
90
|
-
*
|
|
91
|
-
* the server state will match the last requested state from the client.
|
|
92
|
-
*
|
|
93
|
-
* @public
|
|
94
|
-
* @memberof MuteState
|
|
95
|
-
* @param {Object} [meeting] the meeting object
|
|
96
|
-
* @param {Boolean} [mute] true for muting, false for unmuting request
|
|
97
|
-
* @returns {Promise}
|
|
89
|
+
* @param {Object} meeting - the meeting object
|
|
90
|
+
* @returns {void}
|
|
98
91
|
*/
|
|
92
|
+
(0, _createClass2.default)(MuteState, [{
|
|
93
|
+
key: "init",
|
|
94
|
+
value: function init(meeting) {
|
|
95
|
+
if (!this.sdkOwnsLocalTrack) {
|
|
96
|
+
var _meeting$mediaPropert, _meeting$mediaPropert2;
|
|
97
|
+
this.applyUnmuteAllowedToTrack(meeting);
|
|
98
|
+
|
|
99
|
+
// if we are remotely muted, we need to apply that to the local track now (mute on-entry)
|
|
100
|
+
if (this.state.server.remoteMute) {
|
|
101
|
+
this.muteLocalTrack(meeting, this.state.server.remoteMute, 'remotelyMuted');
|
|
102
|
+
}
|
|
103
|
+
var initialMute = this.type === _constants.AUDIO ? (_meeting$mediaPropert = meeting.mediaProperties.audioTrack) === null || _meeting$mediaPropert === void 0 ? void 0 : _meeting$mediaPropert.muted : (_meeting$mediaPropert2 = meeting.mediaProperties.videoTrack) === null || _meeting$mediaPropert2 === void 0 ? void 0 : _meeting$mediaPropert2.muted;
|
|
104
|
+
_loggerProxy.default.logger.info("Meeting:muteState#start --> ".concat(this.type, ": local track initial mute state: ").concat(initialMute));
|
|
105
|
+
if (initialMute !== undefined) {
|
|
106
|
+
this.state.client.localMute = initialMute;
|
|
107
|
+
this.applyClientStateToServer(meeting);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
99
111
|
|
|
112
|
+
/**
|
|
113
|
+
* This method needs to be called whenever the local audio/video track has changed.
|
|
114
|
+
* It reapplies the remote mute state onto the new track and also reads the current
|
|
115
|
+
* local mute state from the track and updates the internal state machine and sends
|
|
116
|
+
* any required requests to the server.
|
|
117
|
+
*
|
|
118
|
+
* @param {Object} meeting - the meeting object
|
|
119
|
+
* @returns {void}
|
|
120
|
+
*/
|
|
121
|
+
}, {
|
|
122
|
+
key: "handleLocalTrackChange",
|
|
123
|
+
value: function handleLocalTrackChange(meeting) {
|
|
124
|
+
return this.init(meeting);
|
|
125
|
+
}
|
|
100
126
|
|
|
101
|
-
|
|
127
|
+
/**
|
|
128
|
+
* Mutes/unmutes local track
|
|
129
|
+
*
|
|
130
|
+
* @param {Object} meeting - the meeting object
|
|
131
|
+
* @param {Boolean} mute - true to mute the track, false to unmute it
|
|
132
|
+
* @param {ServerMuteReason} reason - reason for muting/unmuting
|
|
133
|
+
* @returns {void}
|
|
134
|
+
*/
|
|
135
|
+
}, {
|
|
136
|
+
key: "muteLocalTrack",
|
|
137
|
+
value: function muteLocalTrack(meeting, mute, reason) {
|
|
138
|
+
this.ignoreMuteStateChange = true;
|
|
139
|
+
if (this.type === _constants.AUDIO) {
|
|
140
|
+
var _meeting$mediaPropert3;
|
|
141
|
+
(_meeting$mediaPropert3 = meeting.mediaProperties.audioTrack) === null || _meeting$mediaPropert3 === void 0 ? void 0 : _meeting$mediaPropert3.setServerMuted(mute, reason);
|
|
142
|
+
} else {
|
|
143
|
+
var _meeting$mediaPropert4;
|
|
144
|
+
(_meeting$mediaPropert4 = meeting.mediaProperties.videoTrack) === null || _meeting$mediaPropert4 === void 0 ? void 0 : _meeting$mediaPropert4.setServerMuted(mute, reason);
|
|
145
|
+
}
|
|
146
|
+
this.ignoreMuteStateChange = false;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
/**
|
|
150
|
+
* Handles mute/unmute request from the client/user. Returns a promise that's resolved once the server update is completed or
|
|
151
|
+
* at the point that this request becomese superseded by another client request.
|
|
152
|
+
*
|
|
153
|
+
* The client doesn't have to wait for the returned promise to resolve before calling handleClientRequest() again. If
|
|
154
|
+
* handleClientRequest() is called again before the previous one resolved, the MuteState class will make sure that eventually
|
|
155
|
+
* the server state will match the last requested state from the client.
|
|
156
|
+
*
|
|
157
|
+
* @public
|
|
158
|
+
* @memberof MuteState
|
|
159
|
+
* @param {Object} [meeting] the meeting object
|
|
160
|
+
* @param {Boolean} [mute] true for muting, false for unmuting request
|
|
161
|
+
* @returns {Promise}
|
|
162
|
+
*/
|
|
163
|
+
}, {
|
|
102
164
|
key: "handleClientRequest",
|
|
103
165
|
value: function handleClientRequest(meeting, mute) {
|
|
104
166
|
var _this = this;
|
|
105
|
-
|
|
167
|
+
// todo: this whole method will be removed in SPARK-399695
|
|
106
168
|
_loggerProxy.default.logger.info("Meeting:muteState#handleClientRequest --> ".concat(this.type, ": user requesting new mute state: ").concat(mute));
|
|
107
|
-
|
|
108
169
|
if (!mute && !this.state.server.unmuteAllowed) {
|
|
109
170
|
return _promise.default.reject(new _permission.default('User is not allowed to unmute self (hard mute feature is being used)'));
|
|
110
|
-
}
|
|
111
|
-
// because the client may have changed the audio/vidoe tracks
|
|
112
|
-
|
|
171
|
+
}
|
|
113
172
|
|
|
173
|
+
// 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,
|
|
174
|
+
// because the client may have changed the audio/video tracks
|
|
114
175
|
this.state.client.localMute = mute;
|
|
115
176
|
this.applyClientStateLocally(meeting);
|
|
116
177
|
return new _promise.default(function (resolve, reject) {
|
|
@@ -118,27 +179,59 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
118
179
|
// resolve the last promise we returned to the client as the client has issued a new request that has superseded the previous one
|
|
119
180
|
_this.pendingPromiseResolve();
|
|
120
181
|
}
|
|
121
|
-
|
|
122
182
|
_this.pendingPromiseResolve = resolve;
|
|
123
183
|
_this.pendingPromiseReject = reject;
|
|
124
|
-
|
|
125
184
|
_this.applyClientStateToServer(meeting);
|
|
126
185
|
});
|
|
127
186
|
}
|
|
187
|
+
|
|
188
|
+
/**
|
|
189
|
+
* This method should be called when the local track mute state is changed
|
|
190
|
+
* @public
|
|
191
|
+
* @memberof MuteState
|
|
192
|
+
* @param {Object} [meeting] the meeting object
|
|
193
|
+
* @param {Boolean} [mute] true for muting, false for unmuting request
|
|
194
|
+
* @returns {void}
|
|
195
|
+
*/
|
|
196
|
+
}, {
|
|
197
|
+
key: "handleLocalTrackMuteStateChange",
|
|
198
|
+
value: function handleLocalTrackMuteStateChange(meeting, mute) {
|
|
199
|
+
if (this.ignoreMuteStateChange) {
|
|
200
|
+
return;
|
|
201
|
+
}
|
|
202
|
+
_loggerProxy.default.logger.info("Meeting:muteState#handleLocalTrackMuteStateChange --> ".concat(this.type, ": local track new mute state: ").concat(mute));
|
|
203
|
+
if (this.pendingPromiseReject) {
|
|
204
|
+
_loggerProxy.default.logger.error("Meeting:muteState#handleLocalTrackMuteStateChange --> ".concat(this.type, ": Local track mute state change handler called while a client request is handled - this should never happen!, mute state: ").concat(mute));
|
|
205
|
+
}
|
|
206
|
+
this.state.client.localMute = mute;
|
|
207
|
+
this.applyClientStateToServer(meeting);
|
|
208
|
+
}
|
|
209
|
+
|
|
128
210
|
/**
|
|
129
211
|
* Applies the current mute state to the local track (by enabling or disabling it accordingly)
|
|
130
212
|
*
|
|
131
213
|
* @public
|
|
132
214
|
* @param {Object} [meeting] the meeting object
|
|
215
|
+
* @param {ServerMuteReason} reason - reason why we're applying our client state to the local track
|
|
133
216
|
* @memberof MuteState
|
|
134
217
|
* @returns {void}
|
|
135
218
|
*/
|
|
136
|
-
|
|
137
219
|
}, {
|
|
138
220
|
key: "applyClientStateLocally",
|
|
139
|
-
value: function applyClientStateLocally(meeting) {
|
|
140
|
-
|
|
221
|
+
value: function applyClientStateLocally(meeting, reason) {
|
|
222
|
+
if (this.sdkOwnsLocalTrack) {
|
|
223
|
+
if (this.type === _constants.AUDIO) {
|
|
224
|
+
var _meeting$mediaPropert5;
|
|
225
|
+
(_meeting$mediaPropert5 = meeting.mediaProperties.audioTrack) === null || _meeting$mediaPropert5 === void 0 ? void 0 : _meeting$mediaPropert5.setMuted(this.state.client.localMute);
|
|
226
|
+
} else {
|
|
227
|
+
var _meeting$mediaPropert6;
|
|
228
|
+
(_meeting$mediaPropert6 = meeting.mediaProperties.videoTrack) === null || _meeting$mediaPropert6 === void 0 ? void 0 : _meeting$mediaPropert6.setMuted(this.state.client.localMute);
|
|
229
|
+
}
|
|
230
|
+
} else {
|
|
231
|
+
this.muteLocalTrack(meeting, this.state.client.localMute, reason);
|
|
232
|
+
}
|
|
141
233
|
}
|
|
234
|
+
|
|
142
235
|
/**
|
|
143
236
|
* Updates the server local and remote mute values so that they match the current client desired state.
|
|
144
237
|
*
|
|
@@ -147,62 +240,53 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
147
240
|
* @memberof MuteState
|
|
148
241
|
* @returns {void}
|
|
149
242
|
*/
|
|
150
|
-
|
|
151
243
|
}, {
|
|
152
244
|
key: "applyClientStateToServer",
|
|
153
245
|
value: function applyClientStateToServer(meeting) {
|
|
154
246
|
var _this2 = this;
|
|
155
|
-
|
|
156
247
|
if (this.state.syncToServerInProgress) {
|
|
157
248
|
_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
249
|
return;
|
|
160
250
|
}
|
|
161
|
-
|
|
162
251
|
var localMuteRequiresSync = this.state.client.localMute !== this.state.server.localMute;
|
|
163
252
|
var remoteMuteRequiresSync = !this.state.client.localMute && this.state.server.remoteMute;
|
|
164
|
-
|
|
165
253
|
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": localMuteRequiresSync: ").concat(localMuteRequiresSync, " (").concat(this.state.client.localMute, " ?= ").concat(this.state.server.localMute, ")"));
|
|
166
|
-
|
|
167
254
|
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": remoteMuteRequiresSync: ").concat(remoteMuteRequiresSync));
|
|
168
|
-
|
|
169
255
|
if (!localMuteRequiresSync && !remoteMuteRequiresSync) {
|
|
170
256
|
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": client state already matching server state, nothing to do"));
|
|
171
|
-
|
|
172
257
|
if (this.pendingPromiseResolve) {
|
|
173
258
|
this.pendingPromiseResolve();
|
|
174
259
|
}
|
|
175
|
-
|
|
176
260
|
this.pendingPromiseResolve = null;
|
|
177
261
|
this.pendingPromiseReject = null;
|
|
178
262
|
return;
|
|
179
263
|
}
|
|
264
|
+
this.state.syncToServerInProgress = true;
|
|
180
265
|
|
|
181
|
-
|
|
182
|
-
|
|
266
|
+
// first sync local mute with server
|
|
183
267
|
var localMuteSyncPromise = localMuteRequiresSync ? this.sendLocalMuteRequestToServer(meeting) : _promise.default.resolve();
|
|
184
268
|
localMuteSyncPromise.then(function () {
|
|
185
|
-
return (
|
|
269
|
+
return (
|
|
270
|
+
// then follow it up with remote mute sync
|
|
186
271
|
remoteMuteRequiresSync ? _this2.sendRemoteMuteRequestToServer(meeting) : _promise.default.resolve()
|
|
187
272
|
);
|
|
188
273
|
}).then(function () {
|
|
189
274
|
_this2.state.syncToServerInProgress = false;
|
|
275
|
+
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(_this2.type, ": sync with server completed"));
|
|
190
276
|
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
277
|
+
// need to check if a new sync is required, because this.state.client may have changed while we were doing the current sync
|
|
194
278
|
_this2.applyClientStateToServer(meeting);
|
|
195
279
|
}).catch(function (e) {
|
|
196
280
|
_this2.state.syncToServerInProgress = false;
|
|
197
|
-
|
|
198
281
|
if (_this2.pendingPromiseReject) {
|
|
199
282
|
_this2.pendingPromiseReject(e);
|
|
200
283
|
}
|
|
201
|
-
|
|
202
284
|
_this2.pendingPromiseResolve = null;
|
|
203
285
|
_this2.pendingPromiseReject = null;
|
|
286
|
+
_this2.applyServerMuteToLocalTrack(meeting, 'clientRequestFailed');
|
|
204
287
|
});
|
|
205
288
|
}
|
|
289
|
+
|
|
206
290
|
/**
|
|
207
291
|
* Sets the local mute value in the server
|
|
208
292
|
*
|
|
@@ -211,31 +295,26 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
211
295
|
* @memberof MuteState
|
|
212
296
|
* @returns {Promise}
|
|
213
297
|
*/
|
|
214
|
-
|
|
215
298
|
}, {
|
|
216
299
|
key: "sendLocalMuteRequestToServer",
|
|
217
300
|
value: function sendLocalMuteRequestToServer(meeting) {
|
|
218
301
|
var _meeting$audio,
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
302
|
+
_meeting$video,
|
|
303
|
+
_this3 = this;
|
|
222
304
|
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
305
|
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
|
-
|
|
225
306
|
_loggerProxy.default.logger.info("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(this.type, ": sending local mute (audio=").concat(audioMuted, ", video=").concat(videoMuted, ") to server"));
|
|
226
|
-
|
|
227
307
|
return _util.default.remoteUpdateAudioVideo(audioMuted, videoMuted, meeting).then(function (locus) {
|
|
228
308
|
_loggerProxy.default.logger.info("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(_this3.type, ": local mute (audio=").concat(audioMuted, ", video=").concat(videoMuted, ") applied to server"));
|
|
229
|
-
|
|
230
309
|
_this3.state.server.localMute = _this3.type === _constants.AUDIO ? audioMuted : videoMuted;
|
|
231
310
|
meeting.locusInfo.onFullLocus(locus);
|
|
232
311
|
return locus;
|
|
233
312
|
}).catch(function (remoteUpdateError) {
|
|
234
313
|
_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));
|
|
235
|
-
|
|
236
314
|
return _promise.default.reject(remoteUpdateError);
|
|
237
315
|
});
|
|
238
316
|
}
|
|
317
|
+
|
|
239
318
|
/**
|
|
240
319
|
* Sets the remote mute value in the server
|
|
241
320
|
*
|
|
@@ -244,50 +323,80 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
244
323
|
* @memberof MuteState
|
|
245
324
|
* @returns {Promise}
|
|
246
325
|
*/
|
|
247
|
-
|
|
248
326
|
}, {
|
|
249
327
|
key: "sendRemoteMuteRequestToServer",
|
|
250
328
|
value: function sendRemoteMuteRequestToServer(meeting) {
|
|
251
329
|
var _this4 = this;
|
|
330
|
+
var remoteMute = this.state.client.localMute;
|
|
331
|
+
_loggerProxy.default.logger.info("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(this.type, ": sending remote mute:").concat(remoteMute, " to server"));
|
|
332
|
+
return meeting.members.muteMember(meeting.members.selfId, remoteMute, this.type === _constants.AUDIO).then(function () {
|
|
333
|
+
_loggerProxy.default.logger.info("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(_this4.type, ": remote mute:").concat(remoteMute, " applied to server"));
|
|
334
|
+
_this4.state.server.remoteMute = remoteMute;
|
|
335
|
+
}).catch(function (remoteUpdateError) {
|
|
336
|
+
_loggerProxy.default.logger.warn("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(_this4.type, ": failed to apply remote mute ").concat(remoteMute, " to server: ").concat(remoteUpdateError));
|
|
337
|
+
return _promise.default.reject(remoteUpdateError);
|
|
338
|
+
});
|
|
339
|
+
}
|
|
252
340
|
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
_loggerProxy.default.logger.warn("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(_this4.type, ": failed to apply remote mute ").concat(remoteMute, " to server: ").concat(remoteUpdateError));
|
|
264
|
-
|
|
265
|
-
return _promise.default.reject(remoteUpdateError);
|
|
266
|
-
});
|
|
267
|
-
} // for now we don't need to support remote muting of video (REMOTE_MUTE_VIDEO_MISSING_IMPLEMENTATION)
|
|
341
|
+
/** Sets the mute state of the local track according to what server thinks is our state
|
|
342
|
+
* @param {Object} meeting - the meeting object
|
|
343
|
+
* @param {ServerMuteReason} serverMuteReason - reason why we're applying server mute to the local track
|
|
344
|
+
* @returns {void}
|
|
345
|
+
*/
|
|
346
|
+
}, {
|
|
347
|
+
key: "applyServerMuteToLocalTrack",
|
|
348
|
+
value: function applyServerMuteToLocalTrack(meeting, serverMuteReason) {
|
|
349
|
+
if (!this.sdkOwnsLocalTrack) {
|
|
350
|
+
var muted = this.state.server.localMute || this.state.server.remoteMute;
|
|
268
351
|
|
|
352
|
+
// update the local track mute state, but not this.state.client.localMute
|
|
353
|
+
this.muteLocalTrack(meeting, muted, serverMuteReason);
|
|
354
|
+
}
|
|
355
|
+
}
|
|
269
356
|
|
|
270
|
-
|
|
271
|
-
|
|
357
|
+
/** Applies the current value for unmute allowed to the underlying track
|
|
358
|
+
*
|
|
359
|
+
* @param {Meeting} meeting
|
|
360
|
+
* @returns {void}
|
|
361
|
+
*/
|
|
362
|
+
}, {
|
|
363
|
+
key: "applyUnmuteAllowedToTrack",
|
|
364
|
+
value: function applyUnmuteAllowedToTrack(meeting) {
|
|
365
|
+
if (!this.sdkOwnsLocalTrack) {
|
|
366
|
+
if (this.type === _constants.AUDIO) {
|
|
367
|
+
var _meeting$mediaPropert7;
|
|
368
|
+
(_meeting$mediaPropert7 = meeting.mediaProperties.audioTrack) === null || _meeting$mediaPropert7 === void 0 ? void 0 : _meeting$mediaPropert7.setUnmuteAllowed(this.state.server.unmuteAllowed);
|
|
369
|
+
} else {
|
|
370
|
+
var _meeting$mediaPropert8;
|
|
371
|
+
(_meeting$mediaPropert8 = meeting.mediaProperties.videoTrack) === null || _meeting$mediaPropert8 === void 0 ? void 0 : _meeting$mediaPropert8.setUnmuteAllowed(this.state.server.unmuteAllowed);
|
|
372
|
+
}
|
|
373
|
+
}
|
|
272
374
|
}
|
|
375
|
+
|
|
273
376
|
/**
|
|
274
377
|
* This method should be called whenever the server remote mute state is changed
|
|
275
378
|
*
|
|
276
379
|
* @public
|
|
277
380
|
* @memberof MuteState
|
|
381
|
+
* @param {Meeting} meeting
|
|
278
382
|
* @param {Boolean} [muted] true if user is remotely muted, false otherwise
|
|
279
383
|
* @param {Boolean} [unmuteAllowed] indicates if user is allowed to unmute self (false when "hard mute" feature is used)
|
|
280
384
|
* @returns {undefined}
|
|
281
385
|
*/
|
|
282
|
-
|
|
283
386
|
}, {
|
|
284
387
|
key: "handleServerRemoteMuteUpdate",
|
|
285
|
-
value: function handleServerRemoteMuteUpdate(muted, unmuteAllowed) {
|
|
388
|
+
value: function handleServerRemoteMuteUpdate(meeting, muted, unmuteAllowed) {
|
|
286
389
|
_loggerProxy.default.logger.info("Meeting:muteState#handleServerRemoteMuteUpdate --> ".concat(this.type, ": updating server remoteMute to (").concat(muted, ")"));
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
390
|
+
if (unmuteAllowed !== undefined) {
|
|
391
|
+
this.state.server.unmuteAllowed = unmuteAllowed;
|
|
392
|
+
this.applyUnmuteAllowedToTrack(meeting);
|
|
393
|
+
}
|
|
394
|
+
if (muted !== undefined) {
|
|
395
|
+
this.state.server.remoteMute = muted;
|
|
396
|
+
this.applyServerMuteToLocalTrack(meeting, 'remotelyMuted');
|
|
397
|
+
}
|
|
290
398
|
}
|
|
399
|
+
|
|
291
400
|
/**
|
|
292
401
|
* This method should be called whenever we receive from the server a requirement to locally unmute
|
|
293
402
|
*
|
|
@@ -296,24 +405,23 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
296
405
|
* @param {Object} [meeting] the meeting object
|
|
297
406
|
* @returns {undefined}
|
|
298
407
|
*/
|
|
299
|
-
|
|
300
408
|
}, {
|
|
301
409
|
key: "handleServerLocalUnmuteRequired",
|
|
302
410
|
value: function handleServerLocalUnmuteRequired(meeting) {
|
|
303
411
|
_loggerProxy.default.logger.info("Meeting:muteState#handleServerLocalUnmuteRequired --> ".concat(this.type, ": localAudioUnmuteRequired received -> doing local unmute"));
|
|
304
412
|
|
|
413
|
+
// 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
414
|
this.state.server.remoteMute = false;
|
|
306
415
|
this.state.client.localMute = false;
|
|
307
|
-
|
|
308
416
|
if (this.pendingPromiseReject) {
|
|
309
417
|
this.pendingPromiseReject(new Error('Server requested local unmute - this overrides any client request in progress'));
|
|
310
418
|
this.pendingPromiseResolve = null;
|
|
311
419
|
this.pendingPromiseReject = null;
|
|
312
420
|
}
|
|
313
|
-
|
|
314
|
-
this.applyClientStateLocally(meeting);
|
|
421
|
+
this.applyClientStateLocally(meeting, 'localUnmuteRequired');
|
|
315
422
|
this.applyClientStateToServer(meeting);
|
|
316
423
|
}
|
|
424
|
+
|
|
317
425
|
/**
|
|
318
426
|
* Returns true if the user is locally or remotely muted
|
|
319
427
|
*
|
|
@@ -321,32 +429,72 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
321
429
|
* @memberof MuteState
|
|
322
430
|
* @returns {Boolean}
|
|
323
431
|
*/
|
|
324
|
-
|
|
325
432
|
}, {
|
|
326
433
|
key: "isMuted",
|
|
327
434
|
value: function isMuted() {
|
|
328
435
|
return this.state.client.localMute || this.state.server.localMute || this.state.server.remoteMute;
|
|
329
436
|
}
|
|
437
|
+
|
|
330
438
|
/**
|
|
331
|
-
* Returns true if the user is
|
|
439
|
+
* Returns true if the user is remotely muted
|
|
440
|
+
*
|
|
441
|
+
* @public
|
|
442
|
+
* @memberof MuteState
|
|
443
|
+
* @returns {Boolean}
|
|
444
|
+
*/
|
|
445
|
+
}, {
|
|
446
|
+
key: "isRemotelyMuted",
|
|
447
|
+
value: function isRemotelyMuted() {
|
|
448
|
+
return this.state.server.remoteMute;
|
|
449
|
+
}
|
|
450
|
+
|
|
451
|
+
/**
|
|
452
|
+
* Returns true if unmute is allowed
|
|
332
453
|
*
|
|
333
454
|
* @public
|
|
334
455
|
* @memberof MuteState
|
|
335
456
|
* @returns {Boolean}
|
|
336
457
|
*/
|
|
458
|
+
}, {
|
|
459
|
+
key: "isUnmuteAllowed",
|
|
460
|
+
value: function isUnmuteAllowed() {
|
|
461
|
+
return this.state.server.unmuteAllowed;
|
|
462
|
+
}
|
|
337
463
|
|
|
464
|
+
/**
|
|
465
|
+
* Returns true if the user is locally muted
|
|
466
|
+
*
|
|
467
|
+
* @public
|
|
468
|
+
* @memberof MuteState
|
|
469
|
+
* @returns {Boolean}
|
|
470
|
+
*/
|
|
471
|
+
}, {
|
|
472
|
+
key: "isLocallyMuted",
|
|
473
|
+
value: function isLocallyMuted() {
|
|
474
|
+
return this.state.client.localMute || this.state.server.localMute;
|
|
475
|
+
}
|
|
476
|
+
|
|
477
|
+
/**
|
|
478
|
+
* Returns true if the user is muted as a result of the client request (and not remotely muted)
|
|
479
|
+
*
|
|
480
|
+
* @public
|
|
481
|
+
* @memberof MuteState
|
|
482
|
+
* @returns {Boolean}
|
|
483
|
+
*/
|
|
338
484
|
}, {
|
|
339
485
|
key: "isSelf",
|
|
340
486
|
value: function isSelf() {
|
|
341
487
|
return this.state.client.localMute && !this.state.server.remoteMute;
|
|
342
|
-
}
|
|
488
|
+
}
|
|
343
489
|
|
|
490
|
+
// defined for backwards compatibility with the old AudioStateMachine/VideoStateMachine classes
|
|
344
491
|
}, {
|
|
345
492
|
key: "muted",
|
|
346
493
|
get: function get() {
|
|
347
494
|
return this.isMuted();
|
|
348
|
-
}
|
|
495
|
+
}
|
|
349
496
|
|
|
497
|
+
// defined for backwards compatibility with the old AudioStateMachine/VideoStateMachine classes
|
|
350
498
|
}, {
|
|
351
499
|
key: "self",
|
|
352
500
|
get: function get() {
|
|
@@ -355,7 +503,4 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
355
503
|
}]);
|
|
356
504
|
return MuteState;
|
|
357
505
|
}();
|
|
358
|
-
|
|
359
|
-
var _default = createMuteState;
|
|
360
|
-
exports.default = _default;
|
|
361
506
|
//# sourceMappingURL=muteState.js.map
|