@webex/plugin-meetings 3.0.0-beta.228 → 3.0.0-beta.229
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/breakouts/breakout.js +1 -1
- package/dist/breakouts/index.js +1 -1
- package/dist/common/errors/webex-errors.js +25 -5
- package/dist/common/errors/webex-errors.js.map +1 -1
- package/dist/config.js +2 -2
- package/dist/config.js.map +1 -1
- package/dist/interpretation/index.js +1 -1
- package/dist/interpretation/siLanguage.js +1 -1
- package/dist/meeting-info/util.js +1 -1
- package/dist/meeting-info/util.js.map +1 -1
- package/dist/meeting-info/utilv2.js +16 -31
- package/dist/meeting-info/utilv2.js.map +1 -1
- package/dist/meetings/index.js +6 -2
- package/dist/meetings/index.js.map +1 -1
- package/dist/types/common/errors/webex-errors.d.ts +12 -0
- package/dist/types/meetings/index.d.ts +1 -1
- package/package.json +19 -19
- package/src/common/errors/webex-errors.ts +21 -0
- package/src/config.ts +2 -2
- package/src/meeting-info/util.ts +1 -1
- package/src/meeting-info/utilv2.ts +10 -20
- package/src/meetings/index.ts +8 -4
package/dist/breakouts/index.js
CHANGED
|
@@ -1041,7 +1041,7 @@ var Breakouts = _webexCore.WebexPlugin.extend({
|
|
|
1041
1041
|
this.trigger(_constants.BREAKOUTS.EVENTS.ASK_RETURN_TO_MAIN);
|
|
1042
1042
|
}
|
|
1043
1043
|
},
|
|
1044
|
-
version: "3.0.0-beta.
|
|
1044
|
+
version: "3.0.0-beta.229"
|
|
1045
1045
|
});
|
|
1046
1046
|
var _default = Breakouts;
|
|
1047
1047
|
exports.default = _default;
|
|
@@ -6,7 +6,7 @@ var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequ
|
|
|
6
6
|
_Object$defineProperty(exports, "__esModule", {
|
|
7
7
|
value: true
|
|
8
8
|
});
|
|
9
|
-
exports.UserNotJoinedError = exports.UserInLobbyError = exports.NoMediaEstablishedYetError = exports.MeetingNotActiveError = exports.IceGatheringFailed = void 0;
|
|
9
|
+
exports.UserNotJoinedError = exports.UserInLobbyError = exports.SpaceIDDeprecatedError = exports.NoMediaEstablishedYetError = exports.MeetingNotActiveError = exports.IceGatheringFailed = void 0;
|
|
10
10
|
exports.createMeetingsError = createMeetingsError;
|
|
11
11
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
|
|
12
12
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
|
|
@@ -113,6 +113,26 @@ exports.UserInLobbyError = UserInLobbyError;
|
|
|
113
113
|
(0, _defineProperty2.default)(UserInLobbyError, "CODE", 30104);
|
|
114
114
|
WebExMeetingsErrors[UserInLobbyError.CODE] = UserInLobbyError;
|
|
115
115
|
|
|
116
|
+
/**
|
|
117
|
+
* @class SpaceIDDeprecatedError
|
|
118
|
+
* @classdesc Raised whenever the user passes Space ID as destination for create meeting.
|
|
119
|
+
* @extends WebexMeetingsError
|
|
120
|
+
* @property {number} code - 30105
|
|
121
|
+
* @property {string} message - Using the space ID as a destination is no longer supported. Please refer to the [migration guide](https://github.com/webex/webex-js-sdk/wiki/Migration-guide-for-USM-meeting) to migrate to use the meeting ID or SIP address.'
|
|
122
|
+
*/
|
|
123
|
+
var SpaceIDDeprecatedError = /*#__PURE__*/function (_WebexMeetingsError5) {
|
|
124
|
+
(0, _inherits2.default)(SpaceIDDeprecatedError, _WebexMeetingsError5);
|
|
125
|
+
var _super5 = _createSuper(SpaceIDDeprecatedError);
|
|
126
|
+
function SpaceIDDeprecatedError() {
|
|
127
|
+
(0, _classCallCheck2.default)(this, SpaceIDDeprecatedError);
|
|
128
|
+
return _super5.call(this, SpaceIDDeprecatedError.CODE, 'Using the space ID as a destination is no longer supported. Please refer to the [migration guide](https://github.com/webex/webex-js-sdk/wiki/Migration-guide-for-USM-meeting) to migrate to use the meeting ID or SIP address.');
|
|
129
|
+
}
|
|
130
|
+
return (0, _createClass2.default)(SpaceIDDeprecatedError);
|
|
131
|
+
}(_webexMeetingsError.default);
|
|
132
|
+
exports.SpaceIDDeprecatedError = SpaceIDDeprecatedError;
|
|
133
|
+
(0, _defineProperty2.default)(SpaceIDDeprecatedError, "CODE", 30105);
|
|
134
|
+
WebExMeetingsErrors[SpaceIDDeprecatedError.CODE] = SpaceIDDeprecatedError;
|
|
135
|
+
|
|
116
136
|
/**
|
|
117
137
|
* @class IceGatheringFailed
|
|
118
138
|
* @classdesc Raised whenever ice gathering fails.
|
|
@@ -120,12 +140,12 @@ WebExMeetingsErrors[UserInLobbyError.CODE] = UserInLobbyError;
|
|
|
120
140
|
* @property {number} code - 30202
|
|
121
141
|
* @property {string} message - 'user failed ice gathering check network/firewall'
|
|
122
142
|
*/
|
|
123
|
-
var IceGatheringFailed = /*#__PURE__*/function (
|
|
124
|
-
(0, _inherits2.default)(IceGatheringFailed,
|
|
125
|
-
var
|
|
143
|
+
var IceGatheringFailed = /*#__PURE__*/function (_WebexMeetingsError6) {
|
|
144
|
+
(0, _inherits2.default)(IceGatheringFailed, _WebexMeetingsError6);
|
|
145
|
+
var _super6 = _createSuper(IceGatheringFailed);
|
|
126
146
|
function IceGatheringFailed() {
|
|
127
147
|
(0, _classCallCheck2.default)(this, IceGatheringFailed);
|
|
128
|
-
return
|
|
148
|
+
return _super6.call(this, IceGatheringFailed.CODE, 'iceConnection: gethering ice candidate failed');
|
|
129
149
|
}
|
|
130
150
|
return (0, _createClass2.default)(IceGatheringFailed);
|
|
131
151
|
}(_webexMeetingsError.default);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["WebExMeetingsErrors","createMeetingsError","code","message","WebexMeetingsError","MeetingNotActiveError","CODE","UserNotJoinedError","NoMediaEstablishedYetError","UserInLobbyError","IceGatheringFailed"],"sources":["webex-errors.ts"],"sourcesContent":["// The document would auto generate the doc for errors\n\n// 1) Error codes for Oauth, login, mercury should be separated out (Code range)\n// 2) Errors from the actual locus server or other server in case, we can use the same error code as locus and redirect it\n// 3) Any errors we generate from the SDK can be split into various categories\n// Parameter validation, user action, connection, media specific(They can have different range)\n\n// TODO: all the errors from the server need to be captured\n\n// add a way to log and send metrics if needed\nimport WebexMeetingsError from './webex-meetings-error';\n\nconst WebExMeetingsErrors = {};\n\n/**\n * Create a {@link WebexMeetingsError} for a given code and message.\n * @private\n * @param {number} [code] - Error code\n * @param {string} [message] - Error message\n * @returns {WebexMeetingsError}\n */\nexport function createMeetingsError(code?: number, message?: string) {\n code = typeof code === 'number' ? code : 0;\n message = typeof message === 'string' && message ? message : 'Unknown error';\n\n return WebExMeetingsErrors[code]\n ? new WebExMeetingsErrors[code]()\n : new WebexMeetingsError(code, message);\n}\n\n/**\n * @class MeetingNotActiveError\n * @classdesc Raised whenever Meeting has already ended and user tries to do a action.\n * @extends WebexMeetingsError\n * @property {number} code - 30101\n * @property {string} message - 'Meeting has already Ended or not Active'\n */\nclass MeetingNotActiveError extends WebexMeetingsError {\n static CODE = 30101;\n\n constructor() {\n super(MeetingNotActiveError.CODE, 'Meeting has already Ended or not Active');\n }\n}\n\nexport {MeetingNotActiveError};\nWebExMeetingsErrors[MeetingNotActiveError.CODE] = MeetingNotActiveError;\n\n/**\n * @class UserNotJoinedError\n * @classdesc Raised whenever the user has already left the meeting and user tries to do a action.\n * @extends WebexMeetingsError\n * @property {number} code - 30102\n * @property {string} message - 'User has already left the meeting'\n */\nclass UserNotJoinedError extends WebexMeetingsError {\n static CODE = 30102;\n\n constructor() {\n super(\n UserNotJoinedError.CODE,\n 'User currently not in meeting. Please join a meeting before adding media.'\n );\n }\n}\n\nexport {UserNotJoinedError};\nWebExMeetingsErrors[UserNotJoinedError.CODE] = UserNotJoinedError;\n\n/**\n * @class NoMediaEstablishedYetError\n * @classdesc Raised whenever the user has not established media yet.\n * @extends WebexMeetingsError\n * @property {number} code - 30103\n * @property {string} message - error message\n */\nclass NoMediaEstablishedYetError extends WebexMeetingsError {\n static CODE = 30103;\n\n // eslint-disable-next-line require-jsdoc\n constructor() {\n super(\n NoMediaEstablishedYetError.CODE,\n 'Webrtc media connection is missing, call addMedia() first'\n );\n }\n}\n\nexport {NoMediaEstablishedYetError};\nWebExMeetingsErrors[NoMediaEstablishedYetError.CODE] = NoMediaEstablishedYetError;\n\n/**\n * @class UserInLobbyError\n * @classdesc Raised whenever the user is in lobby and not joined yet.\n * @extends WebexMeetingsError\n * @property {number} code - 30104\n * @property {string} message - 'user is still in the lobby or not joined'\n */\nclass UserInLobbyError extends WebexMeetingsError {\n static CODE = 30104;\n\n constructor() {\n super(UserInLobbyError.CODE, 'user is still in the lobby or not joined');\n }\n}\n\nexport {UserInLobbyError};\nWebExMeetingsErrors[UserInLobbyError.CODE] = UserInLobbyError;\n\n/**\n * @class IceGatheringFailed\n * @classdesc Raised whenever ice gathering fails.\n * @extends WebexMeetingsError\n * @property {number} code - 30202\n * @property {string} message - 'user failed ice gathering check network/firewall'\n */\nclass IceGatheringFailed extends WebexMeetingsError {\n static CODE = 30202;\n\n constructor() {\n super(IceGatheringFailed.CODE, 'iceConnection: gethering ice candidate failed');\n }\n}\n\nexport {IceGatheringFailed};\nWebExMeetingsErrors[IceGatheringFailed.CODE] = IceGatheringFailed;\n"],"mappings":";;;;;;;;;;;;;;;;AAUA;AAAwD;AAAA;AAExD,IAAMA,mBAAmB,GAAG,CAAC,CAAC;;AAE9B;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASC,mBAAmB,CAACC,IAAa,EAAEC,OAAgB,EAAE;EACnED,IAAI,GAAG,OAAOA,IAAI,KAAK,QAAQ,GAAGA,IAAI,GAAG,CAAC;EAC1CC,OAAO,GAAG,OAAOA,OAAO,KAAK,QAAQ,IAAIA,OAAO,GAAGA,OAAO,GAAG,eAAe;EAE5E,OAAOH,mBAAmB,CAACE,IAAI,CAAC,GAC5B,IAAIF,mBAAmB,CAACE,IAAI,CAAC,EAAE,GAC/B,IAAIE,2BAAkB,CAACF,IAAI,EAAEC,OAAO,CAAC;AAC3C;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AANA,IAOME,qBAAqB;EAAA;EAAA;EAGzB,iCAAc;IAAA;IAAA,yBACNA,qBAAqB,CAACC,IAAI,EAAE,yCAAyC;EAC7E;EAAC;AAAA,EALiCF,2BAAkB;AAAA;AAAA,8BAAhDC,qBAAqB,UACX,KAAK;AAQrBL,mBAAmB,CAACK,qBAAqB,CAACC,IAAI,CAAC,GAAGD,qBAAqB;;AAEvE;AACA;AACA;AACA;AACA;AACA;AACA;AANA,IAOME,kBAAkB;EAAA;EAAA;EAGtB,8BAAc;IAAA;IAAA,0BAEVA,kBAAkB,CAACD,IAAI,EACvB,2EAA2E;EAE/E;EAAC;AAAA,EAR8BF,2BAAkB;AAAA;AAAA,8BAA7CG,kBAAkB,UACR,KAAK;AAWrBP,mBAAmB,CAACO,kBAAkB,CAACD,IAAI,CAAC,GAAGC,kBAAkB;;AAEjE;AACA;AACA;AACA;AACA;AACA;AACA;AANA,IAOMC,0BAA0B;EAAA;EAAA;EAG9B;EACA,sCAAc;IAAA;IAAA,0BAEVA,0BAA0B,CAACF,IAAI,EAC/B,2DAA2D;EAE/D;EAAC;AAAA,EATsCF,2BAAkB;AAAA;AAAA,8BAArDI,0BAA0B,UAChB,KAAK;AAYrBR,mBAAmB,CAACQ,0BAA0B,CAACF,IAAI,CAAC,GAAGE,0BAA0B;;AAEjF;AACA;AACA;AACA;AACA;AACA;AACA;AANA,IAOMC,gBAAgB;EAAA;EAAA;EAGpB,4BAAc;IAAA;IAAA,0BACNA,gBAAgB,CAACH,IAAI,EAAE,0CAA0C;EACzE;EAAC;AAAA,EAL4BF,2BAAkB;AAAA;AAAA,8BAA3CK,gBAAgB,UACN,KAAK;AAQrBT,mBAAmB,CAACS,gBAAgB,CAACH,IAAI,CAAC,GAAGG,gBAAgB;;AAE7D;AACA;AACA;AACA;AACA;AACA;AACA;AANA,IAOMC,kBAAkB;EAAA;EAAA;EAGtB,8BAAc;IAAA;IAAA,0BACNA,kBAAkB,
|
|
1
|
+
{"version":3,"names":["WebExMeetingsErrors","createMeetingsError","code","message","WebexMeetingsError","MeetingNotActiveError","CODE","UserNotJoinedError","NoMediaEstablishedYetError","UserInLobbyError","SpaceIDDeprecatedError","IceGatheringFailed"],"sources":["webex-errors.ts"],"sourcesContent":["// The document would auto generate the doc for errors\n\n// 1) Error codes for Oauth, login, mercury should be separated out (Code range)\n// 2) Errors from the actual locus server or other server in case, we can use the same error code as locus and redirect it\n// 3) Any errors we generate from the SDK can be split into various categories\n// Parameter validation, user action, connection, media specific(They can have different range)\n\n// TODO: all the errors from the server need to be captured\n\n// add a way to log and send metrics if needed\nimport WebexMeetingsError from './webex-meetings-error';\n\nconst WebExMeetingsErrors = {};\n\n/**\n * Create a {@link WebexMeetingsError} for a given code and message.\n * @private\n * @param {number} [code] - Error code\n * @param {string} [message] - Error message\n * @returns {WebexMeetingsError}\n */\nexport function createMeetingsError(code?: number, message?: string) {\n code = typeof code === 'number' ? code : 0;\n message = typeof message === 'string' && message ? message : 'Unknown error';\n\n return WebExMeetingsErrors[code]\n ? new WebExMeetingsErrors[code]()\n : new WebexMeetingsError(code, message);\n}\n\n/**\n * @class MeetingNotActiveError\n * @classdesc Raised whenever Meeting has already ended and user tries to do a action.\n * @extends WebexMeetingsError\n * @property {number} code - 30101\n * @property {string} message - 'Meeting has already Ended or not Active'\n */\nclass MeetingNotActiveError extends WebexMeetingsError {\n static CODE = 30101;\n\n constructor() {\n super(MeetingNotActiveError.CODE, 'Meeting has already Ended or not Active');\n }\n}\n\nexport {MeetingNotActiveError};\nWebExMeetingsErrors[MeetingNotActiveError.CODE] = MeetingNotActiveError;\n\n/**\n * @class UserNotJoinedError\n * @classdesc Raised whenever the user has already left the meeting and user tries to do a action.\n * @extends WebexMeetingsError\n * @property {number} code - 30102\n * @property {string} message - 'User has already left the meeting'\n */\nclass UserNotJoinedError extends WebexMeetingsError {\n static CODE = 30102;\n\n constructor() {\n super(\n UserNotJoinedError.CODE,\n 'User currently not in meeting. Please join a meeting before adding media.'\n );\n }\n}\n\nexport {UserNotJoinedError};\nWebExMeetingsErrors[UserNotJoinedError.CODE] = UserNotJoinedError;\n\n/**\n * @class NoMediaEstablishedYetError\n * @classdesc Raised whenever the user has not established media yet.\n * @extends WebexMeetingsError\n * @property {number} code - 30103\n * @property {string} message - error message\n */\nclass NoMediaEstablishedYetError extends WebexMeetingsError {\n static CODE = 30103;\n\n // eslint-disable-next-line require-jsdoc\n constructor() {\n super(\n NoMediaEstablishedYetError.CODE,\n 'Webrtc media connection is missing, call addMedia() first'\n );\n }\n}\n\nexport {NoMediaEstablishedYetError};\nWebExMeetingsErrors[NoMediaEstablishedYetError.CODE] = NoMediaEstablishedYetError;\n\n/**\n * @class UserInLobbyError\n * @classdesc Raised whenever the user is in lobby and not joined yet.\n * @extends WebexMeetingsError\n * @property {number} code - 30104\n * @property {string} message - 'user is still in the lobby or not joined'\n */\nclass UserInLobbyError extends WebexMeetingsError {\n static CODE = 30104;\n\n constructor() {\n super(UserInLobbyError.CODE, 'user is still in the lobby or not joined');\n }\n}\n\nexport {UserInLobbyError};\nWebExMeetingsErrors[UserInLobbyError.CODE] = UserInLobbyError;\n\n/**\n * @class SpaceIDDeprecatedError\n * @classdesc Raised whenever the user passes Space ID as destination for create meeting.\n * @extends WebexMeetingsError\n * @property {number} code - 30105\n * @property {string} message - Using the space ID as a destination is no longer supported. Please refer to the [migration guide](https://github.com/webex/webex-js-sdk/wiki/Migration-guide-for-USM-meeting) to migrate to use the meeting ID or SIP address.'\n */\nclass SpaceIDDeprecatedError extends WebexMeetingsError {\n static CODE = 30105;\n\n constructor() {\n super(\n SpaceIDDeprecatedError.CODE,\n 'Using the space ID as a destination is no longer supported. Please refer to the [migration guide](https://github.com/webex/webex-js-sdk/wiki/Migration-guide-for-USM-meeting) to migrate to use the meeting ID or SIP address.'\n );\n }\n}\n\nexport {SpaceIDDeprecatedError};\nWebExMeetingsErrors[SpaceIDDeprecatedError.CODE] = SpaceIDDeprecatedError;\n\n/**\n * @class IceGatheringFailed\n * @classdesc Raised whenever ice gathering fails.\n * @extends WebexMeetingsError\n * @property {number} code - 30202\n * @property {string} message - 'user failed ice gathering check network/firewall'\n */\nclass IceGatheringFailed extends WebexMeetingsError {\n static CODE = 30202;\n\n constructor() {\n super(IceGatheringFailed.CODE, 'iceConnection: gethering ice candidate failed');\n }\n}\n\nexport {IceGatheringFailed};\nWebExMeetingsErrors[IceGatheringFailed.CODE] = IceGatheringFailed;\n"],"mappings":";;;;;;;;;;;;;;;;AAUA;AAAwD;AAAA;AAExD,IAAMA,mBAAmB,GAAG,CAAC,CAAC;;AAE9B;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASC,mBAAmB,CAACC,IAAa,EAAEC,OAAgB,EAAE;EACnED,IAAI,GAAG,OAAOA,IAAI,KAAK,QAAQ,GAAGA,IAAI,GAAG,CAAC;EAC1CC,OAAO,GAAG,OAAOA,OAAO,KAAK,QAAQ,IAAIA,OAAO,GAAGA,OAAO,GAAG,eAAe;EAE5E,OAAOH,mBAAmB,CAACE,IAAI,CAAC,GAC5B,IAAIF,mBAAmB,CAACE,IAAI,CAAC,EAAE,GAC/B,IAAIE,2BAAkB,CAACF,IAAI,EAAEC,OAAO,CAAC;AAC3C;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AANA,IAOME,qBAAqB;EAAA;EAAA;EAGzB,iCAAc;IAAA;IAAA,yBACNA,qBAAqB,CAACC,IAAI,EAAE,yCAAyC;EAC7E;EAAC;AAAA,EALiCF,2BAAkB;AAAA;AAAA,8BAAhDC,qBAAqB,UACX,KAAK;AAQrBL,mBAAmB,CAACK,qBAAqB,CAACC,IAAI,CAAC,GAAGD,qBAAqB;;AAEvE;AACA;AACA;AACA;AACA;AACA;AACA;AANA,IAOME,kBAAkB;EAAA;EAAA;EAGtB,8BAAc;IAAA;IAAA,0BAEVA,kBAAkB,CAACD,IAAI,EACvB,2EAA2E;EAE/E;EAAC;AAAA,EAR8BF,2BAAkB;AAAA;AAAA,8BAA7CG,kBAAkB,UACR,KAAK;AAWrBP,mBAAmB,CAACO,kBAAkB,CAACD,IAAI,CAAC,GAAGC,kBAAkB;;AAEjE;AACA;AACA;AACA;AACA;AACA;AACA;AANA,IAOMC,0BAA0B;EAAA;EAAA;EAG9B;EACA,sCAAc;IAAA;IAAA,0BAEVA,0BAA0B,CAACF,IAAI,EAC/B,2DAA2D;EAE/D;EAAC;AAAA,EATsCF,2BAAkB;AAAA;AAAA,8BAArDI,0BAA0B,UAChB,KAAK;AAYrBR,mBAAmB,CAACQ,0BAA0B,CAACF,IAAI,CAAC,GAAGE,0BAA0B;;AAEjF;AACA;AACA;AACA;AACA;AACA;AACA;AANA,IAOMC,gBAAgB;EAAA;EAAA;EAGpB,4BAAc;IAAA;IAAA,0BACNA,gBAAgB,CAACH,IAAI,EAAE,0CAA0C;EACzE;EAAC;AAAA,EAL4BF,2BAAkB;AAAA;AAAA,8BAA3CK,gBAAgB,UACN,KAAK;AAQrBT,mBAAmB,CAACS,gBAAgB,CAACH,IAAI,CAAC,GAAGG,gBAAgB;;AAE7D;AACA;AACA;AACA;AACA;AACA;AACA;AANA,IAOMC,sBAAsB;EAAA;EAAA;EAG1B,kCAAc;IAAA;IAAA,0BAEVA,sBAAsB,CAACJ,IAAI,EAC3B,gOAAgO;EAEpO;EAAC;AAAA,EARkCF,2BAAkB;AAAA;AAAA,8BAAjDM,sBAAsB,UACZ,KAAK;AAWrBV,mBAAmB,CAACU,sBAAsB,CAACJ,IAAI,CAAC,GAAGI,sBAAsB;;AAEzE;AACA;AACA;AACA;AACA;AACA;AACA;AANA,IAOMC,kBAAkB;EAAA;EAAA;EAGtB,8BAAc;IAAA;IAAA,0BACNA,kBAAkB,CAACL,IAAI,EAAE,+CAA+C;EAChF;EAAC;AAAA,EAL8BF,2BAAkB;AAAA;AAAA,8BAA7CO,kBAAkB,UACR,KAAK;AAQrBX,mBAAmB,CAACW,kBAAkB,CAACL,IAAI,CAAC,GAAGK,kBAAkB"}
|
package/dist/config.js
CHANGED
|
@@ -92,8 +92,8 @@ var _default = {
|
|
|
92
92
|
installedOrgID: undefined,
|
|
93
93
|
experimental: {
|
|
94
94
|
enableMediaNegotiatedEvent: false,
|
|
95
|
-
enableUnifiedMeetings:
|
|
96
|
-
enableAdhocMeetings:
|
|
95
|
+
enableUnifiedMeetings: true,
|
|
96
|
+
enableAdhocMeetings: true,
|
|
97
97
|
enableTurnDiscovery: true
|
|
98
98
|
},
|
|
99
99
|
degradationPreferences: {
|
package/dist/config.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["meetings","deviceType","WEB","mediaSettings","pstn","reconnection","enabled","autoRejoin","detection","iceReconnectionTimeout","maxRejoinAttempts","stats","enableStatsAnalyzer","autoDowngradeEnabled","interval","analyzerInterval","historyMax","videoPacketLossRatioThreshold","rttThreshold","jitterThreshold","metrics","clientName","clientType","subClientType","mqaMetricsInterval","autoSendMQA","logging","enable","verboseEvents","resolution","maxWidth","maxHeight","idealWidth","idealHeight","screenResolution","bandwidth","audio","video","startBitrate","screenFrameRate","videoShareFrameRate","aspectRatio","autoUploadLogs","enableRtx","receiveTranscription","enableExtmap","enableAutomaticLLM","installedOrgID","undefined","experimental","enableMediaNegotiatedEvent","enableUnifiedMeetings","enableAdhocMeetings","enableTurnDiscovery","degradationPreferences","maxMacroblocksLimit"],"sources":["config.ts"],"sourcesContent":["import {\n // @ts-ignore\n deviceType,\n} from '@webex/common';\n\nexport default {\n // TODO: this needs to be defaulted\n // to JS_SDK and clients set it to WEB or others\n // see https://jira-eng-gpk2.cisco.com/jira/browse/SPARK-73167\n meetings: {\n deviceType: deviceType.WEB,\n mediaSettings: {\n pstn: false,\n },\n reconnection: {\n enabled: false,\n autoRejoin: true,\n detection: true,\n // Timeout duration to wait for ICE to reconnect if a disconnect is received.\n iceReconnectionTimeout: 10000,\n // Amount of times attempting to rejoin a meeting during reconnect\n maxRejoinAttempts: 3,\n },\n stats: {\n // Enable the webrtc stats analyzer that emits quality degradation events\n enableStatsAnalyzer: true,\n // Enable the auto downgrade video quality feature\n autoDowngradeEnabled: false,\n // 1 second intervals to collect stats data\n interval: 1000,\n // we just want to analyze data every 5 sec interval\n analyzerInterval: 5000,\n // hold the last 2 minute of a calls data\n historyMax: 120,\n // Once packet loss hits this ratio, the video will downgrade\n videoPacketLossRatioThreshold: 9, // comparison of packets lost / packets received\n rttThreshold: 500, // 500 ms noticeable quality lag begins based on bandwidth of user\n jitterThreshold: 500, // 500 ms noticeable quality lag begins based on bandwidth of user\n },\n metrics: {\n // change to your client name else data will be muddled\n // you do not need a specific format, and you do not need to register it\n clientName: 'WEBEX_JS_SDK',\n // TODO: for now this line has to be whitelisted, which is problematic for third party\n clientType: 'WEBEX_SDK',\n // Stores the sub client type used when sending metrics\n subClientType: 'WEB_APP',\n // send average values MQA in 60 second intervals\n mqaMetricsInterval: 60000,\n // send to cisco internal MQA data automatically\n // we already send CA\n autoSendMQA: true,\n },\n logging: {\n enable: true,\n verboseEvents: true,\n },\n resolution: {\n maxWidth: 1280,\n maxHeight: 720,\n idealWidth: 1280,\n idealHeight: 720,\n },\n screenResolution: {\n maxWidth: 1920,\n maxHeight: 1080,\n idealWidth: 1920,\n idealHeight: 1080,\n },\n bandwidth: {\n // please note, these are the maximum bandwidth values\n // the server supports, minimums have to be tested\n audio: 64000,\n video: 4000000,\n startBitrate: 2000,\n },\n screenFrameRate: 10,\n videoShareFrameRate: 30,\n aspectRatio: 1.7695852534562213,\n // When enabled, as calls are ended, it will upload the SDK logs and correlate them\n autoUploadLogs: true,\n enableRtx: true,\n receiveTranscription: false,\n enableExtmap: false,\n enableAutomaticLLM: false,\n installedOrgID: undefined,\n experimental: {\n enableMediaNegotiatedEvent: false,\n enableUnifiedMeetings:
|
|
1
|
+
{"version":3,"names":["meetings","deviceType","WEB","mediaSettings","pstn","reconnection","enabled","autoRejoin","detection","iceReconnectionTimeout","maxRejoinAttempts","stats","enableStatsAnalyzer","autoDowngradeEnabled","interval","analyzerInterval","historyMax","videoPacketLossRatioThreshold","rttThreshold","jitterThreshold","metrics","clientName","clientType","subClientType","mqaMetricsInterval","autoSendMQA","logging","enable","verboseEvents","resolution","maxWidth","maxHeight","idealWidth","idealHeight","screenResolution","bandwidth","audio","video","startBitrate","screenFrameRate","videoShareFrameRate","aspectRatio","autoUploadLogs","enableRtx","receiveTranscription","enableExtmap","enableAutomaticLLM","installedOrgID","undefined","experimental","enableMediaNegotiatedEvent","enableUnifiedMeetings","enableAdhocMeetings","enableTurnDiscovery","degradationPreferences","maxMacroblocksLimit"],"sources":["config.ts"],"sourcesContent":["import {\n // @ts-ignore\n deviceType,\n} from '@webex/common';\n\nexport default {\n // TODO: this needs to be defaulted\n // to JS_SDK and clients set it to WEB or others\n // see https://jira-eng-gpk2.cisco.com/jira/browse/SPARK-73167\n meetings: {\n deviceType: deviceType.WEB,\n mediaSettings: {\n pstn: false,\n },\n reconnection: {\n enabled: false,\n autoRejoin: true,\n detection: true,\n // Timeout duration to wait for ICE to reconnect if a disconnect is received.\n iceReconnectionTimeout: 10000,\n // Amount of times attempting to rejoin a meeting during reconnect\n maxRejoinAttempts: 3,\n },\n stats: {\n // Enable the webrtc stats analyzer that emits quality degradation events\n enableStatsAnalyzer: true,\n // Enable the auto downgrade video quality feature\n autoDowngradeEnabled: false,\n // 1 second intervals to collect stats data\n interval: 1000,\n // we just want to analyze data every 5 sec interval\n analyzerInterval: 5000,\n // hold the last 2 minute of a calls data\n historyMax: 120,\n // Once packet loss hits this ratio, the video will downgrade\n videoPacketLossRatioThreshold: 9, // comparison of packets lost / packets received\n rttThreshold: 500, // 500 ms noticeable quality lag begins based on bandwidth of user\n jitterThreshold: 500, // 500 ms noticeable quality lag begins based on bandwidth of user\n },\n metrics: {\n // change to your client name else data will be muddled\n // you do not need a specific format, and you do not need to register it\n clientName: 'WEBEX_JS_SDK',\n // TODO: for now this line has to be whitelisted, which is problematic for third party\n clientType: 'WEBEX_SDK',\n // Stores the sub client type used when sending metrics\n subClientType: 'WEB_APP',\n // send average values MQA in 60 second intervals\n mqaMetricsInterval: 60000,\n // send to cisco internal MQA data automatically\n // we already send CA\n autoSendMQA: true,\n },\n logging: {\n enable: true,\n verboseEvents: true,\n },\n resolution: {\n maxWidth: 1280,\n maxHeight: 720,\n idealWidth: 1280,\n idealHeight: 720,\n },\n screenResolution: {\n maxWidth: 1920,\n maxHeight: 1080,\n idealWidth: 1920,\n idealHeight: 1080,\n },\n bandwidth: {\n // please note, these are the maximum bandwidth values\n // the server supports, minimums have to be tested\n audio: 64000,\n video: 4000000,\n startBitrate: 2000,\n },\n screenFrameRate: 10,\n videoShareFrameRate: 30,\n aspectRatio: 1.7695852534562213,\n // When enabled, as calls are ended, it will upload the SDK logs and correlate them\n autoUploadLogs: true,\n enableRtx: true,\n receiveTranscription: false,\n enableExtmap: false,\n enableAutomaticLLM: false,\n installedOrgID: undefined,\n experimental: {\n enableMediaNegotiatedEvent: false,\n enableUnifiedMeetings: true,\n enableAdhocMeetings: true,\n enableTurnDiscovery: true,\n },\n degradationPreferences: {\n maxMacroblocksLimit: 8192,\n },\n },\n};\n"],"mappings":";;;;;;;AAAA;AAGuB,eAER;EACb;EACA;EACA;EACAA,QAAQ,EAAE;IACRC,UAAU,EAAEA,kBAAU,CAACC,GAAG;IAC1BC,aAAa,EAAE;MACbC,IAAI,EAAE;IACR,CAAC;IACDC,YAAY,EAAE;MACZC,OAAO,EAAE,KAAK;MACdC,UAAU,EAAE,IAAI;MAChBC,SAAS,EAAE,IAAI;MACf;MACAC,sBAAsB,EAAE,KAAK;MAC7B;MACAC,iBAAiB,EAAE;IACrB,CAAC;IACDC,KAAK,EAAE;MACL;MACAC,mBAAmB,EAAE,IAAI;MACzB;MACAC,oBAAoB,EAAE,KAAK;MAC3B;MACAC,QAAQ,EAAE,IAAI;MACd;MACAC,gBAAgB,EAAE,IAAI;MACtB;MACAC,UAAU,EAAE,GAAG;MACf;MACAC,6BAA6B,EAAE,CAAC;MAAE;MAClCC,YAAY,EAAE,GAAG;MAAE;MACnBC,eAAe,EAAE,GAAG,CAAE;IACxB,CAAC;;IACDC,OAAO,EAAE;MACP;MACA;MACAC,UAAU,EAAE,cAAc;MAC1B;MACAC,UAAU,EAAE,WAAW;MACvB;MACAC,aAAa,EAAE,SAAS;MACxB;MACAC,kBAAkB,EAAE,KAAK;MACzB;MACA;MACAC,WAAW,EAAE;IACf,CAAC;IACDC,OAAO,EAAE;MACPC,MAAM,EAAE,IAAI;MACZC,aAAa,EAAE;IACjB,CAAC;IACDC,UAAU,EAAE;MACVC,QAAQ,EAAE,IAAI;MACdC,SAAS,EAAE,GAAG;MACdC,UAAU,EAAE,IAAI;MAChBC,WAAW,EAAE;IACf,CAAC;IACDC,gBAAgB,EAAE;MAChBJ,QAAQ,EAAE,IAAI;MACdC,SAAS,EAAE,IAAI;MACfC,UAAU,EAAE,IAAI;MAChBC,WAAW,EAAE;IACf,CAAC;IACDE,SAAS,EAAE;MACT;MACA;MACAC,KAAK,EAAE,KAAK;MACZC,KAAK,EAAE,OAAO;MACdC,YAAY,EAAE;IAChB,CAAC;IACDC,eAAe,EAAE,EAAE;IACnBC,mBAAmB,EAAE,EAAE;IACvBC,WAAW,EAAE,kBAAkB;IAC/B;IACAC,cAAc,EAAE,IAAI;IACpBC,SAAS,EAAE,IAAI;IACfC,oBAAoB,EAAE,KAAK;IAC3BC,YAAY,EAAE,KAAK;IACnBC,kBAAkB,EAAE,KAAK;IACzBC,cAAc,EAAEC,SAAS;IACzBC,YAAY,EAAE;MACZC,0BAA0B,EAAE,KAAK;MACjCC,qBAAqB,EAAE,IAAI;MAC3BC,mBAAmB,EAAE,IAAI;MACzBC,mBAAmB,EAAE;IACvB,CAAC;IACDC,sBAAsB,EAAE;MACtBC,mBAAmB,EAAE;IACvB;EACF;AACF,CAAC;AAAA"}
|
|
@@ -224,7 +224,7 @@ MeetingInfoUtil.generateOptions = /*#__PURE__*/function () {
|
|
|
224
224
|
_context.next = 47;
|
|
225
225
|
break;
|
|
226
226
|
case 46:
|
|
227
|
-
throw new _parameter.default('MeetingInfo is fetched with meeting link,
|
|
227
|
+
throw new _parameter.default('MeetingInfo is fetched with the meeting link, SIP URI, phone number, Hydra people ID, or a conversation URL.');
|
|
228
228
|
case 47:
|
|
229
229
|
return _context.abrupt("return", _promise.default.resolve(options));
|
|
230
230
|
case 48:
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["MeetingInfoUtil","extractDestination","destination","type","dest","_LOCUS_ID_","url","ParameterError","getParsedUrl","link","parsedUrl","parse","protocol","HTTPS_PROTOCOL","error","LoggerProxy","logger","warn","isMeetingLink","value","hostNameBool","hostname","includes","WEBEX_DOT_COM","pathNameBool","pathname","MEET","MEET_M","JOIN","isConversationUrl","webex","clusterId","internal","services","getClusterId","endsWith","CONVERSATION_SERVICE","convertLinkToSip","user","userIndex","lastIndexOf","substring","company","companyIndex","replace","WWW_DOT","isSipUri","sipString","sipUri","DIALER_REGEX","SIP_ADDRESS","exec","isPhoneNumber","phoneNumber","isValidNumber","PHONE_NUMBER","test","getHydraId","deconstructHydraId","id","cluster","UUID_REG","_ROOM_","room","_PEOPLE_","people","getSipUriFromHydraPersonId","get","then","res","emails","length","catch","err","generateOptions","from","options","hydraId","_MEETING_LINK_","_SIP_URI_","_CONVERSATION_URL_","wasHydraPerson","resolve","waitForCatalog","conversationUrl","conversation","getUrlFromClusterId","getResourceUrl","resource","LOCI","MEETINGINFO","method","HTTP_VERBS","GET","uri","_PERSONAL_ROOM_","_MEETING_ID_","encodeURIComponent","TYPE","USE_URI_LOOKUP_FALSE","PUT","btoa","getRequestParams","resourceOptions","api","requestParams","concat","ALTERNATE_REDIRECT_TRUE","body","lookupType"],"sources":["util.ts"],"sourcesContent":["import url from 'url';\n\nimport btoa from 'btoa';\nimport {\n // @ts-ignore\n deconstructHydraId,\n} from '@webex/common';\n\nimport ParameterError from '../common/errors/parameter';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport {\n _SIP_URI_,\n _PERSONAL_ROOM_,\n _MEETING_ID_,\n _CONVERSATION_URL_,\n _LOCUS_ID_,\n _MEETING_LINK_,\n _PEOPLE_,\n _ROOM_,\n HTTP_VERBS,\n USE_URI_LOOKUP_FALSE,\n TYPE,\n LOCI,\n MEETINGINFO,\n ALTERNATE_REDIRECT_TRUE,\n DIALER_REGEX,\n WEBEX_DOT_COM,\n CONVERSATION_SERVICE,\n WWW_DOT,\n JOIN,\n MEET,\n MEET_M,\n HTTPS_PROTOCOL,\n UUID_REG,\n} from '../constants';\n\nconst MeetingInfoUtil: any = {};\n\nMeetingInfoUtil.extractDestination = (destination, type) => {\n let dest = destination;\n\n if (type === _LOCUS_ID_) {\n if (!(destination && destination.url)) {\n throw new ParameterError('You cannot create a meeting by locus without a locus.url defined');\n }\n dest = destination.url;\n }\n\n return dest;\n};\n\nMeetingInfoUtil.getParsedUrl = (link) => {\n try {\n let parsedUrl = url.parse(link);\n\n if (!parsedUrl) {\n return false;\n }\n // hack for links such as <company>.webex.com/meet/<user> without a protocol\n if (!parsedUrl.protocol) {\n parsedUrl = url.parse(`${HTTPS_PROTOCOL}${link}`);\n }\n\n return parsedUrl;\n } catch (error) {\n LoggerProxy.logger.warn(\n `Meeting-info:util#getParsedUrl --> unable to parse the URL, error: ${error}`\n );\n\n return null;\n }\n};\n\n/**\n * Helper function to check if a string matches a known meeting link pattern\n * @param {String} value string to parse and see if it matches a meeting link\n * @returns {Boolean}\n */\nMeetingInfoUtil.isMeetingLink = (value: string) => {\n const parsedUrl = MeetingInfoUtil.getParsedUrl(value);\n const hostNameBool = parsedUrl.hostname && parsedUrl.hostname.includes(WEBEX_DOT_COM);\n const pathNameBool =\n parsedUrl.pathname &&\n (parsedUrl.pathname.includes(`/${MEET}`) ||\n parsedUrl.pathname.includes(`/${MEET_M}`) ||\n parsedUrl.pathname.includes(`/${JOIN}`));\n\n return hostNameBool && pathNameBool;\n};\n\nMeetingInfoUtil.isConversationUrl = (value, webex) => {\n const clusterId = webex.internal.services.getClusterId(value);\n\n if (clusterId) {\n return clusterId.endsWith(CONVERSATION_SERVICE);\n }\n\n return false;\n};\n\nMeetingInfoUtil.convertLinkToSip = (value) => {\n const parsedUrl = MeetingInfoUtil.getParsedUrl(value);\n\n if (!parsedUrl) {\n return null;\n }\n let user;\n\n if (parsedUrl.pathname) {\n const userIndex = parsedUrl.pathname.lastIndexOf('/');\n\n user = parsedUrl.pathname.substring(userIndex + 1);\n }\n if (!user) {\n return null;\n }\n let company;\n\n if (parsedUrl.hostname) {\n const companyIndex = parsedUrl.hostname.lastIndexOf(`.${WEBEX_DOT_COM}`);\n\n company = parsedUrl.hostname.substring(0, companyIndex).replace(WWW_DOT, '');\n }\n if (!company) {\n return null;\n }\n\n return `${user}@${company}.${WEBEX_DOT_COM}`;\n};\n\nMeetingInfoUtil.isSipUri = (sipString) => {\n // TODO: lets remove regex from this equation and user URI matchers and such\n // have not found a great sip uri parser library as of now\n const sipUri = DIALER_REGEX.SIP_ADDRESS.exec(sipString);\n\n return sipUri;\n};\n\nMeetingInfoUtil.isPhoneNumber = (phoneNumber) => {\n const isValidNumber = DIALER_REGEX.PHONE_NUMBER.test(phoneNumber);\n\n return isValidNumber;\n};\n\nMeetingInfoUtil.getHydraId = (destination) => {\n const {type, id, cluster} = deconstructHydraId(destination);\n\n if (id && UUID_REG.test(id)) {\n if (type === _ROOM_) {\n return {room: true, destination: id, cluster};\n }\n if (type === _PEOPLE_) {\n return {people: true, destination: id, cluster};\n }\n\n return {};\n }\n\n return {};\n};\n\nMeetingInfoUtil.getSipUriFromHydraPersonId = (destination, webex) =>\n webex.people\n .get(destination)\n .then((res) => {\n if (res.emails && res.emails.length) {\n return res.emails[0];\n }\n throw new ParameterError('Hydra Id Lookup was an invalid hydra person id.');\n })\n .catch((err) => {\n LoggerProxy.logger.error(\n `Meeting-info:util#MeetingInfoUtil.getSipUriFromHydraPersonId --> getSipUriFromHydraPersonId ${err} `\n );\n throw err;\n });\n\nMeetingInfoUtil.generateOptions = async (from) => {\n const {destination, type, webex} = from;\n\n if (type) {\n return {\n destination,\n type,\n };\n }\n const options: any = {};\n const hydraId = MeetingInfoUtil.getHydraId(destination);\n\n if (MeetingInfoUtil.isMeetingLink(destination)) {\n LoggerProxy.logger.warn(\n 'Meeting-info:util#generateOptions --> WARN, use of Meeting Link is deprecated, please use a SIP URI instead'\n );\n\n options.type = _MEETING_LINK_;\n options.destination = destination;\n } else if (MeetingInfoUtil.isSipUri(destination)) {\n options.type = _SIP_URI_;\n options.destination = destination;\n } else if (MeetingInfoUtil.isPhoneNumber(destination)) {\n options.type = _SIP_URI_;\n options.destination = destination;\n } else if (MeetingInfoUtil.isConversationUrl(destination, webex)) {\n options.type = _CONVERSATION_URL_;\n options.destination = destination;\n } else if (hydraId.people) {\n options.type = _SIP_URI_;\n\n return MeetingInfoUtil.getSipUriFromHydraPersonId(hydraId.destination, webex).then((res) => {\n options.destination = res;\n\n // Since hydra person ids require a unique case in which they are\n // entirely converted to a SIP URI, we need to set a flag for detecting\n // this type of destination.\n options.wasHydraPerson = true;\n\n return Promise.resolve(options);\n });\n } else if (hydraId.room) {\n options.type = _CONVERSATION_URL_;\n try {\n await webex.internal.services.waitForCatalog('postauth');\n\n const conversationUrl = webex.internal.conversation.getUrlFromClusterId({\n cluster: hydraId.cluster,\n id: hydraId.destination,\n });\n\n options.destination = conversationUrl;\n } catch (e) {\n LoggerProxy.logger.error(`Meeting-info:util#generateOptions --> ${e}`);\n throw e;\n }\n } else {\n throw new ParameterError(\n 'MeetingInfo is fetched with meeting link, sip uri, phone number, hydra room id, hydra people id, or a conversation url.'\n );\n }\n\n return Promise.resolve(options);\n};\n\n/**\n * Helper function to build up a correct locus url depending on the value passed\n * @param {String} type One of [SIP_URI, PERSONAL_ROOM, MEETING_ID, CONVERSATION_URL, LOCUS_ID, MEETING_LINK]\n * @param {Object} value ?? value.value\n * @returns {Object} returns an object with {resource, method}\n */\nMeetingInfoUtil.getResourceUrl = (type: string, value: any) => {\n let resource = `/${LOCI}/${MEETINGINFO}`;\n let method = HTTP_VERBS.GET;\n let uri = null;\n\n switch (type) {\n case _SIP_URI_:\n case _PERSONAL_ROOM_:\n case _MEETING_ID_:\n resource = `/${LOCI}/${MEETINGINFO}/${encodeURIComponent(\n value\n )}?${TYPE}=${type}&${USE_URI_LOOKUP_FALSE}`;\n break;\n case _CONVERSATION_URL_:\n method = HTTP_VERBS.PUT;\n break;\n case _LOCUS_ID_:\n uri = `${value}/${MEETINGINFO}`;\n method = HTTP_VERBS.PUT;\n break;\n case _MEETING_LINK_:\n resource = `$/${LOCI}/${MEETINGINFO}/${btoa(\n value\n )}?${TYPE}=${_MEETING_LINK_}&${USE_URI_LOOKUP_FALSE}`;\n break;\n default:\n }\n\n return {\n uri,\n resource,\n method,\n };\n};\n\nMeetingInfoUtil.getRequestParams = (resourceOptions, type, value, api) => {\n let requestParams: any = {\n method: resourceOptions.method,\n api,\n resource: resourceOptions.resource,\n };\n\n if (resourceOptions.method === HTTP_VERBS.GET) {\n // for handling URL redirections\n requestParams.resource = requestParams.resource.concat(`&${ALTERNATE_REDIRECT_TRUE}`);\n } else if (type !== _LOCUS_ID_) {\n // locus id check is a PUT not sure why\n requestParams.resource = requestParams.resource.concat(`?${ALTERNATE_REDIRECT_TRUE}`);\n requestParams.body = {\n value,\n lookupType: type,\n };\n } else if (type === _LOCUS_ID_) {\n requestParams = {\n method: resourceOptions.method,\n uri: resourceOptions.uri,\n };\n }\n\n return requestParams;\n};\n\nexport default MeetingInfoUtil;\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["MeetingInfoUtil","extractDestination","destination","type","dest","_LOCUS_ID_","url","ParameterError","getParsedUrl","link","parsedUrl","parse","protocol","HTTPS_PROTOCOL","error","LoggerProxy","logger","warn","isMeetingLink","value","hostNameBool","hostname","includes","WEBEX_DOT_COM","pathNameBool","pathname","MEET","MEET_M","JOIN","isConversationUrl","webex","clusterId","internal","services","getClusterId","endsWith","CONVERSATION_SERVICE","convertLinkToSip","user","userIndex","lastIndexOf","substring","company","companyIndex","replace","WWW_DOT","isSipUri","sipString","sipUri","DIALER_REGEX","SIP_ADDRESS","exec","isPhoneNumber","phoneNumber","isValidNumber","PHONE_NUMBER","test","getHydraId","deconstructHydraId","id","cluster","UUID_REG","_ROOM_","room","_PEOPLE_","people","getSipUriFromHydraPersonId","get","then","res","emails","length","catch","err","generateOptions","from","options","hydraId","_MEETING_LINK_","_SIP_URI_","_CONVERSATION_URL_","wasHydraPerson","resolve","waitForCatalog","conversationUrl","conversation","getUrlFromClusterId","getResourceUrl","resource","LOCI","MEETINGINFO","method","HTTP_VERBS","GET","uri","_PERSONAL_ROOM_","_MEETING_ID_","encodeURIComponent","TYPE","USE_URI_LOOKUP_FALSE","PUT","btoa","getRequestParams","resourceOptions","api","requestParams","concat","ALTERNATE_REDIRECT_TRUE","body","lookupType"],"sources":["util.ts"],"sourcesContent":["import url from 'url';\n\nimport btoa from 'btoa';\nimport {\n // @ts-ignore\n deconstructHydraId,\n} from '@webex/common';\n\nimport ParameterError from '../common/errors/parameter';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport {\n _SIP_URI_,\n _PERSONAL_ROOM_,\n _MEETING_ID_,\n _CONVERSATION_URL_,\n _LOCUS_ID_,\n _MEETING_LINK_,\n _PEOPLE_,\n _ROOM_,\n HTTP_VERBS,\n USE_URI_LOOKUP_FALSE,\n TYPE,\n LOCI,\n MEETINGINFO,\n ALTERNATE_REDIRECT_TRUE,\n DIALER_REGEX,\n WEBEX_DOT_COM,\n CONVERSATION_SERVICE,\n WWW_DOT,\n JOIN,\n MEET,\n MEET_M,\n HTTPS_PROTOCOL,\n UUID_REG,\n} from '../constants';\n\nconst MeetingInfoUtil: any = {};\n\nMeetingInfoUtil.extractDestination = (destination, type) => {\n let dest = destination;\n\n if (type === _LOCUS_ID_) {\n if (!(destination && destination.url)) {\n throw new ParameterError('You cannot create a meeting by locus without a locus.url defined');\n }\n dest = destination.url;\n }\n\n return dest;\n};\n\nMeetingInfoUtil.getParsedUrl = (link) => {\n try {\n let parsedUrl = url.parse(link);\n\n if (!parsedUrl) {\n return false;\n }\n // hack for links such as <company>.webex.com/meet/<user> without a protocol\n if (!parsedUrl.protocol) {\n parsedUrl = url.parse(`${HTTPS_PROTOCOL}${link}`);\n }\n\n return parsedUrl;\n } catch (error) {\n LoggerProxy.logger.warn(\n `Meeting-info:util#getParsedUrl --> unable to parse the URL, error: ${error}`\n );\n\n return null;\n }\n};\n\n/**\n * Helper function to check if a string matches a known meeting link pattern\n * @param {String} value string to parse and see if it matches a meeting link\n * @returns {Boolean}\n */\nMeetingInfoUtil.isMeetingLink = (value: string) => {\n const parsedUrl = MeetingInfoUtil.getParsedUrl(value);\n const hostNameBool = parsedUrl.hostname && parsedUrl.hostname.includes(WEBEX_DOT_COM);\n const pathNameBool =\n parsedUrl.pathname &&\n (parsedUrl.pathname.includes(`/${MEET}`) ||\n parsedUrl.pathname.includes(`/${MEET_M}`) ||\n parsedUrl.pathname.includes(`/${JOIN}`));\n\n return hostNameBool && pathNameBool;\n};\n\nMeetingInfoUtil.isConversationUrl = (value, webex) => {\n const clusterId = webex.internal.services.getClusterId(value);\n\n if (clusterId) {\n return clusterId.endsWith(CONVERSATION_SERVICE);\n }\n\n return false;\n};\n\nMeetingInfoUtil.convertLinkToSip = (value) => {\n const parsedUrl = MeetingInfoUtil.getParsedUrl(value);\n\n if (!parsedUrl) {\n return null;\n }\n let user;\n\n if (parsedUrl.pathname) {\n const userIndex = parsedUrl.pathname.lastIndexOf('/');\n\n user = parsedUrl.pathname.substring(userIndex + 1);\n }\n if (!user) {\n return null;\n }\n let company;\n\n if (parsedUrl.hostname) {\n const companyIndex = parsedUrl.hostname.lastIndexOf(`.${WEBEX_DOT_COM}`);\n\n company = parsedUrl.hostname.substring(0, companyIndex).replace(WWW_DOT, '');\n }\n if (!company) {\n return null;\n }\n\n return `${user}@${company}.${WEBEX_DOT_COM}`;\n};\n\nMeetingInfoUtil.isSipUri = (sipString) => {\n // TODO: lets remove regex from this equation and user URI matchers and such\n // have not found a great sip uri parser library as of now\n const sipUri = DIALER_REGEX.SIP_ADDRESS.exec(sipString);\n\n return sipUri;\n};\n\nMeetingInfoUtil.isPhoneNumber = (phoneNumber) => {\n const isValidNumber = DIALER_REGEX.PHONE_NUMBER.test(phoneNumber);\n\n return isValidNumber;\n};\n\nMeetingInfoUtil.getHydraId = (destination) => {\n const {type, id, cluster} = deconstructHydraId(destination);\n\n if (id && UUID_REG.test(id)) {\n if (type === _ROOM_) {\n return {room: true, destination: id, cluster};\n }\n if (type === _PEOPLE_) {\n return {people: true, destination: id, cluster};\n }\n\n return {};\n }\n\n return {};\n};\n\nMeetingInfoUtil.getSipUriFromHydraPersonId = (destination, webex) =>\n webex.people\n .get(destination)\n .then((res) => {\n if (res.emails && res.emails.length) {\n return res.emails[0];\n }\n throw new ParameterError('Hydra Id Lookup was an invalid hydra person id.');\n })\n .catch((err) => {\n LoggerProxy.logger.error(\n `Meeting-info:util#MeetingInfoUtil.getSipUriFromHydraPersonId --> getSipUriFromHydraPersonId ${err} `\n );\n throw err;\n });\n\nMeetingInfoUtil.generateOptions = async (from) => {\n const {destination, type, webex} = from;\n\n if (type) {\n return {\n destination,\n type,\n };\n }\n const options: any = {};\n const hydraId = MeetingInfoUtil.getHydraId(destination);\n\n if (MeetingInfoUtil.isMeetingLink(destination)) {\n LoggerProxy.logger.warn(\n 'Meeting-info:util#generateOptions --> WARN, use of Meeting Link is deprecated, please use a SIP URI instead'\n );\n\n options.type = _MEETING_LINK_;\n options.destination = destination;\n } else if (MeetingInfoUtil.isSipUri(destination)) {\n options.type = _SIP_URI_;\n options.destination = destination;\n } else if (MeetingInfoUtil.isPhoneNumber(destination)) {\n options.type = _SIP_URI_;\n options.destination = destination;\n } else if (MeetingInfoUtil.isConversationUrl(destination, webex)) {\n options.type = _CONVERSATION_URL_;\n options.destination = destination;\n } else if (hydraId.people) {\n options.type = _SIP_URI_;\n\n return MeetingInfoUtil.getSipUriFromHydraPersonId(hydraId.destination, webex).then((res) => {\n options.destination = res;\n\n // Since hydra person ids require a unique case in which they are\n // entirely converted to a SIP URI, we need to set a flag for detecting\n // this type of destination.\n options.wasHydraPerson = true;\n\n return Promise.resolve(options);\n });\n } else if (hydraId.room) {\n options.type = _CONVERSATION_URL_;\n try {\n await webex.internal.services.waitForCatalog('postauth');\n\n const conversationUrl = webex.internal.conversation.getUrlFromClusterId({\n cluster: hydraId.cluster,\n id: hydraId.destination,\n });\n\n options.destination = conversationUrl;\n } catch (e) {\n LoggerProxy.logger.error(`Meeting-info:util#generateOptions --> ${e}`);\n throw e;\n }\n } else {\n throw new ParameterError(\n 'MeetingInfo is fetched with the meeting link, SIP URI, phone number, Hydra people ID, or a conversation URL.'\n );\n }\n\n return Promise.resolve(options);\n};\n\n/**\n * Helper function to build up a correct locus url depending on the value passed\n * @param {String} type One of [SIP_URI, PERSONAL_ROOM, MEETING_ID, CONVERSATION_URL, LOCUS_ID, MEETING_LINK]\n * @param {Object} value ?? value.value\n * @returns {Object} returns an object with {resource, method}\n */\nMeetingInfoUtil.getResourceUrl = (type: string, value: any) => {\n let resource = `/${LOCI}/${MEETINGINFO}`;\n let method = HTTP_VERBS.GET;\n let uri = null;\n\n switch (type) {\n case _SIP_URI_:\n case _PERSONAL_ROOM_:\n case _MEETING_ID_:\n resource = `/${LOCI}/${MEETINGINFO}/${encodeURIComponent(\n value\n )}?${TYPE}=${type}&${USE_URI_LOOKUP_FALSE}`;\n break;\n case _CONVERSATION_URL_:\n method = HTTP_VERBS.PUT;\n break;\n case _LOCUS_ID_:\n uri = `${value}/${MEETINGINFO}`;\n method = HTTP_VERBS.PUT;\n break;\n case _MEETING_LINK_:\n resource = `$/${LOCI}/${MEETINGINFO}/${btoa(\n value\n )}?${TYPE}=${_MEETING_LINK_}&${USE_URI_LOOKUP_FALSE}`;\n break;\n default:\n }\n\n return {\n uri,\n resource,\n method,\n };\n};\n\nMeetingInfoUtil.getRequestParams = (resourceOptions, type, value, api) => {\n let requestParams: any = {\n method: resourceOptions.method,\n api,\n resource: resourceOptions.resource,\n };\n\n if (resourceOptions.method === HTTP_VERBS.GET) {\n // for handling URL redirections\n requestParams.resource = requestParams.resource.concat(`&${ALTERNATE_REDIRECT_TRUE}`);\n } else if (type !== _LOCUS_ID_) {\n // locus id check is a PUT not sure why\n requestParams.resource = requestParams.resource.concat(`?${ALTERNATE_REDIRECT_TRUE}`);\n requestParams.body = {\n value,\n lookupType: type,\n };\n } else if (type === _LOCUS_ID_) {\n requestParams = {\n method: resourceOptions.method,\n uri: resourceOptions.uri,\n };\n }\n\n return requestParams;\n};\n\nexport default MeetingInfoUtil;\n"],"mappings":";;;;;;;;;;;AAAA;AAEA;AACA;AAKA;AACA;AACA;AA0BA,IAAMA,eAAoB,GAAG,CAAC,CAAC;AAE/BA,eAAe,CAACC,kBAAkB,GAAG,UAACC,WAAW,EAAEC,IAAI,EAAK;EAC1D,IAAIC,IAAI,GAAGF,WAAW;EAEtB,IAAIC,IAAI,KAAKE,qBAAU,EAAE;IACvB,IAAI,EAAEH,WAAW,IAAIA,WAAW,CAACI,GAAG,CAAC,EAAE;MACrC,MAAM,IAAIC,kBAAc,CAAC,kEAAkE,CAAC;IAC9F;IACAH,IAAI,GAAGF,WAAW,CAACI,GAAG;EACxB;EAEA,OAAOF,IAAI;AACb,CAAC;AAEDJ,eAAe,CAACQ,YAAY,GAAG,UAACC,IAAI,EAAK;EACvC,IAAI;IACF,IAAIC,SAAS,GAAGJ,YAAG,CAACK,KAAK,CAACF,IAAI,CAAC;IAE/B,IAAI,CAACC,SAAS,EAAE;MACd,OAAO,KAAK;IACd;IACA;IACA,IAAI,CAACA,SAAS,CAACE,QAAQ,EAAE;MACvBF,SAAS,GAAGJ,YAAG,CAACK,KAAK,WAAIE,yBAAc,SAAGJ,IAAI,EAAG;IACnD;IAEA,OAAOC,SAAS;EAClB,CAAC,CAAC,OAAOI,KAAK,EAAE;IACdC,oBAAW,CAACC,MAAM,CAACC,IAAI,8EACiDH,KAAK,EAC5E;IAED,OAAO,IAAI;EACb;AACF,CAAC;;AAED;AACA;AACA;AACA;AACA;AACAd,eAAe,CAACkB,aAAa,GAAG,UAACC,KAAa,EAAK;EACjD,IAAMT,SAAS,GAAGV,eAAe,CAACQ,YAAY,CAACW,KAAK,CAAC;EACrD,IAAMC,YAAY,GAAGV,SAAS,CAACW,QAAQ,IAAIX,SAAS,CAACW,QAAQ,CAACC,QAAQ,CAACC,wBAAa,CAAC;EACrF,IAAMC,YAAY,GAChBd,SAAS,CAACe,QAAQ,KACjBf,SAAS,CAACe,QAAQ,CAACH,QAAQ,YAAKI,eAAI,EAAG,IACtChB,SAAS,CAACe,QAAQ,CAACH,QAAQ,YAAKK,iBAAM,EAAG,IACzCjB,SAAS,CAACe,QAAQ,CAACH,QAAQ,YAAKM,eAAI,EAAG,CAAC;EAE5C,OAAOR,YAAY,IAAII,YAAY;AACrC,CAAC;AAEDxB,eAAe,CAAC6B,iBAAiB,GAAG,UAACV,KAAK,EAAEW,KAAK,EAAK;EACpD,IAAMC,SAAS,GAAGD,KAAK,CAACE,QAAQ,CAACC,QAAQ,CAACC,YAAY,CAACf,KAAK,CAAC;EAE7D,IAAIY,SAAS,EAAE;IACb,OAAOA,SAAS,CAACI,QAAQ,CAACC,+BAAoB,CAAC;EACjD;EAEA,OAAO,KAAK;AACd,CAAC;AAEDpC,eAAe,CAACqC,gBAAgB,GAAG,UAAClB,KAAK,EAAK;EAC5C,IAAMT,SAAS,GAAGV,eAAe,CAACQ,YAAY,CAACW,KAAK,CAAC;EAErD,IAAI,CAACT,SAAS,EAAE;IACd,OAAO,IAAI;EACb;EACA,IAAI4B,IAAI;EAER,IAAI5B,SAAS,CAACe,QAAQ,EAAE;IACtB,IAAMc,SAAS,GAAG7B,SAAS,CAACe,QAAQ,CAACe,WAAW,CAAC,GAAG,CAAC;IAErDF,IAAI,GAAG5B,SAAS,CAACe,QAAQ,CAACgB,SAAS,CAACF,SAAS,GAAG,CAAC,CAAC;EACpD;EACA,IAAI,CAACD,IAAI,EAAE;IACT,OAAO,IAAI;EACb;EACA,IAAII,OAAO;EAEX,IAAIhC,SAAS,CAACW,QAAQ,EAAE;IACtB,IAAMsB,YAAY,GAAGjC,SAAS,CAACW,QAAQ,CAACmB,WAAW,YAAKjB,wBAAa,EAAG;IAExEmB,OAAO,GAAGhC,SAAS,CAACW,QAAQ,CAACoB,SAAS,CAAC,CAAC,EAAEE,YAAY,CAAC,CAACC,OAAO,CAACC,kBAAO,EAAE,EAAE,CAAC;EAC9E;EACA,IAAI,CAACH,OAAO,EAAE;IACZ,OAAO,IAAI;EACb;EAEA,iBAAUJ,IAAI,cAAII,OAAO,cAAInB,wBAAa;AAC5C,CAAC;AAEDvB,eAAe,CAAC8C,QAAQ,GAAG,UAACC,SAAS,EAAK;EACxC;EACA;EACA,IAAMC,MAAM,GAAGC,uBAAY,CAACC,WAAW,CAACC,IAAI,CAACJ,SAAS,CAAC;EAEvD,OAAOC,MAAM;AACf,CAAC;AAEDhD,eAAe,CAACoD,aAAa,GAAG,UAACC,WAAW,EAAK;EAC/C,IAAMC,aAAa,GAAGL,uBAAY,CAACM,YAAY,CAACC,IAAI,CAACH,WAAW,CAAC;EAEjE,OAAOC,aAAa;AACtB,CAAC;AAEDtD,eAAe,CAACyD,UAAU,GAAG,UAACvD,WAAW,EAAK;EAC5C,0BAA4B,IAAAwD,0BAAkB,EAACxD,WAAW,CAAC;IAApDC,IAAI,uBAAJA,IAAI;IAAEwD,EAAE,uBAAFA,EAAE;IAAEC,OAAO,uBAAPA,OAAO;EAExB,IAAID,EAAE,IAAIE,mBAAQ,CAACL,IAAI,CAACG,EAAE,CAAC,EAAE;IAC3B,IAAIxD,IAAI,KAAK2D,iBAAM,EAAE;MACnB,OAAO;QAACC,IAAI,EAAE,IAAI;QAAE7D,WAAW,EAAEyD,EAAE;QAAEC,OAAO,EAAPA;MAAO,CAAC;IAC/C;IACA,IAAIzD,IAAI,KAAK6D,mBAAQ,EAAE;MACrB,OAAO;QAACC,MAAM,EAAE,IAAI;QAAE/D,WAAW,EAAEyD,EAAE;QAAEC,OAAO,EAAPA;MAAO,CAAC;IACjD;IAEA,OAAO,CAAC,CAAC;EACX;EAEA,OAAO,CAAC,CAAC;AACX,CAAC;AAED5D,eAAe,CAACkE,0BAA0B,GAAG,UAAChE,WAAW,EAAE4B,KAAK;EAAA,OAC9DA,KAAK,CAACmC,MAAM,CACTE,GAAG,CAACjE,WAAW,CAAC,CAChBkE,IAAI,CAAC,UAACC,GAAG,EAAK;IACb,IAAIA,GAAG,CAACC,MAAM,IAAID,GAAG,CAACC,MAAM,CAACC,MAAM,EAAE;MACnC,OAAOF,GAAG,CAACC,MAAM,CAAC,CAAC,CAAC;IACtB;IACA,MAAM,IAAI/D,kBAAc,CAAC,iDAAiD,CAAC;EAC7E,CAAC,CAAC,CACDiE,KAAK,CAAC,UAACC,GAAG,EAAK;IACd1D,oBAAW,CAACC,MAAM,CAACF,KAAK,uGACyE2D,GAAG,OACnG;IACD,MAAMA,GAAG;EACX,CAAC,CAAC;AAAA;AAENzE,eAAe,CAAC0E,eAAe;EAAA,mFAAG,iBAAOC,IAAI;IAAA;IAAA;MAAA;QAAA;UACpCzE,WAAW,GAAiByE,IAAI,CAAhCzE,WAAW,EAAEC,IAAI,GAAWwE,IAAI,CAAnBxE,IAAI,EAAE2B,KAAK,GAAI6C,IAAI,CAAb7C,KAAK;UAAA,KAE3B3B,IAAI;YAAA;YAAA;UAAA;UAAA,iCACC;YACLD,WAAW,EAAXA,WAAW;YACXC,IAAI,EAAJA;UACF,CAAC;QAAA;UAEGyE,OAAY,GAAG,CAAC,CAAC;UACjBC,OAAO,GAAG7E,eAAe,CAACyD,UAAU,CAACvD,WAAW,CAAC;UAAA,KAEnDF,eAAe,CAACkB,aAAa,CAAChB,WAAW,CAAC;YAAA;YAAA;UAAA;UAC5Ca,oBAAW,CAACC,MAAM,CAACC,IAAI,CACrB,6GAA6G,CAC9G;UAED2D,OAAO,CAACzE,IAAI,GAAG2E,yBAAc;UAC7BF,OAAO,CAAC1E,WAAW,GAAGA,WAAW;UAAC;UAAA;QAAA;UAAA,KACzBF,eAAe,CAAC8C,QAAQ,CAAC5C,WAAW,CAAC;YAAA;YAAA;UAAA;UAC9C0E,OAAO,CAACzE,IAAI,GAAG4E,oBAAS;UACxBH,OAAO,CAAC1E,WAAW,GAAGA,WAAW;UAAC;UAAA;QAAA;UAAA,KACzBF,eAAe,CAACoD,aAAa,CAAClD,WAAW,CAAC;YAAA;YAAA;UAAA;UACnD0E,OAAO,CAACzE,IAAI,GAAG4E,oBAAS;UACxBH,OAAO,CAAC1E,WAAW,GAAGA,WAAW;UAAC;UAAA;QAAA;UAAA,KACzBF,eAAe,CAAC6B,iBAAiB,CAAC3B,WAAW,EAAE4B,KAAK,CAAC;YAAA;YAAA;UAAA;UAC9D8C,OAAO,CAACzE,IAAI,GAAG6E,6BAAkB;UACjCJ,OAAO,CAAC1E,WAAW,GAAGA,WAAW;UAAC;UAAA;QAAA;UAAA,KACzB2E,OAAO,CAACZ,MAAM;YAAA;YAAA;UAAA;UACvBW,OAAO,CAACzE,IAAI,GAAG4E,oBAAS;UAAC,iCAElB/E,eAAe,CAACkE,0BAA0B,CAACW,OAAO,CAAC3E,WAAW,EAAE4B,KAAK,CAAC,CAACsC,IAAI,CAAC,UAACC,GAAG,EAAK;YAC1FO,OAAO,CAAC1E,WAAW,GAAGmE,GAAG;;YAEzB;YACA;YACA;YACAO,OAAO,CAACK,cAAc,GAAG,IAAI;YAE7B,OAAO,iBAAQC,OAAO,CAACN,OAAO,CAAC;UACjC,CAAC,CAAC;QAAA;UAAA,KACOC,OAAO,CAACd,IAAI;YAAA;YAAA;UAAA;UACrBa,OAAO,CAACzE,IAAI,GAAG6E,6BAAkB;UAAC;UAAA;UAAA,OAE1BlD,KAAK,CAACE,QAAQ,CAACC,QAAQ,CAACkD,cAAc,CAAC,UAAU,CAAC;QAAA;UAElDC,eAAe,GAAGtD,KAAK,CAACE,QAAQ,CAACqD,YAAY,CAACC,mBAAmB,CAAC;YACtE1B,OAAO,EAAEiB,OAAO,CAACjB,OAAO;YACxBD,EAAE,EAAEkB,OAAO,CAAC3E;UACd,CAAC,CAAC;UAEF0E,OAAO,CAAC1E,WAAW,GAAGkF,eAAe;UAAC;UAAA;QAAA;UAAA;UAAA;UAEtCrE,oBAAW,CAACC,MAAM,CAACF,KAAK,8DAA8C;UAAC;QAAA;UAAA;UAAA;QAAA;UAAA,MAInE,IAAIP,kBAAc,CACtB,8GAA8G,CAC/G;QAAA;UAAA,iCAGI,iBAAQ2E,OAAO,CAACN,OAAO,CAAC;QAAA;QAAA;UAAA;MAAA;IAAA;EAAA,CAChC;EAAA;IAAA;EAAA;AAAA;;AAED;AACA;AACA;AACA;AACA;AACA;AACA5E,eAAe,CAACuF,cAAc,GAAG,UAACpF,IAAY,EAAEgB,KAAU,EAAK;EAC7D,IAAIqE,QAAQ,cAAOC,eAAI,cAAIC,sBAAW,CAAE;EACxC,IAAIC,MAAM,GAAGC,qBAAU,CAACC,GAAG;EAC3B,IAAIC,GAAG,GAAG,IAAI;EAEd,QAAQ3F,IAAI;IACV,KAAK4E,oBAAS;IACd,KAAKgB,0BAAe;IACpB,KAAKC,uBAAY;MACfR,QAAQ,cAAOC,eAAI,cAAIC,sBAAW,cAAIO,kBAAkB,CACtD9E,KAAK,CACN,cAAI+E,eAAI,cAAI/F,IAAI,cAAIgG,+BAAoB,CAAE;MAC3C;IACF,KAAKnB,6BAAkB;MACrBW,MAAM,GAAGC,qBAAU,CAACQ,GAAG;MACvB;IACF,KAAK/F,qBAAU;MACbyF,GAAG,aAAM3E,KAAK,cAAIuE,sBAAW,CAAE;MAC/BC,MAAM,GAAGC,qBAAU,CAACQ,GAAG;MACvB;IACF,KAAKtB,yBAAc;MACjBU,QAAQ,eAAQC,eAAI,cAAIC,sBAAW,cAAI,IAAAW,aAAI,EACzClF,KAAK,CACN,cAAI+E,eAAI,cAAIpB,yBAAc,cAAIqB,+BAAoB,CAAE;MACrD;IACF;EAAQ;EAGV,OAAO;IACLL,GAAG,EAAHA,GAAG;IACHN,QAAQ,EAARA,QAAQ;IACRG,MAAM,EAANA;EACF,CAAC;AACH,CAAC;AAED3F,eAAe,CAACsG,gBAAgB,GAAG,UAACC,eAAe,EAAEpG,IAAI,EAAEgB,KAAK,EAAEqF,GAAG,EAAK;EACxE,IAAIC,aAAkB,GAAG;IACvBd,MAAM,EAAEY,eAAe,CAACZ,MAAM;IAC9Ba,GAAG,EAAHA,GAAG;IACHhB,QAAQ,EAAEe,eAAe,CAACf;EAC5B,CAAC;EAED,IAAIe,eAAe,CAACZ,MAAM,KAAKC,qBAAU,CAACC,GAAG,EAAE;IAC7C;IACAY,aAAa,CAACjB,QAAQ,GAAGiB,aAAa,CAACjB,QAAQ,CAACkB,MAAM,YAAKC,kCAAuB,EAAG;EACvF,CAAC,MAAM,IAAIxG,IAAI,KAAKE,qBAAU,EAAE;IAC9B;IACAoG,aAAa,CAACjB,QAAQ,GAAGiB,aAAa,CAACjB,QAAQ,CAACkB,MAAM,YAAKC,kCAAuB,EAAG;IACrFF,aAAa,CAACG,IAAI,GAAG;MACnBzF,KAAK,EAALA,KAAK;MACL0F,UAAU,EAAE1G;IACd,CAAC;EACH,CAAC,MAAM,IAAIA,IAAI,KAAKE,qBAAU,EAAE;IAC9BoG,aAAa,GAAG;MACdd,MAAM,EAAEY,eAAe,CAACZ,MAAM;MAC9BG,GAAG,EAAES,eAAe,CAACT;IACvB,CAAC;EACH;EAEA,OAAOW,aAAa;AACtB,CAAC;AAAC,eAEazG,eAAe;AAAA"}
|
|
@@ -20,9 +20,11 @@ var _common = require("@webex/common");
|
|
|
20
20
|
var _constants = require("../constants");
|
|
21
21
|
var _parameter = _interopRequireDefault(require("../common/errors/parameter"));
|
|
22
22
|
var _loggerProxy = _interopRequireDefault(require("../common/logs/logger-proxy"));
|
|
23
|
+
var _webexErrors = require("../common/errors/webex-errors");
|
|
23
24
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
24
25
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
25
26
|
var MeetingInfoUtil = {};
|
|
27
|
+
var meetingInfoError = 'MeetingInfo is fetched with the meeting link, SIP URI, phone number, Hydra people ID, or a conversation URL.';
|
|
26
28
|
MeetingInfoUtil.getParsedUrl = function (link) {
|
|
27
29
|
try {
|
|
28
30
|
var parsedUrl = _url.default.parse(link);
|
|
@@ -105,7 +107,7 @@ MeetingInfoUtil.getSipUriFromHydraPersonId = function (destination, webex) {
|
|
|
105
107
|
};
|
|
106
108
|
MeetingInfoUtil.getDestinationType = /*#__PURE__*/function () {
|
|
107
109
|
var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(from) {
|
|
108
|
-
var type, webex, destination, _options, res, _res$items$, orgId, userId, options, hydraId
|
|
110
|
+
var type, webex, destination, _options, res, _res$items$, orgId, userId, options, hydraId;
|
|
109
111
|
return _regenerator.default.wrap(function _callee$(_context) {
|
|
110
112
|
while (1) switch (_context.prev = _context.next) {
|
|
111
113
|
case 0:
|
|
@@ -162,7 +164,7 @@ MeetingInfoUtil.getDestinationType = /*#__PURE__*/function () {
|
|
|
162
164
|
_loggerProxy.default.logger.warn('Meeting-info:util#generateOptions --> WARN, use of Meeting Link is deprecated, please use a SIP URI instead');
|
|
163
165
|
options.type = _constants._MEETING_LINK_;
|
|
164
166
|
options.destination = destination;
|
|
165
|
-
_context.next =
|
|
167
|
+
_context.next = 52;
|
|
166
168
|
break;
|
|
167
169
|
case 25:
|
|
168
170
|
if (!MeetingInfoUtil.isSipUri(destination)) {
|
|
@@ -171,7 +173,7 @@ MeetingInfoUtil.getDestinationType = /*#__PURE__*/function () {
|
|
|
171
173
|
}
|
|
172
174
|
options.type = _constants._SIP_URI_;
|
|
173
175
|
options.destination = destination;
|
|
174
|
-
_context.next =
|
|
176
|
+
_context.next = 52;
|
|
175
177
|
break;
|
|
176
178
|
case 30:
|
|
177
179
|
if (!MeetingInfoUtil.isPhoneNumber(destination)) {
|
|
@@ -180,7 +182,7 @@ MeetingInfoUtil.getDestinationType = /*#__PURE__*/function () {
|
|
|
180
182
|
}
|
|
181
183
|
options.type = _constants._SIP_URI_;
|
|
182
184
|
options.destination = destination;
|
|
183
|
-
_context.next =
|
|
185
|
+
_context.next = 52;
|
|
184
186
|
break;
|
|
185
187
|
case 35:
|
|
186
188
|
if (!MeetingInfoUtil.isConversationUrl(destination, webex)) {
|
|
@@ -189,7 +191,7 @@ MeetingInfoUtil.getDestinationType = /*#__PURE__*/function () {
|
|
|
189
191
|
}
|
|
190
192
|
options.type = _constants._CONVERSATION_URL_;
|
|
191
193
|
options.destination = destination;
|
|
192
|
-
_context.next =
|
|
194
|
+
_context.next = 52;
|
|
193
195
|
break;
|
|
194
196
|
case 40:
|
|
195
197
|
if (!hydraId.people) {
|
|
@@ -208,39 +210,22 @@ MeetingInfoUtil.getDestinationType = /*#__PURE__*/function () {
|
|
|
208
210
|
}));
|
|
209
211
|
case 45:
|
|
210
212
|
if (!hydraId.room) {
|
|
211
|
-
_context.next =
|
|
213
|
+
_context.next = 50;
|
|
212
214
|
break;
|
|
213
215
|
}
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
return webex.internal.services.waitForCatalog('postauth');
|
|
216
|
+
_loggerProxy.default.logger.error("Meeting-info:util#getDestinationType --> Using the space ID as a destination is no longer supported. Please refer to the [migration guide](https://github.com/webex/webex-js-sdk/wiki/Migration-guide-for-USM-meeting) to migrate to use the meeting ID or SIP address.");
|
|
217
|
+
// Error code 30105 added as Space ID deprecated as of beta, Please refer migration guide.
|
|
218
|
+
throw new _webexErrors.SpaceIDDeprecatedError();
|
|
218
219
|
case 50:
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
});
|
|
223
|
-
options.destination = conversationUrl;
|
|
224
|
-
_context.next = 58;
|
|
225
|
-
break;
|
|
226
|
-
case 54:
|
|
227
|
-
_context.prev = 54;
|
|
228
|
-
_context.t0 = _context["catch"](47);
|
|
229
|
-
_loggerProxy.default.logger.error("Meeting-info:util#getDestinationType --> ".concat(_context.t0));
|
|
230
|
-
throw _context.t0;
|
|
231
|
-
case 58:
|
|
232
|
-
_context.next = 62;
|
|
233
|
-
break;
|
|
234
|
-
case 60:
|
|
235
|
-
_loggerProxy.default.logger.warn("Meeting-info:util#getDestinationType --> ('MeetingInfo is fetched with meeting link, sip uri, phone number, hydra room id, hydra people id, or a conversation url.");
|
|
236
|
-
throw new _parameter.default('MeetingInfo is fetched with meeting link, sip uri, phone number, hydra room id, hydra people id, or a conversation url.');
|
|
237
|
-
case 62:
|
|
220
|
+
_loggerProxy.default.logger.warn("Meeting-info:util#getDestinationType --> ".concat(meetingInfoError));
|
|
221
|
+
throw new _parameter.default("".concat(meetingInfoError));
|
|
222
|
+
case 52:
|
|
238
223
|
return _context.abrupt("return", _promise.default.resolve(options));
|
|
239
|
-
case
|
|
224
|
+
case 53:
|
|
240
225
|
case "end":
|
|
241
226
|
return _context.stop();
|
|
242
227
|
}
|
|
243
|
-
}, _callee
|
|
228
|
+
}, _callee);
|
|
244
229
|
}));
|
|
245
230
|
return function (_x) {
|
|
246
231
|
return _ref.apply(this, arguments);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["MeetingInfoUtil","getParsedUrl","link","parsedUrl","url","parse","protocol","HTTPS_PROTOCOL","error","LoggerProxy","logger","warn","isMeetingLink","value","hostNameBool","hostname","includes","WEBEX_DOT_COM","pathNameBool","pathname","MEET","MEET_M","JOIN","isConversationUrl","webex","clusterId","internal","services","getClusterId","endsWith","CONVERSATION_SERVICE","isSipUri","sipString","sipUri","DIALER_REGEX","SIP_ADDRESS","exec","isPhoneNumber","phoneNumber","isValidNumber","PHONE_NUMBER","test","getHydraId","destination","deconstructHydraId","type","id","cluster","UUID_REG","_ROOM_","room","_PEOPLE_","people","getSipUriFromHydraPersonId","get","then","res","emails","length","ParameterError","catch","err","getDestinationType","from","_PERSONAL_ROOM_","userId","device","orgId","options","VALID_EMAIL_ADDRESS","email","list","items","hydraId","_MEETING_LINK_","_SIP_URI_","_CONVERSATION_URL_","wasHydraPerson","resolve","waitForCatalog","conversationUrl","conversation","getUrlFromClusterId","getRequestBody","password","captchaInfo","installedOrgID","locusId","extraParams","body","DEFAULT_MEETING_INFO_REQUEST_BODY","sipUrl","_MEETING_ID_","meetingKey","_LOCUS_ID_","info","webExMeetingId","meetingUrl","_MEETING_UUID_","meetingUUID","captchaID","captchaVerifyCode","code","getWebexSite","uri","exceptedDomains","site","match","getDirectMeetingInfoURI","preferredWebexSite","webExSite"],"sources":["utilv2.ts"],"sourcesContent":["import url from 'url';\n\nimport {\n // @ts-ignore\n deconstructHydraId,\n} from '@webex/common';\n\nimport {\n _SIP_URI_,\n _PERSONAL_ROOM_,\n _MEETING_ID_,\n _CONVERSATION_URL_,\n _LOCUS_ID_,\n _MEETING_LINK_,\n _PEOPLE_,\n _ROOM_,\n _MEETING_UUID_,\n DIALER_REGEX,\n WEBEX_DOT_COM,\n CONVERSATION_SERVICE,\n JOIN,\n MEET,\n MEET_M,\n HTTPS_PROTOCOL,\n UUID_REG,\n VALID_EMAIL_ADDRESS,\n DEFAULT_MEETING_INFO_REQUEST_BODY,\n} from '../constants';\nimport ParameterError from '../common/errors/parameter';\nimport LoggerProxy from '../common/logs/logger-proxy';\n\nconst MeetingInfoUtil: any = {};\n\nMeetingInfoUtil.getParsedUrl = (link) => {\n try {\n let parsedUrl = url.parse(link);\n\n if (!parsedUrl) {\n return false;\n }\n // hack for links such as <company>.webex.com/meet/<user> without a protocol\n if (!parsedUrl.protocol) {\n parsedUrl = url.parse(`${HTTPS_PROTOCOL}${link}`);\n }\n\n return parsedUrl;\n } catch (error) {\n LoggerProxy.logger.warn(\n `Meeting-info:util#getParsedUrl --> unable to parse the URL, error: ${error}`\n );\n\n return null;\n }\n};\n\n/**\n * Helper function to check if a string matches a known meeting link pattern\n * @param {String} value string to parse and see if it matches a meeting link\n * @returns {Boolean}\n */\nMeetingInfoUtil.isMeetingLink = (value: string) => {\n const parsedUrl = MeetingInfoUtil.getParsedUrl(value);\n const hostNameBool = parsedUrl.hostname && parsedUrl.hostname.includes(WEBEX_DOT_COM);\n const pathNameBool =\n parsedUrl.pathname &&\n (parsedUrl.pathname.includes(`/${MEET}`) ||\n parsedUrl.pathname.includes(`/${MEET_M}`) ||\n parsedUrl.pathname.includes(`/${JOIN}`));\n\n return hostNameBool && pathNameBool;\n};\n\nMeetingInfoUtil.isConversationUrl = (value, webex) => {\n const clusterId = webex.internal.services.getClusterId(value);\n\n if (clusterId) {\n return clusterId.endsWith(CONVERSATION_SERVICE);\n }\n\n return false;\n};\n\nMeetingInfoUtil.isSipUri = (sipString) => {\n // TODO: lets remove regex from this equation and user URI matchers and such\n // have not found a great sip uri parser library as of now\n const sipUri = DIALER_REGEX.SIP_ADDRESS.exec(sipString);\n\n return sipUri;\n};\n\nMeetingInfoUtil.isPhoneNumber = (phoneNumber) => {\n const isValidNumber = DIALER_REGEX.PHONE_NUMBER.test(phoneNumber);\n\n return isValidNumber;\n};\n\nMeetingInfoUtil.getHydraId = (destination) => {\n const {type, id, cluster} = deconstructHydraId(destination);\n\n if (id && UUID_REG.test(id)) {\n if (type === _ROOM_) {\n return {room: true, destination: id, cluster};\n }\n if (type === _PEOPLE_) {\n return {people: true, destination: id, cluster};\n }\n\n return {};\n }\n\n return {};\n};\n\nMeetingInfoUtil.getSipUriFromHydraPersonId = (destination, webex) =>\n webex.people\n .get(destination)\n .then((res) => {\n if (res.emails && res.emails.length) {\n return res.emails[0];\n }\n throw new ParameterError('Hydra Id Lookup was an invalid hydra person id.');\n })\n .catch((err) => {\n LoggerProxy.logger.error(\n `Meeting-info:util#MeetingInfoUtil.getSipUriFromHydraPersonId --> getSipUriFromHydraPersonId ${err} `\n );\n throw err;\n });\n\nMeetingInfoUtil.getDestinationType = async (from) => {\n const {type, webex} = from;\n let {destination} = from;\n\n if (type === _PERSONAL_ROOM_) {\n // this case checks if your type is personal room\n if (!destination) {\n // if we are not getting anything in desination we fetch org and user ids from webex instance\n destination = {\n userId: webex.internal.device.userId,\n orgId: webex.internal.device.orgId,\n };\n } else {\n const options = VALID_EMAIL_ADDRESS.test(destination)\n ? {email: destination}\n : {id: destination}; // we are assuming userId as default\n const res = await webex.people.list(options);\n\n let {orgId, id: userId} = res.items[0];\n\n userId = deconstructHydraId(userId).id;\n orgId = deconstructHydraId(orgId).id;\n destination = {userId, orgId};\n }\n }\n if (type) {\n return {\n destination,\n type,\n };\n }\n const options: any = {};\n const hydraId = MeetingInfoUtil.getHydraId(destination);\n\n if (MeetingInfoUtil.isMeetingLink(destination)) {\n LoggerProxy.logger.warn(\n 'Meeting-info:util#generateOptions --> WARN, use of Meeting Link is deprecated, please use a SIP URI instead'\n );\n\n options.type = _MEETING_LINK_;\n options.destination = destination;\n } else if (MeetingInfoUtil.isSipUri(destination)) {\n options.type = _SIP_URI_;\n options.destination = destination;\n } else if (MeetingInfoUtil.isPhoneNumber(destination)) {\n options.type = _SIP_URI_;\n options.destination = destination;\n } else if (MeetingInfoUtil.isConversationUrl(destination, webex)) {\n options.type = _CONVERSATION_URL_;\n options.destination = destination;\n } else if (hydraId.people) {\n options.type = _SIP_URI_;\n\n return MeetingInfoUtil.getSipUriFromHydraPersonId(hydraId.destination, webex).then((res) => {\n options.destination = res;\n\n // Since hydra person ids require a unique case in which they are\n // entirely converted to a SIP URI, we need to set a flag for detecting\n // this type of destination.\n options.wasHydraPerson = true;\n\n return Promise.resolve(options);\n });\n } else if (hydraId.room) {\n options.type = _CONVERSATION_URL_;\n try {\n await webex.internal.services.waitForCatalog('postauth');\n\n const conversationUrl = webex.internal.conversation.getUrlFromClusterId({\n cluster: hydraId.cluster,\n id: hydraId.destination,\n });\n\n options.destination = conversationUrl;\n } catch (e) {\n LoggerProxy.logger.error(`Meeting-info:util#getDestinationType --> ${e}`);\n throw e;\n }\n } else {\n LoggerProxy.logger.warn(\n \"Meeting-info:util#getDestinationType --> ('MeetingInfo is fetched with meeting link, sip uri, phone number, hydra room id, hydra people id, or a conversation url.\"\n );\n throw new ParameterError(\n 'MeetingInfo is fetched with meeting link, sip uri, phone number, hydra room id, hydra people id, or a conversation url.'\n );\n }\n\n return Promise.resolve(options);\n};\n\n/**\n * Helper function to build up a correct locus url depending on the value passed\n * @param {Object} options type and value to fetch meeting info\n * @param {String} options.type One of [SIP_URI, PERSONAL_ROOM, MEETING_ID, CONVERSATION_URL, LOCUS_ID, MEETING_LINK]\n * @param {String} options.installedOrgID org ID of user's machine\n * @param {Object} options.destination ?? value.value\n * @returns {Object} returns an object with {resource, method}\n */\nMeetingInfoUtil.getRequestBody = (options: {type: string; destination: object} | any) => {\n const {type, destination, password, captchaInfo, installedOrgID, locusId, extraParams} = options;\n const body: any = {\n ...DEFAULT_MEETING_INFO_REQUEST_BODY,\n ...extraParams,\n };\n\n switch (type) {\n case _SIP_URI_:\n body.sipUrl = destination;\n break;\n case _PERSONAL_ROOM_:\n body.userId = destination.userId;\n body.orgId = destination.orgId;\n break;\n case _MEETING_ID_:\n body.meetingKey = destination;\n break;\n case _CONVERSATION_URL_:\n body.conversationUrl = destination;\n break;\n case _LOCUS_ID_:\n // use meetingID for the completer meeting info for the already started meeting\n if (destination.info?.webExMeetingId) {\n body.meetingKey = destination.info.webExMeetingId;\n } else if (destination.info?.sipUri) {\n body.sipUrl = destination.info.sipUri;\n }\n break;\n case _MEETING_LINK_:\n body.meetingUrl = destination;\n break;\n case _MEETING_UUID_: {\n body.meetingUUID = destination;\n break;\n }\n default:\n }\n\n if (password) {\n body.password = password;\n }\n\n if (captchaInfo) {\n body.captchaID = captchaInfo.id;\n body.captchaVerifyCode = captchaInfo.code;\n }\n\n if (installedOrgID) {\n body.installedOrgID = installedOrgID;\n }\n\n if (locusId) {\n body.locusId = locusId;\n }\n\n return body;\n};\n\n/**\n * Helper function to parse the webex site/host from a URI string.\n * @param {String} uri string (e.g. '10019857020@convergedats.webex.com')\n * @returns {String} the site/host part of the URI string (e.g. 'convergedats.webex.com')\n */\nMeetingInfoUtil.getWebexSite = (uri: string) => {\n const exceptedDomains = ['meet.webex.com', 'meetup.webex.com', 'ciscospark.com'];\n const site = uri?.match(/.+@([^.]+\\.[^.]+\\.[^.]+)$/)?.[1];\n\n return exceptedDomains.includes(site) ? null : site;\n};\n\n/**\n * Helper function to return the direct URI for fetching meeting info (to avoid a redirect).\n * @param {Object} options type and value to fetch meeting info\n * @param {String} options.type One of [SIP_URI, PERSONAL_ROOM, MEETING_ID, CONVERSATION_URL, LOCUS_ID, MEETING_LINK]\n * @param {Object} options.destination ?? value.value\n * @returns {String} returns a URI string or null of there is no direct URI\n */\nMeetingInfoUtil.getDirectMeetingInfoURI = (options: {type: string; destination: any}) => {\n const {type, destination} = options;\n\n let preferredWebexSite = null;\n\n switch (type) {\n case _SIP_URI_:\n preferredWebexSite = MeetingInfoUtil.getWebexSite(destination);\n break;\n case _LOCUS_ID_:\n preferredWebexSite = destination.info?.webExSite;\n break;\n default:\n }\n\n return preferredWebexSite ? `https://${preferredWebexSite}/wbxappapi/v1/meetingInfo` : null;\n};\n\nexport default MeetingInfoUtil;\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["MeetingInfoUtil","meetingInfoError","getParsedUrl","link","parsedUrl","url","parse","protocol","HTTPS_PROTOCOL","error","LoggerProxy","logger","warn","isMeetingLink","value","hostNameBool","hostname","includes","WEBEX_DOT_COM","pathNameBool","pathname","MEET","MEET_M","JOIN","isConversationUrl","webex","clusterId","internal","services","getClusterId","endsWith","CONVERSATION_SERVICE","isSipUri","sipString","sipUri","DIALER_REGEX","SIP_ADDRESS","exec","isPhoneNumber","phoneNumber","isValidNumber","PHONE_NUMBER","test","getHydraId","destination","deconstructHydraId","type","id","cluster","UUID_REG","_ROOM_","room","_PEOPLE_","people","getSipUriFromHydraPersonId","get","then","res","emails","length","ParameterError","catch","err","getDestinationType","from","_PERSONAL_ROOM_","userId","device","orgId","options","VALID_EMAIL_ADDRESS","email","list","items","hydraId","_MEETING_LINK_","_SIP_URI_","_CONVERSATION_URL_","wasHydraPerson","resolve","SpaceIDDeprecatedError","getRequestBody","password","captchaInfo","installedOrgID","locusId","extraParams","body","DEFAULT_MEETING_INFO_REQUEST_BODY","sipUrl","_MEETING_ID_","meetingKey","conversationUrl","_LOCUS_ID_","info","webExMeetingId","meetingUrl","_MEETING_UUID_","meetingUUID","captchaID","captchaVerifyCode","code","getWebexSite","uri","exceptedDomains","site","match","getDirectMeetingInfoURI","preferredWebexSite","webExSite"],"sources":["utilv2.ts"],"sourcesContent":["import url from 'url';\n\nimport {\n // @ts-ignore\n deconstructHydraId,\n} from '@webex/common';\n\nimport {\n _SIP_URI_,\n _PERSONAL_ROOM_,\n _MEETING_ID_,\n _CONVERSATION_URL_,\n _LOCUS_ID_,\n _MEETING_LINK_,\n _PEOPLE_,\n _ROOM_,\n _MEETING_UUID_,\n DIALER_REGEX,\n WEBEX_DOT_COM,\n CONVERSATION_SERVICE,\n JOIN,\n MEET,\n MEET_M,\n HTTPS_PROTOCOL,\n UUID_REG,\n VALID_EMAIL_ADDRESS,\n DEFAULT_MEETING_INFO_REQUEST_BODY,\n} from '../constants';\nimport ParameterError from '../common/errors/parameter';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport {SpaceIDDeprecatedError} from '../common/errors/webex-errors';\n\nconst MeetingInfoUtil: any = {};\nconst meetingInfoError =\n 'MeetingInfo is fetched with the meeting link, SIP URI, phone number, Hydra people ID, or a conversation URL.';\n\nMeetingInfoUtil.getParsedUrl = (link) => {\n try {\n let parsedUrl = url.parse(link);\n\n if (!parsedUrl) {\n return false;\n }\n // hack for links such as <company>.webex.com/meet/<user> without a protocol\n if (!parsedUrl.protocol) {\n parsedUrl = url.parse(`${HTTPS_PROTOCOL}${link}`);\n }\n\n return parsedUrl;\n } catch (error) {\n LoggerProxy.logger.warn(\n `Meeting-info:util#getParsedUrl --> unable to parse the URL, error: ${error}`\n );\n\n return null;\n }\n};\n\n/**\n * Helper function to check if a string matches a known meeting link pattern\n * @param {String} value string to parse and see if it matches a meeting link\n * @returns {Boolean}\n */\nMeetingInfoUtil.isMeetingLink = (value: string) => {\n const parsedUrl = MeetingInfoUtil.getParsedUrl(value);\n const hostNameBool = parsedUrl.hostname && parsedUrl.hostname.includes(WEBEX_DOT_COM);\n const pathNameBool =\n parsedUrl.pathname &&\n (parsedUrl.pathname.includes(`/${MEET}`) ||\n parsedUrl.pathname.includes(`/${MEET_M}`) ||\n parsedUrl.pathname.includes(`/${JOIN}`));\n\n return hostNameBool && pathNameBool;\n};\n\nMeetingInfoUtil.isConversationUrl = (value, webex) => {\n const clusterId = webex.internal.services.getClusterId(value);\n\n if (clusterId) {\n return clusterId.endsWith(CONVERSATION_SERVICE);\n }\n\n return false;\n};\n\nMeetingInfoUtil.isSipUri = (sipString) => {\n // TODO: lets remove regex from this equation and user URI matchers and such\n // have not found a great sip uri parser library as of now\n const sipUri = DIALER_REGEX.SIP_ADDRESS.exec(sipString);\n\n return sipUri;\n};\n\nMeetingInfoUtil.isPhoneNumber = (phoneNumber) => {\n const isValidNumber = DIALER_REGEX.PHONE_NUMBER.test(phoneNumber);\n\n return isValidNumber;\n};\n\nMeetingInfoUtil.getHydraId = (destination) => {\n const {type, id, cluster} = deconstructHydraId(destination);\n\n if (id && UUID_REG.test(id)) {\n if (type === _ROOM_) {\n return {room: true, destination: id, cluster};\n }\n if (type === _PEOPLE_) {\n return {people: true, destination: id, cluster};\n }\n\n return {};\n }\n\n return {};\n};\n\nMeetingInfoUtil.getSipUriFromHydraPersonId = (destination, webex) =>\n webex.people\n .get(destination)\n .then((res) => {\n if (res.emails && res.emails.length) {\n return res.emails[0];\n }\n throw new ParameterError('Hydra Id Lookup was an invalid hydra person id.');\n })\n .catch((err) => {\n LoggerProxy.logger.error(\n `Meeting-info:util#MeetingInfoUtil.getSipUriFromHydraPersonId --> getSipUriFromHydraPersonId ${err} `\n );\n throw err;\n });\n\nMeetingInfoUtil.getDestinationType = async (from) => {\n const {type, webex} = from;\n let {destination} = from;\n\n if (type === _PERSONAL_ROOM_) {\n // this case checks if your type is personal room\n if (!destination) {\n // if we are not getting anything in desination we fetch org and user ids from webex instance\n destination = {\n userId: webex.internal.device.userId,\n orgId: webex.internal.device.orgId,\n };\n } else {\n const options = VALID_EMAIL_ADDRESS.test(destination)\n ? {email: destination}\n : {id: destination}; // we are assuming userId as default\n const res = await webex.people.list(options);\n\n let {orgId, id: userId} = res.items[0];\n\n userId = deconstructHydraId(userId).id;\n orgId = deconstructHydraId(orgId).id;\n destination = {userId, orgId};\n }\n }\n if (type) {\n return {\n destination,\n type,\n };\n }\n const options: any = {};\n const hydraId = MeetingInfoUtil.getHydraId(destination);\n\n if (MeetingInfoUtil.isMeetingLink(destination)) {\n LoggerProxy.logger.warn(\n 'Meeting-info:util#generateOptions --> WARN, use of Meeting Link is deprecated, please use a SIP URI instead'\n );\n\n options.type = _MEETING_LINK_;\n options.destination = destination;\n } else if (MeetingInfoUtil.isSipUri(destination)) {\n options.type = _SIP_URI_;\n options.destination = destination;\n } else if (MeetingInfoUtil.isPhoneNumber(destination)) {\n options.type = _SIP_URI_;\n options.destination = destination;\n } else if (MeetingInfoUtil.isConversationUrl(destination, webex)) {\n options.type = _CONVERSATION_URL_;\n options.destination = destination;\n } else if (hydraId.people) {\n options.type = _SIP_URI_;\n\n return MeetingInfoUtil.getSipUriFromHydraPersonId(hydraId.destination, webex).then((res) => {\n options.destination = res;\n\n // Since hydra person ids require a unique case in which they are\n // entirely converted to a SIP URI, we need to set a flag for detecting\n // this type of destination.\n options.wasHydraPerson = true;\n\n return Promise.resolve(options);\n });\n } else if (hydraId.room) {\n LoggerProxy.logger.error(\n `Meeting-info:util#getDestinationType --> Using the space ID as a destination is no longer supported. Please refer to the [migration guide](https://github.com/webex/webex-js-sdk/wiki/Migration-guide-for-USM-meeting) to migrate to use the meeting ID or SIP address.`\n );\n // Error code 30105 added as Space ID deprecated as of beta, Please refer migration guide.\n throw new SpaceIDDeprecatedError();\n } else {\n LoggerProxy.logger.warn(`Meeting-info:util#getDestinationType --> ${meetingInfoError}`);\n throw new ParameterError(`${meetingInfoError}`);\n }\n\n return Promise.resolve(options);\n};\n\n/**\n * Helper function to build up a correct locus url depending on the value passed\n * @param {Object} options type and value to fetch meeting info\n * @param {String} options.type One of [SIP_URI, PERSONAL_ROOM, MEETING_ID, CONVERSATION_URL, LOCUS_ID, MEETING_LINK]\n * @param {String} options.installedOrgID org ID of user's machine\n * @param {Object} options.destination ?? value.value\n * @returns {Object} returns an object with {resource, method}\n */\nMeetingInfoUtil.getRequestBody = (options: {type: string; destination: object} | any) => {\n const {type, destination, password, captchaInfo, installedOrgID, locusId, extraParams} = options;\n const body: any = {\n ...DEFAULT_MEETING_INFO_REQUEST_BODY,\n ...extraParams,\n };\n\n switch (type) {\n case _SIP_URI_:\n body.sipUrl = destination;\n break;\n case _PERSONAL_ROOM_:\n body.userId = destination.userId;\n body.orgId = destination.orgId;\n break;\n case _MEETING_ID_:\n body.meetingKey = destination;\n break;\n case _CONVERSATION_URL_:\n body.conversationUrl = destination;\n break;\n case _LOCUS_ID_:\n // use meetingID for the completer meeting info for the already started meeting\n if (destination.info?.webExMeetingId) {\n body.meetingKey = destination.info.webExMeetingId;\n } else if (destination.info?.sipUri) {\n body.sipUrl = destination.info.sipUri;\n }\n break;\n case _MEETING_LINK_:\n body.meetingUrl = destination;\n break;\n case _MEETING_UUID_: {\n body.meetingUUID = destination;\n break;\n }\n default:\n }\n\n if (password) {\n body.password = password;\n }\n\n if (captchaInfo) {\n body.captchaID = captchaInfo.id;\n body.captchaVerifyCode = captchaInfo.code;\n }\n\n if (installedOrgID) {\n body.installedOrgID = installedOrgID;\n }\n\n if (locusId) {\n body.locusId = locusId;\n }\n\n return body;\n};\n\n/**\n * Helper function to parse the webex site/host from a URI string.\n * @param {String} uri string (e.g. '10019857020@convergedats.webex.com')\n * @returns {String} the site/host part of the URI string (e.g. 'convergedats.webex.com')\n */\nMeetingInfoUtil.getWebexSite = (uri: string) => {\n const exceptedDomains = ['meet.webex.com', 'meetup.webex.com', 'ciscospark.com'];\n const site = uri?.match(/.+@([^.]+\\.[^.]+\\.[^.]+)$/)?.[1];\n\n return exceptedDomains.includes(site) ? null : site;\n};\n\n/**\n * Helper function to return the direct URI for fetching meeting info (to avoid a redirect).\n * @param {Object} options type and value to fetch meeting info\n * @param {String} options.type One of [SIP_URI, PERSONAL_ROOM, MEETING_ID, CONVERSATION_URL, LOCUS_ID, MEETING_LINK]\n * @param {Object} options.destination ?? value.value\n * @returns {String} returns a URI string or null of there is no direct URI\n */\nMeetingInfoUtil.getDirectMeetingInfoURI = (options: {type: string; destination: any}) => {\n const {type, destination} = options;\n\n let preferredWebexSite = null;\n\n switch (type) {\n case _SIP_URI_:\n preferredWebexSite = MeetingInfoUtil.getWebexSite(destination);\n break;\n case _LOCUS_ID_:\n preferredWebexSite = destination.info?.webExSite;\n break;\n default:\n }\n\n return preferredWebexSite ? `https://${preferredWebexSite}/wbxappapi/v1/meetingInfo` : null;\n};\n\nexport default MeetingInfoUtil;\n"],"mappings":";;;;;;;;;;;;;;;;;AAAA;AAEA;AAKA;AAqBA;AACA;AACA;AAAqE;AAAA;AAErE,IAAMA,eAAoB,GAAG,CAAC,CAAC;AAC/B,IAAMC,gBAAgB,GACpB,8GAA8G;AAEhHD,eAAe,CAACE,YAAY,GAAG,UAACC,IAAI,EAAK;EACvC,IAAI;IACF,IAAIC,SAAS,GAAGC,YAAG,CAACC,KAAK,CAACH,IAAI,CAAC;IAE/B,IAAI,CAACC,SAAS,EAAE;MACd,OAAO,KAAK;IACd;IACA;IACA,IAAI,CAACA,SAAS,CAACG,QAAQ,EAAE;MACvBH,SAAS,GAAGC,YAAG,CAACC,KAAK,WAAIE,yBAAc,SAAGL,IAAI,EAAG;IACnD;IAEA,OAAOC,SAAS;EAClB,CAAC,CAAC,OAAOK,KAAK,EAAE;IACdC,oBAAW,CAACC,MAAM,CAACC,IAAI,8EACiDH,KAAK,EAC5E;IAED,OAAO,IAAI;EACb;AACF,CAAC;;AAED;AACA;AACA;AACA;AACA;AACAT,eAAe,CAACa,aAAa,GAAG,UAACC,KAAa,EAAK;EACjD,IAAMV,SAAS,GAAGJ,eAAe,CAACE,YAAY,CAACY,KAAK,CAAC;EACrD,IAAMC,YAAY,GAAGX,SAAS,CAACY,QAAQ,IAAIZ,SAAS,CAACY,QAAQ,CAACC,QAAQ,CAACC,wBAAa,CAAC;EACrF,IAAMC,YAAY,GAChBf,SAAS,CAACgB,QAAQ,KACjBhB,SAAS,CAACgB,QAAQ,CAACH,QAAQ,YAAKI,eAAI,EAAG,IACtCjB,SAAS,CAACgB,QAAQ,CAACH,QAAQ,YAAKK,iBAAM,EAAG,IACzClB,SAAS,CAACgB,QAAQ,CAACH,QAAQ,YAAKM,eAAI,EAAG,CAAC;EAE5C,OAAOR,YAAY,IAAII,YAAY;AACrC,CAAC;AAEDnB,eAAe,CAACwB,iBAAiB,GAAG,UAACV,KAAK,EAAEW,KAAK,EAAK;EACpD,IAAMC,SAAS,GAAGD,KAAK,CAACE,QAAQ,CAACC,QAAQ,CAACC,YAAY,CAACf,KAAK,CAAC;EAE7D,IAAIY,SAAS,EAAE;IACb,OAAOA,SAAS,CAACI,QAAQ,CAACC,+BAAoB,CAAC;EACjD;EAEA,OAAO,KAAK;AACd,CAAC;AAED/B,eAAe,CAACgC,QAAQ,GAAG,UAACC,SAAS,EAAK;EACxC;EACA;EACA,IAAMC,MAAM,GAAGC,uBAAY,CAACC,WAAW,CAACC,IAAI,CAACJ,SAAS,CAAC;EAEvD,OAAOC,MAAM;AACf,CAAC;AAEDlC,eAAe,CAACsC,aAAa,GAAG,UAACC,WAAW,EAAK;EAC/C,IAAMC,aAAa,GAAGL,uBAAY,CAACM,YAAY,CAACC,IAAI,CAACH,WAAW,CAAC;EAEjE,OAAOC,aAAa;AACtB,CAAC;AAEDxC,eAAe,CAAC2C,UAAU,GAAG,UAACC,WAAW,EAAK;EAC5C,0BAA4B,IAAAC,0BAAkB,EAACD,WAAW,CAAC;IAApDE,IAAI,uBAAJA,IAAI;IAAEC,EAAE,uBAAFA,EAAE;IAAEC,OAAO,uBAAPA,OAAO;EAExB,IAAID,EAAE,IAAIE,mBAAQ,CAACP,IAAI,CAACK,EAAE,CAAC,EAAE;IAC3B,IAAID,IAAI,KAAKI,iBAAM,EAAE;MACnB,OAAO;QAACC,IAAI,EAAE,IAAI;QAAEP,WAAW,EAAEG,EAAE;QAAEC,OAAO,EAAPA;MAAO,CAAC;IAC/C;IACA,IAAIF,IAAI,KAAKM,mBAAQ,EAAE;MACrB,OAAO;QAACC,MAAM,EAAE,IAAI;QAAET,WAAW,EAAEG,EAAE;QAAEC,OAAO,EAAPA;MAAO,CAAC;IACjD;IAEA,OAAO,CAAC,CAAC;EACX;EAEA,OAAO,CAAC,CAAC;AACX,CAAC;AAEDhD,eAAe,CAACsD,0BAA0B,GAAG,UAACV,WAAW,EAAEnB,KAAK;EAAA,OAC9DA,KAAK,CAAC4B,MAAM,CACTE,GAAG,CAACX,WAAW,CAAC,CAChBY,IAAI,CAAC,UAACC,GAAG,EAAK;IACb,IAAIA,GAAG,CAACC,MAAM,IAAID,GAAG,CAACC,MAAM,CAACC,MAAM,EAAE;MACnC,OAAOF,GAAG,CAACC,MAAM,CAAC,CAAC,CAAC;IACtB;IACA,MAAM,IAAIE,kBAAc,CAAC,iDAAiD,CAAC;EAC7E,CAAC,CAAC,CACDC,KAAK,CAAC,UAACC,GAAG,EAAK;IACdpD,oBAAW,CAACC,MAAM,CAACF,KAAK,uGACyEqD,GAAG,OACnG;IACD,MAAMA,GAAG;EACX,CAAC,CAAC;AAAA;AAEN9D,eAAe,CAAC+D,kBAAkB;EAAA,mFAAG,iBAAOC,IAAI;IAAA;IAAA;MAAA;QAAA;UACvClB,IAAI,GAAWkB,IAAI,CAAnBlB,IAAI,EAAErB,KAAK,GAAIuC,IAAI,CAAbvC,KAAK;UACbmB,WAAW,GAAIoB,IAAI,CAAnBpB,WAAW;UAAA,MAEZE,IAAI,KAAKmB,0BAAe;YAAA;YAAA;UAAA;UAAA,IAErBrB,WAAW;YAAA;YAAA;UAAA;UACd;UACAA,WAAW,GAAG;YACZsB,MAAM,EAAEzC,KAAK,CAACE,QAAQ,CAACwC,MAAM,CAACD,MAAM;YACpCE,KAAK,EAAE3C,KAAK,CAACE,QAAQ,CAACwC,MAAM,CAACC;UAC/B,CAAC;UAAC;UAAA;QAAA;UAEIC,QAAO,GAAGC,8BAAmB,CAAC5B,IAAI,CAACE,WAAW,CAAC,GACjD;YAAC2B,KAAK,EAAE3B;UAAW,CAAC,GACpB;YAACG,EAAE,EAAEH;UAAW,CAAC,EAAE;UAAA;UAAA,OACLnB,KAAK,CAAC4B,MAAM,CAACmB,IAAI,CAACH,QAAO,CAAC;QAAA;UAAtCZ,GAAG;UAAA,cAEiBA,GAAG,CAACgB,KAAK,CAAC,CAAC,CAAC,EAAjCL,KAAK,eAALA,KAAK,EAAMF,MAAM,eAAVnB,EAAE;UAEdmB,MAAM,GAAG,IAAArB,0BAAkB,EAACqB,MAAM,CAAC,CAACnB,EAAE;UACtCqB,KAAK,GAAG,IAAAvB,0BAAkB,EAACuB,KAAK,CAAC,CAACrB,EAAE;UACpCH,WAAW,GAAG;YAACsB,MAAM,EAANA,MAAM;YAAEE,KAAK,EAALA;UAAK,CAAC;QAAC;UAAA,KAG9BtB,IAAI;YAAA;YAAA;UAAA;UAAA,iCACC;YACLF,WAAW,EAAXA,WAAW;YACXE,IAAI,EAAJA;UACF,CAAC;QAAA;UAEGuB,OAAY,GAAG,CAAC,CAAC;UACjBK,OAAO,GAAG1E,eAAe,CAAC2C,UAAU,CAACC,WAAW,CAAC;UAAA,KAEnD5C,eAAe,CAACa,aAAa,CAAC+B,WAAW,CAAC;YAAA;YAAA;UAAA;UAC5ClC,oBAAW,CAACC,MAAM,CAACC,IAAI,CACrB,6GAA6G,CAC9G;UAEDyD,OAAO,CAACvB,IAAI,GAAG6B,yBAAc;UAC7BN,OAAO,CAACzB,WAAW,GAAGA,WAAW;UAAC;UAAA;QAAA;UAAA,KACzB5C,eAAe,CAACgC,QAAQ,CAACY,WAAW,CAAC;YAAA;YAAA;UAAA;UAC9CyB,OAAO,CAACvB,IAAI,GAAG8B,oBAAS;UACxBP,OAAO,CAACzB,WAAW,GAAGA,WAAW;UAAC;UAAA;QAAA;UAAA,KACzB5C,eAAe,CAACsC,aAAa,CAACM,WAAW,CAAC;YAAA;YAAA;UAAA;UACnDyB,OAAO,CAACvB,IAAI,GAAG8B,oBAAS;UACxBP,OAAO,CAACzB,WAAW,GAAGA,WAAW;UAAC;UAAA;QAAA;UAAA,KACzB5C,eAAe,CAACwB,iBAAiB,CAACoB,WAAW,EAAEnB,KAAK,CAAC;YAAA;YAAA;UAAA;UAC9D4C,OAAO,CAACvB,IAAI,GAAG+B,6BAAkB;UACjCR,OAAO,CAACzB,WAAW,GAAGA,WAAW;UAAC;UAAA;QAAA;UAAA,KACzB8B,OAAO,CAACrB,MAAM;YAAA;YAAA;UAAA;UACvBgB,OAAO,CAACvB,IAAI,GAAG8B,oBAAS;UAAC,iCAElB5E,eAAe,CAACsD,0BAA0B,CAACoB,OAAO,CAAC9B,WAAW,EAAEnB,KAAK,CAAC,CAAC+B,IAAI,CAAC,UAACC,GAAG,EAAK;YAC1FY,OAAO,CAACzB,WAAW,GAAGa,GAAG;;YAEzB;YACA;YACA;YACAY,OAAO,CAACS,cAAc,GAAG,IAAI;YAE7B,OAAO,iBAAQC,OAAO,CAACV,OAAO,CAAC;UACjC,CAAC,CAAC;QAAA;UAAA,KACOK,OAAO,CAACvB,IAAI;YAAA;YAAA;UAAA;UACrBzC,oBAAW,CAACC,MAAM,CAACF,KAAK,2QAEvB;UACD;UAAA,MACM,IAAIuE,mCAAsB,EAAE;QAAA;UAElCtE,oBAAW,CAACC,MAAM,CAACC,IAAI,oDAA6CX,gBAAgB,EAAG;UAAC,MAClF,IAAI2D,kBAAc,WAAI3D,gBAAgB,EAAG;QAAA;UAAA,iCAG1C,iBAAQ8E,OAAO,CAACV,OAAO,CAAC;QAAA;QAAA;UAAA;MAAA;IAAA;EAAA,CAChC;EAAA;IAAA;EAAA;AAAA;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACArE,eAAe,CAACiF,cAAc,GAAG,UAACZ,OAAkD,EAAK;EAAA;EACvF,IAAOvB,IAAI,GAA8EuB,OAAO,CAAzFvB,IAAI;IAAEF,WAAW,GAAiEyB,OAAO,CAAnFzB,WAAW;IAAEsC,QAAQ,GAAuDb,OAAO,CAAtEa,QAAQ;IAAEC,WAAW,GAA0Cd,OAAO,CAA5Dc,WAAW;IAAEC,cAAc,GAA0Bf,OAAO,CAA/Ce,cAAc;IAAEC,OAAO,GAAiBhB,OAAO,CAA/BgB,OAAO;IAAEC,WAAW,GAAIjB,OAAO,CAAtBiB,WAAW;EACrF,IAAMC,IAAS,mCACVC,4CAAiC,GACjCF,WAAW,CACf;EAED,QAAQxC,IAAI;IACV,KAAK8B,oBAAS;MACZW,IAAI,CAACE,MAAM,GAAG7C,WAAW;MACzB;IACF,KAAKqB,0BAAe;MAClBsB,IAAI,CAACrB,MAAM,GAAGtB,WAAW,CAACsB,MAAM;MAChCqB,IAAI,CAACnB,KAAK,GAAGxB,WAAW,CAACwB,KAAK;MAC9B;IACF,KAAKsB,uBAAY;MACfH,IAAI,CAACI,UAAU,GAAG/C,WAAW;MAC7B;IACF,KAAKiC,6BAAkB;MACrBU,IAAI,CAACK,eAAe,GAAGhD,WAAW;MAClC;IACF,KAAKiD,qBAAU;MACb;MACA,yBAAIjD,WAAW,CAACkD,IAAI,8CAAhB,kBAAkBC,cAAc,EAAE;QACpCR,IAAI,CAACI,UAAU,GAAG/C,WAAW,CAACkD,IAAI,CAACC,cAAc;MACnD,CAAC,MAAM,0BAAInD,WAAW,CAACkD,IAAI,+CAAhB,mBAAkB5D,MAAM,EAAE;QACnCqD,IAAI,CAACE,MAAM,GAAG7C,WAAW,CAACkD,IAAI,CAAC5D,MAAM;MACvC;MACA;IACF,KAAKyC,yBAAc;MACjBY,IAAI,CAACS,UAAU,GAAGpD,WAAW;MAC7B;IACF,KAAKqD,yBAAc;MAAE;QACnBV,IAAI,CAACW,WAAW,GAAGtD,WAAW;QAC9B;MACF;IACA;EAAQ;EAGV,IAAIsC,QAAQ,EAAE;IACZK,IAAI,CAACL,QAAQ,GAAGA,QAAQ;EAC1B;EAEA,IAAIC,WAAW,EAAE;IACfI,IAAI,CAACY,SAAS,GAAGhB,WAAW,CAACpC,EAAE;IAC/BwC,IAAI,CAACa,iBAAiB,GAAGjB,WAAW,CAACkB,IAAI;EAC3C;EAEA,IAAIjB,cAAc,EAAE;IAClBG,IAAI,CAACH,cAAc,GAAGA,cAAc;EACtC;EAEA,IAAIC,OAAO,EAAE;IACXE,IAAI,CAACF,OAAO,GAAGA,OAAO;EACxB;EAEA,OAAOE,IAAI;AACb,CAAC;;AAED;AACA;AACA;AACA;AACA;AACAvF,eAAe,CAACsG,YAAY,GAAG,UAACC,GAAW,EAAK;EAAA;EAC9C,IAAMC,eAAe,GAAG,CAAC,gBAAgB,EAAE,kBAAkB,EAAE,gBAAgB,CAAC;EAChF,IAAMC,IAAI,GAAGF,GAAG,aAAHA,GAAG,qCAAHA,GAAG,CAAEG,KAAK,CAAC,2BAA2B,CAAC,+CAAvC,WAA0C,CAAC,CAAC;EAEzD,OAAOF,eAAe,CAACvF,QAAQ,CAACwF,IAAI,CAAC,GAAG,IAAI,GAAGA,IAAI;AACrD,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACAzG,eAAe,CAAC2G,uBAAuB,GAAG,UAACtC,OAAyC,EAAK;EAAA;EACvF,IAAOvB,IAAI,GAAiBuB,OAAO,CAA5BvB,IAAI;IAAEF,WAAW,GAAIyB,OAAO,CAAtBzB,WAAW;EAExB,IAAIgE,kBAAkB,GAAG,IAAI;EAE7B,QAAQ9D,IAAI;IACV,KAAK8B,oBAAS;MACZgC,kBAAkB,GAAG5G,eAAe,CAACsG,YAAY,CAAC1D,WAAW,CAAC;MAC9D;IACF,KAAKiD,qBAAU;MACbe,kBAAkB,yBAAGhE,WAAW,CAACkD,IAAI,uDAAhB,mBAAkBe,SAAS;MAChD;IACF;EAAQ;EAGV,OAAOD,kBAAkB,qBAAcA,kBAAkB,iCAA8B,IAAI;AAC7F,CAAC;AAAC,eAEa5G,eAAe;AAAA"}
|
package/dist/meetings/index.js
CHANGED
|
@@ -56,6 +56,7 @@ var _captchaError = _interopRequireDefault(require("../common/errors/captcha-err
|
|
|
56
56
|
var _collection = _interopRequireDefault(require("./collection"));
|
|
57
57
|
var _util2 = _interopRequireDefault(require("./util"));
|
|
58
58
|
var _permission = _interopRequireDefault(require("../common/errors/permission"));
|
|
59
|
+
var _webexErrors = require("../common/errors/webex-errors");
|
|
59
60
|
function _getRequireWildcardCache(nodeInterop) { if (typeof _WeakMap !== "function") return null; var cacheBabelInterop = new _WeakMap(); var cacheNodeInterop = new _WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
60
61
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = _Object$defineProperty && _Object$getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? _Object$getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { _Object$defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
61
62
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys2(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
@@ -973,7 +974,7 @@ var Meetings = /*#__PURE__*/function (_WebexPlugin) {
|
|
|
973
974
|
|
|
974
975
|
/**
|
|
975
976
|
* Create a meeting.
|
|
976
|
-
* @param {string} destination - sipURL,
|
|
977
|
+
* @param {string} destination - sipURL, phonenumber, or locus object}
|
|
977
978
|
* @param {string} [type] - the optional specified type, such as locusId
|
|
978
979
|
* @param {Boolean} useRandomDelayForInfo - whether a random delay should be added to fetching meeting info
|
|
979
980
|
* @param {Object} infoExtraParams extra parameters to be provided when fetching meeting info
|
|
@@ -999,7 +1000,10 @@ var Meetings = /*#__PURE__*/function (_WebexPlugin) {
|
|
|
999
1000
|
return this.meetingInfo.fetchInfoOptions(destination, type)
|
|
1000
1001
|
// Catch a failure to fetch info options.
|
|
1001
1002
|
.catch(function (error) {
|
|
1002
|
-
_loggerProxy.default.logger.
|
|
1003
|
+
_loggerProxy.default.logger.error("Meetings:index#create --> ERROR, unable to determine info options: ".concat(error.message));
|
|
1004
|
+
if (error instanceof _webexErrors.SpaceIDDeprecatedError) {
|
|
1005
|
+
throw new _webexErrors.SpaceIDDeprecatedError();
|
|
1006
|
+
}
|
|
1003
1007
|
}).then(function () {
|
|
1004
1008
|
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
1005
1009
|
// Normalize the destination.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["mediaLogger","MediaLogger","LoggerProxy","logger","info","log","error","warn","trace","debug","Meetings","args","MEETINGS","options","authToken","webex","credentials","supertoken","access_token","mediaHelpersModule","NoiseReductionEffect","VirtualBackgroundEffect","mediaHelpers","request","Request","parent","loggerRequest","LoggerRequest","meetingCollection","MeetingCollection","personalMeetingRoom","reachability","Reachability","registered","preferredWebexSite","media","getUserMedia","Media","onReady","meeting","newLocus","breakoutUrl","controls","breakout","url","breakoutLocus","getActiveBreakoutLocus","isSelfJoined","self","state","_JOINED_","isSelfMoved","_LEFT_","reason","_MOVED_","deviceFromNewLocus","MeetingsUtil","getThisDevice","internal","device","isResourceMovedOnThisDevice","isNewLocusJoinThisDevice","joinedOnThisDevice","isBreakoutLocusJoinThisDevice","joinedWith","correlationId","breakoutReplaceAt","replaces","length","replaceAt","newLocusReplaceAt","removed","isNewLocusAsBreakout","isBreakoutLocusDTO","fullState","active","isNeedHandleMainLocus","data","getByKey","LOCUS_URL","locusUrl","CORRELATION_ID","checkForCorrelationId","locus","SIP_URI","callbackInfo","callbackAddress","isUnifiedSpaceMeeting","undefined","CONVERSATION_URL","conversationUrl","MEETINGNUMBER","webExMeetingId","useRandomDelayForInfo","getCorrespondingMeetingByLocus","locusInfo","updateMainSessionLocusCache","isNeedHandleLocusDTO","LOCUS","STATE","INACTIVE","create","_LOCUS_ID_","then","newMeeting","initialSetup","checkHandleBreakoutLocus","catch","e","finally","getMeetingByType","_ID_","id","newMetrics","submitClientEvent","name","payload","trigger","meetingId","Trigger","file","function","EVENT_TRIGGERS","MEETING_ADDED","type","_MEETING_","_JOIN_","_INCOMING_","parse","envelope","eventType","LOCUSEVENT","MESSAGE_ROAP","handleLocusEvent","MEETINGS_NETWORK_DISCONNECTED","mercury","on","LOCUS_MERCURY","handleLocusMercury","ROAP","ROAP_MERCURY","handleRoapMercury","ONLINE","syncMeetings","OFFLINE","handleMercuryOffline","off","once","READY","StaticConfig","set","config","LoggerConfig","logging","setLogger","meetingInfo","experimental","enableUnifiedMeetings","MeetingInfoV2","MeetingInfo","PersonalMeetingRoom","MEETINGS_READY","checkH264Support","disableNotifications","Metrics","changeState","enable","enableTurnDiscovery","enableAdhocMeetings","canAuthorize","reject","Error","resolve","all","fetchUserPreferredWebexSite","getGeoHint","startReachability","message","register","connect","call","listenForEvents","MEETINGS_REGISTERED","sendBehavioralMetric","BEHAVIORAL_METRICS","MEETINGS_REGISTRATION_SUCCESS","MEETINGS_REGISTRATION_FAILED","stack","stopListeningForEvents","disconnect","unregister","MEETINGS_UNREGISTERED","uploadLogs","uploadResult","MEETING_LOG_UPLOAD_SUCCESS","details","uploadError","MEETING_LOG_UPLOAD_FAILURE","UPLOAD_LOGS_FAILURE","meetingsId","code","getReachability","gatherReachability","fetchGeoHint","res","geoHintInfo","getMeetingPreferences","parseDefaultSiteFromMeetingPreferences","user","get","userPreferences","userPreferencesItems","preferredWebExSite","MeetingUtil","cleanUp","delete","MEETING_REMOVED","destination","infoExtraParams","fetchInfoOptions","targetDest","_CONVERSATION_URL_","foundMeeting","foundMeetingIsNotCalendarMeeting","scheduledMeeting","createMeeting","createdMeeting","EVENTS","DESTROY_MEETING","autoUploadLogs","callStart","lastActive","feedbackId","locusId","destroy","REQUEST_UPLOAD_LOGS","meetingInstance","Meeting","userId","deviceUrl","orgId","meetingInfoProvider","destinationType","waitingTime","startTime","startTimeDate","Date","startTimeDatestamp","getTime","timeToStart","maxWaitingTime","Math","max","min","MAX_RANDOM_DELAY_FOR_MEETING_INFO","round","random","isMeetingActive","fetchMeetingInfoTimeoutId","setTimeout","fetchMeetingInfo","extraParams","parseMeetingInfo","CaptchaError","PasswordError","PermissionError","sipUri","setSipUri","meetingAddedType","getMeetingAddedType","value","getAll","getActiveMeetings","locusArray","activeLocusUrl","loci","lociToUpdate","sortLocusArrayToUpdate","forEach","push","meetingsCollection","includes","MEETING_REMOVED_REASON","NO_MEETINGS_TO_SYNC","mainLoci","filter","breakoutLoci","isValidBreakoutLocus","breakoutLocusForHandleLater","associateMainLocus","find","mainLocus","existCorrespondingMeeting","newCreatedLocus","existIndex","findIndex","associateBreakoutLocus","splice","scheduled","WebexPlugin"],"sources":["index.ts"],"sourcesContent":["/* eslint no-shadow: [\"error\", { \"allow\": [\"eventType\"] }] */\n\nimport '@webex/internal-plugin-mercury';\nimport '@webex/internal-plugin-conversation';\nimport '@webex/internal-plugin-metrics';\n// @ts-ignore\nimport {WebexPlugin} from '@webex/webex-core';\nimport {setLogger} from '@webex/internal-media-core';\n\nimport * as mediaHelpersModule from '@webex/media-helpers';\n\nimport 'webrtc-adapter';\n\nimport Metrics from '../metrics';\nimport LoggerConfig from '../common/logs/logger-config';\nimport StaticConfig from '../common/config';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport LoggerRequest from '../common/logs/request';\nimport Trigger from '../common/events/trigger-proxy';\nimport Media from '../media';\nimport MeetingUtil from '../meeting/util';\nimport {\n MEETINGS,\n EVENTS,\n EVENT_TRIGGERS,\n READY,\n LOCUSEVENT,\n LOCUS_URL,\n MAX_RANDOM_DELAY_FOR_MEETING_INFO,\n ROAP,\n ONLINE,\n OFFLINE,\n _MEETING_,\n _JOIN_,\n _LOCUS_ID_,\n _INCOMING_,\n LOCUS,\n CORRELATION_ID,\n SIP_URI,\n _LEFT_,\n _ID_,\n MEETING_REMOVED_REASON,\n _CONVERSATION_URL_,\n CONVERSATION_URL,\n MEETINGNUMBER,\n _JOINED_,\n _MOVED_,\n} from '../constants';\nimport BEHAVIORAL_METRICS from '../metrics/constants';\nimport MeetingInfo from '../meeting-info';\nimport MeetingInfoV2 from '../meeting-info/meeting-info-v2';\nimport Meeting from '../meeting';\nimport PersonalMeetingRoom from '../personal-meeting-room';\nimport Reachability from '../reachability';\nimport Request from './request';\nimport PasswordError from '../common/errors/password-error';\nimport CaptchaError from '../common/errors/captcha-error';\n\nimport MeetingCollection from './collection';\nimport MeetingsUtil from './util';\nimport PermissionError from '../common/errors/permission';\nimport {INoiseReductionEffect, IVirtualBackgroundEffect} from './meetings.types';\n\nlet mediaLogger;\n\nclass MediaLogger {\n info(...args) {\n LoggerProxy.logger.info(...args);\n }\n\n log(...args) {\n LoggerProxy.logger.log(...args);\n }\n\n error(...args) {\n LoggerProxy.logger.error(...args);\n }\n\n warn(...args) {\n LoggerProxy.logger.warn(...args);\n }\n\n trace(...args) {\n LoggerProxy.logger.trace(...args);\n }\n\n debug(...args) {\n LoggerProxy.logger.debug(...args);\n }\n}\n/**\n * Meetings Ready Event\n * Emitted when the meetings instance on webex is ready\n * @event meetings:ready\n * @instance\n * @memberof Meetings\n */\n\n/**\n * Meetings Network Disconnected Event\n * Emitted when the meetings instance is disconnected from\n * the internal mercury server\n * @event network:disconnected\n * @instance\n * @memberof Meetings\n */\n\n/**\n * Meetings Registered Event\n * Emitted when the meetings instance has been registered and listening\n * @event meetings:registered\n * @instance\n * @memberof Meetings\n */\n\n/**\n * Meeting Removed Event\n * Emitted when a meeting was removed from the cache of meetings\n * @event meeting:removed\n * @instance\n * @type {Object}\n * @property {String} meetingId the removed meeting\n * @property {Object} response the server response\n * @property {String} type what type of meeting it was\n * @memberof Meetings\n */\n\n/**\n * Meeting Added Event\n * Emitted when a meeting was added to the cache of meetings\n * @event meeting:added\n * @instance\n * @type {Object}\n * @property {String} meetingId the added meeting\n * @property {String} type what type of meeting it was\n * @memberof Meetings\n */\n\n/**\n * Maintain a cache of meetings and sync with services.\n * @class\n */\nexport default class Meetings extends WebexPlugin {\n loggerRequest: any;\n media: any;\n meetingCollection: any;\n personalMeetingRoom: any;\n preferredWebexSite: any;\n reachability: Reachability;\n registered: any;\n request: any;\n geoHintInfo: any;\n meetingInfo: any;\n mediaHelpers: any;\n breakoutLocusForHandleLater: any;\n namespace = MEETINGS;\n\n /**\n * Initializes the Meetings Plugin\n * @constructor\n * @public\n * @memberof Meetings\n */\n constructor(...args) {\n super(...args);\n\n /**\n * The webrtc-core media helpers. This is a temporary solution required for the SDK sample app\n * to be able to call media helper functions.\n *\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n this.mediaHelpers = mediaHelpersModule;\n\n /**\n * The Meetings request to interact with server\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.request = new Request({}, {parent: this.webex});\n /**\n * Log upload request helper\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.loggerRequest = new LoggerRequest({webex: this.webex});\n this.meetingCollection = new MeetingCollection();\n /**\n * The PersonalMeetingRoom object to interact with server\n * @instance\n * @type {Object}\n * @public\n * @memberof Meetings\n */\n this.personalMeetingRoom = null;\n\n /**\n * The Reachability object to interact with server\n * starts as null\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.reachability = new Reachability(this.webex);\n\n /**\n * If the meetings plugin has been registered and listening via {@link Meetings#register}\n * @instance\n * @type {Boolean}\n * @public\n * @memberof Meetings\n */\n this.registered = false;\n\n /**\n * This values indicates the preferred webex site the user will start there meeting, getsits value from {@link Meetings#register}\n * @instance\n * @type {String}\n * @private\n * @memberof Meetings\n */\n this.preferredWebexSite = '';\n\n /**\n * The public interface for the internal Media util files. These are helpful to expose outside the context\n * of a meeting so that a user can access media without creating a meeting instance.\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n this.media = {\n getUserMedia: Media.getUserMedia,\n };\n\n this.onReady();\n }\n\n /**\n * check whether you need to handle this main session's locus data or not\n * @param {Object} meeting current meeting data\n * @param {Object} newLocus new locus data\n * @returns {boolean}\n * @private\n * @memberof Meetings\n */\n private isNeedHandleMainLocus(meeting: any, newLocus: any) {\n const breakoutUrl = newLocus.controls?.breakout?.url;\n const breakoutLocus = this.meetingCollection.getActiveBreakoutLocus(breakoutUrl);\n\n const isSelfJoined = newLocus?.self?.state === _JOINED_;\n const isSelfMoved = newLocus?.self?.state === _LEFT_ && newLocus?.self?.reason === _MOVED_;\n // @ts-ignore\n const deviceFromNewLocus = MeetingsUtil.getThisDevice(newLocus, this.webex.internal.device.url);\n const isResourceMovedOnThisDevice =\n deviceFromNewLocus?.state === _LEFT_ && deviceFromNewLocus?.reason === _MOVED_;\n\n const isNewLocusJoinThisDevice = MeetingsUtil.joinedOnThisDevice(\n meeting,\n newLocus,\n // @ts-ignore\n this.webex.internal.device.url\n );\n const isBreakoutLocusJoinThisDevice =\n breakoutLocus?.joinedWith?.correlationId &&\n breakoutLocus.joinedWith.correlationId === meeting?.correlationId;\n\n if (isSelfJoined && isNewLocusJoinThisDevice) {\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> self this device shown as JOINED in the main session'\n );\n if (breakoutLocus?.joinedWith && deviceFromNewLocus) {\n const breakoutReplaceAt =\n breakoutLocus.joinedWith.replaces?.length > 0\n ? breakoutLocus.joinedWith.replaces[0].replaceAt\n : '';\n const newLocusReplaceAt =\n deviceFromNewLocus.replaces?.length > 0 ? deviceFromNewLocus.replaces[0].replaceAt : '';\n if (breakoutReplaceAt && newLocusReplaceAt && breakoutReplaceAt > newLocusReplaceAt) {\n LoggerProxy.logger.log(\n `Meetings:index#isNeedHandleMainLocus --> this is expired main joined status locus_dto replacedAt ${newLocusReplaceAt} bo replacedAt ${breakoutReplaceAt}`\n );\n\n return false;\n }\n }\n\n return true;\n }\n if (isBreakoutLocusJoinThisDevice) {\n LoggerProxy.logger.log(\n `Meetings:index#isNeedHandleMainLocus --> there is active breakout session and joined on this device, and don't need to handle main session: ${breakoutUrl}`\n );\n\n return false;\n }\n if (isSelfMoved && (newLocus?.self?.removed || isResourceMovedOnThisDevice)) {\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> self moved main locus with self removed status or with device resource moved, not need to handle'\n );\n\n return false;\n }\n if (isSelfJoined && isResourceMovedOnThisDevice) {\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> self device left&moved in main locus with self joined status, not need to handle'\n );\n\n return false;\n }\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> this is a normal main session locusDTO update case'\n );\n\n return true;\n }\n\n /**\n * check whether you need to handle this locus data or not\n * @param {Object} meeting old locus data\n * @param {Object} newLocus new locus data\n * @returns {boolean}\n * @private\n * @memberof Meetings\n */\n private isNeedHandleLocusDTO(meeting: any, newLocus: any) {\n if (newLocus) {\n const isNewLocusAsBreakout = MeetingsUtil.isBreakoutLocusDTO(newLocus);\n const isSelfMoved = newLocus?.self?.state === _LEFT_ && newLocus?.self?.reason === _MOVED_;\n if (!meeting) {\n if (isNewLocusAsBreakout) {\n LoggerProxy.logger.log(\n `Meetings:index#isNeedHandleLocusDTO --> the first breakout session locusDTO active status: ${newLocus.fullState?.active}`\n );\n\n return newLocus.self?.state === _JOINED_;\n }\n\n return this.isNeedHandleMainLocus(meeting, newLocus);\n }\n if (!isNewLocusAsBreakout) {\n return this.isNeedHandleMainLocus(meeting, newLocus);\n }\n\n return !isSelfMoved;\n }\n\n return true;\n }\n\n /**\n * get corresponding meeting object by locus data\n * @param {Object} data a locus event\n * @param {String} data.locusUrl\n * @param {Object} data.locus\n * @returns {Object}\n * @private\n * @memberof Meetings\n */\n getCorrespondingMeetingByLocus(data) {\n // getting meeting by correlationId. This will happen for the new event\n // Either the locus\n // TODO : Add check for the callBack Address\n return (\n this.meetingCollection.getByKey(LOCUS_URL, data.locusUrl) ||\n // @ts-ignore\n this.meetingCollection.getByKey(\n CORRELATION_ID,\n // @ts-ignore\n MeetingsUtil.checkForCorrelationId(this.webex.internal.device.url, data.locus)\n ) ||\n this.meetingCollection.getByKey(\n SIP_URI,\n data.locus.self &&\n data.locus.self.callbackInfo &&\n data.locus.self.callbackInfo.callbackAddress\n ) ||\n (data.locus.info?.isUnifiedSpaceMeeting\n ? undefined\n : this.meetingCollection.getByKey(CONVERSATION_URL, data.locus.conversationUrl)) ||\n this.meetingCollection.getByKey(MEETINGNUMBER, data.locus?.info?.webExMeetingId)\n );\n }\n\n /**\n * handle locus events and takes meeting actions with them as they come in\n * @param {Object} data a locus event\n * @param {String} data.locusUrl\n * @param {Object} data.locus\n * @param {Boolean} useRandomDelayForInfo whether a random delay should be added to fetching meeting info\n * @param {String} data.eventType\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private handleLocusEvent(data: {locusUrl: string; locus: any}, useRandomDelayForInfo = false) {\n let meeting = this.getCorrespondingMeetingByLocus(data);\n\n // Special case when locus has got replaced, This only happend once if a replace locus exists\n // https://sqbu-github.cisco.com/WebExSquared/locus/wiki/Locus-changing-mid-call\n\n if (!meeting && data.locus?.replaces?.length > 0) {\n // Always the last element in the replace is the active one\n meeting = this.meetingCollection.getByKey(\n LOCUS_URL,\n data.locus.replaces[data.locus.replaces.length - 1].locusUrl\n );\n }\n\n if (meeting && !MeetingsUtil.isBreakoutLocusDTO(data.locus)) {\n meeting.locusInfo.updateMainSessionLocusCache(data.locus);\n }\n if (!this.isNeedHandleLocusDTO(meeting, data.locus)) {\n LoggerProxy.logger.log(\n `Meetings:index#handleLocusEvent --> doesn't need to process locus event`\n );\n\n return;\n }\n if (!meeting) {\n // TODO: create meeting when we get a meeting object\n // const checkForEnded = (locus) => {\n // TODO: you already ended the meeting but you got an event later\n // Mainly for 1:1 Callsor meeting\n // Happens mainly after refresh\n\n // 1:1 Meeting\n // 1) You ended a call before but you got a mercury event\n // Make sure end the call and cleanup the meeting only if the mercury\n // event says so\n // 2) Maintain lastSync time in the meetings object which helps to compare\n // If the meeting came befor or after the sync . ANy meeting start time before the sync time is invalid\n\n // For space Meeting\n // Check the locus object and see who has joined\n\n // };\n // rather then locus object change to locus url\n\n if (\n data.locus &&\n data.locus.fullState &&\n data.locus.fullState.state === LOCUS.STATE.INACTIVE\n ) {\n // just ignore the event as its already ended and not active\n LoggerProxy.logger.warn(\n 'Meetings:index#handleLocusEvent --> Locus event received for meeting, after it was ended.'\n );\n\n return;\n }\n\n // When its wireless share or guest and user leaves the meeting we dont have to keep the meeting object\n // Any future events will be neglected\n\n if (\n data.locus &&\n data.locus.self &&\n data.locus.self.state === _LEFT_ &&\n data.locus.self.removed === true\n ) {\n // just ignore the event as its already ended and not active\n LoggerProxy.logger.warn(\n 'Meetings:index#handleLocusEvent --> Locus event received for meeting, after it was ended.'\n );\n\n return;\n }\n\n this.create(data.locus, _LOCUS_ID_, useRandomDelayForInfo)\n .then((newMeeting) => {\n meeting = newMeeting;\n\n // It's a new meeting so initialize the locus data\n meeting.locusInfo.initialSetup(data.locus);\n this.checkHandleBreakoutLocus(data.locus);\n })\n .catch((e) => {\n LoggerProxy.logger.error(e);\n })\n .finally(() => {\n // There will be cases where locus event comes in gets created and deleted because its a 1:1 and meeting gets deleted\n // because the other user left so before sending 'added' event make sure it exists in the collection\n\n if (this.getMeetingByType(_ID_, meeting.id)) {\n // @ts-ignore\n this.webex.internal.newMetrics.submitClientEvent({\n name: 'client.call.remote-started',\n payload: {\n trigger: 'mercury-event',\n },\n options: {\n meetingId: meeting.id,\n },\n });\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'handleLocusEvent',\n },\n EVENT_TRIGGERS.MEETING_ADDED,\n {\n meeting,\n type: meeting.type === _MEETING_ ? _JOIN_ : _INCOMING_,\n }\n );\n } else {\n // Meeting got added but was not found in the collection. It might have got destroyed\n LoggerProxy.logger.warn(\n 'Meetings:index#handleLocusEvent --> Created and destroyed meeting object before sending an event'\n );\n }\n });\n } else {\n meeting.locusInfo.parse(meeting, data);\n }\n }\n\n /**\n * handles locus events through mercury that are not roap\n * @param {Object} envelope\n * @param {Object} envelope.data\n * @param {String} envelope.data.eventType\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private handleLocusMercury(envelope: {data: any}) {\n const {data} = envelope;\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const {eventType} = data;\n\n if (eventType && eventType !== LOCUSEVENT.MESSAGE_ROAP) {\n this.handleLocusEvent(data, true);\n }\n }\n\n /**\n * handles mecury offline event\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private handleMercuryOffline() {\n Trigger.trigger(\n this,\n {\n file: 'meetings/index',\n function: 'handleMercuryOffline',\n },\n EVENT_TRIGGERS.MEETINGS_NETWORK_DISCONNECTED\n );\n }\n\n /**\n * registers for locus and roap mercury events\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private listenForEvents() {\n // @ts-ignore\n this.webex.internal.mercury.on(LOCUSEVENT.LOCUS_MERCURY, (envelope) => {\n this.handleLocusMercury(envelope);\n });\n // @ts-ignore\n this.webex.internal.mercury.on(ROAP.ROAP_MERCURY, (envelope) => {\n MeetingsUtil.handleRoapMercury(envelope, this.meetingCollection);\n });\n\n // @ts-ignore\n this.webex.internal.mercury.on(ONLINE, () => {\n this.syncMeetings();\n });\n\n // @ts-ignore\n this.webex.internal.mercury.on(OFFLINE, () => {\n this.handleMercuryOffline();\n });\n }\n\n /**\n * stops listening for locus and roap mercury events\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private stopListeningForEvents() {\n // @ts-ignore\n this.webex.internal.mercury.off(LOCUSEVENT.LOCUS_MERCURY);\n // @ts-ignore\n this.webex.internal.mercury.off(ROAP.ROAP_MERCURY);\n // @ts-ignore\n this.webex.internal.mercury.off(ONLINE);\n }\n\n /**\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private onReady() {\n // @ts-ignore\n this.webex.once(READY, () => {\n // @ts-ignore\n StaticConfig.set(this.config);\n // @ts-ignore\n LoggerConfig.set(this.config.logging);\n // @ts-ignore\n LoggerProxy.set(this.webex.logger);\n\n mediaLogger = new MediaLogger();\n setLogger(mediaLogger);\n\n /**\n * The MeetingInfo object to interact with server\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.meetingInfo = this.config.experimental.enableUnifiedMeetings\n ? // @ts-ignore\n new MeetingInfoV2(this.webex)\n : // @ts-ignore\n new MeetingInfo(this.webex);\n // @ts-ignore\n this.personalMeetingRoom = new PersonalMeetingRoom(\n {meetingInfo: this.meetingInfo},\n // @ts-ignore\n {parent: this.webex}\n );\n\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'onReady',\n },\n EVENT_TRIGGERS.MEETINGS_READY\n );\n\n MeetingsUtil.checkH264Support({disableNotifications: true});\n // @ts-ignore\n Metrics.initialSetup(this.webex);\n });\n }\n\n /**\n * API to toggle unified meetings\n * @param {Boolean} changeState\n * @private\n * @memberof Meetings\n * @returns {undefined}\n */\n private _toggleUnifiedMeetings(changeState: boolean) {\n if (typeof changeState !== 'boolean') {\n return;\n }\n // @ts-ignore\n if (this.config?.experimental?.enableUnifiedMeetings !== changeState) {\n // @ts-ignore\n this.config.experimental.enableUnifiedMeetings = changeState;\n // @ts-ignore\n this.meetingInfo = changeState ? new MeetingInfoV2(this.webex) : new MeetingInfo(this.webex);\n }\n }\n\n /**\n * API to enable or disable TURN discovery\n * @param {Boolean} enable\n * @private\n * @memberof Meetings\n * @returns {undefined}\n */\n private _toggleTurnDiscovery(enable: boolean) {\n if (typeof enable !== 'boolean') {\n return;\n }\n // @ts-ignore\n this.config.experimental.enableTurnDiscovery = enable;\n }\n\n /**\n * API to toggle starting adhoc meeting\n * @param {Boolean} changeState\n * @private\n * @memberof Meetings\n * @returns {undefined}\n */\n private _toggleAdhocMeetings(changeState: boolean) {\n if (typeof changeState !== 'boolean') {\n return;\n }\n // @ts-ignore\n if (this.config?.experimental?.enableAdhocMeetings !== changeState) {\n // @ts-ignore\n this.config.experimental.enableAdhocMeetings = changeState;\n }\n }\n\n /**\n * Explicitly sets up the meetings plugin by registering\n * the device, connecting to mercury, and listening for locus events.\n *\n * @returns {Promise}\n * @public\n * @memberof Meetings\n */\n public register() {\n // @ts-ignore\n if (!this.webex.canAuthorize) {\n LoggerProxy.logger.error(\n 'Meetings:index#register --> ERROR, Unable to register, SDK cannot authorize'\n );\n\n return Promise.reject(new Error('SDK cannot authorize'));\n }\n\n if (this.registered) {\n LoggerProxy.logger.info(\n 'Meetings:index#register --> INFO, Meetings plugin already registered'\n );\n\n return Promise.resolve();\n }\n\n return Promise.all([\n this.fetchUserPreferredWebexSite(),\n this.getGeoHint(),\n this.startReachability().catch((error) => {\n LoggerProxy.logger.error(`Meetings:index#register --> GDM error, ${error.message}`);\n }),\n // @ts-ignore\n this.webex.internal.device\n .register()\n // @ts-ignore\n .then(() =>\n LoggerProxy.logger.info(\n // @ts-ignore\n `Meetings:index#register --> INFO, Device registered ${this.webex.internal.device.url}`\n )\n )\n // @ts-ignore\n .then(() => this.webex.internal.mercury.connect()),\n MeetingsUtil.checkH264Support.call(this),\n ])\n .then(() => {\n this.listenForEvents();\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'register',\n },\n EVENT_TRIGGERS.MEETINGS_REGISTERED\n );\n this.registered = true;\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_SUCCESS);\n })\n .catch((error) => {\n LoggerProxy.logger.error(\n `Meetings:index#register --> ERROR, Unable to register, ${error.message}`\n );\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_FAILED, {\n reason: error.message,\n stack: error.stack,\n });\n\n return Promise.reject(error);\n });\n }\n\n /**\n * Explicitly tears down the meetings plugin by deregistering\n * the device, disconnecting from mercury, and stops listening to locus events\n *\n * @returns {Promise}\n * @public\n * @memberof Meetings\n */\n unregister() {\n if (!this.registered) {\n LoggerProxy.logger.info(\n 'Meetings:index#unregister --> INFO, Meetings plugin already unregistered'\n );\n\n return Promise.resolve();\n }\n\n this.stopListeningForEvents();\n\n return (\n // @ts-ignore\n this.webex.internal.mercury\n .disconnect()\n // @ts-ignore\n .then(() => this.webex.internal.device.unregister())\n .then(() => {\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'unregister',\n },\n EVENT_TRIGGERS.MEETINGS_UNREGISTERED\n );\n this.registered = false;\n })\n );\n }\n\n /**\n * Creates a noise reduction effect\n *\n * @param {INoiseReductionEffect} options optional custom effect options\n * @returns {Promise<effect>} noise reduction effect.\n * @public\n * @memberof Meetings\n */\n createNoiseReductionEffect = async (options?: INoiseReductionEffect) => {\n // @ts-ignore\n const authToken = this.webex.credentials.supertoken.access_token;\n\n return new mediaHelpersModule.NoiseReductionEffect({authToken, ...options});\n };\n\n /**\n * Creates a virtual background effect\n *\n * @param {IVirtualBackgroundEffect} options optional custom effect options\n * @returns {Promise<effect>} virtual background effect.\n * @public\n * @memberof Meetings\n */\n createVirtualBackgroundEffect = async (options?: IVirtualBackgroundEffect) => {\n // @ts-ignore\n const authToken = this.webex.credentials.supertoken.access_token;\n\n return new mediaHelpersModule.VirtualBackgroundEffect({authToken, ...options});\n };\n\n /**\n * Uploads logs to the webex services for tracking\n * @param {Object} [options={}]\n * @param {String} [options.callStart] Call Start Time\n * @param {String} [options.feedbackId] ID used for tracking\n * @param {String} [options.locusId]\n * @param {String} [options.correlationId]\n * @param {String} [options.meetingId] webex meeting ID\n * @param {String} [options.userId] userId\n * @param {String} [options.orgId] org id\n * @returns {String} feedback ID logs were submitted under\n */\n uploadLogs(\n options: {\n callStart?: string;\n feedbackId?: string;\n locusId?: string;\n correlationId?: string;\n meetingId?: string;\n userId?: string;\n orgId?: string;\n } = {}\n ) {\n LoggerProxy.logger.info('Meetings:index#uploadLogs --> uploading logs');\n\n return this.loggerRequest\n .uploadLogs(options)\n .then((uploadResult) => {\n LoggerProxy.logger.info(\n 'Meetings:index#uploadLogs --> Upload logs for meeting completed.',\n uploadResult\n );\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'uploadLogs',\n },\n EVENT_TRIGGERS.MEETING_LOG_UPLOAD_SUCCESS,\n {\n meetingId: options.meetingId,\n details: uploadResult,\n }\n );\n\n return uploadResult;\n })\n .catch((uploadError) => {\n LoggerProxy.logger.error(\n 'Meetings:index#uploadLogs --> Unable to upload logs for meeting',\n uploadError\n );\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'uploadLogs',\n },\n EVENT_TRIGGERS.MEETING_LOG_UPLOAD_FAILURE,\n {\n meetingId: options.meetingId,\n reason: uploadError,\n }\n );\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.UPLOAD_LOGS_FAILURE, {\n // @ts-ignore - seems like typo\n meetingId: options.meetingsId,\n reason: uploadError.message,\n stack: uploadError.stack,\n code: uploadError.code,\n });\n });\n }\n\n /**\n * gets the reachability instance for Meetings\n * @returns {Reachability}\n * @public\n * @memberof Meetings\n */\n getReachability() {\n return this.reachability;\n }\n\n /**\n * initializes and starts gathering reachability for Meetings\n * @returns {Promise}\n * @public\n * @memberof Meetings\n */\n startReachability() {\n return this.getReachability().gatherReachability();\n }\n\n /**\n * Get geoHint for info for meetings\n * @returns {Promise}\n * @private\n * @memberof Meetings\n */\n getGeoHint() {\n return this.request.fetchGeoHint().then((res) => {\n this.geoHintInfo = res;\n });\n }\n\n /**\n * Fetch user preferred webex site information\n * This also has other infomation about the user\n * @returns {Promise}\n * @private\n * @memberof Meetings\n */\n fetchUserPreferredWebexSite() {\n return this.request.getMeetingPreferences().then((res) => {\n if (res) {\n this.preferredWebexSite = MeetingsUtil.parseDefaultSiteFromMeetingPreferences(res);\n }\n\n // fall back to getting the preferred site from the user information\n if (!this.preferredWebexSite) {\n // @ts-ignore\n return this.webex.internal.user\n .get()\n .then((user) => {\n const preferredWebexSite =\n user?.userPreferences?.userPreferencesItems?.preferredWebExSite;\n if (preferredWebexSite) {\n this.preferredWebexSite = preferredWebexSite;\n } else {\n throw new Error('site not found');\n }\n })\n .catch(() => {\n LoggerProxy.logger.error(\n 'Failed to fetch preferred site from user - no site will be set'\n );\n });\n }\n\n return Promise.resolve();\n });\n }\n\n /**\n * gets the personal meeting room instance, for saved PMR values for this user\n * @returns {PersonalMeetingRoom}\n * @public\n * @memberof Meetings\n */\n\n getPersonalMeetingRoom() {\n return this.personalMeetingRoom;\n }\n\n /**\n * @param {Meeting} meeting\n * @param {Object} reason\n * @param {String} type\n * @returns {Undefined}\n * @private\n * @memberof Meetings\n */\n private destroy(meeting: Meeting, reason: object) {\n MeetingUtil.cleanUp(meeting);\n this.meetingCollection.delete(meeting.id);\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'destroy',\n },\n EVENT_TRIGGERS.MEETING_REMOVED,\n {\n meetingId: meeting.id,\n reason,\n }\n );\n }\n\n /**\n * Create a meeting.\n * @param {string} destination - sipURL, spaceId, phonenumber, or locus object}\n * @param {string} [type] - the optional specified type, such as locusId\n * @param {Boolean} useRandomDelayForInfo - whether a random delay should be added to fetching meeting info\n * @param {Object} infoExtraParams extra parameters to be provided when fetching meeting info\n * @param {string} correlationId - the optional specified correlationId\n * @returns {Promise<Meeting>} A new Meeting.\n * @public\n * @memberof Meetings\n */\n public create(\n destination: string,\n type: string = null,\n useRandomDelayForInfo = false,\n infoExtraParams = {},\n correlationId: string = undefined\n ) {\n // TODO: type should be from a dictionary\n\n // Validate meeting information based on the provided destination and\n // type. This must be performed prior to determining if the meeting is\n // found in the collection, as we mutate the destination for hydra person\n // id values.\n return (\n this.meetingInfo\n .fetchInfoOptions(destination, type)\n // Catch a failure to fetch info options.\n .catch((error) => {\n LoggerProxy.logger.info(\n `Meetings:index#create --> INFO, unable to determine info options: ${error.message}`\n );\n })\n .then((options: any = {}) => {\n // Normalize the destination.\n const targetDest = options.destination || destination;\n\n // check for the conversation URL then sip Url\n let meeting = null;\n\n if (type === _CONVERSATION_URL_ || options.type === _CONVERSATION_URL_) {\n const foundMeeting = this.meetingCollection.getByKey(CONVERSATION_URL, targetDest);\n\n if (foundMeeting) {\n const foundMeetingIsNotCalendarMeeting = !foundMeeting.locusInfo.scheduledMeeting;\n\n // If the found meeting is not a calendar meeting, return that meeting.\n // This allows for the creation of instant-meetings when calendar meetings are present.\n if (foundMeetingIsNotCalendarMeeting) {\n meeting = foundMeeting;\n }\n }\n }\n\n // Attempt to collect the meeting if it exists.\n if (!meeting) {\n meeting = this.meetingCollection.getByKey(SIP_URI, targetDest);\n }\n\n // Validate if a meeting was found.\n if (!meeting) {\n // Create a meeting based on the normalized destination and type.\n return this.createMeeting(\n targetDest,\n type,\n useRandomDelayForInfo,\n infoExtraParams,\n correlationId\n ).then((createdMeeting: any) => {\n // If the meeting was successfully created.\n if (createdMeeting && createdMeeting.on) {\n // Create a destruction event for the meeting.\n createdMeeting.on(EVENTS.DESTROY_MEETING, (payload) => {\n // @ts-ignore\n if (this.config.autoUploadLogs) {\n this.uploadLogs({\n callStart: createdMeeting.locusInfo?.fullState?.lastActive,\n correlationId: createdMeeting.correlationId,\n feedbackId: createdMeeting.correlationId,\n locusId: createdMeeting.locusId,\n meetingId: createdMeeting.locusInfo?.info?.webExMeetingId,\n }).then(() => this.destroy(createdMeeting, payload.reason));\n } else {\n this.destroy(createdMeeting, payload.reason);\n }\n });\n\n createdMeeting.on(EVENTS.REQUEST_UPLOAD_LOGS, (meetingInstance) => {\n // @ts-ignore\n if (this.config.autoUploadLogs) {\n this.uploadLogs({\n callStart: meetingInstance?.locusInfo?.fullState?.lastActive,\n correlationId: meetingInstance.correlationId,\n feedbackId: meetingInstance.correlationId,\n locusId: meetingInstance.locusId,\n meetingId: meetingInstance.locusInfo?.info?.webExMeetingId,\n });\n }\n });\n } else {\n LoggerProxy.logger.error(\n `Meetings:index#create --> ERROR, meeting does not have on method, will not be destroyed, meeting cleanup impossible for meeting: ${meeting}`\n );\n }\n\n // Return the newly created meeting.\n return Promise.resolve(createdMeeting);\n });\n }\n\n // Return the existing meeting.\n return Promise.resolve(meeting);\n })\n );\n }\n\n /**\n * @param {String} destination see create()\n * @param {String} type see create()\n * @param {Boolean} useRandomDelayForInfo whether a random delay should be added to fetching meeting info\n * @param {Object} infoExtraParams extra parameters to be provided when fetching meeting info\n * @param {String} correlationId the optional specified correlationId\n * @returns {Promise} a new meeting instance complete with meeting info and destination\n * @private\n * @memberof Meetings\n */\n private async createMeeting(\n destination: any,\n type: string = null,\n useRandomDelayForInfo = false,\n infoExtraParams = {},\n correlationId: string = undefined\n ) {\n const meeting = new Meeting(\n {\n // @ts-ignore\n userId: this.webex.internal.device.userId,\n // @ts-ignore\n deviceUrl: this.webex.internal.device.url,\n // @ts-ignore\n orgId: this.webex.internal.device.orgId,\n locus: type === _LOCUS_ID_ ? destination : null, // pass the locus object if present\n meetingInfoProvider: this.meetingInfo,\n destination,\n destinationType: type,\n correlationId,\n },\n {\n // @ts-ignore\n parent: this.webex,\n }\n );\n\n this.meetingCollection.set(meeting);\n\n try {\n // if no participant has joined the scheduled meeting (meaning meeting is not active) and we get a locusEvent,\n // it means the meeting will start in 5-6 min. In that case, we want to fetchMeetingInfo\n // between 5 and 2 min (random between 3 minutes) before the meeting starts\n // to avoid a spike in traffic to the wbxappi service\n let waitingTime = 0;\n\n if (destination.meeting) {\n const {startTime} = destination.meeting;\n const startTimeDate = new Date(startTime);\n const startTimeDatestamp = startTimeDate.getTime();\n const timeToStart = startTimeDatestamp - Date.now();\n const maxWaitingTime = Math.max(\n Math.min(timeToStart, MAX_RANDOM_DELAY_FOR_MEETING_INFO),\n 0\n );\n\n waitingTime = Math.round(Math.random() * maxWaitingTime);\n }\n const isMeetingActive = !!destination.fullState?.active;\n // @ts-ignore\n const {enableUnifiedMeetings} = this.config.experimental;\n\n if (enableUnifiedMeetings && !isMeetingActive && useRandomDelayForInfo && waitingTime > 0) {\n meeting.fetchMeetingInfoTimeoutId = setTimeout(\n () => meeting.fetchMeetingInfo({extraParams: infoExtraParams}),\n waitingTime\n );\n meeting.parseMeetingInfo(undefined, destination);\n } else {\n await meeting.fetchMeetingInfo({extraParams: infoExtraParams});\n }\n } catch (err) {\n if (\n !(err instanceof CaptchaError) &&\n !(err instanceof PasswordError) &&\n !(err instanceof PermissionError)\n ) {\n // if there is no meeting info we assume its a 1:1 call or wireless share\n LoggerProxy.logger.info(\n `Meetings:index#createMeeting --> Info Unable to fetch meeting info for ${destination}.`\n );\n LoggerProxy.logger.info(\n 'Meetings:index#createMeeting --> Info assuming this destination is a 1:1 or wireless share'\n );\n }\n LoggerProxy.logger.debug(\n `Meetings:index#createMeeting --> Debug ${err} fetching /meetingInfo for creation.`\n );\n } finally {\n // For type LOCUS_ID we need to parse the locus object to get the information\n // about the caller and callee\n // Meeting Added event will be created in `handleLocusEvent`\n if (type !== _LOCUS_ID_) {\n if (!meeting.sipUri) {\n meeting.setSipUri(destination);\n }\n\n // TODO: check if we have to move this to parser\n const meetingAddedType = MeetingsUtil.getMeetingAddedType(type);\n\n // We typically shouldn't need to trigger both and event and return a promise.\n // Is this a special case? We want to make the public API usage as simple as possible.\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'createMeeting',\n },\n EVENT_TRIGGERS.MEETING_ADDED,\n {\n meeting,\n type: meetingAddedType,\n }\n );\n }\n }\n\n return meeting;\n\n // Create the meeting calling the necessary service endpoints.\n\n // Internally, there are many more destinations:\n //\n // - locusID\n // - meetingURL\n // - globalMeetingID, e.g, *00*meetingID\n // - meetingID\n // - meetingURL\n // - PSTN\n // - phone number\n //\n // Our job is to determine the appropriate one\n // and its corresponding service so that developers\n // need only sipURL or spaceID to get a meeting\n // and its ID, but have the option to use createWithType()\n // and specify those types to get meetingInfo\n }\n\n /**\n * get a specifc meeting given it's type matched to the value, i.e., locus url\n * @param {String} type\n * @param {Object} value\n * @returns {Meeting}\n * @public\n * @memberof Meetings\n */\n public getMeetingByType(type: string, value: object) {\n return this.meetingCollection.getByKey(type, value);\n }\n\n /**\n * Get all meetings.\n * @param {object} options\n * @param {object} options.startDate - get meetings after this start date\n * @param {object} options.endDate - get meetings before this end date\n * @returns {Object} All currently active meetings.\n * @public\n * @memberof Meetings\n */\n public getAllMeetings(\n options: {\n startDate: object;\n endDate: object;\n } = {} as any\n ) {\n // Options may include other parameters to filter this collection\n // of meetings.\n return this.meetingCollection.getAll(options);\n }\n\n /**\n * syncs all the meeting from server\n * @returns {undefined}\n * @public\n * @memberof Meetings\n */\n public syncMeetings() {\n return this.request\n .getActiveMeetings()\n .then((locusArray) => {\n const activeLocusUrl = [];\n\n if (locusArray?.loci && locusArray.loci.length > 0) {\n const lociToUpdate = this.sortLocusArrayToUpdate(locusArray.loci);\n lociToUpdate.forEach((locus) => {\n activeLocusUrl.push(locus.url);\n this.handleLocusEvent({\n locus,\n locusUrl: locus.url,\n });\n });\n }\n const meetingsCollection = this.meetingCollection.getAll();\n\n if (Object.keys(meetingsCollection).length > 0) {\n // Some time the mercury event is missed after mercury reconnect\n // if sync returns no locus then clear all the meetings\n for (const meeting of Object.values(meetingsCollection)) {\n // @ts-ignore\n if (!activeLocusUrl.includes(meeting.locusUrl)) {\n // destroy function also uploads logs\n // @ts-ignore\n this.destroy(meeting, MEETING_REMOVED_REASON.NO_MEETINGS_TO_SYNC);\n }\n }\n }\n })\n .catch((error) => {\n LoggerProxy.logger.error(\n `Meetings:index#syncMeetings --> failed to sync meetings, ${error}`\n );\n throw new Error(error);\n });\n }\n\n /**\n * sort out locus array for initial creating\n * @param {Array} loci original locus array\n * @returns {undefined}\n * @public\n * @memberof Meetings\n */\n sortLocusArrayToUpdate(loci: any[]) {\n const mainLoci = loci.filter((locus) => !MeetingsUtil.isBreakoutLocusDTO(locus));\n const breakoutLoci = loci.filter((locus) => MeetingsUtil.isValidBreakoutLocus(locus));\n this.breakoutLocusForHandleLater = [];\n const lociToUpdate = [...mainLoci];\n breakoutLoci.forEach((breakoutLocus) => {\n const associateMainLocus = mainLoci.find(\n (mainLocus) => mainLocus.controls?.breakout?.url === breakoutLocus.controls?.breakout?.url\n );\n const existCorrespondingMeeting = this.getCorrespondingMeetingByLocus({\n locus: breakoutLocus,\n locusUrl: breakoutLocus.url,\n });\n\n if (associateMainLocus && !existCorrespondingMeeting) {\n // if exists both main session and breakout session locus of the same non-exist meeting, handle main locus first,\n // after meeting create with main locus, then handle the associate breakout locus.\n // if only handle breakout locus, will miss some date\n this.breakoutLocusForHandleLater.push(breakoutLocus);\n } else {\n lociToUpdate.push(breakoutLocus);\n }\n });\n\n return lociToUpdate;\n }\n\n /**\n * check breakout locus which waiting for main locus's meeting to be created, then handle the breakout locus\n * @param {Object} newCreatedLocus the locus which just create meeting object of it\n * @returns {undefined}\n * @public\n * @memberof Meetings\n */\n checkHandleBreakoutLocus(newCreatedLocus) {\n if (\n !newCreatedLocus ||\n !this.breakoutLocusForHandleLater ||\n !this.breakoutLocusForHandleLater.length\n ) {\n return;\n }\n if (MeetingsUtil.isBreakoutLocusDTO(newCreatedLocus)) {\n return;\n }\n const existIndex = this.breakoutLocusForHandleLater.findIndex(\n (breakoutLocus) =>\n breakoutLocus.controls?.breakout?.url === newCreatedLocus.controls?.breakout?.url\n );\n\n if (existIndex < 0) {\n return;\n }\n\n const associateBreakoutLocus = this.breakoutLocusForHandleLater[existIndex];\n this.handleLocusEvent({locus: associateBreakoutLocus, locusUrl: associateBreakoutLocus.url});\n this.breakoutLocusForHandleLater.splice(existIndex, 1);\n }\n\n /**\n * Get all scheduled meetings.\n * @param {object} options\n * @param {object} options.startDate - get meetings after this start date\n * @param {object} options.endDate - get meetings before this end date\n * @returns {Object} All scheduled meetings.\n * @memberof Meetings\n */\n getScheduledMeetings() {\n return this.meetingCollection.getAll({scheduled: true});\n }\n\n /**\n * Get the logger instance for plugin-meetings\n * @returns {Logger}\n */\n getLogger() {\n return LoggerProxy.get();\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["mediaLogger","MediaLogger","LoggerProxy","logger","info","log","error","warn","trace","debug","Meetings","args","MEETINGS","options","authToken","webex","credentials","supertoken","access_token","mediaHelpersModule","NoiseReductionEffect","VirtualBackgroundEffect","mediaHelpers","request","Request","parent","loggerRequest","LoggerRequest","meetingCollection","MeetingCollection","personalMeetingRoom","reachability","Reachability","registered","preferredWebexSite","media","getUserMedia","Media","onReady","meeting","newLocus","breakoutUrl","controls","breakout","url","breakoutLocus","getActiveBreakoutLocus","isSelfJoined","self","state","_JOINED_","isSelfMoved","_LEFT_","reason","_MOVED_","deviceFromNewLocus","MeetingsUtil","getThisDevice","internal","device","isResourceMovedOnThisDevice","isNewLocusJoinThisDevice","joinedOnThisDevice","isBreakoutLocusJoinThisDevice","joinedWith","correlationId","breakoutReplaceAt","replaces","length","replaceAt","newLocusReplaceAt","removed","isNewLocusAsBreakout","isBreakoutLocusDTO","fullState","active","isNeedHandleMainLocus","data","getByKey","LOCUS_URL","locusUrl","CORRELATION_ID","checkForCorrelationId","locus","SIP_URI","callbackInfo","callbackAddress","isUnifiedSpaceMeeting","undefined","CONVERSATION_URL","conversationUrl","MEETINGNUMBER","webExMeetingId","useRandomDelayForInfo","getCorrespondingMeetingByLocus","locusInfo","updateMainSessionLocusCache","isNeedHandleLocusDTO","LOCUS","STATE","INACTIVE","create","_LOCUS_ID_","then","newMeeting","initialSetup","checkHandleBreakoutLocus","catch","e","finally","getMeetingByType","_ID_","id","newMetrics","submitClientEvent","name","payload","trigger","meetingId","Trigger","file","function","EVENT_TRIGGERS","MEETING_ADDED","type","_MEETING_","_JOIN_","_INCOMING_","parse","envelope","eventType","LOCUSEVENT","MESSAGE_ROAP","handleLocusEvent","MEETINGS_NETWORK_DISCONNECTED","mercury","on","LOCUS_MERCURY","handleLocusMercury","ROAP","ROAP_MERCURY","handleRoapMercury","ONLINE","syncMeetings","OFFLINE","handleMercuryOffline","off","once","READY","StaticConfig","set","config","LoggerConfig","logging","setLogger","meetingInfo","experimental","enableUnifiedMeetings","MeetingInfoV2","MeetingInfo","PersonalMeetingRoom","MEETINGS_READY","checkH264Support","disableNotifications","Metrics","changeState","enable","enableTurnDiscovery","enableAdhocMeetings","canAuthorize","reject","Error","resolve","all","fetchUserPreferredWebexSite","getGeoHint","startReachability","message","register","connect","call","listenForEvents","MEETINGS_REGISTERED","sendBehavioralMetric","BEHAVIORAL_METRICS","MEETINGS_REGISTRATION_SUCCESS","MEETINGS_REGISTRATION_FAILED","stack","stopListeningForEvents","disconnect","unregister","MEETINGS_UNREGISTERED","uploadLogs","uploadResult","MEETING_LOG_UPLOAD_SUCCESS","details","uploadError","MEETING_LOG_UPLOAD_FAILURE","UPLOAD_LOGS_FAILURE","meetingsId","code","getReachability","gatherReachability","fetchGeoHint","res","geoHintInfo","getMeetingPreferences","parseDefaultSiteFromMeetingPreferences","user","get","userPreferences","userPreferencesItems","preferredWebExSite","MeetingUtil","cleanUp","delete","MEETING_REMOVED","destination","infoExtraParams","fetchInfoOptions","SpaceIDDeprecatedError","targetDest","_CONVERSATION_URL_","foundMeeting","foundMeetingIsNotCalendarMeeting","scheduledMeeting","createMeeting","createdMeeting","EVENTS","DESTROY_MEETING","autoUploadLogs","callStart","lastActive","feedbackId","locusId","destroy","REQUEST_UPLOAD_LOGS","meetingInstance","Meeting","userId","deviceUrl","orgId","meetingInfoProvider","destinationType","waitingTime","startTime","startTimeDate","Date","startTimeDatestamp","getTime","timeToStart","maxWaitingTime","Math","max","min","MAX_RANDOM_DELAY_FOR_MEETING_INFO","round","random","isMeetingActive","fetchMeetingInfoTimeoutId","setTimeout","fetchMeetingInfo","extraParams","parseMeetingInfo","CaptchaError","PasswordError","PermissionError","sipUri","setSipUri","meetingAddedType","getMeetingAddedType","value","getAll","getActiveMeetings","locusArray","activeLocusUrl","loci","lociToUpdate","sortLocusArrayToUpdate","forEach","push","meetingsCollection","includes","MEETING_REMOVED_REASON","NO_MEETINGS_TO_SYNC","mainLoci","filter","breakoutLoci","isValidBreakoutLocus","breakoutLocusForHandleLater","associateMainLocus","find","mainLocus","existCorrespondingMeeting","newCreatedLocus","existIndex","findIndex","associateBreakoutLocus","splice","scheduled","WebexPlugin"],"sources":["index.ts"],"sourcesContent":["/* eslint no-shadow: [\"error\", { \"allow\": [\"eventType\"] }] */\n\nimport '@webex/internal-plugin-mercury';\nimport '@webex/internal-plugin-conversation';\nimport '@webex/internal-plugin-metrics';\n// @ts-ignore\nimport {WebexPlugin} from '@webex/webex-core';\nimport {setLogger} from '@webex/internal-media-core';\n\nimport * as mediaHelpersModule from '@webex/media-helpers';\n\nimport 'webrtc-adapter';\n\nimport Metrics from '../metrics';\nimport LoggerConfig from '../common/logs/logger-config';\nimport StaticConfig from '../common/config';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport LoggerRequest from '../common/logs/request';\nimport Trigger from '../common/events/trigger-proxy';\nimport Media from '../media';\nimport MeetingUtil from '../meeting/util';\nimport {\n MEETINGS,\n EVENTS,\n EVENT_TRIGGERS,\n READY,\n LOCUSEVENT,\n LOCUS_URL,\n MAX_RANDOM_DELAY_FOR_MEETING_INFO,\n ROAP,\n ONLINE,\n OFFLINE,\n _MEETING_,\n _JOIN_,\n _LOCUS_ID_,\n _INCOMING_,\n LOCUS,\n CORRELATION_ID,\n SIP_URI,\n _LEFT_,\n _ID_,\n MEETING_REMOVED_REASON,\n _CONVERSATION_URL_,\n CONVERSATION_URL,\n MEETINGNUMBER,\n _JOINED_,\n _MOVED_,\n} from '../constants';\nimport BEHAVIORAL_METRICS from '../metrics/constants';\nimport MeetingInfo from '../meeting-info';\nimport MeetingInfoV2 from '../meeting-info/meeting-info-v2';\nimport Meeting from '../meeting';\nimport PersonalMeetingRoom from '../personal-meeting-room';\nimport Reachability from '../reachability';\nimport Request from './request';\nimport PasswordError from '../common/errors/password-error';\nimport CaptchaError from '../common/errors/captcha-error';\n\nimport MeetingCollection from './collection';\nimport MeetingsUtil from './util';\nimport PermissionError from '../common/errors/permission';\nimport {INoiseReductionEffect, IVirtualBackgroundEffect} from './meetings.types';\nimport {SpaceIDDeprecatedError} from '../common/errors/webex-errors';\n\nlet mediaLogger;\n\nclass MediaLogger {\n info(...args) {\n LoggerProxy.logger.info(...args);\n }\n\n log(...args) {\n LoggerProxy.logger.log(...args);\n }\n\n error(...args) {\n LoggerProxy.logger.error(...args);\n }\n\n warn(...args) {\n LoggerProxy.logger.warn(...args);\n }\n\n trace(...args) {\n LoggerProxy.logger.trace(...args);\n }\n\n debug(...args) {\n LoggerProxy.logger.debug(...args);\n }\n}\n/**\n * Meetings Ready Event\n * Emitted when the meetings instance on webex is ready\n * @event meetings:ready\n * @instance\n * @memberof Meetings\n */\n\n/**\n * Meetings Network Disconnected Event\n * Emitted when the meetings instance is disconnected from\n * the internal mercury server\n * @event network:disconnected\n * @instance\n * @memberof Meetings\n */\n\n/**\n * Meetings Registered Event\n * Emitted when the meetings instance has been registered and listening\n * @event meetings:registered\n * @instance\n * @memberof Meetings\n */\n\n/**\n * Meeting Removed Event\n * Emitted when a meeting was removed from the cache of meetings\n * @event meeting:removed\n * @instance\n * @type {Object}\n * @property {String} meetingId the removed meeting\n * @property {Object} response the server response\n * @property {String} type what type of meeting it was\n * @memberof Meetings\n */\n\n/**\n * Meeting Added Event\n * Emitted when a meeting was added to the cache of meetings\n * @event meeting:added\n * @instance\n * @type {Object}\n * @property {String} meetingId the added meeting\n * @property {String} type what type of meeting it was\n * @memberof Meetings\n */\n\n/**\n * Maintain a cache of meetings and sync with services.\n * @class\n */\nexport default class Meetings extends WebexPlugin {\n loggerRequest: any;\n media: any;\n meetingCollection: any;\n personalMeetingRoom: any;\n preferredWebexSite: any;\n reachability: Reachability;\n registered: any;\n request: any;\n geoHintInfo: any;\n meetingInfo: any;\n mediaHelpers: any;\n breakoutLocusForHandleLater: any;\n namespace = MEETINGS;\n\n /**\n * Initializes the Meetings Plugin\n * @constructor\n * @public\n * @memberof Meetings\n */\n constructor(...args) {\n super(...args);\n\n /**\n * The webrtc-core media helpers. This is a temporary solution required for the SDK sample app\n * to be able to call media helper functions.\n *\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n this.mediaHelpers = mediaHelpersModule;\n\n /**\n * The Meetings request to interact with server\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.request = new Request({}, {parent: this.webex});\n /**\n * Log upload request helper\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.loggerRequest = new LoggerRequest({webex: this.webex});\n this.meetingCollection = new MeetingCollection();\n /**\n * The PersonalMeetingRoom object to interact with server\n * @instance\n * @type {Object}\n * @public\n * @memberof Meetings\n */\n this.personalMeetingRoom = null;\n\n /**\n * The Reachability object to interact with server\n * starts as null\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.reachability = new Reachability(this.webex);\n\n /**\n * If the meetings plugin has been registered and listening via {@link Meetings#register}\n * @instance\n * @type {Boolean}\n * @public\n * @memberof Meetings\n */\n this.registered = false;\n\n /**\n * This values indicates the preferred webex site the user will start there meeting, getsits value from {@link Meetings#register}\n * @instance\n * @type {String}\n * @private\n * @memberof Meetings\n */\n this.preferredWebexSite = '';\n\n /**\n * The public interface for the internal Media util files. These are helpful to expose outside the context\n * of a meeting so that a user can access media without creating a meeting instance.\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n this.media = {\n getUserMedia: Media.getUserMedia,\n };\n\n this.onReady();\n }\n\n /**\n * check whether you need to handle this main session's locus data or not\n * @param {Object} meeting current meeting data\n * @param {Object} newLocus new locus data\n * @returns {boolean}\n * @private\n * @memberof Meetings\n */\n private isNeedHandleMainLocus(meeting: any, newLocus: any) {\n const breakoutUrl = newLocus.controls?.breakout?.url;\n const breakoutLocus = this.meetingCollection.getActiveBreakoutLocus(breakoutUrl);\n\n const isSelfJoined = newLocus?.self?.state === _JOINED_;\n const isSelfMoved = newLocus?.self?.state === _LEFT_ && newLocus?.self?.reason === _MOVED_;\n // @ts-ignore\n const deviceFromNewLocus = MeetingsUtil.getThisDevice(newLocus, this.webex.internal.device.url);\n const isResourceMovedOnThisDevice =\n deviceFromNewLocus?.state === _LEFT_ && deviceFromNewLocus?.reason === _MOVED_;\n\n const isNewLocusJoinThisDevice = MeetingsUtil.joinedOnThisDevice(\n meeting,\n newLocus,\n // @ts-ignore\n this.webex.internal.device.url\n );\n const isBreakoutLocusJoinThisDevice =\n breakoutLocus?.joinedWith?.correlationId &&\n breakoutLocus.joinedWith.correlationId === meeting?.correlationId;\n\n if (isSelfJoined && isNewLocusJoinThisDevice) {\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> self this device shown as JOINED in the main session'\n );\n if (breakoutLocus?.joinedWith && deviceFromNewLocus) {\n const breakoutReplaceAt =\n breakoutLocus.joinedWith.replaces?.length > 0\n ? breakoutLocus.joinedWith.replaces[0].replaceAt\n : '';\n const newLocusReplaceAt =\n deviceFromNewLocus.replaces?.length > 0 ? deviceFromNewLocus.replaces[0].replaceAt : '';\n if (breakoutReplaceAt && newLocusReplaceAt && breakoutReplaceAt > newLocusReplaceAt) {\n LoggerProxy.logger.log(\n `Meetings:index#isNeedHandleMainLocus --> this is expired main joined status locus_dto replacedAt ${newLocusReplaceAt} bo replacedAt ${breakoutReplaceAt}`\n );\n\n return false;\n }\n }\n\n return true;\n }\n if (isBreakoutLocusJoinThisDevice) {\n LoggerProxy.logger.log(\n `Meetings:index#isNeedHandleMainLocus --> there is active breakout session and joined on this device, and don't need to handle main session: ${breakoutUrl}`\n );\n\n return false;\n }\n if (isSelfMoved && (newLocus?.self?.removed || isResourceMovedOnThisDevice)) {\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> self moved main locus with self removed status or with device resource moved, not need to handle'\n );\n\n return false;\n }\n if (isSelfJoined && isResourceMovedOnThisDevice) {\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> self device left&moved in main locus with self joined status, not need to handle'\n );\n\n return false;\n }\n LoggerProxy.logger.log(\n 'Meetings:index#isNeedHandleMainLocus --> this is a normal main session locusDTO update case'\n );\n\n return true;\n }\n\n /**\n * check whether you need to handle this locus data or not\n * @param {Object} meeting old locus data\n * @param {Object} newLocus new locus data\n * @returns {boolean}\n * @private\n * @memberof Meetings\n */\n private isNeedHandleLocusDTO(meeting: any, newLocus: any) {\n if (newLocus) {\n const isNewLocusAsBreakout = MeetingsUtil.isBreakoutLocusDTO(newLocus);\n const isSelfMoved = newLocus?.self?.state === _LEFT_ && newLocus?.self?.reason === _MOVED_;\n if (!meeting) {\n if (isNewLocusAsBreakout) {\n LoggerProxy.logger.log(\n `Meetings:index#isNeedHandleLocusDTO --> the first breakout session locusDTO active status: ${newLocus.fullState?.active}`\n );\n\n return newLocus.self?.state === _JOINED_;\n }\n\n return this.isNeedHandleMainLocus(meeting, newLocus);\n }\n if (!isNewLocusAsBreakout) {\n return this.isNeedHandleMainLocus(meeting, newLocus);\n }\n\n return !isSelfMoved;\n }\n\n return true;\n }\n\n /**\n * get corresponding meeting object by locus data\n * @param {Object} data a locus event\n * @param {String} data.locusUrl\n * @param {Object} data.locus\n * @returns {Object}\n * @private\n * @memberof Meetings\n */\n getCorrespondingMeetingByLocus(data) {\n // getting meeting by correlationId. This will happen for the new event\n // Either the locus\n // TODO : Add check for the callBack Address\n return (\n this.meetingCollection.getByKey(LOCUS_URL, data.locusUrl) ||\n // @ts-ignore\n this.meetingCollection.getByKey(\n CORRELATION_ID,\n // @ts-ignore\n MeetingsUtil.checkForCorrelationId(this.webex.internal.device.url, data.locus)\n ) ||\n this.meetingCollection.getByKey(\n SIP_URI,\n data.locus.self &&\n data.locus.self.callbackInfo &&\n data.locus.self.callbackInfo.callbackAddress\n ) ||\n (data.locus.info?.isUnifiedSpaceMeeting\n ? undefined\n : this.meetingCollection.getByKey(CONVERSATION_URL, data.locus.conversationUrl)) ||\n this.meetingCollection.getByKey(MEETINGNUMBER, data.locus?.info?.webExMeetingId)\n );\n }\n\n /**\n * handle locus events and takes meeting actions with them as they come in\n * @param {Object} data a locus event\n * @param {String} data.locusUrl\n * @param {Object} data.locus\n * @param {Boolean} useRandomDelayForInfo whether a random delay should be added to fetching meeting info\n * @param {String} data.eventType\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private handleLocusEvent(data: {locusUrl: string; locus: any}, useRandomDelayForInfo = false) {\n let meeting = this.getCorrespondingMeetingByLocus(data);\n\n // Special case when locus has got replaced, This only happend once if a replace locus exists\n // https://sqbu-github.cisco.com/WebExSquared/locus/wiki/Locus-changing-mid-call\n\n if (!meeting && data.locus?.replaces?.length > 0) {\n // Always the last element in the replace is the active one\n meeting = this.meetingCollection.getByKey(\n LOCUS_URL,\n data.locus.replaces[data.locus.replaces.length - 1].locusUrl\n );\n }\n\n if (meeting && !MeetingsUtil.isBreakoutLocusDTO(data.locus)) {\n meeting.locusInfo.updateMainSessionLocusCache(data.locus);\n }\n if (!this.isNeedHandleLocusDTO(meeting, data.locus)) {\n LoggerProxy.logger.log(\n `Meetings:index#handleLocusEvent --> doesn't need to process locus event`\n );\n\n return;\n }\n if (!meeting) {\n // TODO: create meeting when we get a meeting object\n // const checkForEnded = (locus) => {\n // TODO: you already ended the meeting but you got an event later\n // Mainly for 1:1 Callsor meeting\n // Happens mainly after refresh\n\n // 1:1 Meeting\n // 1) You ended a call before but you got a mercury event\n // Make sure end the call and cleanup the meeting only if the mercury\n // event says so\n // 2) Maintain lastSync time in the meetings object which helps to compare\n // If the meeting came befor or after the sync . ANy meeting start time before the sync time is invalid\n\n // For space Meeting\n // Check the locus object and see who has joined\n\n // };\n // rather then locus object change to locus url\n\n if (\n data.locus &&\n data.locus.fullState &&\n data.locus.fullState.state === LOCUS.STATE.INACTIVE\n ) {\n // just ignore the event as its already ended and not active\n LoggerProxy.logger.warn(\n 'Meetings:index#handleLocusEvent --> Locus event received for meeting, after it was ended.'\n );\n\n return;\n }\n\n // When its wireless share or guest and user leaves the meeting we dont have to keep the meeting object\n // Any future events will be neglected\n\n if (\n data.locus &&\n data.locus.self &&\n data.locus.self.state === _LEFT_ &&\n data.locus.self.removed === true\n ) {\n // just ignore the event as its already ended and not active\n LoggerProxy.logger.warn(\n 'Meetings:index#handleLocusEvent --> Locus event received for meeting, after it was ended.'\n );\n\n return;\n }\n\n this.create(data.locus, _LOCUS_ID_, useRandomDelayForInfo)\n .then((newMeeting) => {\n meeting = newMeeting;\n\n // It's a new meeting so initialize the locus data\n meeting.locusInfo.initialSetup(data.locus);\n this.checkHandleBreakoutLocus(data.locus);\n })\n .catch((e) => {\n LoggerProxy.logger.error(e);\n })\n .finally(() => {\n // There will be cases where locus event comes in gets created and deleted because its a 1:1 and meeting gets deleted\n // because the other user left so before sending 'added' event make sure it exists in the collection\n\n if (this.getMeetingByType(_ID_, meeting.id)) {\n // @ts-ignore\n this.webex.internal.newMetrics.submitClientEvent({\n name: 'client.call.remote-started',\n payload: {\n trigger: 'mercury-event',\n },\n options: {\n meetingId: meeting.id,\n },\n });\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'handleLocusEvent',\n },\n EVENT_TRIGGERS.MEETING_ADDED,\n {\n meeting,\n type: meeting.type === _MEETING_ ? _JOIN_ : _INCOMING_,\n }\n );\n } else {\n // Meeting got added but was not found in the collection. It might have got destroyed\n LoggerProxy.logger.warn(\n 'Meetings:index#handleLocusEvent --> Created and destroyed meeting object before sending an event'\n );\n }\n });\n } else {\n meeting.locusInfo.parse(meeting, data);\n }\n }\n\n /**\n * handles locus events through mercury that are not roap\n * @param {Object} envelope\n * @param {Object} envelope.data\n * @param {String} envelope.data.eventType\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private handleLocusMercury(envelope: {data: any}) {\n const {data} = envelope;\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const {eventType} = data;\n\n if (eventType && eventType !== LOCUSEVENT.MESSAGE_ROAP) {\n this.handleLocusEvent(data, true);\n }\n }\n\n /**\n * handles mecury offline event\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private handleMercuryOffline() {\n Trigger.trigger(\n this,\n {\n file: 'meetings/index',\n function: 'handleMercuryOffline',\n },\n EVENT_TRIGGERS.MEETINGS_NETWORK_DISCONNECTED\n );\n }\n\n /**\n * registers for locus and roap mercury events\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private listenForEvents() {\n // @ts-ignore\n this.webex.internal.mercury.on(LOCUSEVENT.LOCUS_MERCURY, (envelope) => {\n this.handleLocusMercury(envelope);\n });\n // @ts-ignore\n this.webex.internal.mercury.on(ROAP.ROAP_MERCURY, (envelope) => {\n MeetingsUtil.handleRoapMercury(envelope, this.meetingCollection);\n });\n\n // @ts-ignore\n this.webex.internal.mercury.on(ONLINE, () => {\n this.syncMeetings();\n });\n\n // @ts-ignore\n this.webex.internal.mercury.on(OFFLINE, () => {\n this.handleMercuryOffline();\n });\n }\n\n /**\n * stops listening for locus and roap mercury events\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private stopListeningForEvents() {\n // @ts-ignore\n this.webex.internal.mercury.off(LOCUSEVENT.LOCUS_MERCURY);\n // @ts-ignore\n this.webex.internal.mercury.off(ROAP.ROAP_MERCURY);\n // @ts-ignore\n this.webex.internal.mercury.off(ONLINE);\n }\n\n /**\n * @returns {undefined}\n * @private\n * @memberof Meetings\n */\n private onReady() {\n // @ts-ignore\n this.webex.once(READY, () => {\n // @ts-ignore\n StaticConfig.set(this.config);\n // @ts-ignore\n LoggerConfig.set(this.config.logging);\n // @ts-ignore\n LoggerProxy.set(this.webex.logger);\n\n mediaLogger = new MediaLogger();\n setLogger(mediaLogger);\n\n /**\n * The MeetingInfo object to interact with server\n * @instance\n * @type {Object}\n * @private\n * @memberof Meetings\n */\n // @ts-ignore\n this.meetingInfo = this.config.experimental.enableUnifiedMeetings\n ? // @ts-ignore\n new MeetingInfoV2(this.webex)\n : // @ts-ignore\n new MeetingInfo(this.webex);\n // @ts-ignore\n this.personalMeetingRoom = new PersonalMeetingRoom(\n {meetingInfo: this.meetingInfo},\n // @ts-ignore\n {parent: this.webex}\n );\n\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'onReady',\n },\n EVENT_TRIGGERS.MEETINGS_READY\n );\n\n MeetingsUtil.checkH264Support({disableNotifications: true});\n // @ts-ignore\n Metrics.initialSetup(this.webex);\n });\n }\n\n /**\n * API to toggle unified meetings\n * @param {Boolean} changeState\n * @private\n * @memberof Meetings\n * @returns {undefined}\n */\n private _toggleUnifiedMeetings(changeState: boolean) {\n if (typeof changeState !== 'boolean') {\n return;\n }\n // @ts-ignore\n if (this.config?.experimental?.enableUnifiedMeetings !== changeState) {\n // @ts-ignore\n this.config.experimental.enableUnifiedMeetings = changeState;\n // @ts-ignore\n this.meetingInfo = changeState ? new MeetingInfoV2(this.webex) : new MeetingInfo(this.webex);\n }\n }\n\n /**\n * API to enable or disable TURN discovery\n * @param {Boolean} enable\n * @private\n * @memberof Meetings\n * @returns {undefined}\n */\n private _toggleTurnDiscovery(enable: boolean) {\n if (typeof enable !== 'boolean') {\n return;\n }\n // @ts-ignore\n this.config.experimental.enableTurnDiscovery = enable;\n }\n\n /**\n * API to toggle starting adhoc meeting\n * @param {Boolean} changeState\n * @private\n * @memberof Meetings\n * @returns {undefined}\n */\n private _toggleAdhocMeetings(changeState: boolean) {\n if (typeof changeState !== 'boolean') {\n return;\n }\n // @ts-ignore\n if (this.config?.experimental?.enableAdhocMeetings !== changeState) {\n // @ts-ignore\n this.config.experimental.enableAdhocMeetings = changeState;\n }\n }\n\n /**\n * Explicitly sets up the meetings plugin by registering\n * the device, connecting to mercury, and listening for locus events.\n *\n * @returns {Promise}\n * @public\n * @memberof Meetings\n */\n public register() {\n // @ts-ignore\n if (!this.webex.canAuthorize) {\n LoggerProxy.logger.error(\n 'Meetings:index#register --> ERROR, Unable to register, SDK cannot authorize'\n );\n\n return Promise.reject(new Error('SDK cannot authorize'));\n }\n\n if (this.registered) {\n LoggerProxy.logger.info(\n 'Meetings:index#register --> INFO, Meetings plugin already registered'\n );\n\n return Promise.resolve();\n }\n\n return Promise.all([\n this.fetchUserPreferredWebexSite(),\n this.getGeoHint(),\n this.startReachability().catch((error) => {\n LoggerProxy.logger.error(`Meetings:index#register --> GDM error, ${error.message}`);\n }),\n // @ts-ignore\n this.webex.internal.device\n .register()\n // @ts-ignore\n .then(() =>\n LoggerProxy.logger.info(\n // @ts-ignore\n `Meetings:index#register --> INFO, Device registered ${this.webex.internal.device.url}`\n )\n )\n // @ts-ignore\n .then(() => this.webex.internal.mercury.connect()),\n MeetingsUtil.checkH264Support.call(this),\n ])\n .then(() => {\n this.listenForEvents();\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'register',\n },\n EVENT_TRIGGERS.MEETINGS_REGISTERED\n );\n this.registered = true;\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_SUCCESS);\n })\n .catch((error) => {\n LoggerProxy.logger.error(\n `Meetings:index#register --> ERROR, Unable to register, ${error.message}`\n );\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.MEETINGS_REGISTRATION_FAILED, {\n reason: error.message,\n stack: error.stack,\n });\n\n return Promise.reject(error);\n });\n }\n\n /**\n * Explicitly tears down the meetings plugin by deregistering\n * the device, disconnecting from mercury, and stops listening to locus events\n *\n * @returns {Promise}\n * @public\n * @memberof Meetings\n */\n unregister() {\n if (!this.registered) {\n LoggerProxy.logger.info(\n 'Meetings:index#unregister --> INFO, Meetings plugin already unregistered'\n );\n\n return Promise.resolve();\n }\n\n this.stopListeningForEvents();\n\n return (\n // @ts-ignore\n this.webex.internal.mercury\n .disconnect()\n // @ts-ignore\n .then(() => this.webex.internal.device.unregister())\n .then(() => {\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'unregister',\n },\n EVENT_TRIGGERS.MEETINGS_UNREGISTERED\n );\n this.registered = false;\n })\n );\n }\n\n /**\n * Creates a noise reduction effect\n *\n * @param {INoiseReductionEffect} options optional custom effect options\n * @returns {Promise<effect>} noise reduction effect.\n * @public\n * @memberof Meetings\n */\n createNoiseReductionEffect = async (options?: INoiseReductionEffect) => {\n // @ts-ignore\n const authToken = this.webex.credentials.supertoken.access_token;\n\n return new mediaHelpersModule.NoiseReductionEffect({authToken, ...options});\n };\n\n /**\n * Creates a virtual background effect\n *\n * @param {IVirtualBackgroundEffect} options optional custom effect options\n * @returns {Promise<effect>} virtual background effect.\n * @public\n * @memberof Meetings\n */\n createVirtualBackgroundEffect = async (options?: IVirtualBackgroundEffect) => {\n // @ts-ignore\n const authToken = this.webex.credentials.supertoken.access_token;\n\n return new mediaHelpersModule.VirtualBackgroundEffect({authToken, ...options});\n };\n\n /**\n * Uploads logs to the webex services for tracking\n * @param {Object} [options={}]\n * @param {String} [options.callStart] Call Start Time\n * @param {String} [options.feedbackId] ID used for tracking\n * @param {String} [options.locusId]\n * @param {String} [options.correlationId]\n * @param {String} [options.meetingId] webex meeting ID\n * @param {String} [options.userId] userId\n * @param {String} [options.orgId] org id\n * @returns {String} feedback ID logs were submitted under\n */\n uploadLogs(\n options: {\n callStart?: string;\n feedbackId?: string;\n locusId?: string;\n correlationId?: string;\n meetingId?: string;\n userId?: string;\n orgId?: string;\n } = {}\n ) {\n LoggerProxy.logger.info('Meetings:index#uploadLogs --> uploading logs');\n\n return this.loggerRequest\n .uploadLogs(options)\n .then((uploadResult) => {\n LoggerProxy.logger.info(\n 'Meetings:index#uploadLogs --> Upload logs for meeting completed.',\n uploadResult\n );\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'uploadLogs',\n },\n EVENT_TRIGGERS.MEETING_LOG_UPLOAD_SUCCESS,\n {\n meetingId: options.meetingId,\n details: uploadResult,\n }\n );\n\n return uploadResult;\n })\n .catch((uploadError) => {\n LoggerProxy.logger.error(\n 'Meetings:index#uploadLogs --> Unable to upload logs for meeting',\n uploadError\n );\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'uploadLogs',\n },\n EVENT_TRIGGERS.MEETING_LOG_UPLOAD_FAILURE,\n {\n meetingId: options.meetingId,\n reason: uploadError,\n }\n );\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.UPLOAD_LOGS_FAILURE, {\n // @ts-ignore - seems like typo\n meetingId: options.meetingsId,\n reason: uploadError.message,\n stack: uploadError.stack,\n code: uploadError.code,\n });\n });\n }\n\n /**\n * gets the reachability instance for Meetings\n * @returns {Reachability}\n * @public\n * @memberof Meetings\n */\n getReachability() {\n return this.reachability;\n }\n\n /**\n * initializes and starts gathering reachability for Meetings\n * @returns {Promise}\n * @public\n * @memberof Meetings\n */\n startReachability() {\n return this.getReachability().gatherReachability();\n }\n\n /**\n * Get geoHint for info for meetings\n * @returns {Promise}\n * @private\n * @memberof Meetings\n */\n getGeoHint() {\n return this.request.fetchGeoHint().then((res) => {\n this.geoHintInfo = res;\n });\n }\n\n /**\n * Fetch user preferred webex site information\n * This also has other infomation about the user\n * @returns {Promise}\n * @private\n * @memberof Meetings\n */\n fetchUserPreferredWebexSite() {\n return this.request.getMeetingPreferences().then((res) => {\n if (res) {\n this.preferredWebexSite = MeetingsUtil.parseDefaultSiteFromMeetingPreferences(res);\n }\n\n // fall back to getting the preferred site from the user information\n if (!this.preferredWebexSite) {\n // @ts-ignore\n return this.webex.internal.user\n .get()\n .then((user) => {\n const preferredWebexSite =\n user?.userPreferences?.userPreferencesItems?.preferredWebExSite;\n if (preferredWebexSite) {\n this.preferredWebexSite = preferredWebexSite;\n } else {\n throw new Error('site not found');\n }\n })\n .catch(() => {\n LoggerProxy.logger.error(\n 'Failed to fetch preferred site from user - no site will be set'\n );\n });\n }\n\n return Promise.resolve();\n });\n }\n\n /**\n * gets the personal meeting room instance, for saved PMR values for this user\n * @returns {PersonalMeetingRoom}\n * @public\n * @memberof Meetings\n */\n\n getPersonalMeetingRoom() {\n return this.personalMeetingRoom;\n }\n\n /**\n * @param {Meeting} meeting\n * @param {Object} reason\n * @param {String} type\n * @returns {Undefined}\n * @private\n * @memberof Meetings\n */\n private destroy(meeting: Meeting, reason: object) {\n MeetingUtil.cleanUp(meeting);\n this.meetingCollection.delete(meeting.id);\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'destroy',\n },\n EVENT_TRIGGERS.MEETING_REMOVED,\n {\n meetingId: meeting.id,\n reason,\n }\n );\n }\n\n /**\n * Create a meeting.\n * @param {string} destination - sipURL, phonenumber, or locus object}\n * @param {string} [type] - the optional specified type, such as locusId\n * @param {Boolean} useRandomDelayForInfo - whether a random delay should be added to fetching meeting info\n * @param {Object} infoExtraParams extra parameters to be provided when fetching meeting info\n * @param {string} correlationId - the optional specified correlationId\n * @returns {Promise<Meeting>} A new Meeting.\n * @public\n * @memberof Meetings\n */\n public create(\n destination: string,\n type: string = null,\n useRandomDelayForInfo = false,\n infoExtraParams = {},\n correlationId: string = undefined\n ) {\n // TODO: type should be from a dictionary\n\n // Validate meeting information based on the provided destination and\n // type. This must be performed prior to determining if the meeting is\n // found in the collection, as we mutate the destination for hydra person\n // id values.\n return (\n this.meetingInfo\n .fetchInfoOptions(destination, type)\n // Catch a failure to fetch info options.\n .catch((error) => {\n LoggerProxy.logger.error(\n `Meetings:index#create --> ERROR, unable to determine info options: ${error.message}`\n );\n if (error instanceof SpaceIDDeprecatedError) {\n throw new SpaceIDDeprecatedError();\n }\n })\n .then((options: any = {}) => {\n // Normalize the destination.\n const targetDest = options.destination || destination;\n\n // check for the conversation URL then sip Url\n let meeting = null;\n\n if (type === _CONVERSATION_URL_ || options.type === _CONVERSATION_URL_) {\n const foundMeeting = this.meetingCollection.getByKey(CONVERSATION_URL, targetDest);\n\n if (foundMeeting) {\n const foundMeetingIsNotCalendarMeeting = !foundMeeting.locusInfo.scheduledMeeting;\n\n // If the found meeting is not a calendar meeting, return that meeting.\n // This allows for the creation of instant-meetings when calendar meetings are present.\n if (foundMeetingIsNotCalendarMeeting) {\n meeting = foundMeeting;\n }\n }\n }\n\n // Attempt to collect the meeting if it exists.\n if (!meeting) {\n meeting = this.meetingCollection.getByKey(SIP_URI, targetDest);\n }\n\n // Validate if a meeting was found.\n if (!meeting) {\n // Create a meeting based on the normalized destination and type.\n return this.createMeeting(\n targetDest,\n type,\n useRandomDelayForInfo,\n infoExtraParams,\n correlationId\n ).then((createdMeeting: any) => {\n // If the meeting was successfully created.\n if (createdMeeting && createdMeeting.on) {\n // Create a destruction event for the meeting.\n createdMeeting.on(EVENTS.DESTROY_MEETING, (payload) => {\n // @ts-ignore\n if (this.config.autoUploadLogs) {\n this.uploadLogs({\n callStart: createdMeeting.locusInfo?.fullState?.lastActive,\n correlationId: createdMeeting.correlationId,\n feedbackId: createdMeeting.correlationId,\n locusId: createdMeeting.locusId,\n meetingId: createdMeeting.locusInfo?.info?.webExMeetingId,\n }).then(() => this.destroy(createdMeeting, payload.reason));\n } else {\n this.destroy(createdMeeting, payload.reason);\n }\n });\n\n createdMeeting.on(EVENTS.REQUEST_UPLOAD_LOGS, (meetingInstance) => {\n // @ts-ignore\n if (this.config.autoUploadLogs) {\n this.uploadLogs({\n callStart: meetingInstance?.locusInfo?.fullState?.lastActive,\n correlationId: meetingInstance.correlationId,\n feedbackId: meetingInstance.correlationId,\n locusId: meetingInstance.locusId,\n meetingId: meetingInstance.locusInfo?.info?.webExMeetingId,\n });\n }\n });\n } else {\n LoggerProxy.logger.error(\n `Meetings:index#create --> ERROR, meeting does not have on method, will not be destroyed, meeting cleanup impossible for meeting: ${meeting}`\n );\n }\n\n // Return the newly created meeting.\n return Promise.resolve(createdMeeting);\n });\n }\n\n // Return the existing meeting.\n return Promise.resolve(meeting);\n })\n );\n }\n\n /**\n * @param {String} destination see create()\n * @param {String} type see create()\n * @param {Boolean} useRandomDelayForInfo whether a random delay should be added to fetching meeting info\n * @param {Object} infoExtraParams extra parameters to be provided when fetching meeting info\n * @param {String} correlationId the optional specified correlationId\n * @returns {Promise} a new meeting instance complete with meeting info and destination\n * @private\n * @memberof Meetings\n */\n private async createMeeting(\n destination: any,\n type: string = null,\n useRandomDelayForInfo = false,\n infoExtraParams = {},\n correlationId: string = undefined\n ) {\n const meeting = new Meeting(\n {\n // @ts-ignore\n userId: this.webex.internal.device.userId,\n // @ts-ignore\n deviceUrl: this.webex.internal.device.url,\n // @ts-ignore\n orgId: this.webex.internal.device.orgId,\n locus: type === _LOCUS_ID_ ? destination : null, // pass the locus object if present\n meetingInfoProvider: this.meetingInfo,\n destination,\n destinationType: type,\n correlationId,\n },\n {\n // @ts-ignore\n parent: this.webex,\n }\n );\n\n this.meetingCollection.set(meeting);\n\n try {\n // if no participant has joined the scheduled meeting (meaning meeting is not active) and we get a locusEvent,\n // it means the meeting will start in 5-6 min. In that case, we want to fetchMeetingInfo\n // between 5 and 2 min (random between 3 minutes) before the meeting starts\n // to avoid a spike in traffic to the wbxappi service\n let waitingTime = 0;\n\n if (destination.meeting) {\n const {startTime} = destination.meeting;\n const startTimeDate = new Date(startTime);\n const startTimeDatestamp = startTimeDate.getTime();\n const timeToStart = startTimeDatestamp - Date.now();\n const maxWaitingTime = Math.max(\n Math.min(timeToStart, MAX_RANDOM_DELAY_FOR_MEETING_INFO),\n 0\n );\n\n waitingTime = Math.round(Math.random() * maxWaitingTime);\n }\n const isMeetingActive = !!destination.fullState?.active;\n // @ts-ignore\n const {enableUnifiedMeetings} = this.config.experimental;\n\n if (enableUnifiedMeetings && !isMeetingActive && useRandomDelayForInfo && waitingTime > 0) {\n meeting.fetchMeetingInfoTimeoutId = setTimeout(\n () => meeting.fetchMeetingInfo({extraParams: infoExtraParams}),\n waitingTime\n );\n meeting.parseMeetingInfo(undefined, destination);\n } else {\n await meeting.fetchMeetingInfo({extraParams: infoExtraParams});\n }\n } catch (err) {\n if (\n !(err instanceof CaptchaError) &&\n !(err instanceof PasswordError) &&\n !(err instanceof PermissionError)\n ) {\n // if there is no meeting info we assume its a 1:1 call or wireless share\n LoggerProxy.logger.info(\n `Meetings:index#createMeeting --> Info Unable to fetch meeting info for ${destination}.`\n );\n LoggerProxy.logger.info(\n 'Meetings:index#createMeeting --> Info assuming this destination is a 1:1 or wireless share'\n );\n }\n LoggerProxy.logger.debug(\n `Meetings:index#createMeeting --> Debug ${err} fetching /meetingInfo for creation.`\n );\n } finally {\n // For type LOCUS_ID we need to parse the locus object to get the information\n // about the caller and callee\n // Meeting Added event will be created in `handleLocusEvent`\n if (type !== _LOCUS_ID_) {\n if (!meeting.sipUri) {\n meeting.setSipUri(destination);\n }\n\n // TODO: check if we have to move this to parser\n const meetingAddedType = MeetingsUtil.getMeetingAddedType(type);\n\n // We typically shouldn't need to trigger both and event and return a promise.\n // Is this a special case? We want to make the public API usage as simple as possible.\n Trigger.trigger(\n this,\n {\n file: 'meetings',\n function: 'createMeeting',\n },\n EVENT_TRIGGERS.MEETING_ADDED,\n {\n meeting,\n type: meetingAddedType,\n }\n );\n }\n }\n\n return meeting;\n\n // Create the meeting calling the necessary service endpoints.\n\n // Internally, there are many more destinations:\n //\n // - locusID\n // - meetingURL\n // - globalMeetingID, e.g, *00*meetingID\n // - meetingID\n // - meetingURL\n // - PSTN\n // - phone number\n //\n // Our job is to determine the appropriate one\n // and its corresponding service so that developers\n // need only sipURL to get a meeting\n // and its ID, but have the option to use createWithType()\n // and specify those types to get meetingInfo\n }\n\n /**\n * get a specifc meeting given it's type matched to the value, i.e., locus url\n * @param {String} type\n * @param {Object} value\n * @returns {Meeting}\n * @public\n * @memberof Meetings\n */\n public getMeetingByType(type: string, value: object) {\n return this.meetingCollection.getByKey(type, value);\n }\n\n /**\n * Get all meetings.\n * @param {object} options\n * @param {object} options.startDate - get meetings after this start date\n * @param {object} options.endDate - get meetings before this end date\n * @returns {Object} All currently active meetings.\n * @public\n * @memberof Meetings\n */\n public getAllMeetings(\n options: {\n startDate: object;\n endDate: object;\n } = {} as any\n ) {\n // Options may include other parameters to filter this collection\n // of meetings.\n return this.meetingCollection.getAll(options);\n }\n\n /**\n * syncs all the meeting from server\n * @returns {undefined}\n * @public\n * @memberof Meetings\n */\n public syncMeetings() {\n return this.request\n .getActiveMeetings()\n .then((locusArray) => {\n const activeLocusUrl = [];\n\n if (locusArray?.loci && locusArray.loci.length > 0) {\n const lociToUpdate = this.sortLocusArrayToUpdate(locusArray.loci);\n lociToUpdate.forEach((locus) => {\n activeLocusUrl.push(locus.url);\n this.handleLocusEvent({\n locus,\n locusUrl: locus.url,\n });\n });\n }\n const meetingsCollection = this.meetingCollection.getAll();\n\n if (Object.keys(meetingsCollection).length > 0) {\n // Some time the mercury event is missed after mercury reconnect\n // if sync returns no locus then clear all the meetings\n for (const meeting of Object.values(meetingsCollection)) {\n // @ts-ignore\n if (!activeLocusUrl.includes(meeting.locusUrl)) {\n // destroy function also uploads logs\n // @ts-ignore\n this.destroy(meeting, MEETING_REMOVED_REASON.NO_MEETINGS_TO_SYNC);\n }\n }\n }\n })\n .catch((error) => {\n LoggerProxy.logger.error(\n `Meetings:index#syncMeetings --> failed to sync meetings, ${error}`\n );\n throw new Error(error);\n });\n }\n\n /**\n * sort out locus array for initial creating\n * @param {Array} loci original locus array\n * @returns {undefined}\n * @public\n * @memberof Meetings\n */\n sortLocusArrayToUpdate(loci: any[]) {\n const mainLoci = loci.filter((locus) => !MeetingsUtil.isBreakoutLocusDTO(locus));\n const breakoutLoci = loci.filter((locus) => MeetingsUtil.isValidBreakoutLocus(locus));\n this.breakoutLocusForHandleLater = [];\n const lociToUpdate = [...mainLoci];\n breakoutLoci.forEach((breakoutLocus) => {\n const associateMainLocus = mainLoci.find(\n (mainLocus) => mainLocus.controls?.breakout?.url === breakoutLocus.controls?.breakout?.url\n );\n const existCorrespondingMeeting = this.getCorrespondingMeetingByLocus({\n locus: breakoutLocus,\n locusUrl: breakoutLocus.url,\n });\n\n if (associateMainLocus && !existCorrespondingMeeting) {\n // if exists both main session and breakout session locus of the same non-exist meeting, handle main locus first,\n // after meeting create with main locus, then handle the associate breakout locus.\n // if only handle breakout locus, will miss some date\n this.breakoutLocusForHandleLater.push(breakoutLocus);\n } else {\n lociToUpdate.push(breakoutLocus);\n }\n });\n\n return lociToUpdate;\n }\n\n /**\n * check breakout locus which waiting for main locus's meeting to be created, then handle the breakout locus\n * @param {Object} newCreatedLocus the locus which just create meeting object of it\n * @returns {undefined}\n * @public\n * @memberof Meetings\n */\n checkHandleBreakoutLocus(newCreatedLocus) {\n if (\n !newCreatedLocus ||\n !this.breakoutLocusForHandleLater ||\n !this.breakoutLocusForHandleLater.length\n ) {\n return;\n }\n if (MeetingsUtil.isBreakoutLocusDTO(newCreatedLocus)) {\n return;\n }\n const existIndex = this.breakoutLocusForHandleLater.findIndex(\n (breakoutLocus) =>\n breakoutLocus.controls?.breakout?.url === newCreatedLocus.controls?.breakout?.url\n );\n\n if (existIndex < 0) {\n return;\n }\n\n const associateBreakoutLocus = this.breakoutLocusForHandleLater[existIndex];\n this.handleLocusEvent({locus: associateBreakoutLocus, locusUrl: associateBreakoutLocus.url});\n this.breakoutLocusForHandleLater.splice(existIndex, 1);\n }\n\n /**\n * Get all scheduled meetings.\n * @param {object} options\n * @param {object} options.startDate - get meetings after this start date\n * @param {object} options.endDate - get meetings before this end date\n * @returns {Object} All scheduled meetings.\n * @memberof Meetings\n */\n getScheduledMeetings() {\n return this.meetingCollection.getAll({scheduled: true});\n }\n\n /**\n * Get the logger instance for plugin-meetings\n * @returns {Logger}\n */\n getLogger() {\n return LoggerProxy.get();\n }\n}\n"],"mappings":"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"}
|
|
@@ -55,6 +55,18 @@ declare class UserInLobbyError extends WebexMeetingsError {
|
|
|
55
55
|
constructor();
|
|
56
56
|
}
|
|
57
57
|
export { UserInLobbyError };
|
|
58
|
+
/**
|
|
59
|
+
* @class SpaceIDDeprecatedError
|
|
60
|
+
* @classdesc Raised whenever the user passes Space ID as destination for create meeting.
|
|
61
|
+
* @extends WebexMeetingsError
|
|
62
|
+
* @property {number} code - 30105
|
|
63
|
+
* @property {string} message - Using the space ID as a destination is no longer supported. Please refer to the [migration guide](https://github.com/webex/webex-js-sdk/wiki/Migration-guide-for-USM-meeting) to migrate to use the meeting ID or SIP address.'
|
|
64
|
+
*/
|
|
65
|
+
declare class SpaceIDDeprecatedError extends WebexMeetingsError {
|
|
66
|
+
static CODE: number;
|
|
67
|
+
constructor();
|
|
68
|
+
}
|
|
69
|
+
export { SpaceIDDeprecatedError };
|
|
58
70
|
/**
|
|
59
71
|
* @class IceGatheringFailed
|
|
60
72
|
* @classdesc Raised whenever ice gathering fails.
|
|
@@ -278,7 +278,7 @@ export default class Meetings extends WebexPlugin {
|
|
|
278
278
|
private destroy;
|
|
279
279
|
/**
|
|
280
280
|
* Create a meeting.
|
|
281
|
-
* @param {string} destination - sipURL,
|
|
281
|
+
* @param {string} destination - sipURL, phonenumber, or locus object}
|
|
282
282
|
* @param {string} [type] - the optional specified type, such as locusId
|
|
283
283
|
* @param {Boolean} useRandomDelayForInfo - whether a random delay should be added to fetching meeting info
|
|
284
284
|
* @param {Object} infoExtraParams extra parameters to be provided when fetching meeting info
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webex/plugin-meetings",
|
|
3
|
-
"version": "3.0.0-beta.
|
|
3
|
+
"version": "3.0.0-beta.229",
|
|
4
4
|
"description": "",
|
|
5
5
|
"license": "Cisco EULA (https://www.cisco.com/c/en/us/products/end-user-license-agreement.html)",
|
|
6
6
|
"contributors": [
|
|
@@ -32,12 +32,12 @@
|
|
|
32
32
|
"build": "yarn run -T tsc --declaration true --declarationDir ./dist/types"
|
|
33
33
|
},
|
|
34
34
|
"devDependencies": {
|
|
35
|
-
"@webex/plugin-meetings": "3.0.0-beta.
|
|
36
|
-
"@webex/test-helper-chai": "3.0.0-beta.
|
|
37
|
-
"@webex/test-helper-mocha": "3.0.0-beta.
|
|
38
|
-
"@webex/test-helper-mock-webex": "3.0.0-beta.
|
|
39
|
-
"@webex/test-helper-retry": "3.0.0-beta.
|
|
40
|
-
"@webex/test-helper-test-users": "3.0.0-beta.
|
|
35
|
+
"@webex/plugin-meetings": "3.0.0-beta.229",
|
|
36
|
+
"@webex/test-helper-chai": "3.0.0-beta.229",
|
|
37
|
+
"@webex/test-helper-mocha": "3.0.0-beta.229",
|
|
38
|
+
"@webex/test-helper-mock-webex": "3.0.0-beta.229",
|
|
39
|
+
"@webex/test-helper-retry": "3.0.0-beta.229",
|
|
40
|
+
"@webex/test-helper-test-users": "3.0.0-beta.229",
|
|
41
41
|
"chai": "^4.3.4",
|
|
42
42
|
"chai-as-promised": "^7.1.1",
|
|
43
43
|
"jsdom-global": "3.0.2",
|
|
@@ -46,19 +46,19 @@
|
|
|
46
46
|
"typescript": "^4.7.4"
|
|
47
47
|
},
|
|
48
48
|
"dependencies": {
|
|
49
|
-
"@webex/common": "3.0.0-beta.
|
|
49
|
+
"@webex/common": "3.0.0-beta.229",
|
|
50
50
|
"@webex/internal-media-core": "1.39.3",
|
|
51
|
-
"@webex/internal-plugin-conversation": "3.0.0-beta.
|
|
52
|
-
"@webex/internal-plugin-device": "3.0.0-beta.
|
|
53
|
-
"@webex/internal-plugin-llm": "3.0.0-beta.
|
|
54
|
-
"@webex/internal-plugin-mercury": "3.0.0-beta.
|
|
55
|
-
"@webex/internal-plugin-metrics": "3.0.0-beta.
|
|
56
|
-
"@webex/internal-plugin-support": "3.0.0-beta.
|
|
57
|
-
"@webex/internal-plugin-user": "3.0.0-beta.
|
|
58
|
-
"@webex/media-helpers": "3.0.0-beta.
|
|
59
|
-
"@webex/plugin-people": "3.0.0-beta.
|
|
60
|
-
"@webex/plugin-rooms": "3.0.0-beta.
|
|
61
|
-
"@webex/webex-core": "3.0.0-beta.
|
|
51
|
+
"@webex/internal-plugin-conversation": "3.0.0-beta.229",
|
|
52
|
+
"@webex/internal-plugin-device": "3.0.0-beta.229",
|
|
53
|
+
"@webex/internal-plugin-llm": "3.0.0-beta.229",
|
|
54
|
+
"@webex/internal-plugin-mercury": "3.0.0-beta.229",
|
|
55
|
+
"@webex/internal-plugin-metrics": "3.0.0-beta.229",
|
|
56
|
+
"@webex/internal-plugin-support": "3.0.0-beta.229",
|
|
57
|
+
"@webex/internal-plugin-user": "3.0.0-beta.229",
|
|
58
|
+
"@webex/media-helpers": "3.0.0-beta.229",
|
|
59
|
+
"@webex/plugin-people": "3.0.0-beta.229",
|
|
60
|
+
"@webex/plugin-rooms": "3.0.0-beta.229",
|
|
61
|
+
"@webex/webex-core": "3.0.0-beta.229",
|
|
62
62
|
"ampersand-collection": "^2.0.2",
|
|
63
63
|
"bowser": "^2.11.0",
|
|
64
64
|
"btoa": "^1.2.1",
|
|
@@ -107,6 +107,27 @@ class UserInLobbyError extends WebexMeetingsError {
|
|
|
107
107
|
export {UserInLobbyError};
|
|
108
108
|
WebExMeetingsErrors[UserInLobbyError.CODE] = UserInLobbyError;
|
|
109
109
|
|
|
110
|
+
/**
|
|
111
|
+
* @class SpaceIDDeprecatedError
|
|
112
|
+
* @classdesc Raised whenever the user passes Space ID as destination for create meeting.
|
|
113
|
+
* @extends WebexMeetingsError
|
|
114
|
+
* @property {number} code - 30105
|
|
115
|
+
* @property {string} message - Using the space ID as a destination is no longer supported. Please refer to the [migration guide](https://github.com/webex/webex-js-sdk/wiki/Migration-guide-for-USM-meeting) to migrate to use the meeting ID or SIP address.'
|
|
116
|
+
*/
|
|
117
|
+
class SpaceIDDeprecatedError extends WebexMeetingsError {
|
|
118
|
+
static CODE = 30105;
|
|
119
|
+
|
|
120
|
+
constructor() {
|
|
121
|
+
super(
|
|
122
|
+
SpaceIDDeprecatedError.CODE,
|
|
123
|
+
'Using the space ID as a destination is no longer supported. Please refer to the [migration guide](https://github.com/webex/webex-js-sdk/wiki/Migration-guide-for-USM-meeting) to migrate to use the meeting ID or SIP address.'
|
|
124
|
+
);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
export {SpaceIDDeprecatedError};
|
|
129
|
+
WebExMeetingsErrors[SpaceIDDeprecatedError.CODE] = SpaceIDDeprecatedError;
|
|
130
|
+
|
|
110
131
|
/**
|
|
111
132
|
* @class IceGatheringFailed
|
|
112
133
|
* @classdesc Raised whenever ice gathering fails.
|
package/src/config.ts
CHANGED
|
@@ -86,8 +86,8 @@ export default {
|
|
|
86
86
|
installedOrgID: undefined,
|
|
87
87
|
experimental: {
|
|
88
88
|
enableMediaNegotiatedEvent: false,
|
|
89
|
-
enableUnifiedMeetings:
|
|
90
|
-
enableAdhocMeetings:
|
|
89
|
+
enableUnifiedMeetings: true,
|
|
90
|
+
enableAdhocMeetings: true,
|
|
91
91
|
enableTurnDiscovery: true,
|
|
92
92
|
},
|
|
93
93
|
degradationPreferences: {
|
package/src/meeting-info/util.ts
CHANGED
|
@@ -233,7 +233,7 @@ MeetingInfoUtil.generateOptions = async (from) => {
|
|
|
233
233
|
}
|
|
234
234
|
} else {
|
|
235
235
|
throw new ParameterError(
|
|
236
|
-
'MeetingInfo is fetched with meeting link,
|
|
236
|
+
'MeetingInfo is fetched with the meeting link, SIP URI, phone number, Hydra people ID, or a conversation URL.'
|
|
237
237
|
);
|
|
238
238
|
}
|
|
239
239
|
|
|
@@ -28,8 +28,11 @@ import {
|
|
|
28
28
|
} from '../constants';
|
|
29
29
|
import ParameterError from '../common/errors/parameter';
|
|
30
30
|
import LoggerProxy from '../common/logs/logger-proxy';
|
|
31
|
+
import {SpaceIDDeprecatedError} from '../common/errors/webex-errors';
|
|
31
32
|
|
|
32
33
|
const MeetingInfoUtil: any = {};
|
|
34
|
+
const meetingInfoError =
|
|
35
|
+
'MeetingInfo is fetched with the meeting link, SIP URI, phone number, Hydra people ID, or a conversation URL.';
|
|
33
36
|
|
|
34
37
|
MeetingInfoUtil.getParsedUrl = (link) => {
|
|
35
38
|
try {
|
|
@@ -191,27 +194,14 @@ MeetingInfoUtil.getDestinationType = async (from) => {
|
|
|
191
194
|
return Promise.resolve(options);
|
|
192
195
|
});
|
|
193
196
|
} else if (hydraId.room) {
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
await webex.internal.services.waitForCatalog('postauth');
|
|
197
|
-
|
|
198
|
-
const conversationUrl = webex.internal.conversation.getUrlFromClusterId({
|
|
199
|
-
cluster: hydraId.cluster,
|
|
200
|
-
id: hydraId.destination,
|
|
201
|
-
});
|
|
202
|
-
|
|
203
|
-
options.destination = conversationUrl;
|
|
204
|
-
} catch (e) {
|
|
205
|
-
LoggerProxy.logger.error(`Meeting-info:util#getDestinationType --> ${e}`);
|
|
206
|
-
throw e;
|
|
207
|
-
}
|
|
208
|
-
} else {
|
|
209
|
-
LoggerProxy.logger.warn(
|
|
210
|
-
"Meeting-info:util#getDestinationType --> ('MeetingInfo is fetched with meeting link, sip uri, phone number, hydra room id, hydra people id, or a conversation url."
|
|
211
|
-
);
|
|
212
|
-
throw new ParameterError(
|
|
213
|
-
'MeetingInfo is fetched with meeting link, sip uri, phone number, hydra room id, hydra people id, or a conversation url.'
|
|
197
|
+
LoggerProxy.logger.error(
|
|
198
|
+
`Meeting-info:util#getDestinationType --> Using the space ID as a destination is no longer supported. Please refer to the [migration guide](https://github.com/webex/webex-js-sdk/wiki/Migration-guide-for-USM-meeting) to migrate to use the meeting ID or SIP address.`
|
|
214
199
|
);
|
|
200
|
+
// Error code 30105 added as Space ID deprecated as of beta, Please refer migration guide.
|
|
201
|
+
throw new SpaceIDDeprecatedError();
|
|
202
|
+
} else {
|
|
203
|
+
LoggerProxy.logger.warn(`Meeting-info:util#getDestinationType --> ${meetingInfoError}`);
|
|
204
|
+
throw new ParameterError(`${meetingInfoError}`);
|
|
215
205
|
}
|
|
216
206
|
|
|
217
207
|
return Promise.resolve(options);
|
package/src/meetings/index.ts
CHANGED
|
@@ -60,6 +60,7 @@ import MeetingCollection from './collection';
|
|
|
60
60
|
import MeetingsUtil from './util';
|
|
61
61
|
import PermissionError from '../common/errors/permission';
|
|
62
62
|
import {INoiseReductionEffect, IVirtualBackgroundEffect} from './meetings.types';
|
|
63
|
+
import {SpaceIDDeprecatedError} from '../common/errors/webex-errors';
|
|
63
64
|
|
|
64
65
|
let mediaLogger;
|
|
65
66
|
|
|
@@ -1037,7 +1038,7 @@ export default class Meetings extends WebexPlugin {
|
|
|
1037
1038
|
|
|
1038
1039
|
/**
|
|
1039
1040
|
* Create a meeting.
|
|
1040
|
-
* @param {string} destination - sipURL,
|
|
1041
|
+
* @param {string} destination - sipURL, phonenumber, or locus object}
|
|
1041
1042
|
* @param {string} [type] - the optional specified type, such as locusId
|
|
1042
1043
|
* @param {Boolean} useRandomDelayForInfo - whether a random delay should be added to fetching meeting info
|
|
1043
1044
|
* @param {Object} infoExtraParams extra parameters to be provided when fetching meeting info
|
|
@@ -1064,9 +1065,12 @@ export default class Meetings extends WebexPlugin {
|
|
|
1064
1065
|
.fetchInfoOptions(destination, type)
|
|
1065
1066
|
// Catch a failure to fetch info options.
|
|
1066
1067
|
.catch((error) => {
|
|
1067
|
-
LoggerProxy.logger.
|
|
1068
|
-
`Meetings:index#create -->
|
|
1068
|
+
LoggerProxy.logger.error(
|
|
1069
|
+
`Meetings:index#create --> ERROR, unable to determine info options: ${error.message}`
|
|
1069
1070
|
);
|
|
1071
|
+
if (error instanceof SpaceIDDeprecatedError) {
|
|
1072
|
+
throw new SpaceIDDeprecatedError();
|
|
1073
|
+
}
|
|
1070
1074
|
})
|
|
1071
1075
|
.then((options: any = {}) => {
|
|
1072
1076
|
// Normalize the destination.
|
|
@@ -1284,7 +1288,7 @@ export default class Meetings extends WebexPlugin {
|
|
|
1284
1288
|
//
|
|
1285
1289
|
// Our job is to determine the appropriate one
|
|
1286
1290
|
// and its corresponding service so that developers
|
|
1287
|
-
// need only sipURL
|
|
1291
|
+
// need only sipURL to get a meeting
|
|
1288
1292
|
// and its ID, but have the option to use createWithType()
|
|
1289
1293
|
// and specify those types to get meetingInfo
|
|
1290
1294
|
}
|