{"version":3,"file":"applicationinsights-web--8YBaNhB.js","sources":["../../node_modules/@microsoft/dynamicproto-js/dist-es5/DynamicProto.js","../../node_modules/@microsoft/applicationinsights-shims/dist-es5/Constants.js","../../node_modules/@microsoft/applicationinsights-shims/dist-es5/TsLibShims.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK.Enums/EnumHelperFuncs.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK.Enums/InitActiveStatusEnum.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/__DynamicConstants.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/AggregationError.js","../../node_modules/@nevware21/ts-async/dist/es5/mod/ts-async.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/InternalConstants.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/HelperFuncs.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/EnvUtils.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/RandomHelper.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/DataCacheHelper.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/Config/ConfigDefaults.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/Config/DynamicSupport.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/Config/DynamicProperty.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/Config/DynamicState.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/Config/DynamicConfig.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/AsyncUtils.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/Constants.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/Config/ConfigDefaultHelpers.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/DbgExtensionUtils.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/DiagnosticLogger.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/CookieMgr.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/NotificationManager.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/PerfManager.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/CoreUtils.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/W3cTraceParent.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/TelemetryHelpers.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/ProcessTelemetryContext.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/UnloadHandlerContainer.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/UnloadHookContainer.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/BaseTelemetryPlugin.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/TelemetryInitializerPlugin.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/AppInsightsCore.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/ResponseHelpers.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/SenderPostManager.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/EventHelpers.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK.Enums/LoggingEnums.js","../../node_modules/@microsoft/applicationinsights-core-js/dist-es5/JavaScriptSDK/InstrumentHooks.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Constants.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/RequestResponseHeaders.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/__DynamicConstants.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Telemetry/Common/DataSanitizer.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/UrlHelperFuncs.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Util.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Enums.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/StorageHelperFuncs.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/ThrottleMgr.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/ConnectionStringParser.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Telemetry/Common/Envelope.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Telemetry/Event.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Telemetry/Exception.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Telemetry/Common/DataPoint.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Telemetry/Metric.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/HelperFuncs.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Telemetry/PageView.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Telemetry/RemoteDependencyData.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Telemetry/Trace.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Telemetry/PageViewPerformance.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Telemetry/Common/Data.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Interfaces/Contracts/SeverityLevel.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Interfaces/Contracts/ContextTagKeys.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/TelemetryItemCreator.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Interfaces/PartAExtensions.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/DomHelperFuncs.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/Offline.js","../../node_modules/@microsoft/applicationinsights-common/dist-es5/applicationinsights-common.js","../../node_modules/@microsoft/applicationinsights-analytics-js/dist-es5/__DynamicConstants.js","../../node_modules/@microsoft/applicationinsights-analytics-js/dist-es5/JavaScriptSDK/Telemetry/PageViewManager.js","../../node_modules/@microsoft/applicationinsights-analytics-js/dist-es5/JavaScriptSDK/Telemetry/PageViewPerformanceManager.js","../../node_modules/@microsoft/applicationinsights-analytics-js/dist-es5/JavaScriptSDK/Telemetry/PageVisitTimeManager.js","../../node_modules/@microsoft/applicationinsights-analytics-js/dist-es5/JavaScriptSDK/Timing.js","../../node_modules/@microsoft/applicationinsights-analytics-js/dist-es5/JavaScriptSDK/AnalyticsPlugin.js","../../node_modules/@microsoft/applicationinsights-cfgsync-js/dist-es5/__DynamicConstants.js","../../node_modules/@microsoft/applicationinsights-cfgsync-js/dist-es5/CfgSyncHelperFuncs.js","../../node_modules/@microsoft/applicationinsights-cfgsync-js/dist-es5/CfgSyncPlugin.js","../../node_modules/@microsoft/applicationinsights-channel-js/dist-es5/InternalConstants.js","../../node_modules/@microsoft/applicationinsights-channel-js/dist-es5/__DynamicConstants.js","../../node_modules/@microsoft/applicationinsights-channel-js/dist-es5/EnvelopeCreator.js","../../node_modules/@microsoft/applicationinsights-channel-js/dist-es5/SendBuffer.js","../../node_modules/@microsoft/applicationinsights-channel-js/dist-es5/Serializer.js","../../node_modules/@microsoft/applicationinsights-channel-js/dist-es5/TelemetryProcessors/SamplingScoreGenerators/HashCodeScoreGenerator.js","../../node_modules/@microsoft/applicationinsights-channel-js/dist-es5/TelemetryProcessors/SamplingScoreGenerators/SamplingScoreGenerator.js","../../node_modules/@microsoft/applicationinsights-channel-js/dist-es5/TelemetryProcessors/Sample.js","../../node_modules/@microsoft/applicationinsights-channel-js/dist-es5/Sender.js","../../node_modules/@microsoft/applicationinsights-dependencies-js/dist-es5/InternalConstants.js","../../node_modules/@microsoft/applicationinsights-dependencies-js/dist-es5/__DynamicConstants.js","../../node_modules/@microsoft/applicationinsights-dependencies-js/dist-es5/ajaxRecord.js","../../node_modules/@microsoft/applicationinsights-dependencies-js/dist-es5/ajax.js","../../node_modules/@microsoft/applicationinsights-properties-js/dist-es5/Context/Application.js","../../node_modules/@microsoft/applicationinsights-properties-js/dist-es5/Context/Device.js","../../node_modules/@microsoft/applicationinsights-properties-js/dist-es5/Context/Internal.js","../../node_modules/@microsoft/applicationinsights-properties-js/dist-es5/Context/Location.js","../../node_modules/@microsoft/applicationinsights-properties-js/dist-es5/__DynamicConstants.js","../../node_modules/@microsoft/applicationinsights-properties-js/dist-es5/Context/Session.js","../../node_modules/@microsoft/applicationinsights-properties-js/dist-es5/Context/TelemetryTrace.js","../../node_modules/@microsoft/applicationinsights-properties-js/dist-es5/Context/User.js","../../node_modules/@microsoft/applicationinsights-properties-js/dist-es5/TelemetryContext.js","../../node_modules/@microsoft/applicationinsights-properties-js/dist-es5/PropertiesPlugin.js","../../node_modules/@microsoft/applicationinsights-web/dist-es5/InternalConstants.js","../../node_modules/@microsoft/applicationinsights-web/dist-es5/__DynamicConstants.js","../../node_modules/@microsoft/applicationinsights-web/dist-es5/AISku.js","../../node_modules/@microsoft/applicationinsights-web/dist-es5/ApplicationInsightsContainer.js"],"sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nvar _a;\r\nimport { getGlobal, objCreate, objHasOwnProperty, throwTypeError } from \"@nevware21/ts-utils\";\r\n;\r\nvar UNDEFINED = \"undefined\";\r\n/**\r\n * Constant string defined to support minimization\r\n * @ignore\r\n */\r\nvar Constructor = 'constructor';\r\n/**\r\n * Constant string defined to support minimization\r\n * @ignore\r\n */\r\nvar Prototype = 'prototype';\r\n/**\r\n * Constant string defined to support minimization\r\n * @ignore\r\n */\r\nvar strFunction = 'function';\r\n/**\r\n * Used to define the name of the instance function lookup table\r\n * @ignore\r\n */\r\nvar DynInstFuncTable = '_dynInstFuncs';\r\n/**\r\n * Name used to tag the dynamic prototype function\r\n * @ignore\r\n */\r\nvar DynProxyTag = '_isDynProxy';\r\n/**\r\n * Name added to a prototype to define the dynamic prototype \"class\" name used to lookup the function table\r\n * @ignore\r\n */\r\nvar DynClassName = '_dynClass';\r\n/**\r\n * Prefix added to the classname to avoid any name clashes with other instance level properties\r\n * @ignore\r\n */\r\nvar DynClassNamePrefix = '_dynCls$';\r\n/**\r\n * A tag which is used to check if we have already to attempted to set the instance function if one is not present\r\n * @ignore\r\n */\r\nvar DynInstChkTag = '_dynInstChk';\r\n/**\r\n * A tag which is used to check if we are allows to try and set an instance function is one is not present. Using the same\r\n * tag name as the function level but a different const name for readability only.\r\n */\r\nvar DynAllowInstChkTag = DynInstChkTag;\r\n/**\r\n * The global (imported) instances where the global performance options are stored\r\n */\r\nvar DynProtoDefaultOptions = '_dfOpts';\r\n/**\r\n * Value used as the name of a class when it cannot be determined\r\n * @ignore\r\n */\r\nvar UnknownValue = '_unknown_';\r\n/**\r\n * Constant string defined to support minimization\r\n * @ignore\r\n */\r\nvar str__Proto = \"__proto__\";\r\n/**\r\n * The polyfill version of __proto__ so that it doesn't cause issues for anyone not expecting it to exist\r\n */\r\nvar DynProtoBaseProto = \"_dyn\" + str__Proto;\r\n/**\r\n * Runtime Global holder for dynamicProto settings\r\n */\r\nvar DynProtoGlobalSettings = \"__dynProto$Gbl\";\r\n/**\r\n * Track the current prototype for IE8 as you can't look back to get the prototype\r\n */\r\nvar DynProtoCurrent = \"_dynInstProto\";\r\n/**\r\n * Constant string defined to support minimization\r\n * @ignore\r\n */\r\nvar strUseBaseInst = 'useBaseInst';\r\n/**\r\n * Constant string defined to support minimization\r\n * @ignore\r\n */\r\nvar strSetInstFuncs = 'setInstFuncs';\r\nvar Obj = Object;\r\n/**\r\n * Pre-lookup to check if we are running on a modern browser (i.e. not IE8)\r\n * @ignore\r\n */\r\nvar _objGetPrototypeOf = Obj[\"getPrototypeOf\"];\r\n/**\r\n * Pre-lookup to check for the existence of this function\r\n */\r\nvar _objGetOwnProps = Obj[\"getOwnPropertyNames\"];\r\n// Since 1.1.7 moving these to the runtime global to work around mixed version and module issues\r\n// See Issue https://github.com/microsoft/DynamicProto-JS/issues/57 for details\r\nvar _gbl = getGlobal();\r\nvar _gblInst = _gbl[DynProtoGlobalSettings] || (_gbl[DynProtoGlobalSettings] = {\r\n o: (_a = {},\r\n _a[strSetInstFuncs] = true,\r\n _a[strUseBaseInst] = true,\r\n _a),\r\n n: 1000 // Start new global index @ 1000 so we \"fix\" some cases when mixed with 1.1.6 or earlier\r\n});\r\n/**\r\n * Helper used to check whether the target is an Object prototype or Array prototype\r\n * @ignore\r\n */\r\nfunction _isObjectOrArrayPrototype(target) {\r\n return target && (target === Obj[Prototype] || target === Array[Prototype]);\r\n}\r\n/**\r\n * Helper used to check whether the target is an Object prototype, Array prototype or Function prototype\r\n * @ignore\r\n */\r\nfunction _isObjectArrayOrFunctionPrototype(target) {\r\n return _isObjectOrArrayPrototype(target) || target === Function[Prototype];\r\n}\r\n/**\r\n * Helper used to get the prototype of the target object as getPrototypeOf is not available in an ES3 environment.\r\n * @ignore\r\n */\r\nfunction _getObjProto(target) {\r\n var newProto;\r\n if (target) {\r\n // This method doesn't exist in older browsers (e.g. IE8)\r\n if (_objGetPrototypeOf) {\r\n return _objGetPrototypeOf(target);\r\n }\r\n var curProto = target[str__Proto] || target[Prototype] || (target[Constructor] ? target[Constructor][Prototype] : null);\r\n // Using the pre-calculated value as IE8 doesn't support looking up the prototype of a prototype and thus fails for more than 1 base class\r\n newProto = target[DynProtoBaseProto] || curProto;\r\n if (!objHasOwnProperty(target, DynProtoBaseProto)) {\r\n // As this prototype doesn't have this property then this is from an inherited class so newProto is the base to return so save it\r\n // so we can look it up value (which for a multiple hierarchy dynamicProto will be the base class)\r\n delete target[DynProtoCurrent]; // Delete any current value allocated to this instance so we pick up the value from prototype hierarchy\r\n newProto = target[DynProtoBaseProto] = target[DynProtoCurrent] || target[DynProtoBaseProto];\r\n target[DynProtoCurrent] = curProto;\r\n }\r\n }\r\n return newProto;\r\n}\r\n/**\r\n * Helper to get the properties of an object, including none enumerable ones as functions on a prototype in ES6\r\n * are not enumerable.\r\n * @param target\r\n */\r\nfunction _forEachProp(target, func) {\r\n var props = [];\r\n if (_objGetOwnProps) {\r\n props = _objGetOwnProps(target);\r\n }\r\n else {\r\n for (var name_1 in target) {\r\n if (typeof name_1 === \"string\" && objHasOwnProperty(target, name_1)) {\r\n props.push(name_1);\r\n }\r\n }\r\n }\r\n if (props && props.length > 0) {\r\n for (var lp = 0; lp < props.length; lp++) {\r\n func(props[lp]);\r\n }\r\n }\r\n}\r\n/**\r\n * Helper function to check whether the provided function name is a potential candidate for dynamic\r\n * callback and prototype generation.\r\n * @param target The target object, may be a prototype or class object\r\n * @param funcName The function name\r\n * @param skipOwn Skips the check for own property\r\n * @ignore\r\n */\r\nfunction _isDynamicCandidate(target, funcName, skipOwn) {\r\n return (funcName !== Constructor && typeof target[funcName] === strFunction && (skipOwn || objHasOwnProperty(target, funcName)) && funcName !== str__Proto && funcName !== Prototype);\r\n}\r\n/**\r\n * Helper to throw a TypeError exception\r\n * @param message the message\r\n * @ignore\r\n */\r\nfunction _throwTypeError(message) {\r\n throwTypeError(\"DynamicProto: \" + message);\r\n}\r\n/**\r\n * Returns a collection of the instance functions that are defined directly on the thisTarget object, it does\r\n * not return any inherited functions\r\n * @param thisTarget The object to get the instance functions from\r\n * @ignore\r\n */\r\nfunction _getInstanceFuncs(thisTarget) {\r\n // Get the base proto\r\n var instFuncs = objCreate(null);\r\n // Save any existing instance functions\r\n _forEachProp(thisTarget, function (name) {\r\n // Don't include any dynamic prototype instances - as we only want the real functions\r\n if (!instFuncs[name] && _isDynamicCandidate(thisTarget, name, false)) {\r\n // Create an instance callback for passing the base function to the caller\r\n instFuncs[name] = thisTarget[name];\r\n }\r\n });\r\n return instFuncs;\r\n}\r\n/**\r\n * Returns whether the value is included in the array\r\n * @param values The array of values\r\n * @param value The value\r\n */\r\nfunction _hasVisited(values, value) {\r\n for (var lp = values.length - 1; lp >= 0; lp--) {\r\n if (values[lp] === value) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n}\r\n/**\r\n * Returns an object that contains callback functions for all \"base/super\" functions, this is used to \"save\"\r\n * enabling calling super.xxx() functions without requiring that the base \"class\" has defined a prototype references\r\n * @param target The current instance\r\n * @ignore\r\n */\r\nfunction _getBaseFuncs(classProto, thisTarget, instFuncs, useBaseInst) {\r\n function _instFuncProxy(target, funcHost, funcName) {\r\n var theFunc = funcHost[funcName];\r\n if (theFunc[DynProxyTag] && useBaseInst) {\r\n // grab and reuse the hosted looking function (if available) otherwise the original passed function\r\n var instFuncTable = target[DynInstFuncTable] || {};\r\n if (instFuncTable[DynAllowInstChkTag] !== false) {\r\n theFunc = (instFuncTable[funcHost[DynClassName]] || {})[funcName] || theFunc;\r\n }\r\n }\r\n return function () {\r\n // eslint-disable-next-line prefer-rest-params\r\n return theFunc.apply(target, arguments);\r\n };\r\n }\r\n // Start creating a new baseFuncs by creating proxies for the instance functions (as they may get replaced)\r\n var baseFuncs = objCreate(null);\r\n _forEachProp(instFuncs, function (name) {\r\n // Create an instance callback for passing the base function to the caller\r\n baseFuncs[name] = _instFuncProxy(thisTarget, instFuncs, name);\r\n });\r\n // Get the base prototype functions\r\n var baseProto = _getObjProto(classProto);\r\n var visited = [];\r\n // Don't include base object functions for Object, Array or Function\r\n while (baseProto && !_isObjectArrayOrFunctionPrototype(baseProto) && !_hasVisited(visited, baseProto)) {\r\n // look for prototype functions\r\n _forEachProp(baseProto, function (name) {\r\n // Don't include any dynamic prototype instances - as we only want the real functions\r\n // For IE 7/8 the prototype lookup doesn't provide the full chain so we need to bypass the \r\n // hasOwnProperty check we get all of the methods, main difference is that IE7/8 doesn't return\r\n // the Object prototype methods while bypassing the check\r\n if (!baseFuncs[name] && _isDynamicCandidate(baseProto, name, !_objGetPrototypeOf)) {\r\n // Create an instance callback for passing the base function to the caller\r\n baseFuncs[name] = _instFuncProxy(thisTarget, baseProto, name);\r\n }\r\n });\r\n // We need to find all possible functions that might be overloaded by walking the entire prototype chain\r\n // This avoids the caller from needing to check whether it's direct base class implements the function or not\r\n // by walking the entire chain it simplifies the usage and issues from upgrading any of the base classes.\r\n visited.push(baseProto);\r\n baseProto = _getObjProto(baseProto);\r\n }\r\n return baseFuncs;\r\n}\r\nfunction _getInstFunc(target, funcName, proto, currentDynProtoProxy) {\r\n var instFunc = null;\r\n // We need to check whether the class name is defined directly on this prototype otherwise\r\n // it will walk the proto chain and return any parent proto classname.\r\n if (target && objHasOwnProperty(proto, DynClassName)) {\r\n var instFuncTable = target[DynInstFuncTable] || objCreate(null);\r\n instFunc = (instFuncTable[proto[DynClassName]] || objCreate(null))[funcName];\r\n if (!instFunc) {\r\n // Avoid stack overflow from recursive calling the same function\r\n _throwTypeError(\"Missing [\" + funcName + \"] \" + strFunction);\r\n }\r\n // We have the instance function, lets check it we can speed up further calls\r\n // by adding the instance function back directly on the instance (avoiding the dynamic func lookup)\r\n if (!instFunc[DynInstChkTag] && instFuncTable[DynAllowInstChkTag] !== false) {\r\n // If the instance already has an instance function we can't replace it\r\n var canAddInst = !objHasOwnProperty(target, funcName);\r\n // Get current prototype\r\n var objProto = _getObjProto(target);\r\n var visited = [];\r\n // Lookup the function starting at the top (instance level prototype) and traverse down, if the first matching function\r\n // if nothing is found or if the first hit is a dynamic proto instance then we can safely add an instance shortcut\r\n while (canAddInst && objProto && !_isObjectArrayOrFunctionPrototype(objProto) && !_hasVisited(visited, objProto)) {\r\n var protoFunc = objProto[funcName];\r\n if (protoFunc) {\r\n canAddInst = (protoFunc === currentDynProtoProxy);\r\n break;\r\n }\r\n // We need to find all possible initial functions to ensure that we don't bypass a valid override function\r\n visited.push(objProto);\r\n objProto = _getObjProto(objProto);\r\n }\r\n try {\r\n if (canAddInst) {\r\n // This instance doesn't have an instance func and the class hierarchy does have a higher level prototype version\r\n // so it's safe to directly assign for any subsequent calls (for better performance)\r\n target[funcName] = instFunc;\r\n }\r\n // Block further attempts to set the instance function for any\r\n instFunc[DynInstChkTag] = 1;\r\n }\r\n catch (e) {\r\n // Don't crash if the object is readonly or the runtime doesn't allow changing this\r\n // And set a flag so we don't try again for any function\r\n instFuncTable[DynAllowInstChkTag] = false;\r\n }\r\n }\r\n }\r\n return instFunc;\r\n}\r\nfunction _getProtoFunc(funcName, proto, currentDynProtoProxy) {\r\n var protoFunc = proto[funcName];\r\n // Check that the prototype function is not a self reference -- try to avoid stack overflow!\r\n if (protoFunc === currentDynProtoProxy) {\r\n // It is so lookup the base prototype\r\n protoFunc = _getObjProto(proto)[funcName];\r\n }\r\n if (typeof protoFunc !== strFunction) {\r\n _throwTypeError(\"[\" + funcName + \"] is not a \" + strFunction);\r\n }\r\n return protoFunc;\r\n}\r\n/**\r\n * Add the required dynamic prototype methods to the the class prototype\r\n * @param proto - The class prototype\r\n * @param className - The instance classname\r\n * @param target - The target instance\r\n * @param baseInstFuncs - The base instance functions\r\n * @param setInstanceFunc - Flag to allow prototype function to reset the instance function if one does not exist\r\n * @ignore\r\n */\r\nfunction _populatePrototype(proto, className, target, baseInstFuncs, setInstanceFunc) {\r\n function _createDynamicPrototype(proto, funcName) {\r\n var dynProtoProxy = function () {\r\n // Use the instance or prototype function\r\n var instFunc = _getInstFunc(this, funcName, proto, dynProtoProxy) || _getProtoFunc(funcName, proto, dynProtoProxy);\r\n // eslint-disable-next-line prefer-rest-params\r\n return instFunc.apply(this, arguments);\r\n };\r\n // Tag this function as a proxy to support replacing dynamic proxy elements (primary use case is for unit testing\r\n // via which can dynamically replace the prototype function reference)\r\n dynProtoProxy[DynProxyTag] = 1;\r\n return dynProtoProxy;\r\n }\r\n if (!_isObjectOrArrayPrototype(proto)) {\r\n var instFuncTable = target[DynInstFuncTable] = target[DynInstFuncTable] || objCreate(null);\r\n if (!_isObjectOrArrayPrototype(instFuncTable)) {\r\n var instFuncs_1 = instFuncTable[className] = (instFuncTable[className] || objCreate(null)); // fetch and assign if as it may not exist yet\r\n // Set whether we are allow to lookup instances, if someone has set to false then do not re-enable\r\n if (instFuncTable[DynAllowInstChkTag] !== false) {\r\n instFuncTable[DynAllowInstChkTag] = !!setInstanceFunc;\r\n }\r\n if (!_isObjectOrArrayPrototype(instFuncs_1)) {\r\n _forEachProp(target, function (name) {\r\n // Only add overridden functions\r\n if (_isDynamicCandidate(target, name, false) && target[name] !== baseInstFuncs[name]) {\r\n // Save the instance Function to the lookup table and remove it from the instance as it's not a dynamic proto function\r\n instFuncs_1[name] = target[name];\r\n delete target[name];\r\n // Add a dynamic proto if one doesn't exist or if a prototype function exists and it's not a dynamic one\r\n if (!objHasOwnProperty(proto, name) || (proto[name] && !proto[name][DynProxyTag])) {\r\n proto[name] = _createDynamicPrototype(proto, name);\r\n }\r\n }\r\n });\r\n }\r\n }\r\n }\r\n}\r\n/**\r\n * Checks whether the passed prototype object appears to be correct by walking the prototype hierarchy of the instance\r\n * @param classProto The class prototype instance\r\n * @param thisTarget The current instance that will be checked whether the passed prototype instance is in the hierarchy\r\n * @ignore\r\n */\r\nfunction _checkPrototype(classProto, thisTarget) {\r\n // This method doesn't existing in older browsers (e.g. IE8)\r\n if (_objGetPrototypeOf) {\r\n // As this is primarily a coding time check, don't bother checking if running in IE8 or lower\r\n var visited = [];\r\n var thisProto = _getObjProto(thisTarget);\r\n while (thisProto && !_isObjectArrayOrFunctionPrototype(thisProto) && !_hasVisited(visited, thisProto)) {\r\n if (thisProto === classProto) {\r\n return true;\r\n }\r\n // This avoids the caller from needing to check whether it's direct base class implements the function or not\r\n // by walking the entire chain it simplifies the usage and issues from upgrading any of the base classes.\r\n visited.push(thisProto);\r\n thisProto = _getObjProto(thisProto);\r\n }\r\n return false;\r\n }\r\n // If objGetPrototypeOf doesn't exist then just assume everything is ok.\r\n return true;\r\n}\r\n/**\r\n * Gets the current prototype name using the ES6 name if available otherwise falling back to a use unknown as the name.\r\n * It's not critical for this to return a name, it's used to decorate the generated unique name for easier debugging only.\r\n * @param target\r\n * @param unknownValue\r\n * @ignore\r\n */\r\nfunction _getObjName(target, unknownValue) {\r\n if (objHasOwnProperty(target, Prototype)) {\r\n // Look like a prototype\r\n return target.name || unknownValue || UnknownValue;\r\n }\r\n return (((target || {})[Constructor]) || {}).name || unknownValue || UnknownValue;\r\n}\r\n/**\r\n * Helper function when creating dynamic (inline) functions for classes, this helper performs the following tasks :-\r\n * - Saves references to all defined base class functions\r\n * - Calls the delegateFunc with the current target (this) and a base object reference that can be used to call all \"super\" functions.\r\n * - Will populate the class prototype for all overridden functions to support class extension that call the prototype instance.\r\n * Callers should use this helper when declaring all function within the constructor of a class, as mentioned above the delegateFunc is\r\n * passed both the target \"this\" and an object that can be used to call any base (super) functions, using this based object in place of\r\n * super.XXX() (which gets expanded to _super.prototype.XXX()) provides a better minification outcome and also ensures the correct \"this\"\r\n * context is maintained as TypeScript creates incorrect references using super.XXXX() for dynamically defined functions i.e. Functions\r\n * defined in the constructor or some other function (rather than declared as complete typescript functions).\r\n * ### Usage\r\n * ```typescript\r\n * import dynamicProto from \"@microsoft/dynamicproto-js\";\r\n * class ExampleClass extends BaseClass {\r\n * constructor() {\r\n * dynamicProto(ExampleClass, this, (_self, base) => {\r\n * // This will define a function that will be converted to a prototype function\r\n * _self.newFunc = () => {\r\n * // Access any \"this\" instance property\r\n * if (_self.someProperty) {\r\n * ...\r\n * }\r\n * }\r\n * // This will define a function that will be converted to a prototype function\r\n * _self.myFunction = () => {\r\n * // Access any \"this\" instance property\r\n * if (_self.someProperty) {\r\n * // Call the base version of the function that we are overriding\r\n * base.myFunction();\r\n * }\r\n * ...\r\n * }\r\n * _self.initialize = () => {\r\n * ...\r\n * }\r\n * // Warnings: While the following will work as _self is simply a reference to\r\n * // this, if anyone overrides myFunction() the overridden will be called first\r\n * // as the normal JavaScript method resolution will occur and the defined\r\n * // _self.initialize() function is actually gets removed from the instance and\r\n * // a proxy prototype version is created to reference the created method.\r\n * _self.initialize();\r\n * });\r\n * }\r\n * }\r\n * ```\r\n * @typeparam DPType This is the generic type of the class, used to keep intellisense valid\r\n * @typeparam DPCls The type that contains the prototype of the current class\r\n * @param theClass - This is the current class instance which contains the prototype for the current class\r\n * @param target - The current \"this\" (target) reference, when the class has been extended this.prototype will not be the 'theClass' value.\r\n * @param delegateFunc - The callback function (closure) that will create the dynamic function\r\n * @param options - Additional options to configure how the dynamic prototype operates\r\n */\r\nexport default function dynamicProto(theClass, target, delegateFunc, options) {\r\n // Make sure that the passed theClass argument looks correct\r\n if (!objHasOwnProperty(theClass, Prototype)) {\r\n _throwTypeError(\"theClass is an invalid class definition.\");\r\n }\r\n // Quick check to make sure that the passed theClass argument looks correct (this is a common copy/paste error)\r\n var classProto = theClass[Prototype];\r\n if (!_checkPrototype(classProto, target)) {\r\n _throwTypeError(\"[\" + _getObjName(theClass) + \"] not in hierarchy of [\" + _getObjName(target) + \"]\");\r\n }\r\n var className = null;\r\n if (objHasOwnProperty(classProto, DynClassName)) {\r\n // Only grab the class name if it's defined on this prototype (i.e. don't walk the prototype chain)\r\n className = classProto[DynClassName];\r\n }\r\n else {\r\n // As not all browser support name on the prototype creating a unique dynamic one if we have not already\r\n // assigned one, so we can use a simple string as the lookup rather than an object for the dynamic instance\r\n // function table lookup.\r\n className = DynClassNamePrefix + _getObjName(theClass, \"_\") + \"$\" + _gblInst.n;\r\n _gblInst.n++;\r\n classProto[DynClassName] = className;\r\n }\r\n var perfOptions = dynamicProto[DynProtoDefaultOptions];\r\n var useBaseInst = !!perfOptions[strUseBaseInst];\r\n if (useBaseInst && options && options[strUseBaseInst] !== undefined) {\r\n useBaseInst = !!options[strUseBaseInst];\r\n }\r\n // Get the current instance functions\r\n var instFuncs = _getInstanceFuncs(target);\r\n // Get all of the functions for any base instance (before they are potentially overridden)\r\n var baseFuncs = _getBaseFuncs(classProto, target, instFuncs, useBaseInst);\r\n // Execute the delegate passing in both the current target \"this\" and \"base\" function references\r\n // Note casting the same type as we don't actually have the base class here and this will provide some intellisense support\r\n delegateFunc(target, baseFuncs);\r\n // Don't allow setting instance functions for older IE instances\r\n var setInstanceFunc = !!_objGetPrototypeOf && !!perfOptions[strSetInstFuncs];\r\n if (setInstanceFunc && options) {\r\n setInstanceFunc = !!options[strSetInstFuncs];\r\n }\r\n // Populate the Prototype for any overridden instance functions\r\n _populatePrototype(classProto, className, target, instFuncs, setInstanceFunc !== false);\r\n}\r\n/**\r\n * Exposes the default global options to allow global configuration, if the global values are disabled these will override\r\n * any passed values. This is primarily exposed to support unit-testing without the need for individual classes to expose\r\n * their internal usage of dynamic proto.\r\n */\r\ndynamicProto[DynProtoDefaultOptions] = _gblInst.o;\r\n//# sourceMappingURL=DynamicProto.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nexport var strShimFunction = \"function\";\r\nexport var strShimObject = \"object\";\r\nexport var strShimUndefined = \"undefined\";\r\nexport var strShimPrototype = \"prototype\";\r\nexport var strDefault = \"default\";\r\nexport var ObjClass = Object;\r\nexport var ObjProto = ObjClass[strShimPrototype];\r\n//# sourceMappingURL=Constants.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nimport { getGlobal, objAssign, objCreate, objDefineProp, objHasOwnProperty, throwTypeError } from \"@nevware21/ts-utils\";\r\nimport { ObjClass, ObjProto, strDefault, strShimFunction, strShimPrototype } from \"./Constants\";\r\n// Most of these functions have been directly shamelessly \"lifted\" from the https://github.com/@microsoft/tslib and\r\n// modified to be ES5 compatible and applying several minification and tree-shaking techniques so that Application Insights\r\n// can successfully use TypeScript \"importHelpers\" which imports tslib during compilation but it will use these at runtime\r\n// Which is also why all of the functions have not been included as Application Insights currently doesn't use or require\r\n// them.\r\nexport var SymbolObj = (getGlobal() || {})[\"Symbol\"];\r\nexport var ReflectObj = (getGlobal() || {})[\"Reflect\"];\r\nexport var __hasReflect = !!ReflectObj;\r\nvar strDecorate = \"decorate\";\r\nvar strMetadata = \"metadata\";\r\nvar strGetOwnPropertySymbols = \"getOwnPropertySymbols\";\r\nvar strIterator = \"iterator\";\r\nvar strHasOwnProperty = \"hasOwnProperty\";\r\nexport var __objAssignFnImpl = function (t) {\r\n // tslint:disable-next-line: ban-comma-operator\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) {\r\n if (ObjProto[strHasOwnProperty].call(s, p)) {\r\n t[p] = s[p];\r\n }\r\n }\r\n }\r\n return t;\r\n};\r\nexport var __assignFn = objAssign || __objAssignFnImpl;\r\n// tslint:disable-next-line: only-arrow-functions\r\nvar extendStaticsFn = function (d, b) {\r\n extendStaticsFn = ObjClass[\"setPrototypeOf\"] ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n ({ __proto__: [] } instanceof Array && function (d, b) {\r\n d.__proto__ = b;\r\n }) ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n function (d, b) {\r\n for (var p in b) {\r\n if (b[strHasOwnProperty](p)) {\r\n d[p] = b[p];\r\n }\r\n }\r\n };\r\n return extendStaticsFn(d, b);\r\n};\r\nexport function __extendsFn(d, b) {\r\n if (typeof b !== strShimFunction && b !== null) {\r\n throwTypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n }\r\n extendStaticsFn(d, b);\r\n function __() {\r\n this.constructor = d;\r\n }\r\n // tslint:disable-next-line: ban-comma-operator\r\n d[strShimPrototype] = b === null ? objCreate(b) : (__[strShimPrototype] = b[strShimPrototype], new __());\r\n}\r\nexport function __restFn(s, e) {\r\n var t = {};\r\n for (var k in s) {\r\n if (objHasOwnProperty(s, k) && e.indexOf(k) < 0) {\r\n t[k] = s[k];\r\n }\r\n }\r\n if (s != null && typeof ObjClass[strGetOwnPropertySymbols] === strShimFunction) {\r\n for (var i = 0, p = ObjClass[strGetOwnPropertySymbols](s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && ObjProto[\"propertyIsEnumerable\"].call(s, p[i])) {\r\n t[p[i]] = s[p[i]];\r\n }\r\n }\r\n }\r\n return t;\r\n}\r\nexport function __decorateFn(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = ObjClass[\"getOwnPropertyDescriptor\"](target, key) : desc, d;\r\n if (__hasReflect && typeof ReflectObj[strDecorate] === strShimFunction) {\r\n r = ReflectObj[strDecorate](decorators, target, key, desc);\r\n }\r\n else {\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n // eslint-disable-next-line no-cond-assign\r\n if (d = decorators[i]) {\r\n r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n }\r\n }\r\n }\r\n // tslint:disable-next-line:ban-comma-operator\r\n return c > 3 && r && objDefineProp(target, key, r), r;\r\n}\r\nexport function __paramFn(paramIndex, decorator) {\r\n return function (target, key) {\r\n decorator(target, key, paramIndex);\r\n };\r\n}\r\nexport function __metadataFn(metadataKey, metadataValue) {\r\n if (__hasReflect && ReflectObj[strMetadata] === strShimFunction) {\r\n return ReflectObj[strMetadata](metadataKey, metadataValue);\r\n }\r\n}\r\nexport function __exportStarFn(m, o) {\r\n for (var p in m) {\r\n if (p !== strDefault && !objHasOwnProperty(o, p)) {\r\n __createBindingFn(o, m, p);\r\n }\r\n }\r\n}\r\nexport function __createBindingFn(o, m, k, k2) {\r\n if (k2 === undefined) {\r\n k2 = k;\r\n }\r\n if (!!objDefineProp) {\r\n objDefineProp(o, k2, {\r\n enumerable: true,\r\n get: function () {\r\n return m[k];\r\n }\r\n });\r\n }\r\n else {\r\n o[k2] = m[k];\r\n }\r\n}\r\nexport function __valuesFn(o) {\r\n var s = typeof SymbolObj === strShimFunction && SymbolObj[strIterator], m = s && o[s], i = 0;\r\n if (m) {\r\n return m.call(o);\r\n }\r\n if (o && typeof o.length === \"number\") {\r\n return {\r\n next: function () {\r\n if (o && i >= o.length) {\r\n o = void 0;\r\n }\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n }\r\n throwTypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\nexport function __readFn(o, n) {\r\n var m = typeof SymbolObj === strShimFunction && o[SymbolObj[strIterator]];\r\n if (!m) {\r\n return o;\r\n }\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) {\r\n ar.push(r.value);\r\n }\r\n }\r\n catch (error) {\r\n e = {\r\n error: error\r\n };\r\n }\r\n finally {\r\n try {\r\n // tslint:disable-next-line:no-conditional-assignment\r\n if (r && !r.done && (m = i[\"return\"])) {\r\n m.call(i);\r\n }\r\n }\r\n finally {\r\n if (e) {\r\n // eslint-disable-next-line no-unsafe-finally\r\n throw e.error;\r\n }\r\n }\r\n }\r\n return ar;\r\n}\r\n/** @deprecated */\r\nexport function __spreadArraysFn() {\r\n var theArgs = arguments;\r\n // Calculate new total size\r\n for (var s = 0, i = 0, il = theArgs.length; i < il; i++) {\r\n s += theArgs[i].length;\r\n }\r\n // Create new full array\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++) {\r\n for (var a = theArgs[i], j = 0, jl = a.length; j < jl; j++, k++) {\r\n r[k] = a[j];\r\n }\r\n }\r\n return r;\r\n}\r\nexport function __spreadArrayFn(to, from) {\r\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++) {\r\n to[j] = from[i];\r\n }\r\n return to;\r\n}\r\nexport function __makeTemplateObjectFn(cooked, raw) {\r\n if (objDefineProp) {\r\n objDefineProp(cooked, \"raw\", { value: raw });\r\n }\r\n else {\r\n cooked.raw = raw;\r\n }\r\n return cooked;\r\n}\r\nexport function __importStarFn(mod) {\r\n if (mod && mod.__esModule) {\r\n return mod;\r\n }\r\n var result = {};\r\n if (mod != null) {\r\n for (var k in mod) {\r\n if (k !== strDefault && Object.prototype.hasOwnProperty.call(mod, k)) {\r\n __createBindingFn(result, mod, k);\r\n }\r\n }\r\n }\r\n // Set default module\r\n if (!!objDefineProp) {\r\n objDefineProp(result, strDefault, { enumerable: true, value: mod });\r\n }\r\n else {\r\n result[strDefault] = mod;\r\n }\r\n return result;\r\n}\r\nexport function __importDefaultFn(mod) {\r\n return (mod && mod.__esModule) ? mod : { strDefault: mod };\r\n}\r\n//# sourceMappingURL=TsLibShims.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { createEnum, createTypeMap } from \"@nevware21/ts-utils\";\r\n/**\r\n * Create an enum style object which has both the key \\=\\> value and value \\=\\> key mappings\r\n * @param values - The values to populate on the new object\r\n * @returns\r\n */\r\nexport var createEnumStyle = createEnum;\r\n/**\r\n * Create a 2 index map that maps an enum's key and value to the defined map value, X[\"key\"] \\=\\> mapValue and X[0] \\=\\> mapValue.\r\n * Generic values\r\n * - E = the const enum type (typeof eRequestHeaders);\r\n * - V = Identifies the valid values for the keys, this should include both the enum numeric and string key of the type. The\r\n * resulting \"Value\" of each entry identifies the valid values withing the assignments.\r\n * @param values - The values to populate on the new object\r\n * @returns\r\n */\r\nexport var createValueMap = createTypeMap;\r\n//# sourceMappingURL=EnumHelperFuncs.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { createEnumStyle } from \"./EnumHelperFuncs\";\r\nexport var ActiveStatus = createEnumStyle({\r\n NONE: 0 /* eActiveStatus.NONE */,\r\n PENDING: 3 /* eActiveStatus.PENDING */,\r\n INACTIVE: 1 /* eActiveStatus.INACTIVE */,\r\n ACTIVE: 2 /* eActiveStatus.ACTIVE */\r\n});\r\n//# sourceMappingURL=InitActiveStatusEnum.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES5 which can result in a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_TO_LOWER_CASE = \"toLowerCase\"; // Count: 11\r\nexport var _DYN_LENGTH = \"length\"; // Count: 55\r\nexport var _DYN_WARN_TO_CONSOLE = \"warnToConsole\"; // Count: 4\r\nexport var _DYN_THROW_INTERNAL = \"throwInternal\"; // Count: 5\r\nexport var _DYN_WATCH = \"watch\"; // Count: 7\r\nexport var _DYN_APPLY = \"apply\"; // Count: 7\r\nexport var _DYN_PUSH = \"push\"; // Count: 35\r\nexport var _DYN_SPLICE = \"splice\"; // Count: 8\r\nexport var _DYN_LOGGER = \"logger\"; // Count: 20\r\nexport var _DYN_CANCEL = \"cancel\"; // Count: 6\r\nexport var _DYN_INITIALIZE = \"initialize\"; // Count: 5\r\nexport var _DYN_IDENTIFIER = \"identifier\"; // Count: 8\r\nexport var _DYN_REMOVE_NOTIFICATION_0 = \"removeNotificationListener\"; // Count: 4\r\nexport var _DYN_ADD_NOTIFICATION_LIS1 = \"addNotificationListener\"; // Count: 4\r\nexport var _DYN_IS_INITIALIZED = \"isInitialized\"; // Count: 10\r\nexport var _DYN_VALUE = \"value\"; // Count: 5\r\nexport var _DYN_GET_NOTIFY_MGR = \"getNotifyMgr\"; // Count: 5\r\nexport var _DYN_GET_PLUGIN = \"getPlugin\"; // Count: 5\r\nexport var _DYN_NAME = \"name\"; // Count: 9\r\nexport var _DYN_PROCESS_NEXT = \"processNext\"; // Count: 15\r\nexport var _DYN_GET_PROCESS_TEL_CONT2 = \"getProcessTelContext\"; // Count: 2\r\nexport var _DYN_ENABLED = \"enabled\"; // Count: 6\r\nexport var _DYN_STOP_POLLING_INTERNA3 = \"stopPollingInternalLogs\"; // Count: 2\r\nexport var _DYN_UNLOAD = \"unload\"; // Count: 7\r\nexport var _DYN_ON_COMPLETE = \"onComplete\"; // Count: 4\r\nexport var _DYN_VERSION = \"version\"; // Count: 4\r\nexport var _DYN_LOGGING_LEVEL_CONSOL4 = \"loggingLevelConsole\"; // Count: 2\r\nexport var _DYN_CREATE_NEW = \"createNew\"; // Count: 7\r\nexport var _DYN_TEARDOWN = \"teardown\"; // Count: 9\r\nexport var _DYN_MESSAGE_ID = \"messageId\"; // Count: 4\r\nexport var _DYN_MESSAGE = \"message\"; // Count: 7\r\nexport var _DYN_DIAG_LOG = \"diagLog\"; // Count: 9\r\nexport var _DYN__DO_TEARDOWN = \"_doTeardown\"; // Count: 5\r\nexport var _DYN_UPDATE = \"update\"; // Count: 5\r\nexport var _DYN_GET_NEXT = \"getNext\"; // Count: 10\r\nexport var _DYN_SET_NEXT_PLUGIN = \"setNextPlugin\"; // Count: 5\r\nexport var _DYN_USER_AGENT = \"userAgent\"; // Count: 5\r\nexport var _DYN_SPLIT = \"split\"; // Count: 7\r\nexport var _DYN_REPLACE = \"replace\"; // Count: 9\r\nexport var _DYN_TYPE = \"type\"; // Count: 13\r\nexport var _DYN_EVT_NAME = \"evtName\"; // Count: 4\r\nexport var _DYN_STATUS = \"status\"; // Count: 5\r\nexport var _DYN_GET_ALL_RESPONSE_HEA5 = \"getAllResponseHeaders\"; // Count: 2\r\nexport var _DYN_IS_CHILD_EVT = \"isChildEvt\"; // Count: 3\r\nexport var _DYN_DATA = \"data\"; // Count: 6\r\nexport var _DYN_GET_CTX = \"getCtx\"; // Count: 6\r\nexport var _DYN_SET_CTX = \"setCtx\"; // Count: 10\r\nexport var _DYN_ITEMS_RECEIVED = \"itemsReceived\"; // Count: 3\r\nexport var _DYN_URL_STRING = \"urlString\"; // Count: 5\r\nexport var _DYN_HEADERS = \"headers\"; // Count: 5\r\nexport var _DYN_TIMEOUT = \"timeout\"; // Count: 6\r\nexport var _DYN_TRACE_FLAGS = \"traceFlags\"; // Count: 5\r\nexport var _DYN_GET_ATTRIBUTE = \"getAttribute\"; // Count: 3\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { arrForEach, createCustomError, dumpObj } from \"@nevware21/ts-utils\";\r\nimport { _DYN_LENGTH } from \"../__DynamicConstants\";\r\nvar aggregationErrorType;\r\n/**\r\n * Throws an Aggregation Error which includes all of the errors that led to this error occurring\r\n * @param message - The message describing the aggregation error (the sourceError details are added to this)\r\n * @param sourceErrors - An array of the errors that caused this situation\r\n */\r\nexport function throwAggregationError(message, sourceErrors) {\r\n if (!aggregationErrorType) {\r\n aggregationErrorType = createCustomError(\"AggregationError\", function (self, args) {\r\n if (args[_DYN_LENGTH /* @min:%2elength */] > 1) {\r\n // Save the provided errors\r\n self.errors = args[1];\r\n }\r\n });\r\n }\r\n var theMessage = message || \"One or more errors occurred.\";\r\n arrForEach(sourceErrors, function (srcError, idx) {\r\n theMessage += \"\\n\".concat(idx, \" > \").concat(dumpObj(srcError));\r\n });\r\n throw new aggregationErrorType(theMessage, sourceErrors || []);\r\n}\r\n//# sourceMappingURL=AggregationError.js.map","/*!\n * NevWare21 Solutions LLC - ts-async, 0.5.4\n * https://github.com/nevware21/ts-async\n * Copyright (c) NevWare21 Solutions LLC and contributors. All rights reserved.\n * Licensed under the MIT license.\n */\nimport { isPromiseLike, objDefineProperties, getDocument, createCachedValue, safe, getInst, dumpObj, arrSlice, objDefineProp, hasSymbol, getKnownSymbol, isFunction, throwTypeError, iterForOf, scheduleTimeout, isNode, getWindow, getGlobal, objDefine, objToString, isUndefined, isArray, arrForEach, isIterable, createCustomError, isNumber, scheduleIdleCallback, utcNow, getLength, isIterator, fnCall, arrIndexOf } from '@nevware21/ts-utils';\n\nvar STR_PROMISE = \"Promise\";\nvar DONE = \"done\";\nvar VALUE = \"value\";\nvar RETURN = \"return\";\nvar REJECTED = \"rejected\";\n\nfunction doAwaitResponse(value, cb) {\n return doAwait(value, function (value) {\n return cb ? cb({\n status: \"fulfilled\",\n rejected: false,\n value: value\n }) : value;\n }, function (reason) {\n return cb ? cb({\n status: REJECTED,\n rejected: true,\n reason: reason\n }) : reason;\n });\n}\nfunction doAwait(value, resolveFn, rejectFn, finallyFn) {\n var result = value;\n try {\n if (isPromiseLike(value)) {\n if (resolveFn || rejectFn) {\n result = value.then(resolveFn, rejectFn);\n }\n }\n else {\n try {\n if (resolveFn) {\n result = resolveFn(value);\n }\n }\n catch (err) {\n if (rejectFn) {\n result = rejectFn(err);\n }\n else {\n throw err;\n }\n }\n }\n }\n finally {\n if (finallyFn) {\n doFinally(result, finallyFn);\n }\n }\n return result;\n}\nfunction doFinally(value, finallyFn) {\n var result = value;\n if (finallyFn) {\n if (isPromiseLike(value)) {\n if (value.finally) {\n result = value.finally(finallyFn);\n }\n else {\n result = value.then(function (value) {\n finallyFn();\n return value;\n }, function (reason) {\n finallyFn();\n throw reason;\n });\n }\n }\n else {\n finallyFn();\n }\n }\n return result;\n}\n\n/*#__NO_SIDE_EFFECTS__*/\nfunction _pureAssign(func1, func2) {\n return func1 || func2;\n}\n\nvar _debugState;\nvar _debugResult;\nvar _debugHandled;\nvar _promiseDebugEnabled = false;\nfunction _addDebugState$1(thePromise, stateFn, resultFn, handledFn) {\n _debugState = _debugState || { toString: function () { return \"[[PromiseState]]\"; } };\n _debugResult = _debugResult || { toString: function () { return \"[[PromiseResult]]\"; } };\n _debugHandled = _debugHandled || { toString: function () { return \"[[PromiseIsHandled]]\"; } };\n var props = {};\n props[_debugState] = { get: stateFn };\n props[_debugResult] = { get: resultFn };\n props[_debugHandled] = { get: handledFn };\n objDefineProperties(thePromise, props);\n}\nfunction setPromiseDebugState(enabled, logger) {\n _promiseDebugEnabled = enabled;\n}\n\nvar STRING_STATES = [\n \"pending\", \"resolving\", \"resolved\", REJECTED\n];\n\nvar DISPATCH_EVENT = \"dispatchEvent\";\nvar _hasInitEvent;\nfunction _hasInitEventFn(doc) {\n var evt;\n if (doc && doc.createEvent) {\n evt = doc.createEvent(\"Event\");\n }\n return (!!evt && evt.initEvent);\n}\nfunction emitEvent(target, evtName, populateEvent, useNewEvent) {\n var doc = getDocument();\n !_hasInitEvent && (_hasInitEvent = createCachedValue(!!safe(_hasInitEventFn, [doc]).v));\n var theEvt = _hasInitEvent.v ? doc.createEvent(\"Event\") : (useNewEvent ? new Event(evtName) : {});\n populateEvent && populateEvent(theEvt);\n if (_hasInitEvent.v) {\n theEvt.initEvent(evtName, false, true);\n }\n if (theEvt && target[DISPATCH_EVENT]) {\n target[DISPATCH_EVENT](theEvt);\n }\n else {\n var handler = target[\"on\" + evtName];\n if (handler) {\n handler(theEvt);\n }\n else {\n var theConsole = getInst(\"console\");\n theConsole && (theConsole[\"error\"] || theConsole[\"log\"])(evtName, dumpObj(theEvt));\n }\n }\n}\n\nvar NODE_UNHANDLED_REJECTION = \"unhandledRejection\";\nvar UNHANDLED_REJECTION = NODE_UNHANDLED_REJECTION.toLowerCase();\nvar _currentPromiseId = [];\nvar _uniquePromiseId = 0;\nvar _unhandledRejectionTimeout = 10;\nvar _aggregationError;\nvar _hasPromiseRejectionEvent;\nfunction dumpFnObj(value) {\n if (isFunction(value)) {\n return value.toString();\n }\n return dumpObj(value);\n}\n/*#__NO_SIDE_EFFECTS__*/\nfunction _createAggregationError(values) {\n !_aggregationError && (_aggregationError = createCachedValue(safe(getInst, [\"AggregationError\"]).v || createCustomError(\"AggregationError\", function (self, args) {\n self.errors = args[0];\n })));\n return new _aggregationError.v(values);\n}\nfunction _createPromise(newPromise, processor, executor) {\n var additionalArgs = arrSlice(arguments, 3);\n var _state = 0 ;\n var _hasResolved = false;\n var _settledValue;\n var _queue = [];\n var _id = _uniquePromiseId++;\n var _parentId = _currentPromiseId.length > 0 ? _currentPromiseId[_currentPromiseId.length - 1] : undefined;\n var _handled = false;\n var _unHandledRejectionHandler = null;\n var _thePromise;\n function _then(onResolved, onRejected) {\n try {\n _currentPromiseId.push(_id);\n _handled = true;\n _unHandledRejectionHandler && _unHandledRejectionHandler.cancel();\n _unHandledRejectionHandler = null;\n var thenPromise = newPromise(function (resolve, reject) {\n _queue.push(function () {\n try {\n var handler = _state === 2 ? onResolved : onRejected;\n var value = isUndefined(handler) ? _settledValue : (isFunction(handler) ? handler(_settledValue) : handler);\n if (isPromiseLike(value)) {\n value.then(resolve, reject);\n }\n else if (handler) {\n resolve(value);\n }\n else if (_state === 3 ) {\n reject(value);\n }\n else {\n resolve(value);\n }\n }\n catch (e) {\n reject(e);\n }\n });\n if (_hasResolved) {\n _processQueue();\n }\n }, additionalArgs);\n return thenPromise;\n }\n finally {\n _currentPromiseId.pop();\n }\n }\n function _catch(onRejected) {\n return _then(undefined, onRejected);\n }\n function _finally(onFinally) {\n var thenFinally = onFinally;\n var catchFinally = onFinally;\n if (isFunction(onFinally)) {\n thenFinally = function (value) {\n onFinally && onFinally();\n return value;\n };\n catchFinally = function (reason) {\n onFinally && onFinally();\n throw reason;\n };\n }\n return _then(thenFinally, catchFinally);\n }\n function _strState() {\n return STRING_STATES[_state];\n }\n function _processQueue() {\n if (_queue.length > 0) {\n var pending = _queue.slice();\n _queue = [];\n _handled = true;\n _unHandledRejectionHandler && _unHandledRejectionHandler.cancel();\n _unHandledRejectionHandler = null;\n processor(pending);\n }\n }\n function _createSettleIfFn(newState, allowState) {\n return function (theValue) {\n if (_state === allowState) {\n if (newState === 2 && isPromiseLike(theValue)) {\n _state = 1 ;\n theValue.then(_createSettleIfFn(2 , 1 ), _createSettleIfFn(3 , 1 ));\n return;\n }\n _state = newState;\n _hasResolved = true;\n _settledValue = theValue;\n _processQueue();\n if (!_handled && newState === 3 && !_unHandledRejectionHandler) {\n _unHandledRejectionHandler = scheduleTimeout(_notifyUnhandledRejection, _unhandledRejectionTimeout);\n }\n }\n };\n }\n function _notifyUnhandledRejection() {\n if (!_handled) {\n _handled = true;\n if (isNode()) {\n process.emit(NODE_UNHANDLED_REJECTION, _settledValue, _thePromise);\n }\n else {\n var gbl = getWindow() || getGlobal();\n !_hasPromiseRejectionEvent && (_hasPromiseRejectionEvent = createCachedValue(safe((getInst), [STR_PROMISE + \"RejectionEvent\"]).v));\n emitEvent(gbl, UNHANDLED_REJECTION, function (theEvt) {\n objDefine(theEvt, \"promise\", { g: function () { return _thePromise; } });\n theEvt.reason = _settledValue;\n return theEvt;\n }, !!_hasPromiseRejectionEvent.v);\n }\n }\n }\n _thePromise = {\n then: _then,\n \"catch\": _catch,\n finally: _finally\n };\n objDefineProp(_thePromise, \"state\", {\n get: _strState\n });\n if (_promiseDebugEnabled) {\n _addDebugState$1(_thePromise, _strState, function () { return objToString(_settledValue); }, function () { return _handled; });\n }\n if (hasSymbol()) {\n _thePromise[getKnownSymbol(11 )] = \"IPromise\";\n }\n function _toString() {\n return \"IPromise\" + (_promiseDebugEnabled ? \"[\" + _id + (!isUndefined(_parentId) ? (\":\" + _parentId) : \"\") + \"]\" : \"\") + \" \" + _strState() + (_hasResolved ? (\" - \" + dumpFnObj(_settledValue)) : \"\") + (\"\");\n }\n _thePromise.toString = _toString;\n (function _initialize() {\n if (!isFunction(executor)) {\n throwTypeError(STR_PROMISE + \": executor is not a function - \" + dumpFnObj(executor));\n }\n var _rejectFn = _createSettleIfFn(3 , 0 );\n try {\n executor.call(_thePromise, _createSettleIfFn(2 , 0 ), _rejectFn);\n }\n catch (e) {\n _rejectFn(e);\n }\n })();\n return _thePromise;\n}\n/*#__NO_SIDE_EFFECTS__*/\nfunction _createAllPromise(newPromise) {\n return function (input) {\n var additionalArgs = arrSlice(arguments, 1);\n return newPromise(function (resolve, reject) {\n try {\n var values_1 = [];\n var pending_1 = 1;\n iterForOf(input, function (item, idx) {\n if (item) {\n pending_1++;\n doAwait(item, function (value) {\n values_1[idx] = value;\n if (--pending_1 === 0) {\n resolve(values_1);\n }\n }, reject);\n }\n });\n pending_1--;\n if (pending_1 === 0) {\n resolve(values_1);\n }\n }\n catch (e) {\n reject(e);\n }\n }, additionalArgs);\n };\n}\n/*#__NO_SIDE_EFFECTS__*/\nfunction _createResolvedPromise(newPromise) {\n return function (value) {\n var additionalArgs = arrSlice(arguments, 1);\n if (isPromiseLike(value)) {\n return value;\n }\n return newPromise(function (resolve) {\n resolve(value);\n }, additionalArgs);\n };\n}\n/*#__NO_SIDE_EFFECTS__*/\nfunction _createRejectedPromise(newPromise) {\n return function (reason) {\n var additionalArgs = arrSlice(arguments, 1);\n return newPromise(function (_resolve, reject) {\n reject(reason);\n }, additionalArgs);\n };\n}\n/*#__NO_SIDE_EFFECTS__*/\nfunction _createAllSettledPromise(newPromise) {\n return createCachedValue(function (input) {\n var additionalArgs = arrSlice(arguments, 1);\n return newPromise(function (resolve, reject) {\n var values = [];\n var pending = 1;\n function processItem(item, idx) {\n pending++;\n doAwaitResponse(item, function (value) {\n if (value.rejected) {\n values[idx] = {\n status: REJECTED,\n reason: value.reason\n };\n }\n else {\n values[idx] = {\n status: \"fulfilled\",\n value: value.value\n };\n }\n if (--pending === 0) {\n resolve(values);\n }\n });\n }\n try {\n if (isArray(input)) {\n arrForEach(input, processItem);\n }\n else if (isIterable(input)) {\n iterForOf(input, processItem);\n }\n else {\n throwTypeError(\"Input is not an iterable\");\n }\n pending--;\n if (pending === 0) {\n resolve(values);\n }\n }\n catch (e) {\n reject(e);\n }\n }, additionalArgs);\n });\n}\n/*#__NO_SIDE_EFFECTS__*/\nfunction _createRacePromise(newPromise) {\n return createCachedValue(function (input) {\n var additionalArgs = arrSlice(arguments, 1);\n return newPromise(function (resolve, reject) {\n var isDone = false;\n function processItem(item) {\n doAwaitResponse(item, function (value) {\n if (!isDone) {\n isDone = true;\n if (value.rejected) {\n reject(value.reason);\n }\n else {\n resolve(value.value);\n }\n }\n });\n }\n try {\n if (isArray(input)) {\n arrForEach(input, processItem);\n }\n else if (isIterable(input)) {\n iterForOf(input, processItem);\n }\n else {\n throwTypeError(\"Input is not an iterable\");\n }\n }\n catch (e) {\n reject(e);\n }\n }, additionalArgs);\n });\n}\n/*#__NO_SIDE_EFFECTS__*/\nfunction _createAnyPromise(newPromise) {\n return createCachedValue(function (input) {\n var additionalArgs = arrSlice(arguments, 1);\n return newPromise(function (resolve, reject) {\n var theErros = [];\n var pending = 1;\n var isDone = false;\n function processItem(item, idx) {\n pending++;\n doAwaitResponse(item, function (value) {\n if (!value.rejected) {\n isDone = true;\n resolve(value.value);\n return;\n }\n else {\n theErros[idx] = value.reason;\n }\n if (--pending === 0 && !isDone) {\n reject(_createAggregationError(theErros));\n }\n });\n }\n try {\n if (isArray(input)) {\n arrForEach(input, processItem);\n }\n else if (isIterable(input)) {\n iterForOf(input, processItem);\n }\n else {\n throwTypeError(\"Input is not an iterable\");\n }\n pending--;\n if (pending === 0 && !isDone) {\n reject(_createAggregationError(theErros));\n }\n }\n catch (e) {\n reject(e);\n }\n }, additionalArgs);\n });\n}\n\nfunction syncItemProcessor(pending) {\n arrForEach(pending, function (fn) {\n try {\n fn();\n }\n catch (e) {\n }\n });\n}\nfunction timeoutItemProcessor(timeout) {\n var callbackTimeout = isNumber(timeout) ? timeout : 0;\n return function (pending) {\n scheduleTimeout(function () {\n syncItemProcessor(pending);\n }, callbackTimeout);\n };\n}\nfunction idleItemProcessor(timeout) {\n var options;\n if (timeout >= 0) {\n options = {\n timeout: +timeout\n };\n }\n return function (pending) {\n scheduleIdleCallback(function (deadline) {\n syncItemProcessor(pending);\n }, options);\n };\n}\n\nvar _allAsyncSettledCreator;\nvar _raceAsyncCreator;\nvar _anyAsyncCreator;\nfunction createAsyncPromise(executor, timeout) {\n return _createPromise(createAsyncPromise, timeoutItemProcessor(timeout), executor, timeout);\n}\nvar createAsyncAllPromise = /*#__PURE__*/ _createAllPromise(createAsyncPromise);\nvar createAsyncResolvedPromise = /*#__PURE__*/ _createResolvedPromise(createAsyncPromise);\nvar createAsyncRejectedPromise = /*#__PURE__*/ _createRejectedPromise(createAsyncPromise);\nfunction createAsyncAllSettledPromise(input, timeout) {\n !_allAsyncSettledCreator && (_allAsyncSettledCreator = _createAllSettledPromise(createAsyncPromise));\n return _allAsyncSettledCreator.v(input, timeout);\n}\nfunction createAsyncRacePromise(values, timeout) {\n !_raceAsyncCreator && (_raceAsyncCreator = _createRacePromise(createAsyncPromise));\n return _raceAsyncCreator.v(values, timeout);\n}\nfunction createAsyncAnyPromise(values, timeout) {\n !_anyAsyncCreator && (_anyAsyncCreator = _createAnyPromise(createAsyncPromise));\n return _anyAsyncCreator.v(values, timeout);\n}\n\nvar _promiseCls;\nvar _allCreator;\nvar _allNativeSettledCreator;\nvar _raceNativeCreator;\nvar _anyNativeCreator;\n/*#__NO_SIDE_EFFECTS__*/\nfunction _createNativePromiseHelper(name, func) {\n !_promiseCls && (_promiseCls = createCachedValue((safe(getInst, [STR_PROMISE]).v) || null));\n if (_promiseCls.v && _promiseCls.v[name]) {\n return createCachedValue(function (input, timeout) {\n return createNativePromise(function (resolve, reject) {\n _promiseCls.v[name](input).then(resolve, reject);\n });\n });\n }\n return func();\n}\nfunction createNativePromise(executor, timeout) {\n !_promiseCls && (_promiseCls = createCachedValue((safe(getInst, [STR_PROMISE]).v) || null));\n var PrmCls = _promiseCls.v;\n if (!PrmCls) {\n return createAsyncPromise(executor);\n }\n if (!isFunction(executor)) {\n throwTypeError(STR_PROMISE + \": executor is not a function - \" + dumpObj(executor));\n }\n var _state = 0 ;\n function _strState() {\n return STRING_STATES[_state];\n }\n var thePromise = new PrmCls(function (resolve, reject) {\n function _resolve(value) {\n _state = 2 ;\n resolve(value);\n }\n function _reject(reason) {\n _state = 3 ;\n reject(reason);\n }\n executor(_resolve, _reject);\n });\n objDefineProp(thePromise, \"state\", {\n get: _strState\n });\n return thePromise;\n}\nfunction createNativeAllPromise(input, timeout) {\n !_allCreator && (_allCreator = _createNativePromiseHelper(\"all\", function () { return createCachedValue(_createAllPromise(createNativePromise)); }));\n return _allCreator.v(input, timeout);\n}\nvar createNativeResolvedPromise = /*#__PURE__*/ _createResolvedPromise(createNativePromise);\nvar createNativeRejectedPromise = /*#__PURE__*/ _createRejectedPromise(createNativePromise);\nfunction createNativeAllSettledPromise(input, timeout) {\n !_allNativeSettledCreator && (_allNativeSettledCreator = _createNativePromiseHelper(\"allSettled\", function () { return _createAllSettledPromise(createNativePromise); }));\n return _allNativeSettledCreator.v(input, timeout);\n}\nfunction createNativeRacePromise(values, timeout) {\n !_raceNativeCreator && (_raceNativeCreator = _createNativePromiseHelper(\"race\", function () { return _createRacePromise(createNativePromise); }));\n return _raceNativeCreator.v(values, timeout);\n}\nfunction createNativeAnyPromise(values, timeout) {\n !_anyNativeCreator && (_anyNativeCreator = _createNativePromiseHelper(\"any\", function () { return _createAnyPromise(createNativePromise); }));\n return _anyNativeCreator.v(values, timeout);\n}\n\nvar _allSyncSettledCreator;\nvar _raceSyncCreator;\nvar _anySyncCreator;\nfunction createSyncPromise(executor) {\n return _createPromise(createSyncPromise, syncItemProcessor, executor);\n}\nvar createSyncAllPromise = /*#__PURE__*/ _createAllPromise(createSyncPromise);\nvar createSyncResolvedPromise = /*#__PURE__*/ _createResolvedPromise(createSyncPromise);\nvar createSyncRejectedPromise = /*#__PURE__*/ _createRejectedPromise(createSyncPromise);\nfunction createSyncAllSettledPromise(input, timeout) {\n !_allSyncSettledCreator && (_allSyncSettledCreator = _createAllSettledPromise(createSyncPromise));\n return _allSyncSettledCreator.v(input, timeout);\n}\nfunction createSyncRacePromise(values, timeout) {\n !_raceSyncCreator && (_raceSyncCreator = _createRacePromise(createSyncPromise));\n return _raceSyncCreator.v(values, timeout);\n}\nfunction createSyncAnyPromise(values, timeout) {\n !_anySyncCreator && (_anySyncCreator = _createAnyPromise(createSyncPromise));\n return _anySyncCreator.v(values, timeout);\n}\n\nvar _defaultIdleTimeout;\nvar _allIdleSettledCreator;\nvar _raceIdleCreator;\nvar _anyIdleCreator;\nfunction setDefaultIdlePromiseTimeout(idleDeadline) {\n _defaultIdleTimeout = idleDeadline;\n}\nvar setDefaultIdleTimeout = ( /*#__PURE__*/_pureAssign(setDefaultIdlePromiseTimeout));\nfunction createIdlePromise(executor, timeout) {\n var theTimeout = isUndefined(timeout) ? _defaultIdleTimeout : timeout;\n return _createPromise(createIdlePromise, idleItemProcessor(theTimeout), executor, theTimeout);\n}\nvar createIdleAllPromise = /*#__PURE__*/ _createAllPromise(createIdlePromise);\nvar createIdleResolvedPromise = /*#__PURE__*/ _createResolvedPromise(createIdlePromise);\nvar createIdleRejectedPromise = /*#__PURE__*/ _createRejectedPromise(createIdlePromise);\nfunction createIdleAllSettledPromise(input, timeout) {\n !_allIdleSettledCreator && (_allIdleSettledCreator = _createAllSettledPromise(createIdlePromise));\n return _allIdleSettledCreator.v(input, timeout);\n}\nfunction createIdleRacePromise(values, timeout) {\n !_raceIdleCreator && (_raceIdleCreator = _createRacePromise(createIdlePromise));\n return _raceIdleCreator.v(values, timeout);\n}\nfunction createIdleAnyPromise(values, timeout) {\n !_anyIdleCreator && (_anyIdleCreator = _createAnyPromise(createIdlePromise));\n return _anyIdleCreator.v(values, timeout);\n}\n\nvar _promiseCreator;\nvar _allSettledCreator;\nvar _raceCreator;\nvar _anyCreator;\nfunction setCreatePromiseImpl(creator) {\n _promiseCreator = creator ? createCachedValue(creator) : null;\n}\nfunction createPromise(executor, timeout) {\n !_promiseCreator && (_promiseCreator = createCachedValue(createNativePromise));\n return _promiseCreator.v.call(this, executor, timeout);\n}\nvar createAllPromise = /*#__PURE__*/ _createAllPromise(createPromise);\nvar createResolvedPromise = /*#__PURE__*/ _createResolvedPromise(createPromise);\nvar createRejectedPromise = /*#__PURE__*/ _createRejectedPromise(createPromise);\nfunction createAllSettledPromise(input, timeout) {\n !_allSettledCreator && (_allSettledCreator = _createAllSettledPromise(createPromise));\n return _allSettledCreator.v(input, timeout);\n}\nfunction createRacePromise(values, timeout) {\n !_raceCreator && (_raceCreator = _createRacePromise(createPromise));\n return _raceCreator.v(values, timeout);\n}\nfunction createAnyPromise(values, timeout) {\n !_anyCreator && (_anyCreator = _createAnyPromise(createPromise));\n return _anyCreator.v(values, timeout);\n}\n\nfunction createTimeoutPromise(timeout, resolveReject, message) {\n return createPromise(function (resolve, reject) {\n scheduleTimeout(function () {\n (resolveReject ? resolve : reject)(!isUndefined(message) ? message : \"Timeout of \" + timeout + \"ms exceeded\");\n }, timeout);\n });\n}\n\nfunction _doneChk(isDone, state, value, thisArg) {\n var result = isDone;\n state.res = value;\n if (!result) {\n if (state.isDone && isFunction(state.isDone)) {\n return doAwait(state.isDone.call(thisArg, state), function (done) {\n state.iter++;\n return !!done;\n });\n }\n else {\n result = !!state.isDone;\n }\n }\n state.iter++;\n return result;\n}\nfunction doWhileAsync(callbackFn, isDoneFn, thisArg) {\n var promise;\n var resolve;\n var reject = function (reason) {\n isDone = true;\n throw reason;\n };\n var isDone = false;\n var state = {\n st: utcNow(),\n iter: 0,\n isDone: isDoneFn || false\n };\n if (callbackFn) {\n var _createPromise_1 = function () {\n return createPromise(function (res, rej) {\n resolve = res;\n reject = rej;\n });\n };\n var _handleAsyncDone_1 = function (done) {\n isDone = !!done;\n if (!isDone) {\n _processNext_1();\n }\n else {\n resolve(state.res);\n }\n };\n var _processNext_1 = function () {\n while (!isDone) {\n try {\n var cbResult = callbackFn.call(thisArg, state);\n if (isPromiseLike(cbResult)) {\n promise = promise || _createPromise_1();\n doAwait(cbResult, function (res) {\n try {\n doAwait(_doneChk(isDone, state, res, thisArg), _handleAsyncDone_1, reject);\n }\n catch (e) {\n reject(e);\n }\n }, reject);\n return promise;\n }\n else {\n var dnRes = _doneChk(isDone, state, cbResult, thisArg);\n if (isPromiseLike(dnRes)) {\n promise = promise || _createPromise_1();\n doAwait(dnRes, _handleAsyncDone_1, reject);\n return promise;\n }\n else {\n isDone = !!dnRes;\n }\n }\n }\n catch (e) {\n reject(e);\n return promise;\n }\n }\n if (isDone && resolve) {\n resolve(state.res);\n }\n return promise || state.res;\n };\n return _processNext_1();\n }\n}\n\nfunction arrForEachAsync(theArray, callbackFn, thisArg) {\n if (theArray) {\n var len_1 = getLength(theArray);\n if (len_1) {\n var isDone = function (state) {\n if (state.iter >= len_1 || state.res === -1) {\n return true;\n }\n };\n return doWhileAsync(function (state) {\n var idx = state.iter;\n if (idx in theArray) {\n return callbackFn.call(thisArg || theArray, theArray[idx], idx, theArray);\n }\n }, isDone);\n }\n }\n}\n\nvar _iterSymbol;\nvar _iterAsyncSymbol;\nfunction iterForOfAsync(iter, callbackFn, thisArg) {\n var err;\n var iterResult;\n var theIter = iter;\n function onFailed(failed) {\n err = { e: failed };\n if (theIter.throw) {\n iterResult = null;\n theIter.throw(err);\n }\n throw failed;\n }\n function onFinally() {\n try {\n if (iterResult && !iterResult[DONE]) {\n theIter[RETURN] && theIter[RETURN](iterResult);\n }\n }\n finally {\n if (err) {\n throw err.e;\n }\n }\n }\n if (iter) {\n if (!isIterator(iter)) {\n !_iterAsyncSymbol && (_iterAsyncSymbol = createCachedValue(getKnownSymbol(0 )));\n theIter = iter[_iterAsyncSymbol.v] ? iter[_iterAsyncSymbol.v]() : null;\n if (!theIter) {\n !_iterSymbol && (_iterSymbol = createCachedValue(getKnownSymbol(3 )));\n theIter = iter[_iterSymbol.v] ? iter[_iterSymbol.v]() : null;\n }\n }\n if (theIter && isIterator(theIter)) {\n var result = void 0;\n try {\n result = doWhileAsync(function (state) {\n return doAwait(theIter.next(), function (res) {\n iterResult = res;\n if (!res[DONE]) {\n return fnCall(callbackFn, thisArg || theIter, iterResult[VALUE], state.iter, theIter);\n }\n }, function (reason) {\n state.isDone = true;\n onFailed(reason);\n });\n }, function (state) {\n if (!iterResult || iterResult[DONE] || state.res === -1) {\n onFinally();\n return true;\n }\n }, thisArg || theIter);\n if (isPromiseLike(result)) {\n result = doFinally(result.catch(onFailed), onFinally);\n }\n return result;\n }\n catch (failed) {\n onFailed(failed);\n }\n finally {\n if (result && !isPromiseLike(result)) {\n onFinally();\n }\n }\n }\n }\n}\n\nvar REJECT = \"reject\";\nvar REJECTED_ERROR = \"Rejected\";\nvar _schedulerId = 0;\nvar _debugName;\nvar _debugIntState;\nvar _customErrors = {};\nfunction _rejectDone() {\n}\nfunction _createError(type, evt, message) {\n !_customErrors[type] && (_customErrors[type] = createCustomError(type));\n var now = utcNow();\n return new (_customErrors[type])(\"Task [\".concat(evt.id, \"] \").concat(message || \"\", \"- \").concat((evt.st ? \"Running\" : \"Waiting\"), \": \").concat(_calcTime(now, evt.st || evt.cr)));\n}\nfunction _calcTime(now, start) {\n return ((now - start) || \"0\") + \" ms\";\n}\nfunction _abortStaleTasks(taskQueue, staleTimeoutPeriod) {\n var now = utcNow();\n var expired = now - staleTimeoutPeriod;\n arrForEach(taskQueue, function (evt) {\n if (evt && !evt.rj && (evt.st && evt.st < expired) || (!evt.st && evt.cr && evt.cr < expired)) {\n evt && evt[REJECT](evt.rj || _createError(\"Aborted\", evt, \"Stale \"));\n }\n });\n}\nfunction _removeTask(queue, taskDetail) {\n var idx = arrIndexOf(queue, taskDetail);\n if (idx !== -1) {\n queue.splice(idx, 1);\n }\n}\nfunction _addDebugState(theScheduler, nameFn, stateFn) {\n _debugName = _debugName || { toString: function () { return \"[[SchedulerName]]\"; } };\n _debugIntState = _debugIntState || { toString: function () { return \"[[SchedulerState]]\"; } };\n objDefineProp(theScheduler, _debugName, { get: nameFn });\n objDefineProp(theScheduler, _debugIntState, { get: stateFn });\n}\nfunction createTaskScheduler(newPromise, name) {\n var _theTask;\n var _running = [];\n var _waiting = [];\n var _staleTimeoutPeriod = 600000;\n var _staleTimeoutCheckPeriod = _staleTimeoutPeriod / 10;\n var _taskCount = 0;\n var _schedulerName = (name ? (name + \".\") : \"\") + _schedulerId++;\n var _blockedTimer;\n newPromise = newPromise || createPromise;\n var _startBlockedTimer = function () {\n var hasTasks = (getLength(_running) + getLength(_waiting)) > 0;\n if (_staleTimeoutPeriod > 0) {\n if (!_blockedTimer) {\n _blockedTimer = scheduleTimeout(function () {\n _abortStaleTasks(_running, _staleTimeoutPeriod);\n _abortStaleTasks(_waiting, _staleTimeoutPeriod);\n _blockedTimer && (_blockedTimer.enabled = ((getLength(_running) + getLength(_waiting)) > 0));\n }, _staleTimeoutCheckPeriod);\n _blockedTimer.unref();\n }\n _blockedTimer && (_blockedTimer.enabled = hasTasks);\n }\n };\n var _queueTask = function (startAction, taskName, timeout) {\n var _a;\n var taskId = _schedulerName + \".\" + _taskCount++;\n if (taskName) {\n taskId += \"-(\" + taskName + \")\";\n }\n var newTask = (_a = {\n id: taskId,\n cr: utcNow(),\n to: timeout\n },\n _a[REJECT] = function (reason) {\n newTask.rj = reason || _createError(REJECTED_ERROR, newTask);\n newTask[REJECT] = _rejectDone;\n },\n _a);\n if (!_theTask) {\n newTask.p = newPromise(_runTask(newTask, startAction));\n }\n else {\n newTask.p = _waitForPreviousTask(newTask, _theTask, startAction);\n }\n _theTask = newTask;\n return newTask.p;\n };\n var _runTask = function (taskDetail, startAction) {\n taskDetail.st = utcNow();\n _running.push(taskDetail);\n _startBlockedTimer();\n return function (onTaskResolve, onTaskReject) {\n var _promiseReject = function (reason) {\n taskDetail.rj = taskDetail.rj || reason || _createError(REJECTED_ERROR, taskDetail);\n taskDetail[REJECT] = _rejectDone;\n _doCleanup(taskDetail);\n onTaskResolve = null;\n onTaskReject && onTaskReject(reason);\n onTaskReject = null;\n };\n var taskId = taskDetail.id;\n if (taskDetail.rj) {\n _promiseReject(taskDetail.rj);\n }\n else {\n taskDetail[REJECT] = _promiseReject;\n try {\n var startResult = startAction(taskId);\n if (taskDetail.to && isPromiseLike(startResult)) {\n taskDetail.t = scheduleTimeout(function () {\n _promiseReject(_createError(\"Timeout\", taskDetail));\n }, taskDetail.to);\n }\n doAwait(startResult, function (theResult) {\n _doCleanup(taskDetail);\n try {\n onTaskResolve && onTaskResolve(theResult);\n }\n catch (e) {\n onTaskReject && onTaskReject(e);\n }\n onTaskReject = null;\n onTaskResolve = null;\n }, _promiseReject);\n }\n catch (e) {\n _promiseReject(e);\n }\n }\n };\n };\n var _waitForPreviousTask = function (taskDetail, prevTask, startAction) {\n _waiting.push(taskDetail);\n _startBlockedTimer();\n return newPromise(function (onWaitResolve, onWaitReject) {\n doAwaitResponse(prevTask.p, function () {\n _removeTask(_waiting, taskDetail);\n _runTask(taskDetail, startAction)(onWaitResolve, onWaitReject);\n });\n });\n };\n var _doCleanup = function (taskDetail) {\n _removeTask(_running, taskDetail);\n taskDetail.t && taskDetail.t.cancel();\n taskDetail.t = null;\n if (_theTask && _theTask === taskDetail) {\n _theTask = null;\n if (getLength(_running) + getLength(_waiting) === 0) {\n _blockedTimer && _blockedTimer.cancel();\n _blockedTimer = null;\n }\n }\n };\n var theScheduler = {\n idle: true,\n queue: _queueTask,\n setStaleTimeout: function (staleTimeout, staleCheckPeriod) {\n _blockedTimer && _blockedTimer.cancel();\n _blockedTimer = null;\n _staleTimeoutPeriod = staleTimeout;\n _staleTimeoutCheckPeriod = staleCheckPeriod || staleTimeout / 10;\n _startBlockedTimer();\n }\n };\n objDefine(theScheduler, \"idle\", {\n g: function () {\n return getLength(_running) + getLength(_waiting) === 0;\n }\n });\n _addDebugState(theScheduler, function () { return _schedulerName; }, function () {\n return {\n l: _theTask,\n r: _running,\n w: _waiting\n };\n });\n return theScheduler;\n}\n\nvar toStringTagSymbol = getKnownSymbol(11 );\nvar PolyPromise = /*#__PURE__*/ (function () {\n function PolyPromiseImpl(executor) {\n this._$ = createAsyncPromise(executor);\n if (toStringTagSymbol) {\n this[toStringTagSymbol] = \"Promise\";\n }\n objDefineProp(this, \"state\", {\n get: function () {\n return this._$.state;\n }\n });\n }\n PolyPromiseImpl.all = createAsyncAllPromise;\n PolyPromiseImpl.race = createAsyncRacePromise;\n PolyPromiseImpl.any = createAsyncAnyPromise;\n PolyPromiseImpl.reject = createAsyncRejectedPromise;\n PolyPromiseImpl.resolve = createAsyncResolvedPromise;\n PolyPromiseImpl.allSettled = createAsyncAllSettledPromise;\n var theProto = PolyPromiseImpl.prototype;\n theProto.then = function (onResolved, onRejected) {\n return this._$.then(onResolved, onRejected);\n };\n theProto.catch = function (onRejected) {\n return this._$.catch(onRejected);\n };\n theProto.finally = function (onfinally) {\n return this._$.finally(onfinally);\n };\n return PolyPromiseImpl;\n}());\n\nexport { PolyPromise, arrForEachAsync, createAllPromise, createAllSettledPromise, createAnyPromise, createAsyncAllPromise, createAsyncAllSettledPromise, createAsyncAnyPromise, createAsyncPromise, createAsyncRacePromise, createAsyncRejectedPromise, createAsyncResolvedPromise, createIdleAllPromise, createIdleAllSettledPromise, createIdleAnyPromise, createIdlePromise, createIdleRacePromise, createIdleRejectedPromise, createIdleResolvedPromise, createNativeAllPromise, createNativeAllSettledPromise, createNativeAnyPromise, createNativePromise, createNativeRacePromise, createNativeRejectedPromise, createNativeResolvedPromise, createPromise, createRacePromise, createRejectedPromise, createResolvedPromise, createSyncAllPromise, createSyncAllSettledPromise, createSyncAnyPromise, createSyncPromise, createSyncRacePromise, createSyncRejectedPromise, createSyncResolvedPromise, createTaskScheduler, createTimeoutPromise, doAwait, doAwaitResponse, doFinally, doWhileAsync, iterForOfAsync, setCreatePromiseImpl, setDefaultIdlePromiseTimeout, setDefaultIdleTimeout, setPromiseDebugState };\n//# sourceMappingURL=ts-async.js.map\n","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// ###################################################################################################################################################\r\n// Note: DON'T Export these const from the package as we are still targeting IE/ES5 this will export a mutable variables that someone could change ###\r\n// ###################################################################################################################################################\r\nexport var UNDEFINED_VALUE = undefined;\r\nexport var STR_EMPTY = \"\";\r\nexport var STR_CHANNELS = \"channels\";\r\nexport var STR_CORE = \"core\";\r\nexport var STR_CREATE_PERF_MGR = \"createPerfMgr\";\r\nexport var STR_DISABLED = \"disabled\";\r\nexport var STR_EXTENSION_CONFIG = \"extensionConfig\";\r\nexport var STR_EXTENSIONS = \"extensions\";\r\nexport var STR_PROCESS_TELEMETRY = \"processTelemetry\";\r\nexport var STR_PRIORITY = \"priority\";\r\nexport var STR_EVENTS_SENT = \"eventsSent\";\r\nexport var STR_EVENTS_DISCARDED = \"eventsDiscarded\";\r\nexport var STR_EVENTS_SEND_REQUEST = \"eventsSendRequest\";\r\nexport var STR_PERF_EVENT = \"perfEvent\";\r\nexport var STR_OFFLINE_STORE = \"offlineEventsStored\";\r\nexport var STR_OFFLINE_SENT = \"offlineBatchSent\";\r\nexport var STR_OFFLINE_DROP = \"offlineBatchDrop\";\r\nexport var STR_GET_PERF_MGR = \"getPerfMgr\";\r\nexport var STR_DOMAIN = \"domain\";\r\nexport var STR_PATH = \"path\";\r\nexport var STR_NOT_DYNAMIC_ERROR = \"Not dynamic - \";\r\n//# sourceMappingURL=InternalConstants.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { ObjAssign, ObjClass } from \"@microsoft/applicationinsights-shims\";\r\nimport { arrForEach, asString as asString21, isArray, isBoolean, isError, isFunction, isNullOrUndefined, isNumber, isObject, isPlainObject, isString, isUndefined, objDeepFreeze, objDefine, objForEachKey, objHasOwn, strIndexOf, strTrim } from \"@nevware21/ts-utils\";\r\nimport { _DYN_APPLY, _DYN_GET_ALL_RESPONSE_HEA5, _DYN_LENGTH, _DYN_NAME, _DYN_REPLACE, _DYN_SPLIT, _DYN_STATUS, _DYN_TO_LOWER_CASE } from \"../__DynamicConstants\";\r\nimport { STR_EMPTY } from \"./InternalConstants\";\r\n// RESTRICT and AVOID circular dependencies you should not import other contained modules or export the contents of this file directly\r\n// Added to help with minification\r\nvar strGetPrototypeOf = \"getPrototypeOf\";\r\nvar rCamelCase = /-([a-z])/g;\r\nvar rNormalizeInvalid = /([^\\w\\d_$])/g;\r\nvar rLeadingNumeric = /^(\\d+[\\w\\d_$])/;\r\nexport var _getObjProto = Object[strGetPrototypeOf];\r\nexport function isNotUndefined(value) {\r\n return !isUndefined(value);\r\n}\r\nexport function isNotNullOrUndefined(value) {\r\n return !isNullOrUndefined(value);\r\n}\r\n/**\r\n * Validates that the string name conforms to the JS IdentifierName specification and if not\r\n * normalizes the name so that it would. This method does not identify or change any keywords\r\n * meaning that if you pass in a known keyword the same value will be returned.\r\n * This is a simplified version\r\n * @param name - The name to validate\r\n */\r\nexport function normalizeJsName(name) {\r\n var value = name;\r\n if (value && isString(value)) {\r\n // CamelCase everything after the \"-\" and remove the dash\r\n value = value[_DYN_REPLACE /* @min:%2ereplace */](rCamelCase, function (_all, letter) {\r\n return letter.toUpperCase();\r\n });\r\n value = value[_DYN_REPLACE /* @min:%2ereplace */](rNormalizeInvalid, \"_\");\r\n value = value[_DYN_REPLACE /* @min:%2ereplace */](rLeadingNumeric, function (_all, match) {\r\n return \"_\" + match;\r\n });\r\n }\r\n return value;\r\n}\r\n/**\r\n * A simple wrapper (for minification support) to check if the value contains the search string.\r\n * @param value - The string value to check for the existence of the search value\r\n * @param search - The value search within the value\r\n */\r\nexport function strContains(value, search) {\r\n if (value && search) {\r\n return strIndexOf(value, search) !== -1;\r\n }\r\n return false;\r\n}\r\n/**\r\n * Convert a date to I.S.O. format in IE8\r\n */\r\nexport function toISOString(date) {\r\n return date && date.toISOString() || \"\";\r\n}\r\nexport var deepFreeze = objDeepFreeze;\r\n/**\r\n * Returns the name of object if it's an Error. Otherwise, returns empty string.\r\n */\r\nexport function getExceptionName(object) {\r\n if (isError(object)) {\r\n return object[_DYN_NAME /* @min:%2ename */];\r\n }\r\n return STR_EMPTY;\r\n}\r\n/**\r\n * Sets the provided value on the target instance using the field name when the provided chk function returns true, the chk\r\n * function will only be called if the new value is no equal to the original value.\r\n * @param target - The target object\r\n * @param field - The key of the target\r\n * @param value - The value to set\r\n * @param valChk - [Optional] Callback to check the value that if supplied will be called check if the new value can be set\r\n * @param srcChk - [Optional] Callback to check to original value that if supplied will be called if the new value should be set (if allowed)\r\n * @returns The existing or new value, depending what was set\r\n */\r\nexport function setValue(target, field, value, valChk, srcChk) {\r\n var theValue = value;\r\n if (target) {\r\n theValue = target[field];\r\n if (theValue !== value && (!srcChk || srcChk(theValue)) && (!valChk || valChk(value))) {\r\n theValue = value;\r\n target[field] = theValue;\r\n }\r\n }\r\n return theValue;\r\n}\r\n/**\r\n * Returns the current value from the target object if not null or undefined otherwise sets the new value and returns it\r\n * @param target - The target object to return or set the default value\r\n * @param field - The key for the field to set on the target\r\n * @param defValue - [Optional] The value to set if not already present, when not provided a empty object will be added\r\n */\r\nexport function getSetValue(target, field, defValue) {\r\n var theValue;\r\n if (target) {\r\n theValue = target[field];\r\n if (!theValue && isNullOrUndefined(theValue)) {\r\n // Supports having the default as null\r\n theValue = !isUndefined(defValue) ? defValue : {};\r\n target[field] = theValue;\r\n }\r\n }\r\n else {\r\n // Expanded for performance so we only check defValue if required\r\n theValue = !isUndefined(defValue) ? defValue : {};\r\n }\r\n return theValue;\r\n}\r\nfunction _createProxyFunction(source, funcName) {\r\n var srcFunc = null;\r\n var src = null;\r\n if (isFunction(source)) {\r\n srcFunc = source;\r\n }\r\n else {\r\n src = source;\r\n }\r\n return function () {\r\n // Capture the original arguments passed to the method\r\n var originalArguments = arguments;\r\n if (srcFunc) {\r\n src = srcFunc();\r\n }\r\n if (src) {\r\n return src[funcName][_DYN_APPLY /* @min:%2eapply */](src, originalArguments);\r\n }\r\n };\r\n}\r\n/**\r\n * Effectively assigns all enumerable properties (not just own properties) and functions (including inherited prototype) from\r\n * the source object to the target, it attempts to use proxy getters / setters (if possible) and proxy functions to avoid potential\r\n * implementation issues by assigning prototype functions as instance ones\r\n *\r\n * This method is the primary method used to \"update\" the snippet proxy with the ultimate implementations.\r\n *\r\n * Special ES3 Notes:\r\n * Updates (setting) of direct property values on the target or indirectly on the source object WILL NOT WORK PROPERLY, updates to the\r\n * properties of \"referenced\" object will work (target.context.newValue = 10 =\\> will be reflected in the source.context as it's the\r\n * same object). ES3 Failures: assigning target.myProp = 3 -\\> Won't change source.myProp = 3, likewise the reverse would also fail.\r\n * @param target - The target object to be assigned with the source properties and functions\r\n * @param source - The source object which will be assigned / called by setting / calling the targets proxies\r\n * @param chkSet - An optional callback to determine whether a specific property/function should be proxied\r\n */\r\nexport function proxyAssign(target, source, chkSet) {\r\n if (target && source && isObject(target) && isObject(source)) {\r\n var _loop_1 = function (field) {\r\n if (isString(field)) {\r\n var value = source[field];\r\n if (isFunction(value)) {\r\n if (!chkSet || chkSet(field, true, source, target)) {\r\n // Create a proxy function rather than just copying the (possible) prototype to the new object as an instance function\r\n target[field] = _createProxyFunction(source, field);\r\n }\r\n }\r\n else if (!chkSet || chkSet(field, false, source, target)) {\r\n if (objHasOwn(target, field)) {\r\n // Remove any previous instance property\r\n delete target[field];\r\n }\r\n objDefine(target, field, {\r\n g: function () {\r\n return source[field];\r\n },\r\n s: function (theValue) {\r\n source[field] = theValue;\r\n }\r\n });\r\n }\r\n }\r\n };\r\n // effectively apply/proxy full source to the target instance\r\n for (var field in source) {\r\n _loop_1(field);\r\n }\r\n }\r\n return target;\r\n}\r\n/**\r\n * Creates a proxy function on the target which internally will call the source version with all arguments passed to the target method.\r\n *\r\n * @param target - The target object to be assigned with the source properties and functions\r\n * @param name - The function name that will be added on the target\r\n * @param source - The source object which will be assigned / called by setting / calling the targets proxies\r\n * @param theFunc - The function name on the source that will be proxied on the target\r\n * @param overwriteTarget - If `false` this will not replace any pre-existing name otherwise (the default) it will overwrite any existing name\r\n */\r\nexport function proxyFunctionAs(target, name, source, theFunc, overwriteTarget) {\r\n if (target && name && source) {\r\n if (overwriteTarget !== false || isUndefined(target[name])) {\r\n target[name] = _createProxyFunction(source, theFunc);\r\n }\r\n }\r\n}\r\n/**\r\n * Creates proxy functions on the target which internally will call the source version with all arguments passed to the target method.\r\n *\r\n * @param target - The target object to be assigned with the source properties and functions\r\n * @param source - The source object which will be assigned / called by setting / calling the targets proxies\r\n * @param functionsToProxy - An array of function names that will be proxied on the target\r\n * @param overwriteTarget - If false this will not replace any pre-existing name otherwise (the default) it will overwrite any existing name\r\n */\r\nexport function proxyFunctions(target, source, functionsToProxy, overwriteTarget) {\r\n if (target && source && isObject(target) && isArray(functionsToProxy)) {\r\n arrForEach(functionsToProxy, function (theFuncName) {\r\n if (isString(theFuncName)) {\r\n proxyFunctionAs(target, theFuncName, source, theFuncName, overwriteTarget);\r\n }\r\n });\r\n }\r\n return target;\r\n}\r\n/**\r\n * Simpler helper to create a dynamic class that implements the interface and populates the values with the defaults.\r\n * Only instance properties (hasOwnProperty) values are copied from the defaults to the new instance\r\n * @param defaults - Simple helper\r\n */\r\nexport function createClassFromInterface(defaults) {\r\n return /** @class */ (function () {\r\n function class_1() {\r\n var _this = this;\r\n if (defaults) {\r\n objForEachKey(defaults, function (field, value) {\r\n _this[field] = value;\r\n });\r\n }\r\n }\r\n return class_1;\r\n }());\r\n}\r\n/**\r\n * A helper function to assist with JIT performance for objects that have properties added / removed dynamically\r\n * this is primarily for chromium based browsers and has limited effects on Firefox and none of IE. Only call this\r\n * function after you have finished \"updating\" the object, calling this within loops reduces or defeats the benefits.\r\n * This helps when iterating using for..in, objKeys() and objForEach()\r\n * @param theObject - The object to be optimized if possible\r\n */\r\nexport function optimizeObject(theObject) {\r\n // V8 Optimization to cause the JIT compiler to create a new optimized object for looking up the own properties\r\n // primarily for object with <= 19 properties for >= 20 the effect is reduced or non-existent\r\n if (theObject && ObjAssign) {\r\n theObject = ObjClass(ObjAssign({}, theObject));\r\n }\r\n return theObject;\r\n}\r\nexport function objExtend(obj1, obj2, obj3, obj4, obj5, obj6) {\r\n // Variables\r\n var theArgs = arguments;\r\n var extended = theArgs[0] || {};\r\n var argLen = theArgs[_DYN_LENGTH /* @min:%2elength */];\r\n var deep = false;\r\n var idx = 1;\r\n // Check for \"Deep\" flag\r\n if (argLen > 0 && isBoolean(extended)) {\r\n deep = extended;\r\n extended = theArgs[idx] || {};\r\n idx++;\r\n }\r\n // Handle case when target is a string or something (possible in deep copy)\r\n if (!isObject(extended)) {\r\n extended = {};\r\n }\r\n // Loop through each remaining object and conduct a merge\r\n for (; idx < argLen; idx++) {\r\n var arg = theArgs[idx];\r\n var isArgArray = isArray(arg);\r\n var isArgObj = isObject(arg);\r\n for (var prop in arg) {\r\n var propOk = (isArgArray && (prop in arg)) || (isArgObj && objHasOwn(arg, prop));\r\n if (!propOk) {\r\n continue;\r\n }\r\n var newValue = arg[prop];\r\n var isNewArray = void 0;\r\n // If deep merge and property is an object, merge properties\r\n if (deep && newValue && ((isNewArray = isArray(newValue)) || isPlainObject(newValue))) {\r\n // Grab the current value of the extended object\r\n var clone = extended[prop];\r\n if (isNewArray) {\r\n if (!isArray(clone)) {\r\n // We can't \"merge\" an array with a non-array so overwrite the original\r\n clone = [];\r\n }\r\n }\r\n else if (!isPlainObject(clone)) {\r\n // We can't \"merge\" an object with a non-object\r\n clone = {};\r\n }\r\n // Never move the original objects always clone them\r\n newValue = objExtend(deep, clone, newValue);\r\n }\r\n // Assign the new (or previous) value (unless undefined)\r\n if (newValue !== undefined) {\r\n extended[prop] = newValue;\r\n }\r\n }\r\n }\r\n return extended;\r\n}\r\nexport var asString = asString21;\r\nexport function isFeatureEnabled(feature, cfg) {\r\n var rlt = false;\r\n var ft = cfg && cfg.featureOptIn && cfg.featureOptIn[feature];\r\n if (feature && ft) {\r\n var mode = ft.mode;\r\n // NOTE: None will be considered as true\r\n rlt = (mode == 3 /* FeatureOptInMode.enable */) || (mode == 1 /* FeatureOptInMode.none */);\r\n }\r\n return rlt;\r\n}\r\nexport function getResponseText(xhr) {\r\n try {\r\n return xhr.responseText;\r\n }\r\n catch (e) {\r\n // Best effort, as XHR may throw while XDR wont so just ignore\r\n }\r\n return null;\r\n}\r\nexport function formatErrorMessageXdr(xdr, message) {\r\n if (xdr) {\r\n return \"XDomainRequest,Response:\" + getResponseText(xdr) || \"\";\r\n }\r\n return message;\r\n}\r\nexport function formatErrorMessageXhr(xhr, message) {\r\n if (xhr) {\r\n return \"XMLHttpRequest,Status:\" + xhr[_DYN_STATUS /* @min:%2estatus */] + \",Response:\" + getResponseText(xhr) || xhr.response || \"\";\r\n }\r\n return message;\r\n}\r\nexport function prependTransports(theTransports, newTransports) {\r\n if (newTransports) {\r\n if (isNumber(newTransports)) {\r\n theTransports = [newTransports].concat(theTransports);\r\n }\r\n else if (isArray(newTransports)) {\r\n theTransports = newTransports.concat(theTransports);\r\n }\r\n }\r\n return theTransports;\r\n}\r\nvar strDisabledPropertyName = \"Microsoft_ApplicationInsights_BypassAjaxInstrumentation\";\r\nvar strWithCredentials = \"withCredentials\";\r\nvar strTimeout = \"timeout\";\r\n/**\r\n * Create and open an XMLHttpRequest object\r\n * @param method - The request method\r\n * @param urlString - The url\r\n * @param withCredentials - Option flag indicating that credentials should be sent\r\n * @param disabled - Optional flag indicating that the XHR object should be marked as disabled and not tracked (default is false)\r\n * @param isSync - Optional flag indicating if the instance should be a synchronous request (defaults to false)\r\n * @param timeout - Optional value identifying the timeout value that should be assigned to the XHR request\r\n * @returns A new opened XHR request\r\n */\r\nexport function openXhr(method, urlString, withCredentials, disabled, isSync, timeout) {\r\n if (disabled === void 0) { disabled = false; }\r\n if (isSync === void 0) { isSync = false; }\r\n function _wrapSetXhrProp(xhr, prop, value) {\r\n try {\r\n xhr[prop] = value;\r\n }\r\n catch (e) {\r\n // - Wrapping as depending on the environment setting the property may fail (non-terminally)\r\n }\r\n }\r\n var xhr = new XMLHttpRequest();\r\n if (disabled) {\r\n // Tag the instance so it's not tracked (trackDependency)\r\n // If the environment has locked down the XMLHttpRequest (preventExtensions and/or freeze), this would\r\n // cause the request to fail and we no telemetry would be sent\r\n _wrapSetXhrProp(xhr, strDisabledPropertyName, disabled);\r\n }\r\n if (withCredentials) {\r\n // Some libraries require that the withCredentials flag is set \"before\" open and\r\n // - Wrapping as IE 10 has started throwing when setting before open\r\n _wrapSetXhrProp(xhr, strWithCredentials, withCredentials);\r\n }\r\n xhr.open(method, urlString, !isSync);\r\n if (withCredentials) {\r\n // withCredentials should be set AFTER open (https://xhr.spec.whatwg.org/#the-withcredentials-attribute)\r\n // And older firefox instances from 11+ will throw for sync events (current versions don't) which happens during unload processing\r\n _wrapSetXhrProp(xhr, strWithCredentials, withCredentials);\r\n }\r\n // Only set the timeout for asynchronous requests as\r\n // \"Timeout shouldn't be used for synchronous XMLHttpRequests requests used in a document environment or it will throw an InvalidAccessError exception.\"\"\r\n // https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/timeout\r\n if (!isSync && timeout) {\r\n _wrapSetXhrProp(xhr, strTimeout, timeout);\r\n }\r\n return xhr;\r\n}\r\n/**\r\n* Converts the XHR getAllResponseHeaders to a map containing the header key and value.\r\n* @internal\r\n*/\r\n// tslint:disable-next-line: align\r\nexport function convertAllHeadersToMap(headersString) {\r\n var headers = {};\r\n if (isString(headersString)) {\r\n var headersArray = strTrim(headersString)[_DYN_SPLIT /* @min:%2esplit */](/[\\r\\n]+/);\r\n arrForEach(headersArray, function (headerEntry) {\r\n if (headerEntry) {\r\n var idx = headerEntry.indexOf(\": \");\r\n if (idx !== -1) {\r\n // The new spec has the headers returning all as lowercase -- but not all browsers do this yet\r\n var header = strTrim(headerEntry.substring(0, idx))[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n var value = strTrim(headerEntry.substring(idx + 1));\r\n headers[header] = value;\r\n }\r\n else {\r\n headers[strTrim(headerEntry)] = 1;\r\n }\r\n }\r\n });\r\n }\r\n return headers;\r\n}\r\n/**\r\n* append the XHR headers.\r\n* @internal\r\n*/\r\nexport function _appendHeader(theHeaders, xhr, name) {\r\n if (!theHeaders[name] && xhr && xhr.getResponseHeader) {\r\n var value = xhr.getResponseHeader(name);\r\n if (value) {\r\n theHeaders[name] = strTrim(value);\r\n }\r\n }\r\n return theHeaders;\r\n}\r\nvar STR_KILL_DURATION_HEADER = \"kill-duration\";\r\nvar STR_KILL_DURATION_SECONDS_HEADER = \"kill-duration-seconds\";\r\nvar STR_TIME_DELTA_HEADER = \"time-delta-millis\";\r\n/**\r\n* get the XHR getAllResponseHeaders.\r\n* @internal\r\n*/\r\nexport function _getAllResponseHeaders(xhr, isOneDs) {\r\n var theHeaders = {};\r\n if (!xhr[_DYN_GET_ALL_RESPONSE_HEA5 /* @min:%2egetAllResponseHeaders */]) {\r\n // Firefox 2-63 doesn't have getAllResponseHeaders function but it does have getResponseHeader\r\n // Only call these if getAllResponseHeaders doesn't exist, otherwise we can get invalid response errors\r\n // as collector is not currently returning the correct header to allow JS to access these headers\r\n if (!!isOneDs) {\r\n theHeaders = _appendHeader(theHeaders, xhr, STR_TIME_DELTA_HEADER);\r\n theHeaders = _appendHeader(theHeaders, xhr, STR_KILL_DURATION_HEADER);\r\n theHeaders = _appendHeader(theHeaders, xhr, STR_KILL_DURATION_SECONDS_HEADER);\r\n }\r\n }\r\n else {\r\n theHeaders = convertAllHeadersToMap(xhr[_DYN_GET_ALL_RESPONSE_HEA5 /* @min:%2egetAllResponseHeaders */]());\r\n }\r\n return theHeaders;\r\n}\r\n//# sourceMappingURL=HelperFuncs.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n\"use strict\";\r\nimport { getGlobal, strShimObject, strShimPrototype, strShimUndefined } from \"@microsoft/applicationinsights-shims\";\r\nimport { getDocument, getInst, getNavigator, getPerformance, hasNavigator, isFunction, isString, isUndefined, mathMax, strIndexOf } from \"@nevware21/ts-utils\";\r\nimport { _DYN_LENGTH, _DYN_NAME, _DYN_SPLIT, _DYN_TO_LOWER_CASE, _DYN_USER_AGENT } from \"../__DynamicConstants\";\r\nimport { strContains } from \"./HelperFuncs\";\r\nimport { STR_EMPTY } from \"./InternalConstants\";\r\n/**\r\n * This file exists to hold environment utilities that are required to check and\r\n * validate the current operating environment. Unless otherwise required, please\r\n * only use defined methods (functions) in this class so that users of these\r\n * functions/properties only need to include those that are used within their own modules.\r\n */\r\nvar strDocumentMode = \"documentMode\";\r\nvar strLocation = \"location\";\r\nvar strConsole = \"console\";\r\nvar strJSON = \"JSON\";\r\nvar strCrypto = \"crypto\";\r\nvar strMsCrypto = \"msCrypto\";\r\nvar strReactNative = \"ReactNative\";\r\nvar strMsie = \"msie\";\r\nvar strTrident = \"trident/\";\r\nvar strXMLHttpRequest = \"XMLHttpRequest\";\r\nvar _isTrident = null;\r\nvar _navUserAgentCheck = null;\r\nvar _enableMocks = false;\r\nvar _useXDomainRequest = null;\r\nvar _beaconsSupported = null;\r\nfunction _hasProperty(theClass, property) {\r\n var supported = false;\r\n if (theClass) {\r\n try {\r\n supported = property in theClass;\r\n if (!supported) {\r\n var proto = theClass[strShimPrototype];\r\n if (proto) {\r\n supported = property in proto;\r\n }\r\n }\r\n }\r\n catch (e) {\r\n // Do Nothing\r\n }\r\n if (!supported) {\r\n try {\r\n var tmp = new theClass();\r\n supported = !isUndefined(tmp[property]);\r\n }\r\n catch (e) {\r\n // Do Nothing\r\n }\r\n }\r\n }\r\n return supported;\r\n}\r\n/**\r\n * Enable the lookup of test mock objects if requested\r\n * @param enabled - A flag to enable or disable the mock\r\n */\r\nexport function setEnableEnvMocks(enabled) {\r\n _enableMocks = enabled;\r\n}\r\n/**\r\n * Returns the global location object if it is present otherwise null.\r\n * This helper is used to access the location object without causing an exception\r\n * \"Uncaught ReferenceError: location is not defined\"\r\n */\r\nexport function getLocation(checkForMock) {\r\n if (checkForMock && _enableMocks) {\r\n var mockLocation = getInst(\"__mockLocation\");\r\n if (mockLocation) {\r\n return mockLocation;\r\n }\r\n }\r\n if (typeof location === strShimObject && location) {\r\n return location;\r\n }\r\n return getInst(strLocation);\r\n}\r\n/**\r\n * Returns the global console object\r\n */\r\nexport function getConsole() {\r\n if (typeof console !== strShimUndefined) {\r\n return console;\r\n }\r\n return getInst(strConsole);\r\n}\r\n/**\r\n * Checks if JSON object is available, this is required as we support the API running without a\r\n * window /document (eg. Node server, electron webworkers) and if we attempt to assign a history\r\n * object to a local variable or pass as an argument an \"Uncaught ReferenceError: JSON is not defined\"\r\n * exception will be thrown.\r\n * Defined as a function to support lazy / late binding environments.\r\n */\r\nexport function hasJSON() {\r\n return Boolean((typeof JSON === strShimObject && JSON) || getInst(strJSON) !== null);\r\n}\r\n/**\r\n * Returns the global JSON object if it is present otherwise null.\r\n * This helper is used to access the JSON object without causing an exception\r\n * \"Uncaught ReferenceError: JSON is not defined\"\r\n */\r\nexport function getJSON() {\r\n if (hasJSON()) {\r\n return JSON || getInst(strJSON);\r\n }\r\n return null;\r\n}\r\n/**\r\n * Returns the crypto object if it is present otherwise null.\r\n * This helper is used to access the crypto object from the current\r\n * global instance which could be window or globalThis for a web worker\r\n */\r\nexport function getCrypto() {\r\n return getInst(strCrypto);\r\n}\r\n/**\r\n * Returns the crypto object if it is present otherwise null.\r\n * This helper is used to access the crypto object from the current\r\n * global instance which could be window or globalThis for a web worker\r\n */\r\nexport function getMsCrypto() {\r\n return getInst(strMsCrypto);\r\n}\r\n/**\r\n * Returns whether the environment is reporting that we are running in a React Native Environment\r\n */\r\nexport function isReactNative() {\r\n // If running in React Native, navigator.product will be populated\r\n var nav = getNavigator();\r\n if (nav && nav.product) {\r\n return nav.product === strReactNative;\r\n }\r\n return false;\r\n}\r\n/**\r\n * Identifies whether the current environment appears to be IE\r\n */\r\nexport function isIE() {\r\n var nav = getNavigator();\r\n if (nav && (nav[_DYN_USER_AGENT /* @min:%2euserAgent */] !== _navUserAgentCheck || _isTrident === null)) {\r\n // Added to support test mocking of the user agent\r\n _navUserAgentCheck = nav[_DYN_USER_AGENT /* @min:%2euserAgent */];\r\n var userAgent = (_navUserAgentCheck || STR_EMPTY)[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n _isTrident = (strContains(userAgent, strMsie) || strContains(userAgent, strTrident));\r\n }\r\n return _isTrident;\r\n}\r\n/**\r\n * Gets IE version returning the document emulation mode if we are running on IE, or null otherwise\r\n */\r\nexport function getIEVersion(userAgentStr) {\r\n if (userAgentStr === void 0) { userAgentStr = null; }\r\n if (!userAgentStr) {\r\n var navigator_1 = getNavigator() || {};\r\n userAgentStr = navigator_1 ? (navigator_1.userAgent || STR_EMPTY)[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]() : STR_EMPTY;\r\n }\r\n var ua = (userAgentStr || STR_EMPTY)[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n // Also check for documentMode in case X-UA-Compatible meta tag was included in HTML.\r\n if (strContains(ua, strMsie)) {\r\n var doc = getDocument() || {};\r\n return mathMax(parseInt(ua[_DYN_SPLIT /* @min:%2esplit */](strMsie)[1]), (doc[strDocumentMode] || 0));\r\n }\r\n else if (strContains(ua, strTrident)) {\r\n var tridentVer = parseInt(ua[_DYN_SPLIT /* @min:%2esplit */](strTrident)[1]);\r\n if (tridentVer) {\r\n return tridentVer + 4;\r\n }\r\n }\r\n return null;\r\n}\r\nexport function isSafari(userAgentStr) {\r\n if (!userAgentStr || !isString(userAgentStr)) {\r\n var navigator_2 = getNavigator() || {};\r\n userAgentStr = navigator_2 ? (navigator_2.userAgent || STR_EMPTY)[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]() : STR_EMPTY;\r\n }\r\n var ua = (userAgentStr || STR_EMPTY)[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n return (strIndexOf(ua, \"safari\") >= 0);\r\n}\r\n/**\r\n * Checks if HTML5 Beacons are supported in the current environment.\r\n * @param useCached - [Optional] used for testing to bypass the cached lookup, when `true` this will\r\n * cause the cached global to be reset.\r\n * @returns True if supported, false otherwise.\r\n */\r\nexport function isBeaconsSupported(useCached) {\r\n if (_beaconsSupported === null || useCached === false) {\r\n _beaconsSupported = hasNavigator() && Boolean(getNavigator().sendBeacon);\r\n }\r\n return _beaconsSupported;\r\n}\r\n/**\r\n * Checks if the Fetch API is supported in the current environment.\r\n * @param withKeepAlive - [Optional] If True, check if fetch is available and it supports the keepalive feature, otherwise only check if fetch is supported\r\n * @returns True if supported, otherwise false\r\n */\r\nexport function isFetchSupported(withKeepAlive) {\r\n var isSupported = false;\r\n try {\r\n isSupported = !!getInst(\"fetch\");\r\n var request = getInst(\"Request\");\r\n if (isSupported && withKeepAlive && request) {\r\n isSupported = _hasProperty(request, \"keepalive\");\r\n }\r\n }\r\n catch (e) {\r\n // Just Swallow any failure during availability checks\r\n }\r\n return isSupported;\r\n}\r\nexport function useXDomainRequest() {\r\n if (_useXDomainRequest === null) {\r\n _useXDomainRequest = (typeof XDomainRequest !== strShimUndefined);\r\n if (_useXDomainRequest && isXhrSupported()) {\r\n _useXDomainRequest = _useXDomainRequest && !_hasProperty(getInst(strXMLHttpRequest), \"withCredentials\");\r\n }\r\n }\r\n return _useXDomainRequest;\r\n}\r\n/**\r\n * Checks if XMLHttpRequest is supported\r\n * @returns True if supported, otherwise false\r\n */\r\nexport function isXhrSupported() {\r\n var isSupported = false;\r\n try {\r\n var xmlHttpRequest = getInst(strXMLHttpRequest);\r\n isSupported = !!xmlHttpRequest;\r\n }\r\n catch (e) {\r\n // Just Swallow any failure during availability checks\r\n }\r\n return isSupported;\r\n}\r\nfunction _getNamedValue(values, name) {\r\n if (values) {\r\n for (var i = 0; i < values[_DYN_LENGTH /* @min:%2elength */]; i++) {\r\n var value = values[i];\r\n if (value[_DYN_NAME /* @min:%2ename */]) {\r\n if (value[_DYN_NAME /* @min:%2ename */] === name) {\r\n return value;\r\n }\r\n }\r\n }\r\n }\r\n return {};\r\n}\r\n/**\r\n * Helper function to fetch the named meta-tag from the page.\r\n * @param name - The name of the meta-tag to find.\r\n */\r\nexport function findMetaTag(name) {\r\n var doc = getDocument();\r\n if (doc && name) {\r\n // Look for a meta-tag\r\n return _getNamedValue(doc.querySelectorAll(\"meta\"), name).content;\r\n }\r\n return null;\r\n}\r\n/**\r\n * Helper function to fetch the named server timing value from the page response (first navigation event).\r\n * @param name - The name of the server timing value to find.\r\n */\r\nexport function findNamedServerTiming(name) {\r\n var value;\r\n var perf = getPerformance();\r\n if (perf) {\r\n // Try looking for a server-timing header\r\n var navPerf = perf.getEntriesByType(\"navigation\") || [];\r\n value = _getNamedValue((navPerf[_DYN_LENGTH /* @min:%2elength */] > 0 ? navPerf[0] : {}).serverTiming, name).description;\r\n }\r\n return value;\r\n}\r\n// TODO: should reuse this method for analytics plugin\r\nexport function dispatchEvent(target, evnt) {\r\n if (target && target.dispatchEvent && evnt) {\r\n target.dispatchEvent(evnt);\r\n return true;\r\n }\r\n return false;\r\n}\r\nexport function createCustomDomEvent(eventName, details) {\r\n var event = null;\r\n var detail = { detail: details || null };\r\n if (isFunction(CustomEvent)) { // Use CustomEvent constructor when available\r\n event = new CustomEvent(eventName, detail);\r\n }\r\n else { // CustomEvent has no constructor in IE\r\n var doc = getDocument();\r\n if (doc && doc.createEvent) {\r\n event = doc.createEvent(\"CustomEvent\");\r\n event.initCustomEvent(eventName, true, true, detail);\r\n }\r\n }\r\n return event;\r\n}\r\nexport function sendCustomEvent(evtName, cfg, customDetails) {\r\n var global = getGlobal();\r\n if (global && global.CustomEvent) {\r\n try {\r\n var details = { cfg: cfg || null, customDetails: customDetails || null };\r\n return dispatchEvent(global, createCustomDomEvent(evtName, details));\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n }\r\n return false;\r\n}\r\n//# sourceMappingURL=EnvUtils.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { mathFloor, utcNow } from \"@nevware21/ts-utils\";\r\nimport { _DYN_LENGTH } from \"../__DynamicConstants\";\r\nimport { getCrypto, getMsCrypto, isIE } from \"./EnvUtils\";\r\nimport { STR_EMPTY } from \"./InternalConstants\";\r\nvar UInt32Mask = 0x100000000;\r\nvar MaxUInt32 = 0xffffffff;\r\nvar SEED1 = 123456789;\r\nvar SEED2 = 987654321;\r\n// MWC based Random generator (for IE)\r\nvar _mwcSeeded = false;\r\nvar _mwcW = SEED1;\r\nvar _mwcZ = SEED2;\r\n// Takes any integer\r\nfunction _mwcSeed(seedValue) {\r\n if (seedValue < 0) {\r\n // Make sure we end up with a positive number and not -ve one.\r\n seedValue >>>= 0;\r\n }\r\n _mwcW = (SEED1 + seedValue) & MaxUInt32;\r\n _mwcZ = (SEED2 - seedValue) & MaxUInt32;\r\n _mwcSeeded = true;\r\n}\r\nfunction _autoSeedMwc() {\r\n // Simple initialization using default Math.random() - So we inherit any entropy from the browser\r\n // and bitwise XOR with the current milliseconds\r\n try {\r\n var now = utcNow() & 0x7fffffff;\r\n _mwcSeed(((Math.random() * UInt32Mask) ^ now) + now);\r\n }\r\n catch (e) {\r\n // Don't crash if something goes wrong\r\n }\r\n}\r\n/**\r\n * Generate a random value between 0 and maxValue, max value should be limited to a 32-bit maximum.\r\n * So maxValue(16) will produce a number from 0..16 (range of 17)\r\n * @param maxValue - The max value for the range\r\n */\r\nexport function randomValue(maxValue) {\r\n if (maxValue > 0) {\r\n return mathFloor((random32() / MaxUInt32) * (maxValue + 1)) >>> 0;\r\n }\r\n return 0;\r\n}\r\n/**\r\n * generate a random 32-bit number (0x000000..0xFFFFFFFF) or (-0x80000000..0x7FFFFFFF), defaults un-unsigned.\r\n * @param signed - True to return a signed 32-bit number (-0x80000000..0x7FFFFFFF) otherwise an unsigned one (0x000000..0xFFFFFFFF)\r\n */\r\nexport function random32(signed) {\r\n var value = 0;\r\n var c = getCrypto() || getMsCrypto();\r\n if (c && c.getRandomValues) {\r\n // Make sure the number is converted into the specified range (-0x80000000..0x7FFFFFFF)\r\n value = c.getRandomValues(new Uint32Array(1))[0] & MaxUInt32;\r\n }\r\n if (value === 0 && isIE()) {\r\n // For IE 6, 7, 8 (especially on XP) Math.random is not very random\r\n if (!_mwcSeeded) {\r\n // Set the seed for the Mwc algorithm\r\n _autoSeedMwc();\r\n }\r\n // Don't use Math.random for IE\r\n // Make sure the number is converted into the specified range (-0x80000000..0x7FFFFFFF)\r\n value = mwcRandom32() & MaxUInt32;\r\n }\r\n if (value === 0) {\r\n // Make sure the number is converted into the specified range (-0x80000000..0x7FFFFFFF)\r\n value = mathFloor((UInt32Mask * Math.random()) | 0);\r\n }\r\n if (!signed) {\r\n // Make sure we end up with a positive number and not -ve one.\r\n value >>>= 0;\r\n }\r\n return value;\r\n}\r\n/**\r\n * Seed the MWC random number generator with the specified seed or a random value\r\n * @param value - optional the number to used as the seed, if undefined, null or zero a random value will be chosen\r\n */\r\nexport function mwcRandomSeed(value) {\r\n if (!value) {\r\n _autoSeedMwc();\r\n }\r\n else {\r\n _mwcSeed(value);\r\n }\r\n}\r\n/**\r\n * Generate a random 32-bit number between (0x000000..0xFFFFFFFF) or (-0x80000000..0x7FFFFFFF), using MWC (Multiply with carry)\r\n * instead of Math.random() defaults to un-signed.\r\n * Used as a replacement random generator for IE to avoid issues with older IE instances.\r\n * @param signed - True to return a signed 32-bit number (-0x80000000..0x7FFFFFFF) otherwise an unsigned one (0x000000..0xFFFFFFFF)\r\n */\r\nexport function mwcRandom32(signed) {\r\n _mwcZ = (36969 * (_mwcZ & 0xFFFF) + (_mwcZ >> 16)) & MaxUInt32;\r\n _mwcW = (18000 * (_mwcW & 0xFFFF) + (_mwcW >> 16)) & MaxUInt32;\r\n var value = (((_mwcZ << 16) + (_mwcW & 0xFFFF)) >>> 0) & MaxUInt32 | 0;\r\n if (!signed) {\r\n // Make sure we end up with a positive number and not -ve one.\r\n value >>>= 0;\r\n }\r\n return value;\r\n}\r\n/**\r\n * Generate random base64 id string.\r\n * The default length is 22 which is 132-bits so almost the same as a GUID but as base64 (the previous default was 5)\r\n * @param maxLength - Optional value to specify the length of the id to be generated, defaults to 22\r\n */\r\nexport function newId(maxLength) {\r\n if (maxLength === void 0) { maxLength = 22; }\r\n var base64chars = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\";\r\n // Start with an initial random number, consuming the value in reverse byte order\r\n var number = random32() >>> 0; // Make sure it's a +ve number\r\n var chars = 0;\r\n var result = STR_EMPTY;\r\n while (result[_DYN_LENGTH /* @min:%2elength */] < maxLength) {\r\n chars++;\r\n result += base64chars.charAt(number & 0x3F);\r\n number >>>= 6; // Zero fill with right shift\r\n if (chars === 5) {\r\n // 5 base64 characters === 30 bits so we don't have enough bits for another base64 char\r\n // So add on another 30 bits and make sure it's +ve\r\n number = (((random32() << 2) & 0xFFFFFFFF) | (number & 0x03)) >>> 0;\r\n chars = 0; // We need to reset the number every 5 chars (30 bits)\r\n }\r\n }\r\n return result;\r\n}\r\n//# sourceMappingURL=RandomHelper.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { objDefine } from \"@nevware21/ts-utils\";\r\nimport { normalizeJsName } from \"./HelperFuncs\";\r\nimport { STR_EMPTY } from \"./InternalConstants\";\r\nimport { newId } from \"./RandomHelper\";\r\nvar version = '3.3.6';\r\nvar instanceName = \".\" + newId(6);\r\nvar _dataUid = 0;\r\n// Accepts only:\r\n// - Node\r\n// - Node.ELEMENT_NODE\r\n// - Node.DOCUMENT_NODE\r\n// - Object\r\n// - Any\r\nfunction _canAcceptData(target) {\r\n return target.nodeType === 1 || target.nodeType === 9 || !(+target.nodeType);\r\n}\r\nfunction _getCache(data, target) {\r\n var theCache = target[data.id];\r\n if (!theCache) {\r\n theCache = {};\r\n try {\r\n if (_canAcceptData(target)) {\r\n objDefine(target, data.id, {\r\n e: false,\r\n v: theCache\r\n });\r\n }\r\n }\r\n catch (e) {\r\n // Not all environments allow extending all objects, so just ignore the cache in those cases\r\n }\r\n }\r\n return theCache;\r\n}\r\nexport function createUniqueNamespace(name, includeVersion) {\r\n if (includeVersion === void 0) { includeVersion = false; }\r\n return normalizeJsName(name + (_dataUid++) + (includeVersion ? \".\" + version : STR_EMPTY) + instanceName);\r\n}\r\nexport function createElmNodeData(name) {\r\n var data = {\r\n id: createUniqueNamespace(\"_aiData-\" + (name || STR_EMPTY) + \".\" + version),\r\n accept: function (target) {\r\n return _canAcceptData(target);\r\n },\r\n get: function (target, name, defValue, addDefault) {\r\n var theCache = target[data.id];\r\n if (!theCache) {\r\n if (addDefault) {\r\n // Side effect is adds the cache\r\n theCache = _getCache(data, target);\r\n theCache[normalizeJsName(name)] = defValue;\r\n }\r\n return defValue;\r\n }\r\n return theCache[normalizeJsName(name)];\r\n },\r\n kill: function (target, name) {\r\n if (target && target[name]) {\r\n try {\r\n delete target[name];\r\n }\r\n catch (e) {\r\n // Just cleaning up, so if this fails -- ignore\r\n }\r\n }\r\n }\r\n };\r\n return data;\r\n}\r\n//# sourceMappingURL=DataCacheHelper.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { asString, isArray, isDefined, isNullOrUndefined, isObject, isPlainObject, isUndefined, objForEachKey, objHasOwn } from \"@nevware21/ts-utils\";\r\nimport { _DYN_LENGTH } from \"../__DynamicConstants\";\r\nfunction _isConfigDefaults(value) {\r\n return (value && isObject(value) && (value.isVal || value.fb || objHasOwn(value, \"v\") || objHasOwn(value, \"mrg\") || objHasOwn(value, \"ref\") || value.set));\r\n}\r\nfunction _getDefault(dynamicHandler, theConfig, cfgDefaults) {\r\n var defValue;\r\n var isDefaultValid = cfgDefaults.dfVal || isDefined;\r\n // There is a fallback config key so try and grab that first\r\n if (theConfig && cfgDefaults.fb) {\r\n var fallbacks = cfgDefaults.fb;\r\n if (!isArray(fallbacks)) {\r\n fallbacks = [fallbacks];\r\n }\r\n for (var lp = 0; lp < fallbacks[_DYN_LENGTH /* @min:%2elength */]; lp++) {\r\n var fallback = fallbacks[lp];\r\n var fbValue = theConfig[fallback];\r\n if (isDefaultValid(fbValue)) {\r\n defValue = fbValue;\r\n }\r\n else if (dynamicHandler) {\r\n // Needed to ensure that the fallback value (and potentially) new field is also dynamic even if null/undefined\r\n fbValue = dynamicHandler.cfg[fallback];\r\n if (isDefaultValid(fbValue)) {\r\n defValue = fbValue;\r\n }\r\n // Needed to ensure that the fallback value (and potentially) new field is also dynamic even if null/undefined\r\n dynamicHandler.set(dynamicHandler.cfg, asString(fallback), fbValue);\r\n }\r\n if (isDefaultValid(defValue)) {\r\n // We have a valid default so break out of the look\r\n break;\r\n }\r\n }\r\n }\r\n // If the value is still not defined and we have a default value then use that\r\n if (!isDefaultValid(defValue) && isDefaultValid(cfgDefaults.v)) {\r\n defValue = cfgDefaults.v;\r\n }\r\n return defValue;\r\n}\r\n/**\r\n * Recursively resolve the default value\r\n * @param dynamicHandler\r\n * @param theConfig\r\n * @param cfgDefaults\r\n * @returns\r\n */\r\nfunction _resolveDefaultValue(dynamicHandler, theConfig, cfgDefaults) {\r\n var theValue = cfgDefaults;\r\n if (cfgDefaults && _isConfigDefaults(cfgDefaults)) {\r\n theValue = _getDefault(dynamicHandler, theConfig, cfgDefaults);\r\n }\r\n if (theValue) {\r\n if (_isConfigDefaults(theValue)) {\r\n theValue = _resolveDefaultValue(dynamicHandler, theConfig, theValue);\r\n }\r\n var newValue_1;\r\n if (isArray(theValue)) {\r\n newValue_1 = [];\r\n newValue_1[_DYN_LENGTH /* @min:%2elength */] = theValue[_DYN_LENGTH /* @min:%2elength */];\r\n }\r\n else if (isPlainObject(theValue)) {\r\n newValue_1 = {};\r\n }\r\n if (newValue_1) {\r\n objForEachKey(theValue, function (key, value) {\r\n if (value && _isConfigDefaults(value)) {\r\n value = _resolveDefaultValue(dynamicHandler, theConfig, value);\r\n }\r\n newValue_1[key] = value;\r\n });\r\n theValue = newValue_1;\r\n }\r\n }\r\n return theValue;\r\n}\r\n/**\r\n * Applies the default value on the config property and makes sure that it's dynamic\r\n * @param theConfig\r\n * @param name\r\n * @param defaultValue\r\n */\r\nexport function _applyDefaultValue(dynamicHandler, theConfig, name, defaultValue) {\r\n // Resolve the initial config value from the provided value or use the defined default\r\n var isValid;\r\n var setFn;\r\n var defValue;\r\n var cfgDefaults = defaultValue;\r\n var mergeDf;\r\n var reference;\r\n var readOnly;\r\n var blkDynamicValue;\r\n if (_isConfigDefaults(cfgDefaults)) {\r\n // looks like a IConfigDefault\r\n isValid = cfgDefaults.isVal;\r\n setFn = cfgDefaults.set;\r\n readOnly = cfgDefaults.rdOnly;\r\n blkDynamicValue = cfgDefaults.blkVal;\r\n mergeDf = cfgDefaults.mrg;\r\n reference = cfgDefaults.ref;\r\n if (!reference && isUndefined(reference)) {\r\n reference = !!mergeDf;\r\n }\r\n defValue = _getDefault(dynamicHandler, theConfig, cfgDefaults);\r\n }\r\n else {\r\n defValue = defaultValue;\r\n }\r\n if (blkDynamicValue) {\r\n // Mark the property so that any value assigned will be blocked from conversion, we need to do this\r\n // before assigning or fetching the value to ensure it's not converted\r\n dynamicHandler.blkVal(theConfig, name);\r\n }\r\n // Set the value to the default value;\r\n var theValue;\r\n var usingDefault = true;\r\n var cfgValue = theConfig[name];\r\n // try and get and user provided values\r\n if (cfgValue || !isNullOrUndefined(cfgValue)) {\r\n // Use the defined theConfig[name] value\r\n theValue = cfgValue;\r\n usingDefault = false;\r\n // The values are different and we have a special default value check, which is used to\r\n // override config values like empty strings to continue using the default\r\n if (isValid && theValue !== defValue && !isValid(theValue)) {\r\n theValue = defValue;\r\n usingDefault = true;\r\n }\r\n if (setFn) {\r\n theValue = setFn(theValue, defValue, theConfig);\r\n usingDefault = theValue === defValue;\r\n }\r\n }\r\n if (!usingDefault) {\r\n if (isPlainObject(theValue) || isArray(defValue)) {\r\n // we are using the user supplied value and it's an object\r\n if (mergeDf && defValue && (isPlainObject(defValue) || isArray(defValue))) {\r\n // Resolve/apply the defaults\r\n objForEachKey(defValue, function (dfName, dfValue) {\r\n // Sets the value and makes it dynamic (if it doesn't already exist)\r\n _applyDefaultValue(dynamicHandler, theValue, dfName, dfValue);\r\n });\r\n }\r\n }\r\n }\r\n else if (defValue) {\r\n // Just resolve the default\r\n theValue = _resolveDefaultValue(dynamicHandler, theConfig, defValue);\r\n }\r\n else {\r\n theValue = defValue;\r\n }\r\n // if (theValue && usingDefault && (isPlainObject(theValue) || isArray(theValue))) {\r\n // theValue = _cfgDeepCopy(theValue);\r\n // }\r\n // Needed to ensure that the (potentially) new field is dynamic even if null/undefined\r\n dynamicHandler.set(theConfig, name, theValue);\r\n if (reference) {\r\n dynamicHandler.ref(theConfig, name);\r\n }\r\n if (readOnly) {\r\n dynamicHandler.rdOnly(theConfig, name);\r\n }\r\n}\r\n//# sourceMappingURL=ConfigDefaults.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { isArray, isPlainObject, objForEachKey, symbolFor, throwTypeError } from \"@nevware21/ts-utils\";\r\nimport { _DYN_LENGTH } from \"../__DynamicConstants\";\r\n// Using Symbol.for so that if the same symbol was already created it would be returned\r\n// To handle multiple instances using potentially different versions we are not using\r\n// createUniqueNamespace()\r\nexport var CFG_HANDLER_LINK = symbolFor(\"[[ai_dynCfg_1]]\");\r\n/**\r\n * @internal\r\n * @ignore\r\n * The symbol to tag objects / arrays with if they should not be converted\r\n */\r\nvar BLOCK_DYNAMIC = symbolFor(\"[[ai_blkDynCfg_1]]\");\r\n/**\r\n * @internal\r\n * @ignore\r\n * The symbol to tag objects to indicate that when included into the configuration that\r\n * they should be converted into a trackable dynamic object.\r\n */\r\nvar FORCE_DYNAMIC = symbolFor(\"[[ai_frcDynCfg_1]]\");\r\nexport function _cfgDeepCopy(source) {\r\n if (source) {\r\n var target_1;\r\n if (isArray(source)) {\r\n target_1 = [];\r\n target_1[_DYN_LENGTH /* @min:%2elength */] = source[_DYN_LENGTH /* @min:%2elength */];\r\n }\r\n else if (isPlainObject(source)) {\r\n target_1 = {};\r\n }\r\n if (target_1) {\r\n // Copying index values by property name as the extensionConfig can be an array or object\r\n objForEachKey(source, function (key, value) {\r\n // Perform a deep copy of the object\r\n target_1[key] = _cfgDeepCopy(value);\r\n });\r\n return target_1;\r\n }\r\n }\r\n return source;\r\n}\r\n/**\r\n * @internal\r\n * Get the dynamic config handler if the value is already dynamic\r\n * @returns\r\n */\r\nexport function getDynamicConfigHandler(value) {\r\n if (value) {\r\n var handler = value[CFG_HANDLER_LINK] || value;\r\n if (handler.cfg && (handler.cfg === value || handler.cfg[CFG_HANDLER_LINK] === handler)) {\r\n return handler;\r\n }\r\n }\r\n return null;\r\n}\r\n/**\r\n * Mark the provided value so that if it's included into the configuration it will NOT have\r\n * its properties converted into a dynamic (reactive) object. If the object is not a plain object\r\n * or an array (ie. a class) this function has not affect as only Objects and Arrays are converted\r\n * into dynamic objects in the dynamic configuration.\r\n *\r\n * When you have tagged a value as both {@link forceDynamicConversion} and blocked force will take precedence.\r\n *\r\n * You should only need to use this function, if you are creating dynamic \"classes\" from objects\r\n * which confirm to the require interface. A common case for this is during unit testing where it's\r\n * easier to create mock extensions.\r\n *\r\n * If `value` is falsy (null / undefined / 0 / empty string etc) it will not be tagged and\r\n * if there is an exception adding the property to the value (because its frozen etc) the\r\n * exception will be swallowed\r\n *\r\n * @example\r\n * ```ts\r\n * // This is a valid \"extension\", but it is technically an object\r\n * // So when included in the config.extensions it WILL be cloned and then\r\n * // converted into a dynamic object, where all of its properties will become\r\n * // get/set object properties and will be tracked. While this WILL still\r\n * // function, when attempt to use a mocking framework on top of this the\r\n * // functions are now technically get accessors which return a function\r\n * // and this can cause some mocking frameworks to fail.\r\n * let mockChannel = {\r\n * pause: () => { },\r\n* resume: () => { },\r\n* teardown: () => { },\r\n* flush: (async: any, callBack: any) => { },\r\n* processTelemetry: (env: any) => { },\r\n* setNextPlugin: (next: any) => { },\r\n* initialize: (config: any, core: any, extensions: any) => { },\r\n* identifier: \"testChannel\",\r\n* priority: 1003\r\n* };\r\n * ```\r\n * @param value - The object that you want to block from being converted into a\r\n * trackable dynamic object\r\n * @returns The original value\r\n */\r\nexport function blockDynamicConversion(value) {\r\n if (value && (isPlainObject(value) || isArray(value))) {\r\n try {\r\n value[BLOCK_DYNAMIC] = true;\r\n }\r\n catch (e) {\r\n // Don't throw for this case as it's an ask only\r\n }\r\n }\r\n return value;\r\n}\r\n/**\r\n * This is the reverse case of {@link blockDynamicConversion} in that this will tag an\r\n * object to indicate that it should always be converted into a dynamic trackable object\r\n * even when not an object or array. So all properties of this object will become\r\n * get / set accessor functions.\r\n *\r\n * When you have tagged a value as both {@link forceDynamicConversion} and blocked force will take precedence.\r\n *\r\n * If `value` is falsy (null / undefined / 0 / empty string etc) it will not be tagged and\r\n * if there is an exception adding the property to the value (because its frozen etc) the\r\n * exception will be swallowed.\r\n * @param value - The object that should be tagged and converted if included into a dynamic\r\n * configuration.\r\n * @returns The original value\r\n */\r\nexport function forceDynamicConversion(value) {\r\n if (value) {\r\n try {\r\n value[FORCE_DYNAMIC] = true;\r\n }\r\n catch (e) {\r\n // Don't throw for this case as it's an ask only\r\n }\r\n }\r\n return value;\r\n}\r\n/**\r\n * @internal\r\n * @ignore\r\n * Helper function to check whether an object can or should be converted into a dynamic\r\n * object.\r\n * @param value - The object to check whether it should be converted\r\n * @returns `true` if the value should be converted otherwise `false`.\r\n */\r\nexport function _canMakeDynamic(getFunc, state, value) {\r\n var result = false;\r\n // Object must exist and be truthy\r\n if (value && !getFunc[state.blkVal]) {\r\n // Tagged as always convert\r\n result = value[FORCE_DYNAMIC];\r\n // Check that it's not explicitly tagged as blocked\r\n if (!result && !value[BLOCK_DYNAMIC]) {\r\n // Only convert plain objects or arrays by default\r\n result = isPlainObject(value) || isArray(value);\r\n }\r\n }\r\n return result;\r\n}\r\n/**\r\n * Throws an invalid access exception\r\n * @param message - The message to include in the exception\r\n */\r\nexport function throwInvalidAccess(message) {\r\n throwTypeError(\"InvalidAccess:\" + message);\r\n}\r\n//# sourceMappingURL=DynamicSupport.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { arrForEach, arrIndexOf, dumpObj, isArray, objDefine, objDefineProp, objForEachKey, objGetOwnPropertyDescriptor } from \"@nevware21/ts-utils\";\r\nimport { UNDEFINED_VALUE } from \"../JavaScriptSDK/InternalConstants\";\r\nimport { _DYN_APPLY, _DYN_LOGGER, _DYN_PUSH, _DYN_SPLICE, _DYN_THROW_INTERNAL } from \"../__DynamicConstants\";\r\nimport { CFG_HANDLER_LINK, _canMakeDynamic, blockDynamicConversion, throwInvalidAccess } from \"./DynamicSupport\";\r\nvar arrayMethodsToPatch = [\r\n \"push\",\r\n \"pop\",\r\n \"shift\",\r\n \"unshift\",\r\n \"splice\"\r\n];\r\nexport var _throwDynamicError = function (logger, name, desc, e) {\r\n logger && logger[_DYN_THROW_INTERNAL /* @min:%2ethrowInternal */](3 /* eLoggingSeverity.DEBUG */, 108 /* _eInternalMessageId.DynamicConfigException */, \"\".concat(desc, \" [\").concat(name, \"] failed - \") + dumpObj(e));\r\n};\r\nfunction _patchArray(state, target, name) {\r\n if (isArray(target)) {\r\n // Monkey Patch the methods that might change the array\r\n arrForEach(arrayMethodsToPatch, function (method) {\r\n var orgMethod = target[method];\r\n target[method] = function () {\r\n var args = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n args[_i] = arguments[_i];\r\n }\r\n var result = orgMethod[_DYN_APPLY /* @min:%2eapply */](this, args);\r\n // items may be added, removed or moved so need to make some new dynamic properties\r\n _makeDynamicObject(state, target, name, \"Patching\");\r\n return result;\r\n };\r\n });\r\n }\r\n}\r\nfunction _getOwnPropGetter(target, name) {\r\n var propDesc = objGetOwnPropertyDescriptor(target, name);\r\n return propDesc && propDesc.get;\r\n}\r\nfunction _createDynamicProperty(state, theConfig, name, value) {\r\n // Does not appear to be dynamic so lets make it so\r\n var detail = {\r\n n: name,\r\n h: [],\r\n trk: function (handler) {\r\n if (handler && handler.fn) {\r\n if (arrIndexOf(detail.h, handler) === -1) {\r\n // Add this handler to the collection that should be notified when the value changes\r\n detail.h[_DYN_PUSH /* @min:%2epush */](handler);\r\n }\r\n state.trk(handler, detail);\r\n }\r\n },\r\n clr: function (handler) {\r\n var idx = arrIndexOf(detail.h, handler);\r\n if (idx !== -1) {\r\n detail.h[_DYN_SPLICE /* @min:%2esplice */](idx, 1);\r\n }\r\n }\r\n };\r\n // Flag to optimize lookup response time by avoiding additional function calls\r\n var checkDynamic = true;\r\n var isObjectOrArray = false;\r\n function _getProperty() {\r\n if (checkDynamic) {\r\n isObjectOrArray = isObjectOrArray || _canMakeDynamic(_getProperty, state, value);\r\n // Make sure that if it's an object that we make it dynamic\r\n if (value && !value[CFG_HANDLER_LINK] && isObjectOrArray) {\r\n // It doesn't look like it's already dynamic so lets make sure it's converted the object into a dynamic Config as well\r\n value = _makeDynamicObject(state, value, name, \"Converting\");\r\n }\r\n // If it needed to be converted it now has been\r\n checkDynamic = false;\r\n }\r\n // If there is an active handler then add it to the tracking set of handlers\r\n var activeHandler = state.act;\r\n if (activeHandler) {\r\n detail.trk(activeHandler);\r\n }\r\n return value;\r\n }\r\n // Tag this getter as our dynamic property and provide shortcut for notifying a change\r\n _getProperty[state.prop] = {\r\n chng: function () {\r\n state.add(detail);\r\n }\r\n };\r\n function _setProperty(newValue) {\r\n if (value !== newValue) {\r\n if (!!_getProperty[state.ro] && !state.upd) {\r\n // field is marked as readonly so return false\r\n throwInvalidAccess(\"[\" + name + \"] is read-only:\" + dumpObj(theConfig));\r\n }\r\n if (checkDynamic) {\r\n isObjectOrArray = isObjectOrArray || _canMakeDynamic(_getProperty, state, value);\r\n checkDynamic = false;\r\n }\r\n // The value must be a plain object or an array to enforce the reference (in-place updates)\r\n var isReferenced = isObjectOrArray && _getProperty[state.rf];\r\n if (isObjectOrArray) {\r\n // We are about to replace a plain object or an array\r\n if (isReferenced) {\r\n // Reassign the properties from the current value to the same properties from the newValue\r\n // This will set properties not in the newValue to undefined\r\n objForEachKey(value, function (key) {\r\n value[key] = newValue ? newValue[key] : UNDEFINED_VALUE;\r\n });\r\n // Now assign / re-assign value with all of the keys from newValue\r\n try {\r\n objForEachKey(newValue, function (key, theValue) {\r\n _setDynamicProperty(state, value, key, theValue);\r\n });\r\n // Now drop newValue so when we assign value later it keeps the existing reference\r\n newValue = value;\r\n }\r\n catch (e) {\r\n // Unable to convert to dynamic property so just leave as non-dynamic\r\n _throwDynamicError((state.hdlr || {})[_DYN_LOGGER /* @min:%2elogger */], name, \"Assigning\", e);\r\n // Mark as not an object or array so we don't try and do this again\r\n isObjectOrArray = false;\r\n }\r\n }\r\n else if (value && value[CFG_HANDLER_LINK]) {\r\n // As we are replacing the value, if it's already dynamic then we need to notify the listeners\r\n // for every property it has already\r\n objForEachKey(value, function (key) {\r\n // Check if the value is dynamic\r\n var getter = _getOwnPropGetter(value, key);\r\n if (getter) {\r\n // And if it is tell it's listeners that the value has changed\r\n var valueState = getter[state.prop];\r\n valueState && valueState.chng();\r\n }\r\n });\r\n }\r\n }\r\n if (newValue !== value) {\r\n var newIsObjectOrArray = newValue && _canMakeDynamic(_getProperty, state, newValue);\r\n if (!isReferenced && newIsObjectOrArray) {\r\n // As the newValue is an object/array lets preemptively make it dynamic\r\n newValue = _makeDynamicObject(state, newValue, name, \"Converting\");\r\n }\r\n // Now assign the internal \"value\" to the newValue\r\n value = newValue;\r\n isObjectOrArray = newIsObjectOrArray;\r\n }\r\n // Cause any listeners to be scheduled for notification\r\n state.add(detail);\r\n }\r\n }\r\n objDefine(theConfig, detail.n, { g: _getProperty, s: _setProperty });\r\n}\r\nexport function _setDynamicProperty(state, target, name, value) {\r\n if (target) {\r\n // To be a dynamic property it needs to have a get function\r\n var getter = _getOwnPropGetter(target, name);\r\n var isDynamic = getter && !!getter[state.prop];\r\n if (!isDynamic) {\r\n _createDynamicProperty(state, target, name, value);\r\n }\r\n else {\r\n // Looks like it's already dynamic just assign the new value\r\n target[name] = value;\r\n }\r\n }\r\n return target;\r\n}\r\nexport function _setDynamicPropertyState(state, target, name, flags) {\r\n if (target) {\r\n // To be a dynamic property it needs to have a get function\r\n var getter = _getOwnPropGetter(target, name);\r\n var isDynamic = getter && !!getter[state.prop];\r\n var inPlace = flags && flags[0 /* _eSetDynamicPropertyFlags.inPlace */];\r\n var rdOnly = flags && flags[1 /* _eSetDynamicPropertyFlags.readOnly */];\r\n var blkProp = flags && flags[2 /* _eSetDynamicPropertyFlags.blockDynamicProperty */];\r\n if (!isDynamic) {\r\n if (blkProp) {\r\n try {\r\n // Attempt to mark the target as blocked from conversion\r\n blockDynamicConversion(target);\r\n }\r\n catch (e) {\r\n _throwDynamicError((state.hdlr || {})[_DYN_LOGGER /* @min:%2elogger */], name, \"Blocking\", e);\r\n }\r\n }\r\n try {\r\n // Make sure it's dynamic so that we can tag the property as per the state\r\n _setDynamicProperty(state, target, name, target[name]);\r\n getter = _getOwnPropGetter(target, name);\r\n }\r\n catch (e) {\r\n // Unable to convert to dynamic property so just leave as non-dynamic\r\n _throwDynamicError((state.hdlr || {})[_DYN_LOGGER /* @min:%2elogger */], name, \"State\", e);\r\n }\r\n }\r\n // Assign the optional flags if true\r\n if (inPlace) {\r\n getter[state.rf] = inPlace;\r\n }\r\n if (rdOnly) {\r\n getter[state.ro] = rdOnly;\r\n }\r\n if (blkProp) {\r\n getter[state.blkVal] = true;\r\n }\r\n }\r\n return target;\r\n}\r\nexport function _makeDynamicObject(state, target, name, desc) {\r\n try {\r\n // Assign target with new value properties (converting into dynamic properties in the process)\r\n objForEachKey(target, function (key, value) {\r\n // Assign and/or make the property dynamic\r\n _setDynamicProperty(state, target, key, value);\r\n });\r\n if (!target[CFG_HANDLER_LINK]) {\r\n // Link the config back to the dynamic config details\r\n objDefineProp(target, CFG_HANDLER_LINK, {\r\n get: function () {\r\n return state.hdlr;\r\n }\r\n });\r\n _patchArray(state, target, name);\r\n }\r\n }\r\n catch (e) {\r\n // Unable to convert to dynamic property so just leave as non-dynamic\r\n _throwDynamicError((state.hdlr || {})[_DYN_LOGGER /* @min:%2elogger */], name, desc, e);\r\n }\r\n return target;\r\n}\r\n//# sourceMappingURL=DynamicProperty.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { arrForEach, arrIndexOf, dumpObj, newSymbol, scheduleTimeout } from \"@nevware21/ts-utils\";\r\nimport { throwAggregationError } from \"../JavaScriptSDK/AggregationError\";\r\nimport { _DYN_CANCEL, _DYN_LENGTH, _DYN_LOGGER, _DYN_PUSH, _DYN_THROW_INTERNAL } from \"../__DynamicConstants\";\r\nvar symPrefix = \"[[ai_\";\r\nvar symPostfix = \"]]\";\r\nexport function _createState(cfgHandler) {\r\n var dynamicPropertySymbol = newSymbol(symPrefix + \"get\" + cfgHandler.uid + symPostfix);\r\n var dynamicPropertyReadOnly = newSymbol(symPrefix + \"ro\" + cfgHandler.uid + symPostfix);\r\n var dynamicPropertyReferenced = newSymbol(symPrefix + \"rf\" + cfgHandler.uid + symPostfix);\r\n var dynamicPropertyBlockValue = newSymbol(symPrefix + \"blkVal\" + cfgHandler.uid + symPostfix);\r\n var dynamicPropertyDetail = newSymbol(symPrefix + \"dtl\" + cfgHandler.uid + symPostfix);\r\n var _waitingHandlers = null;\r\n var _watcherTimer = null;\r\n var theState;\r\n function _useHandler(activeHandler, callback) {\r\n var prevWatcher = theState.act;\r\n try {\r\n theState.act = activeHandler;\r\n if (activeHandler && activeHandler[dynamicPropertyDetail]) {\r\n // Clear out the previously tracked details for this handler, so that access are re-evaluated\r\n arrForEach(activeHandler[dynamicPropertyDetail], function (detail) {\r\n detail.clr(activeHandler);\r\n });\r\n activeHandler[dynamicPropertyDetail] = [];\r\n }\r\n callback({\r\n cfg: cfgHandler.cfg,\r\n set: cfgHandler.set.bind(cfgHandler),\r\n setDf: cfgHandler.setDf.bind(cfgHandler),\r\n ref: cfgHandler.ref.bind(cfgHandler),\r\n rdOnly: cfgHandler.rdOnly.bind(cfgHandler)\r\n });\r\n }\r\n catch (e) {\r\n var logger = cfgHandler[_DYN_LOGGER /* @min:%2elogger */];\r\n if (logger) {\r\n // Don't let one individual failure break everyone\r\n logger[_DYN_THROW_INTERNAL /* @min:%2ethrowInternal */](1 /* eLoggingSeverity.CRITICAL */, 107 /* _eInternalMessageId.ConfigWatcherException */, dumpObj(e));\r\n }\r\n // Re-throw the exception so that any true \"error\" is reported back to the called\r\n throw e;\r\n }\r\n finally {\r\n theState.act = prevWatcher || null;\r\n }\r\n }\r\n function _notifyWatchers() {\r\n if (_waitingHandlers) {\r\n var notifyHandlers = _waitingHandlers;\r\n _waitingHandlers = null;\r\n // Stop any timer as we are running them now anyway\r\n _watcherTimer && _watcherTimer[_DYN_CANCEL /* @min:%2ecancel */]();\r\n _watcherTimer = null;\r\n var watcherFailures_1 = [];\r\n // Now run the handlers\r\n arrForEach(notifyHandlers, function (handler) {\r\n if (handler) {\r\n if (handler[dynamicPropertyDetail]) {\r\n arrForEach(handler[dynamicPropertyDetail], function (detail) {\r\n // Clear out this handler from previously tracked details, so that access are re-evaluated\r\n detail.clr(handler);\r\n });\r\n handler[dynamicPropertyDetail] = null;\r\n }\r\n // The handler may have self removed as part of another handler so re-check\r\n if (handler.fn) {\r\n try {\r\n _useHandler(handler, handler.fn);\r\n }\r\n catch (e) {\r\n // Don't let a single failing watcher cause other watches to fail\r\n watcherFailures_1[_DYN_PUSH /* @min:%2epush */](e);\r\n }\r\n }\r\n }\r\n });\r\n // During notification we may have had additional updates -- so notify those updates as well\r\n if (_waitingHandlers) {\r\n try {\r\n _notifyWatchers();\r\n }\r\n catch (e) {\r\n watcherFailures_1[_DYN_PUSH /* @min:%2epush */](e);\r\n }\r\n }\r\n if (watcherFailures_1[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n throwAggregationError(\"Watcher error(s): \", watcherFailures_1);\r\n }\r\n }\r\n }\r\n function _addWatcher(detail) {\r\n if (detail && detail.h[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n if (!_waitingHandlers) {\r\n _waitingHandlers = [];\r\n }\r\n if (!_watcherTimer) {\r\n _watcherTimer = scheduleTimeout(function () {\r\n _watcherTimer = null;\r\n _notifyWatchers();\r\n }, 0);\r\n }\r\n // Add all of the handlers for this detail (if not already present) - using normal for-loop for performance\r\n for (var idx = 0; idx < detail.h[_DYN_LENGTH /* @min:%2elength */]; idx++) {\r\n var handler = detail.h[idx];\r\n // Add this handler to the collection of handlers to re-execute\r\n if (handler && arrIndexOf(_waitingHandlers, handler) === -1) {\r\n _waitingHandlers[_DYN_PUSH /* @min:%2epush */](handler);\r\n }\r\n }\r\n }\r\n }\r\n function _trackHandler(handler, detail) {\r\n if (handler) {\r\n var details = handler[dynamicPropertyDetail] = handler[dynamicPropertyDetail] || [];\r\n if (arrIndexOf(details, detail) === -1) {\r\n // If this detail is not already listed as tracked then add it so that we re-evaluate it's usage\r\n details[_DYN_PUSH /* @min:%2epush */](detail);\r\n }\r\n }\r\n }\r\n theState = {\r\n prop: dynamicPropertySymbol,\r\n ro: dynamicPropertyReadOnly,\r\n rf: dynamicPropertyReferenced,\r\n blkVal: dynamicPropertyBlockValue,\r\n hdlr: cfgHandler,\r\n add: _addWatcher,\r\n notify: _notifyWatchers,\r\n use: _useHandler,\r\n trk: _trackHandler\r\n };\r\n return theState;\r\n}\r\n//# sourceMappingURL=DynamicState.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { dumpObj, isUndefined, objDefine, objForEachKey } from \"@nevware21/ts-utils\";\r\nimport { createUniqueNamespace } from \"../JavaScriptSDK/DataCacheHelper\";\r\nimport { STR_NOT_DYNAMIC_ERROR } from \"../JavaScriptSDK/InternalConstants\";\r\nimport { _DYN_THROW_INTERNAL, _DYN_WARN_TO_CONSOLE, _DYN_WATCH } from \"../__DynamicConstants\";\r\nimport { _applyDefaultValue } from \"./ConfigDefaults\";\r\nimport { _makeDynamicObject, _setDynamicProperty, _setDynamicPropertyState, _throwDynamicError } from \"./DynamicProperty\";\r\nimport { _createState } from \"./DynamicState\";\r\nimport { CFG_HANDLER_LINK, _cfgDeepCopy, getDynamicConfigHandler, throwInvalidAccess } from \"./DynamicSupport\";\r\n/**\r\n * Identifies a function which will be re-called whenever any of it's accessed configuration values\r\n * change.\r\n * @param configHandler - The callback that will be called for the initial request and then whenever any\r\n * accessed configuration changes are identified.\r\n */\r\nfunction _createAndUseHandler(state, configHandler) {\r\n var handler = {\r\n fn: configHandler,\r\n rm: function () {\r\n // Clear all references to the handler so it can be garbage collected\r\n // This will also cause this handler to never get called and eventually removed\r\n handler.fn = null;\r\n state = null;\r\n configHandler = null;\r\n }\r\n };\r\n objDefine(handler, \"toJSON\", { v: function () { return \"WatcherHandler\" + (handler.fn ? \"\" : \"[X]\"); } });\r\n state.use(handler, configHandler);\r\n return handler;\r\n}\r\n/**\r\n * Creates the dynamic config handler and associates with the target config as the root object\r\n * @param target - The config that you want to be root of the dynamic config\r\n * @param inPlace - Should the passed config be converted in-place or a new proxy returned\r\n * @returns The existing dynamic handler or a new instance with the provided config values\r\n */\r\nfunction _createDynamicHandler(logger, target, inPlace) {\r\n var dynamicHandler = getDynamicConfigHandler(target);\r\n if (dynamicHandler) {\r\n // The passed config is already dynamic so return it's tracker\r\n return dynamicHandler;\r\n }\r\n var uid = createUniqueNamespace(\"dyncfg\", true);\r\n var newTarget = (target && inPlace !== false) ? target : _cfgDeepCopy(target);\r\n var theState;\r\n function _notifyWatchers() {\r\n theState.notify();\r\n }\r\n function _setValue(target, name, value) {\r\n try {\r\n target = _setDynamicProperty(theState, target, name, value);\r\n }\r\n catch (e) {\r\n // Unable to convert to dynamic property so just leave as non-dynamic\r\n _throwDynamicError(logger, name, \"Setting value\", e);\r\n }\r\n return target[name];\r\n }\r\n function _watch(configHandler) {\r\n return _createAndUseHandler(theState, configHandler);\r\n }\r\n function _block(configHandler, allowUpdate) {\r\n theState.use(null, function (details) {\r\n var prevUpd = theState.upd;\r\n try {\r\n if (!isUndefined(allowUpdate)) {\r\n theState.upd = allowUpdate;\r\n }\r\n configHandler(details);\r\n }\r\n finally {\r\n theState.upd = prevUpd;\r\n }\r\n });\r\n }\r\n function _ref(target, name) {\r\n var _a;\r\n // Make sure it's dynamic and mark as referenced with it's current value\r\n return _setDynamicPropertyState(theState, target, name, (_a = {}, _a[0 /* _eSetDynamicPropertyFlags.inPlace */] = true, _a))[name];\r\n }\r\n function _rdOnly(target, name) {\r\n var _a;\r\n // Make sure it's dynamic and mark as readonly with it's current value\r\n return _setDynamicPropertyState(theState, target, name, (_a = {}, _a[1 /* _eSetDynamicPropertyFlags.readOnly */] = true, _a))[name];\r\n }\r\n function _blkPropValue(target, name) {\r\n var _a;\r\n // Make sure it's dynamic and mark as readonly with it's current value\r\n return _setDynamicPropertyState(theState, target, name, (_a = {}, _a[2 /* _eSetDynamicPropertyFlags.blockDynamicProperty */] = true, _a))[name];\r\n }\r\n function _applyDefaults(theConfig, defaultValues) {\r\n if (defaultValues) {\r\n // Resolve/apply the defaults\r\n objForEachKey(defaultValues, function (name, value) {\r\n // Sets the value and makes it dynamic (if it doesn't already exist)\r\n _applyDefaultValue(cfgHandler, theConfig, name, value);\r\n });\r\n }\r\n return theConfig;\r\n }\r\n var cfgHandler = {\r\n uid: null,\r\n cfg: newTarget,\r\n logger: logger,\r\n notify: _notifyWatchers,\r\n set: _setValue,\r\n setDf: _applyDefaults,\r\n watch: _watch,\r\n ref: _ref,\r\n rdOnly: _rdOnly,\r\n blkVal: _blkPropValue,\r\n _block: _block\r\n };\r\n objDefine(cfgHandler, \"uid\", {\r\n c: false,\r\n e: false,\r\n w: false,\r\n v: uid\r\n });\r\n theState = _createState(cfgHandler);\r\n // Setup tracking for all defined default keys\r\n _makeDynamicObject(theState, newTarget, \"config\", \"Creating\");\r\n return cfgHandler;\r\n}\r\n/**\r\n * Log an invalid access message to the console\r\n */\r\nfunction _logInvalidAccess(logger, message) {\r\n if (logger) {\r\n logger[_DYN_WARN_TO_CONSOLE /* @min:%2ewarnToConsole */](message);\r\n logger[_DYN_THROW_INTERNAL /* @min:%2ethrowInternal */](2 /* eLoggingSeverity.WARNING */, 108 /* _eInternalMessageId.DynamicConfigException */, message);\r\n }\r\n else {\r\n // We don't have a logger so just throw an exception\r\n throwInvalidAccess(message);\r\n }\r\n}\r\n/**\r\n * Create or return a dynamic version of the passed config, if it is not already dynamic\r\n * @param config - The config to be converted into a dynamic config\r\n * @param defaultConfig - The default values to apply on the config if the properties don't already exist\r\n * @param inPlace - Should the config be converted in-place into a dynamic config or a new instance returned, defaults to true\r\n * @returns The dynamic config handler for the config (whether new or existing)\r\n */\r\nexport function createDynamicConfig(config, defaultConfig, logger, inPlace) {\r\n var dynamicHandler = _createDynamicHandler(logger, config || {}, inPlace);\r\n if (defaultConfig) {\r\n dynamicHandler.setDf(dynamicHandler.cfg, defaultConfig);\r\n }\r\n return dynamicHandler;\r\n}\r\n/**\r\n * Watch and track changes for accesses to the current config, the provided config MUST already be\r\n * a dynamic config or a child accessed via the dynamic config\r\n * @param logger - The logger instance to use if there is no existing handler\r\n * @returns A watcher handler instance that can be used to remove itself when being unloaded\r\n * @throws TypeError if the provided config is not a dynamic config instance\r\n */\r\nexport function onConfigChange(config, configHandler, logger) {\r\n var handler = config[CFG_HANDLER_LINK] || config;\r\n if (handler.cfg && (handler.cfg === config || handler.cfg[CFG_HANDLER_LINK] === handler)) {\r\n return handler[_DYN_WATCH /* @min:%2ewatch */](configHandler);\r\n }\r\n _logInvalidAccess(logger, STR_NOT_DYNAMIC_ERROR + dumpObj(config));\r\n return createDynamicConfig(config, null, logger)[_DYN_WATCH /* @min:%2ewatch */](configHandler);\r\n}\r\n//# sourceMappingURL=DynamicConfig.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { createPromise, doAwaitResponse } from \"@nevware21/ts-async\";\r\nimport { arrSlice, getLength } from \"@nevware21/ts-utils\";\r\nimport { _DYN_UNLOAD } from \"../__DynamicConstants\";\r\n/**\r\n * Run the unload function of the target object if it exists\r\n * @param target - The target object that contains the unload function\r\n * @param isAsync - The caller identifies whether it is expecting the operation to complete synchronously or asynchronously. Even\r\n * if the caller is not waiting the operation may still be performed asynchronously depending on the component and the reverse is\r\n * also true.\r\n * @returns The result of the target function\r\n */\r\nexport function runTargetUnload(target, isAsync) {\r\n if (target && target[_DYN_UNLOAD /* @min:%2eunload */]) {\r\n return target[_DYN_UNLOAD /* @min:%2eunload */](isAsync);\r\n }\r\n}\r\n/**\r\n * Call the unload function on all targets handling any returned [IPromise](https://nevware21.github.io/ts-async/typedoc/interfaces/IPromise.html)\r\n * / Promise before calling the next targets unload\r\n * @param targets - An array of the targets to unload\r\n * @param isAsync - The caller identifies whether it is expecting the operations to complete synchronously or asynchronously. Even\r\n * if the caller is not waiting the operation may still be performed asynchronously depending on the component and the reverse is\r\n * also true.\r\n * @param done - Optional callback function to call once all of the unload functions have been called.\r\n */\r\nexport function doUnloadAll(targets, isAsync, done) {\r\n var result;\r\n if (!done) {\r\n result = createPromise(function (resolved) {\r\n done = resolved;\r\n });\r\n }\r\n if (targets && getLength(targets) > 0) {\r\n doAwaitResponse(runTargetUnload(targets[0], isAsync), function () {\r\n doUnloadAll(arrSlice(targets, 1), isAsync, done);\r\n });\r\n }\r\n else {\r\n done();\r\n }\r\n return result;\r\n}\r\n//# sourceMappingURL=AsyncUtils.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nexport var ChannelControllerPriority = 500;\r\nexport var DisabledPropertyName = \"Microsoft_ApplicationInsights_BypassAjaxInstrumentation\";\r\n// export const SampleRate = \"sampleRate\";\r\n// export const ProcessLegacy = \"ProcessLegacy\";\r\n// export const HttpMethod = \"http.method\";\r\n// export const DEFAULT_BREEZE_ENDPOINT = \"https://dc.services.visualstudio.com\";\r\n// export const DEFAULT_BREEZE_PATH = \"/v2/track\";\r\n// export const strNotSpecified = \"not_specified\";\r\n// export const strIkey = \"iKey\";\r\n//# sourceMappingURL=Constants.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { asString, isBoolean, isFunction, isNullOrUndefined, isString } from \"@nevware21/ts-utils\";\r\nimport { STR_EMPTY } from \"../JavaScriptSDK/InternalConstants\";\r\nimport { _DYN_TO_LOWER_CASE } from \"../__DynamicConstants\";\r\n/**\r\n * @internal\r\n * @ignore\r\n * @param str\r\n * @param defaultValue\r\n * @returns\r\n */\r\nfunction _stringToBoolOrDefault(theValue, defaultValue, theConfig) {\r\n if (!theValue && isNullOrUndefined(theValue)) {\r\n return defaultValue;\r\n }\r\n if (isBoolean(theValue)) {\r\n return theValue;\r\n }\r\n return asString(theValue)[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]() === \"true\";\r\n}\r\n/**\r\n * Helper which returns an IConfigDefaultCheck instance with the field defined as an object\r\n * that should be merged\r\n * @param defaultValue - The default value to apply it not provided or it's not valid\r\n * @returns a new IConfigDefaultCheck structure\r\n */\r\nexport function cfgDfMerge(defaultValue) {\r\n return {\r\n mrg: true,\r\n v: defaultValue\r\n };\r\n}\r\n/**\r\n * Helper which returns an IConfigDefaultCheck instance with the provided field set function\r\n * @param setter - The IConfigCheckFn function to validate the user provided value\r\n * @param defaultValue - The default value to apply it not provided or it's not valid\r\n * @returns a new IConfigDefaultCheck structure\r\n */\r\nexport function cfgDfSet(setter, defaultValue) {\r\n return {\r\n set: setter,\r\n v: defaultValue\r\n };\r\n}\r\n/**\r\n * Helper which returns an IConfigDefaultCheck instance with the provided field validator\r\n * @param validator - The IConfigCheckFn function to validate the user provided value\r\n * @param defaultValue - The default value to apply it not provided or it's not valid\r\n * @param fallBackName - The fallback configuration name if the current value is not available\r\n * @returns a new IConfigDefaultCheck structure\r\n */\r\nexport function cfgDfValidate(validator, defaultValue, fallBackName) {\r\n return {\r\n fb: fallBackName,\r\n isVal: validator,\r\n v: defaultValue\r\n };\r\n}\r\n/**\r\n * Helper which returns an IConfigDefaultCheck instance that will validate and convert the user\r\n * provided value to a boolean from a string or boolean value\r\n * @param defaultValue - The default value to apply it not provided or it's not valid\r\n * @param fallBackName - The fallback configuration name if the current value is not available\r\n * @returns a new IConfigDefaultCheck structure\r\n */\r\nexport function cfgDfBoolean(defaultValue, fallBackName) {\r\n return {\r\n fb: fallBackName,\r\n set: _stringToBoolOrDefault,\r\n v: !!defaultValue\r\n };\r\n}\r\n/**\r\n * Helper which returns an IConfigDefaultCheck instance that will validate that the user\r\n * provided value is a function.\r\n * @param defaultValue - The default value to apply it not provided or it's not valid\r\n * @returns a new IConfigDefaultCheck structure\r\n */\r\nexport function cfgDfFunc(defaultValue) {\r\n return {\r\n isVal: isFunction,\r\n v: defaultValue || null\r\n };\r\n}\r\n/**\r\n * Helper which returns an IConfigDefaultCheck instance that will validate that the user\r\n * provided value is a function.\r\n * @param defaultValue - The default string value to apply it not provided or it's not valid, defaults to an empty string\r\n * @returns a new IConfigDefaultCheck structure\r\n */\r\nexport function cfgDfString(defaultValue) {\r\n return {\r\n isVal: isString,\r\n v: asString(defaultValue || STR_EMPTY)\r\n };\r\n}\r\n/**\r\n * Helper which returns an IConfigDefaultCheck instance identifying that value associated with this property\r\n * should not have it's properties converted into a dynamic config properties.\r\n * @param defaultValue - The default value to apply it not provided or it's not valid\r\n * @returns a new IConfigDefaultCheck structure\r\n */\r\nexport function cfgDfBlockPropValue(defaultValue) {\r\n return {\r\n blkVal: true,\r\n v: defaultValue\r\n };\r\n}\r\n//# sourceMappingURL=ConfigDefaultHelpers.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { getInst } from \"@nevware21/ts-utils\";\r\nimport { _DYN_APPLY, _DYN_LENGTH } from \"../__DynamicConstants\";\r\nimport { STR_EVENTS_DISCARDED, STR_EVENTS_SEND_REQUEST, STR_EVENTS_SENT, STR_PERF_EVENT } from \"./InternalConstants\";\r\nvar listenerFuncs = [STR_EVENTS_SENT, STR_EVENTS_DISCARDED, STR_EVENTS_SEND_REQUEST, STR_PERF_EVENT];\r\nvar _aiNamespace = null;\r\nvar _debugListener;\r\nfunction _listenerProxyFunc(name, config) {\r\n return function () {\r\n var args = arguments;\r\n var dbgExt = getDebugExt(config);\r\n if (dbgExt) {\r\n var listener = dbgExt.listener;\r\n if (listener && listener[name]) {\r\n listener[name][_DYN_APPLY /* @min:%2eapply */](listener, args);\r\n }\r\n }\r\n };\r\n}\r\nfunction _getExtensionNamespace() {\r\n // Cache the lookup of the global namespace object\r\n var target = getInst(\"Microsoft\");\r\n if (target) {\r\n _aiNamespace = target[\"ApplicationInsights\"];\r\n }\r\n return _aiNamespace;\r\n}\r\nexport function getDebugExt(config) {\r\n var ns = _aiNamespace;\r\n if (!ns && config.disableDbgExt !== true) {\r\n ns = _aiNamespace || _getExtensionNamespace();\r\n }\r\n return ns ? ns[\"ChromeDbgExt\"] : null;\r\n}\r\nexport function getDebugListener(config) {\r\n if (!_debugListener) {\r\n _debugListener = {};\r\n for (var lp = 0; lp < listenerFuncs[_DYN_LENGTH /* @min:%2elength */]; lp++) {\r\n _debugListener[listenerFuncs[lp]] = _listenerProxyFunc(listenerFuncs[lp], config);\r\n }\r\n }\r\n return _debugListener;\r\n}\r\n//# sourceMappingURL=DbgExtensionUtils.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n\"use strict\";\r\nvar _a;\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { dumpObj, isFunction, isUndefined } from \"@nevware21/ts-utils\";\r\nimport { createDynamicConfig, onConfigChange } from \"../Config/DynamicConfig\";\r\nimport { _DYN_DIAG_LOG, _DYN_LOGGER, _DYN_LOGGING_LEVEL_CONSOL4, _DYN_MESSAGE, _DYN_MESSAGE_ID, _DYN_PUSH, _DYN_REPLACE, _DYN_THROW_INTERNAL, _DYN_UNLOAD, _DYN_WARN_TO_CONSOLE } from \"../__DynamicConstants\";\r\nimport { getDebugExt } from \"./DbgExtensionUtils\";\r\nimport { getConsole, getJSON, hasJSON } from \"./EnvUtils\";\r\nimport { STR_EMPTY } from \"./InternalConstants\";\r\nvar STR_WARN_TO_CONSOLE = \"warnToConsole\";\r\n/**\r\n * For user non actionable traces use AI Internal prefix.\r\n */\r\nvar AiNonUserActionablePrefix = \"AI (Internal): \";\r\n/**\r\n * Prefix of the traces in portal.\r\n */\r\nvar AiUserActionablePrefix = \"AI: \";\r\n/**\r\n * Session storage key for the prefix for the key indicating message type already logged\r\n */\r\nvar AIInternalMessagePrefix = \"AITR_\";\r\nvar defaultValues = {\r\n loggingLevelConsole: 0,\r\n loggingLevelTelemetry: 1,\r\n maxMessageLimit: 25,\r\n enableDebug: false\r\n};\r\nvar _logFuncs = (_a = {},\r\n _a[0 /* eLoggingSeverity.DISABLED */] = null,\r\n _a[1 /* eLoggingSeverity.CRITICAL */] = \"errorToConsole\",\r\n _a[2 /* eLoggingSeverity.WARNING */] = STR_WARN_TO_CONSOLE,\r\n _a[3 /* eLoggingSeverity.DEBUG */] = \"debugToConsole\",\r\n _a);\r\nfunction _sanitizeDiagnosticText(text) {\r\n if (text) {\r\n return \"\\\"\" + text[_DYN_REPLACE /* @min:%2ereplace */](/\\\"/g, STR_EMPTY) + \"\\\"\";\r\n }\r\n return STR_EMPTY;\r\n}\r\nfunction _logToConsole(func, message) {\r\n var theConsole = getConsole();\r\n if (!!theConsole) {\r\n var logFunc = \"log\";\r\n if (theConsole[func]) {\r\n logFunc = func;\r\n }\r\n if (isFunction(theConsole[logFunc])) {\r\n theConsole[logFunc](message);\r\n }\r\n }\r\n}\r\nvar _InternalLogMessage = /** @class */ (function () {\r\n function _InternalLogMessage(msgId, msg, isUserAct, properties) {\r\n if (isUserAct === void 0) { isUserAct = false; }\r\n var _self = this;\r\n _self[_DYN_MESSAGE_ID /* @min:%2emessageId */] = msgId;\r\n _self[_DYN_MESSAGE /* @min:%2emessage */] =\r\n (isUserAct ? AiUserActionablePrefix : AiNonUserActionablePrefix) +\r\n msgId;\r\n var strProps = STR_EMPTY;\r\n if (hasJSON()) {\r\n strProps = getJSON().stringify(properties);\r\n }\r\n var diagnosticText = (msg ? \" message:\" + _sanitizeDiagnosticText(msg) : STR_EMPTY) +\r\n (properties ? \" props:\" + _sanitizeDiagnosticText(strProps) : STR_EMPTY);\r\n _self[_DYN_MESSAGE /* @min:%2emessage */] += diagnosticText;\r\n }\r\n _InternalLogMessage.dataType = \"MessageData\";\r\n return _InternalLogMessage;\r\n}());\r\nexport { _InternalLogMessage };\r\nexport function safeGetLogger(core, config) {\r\n return (core || {})[_DYN_LOGGER /* @min:%2elogger */] || new DiagnosticLogger(config);\r\n}\r\nvar DiagnosticLogger = /** @class */ (function () {\r\n function DiagnosticLogger(config) {\r\n this.identifier = \"DiagnosticLogger\";\r\n /**\r\n * The internal logging queue\r\n */\r\n this.queue = [];\r\n /**\r\n * Count of internal messages sent\r\n */\r\n var _messageCount = 0;\r\n /**\r\n * Holds information about what message types were already logged to console or sent to server.\r\n */\r\n var _messageLogged = {};\r\n var _loggingLevelConsole;\r\n var _loggingLevelTelemetry;\r\n var _maxInternalMessageLimit;\r\n var _enableDebug;\r\n var _unloadHandler;\r\n dynamicProto(DiagnosticLogger, this, function (_self) {\r\n _unloadHandler = _setDefaultsFromConfig(config || {});\r\n _self.consoleLoggingLevel = function () { return _loggingLevelConsole; };\r\n /**\r\n * This method will throw exceptions in debug mode or attempt to log the error as a console warning.\r\n * @param severity - The severity of the log message\r\n * @param message - The log message.\r\n */\r\n _self[_DYN_THROW_INTERNAL /* @min:%2ethrowInternal */] = function (severity, msgId, msg, properties, isUserAct) {\r\n if (isUserAct === void 0) { isUserAct = false; }\r\n var message = new _InternalLogMessage(msgId, msg, isUserAct, properties);\r\n if (_enableDebug) {\r\n throw dumpObj(message);\r\n }\r\n else {\r\n // Get the logging function and fallback to warnToConsole of for some reason errorToConsole doesn't exist\r\n var logFunc = _logFuncs[severity] || STR_WARN_TO_CONSOLE;\r\n if (!isUndefined(message[_DYN_MESSAGE /* @min:%2emessage */])) {\r\n if (isUserAct) {\r\n // check if this message type was already logged to console for this page view and if so, don't log it again\r\n var messageKey = +message[_DYN_MESSAGE_ID /* @min:%2emessageId */];\r\n if (!_messageLogged[messageKey] && _loggingLevelConsole >= severity) {\r\n _self[logFunc](message[_DYN_MESSAGE /* @min:%2emessage */]);\r\n _messageLogged[messageKey] = true;\r\n }\r\n }\r\n else {\r\n // Only log traces if the console Logging Level is >= the throwInternal severity level\r\n if (_loggingLevelConsole >= severity) {\r\n _self[logFunc](message[_DYN_MESSAGE /* @min:%2emessage */]);\r\n }\r\n }\r\n _logInternalMessage(severity, message);\r\n }\r\n else {\r\n _debugExtMsg(\"throw\" + (severity === 1 /* eLoggingSeverity.CRITICAL */ ? \"Critical\" : \"Warning\"), message);\r\n }\r\n }\r\n };\r\n _self.debugToConsole = function (message) {\r\n _logToConsole(\"debug\", message);\r\n _debugExtMsg(\"warning\", message);\r\n };\r\n _self[_DYN_WARN_TO_CONSOLE /* @min:%2ewarnToConsole */] = function (message) {\r\n _logToConsole(\"warn\", message);\r\n _debugExtMsg(\"warning\", message);\r\n };\r\n _self.errorToConsole = function (message) {\r\n _logToConsole(\"error\", message);\r\n _debugExtMsg(\"error\", message);\r\n };\r\n _self.resetInternalMessageCount = function () {\r\n _messageCount = 0;\r\n _messageLogged = {};\r\n };\r\n _self.logInternalMessage = _logInternalMessage;\r\n _self[_DYN_UNLOAD /* @min:%2eunload */] = function (isAsync) {\r\n _unloadHandler && _unloadHandler.rm();\r\n _unloadHandler = null;\r\n };\r\n function _logInternalMessage(severity, message) {\r\n if (_areInternalMessagesThrottled()) {\r\n return;\r\n }\r\n // check if this message type was already logged for this session and if so, don't log it again\r\n var logMessage = true;\r\n var messageKey = AIInternalMessagePrefix + message[_DYN_MESSAGE_ID /* @min:%2emessageId */];\r\n // if the session storage is not available, limit to only one message type per page view\r\n if (_messageLogged[messageKey]) {\r\n logMessage = false;\r\n }\r\n else {\r\n _messageLogged[messageKey] = true;\r\n }\r\n if (logMessage) {\r\n // Push the event in the internal queue\r\n if (severity <= _loggingLevelTelemetry) {\r\n _self.queue[_DYN_PUSH /* @min:%2epush */](message);\r\n _messageCount++;\r\n _debugExtMsg((severity === 1 /* eLoggingSeverity.CRITICAL */ ? \"error\" : \"warn\"), message);\r\n }\r\n // When throttle limit reached, send a special event\r\n if (_messageCount === _maxInternalMessageLimit) {\r\n var throttleLimitMessage = \"Internal events throttle limit per PageView reached for this app.\";\r\n var throttleMessage = new _InternalLogMessage(23 /* _eInternalMessageId.MessageLimitPerPVExceeded */, throttleLimitMessage, false);\r\n _self.queue[_DYN_PUSH /* @min:%2epush */](throttleMessage);\r\n if (severity === 1 /* eLoggingSeverity.CRITICAL */) {\r\n _self.errorToConsole(throttleLimitMessage);\r\n }\r\n else {\r\n _self[_DYN_WARN_TO_CONSOLE /* @min:%2ewarnToConsole */](throttleLimitMessage);\r\n }\r\n }\r\n }\r\n }\r\n function _setDefaultsFromConfig(config) {\r\n // make sure the config is dynamic\r\n return onConfigChange(createDynamicConfig(config, defaultValues, _self).cfg, function (details) {\r\n var config = details.cfg;\r\n _loggingLevelConsole = config[_DYN_LOGGING_LEVEL_CONSOL4 /* @min:%2eloggingLevelConsole */];\r\n _loggingLevelTelemetry = config.loggingLevelTelemetry;\r\n _maxInternalMessageLimit = config.maxMessageLimit;\r\n _enableDebug = config.enableDebug;\r\n });\r\n }\r\n function _areInternalMessagesThrottled() {\r\n return _messageCount >= _maxInternalMessageLimit;\r\n }\r\n function _debugExtMsg(name, data) {\r\n var dbgExt = getDebugExt(config || {});\r\n if (dbgExt && dbgExt[_DYN_DIAG_LOG /* @min:%2ediagLog */]) {\r\n dbgExt[_DYN_DIAG_LOG /* @min:%2ediagLog */](name, data);\r\n }\r\n }\r\n });\r\n }\r\n// Removed Stub for DiagnosticLogger.prototype.consoleLoggingLevel.\r\n// Removed Stub for DiagnosticLogger.prototype.throwInternal.\r\n// Removed Stub for DiagnosticLogger.prototype.debugToConsole.\r\n// Removed Stub for DiagnosticLogger.prototype.warnToConsole.\r\n// Removed Stub for DiagnosticLogger.prototype.errorToConsole.\r\n// Removed Stub for DiagnosticLogger.prototype.resetInternalMessageCount.\r\n// Removed Stub for DiagnosticLogger.prototype.logInternalMessage.\r\n// Removed Stub for DiagnosticLogger.prototype.unload.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n DiagnosticLogger.__ieDyn=1;\n\n return DiagnosticLogger;\r\n}());\r\nexport { DiagnosticLogger };\r\nfunction _getLogger(logger) {\r\n return (logger || new DiagnosticLogger());\r\n}\r\n/**\r\n * This is a helper method which will call throwInternal on the passed logger, will throw exceptions in\r\n * debug mode or attempt to log the error as a console warning. This helper is provided mostly to better\r\n * support minification as logger.throwInternal() will not compress the publish \"throwInternal\" used throughout\r\n * the code.\r\n * @param logger - The Diagnostic Logger instance to use.\r\n * @param severity - The severity of the log message\r\n * @param message - The log message.\r\n */\r\nexport function _throwInternal(logger, severity, msgId, msg, properties, isUserAct) {\r\n if (isUserAct === void 0) { isUserAct = false; }\r\n _getLogger(logger)[_DYN_THROW_INTERNAL /* @min:%2ethrowInternal */](severity, msgId, msg, properties, isUserAct);\r\n}\r\n/**\r\n * This is a helper method which will call warnToConsole on the passed logger with the provided message.\r\n * @param logger - The Diagnostic Logger instance to use.\r\n * @param message - The log message.\r\n */\r\nexport function _warnToConsole(logger, message) {\r\n _getLogger(logger)[_DYN_WARN_TO_CONSOLE /* @min:%2ewarnToConsole */](message);\r\n}\r\n/**\r\n * Logs a message to the internal queue.\r\n * @param logger - The Diagnostic Logger instance to use.\r\n * @param severity - The severity of the log message\r\n * @param message - The message to log.\r\n */\r\nexport function _logInternalMessage(logger, severity, message) {\r\n _getLogger(logger).logInternalMessage(severity, message);\r\n}\r\n//# sourceMappingURL=DiagnosticLogger.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nvar _a, _b;\r\nimport { arrForEach, arrIndexOf, dumpObj, getDocument, getLazy, getNavigator, isArray, isFunction, isNullOrUndefined, isString, isTruthy, isUndefined, objForEachKey, strEndsWith, strIndexOf, strLeft, strSubstring, strTrim, utcNow } from \"@nevware21/ts-utils\";\r\nimport { cfgDfMerge } from \"../Config/ConfigDefaultHelpers\";\r\nimport { createDynamicConfig, onConfigChange } from \"../Config/DynamicConfig\";\r\nimport { _DYN_ENABLED, _DYN_LENGTH, _DYN_LOGGER, _DYN_SPLIT, _DYN_USER_AGENT } from \"../__DynamicConstants\";\r\nimport { _throwInternal } from \"./DiagnosticLogger\";\r\nimport { getLocation, isIE } from \"./EnvUtils\";\r\nimport { getExceptionName, isNotNullOrUndefined, setValue, strContains } from \"./HelperFuncs\";\r\nimport { STR_DOMAIN, STR_EMPTY, STR_PATH, UNDEFINED_VALUE } from \"./InternalConstants\";\r\nvar strToGMTString = \"toGMTString\";\r\nvar strToUTCString = \"toUTCString\";\r\nvar strCookie = \"cookie\";\r\nvar strExpires = \"expires\";\r\nvar strIsCookieUseDisabled = \"isCookieUseDisabled\";\r\nvar strDisableCookiesUsage = \"disableCookiesUsage\";\r\nvar strConfigCookieMgr = \"_ckMgr\";\r\nvar _supportsCookies = null;\r\nvar _allowUaSameSite = null;\r\nvar _parsedCookieValue = null;\r\nvar _doc;\r\nvar _cookieCache = {};\r\nvar _globalCookieConfig = {};\r\n// // `isCookieUseDisabled` is deprecated, so explicitly casting as a key of IConfiguration to avoid typing error\r\n// // when both isCookieUseDisabled and disableCookiesUsage are used disableCookiesUsage will take precedent, which is\r\n// // why its listed first\r\n/**\r\n * Set the supported dynamic config values as undefined (or an empty object) so that\r\n * any listeners will be informed of any changes.\r\n * Explicitly NOT including the deprecated `isCookieUseDisabled` as we don't want to support\r\n * the v1 deprecated field as dynamic for updates\r\n */\r\nvar rootDefaultConfig = (_a = {\r\n cookieCfg: cfgDfMerge((_b = {},\r\n _b[STR_DOMAIN] = { fb: \"cookieDomain\", dfVal: isNotNullOrUndefined },\r\n _b.path = { fb: \"cookiePath\", dfVal: isNotNullOrUndefined },\r\n _b.enabled = UNDEFINED_VALUE,\r\n _b.ignoreCookies = UNDEFINED_VALUE,\r\n _b.blockedCookies = UNDEFINED_VALUE,\r\n _b)),\r\n cookieDomain: UNDEFINED_VALUE,\r\n cookiePath: UNDEFINED_VALUE\r\n },\r\n _a[strDisableCookiesUsage] = UNDEFINED_VALUE,\r\n _a);\r\nfunction _getDoc() {\r\n !_doc && (_doc = getLazy(function () { return getDocument(); }));\r\n}\r\n/**\r\n * @ignore\r\n * DO NOT USE or export from the module, this is exposed as public to support backward compatibility of previous static utility methods only.\r\n * If you want to manager cookies either use the ICookieMgr available from the core instance via getCookieMgr() or create\r\n * your own instance of the CookieMgr and use that.\r\n * Using this directly for enabling / disabling cookie handling will not only affect your usage but EVERY user of cookies.\r\n * Example, if you are using a shared component that is also using Application Insights you will affect their cookie handling.\r\n * @param logger - The DiagnosticLogger to use for reporting errors.\r\n */\r\nfunction _gblCookieMgr(config, logger) {\r\n // Stash the global instance against the BaseCookieMgr class\r\n var inst = createCookieMgr[strConfigCookieMgr] || _globalCookieConfig[strConfigCookieMgr];\r\n if (!inst) {\r\n // Note: not using the getSetValue() helper as that would require always creating a temporary cookieMgr\r\n // that ultimately is never used\r\n inst = createCookieMgr[strConfigCookieMgr] = createCookieMgr(config, logger);\r\n _globalCookieConfig[strConfigCookieMgr] = inst;\r\n }\r\n return inst;\r\n}\r\nfunction _isMgrEnabled(cookieMgr) {\r\n if (cookieMgr) {\r\n return cookieMgr.isEnabled();\r\n }\r\n return true;\r\n}\r\nfunction _isIgnoredCookie(cookieMgrCfg, name) {\r\n if (name && cookieMgrCfg && isArray(cookieMgrCfg.ignoreCookies)) {\r\n return arrIndexOf(cookieMgrCfg.ignoreCookies, name) !== -1;\r\n }\r\n return false;\r\n}\r\nfunction _isBlockedCookie(cookieMgrCfg, name) {\r\n if (name && cookieMgrCfg && isArray(cookieMgrCfg.blockedCookies)) {\r\n if (arrIndexOf(cookieMgrCfg.blockedCookies, name) !== -1) {\r\n return true;\r\n }\r\n }\r\n return _isIgnoredCookie(cookieMgrCfg, name);\r\n}\r\nfunction _isCfgEnabled(rootConfig, cookieMgrConfig) {\r\n var isCfgEnabled = cookieMgrConfig[_DYN_ENABLED /* @min:%2eenabled */];\r\n if (isNullOrUndefined(isCfgEnabled)) {\r\n // Set the enabled from the provided setting or the legacy root values\r\n var cookieEnabled = void 0;\r\n // This field is deprecated and dynamic updates will not be fully supported\r\n if (!isUndefined(rootConfig[strIsCookieUseDisabled])) {\r\n cookieEnabled = !rootConfig[strIsCookieUseDisabled];\r\n }\r\n // If this value is defined it takes precedent over the above\r\n if (!isUndefined(rootConfig[strDisableCookiesUsage])) {\r\n cookieEnabled = !rootConfig[strDisableCookiesUsage];\r\n }\r\n // Not setting the cookieMgrConfig.enabled as that will update (set) the global dynamic config\r\n // So future \"updates\" then may not be as expected\r\n isCfgEnabled = cookieEnabled;\r\n }\r\n return isCfgEnabled;\r\n}\r\n/**\r\n * Helper to return the ICookieMgr from the core (if not null/undefined) or a default implementation\r\n * associated with the configuration or a legacy default.\r\n * @param core - The AppInsightsCore instance to get the cookie manager from\r\n * @param config - The config to use if the core is not available\r\n * @returns\r\n */\r\nexport function safeGetCookieMgr(core, config) {\r\n var cookieMgr;\r\n if (core) {\r\n // Always returns an instance\r\n cookieMgr = core.getCookieMgr();\r\n }\r\n else if (config) {\r\n var cookieCfg = config.cookieCfg;\r\n if (cookieCfg && cookieCfg[strConfigCookieMgr]) {\r\n cookieMgr = cookieCfg[strConfigCookieMgr];\r\n }\r\n else {\r\n cookieMgr = createCookieMgr(config);\r\n }\r\n }\r\n if (!cookieMgr) {\r\n // Get or initialize the default global (legacy) cookie manager if we couldn't find one\r\n cookieMgr = _gblCookieMgr(config, (core || {})[_DYN_LOGGER /* @min:%2elogger */]);\r\n }\r\n return cookieMgr;\r\n}\r\nexport function createCookieMgr(rootConfig, logger) {\r\n var cookieMgrConfig;\r\n var _path;\r\n var _domain;\r\n var unloadHandler;\r\n // Explicitly checking against false, so that setting to undefined will === true\r\n var _enabled;\r\n var _getCookieFn;\r\n var _setCookieFn;\r\n var _delCookieFn;\r\n // Make sure the root config is dynamic as it may be the global config\r\n rootConfig = createDynamicConfig(rootConfig || _globalCookieConfig, null, logger).cfg;\r\n // Will get recalled if the referenced configuration is changed\r\n unloadHandler = onConfigChange(rootConfig, function (details) {\r\n // Make sure the root config has all of the the defaults to the root config to ensure they are dynamic\r\n details.setDf(details.cfg, rootDefaultConfig);\r\n // Create and apply the defaults to the cookieCfg element\r\n cookieMgrConfig = details.ref(details.cfg, \"cookieCfg\"); // details.setDf(details.cfg.cookieCfg, defaultConfig);\r\n _path = cookieMgrConfig[STR_PATH /* @min:%2epath */] || \"/\";\r\n _domain = cookieMgrConfig[STR_DOMAIN /* @min:%2edomain */];\r\n // Explicitly checking against false, so that setting to undefined will === true\r\n _enabled = _isCfgEnabled(rootConfig, cookieMgrConfig) !== false;\r\n _getCookieFn = cookieMgrConfig.getCookie || _getCookieValue;\r\n _setCookieFn = cookieMgrConfig.setCookie || _setCookieValue;\r\n _delCookieFn = cookieMgrConfig.delCookie || _setCookieValue;\r\n }, logger);\r\n var cookieMgr = {\r\n isEnabled: function () {\r\n var enabled = _isCfgEnabled(rootConfig, cookieMgrConfig) !== false && _enabled && areCookiesSupported(logger);\r\n // Using an indirect lookup for any global cookie manager to support tree shaking for SDK's\r\n // that don't use the \"applicationinsights-core\" version of the default cookie function\r\n var gblManager = _globalCookieConfig[strConfigCookieMgr];\r\n if (enabled && gblManager && cookieMgr !== gblManager) {\r\n // Make sure the GlobalCookie Manager instance (if not this instance) is also enabled.\r\n // As the global (deprecated) functions may have been called (for backward compatibility)\r\n enabled = _isMgrEnabled(gblManager);\r\n }\r\n return enabled;\r\n },\r\n setEnabled: function (value) {\r\n // Explicitly checking against false, so that setting to undefined will === true\r\n _enabled = value !== false;\r\n cookieMgrConfig[_DYN_ENABLED /* @min:%2eenabled */] = value;\r\n },\r\n set: function (name, value, maxAgeSec, domain, path) {\r\n var result = false;\r\n if (_isMgrEnabled(cookieMgr) && !_isBlockedCookie(cookieMgrConfig, name)) {\r\n var values = {};\r\n var theValue = strTrim(value || STR_EMPTY);\r\n var idx = strIndexOf(theValue, \";\");\r\n if (idx !== -1) {\r\n theValue = strTrim(strLeft(value, idx));\r\n values = _extractParts(strSubstring(value, idx + 1));\r\n }\r\n // Only update domain if not already present (isUndefined) and the value is truthy (not null, undefined or empty string)\r\n setValue(values, STR_DOMAIN, domain || _domain, isTruthy, isUndefined);\r\n if (!isNullOrUndefined(maxAgeSec)) {\r\n var _isIE = isIE();\r\n if (isUndefined(values[strExpires])) {\r\n var nowMs = utcNow();\r\n // Only add expires if not already present\r\n var expireMs = nowMs + (maxAgeSec * 1000);\r\n // Sanity check, if zero or -ve then ignore\r\n if (expireMs > 0) {\r\n var expiry = new Date();\r\n expiry.setTime(expireMs);\r\n setValue(values, strExpires, _formatDate(expiry, !_isIE ? strToUTCString : strToGMTString) || _formatDate(expiry, _isIE ? strToGMTString : strToUTCString) || STR_EMPTY, isTruthy);\r\n }\r\n }\r\n if (!_isIE) {\r\n // Only replace if not already present\r\n setValue(values, \"max-age\", STR_EMPTY + maxAgeSec, null, isUndefined);\r\n }\r\n }\r\n var location_1 = getLocation();\r\n if (location_1 && location_1.protocol === \"https:\") {\r\n setValue(values, \"secure\", null, null, isUndefined);\r\n // Only set same site if not also secure\r\n if (_allowUaSameSite === null) {\r\n _allowUaSameSite = !uaDisallowsSameSiteNone((getNavigator() || {})[_DYN_USER_AGENT /* @min:%2euserAgent */]);\r\n }\r\n if (_allowUaSameSite) {\r\n setValue(values, \"SameSite\", \"None\", null, isUndefined);\r\n }\r\n }\r\n setValue(values, STR_PATH, path || _path, null, isUndefined);\r\n //let setCookieFn = cookieMgrConfig.setCookie || _setCookieValue;\r\n _setCookieFn(name, _formatCookieValue(theValue, values));\r\n result = true;\r\n }\r\n return result;\r\n },\r\n get: function (name) {\r\n var value = STR_EMPTY;\r\n if (_isMgrEnabled(cookieMgr) && !_isIgnoredCookie(cookieMgrConfig, name)) {\r\n value = _getCookieFn(name);\r\n }\r\n return value;\r\n },\r\n del: function (name, path) {\r\n var result = false;\r\n if (_isMgrEnabled(cookieMgr)) {\r\n // Only remove the cookie if the manager and cookie support has not been disabled\r\n result = cookieMgr.purge(name, path);\r\n }\r\n return result;\r\n },\r\n purge: function (name, path) {\r\n var _a;\r\n var result = false;\r\n if (areCookiesSupported(logger)) {\r\n // Setting the expiration date in the past immediately removes the cookie\r\n var values = (_a = {},\r\n _a[STR_PATH] = path ? path : \"/\",\r\n _a[strExpires] = \"Thu, 01 Jan 1970 00:00:01 GMT\",\r\n _a);\r\n if (!isIE()) {\r\n // Set max age to expire now\r\n values[\"max-age\"] = \"0\";\r\n }\r\n // let delCookie = cookieMgrConfig.delCookie || _setCookieValue;\r\n _delCookieFn(name, _formatCookieValue(STR_EMPTY, values));\r\n result = true;\r\n }\r\n return result;\r\n },\r\n unload: function (isAsync) {\r\n unloadHandler && unloadHandler.rm();\r\n unloadHandler = null;\r\n }\r\n };\r\n // Associated this cookie manager with the config\r\n cookieMgr[strConfigCookieMgr] = cookieMgr;\r\n return cookieMgr;\r\n}\r\n/*\r\n* Helper method to tell if document.cookie object is supported by the runtime\r\n*/\r\nexport function areCookiesSupported(logger) {\r\n if (_supportsCookies === null) {\r\n _supportsCookies = false;\r\n !_doc && _getDoc();\r\n try {\r\n var doc = _doc.v || {};\r\n _supportsCookies = doc[strCookie] !== undefined;\r\n }\r\n catch (e) {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 68 /* _eInternalMessageId.CannotAccessCookie */, \"Cannot access document.cookie - \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return _supportsCookies;\r\n}\r\nfunction _extractParts(theValue) {\r\n var values = {};\r\n if (theValue && theValue[_DYN_LENGTH /* @min:%2elength */]) {\r\n var parts = strTrim(theValue)[_DYN_SPLIT /* @min:%2esplit */](\";\");\r\n arrForEach(parts, function (thePart) {\r\n thePart = strTrim(thePart || STR_EMPTY);\r\n if (thePart) {\r\n var idx = strIndexOf(thePart, \"=\");\r\n if (idx === -1) {\r\n values[thePart] = null;\r\n }\r\n else {\r\n values[strTrim(strLeft(thePart, idx))] = strTrim(strSubstring(thePart, idx + 1));\r\n }\r\n }\r\n });\r\n }\r\n return values;\r\n}\r\nfunction _formatDate(theDate, func) {\r\n if (isFunction(theDate[func])) {\r\n return theDate[func]();\r\n }\r\n return null;\r\n}\r\nfunction _formatCookieValue(value, values) {\r\n var cookieValue = value || STR_EMPTY;\r\n objForEachKey(values, function (name, theValue) {\r\n cookieValue += \"; \" + name + (!isNullOrUndefined(theValue) ? \"=\" + theValue : STR_EMPTY);\r\n });\r\n return cookieValue;\r\n}\r\nfunction _getCookieValue(name) {\r\n var cookieValue = STR_EMPTY;\r\n !_doc && _getDoc();\r\n if (_doc.v) {\r\n var theCookie = _doc.v[strCookie] || STR_EMPTY;\r\n if (_parsedCookieValue !== theCookie) {\r\n _cookieCache = _extractParts(theCookie);\r\n _parsedCookieValue = theCookie;\r\n }\r\n cookieValue = strTrim(_cookieCache[name] || STR_EMPTY);\r\n }\r\n return cookieValue;\r\n}\r\nfunction _setCookieValue(name, cookieValue) {\r\n !_doc && _getDoc();\r\n if (_doc.v) {\r\n _doc.v[strCookie] = name + \"=\" + cookieValue;\r\n }\r\n}\r\nexport function uaDisallowsSameSiteNone(userAgent) {\r\n if (!isString(userAgent)) {\r\n return false;\r\n }\r\n // Cover all iOS based browsers here. This includes:\r\n // - Safari on iOS 12 for iPhone, iPod Touch, iPad\r\n // - WkWebview on iOS 12 for iPhone, iPod Touch, iPad\r\n // - Chrome on iOS 12 for iPhone, iPod Touch, iPad\r\n // All of which are broken by SameSite=None, because they use the iOS networking stack\r\n if (strContains(userAgent, \"CPU iPhone OS 12\") || strContains(userAgent, \"iPad; CPU OS 12\")) {\r\n return true;\r\n }\r\n // Cover Mac OS X based browsers that use the Mac OS networking stack. This includes:\r\n // - Safari on Mac OS X\r\n // This does not include:\r\n // - Internal browser on Mac OS X\r\n // - Chrome on Mac OS X\r\n // - Chromium on Mac OS X\r\n // Because they do not use the Mac OS networking stack.\r\n if (strContains(userAgent, \"Macintosh; Intel Mac OS X 10_14\") && strContains(userAgent, \"Version/\") && strContains(userAgent, \"Safari\")) {\r\n return true;\r\n }\r\n // Cover Mac OS X internal browsers that use the Mac OS networking stack. This includes:\r\n // - Internal browser on Mac OS X\r\n // This does not include:\r\n // - Safari on Mac OS X\r\n // - Chrome on Mac OS X\r\n // - Chromium on Mac OS X\r\n // Because they do not use the Mac OS networking stack.\r\n if (strContains(userAgent, \"Macintosh; Intel Mac OS X 10_14\") && strEndsWith(userAgent, \"AppleWebKit/605.1.15 (KHTML, like Gecko)\")) {\r\n return true;\r\n }\r\n // Cover Chrome 50-69, because some versions are broken by SameSite=None, and none in this range require it.\r\n // Note: this covers some pre-Chromium Edge versions, but pre-Chromim Edge does not require SameSite=None, so this is fine.\r\n // Note: this regex applies to Windows, Mac OS X, and Linux, deliberately.\r\n if (strContains(userAgent, \"Chrome/5\") || strContains(userAgent, \"Chrome/6\")) {\r\n return true;\r\n }\r\n // Unreal Engine runs Chromium 59, but does not advertise as Chrome until 4.23. Treat versions of Unreal\r\n // that don't specify their Chrome version as lacking support for SameSite=None.\r\n if (strContains(userAgent, \"UnrealEngine\") && !strContains(userAgent, \"Chrome\")) {\r\n return true;\r\n }\r\n // UCBrowser < 12.13.2 ignores Set-Cookie headers with SameSite=None\r\n // NB: this rule isn't complete - you need regex to make a complete rule.\r\n // See: https://www.chromium.org/updates/same-site/incompatible-clients\r\n if (strContains(userAgent, \"UCBrowser/12\") || strContains(userAgent, \"UCBrowser/11\")) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n//# sourceMappingURL=CookieMgr.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { createAllPromise, createPromise, doAwaitResponse } from \"@nevware21/ts-async\";\r\nimport { arrForEach, arrIndexOf, objDefine, safe, scheduleTimeout } from \"@nevware21/ts-utils\";\r\nimport { createDynamicConfig } from \"../Config/DynamicConfig\";\r\nimport { _DYN_ADD_NOTIFICATION_LIS1, _DYN_CANCEL, _DYN_DATA, _DYN_IS_CHILD_EVT, _DYN_LENGTH, _DYN_PUSH, _DYN_REMOVE_NOTIFICATION_0, _DYN_SPLICE, _DYN_UNLOAD, _DYN_WATCH } from \"../__DynamicConstants\";\r\nimport { STR_EVENTS_DISCARDED, STR_EVENTS_SEND_REQUEST, STR_EVENTS_SENT, STR_OFFLINE_DROP, STR_OFFLINE_SENT, STR_OFFLINE_STORE, STR_PERF_EVENT } from \"./InternalConstants\";\r\nvar defaultValues = {\r\n perfEvtsSendAll: false\r\n};\r\nfunction _runScheduledListeners(asyncNotifications) {\r\n asyncNotifications.h = null;\r\n var callbacks = asyncNotifications.cb;\r\n asyncNotifications.cb = [];\r\n arrForEach(callbacks, function (cb) {\r\n // Run the listener in a try-catch to ensure that a single listener failing doesn't prevent the others from running\r\n safe(cb.fn, [cb.arg]);\r\n });\r\n}\r\n// This function is used to combine the logic of running the listeners and handling the async notifications so that they don't\r\n// create multiple timers if there are multiple async listeners.\r\nfunction _runListeners(listeners, name, asyncNotifications, callback) {\r\n arrForEach(listeners, function (listener) {\r\n if (listener && listener[name]) {\r\n if (asyncNotifications) {\r\n // Schedule the callback to be called after the current call stack has cleared.\r\n asyncNotifications.cb[_DYN_PUSH /* @min:%2epush */]({\r\n fn: callback,\r\n arg: listener\r\n });\r\n asyncNotifications.h = asyncNotifications.h || scheduleTimeout(_runScheduledListeners, 0, asyncNotifications);\r\n }\r\n else {\r\n // Run the listener in a try-catch to ensure that a single listener failing doesn't prevent the others from running\r\n safe(callback, [listener]);\r\n }\r\n }\r\n });\r\n}\r\n/**\r\n * Class to manage sending notifications to all the listeners.\r\n */\r\nvar NotificationManager = /** @class */ (function () {\r\n function NotificationManager(config) {\r\n this.listeners = [];\r\n var perfEvtsSendAll;\r\n var unloadHandler;\r\n var _listeners = [];\r\n var _asyncNotifications = {\r\n h: null,\r\n cb: []\r\n };\r\n var cfgHandler = createDynamicConfig(config, defaultValues);\r\n unloadHandler = cfgHandler[_DYN_WATCH /* @min:%2ewatch */](function (details) {\r\n perfEvtsSendAll = !!details.cfg.perfEvtsSendAll;\r\n });\r\n dynamicProto(NotificationManager, this, function (_self) {\r\n objDefine(_self, \"listeners\", {\r\n g: function () { return _listeners; }\r\n });\r\n _self[_DYN_ADD_NOTIFICATION_LIS1 /* @min:%2eaddNotificationListener */] = function (listener) {\r\n _listeners[_DYN_PUSH /* @min:%2epush */](listener);\r\n };\r\n /**\r\n * Removes all instances of the listener.\r\n * @param listener - AWTNotificationListener to remove.\r\n */\r\n _self[_DYN_REMOVE_NOTIFICATION_0 /* @min:%2eremoveNotificationListener */] = function (listener) {\r\n var index = arrIndexOf(_listeners, listener);\r\n while (index > -1) {\r\n _listeners[_DYN_SPLICE /* @min:%2esplice */](index, 1);\r\n index = arrIndexOf(_listeners, listener);\r\n }\r\n };\r\n /**\r\n * Notification for events sent.\r\n * @param events - The array of events that have been sent.\r\n */\r\n _self[STR_EVENTS_SENT /* @min:%2eeventsSent */] = function (events) {\r\n _runListeners(_listeners, STR_EVENTS_SENT, _asyncNotifications, function (listener) {\r\n listener[STR_EVENTS_SENT /* @min:%2eeventsSent */](events);\r\n });\r\n };\r\n /**\r\n * Notification for events being discarded.\r\n * @param events - The array of events that have been discarded by the SDK.\r\n * @param reason - The reason for which the SDK discarded the events. The EventsDiscardedReason\r\n * constant should be used to check the different values.\r\n */\r\n _self[STR_EVENTS_DISCARDED /* @min:%2eeventsDiscarded */] = function (events, reason) {\r\n _runListeners(_listeners, STR_EVENTS_DISCARDED, _asyncNotifications, function (listener) {\r\n listener[STR_EVENTS_DISCARDED /* @min:%2eeventsDiscarded */](events, reason);\r\n });\r\n };\r\n /**\r\n * [Optional] A function called when the events have been requested to be sent to the sever.\r\n * @param sendReason - The reason why the event batch is being sent.\r\n * @param isAsync - A flag which identifies whether the requests are being sent in an async or sync manner.\r\n */\r\n _self[STR_EVENTS_SEND_REQUEST /* @min:%2eeventsSendRequest */] = function (sendReason, isAsync) {\r\n _runListeners(_listeners, STR_EVENTS_SEND_REQUEST, isAsync ? _asyncNotifications : null, function (listener) {\r\n listener[STR_EVENTS_SEND_REQUEST /* @min:%2eeventsSendRequest */](sendReason, isAsync);\r\n });\r\n };\r\n _self[STR_PERF_EVENT /* @min:%2eperfEvent */] = function (perfEvent) {\r\n if (perfEvent) {\r\n // Send all events or only parent events\r\n if (perfEvtsSendAll || !perfEvent[_DYN_IS_CHILD_EVT /* @min:%2eisChildEvt */]()) {\r\n _runListeners(_listeners, STR_PERF_EVENT, null, function (listener) {\r\n if (perfEvent.isAsync) {\r\n scheduleTimeout(function () { return listener[STR_PERF_EVENT /* @min:%2eperfEvent */](perfEvent); }, 0);\r\n }\r\n else {\r\n listener[STR_PERF_EVENT /* @min:%2eperfEvent */](perfEvent);\r\n }\r\n });\r\n }\r\n }\r\n };\r\n _self[STR_OFFLINE_STORE /* @min:%2eofflineEventsStored */] = function (events) {\r\n if (events && events[_DYN_LENGTH /* @min:%2elength */]) {\r\n _runListeners(_listeners, STR_OFFLINE_STORE, _asyncNotifications, function (listener) {\r\n listener[STR_OFFLINE_STORE /* @min:%2eofflineEventsStored */](events);\r\n });\r\n }\r\n };\r\n _self[STR_OFFLINE_SENT /* @min:%2eofflineBatchSent */] = function (batch) {\r\n if (batch && batch[_DYN_DATA /* @min:%2edata */]) {\r\n _runListeners(_listeners, STR_OFFLINE_SENT, _asyncNotifications, function (listener) {\r\n listener[STR_OFFLINE_SENT /* @min:%2eofflineBatchSent */](batch);\r\n });\r\n }\r\n };\r\n _self[STR_OFFLINE_DROP /* @min:%2eofflineBatchDrop */] = function (cnt, reason) {\r\n if (cnt > 0) {\r\n var rn_1 = reason || 0; // default is unknown\r\n _runListeners(_listeners, STR_OFFLINE_DROP, _asyncNotifications, function (listener) {\r\n listener[STR_OFFLINE_DROP /* @min:%2eofflineBatchDrop */](cnt, rn_1);\r\n });\r\n }\r\n };\r\n _self[_DYN_UNLOAD /* @min:%2eunload */] = function (isAsync) {\r\n var _finishUnload = function () {\r\n unloadHandler && unloadHandler.rm();\r\n unloadHandler = null;\r\n _listeners = [];\r\n // Clear any async listener\r\n _asyncNotifications.h && _asyncNotifications.h[_DYN_CANCEL /* @min:%2ecancel */]();\r\n _asyncNotifications.h = null;\r\n _asyncNotifications.cb = [];\r\n };\r\n var waiting;\r\n _runListeners(_listeners, \"unload\", null, function (listener) {\r\n var asyncUnload = listener[_DYN_UNLOAD /* @min:%2eunload */](isAsync);\r\n if (asyncUnload) {\r\n if (!waiting) {\r\n waiting = [];\r\n }\r\n waiting[_DYN_PUSH /* @min:%2epush */](asyncUnload);\r\n }\r\n });\r\n if (waiting) {\r\n return createPromise(function (resolve) {\r\n return doAwaitResponse(createAllPromise(waiting), function () {\r\n _finishUnload();\r\n resolve();\r\n });\r\n });\r\n }\r\n else {\r\n _finishUnload();\r\n }\r\n };\r\n });\r\n }\r\n// Removed Stub for NotificationManager.prototype.addNotificationListener.\r\n// Removed Stub for NotificationManager.prototype.removeNotificationListener.\r\n// Removed Stub for NotificationManager.prototype.eventsSent.\r\n// Removed Stub for NotificationManager.prototype.eventsDiscarded.\r\n// Removed Stub for NotificationManager.prototype.eventsSendRequest.\r\n// Removed Stub for NotificationManager.prototype.perfEvent.\r\n// Removed Stub for NotificationManager.prototype.unload.\r\n// Removed Stub for NotificationManager.prototype.offlineEventsStored.\r\n// Removed Stub for NotificationManager.prototype.offlineBatchSent.\r\n// Removed Stub for NotificationManager.prototype.offlineBatchDrop.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n NotificationManager.__ieDyn=1;\n\n return NotificationManager;\r\n}());\r\nexport { NotificationManager };\r\n//# sourceMappingURL=NotificationManager.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { isArray, isFunction, objDefine, utcNow } from \"@nevware21/ts-utils\";\r\nimport { _DYN_GET_CTX, _DYN_IS_CHILD_EVT, _DYN_LENGTH, _DYN_NAME, _DYN_PUSH, _DYN_SET_CTX } from \"../__DynamicConstants\";\r\nimport { STR_GET_PERF_MGR, STR_PERF_EVENT } from \"./InternalConstants\";\r\nvar strExecutionContextKey = \"ctx\";\r\nvar strParentContextKey = \"ParentContextKey\";\r\nvar strChildrenContextKey = \"ChildrenContextKey\";\r\nvar _defaultPerfManager = null;\r\nvar PerfEvent = /** @class */ (function () {\r\n function PerfEvent(name, payloadDetails, isAsync) {\r\n var _self = this;\r\n _self.start = utcNow();\r\n _self[_DYN_NAME /* @min:%2ename */] = name;\r\n _self.isAsync = isAsync;\r\n _self[_DYN_IS_CHILD_EVT /* @min:%2eisChildEvt */] = function () { return false; };\r\n if (isFunction(payloadDetails)) {\r\n // Create an accessor to minimize the potential performance impact of executing the payloadDetails callback\r\n var theDetails_1;\r\n objDefine(_self, \"payload\", {\r\n g: function () {\r\n // Delay the execution of the payloadDetails until needed\r\n if (!theDetails_1 && isFunction(payloadDetails)) {\r\n theDetails_1 = payloadDetails();\r\n // clear it out now so the referenced objects can be garbage collected\r\n payloadDetails = null;\r\n }\r\n return theDetails_1;\r\n }\r\n });\r\n }\r\n _self[_DYN_GET_CTX /* @min:%2egetCtx */] = function (key) {\r\n if (key) {\r\n // The parent and child links are located directly on the object (for better viewing in the DebugPlugin)\r\n if (key === PerfEvent[strParentContextKey] || key === PerfEvent[strChildrenContextKey]) {\r\n return _self[key];\r\n }\r\n return (_self[strExecutionContextKey] || {})[key];\r\n }\r\n return null;\r\n };\r\n _self[_DYN_SET_CTX /* @min:%2esetCtx */] = function (key, value) {\r\n if (key) {\r\n // Put the parent and child links directly on the object (for better viewing in the DebugPlugin)\r\n if (key === PerfEvent[strParentContextKey]) {\r\n // Simple assumption, if we are setting a parent then we must be a child\r\n if (!_self[key]) {\r\n _self[_DYN_IS_CHILD_EVT /* @min:%2eisChildEvt */] = function () { return true; };\r\n }\r\n _self[key] = value;\r\n }\r\n else if (key === PerfEvent[strChildrenContextKey]) {\r\n _self[key] = value;\r\n }\r\n else {\r\n var ctx = _self[strExecutionContextKey] = _self[strExecutionContextKey] || {};\r\n ctx[key] = value;\r\n }\r\n }\r\n };\r\n _self.complete = function () {\r\n var childTime = 0;\r\n var childEvts = _self[_DYN_GET_CTX /* @min:%2egetCtx */](PerfEvent[strChildrenContextKey]);\r\n if (isArray(childEvts)) {\r\n for (var lp = 0; lp < childEvts[_DYN_LENGTH /* @min:%2elength */]; lp++) {\r\n var childEvt = childEvts[lp];\r\n if (childEvt) {\r\n childTime += childEvt.time;\r\n }\r\n }\r\n }\r\n _self.time = utcNow() - _self.start;\r\n _self.exTime = _self.time - childTime;\r\n _self.complete = function () { };\r\n };\r\n }\r\n PerfEvent.ParentContextKey = \"parent\";\r\n PerfEvent.ChildrenContextKey = \"childEvts\";\r\n return PerfEvent;\r\n}());\r\nexport { PerfEvent };\r\nvar PerfManager = /** @class */ (function () {\r\n function PerfManager(manager) {\r\n /**\r\n * General bucket used for execution context set and retrieved via setCtx() and getCtx.\r\n * Defined as private so it can be visualized via the DebugPlugin\r\n */\r\n this.ctx = {};\r\n dynamicProto(PerfManager, this, function (_self) {\r\n _self.create = function (src, payloadDetails, isAsync) {\r\n // TODO (@MSNev): at some point we will want to add additional configuration to \"select\" which events to instrument\r\n // for now this is just a simple do everything.\r\n return new PerfEvent(src, payloadDetails, isAsync);\r\n };\r\n _self.fire = function (perfEvent) {\r\n if (perfEvent) {\r\n perfEvent.complete();\r\n if (manager && isFunction(manager[STR_PERF_EVENT /* @min:%2eperfEvent */])) {\r\n manager[STR_PERF_EVENT /* @min:%2eperfEvent */](perfEvent);\r\n }\r\n }\r\n };\r\n _self[_DYN_SET_CTX /* @min:%2esetCtx */] = function (key, value) {\r\n if (key) {\r\n var ctx = _self[strExecutionContextKey] = _self[strExecutionContextKey] || {};\r\n ctx[key] = value;\r\n }\r\n };\r\n _self[_DYN_GET_CTX /* @min:%2egetCtx */] = function (key) {\r\n return (_self[strExecutionContextKey] || {})[key];\r\n };\r\n });\r\n }\r\n// Removed Stub for PerfManager.prototype.create.\r\n// Removed Stub for PerfManager.prototype.fire.\r\n// Removed Stub for PerfManager.prototype.setCtx.\r\n// Removed Stub for PerfManager.prototype.getCtx.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n PerfManager.__ieDyn=1;\n\n return PerfManager;\r\n}());\r\nexport { PerfManager };\r\nvar doPerfActiveKey = \"CoreUtils.doPerf\";\r\n/**\r\n * Helper function to wrap a function with a perf event\r\n * @param mgrSource - The Performance Manager or a Performance provider source (may be null)\r\n * @param getSource - The callback to create the source name for the event (if perf monitoring is enabled)\r\n * @param func - The function to call and measure\r\n * @param details - A function to return the payload details\r\n * @param isAsync - Is the event / function being call asynchronously or synchronously\r\n */\r\nexport function doPerf(mgrSource, getSource, func, details, isAsync) {\r\n if (mgrSource) {\r\n var perfMgr = mgrSource;\r\n if (perfMgr[STR_GET_PERF_MGR]) {\r\n // Looks like a perf manager provider object\r\n perfMgr = perfMgr[STR_GET_PERF_MGR]();\r\n }\r\n if (perfMgr) {\r\n var perfEvt = void 0;\r\n var currentActive = perfMgr[_DYN_GET_CTX /* @min:%2egetCtx */](doPerfActiveKey);\r\n try {\r\n perfEvt = perfMgr.create(getSource(), details, isAsync);\r\n if (perfEvt) {\r\n if (currentActive && perfEvt[_DYN_SET_CTX /* @min:%2esetCtx */]) {\r\n perfEvt[_DYN_SET_CTX /* @min:%2esetCtx */](PerfEvent[strParentContextKey], currentActive);\r\n if (currentActive[_DYN_GET_CTX /* @min:%2egetCtx */] && currentActive[_DYN_SET_CTX /* @min:%2esetCtx */]) {\r\n var children = currentActive[_DYN_GET_CTX /* @min:%2egetCtx */](PerfEvent[strChildrenContextKey]);\r\n if (!children) {\r\n children = [];\r\n currentActive[_DYN_SET_CTX /* @min:%2esetCtx */](PerfEvent[strChildrenContextKey], children);\r\n }\r\n children[_DYN_PUSH /* @min:%2epush */](perfEvt);\r\n }\r\n }\r\n // Set this event as the active event now\r\n perfMgr[_DYN_SET_CTX /* @min:%2esetCtx */](doPerfActiveKey, perfEvt);\r\n return func(perfEvt);\r\n }\r\n }\r\n catch (ex) {\r\n if (perfEvt && perfEvt[_DYN_SET_CTX /* @min:%2esetCtx */]) {\r\n perfEvt[_DYN_SET_CTX /* @min:%2esetCtx */](\"exception\", ex);\r\n }\r\n }\r\n finally {\r\n // fire the perf event\r\n if (perfEvt) {\r\n perfMgr.fire(perfEvt);\r\n }\r\n // Reset the active event to the previous value\r\n perfMgr[_DYN_SET_CTX /* @min:%2esetCtx */](doPerfActiveKey, currentActive);\r\n }\r\n }\r\n }\r\n return func();\r\n}\r\n/**\r\n * Set the global performance manager to use when there is no core instance or it has not been initialized yet.\r\n * @param perfManager - The IPerfManager instance to use when no performance manager is supplied.\r\n */\r\nexport function setGblPerfMgr(perfManager) {\r\n _defaultPerfManager = perfManager;\r\n}\r\n/**\r\n * Get the current global performance manager that will be used with no performance manager is supplied.\r\n * @returns - The current default manager\r\n */\r\nexport function getGblPerfMgr() {\r\n return _defaultPerfManager;\r\n}\r\n//# sourceMappingURL=PerfManager.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n\"use strict\";\r\nimport { strShimUndefined } from \"@microsoft/applicationinsights-shims\";\r\nimport { strSubstr, strSubstring } from \"@nevware21/ts-utils\";\r\nimport { _DYN_LENGTH } from \"../__DynamicConstants\";\r\nimport { STR_EMPTY } from \"./InternalConstants\";\r\nimport { random32 } from \"./RandomHelper\";\r\n// Added to help with minfication\r\nexport var Undefined = strShimUndefined;\r\nexport function newGuid() {\r\n var uuid = generateW3CId();\r\n return strSubstring(uuid, 0, 8) + \"-\" + strSubstring(uuid, 8, 12) + \"-\" + strSubstring(uuid, 12, 16) + \"-\" + strSubstring(uuid, 16, 20) + \"-\" + strSubstring(uuid, 20);\r\n}\r\n/**\r\n * The strEndsWith() method determines whether a string ends with the characters of a specified string, returning true or false as appropriate.\r\n * @param value - The value to check whether it ends with the search value.\r\n * @param search - The characters to be searched for at the end of the value.\r\n * @returns true if the given search value is found at the end of the string, otherwise false.\r\n */\r\nexport function strEndsWith(value, search) {\r\n if (value && search) {\r\n var len = value[_DYN_LENGTH /* @min:%2elength */];\r\n var start = len - search[_DYN_LENGTH /* @min:%2elength */];\r\n return strSubstring(value, start >= 0 ? start : 0, len) === search;\r\n }\r\n return false;\r\n}\r\n/**\r\n * generate W3C trace id\r\n */\r\nexport function generateW3CId() {\r\n var hexValues = [\"0\", \"1\", \"2\", \"3\", \"4\", \"5\", \"6\", \"7\", \"8\", \"9\", \"a\", \"b\", \"c\", \"d\", \"e\", \"f\"];\r\n // rfc4122 version 4 UUID without dashes and with lowercase letters\r\n var oct = STR_EMPTY, tmp;\r\n for (var a = 0; a < 4; a++) {\r\n tmp = random32();\r\n oct +=\r\n hexValues[tmp & 0xF] +\r\n hexValues[tmp >> 4 & 0xF] +\r\n hexValues[tmp >> 8 & 0xF] +\r\n hexValues[tmp >> 12 & 0xF] +\r\n hexValues[tmp >> 16 & 0xF] +\r\n hexValues[tmp >> 20 & 0xF] +\r\n hexValues[tmp >> 24 & 0xF] +\r\n hexValues[tmp >> 28 & 0xF];\r\n }\r\n // \"Set the two most significant bits (bits 6 and 7) of the clock_seq_hi_and_reserved to zero and one, respectively\"\r\n var clockSequenceHi = hexValues[8 + (random32() & 0x03) | 0];\r\n return strSubstr(oct, 0, 8) + strSubstr(oct, 9, 4) + \"4\" + strSubstr(oct, 13, 3) + clockSequenceHi + strSubstr(oct, 16, 3) + strSubstr(oct, 19, 12);\r\n}\r\n//# sourceMappingURL=CoreUtils.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { arrForEach, isArray, isString, strLeft, strTrim } from \"@nevware21/ts-utils\";\r\nimport { _DYN_GET_ATTRIBUTE, _DYN_LENGTH, _DYN_PUSH, _DYN_SPLIT, _DYN_TO_LOWER_CASE, _DYN_TRACE_FLAGS, _DYN_VERSION } from \"../__DynamicConstants\";\r\nimport { generateW3CId } from \"./CoreUtils\";\r\nimport { findMetaTag, findNamedServerTiming } from \"./EnvUtils\";\r\nimport { STR_EMPTY } from \"./InternalConstants\";\r\n// using {0,16} for leading and trailing whitespace just to constrain the possible runtime of a random string\r\nvar TRACE_PARENT_REGEX = /^([\\da-f]{2})-([\\da-f]{32})-([\\da-f]{16})-([\\da-f]{2})(-[^\\s]{1,64})?$/i;\r\nvar DEFAULT_VERSION = \"00\";\r\nvar INVALID_VERSION = \"ff\";\r\nvar INVALID_TRACE_ID = \"00000000000000000000000000000000\";\r\nvar INVALID_SPAN_ID = \"0000000000000000\";\r\nvar SAMPLED_FLAG = 0x01;\r\nfunction _isValid(value, len, invalidValue) {\r\n if (value && value[_DYN_LENGTH /* @min:%2elength */] === len && value !== invalidValue) {\r\n return !!value.match(/^[\\da-f]*$/i);\r\n }\r\n return false;\r\n}\r\nfunction _formatValue(value, len, defValue) {\r\n if (_isValid(value, len)) {\r\n return value;\r\n }\r\n return defValue;\r\n}\r\nfunction _formatFlags(value) {\r\n if (isNaN(value) || value < 0 || value > 255) {\r\n value = 0x01;\r\n }\r\n var result = value.toString(16);\r\n while (result[_DYN_LENGTH /* @min:%2elength */] < 2) {\r\n result = \"0\" + result;\r\n }\r\n return result;\r\n}\r\n/**\r\n * Create a new ITraceParent instance using the provided values.\r\n * @param traceId - The traceId to use, when invalid a new random W3C id will be generated.\r\n * @param spanId - The parent/span id to use, a new random value will be generated if it is invalid.\r\n * @param flags - The traceFlags to use, defaults to zero (0) if not supplied or invalid\r\n * @param version - The version to used, defaults to version \"01\" if not supplied or invalid.\r\n * @returns\r\n */\r\nexport function createTraceParent(traceId, spanId, flags, version) {\r\n return {\r\n version: _isValid(version, 2, INVALID_VERSION) ? version : DEFAULT_VERSION,\r\n traceId: isValidTraceId(traceId) ? traceId : generateW3CId(),\r\n spanId: isValidSpanId(spanId) ? spanId : strLeft(generateW3CId(), 16),\r\n traceFlags: flags >= 0 && flags <= 0xFF ? flags : 1\r\n };\r\n}\r\n/**\r\n * Attempt to parse the provided string as a W3C TraceParent header value (https://www.w3.org/TR/trace-context/#traceparent-header)\r\n *\r\n * @param value - The value to be parsed\r\n * @param selectIdx - If the found value is comma separated which is the preferred entry to select, defaults to the first\r\n * @returns\r\n */\r\nexport function parseTraceParent(value, selectIdx) {\r\n if (!value) {\r\n // Don't pass a null/undefined or empty string\r\n return null;\r\n }\r\n if (isArray(value)) {\r\n // The value may have been encoded on the page into an array so handle this automatically\r\n value = value[0] || \"\";\r\n }\r\n if (!value || !isString(value) || value[_DYN_LENGTH /* @min:%2elength */] > 8192) {\r\n // limit potential processing based on total length\r\n return null;\r\n }\r\n if (value.indexOf(\",\") !== -1) {\r\n var values = value[_DYN_SPLIT /* @min:%2esplit */](\",\");\r\n value = values[selectIdx > 0 && values[_DYN_LENGTH /* @min:%2elength */] > selectIdx ? selectIdx : 0];\r\n }\r\n // See https://www.w3.org/TR/trace-context/#versioning-of-traceparent\r\n var match = TRACE_PARENT_REGEX.exec(strTrim(value));\r\n if (!match || // No match\r\n match[1] === INVALID_VERSION || // version ff is forbidden\r\n match[2] === INVALID_TRACE_ID || // All zeros is considered to be invalid\r\n match[3] === INVALID_SPAN_ID) { // All zeros is considered to be invalid\r\n return null;\r\n }\r\n return {\r\n version: (match[1] || STR_EMPTY)[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */](),\r\n traceId: (match[2] || STR_EMPTY)[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */](),\r\n spanId: (match[3] || STR_EMPTY)[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */](),\r\n traceFlags: parseInt(match[4], 16)\r\n };\r\n}\r\n/**\r\n * Is the provided W3c Trace Id a valid string representation, it must be a 32-character string\r\n * of lowercase hexadecimal characters for example, 4bf92f3577b34da6a3ce929d0e0e4736.\r\n * If all characters as zero (00000000000000000000000000000000) it will be considered an invalid value.\r\n * @param value - The W3c trace Id to be validated\r\n * @returns true if valid otherwise false\r\n */\r\nexport function isValidTraceId(value) {\r\n return _isValid(value, 32, INVALID_TRACE_ID);\r\n}\r\n/**\r\n * Is the provided W3c span id (aka. parent id) a valid string representation, it must be a 16-character\r\n * string of lowercase hexadecimal characters, for example, 00f067aa0ba902b7.\r\n * If all characters are zero (0000000000000000) this is considered an invalid value.\r\n * @param value - The W3c span id to be validated\r\n * @returns true if valid otherwise false\r\n */\r\nexport function isValidSpanId(value) {\r\n return _isValid(value, 16, INVALID_SPAN_ID);\r\n}\r\n/**\r\n * Validates that the provided ITraceParent instance conforms to the currently supported specifications\r\n * @param value - The parsed traceParent value\r\n * @returns\r\n */\r\nexport function isValidTraceParent(value) {\r\n if (!value ||\r\n !_isValid(value[_DYN_VERSION /* @min:%2eversion */], 2, INVALID_VERSION) ||\r\n !_isValid(value.traceId, 32, INVALID_TRACE_ID) ||\r\n !_isValid(value.spanId, 16, INVALID_SPAN_ID) ||\r\n !_isValid(_formatFlags(value[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */]), 2)) {\r\n // Each known field must contain a valid value\r\n return false;\r\n }\r\n return true;\r\n}\r\n/**\r\n * Is the parsed traceParent indicating that the trace is currently sampled.\r\n * @param value - The parsed traceParent value\r\n * @returns\r\n */\r\nexport function isSampledFlag(value) {\r\n if (isValidTraceParent(value)) {\r\n return (value[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */] & SAMPLED_FLAG) === SAMPLED_FLAG;\r\n }\r\n return false;\r\n}\r\n/**\r\n * Format the ITraceParent value as a string using the supported and know version formats.\r\n * So even if the passed traceParent is a later version the string value returned from this\r\n * function will convert it to only the known version formats.\r\n * This currently only supports version \"00\" and invalid \"ff\"\r\n * @param value - The parsed traceParent value\r\n * @returns\r\n */\r\nexport function formatTraceParent(value) {\r\n if (value) {\r\n // Special Note: This only supports formatting as version 00, future versions should encode any known supported version\r\n // So parsing a future version will populate the correct version value but reformatting will reduce it to version 00.\r\n var flags = _formatFlags(value[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */]);\r\n if (!_isValid(flags, 2)) {\r\n flags = \"01\";\r\n }\r\n var version = value[_DYN_VERSION /* @min:%2eversion */] || DEFAULT_VERSION;\r\n if (version !== \"00\" && version !== \"ff\") {\r\n // Reduce version to \"00\"\r\n version = DEFAULT_VERSION;\r\n }\r\n // Format as version 00\r\n return \"\".concat(version.toLowerCase(), \"-\").concat(_formatValue(value.traceId, 32, INVALID_TRACE_ID).toLowerCase(), \"-\").concat(_formatValue(value.spanId, 16, INVALID_SPAN_ID).toLowerCase(), \"-\").concat(flags.toLowerCase());\r\n }\r\n return \"\";\r\n}\r\n/**\r\n * Helper function to fetch the passed traceparent from the page, looking for it as a meta-tag or a Server-Timing header.\r\n * @param selectIdx - If the found value is comma separated which is the preferred entry to select, defaults to the first\r\n * @returns\r\n */\r\nexport function findW3cTraceParent(selectIdx) {\r\n var name = \"traceparent\";\r\n var traceParent = parseTraceParent(findMetaTag(name), selectIdx);\r\n if (!traceParent) {\r\n traceParent = parseTraceParent(findNamedServerTiming(name), selectIdx);\r\n }\r\n return traceParent;\r\n}\r\n/**\r\n * Find all script tags in the provided document and return the information about them.\r\n * @param doc - The document to search for script tags\r\n * @returns\r\n */\r\nexport function findAllScripts(doc) {\r\n var scripts = doc.getElementsByTagName(\"script\");\r\n var result = [];\r\n arrForEach(scripts, function (script) {\r\n var src = script[_DYN_GET_ATTRIBUTE /* @min:%2egetAttribute */](\"src\");\r\n if (src) {\r\n var crossOrigin = script[_DYN_GET_ATTRIBUTE /* @min:%2egetAttribute */](\"crossorigin\");\r\n var async = script.hasAttribute(\"async\") === true;\r\n var defer = script.hasAttribute(\"defer\") === true;\r\n var referrerPolicy = script[_DYN_GET_ATTRIBUTE /* @min:%2egetAttribute */](\"referrerpolicy\");\r\n var info = { url: src };\r\n if (crossOrigin) {\r\n info.crossOrigin = crossOrigin;\r\n }\r\n if (async) {\r\n info.async = async;\r\n }\r\n if (defer) {\r\n info.defer = defer;\r\n }\r\n if (referrerPolicy) {\r\n info.referrerPolicy = referrerPolicy;\r\n }\r\n result[_DYN_PUSH /* @min:%2epush */](info);\r\n }\r\n });\r\n return result;\r\n}\r\n//# sourceMappingURL=W3cTraceParent.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n\"use strict\";\r\nimport { arrForEach, isFunction } from \"@nevware21/ts-utils\";\r\nimport { _DYN_GET_NEXT, _DYN_GET_PLUGIN, _DYN_INITIALIZE, _DYN_IS_INITIALIZED, _DYN_LENGTH, _DYN_NAME, _DYN_PUSH, _DYN_SET_NEXT_PLUGIN, _DYN_TEARDOWN, _DYN_TRACE_FLAGS, _DYN__DO_TEARDOWN } from \"../__DynamicConstants\";\r\nimport { createElmNodeData } from \"./DataCacheHelper\";\r\nimport { STR_CORE, STR_PRIORITY, STR_PROCESS_TELEMETRY } from \"./InternalConstants\";\r\nimport { isValidSpanId, isValidTraceId } from \"./W3cTraceParent\";\r\nvar pluginStateData = createElmNodeData(\"plugin\");\r\nexport function _getPluginState(plugin) {\r\n return pluginStateData.get(plugin, \"state\", {}, true);\r\n}\r\n/**\r\n * Initialize the queue of plugins\r\n * @param plugins - The array of plugins to initialize and setting of the next plugin\r\n * @param config - The current config for the instance\r\n * @param core - THe current core instance\r\n * @param extensions - The extensions\r\n */\r\nexport function initializePlugins(processContext, extensions) {\r\n // Set the next plugin and identified the uninitialized plugins\r\n var initPlugins = [];\r\n var lastPlugin = null;\r\n var proxy = processContext[_DYN_GET_NEXT /* @min:%2egetNext */]();\r\n var pluginState;\r\n while (proxy) {\r\n var thePlugin = proxy[_DYN_GET_PLUGIN /* @min:%2egetPlugin */]();\r\n if (thePlugin) {\r\n if (lastPlugin && lastPlugin[_DYN_SET_NEXT_PLUGIN /* @min:%2esetNextPlugin */] && thePlugin[STR_PROCESS_TELEMETRY /* @min:%2eprocessTelemetry */]) {\r\n // Set this plugin as the next for the previous one\r\n lastPlugin[_DYN_SET_NEXT_PLUGIN /* @min:%2esetNextPlugin */](thePlugin);\r\n }\r\n pluginState = _getPluginState(thePlugin);\r\n var isInitialized = !!pluginState[_DYN_IS_INITIALIZED /* @min:%2eisInitialized */];\r\n if (thePlugin[_DYN_IS_INITIALIZED /* @min:%2eisInitialized */]) {\r\n isInitialized = thePlugin[_DYN_IS_INITIALIZED /* @min:%2eisInitialized */]();\r\n }\r\n if (!isInitialized) {\r\n initPlugins[_DYN_PUSH /* @min:%2epush */](thePlugin);\r\n }\r\n lastPlugin = thePlugin;\r\n proxy = proxy[_DYN_GET_NEXT /* @min:%2egetNext */]();\r\n }\r\n }\r\n // Now initialize the plugins\r\n arrForEach(initPlugins, function (thePlugin) {\r\n var core = processContext[STR_CORE /* @min:%2ecore */]();\r\n thePlugin[_DYN_INITIALIZE /* @min:%2einitialize */](processContext.getCfg(), core, extensions, processContext[_DYN_GET_NEXT /* @min:%2egetNext */]());\r\n pluginState = _getPluginState(thePlugin);\r\n // Only add the core to the state if the plugin didn't set it (doesn't extend from BaseTelemetryPlugin)\r\n if (!thePlugin[STR_CORE] && !pluginState[STR_CORE]) {\r\n pluginState[STR_CORE] = core;\r\n }\r\n pluginState[_DYN_IS_INITIALIZED /* @min:%2eisInitialized */] = true;\r\n delete pluginState[_DYN_TEARDOWN /* @min:%2eteardown */];\r\n });\r\n}\r\nexport function sortPlugins(plugins) {\r\n // Sort by priority\r\n return plugins.sort(function (extA, extB) {\r\n var result = 0;\r\n if (extB) {\r\n var bHasProcess = extB[STR_PROCESS_TELEMETRY];\r\n if (extA[STR_PROCESS_TELEMETRY]) {\r\n result = bHasProcess ? extA[STR_PRIORITY] - extB[STR_PRIORITY] : 1;\r\n }\r\n else if (bHasProcess) {\r\n result = -1;\r\n }\r\n }\r\n else {\r\n result = extA ? 1 : -1;\r\n }\r\n return result;\r\n });\r\n // sort complete\r\n}\r\n/**\r\n * Teardown / Unload helper to perform teardown/unloading operations for the provided components synchronously or asynchronously, this will call any\r\n * _doTeardown() or _doUnload() functions on the provided components to allow them to finish removal.\r\n * @param components - The components you want to unload\r\n * @param unloadCtx - This is the context that should be used during unloading.\r\n * @param unloadState - The details / state of the unload process, it holds details like whether it should be unloaded synchronously or asynchronously and the reason for the unload.\r\n * @param asyncCallback - An optional callback that the plugin must call if it returns true to inform the caller that it has completed any async unload/teardown operations.\r\n * @returns boolean - true if the plugin has or will call asyncCallback, this allows the plugin to perform any asynchronous operations.\r\n */\r\nexport function unloadComponents(components, unloadCtx, unloadState, asyncCallback) {\r\n var idx = 0;\r\n function _doUnload() {\r\n while (idx < components[_DYN_LENGTH /* @min:%2elength */]) {\r\n var component = components[idx++];\r\n if (component) {\r\n var func = component._doUnload || component[_DYN__DO_TEARDOWN /* @min:%2e_doTeardown */];\r\n if (isFunction(func)) {\r\n if (func.call(component, unloadCtx, unloadState, _doUnload) === true) {\r\n return true;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n return _doUnload();\r\n}\r\n/**\r\n * Creates a IDistributedTraceContext which optionally also \"sets\" the value on a parent\r\n * @param parentCtx - An optional parent distributed trace instance\r\n * @returns A new IDistributedTraceContext instance that uses an internal temporary object\r\n */\r\nexport function createDistributedTraceContext(parentCtx) {\r\n var trace = {};\r\n return {\r\n getName: function () {\r\n return trace[_DYN_NAME /* @min:%2ename */];\r\n },\r\n setName: function (newValue) {\r\n parentCtx && parentCtx.setName(newValue);\r\n trace[_DYN_NAME /* @min:%2ename */] = newValue;\r\n },\r\n getTraceId: function () {\r\n return trace.traceId;\r\n },\r\n setTraceId: function (newValue) {\r\n parentCtx && parentCtx.setTraceId(newValue);\r\n if (isValidTraceId(newValue)) {\r\n trace.traceId = newValue;\r\n }\r\n },\r\n getSpanId: function () {\r\n return trace.spanId;\r\n },\r\n setSpanId: function (newValue) {\r\n parentCtx && parentCtx.setSpanId(newValue);\r\n if (isValidSpanId(newValue)) {\r\n trace.spanId = newValue;\r\n }\r\n },\r\n getTraceFlags: function () {\r\n return trace[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */];\r\n },\r\n setTraceFlags: function (newTraceFlags) {\r\n parentCtx && parentCtx.setTraceFlags(newTraceFlags);\r\n trace[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */] = newTraceFlags;\r\n }\r\n };\r\n}\r\n//# sourceMappingURL=TelemetryHelpers.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n\"use strict\";\r\nimport { arrForEach, dumpObj, isArray, isFunction, isNullOrUndefined, isUndefined, objForEachKey, objFreeze, objKeys } from \"@nevware21/ts-utils\";\r\nimport { _applyDefaultValue } from \"../Config/ConfigDefaults\";\r\nimport { createDynamicConfig } from \"../Config/DynamicConfig\";\r\nimport { _DYN_CREATE_NEW, _DYN_DIAG_LOG, _DYN_GET_NEXT, _DYN_GET_PLUGIN, _DYN_IDENTIFIER, _DYN_IS_INITIALIZED, _DYN_LENGTH, _DYN_LOGGER, _DYN_PROCESS_NEXT, _DYN_PUSH, _DYN_SET_NEXT_PLUGIN, _DYN_TEARDOWN, _DYN_UNLOAD, _DYN_UPDATE } from \"../__DynamicConstants\";\r\nimport { _throwInternal, safeGetLogger } from \"./DiagnosticLogger\";\r\nimport { proxyFunctions } from \"./HelperFuncs\";\r\nimport { STR_CORE, STR_DISABLED, STR_EMPTY, STR_EXTENSION_CONFIG, STR_PRIORITY, STR_PROCESS_TELEMETRY } from \"./InternalConstants\";\r\nimport { doPerf } from \"./PerfManager\";\r\nimport { _getPluginState } from \"./TelemetryHelpers\";\r\nvar strTelemetryPluginChain = \"TelemetryPluginChain\";\r\nvar strHasRunFlags = \"_hasRun\";\r\nvar strGetTelCtx = \"_getTelCtx\";\r\nvar _chainId = 0;\r\nfunction _getNextProxyStart(proxy, core, startAt) {\r\n while (proxy) {\r\n if (proxy[_DYN_GET_PLUGIN /* @min:%2egetPlugin */]() === startAt) {\r\n return proxy;\r\n }\r\n proxy = proxy[_DYN_GET_NEXT /* @min:%2egetNext */]();\r\n }\r\n // This wasn't found in the existing chain so create an isolated one with just this plugin\r\n return createTelemetryProxyChain([startAt], core.config || {}, core);\r\n}\r\n/**\r\n * @ignore\r\n * @param telemetryChain\r\n * @param dynamicHandler\r\n * @param core\r\n * @param startAt - Identifies the next plugin to execute, if null there is no \"next\" plugin and if undefined it should assume the start of the chain\r\n * @returns\r\n */\r\nfunction _createInternalContext(telemetryChain, dynamicHandler, core, startAt) {\r\n // We have a special case where we want to start execution from this specific plugin\r\n // or we simply reuse the existing telemetry plugin chain (normal execution case)\r\n var _nextProxy = null; // By Default set as no next plugin\r\n var _onComplete = [];\r\n if (!dynamicHandler) {\r\n dynamicHandler = createDynamicConfig({}, null, core[_DYN_LOGGER /* @min:%2elogger */]);\r\n }\r\n if (startAt !== null) {\r\n // There is no next element (null) vs not defined (undefined) so use the full chain\r\n _nextProxy = startAt ? _getNextProxyStart(telemetryChain, core, startAt) : telemetryChain;\r\n }\r\n var context = {\r\n _next: _moveNext,\r\n ctx: {\r\n core: function () {\r\n return core;\r\n },\r\n diagLog: function () {\r\n return safeGetLogger(core, dynamicHandler.cfg);\r\n },\r\n getCfg: function () {\r\n return dynamicHandler.cfg;\r\n },\r\n getExtCfg: _resolveExtCfg,\r\n getConfig: _getConfig,\r\n hasNext: function () {\r\n return !!_nextProxy;\r\n },\r\n getNext: function () {\r\n return _nextProxy;\r\n },\r\n setNext: function (nextPlugin) {\r\n _nextProxy = nextPlugin;\r\n },\r\n iterate: _iterateChain,\r\n onComplete: _addOnComplete\r\n }\r\n };\r\n function _addOnComplete(onComplete, that) {\r\n var args = [];\r\n for (var _i = 2; _i < arguments.length; _i++) {\r\n args[_i - 2] = arguments[_i];\r\n }\r\n if (onComplete) {\r\n _onComplete[_DYN_PUSH /* @min:%2epush */]({\r\n func: onComplete,\r\n self: !isUndefined(that) ? that : context.ctx,\r\n args: args\r\n });\r\n }\r\n }\r\n function _moveNext() {\r\n var nextProxy = _nextProxy;\r\n // Automatically move to the next plugin\r\n _nextProxy = nextProxy ? nextProxy[_DYN_GET_NEXT /* @min:%2egetNext */]() : null;\r\n if (!nextProxy) {\r\n var onComplete = _onComplete;\r\n if (onComplete && onComplete[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n arrForEach(onComplete, function (completeDetails) {\r\n try {\r\n completeDetails.func.call(completeDetails.self, completeDetails.args);\r\n }\r\n catch (e) {\r\n _throwInternal(core[_DYN_LOGGER /* @min:%2elogger */], 2 /* eLoggingSeverity.WARNING */, 73 /* _eInternalMessageId.PluginException */, \"Unexpected Exception during onComplete - \" + dumpObj(e));\r\n }\r\n });\r\n _onComplete = [];\r\n }\r\n }\r\n return nextProxy;\r\n }\r\n function _getExtCfg(identifier, createIfMissing) {\r\n var idCfg = null;\r\n var cfg = dynamicHandler.cfg;\r\n if (cfg && identifier) {\r\n var extCfg = cfg[STR_EXTENSION_CONFIG /* @min:%2eextensionConfig */];\r\n if (!extCfg && createIfMissing) {\r\n extCfg = {};\r\n }\r\n // Always set the value so that the property always exists\r\n cfg[STR_EXTENSION_CONFIG] = extCfg; // Note: it is valid for the \"value\" to be undefined\r\n // Calling `ref()` has a side effect of causing the referenced property to become dynamic (if not already)\r\n extCfg = dynamicHandler.ref(cfg, STR_EXTENSION_CONFIG);\r\n if (extCfg) {\r\n idCfg = extCfg[identifier];\r\n if (!idCfg && createIfMissing) {\r\n idCfg = {};\r\n }\r\n // Always set the value so that the property always exists\r\n extCfg[identifier] = idCfg; // Note: it is valid for the \"value\" to be undefined\r\n // Calling `ref()` has a side effect of causing the referenced property to become dynamic (if not already)\r\n idCfg = dynamicHandler.ref(extCfg, identifier);\r\n }\r\n }\r\n return idCfg;\r\n }\r\n function _resolveExtCfg(identifier, defaultValues) {\r\n var newConfig = _getExtCfg(identifier, true);\r\n if (defaultValues) {\r\n // Enumerate over the defaultValues and if not already populated attempt to\r\n // find a value from the root config or use the default value\r\n objForEachKey(defaultValues, function (field, defaultValue) {\r\n // for each unspecified field, set the default value\r\n if (isNullOrUndefined(newConfig[field])) {\r\n var cfgValue = dynamicHandler.cfg[field];\r\n if (cfgValue || !isNullOrUndefined(cfgValue)) {\r\n newConfig[field] = cfgValue;\r\n }\r\n }\r\n _applyDefaultValue(dynamicHandler, newConfig, field, defaultValue);\r\n });\r\n }\r\n return dynamicHandler.setDf(newConfig, defaultValues);\r\n }\r\n function _getConfig(identifier, field, defaultValue) {\r\n if (defaultValue === void 0) { defaultValue = false; }\r\n var theValue;\r\n var extConfig = _getExtCfg(identifier, false);\r\n var rootConfig = dynamicHandler.cfg;\r\n if (extConfig && (extConfig[field] || !isNullOrUndefined(extConfig[field]))) {\r\n theValue = extConfig[field];\r\n }\r\n else if (rootConfig[field] || !isNullOrUndefined(rootConfig[field])) {\r\n theValue = rootConfig[field];\r\n }\r\n return (theValue || !isNullOrUndefined(theValue)) ? theValue : defaultValue;\r\n }\r\n function _iterateChain(cb) {\r\n // Keep processing until we reach the end of the chain\r\n var nextPlugin;\r\n while (!!(nextPlugin = context._next())) {\r\n var plugin = nextPlugin[_DYN_GET_PLUGIN /* @min:%2egetPlugin */]();\r\n if (plugin) {\r\n // callback with the current on\r\n cb(plugin);\r\n }\r\n }\r\n }\r\n return context;\r\n}\r\n/**\r\n * Creates a new Telemetry Item context with the current config, core and plugin execution chain\r\n * @param plugins - The plugin instances that will be executed\r\n * @param config - The current config\r\n * @param core - The current core instance\r\n * @param startAt - Identifies the next plugin to execute, if null there is no \"next\" plugin and if undefined it should assume the start of the chain\r\n */\r\nexport function createProcessTelemetryContext(telemetryChain, cfg, core, startAt) {\r\n var config = createDynamicConfig(cfg);\r\n var internalContext = _createInternalContext(telemetryChain, config, core, startAt);\r\n var context = internalContext.ctx;\r\n function _processNext(env) {\r\n var nextPlugin = internalContext._next();\r\n if (nextPlugin) {\r\n // Run the next plugin which will call \"processNext()\"\r\n nextPlugin[STR_PROCESS_TELEMETRY /* @min:%2eprocessTelemetry */](env, context);\r\n }\r\n return !nextPlugin;\r\n }\r\n function _createNew(plugins, startAt) {\r\n if (plugins === void 0) { plugins = null; }\r\n if (isArray(plugins)) {\r\n plugins = createTelemetryProxyChain(plugins, config.cfg, core, startAt);\r\n }\r\n return createProcessTelemetryContext(plugins || context[_DYN_GET_NEXT /* @min:%2egetNext */](), config.cfg, core, startAt);\r\n }\r\n context[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */] = _processNext;\r\n context[_DYN_CREATE_NEW /* @min:%2ecreateNew */] = _createNew;\r\n return context;\r\n}\r\n/**\r\n * Creates a new Telemetry Item context with the current config, core and plugin execution chain for handling the unloading of the chain\r\n * @param plugins - The plugin instances that will be executed\r\n * @param config - The current config\r\n * @param core - The current core instance\r\n * @param startAt - Identifies the next plugin to execute, if null there is no \"next\" plugin and if undefined it should assume the start of the chain\r\n */\r\nexport function createProcessTelemetryUnloadContext(telemetryChain, core, startAt) {\r\n var config = createDynamicConfig(core.config);\r\n var internalContext = _createInternalContext(telemetryChain, config, core, startAt);\r\n var context = internalContext.ctx;\r\n function _processNext(unloadState) {\r\n var nextPlugin = internalContext._next();\r\n nextPlugin && nextPlugin[_DYN_UNLOAD /* @min:%2eunload */](context, unloadState);\r\n return !nextPlugin;\r\n }\r\n function _createNew(plugins, startAt) {\r\n if (plugins === void 0) { plugins = null; }\r\n if (isArray(plugins)) {\r\n plugins = createTelemetryProxyChain(plugins, config.cfg, core, startAt);\r\n }\r\n return createProcessTelemetryUnloadContext(plugins || context[_DYN_GET_NEXT /* @min:%2egetNext */](), core, startAt);\r\n }\r\n context[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */] = _processNext;\r\n context[_DYN_CREATE_NEW /* @min:%2ecreateNew */] = _createNew;\r\n return context;\r\n}\r\n/**\r\n * Creates a new Telemetry Item context with the current config, core and plugin execution chain for updating the configuration\r\n * @param plugins - The plugin instances that will be executed\r\n * @param config - The current config\r\n * @param core - The current core instance\r\n * @param startAt - Identifies the next plugin to execute, if null there is no \"next\" plugin and if undefined it should assume the start of the chain\r\n */\r\nexport function createProcessTelemetryUpdateContext(telemetryChain, core, startAt) {\r\n var config = createDynamicConfig(core.config);\r\n var internalContext = _createInternalContext(telemetryChain, config, core, startAt);\r\n var context = internalContext.ctx;\r\n function _processNext(updateState) {\r\n return context.iterate(function (plugin) {\r\n if (isFunction(plugin[_DYN_UPDATE /* @min:%2eupdate */])) {\r\n plugin[_DYN_UPDATE /* @min:%2eupdate */](context, updateState);\r\n }\r\n });\r\n }\r\n function _createNew(plugins, startAt) {\r\n if (plugins === void 0) { plugins = null; }\r\n if (isArray(plugins)) {\r\n plugins = createTelemetryProxyChain(plugins, config.cfg, core, startAt);\r\n }\r\n return createProcessTelemetryUpdateContext(plugins || context[_DYN_GET_NEXT /* @min:%2egetNext */](), core, startAt);\r\n }\r\n context[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */] = _processNext;\r\n context[_DYN_CREATE_NEW /* @min:%2ecreateNew */] = _createNew;\r\n return context;\r\n}\r\n/**\r\n * Creates an execution chain from the array of plugins\r\n * @param plugins - The array of plugins that will be executed in this order\r\n * @param defItemCtx - The default execution context to use when no telemetry context is passed to processTelemetry(), this\r\n * should be for legacy plugins only. Currently, only used for passing the current core instance and to provide better error\r\n * reporting (hasRun) when errors occur.\r\n */\r\nexport function createTelemetryProxyChain(plugins, config, core, startAt) {\r\n var firstProxy = null;\r\n var add = startAt ? false : true;\r\n if (isArray(plugins) && plugins[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n // Create the proxies and wire up the next plugin chain\r\n var lastProxy_1 = null;\r\n arrForEach(plugins, function (thePlugin) {\r\n if (!add && startAt === thePlugin) {\r\n add = true;\r\n }\r\n if (add && thePlugin && isFunction(thePlugin[STR_PROCESS_TELEMETRY /* @min:%2eprocessTelemetry */])) {\r\n // Only add plugins that are processors\r\n var newProxy = createTelemetryPluginProxy(thePlugin, config, core);\r\n if (!firstProxy) {\r\n firstProxy = newProxy;\r\n }\r\n if (lastProxy_1) {\r\n // Set this new proxy as the next for the previous one\r\n lastProxy_1._setNext(newProxy);\r\n }\r\n lastProxy_1 = newProxy;\r\n }\r\n });\r\n }\r\n if (startAt && !firstProxy) {\r\n // Special case where the \"startAt\" was not in the original list of plugins\r\n return createTelemetryProxyChain([startAt], config, core);\r\n }\r\n return firstProxy;\r\n}\r\n/**\r\n * Create the processing telemetry proxy instance, the proxy is used to abstract the current plugin to allow monitoring and\r\n * execution plugins while passing around the dynamic execution state (IProcessTelemetryContext), the proxy instance no longer\r\n * contains any execution state and can be reused between requests (this was not the case for 2.7.2 and earlier with the\r\n * TelemetryPluginChain class).\r\n * @param plugin - The plugin instance to proxy\r\n * @param config - The default execution context to use when no telemetry context is passed to processTelemetry(), this\r\n * should be for legacy plugins only. Currently, only used for passing the current core instance and to provide better error\r\n * reporting (hasRun) when errors occur.\r\n * @returns\r\n */\r\nexport function createTelemetryPluginProxy(plugin, config, core) {\r\n var nextProxy = null;\r\n var hasProcessTelemetry = isFunction(plugin[STR_PROCESS_TELEMETRY /* @min:%2eprocessTelemetry */]);\r\n var hasSetNext = isFunction(plugin[_DYN_SET_NEXT_PLUGIN /* @min:%2esetNextPlugin */]);\r\n var chainId;\r\n if (plugin) {\r\n chainId = plugin[_DYN_IDENTIFIER /* @min:%2eidentifier */] + \"-\" + plugin[STR_PRIORITY /* @min:%2epriority */] + \"-\" + _chainId++;\r\n }\r\n else {\r\n chainId = \"Unknown-0-\" + _chainId++;\r\n }\r\n var proxyChain = {\r\n getPlugin: function () {\r\n return plugin;\r\n },\r\n getNext: function () {\r\n return nextProxy;\r\n },\r\n processTelemetry: _processTelemetry,\r\n unload: _unloadPlugin,\r\n update: _updatePlugin,\r\n _id: chainId,\r\n _setNext: function (nextPlugin) {\r\n nextProxy = nextPlugin;\r\n }\r\n };\r\n function _getTelCtx() {\r\n var itemCtx;\r\n // Looks like a plugin didn't pass the (optional) context, so create a new one\r\n if (plugin && isFunction(plugin[strGetTelCtx])) {\r\n // This plugin extends from the BaseTelemetryPlugin so lets use it\r\n itemCtx = plugin[strGetTelCtx]();\r\n }\r\n if (!itemCtx) {\r\n // Create a temporary one\r\n itemCtx = createProcessTelemetryContext(proxyChain, config, core);\r\n }\r\n return itemCtx;\r\n }\r\n function _processChain(itemCtx, processPluginFn, name, details, isAsync) {\r\n var hasRun = false;\r\n var identifier = plugin ? plugin[_DYN_IDENTIFIER /* @min:%2eidentifier */] : strTelemetryPluginChain;\r\n var hasRunContext = itemCtx[strHasRunFlags];\r\n if (!hasRunContext) {\r\n // Assign and populate\r\n hasRunContext = itemCtx[strHasRunFlags] = {};\r\n }\r\n // Ensure that we keep the context in sync\r\n itemCtx.setNext(nextProxy);\r\n if (plugin) {\r\n doPerf(itemCtx[STR_CORE /* @min:%2ecore */](), function () { return identifier + \":\" + name; }, function () {\r\n // Mark this component as having run\r\n hasRunContext[chainId] = true;\r\n try {\r\n // Set a flag on the next plugin so we know if it was attempted to be executed\r\n var nextId = nextProxy ? nextProxy._id : STR_EMPTY;\r\n if (nextId) {\r\n hasRunContext[nextId] = false;\r\n }\r\n hasRun = processPluginFn(itemCtx);\r\n }\r\n catch (error) {\r\n var hasNextRun = nextProxy ? hasRunContext[nextProxy._id] : true;\r\n if (hasNextRun) {\r\n // The next plugin after us has already run so set this one as complete\r\n hasRun = true;\r\n }\r\n if (!nextProxy || !hasNextRun) {\r\n // Either we have no next plugin or the current one did not attempt to call the next plugin\r\n // Which means the current one is the root of the failure so log/report this failure\r\n _throwInternal(itemCtx[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 73 /* _eInternalMessageId.PluginException */, \"Plugin [\" + identifier + \"] failed during \" + name + \" - \" + dumpObj(error) + \", run flags: \" + dumpObj(hasRunContext));\r\n }\r\n }\r\n }, details, isAsync);\r\n }\r\n return hasRun;\r\n }\r\n function _processTelemetry(env, itemCtx) {\r\n itemCtx = itemCtx || _getTelCtx();\r\n function _callProcessTelemetry(itemCtx) {\r\n if (!plugin || !hasProcessTelemetry) {\r\n return false;\r\n }\r\n var pluginState = _getPluginState(plugin);\r\n if (pluginState[_DYN_TEARDOWN /* @min:%2eteardown */] || pluginState[STR_DISABLED]) {\r\n return false;\r\n }\r\n // Ensure that we keep the context in sync (for processNext()), just in case a plugin\r\n // doesn't calls processTelemetry() instead of itemContext.processNext() or some\r\n // other form of error occurred\r\n if (hasSetNext) {\r\n // Backward compatibility setting the next plugin on the instance\r\n plugin[_DYN_SET_NEXT_PLUGIN /* @min:%2esetNextPlugin */](nextProxy);\r\n }\r\n plugin[STR_PROCESS_TELEMETRY /* @min:%2eprocessTelemetry */](env, itemCtx);\r\n // Process Telemetry is expected to call itemCtx.processNext() or nextPlugin.processTelemetry()\r\n return true;\r\n }\r\n if (!_processChain(itemCtx, _callProcessTelemetry, \"processTelemetry\", function () { return ({ item: env }); }, !(env.sync))) {\r\n // The underlying plugin is either not defined, not enabled or does not have a processTelemetry implementation\r\n // so we still want the next plugin to be executed.\r\n itemCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](env);\r\n }\r\n }\r\n function _unloadPlugin(unloadCtx, unloadState) {\r\n function _callTeardown() {\r\n // Setting default of hasRun as false so the proxyProcessFn() is called as teardown() doesn't have to exist or call unloadNext().\r\n var hasRun = false;\r\n if (plugin) {\r\n var pluginState = _getPluginState(plugin);\r\n var pluginCore = plugin[STR_CORE] || pluginState[STR_CORE /* @min:%2ecore */];\r\n // Only teardown the plugin if it was initialized by the current core (i.e. It's not a shared plugin)\r\n if (plugin && (!pluginCore || pluginCore === unloadCtx.core()) && !pluginState[_DYN_TEARDOWN /* @min:%2eteardown */]) {\r\n // Handle plugins that don't extend from the BaseTelemetryPlugin\r\n pluginState[STR_CORE /* @min:%2ecore */] = null;\r\n pluginState[_DYN_TEARDOWN /* @min:%2eteardown */] = true;\r\n pluginState[_DYN_IS_INITIALIZED /* @min:%2eisInitialized */] = false;\r\n if (plugin[_DYN_TEARDOWN /* @min:%2eteardown */] && plugin[_DYN_TEARDOWN /* @min:%2eteardown */](unloadCtx, unloadState) === true) {\r\n // plugin told us that it was going to (or has) call unloadCtx.processNext()\r\n hasRun = true;\r\n }\r\n }\r\n }\r\n return hasRun;\r\n }\r\n if (!_processChain(unloadCtx, _callTeardown, \"unload\", function () { }, unloadState.isAsync)) {\r\n // Only called if we hasRun was not true\r\n unloadCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](unloadState);\r\n }\r\n }\r\n function _updatePlugin(updateCtx, updateState) {\r\n function _callUpdate() {\r\n // Setting default of hasRun as false so the proxyProcessFn() is called as teardown() doesn't have to exist or call unloadNext().\r\n var hasRun = false;\r\n if (plugin) {\r\n var pluginState = _getPluginState(plugin);\r\n var pluginCore = plugin[STR_CORE] || pluginState[STR_CORE /* @min:%2ecore */];\r\n // Only update the plugin if it was initialized by the current core (i.e. It's not a shared plugin)\r\n if (plugin && (!pluginCore || pluginCore === updateCtx.core()) && !pluginState[_DYN_TEARDOWN /* @min:%2eteardown */]) {\r\n if (plugin[_DYN_UPDATE /* @min:%2eupdate */] && plugin[_DYN_UPDATE /* @min:%2eupdate */](updateCtx, updateState) === true) {\r\n // plugin told us that it was going to (or has) call unloadCtx.processNext()\r\n hasRun = true;\r\n }\r\n }\r\n }\r\n return hasRun;\r\n }\r\n if (!_processChain(updateCtx, _callUpdate, \"update\", function () { }, false)) {\r\n // Only called if we hasRun was not true\r\n updateCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](updateState);\r\n }\r\n }\r\n return objFreeze(proxyChain);\r\n}\r\n/**\r\n * This class will be removed!\r\n * @deprecated use createProcessTelemetryContext() instead\r\n */\r\nvar ProcessTelemetryContext = /** @class */ (function () {\r\n /**\r\n * Creates a new Telemetry Item context with the current config, core and plugin execution chain\r\n * @param plugins - The plugin instances that will be executed\r\n * @param config - The current config\r\n * @param core - The current core instance\r\n */\r\n function ProcessTelemetryContext(pluginChain, config, core, startAt) {\r\n var _self = this;\r\n var context = createProcessTelemetryContext(pluginChain, config, core, startAt);\r\n // Proxy all functions of the context to this object\r\n proxyFunctions(_self, context, objKeys(context));\r\n }\r\n return ProcessTelemetryContext;\r\n}());\r\nexport { ProcessTelemetryContext };\r\n//# sourceMappingURL=ProcessTelemetryContext.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { arrForEach, dumpObj } from \"@nevware21/ts-utils\";\r\nimport { _DYN_DIAG_LOG, _DYN_PUSH } from \"../__DynamicConstants\";\r\nimport { _throwInternal } from \"./DiagnosticLogger\";\r\nexport function createUnloadHandlerContainer() {\r\n var handlers = [];\r\n function _addHandler(handler) {\r\n if (handler) {\r\n handlers[_DYN_PUSH /* @min:%2epush */](handler);\r\n }\r\n }\r\n function _runHandlers(unloadCtx, unloadState) {\r\n arrForEach(handlers, function (handler) {\r\n try {\r\n handler(unloadCtx, unloadState);\r\n }\r\n catch (e) {\r\n _throwInternal(unloadCtx[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 73 /* _eInternalMessageId.PluginException */, \"Unexpected error calling unload handler - \" + dumpObj(e));\r\n }\r\n });\r\n handlers = [];\r\n }\r\n return {\r\n add: _addHandler,\r\n run: _runHandlers\r\n };\r\n}\r\n//# sourceMappingURL=UnloadHandlerContainer.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { arrAppend, arrForEach, dumpObj } from \"@nevware21/ts-utils\";\r\nimport { _DYN_LENGTH } from \"../__DynamicConstants\";\r\nimport { _throwInternal } from \"./DiagnosticLogger\";\r\nvar _maxHooks;\r\nvar _hookAddMonitor;\r\n/**\r\n * Test hook for setting the maximum number of unload hooks and calling a monitor function when the hooks are added or removed\r\n * This allows for automatic test failure when the maximum number of unload hooks is exceeded\r\n * @param maxHooks - The maximum number of unload hooks\r\n * @param addMonitor - The monitor function to call when hooks are added or removed\r\n */\r\nexport function _testHookMaxUnloadHooksCb(maxHooks, addMonitor) {\r\n _maxHooks = maxHooks;\r\n _hookAddMonitor = addMonitor;\r\n}\r\n/**\r\n * Create a IUnloadHookContainer which can be used to remember unload hook functions to be executed during the component unloading\r\n * process.\r\n * @returns A new IUnloadHookContainer instance\r\n */\r\nexport function createUnloadHookContainer() {\r\n var _hooks = [];\r\n function _doUnload(logger) {\r\n var oldHooks = _hooks;\r\n _hooks = [];\r\n // Remove all registered unload hooks\r\n arrForEach(oldHooks, function (fn) {\r\n // allow either rm or remove callback function\r\n try {\r\n (fn.rm || fn.remove).call(fn);\r\n }\r\n catch (e) {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 73 /* _eInternalMessageId.PluginException */, \"Unloading:\" + dumpObj(e));\r\n }\r\n });\r\n if (_maxHooks && oldHooks[_DYN_LENGTH /* @min:%2elength */] > _maxHooks) {\r\n _hookAddMonitor ? _hookAddMonitor(\"doUnload\", oldHooks) : _throwInternal(null, 1 /* eLoggingSeverity.CRITICAL */, 48 /* _eInternalMessageId.MaxUnloadHookExceeded */, \"Max unload hooks exceeded. An excessive number of unload hooks has been detected.\");\r\n }\r\n }\r\n function _addHook(hooks) {\r\n if (hooks) {\r\n arrAppend(_hooks, hooks);\r\n if (_maxHooks && _hooks[_DYN_LENGTH /* @min:%2elength */] > _maxHooks) {\r\n _hookAddMonitor ? _hookAddMonitor(\"Add\", _hooks) : _throwInternal(null, 1 /* eLoggingSeverity.CRITICAL */, 48 /* _eInternalMessageId.MaxUnloadHookExceeded */, \"Max unload hooks exceeded. An excessive number of unload hooks has been detected.\");\r\n }\r\n }\r\n }\r\n return {\r\n run: _doUnload,\r\n add: _addHook\r\n };\r\n}\r\n//# sourceMappingURL=UnloadHookContainer.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n\"use strict\";\r\nvar _a;\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { isFunction, objDefine } from \"@nevware21/ts-utils\";\r\nimport { createDynamicConfig } from \"../Config/DynamicConfig\";\r\nimport { _DYN_CREATE_NEW, _DYN_DIAG_LOG, _DYN_GET_NEXT, _DYN_GET_PROCESS_TEL_CONT2, _DYN_INITIALIZE, _DYN_IS_INITIALIZED, _DYN_PROCESS_NEXT, _DYN_SET_NEXT_PLUGIN, _DYN_TEARDOWN, _DYN_UPDATE, _DYN__DO_TEARDOWN } from \"../__DynamicConstants\";\r\nimport { safeGetLogger } from \"./DiagnosticLogger\";\r\nimport { isNotNullOrUndefined, proxyFunctionAs } from \"./HelperFuncs\";\r\nimport { STR_CORE, STR_EXTENSION_CONFIG, STR_PROCESS_TELEMETRY } from \"./InternalConstants\";\r\nimport { createProcessTelemetryContext, createProcessTelemetryUnloadContext, createProcessTelemetryUpdateContext } from \"./ProcessTelemetryContext\";\r\nimport { createUnloadHandlerContainer } from \"./UnloadHandlerContainer\";\r\nimport { createUnloadHookContainer } from \"./UnloadHookContainer\";\r\nvar strGetPlugin = \"getPlugin\";\r\nvar defaultValues = (_a = {},\r\n _a[STR_EXTENSION_CONFIG] = { isVal: isNotNullOrUndefined, v: {} },\r\n _a);\r\n/**\r\n * BaseTelemetryPlugin provides a basic implementation of the ITelemetryPlugin interface so that plugins\r\n * can avoid implementation the same set of boiler plate code as well as provide a base\r\n * implementation so that new default implementations can be added without breaking all plugins.\r\n */\r\nvar BaseTelemetryPlugin = /** @class */ (function () {\r\n function BaseTelemetryPlugin() {\r\n var _self = this; // Setting _self here as it's used outside of the dynamicProto as well\r\n // NOTE!: DON'T set default values here, instead set them in the _initDefaults() function as it is also called during teardown()\r\n var _isinitialized;\r\n var _rootCtx; // Used as the root context, holding the current config and initialized core\r\n var _nextPlugin; // Used for backward compatibility where plugins don't call the main pipeline\r\n var _unloadHandlerContainer;\r\n var _hookContainer;\r\n _initDefaults();\r\n dynamicProto(BaseTelemetryPlugin, _self, function (_self) {\r\n _self[_DYN_INITIALIZE /* @min:%2einitialize */] = function (config, core, extensions, pluginChain) {\r\n _setDefaults(config, core, pluginChain);\r\n _isinitialized = true;\r\n };\r\n _self[_DYN_TEARDOWN /* @min:%2eteardown */] = function (unloadCtx, unloadState) {\r\n // If this plugin has already been torn down (not operational) or is not initialized (core is not set)\r\n // or the core being used for unload was not the same core used for initialization.\r\n var core = _self[STR_CORE /* @min:%2ecore */];\r\n if (!core || (unloadCtx && core !== unloadCtx[STR_CORE /* @min:%2ecore */]())) {\r\n // Do Nothing as either the plugin is not initialized or was not initialized by the current core\r\n return;\r\n }\r\n var result;\r\n var unloadDone = false;\r\n var theUnloadCtx = unloadCtx || createProcessTelemetryUnloadContext(null, core, _nextPlugin && _nextPlugin[strGetPlugin] ? _nextPlugin[strGetPlugin]() : _nextPlugin);\r\n var theUnloadState = unloadState || {\r\n reason: 0 /* TelemetryUnloadReason.ManualTeardown */,\r\n isAsync: false\r\n };\r\n function _unloadCallback() {\r\n if (!unloadDone) {\r\n unloadDone = true;\r\n _unloadHandlerContainer.run(theUnloadCtx, unloadState);\r\n _hookContainer.run(theUnloadCtx[_DYN_DIAG_LOG /* @min:%2ediagLog */]());\r\n if (result === true) {\r\n theUnloadCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](theUnloadState);\r\n }\r\n _initDefaults();\r\n }\r\n }\r\n if (!_self[_DYN__DO_TEARDOWN /* @min:%2e_doTeardown */] || _self[_DYN__DO_TEARDOWN /* @min:%2e_doTeardown */](theUnloadCtx, theUnloadState, _unloadCallback) !== true) {\r\n _unloadCallback();\r\n }\r\n else {\r\n // Tell the caller that we will be calling processNext()\r\n result = true;\r\n }\r\n return result;\r\n };\r\n _self[_DYN_UPDATE /* @min:%2eupdate */] = function (updateCtx, updateState) {\r\n // If this plugin has already been torn down (not operational) or is not initialized (core is not set)\r\n // or the core being used for unload was not the same core used for initialization.\r\n var core = _self[STR_CORE /* @min:%2ecore */];\r\n if (!core || (updateCtx && core !== updateCtx[STR_CORE /* @min:%2ecore */]())) {\r\n // Do Nothing\r\n return;\r\n }\r\n var result;\r\n var updateDone = false;\r\n var theUpdateCtx = updateCtx || createProcessTelemetryUpdateContext(null, core, _nextPlugin && _nextPlugin[strGetPlugin] ? _nextPlugin[strGetPlugin]() : _nextPlugin);\r\n var theUpdateState = updateState || {\r\n reason: 0 /* TelemetryUpdateReason.Unknown */\r\n };\r\n function _updateCallback() {\r\n if (!updateDone) {\r\n updateDone = true;\r\n _setDefaults(theUpdateCtx.getCfg(), theUpdateCtx.core(), theUpdateCtx[_DYN_GET_NEXT /* @min:%2egetNext */]());\r\n }\r\n }\r\n if (!_self._doUpdate || _self._doUpdate(theUpdateCtx, theUpdateState, _updateCallback) !== true) {\r\n _updateCallback();\r\n }\r\n else {\r\n result = true;\r\n }\r\n return result;\r\n };\r\n proxyFunctionAs(_self, \"_addUnloadCb\", function () { return _unloadHandlerContainer; }, \"add\");\r\n proxyFunctionAs(_self, \"_addHook\", function () { return _hookContainer; }, \"add\");\r\n objDefine(_self, \"_unloadHooks\", { g: function () { return _hookContainer; } });\r\n });\r\n // These are added after the dynamicProto so that are not moved to the prototype\r\n _self[_DYN_DIAG_LOG /* @min:%2ediagLog */] = function (itemCtx) {\r\n return _getTelCtx(itemCtx)[_DYN_DIAG_LOG /* @min:%2ediagLog */]();\r\n };\r\n _self[_DYN_IS_INITIALIZED /* @min:%2eisInitialized */] = function () {\r\n return _isinitialized;\r\n };\r\n _self.setInitialized = function (isInitialized) {\r\n _isinitialized = isInitialized;\r\n };\r\n // _self.getNextPlugin = () => DO NOT IMPLEMENT\r\n // Sub-classes of this base class *should* not be relying on this value and instead\r\n // should use processNext() function. If you require access to the plugin use the\r\n // IProcessTelemetryContext.getNext().getPlugin() while in the pipeline, Note getNext() may return null.\r\n _self[_DYN_SET_NEXT_PLUGIN /* @min:%2esetNextPlugin */] = function (next) {\r\n _nextPlugin = next;\r\n };\r\n _self[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */] = function (env, itemCtx) {\r\n if (itemCtx) {\r\n // Normal core execution sequence\r\n itemCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](env);\r\n }\r\n else if (_nextPlugin && isFunction(_nextPlugin[STR_PROCESS_TELEMETRY /* @min:%2eprocessTelemetry */])) {\r\n // Looks like backward compatibility or out of band processing. And as it looks\r\n // like a ITelemetryPlugin or ITelemetryPluginChain, just call processTelemetry\r\n _nextPlugin[STR_PROCESS_TELEMETRY /* @min:%2eprocessTelemetry */](env, null);\r\n }\r\n };\r\n _self._getTelCtx = _getTelCtx;\r\n function _getTelCtx(currentCtx) {\r\n if (currentCtx === void 0) { currentCtx = null; }\r\n var itemCtx = currentCtx;\r\n if (!itemCtx) {\r\n var rootCtx = _rootCtx || createProcessTelemetryContext(null, {}, _self[STR_CORE /* @min:%2ecore */]);\r\n // tslint:disable-next-line: prefer-conditional-expression\r\n if (_nextPlugin && _nextPlugin[strGetPlugin]) {\r\n // Looks like a chain object\r\n itemCtx = rootCtx[_DYN_CREATE_NEW /* @min:%2ecreateNew */](null, _nextPlugin[strGetPlugin]);\r\n }\r\n else {\r\n itemCtx = rootCtx[_DYN_CREATE_NEW /* @min:%2ecreateNew */](null, _nextPlugin);\r\n }\r\n }\r\n return itemCtx;\r\n }\r\n function _setDefaults(config, core, pluginChain) {\r\n // Make sure the extensionConfig exists and the config is dynamic\r\n createDynamicConfig(config, defaultValues, safeGetLogger(core));\r\n if (!pluginChain && core) {\r\n // Get the first plugin from the core\r\n pluginChain = core[_DYN_GET_PROCESS_TEL_CONT2 /* @min:%2egetProcessTelContext */]()[_DYN_GET_NEXT /* @min:%2egetNext */]();\r\n }\r\n var nextPlugin = _nextPlugin;\r\n if (_nextPlugin && _nextPlugin[strGetPlugin]) {\r\n // If it looks like a proxy/chain then get the plugin\r\n nextPlugin = _nextPlugin[strGetPlugin]();\r\n }\r\n // Support legacy plugins where core was defined as a property\r\n _self[STR_CORE /* @min:%2ecore */] = core;\r\n _rootCtx = createProcessTelemetryContext(pluginChain, config, core, nextPlugin);\r\n }\r\n function _initDefaults() {\r\n _isinitialized = false;\r\n _self[STR_CORE /* @min:%2ecore */] = null;\r\n _rootCtx = null;\r\n _nextPlugin = null;\r\n _hookContainer = createUnloadHookContainer();\r\n _unloadHandlerContainer = createUnloadHandlerContainer();\r\n }\r\n }\r\n// Removed Stub for BaseTelemetryPlugin.prototype.initialize.\r\n// Removed Stub for BaseTelemetryPlugin.prototype.teardown.\r\n// Removed Stub for BaseTelemetryPlugin.prototype.update.\r\n// Removed Stub for BaseTelemetryPlugin.prototype._addUnloadCb.\r\n// Removed Stub for BaseTelemetryPlugin.prototype._addHook.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n BaseTelemetryPlugin.__ieDyn=1;\n\n return BaseTelemetryPlugin;\r\n}());\r\nexport { BaseTelemetryPlugin };\r\n//# sourceMappingURL=BaseTelemetryPlugin.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n// \r\n// \r\nimport { __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { arrAppend, arrForEach, dumpObj } from \"@nevware21/ts-utils\";\r\nimport { _DYN_APPLY, _DYN_DIAG_LOG, _DYN_LENGTH, _DYN_PROCESS_NEXT, _DYN_SPLICE, _DYN__DO_TEARDOWN } from \"../__DynamicConstants\";\r\nimport { BaseTelemetryPlugin } from \"./BaseTelemetryPlugin\";\r\nimport { _throwInternal } from \"./DiagnosticLogger\";\r\nimport { getExceptionName } from \"./HelperFuncs\";\r\nimport { STR_PROCESS_TELEMETRY } from \"./InternalConstants\";\r\nfunction _addInitializer(_initializers, id, telemetryInitializer) {\r\n var theInitializer = {\r\n id: id,\r\n fn: telemetryInitializer\r\n };\r\n arrAppend(_initializers, theInitializer);\r\n var handler = {\r\n remove: function () {\r\n arrForEach(_initializers, function (initializer, idx) {\r\n if (initializer.id === theInitializer.id) {\r\n _initializers[_DYN_SPLICE /* @min:%2esplice */](idx, 1);\r\n return -1;\r\n }\r\n });\r\n }\r\n };\r\n return handler;\r\n}\r\nfunction _runInitializers(_initializers, item, logger) {\r\n var doNotSendItem = false;\r\n var telemetryInitializersCount = _initializers[_DYN_LENGTH /* @min:%2elength */];\r\n for (var i = 0; i < telemetryInitializersCount; ++i) {\r\n var telemetryInitializer = _initializers[i];\r\n if (telemetryInitializer) {\r\n try {\r\n if (telemetryInitializer.fn[_DYN_APPLY /* @min:%2eapply */](null, [item]) === false) {\r\n doNotSendItem = true;\r\n break;\r\n }\r\n }\r\n catch (e) {\r\n // log error but dont stop executing rest of the telemetry initializers\r\n // doNotSendItem = true;\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 64 /* _eInternalMessageId.TelemetryInitializerFailed */, \"Telemetry initializer failed: \" + getExceptionName(e), { exception: dumpObj(e) }, true);\r\n }\r\n }\r\n }\r\n return !doNotSendItem;\r\n}\r\nvar TelemetryInitializerPlugin = /** @class */ (function (_super) {\r\n __extends(TelemetryInitializerPlugin, _super);\r\n function TelemetryInitializerPlugin() {\r\n var _this = _super.call(this) || this;\r\n _this.identifier = \"TelemetryInitializerPlugin\";\r\n _this.priority = 199;\r\n // NOTE!: DON'T set default values here, instead set them in the _initDefaults() function as it is also called during teardown()\r\n var _id;\r\n var _initializers;\r\n _initDefaults();\r\n dynamicProto(TelemetryInitializerPlugin, _this, function (_self, _base) {\r\n _self.addTelemetryInitializer = function (telemetryInitializer) {\r\n return _addInitializer(_initializers, _id++, telemetryInitializer);\r\n };\r\n _self[STR_PROCESS_TELEMETRY /* @min:%2eprocessTelemetry */] = function (item, itemCtx) {\r\n if (_runInitializers(_initializers, item, itemCtx ? itemCtx[_DYN_DIAG_LOG /* @min:%2ediagLog */]() : _self[_DYN_DIAG_LOG /* @min:%2ediagLog */]())) {\r\n _self[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](item, itemCtx);\r\n }\r\n };\r\n _self[_DYN__DO_TEARDOWN /* @min:%2e_doTeardown */] = function () {\r\n _initDefaults();\r\n };\r\n });\r\n function _initDefaults() {\r\n _id = 0;\r\n _initializers = [];\r\n }\r\n return _this;\r\n }\r\n// Removed Stub for TelemetryInitializerPlugin.prototype.addTelemetryInitializer.\r\n// Removed Stub for TelemetryInitializerPlugin.prototype.processTelemetry.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n TelemetryInitializerPlugin.__ieDyn=1;\n\n return TelemetryInitializerPlugin;\r\n}(BaseTelemetryPlugin));\r\nexport { TelemetryInitializerPlugin };\r\n//# sourceMappingURL=TelemetryInitializerPlugin.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n\"use strict\";\r\nvar _a;\r\nimport { __spreadArrayFn as __spreadArray } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { createPromise, createSyncAllSettledPromise, doAwaitResponse } from \"@nevware21/ts-async\";\r\nimport { arrAppend, arrForEach, arrIndexOf, createTimeout, deepExtend, hasDocument, isFunction, isNullOrUndefined, isPlainObject, isPromiseLike, objDeepFreeze, objDefine, objForEachKey, objFreeze, objHasOwn, scheduleTimeout, throwError } from \"@nevware21/ts-utils\";\r\nimport { createDynamicConfig, onConfigChange } from \"../Config/DynamicConfig\";\r\nimport { ActiveStatus } from \"../JavaScriptSDK.Enums/InitActiveStatusEnum\";\r\nimport { _DYN_ADD_NOTIFICATION_LIS1, _DYN_CANCEL, _DYN_CREATE_NEW, _DYN_ENABLED, _DYN_GET_NOTIFY_MGR, _DYN_GET_PLUGIN, _DYN_GET_PROCESS_TEL_CONT2, _DYN_IDENTIFIER, _DYN_INITIALIZE, _DYN_IS_INITIALIZED, _DYN_LENGTH, _DYN_LOGGER, _DYN_LOGGING_LEVEL_CONSOL4, _DYN_MESSAGE, _DYN_MESSAGE_ID, _DYN_NAME, _DYN_ON_COMPLETE, _DYN_PROCESS_NEXT, _DYN_PUSH, _DYN_REMOVE_NOTIFICATION_0, _DYN_SPLICE, _DYN_STOP_POLLING_INTERNA3, _DYN_TEARDOWN, _DYN_UNLOAD, _DYN_VALUE, _DYN_VERSION, _DYN_WATCH } from \"../__DynamicConstants\";\r\nimport { doUnloadAll, runTargetUnload } from \"./AsyncUtils\";\r\nimport { ChannelControllerPriority } from \"./Constants\";\r\nimport { createCookieMgr } from \"./CookieMgr\";\r\nimport { createUniqueNamespace } from \"./DataCacheHelper\";\r\nimport { getDebugListener } from \"./DbgExtensionUtils\";\r\nimport { DiagnosticLogger, _InternalLogMessage, _throwInternal, _warnToConsole } from \"./DiagnosticLogger\";\r\nimport { getSetValue, isNotNullOrUndefined, proxyFunctionAs, proxyFunctions, toISOString } from \"./HelperFuncs\";\r\nimport { STR_CHANNELS, STR_CORE, STR_CREATE_PERF_MGR, STR_DISABLED, STR_EMPTY, STR_EVENTS_DISCARDED, STR_EXTENSIONS, STR_EXTENSION_CONFIG, STR_GET_PERF_MGR, STR_PRIORITY, UNDEFINED_VALUE } from \"./InternalConstants\";\r\nimport { NotificationManager } from \"./NotificationManager\";\r\nimport { PerfManager, doPerf, getGblPerfMgr } from \"./PerfManager\";\r\nimport { createProcessTelemetryContext, createProcessTelemetryUnloadContext, createProcessTelemetryUpdateContext, createTelemetryProxyChain } from \"./ProcessTelemetryContext\";\r\nimport { _getPluginState, createDistributedTraceContext, initializePlugins, sortPlugins } from \"./TelemetryHelpers\";\r\nimport { TelemetryInitializerPlugin } from \"./TelemetryInitializerPlugin\";\r\nimport { createUnloadHandlerContainer } from \"./UnloadHandlerContainer\";\r\nimport { createUnloadHookContainer } from \"./UnloadHookContainer\";\r\nvar strValidationError = \"Plugins must provide initialize method\";\r\nvar strNotificationManager = \"_notificationManager\";\r\nvar strSdkUnloadingError = \"SDK is still unloading...\";\r\nvar strSdkNotInitialized = \"SDK is not initialized\";\r\nvar maxInitQueueSize = 100;\r\nvar maxInitTimeout = 50000;\r\n// const strPluginUnloadFailed = \"Failed to unload plugin\";\r\n/**\r\n * The default settings for the config.\r\n * WE MUST include all defaults here to ensure that the config is created with all of the properties\r\n * defined as dynamic.\r\n */\r\nvar defaultConfig = objDeepFreeze((_a = {\r\n cookieCfg: {}\r\n },\r\n _a[STR_EXTENSIONS] = { rdOnly: true, ref: true, v: [] },\r\n _a[STR_CHANNELS] = { rdOnly: true, ref: true, v: [] },\r\n _a[STR_EXTENSION_CONFIG] = { ref: true, v: {} },\r\n _a[STR_CREATE_PERF_MGR] = UNDEFINED_VALUE,\r\n _a.loggingLevelConsole = 0 /* eLoggingSeverity.DISABLED */,\r\n _a.diagnosticLogInterval = UNDEFINED_VALUE,\r\n _a));\r\n/**\r\n * Helper to create the default performance manager\r\n * @param core - The AppInsightsCore instance\r\n * @param notificationMgr - The notification manager\r\n */\r\nfunction _createPerfManager(core, notificationMgr) {\r\n return new PerfManager(notificationMgr);\r\n}\r\nfunction _validateExtensions(logger, channelPriority, allExtensions) {\r\n // Concat all available extensions\r\n var coreExtensions = [];\r\n var channels = [];\r\n // Check if any two extensions have the same priority, then warn to console\r\n // And extract the local extensions from the\r\n var extPriorities = {};\r\n // Extension validation\r\n arrForEach(allExtensions, function (ext) {\r\n // Check for ext.initialize\r\n if (isNullOrUndefined(ext) || isNullOrUndefined(ext[_DYN_INITIALIZE /* @min:%2einitialize */])) {\r\n throwError(strValidationError);\r\n }\r\n var extPriority = ext[STR_PRIORITY /* @min:%2epriority */];\r\n var identifier = ext[_DYN_IDENTIFIER /* @min:%2eidentifier */];\r\n if (ext && extPriority) {\r\n if (!isNullOrUndefined(extPriorities[extPriority])) {\r\n _warnToConsole(logger, \"Two extensions have same priority #\" + extPriority + \" - \" + extPriorities[extPriority] + \", \" + identifier);\r\n }\r\n else {\r\n // set a value\r\n extPriorities[extPriority] = identifier;\r\n }\r\n }\r\n // Split extensions to core and channels\r\n if (!extPriority || extPriority < channelPriority) {\r\n // Add to core extension that will be managed by AppInsightsCore\r\n coreExtensions[_DYN_PUSH /* @min:%2epush */](ext);\r\n }\r\n else {\r\n channels[_DYN_PUSH /* @min:%2epush */](ext);\r\n }\r\n });\r\n return {\r\n core: coreExtensions,\r\n channels: channels\r\n };\r\n}\r\nfunction _isPluginPresent(thePlugin, plugins) {\r\n var exists = false;\r\n arrForEach(plugins, function (plugin) {\r\n if (plugin === thePlugin) {\r\n exists = true;\r\n return -1;\r\n }\r\n });\r\n return exists;\r\n}\r\nfunction _deepMergeConfig(details, target, newValues, merge) {\r\n // Lets assign the new values to the existing config\r\n if (newValues) {\r\n objForEachKey(newValues, function (key, value) {\r\n if (merge) {\r\n if (isPlainObject(value) && isPlainObject(target[key])) {\r\n // The target is an object and it has a value\r\n _deepMergeConfig(details, target[key], value, merge);\r\n }\r\n }\r\n if (merge && isPlainObject(value) && isPlainObject(target[key])) {\r\n // The target is an object and it has a value\r\n _deepMergeConfig(details, target[key], value, merge);\r\n }\r\n else {\r\n // Just Assign (replace) and/or make the property dynamic\r\n details.set(target, key, value);\r\n }\r\n });\r\n }\r\n}\r\nfunction _findWatcher(listeners, newWatcher) {\r\n var theListener = null;\r\n var idx = -1;\r\n arrForEach(listeners, function (listener, lp) {\r\n if (listener.w === newWatcher) {\r\n theListener = listener;\r\n idx = lp;\r\n return -1;\r\n }\r\n });\r\n return { i: idx, l: theListener };\r\n}\r\nfunction _addDelayedCfgListener(listeners, newWatcher) {\r\n var theListener = _findWatcher(listeners, newWatcher).l;\r\n if (!theListener) {\r\n theListener = {\r\n w: newWatcher,\r\n rm: function () {\r\n var fnd = _findWatcher(listeners, newWatcher);\r\n if (fnd.i !== -1) {\r\n listeners[_DYN_SPLICE /* @min:%2esplice */](fnd.i, 1);\r\n }\r\n }\r\n };\r\n listeners[_DYN_PUSH /* @min:%2epush */](theListener);\r\n }\r\n return theListener;\r\n}\r\nfunction _registerDelayedCfgListener(config, listeners, logger) {\r\n arrForEach(listeners, function (listener) {\r\n var unloadHdl = onConfigChange(config, listener.w, logger);\r\n delete listener.w; // Clear the listener reference so it will get garbage collected.\r\n // replace the remove function\r\n listener.rm = function () {\r\n unloadHdl.rm();\r\n };\r\n });\r\n}\r\n// Moved this outside of the closure to reduce the retained memory footprint\r\nfunction _initDebugListener(configHandler, unloadContainer, notificationManager, debugListener) {\r\n // Will get recalled if any referenced config values are changed\r\n unloadContainer.add(configHandler[_DYN_WATCH /* @min:%2ewatch */](function (details) {\r\n var disableDbgExt = details.cfg.disableDbgExt;\r\n if (disableDbgExt === true && debugListener) {\r\n // Remove any previously loaded debug listener\r\n notificationManager[_DYN_REMOVE_NOTIFICATION_0 /* @min:%2eremoveNotificationListener */](debugListener);\r\n debugListener = null;\r\n }\r\n if (notificationManager && !debugListener && disableDbgExt !== true) {\r\n debugListener = getDebugListener(details.cfg);\r\n notificationManager[_DYN_ADD_NOTIFICATION_LIS1 /* @min:%2eaddNotificationListener */](debugListener);\r\n }\r\n }));\r\n return debugListener;\r\n}\r\n// Moved this outside of the closure to reduce the retained memory footprint\r\nfunction _createUnloadHook(unloadHook) {\r\n return objDefine({\r\n rm: function () {\r\n unloadHook.rm();\r\n }\r\n }, \"toJSON\", { v: function () { return \"aicore::onCfgChange<\" + JSON.stringify(unloadHook) + \">\"; } });\r\n}\r\n/**\r\n * @group Classes\r\n * @group Entrypoint\r\n */\r\nvar AppInsightsCore = /** @class */ (function () {\r\n function AppInsightsCore() {\r\n // NOTE!: DON'T set default values here, instead set them in the _initDefaults() function as it is also called during teardown()\r\n var _configHandler;\r\n var _isInitialized;\r\n var _logger;\r\n var _eventQueue;\r\n var _notificationManager;\r\n var _perfManager;\r\n var _cfgPerfManager;\r\n var _cookieManager;\r\n var _pluginChain;\r\n var _configExtensions;\r\n var _channelConfig;\r\n var _channels;\r\n var _isUnloading;\r\n var _telemetryInitializerPlugin;\r\n var _internalLogsEventName;\r\n var _evtNamespace;\r\n var _unloadHandlers;\r\n var _hookContainer;\r\n var _debugListener;\r\n var _traceCtx;\r\n var _instrumentationKey;\r\n var _cfgListeners;\r\n var _extensions;\r\n var _pluginVersionStringArr;\r\n var _pluginVersionString;\r\n var _activeStatus; // to indicate if ikey or endpoint url promised is resolved or not\r\n var _endpoint;\r\n var _initInMemoMaxSize; // max event count limit during wait for init promises to be resolved\r\n var _isStatusSet; // track if active status is set in case of init timeout and init promises setting the status twice\r\n var _initTimer;\r\n /**\r\n * Internal log poller\r\n */\r\n var _internalLogPoller;\r\n var _internalLogPollerListening;\r\n var _forceStopInternalLogPoller;\r\n dynamicProto(AppInsightsCore, this, function (_self) {\r\n // Set the default values (also called during teardown)\r\n _initDefaults();\r\n // Special internal method to allow the unit tests and DebugPlugin to hook embedded objects\r\n _self[\"_getDbgPlgTargets\"] = function () {\r\n return [_extensions, _eventQueue];\r\n };\r\n _self[_DYN_IS_INITIALIZED /* @min:%2eisInitialized */] = function () { return _isInitialized; };\r\n // since version 3.3.0\r\n _self.activeStatus = function () { return _activeStatus; };\r\n // since version 3.3.0\r\n // internal\r\n _self._setPendingStatus = function () {\r\n _activeStatus = 3 /* eActiveStatus.PENDING */;\r\n };\r\n // Creating the self.initialize = ()\r\n _self[_DYN_INITIALIZE /* @min:%2einitialize */] = function (config, extensions, logger, notificationManager) {\r\n if (_isUnloading) {\r\n throwError(strSdkUnloadingError);\r\n }\r\n // Make sure core is only initialized once\r\n if (_self[_DYN_IS_INITIALIZED /* @min:%2eisInitialized */]()) {\r\n throwError(\"Core cannot be initialized more than once\");\r\n }\r\n _configHandler = createDynamicConfig(config, defaultConfig, logger || _self[_DYN_LOGGER /* @min:%2elogger */], false);\r\n // Re-assigning the local config property so we don't have any references to the passed value and it can be garbage collected\r\n config = _configHandler.cfg;\r\n // This will be \"re-run\" if the referenced config properties are changed\r\n _addUnloadHook(_configHandler[_DYN_WATCH /* @min:%2ewatch */](function (details) {\r\n var rootCfg = details.cfg;\r\n var isPending = _activeStatus === 3 /* eActiveStatus.PENDING */;\r\n if (isPending) {\r\n // means waiting for previous promises to be resolved, won't apply new changes\r\n return;\r\n }\r\n _initInMemoMaxSize = rootCfg.initInMemoMaxSize || maxInitQueueSize;\r\n // app Insights core only handle ikey and endpointurl, aisku will handle cs\r\n var ikey = rootCfg.instrumentationKey;\r\n var endpointUrl = rootCfg.endpointUrl; // do not need to validate endpoint url, if it is null, default one will be set by sender\r\n if (isNullOrUndefined(ikey)) {\r\n _instrumentationKey = null;\r\n // if new ikey is null, set status to be inactive, all new events will be saved in memory or dropped\r\n _activeStatus = ActiveStatus.INACTIVE;\r\n var msg = \"Please provide instrumentation key\";\r\n if (!_isInitialized) {\r\n // only throw error during initialization\r\n throwError(msg);\r\n }\r\n else {\r\n _throwInternal(_logger, 1 /* eLoggingSeverity.CRITICAL */, 100 /* _eInternalMessageId.InvalidInstrumentationKey */, msg);\r\n _releaseQueues();\r\n }\r\n return;\r\n }\r\n var promises = [];\r\n if (isPromiseLike(ikey)) {\r\n promises[_DYN_PUSH /* @min:%2epush */](ikey);\r\n _instrumentationKey = null; // reset current local ikey variable (otherwise it will always be the previous ikeys if timeout is called before promise cb)\r\n }\r\n else {\r\n // string\r\n _instrumentationKey = ikey;\r\n }\r\n if (isPromiseLike(endpointUrl)) {\r\n promises[_DYN_PUSH /* @min:%2epush */](endpointUrl);\r\n _endpoint = null; // reset current local endpoint variable (otherwise it will always be the previous urls if timeout is called before promise cb)\r\n }\r\n else {\r\n // string or null\r\n _endpoint = endpointUrl;\r\n }\r\n // at least have one promise\r\n if (promises[_DYN_LENGTH /* @min:%2elength */]) {\r\n // reset to false for new dynamic changes\r\n _isStatusSet = false;\r\n _activeStatus = 3 /* eActiveStatus.PENDING */;\r\n var initTimeout = isNotNullOrUndefined(rootCfg.initTimeOut) ? rootCfg.initTimeOut : maxInitTimeout; // rootCfg.initTimeOut could be 0\r\n var allPromises = createSyncAllSettledPromise(promises);\r\n _initTimer = scheduleTimeout(function () {\r\n // set _isStatusSet to true\r\n // set active status\r\n // release queues\r\n _initTimer = null;\r\n if (!_isStatusSet) {\r\n _setStatus();\r\n }\r\n }, initTimeout);\r\n doAwaitResponse(allPromises, function (response) {\r\n try {\r\n if (_isStatusSet) {\r\n // promises take too long to resolve, ignore them\r\n // active status should be set by timeout already\r\n return;\r\n }\r\n if (!response.rejected) {\r\n var values = response[_DYN_VALUE /* @min:%2evalue */];\r\n if (values && values[_DYN_LENGTH /* @min:%2elength */]) {\r\n // ikey\r\n var ikeyRes = values[0];\r\n _instrumentationKey = ikeyRes && ikeyRes[_DYN_VALUE /* @min:%2evalue */];\r\n // endpoint\r\n if (values[_DYN_LENGTH /* @min:%2elength */] > 1) {\r\n var endpointRes = values[1];\r\n _endpoint = endpointRes && endpointRes[_DYN_VALUE /* @min:%2evalue */];\r\n }\r\n }\r\n if (_instrumentationKey) {\r\n // if ikey is null, no need to trigger extra dynamic changes for extensions\r\n config.instrumentationKey = _instrumentationKey; // set config.instrumentationKey for extensions to consume\r\n config.endpointUrl = _endpoint; // set config.endpointUrl for extensions to consume\r\n }\r\n }\r\n // set _isStatusSet to true\r\n // set active status\r\n // release queues\r\n _setStatus();\r\n }\r\n catch (e) {\r\n if (!_isStatusSet) {\r\n _setStatus();\r\n }\r\n }\r\n });\r\n }\r\n else {\r\n // means no promises\r\n _setStatus();\r\n }\r\n //_instrumentationKey = details.cfg.instrumentationKey;\r\n // Mark the extensionConfig and all first level keys as referenced\r\n // This is so that calls to getExtCfg() will always return the same object\r\n // Even when a user may \"re-assign\" the plugin properties (or it's unloaded/reloaded)\r\n var extCfg = details.ref(details.cfg, STR_EXTENSION_CONFIG);\r\n objForEachKey(extCfg, function (key) {\r\n details.ref(extCfg, key);\r\n });\r\n }));\r\n _notificationManager = notificationManager;\r\n // Initialize the debug listener outside of the closure to reduce the retained memory footprint\r\n _debugListener = _initDebugListener(_configHandler, _hookContainer, _notificationManager && _self[_DYN_GET_NOTIFY_MGR /* @min:%2egetNotifyMgr */](), _debugListener);\r\n _initPerfManager();\r\n _self[_DYN_LOGGER /* @min:%2elogger */] = logger;\r\n var cfgExtensions = config[STR_EXTENSIONS /* @min:%2eextensions */];\r\n // Extension validation\r\n _configExtensions = [];\r\n _configExtensions[_DYN_PUSH /* @min:%2epush */].apply(_configExtensions, __spreadArray(__spreadArray([], extensions, false), cfgExtensions, false));\r\n _channelConfig = config[STR_CHANNELS /* @min:%2echannels */];\r\n _initPluginChain(null);\r\n if (!_channels || _channels[_DYN_LENGTH /* @min:%2elength */] === 0) {\r\n throwError(\"No \" + STR_CHANNELS + \" available\");\r\n }\r\n if (_channelConfig && _channelConfig[_DYN_LENGTH /* @min:%2elength */] > 1) {\r\n var teeController = _self[_DYN_GET_PLUGIN /* @min:%2egetPlugin */](\"TeeChannelController\");\r\n if (!teeController || !teeController.plugin) {\r\n _throwInternal(_logger, 1 /* eLoggingSeverity.CRITICAL */, 28 /* _eInternalMessageId.SenderNotInitialized */, \"TeeChannel required\");\r\n }\r\n }\r\n _registerDelayedCfgListener(config, _cfgListeners, _logger);\r\n _cfgListeners = null;\r\n _isInitialized = true;\r\n if (_activeStatus === ActiveStatus.ACTIVE) {\r\n _releaseQueues();\r\n }\r\n };\r\n _self.getChannels = function () {\r\n var controls = [];\r\n if (_channels) {\r\n arrForEach(_channels, function (channel) {\r\n controls[_DYN_PUSH /* @min:%2epush */](channel);\r\n });\r\n }\r\n return objFreeze(controls);\r\n };\r\n _self.track = function (telemetryItem) {\r\n doPerf(_self[STR_GET_PERF_MGR /* @min:%2egetPerfMgr */](), function () { return \"AppInsightsCore:track\"; }, function () {\r\n if (telemetryItem === null) {\r\n _notifyInvalidEvent(telemetryItem);\r\n // throw error\r\n throwError(\"Invalid telemetry item\");\r\n }\r\n // do basic validation before sending it through the pipeline\r\n if (!telemetryItem[_DYN_NAME /* @min:%2ename */] && isNullOrUndefined(telemetryItem[_DYN_NAME /* @min:%2ename */])) {\r\n _notifyInvalidEvent(telemetryItem);\r\n throwError(\"telemetry name required\");\r\n }\r\n // setup default iKey if not passed in\r\n telemetryItem.iKey = telemetryItem.iKey || _instrumentationKey;\r\n // add default timestamp if not passed in\r\n telemetryItem.time = telemetryItem.time || toISOString(new Date());\r\n // Common Schema 4.0\r\n telemetryItem.ver = telemetryItem.ver || \"4.0\";\r\n if (!_isUnloading && _self[_DYN_IS_INITIALIZED /* @min:%2eisInitialized */]() && _activeStatus === ActiveStatus.ACTIVE) {\r\n // Process the telemetry plugin chain\r\n _createTelCtx()[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](telemetryItem);\r\n }\r\n else if (_activeStatus !== ActiveStatus.INACTIVE) {\r\n // Queue events until all extensions are initialized\r\n if (_eventQueue[_DYN_LENGTH /* @min:%2elength */] <= _initInMemoMaxSize) {\r\n // set limit, if full, stop adding new events\r\n _eventQueue[_DYN_PUSH /* @min:%2epush */](telemetryItem);\r\n }\r\n }\r\n }, function () { return ({ item: telemetryItem }); }, !(telemetryItem.sync));\r\n };\r\n _self[_DYN_GET_PROCESS_TEL_CONT2 /* @min:%2egetProcessTelContext */] = _createTelCtx;\r\n _self[_DYN_GET_NOTIFY_MGR /* @min:%2egetNotifyMgr */] = function () {\r\n if (!_notificationManager) {\r\n _notificationManager = new NotificationManager(_configHandler.cfg);\r\n // For backward compatibility only\r\n _self[strNotificationManager] = _notificationManager;\r\n }\r\n return _notificationManager;\r\n };\r\n /**\r\n * Adds a notification listener. The SDK calls methods on the listener when an appropriate notification is raised.\r\n * The added plugins must raise notifications. If the plugins do not implement the notifications, then no methods will be\r\n * called.\r\n * @param listener - An INotificationListener object.\r\n */\r\n _self[_DYN_ADD_NOTIFICATION_LIS1 /* @min:%2eaddNotificationListener */] = function (listener) {\r\n _self.getNotifyMgr()[_DYN_ADD_NOTIFICATION_LIS1 /* @min:%2eaddNotificationListener */](listener);\r\n };\r\n /**\r\n * Removes all instances of the listener.\r\n * @param listener - INotificationListener to remove.\r\n */\r\n _self[_DYN_REMOVE_NOTIFICATION_0 /* @min:%2eremoveNotificationListener */] = function (listener) {\r\n if (_notificationManager) {\r\n _notificationManager[_DYN_REMOVE_NOTIFICATION_0 /* @min:%2eremoveNotificationListener */](listener);\r\n }\r\n };\r\n _self.getCookieMgr = function () {\r\n if (!_cookieManager) {\r\n _cookieManager = createCookieMgr(_configHandler.cfg, _self[_DYN_LOGGER /* @min:%2elogger */]);\r\n }\r\n return _cookieManager;\r\n };\r\n _self.setCookieMgr = function (cookieMgr) {\r\n if (_cookieManager !== cookieMgr) {\r\n runTargetUnload(_cookieManager, false);\r\n _cookieManager = cookieMgr;\r\n }\r\n };\r\n _self[STR_GET_PERF_MGR /* @min:%2egetPerfMgr */] = function () {\r\n return _perfManager || _cfgPerfManager || getGblPerfMgr();\r\n };\r\n _self.setPerfMgr = function (perfMgr) {\r\n _perfManager = perfMgr;\r\n };\r\n _self.eventCnt = function () {\r\n return _eventQueue[_DYN_LENGTH /* @min:%2elength */];\r\n };\r\n _self.releaseQueue = function () {\r\n if (_isInitialized && _eventQueue[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n var eventQueue = _eventQueue;\r\n _eventQueue = [];\r\n if (_activeStatus === 2 /* eActiveStatus.ACTIVE */) {\r\n arrForEach(eventQueue, function (event) {\r\n event.iKey = event.iKey || _instrumentationKey;\r\n _createTelCtx()[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](event);\r\n });\r\n }\r\n else {\r\n // new one for msg ikey\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 20 /* _eInternalMessageId.FailedToSendQueuedTelemetry */, \"core init status is not active\");\r\n }\r\n }\r\n };\r\n _self.pollInternalLogs = function (eventName) {\r\n _internalLogsEventName = eventName || null;\r\n _forceStopInternalLogPoller = false;\r\n _internalLogPoller && _internalLogPoller[_DYN_CANCEL /* @min:%2ecancel */]();\r\n return _startLogPoller(true);\r\n };\r\n function _setStatus() {\r\n _isStatusSet = true;\r\n if (isNullOrUndefined(_instrumentationKey)) {\r\n _activeStatus = ActiveStatus.INACTIVE;\r\n _throwInternal(_logger, 1 /* eLoggingSeverity.CRITICAL */, 112 /* _eInternalMessageId.InitPromiseException */, \"ikey can't be resolved from promises\");\r\n }\r\n else {\r\n _activeStatus = ActiveStatus.ACTIVE;\r\n }\r\n _releaseQueues();\r\n }\r\n function _releaseQueues() {\r\n if (_isInitialized) {\r\n _self.releaseQueue();\r\n _self.pollInternalLogs();\r\n }\r\n }\r\n function _startLogPoller(alwaysStart) {\r\n if ((!_internalLogPoller || !_internalLogPoller[_DYN_ENABLED /* @min:%2eenabled */]) && !_forceStopInternalLogPoller) {\r\n var shouldStart = alwaysStart || (_logger && _logger.queue[_DYN_LENGTH /* @min:%2elength */] > 0);\r\n if (shouldStart) {\r\n if (!_internalLogPollerListening) {\r\n _internalLogPollerListening = true;\r\n // listen for any configuration changes so that changes to the\r\n // interval will cause the timer to be re-initialized\r\n _addUnloadHook(_configHandler[_DYN_WATCH /* @min:%2ewatch */](function (details) {\r\n var interval = details.cfg.diagnosticLogInterval;\r\n if (!interval || !(interval > 0)) {\r\n interval = 10000;\r\n }\r\n var isRunning = false;\r\n if (_internalLogPoller) {\r\n // It was already created so remember it's running and cancel\r\n isRunning = _internalLogPoller[_DYN_ENABLED /* @min:%2eenabled */];\r\n _internalLogPoller[_DYN_CANCEL /* @min:%2ecancel */]();\r\n }\r\n // Create / reconfigure\r\n _internalLogPoller = createTimeout(_flushInternalLogs, interval);\r\n _internalLogPoller.unref();\r\n // Restart if previously running\r\n _internalLogPoller[_DYN_ENABLED /* @min:%2eenabled */] = isRunning;\r\n }));\r\n }\r\n _internalLogPoller[_DYN_ENABLED /* @min:%2eenabled */] = true;\r\n }\r\n }\r\n return _internalLogPoller;\r\n }\r\n _self[_DYN_STOP_POLLING_INTERNA3 /* @min:%2estopPollingInternalLogs */] = function () {\r\n _forceStopInternalLogPoller = true;\r\n _internalLogPoller && _internalLogPoller[_DYN_CANCEL /* @min:%2ecancel */]();\r\n _flushInternalLogs();\r\n };\r\n // Add addTelemetryInitializer\r\n proxyFunctions(_self, function () { return _telemetryInitializerPlugin; }, [\"addTelemetryInitializer\"]);\r\n _self[_DYN_UNLOAD /* @min:%2eunload */] = function (isAsync, unloadComplete, cbTimeout) {\r\n if (isAsync === void 0) { isAsync = true; }\r\n if (!_isInitialized) {\r\n // The SDK is not initialized\r\n throwError(strSdkNotInitialized);\r\n }\r\n // Check if the SDK still unloading so throw\r\n if (_isUnloading) {\r\n // The SDK is already unloading\r\n throwError(strSdkUnloadingError);\r\n }\r\n var unloadState = {\r\n reason: 50 /* TelemetryUnloadReason.SdkUnload */,\r\n isAsync: isAsync,\r\n flushComplete: false\r\n };\r\n var result;\r\n if (isAsync && !unloadComplete) {\r\n result = createPromise(function (resolve) {\r\n // Set the callback to the promise resolve callback\r\n unloadComplete = resolve;\r\n });\r\n }\r\n var processUnloadCtx = createProcessTelemetryUnloadContext(_getPluginChain(), _self);\r\n processUnloadCtx[_DYN_ON_COMPLETE /* @min:%2eonComplete */](function () {\r\n _hookContainer.run(_self[_DYN_LOGGER /* @min:%2elogger */]);\r\n // Run any \"unload\" functions for the _cookieManager, _notificationManager and _logger\r\n doUnloadAll([_cookieManager, _notificationManager, _logger], isAsync, function () {\r\n _initDefaults();\r\n unloadComplete && unloadComplete(unloadState);\r\n });\r\n }, _self);\r\n function _doUnload(flushComplete) {\r\n unloadState.flushComplete = flushComplete;\r\n _isUnloading = true;\r\n // Run all of the unload handlers first (before unloading the plugins)\r\n _unloadHandlers.run(processUnloadCtx, unloadState);\r\n // Stop polling the internal logs\r\n _self[_DYN_STOP_POLLING_INTERNA3 /* @min:%2estopPollingInternalLogs */]();\r\n // Start unloading the components, from this point onwards the SDK should be considered to be in an unstable state\r\n processUnloadCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](unloadState);\r\n }\r\n _flushInternalLogs();\r\n if (!_flushChannels(isAsync, _doUnload, 6 /* SendRequestReason.SdkUnload */, cbTimeout)) {\r\n _doUnload(false);\r\n }\r\n return result;\r\n };\r\n _self[_DYN_GET_PLUGIN /* @min:%2egetPlugin */] = _getPlugin;\r\n _self.addPlugin = function (plugin, replaceExisting, isAsync, addCb) {\r\n if (!plugin) {\r\n addCb && addCb(false);\r\n _logOrThrowError(strValidationError);\r\n return;\r\n }\r\n var existingPlugin = _getPlugin(plugin[_DYN_IDENTIFIER /* @min:%2eidentifier */]);\r\n if (existingPlugin && !replaceExisting) {\r\n addCb && addCb(false);\r\n _logOrThrowError(\"Plugin [\" + plugin[_DYN_IDENTIFIER /* @min:%2eidentifier */] + \"] is already loaded!\");\r\n return;\r\n }\r\n var updateState = {\r\n reason: 16 /* TelemetryUpdateReason.PluginAdded */\r\n };\r\n function _addPlugin(removed) {\r\n _configExtensions[_DYN_PUSH /* @min:%2epush */](plugin);\r\n updateState.added = [plugin];\r\n // Re-Initialize the plugin chain\r\n _initPluginChain(updateState);\r\n addCb && addCb(true);\r\n }\r\n if (existingPlugin) {\r\n var removedPlugins_1 = [existingPlugin.plugin];\r\n var unloadState = {\r\n reason: 2 /* TelemetryUnloadReason.PluginReplace */,\r\n isAsync: !!isAsync\r\n };\r\n _removePlugins(removedPlugins_1, unloadState, function (removed) {\r\n if (!removed) {\r\n // Previous plugin was successfully removed or was not installed\r\n addCb && addCb(false);\r\n }\r\n else {\r\n updateState.removed = removedPlugins_1;\r\n updateState.reason |= 32 /* TelemetryUpdateReason.PluginRemoved */;\r\n _addPlugin(true);\r\n }\r\n });\r\n }\r\n else {\r\n _addPlugin(false);\r\n }\r\n };\r\n _self.updateCfg = function (newConfig, mergeExisting) {\r\n if (mergeExisting === void 0) { mergeExisting = true; }\r\n var updateState;\r\n if (_self[_DYN_IS_INITIALIZED /* @min:%2eisInitialized */]()) {\r\n updateState = {\r\n reason: 1 /* TelemetryUpdateReason.ConfigurationChanged */,\r\n cfg: _configHandler.cfg,\r\n oldCfg: deepExtend({}, _configHandler.cfg),\r\n newConfig: deepExtend({}, newConfig),\r\n merge: mergeExisting\r\n };\r\n newConfig = updateState.newConfig;\r\n var cfg = _configHandler.cfg;\r\n // replace the immutable (if initialized) values\r\n // We don't currently allow updating the extensions and channels via the update config\r\n // So overwriting any user provided values to reuse the existing values\r\n newConfig[STR_EXTENSIONS /* @min:%2eextensions */] = cfg[STR_EXTENSIONS /* @min:%2eextensions */];\r\n newConfig[STR_CHANNELS /* @min:%2echannels */] = cfg[STR_CHANNELS /* @min:%2echannels */];\r\n }\r\n // Explicitly blocking any previous config watchers so that they don't get called because\r\n // of this bulk update (Probably not necessary)\r\n _configHandler._block(function (details) {\r\n // Lets assign the new values to the existing config either overwriting or re-assigning\r\n var theConfig = details.cfg;\r\n _deepMergeConfig(details, theConfig, newConfig, mergeExisting);\r\n if (!mergeExisting) {\r\n // Remove (unassign) the values \"missing\" from the newConfig and also not in the default config\r\n objForEachKey(theConfig, function (key) {\r\n if (!objHasOwn(newConfig, key)) {\r\n // Set the value to undefined\r\n details.set(theConfig, key, UNDEFINED_VALUE);\r\n }\r\n });\r\n }\r\n // Apply defaults to the new config\r\n details.setDf(theConfig, defaultConfig);\r\n }, true);\r\n // Now execute all of the listeners (synchronously) so they update their values immediately\r\n _configHandler.notify();\r\n if (updateState) {\r\n _doUpdate(updateState);\r\n }\r\n };\r\n _self.evtNamespace = function () {\r\n return _evtNamespace;\r\n };\r\n _self.flush = _flushChannels;\r\n _self.getTraceCtx = function (createNew) {\r\n if (!_traceCtx) {\r\n _traceCtx = createDistributedTraceContext();\r\n }\r\n return _traceCtx;\r\n };\r\n _self.setTraceCtx = function (traceCtx) {\r\n _traceCtx = traceCtx || null;\r\n };\r\n _self.addUnloadHook = _addUnloadHook;\r\n // Create the addUnloadCb\r\n proxyFunctionAs(_self, \"addUnloadCb\", function () { return _unloadHandlers; }, \"add\");\r\n _self.onCfgChange = function (handler) {\r\n var unloadHook;\r\n if (!_isInitialized) {\r\n unloadHook = _addDelayedCfgListener(_cfgListeners, handler);\r\n }\r\n else {\r\n unloadHook = onConfigChange(_configHandler.cfg, handler, _self[_DYN_LOGGER /* @min:%2elogger */]);\r\n }\r\n return _createUnloadHook(unloadHook);\r\n };\r\n _self.getWParam = function () {\r\n return (hasDocument() || !!_configHandler.cfg.enableWParam) ? 0 : -1;\r\n };\r\n function _setPluginVersions() {\r\n var thePlugins = {};\r\n _pluginVersionStringArr = [];\r\n var _addPluginVersions = function (plugins) {\r\n if (plugins) {\r\n arrForEach(plugins, function (plugin) {\r\n if (plugin[_DYN_IDENTIFIER /* @min:%2eidentifier */] && plugin[_DYN_VERSION /* @min:%2eversion */] && !thePlugins[plugin.identifier]) {\r\n var ver = plugin[_DYN_IDENTIFIER /* @min:%2eidentifier */] + \"=\" + plugin[_DYN_VERSION /* @min:%2eversion */];\r\n _pluginVersionStringArr[_DYN_PUSH /* @min:%2epush */](ver);\r\n thePlugins[plugin.identifier] = plugin;\r\n }\r\n });\r\n }\r\n };\r\n _addPluginVersions(_channels);\r\n if (_channelConfig) {\r\n arrForEach(_channelConfig, function (channels) {\r\n _addPluginVersions(channels);\r\n });\r\n }\r\n _addPluginVersions(_configExtensions);\r\n }\r\n function _initDefaults() {\r\n _isInitialized = false;\r\n // Use a default logger so initialization errors are not dropped on the floor with full logging\r\n _configHandler = createDynamicConfig({}, defaultConfig, _self[_DYN_LOGGER /* @min:%2elogger */]);\r\n // Set the logging level to critical so that any critical initialization failures are displayed on the console\r\n _configHandler.cfg[_DYN_LOGGING_LEVEL_CONSOL4 /* @min:%2eloggingLevelConsole */] = 1 /* eLoggingSeverity.CRITICAL */;\r\n // Define _self.config\r\n objDefine(_self, \"config\", {\r\n g: function () { return _configHandler.cfg; },\r\n s: function (newValue) {\r\n _self.updateCfg(newValue, false);\r\n }\r\n });\r\n objDefine(_self, \"pluginVersionStringArr\", {\r\n g: function () {\r\n if (!_pluginVersionStringArr) {\r\n _setPluginVersions();\r\n }\r\n return _pluginVersionStringArr;\r\n }\r\n });\r\n objDefine(_self, \"pluginVersionString\", {\r\n g: function () {\r\n if (!_pluginVersionString) {\r\n if (!_pluginVersionStringArr) {\r\n _setPluginVersions();\r\n }\r\n _pluginVersionString = _pluginVersionStringArr.join(\";\");\r\n }\r\n return _pluginVersionString || STR_EMPTY;\r\n }\r\n });\r\n objDefine(_self, \"logger\", {\r\n g: function () {\r\n if (!_logger) {\r\n _logger = new DiagnosticLogger(_configHandler.cfg);\r\n _configHandler[_DYN_LOGGER /* @min:%2elogger */] = _logger;\r\n }\r\n return _logger;\r\n },\r\n s: function (newLogger) {\r\n _configHandler[_DYN_LOGGER /* @min:%2elogger */] = newLogger;\r\n if (_logger !== newLogger) {\r\n runTargetUnload(_logger, false);\r\n _logger = newLogger;\r\n }\r\n }\r\n });\r\n _self[_DYN_LOGGER /* @min:%2elogger */] = new DiagnosticLogger(_configHandler.cfg);\r\n _extensions = [];\r\n var cfgExtensions = _self.config[STR_EXTENSIONS /* @min:%2eextensions */] || [];\r\n cfgExtensions.splice(0, cfgExtensions[_DYN_LENGTH /* @min:%2elength */]);\r\n arrAppend(cfgExtensions, _extensions);\r\n _telemetryInitializerPlugin = new TelemetryInitializerPlugin();\r\n _eventQueue = [];\r\n runTargetUnload(_notificationManager, false);\r\n _notificationManager = null;\r\n _perfManager = null;\r\n _cfgPerfManager = null;\r\n runTargetUnload(_cookieManager, false);\r\n _cookieManager = null;\r\n _pluginChain = null;\r\n _configExtensions = [];\r\n _channelConfig = null;\r\n _channels = null;\r\n _isUnloading = false;\r\n _internalLogsEventName = null;\r\n _evtNamespace = createUniqueNamespace(\"AIBaseCore\", true);\r\n _unloadHandlers = createUnloadHandlerContainer();\r\n _traceCtx = null;\r\n _instrumentationKey = null;\r\n _hookContainer = createUnloadHookContainer();\r\n _cfgListeners = [];\r\n _pluginVersionString = null;\r\n _pluginVersionStringArr = null;\r\n _forceStopInternalLogPoller = false;\r\n _internalLogPoller = null;\r\n _internalLogPollerListening = false;\r\n _activeStatus = 0 /* eActiveStatus.NONE */; // default is None\r\n _endpoint = null;\r\n _initInMemoMaxSize = null;\r\n _isStatusSet = false;\r\n _initTimer = null;\r\n }\r\n function _createTelCtx() {\r\n var theCtx = createProcessTelemetryContext(_getPluginChain(), _configHandler.cfg, _self);\r\n theCtx[_DYN_ON_COMPLETE /* @min:%2eonComplete */](_startLogPoller);\r\n return theCtx;\r\n }\r\n // Initialize or Re-initialize the plugins\r\n function _initPluginChain(updateState) {\r\n // Extension validation\r\n var theExtensions = _validateExtensions(_self[_DYN_LOGGER /* @min:%2elogger */], ChannelControllerPriority, _configExtensions);\r\n _pluginChain = null;\r\n _pluginVersionString = null;\r\n _pluginVersionStringArr = null;\r\n // Get the primary channel queue and include as part of the normal extensions\r\n _channels = (_channelConfig || [])[0] || [];\r\n // Add any channels provided in the extensions and sort them\r\n _channels = sortPlugins(arrAppend(_channels, theExtensions[STR_CHANNELS /* @min:%2echannels */]));\r\n // Create an array of all extensions, including the _channels\r\n var allExtensions = arrAppend(sortPlugins(theExtensions[STR_CORE /* @min:%2ecore */]), _channels);\r\n // Required to allow plugins to call core.getPlugin() during their own initialization\r\n _extensions = objFreeze(allExtensions);\r\n // This has a side effect of adding the extensions passed during initialization\r\n // into the config.extensions, so you can see all of the extensions loaded.\r\n // This will also get updated by the addPlugin() and remove plugin code.\r\n var cfgExtensions = _self.config[STR_EXTENSIONS /* @min:%2eextensions */] || [];\r\n cfgExtensions.splice(0, cfgExtensions[_DYN_LENGTH /* @min:%2elength */]);\r\n arrAppend(cfgExtensions, _extensions);\r\n var rootCtx = _createTelCtx();\r\n // Initializing the channels first\r\n if (_channels && _channels[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n initializePlugins(rootCtx[_DYN_CREATE_NEW /* @min:%2ecreateNew */](_channels), allExtensions);\r\n }\r\n // Now initialize the normal extensions (explicitly not including the _channels as this can cause duplicate initialization)\r\n initializePlugins(rootCtx, allExtensions);\r\n if (updateState) {\r\n _doUpdate(updateState);\r\n }\r\n }\r\n function _getPlugin(pluginIdentifier) {\r\n var theExt = null;\r\n var thePlugin = null;\r\n var channelHosts = [];\r\n arrForEach(_extensions, function (ext) {\r\n if (ext[_DYN_IDENTIFIER /* @min:%2eidentifier */] === pluginIdentifier && ext !== _telemetryInitializerPlugin) {\r\n thePlugin = ext;\r\n return -1;\r\n }\r\n if (ext.getChannel) {\r\n channelHosts[_DYN_PUSH /* @min:%2epush */](ext);\r\n }\r\n });\r\n if (!thePlugin && channelHosts[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n arrForEach(channelHosts, function (host) {\r\n thePlugin = host.getChannel(pluginIdentifier);\r\n if (!thePlugin) {\r\n return -1;\r\n }\r\n });\r\n }\r\n if (thePlugin) {\r\n theExt = {\r\n plugin: thePlugin,\r\n setEnabled: function (enabled) {\r\n _getPluginState(thePlugin)[STR_DISABLED] = !enabled;\r\n },\r\n isEnabled: function () {\r\n var pluginState = _getPluginState(thePlugin);\r\n return !pluginState[_DYN_TEARDOWN /* @min:%2eteardown */] && !pluginState[STR_DISABLED];\r\n },\r\n remove: function (isAsync, removeCb) {\r\n if (isAsync === void 0) { isAsync = true; }\r\n var pluginsToRemove = [thePlugin];\r\n var unloadState = {\r\n reason: 1 /* TelemetryUnloadReason.PluginUnload */,\r\n isAsync: isAsync\r\n };\r\n _removePlugins(pluginsToRemove, unloadState, function (removed) {\r\n if (removed) {\r\n // Re-Initialize the plugin chain\r\n _initPluginChain({\r\n reason: 32 /* TelemetryUpdateReason.PluginRemoved */,\r\n removed: pluginsToRemove\r\n });\r\n }\r\n removeCb && removeCb(removed);\r\n });\r\n }\r\n };\r\n }\r\n return theExt;\r\n }\r\n function _getPluginChain() {\r\n if (!_pluginChain) {\r\n // copy the collection of extensions\r\n var extensions = (_extensions || []).slice();\r\n // During add / remove this may get called again, so don't read if already present\r\n if (arrIndexOf(extensions, _telemetryInitializerPlugin) === -1) {\r\n extensions[_DYN_PUSH /* @min:%2epush */](_telemetryInitializerPlugin);\r\n }\r\n _pluginChain = createTelemetryProxyChain(sortPlugins(extensions), _configHandler.cfg, _self);\r\n }\r\n return _pluginChain;\r\n }\r\n function _removePlugins(thePlugins, unloadState, removeComplete) {\r\n if (thePlugins && thePlugins[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n var unloadChain = createTelemetryProxyChain(thePlugins, _configHandler.cfg, _self);\r\n var unloadCtx = createProcessTelemetryUnloadContext(unloadChain, _self);\r\n unloadCtx[_DYN_ON_COMPLETE /* @min:%2eonComplete */](function () {\r\n var removed = false;\r\n // Remove the listed config extensions\r\n var newConfigExtensions = [];\r\n arrForEach(_configExtensions, function (plugin, idx) {\r\n if (!_isPluginPresent(plugin, thePlugins)) {\r\n newConfigExtensions[_DYN_PUSH /* @min:%2epush */](plugin);\r\n }\r\n else {\r\n removed = true;\r\n }\r\n });\r\n _configExtensions = newConfigExtensions;\r\n _pluginVersionString = null;\r\n _pluginVersionStringArr = null;\r\n // Re-Create the channel config\r\n var newChannelConfig = [];\r\n if (_channelConfig) {\r\n arrForEach(_channelConfig, function (queue, idx) {\r\n var newQueue = [];\r\n arrForEach(queue, function (channel) {\r\n if (!_isPluginPresent(channel, thePlugins)) {\r\n newQueue[_DYN_PUSH /* @min:%2epush */](channel);\r\n }\r\n else {\r\n removed = true;\r\n }\r\n });\r\n newChannelConfig[_DYN_PUSH /* @min:%2epush */](newQueue);\r\n });\r\n _channelConfig = newChannelConfig;\r\n }\r\n removeComplete && removeComplete(removed);\r\n _startLogPoller();\r\n });\r\n unloadCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](unloadState);\r\n }\r\n else {\r\n removeComplete(false);\r\n }\r\n }\r\n function _flushInternalLogs() {\r\n if (_logger && _logger.queue) {\r\n var queue = _logger.queue.slice(0);\r\n _logger.queue[_DYN_LENGTH /* @min:%2elength */] = 0;\r\n arrForEach(queue, function (logMessage) {\r\n var item = {\r\n name: _internalLogsEventName ? _internalLogsEventName : \"InternalMessageId: \" + logMessage[_DYN_MESSAGE_ID /* @min:%2emessageId */],\r\n iKey: _instrumentationKey,\r\n time: toISOString(new Date()),\r\n baseType: _InternalLogMessage.dataType,\r\n baseData: { message: logMessage[_DYN_MESSAGE /* @min:%2emessage */] }\r\n };\r\n _self.track(item);\r\n });\r\n }\r\n }\r\n function _flushChannels(isAsync, callBack, sendReason, cbTimeout) {\r\n // Setting waiting to one so that we don't call the callBack until we finish iterating\r\n var waiting = 1;\r\n var doneIterating = false;\r\n var cbTimer = null;\r\n cbTimeout = cbTimeout || 5000;\r\n function doCallback() {\r\n waiting--;\r\n if (doneIterating && waiting === 0) {\r\n cbTimer && cbTimer[_DYN_CANCEL /* @min:%2ecancel */]();\r\n cbTimer = null;\r\n callBack && callBack(doneIterating);\r\n callBack = null;\r\n }\r\n }\r\n if (_channels && _channels[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n var flushCtx = _createTelCtx()[_DYN_CREATE_NEW /* @min:%2ecreateNew */](_channels);\r\n flushCtx.iterate(function (plugin) {\r\n if (plugin.flush) {\r\n waiting++;\r\n var handled_1 = false;\r\n // Not all channels will call this callback for every scenario\r\n if (!plugin.flush(isAsync, function () {\r\n handled_1 = true;\r\n doCallback();\r\n }, sendReason)) {\r\n if (!handled_1) {\r\n // If any channel doesn't return true and it didn't call the callback, then we should assume that the callback\r\n // will never be called, so use a timeout to allow the channel(s) some time to \"finish\" before triggering any\r\n // followup function (such as unloading)\r\n if (isAsync && cbTimer == null) {\r\n cbTimer = scheduleTimeout(function () {\r\n cbTimer = null;\r\n doCallback();\r\n }, cbTimeout);\r\n }\r\n else {\r\n doCallback();\r\n }\r\n }\r\n }\r\n }\r\n });\r\n }\r\n doneIterating = true;\r\n doCallback();\r\n return true;\r\n }\r\n function _initPerfManager() {\r\n // Save the previous config based performance manager creator to avoid creating new perf manager instances if unchanged\r\n var prevCfgPerfMgr;\r\n // Will get recalled if any referenced config values are changed\r\n _addUnloadHook(_configHandler[_DYN_WATCH /* @min:%2ewatch */](function (details) {\r\n var enablePerfMgr = details.cfg.enablePerfMgr;\r\n if (enablePerfMgr) {\r\n var createPerfMgr = details.cfg[STR_CREATE_PERF_MGR /* @min:%2ecreatePerfMgr */];\r\n // for preCfgPerfMgr = createPerfMgr = null\r\n // initial createPerfMgr function should be _createPerfManager\r\n if ((prevCfgPerfMgr !== createPerfMgr) || !prevCfgPerfMgr) {\r\n if (!createPerfMgr) {\r\n createPerfMgr = _createPerfManager;\r\n }\r\n // Set the performance manager creation function if not defined\r\n getSetValue(details.cfg, STR_CREATE_PERF_MGR, createPerfMgr);\r\n prevCfgPerfMgr = createPerfMgr;\r\n // Remove any existing config based performance manager\r\n _cfgPerfManager = null;\r\n }\r\n // Only create the performance manager if it's not already created or manually set\r\n if (!_perfManager && !_cfgPerfManager && isFunction(createPerfMgr)) {\r\n // Create a new config based performance manager\r\n _cfgPerfManager = createPerfMgr(_self, _self[_DYN_GET_NOTIFY_MGR /* @min:%2egetNotifyMgr */]());\r\n }\r\n }\r\n else {\r\n // Remove any existing config based performance manager\r\n _cfgPerfManager = null;\r\n // Clear the previous cached value so it can be GC'd\r\n prevCfgPerfMgr = null;\r\n }\r\n }));\r\n }\r\n function _doUpdate(updateState) {\r\n var updateCtx = createProcessTelemetryUpdateContext(_getPluginChain(), _self);\r\n updateCtx[_DYN_ON_COMPLETE /* @min:%2eonComplete */](_startLogPoller);\r\n if (!_self._updateHook || _self._updateHook(updateCtx, updateState) !== true) {\r\n updateCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](updateState);\r\n }\r\n }\r\n function _logOrThrowError(message) {\r\n var logger = _self[_DYN_LOGGER /* @min:%2elogger */];\r\n if (logger) {\r\n // there should always be a logger\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 73 /* _eInternalMessageId.PluginException */, message);\r\n _startLogPoller();\r\n }\r\n else {\r\n throwError(message);\r\n }\r\n }\r\n function _notifyInvalidEvent(telemetryItem) {\r\n var manager = _self[_DYN_GET_NOTIFY_MGR /* @min:%2egetNotifyMgr */]();\r\n if (manager) {\r\n manager[STR_EVENTS_DISCARDED /* @min:%2eeventsDiscarded */]([telemetryItem], 2 /* eEventsDiscardedReason.InvalidEvent */);\r\n }\r\n }\r\n function _addUnloadHook(hooks) {\r\n _hookContainer.add(hooks);\r\n }\r\n });\r\n }\r\n// Removed Stub for AppInsightsCore.prototype.initialize.\r\n// Removed Stub for AppInsightsCore.prototype.getChannels.\r\n// Removed Stub for AppInsightsCore.prototype.track.\r\n// Removed Stub for AppInsightsCore.prototype.getProcessTelContext.\r\n// Removed Stub for AppInsightsCore.prototype.getNotifyMgr.\r\n// Removed Stub for AppInsightsCore.prototype.addNotificationListener.\r\n// Removed Stub for AppInsightsCore.prototype.removeNotificationListener.\r\n// Removed Stub for AppInsightsCore.prototype.getCookieMgr.\r\n// Removed Stub for AppInsightsCore.prototype.setCookieMgr.\r\n// Removed Stub for AppInsightsCore.prototype.getPerfMgr.\r\n// Removed Stub for AppInsightsCore.prototype.setPerfMgr.\r\n// Removed Stub for AppInsightsCore.prototype.eventCnt.\r\n// Removed Stub for AppInsightsCore.prototype.pollInternalLogs.\r\n// Removed Stub for AppInsightsCore.prototype.stopPollingInternalLogs.\r\n// Removed Stub for AppInsightsCore.prototype.addTelemetryInitializer.\r\n// Removed Stub for AppInsightsCore.prototype.unload.\r\n// Removed Stub for AppInsightsCore.prototype.getPlugin.\r\n// Removed Stub for AppInsightsCore.prototype.addPlugin.\r\n// Removed Stub for AppInsightsCore.prototype.updateCfg.\r\n// Removed Stub for AppInsightsCore.prototype.evtNamespace.\r\n// Removed Stub for AppInsightsCore.prototype.addUnloadCb.\r\n// Removed Stub for AppInsightsCore.prototype.flush.\r\n// Removed Stub for AppInsightsCore.prototype.getTraceCtx.\r\n// Removed Stub for AppInsightsCore.prototype.setTraceCtx.\r\n// Removed Stub for AppInsightsCore.prototype.addUnloadHook.\r\n// Removed Stub for AppInsightsCore.prototype.onCfgChange.\r\n// Removed Stub for AppInsightsCore.prototype.activeStatus.\r\n// Removed Stub for AppInsightsCore.prototype._setPendingStatus.\r\n// Removed Stub for AppInsightsCore.prototype.releaseQueue.\r\n// Removed Stub for AppInsightsCore.prototype._updateHook.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n AppInsightsCore.__ieDyn=1;\n\n return AppInsightsCore;\r\n}());\r\nexport { AppInsightsCore };\r\n//# sourceMappingURL=AppInsightsCore.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { dumpObj } from \"@nevware21/ts-utils\";\r\nimport { _DYN_ITEMS_RECEIVED, _DYN_LENGTH, _DYN_NAME } from \"../__DynamicConstants\";\r\nimport { _throwInternal } from \"./DiagnosticLogger\";\r\nimport { getJSON } from \"./EnvUtils\";\r\n/**\r\n * Parses the response from the backend.\r\n * @param response - XMLHttpRequest or XDomainRequest response\r\n */\r\nexport function parseResponse(response, diagLog) {\r\n try {\r\n if (response && response !== \"\") {\r\n var result = getJSON().parse(response);\r\n if (result && result[_DYN_ITEMS_RECEIVED /* @min:%2eitemsReceived */] && result[_DYN_ITEMS_RECEIVED /* @min:%2eitemsReceived */] >= result.itemsAccepted &&\r\n result.itemsReceived - result.itemsAccepted === result.errors[_DYN_LENGTH /* @min:%2elength */]) {\r\n return result;\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(diagLog, 1 /* eLoggingSeverity.CRITICAL */, 43 /* _eInternalMessageId.InvalidBackendResponse */, \"Cannot parse the response. \" + (e[_DYN_NAME /* @min:%2ename */] || dumpObj(e)), {\r\n response: response\r\n });\r\n }\r\n return null;\r\n}\r\n//# sourceMappingURL=ResponseHelpers.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { createPromise, doAwaitResponse } from \"@nevware21/ts-async\";\r\nimport { arrForEach, dumpObj, getNavigator, getWindow, isFunction, objKeys } from \"@nevware21/ts-utils\";\r\nimport { _DYN_DATA, _DYN_HEADERS, _DYN_INITIALIZE, _DYN_LENGTH, _DYN_MESSAGE, _DYN_REPLACE, _DYN_STATUS, _DYN_TIMEOUT, _DYN_TO_LOWER_CASE, _DYN_URL_STRING, _DYN_VALUE, _DYN__DO_TEARDOWN } from \"../__DynamicConstants\";\r\nimport { DisabledPropertyName } from \"./Constants\";\r\nimport { _throwInternal, _warnToConsole } from \"./DiagnosticLogger\";\r\nimport { getLocation, isBeaconsSupported, isFetchSupported, isXhrSupported, useXDomainRequest } from \"./EnvUtils\";\r\nimport { _getAllResponseHeaders, formatErrorMessageXdr, formatErrorMessageXhr, getResponseText, openXhr } from \"./HelperFuncs\";\r\nvar STR_EMPTY = \"\";\r\nvar STR_NO_RESPONSE_BODY = \"NoResponseBody\";\r\nvar _noResponseQs = \"&\" + STR_NO_RESPONSE_BODY + \"=true\";\r\nvar STR_POST_METHOD = \"POST\";\r\n/**\r\n * This Internal component\r\n * Manager SendPost functions\r\n * SendPostManger\r\n * @internal for internal use only\r\n */\r\nvar SenderPostManager = /** @class */ (function () {\r\n function SenderPostManager() {\r\n var _syncFetchPayload = 0; // Keep track of the outstanding sync fetch payload total (as sync fetch has limits)\r\n var _enableSendPromise;\r\n var _isInitialized;\r\n var _diagLog;\r\n var _isOneDs;\r\n var _onCompleteFuncs;\r\n var _disableCredentials;\r\n var _fetchCredentials;\r\n var _fallbackInst;\r\n var _disableXhr;\r\n var _disableBeacon;\r\n var _disableBeaconSync;\r\n var _disableFetchKeepAlive;\r\n var _addNoResponse;\r\n var _timeoutWrapper;\r\n dynamicProto(SenderPostManager, this, function (_self, _base) {\r\n var _sendCredentials = true; // for 1ds\r\n _initDefaults();\r\n _self[_DYN_INITIALIZE /* @min:%2einitialize */] = function (config, diagLog) {\r\n _diagLog = diagLog;\r\n if (_isInitialized) {\r\n _throwInternal(_diagLog, 1 /* eLoggingSeverity.CRITICAL */, 28 /* _eInternalMessageId.SenderNotInitialized */, \"Sender is already initialized\");\r\n }\r\n _self.SetConfig(config);\r\n _isInitialized = true;\r\n };\r\n _self[\"_getDbgPlgTargets\"] = function () {\r\n return [_isInitialized, _isOneDs, _disableCredentials, _enableSendPromise];\r\n };\r\n // This componet might get its config from sender, offline sender, 1ds post\r\n // so set this function to mock dynamic changes\r\n _self.SetConfig = function (config) {\r\n try {\r\n _onCompleteFuncs = config.senderOnCompleteCallBack || {};\r\n _disableCredentials = !!config.disableCredentials;\r\n _fetchCredentials = config.fetchCredentials;\r\n _isOneDs = !!config.isOneDs;\r\n _enableSendPromise = !!config.enableSendPromise;\r\n _disableXhr = !!config.disableXhr;\r\n _disableBeacon = !!config.disableBeacon;\r\n _disableBeaconSync = !!config.disableBeaconSync;\r\n _timeoutWrapper = config.timeWrapper;\r\n _addNoResponse = !!config.addNoResponse;\r\n _disableFetchKeepAlive = !!config.disableFetchKeepAlive;\r\n _fallbackInst = { sendPOST: _xhrSender };\r\n if (!_isOneDs) {\r\n _sendCredentials = false; // for appInsights, set it to false always\r\n }\r\n if (_disableCredentials) {\r\n var location_1 = getLocation();\r\n if (location_1 && location_1.protocol && location_1.protocol[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]() === \"file:\") {\r\n // Special case where a local html file fails with a CORS error on Chromium browsers\r\n _sendCredentials = false;\r\n }\r\n }\r\n return true;\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return false;\r\n };\r\n _self.getSyncFetchPayload = function () {\r\n return _syncFetchPayload;\r\n };\r\n _self.getSenderInst = function (transports, sync) {\r\n if (transports && transports[_DYN_LENGTH /* @min:%2elength */]) {\r\n return _getSenderInterface(transports, sync);\r\n }\r\n return null;\r\n };\r\n _self.getFallbackInst = function () {\r\n return _fallbackInst;\r\n };\r\n _self[_DYN__DO_TEARDOWN /* @min:%2e_doTeardown */] = function (unloadCtx, unloadState) {\r\n _initDefaults();\r\n };\r\n /**\r\n * success handler\r\n */\r\n function _onSuccess(res, onComplete) {\r\n _doOnComplete(onComplete, 200, {}, res);\r\n }\r\n /**\r\n * error handler\r\n */\r\n function _onError(message, onComplete) {\r\n _throwInternal(_diagLog, 2 /* eLoggingSeverity.WARNING */, 26 /* _eInternalMessageId.OnError */, \"Failed to send telemetry.\", { message: message });\r\n _doOnComplete(onComplete, 400, {});\r\n }\r\n function _onNoPayloadUrl(onComplete) {\r\n _onError(\"No endpoint url is provided for the batch\", onComplete);\r\n }\r\n function _getSenderInterface(transports, syncSupport) {\r\n var transportType = 0 /* TransportType.NotSet */;\r\n var sendPostFunc = null;\r\n var lp = 0;\r\n while (sendPostFunc == null && lp < transports[_DYN_LENGTH /* @min:%2elength */]) {\r\n transportType = transports[lp];\r\n if (!_disableXhr && transportType === 1 /* TransportType.Xhr */) {\r\n if (useXDomainRequest()) {\r\n // IE 8 and 9\r\n sendPostFunc = _xdrSender;\r\n }\r\n else if (isXhrSupported()) {\r\n sendPostFunc = _xhrSender;\r\n }\r\n }\r\n else if (transportType === 2 /* TransportType.Fetch */ && isFetchSupported(syncSupport) && (!syncSupport || !_disableFetchKeepAlive)) {\r\n sendPostFunc = _doFetchSender;\r\n }\r\n else if (transportType === 3 /* TransportType.Beacon */ && isBeaconsSupported() && (syncSupport ? !_disableBeaconSync : !_disableBeacon)) {\r\n sendPostFunc = _beaconSender;\r\n }\r\n lp++;\r\n }\r\n if (sendPostFunc) {\r\n return {\r\n _transport: transportType,\r\n _isSync: syncSupport,\r\n sendPOST: sendPostFunc\r\n };\r\n }\r\n return null;\r\n }\r\n function _doOnComplete(oncomplete, status, headers, response) {\r\n try {\r\n oncomplete && oncomplete(status, headers, response);\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n }\r\n function _doBeaconSend(payload, oncomplete) {\r\n var nav = getNavigator();\r\n var url = payload[_DYN_URL_STRING /* @min:%2eurlString */];\r\n if (!url) {\r\n _onNoPayloadUrl(oncomplete);\r\n // return true here, because we don't want to retry it with fallback sender\r\n return true;\r\n }\r\n url = payload[_DYN_URL_STRING /* @min:%2eurlString */] + (_addNoResponse ? _noResponseQs : STR_EMPTY);\r\n var data = payload[_DYN_DATA /* @min:%2edata */];\r\n // Chrome only allows CORS-safelisted values for the sendBeacon data argument\r\n // see: https://bugs.chromium.org/p/chromium/issues/detail?id=720283\r\n // Chrome only allows CORS-safelisted values for the sendBeacon data argument\r\n // see: https://bugs.chromium.org/p/chromium/issues/detail?id=720283\r\n var plainTextBatch = _isOneDs ? data : new Blob([data], { type: \"text/plain;charset=UTF-8\" });\r\n // The sendBeacon method returns true if the user agent is able to successfully queue the data for transfer. Otherwise it returns false.\r\n var queued = nav.sendBeacon(url, plainTextBatch);\r\n return queued;\r\n }\r\n /**\r\n * Send Beacon API request\r\n * @param payload - The data payload to be sent.\r\n * @param sync - not used\r\n * Note: Beacon API does not support custom headers and we are not able to get\r\n * appId from the backend for the correct correlation.\r\n */\r\n function _beaconSender(payload, oncomplete, sync) {\r\n var data = payload[_DYN_DATA /* @min:%2edata */];\r\n try {\r\n if (data) {\r\n // The sendBeacon method returns true if the user agent is able to successfully queue the data for transfer. Otherwise it returns false.\r\n if (!_doBeaconSend(payload, oncomplete)) {\r\n var onRetry = _onCompleteFuncs && _onCompleteFuncs.beaconOnRetry;\r\n if (onRetry && isFunction(onRetry)) {\r\n onRetry(payload, oncomplete, _doBeaconSend);\r\n }\r\n else {\r\n _fallbackInst && _fallbackInst.sendPOST(payload, oncomplete, true);\r\n _throwInternal(_diagLog, 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \". \" + \"Failed to send telemetry with Beacon API, retried with normal sender.\");\r\n }\r\n }\r\n else {\r\n // if can send\r\n _onSuccess(STR_EMPTY, oncomplete);\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _isOneDs && _warnToConsole(_diagLog, \"Failed to send telemetry using sendBeacon API. Ex:\" + dumpObj(e));\r\n _doOnComplete(oncomplete, _isOneDs ? 0 : 400, {}, STR_EMPTY);\r\n }\r\n return;\r\n }\r\n /**\r\n * Send XMLHttpRequest\r\n * @param payload - The data payload to be sent.\r\n * @param sync - Indicates if the request should be sent synchronously\r\n */\r\n function _xhrSender(payload, oncomplete, sync) {\r\n //let internalPayload = payload as IInternalPayloadData;\r\n var thePromise;\r\n var resolveFunc;\r\n var rejectFunc;\r\n var headers = payload[_DYN_HEADERS /* @min:%2eheaders */] || {};\r\n if (!sync && _enableSendPromise) {\r\n thePromise = createPromise(function (resolve, reject) {\r\n resolveFunc = resolve;\r\n rejectFunc = reject;\r\n });\r\n }\r\n if (_isOneDs && sync && payload.disableXhrSync) {\r\n sync = false;\r\n }\r\n //const xhr = new XMLHttpRequest();\r\n var endPointUrl = payload[_DYN_URL_STRING /* @min:%2eurlString */];\r\n if (!endPointUrl) {\r\n _onNoPayloadUrl(oncomplete);\r\n resolveFunc && resolveFunc(false);\r\n return;\r\n }\r\n var xhr = openXhr(STR_POST_METHOD, endPointUrl, _sendCredentials, true, sync, payload[_DYN_TIMEOUT /* @min:%2etimeout */]);\r\n if (!_isOneDs) {\r\n // application/json should NOT add to 1ds post by default\r\n xhr.setRequestHeader(\"Content-type\", \"application/json\");\r\n }\r\n arrForEach(objKeys(headers), function (headerName) {\r\n xhr.setRequestHeader(headerName, headers[headerName]);\r\n });\r\n xhr.onreadystatechange = function () {\r\n if (!_isOneDs) {\r\n _doOnReadyFunc(xhr);\r\n if (xhr.readyState === 4) {\r\n resolveFunc && resolveFunc(true);\r\n }\r\n }\r\n };\r\n xhr.onload = function () {\r\n if (_isOneDs) {\r\n _doOnReadyFunc(xhr);\r\n }\r\n };\r\n function _doOnReadyFunc(xhr) {\r\n var onReadyFunc = _onCompleteFuncs && _onCompleteFuncs.xhrOnComplete;\r\n var onReadyFuncExist = onReadyFunc && isFunction(onReadyFunc);\r\n if (onReadyFuncExist) {\r\n onReadyFunc(xhr, oncomplete, payload);\r\n }\r\n else {\r\n var response = getResponseText(xhr);\r\n _doOnComplete(oncomplete, xhr[_DYN_STATUS /* @min:%2estatus */], _getAllResponseHeaders(xhr, _isOneDs), response);\r\n }\r\n }\r\n xhr.onerror = function (event) {\r\n _doOnComplete(oncomplete, _isOneDs ? xhr[_DYN_STATUS /* @min:%2estatus */] : 400, _getAllResponseHeaders(xhr, _isOneDs), _isOneDs ? STR_EMPTY : formatErrorMessageXhr(xhr));\r\n rejectFunc && rejectFunc(event);\r\n };\r\n xhr.ontimeout = function () {\r\n _doOnComplete(oncomplete, _isOneDs ? xhr[_DYN_STATUS /* @min:%2estatus */] : 500, _getAllResponseHeaders(xhr, _isOneDs), _isOneDs ? STR_EMPTY : formatErrorMessageXhr(xhr));\r\n resolveFunc && resolveFunc(false);\r\n };\r\n xhr.send(payload[_DYN_DATA /* @min:%2edata */]);\r\n return thePromise;\r\n }\r\n /**\r\n * Send fetch API request\r\n * @param payload - The data payload to be sent.\r\n * @param sync - For fetch this identifies whether we are \"unloading\" (false) or a normal request\r\n */\r\n function _doFetchSender(payload, oncomplete, sync) {\r\n var _a;\r\n var endPointUrl = payload[_DYN_URL_STRING /* @min:%2eurlString */];\r\n var batch = payload[_DYN_DATA /* @min:%2edata */];\r\n var plainTextBatch = _isOneDs ? batch : new Blob([batch], { type: \"application/json\" });\r\n var thePromise;\r\n var resolveFunc;\r\n var rejectFunc;\r\n var requestHeaders = new Headers();\r\n var batchLength = batch[_DYN_LENGTH /* @min:%2elength */];\r\n var ignoreResponse = false;\r\n var responseHandled = false;\r\n var headers = payload[_DYN_HEADERS /* @min:%2eheaders */] || {};\r\n //TODO: handle time out for 1ds\r\n var init = (_a = {\r\n method: STR_POST_METHOD,\r\n body: plainTextBatch\r\n },\r\n _a[DisabledPropertyName] = true // Mark so we don't attempt to track this request\r\n ,\r\n _a);\r\n // Only add headers if there are headers to add, due to issue with some polyfills\r\n if (payload.headers && objKeys(payload.headers)[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n arrForEach(objKeys(headers), function (headerName) {\r\n requestHeaders.append(headerName, headers[headerName]);\r\n });\r\n init[_DYN_HEADERS /* @min:%2eheaders */] = requestHeaders;\r\n }\r\n if (_fetchCredentials) { // if user passed in this value via post channel (1ds), then use it\r\n init.credentials = _fetchCredentials;\r\n }\r\n else if (_sendCredentials && _isOneDs) {\r\n // for 1ds, Don't send credentials when URL is file://\r\n init.credentials = \"include\";\r\n }\r\n if (sync) {\r\n init.keepalive = true;\r\n _syncFetchPayload += batchLength;\r\n if (_isOneDs) {\r\n if (payload[\"_sendReason\"] === 2 /* SendRequestReason.Unload */) {\r\n // As a sync request (during unload), it is unlikely that we will get a chance to process the response so\r\n // just like beacon send assume that the events have been accepted and processed\r\n ignoreResponse = true;\r\n if (_addNoResponse) {\r\n endPointUrl += _noResponseQs;\r\n }\r\n }\r\n }\r\n else {\r\n // for appinsights, set to true for all sync request\r\n ignoreResponse = true;\r\n }\r\n }\r\n var request = new Request(endPointUrl, init);\r\n try {\r\n // Also try and tag the request (just in case the value in init is not copied over)\r\n request[DisabledPropertyName] = true;\r\n }\r\n catch (e) {\r\n // If the environment has locked down the XMLHttpRequest (preventExtensions and/or freeze), this would\r\n // cause the request to fail and we no telemetry would be sent\r\n }\r\n if (!sync && _enableSendPromise) {\r\n thePromise = createPromise(function (resolve, reject) {\r\n resolveFunc = resolve;\r\n rejectFunc = reject;\r\n });\r\n }\r\n if (!endPointUrl) {\r\n _onNoPayloadUrl(oncomplete);\r\n resolveFunc && resolveFunc(false);\r\n return;\r\n }\r\n function _handleError(res) {\r\n // In case there is an error in the request. Set the status to 0 for 1ds and 400 for appInsights\r\n // so that the events can be retried later.\r\n _doOnComplete(oncomplete, _isOneDs ? 0 : 400, {}, _isOneDs ? STR_EMPTY : res);\r\n }\r\n function _onFetchComplete(response, payload, value) {\r\n var status = response[_DYN_STATUS /* @min:%2estatus */];\r\n var onCompleteFunc = _onCompleteFuncs.fetchOnComplete;\r\n if (onCompleteFunc && isFunction(onCompleteFunc)) {\r\n onCompleteFunc(response, oncomplete, value || STR_EMPTY, payload);\r\n }\r\n else {\r\n _doOnComplete(oncomplete, status, {}, value || STR_EMPTY);\r\n }\r\n }\r\n try {\r\n doAwaitResponse(fetch(_isOneDs ? endPointUrl : request, _isOneDs ? init : null), function (result) {\r\n if (sync) {\r\n _syncFetchPayload -= batchLength;\r\n batchLength = 0;\r\n }\r\n if (!responseHandled) {\r\n responseHandled = true;\r\n if (!result.rejected) {\r\n var response_1 = result[_DYN_VALUE /* @min:%2evalue */];\r\n try {\r\n /**\r\n * The Promise returned from fetch() won’t reject on HTTP error status even if the response is an HTTP 404 or 500.\r\n * Instead, it will resolve normally (with ok status set to false), and it will only reject on network failure\r\n * or if anything prevented the request from completing.\r\n */\r\n if (!_isOneDs && !response_1.ok) {\r\n // this is for appInsights only\r\n _handleError(response_1.statusText);\r\n resolveFunc && resolveFunc(false);\r\n }\r\n else {\r\n if (_isOneDs && !response_1.body) {\r\n _onFetchComplete(response_1, null, STR_EMPTY);\r\n resolveFunc && resolveFunc(true);\r\n }\r\n else {\r\n doAwaitResponse(response_1.text(), function (resp) {\r\n _onFetchComplete(response_1, payload, resp[_DYN_VALUE /* @min:%2evalue */]);\r\n resolveFunc && resolveFunc(true);\r\n });\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _handleError(dumpObj(e));\r\n rejectFunc && rejectFunc(e);\r\n }\r\n }\r\n else {\r\n _handleError(result.reason && result.reason[_DYN_MESSAGE /* @min:%2emessage */]);\r\n rejectFunc && rejectFunc(result.reason);\r\n }\r\n }\r\n });\r\n }\r\n catch (e) {\r\n if (!responseHandled) {\r\n _handleError(dumpObj(e));\r\n rejectFunc && rejectFunc(e);\r\n }\r\n }\r\n if (ignoreResponse && !responseHandled) {\r\n // Assume success during unload processing as we most likely won't get the response\r\n responseHandled = true;\r\n _doOnComplete(oncomplete, 200, {});\r\n resolveFunc && resolveFunc(true);\r\n }\r\n if (_isOneDs && !responseHandled && payload[_DYN_TIMEOUT /* @min:%2etimeout */] > 0) {\r\n // Simulate timeout\r\n _timeoutWrapper && _timeoutWrapper.set(function () {\r\n if (!responseHandled) {\r\n // Assume a 500 response (which will cause a retry)\r\n responseHandled = true;\r\n _doOnComplete(oncomplete, 500, {});\r\n resolveFunc && resolveFunc(true);\r\n }\r\n }, payload[_DYN_TIMEOUT /* @min:%2etimeout */]);\r\n }\r\n return thePromise;\r\n }\r\n /**\r\n * Send XDomainRequest\r\n * @param payload - The data payload to be sent.\r\n * @param sync - Indicates if the request should be sent synchronously\r\n *\r\n * Note: XDomainRequest does not support sync requests. This 'isAsync' parameter is added\r\n * to maintain consistency with the xhrSender's contract\r\n * Note: XDomainRequest does not support custom headers and we are not able to get\r\n * appId from the backend for the correct correlation.\r\n */\r\n function _xdrSender(payload, oncomplete, sync) {\r\n // It doesn't support custom headers, so no action is taken with current requestHeaders\r\n var _window = getWindow();\r\n var xdr = new XDomainRequest();\r\n var data = payload[_DYN_DATA /* @min:%2edata */];\r\n xdr.onload = function () {\r\n var response = getResponseText(xdr);\r\n var onloadFunc = _onCompleteFuncs && _onCompleteFuncs.xdrOnComplete;\r\n if (onloadFunc && isFunction(onloadFunc)) {\r\n onloadFunc(xdr, oncomplete, payload);\r\n }\r\n else {\r\n _doOnComplete(oncomplete, 200, {}, response);\r\n }\r\n };\r\n xdr.onerror = function () {\r\n _doOnComplete(oncomplete, 400, {}, _isOneDs ? STR_EMPTY : formatErrorMessageXdr(xdr));\r\n };\r\n xdr.ontimeout = function () {\r\n _doOnComplete(oncomplete, 500, {});\r\n };\r\n xdr.onprogress = function () { };\r\n // XDomainRequest requires the same protocol as the hosting page.\r\n // If the protocol doesn't match, we can't send the telemetry :(.\r\n var hostingProtocol = _window && _window.location && _window.location.protocol || \"\";\r\n var endpoint = payload[_DYN_URL_STRING /* @min:%2eurlString */];\r\n if (!endpoint) {\r\n _onNoPayloadUrl(oncomplete);\r\n return;\r\n }\r\n if (!_isOneDs && endpoint.lastIndexOf(hostingProtocol, 0) !== 0) {\r\n var msg = \"Cannot send XDomain request. The endpoint URL protocol doesn't match the hosting page protocol.\";\r\n _throwInternal(_diagLog, 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \". \" + msg);\r\n _onError(msg, oncomplete);\r\n return;\r\n }\r\n var endpointUrl = _isOneDs ? endpoint : endpoint[_DYN_REPLACE /* @min:%2ereplace */](/^(https?:)/, \"\");\r\n xdr.open(STR_POST_METHOD, endpointUrl);\r\n if (payload[_DYN_TIMEOUT /* @min:%2etimeout */]) {\r\n xdr[_DYN_TIMEOUT /* @min:%2etimeout */] = payload[_DYN_TIMEOUT /* @min:%2etimeout */];\r\n }\r\n xdr.send(data);\r\n if (_isOneDs && sync) {\r\n _timeoutWrapper && _timeoutWrapper.set(function () {\r\n xdr.send(data);\r\n }, 0);\r\n }\r\n else {\r\n xdr.send(data);\r\n }\r\n }\r\n function _initDefaults() {\r\n _syncFetchPayload = 0;\r\n _isInitialized = false;\r\n _enableSendPromise = false;\r\n _diagLog = null;\r\n _isOneDs = null;\r\n _onCompleteFuncs = null;\r\n _disableCredentials = null;\r\n _fetchCredentials = null;\r\n _fallbackInst = null;\r\n _disableXhr = false;\r\n _disableBeacon = false;\r\n _disableBeaconSync = false;\r\n _disableFetchKeepAlive = false;\r\n _addNoResponse = false;\r\n _timeoutWrapper = null;\r\n }\r\n });\r\n }\r\n// Removed Stub for SenderPostManager.prototype.initialize.\r\n// Removed Stub for SenderPostManager.prototype.getSyncFetchPayload.\r\n// Removed Stub for SenderPostManager.prototype.SetConfig.\r\n// Removed Stub for SenderPostManager.prototype.getSenderInst.\r\n// Removed Stub for SenderPostManager.prototype.getFallbackInst.\r\n// Removed Stub for SenderPostManager.prototype._doTeardown.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n SenderPostManager.__ieDyn=1;\n\n return SenderPostManager;\r\n}());\r\nexport { SenderPostManager };\r\n//# sourceMappingURL=SenderPostManager.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { arrForEach, arrIndexOf, getDocument, getWindow, isArray, objForEachKey, objKeys } from \"@nevware21/ts-utils\";\r\nimport { _DYN_EVT_NAME, _DYN_LENGTH, _DYN_PUSH, _DYN_REPLACE, _DYN_SPLICE, _DYN_SPLIT, _DYN_TYPE } from \"../__DynamicConstants\";\r\nimport { createElmNodeData, createUniqueNamespace } from \"./DataCacheHelper\";\r\nimport { STR_EMPTY } from \"./InternalConstants\";\r\n// Added to help with minfication\r\nvar strOnPrefix = \"on\";\r\nvar strAttachEvent = \"attachEvent\";\r\nvar strAddEventHelper = \"addEventListener\";\r\nvar strDetachEvent = \"detachEvent\";\r\nvar strRemoveEventListener = \"removeEventListener\";\r\nvar strEvents = \"events\";\r\nvar strVisibilityChangeEvt = \"visibilitychange\";\r\nvar strPageHide = \"pagehide\";\r\nvar strPageShow = \"pageshow\";\r\nvar strUnload = \"unload\";\r\nvar strBeforeUnload = \"beforeunload\";\r\nvar strPageHideNamespace = createUniqueNamespace(\"aiEvtPageHide\");\r\nvar strPageShowNamespace = createUniqueNamespace(\"aiEvtPageShow\");\r\nvar rRemoveEmptyNs = /\\.[\\.]+/g;\r\nvar rRemoveTrailingEmptyNs = /[\\.]+$/;\r\nvar _guid = 1;\r\nvar elmNodeData = createElmNodeData(\"events\");\r\nvar eventNamespace = /^([^.]*)(?:\\.(.+)|)/;\r\nfunction _normalizeNamespace(name) {\r\n if (name && name[_DYN_REPLACE /* @min:%2ereplace */]) {\r\n return name[_DYN_REPLACE /* @min:%2ereplace */](/^[\\s\\.]+|(?=[\\s\\.])[\\.\\s]+$/g, STR_EMPTY);\r\n }\r\n return name;\r\n}\r\nfunction _getEvtNamespace(eventName, evtNamespace) {\r\n if (evtNamespace) {\r\n var theNamespace_1 = STR_EMPTY;\r\n if (isArray(evtNamespace)) {\r\n theNamespace_1 = STR_EMPTY;\r\n arrForEach(evtNamespace, function (name) {\r\n name = _normalizeNamespace(name);\r\n if (name) {\r\n if (name[0] !== \".\") {\r\n name = \".\" + name;\r\n }\r\n theNamespace_1 += name;\r\n }\r\n });\r\n }\r\n else {\r\n theNamespace_1 = _normalizeNamespace(evtNamespace);\r\n }\r\n if (theNamespace_1) {\r\n if (theNamespace_1[0] !== \".\") {\r\n theNamespace_1 = \".\" + theNamespace_1;\r\n }\r\n // We may only have the namespace and not an eventName\r\n eventName = (eventName || STR_EMPTY) + theNamespace_1;\r\n }\r\n }\r\n var parsedEvent = (eventNamespace.exec(eventName || STR_EMPTY) || []);\r\n return {\r\n type: parsedEvent[1],\r\n ns: ((parsedEvent[2] || STR_EMPTY).replace(rRemoveEmptyNs, \".\").replace(rRemoveTrailingEmptyNs, STR_EMPTY)[_DYN_SPLIT /* @min:%2esplit */](\".\").sort()).join(\".\")\r\n };\r\n}\r\n/**\r\n * Get all of the registered events on the target object, this is primarily used for testing cleanup but may also be used by\r\n * applications to remove their own events\r\n * @param target - The EventTarget that has registered events\r\n * @param eventName - [Optional] The name of the event to return the registered handlers and full name (with namespaces)\r\n * @param evtNamespace - [Optional] Additional namespace(s) to append to the event listeners so they can be uniquely identified and removed based on this namespace,\r\n * if the eventName also includes a namespace the namespace(s) are merged into a single namespace\r\n */\r\nexport function __getRegisteredEvents(target, eventName, evtNamespace) {\r\n var theEvents = [];\r\n var eventCache = elmNodeData.get(target, strEvents, {}, false);\r\n var evtName = _getEvtNamespace(eventName, evtNamespace);\r\n objForEachKey(eventCache, function (evtType, registeredEvents) {\r\n arrForEach(registeredEvents, function (value) {\r\n if (!evtName[_DYN_TYPE /* @min:%2etype */] || evtName[_DYN_TYPE /* @min:%2etype */] === value[_DYN_EVT_NAME /* @min:%2eevtName */][_DYN_TYPE /* @min:%2etype */]) {\r\n if (!evtName.ns || evtName.ns === evtName.ns) {\r\n theEvents[_DYN_PUSH /* @min:%2epush */]({\r\n name: value.evtName[_DYN_TYPE /* @min:%2etype */] + (value[_DYN_EVT_NAME /* @min:%2eevtName */].ns ? \".\" + value[_DYN_EVT_NAME /* @min:%2eevtName */].ns : STR_EMPTY),\r\n handler: value.handler\r\n });\r\n }\r\n }\r\n });\r\n });\r\n return theEvents;\r\n}\r\n// Exported for internal unit testing only\r\nfunction _getRegisteredEvents(target, evtName, addDefault) {\r\n if (addDefault === void 0) { addDefault = true; }\r\n var aiEvts = elmNodeData.get(target, strEvents, {}, addDefault);\r\n var registeredEvents = aiEvts[evtName];\r\n if (!registeredEvents) {\r\n registeredEvents = aiEvts[evtName] = [];\r\n }\r\n return registeredEvents;\r\n}\r\nfunction _doDetach(obj, evtName, handlerRef, useCapture) {\r\n if (obj && evtName && evtName[_DYN_TYPE /* @min:%2etype */]) {\r\n if (obj[strRemoveEventListener]) {\r\n obj[strRemoveEventListener](evtName[_DYN_TYPE /* @min:%2etype */], handlerRef, useCapture);\r\n }\r\n else if (obj[strDetachEvent]) {\r\n obj[strDetachEvent](strOnPrefix + evtName[_DYN_TYPE /* @min:%2etype */], handlerRef);\r\n }\r\n }\r\n}\r\nfunction _doAttach(obj, evtName, handlerRef, useCapture) {\r\n var result = false;\r\n if (obj && evtName && evtName[_DYN_TYPE /* @min:%2etype */] && handlerRef) {\r\n if (obj[strAddEventHelper]) {\r\n // all browsers except IE before version 9\r\n obj[strAddEventHelper](evtName[_DYN_TYPE /* @min:%2etype */], handlerRef, useCapture);\r\n result = true;\r\n }\r\n else if (obj[strAttachEvent]) {\r\n // IE before version 9\r\n obj[strAttachEvent](strOnPrefix + evtName[_DYN_TYPE /* @min:%2etype */], handlerRef);\r\n result = true;\r\n }\r\n }\r\n return result;\r\n}\r\nfunction _doUnregister(target, events, evtName, unRegFn) {\r\n var idx = events[_DYN_LENGTH /* @min:%2elength */];\r\n while (idx--) {\r\n var theEvent = events[idx];\r\n if (theEvent) {\r\n if (!evtName.ns || evtName.ns === theEvent[_DYN_EVT_NAME /* @min:%2eevtName */].ns) {\r\n if (!unRegFn || unRegFn(theEvent)) {\r\n _doDetach(target, theEvent[_DYN_EVT_NAME /* @min:%2eevtName */], theEvent.handler, theEvent.capture);\r\n // Remove the registered event\r\n events[_DYN_SPLICE /* @min:%2esplice */](idx, 1);\r\n }\r\n }\r\n }\r\n }\r\n}\r\nfunction _unregisterEvents(target, evtName, unRegFn) {\r\n if (evtName[_DYN_TYPE /* @min:%2etype */]) {\r\n _doUnregister(target, _getRegisteredEvents(target, evtName[_DYN_TYPE /* @min:%2etype */]), evtName, unRegFn);\r\n }\r\n else {\r\n var eventCache = elmNodeData.get(target, strEvents, {});\r\n objForEachKey(eventCache, function (evtType, events) {\r\n _doUnregister(target, events, evtName, unRegFn);\r\n });\r\n // Cleanup\r\n if (objKeys(eventCache)[_DYN_LENGTH /* @min:%2elength */] === 0) {\r\n elmNodeData.kill(target, strEvents);\r\n }\r\n }\r\n}\r\nexport function mergeEvtNamespace(theNamespace, namespaces) {\r\n var newNamespaces;\r\n if (namespaces) {\r\n if (isArray(namespaces)) {\r\n newNamespaces = [theNamespace].concat(namespaces);\r\n }\r\n else {\r\n newNamespaces = [theNamespace, namespaces];\r\n }\r\n // resort the namespaces so they are always in order\r\n newNamespaces = (_getEvtNamespace(\"xx\", newNamespaces).ns)[_DYN_SPLIT /* @min:%2esplit */](\".\");\r\n }\r\n else {\r\n newNamespaces = theNamespace;\r\n }\r\n return newNamespaces;\r\n}\r\n/**\r\n * Binds the specified function to an event, so that the function gets called whenever the event fires on the object\r\n * @param obj - Object to add the event too.\r\n * @param eventName - String that specifies any of the standard DHTML Events without \"on\" prefix, if may also include an optional (dot \".\" prefixed)\r\n * namespaces \"click\" \"click.mynamespace\" in addition to specific namespaces.\r\n * @param handlerRef - Pointer that specifies the function to call when event fires\r\n * @param evtNamespace - [Optional] Additional namespace(s) to append to the event listeners so they can be uniquely identified and removed based on this namespace,\r\n * if the eventName also includes a namespace the namespace(s) are merged into a single namespace\r\n * @param useCapture - [Optional] Defaults to false\r\n * @returns True if the function was bound successfully to the event, otherwise false\r\n */\r\nexport function eventOn(target, eventName, handlerRef, evtNamespace, useCapture) {\r\n if (useCapture === void 0) { useCapture = false; }\r\n var result = false;\r\n if (target) {\r\n try {\r\n var evtName = _getEvtNamespace(eventName, evtNamespace);\r\n result = _doAttach(target, evtName, handlerRef, useCapture);\r\n if (result && elmNodeData.accept(target)) {\r\n var registeredEvent = {\r\n guid: _guid++,\r\n evtName: evtName,\r\n handler: handlerRef,\r\n capture: useCapture\r\n };\r\n _getRegisteredEvents(target, evtName.type)[_DYN_PUSH /* @min:%2epush */](registeredEvent);\r\n }\r\n }\r\n catch (e) {\r\n // Just Ignore any error so that we don't break any execution path\r\n }\r\n }\r\n return result;\r\n}\r\n/**\r\n * Removes an event handler for the specified event\r\n * @param Object - to remove the event from\r\n * @param eventName - The name of the event, with optional namespaces or just the namespaces,\r\n * such as \"click\", \"click.mynamespace\" or \".mynamespace\"\r\n * @param handlerRef - The callback function that needs to be removed from the given event, when using a\r\n * namespace (with or without a qualifying event) this may be null to remove all previously attached event handlers\r\n * otherwise this will only remove events with this specific handler.\r\n * @param evtNamespace - [Optional] Additional namespace(s) to append to the event listeners so they can be uniquely identified and removed based on this namespace,\r\n * if the eventName also includes a namespace the namespace(s) are merged into a single namespace\r\n * @param useCapture - [Optional] Defaults to false\r\n */\r\nexport function eventOff(target, eventName, handlerRef, evtNamespace, useCapture) {\r\n if (useCapture === void 0) { useCapture = false; }\r\n if (target) {\r\n try {\r\n var evtName_1 = _getEvtNamespace(eventName, evtNamespace);\r\n var found_1 = false;\r\n _unregisterEvents(target, evtName_1, function (regEvent) {\r\n if ((evtName_1.ns && !handlerRef) || regEvent.handler === handlerRef) {\r\n found_1 = true;\r\n return true;\r\n }\r\n return false;\r\n });\r\n if (!found_1) {\r\n // fallback to try and remove as requested\r\n _doDetach(target, evtName_1, handlerRef, useCapture);\r\n }\r\n }\r\n catch (e) {\r\n // Just Ignore any error so that we don't break any execution path\r\n }\r\n }\r\n}\r\n/**\r\n * Binds the specified function to an event, so that the function gets called whenever the event fires on the object\r\n * @param obj - Object to add the event too.\r\n * @param eventNameWithoutOn - String that specifies any of the standard DHTML Events without \"on\" prefix and optional (dot \".\" prefixed) namespaces \"click\" \"click.mynamespace\".\r\n * @param handlerRef - Pointer that specifies the function to call when event fires\r\n * @param useCapture - [Optional] Defaults to false\r\n * @returns True if the function was bound successfully to the event, otherwise false\r\n */\r\nexport function attachEvent(obj, eventNameWithoutOn, handlerRef, useCapture) {\r\n if (useCapture === void 0) { useCapture = false; }\r\n return eventOn(obj, eventNameWithoutOn, handlerRef, null, useCapture);\r\n}\r\n/**\r\n * Removes an event handler for the specified event\r\n * @param Object - to remove the event from\r\n * @param eventNameWithoutOn - The name of the event, with optional namespaces or just the namespaces,\r\n * such as \"click\", \"click.mynamespace\" or \".mynamespace\"\r\n * @param handlerRef - The callback function that needs to be removed from the given event, when using a\r\n * namespace (with or without a qualifying event) this may be null to remove all previously attached event handlers\r\n * otherwise this will only remove events with this specific handler.\r\n * @param useCapture - [Optional] Defaults to false\r\n */\r\nexport function detachEvent(obj, eventNameWithoutOn, handlerRef, useCapture) {\r\n if (useCapture === void 0) { useCapture = false; }\r\n eventOff(obj, eventNameWithoutOn, handlerRef, null, useCapture);\r\n}\r\n/**\r\n * Trys to add an event handler for the specified event to the window, body and document\r\n * @param eventName - The name of the event\r\n * @param callback - The callback function that needs to be executed for the given event\r\n * @param evtNamespace - [Optional] Namespace(s) to append to the event listeners so they can be uniquely identified and removed based on this namespace.\r\n * @returns - true if the handler was successfully added\r\n */\r\nexport function addEventHandler(eventName, callback, evtNamespace) {\r\n var result = false;\r\n var w = getWindow();\r\n if (w) {\r\n result = eventOn(w, eventName, callback, evtNamespace);\r\n result = eventOn(w[\"body\"], eventName, callback, evtNamespace) || result;\r\n }\r\n var doc = getDocument();\r\n if (doc) {\r\n result = eventOn(doc, eventName, callback, evtNamespace) || result;\r\n }\r\n return result;\r\n}\r\n/**\r\n * Trys to remove event handler(s) for the specified event/namespace to the window, body and document\r\n * @param eventName - The name of the event, with optional namespaces or just the namespaces,\r\n * such as \"click\", \"click.mynamespace\" or \".mynamespace\"\r\n * @param callback - The callback function that needs to be removed from the given event, when using a\r\n * namespace (with or without a qualifying event) this may be null to remove all previously attached event handlers\r\n * otherwise this will only remove events with this specific handler.\r\n * @param evtNamespace - [Optional] Namespace(s) to append to the event listeners so they can be uniquely identified and removed based on this namespace.\r\n */\r\nexport function removeEventHandler(eventName, callback, evtNamespace) {\r\n var w = getWindow();\r\n if (w) {\r\n eventOff(w, eventName, callback, evtNamespace);\r\n eventOff(w[\"body\"], eventName, callback, evtNamespace);\r\n }\r\n var doc = getDocument();\r\n if (doc) {\r\n eventOff(doc, eventName, callback, evtNamespace);\r\n }\r\n}\r\n/**\r\n * Bind the listener to the array of events\r\n * @param events - An string array of event names to bind the listener to\r\n * @param listener - The event callback to call when the event is triggered\r\n * @param excludeEvents - [Optional] An array of events that should not be hooked (if possible), unless no other events can be.\r\n * @param evtNamespace - [Optional] Namespace(s) to append to the event listeners so they can be uniquely identified and removed based on this namespace.\r\n * @returns true - when at least one of the events was registered otherwise false\r\n */\r\nfunction _addEventListeners(events, listener, excludeEvents, evtNamespace) {\r\n var added = false;\r\n if (listener && events && events[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n arrForEach(events, function (name) {\r\n if (name) {\r\n if (!excludeEvents || arrIndexOf(excludeEvents, name) === -1) {\r\n added = addEventHandler(name, listener, evtNamespace) || added;\r\n }\r\n }\r\n });\r\n }\r\n return added;\r\n}\r\n/**\r\n * Bind the listener to the array of events\r\n * @param events - An string array of event names to bind the listener to\r\n * @param listener - The event callback to call when the event is triggered\r\n * @param excludeEvents - [Optional] An array of events that should not be hooked (if possible), unless no other events can be.\r\n * @param evtNamespace - [Optional] Namespace(s) to append to the event listeners so they can be uniquely identified and removed based on this namespace.\r\n * @returns true - when at least one of the events was registered otherwise false\r\n */\r\nexport function addEventListeners(events, listener, excludeEvents, evtNamespace) {\r\n var added = false;\r\n if (listener && events && isArray(events)) {\r\n added = _addEventListeners(events, listener, excludeEvents, evtNamespace);\r\n if (!added && excludeEvents && excludeEvents[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n // Failed to add any listeners and we excluded some, so just attempt to add the excluded events\r\n added = _addEventListeners(events, listener, null, evtNamespace);\r\n }\r\n }\r\n return added;\r\n}\r\n/**\r\n * Remove the listener from the array of events\r\n * @param events - An string array of event names to bind the listener to\r\n * @param listener - The event callback to call when the event is triggered\r\n * @param evtNamespace - [Optional] Namespace(s) to append to the event listeners so they can be uniquely identified and removed based on this namespace.\r\n */\r\nexport function removeEventListeners(events, listener, evtNamespace) {\r\n if (events && isArray(events)) {\r\n arrForEach(events, function (name) {\r\n if (name) {\r\n removeEventHandler(name, listener, evtNamespace);\r\n }\r\n });\r\n }\r\n}\r\n/**\r\n * Listen to the 'beforeunload', 'unload' and 'pagehide' events which indicates a page unload is occurring,\r\n * this does NOT listen to the 'visibilitychange' event as while it does indicate that the page is being hidden\r\n * it does not *necessarily* mean that the page is being completely unloaded, it can mean that the user is\r\n * just navigating to a different Tab and may come back (without unloading the page). As such you may also\r\n * need to listen to the 'addPageHideEventListener' and 'addPageShowEventListener' events.\r\n * @param listener - The event callback to call when a page unload event is triggered\r\n * @param excludeEvents - [Optional] An array of events that should not be hooked, unless no other events can be.\r\n * @param evtNamespace - [Optional] Namespace(s) to append to the event listeners so they can be uniquely identified and removed based on this namespace.\r\n * @returns true - when at least one of the events was registered otherwise false\r\n */\r\nexport function addPageUnloadEventListener(listener, excludeEvents, evtNamespace) {\r\n // Hook the unload event for the document, window and body to ensure that the client events are flushed to the server\r\n // As just hooking the window does not always fire (on chrome) for page navigation's.\r\n return addEventListeners([strBeforeUnload, strUnload, strPageHide], listener, excludeEvents, evtNamespace);\r\n}\r\n/**\r\n * Remove any matching 'beforeunload', 'unload' and 'pagehide' events that may have been added via addEventListener,\r\n * addEventListeners, addPageUnloadEventListener or addPageHideEventListener.\r\n * @param listener - The specific event callback to to be removed\r\n * @param evtNamespace - [Optional] Namespace(s) uniquely identified and removed based on this namespace.\r\n * @returns true - when at least one of the events was registered otherwise false\r\n */\r\nexport function removePageUnloadEventListener(listener, evtNamespace) {\r\n removeEventListeners([strBeforeUnload, strUnload, strPageHide], listener, evtNamespace);\r\n}\r\n/**\r\n * Listen to the pagehide and visibility changing to 'hidden' events, because the 'visibilitychange' uses\r\n * an internal proxy to detect the visibility state you SHOULD use a unique namespace when if you plan to call\r\n * removePageShowEventListener as the remove ignores the listener argument for the 'visibilitychange' event.\r\n * @param listener - The event callback to call when a page hide event is triggered\r\n * @param excludeEvents - [Optional] An array of events that should not be hooked (if possible), unless no other events can be.\r\n * @param evtNamespace - [Optional] A Namespace to append to the event listeners so they can be uniquely identified and removed\r\n * based on this namespace. This call also adds an additional unique \"pageshow\" namespace to the events\r\n * so that only the matching \"removePageHideEventListener\" can remove these events.\r\n * Suggestion: pass as true if you are also calling addPageUnloadEventListener as that also hooks pagehide\r\n * @returns true - when at least one of the events was registered otherwise false\r\n */\r\nexport function addPageHideEventListener(listener, excludeEvents, evtNamespace) {\r\n function _handlePageVisibility(evt) {\r\n var doc = getDocument();\r\n if (listener && doc && doc.visibilityState === \"hidden\") {\r\n listener(evt);\r\n }\r\n }\r\n // add the unique page show namespace to any provided namespace so we can only remove the ones added by \"pagehide\"\r\n var newNamespaces = mergeEvtNamespace(strPageHideNamespace, evtNamespace);\r\n var pageUnloadAdded = _addEventListeners([strPageHide], listener, excludeEvents, newNamespaces);\r\n if (!excludeEvents || arrIndexOf(excludeEvents, strVisibilityChangeEvt) === -1) {\r\n pageUnloadAdded = _addEventListeners([strVisibilityChangeEvt], _handlePageVisibility, excludeEvents, newNamespaces) || pageUnloadAdded;\r\n }\r\n if (!pageUnloadAdded && excludeEvents) {\r\n // Failed to add any listeners and we where requested to exclude some, so just call again without excluding anything\r\n pageUnloadAdded = addPageHideEventListener(listener, null, evtNamespace);\r\n }\r\n return pageUnloadAdded;\r\n}\r\n/**\r\n * Removes the pageHide event listeners added by addPageHideEventListener, because the 'visibilitychange' uses\r\n * an internal proxy to detect the visibility state you SHOULD use a unique namespace when calling addPageHideEventListener\r\n * as the remove ignores the listener argument for the 'visibilitychange' event.\r\n * @param listener - The specific listener to remove for the 'pageshow' event only (ignored for 'visibilitychange')\r\n * @param evtNamespace - The unique namespace used when calling addPageShowEventListener\r\n */\r\nexport function removePageHideEventListener(listener, evtNamespace) {\r\n // add the unique page show namespace to any provided namespace so we only remove the ones added by \"pagehide\"\r\n var newNamespaces = mergeEvtNamespace(strPageHideNamespace, evtNamespace);\r\n removeEventListeners([strPageHide], listener, newNamespaces);\r\n removeEventListeners([strVisibilityChangeEvt], null, newNamespaces);\r\n}\r\n/**\r\n * Listen to the pageshow and visibility changing to 'visible' events, because the 'visibilitychange' uses\r\n * an internal proxy to detect the visibility state you SHOULD use a unique namespace when if you plan to call\r\n * removePageShowEventListener as the remove ignores the listener argument for the 'visibilitychange' event.\r\n * @param listener - The event callback to call when a page is show event is triggered\r\n * @param excludeEvents - [Optional] An array of events that should not be hooked (if possible), unless no other events can be.\r\n * @param evtNamespace - [Optional/Recommended] A Namespace to append to the event listeners so they can be uniquely\r\n * identified and removed based on this namespace. This call also adds an additional unique \"pageshow\" namespace to the events\r\n * so that only the matching \"removePageShowEventListener\" can remove these events.\r\n * @returns true - when at least one of the events was registered otherwise false\r\n */\r\nexport function addPageShowEventListener(listener, excludeEvents, evtNamespace) {\r\n function _handlePageVisibility(evt) {\r\n var doc = getDocument();\r\n if (listener && doc && doc.visibilityState === \"visible\") {\r\n listener(evt);\r\n }\r\n }\r\n // add the unique page show namespace to any provided namespace so we can only remove the ones added by \"pageshow\"\r\n var newNamespaces = mergeEvtNamespace(strPageShowNamespace, evtNamespace);\r\n var pageShowAdded = _addEventListeners([strPageShow], listener, excludeEvents, newNamespaces);\r\n pageShowAdded = _addEventListeners([strVisibilityChangeEvt], _handlePageVisibility, excludeEvents, newNamespaces) || pageShowAdded;\r\n if (!pageShowAdded && excludeEvents) {\r\n // Failed to add any listeners and we where requested to exclude some, so just call again without excluding anything\r\n pageShowAdded = addPageShowEventListener(listener, null, evtNamespace);\r\n }\r\n return pageShowAdded;\r\n}\r\n/**\r\n * Removes the pageShow event listeners added by addPageShowEventListener, because the 'visibilitychange' uses\r\n * an internal proxy to detect the visibility state you SHOULD use a unique namespace when calling addPageShowEventListener\r\n * as the remove ignores the listener argument for the 'visibilitychange' event.\r\n * @param listener - The specific listener to remove for the 'pageshow' event only (ignored for 'visibilitychange')\r\n * @param evtNamespace - The unique namespace used when calling addPageShowEventListener\r\n */\r\nexport function removePageShowEventListener(listener, evtNamespace) {\r\n // add the unique page show namespace to any provided namespace so we only remove the ones added by \"pageshow\"\r\n var newNamespaces = mergeEvtNamespace(strPageShowNamespace, evtNamespace);\r\n removeEventListeners([strPageShow], listener, newNamespaces);\r\n removeEventListeners([strVisibilityChangeEvt], null, newNamespaces);\r\n}\r\n//# sourceMappingURL=EventHelpers.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\nimport { createEnumStyle } from \"../JavaScriptSDK.Enums/EnumHelperFuncs\";\r\nexport var LoggingSeverity = createEnumStyle({\r\n DISABLED: 0 /* eLoggingSeverity.DISABLED */,\r\n CRITICAL: 1 /* eLoggingSeverity.CRITICAL */,\r\n WARNING: 2 /* eLoggingSeverity.WARNING */,\r\n DEBUG: 3 /* eLoggingSeverity.DEBUG */\r\n});\r\n//# sourceMappingURL=LoggingEnums.js.map","/*\n * Application Insights JavaScript SDK - Core, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { strShimFunction, strShimPrototype } from \"@microsoft/applicationinsights-shims\";\r\nimport { getInst, objHasOwnProperty } from \"@nevware21/ts-utils\";\r\nimport { _DYN_APPLY, _DYN_LENGTH, _DYN_PUSH, _DYN_SPLICE } from \"../__DynamicConstants\";\r\nimport { _getObjProto } from \"./HelperFuncs\";\r\nvar aiInstrumentHooks = \"_aiHooks\";\r\nvar cbNames = [\r\n \"req\", \"rsp\", \"hkErr\", \"fnErr\"\r\n];\r\n/** @ignore */\r\nfunction _arrLoop(arr, fn) {\r\n if (arr) {\r\n for (var lp = 0; lp < arr[_DYN_LENGTH /* @min:%2elength */]; lp++) {\r\n if (fn(arr[lp], lp)) {\r\n break;\r\n }\r\n }\r\n }\r\n}\r\n/** @ignore */\r\nfunction _doCallbacks(hooks, callDetails, cbArgs, hookCtx, type) {\r\n if (type >= 0 /* CallbackType.Request */ && type <= 2 /* CallbackType.HookError */) {\r\n _arrLoop(hooks, function (hook, idx) {\r\n var cbks = hook.cbks;\r\n var cb = cbks[cbNames[type]];\r\n if (cb) {\r\n // Set the specific hook context implementation using a lazy creation pattern\r\n callDetails.ctx = function () {\r\n var ctx = hookCtx[idx] = (hookCtx[idx] || {});\r\n return ctx;\r\n };\r\n try {\r\n cb[_DYN_APPLY /* @min:%2eapply */](callDetails.inst, cbArgs);\r\n }\r\n catch (err) {\r\n var orgEx = callDetails.err;\r\n try {\r\n // Report Hook error via the callback\r\n var hookErrorCb = cbks[cbNames[2 /* CallbackType.HookError */]];\r\n if (hookErrorCb) {\r\n callDetails.err = err;\r\n hookErrorCb[_DYN_APPLY /* @min:%2eapply */](callDetails.inst, cbArgs);\r\n }\r\n }\r\n catch (e) {\r\n // Not much we can do here -- swallowing the exception to avoid crashing the hosting app\r\n }\r\n finally {\r\n // restore the original exception (if any)\r\n callDetails.err = orgEx;\r\n }\r\n }\r\n }\r\n });\r\n }\r\n}\r\n/** @ignore */\r\nfunction _createFunctionHook(aiHook) {\r\n // Define a temporary method that queues-up a the real method call\r\n return function () {\r\n var funcThis = this;\r\n // Capture the original arguments passed to the method\r\n var orgArgs = arguments;\r\n var hooks = aiHook.h;\r\n var funcArgs = {\r\n name: aiHook.n,\r\n inst: funcThis,\r\n ctx: null,\r\n set: _replaceArg\r\n };\r\n var hookCtx = [];\r\n var cbArgs = _createArgs([funcArgs], orgArgs);\r\n funcArgs.evt = getInst(\"event\");\r\n function _createArgs(target, theArgs) {\r\n _arrLoop(theArgs, function (arg) {\r\n target[_DYN_PUSH /* @min:%2epush */](arg);\r\n });\r\n return target;\r\n }\r\n function _replaceArg(idx, value) {\r\n orgArgs = _createArgs([], orgArgs);\r\n orgArgs[idx] = value;\r\n cbArgs = _createArgs([funcArgs], orgArgs);\r\n }\r\n // Call the pre-request hooks\r\n _doCallbacks(hooks, funcArgs, cbArgs, hookCtx, 0 /* CallbackType.Request */);\r\n // Call the original function was called\r\n var theFunc = aiHook.f;\r\n if (theFunc) {\r\n try {\r\n funcArgs.rslt = theFunc[_DYN_APPLY /* @min:%2eapply */](funcThis, orgArgs);\r\n }\r\n catch (err) {\r\n // Report the request callback\r\n funcArgs.err = err;\r\n _doCallbacks(hooks, funcArgs, cbArgs, hookCtx, 3 /* CallbackType.FunctionError */);\r\n // rethrow the original exception so anyone listening for it can catch the exception\r\n throw err;\r\n }\r\n }\r\n // Call the post-request hooks\r\n _doCallbacks(hooks, funcArgs, cbArgs, hookCtx, 1 /* CallbackType.Response */);\r\n return funcArgs.rslt;\r\n };\r\n}\r\n/** @ignore */\r\nfunction _getOwner(target, name, checkPrototype, checkParentProto) {\r\n var owner = null;\r\n if (target) {\r\n if (objHasOwnProperty(target, name)) {\r\n owner = target;\r\n }\r\n else if (checkPrototype) {\r\n owner = _getOwner(_getObjProto(target), name, checkParentProto, false);\r\n }\r\n }\r\n return owner;\r\n}\r\n/**\r\n * Intercept the named prototype functions for the target class / object\r\n * @param target - The target object\r\n * @param funcName - The function name\r\n * @param callbacks - The callbacks to configure and call whenever the function is called\r\n */\r\nexport function InstrumentProto(target, funcName, callbacks) {\r\n if (target) {\r\n return InstrumentFunc(target[strShimPrototype], funcName, callbacks, false);\r\n }\r\n return null;\r\n}\r\n/**\r\n * Intercept the named prototype functions for the target class / object\r\n * @param target - The target object\r\n * @param funcNames - The function names to intercept and call\r\n * @param callbacks - The callbacks to configure and call whenever the function is called\r\n */\r\nexport function InstrumentProtos(target, funcNames, callbacks) {\r\n if (target) {\r\n return InstrumentFuncs(target[strShimPrototype], funcNames, callbacks, false);\r\n }\r\n return null;\r\n}\r\nfunction _createInstrumentHook(owner, funcName, fn, callbacks) {\r\n var aiHook = fn && fn[aiInstrumentHooks];\r\n if (!aiHook) {\r\n // Only hook the function once\r\n aiHook = {\r\n i: 0,\r\n n: funcName,\r\n f: fn,\r\n h: []\r\n };\r\n // Override (hook) the original function\r\n var newFunc = _createFunctionHook(aiHook);\r\n newFunc[aiInstrumentHooks] = aiHook; // Tag and store the function hooks\r\n owner[funcName] = newFunc;\r\n }\r\n var theHook = {\r\n // tslint:disable:object-literal-shorthand\r\n id: aiHook.i,\r\n cbks: callbacks,\r\n rm: function () {\r\n // DO NOT Use () => { shorthand for the function as the this gets replaced\r\n // with the outer this and not the this for theHook instance.\r\n var id = this.id;\r\n _arrLoop(aiHook.h, function (hook, idx) {\r\n if (hook.id === id) {\r\n aiHook.h[_DYN_SPLICE /* @min:%2esplice */](idx, 1);\r\n return 1;\r\n }\r\n });\r\n }\r\n // tslint:enable:object-literal-shorthand\r\n };\r\n aiHook.i++;\r\n aiHook.h[_DYN_PUSH /* @min:%2epush */](theHook);\r\n return theHook;\r\n}\r\n/**\r\n * Intercept the named prototype functions for the target class / object\r\n * @param target - The target object\r\n * @param funcName - The function name\r\n * @param callbacks - The callbacks to configure and call whenever the function is called\r\n * @param checkPrototype - If the function doesn't exist on the target should it attempt to hook the prototype function\r\n * @param checkParentProto - If the function doesn't exist on the target or it's prototype should it attempt to hook the parent's prototype\r\n */\r\nexport function InstrumentFunc(target, funcName, callbacks, checkPrototype, checkParentProto) {\r\n if (checkPrototype === void 0) { checkPrototype = true; }\r\n if (target && funcName && callbacks) {\r\n var owner = _getOwner(target, funcName, checkPrototype, checkParentProto);\r\n if (owner) {\r\n var fn = owner[funcName];\r\n if (typeof fn === strShimFunction) {\r\n return _createInstrumentHook(owner, funcName, fn, callbacks);\r\n }\r\n }\r\n }\r\n return null;\r\n}\r\n/**\r\n * Intercept the named functions for the target class / object\r\n * @param target - The target object\r\n * @param funcNames - The function names to intercept and call\r\n * @param callbacks - The callbacks to configure and call whenever the function is called\r\n * @param checkPrototype - If the function doesn't exist on the target should it attempt to hook the prototype function\r\n * @param checkParentProto - If the function doesn't exist on the target or it's prototype should it attempt to hook the parent's prototype\r\n */\r\nexport function InstrumentFuncs(target, funcNames, callbacks, checkPrototype, checkParentProto) {\r\n if (checkPrototype === void 0) { checkPrototype = true; }\r\n var hooks = null;\r\n _arrLoop(funcNames, function (funcName) {\r\n var hook = InstrumentFunc(target, funcName, callbacks, checkPrototype, checkParentProto);\r\n if (hook) {\r\n if (!hooks) {\r\n hooks = [];\r\n }\r\n hooks[_DYN_PUSH /* @min:%2epush */](hook);\r\n }\r\n });\r\n return hooks;\r\n}\r\n/**\r\n * Add an instrumentation hook to the provided named \"event\" for the target class / object, this doesn't check whether the\r\n * named \"event\" is in fact a function and just assigns the instrumentation hook to the target[evtName]\r\n * @param target - The target object\r\n * @param evtName - The name of the event\r\n * @param callbacks - The callbacks to configure and call whenever the function is called\r\n * @param checkPrototype - If the function doesn't exist on the target should it attempt to hook the prototype function\r\n * @param checkParentProto - If the function doesn't exist on the target or it's prototype should it attempt to hook the parent's prototype\r\n */\r\nexport function InstrumentEvent(target, evtName, callbacks, checkPrototype, checkParentProto) {\r\n if (target && evtName && callbacks) {\r\n var owner = _getOwner(target, evtName, checkPrototype, checkParentProto) || target;\r\n if (owner) {\r\n return _createInstrumentHook(owner, evtName, owner[evtName], callbacks);\r\n }\r\n }\r\n return null;\r\n}\r\n//# sourceMappingURL=InstrumentHooks.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n/**\r\n * This is an internal property used to cause internal (reporting) requests to be ignored from reporting\r\n * additional telemetry, to handle polyfil implementations ALL urls used with a disabled request will\r\n * also be ignored for future requests even when this property is not provided.\r\n * Tagging as Ignore as this is an internal value and is not expected to be used outside of the SDK\r\n * @ignore\r\n */\r\nexport var DisabledPropertyName = \"Microsoft_ApplicationInsights_BypassAjaxInstrumentation\";\r\nexport var SampleRate = \"sampleRate\";\r\nexport var ProcessLegacy = \"ProcessLegacy\";\r\nexport var HttpMethod = \"http.method\";\r\nexport var DEFAULT_BREEZE_ENDPOINT = \"https://dc.services.visualstudio.com\";\r\nexport var DEFAULT_BREEZE_PATH = \"/v2/track\";\r\nexport var strNotSpecified = \"not_specified\";\r\nexport var strIkey = \"iKey\";\r\n//# sourceMappingURL=Constants.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { createValueMap } from \"@microsoft/applicationinsights-core-js\";\r\nexport var RequestHeaders = createValueMap({\r\n requestContextHeader: [0 /* eRequestHeaders.requestContextHeader */, \"Request-Context\"],\r\n requestContextTargetKey: [1 /* eRequestHeaders.requestContextTargetKey */, \"appId\"],\r\n requestContextAppIdFormat: [2 /* eRequestHeaders.requestContextAppIdFormat */, \"appId=cid-v1:\"],\r\n requestIdHeader: [3 /* eRequestHeaders.requestIdHeader */, \"Request-Id\"],\r\n traceParentHeader: [4 /* eRequestHeaders.traceParentHeader */, \"traceparent\"],\r\n traceStateHeader: [5 /* eRequestHeaders.traceStateHeader */, \"tracestate\"],\r\n sdkContextHeader: [6 /* eRequestHeaders.sdkContextHeader */, \"Sdk-Context\"],\r\n sdkContextHeaderAppIdRequest: [7 /* eRequestHeaders.sdkContextHeaderAppIdRequest */, \"appId\"],\r\n requestContextHeaderLowerCase: [8 /* eRequestHeaders.requestContextHeaderLowerCase */, \"request-context\"]\r\n});\r\n//# sourceMappingURL=RequestResponseHeaders.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES5 which can result in a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_SPLIT = \"split\"; // Count: 6\r\nexport var _DYN_LENGTH = \"length\"; // Count: 46\r\nexport var _DYN_TO_LOWER_CASE = \"toLowerCase\"; // Count: 6\r\nexport var _DYN_INGESTIONENDPOINT = \"ingestionendpoint\"; // Count: 6\r\nexport var _DYN_TO_STRING = \"toString\"; // Count: 8\r\nexport var _DYN_REMOVE_ITEM = \"removeItem\"; // Count: 3\r\nexport var _DYN_MESSAGE = \"message\"; // Count: 5\r\nexport var _DYN_COUNT = \"count\"; // Count: 6\r\nexport var _DYN_PRE_TRIGGER_DATE = \"preTriggerDate\"; // Count: 4\r\nexport var _DYN_GET_UTCDATE = \"getUTCDate\"; // Count: 3\r\nexport var _DYN_STRINGIFY = \"stringify\"; // Count: 4\r\nexport var _DYN_PATHNAME = \"pathname\"; // Count: 4\r\nexport var _DYN_MATCH = \"match\"; // Count: 5\r\nexport var _DYN_CORRELATION_HEADER_E0 = \"correlationHeaderExcludePatterns\"; // Count: 2\r\nexport var _DYN_NAME = \"name\"; // Count: 10\r\nexport var _DYN_EXTENSION_CONFIG = \"extensionConfig\"; // Count: 4\r\nexport var _DYN_PROPERTIES = \"properties\"; // Count: 10\r\nexport var _DYN_MEASUREMENTS = \"measurements\"; // Count: 9\r\nexport var _DYN_SIZE_IN_BYTES = \"sizeInBytes\"; // Count: 4\r\nexport var _DYN_TYPE_NAME = \"typeName\"; // Count: 5\r\nexport var _DYN_EXCEPTIONS = \"exceptions\"; // Count: 5\r\nexport var _DYN_SEVERITY_LEVEL = \"severityLevel\"; // Count: 5\r\nexport var _DYN_PROBLEM_GROUP = \"problemGroup\"; // Count: 3\r\nexport var _DYN_PARSED_STACK = \"parsedStack\"; // Count: 6\r\nexport var _DYN_HAS_FULL_STACK = \"hasFullStack\"; // Count: 5\r\nexport var _DYN_ASSEMBLY = \"assembly\"; // Count: 4\r\nexport var _DYN_FILE_NAME = \"fileName\"; // Count: 9\r\nexport var _DYN_LINE = \"line\"; // Count: 6\r\nexport var _DYN_AI_DATA_CONTRACT = \"aiDataContract\"; // Count: 4\r\nexport var _DYN_DURATION = \"duration\"; // Count: 4\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { _throwInternal, getJSON, hasJSON, isObject, objForEachKey, strTrim } from \"@microsoft/applicationinsights-core-js\";\r\nimport { asString, strSubstr, strSubstring } from \"@nevware21/ts-utils\";\r\nimport { _DYN_LENGTH, _DYN_STRINGIFY, _DYN_TO_STRING } from \"../../__DynamicConstants\";\r\nexport function dataSanitizeKeyAndAddUniqueness(logger, key, map) {\r\n var origLength = key[_DYN_LENGTH /* @min:%2elength */];\r\n var field = dataSanitizeKey(logger, key);\r\n // validation truncated the length. We need to add uniqueness\r\n if (field[_DYN_LENGTH /* @min:%2elength */] !== origLength) {\r\n var i = 0;\r\n var uniqueField = field;\r\n while (map[uniqueField] !== undefined) {\r\n i++;\r\n uniqueField = strSubstring(field, 0, 150 /* DataSanitizerValues.MAX_NAME_LENGTH */ - 3) + dsPadNumber(i);\r\n }\r\n field = uniqueField;\r\n }\r\n return field;\r\n}\r\nexport function dataSanitizeKey(logger, name) {\r\n var nameTrunc;\r\n if (name) {\r\n // Remove any leading or trailing whitespace\r\n name = strTrim(asString(name));\r\n // truncate the string to 150 chars\r\n if (name[_DYN_LENGTH /* @min:%2elength */] > 150 /* DataSanitizerValues.MAX_NAME_LENGTH */) {\r\n nameTrunc = strSubstring(name, 0, 150 /* DataSanitizerValues.MAX_NAME_LENGTH */);\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 57 /* _eInternalMessageId.NameTooLong */, \"name is too long. It has been truncated to \" + 150 /* DataSanitizerValues.MAX_NAME_LENGTH */ + \" characters.\", { name: name }, true);\r\n }\r\n }\r\n return nameTrunc || name;\r\n}\r\nexport function dataSanitizeString(logger, value, maxLength) {\r\n if (maxLength === void 0) { maxLength = 1024 /* DataSanitizerValues.MAX_STRING_LENGTH */; }\r\n var valueTrunc;\r\n if (value) {\r\n maxLength = maxLength ? maxLength : 1024 /* DataSanitizerValues.MAX_STRING_LENGTH */; // in case default parameters dont work\r\n value = strTrim(asString(value));\r\n if (value[_DYN_LENGTH /* @min:%2elength */] > maxLength) {\r\n valueTrunc = strSubstring(value, 0, maxLength);\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 61 /* _eInternalMessageId.StringValueTooLong */, \"string value is too long. It has been truncated to \" + maxLength + \" characters.\", { value: value }, true);\r\n }\r\n }\r\n return valueTrunc || value;\r\n}\r\nexport function dataSanitizeUrl(logger, url) {\r\n return dataSanitizeInput(logger, url, 2048 /* DataSanitizerValues.MAX_URL_LENGTH */, 66 /* _eInternalMessageId.UrlTooLong */);\r\n}\r\nexport function dataSanitizeMessage(logger, message) {\r\n var messageTrunc;\r\n if (message) {\r\n if (message[_DYN_LENGTH /* @min:%2elength */] > 32768 /* DataSanitizerValues.MAX_MESSAGE_LENGTH */) {\r\n messageTrunc = strSubstring(message, 0, 32768 /* DataSanitizerValues.MAX_MESSAGE_LENGTH */);\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 56 /* _eInternalMessageId.MessageTruncated */, \"message is too long, it has been truncated to \" + 32768 /* DataSanitizerValues.MAX_MESSAGE_LENGTH */ + \" characters.\", { message: message }, true);\r\n }\r\n }\r\n return messageTrunc || message;\r\n}\r\nexport function dataSanitizeException(logger, exception) {\r\n var exceptionTrunc;\r\n if (exception) {\r\n // Make surte its a string\r\n var value = \"\" + exception;\r\n if (value[_DYN_LENGTH /* @min:%2elength */] > 32768 /* DataSanitizerValues.MAX_EXCEPTION_LENGTH */) {\r\n exceptionTrunc = strSubstring(value, 0, 32768 /* DataSanitizerValues.MAX_EXCEPTION_LENGTH */);\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 52 /* _eInternalMessageId.ExceptionTruncated */, \"exception is too long, it has been truncated to \" + 32768 /* DataSanitizerValues.MAX_EXCEPTION_LENGTH */ + \" characters.\", { exception: exception }, true);\r\n }\r\n }\r\n return exceptionTrunc || exception;\r\n}\r\nexport function dataSanitizeProperties(logger, properties) {\r\n if (properties) {\r\n var tempProps_1 = {};\r\n objForEachKey(properties, function (prop, value) {\r\n if (isObject(value) && hasJSON()) {\r\n // Stringify any part C properties\r\n try {\r\n value = getJSON()[_DYN_STRINGIFY /* @min:%2estringify */](value);\r\n }\r\n catch (e) {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 49 /* _eInternalMessageId.CannotSerializeObjectNonSerializable */, \"custom property is not valid\", { exception: e }, true);\r\n }\r\n }\r\n value = dataSanitizeString(logger, value, 8192 /* DataSanitizerValues.MAX_PROPERTY_LENGTH */);\r\n prop = dataSanitizeKeyAndAddUniqueness(logger, prop, tempProps_1);\r\n tempProps_1[prop] = value;\r\n });\r\n properties = tempProps_1;\r\n }\r\n return properties;\r\n}\r\nexport function dataSanitizeMeasurements(logger, measurements) {\r\n if (measurements) {\r\n var tempMeasurements_1 = {};\r\n objForEachKey(measurements, function (measure, value) {\r\n measure = dataSanitizeKeyAndAddUniqueness(logger, measure, tempMeasurements_1);\r\n tempMeasurements_1[measure] = value;\r\n });\r\n measurements = tempMeasurements_1;\r\n }\r\n return measurements;\r\n}\r\nexport function dataSanitizeId(logger, id) {\r\n return id ? dataSanitizeInput(logger, id, 128 /* DataSanitizerValues.MAX_ID_LENGTH */, 69 /* _eInternalMessageId.IdTooLong */)[_DYN_TO_STRING /* @min:%2etoString */]() : id;\r\n}\r\nexport function dataSanitizeInput(logger, input, maxLength, _msgId) {\r\n var inputTrunc;\r\n if (input) {\r\n input = strTrim(asString(input));\r\n if (input[_DYN_LENGTH /* @min:%2elength */] > maxLength) {\r\n inputTrunc = strSubstring(input, 0, maxLength);\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, _msgId, \"input is too long, it has been truncated to \" + maxLength + \" characters.\", { data: input }, true);\r\n }\r\n }\r\n return inputTrunc || input;\r\n}\r\nexport function dsPadNumber(num) {\r\n var s = \"00\" + num;\r\n return strSubstr(s, s[_DYN_LENGTH /* @min:%2elength */] - 3);\r\n}\r\n//# sourceMappingURL=DataSanitizer.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { getDocument, isString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_LENGTH, _DYN_MATCH, _DYN_PATHNAME, _DYN_TO_LOWER_CASE } from \"./__DynamicConstants\";\r\nvar _document = getDocument() || {};\r\nvar _htmlAnchorIdx = 0;\r\n// Use an array of temporary values as it's possible for multiple calls to parseUrl() will be called with different URLs\r\n// Using a cache size of 5 for now as it current depth usage is at least 2, so adding a minor buffer to handle future updates\r\nvar _htmlAnchorElement = [null, null, null, null, null];\r\nexport function urlParseUrl(url) {\r\n var anchorIdx = _htmlAnchorIdx;\r\n var anchorCache = _htmlAnchorElement;\r\n var tempAnchor = anchorCache[anchorIdx];\r\n if (!_document.createElement) {\r\n // Always create the temp instance if createElement is not available\r\n tempAnchor = { host: urlParseHost(url, true) };\r\n }\r\n else if (!anchorCache[anchorIdx]) {\r\n // Create and cache the unattached anchor instance\r\n tempAnchor = anchorCache[anchorIdx] = _document.createElement(\"a\");\r\n }\r\n tempAnchor.href = url;\r\n // Move the cache index forward\r\n anchorIdx++;\r\n if (anchorIdx >= anchorCache[_DYN_LENGTH /* @min:%2elength */]) {\r\n anchorIdx = 0;\r\n }\r\n _htmlAnchorIdx = anchorIdx;\r\n return tempAnchor;\r\n}\r\nexport function urlGetAbsoluteUrl(url) {\r\n var result;\r\n var a = urlParseUrl(url);\r\n if (a) {\r\n result = a.href;\r\n }\r\n return result;\r\n}\r\nexport function urlGetPathName(url) {\r\n var result;\r\n var a = urlParseUrl(url);\r\n if (a) {\r\n result = a[_DYN_PATHNAME /* @min:%2epathname */];\r\n }\r\n return result;\r\n}\r\nexport function urlGetCompleteUrl(method, absoluteUrl) {\r\n if (method) {\r\n return method.toUpperCase() + \" \" + absoluteUrl;\r\n }\r\n return absoluteUrl;\r\n}\r\n// Fallback method to grab host from url if document.createElement method is not available\r\nexport function urlParseHost(url, inclPort) {\r\n var fullHost = urlParseFullHost(url, inclPort) || \"\";\r\n if (fullHost) {\r\n var match = fullHost[_DYN_MATCH /* @min:%2ematch */](/(www\\d{0,5}\\.)?([^\\/:]{1,256})(:\\d{1,20})?/i);\r\n if (match != null && match[_DYN_LENGTH /* @min:%2elength */] > 3 && isString(match[2]) && match[2][_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n return match[2] + (match[3] || \"\");\r\n }\r\n }\r\n return fullHost;\r\n}\r\nexport function urlParseFullHost(url, inclPort) {\r\n var result = null;\r\n if (url) {\r\n var match = url[_DYN_MATCH /* @min:%2ematch */](/(\\w{1,150}):\\/\\/([^\\/:]{1,256})(:\\d{1,20})?/i);\r\n if (match != null && match[_DYN_LENGTH /* @min:%2elength */] > 2 && isString(match[2]) && match[2][_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n result = match[2] || \"\";\r\n if (inclPort && match[_DYN_LENGTH /* @min:%2elength */] > 2) {\r\n var protocol = (match[1] || \"\")[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n var port = match[3] || \"\";\r\n // IE includes the standard port so pass it off if it's the same as the protocol\r\n if (protocol === \"http\" && port === \":80\") {\r\n port = \"\";\r\n }\r\n else if (protocol === \"https\" && port === \":443\") {\r\n port = \"\";\r\n }\r\n result += port;\r\n }\r\n }\r\n }\r\n return result;\r\n}\r\n//# sourceMappingURL=UrlHelperFuncs.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { arrForEach, arrIndexOf, dateNow, getPerformance, isNullOrUndefined, isValidSpanId, isValidTraceId } from \"@microsoft/applicationinsights-core-js\";\r\nimport { strIndexOf } from \"@nevware21/ts-utils\";\r\nimport { DEFAULT_BREEZE_ENDPOINT, DEFAULT_BREEZE_PATH } from \"./Constants\";\r\nimport { RequestHeaders } from \"./RequestResponseHeaders\";\r\nimport { dataSanitizeString } from \"./Telemetry/Common/DataSanitizer\";\r\nimport { urlParseFullHost, urlParseUrl } from \"./UrlHelperFuncs\";\r\nimport { _DYN_CORRELATION_HEADER_E0, _DYN_LENGTH, _DYN_NAME, _DYN_PATHNAME, _DYN_SPLIT, _DYN_TO_LOWER_CASE } from \"./__DynamicConstants\";\r\n// listing only non-geo specific locations\r\nvar _internalEndpoints = [\r\n DEFAULT_BREEZE_ENDPOINT + DEFAULT_BREEZE_PATH,\r\n \"https://breeze.aimon.applicationinsights.io\" + DEFAULT_BREEZE_PATH,\r\n \"https://dc-int.services.visualstudio.com\" + DEFAULT_BREEZE_PATH\r\n];\r\nvar _correlationIdPrefix = \"cid-v1:\";\r\nexport function isInternalApplicationInsightsEndpoint(endpointUrl) {\r\n return arrIndexOf(_internalEndpoints, endpointUrl[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]()) !== -1;\r\n}\r\nexport function correlationIdSetPrefix(prefix) {\r\n _correlationIdPrefix = prefix;\r\n}\r\nexport function correlationIdGetPrefix() {\r\n return _correlationIdPrefix;\r\n}\r\n/**\r\n * Checks if a request url is not on a excluded domain list and if it is safe to add correlation headers.\r\n * Headers are always included if the current domain matches the request domain. If they do not match (CORS),\r\n * they are regex-ed across correlationHeaderDomains and correlationHeaderExcludedDomains to determine if headers are included.\r\n * Some environments don't give information on currentHost via window.location.host (e.g. Cordova). In these cases, the user must\r\n * manually supply domains to include correlation headers on. Else, no headers will be included at all.\r\n */\r\nexport function correlationIdCanIncludeCorrelationHeader(config, requestUrl, currentHost) {\r\n if (!requestUrl || (config && config.disableCorrelationHeaders)) {\r\n return false;\r\n }\r\n if (config && config[_DYN_CORRELATION_HEADER_E0 /* @min:%2ecorrelationHeaderExcludePatterns */]) {\r\n for (var i = 0; i < config.correlationHeaderExcludePatterns[_DYN_LENGTH /* @min:%2elength */]; i++) {\r\n if (config[_DYN_CORRELATION_HEADER_E0 /* @min:%2ecorrelationHeaderExcludePatterns */][i].test(requestUrl)) {\r\n return false;\r\n }\r\n }\r\n }\r\n var requestHost = urlParseUrl(requestUrl).host[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n if (requestHost && (strIndexOf(requestHost, \":443\") !== -1 || strIndexOf(requestHost, \":80\") !== -1)) {\r\n // [Bug #1260] IE can include the port even for http and https URLs so if present\r\n // try and parse it to remove if it matches the default protocol port\r\n requestHost = (urlParseFullHost(requestUrl, true) || \"\")[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n }\r\n if ((!config || !config.enableCorsCorrelation) && (requestHost && requestHost !== currentHost)) {\r\n return false;\r\n }\r\n var includedDomains = config && config.correlationHeaderDomains;\r\n if (includedDomains) {\r\n var matchExists_1;\r\n arrForEach(includedDomains, function (domain) {\r\n var regex = new RegExp(domain.toLowerCase().replace(/\\\\/g, \"\\\\\\\\\").replace(/\\./g, \"\\\\.\").replace(/\\*/g, \".*\"));\r\n matchExists_1 = matchExists_1 || regex.test(requestHost);\r\n });\r\n if (!matchExists_1) {\r\n return false;\r\n }\r\n }\r\n var excludedDomains = config && config.correlationHeaderExcludedDomains;\r\n if (!excludedDomains || excludedDomains[_DYN_LENGTH /* @min:%2elength */] === 0) {\r\n return true;\r\n }\r\n for (var i = 0; i < excludedDomains[_DYN_LENGTH /* @min:%2elength */]; i++) {\r\n var regex = new RegExp(excludedDomains[i].toLowerCase().replace(/\\\\/g, \"\\\\\\\\\").replace(/\\./g, \"\\\\.\").replace(/\\*/g, \".*\"));\r\n if (regex.test(requestHost)) {\r\n return false;\r\n }\r\n }\r\n // if we don't know anything about the requestHost, require the user to use included/excludedDomains.\r\n // Previously we always returned false for a falsy requestHost\r\n return requestHost && requestHost[_DYN_LENGTH /* @min:%2elength */] > 0;\r\n}\r\n/**\r\n * Combines target appId and target role name from response header.\r\n */\r\nexport function correlationIdGetCorrelationContext(responseHeader) {\r\n if (responseHeader) {\r\n var correlationId = correlationIdGetCorrelationContextValue(responseHeader, RequestHeaders[1 /* eRequestHeaders.requestContextTargetKey */]);\r\n if (correlationId && correlationId !== _correlationIdPrefix) {\r\n return correlationId;\r\n }\r\n }\r\n}\r\n/**\r\n * Gets key from correlation response header\r\n */\r\nexport function correlationIdGetCorrelationContextValue(responseHeader, key) {\r\n if (responseHeader) {\r\n var keyValues = responseHeader[_DYN_SPLIT /* @min:%2esplit */](\",\");\r\n for (var i = 0; i < keyValues[_DYN_LENGTH /* @min:%2elength */]; ++i) {\r\n var keyValue = keyValues[i][_DYN_SPLIT /* @min:%2esplit */](\"=\");\r\n if (keyValue[_DYN_LENGTH /* @min:%2elength */] === 2 && keyValue[0] === key) {\r\n return keyValue[1];\r\n }\r\n }\r\n }\r\n}\r\nexport function AjaxHelperParseDependencyPath(logger, absoluteUrl, method, commandName) {\r\n var target, name = commandName, data = commandName;\r\n if (absoluteUrl && absoluteUrl[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n var parsedUrl = urlParseUrl(absoluteUrl);\r\n target = parsedUrl.host;\r\n if (!name) {\r\n if (parsedUrl[_DYN_PATHNAME /* @min:%2epathname */] != null) {\r\n var pathName = (parsedUrl.pathname[_DYN_LENGTH /* @min:%2elength */] === 0) ? \"/\" : parsedUrl[_DYN_PATHNAME /* @min:%2epathname */];\r\n if (pathName.charAt(0) !== \"/\") {\r\n pathName = \"/\" + pathName;\r\n }\r\n data = parsedUrl[_DYN_PATHNAME /* @min:%2epathname */];\r\n name = dataSanitizeString(logger, method ? method + \" \" + pathName : pathName);\r\n }\r\n else {\r\n name = dataSanitizeString(logger, absoluteUrl);\r\n }\r\n }\r\n }\r\n else {\r\n target = commandName;\r\n name = commandName;\r\n }\r\n return {\r\n target: target,\r\n name: name,\r\n data: data\r\n };\r\n}\r\nexport function dateTimeUtilsNow() {\r\n // returns the window or webworker performance object\r\n var perf = getPerformance();\r\n if (perf && perf.now && perf.timing) {\r\n var now = perf.now() + perf.timing.navigationStart;\r\n // Known issue with IE where this calculation can be negative, so if it is then ignore and fallback\r\n if (now > 0) {\r\n return now;\r\n }\r\n }\r\n return dateNow();\r\n}\r\nexport function dateTimeUtilsDuration(start, end) {\r\n var result = null;\r\n if (start !== 0 && end !== 0 && !isNullOrUndefined(start) && !isNullOrUndefined(end)) {\r\n result = end - start;\r\n }\r\n return result;\r\n}\r\n/**\r\n * Creates a IDistributedTraceContext from an optional telemetryTrace\r\n * @param telemetryTrace - The telemetryTrace instance that is being wrapped\r\n * @param parentCtx - An optional parent distributed trace instance, almost always undefined as this scenario is only used in the case of multiple property handlers.\r\n * @returns A new IDistributedTraceContext instance that is backed by the telemetryTrace or temporary object\r\n */\r\nexport function createDistributedTraceContextFromTrace(telemetryTrace, parentCtx) {\r\n var trace = telemetryTrace || {};\r\n return {\r\n getName: function () {\r\n return trace[_DYN_NAME /* @min:%2ename */];\r\n },\r\n setName: function (newValue) {\r\n parentCtx && parentCtx.setName(newValue);\r\n trace[_DYN_NAME /* @min:%2ename */] = newValue;\r\n },\r\n getTraceId: function () {\r\n return trace.traceID;\r\n },\r\n setTraceId: function (newValue) {\r\n parentCtx && parentCtx.setTraceId(newValue);\r\n if (isValidTraceId(newValue)) {\r\n trace.traceID = newValue;\r\n }\r\n },\r\n getSpanId: function () {\r\n return trace.parentID;\r\n },\r\n setSpanId: function (newValue) {\r\n parentCtx && parentCtx.setSpanId(newValue);\r\n if (isValidSpanId(newValue)) {\r\n trace.parentID = newValue;\r\n }\r\n },\r\n getTraceFlags: function () {\r\n return trace.traceFlags;\r\n },\r\n setTraceFlags: function (newTraceFlags) {\r\n parentCtx && parentCtx.setTraceFlags(newTraceFlags);\r\n trace.traceFlags = newTraceFlags;\r\n }\r\n };\r\n}\r\n//# sourceMappingURL=Util.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { createEnumStyle } from \"@microsoft/applicationinsights-core-js\";\r\nexport var StorageType = createEnumStyle({\r\n LocalStorage: 0 /* eStorageType.LocalStorage */,\r\n SessionStorage: 1 /* eStorageType.SessionStorage */\r\n});\r\nexport var DistributedTracingModes = createEnumStyle({\r\n AI: 0 /* eDistributedTracingModes.AI */,\r\n AI_AND_W3C: 1 /* eDistributedTracingModes.AI_AND_W3C */,\r\n W3C: 2 /* eDistributedTracingModes.W3C */\r\n});\r\n/**\r\n * The EventPersistence contains a set of values that specify the event's persistence.\r\n */\r\nexport var EventPersistence = createEnumStyle({\r\n /**\r\n * Normal persistence.\r\n */\r\n Normal: 1 /* EventPersistenceValue.Normal */,\r\n /**\r\n * Critical persistence.\r\n */\r\n Critical: 2 /* EventPersistenceValue.Critical */\r\n});\r\n//# sourceMappingURL=Enums.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { _throwInternal, dumpObj, getExceptionName, getGlobal, getGlobalInst, isNullOrUndefined, objForEachKey } from \"@microsoft/applicationinsights-core-js\";\r\nimport { StorageType } from \"./Enums\";\r\nimport { _DYN_REMOVE_ITEM, _DYN_TO_STRING } from \"./__DynamicConstants\";\r\nvar _canUseLocalStorage = undefined;\r\nvar _canUseSessionStorage = undefined;\r\nvar _storagePrefix = \"\";\r\n/**\r\n * Gets the localStorage object if available\r\n * @returns {Storage} - Returns the storage object if available else returns null\r\n */\r\nfunction _getLocalStorageObject() {\r\n if (utlCanUseLocalStorage()) {\r\n return _getVerifiedStorageObject(StorageType.LocalStorage);\r\n }\r\n return null;\r\n}\r\n/**\r\n * Tests storage object (localStorage or sessionStorage) to verify that it is usable\r\n * More details here: https://mathiasbynens.be/notes/localstorage-pattern\r\n * @param storageType - Type of storage\r\n * @returns {Storage} Returns storage object verified that it is usable\r\n */\r\nfunction _getVerifiedStorageObject(storageType) {\r\n try {\r\n if (isNullOrUndefined(getGlobal())) {\r\n return null;\r\n }\r\n var uid = (new Date)[_DYN_TO_STRING /* @min:%2etoString */]();\r\n var storage = getGlobalInst(storageType === StorageType.LocalStorage ? \"localStorage\" : \"sessionStorage\");\r\n var name_1 = _storagePrefix + uid;\r\n storage.setItem(name_1, uid);\r\n var fail = storage.getItem(name_1) !== uid;\r\n storage[_DYN_REMOVE_ITEM /* @min:%2eremoveItem */](name_1);\r\n if (!fail) {\r\n return storage;\r\n }\r\n }\r\n catch (exception) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return null;\r\n}\r\n/**\r\n * Gets the sessionStorage object if available\r\n * @returns {Storage} - Returns the storage object if available else returns null\r\n */\r\nfunction _getSessionStorageObject() {\r\n if (utlCanUseSessionStorage()) {\r\n return _getVerifiedStorageObject(StorageType.SessionStorage);\r\n }\r\n return null;\r\n}\r\n/**\r\n * Disables the global SDK usage of local or session storage if available\r\n */\r\nexport function utlDisableStorage() {\r\n _canUseLocalStorage = false;\r\n _canUseSessionStorage = false;\r\n}\r\nexport function utlSetStoragePrefix(storagePrefix) {\r\n _storagePrefix = storagePrefix || \"\";\r\n}\r\n/**\r\n * Re-enables the global SDK usage of local or session storage if available\r\n */\r\nexport function utlEnableStorage() {\r\n _canUseLocalStorage = utlCanUseLocalStorage(true);\r\n _canUseSessionStorage = utlCanUseSessionStorage(true);\r\n}\r\n/**\r\n * Returns whether LocalStorage can be used, if the reset parameter is passed a true this will override\r\n * any previous disable calls.\r\n * @param reset - Should the usage be reset and determined only based on whether LocalStorage is available\r\n */\r\nexport function utlCanUseLocalStorage(reset) {\r\n if (reset || _canUseLocalStorage === undefined) {\r\n _canUseLocalStorage = !!_getVerifiedStorageObject(StorageType.LocalStorage);\r\n }\r\n return _canUseLocalStorage;\r\n}\r\nexport function utlGetLocalStorage(logger, name) {\r\n var storage = _getLocalStorageObject();\r\n if (storage !== null) {\r\n try {\r\n return storage.getItem(name);\r\n }\r\n catch (e) {\r\n _canUseLocalStorage = false;\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 1 /* _eInternalMessageId.BrowserCannotReadLocalStorage */, \"Browser failed read of local storage. \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return null;\r\n}\r\nexport function utlSetLocalStorage(logger, name, data) {\r\n var storage = _getLocalStorageObject();\r\n if (storage !== null) {\r\n try {\r\n storage.setItem(name, data);\r\n return true;\r\n }\r\n catch (e) {\r\n _canUseLocalStorage = false;\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 3 /* _eInternalMessageId.BrowserCannotWriteLocalStorage */, \"Browser failed write to local storage. \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return false;\r\n}\r\nexport function utlRemoveStorage(logger, name) {\r\n var storage = _getLocalStorageObject();\r\n if (storage !== null) {\r\n try {\r\n storage[_DYN_REMOVE_ITEM /* @min:%2eremoveItem */](name);\r\n return true;\r\n }\r\n catch (e) {\r\n _canUseLocalStorage = false;\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 5 /* _eInternalMessageId.BrowserFailedRemovalFromLocalStorage */, \"Browser failed removal of local storage item. \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return false;\r\n}\r\nexport function utlCanUseSessionStorage(reset) {\r\n if (reset || _canUseSessionStorage === undefined) {\r\n _canUseSessionStorage = !!_getVerifiedStorageObject(StorageType.SessionStorage);\r\n }\r\n return _canUseSessionStorage;\r\n}\r\nexport function utlGetSessionStorageKeys() {\r\n var keys = [];\r\n if (utlCanUseSessionStorage()) {\r\n objForEachKey(getGlobalInst(\"sessionStorage\"), function (key) {\r\n keys.push(key);\r\n });\r\n }\r\n return keys;\r\n}\r\nexport function utlGetSessionStorage(logger, name) {\r\n var storage = _getSessionStorageObject();\r\n if (storage !== null) {\r\n try {\r\n return storage.getItem(name);\r\n }\r\n catch (e) {\r\n _canUseSessionStorage = false;\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 2 /* _eInternalMessageId.BrowserCannotReadSessionStorage */, \"Browser failed read of session storage. \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return null;\r\n}\r\nexport function utlSetSessionStorage(logger, name, data) {\r\n var storage = _getSessionStorageObject();\r\n if (storage !== null) {\r\n try {\r\n storage.setItem(name, data);\r\n return true;\r\n }\r\n catch (e) {\r\n _canUseSessionStorage = false;\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 4 /* _eInternalMessageId.BrowserCannotWriteSessionStorage */, \"Browser failed write to session storage. \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return false;\r\n}\r\nexport function utlRemoveSessionStorage(logger, name) {\r\n var storage = _getSessionStorageObject();\r\n if (storage !== null) {\r\n try {\r\n storage[_DYN_REMOVE_ITEM /* @min:%2eremoveItem */](name);\r\n return true;\r\n }\r\n catch (e) {\r\n _canUseSessionStorage = false;\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 6 /* _eInternalMessageId.BrowserFailedRemovalFromSessionStorage */, \"Browser failed removal of session storage item. \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return false;\r\n}\r\n//# sourceMappingURL=StorageHelperFuncs.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { _throwInternal, arrIndexOf, isNotNullOrUndefined, isNullOrUndefined, onConfigChange, randomValue, safeGetLogger, strTrim } from \"@microsoft/applicationinsights-core-js\";\r\nimport { arrForEach, mathFloor, mathMin, objForEachKey } from \"@nevware21/ts-utils\";\r\nimport { utlCanUseLocalStorage, utlGetLocalStorage, utlSetLocalStorage } from \"./StorageHelperFuncs\";\r\nimport { _DYN_COUNT, _DYN_GET_UTCDATE, _DYN_LENGTH, _DYN_MESSAGE, _DYN_PRE_TRIGGER_DATE, _DYN_STRINGIFY } from \"./__DynamicConstants\";\r\nvar THROTTLE_STORAGE_PREFIX = \"appInsightsThrottle\";\r\nvar ThrottleMgr = /** @class */ (function () {\r\n function ThrottleMgr(core, namePrefix) {\r\n var _self = this;\r\n var _canUseLocalStorage;\r\n var _logger;\r\n var _config;\r\n var _localStorageObj;\r\n var _isTriggered; //_isTriggered is to make sure that we only trigger throttle once a day\r\n var _namePrefix;\r\n var _queue;\r\n var _isReady = false;\r\n var _isSpecificDaysGiven = false;\r\n _initConfig();\r\n // Special internal method to allow the unit tests and DebugPlugin to hook embedded objects\r\n _self[\"_getDbgPlgTargets\"] = function () {\r\n return [_queue];\r\n };\r\n _self.getConfig = function () {\r\n return _config;\r\n };\r\n /**\r\n * Check if it is the correct day to send message.\r\n * If _isTriggered is true, even if canThrottle returns true, message will not be sent,\r\n * because we only allow triggering sendMessage() once a day.\r\n * @returns if the current date is the valid date to send message\r\n */\r\n _self.canThrottle = function (msgId) {\r\n var localObj = _getLocalStorageObjByKey(msgId);\r\n var cfg = _getCfgByKey(msgId);\r\n return _canThrottle(cfg, _canUseLocalStorage, localObj);\r\n };\r\n /**\r\n * Check if throttle is triggered on current day(UTC)\r\n * if canThrottle returns false, isTriggered will return false\r\n * @returns if throttle is triggered on current day(UTC)\r\n */\r\n _self.isTriggered = function (msgId) {\r\n return _isTrigger(msgId);\r\n };\r\n /**\r\n * Before isReady set to true, all message will be stored in queue.\r\n * Message will only be sent out after isReady set to true.\r\n * Initial and default value: false\r\n * @returns isReady state\r\n */\r\n _self.isReady = function () {\r\n return _isReady;\r\n };\r\n /**\r\n * Flush all message with given message key in queue with isReady state set to true.\r\n * @returns if message queue is flushed\r\n */\r\n _self.flush = function (msgId) {\r\n try {\r\n var queue = _getQueueByKey(msgId);\r\n if (queue && queue[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n var items = queue.slice(0);\r\n _queue[msgId] = [];\r\n arrForEach(items, function (item) {\r\n _flushMessage(item.msgID, item[_DYN_MESSAGE /* @min:%2emessage */], item.severity, false);\r\n });\r\n return true;\r\n }\r\n }\r\n catch (err) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return false;\r\n };\r\n /**\r\n * Flush all message in queue with isReady state set to true.\r\n * @returns if message queue is flushed\r\n */\r\n _self.flushAll = function () {\r\n try {\r\n if (_queue) {\r\n var result_1 = true;\r\n objForEachKey(_queue, function (key) {\r\n var isFlushed = _self.flush(parseInt(key));\r\n result_1 = result_1 && isFlushed;\r\n });\r\n return result_1;\r\n }\r\n }\r\n catch (err) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return false;\r\n };\r\n /**\r\n * Set isReady State\r\n * if isReady set to true, message queue will be flushed automatically.\r\n * @param isReady - isReady State\r\n * @pa\r\n * @returns if message queue is flushed\r\n */\r\n _self.onReadyState = function (isReady, flushAll) {\r\n if (flushAll === void 0) { flushAll = true; }\r\n _isReady = isNullOrUndefined(isReady) ? true : isReady;\r\n if (_isReady && flushAll) {\r\n return _self.flushAll();\r\n }\r\n return null;\r\n };\r\n _self.sendMessage = function (msgID, message, severity) {\r\n return _flushMessage(msgID, message, severity, true);\r\n };\r\n function _flushMessage(msgID, message, severity, saveUnsentMsg) {\r\n if (_isReady) {\r\n var isSampledIn = _canSampledIn(msgID);\r\n if (!isSampledIn) {\r\n return;\r\n }\r\n var cfg = _getCfgByKey(msgID);\r\n var localStorageObj = _getLocalStorageObjByKey(msgID);\r\n var canThrottle = _canThrottle(cfg, _canUseLocalStorage, localStorageObj);\r\n var throttled = false;\r\n var number = 0;\r\n var isTriggered = _isTrigger(msgID);\r\n try {\r\n if (canThrottle && !isTriggered) {\r\n number = mathMin(cfg.limit.maxSendNumber, localStorageObj[_DYN_COUNT /* @min:%2ecount */] + 1);\r\n localStorageObj[_DYN_COUNT /* @min:%2ecount */] = 0;\r\n throttled = true;\r\n _isTriggered[msgID] = true;\r\n localStorageObj[_DYN_PRE_TRIGGER_DATE /* @min:%2epreTriggerDate */] = new Date();\r\n }\r\n else {\r\n _isTriggered[msgID] = canThrottle;\r\n localStorageObj[_DYN_COUNT /* @min:%2ecount */] += 1;\r\n }\r\n var localStorageName = _getLocalStorageName(msgID);\r\n _resetLocalStorage(_logger, localStorageName, localStorageObj);\r\n for (var i = 0; i < number; i++) {\r\n _sendMessage(msgID, _logger, message, severity);\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return {\r\n isThrottled: throttled,\r\n throttleNum: number\r\n };\r\n }\r\n else {\r\n if (!!saveUnsentMsg) {\r\n var queue = _getQueueByKey(msgID);\r\n queue.push({\r\n msgID: msgID,\r\n message: message,\r\n severity: severity\r\n });\r\n }\r\n }\r\n return null;\r\n }\r\n function _initConfig() {\r\n _logger = safeGetLogger(core);\r\n _isTriggered = {};\r\n _localStorageObj = {};\r\n _queue = {};\r\n _config = {};\r\n _setCfgByKey(109 /* _eInternalMessageId.DefaultThrottleMsgKey */);\r\n _namePrefix = isNotNullOrUndefined(namePrefix) ? namePrefix : \"\";\r\n core.addUnloadHook(onConfigChange(core.config, function (details) {\r\n var coreConfig = details.cfg;\r\n _canUseLocalStorage = utlCanUseLocalStorage();\r\n var configMgr = coreConfig.throttleMgrCfg || {};\r\n objForEachKey(configMgr, function (key, cfg) {\r\n _setCfgByKey(parseInt(key), cfg);\r\n });\r\n }));\r\n }\r\n function _getCfgByKey(msgID) {\r\n return _config[msgID] || _config[109 /* _eInternalMessageId.DefaultThrottleMsgKey */];\r\n }\r\n function _setCfgByKey(msgID, config) {\r\n var _a, _b;\r\n try {\r\n var cfg = config || {};\r\n var curCfg = {};\r\n curCfg.disabled = !!cfg.disabled;\r\n var configInterval = cfg.interval || {};\r\n _isSpecificDaysGiven = (configInterval === null || configInterval === void 0 ? void 0 : configInterval.daysOfMonth) && (configInterval === null || configInterval === void 0 ? void 0 : configInterval.daysOfMonth[_DYN_LENGTH /* @min:%2elength */]) > 0;\r\n curCfg.interval = _getIntervalConfig(configInterval);\r\n var limit = {\r\n samplingRate: ((_a = cfg.limit) === null || _a === void 0 ? void 0 : _a.samplingRate) || 100,\r\n // dafault: every time sent only 1 event\r\n maxSendNumber: ((_b = cfg.limit) === null || _b === void 0 ? void 0 : _b.maxSendNumber) || 1\r\n };\r\n curCfg.limit = limit;\r\n _config[msgID] = curCfg;\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n }\r\n function _getIntervalConfig(interval) {\r\n interval = interval || {};\r\n var monthInterval = interval === null || interval === void 0 ? void 0 : interval.monthInterval;\r\n var dayInterval = interval === null || interval === void 0 ? void 0 : interval.dayInterval;\r\n // default: send data every 3 month each year\r\n if (isNullOrUndefined(monthInterval) && isNullOrUndefined(dayInterval)) {\r\n interval.monthInterval = 3;\r\n if (!_isSpecificDaysGiven) {\r\n // default: send data on 28th\r\n interval.daysOfMonth = [28];\r\n _isSpecificDaysGiven = true;\r\n }\r\n }\r\n interval = {\r\n // dafault: sent every three months\r\n monthInterval: interval === null || interval === void 0 ? void 0 : interval.monthInterval,\r\n dayInterval: interval === null || interval === void 0 ? void 0 : interval.dayInterval,\r\n daysOfMonth: interval === null || interval === void 0 ? void 0 : interval.daysOfMonth\r\n };\r\n return interval;\r\n }\r\n function _canThrottle(config, canUseLocalStorage, localStorageObj) {\r\n if (config && !config.disabled && canUseLocalStorage && isNotNullOrUndefined(localStorageObj)) {\r\n var curDate = _getThrottleDate();\r\n var date = localStorageObj.date;\r\n var interval = config.interval;\r\n var monthCheck = 1;\r\n if (interval === null || interval === void 0 ? void 0 : interval.monthInterval) {\r\n var monthExpand = (curDate.getUTCFullYear() - date.getUTCFullYear()) * 12 + curDate.getUTCMonth() - date.getUTCMonth();\r\n monthCheck = _checkInterval(interval.monthInterval, 0, monthExpand);\r\n }\r\n var dayCheck = 1;\r\n if (_isSpecificDaysGiven) {\r\n dayCheck = arrIndexOf(interval.daysOfMonth, curDate[_DYN_GET_UTCDATE /* @min:%2egetUTCDate */]());\r\n }\r\n else if (interval === null || interval === void 0 ? void 0 : interval.dayInterval) {\r\n var daySpan = mathFloor((curDate.getTime() - date.getTime()) / 86400000);\r\n dayCheck = _checkInterval(interval.dayInterval, 0, daySpan);\r\n }\r\n return monthCheck >= 0 && dayCheck >= 0;\r\n }\r\n return false;\r\n }\r\n function _getLocalStorageName(msgKey, prefix) {\r\n var fix = isNotNullOrUndefined(prefix) ? prefix : \"\";\r\n if (msgKey) {\r\n return THROTTLE_STORAGE_PREFIX + fix + \"-\" + msgKey;\r\n }\r\n return null;\r\n }\r\n // returns if throttle is triggered on current Date\r\n function _isTriggeredOnCurDate(preTriggerDate) {\r\n try {\r\n if (preTriggerDate) {\r\n var curDate = new Date();\r\n return preTriggerDate.getUTCFullYear() === curDate.getUTCFullYear() &&\r\n preTriggerDate.getUTCMonth() === curDate.getUTCMonth() &&\r\n preTriggerDate[_DYN_GET_UTCDATE /* @min:%2egetUTCDate */]() === curDate[_DYN_GET_UTCDATE /* @min:%2egetUTCDate */]();\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return false;\r\n }\r\n // transfer local storage string value to object that identifies start date, current count and preTriggerDate\r\n function _getLocalStorageObj(value, logger, storageName) {\r\n try {\r\n var storageObj = {\r\n date: _getThrottleDate(),\r\n count: 0\r\n };\r\n if (value) {\r\n var obj = JSON.parse(value);\r\n var curObj = {\r\n date: _getThrottleDate(obj.date) || storageObj.date,\r\n count: obj[_DYN_COUNT /* @min:%2ecount */] || storageObj[_DYN_COUNT /* @min:%2ecount */],\r\n preTriggerDate: obj.preTriggerDate ? _getThrottleDate(obj[_DYN_PRE_TRIGGER_DATE /* @min:%2epreTriggerDate */]) : undefined\r\n };\r\n return curObj;\r\n }\r\n else {\r\n _resetLocalStorage(logger, storageName, storageObj);\r\n return storageObj;\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return null;\r\n }\r\n // if datestr is not defined, current date will be returned\r\n function _getThrottleDate(dateStr) {\r\n // if new Date() can't be created through the provided dateStr, null will be returned.\r\n try {\r\n if (dateStr) {\r\n var date = new Date(dateStr);\r\n //make sure it is a valid Date Object\r\n if (!isNaN(date.getDate())) {\r\n return date;\r\n }\r\n }\r\n else {\r\n return new Date();\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return null;\r\n }\r\n function _resetLocalStorage(logger, storageName, obj) {\r\n try {\r\n return utlSetLocalStorage(logger, storageName, strTrim(JSON[_DYN_STRINGIFY /* @min:%2estringify */](obj)));\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return false;\r\n }\r\n function _checkInterval(interval, start, current) {\r\n if (interval <= 0) {\r\n return 1;\r\n }\r\n // count from start year\r\n return (current >= start) && (current - start) % interval == 0 ? mathFloor((current - start) / interval) + 1 : -1;\r\n }\r\n function _sendMessage(msgID, logger, message, severity) {\r\n _throwInternal(logger, severity || 1 /* eLoggingSeverity.CRITICAL */, msgID, message);\r\n }\r\n // NOTE: config.limit.samplingRate is set to 4 decimal places,\r\n // so config.limit.samplingRate = 1 means 0.0001%\r\n function _canSampledIn(msgID) {\r\n try {\r\n var cfg = _getCfgByKey(msgID);\r\n return randomValue(1000000) <= cfg.limit.samplingRate;\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return false;\r\n }\r\n function _getLocalStorageObjByKey(key) {\r\n try {\r\n var curObj = _localStorageObj[key];\r\n if (!curObj) {\r\n var localStorageName = _getLocalStorageName(key, _namePrefix);\r\n curObj = _getLocalStorageObj(utlGetLocalStorage(_logger, localStorageName), _logger, localStorageName);\r\n _localStorageObj[key] = curObj;\r\n }\r\n return _localStorageObj[key];\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return null;\r\n }\r\n function _isTrigger(key) {\r\n var isTrigger = _isTriggered[key];\r\n if (isNullOrUndefined(isTrigger)) {\r\n isTrigger = false;\r\n var localStorageObj = _getLocalStorageObjByKey(key);\r\n if (localStorageObj) {\r\n isTrigger = _isTriggeredOnCurDate(localStorageObj[_DYN_PRE_TRIGGER_DATE /* @min:%2epreTriggerDate */]);\r\n }\r\n _isTriggered[key] = isTrigger;\r\n }\r\n return _isTriggered[key];\r\n }\r\n function _getQueueByKey(key) {\r\n _queue = _queue || {};\r\n if (isNullOrUndefined(_queue[key])) {\r\n _queue[key] = [];\r\n }\r\n return _queue[key];\r\n }\r\n }\r\n return ThrottleMgr;\r\n}());\r\nexport { ThrottleMgr };\r\n//# sourceMappingURL=ThrottleMgr.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { arrReduce, objKeys, strEndsWith } from \"@microsoft/applicationinsights-core-js\";\r\nimport { DEFAULT_BREEZE_ENDPOINT } from \"./Constants\";\r\nimport { _DYN_INGESTIONENDPOINT, _DYN_LENGTH, _DYN_SPLIT, _DYN_TO_LOWER_CASE } from \"./__DynamicConstants\";\r\nvar _FIELDS_SEPARATOR = \";\";\r\nvar _FIELD_KEY_VALUE_SEPARATOR = \"=\";\r\nexport function parseConnectionString(connectionString) {\r\n if (!connectionString) {\r\n return {};\r\n }\r\n var kvPairs = connectionString[_DYN_SPLIT /* @min:%2esplit */](_FIELDS_SEPARATOR);\r\n var result = arrReduce(kvPairs, function (fields, kv) {\r\n var kvParts = kv[_DYN_SPLIT /* @min:%2esplit */](_FIELD_KEY_VALUE_SEPARATOR);\r\n if (kvParts[_DYN_LENGTH /* @min:%2elength */] === 2) { // only save fields with valid formats\r\n var key = kvParts[0][_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n var value = kvParts[1];\r\n fields[key] = value;\r\n }\r\n return fields;\r\n }, {});\r\n if (objKeys(result)[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n // this is a valid connection string, so parse the results\r\n if (result.endpointsuffix) {\r\n // apply the default endpoints\r\n var locationPrefix = result.location ? result.location + \".\" : \"\";\r\n result[_DYN_INGESTIONENDPOINT /* @min:%2eingestionendpoint */] = result[_DYN_INGESTIONENDPOINT /* @min:%2eingestionendpoint */] || (\"https://\" + locationPrefix + \"dc.\" + result.endpointsuffix);\r\n }\r\n // apply user override endpoint or the default endpoints\r\n result[_DYN_INGESTIONENDPOINT /* @min:%2eingestionendpoint */] = result[_DYN_INGESTIONENDPOINT /* @min:%2eingestionendpoint */] || DEFAULT_BREEZE_ENDPOINT;\r\n if (strEndsWith(result[_DYN_INGESTIONENDPOINT /* @min:%2eingestionendpoint */], \"/\")) {\r\n result[_DYN_INGESTIONENDPOINT /* @min:%2eingestionendpoint */] = result[_DYN_INGESTIONENDPOINT /* @min:%2eingestionendpoint */].slice(0, -1);\r\n }\r\n }\r\n return result;\r\n}\r\nexport var ConnectionStringParser = {\r\n parse: parseConnectionString\r\n};\r\n//# sourceMappingURL=ConnectionStringParser.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { toISOString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { strNotSpecified } from \"../../Constants\";\r\nimport { _DYN_AI_DATA_CONTRACT, _DYN_NAME } from \"../../__DynamicConstants\";\r\nimport { dataSanitizeString } from \"./DataSanitizer\";\r\nvar Envelope = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of telemetry data.\r\n */\r\n function Envelope(logger, data, name) {\r\n var _this = this;\r\n var _self = this;\r\n _self.ver = 1;\r\n _self.sampleRate = 100.0;\r\n _self.tags = {};\r\n _self[_DYN_NAME /* @min:%2ename */] = dataSanitizeString(logger, name) || strNotSpecified;\r\n _self.data = data;\r\n _self.time = toISOString(new Date());\r\n _self[_DYN_AI_DATA_CONTRACT /* @min:%2eaiDataContract */] = {\r\n time: 1 /* FieldType.Required */,\r\n iKey: 1 /* FieldType.Required */,\r\n name: 1 /* FieldType.Required */,\r\n sampleRate: function () {\r\n return (_this.sampleRate === 100) ? 4 /* FieldType.Hidden */ : 1 /* FieldType.Required */;\r\n },\r\n tags: 1 /* FieldType.Required */,\r\n data: 1 /* FieldType.Required */\r\n };\r\n }\r\n return Envelope;\r\n}());\r\nexport { Envelope };\r\n//# sourceMappingURL=Envelope.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { strNotSpecified } from \"../Constants\";\r\nimport { _DYN_MEASUREMENTS, _DYN_NAME, _DYN_PROPERTIES } from \"../__DynamicConstants\";\r\nimport { dataSanitizeMeasurements, dataSanitizeProperties, dataSanitizeString } from \"./Common/DataSanitizer\";\r\nvar Event = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the EventTelemetry object\r\n */\r\n function Event(logger, name, properties, measurements) {\r\n this.aiDataContract = {\r\n ver: 1 /* FieldType.Required */,\r\n name: 1 /* FieldType.Required */,\r\n properties: 0 /* FieldType.Default */,\r\n measurements: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2;\r\n _self[_DYN_NAME /* @min:%2ename */] = dataSanitizeString(logger, name) || strNotSpecified;\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n }\r\n Event.envelopeType = \"Microsoft.ApplicationInsights.{0}.Event\";\r\n Event.dataType = \"EventData\";\r\n return Event;\r\n}());\r\nexport { Event };\r\n//# sourceMappingURL=Event.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { __assignFn as __assign } from \"@microsoft/applicationinsights-shims\";\r\nimport { arrForEach, arrMap, isArray, isError, isFunction, isNullOrUndefined, isObject, isString, strTrim } from \"@microsoft/applicationinsights-core-js\";\r\nimport { asString, getWindow, objFreeze, strIndexOf } from \"@nevware21/ts-utils\";\r\nimport { strNotSpecified } from \"../Constants\";\r\nimport { _DYN_AI_DATA_CONTRACT, _DYN_ASSEMBLY, _DYN_EXCEPTIONS, _DYN_FILE_NAME, _DYN_HAS_FULL_STACK, _DYN_LENGTH, _DYN_LINE, _DYN_MATCH, _DYN_MEASUREMENTS, _DYN_MESSAGE, _DYN_NAME, _DYN_PARSED_STACK, _DYN_PROBLEM_GROUP, _DYN_PROPERTIES, _DYN_SEVERITY_LEVEL, _DYN_SIZE_IN_BYTES, _DYN_SPLIT, _DYN_STRINGIFY, _DYN_TO_STRING, _DYN_TYPE_NAME } from \"../__DynamicConstants\";\r\nimport { dataSanitizeException, dataSanitizeMeasurements, dataSanitizeMessage, dataSanitizeProperties, dataSanitizeString } from \"./Common/DataSanitizer\";\r\n// These Regex covers the following patterns\r\n// 1. Chrome/Firefox/IE/Edge:\r\n// at functionName (filename:lineNumber:columnNumber)\r\n// at functionName (filename:lineNumber)\r\n// at filename:lineNumber:columnNumber\r\n// at filename:lineNumber\r\n// at functionName@filename:lineNumber:columnNumber\r\n// 2. Safari / Opera:\r\n// functionName@filename:lineNumber:columnNumber\r\n// functionName@filename:lineNumber\r\n// filename:lineNumber:columnNumber\r\n// filename:lineNumber\r\n// Line ## of scriptname script filename:lineNumber:columnNumber\r\n// Line ## of scriptname script filename\r\n// 3. IE/Edge (Additional formats)\r\n// at functionName@filename:lineNumber\r\nvar STACKFRAME_BASE_SIZE = 58; // '{\"method\":\"\",\"level\":,\"assembly\":\"\",\"fileName\":\"\",\"line\":}'.length\r\n/**\r\n * Check if the string conforms to what looks like a stack frame line and not just a general message\r\n * comment or other non-stack related info.\r\n *\r\n * This should be used to filter out any leading \"message\" lines from a stack trace, before attempting to parse\r\n * the individual stack frames. Once you have estabilsted the start of the stack frames you can then use the\r\n * FULL_STACK_FRAME_1, FULL_STACK_FRAME_2, FULL_STACK_FRAME_3, and EXTRACT_FILENAME to parse the individual\r\n * stack frames to extract the method, filename, line number, and column number.\r\n * These may still provide invalid matches, so the sequence of execution is important to avoid providing\r\n * an invalid parsed stack.\r\n */\r\nvar IS_FRAME = /^\\s{0,50}(from\\s|at\\s|Line\\s{1,5}\\d{1,10}\\s{1,5}of|\\w{1,50}@\\w{1,80}|[^\\(\\s\\n]+:[0-9\\?]+(?::[0-9\\?]+)?)/;\r\n/**\r\n * Parse a well formed stack frame with both the line and column numbers\r\n * ----------------------------------\r\n * **Primary focus of the matching**\r\n * - at functionName (filename:lineNumber:columnNumber)\r\n * - at filename:lineNumber:columnNumber\r\n * - at functionName@filename:lineNumber:columnNumber\r\n * - functionName (filename:lineNumber:columnNumber)\r\n * - filename:lineNumber:columnNumber\r\n * - functionName@filename:lineNumber:columnNumber\r\n */\r\nvar FULL_STACK_FRAME_1 = /^(?:\\s{0,50}at)?\\s{0,50}([^\\@\\()\\s]+)?\\s{0,50}(?:\\s|\\@|\\()\\s{0,5}([^\\(\\s\\n\\]]+):([0-9\\?]+):([0-9\\?]+)\\)?$/;\r\n/**\r\n * Parse a well formed stack frame with only a line number.\r\n * ----------------------------------\r\n * > Note: this WILL also match with line and column number, but the line number is included with the filename\r\n * > you should attempt to match with FULL_STACK_FRAME_1 first.\r\n *\r\n * **Primary focus of the matching (run FULL_STACK_FRAME_1 first)**\r\n * - at functionName (filename:lineNumber)\r\n * - at filename:lineNumber\r\n * - at functionName@filename:lineNumber\r\n * - functionName (filename:lineNumber)\r\n * - filename:lineNumber\r\n * - functionName@filename:lineNumber\r\n *\r\n * **Secondary matches**\r\n * - at functionName (filename:lineNumber:columnNumber)\r\n * - at filename:lineNumber:columnNumber\r\n * - at functionName@filename:lineNumber:columnNumber\r\n * - functionName (filename:lineNumber:columnNumber)\r\n * - filename:lineNumber:columnNumber\r\n * - functionName@filename:lineNumber:columnNumber\r\n */\r\nvar FULL_STACK_FRAME_2 = /^(?:\\s{0,50}at)?\\s{0,50}([^\\@\\()\\s]+)?\\s{0,50}(?:\\s|\\@|\\()\\s{0,5}([^\\(\\s\\n\\]]+):([0-9\\?]+)\\)?$/;\r\n/**\r\n * Attempt to Parse a frame that doesn't include a line or column number.\r\n * ----------------------------------\r\n * > Note: this WILL also match lines with a line or line and column number, you should attempt to match with\r\n * both FULL_STACK_FRAME_1 and FULL_STACK_FRAME_2 first to avoid false positives.\r\n *\r\n * **Unexpected Invalid Matches** (Matches that should be avoided -- by using the FULL_STACK_FRAME_1 and FULL_STACK_FRAME_2 first)\r\n * - at https://localhost:44365/static/node_bundles/@microsoft/blah/js/bundle.js:144112:27\r\n * - at https://localhost:44365/static/node_bundles/@microsoft/blah/js/bundle.js:144112:27\r\n *\r\n * **Primary focus of the matching (run FULL_STACK_FRAME_1 first)**\r\n * - at functionName@filename\r\n * - at functionName (filename)\r\n * - at functionName filename\r\n * - at filename <- Will actuall match this as the \"method\" and not the filename (care should be taken to avoid this)\r\n * - functionName@filename\r\n * - functionName (filename)\r\n * - functionName filename\r\n * - functionName\r\n *\r\n * **Secondary matches** (The line and column numbers will be included with the matched filename)\r\n * - at functionName (filename:lineNumber:columnNumber)\r\n * - at functionName (filename:lineNumber)\r\n * - at filename:lineNumber:columnNumber\r\n * - at filename:lineNumber\r\n * - at functionName@filename:lineNumber:columnNumber\r\n * - at functionName@filename:lineNumber\r\n * - functionName (filename:lineNumber:columnNumber)\r\n * - functionName (filename:lineNumber)\r\n * - filename:lineNumber:columnNumber\r\n * - filename:lineNumber\r\n * - functionName@filename:lineNumber:columnNumber\r\n * - functionName@filename:lineNumber\r\n */\r\nvar FULL_STACK_FRAME_3 = /^(?:\\s{0,50}at)?\\s{0,50}([^\\@\\()\\s]+)?\\s{0,50}(?:\\s|\\@|\\()\\s{0,5}([^\\(\\s\\n\\)\\]]+)\\)?$/;\r\n/**\r\n * Attempt to extract the filename (with or without line and column numbers) from a string.\r\n * ----------------------------------\r\n * > Note: this will only match the filename (with any line or column numbers) and will\r\n * > return what looks like the filename, however, it will also match random strings that\r\n * > look like a filename, so care should be taken to ensure that the filename is actually\r\n * > a filename before using it.\r\n * >\r\n * > It is recommended to use this in conjunction with the FULL_STACK_FRAME_1, FULL_STACK_FRAME_2, and FULL_STACK_FRAME_3\r\n * > to ensure first to reduce false matches, if all of these fail then you can use this to extract the filename from a random\r\n * > strings to identify any potential filename from a known stack frame line.\r\n *\r\n * **Known Invalid matching**\r\n *\r\n * This regex will basically match any \"final\" string of a line or one that is trailed by a comma, so this should not\r\n * be used as the \"only\" matching regex, but rather as a final fallback to extract the filename from a string.\r\n * If you are certain that the string line is a stack frame and not part of the exception message (lines before the stack)\r\n * or trailing comments, then you can use this to extract the filename and then further parse with PARSE_FILENAME_LINE_COL\r\n * and PARSE_FILENAME_LINE_ONLY to extract any potential the line and column numbers.\r\n *\r\n * **Primary focus of the matching**\r\n * - at (anonymous) @ VM60:1\r\n * - Line 21 of linked script file://localhost/C:/Temp/stacktrace.js\r\n * - Line 11 of inline#1 script in http://localhost:3000/static/js/main.206f4846.js:2:296748\r\n * - Line 68 of inline#2 script in file://localhost/teststack.html\r\n * - at Global code (http://example.com/stacktrace.js:11:1)\r\n */\r\nvar EXTRACT_FILENAME = /(?:^|\\(|\\s{0,10}[\\w\\)]+\\@)?([^\\(\\n\\s\\]\\)]+)(?:\\:([0-9]+)(?:\\:([0-9]+))?)?\\)?(?:,|$)/;\r\n/**\r\n * Attempt to extract the filename, line number, and column number from a string.\r\n */\r\nvar PARSE_FILENAME_LINE_COL = /([^\\(\\s\\n]+):([0-9]+):([0-9]+)$/;\r\n/**\r\n * Attempt to extract the filename and line number from a string.\r\n */\r\nvar PARSE_FILENAME_LINE_ONLY = /([^\\(\\s\\n]+):([0-9]+)$/;\r\nvar NoMethod = \"\";\r\nvar strError = \"error\";\r\nvar strStack = \"stack\";\r\nvar strStackDetails = \"stackDetails\";\r\nvar strErrorSrc = \"errorSrc\";\r\nvar strMessage = \"message\";\r\nvar strDescription = \"description\";\r\nvar _parseSequence = [\r\n { re: FULL_STACK_FRAME_1, len: 5, m: 1, fn: 2, ln: 3, col: 4 },\r\n { chk: _ignoreNative, pre: _scrubAnonymous, re: FULL_STACK_FRAME_2, len: 4, m: 1, fn: 2, ln: 3 },\r\n { re: FULL_STACK_FRAME_3, len: 3, m: 1, fn: 2, hdl: _handleFilename },\r\n { re: EXTRACT_FILENAME, len: 2, fn: 1, hdl: _handleFilename }\r\n];\r\nfunction _scrubAnonymous(frame) {\r\n return frame.replace(/(\\(anonymous\\))/, \"\");\r\n}\r\nfunction _ignoreNative(frame) {\r\n return strIndexOf(frame, \"[native\") < 0;\r\n}\r\nfunction _stringify(value, convertToString) {\r\n var result = value;\r\n if (result && !isString(result)) {\r\n if (JSON && JSON[_DYN_STRINGIFY /* @min:%2estringify */]) {\r\n result = JSON[_DYN_STRINGIFY /* @min:%2estringify */](value);\r\n if (convertToString && (!result || result === \"{}\")) {\r\n if (isFunction(value[_DYN_TO_STRING /* @min:%2etoString */])) {\r\n result = value[_DYN_TO_STRING /* @min:%2etoString */]();\r\n }\r\n else {\r\n result = \"\" + value;\r\n }\r\n }\r\n }\r\n else {\r\n result = \"\" + value + \" - (Missing JSON.stringify)\";\r\n }\r\n }\r\n return result || \"\";\r\n}\r\nfunction _formatMessage(theEvent, errorType) {\r\n var evtMessage = theEvent;\r\n if (theEvent) {\r\n if (evtMessage && !isString(evtMessage)) {\r\n evtMessage = theEvent[strMessage] || theEvent[strDescription] || evtMessage;\r\n }\r\n // Make sure the message is a string\r\n if (evtMessage && !isString(evtMessage)) {\r\n // tslint:disable-next-line: prefer-conditional-expression\r\n evtMessage = _stringify(evtMessage, true);\r\n }\r\n if (theEvent[\"filename\"]) {\r\n // Looks like an event object with filename\r\n evtMessage = evtMessage + \" @\" + (theEvent[\"filename\"] || \"\") + \":\" + (theEvent[\"lineno\"] || \"?\") + \":\" + (theEvent[\"colno\"] || \"?\");\r\n }\r\n }\r\n // Automatically add the error type to the message if it does already appear to be present\r\n if (errorType && errorType !== \"String\" && errorType !== \"Object\" && errorType !== \"Error\" && strIndexOf(evtMessage || \"\", errorType) === -1) {\r\n evtMessage = errorType + \": \" + evtMessage;\r\n }\r\n return evtMessage || \"\";\r\n}\r\nfunction _isExceptionDetailsInternal(value) {\r\n try {\r\n if (isObject(value)) {\r\n return \"hasFullStack\" in value && \"typeName\" in value;\r\n }\r\n }\r\n catch (e) {\r\n // This can happen with some native browser objects, but should not happen for the type we are checking for\r\n }\r\n return false;\r\n}\r\nfunction _isExceptionInternal(value) {\r\n try {\r\n if (isObject(value)) {\r\n return (\"ver\" in value && \"exceptions\" in value && \"properties\" in value);\r\n }\r\n }\r\n catch (e) {\r\n // This can happen with some native browser objects, but should not happen for the type we are checking for\r\n }\r\n return false;\r\n}\r\nfunction _isStackDetails(details) {\r\n return details && details.src && isString(details.src) && details.obj && isArray(details.obj);\r\n}\r\nfunction _convertStackObj(errorStack) {\r\n var src = errorStack || \"\";\r\n if (!isString(src)) {\r\n if (isString(src[strStack])) {\r\n src = src[strStack];\r\n }\r\n else {\r\n src = \"\" + src;\r\n }\r\n }\r\n var items = src[_DYN_SPLIT /* @min:%2esplit */](\"\\n\");\r\n return {\r\n src: src,\r\n obj: items\r\n };\r\n}\r\nfunction _getOperaStack(errorMessage) {\r\n var stack = [];\r\n var lines = errorMessage[_DYN_SPLIT /* @min:%2esplit */](\"\\n\");\r\n for (var lp = 0; lp < lines[_DYN_LENGTH /* @min:%2elength */]; lp++) {\r\n var entry = lines[lp];\r\n if (lines[lp + 1]) {\r\n entry += \"@\" + lines[lp + 1];\r\n lp++;\r\n }\r\n stack.push(entry);\r\n }\r\n return {\r\n src: errorMessage,\r\n obj: stack\r\n };\r\n}\r\nfunction _getStackFromErrorObj(errorObj) {\r\n var details = null;\r\n if (errorObj) {\r\n try {\r\n /* Using bracket notation is support older browsers (IE 7/8 -- dont remember the version) that throw when using dot\r\n notation for undefined objects and we don't want to loose the error from being reported */\r\n if (errorObj[strStack]) {\r\n // Chrome/Firefox\r\n details = _convertStackObj(errorObj[strStack]);\r\n }\r\n else if (errorObj[strError] && errorObj[strError][strStack]) {\r\n // Edge error event provides the stack and error object\r\n details = _convertStackObj(errorObj[strError][strStack]);\r\n }\r\n else if (errorObj[\"exception\"] && errorObj.exception[strStack]) {\r\n details = _convertStackObj(errorObj.exception[strStack]);\r\n }\r\n else if (_isStackDetails(errorObj)) {\r\n details = errorObj;\r\n }\r\n else if (_isStackDetails(errorObj[strStackDetails])) {\r\n details = errorObj[strStackDetails];\r\n }\r\n else if (getWindow() && getWindow()[\"opera\"] && errorObj[strMessage]) {\r\n // Opera\r\n details = _getOperaStack(errorObj[_DYN_MESSAGE /* @min:%2emessage */]);\r\n }\r\n else if (errorObj[\"reason\"] && errorObj.reason[strStack]) {\r\n // UnhandledPromiseRejection\r\n details = _convertStackObj(errorObj.reason[strStack]);\r\n }\r\n else if (isString(errorObj)) {\r\n details = _convertStackObj(errorObj);\r\n }\r\n else {\r\n var evtMessage = errorObj[strMessage] || errorObj[strDescription] || \"\";\r\n if (isString(errorObj[strErrorSrc])) {\r\n if (evtMessage) {\r\n evtMessage += \"\\n\";\r\n }\r\n evtMessage += \" from \" + errorObj[strErrorSrc];\r\n }\r\n if (evtMessage) {\r\n details = _convertStackObj(evtMessage);\r\n }\r\n }\r\n }\r\n catch (e) {\r\n // something unexpected happened so to avoid failing to report any error lets swallow the exception\r\n // and fallback to the callee/caller method\r\n details = _convertStackObj(e);\r\n }\r\n }\r\n return details || {\r\n src: \"\",\r\n obj: null\r\n };\r\n}\r\nfunction _formatStackTrace(stackDetails) {\r\n var stack = \"\";\r\n if (stackDetails) {\r\n if (stackDetails.obj) {\r\n stack = stackDetails.obj.join(\"\\n\");\r\n }\r\n else {\r\n stack = stackDetails.src || \"\";\r\n }\r\n }\r\n return stack;\r\n}\r\nfunction _parseStack(stack) {\r\n var parsedStack;\r\n var frames = stack.obj;\r\n if (frames && frames[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n parsedStack = [];\r\n var level_1 = 0;\r\n var foundStackStart_1 = false;\r\n var totalSizeInBytes_1 = 0;\r\n arrForEach(frames, function (frame) {\r\n if (foundStackStart_1 || _isStackFrame(frame)) {\r\n var theFrame = asString(frame);\r\n // Once we have found the first stack frame we treat the rest of the lines as part of the stack\r\n foundStackStart_1 = true;\r\n var parsedFrame = _extractStackFrame(theFrame, level_1);\r\n if (parsedFrame) {\r\n totalSizeInBytes_1 += parsedFrame[_DYN_SIZE_IN_BYTES /* @min:%2esizeInBytes */];\r\n parsedStack.push(parsedFrame);\r\n level_1++;\r\n }\r\n }\r\n });\r\n // DP Constraint - exception parsed stack must be < 32KB\r\n // remove frames from the middle to meet the threshold\r\n var exceptionParsedStackThreshold = 32 * 1024;\r\n if (totalSizeInBytes_1 > exceptionParsedStackThreshold) {\r\n var left = 0;\r\n var right = parsedStack[_DYN_LENGTH /* @min:%2elength */] - 1;\r\n var size = 0;\r\n var acceptedLeft = left;\r\n var acceptedRight = right;\r\n while (left < right) {\r\n // check size\r\n var lSize = parsedStack[left][_DYN_SIZE_IN_BYTES /* @min:%2esizeInBytes */];\r\n var rSize = parsedStack[right][_DYN_SIZE_IN_BYTES /* @min:%2esizeInBytes */];\r\n size += lSize + rSize;\r\n if (size > exceptionParsedStackThreshold) {\r\n // remove extra frames from the middle\r\n var howMany = acceptedRight - acceptedLeft + 1;\r\n parsedStack.splice(acceptedLeft, howMany);\r\n break;\r\n }\r\n // update pointers\r\n acceptedLeft = left;\r\n acceptedRight = right;\r\n left++;\r\n right--;\r\n }\r\n }\r\n }\r\n return parsedStack;\r\n}\r\nfunction _getErrorType(errorType) {\r\n // Gets the Error Type by passing the constructor (used to get the true type of native error object).\r\n var typeName = \"\";\r\n if (errorType) {\r\n typeName = errorType.typeName || errorType[_DYN_NAME /* @min:%2ename */] || \"\";\r\n if (!typeName) {\r\n try {\r\n var funcNameRegex = /function (.{1,200})\\(/;\r\n var results = (funcNameRegex).exec((errorType).constructor[_DYN_TO_STRING /* @min:%2etoString */]());\r\n typeName = (results && results[_DYN_LENGTH /* @min:%2elength */] > 1) ? results[1] : \"\";\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty -- Ignoring any failures as nothing we can do\r\n }\r\n }\r\n }\r\n return typeName;\r\n}\r\n/**\r\n * Formats the provided errorObj for display and reporting, it may be a String, Object, integer or undefined depending on the browser.\r\n * @param errorObj - The supplied errorObj\r\n */\r\nexport function _formatErrorCode(errorObj) {\r\n if (errorObj) {\r\n try {\r\n if (!isString(errorObj)) {\r\n var errorType = _getErrorType(errorObj);\r\n var result = _stringify(errorObj, false);\r\n if (!result || result === \"{}\") {\r\n if (errorObj[strError]) {\r\n // Looks like an MS Error Event\r\n errorObj = errorObj[strError];\r\n errorType = _getErrorType(errorObj);\r\n }\r\n result = _stringify(errorObj, true);\r\n }\r\n if (strIndexOf(result, errorType) !== 0 && errorType !== \"String\") {\r\n return errorType + \":\" + result;\r\n }\r\n return result;\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty -- Ignoring any failures as nothing we can do\r\n }\r\n }\r\n // Fallback to just letting the object format itself into a string\r\n return \"\" + (errorObj || \"\");\r\n}\r\nvar Exception = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the ExceptionTelemetry object\r\n */\r\n function Exception(logger, exception, properties, measurements, severityLevel, id) {\r\n this.aiDataContract = {\r\n ver: 1 /* FieldType.Required */,\r\n exceptions: 1 /* FieldType.Required */,\r\n severityLevel: 0 /* FieldType.Default */,\r\n properties: 0 /* FieldType.Default */,\r\n measurements: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2; // TODO: handle the CS\"4.0\" ==> breeze 2 conversion in a better way\r\n if (!_isExceptionInternal(exception)) {\r\n if (!properties) {\r\n properties = {};\r\n }\r\n if (id) {\r\n properties.id = id;\r\n }\r\n _self[_DYN_EXCEPTIONS /* @min:%2eexceptions */] = [_createExceptionDetails(logger, exception, properties)];\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n if (severityLevel) {\r\n _self[_DYN_SEVERITY_LEVEL /* @min:%2eseverityLevel */] = severityLevel;\r\n }\r\n if (id) {\r\n _self.id = id;\r\n }\r\n }\r\n else {\r\n _self[_DYN_EXCEPTIONS /* @min:%2eexceptions */] = exception[_DYN_EXCEPTIONS /* @min:%2eexceptions */] || [];\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = exception[_DYN_PROPERTIES /* @min:%2eproperties */];\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = exception[_DYN_MEASUREMENTS /* @min:%2emeasurements */];\r\n if (exception[_DYN_SEVERITY_LEVEL /* @min:%2eseverityLevel */]) {\r\n _self[_DYN_SEVERITY_LEVEL /* @min:%2eseverityLevel */] = exception[_DYN_SEVERITY_LEVEL /* @min:%2eseverityLevel */];\r\n }\r\n if (exception.id) {\r\n _self.id = exception.id;\r\n exception[_DYN_PROPERTIES /* @min:%2eproperties */].id = exception.id;\r\n }\r\n if (exception[_DYN_PROBLEM_GROUP /* @min:%2eproblemGroup */]) {\r\n _self[_DYN_PROBLEM_GROUP /* @min:%2eproblemGroup */] = exception[_DYN_PROBLEM_GROUP /* @min:%2eproblemGroup */];\r\n }\r\n // bool/int types, use isNullOrUndefined\r\n if (!isNullOrUndefined(exception.isManual)) {\r\n _self.isManual = exception.isManual;\r\n }\r\n }\r\n }\r\n Exception.CreateAutoException = function (message, url, lineNumber, columnNumber, error, evt, stack, errorSrc) {\r\n var errorType = _getErrorType(error || evt || message);\r\n return {\r\n message: _formatMessage(message, errorType),\r\n url: url,\r\n lineNumber: lineNumber,\r\n columnNumber: columnNumber,\r\n error: _formatErrorCode(error || evt || message),\r\n evt: _formatErrorCode(evt || message),\r\n typeName: errorType,\r\n stackDetails: _getStackFromErrorObj(stack || error || evt),\r\n errorSrc: errorSrc\r\n };\r\n };\r\n Exception.CreateFromInterface = function (logger, exception, properties, measurements) {\r\n var exceptions = exception[_DYN_EXCEPTIONS /* @min:%2eexceptions */]\r\n && arrMap(exception[_DYN_EXCEPTIONS /* @min:%2eexceptions */], function (ex) { return _createExDetailsFromInterface(logger, ex); });\r\n var exceptionData = new Exception(logger, __assign(__assign({}, exception), { exceptions: exceptions }), properties, measurements);\r\n return exceptionData;\r\n };\r\n Exception.prototype.toInterface = function () {\r\n var _a = this, exceptions = _a.exceptions, properties = _a.properties, measurements = _a.measurements, severityLevel = _a.severityLevel, problemGroup = _a.problemGroup, id = _a.id, isManual = _a.isManual;\r\n var exceptionDetailsInterface = exceptions instanceof Array\r\n && arrMap(exceptions, function (exception) { return exception.toInterface(); })\r\n || undefined;\r\n return {\r\n ver: \"4.0\",\r\n exceptions: exceptionDetailsInterface,\r\n severityLevel: severityLevel,\r\n properties: properties,\r\n measurements: measurements,\r\n problemGroup: problemGroup,\r\n id: id,\r\n isManual: isManual\r\n };\r\n };\r\n /**\r\n * Creates a simple exception with 1 stack frame. Useful for manual constracting of exception.\r\n */\r\n Exception.CreateSimpleException = function (message, typeName, assembly, fileName, details, line) {\r\n var _a;\r\n return {\r\n exceptions: [\r\n (_a = {},\r\n _a[_DYN_HAS_FULL_STACK /* @min:hasFullStack */] = true,\r\n _a.message = message,\r\n _a.stack = details,\r\n _a.typeName = typeName,\r\n _a)\r\n ]\r\n };\r\n };\r\n Exception.envelopeType = \"Microsoft.ApplicationInsights.{0}.Exception\";\r\n Exception.dataType = \"ExceptionData\";\r\n Exception.formatError = _formatErrorCode;\r\n return Exception;\r\n}());\r\nexport { Exception };\r\nvar exDetailsAiDataContract = objFreeze({\r\n id: 0 /* FieldType.Default */,\r\n outerId: 0 /* FieldType.Default */,\r\n typeName: 1 /* FieldType.Required */,\r\n message: 1 /* FieldType.Required */,\r\n hasFullStack: 0 /* FieldType.Default */,\r\n stack: 0 /* FieldType.Default */,\r\n parsedStack: 2 /* FieldType.Array */\r\n});\r\nfunction _toInterface() {\r\n var _self = this;\r\n var parsedStack = isArray(_self[_DYN_PARSED_STACK /* @min:%2eparsedStack */])\r\n && arrMap(_self[_DYN_PARSED_STACK /* @min:%2eparsedStack */], function (frame) { return _parsedFrameToInterface(frame); });\r\n var exceptionDetailsInterface = {\r\n id: _self.id,\r\n outerId: _self.outerId,\r\n typeName: _self[_DYN_TYPE_NAME /* @min:%2etypeName */],\r\n message: _self[_DYN_MESSAGE /* @min:%2emessage */],\r\n hasFullStack: _self[_DYN_HAS_FULL_STACK /* @min:%2ehasFullStack */],\r\n stack: _self[strStack],\r\n parsedStack: parsedStack || undefined\r\n };\r\n return exceptionDetailsInterface;\r\n}\r\nexport function _createExceptionDetails(logger, exception, properties) {\r\n var _a;\r\n var id;\r\n var outerId;\r\n var typeName;\r\n var message;\r\n var hasFullStack;\r\n var theStack;\r\n var parsedStack;\r\n if (!_isExceptionDetailsInternal(exception)) {\r\n var error = exception;\r\n var evt = error && error.evt;\r\n if (!isError(error)) {\r\n error = error[strError] || evt || error;\r\n }\r\n typeName = dataSanitizeString(logger, _getErrorType(error)) || strNotSpecified;\r\n message = dataSanitizeMessage(logger, _formatMessage(exception || error, typeName)) || strNotSpecified;\r\n var stack = exception[strStackDetails] || _getStackFromErrorObj(exception);\r\n parsedStack = _parseStack(stack);\r\n // after parsedStack is inited, iterate over each frame object, sanitize its assembly field\r\n if (isArray(parsedStack)) {\r\n arrMap(parsedStack, function (frame) {\r\n frame[_DYN_ASSEMBLY /* @min:%2eassembly */] = dataSanitizeString(logger, frame[_DYN_ASSEMBLY /* @min:%2eassembly */]);\r\n frame[_DYN_FILE_NAME /* @min:%2efileName */] = dataSanitizeString(logger, frame[_DYN_FILE_NAME /* @min:%2efileName */]);\r\n });\r\n }\r\n theStack = dataSanitizeException(logger, _formatStackTrace(stack));\r\n hasFullStack = isArray(parsedStack) && parsedStack[_DYN_LENGTH /* @min:%2elength */] > 0;\r\n if (properties) {\r\n properties[_DYN_TYPE_NAME /* @min:%2etypeName */] = properties[_DYN_TYPE_NAME /* @min:%2etypeName */] || typeName;\r\n }\r\n }\r\n else {\r\n typeName = exception[_DYN_TYPE_NAME /* @min:%2etypeName */];\r\n message = exception[_DYN_MESSAGE /* @min:%2emessage */];\r\n theStack = exception[strStack];\r\n parsedStack = exception[_DYN_PARSED_STACK /* @min:%2eparsedStack */] || [];\r\n hasFullStack = exception[_DYN_HAS_FULL_STACK /* @min:%2ehasFullStack */];\r\n }\r\n return _a = {},\r\n _a[_DYN_AI_DATA_CONTRACT /* @min:aiDataContract */] = exDetailsAiDataContract,\r\n _a.id = id,\r\n _a.outerId = outerId,\r\n _a.typeName = typeName,\r\n _a.message = message,\r\n _a[_DYN_HAS_FULL_STACK /* @min:hasFullStack */] = hasFullStack,\r\n _a.stack = theStack,\r\n _a.parsedStack = parsedStack,\r\n _a.toInterface = _toInterface,\r\n _a;\r\n}\r\nexport function _createExDetailsFromInterface(logger, exception) {\r\n var parsedStack = (isArray(exception[_DYN_PARSED_STACK /* @min:%2eparsedStack */])\r\n && arrMap(exception[_DYN_PARSED_STACK /* @min:%2eparsedStack */], function (frame) { return _stackFrameFromInterface(frame); }))\r\n || exception[_DYN_PARSED_STACK /* @min:%2eparsedStack */];\r\n var exceptionDetails = _createExceptionDetails(logger, __assign(__assign({}, exception), { parsedStack: parsedStack }));\r\n return exceptionDetails;\r\n}\r\nfunction _parseFilename(theFrame, fileName) {\r\n var lineCol = fileName[_DYN_MATCH /* @min:%2ematch */](PARSE_FILENAME_LINE_COL);\r\n if (lineCol && lineCol[_DYN_LENGTH /* @min:%2elength */] >= 4) {\r\n theFrame[_DYN_FILE_NAME /* @min:%2efileName */] = lineCol[1];\r\n theFrame[_DYN_LINE /* @min:%2eline */] = parseInt(lineCol[2]);\r\n }\r\n else {\r\n var lineNo = fileName[_DYN_MATCH /* @min:%2ematch */](PARSE_FILENAME_LINE_ONLY);\r\n if (lineNo && lineNo[_DYN_LENGTH /* @min:%2elength */] >= 3) {\r\n theFrame[_DYN_FILE_NAME /* @min:%2efileName */] = lineNo[1];\r\n theFrame[_DYN_LINE /* @min:%2eline */] = parseInt(lineNo[2]);\r\n }\r\n else {\r\n theFrame[_DYN_FILE_NAME /* @min:%2efileName */] = fileName;\r\n }\r\n }\r\n}\r\nfunction _handleFilename(theFrame, sequence, matches) {\r\n var filename = theFrame[_DYN_FILE_NAME /* @min:%2efileName */];\r\n if (sequence.fn && matches && matches[_DYN_LENGTH /* @min:%2elength */] > sequence.fn) {\r\n if (sequence.ln && matches[_DYN_LENGTH /* @min:%2elength */] > sequence.ln) {\r\n filename = strTrim(matches[sequence.fn] || \"\");\r\n theFrame[_DYN_LINE /* @min:%2eline */] = parseInt(strTrim(matches[sequence.ln] || \"\")) || 0;\r\n }\r\n else {\r\n filename = strTrim(matches[sequence.fn] || \"\");\r\n }\r\n }\r\n if (filename) {\r\n _parseFilename(theFrame, filename);\r\n }\r\n}\r\nfunction _isStackFrame(frame) {\r\n var result = false;\r\n if (frame && isString(frame)) {\r\n var trimmedFrame = strTrim(frame);\r\n if (trimmedFrame) {\r\n result = IS_FRAME.test(trimmedFrame);\r\n }\r\n }\r\n return result;\r\n}\r\nvar stackFrameAiDataContract = objFreeze({\r\n level: 1 /* FieldType.Required */,\r\n method: 1 /* FieldType.Required */,\r\n assembly: 0 /* FieldType.Default */,\r\n fileName: 0 /* FieldType.Default */,\r\n line: 0 /* FieldType.Default */\r\n});\r\nexport function _extractStackFrame(frame, level) {\r\n var _a;\r\n var theFrame;\r\n if (frame && isString(frame) && strTrim(frame)) {\r\n theFrame = (_a = {},\r\n _a[_DYN_AI_DATA_CONTRACT /* @min:aiDataContract */] = stackFrameAiDataContract,\r\n _a.level = level,\r\n _a.assembly = strTrim(frame),\r\n _a.method = NoMethod,\r\n _a.fileName = \"\",\r\n _a.line = 0,\r\n _a.sizeInBytes = 0,\r\n _a);\r\n var idx = 0;\r\n while (idx < _parseSequence[_DYN_LENGTH /* @min:%2elength */]) {\r\n var sequence = _parseSequence[idx];\r\n if (sequence.chk && !sequence.chk(frame)) {\r\n break;\r\n }\r\n if (sequence.pre) {\r\n frame = sequence.pre(frame);\r\n }\r\n // Attempt to \"parse\" the stack frame\r\n var matches = frame[_DYN_MATCH /* @min:%2ematch */](sequence.re);\r\n if (matches && matches[_DYN_LENGTH /* @min:%2elength */] >= sequence.len) {\r\n if (sequence.m) {\r\n theFrame.method = strTrim(matches[sequence.m] || NoMethod);\r\n }\r\n if (sequence.hdl) {\r\n // Run any custom handler\r\n sequence.hdl(theFrame, sequence, matches);\r\n }\r\n else if (sequence.fn) {\r\n if (sequence.ln) {\r\n theFrame[_DYN_FILE_NAME /* @min:%2efileName */] = strTrim(matches[sequence.fn] || \"\");\r\n theFrame[_DYN_LINE /* @min:%2eline */] = parseInt(strTrim(matches[sequence.ln] || \"\")) || 0;\r\n }\r\n else {\r\n _parseFilename(theFrame, matches[sequence.fn] || \"\");\r\n }\r\n }\r\n // We found a match so stop looking\r\n break;\r\n }\r\n idx++;\r\n }\r\n }\r\n return _populateFrameSizeInBytes(theFrame);\r\n}\r\nfunction _stackFrameFromInterface(frame) {\r\n var _a;\r\n var parsedFrame = (_a = {},\r\n _a[_DYN_AI_DATA_CONTRACT /* @min:aiDataContract */] = stackFrameAiDataContract,\r\n _a.level = frame.level,\r\n _a.method = frame.method,\r\n _a.assembly = frame[_DYN_ASSEMBLY /* @min:%2eassembly */],\r\n _a.fileName = frame[_DYN_FILE_NAME /* @min:%2efileName */],\r\n _a.line = frame[_DYN_LINE /* @min:%2eline */],\r\n _a.sizeInBytes = 0,\r\n _a);\r\n return _populateFrameSizeInBytes(parsedFrame);\r\n}\r\nfunction _populateFrameSizeInBytes(frame) {\r\n var sizeInBytes = STACKFRAME_BASE_SIZE;\r\n if (frame) {\r\n sizeInBytes += frame.method[_DYN_LENGTH /* @min:%2elength */];\r\n sizeInBytes += frame.assembly[_DYN_LENGTH /* @min:%2elength */];\r\n sizeInBytes += frame.fileName[_DYN_LENGTH /* @min:%2elength */];\r\n sizeInBytes += frame.level.toString()[_DYN_LENGTH /* @min:%2elength */];\r\n sizeInBytes += frame.line.toString()[_DYN_LENGTH /* @min:%2elength */];\r\n frame[_DYN_SIZE_IN_BYTES /* @min:%2esizeInBytes */] = sizeInBytes;\r\n }\r\n return frame;\r\n}\r\nexport function _parsedFrameToInterface(frame) {\r\n return {\r\n level: frame.level,\r\n method: frame.method,\r\n assembly: frame[_DYN_ASSEMBLY /* @min:%2eassembly */],\r\n fileName: frame[_DYN_FILE_NAME /* @min:%2efileName */],\r\n line: frame[_DYN_LINE /* @min:%2eline */]\r\n };\r\n}\r\n//# sourceMappingURL=Exception.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nvar DataPoint = /** @class */ (function () {\r\n function DataPoint() {\r\n /**\r\n * The data contract for serializing this object.\r\n */\r\n this.aiDataContract = {\r\n name: 1 /* FieldType.Required */,\r\n kind: 0 /* FieldType.Default */,\r\n value: 1 /* FieldType.Required */,\r\n count: 0 /* FieldType.Default */,\r\n min: 0 /* FieldType.Default */,\r\n max: 0 /* FieldType.Default */,\r\n stdDev: 0 /* FieldType.Default */\r\n };\r\n /**\r\n * Metric type. Single measurement or the aggregated value.\r\n */\r\n this.kind = 0 /* DataPointType.Measurement */;\r\n }\r\n return DataPoint;\r\n}());\r\nexport { DataPoint };\r\n//# sourceMappingURL=DataPoint.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { strNotSpecified } from \"../Constants\";\r\nimport { _DYN_COUNT, _DYN_MEASUREMENTS, _DYN_NAME, _DYN_PROPERTIES } from \"../__DynamicConstants\";\r\nimport { DataPoint } from \"./Common/DataPoint\";\r\nimport { dataSanitizeMeasurements, dataSanitizeProperties, dataSanitizeString } from \"./Common/DataSanitizer\";\r\nvar Metric = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the MetricTelemetry object\r\n */\r\n function Metric(logger, name, value, count, min, max, stdDev, properties, measurements) {\r\n this.aiDataContract = {\r\n ver: 1 /* FieldType.Required */,\r\n metrics: 1 /* FieldType.Required */,\r\n properties: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2;\r\n var dataPoint = new DataPoint();\r\n dataPoint[_DYN_COUNT /* @min:%2ecount */] = count > 0 ? count : undefined;\r\n dataPoint.max = isNaN(max) || max === null ? undefined : max;\r\n dataPoint.min = isNaN(min) || min === null ? undefined : min;\r\n dataPoint[_DYN_NAME /* @min:%2ename */] = dataSanitizeString(logger, name) || strNotSpecified;\r\n dataPoint.value = value;\r\n dataPoint.stdDev = isNaN(stdDev) || stdDev === null ? undefined : stdDev;\r\n _self.metrics = [dataPoint];\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n }\r\n Metric.envelopeType = \"Microsoft.ApplicationInsights.{0}.Metric\";\r\n Metric.dataType = \"MetricData\";\r\n return Metric;\r\n}());\r\nexport { Metric };\r\n//# sourceMappingURL=Metric.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { arrForEach, isString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { mathFloor, mathRound } from \"@nevware21/ts-utils\";\r\nimport { _DYN_LENGTH, _DYN_TO_LOWER_CASE } from \"./__DynamicConstants\";\r\nvar strEmpty = \"\";\r\nexport function stringToBoolOrDefault(str, defaultValue) {\r\n if (defaultValue === void 0) { defaultValue = false; }\r\n if (str === undefined || str === null) {\r\n return defaultValue;\r\n }\r\n return str.toString()[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]() === \"true\";\r\n}\r\n/**\r\n * Convert ms to c# time span format\r\n */\r\nexport function msToTimeSpan(totalms) {\r\n if (isNaN(totalms) || totalms < 0) {\r\n totalms = 0;\r\n }\r\n totalms = mathRound(totalms);\r\n var ms = strEmpty + totalms % 1000;\r\n var sec = strEmpty + mathFloor(totalms / 1000) % 60;\r\n var min = strEmpty + mathFloor(totalms / (1000 * 60)) % 60;\r\n var hour = strEmpty + mathFloor(totalms / (1000 * 60 * 60)) % 24;\r\n var days = mathFloor(totalms / (1000 * 60 * 60 * 24));\r\n ms = ms[_DYN_LENGTH /* @min:%2elength */] === 1 ? \"00\" + ms : ms[_DYN_LENGTH /* @min:%2elength */] === 2 ? \"0\" + ms : ms;\r\n sec = sec[_DYN_LENGTH /* @min:%2elength */] < 2 ? \"0\" + sec : sec;\r\n min = min[_DYN_LENGTH /* @min:%2elength */] < 2 ? \"0\" + min : min;\r\n hour = hour[_DYN_LENGTH /* @min:%2elength */] < 2 ? \"0\" + hour : hour;\r\n return (days > 0 ? days + \".\" : strEmpty) + hour + \":\" + min + \":\" + sec + \".\" + ms;\r\n}\r\nexport function getExtensionByName(extensions, identifier) {\r\n var extension = null;\r\n arrForEach(extensions, function (value) {\r\n if (value.identifier === identifier) {\r\n extension = value;\r\n return -1;\r\n }\r\n });\r\n return extension;\r\n}\r\nexport function isCrossOriginError(message, url, lineNumber, columnNumber, error) {\r\n return !error && isString(message) && (message === \"Script error.\" || message === \"Script error\");\r\n}\r\n//# sourceMappingURL=HelperFuncs.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { strNotSpecified } from \"../Constants\";\r\nimport { msToTimeSpan } from \"../HelperFuncs\";\r\nimport { _DYN_DURATION, _DYN_MEASUREMENTS, _DYN_NAME, _DYN_PROPERTIES } from \"../__DynamicConstants\";\r\nimport { dataSanitizeId, dataSanitizeMeasurements, dataSanitizeProperties, dataSanitizeString, dataSanitizeUrl } from \"./Common/DataSanitizer\";\r\nvar PageView = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the PageEventTelemetry object\r\n */\r\n function PageView(logger, name, url, durationMs, properties, measurements, id) {\r\n this.aiDataContract = {\r\n ver: 1 /* FieldType.Required */,\r\n name: 0 /* FieldType.Default */,\r\n url: 0 /* FieldType.Default */,\r\n duration: 0 /* FieldType.Default */,\r\n properties: 0 /* FieldType.Default */,\r\n measurements: 0 /* FieldType.Default */,\r\n id: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2;\r\n _self.id = dataSanitizeId(logger, id);\r\n _self.url = dataSanitizeUrl(logger, url);\r\n _self[_DYN_NAME /* @min:%2ename */] = dataSanitizeString(logger, name) || strNotSpecified;\r\n if (!isNaN(durationMs)) {\r\n _self[_DYN_DURATION /* @min:%2eduration */] = msToTimeSpan(durationMs);\r\n }\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n }\r\n PageView.envelopeType = \"Microsoft.ApplicationInsights.{0}.Pageview\";\r\n PageView.dataType = \"PageviewData\";\r\n return PageView;\r\n}());\r\nexport { PageView };\r\n//# sourceMappingURL=PageView.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { msToTimeSpan } from \"../HelperFuncs\";\r\nimport { AjaxHelperParseDependencyPath } from \"../Util\";\r\nimport { _DYN_DURATION, _DYN_MEASUREMENTS, _DYN_NAME, _DYN_PROPERTIES } from \"../__DynamicConstants\";\r\nimport { dataSanitizeMeasurements, dataSanitizeProperties, dataSanitizeString, dataSanitizeUrl } from \"./Common/DataSanitizer\";\r\nvar RemoteDependencyData = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the RemoteDependencyData object\r\n */\r\n function RemoteDependencyData(logger, id, absoluteUrl, commandName, value, success, resultCode, method, requestAPI, correlationContext, properties, measurements) {\r\n if (requestAPI === void 0) { requestAPI = \"Ajax\"; }\r\n this.aiDataContract = {\r\n id: 1 /* FieldType.Required */,\r\n ver: 1 /* FieldType.Required */,\r\n name: 0 /* FieldType.Default */,\r\n resultCode: 0 /* FieldType.Default */,\r\n duration: 0 /* FieldType.Default */,\r\n success: 0 /* FieldType.Default */,\r\n data: 0 /* FieldType.Default */,\r\n target: 0 /* FieldType.Default */,\r\n type: 0 /* FieldType.Default */,\r\n properties: 0 /* FieldType.Default */,\r\n measurements: 0 /* FieldType.Default */,\r\n kind: 0 /* FieldType.Default */,\r\n value: 0 /* FieldType.Default */,\r\n count: 0 /* FieldType.Default */,\r\n min: 0 /* FieldType.Default */,\r\n max: 0 /* FieldType.Default */,\r\n stdDev: 0 /* FieldType.Default */,\r\n dependencyKind: 0 /* FieldType.Default */,\r\n dependencySource: 0 /* FieldType.Default */,\r\n commandName: 0 /* FieldType.Default */,\r\n dependencyTypeName: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2;\r\n _self.id = id;\r\n _self[_DYN_DURATION /* @min:%2eduration */] = msToTimeSpan(value);\r\n _self.success = success;\r\n _self.resultCode = resultCode + \"\";\r\n _self.type = dataSanitizeString(logger, requestAPI);\r\n var dependencyFields = AjaxHelperParseDependencyPath(logger, absoluteUrl, method, commandName);\r\n _self.data = dataSanitizeUrl(logger, commandName) || dependencyFields.data; // get a value from hosturl if commandName not available\r\n _self.target = dataSanitizeString(logger, dependencyFields.target);\r\n if (correlationContext) {\r\n _self.target = \"\".concat(_self.target, \" | \").concat(correlationContext);\r\n }\r\n _self[_DYN_NAME /* @min:%2ename */] = dataSanitizeString(logger, dependencyFields[_DYN_NAME /* @min:%2ename */]);\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n }\r\n RemoteDependencyData.envelopeType = \"Microsoft.ApplicationInsights.{0}.RemoteDependency\";\r\n RemoteDependencyData.dataType = \"RemoteDependencyData\";\r\n return RemoteDependencyData;\r\n}());\r\nexport { RemoteDependencyData };\r\n//# sourceMappingURL=RemoteDependencyData.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { strNotSpecified } from \"../Constants\";\r\nimport { _DYN_MEASUREMENTS, _DYN_MESSAGE, _DYN_PROPERTIES, _DYN_SEVERITY_LEVEL } from \"../__DynamicConstants\";\r\nimport { dataSanitizeMeasurements, dataSanitizeMessage, dataSanitizeProperties } from \"./Common/DataSanitizer\";\r\nvar Trace = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the TraceTelemetry object\r\n */\r\n function Trace(logger, message, severityLevel, properties, measurements) {\r\n this.aiDataContract = {\r\n ver: 1 /* FieldType.Required */,\r\n message: 1 /* FieldType.Required */,\r\n severityLevel: 0 /* FieldType.Default */,\r\n properties: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2;\r\n message = message || strNotSpecified;\r\n _self[_DYN_MESSAGE /* @min:%2emessage */] = dataSanitizeMessage(logger, message);\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n if (severityLevel) {\r\n _self[_DYN_SEVERITY_LEVEL /* @min:%2eseverityLevel */] = severityLevel;\r\n }\r\n }\r\n Trace.envelopeType = \"Microsoft.ApplicationInsights.{0}.Message\";\r\n Trace.dataType = \"MessageData\";\r\n return Trace;\r\n}());\r\nexport { Trace };\r\n//# sourceMappingURL=Trace.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { strNotSpecified } from \"../Constants\";\r\nimport { _DYN_DURATION, _DYN_MEASUREMENTS, _DYN_NAME, _DYN_PROPERTIES } from \"../__DynamicConstants\";\r\nimport { dataSanitizeMeasurements, dataSanitizeProperties, dataSanitizeString, dataSanitizeUrl } from \"./Common/DataSanitizer\";\r\nvar PageViewPerformance = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the PageEventTelemetry object\r\n */\r\n function PageViewPerformance(logger, name, url, unused, properties, measurements, cs4BaseData) {\r\n this.aiDataContract = {\r\n ver: 1 /* FieldType.Required */,\r\n name: 0 /* FieldType.Default */,\r\n url: 0 /* FieldType.Default */,\r\n duration: 0 /* FieldType.Default */,\r\n perfTotal: 0 /* FieldType.Default */,\r\n networkConnect: 0 /* FieldType.Default */,\r\n sentRequest: 0 /* FieldType.Default */,\r\n receivedResponse: 0 /* FieldType.Default */,\r\n domProcessing: 0 /* FieldType.Default */,\r\n properties: 0 /* FieldType.Default */,\r\n measurements: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2;\r\n _self.url = dataSanitizeUrl(logger, url);\r\n _self[_DYN_NAME /* @min:%2ename */] = dataSanitizeString(logger, name) || strNotSpecified;\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n if (cs4BaseData) {\r\n _self.domProcessing = cs4BaseData.domProcessing;\r\n _self[_DYN_DURATION /* @min:%2eduration */] = cs4BaseData[_DYN_DURATION /* @min:%2eduration */];\r\n _self.networkConnect = cs4BaseData.networkConnect;\r\n _self.perfTotal = cs4BaseData.perfTotal;\r\n _self.receivedResponse = cs4BaseData.receivedResponse;\r\n _self.sentRequest = cs4BaseData.sentRequest;\r\n }\r\n }\r\n PageViewPerformance.envelopeType = \"Microsoft.ApplicationInsights.{0}.PageviewPerformance\";\r\n PageViewPerformance.dataType = \"PageviewPerformanceData\";\r\n return PageViewPerformance;\r\n}());\r\nexport { PageViewPerformance };\r\n//# sourceMappingURL=PageViewPerformance.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nvar Data = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of telemetry data.\r\n */\r\n function Data(baseType, data) {\r\n /**\r\n * The data contract for serializing this object.\r\n */\r\n this.aiDataContract = {\r\n baseType: 1 /* FieldType.Required */,\r\n baseData: 1 /* FieldType.Required */\r\n };\r\n this.baseType = baseType;\r\n this.baseData = data;\r\n }\r\n return Data;\r\n}());\r\nexport { Data };\r\n//# sourceMappingURL=Data.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { createEnumStyle } from \"@microsoft/applicationinsights-core-js\";\r\n/**\r\n * Defines the level of severity for the event.\r\n */\r\nexport var SeverityLevel = createEnumStyle({\r\n Verbose: 0 /* eSeverityLevel.Verbose */,\r\n Information: 1 /* eSeverityLevel.Information */,\r\n Warning: 2 /* eSeverityLevel.Warning */,\r\n Error: 3 /* eSeverityLevel.Error */,\r\n Critical: 4 /* eSeverityLevel.Critical */\r\n});\r\n//# sourceMappingURL=SeverityLevel.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport { createClassFromInterface } from \"@microsoft/applicationinsights-core-js\";\r\nfunction _aiNameFunc(baseName) {\r\n var aiName = \"ai.\" + baseName + \".\";\r\n return function (name) {\r\n return aiName + name;\r\n };\r\n}\r\nvar _aiApplication = _aiNameFunc(\"application\");\r\nvar _aiDevice = _aiNameFunc(\"device\");\r\nvar _aiLocation = _aiNameFunc(\"location\");\r\nvar _aiOperation = _aiNameFunc(\"operation\");\r\nvar _aiSession = _aiNameFunc(\"session\");\r\nvar _aiUser = _aiNameFunc(\"user\");\r\nvar _aiCloud = _aiNameFunc(\"cloud\");\r\nvar _aiInternal = _aiNameFunc(\"internal\");\r\nvar ContextTagKeys = /** @class */ (function (_super) {\r\n __extends(ContextTagKeys, _super);\r\n function ContextTagKeys() {\r\n return _super.call(this) || this;\r\n }\r\n return ContextTagKeys;\r\n}(createClassFromInterface({\r\n applicationVersion: _aiApplication(\"ver\"),\r\n applicationBuild: _aiApplication(\"build\"),\r\n applicationTypeId: _aiApplication(\"typeId\"),\r\n applicationId: _aiApplication(\"applicationId\"),\r\n applicationLayer: _aiApplication(\"layer\"),\r\n deviceId: _aiDevice(\"id\"),\r\n deviceIp: _aiDevice(\"ip\"),\r\n deviceLanguage: _aiDevice(\"language\"),\r\n deviceLocale: _aiDevice(\"locale\"),\r\n deviceModel: _aiDevice(\"model\"),\r\n deviceFriendlyName: _aiDevice(\"friendlyName\"),\r\n deviceNetwork: _aiDevice(\"network\"),\r\n deviceNetworkName: _aiDevice(\"networkName\"),\r\n deviceOEMName: _aiDevice(\"oemName\"),\r\n deviceOS: _aiDevice(\"os\"),\r\n deviceOSVersion: _aiDevice(\"osVersion\"),\r\n deviceRoleInstance: _aiDevice(\"roleInstance\"),\r\n deviceRoleName: _aiDevice(\"roleName\"),\r\n deviceScreenResolution: _aiDevice(\"screenResolution\"),\r\n deviceType: _aiDevice(\"type\"),\r\n deviceMachineName: _aiDevice(\"machineName\"),\r\n deviceVMName: _aiDevice(\"vmName\"),\r\n deviceBrowser: _aiDevice(\"browser\"),\r\n deviceBrowserVersion: _aiDevice(\"browserVersion\"),\r\n locationIp: _aiLocation(\"ip\"),\r\n locationCountry: _aiLocation(\"country\"),\r\n locationProvince: _aiLocation(\"province\"),\r\n locationCity: _aiLocation(\"city\"),\r\n operationId: _aiOperation(\"id\"),\r\n operationName: _aiOperation(\"name\"),\r\n operationParentId: _aiOperation(\"parentId\"),\r\n operationRootId: _aiOperation(\"rootId\"),\r\n operationSyntheticSource: _aiOperation(\"syntheticSource\"),\r\n operationCorrelationVector: _aiOperation(\"correlationVector\"),\r\n sessionId: _aiSession(\"id\"),\r\n sessionIsFirst: _aiSession(\"isFirst\"),\r\n sessionIsNew: _aiSession(\"isNew\"),\r\n userAccountAcquisitionDate: _aiUser(\"accountAcquisitionDate\"),\r\n userAccountId: _aiUser(\"accountId\"),\r\n userAgent: _aiUser(\"userAgent\"),\r\n userId: _aiUser(\"id\"),\r\n userStoreRegion: _aiUser(\"storeRegion\"),\r\n userAuthUserId: _aiUser(\"authUserId\"),\r\n userAnonymousUserAcquisitionDate: _aiUser(\"anonUserAcquisitionDate\"),\r\n userAuthenticatedUserAcquisitionDate: _aiUser(\"authUserAcquisitionDate\"),\r\n cloudName: _aiCloud(\"name\"),\r\n cloudRole: _aiCloud(\"role\"),\r\n cloudRoleVer: _aiCloud(\"roleVer\"),\r\n cloudRoleInstance: _aiCloud(\"roleInstance\"),\r\n cloudEnvironment: _aiCloud(\"environment\"),\r\n cloudLocation: _aiCloud(\"location\"),\r\n cloudDeploymentUnit: _aiCloud(\"deploymentUnit\"),\r\n internalNodeName: _aiInternal(\"nodeName\"),\r\n internalSdkVersion: _aiInternal(\"sdkVersion\"),\r\n internalAgentVersion: _aiInternal(\"agentVersion\"),\r\n internalSnippet: _aiInternal(\"snippet\"),\r\n internalSdkSrc: _aiInternal(\"sdkSrc\")\r\n})));\r\nexport { ContextTagKeys };\r\n//# sourceMappingURL=ContextTagKeys.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { isNullOrUndefined, objForEachKey, throwError, toISOString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { strIkey, strNotSpecified } from \"./Constants\";\r\nimport { dataSanitizeString } from \"./Telemetry/Common/DataSanitizer\";\r\n/**\r\n * Create a telemetry item that the 1DS channel understands\r\n * @param item - domain specific properties; part B\r\n * @param baseType - telemetry item type. ie PageViewData\r\n * @param envelopeName - Name of the envelope, e.g., `Microsoft.ApplicationInsights.\\.PageView`.\r\n * @param customProperties - user defined custom properties; part C\r\n * @param systemProperties - system properties that are added to the context; part A\r\n * @returns ITelemetryItem that is sent to channel\r\n */\r\nexport function createTelemetryItem(item, baseType, envelopeName, logger, customProperties, systemProperties) {\r\n envelopeName = dataSanitizeString(logger, envelopeName) || strNotSpecified;\r\n if (isNullOrUndefined(item) ||\r\n isNullOrUndefined(baseType) ||\r\n isNullOrUndefined(envelopeName)) {\r\n throwError(\"Input doesn't contain all required fields\");\r\n }\r\n var iKey = \"\";\r\n if (item[strIkey]) {\r\n iKey = item[strIkey];\r\n delete item[strIkey];\r\n }\r\n var telemetryItem = {\r\n name: envelopeName,\r\n time: toISOString(new Date()),\r\n iKey: iKey,\r\n ext: systemProperties ? systemProperties : {},\r\n tags: [],\r\n data: {},\r\n baseType: baseType,\r\n baseData: item // Part B\r\n };\r\n // Part C\r\n if (!isNullOrUndefined(customProperties)) {\r\n objForEachKey(customProperties, function (prop, value) {\r\n telemetryItem.data[prop] = value;\r\n });\r\n }\r\n return telemetryItem;\r\n}\r\nvar TelemetryItemCreator = /** @class */ (function () {\r\n function TelemetryItemCreator() {\r\n }\r\n /**\r\n * Create a telemetry item that the 1DS channel understands\r\n * @param item - domain specific properties; part B\r\n * @param baseType - telemetry item type. ie PageViewData\r\n * @param envelopeName - Name of the envelope (e.g., Microsoft.ApplicationInsights.[instrumentationKey].PageView).\r\n * @param customProperties - user defined custom properties; part C\r\n * @param systemProperties - system properties that are added to the context; part A\r\n * @returns ITelemetryItem that is sent to channel\r\n */\r\n TelemetryItemCreator.create = createTelemetryItem;\r\n return TelemetryItemCreator;\r\n}());\r\nexport { TelemetryItemCreator };\r\n//# sourceMappingURL=TelemetryItemCreator.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { ContextTagKeys } from \"./Contracts/ContextTagKeys\";\r\nexport var Extensions = {\r\n UserExt: \"user\",\r\n DeviceExt: \"device\",\r\n TraceExt: \"trace\",\r\n WebExt: \"web\",\r\n AppExt: \"app\",\r\n OSExt: \"os\",\r\n SessionExt: \"ses\",\r\n SDKExt: \"sdk\"\r\n};\r\nexport var CtxTagKeys = new ContextTagKeys();\r\n//# sourceMappingURL=PartAExtensions.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { getDocument, isFunction } from \"@microsoft/applicationinsights-core-js\";\r\nexport function createDomEvent(eventName) {\r\n var event = null;\r\n if (isFunction(Event)) { // Use Event constructor when available\r\n event = new Event(eventName);\r\n }\r\n else { // Event has no constructor in IE\r\n var doc = getDocument();\r\n if (doc && doc.createEvent) {\r\n event = doc.createEvent(\"Event\");\r\n event.initEvent(eventName, true, true);\r\n }\r\n }\r\n return event;\r\n}\r\n//# sourceMappingURL=DomHelperFuncs.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { arrForEach, createUniqueNamespace, eventOff, eventOn, getDocument, getNavigator, getWindow, isNullOrUndefined, isUndefined, mergeEvtNamespace } from \"@microsoft/applicationinsights-core-js\";\r\nfunction _disableEvents(target, evtNamespace) {\r\n eventOff(target, null, null, evtNamespace);\r\n}\r\n/**\r\n * Create a new OfflineListener instance to monitor browser online / offline events\r\n * @param parentEvtNamespace - The parent event namespace to append to any specific events for this instance\r\n */\r\nexport function createOfflineListener(parentEvtNamespace) {\r\n var _document = getDocument();\r\n var _navigator = getNavigator(); // Gets the window.navigator or workerNavigator depending on the global\r\n var _isListening = false;\r\n var listenerList = [];\r\n // Set the initial state\r\n // rState is changed by the browser, both via events and when we check the navigator.onLine property\r\n var rState = 1 /* eOfflineValue.Online */;\r\n if (_navigator && !isNullOrUndefined(_navigator.onLine) && !_navigator.onLine) { // navigator.onLine is undefined in react-native\r\n rState = 2 /* eOfflineValue.Offline */;\r\n }\r\n // ustate is changed by the user calling setOnlineState\r\n var uState = 0 /* eOfflineValue.Unknown */;\r\n // current state would be updated each time rState or uState is changed\r\n // it is a resolved value of rState and uState\r\n var _currentState = calCurrentState();\r\n var _evtNamespace = mergeEvtNamespace(createUniqueNamespace(\"OfflineListener\"), parentEvtNamespace);\r\n try {\r\n if (_enableEvents(getWindow())) {\r\n _isListening = true;\r\n }\r\n if (_document) {\r\n // Also attach to the document.body or document\r\n var target = _document.body || _document;\r\n if (target.ononline) {\r\n if (_enableEvents(target)) {\r\n _isListening = true;\r\n }\r\n }\r\n }\r\n }\r\n catch (e) {\r\n // this makes react-native less angry\r\n _isListening = false;\r\n }\r\n function _enableEvents(target) {\r\n var enabled = false;\r\n if (target) {\r\n enabled = eventOn(target, \"online\", _setOnline, _evtNamespace);\r\n if (enabled) {\r\n eventOn(target, \"offline\", _setOffline, _evtNamespace);\r\n }\r\n }\r\n return enabled;\r\n }\r\n function _isOnline() {\r\n return _currentState;\r\n }\r\n function calCurrentState() {\r\n if (uState === 2 /* eOfflineValue.Offline */ || rState === 2 /* eOfflineValue.Offline */) {\r\n return false;\r\n }\r\n return true; // if both unknown, then we assume the network is good\r\n }\r\n function listnerNoticeCheck() {\r\n // we were offline and are now online or we were online and now offline\r\n var newState = calCurrentState();\r\n if (_currentState !== newState) {\r\n _currentState = newState; // use the resolved state to update\r\n // send all the callbacks with the current state\r\n arrForEach(listenerList, function (callback) {\r\n var offlineState = {\r\n isOnline: _currentState,\r\n rState: rState,\r\n uState: uState\r\n };\r\n try {\r\n callback(offlineState);\r\n }\r\n catch (e) {\r\n // Do nothing, just making sure we run all of the callbacks\r\n }\r\n });\r\n }\r\n }\r\n function setOnlineState(newState) {\r\n uState = newState;\r\n listnerNoticeCheck();\r\n }\r\n function _setOnline() {\r\n rState = 1 /* eOfflineValue.Online */;\r\n listnerNoticeCheck();\r\n }\r\n function _setOffline() {\r\n rState = 2 /* eOfflineValue.Offline */;\r\n listnerNoticeCheck();\r\n }\r\n function _unload() {\r\n var win = getWindow();\r\n if (win && _isListening) {\r\n _disableEvents(win, _evtNamespace);\r\n if (_document) {\r\n // Also attach to the document.body or document\r\n var target = _document.body || _document;\r\n if (!isUndefined(target.ononline)) {\r\n _disableEvents(target, _evtNamespace);\r\n }\r\n }\r\n _isListening = false;\r\n }\r\n }\r\n function addListener(callback) {\r\n listenerList.push(callback);\r\n // Define rm as an instance of IUnloadHook\r\n return {\r\n rm: function () {\r\n var index = listenerList.indexOf(callback);\r\n if (index > -1) {\r\n return listenerList.splice(index, 1);\r\n }\r\n else {\r\n return;\r\n }\r\n }\r\n };\r\n }\r\n return {\r\n isOnline: _isOnline,\r\n isListening: function () { return _isListening; },\r\n unload: _unload,\r\n addListener: addListener,\r\n setOnlineState: setOnlineState\r\n };\r\n}\r\n//# sourceMappingURL=Offline.js.map","/*\n * Application Insights JavaScript SDK - Common, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n// Licensed under the\r\nexport { correlationIdSetPrefix, correlationIdGetPrefix, correlationIdCanIncludeCorrelationHeader, correlationIdGetCorrelationContext, correlationIdGetCorrelationContextValue, dateTimeUtilsNow, dateTimeUtilsDuration, isInternalApplicationInsightsEndpoint, createDistributedTraceContextFromTrace } from \"./Util\";\r\nexport { ThrottleMgr } from \"./ThrottleMgr\";\r\nexport { parseConnectionString, ConnectionStringParser } from \"./ConnectionStringParser\";\r\nexport { RequestHeaders } from \"./RequestResponseHeaders\";\r\nexport { DisabledPropertyName, ProcessLegacy, SampleRate, HttpMethod, DEFAULT_BREEZE_ENDPOINT, DEFAULT_BREEZE_PATH, strNotSpecified } from \"./Constants\";\r\nexport { Envelope } from \"./Telemetry/Common/Envelope\";\r\nexport { Event } from \"./Telemetry/Event\";\r\nexport { Exception } from \"./Telemetry/Exception\";\r\nexport { Metric } from \"./Telemetry/Metric\";\r\nexport { PageView } from \"./Telemetry/PageView\";\r\nexport { RemoteDependencyData } from \"./Telemetry/RemoteDependencyData\";\r\nexport { Trace } from \"./Telemetry/Trace\";\r\nexport { PageViewPerformance } from \"./Telemetry/PageViewPerformance\";\r\nexport { Data } from \"./Telemetry/Common/Data\";\r\nexport { SeverityLevel } from \"./Interfaces/Contracts/SeverityLevel\";\r\nexport { ConfigurationManager } from \"./Interfaces/IConfig\";\r\nexport { ContextTagKeys } from \"./Interfaces/Contracts/ContextTagKeys\";\r\nexport { dataSanitizeKeyAndAddUniqueness, dataSanitizeKey, dataSanitizeString, dataSanitizeUrl, dataSanitizeMessage, dataSanitizeException, dataSanitizeProperties, dataSanitizeMeasurements, dataSanitizeId, dataSanitizeInput, dsPadNumber } from \"./Telemetry/Common/DataSanitizer\";\r\nexport { TelemetryItemCreator, createTelemetryItem } from \"./TelemetryItemCreator\";\r\nexport { CtxTagKeys, Extensions } from \"./Interfaces/PartAExtensions\";\r\nexport { DistributedTracingModes, EventPersistence } from \"./Enums\";\r\nexport { stringToBoolOrDefault, msToTimeSpan, getExtensionByName, isCrossOriginError } from \"./HelperFuncs\";\r\nexport { isBeaconsSupported as isBeaconApiSupported, createTraceParent, parseTraceParent, isValidTraceId, isValidSpanId, isValidTraceParent, isSampledFlag, formatTraceParent, findW3cTraceParent, findAllScripts } from \"@microsoft/applicationinsights-core-js\";\r\nexport { createDomEvent } from \"./DomHelperFuncs\";\r\nexport { utlDisableStorage, utlEnableStorage, utlCanUseLocalStorage, utlGetLocalStorage, utlSetLocalStorage, utlRemoveStorage, utlCanUseSessionStorage, utlGetSessionStorageKeys, utlGetSessionStorage, utlSetSessionStorage, utlRemoveSessionStorage, utlSetStoragePrefix } from \"./StorageHelperFuncs\";\r\nexport { urlParseUrl, urlGetAbsoluteUrl, urlGetPathName, urlGetCompleteUrl, urlParseHost, urlParseFullHost } from \"./UrlHelperFuncs\";\r\nexport { createOfflineListener } from \"./Offline\";\r\nexport var PropertiesPluginIdentifier = \"AppInsightsPropertiesPlugin\";\r\nexport var BreezeChannelIdentifier = \"AppInsightsChannelPlugin\";\r\nexport var AnalyticsPluginIdentifier = \"ApplicationInsightsAnalytics\";\r\n//# sourceMappingURL=applicationinsights-common.js.map","/*\n * Application Insights JavaScript SDK - Web Analytics, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES5 which can result in a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_TO_STRING = \"toString\"; // Count: 4\r\nexport var _DYN_IS_STORAGE_USE_DISAB0 = \"isStorageUseDisabled\"; // Count: 3\r\nexport var _DYN__ADD_HOOK = \"_addHook\"; // Count: 6\r\nexport var _DYN_CORE = \"core\"; // Count: 7\r\nexport var _DYN_DATA_TYPE = \"dataType\"; // Count: 8\r\nexport var _DYN_ENVELOPE_TYPE = \"envelopeType\"; // Count: 7\r\nexport var _DYN_DIAG_LOG = \"diagLog\"; // Count: 13\r\nexport var _DYN_TRACK = \"track\"; // Count: 7\r\nexport var _DYN_TRACK_PAGE_VIEW = \"trackPageView\"; // Count: 4\r\nexport var _DYN_TRACK_PREVIOUS_PAGE_1 = \"trackPreviousPageVisit\"; // Count: 3\r\nexport var _DYN_SEND_PAGE_VIEW_INTER2 = \"sendPageViewInternal\"; // Count: 7\r\nexport var _DYN_START_TIME = \"startTime\"; // Count: 6\r\nexport var _DYN_PROPERTIES = \"properties\"; // Count: 5\r\nexport var _DYN_DURATION = \"duration\"; // Count: 12\r\nexport var _DYN_SEND_PAGE_VIEW_PERFO3 = \"sendPageViewPerformanceInternal\"; // Count: 3\r\nexport var _DYN_POPULATE_PAGE_VIEW_P4 = \"populatePageViewPerformanceEvent\"; // Count: 3\r\nexport var _DYN_HREF = \"href\"; // Count: 6\r\nexport var _DYN_SEND_EXCEPTION_INTER5 = \"sendExceptionInternal\"; // Count: 2\r\nexport var _DYN_ERROR = \"error\"; // Count: 5\r\nexport var _DYN_LINE_NUMBER = \"lineNumber\"; // Count: 4\r\nexport var _DYN_COLUMN_NUMBER = \"columnNumber\"; // Count: 5\r\nexport var _DYN__CREATE_AUTO_EXCEPTI6 = \"CreateAutoException\"; // Count: 3\r\nexport var _DYN_ADD_TELEMETRY_INITIA7 = \"addTelemetryInitializer\"; // Count: 4\r\nexport var _DYN_OVERRIDE_PAGE_VIEW_D8 = \"overridePageViewDuration\"; // Count: 2\r\nexport var _DYN_AUTO_EXCEPTION_INSTR9 = \"autoExceptionInstrumented\"; // Count: 3\r\nexport var _DYN_AUTO_TRACK_PAGE_VISI10 = \"autoTrackPageVisitTime\"; // Count: 2\r\nexport var _DYN_IS_BROWSER_LINK_TRAC11 = \"isBrowserLinkTrackingEnabled\"; // Count: 2\r\nexport var _DYN_LENGTH = \"length\"; // Count: 5\r\nexport var _DYN_ENABLE_AUTO_ROUTE_TR12 = \"enableAutoRouteTracking\"; // Count: 2\r\nexport var _DYN_ENABLE_UNHANDLED_PRO13 = \"enableUnhandledPromiseRejectionTracking\"; // Count: 2\r\nexport var _DYN_AUTO_UNHANDLED_PROMI14 = \"autoUnhandledPromiseInstrumented\"; // Count: 3\r\nexport var _DYN_GET_ENTRIES_BY_TYPE = \"getEntriesByType\"; // Count: 5\r\nexport var _DYN_IS_PERFORMANCE_TIMIN15 = \"isPerformanceTimingSupported\"; // Count: 2\r\nexport var _DYN_GET_PERFORMANCE_TIMI16 = \"getPerformanceTiming\"; // Count: 2\r\nexport var _DYN_NAVIGATION_START = \"navigationStart\"; // Count: 4\r\nexport var _DYN_SHOULD_COLLECT_DURAT17 = \"shouldCollectDuration\"; // Count: 3\r\nexport var _DYN_IS_PERFORMANCE_TIMIN18 = \"isPerformanceTimingDataReady\"; // Count: 2\r\nexport var _DYN_RESPONSE_START = \"responseStart\"; // Count: 5\r\nexport var _DYN_REQUEST_START = \"requestStart\"; // Count: 3\r\nexport var _DYN_LOAD_EVENT_END = \"loadEventEnd\"; // Count: 4\r\nexport var _DYN_RESPONSE_END = \"responseEnd\"; // Count: 5\r\nexport var _DYN_CONNECT_END = \"connectEnd\"; // Count: 4\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Web Analytics, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { dateTimeUtilsDuration } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal, arrForEach, dumpObj, getDocument, getExceptionName, getLocation, isNullOrUndefined } from \"@microsoft/applicationinsights-core-js\";\r\nimport { getPerformance, isUndefined, isWebWorker, scheduleTimeout } from \"@nevware21/ts-utils\";\r\nimport { _DYN_DURATION, _DYN_GET_ENTRIES_BY_TYPE, _DYN_GET_PERFORMANCE_TIMI16, _DYN_HREF, _DYN_IS_PERFORMANCE_TIMIN15, _DYN_IS_PERFORMANCE_TIMIN18, _DYN_LENGTH, _DYN_NAVIGATION_START, _DYN_POPULATE_PAGE_VIEW_P4, _DYN_PROPERTIES, _DYN_SEND_PAGE_VIEW_INTER2, _DYN_SEND_PAGE_VIEW_PERFO3, _DYN_SHOULD_COLLECT_DURAT17, _DYN_START_TIME, _DYN_TRACK_PAGE_VIEW } from \"../../__DynamicConstants\";\r\n/**\r\n * Class encapsulates sending page views and page view performance telemetry.\r\n */\r\nvar PageViewManager = /** @class */ (function () {\r\n function PageViewManager(appInsights, overridePageViewDuration, core, pageViewPerformanceManager) {\r\n dynamicProto(PageViewManager, this, function (_self) {\r\n var queueTimer = null;\r\n var itemQueue = [];\r\n var pageViewPerformanceSent = false;\r\n var firstPageViewSent = false;\r\n var _logger;\r\n if (core) {\r\n _logger = core.logger;\r\n }\r\n function _flushChannels(isAsync) {\r\n if (core) {\r\n core.flush(isAsync, function () {\r\n // Event flushed, callback added to prevent promise creation\r\n });\r\n }\r\n }\r\n function _startTimer() {\r\n if (!queueTimer) {\r\n queueTimer = scheduleTimeout((function () {\r\n queueTimer = null;\r\n var allItems = itemQueue.slice(0);\r\n var doFlush = false;\r\n itemQueue = [];\r\n arrForEach(allItems, function (item) {\r\n if (!item()) {\r\n // Not processed so rescheduled\r\n itemQueue.push(item);\r\n }\r\n else {\r\n doFlush = true;\r\n }\r\n });\r\n if (itemQueue[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n _startTimer();\r\n }\r\n if (doFlush) {\r\n // We process at least one item so flush the queue\r\n _flushChannels(true);\r\n }\r\n }), 100);\r\n }\r\n }\r\n function _addQueue(cb) {\r\n itemQueue.push(cb);\r\n _startTimer();\r\n }\r\n _self[_DYN_TRACK_PAGE_VIEW /* @min:%2etrackPageView */] = function (pageView, customProperties) {\r\n var name = pageView.name;\r\n if (isNullOrUndefined(name) || typeof name !== \"string\") {\r\n var doc = getDocument();\r\n name = pageView.name = doc && doc.title || \"\";\r\n }\r\n var uri = pageView.uri;\r\n if (isNullOrUndefined(uri) || typeof uri !== \"string\") {\r\n var location_1 = getLocation();\r\n uri = pageView.uri = location_1 && location_1[_DYN_HREF /* @min:%2ehref */] || \"\";\r\n }\r\n if (!firstPageViewSent) {\r\n var perf = getPerformance();\r\n // Access the performance timing object\r\n var navigationEntries = (perf && perf[_DYN_GET_ENTRIES_BY_TYPE /* @min:%2egetEntriesByType */] && perf[_DYN_GET_ENTRIES_BY_TYPE /* @min:%2egetEntriesByType */](\"navigation\"));\r\n // Edge Case the navigation Entries may return an empty array and the timeOrigin is not supported on IE\r\n if (navigationEntries && navigationEntries[0] && !isUndefined(perf.timeOrigin)) {\r\n // Get the value of loadEventStart\r\n var loadEventStart = navigationEntries[0].loadEventStart;\r\n pageView[_DYN_START_TIME /* @min:%2estartTime */] = new Date(perf.timeOrigin + loadEventStart);\r\n }\r\n else {\r\n // calculate the start time manually\r\n var duration_1 = ((customProperties || pageView[_DYN_PROPERTIES /* @min:%2eproperties */] || {})[_DYN_DURATION /* @min:%2eduration */] || 0);\r\n pageView[_DYN_START_TIME /* @min:%2estartTime */] = new Date(new Date().getTime() - duration_1);\r\n }\r\n firstPageViewSent = true;\r\n }\r\n // case 1a. if performance timing is not supported by the browser, send the page view telemetry with the duration provided by the user. If the user\r\n // do not provide the duration, set duration to undefined\r\n // Also this is case 4\r\n if (!pageViewPerformanceManager[_DYN_IS_PERFORMANCE_TIMIN15 /* @min:%2eisPerformanceTimingSupported */]()) {\r\n appInsights[_DYN_SEND_PAGE_VIEW_INTER2 /* @min:%2esendPageViewInternal */](pageView, customProperties);\r\n _flushChannels(true);\r\n if (!isWebWorker()) {\r\n // no navigation timing (IE 8, iOS Safari 8.4, Opera Mini 8 - see http://caniuse.com/#feat=nav-timing)\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 25 /* _eInternalMessageId.NavigationTimingNotSupported */, \"trackPageView: navigation timing API used for calculation of page duration is not supported in this browser. This page view will be collected without duration and timing info.\");\r\n }\r\n return;\r\n }\r\n var pageViewSent = false;\r\n var customDuration;\r\n // if the performance timing is supported by the browser, calculate the custom duration\r\n var start = pageViewPerformanceManager[_DYN_GET_PERFORMANCE_TIMI16 /* @min:%2egetPerformanceTiming */]()[_DYN_NAVIGATION_START /* @min:%2enavigationStart */];\r\n if (start > 0) {\r\n customDuration = dateTimeUtilsDuration(start, +new Date);\r\n if (!pageViewPerformanceManager[_DYN_SHOULD_COLLECT_DURAT17 /* @min:%2eshouldCollectDuration */](customDuration)) {\r\n customDuration = undefined;\r\n }\r\n }\r\n // if the user has provided duration, send a page view telemetry with the provided duration. Otherwise, if\r\n // overridePageViewDuration is set to true, send a page view telemetry with the custom duration calculated earlier\r\n var duration;\r\n if (!isNullOrUndefined(customProperties) &&\r\n !isNullOrUndefined(customProperties[_DYN_DURATION /* @min:%2eduration */])) {\r\n duration = customProperties[_DYN_DURATION /* @min:%2eduration */];\r\n }\r\n if (overridePageViewDuration || !isNaN(duration)) {\r\n if (isNaN(duration)) {\r\n // case 3\r\n if (!customProperties) {\r\n customProperties = {};\r\n }\r\n customProperties[_DYN_DURATION /* @min:%2eduration */] = customDuration;\r\n }\r\n // case 2\r\n appInsights[_DYN_SEND_PAGE_VIEW_INTER2 /* @min:%2esendPageViewInternal */](pageView, customProperties);\r\n _flushChannels(true);\r\n pageViewSent = true;\r\n }\r\n // now try to send the page view performance telemetry\r\n var maxDurationLimit = 60000;\r\n if (!customProperties) {\r\n customProperties = {};\r\n }\r\n // Queue the event for processing\r\n _addQueue(function () {\r\n var processed = false;\r\n try {\r\n if (pageViewPerformanceManager[_DYN_IS_PERFORMANCE_TIMIN18 /* @min:%2eisPerformanceTimingDataReady */]()) {\r\n processed = true;\r\n var pageViewPerformance = {\r\n name: name,\r\n uri: uri\r\n };\r\n pageViewPerformanceManager[_DYN_POPULATE_PAGE_VIEW_P4 /* @min:%2epopulatePageViewPerformanceEvent */](pageViewPerformance);\r\n if (!pageViewPerformance.isValid && !pageViewSent) {\r\n // If navigation timing gives invalid numbers, then go back to \"override page view duration\" mode.\r\n // That's the best value we can get that makes sense.\r\n customProperties[_DYN_DURATION /* @min:%2eduration */] = customDuration;\r\n appInsights[_DYN_SEND_PAGE_VIEW_INTER2 /* @min:%2esendPageViewInternal */](pageView, customProperties);\r\n }\r\n else {\r\n if (!pageViewSent) {\r\n customProperties[_DYN_DURATION /* @min:%2eduration */] = pageViewPerformance.durationMs;\r\n appInsights[_DYN_SEND_PAGE_VIEW_INTER2 /* @min:%2esendPageViewInternal */](pageView, customProperties);\r\n }\r\n if (!pageViewPerformanceSent) {\r\n appInsights[_DYN_SEND_PAGE_VIEW_PERFO3 /* @min:%2esendPageViewPerformanceInternal */](pageViewPerformance, customProperties);\r\n pageViewPerformanceSent = true;\r\n }\r\n }\r\n }\r\n else if (start > 0 && dateTimeUtilsDuration(start, +new Date) > maxDurationLimit) {\r\n // if performance timings are not ready but we exceeded the maximum duration limit, just log a page view telemetry\r\n // with the maximum duration limit. Otherwise, keep waiting until performance timings are ready\r\n processed = true;\r\n if (!pageViewSent) {\r\n customProperties[_DYN_DURATION /* @min:%2eduration */] = maxDurationLimit;\r\n appInsights[_DYN_SEND_PAGE_VIEW_INTER2 /* @min:%2esendPageViewInternal */](pageView, customProperties);\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(_logger, 1 /* eLoggingSeverity.CRITICAL */, 38 /* _eInternalMessageId.TrackPVFailedCalc */, \"trackPageView failed on page load calculation: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n return processed;\r\n });\r\n };\r\n _self.teardown = function (unloadCtx, unloadState) {\r\n if (queueTimer) {\r\n queueTimer.cancel();\r\n queueTimer = null;\r\n var allItems = itemQueue.slice(0);\r\n var doFlush_1 = false;\r\n itemQueue = [];\r\n arrForEach(allItems, function (item) {\r\n if (item()) {\r\n doFlush_1 = true;\r\n }\r\n });\r\n }\r\n };\r\n });\r\n }\r\n// Removed Stub for PageViewManager.prototype.trackPageView.\r\n// Removed Stub for PageViewManager.prototype.teardown.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n PageViewManager.__ieDyn=1;\n\n return PageViewManager;\r\n}());\r\nexport { PageViewManager };\r\n//# sourceMappingURL=PageViewManager.js.map","/*\n * Application Insights JavaScript SDK - Web Analytics, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { dateTimeUtilsDuration, msToTimeSpan } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal, getNavigator, getPerformance, safeGetLogger } from \"@microsoft/applicationinsights-core-js\";\r\nimport { mathFloor, strIndexOf } from \"@nevware21/ts-utils\";\r\nimport { _DYN_CONNECT_END, _DYN_DURATION, _DYN_GET_ENTRIES_BY_TYPE, _DYN_GET_PERFORMANCE_TIMI16, _DYN_IS_PERFORMANCE_TIMIN15, _DYN_IS_PERFORMANCE_TIMIN18, _DYN_LENGTH, _DYN_LOAD_EVENT_END, _DYN_NAVIGATION_START, _DYN_POPULATE_PAGE_VIEW_P4, _DYN_REQUEST_START, _DYN_RESPONSE_END, _DYN_RESPONSE_START, _DYN_SHOULD_COLLECT_DURAT17, _DYN_START_TIME } from \"../../__DynamicConstants\";\r\nvar MAX_DURATION_ALLOWED = 3600000; // 1h\r\nvar botAgentNames = [\"googlebot\", \"adsbot-google\", \"apis-google\", \"mediapartners-google\"];\r\nfunction _isPerformanceTimingSupported() {\r\n var perf = getPerformance();\r\n return perf && !!perf.timing;\r\n}\r\nfunction _isPerformanceNavigationTimingSupported() {\r\n var perf = getPerformance();\r\n return perf && perf.getEntriesByType && perf.getEntriesByType(\"navigation\")[_DYN_LENGTH /* @min:%2elength */] > 0;\r\n}\r\nfunction _isPerformanceTimingDataReady() {\r\n var perf = getPerformance();\r\n var timing = perf ? perf.timing : 0;\r\n return timing\r\n && timing.domainLookupStart > 0\r\n && timing[_DYN_NAVIGATION_START /* @min:%2enavigationStart */] > 0\r\n && timing[_DYN_RESPONSE_START /* @min:%2eresponseStart */] > 0\r\n && timing[_DYN_REQUEST_START /* @min:%2erequestStart */] > 0\r\n && timing[_DYN_LOAD_EVENT_END /* @min:%2eloadEventEnd */] > 0\r\n && timing[_DYN_RESPONSE_END /* @min:%2eresponseEnd */] > 0\r\n && timing[_DYN_CONNECT_END /* @min:%2econnectEnd */] > 0\r\n && timing.domLoading > 0;\r\n}\r\nfunction _getPerformanceTiming() {\r\n if (_isPerformanceTimingSupported()) {\r\n return getPerformance().timing;\r\n }\r\n return null;\r\n}\r\nfunction _getPerformanceNavigationTiming() {\r\n if (_isPerformanceNavigationTimingSupported()) {\r\n return getPerformance()[_DYN_GET_ENTRIES_BY_TYPE /* @min:%2egetEntriesByType */](\"navigation\")[0];\r\n }\r\n return null;\r\n}\r\n/**\r\n* This method tells if given durations should be excluded from collection.\r\n*/\r\nfunction _shouldCollectDuration() {\r\n var durations = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n durations[_i] = arguments[_i];\r\n }\r\n var _navigator = getNavigator() || {};\r\n // a full list of Google crawlers user agent strings - https://support.google.com/webmasters/answer/1061943?hl=en\r\n var userAgent = _navigator.userAgent;\r\n var isGoogleBot = false;\r\n if (userAgent) {\r\n for (var i = 0; i < botAgentNames[_DYN_LENGTH /* @min:%2elength */]; i++) {\r\n isGoogleBot = isGoogleBot || strIndexOf(userAgent.toLowerCase(), botAgentNames[i]) !== -1;\r\n }\r\n }\r\n if (isGoogleBot) {\r\n // Don't report durations for GoogleBot, it is returning invalid values in performance.timing API.\r\n return false;\r\n }\r\n else {\r\n // for other page views, don't report if it's outside of a reasonable range\r\n for (var i = 0; i < durations[_DYN_LENGTH /* @min:%2elength */]; i++) {\r\n if (durations[i] < 0 || durations[i] >= MAX_DURATION_ALLOWED) {\r\n return false;\r\n }\r\n }\r\n }\r\n return true;\r\n}\r\n/**\r\n * Class encapsulates sending page view performance telemetry.\r\n */\r\nvar PageViewPerformanceManager = /** @class */ (function () {\r\n function PageViewPerformanceManager(core) {\r\n var _logger = safeGetLogger(core);\r\n dynamicProto(PageViewPerformanceManager, this, function (_self) {\r\n _self[_DYN_POPULATE_PAGE_VIEW_P4 /* @min:%2epopulatePageViewPerformanceEvent */] = function (pageViewPerformance) {\r\n pageViewPerformance.isValid = false;\r\n /*\r\n * http://www.w3.org/TR/navigation-timing/#processing-model\r\n * |-navigationStart\r\n * | |-connectEnd\r\n * | ||-requestStart\r\n * | || |-responseStart\r\n * | || | |-responseEnd\r\n * | || | |\r\n * | || | | |-loadEventEnd\r\n * |---network---||---request---|---response---|---dom---|\r\n * |--------------------------total----------------------|\r\n *\r\n * total = The difference between the load event of the current document is completed and the first recorded timestamp of the performance entry : https://developer.mozilla.org/en-US/docs/Web/Performance/Navigation_and_resource_timings#duration\r\n * network = Redirect time + App Cache + DNS lookup time + TCP connection time\r\n * request = Request time : https://developer.mozilla.org/en-US/docs/Web/Performance/Navigation_and_resource_timings#request_time\r\n * response = Response time\r\n * dom = Document load time : https://html.spec.whatwg.org/multipage/dom.html#document-load-timing-info\r\n * = Document processing time : https://developers.google.com/web/fundamentals/performance/navigation-and-resource-timing/#document_processing\r\n * + Loading time : https://developers.google.com/web/fundamentals/performance/navigation-and-resource-timing/#loading\r\n */\r\n var navigationTiming = _getPerformanceNavigationTiming();\r\n var timing = _getPerformanceTiming();\r\n var total = 0;\r\n var network = 0;\r\n var request = 0;\r\n var response = 0;\r\n var dom = 0;\r\n if (navigationTiming || timing) {\r\n if (navigationTiming) {\r\n total = navigationTiming[_DYN_DURATION /* @min:%2eduration */];\r\n /**\r\n * support both cases:\r\n * - startTime is always zero: https://developer.mozilla.org/en-US/docs/Web/API/PerformanceNavigationTiming\r\n * - for older browsers where the startTime is not zero\r\n */\r\n network = navigationTiming[_DYN_START_TIME /* @min:%2estartTime */] === 0 ? navigationTiming[_DYN_CONNECT_END /* @min:%2econnectEnd */] : dateTimeUtilsDuration(navigationTiming[_DYN_START_TIME /* @min:%2estartTime */], navigationTiming[_DYN_CONNECT_END /* @min:%2econnectEnd */]);\r\n request = dateTimeUtilsDuration(navigationTiming.requestStart, navigationTiming[_DYN_RESPONSE_START /* @min:%2eresponseStart */]);\r\n response = dateTimeUtilsDuration(navigationTiming[_DYN_RESPONSE_START /* @min:%2eresponseStart */], navigationTiming[_DYN_RESPONSE_END /* @min:%2eresponseEnd */]);\r\n dom = dateTimeUtilsDuration(navigationTiming.responseEnd, navigationTiming[_DYN_LOAD_EVENT_END /* @min:%2eloadEventEnd */]);\r\n }\r\n else {\r\n total = dateTimeUtilsDuration(timing[_DYN_NAVIGATION_START /* @min:%2enavigationStart */], timing[_DYN_LOAD_EVENT_END /* @min:%2eloadEventEnd */]);\r\n network = dateTimeUtilsDuration(timing[_DYN_NAVIGATION_START /* @min:%2enavigationStart */], timing[_DYN_CONNECT_END /* @min:%2econnectEnd */]);\r\n request = dateTimeUtilsDuration(timing.requestStart, timing[_DYN_RESPONSE_START /* @min:%2eresponseStart */]);\r\n response = dateTimeUtilsDuration(timing[_DYN_RESPONSE_START /* @min:%2eresponseStart */], timing[_DYN_RESPONSE_END /* @min:%2eresponseEnd */]);\r\n dom = dateTimeUtilsDuration(timing.responseEnd, timing[_DYN_LOAD_EVENT_END /* @min:%2eloadEventEnd */]);\r\n }\r\n if (total === 0) {\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 10 /* _eInternalMessageId.ErrorPVCalc */, \"error calculating page view performance.\", { total: total, network: network, request: request, response: response, dom: dom });\r\n }\r\n else if (!_self[_DYN_SHOULD_COLLECT_DURAT17 /* @min:%2eshouldCollectDuration */](total, network, request, response, dom)) {\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 45 /* _eInternalMessageId.InvalidDurationValue */, \"Invalid page load duration value. Browser perf data won't be sent.\", { total: total, network: network, request: request, response: response, dom: dom });\r\n }\r\n else if (total < mathFloor(network) + mathFloor(request) + mathFloor(response) + mathFloor(dom)) {\r\n // some browsers may report individual components incorrectly so that the sum of the parts will be bigger than total PLT\r\n // in this case, don't report client performance from this page\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 8 /* _eInternalMessageId.ClientPerformanceMathError */, \"client performance math error.\", { total: total, network: network, request: request, response: response, dom: dom });\r\n }\r\n else {\r\n pageViewPerformance.durationMs = total;\r\n // // convert to timespans\r\n pageViewPerformance.perfTotal = pageViewPerformance[_DYN_DURATION /* @min:%2eduration */] = msToTimeSpan(total);\r\n pageViewPerformance.networkConnect = msToTimeSpan(network);\r\n pageViewPerformance.sentRequest = msToTimeSpan(request);\r\n pageViewPerformance.receivedResponse = msToTimeSpan(response);\r\n pageViewPerformance.domProcessing = msToTimeSpan(dom);\r\n pageViewPerformance.isValid = true;\r\n }\r\n }\r\n };\r\n _self[_DYN_GET_PERFORMANCE_TIMI16 /* @min:%2egetPerformanceTiming */] = _getPerformanceTiming;\r\n _self[_DYN_IS_PERFORMANCE_TIMIN15 /* @min:%2eisPerformanceTimingSupported */] = _isPerformanceTimingSupported;\r\n _self[_DYN_IS_PERFORMANCE_TIMIN18 /* @min:%2eisPerformanceTimingDataReady */] = _isPerformanceTimingDataReady;\r\n _self[_DYN_SHOULD_COLLECT_DURAT17 /* @min:%2eshouldCollectDuration */] = _shouldCollectDuration;\r\n });\r\n }\r\n// Removed Stub for PageViewPerformanceManager.prototype.populatePageViewPerformanceEvent.\r\n// Removed Stub for PageViewPerformanceManager.prototype.getPerformanceTiming.\r\n// Removed Stub for PageViewPerformanceManager.prototype.isPerformanceTimingSupported.\r\n// Removed Stub for PageViewPerformanceManager.prototype.isPerformanceTimingDataReady.\r\n// Removed Stub for PageViewPerformanceManager.prototype.shouldCollectDuration.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n PageViewPerformanceManager.__ieDyn=1;\n\n return PageViewPerformanceManager;\r\n}());\r\nexport { PageViewPerformanceManager };\r\n//# sourceMappingURL=PageViewPerformanceManager.js.map","/*\n * Application Insights JavaScript SDK - Web Analytics, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { utlCanUseSessionStorage, utlGetSessionStorage, utlRemoveSessionStorage, utlSetSessionStorage } from \"@microsoft/applicationinsights-common\";\r\nimport { _warnToConsole, dateNow, dumpObj, getJSON, hasJSON, throwError } from \"@microsoft/applicationinsights-core-js\";\r\nimport { objDefine } from \"@nevware21/ts-utils\";\r\nimport { _DYN_TRACK_PREVIOUS_PAGE_1 } from \"../../__DynamicConstants\";\r\n/**\r\n * Used to track page visit durations\r\n */\r\nvar PageVisitTimeManager = /** @class */ (function () {\r\n /**\r\n * Creates a new instance of PageVisitTimeManager\r\n * @param pageVisitTimeTrackingHandler - Delegate that will be called to send telemetry data to AI (when trackPreviousPageVisit is called)\r\n * @returns {}\r\n */\r\n function PageVisitTimeManager(logger, pageVisitTimeTrackingHandler) {\r\n var prevPageVisitDataKeyName = \"prevPageVisitData\";\r\n dynamicProto(PageVisitTimeManager, this, function (_self) {\r\n _self[_DYN_TRACK_PREVIOUS_PAGE_1 /* @min:%2etrackPreviousPageVisit */] = function (currentPageName, currentPageUrl) {\r\n try {\r\n // Restart timer for new page view\r\n var prevPageVisitTimeData = restartPageVisitTimer(currentPageName, currentPageUrl);\r\n // If there was a page already being timed, track the visit time for it now.\r\n if (prevPageVisitTimeData) {\r\n pageVisitTimeTrackingHandler(prevPageVisitTimeData.pageName, prevPageVisitTimeData.pageUrl, prevPageVisitTimeData.pageVisitTime);\r\n }\r\n }\r\n catch (e) {\r\n _warnToConsole(logger, \"Auto track page visit time failed, metric will not be collected: \" + dumpObj(e));\r\n }\r\n };\r\n /**\r\n * Stops timing of current page (if exists) and starts timing for duration of visit to pageName\r\n * @param pageName - Name of page to begin timing visit duration\r\n * @returns {PageVisitData} Page visit data (including duration) of pageName from last call to start or restart, if exists. Null if not.\r\n */\r\n function restartPageVisitTimer(pageName, pageUrl) {\r\n var prevPageVisitData = null;\r\n try {\r\n prevPageVisitData = stopPageVisitTimer();\r\n if (utlCanUseSessionStorage()) {\r\n if (utlGetSessionStorage(logger, prevPageVisitDataKeyName) != null) {\r\n throwError(\"Cannot call startPageVisit consecutively without first calling stopPageVisit\");\r\n }\r\n var currPageVisitDataStr = getJSON().stringify(new PageVisitData(pageName, pageUrl));\r\n utlSetSessionStorage(logger, prevPageVisitDataKeyName, currPageVisitDataStr);\r\n }\r\n }\r\n catch (e) {\r\n _warnToConsole(logger, \"Call to restart failed: \" + dumpObj(e));\r\n prevPageVisitData = null;\r\n }\r\n return prevPageVisitData;\r\n }\r\n /**\r\n * Stops timing of current page, if exists.\r\n * @returns {PageVisitData} Page visit data (including duration) of pageName from call to start, if exists. Null if not.\r\n */\r\n function stopPageVisitTimer() {\r\n var prevPageVisitData = null;\r\n try {\r\n if (utlCanUseSessionStorage()) {\r\n // Define end time of page's visit\r\n var pageVisitEndTime = dateNow();\r\n // Try to retrieve page name and start time from session storage\r\n var pageVisitDataJsonStr = utlGetSessionStorage(logger, prevPageVisitDataKeyName);\r\n if (pageVisitDataJsonStr && hasJSON()) {\r\n // if previous page data exists, set end time of visit\r\n prevPageVisitData = getJSON().parse(pageVisitDataJsonStr);\r\n prevPageVisitData.pageVisitTime = pageVisitEndTime - prevPageVisitData.pageVisitStartTime;\r\n // Remove data from storage since we already used it\r\n utlRemoveSessionStorage(logger, prevPageVisitDataKeyName);\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _warnToConsole(logger, \"Stop page visit timer failed: \" + dumpObj(e));\r\n prevPageVisitData = null;\r\n }\r\n return prevPageVisitData;\r\n }\r\n // For backward compatibility\r\n objDefine(_self, \"_logger\", { g: function () { return logger; } });\r\n objDefine(_self, \"pageVisitTimeTrackingHandler\", { g: function () { return pageVisitTimeTrackingHandler; } });\r\n });\r\n }\r\n// Removed Stub for PageVisitTimeManager.prototype.trackPreviousPageVisit.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n PageVisitTimeManager.__ieDyn=1;\n\n return PageVisitTimeManager;\r\n}());\r\nexport { PageVisitTimeManager };\r\nvar PageVisitData = /** @class */ (function () {\r\n function PageVisitData(pageName, pageUrl) {\r\n this.pageVisitStartTime = dateNow();\r\n this.pageName = pageName;\r\n this.pageUrl = pageUrl;\r\n }\r\n return PageVisitData;\r\n}());\r\nexport { PageVisitData };\r\n//# sourceMappingURL=PageVisitTimeManager.js.map","/*\n * Application Insights JavaScript SDK - Web Analytics, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { dateTimeUtilsDuration } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal } from \"@microsoft/applicationinsights-core-js\";\r\n/**\r\n * Used to record timed events and page views.\r\n */\r\nvar Timing = /** @class */ (function () {\r\n function Timing(logger, name) {\r\n var _self = this;\r\n var _events = {};\r\n _self.start = function (name) {\r\n if (typeof _events[name] !== \"undefined\") {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 62 /* _eInternalMessageId.StartCalledMoreThanOnce */, \"start was called more than once for this event without calling stop.\", { name: name, key: name }, true);\r\n }\r\n _events[name] = +new Date;\r\n };\r\n _self.stop = function (name, url, properties, measurements) {\r\n var start = _events[name];\r\n if (isNaN(start)) {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 63 /* _eInternalMessageId.StopCalledWithoutStart */, \"stop was called without a corresponding start.\", { name: name, key: name }, true);\r\n }\r\n else {\r\n var end = +new Date;\r\n var duration = dateTimeUtilsDuration(start, end);\r\n _self.action(name, url, duration, properties, measurements);\r\n }\r\n delete _events[name];\r\n _events[name] = undefined;\r\n };\r\n }\r\n return Timing;\r\n}());\r\nexport { Timing };\r\n//# sourceMappingURL=Timing.js.map","/*\n * Application Insights JavaScript SDK - Web Analytics, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n/**\r\n* ApplicationInsights.ts\r\n* @copyright Microsoft 2018\r\n*/\r\nvar _a;\r\nimport { __assignFn as __assign, __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { AnalyticsPluginIdentifier, Event as EventTelemetry, Exception, Metric, PageView, PageViewPerformance, PropertiesPluginIdentifier, RemoteDependencyData, Trace, createDistributedTraceContextFromTrace, createDomEvent, createTelemetryItem, dataSanitizeString, isCrossOriginError, strNotSpecified, utlDisableStorage, utlEnableStorage, utlSetStoragePrefix } from \"@microsoft/applicationinsights-common\";\r\nimport { BaseTelemetryPlugin, InstrumentEvent, arrForEach, cfgDfBoolean, cfgDfMerge, cfgDfSet, cfgDfString, cfgDfValidate, createProcessTelemetryContext, createUniqueNamespace, dumpObj, eventOff, eventOn, findAllScripts, generateW3CId, getDocument, getExceptionName, getHistory, getLocation, getWindow, hasHistory, hasWindow, isFunction, isNullOrUndefined, isString, isUndefined, mergeEvtNamespace, onConfigChange, safeGetCookieMgr, strUndefined, throwError } from \"@microsoft/applicationinsights-core-js\";\r\nimport { isArray, isError, objDeepFreeze, objDefine, scheduleTimeout, strIndexOf } from \"@nevware21/ts-utils\";\r\nimport { _DYN_ADD_TELEMETRY_INITIA7, _DYN_AUTO_EXCEPTION_INSTR9, _DYN_AUTO_TRACK_PAGE_VISI10, _DYN_AUTO_UNHANDLED_PROMI14, _DYN_COLUMN_NUMBER, _DYN_CORE, _DYN_DATA_TYPE, _DYN_DIAG_LOG, _DYN_DURATION, _DYN_ENABLE_AUTO_ROUTE_TR12, _DYN_ENABLE_UNHANDLED_PRO13, _DYN_ENVELOPE_TYPE, _DYN_ERROR, _DYN_HREF, _DYN_IS_BROWSER_LINK_TRAC11, _DYN_IS_STORAGE_USE_DISAB0, _DYN_LENGTH, _DYN_LINE_NUMBER, _DYN_OVERRIDE_PAGE_VIEW_D8, _DYN_POPULATE_PAGE_VIEW_P4, _DYN_PROPERTIES, _DYN_SEND_EXCEPTION_INTER5, _DYN_SEND_PAGE_VIEW_INTER2, _DYN_SEND_PAGE_VIEW_PERFO3, _DYN_START_TIME, _DYN_TO_STRING, _DYN_TRACK, _DYN_TRACK_PAGE_VIEW, _DYN_TRACK_PREVIOUS_PAGE_1, _DYN__ADD_HOOK, _DYN__CREATE_AUTO_EXCEPTI6 } from \"../__DynamicConstants\";\r\nimport { PageViewManager } from \"./Telemetry/PageViewManager\";\r\nimport { PageViewPerformanceManager } from \"./Telemetry/PageViewPerformanceManager\";\r\nimport { PageVisitTimeManager } from \"./Telemetry/PageVisitTimeManager\";\r\nimport { Timing } from \"./Timing\";\r\nvar strEvent = \"event\";\r\nfunction _dispatchEvent(target, evnt) {\r\n if (target && target.dispatchEvent && evnt) {\r\n target.dispatchEvent(evnt);\r\n }\r\n}\r\nfunction _getReason(error) {\r\n if (error && error.reason) {\r\n var reason = error.reason;\r\n if (!isString(reason) && isFunction(reason[_DYN_TO_STRING /* @min:%2etoString */])) {\r\n return reason[_DYN_TO_STRING /* @min:%2etoString */]();\r\n }\r\n return dumpObj(reason);\r\n }\r\n // Pass the original object down which will eventually get evaluated for any message or description\r\n return error || \"\";\r\n}\r\nvar MinMilliSeconds = 60000;\r\nvar defaultValues = objDeepFreeze((_a = {\r\n sessionRenewalMs: cfgDfSet(_chkConfigMilliseconds, 30 * 60 * 1000),\r\n sessionExpirationMs: cfgDfSet(_chkConfigMilliseconds, 24 * 60 * 60 * 1000),\r\n disableExceptionTracking: cfgDfBoolean()\r\n },\r\n _a[_DYN_AUTO_TRACK_PAGE_VISI10 /* @min:autoTrackPageVisitTime */] = cfgDfBoolean(),\r\n _a[_DYN_OVERRIDE_PAGE_VIEW_D8 /* @min:overridePageViewDuration */] = cfgDfBoolean(),\r\n _a[_DYN_ENABLE_UNHANDLED_PRO13 /* @min:enableUnhandledPromiseRejectionTracking */] = cfgDfBoolean(),\r\n _a[_DYN_AUTO_UNHANDLED_PROMI14 /* @min:autoUnhandledPromiseInstrumented */] = false,\r\n _a.samplingPercentage = cfgDfValidate(_chkSampling, 100),\r\n _a[_DYN_IS_STORAGE_USE_DISAB0 /* @min:isStorageUseDisabled */] = cfgDfBoolean(),\r\n _a[_DYN_IS_BROWSER_LINK_TRAC11 /* @min:isBrowserLinkTrackingEnabled */] = cfgDfBoolean(),\r\n _a[_DYN_ENABLE_AUTO_ROUTE_TR12 /* @min:enableAutoRouteTracking */] = cfgDfBoolean(),\r\n _a.namePrefix = cfgDfString(),\r\n _a.enableDebug = cfgDfBoolean(),\r\n _a.disableFlushOnBeforeUnload = cfgDfBoolean(),\r\n _a.disableFlushOnUnload = cfgDfBoolean(false, \"disableFlushOnBeforeUnload\"),\r\n _a.expCfg = cfgDfMerge({ inclScripts: false, expLog: undefined, maxLogs: 50 }),\r\n _a));\r\nfunction _chkConfigMilliseconds(value, defValue) {\r\n value = value || defValue;\r\n if (value < MinMilliSeconds) {\r\n value = MinMilliSeconds;\r\n }\r\n return +value;\r\n}\r\nfunction _chkSampling(value) {\r\n return !isNaN(value) && value > 0 && value <= 100;\r\n}\r\nfunction _updateStorageUsage(extConfig) {\r\n // Not resetting the storage usage as someone may have manually called utlDisableStorage, so this will only\r\n // reset based if the configuration option is provided\r\n if (!isUndefined(extConfig[_DYN_IS_STORAGE_USE_DISAB0 /* @min:%2eisStorageUseDisabled */])) {\r\n if (extConfig[_DYN_IS_STORAGE_USE_DISAB0 /* @min:%2eisStorageUseDisabled */]) {\r\n utlDisableStorage();\r\n }\r\n else {\r\n utlEnableStorage();\r\n }\r\n }\r\n}\r\nvar AnalyticsPlugin = /** @class */ (function (_super) {\r\n __extends(AnalyticsPlugin, _super);\r\n function AnalyticsPlugin() {\r\n var _this = _super.call(this) || this;\r\n _this.identifier = AnalyticsPluginIdentifier; // do not change name or priority\r\n _this.priority = 180; // take from reserved priority range 100- 200\r\n _this.autoRoutePVDelay = 500; // ms; Time to wait after a route change before triggering a pageview to allow DOM changes to take place\r\n var _eventTracking;\r\n var _pageTracking;\r\n var _pageViewManager;\r\n var _pageViewPerformanceManager;\r\n var _pageVisitTimeManager;\r\n var _preInitTelemetryInitializers;\r\n var _isBrowserLinkTrackingEnabled;\r\n var _browserLinkInitializerAdded;\r\n var _enableAutoRouteTracking;\r\n var _historyListenerAdded;\r\n var _disableExceptionTracking;\r\n var _autoExceptionInstrumented;\r\n var _enableUnhandledPromiseRejectionTracking;\r\n var _autoUnhandledPromiseInstrumented;\r\n var _extConfig;\r\n var _autoTrackPageVisitTime;\r\n var _expCfg;\r\n // Counts number of trackAjax invocations.\r\n // By default we only monitor X ajax call per view to avoid too much load.\r\n // Default value is set in config.\r\n // This counter keeps increasing even after the limit is reached.\r\n var _trackAjaxAttempts = 0;\r\n // array with max length of 2 that store current url and previous url for SPA page route change trackPageview use.\r\n var _prevUri; // Assigned in the constructor\r\n var _currUri;\r\n var _evtNamespace;\r\n // For testing error hooks only\r\n var _errorHookCnt;\r\n dynamicProto(AnalyticsPlugin, _this, function (_self, _base) {\r\n var _addHook = _base[_DYN__ADD_HOOK /* @min:%2e_addHook */];\r\n _initDefaults();\r\n _self.getCookieMgr = function () {\r\n return safeGetCookieMgr(_self[_DYN_CORE /* @min:%2ecore */]);\r\n };\r\n _self.processTelemetry = function (env, itemCtx) {\r\n _self.processNext(env, itemCtx);\r\n };\r\n _self.trackEvent = function (event, customProperties) {\r\n try {\r\n var telemetryItem = createTelemetryItem(event, EventTelemetry[_DYN_DATA_TYPE /* @min:%2edataType */], EventTelemetry[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), customProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n }\r\n catch (e) {\r\n _throwInternal(2 /* eLoggingSeverity.WARNING */, 39 /* _eInternalMessageId.TrackTraceFailed */, \"trackTrace failed, trace will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * Start timing an extended event. Call `stopTrackEvent` to log the event when it ends.\r\n * @param name - A string that identifies this event uniquely within the document.\r\n */\r\n _self.startTrackEvent = function (name) {\r\n try {\r\n _eventTracking.start(name);\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 29 /* _eInternalMessageId.StartTrackEventFailed */, \"startTrackEvent failed, event will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * Log an extended event that you started timing with `startTrackEvent`.\r\n * @param name - The string you used to identify this event in `startTrackEvent`.\r\n * @param properties - map[string, string] - additional data used to filter events and metrics in the portal. Defaults to empty.\r\n * @param measurements - map[string, number] - metrics associated with this event, displayed in Metrics Explorer on the portal. Defaults to empty.\r\n */\r\n _self.stopTrackEvent = function (name, properties, measurements) {\r\n try {\r\n _eventTracking.stop(name, undefined, properties, measurements);\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 30 /* _eInternalMessageId.StopTrackEventFailed */, \"stopTrackEvent failed, event will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * @description Log a diagnostic message\r\n * @param trace - the trace message\r\n * @param customProperties - Additional custom properties to include in the event\r\n */\r\n _self.trackTrace = function (trace, customProperties) {\r\n try {\r\n var telemetryItem = createTelemetryItem(trace, Trace[_DYN_DATA_TYPE /* @min:%2edataType */], Trace[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), customProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n }\r\n catch (e) {\r\n _throwInternal(2 /* eLoggingSeverity.WARNING */, 39 /* _eInternalMessageId.TrackTraceFailed */, \"trackTrace failed, trace will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * @description Log a numeric value that is not associated with a specific event. Typically\r\n * used to send regular reports of performance indicators. To send single measurement, just\r\n * use the name and average fields of {@link IMetricTelemetry}. If you take measurements\r\n * frequently, you can reduce the telemetry bandwidth by aggregating multiple measurements\r\n * and sending the resulting average at intervals\r\n * @param metric - input object argument. Only name and average are mandatory.\r\n * @param } customProperties additional data used to filter metrics in the\r\n * portal. Defaults to empty.\r\n */\r\n _self.trackMetric = function (metric, customProperties) {\r\n try {\r\n var telemetryItem = createTelemetryItem(metric, Metric[_DYN_DATA_TYPE /* @min:%2edataType */], Metric[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), customProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 36 /* _eInternalMessageId.TrackMetricFailed */, \"trackMetric failed, metric will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * Logs that a page or other item was viewed.\r\n * @param IPageViewTelemetry - The string you used as the name in startTrackPage. Defaults to the document title.\r\n * @param customProperties - Additional data used to filter events and metrics. Defaults to empty.\r\n * If a user wants to provide duration for pageLoad, it'll have to be in pageView.properties.duration\r\n */\r\n _self[_DYN_TRACK_PAGE_VIEW /* @min:%2etrackPageView */] = function (pageView, customProperties) {\r\n try {\r\n var inPv = pageView || {};\r\n _pageViewManager[_DYN_TRACK_PAGE_VIEW /* @min:%2etrackPageView */](inPv, __assign(__assign(__assign({}, inPv.properties), inPv.measurements), customProperties));\r\n if (_autoTrackPageVisitTime) {\r\n _pageVisitTimeManager[_DYN_TRACK_PREVIOUS_PAGE_1 /* @min:%2etrackPreviousPageVisit */](inPv.name, inPv.uri);\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 37 /* _eInternalMessageId.TrackPVFailed */, \"trackPageView failed, page view will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * Create a page view telemetry item and send it to the SDK pipeline through the core.track API\r\n * @param pageView - Page view item to be sent\r\n * @param properties - Custom properties (Part C) that a user can add to the telemetry item\r\n * @param systemProperties - System level properties (Part A) that a user can add to the telemetry item\r\n */\r\n _self[_DYN_SEND_PAGE_VIEW_INTER2 /* @min:%2esendPageViewInternal */] = function (pageView, properties, systemProperties) {\r\n var doc = getDocument();\r\n if (doc) {\r\n pageView.refUri = pageView.refUri === undefined ? doc.referrer : pageView.refUri;\r\n }\r\n if (isNullOrUndefined(pageView[_DYN_START_TIME /* @min:%2estartTime */])) {\r\n // calculate the start time manually\r\n var duration = ((properties || pageView[_DYN_PROPERTIES /* @min:%2eproperties */] || {})[_DYN_DURATION /* @min:%2eduration */] || 0);\r\n pageView[_DYN_START_TIME /* @min:%2estartTime */] = new Date(new Date().getTime() - duration);\r\n }\r\n var telemetryItem = createTelemetryItem(pageView, PageView[_DYN_DATA_TYPE /* @min:%2edataType */], PageView[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), properties, systemProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n // reset ajaxes counter\r\n _trackAjaxAttempts = 0;\r\n };\r\n /**\r\n * @ignore INTERNAL ONLY\r\n * @param pageViewPerformance\r\n * @param properties\r\n */\r\n _self[_DYN_SEND_PAGE_VIEW_PERFO3 /* @min:%2esendPageViewPerformanceInternal */] = function (pageViewPerformance, properties, systemProperties) {\r\n var telemetryItem = createTelemetryItem(pageViewPerformance, PageViewPerformance[_DYN_DATA_TYPE /* @min:%2edataType */], PageViewPerformance[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), properties, systemProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n };\r\n /**\r\n * Send browser performance metrics.\r\n * @param pageViewPerformance\r\n * @param customProperties\r\n */\r\n _self.trackPageViewPerformance = function (pageViewPerformance, customProperties) {\r\n var inPvp = pageViewPerformance || {};\r\n try {\r\n _pageViewPerformanceManager[_DYN_POPULATE_PAGE_VIEW_P4 /* @min:%2epopulatePageViewPerformanceEvent */](inPvp);\r\n _self[_DYN_SEND_PAGE_VIEW_PERFO3 /* @min:%2esendPageViewPerformanceInternal */](inPvp, customProperties);\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 37 /* _eInternalMessageId.TrackPVFailed */, \"trackPageViewPerformance failed, page view will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * Starts the timer for tracking a page load time. Use this instead of `trackPageView` if you want to control when the page view timer starts and stops,\r\n * but don't want to calculate the duration yourself. This method doesn't send any telemetry. Call `stopTrackPage` to log the end of the page view\r\n * and send the event.\r\n * @param name - A string that idenfities this item, unique within this HTML document. Defaults to the document title.\r\n */\r\n _self.startTrackPage = function (name) {\r\n try {\r\n if (typeof name !== \"string\") {\r\n var doc = getDocument();\r\n name = doc && doc.title || \"\";\r\n }\r\n _pageTracking.start(name);\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 31 /* _eInternalMessageId.StartTrackFailed */, \"startTrackPage failed, page view may not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * Stops the timer that was started by calling `startTrackPage` and sends the pageview load time telemetry with the specified properties and measurements.\r\n * The duration of the page view will be the time between calling `startTrackPage` and `stopTrackPage`.\r\n * @param name - The string you used as the name in startTrackPage. Defaults to the document title.\r\n * @param url - String - a relative or absolute URL that identifies the page or other item. Defaults to the window location.\r\n * @param properties - map[string, string] - additional data used to filter pages and metrics in the portal. Defaults to empty.\r\n * @param measurements - map[string, number] - metrics associated with this page, displayed in Metrics Explorer on the portal. Defaults to empty.\r\n */\r\n _self.stopTrackPage = function (name, url, properties, measurement) {\r\n try {\r\n if (typeof name !== \"string\") {\r\n var doc = getDocument();\r\n name = doc && doc.title || \"\";\r\n }\r\n if (typeof url !== \"string\") {\r\n var loc = getLocation();\r\n url = loc && loc[_DYN_HREF /* @min:%2ehref */] || \"\";\r\n }\r\n _pageTracking.stop(name, url, properties, measurement);\r\n if (_autoTrackPageVisitTime) {\r\n _pageVisitTimeManager[_DYN_TRACK_PREVIOUS_PAGE_1 /* @min:%2etrackPreviousPageVisit */](name, url);\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 32 /* _eInternalMessageId.StopTrackFailed */, \"stopTrackPage failed, page view will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * @ignore INTERNAL ONLY\r\n * @param exception\r\n * @param properties\r\n * @param systemProperties\r\n */\r\n _self[_DYN_SEND_EXCEPTION_INTER5 /* @min:%2esendExceptionInternal */] = function (exception, customProperties, systemProperties) {\r\n // Adding additional edge cases to handle\r\n // - Not passing anything (null / undefined)\r\n var theError = (exception && (exception.exception || exception[_DYN_ERROR /* @min:%2eerror */])) ||\r\n // - Handle someone calling trackException based of v1 API where the exception was the Error\r\n isError(exception) && exception ||\r\n // - Handles no error being defined and instead of creating a new Error() instance attempt to map so any stacktrace\r\n // is preserved and does not list ApplicationInsights code as the source\r\n { name: (exception && typeof exception), message: exception || strNotSpecified };\r\n // If no exception object was passed assign to an empty object to avoid internal exceptions\r\n exception = exception || {};\r\n var exceptionPartB = new Exception(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), theError, exception[_DYN_PROPERTIES /* @min:%2eproperties */] || customProperties, exception.measurements, exception.severityLevel, exception.id).toInterface();\r\n var doc = getDocument();\r\n if (doc && (_expCfg === null || _expCfg === void 0 ? void 0 : _expCfg.inclScripts)) {\r\n var scriptsInfo = findAllScripts(doc);\r\n exceptionPartB[_DYN_PROPERTIES /* @min:%2eproperties */][\"exceptionScripts\"] = JSON.stringify(scriptsInfo);\r\n }\r\n if (_expCfg === null || _expCfg === void 0 ? void 0 : _expCfg.expLog) {\r\n var logs = _expCfg.expLog();\r\n if (logs && logs.logs && isArray(logs.logs)) {\r\n exceptionPartB[_DYN_PROPERTIES /* @min:%2eproperties */][\"exceptionLog\"] = logs.logs.slice(0, _expCfg.maxLogs).join(\"\\n\");\r\n }\r\n }\r\n var telemetryItem = createTelemetryItem(exceptionPartB, Exception[_DYN_DATA_TYPE /* @min:%2edataType */], Exception[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), customProperties, systemProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n };\r\n /**\r\n * Log an exception you have caught.\r\n *\r\n * @param exception - Object which contains exception to be sent\r\n * @param } customProperties Additional data used to filter pages and metrics in the portal. Defaults to empty.\r\n *\r\n * Any property of type double will be considered a measurement, and will be treated by Application Insights as a metric.\r\n */\r\n _self.trackException = function (exception, customProperties) {\r\n if (exception && !exception.exception && exception[_DYN_ERROR /* @min:%2eerror */]) {\r\n exception.exception = exception[_DYN_ERROR /* @min:%2eerror */];\r\n }\r\n try {\r\n _self[_DYN_SEND_EXCEPTION_INTER5 /* @min:%2esendExceptionInternal */](exception, customProperties);\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 35 /* _eInternalMessageId.TrackExceptionFailed */, \"trackException failed, exception will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * @description Custom error handler for Application Insights Analytics\r\n * @param exception\r\n */\r\n _self._onerror = function (exception) {\r\n var error = exception && exception[_DYN_ERROR /* @min:%2eerror */];\r\n var evt = exception && exception.evt;\r\n try {\r\n if (!evt) {\r\n var _window = getWindow();\r\n if (_window) {\r\n evt = _window[strEvent];\r\n }\r\n }\r\n var url = (exception && exception.url) || (getDocument() || {}).URL;\r\n // If no error source is provided assume the default window.onerror handler\r\n var errorSrc = exception.errorSrc || \"window.onerror@\" + url + \":\" + (exception[_DYN_LINE_NUMBER /* @min:%2elineNumber */] || 0) + \":\" + (exception[_DYN_COLUMN_NUMBER /* @min:%2ecolumnNumber */] || 0);\r\n var properties = {\r\n errorSrc: errorSrc,\r\n url: url,\r\n lineNumber: exception[_DYN_LINE_NUMBER /* @min:%2elineNumber */] || 0,\r\n columnNumber: exception[_DYN_COLUMN_NUMBER /* @min:%2ecolumnNumber */] || 0,\r\n message: exception.message\r\n };\r\n if (isCrossOriginError(exception.message, exception.url, exception.lineNumber, exception.columnNumber, exception[_DYN_ERROR /* @min:%2eerror */])) {\r\n _sendCORSException(Exception[_DYN__CREATE_AUTO_EXCEPTI6 /* @min:%2eCreateAutoException */](\"Script error: The browser's same-origin policy prevents us from getting the details of this exception. Consider using the 'crossorigin' attribute.\", url, exception[_DYN_LINE_NUMBER /* @min:%2elineNumber */] || 0, exception[_DYN_COLUMN_NUMBER /* @min:%2ecolumnNumber */] || 0, error, evt, null, errorSrc), properties);\r\n }\r\n else {\r\n if (!exception.errorSrc) {\r\n exception.errorSrc = errorSrc;\r\n }\r\n _self.trackException({ exception: exception, severityLevel: 3 /* eSeverityLevel.Error */ }, properties);\r\n }\r\n }\r\n catch (e) {\r\n var errorString = error ? (error.name + \", \" + error.message) : \"null\";\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 11 /* _eInternalMessageId.ExceptionWhileLoggingError */, \"_onError threw exception while logging error, error will not be collected: \"\r\n + getExceptionName(e), { exception: dumpObj(e), errorString: errorString });\r\n }\r\n };\r\n _self[_DYN_ADD_TELEMETRY_INITIA7 /* @min:%2eaddTelemetryInitializer */] = function (telemetryInitializer) {\r\n if (_self[_DYN_CORE /* @min:%2ecore */]) {\r\n // Just add to the core\r\n return _self[_DYN_CORE /* @min:%2ecore */][_DYN_ADD_TELEMETRY_INITIA7 /* @min:%2eaddTelemetryInitializer */](telemetryInitializer);\r\n }\r\n // Handle \"pre-initialization\" telemetry initializers (for backward compatibility)\r\n if (!_preInitTelemetryInitializers) {\r\n _preInitTelemetryInitializers = [];\r\n }\r\n _preInitTelemetryInitializers.push(telemetryInitializer);\r\n };\r\n _self.initialize = function (config, core, extensions, pluginChain) {\r\n if (_self.isInitialized()) {\r\n return;\r\n }\r\n if (isNullOrUndefined(core)) {\r\n throwError(\"Error initializing\");\r\n }\r\n _base.initialize(config, core, extensions, pluginChain);\r\n try {\r\n _evtNamespace = mergeEvtNamespace(createUniqueNamespace(_self.identifier), core.evtNamespace && core.evtNamespace());\r\n if (_preInitTelemetryInitializers) {\r\n arrForEach(_preInitTelemetryInitializers, function (initializer) {\r\n core[_DYN_ADD_TELEMETRY_INITIA7 /* @min:%2eaddTelemetryInitializer */](initializer);\r\n });\r\n _preInitTelemetryInitializers = null;\r\n }\r\n _populateDefaults(config);\r\n _pageViewPerformanceManager = new PageViewPerformanceManager(_self[_DYN_CORE /* @min:%2ecore */]);\r\n _pageViewManager = new PageViewManager(_self, _extConfig.overridePageViewDuration, _self[_DYN_CORE /* @min:%2ecore */], _pageViewPerformanceManager);\r\n _pageVisitTimeManager = new PageVisitTimeManager(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), function (pageName, pageUrl, pageVisitTime) { return trackPageVisitTime(pageName, pageUrl, pageVisitTime); });\r\n _eventTracking = new Timing(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), \"trackEvent\");\r\n _eventTracking.action =\r\n function (name, url, duration, properties, measurements) {\r\n if (!properties) {\r\n properties = {};\r\n }\r\n if (!measurements) {\r\n measurements = {};\r\n }\r\n properties.duration = duration[_DYN_TO_STRING /* @min:%2etoString */]();\r\n _self.trackEvent({ name: name, properties: properties, measurements: measurements });\r\n };\r\n // initialize page view timing\r\n _pageTracking = new Timing(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), \"trackPageView\");\r\n _pageTracking.action = function (name, url, duration, properties, measurements) {\r\n // duration must be a custom property in order for the collector to extract it\r\n if (isNullOrUndefined(properties)) {\r\n properties = {};\r\n }\r\n properties.duration = duration[_DYN_TO_STRING /* @min:%2etoString */]();\r\n var pageViewItem = {\r\n name: name,\r\n uri: url,\r\n properties: properties,\r\n measurements: measurements\r\n };\r\n _self[_DYN_SEND_PAGE_VIEW_INTER2 /* @min:%2esendPageViewInternal */](pageViewItem, properties);\r\n };\r\n if (hasWindow()) {\r\n _updateExceptionTracking();\r\n _updateLocationChange();\r\n }\r\n }\r\n catch (e) {\r\n // resetting the initialized state because of failure\r\n _self.setInitialized(false);\r\n throw e;\r\n }\r\n };\r\n _self._doTeardown = function (unloadCtx, unloadState) {\r\n _pageViewManager && _pageViewManager.teardown(unloadCtx, unloadState);\r\n // Just register to remove all events associated with this namespace\r\n eventOff(window, null, null, _evtNamespace);\r\n _initDefaults();\r\n };\r\n _self[\"_getDbgPlgTargets\"] = function () {\r\n return [_errorHookCnt, _autoExceptionInstrumented];\r\n };\r\n function _populateDefaults(config) {\r\n // it is used for 1DS as well, so config type should be IConfiguration only\r\n var identifier = _self.identifier;\r\n var core = _self[_DYN_CORE /* @min:%2ecore */];\r\n _self[_DYN__ADD_HOOK /* @min:%2e_addHook */](onConfigChange(config, function () {\r\n var ctx = createProcessTelemetryContext(null, config, core);\r\n _extConfig = ctx.getExtCfg(identifier, defaultValues);\r\n // make sure auto exception is instrumented only once and it won't be overriden by the following config changes\r\n _autoExceptionInstrumented = _autoExceptionInstrumented || config[_DYN_AUTO_EXCEPTION_INSTR9 /* @min:%2eautoExceptionInstrumented */] || _extConfig[_DYN_AUTO_EXCEPTION_INSTR9 /* @min:%2eautoExceptionInstrumented */];\r\n _expCfg = _extConfig.expCfg;\r\n _autoTrackPageVisitTime = _extConfig[_DYN_AUTO_TRACK_PAGE_VISI10 /* @min:%2eautoTrackPageVisitTime */];\r\n if (config.storagePrefix) {\r\n utlSetStoragePrefix(config.storagePrefix);\r\n }\r\n _updateStorageUsage(_extConfig);\r\n // _updateBrowserLinkTracking\r\n _isBrowserLinkTrackingEnabled = _extConfig[_DYN_IS_BROWSER_LINK_TRAC11 /* @min:%2eisBrowserLinkTrackingEnabled */];\r\n _addDefaultTelemetryInitializers();\r\n }));\r\n }\r\n /**\r\n * Log a page visit time\r\n * @param pageName - Name of page\r\n * @param pageVisitDuration - Duration of visit to the page in milliseconds\r\n */\r\n function trackPageVisitTime(pageName, pageUrl, pageVisitTime) {\r\n var properties = { PageName: pageName, PageUrl: pageUrl };\r\n _self.trackMetric({\r\n name: \"PageVisitTime\",\r\n average: pageVisitTime,\r\n max: pageVisitTime,\r\n min: pageVisitTime,\r\n sampleCount: 1\r\n }, properties);\r\n }\r\n function _addDefaultTelemetryInitializers() {\r\n if (!_browserLinkInitializerAdded && _isBrowserLinkTrackingEnabled) {\r\n var browserLinkPaths_1 = [\"/browserLinkSignalR/\", \"/__browserLink/\"];\r\n var dropBrowserLinkRequests = function (envelope) {\r\n if (_isBrowserLinkTrackingEnabled && envelope.baseType === RemoteDependencyData[_DYN_DATA_TYPE /* @min:%2edataType */]) {\r\n var remoteData = envelope.baseData;\r\n if (remoteData) {\r\n for (var i = 0; i < browserLinkPaths_1[_DYN_LENGTH /* @min:%2elength */]; i++) {\r\n if (remoteData.target && strIndexOf(remoteData.target, browserLinkPaths_1[i]) >= 0) {\r\n return false;\r\n }\r\n }\r\n }\r\n }\r\n return true;\r\n };\r\n _self[_DYN__ADD_HOOK /* @min:%2e_addHook */](_self[_DYN_ADD_TELEMETRY_INITIA7 /* @min:%2eaddTelemetryInitializer */](dropBrowserLinkRequests));\r\n _browserLinkInitializerAdded = true;\r\n }\r\n }\r\n function _sendCORSException(exception, properties) {\r\n var telemetryItem = createTelemetryItem(exception, Exception[_DYN_DATA_TYPE /* @min:%2edataType */], Exception[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), properties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n }\r\n function _updateExceptionTracking() {\r\n var _window = getWindow();\r\n var locn = getLocation(true);\r\n _self[_DYN__ADD_HOOK /* @min:%2e_addHook */](onConfigChange(_extConfig, function () {\r\n _disableExceptionTracking = _extConfig.disableExceptionTracking;\r\n if (!_disableExceptionTracking && !_autoExceptionInstrumented && !_extConfig[_DYN_AUTO_EXCEPTION_INSTR9 /* @min:%2eautoExceptionInstrumented */]) {\r\n // We want to enable exception auto collection and it has not been done so yet\r\n _addHook(InstrumentEvent(_window, \"onerror\", {\r\n ns: _evtNamespace,\r\n rsp: function (callDetails, message, url, lineNumber, columnNumber, error) {\r\n if (!_disableExceptionTracking && callDetails.rslt !== true) {\r\n _self._onerror(Exception[_DYN__CREATE_AUTO_EXCEPTI6 /* @min:%2eCreateAutoException */](message, url, lineNumber, columnNumber, error, callDetails.evt));\r\n }\r\n }\r\n }, false));\r\n _errorHookCnt++;\r\n _autoExceptionInstrumented = true;\r\n }\r\n }));\r\n _addUnhandledPromiseRejectionTracking(_window, locn);\r\n }\r\n function _updateLocationChange() {\r\n var win = getWindow();\r\n var locn = getLocation(true);\r\n _self[_DYN__ADD_HOOK /* @min:%2e_addHook */](onConfigChange(_extConfig, function () {\r\n _enableAutoRouteTracking = _extConfig[_DYN_ENABLE_AUTO_ROUTE_TR12 /* @min:%2eenableAutoRouteTracking */] === true;\r\n /**\r\n * Create a custom \"locationchange\" event which is triggered each time the history object is changed\r\n */\r\n if (win && _enableAutoRouteTracking && !_historyListenerAdded && hasHistory()) {\r\n var _history = getHistory();\r\n if (isFunction(_history.pushState) && isFunction(_history.replaceState) && typeof Event !== strUndefined) {\r\n _addHistoryListener(win, _history, locn);\r\n }\r\n }\r\n }));\r\n }\r\n function _getDistributedTraceCtx() {\r\n var distributedTraceCtx = null;\r\n if (_self[_DYN_CORE /* @min:%2ecore */] && _self[_DYN_CORE /* @min:%2ecore */].getTraceCtx) {\r\n distributedTraceCtx = _self[_DYN_CORE /* @min:%2ecore */].getTraceCtx(false);\r\n }\r\n if (!distributedTraceCtx) {\r\n // Fallback when using an older Core and PropertiesPlugin\r\n var properties = _self[_DYN_CORE /* @min:%2ecore */].getPlugin(PropertiesPluginIdentifier);\r\n if (properties) {\r\n var context = properties.plugin.context;\r\n if (context) {\r\n distributedTraceCtx = createDistributedTraceContextFromTrace(context.telemetryTrace);\r\n }\r\n }\r\n }\r\n return distributedTraceCtx;\r\n }\r\n /**\r\n * Create a custom \"locationchange\" event which is triggered each time the history object is changed\r\n */\r\n function _addHistoryListener(win, history, locn) {\r\n if (_historyListenerAdded) {\r\n return;\r\n }\r\n // Name Prefix is only referenced during the initial initialization and cannot be changed afterwards\r\n var namePrefix = _extConfig.namePrefix || \"\";\r\n function _popstateHandler() {\r\n if (_enableAutoRouteTracking) {\r\n _dispatchEvent(win, createDomEvent(namePrefix + \"locationchange\"));\r\n }\r\n }\r\n function _locationChangeHandler() {\r\n // We always track the changes (if the handler is installed) to handle the feature being disabled between location changes\r\n if (_currUri) {\r\n _prevUri = _currUri;\r\n _currUri = locn && locn[_DYN_HREF /* @min:%2ehref */] || \"\";\r\n }\r\n else {\r\n _currUri = locn && locn[_DYN_HREF /* @min:%2ehref */] || \"\";\r\n }\r\n if (_enableAutoRouteTracking) {\r\n var distributedTraceCtx = _getDistributedTraceCtx();\r\n if (distributedTraceCtx) {\r\n distributedTraceCtx.setTraceId(generateW3CId());\r\n var traceLocationName = \"_unknown_\";\r\n if (locn && locn.pathname) {\r\n traceLocationName = locn.pathname + (locn.hash || \"\");\r\n }\r\n // This populates the ai.operation.name which has a maximum size of 1024 so we need to sanitize it\r\n distributedTraceCtx.setName(dataSanitizeString(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), traceLocationName));\r\n }\r\n scheduleTimeout((function (uri) {\r\n // todo: override start time so that it is not affected by autoRoutePVDelay\r\n _self[_DYN_TRACK_PAGE_VIEW /* @min:%2etrackPageView */]({ refUri: uri, properties: { duration: 0 } }); // SPA route change loading durations are undefined, so send 0\r\n }).bind(_self, _prevUri), _self.autoRoutePVDelay);\r\n }\r\n }\r\n _addHook(InstrumentEvent(history, \"pushState\", {\r\n ns: _evtNamespace,\r\n rsp: function () {\r\n if (_enableAutoRouteTracking) {\r\n _dispatchEvent(win, createDomEvent(namePrefix + \"pushState\"));\r\n _dispatchEvent(win, createDomEvent(namePrefix + \"locationchange\"));\r\n }\r\n }\r\n }, true));\r\n _addHook(InstrumentEvent(history, \"replaceState\", {\r\n ns: _evtNamespace,\r\n rsp: function () {\r\n if (_enableAutoRouteTracking) {\r\n _dispatchEvent(win, createDomEvent(namePrefix + \"replaceState\"));\r\n _dispatchEvent(win, createDomEvent(namePrefix + \"locationchange\"));\r\n }\r\n }\r\n }, true));\r\n eventOn(win, namePrefix + \"popstate\", _popstateHandler, _evtNamespace);\r\n eventOn(win, namePrefix + \"locationchange\", _locationChangeHandler, _evtNamespace);\r\n _historyListenerAdded = true;\r\n }\r\n function _addUnhandledPromiseRejectionTracking(_window, _location) {\r\n _self[_DYN__ADD_HOOK /* @min:%2e_addHook */](onConfigChange(_extConfig, function () {\r\n _enableUnhandledPromiseRejectionTracking = _extConfig[_DYN_ENABLE_UNHANDLED_PRO13 /* @min:%2eenableUnhandledPromiseRejectionTracking */] === true;\r\n _autoExceptionInstrumented = _autoExceptionInstrumented || _extConfig[_DYN_AUTO_UNHANDLED_PROMI14 /* @min:%2eautoUnhandledPromiseInstrumented */];\r\n if (_enableUnhandledPromiseRejectionTracking && !_autoUnhandledPromiseInstrumented) {\r\n // We want to enable exception auto collection and it has not been done so yet\r\n _addHook(InstrumentEvent(_window, \"onunhandledrejection\", {\r\n ns: _evtNamespace,\r\n rsp: function (callDetails, error) {\r\n if (_enableUnhandledPromiseRejectionTracking && callDetails.rslt !== true) { // handled could be typeof function\r\n _self._onerror(Exception[_DYN__CREATE_AUTO_EXCEPTI6 /* @min:%2eCreateAutoException */](_getReason(error), _location ? _location[_DYN_HREF /* @min:%2ehref */] : \"\", 0, 0, error, callDetails.evt));\r\n }\r\n }\r\n }, false));\r\n _errorHookCnt++;\r\n _extConfig[_DYN_AUTO_UNHANDLED_PROMI14 /* @min:%2eautoUnhandledPromiseInstrumented */] = _autoUnhandledPromiseInstrumented = true;\r\n }\r\n }));\r\n }\r\n /**\r\n * This method will throw exceptions in debug mode or attempt to log the error as a console warning.\r\n * @param severity - The severity of the log message\r\n * @param msgId - The log message.\r\n */\r\n function _throwInternal(severity, msgId, msg, properties, isUserAct) {\r\n _self[_DYN_DIAG_LOG /* @min:%2ediagLog */]().throwInternal(severity, msgId, msg, properties, isUserAct);\r\n }\r\n function _initDefaults() {\r\n _eventTracking = null;\r\n _pageTracking = null;\r\n _pageViewManager = null;\r\n _pageViewPerformanceManager = null;\r\n _pageVisitTimeManager = null;\r\n _preInitTelemetryInitializers = null;\r\n _isBrowserLinkTrackingEnabled = false;\r\n _browserLinkInitializerAdded = false;\r\n _enableAutoRouteTracking = false;\r\n _historyListenerAdded = false;\r\n _disableExceptionTracking = false;\r\n _autoExceptionInstrumented = false;\r\n _enableUnhandledPromiseRejectionTracking = false;\r\n _autoUnhandledPromiseInstrumented = false;\r\n _autoTrackPageVisitTime = false;\r\n // Counts number of trackAjax invocations.\r\n // By default we only monitor X ajax call per view to avoid too much load.\r\n // Default value is set in config.\r\n // This counter keeps increasing even after the limit is reached.\r\n _trackAjaxAttempts = 0;\r\n // array with max length of 2 that store current url and previous url for SPA page route change trackPageview use.\r\n var location = getLocation(true);\r\n _prevUri = location && location[_DYN_HREF /* @min:%2ehref */] || \"\";\r\n _currUri = null;\r\n _evtNamespace = null;\r\n _extConfig = null;\r\n _errorHookCnt = 0;\r\n // Define _self.config\r\n objDefine(_self, \"config\", {\r\n g: function () { return _extConfig; }\r\n });\r\n }\r\n // For backward compatibility\r\n objDefine(_self, \"_pageViewManager\", { g: function () { return _pageViewManager; } });\r\n objDefine(_self, \"_pageViewPerformanceManager\", { g: function () { return _pageViewPerformanceManager; } });\r\n objDefine(_self, \"_pageVisitTimeManager\", { g: function () { return _pageVisitTimeManager; } });\r\n objDefine(_self, \"_evtNamespace\", { g: function () { return \".\" + _evtNamespace; } });\r\n });\r\n return _this;\r\n }\r\n// Removed Stub for AnalyticsPlugin.prototype.getCookieMgr.\r\n// Removed Stub for AnalyticsPlugin.prototype.processTelemetry.\r\n// Removed Stub for AnalyticsPlugin.prototype.trackEvent.\r\n// Removed Stub for AnalyticsPlugin.prototype.startTrackEvent.\r\n// Removed Stub for AnalyticsPlugin.prototype.stopTrackEvent.\r\n// Removed Stub for AnalyticsPlugin.prototype.trackTrace.\r\n// Removed Stub for AnalyticsPlugin.prototype.trackMetric.\r\n// Removed Stub for AnalyticsPlugin.prototype.trackPageView.\r\n// Removed Stub for AnalyticsPlugin.prototype.sendPageViewInternal.\r\n// Removed Stub for AnalyticsPlugin.prototype.sendPageViewPerformanceInternal.\r\n// Removed Stub for AnalyticsPlugin.prototype.trackPageViewPerformance.\r\n// Removed Stub for AnalyticsPlugin.prototype.startTrackPage.\r\n// Removed Stub for AnalyticsPlugin.prototype.stopTrackPage.\r\n// Removed Stub for AnalyticsPlugin.prototype.sendExceptionInternal.\r\n// Removed Stub for AnalyticsPlugin.prototype.trackException.\r\n// Removed Stub for AnalyticsPlugin.prototype._onerror.\r\n// Removed Stub for AnalyticsPlugin.prototype.addTelemetryInitializer.\r\n// Removed Stub for AnalyticsPlugin.prototype.initialize.\r\n AnalyticsPlugin.Version = '3.3.6'; // Not currently used anywhere\r\n return AnalyticsPlugin;\r\n}(BaseTelemetryPlugin));\r\nexport { AnalyticsPlugin };\r\n//# sourceMappingURL=AnalyticsPlugin.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES5 which can result in a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_FEATURE_OPT_IN = \"featureOptIn\"; // Count: 4\r\nexport var _DYN_SCHEDULE_FETCH_TIMEO0 = \"scheduleFetchTimeout\"; // Count: 2\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { isNullOrUndefined, isObject, objExtend, objForEachKey, setValueByKey } from \"@nevware21/ts-utils\";\r\nimport { _DYN_FEATURE_OPT_IN } from \"./__DynamicConstants\";\r\n/**\r\n * Delete a config key in the given cfg, if the config key exists in nonOverrideConfigs and its value is set to true\r\n * @param cfg - cfg to modify\r\n * @param nonOverrideConfigs - nonOverrideConfigs\r\n * @param curLevel - cur config level, starting at 0\r\n * @param maxLevel - max config level\r\n * @returns new copy of modified configs\r\n */\r\nexport function replaceByNonOverrideCfg(cfg, nonOverrideConfigs, curLevel, maxLevel) {\r\n try {\r\n var exceedMaxLevel = curLevel > maxLevel;\r\n if (exceedMaxLevel) {\r\n cfg = null;\r\n }\r\n var curCfg_1 = curLevel == 0 ? objExtend({}, cfg) : cfg; // only copy cfg at the begining level\r\n if (curCfg_1 && nonOverrideConfigs && !exceedMaxLevel) {\r\n objForEachKey(curCfg_1, function (key) {\r\n var nonOverrideVal = nonOverrideConfigs[key];\r\n if (!!nonOverrideVal) {\r\n if (isObject(curCfg_1[key]) && isObject(nonOverrideVal)) {\r\n curCfg_1[key] = replaceByNonOverrideCfg(curCfg_1[key], nonOverrideVal, ++curLevel, maxLevel);\r\n }\r\n else {\r\n delete curCfg_1[key];\r\n }\r\n }\r\n });\r\n }\r\n return curCfg_1;\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n // if errors happen, do nothing\r\n return cfg;\r\n}\r\n// CDN Mode, value = B (CDN value = B)\r\n// |--------------------------------------------------------------------------|-----------|\r\n// | | none | disabled | enabled | forceOn | forceOff |\r\n// | ------------------ | ----------- | ----------- | ----------- | --------- | --------- |\r\n// | User Mode, value = A | none | none | disabled | enabled | enabled | disabled |\r\n// (user Value = A) | disabled | disabled | disabled | disabled | enabled | disabled |\r\n// | enabled | enabled | disabled | enabled | enabled | disabled |\r\n// | none(blockCdn) | none | none | none | none | none |\r\n// | disabled(blockCdn) | disabled | disabled | disabled | disabled | disabled |\r\n// | enabled(blockCdn) | enabled | enabled | enabled | enabled | enabled |\r\n// This matrix identifies how feature based overrides are selected (if present)\r\n// cdn Mode (cdn Value = B)\r\n// |---------------------------------------------------------------------------|\r\n// | | none | disabled | enabled | forceOn | forceOff |\r\n// | ------------------ | ---------| ---------| ---------| ---------|----------|\r\n// | User Mode | none | A | A | A || B | B || A | B || A |\r\n// (user Value = A) | disabled | A | A | A | B || A | B || A |\r\n// | enabled | A | A | A || B | B || A | B || A |\r\n// | none(blockCdn) | A | A | A | A | A |\r\n// | disabled(blockCdn) | A | A | A | A | A |\r\n// | enabled(blockCdn) | A | A | A | A | A |\r\n// Note:\r\n// Where the \"value\" is an object (map) of encoded key/values which will be used to override the real configuration\r\n// A = either the user supplied enable/disable value (via the `config.featureOptIn[name]`) or if not defined by the user the SDK defaults of the same.\r\n// B = The enable/disable value obtained from the CDN for the named feature\r\n// These are evaluated based on the above matrix to either\r\n// - A (Always the user/sdk value)\r\n// - B (Always the value from the CDN)\r\n// - A || B (If A is null or undefined use the value from the CDN (B) otherwise A)\r\n// - B || A (If B is null or undefined use the user/SDK value otherwise use the value from the CDN)\r\n//\r\n// The result of the value may also be null / undefined, which means there are no overrides to apply when the feature is enabled\r\nvar F = \"featureOptIn.\";\r\nvar M = \".mode\";\r\nvar ON = \".onCfg\";\r\nvar OFF = \".offCfg\";\r\nexport function resolveCdnFeatureCfg(field, cdnCfg, userOptInDetails) {\r\n var _a;\r\n // cdn conifg value\r\n if (!cdnCfg || !cdnCfg.enabled) {\r\n return null;\r\n }\r\n var cdnFt = (cdnCfg[_DYN_FEATURE_OPT_IN /* @min:%2efeatureOptIn */] || {})[field] || { mode: 1 /* CdnFeatureMode.none */ };\r\n var cdnM = cdnFt.mode;\r\n var cdnOnV = cdnFt.onCfg;\r\n var cdnOffV = cdnFt.offCfg;\r\n var userFt = (userOptInDetails || {})[field] || { mode: 2 /* FeatureOptInMode.disable */ }; // default user mode is disable\r\n var userM = userFt.mode;\r\n var userOnV = userFt.onCfg;\r\n var userOffV = userFt.offCfg;\r\n var blockCdn = !!userFt.blockCdnCfg;\r\n var mFld = F + field + M;\r\n var onFld = F + field + ON;\r\n var offFld = F + field + OFF;\r\n var mode = userM;\r\n var onV = userOnV;\r\n var offV = userOffV;\r\n if (!blockCdn) {\r\n if (cdnM === 4 /* CdnFeatureMode.forceOn */ || cdnM === 5 /* CdnFeatureMode.forceOff */) {\r\n mode = (cdnM == 4 /* CdnFeatureMode.forceOn */ ? 3 /* FeatureOptInMode.enable */ : 2 /* FeatureOptInMode.disable */);\r\n onV = cdnOnV || userOnV;\r\n offV = cdnOffV || userOffV;\r\n }\r\n else if (cdnM === 2 /* CdnFeatureMode.disable */ || userM === 2 /* FeatureOptInMode.disable */) {\r\n mode = 2 /* FeatureOptInMode.disable */;\r\n onV = userOnV || cdnOnV;\r\n offV = userOffV || cdnOffV;\r\n }\r\n else if (cdnM === 3 /* CdnFeatureMode.enable */) {\r\n mode = 3 /* FeatureOptInMode.enable */;\r\n onV = userOnV || cdnOnV;\r\n offV = userOffV || cdnOffV;\r\n }\r\n else if (cdnM === 1 /* CdnFeatureMode.none */ && userM === 1 /* FeatureOptInMode.none */) {\r\n mode = 1 /* FeatureOptInMode.none */;\r\n }\r\n }\r\n return _a = {},\r\n _a[mFld] = mode,\r\n _a[onFld] = onV,\r\n _a[offFld] = offV,\r\n _a;\r\n}\r\n// helper function to get cdn config with opt-in features\r\nexport function applyCdnfeatureCfg(cdnCfg, core) {\r\n try {\r\n if (!cdnCfg || !cdnCfg.enabled) {\r\n return null;\r\n }\r\n if (!cdnCfg[_DYN_FEATURE_OPT_IN /* @min:%2efeatureOptIn */]) {\r\n return cdnCfg.config;\r\n }\r\n var optInMap = cdnCfg[_DYN_FEATURE_OPT_IN /* @min:%2efeatureOptIn */];\r\n var cdnConfig_1 = cdnCfg.config || {};\r\n objForEachKey(optInMap, function (key) {\r\n var featureVal = resolveCdnFeatureCfg(key, cdnCfg, core.config[_DYN_FEATURE_OPT_IN /* @min:%2efeatureOptIn */]);\r\n if (!isNullOrUndefined(featureVal)) {\r\n objForEachKey(featureVal, function (config, val) {\r\n setValueByKey(cdnConfig_1, config, val);\r\n });\r\n _overrideCdnCfgByFeature(key, featureVal, cdnConfig_1);\r\n }\r\n });\r\n return cdnConfig_1;\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return null;\r\n}\r\nfunction _overrideCdnCfgByFeature(field, ftVal, config) {\r\n var mode = ftVal[F + field + M];\r\n var val = ftVal[F + field + ON];\r\n var dVal = ftVal[F + field + OFF];\r\n var target = null;\r\n if (mode === 3 /* FeatureOptInMode.enable */) {\r\n target = val;\r\n }\r\n if (mode === 2 /* FeatureOptInMode.disable */) {\r\n target = dVal;\r\n }\r\n if (target) {\r\n objForEachKey(target, function (key, cfg) {\r\n setValueByKey(config, key, cfg);\r\n });\r\n }\r\n}\r\n//# sourceMappingURL=CfgSyncHelperFuncs.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n/**\r\n* CfgSyncPlugin.ts\r\n* @copyright Microsoft 2018\r\n*/\r\nvar _a;\r\nimport { __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { DisabledPropertyName } from \"@microsoft/applicationinsights-common\";\r\nimport { BaseTelemetryPlugin, createProcessTelemetryContext, createUniqueNamespace, eventOff, eventOn, getGlobal, getJSON, isFetchSupported, isXhrSupported, mergeEvtNamespace, onConfigChange, sendCustomEvent } from \"@microsoft/applicationinsights-core-js\";\r\nimport { doAwaitResponse } from \"@nevware21/ts-async\";\r\nimport { isFunction, isNullOrUndefined, isPlainObject, objDeepFreeze, scheduleTimeout } from \"@nevware21/ts-utils\";\r\nimport { applyCdnfeatureCfg, replaceByNonOverrideCfg } from \"./CfgSyncHelperFuncs\";\r\nimport { _DYN_SCHEDULE_FETCH_TIMEO0 } from \"./__DynamicConstants\";\r\nvar EVENT_NAME = \"ai_cfgsync\";\r\nvar STR_GET_METHOD = \"GET\";\r\nvar FETCH_TIMEOUT = 1800000; // 30 minutes\r\nvar udfVal = undefined;\r\nvar defaultNonOverrideCfg = { instrumentationKey: true, connectionString: true, endpointUrl: true };\r\nvar _defaultConfig = objDeepFreeze((_a = {\r\n syncMode: 1 /* ICfgSyncMode.Broadcast */,\r\n blkCdnCfg: udfVal,\r\n customEvtName: udfVal,\r\n cfgUrl: udfVal,\r\n overrideSyncFn: udfVal,\r\n overrideFetchFn: udfVal,\r\n onCfgChangeReceive: udfVal\r\n },\r\n _a[_DYN_SCHEDULE_FETCH_TIMEO0 /* @min:scheduleFetchTimeout */] = FETCH_TIMEOUT,\r\n _a.nonOverrideConfigs = defaultNonOverrideCfg,\r\n _a.enableAjax = false,\r\n _a));\r\nvar CfgSyncPlugin = /** @class */ (function (_super) {\r\n __extends(CfgSyncPlugin, _super);\r\n function CfgSyncPlugin() {\r\n var _this = _super.call(this) || this;\r\n _this.priority = 198;\r\n _this.identifier = \"AppInsightsCfgSyncPlugin\";\r\n var _extensionConfig;\r\n var _mainConfig; // throttle config should be wrapped in IConfiguration\r\n var _evtName;\r\n var _evtNamespace;\r\n var _cfgUrl;\r\n var _timeoutHandle;\r\n var _receiveChanges;\r\n var _broadcastChanges;\r\n var _blkCdnCfg;\r\n var _fetchTimeout;\r\n var _retryCnt;\r\n var _onCfgChangeReceive;\r\n var _nonOverrideConfigs;\r\n var _fetchFn;\r\n var _overrideFetchFn;\r\n var _overrideSyncFn;\r\n var _paused = false;\r\n var _enableAjax;\r\n dynamicProto(CfgSyncPlugin, _this, function (_self, _base) {\r\n _initDefaults();\r\n _self.initialize = function (config, core, extensions, pluginChain) {\r\n _base.initialize(config, core, extensions, pluginChain);\r\n _evtNamespace = mergeEvtNamespace(createUniqueNamespace(_self.identifier), core.evtNamespace && core.evtNamespace());\r\n _populateDefaults(config);\r\n };\r\n _self.getCfg = function () {\r\n return _mainConfig;\r\n };\r\n _self.pause = function () {\r\n _paused = true;\r\n _clearScheduledTimer();\r\n };\r\n _self.resume = function () {\r\n _paused = false;\r\n _setupTimer();\r\n };\r\n // used for V2 to manaully trigger config udpate\r\n _self.setCfg = function (config) {\r\n return _setCfg(config);\r\n };\r\n _self.sync = function (customDetails) {\r\n return _sendCfgsyncEvents(customDetails);\r\n };\r\n _self.updateEventListenerName = function (eventName) {\r\n return _updateEventListenerName(eventName);\r\n };\r\n _self._doTeardown = function (unloadCtx, unloadState) {\r\n _eventOff();\r\n _clearScheduledTimer();\r\n _initDefaults();\r\n };\r\n _self[\"_getDbgPlgTargets\"] = function () {\r\n return [_broadcastChanges, _receiveChanges, _evtName, _blkCdnCfg, _nonOverrideConfigs];\r\n };\r\n function _initDefaults() {\r\n _mainConfig = null;\r\n _evtName = null;\r\n _evtNamespace = null;\r\n _cfgUrl = null;\r\n _receiveChanges = null;\r\n _broadcastChanges = null;\r\n _nonOverrideConfigs = null;\r\n _timeoutHandle = null;\r\n _fetchTimeout = null;\r\n _retryCnt = null;\r\n _blkCdnCfg = null;\r\n _enableAjax = false;\r\n _overrideFetchFn = null;\r\n _overrideSyncFn = null;\r\n _onCfgChangeReceive = null;\r\n }\r\n function _populateDefaults(config) {\r\n var identifier = _self.identifier;\r\n var core = _self.core;\r\n _self._addHook(onConfigChange(config, function () {\r\n var ctx = createProcessTelemetryContext(null, config, core);\r\n _extensionConfig = ctx.getExtCfg(identifier, _defaultConfig);\r\n var preBlkCdn = _blkCdnCfg;\r\n _blkCdnCfg = !!_extensionConfig.blkCdnCfg;\r\n _enableAjax = !!_extensionConfig.enableAjax;\r\n // avoid initial call\r\n if (!isNullOrUndefined(preBlkCdn) && preBlkCdn !== _blkCdnCfg) {\r\n if (!_blkCdnCfg && _cfgUrl) {\r\n _fetchFn && _fetchFn(_cfgUrl, _onFetchComplete, _broadcastChanges);\r\n }\r\n else {\r\n _clearScheduledTimer();\r\n }\r\n }\r\n if (isNullOrUndefined(_receiveChanges)) {\r\n _receiveChanges = _extensionConfig.syncMode === 2 /* ICfgSyncMode.Receive */;\r\n }\r\n if (isNullOrUndefined(_broadcastChanges)) {\r\n _broadcastChanges = _extensionConfig.syncMode === 1 /* ICfgSyncMode.Broadcast */;\r\n }\r\n var newEvtName = _extensionConfig.customEvtName || EVENT_NAME;\r\n if (_evtName !== newEvtName) {\r\n if (_receiveChanges) {\r\n _updateEventListenerName(newEvtName);\r\n }\r\n else {\r\n _eventOff();\r\n _evtName = newEvtName;\r\n }\r\n }\r\n if (isNullOrUndefined(_cfgUrl)) {\r\n _cfgUrl = _extensionConfig.cfgUrl;\r\n }\r\n // if cfgUrl is set, we will ignore core config change\r\n if (!_cfgUrl) {\r\n _mainConfig = config;\r\n if (_broadcastChanges) {\r\n _sendCfgsyncEvents();\r\n }\r\n }\r\n }));\r\n _overrideSyncFn = _extensionConfig.overrideSyncFn;\r\n _overrideFetchFn = _extensionConfig.overrideFetchFn;\r\n _onCfgChangeReceive = _extensionConfig.onCfgChangeReceive;\r\n _nonOverrideConfigs = _extensionConfig.nonOverrideConfigs; // override values should not be changed\r\n _fetchTimeout = _extensionConfig[_DYN_SCHEDULE_FETCH_TIMEO0 /* @min:%2escheduleFetchTimeout */];\r\n _fetchFn = _getFetchFnInterface();\r\n _retryCnt = 0;\r\n // NOT support cfgURL change to avoid mutiple fetch calls\r\n if (_cfgUrl && !_blkCdnCfg) {\r\n _fetchFn && _fetchFn(_cfgUrl, _onFetchComplete, _broadcastChanges);\r\n }\r\n }\r\n function _setCfg(config, isAutoSync) {\r\n if (config) {\r\n _mainConfig = config;\r\n if (!!isAutoSync && !_paused) {\r\n return _sendCfgsyncEvents();\r\n }\r\n if (_receiveChanges && !_paused) {\r\n _self.core.updateCfg(config);\r\n return true;\r\n }\r\n }\r\n return false;\r\n }\r\n function _eventOff() {\r\n try {\r\n var global_1 = getGlobal();\r\n if (global_1) {\r\n eventOff(global_1, null, null, _evtNamespace);\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n }\r\n function _sendCfgsyncEvents(customDetails) {\r\n try {\r\n if (!!_overrideSyncFn && isFunction(_overrideSyncFn)) {\r\n return _overrideSyncFn(_mainConfig, customDetails);\r\n }\r\n return sendCustomEvent(_evtName, _mainConfig, customDetails);\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return false;\r\n }\r\n function _updateEventListenerName(name) {\r\n try {\r\n _eventOff();\r\n if (name) {\r\n _evtName = name;\r\n _addEventListener();\r\n }\r\n return true;\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return false;\r\n }\r\n function _getFetchFnInterface() {\r\n var _fetchFn = _overrideFetchFn;\r\n if (isNullOrUndefined(_fetchFn)) {\r\n if (isFetchSupported()) {\r\n _fetchFn = _fetchSender;\r\n }\r\n else if (isXhrSupported()) {\r\n _fetchFn = _xhrSender;\r\n }\r\n }\r\n return _fetchFn;\r\n }\r\n function _fetchSender(url, oncomplete, isAutoSync) {\r\n var global = getGlobal();\r\n var fetchFn = (global && global.fetch) || null;\r\n if (url && fetchFn && isFunction(fetchFn)) {\r\n try {\r\n var init = {\r\n method: STR_GET_METHOD\r\n };\r\n if (!_enableAjax) {\r\n init[DisabledPropertyName] = true;\r\n }\r\n var request = new Request(url, init);\r\n if (!_enableAjax) {\r\n try {\r\n // Also try and tag the request (just in case the value in init is not copied over)\r\n request[DisabledPropertyName] = true;\r\n }\r\n catch (e) {\r\n // If the environment has locked down the XMLHttpRequest (preventExtensions and/or freeze), this would\r\n // cause the request to fail and we no telemetry would be sent\r\n }\r\n }\r\n doAwaitResponse(fetch(request), function (result) {\r\n var response = result.value;\r\n if (!result.rejected) {\r\n if (response.ok) {\r\n doAwaitResponse(response.text(), function (res) {\r\n _doOnComplete(oncomplete, response.status, res.value, isAutoSync);\r\n });\r\n }\r\n else {\r\n _doOnComplete(oncomplete, response.status, null, isAutoSync);\r\n }\r\n }\r\n else {\r\n _doOnComplete(oncomplete, 400);\r\n }\r\n });\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n }\r\n }\r\n function _xhrSender(url, oncomplete, isAutoSync) {\r\n try {\r\n var xhr_1 = new XMLHttpRequest();\r\n if (!_enableAjax) {\r\n xhr_1[DisabledPropertyName] = true;\r\n }\r\n xhr_1.open(STR_GET_METHOD, url);\r\n xhr_1.onreadystatechange = function () {\r\n if (xhr_1.readyState === XMLHttpRequest.DONE) {\r\n _doOnComplete(oncomplete, xhr_1.status, xhr_1.responseText, isAutoSync);\r\n }\r\n };\r\n xhr_1.onerror = function () {\r\n _doOnComplete(oncomplete, 400);\r\n };\r\n xhr_1.ontimeout = function () {\r\n _doOnComplete(oncomplete, 400);\r\n };\r\n xhr_1.send();\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n }\r\n function _onFetchComplete(status, response, isAutoSync) {\r\n try {\r\n if (status >= 200 && status < 400 && response) {\r\n _retryCnt = 0; // any successful response will reset retry count to 0\r\n var JSON_1 = getJSON();\r\n if (JSON_1) {\r\n var cdnCfg = JSON_1.parse(response); //comments are not allowed\r\n var cfg = applyCdnfeatureCfg(cdnCfg, _self.core);\r\n var newCfg = cfg && isPlainObject(cfg) && _replaceTartgetByKeys(cfg);\r\n newCfg && _setCfg(newCfg, isAutoSync);\r\n //cfg && _setCfg(cfg, isAutoSync);\r\n }\r\n }\r\n else {\r\n _retryCnt++;\r\n }\r\n if (_retryCnt < 3) {\r\n _setupTimer();\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n }\r\n function _doOnComplete(oncomplete, status, response, isAutoSync) {\r\n try {\r\n oncomplete(status, response, isAutoSync);\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n }\r\n function _addEventListener() {\r\n if (_receiveChanges) {\r\n var global_2 = getGlobal();\r\n if (global_2) {\r\n try {\r\n eventOn(global_2, _evtName, function (event) {\r\n // TODO: add more validation here\r\n // may include a \"name\" or some other features to check\r\n var cfgEvent = event && event.detail;\r\n if (_onCfgChangeReceive && cfgEvent) {\r\n _onCfgChangeReceive(cfgEvent);\r\n }\r\n else {\r\n var cfg = cfgEvent && cfgEvent.cfg;\r\n var newCfg = cfg && isPlainObject(cfg) && _replaceTartgetByKeys(cfg);\r\n newCfg && _setCfg(newCfg);\r\n }\r\n }, _evtNamespace, true);\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n }\r\n }\r\n }\r\n // 4 levels\r\n function _replaceTartgetByKeys(cfg, level) {\r\n var _cfg = null;\r\n try {\r\n if (cfg) {\r\n _cfg = replaceByNonOverrideCfg(cfg, _nonOverrideConfigs, 0, 5);\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return _cfg;\r\n }\r\n /**\r\n * Sets up the timer which triggers fetching cdn every 30mins after inital call\r\n */\r\n function _setupTimer() {\r\n if (!_timeoutHandle && _fetchTimeout) {\r\n _timeoutHandle = scheduleTimeout(function () {\r\n _timeoutHandle = null;\r\n _fetchFn(_cfgUrl, _onFetchComplete, _broadcastChanges);\r\n }, _fetchTimeout);\r\n _timeoutHandle.unref();\r\n }\r\n }\r\n function _clearScheduledTimer() {\r\n _timeoutHandle && _timeoutHandle.cancel();\r\n _timeoutHandle = null;\r\n _retryCnt = 0;\r\n }\r\n _self.processTelemetry = function (env, itemCtx) {\r\n _self.processNext(env, itemCtx);\r\n };\r\n });\r\n return _this;\r\n }\r\n// Removed Stub for CfgSyncPlugin.prototype.initialize.\r\n// Removed Stub for CfgSyncPlugin.prototype.getCfg.\r\n// Removed Stub for CfgSyncPlugin.prototype.setCfg.\r\n// Removed Stub for CfgSyncPlugin.prototype.sync.\r\n// Removed Stub for CfgSyncPlugin.prototype.updateEventListenerName.\r\n// Removed Stub for CfgSyncPlugin.prototype.pause.\r\n// Removed Stub for CfgSyncPlugin.prototype.resume.\r\n //// Removed Stub for CfgSyncPlugin.prototype.processTelemetry.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n CfgSyncPlugin.__ieDyn=1;\n\n return CfgSyncPlugin;\r\n}(BaseTelemetryPlugin));\r\nexport { CfgSyncPlugin };\r\n//# sourceMappingURL=CfgSyncPlugin.js.map","/*\n * Application Insights JavaScript SDK - Channel, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// ###################################################################################################################################################\r\n// Note: DON'T Export these const from the package as we are still targeting IE/ES5 this will export a mutable variables that someone could change ###\r\n// ###################################################################################################################################################\r\n// Generally you should only put values that are used more than 2 times and then only if not already exposed as a constant (such as SdkCoreNames)\r\n// as when using \"short\" named values from here they will be will be minified smaller than the SdkCoreNames[eSdkCoreNames.xxxx] value.\r\nexport var STR_DURATION = \"duration\";\r\n//# sourceMappingURL=InternalConstants.js.map","/*\n * Application Insights JavaScript SDK - Channel, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES5 which can result in a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_TAGS = \"tags\"; // Count: 17\r\nexport var _DYN_DEVICE_TYPE = \"deviceType\"; // Count: 3\r\nexport var _DYN_DATA = \"data\"; // Count: 13\r\nexport var _DYN_NAME = \"name\"; // Count: 8\r\nexport var _DYN_TRACE_ID = \"traceID\"; // Count: 5\r\nexport var _DYN_LENGTH = \"length\"; // Count: 38\r\nexport var _DYN_STRINGIFY = \"stringify\"; // Count: 5\r\nexport var _DYN_MEASUREMENTS = \"measurements\"; // Count: 7\r\nexport var _DYN_DATA_TYPE = \"dataType\"; // Count: 10\r\nexport var _DYN_ENVELOPE_TYPE = \"envelopeType\"; // Count: 7\r\nexport var _DYN_TO_STRING = \"toString\"; // Count: 7\r\nexport var _DYN_ENQUEUE = \"enqueue\"; // Count: 7\r\nexport var _DYN_COUNT = \"count\"; // Count: 7\r\nexport var _DYN_PUSH = \"push\"; // Count: 9\r\nexport var _DYN_EMIT_LINE_DELIMITED_0 = \"emitLineDelimitedJson\"; // Count: 3\r\nexport var _DYN_CLEAR = \"clear\"; // Count: 6\r\nexport var _DYN_MARK_AS_SENT = \"markAsSent\"; // Count: 4\r\nexport var _DYN_CLEAR_SENT = \"clearSent\"; // Count: 5\r\nexport var _DYN_BUFFER_OVERRIDE = \"bufferOverride\"; // Count: 3\r\nexport var _DYN__BUFFER__KEY = \"BUFFER_KEY\"; // Count: 5\r\nexport var _DYN__SENT__BUFFER__KEY = \"SENT_BUFFER_KEY\"; // Count: 8\r\nexport var _DYN_CONCAT = \"concat\"; // Count: 6\r\nexport var _DYN__MAX__BUFFER__SIZE = \"MAX_BUFFER_SIZE\"; // Count: 5\r\nexport var _DYN_TRIGGER_SEND = \"triggerSend\"; // Count: 5\r\nexport var _DYN_DIAG_LOG = \"diagLog\"; // Count: 16\r\nexport var _DYN_INITIALIZE = \"initialize\"; // Count: 3\r\nexport var _DYN__SENDER = \"_sender\"; // Count: 5\r\nexport var _DYN_ENDPOINT_URL = \"endpointUrl\"; // Count: 5\r\nexport var _DYN_INSTRUMENTATION_KEY = \"instrumentationKey\"; // Count: 5\r\nexport var _DYN_CUSTOM_HEADERS = \"customHeaders\"; // Count: 3\r\nexport var _DYN_MAX_BATCH_SIZE_IN_BY1 = \"maxBatchSizeInBytes\"; // Count: 2\r\nexport var _DYN_ONUNLOAD_DISABLE_BEA2 = \"onunloadDisableBeacon\"; // Count: 3\r\nexport var _DYN_IS_BEACON_API_DISABL3 = \"isBeaconApiDisabled\"; // Count: 3\r\nexport var _DYN_ALWAYS_USE_XHR_OVERR4 = \"alwaysUseXhrOverride\"; // Count: 2\r\nexport var _DYN_ENABLE_SESSION_STORA5 = \"enableSessionStorageBuffer\"; // Count: 2\r\nexport var _DYN__BUFFER = \"_buffer\"; // Count: 9\r\nexport var _DYN_ONUNLOAD_DISABLE_FET6 = \"onunloadDisableFetch\"; // Count: 2\r\nexport var _DYN_DISABLE_SEND_BEACON_7 = \"disableSendBeaconSplit\"; // Count: 2\r\nexport var _DYN_GET_SENDER_INST = \"getSenderInst\"; // Count: 4\r\nexport var _DYN__ON_ERROR = \"_onError\"; // Count: 7\r\nexport var _DYN__ON_PARTIAL_SUCCESS = \"_onPartialSuccess\"; // Count: 3\r\nexport var _DYN__ON_SUCCESS = \"_onSuccess\"; // Count: 6\r\nexport var _DYN_ITEMS_RECEIVED = \"itemsReceived\"; // Count: 3\r\nexport var _DYN_ITEMS_ACCEPTED = \"itemsAccepted\"; // Count: 3\r\nexport var _DYN_BASE_TYPE = \"baseType\"; // Count: 4\r\nexport var _DYN_SAMPLE_RATE = \"sampleRate\"; // Count: 4\r\nexport var _DYN_GET_HASH_CODE_SCORE = \"getHashCodeScore\"; // Count: 4\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Channel, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { __assignFn as __assign } from \"@microsoft/applicationinsights-shims\";\r\nimport { CtxTagKeys, Data, Envelope, Event, Exception, HttpMethod, Metric, PageView, PageViewPerformance, RemoteDependencyData, SampleRate, Trace, dataSanitizeString } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal, _warnToConsole, getJSON, hasJSON, isNullOrUndefined, isNumber, isString, isTruthy, objForEachKey, optimizeObject, setValue, toISOString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { STR_DURATION } from \"./InternalConstants\";\r\nimport { _DYN_DATA, _DYN_DATA_TYPE, _DYN_DEVICE_TYPE, _DYN_ENVELOPE_TYPE, _DYN_LENGTH, _DYN_MEASUREMENTS, _DYN_NAME, _DYN_STRINGIFY, _DYN_TAGS, _DYN_TO_STRING, _DYN_TRACE_ID } from \"./__DynamicConstants\";\r\n// these two constants are used to filter out properties not needed when trying to extract custom properties and measurements from the incoming payload\r\nvar strBaseType = \"baseType\";\r\nvar strBaseData = \"baseData\";\r\nvar strProperties = \"properties\";\r\nvar strTrue = \"true\";\r\nfunction _setValueIf(target, field, value) {\r\n return setValue(target, field, value, isTruthy);\r\n}\r\n/*\r\n * Maps Part A data from CS 4.0\r\n */\r\nfunction _extractPartAExtensions(logger, item, env) {\r\n // todo: switch to keys from common in this method\r\n var envTags = env[_DYN_TAGS /* @min:%2etags */] = env[_DYN_TAGS /* @min:%2etags */] || {};\r\n var itmExt = item.ext = item.ext || {};\r\n var itmTags = item[_DYN_TAGS /* @min:%2etags */] = item[_DYN_TAGS /* @min:%2etags */] || [];\r\n var extUser = itmExt.user;\r\n if (extUser) {\r\n _setValueIf(envTags, CtxTagKeys.userAuthUserId, extUser.authId);\r\n _setValueIf(envTags, CtxTagKeys.userId, extUser.id || extUser.localId);\r\n }\r\n var extApp = itmExt.app;\r\n if (extApp) {\r\n _setValueIf(envTags, CtxTagKeys.sessionId, extApp.sesId);\r\n }\r\n var extDevice = itmExt.device;\r\n if (extDevice) {\r\n _setValueIf(envTags, CtxTagKeys.deviceId, extDevice.id || extDevice.localId);\r\n _setValueIf(envTags, CtxTagKeys[_DYN_DEVICE_TYPE /* @min:%2edeviceType */], extDevice.deviceClass);\r\n _setValueIf(envTags, CtxTagKeys.deviceIp, extDevice.ip);\r\n _setValueIf(envTags, CtxTagKeys.deviceModel, extDevice.model);\r\n _setValueIf(envTags, CtxTagKeys[_DYN_DEVICE_TYPE /* @min:%2edeviceType */], extDevice[_DYN_DEVICE_TYPE /* @min:%2edeviceType */]);\r\n }\r\n var web = item.ext.web;\r\n if (web) {\r\n _setValueIf(envTags, CtxTagKeys.deviceLanguage, web.browserLang);\r\n _setValueIf(envTags, CtxTagKeys.deviceBrowserVersion, web.browserVer);\r\n _setValueIf(envTags, CtxTagKeys.deviceBrowser, web.browser);\r\n var envData = env[_DYN_DATA /* @min:%2edata */] = env[_DYN_DATA /* @min:%2edata */] || {};\r\n var envBaseData = envData[strBaseData] = envData[strBaseData] || {};\r\n var envProps = envBaseData[strProperties] = envBaseData[strProperties] || {};\r\n _setValueIf(envProps, \"domain\", web.domain);\r\n _setValueIf(envProps, \"isManual\", web.isManual ? strTrue : null);\r\n _setValueIf(envProps, \"screenRes\", web.screenRes);\r\n _setValueIf(envProps, \"userConsent\", web.userConsent ? strTrue : null);\r\n }\r\n var extOs = itmExt.os;\r\n if (extOs) {\r\n _setValueIf(envTags, CtxTagKeys.deviceOS, extOs[_DYN_NAME /* @min:%2ename */]);\r\n _setValueIf(envTags, CtxTagKeys.deviceOSVersion, extOs.osVer);\r\n }\r\n // No support for mapping Trace.traceState to 2.0 as it is currently empty\r\n var extTrace = itmExt.trace;\r\n if (extTrace) {\r\n _setValueIf(envTags, CtxTagKeys.operationParentId, extTrace.parentID);\r\n _setValueIf(envTags, CtxTagKeys.operationName, dataSanitizeString(logger, extTrace[_DYN_NAME /* @min:%2ename */]));\r\n _setValueIf(envTags, CtxTagKeys.operationId, extTrace[_DYN_TRACE_ID /* @min:%2etraceID */]);\r\n }\r\n // Sample 4.0 schema\r\n // {\r\n // \"time\" : \"2018-09-05T22:51:22.4936Z\",\r\n // \"name\" : \"MetricWithNamespace\",\r\n // \"iKey\" : \"ABC-5a4cbd20-e601-4ef5-a3c6-5d6577e4398e\",\r\n // \"ext\": { \"cloud\": {\r\n // \"role\": \"WATSON3\",\r\n // \"roleInstance\": \"CO4AEAP00000260\"\r\n // },\r\n // \"device\": {}, \"correlation\": {} },\r\n // \"tags\": [\r\n // { \"amazon.region\" : \"east2\" },\r\n // { \"os.expid\" : \"wp:02df239\" }\r\n // ]\r\n // }\r\n var tgs = {};\r\n // deals with tags.push({object})\r\n for (var i = itmTags[_DYN_LENGTH /* @min:%2elength */] - 1; i >= 0; i--) {\r\n var tg = itmTags[i];\r\n objForEachKey(tg, function (key, value) {\r\n tgs[key] = value;\r\n });\r\n itmTags.splice(i, 1);\r\n }\r\n // deals with tags[key]=value (and handles hasOwnProperty)\r\n objForEachKey(itmTags, function (tg, value) {\r\n tgs[tg] = value;\r\n });\r\n var theTags = __assign(__assign({}, envTags), tgs);\r\n if (!theTags[CtxTagKeys.internalSdkVersion]) {\r\n // Append a version in case it is not already set\r\n theTags[CtxTagKeys.internalSdkVersion] = dataSanitizeString(logger, \"javascript:\".concat(EnvelopeCreator.Version), 64);\r\n }\r\n env[_DYN_TAGS /* @min:%2etags */] = optimizeObject(theTags);\r\n}\r\nfunction _extractPropsAndMeasurements(data, properties, measurements) {\r\n if (!isNullOrUndefined(data)) {\r\n objForEachKey(data, function (key, value) {\r\n if (isNumber(value)) {\r\n measurements[key] = value;\r\n }\r\n else if (isString(value)) {\r\n properties[key] = value;\r\n }\r\n else if (hasJSON()) {\r\n properties[key] = getJSON()[_DYN_STRINGIFY /* @min:%2estringify */](value);\r\n }\r\n });\r\n }\r\n}\r\nfunction _convertPropsUndefinedToCustomDefinedValue(properties, customUndefinedValue) {\r\n if (!isNullOrUndefined(properties)) {\r\n objForEachKey(properties, function (key, value) {\r\n properties[key] = value || customUndefinedValue;\r\n });\r\n }\r\n}\r\n// TODO: Do we want this to take logger as arg or use this._logger as nonstatic?\r\nfunction _createEnvelope(logger, envelopeType, telemetryItem, data) {\r\n var envelope = new Envelope(logger, data, envelopeType);\r\n _setValueIf(envelope, \"sampleRate\", telemetryItem[SampleRate]);\r\n if ((telemetryItem[strBaseData] || {}).startTime) {\r\n // Starting from Version 3.0.3, the time property will be assigned by the startTime value,\r\n // which records the loadEvent time for the pageView event.\r\n envelope.time = toISOString(telemetryItem[strBaseData].startTime);\r\n }\r\n envelope.iKey = telemetryItem.iKey;\r\n var iKeyNoDashes = telemetryItem.iKey.replace(/-/g, \"\");\r\n envelope[_DYN_NAME /* @min:%2ename */] = envelope[_DYN_NAME /* @min:%2ename */].replace(\"{0}\", iKeyNoDashes);\r\n // extract all extensions from ctx\r\n _extractPartAExtensions(logger, telemetryItem, envelope);\r\n // loop through the envelope tags (extension of Part A) and pick out the ones that should go in outgoing envelope tags\r\n telemetryItem[_DYN_TAGS /* @min:%2etags */] = telemetryItem[_DYN_TAGS /* @min:%2etags */] || [];\r\n return optimizeObject(envelope);\r\n}\r\nfunction EnvelopeCreatorInit(logger, telemetryItem) {\r\n if (isNullOrUndefined(telemetryItem[strBaseData])) {\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 46 /* _eInternalMessageId.TelemetryEnvelopeInvalid */, \"telemetryItem.baseData cannot be null.\");\r\n }\r\n}\r\nexport var EnvelopeCreator = {\r\n Version: '3.3.6'\r\n};\r\nexport function DependencyEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n var customMeasurements = telemetryItem[strBaseData][_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n var customProperties = telemetryItem[strBaseData][strProperties] || {};\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], customProperties, customMeasurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(customProperties, customUndefinedValue);\r\n }\r\n var bd = telemetryItem[strBaseData];\r\n if (isNullOrUndefined(bd)) {\r\n _warnToConsole(logger, \"Invalid input for dependency data\");\r\n return null;\r\n }\r\n var method = bd[strProperties] && bd[strProperties][HttpMethod] ? bd[strProperties][HttpMethod] : \"GET\";\r\n var remoteDepData = new RemoteDependencyData(logger, bd.id, bd.target, bd[_DYN_NAME /* @min:%2ename */], bd[STR_DURATION /* @min:%2eduration */], bd.success, bd.responseCode, method, bd.type, bd.correlationContext, customProperties, customMeasurements);\r\n var data = new Data(RemoteDependencyData[_DYN_DATA_TYPE /* @min:%2edataType */], remoteDepData);\r\n return _createEnvelope(logger, RemoteDependencyData[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\nexport function EventEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n var customProperties = {};\r\n var customMeasurements = {};\r\n if (telemetryItem[strBaseType] !== Event[_DYN_DATA_TYPE /* @min:%2edataType */]) {\r\n customProperties[\"baseTypeSource\"] = telemetryItem[strBaseType]; // save the passed in base type as a property\r\n }\r\n if (telemetryItem[strBaseType] === Event[_DYN_DATA_TYPE /* @min:%2edataType */]) { // take collection\r\n customProperties = telemetryItem[strBaseData][strProperties] || {};\r\n customMeasurements = telemetryItem[strBaseData][_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n }\r\n else { // if its not a known type, convert to custom event\r\n if (telemetryItem[strBaseData]) {\r\n _extractPropsAndMeasurements(telemetryItem[strBaseData], customProperties, customMeasurements);\r\n }\r\n }\r\n // Extract root level properties from part C telemetryItem.data\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], customProperties, customMeasurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(customProperties, customUndefinedValue);\r\n }\r\n var eventName = telemetryItem[strBaseData][_DYN_NAME /* @min:%2ename */];\r\n var eventData = new Event(logger, eventName, customProperties, customMeasurements);\r\n var data = new Data(Event[_DYN_DATA_TYPE /* @min:%2edataType */], eventData);\r\n return _createEnvelope(logger, Event[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\nexport function ExceptionEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n // Extract root level properties from part C telemetryItem.data\r\n var customMeasurements = telemetryItem[strBaseData][_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n var customProperties = telemetryItem[strBaseData][strProperties] || {};\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], customProperties, customMeasurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(customProperties, customUndefinedValue);\r\n }\r\n var bd = telemetryItem[strBaseData];\r\n var exData = Exception.CreateFromInterface(logger, bd, customProperties, customMeasurements);\r\n var data = new Data(Exception[_DYN_DATA_TYPE /* @min:%2edataType */], exData);\r\n return _createEnvelope(logger, Exception[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\nexport function MetricEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n var baseData = telemetryItem[strBaseData];\r\n var props = baseData[strProperties] || {};\r\n var measurements = baseData[_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], props, measurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(props, customUndefinedValue);\r\n }\r\n var baseMetricData = new Metric(logger, baseData[_DYN_NAME /* @min:%2ename */], baseData.average, baseData.sampleCount, baseData.min, baseData.max, baseData.stdDev, props, measurements);\r\n var data = new Data(Metric[_DYN_DATA_TYPE /* @min:%2edataType */], baseMetricData);\r\n return _createEnvelope(logger, Metric[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\nexport function PageViewEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n // Since duration is not part of the domain properties in Common Schema, extract it from part C\r\n var duration;\r\n var baseData = telemetryItem[strBaseData];\r\n if (!isNullOrUndefined(baseData) &&\r\n !isNullOrUndefined(baseData[strProperties]) &&\r\n !isNullOrUndefined(baseData[strProperties][STR_DURATION])) { // from part B properties\r\n duration = baseData[strProperties][STR_DURATION];\r\n delete baseData[strProperties][STR_DURATION];\r\n }\r\n else if (!isNullOrUndefined(telemetryItem[_DYN_DATA /* @min:%2edata */]) &&\r\n !isNullOrUndefined(telemetryItem[_DYN_DATA /* @min:%2edata */][STR_DURATION])) { // from custom properties\r\n duration = telemetryItem[_DYN_DATA /* @min:%2edata */][STR_DURATION];\r\n delete telemetryItem[_DYN_DATA /* @min:%2edata */][STR_DURATION];\r\n }\r\n var bd = telemetryItem[strBaseData];\r\n // special case: pageview.id is grabbed from current operation id. Analytics plugin is decoupled from properties plugin, so this is done here instead. This can be made a default telemetry intializer instead if needed to be decoupled from channel\r\n var currentContextId;\r\n if (((telemetryItem.ext || {}).trace || {})[_DYN_TRACE_ID /* @min:%2etraceID */]) {\r\n currentContextId = telemetryItem.ext.trace[_DYN_TRACE_ID /* @min:%2etraceID */];\r\n }\r\n var id = bd.id || currentContextId;\r\n var name = bd[_DYN_NAME /* @min:%2ename */];\r\n var url = bd.uri;\r\n var properties = bd[strProperties] || {};\r\n var measurements = bd[_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n // refUri is a field that Breeze still does not recognize as part of Part B. For now, put it in Part C until it supports it as a domain property\r\n if (!isNullOrUndefined(bd.refUri)) {\r\n properties[\"refUri\"] = bd.refUri;\r\n }\r\n // pageType is a field that Breeze still does not recognize as part of Part B. For now, put it in Part C until it supports it as a domain property\r\n if (!isNullOrUndefined(bd.pageType)) {\r\n properties[\"pageType\"] = bd.pageType;\r\n }\r\n // isLoggedIn is a field that Breeze still does not recognize as part of Part B. For now, put it in Part C until it supports it as a domain property\r\n if (!isNullOrUndefined(bd.isLoggedIn)) {\r\n properties[\"isLoggedIn\"] = bd.isLoggedIn[_DYN_TO_STRING /* @min:%2etoString */]();\r\n }\r\n // pageTags is a field that Breeze still does not recognize as part of Part B. For now, put it in Part C until it supports it as a domain property\r\n if (!isNullOrUndefined(bd[strProperties])) {\r\n var pageTags = bd[strProperties];\r\n objForEachKey(pageTags, function (key, value) {\r\n properties[key] = value;\r\n });\r\n }\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], properties, measurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(properties, customUndefinedValue);\r\n }\r\n var pageViewData = new PageView(logger, name, url, duration, properties, measurements, id);\r\n var data = new Data(PageView[_DYN_DATA_TYPE /* @min:%2edataType */], pageViewData);\r\n return _createEnvelope(logger, PageView[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\nexport function PageViewPerformanceEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n var bd = telemetryItem[strBaseData];\r\n var name = bd[_DYN_NAME /* @min:%2ename */];\r\n var url = bd.uri || bd.url;\r\n var properties = bd[strProperties] || {};\r\n var measurements = bd[_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], properties, measurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(properties, customUndefinedValue);\r\n }\r\n var baseData = new PageViewPerformance(logger, name, url, undefined, properties, measurements, bd);\r\n var data = new Data(PageViewPerformance[_DYN_DATA_TYPE /* @min:%2edataType */], baseData);\r\n return _createEnvelope(logger, PageViewPerformance[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\nexport function TraceEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n var message = telemetryItem[strBaseData].message;\r\n var severityLevel = telemetryItem[strBaseData].severityLevel;\r\n var props = telemetryItem[strBaseData][strProperties] || {};\r\n var measurements = telemetryItem[strBaseData][_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], props, measurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(props, customUndefinedValue);\r\n }\r\n var baseData = new Trace(logger, message, severityLevel, props, measurements);\r\n var data = new Data(Trace[_DYN_DATA_TYPE /* @min:%2edataType */], baseData);\r\n return _createEnvelope(logger, Trace[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\n//# sourceMappingURL=EnvelopeCreator.js.map","/*\n * Application Insights JavaScript SDK - Channel, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { utlGetSessionStorage, utlRemoveSessionStorage, utlSetSessionStorage } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal, arrForEach, arrIndexOf, dumpObj, getExceptionName, getJSON, isArray, isFunction, isNullOrUndefined, isString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_BUFFER_OVERRIDE, _DYN_CLEAR, _DYN_CLEAR_SENT, _DYN_CONCAT, _DYN_COUNT, _DYN_EMIT_LINE_DELIMITED_0, _DYN_ENQUEUE, _DYN_LENGTH, _DYN_MARK_AS_SENT, _DYN_PUSH, _DYN_STRINGIFY, _DYN__BUFFER__KEY, _DYN__MAX__BUFFER__SIZE, _DYN__SENT__BUFFER__KEY } from \"./__DynamicConstants\";\r\nvar BaseSendBuffer = /** @class */ (function () {\r\n function BaseSendBuffer(logger, config) {\r\n var _buffer = [];\r\n var _bufferFullMessageSent = false;\r\n var _maxRetryCnt = config.maxRetryCnt;\r\n this._get = function () {\r\n return _buffer;\r\n };\r\n this._set = function (buffer) {\r\n _buffer = buffer;\r\n return _buffer;\r\n };\r\n dynamicProto(BaseSendBuffer, this, function (_self) {\r\n _self[_DYN_ENQUEUE /* @min:%2eenqueue */] = function (payload) {\r\n if (_self[_DYN_COUNT /* @min:%2ecount */]() >= config.eventsLimitInMem) {\r\n // sent internal log only once per page view\r\n if (!_bufferFullMessageSent) {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 105 /* _eInternalMessageId.InMemoryStorageBufferFull */, \"Maximum in-memory buffer size reached: \" + _self[_DYN_COUNT /* @min:%2ecount */](), true);\r\n _bufferFullMessageSent = true;\r\n }\r\n return;\r\n }\r\n payload.cnt = payload.cnt || 0;\r\n // max retry is defined, and max retry is reached, do not add the payload to buffer\r\n if (!isNullOrUndefined(_maxRetryCnt)) {\r\n if (payload.cnt > _maxRetryCnt) {\r\n // TODO: add log here on dropping payloads\r\n return;\r\n }\r\n }\r\n _buffer[_DYN_PUSH /* @min:%2epush */](payload);\r\n return;\r\n };\r\n _self[_DYN_COUNT /* @min:%2ecount */] = function () {\r\n return _buffer[_DYN_LENGTH /* @min:%2elength */];\r\n };\r\n _self.size = function () {\r\n var size = _buffer[_DYN_LENGTH /* @min:%2elength */];\r\n for (var lp = 0; lp < _buffer[_DYN_LENGTH /* @min:%2elength */]; lp++) {\r\n size += (_buffer[lp].item)[_DYN_LENGTH /* @min:%2elength */];\r\n }\r\n if (!config[_DYN_EMIT_LINE_DELIMITED_0 /* @min:%2eemitLineDelimitedJson */]) {\r\n size += 2;\r\n }\r\n return size;\r\n };\r\n _self[_DYN_CLEAR /* @min:%2eclear */] = function () {\r\n _buffer = [];\r\n _bufferFullMessageSent = false;\r\n };\r\n _self.getItems = function () {\r\n return _buffer.slice(0);\r\n };\r\n _self.batchPayloads = function (payloads) {\r\n if (payloads && payloads[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n var payloadStr_1 = [];\r\n arrForEach(payloads, function (payload) {\r\n payloadStr_1[_DYN_PUSH /* @min:%2epush */](payload.item);\r\n });\r\n var batch = config[_DYN_EMIT_LINE_DELIMITED_0 /* @min:%2eemitLineDelimitedJson */] ?\r\n payloadStr_1.join(\"\\n\") :\r\n \"[\" + payloadStr_1.join(\",\") + \"]\";\r\n return batch;\r\n }\r\n return null;\r\n };\r\n _self.createNew = function (newLogger, newConfig, canUseSessionStorage) {\r\n var items = _buffer.slice(0);\r\n newLogger = newLogger || logger;\r\n newConfig = newConfig || {};\r\n var newBuffer = !!canUseSessionStorage ? new SessionStorageSendBuffer(newLogger, newConfig) : new ArraySendBuffer(newLogger, newConfig);\r\n arrForEach(items, function (payload) {\r\n newBuffer[_DYN_ENQUEUE /* @min:%2eenqueue */](payload);\r\n });\r\n return newBuffer;\r\n };\r\n });\r\n }\r\n// Removed Stub for BaseSendBuffer.prototype.enqueue.\r\n// Removed Stub for BaseSendBuffer.prototype.count.\r\n// Removed Stub for BaseSendBuffer.prototype.size.\r\n// Removed Stub for BaseSendBuffer.prototype.clear.\r\n// Removed Stub for BaseSendBuffer.prototype.getItems.\r\n// Removed Stub for BaseSendBuffer.prototype.batchPayloads.\r\n// Removed Stub for BaseSendBuffer.prototype.createNew.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n BaseSendBuffer.__ieDyn=1;\n\n return BaseSendBuffer;\r\n}());\r\n/*\r\n * An array based send buffer.\r\n */\r\nvar ArraySendBuffer = /** @class */ (function (_super) {\r\n __extends(ArraySendBuffer, _super);\r\n function ArraySendBuffer(logger, config) {\r\n var _this = _super.call(this, logger, config) || this;\r\n dynamicProto(ArraySendBuffer, _this, function (_self, _base) {\r\n _self[_DYN_MARK_AS_SENT /* @min:%2emarkAsSent */] = function (payload) {\r\n _base[_DYN_CLEAR /* @min:%2eclear */]();\r\n };\r\n _self[_DYN_CLEAR_SENT /* @min:%2eclearSent */] = function (payload) {\r\n // not supported\r\n };\r\n });\r\n return _this;\r\n }\r\n// Removed Stub for ArraySendBuffer.prototype.markAsSent.\r\n// Removed Stub for ArraySendBuffer.prototype.clearSent.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n ArraySendBuffer.__ieDyn=1;\n\n return ArraySendBuffer;\r\n}(BaseSendBuffer));\r\nexport { ArraySendBuffer };\r\nvar PREVIOUS_KEYS = [\"AI_buffer\", \"AI_sentBuffer\"];\r\n/*\r\n * Session storage buffer holds a copy of all unsent items in the browser session storage.\r\n */\r\nvar SessionStorageSendBuffer = /** @class */ (function (_super) {\r\n __extends(SessionStorageSendBuffer, _super);\r\n function SessionStorageSendBuffer(logger, config) {\r\n var _this = _super.call(this, logger, config) || this;\r\n var _bufferFullMessageSent = false;\r\n //Note: should not use config.namePrefix directly, because it will always refers to the latest namePrefix\r\n var _namePrefix = config === null || config === void 0 ? void 0 : config.namePrefix;\r\n // TODO: add remove buffer override as well\r\n var _b = config[_DYN_BUFFER_OVERRIDE /* @min:%2ebufferOverride */] || { getItem: utlGetSessionStorage, setItem: utlSetSessionStorage }, getItem = _b.getItem, setItem = _b.setItem;\r\n var _maxRetryCnt = config.maxRetryCnt;\r\n dynamicProto(SessionStorageSendBuffer, _this, function (_self, _base) {\r\n var bufferItems = _getBuffer(SessionStorageSendBuffer[_DYN__BUFFER__KEY /* @min:%2eBUFFER_KEY */]);\r\n var itemsInSentBuffer = _getBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */]);\r\n var previousItems = _getPreviousEvents();\r\n var notDeliveredItems = itemsInSentBuffer[_DYN_CONCAT /* @min:%2econcat */](previousItems);\r\n var buffer = _self._set(bufferItems[_DYN_CONCAT /* @min:%2econcat */](notDeliveredItems));\r\n // If the buffer has too many items, drop items from the end.\r\n if (buffer[_DYN_LENGTH /* @min:%2elength */] > SessionStorageSendBuffer[_DYN__MAX__BUFFER__SIZE /* @min:%2eMAX_BUFFER_SIZE */]) {\r\n buffer[_DYN_LENGTH /* @min:%2elength */] = SessionStorageSendBuffer[_DYN__MAX__BUFFER__SIZE /* @min:%2eMAX_BUFFER_SIZE */];\r\n }\r\n _setBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */], []);\r\n _setBuffer(SessionStorageSendBuffer[_DYN__BUFFER__KEY /* @min:%2eBUFFER_KEY */], buffer);\r\n _self[_DYN_ENQUEUE /* @min:%2eenqueue */] = function (payload) {\r\n if (_self[_DYN_COUNT /* @min:%2ecount */]() >= SessionStorageSendBuffer[_DYN__MAX__BUFFER__SIZE /* @min:%2eMAX_BUFFER_SIZE */]) {\r\n // sent internal log only once per page view\r\n if (!_bufferFullMessageSent) {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 67 /* _eInternalMessageId.SessionStorageBufferFull */, \"Maximum buffer size reached: \" + _self[_DYN_COUNT /* @min:%2ecount */](), true);\r\n _bufferFullMessageSent = true;\r\n }\r\n return;\r\n }\r\n payload.cnt = payload.cnt || 0;\r\n // max retry is defined, and max retry is reached, do not add the payload to buffer\r\n if (!isNullOrUndefined(_maxRetryCnt)) {\r\n if (payload.cnt > _maxRetryCnt) {\r\n // TODO: add log here on dropping payloads\r\n return;\r\n }\r\n }\r\n _base[_DYN_ENQUEUE /* @min:%2eenqueue */](payload);\r\n _setBuffer(SessionStorageSendBuffer[_DYN__BUFFER__KEY /* @min:%2eBUFFER_KEY */], _self._get());\r\n };\r\n _self[_DYN_CLEAR /* @min:%2eclear */] = function () {\r\n _base[_DYN_CLEAR /* @min:%2eclear */]();\r\n _setBuffer(SessionStorageSendBuffer[_DYN__BUFFER__KEY /* @min:%2eBUFFER_KEY */], _self._get());\r\n _setBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */], []);\r\n _bufferFullMessageSent = false;\r\n };\r\n _self[_DYN_MARK_AS_SENT /* @min:%2emarkAsSent */] = function (payload) {\r\n _setBuffer(SessionStorageSendBuffer[_DYN__BUFFER__KEY /* @min:%2eBUFFER_KEY */], _self._set(_removePayloadsFromBuffer(payload, _self._get())));\r\n var sentElements = _getBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */]);\r\n if (sentElements instanceof Array && payload instanceof Array) {\r\n sentElements = sentElements[_DYN_CONCAT /* @min:%2econcat */](payload);\r\n if (sentElements[_DYN_LENGTH /* @min:%2elength */] > SessionStorageSendBuffer[_DYN__MAX__BUFFER__SIZE /* @min:%2eMAX_BUFFER_SIZE */]) {\r\n // We send telemetry normally. If the SENT_BUFFER is too big we don't add new elements\r\n // until we receive a response from the backend and the buffer has free space again (see clearSent method)\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 67 /* _eInternalMessageId.SessionStorageBufferFull */, \"Sent buffer reached its maximum size: \" + sentElements[_DYN_LENGTH /* @min:%2elength */], true);\r\n sentElements[_DYN_LENGTH /* @min:%2elength */] = SessionStorageSendBuffer[_DYN__MAX__BUFFER__SIZE /* @min:%2eMAX_BUFFER_SIZE */];\r\n }\r\n _setBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */], sentElements);\r\n }\r\n };\r\n _self[_DYN_CLEAR_SENT /* @min:%2eclearSent */] = function (payload) {\r\n var sentElements = _getBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */]);\r\n sentElements = _removePayloadsFromBuffer(payload, sentElements);\r\n _setBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */], sentElements);\r\n };\r\n _self.createNew = function (newLogger, newConfig, canUseSessionStorage) {\r\n canUseSessionStorage = !!canUseSessionStorage;\r\n var unsentItems = _self._get().slice(0);\r\n var sentItems = _getBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */]).slice(0);\r\n newLogger = newLogger || logger;\r\n newConfig = newConfig || {};\r\n // to make sure that we do not send duplicated payloads when it is switched back to previous one\r\n _self[_DYN_CLEAR /* @min:%2eclear */]();\r\n var newBuffer = canUseSessionStorage ? new SessionStorageSendBuffer(newLogger, newConfig) : new ArraySendBuffer(newLogger, newConfig);\r\n arrForEach(unsentItems, function (payload) {\r\n newBuffer[_DYN_ENQUEUE /* @min:%2eenqueue */](payload);\r\n });\r\n if (canUseSessionStorage) {\r\n // arr buffer will clear all payloads if markAsSent() is called\r\n newBuffer[_DYN_MARK_AS_SENT /* @min:%2emarkAsSent */](sentItems);\r\n }\r\n return newBuffer;\r\n };\r\n function _removePayloadsFromBuffer(payloads, buffer) {\r\n var remaining = [];\r\n var payloadStr = [];\r\n arrForEach(payloads, function (payload) {\r\n payloadStr[_DYN_PUSH /* @min:%2epush */](payload.item);\r\n });\r\n arrForEach(buffer, function (value) {\r\n if (!isFunction(value) && arrIndexOf(payloadStr, value.item) === -1) {\r\n remaining[_DYN_PUSH /* @min:%2epush */](value);\r\n }\r\n });\r\n return remaining;\r\n }\r\n function _getBuffer(key) {\r\n var prefixedKey = key;\r\n prefixedKey = _namePrefix ? _namePrefix + \"_\" + prefixedKey : prefixedKey;\r\n return _getBufferBase(prefixedKey);\r\n }\r\n function _getBufferBase(key) {\r\n try {\r\n var bufferJson = getItem(logger, key);\r\n if (bufferJson) {\r\n var buffer_1 = getJSON().parse(bufferJson);\r\n if (isString(buffer_1)) {\r\n // When using some version prototype.js the stringify / parse cycle does not decode array's correctly\r\n buffer_1 = getJSON().parse(buffer_1);\r\n }\r\n if (buffer_1 && isArray(buffer_1)) {\r\n return buffer_1;\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 42 /* _eInternalMessageId.FailedToRestoreStorageBuffer */, \" storage key: \" + key + \", \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n return [];\r\n }\r\n function _setBuffer(key, buffer) {\r\n var prefixedKey = key;\r\n try {\r\n prefixedKey = _namePrefix ? _namePrefix + \"_\" + prefixedKey : prefixedKey;\r\n var bufferJson = JSON[_DYN_STRINGIFY /* @min:%2estringify */](buffer);\r\n setItem(logger, prefixedKey, bufferJson);\r\n }\r\n catch (e) {\r\n // if there was an error, clear the buffer\r\n // telemetry is stored in the _buffer array so we won't loose any items\r\n setItem(logger, prefixedKey, JSON[_DYN_STRINGIFY /* @min:%2estringify */]([]));\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 41 /* _eInternalMessageId.FailedToSetStorageBuffer */, \" storage key: \" + prefixedKey + \", \" + getExceptionName(e) + \". Buffer cleared\", { exception: dumpObj(e) });\r\n }\r\n }\r\n // this removes buffer with prefix+key\r\n function _getPreviousEvents() {\r\n var items = [];\r\n try {\r\n arrForEach(PREVIOUS_KEYS, function (key) {\r\n var events = _getItemsFromPreviousKey(key);\r\n items = items[_DYN_CONCAT /* @min:%2econcat */](events);\r\n // to make sure that we also transfer items from old prefixed + key buffer\r\n if (_namePrefix) {\r\n var prefixedKey = _namePrefix + \"_\" + key;\r\n var prefixEvents = _getItemsFromPreviousKey(prefixedKey);\r\n items = items[_DYN_CONCAT /* @min:%2econcat */](prefixEvents);\r\n }\r\n });\r\n return items;\r\n }\r\n catch (e) {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 41 /* _eInternalMessageId.FailedToSetStorageBuffer */, \"Transfer events from previous buffers: \" + getExceptionName(e) + \". previous Buffer items can not be removed\", { exception: dumpObj(e) });\r\n }\r\n return [];\r\n }\r\n // transform string[] to IInternalStorageItem[]\r\n function _getItemsFromPreviousKey(key) {\r\n try {\r\n var items = _getBufferBase(key);\r\n var transFormedItems_1 = [];\r\n arrForEach(items, function (item) {\r\n var internalItem = {\r\n item: item,\r\n cnt: 0 // previous events will be default to 0 count\r\n };\r\n transFormedItems_1[_DYN_PUSH /* @min:%2epush */](internalItem);\r\n });\r\n // remove the session storage if we can add events back\r\n utlRemoveSessionStorage(logger, key);\r\n return transFormedItems_1;\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return [];\r\n }\r\n });\r\n return _this;\r\n }\r\n// Removed Stub for SessionStorageSendBuffer.prototype.enqueue.\r\n// Removed Stub for SessionStorageSendBuffer.prototype.clear.\r\n// Removed Stub for SessionStorageSendBuffer.prototype.markAsSent.\r\n// Removed Stub for SessionStorageSendBuffer.prototype.clearSent.\r\n// Removed Stub for SessionStorageSendBuffer.prototype.createNew.\r\n var _a;\r\n _a = SessionStorageSendBuffer;\r\n SessionStorageSendBuffer.VERSION = \"_1\";\r\n SessionStorageSendBuffer.BUFFER_KEY = \"AI_buffer\" + _a.VERSION;\r\n SessionStorageSendBuffer.SENT_BUFFER_KEY = \"AI_sentBuffer\" + _a.VERSION;\r\n // Maximum number of payloads stored in the buffer. If the buffer is full, new elements will be dropped.\r\n SessionStorageSendBuffer.MAX_BUFFER_SIZE = 2000;\r\n return SessionStorageSendBuffer;\r\n}(BaseSendBuffer));\r\nexport { SessionStorageSendBuffer };\r\n//# sourceMappingURL=SendBuffer.js.map","/*\n * Application Insights JavaScript SDK - Channel, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { _throwInternal, getJSON, isArray, isFunction, isObject, objForEachKey } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_LENGTH, _DYN_PUSH, _DYN_STRINGIFY, _DYN_TO_STRING } from \"./__DynamicConstants\";\r\nvar Serializer = /** @class */ (function () {\r\n function Serializer(logger) {\r\n dynamicProto(Serializer, this, function (_self) {\r\n /**\r\n * Serializes the current object to a JSON string.\r\n */\r\n _self.serialize = function (input) {\r\n var output = _serializeObject(input, \"root\");\r\n try {\r\n return getJSON()[_DYN_STRINGIFY /* @min:%2estringify */](output);\r\n }\r\n catch (e) {\r\n // if serialization fails return an empty string\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 48 /* _eInternalMessageId.CannotSerializeObject */, (e && isFunction(e[_DYN_TO_STRING /* @min:%2etoString */])) ? e[_DYN_TO_STRING /* @min:%2etoString */]() : \"Error serializing object\", null, true);\r\n }\r\n };\r\n function _serializeObject(source, name) {\r\n var circularReferenceCheck = \"__aiCircularRefCheck\";\r\n var output = {};\r\n if (!source) {\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 48 /* _eInternalMessageId.CannotSerializeObject */, \"cannot serialize object because it is null or undefined\", { name: name }, true);\r\n return output;\r\n }\r\n if (source[circularReferenceCheck]) {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 50 /* _eInternalMessageId.CircularReferenceDetected */, \"Circular reference detected while serializing object\", { name: name }, true);\r\n return output;\r\n }\r\n if (!source.aiDataContract) {\r\n // special case for measurements/properties/tags\r\n if (name === \"measurements\") {\r\n output = _serializeStringMap(source, \"number\", name);\r\n }\r\n else if (name === \"properties\") {\r\n output = _serializeStringMap(source, \"string\", name);\r\n }\r\n else if (name === \"tags\") {\r\n output = _serializeStringMap(source, \"string\", name);\r\n }\r\n else if (isArray(source)) {\r\n output = _serializeArray(source, name);\r\n }\r\n else {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 49 /* _eInternalMessageId.CannotSerializeObjectNonSerializable */, \"Attempting to serialize an object which does not implement ISerializable\", { name: name }, true);\r\n try {\r\n // verify that the object can be stringified\r\n getJSON()[_DYN_STRINGIFY /* @min:%2estringify */](source);\r\n output = source;\r\n }\r\n catch (e) {\r\n // if serialization fails return an empty string\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 48 /* _eInternalMessageId.CannotSerializeObject */, (e && isFunction(e[_DYN_TO_STRING /* @min:%2etoString */])) ? e[_DYN_TO_STRING /* @min:%2etoString */]() : \"Error serializing object\", null, true);\r\n }\r\n }\r\n return output;\r\n }\r\n source[circularReferenceCheck] = true;\r\n objForEachKey(source.aiDataContract, function (field, contract) {\r\n var isRequired = (isFunction(contract)) ? (contract() & 1 /* FieldType.Required */) : (contract & 1 /* FieldType.Required */);\r\n var isHidden = (isFunction(contract)) ? (contract() & 4 /* FieldType.Hidden */) : (contract & 4 /* FieldType.Hidden */);\r\n var isArray = contract & 2 /* FieldType.Array */;\r\n var isPresent = source[field] !== undefined;\r\n var isObj = isObject(source[field]) && source[field] !== null;\r\n if (isRequired && !isPresent && !isArray) {\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 24 /* _eInternalMessageId.MissingRequiredFieldSpecification */, \"Missing required field specification. The field is required but not present on source\", { field: field, name: name });\r\n // If not in debug mode, continue and hope the error is permissible\r\n }\r\n else if (!isHidden) { // Don't serialize hidden fields\r\n var value = void 0;\r\n if (isObj) {\r\n if (isArray) {\r\n // special case; recurse on each object in the source array\r\n value = _serializeArray(source[field], field);\r\n }\r\n else {\r\n // recurse on the source object in this field\r\n value = _serializeObject(source[field], field);\r\n }\r\n }\r\n else {\r\n // assign the source field to the output even if undefined or required\r\n value = source[field];\r\n }\r\n // only emit this field if the value is defined\r\n if (value !== undefined) {\r\n output[field] = value;\r\n }\r\n }\r\n });\r\n delete source[circularReferenceCheck];\r\n return output;\r\n }\r\n function _serializeArray(sources, name) {\r\n var output;\r\n if (!!sources) {\r\n if (!isArray(sources)) {\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 54 /* _eInternalMessageId.ItemNotInArray */, \"This field was specified as an array in the contract but the item is not an array.\\r\\n\", { name: name }, true);\r\n }\r\n else {\r\n output = [];\r\n for (var i = 0; i < sources[_DYN_LENGTH /* @min:%2elength */]; i++) {\r\n var source = sources[i];\r\n var item = _serializeObject(source, name + \"[\" + i + \"]\");\r\n output[_DYN_PUSH /* @min:%2epush */](item);\r\n }\r\n }\r\n }\r\n return output;\r\n }\r\n function _serializeStringMap(map, expectedType, name) {\r\n var output;\r\n if (map) {\r\n output = {};\r\n objForEachKey(map, function (field, value) {\r\n if (expectedType === \"string\") {\r\n if (value === undefined) {\r\n output[field] = \"undefined\";\r\n }\r\n else if (value === null) {\r\n output[field] = \"null\";\r\n }\r\n else if (!value[_DYN_TO_STRING /* @min:%2etoString */]) {\r\n output[field] = \"invalid field: toString() is not defined.\";\r\n }\r\n else {\r\n output[field] = value[_DYN_TO_STRING /* @min:%2etoString */]();\r\n }\r\n }\r\n else if (expectedType === \"number\") {\r\n if (value === undefined) {\r\n output[field] = \"undefined\";\r\n }\r\n else if (value === null) {\r\n output[field] = \"null\";\r\n }\r\n else {\r\n var num = parseFloat(value);\r\n output[field] = num;\r\n }\r\n }\r\n else {\r\n output[field] = \"invalid field: \" + name + \" is of unknown type.\";\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, output[field], null, true);\r\n }\r\n });\r\n }\r\n return output;\r\n }\r\n });\r\n }\r\n// Removed Stub for Serializer.prototype.serialize.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n Serializer.__ieDyn=1;\n\n return Serializer;\r\n}());\r\nexport { Serializer };\r\n//# sourceMappingURL=Serializer.js.map","/*\n * Application Insights JavaScript SDK - Channel, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { _DYN_CONCAT, _DYN_LENGTH } from \"../../__DynamicConstants\";\r\n// (Magic number) DJB algorithm can't work on shorter strings (results in poor distribution\r\nvar MIN_INPUT_LENGTH = 8;\r\nvar HashCodeScoreGenerator = /** @class */ (function () {\r\n function HashCodeScoreGenerator() {\r\n }\r\n HashCodeScoreGenerator.prototype.getHashCodeScore = function (key) {\r\n var score = this.getHashCode(key) / HashCodeScoreGenerator.INT_MAX_VALUE;\r\n return score * 100;\r\n };\r\n HashCodeScoreGenerator.prototype.getHashCode = function (input) {\r\n if (input === \"\") {\r\n return 0;\r\n }\r\n while (input[_DYN_LENGTH /* @min:%2elength */] < MIN_INPUT_LENGTH) {\r\n input = input[_DYN_CONCAT /* @min:%2econcat */](input);\r\n }\r\n // 5381 is a magic number: http://stackoverflow.com/questions/10696223/reason-for-5381-number-in-djb-hash-function\r\n var hash = 5381;\r\n for (var i = 0; i < input[_DYN_LENGTH /* @min:%2elength */]; ++i) {\r\n hash = ((hash << 5) + hash) + input.charCodeAt(i);\r\n // 'hash' is of number type which means 53 bit integer (http://www.ecma-international.org/ecma-262/6.0/#sec-ecmascript-language-types-number-type)\r\n // 'hash & hash' will keep it 32 bit integer - just to make it clearer what the result is.\r\n hash = hash & hash;\r\n }\r\n return Math.abs(hash);\r\n };\r\n // We're using 32 bit math, hence max value is (2^31 - 1)\r\n HashCodeScoreGenerator.INT_MAX_VALUE = 2147483647;\r\n return HashCodeScoreGenerator;\r\n}());\r\nexport { HashCodeScoreGenerator };\r\n//# sourceMappingURL=HashCodeScoreGenerator.js.map","/*\n * Application Insights JavaScript SDK - Channel, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { ContextTagKeys } from \"@microsoft/applicationinsights-common\";\r\nimport { _DYN_GET_HASH_CODE_SCORE, _DYN_TAGS, _DYN_TRACE_ID } from \"../../__DynamicConstants\";\r\nimport { HashCodeScoreGenerator } from \"./HashCodeScoreGenerator\";\r\nvar SamplingScoreGenerator = /** @class */ (function () {\r\n function SamplingScoreGenerator() {\r\n var _self = this;\r\n var hashCodeGenerator = new HashCodeScoreGenerator();\r\n var keys = new ContextTagKeys();\r\n _self.getSamplingScore = function (item) {\r\n var score = 0;\r\n if (item[_DYN_TAGS /* @min:%2etags */] && item[_DYN_TAGS /* @min:%2etags */][keys.userId]) { // search in tags first, then ext\r\n score = hashCodeGenerator.getHashCodeScore(item[_DYN_TAGS /* @min:%2etags */][keys.userId]);\r\n }\r\n else if (item.ext && item.ext.user && item.ext.user.id) {\r\n score = hashCodeGenerator[_DYN_GET_HASH_CODE_SCORE /* @min:%2egetHashCodeScore */](item.ext.user.id);\r\n }\r\n else if (item[_DYN_TAGS /* @min:%2etags */] && item[_DYN_TAGS /* @min:%2etags */][keys.operationId]) { // search in tags first, then ext\r\n score = hashCodeGenerator.getHashCodeScore(item[_DYN_TAGS /* @min:%2etags */][keys.operationId]);\r\n }\r\n else if (item.ext && item.ext.telemetryTrace && item.ext.telemetryTrace[_DYN_TRACE_ID /* @min:%2etraceID */]) {\r\n score = hashCodeGenerator.getHashCodeScore(item.ext.telemetryTrace[_DYN_TRACE_ID /* @min:%2etraceID */]);\r\n }\r\n else {\r\n // tslint:disable-next-line:insecure-random\r\n score = (Math.random() * 100);\r\n }\r\n return score;\r\n };\r\n }\r\n return SamplingScoreGenerator;\r\n}());\r\nexport { SamplingScoreGenerator };\r\n//# sourceMappingURL=SamplingScoreGenerator.js.map","/*\n * Application Insights JavaScript SDK - Channel, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { Metric } from \"@microsoft/applicationinsights-common\";\r\nimport { safeGetLogger } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_DATA_TYPE, _DYN_SAMPLE_RATE } from \"../__DynamicConstants\";\r\nimport { SamplingScoreGenerator } from \"./SamplingScoreGenerators/SamplingScoreGenerator\";\r\nvar Sample = /** @class */ (function () {\r\n function Sample(sampleRate, logger) {\r\n // We're using 32 bit math, hence max value is (2^31 - 1)\r\n this.INT_MAX_VALUE = 2147483647;\r\n var _logger = logger || safeGetLogger(null);\r\n if (sampleRate > 100 || sampleRate < 0) {\r\n _logger.throwInternal(2 /* eLoggingSeverity.WARNING */, 58 /* _eInternalMessageId.SampleRateOutOfRange */, \"Sampling rate is out of range (0..100). Sampling will be disabled, you may be sending too much data which may affect your AI service level.\", { samplingRate: sampleRate }, true);\r\n sampleRate = 100;\r\n }\r\n this[_DYN_SAMPLE_RATE /* @min:%2esampleRate */] = sampleRate;\r\n this.samplingScoreGenerator = new SamplingScoreGenerator();\r\n }\r\n /**\r\n * Determines if an envelope is sampled in (i.e. will be sent) or not (i.e. will be dropped).\r\n */\r\n Sample.prototype.isSampledIn = function (envelope) {\r\n var samplingPercentage = this[_DYN_SAMPLE_RATE /* @min:%2esampleRate */]; // 0 - 100\r\n var isSampledIn = false;\r\n if (samplingPercentage === null || samplingPercentage === undefined || samplingPercentage >= 100) {\r\n return true;\r\n }\r\n else if (envelope.baseType === Metric[_DYN_DATA_TYPE /* @min:%2edataType */]) {\r\n // exclude MetricData telemetry from sampling\r\n return true;\r\n }\r\n isSampledIn = this.samplingScoreGenerator.getSamplingScore(envelope) < samplingPercentage;\r\n return isSampledIn;\r\n };\r\n return Sample;\r\n}());\r\nexport { Sample };\r\n//# sourceMappingURL=Sample.js.map","/*\n * Application Insights JavaScript SDK - Channel, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nvar _a, _b;\r\nimport { __assignFn as __assign, __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { BreezeChannelIdentifier, DEFAULT_BREEZE_ENDPOINT, DEFAULT_BREEZE_PATH, Event, Exception, Metric, PageView, PageViewPerformance, ProcessLegacy, RemoteDependencyData, RequestHeaders, SampleRate, Trace, createOfflineListener, isInternalApplicationInsightsEndpoint, utlCanUseSessionStorage, utlSetStoragePrefix } from \"@microsoft/applicationinsights-common\";\r\nimport { ActiveStatus, BaseTelemetryPlugin, SenderPostManager, _throwInternal, _warnToConsole, arrForEach, cfgDfBoolean, cfgDfValidate, createProcessTelemetryContext, createUniqueNamespace, dateNow, dumpObj, formatErrorMessageXdr, formatErrorMessageXhr, getExceptionName, getIEVersion, isArray, isBeaconsSupported, isFetchSupported, isNullOrUndefined, mergeEvtNamespace, objExtend, onConfigChange, parseResponse, prependTransports, runTargetUnload } from \"@microsoft/applicationinsights-core-js\";\r\nimport { isNumber, isPromiseLike, isString, isTruthy, mathFloor, mathMax, mathMin, objDeepFreeze, objDefine, scheduleTimeout } from \"@nevware21/ts-utils\";\r\nimport { DependencyEnvelopeCreator, EventEnvelopeCreator, ExceptionEnvelopeCreator, MetricEnvelopeCreator, PageViewEnvelopeCreator, PageViewPerformanceEnvelopeCreator, TraceEnvelopeCreator } from \"./EnvelopeCreator\";\r\nimport { ArraySendBuffer, SessionStorageSendBuffer } from \"./SendBuffer\";\r\nimport { Serializer } from \"./Serializer\";\r\nimport { Sample } from \"./TelemetryProcessors/Sample\";\r\nimport { _DYN_ALWAYS_USE_XHR_OVERR4, _DYN_BASE_TYPE, _DYN_BUFFER_OVERRIDE, _DYN_CLEAR, _DYN_CLEAR_SENT, _DYN_COUNT, _DYN_CUSTOM_HEADERS, _DYN_DIAG_LOG, _DYN_DISABLE_SEND_BEACON_7, _DYN_EMIT_LINE_DELIMITED_0, _DYN_ENABLE_SESSION_STORA5, _DYN_ENDPOINT_URL, _DYN_ENQUEUE, _DYN_GET_SENDER_INST, _DYN_INITIALIZE, _DYN_INSTRUMENTATION_KEY, _DYN_IS_BEACON_API_DISABL3, _DYN_ITEMS_ACCEPTED, _DYN_ITEMS_RECEIVED, _DYN_LENGTH, _DYN_MARK_AS_SENT, _DYN_MAX_BATCH_SIZE_IN_BY1, _DYN_ONUNLOAD_DISABLE_BEA2, _DYN_ONUNLOAD_DISABLE_FET6, _DYN_PUSH, _DYN_SAMPLE_RATE, _DYN_TAGS, _DYN_TRIGGER_SEND, _DYN__BUFFER, _DYN__ON_ERROR, _DYN__ON_PARTIAL_SUCCESS, _DYN__ON_SUCCESS, _DYN__SENDER } from \"./__DynamicConstants\";\r\nvar UNDEFINED_VALUE = undefined;\r\nvar EMPTY_STR = \"\";\r\nvar FetchSyncRequestSizeLimitBytes = 65000; // approx 64kb (the current Edge, Firefox and Chrome max limit)\r\nfunction _getResponseText(xhr) {\r\n try {\r\n return xhr.responseText;\r\n }\r\n catch (e) {\r\n // Best effort, as XHR may throw while XDR wont so just ignore\r\n }\r\n return null;\r\n}\r\nfunction isOverrideFn(httpXHROverride) {\r\n return httpXHROverride && httpXHROverride.sendPOST;\r\n}\r\nvar defaultAppInsightsChannelConfig = objDeepFreeze((_a = {\r\n // Use the default value (handles empty string in the configuration)\r\n endpointUrl: cfgDfValidate(isTruthy, DEFAULT_BREEZE_ENDPOINT + DEFAULT_BREEZE_PATH)\r\n },\r\n _a[_DYN_EMIT_LINE_DELIMITED_0 /* @min:emitLineDelimitedJson */] = cfgDfBoolean(),\r\n _a.maxBatchInterval = 15000,\r\n _a[_DYN_MAX_BATCH_SIZE_IN_BY1 /* @min:maxBatchSizeInBytes */] = 102400,\r\n _a.disableTelemetry = cfgDfBoolean(),\r\n _a[_DYN_ENABLE_SESSION_STORA5 /* @min:enableSessionStorageBuffer */] = cfgDfBoolean(true),\r\n _a.isRetryDisabled = cfgDfBoolean(),\r\n _a[_DYN_IS_BEACON_API_DISABL3 /* @min:isBeaconApiDisabled */] = cfgDfBoolean(true),\r\n _a[_DYN_DISABLE_SEND_BEACON_7 /* @min:disableSendBeaconSplit */] = cfgDfBoolean(true),\r\n _a.disableXhr = cfgDfBoolean(),\r\n _a[_DYN_ONUNLOAD_DISABLE_FET6 /* @min:onunloadDisableFetch */] = cfgDfBoolean(),\r\n _a[_DYN_ONUNLOAD_DISABLE_BEA2 /* @min:onunloadDisableBeacon */] = cfgDfBoolean(),\r\n _a[_DYN_INSTRUMENTATION_KEY /* @min:instrumentationKey */] = UNDEFINED_VALUE,\r\n _a.namePrefix = UNDEFINED_VALUE,\r\n _a.samplingPercentage = cfgDfValidate(_chkSampling, 100),\r\n _a[_DYN_CUSTOM_HEADERS /* @min:customHeaders */] = UNDEFINED_VALUE,\r\n _a.convertUndefined = UNDEFINED_VALUE,\r\n _a.eventsLimitInMem = 10000,\r\n _a[_DYN_BUFFER_OVERRIDE /* @min:bufferOverride */] = false,\r\n _a.httpXHROverride = { isVal: isOverrideFn, v: UNDEFINED_VALUE },\r\n _a[_DYN_ALWAYS_USE_XHR_OVERR4 /* @min:alwaysUseXhrOverride */] = cfgDfBoolean(),\r\n _a.transports = UNDEFINED_VALUE,\r\n _a.retryCodes = UNDEFINED_VALUE,\r\n _a.maxRetryCnt = { isVal: isNumber, v: 10 },\r\n _a));\r\nfunction _chkSampling(value) {\r\n return !isNaN(value) && value > 0 && value <= 100;\r\n}\r\nvar EnvelopeTypeCreator = (_b = {},\r\n _b[Event.dataType] = EventEnvelopeCreator,\r\n _b[Trace.dataType] = TraceEnvelopeCreator,\r\n _b[PageView.dataType] = PageViewEnvelopeCreator,\r\n _b[PageViewPerformance.dataType] = PageViewPerformanceEnvelopeCreator,\r\n _b[Exception.dataType] = ExceptionEnvelopeCreator,\r\n _b[Metric.dataType] = MetricEnvelopeCreator,\r\n _b[RemoteDependencyData.dataType] = DependencyEnvelopeCreator,\r\n _b);\r\nvar Sender = /** @class */ (function (_super) {\r\n __extends(Sender, _super);\r\n function Sender() {\r\n var _this = _super.call(this) || this;\r\n _this.priority = 1001;\r\n _this.identifier = BreezeChannelIdentifier;\r\n // Don't set the defaults here, set them in the _initDefaults() as this is also called during unload\r\n var _consecutiveErrors; // How many times in a row a retryable error condition has occurred.\r\n var _retryAt; // The time to retry at in milliseconds from 1970/01/01 (this makes the timer calculation easy).\r\n var _lastSend; // The time of the last send operation.\r\n var _paused; // Flag indicating that the sending should be paused\r\n var _timeoutHandle; // Handle to the timer for delayed sending of batches of data.\r\n var _serializer;\r\n var _stamp_specific_redirects;\r\n var _headers;\r\n var _syncFetchPayload = 0; // Keep track of the outstanding sync fetch payload total (as sync fetch has limits)\r\n var _syncUnloadSender; // The identified sender to use for the synchronous unload stage\r\n var _offlineListener;\r\n var _evtNamespace;\r\n var _endpointUrl;\r\n var _orgEndpointUrl;\r\n var _maxBatchSizeInBytes;\r\n var _beaconSupported;\r\n var _beaconOnUnloadSupported;\r\n var _beaconNormalSupported;\r\n var _customHeaders;\r\n var _disableTelemetry;\r\n var _instrumentationKey;\r\n var _convertUndefined;\r\n var _isRetryDisabled;\r\n var _maxBatchInterval;\r\n var _sessionStorageUsed;\r\n var _bufferOverrideUsed;\r\n var _namePrefix;\r\n var _enableSendPromise;\r\n var _alwaysUseCustomSend;\r\n var _disableXhr;\r\n var _fetchKeepAlive;\r\n var _xhrSend;\r\n var _fallbackSend;\r\n var _disableBeaconSplit;\r\n var _sendPostMgr;\r\n var _retryCodes;\r\n dynamicProto(Sender, _this, function (_self, _base) {\r\n _initDefaults();\r\n _self.pause = function () {\r\n _clearScheduledTimer();\r\n _paused = true;\r\n };\r\n _self.resume = function () {\r\n if (_paused) {\r\n _paused = false;\r\n _retryAt = null;\r\n // flush if we have exceeded the max-size already\r\n _checkMaxSize();\r\n _setupTimer();\r\n }\r\n };\r\n _self.flush = function (isAsync, callBack, sendReason) {\r\n if (isAsync === void 0) { isAsync = true; }\r\n if (!_paused) {\r\n // Clear the normal schedule timer as we are going to try and flush ASAP\r\n _clearScheduledTimer();\r\n try {\r\n return _self[_DYN_TRIGGER_SEND /* @min:%2etriggerSend */](isAsync, null, sendReason || 1 /* SendRequestReason.ManualFlush */);\r\n }\r\n catch (e) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 22 /* _eInternalMessageId.FlushFailed */, \"flush failed, telemetry will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n };\r\n _self.onunloadFlush = function () {\r\n if (!_paused) {\r\n if (_beaconSupported || _alwaysUseCustomSend) {\r\n try {\r\n return _self[_DYN_TRIGGER_SEND /* @min:%2etriggerSend */](true, _doUnloadSend, 2 /* SendRequestReason.Unload */);\r\n }\r\n catch (e) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 20 /* _eInternalMessageId.FailedToSendQueuedTelemetry */, \"failed to flush with beacon sender on page unload, telemetry will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n else {\r\n _self.flush(false);\r\n }\r\n }\r\n };\r\n _self.addHeader = function (name, value) {\r\n _headers[name] = value;\r\n };\r\n _self[_DYN_INITIALIZE /* @min:%2einitialize */] = function (config, core, extensions, pluginChain) {\r\n if (_self.isInitialized()) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 28 /* _eInternalMessageId.SenderNotInitialized */, \"Sender is already initialized\");\r\n }\r\n _base[_DYN_INITIALIZE /* @min:%2einitialize */](config, core, extensions, pluginChain);\r\n var identifier = _self.identifier;\r\n _serializer = new Serializer(core.logger);\r\n _consecutiveErrors = 0;\r\n _retryAt = null;\r\n _lastSend = 0;\r\n _self[_DYN__SENDER /* @min:%2e_sender */] = null;\r\n _stamp_specific_redirects = 0;\r\n var diagLog = _self[_DYN_DIAG_LOG /* @min:%2ediagLog */]();\r\n _evtNamespace = mergeEvtNamespace(createUniqueNamespace(\"Sender\"), core.evtNamespace && core.evtNamespace());\r\n _offlineListener = createOfflineListener(_evtNamespace);\r\n // This function will be re-called whenever any referenced configuration is changed\r\n _self._addHook(onConfigChange(config, function (details) {\r\n var config = details.cfg;\r\n if (config.storagePrefix) {\r\n utlSetStoragePrefix(config.storagePrefix);\r\n }\r\n var ctx = createProcessTelemetryContext(null, config, core);\r\n // getExtCfg only finds undefined values from core\r\n var senderConfig = ctx.getExtCfg(identifier, defaultAppInsightsChannelConfig);\r\n var curExtUrl = senderConfig[_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */];\r\n // if it is not inital change (_endpointUrl has value)\r\n // if current sender endpoint url is not changed directly\r\n // means ExtCfg is not changed directly\r\n // then we need to monitor endpoint url changes from core\r\n if (_endpointUrl && curExtUrl === _endpointUrl) {\r\n var coreUrl = config[_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */];\r\n // if core endpoint url is changed\r\n if (coreUrl && coreUrl !== curExtUrl) {\r\n // and endpoint promise changes is handled by this as well\r\n senderConfig[_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */] = coreUrl;\r\n }\r\n }\r\n if (isPromiseLike(senderConfig[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */])) {\r\n // if it is promise, means the endpoint url is from core.endpointurl\r\n senderConfig[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */] = config[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */];\r\n }\r\n objDefine(_self, \"_senderConfig\", {\r\n g: function () {\r\n return senderConfig;\r\n }\r\n });\r\n // Only update the endpoint if the original config !== the current config\r\n // This is so any redirect endpointUrl is not overwritten\r\n if (_orgEndpointUrl !== senderConfig[_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */]) {\r\n if (_orgEndpointUrl) {\r\n // TODO: add doc to remind users to flush before changing endpoint, otherwise all unsent payload will be sent to new endpoint\r\n }\r\n _endpointUrl = _orgEndpointUrl = senderConfig[_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */];\r\n }\r\n // or is not string\r\n if (core.activeStatus() === ActiveStatus.PENDING) {\r\n // waiting for core promises to be resolved\r\n // NOTE: if active status is set to pending, stop sending, clear timer here\r\n _self.pause();\r\n }\r\n else if (core.activeStatus() === ActiveStatus.ACTIVE) {\r\n // core status changed from pending to other status\r\n _self.resume();\r\n }\r\n if (_customHeaders && _customHeaders !== senderConfig[_DYN_CUSTOM_HEADERS /* @min:%2ecustomHeaders */]) {\r\n // Removing any previously defined custom headers as they have changed\r\n arrForEach(_customHeaders, function (customHeader) {\r\n delete _headers[customHeader.header];\r\n });\r\n }\r\n _maxBatchSizeInBytes = senderConfig[_DYN_MAX_BATCH_SIZE_IN_BY1 /* @min:%2emaxBatchSizeInBytes */];\r\n _beaconSupported = (senderConfig[_DYN_ONUNLOAD_DISABLE_BEA2 /* @min:%2eonunloadDisableBeacon */] === false || senderConfig[_DYN_IS_BEACON_API_DISABL3 /* @min:%2eisBeaconApiDisabled */] === false) && isBeaconsSupported();\r\n _beaconOnUnloadSupported = senderConfig[_DYN_ONUNLOAD_DISABLE_BEA2 /* @min:%2eonunloadDisableBeacon */] === false && isBeaconsSupported();\r\n _beaconNormalSupported = senderConfig[_DYN_IS_BEACON_API_DISABL3 /* @min:%2eisBeaconApiDisabled */] === false && isBeaconsSupported();\r\n _alwaysUseCustomSend = senderConfig[_DYN_ALWAYS_USE_XHR_OVERR4 /* @min:%2ealwaysUseXhrOverride */];\r\n _disableXhr = !!senderConfig.disableXhr;\r\n _retryCodes = senderConfig.retryCodes;\r\n var bufferOverride = senderConfig[_DYN_BUFFER_OVERRIDE /* @min:%2ebufferOverride */];\r\n var canUseSessionStorage = !!senderConfig[_DYN_ENABLE_SESSION_STORA5 /* @min:%2eenableSessionStorageBuffer */] &&\r\n (!!bufferOverride || utlCanUseSessionStorage());\r\n var namePrefix = senderConfig.namePrefix;\r\n //Note: emitLineDelimitedJson and eventsLimitInMem is directly accessed via config in senderBuffer\r\n //Therefore, if canUseSessionStorage is not changed, we do not need to re initialize a new one\r\n var shouldUpdate = (canUseSessionStorage !== _sessionStorageUsed)\r\n || (canUseSessionStorage && (_namePrefix !== namePrefix)) // prefixName is only used in session storage\r\n || (canUseSessionStorage && (_bufferOverrideUsed !== bufferOverride));\r\n if (_self[_DYN__BUFFER /* @min:%2e_buffer */]) {\r\n // case1 (Pre and Now enableSessionStorageBuffer settings are same)\r\n // if namePrefix changes, transfer current buffer to new buffer\r\n // else no action needed\r\n //case2 (Pre and Now enableSessionStorageBuffer settings are changed)\r\n // transfer current buffer to new buffer\r\n if (shouldUpdate) {\r\n try {\r\n _self[_DYN__BUFFER /* @min:%2e_buffer */] = _self[_DYN__BUFFER /* @min:%2e_buffer */].createNew(diagLog, senderConfig, canUseSessionStorage);\r\n }\r\n catch (e) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 12 /* _eInternalMessageId.FailedAddingTelemetryToBuffer */, \"failed to transfer telemetry to different buffer storage, telemetry will be lost: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n _checkMaxSize();\r\n }\r\n else {\r\n _self[_DYN__BUFFER /* @min:%2e_buffer */] = canUseSessionStorage\r\n ? new SessionStorageSendBuffer(diagLog, senderConfig) : new ArraySendBuffer(diagLog, senderConfig);\r\n }\r\n _namePrefix = namePrefix;\r\n _sessionStorageUsed = canUseSessionStorage;\r\n _bufferOverrideUsed = bufferOverride;\r\n _fetchKeepAlive = !senderConfig[_DYN_ONUNLOAD_DISABLE_FET6 /* @min:%2eonunloadDisableFetch */] && isFetchSupported(true);\r\n _disableBeaconSplit = !!senderConfig[_DYN_DISABLE_SEND_BEACON_7 /* @min:%2edisableSendBeaconSplit */];\r\n _self._sample = new Sample(senderConfig.samplingPercentage, diagLog);\r\n _instrumentationKey = senderConfig[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */];\r\n if (!isPromiseLike(_instrumentationKey) && !_validateInstrumentationKey(_instrumentationKey, config)) {\r\n _throwInternal(diagLog, 1 /* eLoggingSeverity.CRITICAL */, 100 /* _eInternalMessageId.InvalidInstrumentationKey */, \"Invalid Instrumentation key \" + _instrumentationKey);\r\n }\r\n _customHeaders = senderConfig[_DYN_CUSTOM_HEADERS /* @min:%2ecustomHeaders */];\r\n if (isString(_endpointUrl) && !isInternalApplicationInsightsEndpoint(_endpointUrl) && _customHeaders && _customHeaders[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n arrForEach(_customHeaders, function (customHeader) {\r\n _this.addHeader(customHeader.header, customHeader.value);\r\n });\r\n }\r\n else {\r\n _customHeaders = null;\r\n }\r\n _enableSendPromise = senderConfig.enableSendPromise;\r\n var sendPostConfig = _getSendPostMgrConfig();\r\n // only init it once\r\n if (!_sendPostMgr) {\r\n _sendPostMgr = new SenderPostManager();\r\n _sendPostMgr[_DYN_INITIALIZE /* @min:%2einitialize */](sendPostConfig, diagLog);\r\n }\r\n else {\r\n _sendPostMgr.SetConfig(sendPostConfig);\r\n }\r\n var customInterface = senderConfig.httpXHROverride;\r\n var httpInterface = null;\r\n var syncInterface = null;\r\n // User requested transport(s) values > Beacon > Fetch > XHR\r\n // Beacon would be filtered out if user has set disableBeaconApi to true at _getSenderInterface\r\n var theTransports = prependTransports([3 /* TransportType.Beacon */, 1 /* TransportType.Xhr */, 2 /* TransportType.Fetch */], senderConfig.transports);\r\n httpInterface = _sendPostMgr && _sendPostMgr[_DYN_GET_SENDER_INST /* @min:%2egetSenderInst */](theTransports, false);\r\n var xhrInterface = _sendPostMgr && _sendPostMgr.getFallbackInst();\r\n _xhrSend = function (payload, isAsync) {\r\n return _doSend(xhrInterface, payload, isAsync);\r\n };\r\n _fallbackSend = function (payload, isAsync) {\r\n return _doSend(xhrInterface, payload, isAsync, false);\r\n };\r\n httpInterface = _alwaysUseCustomSend ? customInterface : (httpInterface || customInterface || xhrInterface);\r\n _self[_DYN__SENDER /* @min:%2e_sender */] = function (payload, isAsync) {\r\n return _doSend(httpInterface, payload, isAsync);\r\n };\r\n if (_fetchKeepAlive) {\r\n // Try and use the fetch with keepalive\r\n _syncUnloadSender = _fetchKeepAliveSender;\r\n }\r\n var syncTransports = prependTransports([3 /* TransportType.Beacon */, 1 /* TransportType.Xhr */], senderConfig.unloadTransports);\r\n if (!_fetchKeepAlive) {\r\n // remove fetch from theTransports\r\n syncTransports = syncTransports.filter(function (transport) { return transport !== 2 /* TransportType.Fetch */; });\r\n }\r\n syncInterface = _sendPostMgr && _sendPostMgr[_DYN_GET_SENDER_INST /* @min:%2egetSenderInst */](syncTransports, true);\r\n syncInterface = _alwaysUseCustomSend ? customInterface : (syncInterface || customInterface);\r\n if ((_alwaysUseCustomSend || senderConfig.unloadTransports || !_syncUnloadSender) && syncInterface) {\r\n _syncUnloadSender = function (payload, isAsync) {\r\n return _doSend(syncInterface, payload, isAsync);\r\n };\r\n }\r\n if (!_syncUnloadSender) {\r\n _syncUnloadSender = _xhrSend;\r\n }\r\n _disableTelemetry = senderConfig.disableTelemetry;\r\n _convertUndefined = senderConfig.convertUndefined || UNDEFINED_VALUE;\r\n _isRetryDisabled = senderConfig.isRetryDisabled;\r\n _maxBatchInterval = senderConfig.maxBatchInterval;\r\n }));\r\n };\r\n _self.processTelemetry = function (telemetryItem, itemCtx) {\r\n itemCtx = _self._getTelCtx(itemCtx);\r\n var diagLogger = itemCtx[_DYN_DIAG_LOG /* @min:%2ediagLog */]();\r\n try {\r\n var isValidate = _validate(telemetryItem, diagLogger);\r\n if (!isValidate) {\r\n return;\r\n }\r\n var aiEnvelope = _getEnvelope(telemetryItem, diagLogger);\r\n if (!aiEnvelope) {\r\n return;\r\n }\r\n // check if the incoming payload is too large, truncate if necessary\r\n var payload = _serializer.serialize(aiEnvelope);\r\n // flush if we would exceed the max-size limit by adding this item\r\n var buffer = _self[_DYN__BUFFER /* @min:%2e_buffer */];\r\n _checkMaxSize(payload);\r\n var payloadItem = {\r\n item: payload,\r\n cnt: 0 // inital cnt will always be 0\r\n };\r\n // enqueue the payload\r\n buffer[_DYN_ENQUEUE /* @min:%2eenqueue */](payloadItem);\r\n // ensure an invocation timeout is set\r\n _setupTimer();\r\n }\r\n catch (e) {\r\n _throwInternal(diagLogger, 2 /* eLoggingSeverity.WARNING */, 12 /* _eInternalMessageId.FailedAddingTelemetryToBuffer */, \"Failed adding telemetry to the sender's buffer, some telemetry will be lost: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n // hand off the telemetry item to the next plugin\r\n _self.processNext(telemetryItem, itemCtx);\r\n };\r\n _self.isCompletelyIdle = function () {\r\n return !_paused && _syncFetchPayload === 0 && _self._buffer[_DYN_COUNT /* @min:%2ecount */]() === 0;\r\n };\r\n _self.getOfflineListener = function () {\r\n return _offlineListener;\r\n };\r\n /**\r\n * xhr state changes\r\n */\r\n _self._xhrReadyStateChange = function (xhr, payload, countOfItemsInPayload) {\r\n // since version 3.2.0, this function is no-op\r\n if (_isStringArr(payload)) {\r\n return;\r\n }\r\n return _xhrReadyStateChange(xhr, payload, countOfItemsInPayload);\r\n };\r\n /**\r\n * Immediately send buffered data\r\n * @param async - Indicates if the events should be sent asynchronously\r\n * @param forcedSender - Indicates the forcedSender, undefined if not passed\r\n */\r\n _self[_DYN_TRIGGER_SEND /* @min:%2etriggerSend */] = function (async, forcedSender, sendReason) {\r\n if (async === void 0) { async = true; }\r\n var result;\r\n if (!_paused) {\r\n try {\r\n var buffer = _self[_DYN__BUFFER /* @min:%2e_buffer */];\r\n // Send data only if disableTelemetry is false\r\n if (!_disableTelemetry) {\r\n if (buffer[_DYN_COUNT /* @min:%2ecount */]() > 0) {\r\n var payload = buffer.getItems();\r\n _notifySendRequest(sendReason || 0 /* SendRequestReason.Undefined */, async);\r\n // invoke send\r\n if (forcedSender) {\r\n result = forcedSender.call(_self, payload, async);\r\n }\r\n else {\r\n result = _self[_DYN__SENDER /* @min:%2e_sender */](payload, async);\r\n }\r\n }\r\n // update lastSend time to enable throttling\r\n _lastSend = +new Date;\r\n }\r\n else {\r\n buffer[_DYN_CLEAR /* @min:%2eclear */]();\r\n }\r\n _clearScheduledTimer();\r\n }\r\n catch (e) {\r\n /* Ignore this error for IE under v10 */\r\n var ieVer = getIEVersion();\r\n if (!ieVer || ieVer > 9) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 40 /* _eInternalMessageId.TransmissionFailed */, \"Telemetry transmission failed, some telemetry will be lost: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n }\r\n return result;\r\n };\r\n _self.getOfflineSupport = function () {\r\n return {\r\n getUrl: function () {\r\n return _endpointUrl;\r\n },\r\n createPayload: _createPayload,\r\n serialize: _serialize,\r\n batch: _batch,\r\n shouldProcess: function (evt) {\r\n return !!_validate(evt);\r\n }\r\n };\r\n };\r\n _self._doTeardown = function (unloadCtx, unloadState) {\r\n _self.onunloadFlush();\r\n runTargetUnload(_offlineListener, false);\r\n _initDefaults();\r\n };\r\n /**\r\n * error handler\r\n */\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */] = function (payload, message, event) {\r\n // since version 3.1.3, string[] is no-op\r\n if (_isStringArr(payload)) {\r\n return;\r\n }\r\n return _onError(payload, message, event);\r\n };\r\n /**\r\n * partial success handler\r\n */\r\n _self[_DYN__ON_PARTIAL_SUCCESS /* @min:%2e_onPartialSuccess */] = function (payload, results) {\r\n // since version 3.1.3, string[] is no-op\r\n if (_isStringArr(payload)) {\r\n return;\r\n }\r\n return _onPartialSuccess(payload, results);\r\n };\r\n /**\r\n * success handler\r\n */\r\n _self[_DYN__ON_SUCCESS /* @min:%2e_onSuccess */] = function (payload, countOfItemsInPayload) {\r\n // since version 3.1.3, string[] is no-op\r\n if (_isStringArr(payload)) {\r\n return;\r\n }\r\n return _onSuccess(payload, countOfItemsInPayload);\r\n //_self._buffer && _self._buffer.clearSent(payload);\r\n };\r\n /**\r\n * xdr state changes\r\n */\r\n _self._xdrOnLoad = function (xdr, payload) {\r\n // since version 3.1.3, string[] is no-op\r\n if (_isStringArr(payload)) {\r\n return;\r\n }\r\n return _xdrOnLoad(xdr, payload);\r\n };\r\n function _xdrOnLoad(xdr, payload) {\r\n var responseText = _getResponseText(xdr);\r\n if (xdr && (responseText + \"\" === \"200\" || responseText === \"\")) {\r\n _consecutiveErrors = 0;\r\n _self[_DYN__ON_SUCCESS /* @min:%2e_onSuccess */](payload, 0);\r\n }\r\n else {\r\n var results = parseResponse(responseText);\r\n if (results && results[_DYN_ITEMS_RECEIVED /* @min:%2eitemsReceived */] && results[_DYN_ITEMS_RECEIVED /* @min:%2eitemsReceived */] > results[_DYN_ITEMS_ACCEPTED /* @min:%2eitemsAccepted */]\r\n && !_isRetryDisabled) {\r\n _self[_DYN__ON_PARTIAL_SUCCESS /* @min:%2e_onPartialSuccess */](payload, results);\r\n }\r\n else {\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, formatErrorMessageXdr(xdr));\r\n }\r\n }\r\n }\r\n function _getSendPostMgrConfig() {\r\n try {\r\n var onCompleteFuncs = {\r\n xdrOnComplete: function (xdr, oncomplete, payload) {\r\n var data = _getPayloadArr(payload);\r\n if (!data) {\r\n return;\r\n }\r\n return _xdrOnLoad(xdr, data);\r\n },\r\n fetchOnComplete: function (response, onComplete, resValue, payload) {\r\n var data = _getPayloadArr(payload);\r\n if (!data) {\r\n return;\r\n }\r\n return _checkResponsStatus(response.status, data, response.url, data[_DYN_LENGTH /* @min:%2elength */], response.statusText, resValue || \"\");\r\n },\r\n xhrOnComplete: function (request, oncomplete, payload) {\r\n var data = _getPayloadArr(payload);\r\n if (!data) {\r\n return;\r\n }\r\n return _xhrReadyStateChange(request, data, data[_DYN_LENGTH /* @min:%2elength */]);\r\n },\r\n beaconOnRetry: function (data, onComplete, canSend) {\r\n return _onBeaconRetry(data, onComplete, canSend);\r\n }\r\n };\r\n var config = {\r\n enableSendPromise: _enableSendPromise,\r\n isOneDs: false,\r\n disableCredentials: false,\r\n disableXhr: _disableXhr,\r\n disableBeacon: !_beaconNormalSupported,\r\n disableBeaconSync: !_beaconOnUnloadSupported,\r\n senderOnCompleteCallBack: onCompleteFuncs\r\n };\r\n return config;\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return null;\r\n }\r\n /**\r\n * xhr state changes\r\n */\r\n function _xhrReadyStateChange(xhr, payload, countOfItemsInPayload) {\r\n if (xhr.readyState === 4) {\r\n _checkResponsStatus(xhr.status, payload, xhr.responseURL, countOfItemsInPayload, formatErrorMessageXhr(xhr), _getResponseText(xhr) || xhr.response);\r\n }\r\n }\r\n /**\r\n * error handler\r\n */\r\n function _onError(payload, message, event) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 26 /* _eInternalMessageId.OnError */, \"Failed to send telemetry.\", { message: message });\r\n _self._buffer && _self._buffer[_DYN_CLEAR_SENT /* @min:%2eclearSent */](payload);\r\n }\r\n /**\r\n * partial success handler\r\n */\r\n function _onPartialSuccess(payload, results) {\r\n var failed = [];\r\n var retry = [];\r\n // Iterate through the reversed array of errors so that splicing doesn't have invalid indexes after the first item.\r\n var errors = results.errors.reverse();\r\n for (var _i = 0, errors_1 = errors; _i < errors_1.length; _i++) {\r\n var error = errors_1[_i];\r\n var extracted = payload.splice(error.index, 1)[0];\r\n if (_isRetriable(error.statusCode)) {\r\n retry[_DYN_PUSH /* @min:%2epush */](extracted);\r\n }\r\n else {\r\n // All other errors, including: 402 (Monthly quota exceeded) and 439 (Too many requests and refresh cache).\r\n failed[_DYN_PUSH /* @min:%2epush */](extracted);\r\n }\r\n }\r\n if (payload[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n _self[_DYN__ON_SUCCESS /* @min:%2e_onSuccess */](payload, results[_DYN_ITEMS_ACCEPTED /* @min:%2eitemsAccepted */]);\r\n }\r\n if (failed[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */](failed, formatErrorMessageXhr(null, [\"partial success\", results[_DYN_ITEMS_ACCEPTED /* @min:%2eitemsAccepted */], \"of\", results.itemsReceived].join(\" \")));\r\n }\r\n if (retry[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n _resendPayload(retry);\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \"Partial success. \" +\r\n \"Delivered: \" + payload[_DYN_LENGTH /* @min:%2elength */] + \", Failed: \" + failed[_DYN_LENGTH /* @min:%2elength */] +\r\n \". Will retry to send \" + retry[_DYN_LENGTH /* @min:%2elength */] + \" our of \" + results[_DYN_ITEMS_RECEIVED /* @min:%2eitemsReceived */] + \" items\");\r\n }\r\n }\r\n /**\r\n * success handler\r\n */\r\n function _onSuccess(payload, countOfItemsInPayload) {\r\n _self._buffer && _self._buffer[_DYN_CLEAR_SENT /* @min:%2eclearSent */](payload);\r\n }\r\n function _getPayloadArr(payload) {\r\n try {\r\n if (payload) {\r\n var internalPayload = payload;\r\n var arr = internalPayload.oriPayload;\r\n if (arr && arr[_DYN_LENGTH /* @min:%2elength */]) {\r\n return arr;\r\n }\r\n return null;\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return null;\r\n }\r\n function _validate(telemetryItem, diagLogger) {\r\n if (_disableTelemetry) {\r\n // Do not send/save data\r\n return false;\r\n }\r\n // validate input\r\n if (!telemetryItem) {\r\n diagLogger && _throwInternal(diagLogger, 1 /* eLoggingSeverity.CRITICAL */, 7 /* _eInternalMessageId.CannotSendEmptyTelemetry */, \"Cannot send empty telemetry\");\r\n return false;\r\n }\r\n // validate event\r\n if (telemetryItem.baseData && !telemetryItem[_DYN_BASE_TYPE /* @min:%2ebaseType */]) {\r\n diagLogger && _throwInternal(diagLogger, 1 /* eLoggingSeverity.CRITICAL */, 70 /* _eInternalMessageId.InvalidEvent */, \"Cannot send telemetry without baseData and baseType\");\r\n return false;\r\n }\r\n if (!telemetryItem[_DYN_BASE_TYPE /* @min:%2ebaseType */]) {\r\n // Default\r\n telemetryItem[_DYN_BASE_TYPE /* @min:%2ebaseType */] = \"EventData\";\r\n }\r\n // ensure a sender was constructed\r\n if (!_self[_DYN__SENDER /* @min:%2e_sender */]) {\r\n diagLogger && _throwInternal(diagLogger, 1 /* eLoggingSeverity.CRITICAL */, 28 /* _eInternalMessageId.SenderNotInitialized */, \"Sender was not initialized\");\r\n return false;\r\n }\r\n // check if this item should be sampled in, else add sampleRate tag\r\n if (!_isSampledIn(telemetryItem)) {\r\n // Item is sampled out, do not send it\r\n diagLogger && _throwInternal(diagLogger, 2 /* eLoggingSeverity.WARNING */, 33 /* _eInternalMessageId.TelemetrySampledAndNotSent */, \"Telemetry item was sampled out and not sent\", { SampleRate: _self._sample[_DYN_SAMPLE_RATE /* @min:%2esampleRate */] });\r\n return false;\r\n }\r\n else {\r\n telemetryItem[SampleRate] = _self._sample[_DYN_SAMPLE_RATE /* @min:%2esampleRate */];\r\n }\r\n return true;\r\n }\r\n function _getEnvelope(telemetryItem, diagLogger) {\r\n // construct an envelope that Application Insights endpoint can understand\r\n // if ikey of telemetry is provided and not empty, envelope will use this iKey instead of senderConfig iKey\r\n var defaultEnvelopeIkey = telemetryItem.iKey || _instrumentationKey;\r\n var aiEnvelope = Sender.constructEnvelope(telemetryItem, defaultEnvelopeIkey, diagLogger, _convertUndefined);\r\n if (!aiEnvelope) {\r\n _throwInternal(diagLogger, 1 /* eLoggingSeverity.CRITICAL */, 47 /* _eInternalMessageId.CreateEnvelopeError */, \"Unable to create an AppInsights envelope\");\r\n return;\r\n }\r\n var doNotSendItem = false;\r\n // this is for running in legacy mode, where customer may already have a custom initializer present\r\n if (telemetryItem[_DYN_TAGS /* @min:%2etags */] && telemetryItem[_DYN_TAGS /* @min:%2etags */][ProcessLegacy]) {\r\n arrForEach(telemetryItem[_DYN_TAGS /* @min:%2etags */][ProcessLegacy], function (callBack) {\r\n try {\r\n if (callBack && callBack(aiEnvelope) === false) {\r\n doNotSendItem = true;\r\n _warnToConsole(diagLogger, \"Telemetry processor check returns false\");\r\n }\r\n }\r\n catch (e) {\r\n // log error but dont stop executing rest of the telemetry initializers\r\n // doNotSendItem = true;\r\n _throwInternal(diagLogger, 1 /* eLoggingSeverity.CRITICAL */, 64 /* _eInternalMessageId.TelemetryInitializerFailed */, \"One of telemetry initializers failed, telemetry item will not be sent: \" + getExceptionName(e), { exception: dumpObj(e) }, true);\r\n }\r\n });\r\n delete telemetryItem[_DYN_TAGS /* @min:%2etags */][ProcessLegacy];\r\n }\r\n if (doNotSendItem) {\r\n return; // do not send, no need to execute next plugin\r\n }\r\n return aiEnvelope;\r\n }\r\n function _serialize(item) {\r\n var rlt = EMPTY_STR;\r\n var diagLogger = _self[_DYN_DIAG_LOG /* @min:%2ediagLog */]();\r\n try {\r\n var valid = _validate(item, diagLogger);\r\n var envelope = null;\r\n if (valid) {\r\n envelope = _getEnvelope(item, diagLogger);\r\n }\r\n if (envelope) {\r\n rlt = _serializer.serialize(envelope);\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return rlt;\r\n }\r\n function _batch(arr) {\r\n var rlt = EMPTY_STR;\r\n if (arr && arr[_DYN_LENGTH /* @min:%2elength */]) {\r\n rlt = \"[\" + arr.join(\",\") + \"]\";\r\n }\r\n return rlt;\r\n }\r\n function _createPayload(data) {\r\n var headers = _getHeaders();\r\n return {\r\n urlString: _endpointUrl,\r\n data: data,\r\n headers: headers\r\n };\r\n }\r\n function _isSampledIn(envelope) {\r\n return _self._sample.isSampledIn(envelope);\r\n }\r\n function _getOnComplete(payload, status, headers, response) {\r\n // ***********************************************************************************************\r\n //TODO: handle other status codes\r\n if (status === 200 && payload) {\r\n _self._onSuccess(payload, payload[_DYN_LENGTH /* @min:%2elength */]);\r\n }\r\n else {\r\n response && _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, response);\r\n }\r\n }\r\n function _doSend(sendInterface, payload, isAsync, markAsSent) {\r\n if (markAsSent === void 0) { markAsSent = true; }\r\n var onComplete = function (status, headers, response) {\r\n return _getOnComplete(payload, status, headers, response);\r\n };\r\n var payloadData = _getPayload(payload);\r\n var sendPostFunc = sendInterface && sendInterface.sendPOST;\r\n if (sendPostFunc && payloadData) {\r\n // ***********************************************************************************************\r\n // mark payload as sent at the beginning of calling each send function\r\n if (markAsSent) {\r\n _self._buffer[_DYN_MARK_AS_SENT /* @min:%2emarkAsSent */](payload);\r\n }\r\n return sendPostFunc(payloadData, onComplete, !isAsync);\r\n }\r\n return null;\r\n }\r\n function _getPayload(payload) {\r\n if (isArray(payload) && payload[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n var batch = _self[_DYN__BUFFER /* @min:%2e_buffer */].batchPayloads(payload);\r\n var headers = _getHeaders();\r\n var payloadData = {\r\n data: batch,\r\n urlString: _endpointUrl,\r\n headers: headers,\r\n disableXhrSync: _disableXhr,\r\n disableFetchKeepAlive: !_fetchKeepAlive,\r\n oriPayload: payload\r\n };\r\n return payloadData;\r\n }\r\n return null;\r\n }\r\n function _getHeaders() {\r\n try {\r\n var headers = _headers || {};\r\n if (isInternalApplicationInsightsEndpoint(_endpointUrl)) {\r\n headers[RequestHeaders[6 /* eRequestHeaders.sdkContextHeader */]] = RequestHeaders[7 /* eRequestHeaders.sdkContextHeaderAppIdRequest */];\r\n }\r\n return headers;\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return null;\r\n }\r\n function _checkMaxSize(incomingPayload) {\r\n var incomingSize = incomingPayload ? incomingPayload[_DYN_LENGTH /* @min:%2elength */] : 0;\r\n if ((_self[_DYN__BUFFER /* @min:%2e_buffer */].size() + incomingSize) > _maxBatchSizeInBytes) {\r\n if (!_offlineListener || _offlineListener.isOnline()) { // only trigger send when currently online\r\n _self[_DYN_TRIGGER_SEND /* @min:%2etriggerSend */](true, null, 10 /* SendRequestReason.MaxBatchSize */);\r\n }\r\n return true;\r\n }\r\n return false;\r\n }\r\n function _checkResponsStatus(status, payload, responseUrl, countOfItemsInPayload, errorMessage, res) {\r\n var response = null;\r\n if (!_self._appId) {\r\n response = parseResponse(res);\r\n if (response && response.appId) {\r\n _self._appId = response.appId;\r\n }\r\n }\r\n if ((status < 200 || status >= 300) && status !== 0) {\r\n // Update End Point url if permanent redirect or moved permanently\r\n // Updates the end point url before retry\r\n if (status === 301 || status === 307 || status === 308) {\r\n if (!_checkAndUpdateEndPointUrl(responseUrl)) {\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, errorMessage);\r\n return;\r\n }\r\n }\r\n if (_offlineListener && !_offlineListener.isOnline()) { // offline\r\n // Note: Don't check for status == 0, since adblock gives this code\r\n if (!_isRetryDisabled) {\r\n var offlineBackOffMultiplier = 10; // arbritrary number\r\n _resendPayload(payload, offlineBackOffMultiplier);\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \". Offline - Response Code: \".concat(status, \". Offline status: \").concat(!_offlineListener.isOnline(), \". Will retry to send \").concat(payload.length, \" items.\"));\r\n }\r\n return;\r\n }\r\n if (!_isRetryDisabled && _isRetriable(status)) {\r\n _resendPayload(payload);\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \". \" +\r\n \"Response code \" + status + \". Will retry to send \" + payload[_DYN_LENGTH /* @min:%2elength */] + \" items.\");\r\n }\r\n else {\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, errorMessage);\r\n }\r\n }\r\n else {\r\n // check if the xhr's responseURL or fetch's response.url is same as endpoint url\r\n // TODO after 10 redirects force send telemetry with 'redirect=false' as query parameter.\r\n _checkAndUpdateEndPointUrl(responseUrl);\r\n if (status === 206) {\r\n if (!response) {\r\n response = parseResponse(res);\r\n }\r\n if (response && !_isRetryDisabled) {\r\n _self[_DYN__ON_PARTIAL_SUCCESS /* @min:%2e_onPartialSuccess */](payload, response);\r\n }\r\n else {\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, errorMessage);\r\n }\r\n }\r\n else {\r\n _consecutiveErrors = 0;\r\n _self[_DYN__ON_SUCCESS /* @min:%2e_onSuccess */](payload, countOfItemsInPayload);\r\n }\r\n }\r\n }\r\n function _checkAndUpdateEndPointUrl(responseUrl) {\r\n // Maximum stamp specific redirects allowed(uncomment this when breeze is ready with not allowing redirects feature)\r\n if (_stamp_specific_redirects >= 10) {\r\n // _self._senderConfig.endpointUrl = () => Sender._getDefaultAppInsightsChannelConfig().endpointUrl()+\"/?redirect=false\";\r\n // _stamp_specific_redirects = 0;\r\n return false;\r\n }\r\n if (!isNullOrUndefined(responseUrl) && responseUrl !== \"\") {\r\n if (responseUrl !== _endpointUrl) {\r\n _endpointUrl = responseUrl;\r\n ++_stamp_specific_redirects;\r\n return true;\r\n }\r\n }\r\n return false;\r\n }\r\n function _doUnloadSend(payload, isAsync) {\r\n if (_syncUnloadSender) {\r\n // We are unloading so always call the sender with sync set to false\r\n _syncUnloadSender(payload, false);\r\n }\r\n else {\r\n // Fallback to the previous beacon Sender (which causes a CORB warning on chrome now)\r\n var beaconInst = _sendPostMgr && _sendPostMgr[_DYN_GET_SENDER_INST /* @min:%2egetSenderInst */]([3 /* TransportType.Beacon */], true);\r\n return _doSend(beaconInst, payload, isAsync);\r\n }\r\n }\r\n function _onBeaconRetry(payload, onComplete, canSend) {\r\n var internalPayload = payload;\r\n var data = internalPayload && internalPayload.oriPayload;\r\n if (!_disableBeaconSplit) {\r\n // Failed to send entire payload so try and split data and try to send as much events as possible\r\n var droppedPayload = [];\r\n for (var lp = 0; lp < data[_DYN_LENGTH /* @min:%2elength */]; lp++) {\r\n var thePayload = data[lp];\r\n var arr = [thePayload];\r\n var item = _getPayload(arr);\r\n if (!canSend(item, onComplete)) {\r\n // Can't send anymore, so split the batch and drop the rest\r\n droppedPayload[_DYN_PUSH /* @min:%2epush */](thePayload);\r\n }\r\n else {\r\n _self._onSuccess(arr, arr[_DYN_LENGTH /* @min:%2elength */]);\r\n }\r\n }\r\n if (droppedPayload[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n _fallbackSend && _fallbackSend(droppedPayload, true);\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \". \" + \"Failed to send telemetry with Beacon API, retried with normal sender.\");\r\n }\r\n }\r\n else {\r\n _fallbackSend && _fallbackSend(data, true);\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \". \" + \"Failed to send telemetry with Beacon API, retried with normal sender.\");\r\n }\r\n }\r\n function _isStringArr(arr) {\r\n try {\r\n if (arr && arr[_DYN_LENGTH /* @min:%2elength */]) {\r\n return (isString(arr[0]));\r\n }\r\n }\r\n catch (e) {\r\n //TODO: log, sender use IInternalStorageItem instead of string since 3.1.3\r\n }\r\n return null;\r\n }\r\n function _fetchKeepAliveSender(payload, isAsync) {\r\n var transport = null;\r\n if (isArray(payload)) {\r\n var payloadSize = payload[_DYN_LENGTH /* @min:%2elength */];\r\n for (var lp = 0; lp < payload[_DYN_LENGTH /* @min:%2elength */]; lp++) {\r\n payloadSize += payload[lp].item[_DYN_LENGTH /* @min:%2elength */];\r\n }\r\n var syncFetchPayload = _sendPostMgr.getSyncFetchPayload();\r\n if ((syncFetchPayload + payloadSize) <= FetchSyncRequestSizeLimitBytes) {\r\n transport = 2 /* TransportType.Fetch */;\r\n }\r\n else if (isBeaconsSupported()) {\r\n // Fallback to beacon sender as we at least get told which events can't be scheduled\r\n transport = 3 /* TransportType.Beacon */;\r\n }\r\n else {\r\n // Payload is going to be too big so just try and send via XHR\r\n transport = 1 /* TransportType.Xhr */;\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \". \" + \"Failed to send telemetry with Beacon API, retried with xhrSender.\");\r\n }\r\n var inst = _sendPostMgr && _sendPostMgr[_DYN_GET_SENDER_INST /* @min:%2egetSenderInst */]([transport], true);\r\n return _doSend(inst, payload, isAsync);\r\n }\r\n return null;\r\n }\r\n /**\r\n * Resend payload. Adds payload back to the send buffer and setup a send timer (with exponential backoff).\r\n * @param payload\r\n */\r\n function _resendPayload(payload, linearFactor) {\r\n if (linearFactor === void 0) { linearFactor = 1; }\r\n if (!payload || payload[_DYN_LENGTH /* @min:%2elength */] === 0) {\r\n return;\r\n }\r\n var buffer = _self[_DYN__BUFFER /* @min:%2e_buffer */];\r\n buffer[_DYN_CLEAR_SENT /* @min:%2eclearSent */](payload);\r\n _consecutiveErrors++;\r\n for (var _i = 0, payload_1 = payload; _i < payload_1.length; _i++) {\r\n var item = payload_1[_i];\r\n item.cnt = item.cnt || 0; // to make sure we have cnt for each payload\r\n item.cnt++; // when resend, increase cnt\r\n buffer[_DYN_ENQUEUE /* @min:%2eenqueue */](item);\r\n }\r\n // setup timer\r\n _setRetryTime(linearFactor);\r\n _setupTimer();\r\n }\r\n /**\r\n * Calculates the time to wait before retrying in case of an error based on\r\n * http://en.wikipedia.org/wiki/Exponential_backoff\r\n */\r\n function _setRetryTime(linearFactor) {\r\n var SlotDelayInSeconds = 10;\r\n var delayInSeconds;\r\n if (_consecutiveErrors <= 1) {\r\n delayInSeconds = SlotDelayInSeconds;\r\n }\r\n else {\r\n var backOffSlot = (Math.pow(2, _consecutiveErrors) - 1) / 2;\r\n // tslint:disable-next-line:insecure-random\r\n var backOffDelay = mathFloor(Math.random() * backOffSlot * SlotDelayInSeconds) + 1;\r\n backOffDelay = linearFactor * backOffDelay;\r\n delayInSeconds = mathMax(mathMin(backOffDelay, 3600), SlotDelayInSeconds);\r\n }\r\n // TODO: Log the backoff time like the C# version does.\r\n var retryAfterTimeSpan = dateNow() + (delayInSeconds * 1000);\r\n // TODO: Log the retry at time like the C# version does.\r\n _retryAt = retryAfterTimeSpan;\r\n }\r\n /**\r\n * Sets up the timer which triggers actually sending the data.\r\n */\r\n function _setupTimer() {\r\n if (!_timeoutHandle && !_paused) {\r\n var retryInterval = _retryAt ? mathMax(0, _retryAt - dateNow()) : 0;\r\n var timerValue = mathMax(_maxBatchInterval, retryInterval);\r\n _timeoutHandle = scheduleTimeout(function () {\r\n _timeoutHandle = null;\r\n _self[_DYN_TRIGGER_SEND /* @min:%2etriggerSend */](true, null, 1 /* SendRequestReason.NormalSchedule */);\r\n }, timerValue);\r\n }\r\n }\r\n function _clearScheduledTimer() {\r\n _timeoutHandle && _timeoutHandle.cancel();\r\n _timeoutHandle = null;\r\n _retryAt = null;\r\n }\r\n /**\r\n * Checks if the SDK should resend the payload after receiving this status code from the backend.\r\n * @param statusCode\r\n */\r\n function _isRetriable(statusCode) {\r\n // retryCodes = [] means should not retry\r\n if (!isNullOrUndefined(_retryCodes)) {\r\n return _retryCodes[_DYN_LENGTH /* @min:%2elength */] && _retryCodes.indexOf(statusCode) > -1;\r\n }\r\n return statusCode === 401 // Unauthorized\r\n // Removing as private links can return a 403 which causes excessive retries and session storage usage\r\n // || statusCode === 403 // Forbidden\r\n || statusCode === 408 // Timeout\r\n || statusCode === 429 // Too many requests.\r\n || statusCode === 500 // Internal server error.\r\n || statusCode === 502 // Bad Gateway.\r\n || statusCode === 503 // Service unavailable.\r\n || statusCode === 504; // Gateway timeout.\r\n }\r\n // Using function lookups for backward compatibility as the getNotifyMgr() did not exist until after v2.5.6\r\n function _getNotifyMgr() {\r\n var func = \"getNotifyMgr\";\r\n if (_self.core[func]) {\r\n return _self.core[func]();\r\n }\r\n // using _self.core['_notificationManager'] for backward compatibility\r\n return _self.core[\"_notificationManager\"];\r\n }\r\n function _notifySendRequest(sendRequest, isAsync) {\r\n var manager = _getNotifyMgr();\r\n if (manager && manager.eventsSendRequest) {\r\n try {\r\n manager.eventsSendRequest(sendRequest, isAsync);\r\n }\r\n catch (e) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 74 /* _eInternalMessageId.NotificationException */, \"send request notification failed: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n }\r\n /**\r\n * Validate UUID Format\r\n * Specs taken from https://tools.ietf.org/html/rfc4122 and breeze repo\r\n */\r\n function _validateInstrumentationKey(instrumentationKey, config) {\r\n var disableValidation = config.disableInstrumentationKeyValidation;\r\n var disableIKeyValidationFlag = isNullOrUndefined(disableValidation) ? false : disableValidation;\r\n if (disableIKeyValidationFlag) {\r\n return true;\r\n }\r\n var UUID_Regex = \"^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$\";\r\n var regexp = new RegExp(UUID_Regex);\r\n return regexp.test(instrumentationKey);\r\n }\r\n function _initDefaults() {\r\n _self[_DYN__SENDER /* @min:%2e_sender */] = null;\r\n _self[_DYN__BUFFER /* @min:%2e_buffer */] = null;\r\n _self._appId = null;\r\n _self._sample = null;\r\n _headers = {};\r\n _offlineListener = null;\r\n _consecutiveErrors = 0;\r\n _retryAt = null;\r\n _lastSend = null;\r\n _paused = false;\r\n _timeoutHandle = null;\r\n _serializer = null;\r\n _stamp_specific_redirects = 0;\r\n _syncFetchPayload = 0;\r\n _syncUnloadSender = null;\r\n _evtNamespace = null;\r\n _endpointUrl = null;\r\n _orgEndpointUrl = null;\r\n _maxBatchSizeInBytes = 0;\r\n _beaconSupported = false;\r\n _customHeaders = null;\r\n _disableTelemetry = false;\r\n _instrumentationKey = null;\r\n _convertUndefined = UNDEFINED_VALUE;\r\n _isRetryDisabled = false;\r\n _sessionStorageUsed = null;\r\n _namePrefix = UNDEFINED_VALUE;\r\n _disableXhr = false;\r\n _fetchKeepAlive = false;\r\n _disableBeaconSplit = false;\r\n _xhrSend = null;\r\n _fallbackSend = null;\r\n _sendPostMgr = null;\r\n objDefine(_self, \"_senderConfig\", {\r\n g: function () {\r\n return objExtend({}, defaultAppInsightsChannelConfig);\r\n }\r\n });\r\n }\r\n });\r\n return _this;\r\n }\r\n Sender.constructEnvelope = function (orig, iKey, logger, convertUndefined) {\r\n var envelope;\r\n if (iKey !== orig.iKey && !isNullOrUndefined(iKey)) {\r\n envelope = __assign(__assign({}, orig), { iKey: iKey });\r\n }\r\n else {\r\n envelope = orig;\r\n }\r\n var creator = EnvelopeTypeCreator[envelope.baseType] || EventEnvelopeCreator;\r\n return creator(logger, envelope, convertUndefined);\r\n };\r\n// Removed Stub for Sender.prototype.pause.\r\n// Removed Stub for Sender.prototype.resume.\r\n// Removed Stub for Sender.prototype.flush.\r\n// Removed Stub for Sender.prototype.onunloadFlush.\r\n// Removed Stub for Sender.prototype.initialize.\r\n// Removed Stub for Sender.prototype.processTelemetry.\r\n// Removed Stub for Sender.prototype._xhrReadyStateChange.\r\n// Removed Stub for Sender.prototype.triggerSend.\r\n// Removed Stub for Sender.prototype._onError.\r\n// Removed Stub for Sender.prototype._onPartialSuccess.\r\n// Removed Stub for Sender.prototype._onSuccess.\r\n// Removed Stub for Sender.prototype._xdrOnLoad.\r\n// Removed Stub for Sender.prototype.addHeader.\r\n// Removed Stub for Sender.prototype.isCompletelyIdle.\r\n// Removed Stub for Sender.prototype.getOfflineSupport.\r\n// Removed Stub for Sender.prototype.getOfflineListener.\r\n return Sender;\r\n}(BaseTelemetryPlugin));\r\nexport { Sender };\r\n//# sourceMappingURL=Sender.js.map","/*\n * Application Insights JavaScript SDK - Dependencies Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// ###################################################################################################################################################\r\n// Note: DON'T Export these const from the package as we are still targeting IE/ES5 this will export a mutable variables that someone could change ###\r\n// ###################################################################################################################################################\r\n// Generally you should only put values that are used more than 2 times and then only if not already exposed as a constant (such as SdkCoreNames)\r\n// as when using \"short\" named values from here they will be will be minified smaller than the SdkCoreNames[eSdkCoreNames.xxxx] value.\r\nexport var STR_DURATION = \"duration\";\r\nexport var STR_PROPERTIES = \"properties\";\r\n//# sourceMappingURL=InternalConstants.js.map","/*\n * Application Insights JavaScript SDK - Dependencies Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES5 which can result in a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_REQUEST_URL = \"requestUrl\"; // Count: 11\r\nexport var _DYN_LENGTH = \"length\"; // Count: 8\r\nexport var _DYN_TRACE_ID = \"traceID\"; // Count: 8\r\nexport var _DYN_SPAN_ID = \"spanID\"; // Count: 8\r\nexport var _DYN_TRACE_FLAGS = \"traceFlags\"; // Count: 11\r\nexport var _DYN_CONTEXT = \"context\"; // Count: 5\r\nexport var _DYN_ABORTED = \"aborted\"; // Count: 6\r\nexport var _DYN__ADD_HOOK = \"_addHook\"; // Count: 4\r\nexport var _DYN_CORE = \"core\"; // Count: 7\r\nexport var _DYN_INCLUDE_CORRELATION_0 = \"includeCorrelationHeaders\"; // Count: 4\r\nexport var _DYN_GET_ABSOLUTE_URL = \"getAbsoluteUrl\"; // Count: 3\r\nexport var _DYN_HEADERS = \"headers\"; // Count: 7\r\nexport var _DYN_REQUEST_HEADERS = \"requestHeaders\"; // Count: 13\r\nexport var _DYN_SET_REQUEST_HEADER = \"setRequestHeader\"; // Count: 3\r\nexport var _DYN_TRACK_DEPENDENCY_DAT1 = \"trackDependencyDataInternal\"; // Count: 2\r\nexport var _DYN_START_TIME = \"startTime\"; // Count: 5\r\nexport var _DYN_TO_LOWER_CASE = \"toLowerCase\"; // Count: 6\r\nexport var _DYN_ENABLE_REQUEST_HEADE2 = \"enableRequestHeaderTracking\"; // Count: 3\r\nexport var _DYN_ENABLE_AJAX_ERROR_ST3 = \"enableAjaxErrorStatusText\"; // Count: 2\r\nexport var _DYN_ENABLE_AJAX_PERF_TRA4 = \"enableAjaxPerfTracking\"; // Count: 2\r\nexport var _DYN_MAX_AJAX_CALLS_PER_V5 = \"maxAjaxCallsPerView\"; // Count: 2\r\nexport var _DYN_EXCLUDE_REQUEST_FROM6 = \"excludeRequestFromAutoTrackingPatterns\"; // Count: 2\r\nexport var _DYN_DISABLE_AJAX_TRACKIN7 = \"disableAjaxTracking\"; // Count: 3\r\nexport var _DYN_AJAX_PERF_LOOKUP_DEL8 = \"ajaxPerfLookupDelay\"; // Count: 2\r\nexport var _DYN_DISABLE_FETCH_TRACKI9 = \"disableFetchTracking\"; // Count: 2\r\nexport var _DYN_ENABLE_RESPONSE_HEAD10 = \"enableResponseHeaderTracking\"; // Count: 2\r\nexport var _DYN_STATUS = \"status\"; // Count: 11\r\nexport var _DYN_STATUS_TEXT = \"statusText\"; // Count: 7\r\nexport var _DYN_HEADER_MAP = \"headerMap\"; // Count: 5\r\nexport var _DYN_REQUEST_SENT_TIME = \"requestSentTime\"; // Count: 9\r\nexport var _DYN_GET_TRACE_ID = \"getTraceId\"; // Count: 3\r\nexport var _DYN_GET_TRACE_FLAGS = \"getTraceFlags\"; // Count: 3\r\nexport var _DYN_METHOD = \"method\"; // Count: 8\r\nexport var _DYN_ERROR_STATUS_TEXT = \"errorStatusText\"; // Count: 3\r\nexport var _DYN_STATE_CHANGE_ATTACHE11 = \"stateChangeAttached\"; // Count: 2\r\nexport var _DYN_RESPONSE_TEXT = \"responseText\"; // Count: 6\r\nexport var _DYN_RESPONSE_FINISHED_TI12 = \"responseFinishedTime\"; // Count: 7\r\nexport var _DYN__CREATE_TRACK_ITEM = \"CreateTrackItem\"; // Count: 3\r\nexport var _DYN_GET_ALL_RESPONSE_HEA13 = \"getAllResponseHeaders\"; // Count: 2\r\nexport var _DYN_GET_PART_APROPS = \"getPartAProps\"; // Count: 3\r\nexport var _DYN_PERF_MARK = \"perfMark\"; // Count: 4\r\nexport var _DYN_PERF_TIMING = \"perfTiming\"; // Count: 3\r\nexport var _DYN_AJAX_DIAGNOSTICS_MES14 = \"ajaxDiagnosticsMessage\"; // Count: 3\r\nexport var _DYN_CORRELATION_CONTEXT = \"correlationContext\"; // Count: 3\r\nexport var _DYN_AJAX_TOTAL_DURATION = \"ajaxTotalDuration\"; // Count: 3\r\nexport var _DYN_EVENT_TRACE_CTX = \"eventTraceCtx\"; // Count: 3\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Dependencies Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { Extensions, dataSanitizeUrl, dateTimeUtilsDuration, msToTimeSpan, urlGetAbsoluteUrl, urlGetCompleteUrl } from \"@microsoft/applicationinsights-common\";\r\nimport { arrForEach, isNullOrUndefined, isNumber, isString, normalizeJsName, objForEachKey, objKeys } from \"@microsoft/applicationinsights-core-js\";\r\nimport { mathRound } from \"@nevware21/ts-utils\";\r\nimport { STR_DURATION, STR_PROPERTIES } from \"./InternalConstants\";\r\nimport { _DYN_ABORTED, _DYN_AJAX_TOTAL_DURATION, _DYN_CORRELATION_CONTEXT, _DYN_ERROR_STATUS_TEXT, _DYN_EVENT_TRACE_CTX, _DYN_GET_ABSOLUTE_URL, _DYN_GET_PART_APROPS, _DYN_GET_TRACE_FLAGS, _DYN_GET_TRACE_ID, _DYN_HEADER_MAP, _DYN_LENGTH, _DYN_METHOD, _DYN_PERF_MARK, _DYN_PERF_TIMING, _DYN_REQUEST_HEADERS, _DYN_REQUEST_SENT_TIME, _DYN_REQUEST_URL, _DYN_RESPONSE_FINISHED_TI12, _DYN_SPAN_ID, _DYN_START_TIME, _DYN_STATE_CHANGE_ATTACHE11, _DYN_STATUS, _DYN_STATUS_TEXT, _DYN_TRACE_FLAGS, _DYN_TRACE_ID, _DYN__CREATE_TRACK_ITEM } from \"./__DynamicConstants\";\r\n/** @ignore */\r\nfunction _calcPerfDuration(resourceEntry, start, end) {\r\n var result = 0;\r\n var from = resourceEntry[start];\r\n var to = resourceEntry[end];\r\n if (from && to) {\r\n result = dateTimeUtilsDuration(from, to);\r\n }\r\n return result;\r\n}\r\n/** @ignore */\r\nfunction _setPerfDuration(props, name, resourceEntry, start, end) {\r\n var result = 0;\r\n var value = _calcPerfDuration(resourceEntry, start, end);\r\n if (value) {\r\n result = _setPerfValue(props, name, msToTimeSpan(value));\r\n }\r\n return result;\r\n}\r\n/** @ignore */\r\nfunction _setPerfValue(props, name, value) {\r\n var strPerf = \"ajaxPerf\";\r\n var result = 0;\r\n if (props && name && value) {\r\n var perfData = props[strPerf] = (props[strPerf] || {});\r\n perfData[name] = value;\r\n result = 1;\r\n }\r\n return result;\r\n}\r\n/** @ignore */\r\nfunction _populatePerfData(ajaxData, dependency) {\r\n /*\r\n * https://developer.mozilla.org/en-US/docs/Web/API/Resource_Timing_API/Using_the_Resource_Timing_API\r\n * | -startTime\r\n * | -redirectStart\r\n * | | -redirectEnd\r\n * | | | -fetchStart\r\n * | | | | -domainLookupStart\r\n * | | | | |- domainLookupEnd\r\n * | | | | | | -connectStart\r\n * | | | | | | | -secureConnectionStart\r\n * | | | | | | | | -connectEnd\r\n * | | | | | | | | | -requestStart\r\n * | | | | | | | | | | | -responseStart\r\n * | | | | | | | | | | | | | -responseEnd\r\n * +------------+-+---+----------------+-+--+--------+-+-----------+-+------------+-+\r\n * |--redirect--| |---|--domainLookup--| |--connect--| |--request--| |--response--| |\r\n * |-------------------networkConnect----------------|\r\n * | |---------sentRequest--------|\r\n * |------------------------------------perfTotal-----------------------------------|\r\n */\r\n var resourceEntry = ajaxData[_DYN_PERF_TIMING /* @min:%2eperfTiming */];\r\n var props = dependency[STR_PROPERTIES /* @min:%2eproperties */] || {};\r\n var propsSet = 0;\r\n var strName = \"name\";\r\n var strStart = \"Start\";\r\n var strEnd = \"End\";\r\n var strDomainLookup = \"domainLookup\";\r\n var strConnect = \"connect\";\r\n var strRedirect = \"redirect\";\r\n var strRequest = \"request\";\r\n var strResponse = \"response\";\r\n var strStartTime = \"startTime\";\r\n var strDomainLookupStart = strDomainLookup + strStart;\r\n var strDomainLookupEnd = strDomainLookup + strEnd;\r\n var strConnectStart = strConnect + strStart;\r\n var strConnectEnd = strConnect + strEnd;\r\n var strRequestStart = strRequest + strStart;\r\n var strRequestEnd = strRequest + strEnd;\r\n var strResponseStart = strResponse + strStart;\r\n var strResponseEnd = strResponse + strEnd;\r\n var strRedirectStart = strRedirect + strStart;\r\n var strRedirectEnd = strRedirect = strEnd;\r\n var strTransferSize = \"transferSize\";\r\n var strEncodedBodySize = \"encodedBodySize\";\r\n var strDecodedBodySize = \"decodedBodySize\";\r\n var strServerTiming = \"serverTiming\";\r\n if (resourceEntry) {\r\n // redirect\r\n propsSet |= _setPerfDuration(props, strRedirect, resourceEntry, strRedirectStart, strRedirectEnd);\r\n // domainLookup\r\n propsSet |= _setPerfDuration(props, strDomainLookup, resourceEntry, strDomainLookupStart, strDomainLookupEnd);\r\n // connect\r\n propsSet |= _setPerfDuration(props, strConnect, resourceEntry, strConnectStart, strConnectEnd);\r\n // request\r\n propsSet |= _setPerfDuration(props, strRequest, resourceEntry, strRequestStart, strRequestEnd);\r\n // response\r\n propsSet |= _setPerfDuration(props, strResponse, resourceEntry, strResponseStart, strResponseEnd);\r\n // Network connection time\r\n propsSet |= _setPerfDuration(props, \"networkConnect\", resourceEntry, strStartTime, strConnectEnd);\r\n // Sent Request\r\n propsSet |= _setPerfDuration(props, \"sentRequest\", resourceEntry, strRequestStart, strResponseEnd);\r\n // PerfTotal / Duration\r\n var duration = resourceEntry[STR_DURATION /* @min:%2eduration */];\r\n if (!duration) {\r\n duration = _calcPerfDuration(resourceEntry, strStartTime, strResponseEnd) || 0;\r\n }\r\n propsSet |= _setPerfValue(props, STR_DURATION, duration);\r\n propsSet |= _setPerfValue(props, \"perfTotal\", duration);\r\n var serverTiming = resourceEntry[strServerTiming];\r\n if (serverTiming) {\r\n var server_1 = {};\r\n arrForEach(serverTiming, function (value, idx) {\r\n var name = normalizeJsName(value[strName] || \"\" + idx);\r\n var newValue = server_1[name] || {};\r\n objForEachKey(value, function (key, val) {\r\n if (key !== strName && isString(val) || isNumber(val)) {\r\n if (newValue[key]) {\r\n val = newValue[key] + \";\" + val;\r\n }\r\n if (val || !isString(val)) {\r\n // Only set the value if it has a value and it's not an empty string\r\n newValue[key] = val;\r\n }\r\n }\r\n });\r\n server_1[name] = newValue;\r\n });\r\n propsSet |= _setPerfValue(props, strServerTiming, server_1);\r\n }\r\n propsSet |= _setPerfValue(props, strTransferSize, resourceEntry[strTransferSize]);\r\n propsSet |= _setPerfValue(props, strEncodedBodySize, resourceEntry[strEncodedBodySize]);\r\n propsSet |= _setPerfValue(props, strDecodedBodySize, resourceEntry[strDecodedBodySize]);\r\n }\r\n else {\r\n if (ajaxData[_DYN_PERF_MARK /* @min:%2eperfMark */]) {\r\n propsSet |= _setPerfValue(props, \"missing\", ajaxData.perfAttempts);\r\n }\r\n }\r\n if (propsSet) {\r\n dependency[STR_PROPERTIES /* @min:%2eproperties */] = props;\r\n }\r\n}\r\nvar XHRMonitoringState = /** @class */ (function () {\r\n function XHRMonitoringState() {\r\n var self = this;\r\n self.openDone = false;\r\n self.setRequestHeaderDone = false;\r\n self.sendDone = false;\r\n self.abortDone = false;\r\n // True, if onreadyStateChangeCallback function attached to xhr, otherwise false\r\n self[_DYN_STATE_CHANGE_ATTACHE11 /* @min:%2estateChangeAttached */] = false;\r\n }\r\n return XHRMonitoringState;\r\n}());\r\nexport { XHRMonitoringState };\r\nvar ajaxRecord = /** @class */ (function () {\r\n function ajaxRecord(traceId, spanId, logger, traceCtx) {\r\n var self = this;\r\n var _logger = logger;\r\n var strResponseText = \"responseText\";\r\n // Assigning the initial/default values within the constructor to avoid typescript from creating a bunch of\r\n // this.XXXX = null\r\n self[_DYN_PERF_MARK /* @min:%2eperfMark */] = null;\r\n self.completed = false;\r\n self.requestHeadersSize = null;\r\n self[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */] = null;\r\n self.responseReceivingDuration = null;\r\n self.callbackDuration = null;\r\n self[_DYN_AJAX_TOTAL_DURATION /* @min:%2eajaxTotalDuration */] = null;\r\n self[_DYN_ABORTED /* @min:%2eaborted */] = 0;\r\n self.pageUrl = null;\r\n self[_DYN_REQUEST_URL /* @min:%2erequestUrl */] = null;\r\n self.requestSize = 0;\r\n self[_DYN_METHOD /* @min:%2emethod */] = null;\r\n self[_DYN_STATUS /* @min:%2estatus */] = null;\r\n self[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */] = null;\r\n self.responseStartedTime = null;\r\n self[_DYN_RESPONSE_FINISHED_TI12 /* @min:%2eresponseFinishedTime */] = null;\r\n self.callbackFinishedTime = null;\r\n self.endTime = null;\r\n self.xhrMonitoringState = new XHRMonitoringState();\r\n self.clientFailure = 0;\r\n self[_DYN_TRACE_ID /* @min:%2etraceID */] = traceId;\r\n self[_DYN_SPAN_ID /* @min:%2espanID */] = spanId;\r\n self[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */] = traceCtx === null || traceCtx === void 0 ? void 0 : traceCtx.getTraceFlags();\r\n if (traceCtx) {\r\n self[_DYN_EVENT_TRACE_CTX /* @min:%2eeventTraceCtx */] = {\r\n traceId: traceCtx[_DYN_GET_TRACE_ID /* @min:%2egetTraceId */](),\r\n spanId: traceCtx.getSpanId(),\r\n traceFlags: traceCtx[_DYN_GET_TRACE_FLAGS /* @min:%2egetTraceFlags */]()\r\n };\r\n }\r\n else {\r\n self[_DYN_EVENT_TRACE_CTX /* @min:%2eeventTraceCtx */] = null;\r\n }\r\n dynamicProto(ajaxRecord, self, function (self) {\r\n self.getAbsoluteUrl = function () {\r\n return self[_DYN_REQUEST_URL /* @min:%2erequestUrl */] ? urlGetAbsoluteUrl(self[_DYN_REQUEST_URL /* @min:%2erequestUrl */]) : null;\r\n };\r\n self.getPathName = function () {\r\n return self[_DYN_REQUEST_URL /* @min:%2erequestUrl */] ? dataSanitizeUrl(_logger, urlGetCompleteUrl(self[_DYN_METHOD /* @min:%2emethod */], self[_DYN_REQUEST_URL /* @min:%2erequestUrl */])) : null;\r\n };\r\n self[_DYN__CREATE_TRACK_ITEM /* @min:%2eCreateTrackItem */] = function (ajaxType, enableRequestHeaderTracking, getResponse) {\r\n var _a;\r\n // round to 3 decimal points\r\n self.ajaxTotalDuration = mathRound(dateTimeUtilsDuration(self.requestSentTime, self.responseFinishedTime) * 1000) / 1000;\r\n if (self[_DYN_AJAX_TOTAL_DURATION /* @min:%2eajaxTotalDuration */] < 0) {\r\n return null;\r\n }\r\n var dependency = (_a = {\r\n id: \"|\" + self[_DYN_TRACE_ID /* @min:%2etraceID */] + \".\" + self[_DYN_SPAN_ID /* @min:%2espanID */],\r\n target: self[_DYN_GET_ABSOLUTE_URL /* @min:%2egetAbsoluteUrl */](),\r\n name: self.getPathName(),\r\n type: ajaxType,\r\n startTime: null,\r\n duration: self[_DYN_AJAX_TOTAL_DURATION /* @min:%2eajaxTotalDuration */],\r\n success: (+(self[_DYN_STATUS /* @min:%2estatus */])) >= 200 && (+(self[_DYN_STATUS /* @min:%2estatus */])) < 400,\r\n responseCode: (+(self[_DYN_STATUS /* @min:%2estatus */]))\r\n },\r\n _a[STR_PROPERTIES] = { HttpMethod: self[_DYN_METHOD /* @min:%2emethod */] },\r\n _a);\r\n var props = dependency[STR_PROPERTIES];\r\n if (self[_DYN_ABORTED /* @min:%2eaborted */]) {\r\n props[_DYN_ABORTED /* @min:%2eaborted */] = true;\r\n }\r\n if (self[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */]) {\r\n // Set the correct dependency start time\r\n dependency[_DYN_START_TIME /* @min:%2estartTime */] = new Date();\r\n dependency[_DYN_START_TIME /* @min:%2estartTime */].setTime(self[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */]);\r\n }\r\n // Add Ajax perf details if available\r\n _populatePerfData(self, dependency);\r\n if (enableRequestHeaderTracking) {\r\n if (objKeys(self.requestHeaders)[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n props[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */] = self[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */];\r\n }\r\n }\r\n if (getResponse) {\r\n var response = getResponse();\r\n if (response) {\r\n // enrich dependency target with correlation context from the server\r\n var correlationContext = response[_DYN_CORRELATION_CONTEXT /* @min:%2ecorrelationContext */];\r\n if (correlationContext) {\r\n dependency.correlationContext = /* dependency.target + \" | \" + */ correlationContext;\r\n }\r\n if (response[_DYN_HEADER_MAP /* @min:%2eheaderMap */]) {\r\n if (objKeys(response.headerMap)[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n props.responseHeaders = response[_DYN_HEADER_MAP /* @min:%2eheaderMap */];\r\n }\r\n }\r\n if (self[_DYN_ERROR_STATUS_TEXT /* @min:%2eerrorStatusText */]) {\r\n if (self[_DYN_STATUS /* @min:%2estatus */] >= 400) {\r\n var responseType = response.type;\r\n if (responseType === \"\" || responseType === \"text\") {\r\n props.responseText = response.responseText ? response[_DYN_STATUS_TEXT /* @min:%2estatusText */] + \" - \" + response[strResponseText] : response[_DYN_STATUS_TEXT /* @min:%2estatusText */];\r\n }\r\n if (responseType === \"json\") {\r\n props.responseText = response.response ? response[_DYN_STATUS_TEXT /* @min:%2estatusText */] + \" - \" + JSON.stringify(response.response) : response[_DYN_STATUS_TEXT /* @min:%2estatusText */];\r\n }\r\n }\r\n else if (self[_DYN_STATUS /* @min:%2estatus */] === 0) {\r\n props.responseText = response[_DYN_STATUS_TEXT /* @min:%2estatusText */] || \"\";\r\n }\r\n }\r\n }\r\n }\r\n return dependency;\r\n };\r\n self[_DYN_GET_PART_APROPS /* @min:%2egetPartAProps */] = function () {\r\n var partA = null;\r\n var traceCtx = self[_DYN_EVENT_TRACE_CTX /* @min:%2eeventTraceCtx */];\r\n if (traceCtx && (traceCtx.traceId || traceCtx.spanId)) {\r\n partA = {};\r\n var traceExt = partA[Extensions.TraceExt] = {\r\n traceID: traceCtx.traceId,\r\n parentID: traceCtx.spanId\r\n };\r\n if (!isNullOrUndefined(traceCtx[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */])) {\r\n traceExt[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */] = traceCtx[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */];\r\n }\r\n }\r\n return partA;\r\n };\r\n });\r\n }\r\n// Removed Stub for ajaxRecord.prototype.getAbsoluteUrl.\r\n// Removed Stub for ajaxRecord.prototype.getPathName.\r\n// Removed Stub for ajaxRecord.prototype.CreateTrackItem.\r\n// Removed Stub for ajaxRecord.prototype.getPartAProps.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n ajaxRecord.__ieDyn=1;\n\n return ajaxRecord;\r\n}());\r\nexport { ajaxRecord };\r\n//# sourceMappingURL=ajaxRecord.js.map","/*\n * Application Insights JavaScript SDK - Dependencies Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nvar _a;\r\nimport { __assignFn as __assign, __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { DisabledPropertyName, PropertiesPluginIdentifier, RemoteDependencyData, RequestHeaders, correlationIdCanIncludeCorrelationHeader, correlationIdGetCorrelationContext, createDistributedTraceContextFromTrace, createTelemetryItem, createTraceParent, dateTimeUtilsNow, formatTraceParent, isInternalApplicationInsightsEndpoint } from \"@microsoft/applicationinsights-common\";\r\nimport { BaseTelemetryPlugin, InstrumentFunc, InstrumentProto, _throwInternal, arrForEach, createProcessTelemetryContext, createUniqueNamespace, dumpObj, eventOn, generateW3CId, getExceptionName, getGlobal, getIEVersion, getLocation, getPerformance, isFunction, isNullOrUndefined, isString, isXhrSupported, mergeEvtNamespace, onConfigChange, strPrototype, strTrim } from \"@microsoft/applicationinsights-core-js\";\r\nimport { isWebWorker, objFreeze, scheduleTimeout, strIndexOf, strSplit, strSubstr } from \"@nevware21/ts-utils\";\r\nimport { STR_PROPERTIES } from \"./InternalConstants\";\r\nimport { _DYN_ABORTED, _DYN_AJAX_DIAGNOSTICS_MES14, _DYN_AJAX_PERF_LOOKUP_DEL8, _DYN_CONTEXT, _DYN_CORE, _DYN_CORRELATION_CONTEXT, _DYN_DISABLE_AJAX_TRACKIN7, _DYN_DISABLE_FETCH_TRACKI9, _DYN_ENABLE_AJAX_ERROR_ST3, _DYN_ENABLE_AJAX_PERF_TRA4, _DYN_ENABLE_REQUEST_HEADE2, _DYN_ENABLE_RESPONSE_HEAD10, _DYN_ERROR_STATUS_TEXT, _DYN_EXCLUDE_REQUEST_FROM6, _DYN_GET_ABSOLUTE_URL, _DYN_GET_ALL_RESPONSE_HEA13, _DYN_GET_PART_APROPS, _DYN_GET_TRACE_FLAGS, _DYN_GET_TRACE_ID, _DYN_HEADERS, _DYN_HEADER_MAP, _DYN_INCLUDE_CORRELATION_0, _DYN_LENGTH, _DYN_MAX_AJAX_CALLS_PER_V5, _DYN_METHOD, _DYN_PERF_MARK, _DYN_PERF_TIMING, _DYN_REQUEST_HEADERS, _DYN_REQUEST_SENT_TIME, _DYN_REQUEST_URL, _DYN_RESPONSE_FINISHED_TI12, _DYN_RESPONSE_TEXT, _DYN_SET_REQUEST_HEADER, _DYN_SPAN_ID, _DYN_START_TIME, _DYN_STATE_CHANGE_ATTACHE11, _DYN_STATUS, _DYN_STATUS_TEXT, _DYN_TO_LOWER_CASE, _DYN_TRACE_FLAGS, _DYN_TRACE_ID, _DYN_TRACK_DEPENDENCY_DAT1, _DYN__ADD_HOOK, _DYN__CREATE_TRACK_ITEM } from \"./__DynamicConstants\";\r\nimport { ajaxRecord } from \"./ajaxRecord\";\r\n// const AJAX_MONITOR_PREFIX = \"ai.ajxmn.\";\r\nvar strDiagLog = \"diagLog\";\r\nvar AJAX_DATA_CONTAINER = \"_ajaxData\";\r\nvar STR_FETCH = \"fetch\";\r\nvar ERROR_HEADER = \"Failed to monitor XMLHttpRequest\";\r\nvar ERROR_PREFIX = \", monitoring data for this ajax call \";\r\nvar ERROR_POSTFIX = ERROR_PREFIX + \"may be incorrect.\";\r\nvar ERROR_NOT_SENT = ERROR_PREFIX + \"won't be sent.\";\r\nvar CORRELATION_HEADER_ERROR = \"Failed to get Request-Context correlation header as it may be not included in the response or not accessible.\";\r\nvar CUSTOM_REQUEST_CONTEXT_ERROR = \"Failed to add custom defined request context as configured call back may missing a null check.\";\r\nvar FAILED_TO_CALCULATE_DURATION_ERROR = \"Failed to calculate the duration of the \";\r\n// Using a global value so that to handle same iKey with multiple app insights instances (mostly for testing)\r\nvar _markCount = 0;\r\n/** @Ignore */\r\nfunction _supportsFetch() {\r\n var _global = getGlobal();\r\n if (!_global ||\r\n isNullOrUndefined(_global.Request) ||\r\n isNullOrUndefined(_global.Request[strPrototype]) ||\r\n isNullOrUndefined(_global[STR_FETCH])) {\r\n return null;\r\n }\r\n return _global[STR_FETCH];\r\n}\r\n/**\r\n * Determines whether ajax monitoring can be enabled on this document\r\n * @returns True if Ajax monitoring is supported on this page, otherwise false\r\n * @ignore\r\n */\r\nfunction _supportsAjaxMonitoring(ajaxMonitorInstance, ajaxDataId) {\r\n var _a;\r\n var result = false;\r\n if (isXhrSupported()) {\r\n var proto = XMLHttpRequest[strPrototype];\r\n result = !isNullOrUndefined(proto) &&\r\n !isNullOrUndefined(proto.open) && // eslint-disable-line security/detect-non-literal-fs-filename -- false positive\r\n !isNullOrUndefined(proto.send) &&\r\n !isNullOrUndefined(proto.abort);\r\n }\r\n var ieVer = getIEVersion();\r\n if (ieVer && ieVer < 9) {\r\n result = false;\r\n }\r\n if (result) {\r\n // Disable if the XmlHttpRequest can't be extended or hooked\r\n try {\r\n var xhr = new XMLHttpRequest();\r\n var xhrData = {\r\n xh: [],\r\n i: (_a = {},\r\n _a[ajaxDataId] = {},\r\n _a)\r\n };\r\n xhr[AJAX_DATA_CONTAINER] = xhrData;\r\n // Check that we can update the prototype\r\n var theOpen = XMLHttpRequest[strPrototype].open;\r\n XMLHttpRequest[strPrototype].open = theOpen;\r\n }\r\n catch (e) {\r\n // We can't decorate the xhr object so disable monitoring\r\n result = false;\r\n _throwInternalCritical(ajaxMonitorInstance, 15 /* _eInternalMessageId.FailedMonitorAjaxOpen */, \"Failed to enable XMLHttpRequest monitoring, extension is not supported\", {\r\n exception: dumpObj(e)\r\n });\r\n }\r\n }\r\n return result;\r\n}\r\n/**\r\n * Internal helper to fetch the SDK instance tracking data for this XHR request\r\n * @param xhr\r\n * @param ajaxDataId\r\n * @returns\r\n */\r\nvar _getAjaxData = function (xhr, ajaxDataId) {\r\n if (xhr && ajaxDataId && xhr[AJAX_DATA_CONTAINER]) {\r\n return (xhr[AJAX_DATA_CONTAINER].i || {})[ajaxDataId];\r\n }\r\n return null;\r\n};\r\n/**\r\n * @ignore\r\n * Internal helper to track the singleton shared tracking headers, so we can attempt to not create headers\r\n * that might cause an issue if multiple values are populated.\r\n * @param xhr - The instrumented XHR instance\r\n */\r\nvar _addSharedXhrHeaders = function (xhr, name, value) {\r\n if (xhr) {\r\n var headers = (xhr[AJAX_DATA_CONTAINER] || {}).xh;\r\n if (headers) {\r\n headers.push({\r\n n: name,\r\n v: value\r\n });\r\n }\r\n }\r\n};\r\nvar _isHeaderSet = function (xhr, name) {\r\n var isPresent = false;\r\n if (xhr) {\r\n var headers = (xhr[AJAX_DATA_CONTAINER] || {}).xh;\r\n if (headers) {\r\n arrForEach(headers, function (header) {\r\n if (header.n === name) {\r\n isPresent = true;\r\n return -1;\r\n }\r\n });\r\n }\r\n }\r\n return isPresent;\r\n};\r\n/** @Ignore */\r\nfunction _getFailedAjaxDiagnosticsMessage(xhr, ajaxDataId) {\r\n var result = \"\";\r\n try {\r\n var ajaxData = _getAjaxData(xhr, ajaxDataId);\r\n if (ajaxData && ajaxData[_DYN_REQUEST_URL /* @min:%2erequestUrl */]) {\r\n result += \"(url: '\" + ajaxData[_DYN_REQUEST_URL /* @min:%2erequestUrl */] + \"')\";\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return result;\r\n}\r\n/** @ignore */\r\nfunction _throwInternalCritical(ajaxMonitorInstance, msgId, message, properties, isUserAct) {\r\n _throwInternal(ajaxMonitorInstance[strDiagLog](), 1 /* eLoggingSeverity.CRITICAL */, msgId, message, properties, isUserAct);\r\n}\r\n/** @ignore */\r\nfunction _throwInternalWarning(ajaxMonitorInstance, msgId, message, properties, isUserAct) {\r\n _throwInternal(ajaxMonitorInstance[strDiagLog](), 2 /* eLoggingSeverity.WARNING */, msgId, message, properties, isUserAct);\r\n}\r\n/** @Ignore */\r\nfunction _createErrorCallbackFunc(ajaxMonitorInstance, internalMessage, message) {\r\n // tslint:disable-next-line\r\n return function (callDetails) {\r\n var _a;\r\n _throwInternalCritical(ajaxMonitorInstance, internalMessage, message, (_a = {},\r\n _a[_DYN_AJAX_DIAGNOSTICS_MES14 /* @min:ajaxDiagnosticsMessage */] = _getFailedAjaxDiagnosticsMessage(callDetails.inst, ajaxMonitorInstance._ajaxDataId),\r\n _a.exception = dumpObj(callDetails.err),\r\n _a));\r\n };\r\n}\r\nfunction _indexOf(value, match) {\r\n if (value && match) {\r\n return strIndexOf(value, match);\r\n }\r\n return -1;\r\n}\r\nfunction _addHandler(container, id, theFunc) {\r\n var theHandler = {\r\n id: id,\r\n fn: theFunc\r\n };\r\n container.push(theHandler);\r\n return {\r\n remove: function () {\r\n arrForEach(container, function (initializer, idx) {\r\n if (initializer.id === theHandler.id) {\r\n container.splice(idx, 1);\r\n return -1;\r\n }\r\n });\r\n }\r\n };\r\n}\r\nfunction _processDependencyContainer(core, container, details, message) {\r\n var result = true;\r\n arrForEach(container, function (theFunc, idx) {\r\n try {\r\n if (theFunc.fn.call(null, details) === false) {\r\n result = false;\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(core && core.logger, 1 /* eLoggingSeverity.CRITICAL */, 64 /* _eInternalMessageId.TelemetryInitializerFailed */, \"Dependency \" + message + \" [#\" + idx + \"] failed: \" + getExceptionName(e), { exception: dumpObj(e) }, true);\r\n }\r\n });\r\n return result;\r\n}\r\nfunction _processDependencyListeners(listeners, core, ajaxData, xhr, input, init) {\r\n var initializersCount = listeners[_DYN_LENGTH /* @min:%2elength */];\r\n if (initializersCount > 0) {\r\n var details = {\r\n core: core,\r\n xhr: xhr,\r\n input: input,\r\n init: init,\r\n traceId: ajaxData[_DYN_TRACE_ID /* @min:%2etraceID */],\r\n spanId: ajaxData[_DYN_SPAN_ID /* @min:%2espanID */],\r\n traceFlags: ajaxData[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */],\r\n context: ajaxData[_DYN_CONTEXT /* @min:%2econtext */] || {},\r\n aborted: !!ajaxData[_DYN_ABORTED /* @min:%2eaborted */]\r\n };\r\n _processDependencyContainer(core, listeners, details, \"listener\");\r\n ajaxData[_DYN_TRACE_ID /* @min:%2etraceID */] = details.traceId;\r\n ajaxData[_DYN_SPAN_ID /* @min:%2espanID */] = details.spanId;\r\n ajaxData[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */] = details[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */];\r\n ajaxData[_DYN_CONTEXT /* @min:%2econtext */] = details[_DYN_CONTEXT /* @min:%2econtext */];\r\n }\r\n}\r\nvar BLOB_CORE = \"*.blob.core.\";\r\nexport var DfltAjaxCorrelationHeaderExDomains = objFreeze([\r\n BLOB_CORE + \"windows.net\",\r\n BLOB_CORE + \"chinacloudapi.cn\",\r\n BLOB_CORE + \"cloudapi.de\",\r\n BLOB_CORE + \"usgovcloudapi.net\"\r\n]);\r\nvar _internalExcludeEndpoints = [\r\n /https:\\/\\/[^\\/]*(\\.pipe\\.aria|aria\\.pipe|events\\.data|collector\\.azure)\\.[^\\/]+\\/(OneCollector\\/1|Collector\\/3)\\.0/i\r\n];\r\nvar _defaultConfig = objFreeze((_a = {},\r\n _a[_DYN_MAX_AJAX_CALLS_PER_V5 /* @min:maxAjaxCallsPerView */] = 500,\r\n _a[_DYN_DISABLE_AJAX_TRACKIN7 /* @min:disableAjaxTracking */] = false,\r\n _a[_DYN_DISABLE_FETCH_TRACKI9 /* @min:disableFetchTracking */] = false,\r\n _a[_DYN_EXCLUDE_REQUEST_FROM6 /* @min:excludeRequestFromAutoTrackingPatterns */] = undefined,\r\n _a.disableCorrelationHeaders = false,\r\n _a.distributedTracingMode = 1 /* eDistributedTracingModes.AI_AND_W3C */,\r\n _a.correlationHeaderExcludedDomains = DfltAjaxCorrelationHeaderExDomains,\r\n _a.correlationHeaderDomains = undefined,\r\n _a.correlationHeaderExcludePatterns = undefined,\r\n _a.appId = undefined,\r\n _a.enableCorsCorrelation = false,\r\n _a[_DYN_ENABLE_REQUEST_HEADE2 /* @min:enableRequestHeaderTracking */] = false,\r\n _a[_DYN_ENABLE_RESPONSE_HEAD10 /* @min:enableResponseHeaderTracking */] = false,\r\n _a[_DYN_ENABLE_AJAX_ERROR_ST3 /* @min:enableAjaxErrorStatusText */] = false,\r\n _a[_DYN_ENABLE_AJAX_PERF_TRA4 /* @min:enableAjaxPerfTracking */] = false,\r\n _a.maxAjaxPerfLookupAttempts = 3,\r\n _a[_DYN_AJAX_PERF_LOOKUP_DEL8 /* @min:ajaxPerfLookupDelay */] = 25,\r\n _a.ignoreHeaders = [\r\n \"Authorization\",\r\n \"X-API-Key\",\r\n \"WWW-Authenticate\"\r\n ],\r\n _a.addRequestContext = undefined,\r\n _a.addIntEndpoints = true,\r\n _a));\r\nvar AjaxMonitor = /** @class */ (function (_super) {\r\n __extends(AjaxMonitor, _super);\r\n function AjaxMonitor() {\r\n var _this = _super.call(this) || this;\r\n _this.identifier = AjaxMonitor.identifier;\r\n _this.priority = 120;\r\n var _fetchInitialized; // fetch monitoring initialized\r\n var _xhrInitialized; // XHR monitoring initialized\r\n var _currentWindowHost;\r\n var _extensionConfig;\r\n var _enableRequestHeaderTracking;\r\n var _enableAjaxErrorStatusText;\r\n var _trackAjaxAttempts;\r\n var _context;\r\n var _isUsingW3CHeaders;\r\n var _isUsingAIHeaders;\r\n var _markPrefix;\r\n var _enableAjaxPerfTracking;\r\n var _maxAjaxCallsPerView;\r\n var _enableResponseHeaderTracking;\r\n var _disabledUrls;\r\n var _disableAjaxTracking;\r\n var _disableFetchTracking;\r\n var _excludeRequestFromAutoTrackingPatterns;\r\n var _addRequestContext;\r\n var _evtNamespace;\r\n var _ajaxDataId;\r\n var _dependencyHandlerId;\r\n var _dependencyListeners;\r\n var _dependencyInitializers;\r\n var _ignoreHeaders;\r\n var _maxAjaxPerfLookupAttempts;\r\n var _ajaxPerfLookupDelay;\r\n var _distributedTracingMode;\r\n var _appId;\r\n var _polyfillInitialized;\r\n dynamicProto(AjaxMonitor, _this, function (_self, _base) {\r\n var _addHook = _base[_DYN__ADD_HOOK /* @min:%2e_addHook */];\r\n _initDefaults();\r\n _self.initialize = function (config, core, extensions, pluginChain) {\r\n if (!_self.isInitialized()) {\r\n _base.initialize(config, core, extensions, pluginChain);\r\n _evtNamespace = mergeEvtNamespace(createUniqueNamespace(\"ajax\"), core && core.evtNamespace && core.evtNamespace());\r\n _populateDefaults(config);\r\n _instrumentXhr();\r\n _instrumentFetch();\r\n _populateContext();\r\n }\r\n };\r\n _self._doTeardown = function () {\r\n _initDefaults();\r\n };\r\n _self.trackDependencyData = function (dependency, properties) {\r\n _reportDependencyInternal(_dependencyInitializers, _self[_DYN_CORE /* @min:%2ecore */], null, dependency, properties);\r\n };\r\n _self[_DYN_INCLUDE_CORRELATION_0 /* @min:%2eincludeCorrelationHeaders */] = function (ajaxData, input, init, xhr) {\r\n // Test Hook to allow the overriding of the location host\r\n var currentWindowHost = _self[\"_currentWindowHost\"] || _currentWindowHost;\r\n _processDependencyListeners(_dependencyListeners, _self[_DYN_CORE /* @min:%2ecore */], ajaxData, xhr, input, init);\r\n if (input || input === \"\") { // Fetch\r\n if (correlationIdCanIncludeCorrelationHeader(_extensionConfig, ajaxData[_DYN_GET_ABSOLUTE_URL /* @min:%2egetAbsoluteUrl */](), currentWindowHost)) {\r\n if (!init) {\r\n init = {};\r\n }\r\n // init headers override original request headers\r\n // so, if they exist use only them, otherwise use request's because they should have been applied in the first place\r\n // not using original request headers will result in them being lost\r\n var headers = new Headers(init[_DYN_HEADERS /* @min:%2eheaders */] || (input instanceof Request ? (input[_DYN_HEADERS /* @min:%2eheaders */] || {}) : {}));\r\n if (_isUsingAIHeaders) {\r\n var id = \"|\" + ajaxData[_DYN_TRACE_ID /* @min:%2etraceID */] + \".\" + ajaxData[_DYN_SPAN_ID /* @min:%2espanID */];\r\n headers.set(RequestHeaders[3 /* eRequestHeaders.requestIdHeader */], id);\r\n if (_enableRequestHeaderTracking) {\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][RequestHeaders[3 /* eRequestHeaders.requestIdHeader */]] = id;\r\n }\r\n }\r\n var appId = _appId || (_context && _context.appId());\r\n if (appId) {\r\n headers.set(RequestHeaders[0 /* eRequestHeaders.requestContextHeader */], RequestHeaders[2 /* eRequestHeaders.requestContextAppIdFormat */] + appId);\r\n if (_enableRequestHeaderTracking) {\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][RequestHeaders[0 /* eRequestHeaders.requestContextHeader */]] = RequestHeaders[2 /* eRequestHeaders.requestContextAppIdFormat */] + appId;\r\n }\r\n }\r\n if (_isUsingW3CHeaders) {\r\n var traceFlags = ajaxData[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */];\r\n if (isNullOrUndefined(traceFlags)) {\r\n traceFlags = 0x01;\r\n }\r\n var traceParent = formatTraceParent(createTraceParent(ajaxData[_DYN_TRACE_ID /* @min:%2etraceID */], ajaxData[_DYN_SPAN_ID /* @min:%2espanID */], traceFlags));\r\n headers.set(RequestHeaders[4 /* eRequestHeaders.traceParentHeader */], traceParent);\r\n if (_enableRequestHeaderTracking) {\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][RequestHeaders[4 /* eRequestHeaders.traceParentHeader */]] = traceParent;\r\n }\r\n }\r\n init[_DYN_HEADERS /* @min:%2eheaders */] = headers;\r\n }\r\n return init;\r\n }\r\n else if (xhr) { // XHR\r\n if (correlationIdCanIncludeCorrelationHeader(_extensionConfig, ajaxData[_DYN_GET_ABSOLUTE_URL /* @min:%2egetAbsoluteUrl */](), currentWindowHost)) {\r\n if (_isUsingAIHeaders) {\r\n if (!_isHeaderSet(xhr, RequestHeaders[3 /* eRequestHeaders.requestIdHeader */])) {\r\n var id = \"|\" + ajaxData[_DYN_TRACE_ID /* @min:%2etraceID */] + \".\" + ajaxData[_DYN_SPAN_ID /* @min:%2espanID */];\r\n xhr[_DYN_SET_REQUEST_HEADER /* @min:%2esetRequestHeader */](RequestHeaders[3 /* eRequestHeaders.requestIdHeader */], id);\r\n if (_enableRequestHeaderTracking) {\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][RequestHeaders[3 /* eRequestHeaders.requestIdHeader */]] = id;\r\n }\r\n }\r\n else {\r\n _throwInternalWarning(_self, 71 /* _eInternalMessageId.FailedMonitorAjaxSetRequestHeader */, \"Unable to set [\" + RequestHeaders[3 /* eRequestHeaders.requestIdHeader */] + \"] as it has already been set by another instance\");\r\n }\r\n }\r\n var appId = _appId || (_context && _context.appId());\r\n if (appId) {\r\n if (!_isHeaderSet(xhr, RequestHeaders[0 /* eRequestHeaders.requestContextHeader */])) {\r\n xhr[_DYN_SET_REQUEST_HEADER /* @min:%2esetRequestHeader */](RequestHeaders[0 /* eRequestHeaders.requestContextHeader */], RequestHeaders[2 /* eRequestHeaders.requestContextAppIdFormat */] + appId);\r\n if (_enableRequestHeaderTracking) {\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][RequestHeaders[0 /* eRequestHeaders.requestContextHeader */]] = RequestHeaders[2 /* eRequestHeaders.requestContextAppIdFormat */] + appId;\r\n }\r\n }\r\n else {\r\n _throwInternalWarning(_self, 71 /* _eInternalMessageId.FailedMonitorAjaxSetRequestHeader */, \"Unable to set [\" + RequestHeaders[0 /* eRequestHeaders.requestContextHeader */] + \"] as it has already been set by another instance\");\r\n }\r\n }\r\n if (_isUsingW3CHeaders) {\r\n var traceFlags = ajaxData[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */];\r\n if (isNullOrUndefined(traceFlags)) {\r\n traceFlags = 0x01;\r\n }\r\n if (!_isHeaderSet(xhr, RequestHeaders[4 /* eRequestHeaders.traceParentHeader */])) {\r\n var traceParent = formatTraceParent(createTraceParent(ajaxData[_DYN_TRACE_ID /* @min:%2etraceID */], ajaxData[_DYN_SPAN_ID /* @min:%2espanID */], traceFlags));\r\n xhr[_DYN_SET_REQUEST_HEADER /* @min:%2esetRequestHeader */](RequestHeaders[4 /* eRequestHeaders.traceParentHeader */], traceParent);\r\n if (_enableRequestHeaderTracking) {\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][RequestHeaders[4 /* eRequestHeaders.traceParentHeader */]] = traceParent;\r\n }\r\n }\r\n else {\r\n _throwInternalWarning(_self, 71 /* _eInternalMessageId.FailedMonitorAjaxSetRequestHeader */, \"Unable to set [\" + RequestHeaders[4 /* eRequestHeaders.traceParentHeader */] + \"] as it has already been set by another instance\");\r\n }\r\n }\r\n }\r\n return xhr;\r\n }\r\n return undefined;\r\n };\r\n _self[_DYN_TRACK_DEPENDENCY_DAT1 /* @min:%2etrackDependencyDataInternal */] = function (dependency, properties, systemProperties) {\r\n if (_maxAjaxCallsPerView === -1 || _trackAjaxAttempts < _maxAjaxCallsPerView) {\r\n // Hack since expected format in w3c mode is |abc.def.\r\n // Non-w3c format is |abc.def\r\n // @todo Remove if better solution is available, e.g. handle in portal\r\n if ((_distributedTracingMode === 2 /* eDistributedTracingModes.W3C */\r\n || _distributedTracingMode === 1 /* eDistributedTracingModes.AI_AND_W3C */)\r\n && typeof dependency.id === \"string\" && dependency.id[dependency.id[_DYN_LENGTH /* @min:%2elength */] - 1] !== \".\") {\r\n dependency.id += \".\";\r\n }\r\n if (isNullOrUndefined(dependency[_DYN_START_TIME /* @min:%2estartTime */])) {\r\n dependency[_DYN_START_TIME /* @min:%2estartTime */] = new Date();\r\n }\r\n var item = createTelemetryItem(dependency, RemoteDependencyData.dataType, RemoteDependencyData.envelopeType, _self[strDiagLog](), properties, systemProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */].track(item);\r\n }\r\n else if (_trackAjaxAttempts === _maxAjaxCallsPerView) {\r\n _throwInternalCritical(_self, 55 /* _eInternalMessageId.MaxAjaxPerPVExceeded */, \"Maximum ajax per page view limit reached, ajax monitoring is paused until the next trackPageView(). In order to increase the limit set the maxAjaxCallsPerView configuration parameter.\", true);\r\n }\r\n ++_trackAjaxAttempts;\r\n };\r\n _self.addDependencyListener = function (dependencyListener) {\r\n return _addHandler(_dependencyListeners, _dependencyHandlerId++, dependencyListener);\r\n };\r\n _self.addDependencyInitializer = function (dependencyInitializer) {\r\n return _addHandler(_dependencyInitializers, _dependencyHandlerId++, dependencyInitializer);\r\n };\r\n function _initDefaults() {\r\n var location = getLocation();\r\n _fetchInitialized = false; // fetch monitoring initialized\r\n _xhrInitialized = false; // XHR monitoring initialized\r\n _polyfillInitialized = false; // polyfill monitoring initialized\r\n _currentWindowHost = location && location.host && location.host[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n _extensionConfig = null;\r\n _enableRequestHeaderTracking = false;\r\n _enableAjaxErrorStatusText = false;\r\n _trackAjaxAttempts = 0;\r\n _context = null;\r\n _isUsingW3CHeaders = false;\r\n _isUsingAIHeaders = false;\r\n _markPrefix = null;\r\n _enableAjaxPerfTracking = false;\r\n _maxAjaxCallsPerView = 0;\r\n _enableResponseHeaderTracking = false;\r\n _disabledUrls = {};\r\n _disableAjaxTracking = false;\r\n _disableFetchTracking = false;\r\n _excludeRequestFromAutoTrackingPatterns = null;\r\n _addRequestContext = null;\r\n _evtNamespace = null;\r\n _dependencyHandlerId = 0;\r\n _dependencyListeners = [];\r\n _dependencyInitializers = [];\r\n _ajaxDataId = createUniqueNamespace(\"ajaxData\");\r\n _self._ajaxDataId = _ajaxDataId;\r\n _ignoreHeaders = null;\r\n _maxAjaxPerfLookupAttempts = 1;\r\n _ajaxPerfLookupDelay = 1;\r\n _distributedTracingMode = 1 /* eDistributedTracingModes.AI_AND_W3C */;\r\n _appId = null;\r\n }\r\n function _populateDefaults(config) {\r\n _self[_DYN__ADD_HOOK /* @min:%2e_addHook */](onConfigChange(config, function (details) {\r\n var config = details.cfg;\r\n var ctx = createProcessTelemetryContext(null, config, _self[_DYN_CORE /* @min:%2ecore */]);\r\n _extensionConfig = ctx.getExtCfg(AjaxMonitor.identifier, _defaultConfig);\r\n _distributedTracingMode = _extensionConfig.distributedTracingMode;\r\n _enableRequestHeaderTracking = _extensionConfig[_DYN_ENABLE_REQUEST_HEADE2 /* @min:%2eenableRequestHeaderTracking */];\r\n _enableAjaxErrorStatusText = _extensionConfig[_DYN_ENABLE_AJAX_ERROR_ST3 /* @min:%2eenableAjaxErrorStatusText */];\r\n _enableAjaxPerfTracking = _extensionConfig[_DYN_ENABLE_AJAX_PERF_TRA4 /* @min:%2eenableAjaxPerfTracking */];\r\n _maxAjaxCallsPerView = _extensionConfig[_DYN_MAX_AJAX_CALLS_PER_V5 /* @min:%2emaxAjaxCallsPerView */];\r\n _excludeRequestFromAutoTrackingPatterns = [].concat(_extensionConfig[_DYN_EXCLUDE_REQUEST_FROM6 /* @min:%2eexcludeRequestFromAutoTrackingPatterns */] || [], _extensionConfig.addIntEndpoints !== false ? _internalExcludeEndpoints : []);\r\n _addRequestContext = _extensionConfig.addRequestContext;\r\n _isUsingAIHeaders = _distributedTracingMode === 0 /* eDistributedTracingModes.AI */ || _distributedTracingMode === 1 /* eDistributedTracingModes.AI_AND_W3C */;\r\n _isUsingW3CHeaders = _distributedTracingMode === 1 /* eDistributedTracingModes.AI_AND_W3C */ || _distributedTracingMode === 2 /* eDistributedTracingModes.W3C */;\r\n if (_enableAjaxPerfTracking) {\r\n _markPrefix = _ajaxDataId;\r\n }\r\n _disableAjaxTracking = !!_extensionConfig[_DYN_DISABLE_AJAX_TRACKIN7 /* @min:%2edisableAjaxTracking */];\r\n _maxAjaxPerfLookupAttempts = _extensionConfig.maxAjaxPerfLookupAttempts;\r\n _ajaxPerfLookupDelay = _extensionConfig[_DYN_AJAX_PERF_LOOKUP_DEL8 /* @min:%2eajaxPerfLookupDelay */];\r\n _ignoreHeaders = _extensionConfig.ignoreHeaders;\r\n _appId = _extensionConfig.appId;\r\n }));\r\n }\r\n function _populateContext() {\r\n var propExt = _self[_DYN_CORE /* @min:%2ecore */].getPlugin(PropertiesPluginIdentifier);\r\n if (propExt) {\r\n _context = propExt.plugin[_DYN_CONTEXT /* @min:%2econtext */]; // we could move IPropertiesPlugin to common as well\r\n }\r\n }\r\n // discard the header if it's defined as ignoreHeaders in ICorrelationConfig\r\n function _canIncludeHeaders(header) {\r\n var rlt = true;\r\n if (header || _ignoreHeaders) {\r\n arrForEach(_ignoreHeaders, (function (key) {\r\n if (key[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]() === header[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]()) {\r\n rlt = false;\r\n return -1;\r\n }\r\n }));\r\n }\r\n return rlt;\r\n }\r\n // Fetch Stuff\r\n function _instrumentFetch() {\r\n var fetch = _supportsFetch();\r\n if (!fetch) {\r\n return;\r\n }\r\n var global = getGlobal();\r\n var isPolyfill = fetch.polyfill;\r\n _self[_DYN__ADD_HOOK /* @min:%2e_addHook */](onConfigChange(_extensionConfig, function () {\r\n _disableFetchTracking = !!_extensionConfig[_DYN_DISABLE_FETCH_TRACKI9 /* @min:%2edisableFetchTracking */];\r\n _enableResponseHeaderTracking = _extensionConfig[_DYN_ENABLE_RESPONSE_HEAD10 /* @min:%2eenableResponseHeaderTracking */];\r\n if (!_disableFetchTracking && !_fetchInitialized) {\r\n _addHook(InstrumentFunc(global, STR_FETCH, {\r\n ns: _evtNamespace,\r\n // Add request hook\r\n req: function (callDetails, input, init) {\r\n var fetchData;\r\n if (!_disableFetchTracking && _fetchInitialized &&\r\n !_isDisabledRequest(null, input, init) &&\r\n // If we have a polyfil and XHR instrumented then let XHR report otherwise we get duplicates\r\n !(isPolyfill && _xhrInitialized)) {\r\n var ctx = callDetails.ctx();\r\n fetchData = _createFetchRecord(input, init);\r\n var newInit = _self[_DYN_INCLUDE_CORRELATION_0 /* @min:%2eincludeCorrelationHeaders */](fetchData, input, init);\r\n if (newInit !== init) {\r\n callDetails.set(1, newInit);\r\n }\r\n ctx.data = fetchData;\r\n }\r\n },\r\n rsp: function (callDetails, input) {\r\n if (!_disableFetchTracking) {\r\n var fetchData_1 = callDetails.ctx().data;\r\n if (fetchData_1) {\r\n // Replace the result with the new promise from this code\r\n callDetails.rslt = callDetails.rslt.then(function (response) {\r\n _reportFetchMetrics(callDetails, (response || {})[_DYN_STATUS /* @min:%2estatus */], input, response, fetchData_1, function () {\r\n var _a;\r\n var ajaxResponse = (_a = {\r\n statusText: (response || {})[_DYN_STATUS_TEXT /* @min:%2estatusText */],\r\n headerMap: null\r\n },\r\n _a[_DYN_CORRELATION_CONTEXT /* @min:correlationContext */] = _getFetchCorrelationContext(response),\r\n _a);\r\n if (_enableResponseHeaderTracking && response) {\r\n var responseHeaderMap_1 = {};\r\n response.headers.forEach(function (value, name) {\r\n if (_canIncludeHeaders(name)) {\r\n responseHeaderMap_1[name] = value;\r\n }\r\n });\r\n ajaxResponse[_DYN_HEADER_MAP /* @min:%2eheaderMap */] = responseHeaderMap_1;\r\n }\r\n return ajaxResponse;\r\n });\r\n return response;\r\n })\r\n .catch(function (reason) {\r\n _reportFetchMetrics(callDetails, 0, input, null, fetchData_1, null, { error: reason.message || dumpObj(reason) });\r\n throw reason;\r\n });\r\n }\r\n }\r\n },\r\n // Create an error callback to report any hook errors\r\n hkErr: _createErrorCallbackFunc(_self, 15 /* _eInternalMessageId.FailedMonitorAjaxOpen */, \"Failed to monitor Window.fetch\" + ERROR_POSTFIX)\r\n }, true, isWebWorker()));\r\n _fetchInitialized = true;\r\n }\r\n else if (isPolyfill && !_polyfillInitialized) {\r\n // If fetch is a polyfill we need to capture the request to ensure that we correctly track\r\n // disabled request URLS (i.e. internal urls) to ensure we don't end up in a constant loop\r\n // of reporting ourselves, for example React Native uses a polyfill for fetch\r\n // Note: Polyfill implementations that don't support the \"polyfill\" tag are not supported\r\n // the workaround is to add a polyfill property to your fetch implementation before initializing\r\n // App Insights\r\n _addHook(InstrumentFunc(global, STR_FETCH, {\r\n ns: _evtNamespace,\r\n req: function (callDetails, input, init) {\r\n // Just call so that we record any disabled URL\r\n _isDisabledRequest(null, input, init);\r\n }\r\n }));\r\n _polyfillInitialized = true;\r\n }\r\n }));\r\n if (isPolyfill) {\r\n // retag the instrumented fetch with the same polyfill settings this is mostly for testing\r\n // But also supports multiple App Insights usages\r\n global[STR_FETCH].polyfill = isPolyfill;\r\n }\r\n }\r\n function _hookProto(target, funcName, callbacks) {\r\n _addHook(InstrumentProto(target, funcName, callbacks));\r\n }\r\n function _instrumentXhr() {\r\n if (!_supportsAjaxMonitoring(_self, _ajaxDataId)) {\r\n return;\r\n }\r\n _self[_DYN__ADD_HOOK /* @min:%2e_addHook */](onConfigChange(_extensionConfig, function () {\r\n _disableAjaxTracking = !!_extensionConfig[_DYN_DISABLE_AJAX_TRACKIN7 /* @min:%2edisableAjaxTracking */];\r\n _enableRequestHeaderTracking = _extensionConfig[_DYN_ENABLE_REQUEST_HEADE2 /* @min:%2eenableRequestHeaderTracking */];\r\n if (!_disableAjaxTracking && !_xhrInitialized) {\r\n // Instrument open\r\n _hookProto(XMLHttpRequest, \"open\", {\r\n ns: _evtNamespace,\r\n req: function (callDetails, method, url, async) {\r\n if (!_disableAjaxTracking) {\r\n var xhr = callDetails.inst;\r\n var ajaxData = _getAjaxData(xhr, _ajaxDataId);\r\n if (!_isDisabledRequest(xhr, url) && _isMonitoredXhrInstance(xhr, ajaxData, true)) {\r\n if (!ajaxData || !ajaxData.xhrMonitoringState.openDone) {\r\n // Only create a single ajaxData (even when multiple AI instances are running)\r\n ajaxData = _openHandler(xhr, method, url, async);\r\n }\r\n // always attach to the on ready state change (required for handling multiple instances)\r\n _attachToOnReadyStateChange(xhr, ajaxData);\r\n }\r\n }\r\n },\r\n hkErr: _createErrorCallbackFunc(_self, 15 /* _eInternalMessageId.FailedMonitorAjaxOpen */, ERROR_HEADER + \".open\" + ERROR_POSTFIX)\r\n });\r\n // Instrument send\r\n _hookProto(XMLHttpRequest, \"send\", {\r\n ns: _evtNamespace,\r\n req: function (callDetails, context) {\r\n if (!_disableAjaxTracking) {\r\n var xhr = callDetails.inst;\r\n var ajaxData = _getAjaxData(xhr, _ajaxDataId);\r\n if (_isMonitoredXhrInstance(xhr, ajaxData) && !ajaxData.xhrMonitoringState.sendDone) {\r\n _createMarkId(\"xhr\", ajaxData);\r\n ajaxData[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */] = dateTimeUtilsNow();\r\n _self[_DYN_INCLUDE_CORRELATION_0 /* @min:%2eincludeCorrelationHeaders */](ajaxData, undefined, undefined, xhr);\r\n ajaxData.xhrMonitoringState.sendDone = true;\r\n }\r\n }\r\n },\r\n hkErr: _createErrorCallbackFunc(_self, 17 /* _eInternalMessageId.FailedMonitorAjaxSend */, ERROR_HEADER + ERROR_POSTFIX)\r\n });\r\n // Instrument abort\r\n _hookProto(XMLHttpRequest, \"abort\", {\r\n ns: _evtNamespace,\r\n req: function (callDetails) {\r\n if (!_disableAjaxTracking) {\r\n var xhr = callDetails.inst;\r\n var ajaxData = _getAjaxData(xhr, _ajaxDataId);\r\n if (_isMonitoredXhrInstance(xhr, ajaxData) && !ajaxData.xhrMonitoringState.abortDone) {\r\n ajaxData[_DYN_ABORTED /* @min:%2eaborted */] = 1;\r\n ajaxData.xhrMonitoringState.abortDone = true;\r\n }\r\n }\r\n },\r\n hkErr: _createErrorCallbackFunc(_self, 13 /* _eInternalMessageId.FailedMonitorAjaxAbort */, ERROR_HEADER + \".abort\" + ERROR_POSTFIX)\r\n });\r\n // Instrument setRequestHeader\r\n _hookProto(XMLHttpRequest, \"setRequestHeader\", {\r\n ns: _evtNamespace,\r\n req: function (callDetails, header, value) {\r\n if (!_disableAjaxTracking) {\r\n var xhr = callDetails.inst;\r\n var ajaxData = _getAjaxData(xhr, _ajaxDataId);\r\n if (ajaxData && _isMonitoredXhrInstance(xhr, ajaxData)) {\r\n _addSharedXhrHeaders(xhr, header, value);\r\n if (_enableRequestHeaderTracking && _canIncludeHeaders(header)) {\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][header] = value;\r\n }\r\n }\r\n }\r\n },\r\n hkErr: _createErrorCallbackFunc(_self, 71 /* _eInternalMessageId.FailedMonitorAjaxSetRequestHeader */, ERROR_HEADER + \".setRequestHeader\" + ERROR_POSTFIX)\r\n });\r\n _xhrInitialized = true;\r\n }\r\n }));\r\n }\r\n function _isDisabledRequest(xhr, request, init) {\r\n var isDisabled = false;\r\n var theUrl = ((!isString(request) ? (request || {}).url || \"\" : request) || \"\")[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n // check excludeRequestFromAutoTrackingPatterns before stripping off any query string\r\n arrForEach(_excludeRequestFromAutoTrackingPatterns, function (regex) {\r\n var theRegex = regex;\r\n if (isString(regex)) {\r\n theRegex = new RegExp(regex);\r\n }\r\n if (!isDisabled) {\r\n isDisabled = theRegex.test(theUrl);\r\n }\r\n });\r\n // if request url matches with exclude regex pattern, return true and no need to check for headers\r\n if (isDisabled) {\r\n return isDisabled;\r\n }\r\n var idx = _indexOf(theUrl, \"?\");\r\n var idx2 = _indexOf(theUrl, \"#\");\r\n if (idx === -1 || (idx2 !== -1 && idx2 < idx)) {\r\n idx = idx2;\r\n }\r\n if (idx !== -1) {\r\n // Strip off any Query string\r\n theUrl = theUrl.substring(0, idx);\r\n }\r\n // check that this instance is not not used by ajax call performed inside client side monitoring to send data to collector\r\n if (!isNullOrUndefined(xhr)) {\r\n // Look on the XMLHttpRequest of the URL string value\r\n isDisabled = xhr[DisabledPropertyName] === true || theUrl[DisabledPropertyName] === true;\r\n }\r\n else if (!isNullOrUndefined(request)) { // fetch\r\n // Look for DisabledPropertyName in either Request or RequestInit\r\n isDisabled = (typeof request === \"object\" ? request[DisabledPropertyName] === true : false) ||\r\n (init ? init[DisabledPropertyName] === true : false);\r\n }\r\n // Also add extra check just in case the XHR or fetch objects where not decorated with the DisableProperty due to sealing or freezing\r\n if (!isDisabled && theUrl && isInternalApplicationInsightsEndpoint(theUrl)) {\r\n isDisabled = true;\r\n }\r\n if (isDisabled) {\r\n // Add the disabled url if not present\r\n if (!_disabledUrls[theUrl]) {\r\n _disabledUrls[theUrl] = 1;\r\n }\r\n }\r\n else {\r\n // Check to see if the url is listed as disabled\r\n if (_disabledUrls[theUrl]) {\r\n isDisabled = true;\r\n }\r\n }\r\n return isDisabled;\r\n }\r\n /// Verifies that particular instance of XMLHttpRequest needs to be monitored\r\n /// Optional parameter. True if ajaxData must be excluded from verification\r\n /// True if instance needs to be monitored, otherwise false\r\n function _isMonitoredXhrInstance(xhr, ajaxData, excludeAjaxDataValidation) {\r\n var ajaxValidation = true;\r\n var initialized = _xhrInitialized;\r\n if (!isNullOrUndefined(xhr)) {\r\n ajaxValidation = excludeAjaxDataValidation === true || !isNullOrUndefined(ajaxData);\r\n }\r\n // checking to see that all interested functions on xhr were instrumented\r\n return initialized\r\n // checking on ajaxData to see that it was not removed in user code\r\n && ajaxValidation;\r\n }\r\n function _getDistributedTraceCtx() {\r\n var distributedTraceCtx = null;\r\n if (_self[_DYN_CORE /* @min:%2ecore */] && _self[_DYN_CORE /* @min:%2ecore */].getTraceCtx) {\r\n distributedTraceCtx = _self[_DYN_CORE /* @min:%2ecore */].getTraceCtx(false);\r\n }\r\n // Fall back\r\n if (!distributedTraceCtx && _context && _context.telemetryTrace) {\r\n distributedTraceCtx = createDistributedTraceContextFromTrace(_context.telemetryTrace);\r\n }\r\n return distributedTraceCtx;\r\n }\r\n function _openHandler(xhr, method, url, async) {\r\n var _a;\r\n var distributedTraceCtx = _getDistributedTraceCtx();\r\n var traceID = (distributedTraceCtx && distributedTraceCtx[_DYN_GET_TRACE_ID /* @min:%2egetTraceId */]()) || generateW3CId();\r\n var spanID = strSubstr(generateW3CId(), 0, 16);\r\n var xhrRequestData = xhr[AJAX_DATA_CONTAINER] = (xhr[AJAX_DATA_CONTAINER] || { xh: [], i: {} });\r\n var ajaxDataCntr = xhrRequestData.i = (xhrRequestData.i || {});\r\n var ajaxData = ajaxDataCntr[_ajaxDataId] = (ajaxDataCntr[_ajaxDataId] || new ajaxRecord(traceID, spanID, _self[strDiagLog](), (_a = _self.core) === null || _a === void 0 ? void 0 : _a.getTraceCtx()));\r\n ajaxData[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */] = distributedTraceCtx && distributedTraceCtx[_DYN_GET_TRACE_FLAGS /* @min:%2egetTraceFlags */]();\r\n ajaxData[_DYN_METHOD /* @min:%2emethod */] = method;\r\n ajaxData[_DYN_REQUEST_URL /* @min:%2erequestUrl */] = url;\r\n ajaxData.xhrMonitoringState.openDone = true;\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */] = {};\r\n ajaxData.async = async;\r\n ajaxData[_DYN_ERROR_STATUS_TEXT /* @min:%2eerrorStatusText */] = _enableAjaxErrorStatusText;\r\n return ajaxData;\r\n }\r\n function _attachToOnReadyStateChange(xhr, ajaxData) {\r\n ajaxData.xhrMonitoringState[_DYN_STATE_CHANGE_ATTACHE11 /* @min:%2estateChangeAttached */] = eventOn(xhr, \"readystatechange\", function () {\r\n var _a;\r\n try {\r\n if (xhr && xhr.readyState === 4 && _isMonitoredXhrInstance(xhr, ajaxData)) {\r\n _onAjaxComplete(xhr);\r\n }\r\n }\r\n catch (e) {\r\n var exceptionText = dumpObj(e);\r\n // ignore messages with c00c023f, as this a known IE9 XHR abort issue\r\n if (!exceptionText || _indexOf(exceptionText[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */](), \"c00c023f\") === -1) {\r\n _throwInternalCritical(_self, 16 /* _eInternalMessageId.FailedMonitorAjaxRSC */, ERROR_HEADER + \" 'readystatechange' event handler\" + ERROR_POSTFIX, (_a = {},\r\n _a[_DYN_AJAX_DIAGNOSTICS_MES14 /* @min:ajaxDiagnosticsMessage */] = _getFailedAjaxDiagnosticsMessage(xhr, _ajaxDataId),\r\n _a.exception = exceptionText,\r\n _a));\r\n }\r\n }\r\n }, _evtNamespace);\r\n }\r\n function _getResponseText(xhr) {\r\n try {\r\n var responseType = xhr.responseType;\r\n if (responseType === \"\" || responseType === \"text\") {\r\n // As per the specification responseText is only valid if the type is an empty string or \"text\"\r\n return xhr[_DYN_RESPONSE_TEXT /* @min:%2eresponseText */];\r\n }\r\n }\r\n catch (e) {\r\n // This shouldn't happen because of the above check -- but just in case, so just ignore\r\n }\r\n return null;\r\n }\r\n function _onAjaxComplete(xhr) {\r\n var ajaxData = _getAjaxData(xhr, _ajaxDataId);\r\n ajaxData[_DYN_RESPONSE_FINISHED_TI12 /* @min:%2eresponseFinishedTime */] = dateTimeUtilsNow();\r\n ajaxData[_DYN_STATUS /* @min:%2estatus */] = xhr[_DYN_STATUS /* @min:%2estatus */];\r\n function _reportXhrError(e, failedProps) {\r\n var errorProps = failedProps || {};\r\n errorProps[\"ajaxDiagnosticsMessage\"] = _getFailedAjaxDiagnosticsMessage(xhr, _ajaxDataId);\r\n if (e) {\r\n errorProps[\"exception\"] = dumpObj(e);\r\n }\r\n _throwInternalWarning(_self, 14 /* _eInternalMessageId.FailedMonitorAjaxDur */, FAILED_TO_CALCULATE_DURATION_ERROR + \"ajax call\" + ERROR_NOT_SENT, errorProps);\r\n }\r\n _findPerfResourceEntry(\"xmlhttprequest\", ajaxData, function () {\r\n try {\r\n var dependency = ajaxData[_DYN__CREATE_TRACK_ITEM /* @min:%2eCreateTrackItem */](\"Ajax\", _enableRequestHeaderTracking, function () {\r\n var _a;\r\n var ajaxResponse = (_a = {\r\n statusText: xhr[_DYN_STATUS_TEXT /* @min:%2estatusText */],\r\n headerMap: null\r\n },\r\n _a[_DYN_CORRELATION_CONTEXT /* @min:correlationContext */] = _getAjaxCorrelationContext(xhr),\r\n _a.type = xhr.responseType,\r\n _a[_DYN_RESPONSE_TEXT /* @min:responseText */] = _getResponseText(xhr),\r\n _a.response = xhr.response,\r\n _a);\r\n if (_enableResponseHeaderTracking) {\r\n var headers = xhr[_DYN_GET_ALL_RESPONSE_HEA13 /* @min:%2egetAllResponseHeaders */]();\r\n if (headers) {\r\n // xhr.getAllResponseHeaders() method returns all the response headers, separated by CRLF, as a string or null\r\n // the regex converts the header string into an array of individual headers\r\n var arr = strTrim(headers).split(/[\\r\\n]+/);\r\n var responseHeaderMap_2 = {};\r\n arrForEach(arr, function (line) {\r\n var parts = line.split(\": \");\r\n var header = parts.shift();\r\n var value = parts.join(\": \");\r\n if (_canIncludeHeaders(header)) {\r\n responseHeaderMap_2[header] = value;\r\n }\r\n });\r\n ajaxResponse[_DYN_HEADER_MAP /* @min:%2eheaderMap */] = responseHeaderMap_2;\r\n }\r\n }\r\n return ajaxResponse;\r\n });\r\n var properties = void 0;\r\n try {\r\n if (!!_addRequestContext) {\r\n properties = _addRequestContext({ status: xhr[_DYN_STATUS /* @min:%2estatus */], xhr: xhr });\r\n }\r\n }\r\n catch (e) {\r\n _throwInternalWarning(_self, 104 /* _eInternalMessageId.FailedAddingCustomDefinedRequestContext */, CUSTOM_REQUEST_CONTEXT_ERROR);\r\n }\r\n if (dependency) {\r\n if (properties !== undefined) {\r\n dependency[STR_PROPERTIES /* @min:%2eproperties */] = __assign(__assign({}, dependency.properties), properties);\r\n }\r\n var sysProperties = ajaxData[_DYN_GET_PART_APROPS /* @min:%2egetPartAProps */]();\r\n _reportDependencyInternal(_dependencyInitializers, _self[_DYN_CORE /* @min:%2ecore */], ajaxData, dependency, null, sysProperties);\r\n }\r\n else {\r\n _reportXhrError(null, {\r\n requestSentTime: ajaxData[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */],\r\n responseFinishedTime: ajaxData[_DYN_RESPONSE_FINISHED_TI12 /* @min:%2eresponseFinishedTime */]\r\n });\r\n }\r\n }\r\n finally {\r\n // cleanup telemetry data\r\n try {\r\n var xhrRequestData = (xhr[AJAX_DATA_CONTAINER] || { i: {} });\r\n var ajaxDataCntr = (xhrRequestData.i || {});\r\n if (ajaxDataCntr[_ajaxDataId]) {\r\n ajaxDataCntr[_ajaxDataId] = null;\r\n }\r\n }\r\n catch (e) {\r\n // May throw in environments that prevent extension or freeze xhr\r\n }\r\n }\r\n }, function (e) {\r\n _reportXhrError(e, null);\r\n });\r\n }\r\n function _getAjaxCorrelationContext(xhr) {\r\n var _a;\r\n try {\r\n var responseHeadersString = xhr[_DYN_GET_ALL_RESPONSE_HEA13 /* @min:%2egetAllResponseHeaders */]();\r\n if (responseHeadersString !== null) {\r\n var index = _indexOf(responseHeadersString[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */](), RequestHeaders[8 /* eRequestHeaders.requestContextHeaderLowerCase */]);\r\n if (index !== -1) {\r\n var responseHeader = xhr.getResponseHeader(RequestHeaders[0 /* eRequestHeaders.requestContextHeader */]);\r\n return correlationIdGetCorrelationContext(responseHeader);\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _throwInternalWarning(_self, 18 /* _eInternalMessageId.FailedMonitorAjaxGetCorrelationHeader */, CORRELATION_HEADER_ERROR, (_a = {},\r\n _a[_DYN_AJAX_DIAGNOSTICS_MES14 /* @min:ajaxDiagnosticsMessage */] = _getFailedAjaxDiagnosticsMessage(xhr, _ajaxDataId),\r\n _a.exception = dumpObj(e),\r\n _a));\r\n }\r\n }\r\n function _createMarkId(type, ajaxData) {\r\n if (ajaxData[_DYN_REQUEST_URL /* @min:%2erequestUrl */] && _markPrefix && _enableAjaxPerfTracking) {\r\n var performance_1 = getPerformance();\r\n if (performance_1 && isFunction(performance_1.mark)) {\r\n _markCount++;\r\n var markId = _markPrefix + type + \"#\" + _markCount;\r\n performance_1.mark(markId);\r\n var entries = performance_1.getEntriesByName(markId);\r\n if (entries && entries[_DYN_LENGTH /* @min:%2elength */] === 1) {\r\n ajaxData[_DYN_PERF_MARK /* @min:%2eperfMark */] = entries[0];\r\n }\r\n }\r\n }\r\n }\r\n function _findPerfResourceEntry(initiatorType, ajaxData, trackCallback, reportError) {\r\n var perfMark = ajaxData[_DYN_PERF_MARK /* @min:%2eperfMark */];\r\n var performance = getPerformance();\r\n var maxAttempts = _maxAjaxPerfLookupAttempts;\r\n var retryDelay = _ajaxPerfLookupDelay;\r\n var requestUrl = ajaxData[_DYN_REQUEST_URL /* @min:%2erequestUrl */];\r\n var attempt = 0;\r\n (function locateResourceTiming() {\r\n try {\r\n if (performance && perfMark) {\r\n attempt++;\r\n var perfTiming = null;\r\n var entries = performance.getEntries();\r\n for (var lp = entries[_DYN_LENGTH /* @min:%2elength */] - 1; lp >= 0; lp--) {\r\n var entry = entries[lp];\r\n if (entry) {\r\n if (entry.entryType === \"resource\") {\r\n if (entry.initiatorType === initiatorType &&\r\n (_indexOf(entry.name, requestUrl) !== -1 || _indexOf(requestUrl, entry.name) !== -1)) {\r\n perfTiming = entry;\r\n }\r\n }\r\n else if (entry.entryType === \"mark\" && entry.name === perfMark.name) {\r\n // We hit the start event\r\n ajaxData[_DYN_PERF_TIMING /* @min:%2eperfTiming */] = perfTiming;\r\n break;\r\n }\r\n if (entry[_DYN_START_TIME /* @min:%2estartTime */] < perfMark[_DYN_START_TIME /* @min:%2estartTime */] - 1000) {\r\n // Fallback to try and reduce the time spent looking for the perf entry\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n if (!perfMark || // - we don't have a perfMark or\r\n ajaxData[_DYN_PERF_TIMING /* @min:%2eperfTiming */] || // - we have not found the perf entry or\r\n attempt >= maxAttempts || // - we have tried too many attempts or\r\n ajaxData.async === false) { // - this is a sync request\r\n if (perfMark && isFunction(performance.clearMarks)) {\r\n // Remove the mark so we don't fill up the performance resources too much\r\n performance.clearMarks(perfMark.name);\r\n }\r\n ajaxData.perfAttempts = attempt;\r\n // just continue and report the track event\r\n trackCallback();\r\n }\r\n else {\r\n // We need to wait for the browser to populate the window.performance entry\r\n // This needs to be at least 1ms as waiting <= 1 (on firefox) is not enough time for fetch or xhr,\r\n // this is a scheduling issue for the browser implementation\r\n scheduleTimeout(locateResourceTiming, retryDelay);\r\n }\r\n }\r\n catch (e) {\r\n reportError(e);\r\n }\r\n })();\r\n }\r\n function _createFetchRecord(input, init) {\r\n var _a;\r\n var distributedTraceCtx = _getDistributedTraceCtx();\r\n var traceID = (distributedTraceCtx && distributedTraceCtx[_DYN_GET_TRACE_ID /* @min:%2egetTraceId */]()) || generateW3CId();\r\n var spanID = strSubstr(generateW3CId(), 0, 16);\r\n var ajaxData = new ajaxRecord(traceID, spanID, _self[strDiagLog](), (_a = _self.core) === null || _a === void 0 ? void 0 : _a.getTraceCtx());\r\n ajaxData[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */] = distributedTraceCtx && distributedTraceCtx[_DYN_GET_TRACE_FLAGS /* @min:%2egetTraceFlags */]();\r\n ajaxData[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */] = dateTimeUtilsNow();\r\n ajaxData[_DYN_ERROR_STATUS_TEXT /* @min:%2eerrorStatusText */] = _enableAjaxErrorStatusText;\r\n var requestUrl;\r\n if (input instanceof Request) {\r\n requestUrl = (input || {}).url || \"\";\r\n }\r\n else {\r\n requestUrl = input;\r\n }\r\n if (requestUrl === \"\") {\r\n var location_1 = getLocation();\r\n if (location_1 && location_1.href) {\r\n requestUrl = strSplit(location_1.href, \"#\")[0];\r\n }\r\n }\r\n ajaxData[_DYN_REQUEST_URL /* @min:%2erequestUrl */] = requestUrl;\r\n var method = \"GET\";\r\n if (init && init[_DYN_METHOD /* @min:%2emethod */]) {\r\n method = init[_DYN_METHOD /* @min:%2emethod */];\r\n }\r\n else if (input && input instanceof Request) {\r\n method = input[_DYN_METHOD /* @min:%2emethod */];\r\n }\r\n ajaxData[_DYN_METHOD /* @min:%2emethod */] = method;\r\n var requestHeaders = {};\r\n if (_enableRequestHeaderTracking) {\r\n var headers = new Headers((init ? init[_DYN_HEADERS /* @min:%2eheaders */] : 0) || (input instanceof Request ? (input[_DYN_HEADERS /* @min:%2eheaders */] || {}) : {}));\r\n headers.forEach(function (value, key) {\r\n if (_canIncludeHeaders(key)) {\r\n requestHeaders[key] = value;\r\n }\r\n });\r\n }\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */] = requestHeaders;\r\n _createMarkId(STR_FETCH, ajaxData);\r\n return ajaxData;\r\n }\r\n function _getFailedFetchDiagnosticsMessage(input) {\r\n var result = \"\";\r\n try {\r\n if (!isNullOrUndefined(input)) {\r\n if (typeof (input) === \"string\") {\r\n result += \"(url: '\".concat(input, \"')\");\r\n }\r\n else {\r\n result += \"(url: '\".concat(input.url, \"')\");\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _throwInternalCritical(_self, 15 /* _eInternalMessageId.FailedMonitorAjaxOpen */, \"Failed to grab failed fetch diagnostics message\", { exception: dumpObj(e) });\r\n }\r\n return result;\r\n }\r\n function _reportFetchMetrics(callDetails, status, input, response, ajaxData, getResponse, properties) {\r\n if (!ajaxData) {\r\n return;\r\n }\r\n function _reportFetchError(msgId, e, failedProps) {\r\n var errorProps = failedProps || {};\r\n errorProps[\"fetchDiagnosticsMessage\"] = _getFailedFetchDiagnosticsMessage(input);\r\n if (e) {\r\n errorProps[\"exception\"] = dumpObj(e);\r\n }\r\n _throwInternalWarning(_self, msgId, FAILED_TO_CALCULATE_DURATION_ERROR + \"fetch call\" + ERROR_NOT_SENT, errorProps);\r\n }\r\n ajaxData[_DYN_RESPONSE_FINISHED_TI12 /* @min:%2eresponseFinishedTime */] = dateTimeUtilsNow();\r\n ajaxData[_DYN_STATUS /* @min:%2estatus */] = status;\r\n _findPerfResourceEntry(STR_FETCH, ajaxData, function () {\r\n var dependency = ajaxData[_DYN__CREATE_TRACK_ITEM /* @min:%2eCreateTrackItem */](\"Fetch\", _enableRequestHeaderTracking, getResponse);\r\n var properties;\r\n try {\r\n if (!!_addRequestContext) {\r\n properties = _addRequestContext({ status: status, request: input, response: response });\r\n }\r\n }\r\n catch (e) {\r\n _throwInternalWarning(_self, 104 /* _eInternalMessageId.FailedAddingCustomDefinedRequestContext */, CUSTOM_REQUEST_CONTEXT_ERROR);\r\n }\r\n if (dependency) {\r\n if (properties !== undefined) {\r\n dependency[STR_PROPERTIES /* @min:%2eproperties */] = __assign(__assign({}, dependency.properties), properties);\r\n }\r\n var sysProperties = ajaxData[_DYN_GET_PART_APROPS /* @min:%2egetPartAProps */]();\r\n _reportDependencyInternal(_dependencyInitializers, _self[_DYN_CORE /* @min:%2ecore */], ajaxData, dependency, null, sysProperties);\r\n }\r\n else {\r\n _reportFetchError(14 /* _eInternalMessageId.FailedMonitorAjaxDur */, null, {\r\n requestSentTime: ajaxData[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */],\r\n responseFinishedTime: ajaxData[_DYN_RESPONSE_FINISHED_TI12 /* @min:%2eresponseFinishedTime */]\r\n });\r\n }\r\n }, function (e) {\r\n _reportFetchError(18 /* _eInternalMessageId.FailedMonitorAjaxGetCorrelationHeader */, e, null);\r\n });\r\n }\r\n function _getFetchCorrelationContext(response) {\r\n if (response && response[_DYN_HEADERS /* @min:%2eheaders */]) {\r\n try {\r\n var responseHeader = response[_DYN_HEADERS /* @min:%2eheaders */].get(RequestHeaders[0 /* eRequestHeaders.requestContextHeader */]);\r\n return correlationIdGetCorrelationContext(responseHeader);\r\n }\r\n catch (e) {\r\n _throwInternalWarning(_self, 18 /* _eInternalMessageId.FailedMonitorAjaxGetCorrelationHeader */, CORRELATION_HEADER_ERROR, {\r\n fetchDiagnosticsMessage: _getFailedFetchDiagnosticsMessage(response),\r\n exception: dumpObj(e)\r\n });\r\n }\r\n }\r\n }\r\n function _reportDependencyInternal(initializers, core, ajaxData, dependency, properties, systemProperties) {\r\n var result = true;\r\n var initializersCount = initializers[_DYN_LENGTH /* @min:%2elength */];\r\n if (initializersCount > 0) {\r\n var details = {\r\n item: dependency,\r\n properties: properties,\r\n sysProperties: systemProperties,\r\n context: ajaxData ? ajaxData[_DYN_CONTEXT /* @min:%2econtext */] : null,\r\n aborted: ajaxData ? !!ajaxData[_DYN_ABORTED /* @min:%2eaborted */] : false\r\n };\r\n result = _processDependencyContainer(core, initializers, details, \"initializer\");\r\n }\r\n if (result) {\r\n _self[_DYN_TRACK_DEPENDENCY_DAT1 /* @min:%2etrackDependencyDataInternal */](dependency, properties, systemProperties);\r\n }\r\n }\r\n });\r\n return _this;\r\n }\r\n// Removed Stub for AjaxMonitor.prototype.initialize.\r\n AjaxMonitor.prototype.processTelemetry = function (item, itemCtx) {\r\n this.processNext(item, itemCtx);\r\n };\r\n// Removed Stub for AjaxMonitor.prototype.trackDependencyData.\r\n// Removed Stub for AjaxMonitor.prototype.includeCorrelationHeaders.\r\n// Removed Stub for AjaxMonitor.prototype.addDependencyListener.\r\n /**\r\n * Add an dependency telemetry initializer callback function to allow populating additional properties or drop the request.\r\n * It is called after the dependency call has completed and any available performance details are available. A dependency\r\n * initializer is similar to the TelemetryInitializer function but it allows you to block the reporting of the dependency\r\n * request so that it doesn't count against the `maxAjaxCallsPerView`.\r\n * @param dependencyInitializer - The Dependency Telemetry Initializer function\r\n * @returns - A IDependencyInitializerHandler to enable the initializer to be removed\r\n */\r\n AjaxMonitor.prototype.addDependencyInitializer = function (dependencyInitializer) {\r\n return null;\r\n };\r\n// Removed Stub for AjaxMonitor.prototype.trackDependencyDataInternal.\r\n AjaxMonitor.identifier = \"AjaxDependencyPlugin\";\r\n return AjaxMonitor;\r\n}(BaseTelemetryPlugin));\r\nexport { AjaxMonitor };\r\n//# sourceMappingURL=ajax.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nvar Application = /** @class */ (function () {\r\n function Application() {\r\n }\r\n return Application;\r\n}());\r\nexport { Application };\r\n//# sourceMappingURL=Application.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nvar Device = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the Device class\r\n */\r\n function Device() {\r\n // don't attempt to fingerprint browsers\r\n this.id = \"browser\";\r\n // Device type is a dimension in our data platform\r\n // Setting it to 'Browser' allows to separate client and server dependencies/exceptions\r\n this.deviceClass = \"Browser\";\r\n }\r\n return Device;\r\n}());\r\nexport { Device };\r\n//# sourceMappingURL=Device.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { onConfigChange } from \"@microsoft/applicationinsights-core-js\";\r\nvar Version = '3.3.6';\r\nvar Internal = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the internal telemetry data class.\r\n */\r\n function Internal(config, unloadHookContainer) {\r\n var _this = this;\r\n var unloadHook = onConfigChange((config), function () {\r\n var prefix = config.sdkExtension;\r\n _this.sdkVersion = (prefix ? prefix + \"_\" : \"\") + \"javascript:\" + Version;\r\n });\r\n unloadHookContainer && unloadHookContainer.add(unloadHook);\r\n }\r\n return Internal;\r\n}());\r\nexport { Internal };\r\n//# sourceMappingURL=Internal.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nvar Location = /** @class */ (function () {\r\n function Location() {\r\n }\r\n return Location;\r\n}());\r\nexport { Location };\r\n//# sourceMappingURL=Location.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES5 which can result in a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_SESSION = \"session\"; // Count: 4\r\nexport var _DYN_SESSION_MANAGER = \"sessionManager\"; // Count: 3\r\nexport var _DYN_IS_USER_COOKIE_SET = \"isUserCookieSet\"; // Count: 4\r\nexport var _DYN_IS_NEW_USER = \"isNewUser\"; // Count: 4\r\nexport var _DYN_GET_TRACE_CTX = \"getTraceCtx\"; // Count: 3\r\nexport var _DYN_TELEMETRY_TRACE = \"telemetryTrace\"; // Count: 3\r\nexport var _DYN_APPLY_SESSION_CONTEX0 = \"applySessionContext\"; // Count: 2\r\nexport var _DYN_APPLY_APPLICATION_CO1 = \"applyApplicationContext\"; // Count: 2\r\nexport var _DYN_APPLY_OPERATION_CONT2 = \"applyOperationContext\"; // Count: 2\r\nexport var _DYN_APPLY_OPERATING_SYST3 = \"applyOperatingSystemContxt\"; // Count: 2\r\nexport var _DYN_APPLY_LOCATION_CONTE4 = \"applyLocationContext\"; // Count: 2\r\nexport var _DYN_APPLY_INTERNAL_CONTE5 = \"applyInternalContext\"; // Count: 2\r\nexport var _DYN_GET_SESSION_ID = \"getSessionId\"; // Count: 4\r\nexport var _DYN_SESSION_COOKIE_POSTF6 = \"sessionCookiePostfix\"; // Count: 2\r\nexport var _DYN_AUTOMATIC_SESSION = \"automaticSession\"; // Count: 6\r\nexport var _DYN_ACCOUNT_ID = \"accountId\"; // Count: 6\r\nexport var _DYN_AUTHENTICATED_ID = \"authenticatedId\"; // Count: 6\r\nexport var _DYN_ACQUISITION_DATE = \"acquisitionDate\"; // Count: 5\r\nexport var _DYN_RENEWAL_DATE = \"renewalDate\"; // Count: 4\r\nexport var _DYN_COOKIE_SEPARATOR = \"cookieSeparator\"; // Count: 5\r\nexport var _DYN_AUTH_USER_COOKIE_NAM7 = \"authUserCookieName\"; // Count: 3\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { utlCanUseLocalStorage, utlGetLocalStorage, utlSetLocalStorage } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal, dateNow, dumpObj, getExceptionName, isFunction, newId, onConfigChange, safeGetCookieMgr, safeGetLogger } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_ACQUISITION_DATE, _DYN_AUTOMATIC_SESSION, _DYN_RENEWAL_DATE, _DYN_SESSION_COOKIE_POSTF6 } from \"../__DynamicConstants\";\r\nvar SESSION_COOKIE_NAME = \"ai_session\";\r\nvar ACQUISITION_SPAN = 86400000; // 24 hours in ms\r\nvar RENEWAL_SPAN = 1800000; // 30 minutes in ms\r\nvar COOKIE_UPDATE_INTERVAL = 60000; // 1 minute in ms\r\nvar Session = /** @class */ (function () {\r\n function Session() {\r\n }\r\n return Session;\r\n}());\r\nexport { Session };\r\nvar _SessionManager = /** @class */ (function () {\r\n function _SessionManager(config, core, unloadHookContainer) {\r\n var self = this;\r\n var _storageNamePrefix;\r\n var _cookieUpdatedTimestamp;\r\n var _logger = safeGetLogger(core);\r\n var _cookieManager = safeGetCookieMgr(core);\r\n var _sessionExpirationMs;\r\n var _sessionRenewalMs;\r\n dynamicProto(_SessionManager, self, function (_self) {\r\n if (!config) {\r\n config = {};\r\n }\r\n var unloadHook = onConfigChange(config, function (details) {\r\n _sessionExpirationMs = config.sessionExpirationMs || ACQUISITION_SPAN;\r\n _sessionRenewalMs = config.sessionRenewalMs || RENEWAL_SPAN;\r\n // sessionCookiePostfix takes the preference if it is configured, otherwise takes namePrefix if configured.\r\n var sessionCookiePostfix = config[_DYN_SESSION_COOKIE_POSTF6 /* @min:%2esessionCookiePostfix */] || config.namePrefix || \"\";\r\n _storageNamePrefix = SESSION_COOKIE_NAME + sessionCookiePostfix;\r\n });\r\n unloadHookContainer && unloadHookContainer.add(unloadHook);\r\n _self[_DYN_AUTOMATIC_SESSION /* @min:%2eautomaticSession */] = new Session();\r\n _self.update = function () {\r\n // Always using Date getTime() as there is a bug in older IE instances that causes the performance timings to have the hi-bit set eg 0x800000000 causing\r\n // the number to be incorrect.\r\n var nowMs = dateNow();\r\n var isExpired = false;\r\n var session = _self[_DYN_AUTOMATIC_SESSION /* @min:%2eautomaticSession */];\r\n if (!session.id) {\r\n isExpired = !_initializeAutomaticSession(session, nowMs);\r\n }\r\n if (!isExpired && _sessionExpirationMs > 0) {\r\n var timeSinceAcqMs = nowMs - session[_DYN_ACQUISITION_DATE /* @min:%2eacquisitionDate */];\r\n var timeSinceRenewalMs = nowMs - session[_DYN_RENEWAL_DATE /* @min:%2erenewalDate */];\r\n isExpired = timeSinceAcqMs < 0 || timeSinceRenewalMs < 0; // expired if the acquisition or last renewal are in the future\r\n isExpired = isExpired || timeSinceAcqMs > _sessionExpirationMs; // expired if the time since acquisition is more than session Expiration\r\n isExpired = isExpired || timeSinceRenewalMs > _sessionRenewalMs; // expired if the time since last renewal is more than renewal period\r\n }\r\n // renew if acquisitionSpan or renewalSpan has elapsed\r\n if (isExpired) {\r\n // update automaticSession so session state has correct id\r\n _renew(nowMs);\r\n }\r\n else {\r\n // do not update the cookie more often than cookieUpdateInterval\r\n if (!_cookieUpdatedTimestamp || nowMs - _cookieUpdatedTimestamp > COOKIE_UPDATE_INTERVAL) {\r\n _setCookie(session, nowMs);\r\n }\r\n }\r\n };\r\n /**\r\n * Record the current state of the automatic session and store it in our cookie string format\r\n * into the browser's local storage. This is used to restore the session data when the cookie\r\n * expires.\r\n */\r\n _self.backup = function () {\r\n var session = _self[_DYN_AUTOMATIC_SESSION /* @min:%2eautomaticSession */];\r\n _setStorage(session.id, session[_DYN_ACQUISITION_DATE /* @min:%2eacquisitionDate */], session[_DYN_RENEWAL_DATE /* @min:%2erenewalDate */]);\r\n };\r\n /**\r\n * Use config.namePrefix + ai_session cookie data or local storage data (when the cookie is unavailable) to\r\n * initialize the automatic session.\r\n * @returns true if values set otherwise false\r\n */\r\n function _initializeAutomaticSession(session, now) {\r\n var isValid = false;\r\n var cookieValue = _cookieManager.get(_storageNamePrefix);\r\n if (cookieValue && isFunction(cookieValue.split)) {\r\n isValid = _initializeAutomaticSessionWithData(session, cookieValue);\r\n }\r\n else {\r\n // There's no cookie, but we might have session data in local storage\r\n // This can happen if the session expired or the user actively deleted the cookie\r\n // We only want to recover data if the cookie is missing from expiry. We should respect the user's wishes if the cookie was deleted actively.\r\n // The User class handles this for us and deletes our local storage object if the persistent user cookie was removed.\r\n var storageValue = utlGetLocalStorage(_logger, _storageNamePrefix);\r\n if (storageValue) {\r\n isValid = _initializeAutomaticSessionWithData(session, storageValue);\r\n }\r\n }\r\n return isValid || !!session.id;\r\n }\r\n /**\r\n * Extract id, acquisitionDate, and renewalDate from an ai_session payload string and\r\n * use this data to initialize automaticSession.\r\n *\r\n * @param sessionData - The string stored in an ai_session cookie or local storage backup\r\n * @returns true if values set otherwise false\r\n */\r\n function _initializeAutomaticSessionWithData(session, sessionData) {\r\n var isValid = false;\r\n var sessionReset = \", session will be reset\";\r\n var tokens = sessionData.split(\"|\");\r\n if (tokens.length >= 2) {\r\n try {\r\n var acqMs = +tokens[1] || 0;\r\n var renewalMs = +tokens[2] || 0;\r\n if (isNaN(acqMs) || acqMs <= 0) {\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 27 /* _eInternalMessageId.SessionRenewalDateIsZero */, \"AI session acquisition date is 0\" + sessionReset);\r\n }\r\n else if (isNaN(renewalMs) || renewalMs <= 0) {\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 27 /* _eInternalMessageId.SessionRenewalDateIsZero */, \"AI session renewal date is 0\" + sessionReset);\r\n }\r\n else if (tokens[0]) {\r\n // Everything looks valid so set the values\r\n session.id = tokens[0];\r\n session[_DYN_ACQUISITION_DATE /* @min:%2eacquisitionDate */] = acqMs;\r\n session[_DYN_RENEWAL_DATE /* @min:%2erenewalDate */] = renewalMs;\r\n isValid = true;\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(_logger, 1 /* eLoggingSeverity.CRITICAL */, 9 /* _eInternalMessageId.ErrorParsingAISessionCookie */, \"Error parsing ai_session value [\" + (sessionData || \"\") + \"]\" + sessionReset + \" - \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return isValid;\r\n }\r\n function _renew(nowMs) {\r\n var getNewId = config.getNewId || newId;\r\n _self[_DYN_AUTOMATIC_SESSION /* @min:%2eautomaticSession */].id = getNewId(config.idLength || 22);\r\n _self[_DYN_AUTOMATIC_SESSION /* @min:%2eautomaticSession */][_DYN_ACQUISITION_DATE /* @min:%2eacquisitionDate */] = nowMs;\r\n _setCookie(_self[_DYN_AUTOMATIC_SESSION /* @min:%2eautomaticSession */], nowMs);\r\n // If this browser does not support local storage, fire an internal log to keep track of it at this point\r\n if (!utlCanUseLocalStorage()) {\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 0 /* _eInternalMessageId.BrowserDoesNotSupportLocalStorage */, \"Browser does not support local storage. Session durations will be inaccurate.\");\r\n }\r\n }\r\n function _setCookie(session, nowMs) {\r\n var acq = session[_DYN_ACQUISITION_DATE /* @min:%2eacquisitionDate */];\r\n session[_DYN_RENEWAL_DATE /* @min:%2erenewalDate */] = nowMs;\r\n var renewalPeriodMs = _sessionRenewalMs;\r\n // Set cookie to expire after the session expiry time passes or the session renewal deadline, whichever is sooner\r\n // Expiring the cookie will cause the session to expire even if the user isn't on the page\r\n var acqTimeLeftMs = (acq + _sessionExpirationMs) - nowMs;\r\n var cookie = [session.id, acq, nowMs];\r\n var maxAgeSec = 0;\r\n if (acqTimeLeftMs < renewalPeriodMs) {\r\n maxAgeSec = acqTimeLeftMs / 1000;\r\n }\r\n else {\r\n maxAgeSec = renewalPeriodMs / 1000;\r\n }\r\n var cookieDomain = config.cookieDomain || null;\r\n // if sessionExpirationMs is set to 0, it means the expiry is set to 0 for this session cookie\r\n // A cookie with 0 expiry in the session cookie will never expire for that browser session. If the browser is closed the cookie expires.\r\n // Depending on the browser, another instance does not inherit this cookie, however, another tab will\r\n _cookieManager.set(_storageNamePrefix, cookie.join(\"|\"), _sessionExpirationMs > 0 ? maxAgeSec : null, cookieDomain);\r\n _cookieUpdatedTimestamp = nowMs;\r\n }\r\n function _setStorage(guid, acq, renewal) {\r\n // Keep data in local storage to retain the last session id, allowing us to cleanly end the session when it expires\r\n // Browsers that don't support local storage won't be able to end sessions cleanly from the client\r\n // The server will notice this and end the sessions itself, with loss of accurate session duration\r\n utlSetLocalStorage(_logger, _storageNamePrefix, [guid, acq, renewal].join(\"|\"));\r\n }\r\n });\r\n }\r\n// Removed Stub for _SessionManager.prototype.update.\r\n// Removed Stub for _SessionManager.prototype.backup.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n _SessionManager.__ieDyn=1;\n\n return _SessionManager;\r\n}());\r\nexport { _SessionManager };\r\n//# sourceMappingURL=Session.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { dataSanitizeString } from \"@microsoft/applicationinsights-common\";\r\nimport { generateW3CId, getLocation } from \"@microsoft/applicationinsights-core-js\";\r\nvar TelemetryTrace = /** @class */ (function () {\r\n function TelemetryTrace(id, parentId, name, logger) {\r\n var _self = this;\r\n _self.traceID = id || generateW3CId();\r\n _self.parentID = parentId;\r\n var location = getLocation();\r\n if (!name && location && location.pathname) {\r\n name = location.pathname;\r\n }\r\n _self.name = dataSanitizeString(logger, name);\r\n }\r\n return TelemetryTrace;\r\n}());\r\nexport { TelemetryTrace };\r\n//# sourceMappingURL=TelemetryTrace.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { utlRemoveStorage } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal, newId, onConfigChange, safeGetCookieMgr, safeGetLogger, toISOString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { objDefine } from \"@nevware21/ts-utils\";\r\nimport { _DYN_ACCOUNT_ID, _DYN_AUTHENTICATED_ID, _DYN_AUTH_USER_COOKIE_NAM7, _DYN_COOKIE_SEPARATOR, _DYN_IS_NEW_USER, _DYN_IS_USER_COOKIE_SET } from \"../__DynamicConstants\";\r\nfunction _validateUserInput(id) {\r\n // Validate:\r\n // 1. Id is a non-empty string.\r\n // 2. It does not contain special characters for cookies.\r\n if (typeof id !== \"string\" ||\r\n !id ||\r\n id.match(/,|;|=| |\\|/)) {\r\n return false;\r\n }\r\n return true;\r\n}\r\nvar User = /** @class */ (function () {\r\n function User(config, core, unloadHookContainer) {\r\n /**\r\n * A flag indicating whether this represents a new user\r\n */\r\n this.isNewUser = false;\r\n /**\r\n * A flag indicating whether the user cookie has been set\r\n */\r\n this.isUserCookieSet = false;\r\n var _logger = safeGetLogger(core);\r\n var _cookieManager = safeGetCookieMgr(core);\r\n var _storageNamePrefix;\r\n dynamicProto(User, this, function (_self) {\r\n // Define _self.config\r\n objDefine(_self, \"config\", {\r\n g: function () { return config; }\r\n });\r\n var unloadHook = onConfigChange(config, function () {\r\n var userCookiePostfix = config.userCookiePostfix || \"\";\r\n _storageNamePrefix = User.userCookieName + userCookiePostfix;\r\n // get userId or create new one if none exists\r\n var cookie = _cookieManager.get(_storageNamePrefix);\r\n if (cookie) {\r\n _self[_DYN_IS_NEW_USER /* @min:%2eisNewUser */] = false;\r\n var params = cookie.split(User[_DYN_COOKIE_SEPARATOR /* @min:%2ecookieSeparator */]);\r\n if (params.length > 0) {\r\n _self.id = params[0];\r\n // we already have a cookie\r\n _self[_DYN_IS_USER_COOKIE_SET /* @min:%2eisUserCookieSet */] = !!_self.id;\r\n }\r\n }\r\n if (!_self.id) {\r\n _self.id = _generateNewId();\r\n var newCookie = _generateNewCookie(_self.id);\r\n _setUserCookie(newCookie.join(User[_DYN_COOKIE_SEPARATOR /* @min:%2ecookieSeparator */]));\r\n // If we have an config.namePrefix() + ai_session in local storage this means the user actively removed our cookies.\r\n // We should respect their wishes and clear ourselves from local storage\r\n var name_1 = (config.namePrefix || \"\") + \"ai_session\";\r\n utlRemoveStorage(_logger, name_1);\r\n }\r\n // We still take the account id from the ctor param for backward compatibility.\r\n // But if the the customer set the accountId through the newer setAuthenticatedUserContext API, we will override it.\r\n _self[_DYN_ACCOUNT_ID /* @min:%2eaccountId */] = config[_DYN_ACCOUNT_ID /* @min:%2eaccountId */] || undefined;\r\n // Get the auth user id and account id from the cookie if exists\r\n // Cookie is in the pattern: |\r\n var authCookie = _cookieManager.get(User[_DYN_AUTH_USER_COOKIE_NAM7 /* @min:%2eauthUserCookieName */]);\r\n if (authCookie) {\r\n authCookie = decodeURI(authCookie);\r\n var authCookieString = authCookie.split(User[_DYN_COOKIE_SEPARATOR /* @min:%2ecookieSeparator */]);\r\n if (authCookieString[0]) {\r\n _self[_DYN_AUTHENTICATED_ID /* @min:%2eauthenticatedId */] = authCookieString[0];\r\n }\r\n if (authCookieString.length > 1 && authCookieString[1]) {\r\n _self[_DYN_ACCOUNT_ID /* @min:%2eaccountId */] = authCookieString[1];\r\n }\r\n }\r\n });\r\n unloadHookContainer && unloadHookContainer.add(unloadHook);\r\n function _generateNewId() {\r\n var theConfig = (config || {});\r\n var getNewId = theConfig.getNewId || newId;\r\n var id = getNewId(theConfig.idLength ? config.idLength : 22);\r\n return id;\r\n }\r\n function _generateNewCookie(userId) {\r\n var acqStr = toISOString(new Date());\r\n _self.accountAcquisitionDate = acqStr;\r\n _self[_DYN_IS_NEW_USER /* @min:%2eisNewUser */] = true;\r\n var newCookie = [userId, acqStr];\r\n return newCookie;\r\n }\r\n function _setUserCookie(cookie) {\r\n // without expiration, cookies expire at the end of the session\r\n // set it to 365 days from now\r\n // 365 * 24 * 60 * 60 = 31536000\r\n var oneYear = 31536000;\r\n _self[_DYN_IS_USER_COOKIE_SET /* @min:%2eisUserCookieSet */] = _cookieManager.set(_storageNamePrefix, cookie, oneYear);\r\n }\r\n _self.setAuthenticatedUserContext = function (authenticatedUserId, accountId, storeInCookie) {\r\n if (storeInCookie === void 0) { storeInCookie = false; }\r\n // Validate inputs to ensure no cookie control characters.\r\n var isInvalidInput = !_validateUserInput(authenticatedUserId) || (accountId && !_validateUserInput(accountId));\r\n if (isInvalidInput) {\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 60 /* _eInternalMessageId.SetAuthContextFailedAccountName */, \"Setting auth user context failed. \" +\r\n \"User auth/account id should be of type string, and not contain commas, semi-colons, equal signs, spaces, or vertical-bars.\", true);\r\n return;\r\n }\r\n // Create cookie string.\r\n _self[_DYN_AUTHENTICATED_ID /* @min:%2eauthenticatedId */] = authenticatedUserId;\r\n var authCookie = _self[_DYN_AUTHENTICATED_ID /* @min:%2eauthenticatedId */];\r\n if (accountId) {\r\n _self[_DYN_ACCOUNT_ID /* @min:%2eaccountId */] = accountId;\r\n authCookie = [_self[_DYN_AUTHENTICATED_ID /* @min:%2eauthenticatedId */], _self.accountId].join(User[_DYN_COOKIE_SEPARATOR /* @min:%2ecookieSeparator */]);\r\n }\r\n if (storeInCookie) {\r\n // Set the cookie. No expiration date because this is a session cookie (expires when browser closed).\r\n // Encoding the cookie to handle unexpected unicode characters.\r\n _cookieManager.set(User[_DYN_AUTH_USER_COOKIE_NAM7 /* @min:%2eauthUserCookieName */], encodeURI(authCookie));\r\n }\r\n };\r\n /**\r\n * Clears the authenticated user id and the account id from the user context.\r\n * @returns {}\r\n */\r\n _self.clearAuthenticatedUserContext = function () {\r\n _self[_DYN_AUTHENTICATED_ID /* @min:%2eauthenticatedId */] = null;\r\n _self[_DYN_ACCOUNT_ID /* @min:%2eaccountId */] = null;\r\n _cookieManager.del(User[_DYN_AUTH_USER_COOKIE_NAM7 /* @min:%2eauthUserCookieName */]);\r\n };\r\n _self.update = function (userId) {\r\n // Optimizations to avoid setting and processing the cookie when not needed\r\n if (_self.id !== userId || !_self[_DYN_IS_USER_COOKIE_SET /* @min:%2eisUserCookieSet */]) {\r\n var user_id = userId ? userId : _generateNewId();\r\n var user_cookie = _generateNewCookie(user_id);\r\n _setUserCookie(user_cookie.join(User[_DYN_COOKIE_SEPARATOR /* @min:%2ecookieSeparator */]));\r\n }\r\n };\r\n });\r\n }\r\n// Removed Stub for User.prototype.setAuthenticatedUserContext.\r\n// Removed Stub for User.prototype.clearAuthenticatedUserContext.\r\n// Removed Stub for User.prototype.update.\r\n User.cookieSeparator = \"|\";\r\n User.userCookieName = \"ai_user\";\r\n User.authUserCookieName = \"ai_authUser\";\r\n return User;\r\n}());\r\nexport { User };\r\n//# sourceMappingURL=User.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n/**\r\n* TelemetryContext.ts\r\n* @copyright Microsoft 2018\r\n*/\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { CtxTagKeys, Extensions, PageView, dataSanitizeString } from \"@microsoft/applicationinsights-common\";\r\nimport { _InternalLogMessage, getSetValue, hasWindow, isNullOrUndefined, isString, objKeys, setValue } from \"@microsoft/applicationinsights-core-js\";\r\nimport { Application } from \"./Context/Application\";\r\nimport { Device } from \"./Context/Device\";\r\nimport { Internal } from \"./Context/Internal\";\r\nimport { Location } from \"./Context/Location\";\r\nimport { Session, _SessionManager } from \"./Context/Session\";\r\nimport { TelemetryTrace } from \"./Context/TelemetryTrace\";\r\nimport { User } from \"./Context/User\";\r\nimport { _DYN_ACCOUNT_ID, _DYN_APPLY_APPLICATION_CO1, _DYN_APPLY_INTERNAL_CONTE5, _DYN_APPLY_LOCATION_CONTE4, _DYN_APPLY_OPERATING_SYST3, _DYN_APPLY_OPERATION_CONT2, _DYN_APPLY_SESSION_CONTEX0, _DYN_AUTHENTICATED_ID, _DYN_AUTOMATIC_SESSION, _DYN_GET_SESSION_ID, _DYN_SESSION, _DYN_SESSION_MANAGER, _DYN_TELEMETRY_TRACE } from \"./__DynamicConstants\";\r\nvar strExt = \"ext\";\r\nvar strTags = \"tags\";\r\nfunction _removeEmpty(target, name) {\r\n if (target && target[name] && objKeys(target[name]).length === 0) {\r\n delete target[name];\r\n }\r\n}\r\nfunction _nullResult() {\r\n return null;\r\n}\r\nvar TelemetryContext = /** @class */ (function () {\r\n function TelemetryContext(core, defaultConfig, previousTraceCtx, unloadHookContainer) {\r\n var _this = this;\r\n var logger = core.logger;\r\n dynamicProto(TelemetryContext, this, function (_self) {\r\n _self.appId = _nullResult;\r\n _self[_DYN_GET_SESSION_ID /* @min:%2egetSessionId */] = _nullResult;\r\n _self.application = new Application();\r\n _self.internal = new Internal(defaultConfig, unloadHookContainer);\r\n if (hasWindow()) {\r\n _self[_DYN_SESSION_MANAGER /* @min:%2esessionManager */] = new _SessionManager(defaultConfig, core, unloadHookContainer);\r\n _self.device = new Device();\r\n _self.location = new Location();\r\n _self.user = new User(defaultConfig, core, unloadHookContainer);\r\n var traceId = void 0;\r\n var parentId = void 0;\r\n var name_1;\r\n if (previousTraceCtx) {\r\n traceId = previousTraceCtx.getTraceId();\r\n parentId = previousTraceCtx.getSpanId();\r\n name_1 = previousTraceCtx.getName();\r\n }\r\n _self[_DYN_TELEMETRY_TRACE /* @min:%2etelemetryTrace */] = new TelemetryTrace(traceId, parentId, name_1, logger);\r\n _self[_DYN_SESSION /* @min:%2esession */] = new Session();\r\n }\r\n _self[_DYN_GET_SESSION_ID /* @min:%2egetSessionId */] = function () {\r\n var session = _self[_DYN_SESSION /* @min:%2esession */];\r\n var sesId = null;\r\n // If customer set session info, apply their context; otherwise apply context automatically generated\r\n if (session && isString(session.id)) {\r\n sesId = session.id;\r\n }\r\n else {\r\n // Gets the automatic session if it exists or an empty object\r\n var autoSession = (_self[_DYN_SESSION_MANAGER /* @min:%2esessionManager */] || {})[_DYN_AUTOMATIC_SESSION /* @min:%2eautomaticSession */];\r\n sesId = autoSession && isString(autoSession.id) ? autoSession.id : null;\r\n }\r\n return sesId;\r\n };\r\n _self[_DYN_APPLY_SESSION_CONTEX0 /* @min:%2eapplySessionContext */] = function (evt, itemCtx) {\r\n setValue(getSetValue(evt.ext, Extensions.AppExt), \"sesId\", _self[_DYN_GET_SESSION_ID /* @min:%2egetSessionId */](), isString);\r\n };\r\n _self[_DYN_APPLY_OPERATING_SYST3 /* @min:%2eapplyOperatingSystemContxt */] = function (evt, itemCtx) {\r\n setValue(evt.ext, Extensions.OSExt, _self.os);\r\n };\r\n _self[_DYN_APPLY_APPLICATION_CO1 /* @min:%2eapplyApplicationContext */] = function (evt, itemCtx) {\r\n var application = _self.application;\r\n if (application) {\r\n // evt.ext.app\r\n var tags = getSetValue(evt, strTags);\r\n setValue(tags, CtxTagKeys.applicationVersion, application.ver, isString);\r\n setValue(tags, CtxTagKeys.applicationBuild, application.build, isString);\r\n }\r\n };\r\n _self.applyDeviceContext = function (evt, itemCtx) {\r\n var device = _self.device;\r\n if (device) {\r\n // evt.ext.device\r\n var extDevice = getSetValue(getSetValue(evt, strExt), Extensions.DeviceExt);\r\n setValue(extDevice, \"localId\", device.id, isString);\r\n setValue(extDevice, \"ip\", device.ip, isString);\r\n setValue(extDevice, \"model\", device.model, isString);\r\n setValue(extDevice, \"deviceClass\", device.deviceClass, isString);\r\n }\r\n };\r\n _self[_DYN_APPLY_INTERNAL_CONTE5 /* @min:%2eapplyInternalContext */] = function (evt, itemCtx) {\r\n var internal = _self.internal;\r\n if (internal) {\r\n var tags = getSetValue(evt, strTags);\r\n setValue(tags, CtxTagKeys.internalAgentVersion, internal.agentVersion, isString); // not mapped in CS 4.0\r\n setValue(tags, CtxTagKeys.internalSdkVersion, dataSanitizeString(logger, internal.sdkVersion, 64), isString);\r\n if (evt.baseType === _InternalLogMessage.dataType || evt.baseType === PageView.dataType) {\r\n setValue(tags, CtxTagKeys.internalSnippet, internal.snippetVer, isString);\r\n setValue(tags, CtxTagKeys.internalSdkSrc, internal.sdkSrc, isString);\r\n }\r\n }\r\n };\r\n _self[_DYN_APPLY_LOCATION_CONTE4 /* @min:%2eapplyLocationContext */] = function (evt, itemCtx) {\r\n var location = _this.location;\r\n if (location) {\r\n setValue(getSetValue(evt, strTags, []), CtxTagKeys.locationIp, location.ip, isString);\r\n }\r\n };\r\n _self[_DYN_APPLY_OPERATION_CONT2 /* @min:%2eapplyOperationContext */] = function (evt, itemCtx) {\r\n var telemetryTrace = _self[_DYN_TELEMETRY_TRACE /* @min:%2etelemetryTrace */];\r\n if (telemetryTrace) {\r\n var extTrace = getSetValue(getSetValue(evt, strExt), Extensions.TraceExt, { traceID: undefined, parentID: undefined });\r\n setValue(extTrace, \"traceID\", telemetryTrace.traceID, isString, isNullOrUndefined);\r\n setValue(extTrace, \"name\", telemetryTrace.name, isString, isNullOrUndefined);\r\n setValue(extTrace, \"parentID\", telemetryTrace.parentID, isString, isNullOrUndefined);\r\n }\r\n };\r\n _self.applyWebContext = function (evt, itemCtx) {\r\n var web = _this.web;\r\n if (web) {\r\n setValue(getSetValue(evt, strExt), Extensions.WebExt, web);\r\n }\r\n };\r\n _self.applyUserContext = function (evt, itemCtx) {\r\n var user = _self.user;\r\n if (user) {\r\n var tags = getSetValue(evt, strTags, []);\r\n // stays in tags\r\n setValue(tags, CtxTagKeys.userAccountId, user[_DYN_ACCOUNT_ID /* @min:%2eaccountId */], isString);\r\n // CS 4.0\r\n var extUser = getSetValue(getSetValue(evt, strExt), Extensions.UserExt);\r\n setValue(extUser, \"id\", user.id, isString);\r\n setValue(extUser, \"authId\", user[_DYN_AUTHENTICATED_ID /* @min:%2eauthenticatedId */], isString);\r\n }\r\n };\r\n _self.cleanUp = function (evt, itemCtx) {\r\n var ext = evt.ext;\r\n if (ext) {\r\n _removeEmpty(ext, Extensions.DeviceExt);\r\n _removeEmpty(ext, Extensions.UserExt);\r\n _removeEmpty(ext, Extensions.WebExt);\r\n _removeEmpty(ext, Extensions.OSExt);\r\n _removeEmpty(ext, Extensions.AppExt);\r\n _removeEmpty(ext, Extensions.TraceExt);\r\n }\r\n };\r\n });\r\n }\r\n// Removed Stub for TelemetryContext.prototype.applySessionContext.\r\n// Removed Stub for TelemetryContext.prototype.applyOperatingSystemContxt.\r\n// Removed Stub for TelemetryContext.prototype.applyApplicationContext.\r\n// Removed Stub for TelemetryContext.prototype.applyDeviceContext.\r\n// Removed Stub for TelemetryContext.prototype.applyInternalContext.\r\n// Removed Stub for TelemetryContext.prototype.applyLocationContext.\r\n// Removed Stub for TelemetryContext.prototype.applyOperationContext.\r\n// Removed Stub for TelemetryContext.prototype.applyWebContext.\r\n// Removed Stub for TelemetryContext.prototype.applyUserContext.\r\n// Removed Stub for TelemetryContext.prototype.cleanUp.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n TelemetryContext.__ieDyn=1;\n\n return TelemetryContext;\r\n}());\r\nexport { TelemetryContext };\r\n//# sourceMappingURL=TelemetryContext.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n/**\r\n* PropertiesPlugin.ts\r\n* @copyright Microsoft 2018\r\n*/\r\nvar _a;\r\nimport { __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { BreezeChannelIdentifier, PageView, PropertiesPluginIdentifier, createDistributedTraceContextFromTrace, utlSetStoragePrefix } from \"@microsoft/applicationinsights-common\";\r\nimport { BaseTelemetryPlugin, _InternalLogMessage, _logInternalMessage, createProcessTelemetryContext, getNavigator, getSetValue, isNullOrUndefined, onConfigChange } from \"@microsoft/applicationinsights-core-js\";\r\nimport { objDeepFreeze, objDefine } from \"@nevware21/ts-utils\";\r\nimport { TelemetryContext } from \"./TelemetryContext\";\r\nimport { _DYN_APPLY_APPLICATION_CO1, _DYN_APPLY_INTERNAL_CONTE5, _DYN_APPLY_LOCATION_CONTE4, _DYN_APPLY_OPERATING_SYST3, _DYN_APPLY_OPERATION_CONT2, _DYN_APPLY_SESSION_CONTEX0, _DYN_GET_SESSION_ID, _DYN_GET_TRACE_CTX, _DYN_IS_NEW_USER, _DYN_IS_USER_COOKIE_SET, _DYN_SESSION, _DYN_SESSION_COOKIE_POSTF6, _DYN_SESSION_MANAGER, _DYN_TELEMETRY_TRACE } from \"./__DynamicConstants\";\r\nvar undefString;\r\nvar nullValue = null;\r\nvar _defaultConfig = objDeepFreeze((_a = {\r\n accountId: nullValue,\r\n sessionRenewalMs: 30 * 60 * 1000,\r\n samplingPercentage: 100,\r\n sessionExpirationMs: 24 * 60 * 60 * 1000,\r\n cookieDomain: nullValue,\r\n sdkExtension: nullValue,\r\n isBrowserLinkTrackingEnabled: false,\r\n appId: nullValue\r\n },\r\n _a[_DYN_GET_SESSION_ID /* @min:getSessionId */] = nullValue,\r\n _a.namePrefix = undefString,\r\n _a[_DYN_SESSION_COOKIE_POSTF6 /* @min:sessionCookiePostfix */] = undefString,\r\n _a.userCookiePostfix = undefString,\r\n _a.idLength = 22,\r\n _a.getNewId = nullValue,\r\n _a));\r\nvar PropertiesPlugin = /** @class */ (function (_super) {\r\n __extends(PropertiesPlugin, _super);\r\n function PropertiesPlugin() {\r\n var _this = _super.call(this) || this;\r\n _this.priority = 110;\r\n _this.identifier = PropertiesPluginIdentifier;\r\n var _extensionConfig;\r\n var _distributedTraceCtx;\r\n var _previousTraceCtx;\r\n var _context;\r\n var _disableUserInitMessage;\r\n dynamicProto(PropertiesPlugin, _this, function (_self, _base) {\r\n _initDefaults();\r\n objDefine(_self, \"context\", {\r\n g: function () {\r\n return _context;\r\n }\r\n });\r\n _self.initialize = function (config, core, extensions, pluginChain) {\r\n _base.initialize(config, core, extensions, pluginChain);\r\n _populateDefaults(config);\r\n };\r\n /**\r\n * Add Part A fields to the event\r\n * @param event - The event that needs to be processed\r\n */\r\n _self.processTelemetry = function (event, itemCtx) {\r\n if (!isNullOrUndefined(event)) {\r\n itemCtx = _self._getTelCtx(itemCtx);\r\n // If the envelope is PageView, reset the internal message count so that we can send internal telemetry for the new page.\r\n if (event.name === PageView.envelopeType) {\r\n itemCtx.diagLog().resetInternalMessageCount();\r\n }\r\n var theContext = (_context || {});\r\n if (theContext[_DYN_SESSION /* @min:%2esession */]) {\r\n // If customer did not provide custom session id update the session manager\r\n if (typeof _context[_DYN_SESSION /* @min:%2esession */].id !== \"string\" && theContext[_DYN_SESSION_MANAGER /* @min:%2esessionManager */]) {\r\n theContext[_DYN_SESSION_MANAGER /* @min:%2esessionManager */].update();\r\n }\r\n }\r\n var userCtx = theContext.user;\r\n if (userCtx && !userCtx[_DYN_IS_USER_COOKIE_SET /* @min:%2eisUserCookieSet */]) {\r\n userCtx.update(theContext.user.id);\r\n }\r\n _processTelemetryInternal(event, itemCtx);\r\n if (userCtx && userCtx[_DYN_IS_NEW_USER /* @min:%2eisNewUser */]) {\r\n userCtx[_DYN_IS_NEW_USER /* @min:%2eisNewUser */] = false;\r\n if (!_disableUserInitMessage) {\r\n var message = new _InternalLogMessage(72 /* _eInternalMessageId.SendBrowserInfoOnUserInit */, ((getNavigator() || {}).userAgent || \"\"));\r\n _logInternalMessage(itemCtx.diagLog(), 1 /* eLoggingSeverity.CRITICAL */, message);\r\n }\r\n }\r\n _self.processNext(event, itemCtx);\r\n }\r\n };\r\n _self._doTeardown = function (unloadCtx, unloadState) {\r\n var core = (unloadCtx || {}).core();\r\n if (core && core[_DYN_GET_TRACE_CTX /* @min:%2egetTraceCtx */]) {\r\n var traceCtx = core[_DYN_GET_TRACE_CTX /* @min:%2egetTraceCtx */](false);\r\n if (traceCtx === _distributedTraceCtx) {\r\n core.setTraceCtx(_previousTraceCtx);\r\n }\r\n }\r\n _initDefaults();\r\n };\r\n function _initDefaults() {\r\n _extensionConfig = null;\r\n _distributedTraceCtx = null;\r\n _previousTraceCtx = null;\r\n _context = null;\r\n _disableUserInitMessage = true;\r\n }\r\n function _populateDefaults(config) {\r\n var identifier = _self.identifier;\r\n var core = _self.core;\r\n // This function will be re-called whenever any referenced configuration is changed\r\n _self._addHook(onConfigChange(config, function () {\r\n var ctx = createProcessTelemetryContext(null, config, core);\r\n if (config.storagePrefix) {\r\n utlSetStoragePrefix(config.storagePrefix);\r\n }\r\n _disableUserInitMessage = config.disableUserInitMessage === false ? false : true;\r\n _extensionConfig = ctx.getExtCfg(identifier, _defaultConfig);\r\n // Test hook to allow accessing the internal values -- explicitly not defined as an available property on the class\r\n _self[\"_extConfig\"] = _extensionConfig;\r\n }));\r\n // This is outside of the onConfigChange as we don't want to update (replace) these values whenever a referenced config item changes\r\n _previousTraceCtx = core[_DYN_GET_TRACE_CTX /* @min:%2egetTraceCtx */](false);\r\n _context = new TelemetryContext(core, _extensionConfig, _previousTraceCtx, _self._unloadHooks);\r\n _distributedTraceCtx = createDistributedTraceContextFromTrace(_self.context[_DYN_TELEMETRY_TRACE /* @min:%2etelemetryTrace */], _previousTraceCtx);\r\n core.setTraceCtx(_distributedTraceCtx);\r\n _self.context.appId = function () {\r\n var breezeChannel = core.getPlugin(BreezeChannelIdentifier);\r\n return breezeChannel ? breezeChannel.plugin[\"_appId\"] : null;\r\n };\r\n }\r\n function _processTelemetryInternal(evt, itemCtx) {\r\n // Set Part A fields\r\n getSetValue(evt, \"tags\", []);\r\n getSetValue(evt, \"ext\", {});\r\n var ctx = _self.context;\r\n ctx[_DYN_APPLY_SESSION_CONTEX0 /* @min:%2eapplySessionContext */](evt, itemCtx);\r\n ctx[_DYN_APPLY_APPLICATION_CO1 /* @min:%2eapplyApplicationContext */](evt, itemCtx);\r\n ctx.applyDeviceContext(evt, itemCtx);\r\n ctx[_DYN_APPLY_OPERATION_CONT2 /* @min:%2eapplyOperationContext */](evt, itemCtx);\r\n ctx.applyUserContext(evt, itemCtx);\r\n ctx[_DYN_APPLY_OPERATING_SYST3 /* @min:%2eapplyOperatingSystemContxt */](evt, itemCtx);\r\n ctx.applyWebContext(evt, itemCtx);\r\n ctx[_DYN_APPLY_LOCATION_CONTE4 /* @min:%2eapplyLocationContext */](evt, itemCtx); // legacy tags\r\n ctx[_DYN_APPLY_INTERNAL_CONTE5 /* @min:%2eapplyInternalContext */](evt, itemCtx); // legacy tags\r\n ctx.cleanUp(evt, itemCtx);\r\n }\r\n });\r\n return _this;\r\n }\r\n// Removed Stub for PropertiesPlugin.prototype.initialize.\r\n// Removed Stub for PropertiesPlugin.prototype.processTelemetry.\r\n // This is a workaround for an IE bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n PropertiesPlugin.__ieDyn=1;\n\n return PropertiesPlugin;\r\n}(BaseTelemetryPlugin));\r\nexport default PropertiesPlugin;\r\n//# sourceMappingURL=PropertiesPlugin.js.map","/*\n * Application Insights JavaScript SDK - Web, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// ###################################################################################################################################################\r\n// Note: DON'T Export these const from the package as we are still targeting IE/ES5 this will export a mutable variables that someone could change ###\r\n// ###################################################################################################################################################\r\n// Generally you should only put values that are used more than 2 times and then only if not already exposed as a constant (such as SdkCoreNames)\r\n// as when using \"short\" named values from here they will be will be minified smaller than the SdkCoreNames[eSdkCoreNames.xxxx] value.\r\nvar _AUTHENTICATED_USER_CONTEXT = \"AuthenticatedUserContext\";\r\nvar _TRACK = \"track\";\r\nexport var STR_EMPTY = \"\";\r\nexport var STR_SNIPPET = \"snippet\";\r\nexport var STR_GET_COOKIE_MGR = \"getCookieMgr\";\r\nexport var STR_START_TRACK_PAGE = \"startTrackPage\";\r\nexport var STR_STOP_TRACK_PAGE = \"stopTrackPage\";\r\nexport var STR_FLUSH = \"flush\";\r\nexport var STR_START_TRACK_EVENT = \"startTrackEvent\";\r\nexport var STR_STOP_TRACK_EVENT = \"stopTrackEvent\";\r\nexport var STR_ADD_TELEMETRY_INITIALIZER = \"addTelemetryInitializer\";\r\nexport var STR_ADD_TELEMETRY_INITIALIZERS = STR_ADD_TELEMETRY_INITIALIZER + \"s\";\r\nexport var STR_POLL_INTERNAL_LOGS = \"pollInternalLogs\";\r\nexport var STR_GET_PLUGIN = \"getPlugin\";\r\nexport var STR_EVT_NAMESPACE = \"evtNamespace\";\r\nexport var STR_TRACK_EVENT = _TRACK + \"Event\";\r\nexport var STR_TRACK_TRACE = _TRACK + \"Trace\";\r\nexport var STR_TRACK_METRIC = _TRACK + \"Metric\";\r\nexport var STR_TRACK_PAGE_VIEW = _TRACK + \"PageView\";\r\nexport var STR_TRACK_EXCEPTION = _TRACK + \"Exception\";\r\nexport var STR_TRACK_DEPENDENCY_DATA = _TRACK + \"DependencyData\";\r\nexport var STR_SET_AUTHENTICATED_USER_CONTEXT = \"set\" + _AUTHENTICATED_USER_CONTEXT;\r\nexport var STR_CLEAR_AUTHENTICATED_USER_CONTEXT = \"clear\" + _AUTHENTICATED_USER_CONTEXT;\r\nexport var CONFIG_ENDPOINT_URL = \"https://js.monitor.azure.com/scripts/b/ai.config.1.cfg.json\";\r\n//# sourceMappingURL=InternalConstants.js.map","/*\n * Application Insights JavaScript SDK - Web, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES5 which can result in a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_VERSION = \"version\"; // Count: 6\r\nexport var _DYN_QUEUE = \"queue\"; // Count: 6\r\nexport var _DYN_CONNECTION_STRING = \"connectionString\"; // Count: 4\r\nexport var _DYN_INSTRUMENTATION_KEY = \"instrumentationKey\"; // Count: 5\r\nexport var _DYN_USER_OVERRIDE_ENDPOI0 = \"userOverrideEndpointUrl\"; // Count: 6\r\nexport var _DYN_ENDPOINT_URL = \"endpointUrl\"; // Count: 5\r\nexport var _DYN_ONUNLOAD_FLUSH = \"onunloadFlush\"; // Count: 6\r\nexport var _DYN_CONTEXT = \"context\"; // Count: 5\r\nexport var _DYN_ADD_HOUSEKEEPING_BEF1 = \"addHousekeepingBeforeUnload\"; // Count: 2\r\nexport var _DYN_SEND_MESSAGE = \"sendMessage\"; // Count: 3\r\nexport var _DYN_UPDATE_SNIPPET_DEFIN2 = \"updateSnippetDefinitions\"; // Count: 2\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Web, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n\"use strict\";\r\nvar _a, _b, _c, _d;\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { AnalyticsPlugin } from \"@microsoft/applicationinsights-analytics-js\";\r\nimport { CfgSyncPlugin } from \"@microsoft/applicationinsights-cfgsync-js\";\r\nimport { Sender } from \"@microsoft/applicationinsights-channel-js\";\r\nimport { AnalyticsPluginIdentifier, DEFAULT_BREEZE_PATH, PropertiesPluginIdentifier, ThrottleMgr, parseConnectionString } from \"@microsoft/applicationinsights-common\";\r\nimport { AppInsightsCore, _throwInternal, addPageHideEventListener, addPageUnloadEventListener, cfgDfMerge, cfgDfValidate, createDynamicConfig, createProcessTelemetryContext, createUniqueNamespace, doPerf, hasDocument, hasWindow, isArray, isFeatureEnabled, isFunction, isNullOrUndefined, isReactNative, isString, mergeEvtNamespace, onConfigChange, proxyAssign, proxyFunctions, removePageHideEventListener, removePageUnloadEventListener } from \"@microsoft/applicationinsights-core-js\";\r\nimport { AjaxPlugin as DependenciesPlugin } from \"@microsoft/applicationinsights-dependencies-js\";\r\nimport { PropertiesPlugin } from \"@microsoft/applicationinsights-properties-js\";\r\nimport { createPromise, createSyncPromise, doAwaitResponse } from \"@nevware21/ts-async\";\r\nimport { arrForEach, arrIndexOf, isPromiseLike, objDefine, objForEachKey, strIndexOf, throwUnsupported } from \"@nevware21/ts-utils\";\r\nimport { CONFIG_ENDPOINT_URL, STR_ADD_TELEMETRY_INITIALIZER, STR_CLEAR_AUTHENTICATED_USER_CONTEXT, STR_EVT_NAMESPACE, STR_FLUSH, STR_GET_COOKIE_MGR, STR_GET_PLUGIN, STR_POLL_INTERNAL_LOGS, STR_SET_AUTHENTICATED_USER_CONTEXT, STR_SNIPPET, STR_START_TRACK_EVENT, STR_START_TRACK_PAGE, STR_STOP_TRACK_EVENT, STR_STOP_TRACK_PAGE, STR_TRACK_DEPENDENCY_DATA, STR_TRACK_EVENT, STR_TRACK_EXCEPTION, STR_TRACK_METRIC, STR_TRACK_PAGE_VIEW, STR_TRACK_TRACE } from \"./InternalConstants\";\r\nimport { _DYN_ADD_HOUSEKEEPING_BEF1, _DYN_CONNECTION_STRING, _DYN_CONTEXT, _DYN_ENDPOINT_URL, _DYN_INSTRUMENTATION_KEY, _DYN_ONUNLOAD_FLUSH, _DYN_QUEUE, _DYN_SEND_MESSAGE, _DYN_UPDATE_SNIPPET_DEFIN2, _DYN_USER_OVERRIDE_ENDPOI0, _DYN_VERSION } from \"./__DynamicConstants\";\r\nvar _internalSdkSrc;\r\n// This is an exclude list of properties that should not be updated during initialization\r\n// They include a combination of private and internal property names\r\nvar _ignoreUpdateSnippetProperties = [\r\n STR_SNIPPET, \"dependencies\", \"properties\", \"_snippetVersion\", \"appInsightsNew\", \"getSKUDefaults\"\r\n];\r\nvar IKEY_USAGE = \"iKeyUsage\";\r\nvar CDN_USAGE = \"CdnUsage\";\r\nvar SDK_LOADER_VER = \"SdkLoaderVer\";\r\nvar UNDEFINED_VALUE = undefined;\r\nvar default_limit = {\r\n samplingRate: 100,\r\n maxSendNumber: 1\r\n};\r\nvar default_interval = {\r\n monthInterval: 3,\r\n daysOfMonth: [28]\r\n};\r\nvar default_throttle_config = {\r\n disabled: true,\r\n limit: cfgDfMerge(default_limit),\r\n interval: cfgDfMerge(default_interval)\r\n};\r\n// We need to include all properties that we only reference that we want to be dynamically updatable here\r\n// So they are converted even when not specified in the passed configuration\r\nvar defaultConfigValues = (_a = {},\r\n _a[_DYN_CONNECTION_STRING /* @min:connectionString */] = UNDEFINED_VALUE,\r\n _a.endpointUrl = UNDEFINED_VALUE,\r\n _a[_DYN_INSTRUMENTATION_KEY /* @min:instrumentationKey */] = UNDEFINED_VALUE,\r\n _a[_DYN_USER_OVERRIDE_ENDPOI0 /* @min:userOverrideEndpointUrl */] = UNDEFINED_VALUE,\r\n _a.diagnosticLogInterval = cfgDfValidate(_chkDiagLevel, 10000),\r\n _a.featureOptIn = (_b = {},\r\n _b[IKEY_USAGE] = { mode: 3 /* FeatureOptInMode.enable */ },\r\n _b[CDN_USAGE] = { mode: 2 /* FeatureOptInMode.disable */ },\r\n _b[SDK_LOADER_VER] = { mode: 2 /* FeatureOptInMode.disable */ },\r\n _b),\r\n _a.throttleMgrCfg = cfgDfMerge((_c = {},\r\n _c[109 /* _eInternalMessageId.DefaultThrottleMsgKey */] = cfgDfMerge(default_throttle_config),\r\n _c[106 /* _eInternalMessageId.InstrumentationKeyDeprecation */] = cfgDfMerge(default_throttle_config),\r\n _c[111 /* _eInternalMessageId.SdkLdrUpdate */] = cfgDfMerge(default_throttle_config),\r\n _c[110 /* _eInternalMessageId.CdnDeprecation */] = cfgDfMerge(default_throttle_config),\r\n _c)),\r\n _a.extensionConfig = cfgDfMerge((_d = {},\r\n _d[\"AppInsightsCfgSyncPlugin\"] = cfgDfMerge({\r\n cfgUrl: CONFIG_ENDPOINT_URL,\r\n syncMode: 2 /* ICfgSyncMode.Receive */\r\n }),\r\n _d)),\r\n _a);\r\nfunction _chkDiagLevel(value) {\r\n // Make sure we have a value > 0\r\n return value && value > 0;\r\n}\r\n/**\r\n * Application Insights API\r\n * @group Entrypoint\r\n * @group Classes\r\n * @class Initialization\r\n * @implements {IApplicationInsights}\r\n */\r\nvar AppInsightsSku = /** @class */ (function () {\r\n function AppInsightsSku(snippet) {\r\n var _this = this;\r\n // NOTE!: DON'T set default values here, instead set them in the _initDefaults() function as it is also called during teardown()\r\n var dependencies;\r\n var properties;\r\n var _sender;\r\n var _snippetVersion;\r\n var _evtNamespace;\r\n var _houseKeepingNamespace;\r\n var _core;\r\n var _config;\r\n var _analyticsPlugin;\r\n var _cfgSyncPlugin;\r\n var _throttleMgr;\r\n var _iKeySentMessage;\r\n var _cdnSentMessage;\r\n var _sdkVerSentMessage;\r\n dynamicProto(AppInsightsSku, this, function (_self) {\r\n _initDefaults();\r\n objDefine(_self, \"config\", {\r\n g: function () {\r\n return _config;\r\n }\r\n });\r\n arrForEach([\"pluginVersionStringArr\", \"pluginVersionString\"], function (key) {\r\n objDefine(_self, key, {\r\n g: function () {\r\n if (_core) {\r\n return _core[key];\r\n }\r\n return null;\r\n }\r\n });\r\n });\r\n // initialize the queue and config in case they are undefined\r\n _snippetVersion = \"\" + (snippet.sv || snippet[_DYN_VERSION /* @min:%2eversion */] || \"\");\r\n snippet[_DYN_QUEUE /* @min:%2equeue */] = snippet[_DYN_QUEUE /* @min:%2equeue */] || [];\r\n snippet[_DYN_VERSION /* @min:%2eversion */] = snippet[_DYN_VERSION /* @min:%2eversion */] || 2.0; // Default to new version\r\n var cfgHandler = createDynamicConfig(snippet.config || {}, defaultConfigValues);\r\n _config = cfgHandler.cfg;\r\n _analyticsPlugin = new AnalyticsPlugin();\r\n objDefine(_self, \"appInsights\", {\r\n g: function () {\r\n return _analyticsPlugin;\r\n }\r\n });\r\n properties = new PropertiesPlugin();\r\n dependencies = new DependenciesPlugin();\r\n _sender = new Sender();\r\n _core = new AppInsightsCore();\r\n objDefine(_self, \"core\", {\r\n g: function () {\r\n return _core;\r\n }\r\n });\r\n // Will get recalled if any referenced values are changed\r\n _addUnloadHook(onConfigChange(cfgHandler, function () {\r\n var configCs = _config[_DYN_CONNECTION_STRING /* @min:%2econnectionString */];\r\n function _parseCs() {\r\n return createSyncPromise(function (resolve, reject) {\r\n doAwaitResponse(configCs, function (res) {\r\n var curCs = res && res.value;\r\n var parsedCs = null;\r\n if (!res.rejected && curCs) {\r\n // replace cs with resolved values in case of circular promises\r\n _config[_DYN_CONNECTION_STRING /* @min:%2econnectionString */] = curCs;\r\n parsedCs = parseConnectionString(curCs);\r\n }\r\n // if can't resolve cs promise, null will be returned\r\n resolve(parsedCs);\r\n });\r\n });\r\n }\r\n if (isPromiseLike(configCs)) {\r\n var ikeyPromise = createSyncPromise(function (resolve, reject) {\r\n _parseCs().then(function (cs) {\r\n var ikey = _config[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */];\r\n ikey = cs && cs.instrumentationkey || ikey;\r\n resolve(ikey);\r\n }).catch(function (e) {\r\n // parseCs will always resolve(unless timeout)\r\n // return null in case any error happens\r\n resolve(null);\r\n });\r\n });\r\n var url = _config[_DYN_USER_OVERRIDE_ENDPOI0 /* @min:%2euserOverrideEndpointUrl */];\r\n if (isNullOrUndefined(url)) {\r\n url = createSyncPromise(function (resolve, reject) {\r\n _parseCs().then(function (cs) {\r\n var url = _config[_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */];\r\n var ingest = cs && cs.ingestionendpoint;\r\n url = ingest ? ingest + DEFAULT_BREEZE_PATH : url;\r\n resolve(url);\r\n }).catch(function (e) {\r\n // parseCs will always resolve(unless timeout)\r\n // return null in case any error happens\r\n resolve(null);\r\n });\r\n });\r\n }\r\n _config[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */] = ikeyPromise;\r\n _config[_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */] = url;\r\n }\r\n if (isString(configCs) && configCs) {\r\n // confirm if promiselike function present\r\n // handle cs promise here\r\n // add cases to oneNote\r\n var cs = parseConnectionString(configCs);\r\n var ingest = cs.ingestionendpoint;\r\n _config.endpointUrl = _config[_DYN_USER_OVERRIDE_ENDPOI0 /* @min:%2euserOverrideEndpointUrl */] ? _config[_DYN_USER_OVERRIDE_ENDPOI0 /* @min:%2euserOverrideEndpointUrl */] : ingest + DEFAULT_BREEZE_PATH; // add /v2/track\r\n _config[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */] = cs.instrumentationkey || _config[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */];\r\n }\r\n // userOverrideEndpointUrl have the highest priority\r\n _config.endpointUrl = _config[_DYN_USER_OVERRIDE_ENDPOI0 /* @min:%2euserOverrideEndpointUrl */] ? _config[_DYN_USER_OVERRIDE_ENDPOI0 /* @min:%2euserOverrideEndpointUrl */] : _config[_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */];\r\n }));\r\n _self[STR_SNIPPET /* @min:%2esnippet */] = snippet;\r\n _self[STR_FLUSH /* @min:%2eflush */] = function (async, callBack) {\r\n if (async === void 0) { async = true; }\r\n var result;\r\n doPerf(_core, function () { return \"AISKU.flush\"; }, function () {\r\n if (async && !callBack) {\r\n result = createPromise(function (resolve) {\r\n callBack = resolve;\r\n });\r\n }\r\n var waiting = 1;\r\n var flushDone = function () {\r\n waiting--;\r\n if (waiting === 0) {\r\n callBack();\r\n }\r\n };\r\n arrForEach(_core.getChannels(), function (channel) {\r\n if (channel) {\r\n waiting++;\r\n channel[STR_FLUSH /* @min:%2eflush */](async, flushDone);\r\n }\r\n });\r\n // decrement the initial \"waiting\"\r\n flushDone();\r\n }, null, async);\r\n return result;\r\n };\r\n _self[_DYN_ONUNLOAD_FLUSH /* @min:%2eonunloadFlush */] = function (async) {\r\n if (async === void 0) { async = true; }\r\n arrForEach(_core.getChannels(), function (channel) {\r\n if (channel[_DYN_ONUNLOAD_FLUSH /* @min:%2eonunloadFlush */]) {\r\n channel[_DYN_ONUNLOAD_FLUSH /* @min:%2eonunloadFlush */]();\r\n }\r\n else {\r\n channel[STR_FLUSH /* @min:%2eflush */](async);\r\n }\r\n });\r\n };\r\n _self.loadAppInsights = function (legacyMode, logger, notificationManager) {\r\n if (legacyMode === void 0) { legacyMode = false; }\r\n if (legacyMode) {\r\n throwUnsupported(\"Legacy Mode is no longer supported\");\r\n }\r\n function _updateSnippetProperties(snippet) {\r\n if (snippet) {\r\n var snippetVer = \"\";\r\n if (!isNullOrUndefined(_snippetVersion)) {\r\n snippetVer += _snippetVersion;\r\n }\r\n if (_self[_DYN_CONTEXT /* @min:%2econtext */] && _self[_DYN_CONTEXT /* @min:%2econtext */].internal) {\r\n _self[_DYN_CONTEXT /* @min:%2econtext */].internal.snippetVer = snippetVer || \"-\";\r\n }\r\n // apply updated properties to the global instance (snippet)\r\n objForEachKey(_self, function (field, value) {\r\n if (isString(field) &&\r\n !isFunction(value) &&\r\n field && field[0] !== \"_\" && // Don't copy \"internal\" values\r\n arrIndexOf(_ignoreUpdateSnippetProperties, field) === -1) {\r\n if (snippet[field] !== value) {\r\n snippet[field] = value;\r\n }\r\n }\r\n });\r\n }\r\n }\r\n doPerf(_self.core, function () { return \"AISKU.loadAppInsights\"; }, function () {\r\n // initialize core\r\n _core.initialize(_config, [_sender, properties, dependencies, _analyticsPlugin, _cfgSyncPlugin], logger, notificationManager);\r\n objDefine(_self, \"context\", {\r\n g: function () { return properties[_DYN_CONTEXT /* @min:%2econtext */]; }\r\n });\r\n if (!_throttleMgr) {\r\n _throttleMgr = new ThrottleMgr(_core);\r\n }\r\n var sdkSrc = _findSdkSourceFile();\r\n if (sdkSrc && _self[_DYN_CONTEXT /* @min:%2econtext */]) {\r\n _self[_DYN_CONTEXT /* @min:%2econtext */].internal.sdkSrc = sdkSrc;\r\n }\r\n _updateSnippetProperties(_self[STR_SNIPPET /* @min:%2esnippet */]);\r\n // Empty queue of all api calls logged prior to sdk download\r\n _self.emptyQueue();\r\n _self[STR_POLL_INTERNAL_LOGS /* @min:%2epollInternalLogs */]();\r\n _self[_DYN_ADD_HOUSEKEEPING_BEF1 /* @min:%2eaddHousekeepingBeforeUnload */](_self);\r\n _addUnloadHook(onConfigChange(cfgHandler, function () {\r\n var defaultEnable = false;\r\n if (_config.throttleMgrCfg[109 /* _eInternalMessageId.DefaultThrottleMsgKey */]) {\r\n defaultEnable = !_config.throttleMgrCfg[109 /* _eInternalMessageId.DefaultThrottleMsgKey */].disabled;\r\n }\r\n if (!_throttleMgr.isReady() && _config.extensionConfig && _config.extensionConfig[_cfgSyncPlugin.identifier] && defaultEnable) {\r\n // set ready state to true will automatically trigger flush()\r\n _throttleMgr.onReadyState(true);\r\n }\r\n if (!_iKeySentMessage && !_config[_DYN_CONNECTION_STRING /* @min:%2econnectionString */] && isFeatureEnabled(IKEY_USAGE, _config)) {\r\n _throttleMgr[_DYN_SEND_MESSAGE /* @min:%2esendMessage */](106 /* _eInternalMessageId.InstrumentationKeyDeprecation */, \"See Instrumentation key support at aka.ms/IkeyMigrate\");\r\n _iKeySentMessage = true;\r\n }\r\n if (!_cdnSentMessage && _self[_DYN_CONTEXT /* @min:%2econtext */].internal.sdkSrc && _self[_DYN_CONTEXT /* @min:%2econtext */].internal.sdkSrc.indexOf(\"az416426\") != -1 && isFeatureEnabled(CDN_USAGE, _config)) {\r\n _throttleMgr[_DYN_SEND_MESSAGE /* @min:%2esendMessage */](110 /* _eInternalMessageId.CdnDeprecation */, \"See Cdn support notice at aka.ms/JsActiveCdn\");\r\n _cdnSentMessage = true;\r\n }\r\n if (!_sdkVerSentMessage && parseInt(_snippetVersion) < 6 && isFeatureEnabled(SDK_LOADER_VER, _config)) {\r\n _throttleMgr[_DYN_SEND_MESSAGE /* @min:%2esendMessage */](111 /* _eInternalMessageId.SdkLdrUpdate */, \"An updated Sdk Loader is available, see aka.ms/SnippetVer\");\r\n _sdkVerSentMessage = true;\r\n }\r\n }));\r\n });\r\n return _self;\r\n };\r\n _self[_DYN_UPDATE_SNIPPET_DEFIN2 /* @min:%2eupdateSnippetDefinitions */] = function (snippet) {\r\n // apply full appInsights to the global instance\r\n // Note: This must be called before loadAppInsights is called\r\n proxyAssign(snippet, _self, function (name) {\r\n // Not excluding names prefixed with \"_\" as we need to proxy some functions like _onError\r\n return name && arrIndexOf(_ignoreUpdateSnippetProperties, name) === -1;\r\n });\r\n };\r\n _self.emptyQueue = function () {\r\n // call functions that were queued before the main script was loaded\r\n try {\r\n if (isArray(_self.snippet[_DYN_QUEUE /* @min:%2equeue */])) {\r\n // note: do not check length in the for-loop conditional in case something goes wrong and the stub methods are not overridden.\r\n var length_1 = _self.snippet[_DYN_QUEUE /* @min:%2equeue */].length;\r\n for (var i = 0; i < length_1; i++) {\r\n var call = _self.snippet[_DYN_QUEUE /* @min:%2equeue */][i];\r\n call();\r\n }\r\n _self.snippet[_DYN_QUEUE /* @min:%2equeue */] = undefined;\r\n delete _self.snippet[_DYN_QUEUE /* @min:%2equeue */];\r\n }\r\n }\r\n catch (exception) {\r\n var properties_1 = {};\r\n if (exception && isFunction(exception.toString)) {\r\n properties_1.exception = exception.toString();\r\n }\r\n // need from core\r\n // Microsoft.ApplicationInsights._InternalLogging.throwInternal(\r\n // eLoggingSeverity.WARNING,\r\n // _eInternalMessageId.FailedToSendQueuedTelemetry,\r\n // \"Failed to send queued telemetry\",\r\n // properties);\r\n }\r\n };\r\n _self[_DYN_ADD_HOUSEKEEPING_BEF1 /* @min:%2eaddHousekeepingBeforeUnload */] = function (appInsightsInstance) {\r\n // Add callback to push events when the user navigates away\r\n if (hasWindow() || hasDocument()) {\r\n var performHousekeeping_1 = function () {\r\n // Adds the ability to flush all data before the page unloads.\r\n // Note: This approach tries to push a sync request with all the pending events onbeforeunload.\r\n // Firefox does not respect this.Other browsers DO push out the call with < 100% hit rate.\r\n // Telemetry here will help us analyze how effective this approach is.\r\n // Another approach would be to make this call sync with a acceptable timeout to reduce the\r\n // impact on user experience.\r\n // appInsightsInstance.context._sender.triggerSend();\r\n appInsightsInstance[_DYN_ONUNLOAD_FLUSH /* @min:%2eonunloadFlush */](false);\r\n // Back up the current session to local storage\r\n // This lets us close expired sessions after the cookies themselves expire\r\n if (isFunction(_self.core[STR_GET_PLUGIN /* @min:%2egetPlugin */])) {\r\n var loadedPlugin = _this.core[STR_GET_PLUGIN /* @min:%2egetPlugin */](PropertiesPluginIdentifier);\r\n if (loadedPlugin) {\r\n var propertiesPlugin = loadedPlugin.plugin;\r\n if (propertiesPlugin && propertiesPlugin[_DYN_CONTEXT /* @min:%2econtext */] && propertiesPlugin[_DYN_CONTEXT /* @min:%2econtext */]._sessionManager) {\r\n propertiesPlugin[_DYN_CONTEXT /* @min:%2econtext */]._sessionManager.backup();\r\n }\r\n }\r\n }\r\n };\r\n var added_1 = false;\r\n if (!_houseKeepingNamespace) {\r\n _houseKeepingNamespace = mergeEvtNamespace(_evtNamespace, _core[STR_EVT_NAMESPACE /* @min:%2eevtNamespace */] && _core[STR_EVT_NAMESPACE /* @min:%2eevtNamespace */]());\r\n }\r\n // Will be recalled if any referenced config properties change\r\n _addUnloadHook(onConfigChange(_config, function (details) {\r\n var coreConfig = details.cfg;\r\n var analyticsPlugin = appInsightsInstance.appInsights;\r\n var ctx = createProcessTelemetryContext(null, coreConfig, analyticsPlugin.core);\r\n var extConfig = ctx.getExtCfg(analyticsPlugin.identifier || AnalyticsPluginIdentifier);\r\n // As we could get recalled, remove any previously registered event handlers first\r\n _removePageEventHandlers();\r\n var excludePageUnloadEvents = coreConfig.disablePageUnloadEvents;\r\n if (!extConfig.disableFlushOnBeforeUnload) {\r\n // Hook the unload event for the document, window and body to ensure that the client events are flushed to the server\r\n // As just hooking the window does not always fire (on chrome) for page navigation's.\r\n if (addPageUnloadEventListener(performHousekeeping_1, excludePageUnloadEvents, _houseKeepingNamespace)) {\r\n added_1 = true;\r\n }\r\n // We also need to hook the pagehide and visibilitychange events as not all versions of Safari support load/unload events.\r\n if (addPageHideEventListener(performHousekeeping_1, excludePageUnloadEvents, _houseKeepingNamespace)) {\r\n added_1 = true;\r\n }\r\n // A reactNative app may not have a window and therefore the beforeunload/pagehide events -- so don't\r\n // log the failure in this case\r\n if (!added_1 && !isReactNative()) {\r\n _throwInternal(_core.logger, 1 /* eLoggingSeverity.CRITICAL */, 19 /* _eInternalMessageId.FailedToAddHandlerForOnBeforeUnload */, \"Could not add handler for beforeunload and pagehide\");\r\n }\r\n }\r\n if (!added_1 && !extConfig.disableFlushOnUnload) {\r\n // If we didn't add the normal set then attempt to add the pagehide and visibilitychange only\r\n addPageHideEventListener(performHousekeeping_1, excludePageUnloadEvents, _houseKeepingNamespace);\r\n }\r\n }));\r\n }\r\n };\r\n _self.getSender = function () {\r\n return _sender;\r\n };\r\n _self.unload = function (isAsync, unloadComplete, cbTimeout) {\r\n var unloadDone = false;\r\n var result;\r\n if (isAsync && !unloadComplete) {\r\n result = createPromise(function (resolve) {\r\n // Set the callback to the promise resolve callback\r\n unloadComplete = resolve;\r\n });\r\n }\r\n function _unloadCallback(unloadState) {\r\n if (!unloadDone) {\r\n unloadDone = true;\r\n _initDefaults();\r\n unloadComplete && unloadComplete(unloadState);\r\n }\r\n }\r\n _self[_DYN_ONUNLOAD_FLUSH /* @min:%2eonunloadFlush */](isAsync);\r\n _removePageEventHandlers();\r\n _core.unload && _core.unload(isAsync, _unloadCallback, cbTimeout);\r\n return result;\r\n };\r\n proxyFunctions(_self, _analyticsPlugin, [\r\n STR_GET_COOKIE_MGR,\r\n STR_TRACK_EVENT,\r\n STR_TRACK_PAGE_VIEW,\r\n \"trackPageViewPerformance\",\r\n STR_TRACK_EXCEPTION,\r\n \"_onerror\",\r\n STR_TRACK_TRACE,\r\n STR_TRACK_METRIC,\r\n STR_START_TRACK_PAGE,\r\n STR_STOP_TRACK_PAGE,\r\n STR_START_TRACK_EVENT,\r\n STR_STOP_TRACK_EVENT\r\n ]);\r\n proxyFunctions(_self, _getCurrentDependencies, [\r\n STR_TRACK_DEPENDENCY_DATA,\r\n \"addDependencyListener\",\r\n \"addDependencyInitializer\"\r\n ]);\r\n proxyFunctions(_self, _core, [\r\n STR_ADD_TELEMETRY_INITIALIZER,\r\n STR_POLL_INTERNAL_LOGS,\r\n \"stopPollingInternalLogs\",\r\n STR_GET_PLUGIN,\r\n \"addPlugin\",\r\n STR_EVT_NAMESPACE,\r\n \"addUnloadCb\",\r\n \"getTraceCtx\",\r\n \"updateCfg\",\r\n \"onCfgChange\"\r\n ]);\r\n proxyFunctions(_self, function () {\r\n var context = properties[_DYN_CONTEXT /* @min:%2econtext */];\r\n return context ? context.user : null;\r\n }, [\r\n STR_SET_AUTHENTICATED_USER_CONTEXT,\r\n STR_CLEAR_AUTHENTICATED_USER_CONTEXT\r\n ]);\r\n // Using a function to support the dynamic adding / removal of plugins, so this will always return the current value\r\n function _getCurrentDependencies() {\r\n return dependencies;\r\n }\r\n function _initDefaults() {\r\n _evtNamespace = createUniqueNamespace(\"AISKU\");\r\n _houseKeepingNamespace = null;\r\n dependencies = null;\r\n properties = null;\r\n _sender = null;\r\n _snippetVersion = null;\r\n _throttleMgr = null;\r\n _iKeySentMessage = false;\r\n _cdnSentMessage = false;\r\n _sdkVerSentMessage = false;\r\n _cfgSyncPlugin = new CfgSyncPlugin();\r\n }\r\n function _removePageEventHandlers() {\r\n // Remove any registered event handlers\r\n if (_houseKeepingNamespace) {\r\n removePageUnloadEventListener(null, _houseKeepingNamespace);\r\n removePageHideEventListener(null, _houseKeepingNamespace);\r\n }\r\n }\r\n function _addUnloadHook(hooks) {\r\n _core.addUnloadHook(hooks);\r\n }\r\n });\r\n }\r\n // Analytics Plugin\r\n// Removed Stub for AppInsightsSku.prototype.getCookieMgr.\r\n// Removed Stub for AppInsightsSku.prototype.trackEvent.\r\n// Removed Stub for AppInsightsSku.prototype.trackPageView.\r\n// Removed Stub for AppInsightsSku.prototype.trackPageViewPerformance.\r\n// Removed Stub for AppInsightsSku.prototype.trackException.\r\n// Removed Stub for AppInsightsSku.prototype._onerror.\r\n// Removed Stub for AppInsightsSku.prototype.trackTrace.\r\n// Removed Stub for AppInsightsSku.prototype.trackMetric.\r\n// Removed Stub for AppInsightsSku.prototype.startTrackPage.\r\n// Removed Stub for AppInsightsSku.prototype.stopTrackPage.\r\n// Removed Stub for AppInsightsSku.prototype.startTrackEvent.\r\n// Removed Stub for AppInsightsSku.prototype.stopTrackEvent.\r\n// Removed Stub for AppInsightsSku.prototype.addTelemetryInitializer.\r\n // Properties Plugin\r\n// Removed Stub for AppInsightsSku.prototype.setAuthenticatedUserContext.\r\n// Removed Stub for AppInsightsSku.prototype.clearAuthenticatedUserContext.\r\n // Dependencies Plugin\r\n// Removed Stub for AppInsightsSku.prototype.trackDependencyData.\r\n // Misc\r\n// Removed Stub for AppInsightsSku.prototype.flush.\r\n// Removed Stub for AppInsightsSku.prototype.onunloadFlush.\r\n// Removed Stub for AppInsightsSku.prototype.loadAppInsights.\r\n// Removed Stub for AppInsightsSku.prototype.updateSnippetDefinitions.\r\n// Removed Stub for AppInsightsSku.prototype.emptyQueue.\r\n// Removed Stub for AppInsightsSku.prototype.pollInternalLogs.\r\n// Removed Stub for AppInsightsSku.prototype.stopPollingInternalLogs.\r\n// Removed Stub for AppInsightsSku.prototype.addHousekeepingBeforeUnload.\r\n// Removed Stub for AppInsightsSku.prototype.getSender.\r\n// Removed Stub for AppInsightsSku.prototype.unload.\r\n// Removed Stub for AppInsightsSku.prototype.getPlugin.\r\n// Removed Stub for AppInsightsSku.prototype.addPlugin.\r\n// Removed Stub for AppInsightsSku.prototype.updateCfg.\r\n// Removed Stub for AppInsightsSku.prototype.evtNamespace.\r\n// Removed Stub for AppInsightsSku.prototype.addUnloadCb.\r\n// Removed Stub for AppInsightsSku.prototype.addDependencyListener.\r\n /**\r\n * Add an dependency telemetry initializer callback function to allow populating additional properties or drop the request.\r\n * It is called after the dependency call has completed and any available performance details are available. A dependency\r\n * initializer is similar to the TelemetryInitializer function but it allows you to block the reporting of the dependency\r\n * request so that it doesn't count against the `maxAjaxCallsPerView`.\r\n * @param dependencyInitializer - The Dependency Telemetry Initializer function\r\n * @returns - A IDependencyInitializerHandler to enable the initializer to be removed\r\n */\r\n AppInsightsSku.prototype.addDependencyInitializer = function (dependencyInitializer) {\r\n return null;\r\n };\r\n// Removed Stub for AppInsightsSku.prototype.getTraceCtx.\r\n// Removed Stub for AppInsightsSku.prototype.onCfgChange.\r\n return AppInsightsSku;\r\n}());\r\nexport { AppInsightsSku };\r\n// tslint:disable-next-line\r\nexport function _findSdkSourceFile() {\r\n if (_internalSdkSrc) {\r\n // Use the cached value\r\n return _internalSdkSrc;\r\n }\r\n var sdkSrc = null;\r\n var isModule = false;\r\n var cdns = [\r\n \"://js.monitor.azure.com/\",\r\n \"://az416426.vo.msecnd.net/\"\r\n ];\r\n try {\r\n // Try and determine whether the sdk is being loaded from the CDN\r\n // currentScript is only valid during initial processing\r\n var scrpt = (document || {}).currentScript;\r\n if (scrpt) {\r\n sdkSrc = scrpt.src;\r\n // } else {\r\n // // We need to update to at least typescript 2.9 for this to work :-(\r\n // // Leaving as a stub for now so after we upgrade this breadcrumb is available\r\n // let meta = import.meta;\r\n // sdkSrc = (meta || {}).url;\r\n // isModule = true;\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n if (sdkSrc) {\r\n try {\r\n var url_1 = sdkSrc.toLowerCase();\r\n if (url_1) {\r\n var src_1 = \"\";\r\n arrForEach(cdns, function (value, idx) {\r\n if (strIndexOf(url_1, value) !== -1) {\r\n src_1 = \"cdn\" + (idx + 1);\r\n if (strIndexOf(url_1, \"/scripts/\") === -1) {\r\n if (strIndexOf(url_1, \"/next/\") !== -1) {\r\n src_1 += \"-next\";\r\n }\r\n else if (strIndexOf(url_1, \"/beta/\") !== -1) {\r\n src_1 += \"-beta\";\r\n }\r\n }\r\n _internalSdkSrc = src_1 + (isModule ? \".mod\" : \"\");\r\n return -1;\r\n }\r\n });\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n // Cache the found value so we don't have to look it up again\r\n _internalSdkSrc = sdkSrc;\r\n }\r\n return _internalSdkSrc;\r\n}\r\n//# sourceMappingURL=AISku.js.map","/*\n * Application Insights JavaScript SDK - Web, 3.3.6\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { throwUnsupported } from \"@nevware21/ts-utils\";\r\nimport { AppInsightsSku } from \"./AISku\";\r\nimport { _DYN_UPDATE_SNIPPET_DEFIN2 } from \"./__DynamicConstants\";\r\nvar ApplicationInsightsContainer = /** @class */ (function () {\r\n function ApplicationInsightsContainer() {\r\n }\r\n ApplicationInsightsContainer.getAppInsights = function (snippet, version) {\r\n var theSku = new AppInsightsSku(snippet);\r\n // Two target scenarios:\r\n // Removed: 1. Customer runs v1 snippet + runtime. If customer updates just cdn location to new SDK, it will run in compat mode so old apis work\r\n // 2. Customer updates to new snippet (that uses cdn location to new SDK. This is same as a new customer onboarding\r\n // and all api signatures are expected to map to new SDK. Note new snippet specifies version\r\n if (version >= 2.0) {\r\n theSku[_DYN_UPDATE_SNIPPET_DEFIN2 /* @min:%2eupdateSnippetDefinitions */](snippet);\r\n theSku.loadAppInsights(false);\r\n return theSku; // default behavior with new snippet\r\n }\r\n throwUnsupported(\"V1 API compatibility is no longer supported\");\r\n };\r\n return ApplicationInsightsContainer;\r\n}());\r\nexport { ApplicationInsightsContainer };\r\n//# sourceMappingURL=ApplicationInsightsContainer.js.map"],"names":["_a","Constructor","Prototype","strFunction","DynInstFuncTable","DynProxyTag","DynClassName","DynClassNamePrefix","DynInstChkTag","DynAllowInstChkTag","DynProtoDefaultOptions","UnknownValue","str__Proto","DynProtoBaseProto","DynProtoGlobalSettings","DynProtoCurrent","strUseBaseInst","strSetInstFuncs","Obj","_objGetPrototypeOf","_objGetOwnProps","_gbl","getGlobal","_gblInst","_isObjectOrArrayPrototype","target","_isObjectArrayOrFunctionPrototype","_getObjProto","newProto","curProto","objHasOwnProperty","_forEachProp","func","props","name_1","lp","_isDynamicCandidate","funcName","skipOwn","_throwTypeError","message","throwTypeError","_getInstanceFuncs","thisTarget","instFuncs","objCreate","name","_hasVisited","values","value","_getBaseFuncs","classProto","useBaseInst","_instFuncProxy","funcHost","theFunc","instFuncTable","baseFuncs","baseProto","visited","_getInstFunc","proto","currentDynProtoProxy","instFunc","canAddInst","objProto","protoFunc","_getProtoFunc","_populatePrototype","className","baseInstFuncs","setInstanceFunc","_createDynamicPrototype","dynProtoProxy","instFuncs_1","_checkPrototype","thisProto","_getObjName","unknownValue","dynamicProto","theClass","delegateFunc","options","perfOptions","strShimFunction","strShimObject","strShimUndefined","strShimPrototype","ObjClass","ObjProto","strHasOwnProperty","__objAssignFnImpl","t","s","i","n","p","__assignFn","objAssign","extendStaticsFn","d","b","__extendsFn","__","__spreadArrayFn","to","from","il","j","createEnumStyle","createEnum","createValueMap","createTypeMap","ActiveStatus","_DYN_TO_LOWER_CASE","_DYN_LENGTH","_DYN_WARN_TO_CONSOLE","_DYN_THROW_INTERNAL","_DYN_WATCH","_DYN_APPLY","_DYN_PUSH","_DYN_SPLICE","_DYN_LOGGER","_DYN_CANCEL","_DYN_INITIALIZE","_DYN_IDENTIFIER","_DYN_REMOVE_NOTIFICATION_0","_DYN_ADD_NOTIFICATION_LIS1","_DYN_IS_INITIALIZED","_DYN_VALUE","_DYN_GET_NOTIFY_MGR","_DYN_GET_PLUGIN","_DYN_NAME","_DYN_PROCESS_NEXT","_DYN_GET_PROCESS_TEL_CONT2","_DYN_ENABLED","_DYN_STOP_POLLING_INTERNA3","_DYN_UNLOAD","_DYN_ON_COMPLETE","_DYN_VERSION","_DYN_LOGGING_LEVEL_CONSOL4","_DYN_CREATE_NEW","_DYN_TEARDOWN","_DYN_MESSAGE_ID","_DYN_MESSAGE","_DYN_DIAG_LOG","_DYN__DO_TEARDOWN","_DYN_UPDATE","_DYN_GET_NEXT","_DYN_SET_NEXT_PLUGIN","_DYN_USER_AGENT","_DYN_SPLIT","_DYN_REPLACE","_DYN_TYPE","_DYN_EVT_NAME","_DYN_STATUS","_DYN_GET_ALL_RESPONSE_HEA5","_DYN_IS_CHILD_EVT","_DYN_DATA","_DYN_GET_CTX","_DYN_SET_CTX","_DYN_ITEMS_RECEIVED","_DYN_URL_STRING","_DYN_HEADERS","_DYN_TIMEOUT","_DYN_TRACE_FLAGS","_DYN_GET_ATTRIBUTE","aggregationErrorType","throwAggregationError","sourceErrors","createCustomError","self","args","theMessage","arrForEach","srcError","idx","dumpObj","STR_PROMISE","REJECTED","doAwaitResponse","cb","doAwait","reason","resolveFn","rejectFn","finallyFn","result","isPromiseLike","err","STRING_STATES","DISPATCH_EVENT","_hasInitEvent","_hasInitEventFn","doc","evt","emitEvent","evtName","populateEvent","useNewEvent","getDocument","createCachedValue","safe","theEvt","handler","theConsole","getInst","NODE_UNHANDLED_REJECTION","UNHANDLED_REJECTION","_currentPromiseId","_uniquePromiseId","_unhandledRejectionTimeout","_hasPromiseRejectionEvent","dumpFnObj","isFunction","_createPromise","newPromise","processor","executor","additionalArgs","arrSlice","_state","_hasResolved","_settledValue","_queue","_id","_handled","_unHandledRejectionHandler","_thePromise","_then","onResolved","onRejected","thenPromise","resolve","reject","isUndefined","e","_processQueue","_catch","_finally","onFinally","thenFinally","catchFinally","_strState","pending","_createSettleIfFn","newState","allowState","theValue","scheduleTimeout","_notifyUnhandledRejection","isNode","gbl","getWindow","objDefine","objDefineProp","hasSymbol","getKnownSymbol","_toString","_rejectFn","_createAllPromise","input","values_1","pending_1","iterForOf","item","_createAllSettledPromise","processItem","isArray","isIterable","syncItemProcessor","fn","timeoutItemProcessor","timeout","callbackTimeout","isNumber","createAsyncPromise","_promiseCls","createNativePromise","PrmCls","thePromise","_resolve","_reject","_allSyncSettledCreator","createSyncPromise","createSyncAllSettledPromise","_promiseCreator","createPromise","createAllPromise","UNDEFINED_VALUE","STR_EMPTY","STR_CHANNELS","STR_CORE","STR_CREATE_PERF_MGR","STR_DISABLED","STR_EXTENSION_CONFIG","STR_EXTENSIONS","STR_PROCESS_TELEMETRY","STR_PRIORITY","STR_EVENTS_SENT","STR_EVENTS_DISCARDED","STR_EVENTS_SEND_REQUEST","STR_PERF_EVENT","STR_OFFLINE_STORE","STR_OFFLINE_SENT","STR_OFFLINE_DROP","STR_GET_PERF_MGR","STR_DOMAIN","STR_PATH","STR_NOT_DYNAMIC_ERROR","strGetPrototypeOf","rCamelCase","rNormalizeInvalid","rLeadingNumeric","isNotNullOrUndefined","isNullOrUndefined","normalizeJsName","isString","_all","letter","match","strContains","search","strIndexOf","toISOString","date","getExceptionName","object","isError","setValue","field","valChk","srcChk","getSetValue","defValue","_createProxyFunction","source","srcFunc","src","originalArguments","proxyAssign","chkSet","isObject","_loop_1","objHasOwn","proxyFunctionAs","overwriteTarget","proxyFunctions","functionsToProxy","theFuncName","createClassFromInterface","defaults","class_1","_this","objForEachKey","optimizeObject","theObject","ObjAssign","objExtend","obj1","obj2","obj3","obj4","obj5","obj6","theArgs","extended","argLen","deep","isBoolean","arg","isArgArray","isArgObj","prop","propOk","newValue","isNewArray","isPlainObject","clone","isFeatureEnabled","feature","cfg","rlt","ft","mode","getResponseText","xhr","formatErrorMessageXdr","xdr","formatErrorMessageXhr","prependTransports","theTransports","newTransports","strDisabledPropertyName","strWithCredentials","strTimeout","openXhr","method","urlString","withCredentials","disabled","isSync","_wrapSetXhrProp","convertAllHeadersToMap","headersString","headers","headersArray","strTrim","headerEntry","header","_appendHeader","theHeaders","STR_KILL_DURATION_HEADER","STR_KILL_DURATION_SECONDS_HEADER","STR_TIME_DELTA_HEADER","_getAllResponseHeaders","isOneDs","strDocumentMode","strLocation","strConsole","strJSON","strCrypto","strMsCrypto","strReactNative","strMsie","strTrident","strXMLHttpRequest","_isTrident","_navUserAgentCheck","_enableMocks","_useXDomainRequest","_beaconsSupported","_hasProperty","property","supported","tmp","getLocation","checkForMock","mockLocation","getConsole","hasJSON","getJSON","getCrypto","getMsCrypto","isReactNative","nav","getNavigator","isIE","userAgent","getIEVersion","userAgentStr","navigator_1","ua","mathMax","tridentVer","isBeaconsSupported","useCached","hasNavigator","isFetchSupported","withKeepAlive","isSupported","request","useXDomainRequest","isXhrSupported","xmlHttpRequest","dispatchEvent","evnt","createCustomDomEvent","eventName","details","event","detail","sendCustomEvent","customDetails","global","UInt32Mask","MaxUInt32","SEED1","SEED2","_mwcSeeded","_mwcW","_mwcZ","_mwcSeed","seedValue","_autoSeedMwc","now","utcNow","randomValue","maxValue","mathFloor","random32","signed","c","mwcRandom32","newId","maxLength","base64chars","number","chars","version","instanceName","_dataUid","_canAcceptData","_getCache","data","theCache","createUniqueNamespace","includeVersion","createElmNodeData","addDefault","_isConfigDefaults","_getDefault","dynamicHandler","theConfig","cfgDefaults","isDefaultValid","isDefined","fallbacks","fallback","fbValue","asString","_resolveDefaultValue","newValue_1","key","_applyDefaultValue","defaultValue","isValid","setFn","mergeDf","reference","readOnly","blkDynamicValue","usingDefault","cfgValue","dfName","dfValue","CFG_HANDLER_LINK","symbolFor","BLOCK_DYNAMIC","FORCE_DYNAMIC","_cfgDeepCopy","target_1","getDynamicConfigHandler","blockDynamicConversion","_canMakeDynamic","getFunc","state","throwInvalidAccess","arrayMethodsToPatch","_throwDynamicError","logger","desc","_patchArray","orgMethod","_i","_makeDynamicObject","_getOwnPropGetter","propDesc","objGetOwnPropertyDescriptor","_createDynamicProperty","arrIndexOf","checkDynamic","isObjectOrArray","_getProperty","activeHandler","_setProperty","isReferenced","_setDynamicProperty","getter","valueState","newIsObjectOrArray","isDynamic","_setDynamicPropertyState","flags","inPlace","rdOnly","blkProp","symPrefix","symPostfix","_createState","cfgHandler","dynamicPropertySymbol","newSymbol","dynamicPropertyReadOnly","dynamicPropertyReferenced","dynamicPropertyBlockValue","dynamicPropertyDetail","_waitingHandlers","_watcherTimer","theState","_useHandler","callback","prevWatcher","_notifyWatchers","notifyHandlers","watcherFailures_1","_addWatcher","_trackHandler","_createAndUseHandler","configHandler","_createDynamicHandler","uid","newTarget","_setValue","_watch","_block","allowUpdate","prevUpd","_ref","_rdOnly","_blkPropValue","_applyDefaults","defaultValues","_logInvalidAccess","createDynamicConfig","config","defaultConfig","onConfigChange","runTargetUnload","isAsync","doUnloadAll","targets","done","resolved","getLength","ChannelControllerPriority","DisabledPropertyName","_stringToBoolOrDefault","cfgDfMerge","cfgDfSet","setter","cfgDfValidate","validator","fallBackName","cfgDfBoolean","cfgDfString","listenerFuncs","_aiNamespace","_debugListener","_listenerProxyFunc","dbgExt","getDebugExt","listener","_getExtensionNamespace","ns","getDebugListener","STR_WARN_TO_CONSOLE","AiNonUserActionablePrefix","AiUserActionablePrefix","AIInternalMessagePrefix","_logFuncs","_sanitizeDiagnosticText","text","_logToConsole","logFunc","_InternalLogMessage","msgId","msg","isUserAct","properties","_self","strProps","diagnosticText","safeGetLogger","core","DiagnosticLogger","_messageCount","_messageLogged","_loggingLevelConsole","_loggingLevelTelemetry","_maxInternalMessageLimit","_enableDebug","_unloadHandler","_setDefaultsFromConfig","severity","_debugExtMsg","messageKey","_logInternalMessage","_areInternalMessagesThrottled","logMessage","throttleLimitMessage","throttleMessage","_getLogger","_throwInternal","_warnToConsole","_b","strToGMTString","strToUTCString","strCookie","strExpires","strIsCookieUseDisabled","strDisableCookiesUsage","strConfigCookieMgr","_supportsCookies","_allowUaSameSite","_parsedCookieValue","_doc","_cookieCache","_globalCookieConfig","rootDefaultConfig","_getDoc","getLazy","_gblCookieMgr","inst","createCookieMgr","_isMgrEnabled","cookieMgr","_isIgnoredCookie","cookieMgrCfg","_isBlockedCookie","_isCfgEnabled","rootConfig","cookieMgrConfig","isCfgEnabled","cookieEnabled","safeGetCookieMgr","_path","_domain","unloadHandler","_enabled","_getCookieFn","_setCookieFn","_delCookieFn","_getCookieValue","_setCookieValue","enabled","areCookiesSupported","gblManager","maxAgeSec","domain","path","strLeft","_extractParts","strSubstring","isTruthy","_isIE","nowMs","expireMs","expiry","_formatDate","location_1","uaDisallowsSameSiteNone","_formatCookieValue","parts","thePart","theDate","cookieValue","theCookie","strEndsWith","_runScheduledListeners","asyncNotifications","callbacks","_runListeners","listeners","NotificationManager","perfEvtsSendAll","_listeners","_asyncNotifications","index","events","sendReason","perfEvent","batch","cnt","rn_1","_finishUnload","waiting","asyncUnload","strExecutionContextKey","strParentContextKey","strChildrenContextKey","_defaultPerfManager","PerfEvent","payloadDetails","theDetails_1","ctx","childTime","childEvts","childEvt","PerfManager","manager","doPerfActiveKey","doPerf","mgrSource","getSource","perfMgr","perfEvt","currentActive","children","ex","getGblPerfMgr","generateW3CId","hexValues","oct","a","clockSequenceHi","strSubstr","DEFAULT_VERSION","INVALID_VERSION","INVALID_TRACE_ID","INVALID_SPAN_ID","_isValid","len","invalidValue","_formatValue","_formatFlags","createTraceParent","traceId","spanId","isValidTraceId","isValidSpanId","formatTraceParent","findAllScripts","scripts","script","crossOrigin","async","defer","referrerPolicy","info","pluginStateData","_getPluginState","plugin","initializePlugins","processContext","extensions","initPlugins","lastPlugin","proxy","pluginState","thePlugin","isInitialized","sortPlugins","plugins","extA","extB","bHasProcess","createDistributedTraceContext","parentCtx","trace","newTraceFlags","strTelemetryPluginChain","strHasRunFlags","strGetTelCtx","_chainId","_getNextProxyStart","startAt","createTelemetryProxyChain","_createInternalContext","telemetryChain","_nextProxy","_onComplete","context","_moveNext","_resolveExtCfg","_getConfig","nextPlugin","_iterateChain","_addOnComplete","onComplete","that","nextProxy","completeDetails","_getExtCfg","identifier","createIfMissing","idCfg","extCfg","newConfig","extConfig","createProcessTelemetryContext","internalContext","_processNext","env","_createNew","createProcessTelemetryUnloadContext","unloadState","createProcessTelemetryUpdateContext","updateState","firstProxy","add","lastProxy_1","newProxy","createTelemetryPluginProxy","hasProcessTelemetry","hasSetNext","chainId","proxyChain","_processTelemetry","_unloadPlugin","_updatePlugin","_getTelCtx","itemCtx","_processChain","processPluginFn","hasRun","hasRunContext","nextId","error","hasNextRun","_callProcessTelemetry","unloadCtx","_callTeardown","pluginCore","updateCtx","_callUpdate","objFreeze","createUnloadHandlerContainer","handlers","_addHandler","_runHandlers","createUnloadHookContainer","_hooks","_doUnload","oldHooks","_addHook","hooks","arrAppend","strGetPlugin","BaseTelemetryPlugin","_isinitialized","_rootCtx","_nextPlugin","_unloadHandlerContainer","_hookContainer","_initDefaults","pluginChain","_setDefaults","unloadDone","theUnloadCtx","theUnloadState","_unloadCallback","updateDone","theUpdateCtx","theUpdateState","_updateCallback","next","currentCtx","rootCtx","_addInitializer","_initializers","id","telemetryInitializer","theInitializer","initializer","_runInitializers","doNotSendItem","telemetryInitializersCount","TelemetryInitializerPlugin","_super","__extends","_base","strValidationError","strNotificationManager","strSdkUnloadingError","strSdkNotInitialized","maxInitQueueSize","maxInitTimeout","objDeepFreeze","_createPerfManager","notificationMgr","_validateExtensions","channelPriority","allExtensions","coreExtensions","channels","extPriorities","ext","throwError","extPriority","_isPluginPresent","exists","_deepMergeConfig","newValues","merge","_findWatcher","newWatcher","theListener","_addDelayedCfgListener","fnd","_registerDelayedCfgListener","unloadHdl","_initDebugListener","unloadContainer","notificationManager","debugListener","disableDbgExt","_createUnloadHook","unloadHook","AppInsightsCore","_configHandler","_isInitialized","_logger","_eventQueue","_notificationManager","_perfManager","_cfgPerfManager","_cookieManager","_pluginChain","_configExtensions","_channelConfig","_channels","_isUnloading","_telemetryInitializerPlugin","_internalLogsEventName","_evtNamespace","_unloadHandlers","_traceCtx","_instrumentationKey","_cfgListeners","_extensions","_pluginVersionStringArr","_pluginVersionString","_activeStatus","_endpoint","_initInMemoMaxSize","_isStatusSet","_internalLogPoller","_internalLogPollerListening","_forceStopInternalLogPoller","_addUnloadHook","rootCfg","isPending","ikey","endpointUrl","_releaseQueues","promises","initTimeout","allPromises","_setStatus","response","ikeyRes","endpointRes","_initPerfManager","cfgExtensions","__spreadArray","_initPluginChain","teeController","controls","channel","telemetryItem","_notifyInvalidEvent","_createTelCtx","eventQueue","_startLogPoller","alwaysStart","shouldStart","interval","isRunning","createTimeout","_flushInternalLogs","unloadComplete","cbTimeout","processUnloadCtx","_getPluginChain","flushComplete","_flushChannels","_getPlugin","replaceExisting","addCb","_logOrThrowError","existingPlugin","_addPlugin","removed","removedPlugins_1","_removePlugins","mergeExisting","deepExtend","_doUpdate","createNew","traceCtx","hasDocument","_setPluginVersions","thePlugins","_addPluginVersions","ver","newLogger","theCtx","theExtensions","pluginIdentifier","theExt","channelHosts","host","removeCb","pluginsToRemove","removeComplete","unloadChain","newConfigExtensions","newChannelConfig","queue","newQueue","callBack","doneIterating","cbTimer","doCallback","flushCtx","handled_1","prevCfgPerfMgr","enablePerfMgr","createPerfMgr","parseResponse","diagLog","STR_NO_RESPONSE_BODY","_noResponseQs","STR_POST_METHOD","SenderPostManager","_syncFetchPayload","_enableSendPromise","_diagLog","_isOneDs","_onCompleteFuncs","_disableCredentials","_fetchCredentials","_fallbackInst","_disableXhr","_disableBeacon","_disableBeaconSync","_disableFetchKeepAlive","_addNoResponse","_timeoutWrapper","_sendCredentials","_xhrSender","transports","sync","_getSenderInterface","_onSuccess","res","_doOnComplete","_onError","_onNoPayloadUrl","syncSupport","transportType","sendPostFunc","_xdrSender","_doFetchSender","_beaconSender","oncomplete","status","_doBeaconSend","payload","url","plainTextBatch","queued","onRetry","resolveFunc","rejectFunc","endPointUrl","objKeys","headerName","_doOnReadyFunc","onReadyFunc","onReadyFuncExist","requestHeaders","batchLength","ignoreResponse","responseHandled","init","_handleError","_onFetchComplete","onCompleteFunc","response_1","resp","_window","onloadFunc","hostingProtocol","endpoint","strOnPrefix","strAttachEvent","strAddEventHelper","strDetachEvent","strRemoveEventListener","strEvents","strVisibilityChangeEvt","strPageHide","strUnload","strBeforeUnload","strPageHideNamespace","rRemoveEmptyNs","rRemoveTrailingEmptyNs","_guid","elmNodeData","eventNamespace","_normalizeNamespace","_getEvtNamespace","evtNamespace","theNamespace_1","parsedEvent","_getRegisteredEvents","aiEvts","registeredEvents","_doDetach","obj","handlerRef","useCapture","_doAttach","_doUnregister","unRegFn","theEvent","_unregisterEvents","eventCache","evtType","mergeEvtNamespace","theNamespace","namespaces","newNamespaces","eventOn","registeredEvent","eventOff","evtName_1","found_1","regEvent","addEventHandler","w","removeEventHandler","_addEventListeners","excludeEvents","added","addEventListeners","removeEventListeners","addPageUnloadEventListener","removePageUnloadEventListener","addPageHideEventListener","_handlePageVisibility","pageUnloadAdded","removePageHideEventListener","LoggingSeverity","aiInstrumentHooks","cbNames","_arrLoop","arr","_doCallbacks","callDetails","cbArgs","hookCtx","type","hook","cbks","orgEx","hookErrorCb","_createFunctionHook","aiHook","funcThis","orgArgs","funcArgs","_replaceArg","_createArgs","_getOwner","checkPrototype","checkParentProto","owner","InstrumentProto","InstrumentFunc","_createInstrumentHook","newFunc","theHook","InstrumentEvent","SampleRate","ProcessLegacy","HttpMethod","DEFAULT_BREEZE_ENDPOINT","DEFAULT_BREEZE_PATH","strNotSpecified","strIkey","RequestHeaders","_DYN_INGESTIONENDPOINT","_DYN_TO_STRING","_DYN_REMOVE_ITEM","_DYN_COUNT","_DYN_PRE_TRIGGER_DATE","_DYN_GET_UTCDATE","_DYN_STRINGIFY","_DYN_PATHNAME","_DYN_MATCH","_DYN_CORRELATION_HEADER_E0","_DYN_PROPERTIES","_DYN_MEASUREMENTS","_DYN_SIZE_IN_BYTES","_DYN_TYPE_NAME","_DYN_EXCEPTIONS","_DYN_SEVERITY_LEVEL","_DYN_PROBLEM_GROUP","_DYN_PARSED_STACK","_DYN_HAS_FULL_STACK","_DYN_ASSEMBLY","_DYN_FILE_NAME","_DYN_LINE","_DYN_AI_DATA_CONTRACT","_DYN_DURATION","dataSanitizeKeyAndAddUniqueness","map","origLength","dataSanitizeKey","uniqueField","dsPadNumber","nameTrunc","dataSanitizeString","valueTrunc","dataSanitizeUrl","dataSanitizeInput","dataSanitizeMessage","messageTrunc","dataSanitizeException","exception","exceptionTrunc","dataSanitizeProperties","tempProps_1","dataSanitizeMeasurements","measurements","tempMeasurements_1","measure","dataSanitizeId","_msgId","inputTrunc","num","_document","_htmlAnchorIdx","_htmlAnchorElement","urlParseUrl","anchorIdx","anchorCache","tempAnchor","urlParseHost","urlGetAbsoluteUrl","urlGetCompleteUrl","absoluteUrl","inclPort","fullHost","urlParseFullHost","protocol","port","_internalEndpoints","_correlationIdPrefix","isInternalApplicationInsightsEndpoint","correlationIdCanIncludeCorrelationHeader","requestUrl","currentHost","requestHost","includedDomains","matchExists_1","regex","excludedDomains","correlationIdGetCorrelationContext","responseHeader","correlationId","correlationIdGetCorrelationContextValue","keyValues","keyValue","AjaxHelperParseDependencyPath","commandName","parsedUrl","pathName","dateTimeUtilsNow","perf","getPerformance","dateNow","dateTimeUtilsDuration","start","end","createDistributedTraceContextFromTrace","telemetryTrace","StorageType","DistributedTracingModes","EventPersistence","_canUseLocalStorage","_canUseSessionStorage","_storagePrefix","_getLocalStorageObject","utlCanUseLocalStorage","_getVerifiedStorageObject","storageType","storage","getGlobalInst","fail","_getSessionStorageObject","utlCanUseSessionStorage","utlDisableStorage","utlSetStoragePrefix","storagePrefix","utlEnableStorage","reset","utlGetLocalStorage","utlSetLocalStorage","utlRemoveStorage","utlGetSessionStorage","utlSetSessionStorage","utlRemoveSessionStorage","THROTTLE_STORAGE_PREFIX","ThrottleMgr","namePrefix","_config","_localStorageObj","_isTriggered","_namePrefix","_isReady","_isSpecificDaysGiven","_initConfig","localObj","_getLocalStorageObjByKey","_getCfgByKey","_canThrottle","_isTrigger","_getQueueByKey","items","_flushMessage","result_1","isFlushed","isReady","flushAll","msgID","saveUnsentMsg","isSampledIn","_canSampledIn","localStorageObj","canThrottle","throttled","isTriggered","mathMin","localStorageName","_getLocalStorageName","_resetLocalStorage","_sendMessage","_setCfgByKey","coreConfig","configMgr","curCfg","configInterval","_getIntervalConfig","limit","monthInterval","dayInterval","canUseLocalStorage","curDate","_getThrottleDate","monthCheck","monthExpand","_checkInterval","dayCheck","daySpan","msgKey","prefix","fix","_isTriggeredOnCurDate","preTriggerDate","_getLocalStorageObj","storageName","storageObj","curObj","dateStr","current","isTrigger","_FIELDS_SEPARATOR","_FIELD_KEY_VALUE_SEPARATOR","parseConnectionString","connectionString","kvPairs","arrReduce","fields","kv","kvParts","locationPrefix","Envelope","Event","STACKFRAME_BASE_SIZE","IS_FRAME","FULL_STACK_FRAME_1","FULL_STACK_FRAME_2","FULL_STACK_FRAME_3","EXTRACT_FILENAME","PARSE_FILENAME_LINE_COL","PARSE_FILENAME_LINE_ONLY","NoMethod","strError","strStack","strStackDetails","strErrorSrc","strMessage","strDescription","_parseSequence","_ignoreNative","_scrubAnonymous","_handleFilename","frame","_stringify","convertToString","_formatMessage","errorType","evtMessage","_isExceptionDetailsInternal","_isExceptionInternal","_isStackDetails","_convertStackObj","errorStack","_getOperaStack","errorMessage","stack","lines","entry","_getStackFromErrorObj","errorObj","_formatStackTrace","stackDetails","_parseStack","parsedStack","frames","level_1","foundStackStart_1","totalSizeInBytes_1","_isStackFrame","theFrame","parsedFrame","_extractStackFrame","exceptionParsedStackThreshold","left","right","size","acceptedLeft","acceptedRight","lSize","rSize","howMany","_getErrorType","typeName","funcNameRegex","results","_formatErrorCode","Exception","severityLevel","_createExceptionDetails","lineNumber","columnNumber","errorSrc","exceptions","arrMap","_createExDetailsFromInterface","exceptionData","__assign","problemGroup","isManual","exceptionDetailsInterface","assembly","fileName","line","exDetailsAiDataContract","_toInterface","_parsedFrameToInterface","outerId","hasFullStack","theStack","_stackFrameFromInterface","exceptionDetails","_parseFilename","lineCol","lineNo","sequence","matches","filename","trimmedFrame","stackFrameAiDataContract","level","_populateFrameSizeInBytes","sizeInBytes","DataPoint","Metric","count","min","max","stdDev","dataPoint","strEmpty","msToTimeSpan","totalms","mathRound","ms","sec","hour","days","isCrossOriginError","PageView","durationMs","RemoteDependencyData","success","resultCode","requestAPI","correlationContext","dependencyFields","Trace","PageViewPerformance","unused","cs4BaseData","Data","baseType","SeverityLevel","_aiNameFunc","baseName","aiName","_aiApplication","_aiDevice","_aiLocation","_aiOperation","_aiSession","_aiUser","_aiCloud","_aiInternal","ContextTagKeys","createTelemetryItem","envelopeName","customProperties","systemProperties","iKey","Extensions","CtxTagKeys","createDomEvent","_disableEvents","createOfflineListener","parentEvtNamespace","_navigator","_isListening","listenerList","rState","uState","_currentState","calCurrentState","_enableEvents","_setOnline","_setOffline","_isOnline","listnerNoticeCheck","offlineState","setOnlineState","_unload","win","addListener","PropertiesPluginIdentifier","BreezeChannelIdentifier","AnalyticsPluginIdentifier","_DYN_IS_STORAGE_USE_DISAB0","_DYN__ADD_HOOK","_DYN_CORE","_DYN_DATA_TYPE","_DYN_ENVELOPE_TYPE","_DYN_TRACK","_DYN_TRACK_PAGE_VIEW","_DYN_TRACK_PREVIOUS_PAGE_1","_DYN_SEND_PAGE_VIEW_INTER2","_DYN_START_TIME","_DYN_SEND_PAGE_VIEW_PERFO3","_DYN_POPULATE_PAGE_VIEW_P4","_DYN_HREF","_DYN_SEND_EXCEPTION_INTER5","_DYN_ERROR","_DYN_LINE_NUMBER","_DYN_COLUMN_NUMBER","_DYN__CREATE_AUTO_EXCEPTI6","_DYN_ADD_TELEMETRY_INITIA7","_DYN_OVERRIDE_PAGE_VIEW_D8","_DYN_AUTO_EXCEPTION_INSTR9","_DYN_AUTO_TRACK_PAGE_VISI10","_DYN_IS_BROWSER_LINK_TRAC11","_DYN_ENABLE_AUTO_ROUTE_TR12","_DYN_ENABLE_UNHANDLED_PRO13","_DYN_AUTO_UNHANDLED_PROMI14","_DYN_GET_ENTRIES_BY_TYPE","_DYN_IS_PERFORMANCE_TIMIN15","_DYN_GET_PERFORMANCE_TIMI16","_DYN_NAVIGATION_START","_DYN_SHOULD_COLLECT_DURAT17","_DYN_IS_PERFORMANCE_TIMIN18","_DYN_RESPONSE_START","_DYN_REQUEST_START","_DYN_LOAD_EVENT_END","_DYN_RESPONSE_END","_DYN_CONNECT_END","PageViewManager","appInsights","overridePageViewDuration","pageViewPerformanceManager","queueTimer","itemQueue","pageViewPerformanceSent","firstPageViewSent","_startTimer","allItems","doFlush","_addQueue","pageView","uri","navigationEntries","loadEventStart","duration_1","isWebWorker","pageViewSent","customDuration","duration","maxDurationLimit","processed","pageViewPerformance","MAX_DURATION_ALLOWED","botAgentNames","_isPerformanceTimingSupported","_isPerformanceNavigationTimingSupported","_isPerformanceTimingDataReady","timing","_getPerformanceTiming","_getPerformanceNavigationTiming","_shouldCollectDuration","durations","isGoogleBot","PageViewPerformanceManager","navigationTiming","total","network","dom","PageVisitTimeManager","pageVisitTimeTrackingHandler","prevPageVisitDataKeyName","currentPageName","currentPageUrl","prevPageVisitTimeData","restartPageVisitTimer","pageName","pageUrl","prevPageVisitData","stopPageVisitTimer","currPageVisitDataStr","PageVisitData","pageVisitEndTime","pageVisitDataJsonStr","Timing","_events","strEvent","_dispatchEvent","_getReason","MinMilliSeconds","_chkConfigMilliseconds","_chkSampling","_updateStorageUsage","AnalyticsPlugin","_eventTracking","_pageTracking","_pageViewManager","_pageViewPerformanceManager","_pageVisitTimeManager","_preInitTelemetryInitializers","_isBrowserLinkTrackingEnabled","_browserLinkInitializerAdded","_enableAutoRouteTracking","_historyListenerAdded","_disableExceptionTracking","_autoExceptionInstrumented","_enableUnhandledPromiseRejectionTracking","_autoUnhandledPromiseInstrumented","_extConfig","_autoTrackPageVisitTime","_expCfg","_prevUri","_currUri","_errorHookCnt","EventTelemetry","metric","inPv","inPvp","measurement","loc","theError","exceptionPartB","scriptsInfo","logs","_sendCORSException","errorString","_populateDefaults","pageVisitTime","trackPageVisitTime","pageViewItem","hasWindow","_updateExceptionTracking","_updateLocationChange","_addDefaultTelemetryInitializers","browserLinkPaths_1","dropBrowserLinkRequests","envelope","remoteData","locn","_addUnhandledPromiseRejectionTracking","hasHistory","_history","getHistory","strUndefined","_addHistoryListener","_getDistributedTraceCtx","distributedTraceCtx","history","_popstateHandler","_locationChangeHandler","traceLocationName","_location","location","_DYN_FEATURE_OPT_IN","_DYN_SCHEDULE_FETCH_TIMEO0","replaceByNonOverrideCfg","nonOverrideConfigs","curLevel","maxLevel","exceedMaxLevel","curCfg_1","nonOverrideVal","F","M","ON","OFF","resolveCdnFeatureCfg","cdnCfg","userOptInDetails","cdnFt","cdnM","cdnOnV","cdnOffV","userFt","userM","userOnV","userOffV","blockCdn","mFld","onFld","offFld","onV","offV","applyCdnfeatureCfg","optInMap","cdnConfig_1","featureVal","val","setValueByKey","_overrideCdnCfgByFeature","ftVal","dVal","EVENT_NAME","STR_GET_METHOD","FETCH_TIMEOUT","udfVal","defaultNonOverrideCfg","_defaultConfig","CfgSyncPlugin","_extensionConfig","_mainConfig","_evtName","_cfgUrl","_timeoutHandle","_receiveChanges","_broadcastChanges","_blkCdnCfg","_fetchTimeout","_retryCnt","_onCfgChangeReceive","_nonOverrideConfigs","_fetchFn","_overrideFetchFn","_overrideSyncFn","_paused","_enableAjax","_clearScheduledTimer","_setupTimer","_setCfg","_sendCfgsyncEvents","_updateEventListenerName","_eventOff","preBlkCdn","newEvtName","_getFetchFnInterface","isAutoSync","global_1","_addEventListener","_fetchSender","fetchFn","xhr_1","JSON_1","newCfg","_replaceTartgetByKeys","global_2","cfgEvent","_cfg","STR_DURATION","_DYN_TAGS","_DYN_DEVICE_TYPE","_DYN_TRACE_ID","_DYN_ENQUEUE","_DYN_EMIT_LINE_DELIMITED_0","_DYN_CLEAR","_DYN_MARK_AS_SENT","_DYN_CLEAR_SENT","_DYN_BUFFER_OVERRIDE","_DYN__BUFFER__KEY","_DYN__SENT__BUFFER__KEY","_DYN_CONCAT","_DYN__MAX__BUFFER__SIZE","_DYN_TRIGGER_SEND","_DYN__SENDER","_DYN_ENDPOINT_URL","_DYN_INSTRUMENTATION_KEY","_DYN_CUSTOM_HEADERS","_DYN_MAX_BATCH_SIZE_IN_BY1","_DYN_ONUNLOAD_DISABLE_BEA2","_DYN_IS_BEACON_API_DISABL3","_DYN_ALWAYS_USE_XHR_OVERR4","_DYN_ENABLE_SESSION_STORA5","_DYN__BUFFER","_DYN_ONUNLOAD_DISABLE_FET6","_DYN_DISABLE_SEND_BEACON_7","_DYN_GET_SENDER_INST","_DYN__ON_ERROR","_DYN__ON_PARTIAL_SUCCESS","_DYN__ON_SUCCESS","_DYN_ITEMS_ACCEPTED","_DYN_BASE_TYPE","_DYN_SAMPLE_RATE","_DYN_GET_HASH_CODE_SCORE","strBaseType","strBaseData","strProperties","strTrue","_setValueIf","_extractPartAExtensions","envTags","itmExt","itmTags","extUser","extApp","extDevice","web","envData","envBaseData","envProps","extOs","extTrace","tgs","tg","theTags","EnvelopeCreator","_extractPropsAndMeasurements","_convertPropsUndefinedToCustomDefinedValue","customUndefinedValue","_createEnvelope","envelopeType","iKeyNoDashes","EnvelopeCreatorInit","DependencyEnvelopeCreator","customMeasurements","bd","remoteDepData","EventEnvelopeCreator","eventData","ExceptionEnvelopeCreator","exData","MetricEnvelopeCreator","baseData","baseMetricData","PageViewEnvelopeCreator","currentContextId","pageTags","pageViewData","PageViewPerformanceEnvelopeCreator","TraceEnvelopeCreator","BaseSendBuffer","_buffer","_bufferFullMessageSent","_maxRetryCnt","buffer","payloads","payloadStr_1","canUseSessionStorage","newBuffer","SessionStorageSendBuffer","ArraySendBuffer","PREVIOUS_KEYS","getItem","setItem","bufferItems","_getBuffer","itemsInSentBuffer","previousItems","_getPreviousEvents","notDeliveredItems","_setBuffer","_removePayloadsFromBuffer","sentElements","unsentItems","sentItems","remaining","payloadStr","prefixedKey","_getBufferBase","bufferJson","buffer_1","_getItemsFromPreviousKey","prefixEvents","transFormedItems_1","internalItem","Serializer","output","_serializeObject","circularReferenceCheck","_serializeStringMap","_serializeArray","contract","isRequired","isHidden","isPresent","isObj","sources","expectedType","MIN_INPUT_LENGTH","HashCodeScoreGenerator","score","hash","SamplingScoreGenerator","hashCodeGenerator","keys","Sample","sampleRate","samplingPercentage","EMPTY_STR","FetchSyncRequestSizeLimitBytes","_getResponseText","isOverrideFn","httpXHROverride","defaultAppInsightsChannelConfig","EnvelopeTypeCreator","Sender","_consecutiveErrors","_retryAt","_lastSend","_serializer","_stamp_specific_redirects","_headers","_syncUnloadSender","_offlineListener","_endpointUrl","_orgEndpointUrl","_maxBatchSizeInBytes","_beaconSupported","_beaconOnUnloadSupported","_beaconNormalSupported","_customHeaders","_disableTelemetry","_convertUndefined","_isRetryDisabled","_maxBatchInterval","_sessionStorageUsed","_bufferOverrideUsed","_alwaysUseCustomSend","_fetchKeepAlive","_xhrSend","_fallbackSend","_disableBeaconSplit","_sendPostMgr","_retryCodes","_checkMaxSize","_doUnloadSend","senderConfig","curExtUrl","coreUrl","customHeader","bufferOverride","shouldUpdate","_validateInstrumentationKey","sendPostConfig","_getSendPostMgrConfig","customInterface","httpInterface","syncInterface","xhrInterface","_doSend","_fetchKeepAliveSender","syncTransports","transport","diagLogger","isValidate","_validate","aiEnvelope","_getEnvelope","payloadItem","countOfItemsInPayload","_isStringArr","_xhrReadyStateChange","forcedSender","_notifySendRequest","ieVer","_createPayload","_serialize","_batch","_onPartialSuccess","_xdrOnLoad","responseText","onCompleteFuncs","_getPayloadArr","resValue","_checkResponsStatus","canSend","_onBeaconRetry","failed","retry","errors","errors_1","extracted","_isRetriable","_resendPayload","internalPayload","_isSampledIn","defaultEnvelopeIkey","valid","_getHeaders","_getOnComplete","sendInterface","markAsSent","payloadData","_getPayload","incomingPayload","incomingSize","responseUrl","_checkAndUpdateEndPointUrl","offlineBackOffMultiplier","beaconInst","droppedPayload","thePayload","payloadSize","syncFetchPayload","linearFactor","payload_1","_setRetryTime","SlotDelayInSeconds","delayInSeconds","backOffSlot","backOffDelay","retryAfterTimeSpan","retryInterval","timerValue","statusCode","_getNotifyMgr","sendRequest","instrumentationKey","disableValidation","disableIKeyValidationFlag","UUID_Regex","regexp","orig","convertUndefined","creator","STR_PROPERTIES","_DYN_REQUEST_URL","_DYN_SPAN_ID","_DYN_CONTEXT","_DYN_ABORTED","_DYN_INCLUDE_CORRELATION_0","_DYN_GET_ABSOLUTE_URL","_DYN_REQUEST_HEADERS","_DYN_SET_REQUEST_HEADER","_DYN_TRACK_DEPENDENCY_DAT1","_DYN_ENABLE_REQUEST_HEADE2","_DYN_ENABLE_AJAX_ERROR_ST3","_DYN_ENABLE_AJAX_PERF_TRA4","_DYN_MAX_AJAX_CALLS_PER_V5","_DYN_EXCLUDE_REQUEST_FROM6","_DYN_DISABLE_AJAX_TRACKIN7","_DYN_AJAX_PERF_LOOKUP_DEL8","_DYN_DISABLE_FETCH_TRACKI9","_DYN_ENABLE_RESPONSE_HEAD10","_DYN_STATUS_TEXT","_DYN_HEADER_MAP","_DYN_REQUEST_SENT_TIME","_DYN_GET_TRACE_ID","_DYN_GET_TRACE_FLAGS","_DYN_METHOD","_DYN_ERROR_STATUS_TEXT","_DYN_STATE_CHANGE_ATTACHE11","_DYN_RESPONSE_TEXT","_DYN_RESPONSE_FINISHED_TI12","_DYN__CREATE_TRACK_ITEM","_DYN_GET_ALL_RESPONSE_HEA13","_DYN_GET_PART_APROPS","_DYN_PERF_MARK","_DYN_PERF_TIMING","_DYN_AJAX_DIAGNOSTICS_MES14","_DYN_CORRELATION_CONTEXT","_DYN_AJAX_TOTAL_DURATION","_DYN_EVENT_TRACE_CTX","_calcPerfDuration","resourceEntry","_setPerfDuration","_setPerfValue","strPerf","perfData","_populatePerfData","ajaxData","dependency","propsSet","strName","strStart","strEnd","strDomainLookup","strConnect","strRedirect","strRequest","strResponse","strStartTime","strDomainLookupStart","strDomainLookupEnd","strConnectStart","strConnectEnd","strRequestStart","strRequestEnd","strResponseStart","strResponseEnd","strRedirectStart","strRedirectEnd","strTransferSize","strEncodedBodySize","strDecodedBodySize","strServerTiming","serverTiming","server_1","XHRMonitoringState","ajaxRecord","strResponseText","ajaxType","enableRequestHeaderTracking","getResponse","responseType","partA","traceExt","strDiagLog","AJAX_DATA_CONTAINER","STR_FETCH","ERROR_HEADER","ERROR_PREFIX","ERROR_POSTFIX","ERROR_NOT_SENT","CORRELATION_HEADER_ERROR","CUSTOM_REQUEST_CONTEXT_ERROR","FAILED_TO_CALCULATE_DURATION_ERROR","_markCount","_supportsFetch","_global","strPrototype","_supportsAjaxMonitoring","ajaxMonitorInstance","ajaxDataId","xhrData","theOpen","_throwInternalCritical","_getAjaxData","_addSharedXhrHeaders","_isHeaderSet","_getFailedAjaxDiagnosticsMessage","_throwInternalWarning","_createErrorCallbackFunc","internalMessage","_indexOf","container","theHandler","_processDependencyContainer","_processDependencyListeners","initializersCount","BLOB_CORE","DfltAjaxCorrelationHeaderExDomains","_internalExcludeEndpoints","AjaxMonitor","_fetchInitialized","_xhrInitialized","_currentWindowHost","_enableRequestHeaderTracking","_enableAjaxErrorStatusText","_trackAjaxAttempts","_context","_isUsingW3CHeaders","_isUsingAIHeaders","_markPrefix","_enableAjaxPerfTracking","_maxAjaxCallsPerView","_enableResponseHeaderTracking","_disabledUrls","_disableAjaxTracking","_disableFetchTracking","_excludeRequestFromAutoTrackingPatterns","_addRequestContext","_ajaxDataId","_dependencyHandlerId","_dependencyListeners","_dependencyInitializers","_ignoreHeaders","_maxAjaxPerfLookupAttempts","_ajaxPerfLookupDelay","_distributedTracingMode","_appId","_polyfillInitialized","_instrumentXhr","_instrumentFetch","_populateContext","_reportDependencyInternal","currentWindowHost","appId","traceFlags","traceParent","dependencyListener","dependencyInitializer","propExt","_canIncludeHeaders","fetch","isPolyfill","fetchData","_isDisabledRequest","_createFetchRecord","newInit","fetchData_1","_reportFetchMetrics","ajaxResponse","_getFetchCorrelationContext","responseHeaderMap_1","_hookProto","_isMonitoredXhrInstance","_openHandler","_attachToOnReadyStateChange","_createMarkId","isDisabled","theUrl","theRegex","idx2","excludeAjaxDataValidation","ajaxValidation","initialized","traceID","spanID","xhrRequestData","ajaxDataCntr","_onAjaxComplete","exceptionText","_reportXhrError","failedProps","errorProps","_findPerfResourceEntry","_getAjaxCorrelationContext","responseHeaderMap_2","sysProperties","responseHeadersString","performance_1","markId","entries","initiatorType","trackCallback","reportError","perfMark","performance","maxAttempts","retryDelay","attempt","locateResourceTiming","perfTiming","strSplit","_getFailedFetchDiagnosticsMessage","_reportFetchError","initializers","Application","Device","Version","Internal","unloadHookContainer","Location","_DYN_SESSION","_DYN_SESSION_MANAGER","_DYN_IS_USER_COOKIE_SET","_DYN_IS_NEW_USER","_DYN_GET_TRACE_CTX","_DYN_TELEMETRY_TRACE","_DYN_APPLY_SESSION_CONTEX0","_DYN_APPLY_APPLICATION_CO1","_DYN_APPLY_OPERATION_CONT2","_DYN_APPLY_OPERATING_SYST3","_DYN_APPLY_LOCATION_CONTE4","_DYN_APPLY_INTERNAL_CONTE5","_DYN_GET_SESSION_ID","_DYN_SESSION_COOKIE_POSTF6","_DYN_AUTOMATIC_SESSION","_DYN_ACCOUNT_ID","_DYN_AUTHENTICATED_ID","_DYN_ACQUISITION_DATE","_DYN_RENEWAL_DATE","_DYN_COOKIE_SEPARATOR","_DYN_AUTH_USER_COOKIE_NAM7","SESSION_COOKIE_NAME","ACQUISITION_SPAN","RENEWAL_SPAN","COOKIE_UPDATE_INTERVAL","Session","_SessionManager","_storageNamePrefix","_cookieUpdatedTimestamp","_sessionExpirationMs","_sessionRenewalMs","sessionCookiePostfix","isExpired","session","_initializeAutomaticSession","timeSinceAcqMs","timeSinceRenewalMs","_renew","_setCookie","_setStorage","_initializeAutomaticSessionWithData","storageValue","sessionData","sessionReset","tokens","acqMs","renewalMs","getNewId","acq","renewalPeriodMs","acqTimeLeftMs","cookie","cookieDomain","guid","renewal","TelemetryTrace","parentId","_validateUserInput","User","userCookiePostfix","params","_generateNewId","newCookie","_generateNewCookie","_setUserCookie","authCookie","authCookieString","userId","acqStr","oneYear","authenticatedUserId","accountId","storeInCookie","isInvalidInput","user_id","user_cookie","strExt","strTags","_removeEmpty","_nullResult","TelemetryContext","previousTraceCtx","sesId","autoSession","application","tags","device","internal","user","undefString","nullValue","PropertiesPlugin","_distributedTraceCtx","_previousTraceCtx","_disableUserInitMessage","theContext","userCtx","_processTelemetryInternal","breezeChannel","_AUTHENTICATED_USER_CONTEXT","_TRACK","STR_SNIPPET","STR_GET_COOKIE_MGR","STR_START_TRACK_PAGE","STR_STOP_TRACK_PAGE","STR_FLUSH","STR_START_TRACK_EVENT","STR_STOP_TRACK_EVENT","STR_ADD_TELEMETRY_INITIALIZER","STR_POLL_INTERNAL_LOGS","STR_GET_PLUGIN","STR_EVT_NAMESPACE","STR_TRACK_EVENT","STR_TRACK_TRACE","STR_TRACK_METRIC","STR_TRACK_PAGE_VIEW","STR_TRACK_EXCEPTION","STR_TRACK_DEPENDENCY_DATA","STR_SET_AUTHENTICATED_USER_CONTEXT","STR_CLEAR_AUTHENTICATED_USER_CONTEXT","CONFIG_ENDPOINT_URL","_DYN_QUEUE","_DYN_CONNECTION_STRING","_DYN_USER_OVERRIDE_ENDPOI0","_DYN_ONUNLOAD_FLUSH","_DYN_ADD_HOUSEKEEPING_BEF1","_DYN_SEND_MESSAGE","_DYN_UPDATE_SNIPPET_DEFIN2","_c","_d","_internalSdkSrc","_ignoreUpdateSnippetProperties","IKEY_USAGE","CDN_USAGE","SDK_LOADER_VER","default_limit","default_interval","default_throttle_config","defaultConfigValues","_chkDiagLevel","AppInsightsSku","snippet","dependencies","_sender","_snippetVersion","_houseKeepingNamespace","_core","_analyticsPlugin","_cfgSyncPlugin","_throttleMgr","_iKeySentMessage","_cdnSentMessage","_sdkVerSentMessage","DependenciesPlugin","configCs","_parseCs","curCs","parsedCs","ikeyPromise","cs","ingest","flushDone","legacyMode","throwUnsupported","_updateSnippetProperties","snippetVer","sdkSrc","_findSdkSourceFile","defaultEnable","length_1","call","properties_1","appInsightsInstance","performHousekeeping_1","loadedPlugin","propertiesPlugin","added_1","analyticsPlugin","_removePageEventHandlers","excludePageUnloadEvents","_getCurrentDependencies","isModule","cdns","scrpt","url_1","src_1","ApplicationInsightsContainer","theSku"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103]}