@webex/plugin-meetings 3.12.0-next.6 → 3.12.0-next.61
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/AGENTS.md +9 -0
- package/dist/aiEnableRequest/index.js +15 -2
- package/dist/aiEnableRequest/index.js.map +1 -1
- package/dist/breakouts/breakout.js +8 -3
- package/dist/breakouts/breakout.js.map +1 -1
- package/dist/breakouts/index.js +26 -2
- package/dist/breakouts/index.js.map +1 -1
- package/dist/config.js +2 -0
- package/dist/config.js.map +1 -1
- package/dist/constants.js +6 -3
- package/dist/constants.js.map +1 -1
- package/dist/controls-options-manager/constants.js +11 -1
- package/dist/controls-options-manager/constants.js.map +1 -1
- package/dist/controls-options-manager/index.js +38 -24
- package/dist/controls-options-manager/index.js.map +1 -1
- package/dist/controls-options-manager/util.js +91 -0
- package/dist/controls-options-manager/util.js.map +1 -1
- package/dist/hashTree/constants.js +10 -1
- package/dist/hashTree/constants.js.map +1 -1
- package/dist/hashTree/hashTreeParser.js +716 -370
- package/dist/hashTree/hashTreeParser.js.map +1 -1
- package/dist/hashTree/utils.js +22 -0
- package/dist/hashTree/utils.js.map +1 -1
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -1
- package/dist/interceptors/locusRetry.js +23 -8
- package/dist/interceptors/locusRetry.js.map +1 -1
- package/dist/interpretation/index.js +10 -1
- package/dist/interpretation/index.js.map +1 -1
- package/dist/interpretation/siLanguage.js +1 -1
- package/dist/locus-info/controlsUtils.js +4 -1
- package/dist/locus-info/controlsUtils.js.map +1 -1
- package/dist/locus-info/index.js +289 -87
- package/dist/locus-info/index.js.map +1 -1
- package/dist/locus-info/types.js +19 -0
- package/dist/locus-info/types.js.map +1 -1
- package/dist/media/index.js +3 -1
- package/dist/media/index.js.map +1 -1
- package/dist/media/properties.js +1 -0
- package/dist/media/properties.js.map +1 -1
- package/dist/meeting/in-meeting-actions.js +3 -1
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +907 -535
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/util.js +19 -2
- package/dist/meeting/util.js.map +1 -1
- package/dist/meetings/index.js +231 -78
- package/dist/meetings/index.js.map +1 -1
- package/dist/meetings/meetings.types.js +6 -1
- package/dist/meetings/meetings.types.js.map +1 -1
- package/dist/meetings/request.js +39 -0
- package/dist/meetings/request.js.map +1 -1
- package/dist/meetings/util.js +79 -5
- package/dist/meetings/util.js.map +1 -1
- package/dist/member/index.js +10 -0
- package/dist/member/index.js.map +1 -1
- package/dist/member/types.js.map +1 -1
- package/dist/member/util.js +3 -0
- package/dist/member/util.js.map +1 -1
- package/dist/metrics/constants.js +4 -1
- package/dist/metrics/constants.js.map +1 -1
- package/dist/multistream/codec/constants.js +63 -0
- package/dist/multistream/codec/constants.js.map +1 -0
- package/dist/multistream/mediaRequestManager.js +62 -15
- package/dist/multistream/mediaRequestManager.js.map +1 -1
- package/dist/multistream/receiveSlot.js +9 -0
- package/dist/multistream/receiveSlot.js.map +1 -1
- package/dist/reactions/reactions.type.js.map +1 -1
- package/dist/recording-controller/index.js +1 -3
- package/dist/recording-controller/index.js.map +1 -1
- package/dist/types/config.d.ts +2 -0
- package/dist/types/constants.d.ts +2 -0
- package/dist/types/controls-options-manager/constants.d.ts +6 -1
- package/dist/types/controls-options-manager/index.d.ts +10 -0
- package/dist/types/hashTree/constants.d.ts +1 -0
- package/dist/types/hashTree/hashTreeParser.d.ts +92 -16
- package/dist/types/hashTree/utils.d.ts +11 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/interceptors/locusRetry.d.ts +4 -4
- package/dist/types/locus-info/index.d.ts +46 -6
- package/dist/types/locus-info/types.d.ts +21 -1
- package/dist/types/media/properties.d.ts +1 -0
- package/dist/types/meeting/in-meeting-actions.d.ts +2 -0
- package/dist/types/meeting/index.d.ts +87 -3
- package/dist/types/meeting/util.d.ts +8 -0
- package/dist/types/meetings/index.d.ts +30 -2
- package/dist/types/meetings/meetings.types.d.ts +15 -0
- package/dist/types/meetings/request.d.ts +14 -0
- package/dist/types/member/index.d.ts +1 -0
- package/dist/types/member/types.d.ts +1 -0
- package/dist/types/member/util.d.ts +1 -0
- package/dist/types/metrics/constants.d.ts +3 -0
- package/dist/types/multistream/codec/constants.d.ts +7 -0
- package/dist/types/multistream/mediaRequestManager.d.ts +22 -5
- package/dist/types/reactions/reactions.type.d.ts +3 -0
- package/dist/webinar/index.js +361 -235
- package/dist/webinar/index.js.map +1 -1
- package/package.json +22 -22
- package/src/aiEnableRequest/index.ts +16 -0
- package/src/breakouts/breakout.ts +3 -1
- package/src/breakouts/index.ts +31 -0
- package/src/config.ts +2 -0
- package/src/constants.ts +5 -1
- package/src/controls-options-manager/constants.ts +14 -1
- package/src/controls-options-manager/index.ts +47 -24
- package/src/controls-options-manager/util.ts +81 -1
- package/src/hashTree/constants.ts +9 -0
- package/src/hashTree/hashTreeParser.ts +429 -183
- package/src/hashTree/utils.ts +17 -0
- package/src/index.ts +5 -0
- package/src/interceptors/locusRetry.ts +25 -4
- package/src/interpretation/index.ts +25 -8
- package/src/locus-info/controlsUtils.ts +3 -1
- package/src/locus-info/index.ts +291 -97
- package/src/locus-info/types.ts +25 -1
- package/src/media/index.ts +3 -0
- package/src/media/properties.ts +1 -0
- package/src/meeting/in-meeting-actions.ts +4 -0
- package/src/meeting/index.ts +388 -33
- package/src/meeting/util.ts +20 -2
- package/src/meetings/index.ts +134 -44
- package/src/meetings/meetings.types.ts +19 -0
- package/src/meetings/request.ts +43 -0
- package/src/meetings/util.ts +97 -1
- package/src/member/index.ts +10 -0
- package/src/member/types.ts +1 -0
- package/src/member/util.ts +3 -0
- package/src/metrics/constants.ts +3 -0
- package/src/multistream/codec/constants.ts +58 -0
- package/src/multistream/mediaRequestManager.ts +119 -28
- package/src/multistream/receiveSlot.ts +18 -0
- package/src/reactions/reactions.type.ts +3 -0
- package/src/recording-controller/index.ts +1 -2
- package/src/webinar/index.ts +162 -21
- package/test/unit/spec/aiEnableRequest/index.ts +86 -0
- package/test/unit/spec/breakouts/breakout.ts +9 -3
- package/test/unit/spec/breakouts/index.ts +49 -0
- package/test/unit/spec/controls-options-manager/index.js +140 -29
- package/test/unit/spec/controls-options-manager/util.js +165 -0
- package/test/unit/spec/hashTree/hashTreeParser.ts +1508 -149
- package/test/unit/spec/hashTree/utils.ts +88 -1
- package/test/unit/spec/interceptors/locusRetry.ts +205 -4
- package/test/unit/spec/interpretation/index.ts +26 -4
- package/test/unit/spec/locus-info/controlsUtils.js +172 -57
- package/test/unit/spec/locus-info/index.js +475 -81
- package/test/unit/spec/media/index.ts +31 -0
- package/test/unit/spec/meeting/in-meeting-actions.ts +2 -0
- package/test/unit/spec/meeting/index.js +1131 -49
- package/test/unit/spec/meeting/muteState.js +3 -0
- package/test/unit/spec/meeting/utils.js +33 -0
- package/test/unit/spec/meetings/index.js +360 -10
- package/test/unit/spec/meetings/request.js +141 -0
- package/test/unit/spec/meetings/utils.js +189 -0
- package/test/unit/spec/member/index.js +7 -0
- package/test/unit/spec/member/util.js +24 -0
- package/test/unit/spec/multistream/mediaRequestManager.ts +501 -37
- package/test/unit/spec/recording-controller/index.js +9 -8
- package/test/unit/spec/webinar/index.ts +141 -16
package/dist/locus-info/index.js
CHANGED
|
@@ -32,9 +32,9 @@ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/he
|
|
|
32
32
|
var _values = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/values"));
|
|
33
33
|
var _assign = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/assign"));
|
|
34
34
|
var _map = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/map"));
|
|
35
|
+
var _isArray = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/array/is-array"));
|
|
35
36
|
var _keys = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/keys"));
|
|
36
37
|
var _stringify = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/json/stringify"));
|
|
37
|
-
var _isArray = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/array/is-array"));
|
|
38
38
|
var _lodash = require("lodash");
|
|
39
39
|
var _loggerProxy = _interopRequireDefault(require("../common/logs/logger-proxy"));
|
|
40
40
|
var _eventsScope = _interopRequireDefault(require("../common/events/events-scope"));
|
|
@@ -53,7 +53,7 @@ var _hashTreeParser2 = _interopRequireWildcard(require("../hashTree/hashTreePars
|
|
|
53
53
|
var _types = require("../hashTree/types");
|
|
54
54
|
var _utils = require("../hashTree/utils");
|
|
55
55
|
var _util = _interopRequireDefault(require("../meetings/util"));
|
|
56
|
-
function _interopRequireWildcard(e, t) { if ("function" == typeof _WeakMap) var r = new _WeakMap(), n = new _WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var
|
|
56
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof _WeakMap) var r = new _WeakMap(), n = new _WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t3 in e) "default" !== _t3 && {}.hasOwnProperty.call(e, _t3) && ((i = (o = _Object$defineProperty) && _Object$getOwnPropertyDescriptor(e, _t3)) && (i.get || i.set) ? o(f, _t3, i) : f[_t3] = e[_t3]); return f; })(e, t); }
|
|
57
57
|
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2.default)(o), (0, _possibleConstructorReturn2.default)(t, _isNativeReflectConstruct() ? _Reflect$construct(o, e || [], (0, _getPrototypeOf2.default)(t).constructor) : o.apply(t, e)); }
|
|
58
58
|
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
|
|
59
59
|
function ownKeys(e, r) { var t = _Object$keys2(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
@@ -76,7 +76,7 @@ var LocusObjectStateAfterUpdates = {
|
|
|
76
76
|
* Gets the replacement information
|
|
77
77
|
*
|
|
78
78
|
* @param {any} self - "self" object from Locus DTO
|
|
79
|
-
* @param {string} deviceUrl - The URL of the
|
|
79
|
+
* @param {string} deviceUrl - The URL of the specified device
|
|
80
80
|
* @returns {any} The replace information if available, otherwise undefined
|
|
81
81
|
*/
|
|
82
82
|
function getReplaceInfoFromSelf(self, deviceUrl) {
|
|
@@ -115,11 +115,13 @@ function findLocusUrlInAnyHashTreeParser(meetingCollection, locusUrl) {
|
|
|
115
115
|
*
|
|
116
116
|
* @param {HashTreeMessage} message - The hash tree message to find the meeting for
|
|
117
117
|
* @param {MeetingCollection} meetingCollection - The collection of meetings to search
|
|
118
|
-
* @param {string} deviceUrl - The URL of the user's device
|
|
119
118
|
* @returns {any} The meeting if found, otherwise undefined
|
|
120
119
|
*/
|
|
121
|
-
function findMeetingForHashTreeMessage(message, meetingCollection
|
|
120
|
+
function findMeetingForHashTreeMessage(message, meetingCollection) {
|
|
122
121
|
var _message$locusStateEl, _message$locusStateEl2;
|
|
122
|
+
if (!message) {
|
|
123
|
+
return undefined;
|
|
124
|
+
}
|
|
123
125
|
var foundMeeting = findLocusUrlInAnyHashTreeParser(meetingCollection, message.locusUrl);
|
|
124
126
|
if (foundMeeting) {
|
|
125
127
|
return foundMeeting;
|
|
@@ -130,7 +132,7 @@ function findMeetingForHashTreeMessage(message, meetingCollection, deviceUrl) {
|
|
|
130
132
|
var self = (_message$locusStateEl = message.locusStateElements) === null || _message$locusStateEl === void 0 ? void 0 : (_message$locusStateEl2 = _message$locusStateEl.find(function (el) {
|
|
131
133
|
return (0, _utils.isSelf)(el);
|
|
132
134
|
})) === null || _message$locusStateEl2 === void 0 ? void 0 : _message$locusStateEl2.data;
|
|
133
|
-
var replaces = getReplaceInfoFromSelf(self, deviceUrl);
|
|
135
|
+
var replaces = getReplaceInfoFromSelf(self, self === null || self === void 0 ? void 0 : self.deviceUrl);
|
|
134
136
|
if (replaces !== null && replaces !== void 0 && replaces.locusUrl) {
|
|
135
137
|
foundMeeting = findLocusUrlInAnyHashTreeParser(meetingCollection, replaces.locusUrl);
|
|
136
138
|
return foundMeeting;
|
|
@@ -511,7 +513,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
511
513
|
}, {
|
|
512
514
|
key: "createHashTreeParser",
|
|
513
515
|
value: function createHashTreeParser(_ref) {
|
|
514
|
-
var _this$webex$config$me;
|
|
516
|
+
var _locusUrl$split, _locusUrl$split$pop, _this$webex$config$me;
|
|
515
517
|
var locusUrl = _ref.locusUrl,
|
|
516
518
|
initialLocus = _ref.initialLocus,
|
|
517
519
|
metadata = _ref.metadata,
|
|
@@ -521,7 +523,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
521
523
|
metadata: metadata,
|
|
522
524
|
webexRequest: this.webex.request.bind(this.webex),
|
|
523
525
|
locusInfoUpdateCallback: this.updateFromHashTree.bind(this, locusUrl),
|
|
524
|
-
debugId: "HT-".concat(locusUrl.split('/').pop().substring(0, 4)),
|
|
526
|
+
debugId: "HT-".concat((_locusUrl$split = locusUrl.split('/')) === null || _locusUrl$split === void 0 ? void 0 : (_locusUrl$split$pop = _locusUrl$split.pop()) === null || _locusUrl$split$pop === void 0 ? void 0 : _locusUrl$split$pop.substring(0, 4)),
|
|
525
527
|
excludedDataSets: (_this$webex$config$me = this.webex.config.meetings.locus) === null || _this$webex$config$me === void 0 ? void 0 : _this$webex$config$me.excludedDataSets
|
|
526
528
|
});
|
|
527
529
|
|
|
@@ -558,18 +560,20 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
558
560
|
|
|
559
561
|
/**
|
|
560
562
|
* @param {Object} data - data to initialize locus info with. It may be from a join or GET /loci response or from a Mercury event that triggers a creation of meeting object
|
|
563
|
+
* @param {Function} [onLocusSynced] - optional callback that will be called at the end of initial setup, when locus info is fully synced. It will be called with the full locus snapshot as an argument (which may be null if we haven't received any full locus DTOs during the initial setup, for example in case we receive only hash tree messages without full locus DTOs)
|
|
561
564
|
* @returns {undefined}
|
|
562
565
|
* @memberof LocusInfo
|
|
563
566
|
*/
|
|
564
567
|
}, {
|
|
565
568
|
key: "initialSetup",
|
|
566
569
|
value: (function () {
|
|
567
|
-
var _initialSetup = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee(data) {
|
|
570
|
+
var _initialSetup = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee(data, onLocusSynced) {
|
|
568
571
|
var _data$locus, _data$locus$links, _data$locus$links$res, _data$locus$links$res2;
|
|
569
|
-
var _data$hashTreeMessage, _metadataObject$data, metadataObject, hashTreeParser, _hashTreeParser, _t;
|
|
572
|
+
var initialFullLocus, _data$hashTreeMessage, _metadataObject$data, metadataObject, hashTreeParser, _hashTreeParser, _t;
|
|
570
573
|
return _regenerator.default.wrap(function (_context) {
|
|
571
574
|
while (1) switch (_context.prev = _context.next) {
|
|
572
575
|
case 0:
|
|
576
|
+
initialFullLocus = null;
|
|
573
577
|
_t = data.trigger;
|
|
574
578
|
_context.next = _t === 'locus-message' ? 1 : _t === 'join-response' ? 6 : _t === 'get-loci-response' ? 7 : 10;
|
|
575
579
|
break;
|
|
@@ -621,6 +625,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
621
625
|
case 6:
|
|
622
626
|
this.updateLocusCache(data.locus);
|
|
623
627
|
this.onFullLocus('join response', data.locus, undefined, data.dataSets, data.metadata);
|
|
628
|
+
initialFullLocus = data.locus;
|
|
624
629
|
return _context.abrupt("continue", 10);
|
|
625
630
|
case 7:
|
|
626
631
|
if (!((_data$locus = data.locus) !== null && _data$locus !== void 0 && (_data$locus$links = _data$locus.links) !== null && _data$locus$links !== void 0 && (_data$locus$links$res = _data$locus$links.resources) !== null && _data$locus$links$res !== void 0 && (_data$locus$links$res2 = _data$locus$links$res.visibleDataSets) !== null && _data$locus$links$res2 !== void 0 && _data$locus$links$res2.url)) {
|
|
@@ -646,7 +651,16 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
646
651
|
// "classic" Locus case, no hash trees involved
|
|
647
652
|
this.updateLocusCache(data.locus);
|
|
648
653
|
this.onFullLocus('classic get-loci-response', data.locus, undefined);
|
|
654
|
+
initialFullLocus = data.locus || null;
|
|
649
655
|
case 10:
|
|
656
|
+
if (onLocusSynced) {
|
|
657
|
+
try {
|
|
658
|
+
onLocusSynced(initialFullLocus || this.getCurrentLocusSnapshot());
|
|
659
|
+
} catch (error) {
|
|
660
|
+
_loggerProxy.default.logger.warn("Locus-info:index#initialSetup --> onLocusSynced callback failed: ".concat(error));
|
|
661
|
+
}
|
|
662
|
+
}
|
|
663
|
+
|
|
650
664
|
// Change it to true after it receives it first locus object
|
|
651
665
|
this.emitChange = true;
|
|
652
666
|
case 11:
|
|
@@ -655,18 +669,40 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
655
669
|
}
|
|
656
670
|
}, _callee, this);
|
|
657
671
|
}));
|
|
658
|
-
function initialSetup(_x) {
|
|
672
|
+
function initialSetup(_x, _x2) {
|
|
659
673
|
return _initialSetup.apply(this, arguments);
|
|
660
674
|
}
|
|
661
675
|
return initialSetup;
|
|
662
676
|
}()
|
|
677
|
+
/**
|
|
678
|
+
* Builds a full locus DTO snapshot from current internal locus state.
|
|
679
|
+
*
|
|
680
|
+
* @returns {LocusDTO}
|
|
681
|
+
*/
|
|
682
|
+
)
|
|
683
|
+
}, {
|
|
684
|
+
key: "getCurrentLocusSnapshot",
|
|
685
|
+
value: function getCurrentLocusSnapshot() {
|
|
686
|
+
var _this4 = this;
|
|
687
|
+
var locus = {};
|
|
688
|
+
LocusDtoTopLevelKeys.forEach(function (key) {
|
|
689
|
+
var value = _this4[key];
|
|
690
|
+
if (value !== undefined && value !== null) {
|
|
691
|
+
locus[key] = (0, _lodash.cloneDeep)(value);
|
|
692
|
+
}
|
|
693
|
+
});
|
|
694
|
+
if (!(0, _isArray.default)(locus.participants)) {
|
|
695
|
+
locus.participants = [];
|
|
696
|
+
}
|
|
697
|
+
return locus;
|
|
698
|
+
}
|
|
699
|
+
|
|
663
700
|
/**
|
|
664
701
|
* Handles HTTP response from Locus API call.
|
|
665
702
|
* @param {Meeting} meeting meeting object
|
|
666
703
|
* @param {LocusApiResponseBody} responseBody body of the http response from Locus API call
|
|
667
704
|
* @returns {void}
|
|
668
705
|
*/
|
|
669
|
-
)
|
|
670
706
|
}, {
|
|
671
707
|
key: "handleLocusAPIResponse",
|
|
672
708
|
value: function handleLocusAPIResponse(meeting, responseBody) {
|
|
@@ -674,29 +710,38 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
674
710
|
var isWrapped = 'locus' in responseBody;
|
|
675
711
|
var locusUrl = isWrapped ? (_responseBody$locus = responseBody.locus) === null || _responseBody$locus === void 0 ? void 0 : _responseBody$locus.url : responseBody.url;
|
|
676
712
|
var hashTreeParserEntry = locusUrl && this.hashTreeParsers.get(locusUrl);
|
|
677
|
-
|
|
678
|
-
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
|
|
713
|
+
var locus = isWrapped ? responseBody.locus : responseBody;
|
|
714
|
+
if (this.hashTreeParsers.size > 0) {
|
|
715
|
+
// We are in hash tree mode. Check if we need to create/reactivate a parser for this locusUrl.
|
|
716
|
+
if (!hashTreeParserEntry || hashTreeParserEntry.parser.state === 'stopped') {
|
|
717
|
+
if (!locusUrl) {
|
|
718
|
+
_loggerProxy.default.logger.warn('Locus-info:index#handleLocusAPIResponse --> API response has no locusUrl, cannot handle hash tree parser switch');
|
|
719
|
+
return;
|
|
682
720
|
}
|
|
683
|
-
|
|
721
|
+
this.handleHashTreeParserSwitchForAPIResponse(locusUrl, locus);
|
|
722
|
+
return;
|
|
723
|
+
}
|
|
724
|
+
|
|
725
|
+
// Active parser found - pass the API response to it
|
|
726
|
+
if (isWrapped) {
|
|
684
727
|
// update the data in our hash trees
|
|
685
728
|
hashTreeParserEntry.parser.handleLocusUpdate(responseBody);
|
|
686
729
|
} else {
|
|
687
|
-
// LocusDTO without wrapper - pass it through as if it had no dataSets
|
|
730
|
+
// LocusDTO without wrapper - pass it through as if it had no dataSets nor metadata
|
|
688
731
|
hashTreeParserEntry.parser.handleLocusUpdate({
|
|
689
732
|
locus: responseBody
|
|
690
733
|
});
|
|
691
734
|
}
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
this.handleLocusDelta(locus, meeting);
|
|
735
|
+
return;
|
|
736
|
+
}
|
|
737
|
+
|
|
738
|
+
// No hash tree parsers - classic Locus mode
|
|
739
|
+
if (isWrapped && responseBody.dataSets) {
|
|
740
|
+
this.sendClassicVsHashTreeMismatchMetric(meeting, "unexpected hash tree dataSets in API response");
|
|
699
741
|
}
|
|
742
|
+
|
|
743
|
+
// classic Locus delta
|
|
744
|
+
this.handleLocusDelta(locus, meeting);
|
|
700
745
|
}
|
|
701
746
|
|
|
702
747
|
/**
|
|
@@ -707,7 +752,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
707
752
|
}, {
|
|
708
753
|
key: "updateLocusFromHashTreeObject",
|
|
709
754
|
value: function updateLocusFromHashTreeObject(object, locus) {
|
|
710
|
-
var
|
|
755
|
+
var _this5 = this,
|
|
711
756
|
_locus$self;
|
|
712
757
|
var type = object.htMeta.elementId.type.toLowerCase();
|
|
713
758
|
var addParticipantObject = function addParticipantObject(obj) {
|
|
@@ -715,7 +760,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
715
760
|
locus.participants = [];
|
|
716
761
|
}
|
|
717
762
|
locus.participants.push(obj.data);
|
|
718
|
-
|
|
763
|
+
_this5.hashTreeObjectId2ParticipantId.set(obj.htMeta.elementId.id, obj.data.id);
|
|
719
764
|
};
|
|
720
765
|
switch (type) {
|
|
721
766
|
case _types.ObjectType.locus:
|
|
@@ -879,6 +924,81 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
879
924
|
}
|
|
880
925
|
}
|
|
881
926
|
|
|
927
|
+
/**
|
|
928
|
+
* Helper that handles the common logic for reactivating a stopped HashTreeParser when
|
|
929
|
+
* a newer "replaces" is detected. Used by both the message and API response parser switch methods.
|
|
930
|
+
*
|
|
931
|
+
* @param {string} callerName - name of the calling method, used in log messages
|
|
932
|
+
* @param {string} locusUrl - the locus URL of the stopped parser
|
|
933
|
+
* @param {HashTreeParserEntry} stoppedEntry - the stopped parser entry
|
|
934
|
+
* @param {ReplacesInfo} replaces - replacement info extracted from self
|
|
935
|
+
* @param {Function} resumeCallback - callback to invoke after reactivation to resume the parser
|
|
936
|
+
* @returns {void}
|
|
937
|
+
*/
|
|
938
|
+
}, {
|
|
939
|
+
key: "resumeStoppedParser",
|
|
940
|
+
value: function resumeStoppedParser(callerName, locusUrl, stoppedEntry, replaces, resumeCallback) {
|
|
941
|
+
// this check is just for typescript, it should never happen, replaces should always be defined
|
|
942
|
+
if (!replaces) {
|
|
943
|
+
_loggerProxy.default.logger.info("Locus-info:index#".concat(callerName, " --> received data for stopped HashTreeParser with locusUrl ").concat(locusUrl, ", but no replaces info provided, so not re-activating the parser"));
|
|
944
|
+
return;
|
|
945
|
+
}
|
|
946
|
+
if (replaces.replacedAt <= (stoppedEntry.replacedAt || '')) {
|
|
947
|
+
_loggerProxy.default.logger.info("Locus-info:index#".concat(callerName, " --> received data for stopped HashTreeParser with locusUrl ").concat(locusUrl, ", but replaces info provided is not newer, so not re-activating the parser"));
|
|
948
|
+
return;
|
|
949
|
+
}
|
|
950
|
+
_loggerProxy.default.logger.info("Locus-info:index#".concat(callerName, " --> reactivating HashTreeParser for locusUrl=").concat(locusUrl, ", which replaces ").concat(replaces.locusUrl));
|
|
951
|
+
var replacedEntry = this.hashTreeParsers.get(replaces.locusUrl);
|
|
952
|
+
if (replacedEntry) {
|
|
953
|
+
replacedEntry.replacedAt = replaces.replacedAt;
|
|
954
|
+
replacedEntry.parser.stop();
|
|
955
|
+
} else {
|
|
956
|
+
_loggerProxy.default.logger.warn("Locus-info:index#".concat(callerName, " --> the parser that is supposed to be replaced with the currently reactivated parser is not found, locusUrl=").concat(replaces.locusUrl));
|
|
957
|
+
}
|
|
958
|
+
stoppedEntry.initializedFromHashTree = false;
|
|
959
|
+
this.hashTreeObjectId2ParticipantId.clear();
|
|
960
|
+
resumeCallback();
|
|
961
|
+
}
|
|
962
|
+
|
|
963
|
+
/**
|
|
964
|
+
* Handles an API response whose locusUrl doesn't match any active HashTreeParser
|
|
965
|
+
* (either no entry exists, or the existing entry is stopped).
|
|
966
|
+
* Creates a new parser or reactivates a stopped one using initializeFromGetLociResponse.
|
|
967
|
+
*
|
|
968
|
+
* @param {string} locusUrl - the locus URL from the API response
|
|
969
|
+
* @param {LocusDTO} locus - the locus DTO from the API response
|
|
970
|
+
* @returns {void}
|
|
971
|
+
*/
|
|
972
|
+
}, {
|
|
973
|
+
key: "handleHashTreeParserSwitchForAPIResponse",
|
|
974
|
+
value: function handleHashTreeParserSwitchForAPIResponse(locusUrl, locus) {
|
|
975
|
+
var entry = this.hashTreeParsers.get(locusUrl);
|
|
976
|
+
var replaces = getReplaceInfoFromSelf(locus.self,
|
|
977
|
+
// @ts-ignore
|
|
978
|
+
this.webex.internal.device.url);
|
|
979
|
+
if (!entry) {
|
|
980
|
+
_loggerProxy.default.logger.info("Locus-info:index#handleHashTreeParserSwitchForAPIResponse --> no parser for locusUrl ".concat(locusUrl, ", creating a new one"));
|
|
981
|
+
var parser = this.createHashTreeParser({
|
|
982
|
+
locusUrl: locusUrl,
|
|
983
|
+
initialLocus: {
|
|
984
|
+
locus: null,
|
|
985
|
+
dataSets: []
|
|
986
|
+
},
|
|
987
|
+
metadata: null,
|
|
988
|
+
replacedAt: replaces === null || replaces === void 0 ? void 0 : replaces.replacedAt
|
|
989
|
+
});
|
|
990
|
+
parser.initializeFromGetLociResponse(locus);
|
|
991
|
+
return;
|
|
992
|
+
}
|
|
993
|
+
if (entry.parser.state !== 'stopped') {
|
|
994
|
+
_loggerProxy.default.logger.warn("Locus-info:index#handleHashTreeParserSwitchForAPIResponse --> unexpected parser state \"".concat(entry.parser.state, "\" for locusUrl ").concat(locusUrl));
|
|
995
|
+
return;
|
|
996
|
+
}
|
|
997
|
+
this.resumeStoppedParser('handleHashTreeParserSwitchForAPIResponse', locusUrl, entry, replaces, function () {
|
|
998
|
+
return entry.parser.resumeFromApiResponse(locus);
|
|
999
|
+
});
|
|
1000
|
+
}
|
|
1001
|
+
|
|
882
1002
|
/**
|
|
883
1003
|
* Checks if the hash tree message should trigger a switch to a different HashTreeParser
|
|
884
1004
|
*
|
|
@@ -903,7 +1023,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
903
1023
|
var metadata = (_message$locusStateEl5 = message.locusStateElements) === null || _message$locusStateEl5 === void 0 ? void 0 : _message$locusStateEl5.find(function (el) {
|
|
904
1024
|
return (0, _utils.isMetadata)(el);
|
|
905
1025
|
});
|
|
906
|
-
if (
|
|
1026
|
+
if (metadata && ((_metadata$data = metadata.data) === null || _metadata$data === void 0 ? void 0 : (_metadata$data$visibl = _metadata$data.visibleDataSets) === null || _metadata$data$visibl === void 0 ? void 0 : _metadata$data$visibl.length) > 0) {
|
|
907
1027
|
_loggerProxy.default.logger.info("Locus-info:index#handleHashTreeParserSwitch --> no hash tree parser found for locusUrl ".concat(message.locusUrl, ", creating a new one"));
|
|
908
1028
|
var parser = this.createHashTreeParser({
|
|
909
1029
|
locusUrl: message.locusUrl,
|
|
@@ -926,25 +1046,9 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
926
1046
|
if (entry.parser.state === 'stopped') {
|
|
927
1047
|
// the message matches a stopped parser, we need to check if maybe this is a new "replacement" and we need to re-activate the parser
|
|
928
1048
|
// this happens when you move from breakout A -> breakout B -> back to breakout A
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
var replacedEntry = this.hashTreeParsers.get(replaces.locusUrl);
|
|
933
|
-
if (replacedEntry) {
|
|
934
|
-
replacedEntry.replacedAt = replaces.replacedAt;
|
|
935
|
-
entry.initializedFromHashTree = false;
|
|
936
|
-
this.hashTreeObjectId2ParticipantId.clear();
|
|
937
|
-
replacedEntry.parser.stop();
|
|
938
|
-
entry.parser.resume(message);
|
|
939
|
-
} else {
|
|
940
|
-
_loggerProxy.default.logger.warn("Locus-info:index#handleHashTreeParserSwitch --> the parser that is supposed to be replaced with the currently resumed parser is not found, locusUrl=".concat(replaces.locusUrl));
|
|
941
|
-
}
|
|
942
|
-
} else {
|
|
943
|
-
_loggerProxy.default.logger.info("Locus-info:index#handleHashTreeParserSwitch --> received message for stopped HashTreeParser with locusUrl ".concat(message.locusUrl, ", but replaces info provided is not newer, so not re-activating the parser"));
|
|
944
|
-
}
|
|
945
|
-
return true;
|
|
946
|
-
}
|
|
947
|
-
_loggerProxy.default.logger.info("Locus-info:index#handleHashTreeParserSwitch --> received message for stopped HashTreeParser with locusUrl ".concat(message.locusUrl, ", but no replaces info provided, so not re-activating the parser"));
|
|
1049
|
+
this.resumeStoppedParser('handleHashTreeParserSwitch', message.locusUrl, entry, replaces, function () {
|
|
1050
|
+
return entry.parser.resumeFromMessage(message);
|
|
1051
|
+
});
|
|
948
1052
|
return true;
|
|
949
1053
|
}
|
|
950
1054
|
return false;
|
|
@@ -970,23 +1074,81 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
970
1074
|
return;
|
|
971
1075
|
}
|
|
972
1076
|
var entry = this.hashTreeParsers.get(message.locusUrl);
|
|
973
|
-
|
|
1077
|
+
|
|
1078
|
+
// the check is just for typescript, the case of no entry in hashTreeParsers is handled in handleHashTreeParserSwitch() above
|
|
1079
|
+
if (entry) {
|
|
1080
|
+
entry.parser.handleMessage(message);
|
|
1081
|
+
}
|
|
974
1082
|
}
|
|
975
1083
|
|
|
1084
|
+
/**
|
|
1085
|
+
* Triggers a sync of all hash tree datasets for all hash tree parsers associated with this meeting.
|
|
1086
|
+
* The syncs are executed sequentially within each parser.
|
|
1087
|
+
*
|
|
1088
|
+
* @returns {Promise<void>}
|
|
1089
|
+
*/
|
|
1090
|
+
}, {
|
|
1091
|
+
key: "syncAllHashTreeDatasets",
|
|
1092
|
+
value: (function () {
|
|
1093
|
+
var _syncAllHashTreeDatasets = (0, _asyncToGenerator2.default)(/*#__PURE__*/_regenerator.default.mark(function _callee2() {
|
|
1094
|
+
var _iterator3, _step3, _step3$value, entry, _t2;
|
|
1095
|
+
return _regenerator.default.wrap(function (_context2) {
|
|
1096
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
1097
|
+
case 0:
|
|
1098
|
+
_iterator3 = _createForOfIteratorHelper(this.hashTreeParsers);
|
|
1099
|
+
_context2.prev = 1;
|
|
1100
|
+
_iterator3.s();
|
|
1101
|
+
case 2:
|
|
1102
|
+
if ((_step3 = _iterator3.n()).done) {
|
|
1103
|
+
_context2.next = 4;
|
|
1104
|
+
break;
|
|
1105
|
+
}
|
|
1106
|
+
_step3$value = (0, _slicedToArray2.default)(_step3.value, 2), entry = _step3$value[1];
|
|
1107
|
+
if (!entry.parser) {
|
|
1108
|
+
_context2.next = 3;
|
|
1109
|
+
break;
|
|
1110
|
+
}
|
|
1111
|
+
_context2.next = 3;
|
|
1112
|
+
return entry.parser.syncAllDatasets();
|
|
1113
|
+
case 3:
|
|
1114
|
+
_context2.next = 2;
|
|
1115
|
+
break;
|
|
1116
|
+
case 4:
|
|
1117
|
+
_context2.next = 6;
|
|
1118
|
+
break;
|
|
1119
|
+
case 5:
|
|
1120
|
+
_context2.prev = 5;
|
|
1121
|
+
_t2 = _context2["catch"](1);
|
|
1122
|
+
_iterator3.e(_t2);
|
|
1123
|
+
case 6:
|
|
1124
|
+
_context2.prev = 6;
|
|
1125
|
+
_iterator3.f();
|
|
1126
|
+
return _context2.finish(6);
|
|
1127
|
+
case 7:
|
|
1128
|
+
case "end":
|
|
1129
|
+
return _context2.stop();
|
|
1130
|
+
}
|
|
1131
|
+
}, _callee2, this, [[1, 5, 6, 7]]);
|
|
1132
|
+
}));
|
|
1133
|
+
function syncAllHashTreeDatasets() {
|
|
1134
|
+
return _syncAllHashTreeDatasets.apply(this, arguments);
|
|
1135
|
+
}
|
|
1136
|
+
return syncAllHashTreeDatasets;
|
|
1137
|
+
}()
|
|
976
1138
|
/**
|
|
977
1139
|
* Callback registered with HashTreeParser to receive locus info updates.
|
|
978
1140
|
* Updates our locus info based on the data parsed by the hash tree parser.
|
|
979
1141
|
*
|
|
980
1142
|
* @param {string} locusUrl - the locus URL for which the update is received
|
|
981
|
-
* @param {
|
|
982
|
-
* @param {Object} [data] - Additional data for the update, if applicable.
|
|
1143
|
+
* @param {LocusInfoUpdate} update - Details about the update.
|
|
983
1144
|
* @returns {void}
|
|
984
1145
|
*/
|
|
1146
|
+
)
|
|
985
1147
|
}, {
|
|
986
1148
|
key: "updateFromHashTree",
|
|
987
|
-
value: function updateFromHashTree(locusUrl,
|
|
988
|
-
var
|
|
989
|
-
switch (updateType) {
|
|
1149
|
+
value: function updateFromHashTree(locusUrl, update) {
|
|
1150
|
+
var _this6 = this;
|
|
1151
|
+
switch (update.updateType) {
|
|
990
1152
|
case _hashTreeParser2.LocusInfoUpdateType.OBJECTS_UPDATED:
|
|
991
1153
|
{
|
|
992
1154
|
// initialize our new locus
|
|
@@ -1000,7 +1162,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1000
1162
|
|
|
1001
1163
|
// first go over all the updates and check what happens with the main locus object
|
|
1002
1164
|
var locusObjectStateAfterUpdates = LocusObjectStateAfterUpdates.unchanged;
|
|
1003
|
-
|
|
1165
|
+
update.updatedObjects.forEach(function (object) {
|
|
1004
1166
|
if (object.htMeta.elementId.type.toLowerCase() === _types.ObjectType.locus) {
|
|
1005
1167
|
if (locusObjectStateAfterUpdates === LocusObjectStateAfterUpdates.updated) {
|
|
1006
1168
|
var _object$data;
|
|
@@ -1009,7 +1171,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1009
1171
|
// but these should never happen
|
|
1010
1172
|
_loggerProxy.default.logger.warn("Locus-info:index#updateFromHashTree --> received multiple LOCUS objects in one update, this is unexpected!");
|
|
1011
1173
|
_metrics.default.sendBehavioralMetric(_constants2.default.LOCUS_HASH_TREE_UNSUPPORTED_OPERATION, {
|
|
1012
|
-
locusUrl: ((_object$data = object.data) === null || _object$data === void 0 ? void 0 : _object$data.url) ||
|
|
1174
|
+
locusUrl: ((_object$data = object.data) === null || _object$data === void 0 ? void 0 : _object$data.url) || _this6.url,
|
|
1013
1175
|
message: object.data ? 'multiple LOCUS object updates' : 'LOCUS object update followed by removal'
|
|
1014
1176
|
});
|
|
1015
1177
|
}
|
|
@@ -1021,12 +1183,17 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1021
1183
|
}
|
|
1022
1184
|
});
|
|
1023
1185
|
var hashTreeParserEntry = this.hashTreeParsers.get(locusUrl);
|
|
1186
|
+
if (!hashTreeParserEntry) {
|
|
1187
|
+
_loggerProxy.default.logger.warn("Locus-info:index#updateFromHashTree --> no HashTreeParser found for locusUrl ".concat(locusUrl, " when trying to apply updates from hash tree"));
|
|
1188
|
+
return;
|
|
1189
|
+
}
|
|
1024
1190
|
if (!hashTreeParserEntry.initializedFromHashTree) {
|
|
1025
1191
|
// this is the first time we're getting an update for this locusUrl,
|
|
1026
1192
|
// so it's probably a move to/from breakout. We need to start from a clean state,
|
|
1027
1193
|
// so empty locus and we rely on Locus giving us sufficient data in the updates to populate it.
|
|
1028
1194
|
_loggerProxy.default.logger.info("Locus-info:index#updateFromHashTree --> first INITIAL update for locusUrl ".concat(locusUrl, ", starting from empty state"));
|
|
1029
1195
|
hashTreeParserEntry.initializedFromHashTree = true;
|
|
1196
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
1030
1197
|
locus.jsSdkMeta.forceReplaceMembers = true;
|
|
1031
1198
|
} else if (
|
|
1032
1199
|
// if Locus object is unchanged or removed, we need to keep using the existing locus
|
|
@@ -1038,7 +1205,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1038
1205
|
// copy over all of existing locus except participants
|
|
1039
1206
|
LocusDtoTopLevelKeys.forEach(function (key) {
|
|
1040
1207
|
if (key !== 'participants') {
|
|
1041
|
-
locus[key] = (0, _lodash.cloneDeep)(
|
|
1208
|
+
locus[key] = (0, _lodash.cloneDeep)(_this6[key]);
|
|
1042
1209
|
}
|
|
1043
1210
|
});
|
|
1044
1211
|
} else {
|
|
@@ -1046,11 +1213,11 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1046
1213
|
// (except participants, which need to stay empty - that means "no participant changes")
|
|
1047
1214
|
(0, _values.default)(_types.ObjectTypeToLocusKeyMap).forEach(function (locusDtoKey) {
|
|
1048
1215
|
if (locusDtoKey !== 'participants') {
|
|
1049
|
-
locus[locusDtoKey] = (0, _lodash.cloneDeep)(
|
|
1216
|
+
locus[locusDtoKey] = (0, _lodash.cloneDeep)(_this6[locusDtoKey]);
|
|
1050
1217
|
}
|
|
1051
1218
|
});
|
|
1052
1219
|
}
|
|
1053
|
-
_loggerProxy.default.logger.info("Locus-info:index#updateFromHashTree --> LOCUS object is ".concat(locusObjectStateAfterUpdates, ", all updates: ").concat((0, _stringify.default)(
|
|
1220
|
+
_loggerProxy.default.logger.info("Locus-info:index#updateFromHashTree --> LOCUS object is ".concat(locusObjectStateAfterUpdates, ", all updates: ").concat((0, _stringify.default)(update.updatedObjects.map(function (o) {
|
|
1054
1221
|
return {
|
|
1055
1222
|
type: o.htMeta.elementId.type,
|
|
1056
1223
|
id: o.htMeta.elementId.id,
|
|
@@ -1058,8 +1225,8 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1058
1225
|
};
|
|
1059
1226
|
}))));
|
|
1060
1227
|
// now apply all the updates from the hash tree onto the locus
|
|
1061
|
-
|
|
1062
|
-
locus =
|
|
1228
|
+
update.updatedObjects.forEach(function (object) {
|
|
1229
|
+
locus = _this6.updateLocusFromHashTreeObject(object, locus);
|
|
1063
1230
|
});
|
|
1064
1231
|
|
|
1065
1232
|
// update our locus info with the new locus
|
|
@@ -1073,6 +1240,18 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1073
1240
|
_loggerProxy.default.logger.info("Locus-info:index#updateFromHashTree --> received signal that meeting ended, destroying meeting ".concat(this.meetingId));
|
|
1074
1241
|
this.webex.meetings.destroy(meeting, _constants.MEETING_REMOVED_REASON.SELF_REMOVED);
|
|
1075
1242
|
}
|
|
1243
|
+
break;
|
|
1244
|
+
}
|
|
1245
|
+
case _hashTreeParser2.LocusInfoUpdateType.LOCUS_NOT_FOUND:
|
|
1246
|
+
{
|
|
1247
|
+
_loggerProxy.default.logger.info("Locus-info:index#updateFromHashTree --> received LOCUS_NOT_FOUND for ".concat(locusUrl, ", triggering syncMeetings"));
|
|
1248
|
+
this.webex.meetings.syncMeetings({
|
|
1249
|
+
keepOnlyLocusMeetings: false,
|
|
1250
|
+
skipHashTreeSync: true
|
|
1251
|
+
}).catch(function (syncError) {
|
|
1252
|
+
_loggerProxy.default.logger.error("Locus-info:index#updateFromHashTree --> syncMeetings failed after LOCUS_NOT_FOUND: ".concat(syncError));
|
|
1253
|
+
});
|
|
1254
|
+
break;
|
|
1076
1255
|
}
|
|
1077
1256
|
}
|
|
1078
1257
|
}
|
|
@@ -1087,7 +1266,13 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1087
1266
|
key: "parse",
|
|
1088
1267
|
value: function parse(meeting, data) {
|
|
1089
1268
|
if (this.hashTreeParsers.size > 0) {
|
|
1090
|
-
|
|
1269
|
+
if (data.eventType === _constants.LOCUSEVENT.SDK_LOCUS_FROM_SYNC_MEETINGS) {
|
|
1270
|
+
// sync meetings response follows the format of "not wrapped" locus API responses,
|
|
1271
|
+
// so has no dataSets nor Metadata
|
|
1272
|
+
this.handleLocusAPIResponse(meeting, _objectSpread({}, data.locus));
|
|
1273
|
+
} else {
|
|
1274
|
+
this.handleHashTreeMessage(meeting, data.eventType, data.stateElementsMessage);
|
|
1275
|
+
}
|
|
1091
1276
|
} else {
|
|
1092
1277
|
var eventType = data.eventType;
|
|
1093
1278
|
if (eventType === _constants.LOCUSEVENT.HASH_TREE_DATA_UPDATED) {
|
|
@@ -1148,13 +1333,13 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1148
1333
|
* @param {string} debugText string explaining the trigger for this call, added to logs for debugging purposes
|
|
1149
1334
|
* @param {object} locus locus object
|
|
1150
1335
|
* @param {object} metadata locus hash trees metadata
|
|
1151
|
-
* @param {string} eventType locus event
|
|
1152
1336
|
* @param {DataSet[]} dataSets
|
|
1337
|
+
* @param {string} eventType locus event
|
|
1153
1338
|
* @returns {void}
|
|
1154
1339
|
*/
|
|
1155
1340
|
}, {
|
|
1156
1341
|
key: "onFullLocusWithHashTrees",
|
|
1157
|
-
value: function onFullLocusWithHashTrees(debugText, locus, metadata,
|
|
1342
|
+
value: function onFullLocusWithHashTrees(debugText, locus, metadata, dataSets, eventType) {
|
|
1158
1343
|
if (!this.hashTreeParsers.has(locus.url)) {
|
|
1159
1344
|
_loggerProxy.default.logger.info("Locus-info:index#onFullLocus (".concat(debugText, ") --> creating hash tree parser for locusUrl=").concat(locus.url));
|
|
1160
1345
|
_loggerProxy.default.logger.info("Locus-info:index#onFullLocus (".concat(debugText, ") --> dataSets:"), dataSets, ' and locus:', locus, ' and metadata:', metadata);
|
|
@@ -1167,6 +1352,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1167
1352
|
metadata: metadata
|
|
1168
1353
|
});
|
|
1169
1354
|
// we have a full locus to start with, so we consider Locus info to be "initialized"
|
|
1355
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
1170
1356
|
this.hashTreeParsers.get(locus.url).initializedFromHashTree = true;
|
|
1171
1357
|
this.onFullLocusCommon(locus, eventType);
|
|
1172
1358
|
} else {
|
|
@@ -1221,7 +1407,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1221
1407
|
throw new Error("Locus-info:index#onFullLocus (".concat(debugText, ") --> hash tree metadata is missing with full Locus"));
|
|
1222
1408
|
}
|
|
1223
1409
|
// this is the new hashmap Locus DTO format (only applicable to webinars for now)
|
|
1224
|
-
this.onFullLocusWithHashTrees(debugText, locus, metadata,
|
|
1410
|
+
this.onFullLocusWithHashTrees(debugText, locus, metadata, dataSets, eventType);
|
|
1225
1411
|
} else {
|
|
1226
1412
|
this.onFullLocusClassic(debugText, locus, eventType);
|
|
1227
1413
|
}
|
|
@@ -1237,7 +1423,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1237
1423
|
key: "onFullLocusCommon",
|
|
1238
1424
|
value: function onFullLocusCommon(locus, eventType) {
|
|
1239
1425
|
var _this$participants,
|
|
1240
|
-
|
|
1426
|
+
_this7 = this,
|
|
1241
1427
|
_locus$jsSdkMeta;
|
|
1242
1428
|
this.scheduledMeeting = locus.meeting || null;
|
|
1243
1429
|
this.participants = locus.participants;
|
|
@@ -1245,7 +1431,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1245
1431
|
var _participant$htMeta;
|
|
1246
1432
|
// participant.htMeta is set only for hash tree based locus
|
|
1247
1433
|
if (typeof ((_participant$htMeta = participant.htMeta) === null || _participant$htMeta === void 0 ? void 0 : _participant$htMeta.elementId.id) === 'number') {
|
|
1248
|
-
|
|
1434
|
+
_this7.hashTreeObjectId2ParticipantId.set(participant.htMeta.elementId.id, participant.id);
|
|
1249
1435
|
}
|
|
1250
1436
|
});
|
|
1251
1437
|
var isReplaceMembers = _controlsUtils.default.isNeedReplaceMembers(this.controls, locus.controls);
|
|
@@ -1353,8 +1539,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1353
1539
|
}, {
|
|
1354
1540
|
key: "updateLocusInfo",
|
|
1355
1541
|
value: function updateLocusInfo(locus) {
|
|
1356
|
-
|
|
1357
|
-
if (((_locus$self2 = locus.self) === null || _locus$self2 === void 0 ? void 0 : _locus$self2.reason) === 'MOVED' && ((_locus$self3 = locus.self) === null || _locus$self3 === void 0 ? void 0 : _locus$self3.state) === 'LEFT') {
|
|
1542
|
+
if (_util.default.isSelfMovedOrBreakoutEnded(locus)) {
|
|
1358
1543
|
// When moved to a breakout session locus sends a message for the previous locus
|
|
1359
1544
|
// indicating that we have been moved. It isn't helpful to continue parsing this
|
|
1360
1545
|
// as it gets interpreted as if we have left the call
|
|
@@ -1474,10 +1659,8 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1474
1659
|
});
|
|
1475
1660
|
}
|
|
1476
1661
|
} else if (((_this$parsedLocus$ful6 = this.parsedLocus.fullState) === null || _this$parsedLocus$ful6 === void 0 ? void 0 : _this$parsedLocus$ful6.type) === _constants._MEETING_) {
|
|
1477
|
-
if (this.fullState && (this.fullState
|
|
1478
|
-
|
|
1479
|
-
this.fullState.state === _constants.LOCUS.STATE.TERMINATING)) {
|
|
1480
|
-
_loggerProxy.default.logger.warn('Locus-info:index#isMeetingActive --> Meeting is ending due to inactive or terminating');
|
|
1662
|
+
if (this.fullState && _util.default.isWholeMeetingEnded(this.fullState)) {
|
|
1663
|
+
_loggerProxy.default.logger.warn('Locus-info:index#isMeetingActive --> Meeting is ending due to inactive');
|
|
1481
1664
|
|
|
1482
1665
|
// @ts-ignore
|
|
1483
1666
|
this.webex.internal.newMetrics.submitClientEvent({
|
|
@@ -1579,11 +1762,11 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1579
1762
|
isReplace: isReplace
|
|
1580
1763
|
});
|
|
1581
1764
|
if (participants && (0, _isArray.default)(participants) && participants.length > 0) {
|
|
1582
|
-
var
|
|
1583
|
-
|
|
1765
|
+
var _iterator4 = _createForOfIteratorHelper(participants),
|
|
1766
|
+
_step4;
|
|
1584
1767
|
try {
|
|
1585
|
-
for (
|
|
1586
|
-
var participant =
|
|
1768
|
+
for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
|
|
1769
|
+
var participant = _step4.value;
|
|
1587
1770
|
if (participant && (participant === null || participant === void 0 ? void 0 : participant.reason) === 'FAILURE') {
|
|
1588
1771
|
var _participant$person;
|
|
1589
1772
|
this.emitScoped({
|
|
@@ -1595,9 +1778,9 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1595
1778
|
}
|
|
1596
1779
|
}
|
|
1597
1780
|
} catch (err) {
|
|
1598
|
-
|
|
1781
|
+
_iterator4.e(err);
|
|
1599
1782
|
} finally {
|
|
1600
|
-
|
|
1783
|
+
_iterator4.f();
|
|
1601
1784
|
}
|
|
1602
1785
|
}
|
|
1603
1786
|
}
|
|
@@ -1718,7 +1901,9 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
1718
1901
|
}, _constants.LOCUSINFO.EVENTS.CONTROLS_RECORDING_UPDATED, {
|
|
1719
1902
|
state: state,
|
|
1720
1903
|
modifiedBy: current.record.modifiedBy,
|
|
1721
|
-
lastModified: current.record.lastModified
|
|
1904
|
+
lastModified: current.record.lastModified,
|
|
1905
|
+
modifiedByServiceAppName: current.record.modifiedByServiceAppName,
|
|
1906
|
+
modifiedByServiceAppId: current.record.modifiedByServiceAppId
|
|
1722
1907
|
});
|
|
1723
1908
|
}
|
|
1724
1909
|
if (hasMeetingContainerChanged) {
|
|
@@ -2243,12 +2428,14 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
2243
2428
|
});
|
|
2244
2429
|
}
|
|
2245
2430
|
if (parsedSelves.updates.isMutedByOthersChanged) {
|
|
2431
|
+
var _parsedSelves$current2;
|
|
2246
2432
|
this.emitScoped({
|
|
2247
2433
|
file: 'locus-info',
|
|
2248
2434
|
function: 'updateSelf'
|
|
2249
2435
|
}, _constants.LOCUSINFO.EVENTS.SELF_REMOTE_MUTE_STATUS_UPDATED, {
|
|
2250
2436
|
muted: parsedSelves.current.remoteMuted,
|
|
2251
|
-
unmuteAllowed: parsedSelves.current.unmuteAllowed
|
|
2437
|
+
unmuteAllowed: parsedSelves.current.unmuteAllowed,
|
|
2438
|
+
modifiedBy: (_parsedSelves$current2 = parsedSelves.current.modifiedBy) !== null && _parsedSelves$current2 !== void 0 ? _parsedSelves$current2 : null
|
|
2252
2439
|
});
|
|
2253
2440
|
}
|
|
2254
2441
|
if (parsedSelves.updates.localAudioUnmuteRequestedByServer) {
|
|
@@ -2278,14 +2465,14 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
2278
2465
|
_constants.LOCUSINFO.EVENTS.MEDIA_INACTIVITY, _selfUtils.default.getMediaStatus(self.mediaSessions));
|
|
2279
2466
|
}
|
|
2280
2467
|
if (parsedSelves.updates.audioStateChange || parsedSelves.updates.videoStateChange || parsedSelves.updates.shareStateChange) {
|
|
2281
|
-
var _parsedSelves$
|
|
2468
|
+
var _parsedSelves$current3, _parsedSelves$current4, _parsedSelves$current5;
|
|
2282
2469
|
this.emitScoped({
|
|
2283
2470
|
file: 'locus-info',
|
|
2284
2471
|
function: 'updateSelf'
|
|
2285
2472
|
}, _constants.LOCUSINFO.EVENTS.MEDIA_STATUS_CHANGE, {
|
|
2286
|
-
audioStatus: (_parsedSelves$
|
|
2287
|
-
videoStatus: (_parsedSelves$
|
|
2288
|
-
shareStatus: (_parsedSelves$
|
|
2473
|
+
audioStatus: (_parsedSelves$current3 = parsedSelves.current.currentMediaStatus) === null || _parsedSelves$current3 === void 0 ? void 0 : _parsedSelves$current3.audio,
|
|
2474
|
+
videoStatus: (_parsedSelves$current4 = parsedSelves.current.currentMediaStatus) === null || _parsedSelves$current4 === void 0 ? void 0 : _parsedSelves$current4.video,
|
|
2475
|
+
shareStatus: (_parsedSelves$current5 = parsedSelves.current.currentMediaStatus) === null || _parsedSelves$current5 === void 0 ? void 0 : _parsedSelves$current5.share
|
|
2289
2476
|
});
|
|
2290
2477
|
}
|
|
2291
2478
|
if (parsedSelves.updates.isUserObserving) {
|
|
@@ -2467,7 +2654,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
2467
2654
|
}, {
|
|
2468
2655
|
key: "updateMainSessionLocusCache",
|
|
2469
2656
|
value: function updateMainSessionLocusCache(mainLocus) {
|
|
2470
|
-
var
|
|
2657
|
+
var _this8 = this;
|
|
2471
2658
|
if (!mainLocus) {
|
|
2472
2659
|
return;
|
|
2473
2660
|
}
|
|
@@ -2476,7 +2663,7 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
2476
2663
|
// shallow merge and do special merge for participants
|
|
2477
2664
|
(0, _lodash.assignWith)(this.mainSessionLocusCache, locusClone, function (objValue, srcValue, key) {
|
|
2478
2665
|
if (key === 'participants') {
|
|
2479
|
-
return
|
|
2666
|
+
return _this8.mergeParticipants(objValue, srcValue);
|
|
2480
2667
|
}
|
|
2481
2668
|
return srcValue || objValue;
|
|
2482
2669
|
});
|
|
@@ -2495,6 +2682,21 @@ var LocusInfo = exports.default = /*#__PURE__*/function (_EventsScope) {
|
|
|
2495
2682
|
value: function clearMainSessionLocusCache() {
|
|
2496
2683
|
this.mainSessionLocusCache = null;
|
|
2497
2684
|
}
|
|
2685
|
+
|
|
2686
|
+
/**
|
|
2687
|
+
* Cleans up all hash tree parsers and clears internal maps.
|
|
2688
|
+
* @returns {void}
|
|
2689
|
+
* @memberof LocusInfo
|
|
2690
|
+
*/
|
|
2691
|
+
}, {
|
|
2692
|
+
key: "cleanUp",
|
|
2693
|
+
value: function cleanUp() {
|
|
2694
|
+
this.hashTreeParsers.forEach(function (entry) {
|
|
2695
|
+
entry.parser.cleanUp();
|
|
2696
|
+
});
|
|
2697
|
+
this.hashTreeParsers.clear();
|
|
2698
|
+
this.hashTreeObjectId2ParticipantId.clear();
|
|
2699
|
+
}
|
|
2498
2700
|
}]);
|
|
2499
2701
|
}(_eventsScope.default);
|
|
2500
2702
|
//# sourceMappingURL=index.js.map
|