@webex/plugin-meetings 3.0.0-beta.4 → 3.0.0-beta.400
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 +58 -8
- package/UPGRADING.md +9 -9
- package/browsers.js +19 -24
- package/dist/annotation/annotation.types.js +7 -0
- package/dist/annotation/annotation.types.js.map +1 -0
- package/dist/annotation/constants.js +49 -0
- package/dist/annotation/constants.js.map +1 -0
- package/dist/annotation/index.js +342 -0
- package/dist/annotation/index.js.map +1 -0
- package/dist/breakouts/breakout.js +216 -0
- package/dist/breakouts/breakout.js.map +1 -0
- package/dist/breakouts/collection.js +23 -0
- package/dist/breakouts/collection.js.map +1 -0
- package/dist/breakouts/edit-lock-error.js +52 -0
- package/dist/breakouts/edit-lock-error.js.map +1 -0
- package/dist/breakouts/events.js +45 -0
- package/dist/breakouts/events.js.map +1 -0
- package/dist/breakouts/index.js +1048 -0
- package/dist/breakouts/index.js.map +1 -0
- package/dist/breakouts/request.js +78 -0
- package/dist/breakouts/request.js.map +1 -0
- package/dist/breakouts/utils.js +67 -0
- package/dist/breakouts/utils.js.map +1 -0
- package/dist/common/browser-detection.js +1 -20
- package/dist/common/browser-detection.js.map +1 -1
- package/dist/common/collection.js +5 -20
- package/dist/common/collection.js.map +1 -1
- package/dist/common/config.js +0 -7
- package/dist/common/config.js.map +1 -1
- package/dist/common/errors/captcha-error.js +10 -24
- package/dist/common/errors/captcha-error.js.map +1 -1
- package/dist/common/errors/intent-to-join.js +11 -24
- package/dist/common/errors/intent-to-join.js.map +1 -1
- package/dist/common/errors/join-meeting.js +12 -25
- package/dist/common/errors/join-meeting.js.map +1 -1
- package/dist/common/errors/media.js +10 -24
- package/dist/common/errors/media.js.map +1 -1
- package/dist/common/errors/no-meeting-info.js +51 -0
- package/dist/common/errors/no-meeting-info.js.map +1 -0
- package/dist/common/errors/parameter.js +5 -33
- package/dist/common/errors/parameter.js.map +1 -1
- package/dist/common/errors/password-error.js +10 -24
- package/dist/common/errors/password-error.js.map +1 -1
- package/dist/common/errors/permission.js +9 -23
- package/dist/common/errors/permission.js.map +1 -1
- package/dist/common/errors/reclaim-host-role-errors.js +158 -0
- package/dist/common/errors/reclaim-host-role-errors.js.map +1 -0
- package/dist/common/errors/reconnection-in-progress.js +0 -17
- package/dist/common/errors/reconnection-in-progress.js.map +1 -1
- package/dist/common/errors/reconnection.js +10 -24
- package/dist/common/errors/reconnection.js.map +1 -1
- package/dist/common/errors/stats.js +10 -24
- package/dist/common/errors/stats.js.map +1 -1
- package/dist/common/errors/webex-errors.js +54 -48
- package/dist/common/errors/webex-errors.js.map +1 -1
- package/dist/common/errors/webex-meetings-error.js +5 -25
- package/dist/common/errors/webex-meetings-error.js.map +1 -1
- package/dist/common/events/events-scope.js +0 -22
- package/dist/common/events/events-scope.js.map +1 -1
- package/dist/common/events/events.js +0 -23
- package/dist/common/events/events.js.map +1 -1
- package/dist/common/events/trigger-proxy.js +0 -12
- package/dist/common/events/trigger-proxy.js.map +1 -1
- package/dist/common/events/util.js +0 -15
- package/dist/common/events/util.js.map +1 -1
- package/dist/common/logs/logger-config.js +0 -4
- package/dist/common/logs/logger-config.js.map +1 -1
- package/dist/common/logs/logger-proxy.js +1 -8
- package/dist/common/logs/logger-proxy.js.map +1 -1
- package/dist/common/logs/request.js +41 -60
- package/dist/common/logs/request.js.map +1 -1
- package/dist/common/queue.js +28 -23
- package/dist/common/queue.js.map +1 -1
- package/dist/config.js +11 -15
- package/dist/config.js.map +1 -1
- package/dist/constants.js +347 -74
- 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 +125 -18
- package/dist/index.js.map +1 -1
- package/dist/interceptors/index.js +15 -0
- package/dist/interceptors/index.js.map +1 -0
- package/dist/interceptors/locusRetry.js +93 -0
- package/dist/interceptors/locusRetry.js.map +1 -0
- package/dist/interpretation/collection.js +23 -0
- package/dist/interpretation/collection.js.map +1 -0
- package/dist/interpretation/index.js +380 -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 +564 -246
- package/dist/locus-info/index.js.map +1 -1
- package/dist/locus-info/infoUtils.js +10 -38
- package/dist/locus-info/infoUtils.js.map +1 -1
- package/dist/locus-info/mediaSharesUtils.js +82 -38
- package/dist/locus-info/mediaSharesUtils.js.map +1 -1
- package/dist/locus-info/parser.js +314 -163
- package/dist/locus-info/parser.js.map +1 -1
- package/dist/locus-info/selfUtils.js +110 -92
- package/dist/locus-info/selfUtils.js.map +1 -1
- package/dist/media/index.js +107 -231
- package/dist/media/index.js.map +1 -1
- package/dist/media/properties.js +137 -222
- package/dist/media/properties.js.map +1 -1
- package/dist/media/util.js +2 -9
- package/dist/media/util.js.map +1 -1
- package/dist/mediaQualityMetrics/config.js +316 -501
- package/dist/mediaQualityMetrics/config.js.map +1 -1
- package/dist/meeting/in-meeting-actions.js +97 -14
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +5311 -3871
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/locusMediaRequest.js +292 -0
- package/dist/meeting/locusMediaRequest.js.map +1 -0
- package/dist/meeting/muteState.js +260 -183
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +421 -347
- 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 +672 -585
- package/dist/meeting/util.js.map +1 -1
- package/dist/meeting/voicea-meeting.js +172 -0
- package/dist/meeting/voicea-meeting.js.map +1 -0
- package/dist/meeting-info/collection.js +6 -25
- package/dist/meeting-info/collection.js.map +1 -1
- package/dist/meeting-info/index.js +87 -39
- package/dist/meeting-info/index.js.map +1 -1
- package/dist/meeting-info/meeting-info-v2.js +352 -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 +99 -183
- package/dist/meeting-info/util.js.map +1 -1
- package/dist/meeting-info/utilv2.js +147 -234
- package/dist/meeting-info/utilv2.js.map +1 -1
- package/dist/meetings/collection.js +43 -19
- package/dist/meetings/collection.js.map +1 -1
- package/dist/meetings/index.js +895 -600
- 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 +184 -157
- package/dist/meetings/util.js.map +1 -1
- package/dist/member/index.js +134 -85
- package/dist/member/index.js.map +1 -1
- package/dist/member/types.js +25 -0
- package/dist/member/types.js.map +1 -0
- package/dist/member/util.js +158 -88
- package/dist/member/util.js.map +1 -1
- package/dist/members/collection.js +13 -12
- package/dist/members/collection.js.map +1 -1
- package/dist/members/index.js +194 -204
- package/dist/members/index.js.map +1 -1
- package/dist/members/request.js +113 -68
- package/dist/members/request.js.map +1 -1
- package/dist/members/types.js +15 -0
- package/dist/members/types.js.map +1 -0
- package/dist/members/util.js +324 -259
- package/dist/members/util.js.map +1 -1
- package/dist/metrics/constants.js +19 -7
- package/dist/metrics/constants.js.map +1 -1
- package/dist/metrics/index.js +11 -558
- package/dist/metrics/index.js.map +1 -1
- package/dist/multistream/mediaRequestManager.js +263 -50
- package/dist/multistream/mediaRequestManager.js.map +1 -1
- package/dist/multistream/receiveSlot.js +58 -65
- package/dist/multistream/receiveSlot.js.map +1 -1
- package/dist/multistream/receiveSlotManager.js +76 -95
- package/dist/multistream/receiveSlotManager.js.map +1 -1
- package/dist/multistream/remoteMedia.js +62 -76
- package/dist/multistream/remoteMedia.js.map +1 -1
- package/dist/multistream/remoteMediaGroup.js +82 -45
- package/dist/multistream/remoteMediaGroup.js.map +1 -1
- package/dist/multistream/remoteMediaManager.js +657 -448
- package/dist/multistream/remoteMediaManager.js.map +1 -1
- package/dist/multistream/sendSlotManager.js +255 -0
- package/dist/multistream/sendSlotManager.js.map +1 -0
- package/dist/networkQualityMonitor/index.js +40 -59
- package/dist/networkQualityMonitor/index.js.map +1 -1
- package/dist/personal-meeting-room/index.js +21 -45
- package/dist/personal-meeting-room/index.js.map +1 -1
- package/dist/personal-meeting-room/request.js +1 -31
- package/dist/personal-meeting-room/request.js.map +1 -1
- package/dist/personal-meeting-room/util.js +0 -13
- package/dist/personal-meeting-room/util.js.map +1 -1
- package/dist/reachability/clusterReachability.js +356 -0
- package/dist/reachability/clusterReachability.js.map +1 -0
- package/dist/reachability/index.js +297 -460
- package/dist/reachability/index.js.map +1 -1
- package/dist/reachability/request.js +20 -26
- package/dist/reachability/request.js.map +1 -1
- package/dist/reachability/util.js +29 -0
- package/dist/reachability/util.js.map +1 -0
- 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 +413 -483
- package/dist/reconnection-manager/index.js.map +1 -1
- package/dist/recording-controller/enums.js +17 -0
- package/dist/recording-controller/enums.js.map +1 -0
- package/dist/recording-controller/index.js +362 -0
- package/dist/recording-controller/index.js.map +1 -0
- package/dist/recording-controller/util.js +64 -0
- package/dist/recording-controller/util.js.map +1 -0
- package/dist/roap/index.js +102 -86
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +131 -135
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/turnDiscovery.js +437 -116
- 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 +179 -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 +557 -583
- package/dist/statsAnalyzer/index.js.map +1 -1
- package/dist/statsAnalyzer/mqaUtil.js +326 -130
- package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
- package/dist/transcription/index.js +22 -47
- package/dist/transcription/index.js.map +1 -1
- package/dist/types/annotation/annotation.types.d.ts +42 -0
- package/dist/types/annotation/constants.d.ts +31 -0
- package/dist/types/annotation/index.d.ts +117 -0
- package/dist/types/breakouts/breakout.d.ts +8 -0
- package/dist/types/breakouts/collection.d.ts +5 -0
- package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
- package/dist/types/breakouts/events.d.ts +8 -0
- package/dist/types/breakouts/index.d.ts +5 -0
- package/dist/types/breakouts/request.d.ts +22 -0
- package/dist/types/breakouts/utils.d.ts +15 -0
- package/dist/types/common/browser-detection.d.ts +9 -0
- package/dist/types/common/collection.d.ts +48 -0
- package/dist/types/common/config.d.ts +2 -0
- package/dist/types/common/errors/captcha-error.d.ts +15 -0
- package/dist/types/common/errors/intent-to-join.d.ts +16 -0
- package/dist/types/common/errors/join-meeting.d.ts +17 -0
- package/dist/types/common/errors/media.d.ts +15 -0
- package/dist/types/common/errors/no-meeting-info.d.ts +14 -0
- package/dist/types/common/errors/parameter.d.ts +15 -0
- package/dist/types/common/errors/password-error.d.ts +15 -0
- package/dist/types/common/errors/permission.d.ts +14 -0
- package/dist/types/common/errors/reclaim-host-role-errors.d.ts +60 -0
- package/dist/types/common/errors/reconnection-in-progress.d.ts +9 -0
- package/dist/types/common/errors/reconnection.d.ts +15 -0
- package/dist/types/common/errors/stats.d.ts +15 -0
- package/dist/types/common/errors/webex-errors.d.ts +93 -0
- package/dist/types/common/errors/webex-meetings-error.d.ts +20 -0
- package/dist/types/common/events/events-scope.d.ts +17 -0
- package/dist/types/common/events/events.d.ts +12 -0
- package/dist/types/common/events/trigger-proxy.d.ts +2 -0
- package/dist/types/common/events/util.d.ts +2 -0
- package/dist/types/common/logs/logger-config.d.ts +2 -0
- package/dist/types/common/logs/logger-proxy.d.ts +2 -0
- package/dist/types/common/logs/request.d.ts +36 -0
- package/dist/types/common/queue.d.ts +34 -0
- package/dist/types/config.d.ts +72 -0
- package/dist/types/constants.d.ts +1088 -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/interceptors/index.d.ts +2 -0
- package/dist/types/interceptors/locusRetry.d.ts +27 -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 +272 -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 +241 -0
- package/dist/types/meeting/in-meeting-actions.d.ts +167 -0
- package/dist/types/meeting/index.d.ts +1824 -0
- package/dist/types/meeting/locusMediaRequest.d.ts +74 -0
- package/dist/types/meeting/muteState.d.ts +178 -0
- package/dist/types/meeting/request.d.ts +293 -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 +118 -0
- package/dist/types/meeting/voicea-meeting.d.ts +16 -0
- package/dist/types/meeting-info/collection.d.ts +20 -0
- package/dist/types/meeting-info/index.d.ts +69 -0
- package/dist/types/meeting-info/meeting-info-v2.d.ts +123 -0
- package/dist/types/meeting-info/request.d.ts +22 -0
- package/dist/types/meeting-info/util.d.ts +2 -0
- package/dist/types/meeting-info/utilv2.d.ts +2 -0
- package/dist/types/meetings/collection.d.ts +40 -0
- package/dist/types/meetings/index.d.ts +389 -0
- package/dist/types/meetings/meetings.types.d.ts +4 -0
- package/dist/types/meetings/request.d.ts +27 -0
- package/dist/types/meetings/util.d.ts +18 -0
- package/dist/types/member/index.d.ts +160 -0
- package/dist/types/member/types.d.ts +32 -0
- package/dist/types/member/util.d.ts +2 -0
- package/dist/types/members/collection.d.ts +29 -0
- package/dist/types/members/index.d.ts +353 -0
- package/dist/types/members/request.d.ts +114 -0
- package/dist/types/members/types.d.ts +25 -0
- package/dist/types/members/util.d.ts +215 -0
- package/dist/types/metrics/constants.d.ts +70 -0
- package/dist/types/metrics/index.d.ts +45 -0
- package/dist/types/multistream/mediaRequestManager.d.ts +120 -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 +49 -0
- package/dist/types/multistream/remoteMediaManager.d.ts +301 -0
- package/dist/types/multistream/sendSlotManager.d.ts +70 -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/clusterReachability.d.ts +109 -0
- package/dist/types/reachability/index.d.ts +105 -0
- package/dist/types/reachability/request.d.ts +39 -0
- package/dist/types/reachability/util.d.ts +8 -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 +136 -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 +86 -0
- package/dist/types/roap/request.d.ts +39 -0
- package/dist/types/roap/turnDiscovery.d.ts +155 -0
- package/dist/types/rtcMetrics/constants.d.ts +4 -0
- package/dist/types/rtcMetrics/index.d.ts +61 -0
- package/dist/types/statsAnalyzer/global.d.ts +36 -0
- package/dist/types/statsAnalyzer/index.d.ts +217 -0
- package/dist/types/statsAnalyzer/mqaUtil.d.ts +48 -0
- package/dist/types/transcription/index.d.ts +64 -0
- package/dist/types/webinar/collection.d.ts +16 -0
- package/dist/types/webinar/index.d.ts +5 -0
- package/dist/webinar/collection.js +44 -0
- package/dist/webinar/collection.js.map +1 -0
- package/dist/webinar/index.js +69 -0
- package/dist/webinar/index.js.map +1 -0
- package/internal-README.md +7 -6
- package/package.json +30 -21
- package/src/annotation/annotation.types.ts +50 -0
- package/src/annotation/constants.ts +36 -0
- package/src/annotation/index.ts +328 -0
- package/src/breakouts/README.md +220 -0
- package/src/breakouts/breakout.ts +188 -0
- package/src/breakouts/collection.ts +19 -0
- package/src/breakouts/edit-lock-error.ts +25 -0
- package/src/breakouts/events.ts +56 -0
- package/src/breakouts/index.ts +925 -0
- package/src/breakouts/request.ts +55 -0
- package/src/breakouts/utils.ts +57 -0
- package/src/common/{browser-detection.js → browser-detection.ts} +9 -6
- package/src/common/collection.ts +9 -7
- package/src/common/{config.js → config.ts} +1 -1
- package/src/common/errors/{captcha-error.js → captcha-error.ts} +11 -7
- package/src/common/errors/{intent-to-join.js → intent-to-join.ts} +12 -7
- package/src/common/errors/{join-meeting.js → join-meeting.ts} +17 -8
- package/src/common/errors/{media.js → media.ts} +11 -7
- package/src/common/errors/no-meeting-info.ts +24 -0
- package/src/common/errors/parameter.ts +11 -7
- package/src/common/errors/{password-error.js → password-error.ts} +11 -7
- package/src/common/errors/{permission.js → permission.ts} +10 -6
- package/src/common/errors/reclaim-host-role-errors.ts +134 -0
- package/src/common/errors/{reconnection.js → reconnection.ts} +11 -7
- package/src/common/errors/{stats.js → stats.ts} +11 -7
- package/src/common/errors/{webex-errors.js → webex-errors.ts} +51 -8
- package/src/common/errors/{webex-meetings-error.js → webex-meetings-error.ts} +4 -2
- package/src/common/events/{events-scope.js → events-scope.ts} +6 -2
- package/src/common/events/{events.js → events.ts} +5 -1
- package/src/common/events/{trigger-proxy.js → trigger-proxy.ts} +9 -5
- package/src/common/events/{util.js → util.ts} +2 -3
- package/src/common/logs/{logger-config.js → logger-config.ts} +1 -2
- package/src/common/logs/logger-proxy.ts +44 -0
- package/src/common/logs/{request.js → request.ts} +26 -9
- package/src/common/queue.ts +22 -9
- package/src/{config.js → config.ts} +19 -21
- package/src/constants.ts +296 -27
- 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 +45 -0
- package/src/interceptors/index.ts +3 -0
- package/src/interceptors/locusRetry.ts +67 -0
- package/src/interpretation/README.md +60 -0
- package/src/interpretation/collection.ts +19 -0
- package/src/interpretation/index.ts +349 -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} +561 -119
- package/src/locus-info/{infoUtils.js → infoUtils.ts} +29 -10
- package/src/locus-info/{mediaSharesUtils.js → mediaSharesUtils.ts} +97 -17
- package/src/locus-info/{parser.js → parser.ts} +303 -104
- package/src/locus-info/{selfUtils.js → selfUtils.ts} +199 -68
- package/src/media/index.ts +460 -0
- package/src/media/properties.ts +283 -0
- package/src/media/{util.js → util.ts} +2 -2
- package/src/mediaQualityMetrics/config.ts +249 -0
- package/src/meeting/in-meeting-actions.ts +199 -3
- package/src/meeting/index.ts +8494 -0
- package/src/meeting/locusMediaRequest.ts +313 -0
- package/src/meeting/muteState.ts +465 -0
- package/src/meeting/request.ts +912 -0
- package/src/meeting/request.type.ts +13 -0
- package/src/meeting/{state.js → state.ts} +50 -35
- package/src/meeting/util.ts +799 -0
- package/src/meeting/voicea-meeting.ts +122 -0
- package/src/meeting-info/{collection.js → collection.ts} +6 -2
- package/src/meeting-info/index.ts +210 -0
- package/src/meeting-info/meeting-info-v2.ts +423 -0
- package/src/meeting-info/{request.js → request.ts} +14 -4
- package/src/meeting-info/{util.js → util.ts} +70 -58
- package/src/meeting-info/{utilv2.js → utilv2.ts} +99 -82
- package/src/meetings/collection.ts +76 -0
- package/src/meetings/index.ts +1539 -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} +133 -38
- package/src/member/{index.js → index.ts} +159 -56
- package/src/member/types.ts +38 -0
- package/src/member/util.ts +397 -0
- package/src/members/{collection.js → collection.ts} +10 -2
- package/src/members/{index.js → index.ts} +351 -146
- package/src/members/request.ts +255 -0
- package/src/members/types.ts +29 -0
- package/src/members/util.ts +353 -0
- package/src/metrics/{constants.js → constants.ts} +17 -6
- package/src/metrics/index.ts +73 -0
- package/src/multistream/mediaRequestManager.ts +341 -64
- 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 +82 -3
- package/src/multistream/remoteMediaManager.ts +401 -81
- package/src/multistream/sendSlotManager.ts +199 -0
- package/src/networkQualityMonitor/{index.js → index.ts} +41 -29
- package/src/personal-meeting-room/{index.js → index.ts} +28 -19
- package/src/personal-meeting-room/{request.js → request.ts} +13 -4
- package/src/personal-meeting-room/{util.js → util.ts} +4 -4
- package/src/reachability/clusterReachability.ts +320 -0
- package/src/reachability/index.ts +371 -0
- package/src/reachability/request.ts +50 -35
- package/src/reachability/util.ts +24 -0
- 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.ts +643 -0
- package/src/recording-controller/enums.ts +8 -0
- package/src/recording-controller/index.ts +332 -0
- package/src/recording-controller/util.ts +75 -0
- package/src/roap/index.ts +288 -0
- package/src/roap/request.ts +153 -0
- package/src/roap/turnDiscovery.ts +374 -70
- package/src/rtcMetrics/constants.ts +3 -0
- package/src/rtcMetrics/index.ts +166 -0
- package/src/statsAnalyzer/global.ts +37 -0
- package/src/statsAnalyzer/index.ts +1275 -0
- package/src/statsAnalyzer/mqaUtil.ts +440 -0
- package/src/transcription/{index.js → index.ts} +46 -39
- package/src/webinar/collection.ts +31 -0
- package/src/webinar/index.ts +62 -0
- package/test/integration/spec/converged-space-meetings.js +233 -0
- package/test/integration/spec/journey.js +791 -531
- 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 +238 -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 +1793 -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/interceptors/locusRetry.ts +131 -0
- package/test/unit/spec/interpretation/collection.ts +15 -0
- package/test/unit/spec/interpretation/index.ts +625 -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 +1458 -21
- package/test/unit/spec/locus-info/infoUtils.js +71 -40
- package/test/unit/spec/locus-info/lib/BasicSeqCmp.json +88 -430
- package/test/unit/spec/locus-info/lib/SeqCmp.json +529 -685
- package/test/unit/spec/locus-info/mediaSharesUtils.ts +41 -0
- package/test/unit/spec/locus-info/parser.js +119 -44
- package/test/unit/spec/locus-info/selfConstant.js +120 -103
- package/test/unit/spec/locus-info/selfUtils.js +291 -12
- package/test/unit/spec/media/index.ts +194 -111
- package/test/unit/spec/media/properties.ts +11 -11
- package/test/unit/spec/meeting/in-meeting-actions.ts +96 -3
- package/test/unit/spec/meeting/index.js +8616 -1921
- package/test/unit/spec/meeting/locusMediaRequest.ts +442 -0
- package/test/unit/spec/meeting/muteState.js +568 -207
- package/test/unit/spec/meeting/request.js +602 -82
- package/test/unit/spec/meeting/utils.js +867 -179
- package/test/unit/spec/meeting/voicea-meeting.ts +266 -0
- package/test/unit/spec/meeting-info/index.js +300 -0
- package/test/unit/spec/meeting-info/meetinginfov2.js +631 -78
- 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 +27 -1
- package/test/unit/spec/meetings/index.js +1826 -374
- package/test/unit/spec/meetings/utils.js +243 -14
- package/test/unit/spec/member/index.js +61 -7
- package/test/unit/spec/member/util.js +526 -26
- package/test/unit/spec/members/index.js +536 -55
- package/test/unit/spec/members/request.js +228 -40
- package/test/unit/spec/members/utils.js +217 -4
- package/test/unit/spec/metrics/index.js +13 -68
- package/test/unit/spec/multistream/mediaRequestManager.ts +1032 -110
- 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 +350 -5
- package/test/unit/spec/multistream/remoteMediaManager.ts +937 -65
- package/test/unit/spec/multistream/sendSlotManager.ts +274 -0
- package/test/unit/spec/networkQualityMonitor/index.js +24 -18
- package/test/unit/spec/personal-meeting-room/personal-meeting-room.js +2 -7
- package/test/unit/spec/reachability/clusterReachability.ts +279 -0
- package/test/unit/spec/reachability/index.ts +606 -26
- package/test/unit/spec/reachability/request.js +68 -0
- package/test/unit/spec/reachability/util.ts +40 -0
- package/test/unit/spec/reconnection-manager/index.js +222 -34
- package/test/unit/spec/recording-controller/index.js +306 -0
- package/test/unit/spec/recording-controller/util.js +229 -0
- package/test/unit/spec/roap/index.ts +238 -82
- package/test/unit/spec/roap/request.ts +255 -0
- package/test/unit/spec/roap/turnDiscovery.ts +707 -110
- package/test/unit/spec/rtcMetrics/index.ts +122 -0
- package/test/unit/spec/stats-analyzer/index.js +1331 -62
- package/test/unit/spec/webinar/collection.ts +13 -0
- package/test/unit/spec/webinar/index.ts +60 -0
- package/test/utils/cmr.js +44 -42
- package/test/utils/constants.js +9 -0
- package/test/utils/integrationTestUtils.js +46 -0
- package/test/utils/testUtils.js +63 -99
- package/test/utils/webex-config.js +22 -18
- package/test/utils/webex-test-users.js +65 -50
- package/tsconfig.json +6 -0
- package/dist/media/internal-media-core-wrapper.js +0 -22
- package/dist/media/internal-media-core-wrapper.js.map +0 -1
- package/dist/meeting/effectsState.js +0 -327
- package/dist/meeting/effectsState.js.map +0 -1
- package/dist/metrics/config.js +0 -301
- package/dist/metrics/config.js.map +0 -1
- package/dist/multistream/multistreamMedia.js +0 -116
- package/dist/multistream/multistreamMedia.js.map +0 -1
- package/dist/peer-connection-manager/util.js +0 -124
- package/dist/peer-connection-manager/util.js.map +0 -1
- package/src/common/logs/logger-proxy.js +0 -33
- package/src/index.js +0 -15
- package/src/locus-info/controlsUtils.js +0 -102
- package/src/media/index.js +0 -459
- package/src/media/internal-media-core-wrapper.ts +0 -9
- package/src/media/properties.js +0 -289
- package/src/mediaQualityMetrics/config.js +0 -382
- package/src/meeting/effectsState.js +0 -205
- package/src/meeting/index.js +0 -6284
- package/src/meeting/muteState.js +0 -318
- package/src/meeting/request.js +0 -684
- 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/collection.js +0 -40
- package/src/meetings/index.js +0 -1015
- package/src/member/util.js +0 -254
- package/src/members/request.js +0 -131
- package/src/members/util.js +0 -258
- package/src/metrics/config.js +0 -324
- package/src/metrics/index.js +0 -530
- package/src/multistream/multistreamMedia.ts +0 -92
- package/src/peer-connection-manager/util.ts +0 -117
- package/src/reachability/index.js +0 -464
- package/src/reconnection-manager/index.js +0 -519
- package/src/roap/index.js +0 -220
- package/src/roap/request.js +0 -127
- package/src/statsAnalyzer/global.js +0 -133
- package/src/statsAnalyzer/index.js +0 -1006
- package/src/statsAnalyzer/mqaUtil.js +0 -173
- package/test/unit/spec/meeting/effectsState.js +0 -291
- package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -389
- /package/src/common/errors/{reconnection-in-progress.js → reconnection-in-progress.ts} +0 -0
|
@@ -1,13 +1,20 @@
|
|
|
1
|
-
|
|
1
|
+
/* eslint-disable valid-jsdoc */
|
|
2
|
+
import {
|
|
3
|
+
MediaType,
|
|
4
|
+
ReceiveSlot as WcmeReceiveSlot,
|
|
5
|
+
ReceiveSlotEvents as WcmeReceiveSlotEvents,
|
|
6
|
+
StreamState,
|
|
7
|
+
} from '@webex/internal-media-core';
|
|
2
8
|
|
|
3
9
|
import LoggerProxy from '../common/logs/logger-proxy';
|
|
4
10
|
import EventsScope from '../common/events/events-scope';
|
|
5
11
|
|
|
6
12
|
export const ReceiveSlotEvents = {
|
|
7
13
|
SourceUpdate: 'sourceUpdate',
|
|
14
|
+
MaxFsUpdate: 'maxFsUpdate',
|
|
8
15
|
};
|
|
9
16
|
|
|
10
|
-
export type
|
|
17
|
+
export type {StreamState} from '@webex/internal-media-core';
|
|
11
18
|
export type CSI = number;
|
|
12
19
|
export type MemberId = string;
|
|
13
20
|
export type ReceiveSlotId = string;
|
|
@@ -21,31 +28,31 @@ export type FindMemberIdCallback = (csi: CSI) => MemberId | undefined;
|
|
|
21
28
|
* for example some participant's main video or audio
|
|
22
29
|
*/
|
|
23
30
|
export class ReceiveSlot extends EventsScope {
|
|
24
|
-
private readonly mcReceiveSlot:
|
|
31
|
+
private readonly mcReceiveSlot: WcmeReceiveSlot;
|
|
25
32
|
|
|
26
33
|
private readonly findMemberIdCallback: FindMemberIdCallback;
|
|
27
34
|
|
|
28
35
|
public readonly id: ReceiveSlotId;
|
|
29
36
|
|
|
30
|
-
public readonly mediaType:
|
|
37
|
+
public readonly mediaType: MediaType;
|
|
31
38
|
|
|
32
39
|
#memberId?: MemberId;
|
|
33
40
|
|
|
34
41
|
#csi?: CSI;
|
|
35
42
|
|
|
36
|
-
#sourceState:
|
|
43
|
+
#sourceState: StreamState;
|
|
37
44
|
|
|
38
45
|
/**
|
|
39
46
|
* constructor - don't use it directly, you should always use meeting.receiveSlotManager.allocateSlot()
|
|
40
47
|
* to create any receive slots
|
|
41
48
|
*
|
|
42
|
-
* @param {
|
|
43
|
-
* @param {
|
|
49
|
+
* @param {MediaType} mediaType
|
|
50
|
+
* @param {ReceiveSlot} mcReceiveSlot
|
|
44
51
|
* @param {FindMemberIdCallback} findMemberIdCallback callback for finding memberId for given CSI
|
|
45
52
|
*/
|
|
46
53
|
constructor(
|
|
47
|
-
mediaType:
|
|
48
|
-
mcReceiveSlot:
|
|
54
|
+
mediaType: MediaType,
|
|
55
|
+
mcReceiveSlot: WcmeReceiveSlot,
|
|
49
56
|
findMemberIdCallback: FindMemberIdCallback
|
|
50
57
|
) {
|
|
51
58
|
super();
|
|
@@ -75,6 +82,25 @@ export class ReceiveSlot extends EventsScope {
|
|
|
75
82
|
return this.#csi;
|
|
76
83
|
}
|
|
77
84
|
|
|
85
|
+
/**
|
|
86
|
+
* Set the max frame size for this slot
|
|
87
|
+
* @param newFs frame size
|
|
88
|
+
*/
|
|
89
|
+
public setMaxFs(newFs) {
|
|
90
|
+
// emit event for media request manager to listen to
|
|
91
|
+
|
|
92
|
+
this.emit(
|
|
93
|
+
{
|
|
94
|
+
file: 'meeting/receiveSlot',
|
|
95
|
+
function: 'findMemberId',
|
|
96
|
+
},
|
|
97
|
+
ReceiveSlotEvents.MaxFsUpdate,
|
|
98
|
+
{
|
|
99
|
+
maxFs: newFs,
|
|
100
|
+
}
|
|
101
|
+
);
|
|
102
|
+
}
|
|
103
|
+
|
|
78
104
|
/**
|
|
79
105
|
* Getter for sourceState
|
|
80
106
|
*/
|
|
@@ -85,15 +111,15 @@ export class ReceiveSlot extends EventsScope {
|
|
|
85
111
|
/**
|
|
86
112
|
* registers event handlers with the underlying ReceiveSlot
|
|
87
113
|
*/
|
|
88
|
-
setupEventListeners() {
|
|
114
|
+
private setupEventListeners() {
|
|
89
115
|
const scope = {
|
|
90
116
|
file: 'meeting/receiveSlot',
|
|
91
117
|
function: 'setupEventListeners',
|
|
92
118
|
};
|
|
93
119
|
|
|
94
120
|
this.mcReceiveSlot.on(
|
|
95
|
-
|
|
96
|
-
(state:
|
|
121
|
+
WcmeReceiveSlotEvents.SourceUpdate,
|
|
122
|
+
(state: StreamState, csi?: number) => {
|
|
97
123
|
LoggerProxy.logger.log(
|
|
98
124
|
`ReceiveSlot#setupEventListeners --> got source update on receive slot ${this.id}, mediaType=${this.mediaType}, csi=${csi}, state=${state}`
|
|
99
125
|
);
|
|
@@ -110,6 +136,36 @@ export class ReceiveSlot extends EventsScope {
|
|
|
110
136
|
);
|
|
111
137
|
}
|
|
112
138
|
|
|
139
|
+
/** Tries to find the member id for this receive slot if it hasn't got one */
|
|
140
|
+
public findMemberId() {
|
|
141
|
+
if (this.#memberId === undefined && this.#csi) {
|
|
142
|
+
this.#memberId = this.findMemberIdCallback(this.#csi);
|
|
143
|
+
|
|
144
|
+
if (this.#memberId) {
|
|
145
|
+
// if we found the memberId, simulate source update so that the client app knows that something's changed
|
|
146
|
+
this.emit(
|
|
147
|
+
{
|
|
148
|
+
file: 'meeting/receiveSlot',
|
|
149
|
+
function: 'findMemberId',
|
|
150
|
+
},
|
|
151
|
+
ReceiveSlotEvents.SourceUpdate,
|
|
152
|
+
{
|
|
153
|
+
state: this.#sourceState,
|
|
154
|
+
csi: this.#csi,
|
|
155
|
+
memberId: this.#memberId,
|
|
156
|
+
}
|
|
157
|
+
);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
/**
|
|
163
|
+
* @returns {string} a log message used to identify the receive slot
|
|
164
|
+
*/
|
|
165
|
+
public get logString() {
|
|
166
|
+
return `ReceiveSlot - ${this.id}: ${JSON.stringify(this.mcReceiveSlot.id)}`;
|
|
167
|
+
}
|
|
168
|
+
|
|
113
169
|
/**
|
|
114
170
|
* The MediaStream object associated with this slot.
|
|
115
171
|
*
|
|
@@ -122,20 +178,7 @@ export class ReceiveSlot extends EventsScope {
|
|
|
122
178
|
/**
|
|
123
179
|
* The underlying WCME receive slot
|
|
124
180
|
*/
|
|
125
|
-
get wcmeReceiveSlot():
|
|
181
|
+
get wcmeReceiveSlot(): WcmeReceiveSlot {
|
|
126
182
|
return this.mcReceiveSlot;
|
|
127
183
|
}
|
|
128
|
-
|
|
129
|
-
/**
|
|
130
|
-
* Resets the source state to the default 'no source' value.
|
|
131
|
-
* This function should be called on receive slots that are
|
|
132
|
-
* no longer part of a media request. It's needed because WCME
|
|
133
|
-
* does not send any more events on such slots, so the sourceState
|
|
134
|
-
* value would not represent the truth anymore.
|
|
135
|
-
*/
|
|
136
|
-
public resetSourceState() {
|
|
137
|
-
this.#sourceState = 'no source';
|
|
138
|
-
this.#csi = undefined;
|
|
139
|
-
this.#memberId = undefined;
|
|
140
|
-
}
|
|
141
184
|
}
|
|
@@ -1,76 +1,76 @@
|
|
|
1
|
+
/* eslint-disable valid-jsdoc */
|
|
1
2
|
/* eslint-disable import/prefer-default-export */
|
|
2
|
-
import {
|
|
3
|
-
|
|
3
|
+
import {MediaType, ReceiveSlot as WcmeReceiveSlot} from '@webex/internal-media-core';
|
|
4
4
|
import LoggerProxy from '../common/logs/logger-proxy';
|
|
5
|
-
import Meeting from '../meeting';
|
|
6
5
|
|
|
7
|
-
import {
|
|
6
|
+
import {FindMemberIdCallback, ReceiveSlot} from './receiveSlot';
|
|
7
|
+
|
|
8
|
+
export type CreateSlotCallback = (mediaType: MediaType) => Promise<WcmeReceiveSlot>;
|
|
9
|
+
|
|
10
|
+
export type {CSI, FindMemberIdCallback} from './receiveSlot';
|
|
8
11
|
|
|
9
12
|
/**
|
|
10
13
|
* Manages all receive slots used by a meeting. WMCE receive slots cannot be ever deleted,
|
|
11
14
|
* so this manager has a pool in order to re-use the slots that were released earlier.
|
|
12
15
|
*/
|
|
13
16
|
export class ReceiveSlotManager {
|
|
14
|
-
private allocatedSlots: {[key in
|
|
17
|
+
private allocatedSlots: {[key in MediaType]: ReceiveSlot[]};
|
|
15
18
|
|
|
16
|
-
private freeSlots: {[key in
|
|
19
|
+
private freeSlots: {[key in MediaType]: ReceiveSlot[]};
|
|
17
20
|
|
|
18
|
-
private
|
|
21
|
+
private createSlotCallback: CreateSlotCallback;
|
|
22
|
+
|
|
23
|
+
private findMemberIdByCsiCallback: FindMemberIdCallback;
|
|
19
24
|
|
|
20
25
|
/**
|
|
21
26
|
* Constructor
|
|
22
27
|
* @param {Meeting} meeting
|
|
23
28
|
*/
|
|
24
|
-
constructor(
|
|
29
|
+
constructor(
|
|
30
|
+
createSlotCallback: CreateSlotCallback,
|
|
31
|
+
findMemberIdByCsiCallback: FindMemberIdCallback
|
|
32
|
+
) {
|
|
25
33
|
this.allocatedSlots = {
|
|
26
|
-
[
|
|
27
|
-
[
|
|
28
|
-
[
|
|
29
|
-
[
|
|
34
|
+
[MediaType.AudioMain]: [],
|
|
35
|
+
[MediaType.VideoMain]: [],
|
|
36
|
+
[MediaType.AudioSlides]: [],
|
|
37
|
+
[MediaType.VideoSlides]: [],
|
|
30
38
|
};
|
|
31
39
|
this.freeSlots = {
|
|
32
|
-
[
|
|
33
|
-
[
|
|
34
|
-
[
|
|
35
|
-
[
|
|
40
|
+
[MediaType.AudioMain]: [],
|
|
41
|
+
[MediaType.VideoMain]: [],
|
|
42
|
+
[MediaType.AudioSlides]: [],
|
|
43
|
+
[MediaType.VideoSlides]: [],
|
|
36
44
|
};
|
|
37
|
-
this.
|
|
45
|
+
this.createSlotCallback = createSlotCallback;
|
|
46
|
+
this.findMemberIdByCsiCallback = findMemberIdByCsiCallback;
|
|
38
47
|
}
|
|
39
48
|
|
|
40
49
|
/**
|
|
41
50
|
* Creates a new receive slot or returns one from the existing pool of free slots
|
|
42
51
|
*
|
|
43
|
-
* @param {
|
|
52
|
+
* @param {MediaType} mediaType
|
|
44
53
|
* @returns {Promise<ReceiveSlot>}
|
|
45
54
|
*/
|
|
46
|
-
async allocateSlot(mediaType:
|
|
47
|
-
if (!this.meeting?.mediaProperties?.webrtcMediaConnection) {
|
|
48
|
-
return Promise.reject(new Error('Webrtc media connection is missing'));
|
|
49
|
-
}
|
|
50
|
-
|
|
55
|
+
async allocateSlot(mediaType: MediaType): Promise<ReceiveSlot> {
|
|
51
56
|
// try to use one of the free ones
|
|
52
57
|
const availableSlot = this.freeSlots[mediaType].pop();
|
|
53
58
|
|
|
54
59
|
if (availableSlot) {
|
|
55
60
|
this.allocatedSlots[mediaType].push(availableSlot);
|
|
56
61
|
|
|
57
|
-
LoggerProxy.logger.log(
|
|
62
|
+
LoggerProxy.logger.log(`${mediaType}: receive slot re-used: ${availableSlot.id}`);
|
|
58
63
|
|
|
59
64
|
return availableSlot;
|
|
60
65
|
}
|
|
61
66
|
|
|
62
67
|
// we have to create a new one
|
|
63
|
-
const wcmeReceiveSlot =
|
|
64
|
-
await this.meeting.mediaProperties.webrtcMediaConnection.createReceiveSlot(mediaType);
|
|
68
|
+
const wcmeReceiveSlot = await this.createSlotCallback(mediaType);
|
|
65
69
|
|
|
66
|
-
const receiveSlot = new ReceiveSlot(
|
|
67
|
-
mediaType,
|
|
68
|
-
wcmeReceiveSlot,
|
|
69
|
-
(csi: CSI) => this.meeting.members.findMemberByCsi(csi)?.id
|
|
70
|
-
);
|
|
70
|
+
const receiveSlot = new ReceiveSlot(mediaType, wcmeReceiveSlot, this.findMemberIdByCsiCallback);
|
|
71
71
|
|
|
72
72
|
this.allocatedSlots[mediaType].push(receiveSlot);
|
|
73
|
-
LoggerProxy.logger.log(
|
|
73
|
+
LoggerProxy.logger.log(`${mediaType}: new receive slot allocated: ${receiveSlot.id}`);
|
|
74
74
|
|
|
75
75
|
return receiveSlot;
|
|
76
76
|
}
|
|
@@ -87,10 +87,10 @@ export class ReceiveSlotManager {
|
|
|
87
87
|
if (idx >= 0) {
|
|
88
88
|
this.allocatedSlots[slot.mediaType].splice(idx, 1);
|
|
89
89
|
this.freeSlots[slot.mediaType].push(slot);
|
|
90
|
-
LoggerProxy.logger.log(
|
|
90
|
+
LoggerProxy.logger.log(`${slot.mediaType}: receive slot released: ${slot.id}`);
|
|
91
91
|
} else {
|
|
92
92
|
LoggerProxy.logger.warn(
|
|
93
|
-
|
|
93
|
+
`ReceiveSlotManager#releaseSlot --> trying to release a ${slot.mediaType}} slot that is not managed by this ReceiveSlotManager`
|
|
94
94
|
);
|
|
95
95
|
}
|
|
96
96
|
}
|
|
@@ -100,16 +100,16 @@ export class ReceiveSlotManager {
|
|
|
100
100
|
*/
|
|
101
101
|
reset() {
|
|
102
102
|
this.allocatedSlots = {
|
|
103
|
-
[
|
|
104
|
-
[
|
|
105
|
-
[
|
|
106
|
-
[
|
|
103
|
+
[MediaType.AudioMain]: [],
|
|
104
|
+
[MediaType.VideoMain]: [],
|
|
105
|
+
[MediaType.AudioSlides]: [],
|
|
106
|
+
[MediaType.VideoSlides]: [],
|
|
107
107
|
};
|
|
108
108
|
this.freeSlots = {
|
|
109
|
-
[
|
|
110
|
-
[
|
|
111
|
-
[
|
|
112
|
-
[
|
|
109
|
+
[MediaType.AudioMain]: [],
|
|
110
|
+
[MediaType.VideoMain]: [],
|
|
111
|
+
[MediaType.AudioSlides]: [],
|
|
112
|
+
[MediaType.VideoSlides]: [],
|
|
113
113
|
};
|
|
114
114
|
}
|
|
115
115
|
|
|
@@ -139,4 +139,28 @@ export class ReceiveSlotManager {
|
|
|
139
139
|
numFreeSlots,
|
|
140
140
|
};
|
|
141
141
|
}
|
|
142
|
+
|
|
143
|
+
/**
|
|
144
|
+
* Tries to find the member id on all allocated receive slots
|
|
145
|
+
* This function should be called when new members are added to the meeting.
|
|
146
|
+
*/
|
|
147
|
+
updateMemberIds() {
|
|
148
|
+
Object.keys(this.allocatedSlots).forEach((key) => {
|
|
149
|
+
this.allocatedSlots[key].forEach((slot: ReceiveSlot) => {
|
|
150
|
+
slot.findMemberId();
|
|
151
|
+
});
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
/**
|
|
156
|
+
* Find a receive slot by a ssrc.
|
|
157
|
+
*
|
|
158
|
+
* @param ssrc - The ssrc of the receive slot to find.
|
|
159
|
+
* @returns - The receive slot with this ssrc, undefined if not found.
|
|
160
|
+
*/
|
|
161
|
+
findReceiveSlotBySsrc(ssrc: number): ReceiveSlot | undefined {
|
|
162
|
+
return Object.values(this.allocatedSlots)
|
|
163
|
+
.flat()
|
|
164
|
+
.find((r) => ssrc && r.wcmeReceiveSlot?.id?.ssrc === ssrc);
|
|
165
|
+
}
|
|
142
166
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
/* eslint-disable valid-jsdoc */
|
|
2
|
+
import {MediaType, StreamState} from '@webex/internal-media-core';
|
|
2
3
|
import LoggerProxy from '../common/logs/logger-proxy';
|
|
3
4
|
import EventsScope from '../common/events/events-scope';
|
|
4
5
|
|
|
@@ -7,6 +8,7 @@ import {CSI, ReceiveSlot, ReceiveSlotEvents} from './receiveSlot';
|
|
|
7
8
|
|
|
8
9
|
export const RemoteMediaEvents = {
|
|
9
10
|
SourceUpdate: ReceiveSlotEvents.SourceUpdate,
|
|
11
|
+
Stopped: 'stopped',
|
|
10
12
|
};
|
|
11
13
|
|
|
12
14
|
export type RemoteVideoResolution =
|
|
@@ -55,7 +57,7 @@ export function getMaxFs(paneSize: RemoteVideoResolution): number {
|
|
|
55
57
|
}
|
|
56
58
|
|
|
57
59
|
type Options = {
|
|
58
|
-
resolution?: RemoteVideoResolution; // applies only to groups of type
|
|
60
|
+
resolution?: RemoteVideoResolution; // applies only to groups of type MediaType.VideoMain and MediaType.VideoSlides
|
|
59
61
|
};
|
|
60
62
|
|
|
61
63
|
export type RemoteMediaId = string;
|
|
@@ -100,6 +102,31 @@ export class RemoteMedia extends EventsScope {
|
|
|
100
102
|
this.id = `RM${remoteMediaCounter}-${this.receiveSlot.id}`;
|
|
101
103
|
}
|
|
102
104
|
|
|
105
|
+
/**
|
|
106
|
+
* Supply the width and height of the video element
|
|
107
|
+
* to restrict the requested resolution to this size
|
|
108
|
+
* @param width width of the video element
|
|
109
|
+
* @param height height of the video element
|
|
110
|
+
*/
|
|
111
|
+
public setSizeHint(width, height) {
|
|
112
|
+
// only base on height for now
|
|
113
|
+
let fs: number;
|
|
114
|
+
|
|
115
|
+
if (height < 135) {
|
|
116
|
+
fs = 60;
|
|
117
|
+
} else if (height < 270) {
|
|
118
|
+
fs = 240;
|
|
119
|
+
} else if (height < 540) {
|
|
120
|
+
fs = 920;
|
|
121
|
+
} else if (height <= 720) {
|
|
122
|
+
fs = 3600;
|
|
123
|
+
} else {
|
|
124
|
+
fs = 8192;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
this.receiveSlot?.setMaxFs(fs);
|
|
128
|
+
}
|
|
129
|
+
|
|
103
130
|
/**
|
|
104
131
|
* Invalidates the remote media by clearing the reference to a receive slot and
|
|
105
132
|
* cancelling the media request.
|
|
@@ -108,10 +135,18 @@ export class RemoteMedia extends EventsScope {
|
|
|
108
135
|
* @param {boolean} commit - whether to commit the cancellation of the media request
|
|
109
136
|
* @internal
|
|
110
137
|
*/
|
|
111
|
-
public stop(commit
|
|
138
|
+
public stop(commit = true) {
|
|
112
139
|
this.cancelMediaRequest(commit);
|
|
113
140
|
this.receiveSlot?.removeAllListeners();
|
|
114
141
|
this.receiveSlot = undefined;
|
|
142
|
+
this.emit(
|
|
143
|
+
{
|
|
144
|
+
file: 'multistream/remoteMedia',
|
|
145
|
+
function: 'stop',
|
|
146
|
+
},
|
|
147
|
+
RemoteMediaEvents.Stopped,
|
|
148
|
+
{}
|
|
149
|
+
);
|
|
115
150
|
}
|
|
116
151
|
|
|
117
152
|
/**
|
|
@@ -164,7 +199,7 @@ export class RemoteMedia extends EventsScope {
|
|
|
164
199
|
private setupEventListeners() {
|
|
165
200
|
if (this.receiveSlot) {
|
|
166
201
|
const scope = {
|
|
167
|
-
file: '
|
|
202
|
+
file: 'multistream/remoteMedia',
|
|
168
203
|
function: 'setupEventListeners',
|
|
169
204
|
};
|
|
170
205
|
|
|
@@ -177,7 +212,7 @@ export class RemoteMedia extends EventsScope {
|
|
|
177
212
|
/**
|
|
178
213
|
* Getter for mediaType
|
|
179
214
|
*/
|
|
180
|
-
public get mediaType() {
|
|
215
|
+
public get mediaType(): MediaType {
|
|
181
216
|
return this.receiveSlot?.mediaType;
|
|
182
217
|
}
|
|
183
218
|
|
|
@@ -198,7 +233,7 @@ export class RemoteMedia extends EventsScope {
|
|
|
198
233
|
/**
|
|
199
234
|
* Getter for source state
|
|
200
235
|
*/
|
|
201
|
-
public get sourceState() {
|
|
236
|
+
public get sourceState(): StreamState {
|
|
202
237
|
return this.receiveSlot?.sourceState;
|
|
203
238
|
}
|
|
204
239
|
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
/* eslint-disable valid-jsdoc */
|
|
2
2
|
/* eslint-disable require-jsdoc */
|
|
3
3
|
/* eslint-disable import/prefer-default-export */
|
|
4
|
+
import {forEach} from 'lodash';
|
|
5
|
+
import {NamedMediaGroup} from '@webex/json-multistream';
|
|
4
6
|
import LoggerProxy from '../common/logs/logger-proxy';
|
|
5
7
|
|
|
6
8
|
import {getMaxFs, RemoteMedia, RemoteVideoResolution} from './remoteMedia';
|
|
@@ -8,8 +10,9 @@ import {MediaRequestId, MediaRequestManager} from './mediaRequestManager';
|
|
|
8
10
|
import {CSI, ReceiveSlot} from './receiveSlot';
|
|
9
11
|
|
|
10
12
|
type Options = {
|
|
11
|
-
resolution?: RemoteVideoResolution; // applies only to groups of type
|
|
12
|
-
preferLiveVideo?: boolean; // applies only to groups of type
|
|
13
|
+
resolution?: RemoteVideoResolution; // applies only to groups of type MediaType.VideoMain and MediaType.VideoSlides
|
|
14
|
+
preferLiveVideo?: boolean; // applies only to groups of type MediaType.VideoMain and MediaType.VideoSlides
|
|
15
|
+
namedMediaGroup?: NamedMediaGroup; // applies only to named media groups for audio
|
|
13
16
|
};
|
|
14
17
|
|
|
15
18
|
export class RemoteMediaGroup {
|
|
@@ -62,9 +65,57 @@ export class RemoteMediaGroup {
|
|
|
62
65
|
// return a shallow copy so that the client cannot modify this.pinnedRemoteMedia array
|
|
63
66
|
return [...this.pinnedRemoteMedia];
|
|
64
67
|
}
|
|
68
|
+
|
|
65
69
|
return [...this.unpinnedRemoteMedia, ...this.pinnedRemoteMedia];
|
|
66
70
|
}
|
|
67
71
|
|
|
72
|
+
/**
|
|
73
|
+
* Sets CSIs for multiple RemoteMedia instances belonging to this RemoteMediaGroup.
|
|
74
|
+
* For each entry in the remoteMediaCsis array:
|
|
75
|
+
* - if csi is specified, the RemoteMedia instance is pinned to that CSI
|
|
76
|
+
* - if csi is undefined, the RemoteMedia instance is unpinned
|
|
77
|
+
* @internal
|
|
78
|
+
*/
|
|
79
|
+
public setActiveSpeakerCsis(
|
|
80
|
+
remoteMediaCsis: {remoteMedia: RemoteMedia; csi?: number}[],
|
|
81
|
+
commit = true
|
|
82
|
+
): void {
|
|
83
|
+
forEach(remoteMediaCsis, ({csi, remoteMedia}) => {
|
|
84
|
+
if (csi) {
|
|
85
|
+
if (!(this.pinnedRemoteMedia.indexOf(remoteMedia) >= 0)) {
|
|
86
|
+
const unpinId = this.unpinnedRemoteMedia.indexOf(remoteMedia);
|
|
87
|
+
if (unpinId >= 0) {
|
|
88
|
+
this.unpinnedRemoteMedia.splice(unpinId, 1);
|
|
89
|
+
this.pinnedRemoteMedia.push(remoteMedia);
|
|
90
|
+
} else {
|
|
91
|
+
throw new Error(
|
|
92
|
+
`failed to pin a remote media object ${remoteMedia.id}, because it is not found in this remote media group`
|
|
93
|
+
);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
remoteMedia.sendMediaRequest(csi, false);
|
|
97
|
+
} else {
|
|
98
|
+
if (!(this.unpinnedRemoteMedia.indexOf(remoteMedia) >= 0)) {
|
|
99
|
+
const pinId = this.pinnedRemoteMedia.indexOf(remoteMedia);
|
|
100
|
+
if (pinId >= 0) {
|
|
101
|
+
this.pinnedRemoteMedia.splice(pinId, 1);
|
|
102
|
+
this.unpinnedRemoteMedia.push(remoteMedia);
|
|
103
|
+
} else {
|
|
104
|
+
throw new Error(
|
|
105
|
+
`failed to unpin a remote media object ${remoteMedia.id}, because it is not found in this remote media group`
|
|
106
|
+
);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
remoteMedia.cancelMediaRequest(false);
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
this.cancelActiveSpeakerMediaRequest(false);
|
|
113
|
+
this.sendActiveSpeakerMediaRequest(false);
|
|
114
|
+
if (commit) {
|
|
115
|
+
this.mediaRequestManager.commit();
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
68
119
|
/**
|
|
69
120
|
* Pins a specific remote media instance to a specfic CSI, so the media will
|
|
70
121
|
* no longer come from active speaker, but from that CSI.
|
|
@@ -150,6 +201,17 @@ export class RemoteMediaGroup {
|
|
|
150
201
|
throw new Error(`remote media object ${remoteMedia.id} not found in the group`);
|
|
151
202
|
}
|
|
152
203
|
|
|
204
|
+
/**
|
|
205
|
+
* setPreferLiveVideo - sets preferLiveVideo to true/false
|
|
206
|
+
* @internal
|
|
207
|
+
*/
|
|
208
|
+
public setPreferLiveVideo(preferLiveVideo: boolean, commit: boolean) {
|
|
209
|
+
if (this.options.preferLiveVideo !== preferLiveVideo) {
|
|
210
|
+
this.options.preferLiveVideo = preferLiveVideo;
|
|
211
|
+
this.sendActiveSpeakerMediaRequest(commit);
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
|
|
153
215
|
private sendActiveSpeakerMediaRequest(commit: boolean) {
|
|
154
216
|
this.cancelActiveSpeakerMediaRequest(false);
|
|
155
217
|
|
|
@@ -161,6 +223,9 @@ export class RemoteMediaGroup {
|
|
|
161
223
|
crossPriorityDuplication: false,
|
|
162
224
|
crossPolicyDuplication: false,
|
|
163
225
|
preferLiveVideo: !!this.options?.preferLiveVideo,
|
|
226
|
+
namedMediaGroups: this.options.namedMediaGroup?.value
|
|
227
|
+
? [this.options?.namedMediaGroup]
|
|
228
|
+
: undefined,
|
|
164
229
|
},
|
|
165
230
|
receiveSlots: this.unpinnedRemoteMedia.map((remoteMedia) =>
|
|
166
231
|
remoteMedia.getUnderlyingReceiveSlot()
|
|
@@ -181,6 +246,20 @@ export class RemoteMediaGroup {
|
|
|
181
246
|
}
|
|
182
247
|
}
|
|
183
248
|
|
|
249
|
+
/**
|
|
250
|
+
* setNamedMediaGroup - sets named media group type and value
|
|
251
|
+
* @internal
|
|
252
|
+
*/
|
|
253
|
+
public setNamedMediaGroup(namedMediaGroup: NamedMediaGroup, commit: boolean) {
|
|
254
|
+
if (
|
|
255
|
+
this.options.namedMediaGroup.value !== namedMediaGroup.value ||
|
|
256
|
+
this.options.namedMediaGroup.type !== namedMediaGroup.type
|
|
257
|
+
) {
|
|
258
|
+
this.options.namedMediaGroup = namedMediaGroup;
|
|
259
|
+
this.sendActiveSpeakerMediaRequest(commit);
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
|
|
184
263
|
/**
|
|
185
264
|
* Invalidates the remote media group by clearing the references to the receive slots
|
|
186
265
|
* used by all remote media from that group and cancelling all media requests.
|
|
@@ -189,7 +268,7 @@ export class RemoteMediaGroup {
|
|
|
189
268
|
* @param{boolean} commit whether to commit the cancellation of media requests
|
|
190
269
|
* @internal
|
|
191
270
|
*/
|
|
192
|
-
public stop(commit
|
|
271
|
+
public stop(commit = true) {
|
|
193
272
|
this.unpinnedRemoteMedia.forEach((remoteMedia) => remoteMedia.stop(false));
|
|
194
273
|
this.pinnedRemoteMedia.forEach((remoteMedia) => remoteMedia.stop(false));
|
|
195
274
|
this.cancelActiveSpeakerMediaRequest(false);
|