@microsoft/applicationinsights-common 3.0.0-beta.2303-02 → 3.0.0-beta.2303-03

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 (98) hide show
  1. package/browser/applicationinsights-common.integrity.json +9 -9
  2. package/browser/applicationinsights-common.js +116 -33
  3. package/browser/applicationinsights-common.js.map +1 -1
  4. package/browser/applicationinsights-common.min.js +2 -2
  5. package/browser/applicationinsights-common.min.js.map +1 -1
  6. package/dist/applicationinsights-common.api.json +57 -9
  7. package/dist/applicationinsights-common.api.md +5 -5
  8. package/dist/applicationinsights-common.d.ts +16 -3
  9. package/dist/applicationinsights-common.js +116 -33
  10. package/dist/applicationinsights-common.js.map +1 -1
  11. package/dist/applicationinsights-common.min.js +2 -2
  12. package/dist/applicationinsights-common.min.js.map +1 -1
  13. package/dist/applicationinsights-common.rollup.d.ts +16 -3
  14. package/dist-esm/ConnectionStringParser.js +1 -1
  15. package/dist-esm/Constants.js +1 -1
  16. package/dist-esm/DomHelperFuncs.js +1 -1
  17. package/dist-esm/Enums.js +1 -1
  18. package/dist-esm/HelperFuncs.js +1 -1
  19. package/dist-esm/Interfaces/ConnectionString.js +1 -1
  20. package/dist-esm/Interfaces/Context/IApplication.js +1 -1
  21. package/dist-esm/Interfaces/Context/IDevice.js +1 -1
  22. package/dist-esm/Interfaces/Context/IInternal.js +1 -1
  23. package/dist-esm/Interfaces/Context/ILocation.js +1 -1
  24. package/dist-esm/Interfaces/Context/IOperatingSystem.js +1 -1
  25. package/dist-esm/Interfaces/Context/ISample.js +1 -1
  26. package/dist-esm/Interfaces/Context/ISession.js +1 -1
  27. package/dist-esm/Interfaces/Context/ITelemetryTrace.js +1 -1
  28. package/dist-esm/Interfaces/Context/IUser.js +1 -1
  29. package/dist-esm/Interfaces/Context/IWeb.js +1 -1
  30. package/dist-esm/Interfaces/Contracts/AvailabilityData.js +1 -1
  31. package/dist-esm/Interfaces/Contracts/ContextTagKeys.js +1 -1
  32. package/dist-esm/Interfaces/Contracts/DataPointType.js +1 -1
  33. package/dist-esm/Interfaces/Contracts/DependencyKind.js +1 -1
  34. package/dist-esm/Interfaces/Contracts/DependencySourceType.js +1 -1
  35. package/dist-esm/Interfaces/Contracts/IBase.js +1 -1
  36. package/dist-esm/Interfaces/Contracts/IData.js +1 -1
  37. package/dist-esm/Interfaces/Contracts/IDataPoint.js +1 -1
  38. package/dist-esm/Interfaces/Contracts/IDomain.js +1 -1
  39. package/dist-esm/Interfaces/Contracts/IEnvelope.js +1 -1
  40. package/dist-esm/Interfaces/Contracts/IEventData.js +1 -1
  41. package/dist-esm/Interfaces/Contracts/IExceptionData.js +1 -1
  42. package/dist-esm/Interfaces/Contracts/IExceptionDetails.js +1 -1
  43. package/dist-esm/Interfaces/Contracts/IMessageData.js +1 -1
  44. package/dist-esm/Interfaces/Contracts/IMetricData.js +1 -1
  45. package/dist-esm/Interfaces/Contracts/IPageViewData.js +1 -1
  46. package/dist-esm/Interfaces/Contracts/IPageViewPerfData.js +1 -1
  47. package/dist-esm/Interfaces/Contracts/IRemoteDependencyData.js +1 -1
  48. package/dist-esm/Interfaces/Contracts/IStackFrame.js +1 -1
  49. package/dist-esm/Interfaces/Contracts/RequestData.js +1 -1
  50. package/dist-esm/Interfaces/Contracts/SeverityLevel.js +1 -1
  51. package/dist-esm/Interfaces/IAppInsights.js +1 -1
  52. package/dist-esm/Interfaces/IChannelControlsAI.js +1 -1
  53. package/dist-esm/Interfaces/IConfig.js +1 -1
  54. package/dist-esm/Interfaces/ICorrelationConfig.js +1 -1
  55. package/dist-esm/Interfaces/IDependencyTelemetry.js +1 -1
  56. package/dist-esm/Interfaces/IEventTelemetry.js +1 -1
  57. package/dist-esm/Interfaces/IExceptionTelemetry.js +1 -1
  58. package/dist-esm/Interfaces/IMetricTelemetry.js +1 -1
  59. package/dist-esm/Interfaces/IPageViewPerformanceTelemetry.js +1 -1
  60. package/dist-esm/Interfaces/IPageViewTelemetry.js +1 -1
  61. package/dist-esm/Interfaces/IPartC.js +1 -1
  62. package/dist-esm/Interfaces/IPropertiesPlugin.js +1 -1
  63. package/dist-esm/Interfaces/IRequestContext.js +1 -1
  64. package/dist-esm/Interfaces/ITelemetryContext.js +1 -1
  65. package/dist-esm/Interfaces/IThrottleMgr.js +1 -1
  66. package/dist-esm/Interfaces/ITraceTelemetry.js +1 -1
  67. package/dist-esm/Interfaces/PartAExtensions.js +1 -1
  68. package/dist-esm/Interfaces/Telemetry/IEnvelope.js +1 -1
  69. package/dist-esm/Interfaces/Telemetry/ISerializable.js +1 -1
  70. package/dist-esm/RequestResponseHeaders.js +1 -1
  71. package/dist-esm/StorageHelperFuncs.js +1 -1
  72. package/dist-esm/Telemetry/Common/Data.js +1 -1
  73. package/dist-esm/Telemetry/Common/DataPoint.js +1 -1
  74. package/dist-esm/Telemetry/Common/DataSanitizer.js +1 -1
  75. package/dist-esm/Telemetry/Common/Envelope.js +1 -1
  76. package/dist-esm/Telemetry/Event.js +1 -1
  77. package/dist-esm/Telemetry/Exception.js +1 -1
  78. package/dist-esm/Telemetry/Metric.js +1 -1
  79. package/dist-esm/Telemetry/PageView.js +1 -1
  80. package/dist-esm/Telemetry/PageViewPerformance.js +1 -1
  81. package/dist-esm/Telemetry/RemoteDependencyData.js +1 -1
  82. package/dist-esm/Telemetry/Trace.js +1 -1
  83. package/dist-esm/TelemetryItemCreator.js +1 -1
  84. package/dist-esm/ThrottleMgr.js +54 -34
  85. package/dist-esm/ThrottleMgr.js.map +1 -1
  86. package/dist-esm/UrlHelperFuncs.js +1 -1
  87. package/dist-esm/Util.js +1 -1
  88. package/dist-esm/__DynamicConstants.js +1 -1
  89. package/dist-esm/applicationinsights-common.js +1 -1
  90. package/package.json +2 -2
  91. package/src/Enums.ts +10 -0
  92. package/src/Interfaces/IThrottleMgr.ts +4 -2
  93. package/src/ThrottleMgr.ts +61 -33
  94. package/src/applicationinsights-common.ts +1 -1
  95. package/types/Enums.d.ts +9 -0
  96. package/types/Interfaces/IThrottleMgr.d.ts +3 -1
  97. package/types/ThrottleMgr.d.ts +3 -2
  98. package/types/applicationinsights-common.d.ts +1 -1
@@ -1,25 +1,25 @@
1
1
  {
2
2
  "name": "applicationinsights-common",
3
- "version": "3.0.0-beta.2303-02",
3
+ "version": "3.0.0-beta.2303-03",
4
4
  "ext": {
5
5
  "@js": {
6
6
  "file": "applicationinsights-common.js",
7
7
  "type": "text/javascript; charset=utf-8",
8
- "integrity": "sha256-4VEOcN5fcu6SkTknpPpZVRv5zcCP0ZGKobVYSzvU/MA= sha384-3DA77EVjvT954yaNc3nDor1TeSB+dy1mzs3FpLH7CPqEK7k/SknYtAHL4dWK3Cjf sha512-2hksL6Rw8eB5xgAdnnFM98TtWyrbA7N5h5UHMhifsON/esW7QHp3yP2GlWWCgU4+t0zCx4RJPTn+BrDixxiQ3g==",
8
+ "integrity": "sha256-47nArvutdhPqpHnFH0C8SY5g9rcx6KA3qmzIlMesMdw= sha384-QM7xovi2zdnDBmRowxpJm3Rq595/mMfmvUBCj99NwSN9UOvxHTDMIFGv2cN43pJL sha512-tI5/3zrMkw3L6gf/vhFVsTIH7CZWZ29GUqrgDNbcR9D1uV+YM1ky0iCIzBLnbMyyf6MGHQ2+bq5VZWAZsEXbXw==",
9
9
  "hashes": {
10
- "sha256": "4VEOcN5fcu6SkTknpPpZVRv5zcCP0ZGKobVYSzvU/MA=",
11
- "sha384": "3DA77EVjvT954yaNc3nDor1TeSB+dy1mzs3FpLH7CPqEK7k/SknYtAHL4dWK3Cjf",
12
- "sha512": "2hksL6Rw8eB5xgAdnnFM98TtWyrbA7N5h5UHMhifsON/esW7QHp3yP2GlWWCgU4+t0zCx4RJPTn+BrDixxiQ3g=="
10
+ "sha256": "47nArvutdhPqpHnFH0C8SY5g9rcx6KA3qmzIlMesMdw=",
11
+ "sha384": "QM7xovi2zdnDBmRowxpJm3Rq595/mMfmvUBCj99NwSN9UOvxHTDMIFGv2cN43pJL",
12
+ "sha512": "tI5/3zrMkw3L6gf/vhFVsTIH7CZWZ29GUqrgDNbcR9D1uV+YM1ky0iCIzBLnbMyyf6MGHQ2+bq5VZWAZsEXbXw=="
13
13
  }
14
14
  },
15
15
  "@min.js": {
16
16
  "file": "applicationinsights-common.min.js",
17
17
  "type": "text/javascript; charset=utf-8",
18
- "integrity": "sha256-Gv0Sr7edRk45aghQsmvMPkcbqkJ/jz3jtlP9Jb55Eh4= sha384-Z738FCSJLUAx8di4slT6WdLZug7Ahifq7jUMeCbAg9bSCkadrrT81is5fUfN0IUN sha512-1lwX842gM6y+QlK+bD8qYcT+bEvUtgFGNANfRMao72rL+WBCVSnCcBpmp4mG9oTKx79fS9arUbU/c6q3WBHg4A==",
18
+ "integrity": "sha256-gWZi7qTX3W+i63jghbrbobQ6Bn5eAnLuhYo1q61jE80= sha384-v+eNJYBpG5e9knsrgHTeqIxDNvNlWmNv9NEQ/dA+NRVmuInA2NKHSIMVbbi0rNWl sha512-DMJqEo787697J0B9tjTXGtd04L6jKiBahxFqB0LsGWmJx78LcupSPPswtWeJtcRAYhjiO8gZV7ZJWIu041ELGQ==",
19
19
  "hashes": {
20
- "sha256": "Gv0Sr7edRk45aghQsmvMPkcbqkJ/jz3jtlP9Jb55Eh4=",
21
- "sha384": "Z738FCSJLUAx8di4slT6WdLZug7Ahifq7jUMeCbAg9bSCkadrrT81is5fUfN0IUN",
22
- "sha512": "1lwX842gM6y+QlK+bD8qYcT+bEvUtgFGNANfRMao72rL+WBCVSnCcBpmp4mG9oTKx79fS9arUbU/c6q3WBHg4A=="
20
+ "sha256": "gWZi7qTX3W+i63jghbrbobQ6Bn5eAnLuhYo1q61jE80=",
21
+ "sha384": "v+eNJYBpG5e9knsrgHTeqIxDNvNlWmNv9NEQ/dA+NRVmuInA2NKHSIMVbbi0rNWl",
22
+ "sha512": "DMJqEo787697J0B9tjTXGtd04L6jKiBahxFqB0LsGWmJx78LcupSPPswtWeJtcRAYhjiO8gZV7ZJWIu041ELGQ=="
23
23
  }
24
24
  }
25
25
  }
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * Application Insights JavaScript SDK - Common, 3.0.0-beta.2303-02
2
+ * Application Insights JavaScript SDK - Common, 3.0.0-beta.2303-03
3
3
  * Copyright (c) Microsoft and contributors. All rights reserved.
4
4
  */
5
5
  (function (global, factory) {
@@ -28,6 +28,7 @@
28
28
  var POLYFILL_TAG = "_polyfill";
29
29
  var INDEX_OF = "indexOf";
30
30
  var LENGTH = "length";
31
+ var DONE = "done";
31
32
  var VALUE = "value";
32
33
  var NAME = "name";
33
34
  var ObjClass$1 = Object;
@@ -403,6 +404,27 @@
403
404
  (!_symbolFor || (_globalLazyTestHooks.lzy && !_symbol.b)) && getSymbol();
404
405
  return (_symbolFor.v || polySymbolFor)(key);
405
406
  }
407
+ function isIterator(value) {
408
+ return !!value && isFunction(value.next);
409
+ }
410
+ function arrAppend(target, elms) {
411
+ if (!isUndefined(elms) && target) {
412
+ if (isArray(elms)) {
413
+ target.push.apply(target, elms);
414
+ }
415
+ else if (isIterator(elms)) {
416
+ var value = elms.next();
417
+ while (!value[DONE]) {
418
+ target.push(value[VALUE]);
419
+ value = elms.next();
420
+ }
421
+ }
422
+ else {
423
+ target.push(elms);
424
+ }
425
+ }
426
+ return target;
427
+ }
406
428
  function arrForEach(theArray, callbackfn, thisArg) {
407
429
  if (theArray) {
408
430
  var len = theArray[LENGTH] >>> 0;
@@ -1019,6 +1041,7 @@
1019
1041
  var STR_EMPTY = "";
1020
1042
  var STR_ERROR_TO_CONSOLE = "errorToConsole";
1021
1043
  var STR_WARN_TO_CONSOLE = "warnToConsole";
1044
+ var STR_NOT_DYNAMIC_ERROR = "Not dynamic - ";
1022
1045
 
1023
1046
  var rCamelCase = /-([a-z])/g;
1024
1047
  var rNormalizeInvalid = /([^\w\d_$])/g;
@@ -1217,7 +1240,7 @@
1217
1240
  return result;
1218
1241
  }
1219
1242
 
1220
- var version = "3.0.0-beta.2303-02";
1243
+ var version = "3.0.0-beta.2303-03";
1221
1244
  var instanceName = "." + newId(6);
1222
1245
  var _dataUid = 0;
1223
1246
  function createUniqueNamespace(name, includeVersion) {
@@ -1722,6 +1745,15 @@
1722
1745
  _makeDynamicObject(theState, newTarget);
1723
1746
  return cfgHandler;
1724
1747
  }
1748
+ function _logInvalidAccess(logger, message) {
1749
+ if (logger) {
1750
+ logger[STR_WARN_TO_CONSOLE ](message);
1751
+ logger[_DYN_THROW_INTERNAL ](2 , 108 , message);
1752
+ }
1753
+ else {
1754
+ throwInvalidAccess(message);
1755
+ }
1756
+ }
1725
1757
  function createDynamicConfig(config, defaultConfig, logger, inPlace) {
1726
1758
  var dynamicHandler = _createDynamicHandler(logger, config || {}, inPlace);
1727
1759
  if (defaultConfig) {
@@ -1729,6 +1761,14 @@
1729
1761
  }
1730
1762
  return dynamicHandler;
1731
1763
  }
1764
+ function onConfigChange(config, configHandler, logger) {
1765
+ var handler = config[CFG_HANDLER_LINK] || config;
1766
+ if (handler.cfg && (handler.cfg === config || handler.cfg[CFG_HANDLER_LINK] === handler)) {
1767
+ return handler[_DYN_WATCH ](configHandler);
1768
+ }
1769
+ _logInvalidAccess(logger, STR_NOT_DYNAMIC_ERROR + dumpObj(config));
1770
+ createDynamicConfig(config, null, logger)[_DYN_WATCH ](configHandler);
1771
+ }
1732
1772
 
1733
1773
  var _aiNamespace = null;
1734
1774
  function _getExtensionNamespace() {
@@ -2044,6 +2084,31 @@
2044
2084
  return traceParent;
2045
2085
  }
2046
2086
 
2087
+ function createUnloadHookContainer() {
2088
+ var _hooks = [];
2089
+ function _doUnload(logger) {
2090
+ var oldHooks = _hooks;
2091
+ _hooks = [];
2092
+ arrForEach(oldHooks, function (fn) {
2093
+ try {
2094
+ (fn.rm || fn.remove).call(fn);
2095
+ }
2096
+ catch (e) {
2097
+ _throwInternal(logger, 2 , 73 , "Unloading:" + dumpObj(e));
2098
+ }
2099
+ });
2100
+ }
2101
+ function _addHook(hooks) {
2102
+ if (hooks) {
2103
+ arrAppend(_hooks, hooks);
2104
+ }
2105
+ }
2106
+ return {
2107
+ run: _doUnload,
2108
+ add: _addHook
2109
+ };
2110
+ }
2111
+
2047
2112
  var DisabledPropertyName = "Microsoft_ApplicationInsights_BypassAjaxInstrumentation";
2048
2113
  var SampleRate = "sampleRate";
2049
2114
  var ProcessLegacy = "ProcessLegacy";
@@ -2606,7 +2671,7 @@
2606
2671
 
2607
2672
  var THROTTLE_STORAGE_PREFIX = "appInsightsThrottle";
2608
2673
  var ThrottleMgr = /** @class */ (function () {
2609
- function ThrottleMgr(throttleMgr, core, namePrefix) {
2674
+ function ThrottleMgr(config, core, namePrefix, unloadHookContainer) {
2610
2675
  var _self = this;
2611
2676
  var _canUseLocalStorage;
2612
2677
  var _logger;
@@ -2619,6 +2684,9 @@
2619
2684
  var _isReady = false;
2620
2685
  var _isSpecificDaysGiven = false;
2621
2686
  _initConfig();
2687
+ _self["_getDbgPlgTargets"] = function () {
2688
+ return [_queue];
2689
+ };
2622
2690
  _self.getConfig = function () {
2623
2691
  return _config;
2624
2692
  };
@@ -2634,8 +2702,10 @@
2634
2702
  _self.flush = function () {
2635
2703
  try {
2636
2704
  if (_isReady && _queue[_DYN_LENGTH ] > 0) {
2637
- arrForEach(_queue, function (item) {
2638
- _self.sendMessage(item.msgID, item[_DYN_MESSAGE ], item.severity);
2705
+ var items = _queue.slice(0);
2706
+ _queue = [];
2707
+ arrForEach(items, function (item) {
2708
+ _flushMessage(item.msgID, item[_DYN_MESSAGE ], item.severity, false);
2639
2709
  });
2640
2710
  return true;
2641
2711
  }
@@ -2649,6 +2719,9 @@
2649
2719
  return _self.flush();
2650
2720
  };
2651
2721
  _self.sendMessage = function (msgID, message, severity) {
2722
+ return _flushMessage(msgID, message, severity, true);
2723
+ };
2724
+ function _flushMessage(msgID, message, severity, saveUnsentMsg) {
2652
2725
  if (_isReady) {
2653
2726
  var isSampledIn = _canSampledIn();
2654
2727
  if (!isSampledIn) {
@@ -2682,40 +2755,47 @@
2682
2755
  };
2683
2756
  }
2684
2757
  else {
2685
- _queue.push({
2686
- msgID: msgID,
2687
- message: message,
2688
- severity: severity
2689
- });
2758
+ if (!!saveUnsentMsg) {
2759
+ _queue.push({
2760
+ msgID: msgID,
2761
+ message: message,
2762
+ severity: severity
2763
+ });
2764
+ }
2690
2765
  }
2691
2766
  return null;
2692
- };
2767
+ }
2693
2768
  function _initConfig() {
2694
- var _a, _b;
2695
- _canUseLocalStorage = utlCanUseLocalStorage();
2696
2769
  _logger = safeGetLogger(core);
2697
2770
  _isTriggered = false;
2698
- _namePrefix = isNotNullOrUndefined(namePrefix) ? namePrefix : "";
2699
2771
  _queue = [];
2700
- var configMgr = throttleMgr;
2701
- _config = {};
2702
- _config[_DYN_DISABLED ] = !!configMgr[_DYN_DISABLED ];
2703
- _config.msgKey = configMgr.msgKey;
2704
- var configInterval = configMgr[_DYN_INTERVAL ] || {};
2705
- _isSpecificDaysGiven = (configInterval === null || configInterval === void 0 ? void 0 : configInterval.daysOfMonth) && (configInterval === null || configInterval === void 0 ? void 0 : configInterval.daysOfMonth[_DYN_LENGTH ]) > 0;
2706
- _config[_DYN_INTERVAL ] = _getIntervalConfig(configInterval);
2707
- var limit = {
2708
- samplingRate: ((_a = configMgr.limit) === null || _a === void 0 ? void 0 : _a.samplingRate) || 100,
2709
- maxSendNumber: ((_b = configMgr.limit) === null || _b === void 0 ? void 0 : _b.maxSendNumber) || 1
2710
- };
2711
- _config.limit = limit;
2712
- _localStorageName = _getLocalStorageName(_config.msgKey, _namePrefix);
2713
- if (_canUseLocalStorage && _localStorageName) {
2714
- _localStorageObj = _getLocalStorageObj(utlGetLocalStorage(_logger, _localStorageName), _logger, _localStorageName);
2715
- }
2716
- if (_localStorageObj) {
2717
- _isTriggered = _isTriggeredOnCurDate(_localStorageObj[_DYN_PRE_TRIGGER_DATE ]);
2718
- }
2772
+ _namePrefix = isNotNullOrUndefined(namePrefix) ? namePrefix : "";
2773
+ unloadHookContainer = unloadHookContainer || createUnloadHookContainer();
2774
+ config = createDynamicConfig(config || {}, null, _logger).cfg;
2775
+ var unloadHook = onConfigChange((config), function () {
2776
+ var _a, _b;
2777
+ _canUseLocalStorage = utlCanUseLocalStorage();
2778
+ var configMgr = config || {};
2779
+ _config = {};
2780
+ _config[_DYN_DISABLED ] = !!configMgr[_DYN_DISABLED ];
2781
+ _config.msgKey = configMgr.msgKey || 0 ;
2782
+ var configInterval = configMgr[_DYN_INTERVAL ] || {};
2783
+ _isSpecificDaysGiven = (configInterval === null || configInterval === void 0 ? void 0 : configInterval.daysOfMonth) && (configInterval === null || configInterval === void 0 ? void 0 : configInterval.daysOfMonth[_DYN_LENGTH ]) > 0;
2784
+ _config[_DYN_INTERVAL ] = _getIntervalConfig(configInterval);
2785
+ var limit = {
2786
+ samplingRate: ((_a = configMgr.limit) === null || _a === void 0 ? void 0 : _a.samplingRate) || 100,
2787
+ maxSendNumber: ((_b = configMgr.limit) === null || _b === void 0 ? void 0 : _b.maxSendNumber) || 1
2788
+ };
2789
+ _config.limit = limit;
2790
+ _localStorageName = _getLocalStorageName(_config.msgKey, _namePrefix);
2791
+ if (_canUseLocalStorage && _localStorageName) {
2792
+ _localStorageObj = _getLocalStorageObj(utlGetLocalStorage(_logger, _localStorageName), _logger, _localStorageName);
2793
+ }
2794
+ if (_localStorageObj) {
2795
+ _isTriggered = _isTriggeredOnCurDate(_localStorageObj[_DYN_PRE_TRIGGER_DATE ]);
2796
+ }
2797
+ });
2798
+ unloadHookContainer && unloadHookContainer.add(unloadHook);
2719
2799
  }
2720
2800
  function _getIntervalConfig(interval) {
2721
2801
  interval = interval || {};
@@ -2825,6 +2905,9 @@
2825
2905
  return false;
2826
2906
  }
2827
2907
  function _checkInterval(interval, start, current) {
2908
+ if (interval <= 0) {
2909
+ return 1;
2910
+ }
2828
2911
  return (current >= start) && (current - start) % interval == 0 ? Math.floor((current - start) / interval) + 1 : -1;
2829
2912
  }
2830
2913
  function _sendMessage(msgID, logger, message, severity) {