@webex/internal-plugin-metrics 3.0.0-beta.2 → 3.0.0-beta.200

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 (76) hide show
  1. package/README.md +1 -3
  2. package/dist/batcher.js +3 -22
  3. package/dist/batcher.js.map +1 -1
  4. package/dist/call-diagnostic/call-diagnostic-metrics-batcher.js +56 -0
  5. package/dist/call-diagnostic/call-diagnostic-metrics-batcher.js.map +1 -0
  6. package/dist/call-diagnostic/call-diagnostic-metrics-latencies.js +451 -0
  7. package/dist/call-diagnostic/call-diagnostic-metrics-latencies.js.map +1 -0
  8. package/dist/call-diagnostic/call-diagnostic-metrics.js +584 -0
  9. package/dist/call-diagnostic/call-diagnostic-metrics.js.map +1 -0
  10. package/dist/call-diagnostic/call-diagnostic-metrics.util.js +225 -0
  11. package/dist/call-diagnostic/call-diagnostic-metrics.util.js.map +1 -0
  12. package/dist/call-diagnostic/config.js +461 -0
  13. package/dist/call-diagnostic/config.js.map +1 -0
  14. package/dist/call-diagnostic/generated-types-temp/ClientEvent.js +7 -0
  15. package/dist/call-diagnostic/generated-types-temp/ClientEvent.js.map +1 -0
  16. package/dist/call-diagnostic/generated-types-temp/Event.js +7 -0
  17. package/dist/call-diagnostic/generated-types-temp/Event.js.map +1 -0
  18. package/dist/call-diagnostic/generated-types-temp/MediaQualityEvent.js +7 -0
  19. package/dist/call-diagnostic/generated-types-temp/MediaQualityEvent.js.map +1 -0
  20. package/dist/client-metrics-batcher.js +1 -7
  21. package/dist/client-metrics-batcher.js.map +1 -1
  22. package/dist/config.js +21 -5
  23. package/dist/config.js.map +1 -1
  24. package/dist/index.js +26 -10
  25. package/dist/index.js.map +1 -1
  26. package/dist/metrics.js +43 -80
  27. package/dist/metrics.js.map +1 -1
  28. package/dist/metrics.types.js +7 -0
  29. package/dist/metrics.types.js.map +1 -0
  30. package/dist/new-metrics.js +249 -0
  31. package/dist/new-metrics.js.map +1 -0
  32. package/dist/types/batcher.d.ts +2 -0
  33. package/dist/types/call-diagnostic/call-diagnostic-metrics-batcher.d.ts +2 -0
  34. package/dist/types/call-diagnostic/call-diagnostic-metrics-latencies.d.ts +189 -0
  35. package/dist/types/call-diagnostic/call-diagnostic-metrics.d.ts +348 -0
  36. package/dist/types/call-diagnostic/call-diagnostic-metrics.util.d.ts +52 -0
  37. package/dist/types/call-diagnostic/config.d.ts +57 -0
  38. package/dist/types/call-diagnostic/generated-types-temp/ClientEvent.d.ts +1112 -0
  39. package/dist/types/call-diagnostic/generated-types-temp/Event.d.ts +4851 -0
  40. package/dist/types/call-diagnostic/generated-types-temp/MediaQualityEvent.d.ts +2121 -0
  41. package/dist/types/client-metrics-batcher.d.ts +2 -0
  42. package/dist/types/config.d.ts +35 -0
  43. package/dist/types/index.d.ts +11 -0
  44. package/dist/types/metrics.d.ts +3 -0
  45. package/dist/types/metrics.types.d.ts +92 -0
  46. package/dist/types/new-metrics.d.ts +119 -0
  47. package/package.json +12 -8
  48. package/src/batcher.js +33 -26
  49. package/src/call-diagnostic/call-diagnostic-metrics-batcher.ts +51 -0
  50. package/src/call-diagnostic/call-diagnostic-metrics-latencies.ts +408 -0
  51. package/src/call-diagnostic/call-diagnostic-metrics.ts +591 -0
  52. package/src/call-diagnostic/call-diagnostic-metrics.util.ts +233 -0
  53. package/src/call-diagnostic/config.ts +455 -0
  54. package/src/call-diagnostic/generated-types-temp/ClientEvent.ts +2395 -0
  55. package/src/call-diagnostic/generated-types-temp/Event.ts +7762 -0
  56. package/src/call-diagnostic/generated-types-temp/MediaQualityEvent.ts +2321 -0
  57. package/src/client-metrics-batcher.js +3 -4
  58. package/src/config.js +25 -5
  59. package/src/index.ts +39 -0
  60. package/src/metrics.js +44 -58
  61. package/src/metrics.types.ts +137 -0
  62. package/src/new-metrics.ts +223 -0
  63. package/test/unit/spec/batcher.js +26 -15
  64. package/test/unit/spec/call-diagnostic/call-diagnostic-metrics-batcher.ts +243 -0
  65. package/test/unit/spec/call-diagnostic/call-diagnostic-metrics-latencies.ts +474 -0
  66. package/test/unit/spec/call-diagnostic/call-diagnostic-metrics.ts +820 -0
  67. package/test/unit/spec/call-diagnostic/call-diagnostic-metrics.util.ts +336 -0
  68. package/test/unit/spec/client-metrics-batcher.js +26 -15
  69. package/test/unit/spec/metrics.js +85 -116
  70. package/test/unit/spec/new-metrics.ts +153 -0
  71. package/tsconfig.json +6 -0
  72. package/dist/call-diagnostic-events-batcher.js +0 -70
  73. package/dist/call-diagnostic-events-batcher.js.map +0 -1
  74. package/src/call-diagnostic-events-batcher.js +0 -62
  75. package/src/index.js +0 -17
  76. package/test/unit/spec/call-diagnostic-events-batcher.js +0 -180
package/README.md CHANGED
@@ -21,14 +21,12 @@ npm install --save @webex/internal-plugin-metrics
21
21
  ## Usage
22
22
 
23
23
  ```js
24
-
25
24
  import '@webex/internal-plugin-metrics';
26
25
 
27
26
  import WebexCore from '@webex/webex-core';
28
27
 
29
28
  const webex = new WebexCore();
30
- webex.internal.metrics.WHATEVER
31
-
29
+ webex.internal.metrics.WHATEVER;
32
30
  ```
33
31
 
34
32
  ## Maintainers
package/dist/batcher.js CHANGED
@@ -1,34 +1,23 @@
1
1
  "use strict";
2
2
 
3
3
  var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
4
-
5
4
  var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
6
-
7
5
  _Object$defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
-
11
8
  exports.default = void 0;
12
-
13
9
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/slicedToArray"));
14
-
15
10
  var _symbol = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/symbol"));
16
-
17
11
  var _now = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/date/now"));
18
-
19
12
  var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
20
-
21
13
  var _apply = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/reflect/apply"));
22
-
23
14
  var _webexCore = require("@webex/webex-core");
24
-
25
15
  var _commonTimers = require("@webex/common-timers");
26
-
27
16
  /*!
28
17
  * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.
29
18
  */
30
- var sym = (0, _symbol.default)('metric id');
31
19
 
20
+ var sym = (0, _symbol.default)('metric id');
32
21
  var MetricsBatcher = _webexCore.Batcher.extend({
33
22
  namespace: 'Metrics',
34
23
  prepareItem: function prepareItem(item) {
@@ -58,41 +47,34 @@ var MetricsBatcher = _webexCore.Batcher.extend({
58
47
  },
59
48
  handleHttpSuccess: function handleHttpSuccess(res) {
60
49
  var _this = this;
61
-
62
50
  return _promise.default.all(res.options.body.metrics.map(function (item) {
63
51
  return _this.acceptItem(item);
64
52
  }));
65
53
  },
66
54
  handleHttpError: function handleHttpError(reason) {
67
55
  var _this2 = this;
68
-
69
56
  if (reason instanceof _webexCore.WebexHttpError.NetworkOrCORSError) {
70
57
  this.logger.warn('metrics-batcher: received network error submitting metrics, reenqueuing payload');
71
58
  return _promise.default.all(reason.options.body.metrics.map(function (item) {
72
59
  return new _promise.default(function (resolve) {
73
60
  var delay = item[sym].nextDelay;
74
-
75
61
  if (delay < _this2.config.batcherRetryPlateau) {
76
62
  item[sym].nextDelay *= 2;
77
63
  }
78
-
79
64
  (0, _commonTimers.safeSetTimeout)(function () {
80
65
  resolve(_this2.rerequest(item));
81
66
  }, delay);
82
67
  });
83
68
  }));
84
69
  }
85
-
86
70
  return (0, _apply.default)(_webexCore.Batcher.prototype.handleHttpError, this, [reason]);
87
71
  },
88
72
  rerequest: function rerequest(item) {
89
73
  var _this3 = this;
90
-
91
74
  return _promise.default.all([this.getDeferredForRequest(item), this.prepareItem(item)]).then(function (_ref) {
92
75
  var _ref2 = (0, _slicedToArray2.default)(_ref, 2),
93
- defer = _ref2[0],
94
- req = _ref2[1];
95
-
76
+ defer = _ref2[0],
77
+ req = _ref2[1];
96
78
  _this3.enqueue(req).then(function () {
97
79
  return _this3.bounce();
98
80
  }).catch(function (reason) {
@@ -110,7 +92,6 @@ var MetricsBatcher = _webexCore.Batcher.extend({
110
92
  return _promise.default.resolve(item[sym]);
111
93
  }
112
94
  });
113
-
114
95
  var _default = MetricsBatcher;
115
96
  exports.default = _default;
116
97
  //# sourceMappingURL=batcher.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["sym","MetricsBatcher","Batcher","extend","namespace","prepareItem","item","env","process","NODE_ENV","appType","config","time","version","webex","resolve","prepareRequest","queue","map","postTime","submitHttpRequest","payload","request","method","service","resource","body","metrics","handleHttpSuccess","res","all","options","acceptItem","handleHttpError","reason","WebexHttpError","NetworkOrCORSError","logger","warn","delay","nextDelay","batcherRetryPlateau","safeSetTimeout","rerequest","prototype","getDeferredForRequest","then","defer","req","enqueue","bounce","catch","reject","fingerprintRequest","fingerprintResponse"],"sources":["batcher.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\nimport {Batcher, WebexHttpError} from '@webex/webex-core';\nimport {safeSetTimeout} from '@webex/common-timers';\n\nconst sym = Symbol('metric id');\n\nconst MetricsBatcher = Batcher.extend({\n namespace: 'Metrics',\n\n prepareItem(item) {\n // Keep non-prod data out of metrics\n const env = process.env.NODE_ENV === 'production' ? null : 'TEST';\n\n item.appType = item.appType || this.config.appType;\n item.env = item.env || env;\n item.time = item.time || Date.now();\n item.version = item.version || this.webex.version;\n\n return Promise.resolve(item);\n },\n\n prepareRequest(queue) {\n return Promise.resolve(queue.map((item) => {\n item.postTime = item.postTime || Date.now();\n\n return item;\n }));\n },\n\n submitHttpRequest(payload) {\n return this.webex.request({\n method: 'POST',\n service: 'metrics',\n resource: 'metrics',\n body: {\n metrics: payload\n }\n });\n },\n\n handleHttpSuccess(res) {\n return Promise.all(res.options.body.metrics.map((item) => this.acceptItem(item)));\n },\n\n handleHttpError(reason) {\n if (reason instanceof WebexHttpError.NetworkOrCORSError) {\n this.logger.warn('metrics-batcher: received network error submitting metrics, reenqueuing payload');\n\n return Promise.all(reason.options.body.metrics.map((item) => new Promise((resolve) => {\n const delay = item[sym].nextDelay;\n\n if (delay < this.config.batcherRetryPlateau) {\n item[sym].nextDelay *= 2;\n }\n safeSetTimeout(() => {\n resolve(this.rerequest(item));\n }, delay);\n })));\n }\n\n return Reflect.apply(Batcher.prototype.handleHttpError, this, [reason]);\n },\n\n rerequest(item) {\n return Promise.all([\n this.getDeferredForRequest(item),\n this.prepareItem(item)\n ])\n .then(([defer, req]) => {\n this.enqueue(req)\n .then(() => this.bounce())\n .catch((reason) => defer.reject(reason));\n });\n },\n\n fingerprintRequest(item) {\n item[sym] = item[sym] || {\n nextDelay: 1000\n };\n\n return Promise.resolve(item[sym]);\n },\n\n fingerprintResponse(item) {\n return Promise.resolve(item[sym]);\n }\n});\n\nexport default MetricsBatcher;\n"],"mappings":"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"}
1
+ {"version":3,"names":["sym","MetricsBatcher","Batcher","extend","namespace","prepareItem","item","env","process","NODE_ENV","appType","config","time","version","webex","resolve","prepareRequest","queue","map","postTime","submitHttpRequest","payload","request","method","service","resource","body","metrics","handleHttpSuccess","res","all","options","acceptItem","handleHttpError","reason","WebexHttpError","NetworkOrCORSError","logger","warn","delay","nextDelay","batcherRetryPlateau","safeSetTimeout","rerequest","prototype","getDeferredForRequest","then","defer","req","enqueue","bounce","catch","reject","fingerprintRequest","fingerprintResponse"],"sources":["batcher.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\nimport {Batcher, WebexHttpError} from '@webex/webex-core';\nimport {safeSetTimeout} from '@webex/common-timers';\n\nconst sym = Symbol('metric id');\n\nconst MetricsBatcher = Batcher.extend({\n namespace: 'Metrics',\n\n prepareItem(item) {\n // Keep non-prod data out of metrics\n const env = process.env.NODE_ENV === 'production' ? null : 'TEST';\n\n item.appType = item.appType || this.config.appType;\n item.env = item.env || env;\n item.time = item.time || Date.now();\n item.version = item.version || this.webex.version;\n\n return Promise.resolve(item);\n },\n\n prepareRequest(queue) {\n return Promise.resolve(\n queue.map((item) => {\n item.postTime = item.postTime || Date.now();\n\n return item;\n })\n );\n },\n\n submitHttpRequest(payload) {\n return this.webex.request({\n method: 'POST',\n service: 'metrics',\n resource: 'metrics',\n body: {\n metrics: payload,\n },\n });\n },\n\n handleHttpSuccess(res) {\n return Promise.all(res.options.body.metrics.map((item) => this.acceptItem(item)));\n },\n\n handleHttpError(reason) {\n if (reason instanceof WebexHttpError.NetworkOrCORSError) {\n this.logger.warn(\n 'metrics-batcher: received network error submitting metrics, reenqueuing payload'\n );\n\n return Promise.all(\n reason.options.body.metrics.map(\n (item) =>\n new Promise((resolve) => {\n const delay = item[sym].nextDelay;\n\n if (delay < this.config.batcherRetryPlateau) {\n item[sym].nextDelay *= 2;\n }\n safeSetTimeout(() => {\n resolve(this.rerequest(item));\n }, delay);\n })\n )\n );\n }\n\n return Reflect.apply(Batcher.prototype.handleHttpError, this, [reason]);\n },\n\n rerequest(item) {\n return Promise.all([this.getDeferredForRequest(item), this.prepareItem(item)]).then(\n ([defer, req]) => {\n this.enqueue(req)\n .then(() => this.bounce())\n .catch((reason) => defer.reject(reason));\n }\n );\n },\n\n fingerprintRequest(item) {\n item[sym] = item[sym] || {\n nextDelay: 1000,\n };\n\n return Promise.resolve(item[sym]);\n },\n\n fingerprintResponse(item) {\n return Promise.resolve(item[sym]);\n },\n});\n\nexport default MetricsBatcher;\n"],"mappings":"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"}
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+
3
+ var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
4
+ var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
5
+ _Object$defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+ var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
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
+
15
+ var CallDiagnosticEventsBatcher = _batcher.default.extend({
16
+ namespace: 'Metrics',
17
+ /**
18
+ * Prepare item
19
+ * @param item
20
+ * @returns
21
+ */
22
+ prepareItem: function prepareItem(item) {
23
+ return _promise.default.resolve((0, _callDiagnosticMetrics.prepareDiagnosticMetricItem)(this.webex, item));
24
+ },
25
+ /**
26
+ * Prepare request, add time sensitive date etc.
27
+ * @param queue
28
+ * @returns
29
+ */
30
+ prepareRequest: function prepareRequest(queue) {
31
+ // Add sent timestamp
32
+ queue.forEach(function (item) {
33
+ item.eventPayload.originTime = item.eventPayload.originTime || {};
34
+ item.eventPayload.originTime.sent = new Date().toISOString();
35
+ });
36
+ return _promise.default.resolve(queue);
37
+ },
38
+ /**
39
+ *
40
+ * @param payload
41
+ * @returns
42
+ */
43
+ submitHttpRequest: function submitHttpRequest(payload) {
44
+ return this.webex.request({
45
+ method: 'POST',
46
+ service: 'metrics',
47
+ resource: 'clientmetrics',
48
+ body: {
49
+ metrics: payload
50
+ }
51
+ });
52
+ }
53
+ });
54
+ var _default = CallDiagnosticEventsBatcher;
55
+ exports.default = _default;
56
+ //# sourceMappingURL=call-diagnostic-metrics-batcher.js.map
@@ -0,0 +1 @@
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"}
@@ -0,0 +1,451 @@
1
+ "use strict";
2
+
3
+ var _Reflect$construct = require("@babel/runtime-corejs2/core-js/reflect/construct");
4
+ var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
5
+ var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
6
+ _Object$defineProperty(exports, "__esModule", {
7
+ value: true
8
+ });
9
+ exports.default = void 0;
10
+ var _map = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/map"));
11
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
12
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
13
+ var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/assertThisInitialized"));
14
+ var _inherits2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/inherits"));
15
+ var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/possibleConstructorReturn"));
16
+ var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/getPrototypeOf"));
17
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
18
+ var _webexCore = require("@webex/webex-core");
19
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = _Reflect$construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; }
20
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !_Reflect$construct) return false; if (_Reflect$construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
21
+ // we only care about client event and feature event for now
22
+ /**
23
+ * @description Helper class to store latencies timestamp and to calculate various latencies for CA.
24
+ * @exports
25
+ * @class CallDiagnosticLatencies
26
+ */
27
+ var CallDiagnosticLatencies = /*#__PURE__*/function (_WebexPlugin) {
28
+ (0, _inherits2.default)(CallDiagnosticLatencies, _WebexPlugin);
29
+ var _super = _createSuper(CallDiagnosticLatencies);
30
+ // meetingId that the current latencies are for
31
+
32
+ /**
33
+ * @constructor
34
+ */
35
+ function CallDiagnosticLatencies() {
36
+ var _this;
37
+ (0, _classCallCheck2.default)(this, CallDiagnosticLatencies);
38
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
39
+ args[_key] = arguments[_key];
40
+ }
41
+ _this = _super.call.apply(_super, [this].concat(args));
42
+ (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "latencyTimestamps", void 0);
43
+ (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "precomputedLatencies", void 0);
44
+ (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "meetingId", void 0);
45
+ _this.latencyTimestamps = new _map.default();
46
+ _this.precomputedLatencies = new _map.default();
47
+ return _this;
48
+ }
49
+
50
+ /**
51
+ * Clear timestamps
52
+ */
53
+ (0, _createClass2.default)(CallDiagnosticLatencies, [{
54
+ key: "clearTimestamps",
55
+ value: function clearTimestamps() {
56
+ this.latencyTimestamps.clear();
57
+ }
58
+
59
+ /**
60
+ * Associate current latencies with a meeting id
61
+ * @param meetingId
62
+ */
63
+ }, {
64
+ key: "setMeetingId",
65
+ value: function setMeetingId(meetingId) {
66
+ this.meetingId = meetingId;
67
+ }
68
+
69
+ /**
70
+ * Returns the meeting object associated with current latencies
71
+ * @returns meeting object
72
+ */
73
+ }, {
74
+ key: "getMeeting",
75
+ value: function getMeeting() {
76
+ if (this.meetingId) {
77
+ // @ts-ignore
78
+ return this.webex.meetings.meetingCollection.get(this.meetingId);
79
+ }
80
+ return undefined;
81
+ }
82
+
83
+ /**
84
+ * Store timestamp value
85
+ * @param key - key
86
+ * @param value -value
87
+ * @throws
88
+ * @returns
89
+ */
90
+ }, {
91
+ key: "saveTimestamp",
92
+ value: function saveTimestamp(_ref) {
93
+ var key = _ref.key,
94
+ _ref$value = _ref.value,
95
+ value = _ref$value === void 0 ? new Date().getTime() : _ref$value,
96
+ _ref$options = _ref.options,
97
+ options = _ref$options === void 0 ? {} : _ref$options;
98
+ // save the meetingId so we can use the meeting object in latency calculations if needed
99
+ var meetingId = options.meetingId;
100
+ if (meetingId) {
101
+ this.setMeetingId(meetingId);
102
+ }
103
+ // for some events we're only interested in the first timestamp not last
104
+ // as these events can happen multiple times
105
+ if (key === 'client.media.rx.start' || key === 'client.media.tx.start') {
106
+ this.saveFirstTimestampOnly(key, value);
107
+ } else {
108
+ this.latencyTimestamps.set(key, value);
109
+ }
110
+ }
111
+
112
+ /**
113
+ * Store precomputed latency value
114
+ * @param key - key
115
+ * @param value -value
116
+ * @throws
117
+ * @returns
118
+ */
119
+ }, {
120
+ key: "saveLatency",
121
+ value: function saveLatency(key, value) {
122
+ this.precomputedLatencies.set(key, value);
123
+ }
124
+
125
+ /**
126
+ * Store only the first timestamp value for the given key
127
+ * @param key - key
128
+ * @param value -value
129
+ * @throws
130
+ * @returns
131
+ */
132
+ }, {
133
+ key: "saveFirstTimestampOnly",
134
+ value: function saveFirstTimestampOnly(key) {
135
+ var value = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : new Date().getTime();
136
+ if (this.latencyTimestamps.has(key)) {
137
+ return;
138
+ }
139
+ this.latencyTimestamps.set(key, value);
140
+ }
141
+
142
+ /**
143
+ * Helper to calculate end - start
144
+ * @param a start
145
+ * @param b end
146
+ * @returns latency
147
+ */
148
+ }, {
149
+ key: "getDiffBetweenTimestamps",
150
+ value: function getDiffBetweenTimestamps(a, b) {
151
+ var start = this.latencyTimestamps.get(a);
152
+ var end = this.latencyTimestamps.get(b);
153
+ if (start && end) {
154
+ return end - start;
155
+ }
156
+ return undefined;
157
+ }
158
+
159
+ /**
160
+ * Meeting Info Request
161
+ * @note Meeting Info request happen not just in the join phase. CA requires
162
+ * metrics around meeting info request that are only part of join phase.
163
+ * This internal.* event is used to track the real timestamps
164
+ * (when the actual request/response happen). This is because the actual CA event is
165
+ * sent inside the join method on the meeting object based on some logic, but that's not exactly when
166
+ * those events are actually fired. The logic only confirms that they have happened, and we send them over.
167
+ * @returns - latency
168
+ */
169
+ }, {
170
+ key: "getMeetingInfoReqResp",
171
+ value: function getMeetingInfoReqResp() {
172
+ return this.getDiffBetweenTimestamps('internal.client.meetinginfo.request', 'internal.client.meetinginfo.response');
173
+ }
174
+
175
+ /**
176
+ * Interstitial Time
177
+ * @returns - latency
178
+ */
179
+ }, {
180
+ key: "getShowInterstitialTime",
181
+ value: function getShowInterstitialTime() {
182
+ return this.getDiffBetweenTimestamps('internal.client.interstitial-window.launched', 'internal.client.interstitial-window.click.joinbutton');
183
+ }
184
+
185
+ /**
186
+ * Call Init Join Request
187
+ * @returns - latency
188
+ */
189
+ }, {
190
+ key: "getCallInitJoinReq",
191
+ value: function getCallInitJoinReq() {
192
+ if (this.latencyTimestamps.get('internal.client.meeting.click.joinbutton')) {
193
+ return this.getDiffBetweenTimestamps('internal.client.meeting.click.joinbutton', 'client.locus.join.request');
194
+ }
195
+
196
+ // for cross launch and guest flows
197
+ return this.precomputedLatencies.get('internal.call.init.join.req') || undefined;
198
+ }
199
+
200
+ /**
201
+ * Locus Join Request
202
+ * @returns - latency
203
+ */
204
+ }, {
205
+ key: "getJoinReqResp",
206
+ value: function getJoinReqResp() {
207
+ return this.getDiffBetweenTimestamps('client.locus.join.request', 'client.locus.join.response');
208
+ }
209
+
210
+ /**
211
+ * Locus Join Response Sent Received
212
+ * @returns - latency
213
+ */
214
+ }, {
215
+ key: "getJoinRespSentReceived",
216
+ value: function getJoinRespSentReceived() {
217
+ // TODO: not clear SPARK-440554
218
+ return undefined;
219
+ }
220
+
221
+ /**
222
+ * Local SDP Generated Remote SDP REceived
223
+ * @returns - latency
224
+ */
225
+ }, {
226
+ key: "getLocalSDPGenRemoteSDPRecv",
227
+ value: function getLocalSDPGenRemoteSDPRecv() {
228
+ return this.getDiffBetweenTimestamps('client.media-engine.local-sdp-generated', 'client.media-engine.remote-sdp-received');
229
+ }
230
+
231
+ /**
232
+ * ICE Setup Time
233
+ * @returns - latency
234
+ */
235
+ }, {
236
+ key: "getICESetupTime",
237
+ value: function getICESetupTime() {
238
+ return this.getDiffBetweenTimestamps('client.ice.start', 'client.ice.end');
239
+ }
240
+
241
+ /**
242
+ * Audio ICE time
243
+ * @returns - latency
244
+ */
245
+ }, {
246
+ key: "getAudioICESetupTime",
247
+ value: function getAudioICESetupTime() {
248
+ return this.getDiffBetweenTimestamps('client.ice.start', 'client.ice.end');
249
+ }
250
+
251
+ /**
252
+ * Video ICE Time
253
+ * @returns - latency
254
+ */
255
+ }, {
256
+ key: "getVideoICESetupTime",
257
+ value: function getVideoICESetupTime() {
258
+ return this.getDiffBetweenTimestamps('client.ice.start', 'client.ice.end');
259
+ }
260
+
261
+ /**
262
+ * Share ICE Time
263
+ * @returns - latency
264
+ */
265
+ }, {
266
+ key: "getShareICESetupTime",
267
+ value: function getShareICESetupTime() {
268
+ return this.getDiffBetweenTimestamps('client.ice.start', 'client.ice.end');
269
+ }
270
+
271
+ /**
272
+ * Stay Lobby Time
273
+ * @returns - latency
274
+ */
275
+ }, {
276
+ key: "getStayLobbyTime",
277
+ value: function getStayLobbyTime() {
278
+ return this.getDiffBetweenTimestamps('client.locus.join.response', 'internal.host.meeting.participant.admitted');
279
+ }
280
+
281
+ /**
282
+ * Page JMT
283
+ * @returns - latency
284
+ */
285
+ }, {
286
+ key: "getPageJMT",
287
+ value: function getPageJMT() {
288
+ return this.precomputedLatencies.get('internal.client.pageJMT') || undefined;
289
+ }
290
+
291
+ /**
292
+ * Click To Interstitial
293
+ * @returns - latency
294
+ */
295
+ }, {
296
+ key: "getClickToInterstitial",
297
+ value: function getClickToInterstitial() {
298
+ // for normal join (where green join button exists before interstitial, i.e reminder, space list etc)
299
+ if (this.latencyTimestamps.get('internal.client.meeting.click.joinbutton')) {
300
+ return this.getDiffBetweenTimestamps('internal.client.meeting.click.joinbutton', 'internal.client.meeting.interstitial-window.showed');
301
+ }
302
+
303
+ // for cross launch and guest flows
304
+ return this.precomputedLatencies.get('internal.click.to.interstitial') || undefined;
305
+ }
306
+
307
+ /**
308
+ * Interstitial To Join Ok
309
+ * @returns - latency
310
+ */
311
+ }, {
312
+ key: "getInterstitialToJoinOK",
313
+ value: function getInterstitialToJoinOK() {
314
+ return this.getDiffBetweenTimestamps('internal.client.interstitial-window.click.joinbutton', 'client.locus.join.response');
315
+ }
316
+
317
+ /**
318
+ * Call Init To MediaEngineReady
319
+ * @returns - latency
320
+ */
321
+ }, {
322
+ key: "getCallInitMediaEngineReady",
323
+ value: function getCallInitMediaEngineReady() {
324
+ return this.getDiffBetweenTimestamps('internal.client.interstitial-window.click.joinbutton', 'client.media-engine.ready');
325
+ }
326
+
327
+ /**
328
+ * Interstitial To Media Ok
329
+ * @returns - latency
330
+ */
331
+ }, {
332
+ key: "getInterstitialToMediaOKJMT",
333
+ value: function getInterstitialToMediaOKJMT() {
334
+ var interstitialJoinClickTimestamp = this.latencyTimestamps.get('internal.client.interstitial-window.click.joinbutton');
335
+
336
+ // get the first timestamp
337
+ var mediaFlowStartedTimestamp = Math.min(this.latencyTimestamps.get('client.media.rx.start'), this.latencyTimestamps.get('client.media.tx.start'));
338
+ var lobbyTime = this.getStayLobbyTime() || 0;
339
+ if (interstitialJoinClickTimestamp && mediaFlowStartedTimestamp) {
340
+ return mediaFlowStartedTimestamp - interstitialJoinClickTimestamp - lobbyTime;
341
+ }
342
+ return undefined;
343
+ }
344
+
345
+ /**
346
+ * Total JMT
347
+ * @returns - latency
348
+ */
349
+ }, {
350
+ key: "getTotalJMT",
351
+ value: function getTotalJMT() {
352
+ var clickToInterstitial = this.getClickToInterstitial();
353
+ var interstitialToJoinOk = this.getInterstitialToJoinOK();
354
+ if (clickToInterstitial && interstitialToJoinOk) {
355
+ return clickToInterstitial + interstitialToJoinOk;
356
+ }
357
+ return undefined;
358
+ }
359
+
360
+ /**
361
+ * Join Conf JMT
362
+ * @returns - latency
363
+ */
364
+ }, {
365
+ key: "getJoinConfJMT",
366
+ value: function getJoinConfJMT() {
367
+ var joinReqResp = this.getJoinReqResp();
368
+ var ICESetupTime = this.getICESetupTime();
369
+ if (joinReqResp && ICESetupTime) {
370
+ return joinReqResp + ICESetupTime;
371
+ }
372
+ return undefined;
373
+ }
374
+
375
+ /**
376
+ * Total Media JMT
377
+ * @returns - latency
378
+ */
379
+ }, {
380
+ key: "getTotalMediaJMT",
381
+ value: function getTotalMediaJMT() {
382
+ var clickToInterstitial = this.getClickToInterstitial();
383
+ var interstitialToJoinOk = this.getInterstitialToJoinOK();
384
+ var joinConfJMT = this.getJoinConfJMT();
385
+ var lobbyTime = this.getStayLobbyTime();
386
+ if (clickToInterstitial && interstitialToJoinOk && joinConfJMT) {
387
+ var _this$getMeeting;
388
+ var totalMediaJMT = clickToInterstitial + interstitialToJoinOk + joinConfJMT;
389
+ if ((_this$getMeeting = this.getMeeting()) !== null && _this$getMeeting !== void 0 && _this$getMeeting.allowMediaInLobby) {
390
+ return totalMediaJMT;
391
+ }
392
+ return totalMediaJMT - lobbyTime;
393
+ }
394
+ return undefined;
395
+ }
396
+
397
+ /**
398
+ * Client JMT
399
+ * @returns - latency
400
+ */
401
+ }, {
402
+ key: "getClientJMT",
403
+ value: function getClientJMT() {
404
+ var interstitialToJoinOk = this.getInterstitialToJoinOK();
405
+ var joinConfJMT = this.getJoinConfJMT();
406
+ if (interstitialToJoinOk && joinConfJMT) {
407
+ return interstitialToJoinOk - joinConfJMT;
408
+ }
409
+ return undefined;
410
+ }
411
+
412
+ /**
413
+ * Audio setup delay receive
414
+ */
415
+ }, {
416
+ key: "getAudioJoinRespRxStart",
417
+ value: function getAudioJoinRespRxStart() {
418
+ return this.getDiffBetweenTimestamps('client.locus.join.response', 'client.media.rx.start');
419
+ }
420
+
421
+ /**
422
+ * Video setup delay receive
423
+ */
424
+ }, {
425
+ key: "getVideoJoinRespRxStart",
426
+ value: function getVideoJoinRespRxStart() {
427
+ return this.getDiffBetweenTimestamps('client.locus.join.response', 'client.media.rx.start');
428
+ }
429
+
430
+ /**
431
+ * Audio setup delay transmit
432
+ */
433
+ }, {
434
+ key: "getAudioJoinRespTxStart",
435
+ value: function getAudioJoinRespTxStart() {
436
+ return this.getDiffBetweenTimestamps('client.locus.join.response', 'client.media.tx.start');
437
+ }
438
+
439
+ /**
440
+ * Video setup delay transmit
441
+ */
442
+ }, {
443
+ key: "getVideoJoinRespTxStart",
444
+ value: function getVideoJoinRespTxStart() {
445
+ return this.getDiffBetweenTimestamps('client.locus.join.response', 'client.media.tx.start');
446
+ }
447
+ }]);
448
+ return CallDiagnosticLatencies;
449
+ }(_webexCore.WebexPlugin);
450
+ exports.default = CallDiagnosticLatencies;
451
+ //# sourceMappingURL=call-diagnostic-metrics-latencies.js.map