@webex/plugin-meetings 3.0.0-beta.14 → 3.0.0-beta.16
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/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 +5 -26
- package/dist/common/errors/captcha-error.js.map +1 -1
- package/dist/common/errors/intent-to-join.js +5 -26
- package/dist/common/errors/intent-to-join.js.map +1 -1
- package/dist/common/errors/join-meeting.js +6 -27
- package/dist/common/errors/join-meeting.js.map +1 -1
- package/dist/common/errors/media.js +5 -26
- 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 +5 -26
- package/dist/common/errors/password-error.js.map +1 -1
- package/dist/common/errors/permission.js +4 -25
- 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 +5 -26
- package/dist/common/errors/reconnection.js.map +1 -1
- package/dist/common/errors/stats.js +5 -26
- 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 +1 -24
- 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 +35 -61
- 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 +1 -5
- package/dist/config.js.map +1 -1
- package/dist/constants.js +45 -40
- 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 +10 -28
- 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 +101 -193
- package/dist/locus-info/index.js.map +1 -1
- package/dist/locus-info/infoUtils.js +0 -38
- 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 +87 -123
- package/dist/locus-info/parser.js.map +1 -1
- package/dist/locus-info/selfUtils.js +16 -81
- package/dist/locus-info/selfUtils.js.map +1 -1
- package/dist/media/index.js +43 -97
- package/dist/media/index.js.map +1 -1
- package/dist/media/internal-media-core-wrapper.js +0 -4
- package/dist/media/internal-media-core-wrapper.js.map +1 -1
- package/dist/media/properties.js +64 -110
- 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 +120 -192
- package/dist/meeting/effectsState.js.map +1 -1
- package/dist/meeting/in-meeting-actions.js +0 -13
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +819 -1591
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/muteState.js +31 -78
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +160 -230
- package/dist/meeting/request.js.map +1 -1
- package/dist/meeting/request.type.js +0 -1
- package/dist/meeting/request.type.js.map +1 -1
- package/dist/meeting/state.js +21 -31
- package/dist/meeting/state.js.map +1 -1
- package/dist/meeting/util.js +19 -158
- package/dist/meeting/util.js.map +1 -1
- package/dist/meeting-info/collection.js +3 -25
- package/dist/meeting-info/collection.js.map +1 -1
- package/dist/meeting-info/index.js +10 -33
- package/dist/meeting-info/index.js.map +1 -1
- package/dist/meeting-info/meeting-info-v2.js +179 -268
- package/dist/meeting-info/meeting-info-v2.js.map +1 -1
- package/dist/meeting-info/request.js +1 -16
- 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 +3 -21
- package/dist/meetings/collection.js.map +1 -1
- package/dist/meetings/index.js +450 -582
- package/dist/meetings/index.js.map +1 -1
- package/dist/meetings/request.js +7 -30
- 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 +49 -89
- package/dist/member/index.js.map +1 -1
- package/dist/member/util.js +17 -68
- package/dist/member/util.js.map +1 -1
- package/dist/members/collection.js +2 -12
- package/dist/members/collection.js.map +1 -1
- package/dist/members/index.js +72 -194
- package/dist/members/index.js.map +1 -1
- package/dist/members/request.js +21 -56
- 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 +48 -136
- package/dist/metrics/index.js.map +1 -1
- package/dist/multistream/mediaRequestManager.js +12 -28
- package/dist/multistream/mediaRequestManager.js.map +1 -1
- package/dist/multistream/multistreamMedia.js +11 -21
- package/dist/multistream/multistreamMedia.js.map +1 -1
- package/dist/multistream/receiveSlot.js +7 -47
- package/dist/multistream/receiveSlot.js.map +1 -1
- package/dist/multistream/receiveSlotManager.js +38 -77
- package/dist/multistream/receiveSlotManager.js.map +1 -1
- package/dist/multistream/remoteMedia.js +11 -56
- 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 +221 -380
- package/dist/multistream/remoteMediaManager.js.map +1 -1
- package/dist/networkQualityMonitor/index.js +28 -57
- package/dist/networkQualityMonitor/index.js.map +1 -1
- package/dist/personal-meeting-room/index.js +10 -45
- package/dist/personal-meeting-room/index.js.map +1 -1
- package/dist/personal-meeting-room/request.js +2 -33
- 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 +100 -166
- package/dist/reachability/index.js.map +1 -1
- package/dist/reachability/request.js +2 -18
- package/dist/reachability/request.js.map +1 -1
- package/dist/reactions/reactions.js +0 -2
- package/dist/reactions/reactions.js.map +1 -1
- package/dist/reactions/reactions.type.js +2 -6
- package/dist/reactions/reactions.type.js.map +1 -1
- package/dist/reconnection-manager/index.js +294 -459
- package/dist/reconnection-manager/index.js.map +1 -1
- package/dist/roap/index.js +18 -53
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +13 -55
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/turnDiscovery.js +10 -52
- 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 +66 -174
- package/dist/statsAnalyzer/index.js.map +1 -1
- package/dist/statsAnalyzer/mqaUtil.js +54 -53
- package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
- package/dist/transcription/index.js +13 -45
- package/dist/transcription/index.js.map +1 -1
- package/internal-README.md +7 -6
- package/package.json +18 -18
- package/src/common/browser-detection.ts +9 -6
- package/src/common/collection.ts +3 -1
- package/src/common/errors/captcha-error.ts +6 -6
- package/src/common/errors/intent-to-join.ts +6 -6
- package/src/common/errors/join-meeting.ts +12 -8
- package/src/common/errors/media.ts +6 -6
- package/src/common/errors/parameter.ts +9 -6
- package/src/common/errors/password-error.ts +6 -6
- package/src/common/errors/permission.ts +5 -5
- package/src/common/errors/reconnection.ts +6 -6
- package/src/common/errors/stats.ts +6 -6
- package/src/common/errors/webex-errors.ts +7 -5
- package/src/common/errors/webex-meetings-error.ts +1 -1
- package/src/common/events/events-scope.ts +5 -1
- package/src/common/events/events.ts +5 -1
- package/src/common/events/trigger-proxy.ts +8 -3
- package/src/common/events/util.ts +1 -2
- package/src/common/logs/logger-proxy.ts +21 -10
- package/src/common/logs/request.ts +11 -8
- package/src/config.ts +11 -11
- package/src/constants.ts +1 -1
- package/src/index.js +1 -1
- package/src/locus-info/controlsUtils.ts +34 -24
- package/src/locus-info/fullState.ts +15 -11
- package/src/locus-info/hostUtils.ts +4 -3
- package/src/locus-info/index.ts +25 -34
- package/src/locus-info/infoUtils.ts +12 -4
- package/src/locus-info/mediaSharesUtils.ts +4 -4
- package/src/locus-info/parser.ts +45 -68
- package/src/locus-info/selfUtils.ts +106 -57
- package/src/media/index.ts +123 -135
- package/src/media/internal-media-core-wrapper.ts +2 -2
- package/src/media/properties.ts +30 -20
- package/src/media/util.ts +1 -1
- package/src/mediaQualityMetrics/config.ts +46 -46
- package/src/meeting/effectsState.ts +35 -35
- package/src/meeting/in-meeting-actions.ts +7 -3
- package/src/meeting/index.ts +1559 -1292
- package/src/meeting/muteState.ts +62 -31
- package/src/meeting/request.ts +155 -116
- package/src/meeting/request.type.ts +8 -8
- package/src/meeting/state.ts +45 -30
- package/src/meeting/util.ts +101 -70
- package/src/meeting-info/collection.ts +2 -1
- package/src/meeting-info/index.ts +32 -30
- package/src/meeting-info/meeting-info-v2.ts +106 -108
- package/src/meeting-info/request.ts +9 -3
- package/src/meeting-info/util.ts +54 -46
- package/src/meeting-info/utilv2.ts +59 -53
- package/src/meetings/collection.ts +1 -1
- package/src/meetings/index.ts +512 -440
- package/src/meetings/request.ts +26 -24
- package/src/meetings/util.ts +29 -29
- package/src/member/index.ts +55 -49
- package/src/member/util.ts +26 -13
- package/src/members/collection.ts +0 -1
- package/src/members/index.ts +182 -126
- package/src/members/request.ts +46 -14
- package/src/members/util.ts +44 -42
- package/src/metrics/config.ts +254 -81
- package/src/metrics/constants.ts +0 -2
- package/src/metrics/index.ts +84 -71
- package/src/multistream/multistreamMedia.ts +1 -0
- package/src/multistream/receiveSlot.ts +1 -0
- package/src/multistream/receiveSlotManager.ts +1 -0
- package/src/multistream/remoteMedia.ts +1 -1
- package/src/multistream/remoteMediaGroup.ts +2 -1
- package/src/multistream/remoteMediaManager.ts +3 -0
- package/src/networkQualityMonitor/index.ts +20 -23
- package/src/personal-meeting-room/index.ts +12 -16
- package/src/personal-meeting-room/request.ts +10 -3
- package/src/personal-meeting-room/util.ts +3 -3
- package/src/reachability/index.ts +61 -59
- package/src/reachability/request.ts +36 -32
- package/src/reactions/reactions.ts +4 -4
- package/src/reactions/reactions.type.ts +4 -3
- package/src/reconnection-manager/index.ts +139 -84
- package/src/roap/index.ts +46 -38
- package/src/roap/request.ts +44 -31
- package/src/roap/turnDiscovery.ts +59 -30
- package/src/statsAnalyzer/global.ts +30 -33
- package/src/statsAnalyzer/index.ts +432 -175
- package/src/statsAnalyzer/mqaUtil.ts +178 -72
- package/src/transcription/index.ts +34 -32
- package/test/integration/spec/journey.js +664 -463
- package/test/integration/spec/space-meeting.js +319 -204
- package/test/integration/spec/transcription.js +7 -8
- 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 +5 -5
- package/test/unit/spec/locus-info/embeddedAppsUtils.js +8 -6
- package/test/unit/spec/locus-info/index.js +1 -2
- package/test/unit/spec/locus-info/infoUtils.js +26 -33
- 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 +72 -103
- package/test/unit/spec/locus-info/selfUtils.js +21 -12
- package/test/unit/spec/meeting/effectsState.js +36 -46
- package/test/unit/spec/meeting/in-meeting-actions.ts +2 -3
- package/test/unit/spec/meeting/index.js +1279 -685
- package/test/unit/spec/meeting/muteState.js +42 -33
- package/test/unit/spec/meeting/request.js +57 -46
- package/test/unit/spec/meeting/utils.js +78 -53
- 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 +438 -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 +5 -6
- 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/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 +9 -11
- package/test/unit/spec/reconnection-manager/index.js +16 -18
- package/test/unit/spec/roap/turnDiscovery.ts +22 -19
- package/test/unit/spec/stats-analyzer/index.js +25 -20
- 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 +53 -50
|
@@ -1,48 +1,30 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _Reflect$construct = require("@babel/runtime-corejs2/core-js/reflect/construct");
|
|
4
|
-
|
|
5
4
|
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
6
|
-
|
|
7
5
|
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
|
|
8
|
-
|
|
9
6
|
_Object$defineProperty(exports, "__esModule", {
|
|
10
7
|
value: true
|
|
11
8
|
});
|
|
12
|
-
|
|
13
9
|
exports.RemoteMediaEvents = exports.RemoteMedia = void 0;
|
|
14
10
|
exports.getMaxFs = getMaxFs;
|
|
15
|
-
|
|
16
11
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
|
|
17
|
-
|
|
18
12
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
|
|
19
|
-
|
|
20
13
|
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/assertThisInitialized"));
|
|
21
|
-
|
|
22
14
|
var _inherits2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/inherits"));
|
|
23
|
-
|
|
24
15
|
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/possibleConstructorReturn"));
|
|
25
|
-
|
|
26
16
|
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/getPrototypeOf"));
|
|
27
|
-
|
|
28
17
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
|
|
29
|
-
|
|
30
18
|
var _loggerProxy = _interopRequireDefault(require("../common/logs/logger-proxy"));
|
|
31
|
-
|
|
32
19
|
var _eventsScope = _interopRequireDefault(require("../common/events/events-scope"));
|
|
33
|
-
|
|
34
20
|
var _receiveSlot = require("./receiveSlot");
|
|
35
|
-
|
|
36
21
|
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = _Reflect$construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; }
|
|
37
|
-
|
|
38
22
|
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !_Reflect$construct) return false; if (_Reflect$construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
39
|
-
|
|
40
23
|
var RemoteMediaEvents = {
|
|
41
24
|
SourceUpdate: _receiveSlot.ReceiveSlotEvents.SourceUpdate,
|
|
42
25
|
Stopped: 'stopped'
|
|
43
26
|
};
|
|
44
27
|
exports.RemoteMediaEvents = RemoteMediaEvents;
|
|
45
|
-
|
|
46
28
|
// highest possible resolution
|
|
47
29
|
|
|
48
30
|
/**
|
|
@@ -52,55 +34,42 @@ exports.RemoteMediaEvents = RemoteMediaEvents;
|
|
|
52
34
|
*/
|
|
53
35
|
function getMaxFs(paneSize) {
|
|
54
36
|
var maxFs;
|
|
55
|
-
|
|
56
37
|
switch (paneSize) {
|
|
57
38
|
case 'thumbnail':
|
|
58
39
|
maxFs = 60;
|
|
59
40
|
break;
|
|
60
|
-
|
|
61
41
|
case 'very small':
|
|
62
42
|
maxFs = 240;
|
|
63
43
|
break;
|
|
64
|
-
|
|
65
44
|
case 'small':
|
|
66
45
|
maxFs = 920;
|
|
67
46
|
break;
|
|
68
|
-
|
|
69
47
|
case 'medium':
|
|
70
48
|
maxFs = 3600;
|
|
71
49
|
break;
|
|
72
|
-
|
|
73
50
|
case 'large':
|
|
74
51
|
maxFs = 8192;
|
|
75
52
|
break;
|
|
76
|
-
|
|
77
53
|
case 'best':
|
|
78
54
|
maxFs = 8192; // for now 'best' is 1080p, so same as 'large'
|
|
79
|
-
|
|
80
55
|
break;
|
|
81
|
-
|
|
82
56
|
default:
|
|
83
57
|
_loggerProxy.default.logger.warn("RemoteMedia#getMaxFs --> unsupported paneSize: ".concat(paneSize, ", using \"medium\" instead"));
|
|
84
|
-
|
|
85
58
|
maxFs = 3600;
|
|
86
59
|
}
|
|
87
|
-
|
|
88
60
|
return maxFs;
|
|
89
61
|
}
|
|
90
|
-
|
|
91
62
|
var remoteMediaCounter = 0;
|
|
63
|
+
|
|
92
64
|
/**
|
|
93
65
|
* Class representing a remote audio/video stream.
|
|
94
66
|
*
|
|
95
67
|
* Internally it is associated with a specific receive slot
|
|
96
68
|
* and a media request for it.
|
|
97
69
|
*/
|
|
98
|
-
|
|
99
70
|
var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
100
71
|
(0, _inherits2.default)(RemoteMedia, _EventsScope);
|
|
101
|
-
|
|
102
72
|
var _super = _createSuper(RemoteMedia);
|
|
103
|
-
|
|
104
73
|
/**
|
|
105
74
|
* Constructs RemoteMedia instance
|
|
106
75
|
*
|
|
@@ -110,7 +79,6 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
110
79
|
*/
|
|
111
80
|
function RemoteMedia(receiveSlot, mediaRequestManager, options) {
|
|
112
81
|
var _this;
|
|
113
|
-
|
|
114
82
|
(0, _classCallCheck2.default)(this, RemoteMedia);
|
|
115
83
|
_this = _super.call(this);
|
|
116
84
|
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "receiveSlot", void 0);
|
|
@@ -122,12 +90,11 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
122
90
|
_this.receiveSlot = receiveSlot;
|
|
123
91
|
_this.mediaRequestManager = mediaRequestManager;
|
|
124
92
|
_this.options = options || {};
|
|
125
|
-
|
|
126
93
|
_this.setupEventListeners();
|
|
127
|
-
|
|
128
94
|
_this.id = "RM".concat(remoteMediaCounter, "-").concat(_this.receiveSlot.id);
|
|
129
95
|
return _this;
|
|
130
96
|
}
|
|
97
|
+
|
|
131
98
|
/**
|
|
132
99
|
* Invalidates the remote media by clearing the reference to a receive slot and
|
|
133
100
|
* cancelling the media request.
|
|
@@ -136,13 +103,10 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
136
103
|
* @param {boolean} commit - whether to commit the cancellation of the media request
|
|
137
104
|
* @internal
|
|
138
105
|
*/
|
|
139
|
-
|
|
140
|
-
|
|
141
106
|
(0, _createClass2.default)(RemoteMedia, [{
|
|
142
107
|
key: "stop",
|
|
143
108
|
value: function stop() {
|
|
144
109
|
var _this$receiveSlot;
|
|
145
|
-
|
|
146
110
|
var commit = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;
|
|
147
111
|
this.cancelMediaRequest(commit);
|
|
148
112
|
(_this$receiveSlot = this.receiveSlot) === null || _this$receiveSlot === void 0 ? void 0 : _this$receiveSlot.removeAllListeners();
|
|
@@ -152,6 +116,7 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
152
116
|
function: 'stop'
|
|
153
117
|
}, RemoteMediaEvents.Stopped, {});
|
|
154
118
|
}
|
|
119
|
+
|
|
155
120
|
/**
|
|
156
121
|
* Sends a new media request. This method can only be used for receiver-selected policy,
|
|
157
122
|
* because only in that policy we have a 1-1 relationship between RemoteMedia and MediaRequest
|
|
@@ -161,18 +126,15 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
161
126
|
*
|
|
162
127
|
* @internal
|
|
163
128
|
*/
|
|
164
|
-
|
|
165
129
|
}, {
|
|
166
130
|
key: "sendMediaRequest",
|
|
167
131
|
value: function sendMediaRequest(csi, commit) {
|
|
168
132
|
if (this.mediaRequestId) {
|
|
169
133
|
this.cancelMediaRequest(false);
|
|
170
134
|
}
|
|
171
|
-
|
|
172
135
|
if (!this.receiveSlot) {
|
|
173
136
|
throw new Error('sendMediaRequest() called on an invalidated RemoteMedia instance');
|
|
174
137
|
}
|
|
175
|
-
|
|
176
138
|
this.mediaRequestId = this.mediaRequestManager.addRequest({
|
|
177
139
|
policyInfo: {
|
|
178
140
|
policy: 'receiver-selected',
|
|
@@ -185,10 +147,10 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
185
147
|
}
|
|
186
148
|
}, commit);
|
|
187
149
|
}
|
|
150
|
+
|
|
188
151
|
/**
|
|
189
152
|
* @internal
|
|
190
153
|
*/
|
|
191
|
-
|
|
192
154
|
}, {
|
|
193
155
|
key: "cancelMediaRequest",
|
|
194
156
|
value: function cancelMediaRequest(commit) {
|
|
@@ -197,15 +159,14 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
197
159
|
this.mediaRequestId = undefined;
|
|
198
160
|
}
|
|
199
161
|
}
|
|
162
|
+
|
|
200
163
|
/**
|
|
201
164
|
* registers event listeners on the receive slot and forwards all the events
|
|
202
165
|
*/
|
|
203
|
-
|
|
204
166
|
}, {
|
|
205
167
|
key: "setupEventListeners",
|
|
206
168
|
value: function setupEventListeners() {
|
|
207
169
|
var _this2 = this;
|
|
208
|
-
|
|
209
170
|
if (this.receiveSlot) {
|
|
210
171
|
var scope = {
|
|
211
172
|
file: 'multistream/remoteMedia',
|
|
@@ -216,66 +177,61 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
216
177
|
});
|
|
217
178
|
}
|
|
218
179
|
}
|
|
180
|
+
|
|
219
181
|
/**
|
|
220
182
|
* Getter for mediaType
|
|
221
183
|
*/
|
|
222
|
-
|
|
223
184
|
}, {
|
|
224
185
|
key: "mediaType",
|
|
225
186
|
get: function get() {
|
|
226
187
|
var _this$receiveSlot2;
|
|
227
|
-
|
|
228
188
|
return (_this$receiveSlot2 = this.receiveSlot) === null || _this$receiveSlot2 === void 0 ? void 0 : _this$receiveSlot2.mediaType;
|
|
229
189
|
}
|
|
190
|
+
|
|
230
191
|
/**
|
|
231
192
|
* Getter for memberId
|
|
232
193
|
*/
|
|
233
|
-
|
|
234
194
|
}, {
|
|
235
195
|
key: "memberId",
|
|
236
196
|
get: function get() {
|
|
237
197
|
var _this$receiveSlot3;
|
|
238
|
-
|
|
239
198
|
return (_this$receiveSlot3 = this.receiveSlot) === null || _this$receiveSlot3 === void 0 ? void 0 : _this$receiveSlot3.memberId;
|
|
240
199
|
}
|
|
200
|
+
|
|
241
201
|
/**
|
|
242
202
|
* Getter for csi
|
|
243
203
|
*/
|
|
244
|
-
|
|
245
204
|
}, {
|
|
246
205
|
key: "csi",
|
|
247
206
|
get: function get() {
|
|
248
207
|
var _this$receiveSlot4;
|
|
249
|
-
|
|
250
208
|
return (_this$receiveSlot4 = this.receiveSlot) === null || _this$receiveSlot4 === void 0 ? void 0 : _this$receiveSlot4.csi;
|
|
251
209
|
}
|
|
210
|
+
|
|
252
211
|
/**
|
|
253
212
|
* Getter for source state
|
|
254
213
|
*/
|
|
255
|
-
|
|
256
214
|
}, {
|
|
257
215
|
key: "sourceState",
|
|
258
216
|
get: function get() {
|
|
259
217
|
var _this$receiveSlot5;
|
|
260
|
-
|
|
261
218
|
return (_this$receiveSlot5 = this.receiveSlot) === null || _this$receiveSlot5 === void 0 ? void 0 : _this$receiveSlot5.sourceState;
|
|
262
219
|
}
|
|
220
|
+
|
|
263
221
|
/**
|
|
264
222
|
* Getter for remote media stream
|
|
265
223
|
*/
|
|
266
|
-
|
|
267
224
|
}, {
|
|
268
225
|
key: "stream",
|
|
269
226
|
get: function get() {
|
|
270
227
|
var _this$receiveSlot6;
|
|
271
|
-
|
|
272
228
|
return (_this$receiveSlot6 = this.receiveSlot) === null || _this$receiveSlot6 === void 0 ? void 0 : _this$receiveSlot6.stream;
|
|
273
229
|
}
|
|
230
|
+
|
|
274
231
|
/**
|
|
275
232
|
* @internal
|
|
276
233
|
* @returns {ReceiveSlot}
|
|
277
234
|
*/
|
|
278
|
-
|
|
279
235
|
}, {
|
|
280
236
|
key: "getUnderlyingReceiveSlot",
|
|
281
237
|
value: function getUnderlyingReceiveSlot() {
|
|
@@ -284,6 +240,5 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
284
240
|
}]);
|
|
285
241
|
return RemoteMedia;
|
|
286
242
|
}(_eventsScope.default);
|
|
287
|
-
|
|
288
243
|
exports.RemoteMedia = RemoteMedia;
|
|
289
244
|
//# sourceMappingURL=remoteMedia.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["RemoteMediaEvents","SourceUpdate","ReceiveSlotEvents","Stopped","getMaxFs","paneSize","maxFs","LoggerProxy","logger","warn","remoteMediaCounter","RemoteMedia","receiveSlot","mediaRequestManager","options","setupEventListeners","id","commit","cancelMediaRequest","removeAllListeners","undefined","emit","file","function","csi","mediaRequestId","Error","addRequest","policyInfo","policy","receiveSlots","codecInfo","resolution","codec","cancelRequest","scope","on","data","mediaType","memberId","sourceState","stream","EventsScope"],"sources":["remoteMedia.ts"],"sourcesContent":["/* eslint-disable valid-jsdoc */\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport EventsScope from '../common/events/events-scope';\n\nimport {MediaRequestId, MediaRequestManager} from './mediaRequestManager';\nimport {CSI, ReceiveSlot, ReceiveSlotEvents} from './receiveSlot';\n\nexport const RemoteMediaEvents = {\n SourceUpdate: ReceiveSlotEvents.SourceUpdate,\n Stopped: 'stopped',\n};\n\nexport type RemoteVideoResolution =\n | 'thumbnail' // the smallest possible resolution, 90p or less\n | 'very small' // 180p or less\n | 'small' // 360p or less\n | 'medium' // 720p or less\n | 'large' // 1080p or less\n | 'best'; // highest possible resolution\n\n/**\n * Converts pane size into h264 maxFs\n * @param {PaneSize} paneSize\n * @returns {number}\n */\nexport function getMaxFs(paneSize: RemoteVideoResolution): number {\n let maxFs;\n\n switch (paneSize) {\n case 'thumbnail':\n maxFs = 60;\n break;\n case 'very small':\n maxFs = 240;\n break;\n case 'small':\n maxFs = 920;\n break;\n case 'medium':\n maxFs = 3600;\n break;\n case 'large':\n maxFs = 8192;\n break;\n case 'best':\n maxFs = 8192; // for now 'best' is 1080p, so same as 'large'\n break;\n default:\n LoggerProxy.logger.warn(\n `RemoteMedia#getMaxFs --> unsupported paneSize: ${paneSize}, using \"medium\" instead`\n );\n maxFs = 3600;\n }\n\n return maxFs;\n}\n\ntype Options = {\n resolution?: RemoteVideoResolution; // applies only to groups of type MC.MediaType.VideoMain and MC.MediaType.VideoSlides\n};\n\nexport type RemoteMediaId = string;\n\nlet remoteMediaCounter = 0;\n\n/**\n * Class representing a remote audio/video stream.\n *\n * Internally it is associated with a specific receive slot\n * and a media request for it.\n */\nexport class RemoteMedia extends EventsScope {\n private receiveSlot?: ReceiveSlot;\n\n private readonly mediaRequestManager: MediaRequestManager;\n\n private readonly options: Options;\n\n private mediaRequestId?: MediaRequestId;\n\n public readonly id: RemoteMediaId;\n\n /**\n * Constructs RemoteMedia instance\n *\n * @param receiveSlot\n * @param mediaRequestManager\n * @param options\n */\n constructor(\n receiveSlot: ReceiveSlot,\n mediaRequestManager: MediaRequestManager,\n options?: Options\n ) {\n super();\n remoteMediaCounter += 1;\n this.receiveSlot = receiveSlot;\n this.mediaRequestManager = mediaRequestManager;\n this.options = options || {};\n this.setupEventListeners();\n this.id = `RM${remoteMediaCounter}-${this.receiveSlot.id}`;\n }\n\n /**\n * Invalidates the remote media by clearing the reference to a receive slot and\n * cancelling the media request.\n * After this call the remote media is unusable.\n *\n * @param {boolean} commit - whether to commit the cancellation of the media request\n * @internal\n */\n public stop(commit
|
|
1
|
+
{"version":3,"names":["RemoteMediaEvents","SourceUpdate","ReceiveSlotEvents","Stopped","getMaxFs","paneSize","maxFs","LoggerProxy","logger","warn","remoteMediaCounter","RemoteMedia","receiveSlot","mediaRequestManager","options","setupEventListeners","id","commit","cancelMediaRequest","removeAllListeners","undefined","emit","file","function","csi","mediaRequestId","Error","addRequest","policyInfo","policy","receiveSlots","codecInfo","resolution","codec","cancelRequest","scope","on","data","mediaType","memberId","sourceState","stream","EventsScope"],"sources":["remoteMedia.ts"],"sourcesContent":["/* eslint-disable valid-jsdoc */\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport EventsScope from '../common/events/events-scope';\n\nimport {MediaRequestId, MediaRequestManager} from './mediaRequestManager';\nimport {CSI, ReceiveSlot, ReceiveSlotEvents} from './receiveSlot';\n\nexport const RemoteMediaEvents = {\n SourceUpdate: ReceiveSlotEvents.SourceUpdate,\n Stopped: 'stopped',\n};\n\nexport type RemoteVideoResolution =\n | 'thumbnail' // the smallest possible resolution, 90p or less\n | 'very small' // 180p or less\n | 'small' // 360p or less\n | 'medium' // 720p or less\n | 'large' // 1080p or less\n | 'best'; // highest possible resolution\n\n/**\n * Converts pane size into h264 maxFs\n * @param {PaneSize} paneSize\n * @returns {number}\n */\nexport function getMaxFs(paneSize: RemoteVideoResolution): number {\n let maxFs;\n\n switch (paneSize) {\n case 'thumbnail':\n maxFs = 60;\n break;\n case 'very small':\n maxFs = 240;\n break;\n case 'small':\n maxFs = 920;\n break;\n case 'medium':\n maxFs = 3600;\n break;\n case 'large':\n maxFs = 8192;\n break;\n case 'best':\n maxFs = 8192; // for now 'best' is 1080p, so same as 'large'\n break;\n default:\n LoggerProxy.logger.warn(\n `RemoteMedia#getMaxFs --> unsupported paneSize: ${paneSize}, using \"medium\" instead`\n );\n maxFs = 3600;\n }\n\n return maxFs;\n}\n\ntype Options = {\n resolution?: RemoteVideoResolution; // applies only to groups of type MC.MediaType.VideoMain and MC.MediaType.VideoSlides\n};\n\nexport type RemoteMediaId = string;\n\nlet remoteMediaCounter = 0;\n\n/**\n * Class representing a remote audio/video stream.\n *\n * Internally it is associated with a specific receive slot\n * and a media request for it.\n */\nexport class RemoteMedia extends EventsScope {\n private receiveSlot?: ReceiveSlot;\n\n private readonly mediaRequestManager: MediaRequestManager;\n\n private readonly options: Options;\n\n private mediaRequestId?: MediaRequestId;\n\n public readonly id: RemoteMediaId;\n\n /**\n * Constructs RemoteMedia instance\n *\n * @param receiveSlot\n * @param mediaRequestManager\n * @param options\n */\n constructor(\n receiveSlot: ReceiveSlot,\n mediaRequestManager: MediaRequestManager,\n options?: Options\n ) {\n super();\n remoteMediaCounter += 1;\n this.receiveSlot = receiveSlot;\n this.mediaRequestManager = mediaRequestManager;\n this.options = options || {};\n this.setupEventListeners();\n this.id = `RM${remoteMediaCounter}-${this.receiveSlot.id}`;\n }\n\n /**\n * Invalidates the remote media by clearing the reference to a receive slot and\n * cancelling the media request.\n * After this call the remote media is unusable.\n *\n * @param {boolean} commit - whether to commit the cancellation of the media request\n * @internal\n */\n public stop(commit = true) {\n this.cancelMediaRequest(commit);\n this.receiveSlot?.removeAllListeners();\n this.receiveSlot = undefined;\n this.emit(\n {\n file: 'multistream/remoteMedia',\n function: 'stop',\n },\n RemoteMediaEvents.Stopped,\n {}\n );\n }\n\n /**\n * Sends a new media request. This method can only be used for receiver-selected policy,\n * because only in that policy we have a 1-1 relationship between RemoteMedia and MediaRequest\n * and the request id is then stored in this RemoteMedia instance.\n * For active-speaker policy, the same request is shared among many RemoteMedia instances,\n * so it's managed through RemoteMediaGroup\n *\n * @internal\n */\n public sendMediaRequest(csi: CSI, commit: boolean) {\n if (this.mediaRequestId) {\n this.cancelMediaRequest(false);\n }\n\n if (!this.receiveSlot) {\n throw new Error('sendMediaRequest() called on an invalidated RemoteMedia instance');\n }\n\n this.mediaRequestId = this.mediaRequestManager.addRequest(\n {\n policyInfo: {\n policy: 'receiver-selected',\n csi,\n },\n receiveSlots: [this.receiveSlot],\n codecInfo: this.options.resolution && {\n codec: 'h264',\n maxFs: getMaxFs(this.options.resolution),\n },\n },\n commit\n );\n }\n\n /**\n * @internal\n */\n public cancelMediaRequest(commit: boolean) {\n if (this.mediaRequestId) {\n this.mediaRequestManager.cancelRequest(this.mediaRequestId, commit);\n this.mediaRequestId = undefined;\n }\n }\n\n /**\n * registers event listeners on the receive slot and forwards all the events\n */\n private setupEventListeners() {\n if (this.receiveSlot) {\n const scope = {\n file: 'multistream/remoteMedia',\n function: 'setupEventListeners',\n };\n\n this.receiveSlot.on(ReceiveSlotEvents.SourceUpdate, (data) => {\n this.emit(scope, RemoteMediaEvents.SourceUpdate, data);\n });\n }\n }\n\n /**\n * Getter for mediaType\n */\n public get mediaType() {\n return this.receiveSlot?.mediaType;\n }\n\n /**\n * Getter for memberId\n */\n public get memberId() {\n return this.receiveSlot?.memberId;\n }\n\n /**\n * Getter for csi\n */\n public get csi() {\n return this.receiveSlot?.csi;\n }\n\n /**\n * Getter for source state\n */\n public get sourceState() {\n return this.receiveSlot?.sourceState;\n }\n\n /**\n * Getter for remote media stream\n */\n public get stream() {\n return this.receiveSlot?.stream;\n }\n\n /**\n * @internal\n * @returns {ReceiveSlot}\n */\n public getUnderlyingReceiveSlot() {\n return this.receiveSlot;\n }\n}\n"],"mappings":"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"}
|
|
@@ -1,37 +1,25 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
4
|
-
|
|
5
4
|
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
|
|
6
|
-
|
|
7
5
|
_Object$defineProperty(exports, "__esModule", {
|
|
8
6
|
value: true
|
|
9
7
|
});
|
|
10
|
-
|
|
11
8
|
exports.RemoteMediaGroup = void 0;
|
|
12
|
-
|
|
13
9
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/toConsumableArray"));
|
|
14
|
-
|
|
15
10
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
|
|
16
|
-
|
|
17
11
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
|
|
18
|
-
|
|
19
12
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
|
|
20
|
-
|
|
21
13
|
var _loggerProxy = _interopRequireDefault(require("../common/logs/logger-proxy"));
|
|
22
|
-
|
|
23
14
|
var _remoteMedia = require("./remoteMedia");
|
|
24
|
-
|
|
25
15
|
/* eslint-disable valid-jsdoc */
|
|
26
|
-
|
|
27
16
|
/* eslint-disable require-jsdoc */
|
|
28
|
-
|
|
29
17
|
/* eslint-disable import/prefer-default-export */
|
|
30
18
|
var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
31
19
|
// id of the "active-speaker" media request id
|
|
20
|
+
|
|
32
21
|
function RemoteMediaGroup(mediaRequestManager, receiveSlots, priority, commitMediaRequest) {
|
|
33
22
|
var _this = this;
|
|
34
|
-
|
|
35
23
|
var options = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {};
|
|
36
24
|
(0, _classCallCheck2.default)(this, RemoteMediaGroup);
|
|
37
25
|
(0, _defineProperty2.default)(this, "mediaRequestManager", void 0);
|
|
@@ -51,91 +39,77 @@ var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
|
51
39
|
this.pinnedRemoteMedia = [];
|
|
52
40
|
this.sendActiveSpeakerMediaRequest(commitMediaRequest);
|
|
53
41
|
}
|
|
42
|
+
|
|
54
43
|
/**
|
|
55
44
|
* Gets the array of remote media elements from the group
|
|
56
45
|
*
|
|
57
46
|
* @param {string} filter - 'all' (default) returns both pinned and unpinned
|
|
58
47
|
* @returns {Array<RemoteMedia>}
|
|
59
48
|
*/
|
|
60
|
-
|
|
61
|
-
|
|
62
49
|
(0, _createClass2.default)(RemoteMediaGroup, [{
|
|
63
50
|
key: "getRemoteMedia",
|
|
64
51
|
value: function getRemoteMedia() {
|
|
65
52
|
var filter = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'all';
|
|
66
|
-
|
|
67
53
|
if (filter === 'unpinned') {
|
|
68
54
|
// return a shallow copy so that the client cannot modify this.unpinnedRemoteMedia array
|
|
69
55
|
return (0, _toConsumableArray2.default)(this.unpinnedRemoteMedia);
|
|
70
56
|
}
|
|
71
|
-
|
|
72
57
|
if (filter === 'pinned') {
|
|
73
58
|
// return a shallow copy so that the client cannot modify this.pinnedRemoteMedia array
|
|
74
59
|
return (0, _toConsumableArray2.default)(this.pinnedRemoteMedia);
|
|
75
60
|
}
|
|
76
|
-
|
|
77
61
|
return [].concat((0, _toConsumableArray2.default)(this.unpinnedRemoteMedia), (0, _toConsumableArray2.default)(this.pinnedRemoteMedia));
|
|
78
62
|
}
|
|
63
|
+
|
|
79
64
|
/**
|
|
80
65
|
* Pins a specific remote media instance to a specfic CSI, so the media will
|
|
81
66
|
* no longer come from active speaker, but from that CSI.
|
|
82
67
|
* If no CSI is given, the current CSI value is used.
|
|
83
68
|
*
|
|
84
69
|
*/
|
|
85
|
-
|
|
86
70
|
}, {
|
|
87
71
|
key: "pin",
|
|
88
72
|
value: function pin(remoteMedia, csi) {
|
|
89
73
|
// if csi is not specified, use the current one
|
|
90
74
|
var targetCsi = csi || remoteMedia.csi;
|
|
91
|
-
|
|
92
75
|
if (!targetCsi) {
|
|
93
76
|
throw new Error("failed to pin a remote media object ".concat(remoteMedia.id, ", because it has no CSI set and no CSI value was given"));
|
|
94
77
|
}
|
|
95
|
-
|
|
96
78
|
if (this.pinnedRemoteMedia.indexOf(remoteMedia) >= 0) {
|
|
97
79
|
if (targetCsi === remoteMedia.csi) {
|
|
98
80
|
// remote media already pinned to target CSI, nothing to do
|
|
99
81
|
_loggerProxy.default.logger.log("RemoteMediaGroup#pin --> remote media ".concat(remoteMedia.id, " already pinned"));
|
|
100
|
-
|
|
101
82
|
return;
|
|
102
83
|
}
|
|
103
84
|
} else {
|
|
104
85
|
var idx = this.unpinnedRemoteMedia.indexOf(remoteMedia);
|
|
105
|
-
|
|
106
86
|
if (idx < 0) {
|
|
107
87
|
throw new Error("failed to pin a remote media object ".concat(remoteMedia.id, ", because it is not found in this remote media group"));
|
|
108
88
|
}
|
|
109
|
-
|
|
110
89
|
this.unpinnedRemoteMedia.splice(idx, 1);
|
|
111
90
|
this.pinnedRemoteMedia.push(remoteMedia);
|
|
112
91
|
this.cancelActiveSpeakerMediaRequest(false);
|
|
113
92
|
this.sendActiveSpeakerMediaRequest(false);
|
|
114
93
|
}
|
|
115
|
-
|
|
116
94
|
remoteMedia.sendMediaRequest(targetCsi, false);
|
|
117
95
|
this.mediaRequestManager.commit();
|
|
118
96
|
}
|
|
97
|
+
|
|
119
98
|
/**
|
|
120
99
|
* Unpins a remote media instance, so that it will again provide media from active speakers
|
|
121
100
|
*
|
|
122
101
|
*/
|
|
123
|
-
|
|
124
102
|
}, {
|
|
125
103
|
key: "unpin",
|
|
126
104
|
value: function unpin(remoteMedia) {
|
|
127
105
|
if (this.unpinnedRemoteMedia.indexOf(remoteMedia) >= 0) {
|
|
128
106
|
_loggerProxy.default.logger.log("RemoteMediaGroup#pin --> remote media ".concat(remoteMedia.id, " already unpinned"));
|
|
129
|
-
|
|
130
107
|
return;
|
|
131
108
|
}
|
|
132
|
-
|
|
133
109
|
var idx = this.pinnedRemoteMedia.indexOf(remoteMedia);
|
|
134
|
-
|
|
135
110
|
if (idx < 0) {
|
|
136
111
|
throw new Error("failed to unpin a remote media object ".concat(remoteMedia.id, ", because it is not found in this remote media group"));
|
|
137
112
|
}
|
|
138
|
-
|
|
139
113
|
this.pinnedRemoteMedia.splice(idx, 1);
|
|
140
114
|
this.unpinnedRemoteMedia.push(remoteMedia);
|
|
141
115
|
remoteMedia.cancelMediaRequest(false);
|
|
@@ -149,18 +123,15 @@ var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
|
149
123
|
if (this.unpinnedRemoteMedia.indexOf(remoteMedia) >= 0) {
|
|
150
124
|
return false;
|
|
151
125
|
}
|
|
152
|
-
|
|
153
126
|
if (this.pinnedRemoteMedia.indexOf(remoteMedia) >= 0) {
|
|
154
127
|
return true;
|
|
155
128
|
}
|
|
156
|
-
|
|
157
129
|
throw new Error("remote media object ".concat(remoteMedia.id, " not found in the group"));
|
|
158
130
|
}
|
|
159
131
|
}, {
|
|
160
132
|
key: "sendActiveSpeakerMediaRequest",
|
|
161
133
|
value: function sendActiveSpeakerMediaRequest(commit) {
|
|
162
134
|
var _this$options;
|
|
163
|
-
|
|
164
135
|
this.cancelActiveSpeakerMediaRequest(false);
|
|
165
136
|
this.mediaRequestId = this.mediaRequestManager.addRequest({
|
|
166
137
|
policyInfo: {
|
|
@@ -187,6 +158,7 @@ var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
|
187
158
|
this.mediaRequestId = undefined;
|
|
188
159
|
}
|
|
189
160
|
}
|
|
161
|
+
|
|
190
162
|
/**
|
|
191
163
|
* Invalidates the remote media group by clearing the references to the receive slots
|
|
192
164
|
* used by all remote media from that group and cancelling all media requests.
|
|
@@ -195,7 +167,6 @@ var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
|
195
167
|
* @param{boolean} commit whether to commit the cancellation of media requests
|
|
196
168
|
* @internal
|
|
197
169
|
*/
|
|
198
|
-
|
|
199
170
|
}, {
|
|
200
171
|
key: "stop",
|
|
201
172
|
value: function stop() {
|
|
@@ -207,11 +178,11 @@ var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
|
207
178
|
return remoteMedia.stop(false);
|
|
208
179
|
});
|
|
209
180
|
this.cancelActiveSpeakerMediaRequest(false);
|
|
210
|
-
|
|
211
181
|
if (commit) {
|
|
212
182
|
this.mediaRequestManager.commit();
|
|
213
183
|
}
|
|
214
184
|
}
|
|
185
|
+
|
|
215
186
|
/**
|
|
216
187
|
* Checks if a given RemoteMedia instance belongs to this group.
|
|
217
188
|
*
|
|
@@ -219,25 +190,20 @@ var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
|
219
190
|
* @param filter controls which remote media from the group to check
|
|
220
191
|
* @returns true if remote media is found
|
|
221
192
|
*/
|
|
222
|
-
|
|
223
193
|
}, {
|
|
224
194
|
key: "includes",
|
|
225
195
|
value: function includes(remoteMedia) {
|
|
226
196
|
var filter = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'all';
|
|
227
|
-
|
|
228
197
|
if (filter === 'pinned') {
|
|
229
198
|
return this.pinnedRemoteMedia.includes(remoteMedia);
|
|
230
199
|
}
|
|
231
|
-
|
|
232
200
|
if (filter === 'unpinned') {
|
|
233
201
|
return this.unpinnedRemoteMedia.includes(remoteMedia);
|
|
234
202
|
}
|
|
235
|
-
|
|
236
203
|
return this.unpinnedRemoteMedia.includes(remoteMedia) || this.pinnedRemoteMedia.includes(remoteMedia);
|
|
237
204
|
}
|
|
238
205
|
}]);
|
|
239
206
|
return RemoteMediaGroup;
|
|
240
207
|
}();
|
|
241
|
-
|
|
242
208
|
exports.RemoteMediaGroup = RemoteMediaGroup;
|
|
243
209
|
//# sourceMappingURL=remoteMediaGroup.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["RemoteMediaGroup","mediaRequestManager","receiveSlots","priority","commitMediaRequest","options","unpinnedRemoteMedia","map","slot","RemoteMedia","resolution","pinnedRemoteMedia","sendActiveSpeakerMediaRequest","filter","remoteMedia","csi","targetCsi","Error","id","indexOf","LoggerProxy","logger","log","idx","splice","push","cancelActiveSpeakerMediaRequest","sendMediaRequest","commit","cancelMediaRequest","mediaRequestId","addRequest","policyInfo","policy","crossPriorityDuplication","crossPolicyDuplication","preferLiveVideo","getUnderlyingReceiveSlot","codecInfo","codec","maxFs","getMaxFs","cancelRequest","undefined","forEach","stop","includes"],"sources":["remoteMediaGroup.ts"],"sourcesContent":["/* eslint-disable valid-jsdoc */\n/* eslint-disable require-jsdoc */\n/* eslint-disable import/prefer-default-export */\nimport LoggerProxy from '../common/logs/logger-proxy';\n\nimport {getMaxFs, RemoteMedia, RemoteVideoResolution} from './remoteMedia';\nimport {MediaRequestId, MediaRequestManager} from './mediaRequestManager';\nimport {CSI, ReceiveSlot} from './receiveSlot';\n\ntype Options = {\n resolution?: RemoteVideoResolution; // applies only to groups of type MC.MediaType.VideoMain and MC.MediaType.VideoSlides\n preferLiveVideo?: boolean; // applies only to groups of type MC.MediaType.VideoMain and MC.MediaType.VideoSlides\n};\n\nexport class RemoteMediaGroup {\n private mediaRequestManager: MediaRequestManager;\n\n private priority: number;\n\n private options: Options;\n\n private unpinnedRemoteMedia: RemoteMedia[];\n\n private mediaRequestId?: MediaRequestId; // id of the \"active-speaker\" media request id\n\n private pinnedRemoteMedia: RemoteMedia[];\n\n constructor(\n mediaRequestManager: MediaRequestManager,\n receiveSlots: ReceiveSlot[],\n priority: number,\n commitMediaRequest: boolean,\n options: Options = {}\n ) {\n this.mediaRequestManager = mediaRequestManager;\n this.priority = priority;\n this.options = options;\n\n this.unpinnedRemoteMedia = receiveSlots.map(\n (slot) =>\n new RemoteMedia(slot, this.mediaRequestManager, {\n resolution: this.options.resolution,\n })\n );\n this.pinnedRemoteMedia = [];\n\n this.sendActiveSpeakerMediaRequest(commitMediaRequest);\n }\n\n /**\n * Gets the array of remote media elements from the group\n *\n * @param {string} filter - 'all' (default) returns both pinned and unpinned\n * @returns {Array<RemoteMedia>}\n */\n public getRemoteMedia(filter: 'all' | 'pinned' | 'unpinned' = 'all') {\n if (filter === 'unpinned') {\n // return a shallow copy so that the client cannot modify this.unpinnedRemoteMedia array\n return [...this.unpinnedRemoteMedia];\n }\n if (filter === 'pinned') {\n // return a shallow copy so that the client cannot modify this.pinnedRemoteMedia array\n return [...this.pinnedRemoteMedia];\n }\n return [...this.unpinnedRemoteMedia, ...this.pinnedRemoteMedia];\n }\n\n /**\n * Pins a specific remote media instance to a specfic CSI, so the media will\n * no longer come from active speaker, but from that CSI.\n * If no CSI is given, the current CSI value is used.\n *\n */\n public pin(remoteMedia: RemoteMedia, csi?: CSI): void {\n // if csi is not specified, use the current one\n const targetCsi = csi || remoteMedia.csi;\n\n if (!targetCsi) {\n throw new Error(\n `failed to pin a remote media object ${remoteMedia.id}, because it has no CSI set and no CSI value was given`\n );\n }\n\n if (this.pinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n if (targetCsi === remoteMedia.csi) {\n // remote media already pinned to target CSI, nothing to do\n LoggerProxy.logger.log(\n `RemoteMediaGroup#pin --> remote media ${remoteMedia.id} already pinned`\n );\n\n return;\n }\n } else {\n const idx = this.unpinnedRemoteMedia.indexOf(remoteMedia);\n\n if (idx < 0) {\n throw new Error(\n `failed to pin a remote media object ${remoteMedia.id}, because it is not found in this remote media group`\n );\n }\n\n this.unpinnedRemoteMedia.splice(idx, 1);\n this.pinnedRemoteMedia.push(remoteMedia);\n\n this.cancelActiveSpeakerMediaRequest(false);\n this.sendActiveSpeakerMediaRequest(false);\n }\n\n remoteMedia.sendMediaRequest(targetCsi, false);\n this.mediaRequestManager.commit();\n }\n\n /**\n * Unpins a remote media instance, so that it will again provide media from active speakers\n *\n */\n public unpin(remoteMedia: RemoteMedia) {\n if (this.unpinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n LoggerProxy.logger.log(\n `RemoteMediaGroup#pin --> remote media ${remoteMedia.id} already unpinned`\n );\n\n return;\n }\n const idx = this.pinnedRemoteMedia.indexOf(remoteMedia);\n\n if (idx < 0) {\n throw new Error(\n `failed to unpin a remote media object ${remoteMedia.id}, because it is not found in this remote media group`\n );\n }\n\n this.pinnedRemoteMedia.splice(idx, 1);\n this.unpinnedRemoteMedia.push(remoteMedia);\n\n remoteMedia.cancelMediaRequest(false);\n this.cancelActiveSpeakerMediaRequest(false);\n this.sendActiveSpeakerMediaRequest(false);\n this.mediaRequestManager.commit();\n }\n\n public isPinned(remoteMedia: RemoteMedia) {\n if (this.unpinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n return false;\n }\n if (this.pinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n return true;\n }\n\n throw new Error(`remote media object ${remoteMedia.id} not found in the group`);\n }\n\n private sendActiveSpeakerMediaRequest(commit: boolean) {\n this.cancelActiveSpeakerMediaRequest(false);\n\n this.mediaRequestId = this.mediaRequestManager.addRequest(\n {\n policyInfo: {\n policy: 'active-speaker',\n priority: this.priority,\n crossPriorityDuplication: false,\n crossPolicyDuplication: false,\n preferLiveVideo: !!this.options?.preferLiveVideo,\n },\n receiveSlots: this.unpinnedRemoteMedia.map((remoteMedia) =>\n remoteMedia.getUnderlyingReceiveSlot()\n ) as ReceiveSlot[],\n codecInfo: this.options.resolution && {\n codec: 'h264',\n maxFs: getMaxFs(this.options.resolution),\n },\n },\n commit\n );\n }\n\n private cancelActiveSpeakerMediaRequest(commit: boolean) {\n if (this.mediaRequestId) {\n this.mediaRequestManager.cancelRequest(this.mediaRequestId, commit);\n this.mediaRequestId = undefined;\n }\n }\n\n /**\n * Invalidates the remote media group by clearing the references to the receive slots\n * used by all remote media from that group and cancelling all media requests.\n * After this call the remote media group is unusable.\n *\n * @param{boolean} commit whether to commit the cancellation of media requests\n * @internal\n */\n public stop(commit: boolean = true) {\n this.unpinnedRemoteMedia.forEach((remoteMedia) => remoteMedia.stop(false));\n this.pinnedRemoteMedia.forEach((remoteMedia) => remoteMedia.stop(false));\n this.cancelActiveSpeakerMediaRequest(false);\n\n if (commit) {\n this.mediaRequestManager.commit();\n }\n }\n\n /**\n * Checks if a given RemoteMedia instance belongs to this group.\n *\n * @param remoteMedia RemoteMedia instance to check\n * @param filter controls which remote media from the group to check\n * @returns true if remote media is found\n */\n public includes(\n remoteMedia: RemoteMedia,\n filter: 'all' | 'pinned' | 'unpinned' = 'all'\n ): boolean {\n if (filter === 'pinned') {\n return this.pinnedRemoteMedia.includes(remoteMedia);\n }\n if (filter === 'unpinned') {\n return this.unpinnedRemoteMedia.includes(remoteMedia);\n }\n\n return (\n this.unpinnedRemoteMedia.includes(remoteMedia) || this.pinnedRemoteMedia.includes(remoteMedia)\n );\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["RemoteMediaGroup","mediaRequestManager","receiveSlots","priority","commitMediaRequest","options","unpinnedRemoteMedia","map","slot","RemoteMedia","resolution","pinnedRemoteMedia","sendActiveSpeakerMediaRequest","filter","remoteMedia","csi","targetCsi","Error","id","indexOf","LoggerProxy","logger","log","idx","splice","push","cancelActiveSpeakerMediaRequest","sendMediaRequest","commit","cancelMediaRequest","mediaRequestId","addRequest","policyInfo","policy","crossPriorityDuplication","crossPolicyDuplication","preferLiveVideo","getUnderlyingReceiveSlot","codecInfo","codec","maxFs","getMaxFs","cancelRequest","undefined","forEach","stop","includes"],"sources":["remoteMediaGroup.ts"],"sourcesContent":["/* eslint-disable valid-jsdoc */\n/* eslint-disable require-jsdoc */\n/* eslint-disable import/prefer-default-export */\nimport LoggerProxy from '../common/logs/logger-proxy';\n\nimport {getMaxFs, RemoteMedia, RemoteVideoResolution} from './remoteMedia';\nimport {MediaRequestId, MediaRequestManager} from './mediaRequestManager';\nimport {CSI, ReceiveSlot} from './receiveSlot';\n\ntype Options = {\n resolution?: RemoteVideoResolution; // applies only to groups of type MC.MediaType.VideoMain and MC.MediaType.VideoSlides\n preferLiveVideo?: boolean; // applies only to groups of type MC.MediaType.VideoMain and MC.MediaType.VideoSlides\n};\n\nexport class RemoteMediaGroup {\n private mediaRequestManager: MediaRequestManager;\n\n private priority: number;\n\n private options: Options;\n\n private unpinnedRemoteMedia: RemoteMedia[];\n\n private mediaRequestId?: MediaRequestId; // id of the \"active-speaker\" media request id\n\n private pinnedRemoteMedia: RemoteMedia[];\n\n constructor(\n mediaRequestManager: MediaRequestManager,\n receiveSlots: ReceiveSlot[],\n priority: number,\n commitMediaRequest: boolean,\n options: Options = {}\n ) {\n this.mediaRequestManager = mediaRequestManager;\n this.priority = priority;\n this.options = options;\n\n this.unpinnedRemoteMedia = receiveSlots.map(\n (slot) =>\n new RemoteMedia(slot, this.mediaRequestManager, {\n resolution: this.options.resolution,\n })\n );\n this.pinnedRemoteMedia = [];\n\n this.sendActiveSpeakerMediaRequest(commitMediaRequest);\n }\n\n /**\n * Gets the array of remote media elements from the group\n *\n * @param {string} filter - 'all' (default) returns both pinned and unpinned\n * @returns {Array<RemoteMedia>}\n */\n public getRemoteMedia(filter: 'all' | 'pinned' | 'unpinned' = 'all') {\n if (filter === 'unpinned') {\n // return a shallow copy so that the client cannot modify this.unpinnedRemoteMedia array\n return [...this.unpinnedRemoteMedia];\n }\n if (filter === 'pinned') {\n // return a shallow copy so that the client cannot modify this.pinnedRemoteMedia array\n return [...this.pinnedRemoteMedia];\n }\n\n return [...this.unpinnedRemoteMedia, ...this.pinnedRemoteMedia];\n }\n\n /**\n * Pins a specific remote media instance to a specfic CSI, so the media will\n * no longer come from active speaker, but from that CSI.\n * If no CSI is given, the current CSI value is used.\n *\n */\n public pin(remoteMedia: RemoteMedia, csi?: CSI): void {\n // if csi is not specified, use the current one\n const targetCsi = csi || remoteMedia.csi;\n\n if (!targetCsi) {\n throw new Error(\n `failed to pin a remote media object ${remoteMedia.id}, because it has no CSI set and no CSI value was given`\n );\n }\n\n if (this.pinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n if (targetCsi === remoteMedia.csi) {\n // remote media already pinned to target CSI, nothing to do\n LoggerProxy.logger.log(\n `RemoteMediaGroup#pin --> remote media ${remoteMedia.id} already pinned`\n );\n\n return;\n }\n } else {\n const idx = this.unpinnedRemoteMedia.indexOf(remoteMedia);\n\n if (idx < 0) {\n throw new Error(\n `failed to pin a remote media object ${remoteMedia.id}, because it is not found in this remote media group`\n );\n }\n\n this.unpinnedRemoteMedia.splice(idx, 1);\n this.pinnedRemoteMedia.push(remoteMedia);\n\n this.cancelActiveSpeakerMediaRequest(false);\n this.sendActiveSpeakerMediaRequest(false);\n }\n\n remoteMedia.sendMediaRequest(targetCsi, false);\n this.mediaRequestManager.commit();\n }\n\n /**\n * Unpins a remote media instance, so that it will again provide media from active speakers\n *\n */\n public unpin(remoteMedia: RemoteMedia) {\n if (this.unpinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n LoggerProxy.logger.log(\n `RemoteMediaGroup#pin --> remote media ${remoteMedia.id} already unpinned`\n );\n\n return;\n }\n const idx = this.pinnedRemoteMedia.indexOf(remoteMedia);\n\n if (idx < 0) {\n throw new Error(\n `failed to unpin a remote media object ${remoteMedia.id}, because it is not found in this remote media group`\n );\n }\n\n this.pinnedRemoteMedia.splice(idx, 1);\n this.unpinnedRemoteMedia.push(remoteMedia);\n\n remoteMedia.cancelMediaRequest(false);\n this.cancelActiveSpeakerMediaRequest(false);\n this.sendActiveSpeakerMediaRequest(false);\n this.mediaRequestManager.commit();\n }\n\n public isPinned(remoteMedia: RemoteMedia) {\n if (this.unpinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n return false;\n }\n if (this.pinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n return true;\n }\n\n throw new Error(`remote media object ${remoteMedia.id} not found in the group`);\n }\n\n private sendActiveSpeakerMediaRequest(commit: boolean) {\n this.cancelActiveSpeakerMediaRequest(false);\n\n this.mediaRequestId = this.mediaRequestManager.addRequest(\n {\n policyInfo: {\n policy: 'active-speaker',\n priority: this.priority,\n crossPriorityDuplication: false,\n crossPolicyDuplication: false,\n preferLiveVideo: !!this.options?.preferLiveVideo,\n },\n receiveSlots: this.unpinnedRemoteMedia.map((remoteMedia) =>\n remoteMedia.getUnderlyingReceiveSlot()\n ) as ReceiveSlot[],\n codecInfo: this.options.resolution && {\n codec: 'h264',\n maxFs: getMaxFs(this.options.resolution),\n },\n },\n commit\n );\n }\n\n private cancelActiveSpeakerMediaRequest(commit: boolean) {\n if (this.mediaRequestId) {\n this.mediaRequestManager.cancelRequest(this.mediaRequestId, commit);\n this.mediaRequestId = undefined;\n }\n }\n\n /**\n * Invalidates the remote media group by clearing the references to the receive slots\n * used by all remote media from that group and cancelling all media requests.\n * After this call the remote media group is unusable.\n *\n * @param{boolean} commit whether to commit the cancellation of media requests\n * @internal\n */\n public stop(commit = true) {\n this.unpinnedRemoteMedia.forEach((remoteMedia) => remoteMedia.stop(false));\n this.pinnedRemoteMedia.forEach((remoteMedia) => remoteMedia.stop(false));\n this.cancelActiveSpeakerMediaRequest(false);\n\n if (commit) {\n this.mediaRequestManager.commit();\n }\n }\n\n /**\n * Checks if a given RemoteMedia instance belongs to this group.\n *\n * @param remoteMedia RemoteMedia instance to check\n * @param filter controls which remote media from the group to check\n * @returns true if remote media is found\n */\n public includes(\n remoteMedia: RemoteMedia,\n filter: 'all' | 'pinned' | 'unpinned' = 'all'\n ): boolean {\n if (filter === 'pinned') {\n return this.pinnedRemoteMedia.includes(remoteMedia);\n }\n if (filter === 'unpinned') {\n return this.unpinnedRemoteMedia.includes(remoteMedia);\n }\n\n return (\n this.unpinnedRemoteMedia.includes(remoteMedia) || this.pinnedRemoteMedia.includes(remoteMedia)\n );\n }\n}\n"],"mappings":"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"}
|