@webex/plugin-meetings 3.0.0-bnr.4 → 3.0.0-stream-classes.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/README.md +46 -8
- 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 +70 -32
- package/dist/breakouts/breakout.js.map +1 -1
- package/dist/breakouts/events.js +45 -0
- package/dist/breakouts/events.js.map +1 -0
- package/dist/breakouts/index.js +422 -217
- package/dist/breakouts/index.js.map +1 -1
- package/dist/breakouts/utils.js +12 -1
- package/dist/breakouts/utils.js.map +1 -1
- package/dist/common/errors/webex-errors.js +3 -2
- package/dist/common/errors/webex-errors.js.map +1 -1
- package/dist/common/logs/logger-proxy.js +1 -1
- package/dist/common/logs/logger-proxy.js.map +1 -1
- package/dist/common/logs/request.d.ts +1 -1
- package/dist/common/queue.js +24 -9
- package/dist/common/queue.js.map +1 -1
- package/dist/config.js +1 -7
- package/dist/config.js.map +1 -1
- package/dist/constants.js +118 -24
- package/dist/constants.js.map +1 -1
- package/dist/controls-options-manager/enums.js +2 -0
- package/dist/controls-options-manager/enums.js.map +1 -1
- package/dist/controls-options-manager/index.js +19 -14
- package/dist/controls-options-manager/index.js.map +1 -1
- package/dist/controls-options-manager/types.js.map +1 -1
- package/dist/controls-options-manager/util.js +80 -11
- package/dist/controls-options-manager/util.js.map +1 -1
- package/dist/index.js +62 -20
- package/dist/index.js.map +1 -1
- package/dist/interpretation/collection.js +23 -0
- package/dist/interpretation/collection.js.map +1 -0
- package/dist/interpretation/index.js +366 -0
- package/dist/interpretation/index.js.map +1 -0
- package/dist/interpretation/siLanguage.js +25 -0
- package/dist/interpretation/siLanguage.js.map +1 -0
- package/dist/locus-info/controlsUtils.js +71 -1
- package/dist/locus-info/controlsUtils.js.map +1 -1
- package/dist/locus-info/index.js +305 -57
- package/dist/locus-info/index.js.map +1 -1
- package/dist/locus-info/infoUtils.js +7 -1
- package/dist/locus-info/infoUtils.js.map +1 -1
- package/dist/locus-info/mediaSharesUtils.js +43 -1
- package/dist/locus-info/mediaSharesUtils.js.map +1 -1
- package/dist/locus-info/parser.js +219 -63
- package/dist/locus-info/parser.js.map +1 -1
- package/dist/locus-info/selfUtils.js +44 -22
- package/dist/locus-info/selfUtils.js.map +1 -1
- package/dist/media/index.js +57 -104
- package/dist/media/index.js.map +1 -1
- package/dist/media/properties.js +60 -121
- package/dist/media/properties.js.map +1 -1
- package/dist/meeting/in-meeting-actions.js +61 -3
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +2530 -2534
- 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 +125 -205
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +150 -150
- package/dist/meeting/request.js.map +1 -1
- package/dist/meeting/util.js +568 -438
- package/dist/meeting/util.js.map +1 -1
- package/dist/meeting-info/index.js +48 -7
- package/dist/meeting-info/index.js.map +1 -1
- package/dist/meeting-info/meeting-info-v2.js +94 -38
- package/dist/meeting-info/meeting-info-v2.js.map +1 -1
- package/dist/meeting-info/utilv2.js +4 -2
- package/dist/meeting-info/utilv2.js.map +1 -1
- package/dist/meetings/index.d.ts +0 -2
- package/dist/meetings/index.js +260 -85
- 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/util.js +42 -7
- package/dist/meetings/util.js.map +1 -1
- package/dist/member/index.d.ts +2 -0
- package/dist/member/index.js +26 -0
- package/dist/member/index.js.map +1 -1
- package/dist/member/member.types.d.ts +11 -0
- package/dist/member/member.types.js +18 -0
- package/dist/member/member.types.js.map +1 -0
- package/dist/member/types.js +11 -1
- package/dist/member/types.js.map +1 -1
- package/dist/member/util.js +60 -23
- package/dist/member/util.js.map +1 -1
- package/dist/members/index.js +4 -1
- package/dist/members/index.js.map +1 -1
- package/dist/members/request.js +75 -45
- package/dist/members/request.js.map +1 -1
- package/dist/members/util.js +308 -317
- package/dist/members/util.js.map +1 -1
- package/dist/metrics/config.js +1 -3
- package/dist/metrics/config.js.map +1 -1
- package/dist/metrics/constants.js +1 -0
- package/dist/metrics/constants.js.map +1 -1
- package/dist/metrics/index.d.ts +1 -1
- package/dist/metrics/index.js +1 -451
- package/dist/metrics/index.js.map +1 -1
- package/dist/multistream/mediaRequestManager.js +136 -40
- package/dist/multistream/mediaRequestManager.js.map +1 -1
- package/dist/multistream/receiveSlot.js.map +1 -1
- package/dist/multistream/receiveSlotManager.js +4 -4
- package/dist/multistream/receiveSlotManager.js.map +1 -1
- package/dist/multistream/remoteMedia.js.map +1 -1
- package/dist/multistream/remoteMediaGroup.js +60 -3
- package/dist/multistream/remoteMediaGroup.js.map +1 -1
- package/dist/multistream/remoteMediaManager.js +36 -0
- package/dist/multistream/remoteMediaManager.js.map +1 -1
- package/dist/multistream/sendSlotManager.js +233 -0
- package/dist/multistream/sendSlotManager.js.map +1 -0
- package/dist/reachability/index.js +18 -3
- package/dist/reachability/index.js.map +1 -1
- package/dist/reachability/request.js +5 -3
- package/dist/reachability/request.js.map +1 -1
- package/dist/reconnection-manager/index.js +181 -153
- package/dist/reconnection-manager/index.js.map +1 -1
- package/dist/recording-controller/index.js +21 -2
- package/dist/recording-controller/index.js.map +1 -1
- package/dist/recording-controller/util.js +9 -8
- package/dist/recording-controller/util.js.map +1 -1
- package/dist/roap/index.js +25 -32
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +42 -51
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/turnDiscovery.js +97 -38
- package/dist/roap/turnDiscovery.js.map +1 -1
- package/dist/rtcMetrics/constants.js +12 -0
- package/dist/rtcMetrics/constants.js.map +1 -0
- package/dist/rtcMetrics/index.js +117 -0
- package/dist/rtcMetrics/index.js.map +1 -0
- package/dist/statsAnalyzer/index.js +0 -1
- package/dist/statsAnalyzer/index.js.map +1 -1
- package/dist/types/annotation/annotation.types.d.ts +43 -0
- package/dist/types/annotation/constants.d.ts +31 -0
- package/dist/types/annotation/index.d.ts +124 -0
- package/dist/types/breakouts/events.d.ts +2 -0
- package/dist/types/breakouts/utils.d.ts +7 -0
- package/dist/types/common/errors/webex-errors.d.ts +1 -1
- package/dist/types/config.d.ts +0 -6
- package/dist/types/constants.d.ts +51 -21
- package/dist/types/controls-options-manager/enums.d.ts +2 -0
- package/dist/types/controls-options-manager/index.d.ts +1 -1
- package/dist/types/controls-options-manager/types.d.ts +7 -1
- package/dist/types/index.d.ts +1 -1
- 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/index.d.ts +39 -1
- package/dist/types/media/index.d.ts +2 -0
- package/dist/types/media/properties.d.ts +16 -38
- package/dist/types/meeting/in-meeting-actions.d.ts +46 -2
- package/dist/types/meeting/index.d.ts +179 -379
- package/dist/types/meeting/locusMediaRequest.d.ts +70 -0
- package/dist/types/meeting/muteState.d.ts +39 -40
- package/dist/types/meeting/request.d.ts +25 -26
- package/dist/types/meeting/util.d.ts +74 -1
- package/dist/types/meeting-info/meeting-info-v2.d.ts +14 -3
- package/dist/types/meetings/index.d.ts +49 -1
- package/dist/types/meetings/meetings.types.d.ts +4 -0
- package/dist/types/member/index.d.ts +2 -0
- package/dist/types/members/request.d.ts +56 -11
- package/dist/types/members/util.d.ts +209 -1
- package/dist/types/metrics/config.d.ts +26 -2
- package/dist/types/metrics/constants.d.ts +1 -0
- package/dist/types/metrics/index.d.ts +17 -0
- package/dist/types/multistream/mediaRequestManager.d.ts +27 -10
- package/dist/types/multistream/receiveSlot.d.ts +3 -3
- package/dist/types/multistream/remoteMedia.d.ts +2 -2
- package/dist/types/multistream/remoteMediaManager.d.ts +14 -0
- package/dist/types/roap/request.d.ts +6 -8
- package/dist/types/roap/turnDiscovery.d.ts +18 -1
- package/package.json +3 -2
- 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 +3 -2
- package/src/breakouts/breakout.ts +62 -27
- package/src/breakouts/events.ts +56 -0
- package/src/breakouts/index.ts +244 -64
- package/src/breakouts/utils.ts +13 -0
- package/src/common/errors/webex-errors.ts +6 -2
- package/src/common/logs/logger-proxy.ts +1 -1
- package/src/common/queue.ts +22 -8
- package/src/config.ts +0 -6
- package/src/constants.ts +111 -19
- package/src/controls-options-manager/enums.ts +2 -0
- package/src/controls-options-manager/index.ts +13 -10
- package/src/controls-options-manager/types.ts +10 -0
- package/src/controls-options-manager/util.ts +82 -11
- package/src/index.ts +18 -11
- package/src/interpretation/README.md +60 -0
- package/src/interpretation/collection.ts +19 -0
- package/src/interpretation/index.ts +332 -0
- package/src/interpretation/siLanguage.ts +18 -0
- package/src/locus-info/controlsUtils.ts +81 -0
- package/src/locus-info/index.ts +318 -57
- package/src/locus-info/infoUtils.ts +10 -2
- package/src/locus-info/mediaSharesUtils.ts +48 -0
- package/src/locus-info/parser.ts +224 -39
- package/src/locus-info/selfUtils.ts +32 -20
- package/src/media/index.ts +94 -108
- package/src/media/properties.ts +69 -109
- package/src/meeting/in-meeting-actions.ts +120 -4
- package/src/meeting/index.ts +1967 -2120
- package/src/meeting/locusMediaRequest.ts +314 -0
- package/src/meeting/muteState.ts +119 -194
- package/src/meeting/request.ts +122 -115
- package/src/meeting/util.ts +549 -413
- package/src/meeting-info/index.ts +54 -8
- package/src/meeting-info/meeting-info-v2.ts +89 -24
- package/src/meeting-info/utilv2.ts +6 -2
- package/src/meetings/index.ts +247 -87
- package/src/meetings/meetings.types.ts +12 -0
- package/src/meetings/util.ts +47 -12
- package/src/member/index.ts +28 -1
- package/src/member/types.ts +14 -0
- package/src/member/util.ts +75 -26
- package/src/members/index.ts +7 -1
- package/src/members/request.ts +61 -21
- package/src/members/util.ts +316 -326
- package/src/metrics/constants.ts +1 -0
- package/src/metrics/index.ts +1 -474
- package/src/multistream/mediaRequestManager.ts +183 -67
- package/src/multistream/receiveSlot.ts +4 -4
- package/src/multistream/receiveSlotManager.ts +4 -4
- package/src/multistream/remoteMedia.ts +2 -2
- package/src/multistream/remoteMediaGroup.ts +59 -0
- package/src/multistream/remoteMediaManager.ts +33 -0
- package/src/multistream/sendSlotManager.ts +170 -0
- package/src/reachability/index.ts +15 -4
- package/src/reachability/request.ts +7 -3
- package/src/reconnection-manager/index.ts +36 -29
- package/src/recording-controller/index.ts +20 -3
- package/src/recording-controller/util.ts +26 -9
- package/src/roap/index.ts +25 -30
- package/src/roap/request.ts +44 -51
- package/src/roap/turnDiscovery.ts +51 -25
- package/src/rtcMetrics/constants.ts +3 -0
- package/src/rtcMetrics/index.ts +100 -0
- package/src/statsAnalyzer/index.ts +0 -1
- package/test/integration/spec/converged-space-meetings.js +60 -3
- package/test/integration/spec/journey.js +336 -259
- package/test/integration/spec/space-meeting.js +76 -3
- package/test/unit/spec/annotation/index.ts +418 -0
- package/test/unit/spec/breakouts/breakout.ts +85 -26
- package/test/unit/spec/breakouts/events.ts +89 -0
- package/test/unit/spec/breakouts/index.ts +636 -98
- package/test/unit/spec/breakouts/utils.js +19 -1
- package/test/unit/spec/common/queue.js +31 -2
- package/test/unit/spec/controls-options-manager/index.js +8 -1
- package/test/unit/spec/controls-options-manager/util.js +576 -397
- package/test/unit/spec/fixture/locus.js +1 -0
- package/test/unit/spec/interpretation/collection.ts +15 -0
- package/test/unit/spec/interpretation/index.ts +589 -0
- package/test/unit/spec/interpretation/siLanguage.ts +28 -0
- package/test/unit/spec/locus-info/controlsUtils.js +195 -1
- package/test/unit/spec/locus-info/index.js +950 -45
- package/test/unit/spec/locus-info/infoUtils.js +37 -15
- package/test/unit/spec/locus-info/mediaSharesUtils.ts +22 -0
- package/test/unit/spec/locus-info/parser.js +62 -22
- package/test/unit/spec/locus-info/selfConstant.js +19 -0
- package/test/unit/spec/locus-info/selfUtils.js +131 -26
- package/test/unit/spec/media/index.ts +82 -79
- package/test/unit/spec/meeting/in-meeting-actions.ts +60 -2
- package/test/unit/spec/meeting/index.js +3208 -1734
- package/test/unit/spec/meeting/locusMediaRequest.ts +443 -0
- package/test/unit/spec/meeting/muteState.js +328 -417
- package/test/unit/spec/meeting/request.js +393 -48
- package/test/unit/spec/meeting/utils.js +552 -76
- package/test/unit/spec/meeting-info/index.js +181 -0
- package/test/unit/spec/meeting-info/meetinginfov2.js +258 -20
- package/test/unit/spec/meeting-info/utilv2.js +21 -0
- package/test/unit/spec/meetings/index.js +631 -145
- package/test/unit/spec/meetings/utils.js +164 -9
- package/test/unit/spec/member/index.js +44 -14
- package/test/unit/spec/member/util.js +296 -155
- package/test/unit/spec/members/index.js +23 -3
- package/test/unit/spec/members/request.js +167 -35
- package/test/unit/spec/metrics/index.js +1 -50
- package/test/unit/spec/multistream/mediaRequestManager.ts +366 -8
- package/test/unit/spec/multistream/receiveSlot.ts +1 -1
- package/test/unit/spec/multistream/remoteMediaGroup.ts +266 -0
- package/test/unit/spec/multistream/remoteMediaManager.ts +123 -0
- package/test/unit/spec/multistream/sendSlotManager.ts +242 -0
- package/test/unit/spec/reachability/index.ts +66 -5
- package/test/unit/spec/reachability/request.js +3 -1
- package/test/unit/spec/reconnection-manager/index.js +55 -5
- package/test/unit/spec/recording-controller/index.js +294 -218
- package/test/unit/spec/recording-controller/util.js +223 -96
- package/test/unit/spec/roap/index.ts +21 -48
- package/test/unit/spec/roap/request.ts +74 -60
- package/test/unit/spec/roap/turnDiscovery.ts +30 -6
- package/test/unit/spec/rtcMetrics/index.ts +68 -0
- package/test/utils/integrationTestUtils.js +46 -0
- package/test/utils/testUtils.js +0 -60
- package/src/metrics/config.ts +0 -487
|
@@ -5,33 +5,21 @@ var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequ
|
|
|
5
5
|
_Object$defineProperty(exports, "__esModule", {
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
|
-
exports.createMuteState = void 0;
|
|
8
|
+
exports.createMuteState = exports.MuteState = void 0;
|
|
9
9
|
var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
|
|
10
10
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
|
|
11
11
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
|
|
12
12
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
|
|
13
13
|
var _loggerProxy = _interopRequireDefault(require("../common/logs/logger-proxy"));
|
|
14
14
|
var _parameter = _interopRequireDefault(require("../common/errors/parameter"));
|
|
15
|
-
var _permission = _interopRequireDefault(require("../common/errors/permission"));
|
|
16
15
|
var _util = _interopRequireDefault(require("./util"));
|
|
17
16
|
var _constants = require("../constants");
|
|
18
|
-
/* Certain aspects of server interaction for video muting are not implemented as we currently don't support remote muting of video.
|
|
19
|
-
If we ever need to support it, search for REMOTE_MUTE_VIDEO_MISSING_IMPLEMENTATION string to find the places that need updating
|
|
20
|
-
*/
|
|
21
|
-
|
|
22
17
|
// eslint-disable-next-line import/prefer-default-export
|
|
23
|
-
var createMuteState = function createMuteState(type, meeting,
|
|
24
|
-
// todo: remove mediaDirection argument (SPARK-399695)
|
|
18
|
+
var createMuteState = function createMuteState(type, meeting, enabled) {
|
|
25
19
|
// todo: remove the meeting argument (SPARK-399695)
|
|
26
|
-
|
|
27
|
-
return null;
|
|
28
|
-
}
|
|
29
|
-
if (type === _constants.VIDEO && !mediaDirection.sendVideo) {
|
|
30
|
-
return null;
|
|
31
|
-
}
|
|
20
|
+
|
|
32
21
|
_loggerProxy.default.logger.info("Meeting:muteState#createMuteState --> ".concat(type, ": creating MuteState for meeting id ").concat(meeting === null || meeting === void 0 ? void 0 : meeting.id));
|
|
33
|
-
var muteState = new MuteState(type, meeting,
|
|
34
|
-
muteState.init(meeting);
|
|
22
|
+
var muteState = new MuteState(type, meeting, enabled);
|
|
35
23
|
return muteState;
|
|
36
24
|
};
|
|
37
25
|
|
|
@@ -39,48 +27,42 @@ var createMuteState = function createMuteState(type, meeting, mediaDirection, sd
|
|
|
39
27
|
the last requested state by the client.
|
|
40
28
|
|
|
41
29
|
More info about Locus muting API: https://sqbu-github.cisco.com/pages/WebExSquared/locus/guides/mute.html#
|
|
30
|
+
|
|
31
|
+
This class is exported only for unit tests. It should never be instantiated directly with new MuteState(), instead createMuteState() should be called
|
|
42
32
|
*/
|
|
43
33
|
exports.createMuteState = createMuteState;
|
|
44
34
|
var MuteState = /*#__PURE__*/function () {
|
|
45
|
-
// todo: remove this when doing SPARK-399695
|
|
46
|
-
|
|
47
35
|
/**
|
|
48
36
|
* Constructor
|
|
49
37
|
*
|
|
50
38
|
* @param {String} type - audio or video
|
|
51
39
|
* @param {Object} meeting - the meeting object (used for reading current remote mute status)
|
|
52
|
-
* @param {boolean}
|
|
40
|
+
* @param {boolean} enabled - whether the client audio/video is enabled at all
|
|
53
41
|
*/
|
|
54
|
-
function MuteState(type, meeting,
|
|
42
|
+
function MuteState(type, meeting, enabled) {
|
|
55
43
|
var _meeting$remoteVideoM, _meeting$unmuteVideoA;
|
|
56
44
|
(0, _classCallCheck2.default)(this, MuteState);
|
|
57
|
-
(0, _defineProperty2.default)(this, "pendingPromiseReject", void 0);
|
|
58
|
-
(0, _defineProperty2.default)(this, "pendingPromiseResolve", void 0);
|
|
59
45
|
(0, _defineProperty2.default)(this, "state", void 0);
|
|
60
46
|
(0, _defineProperty2.default)(this, "type", void 0);
|
|
61
|
-
(0, _defineProperty2.default)(this, "sdkOwnsLocalTrack", void 0);
|
|
62
47
|
(0, _defineProperty2.default)(this, "ignoreMuteStateChange", void 0);
|
|
63
48
|
if (type !== _constants.AUDIO && type !== _constants.VIDEO) {
|
|
64
49
|
throw new _parameter.default('Mute state is designed for handling audio or video only');
|
|
65
50
|
}
|
|
66
51
|
this.type = type;
|
|
67
|
-
this.sdkOwnsLocalTrack = sdkOwnsLocalTrack;
|
|
68
52
|
this.ignoreMuteStateChange = false;
|
|
69
53
|
this.state = {
|
|
70
54
|
client: {
|
|
71
|
-
|
|
55
|
+
enabled: enabled,
|
|
56
|
+
localMute: true
|
|
72
57
|
},
|
|
73
58
|
server: {
|
|
74
|
-
localMute:
|
|
59
|
+
localMute: true,
|
|
75
60
|
// because remoteVideoMuted and unmuteVideoAllowed are updated seperately, they might be undefined
|
|
76
61
|
remoteMute: type === _constants.AUDIO ? meeting.remoteMuted : (_meeting$remoteVideoM = meeting.remoteVideoMuted) !== null && _meeting$remoteVideoM !== void 0 ? _meeting$remoteVideoM : false,
|
|
77
62
|
unmuteAllowed: type === _constants.AUDIO ? meeting.unmuteAllowed : (_meeting$unmuteVideoA = meeting.unmuteVideoAllowed) !== null && _meeting$unmuteVideoA !== void 0 ? _meeting$unmuteVideoA : true
|
|
78
63
|
},
|
|
79
64
|
syncToServerInProgress: false
|
|
80
65
|
};
|
|
81
|
-
// these 2 hold the resolve, reject methods for the promise we returned to the client in last handleClientRequest() call
|
|
82
|
-
this.pendingPromiseResolve = null;
|
|
83
|
-
this.pendingPromiseReject = null;
|
|
84
66
|
}
|
|
85
67
|
|
|
86
68
|
/**
|
|
@@ -92,101 +74,78 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
92
74
|
(0, _createClass2.default)(MuteState, [{
|
|
93
75
|
key: "init",
|
|
94
76
|
value: function init(meeting) {
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
this.applyUnmuteAllowedToTrack(meeting);
|
|
77
|
+
var _meeting$mediaPropert, _meeting$mediaPropert2;
|
|
78
|
+
this.applyUnmuteAllowedToStream(meeting);
|
|
98
79
|
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
80
|
+
// if we are remotely muted, we need to apply that to the local stream now (mute on-entry)
|
|
81
|
+
if (this.state.server.remoteMute) {
|
|
82
|
+
this.muteLocalStream(meeting, this.state.server.remoteMute, 'remotelyMuted');
|
|
83
|
+
}
|
|
84
|
+
var initialMute = this.type === _constants.AUDIO ? (_meeting$mediaPropert = meeting.mediaProperties.audioStream) === null || _meeting$mediaPropert === void 0 ? void 0 : _meeting$mediaPropert.muted : (_meeting$mediaPropert2 = meeting.mediaProperties.videoStream) === null || _meeting$mediaPropert2 === void 0 ? void 0 : _meeting$mediaPropert2.muted;
|
|
85
|
+
_loggerProxy.default.logger.info("Meeting:muteState#init --> ".concat(this.type, ": local stream initial mute state: ").concat(initialMute));
|
|
86
|
+
if (initialMute !== undefined) {
|
|
87
|
+
this.state.client.localMute = initialMute;
|
|
88
|
+
} else {
|
|
89
|
+
// there is no stream, so it's like we are locally muted
|
|
90
|
+
// (this is important especially for transcoded meetings, in which the SDP m-line direction always stays "sendrecv")
|
|
91
|
+
this.state.client.localMute = true;
|
|
109
92
|
}
|
|
93
|
+
this.applyClientStateToServer(meeting);
|
|
110
94
|
}
|
|
111
95
|
|
|
112
96
|
/**
|
|
113
|
-
* This method needs to be called whenever the local audio/video
|
|
114
|
-
* It reapplies the remote mute state onto the new
|
|
115
|
-
* local mute state from the
|
|
97
|
+
* This method needs to be called whenever the local audio/video stream has changed.
|
|
98
|
+
* It reapplies the remote mute state onto the new stream and also reads the current
|
|
99
|
+
* local mute state from the stream and updates the internal state machine and sends
|
|
116
100
|
* any required requests to the server.
|
|
117
101
|
*
|
|
118
102
|
* @param {Object} meeting - the meeting object
|
|
119
103
|
* @returns {void}
|
|
120
104
|
*/
|
|
121
105
|
}, {
|
|
122
|
-
key: "
|
|
123
|
-
value: function
|
|
106
|
+
key: "handleLocalStreamChange",
|
|
107
|
+
value: function handleLocalStreamChange(meeting) {
|
|
124
108
|
return this.init(meeting);
|
|
125
109
|
}
|
|
126
110
|
|
|
127
111
|
/**
|
|
128
|
-
*
|
|
112
|
+
* Enables/disables audio/video
|
|
129
113
|
*
|
|
130
114
|
* @param {Object} meeting - the meeting object
|
|
131
|
-
* @param {
|
|
115
|
+
* @param {boolean} enable
|
|
116
|
+
* @returns {void}
|
|
117
|
+
*/
|
|
118
|
+
}, {
|
|
119
|
+
key: "enable",
|
|
120
|
+
value: function enable(meeting, _enable) {
|
|
121
|
+
this.state.client.enabled = _enable;
|
|
122
|
+
this.applyClientStateToServer(meeting);
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
/**
|
|
126
|
+
* Mutes/unmutes local stream
|
|
127
|
+
*
|
|
128
|
+
* @param {Object} meeting - the meeting object
|
|
129
|
+
* @param {Boolean} mute - true to mute the stream, false to unmute it
|
|
132
130
|
* @param {ServerMuteReason} reason - reason for muting/unmuting
|
|
133
131
|
* @returns {void}
|
|
134
132
|
*/
|
|
135
133
|
}, {
|
|
136
|
-
key: "
|
|
137
|
-
value: function
|
|
134
|
+
key: "muteLocalStream",
|
|
135
|
+
value: function muteLocalStream(meeting, mute, reason) {
|
|
138
136
|
this.ignoreMuteStateChange = true;
|
|
139
137
|
if (this.type === _constants.AUDIO) {
|
|
140
138
|
var _meeting$mediaPropert3;
|
|
141
|
-
(_meeting$mediaPropert3 = meeting.mediaProperties.
|
|
139
|
+
(_meeting$mediaPropert3 = meeting.mediaProperties.audioStream) === null || _meeting$mediaPropert3 === void 0 ? void 0 : _meeting$mediaPropert3.setServerMuted(mute, reason);
|
|
142
140
|
} else {
|
|
143
141
|
var _meeting$mediaPropert4;
|
|
144
|
-
(_meeting$mediaPropert4 = meeting.mediaProperties.
|
|
142
|
+
(_meeting$mediaPropert4 = meeting.mediaProperties.videoStream) === null || _meeting$mediaPropert4 === void 0 ? void 0 : _meeting$mediaPropert4.setServerMuted(mute, reason);
|
|
145
143
|
}
|
|
146
144
|
this.ignoreMuteStateChange = false;
|
|
147
145
|
}
|
|
148
146
|
|
|
149
147
|
/**
|
|
150
|
-
*
|
|
151
|
-
* at the point that this request becomese superseded by another client request.
|
|
152
|
-
*
|
|
153
|
-
* The client doesn't have to wait for the returned promise to resolve before calling handleClientRequest() again. If
|
|
154
|
-
* handleClientRequest() is called again before the previous one resolved, the MuteState class will make sure that eventually
|
|
155
|
-
* the server state will match the last requested state from the client.
|
|
156
|
-
*
|
|
157
|
-
* @public
|
|
158
|
-
* @memberof MuteState
|
|
159
|
-
* @param {Object} [meeting] the meeting object
|
|
160
|
-
* @param {Boolean} [mute] true for muting, false for unmuting request
|
|
161
|
-
* @returns {Promise}
|
|
162
|
-
*/
|
|
163
|
-
}, {
|
|
164
|
-
key: "handleClientRequest",
|
|
165
|
-
value: function handleClientRequest(meeting, mute) {
|
|
166
|
-
var _this = this;
|
|
167
|
-
// todo: this whole method will be removed in SPARK-399695
|
|
168
|
-
_loggerProxy.default.logger.info("Meeting:muteState#handleClientRequest --> ".concat(this.type, ": user requesting new mute state: ").concat(mute));
|
|
169
|
-
if (!mute && !this.state.server.unmuteAllowed) {
|
|
170
|
-
return _promise.default.reject(new _permission.default('User is not allowed to unmute self (hard mute feature is being used)'));
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
// we don't check if we're already in the same state, because even if we were, we would still have to apply the mute state locally,
|
|
174
|
-
// because the client may have changed the audio/video tracks
|
|
175
|
-
this.state.client.localMute = mute;
|
|
176
|
-
this.applyClientStateLocally(meeting);
|
|
177
|
-
return new _promise.default(function (resolve, reject) {
|
|
178
|
-
if (_this.pendingPromiseResolve) {
|
|
179
|
-
// resolve the last promise we returned to the client as the client has issued a new request that has superseded the previous one
|
|
180
|
-
_this.pendingPromiseResolve();
|
|
181
|
-
}
|
|
182
|
-
_this.pendingPromiseResolve = resolve;
|
|
183
|
-
_this.pendingPromiseReject = reject;
|
|
184
|
-
_this.applyClientStateToServer(meeting);
|
|
185
|
-
});
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
/**
|
|
189
|
-
* This method should be called when the local track mute state is changed
|
|
148
|
+
* This method should be called when the local stream mute state is changed
|
|
190
149
|
* @public
|
|
191
150
|
* @memberof MuteState
|
|
192
151
|
* @param {Object} [meeting] the meeting object
|
|
@@ -194,42 +153,40 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
194
153
|
* @returns {void}
|
|
195
154
|
*/
|
|
196
155
|
}, {
|
|
197
|
-
key: "
|
|
198
|
-
value: function
|
|
156
|
+
key: "handleLocalStreamMuteStateChange",
|
|
157
|
+
value: function handleLocalStreamMuteStateChange(meeting, mute) {
|
|
199
158
|
if (this.ignoreMuteStateChange) {
|
|
200
159
|
return;
|
|
201
160
|
}
|
|
202
|
-
_loggerProxy.default.logger.info("Meeting:muteState#
|
|
203
|
-
if (this.pendingPromiseReject) {
|
|
204
|
-
_loggerProxy.default.logger.error("Meeting:muteState#handleLocalTrackMuteStateChange --> ".concat(this.type, ": Local track mute state change handler called while a client request is handled - this should never happen!, mute state: ").concat(mute));
|
|
205
|
-
}
|
|
161
|
+
_loggerProxy.default.logger.info("Meeting:muteState#handleLocalStreamMuteStateChange --> ".concat(this.type, ": local stream new mute state: ").concat(mute));
|
|
206
162
|
this.state.client.localMute = mute;
|
|
207
163
|
this.applyClientStateToServer(meeting);
|
|
208
164
|
}
|
|
209
165
|
|
|
210
166
|
/**
|
|
211
|
-
* Applies the current mute state to the local
|
|
167
|
+
* Applies the current mute state to the local stream (by enabling or disabling it accordingly)
|
|
212
168
|
*
|
|
213
169
|
* @public
|
|
214
170
|
* @param {Object} [meeting] the meeting object
|
|
215
|
-
* @param {ServerMuteReason} reason - reason why we're applying our client state to the local
|
|
171
|
+
* @param {ServerMuteReason} reason - reason why we're applying our client state to the local stream
|
|
216
172
|
* @memberof MuteState
|
|
217
173
|
* @returns {void}
|
|
218
174
|
*/
|
|
219
175
|
}, {
|
|
220
176
|
key: "applyClientStateLocally",
|
|
221
177
|
value: function applyClientStateLocally(meeting, reason) {
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
178
|
+
this.muteLocalStream(meeting, this.state.client.localMute, reason);
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
/** Returns true if client is locally muted - it takes into account not just the client local mute state,
|
|
182
|
+
* but also whether audio/video is enabled at all
|
|
183
|
+
*
|
|
184
|
+
* @returns {boolean}
|
|
185
|
+
*/
|
|
186
|
+
}, {
|
|
187
|
+
key: "getClientLocalMuteState",
|
|
188
|
+
value: function getClientLocalMuteState() {
|
|
189
|
+
return this.state.client.enabled ? this.state.client.localMute : true;
|
|
233
190
|
}
|
|
234
191
|
|
|
235
192
|
/**
|
|
@@ -243,22 +200,18 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
243
200
|
}, {
|
|
244
201
|
key: "applyClientStateToServer",
|
|
245
202
|
value: function applyClientStateToServer(meeting) {
|
|
246
|
-
var
|
|
203
|
+
var _this = this;
|
|
247
204
|
if (this.state.syncToServerInProgress) {
|
|
248
205
|
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": request to server in progress, we need to wait for it to complete"));
|
|
249
206
|
return;
|
|
250
207
|
}
|
|
251
|
-
var
|
|
252
|
-
var
|
|
253
|
-
|
|
208
|
+
var localMuteState = this.getClientLocalMuteState();
|
|
209
|
+
var localMuteRequiresSync = localMuteState !== this.state.server.localMute;
|
|
210
|
+
var remoteMuteRequiresSync = !localMuteState && this.state.server.remoteMute;
|
|
211
|
+
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": localMuteRequiresSync: ").concat(localMuteRequiresSync, " (").concat(localMuteState, " ?= ").concat(this.state.server.localMute, ")"));
|
|
254
212
|
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": remoteMuteRequiresSync: ").concat(remoteMuteRequiresSync));
|
|
255
213
|
if (!localMuteRequiresSync && !remoteMuteRequiresSync) {
|
|
256
214
|
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(this.type, ": client state already matching server state, nothing to do"));
|
|
257
|
-
if (this.pendingPromiseResolve) {
|
|
258
|
-
this.pendingPromiseResolve();
|
|
259
|
-
}
|
|
260
|
-
this.pendingPromiseResolve = null;
|
|
261
|
-
this.pendingPromiseReject = null;
|
|
262
215
|
return;
|
|
263
216
|
}
|
|
264
217
|
this.state.syncToServerInProgress = true;
|
|
@@ -268,22 +221,18 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
268
221
|
localMuteSyncPromise.then(function () {
|
|
269
222
|
return (
|
|
270
223
|
// then follow it up with remote mute sync
|
|
271
|
-
remoteMuteRequiresSync ?
|
|
224
|
+
remoteMuteRequiresSync ? _this.sendRemoteMuteRequestToServer(meeting) : _promise.default.resolve()
|
|
272
225
|
);
|
|
273
226
|
}).then(function () {
|
|
274
|
-
|
|
275
|
-
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(
|
|
227
|
+
_this.state.syncToServerInProgress = false;
|
|
228
|
+
_loggerProxy.default.logger.info("Meeting:muteState#applyClientStateToServer --> ".concat(_this.type, ": sync with server completed"));
|
|
276
229
|
|
|
277
230
|
// need to check if a new sync is required, because this.state.client may have changed while we were doing the current sync
|
|
278
|
-
|
|
231
|
+
_this.applyClientStateToServer(meeting);
|
|
279
232
|
}).catch(function (e) {
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
}
|
|
284
|
-
_this2.pendingPromiseResolve = null;
|
|
285
|
-
_this2.pendingPromiseReject = null;
|
|
286
|
-
_this2.applyServerMuteToLocalTrack(meeting, 'clientRequestFailed');
|
|
233
|
+
_this.state.syncToServerInProgress = false;
|
|
234
|
+
_loggerProxy.default.logger.warn("Meeting:muteState#applyClientStateToServer --> ".concat(_this.type, ": error: ").concat(e));
|
|
235
|
+
_this.applyServerMuteToLocalStream(meeting, 'clientRequestFailed');
|
|
287
236
|
});
|
|
288
237
|
}
|
|
289
238
|
|
|
@@ -298,19 +247,19 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
298
247
|
}, {
|
|
299
248
|
key: "sendLocalMuteRequestToServer",
|
|
300
249
|
value: function sendLocalMuteRequestToServer(meeting) {
|
|
301
|
-
var
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
var audioMuted = this.type === _constants.AUDIO ? this.state.client.localMute : (_meeting$audio = meeting.audio) === null || _meeting$audio === void 0 ? void 0 : _meeting$audio.state.client.localMute;
|
|
305
|
-
var videoMuted = this.type === _constants.VIDEO ? this.state.client.localMute : (_meeting$video = meeting.video) === null || _meeting$video === void 0 ? void 0 : _meeting$video.state.client.localMute;
|
|
250
|
+
var _this2 = this;
|
|
251
|
+
var audioMuted = this.type === _constants.AUDIO ? this.getClientLocalMuteState() : undefined;
|
|
252
|
+
var videoMuted = this.type === _constants.VIDEO ? this.getClientLocalMuteState() : undefined;
|
|
306
253
|
_loggerProxy.default.logger.info("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(this.type, ": sending local mute (audio=").concat(audioMuted, ", video=").concat(videoMuted, ") to server"));
|
|
307
|
-
return _util.default.remoteUpdateAudioVideo(audioMuted, videoMuted
|
|
308
|
-
_loggerProxy.default.logger.info("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(
|
|
309
|
-
|
|
310
|
-
|
|
254
|
+
return _util.default.remoteUpdateAudioVideo(meeting, audioMuted, videoMuted).then(function (locus) {
|
|
255
|
+
_loggerProxy.default.logger.info("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(_this2.type, ": local mute (audio=").concat(audioMuted, ", video=").concat(videoMuted, ") applied to server"));
|
|
256
|
+
_this2.state.server.localMute = _this2.type === _constants.AUDIO ? audioMuted : videoMuted;
|
|
257
|
+
if (locus) {
|
|
258
|
+
meeting.locusInfo.handleLocusDelta(locus, meeting);
|
|
259
|
+
}
|
|
311
260
|
return locus;
|
|
312
261
|
}).catch(function (remoteUpdateError) {
|
|
313
|
-
_loggerProxy.default.logger.warn("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(
|
|
262
|
+
_loggerProxy.default.logger.warn("Meeting:muteState#sendLocalMuteRequestToServer --> ".concat(_this2.type, ": failed to apply local mute (audio=").concat(audioMuted, ", video=").concat(videoMuted, ") to server: ").concat(remoteUpdateError));
|
|
314
263
|
return _promise.default.reject(remoteUpdateError);
|
|
315
264
|
});
|
|
316
265
|
}
|
|
@@ -326,50 +275,47 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
326
275
|
}, {
|
|
327
276
|
key: "sendRemoteMuteRequestToServer",
|
|
328
277
|
value: function sendRemoteMuteRequestToServer(meeting) {
|
|
329
|
-
var
|
|
330
|
-
var remoteMute = this.
|
|
278
|
+
var _this3 = this;
|
|
279
|
+
var remoteMute = this.getClientLocalMuteState();
|
|
331
280
|
_loggerProxy.default.logger.info("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(this.type, ": sending remote mute:").concat(remoteMute, " to server"));
|
|
332
281
|
return meeting.members.muteMember(meeting.members.selfId, remoteMute, this.type === _constants.AUDIO).then(function () {
|
|
333
|
-
_loggerProxy.default.logger.info("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(
|
|
334
|
-
|
|
282
|
+
_loggerProxy.default.logger.info("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(_this3.type, ": remote mute:").concat(remoteMute, " applied to server"));
|
|
283
|
+
_this3.state.server.remoteMute = remoteMute;
|
|
335
284
|
}).catch(function (remoteUpdateError) {
|
|
336
|
-
_loggerProxy.default.logger.warn("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(
|
|
285
|
+
_loggerProxy.default.logger.warn("Meeting:muteState#sendRemoteMuteRequestToServer --> ".concat(_this3.type, ": failed to apply remote mute ").concat(remoteMute, " to server: ").concat(remoteUpdateError));
|
|
337
286
|
return _promise.default.reject(remoteUpdateError);
|
|
338
287
|
});
|
|
339
288
|
}
|
|
340
289
|
|
|
341
|
-
/** Sets the mute state of the local
|
|
290
|
+
/** Sets the mute state of the local stream according to what server thinks is our state
|
|
342
291
|
* @param {Object} meeting - the meeting object
|
|
343
|
-
* @param {ServerMuteReason} serverMuteReason - reason why we're applying server mute to the local
|
|
292
|
+
* @param {ServerMuteReason} serverMuteReason - reason why we're applying server mute to the local stream
|
|
344
293
|
* @returns {void}
|
|
345
294
|
*/
|
|
346
295
|
}, {
|
|
347
|
-
key: "
|
|
348
|
-
value: function
|
|
349
|
-
|
|
350
|
-
var muted = this.state.server.localMute || this.state.server.remoteMute;
|
|
296
|
+
key: "applyServerMuteToLocalStream",
|
|
297
|
+
value: function applyServerMuteToLocalStream(meeting, serverMuteReason) {
|
|
298
|
+
var muted = this.state.server.localMute || this.state.server.remoteMute;
|
|
351
299
|
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
}
|
|
300
|
+
// update the local stream mute state, but not this.state.client.localMute
|
|
301
|
+
this.muteLocalStream(meeting, muted, serverMuteReason);
|
|
355
302
|
}
|
|
356
303
|
|
|
357
|
-
/** Applies the current value for unmute allowed to the underlying
|
|
304
|
+
/** Applies the current value for unmute allowed to the underlying stream
|
|
358
305
|
*
|
|
359
306
|
* @param {Meeting} meeting
|
|
360
307
|
* @returns {void}
|
|
361
308
|
*/
|
|
309
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
362
310
|
}, {
|
|
363
|
-
key: "
|
|
364
|
-
value: function
|
|
365
|
-
if (
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
(_meeting$mediaPropert8 = meeting.mediaProperties.videoTrack) === null || _meeting$mediaPropert8 === void 0 ? void 0 : _meeting$mediaPropert8.setUnmuteAllowed(this.state.server.unmuteAllowed);
|
|
372
|
-
}
|
|
311
|
+
key: "applyUnmuteAllowedToStream",
|
|
312
|
+
value: function applyUnmuteAllowedToStream(meeting) {
|
|
313
|
+
if (this.type === _constants.AUDIO) {
|
|
314
|
+
var _meeting$mediaPropert5;
|
|
315
|
+
(_meeting$mediaPropert5 = meeting.mediaProperties.audioStream) === null || _meeting$mediaPropert5 === void 0 ? void 0 : _meeting$mediaPropert5.setUnmuteAllowed(this.state.server.unmuteAllowed);
|
|
316
|
+
} else {
|
|
317
|
+
var _meeting$mediaPropert6;
|
|
318
|
+
(_meeting$mediaPropert6 = meeting.mediaProperties.videoStream) === null || _meeting$mediaPropert6 === void 0 ? void 0 : _meeting$mediaPropert6.setUnmuteAllowed(this.state.server.unmuteAllowed);
|
|
373
319
|
}
|
|
374
320
|
}
|
|
375
321
|
|
|
@@ -389,11 +335,11 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
389
335
|
_loggerProxy.default.logger.info("Meeting:muteState#handleServerRemoteMuteUpdate --> ".concat(this.type, ": updating server remoteMute to (").concat(muted, ")"));
|
|
390
336
|
if (unmuteAllowed !== undefined) {
|
|
391
337
|
this.state.server.unmuteAllowed = unmuteAllowed;
|
|
392
|
-
this.
|
|
338
|
+
this.applyUnmuteAllowedToStream(meeting);
|
|
393
339
|
}
|
|
394
340
|
if (muted !== undefined) {
|
|
395
341
|
this.state.server.remoteMute = muted;
|
|
396
|
-
this.
|
|
342
|
+
this.applyServerMuteToLocalStream(meeting, 'remotelyMuted');
|
|
397
343
|
}
|
|
398
344
|
}
|
|
399
345
|
|
|
@@ -408,22 +354,22 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
408
354
|
}, {
|
|
409
355
|
key: "handleServerLocalUnmuteRequired",
|
|
410
356
|
value: function handleServerLocalUnmuteRequired(meeting) {
|
|
411
|
-
|
|
357
|
+
if (!this.state.client.enabled) {
|
|
358
|
+
_loggerProxy.default.logger.warn("Meeting:muteState#handleServerLocalUnmuteRequired --> ".concat(this.type, ": localAudioUnmuteRequired received while ").concat(this.type, " is disabled -> local unmute will not result in ").concat(this.type, " being sent"));
|
|
359
|
+
} else {
|
|
360
|
+
_loggerProxy.default.logger.info("Meeting:muteState#handleServerLocalUnmuteRequired --> ".concat(this.type, ": localAudioUnmuteRequired received -> doing local unmute"));
|
|
361
|
+
}
|
|
412
362
|
|
|
413
363
|
// todo: I'm seeing "you can now unmute yourself " popup when this happens - but same thing happens on web.w.c so we can ignore for now
|
|
414
364
|
this.state.server.remoteMute = false;
|
|
415
365
|
this.state.client.localMute = false;
|
|
416
|
-
if (this.pendingPromiseReject) {
|
|
417
|
-
this.pendingPromiseReject(new Error('Server requested local unmute - this overrides any client request in progress'));
|
|
418
|
-
this.pendingPromiseResolve = null;
|
|
419
|
-
this.pendingPromiseReject = null;
|
|
420
|
-
}
|
|
421
366
|
this.applyClientStateLocally(meeting, 'localUnmuteRequired');
|
|
422
367
|
this.applyClientStateToServer(meeting);
|
|
423
368
|
}
|
|
424
369
|
|
|
425
370
|
/**
|
|
426
|
-
* Returns true if the user is locally or remotely muted
|
|
371
|
+
* Returns true if the user is locally or remotely muted.
|
|
372
|
+
* It only checks the mute status, ignoring the fact whether audio/video is enabled.
|
|
427
373
|
*
|
|
428
374
|
* @public
|
|
429
375
|
* @memberof MuteState
|
|
@@ -462,7 +408,7 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
462
408
|
}
|
|
463
409
|
|
|
464
410
|
/**
|
|
465
|
-
* Returns true if the user is locally muted
|
|
411
|
+
* Returns true if the user is locally muted or audio/video is disabled
|
|
466
412
|
*
|
|
467
413
|
* @public
|
|
468
414
|
* @memberof MuteState
|
|
@@ -471,36 +417,10 @@ var MuteState = /*#__PURE__*/function () {
|
|
|
471
417
|
}, {
|
|
472
418
|
key: "isLocallyMuted",
|
|
473
419
|
value: function isLocallyMuted() {
|
|
474
|
-
return this.
|
|
475
|
-
}
|
|
476
|
-
|
|
477
|
-
/**
|
|
478
|
-
* Returns true if the user is muted as a result of the client request (and not remotely muted)
|
|
479
|
-
*
|
|
480
|
-
* @public
|
|
481
|
-
* @memberof MuteState
|
|
482
|
-
* @returns {Boolean}
|
|
483
|
-
*/
|
|
484
|
-
}, {
|
|
485
|
-
key: "isSelf",
|
|
486
|
-
value: function isSelf() {
|
|
487
|
-
return this.state.client.localMute && !this.state.server.remoteMute;
|
|
488
|
-
}
|
|
489
|
-
|
|
490
|
-
// defined for backwards compatibility with the old AudioStateMachine/VideoStateMachine classes
|
|
491
|
-
}, {
|
|
492
|
-
key: "muted",
|
|
493
|
-
get: function get() {
|
|
494
|
-
return this.isMuted();
|
|
495
|
-
}
|
|
496
|
-
|
|
497
|
-
// defined for backwards compatibility with the old AudioStateMachine/VideoStateMachine classes
|
|
498
|
-
}, {
|
|
499
|
-
key: "self",
|
|
500
|
-
get: function get() {
|
|
501
|
-
return this.isSelf();
|
|
420
|
+
return this.getClientLocalMuteState();
|
|
502
421
|
}
|
|
503
422
|
}]);
|
|
504
423
|
return MuteState;
|
|
505
424
|
}();
|
|
425
|
+
exports.MuteState = MuteState;
|
|
506
426
|
//# sourceMappingURL=muteState.js.map
|