@webex/internal-plugin-metrics 3.0.0-beta.195 → 3.0.0-beta.197

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.
Files changed (29) hide show
  1. package/dist/call-diagnostic/call-diagnostic-metrics-batcher.js +5 -83
  2. package/dist/call-diagnostic/call-diagnostic-metrics-batcher.js.map +1 -1
  3. package/dist/call-diagnostic/call-diagnostic-metrics.js +76 -3
  4. package/dist/call-diagnostic/call-diagnostic-metrics.js.map +1 -1
  5. package/dist/call-diagnostic/call-diagnostic-metrics.util.js +120 -1
  6. package/dist/call-diagnostic/call-diagnostic-metrics.util.js.map +1 -1
  7. package/dist/call-diagnostic/generated-types-temp/ClientEvent.js.map +1 -1
  8. package/dist/call-diagnostic/generated-types-temp/Event.js.map +1 -1
  9. package/dist/metrics.js +1 -1
  10. package/dist/metrics.types.js.map +1 -1
  11. package/dist/new-metrics.js +64 -0
  12. package/dist/new-metrics.js.map +1 -1
  13. package/dist/types/call-diagnostic/call-diagnostic-metrics.d.ts +24 -0
  14. package/dist/types/call-diagnostic/call-diagnostic-metrics.util.d.ts +21 -0
  15. package/dist/types/call-diagnostic/generated-types-temp/ClientEvent.d.ts +135 -135
  16. package/dist/types/call-diagnostic/generated-types-temp/Event.d.ts +379 -379
  17. package/dist/types/metrics.types.d.ts +5 -0
  18. package/dist/types/new-metrics.d.ts +36 -0
  19. package/package.json +8 -8
  20. package/src/call-diagnostic/call-diagnostic-metrics-batcher.ts +2 -99
  21. package/src/call-diagnostic/call-diagnostic-metrics.ts +64 -2
  22. package/src/call-diagnostic/call-diagnostic-metrics.util.ts +132 -1
  23. package/src/call-diagnostic/generated-types-temp/ClientEvent.ts +1360 -1322
  24. package/src/call-diagnostic/generated-types-temp/Event.ts +3142 -3049
  25. package/src/metrics.types.ts +6 -0
  26. package/src/new-metrics.ts +52 -0
  27. package/test/unit/spec/call-diagnostic/call-diagnostic-metrics.ts +145 -46
  28. package/test/unit/spec/call-diagnostic/call-diagnostic-metrics.util.ts +262 -2
  29. package/test/unit/spec/new-metrics.ts +84 -22
@@ -6,99 +6,21 @@ _Object$defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
8
  exports.default = void 0;
9
- var _assign = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/assign"));
10
9
  var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
11
- var _merge2 = _interopRequireDefault(require("lodash/merge"));
12
- var _isEmpty2 = _interopRequireDefault(require("lodash/isEmpty"));
13
10
  var _batcher = _interopRequireDefault(require("../batcher"));
11
+ var _callDiagnosticMetrics = require("./call-diagnostic-metrics.util");
12
+ /* eslint-disable class-methods-use-this */
13
+ /* eslint-disable valid-jsdoc */
14
+
14
15
  var CallDiagnosticEventsBatcher = _batcher.default.extend({
15
16
  namespace: 'Metrics',
16
- /**
17
- * @param webClientDomain
18
- * @returns
19
- */
20
- getBuildType: function getBuildType(webClientDomain) {
21
- if (webClientDomain !== null && webClientDomain !== void 0 && webClientDomain.includes('localhost') || webClientDomain !== null && webClientDomain !== void 0 && webClientDomain.includes('127.0.0.1') || process.env.NODE_ENV !== 'production') {
22
- return 'test';
23
- }
24
- return process.env.NODE_ENV === 'production' ? 'prod' : 'test';
25
- },
26
17
  /**
27
18
  * Prepare item
28
19
  * @param item
29
20
  * @returns
30
21
  */
31
22
  prepareItem: function prepareItem(item) {
32
- var _item$event, _item$event$eventData, _item$eventPayload, _item$eventPayload$ev;
33
- var origin = {
34
- buildType: this.getBuildType((_item$event = item.event) === null || _item$event === void 0 ? void 0 : (_item$event$eventData = _item$event.eventData) === null || _item$event$eventData === void 0 ? void 0 : _item$event$eventData.webClientDomain),
35
- networkType: 'unknown'
36
- };
37
-
38
- // check event names and append latencies?
39
- var eventName = (_item$eventPayload = item.eventPayload) === null || _item$eventPayload === void 0 ? void 0 : (_item$eventPayload$ev = _item$eventPayload.event) === null || _item$eventPayload$ev === void 0 ? void 0 : _item$eventPayload$ev.name;
40
- var joinTimes = {};
41
- var audioSetupDelay = {};
42
- var videoSetupDelay = {};
43
- var cdl = this.webex.internal.newMetrics.callDiagnosticLatencies;
44
- switch (eventName) {
45
- case 'client.interstitial-window.launched':
46
- joinTimes.meetingInfoReqResp = cdl.getMeetingInfoReqResp();
47
- joinTimes.clickToInterstitial = cdl.getClickToInterstitial();
48
- break;
49
- case 'client.call.initiated':
50
- joinTimes.meetingInfoReqResp = cdl.getMeetingInfoReqResp();
51
- joinTimes.showInterstitialTime = cdl.getShowInterstitialTime();
52
- break;
53
- case 'client.locus.join.response':
54
- joinTimes.meetingInfoReqResp = cdl.getMeetingInfoReqResp();
55
- joinTimes.callInitJoinReq = cdl.getCallInitJoinReq();
56
- joinTimes.joinReqResp = cdl.getJoinReqResp();
57
- joinTimes.joinReqSentReceived = cdl.getJoinRespSentReceived();
58
- joinTimes.pageJmt = cdl.getPageJMT();
59
- joinTimes.clickToInterstitial = cdl.getClickToInterstitial();
60
- joinTimes.interstitialToJoinOK = cdl.getInterstitialToJoinOK();
61
- joinTimes.totalJmt = cdl.getTotalJMT();
62
- joinTimes.clientJmt = cdl.getClientJMT();
63
- break;
64
- case 'client.ice.end':
65
- joinTimes.ICESetupTime = cdl.getICESetupTime();
66
- joinTimes.audioICESetupTime = cdl.getAudioICESetupTime();
67
- joinTimes.videoICESetupTime = cdl.getVideoICESetupTime();
68
- joinTimes.shareICESetupTime = cdl.getShareICESetupTime();
69
- break;
70
- case 'client.media.rx.start':
71
- joinTimes.localSDPGenRemoteSDPRecv = cdl.getLocalSDPGenRemoteSDPRecv();
72
- break;
73
- case 'client.media-engine.ready':
74
- joinTimes.totalMediaJMT = cdl.getTotalMediaJMT();
75
- joinTimes.interstitialToMediaOKJMT = cdl.getInterstitialToMediaOKJMT();
76
- joinTimes.callInitMediaEngineReady = cdl.getCallInitMediaEngineReady();
77
- joinTimes.stayLobbyTime = cdl.getStayLobbyTime();
78
- break;
79
- case 'client.mediaquality.event':
80
- audioSetupDelay.joinRespRxStart = cdl.getAudioJoinRespRxStart();
81
- audioSetupDelay.joinRespTxStart = cdl.getAudioJoinRespTxStart();
82
- videoSetupDelay.joinRespRxStart = cdl.getVideoJoinRespRxStart();
83
- videoSetupDelay.joinRespTxStart = cdl.getVideoJoinRespTxStart();
84
- }
85
- if (!(0, _isEmpty2.default)(joinTimes)) {
86
- item.eventPayload.event = (0, _merge2.default)(item.eventPayload.event, {
87
- joinTimes: joinTimes
88
- });
89
- }
90
- if (!(0, _isEmpty2.default)(audioSetupDelay)) {
91
- item.eventPayload.event = (0, _merge2.default)(item.eventPayload.event, {
92
- audioSetupDelay: audioSetupDelay
93
- });
94
- }
95
- if (!(0, _isEmpty2.default)(videoSetupDelay)) {
96
- item.eventPayload.event = (0, _merge2.default)(item.eventPayload.event, {
97
- videoSetupDelay: videoSetupDelay
98
- });
99
- }
100
- item.eventPayload.origin = (0, _assign.default)(origin, item.eventPayload.origin);
101
- return _promise.default.resolve(item);
23
+ return _promise.default.resolve((0, _callDiagnosticMetrics.prepareDiagnosticMetricItem)(this.webex, item));
102
24
  },
103
25
  /**
104
26
  * Prepare request, add time sensitive date etc.
@@ -1 +1 @@
1
- {"version":3,"names":["CallDiagnosticEventsBatcher","Batcher","extend","namespace","getBuildType","webClientDomain","includes","process","env","NODE_ENV","prepareItem","item","origin","buildType","event","eventData","networkType","eventName","eventPayload","name","joinTimes","audioSetupDelay","videoSetupDelay","cdl","webex","internal","newMetrics","callDiagnosticLatencies","meetingInfoReqResp","getMeetingInfoReqResp","clickToInterstitial","getClickToInterstitial","showInterstitialTime","getShowInterstitialTime","callInitJoinReq","getCallInitJoinReq","joinReqResp","getJoinReqResp","joinReqSentReceived","getJoinRespSentReceived","pageJmt","getPageJMT","interstitialToJoinOK","getInterstitialToJoinOK","totalJmt","getTotalJMT","clientJmt","getClientJMT","ICESetupTime","getICESetupTime","audioICESetupTime","getAudioICESetupTime","videoICESetupTime","getVideoICESetupTime","shareICESetupTime","getShareICESetupTime","localSDPGenRemoteSDPRecv","getLocalSDPGenRemoteSDPRecv","totalMediaJMT","getTotalMediaJMT","interstitialToMediaOKJMT","getInterstitialToMediaOKJMT","callInitMediaEngineReady","getCallInitMediaEngineReady","stayLobbyTime","getStayLobbyTime","joinRespRxStart","getAudioJoinRespRxStart","joinRespTxStart","getAudioJoinRespTxStart","getVideoJoinRespRxStart","getVideoJoinRespTxStart","resolve","prepareRequest","queue","forEach","originTime","sent","Date","toISOString","submitHttpRequest","payload","request","method","service","resource","body","metrics"],"sources":["call-diagnostic-metrics-batcher.ts"],"sourcesContent":["/* eslint-disable class-methods-use-this */\n/* eslint-disable valid-jsdoc */\n\nimport {isEmpty, merge} from 'lodash';\nimport Batcher from '../batcher';\nimport {\n ClientEvent,\n MetricEventNames,\n MediaQualityEventAudioSetupDelayPayload,\n MediaQualityEventVideoSetupDelayPayload,\n} from '../metrics.types';\n\nconst CallDiagnosticEventsBatcher = Batcher.extend({\n namespace: 'Metrics',\n\n /**\n * @param webClientDomain\n * @returns\n */\n getBuildType(webClientDomain) {\n if (\n webClientDomain?.includes('localhost') ||\n webClientDomain?.includes('127.0.0.1') ||\n process.env.NODE_ENV !== 'production'\n ) {\n return 'test';\n }\n\n return process.env.NODE_ENV === 'production' ? 'prod' : 'test';\n },\n\n /**\n * Prepare item\n * @param item\n * @returns\n */\n prepareItem(item) {\n const origin = {\n buildType: this.getBuildType(item.event?.eventData?.webClientDomain),\n networkType: 'unknown',\n };\n\n // check event names and append latencies?\n const eventName = item.eventPayload?.event?.name as MetricEventNames;\n const joinTimes: ClientEvent['payload']['joinTimes'] = {};\n const audioSetupDelay: MediaQualityEventAudioSetupDelayPayload = {};\n const videoSetupDelay: MediaQualityEventVideoSetupDelayPayload = {};\n\n const cdl = this.webex.internal.newMetrics.callDiagnosticLatencies;\n\n switch (eventName) {\n case 'client.interstitial-window.launched':\n joinTimes.meetingInfoReqResp = cdl.getMeetingInfoReqResp();\n joinTimes.clickToInterstitial = cdl.getClickToInterstitial();\n break;\n\n case 'client.call.initiated':\n joinTimes.meetingInfoReqResp = cdl.getMeetingInfoReqResp();\n joinTimes.showInterstitialTime = cdl.getShowInterstitialTime();\n break;\n\n case 'client.locus.join.response':\n joinTimes.meetingInfoReqResp = cdl.getMeetingInfoReqResp();\n joinTimes.callInitJoinReq = cdl.getCallInitJoinReq();\n joinTimes.joinReqResp = cdl.getJoinReqResp();\n joinTimes.joinReqSentReceived = cdl.getJoinRespSentReceived();\n joinTimes.pageJmt = cdl.getPageJMT();\n joinTimes.clickToInterstitial = cdl.getClickToInterstitial();\n joinTimes.interstitialToJoinOK = cdl.getInterstitialToJoinOK();\n joinTimes.totalJmt = cdl.getTotalJMT();\n joinTimes.clientJmt = cdl.getClientJMT();\n break;\n\n case 'client.ice.end':\n joinTimes.ICESetupTime = cdl.getICESetupTime();\n joinTimes.audioICESetupTime = cdl.getAudioICESetupTime();\n joinTimes.videoICESetupTime = cdl.getVideoICESetupTime();\n joinTimes.shareICESetupTime = cdl.getShareICESetupTime();\n break;\n\n case 'client.media.rx.start':\n joinTimes.localSDPGenRemoteSDPRecv = cdl.getLocalSDPGenRemoteSDPRecv();\n break;\n\n case 'client.media-engine.ready':\n joinTimes.totalMediaJMT = cdl.getTotalMediaJMT();\n joinTimes.interstitialToMediaOKJMT = cdl.getInterstitialToMediaOKJMT();\n joinTimes.callInitMediaEngineReady = cdl.getCallInitMediaEngineReady();\n joinTimes.stayLobbyTime = cdl.getStayLobbyTime();\n break;\n\n case 'client.mediaquality.event':\n audioSetupDelay.joinRespRxStart = cdl.getAudioJoinRespRxStart();\n audioSetupDelay.joinRespTxStart = cdl.getAudioJoinRespTxStart();\n videoSetupDelay.joinRespRxStart = cdl.getVideoJoinRespRxStart();\n videoSetupDelay.joinRespTxStart = cdl.getVideoJoinRespTxStart();\n }\n\n if (!isEmpty(joinTimes)) {\n item.eventPayload.event = merge(item.eventPayload.event, {joinTimes});\n }\n\n if (!isEmpty(audioSetupDelay)) {\n item.eventPayload.event = merge(item.eventPayload.event, {audioSetupDelay});\n }\n\n if (!isEmpty(videoSetupDelay)) {\n item.eventPayload.event = merge(item.eventPayload.event, {videoSetupDelay});\n }\n\n item.eventPayload.origin = Object.assign(origin, item.eventPayload.origin);\n\n return Promise.resolve(item);\n },\n\n /**\n * Prepare request, add time sensitive date etc.\n * @param queue\n * @returns\n */\n prepareRequest(queue) {\n // Add sent timestamp\n queue.forEach((item) => {\n item.eventPayload.originTime = item.eventPayload.originTime || {};\n item.eventPayload.originTime.sent = new Date().toISOString();\n });\n\n return Promise.resolve(queue);\n },\n\n /**\n *\n * @param payload\n * @returns\n */\n submitHttpRequest(payload) {\n return this.webex.request({\n method: 'POST',\n service: 'metrics',\n resource: 'clientmetrics',\n body: {\n metrics: payload,\n },\n });\n },\n});\n\nexport default CallDiagnosticEventsBatcher;\n"],"mappings":"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"}
1
+ {"version":3,"names":["CallDiagnosticEventsBatcher","Batcher","extend","namespace","prepareItem","item","resolve","prepareDiagnosticMetricItem","webex","prepareRequest","queue","forEach","eventPayload","originTime","sent","Date","toISOString","submitHttpRequest","payload","request","method","service","resource","body","metrics"],"sources":["call-diagnostic-metrics-batcher.ts"],"sourcesContent":["/* eslint-disable class-methods-use-this */\n/* eslint-disable valid-jsdoc */\n\nimport Batcher from '../batcher';\nimport {prepareDiagnosticMetricItem} from './call-diagnostic-metrics.util';\n\nconst CallDiagnosticEventsBatcher = Batcher.extend({\n namespace: 'Metrics',\n\n /**\n * Prepare item\n * @param item\n * @returns\n */\n prepareItem(item) {\n return Promise.resolve(prepareDiagnosticMetricItem(this.webex, item));\n },\n\n /**\n * Prepare request, add time sensitive date etc.\n * @param queue\n * @returns\n */\n prepareRequest(queue) {\n // Add sent timestamp\n queue.forEach((item) => {\n item.eventPayload.originTime = item.eventPayload.originTime || {};\n item.eventPayload.originTime.sent = new Date().toISOString();\n });\n\n return Promise.resolve(queue);\n },\n\n /**\n *\n * @param payload\n * @returns\n */\n submitHttpRequest(payload) {\n return this.webex.request({\n method: 'POST',\n service: 'metrics',\n resource: 'clientmetrics',\n body: {\n metrics: payload,\n },\n });\n },\n});\n\nexport default CallDiagnosticEventsBatcher;\n"],"mappings":";;;;;;;;;AAGA;AACA;AAJA;AACA;;AAKA,IAAMA,2BAA2B,GAAGC,gBAAO,CAACC,MAAM,CAAC;EACjDC,SAAS,EAAE,SAAS;EAEpB;AACF;AACA;AACA;AACA;EACEC,WAAW,uBAACC,IAAI,EAAE;IAChB,OAAO,iBAAQC,OAAO,CAAC,IAAAC,kDAA2B,EAAC,IAAI,CAACC,KAAK,EAAEH,IAAI,CAAC,CAAC;EACvE,CAAC;EAED;AACF;AACA;AACA;AACA;EACEI,cAAc,0BAACC,KAAK,EAAE;IACpB;IACAA,KAAK,CAACC,OAAO,CAAC,UAACN,IAAI,EAAK;MACtBA,IAAI,CAACO,YAAY,CAACC,UAAU,GAAGR,IAAI,CAACO,YAAY,CAACC,UAAU,IAAI,CAAC,CAAC;MACjER,IAAI,CAACO,YAAY,CAACC,UAAU,CAACC,IAAI,GAAG,IAAIC,IAAI,EAAE,CAACC,WAAW,EAAE;IAC9D,CAAC,CAAC;IAEF,OAAO,iBAAQV,OAAO,CAACI,KAAK,CAAC;EAC/B,CAAC;EAED;AACF;AACA;AACA;AACA;EACEO,iBAAiB,6BAACC,OAAO,EAAE;IACzB,OAAO,IAAI,CAACV,KAAK,CAACW,OAAO,CAAC;MACxBC,MAAM,EAAE,MAAM;MACdC,OAAO,EAAE,SAAS;MAClBC,QAAQ,EAAE,eAAe;MACzBC,IAAI,EAAE;QACJC,OAAO,EAAEN;MACX;IACF,CAAC,CAAC;EACJ;AACF,CAAC,CAAC;AAAC,eAEYlB,2BAA2B;AAAA"}
@@ -7,6 +7,8 @@ _Object$defineProperty(exports, "__esModule", {
7
7
  value: true
8
8
  });
9
9
  exports.default = void 0;
10
+ var _regenerator = _interopRequireDefault(require("@babel/runtime-corejs2/regenerator"));
11
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/asyncToGenerator"));
10
12
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
11
13
  var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
12
14
  var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/assertThisInitialized"));
@@ -448,16 +450,17 @@ var CallDiagnosticMetrics = /*#__PURE__*/function (_StatelessWebexPlugin) {
448
450
  }
449
451
 
450
452
  /**
451
- * Submit Client Event CA event.
453
+ * Prepare Client Event CA event.
452
454
  * @param arg - submit params
453
455
  * @param arg.event - event key
454
456
  * @param arg.payload - additional payload to be merged with default payload
455
457
  * @param arg.options - payload
458
+ * @returns {any} options to be with fetch
456
459
  * @throws
457
460
  */
458
461
  }, {
459
- key: "submitClientEvent",
460
- value: function submitClientEvent(_ref5) {
462
+ key: "prepareClientEvent",
463
+ value: function prepareClientEvent(_ref5) {
461
464
  var name = _ref5.name,
462
465
  payload = _ref5.payload,
463
466
  options = _ref5.options;
@@ -486,6 +489,28 @@ var CallDiagnosticMetrics = /*#__PURE__*/function (_StatelessWebexPlugin) {
486
489
 
487
490
  // append client event data to the call diagnostic event
488
491
  var diagnosticEvent = this.prepareDiagnosticEvent(clientEventObject, options);
492
+ return diagnosticEvent;
493
+ }
494
+
495
+ /**
496
+ * Submit Client Event CA event.
497
+ * @param arg - submit params
498
+ * @param arg.event - event key
499
+ * @param arg.payload - additional payload to be merged with default payload
500
+ * @param arg.options - payload
501
+ * @throws
502
+ */
503
+ }, {
504
+ key: "submitClientEvent",
505
+ value: function submitClientEvent(_ref6) {
506
+ var name = _ref6.name,
507
+ payload = _ref6.payload,
508
+ options = _ref6.options;
509
+ var diagnosticEvent = this.prepareClientEvent({
510
+ name: name,
511
+ payload: payload,
512
+ options: options
513
+ });
489
514
  return this.submitToCallDiagnostics(diagnosticEvent);
490
515
  }
491
516
 
@@ -504,6 +529,54 @@ var CallDiagnosticMetrics = /*#__PURE__*/function (_StatelessWebexPlugin) {
504
529
  };
505
530
  return this.callDiagnosticEventsBatcher.request(finalEvent);
506
531
  }
532
+
533
+ /**
534
+ * Builds a request options object to later be passed to fetch().
535
+ * @param arg - submit params
536
+ * @param arg.event - event key
537
+ * @param arg.payload - additional payload to be merged with default payload
538
+ * @param arg.options - client event options
539
+ * @returns {Promise<any>}
540
+ * @throws
541
+ */
542
+ }, {
543
+ key: "buildClientEventFetchRequestOptions",
544
+ value: function () {
545
+ var _buildClientEventFetchRequestOptions = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(_ref7) {
546
+ var name, payload, options, clientEvent, diagnosticEvent;
547
+ return _regenerator.default.wrap(function _callee$(_context) {
548
+ while (1) switch (_context.prev = _context.next) {
549
+ case 0:
550
+ name = _ref7.name, payload = _ref7.payload, options = _ref7.options;
551
+ clientEvent = this.prepareClientEvent({
552
+ name: name,
553
+ payload: payload,
554
+ options: options
555
+ }); // build metrics-a event type
556
+ // @ts-ignore
557
+ diagnosticEvent = (0, _callDiagnosticMetrics.prepareDiagnosticMetricItem)(this.webex, {
558
+ eventPayload: clientEvent,
559
+ type: ['diagnostic-event']
560
+ }); // @ts-ignore
561
+ return _context.abrupt("return", this.webex.prepareFetchOptions({
562
+ method: 'POST',
563
+ service: 'metrics',
564
+ resource: 'clientmetrics',
565
+ body: {
566
+ metrics: [diagnosticEvent]
567
+ }
568
+ }));
569
+ case 4:
570
+ case "end":
571
+ return _context.stop();
572
+ }
573
+ }, _callee, this);
574
+ }));
575
+ function buildClientEventFetchRequestOptions(_x) {
576
+ return _buildClientEventFetchRequestOptions.apply(this, arguments);
577
+ }
578
+ return buildClientEventFetchRequestOptions;
579
+ }()
507
580
  }]);
508
581
  return CallDiagnosticMetrics;
509
582
  }(_webexCore.StatelessWebexPlugin);
@@ -1 +1 @@
1
- {"version":3,"names":["BrowserDetection","getOSVersion","getBrowserName","getBrowserVersion","CallDiagnosticMetrics","args","callDiagnosticEventsBatcher","CallDiagnosticEventsBatcher","parent","webex","canAuthorize","credentials","isUnverifiedGuest","options","meetingId","defaultClientType","meetings","config","metrics","clientType","defaultSubClientType","subClientType","origin","name","networkType","userAgent","userAgentToString","clientName","webexVersion","version","clientInfo","clientVersion","CLIENT_NAME","localNetworkPrefix","anonymizeIPAddress","geoHintInfo","clientAddress","undefined","osVersion","os","getOSNameInternal","browser","browserVersion","meeting","meetingCollection","get","environment","Error","mediaConnections","correlationId","identifiers","internal","device","userId","deviceId","url","orgId","locusUrl","services","locusInfo","fullState","locusId","split","pop","locusStartTime","lastActive","mediaAgentAlias","mediaAgentGroupId","eventData","getOrigin","event","eventId","uuid","v4","originTime","triggered","Date","toISOString","sent","senderCountryCode","countryCode","clearEmptyKeysRecursively","payload","console","warn","submitClientMetrics","CALL_DIAGNOSTIC_EVENT_FAILED_TO_SEND","fields","getIdentifiers","clientEventObject","canProceed","webClientDomain","window","location","hostname","intervals","sourceMetadata","applicationSoftwareType","applicationSoftwareVersion","mediaEngineSoftwareType","mediaEngineSoftwareVersion","startTime","diagnosticEvent","prepareDiagnosticEvent","submitToCallDiagnostics","clientErrorCode","serviceErrorCode","error","partialParsedError","CLIENT_ERROR_CODE_TO_ERROR_PAYLOAD","fatal","shownToUser","category","errorCode","rawError","body","code","SERVICE_ERROR_CODES_TO_CLIENT_ERROR_CODES_MAP","getErrorPayloadForClientErrorCode","isLocusServiceErrorCode","NEW_LOCUS_ERROR_CLIENT_CODE","MEETING_INFO_LOOKUP_ERROR_CLIENT_CODE","errors","generatedError","generateClientEventErrorPayload","push","userType","getCurUserType","loginType","getCurLoginType","createClientEventObjectInMeeting","createClientEventObjectPreMeeting","finalEvent","eventPayload","type","request","StatelessWebexPlugin"],"sources":["call-diagnostic-metrics.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\n/* eslint-disable class-methods-use-this */\n/* eslint-disable valid-jsdoc */\nimport {getOSNameInternal} from '@webex/internal-plugin-metrics';\nimport {BrowserDetection} from '@webex/common';\nimport uuid from 'uuid';\nimport {merge} from 'lodash';\nimport {StatelessWebexPlugin} from '@webex/webex-core';\n\nimport {\n anonymizeIPAddress,\n clearEmptyKeysRecursively,\n isLocusServiceErrorCode,\n userAgentToString,\n} from './call-diagnostic-metrics.util';\nimport {CLIENT_NAME} from '../config';\nimport {\n RecursivePartial,\n Event,\n ClientType,\n SubClientType,\n NetworkType,\n ClientEvent,\n SubmitClientEventOptions,\n MediaQualityEvent,\n SubmitMQEOptions,\n SubmitMQEPayload,\n ClientEventError,\n ClientEventPayload,\n} from '../metrics.types';\nimport CallDiagnosticEventsBatcher from './call-diagnostic-metrics-batcher';\nimport {\n CLIENT_ERROR_CODE_TO_ERROR_PAYLOAD,\n CALL_DIAGNOSTIC_EVENT_FAILED_TO_SEND,\n MEETING_INFO_LOOKUP_ERROR_CLIENT_CODE,\n NEW_LOCUS_ERROR_CLIENT_CODE,\n SERVICE_ERROR_CODES_TO_CLIENT_ERROR_CODES_MAP,\n} from './config';\n\nconst {getOSVersion, getBrowserName, getBrowserVersion} = BrowserDetection();\n\ntype GetOriginOptions = {\n clientType: ClientType;\n subClientType: SubClientType;\n networkType?: NetworkType;\n};\n\ntype GetIdentifiersOptions = {\n meeting?: any;\n mediaConnections?: any[];\n correlationId?: string;\n};\n\n/**\n * @description Util class to handle Call Analyzer Metrics\n * @export\n * @class CallDiagnosticMetrics\n */\nexport default class CallDiagnosticMetrics extends StatelessWebexPlugin {\n // @ts-ignore\n private callDiagnosticEventsBatcher: CallDiagnosticEventsBatcher;\n\n /**\n * Constructor\n * @param args\n */\n constructor(...args) {\n super(...args);\n // @ts-ignore\n this.callDiagnosticEventsBatcher = new CallDiagnosticEventsBatcher({}, {parent: this.webex});\n }\n\n /**\n * Returns the login type of the current user\n * @returns one of 'login-ci','unverified-guest', null\n */\n getCurLoginType() {\n // @ts-ignore\n if (this.webex.canAuthorize) {\n // @ts-ignore\n return this.webex.credentials.isUnverifiedGuest ? 'unverified-guest' : 'login-ci';\n }\n\n return null;\n }\n\n /**\n * Get origin object for Call Diagnostic Event payload.\n * @param options\n * @param meetingId\n * @returns\n */\n getOrigin(options: GetOriginOptions, meetingId?: string) {\n const defaultClientType: ClientType =\n // @ts-ignore\n this.webex.meetings.config?.metrics?.clientType;\n const defaultSubClientType: SubClientType =\n // @ts-ignore\n this.webex.meetings.config?.metrics?.subClientType;\n\n if (\n (defaultClientType && defaultSubClientType) ||\n (options.clientType && options.subClientType)\n ) {\n const origin: Event['origin'] = {\n name: 'endpoint',\n networkType: options?.networkType || 'unknown',\n userAgent: userAgentToString({\n // @ts-ignore\n clientName: this.webex.meetings?.metrics?.clientName,\n // @ts-ignore\n webexVersion: this.webex.version,\n }),\n clientInfo: {\n clientType: options?.clientType || defaultClientType,\n // @ts-ignore\n clientVersion: `${CLIENT_NAME}/${this.webex.version}`,\n localNetworkPrefix:\n // @ts-ignore\n anonymizeIPAddress(this.webex.meetings.geoHintInfo?.clientAddress) || undefined,\n osVersion: getOSVersion() || 'unknown',\n subClientType: options?.subClientType || defaultSubClientType,\n os: getOSNameInternal(),\n browser: getBrowserName(),\n browserVersion: getBrowserVersion(),\n },\n };\n\n if (meetingId) {\n // @ts-ignore\n const meeting = this.webex.meetings.meetingCollection.get(meetingId);\n if (meeting?.environment) {\n origin.environment = meeting.environment;\n }\n }\n\n return origin;\n }\n\n throw new Error(\"ClientType and SubClientType can't be undefined\");\n }\n\n /**\n * Gather identifier details for call diagnostic payload.\n * @throws Error if initialization fails.\n * @param options\n */\n getIdentifiers(options: GetIdentifiersOptions) {\n const {meeting, mediaConnections, correlationId} = options;\n const identifiers: Event['event']['identifiers'] = {correlationId: 'unknown'};\n\n if (meeting) {\n identifiers.correlationId = meeting.correlationId;\n }\n\n if (correlationId) {\n identifiers.correlationId = correlationId;\n }\n // @ts-ignore\n if (this.webex.internal) {\n // @ts-ignore\n const {device} = this.webex.internal;\n identifiers.userId = device.userId;\n identifiers.deviceId = device.url;\n identifiers.orgId = device.orgId;\n // @ts-ignore\n identifiers.locusUrl = this.webex.internal.services.get('locus');\n }\n\n if (meeting?.locusInfo?.fullState) {\n identifiers.locusUrl = meeting.locusUrl;\n identifiers.locusId = meeting.locusUrl && meeting.locusUrl.split('/').pop();\n identifiers.locusStartTime =\n meeting.locusInfo.fullState && meeting.locusInfo.fullState.lastActive;\n }\n\n if (mediaConnections) {\n identifiers.mediaAgentAlias = mediaConnections?.[0]?.mediaAgentAlias;\n identifiers.mediaAgentGroupId = mediaConnections?.[0]?.mediaAgentGroupId;\n }\n\n if (identifiers.correlationId === undefined) {\n throw new Error('Identifiers initialization failed.');\n }\n\n return identifiers;\n }\n\n /**\n * Create diagnostic event, which can hold client event, feature event or MQE event data.\n * This just initiates the shared properties that are required for all the 3 event categories.\n * @param eventData\n * @param options\n * @returns\n */\n prepareDiagnosticEvent(eventData: Event['event'], options: any) {\n const {meetingId} = options;\n const origin = this.getOrigin(options, meetingId);\n\n const event: Event = {\n eventId: uuid.v4(),\n version: 1,\n origin,\n originTime: {\n triggered: new Date().toISOString(),\n // is overridden in prepareRequest batcher\n sent: 'not_defined_yet',\n },\n // @ts-ignore\n senderCountryCode: this.webex.meetings.geoHintInfo?.countryCode,\n event: eventData,\n };\n\n // sanitize (remove empty properties, CA requires it)\n // but we don't want to sanitize MQE as most of the times\n // values will be 0, [] etc, and they are required.\n if (eventData.name !== 'client.mediaquality.event') {\n clearEmptyKeysRecursively(event);\n }\n\n return event;\n }\n\n /**\n * TODO: NOT IMPLEMENTED\n * Submit Feature Event\n * @returns\n */\n public submitFeatureEvent() {\n throw Error('Not implemented');\n }\n\n /**\n * Submit Media Quality Event\n * @param args - submit params\n * @param arg.name - event key\n * @param arg.payload - additional payload to be merge with the default payload\n * @param arg.options - options\n */\n submitMQE({\n name,\n payload,\n options,\n }: {\n name: MediaQualityEvent['name'];\n payload: SubmitMQEPayload;\n options: SubmitMQEOptions;\n }) {\n const {meetingId, mediaConnections} = options;\n\n // events that will most likely happen in join phase\n if (meetingId) {\n // @ts-ignore\n const meeting = this.webex.meetings.meetingCollection.get(meetingId);\n\n if (!meeting) {\n console.warn(\n 'Attempt to send MQE but no meeting was found...',\n `event: ${name}, meetingId: ${meetingId}`\n );\n // @ts-ignore\n this.webex.internal.metrics.submitClientMetrics(CALL_DIAGNOSTIC_EVENT_FAILED_TO_SEND, {\n fields: {\n meetingId,\n name,\n },\n });\n\n return;\n }\n\n // merge identifiers\n const identifiers = this.getIdentifiers({\n meeting,\n mediaConnections: meeting.mediaConnections || mediaConnections,\n });\n\n // create media quality event object\n let clientEventObject: MediaQualityEvent['payload'] = {\n name,\n canProceed: true,\n identifiers,\n eventData: {\n webClientDomain: window.location.hostname,\n },\n intervals: payload.intervals,\n sourceMetadata: {\n applicationSoftwareType: CLIENT_NAME,\n // @ts-ignore\n applicationSoftwareVersion: this.webex.version,\n mediaEngineSoftwareType: getBrowserName() || 'browser',\n mediaEngineSoftwareVersion: getOSVersion() || 'unknown',\n startTime: new Date().toISOString(),\n },\n };\n\n // merge any new properties, or override existing ones\n clientEventObject = merge(clientEventObject, payload);\n\n // append media quality event data to the call diagnostic event\n const diagnosticEvent = this.prepareDiagnosticEvent(clientEventObject, options);\n this.submitToCallDiagnostics(diagnosticEvent);\n } else {\n throw new Error(\n 'Media quality events cant be sent outside the context of a meeting. Meeting id is required.'\n );\n }\n }\n\n /**\n * Return Client Event payload by client error code\n * @param arg - get error arg\n * @param arg.clientErrorCode\n * @param arg.serviceErrorCode\n * @returns\n */\n public getErrorPayloadForClientErrorCode({\n clientErrorCode,\n serviceErrorCode,\n }: {\n clientErrorCode: number;\n serviceErrorCode: any;\n }): ClientEventError {\n let error: ClientEventError;\n\n if (clientErrorCode) {\n const partialParsedError = CLIENT_ERROR_CODE_TO_ERROR_PAYLOAD[clientErrorCode];\n\n if (partialParsedError) {\n error = merge(\n {fatal: true, shownToUser: false, name: 'other', category: 'other'}, // default values\n {errorCode: clientErrorCode},\n {serviceErrorCode},\n partialParsedError\n );\n\n return error;\n }\n }\n\n return undefined;\n }\n\n /**\n * Generate error payload for Client Event\n * @param rawError\n */\n generateClientEventErrorPayload(rawError: any) {\n const serviceErrorCode = rawError?.body?.errorCode || rawError?.body?.code;\n if (serviceErrorCode) {\n const clientErrorCode = SERVICE_ERROR_CODES_TO_CLIENT_ERROR_CODES_MAP[serviceErrorCode];\n if (clientErrorCode) {\n return this.getErrorPayloadForClientErrorCode({clientErrorCode, serviceErrorCode});\n }\n\n // by default, if it is locus error, return nre locus err\n if (isLocusServiceErrorCode(serviceErrorCode)) {\n return this.getErrorPayloadForClientErrorCode({\n clientErrorCode: NEW_LOCUS_ERROR_CLIENT_CODE,\n serviceErrorCode,\n });\n }\n\n // otherwise return meeting info\n return this.getErrorPayloadForClientErrorCode({\n clientErrorCode: MEETING_INFO_LOOKUP_ERROR_CLIENT_CODE,\n serviceErrorCode,\n });\n }\n\n return undefined;\n }\n\n /**\n * Create client event object for in meeting events\n * @param arg - create args\n * @param arg.event - event key\n * @param arg.options - options\n * @returns object\n */\n private createClientEventObjectInMeeting({\n name,\n options,\n }: {\n name: ClientEvent['name'];\n options: SubmitClientEventOptions;\n }) {\n const {meetingId, mediaConnections, rawError} = options;\n\n // @ts-ignore\n const meeting = this.webex.meetings.meetingCollection.get(meetingId);\n\n if (!meeting) {\n console.warn(\n 'Attempt to send client event but no meeting was found...',\n `event: ${name}, meetingId: ${meetingId}`\n );\n // @ts-ignore\n this.webex.internal.metrics.submitClientMetrics(CALL_DIAGNOSTIC_EVENT_FAILED_TO_SEND, {\n fields: {\n meetingId,\n name,\n },\n });\n\n return undefined;\n }\n\n // grab identifiers\n const identifiers = this.getIdentifiers({\n meeting,\n mediaConnections: meeting?.mediaConnections || mediaConnections,\n });\n\n // check if we need to generate errors\n const errors: ClientEvent['payload']['errors'] = [];\n\n if (rawError) {\n const generatedError = this.generateClientEventErrorPayload(rawError);\n if (generatedError) {\n errors.push(generatedError);\n }\n }\n\n // create client event object\n const clientEventObject: ClientEvent['payload'] = {\n name,\n canProceed: true,\n identifiers,\n errors,\n eventData: {\n webClientDomain: window.location.hostname,\n },\n userType: meeting.getCurUserType(),\n loginType: this.getCurLoginType(),\n };\n\n return clientEventObject;\n }\n\n /**\n * Create client event object for pre meeting events\n * @param arg - create args\n * @param arg.event - event key\n * @param arg.options - payload\n * @returns object\n */\n private createClientEventObjectPreMeeting({\n name,\n options,\n }: {\n name: ClientEvent['name'];\n options: SubmitClientEventOptions;\n }) {\n const {correlationId} = options;\n\n // grab identifiers\n const identifiers = this.getIdentifiers({\n correlationId,\n });\n\n // create client event object\n const clientEventObject: ClientEvent['payload'] = {\n name,\n canProceed: true,\n identifiers,\n eventData: {\n webClientDomain: window.location.hostname,\n },\n loginType: this.getCurLoginType(),\n };\n\n return clientEventObject;\n }\n\n /**\n * Submit Client Event CA event.\n * @param arg - submit params\n * @param arg.event - event key\n * @param arg.payload - additional payload to be merged with default payload\n * @param arg.options - payload\n * @throws\n */\n public submitClientEvent({\n name,\n payload,\n options,\n }: {\n name: ClientEvent['name'];\n payload?: ClientEventPayload;\n options: SubmitClientEventOptions;\n }) {\n const {meetingId, correlationId} = options;\n let clientEventObject: ClientEvent['payload'];\n\n // events that will most likely happen in join phase\n if (meetingId) {\n clientEventObject = this.createClientEventObjectInMeeting({name, options});\n } else if (correlationId) {\n // any pre join events or events that are outside the meeting.\n clientEventObject = this.createClientEventObjectPreMeeting({name, options});\n } else {\n throw new Error('Not implemented');\n }\n\n // merge any new properties, or override existing ones\n clientEventObject = merge(clientEventObject, payload);\n\n // append client event data to the call diagnostic event\n const diagnosticEvent = this.prepareDiagnosticEvent(clientEventObject, options);\n\n return this.submitToCallDiagnostics(diagnosticEvent);\n }\n\n /**\n * Prepare the event and send the request to metrics-a service.\n * @param event\n * @returns promise\n */\n submitToCallDiagnostics(event: Event): Promise<any> {\n // build metrics-a event type\n const finalEvent = {\n eventPayload: event,\n type: ['diagnostic-event'],\n };\n\n return this.callDiagnosticEventsBatcher.request(finalEvent);\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["BrowserDetection","getOSVersion","getBrowserName","getBrowserVersion","CallDiagnosticMetrics","args","callDiagnosticEventsBatcher","CallDiagnosticEventsBatcher","parent","webex","canAuthorize","credentials","isUnverifiedGuest","options","meetingId","defaultClientType","meetings","config","metrics","clientType","defaultSubClientType","subClientType","origin","name","networkType","userAgent","userAgentToString","clientName","webexVersion","version","clientInfo","clientVersion","CLIENT_NAME","localNetworkPrefix","anonymizeIPAddress","geoHintInfo","clientAddress","undefined","osVersion","os","getOSNameInternal","browser","browserVersion","meeting","meetingCollection","get","environment","Error","mediaConnections","correlationId","identifiers","internal","device","userId","deviceId","url","orgId","locusUrl","services","locusInfo","fullState","locusId","split","pop","locusStartTime","lastActive","mediaAgentAlias","mediaAgentGroupId","eventData","getOrigin","event","eventId","uuid","v4","originTime","triggered","Date","toISOString","sent","senderCountryCode","countryCode","clearEmptyKeysRecursively","payload","console","warn","submitClientMetrics","CALL_DIAGNOSTIC_EVENT_FAILED_TO_SEND","fields","getIdentifiers","clientEventObject","canProceed","webClientDomain","window","location","hostname","intervals","sourceMetadata","applicationSoftwareType","applicationSoftwareVersion","mediaEngineSoftwareType","mediaEngineSoftwareVersion","startTime","diagnosticEvent","prepareDiagnosticEvent","submitToCallDiagnostics","clientErrorCode","serviceErrorCode","error","partialParsedError","CLIENT_ERROR_CODE_TO_ERROR_PAYLOAD","fatal","shownToUser","category","errorCode","rawError","body","code","SERVICE_ERROR_CODES_TO_CLIENT_ERROR_CODES_MAP","getErrorPayloadForClientErrorCode","isLocusServiceErrorCode","NEW_LOCUS_ERROR_CLIENT_CODE","MEETING_INFO_LOOKUP_ERROR_CLIENT_CODE","errors","generatedError","generateClientEventErrorPayload","push","userType","getCurUserType","loginType","getCurLoginType","createClientEventObjectInMeeting","createClientEventObjectPreMeeting","prepareClientEvent","finalEvent","eventPayload","type","request","clientEvent","prepareDiagnosticMetricItem","prepareFetchOptions","method","service","resource","StatelessWebexPlugin"],"sources":["call-diagnostic-metrics.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\n/* eslint-disable class-methods-use-this */\n/* eslint-disable valid-jsdoc */\nimport {getOSNameInternal} from '@webex/internal-plugin-metrics';\nimport {BrowserDetection} from '@webex/common';\nimport uuid from 'uuid';\nimport {merge} from 'lodash';\nimport {StatelessWebexPlugin} from '@webex/webex-core';\n\nimport {\n anonymizeIPAddress,\n clearEmptyKeysRecursively,\n isLocusServiceErrorCode,\n prepareDiagnosticMetricItem,\n userAgentToString,\n} from './call-diagnostic-metrics.util';\nimport {CLIENT_NAME} from '../config';\nimport {\n RecursivePartial,\n Event,\n ClientType,\n SubClientType,\n NetworkType,\n ClientEvent,\n SubmitClientEventOptions,\n MediaQualityEvent,\n SubmitMQEOptions,\n SubmitMQEPayload,\n ClientEventError,\n ClientEventPayload,\n} from '../metrics.types';\nimport CallDiagnosticEventsBatcher from './call-diagnostic-metrics-batcher';\nimport {\n CLIENT_ERROR_CODE_TO_ERROR_PAYLOAD,\n CALL_DIAGNOSTIC_EVENT_FAILED_TO_SEND,\n MEETING_INFO_LOOKUP_ERROR_CLIENT_CODE,\n NEW_LOCUS_ERROR_CLIENT_CODE,\n SERVICE_ERROR_CODES_TO_CLIENT_ERROR_CODES_MAP,\n} from './config';\n\nconst {getOSVersion, getBrowserName, getBrowserVersion} = BrowserDetection();\n\ntype GetOriginOptions = {\n clientType: ClientType;\n subClientType: SubClientType;\n networkType?: NetworkType;\n};\n\ntype GetIdentifiersOptions = {\n meeting?: any;\n mediaConnections?: any[];\n correlationId?: string;\n};\n\n/**\n * @description Util class to handle Call Analyzer Metrics\n * @export\n * @class CallDiagnosticMetrics\n */\nexport default class CallDiagnosticMetrics extends StatelessWebexPlugin {\n // @ts-ignore\n private callDiagnosticEventsBatcher: CallDiagnosticEventsBatcher;\n\n /**\n * Constructor\n * @param args\n */\n constructor(...args) {\n super(...args);\n // @ts-ignore\n this.callDiagnosticEventsBatcher = new CallDiagnosticEventsBatcher({}, {parent: this.webex});\n }\n\n /**\n * Returns the login type of the current user\n * @returns one of 'login-ci','unverified-guest', null\n */\n getCurLoginType() {\n // @ts-ignore\n if (this.webex.canAuthorize) {\n // @ts-ignore\n return this.webex.credentials.isUnverifiedGuest ? 'unverified-guest' : 'login-ci';\n }\n\n return null;\n }\n\n /**\n * Get origin object for Call Diagnostic Event payload.\n * @param options\n * @param meetingId\n * @returns\n */\n getOrigin(options: GetOriginOptions, meetingId?: string) {\n const defaultClientType: ClientType =\n // @ts-ignore\n this.webex.meetings.config?.metrics?.clientType;\n const defaultSubClientType: SubClientType =\n // @ts-ignore\n this.webex.meetings.config?.metrics?.subClientType;\n\n if (\n (defaultClientType && defaultSubClientType) ||\n (options.clientType && options.subClientType)\n ) {\n const origin: Event['origin'] = {\n name: 'endpoint',\n networkType: options?.networkType || 'unknown',\n userAgent: userAgentToString({\n // @ts-ignore\n clientName: this.webex.meetings?.metrics?.clientName,\n // @ts-ignore\n webexVersion: this.webex.version,\n }),\n clientInfo: {\n clientType: options?.clientType || defaultClientType,\n // @ts-ignore\n clientVersion: `${CLIENT_NAME}/${this.webex.version}`,\n localNetworkPrefix:\n // @ts-ignore\n anonymizeIPAddress(this.webex.meetings.geoHintInfo?.clientAddress) || undefined,\n osVersion: getOSVersion() || 'unknown',\n subClientType: options?.subClientType || defaultSubClientType,\n os: getOSNameInternal(),\n browser: getBrowserName(),\n browserVersion: getBrowserVersion(),\n },\n };\n\n if (meetingId) {\n // @ts-ignore\n const meeting = this.webex.meetings.meetingCollection.get(meetingId);\n if (meeting?.environment) {\n origin.environment = meeting.environment;\n }\n }\n\n return origin;\n }\n\n throw new Error(\"ClientType and SubClientType can't be undefined\");\n }\n\n /**\n * Gather identifier details for call diagnostic payload.\n * @throws Error if initialization fails.\n * @param options\n */\n getIdentifiers(options: GetIdentifiersOptions) {\n const {meeting, mediaConnections, correlationId} = options;\n const identifiers: Event['event']['identifiers'] = {correlationId: 'unknown'};\n\n if (meeting) {\n identifiers.correlationId = meeting.correlationId;\n }\n\n if (correlationId) {\n identifiers.correlationId = correlationId;\n }\n // @ts-ignore\n if (this.webex.internal) {\n // @ts-ignore\n const {device} = this.webex.internal;\n identifiers.userId = device.userId;\n identifiers.deviceId = device.url;\n identifiers.orgId = device.orgId;\n // @ts-ignore\n identifiers.locusUrl = this.webex.internal.services.get('locus');\n }\n\n if (meeting?.locusInfo?.fullState) {\n identifiers.locusUrl = meeting.locusUrl;\n identifiers.locusId = meeting.locusUrl && meeting.locusUrl.split('/').pop();\n identifiers.locusStartTime =\n meeting.locusInfo.fullState && meeting.locusInfo.fullState.lastActive;\n }\n\n if (mediaConnections) {\n identifiers.mediaAgentAlias = mediaConnections?.[0]?.mediaAgentAlias;\n identifiers.mediaAgentGroupId = mediaConnections?.[0]?.mediaAgentGroupId;\n }\n\n if (identifiers.correlationId === undefined) {\n throw new Error('Identifiers initialization failed.');\n }\n\n return identifiers;\n }\n\n /**\n * Create diagnostic event, which can hold client event, feature event or MQE event data.\n * This just initiates the shared properties that are required for all the 3 event categories.\n * @param eventData\n * @param options\n * @returns\n */\n prepareDiagnosticEvent(eventData: Event['event'], options: any) {\n const {meetingId} = options;\n const origin = this.getOrigin(options, meetingId);\n\n const event: Event = {\n eventId: uuid.v4(),\n version: 1,\n origin,\n originTime: {\n triggered: new Date().toISOString(),\n // is overridden in prepareRequest batcher\n sent: 'not_defined_yet',\n },\n // @ts-ignore\n senderCountryCode: this.webex.meetings.geoHintInfo?.countryCode,\n event: eventData,\n };\n\n // sanitize (remove empty properties, CA requires it)\n // but we don't want to sanitize MQE as most of the times\n // values will be 0, [] etc, and they are required.\n if (eventData.name !== 'client.mediaquality.event') {\n clearEmptyKeysRecursively(event);\n }\n\n return event;\n }\n\n /**\n * TODO: NOT IMPLEMENTED\n * Submit Feature Event\n * @returns\n */\n public submitFeatureEvent() {\n throw Error('Not implemented');\n }\n\n /**\n * Submit Media Quality Event\n * @param args - submit params\n * @param arg.name - event key\n * @param arg.payload - additional payload to be merge with the default payload\n * @param arg.options - options\n */\n submitMQE({\n name,\n payload,\n options,\n }: {\n name: MediaQualityEvent['name'];\n payload: SubmitMQEPayload;\n options: SubmitMQEOptions;\n }) {\n const {meetingId, mediaConnections} = options;\n\n // events that will most likely happen in join phase\n if (meetingId) {\n // @ts-ignore\n const meeting = this.webex.meetings.meetingCollection.get(meetingId);\n\n if (!meeting) {\n console.warn(\n 'Attempt to send MQE but no meeting was found...',\n `event: ${name}, meetingId: ${meetingId}`\n );\n // @ts-ignore\n this.webex.internal.metrics.submitClientMetrics(CALL_DIAGNOSTIC_EVENT_FAILED_TO_SEND, {\n fields: {\n meetingId,\n name,\n },\n });\n\n return;\n }\n\n // merge identifiers\n const identifiers = this.getIdentifiers({\n meeting,\n mediaConnections: meeting.mediaConnections || mediaConnections,\n });\n\n // create media quality event object\n let clientEventObject: MediaQualityEvent['payload'] = {\n name,\n canProceed: true,\n identifiers,\n eventData: {\n webClientDomain: window.location.hostname,\n },\n intervals: payload.intervals,\n sourceMetadata: {\n applicationSoftwareType: CLIENT_NAME,\n // @ts-ignore\n applicationSoftwareVersion: this.webex.version,\n mediaEngineSoftwareType: getBrowserName() || 'browser',\n mediaEngineSoftwareVersion: getOSVersion() || 'unknown',\n startTime: new Date().toISOString(),\n },\n };\n\n // merge any new properties, or override existing ones\n clientEventObject = merge(clientEventObject, payload);\n\n // append media quality event data to the call diagnostic event\n const diagnosticEvent = this.prepareDiagnosticEvent(clientEventObject, options);\n this.submitToCallDiagnostics(diagnosticEvent);\n } else {\n throw new Error(\n 'Media quality events cant be sent outside the context of a meeting. Meeting id is required.'\n );\n }\n }\n\n /**\n * Return Client Event payload by client error code\n * @param arg - get error arg\n * @param arg.clientErrorCode\n * @param arg.serviceErrorCode\n * @returns\n */\n public getErrorPayloadForClientErrorCode({\n clientErrorCode,\n serviceErrorCode,\n }: {\n clientErrorCode: number;\n serviceErrorCode: any;\n }): ClientEventError {\n let error: ClientEventError;\n\n if (clientErrorCode) {\n const partialParsedError = CLIENT_ERROR_CODE_TO_ERROR_PAYLOAD[clientErrorCode];\n\n if (partialParsedError) {\n error = merge(\n {fatal: true, shownToUser: false, name: 'other', category: 'other'}, // default values\n {errorCode: clientErrorCode},\n {serviceErrorCode},\n partialParsedError\n );\n\n return error;\n }\n }\n\n return undefined;\n }\n\n /**\n * Generate error payload for Client Event\n * @param rawError\n */\n generateClientEventErrorPayload(rawError: any) {\n const serviceErrorCode = rawError?.body?.errorCode || rawError?.body?.code;\n if (serviceErrorCode) {\n const clientErrorCode = SERVICE_ERROR_CODES_TO_CLIENT_ERROR_CODES_MAP[serviceErrorCode];\n if (clientErrorCode) {\n return this.getErrorPayloadForClientErrorCode({clientErrorCode, serviceErrorCode});\n }\n\n // by default, if it is locus error, return nre locus err\n if (isLocusServiceErrorCode(serviceErrorCode)) {\n return this.getErrorPayloadForClientErrorCode({\n clientErrorCode: NEW_LOCUS_ERROR_CLIENT_CODE,\n serviceErrorCode,\n });\n }\n\n // otherwise return meeting info\n return this.getErrorPayloadForClientErrorCode({\n clientErrorCode: MEETING_INFO_LOOKUP_ERROR_CLIENT_CODE,\n serviceErrorCode,\n });\n }\n\n return undefined;\n }\n\n /**\n * Create client event object for in meeting events\n * @param arg - create args\n * @param arg.event - event key\n * @param arg.options - options\n * @returns object\n */\n private createClientEventObjectInMeeting({\n name,\n options,\n }: {\n name: ClientEvent['name'];\n options: SubmitClientEventOptions;\n }) {\n const {meetingId, mediaConnections, rawError} = options;\n\n // @ts-ignore\n const meeting = this.webex.meetings.meetingCollection.get(meetingId);\n\n if (!meeting) {\n console.warn(\n 'Attempt to send client event but no meeting was found...',\n `event: ${name}, meetingId: ${meetingId}`\n );\n // @ts-ignore\n this.webex.internal.metrics.submitClientMetrics(CALL_DIAGNOSTIC_EVENT_FAILED_TO_SEND, {\n fields: {\n meetingId,\n name,\n },\n });\n\n return undefined;\n }\n\n // grab identifiers\n const identifiers = this.getIdentifiers({\n meeting,\n mediaConnections: meeting?.mediaConnections || mediaConnections,\n });\n\n // check if we need to generate errors\n const errors: ClientEvent['payload']['errors'] = [];\n\n if (rawError) {\n const generatedError = this.generateClientEventErrorPayload(rawError);\n if (generatedError) {\n errors.push(generatedError);\n }\n }\n\n // create client event object\n const clientEventObject: ClientEvent['payload'] = {\n name,\n canProceed: true,\n identifiers,\n errors,\n eventData: {\n webClientDomain: window.location.hostname,\n },\n userType: meeting.getCurUserType(),\n loginType: this.getCurLoginType(),\n };\n\n return clientEventObject;\n }\n\n /**\n * Create client event object for pre meeting events\n * @param arg - create args\n * @param arg.event - event key\n * @param arg.options - payload\n * @returns object\n */\n private createClientEventObjectPreMeeting({\n name,\n options,\n }: {\n name: ClientEvent['name'];\n options: SubmitClientEventOptions;\n }) {\n const {correlationId} = options;\n\n // grab identifiers\n const identifiers = this.getIdentifiers({\n correlationId,\n });\n\n // create client event object\n const clientEventObject: ClientEvent['payload'] = {\n name,\n canProceed: true,\n identifiers,\n eventData: {\n webClientDomain: window.location.hostname,\n },\n loginType: this.getCurLoginType(),\n };\n\n return clientEventObject;\n }\n\n /**\n * Prepare Client Event CA event.\n * @param arg - submit params\n * @param arg.event - event key\n * @param arg.payload - additional payload to be merged with default payload\n * @param arg.options - payload\n * @returns {any} options to be with fetch\n * @throws\n */\n private prepareClientEvent({\n name,\n payload,\n options,\n }: {\n name: ClientEvent['name'];\n payload?: ClientEventPayload;\n options: SubmitClientEventOptions;\n }) {\n const {meetingId, correlationId} = options;\n let clientEventObject: ClientEvent['payload'];\n\n // events that will most likely happen in join phase\n if (meetingId) {\n clientEventObject = this.createClientEventObjectInMeeting({name, options});\n } else if (correlationId) {\n // any pre join events or events that are outside the meeting.\n clientEventObject = this.createClientEventObjectPreMeeting({name, options});\n } else {\n throw new Error('Not implemented');\n }\n\n // merge any new properties, or override existing ones\n clientEventObject = merge(clientEventObject, payload);\n\n // append client event data to the call diagnostic event\n const diagnosticEvent = this.prepareDiagnosticEvent(clientEventObject, options);\n\n return diagnosticEvent;\n }\n\n /**\n * Submit Client Event CA event.\n * @param arg - submit params\n * @param arg.event - event key\n * @param arg.payload - additional payload to be merged with default payload\n * @param arg.options - payload\n * @throws\n */\n public submitClientEvent({\n name,\n payload,\n options,\n }: {\n name: ClientEvent['name'];\n payload?: ClientEventPayload;\n options: SubmitClientEventOptions;\n }) {\n const diagnosticEvent = this.prepareClientEvent({name, payload, options});\n\n return this.submitToCallDiagnostics(diagnosticEvent);\n }\n\n /**\n * Prepare the event and send the request to metrics-a service.\n * @param event\n * @returns promise\n */\n submitToCallDiagnostics(event: Event): Promise<any> {\n // build metrics-a event type\n const finalEvent = {\n eventPayload: event,\n type: ['diagnostic-event'],\n };\n\n return this.callDiagnosticEventsBatcher.request(finalEvent);\n }\n\n /**\n * Builds a request options object to later be passed to fetch().\n * @param arg - submit params\n * @param arg.event - event key\n * @param arg.payload - additional payload to be merged with default payload\n * @param arg.options - client event options\n * @returns {Promise<any>}\n * @throws\n */\n public async buildClientEventFetchRequestOptions({\n name,\n payload,\n options,\n }: {\n name: ClientEvent['name'];\n payload?: ClientEventPayload;\n options: SubmitClientEventOptions;\n }): Promise<any> {\n const clientEvent = this.prepareClientEvent({name, payload, options});\n\n // build metrics-a event type\n // @ts-ignore\n const diagnosticEvent = prepareDiagnosticMetricItem(this.webex, {\n eventPayload: clientEvent,\n type: ['diagnostic-event'],\n });\n\n // @ts-ignore\n return this.webex.prepareFetchOptions({\n method: 'POST',\n service: 'metrics',\n resource: 'clientmetrics',\n body: {\n metrics: [diagnosticEvent],\n },\n });\n }\n}\n"],"mappings":"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"}
@@ -5,11 +5,13 @@ var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequ
5
5
  _Object$defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.userAgentToString = exports.isLocusServiceErrorCode = exports.clearEmptyKeysRecursively = exports.anonymizeIPAddress = void 0;
8
+ exports.userAgentToString = exports.setMetricTimings = exports.prepareDiagnosticMetricItem = exports.isLocusServiceErrorCode = exports.getBuildType = exports.clearEmptyKeysRecursively = exports.anonymizeIPAddress = void 0;
9
9
  var _keys = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/keys"));
10
10
  var _isArray = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/array/is-array"));
11
+ var _assign = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/assign"));
11
12
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/toConsumableArray"));
12
13
  var _typeof2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/typeof"));
14
+ var _merge2 = _interopRequireDefault(require("lodash/merge"));
13
15
  var _isEmpty2 = _interopRequireDefault(require("lodash/isEmpty"));
14
16
  var _ipAnonymize = _interopRequireDefault(require("ip-anonymize"));
15
17
  var _util = _interopRequireDefault(require("util"));
@@ -102,5 +104,122 @@ var isLocusServiceErrorCode = function isLocusServiceErrorCode(errorCode) {
102
104
  }
103
105
  return false;
104
106
  };
107
+
108
+ /**
109
+ * @param webClientDomain
110
+ * @returns
111
+ */
105
112
  exports.isLocusServiceErrorCode = isLocusServiceErrorCode;
113
+ var getBuildType = function getBuildType(webClientDomain) {
114
+ if (webClientDomain !== null && webClientDomain !== void 0 && webClientDomain.includes('localhost') || webClientDomain !== null && webClientDomain !== void 0 && webClientDomain.includes('127.0.0.1') || process.env.NODE_ENV !== 'production') {
115
+ return 'test';
116
+ }
117
+ return 'production';
118
+ };
119
+
120
+ /**
121
+ * Prepare metric item for submission.
122
+ * @param {Object} webex sdk instance
123
+ * @param {Object} item
124
+ * @returns {Object} prepared item
125
+ */
126
+ exports.getBuildType = getBuildType;
127
+ var prepareDiagnosticMetricItem = function prepareDiagnosticMetricItem(webex, item) {
128
+ var _item$event, _item$event$eventData, _item$eventPayload, _item$eventPayload$ev;
129
+ var origin = {
130
+ buildType: getBuildType((_item$event = item.event) === null || _item$event === void 0 ? void 0 : (_item$event$eventData = _item$event.eventData) === null || _item$event$eventData === void 0 ? void 0 : _item$event$eventData.webClientDomain),
131
+ networkType: 'unknown'
132
+ };
133
+
134
+ // check event names and append latencies?
135
+ var eventName = (_item$eventPayload = item.eventPayload) === null || _item$eventPayload === void 0 ? void 0 : (_item$eventPayload$ev = _item$eventPayload.event) === null || _item$eventPayload$ev === void 0 ? void 0 : _item$eventPayload$ev.name;
136
+ var joinTimes = {};
137
+ var audioSetupDelay = {};
138
+ var videoSetupDelay = {};
139
+ var cdl = webex.internal.newMetrics.callDiagnosticLatencies;
140
+ switch (eventName) {
141
+ case 'client.interstitial-window.launched':
142
+ joinTimes.meetingInfoReqResp = cdl.getMeetingInfoReqResp();
143
+ joinTimes.clickToInterstitial = cdl.getClickToInterstitial();
144
+ break;
145
+ case 'client.call.initiated':
146
+ joinTimes.meetingInfoReqResp = cdl.getMeetingInfoReqResp();
147
+ joinTimes.showInterstitialTime = cdl.getShowInterstitialTime();
148
+ break;
149
+ case 'client.locus.join.response':
150
+ joinTimes.meetingInfoReqResp = cdl.getMeetingInfoReqResp();
151
+ joinTimes.callInitJoinReq = cdl.getCallInitJoinReq();
152
+ joinTimes.joinReqResp = cdl.getJoinReqResp();
153
+ joinTimes.joinReqSentReceived = cdl.getJoinRespSentReceived();
154
+ joinTimes.pageJmt = cdl.getPageJMT();
155
+ joinTimes.clickToInterstitial = cdl.getClickToInterstitial();
156
+ joinTimes.interstitialToJoinOK = cdl.getInterstitialToJoinOK();
157
+ joinTimes.totalJmt = cdl.getTotalJMT();
158
+ joinTimes.clientJmt = cdl.getClientJMT();
159
+ break;
160
+ case 'client.ice.end':
161
+ joinTimes.ICESetupTime = cdl.getICESetupTime();
162
+ joinTimes.audioICESetupTime = cdl.getAudioICESetupTime();
163
+ joinTimes.videoICESetupTime = cdl.getVideoICESetupTime();
164
+ joinTimes.shareICESetupTime = cdl.getShareICESetupTime();
165
+ break;
166
+ case 'client.media.rx.start':
167
+ joinTimes.localSDPGenRemoteSDPRecv = cdl.getLocalSDPGenRemoteSDPRecv();
168
+ break;
169
+ case 'client.media-engine.ready':
170
+ joinTimes.totalMediaJMT = cdl.getTotalMediaJMT();
171
+ joinTimes.interstitialToMediaOKJMT = cdl.getInterstitialToMediaOKJMT();
172
+ joinTimes.callInitMediaEngineReady = cdl.getCallInitMediaEngineReady();
173
+ joinTimes.stayLobbyTime = cdl.getStayLobbyTime();
174
+ break;
175
+ case 'client.mediaquality.event':
176
+ audioSetupDelay.joinRespRxStart = cdl.getAudioJoinRespRxStart();
177
+ audioSetupDelay.joinRespTxStart = cdl.getAudioJoinRespTxStart();
178
+ videoSetupDelay.joinRespRxStart = cdl.getVideoJoinRespRxStart();
179
+ videoSetupDelay.joinRespTxStart = cdl.getVideoJoinRespTxStart();
180
+ }
181
+ if (!(0, _isEmpty2.default)(joinTimes)) {
182
+ item.eventPayload.event = (0, _merge2.default)(item.eventPayload.event, {
183
+ joinTimes: joinTimes
184
+ });
185
+ }
186
+ if (!(0, _isEmpty2.default)(audioSetupDelay)) {
187
+ item.eventPayload.event = (0, _merge2.default)(item.eventPayload.event, {
188
+ audioSetupDelay: audioSetupDelay
189
+ });
190
+ }
191
+ if (!(0, _isEmpty2.default)(videoSetupDelay)) {
192
+ item.eventPayload.event = (0, _merge2.default)(item.eventPayload.event, {
193
+ videoSetupDelay: videoSetupDelay
194
+ });
195
+ }
196
+ item.eventPayload.origin = (0, _assign.default)(origin, item.eventPayload.origin);
197
+ return item;
198
+ };
199
+
200
+ /**
201
+ * Sets the originTime value(s) before the request/fetch.
202
+ * This function is only useful if you are about to submit a metrics
203
+ * request using pre-built fetch options;
204
+ *
205
+ * @param {any} options
206
+ * @returns {any} the updated options object
207
+ */
208
+ exports.prepareDiagnosticMetricItem = prepareDiagnosticMetricItem;
209
+ var setMetricTimings = function setMetricTimings(options) {
210
+ var _options$body;
211
+ if ((_options$body = options.body) !== null && _options$body !== void 0 && _options$body.metrics) {
212
+ var now = new Date().toISOString();
213
+ options.body.metrics.forEach(function (metric) {
214
+ if (metric.eventPayload) {
215
+ metric.eventPayload.originTime = {
216
+ triggered: now,
217
+ sent: now
218
+ };
219
+ }
220
+ });
221
+ }
222
+ return options;
223
+ };
224
+ exports.setMetricTimings = setMetricTimings;
106
225
  //# sourceMappingURL=call-diagnostic-metrics.util.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["BrowserDetection","getOSName","getOSVersion","getBrowserName","getBrowserVersion","anonymizeIPAddress","localIp","anonymize","userAgentToString","clientName","webexVersion","userAgentOption","browserInfo","clientInfo","util","format","indexOf","toLowerCase","split","osInfo","process","env","NODE_ENV","clearEmptyKeysRecursively","obj","length","forEach","key","filter","x","isLocusServiceErrorCode","errorCode","code","charAt"],"sources":["call-diagnostic-metrics.util.ts"],"sourcesContent":["/* eslint-disable valid-jsdoc */\nimport anonymize from 'ip-anonymize';\nimport util from 'util';\n\nimport {BrowserDetection} from '@webex/common';\nimport {isEmpty} from 'lodash';\n\nconst {getOSName, getOSVersion, getBrowserName, getBrowserVersion} = BrowserDetection();\n\nexport const anonymizeIPAddress = (localIp) => anonymize(localIp, 28, 96);\n\n/**\n * Returns a formated string of the user agent.\n *\n * @returns {string} formatted user agent information\n */\nexport const userAgentToString = ({clientName, webexVersion}) => {\n let userAgentOption;\n let browserInfo;\n const clientInfo = util.format('client=%s', `${clientName}`);\n\n if (\n ['chrome', 'firefox', 'msie', 'msedge', 'safari'].indexOf(getBrowserName().toLowerCase()) !== -1\n ) {\n browserInfo = util.format(\n 'browser=%s',\n `${getBrowserName().toLowerCase()}/${getBrowserVersion().split('.')[0]}`\n );\n }\n const osInfo = util.format('os=%s', `${getOSName()}/${getOSVersion().split('.')[0]}`);\n\n if (browserInfo) {\n userAgentOption = `(${browserInfo}`;\n }\n if (osInfo) {\n userAgentOption = userAgentOption\n ? `${userAgentOption}; ${clientInfo}; ${osInfo}`\n : `${clientInfo}; (${osInfo}`;\n }\n if (userAgentOption) {\n userAgentOption += ')';\n\n return util.format(\n 'webex-js-sdk/%s %s',\n `${process.env.NODE_ENV}-${webexVersion}`,\n userAgentOption\n );\n }\n\n return util.format('webex-js-sdk/%s', `${process.env.NODE_ENV}-${webexVersion}`);\n};\n\n/**\n * Iterates object recursively and removes any\n * property that returns isEmpty for it's associated value\n * isEmpty = implementation from Lodash.\n *\n * It modifies the object in place (mutable)\n *\n * @param obj - input\n * @returns\n */\nexport const clearEmptyKeysRecursively = (obj: any) => {\n // Check if the object is empty\n if (Object.keys(obj).length === 0) {\n return;\n }\n\n Object.keys(obj).forEach((key) => {\n if (\n (typeof obj[key] === 'object' || typeof obj[key] === 'string' || Array.isArray(obj[key])) &&\n isEmpty(obj[key])\n ) {\n delete obj[key];\n }\n if (Array.isArray(obj[key])) {\n obj[key] = [...obj[key].filter((x) => !!x)];\n }\n if (typeof obj[key] === 'object') {\n clearEmptyKeysRecursively(obj[key]);\n }\n });\n};\n\n/**\n * Locus error codes start with 2. The next three digits are the\n * HTTP status code related to the error code (like 400, 403, 502, etc.)\n * The remaining three digits are just an increasing integer.\n * If it is 7 digits and starts with a 2, it is locus.\n *\n * @param errorCode\n * @returns\n */\nexport const isLocusServiceErrorCode = (errorCode: string | number) => {\n const code = `${errorCode}`;\n\n if (code.length === 7 && code.charAt(0) === '2') {\n return true;\n }\n\n return false;\n};\n"],"mappings":"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"}
1
+ {"version":3,"names":["BrowserDetection","getOSName","getOSVersion","getBrowserName","getBrowserVersion","anonymizeIPAddress","localIp","anonymize","userAgentToString","clientName","webexVersion","userAgentOption","browserInfo","clientInfo","util","format","indexOf","toLowerCase","split","osInfo","process","env","NODE_ENV","clearEmptyKeysRecursively","obj","length","forEach","key","filter","x","isLocusServiceErrorCode","errorCode","code","charAt","getBuildType","webClientDomain","includes","prepareDiagnosticMetricItem","webex","item","origin","buildType","event","eventData","networkType","eventName","eventPayload","name","joinTimes","audioSetupDelay","videoSetupDelay","cdl","internal","newMetrics","callDiagnosticLatencies","meetingInfoReqResp","getMeetingInfoReqResp","clickToInterstitial","getClickToInterstitial","showInterstitialTime","getShowInterstitialTime","callInitJoinReq","getCallInitJoinReq","joinReqResp","getJoinReqResp","joinReqSentReceived","getJoinRespSentReceived","pageJmt","getPageJMT","interstitialToJoinOK","getInterstitialToJoinOK","totalJmt","getTotalJMT","clientJmt","getClientJMT","ICESetupTime","getICESetupTime","audioICESetupTime","getAudioICESetupTime","videoICESetupTime","getVideoICESetupTime","shareICESetupTime","getShareICESetupTime","localSDPGenRemoteSDPRecv","getLocalSDPGenRemoteSDPRecv","totalMediaJMT","getTotalMediaJMT","interstitialToMediaOKJMT","getInterstitialToMediaOKJMT","callInitMediaEngineReady","getCallInitMediaEngineReady","stayLobbyTime","getStayLobbyTime","joinRespRxStart","getAudioJoinRespRxStart","joinRespTxStart","getAudioJoinRespTxStart","getVideoJoinRespRxStart","getVideoJoinRespTxStart","setMetricTimings","options","body","metrics","now","Date","toISOString","metric","originTime","triggered","sent"],"sources":["call-diagnostic-metrics.util.ts"],"sourcesContent":["/* eslint-disable valid-jsdoc */\nimport anonymize from 'ip-anonymize';\nimport util from 'util';\n\nimport {BrowserDetection} from '@webex/common';\nimport {isEmpty, merge} from 'lodash';\nimport {\n ClientEvent,\n MediaQualityEventAudioSetupDelayPayload,\n MediaQualityEventVideoSetupDelayPayload,\n MetricEventNames,\n} from '../metrics.types';\n\nconst {getOSName, getOSVersion, getBrowserName, getBrowserVersion} = BrowserDetection();\n\nexport const anonymizeIPAddress = (localIp) => anonymize(localIp, 28, 96);\n\n/**\n * Returns a formated string of the user agent.\n *\n * @returns {string} formatted user agent information\n */\nexport const userAgentToString = ({clientName, webexVersion}) => {\n let userAgentOption;\n let browserInfo;\n const clientInfo = util.format('client=%s', `${clientName}`);\n\n if (\n ['chrome', 'firefox', 'msie', 'msedge', 'safari'].indexOf(getBrowserName().toLowerCase()) !== -1\n ) {\n browserInfo = util.format(\n 'browser=%s',\n `${getBrowserName().toLowerCase()}/${getBrowserVersion().split('.')[0]}`\n );\n }\n const osInfo = util.format('os=%s', `${getOSName()}/${getOSVersion().split('.')[0]}`);\n\n if (browserInfo) {\n userAgentOption = `(${browserInfo}`;\n }\n if (osInfo) {\n userAgentOption = userAgentOption\n ? `${userAgentOption}; ${clientInfo}; ${osInfo}`\n : `${clientInfo}; (${osInfo}`;\n }\n if (userAgentOption) {\n userAgentOption += ')';\n\n return util.format(\n 'webex-js-sdk/%s %s',\n `${process.env.NODE_ENV}-${webexVersion}`,\n userAgentOption\n );\n }\n\n return util.format('webex-js-sdk/%s', `${process.env.NODE_ENV}-${webexVersion}`);\n};\n\n/**\n * Iterates object recursively and removes any\n * property that returns isEmpty for it's associated value\n * isEmpty = implementation from Lodash.\n *\n * It modifies the object in place (mutable)\n *\n * @param obj - input\n * @returns\n */\nexport const clearEmptyKeysRecursively = (obj: any) => {\n // Check if the object is empty\n if (Object.keys(obj).length === 0) {\n return;\n }\n\n Object.keys(obj).forEach((key) => {\n if (\n (typeof obj[key] === 'object' || typeof obj[key] === 'string' || Array.isArray(obj[key])) &&\n isEmpty(obj[key])\n ) {\n delete obj[key];\n }\n if (Array.isArray(obj[key])) {\n obj[key] = [...obj[key].filter((x) => !!x)];\n }\n if (typeof obj[key] === 'object') {\n clearEmptyKeysRecursively(obj[key]);\n }\n });\n};\n\n/**\n * Locus error codes start with 2. The next three digits are the\n * HTTP status code related to the error code (like 400, 403, 502, etc.)\n * The remaining three digits are just an increasing integer.\n * If it is 7 digits and starts with a 2, it is locus.\n *\n * @param errorCode\n * @returns\n */\nexport const isLocusServiceErrorCode = (errorCode: string | number) => {\n const code = `${errorCode}`;\n\n if (code.length === 7 && code.charAt(0) === '2') {\n return true;\n }\n\n return false;\n};\n\n/**\n * @param webClientDomain\n * @returns\n */\nexport const getBuildType = (webClientDomain) => {\n if (\n webClientDomain?.includes('localhost') ||\n webClientDomain?.includes('127.0.0.1') ||\n process.env.NODE_ENV !== 'production'\n ) {\n return 'test';\n }\n\n return 'production';\n};\n\n/**\n * Prepare metric item for submission.\n * @param {Object} webex sdk instance\n * @param {Object} item\n * @returns {Object} prepared item\n */\nexport const prepareDiagnosticMetricItem = (webex: any, item: any) => {\n const origin = {\n buildType: getBuildType(item.event?.eventData?.webClientDomain),\n networkType: 'unknown',\n };\n\n // check event names and append latencies?\n const eventName = item.eventPayload?.event?.name as MetricEventNames;\n const joinTimes: ClientEvent['payload']['joinTimes'] = {};\n const audioSetupDelay: MediaQualityEventAudioSetupDelayPayload = {};\n const videoSetupDelay: MediaQualityEventVideoSetupDelayPayload = {};\n\n const cdl = webex.internal.newMetrics.callDiagnosticLatencies;\n\n switch (eventName) {\n case 'client.interstitial-window.launched':\n joinTimes.meetingInfoReqResp = cdl.getMeetingInfoReqResp();\n joinTimes.clickToInterstitial = cdl.getClickToInterstitial();\n break;\n\n case 'client.call.initiated':\n joinTimes.meetingInfoReqResp = cdl.getMeetingInfoReqResp();\n joinTimes.showInterstitialTime = cdl.getShowInterstitialTime();\n break;\n\n case 'client.locus.join.response':\n joinTimes.meetingInfoReqResp = cdl.getMeetingInfoReqResp();\n joinTimes.callInitJoinReq = cdl.getCallInitJoinReq();\n joinTimes.joinReqResp = cdl.getJoinReqResp();\n joinTimes.joinReqSentReceived = cdl.getJoinRespSentReceived();\n joinTimes.pageJmt = cdl.getPageJMT();\n joinTimes.clickToInterstitial = cdl.getClickToInterstitial();\n joinTimes.interstitialToJoinOK = cdl.getInterstitialToJoinOK();\n joinTimes.totalJmt = cdl.getTotalJMT();\n joinTimes.clientJmt = cdl.getClientJMT();\n break;\n\n case 'client.ice.end':\n joinTimes.ICESetupTime = cdl.getICESetupTime();\n joinTimes.audioICESetupTime = cdl.getAudioICESetupTime();\n joinTimes.videoICESetupTime = cdl.getVideoICESetupTime();\n joinTimes.shareICESetupTime = cdl.getShareICESetupTime();\n break;\n\n case 'client.media.rx.start':\n joinTimes.localSDPGenRemoteSDPRecv = cdl.getLocalSDPGenRemoteSDPRecv();\n break;\n\n case 'client.media-engine.ready':\n joinTimes.totalMediaJMT = cdl.getTotalMediaJMT();\n joinTimes.interstitialToMediaOKJMT = cdl.getInterstitialToMediaOKJMT();\n joinTimes.callInitMediaEngineReady = cdl.getCallInitMediaEngineReady();\n joinTimes.stayLobbyTime = cdl.getStayLobbyTime();\n break;\n\n case 'client.mediaquality.event':\n audioSetupDelay.joinRespRxStart = cdl.getAudioJoinRespRxStart();\n audioSetupDelay.joinRespTxStart = cdl.getAudioJoinRespTxStart();\n videoSetupDelay.joinRespRxStart = cdl.getVideoJoinRespRxStart();\n videoSetupDelay.joinRespTxStart = cdl.getVideoJoinRespTxStart();\n }\n\n if (!isEmpty(joinTimes)) {\n item.eventPayload.event = merge(item.eventPayload.event, {joinTimes});\n }\n\n if (!isEmpty(audioSetupDelay)) {\n item.eventPayload.event = merge(item.eventPayload.event, {audioSetupDelay});\n }\n\n if (!isEmpty(videoSetupDelay)) {\n item.eventPayload.event = merge(item.eventPayload.event, {videoSetupDelay});\n }\n\n item.eventPayload.origin = Object.assign(origin, item.eventPayload.origin);\n\n return item;\n};\n\n/**\n * Sets the originTime value(s) before the request/fetch.\n * This function is only useful if you are about to submit a metrics\n * request using pre-built fetch options;\n *\n * @param {any} options\n * @returns {any} the updated options object\n */\nexport const setMetricTimings = (options) => {\n if (options.body?.metrics) {\n const now = new Date().toISOString();\n options.body.metrics.forEach((metric) => {\n if (metric.eventPayload) {\n metric.eventPayload.originTime = {\n triggered: now,\n sent: now,\n };\n }\n });\n }\n\n return options;\n};\n"],"mappings":"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"}