@webex/plugin-meetings 3.0.0-beta.2 → 3.0.0-beta.200
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/UPGRADING.md +9 -9
- package/browsers.js +19 -24
- package/dist/annotation/annotation.types.js +7 -0
- package/dist/annotation/annotation.types.js.map +1 -0
- package/dist/annotation/constants.js +49 -0
- package/dist/annotation/constants.js.map +1 -0
- package/dist/annotation/index.js +342 -0
- package/dist/annotation/index.js.map +1 -0
- package/dist/breakouts/breakout.js +216 -0
- package/dist/breakouts/breakout.js.map +1 -0
- package/dist/breakouts/collection.js +23 -0
- package/dist/breakouts/collection.js.map +1 -0
- package/dist/breakouts/edit-lock-error.js +52 -0
- package/dist/breakouts/edit-lock-error.js.map +1 -0
- package/dist/breakouts/events.js +45 -0
- package/dist/breakouts/events.js.map +1 -0
- package/dist/breakouts/index.js +1048 -0
- package/dist/breakouts/index.js.map +1 -0
- package/dist/breakouts/request.js +78 -0
- package/dist/breakouts/request.js.map +1 -0
- package/dist/breakouts/utils.js +67 -0
- package/dist/breakouts/utils.js.map +1 -0
- package/dist/common/browser-detection.js +1 -20
- package/dist/common/browser-detection.js.map +1 -1
- package/dist/common/collection.js +5 -20
- package/dist/common/collection.js.map +1 -1
- package/dist/common/config.js +0 -7
- package/dist/common/config.js.map +1 -1
- package/dist/common/errors/captcha-error.js +10 -24
- package/dist/common/errors/captcha-error.js.map +1 -1
- package/dist/common/errors/intent-to-join.js +11 -24
- package/dist/common/errors/intent-to-join.js.map +1 -1
- package/dist/common/errors/join-meeting.js +12 -25
- package/dist/common/errors/join-meeting.js.map +1 -1
- package/dist/common/errors/media.js +10 -24
- package/dist/common/errors/media.js.map +1 -1
- package/dist/common/errors/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 +9 -43
- 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 +28 -23
- package/dist/common/queue.js.map +1 -1
- package/dist/config.js +8 -13
- package/dist/config.js.map +1 -1
- package/dist/constants.js +250 -66
- 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 +108 -17
- package/dist/index.js.map +1 -1
- package/dist/interpretation/collection.js +23 -0
- package/dist/interpretation/collection.js.map +1 -0
- package/dist/interpretation/index.js +366 -0
- package/dist/interpretation/index.js.map +1 -0
- package/dist/interpretation/siLanguage.js +25 -0
- package/dist/interpretation/siLanguage.js.map +1 -0
- package/dist/locus-info/controlsUtils.js +101 -29
- package/dist/locus-info/controlsUtils.js.map +1 -1
- package/dist/locus-info/embeddedAppsUtils.js +3 -26
- package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
- package/dist/locus-info/fullState.js +0 -15
- package/dist/locus-info/fullState.js.map +1 -1
- package/dist/locus-info/hostUtils.js +4 -12
- package/dist/locus-info/hostUtils.js.map +1 -1
- package/dist/locus-info/index.js +532 -240
- 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 +54 -38
- package/dist/locus-info/mediaSharesUtils.js.map +1 -1
- package/dist/locus-info/parser.js +284 -154
- package/dist/locus-info/parser.js.map +1 -1
- package/dist/locus-info/selfUtils.js +110 -92
- package/dist/locus-info/selfUtils.js.map +1 -1
- package/dist/media/index.js +95 -226
- package/dist/media/index.js.map +1 -1
- package/dist/media/properties.js +99 -194
- package/dist/media/properties.js.map +1 -1
- package/dist/media/util.js +2 -9
- package/dist/media/util.js.map +1 -1
- package/dist/mediaQualityMetrics/config.js +505 -495
- package/dist/mediaQualityMetrics/config.js.map +1 -1
- package/dist/meeting/in-meeting-actions.js +83 -14
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +3478 -3563
- 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 +247 -183
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +344 -344
- 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 +529 -588
- 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 +62 -39
- package/dist/meeting-info/index.js.map +1 -1
- package/dist/meeting-info/meeting-info-v2.js +328 -283
- package/dist/meeting-info/meeting-info-v2.js.map +1 -1
- package/dist/meeting-info/request.js +3 -15
- package/dist/meeting-info/request.js.map +1 -1
- package/dist/meeting-info/util.js +98 -183
- package/dist/meeting-info/util.js.map +1 -1
- package/dist/meeting-info/utilv2.js +156 -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 +795 -574
- package/dist/meetings/index.js.map +1 -1
- package/dist/meetings/meetings.types.js +7 -0
- package/dist/meetings/meetings.types.js.map +1 -0
- package/dist/meetings/request.js +26 -41
- package/dist/meetings/request.js.map +1 -1
- package/dist/meetings/util.js +186 -155
- package/dist/meetings/util.js.map +1 -1
- package/dist/member/index.js +126 -85
- package/dist/member/index.js.map +1 -1
- package/dist/member/types.js +25 -0
- package/dist/member/types.js.map +1 -0
- package/dist/member/util.js +147 -88
- package/dist/member/util.js.map +1 -1
- package/dist/members/collection.js +13 -12
- package/dist/members/collection.js.map +1 -1
- package/dist/members/index.js +178 -204
- package/dist/members/index.js.map +1 -1
- package/dist/members/request.js +113 -68
- package/dist/members/request.js.map +1 -1
- package/dist/members/types.js +15 -0
- package/dist/members/types.js.map +1 -0
- package/dist/members/util.js +314 -260
- package/dist/members/util.js.map +1 -1
- package/dist/metrics/constants.js +4 -7
- package/dist/metrics/constants.js.map +1 -1
- package/dist/metrics/index.js +11 -558
- package/dist/metrics/index.js.map +1 -1
- package/dist/multistream/mediaRequestManager.js +264 -50
- package/dist/multistream/mediaRequestManager.js.map +1 -1
- package/dist/multistream/receiveSlot.js +58 -65
- package/dist/multistream/receiveSlot.js.map +1 -1
- package/dist/multistream/receiveSlotManager.js +76 -95
- package/dist/multistream/receiveSlotManager.js.map +1 -1
- package/dist/multistream/remoteMedia.js +62 -76
- package/dist/multistream/remoteMedia.js.map +1 -1
- package/dist/multistream/remoteMediaGroup.js +66 -43
- package/dist/multistream/remoteMediaGroup.js.map +1 -1
- package/dist/multistream/remoteMediaManager.js +502 -442
- package/dist/multistream/remoteMediaManager.js.map +1 -1
- 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 +384 -476
- package/dist/reconnection-manager/index.js.map +1 -1
- package/dist/recording-controller/enums.js +17 -0
- package/dist/recording-controller/enums.js.map +1 -0
- package/dist/recording-controller/index.js +363 -0
- package/dist/recording-controller/index.js.map +1 -0
- package/dist/recording-controller/util.js +64 -0
- package/dist/recording-controller/util.js.map +1 -0
- package/dist/roap/index.js +58 -91
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +137 -135
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/turnDiscovery.js +148 -100
- 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 +115 -0
- package/dist/rtcMetrics/index.js.map +1 -0
- package/dist/statsAnalyzer/global.js +1 -95
- package/dist/statsAnalyzer/global.js.map +1 -1
- package/dist/statsAnalyzer/index.js +385 -460
- 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 +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 +1016 -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 +153 -0
- package/dist/types/meeting/index.d.ts +1471 -0
- package/dist/types/meeting/locusMediaRequest.d.ts +70 -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 +78 -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 +208 -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/internal-README.md +7 -6
- package/package.json +29 -21
- package/src/annotation/annotation.types.ts +50 -0
- package/src/annotation/constants.ts +36 -0
- package/src/annotation/index.ts +328 -0
- package/src/breakouts/README.md +220 -0
- package/src/breakouts/breakout.ts +188 -0
- package/src/breakouts/collection.ts +19 -0
- package/src/breakouts/edit-lock-error.ts +25 -0
- package/src/breakouts/events.ts +56 -0
- package/src/breakouts/index.ts +925 -0
- package/src/breakouts/request.ts +55 -0
- package/src/breakouts/utils.ts +57 -0
- package/src/common/{browser-detection.js → browser-detection.ts} +9 -6
- package/src/common/collection.ts +9 -7
- package/src/common/{config.js → config.ts} +1 -1
- package/src/common/errors/{captcha-error.js → captcha-error.ts} +11 -7
- package/src/common/errors/{intent-to-join.js → intent-to-join.ts} +12 -7
- package/src/common/errors/{join-meeting.js → join-meeting.ts} +17 -8
- package/src/common/errors/{media.js → media.ts} +11 -7
- package/src/common/errors/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} +14 -9
- 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 +22 -9
- package/src/{config.js → config.ts} +17 -17
- package/src/constants.ts +197 -22
- package/src/controls-options-manager/constants.ts +5 -0
- package/src/controls-options-manager/enums.ts +18 -0
- package/src/controls-options-manager/index.ts +278 -0
- package/src/controls-options-manager/types.ts +59 -0
- package/src/controls-options-manager/util.ts +300 -0
- package/src/index.ts +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 +222 -0
- package/src/locus-info/{embeddedAppsUtils.js → embeddedAppsUtils.ts} +5 -6
- package/src/locus-info/{fullState.js → fullState.ts} +16 -12
- package/src/locus-info/{hostUtils.js → hostUtils.ts} +9 -8
- package/src/locus-info/{index.js → index.ts} +518 -111
- package/src/locus-info/{infoUtils.js → infoUtils.ts} +19 -8
- package/src/locus-info/{mediaSharesUtils.js → mediaSharesUtils.ts} +65 -17
- package/src/locus-info/{parser.js → parser.ts} +271 -98
- package/src/locus-info/{selfUtils.js → selfUtils.ts} +199 -68
- package/src/media/index.ts +456 -0
- package/src/media/{properties.js → properties.ts} +80 -102
- package/src/media/{util.js → util.ts} +2 -2
- package/src/mediaQualityMetrics/config.ts +384 -0
- package/src/meeting/in-meeting-actions.ts +171 -3
- package/src/meeting/index.ts +7070 -0
- package/src/meeting/locusMediaRequest.ts +309 -0
- package/src/meeting/muteState.ts +450 -0
- package/src/meeting/{request.js → request.ts} +354 -214
- package/src/meeting/request.type.ts +13 -0
- package/src/meeting/{state.js → state.ts} +50 -35
- package/src/meeting/util.ts +615 -0
- package/src/meeting-info/{collection.js → collection.ts} +6 -2
- package/src/meeting-info/index.ts +183 -0
- package/src/meeting-info/meeting-info-v2.ts +407 -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} +77 -60
- package/src/meetings/{collection.js → collection.ts} +26 -3
- package/src/meetings/index.ts +1467 -0
- package/src/meetings/meetings.types.ts +12 -0
- package/src/meetings/{request.js → request.ts} +34 -25
- package/src/meetings/{util.js → util.ts} +137 -36
- package/src/member/{index.js → index.ts} +151 -56
- package/src/member/types.ts +38 -0
- package/src/member/util.ts +383 -0
- package/src/members/{collection.js → collection.ts} +10 -2
- package/src/members/{index.js → index.ts} +323 -145
- package/src/members/request.ts +255 -0
- package/src/members/types.ts +28 -0
- package/src/members/util.ts +339 -0
- package/src/metrics/{constants.js → constants.ts} +2 -6
- package/src/metrics/index.ts +73 -0
- package/src/multistream/mediaRequestManager.ts +337 -61
- package/src/multistream/receiveSlot.ts +69 -26
- package/src/multistream/receiveSlotManager.ts +66 -42
- package/src/multistream/remoteMedia.ts +40 -5
- package/src/multistream/remoteMediaGroup.ts +63 -3
- package/src/multistream/remoteMediaManager.ts +263 -66
- 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} +254 -136
- package/src/recording-controller/enums.ts +8 -0
- package/src/recording-controller/index.ts +333 -0
- package/src/recording-controller/util.ts +75 -0
- package/src/roap/{index.js → index.ts} +86 -78
- package/src/roap/request.ts +163 -0
- package/src/roap/turnDiscovery.ts +111 -49
- package/src/rtcMetrics/constants.ts +3 -0
- package/src/rtcMetrics/index.ts +96 -0
- package/src/statsAnalyzer/global.ts +37 -0
- package/src/statsAnalyzer/index.ts +1272 -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 +233 -0
- package/test/integration/spec/journey.js +804 -526
- package/test/integration/spec/space-meeting.js +391 -204
- package/test/integration/spec/transcription.js +7 -8
- package/test/unit/spec/annotation/index.ts +418 -0
- package/test/unit/spec/breakouts/breakout.ts +237 -0
- package/test/unit/spec/breakouts/collection.ts +15 -0
- package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
- package/test/unit/spec/breakouts/events.ts +89 -0
- package/test/unit/spec/breakouts/index.ts +1790 -0
- package/test/unit/spec/breakouts/request.ts +104 -0
- package/test/unit/spec/breakouts/utils.js +72 -0
- package/test/unit/spec/common/browser-detection.js +9 -28
- package/test/unit/spec/common/queue.js +31 -2
- package/test/unit/spec/controls-options-manager/index.js +287 -0
- package/test/unit/spec/controls-options-manager/util.js +582 -0
- package/test/unit/spec/fixture/locus.js +93 -90
- package/test/unit/spec/interpretation/collection.ts +15 -0
- package/test/unit/spec/interpretation/index.ts +589 -0
- package/test/unit/spec/interpretation/siLanguage.ts +28 -0
- package/test/unit/spec/locus-info/controlsUtils.js +325 -32
- package/test/unit/spec/locus-info/embeddedAppsUtils.js +8 -6
- package/test/unit/spec/locus-info/index.js +1176 -18
- 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/mediaSharesUtils.ts +22 -0
- package/test/unit/spec/locus-info/parser.js +65 -31
- package/test/unit/spec/locus-info/selfConstant.js +120 -103
- package/test/unit/spec/locus-info/selfUtils.js +296 -12
- package/test/unit/spec/media/index.ts +162 -68
- package/test/unit/spec/media/properties.ts +9 -9
- package/test/unit/spec/meeting/in-meeting-actions.ts +82 -3
- package/test/unit/spec/meeting/index.js +4569 -1773
- package/test/unit/spec/meeting/locusMediaRequest.ts +436 -0
- package/test/unit/spec/meeting/muteState.js +382 -211
- package/test/unit/spec/meeting/request.js +444 -78
- package/test/unit/spec/meeting/utils.js +517 -192
- package/test/unit/spec/meeting-info/index.js +181 -0
- package/test/unit/spec/meeting-info/meetinginfov2.js +481 -76
- package/test/unit/spec/meeting-info/request.js +7 -9
- package/test/unit/spec/meeting-info/util.js +11 -12
- package/test/unit/spec/meeting-info/utilv2.js +131 -74
- package/test/unit/spec/meetings/collection.js +15 -1
- package/test/unit/spec/meetings/index.js +1254 -330
- package/test/unit/spec/meetings/utils.js +220 -14
- package/test/unit/spec/member/index.js +58 -5
- package/test/unit/spec/member/util.js +494 -26
- package/test/unit/spec/members/index.js +423 -55
- package/test/unit/spec/members/request.js +228 -40
- package/test/unit/spec/members/utils.js +191 -4
- package/test/unit/spec/metrics/index.js +12 -66
- package/test/unit/spec/multistream/mediaRequestManager.ts +1013 -106
- package/test/unit/spec/multistream/receiveSlot.ts +77 -18
- package/test/unit/spec/multistream/receiveSlotManager.ts +69 -39
- package/test/unit/spec/multistream/remoteMedia.ts +40 -2
- package/test/unit/spec/multistream/remoteMediaGroup.ts +271 -5
- package/test/unit/spec/multistream/remoteMediaManager.ts +730 -65
- 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 +155 -9
- package/test/unit/spec/recording-controller/index.js +307 -0
- package/test/unit/spec/recording-controller/util.js +229 -0
- package/test/unit/spec/roap/index.ts +28 -52
- package/test/unit/spec/roap/request.ts +225 -0
- package/test/unit/spec/roap/turnDiscovery.ts +92 -50
- package/test/unit/spec/rtcMetrics/index.ts +60 -0
- package/test/unit/spec/stats-analyzer/index.js +116 -60
- package/test/utils/cmr.js +44 -42
- package/test/utils/constants.js +9 -0
- package/test/utils/integrationTestUtils.js +46 -0
- package/test/utils/testUtils.js +63 -99
- package/test/utils/webex-config.js +22 -18
- package/test/utils/webex-test-users.js +57 -50
- package/tsconfig.json +6 -0
- package/dist/media/internal-media-core-wrapper.js +0 -22
- package/dist/media/internal-media-core-wrapper.js.map +0 -1
- package/dist/meeting/effectsState.js +0 -327
- package/dist/meeting/effectsState.js.map +0 -1
- package/dist/metrics/config.js +0 -301
- package/dist/metrics/config.js.map +0 -1
- package/dist/multistream/multistreamMedia.js +0 -116
- package/dist/multistream/multistreamMedia.js.map +0 -1
- package/dist/peer-connection-manager/util.js +0 -124
- package/dist/peer-connection-manager/util.js.map +0 -1
- package/src/common/logs/logger-proxy.js +0 -33
- package/src/index.js +0 -15
- package/src/locus-info/controlsUtils.js +0 -102
- package/src/media/index.js +0 -459
- package/src/media/internal-media-core-wrapper.ts +0 -9
- package/src/mediaQualityMetrics/config.js +0 -382
- package/src/meeting/effectsState.js +0 -205
- package/src/meeting/index.js +0 -6284
- package/src/meeting/muteState.js +0 -318
- package/src/meeting/util.js +0 -506
- package/src/meeting-info/index.js +0 -131
- package/src/meeting-info/meeting-info-v2.js +0 -255
- package/src/meetings/index.js +0 -1015
- package/src/member/util.js +0 -254
- package/src/members/request.js +0 -131
- package/src/members/util.js +0 -258
- package/src/metrics/config.js +0 -324
- package/src/metrics/index.js +0 -530
- package/src/multistream/multistreamMedia.ts +0 -92
- package/src/peer-connection-manager/util.ts +0 -117
- package/src/roap/request.js +0 -127
- package/src/statsAnalyzer/global.js +0 -133
- package/src/statsAnalyzer/index.js +0 -1006
- package/src/statsAnalyzer/mqaUtil.js +0 -173
- package/test/unit/spec/meeting/effectsState.js +0 -291
- package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -389
- /package/src/common/errors/{reconnection-in-progress.js → reconnection-in-progress.ts} +0 -0
|
@@ -0,0 +1,328 @@
|
|
|
1
|
+
import uuid from 'uuid';
|
|
2
|
+
// eslint-disable-next-line import/no-extraneous-dependencies
|
|
3
|
+
import {WebexPlugin, config} from '@webex/webex-core';
|
|
4
|
+
import TriggerProxy from '../common/events/trigger-proxy';
|
|
5
|
+
|
|
6
|
+
import {
|
|
7
|
+
EVENT_TRIGGERS,
|
|
8
|
+
ANNOTATION_RELAY_TYPES,
|
|
9
|
+
ANNOTATION,
|
|
10
|
+
ANNOTATION_REQUEST_TYPE,
|
|
11
|
+
ANNOTATION_ACTION_TYPE,
|
|
12
|
+
ANNOTATION_RESOURCE_TYPE,
|
|
13
|
+
} from './constants';
|
|
14
|
+
|
|
15
|
+
import {StrokeData, RequestData, IAnnotationChannel, CommandRequestBody} from './annotation.types';
|
|
16
|
+
import {HTTP_VERBS} from '../constants';
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* @description Annotation to handle LLM and Mercury message and locus API
|
|
20
|
+
* @class
|
|
21
|
+
*/
|
|
22
|
+
class AnnotationChannel extends WebexPlugin implements IAnnotationChannel {
|
|
23
|
+
namespace = ANNOTATION;
|
|
24
|
+
|
|
25
|
+
private seqNum: number;
|
|
26
|
+
|
|
27
|
+
hasSubscribedToEvents: boolean;
|
|
28
|
+
|
|
29
|
+
approvalUrl: string;
|
|
30
|
+
locusUrl: string;
|
|
31
|
+
deviceUrl: string;
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Initializes annotation module
|
|
35
|
+
*/
|
|
36
|
+
constructor(...args) {
|
|
37
|
+
super(...args);
|
|
38
|
+
this.seqNum = 1;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Process Stroke Data
|
|
43
|
+
* @param {object} data
|
|
44
|
+
* @returns {void}
|
|
45
|
+
*/
|
|
46
|
+
private processStrokeMessage(data) {
|
|
47
|
+
const {request} = data;
|
|
48
|
+
this.decryptContent(request.value.encryptionKeyUrl, request.value.content).then(
|
|
49
|
+
(decryptedContent) => {
|
|
50
|
+
request.value.content = decryptedContent;
|
|
51
|
+
TriggerProxy.trigger(
|
|
52
|
+
this,
|
|
53
|
+
{
|
|
54
|
+
file: 'annotation',
|
|
55
|
+
function: 'processStrokeMessage',
|
|
56
|
+
},
|
|
57
|
+
EVENT_TRIGGERS.ANNOTATION_STROKE_DATA,
|
|
58
|
+
{
|
|
59
|
+
payload: data,
|
|
60
|
+
}
|
|
61
|
+
);
|
|
62
|
+
}
|
|
63
|
+
);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
/** bind all events from mercury
|
|
67
|
+
* @param {Object} e
|
|
68
|
+
* @returns {undefined}
|
|
69
|
+
*/
|
|
70
|
+
private eventCommandProcessor(e) {
|
|
71
|
+
if (
|
|
72
|
+
e?.data?.eventType === 'locus.approval_request' &&
|
|
73
|
+
e?.data?.approval?.resourceType === ANNOTATION_RESOURCE_TYPE &&
|
|
74
|
+
e?.data?.approval?.actionType
|
|
75
|
+
) {
|
|
76
|
+
TriggerProxy.trigger(
|
|
77
|
+
this,
|
|
78
|
+
{
|
|
79
|
+
file: 'annotation',
|
|
80
|
+
function: 'approval_request',
|
|
81
|
+
},
|
|
82
|
+
EVENT_TRIGGERS.ANNOTATION_COMMAND,
|
|
83
|
+
{
|
|
84
|
+
type: e.data.approval.actionType,
|
|
85
|
+
payload: e.data.approval,
|
|
86
|
+
}
|
|
87
|
+
);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
/** bind all events from llm
|
|
92
|
+
* @param {Object} e
|
|
93
|
+
* @returns {undefined}
|
|
94
|
+
*/
|
|
95
|
+
private eventDataProcessor(e) {
|
|
96
|
+
switch (e?.data?.relayType) {
|
|
97
|
+
case ANNOTATION_RELAY_TYPES.ANNOTATION_CLIENT:
|
|
98
|
+
this.processStrokeMessage(e.data);
|
|
99
|
+
break;
|
|
100
|
+
default:
|
|
101
|
+
break;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* Listen to websocket messages
|
|
107
|
+
* @returns {undefined}
|
|
108
|
+
*/
|
|
109
|
+
private listenToEvents() {
|
|
110
|
+
if (!this.hasSubscribedToEvents) {
|
|
111
|
+
// @ts-ignore
|
|
112
|
+
this.webex.internal.mercury.on(
|
|
113
|
+
'event:locus.approval_request',
|
|
114
|
+
this.eventCommandProcessor,
|
|
115
|
+
this
|
|
116
|
+
);
|
|
117
|
+
// @ts-ignore
|
|
118
|
+
this.webex.internal.llm.on('event:relay.event', this.eventDataProcessor, this);
|
|
119
|
+
this.hasSubscribedToEvents = true;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
/**
|
|
124
|
+
* set locusUrl
|
|
125
|
+
* @param {string} locusUrl
|
|
126
|
+
* @returns {void}
|
|
127
|
+
*/
|
|
128
|
+
public locusUrlUpdate(locusUrl: string) {
|
|
129
|
+
this.locusUrl = locusUrl;
|
|
130
|
+
this.listenToEvents();
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
/**
|
|
134
|
+
* set approved url
|
|
135
|
+
* @param {string} approvalUrl
|
|
136
|
+
* @returns {void}
|
|
137
|
+
*/
|
|
138
|
+
public approvalUrlUpdate(approvalUrl: string) {
|
|
139
|
+
this.approvalUrl = approvalUrl;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
/**
|
|
143
|
+
* accept request
|
|
144
|
+
* @param {object} approval
|
|
145
|
+
* @returns {Promise}
|
|
146
|
+
*/
|
|
147
|
+
public acceptRequest(approval) {
|
|
148
|
+
// @ts-ignore
|
|
149
|
+
return this.request({
|
|
150
|
+
method: HTTP_VERBS.PUT,
|
|
151
|
+
url: approval.url,
|
|
152
|
+
body: {
|
|
153
|
+
resourceType: ANNOTATION_RESOURCE_TYPE,
|
|
154
|
+
actionType: ANNOTATION_ACTION_TYPE.ACCEPTED,
|
|
155
|
+
},
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
/**
|
|
160
|
+
* presenter declined request annotation
|
|
161
|
+
* @param {approval} approval
|
|
162
|
+
* @returns {Promise}
|
|
163
|
+
*/
|
|
164
|
+
public declineRequest(approval) {
|
|
165
|
+
// @ts-ignore
|
|
166
|
+
return this.request({
|
|
167
|
+
method: HTTP_VERBS.PUT,
|
|
168
|
+
url: approval.url,
|
|
169
|
+
body: {
|
|
170
|
+
resourceType: ANNOTATION_RESOURCE_TYPE,
|
|
171
|
+
actionType: ANNOTATION_ACTION_TYPE.DECLINED,
|
|
172
|
+
},
|
|
173
|
+
});
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
/**
|
|
177
|
+
* request approved annotation
|
|
178
|
+
* @param {RequestData} requestData
|
|
179
|
+
* @returns {Promise}
|
|
180
|
+
*/
|
|
181
|
+
public approveAnnotation(requestData: RequestData) {
|
|
182
|
+
return this.sendAnnotationAction(ANNOTATION_ACTION_TYPE.REQUESTED, requestData);
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
/**
|
|
186
|
+
* cancel approved annotation
|
|
187
|
+
* @param {object} requestData
|
|
188
|
+
* @param {object} approval
|
|
189
|
+
* @returns {Promise}
|
|
190
|
+
*/
|
|
191
|
+
public cancelApproveAnnotation(requestData: RequestData, approval) {
|
|
192
|
+
const body: CommandRequestBody = {
|
|
193
|
+
actionType: ANNOTATION_ACTION_TYPE.CANCELED,
|
|
194
|
+
resourceType: 'AnnotationOnShare',
|
|
195
|
+
shareInstanceId: requestData.shareInstanceId,
|
|
196
|
+
};
|
|
197
|
+
|
|
198
|
+
// @ts-ignore
|
|
199
|
+
return this.request({
|
|
200
|
+
method: HTTP_VERBS.PUT,
|
|
201
|
+
url: `${approval.url}`,
|
|
202
|
+
body,
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
/**
|
|
207
|
+
* close annotation
|
|
208
|
+
* @param {object} requestData
|
|
209
|
+
* @returns {Promise}
|
|
210
|
+
*/
|
|
211
|
+
public closeAnnotation(requestData: RequestData) {
|
|
212
|
+
return this.sendAnnotationAction(ANNOTATION_ACTION_TYPE.CLOSED, requestData);
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
/**
|
|
216
|
+
* send annotation command
|
|
217
|
+
* @param {ANNOTATION_ACTION_TYPE} actionType
|
|
218
|
+
* @param {RequestData} requestData
|
|
219
|
+
* @returns {Promise}
|
|
220
|
+
*/
|
|
221
|
+
private sendAnnotationAction = async (
|
|
222
|
+
actionType: ANNOTATION_ACTION_TYPE,
|
|
223
|
+
requestData: RequestData
|
|
224
|
+
): Promise<void> => {
|
|
225
|
+
const body: CommandRequestBody = {
|
|
226
|
+
actionType,
|
|
227
|
+
resourceType: 'AnnotationOnShare',
|
|
228
|
+
shareInstanceId: requestData.shareInstanceId,
|
|
229
|
+
};
|
|
230
|
+
if (requestData?.toUserId) {
|
|
231
|
+
body.receivers = [{participantId: requestData.toUserId, deviceUrl: requestData.toDeviceUrl}];
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
// @ts-ignore
|
|
235
|
+
return this.request({
|
|
236
|
+
method: HTTP_VERBS.POST,
|
|
237
|
+
url: `${this.approvalUrl}`,
|
|
238
|
+
body,
|
|
239
|
+
});
|
|
240
|
+
};
|
|
241
|
+
|
|
242
|
+
/**
|
|
243
|
+
* decrypt data
|
|
244
|
+
* @param {string} encryptionKeyUrl
|
|
245
|
+
* @param {string} content encrypted content
|
|
246
|
+
* @returns {string} decrypted content
|
|
247
|
+
*/
|
|
248
|
+
private decryptContent = (encryptionKeyUrl: string, content: string): Promise<any> => {
|
|
249
|
+
// @ts-ignore
|
|
250
|
+
return this.webex.internal.encryption.decryptText(encryptionKeyUrl, content).then((res) => {
|
|
251
|
+
return res;
|
|
252
|
+
});
|
|
253
|
+
};
|
|
254
|
+
|
|
255
|
+
/**
|
|
256
|
+
* encrypt data
|
|
257
|
+
* @param {string} encryptionKeyUrl
|
|
258
|
+
* @param {string} content original content
|
|
259
|
+
* @returns {string} encrypted content
|
|
260
|
+
*/
|
|
261
|
+
private encryptContent = (encryptionKeyUrl: string, content: string): Promise<any> => {
|
|
262
|
+
// @ts-ignore
|
|
263
|
+
return this.webex.internal.encryption.encryptText(encryptionKeyUrl, content).then((res) => {
|
|
264
|
+
return res;
|
|
265
|
+
});
|
|
266
|
+
};
|
|
267
|
+
|
|
268
|
+
/**
|
|
269
|
+
* Sends stroke data to presenter
|
|
270
|
+
* @param {StrokeData} strokeData
|
|
271
|
+
* @returns {void}
|
|
272
|
+
*/
|
|
273
|
+
public sendStrokeData = (strokeData: StrokeData): void => {
|
|
274
|
+
// @ts-ignore
|
|
275
|
+
if (!this.webex.internal.llm.isConnected()) return;
|
|
276
|
+
this.encryptContent(strokeData.encryptionKeyUrl, strokeData.content).then(
|
|
277
|
+
(encryptedContent) => {
|
|
278
|
+
this.publishEncrypted(encryptedContent, strokeData);
|
|
279
|
+
}
|
|
280
|
+
);
|
|
281
|
+
};
|
|
282
|
+
|
|
283
|
+
/**
|
|
284
|
+
* private encrypted the strokes data
|
|
285
|
+
* @param {string} encryptedContent
|
|
286
|
+
* @param {StrokeData} strokeData
|
|
287
|
+
* @returns {void}
|
|
288
|
+
*/
|
|
289
|
+
private publishEncrypted(encryptedContent: string, strokeData: StrokeData) {
|
|
290
|
+
const data = {
|
|
291
|
+
id: `${this.seqNum}`,
|
|
292
|
+
type: 'publishRequest',
|
|
293
|
+
recipients: {
|
|
294
|
+
// @ts-ignore
|
|
295
|
+
route: this.webex.internal.llm.getBinding(),
|
|
296
|
+
},
|
|
297
|
+
headers: {
|
|
298
|
+
to: strokeData.toUserId,
|
|
299
|
+
},
|
|
300
|
+
data: {
|
|
301
|
+
eventType: 'relay.event',
|
|
302
|
+
relayType: ANNOTATION_RELAY_TYPES.ANNOTATION_CLIENT,
|
|
303
|
+
request: {
|
|
304
|
+
value: {
|
|
305
|
+
type: ANNOTATION_REQUEST_TYPE.ANNOTATION_MESSAGE,
|
|
306
|
+
content: encryptedContent,
|
|
307
|
+
deviceId: strokeData.deviceId,
|
|
308
|
+
seq: this.seqNum,
|
|
309
|
+
requesterId: strokeData.requesterId,
|
|
310
|
+
version: strokeData.version,
|
|
311
|
+
shareInstanceId: strokeData.shareInstanceId,
|
|
312
|
+
encryptionKeyUrl: strokeData.encryptionKeyUrl,
|
|
313
|
+
},
|
|
314
|
+
},
|
|
315
|
+
},
|
|
316
|
+
trackingId: `${config.trackingIdPrefix}_${uuid.v4().toString()}`,
|
|
317
|
+
timestamp: new Date().getTime(),
|
|
318
|
+
sequenceNumber: this.seqNum,
|
|
319
|
+
filterMessage: false,
|
|
320
|
+
};
|
|
321
|
+
|
|
322
|
+
// @ts-ignore
|
|
323
|
+
this.webex.internal.llm.socket.send(data);
|
|
324
|
+
this.seqNum += 1;
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
export default AnnotationChannel;
|
|
@@ -0,0 +1,220 @@
|
|
|
1
|
+
# Breakout Sessions
|
|
2
|
+
|
|
3
|
+
Breakout sessions are like meetings within meetings. They have separate roster lists and titles. Participants can move between breakouts and the main session.
|
|
4
|
+
|
|
5
|
+
### Enabling
|
|
6
|
+
|
|
7
|
+
To enable breakouts the `breakoutsSupported` parameter must be passed to the meeting join method.
|
|
8
|
+
|
|
9
|
+
### Structure
|
|
10
|
+
|
|
11
|
+
The current breakout session is accessible as follows:
|
|
12
|
+
|
|
13
|
+
```javascript
|
|
14
|
+
breakouts.currentBreakoutSession;
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
Other breakout sessions are available in the breakouts collection. These are breakouts that you known about. If you are an attendee, you may not know about all the breakout sessions in the meeting.
|
|
18
|
+
|
|
19
|
+
```javascript
|
|
20
|
+
breakouts.breakouts;
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
note: The `currentBreakoutSession` is NOT a member of the `breakouts.breakouts` collection.
|
|
24
|
+
|
|
25
|
+
Some information about the state of breakouts is available on the `meeting.breakouts` object itself
|
|
26
|
+
|
|
27
|
+
```javascript
|
|
28
|
+
// The number of seconds after ending breakouts before the participants are returned to the main session
|
|
29
|
+
breakouts.delayCloseTime;
|
|
30
|
+
|
|
31
|
+
// Whether the participant is allowed back to the main session
|
|
32
|
+
breakouts.allowBackToMain;
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
### Attendee functionality
|
|
36
|
+
|
|
37
|
+
The normal meeting members are updated when you move in and out of a breakout session.
|
|
38
|
+
|
|
39
|
+
The following are methods available to attendees of a meeting:
|
|
40
|
+
|
|
41
|
+
```javascript
|
|
42
|
+
// Join a breakout
|
|
43
|
+
// This can be used when the participant is in the main session or in a different breakout session
|
|
44
|
+
// when call join function, should send message to metrics
|
|
45
|
+
/* Breakout Sessions created during meetings allow participants to move into smaller breakout sessions and then
|
|
46
|
+
return to the main meeting at a later time. These moves can be initiated by the user or by the meeting
|
|
47
|
+
host/co-host. The goal of this metric is to track these moves in production by instrumenting them for
|
|
48
|
+
analysis from the end user's experience perspective.
|
|
49
|
+
*/
|
|
50
|
+
breakout.join();
|
|
51
|
+
|
|
52
|
+
// Leave a breakout
|
|
53
|
+
// This will cause the participant to return to the main session
|
|
54
|
+
breakouts.currentBreakoutSession.leave();
|
|
55
|
+
|
|
56
|
+
// Ask for help when in a breakout session. 10 second cooldown.
|
|
57
|
+
breakout.currentBreakoutSession.askForHelp();
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
#### Members
|
|
61
|
+
|
|
62
|
+
Each breakout session has members. Members represent other entities within the meeting.
|
|
63
|
+
The current breakout session members are accessed via the meeting object i.e. they will automatically
|
|
64
|
+
be updated when the user moves between sessions.
|
|
65
|
+
|
|
66
|
+
To see which members are in other sessions, you can access them via the breakout model. The Members
|
|
67
|
+
class is the same as that of the main meeting.
|
|
68
|
+
|
|
69
|
+
```javascript
|
|
70
|
+
breakout = breakouts.breakouts.models[0];
|
|
71
|
+
breakout.members;
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
#### breakouts events
|
|
75
|
+
|
|
76
|
+
```javascript
|
|
77
|
+
// When the breakouts in the breakouts collection changes. This includes updates to session members
|
|
78
|
+
on('meeting:breakouts:update', (breakouts) => {});
|
|
79
|
+
|
|
80
|
+
// When the breakout sessions end this event will be fired
|
|
81
|
+
on('meeting:breakouts:closing', () => {});
|
|
82
|
+
|
|
83
|
+
// When the host sends a message to the breakout this event will fire
|
|
84
|
+
on('meeting:breakouts:message', {senderUserId, sentTime, message, sessionId});
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
When breakouts are started there are several possibilities:
|
|
88
|
+
|
|
89
|
+
1. The attendee is forced to join a session
|
|
90
|
+
2. The attendee is assigned to a session, but can join when they feel like it
|
|
91
|
+
3. The attendee is not assigned to a session, and can choose which session they want to join
|
|
92
|
+
|
|
93
|
+
```javascript
|
|
94
|
+
breakout.assigned; // Assigned to a session, but not in it yet
|
|
95
|
+
breakout.assignedCurrent; // Forced to join a session
|
|
96
|
+
breakout.active; // The session exists
|
|
97
|
+
breakout.allowed; // The user is allowed to join the session
|
|
98
|
+
breakout.requested; // The user has been requested to join the session
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
The above attributes of the breakout sessions, combined with the `meeting:breakouts:update` event allow you to determine which situation you are in.
|
|
102
|
+
|
|
103
|
+
A host can signal attendees to move to a particular session. In this case the following is available. Using the same event, and the `requested` attribute of the breakout you can determine which session is to be moved to. Requesting return to the main session is the current use case of this.
|
|
104
|
+
|
|
105
|
+
### Host functionality
|
|
106
|
+
|
|
107
|
+
The following are methods available to a hosts of a meeting.
|
|
108
|
+
|
|
109
|
+
note: None of these are currently implemented
|
|
110
|
+
|
|
111
|
+
```javascript
|
|
112
|
+
|
|
113
|
+
// Move a participant to breakout
|
|
114
|
+
breakout.move(participant)
|
|
115
|
+
|
|
116
|
+
// Remove someone from a breakout session
|
|
117
|
+
// This returns them to the main session
|
|
118
|
+
breakout.remove(participant)
|
|
119
|
+
|
|
120
|
+
// Deletes a breakout session
|
|
121
|
+
// This can only be done when breakouts are inactive
|
|
122
|
+
breakout.delete()
|
|
123
|
+
|
|
124
|
+
/*
|
|
125
|
+
Create breakout sessions, Type is array
|
|
126
|
+
Format: [{'name':'session1', "anyoneCanJoin" : true}]
|
|
127
|
+
*/
|
|
128
|
+
breakouts.create(sessions)
|
|
129
|
+
|
|
130
|
+
// Delete all breakout sessions
|
|
131
|
+
breakouts.clearSessions()
|
|
132
|
+
|
|
133
|
+
// update breakout session with params
|
|
134
|
+
// if unlockEdit is true, will release lock editing after update finish
|
|
135
|
+
breakout.update(params, unlockEdit)
|
|
136
|
+
|
|
137
|
+
// Start breakout sessions with necessary params
|
|
138
|
+
breakouts.start(params)
|
|
139
|
+
|
|
140
|
+
// Assign a particpant/participants to breakouts/a breakout
|
|
141
|
+
// sessions should be like: [{id:'xx',memberIds:['111'],emails:['111@ss.com',anyone: true]},...]
|
|
142
|
+
breakouts.assign(sessions)
|
|
143
|
+
|
|
144
|
+
// Dynammic assign a particpant/participants to breakouts/main (not used by now)
|
|
145
|
+
// Admit lobby waiting participants to a breakout directly
|
|
146
|
+
// sessions should be like: [{id:'xx',participants:['111'],targetState:'JOINED'},...]
|
|
147
|
+
breakouts.dynamicAssign(sessions)
|
|
148
|
+
|
|
149
|
+
// End breakout sessions with necessary params
|
|
150
|
+
breakouts.end(params)
|
|
151
|
+
|
|
152
|
+
// get breakout sessions with/without param editlock
|
|
153
|
+
breakouts.getBreakout(editlock?)
|
|
154
|
+
|
|
155
|
+
// Enable breakout sessions
|
|
156
|
+
breakouts.enable()
|
|
157
|
+
|
|
158
|
+
// Enable and lock breakout
|
|
159
|
+
breakouts.enableAndLockBreakout()
|
|
160
|
+
|
|
161
|
+
// Lock breakout
|
|
162
|
+
breakouts.lockBreakout()
|
|
163
|
+
|
|
164
|
+
// Unlock breakout
|
|
165
|
+
breakouts.unLockEditBreakout()
|
|
166
|
+
|
|
167
|
+
// Disable breakout sessions
|
|
168
|
+
breakouts.disable()
|
|
169
|
+
|
|
170
|
+
// Send message asking all participants to return to the main session
|
|
171
|
+
breakouts.askAllToReturn()
|
|
172
|
+
|
|
173
|
+
// Send a message to a breakout session
|
|
174
|
+
// You can determine which participant types receive the message, if no type set, default is to all participants
|
|
175
|
+
breakout.broadcast(message, {participants: boolean, cohosts: boolean, presenters: boolean})
|
|
176
|
+
|
|
177
|
+
// Send a message to All breakout sessions
|
|
178
|
+
// You can determine which participant types receive the message, if no type set, default is to all participants
|
|
179
|
+
breakouts.broadcast(message, {participants: boolean, cohosts: boolean, presenters: boolean})
|
|
180
|
+
|
|
181
|
+
// When breakouts are active you can cancel the automatic end of all sessions by calling this
|
|
182
|
+
// method. It cannot be restarted, only manually ending breakouts is possible after calling this
|
|
183
|
+
breakouts.cancelAutomaticEnd()
|
|
184
|
+
|
|
185
|
+
IBreakoutConfig {
|
|
186
|
+
/*
|
|
187
|
+
Number of sessions to count down before returning users to main session. Seconds. Default 60. 0 means off
|
|
188
|
+
*/
|
|
189
|
+
countdownTimer: Number,
|
|
190
|
+
/*
|
|
191
|
+
Whether attendees are allowed to return to the main meeting
|
|
192
|
+
*/
|
|
193
|
+
allowReturntoMainMeeting: Boolean,
|
|
194
|
+
/*
|
|
195
|
+
Whether attendees are allowed to join later
|
|
196
|
+
*/
|
|
197
|
+
allowJoinLater: Boolean,
|
|
198
|
+
/*
|
|
199
|
+
The timeout after which breakouts are automatically ended. Seconds. Default 1800 (30 minutes) Miniumum 5 minutes.
|
|
200
|
+
*/
|
|
201
|
+
automaticallyEndBreakoutsAfter: Number,
|
|
202
|
+
/*
|
|
203
|
+
How participants are assigned to breakouts.
|
|
204
|
+
auto -> participants are automatically placed in sessions
|
|
205
|
+
*/
|
|
206
|
+
assignmentMethod: 'auto' | 'manual' | 'choose'
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
// Configure settings on breakouts
|
|
210
|
+
breakouts.configure(config)
|
|
211
|
+
|
|
212
|
+
// set whether anyone can join the breakout or whether it is just assigned participants that can join
|
|
213
|
+
breakout.setOpen(isOpen)
|
|
214
|
+
|
|
215
|
+
// When the members change for a given breakout
|
|
216
|
+
on('meeting:breakout:members:update', ({sessionId, members}) => {
|
|
217
|
+
|
|
218
|
+
})
|
|
219
|
+
|
|
220
|
+
```
|