@webex/plugin-meetings 3.0.0-beta.21 → 3.0.0-beta.211
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 +45 -7
- 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 +114 -14
- package/dist/breakouts/breakout.js.map +1 -1
- 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 +841 -19
- package/dist/breakouts/index.js.map +1 -1
- 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/errors/webex-errors.js +3 -2
- package/dist/common/errors/webex-errors.js.map +1 -1
- package/dist/common/logs/logger-proxy.js +1 -1
- package/dist/common/logs/logger-proxy.js.map +1 -1
- package/dist/common/queue.js +24 -9
- package/dist/common/queue.js.map +1 -1
- package/dist/config.js +3 -8
- package/dist/config.js.map +1 -1
- package/dist/constants.js +179 -30
- 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 +106 -1
- 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 +91 -2
- package/dist/locus-info/controlsUtils.js.map +1 -1
- package/dist/locus-info/index.js +359 -64
- package/dist/locus-info/index.js.map +1 -1
- package/dist/locus-info/infoUtils.js +7 -1
- package/dist/locus-info/infoUtils.js.map +1 -1
- package/dist/locus-info/mediaSharesUtils.js +43 -1
- package/dist/locus-info/mediaSharesUtils.js.map +1 -1
- package/dist/locus-info/parser.js +219 -63
- package/dist/locus-info/parser.js.map +1 -1
- package/dist/locus-info/selfUtils.js +89 -14
- package/dist/locus-info/selfUtils.js.map +1 -1
- package/dist/media/index.js +48 -135
- package/dist/media/index.js.map +1 -1
- package/dist/media/properties.js +29 -90
- package/dist/media/properties.js.map +1 -1
- package/dist/mediaQualityMetrics/config.js +505 -493
- package/dist/mediaQualityMetrics/config.js.map +1 -1
- package/dist/meeting/in-meeting-actions.js +90 -2
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +2770 -2547
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/locusMediaRequest.js +291 -0
- package/dist/meeting/locusMediaRequest.js.map +1 -0
- package/dist/meeting/muteState.js +229 -124
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +199 -193
- package/dist/meeting/request.js.map +1 -1
- package/dist/meeting/util.js +532 -414
- package/dist/meeting/util.js.map +1 -1
- package/dist/meeting-info/index.js +48 -7
- package/dist/meeting-info/index.js.map +1 -1
- package/dist/meeting-info/meeting-info-v2.js +171 -51
- package/dist/meeting-info/meeting-info-v2.js.map +1 -1
- package/dist/meeting-info/utilv2.js +20 -5
- package/dist/meeting-info/utilv2.js.map +1 -1
- package/dist/meetings/collection.js +22 -0
- package/dist/meetings/collection.js.map +1 -1
- package/dist/meetings/index.js +357 -66
- 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 +2 -0
- package/dist/meetings/request.js.map +1 -1
- package/dist/meetings/util.js +88 -1
- package/dist/meetings/util.js.map +1 -1
- package/dist/member/index.js +49 -0
- 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 +121 -25
- package/dist/member/util.js.map +1 -1
- package/dist/members/collection.js +10 -0
- package/dist/members/collection.js.map +1 -1
- package/dist/members/index.js +86 -5
- package/dist/members/index.js.map +1 -1
- package/dist/members/request.js +106 -38
- 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 +316 -233
- package/dist/members/util.js.map +1 -1
- package/dist/metrics/constants.js +3 -5
- package/dist/metrics/constants.js.map +1 -1
- package/dist/metrics/index.js +1 -468
- package/dist/metrics/index.js.map +1 -1
- package/dist/multistream/mediaRequestManager.js +238 -49
- package/dist/multistream/mediaRequestManager.js.map +1 -1
- package/dist/multistream/receiveSlot.js +49 -16
- package/dist/multistream/receiveSlot.js.map +1 -1
- package/dist/multistream/receiveSlotManager.js +52 -34
- package/dist/multistream/receiveSlotManager.js.map +1 -1
- package/dist/multistream/remoteMedia.js +44 -18
- package/dist/multistream/remoteMedia.js.map +1 -1
- package/dist/multistream/remoteMediaGroup.js +60 -3
- package/dist/multistream/remoteMediaGroup.js.map +1 -1
- package/dist/multistream/remoteMediaManager.js +173 -59
- package/dist/multistream/remoteMediaManager.js.map +1 -1
- package/dist/networkQualityMonitor/index.js +4 -2
- package/dist/networkQualityMonitor/index.js.map +1 -1
- package/dist/reachability/index.js +72 -27
- package/dist/reachability/index.js.map +1 -1
- package/dist/reachability/request.js +12 -5
- package/dist/reachability/request.js.map +1 -1
- package/dist/reconnection-manager/index.js +196 -155
- package/dist/reconnection-manager/index.js.map +1 -1
- package/dist/recording-controller/index.js +21 -2
- package/dist/recording-controller/index.js.map +1 -1
- package/dist/recording-controller/util.js +9 -8
- package/dist/recording-controller/util.js.map +1 -1
- package/dist/roap/index.js +21 -29
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +110 -89
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/turnDiscovery.js +93 -36
- 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 -93
- package/dist/statsAnalyzer/global.js.map +1 -1
- package/dist/statsAnalyzer/index.js +326 -311
- package/dist/statsAnalyzer/index.js.map +1 -1
- package/dist/statsAnalyzer/mqaUtil.js +90 -53
- package/dist/statsAnalyzer/mqaUtil.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/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 +34 -0
- package/dist/types/config.d.ts +72 -0
- package/dist/types/constants.d.ts +1020 -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 +271 -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 +1482 -0
- package/dist/types/meeting/locusMediaRequest.d.ts +72 -0
- package/dist/types/meeting/muteState.d.ts +184 -0
- package/dist/types/meeting/request.d.ts +257 -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 +79 -0
- package/dist/types/meeting-info/collection.d.ts +20 -0
- package/dist/types/meeting-info/index.d.ts +62 -0
- package/dist/types/meeting-info/meeting-info-v2.d.ts +122 -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 +159 -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 +24 -0
- package/dist/types/members/util.d.ts +210 -0
- package/dist/types/metrics/constants.d.ts +55 -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 +277 -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 +207 -0
- package/dist/types/recording-controller/util.d.ts +14 -0
- package/dist/types/roap/index.d.ts +77 -0
- package/dist/types/roap/request.d.ts +36 -0
- package/dist/types/roap/turnDiscovery.d.ts +91 -0
- package/dist/types/rtcMetrics/constants.d.ts +4 -0
- package/dist/types/rtcMetrics/index.d.ts +46 -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/package.json +23 -20
- 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 +44 -14
- package/src/breakouts/breakout.ts +87 -9
- package/src/breakouts/edit-lock-error.ts +25 -0
- package/src/breakouts/events.ts +56 -0
- package/src/breakouts/index.ts +710 -10
- package/src/breakouts/request.ts +55 -0
- package/src/breakouts/utils.ts +57 -0
- package/src/common/errors/webex-errors.ts +6 -2
- package/src/common/logs/logger-proxy.ts +1 -1
- package/src/common/queue.ts +22 -8
- package/src/config.ts +2 -7
- package/src/constants.ts +165 -21
- 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 +39 -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 +108 -0
- package/src/locus-info/index.ts +383 -61
- package/src/locus-info/infoUtils.ts +10 -2
- package/src/locus-info/mediaSharesUtils.ts +48 -0
- package/src/locus-info/parser.ts +224 -39
- package/src/locus-info/selfUtils.ts +81 -5
- package/src/media/index.ts +87 -140
- package/src/media/properties.ts +49 -90
- package/src/mediaQualityMetrics/config.ts +379 -377
- package/src/meeting/in-meeting-actions.ts +179 -3
- package/src/meeting/index.ts +2099 -2083
- package/src/meeting/locusMediaRequest.ts +311 -0
- package/src/meeting/muteState.ts +228 -132
- package/src/meeting/request.ts +105 -115
- package/src/meeting/util.ts +511 -397
- package/src/meeting-info/index.ts +54 -8
- package/src/meeting-info/meeting-info-v2.ts +148 -14
- package/src/meeting-info/utilv2.ts +13 -3
- package/src/meetings/collection.ts +20 -0
- package/src/meetings/index.ts +392 -84
- package/src/meetings/meetings.types.ts +12 -0
- package/src/meetings/request.ts +2 -0
- package/src/meetings/util.ts +103 -4
- package/src/member/index.ts +49 -0
- package/src/member/types.ts +38 -0
- package/src/member/util.ts +127 -25
- package/src/members/collection.ts +8 -0
- package/src/members/index.ts +107 -6
- package/src/members/request.ts +97 -17
- package/src/members/types.ts +28 -0
- package/src/members/util.ts +319 -240
- package/src/metrics/constants.ts +2 -4
- package/src/metrics/index.ts +1 -490
- package/src/multistream/mediaRequestManager.ts +289 -79
- package/src/multistream/receiveSlot.ts +55 -18
- package/src/multistream/receiveSlotManager.ts +46 -24
- package/src/multistream/remoteMedia.ts +27 -2
- package/src/multistream/remoteMediaGroup.ts +59 -0
- package/src/multistream/remoteMediaManager.ts +113 -32
- package/src/networkQualityMonitor/index.ts +6 -6
- package/src/reachability/index.ts +62 -15
- package/src/reachability/request.ts +10 -5
- package/src/reconnection-manager/index.ts +68 -43
- package/src/recording-controller/index.ts +20 -3
- package/src/recording-controller/util.ts +26 -9
- package/src/roap/index.ts +21 -30
- package/src/roap/request.ts +101 -95
- package/src/roap/turnDiscovery.ts +47 -25
- package/src/rtcMetrics/constants.ts +3 -0
- package/src/rtcMetrics/index.ts +100 -0
- package/src/statsAnalyzer/global.ts +1 -94
- package/src/statsAnalyzer/index.ts +376 -386
- package/src/statsAnalyzer/mqaUtil.ts +100 -99
- package/test/integration/spec/converged-space-meetings.js +233 -0
- package/test/integration/spec/journey.js +336 -259
- package/test/integration/spec/space-meeting.js +77 -4
- package/test/unit/spec/annotation/index.ts +418 -0
- package/test/unit/spec/breakouts/breakout.ts +142 -24
- 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 +1545 -48
- package/test/unit/spec/breakouts/request.ts +104 -0
- package/test/unit/spec/breakouts/utils.js +72 -0
- 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 +1 -0
- 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 +316 -43
- package/test/unit/spec/locus-info/index.js +1169 -36
- package/test/unit/spec/locus-info/infoUtils.js +37 -15
- package/test/unit/spec/locus-info/mediaSharesUtils.ts +22 -0
- package/test/unit/spec/locus-info/parser.js +62 -22
- package/test/unit/spec/locus-info/selfConstant.js +27 -4
- package/test/unit/spec/locus-info/selfUtils.js +208 -17
- package/test/unit/spec/media/index.ts +138 -28
- package/test/unit/spec/meeting/in-meeting-actions.ts +89 -3
- package/test/unit/spec/meeting/index.js +3573 -1663
- package/test/unit/spec/meeting/locusMediaRequest.ts +438 -0
- package/test/unit/spec/meeting/muteState.js +370 -208
- package/test/unit/spec/meeting/request.js +339 -44
- package/test/unit/spec/meeting/utils.js +456 -53
- package/test/unit/spec/meeting-info/index.js +181 -0
- package/test/unit/spec/meeting-info/meetinginfov2.js +383 -5
- package/test/unit/spec/meeting-info/utilv2.js +21 -0
- package/test/unit/spec/meetings/collection.js +14 -0
- package/test/unit/spec/meetings/index.js +867 -125
- package/test/unit/spec/meetings/utils.js +206 -2
- package/test/unit/spec/member/index.js +58 -4
- package/test/unit/spec/member/util.js +479 -35
- package/test/unit/spec/members/index.js +319 -1
- package/test/unit/spec/members/request.js +206 -27
- package/test/unit/spec/members/utils.js +184 -0
- package/test/unit/spec/metrics/index.js +1 -50
- package/test/unit/spec/multistream/mediaRequestManager.ts +803 -162
- package/test/unit/spec/multistream/receiveSlot.ts +72 -13
- package/test/unit/spec/multistream/receiveSlotManager.ts +58 -28
- package/test/unit/spec/multistream/remoteMedia.ts +30 -0
- package/test/unit/spec/multistream/remoteMediaGroup.ts +266 -0
- package/test/unit/spec/multistream/remoteMediaManager.ts +318 -0
- package/test/unit/spec/networkQualityMonitor/index.js +4 -4
- package/test/unit/spec/reachability/index.ts +125 -8
- package/test/unit/spec/reachability/request.js +66 -0
- package/test/unit/spec/reconnection-manager/index.js +59 -6
- package/test/unit/spec/recording-controller/index.js +294 -218
- package/test/unit/spec/recording-controller/util.js +223 -96
- package/test/unit/spec/roap/index.ts +26 -51
- package/test/unit/spec/roap/request.ts +196 -85
- package/test/unit/spec/roap/turnDiscovery.ts +30 -7
- package/test/unit/spec/rtcMetrics/index.ts +60 -0
- package/test/unit/spec/stats-analyzer/index.js +92 -41
- package/test/utils/constants.js +9 -0
- package/test/utils/integrationTestUtils.js +46 -0
- package/test/utils/testUtils.js +0 -45
- package/test/utils/webex-config.js +4 -0
- package/test/utils/webex-test-users.js +6 -3
- package/dist/meeting/effectsState.js +0 -262
- package/dist/meeting/effectsState.js.map +0 -1
- package/dist/metrics/config.js +0 -299
- package/dist/metrics/config.js.map +0 -1
- package/dist/multistream/multistreamMedia.js +0 -110
- package/dist/multistream/multistreamMedia.js.map +0 -1
- package/src/index.js +0 -16
- package/src/meeting/effectsState.ts +0 -211
- package/src/metrics/config.ts +0 -495
- package/src/multistream/multistreamMedia.ts +0 -97
- package/test/unit/spec/meeting/effectsState.js +0 -285
|
@@ -0,0 +1,297 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _Object$keys2 = require("@babel/runtime-corejs2/core-js/object/keys");
|
|
4
|
+
var _Object$getOwnPropertySymbols = require("@babel/runtime-corejs2/core-js/object/get-own-property-symbols");
|
|
5
|
+
var _Object$getOwnPropertyDescriptor = require("@babel/runtime-corejs2/core-js/object/get-own-property-descriptor");
|
|
6
|
+
var _Object$getOwnPropertyDescriptors = require("@babel/runtime-corejs2/core-js/object/get-own-property-descriptors");
|
|
7
|
+
var _Object$defineProperties = require("@babel/runtime-corejs2/core-js/object/define-properties");
|
|
8
|
+
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
9
|
+
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
|
|
10
|
+
_Object$defineProperty(exports, "__esModule", {
|
|
11
|
+
value: true
|
|
12
|
+
});
|
|
13
|
+
exports.default = void 0;
|
|
14
|
+
var _keys = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/keys"));
|
|
15
|
+
var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
|
|
16
|
+
var _stringify = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/json/stringify"));
|
|
17
|
+
var _entries = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/entries"));
|
|
18
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/slicedToArray"));
|
|
19
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
|
|
20
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
|
|
21
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
|
|
22
|
+
var _camelCase2 = _interopRequireDefault(require("lodash/camelCase"));
|
|
23
|
+
var _permission = _interopRequireDefault(require("../common/errors/permission"));
|
|
24
|
+
var _constants = require("../constants");
|
|
25
|
+
var _loggerProxy = _interopRequireDefault(require("../common/logs/logger-proxy"));
|
|
26
|
+
var _enums = require("./enums");
|
|
27
|
+
var _util = _interopRequireDefault(require("./util"));
|
|
28
|
+
var _constants2 = require("./constants");
|
|
29
|
+
function ownKeys(object, enumerableOnly) { var keys = _Object$keys2(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
30
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
31
|
+
/**
|
|
32
|
+
* docs
|
|
33
|
+
* https://sqbu-github.cisco.com/pages/WebExSquared/locus/guides/mute.html
|
|
34
|
+
* https://confluence-eng-gpk2.cisco.com/conf/display/LOCUS/Hard+Mute+and+Audio+Privacy#HardMuteandAudioPrivacy-SelfMuteonEntry
|
|
35
|
+
* https://confluence-eng-gpk2.cisco.com/conf/pages/viewpage.action?spaceKey=UC&title=WEBEX-124454%3A+UCF%3A+Hard+mute+support+for+Teams+joining+Webex+meeting
|
|
36
|
+
* https://jira-eng-gpk2.cisco.com/jira/browse/SPARK-180867
|
|
37
|
+
* https://jira-eng-gpk2.cisco.com/jira/browse/SPARK-393351
|
|
38
|
+
*/
|
|
39
|
+
/**
|
|
40
|
+
* @description ControlsOptionsManager is responsible for handling the behavior of participant controls when somebody joins a meeting
|
|
41
|
+
* @export
|
|
42
|
+
* @private
|
|
43
|
+
* @class Recording
|
|
44
|
+
*/
|
|
45
|
+
var ControlsOptionsManager = /*#__PURE__*/function () {
|
|
46
|
+
/**
|
|
47
|
+
* @instance
|
|
48
|
+
* @type {MeetingRequest}
|
|
49
|
+
* @private
|
|
50
|
+
* @memberof ControlsOptionsManager
|
|
51
|
+
*/
|
|
52
|
+
|
|
53
|
+
/**
|
|
54
|
+
* @instance
|
|
55
|
+
* @type {Array}
|
|
56
|
+
* @private
|
|
57
|
+
* @memberof ControlsOptionsManager
|
|
58
|
+
*/
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* @instance
|
|
62
|
+
* @type {string}
|
|
63
|
+
* @private
|
|
64
|
+
* @memberof ControlsOptionsManager
|
|
65
|
+
*/
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* @param {MeetingRequest} request
|
|
69
|
+
* @param {Object} options
|
|
70
|
+
* @constructor
|
|
71
|
+
* @memberof ControlsOptionsManager
|
|
72
|
+
*/
|
|
73
|
+
function ControlsOptionsManager(request, options) {
|
|
74
|
+
(0, _classCallCheck2.default)(this, ControlsOptionsManager);
|
|
75
|
+
(0, _defineProperty2.default)(this, "request", void 0);
|
|
76
|
+
(0, _defineProperty2.default)(this, "displayHints", []);
|
|
77
|
+
(0, _defineProperty2.default)(this, "locusUrl", void 0);
|
|
78
|
+
this.initialize(request);
|
|
79
|
+
this.set(options);
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* @param {MeetingRequest} request
|
|
84
|
+
* @returns {void}
|
|
85
|
+
* @private
|
|
86
|
+
* @memberof ControlsOptionsManager
|
|
87
|
+
*/
|
|
88
|
+
(0, _createClass2.default)(ControlsOptionsManager, [{
|
|
89
|
+
key: "initialize",
|
|
90
|
+
value: function initialize(request) {
|
|
91
|
+
this.request = request;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
/**
|
|
95
|
+
* @param {Object} options
|
|
96
|
+
* @returns {void}
|
|
97
|
+
* @public
|
|
98
|
+
* @memberof ControlsOptionsManager
|
|
99
|
+
*/
|
|
100
|
+
}, {
|
|
101
|
+
key: "set",
|
|
102
|
+
value: function set(options) {
|
|
103
|
+
this.extract(options);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* @param {string} url
|
|
108
|
+
* @returns {void}
|
|
109
|
+
* @public
|
|
110
|
+
* @memberof ControlsOptionsManager
|
|
111
|
+
*/
|
|
112
|
+
}, {
|
|
113
|
+
key: "setLocusUrl",
|
|
114
|
+
value: function setLocusUrl(url) {
|
|
115
|
+
this.locusUrl = url;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
/**
|
|
119
|
+
* @param {Array} hints
|
|
120
|
+
* @returns {void}
|
|
121
|
+
* @public
|
|
122
|
+
* @memberof ControlsOptionsManager
|
|
123
|
+
*/
|
|
124
|
+
}, {
|
|
125
|
+
key: "setDisplayHints",
|
|
126
|
+
value: function setDisplayHints(hints) {
|
|
127
|
+
this.displayHints = hints;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
/**
|
|
131
|
+
* @returns {string}
|
|
132
|
+
* @public
|
|
133
|
+
* @memberof ControlsOptionsManager
|
|
134
|
+
*/
|
|
135
|
+
}, {
|
|
136
|
+
key: "getLocusUrl",
|
|
137
|
+
value: function getLocusUrl() {
|
|
138
|
+
return this.locusUrl;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
/**
|
|
142
|
+
* @returns {Array}
|
|
143
|
+
* @public
|
|
144
|
+
* @memberof ControlsOptionsManager
|
|
145
|
+
*/
|
|
146
|
+
}, {
|
|
147
|
+
key: "getDisplayHints",
|
|
148
|
+
value: function getDisplayHints() {
|
|
149
|
+
return this.displayHints;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
/**
|
|
153
|
+
* @param {Object} options
|
|
154
|
+
* @returns {void}
|
|
155
|
+
* @private
|
|
156
|
+
* @memberof ControlsOptionsManager
|
|
157
|
+
*/
|
|
158
|
+
}, {
|
|
159
|
+
key: "extract",
|
|
160
|
+
value: function extract(options) {
|
|
161
|
+
this.setDisplayHints(options === null || options === void 0 ? void 0 : options.displayHints);
|
|
162
|
+
this.setLocusUrl(options === null || options === void 0 ? void 0 : options.locusUrl);
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
/**
|
|
166
|
+
* Set controls for this meeting.
|
|
167
|
+
*
|
|
168
|
+
* @param {Array<ControlConfig>} controls - Spread Array of ControlConfigs
|
|
169
|
+
* @returns {Promise<Array<any>>}- Promise resolving if the request was successful.
|
|
170
|
+
*/
|
|
171
|
+
}, {
|
|
172
|
+
key: "update",
|
|
173
|
+
value: function update() {
|
|
174
|
+
var _this = this;
|
|
175
|
+
for (var _len = arguments.length, controls = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
176
|
+
controls[_key] = arguments[_key];
|
|
177
|
+
}
|
|
178
|
+
var payloads = controls.map(function (control) {
|
|
179
|
+
if (!(0, _keys.default)(_enums.Control).includes(control.scope)) {
|
|
180
|
+
throw new Error("updating meeting control scope \"".concat(control.scope, "\" is not a supported scope"));
|
|
181
|
+
}
|
|
182
|
+
if (!_util.default.canUpdate(control, _this.displayHints)) {
|
|
183
|
+
throw new _permission.default("updating meeting control scope \"".concat(control.scope, "\" not allowed, due to moderator property."));
|
|
184
|
+
}
|
|
185
|
+
return (0, _defineProperty2.default)({}, control.scope, control.properties);
|
|
186
|
+
});
|
|
187
|
+
return payloads.reduce(function (previous, payload) {
|
|
188
|
+
return previous.then(function () {
|
|
189
|
+
return (
|
|
190
|
+
// @ts-ignore
|
|
191
|
+
_this.request.request({
|
|
192
|
+
uri: "".concat(_this.locusUrl, "/").concat(_constants.CONTROLS),
|
|
193
|
+
body: payload,
|
|
194
|
+
method: _constants.HTTP_VERBS.PATCH
|
|
195
|
+
})
|
|
196
|
+
);
|
|
197
|
+
});
|
|
198
|
+
}, _promise.default.resolve());
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
/**
|
|
202
|
+
* @param {Setting} setting
|
|
203
|
+
* @private
|
|
204
|
+
* @memberof ControlsOptionsManager
|
|
205
|
+
* @returns {Promise}
|
|
206
|
+
*/
|
|
207
|
+
}, {
|
|
208
|
+
key: "setControls",
|
|
209
|
+
value: function setControls(setting) {
|
|
210
|
+
var _this2 = this;
|
|
211
|
+
_loggerProxy.default.logger.log("ControlsOptionsManager:index#setControls --> ".concat((0, _stringify.default)(setting)));
|
|
212
|
+
var body = {};
|
|
213
|
+
var error;
|
|
214
|
+
var shouldSkipCheckToMergeBody = false;
|
|
215
|
+
(0, _entries.default)(setting).forEach(function (_ref2) {
|
|
216
|
+
var _ref3 = (0, _slicedToArray2.default)(_ref2, 2),
|
|
217
|
+
key = _ref3[0],
|
|
218
|
+
value = _ref3[1];
|
|
219
|
+
if (!shouldSkipCheckToMergeBody && !(_util.default !== null && _util.default !== void 0 && _util.default["".concat(value ? _constants2.CAN_SET : _constants2.CAN_UNSET).concat(key)](_this2.displayHints))) {
|
|
220
|
+
error = new _permission.default("".concat(key, " [").concat(value, "] not allowed, due to moderator property."));
|
|
221
|
+
}
|
|
222
|
+
if (error) {
|
|
223
|
+
return;
|
|
224
|
+
}
|
|
225
|
+
switch (key) {
|
|
226
|
+
case _enums.Setting.muted:
|
|
227
|
+
shouldSkipCheckToMergeBody = true;
|
|
228
|
+
body.audio = body.audio ? _objectSpread(_objectSpread({}, body.audio), {}, (0, _defineProperty2.default)({}, (0, _camelCase2.default)(key), value)) : (0, _defineProperty2.default)({}, (0, _camelCase2.default)(key), value);
|
|
229
|
+
break;
|
|
230
|
+
case _enums.Setting.disallowUnmute:
|
|
231
|
+
case _enums.Setting.muteOnEntry:
|
|
232
|
+
if ((0, _keys.default)(setting).includes(_enums.Setting.muted)) {
|
|
233
|
+
body.audio = body.audio ? _objectSpread(_objectSpread({}, body.audio), {}, (0, _defineProperty2.default)({}, (0, _camelCase2.default)(key), value)) : (0, _defineProperty2.default)({}, (0, _camelCase2.default)(key), value);
|
|
234
|
+
body.audio[(0, _camelCase2.default)(key)] = value;
|
|
235
|
+
} else {
|
|
236
|
+
body[(0, _camelCase2.default)(key)] = (0, _defineProperty2.default)({}, _constants2.ENABLED, value);
|
|
237
|
+
}
|
|
238
|
+
break;
|
|
239
|
+
default:
|
|
240
|
+
error = new _permission.default("".concat(key, " [").concat(value, "] not allowed, due to moderator property."));
|
|
241
|
+
}
|
|
242
|
+
});
|
|
243
|
+
if (error) {
|
|
244
|
+
return _promise.default.reject(error);
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
// @ts-ignore
|
|
248
|
+
return this.request.request({
|
|
249
|
+
uri: "".concat(this.locusUrl, "/").concat(_constants.CONTROLS),
|
|
250
|
+
body: body,
|
|
251
|
+
method: _constants.HTTP_VERBS.PATCH
|
|
252
|
+
});
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
/**
|
|
256
|
+
* @public
|
|
257
|
+
* @param {boolean} enabled
|
|
258
|
+
* @memberof ControlsOptionsManager
|
|
259
|
+
* @returns {Promise}
|
|
260
|
+
*/
|
|
261
|
+
}, {
|
|
262
|
+
key: "setMuteOnEntry",
|
|
263
|
+
value: function setMuteOnEntry(enabled) {
|
|
264
|
+
return this.setControls((0, _defineProperty2.default)({}, _enums.Setting.muteOnEntry, enabled));
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
/**
|
|
268
|
+
* @public
|
|
269
|
+
* @param {boolean} enabled
|
|
270
|
+
* @memberof ControlsOptionsManager
|
|
271
|
+
* @returns {Promise}
|
|
272
|
+
*/
|
|
273
|
+
}, {
|
|
274
|
+
key: "setDisallowUnmute",
|
|
275
|
+
value: function setDisallowUnmute(enabled) {
|
|
276
|
+
return this.setControls((0, _defineProperty2.default)({}, _enums.Setting.disallowUnmute, enabled));
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
/**
|
|
280
|
+
* @public
|
|
281
|
+
* @param {boolean} mutedEnabled
|
|
282
|
+
* @param {boolean} disallowUnmuteEnabled
|
|
283
|
+
* @param {boolean} muteOnEntryEnabled
|
|
284
|
+
* @memberof ControlsOptionsManager
|
|
285
|
+
* @returns {Promise}
|
|
286
|
+
*/
|
|
287
|
+
}, {
|
|
288
|
+
key: "setMuteAll",
|
|
289
|
+
value: function setMuteAll(mutedEnabled, disallowUnmuteEnabled, muteOnEntryEnabled) {
|
|
290
|
+
var _this$setControls3;
|
|
291
|
+
return this.setControls((_this$setControls3 = {}, (0, _defineProperty2.default)(_this$setControls3, _enums.Setting.muted, mutedEnabled), (0, _defineProperty2.default)(_this$setControls3, _enums.Setting.disallowUnmute, disallowUnmuteEnabled), (0, _defineProperty2.default)(_this$setControls3, _enums.Setting.muteOnEntry, muteOnEntryEnabled), _this$setControls3));
|
|
292
|
+
}
|
|
293
|
+
}]);
|
|
294
|
+
return ControlsOptionsManager;
|
|
295
|
+
}();
|
|
296
|
+
exports.default = ControlsOptionsManager;
|
|
297
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["ControlsOptionsManager","request","options","initialize","set","extract","url","locusUrl","hints","displayHints","setDisplayHints","setLocusUrl","controls","payloads","map","control","Control","includes","scope","Error","Util","canUpdate","PermissionError","properties","reduce","previous","payload","then","uri","CONTROLS","body","method","HTTP_VERBS","PATCH","resolve","setting","LoggerProxy","logger","log","error","shouldSkipCheckToMergeBody","forEach","key","value","CAN_SET","CAN_UNSET","Setting","muted","audio","disallowUnmute","muteOnEntry","ENABLED","reject","enabled","setControls","mutedEnabled","disallowUnmuteEnabled","muteOnEntryEnabled"],"sources":["index.ts"],"sourcesContent":["import {camelCase} from 'lodash';\nimport PermissionError from '../common/errors/permission';\nimport {CONTROLS, HTTP_VERBS} from '../constants';\nimport MeetingRequest from '../meeting/request';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport {Control, Setting} from './enums';\nimport {ControlConfig} from './types';\nimport Util from './util';\nimport {CAN_SET, CAN_UNSET, ENABLED} from './constants';\n\n/**\n * docs\n * https://sqbu-github.cisco.com/pages/WebExSquared/locus/guides/mute.html\n * https://confluence-eng-gpk2.cisco.com/conf/display/LOCUS/Hard+Mute+and+Audio+Privacy#HardMuteandAudioPrivacy-SelfMuteonEntry\n * https://confluence-eng-gpk2.cisco.com/conf/pages/viewpage.action?spaceKey=UC&title=WEBEX-124454%3A+UCF%3A+Hard+mute+support+for+Teams+joining+Webex+meeting\n * https://jira-eng-gpk2.cisco.com/jira/browse/SPARK-180867\n * https://jira-eng-gpk2.cisco.com/jira/browse/SPARK-393351\n */\n\n/**\n * @description ControlsOptionsManager is responsible for handling the behavior of participant controls when somebody joins a meeting\n * @export\n * @private\n * @class Recording\n */\nexport default class ControlsOptionsManager {\n /**\n * @instance\n * @type {MeetingRequest}\n * @private\n * @memberof ControlsOptionsManager\n */\n private request: MeetingRequest;\n\n /**\n * @instance\n * @type {Array}\n * @private\n * @memberof ControlsOptionsManager\n */\n private displayHints: Array<string> = [];\n\n /**\n * @instance\n * @type {string}\n * @private\n * @memberof ControlsOptionsManager\n */\n private locusUrl: string;\n\n /**\n * @param {MeetingRequest} request\n * @param {Object} options\n * @constructor\n * @memberof ControlsOptionsManager\n */\n constructor(\n request: MeetingRequest,\n options?: {\n locusUrl: string;\n displayHints?: Array<string>;\n }\n ) {\n this.initialize(request);\n this.set(options);\n }\n\n /**\n * @param {MeetingRequest} request\n * @returns {void}\n * @private\n * @memberof ControlsOptionsManager\n */\n private initialize(request: MeetingRequest) {\n this.request = request;\n }\n\n /**\n * @param {Object} options\n * @returns {void}\n * @public\n * @memberof ControlsOptionsManager\n */\n public set(options?: {locusUrl: string; displayHints?: Array<string>}) {\n this.extract(options);\n }\n\n /**\n * @param {string} url\n * @returns {void}\n * @public\n * @memberof ControlsOptionsManager\n */\n public setLocusUrl(url: string) {\n this.locusUrl = url;\n }\n\n /**\n * @param {Array} hints\n * @returns {void}\n * @public\n * @memberof ControlsOptionsManager\n */\n public setDisplayHints(hints: Array<string>) {\n this.displayHints = hints;\n }\n\n /**\n * @returns {string}\n * @public\n * @memberof ControlsOptionsManager\n */\n public getLocusUrl() {\n return this.locusUrl;\n }\n\n /**\n * @returns {Array}\n * @public\n * @memberof ControlsOptionsManager\n */\n public getDisplayHints() {\n return this.displayHints;\n }\n\n /**\n * @param {Object} options\n * @returns {void}\n * @private\n * @memberof ControlsOptionsManager\n */\n private extract(options?: {locusUrl: string; displayHints?: Array<string>}) {\n this.setDisplayHints(options?.displayHints);\n this.setLocusUrl(options?.locusUrl);\n }\n\n /**\n * Set controls for this meeting.\n *\n * @param {Array<ControlConfig>} controls - Spread Array of ControlConfigs\n * @returns {Promise<Array<any>>}- Promise resolving if the request was successful.\n */\n public update(...controls: Array<ControlConfig>) {\n const payloads = controls.map((control) => {\n if (!Object.keys(Control).includes(control.scope)) {\n throw new Error(\n `updating meeting control scope \"${control.scope}\" is not a supported scope`\n );\n }\n\n if (!Util.canUpdate(control, this.displayHints)) {\n throw new PermissionError(\n `updating meeting control scope \"${control.scope}\" not allowed, due to moderator property.`\n );\n }\n\n return {\n [control.scope]: control.properties,\n };\n });\n\n return payloads.reduce((previous, payload) => {\n return previous.then(() =>\n // @ts-ignore\n this.request.request({\n uri: `${this.locusUrl}/${CONTROLS}`,\n body: payload,\n method: HTTP_VERBS.PATCH,\n })\n );\n }, Promise.resolve());\n }\n\n /**\n * @param {Setting} setting\n * @private\n * @memberof ControlsOptionsManager\n * @returns {Promise}\n */\n private setControls(setting: {[key in Setting]?: boolean}): Promise<any> {\n LoggerProxy.logger.log(\n `ControlsOptionsManager:index#setControls --> ${JSON.stringify(setting)}`\n );\n\n const body: Record<string, any> = {};\n let error: PermissionError;\n\n let shouldSkipCheckToMergeBody = false;\n\n Object.entries(setting).forEach(([key, value]) => {\n if (\n !shouldSkipCheckToMergeBody &&\n !Util?.[`${value ? CAN_SET : CAN_UNSET}${key}`](this.displayHints)\n ) {\n error = new PermissionError(`${key} [${value}] not allowed, due to moderator property.`);\n }\n\n if (error) {\n return;\n }\n\n switch (key) {\n case Setting.muted:\n shouldSkipCheckToMergeBody = true;\n body.audio = body.audio\n ? {...body.audio, [camelCase(key)]: value}\n : {[camelCase(key)]: value};\n break;\n\n case Setting.disallowUnmute:\n case Setting.muteOnEntry:\n if (Object.keys(setting).includes(Setting.muted)) {\n body.audio = body.audio\n ? {...body.audio, [camelCase(key)]: value}\n : {[camelCase(key)]: value};\n body.audio[camelCase(key)] = value;\n } else {\n body[camelCase(key)] = {[ENABLED]: value};\n }\n break;\n\n default:\n error = new PermissionError(`${key} [${value}] not allowed, due to moderator property.`);\n }\n });\n\n if (error) {\n return Promise.reject(error);\n }\n\n // @ts-ignore\n return this.request.request({\n uri: `${this.locusUrl}/${CONTROLS}`,\n body,\n method: HTTP_VERBS.PATCH,\n });\n }\n\n /**\n * @public\n * @param {boolean} enabled\n * @memberof ControlsOptionsManager\n * @returns {Promise}\n */\n public setMuteOnEntry(enabled: boolean): Promise<any> {\n return this.setControls({[Setting.muteOnEntry]: enabled});\n }\n\n /**\n * @public\n * @param {boolean} enabled\n * @memberof ControlsOptionsManager\n * @returns {Promise}\n */\n public setDisallowUnmute(enabled: boolean): Promise<any> {\n return this.setControls({[Setting.disallowUnmute]: enabled});\n }\n\n /**\n * @public\n * @param {boolean} mutedEnabled\n * @param {boolean} disallowUnmuteEnabled\n * @param {boolean} muteOnEntryEnabled\n * @memberof ControlsOptionsManager\n * @returns {Promise}\n */\n public setMuteAll(\n mutedEnabled: boolean,\n disallowUnmuteEnabled: boolean,\n muteOnEntryEnabled: boolean\n ): Promise<any> {\n return this.setControls({\n [Setting.muted]: mutedEnabled,\n [Setting.disallowUnmute]: disallowUnmuteEnabled,\n [Setting.muteOnEntry]: muteOnEntryEnabled,\n });\n }\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["import {Control} from './enums';\n\nexport interface ControlProperties {\n /**\n * A list of additional properties that apply to various specific settings.\n *\n * @remarks\n * The values stored here, per the service, are fully ambiguous, an can vary\n * depending on which control scope is being configured.\n */\n [key: string]: boolean;\n}\n\nexport interface AudioProperties {\n muted?: boolean;\n disallowUnmute?: boolean;\n muteOnEntry?: boolean;\n}\n\nexport interface RaiseHandProperties {\n enabled?: boolean;\n}\n\nexport interface ReactionsProperties {\n enabled?: boolean;\n showDisplayNameWithReactions?: boolean;\n}\n\nexport interface ShareControlProperties {\n control?: 'ANYONE' | 'MODERATOR_PRESENTER';\n}\n\nexport interface VideoProperties {\n enabled?: boolean;\n}\n\nexport interface ViewTheParticipantListProperties {\n enabled?: boolean;\n}\n\nexport type Properties =\n | AudioProperties\n | RaiseHandProperties\n | ReactionsProperties\n | ShareControlProperties\n | VideoProperties\n | ViewTheParticipantListProperties;\n\nexport interface ControlConfig<Props = Properties> {\n /**\n * The scope of the control within this object.\n */\n scope: Control;\n\n /**\n * The properties to assign to this control.\n */\n properties: Props;\n}\n"],"mappings":""}
|
|
@@ -0,0 +1,319 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
4
|
+
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
|
|
5
|
+
_Object$defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = void 0;
|
|
9
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
|
|
10
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
|
|
11
|
+
var _constants = require("../constants");
|
|
12
|
+
var _enums = require("./enums");
|
|
13
|
+
/**
|
|
14
|
+
* The Controls Options Manager utilities
|
|
15
|
+
*
|
|
16
|
+
* @internal
|
|
17
|
+
*/
|
|
18
|
+
var Utils = /*#__PURE__*/function () {
|
|
19
|
+
function Utils() {
|
|
20
|
+
(0, _classCallCheck2.default)(this, Utils);
|
|
21
|
+
}
|
|
22
|
+
(0, _createClass2.default)(Utils, null, [{
|
|
23
|
+
key: "canSetMuteOnEntry",
|
|
24
|
+
value:
|
|
25
|
+
/**
|
|
26
|
+
* Validate if enabling mute on entry can be set.
|
|
27
|
+
*
|
|
28
|
+
* @param {Array<string>} displayHints - Display Hints to use when validating.
|
|
29
|
+
* @returns {boolean} - True if the action is allowed.
|
|
30
|
+
*/
|
|
31
|
+
function canSetMuteOnEntry(displayHints) {
|
|
32
|
+
return displayHints.includes(_constants.DISPLAY_HINTS.ENABLE_MUTE_ON_ENTRY);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Validate if allowing unmuting can be set.
|
|
37
|
+
*
|
|
38
|
+
* @param {Array<string>} displayHints - Display Hints to use when validating.
|
|
39
|
+
* @returns {boolean} - True if the action is allowed.
|
|
40
|
+
*/
|
|
41
|
+
}, {
|
|
42
|
+
key: "canSetDisallowUnmute",
|
|
43
|
+
value: function canSetDisallowUnmute(displayHints) {
|
|
44
|
+
return displayHints.includes(_constants.DISPLAY_HINTS.ENABLE_HARD_MUTE);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* Validate if disabling mute on entry can be set.
|
|
49
|
+
*
|
|
50
|
+
* @param {Array<string>} displayHints - Display Hints to use when validating.
|
|
51
|
+
* @returns {boolean} - True if the action is allowed.
|
|
52
|
+
*/
|
|
53
|
+
}, {
|
|
54
|
+
key: "canUnsetMuteOnEntry",
|
|
55
|
+
value: function canUnsetMuteOnEntry(displayHints) {
|
|
56
|
+
return displayHints.includes(_constants.DISPLAY_HINTS.DISABLE_MUTE_ON_ENTRY);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* Validate if enabling muting can be set.
|
|
61
|
+
*
|
|
62
|
+
* @param {Array<string>} displayHints - Display Hints to use when validating.
|
|
63
|
+
* @returns {boolean} - True if the action is allowed.
|
|
64
|
+
*/
|
|
65
|
+
}, {
|
|
66
|
+
key: "canUnsetDisallowUnmute",
|
|
67
|
+
value: function canUnsetDisallowUnmute(displayHints) {
|
|
68
|
+
return displayHints.includes(_constants.DISPLAY_HINTS.DISABLE_HARD_MUTE);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
/**
|
|
72
|
+
* Validate if muting all can be set.
|
|
73
|
+
*
|
|
74
|
+
* @param {Array<string>} displayHints - Display Hints to use when validating.
|
|
75
|
+
* @returns {boolean} - True if the action is allowed.
|
|
76
|
+
*/
|
|
77
|
+
}, {
|
|
78
|
+
key: "canSetMuted",
|
|
79
|
+
value: function canSetMuted(displayHints) {
|
|
80
|
+
return displayHints.includes(_constants.DISPLAY_HINTS.MUTE_ALL);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
/**
|
|
84
|
+
* Validate if unmuting all can be set.
|
|
85
|
+
*
|
|
86
|
+
* @param {Array<string>} displayHints - Display Hints to use when validating.
|
|
87
|
+
* @returns {boolean} - True if the action is allowed.
|
|
88
|
+
*/
|
|
89
|
+
}, {
|
|
90
|
+
key: "canUnsetMuted",
|
|
91
|
+
value: function canUnsetMuted(displayHints) {
|
|
92
|
+
return displayHints.includes(_constants.DISPLAY_HINTS.UNMUTE_ALL);
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* Validate an array of hints are allowed based on a full collection of hints.
|
|
97
|
+
*
|
|
98
|
+
* @param {Object} config - Configuration Object.
|
|
99
|
+
* @param {Array<string>} config.requiredHints - Hints required for validation.
|
|
100
|
+
* @param {Array<string>} config.displayHints - All available hints.
|
|
101
|
+
* @returns {boolean} - True if all of the actions are allowed.
|
|
102
|
+
*/
|
|
103
|
+
}, {
|
|
104
|
+
key: "hasHints",
|
|
105
|
+
value: function hasHints(config) {
|
|
106
|
+
var requiredHints = config.requiredHints,
|
|
107
|
+
displayHints = config.displayHints;
|
|
108
|
+
return requiredHints.every(function (hint) {
|
|
109
|
+
return displayHints.includes(hint);
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
/**
|
|
114
|
+
* Validate that the self policy object contains the required policies.
|
|
115
|
+
*
|
|
116
|
+
* @param {Object} config - Configuration Object.
|
|
117
|
+
* @param {Array<string>} config.requiredPolicies - Policies required for validation.
|
|
118
|
+
* @param {Array<string>} config.policies - All available policies.
|
|
119
|
+
* @returns {boolean} - True if all of the actions are allowed.
|
|
120
|
+
*/
|
|
121
|
+
}, {
|
|
122
|
+
key: "hasPolicies",
|
|
123
|
+
value: function hasPolicies(config) {
|
|
124
|
+
var requiredPolicies = config.requiredPolicies,
|
|
125
|
+
_config$policies = config.policies,
|
|
126
|
+
policies = _config$policies === void 0 ? {} : _config$policies;
|
|
127
|
+
return requiredPolicies.every(function (hint) {
|
|
128
|
+
return policies[hint];
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/**
|
|
133
|
+
* Validate if an audio-scoped control is allowed to be sent to the service.
|
|
134
|
+
*
|
|
135
|
+
* @param {ControlConfig<AudioProperties>} control - Audio control config to validate.
|
|
136
|
+
* @param {Array<string>} displayHints - All available hints.
|
|
137
|
+
* @returns {boolean} - True if all of the actions are allowed.
|
|
138
|
+
*/
|
|
139
|
+
}, {
|
|
140
|
+
key: "canUpdateAudio",
|
|
141
|
+
value: function canUpdateAudio(control, displayHints) {
|
|
142
|
+
var requiredHints = [];
|
|
143
|
+
if (control.properties.muted === true) {
|
|
144
|
+
requiredHints.push(_constants.DISPLAY_HINTS.MUTE_ALL);
|
|
145
|
+
}
|
|
146
|
+
if (control.properties.muted === false) {
|
|
147
|
+
requiredHints.push(_constants.DISPLAY_HINTS.UNMUTE_ALL);
|
|
148
|
+
}
|
|
149
|
+
if (control.properties.disallowUnmute === true) {
|
|
150
|
+
requiredHints.push(_constants.DISPLAY_HINTS.ENABLE_HARD_MUTE);
|
|
151
|
+
}
|
|
152
|
+
if (control.properties.disallowUnmute === false) {
|
|
153
|
+
requiredHints.push(_constants.DISPLAY_HINTS.DISABLE_HARD_MUTE);
|
|
154
|
+
}
|
|
155
|
+
if (control.properties.muteOnEntry === true) {
|
|
156
|
+
requiredHints.push(_constants.DISPLAY_HINTS.ENABLE_MUTE_ON_ENTRY);
|
|
157
|
+
}
|
|
158
|
+
if (control.properties.muteOnEntry === false) {
|
|
159
|
+
requiredHints.push(_constants.DISPLAY_HINTS.DISABLE_MUTE_ON_ENTRY);
|
|
160
|
+
}
|
|
161
|
+
return Utils.hasHints({
|
|
162
|
+
requiredHints: requiredHints,
|
|
163
|
+
displayHints: displayHints
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
}, {
|
|
167
|
+
key: "canUpdateRaiseHand",
|
|
168
|
+
value: function canUpdateRaiseHand(control, displayHints) {
|
|
169
|
+
var requiredHints = [];
|
|
170
|
+
if (control.properties.enabled === true) {
|
|
171
|
+
requiredHints.push(_constants.DISPLAY_HINTS.ENABLE_RAISE_HAND);
|
|
172
|
+
}
|
|
173
|
+
if (control.properties.enabled === false) {
|
|
174
|
+
requiredHints.push(_constants.DISPLAY_HINTS.DISABLE_RAISE_HAND);
|
|
175
|
+
}
|
|
176
|
+
return Utils.hasHints({
|
|
177
|
+
requiredHints: requiredHints,
|
|
178
|
+
displayHints: displayHints
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
/**
|
|
183
|
+
* Validate if an reactions-scoped control is allowed to be sent to the service.
|
|
184
|
+
*
|
|
185
|
+
* @param {ControlConfig<ReactionsProperties>} control - Reaction control config to validate.
|
|
186
|
+
* @param {Array<string>} displayHints - All available hints.
|
|
187
|
+
* @returns {boolean} - True if all of the actions are allowed.
|
|
188
|
+
*/
|
|
189
|
+
}, {
|
|
190
|
+
key: "canUpdateReactions",
|
|
191
|
+
value: function canUpdateReactions(control, displayHints) {
|
|
192
|
+
var requiredHints = [];
|
|
193
|
+
|
|
194
|
+
// This additional if statement avoids the display hint discrepency due to
|
|
195
|
+
// the service blocking partial requests with this property only.
|
|
196
|
+
if (control.properties.showDisplayNameWithReactions !== undefined) {
|
|
197
|
+
if (control.properties.showDisplayNameWithReactions === true) {
|
|
198
|
+
requiredHints.push(_constants.DISPLAY_HINTS.ENABLE_SHOW_DISPLAY_NAME);
|
|
199
|
+
}
|
|
200
|
+
if (control.properties.showDisplayNameWithReactions === false) {
|
|
201
|
+
requiredHints.push(_constants.DISPLAY_HINTS.DISABLE_SHOW_DISPLAY_NAME);
|
|
202
|
+
}
|
|
203
|
+
} else {
|
|
204
|
+
if (control.properties.enabled === true) {
|
|
205
|
+
requiredHints.push(_constants.DISPLAY_HINTS.ENABLE_REACTIONS);
|
|
206
|
+
}
|
|
207
|
+
if (control.properties.enabled === false) {
|
|
208
|
+
requiredHints.push(_constants.DISPLAY_HINTS.DISABLE_REACTIONS);
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
return Utils.hasHints({
|
|
212
|
+
requiredHints: requiredHints,
|
|
213
|
+
displayHints: displayHints
|
|
214
|
+
});
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
/**
|
|
218
|
+
* Validate if an share-control-scoped control is allowed to be sent to the service.
|
|
219
|
+
*
|
|
220
|
+
* @param {Array<string>} displayHints - All available hints.
|
|
221
|
+
* @returns {boolean} - True if all of the actions are allowed.
|
|
222
|
+
*/
|
|
223
|
+
}, {
|
|
224
|
+
key: "canUpdateShareControl",
|
|
225
|
+
value: function canUpdateShareControl(displayHints) {
|
|
226
|
+
return Utils.hasHints({
|
|
227
|
+
requiredHints: [_constants.DISPLAY_HINTS.SHARE_CONTROL],
|
|
228
|
+
displayHints: displayHints
|
|
229
|
+
});
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
/**
|
|
233
|
+
* Validate if an view-the-participants-list-scoped control is allowed to be sent to the service.
|
|
234
|
+
*
|
|
235
|
+
* @param {ControlConfig<ViewTheParticipantListProperties>} control - View Participants List control config to validate.
|
|
236
|
+
* @param {Array<string>} displayHints - All available hints.
|
|
237
|
+
* @returns {boolean} - True if all of the actions are allowed.
|
|
238
|
+
*/
|
|
239
|
+
}, {
|
|
240
|
+
key: "canUpdateViewTheParticipantsList",
|
|
241
|
+
value: function canUpdateViewTheParticipantsList(control, displayHints) {
|
|
242
|
+
var requiredHints = [];
|
|
243
|
+
if (control.properties.enabled === true) {
|
|
244
|
+
requiredHints.push(_constants.DISPLAY_HINTS.ENABLE_VIEW_THE_PARTICIPANT_LIST);
|
|
245
|
+
}
|
|
246
|
+
if (control.properties.enabled === false) {
|
|
247
|
+
requiredHints.push(_constants.DISPLAY_HINTS.DISABLE_VIEW_THE_PARTICIPANT_LIST);
|
|
248
|
+
}
|
|
249
|
+
return Utils.hasHints({
|
|
250
|
+
requiredHints: requiredHints,
|
|
251
|
+
displayHints: displayHints
|
|
252
|
+
});
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
/**
|
|
256
|
+
* Validate if a video-scoped control is allowed to be sent to the service.
|
|
257
|
+
*
|
|
258
|
+
* @param {ControlConfig<VideoProperties>} control - Video control config to validate.
|
|
259
|
+
* @param {Array<string>} displayHints - All available hints.
|
|
260
|
+
* @returns {boolean} - True if all of the actions are allowed.
|
|
261
|
+
*/
|
|
262
|
+
}, {
|
|
263
|
+
key: "canUpdateVideo",
|
|
264
|
+
value: function canUpdateVideo(control, displayHints) {
|
|
265
|
+
var requiredHints = [];
|
|
266
|
+
if (control.properties.enabled === true) {
|
|
267
|
+
requiredHints.push(_constants.DISPLAY_HINTS.ENABLE_VIDEO);
|
|
268
|
+
}
|
|
269
|
+
if (control.properties.enabled === false) {
|
|
270
|
+
requiredHints.push(_constants.DISPLAY_HINTS.DISABLE_VIDEO);
|
|
271
|
+
}
|
|
272
|
+
return Utils.hasHints({
|
|
273
|
+
requiredHints: requiredHints,
|
|
274
|
+
displayHints: displayHints
|
|
275
|
+
});
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
/**
|
|
279
|
+
* Validate that a control can be sent to the service based on the provided
|
|
280
|
+
* display hints.
|
|
281
|
+
*
|
|
282
|
+
* @param {ControlConfig} control - Control to validate.
|
|
283
|
+
* @param {Array<string>} displayHints - All available hints.
|
|
284
|
+
* @returns {boolean} - True if all of the actions are allowed.
|
|
285
|
+
*/
|
|
286
|
+
}, {
|
|
287
|
+
key: "canUpdate",
|
|
288
|
+
value: function canUpdate(control, displayHints) {
|
|
289
|
+
var determinant;
|
|
290
|
+
switch (control.scope) {
|
|
291
|
+
case _enums.Control.audio:
|
|
292
|
+
determinant = Utils.canUpdateAudio(control, displayHints);
|
|
293
|
+
break;
|
|
294
|
+
case _enums.Control.raiseHand:
|
|
295
|
+
determinant = Utils.canUpdateRaiseHand(control, displayHints);
|
|
296
|
+
break;
|
|
297
|
+
case _enums.Control.reactions:
|
|
298
|
+
determinant = Utils.canUpdateReactions(control, displayHints);
|
|
299
|
+
break;
|
|
300
|
+
case _enums.Control.shareControl:
|
|
301
|
+
determinant = Utils.canUpdateShareControl(displayHints);
|
|
302
|
+
break;
|
|
303
|
+
case _enums.Control.video:
|
|
304
|
+
determinant = Utils.canUpdateVideo(control, displayHints);
|
|
305
|
+
break;
|
|
306
|
+
case _enums.Control.viewTheParticipantList:
|
|
307
|
+
determinant = Utils.canUpdateViewTheParticipantsList(control, displayHints);
|
|
308
|
+
break;
|
|
309
|
+
default:
|
|
310
|
+
determinant = false;
|
|
311
|
+
}
|
|
312
|
+
return determinant;
|
|
313
|
+
}
|
|
314
|
+
}]);
|
|
315
|
+
return Utils;
|
|
316
|
+
}();
|
|
317
|
+
var _default = Utils;
|
|
318
|
+
exports.default = _default;
|
|
319
|
+
//# sourceMappingURL=util.js.map
|