@webex/plugin-meetings 3.0.0-beta.2 → 3.0.0-beta.20
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/UPGRADING.md +9 -9
- package/browsers.js +19 -24
- package/dist/breakouts/breakout.js +116 -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/index.js +226 -0
- package/dist/breakouts/index.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 +6 -41
- package/dist/common/errors/webex-errors.js.map +1 -1
- package/dist/common/errors/webex-meetings-error.js +5 -25
- package/dist/common/errors/webex-meetings-error.js.map +1 -1
- package/dist/common/events/events-scope.js +0 -22
- package/dist/common/events/events-scope.js.map +1 -1
- package/dist/common/events/events.js +0 -23
- package/dist/common/events/events.js.map +1 -1
- package/dist/common/events/trigger-proxy.js +0 -12
- package/dist/common/events/trigger-proxy.js.map +1 -1
- package/dist/common/events/util.js +0 -15
- package/dist/common/events/util.js.map +1 -1
- package/dist/common/logs/logger-config.js +0 -4
- package/dist/common/logs/logger-config.js.map +1 -1
- package/dist/common/logs/logger-proxy.js +1 -8
- package/dist/common/logs/logger-proxy.js.map +1 -1
- package/dist/common/logs/request.js +37 -60
- package/dist/common/logs/request.js.map +1 -1
- package/dist/common/queue.js +4 -14
- package/dist/common/queue.js.map +1 -1
- package/dist/config.js +6 -6
- package/dist/config.js.map +1 -1
- package/dist/constants.js +88 -46
- package/dist/constants.js.map +1 -1
- package/dist/index.js +1 -17
- package/dist/index.js.map +1 -1
- package/dist/locus-info/controlsUtils.js +12 -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 +184 -190
- package/dist/locus-info/index.js.map +1 -1
- package/dist/locus-info/infoUtils.js +3 -37
- package/dist/locus-info/infoUtils.js.map +1 -1
- package/dist/locus-info/mediaSharesUtils.js +12 -38
- package/dist/locus-info/mediaSharesUtils.js.map +1 -1
- package/dist/locus-info/parser.js +92 -118
- package/dist/locus-info/parser.js.map +1 -1
- package/dist/locus-info/selfUtils.js +34 -91
- package/dist/locus-info/selfUtils.js.map +1 -1
- package/dist/media/index.js +67 -111
- package/dist/media/index.js.map +1 -1
- package/dist/media/properties.js +80 -114
- 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 +10 -12
- package/dist/mediaQualityMetrics/config.js.map +1 -1
- package/dist/meeting/effectsState.js +125 -190
- package/dist/meeting/effectsState.js.map +1 -1
- package/dist/meeting/in-meeting-actions.js +5 -14
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +1692 -1925
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/muteState.js +36 -77
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +224 -230
- 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 +43 -215
- package/dist/meeting/util.js.map +1 -1
- package/dist/meeting-info/collection.js +6 -25
- package/dist/meeting-info/collection.js.map +1 -1
- package/dist/meeting-info/index.js +14 -32
- package/dist/meeting-info/index.js.map +1 -1
- package/dist/meeting-info/meeting-info-v2.js +193 -268
- 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 +137 -228
- package/dist/meeting-info/utilv2.js.map +1 -1
- package/dist/meetings/collection.js +5 -20
- package/dist/meetings/collection.js.map +1 -1
- package/dist/meetings/index.js +490 -560
- package/dist/meetings/index.js.map +1 -1
- package/dist/meetings/request.js +24 -41
- package/dist/meetings/request.js.map +1 -1
- package/dist/meetings/util.js +99 -155
- package/dist/meetings/util.js.map +1 -1
- package/dist/member/index.js +78 -86
- package/dist/member/index.js.map +1 -1
- package/dist/member/util.js +31 -68
- package/dist/member/util.js.map +1 -1
- package/dist/members/collection.js +3 -12
- package/dist/members/collection.js.map +1 -1
- package/dist/members/index.js +93 -200
- package/dist/members/index.js.map +1 -1
- package/dist/members/request.js +16 -39
- package/dist/members/request.js.map +1 -1
- package/dist/members/util.js +9 -38
- package/dist/members/util.js.map +1 -1
- package/dist/metrics/config.js +0 -2
- package/dist/metrics/config.js.map +1 -1
- package/dist/metrics/constants.js +1 -2
- package/dist/metrics/constants.js.map +1 -1
- package/dist/metrics/index.js +55 -135
- package/dist/metrics/index.js.map +1 -1
- package/dist/multistream/mediaRequestManager.js +57 -32
- package/dist/multistream/mediaRequestManager.js.map +1 -1
- package/dist/multistream/multistreamMedia.js +15 -21
- package/dist/multistream/multistreamMedia.js.map +1 -1
- package/dist/multistream/receiveSlot.js +10 -50
- package/dist/multistream/receiveSlot.js.map +1 -1
- package/dist/multistream/receiveSlotManager.js +45 -82
- package/dist/multistream/receiveSlotManager.js.map +1 -1
- package/dist/multistream/remoteMedia.js +18 -58
- package/dist/multistream/remoteMedia.js.map +1 -1
- package/dist/multistream/remoteMediaGroup.js +6 -40
- package/dist/multistream/remoteMediaGroup.js.map +1 -1
- package/dist/multistream/remoteMediaManager.js +362 -416
- package/dist/multistream/remoteMediaManager.js.map +1 -1
- package/dist/networkQualityMonitor/index.js +36 -57
- 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 +138 -182
- package/dist/reachability/index.js.map +1 -1
- package/dist/reachability/request.js +3 -18
- 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 +322 -455
- package/dist/reconnection-manager/index.js.map +1 -1
- package/dist/recording-controller/enums.js +17 -0
- package/dist/recording-controller/enums.js.map +1 -0
- package/dist/recording-controller/index.js +343 -0
- package/dist/recording-controller/index.js.map +1 -0
- package/dist/recording-controller/util.js +63 -0
- package/dist/recording-controller/util.js.map +1 -0
- package/dist/roap/index.js +39 -64
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +94 -113
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/turnDiscovery.js +85 -94
- package/dist/roap/turnDiscovery.js.map +1 -1
- package/dist/statsAnalyzer/global.js +0 -2
- package/dist/statsAnalyzer/global.js.map +1 -1
- package/dist/statsAnalyzer/index.js +85 -175
- package/dist/statsAnalyzer/index.js.map +1 -1
- package/dist/statsAnalyzer/mqaUtil.js +72 -53
- package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
- package/dist/transcription/index.js +22 -47
- package/dist/transcription/index.js.map +1 -1
- package/internal-README.md +7 -6
- package/package.json +25 -20
- package/src/breakouts/README.md +190 -0
- package/src/breakouts/breakout.ts +110 -0
- package/src/breakouts/collection.ts +19 -0
- package/src/breakouts/index.ts +225 -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-in-progress.js → reconnection-in-progress.ts} +0 -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} +8 -7
- package/src/common/errors/{webex-meetings-error.js → webex-meetings-error.ts} +4 -2
- package/src/common/events/{events-scope.js → events-scope.ts} +6 -2
- package/src/common/events/{events.js → events.ts} +5 -1
- package/src/common/events/{trigger-proxy.js → trigger-proxy.ts} +9 -5
- package/src/common/events/{util.js → util.ts} +2 -3
- package/src/common/logs/{logger-config.js → logger-config.ts} +1 -2
- package/src/common/logs/logger-proxy.ts +44 -0
- package/src/common/logs/{request.js → request.ts} +22 -9
- package/src/common/queue.ts +1 -2
- package/src/{config.js → config.ts} +17 -12
- package/src/constants.ts +40 -1
- package/src/index.js +1 -1
- package/src/locus-info/controlsUtils.ts +114 -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} +148 -64
- package/src/locus-info/{infoUtils.js → infoUtils.ts} +19 -8
- package/src/locus-info/{mediaSharesUtils.js → mediaSharesUtils.ts} +17 -17
- package/src/locus-info/{parser.js → parser.ts} +67 -79
- package/src/locus-info/{selfUtils.js → selfUtils.ts} +123 -68
- package/src/media/{index.js → index.ts} +181 -131
- package/src/media/{properties.js → properties.ts} +47 -28
- package/src/media/{util.js → util.ts} +2 -2
- package/src/mediaQualityMetrics/{config.js → config.ts} +46 -46
- package/src/meeting/{effectsState.js → effectsState.ts} +47 -41
- package/src/meeting/in-meeting-actions.ts +15 -3
- package/src/meeting/{index.js → index.ts} +2263 -1427
- package/src/meeting/{muteState.js → muteState.ts} +78 -42
- package/src/meeting/{request.js → request.ts} +292 -142
- package/src/meeting/request.type.ts +13 -0
- package/src/meeting/{state.js → state.ts} +50 -35
- package/src/meeting/{util.js → util.ts} +112 -115
- package/src/meeting-info/{collection.js → collection.ts} +6 -2
- package/src/meeting-info/{index.js → index.ts} +42 -36
- package/src/meeting-info/meeting-info-v2.ts +273 -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} +65 -58
- package/src/meetings/{collection.js → collection.ts} +6 -3
- package/src/meetings/index.ts +1159 -0
- package/src/meetings/{request.js → request.ts} +32 -25
- package/src/meetings/{util.js → util.ts} +34 -32
- package/src/member/{index.js → index.ts} +102 -56
- package/src/member/{util.js → util.ts} +52 -25
- package/src/members/{collection.js → collection.ts} +2 -2
- package/src/members/{index.js → index.ts} +219 -142
- package/src/members/{request.js → request.ts} +60 -16
- package/src/members/{util.js → util.ts} +50 -48
- package/src/metrics/{config.js → config.ts} +254 -83
- package/src/metrics/{constants.js → constants.ts} +0 -2
- package/src/metrics/{index.js → index.ts} +106 -74
- package/src/multistream/mediaRequestManager.ts +81 -15
- package/src/multistream/multistreamMedia.ts +5 -0
- package/src/multistream/receiveSlot.ts +18 -12
- package/src/multistream/receiveSlotManager.ts +23 -21
- package/src/multistream/remoteMedia.ts +15 -5
- package/src/multistream/remoteMediaGroup.ts +4 -3
- package/src/multistream/remoteMediaManager.ts +153 -37
- package/src/networkQualityMonitor/{index.js → index.ts} +37 -25
- 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} +99 -83
- package/src/reachability/request.ts +39 -33
- 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} +195 -102
- package/src/recording-controller/enums.ts +8 -0
- package/src/recording-controller/index.ts +315 -0
- package/src/recording-controller/util.ts +58 -0
- package/src/roap/{index.js → index.ts} +73 -56
- package/src/roap/request.ts +157 -0
- package/src/roap/turnDiscovery.ts +77 -37
- package/src/statsAnalyzer/{global.js → global.ts} +30 -33
- package/src/statsAnalyzer/{index.js → index.ts} +468 -192
- package/src/statsAnalyzer/mqaUtil.ts +290 -0
- package/src/transcription/{index.js → index.ts} +46 -39
- package/test/integration/spec/journey.js +664 -463
- package/test/integration/spec/space-meeting.js +320 -206
- package/test/integration/spec/transcription.js +7 -8
- package/test/unit/spec/breakouts/breakout.ts +119 -0
- package/test/unit/spec/breakouts/collection.ts +15 -0
- package/test/unit/spec/breakouts/index.ts +293 -0
- package/test/unit/spec/common/browser-detection.js +9 -28
- package/test/unit/spec/fixture/locus.js +92 -90
- package/test/unit/spec/locus-info/controlsUtils.js +25 -5
- package/test/unit/spec/locus-info/embeddedAppsUtils.js +8 -6
- package/test/unit/spec/locus-info/index.js +104 -2
- package/test/unit/spec/locus-info/infoUtils.js +41 -32
- package/test/unit/spec/locus-info/lib/BasicSeqCmp.json +88 -430
- package/test/unit/spec/locus-info/lib/SeqCmp.json +513 -685
- package/test/unit/spec/locus-info/parser.js +3 -9
- package/test/unit/spec/locus-info/selfConstant.js +97 -103
- package/test/unit/spec/locus-info/selfUtils.js +105 -12
- package/test/unit/spec/media/index.ts +31 -47
- package/test/unit/spec/media/properties.ts +9 -9
- package/test/unit/spec/meeting/effectsState.js +39 -45
- package/test/unit/spec/meeting/in-meeting-actions.ts +5 -2
- package/test/unit/spec/meeting/index.js +2017 -742
- package/test/unit/spec/meeting/muteState.js +42 -33
- package/test/unit/spec/meeting/request.js +115 -44
- package/test/unit/spec/meeting/utils.js +104 -171
- package/test/unit/spec/meeting-info/meetinginfov2.js +100 -73
- 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 +110 -74
- package/test/unit/spec/meetings/collection.js +1 -1
- package/test/unit/spec/meetings/index.js +439 -257
- package/test/unit/spec/meetings/utils.js +14 -12
- package/test/unit/spec/member/index.js +0 -1
- package/test/unit/spec/member/util.js +31 -7
- package/test/unit/spec/members/index.js +104 -54
- package/test/unit/spec/members/request.js +29 -20
- package/test/unit/spec/members/utils.js +8 -5
- package/test/unit/spec/metrics/index.js +16 -21
- package/test/unit/spec/multistream/mediaRequestManager.ts +316 -50
- package/test/unit/spec/multistream/receiveSlot.ts +6 -6
- package/test/unit/spec/multistream/receiveSlotManager.ts +13 -13
- package/test/unit/spec/multistream/remoteMedia.ts +10 -2
- package/test/unit/spec/multistream/remoteMediaGroup.ts +5 -5
- package/test/unit/spec/multistream/remoteMediaManager.ts +412 -65
- package/test/unit/spec/networkQualityMonitor/index.js +21 -15
- package/test/unit/spec/personal-meeting-room/personal-meeting-room.js +2 -7
- package/test/unit/spec/reachability/index.ts +58 -26
- package/test/unit/spec/reconnection-manager/index.js +102 -9
- package/test/unit/spec/recording-controller/index.js +231 -0
- package/test/unit/spec/recording-controller/util.js +102 -0
- package/test/unit/spec/roap/index.ts +2 -1
- package/test/unit/spec/roap/request.ts +114 -0
- package/test/unit/spec/roap/turnDiscovery.ts +64 -45
- package/test/unit/spec/stats-analyzer/index.js +27 -22
- package/test/utils/cmr.js +44 -42
- package/test/utils/testUtils.js +83 -74
- package/test/utils/webex-config.js +18 -18
- package/test/utils/webex-test-users.js +54 -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/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/locus-info/controlsUtils.js +0 -102
- package/src/media/internal-media-core-wrapper.ts +0 -9
- package/src/meeting-info/meeting-info-v2.js +0 -255
- package/src/meetings/index.js +0 -1015
- package/src/peer-connection-manager/util.ts +0 -117
- package/src/roap/request.js +0 -127
- package/src/statsAnalyzer/mqaUtil.js +0 -173
- package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -389
|
@@ -2,11 +2,7 @@
|
|
|
2
2
|
* Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.
|
|
3
3
|
*/
|
|
4
4
|
|
|
5
|
-
import {
|
|
6
|
-
_MEETING_LINK_,
|
|
7
|
-
_SIP_URI_,
|
|
8
|
-
_PERSONAL_ROOM_
|
|
9
|
-
} from '../constants';
|
|
5
|
+
import {_MEETING_LINK_, _SIP_URI_, _PERSONAL_ROOM_} from '../constants';
|
|
10
6
|
import LoggerProxy from '../common/logs/logger-proxy';
|
|
11
7
|
|
|
12
8
|
import MeetingInfoCollection from './collection';
|
|
@@ -17,11 +13,15 @@ import MeetingInfoUtil from './util';
|
|
|
17
13
|
* @class MeetingInfo
|
|
18
14
|
*/
|
|
19
15
|
export default class MeetingInfo {
|
|
16
|
+
meetingInfoCollection: any;
|
|
17
|
+
meetingInfoRequest: any;
|
|
18
|
+
webex: any;
|
|
19
|
+
|
|
20
20
|
/**
|
|
21
21
|
*
|
|
22
22
|
* @param {WebexSDK} webex
|
|
23
23
|
*/
|
|
24
|
-
constructor(webex) {
|
|
24
|
+
constructor(webex: any) {
|
|
25
25
|
this.webex = webex;
|
|
26
26
|
|
|
27
27
|
/**
|
|
@@ -30,7 +30,7 @@ export default class MeetingInfo {
|
|
|
30
30
|
* @type {Object}
|
|
31
31
|
* @private
|
|
32
32
|
* @memberof MeetingInfo
|
|
33
|
-
|
|
33
|
+
*/
|
|
34
34
|
this.meetingInfoRequest = new MeetingInfoRequest(this.webex);
|
|
35
35
|
/**
|
|
36
36
|
* The meeting information collection interface
|
|
@@ -38,7 +38,7 @@ export default class MeetingInfo {
|
|
|
38
38
|
* @type {Object}
|
|
39
39
|
* @private
|
|
40
40
|
* @memberof MeetingInfo
|
|
41
|
-
|
|
41
|
+
*/
|
|
42
42
|
this.meetingInfoCollection = new MeetingInfoCollection();
|
|
43
43
|
}
|
|
44
44
|
|
|
@@ -48,7 +48,7 @@ export default class MeetingInfo {
|
|
|
48
48
|
* @public
|
|
49
49
|
* @memberof MeetingInfo
|
|
50
50
|
*/
|
|
51
|
-
getMeetingInfo(id) {
|
|
51
|
+
public getMeetingInfo(id: string) {
|
|
52
52
|
return this.meetingInfoCollection.get(id);
|
|
53
53
|
}
|
|
54
54
|
|
|
@@ -59,7 +59,7 @@ export default class MeetingInfo {
|
|
|
59
59
|
* @public
|
|
60
60
|
* @memberof MeetingInfo
|
|
61
61
|
*/
|
|
62
|
-
setMeetingInfo(id, info) {
|
|
62
|
+
public setMeetingInfo(id: string, info: object) {
|
|
63
63
|
this.meetingInfoCollection.set(id, info);
|
|
64
64
|
}
|
|
65
65
|
|
|
@@ -70,18 +70,23 @@ export default class MeetingInfo {
|
|
|
70
70
|
* @private
|
|
71
71
|
* @memberof MeetingInfo
|
|
72
72
|
*/
|
|
73
|
-
requestFetchInfo(options) {
|
|
74
|
-
return this.meetingInfoRequest
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
73
|
+
private requestFetchInfo(options: object) {
|
|
74
|
+
return this.meetingInfoRequest
|
|
75
|
+
.fetchMeetingInfo(options)
|
|
76
|
+
.then((info) => {
|
|
77
|
+
if (info && info.body) {
|
|
78
|
+
this.setMeetingInfo(info.body.sipMeetingUri || info.body.meetingLink, info.body);
|
|
79
|
+
}
|
|
78
80
|
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
81
|
+
return info;
|
|
82
|
+
})
|
|
83
|
+
.catch((error) => {
|
|
84
|
+
LoggerProxy.logger.error(
|
|
85
|
+
`Meeting-info:index#requestFetchInfo --> ${error} fetch meetingInfo`
|
|
86
|
+
);
|
|
82
87
|
|
|
83
|
-
|
|
84
|
-
|
|
88
|
+
return Promise.reject(error);
|
|
89
|
+
});
|
|
85
90
|
}
|
|
86
91
|
|
|
87
92
|
/**
|
|
@@ -92,11 +97,11 @@ export default class MeetingInfo {
|
|
|
92
97
|
* @private
|
|
93
98
|
* @memberof MeetingInfo
|
|
94
99
|
*/
|
|
95
|
-
fetchInfoOptions(destination, type) {
|
|
100
|
+
private fetchInfoOptions(destination: string, type: string) {
|
|
96
101
|
return MeetingInfoUtil.generateOptions({
|
|
97
102
|
destination,
|
|
98
103
|
type,
|
|
99
|
-
webex: this.webex
|
|
104
|
+
webex: this.webex,
|
|
100
105
|
});
|
|
101
106
|
}
|
|
102
107
|
|
|
@@ -108,24 +113,25 @@ export default class MeetingInfo {
|
|
|
108
113
|
* @public
|
|
109
114
|
* @memberof MeetingInfo
|
|
110
115
|
*/
|
|
111
|
-
fetchMeetingInfo(destination, type = null) {
|
|
116
|
+
public fetchMeetingInfo(destination: string, type: string = null) {
|
|
112
117
|
if (type === _PERSONAL_ROOM_ && !destination) {
|
|
113
118
|
destination = this.webex.internal.device.userId;
|
|
114
119
|
}
|
|
115
120
|
|
|
116
|
-
return this.fetchInfoOptions(
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
121
|
+
return this.fetchInfoOptions(MeetingInfoUtil.extractDestination(destination, type), type).then(
|
|
122
|
+
(options) =>
|
|
123
|
+
// fetch meeting info
|
|
124
|
+
this.requestFetchInfo(options).catch((error) => {
|
|
125
|
+
// if it failed the first time as meeting link
|
|
126
|
+
if (options.type === _MEETING_LINK_) {
|
|
127
|
+
// convert the meeting link to sip URI and retry
|
|
128
|
+
return this.requestFetchInfo(
|
|
129
|
+
this.fetchInfoOptions(MeetingInfoUtil.convertLinkToSip(destination), _SIP_URI_)
|
|
130
|
+
);
|
|
131
|
+
}
|
|
127
132
|
|
|
128
|
-
|
|
129
|
-
|
|
133
|
+
return Promise.reject(error);
|
|
134
|
+
})
|
|
135
|
+
);
|
|
130
136
|
}
|
|
131
137
|
}
|
|
@@ -0,0 +1,273 @@
|
|
|
1
|
+
import {HTTP_VERBS, _CONVERSATION_URL_, WBXAPPAPI_SERVICE} from '../constants';
|
|
2
|
+
import Metrics from '../metrics';
|
|
3
|
+
import BEHAVIORAL_METRICS from '../metrics/constants';
|
|
4
|
+
|
|
5
|
+
import MeetingInfoUtil from './utilv2';
|
|
6
|
+
|
|
7
|
+
const PASSWORD_ERROR_DEFAULT_MESSAGE =
|
|
8
|
+
'Password required. Call fetchMeetingInfo() with password argument';
|
|
9
|
+
const CAPTCHA_ERROR_DEFAULT_MESSAGE =
|
|
10
|
+
'Captcha required. Call fetchMeetingInfo() with captchaInfo argument';
|
|
11
|
+
const ADHOC_MEETING_DEFAULT_ERROR =
|
|
12
|
+
'Failed starting the adhoc meeting, Please contact support team ';
|
|
13
|
+
const CAPTCHA_ERROR_REQUIRES_PASSWORD_CODES = [423005, 423006];
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* Error to indicate that wbxappapi requires a password
|
|
17
|
+
*/
|
|
18
|
+
export class MeetingInfoV2PasswordError extends Error {
|
|
19
|
+
meetingInfo: any;
|
|
20
|
+
sdkMessage: any;
|
|
21
|
+
wbxAppApiCode: any;
|
|
22
|
+
body: any;
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
*
|
|
26
|
+
* @constructor
|
|
27
|
+
* @param {Number} [wbxAppApiErrorCode]
|
|
28
|
+
* @param {Object} [meetingInfo]
|
|
29
|
+
* @param {String} [message]
|
|
30
|
+
*/
|
|
31
|
+
constructor(
|
|
32
|
+
wbxAppApiErrorCode?: number,
|
|
33
|
+
meetingInfo?: object,
|
|
34
|
+
message: string = PASSWORD_ERROR_DEFAULT_MESSAGE
|
|
35
|
+
) {
|
|
36
|
+
super(`${message}, code=${wbxAppApiErrorCode}`);
|
|
37
|
+
this.name = 'MeetingInfoV2PasswordError';
|
|
38
|
+
this.sdkMessage = message;
|
|
39
|
+
this.stack = new Error().stack;
|
|
40
|
+
this.wbxAppApiCode = wbxAppApiErrorCode;
|
|
41
|
+
this.meetingInfo = meetingInfo;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Error generating a adhoc space meeting
|
|
47
|
+
*/
|
|
48
|
+
export class MeetingInfoV2AdhocMeetingError extends Error {
|
|
49
|
+
sdkMessage: any;
|
|
50
|
+
wbxAppApiCode: any;
|
|
51
|
+
/**
|
|
52
|
+
*
|
|
53
|
+
* @constructor
|
|
54
|
+
* @param {Number} [wbxAppApiErrorCode]
|
|
55
|
+
* @param {String} [message]
|
|
56
|
+
*/
|
|
57
|
+
constructor(wbxAppApiErrorCode?: number, message: string = ADHOC_MEETING_DEFAULT_ERROR) {
|
|
58
|
+
super(`${message}, code=${wbxAppApiErrorCode}`);
|
|
59
|
+
this.name = 'MeetingInfoV2AdhocMeetingError';
|
|
60
|
+
this.sdkMessage = message;
|
|
61
|
+
this.stack = new Error().stack;
|
|
62
|
+
this.wbxAppApiCode = wbxAppApiErrorCode;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
/**
|
|
67
|
+
* Error to indicate that preferred webex site not present to start adhoc meeting
|
|
68
|
+
*/
|
|
69
|
+
export class MeetingInfoV2CaptchaError extends Error {
|
|
70
|
+
captchaInfo: any;
|
|
71
|
+
isPasswordRequired: any;
|
|
72
|
+
sdkMessage: any;
|
|
73
|
+
wbxAppApiCode: any;
|
|
74
|
+
body: any;
|
|
75
|
+
/**
|
|
76
|
+
*
|
|
77
|
+
* @constructor
|
|
78
|
+
* @param {Number} [wbxAppApiErrorCode]
|
|
79
|
+
* @param {Object} [captchaInfo]
|
|
80
|
+
* @param {String} [message]
|
|
81
|
+
*/
|
|
82
|
+
constructor(
|
|
83
|
+
wbxAppApiErrorCode?: number,
|
|
84
|
+
captchaInfo?: object,
|
|
85
|
+
message: string = CAPTCHA_ERROR_DEFAULT_MESSAGE
|
|
86
|
+
) {
|
|
87
|
+
super(`${message}, code=${wbxAppApiErrorCode}`);
|
|
88
|
+
this.name = 'MeetingInfoV2PasswordError';
|
|
89
|
+
this.sdkMessage = message;
|
|
90
|
+
this.stack = new Error().stack;
|
|
91
|
+
this.wbxAppApiCode = wbxAppApiErrorCode;
|
|
92
|
+
this.isPasswordRequired = CAPTCHA_ERROR_REQUIRES_PASSWORD_CODES.includes(wbxAppApiErrorCode);
|
|
93
|
+
this.captchaInfo = captchaInfo;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
/**
|
|
98
|
+
* @class MeetingInfo
|
|
99
|
+
*/
|
|
100
|
+
export default class MeetingInfoV2 {
|
|
101
|
+
webex: any;
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
*
|
|
105
|
+
* @param {WebexSDK} webex
|
|
106
|
+
*/
|
|
107
|
+
constructor(webex) {
|
|
108
|
+
this.webex = webex;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
/**
|
|
112
|
+
* converts hydra id into conversation url and persons Id
|
|
113
|
+
* @param {String} destination one of many different types of destinations to look up info for
|
|
114
|
+
* @param {String} [type] to match up with the destination value
|
|
115
|
+
* @returns {Promise} destination and type
|
|
116
|
+
* @public
|
|
117
|
+
* @memberof MeetingInfo
|
|
118
|
+
*/
|
|
119
|
+
fetchInfoOptions(destination: string, type: string = null) {
|
|
120
|
+
return MeetingInfoUtil.getDestinationType({
|
|
121
|
+
destination,
|
|
122
|
+
type,
|
|
123
|
+
webex: this.webex,
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
/**
|
|
128
|
+
* Creates adhoc space meetings for a space by fetching the conversation infomation
|
|
129
|
+
* @param {String} conversationUrl conversationUrl to start adhoc meeting on
|
|
130
|
+
* @returns {Promise} returns a meeting info object
|
|
131
|
+
* @public
|
|
132
|
+
* @memberof MeetingInfo
|
|
133
|
+
*/
|
|
134
|
+
async createAdhocSpaceMeeting(conversationUrl: string) {
|
|
135
|
+
if (!this.webex.meetings.preferredWebexSite) {
|
|
136
|
+
throw Error('No preferred webex site found');
|
|
137
|
+
}
|
|
138
|
+
const getInvitees = (particpants = []) => {
|
|
139
|
+
const invitees = [];
|
|
140
|
+
|
|
141
|
+
if (particpants) {
|
|
142
|
+
particpants.forEach((participant) => {
|
|
143
|
+
invitees.push({
|
|
144
|
+
email: participant.emailAddress,
|
|
145
|
+
ciUserUuid: participant.entryUUID,
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
return invitees;
|
|
151
|
+
};
|
|
152
|
+
|
|
153
|
+
return this.webex.internal.conversation
|
|
154
|
+
.get({url: conversationUrl}, {includeParticipants: true, disableTransform: true})
|
|
155
|
+
.then((conversation) => {
|
|
156
|
+
const body = {
|
|
157
|
+
title: conversation.displayName,
|
|
158
|
+
spaceUrl: conversation.url,
|
|
159
|
+
keyUrl: conversation.encryptionKeyUrl,
|
|
160
|
+
kroUrl: conversation.kmsResourceObjectUrl,
|
|
161
|
+
invitees: getInvitees(conversation.participants?.items),
|
|
162
|
+
};
|
|
163
|
+
|
|
164
|
+
const uri = this.webex.meetings.preferredWebexSite
|
|
165
|
+
? `https://${this.webex.meetings.preferredWebexSite}/wbxappapi/v2/meetings/spaceInstant`
|
|
166
|
+
: '';
|
|
167
|
+
|
|
168
|
+
Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.ADHOC_MEETING_SUCCESS);
|
|
169
|
+
|
|
170
|
+
return this.webex.request({
|
|
171
|
+
method: HTTP_VERBS.POST,
|
|
172
|
+
uri,
|
|
173
|
+
body,
|
|
174
|
+
});
|
|
175
|
+
})
|
|
176
|
+
.catch((err) => {
|
|
177
|
+
Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.ADHOC_MEETING_FAILURE, {
|
|
178
|
+
reason: err.message,
|
|
179
|
+
stack: err.stack,
|
|
180
|
+
});
|
|
181
|
+
throw new MeetingInfoV2AdhocMeetingError(err.body?.code, err.body?.message);
|
|
182
|
+
});
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
/**
|
|
186
|
+
* Fetches meeting info from the server
|
|
187
|
+
* @param {String} destination one of many different types of destinations to look up info for
|
|
188
|
+
* @param {String} [type] to match up with the destination value
|
|
189
|
+
* @param {String} password
|
|
190
|
+
* @param {Object} captchaInfo
|
|
191
|
+
* @param {String} captchaInfo.code
|
|
192
|
+
* @param {String} captchaInfo.id
|
|
193
|
+
* @returns {Promise} returns a meeting info object
|
|
194
|
+
* @public
|
|
195
|
+
* @memberof MeetingInfo
|
|
196
|
+
*/
|
|
197
|
+
async fetchMeetingInfo(
|
|
198
|
+
destination: string,
|
|
199
|
+
type: string = null,
|
|
200
|
+
password: string = null,
|
|
201
|
+
captchaInfo: {
|
|
202
|
+
code: string;
|
|
203
|
+
id: string;
|
|
204
|
+
} = null
|
|
205
|
+
) {
|
|
206
|
+
const destinationType = await MeetingInfoUtil.getDestinationType({
|
|
207
|
+
destination,
|
|
208
|
+
type,
|
|
209
|
+
webex: this.webex,
|
|
210
|
+
});
|
|
211
|
+
|
|
212
|
+
if (
|
|
213
|
+
destinationType.type === _CONVERSATION_URL_ &&
|
|
214
|
+
this.webex.config.meetings.experimental.enableAdhocMeetings &&
|
|
215
|
+
this.webex.meetings.preferredWebexSite
|
|
216
|
+
) {
|
|
217
|
+
return this.createAdhocSpaceMeeting(destinationType.destination);
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
const body = await MeetingInfoUtil.getRequestBody({...destinationType, password, captchaInfo});
|
|
221
|
+
|
|
222
|
+
const options: any = {
|
|
223
|
+
method: HTTP_VERBS.POST,
|
|
224
|
+
body,
|
|
225
|
+
};
|
|
226
|
+
|
|
227
|
+
const directURI = await MeetingInfoUtil.getDirectMeetingInfoURI(destinationType);
|
|
228
|
+
|
|
229
|
+
if (directURI) {
|
|
230
|
+
options.uri = directURI;
|
|
231
|
+
} else {
|
|
232
|
+
options.service = WBXAPPAPI_SERVICE;
|
|
233
|
+
options.resource = 'meetingInfo';
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
return this.webex
|
|
237
|
+
.request(options)
|
|
238
|
+
.then((response) => {
|
|
239
|
+
Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.FETCH_MEETING_INFO_V1_SUCCESS);
|
|
240
|
+
|
|
241
|
+
return response;
|
|
242
|
+
})
|
|
243
|
+
.catch((err) => {
|
|
244
|
+
if (err?.statusCode === 403) {
|
|
245
|
+
Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.VERIFY_PASSWORD_ERROR, {
|
|
246
|
+
reason: err.message,
|
|
247
|
+
stack: err.stack,
|
|
248
|
+
});
|
|
249
|
+
|
|
250
|
+
throw new MeetingInfoV2PasswordError(err.body?.code, err.body?.data?.meetingInfo);
|
|
251
|
+
}
|
|
252
|
+
if (err?.statusCode === 423) {
|
|
253
|
+
Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.VERIFY_CAPTCHA_ERROR, {
|
|
254
|
+
reason: err.message,
|
|
255
|
+
stack: err.stack,
|
|
256
|
+
});
|
|
257
|
+
|
|
258
|
+
throw new MeetingInfoV2CaptchaError(err.body?.code, {
|
|
259
|
+
captchaId: err.body.captchaID,
|
|
260
|
+
verificationImageURL: err.body.verificationImageURL,
|
|
261
|
+
verificationAudioURL: err.body.verificationAudioURL,
|
|
262
|
+
refreshURL: err.body.refreshURL,
|
|
263
|
+
});
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.FETCH_MEETING_INFO_V1_FAILURE, {
|
|
267
|
+
reason: err.message,
|
|
268
|
+
stack: err.stack,
|
|
269
|
+
});
|
|
270
|
+
throw err;
|
|
271
|
+
});
|
|
272
|
+
}
|
|
273
|
+
}
|
|
@@ -2,15 +2,18 @@ import {API} from '../constants';
|
|
|
2
2
|
import ParameterError from '../common/errors/parameter';
|
|
3
3
|
|
|
4
4
|
import MeetingInfoUtil from './util';
|
|
5
|
+
|
|
5
6
|
/**
|
|
6
7
|
* @class MeetingInfoRequest
|
|
7
8
|
*/
|
|
8
9
|
export default class MeetingInfoRequest {
|
|
10
|
+
webex: any;
|
|
11
|
+
|
|
9
12
|
/**
|
|
10
13
|
* Meeting Info Request Constructor
|
|
11
14
|
* @param {WebexSDK} webex
|
|
12
15
|
*/
|
|
13
|
-
constructor(webex) {
|
|
16
|
+
constructor(webex: any) {
|
|
14
17
|
this.webex = webex;
|
|
15
18
|
}
|
|
16
19
|
|
|
@@ -24,12 +27,19 @@ export default class MeetingInfoRequest {
|
|
|
24
27
|
* @throws {Error} if the options are not valid and complete
|
|
25
28
|
* @memberof MeetingInfoRequest
|
|
26
29
|
*/
|
|
27
|
-
fetchMeetingInfo(options) {
|
|
30
|
+
fetchMeetingInfo(options: any) {
|
|
28
31
|
if (!options || !options.type || !options.destination) {
|
|
29
|
-
throw new ParameterError(
|
|
32
|
+
throw new ParameterError(
|
|
33
|
+
'MeetingInfo should be fetched with a type and destination specified, see list of valid types and their corresponding values in constants'
|
|
34
|
+
);
|
|
30
35
|
}
|
|
31
36
|
const resourceUrl = MeetingInfoUtil.getResourceUrl(options.type, options.destination);
|
|
32
|
-
const requestParams = MeetingInfoUtil.getRequestParams(
|
|
37
|
+
const requestParams = MeetingInfoUtil.getRequestParams(
|
|
38
|
+
resourceUrl,
|
|
39
|
+
options.type,
|
|
40
|
+
options.destination,
|
|
41
|
+
API.LOCUS
|
|
42
|
+
);
|
|
33
43
|
|
|
34
44
|
return this.webex.request(requestParams);
|
|
35
45
|
}
|