@webex/plugin-meetings 3.7.0 → 3.8.0-next.1
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/dist/annotation/index.js +17 -0
- package/dist/annotation/index.js.map +1 -1
- package/dist/breakouts/breakout.js +1 -1
- package/dist/breakouts/index.js +1 -1
- package/dist/common/errors/join-forbidden-error.js +52 -0
- package/dist/common/errors/join-forbidden-error.js.map +1 -0
- package/dist/common/errors/{webinar-registration-error.js → join-webinar-error.js} +12 -12
- package/dist/common/errors/join-webinar-error.js.map +1 -0
- package/dist/common/errors/multistream-not-supported-error.js +53 -0
- package/dist/common/errors/multistream-not-supported-error.js.map +1 -0
- package/dist/config.js +2 -1
- package/dist/config.js.map +1 -1
- package/dist/constants.js +68 -6
- package/dist/constants.js.map +1 -1
- package/dist/index.js +16 -11
- package/dist/index.js.map +1 -1
- package/dist/interpretation/index.js +1 -1
- package/dist/interpretation/siLanguage.js +1 -1
- package/dist/locus-info/index.js +14 -3
- package/dist/locus-info/index.js.map +1 -1
- package/dist/locus-info/selfUtils.js +35 -17
- package/dist/locus-info/selfUtils.js.map +1 -1
- package/dist/media/MediaConnectionAwaiter.js +1 -0
- package/dist/media/MediaConnectionAwaiter.js.map +1 -1
- package/dist/media/properties.js +30 -16
- package/dist/media/properties.js.map +1 -1
- package/dist/meeting/brbState.js +167 -0
- package/dist/meeting/brbState.js.map +1 -0
- package/dist/meeting/in-meeting-actions.js +13 -1
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +1335 -1052
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/locusMediaRequest.js +11 -6
- package/dist/meeting/locusMediaRequest.js.map +1 -1
- package/dist/meeting/muteState.js +1 -6
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +51 -29
- package/dist/meeting/request.js.map +1 -1
- package/dist/meeting/request.type.js.map +1 -1
- package/dist/meeting/util.js +103 -67
- package/dist/meeting/util.js.map +1 -1
- package/dist/meeting-info/meeting-info-v2.js +115 -45
- package/dist/meeting-info/meeting-info-v2.js.map +1 -1
- package/dist/meeting-info/utilv2.js +6 -2
- package/dist/meeting-info/utilv2.js.map +1 -1
- package/dist/meetings/index.js +107 -55
- package/dist/meetings/index.js.map +1 -1
- package/dist/meetings/meetings.types.js +2 -0
- package/dist/meetings/meetings.types.js.map +1 -1
- package/dist/meetings/util.js +1 -1
- package/dist/meetings/util.js.map +1 -1
- package/dist/member/index.js +9 -0
- package/dist/member/index.js.map +1 -1
- package/dist/member/types.js.map +1 -1
- package/dist/member/util.js +39 -28
- package/dist/member/util.js.map +1 -1
- package/dist/members/util.js +4 -2
- package/dist/members/util.js.map +1 -1
- package/dist/metrics/constants.js +6 -1
- package/dist/metrics/constants.js.map +1 -1
- package/dist/multistream/remoteMedia.js +30 -15
- package/dist/multistream/remoteMedia.js.map +1 -1
- package/dist/multistream/sendSlotManager.js +24 -0
- package/dist/multistream/sendSlotManager.js.map +1 -1
- package/dist/reachability/clusterReachability.js +12 -15
- package/dist/reachability/clusterReachability.js.map +1 -1
- package/dist/reachability/index.js +461 -136
- package/dist/reachability/index.js.map +1 -1
- package/dist/{rtcMetrics/constants.js → reachability/reachability.types.js} +1 -5
- package/dist/reachability/reachability.types.js.map +1 -0
- package/dist/reachability/request.js +21 -8
- package/dist/reachability/request.js.map +1 -1
- package/dist/recording-controller/enums.js +8 -4
- package/dist/recording-controller/enums.js.map +1 -1
- package/dist/recording-controller/index.js +18 -9
- package/dist/recording-controller/index.js.map +1 -1
- package/dist/recording-controller/util.js +13 -9
- package/dist/recording-controller/util.js.map +1 -1
- package/dist/roap/index.js +15 -15
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +45 -79
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/turnDiscovery.js +3 -6
- package/dist/roap/turnDiscovery.js.map +1 -1
- package/dist/types/annotation/index.d.ts +5 -0
- package/dist/types/common/errors/join-forbidden-error.d.ts +15 -0
- package/dist/types/common/errors/{webinar-registration-error.d.ts → join-webinar-error.d.ts} +2 -2
- package/dist/types/common/errors/multistream-not-supported-error.d.ts +17 -0
- package/dist/types/config.d.ts +1 -0
- package/dist/types/constants.d.ts +53 -1
- package/dist/types/index.d.ts +3 -3
- package/dist/types/locus-info/index.d.ts +2 -1
- package/dist/types/meeting/brbState.d.ts +54 -0
- package/dist/types/meeting/in-meeting-actions.d.ts +12 -0
- package/dist/types/meeting/index.d.ts +64 -14
- package/dist/types/meeting/locusMediaRequest.d.ts +6 -3
- package/dist/types/meeting/request.d.ts +14 -3
- package/dist/types/meeting/request.type.d.ts +6 -0
- package/dist/types/meeting/util.d.ts +3 -3
- package/dist/types/meeting-info/meeting-info-v2.d.ts +30 -5
- package/dist/types/meetings/index.d.ts +20 -2
- package/dist/types/meetings/meetings.types.d.ts +8 -0
- package/dist/types/member/index.d.ts +1 -0
- package/dist/types/member/types.d.ts +7 -0
- package/dist/types/members/util.d.ts +2 -0
- package/dist/types/metrics/constants.d.ts +6 -1
- package/dist/types/multistream/sendSlotManager.d.ts +8 -1
- package/dist/types/reachability/clusterReachability.d.ts +1 -10
- package/dist/types/reachability/index.d.ts +83 -36
- package/dist/types/reachability/reachability.types.d.ts +64 -0
- package/dist/types/reachability/request.d.ts +5 -1
- package/dist/types/recording-controller/enums.d.ts +5 -2
- package/dist/types/recording-controller/index.d.ts +1 -0
- package/dist/types/recording-controller/util.d.ts +2 -1
- package/dist/types/roap/request.d.ts +1 -13
- package/dist/webinar/index.js +390 -7
- package/dist/webinar/index.js.map +1 -1
- package/package.json +23 -22
- package/src/annotation/index.ts +16 -0
- package/src/common/errors/join-forbidden-error.ts +26 -0
- package/src/common/errors/join-webinar-error.ts +24 -0
- package/src/common/errors/multistream-not-supported-error.ts +30 -0
- package/src/config.ts +1 -0
- package/src/constants.ts +61 -3
- package/src/index.ts +5 -3
- package/src/locus-info/index.ts +20 -3
- package/src/locus-info/selfUtils.ts +24 -6
- package/src/media/MediaConnectionAwaiter.ts +2 -0
- package/src/media/properties.ts +34 -13
- package/src/meeting/brbState.ts +169 -0
- package/src/meeting/in-meeting-actions.ts +25 -0
- package/src/meeting/index.ts +451 -88
- package/src/meeting/locusMediaRequest.ts +11 -8
- package/src/meeting/muteState.ts +1 -6
- package/src/meeting/request.ts +30 -12
- package/src/meeting/request.type.ts +7 -0
- package/src/meeting/util.ts +32 -13
- package/src/meeting-info/meeting-info-v2.ts +83 -12
- package/src/meeting-info/utilv2.ts +17 -3
- package/src/meetings/index.ts +79 -20
- package/src/meetings/meetings.types.ts +10 -0
- package/src/meetings/util.ts +2 -1
- package/src/member/index.ts +9 -0
- package/src/member/types.ts +8 -0
- package/src/member/util.ts +34 -24
- package/src/members/util.ts +1 -0
- package/src/metrics/constants.ts +6 -1
- package/src/multistream/remoteMedia.ts +28 -15
- package/src/multistream/sendSlotManager.ts +31 -0
- package/src/reachability/clusterReachability.ts +5 -15
- package/src/reachability/index.ts +311 -75
- package/src/reachability/reachability.types.ts +85 -0
- package/src/reachability/request.ts +55 -31
- package/src/recording-controller/enums.ts +5 -2
- package/src/recording-controller/index.ts +17 -4
- package/src/recording-controller/util.ts +20 -5
- package/src/roap/index.ts +14 -13
- package/src/roap/request.ts +30 -44
- package/src/roap/turnDiscovery.ts +2 -4
- package/src/webinar/index.ts +235 -9
- package/test/unit/spec/annotation/index.ts +46 -1
- package/test/unit/spec/locus-info/index.js +292 -60
- package/test/unit/spec/locus-info/selfConstant.js +7 -0
- package/test/unit/spec/locus-info/selfUtils.js +101 -1
- package/test/unit/spec/media/properties.ts +15 -0
- package/test/unit/spec/meeting/brbState.ts +114 -0
- package/test/unit/spec/meeting/in-meeting-actions.ts +15 -1
- package/test/unit/spec/meeting/index.js +860 -110
- package/test/unit/spec/meeting/locusMediaRequest.ts +18 -11
- package/test/unit/spec/meeting/muteState.js +0 -24
- package/test/unit/spec/meeting/request.js +3 -26
- package/test/unit/spec/meeting/utils.js +73 -28
- package/test/unit/spec/meeting-info/meetinginfov2.js +46 -4
- package/test/unit/spec/meeting-info/utilv2.js +26 -0
- package/test/unit/spec/meetings/index.js +159 -18
- package/test/unit/spec/meetings/utils.js +10 -0
- package/test/unit/spec/member/util.js +52 -11
- package/test/unit/spec/members/utils.js +95 -0
- package/test/unit/spec/multistream/remoteMedia.ts +11 -7
- package/test/unit/spec/reachability/clusterReachability.ts +7 -0
- package/test/unit/spec/reachability/index.ts +383 -9
- package/test/unit/spec/reachability/request.js +48 -12
- package/test/unit/spec/recording-controller/index.js +61 -5
- package/test/unit/spec/recording-controller/util.js +39 -3
- package/test/unit/spec/roap/index.ts +48 -1
- package/test/unit/spec/roap/request.ts +51 -109
- package/test/unit/spec/roap/turnDiscovery.ts +202 -147
- package/test/unit/spec/webinar/index.ts +504 -0
- package/dist/common/errors/webinar-registration-error.js.map +0 -1
- package/dist/networkQualityMonitor/index.js +0 -227
- package/dist/networkQualityMonitor/index.js.map +0 -1
- package/dist/rtcMetrics/constants.js.map +0 -1
- package/dist/rtcMetrics/index.js +0 -197
- package/dist/rtcMetrics/index.js.map +0 -1
- package/dist/types/networkQualityMonitor/index.d.ts +0 -70
- package/dist/types/rtcMetrics/constants.d.ts +0 -4
- package/dist/types/rtcMetrics/index.d.ts +0 -71
- package/src/common/errors/webinar-registration-error.ts +0 -27
package/src/webinar/index.ts
CHANGED
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* Copyright (c) 2015-2023 Cisco Systems, Inc. See LICENSE file.
|
|
3
3
|
*/
|
|
4
|
-
import {WebexPlugin} from '@webex/webex-core';
|
|
4
|
+
import {WebexPlugin, config} from '@webex/webex-core';
|
|
5
|
+
import uuid from 'uuid';
|
|
5
6
|
import {get} from 'lodash';
|
|
6
|
-
import {MEETINGS, SELF_ROLES} from '../constants';
|
|
7
|
+
import {_ID_, HEADERS, HTTP_VERBS, MEETINGS, SELF_ROLES, SHARE_STATUS} from '../constants';
|
|
7
8
|
|
|
8
9
|
import WebinarCollection from './collection';
|
|
10
|
+
import LoggerProxy from '../common/logs/logger-proxy';
|
|
9
11
|
|
|
10
12
|
/**
|
|
11
13
|
* @class Webinar
|
|
@@ -22,6 +24,8 @@ const Webinar = WebexPlugin.extend({
|
|
|
22
24
|
canManageWebcast: 'boolean', // appears the ability to manage webcast
|
|
23
25
|
selfIsPanelist: 'boolean', // self is panelist
|
|
24
26
|
selfIsAttendee: 'boolean', // self is attendee
|
|
27
|
+
practiceSessionEnabled: 'boolean', // practice session enabled
|
|
28
|
+
meetingId: 'string',
|
|
25
29
|
},
|
|
26
30
|
|
|
27
31
|
/**
|
|
@@ -59,18 +63,240 @@ const Webinar = WebexPlugin.extend({
|
|
|
59
63
|
* @returns {{isPromoted: boolean, isDemoted: boolean}} Role transition states
|
|
60
64
|
*/
|
|
61
65
|
updateRoleChanged(payload) {
|
|
66
|
+
const oldRoles = get(payload, 'oldRoles', []);
|
|
67
|
+
const newRoles = get(payload, 'newRoles', []);
|
|
68
|
+
|
|
62
69
|
const isPromoted =
|
|
63
|
-
|
|
64
|
-
get(payload, 'newRoles', []).includes(SELF_ROLES.PANELIST);
|
|
70
|
+
oldRoles.includes(SELF_ROLES.ATTENDEE) && newRoles.includes(SELF_ROLES.PANELIST);
|
|
65
71
|
const isDemoted =
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
this.set('selfIsPanelist',
|
|
69
|
-
this.set('selfIsAttendee',
|
|
70
|
-
this.updateCanManageWebcast(
|
|
72
|
+
(oldRoles.includes(SELF_ROLES.PANELIST) && newRoles.includes(SELF_ROLES.ATTENDEE)) ||
|
|
73
|
+
(!oldRoles.includes(SELF_ROLES.ATTENDEE) && newRoles.includes(SELF_ROLES.ATTENDEE)); // for attendee just join meeting case
|
|
74
|
+
this.set('selfIsPanelist', newRoles.includes(SELF_ROLES.PANELIST));
|
|
75
|
+
this.set('selfIsAttendee', newRoles.includes(SELF_ROLES.ATTENDEE));
|
|
76
|
+
this.updateCanManageWebcast(newRoles.includes(SELF_ROLES.MODERATOR));
|
|
77
|
+
this.updateStatusByRole({isPromoted, isDemoted});
|
|
71
78
|
|
|
72
79
|
return {isPromoted, isDemoted};
|
|
73
80
|
},
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* should join practice session data channel or not
|
|
84
|
+
* @param {Object} {isPromoted: boolean, isDemoted: boolean}} Role transition states
|
|
85
|
+
* @returns {void}
|
|
86
|
+
*/
|
|
87
|
+
updateStatusByRole({isPromoted, isDemoted}) {
|
|
88
|
+
const meeting = this.webex.meetings.getMeetingByType(_ID_, this.meetingId);
|
|
89
|
+
|
|
90
|
+
if (
|
|
91
|
+
(isDemoted && meeting?.shareStatus === SHARE_STATUS.WHITEBOARD_SHARE_ACTIVE) ||
|
|
92
|
+
isPromoted
|
|
93
|
+
) {
|
|
94
|
+
// attendees in webinar should subscribe streaming for whiteboard sharing
|
|
95
|
+
// while panelist still need subscribe native mode so trigger force update here
|
|
96
|
+
meeting?.locusInfo?.updateMediaShares(meeting?.locusInfo?.mediaShares, true);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
if (this.practiceSessionEnabled) {
|
|
100
|
+
// may need change data channel in practice session
|
|
101
|
+
meeting?.updateLLMConnection();
|
|
102
|
+
}
|
|
103
|
+
},
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* should join practice session data channel or not
|
|
107
|
+
* @returns {boolean}
|
|
108
|
+
*/
|
|
109
|
+
isJoinPracticeSessionDataChannel() {
|
|
110
|
+
return this.selfIsPanelist && this.practiceSessionEnabled;
|
|
111
|
+
},
|
|
112
|
+
|
|
113
|
+
/**
|
|
114
|
+
* start or stop practice session for webinar
|
|
115
|
+
* @param {boolean} enabled
|
|
116
|
+
* @returns {Promise}
|
|
117
|
+
*/
|
|
118
|
+
setPracticeSessionState(enabled) {
|
|
119
|
+
return this.request({
|
|
120
|
+
method: HTTP_VERBS.PATCH,
|
|
121
|
+
uri: `${this.locusUrl}/controls`,
|
|
122
|
+
body: {
|
|
123
|
+
practiceSession: {
|
|
124
|
+
enabled,
|
|
125
|
+
},
|
|
126
|
+
},
|
|
127
|
+
}).catch((error) => {
|
|
128
|
+
LoggerProxy.logger.error('Meeting:webinar#setPracticeSessionState failed', error);
|
|
129
|
+
throw error;
|
|
130
|
+
});
|
|
131
|
+
},
|
|
132
|
+
|
|
133
|
+
/**
|
|
134
|
+
* update practice session status
|
|
135
|
+
* @param {object} payload
|
|
136
|
+
* @returns {void}
|
|
137
|
+
*/
|
|
138
|
+
updatePracticeSessionStatus(payload) {
|
|
139
|
+
this.set('practiceSessionEnabled', payload.enabled);
|
|
140
|
+
},
|
|
141
|
+
|
|
142
|
+
/**
|
|
143
|
+
* start webcast mode for webinar
|
|
144
|
+
* @param {object} meeting
|
|
145
|
+
* @param {object} layout
|
|
146
|
+
* @returns {Promise}
|
|
147
|
+
*/
|
|
148
|
+
async startWebcast(meeting, layout) {
|
|
149
|
+
if (!meeting) {
|
|
150
|
+
LoggerProxy.logger.error(
|
|
151
|
+
`Meeting:webinar#startWebcast failed --> meeting parameter : ${meeting}`
|
|
152
|
+
);
|
|
153
|
+
throw new Error('Meeting parameter does not meet expectations');
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
return this.request({
|
|
157
|
+
method: HTTP_VERBS.PUT,
|
|
158
|
+
uri: `${this.webcastInstanceUrl}/streaming`,
|
|
159
|
+
headers: {
|
|
160
|
+
authorization: await this.webex.credentials.getUserToken(),
|
|
161
|
+
trackingId: `${config.trackingIdPrefix}_${uuid.v4().toString()}`,
|
|
162
|
+
[HEADERS.CONTENT_TYPE]: HEADERS.CONTENT_TYPE_VALUE.APPLICATION_JSON,
|
|
163
|
+
},
|
|
164
|
+
body: {
|
|
165
|
+
action: 'start',
|
|
166
|
+
meetingInfo: {
|
|
167
|
+
locusId: meeting.locusId,
|
|
168
|
+
correlationId: meeting.correlationId,
|
|
169
|
+
},
|
|
170
|
+
layout,
|
|
171
|
+
},
|
|
172
|
+
}).catch((error) => {
|
|
173
|
+
LoggerProxy.logger.error('Meeting:webinar#startWebcast failed', error);
|
|
174
|
+
throw error;
|
|
175
|
+
});
|
|
176
|
+
},
|
|
177
|
+
|
|
178
|
+
/**
|
|
179
|
+
* stop webcast mode for webinar
|
|
180
|
+
* @returns {Promise}
|
|
181
|
+
*/
|
|
182
|
+
async stopWebcast() {
|
|
183
|
+
return this.request({
|
|
184
|
+
method: HTTP_VERBS.PUT,
|
|
185
|
+
uri: `${this.webcastInstanceUrl}/streaming`,
|
|
186
|
+
headers: {
|
|
187
|
+
authorization: await this.webex.credentials.getUserToken(),
|
|
188
|
+
trackingId: `${config.trackingIdPrefix}_${uuid.v4().toString()}`,
|
|
189
|
+
[HEADERS.CONTENT_TYPE]: HEADERS.CONTENT_TYPE_VALUE.APPLICATION_JSON,
|
|
190
|
+
},
|
|
191
|
+
body: {
|
|
192
|
+
action: 'stop',
|
|
193
|
+
},
|
|
194
|
+
}).catch((error) => {
|
|
195
|
+
LoggerProxy.logger.error('Meeting:webinar#stopWebcast failed', error);
|
|
196
|
+
throw error;
|
|
197
|
+
});
|
|
198
|
+
},
|
|
199
|
+
|
|
200
|
+
/**
|
|
201
|
+
* query webcast layout for webinar
|
|
202
|
+
* @returns {Promise}
|
|
203
|
+
*/
|
|
204
|
+
async queryWebcastLayout() {
|
|
205
|
+
return this.request({
|
|
206
|
+
method: HTTP_VERBS.GET,
|
|
207
|
+
uri: `${this.webcastInstanceUrl}/layout`,
|
|
208
|
+
headers: {
|
|
209
|
+
authorization: await this.webex.credentials.getUserToken(),
|
|
210
|
+
trackingId: `${config.trackingIdPrefix}_${uuid.v4().toString()}`,
|
|
211
|
+
},
|
|
212
|
+
}).catch((error) => {
|
|
213
|
+
LoggerProxy.logger.error('Meeting:webinar#queryWebcastLayout failed', error);
|
|
214
|
+
throw error;
|
|
215
|
+
});
|
|
216
|
+
},
|
|
217
|
+
|
|
218
|
+
/**
|
|
219
|
+
* update webcast layout for webinar
|
|
220
|
+
* @param {object} layout
|
|
221
|
+
* @returns {Promise}
|
|
222
|
+
*/
|
|
223
|
+
async updateWebcastLayout(layout) {
|
|
224
|
+
return this.request({
|
|
225
|
+
method: HTTP_VERBS.PUT,
|
|
226
|
+
uri: `${this.webcastInstanceUrl}/layout`,
|
|
227
|
+
headers: {
|
|
228
|
+
authorization: await this.webex.credentials.getUserToken(),
|
|
229
|
+
trackingId: `${config.trackingIdPrefix}_${uuid.v4().toString()}`,
|
|
230
|
+
[HEADERS.CONTENT_TYPE]: HEADERS.CONTENT_TYPE_VALUE.APPLICATION_JSON,
|
|
231
|
+
},
|
|
232
|
+
body: {
|
|
233
|
+
videoLayout: layout.videoLayout,
|
|
234
|
+
contentLayout: layout.contentLayout,
|
|
235
|
+
syncStageLayout: layout.syncStageLayout,
|
|
236
|
+
syncStageInMeeting: layout.syncStageInMeeting,
|
|
237
|
+
},
|
|
238
|
+
}).catch((error) => {
|
|
239
|
+
LoggerProxy.logger.error('Meeting:webinar#updateWebcastLayout failed', error);
|
|
240
|
+
throw error;
|
|
241
|
+
});
|
|
242
|
+
},
|
|
243
|
+
|
|
244
|
+
/**
|
|
245
|
+
* view all webcast attendees
|
|
246
|
+
* @param {string} queryString
|
|
247
|
+
* @returns {Promise}
|
|
248
|
+
*/
|
|
249
|
+
async viewAllWebcastAttendees() {
|
|
250
|
+
return this.request({
|
|
251
|
+
method: HTTP_VERBS.GET,
|
|
252
|
+
uri: `${this.webcastInstanceUrl}/attendees`,
|
|
253
|
+
headers: {
|
|
254
|
+
authorization: await this.webex.credentials.getUserToken(),
|
|
255
|
+
trackingId: `${config.trackingIdPrefix}_${uuid.v4().toString()}`,
|
|
256
|
+
},
|
|
257
|
+
}).catch((error) => {
|
|
258
|
+
LoggerProxy.logger.error('Meeting:webinar#viewAllWebcastAttendees failed', error);
|
|
259
|
+
throw error;
|
|
260
|
+
});
|
|
261
|
+
},
|
|
262
|
+
|
|
263
|
+
/**
|
|
264
|
+
* search webcast attendees by query string
|
|
265
|
+
* @param {string} queryString
|
|
266
|
+
* @returns {Promise}
|
|
267
|
+
*/
|
|
268
|
+
async searchWebcastAttendees(queryString = '') {
|
|
269
|
+
return this.request({
|
|
270
|
+
method: HTTP_VERBS.GET,
|
|
271
|
+
uri: `${this.webcastInstanceUrl}/attendees?keyword=${encodeURIComponent(queryString)}`,
|
|
272
|
+
headers: {
|
|
273
|
+
authorization: await this.webex.credentials.getUserToken(),
|
|
274
|
+
trackingId: `${config.trackingIdPrefix}_${uuid.v4().toString()}`,
|
|
275
|
+
},
|
|
276
|
+
}).catch((error) => {
|
|
277
|
+
LoggerProxy.logger.error('Meeting:webinar#searchWebcastAttendees failed', error);
|
|
278
|
+
throw error;
|
|
279
|
+
});
|
|
280
|
+
},
|
|
281
|
+
|
|
282
|
+
/**
|
|
283
|
+
* expel webcast attendee by participantId
|
|
284
|
+
* @param {string} participantId
|
|
285
|
+
* @returns {Promise}
|
|
286
|
+
*/
|
|
287
|
+
async expelWebcastAttendee(participantId) {
|
|
288
|
+
return this.request({
|
|
289
|
+
method: HTTP_VERBS.DELETE,
|
|
290
|
+
uri: `${this.webcastInstanceUrl}/attendees/${participantId}`,
|
|
291
|
+
headers: {
|
|
292
|
+
authorization: await this.webex.credentials.getUserToken(),
|
|
293
|
+
trackingId: `${config.trackingIdPrefix}_${uuid.v4().toString()}`,
|
|
294
|
+
},
|
|
295
|
+
}).catch((error) => {
|
|
296
|
+
LoggerProxy.logger.error('Meeting:webinar#expelWebcastAttendee failed', error);
|
|
297
|
+
throw error;
|
|
298
|
+
});
|
|
299
|
+
},
|
|
74
300
|
});
|
|
75
301
|
|
|
76
302
|
export default Webinar;
|
|
@@ -413,6 +413,51 @@ describe('live-annotation', () => {
|
|
|
413
413
|
});
|
|
414
414
|
});
|
|
415
415
|
});
|
|
416
|
-
});
|
|
417
416
|
|
|
417
|
+
describe('#deregisterEvents', () => {
|
|
418
|
+
let llmOn;
|
|
419
|
+
let llmOff;
|
|
420
|
+
let mercuryOn;
|
|
421
|
+
let mercuryOff;
|
|
422
|
+
|
|
423
|
+
beforeEach(() => {
|
|
424
|
+
llmOn = sinon.spy(webex.internal.llm, 'on');
|
|
425
|
+
llmOff = sinon.spy(webex.internal.llm, 'off');
|
|
426
|
+
mercuryOn = sinon.spy(webex.internal.mercury, 'on');
|
|
427
|
+
mercuryOff = sinon.spy(webex.internal.mercury, 'off');
|
|
428
|
+
});
|
|
429
|
+
|
|
430
|
+
it('cleans up events', () => {
|
|
431
|
+
annotationService.locusUrlUpdate(locusUrl);
|
|
432
|
+
assert.calledWith(
|
|
433
|
+
mercuryOn,
|
|
434
|
+
'event:locus.approval_request',
|
|
435
|
+
annotationService.eventCommandProcessor,
|
|
436
|
+
annotationService
|
|
437
|
+
);
|
|
438
|
+
assert.calledWith(
|
|
439
|
+
llmOn,
|
|
440
|
+
'event:relay.event',
|
|
441
|
+
annotationService.eventDataProcessor,
|
|
442
|
+
annotationService
|
|
443
|
+
);
|
|
444
|
+
assert.match(annotationService.hasSubscribedToEvents, true);
|
|
445
|
+
|
|
446
|
+
annotationService.deregisterEvents();
|
|
447
|
+
assert.calledWith(llmOff, 'event:relay.event', annotationService.eventDataProcessor);
|
|
448
|
+
assert.calledWith(
|
|
449
|
+
mercuryOff,
|
|
450
|
+
'event:locus.approval_request',
|
|
451
|
+
annotationService.eventCommandProcessor
|
|
452
|
+
);
|
|
453
|
+
assert.match(annotationService.hasSubscribedToEvents, false);
|
|
454
|
+
});
|
|
455
|
+
|
|
456
|
+
it('does not call llm off if events have not been registered', () => {
|
|
457
|
+
annotationService.deregisterEvents();
|
|
458
|
+
assert.notCalled(llmOff);
|
|
459
|
+
assert.notCalled(mercuryOff);
|
|
460
|
+
});
|
|
461
|
+
});
|
|
462
|
+
});
|
|
418
463
|
});
|