@microsoft/applicationinsights-properties-js 3.0.2-nightly3.2305-03 → 3.0.2-nightly3.2305-04
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/browser/es5/{ai.props.3.0.2-nightly3.2305-03.cjs.js → ai.props.3.0.2-nightly3.2305-04.cjs.js} +5 -4
- package/browser/es5/{ai.props.3.0.2-nightly3.2305-03.gbl.js.map → ai.props.3.0.2-nightly3.2305-04.cjs.js.map} +1 -1
- package/browser/es5/{ai.props.3.0.2-nightly3.2305-03.cjs.min.js → ai.props.3.0.2-nightly3.2305-04.cjs.min.js} +3 -3
- package/browser/es5/{ai.props.3.0.2-nightly3.2305-03.cjs.min.js.map → ai.props.3.0.2-nightly3.2305-04.cjs.min.js.map} +1 -1
- package/browser/es5/ai.props.3.0.2-nightly3.2305-04.gbl.js +4027 -0
- package/browser/es5/{ai.props.3.0.2-nightly3.2305-03.cjs.js.map → ai.props.3.0.2-nightly3.2305-04.gbl.js.map} +1 -1
- package/browser/es5/ai.props.3.0.2-nightly3.2305-04.gbl.min.js +6 -0
- package/browser/es5/{ai.props.3.0.2-nightly3.2305-03.gbl.min.js.map → ai.props.3.0.2-nightly3.2305-04.gbl.min.js.map} +1 -1
- package/browser/es5/ai.props.3.0.2-nightly3.2305-04.integrity.json +66 -0
- package/browser/es5/ai.props.3.0.2-nightly3.2305-04.js +4031 -0
- package/browser/es5/{ai.props.3.0.2-nightly3.2305-03.js.map → ai.props.3.0.2-nightly3.2305-04.js.map} +1 -1
- package/browser/es5/ai.props.3.0.2-nightly3.2305-04.min.js +6 -0
- package/browser/es5/{ai.props.3.0.2-nightly3.2305-03.min.js.map → ai.props.3.0.2-nightly3.2305-04.min.js.map} +1 -1
- package/browser/es5/ai.props.3.cjs.js +4 -3
- package/browser/es5/ai.props.3.cjs.js.map +1 -1
- package/browser/es5/ai.props.3.cjs.min.js +2 -2
- package/browser/es5/ai.props.3.cjs.min.js.map +1 -1
- package/browser/es5/ai.props.3.gbl.js +3723 -3703
- package/browser/es5/ai.props.3.gbl.js.map +1 -1
- package/browser/es5/ai.props.3.gbl.min.js +2 -2
- package/browser/es5/ai.props.3.gbl.min.js.map +1 -1
- package/browser/es5/ai.props.3.js +3726 -3704
- package/browser/es5/ai.props.3.js.map +1 -1
- package/browser/es5/ai.props.3.min.js +2 -2
- package/browser/es5/ai.props.3.min.js.map +1 -1
- package/dist/es5/applicationinsights-properties-js.js +4 -4
- package/dist/es5/applicationinsights-properties-js.js.map +1 -1
- package/dist/es5/applicationinsights-properties-js.min.js +2 -2
- package/dist/es5/applicationinsights-properties-js.min.js.map +1 -1
- package/dist-es5/Context/Application.js +1 -1
- package/dist-es5/Context/Device.js +1 -1
- package/dist-es5/Context/Internal.js +2 -2
- package/dist-es5/Context/Internal.js.map +1 -1
- package/dist-es5/Context/Location.js +1 -1
- package/dist-es5/Context/Session.js +1 -1
- package/dist-es5/Context/TelemetryTrace.js +1 -1
- package/dist-es5/Context/User.js +1 -1
- package/dist-es5/Interfaces/IPropTelemetryContext.js +1 -1
- package/dist-es5/Interfaces/IPropertiesConfig.js +1 -1
- package/dist-es5/PropertiesPlugin.js +1 -1
- package/dist-es5/TelemetryContext.js +1 -1
- package/dist-es5/__DynamicConstants.js +1 -1
- package/dist-es5/applicationinsights-properties-js.js +1 -1
- package/package.json +3 -3
- package/types/applicationinsights-properties-js.d.ts +1 -1
- package/types/applicationinsights-properties-js.namespaced.d.ts +1 -1
- package/browser/es5/ai.props.3.0.2-nightly3.2305-03.gbl.js +0 -4007
- package/browser/es5/ai.props.3.0.2-nightly3.2305-03.gbl.min.js +0 -6
- package/browser/es5/ai.props.3.0.2-nightly3.2305-03.integrity.json +0 -66
- package/browser/es5/ai.props.3.0.2-nightly3.2305-03.js +0 -4009
- package/browser/es5/ai.props.3.0.2-nightly3.2305-03.min.js +0 -6
|
@@ -0,0 +1,4027 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Application Insights JavaScript SDK - Properties Plugin, 3.0.2-nightly3.2305-04
|
|
3
|
+
* Copyright (c) Microsoft and contributors. All rights reserved.
|
|
4
|
+
*/
|
|
5
|
+
(function (global, factory) {
|
|
6
|
+
var undef = "undefined";
|
|
7
|
+
var nsKey, key, nm, theExports = {}, modName = "es5_ai_props_3_0_2_nightly3_2305_04", msMod="__ms$mod__";
|
|
8
|
+
var mods={}, modDetail=mods[modName]={}, ver="3.0.2-nightly3.2305-04";
|
|
9
|
+
var baseNs=global, nsKey="Microsoft", baseNs=baseNs[nsKey]=(baseNs[nsKey]||{});
|
|
10
|
+
// Versioned namespace "Microsoft.ApplicationInsights3"
|
|
11
|
+
var exportNs=baseNs, nsKey="ApplicationInsights3", exportNs=exportNs[nsKey]=(exportNs[nsKey]||{});
|
|
12
|
+
// Global namespace "Microsoft.ApplicationInsights"
|
|
13
|
+
var destNs=baseNs, nsKey="ApplicationInsights", destNs=destNs[nsKey]=(destNs[nsKey]||{});
|
|
14
|
+
var expNsDetail=(exportNs[msMod]=(exportNs[msMod] || {})), expNameVer=(expNsDetail["v"]=(expNsDetail["v"] || []));
|
|
15
|
+
var destNsDetail=(destNs[msMod]=(destNs[msMod] || {})), destNameVer=(destNsDetail["v"]=(destNsDetail["v"] || []));
|
|
16
|
+
(destNsDetail["o"]=(destNsDetail["o"] || [])).push(mods);
|
|
17
|
+
factory(theExports);
|
|
18
|
+
for(var key in theExports) {
|
|
19
|
+
// Always set the imported value into the "export" versioned namespace (last-write wins)
|
|
20
|
+
nm="x", exportNs[key]=theExports[key], expNameVer[key]=ver;
|
|
21
|
+
// Copy over any named element that is not already present (first-write wins)
|
|
22
|
+
typeof destNs[key]===undef ? (nm="n", destNs[key]=theExports[key]) && (destNameVer[key]=ver) : !destNameVer[key] && (destNameVer[key]="---");
|
|
23
|
+
(modDetail[nm] = (modDetail[nm] || [])).push(key);
|
|
24
|
+
}
|
|
25
|
+
})(this, (function (exports) {
|
|
26
|
+
'use strict';
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
var strShimFunction = "function";
|
|
30
|
+
var strShimObject = "object";
|
|
31
|
+
var strShimUndefined = "undefined";
|
|
32
|
+
var strShimPrototype = "prototype";
|
|
33
|
+
var ObjClass$1 = Object;
|
|
34
|
+
|
|
35
|
+
var UNDEF_VALUE = undefined;
|
|
36
|
+
var EMPTY = "";
|
|
37
|
+
var FUNCTION = "function";
|
|
38
|
+
var NUMBER = "number";
|
|
39
|
+
var OBJECT = "object";
|
|
40
|
+
var PROTOTYPE = "prototype";
|
|
41
|
+
var STRING = "string";
|
|
42
|
+
var UNDEFINED = "undefined";
|
|
43
|
+
var CONSTRUCTOR = "constructor";
|
|
44
|
+
var SYMBOL = "Symbol";
|
|
45
|
+
var POLYFILL_TAG = "_polyfill";
|
|
46
|
+
var INDEX_OF = "indexOf";
|
|
47
|
+
var LENGTH = "length";
|
|
48
|
+
var DONE = "done";
|
|
49
|
+
var VALUE = "value";
|
|
50
|
+
var NAME = "name";
|
|
51
|
+
var SLICE = "slice";
|
|
52
|
+
var ObjClass = Object;
|
|
53
|
+
var ObjProto = ObjClass[PROTOTYPE];
|
|
54
|
+
var StrCls = String;
|
|
55
|
+
var StrProto = StrCls[PROTOTYPE];
|
|
56
|
+
var MathCls = Math;
|
|
57
|
+
var ArrCls = Array;
|
|
58
|
+
var ArrProto = ArrCls[PROTOTYPE];
|
|
59
|
+
|
|
60
|
+
function safeGet(cb, defValue) {
|
|
61
|
+
var result = defValue;
|
|
62
|
+
try {
|
|
63
|
+
result = cb();
|
|
64
|
+
}
|
|
65
|
+
catch (e) {
|
|
66
|
+
}
|
|
67
|
+
return result;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
function _createIs(theType) {
|
|
71
|
+
return function (value) {
|
|
72
|
+
return typeof value === theType;
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
function _createObjIs(theName) {
|
|
76
|
+
var theType = "[object " + theName + "]";
|
|
77
|
+
return function (value) {
|
|
78
|
+
return !!(value && objToString(value) === theType);
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
function objToString(value) {
|
|
82
|
+
return ObjProto.toString.call(value);
|
|
83
|
+
}
|
|
84
|
+
function isUndefined(value) {
|
|
85
|
+
return typeof value === UNDEFINED || value === UNDEFINED;
|
|
86
|
+
}
|
|
87
|
+
function isNullOrUndefined(value) {
|
|
88
|
+
return value === null || isUndefined(value);
|
|
89
|
+
}
|
|
90
|
+
function isStrictNullOrUndefined(value) {
|
|
91
|
+
return value === null || !isDefined(value);
|
|
92
|
+
}
|
|
93
|
+
function isDefined(arg) {
|
|
94
|
+
return !!arg || arg !== UNDEF_VALUE;
|
|
95
|
+
}
|
|
96
|
+
var isString = _createIs(STRING);
|
|
97
|
+
var isFunction = _createIs(FUNCTION);
|
|
98
|
+
function isObject(value) {
|
|
99
|
+
if (!value && isNullOrUndefined(value)) {
|
|
100
|
+
return false;
|
|
101
|
+
}
|
|
102
|
+
return !!value && typeof value === OBJECT;
|
|
103
|
+
}
|
|
104
|
+
var isArray = ArrCls.isArray;
|
|
105
|
+
var isNumber = _createIs(NUMBER);
|
|
106
|
+
var isError = _createObjIs("Error");
|
|
107
|
+
function isTruthy(value) {
|
|
108
|
+
return !(!value || safeGet(function () { return !(value && (0 + value)); }, !value));
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
var objGetOwnPropertyDescriptor = ObjClass.getOwnPropertyDescriptor;
|
|
112
|
+
|
|
113
|
+
function objHasOwnProperty(obj, prop) {
|
|
114
|
+
return obj && ObjProto.hasOwnProperty.call(obj, prop);
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
var objHasOwn = ObjClass["hasOwn"] || polyObjHasOwn;
|
|
118
|
+
function polyObjHasOwn(obj, prop) {
|
|
119
|
+
return objHasOwnProperty(obj, prop) || !!objGetOwnPropertyDescriptor(obj, prop);
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
function objForEachKey(theObject, callbackfn, thisArg) {
|
|
123
|
+
if (theObject && isObject(theObject)) {
|
|
124
|
+
for (var prop in theObject) {
|
|
125
|
+
if (objHasOwn(theObject, prop)) {
|
|
126
|
+
if (callbackfn.call(thisArg || theObject, prop, theObject[prop]) === -1) {
|
|
127
|
+
break;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
function _createKeyValueMap(values, keyType, valueType, completeFn) {
|
|
135
|
+
var theMap = {};
|
|
136
|
+
objForEachKey(values, function (key, value) {
|
|
137
|
+
theMap[key] = keyType ? value : key;
|
|
138
|
+
theMap[value] = valueType ? value : key;
|
|
139
|
+
});
|
|
140
|
+
return completeFn(theMap);
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
function throwTypeError(message) {
|
|
144
|
+
throw new TypeError(message);
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
var _objFreeze = ObjClass["freeze"];
|
|
148
|
+
var _doNothing = function (value) { return value; };
|
|
149
|
+
function objKeys(value) {
|
|
150
|
+
if (!isObject(value) || value === null) {
|
|
151
|
+
throwTypeError("objKeys called on non-object");
|
|
152
|
+
}
|
|
153
|
+
return ObjClass.keys(value);
|
|
154
|
+
}
|
|
155
|
+
function objDeepFreeze(value) {
|
|
156
|
+
if (_objFreeze) {
|
|
157
|
+
objForEachKey(value, function (key, value) {
|
|
158
|
+
if (isArray(value) || isObject(value)) {
|
|
159
|
+
_objFreeze(value);
|
|
160
|
+
}
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
return objFreeze(value);
|
|
164
|
+
}
|
|
165
|
+
var objFreeze = _objFreeze || _doNothing;
|
|
166
|
+
var objGetPrototypeOf = ObjClass["getPrototypeOf"] || _doNothing;
|
|
167
|
+
|
|
168
|
+
function createEnum(values) {
|
|
169
|
+
return _createKeyValueMap(values, 1 , 0 , objDeepFreeze);
|
|
170
|
+
}
|
|
171
|
+
function createEnumKeyMap(values) {
|
|
172
|
+
return _createKeyValueMap(values, 0 , 0 , objDeepFreeze);
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
var _wellKnownSymbolMap = createEnumKeyMap({
|
|
176
|
+
asyncIterator: 0 ,
|
|
177
|
+
hasInstance: 1 ,
|
|
178
|
+
isConcatSpreadable: 2 ,
|
|
179
|
+
iterator: 3 ,
|
|
180
|
+
match: 4 ,
|
|
181
|
+
matchAll: 5 ,
|
|
182
|
+
replace: 6 ,
|
|
183
|
+
search: 7 ,
|
|
184
|
+
species: 8 ,
|
|
185
|
+
split: 9 ,
|
|
186
|
+
toPrimitive: 10 ,
|
|
187
|
+
toStringTag: 11 ,
|
|
188
|
+
unscopables: 12
|
|
189
|
+
});
|
|
190
|
+
|
|
191
|
+
var asString = StrCls;
|
|
192
|
+
|
|
193
|
+
var GLOBAL_CONFIG_KEY = "__tsUtils$gblCfg";
|
|
194
|
+
var _globalCfg;
|
|
195
|
+
function _getGlobalValue() {
|
|
196
|
+
var result;
|
|
197
|
+
if (typeof globalThis !== UNDEFINED) {
|
|
198
|
+
result = globalThis;
|
|
199
|
+
}
|
|
200
|
+
if (!result && typeof self !== UNDEFINED) {
|
|
201
|
+
result = self;
|
|
202
|
+
}
|
|
203
|
+
if (!result && typeof window !== UNDEFINED) {
|
|
204
|
+
result = window;
|
|
205
|
+
}
|
|
206
|
+
if (!result && typeof global !== UNDEFINED) {
|
|
207
|
+
result = global;
|
|
208
|
+
}
|
|
209
|
+
return result;
|
|
210
|
+
}
|
|
211
|
+
function _getGlobalConfig() {
|
|
212
|
+
if (!_globalCfg) {
|
|
213
|
+
var gbl = _getGlobalValue() || {};
|
|
214
|
+
_globalCfg = gbl[GLOBAL_CONFIG_KEY] = gbl[GLOBAL_CONFIG_KEY] || {};
|
|
215
|
+
}
|
|
216
|
+
return _globalCfg;
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
function dumpObj(object, format) {
|
|
220
|
+
var propertyValueDump = EMPTY;
|
|
221
|
+
if (isError(object)) {
|
|
222
|
+
propertyValueDump = "{ stack: '" + object.stack + "', message: '" + object.message + "', name: '" + object.name + "'";
|
|
223
|
+
}
|
|
224
|
+
else {
|
|
225
|
+
try {
|
|
226
|
+
propertyValueDump = JSON.stringify(object, null, format ? (isNumber(format) ? format : 4) : UNDEF_VALUE);
|
|
227
|
+
}
|
|
228
|
+
catch (e) {
|
|
229
|
+
propertyValueDump = " - " + dumpObj(e, format);
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
return objToString(object) + ": " + propertyValueDump;
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
function _unwrapFunction(funcName, target, polyFunc) {
|
|
236
|
+
return function (thisArg) {
|
|
237
|
+
var theFunc = (thisArg && thisArg[funcName]) || (target && target[funcName]);
|
|
238
|
+
if (theFunc || polyFunc) {
|
|
239
|
+
var theArgs = arguments;
|
|
240
|
+
return (theFunc || polyFunc).apply(thisArg, theFunc ? ArrProto[SLICE].call(theArgs, 1) : theArgs);
|
|
241
|
+
}
|
|
242
|
+
throwTypeError("'" + asString(funcName) + "' not defined for " + dumpObj(thisArg));
|
|
243
|
+
};
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
var mathMax = MathCls.max;
|
|
247
|
+
|
|
248
|
+
var strSlice = _unwrapFunction(SLICE, StrProto);
|
|
249
|
+
|
|
250
|
+
var strSubstring = _unwrapFunction("substring", StrProto);
|
|
251
|
+
var strSubstr = _unwrapFunction("substr", StrProto, polyStrSubstr);
|
|
252
|
+
function polyStrSubstr(value, start, length) {
|
|
253
|
+
if (isNullOrUndefined(value)) {
|
|
254
|
+
throwTypeError("'polyStrSubstr called with invalid " + dumpObj(value));
|
|
255
|
+
}
|
|
256
|
+
if (length < 0) {
|
|
257
|
+
return EMPTY;
|
|
258
|
+
}
|
|
259
|
+
start = start || 0;
|
|
260
|
+
if (start < 0) {
|
|
261
|
+
start = mathMax(start + value[LENGTH], 0);
|
|
262
|
+
}
|
|
263
|
+
if (isUndefined(length)) {
|
|
264
|
+
return strSlice(value, start);
|
|
265
|
+
}
|
|
266
|
+
return strSlice(value, start, start + length);
|
|
267
|
+
}
|
|
268
|
+
function strLeft(value, count) {
|
|
269
|
+
return strSubstring(value, 0, count);
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
var _polySymbols;
|
|
273
|
+
function _globalSymbolRegistry() {
|
|
274
|
+
if (!_polySymbols) {
|
|
275
|
+
var gblCfg = _getGlobalConfig();
|
|
276
|
+
_polySymbols = gblCfg.gblSym = gblCfg.gblSym || { k: {}, s: {} };
|
|
277
|
+
}
|
|
278
|
+
return _polySymbols;
|
|
279
|
+
}
|
|
280
|
+
var _wellKnownSymbolCache = {};
|
|
281
|
+
function polyNewSymbol(description) {
|
|
282
|
+
var theSymbol = {
|
|
283
|
+
description: asString(description),
|
|
284
|
+
toString: function () { return SYMBOL + "(" + description + ")"; }
|
|
285
|
+
};
|
|
286
|
+
theSymbol[POLYFILL_TAG] = true;
|
|
287
|
+
return theSymbol;
|
|
288
|
+
}
|
|
289
|
+
function polySymbolFor(key) {
|
|
290
|
+
var registry = _globalSymbolRegistry();
|
|
291
|
+
if (!objHasOwn(registry, key)) {
|
|
292
|
+
var newSymbol = polyNewSymbol(key);
|
|
293
|
+
registry.k[key] = newSymbol;
|
|
294
|
+
registry.s[newSymbol] = asString(key);
|
|
295
|
+
}
|
|
296
|
+
return registry.k[key];
|
|
297
|
+
}
|
|
298
|
+
function polyGetKnownSymbol(name) {
|
|
299
|
+
var result;
|
|
300
|
+
var knownName = _wellKnownSymbolMap[name];
|
|
301
|
+
if (knownName) {
|
|
302
|
+
result = _wellKnownSymbolCache[knownName] = _wellKnownSymbolCache[knownName] || polyNewSymbol(SYMBOL + "." + knownName);
|
|
303
|
+
}
|
|
304
|
+
return result;
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
var propMap = {
|
|
308
|
+
e: "enumerable",
|
|
309
|
+
c: "configurable",
|
|
310
|
+
v: VALUE,
|
|
311
|
+
w: "writable",
|
|
312
|
+
g: "get",
|
|
313
|
+
s: "set"
|
|
314
|
+
};
|
|
315
|
+
function _createProp(value) {
|
|
316
|
+
var prop = {};
|
|
317
|
+
prop[propMap["c"]] = true;
|
|
318
|
+
prop[propMap["e"]] = true;
|
|
319
|
+
if (value.l) {
|
|
320
|
+
prop.get = function () { return value.l.v; };
|
|
321
|
+
var desc = objGetOwnPropertyDescriptor(value.l, "v");
|
|
322
|
+
if (desc && desc.set) {
|
|
323
|
+
prop.set = function (newValue) {
|
|
324
|
+
value.l.v = newValue;
|
|
325
|
+
};
|
|
326
|
+
}
|
|
327
|
+
}
|
|
328
|
+
objForEachKey(value, function (key, value) {
|
|
329
|
+
prop[propMap[key]] = isUndefined(value) ? prop[propMap[key]] : value;
|
|
330
|
+
});
|
|
331
|
+
return prop;
|
|
332
|
+
}
|
|
333
|
+
var objDefineProp = ObjClass["defineProperty"];
|
|
334
|
+
function objDefine(target, key, propDesc) {
|
|
335
|
+
return objDefineProp(target, key, _createProp(propDesc));
|
|
336
|
+
}
|
|
337
|
+
|
|
338
|
+
var _globalLazyTestHooks;
|
|
339
|
+
var _fetchLazyTestHooks = function () {
|
|
340
|
+
_globalLazyTestHooks = _getGlobalConfig();
|
|
341
|
+
_fetchLazyTestHooks = null;
|
|
342
|
+
};
|
|
343
|
+
function getLazy(cb) {
|
|
344
|
+
var lazyValue = {};
|
|
345
|
+
_fetchLazyTestHooks && _fetchLazyTestHooks();
|
|
346
|
+
lazyValue.b = _globalLazyTestHooks.lzy;
|
|
347
|
+
objDefineProp(lazyValue, "v", {
|
|
348
|
+
configurable: true,
|
|
349
|
+
get: function () {
|
|
350
|
+
var result = cb();
|
|
351
|
+
if (!_globalLazyTestHooks.lzy) {
|
|
352
|
+
objDefineProp(lazyValue, "v", {
|
|
353
|
+
value: result
|
|
354
|
+
});
|
|
355
|
+
if (lazyValue.b) {
|
|
356
|
+
delete lazyValue.b;
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
if (_globalLazyTestHooks.lzy && lazyValue.b !== _globalLazyTestHooks.lzy) {
|
|
360
|
+
lazyValue.b = _globalLazyTestHooks.lzy;
|
|
361
|
+
}
|
|
362
|
+
return result;
|
|
363
|
+
}
|
|
364
|
+
});
|
|
365
|
+
return lazyValue;
|
|
366
|
+
}
|
|
367
|
+
|
|
368
|
+
function safeGetLazy(cb, defValue) {
|
|
369
|
+
return getLazy(function () { return safeGet(cb, defValue); });
|
|
370
|
+
}
|
|
371
|
+
|
|
372
|
+
var WINDOW = "window";
|
|
373
|
+
var _cachedGlobal;
|
|
374
|
+
var _cachedWindow;
|
|
375
|
+
var _cachedDocument;
|
|
376
|
+
var _cachedNavigator;
|
|
377
|
+
function lazySafeGetInst(name) {
|
|
378
|
+
return safeGetLazy(function () { return getInst(name) || UNDEF_VALUE; }, UNDEF_VALUE);
|
|
379
|
+
}
|
|
380
|
+
function getGlobal(useCached) {
|
|
381
|
+
(!_cachedGlobal || useCached === false || (_globalLazyTestHooks.lzy && !_cachedGlobal.b)) && (_cachedGlobal = safeGetLazy(_getGlobalValue, null));
|
|
382
|
+
return _cachedGlobal.v;
|
|
383
|
+
}
|
|
384
|
+
function getInst(name, useCached) {
|
|
385
|
+
var gbl = getGlobal(useCached);
|
|
386
|
+
if (gbl && gbl[name]) {
|
|
387
|
+
return gbl[name];
|
|
388
|
+
}
|
|
389
|
+
if (name === WINDOW && _cachedWindow) {
|
|
390
|
+
return _cachedWindow.v;
|
|
391
|
+
}
|
|
392
|
+
return null;
|
|
393
|
+
}
|
|
394
|
+
function getDocument() {
|
|
395
|
+
(!_cachedDocument || (_globalLazyTestHooks.lzy && !_cachedDocument.b)) && (_cachedDocument = lazySafeGetInst("document"));
|
|
396
|
+
return _cachedDocument.v;
|
|
397
|
+
}
|
|
398
|
+
function hasWindow() {
|
|
399
|
+
return !!getWindow();
|
|
400
|
+
}
|
|
401
|
+
function getWindow() {
|
|
402
|
+
(!_cachedWindow || (_globalLazyTestHooks.lzy && !_cachedWindow.b)) && (_cachedWindow = lazySafeGetInst(WINDOW));
|
|
403
|
+
return _cachedWindow.v;
|
|
404
|
+
}
|
|
405
|
+
function getNavigator() {
|
|
406
|
+
(!_cachedNavigator || (_globalLazyTestHooks.lzy && !_cachedNavigator.b)) && (_cachedNavigator = lazySafeGetInst("navigator"));
|
|
407
|
+
return _cachedNavigator.v;
|
|
408
|
+
}
|
|
409
|
+
|
|
410
|
+
var _symbol;
|
|
411
|
+
var _symbolFor;
|
|
412
|
+
var _symbolKeyFor;
|
|
413
|
+
function _getSymbolValue(name) {
|
|
414
|
+
return safeGetLazy(function () {
|
|
415
|
+
return (_symbol.v ? _symbol[name] : UNDEF_VALUE);
|
|
416
|
+
}, UNDEF_VALUE);
|
|
417
|
+
}
|
|
418
|
+
function getSymbol() {
|
|
419
|
+
var resetCache = !_symbol || (_globalLazyTestHooks && _globalLazyTestHooks.lzy && !_symbol.b);
|
|
420
|
+
resetCache && (_symbol = lazySafeGetInst(SYMBOL));
|
|
421
|
+
(!_symbolFor || resetCache) && (_symbolFor = _getSymbolValue("for"));
|
|
422
|
+
(!_symbolKeyFor || resetCache) && (_symbolKeyFor = _getSymbolValue("keyFor"));
|
|
423
|
+
return _symbol.v;
|
|
424
|
+
}
|
|
425
|
+
function getKnownSymbol(name, noPoly) {
|
|
426
|
+
var knownName = _wellKnownSymbolMap[name];
|
|
427
|
+
(!_symbol || (_globalLazyTestHooks.lzy && !_symbol.b)) && getSymbol();
|
|
428
|
+
return _symbol.v ? _symbol.v[knownName || name] : (!noPoly ? polyGetKnownSymbol(name) : UNDEF_VALUE);
|
|
429
|
+
}
|
|
430
|
+
function newSymbol(description, noPoly) {
|
|
431
|
+
(!_symbol || (_globalLazyTestHooks.lzy && !_symbol.b)) && getSymbol();
|
|
432
|
+
return _symbol.v ? _symbol.v(description) : (!noPoly ? polyNewSymbol(description) : null);
|
|
433
|
+
}
|
|
434
|
+
function symbolFor(key) {
|
|
435
|
+
(!_symbolFor || (_globalLazyTestHooks.lzy && !_symbol.b)) && getSymbol();
|
|
436
|
+
return (_symbolFor.v || polySymbolFor)(key);
|
|
437
|
+
}
|
|
438
|
+
|
|
439
|
+
function isIterator(value) {
|
|
440
|
+
return !!value && isFunction(value.next);
|
|
441
|
+
}
|
|
442
|
+
function isIterable(value) {
|
|
443
|
+
return !isStrictNullOrUndefined(value) && isFunction(value[getKnownSymbol(3 )]);
|
|
444
|
+
}
|
|
445
|
+
|
|
446
|
+
function iterForOf(iter, callbackfn, thisArg) {
|
|
447
|
+
if (iter) {
|
|
448
|
+
if (!isIterator(iter)) {
|
|
449
|
+
var itSymbol = getKnownSymbol(3 );
|
|
450
|
+
iter = iter[itSymbol] ? iter[itSymbol]() : null;
|
|
451
|
+
}
|
|
452
|
+
if (isIterator(iter)) {
|
|
453
|
+
try {
|
|
454
|
+
var count = 0;
|
|
455
|
+
var value = iter.next();
|
|
456
|
+
while (!value[DONE]) {
|
|
457
|
+
if (callbackfn.call(thisArg || iter, value[VALUE], count, iter) === -1) {
|
|
458
|
+
break;
|
|
459
|
+
}
|
|
460
|
+
count++;
|
|
461
|
+
value = iter.next();
|
|
462
|
+
}
|
|
463
|
+
iter.return && iter.return(value);
|
|
464
|
+
}
|
|
465
|
+
catch (e) {
|
|
466
|
+
iter.throw && iter.throw(e);
|
|
467
|
+
}
|
|
468
|
+
}
|
|
469
|
+
}
|
|
470
|
+
}
|
|
471
|
+
|
|
472
|
+
function arrAppend(target, elms) {
|
|
473
|
+
if (!isUndefined(elms) && target) {
|
|
474
|
+
if (isArray(elms)) {
|
|
475
|
+
target.push.apply(target, elms);
|
|
476
|
+
}
|
|
477
|
+
else if (isIterator(elms) || isIterable(elms)) {
|
|
478
|
+
iterForOf(elms, function (elm) {
|
|
479
|
+
target.push(elm);
|
|
480
|
+
});
|
|
481
|
+
}
|
|
482
|
+
else {
|
|
483
|
+
target.push(elms);
|
|
484
|
+
}
|
|
485
|
+
}
|
|
486
|
+
return target;
|
|
487
|
+
}
|
|
488
|
+
|
|
489
|
+
function arrForEach(theArray, callbackfn, thisArg) {
|
|
490
|
+
if (theArray) {
|
|
491
|
+
var len = theArray[LENGTH] >>> 0;
|
|
492
|
+
for (var idx = 0; idx < len; idx++) {
|
|
493
|
+
if (idx in theArray) {
|
|
494
|
+
if (callbackfn.call(thisArg || theArray, theArray[idx], idx, theArray) === -1) {
|
|
495
|
+
break;
|
|
496
|
+
}
|
|
497
|
+
}
|
|
498
|
+
}
|
|
499
|
+
}
|
|
500
|
+
}
|
|
501
|
+
|
|
502
|
+
var arrIndexOf = _unwrapFunction(INDEX_OF, ArrProto);
|
|
503
|
+
|
|
504
|
+
var arrSlice = _unwrapFunction(SLICE, ArrProto);
|
|
505
|
+
|
|
506
|
+
function objSetPrototypeOf(obj, proto) {
|
|
507
|
+
var fn = ObjClass["setPrototypeOf"] ||
|
|
508
|
+
({ __proto__: [] } instanceof Array && function (d, b) {
|
|
509
|
+
d.__proto__ = b;
|
|
510
|
+
}) ||
|
|
511
|
+
function (d, b) {
|
|
512
|
+
objForEachKey(b, function (key, value) { return d[key] = value; });
|
|
513
|
+
};
|
|
514
|
+
return fn(obj, proto);
|
|
515
|
+
}
|
|
516
|
+
|
|
517
|
+
function _createCustomError(name, d, baseClass) {
|
|
518
|
+
objSetPrototypeOf(d, baseClass);
|
|
519
|
+
function __() {
|
|
520
|
+
this.constructor = d;
|
|
521
|
+
this[NAME] = name;
|
|
522
|
+
}
|
|
523
|
+
__[PROTOTYPE] = baseClass[PROTOTYPE];
|
|
524
|
+
d[PROTOTYPE] = new __();
|
|
525
|
+
return d;
|
|
526
|
+
}
|
|
527
|
+
var _safeSetName = function (baseClass, name) {
|
|
528
|
+
try {
|
|
529
|
+
baseClass[PROTOTYPE][NAME] = name;
|
|
530
|
+
}
|
|
531
|
+
catch (e) {
|
|
532
|
+
}
|
|
533
|
+
};
|
|
534
|
+
function createCustomError(name, constructCb) {
|
|
535
|
+
var baseClass = Error;
|
|
536
|
+
var orgName = baseClass[PROTOTYPE][NAME];
|
|
537
|
+
var customError = _createCustomError(name, function () {
|
|
538
|
+
var _this = this;
|
|
539
|
+
try {
|
|
540
|
+
_safeSetName(baseClass, name);
|
|
541
|
+
_this = baseClass.apply(_this, arguments) || _this;
|
|
542
|
+
_this[NAME] = name;
|
|
543
|
+
constructCb && constructCb(_this, arguments);
|
|
544
|
+
}
|
|
545
|
+
finally {
|
|
546
|
+
_safeSetName(baseClass, orgName);
|
|
547
|
+
}
|
|
548
|
+
return _this;
|
|
549
|
+
}, baseClass);
|
|
550
|
+
return customError;
|
|
551
|
+
}
|
|
552
|
+
|
|
553
|
+
function utcNow() {
|
|
554
|
+
return (Date.now || polyUtcNow)();
|
|
555
|
+
}
|
|
556
|
+
function polyUtcNow() {
|
|
557
|
+
return new Date().getTime();
|
|
558
|
+
}
|
|
559
|
+
|
|
560
|
+
function _createTrimFn(exp) {
|
|
561
|
+
return function _doTrim(value) {
|
|
562
|
+
if (isNullOrUndefined(value)) {
|
|
563
|
+
throwTypeError("strTrim called [" + dumpObj(value) + "]");
|
|
564
|
+
}
|
|
565
|
+
if (value && value.replace) {
|
|
566
|
+
value = value.replace(exp, EMPTY);
|
|
567
|
+
}
|
|
568
|
+
return value;
|
|
569
|
+
};
|
|
570
|
+
}
|
|
571
|
+
var polyStrTrim = _createTrimFn(/^\s+|(?=\s)\s+$/g);
|
|
572
|
+
|
|
573
|
+
var strTrim = _unwrapFunction("trim", StrProto, polyStrTrim);
|
|
574
|
+
|
|
575
|
+
var _fnToString;
|
|
576
|
+
var _objCtrFnString;
|
|
577
|
+
var _gblWindow;
|
|
578
|
+
function isPlainObject(value) {
|
|
579
|
+
if (!value || typeof value !== OBJECT) {
|
|
580
|
+
return false;
|
|
581
|
+
}
|
|
582
|
+
if (!_gblWindow) {
|
|
583
|
+
_gblWindow = hasWindow() ? getWindow() : true;
|
|
584
|
+
}
|
|
585
|
+
var result = false;
|
|
586
|
+
if (value !== _gblWindow) {
|
|
587
|
+
if (!_objCtrFnString) {
|
|
588
|
+
_fnToString = Function[PROTOTYPE].toString;
|
|
589
|
+
_objCtrFnString = _fnToString.call(ObjClass);
|
|
590
|
+
}
|
|
591
|
+
try {
|
|
592
|
+
var proto = objGetPrototypeOf(value);
|
|
593
|
+
result = !proto;
|
|
594
|
+
if (!result) {
|
|
595
|
+
if (objHasOwnProperty(proto, CONSTRUCTOR)) {
|
|
596
|
+
proto = proto[CONSTRUCTOR];
|
|
597
|
+
}
|
|
598
|
+
result = proto && typeof proto === FUNCTION && _fnToString.call(proto) === _objCtrFnString;
|
|
599
|
+
}
|
|
600
|
+
}
|
|
601
|
+
catch (ex) {
|
|
602
|
+
}
|
|
603
|
+
}
|
|
604
|
+
return result;
|
|
605
|
+
}
|
|
606
|
+
|
|
607
|
+
var _objCreate = ObjClass["create"];
|
|
608
|
+
var objCreate = _objCreate || polyObjCreate;
|
|
609
|
+
function polyObjCreate(obj) {
|
|
610
|
+
if (!obj) {
|
|
611
|
+
return {};
|
|
612
|
+
}
|
|
613
|
+
var type = typeof obj;
|
|
614
|
+
if (type !== OBJECT && type !== FUNCTION) {
|
|
615
|
+
throw new TypeError("Prototype must be an Object or function: " + dumpObj(obj));
|
|
616
|
+
}
|
|
617
|
+
function tempFunc() { }
|
|
618
|
+
tempFunc[PROTOTYPE] = obj;
|
|
619
|
+
return new tempFunc();
|
|
620
|
+
}
|
|
621
|
+
|
|
622
|
+
var strEndsWith = _unwrapFunction("endsWith", StrProto, polyStrEndsWith);
|
|
623
|
+
function polyStrEndsWith(value, searchString, length) {
|
|
624
|
+
if (!isString(value)) {
|
|
625
|
+
throwTypeError("'" + dumpObj(value) + "' is not a string");
|
|
626
|
+
}
|
|
627
|
+
var searchValue = isString(searchString) ? searchString : asString(searchString);
|
|
628
|
+
var chkLen = searchValue[LENGTH];
|
|
629
|
+
var len = value[LENGTH];
|
|
630
|
+
var end = !isUndefined(length) && length < len ? length : len;
|
|
631
|
+
return strSubstring(value, end - chkLen, end) === searchValue;
|
|
632
|
+
}
|
|
633
|
+
|
|
634
|
+
var strIndexOf = _unwrapFunction(INDEX_OF, StrProto);
|
|
635
|
+
|
|
636
|
+
var REF = "ref";
|
|
637
|
+
var UNREF = "un" + REF;
|
|
638
|
+
var HAS_REF = "hasRef";
|
|
639
|
+
var ENABLED = "enabled";
|
|
640
|
+
function _createTimerHandler(startTimer, refreshFn, cancelFn) {
|
|
641
|
+
var _a;
|
|
642
|
+
var ref = true;
|
|
643
|
+
var timerId = startTimer ? refreshFn(null) : null;
|
|
644
|
+
var theTimerHandler;
|
|
645
|
+
var _unref = function () {
|
|
646
|
+
ref = false;
|
|
647
|
+
timerId && timerId[UNREF] && timerId[UNREF]();
|
|
648
|
+
return theTimerHandler;
|
|
649
|
+
};
|
|
650
|
+
var _ref = function () {
|
|
651
|
+
ref = true;
|
|
652
|
+
timerId && timerId[REF] && timerId[REF]();
|
|
653
|
+
return theTimerHandler;
|
|
654
|
+
};
|
|
655
|
+
var _hasRef = function () {
|
|
656
|
+
if (timerId && timerId[HAS_REF]) {
|
|
657
|
+
return timerId[HAS_REF]();
|
|
658
|
+
}
|
|
659
|
+
return ref;
|
|
660
|
+
};
|
|
661
|
+
var _refresh = function () {
|
|
662
|
+
timerId = refreshFn(timerId);
|
|
663
|
+
if (!ref) {
|
|
664
|
+
_unref();
|
|
665
|
+
}
|
|
666
|
+
return theTimerHandler;
|
|
667
|
+
};
|
|
668
|
+
var _cancel = function () {
|
|
669
|
+
timerId && cancelFn(timerId);
|
|
670
|
+
timerId = null;
|
|
671
|
+
};
|
|
672
|
+
var _setEnabled = function (value) {
|
|
673
|
+
!value && timerId && _cancel();
|
|
674
|
+
value && !timerId && _refresh();
|
|
675
|
+
};
|
|
676
|
+
theTimerHandler = (_a = {
|
|
677
|
+
cancel: _cancel,
|
|
678
|
+
refresh: _refresh
|
|
679
|
+
},
|
|
680
|
+
_a[HAS_REF] = _hasRef,
|
|
681
|
+
_a[REF] = _ref,
|
|
682
|
+
_a[UNREF] = _unref,
|
|
683
|
+
_a[ENABLED] = false,
|
|
684
|
+
_a);
|
|
685
|
+
objDefineProp(theTimerHandler, ENABLED, {
|
|
686
|
+
get: function () { return !!timerId; },
|
|
687
|
+
set: _setEnabled
|
|
688
|
+
});
|
|
689
|
+
return {
|
|
690
|
+
h: theTimerHandler,
|
|
691
|
+
dn: function () {
|
|
692
|
+
timerId = null;
|
|
693
|
+
}
|
|
694
|
+
};
|
|
695
|
+
}
|
|
696
|
+
|
|
697
|
+
function _createTimeoutWith(self, startTimer, overrideFn, theArgs) {
|
|
698
|
+
var isArr = isArray(overrideFn);
|
|
699
|
+
var len = isArr ? overrideFn.length : 0;
|
|
700
|
+
var setFn = (len > 0 ? overrideFn[0] : (!isArr ? overrideFn : UNDEF_VALUE)) || setTimeout;
|
|
701
|
+
var clearFn = (len > 1 ? overrideFn[1] : UNDEF_VALUE) || clearTimeout;
|
|
702
|
+
var timerFn = theArgs[0];
|
|
703
|
+
theArgs[0] = function () {
|
|
704
|
+
handler.dn();
|
|
705
|
+
timerFn.apply(self, arguments);
|
|
706
|
+
};
|
|
707
|
+
var handler = _createTimerHandler(startTimer, function (timerId) {
|
|
708
|
+
if (timerId) {
|
|
709
|
+
if (timerId.refresh) {
|
|
710
|
+
timerId.refresh();
|
|
711
|
+
return timerId;
|
|
712
|
+
}
|
|
713
|
+
clearFn.call(self, timerId);
|
|
714
|
+
}
|
|
715
|
+
return setFn.apply(self, theArgs);
|
|
716
|
+
}, function (timerId) {
|
|
717
|
+
clearFn.call(self, timerId);
|
|
718
|
+
});
|
|
719
|
+
return handler.h;
|
|
720
|
+
}
|
|
721
|
+
function scheduleTimeout(callback, timeout) {
|
|
722
|
+
return _createTimeoutWith(this, true, UNDEF_VALUE, arrSlice(arguments));
|
|
723
|
+
}
|
|
724
|
+
|
|
725
|
+
(getGlobal() || {})["Symbol"];
|
|
726
|
+
(getGlobal() || {})["Reflect"];
|
|
727
|
+
var strHasOwnProperty = "hasOwnProperty";
|
|
728
|
+
var extendStaticsFn = function (d, b) {
|
|
729
|
+
extendStaticsFn = ObjClass$1["setPrototypeOf"] ||
|
|
730
|
+
({ __proto__: [] } instanceof Array && function (d, b) {
|
|
731
|
+
d.__proto__ = b;
|
|
732
|
+
}) ||
|
|
733
|
+
function (d, b) {
|
|
734
|
+
for (var p in b) {
|
|
735
|
+
if (b[strHasOwnProperty](p)) {
|
|
736
|
+
d[p] = b[p];
|
|
737
|
+
}
|
|
738
|
+
}
|
|
739
|
+
};
|
|
740
|
+
return extendStaticsFn(d, b);
|
|
741
|
+
};
|
|
742
|
+
function __extendsFn(d, b) {
|
|
743
|
+
if (typeof b !== strShimFunction && b !== null) {
|
|
744
|
+
throwTypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
745
|
+
}
|
|
746
|
+
extendStaticsFn(d, b);
|
|
747
|
+
function __() {
|
|
748
|
+
this.constructor = d;
|
|
749
|
+
}
|
|
750
|
+
d[strShimPrototype] = b === null ? objCreate(b) : (__[strShimPrototype] = b[strShimPrototype], new __());
|
|
751
|
+
}
|
|
752
|
+
|
|
753
|
+
var _a$3;
|
|
754
|
+
var Constructor = 'constructor';
|
|
755
|
+
var Prototype = 'prototype';
|
|
756
|
+
var strFunction = 'function';
|
|
757
|
+
var DynInstFuncTable = '_dynInstFuncs';
|
|
758
|
+
var DynProxyTag = '_isDynProxy';
|
|
759
|
+
var DynClassName = '_dynClass';
|
|
760
|
+
var DynClassNamePrefix = '_dynCls$';
|
|
761
|
+
var DynInstChkTag = '_dynInstChk';
|
|
762
|
+
var DynAllowInstChkTag = DynInstChkTag;
|
|
763
|
+
var DynProtoDefaultOptions = '_dfOpts';
|
|
764
|
+
var UnknownValue = '_unknown_';
|
|
765
|
+
var str__Proto = "__proto__";
|
|
766
|
+
var DynProtoBaseProto = "_dyn" + str__Proto;
|
|
767
|
+
var DynProtoGlobalSettings = "__dynProto$Gbl";
|
|
768
|
+
var DynProtoCurrent = "_dynInstProto";
|
|
769
|
+
var strUseBaseInst = 'useBaseInst';
|
|
770
|
+
var strSetInstFuncs = 'setInstFuncs';
|
|
771
|
+
var Obj = Object;
|
|
772
|
+
var _objGetPrototypeOf = Obj["getPrototypeOf"];
|
|
773
|
+
var _objGetOwnProps = Obj["getOwnPropertyNames"];
|
|
774
|
+
var _gbl = getGlobal();
|
|
775
|
+
var _gblInst = _gbl[DynProtoGlobalSettings] || (_gbl[DynProtoGlobalSettings] = {
|
|
776
|
+
o: (_a$3 = {},
|
|
777
|
+
_a$3[strSetInstFuncs] = true,
|
|
778
|
+
_a$3[strUseBaseInst] = true,
|
|
779
|
+
_a$3),
|
|
780
|
+
n: 1000
|
|
781
|
+
});
|
|
782
|
+
function _isObjectOrArrayPrototype(target) {
|
|
783
|
+
return target && (target === Obj[Prototype] || target === Array[Prototype]);
|
|
784
|
+
}
|
|
785
|
+
function _isObjectArrayOrFunctionPrototype(target) {
|
|
786
|
+
return _isObjectOrArrayPrototype(target) || target === Function[Prototype];
|
|
787
|
+
}
|
|
788
|
+
function _getObjProto(target) {
|
|
789
|
+
var newProto;
|
|
790
|
+
if (target) {
|
|
791
|
+
if (_objGetPrototypeOf) {
|
|
792
|
+
return _objGetPrototypeOf(target);
|
|
793
|
+
}
|
|
794
|
+
var curProto = target[str__Proto] || target[Prototype] || (target[Constructor] ? target[Constructor][Prototype] : null);
|
|
795
|
+
newProto = target[DynProtoBaseProto] || curProto;
|
|
796
|
+
if (!objHasOwnProperty(target, DynProtoBaseProto)) {
|
|
797
|
+
delete target[DynProtoCurrent];
|
|
798
|
+
newProto = target[DynProtoBaseProto] = target[DynProtoCurrent] || target[DynProtoBaseProto];
|
|
799
|
+
target[DynProtoCurrent] = curProto;
|
|
800
|
+
}
|
|
801
|
+
}
|
|
802
|
+
return newProto;
|
|
803
|
+
}
|
|
804
|
+
function _forEachProp(target, func) {
|
|
805
|
+
var props = [];
|
|
806
|
+
if (_objGetOwnProps) {
|
|
807
|
+
props = _objGetOwnProps(target);
|
|
808
|
+
}
|
|
809
|
+
else {
|
|
810
|
+
for (var name_1 in target) {
|
|
811
|
+
if (typeof name_1 === "string" && objHasOwnProperty(target, name_1)) {
|
|
812
|
+
props.push(name_1);
|
|
813
|
+
}
|
|
814
|
+
}
|
|
815
|
+
}
|
|
816
|
+
if (props && props.length > 0) {
|
|
817
|
+
for (var lp = 0; lp < props.length; lp++) {
|
|
818
|
+
func(props[lp]);
|
|
819
|
+
}
|
|
820
|
+
}
|
|
821
|
+
}
|
|
822
|
+
function _isDynamicCandidate(target, funcName, skipOwn) {
|
|
823
|
+
return (funcName !== Constructor && typeof target[funcName] === strFunction && (skipOwn || objHasOwnProperty(target, funcName)));
|
|
824
|
+
}
|
|
825
|
+
function _throwTypeError(message) {
|
|
826
|
+
throwTypeError("DynamicProto: " + message);
|
|
827
|
+
}
|
|
828
|
+
function _getInstanceFuncs(thisTarget) {
|
|
829
|
+
var instFuncs = {};
|
|
830
|
+
_forEachProp(thisTarget, function (name) {
|
|
831
|
+
if (!instFuncs[name] && _isDynamicCandidate(thisTarget, name, false)) {
|
|
832
|
+
instFuncs[name] = thisTarget[name];
|
|
833
|
+
}
|
|
834
|
+
});
|
|
835
|
+
return instFuncs;
|
|
836
|
+
}
|
|
837
|
+
function _hasVisited(values, value) {
|
|
838
|
+
for (var lp = values.length - 1; lp >= 0; lp--) {
|
|
839
|
+
if (values[lp] === value) {
|
|
840
|
+
return true;
|
|
841
|
+
}
|
|
842
|
+
}
|
|
843
|
+
return false;
|
|
844
|
+
}
|
|
845
|
+
function _getBaseFuncs(classProto, thisTarget, instFuncs, useBaseInst) {
|
|
846
|
+
function _instFuncProxy(target, funcHost, funcName) {
|
|
847
|
+
var theFunc = funcHost[funcName];
|
|
848
|
+
if (theFunc[DynProxyTag] && useBaseInst) {
|
|
849
|
+
var instFuncTable = target[DynInstFuncTable] || {};
|
|
850
|
+
if (instFuncTable[DynAllowInstChkTag] !== false) {
|
|
851
|
+
theFunc = (instFuncTable[funcHost[DynClassName]] || {})[funcName] || theFunc;
|
|
852
|
+
}
|
|
853
|
+
}
|
|
854
|
+
return function () {
|
|
855
|
+
return theFunc.apply(target, arguments);
|
|
856
|
+
};
|
|
857
|
+
}
|
|
858
|
+
var baseFuncs = {};
|
|
859
|
+
_forEachProp(instFuncs, function (name) {
|
|
860
|
+
baseFuncs[name] = _instFuncProxy(thisTarget, instFuncs, name);
|
|
861
|
+
});
|
|
862
|
+
var baseProto = _getObjProto(classProto);
|
|
863
|
+
var visited = [];
|
|
864
|
+
while (baseProto && !_isObjectArrayOrFunctionPrototype(baseProto) && !_hasVisited(visited, baseProto)) {
|
|
865
|
+
_forEachProp(baseProto, function (name) {
|
|
866
|
+
if (!baseFuncs[name] && _isDynamicCandidate(baseProto, name, !_objGetPrototypeOf)) {
|
|
867
|
+
baseFuncs[name] = _instFuncProxy(thisTarget, baseProto, name);
|
|
868
|
+
}
|
|
869
|
+
});
|
|
870
|
+
visited.push(baseProto);
|
|
871
|
+
baseProto = _getObjProto(baseProto);
|
|
872
|
+
}
|
|
873
|
+
return baseFuncs;
|
|
874
|
+
}
|
|
875
|
+
function _getInstFunc(target, funcName, proto, currentDynProtoProxy) {
|
|
876
|
+
var instFunc = null;
|
|
877
|
+
if (target && objHasOwnProperty(proto, DynClassName)) {
|
|
878
|
+
var instFuncTable = target[DynInstFuncTable] || {};
|
|
879
|
+
instFunc = (instFuncTable[proto[DynClassName]] || {})[funcName];
|
|
880
|
+
if (!instFunc) {
|
|
881
|
+
_throwTypeError("Missing [" + funcName + "] " + strFunction);
|
|
882
|
+
}
|
|
883
|
+
if (!instFunc[DynInstChkTag] && instFuncTable[DynAllowInstChkTag] !== false) {
|
|
884
|
+
var canAddInst = !objHasOwnProperty(target, funcName);
|
|
885
|
+
var objProto = _getObjProto(target);
|
|
886
|
+
var visited = [];
|
|
887
|
+
while (canAddInst && objProto && !_isObjectArrayOrFunctionPrototype(objProto) && !_hasVisited(visited, objProto)) {
|
|
888
|
+
var protoFunc = objProto[funcName];
|
|
889
|
+
if (protoFunc) {
|
|
890
|
+
canAddInst = (protoFunc === currentDynProtoProxy);
|
|
891
|
+
break;
|
|
892
|
+
}
|
|
893
|
+
visited.push(objProto);
|
|
894
|
+
objProto = _getObjProto(objProto);
|
|
895
|
+
}
|
|
896
|
+
try {
|
|
897
|
+
if (canAddInst) {
|
|
898
|
+
target[funcName] = instFunc;
|
|
899
|
+
}
|
|
900
|
+
instFunc[DynInstChkTag] = 1;
|
|
901
|
+
}
|
|
902
|
+
catch (e) {
|
|
903
|
+
instFuncTable[DynAllowInstChkTag] = false;
|
|
904
|
+
}
|
|
905
|
+
}
|
|
906
|
+
}
|
|
907
|
+
return instFunc;
|
|
908
|
+
}
|
|
909
|
+
function _getProtoFunc(funcName, proto, currentDynProtoProxy) {
|
|
910
|
+
var protoFunc = proto[funcName];
|
|
911
|
+
if (protoFunc === currentDynProtoProxy) {
|
|
912
|
+
protoFunc = _getObjProto(proto)[funcName];
|
|
913
|
+
}
|
|
914
|
+
if (typeof protoFunc !== strFunction) {
|
|
915
|
+
_throwTypeError("[" + funcName + "] is not a " + strFunction);
|
|
916
|
+
}
|
|
917
|
+
return protoFunc;
|
|
918
|
+
}
|
|
919
|
+
function _populatePrototype(proto, className, target, baseInstFuncs, setInstanceFunc) {
|
|
920
|
+
function _createDynamicPrototype(proto, funcName) {
|
|
921
|
+
var dynProtoProxy = function () {
|
|
922
|
+
var instFunc = _getInstFunc(this, funcName, proto, dynProtoProxy) || _getProtoFunc(funcName, proto, dynProtoProxy);
|
|
923
|
+
return instFunc.apply(this, arguments);
|
|
924
|
+
};
|
|
925
|
+
dynProtoProxy[DynProxyTag] = 1;
|
|
926
|
+
return dynProtoProxy;
|
|
927
|
+
}
|
|
928
|
+
if (!_isObjectOrArrayPrototype(proto)) {
|
|
929
|
+
var instFuncTable = target[DynInstFuncTable] = target[DynInstFuncTable] || {};
|
|
930
|
+
var instFuncs_1 = instFuncTable[className] = (instFuncTable[className] || {});
|
|
931
|
+
if (instFuncTable[DynAllowInstChkTag] !== false) {
|
|
932
|
+
instFuncTable[DynAllowInstChkTag] = !!setInstanceFunc;
|
|
933
|
+
}
|
|
934
|
+
_forEachProp(target, function (name) {
|
|
935
|
+
if (_isDynamicCandidate(target, name, false) && target[name] !== baseInstFuncs[name]) {
|
|
936
|
+
instFuncs_1[name] = target[name];
|
|
937
|
+
delete target[name];
|
|
938
|
+
if (!objHasOwnProperty(proto, name) || (proto[name] && !proto[name][DynProxyTag])) {
|
|
939
|
+
proto[name] = _createDynamicPrototype(proto, name);
|
|
940
|
+
}
|
|
941
|
+
}
|
|
942
|
+
});
|
|
943
|
+
}
|
|
944
|
+
}
|
|
945
|
+
function _checkPrototype(classProto, thisTarget) {
|
|
946
|
+
if (_objGetPrototypeOf) {
|
|
947
|
+
var visited = [];
|
|
948
|
+
var thisProto = _getObjProto(thisTarget);
|
|
949
|
+
while (thisProto && !_isObjectArrayOrFunctionPrototype(thisProto) && !_hasVisited(visited, thisProto)) {
|
|
950
|
+
if (thisProto === classProto) {
|
|
951
|
+
return true;
|
|
952
|
+
}
|
|
953
|
+
visited.push(thisProto);
|
|
954
|
+
thisProto = _getObjProto(thisProto);
|
|
955
|
+
}
|
|
956
|
+
return false;
|
|
957
|
+
}
|
|
958
|
+
return true;
|
|
959
|
+
}
|
|
960
|
+
function _getObjName(target, unknownValue) {
|
|
961
|
+
if (objHasOwnProperty(target, Prototype)) {
|
|
962
|
+
return target.name || unknownValue || UnknownValue;
|
|
963
|
+
}
|
|
964
|
+
return (((target || {})[Constructor]) || {}).name || unknownValue || UnknownValue;
|
|
965
|
+
}
|
|
966
|
+
function dynamicProto(theClass, target, delegateFunc, options) {
|
|
967
|
+
if (!objHasOwnProperty(theClass, Prototype)) {
|
|
968
|
+
_throwTypeError("theClass is an invalid class definition.");
|
|
969
|
+
}
|
|
970
|
+
var classProto = theClass[Prototype];
|
|
971
|
+
if (!_checkPrototype(classProto, target)) {
|
|
972
|
+
_throwTypeError("[" + _getObjName(theClass) + "] not in hierarchy of [" + _getObjName(target) + "]");
|
|
973
|
+
}
|
|
974
|
+
var className = null;
|
|
975
|
+
if (objHasOwnProperty(classProto, DynClassName)) {
|
|
976
|
+
className = classProto[DynClassName];
|
|
977
|
+
}
|
|
978
|
+
else {
|
|
979
|
+
className = DynClassNamePrefix + _getObjName(theClass, "_") + "$" + _gblInst.n;
|
|
980
|
+
_gblInst.n++;
|
|
981
|
+
classProto[DynClassName] = className;
|
|
982
|
+
}
|
|
983
|
+
var perfOptions = dynamicProto[DynProtoDefaultOptions];
|
|
984
|
+
var useBaseInst = !!perfOptions[strUseBaseInst];
|
|
985
|
+
if (useBaseInst && options && options[strUseBaseInst] !== undefined) {
|
|
986
|
+
useBaseInst = !!options[strUseBaseInst];
|
|
987
|
+
}
|
|
988
|
+
var instFuncs = _getInstanceFuncs(target);
|
|
989
|
+
var baseFuncs = _getBaseFuncs(classProto, target, instFuncs, useBaseInst);
|
|
990
|
+
delegateFunc(target, baseFuncs);
|
|
991
|
+
var setInstanceFunc = !!_objGetPrototypeOf && !!perfOptions[strSetInstFuncs];
|
|
992
|
+
if (setInstanceFunc && options) {
|
|
993
|
+
setInstanceFunc = !!options[strSetInstFuncs];
|
|
994
|
+
}
|
|
995
|
+
_populatePrototype(classProto, className, target, instFuncs, setInstanceFunc !== false);
|
|
996
|
+
}
|
|
997
|
+
dynamicProto[DynProtoDefaultOptions] = _gblInst.o;
|
|
998
|
+
|
|
999
|
+
var createEnumStyle = createEnum;
|
|
1000
|
+
|
|
1001
|
+
var _DYN_TO_LOWER_CASE = "toLowerCase";
|
|
1002
|
+
var _DYN_LENGTH$2 = "length";
|
|
1003
|
+
var _DYN_RD_ONLY = "rdOnly";
|
|
1004
|
+
var _DYN_NOTIFY = "notify";
|
|
1005
|
+
var _DYN_THROW_INTERNAL = "throwInternal";
|
|
1006
|
+
var _DYN_SET_DF = "setDf";
|
|
1007
|
+
var _DYN_WATCH = "watch";
|
|
1008
|
+
var _DYN_LOGGER = "logger";
|
|
1009
|
+
var _DYN_APPLY = "apply";
|
|
1010
|
+
var _DYN_PUSH = "push";
|
|
1011
|
+
var _DYN_SPLICE = "splice";
|
|
1012
|
+
var _DYN_CANCEL = "cancel";
|
|
1013
|
+
var _DYN_INITIALIZE = "initialize";
|
|
1014
|
+
var _DYN_IDENTIFIER = "identifier";
|
|
1015
|
+
var _DYN_IS_INITIALIZED = "isInitialized";
|
|
1016
|
+
var _DYN_GET_PLUGIN = "getPlugin";
|
|
1017
|
+
var _DYN_NAME$1 = "name";
|
|
1018
|
+
var _DYN_TIME = "time";
|
|
1019
|
+
var _DYN_PROCESS_NEXT = "processNext";
|
|
1020
|
+
var _DYN_GET_PROCESS_TEL_CONT0 = "getProcessTelContext";
|
|
1021
|
+
var _DYN_ENABLED = "enabled";
|
|
1022
|
+
var _DYN_UNLOAD = "unload";
|
|
1023
|
+
var _DYN_LOGGING_LEVEL_CONSOL4 = "loggingLevelConsole";
|
|
1024
|
+
var _DYN_CREATE_NEW = "createNew";
|
|
1025
|
+
var _DYN_TEARDOWN = "teardown";
|
|
1026
|
+
var _DYN_MESSAGE_ID = "messageId";
|
|
1027
|
+
var _DYN_MESSAGE = "message";
|
|
1028
|
+
var _DYN_IS_ASYNC = "isAsync";
|
|
1029
|
+
var _DYN_DIAG_LOG = "diagLog";
|
|
1030
|
+
var _DYN__DO_TEARDOWN = "_doTeardown";
|
|
1031
|
+
var _DYN_UPDATE$1 = "update";
|
|
1032
|
+
var _DYN_GET_NEXT = "getNext";
|
|
1033
|
+
var _DYN_SET_NEXT_PLUGIN = "setNextPlugin";
|
|
1034
|
+
var _DYN_USER_AGENT = "userAgent";
|
|
1035
|
+
var _DYN_SPLIT = "split";
|
|
1036
|
+
var _DYN_NODE_TYPE = "nodeType";
|
|
1037
|
+
var _DYN_REPLACE = "replace";
|
|
1038
|
+
var _DYN_LOG_INTERNAL_MESSAGE = "logInternalMessage";
|
|
1039
|
+
var _DYN_IS_CHILD_EVT = "isChildEvt";
|
|
1040
|
+
var _DYN_GET_CTX = "getCtx";
|
|
1041
|
+
var _DYN_SET_CTX = "setCtx";
|
|
1042
|
+
var _DYN_COMPLETE = "complete";
|
|
1043
|
+
|
|
1044
|
+
var aggregationErrorType;
|
|
1045
|
+
function throwAggregationError(message, sourceErrors) {
|
|
1046
|
+
if (!aggregationErrorType) {
|
|
1047
|
+
aggregationErrorType = createCustomError("AggregationError", function (self, args) {
|
|
1048
|
+
if (args[_DYN_LENGTH$2 ] > 1) {
|
|
1049
|
+
self.errors = args[1];
|
|
1050
|
+
}
|
|
1051
|
+
});
|
|
1052
|
+
}
|
|
1053
|
+
var theMessage = message || "One or more errors occurred.";
|
|
1054
|
+
arrForEach(sourceErrors, function (srcError, idx) {
|
|
1055
|
+
theMessage += "\n".concat(idx, " > ").concat(dumpObj(srcError));
|
|
1056
|
+
});
|
|
1057
|
+
throw new aggregationErrorType(theMessage, sourceErrors || []);
|
|
1058
|
+
}
|
|
1059
|
+
|
|
1060
|
+
var UNDEFINED_VALUE = undefined;
|
|
1061
|
+
var STR_EMPTY = "";
|
|
1062
|
+
var STR_CORE = "core";
|
|
1063
|
+
var STR_DISABLED = "disabled";
|
|
1064
|
+
var STR_EXTENSION_CONFIG = "extensionConfig";
|
|
1065
|
+
var STR_PROCESS_TELEMETRY = "processTelemetry";
|
|
1066
|
+
var STR_PRIORITY = "priority";
|
|
1067
|
+
var STR_ERROR_TO_CONSOLE = "errorToConsole";
|
|
1068
|
+
var STR_WARN_TO_CONSOLE = "warnToConsole";
|
|
1069
|
+
var STR_GET_PERF_MGR = "getPerfMgr";
|
|
1070
|
+
var STR_DOMAIN = "domain";
|
|
1071
|
+
var STR_PATH = "path";
|
|
1072
|
+
var STR_NOT_DYNAMIC_ERROR = "Not dynamic - ";
|
|
1073
|
+
|
|
1074
|
+
var rCamelCase = /-([a-z])/g;
|
|
1075
|
+
var rNormalizeInvalid = /([^\w\d_$])/g;
|
|
1076
|
+
var rLeadingNumeric = /^(\d+[\w\d_$])/;
|
|
1077
|
+
function isNotNullOrUndefined(value) {
|
|
1078
|
+
return !isNullOrUndefined(value);
|
|
1079
|
+
}
|
|
1080
|
+
function normalizeJsName(name) {
|
|
1081
|
+
var value = name;
|
|
1082
|
+
if (value && isString(value)) {
|
|
1083
|
+
value = value[_DYN_REPLACE ](rCamelCase, function (_all, letter) {
|
|
1084
|
+
return letter.toUpperCase();
|
|
1085
|
+
});
|
|
1086
|
+
value = value[_DYN_REPLACE ](rNormalizeInvalid, "_");
|
|
1087
|
+
value = value[_DYN_REPLACE ](rLeadingNumeric, function (_all, match) {
|
|
1088
|
+
return "_" + match;
|
|
1089
|
+
});
|
|
1090
|
+
}
|
|
1091
|
+
return value;
|
|
1092
|
+
}
|
|
1093
|
+
function strContains(value, search) {
|
|
1094
|
+
if (value && search) {
|
|
1095
|
+
return strIndexOf(value, search) !== -1;
|
|
1096
|
+
}
|
|
1097
|
+
return false;
|
|
1098
|
+
}
|
|
1099
|
+
function toISOString(date) {
|
|
1100
|
+
return date && date.toISOString() || "";
|
|
1101
|
+
}
|
|
1102
|
+
function getExceptionName(object) {
|
|
1103
|
+
if (isError(object)) {
|
|
1104
|
+
return object[_DYN_NAME$1 ];
|
|
1105
|
+
}
|
|
1106
|
+
return STR_EMPTY;
|
|
1107
|
+
}
|
|
1108
|
+
function setValue(target, field, value, valChk, srcChk) {
|
|
1109
|
+
var theValue = value;
|
|
1110
|
+
if (target) {
|
|
1111
|
+
theValue = target[field];
|
|
1112
|
+
if (theValue !== value && (!srcChk || srcChk(theValue)) && (!valChk || valChk(value))) {
|
|
1113
|
+
theValue = value;
|
|
1114
|
+
target[field] = theValue;
|
|
1115
|
+
}
|
|
1116
|
+
}
|
|
1117
|
+
return theValue;
|
|
1118
|
+
}
|
|
1119
|
+
function getSetValue(target, field, defValue) {
|
|
1120
|
+
var theValue;
|
|
1121
|
+
if (target) {
|
|
1122
|
+
theValue = target[field];
|
|
1123
|
+
if (!theValue && isNullOrUndefined(theValue)) {
|
|
1124
|
+
theValue = !isUndefined(defValue) ? defValue : {};
|
|
1125
|
+
target[field] = theValue;
|
|
1126
|
+
}
|
|
1127
|
+
}
|
|
1128
|
+
else {
|
|
1129
|
+
theValue = !isUndefined(defValue) ? defValue : {};
|
|
1130
|
+
}
|
|
1131
|
+
return theValue;
|
|
1132
|
+
}
|
|
1133
|
+
function _createProxyFunction(source, funcName) {
|
|
1134
|
+
var srcFunc = null;
|
|
1135
|
+
var src = null;
|
|
1136
|
+
if (isFunction(source)) {
|
|
1137
|
+
srcFunc = source;
|
|
1138
|
+
}
|
|
1139
|
+
else {
|
|
1140
|
+
src = source;
|
|
1141
|
+
}
|
|
1142
|
+
return function () {
|
|
1143
|
+
var originalArguments = arguments;
|
|
1144
|
+
if (srcFunc) {
|
|
1145
|
+
src = srcFunc();
|
|
1146
|
+
}
|
|
1147
|
+
if (src) {
|
|
1148
|
+
return src[funcName][_DYN_APPLY ](src, originalArguments);
|
|
1149
|
+
}
|
|
1150
|
+
};
|
|
1151
|
+
}
|
|
1152
|
+
function proxyFunctionAs(target, name, source, theFunc, overwriteTarget) {
|
|
1153
|
+
if (target && name && source) {
|
|
1154
|
+
if (overwriteTarget !== false || isUndefined(target[name])) {
|
|
1155
|
+
target[name] = _createProxyFunction(source, theFunc);
|
|
1156
|
+
}
|
|
1157
|
+
}
|
|
1158
|
+
}
|
|
1159
|
+
function createClassFromInterface(defaults) {
|
|
1160
|
+
return /** @class */ (function () {
|
|
1161
|
+
function class_1() {
|
|
1162
|
+
var _this = this;
|
|
1163
|
+
if (defaults) {
|
|
1164
|
+
objForEachKey(defaults, function (field, value) {
|
|
1165
|
+
_this[field] = value;
|
|
1166
|
+
});
|
|
1167
|
+
}
|
|
1168
|
+
}
|
|
1169
|
+
return class_1;
|
|
1170
|
+
}());
|
|
1171
|
+
}
|
|
1172
|
+
|
|
1173
|
+
var strLocation = "location";
|
|
1174
|
+
var strConsole = "console";
|
|
1175
|
+
var strJSON = "JSON";
|
|
1176
|
+
var strCrypto = "crypto";
|
|
1177
|
+
var strMsCrypto = "msCrypto";
|
|
1178
|
+
var strMsie = "msie";
|
|
1179
|
+
var strTrident = "trident/";
|
|
1180
|
+
var _isTrident = null;
|
|
1181
|
+
var _navUserAgentCheck = null;
|
|
1182
|
+
var _enableMocks = false;
|
|
1183
|
+
function getLocation(checkForMock) {
|
|
1184
|
+
if (checkForMock && _enableMocks) {
|
|
1185
|
+
var mockLocation = getInst("__mockLocation");
|
|
1186
|
+
if (mockLocation) {
|
|
1187
|
+
return mockLocation;
|
|
1188
|
+
}
|
|
1189
|
+
}
|
|
1190
|
+
if (typeof location === strShimObject && location) {
|
|
1191
|
+
return location;
|
|
1192
|
+
}
|
|
1193
|
+
return getInst(strLocation);
|
|
1194
|
+
}
|
|
1195
|
+
function getConsole() {
|
|
1196
|
+
if (typeof console !== strShimUndefined) {
|
|
1197
|
+
return console;
|
|
1198
|
+
}
|
|
1199
|
+
return getInst(strConsole);
|
|
1200
|
+
}
|
|
1201
|
+
function hasJSON() {
|
|
1202
|
+
return Boolean((typeof JSON === strShimObject && JSON) || getInst(strJSON) !== null);
|
|
1203
|
+
}
|
|
1204
|
+
function getJSON() {
|
|
1205
|
+
if (hasJSON()) {
|
|
1206
|
+
return JSON || getInst(strJSON);
|
|
1207
|
+
}
|
|
1208
|
+
return null;
|
|
1209
|
+
}
|
|
1210
|
+
function getCrypto() {
|
|
1211
|
+
return getInst(strCrypto);
|
|
1212
|
+
}
|
|
1213
|
+
function getMsCrypto() {
|
|
1214
|
+
return getInst(strMsCrypto);
|
|
1215
|
+
}
|
|
1216
|
+
function isIE() {
|
|
1217
|
+
var nav = getNavigator();
|
|
1218
|
+
if (nav && (nav[_DYN_USER_AGENT ] !== _navUserAgentCheck || _isTrident === null)) {
|
|
1219
|
+
_navUserAgentCheck = nav[_DYN_USER_AGENT ];
|
|
1220
|
+
var userAgent = (_navUserAgentCheck || STR_EMPTY)[_DYN_TO_LOWER_CASE ]();
|
|
1221
|
+
_isTrident = (strContains(userAgent, strMsie) || strContains(userAgent, strTrident));
|
|
1222
|
+
}
|
|
1223
|
+
return _isTrident;
|
|
1224
|
+
}
|
|
1225
|
+
|
|
1226
|
+
var UInt32Mask = 0x100000000;
|
|
1227
|
+
var MaxUInt32 = 0xffffffff;
|
|
1228
|
+
var SEED1 = 123456789;
|
|
1229
|
+
var SEED2 = 987654321;
|
|
1230
|
+
var _mwcSeeded = false;
|
|
1231
|
+
var _mwcW = SEED1;
|
|
1232
|
+
var _mwcZ = SEED2;
|
|
1233
|
+
function _mwcSeed(seedValue) {
|
|
1234
|
+
if (seedValue < 0) {
|
|
1235
|
+
seedValue >>>= 0;
|
|
1236
|
+
}
|
|
1237
|
+
_mwcW = (SEED1 + seedValue) & MaxUInt32;
|
|
1238
|
+
_mwcZ = (SEED2 - seedValue) & MaxUInt32;
|
|
1239
|
+
_mwcSeeded = true;
|
|
1240
|
+
}
|
|
1241
|
+
function _autoSeedMwc() {
|
|
1242
|
+
try {
|
|
1243
|
+
var now = utcNow() & 0x7fffffff;
|
|
1244
|
+
_mwcSeed(((Math.random() * UInt32Mask) ^ now) + now);
|
|
1245
|
+
}
|
|
1246
|
+
catch (e) {
|
|
1247
|
+
}
|
|
1248
|
+
}
|
|
1249
|
+
function random32(signed) {
|
|
1250
|
+
var value = 0;
|
|
1251
|
+
var c = getCrypto() || getMsCrypto();
|
|
1252
|
+
if (c && c.getRandomValues) {
|
|
1253
|
+
value = c.getRandomValues(new Uint32Array(1))[0] & MaxUInt32;
|
|
1254
|
+
}
|
|
1255
|
+
if (value === 0 && isIE()) {
|
|
1256
|
+
if (!_mwcSeeded) {
|
|
1257
|
+
_autoSeedMwc();
|
|
1258
|
+
}
|
|
1259
|
+
value = mwcRandom32() & MaxUInt32;
|
|
1260
|
+
}
|
|
1261
|
+
if (value === 0) {
|
|
1262
|
+
value = Math.floor((UInt32Mask * Math.random()) | 0);
|
|
1263
|
+
}
|
|
1264
|
+
if (!signed) {
|
|
1265
|
+
value >>>= 0;
|
|
1266
|
+
}
|
|
1267
|
+
return value;
|
|
1268
|
+
}
|
|
1269
|
+
function mwcRandom32(signed) {
|
|
1270
|
+
_mwcZ = (36969 * (_mwcZ & 0xFFFF) + (_mwcZ >> 16)) & MaxUInt32;
|
|
1271
|
+
_mwcW = (18000 * (_mwcW & 0xFFFF) + (_mwcW >> 16)) & MaxUInt32;
|
|
1272
|
+
var value = (((_mwcZ << 16) + (_mwcW & 0xFFFF)) >>> 0) & MaxUInt32 | 0;
|
|
1273
|
+
if (!signed) {
|
|
1274
|
+
value >>>= 0;
|
|
1275
|
+
}
|
|
1276
|
+
return value;
|
|
1277
|
+
}
|
|
1278
|
+
function newId(maxLength) {
|
|
1279
|
+
if (maxLength === void 0) { maxLength = 22; }
|
|
1280
|
+
var base64chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
|
1281
|
+
var number = random32() >>> 0;
|
|
1282
|
+
var chars = 0;
|
|
1283
|
+
var result = STR_EMPTY;
|
|
1284
|
+
while (result[_DYN_LENGTH$2 ] < maxLength) {
|
|
1285
|
+
chars++;
|
|
1286
|
+
result += base64chars.charAt(number & 0x3F);
|
|
1287
|
+
number >>>= 6;
|
|
1288
|
+
if (chars === 5) {
|
|
1289
|
+
number = (((random32() << 2) & 0xFFFFFFFF) | (number & 0x03)) >>> 0;
|
|
1290
|
+
chars = 0;
|
|
1291
|
+
}
|
|
1292
|
+
}
|
|
1293
|
+
return result;
|
|
1294
|
+
}
|
|
1295
|
+
|
|
1296
|
+
var version = "3.0.2-nightly3.2305-04";
|
|
1297
|
+
var instanceName = "." + newId(6);
|
|
1298
|
+
var _dataUid = 0;
|
|
1299
|
+
function _canAcceptData(target) {
|
|
1300
|
+
return target[_DYN_NODE_TYPE ] === 1 || target[_DYN_NODE_TYPE ] === 9 || !(+target[_DYN_NODE_TYPE ]);
|
|
1301
|
+
}
|
|
1302
|
+
function _getCache(data, target) {
|
|
1303
|
+
var theCache = target[data.id];
|
|
1304
|
+
if (!theCache) {
|
|
1305
|
+
theCache = {};
|
|
1306
|
+
try {
|
|
1307
|
+
if (_canAcceptData(target)) {
|
|
1308
|
+
objDefine(target, data.id, {
|
|
1309
|
+
e: false,
|
|
1310
|
+
v: theCache
|
|
1311
|
+
});
|
|
1312
|
+
}
|
|
1313
|
+
}
|
|
1314
|
+
catch (e) {
|
|
1315
|
+
}
|
|
1316
|
+
}
|
|
1317
|
+
return theCache;
|
|
1318
|
+
}
|
|
1319
|
+
function createUniqueNamespace(name, includeVersion) {
|
|
1320
|
+
if (includeVersion === void 0) { includeVersion = false; }
|
|
1321
|
+
return normalizeJsName(name + (_dataUid++) + (includeVersion ? "." + version : STR_EMPTY) + instanceName);
|
|
1322
|
+
}
|
|
1323
|
+
function createElmNodeData(name) {
|
|
1324
|
+
var data = {
|
|
1325
|
+
id: createUniqueNamespace("_aiData-" + (name || STR_EMPTY) + "." + version),
|
|
1326
|
+
accept: function (target) {
|
|
1327
|
+
return _canAcceptData(target);
|
|
1328
|
+
},
|
|
1329
|
+
get: function (target, name, defValue, addDefault) {
|
|
1330
|
+
var theCache = target[data.id];
|
|
1331
|
+
if (!theCache) {
|
|
1332
|
+
if (addDefault) {
|
|
1333
|
+
theCache = _getCache(data, target);
|
|
1334
|
+
theCache[normalizeJsName(name)] = defValue;
|
|
1335
|
+
}
|
|
1336
|
+
return defValue;
|
|
1337
|
+
}
|
|
1338
|
+
return theCache[normalizeJsName(name)];
|
|
1339
|
+
},
|
|
1340
|
+
kill: function (target, name) {
|
|
1341
|
+
if (target && target[name]) {
|
|
1342
|
+
try {
|
|
1343
|
+
delete target[name];
|
|
1344
|
+
}
|
|
1345
|
+
catch (e) {
|
|
1346
|
+
}
|
|
1347
|
+
}
|
|
1348
|
+
}
|
|
1349
|
+
};
|
|
1350
|
+
return data;
|
|
1351
|
+
}
|
|
1352
|
+
|
|
1353
|
+
function _isConfigDefaults(value) {
|
|
1354
|
+
return (value && isObject(value) && (value.isVal || value.fb || objHasOwn(value, "v") || objHasOwn(value, "mrg") || objHasOwn(value, "ref") || value.set));
|
|
1355
|
+
}
|
|
1356
|
+
function _getDefault(dynamicHandler, theConfig, cfgDefaults) {
|
|
1357
|
+
var defValue;
|
|
1358
|
+
var isDefaultValid = cfgDefaults.dfVal || isDefined;
|
|
1359
|
+
if (theConfig && cfgDefaults.fb) {
|
|
1360
|
+
var fallbacks = cfgDefaults.fb;
|
|
1361
|
+
if (!isArray(fallbacks)) {
|
|
1362
|
+
fallbacks = [fallbacks];
|
|
1363
|
+
}
|
|
1364
|
+
for (var lp = 0; lp < fallbacks[_DYN_LENGTH$2 ]; lp++) {
|
|
1365
|
+
var fallback = fallbacks[lp];
|
|
1366
|
+
var fbValue = theConfig[fallback];
|
|
1367
|
+
if (isDefaultValid(fbValue)) {
|
|
1368
|
+
defValue = fbValue;
|
|
1369
|
+
}
|
|
1370
|
+
else if (dynamicHandler) {
|
|
1371
|
+
fbValue = dynamicHandler.cfg[fallback];
|
|
1372
|
+
if (isDefaultValid(fbValue)) {
|
|
1373
|
+
defValue = fbValue;
|
|
1374
|
+
}
|
|
1375
|
+
dynamicHandler.set(dynamicHandler.cfg, asString(fallback), fbValue);
|
|
1376
|
+
}
|
|
1377
|
+
if (isDefaultValid(defValue)) {
|
|
1378
|
+
break;
|
|
1379
|
+
}
|
|
1380
|
+
}
|
|
1381
|
+
}
|
|
1382
|
+
if (!isDefaultValid(defValue) && isDefaultValid(cfgDefaults.v)) {
|
|
1383
|
+
defValue = cfgDefaults.v;
|
|
1384
|
+
}
|
|
1385
|
+
return defValue;
|
|
1386
|
+
}
|
|
1387
|
+
function _resolveDefaultValue(dynamicHandler, theConfig, cfgDefaults) {
|
|
1388
|
+
var theValue = cfgDefaults;
|
|
1389
|
+
if (cfgDefaults && _isConfigDefaults(cfgDefaults)) {
|
|
1390
|
+
theValue = _getDefault(dynamicHandler, theConfig, cfgDefaults);
|
|
1391
|
+
}
|
|
1392
|
+
if (theValue) {
|
|
1393
|
+
if (_isConfigDefaults(theValue)) {
|
|
1394
|
+
theValue = _resolveDefaultValue(dynamicHandler, theConfig, theValue);
|
|
1395
|
+
}
|
|
1396
|
+
var newValue_1;
|
|
1397
|
+
if (isArray(theValue)) {
|
|
1398
|
+
newValue_1 = [];
|
|
1399
|
+
newValue_1[_DYN_LENGTH$2 ] = theValue[_DYN_LENGTH$2 ];
|
|
1400
|
+
}
|
|
1401
|
+
else if (isPlainObject(theValue)) {
|
|
1402
|
+
newValue_1 = {};
|
|
1403
|
+
}
|
|
1404
|
+
if (newValue_1) {
|
|
1405
|
+
objForEachKey(theValue, function (key, value) {
|
|
1406
|
+
if (value && _isConfigDefaults(value)) {
|
|
1407
|
+
value = _resolveDefaultValue(dynamicHandler, theConfig, value);
|
|
1408
|
+
}
|
|
1409
|
+
newValue_1[key] = value;
|
|
1410
|
+
});
|
|
1411
|
+
theValue = newValue_1;
|
|
1412
|
+
}
|
|
1413
|
+
}
|
|
1414
|
+
return theValue;
|
|
1415
|
+
}
|
|
1416
|
+
function _applyDefaultValue(dynamicHandler, theConfig, name, defaultValue) {
|
|
1417
|
+
var isValid;
|
|
1418
|
+
var setFn;
|
|
1419
|
+
var defValue;
|
|
1420
|
+
var cfgDefaults = defaultValue;
|
|
1421
|
+
var mergeDf;
|
|
1422
|
+
var reference;
|
|
1423
|
+
var readOnly;
|
|
1424
|
+
if (_isConfigDefaults(cfgDefaults)) {
|
|
1425
|
+
isValid = cfgDefaults.isVal;
|
|
1426
|
+
setFn = cfgDefaults.set;
|
|
1427
|
+
readOnly = cfgDefaults[_DYN_RD_ONLY ];
|
|
1428
|
+
mergeDf = cfgDefaults.mrg;
|
|
1429
|
+
reference = cfgDefaults.ref;
|
|
1430
|
+
if (!reference && isUndefined(reference)) {
|
|
1431
|
+
reference = !!mergeDf;
|
|
1432
|
+
}
|
|
1433
|
+
defValue = _getDefault(dynamicHandler, theConfig, cfgDefaults);
|
|
1434
|
+
}
|
|
1435
|
+
else {
|
|
1436
|
+
defValue = defaultValue;
|
|
1437
|
+
}
|
|
1438
|
+
var theValue;
|
|
1439
|
+
var usingDefault = true;
|
|
1440
|
+
var cfgValue = theConfig[name];
|
|
1441
|
+
if (cfgValue || !isNullOrUndefined(cfgValue)) {
|
|
1442
|
+
theValue = cfgValue;
|
|
1443
|
+
usingDefault = false;
|
|
1444
|
+
if (isValid && theValue !== defValue && !isValid(theValue)) {
|
|
1445
|
+
theValue = defValue;
|
|
1446
|
+
usingDefault = true;
|
|
1447
|
+
}
|
|
1448
|
+
if (setFn) {
|
|
1449
|
+
theValue = setFn(theValue, defValue, theConfig);
|
|
1450
|
+
usingDefault = theValue === defValue;
|
|
1451
|
+
}
|
|
1452
|
+
}
|
|
1453
|
+
if (!usingDefault) {
|
|
1454
|
+
if (isPlainObject(theValue) || isArray(defValue)) {
|
|
1455
|
+
if (mergeDf && defValue && (isPlainObject(defValue) || isArray(defValue))) {
|
|
1456
|
+
objForEachKey(defValue, function (dfName, dfValue) {
|
|
1457
|
+
_applyDefaultValue(dynamicHandler, theValue, dfName, dfValue);
|
|
1458
|
+
});
|
|
1459
|
+
}
|
|
1460
|
+
}
|
|
1461
|
+
}
|
|
1462
|
+
else if (defValue) {
|
|
1463
|
+
theValue = _resolveDefaultValue(dynamicHandler, theConfig, defValue);
|
|
1464
|
+
}
|
|
1465
|
+
else {
|
|
1466
|
+
theValue = defValue;
|
|
1467
|
+
}
|
|
1468
|
+
dynamicHandler.set(theConfig, name, theValue);
|
|
1469
|
+
if (reference) {
|
|
1470
|
+
dynamicHandler.ref(theConfig, name);
|
|
1471
|
+
}
|
|
1472
|
+
if (readOnly) {
|
|
1473
|
+
dynamicHandler[_DYN_RD_ONLY ](theConfig, name);
|
|
1474
|
+
}
|
|
1475
|
+
}
|
|
1476
|
+
|
|
1477
|
+
var CFG_HANDLER_LINK = symbolFor("[[ai_dynCfg_1]]");
|
|
1478
|
+
var BLOCK_DYNAMIC = symbolFor("[[ai_blkDynCfg_1]]");
|
|
1479
|
+
var FORCE_DYNAMIC = symbolFor("[[ai_frcDynCfg_1]]");
|
|
1480
|
+
function _cfgDeepCopy(source) {
|
|
1481
|
+
if (source) {
|
|
1482
|
+
var target_1;
|
|
1483
|
+
if (isArray(source)) {
|
|
1484
|
+
target_1 = [];
|
|
1485
|
+
target_1[_DYN_LENGTH$2 ] = source[_DYN_LENGTH$2 ];
|
|
1486
|
+
}
|
|
1487
|
+
else if (isPlainObject(source)) {
|
|
1488
|
+
target_1 = {};
|
|
1489
|
+
}
|
|
1490
|
+
if (target_1) {
|
|
1491
|
+
objForEachKey(source, function (key, value) {
|
|
1492
|
+
target_1[key] = _cfgDeepCopy(value);
|
|
1493
|
+
});
|
|
1494
|
+
return target_1;
|
|
1495
|
+
}
|
|
1496
|
+
}
|
|
1497
|
+
return source;
|
|
1498
|
+
}
|
|
1499
|
+
function getDynamicConfigHandler(value) {
|
|
1500
|
+
if (value) {
|
|
1501
|
+
var handler = value[CFG_HANDLER_LINK] || value;
|
|
1502
|
+
if (handler.cfg && (handler.cfg === value || handler.cfg[CFG_HANDLER_LINK] === handler)) {
|
|
1503
|
+
return handler;
|
|
1504
|
+
}
|
|
1505
|
+
}
|
|
1506
|
+
return null;
|
|
1507
|
+
}
|
|
1508
|
+
function _canMakeDynamic(value) {
|
|
1509
|
+
var result = false;
|
|
1510
|
+
if (value) {
|
|
1511
|
+
result = value[FORCE_DYNAMIC];
|
|
1512
|
+
if (!result && !value[BLOCK_DYNAMIC]) {
|
|
1513
|
+
result = isPlainObject(value) || isArray(value);
|
|
1514
|
+
}
|
|
1515
|
+
}
|
|
1516
|
+
return result;
|
|
1517
|
+
}
|
|
1518
|
+
function throwInvalidAccess(message) {
|
|
1519
|
+
throwTypeError("InvalidAccess:" + message);
|
|
1520
|
+
}
|
|
1521
|
+
|
|
1522
|
+
var arrayMethodsToPatch = [
|
|
1523
|
+
"push",
|
|
1524
|
+
"pop",
|
|
1525
|
+
"shift",
|
|
1526
|
+
"unshift",
|
|
1527
|
+
"splice"
|
|
1528
|
+
];
|
|
1529
|
+
function _patchArray(state, target) {
|
|
1530
|
+
if (isArray(target)) {
|
|
1531
|
+
arrForEach(arrayMethodsToPatch, function (method) {
|
|
1532
|
+
var orgMethod = target[method];
|
|
1533
|
+
target[method] = function () {
|
|
1534
|
+
var args = [];
|
|
1535
|
+
for (var _i = 0; _i < arguments.length; _i++) {
|
|
1536
|
+
args[_i] = arguments[_i];
|
|
1537
|
+
}
|
|
1538
|
+
var result = orgMethod[_DYN_APPLY ](this, args);
|
|
1539
|
+
_makeDynamicObject(state, target);
|
|
1540
|
+
return result;
|
|
1541
|
+
};
|
|
1542
|
+
});
|
|
1543
|
+
}
|
|
1544
|
+
}
|
|
1545
|
+
function _getOwnPropGetter(target, name) {
|
|
1546
|
+
var propDesc = objGetOwnPropertyDescriptor(target, name);
|
|
1547
|
+
return propDesc && propDesc.get;
|
|
1548
|
+
}
|
|
1549
|
+
function _makeDynamicProperty(state, theConfig, name, value) {
|
|
1550
|
+
var detail = {
|
|
1551
|
+
n: name,
|
|
1552
|
+
h: [],
|
|
1553
|
+
trk: function (handler) {
|
|
1554
|
+
if (handler && handler.fn) {
|
|
1555
|
+
if (arrIndexOf(detail.h, handler) === -1) {
|
|
1556
|
+
detail.h[_DYN_PUSH ](handler);
|
|
1557
|
+
}
|
|
1558
|
+
state.trk(handler, detail);
|
|
1559
|
+
}
|
|
1560
|
+
},
|
|
1561
|
+
clr: function (handler) {
|
|
1562
|
+
var idx = arrIndexOf(detail.h, handler);
|
|
1563
|
+
if (idx !== -1) {
|
|
1564
|
+
detail.h[_DYN_SPLICE ](idx, 1);
|
|
1565
|
+
}
|
|
1566
|
+
}
|
|
1567
|
+
};
|
|
1568
|
+
var checkDynamic = true;
|
|
1569
|
+
var isObjectOrArray = false;
|
|
1570
|
+
function _getProperty() {
|
|
1571
|
+
if (checkDynamic) {
|
|
1572
|
+
isObjectOrArray = isObjectOrArray || _canMakeDynamic(value);
|
|
1573
|
+
if (value && !value[CFG_HANDLER_LINK] && isObjectOrArray) {
|
|
1574
|
+
value = _makeDynamicObject(state, value);
|
|
1575
|
+
}
|
|
1576
|
+
checkDynamic = false;
|
|
1577
|
+
}
|
|
1578
|
+
var activeHandler = state.act;
|
|
1579
|
+
if (activeHandler) {
|
|
1580
|
+
detail.trk(activeHandler);
|
|
1581
|
+
}
|
|
1582
|
+
return value;
|
|
1583
|
+
}
|
|
1584
|
+
_getProperty[state.prop] = {
|
|
1585
|
+
chng: function () {
|
|
1586
|
+
state.add(detail);
|
|
1587
|
+
}
|
|
1588
|
+
};
|
|
1589
|
+
function _setProperty(newValue) {
|
|
1590
|
+
if (value !== newValue) {
|
|
1591
|
+
if (!!_getProperty[state.ro] && !state.upd) {
|
|
1592
|
+
throwInvalidAccess("[" + name + "] is read-only:" + dumpObj(theConfig));
|
|
1593
|
+
}
|
|
1594
|
+
if (checkDynamic) {
|
|
1595
|
+
isObjectOrArray = isObjectOrArray || _canMakeDynamic(value);
|
|
1596
|
+
checkDynamic = false;
|
|
1597
|
+
}
|
|
1598
|
+
var isReferenced = isObjectOrArray && _getProperty[state.rf];
|
|
1599
|
+
if (isObjectOrArray) {
|
|
1600
|
+
if (isReferenced) {
|
|
1601
|
+
objForEachKey(value, function (key) {
|
|
1602
|
+
value[key] = newValue ? newValue[key] : UNDEFINED_VALUE;
|
|
1603
|
+
});
|
|
1604
|
+
objForEachKey(newValue, function (key, theValue) {
|
|
1605
|
+
_setDynamicProperty(state, value, key, theValue);
|
|
1606
|
+
});
|
|
1607
|
+
newValue = value;
|
|
1608
|
+
}
|
|
1609
|
+
else if (value && value[CFG_HANDLER_LINK]) {
|
|
1610
|
+
objForEachKey(value, function (key) {
|
|
1611
|
+
var getter = _getOwnPropGetter(value, key);
|
|
1612
|
+
if (getter) {
|
|
1613
|
+
var valueState = getter[state.prop];
|
|
1614
|
+
valueState && valueState.chng();
|
|
1615
|
+
}
|
|
1616
|
+
});
|
|
1617
|
+
}
|
|
1618
|
+
}
|
|
1619
|
+
if (newValue !== value) {
|
|
1620
|
+
var newIsObjectOrArray = newValue && _canMakeDynamic(newValue);
|
|
1621
|
+
if (!isReferenced && newIsObjectOrArray) {
|
|
1622
|
+
_makeDynamicObject(state, newValue);
|
|
1623
|
+
}
|
|
1624
|
+
value = newValue;
|
|
1625
|
+
isObjectOrArray = newIsObjectOrArray;
|
|
1626
|
+
}
|
|
1627
|
+
state.add(detail);
|
|
1628
|
+
}
|
|
1629
|
+
}
|
|
1630
|
+
objDefine(theConfig, detail.n, { g: _getProperty, s: _setProperty });
|
|
1631
|
+
}
|
|
1632
|
+
function _setDynamicProperty(state, target, name, value, inPlace, rdOnly) {
|
|
1633
|
+
if (target) {
|
|
1634
|
+
var getter = _getOwnPropGetter(target, name);
|
|
1635
|
+
var isDynamic = getter && !!getter[state.prop];
|
|
1636
|
+
if (!isDynamic) {
|
|
1637
|
+
_makeDynamicProperty(state, target, name, value);
|
|
1638
|
+
if (inPlace || rdOnly) {
|
|
1639
|
+
getter = _getOwnPropGetter(target, name);
|
|
1640
|
+
}
|
|
1641
|
+
}
|
|
1642
|
+
else {
|
|
1643
|
+
target[name] = value;
|
|
1644
|
+
}
|
|
1645
|
+
if (inPlace) {
|
|
1646
|
+
getter[state.rf] = inPlace;
|
|
1647
|
+
}
|
|
1648
|
+
if (rdOnly) {
|
|
1649
|
+
getter[state.ro] = rdOnly;
|
|
1650
|
+
}
|
|
1651
|
+
}
|
|
1652
|
+
return target;
|
|
1653
|
+
}
|
|
1654
|
+
function _makeDynamicObject(state, target) {
|
|
1655
|
+
objForEachKey(target, function (key, value) {
|
|
1656
|
+
_setDynamicProperty(state, target, key, value);
|
|
1657
|
+
});
|
|
1658
|
+
if (!target[CFG_HANDLER_LINK]) {
|
|
1659
|
+
objDefineProp(target, CFG_HANDLER_LINK, {
|
|
1660
|
+
get: function () {
|
|
1661
|
+
return state.hdlr;
|
|
1662
|
+
}
|
|
1663
|
+
});
|
|
1664
|
+
_patchArray(state, target);
|
|
1665
|
+
}
|
|
1666
|
+
return target;
|
|
1667
|
+
}
|
|
1668
|
+
|
|
1669
|
+
var symPrefix = "[[ai_";
|
|
1670
|
+
var symPostfix = "]]";
|
|
1671
|
+
function _createState(cfgHandler) {
|
|
1672
|
+
var _a;
|
|
1673
|
+
var dynamicPropertySymbol = newSymbol(symPrefix + "get" + cfgHandler.uid + symPostfix);
|
|
1674
|
+
var dynamicPropertyReadOnly = newSymbol(symPrefix + "ro" + cfgHandler.uid + symPostfix);
|
|
1675
|
+
var dynamicPropertyReferenced = newSymbol(symPrefix + "rf" + cfgHandler.uid + symPostfix);
|
|
1676
|
+
var dynamicPropertyDetail = newSymbol(symPrefix + "dtl" + cfgHandler.uid + symPostfix);
|
|
1677
|
+
var _waitingHandlers = null;
|
|
1678
|
+
var _watcherTimer = null;
|
|
1679
|
+
var theState;
|
|
1680
|
+
function _useHandler(activeHandler, callback) {
|
|
1681
|
+
var prevWatcher = theState.act;
|
|
1682
|
+
try {
|
|
1683
|
+
theState.act = activeHandler;
|
|
1684
|
+
if (activeHandler && activeHandler[dynamicPropertyDetail]) {
|
|
1685
|
+
arrForEach(activeHandler[dynamicPropertyDetail], function (detail) {
|
|
1686
|
+
detail.clr(activeHandler);
|
|
1687
|
+
});
|
|
1688
|
+
activeHandler[dynamicPropertyDetail] = [];
|
|
1689
|
+
}
|
|
1690
|
+
callback({
|
|
1691
|
+
cfg: cfgHandler.cfg,
|
|
1692
|
+
set: cfgHandler.set.bind(cfgHandler),
|
|
1693
|
+
setDf: cfgHandler[_DYN_SET_DF ].bind(cfgHandler),
|
|
1694
|
+
ref: cfgHandler.ref.bind(cfgHandler),
|
|
1695
|
+
rdOnly: cfgHandler[_DYN_RD_ONLY ].bind(cfgHandler)
|
|
1696
|
+
});
|
|
1697
|
+
}
|
|
1698
|
+
catch (e) {
|
|
1699
|
+
var logger = cfgHandler[_DYN_LOGGER ];
|
|
1700
|
+
if (logger) {
|
|
1701
|
+
logger[_DYN_THROW_INTERNAL ](1 , 107 , dumpObj(e));
|
|
1702
|
+
}
|
|
1703
|
+
throw e;
|
|
1704
|
+
}
|
|
1705
|
+
finally {
|
|
1706
|
+
theState.act = prevWatcher || null;
|
|
1707
|
+
}
|
|
1708
|
+
}
|
|
1709
|
+
function _notifyWatchers() {
|
|
1710
|
+
if (_waitingHandlers) {
|
|
1711
|
+
var notifyHandlers = _waitingHandlers;
|
|
1712
|
+
_waitingHandlers = null;
|
|
1713
|
+
_watcherTimer && _watcherTimer[_DYN_CANCEL ]();
|
|
1714
|
+
_watcherTimer = null;
|
|
1715
|
+
var watcherFailures_1 = [];
|
|
1716
|
+
arrForEach(notifyHandlers, function (handler) {
|
|
1717
|
+
if (handler) {
|
|
1718
|
+
if (handler[dynamicPropertyDetail]) {
|
|
1719
|
+
arrForEach(handler[dynamicPropertyDetail], function (detail) {
|
|
1720
|
+
detail.clr(handler);
|
|
1721
|
+
});
|
|
1722
|
+
handler[dynamicPropertyDetail] = null;
|
|
1723
|
+
}
|
|
1724
|
+
if (handler.fn) {
|
|
1725
|
+
try {
|
|
1726
|
+
_useHandler(handler, handler.fn);
|
|
1727
|
+
}
|
|
1728
|
+
catch (e) {
|
|
1729
|
+
watcherFailures_1[_DYN_PUSH ](e);
|
|
1730
|
+
}
|
|
1731
|
+
}
|
|
1732
|
+
}
|
|
1733
|
+
});
|
|
1734
|
+
if (_waitingHandlers) {
|
|
1735
|
+
try {
|
|
1736
|
+
_notifyWatchers();
|
|
1737
|
+
}
|
|
1738
|
+
catch (e) {
|
|
1739
|
+
watcherFailures_1[_DYN_PUSH ](e);
|
|
1740
|
+
}
|
|
1741
|
+
}
|
|
1742
|
+
if (watcherFailures_1[_DYN_LENGTH$2 ] > 0) {
|
|
1743
|
+
throwAggregationError("Watcher error(s): ", watcherFailures_1);
|
|
1744
|
+
}
|
|
1745
|
+
}
|
|
1746
|
+
}
|
|
1747
|
+
function _addWatcher(detail) {
|
|
1748
|
+
if (detail && detail.h[_DYN_LENGTH$2 ] > 0) {
|
|
1749
|
+
if (!_waitingHandlers) {
|
|
1750
|
+
_waitingHandlers = [];
|
|
1751
|
+
}
|
|
1752
|
+
if (!_watcherTimer) {
|
|
1753
|
+
_watcherTimer = scheduleTimeout(function () {
|
|
1754
|
+
_watcherTimer = null;
|
|
1755
|
+
_notifyWatchers();
|
|
1756
|
+
}, 0);
|
|
1757
|
+
}
|
|
1758
|
+
for (var idx = 0; idx < detail.h[_DYN_LENGTH$2 ]; idx++) {
|
|
1759
|
+
var handler = detail.h[idx];
|
|
1760
|
+
if (handler && arrIndexOf(_waitingHandlers, handler) === -1) {
|
|
1761
|
+
_waitingHandlers[_DYN_PUSH ](handler);
|
|
1762
|
+
}
|
|
1763
|
+
}
|
|
1764
|
+
}
|
|
1765
|
+
}
|
|
1766
|
+
function _trackHandler(handler, detail) {
|
|
1767
|
+
if (handler) {
|
|
1768
|
+
var details = handler[dynamicPropertyDetail] = handler[dynamicPropertyDetail] || [];
|
|
1769
|
+
if (arrIndexOf(details, detail) === -1) {
|
|
1770
|
+
details[_DYN_PUSH ](detail);
|
|
1771
|
+
}
|
|
1772
|
+
}
|
|
1773
|
+
}
|
|
1774
|
+
theState = (_a = {
|
|
1775
|
+
prop: dynamicPropertySymbol,
|
|
1776
|
+
ro: dynamicPropertyReadOnly,
|
|
1777
|
+
rf: dynamicPropertyReferenced,
|
|
1778
|
+
hdlr: cfgHandler,
|
|
1779
|
+
add: _addWatcher
|
|
1780
|
+
},
|
|
1781
|
+
_a[_DYN_NOTIFY ] = _notifyWatchers,
|
|
1782
|
+
_a.use = _useHandler,
|
|
1783
|
+
_a.trk = _trackHandler,
|
|
1784
|
+
_a);
|
|
1785
|
+
return theState;
|
|
1786
|
+
}
|
|
1787
|
+
|
|
1788
|
+
function _createAndUseHandler(state, configHandler) {
|
|
1789
|
+
var handler = {
|
|
1790
|
+
fn: configHandler,
|
|
1791
|
+
rm: function () {
|
|
1792
|
+
handler.fn = null;
|
|
1793
|
+
state = null;
|
|
1794
|
+
configHandler = null;
|
|
1795
|
+
}
|
|
1796
|
+
};
|
|
1797
|
+
state.use(handler, configHandler);
|
|
1798
|
+
return handler;
|
|
1799
|
+
}
|
|
1800
|
+
function _createDynamicHandler(logger, target, inPlace) {
|
|
1801
|
+
var _a;
|
|
1802
|
+
var dynamicHandler = getDynamicConfigHandler(target);
|
|
1803
|
+
if (dynamicHandler) {
|
|
1804
|
+
return dynamicHandler;
|
|
1805
|
+
}
|
|
1806
|
+
var uid = createUniqueNamespace("dyncfg", true);
|
|
1807
|
+
var newTarget = (target && inPlace !== false) ? target : _cfgDeepCopy(target);
|
|
1808
|
+
var theState;
|
|
1809
|
+
function _notifyWatchers() {
|
|
1810
|
+
theState[_DYN_NOTIFY ]();
|
|
1811
|
+
}
|
|
1812
|
+
function _setValue(target, name, value) {
|
|
1813
|
+
return _setDynamicProperty(theState, target, name, value)[name];
|
|
1814
|
+
}
|
|
1815
|
+
function _watch(configHandler) {
|
|
1816
|
+
return _createAndUseHandler(theState, configHandler);
|
|
1817
|
+
}
|
|
1818
|
+
function _block(configHandler, allowUpdate) {
|
|
1819
|
+
theState.use(null, function (details) {
|
|
1820
|
+
var prevUpd = theState.upd;
|
|
1821
|
+
try {
|
|
1822
|
+
if (!isUndefined(allowUpdate)) {
|
|
1823
|
+
theState.upd = allowUpdate;
|
|
1824
|
+
}
|
|
1825
|
+
configHandler(details);
|
|
1826
|
+
}
|
|
1827
|
+
finally {
|
|
1828
|
+
theState.upd = prevUpd;
|
|
1829
|
+
}
|
|
1830
|
+
});
|
|
1831
|
+
}
|
|
1832
|
+
function _ref(target, name) {
|
|
1833
|
+
return _setDynamicProperty(theState, target, name, target[name], true)[name];
|
|
1834
|
+
}
|
|
1835
|
+
function _rdOnly(target, name) {
|
|
1836
|
+
return _setDynamicProperty(theState, target, name, target[name], false, true)[name];
|
|
1837
|
+
}
|
|
1838
|
+
function _applyDefaults(theConfig, defaultValues) {
|
|
1839
|
+
if (defaultValues) {
|
|
1840
|
+
objForEachKey(defaultValues, function (name, value) {
|
|
1841
|
+
_applyDefaultValue(cfgHandler, theConfig, name, value);
|
|
1842
|
+
});
|
|
1843
|
+
}
|
|
1844
|
+
return theConfig;
|
|
1845
|
+
}
|
|
1846
|
+
var cfgHandler = (_a = {
|
|
1847
|
+
uid: null,
|
|
1848
|
+
cfg: newTarget
|
|
1849
|
+
},
|
|
1850
|
+
_a[_DYN_LOGGER ] = logger,
|
|
1851
|
+
_a[_DYN_NOTIFY ] = _notifyWatchers,
|
|
1852
|
+
_a.set = _setValue,
|
|
1853
|
+
_a[_DYN_SET_DF ] = _applyDefaults,
|
|
1854
|
+
_a[_DYN_WATCH ] = _watch,
|
|
1855
|
+
_a.ref = _ref,
|
|
1856
|
+
_a[_DYN_RD_ONLY ] = _rdOnly,
|
|
1857
|
+
_a._block = _block,
|
|
1858
|
+
_a);
|
|
1859
|
+
objDefine(cfgHandler, "uid", {
|
|
1860
|
+
c: false,
|
|
1861
|
+
e: false,
|
|
1862
|
+
w: false,
|
|
1863
|
+
v: uid
|
|
1864
|
+
});
|
|
1865
|
+
theState = _createState(cfgHandler);
|
|
1866
|
+
_makeDynamicObject(theState, newTarget);
|
|
1867
|
+
return cfgHandler;
|
|
1868
|
+
}
|
|
1869
|
+
function _logInvalidAccess(logger, message) {
|
|
1870
|
+
if (logger) {
|
|
1871
|
+
logger[STR_WARN_TO_CONSOLE ](message);
|
|
1872
|
+
logger[_DYN_THROW_INTERNAL ](2 , 108 , message);
|
|
1873
|
+
}
|
|
1874
|
+
else {
|
|
1875
|
+
throwInvalidAccess(message);
|
|
1876
|
+
}
|
|
1877
|
+
}
|
|
1878
|
+
function createDynamicConfig(config, defaultConfig, logger, inPlace) {
|
|
1879
|
+
var dynamicHandler = _createDynamicHandler(logger, config || {}, inPlace);
|
|
1880
|
+
if (defaultConfig) {
|
|
1881
|
+
dynamicHandler[_DYN_SET_DF ](dynamicHandler.cfg, defaultConfig);
|
|
1882
|
+
}
|
|
1883
|
+
return dynamicHandler;
|
|
1884
|
+
}
|
|
1885
|
+
function onConfigChange(config, configHandler, logger) {
|
|
1886
|
+
var handler = config[CFG_HANDLER_LINK] || config;
|
|
1887
|
+
if (handler.cfg && (handler.cfg === config || handler.cfg[CFG_HANDLER_LINK] === handler)) {
|
|
1888
|
+
return handler[_DYN_WATCH ](configHandler);
|
|
1889
|
+
}
|
|
1890
|
+
_logInvalidAccess(logger, STR_NOT_DYNAMIC_ERROR + dumpObj(config));
|
|
1891
|
+
return createDynamicConfig(config, null, logger)[_DYN_WATCH ](configHandler);
|
|
1892
|
+
}
|
|
1893
|
+
|
|
1894
|
+
function cfgDfMerge(defaultValue) {
|
|
1895
|
+
return {
|
|
1896
|
+
mrg: true,
|
|
1897
|
+
v: defaultValue
|
|
1898
|
+
};
|
|
1899
|
+
}
|
|
1900
|
+
|
|
1901
|
+
var _aiNamespace = null;
|
|
1902
|
+
function _getExtensionNamespace() {
|
|
1903
|
+
var target = getInst("Microsoft");
|
|
1904
|
+
if (target) {
|
|
1905
|
+
_aiNamespace = target["ApplicationInsights"];
|
|
1906
|
+
}
|
|
1907
|
+
return _aiNamespace;
|
|
1908
|
+
}
|
|
1909
|
+
function getDebugExt(config) {
|
|
1910
|
+
var ns = _aiNamespace;
|
|
1911
|
+
if (!ns && config.disableDbgExt !== true) {
|
|
1912
|
+
ns = _aiNamespace || _getExtensionNamespace();
|
|
1913
|
+
}
|
|
1914
|
+
return ns ? ns["ChromeDbgExt"] : null;
|
|
1915
|
+
}
|
|
1916
|
+
|
|
1917
|
+
var AiNonUserActionablePrefix = "AI (Internal): ";
|
|
1918
|
+
var AiUserActionablePrefix = "AI: ";
|
|
1919
|
+
var AIInternalMessagePrefix = "AITR_";
|
|
1920
|
+
var defaultValues$1 = {
|
|
1921
|
+
loggingLevelConsole: 0,
|
|
1922
|
+
loggingLevelTelemetry: 1,
|
|
1923
|
+
maxMessageLimit: 25,
|
|
1924
|
+
enableDebug: false
|
|
1925
|
+
};
|
|
1926
|
+
function _sanitizeDiagnosticText(text) {
|
|
1927
|
+
if (text) {
|
|
1928
|
+
return "\"" + text[_DYN_REPLACE ](/\"/g, STR_EMPTY) + "\"";
|
|
1929
|
+
}
|
|
1930
|
+
return STR_EMPTY;
|
|
1931
|
+
}
|
|
1932
|
+
function _logToConsole(func, message) {
|
|
1933
|
+
var theConsole = getConsole();
|
|
1934
|
+
if (!!theConsole) {
|
|
1935
|
+
var logFunc = "log";
|
|
1936
|
+
if (theConsole[func]) {
|
|
1937
|
+
logFunc = func;
|
|
1938
|
+
}
|
|
1939
|
+
if (isFunction(theConsole[logFunc])) {
|
|
1940
|
+
theConsole[logFunc](message);
|
|
1941
|
+
}
|
|
1942
|
+
}
|
|
1943
|
+
}
|
|
1944
|
+
var _InternalLogMessage = /** @class */ (function () {
|
|
1945
|
+
function _InternalLogMessage(msgId, msg, isUserAct, properties) {
|
|
1946
|
+
if (isUserAct === void 0) { isUserAct = false; }
|
|
1947
|
+
var _self = this;
|
|
1948
|
+
_self[_DYN_MESSAGE_ID ] = msgId;
|
|
1949
|
+
_self[_DYN_MESSAGE ] =
|
|
1950
|
+
(isUserAct ? AiUserActionablePrefix : AiNonUserActionablePrefix) +
|
|
1951
|
+
msgId;
|
|
1952
|
+
var strProps = STR_EMPTY;
|
|
1953
|
+
if (hasJSON()) {
|
|
1954
|
+
strProps = getJSON().stringify(properties);
|
|
1955
|
+
}
|
|
1956
|
+
var diagnosticText = (msg ? " message:" + _sanitizeDiagnosticText(msg) : STR_EMPTY) +
|
|
1957
|
+
(properties ? " props:" + _sanitizeDiagnosticText(strProps) : STR_EMPTY);
|
|
1958
|
+
_self[_DYN_MESSAGE ] += diagnosticText;
|
|
1959
|
+
}
|
|
1960
|
+
_InternalLogMessage.dataType = "MessageData";
|
|
1961
|
+
return _InternalLogMessage;
|
|
1962
|
+
}());
|
|
1963
|
+
function safeGetLogger(core, config) {
|
|
1964
|
+
return (core || {})[_DYN_LOGGER ] || new DiagnosticLogger(config);
|
|
1965
|
+
}
|
|
1966
|
+
var DiagnosticLogger = /** @class */ (function () {
|
|
1967
|
+
function DiagnosticLogger(config) {
|
|
1968
|
+
this.identifier = "DiagnosticLogger";
|
|
1969
|
+
this.queue = [];
|
|
1970
|
+
var _messageCount = 0;
|
|
1971
|
+
var _messageLogged = {};
|
|
1972
|
+
var _loggingLevelConsole;
|
|
1973
|
+
var _loggingLevelTelemetry;
|
|
1974
|
+
var _maxInternalMessageLimit;
|
|
1975
|
+
var _enableDebug;
|
|
1976
|
+
var _unloadHandler;
|
|
1977
|
+
dynamicProto(DiagnosticLogger, this, function (_self) {
|
|
1978
|
+
_unloadHandler = _setDefaultsFromConfig(config || {});
|
|
1979
|
+
_self.consoleLoggingLevel = function () { return _loggingLevelConsole; };
|
|
1980
|
+
_self[_DYN_THROW_INTERNAL ] = function (severity, msgId, msg, properties, isUserAct) {
|
|
1981
|
+
if (isUserAct === void 0) { isUserAct = false; }
|
|
1982
|
+
var message = new _InternalLogMessage(msgId, msg, isUserAct, properties);
|
|
1983
|
+
if (_enableDebug) {
|
|
1984
|
+
throw dumpObj(message);
|
|
1985
|
+
}
|
|
1986
|
+
else {
|
|
1987
|
+
var logFunc = severity === 1 ? STR_ERROR_TO_CONSOLE : STR_WARN_TO_CONSOLE;
|
|
1988
|
+
if (!isUndefined(message[_DYN_MESSAGE ])) {
|
|
1989
|
+
if (isUserAct) {
|
|
1990
|
+
var messageKey = +message[_DYN_MESSAGE_ID ];
|
|
1991
|
+
if (!_messageLogged[messageKey] && _loggingLevelConsole >= severity) {
|
|
1992
|
+
_self[logFunc](message[_DYN_MESSAGE ]);
|
|
1993
|
+
_messageLogged[messageKey] = true;
|
|
1994
|
+
}
|
|
1995
|
+
}
|
|
1996
|
+
else {
|
|
1997
|
+
if (_loggingLevelConsole >= severity) {
|
|
1998
|
+
_self[logFunc](message[_DYN_MESSAGE ]);
|
|
1999
|
+
}
|
|
2000
|
+
}
|
|
2001
|
+
_logInternalMessage(severity, message);
|
|
2002
|
+
}
|
|
2003
|
+
else {
|
|
2004
|
+
_debugExtMsg("throw" + (severity === 1 ? "Critical" : "Warning"), message);
|
|
2005
|
+
}
|
|
2006
|
+
}
|
|
2007
|
+
};
|
|
2008
|
+
_self[STR_WARN_TO_CONSOLE ] = function (message) {
|
|
2009
|
+
_logToConsole("warn", message);
|
|
2010
|
+
_debugExtMsg("warning", message);
|
|
2011
|
+
};
|
|
2012
|
+
_self[STR_ERROR_TO_CONSOLE ] = function (message) {
|
|
2013
|
+
_logToConsole("error", message);
|
|
2014
|
+
_debugExtMsg("error", message);
|
|
2015
|
+
};
|
|
2016
|
+
_self.resetInternalMessageCount = function () {
|
|
2017
|
+
_messageCount = 0;
|
|
2018
|
+
_messageLogged = {};
|
|
2019
|
+
};
|
|
2020
|
+
_self[_DYN_LOG_INTERNAL_MESSAGE ] = _logInternalMessage;
|
|
2021
|
+
_self[_DYN_UNLOAD ] = function (isAsync) {
|
|
2022
|
+
_unloadHandler && _unloadHandler.rm();
|
|
2023
|
+
_unloadHandler = null;
|
|
2024
|
+
};
|
|
2025
|
+
function _logInternalMessage(severity, message) {
|
|
2026
|
+
if (_areInternalMessagesThrottled()) {
|
|
2027
|
+
return;
|
|
2028
|
+
}
|
|
2029
|
+
var logMessage = true;
|
|
2030
|
+
var messageKey = AIInternalMessagePrefix + message[_DYN_MESSAGE_ID ];
|
|
2031
|
+
if (_messageLogged[messageKey]) {
|
|
2032
|
+
logMessage = false;
|
|
2033
|
+
}
|
|
2034
|
+
else {
|
|
2035
|
+
_messageLogged[messageKey] = true;
|
|
2036
|
+
}
|
|
2037
|
+
if (logMessage) {
|
|
2038
|
+
if (severity <= _loggingLevelTelemetry) {
|
|
2039
|
+
_self.queue[_DYN_PUSH ](message);
|
|
2040
|
+
_messageCount++;
|
|
2041
|
+
_debugExtMsg((severity === 1 ? "error" : "warn"), message);
|
|
2042
|
+
}
|
|
2043
|
+
if (_messageCount === _maxInternalMessageLimit) {
|
|
2044
|
+
var throttleLimitMessage = "Internal events throttle limit per PageView reached for this app.";
|
|
2045
|
+
var throttleMessage = new _InternalLogMessage(23 , throttleLimitMessage, false);
|
|
2046
|
+
_self.queue[_DYN_PUSH ](throttleMessage);
|
|
2047
|
+
if (severity === 1 ) {
|
|
2048
|
+
_self[STR_ERROR_TO_CONSOLE ](throttleLimitMessage);
|
|
2049
|
+
}
|
|
2050
|
+
else {
|
|
2051
|
+
_self[STR_WARN_TO_CONSOLE ](throttleLimitMessage);
|
|
2052
|
+
}
|
|
2053
|
+
}
|
|
2054
|
+
}
|
|
2055
|
+
}
|
|
2056
|
+
function _setDefaultsFromConfig(config) {
|
|
2057
|
+
return onConfigChange(createDynamicConfig(config, defaultValues$1, _self).cfg, function (details) {
|
|
2058
|
+
var config = details.cfg;
|
|
2059
|
+
_loggingLevelConsole = config[_DYN_LOGGING_LEVEL_CONSOL4 ];
|
|
2060
|
+
_loggingLevelTelemetry = config.loggingLevelTelemetry;
|
|
2061
|
+
_maxInternalMessageLimit = config.maxMessageLimit;
|
|
2062
|
+
_enableDebug = config.enableDebug;
|
|
2063
|
+
});
|
|
2064
|
+
}
|
|
2065
|
+
function _areInternalMessagesThrottled() {
|
|
2066
|
+
return _messageCount >= _maxInternalMessageLimit;
|
|
2067
|
+
}
|
|
2068
|
+
function _debugExtMsg(name, data) {
|
|
2069
|
+
var dbgExt = getDebugExt(config || {});
|
|
2070
|
+
if (dbgExt && dbgExt[_DYN_DIAG_LOG ]) {
|
|
2071
|
+
dbgExt[_DYN_DIAG_LOG ](name, data);
|
|
2072
|
+
}
|
|
2073
|
+
}
|
|
2074
|
+
});
|
|
2075
|
+
}
|
|
2076
|
+
DiagnosticLogger.__ieDyn=1;
|
|
2077
|
+
return DiagnosticLogger;
|
|
2078
|
+
}());
|
|
2079
|
+
function _getLogger(logger) {
|
|
2080
|
+
return (logger || new DiagnosticLogger());
|
|
2081
|
+
}
|
|
2082
|
+
function _throwInternal(logger, severity, msgId, msg, properties, isUserAct) {
|
|
2083
|
+
if (isUserAct === void 0) { isUserAct = false; }
|
|
2084
|
+
_getLogger(logger)[_DYN_THROW_INTERNAL ](severity, msgId, msg, properties, isUserAct);
|
|
2085
|
+
}
|
|
2086
|
+
function _logInternalMessage(logger, severity, message) {
|
|
2087
|
+
_getLogger(logger)[_DYN_LOG_INTERNAL_MESSAGE ](severity, message);
|
|
2088
|
+
}
|
|
2089
|
+
|
|
2090
|
+
var _a$2, _b;
|
|
2091
|
+
var strToGMTString = "toGMTString";
|
|
2092
|
+
var strToUTCString = "toUTCString";
|
|
2093
|
+
var strCookie = "cookie";
|
|
2094
|
+
var strExpires = "expires";
|
|
2095
|
+
var strIsCookieUseDisabled = "isCookieUseDisabled";
|
|
2096
|
+
var strDisableCookiesUsage = "disableCookiesUsage";
|
|
2097
|
+
var strConfigCookieMgr = "_ckMgr";
|
|
2098
|
+
var _supportsCookies = null;
|
|
2099
|
+
var _allowUaSameSite = null;
|
|
2100
|
+
var _parsedCookieValue = null;
|
|
2101
|
+
var _doc;
|
|
2102
|
+
var _cookieCache = {};
|
|
2103
|
+
var _globalCookieConfig = {};
|
|
2104
|
+
var rootDefaultConfig = (_a$2 = {
|
|
2105
|
+
cookieCfg: cfgDfMerge((_b = {},
|
|
2106
|
+
_b[STR_DOMAIN] = { fb: "cookieDomain", dfVal: isNotNullOrUndefined },
|
|
2107
|
+
_b.path = { fb: "cookiePath", dfVal: isNotNullOrUndefined },
|
|
2108
|
+
_b.enabled = UNDEFINED_VALUE,
|
|
2109
|
+
_b.ignoreCookies = UNDEFINED_VALUE,
|
|
2110
|
+
_b.blockedCookies = UNDEFINED_VALUE,
|
|
2111
|
+
_b)),
|
|
2112
|
+
cookieDomain: UNDEFINED_VALUE,
|
|
2113
|
+
cookiePath: UNDEFINED_VALUE
|
|
2114
|
+
},
|
|
2115
|
+
_a$2[strDisableCookiesUsage] = UNDEFINED_VALUE,
|
|
2116
|
+
_a$2);
|
|
2117
|
+
function _getDoc() {
|
|
2118
|
+
!_doc && (_doc = getLazy(function () { return getDocument(); }));
|
|
2119
|
+
}
|
|
2120
|
+
function _gblCookieMgr(config, logger) {
|
|
2121
|
+
var inst = createCookieMgr[strConfigCookieMgr] || _globalCookieConfig[strConfigCookieMgr];
|
|
2122
|
+
if (!inst) {
|
|
2123
|
+
inst = createCookieMgr[strConfigCookieMgr] = createCookieMgr(config, logger);
|
|
2124
|
+
_globalCookieConfig[strConfigCookieMgr] = inst;
|
|
2125
|
+
}
|
|
2126
|
+
return inst;
|
|
2127
|
+
}
|
|
2128
|
+
function _isMgrEnabled(cookieMgr) {
|
|
2129
|
+
if (cookieMgr) {
|
|
2130
|
+
return cookieMgr.isEnabled();
|
|
2131
|
+
}
|
|
2132
|
+
return true;
|
|
2133
|
+
}
|
|
2134
|
+
function _isIgnoredCookie(cookieMgrCfg, name) {
|
|
2135
|
+
if (name && cookieMgrCfg && isArray(cookieMgrCfg.ignoreCookies)) {
|
|
2136
|
+
return arrIndexOf(cookieMgrCfg.ignoreCookies, name) !== -1;
|
|
2137
|
+
}
|
|
2138
|
+
return false;
|
|
2139
|
+
}
|
|
2140
|
+
function _isBlockedCookie(cookieMgrCfg, name) {
|
|
2141
|
+
if (name && cookieMgrCfg && isArray(cookieMgrCfg.blockedCookies)) {
|
|
2142
|
+
if (arrIndexOf(cookieMgrCfg.blockedCookies, name) !== -1) {
|
|
2143
|
+
return true;
|
|
2144
|
+
}
|
|
2145
|
+
}
|
|
2146
|
+
return _isIgnoredCookie(cookieMgrCfg, name);
|
|
2147
|
+
}
|
|
2148
|
+
function _isCfgEnabled(rootConfig, cookieMgrConfig) {
|
|
2149
|
+
var isCfgEnabled = cookieMgrConfig[_DYN_ENABLED ];
|
|
2150
|
+
if (isNullOrUndefined(isCfgEnabled)) {
|
|
2151
|
+
var cookieEnabled = void 0;
|
|
2152
|
+
if (!isUndefined(rootConfig[strIsCookieUseDisabled])) {
|
|
2153
|
+
cookieEnabled = !rootConfig[strIsCookieUseDisabled];
|
|
2154
|
+
}
|
|
2155
|
+
if (!isUndefined(rootConfig[strDisableCookiesUsage])) {
|
|
2156
|
+
cookieEnabled = !rootConfig[strDisableCookiesUsage];
|
|
2157
|
+
}
|
|
2158
|
+
isCfgEnabled = cookieEnabled;
|
|
2159
|
+
}
|
|
2160
|
+
return isCfgEnabled;
|
|
2161
|
+
}
|
|
2162
|
+
function safeGetCookieMgr(core, config) {
|
|
2163
|
+
var cookieMgr;
|
|
2164
|
+
if (core) {
|
|
2165
|
+
cookieMgr = core.getCookieMgr();
|
|
2166
|
+
}
|
|
2167
|
+
else if (config) {
|
|
2168
|
+
var cookieCfg = config.cookieCfg;
|
|
2169
|
+
if (cookieCfg && cookieCfg[strConfigCookieMgr]) {
|
|
2170
|
+
cookieMgr = cookieCfg[strConfigCookieMgr];
|
|
2171
|
+
}
|
|
2172
|
+
else {
|
|
2173
|
+
cookieMgr = createCookieMgr(config);
|
|
2174
|
+
}
|
|
2175
|
+
}
|
|
2176
|
+
if (!cookieMgr) {
|
|
2177
|
+
cookieMgr = _gblCookieMgr(config, (core || {})[_DYN_LOGGER ]);
|
|
2178
|
+
}
|
|
2179
|
+
return cookieMgr;
|
|
2180
|
+
}
|
|
2181
|
+
function createCookieMgr(rootConfig, logger) {
|
|
2182
|
+
var _a;
|
|
2183
|
+
var cookieMgrConfig;
|
|
2184
|
+
var _path;
|
|
2185
|
+
var _domain;
|
|
2186
|
+
var unloadHandler;
|
|
2187
|
+
var _enabled;
|
|
2188
|
+
var _getCookieFn;
|
|
2189
|
+
var _setCookieFn;
|
|
2190
|
+
var _delCookieFn;
|
|
2191
|
+
rootConfig = createDynamicConfig(rootConfig || _globalCookieConfig, null, logger).cfg;
|
|
2192
|
+
unloadHandler = onConfigChange(rootConfig, function (details) {
|
|
2193
|
+
details[_DYN_SET_DF ](details.cfg, rootDefaultConfig);
|
|
2194
|
+
cookieMgrConfig = details.ref(details.cfg, "cookieCfg");
|
|
2195
|
+
_path = cookieMgrConfig[STR_PATH ] || "/";
|
|
2196
|
+
_domain = cookieMgrConfig[STR_DOMAIN ];
|
|
2197
|
+
_enabled = _isCfgEnabled(rootConfig, cookieMgrConfig) !== false;
|
|
2198
|
+
_getCookieFn = cookieMgrConfig.getCookie || _getCookieValue;
|
|
2199
|
+
_setCookieFn = cookieMgrConfig.setCookie || _setCookieValue;
|
|
2200
|
+
_delCookieFn = cookieMgrConfig.delCookie || _setCookieValue;
|
|
2201
|
+
}, logger);
|
|
2202
|
+
var cookieMgr = (_a = {
|
|
2203
|
+
isEnabled: function () {
|
|
2204
|
+
var enabled = _isCfgEnabled(rootConfig, cookieMgrConfig) !== false && _enabled && areCookiesSupported(logger);
|
|
2205
|
+
var gblManager = _globalCookieConfig[strConfigCookieMgr];
|
|
2206
|
+
if (enabled && gblManager && cookieMgr !== gblManager) {
|
|
2207
|
+
enabled = _isMgrEnabled(gblManager);
|
|
2208
|
+
}
|
|
2209
|
+
return enabled;
|
|
2210
|
+
},
|
|
2211
|
+
setEnabled: function (value) {
|
|
2212
|
+
_enabled = value !== false;
|
|
2213
|
+
cookieMgrConfig[_DYN_ENABLED ] = value;
|
|
2214
|
+
},
|
|
2215
|
+
set: function (name, value, maxAgeSec, domain, path) {
|
|
2216
|
+
var result = false;
|
|
2217
|
+
if (_isMgrEnabled(cookieMgr) && !_isBlockedCookie(cookieMgrConfig, name)) {
|
|
2218
|
+
var values = {};
|
|
2219
|
+
var theValue = strTrim(value || STR_EMPTY);
|
|
2220
|
+
var idx = strIndexOf(theValue, ";");
|
|
2221
|
+
if (idx !== -1) {
|
|
2222
|
+
theValue = strTrim(strLeft(value, idx));
|
|
2223
|
+
values = _extractParts(strSubstring(value, idx + 1));
|
|
2224
|
+
}
|
|
2225
|
+
setValue(values, STR_DOMAIN, domain || _domain, isTruthy, isUndefined);
|
|
2226
|
+
if (!isNullOrUndefined(maxAgeSec)) {
|
|
2227
|
+
var _isIE = isIE();
|
|
2228
|
+
if (isUndefined(values[strExpires])) {
|
|
2229
|
+
var nowMs = utcNow();
|
|
2230
|
+
var expireMs = nowMs + (maxAgeSec * 1000);
|
|
2231
|
+
if (expireMs > 0) {
|
|
2232
|
+
var expiry = new Date();
|
|
2233
|
+
expiry.setTime(expireMs);
|
|
2234
|
+
setValue(values, strExpires, _formatDate(expiry, !_isIE ? strToUTCString : strToGMTString) || _formatDate(expiry, _isIE ? strToGMTString : strToUTCString) || STR_EMPTY, isTruthy);
|
|
2235
|
+
}
|
|
2236
|
+
}
|
|
2237
|
+
if (!_isIE) {
|
|
2238
|
+
setValue(values, "max-age", STR_EMPTY + maxAgeSec, null, isUndefined);
|
|
2239
|
+
}
|
|
2240
|
+
}
|
|
2241
|
+
var location_1 = getLocation();
|
|
2242
|
+
if (location_1 && location_1.protocol === "https:") {
|
|
2243
|
+
setValue(values, "secure", null, null, isUndefined);
|
|
2244
|
+
if (_allowUaSameSite === null) {
|
|
2245
|
+
_allowUaSameSite = !uaDisallowsSameSiteNone((getNavigator() || {})[_DYN_USER_AGENT ]);
|
|
2246
|
+
}
|
|
2247
|
+
if (_allowUaSameSite) {
|
|
2248
|
+
setValue(values, "SameSite", "None", null, isUndefined);
|
|
2249
|
+
}
|
|
2250
|
+
}
|
|
2251
|
+
setValue(values, STR_PATH, path || _path, null, isUndefined);
|
|
2252
|
+
_setCookieFn(name, _formatCookieValue(theValue, values));
|
|
2253
|
+
result = true;
|
|
2254
|
+
}
|
|
2255
|
+
return result;
|
|
2256
|
+
},
|
|
2257
|
+
get: function (name) {
|
|
2258
|
+
var value = STR_EMPTY;
|
|
2259
|
+
if (_isMgrEnabled(cookieMgr) && !_isIgnoredCookie(cookieMgrConfig, name)) {
|
|
2260
|
+
value = _getCookieFn(name);
|
|
2261
|
+
}
|
|
2262
|
+
return value;
|
|
2263
|
+
},
|
|
2264
|
+
del: function (name, path) {
|
|
2265
|
+
var result = false;
|
|
2266
|
+
if (_isMgrEnabled(cookieMgr)) {
|
|
2267
|
+
result = cookieMgr.purge(name, path);
|
|
2268
|
+
}
|
|
2269
|
+
return result;
|
|
2270
|
+
},
|
|
2271
|
+
purge: function (name, path) {
|
|
2272
|
+
var _a;
|
|
2273
|
+
var result = false;
|
|
2274
|
+
if (areCookiesSupported(logger)) {
|
|
2275
|
+
var values = (_a = {},
|
|
2276
|
+
_a[STR_PATH] = path ? path : "/",
|
|
2277
|
+
_a[strExpires] = "Thu, 01 Jan 1970 00:00:01 GMT",
|
|
2278
|
+
_a);
|
|
2279
|
+
if (!isIE()) {
|
|
2280
|
+
values["max-age"] = "0";
|
|
2281
|
+
}
|
|
2282
|
+
_delCookieFn(name, _formatCookieValue(STR_EMPTY, values));
|
|
2283
|
+
result = true;
|
|
2284
|
+
}
|
|
2285
|
+
return result;
|
|
2286
|
+
}
|
|
2287
|
+
},
|
|
2288
|
+
_a[_DYN_UNLOAD ] = function (isAsync) {
|
|
2289
|
+
unloadHandler && unloadHandler.rm();
|
|
2290
|
+
unloadHandler = null;
|
|
2291
|
+
},
|
|
2292
|
+
_a);
|
|
2293
|
+
cookieMgr[strConfigCookieMgr] = cookieMgr;
|
|
2294
|
+
return cookieMgr;
|
|
2295
|
+
}
|
|
2296
|
+
function areCookiesSupported(logger) {
|
|
2297
|
+
if (_supportsCookies === null) {
|
|
2298
|
+
_supportsCookies = false;
|
|
2299
|
+
!_doc && _getDoc();
|
|
2300
|
+
try {
|
|
2301
|
+
var doc = _doc.v || {};
|
|
2302
|
+
_supportsCookies = doc[strCookie] !== undefined;
|
|
2303
|
+
}
|
|
2304
|
+
catch (e) {
|
|
2305
|
+
_throwInternal(logger, 2 , 68 , "Cannot access document.cookie - " + getExceptionName(e), { exception: dumpObj(e) });
|
|
2306
|
+
}
|
|
2307
|
+
}
|
|
2308
|
+
return _supportsCookies;
|
|
2309
|
+
}
|
|
2310
|
+
function _extractParts(theValue) {
|
|
2311
|
+
var values = {};
|
|
2312
|
+
if (theValue && theValue[_DYN_LENGTH$2 ]) {
|
|
2313
|
+
var parts = strTrim(theValue)[_DYN_SPLIT ](";");
|
|
2314
|
+
arrForEach(parts, function (thePart) {
|
|
2315
|
+
thePart = strTrim(thePart || STR_EMPTY);
|
|
2316
|
+
if (thePart) {
|
|
2317
|
+
var idx = strIndexOf(thePart, "=");
|
|
2318
|
+
if (idx === -1) {
|
|
2319
|
+
values[thePart] = null;
|
|
2320
|
+
}
|
|
2321
|
+
else {
|
|
2322
|
+
values[strTrim(strLeft(thePart, idx))] = strTrim(strSubstring(thePart, idx + 1));
|
|
2323
|
+
}
|
|
2324
|
+
}
|
|
2325
|
+
});
|
|
2326
|
+
}
|
|
2327
|
+
return values;
|
|
2328
|
+
}
|
|
2329
|
+
function _formatDate(theDate, func) {
|
|
2330
|
+
if (isFunction(theDate[func])) {
|
|
2331
|
+
return theDate[func]();
|
|
2332
|
+
}
|
|
2333
|
+
return null;
|
|
2334
|
+
}
|
|
2335
|
+
function _formatCookieValue(value, values) {
|
|
2336
|
+
var cookieValue = value || STR_EMPTY;
|
|
2337
|
+
objForEachKey(values, function (name, theValue) {
|
|
2338
|
+
cookieValue += "; " + name + (!isNullOrUndefined(theValue) ? "=" + theValue : STR_EMPTY);
|
|
2339
|
+
});
|
|
2340
|
+
return cookieValue;
|
|
2341
|
+
}
|
|
2342
|
+
function _getCookieValue(name) {
|
|
2343
|
+
var cookieValue = STR_EMPTY;
|
|
2344
|
+
!_doc && _getDoc();
|
|
2345
|
+
if (_doc.v) {
|
|
2346
|
+
var theCookie = _doc.v[strCookie] || STR_EMPTY;
|
|
2347
|
+
if (_parsedCookieValue !== theCookie) {
|
|
2348
|
+
_cookieCache = _extractParts(theCookie);
|
|
2349
|
+
_parsedCookieValue = theCookie;
|
|
2350
|
+
}
|
|
2351
|
+
cookieValue = strTrim(_cookieCache[name] || STR_EMPTY);
|
|
2352
|
+
}
|
|
2353
|
+
return cookieValue;
|
|
2354
|
+
}
|
|
2355
|
+
function _setCookieValue(name, cookieValue) {
|
|
2356
|
+
!_doc && _getDoc();
|
|
2357
|
+
if (_doc.v) {
|
|
2358
|
+
_doc.v[strCookie] = name + "=" + cookieValue;
|
|
2359
|
+
}
|
|
2360
|
+
}
|
|
2361
|
+
function uaDisallowsSameSiteNone(userAgent) {
|
|
2362
|
+
if (!isString(userAgent)) {
|
|
2363
|
+
return false;
|
|
2364
|
+
}
|
|
2365
|
+
if (strContains(userAgent, "CPU iPhone OS 12") || strContains(userAgent, "iPad; CPU OS 12")) {
|
|
2366
|
+
return true;
|
|
2367
|
+
}
|
|
2368
|
+
if (strContains(userAgent, "Macintosh; Intel Mac OS X 10_14") && strContains(userAgent, "Version/") && strContains(userAgent, "Safari")) {
|
|
2369
|
+
return true;
|
|
2370
|
+
}
|
|
2371
|
+
if (strContains(userAgent, "Macintosh; Intel Mac OS X 10_14") && strEndsWith(userAgent, "AppleWebKit/605.1.15 (KHTML, like Gecko)")) {
|
|
2372
|
+
return true;
|
|
2373
|
+
}
|
|
2374
|
+
if (strContains(userAgent, "Chrome/5") || strContains(userAgent, "Chrome/6")) {
|
|
2375
|
+
return true;
|
|
2376
|
+
}
|
|
2377
|
+
if (strContains(userAgent, "UnrealEngine") && !strContains(userAgent, "Chrome")) {
|
|
2378
|
+
return true;
|
|
2379
|
+
}
|
|
2380
|
+
if (strContains(userAgent, "UCBrowser/12") || strContains(userAgent, "UCBrowser/11")) {
|
|
2381
|
+
return true;
|
|
2382
|
+
}
|
|
2383
|
+
return false;
|
|
2384
|
+
}
|
|
2385
|
+
|
|
2386
|
+
var strExecutionContextKey = "ctx";
|
|
2387
|
+
var strParentContextKey = "ParentContextKey";
|
|
2388
|
+
var strChildrenContextKey = "ChildrenContextKey";
|
|
2389
|
+
var PerfEvent = /** @class */ (function () {
|
|
2390
|
+
function PerfEvent(name, payloadDetails, isAsync) {
|
|
2391
|
+
var _self = this;
|
|
2392
|
+
_self.start = utcNow();
|
|
2393
|
+
_self[_DYN_NAME$1 ] = name;
|
|
2394
|
+
_self[_DYN_IS_ASYNC ] = isAsync;
|
|
2395
|
+
_self[_DYN_IS_CHILD_EVT ] = function () { return false; };
|
|
2396
|
+
if (isFunction(payloadDetails)) {
|
|
2397
|
+
var theDetails_1;
|
|
2398
|
+
objDefine(_self, "payload", {
|
|
2399
|
+
g: function () {
|
|
2400
|
+
if (!theDetails_1 && isFunction(payloadDetails)) {
|
|
2401
|
+
theDetails_1 = payloadDetails();
|
|
2402
|
+
payloadDetails = null;
|
|
2403
|
+
}
|
|
2404
|
+
return theDetails_1;
|
|
2405
|
+
}
|
|
2406
|
+
});
|
|
2407
|
+
}
|
|
2408
|
+
_self[_DYN_GET_CTX ] = function (key) {
|
|
2409
|
+
if (key) {
|
|
2410
|
+
if (key === PerfEvent[strParentContextKey] || key === PerfEvent[strChildrenContextKey]) {
|
|
2411
|
+
return _self[key];
|
|
2412
|
+
}
|
|
2413
|
+
return (_self[strExecutionContextKey] || {})[key];
|
|
2414
|
+
}
|
|
2415
|
+
return null;
|
|
2416
|
+
};
|
|
2417
|
+
_self[_DYN_SET_CTX ] = function (key, value) {
|
|
2418
|
+
if (key) {
|
|
2419
|
+
if (key === PerfEvent[strParentContextKey]) {
|
|
2420
|
+
if (!_self[key]) {
|
|
2421
|
+
_self[_DYN_IS_CHILD_EVT ] = function () { return true; };
|
|
2422
|
+
}
|
|
2423
|
+
_self[key] = value;
|
|
2424
|
+
}
|
|
2425
|
+
else if (key === PerfEvent[strChildrenContextKey]) {
|
|
2426
|
+
_self[key] = value;
|
|
2427
|
+
}
|
|
2428
|
+
else {
|
|
2429
|
+
var ctx = _self[strExecutionContextKey] = _self[strExecutionContextKey] || {};
|
|
2430
|
+
ctx[key] = value;
|
|
2431
|
+
}
|
|
2432
|
+
}
|
|
2433
|
+
};
|
|
2434
|
+
_self[_DYN_COMPLETE ] = function () {
|
|
2435
|
+
var childTime = 0;
|
|
2436
|
+
var childEvts = _self[_DYN_GET_CTX ](PerfEvent[strChildrenContextKey]);
|
|
2437
|
+
if (isArray(childEvts)) {
|
|
2438
|
+
for (var lp = 0; lp < childEvts[_DYN_LENGTH$2 ]; lp++) {
|
|
2439
|
+
var childEvt = childEvts[lp];
|
|
2440
|
+
if (childEvt) {
|
|
2441
|
+
childTime += childEvt[_DYN_TIME ];
|
|
2442
|
+
}
|
|
2443
|
+
}
|
|
2444
|
+
}
|
|
2445
|
+
_self[_DYN_TIME ] = utcNow() - _self.start;
|
|
2446
|
+
_self.exTime = _self[_DYN_TIME ] - childTime;
|
|
2447
|
+
_self[_DYN_COMPLETE ] = function () { };
|
|
2448
|
+
};
|
|
2449
|
+
}
|
|
2450
|
+
PerfEvent.ParentContextKey = "parent";
|
|
2451
|
+
PerfEvent.ChildrenContextKey = "childEvts";
|
|
2452
|
+
return PerfEvent;
|
|
2453
|
+
}());
|
|
2454
|
+
var doPerfActiveKey = "CoreUtils.doPerf";
|
|
2455
|
+
function doPerf(mgrSource, getSource, func, details, isAsync) {
|
|
2456
|
+
if (mgrSource) {
|
|
2457
|
+
var perfMgr = mgrSource;
|
|
2458
|
+
if (perfMgr[STR_GET_PERF_MGR]) {
|
|
2459
|
+
perfMgr = perfMgr[STR_GET_PERF_MGR]();
|
|
2460
|
+
}
|
|
2461
|
+
if (perfMgr) {
|
|
2462
|
+
var perfEvt = void 0;
|
|
2463
|
+
var currentActive = perfMgr[_DYN_GET_CTX ](doPerfActiveKey);
|
|
2464
|
+
try {
|
|
2465
|
+
perfEvt = perfMgr.create(getSource(), details, isAsync);
|
|
2466
|
+
if (perfEvt) {
|
|
2467
|
+
if (currentActive && perfEvt[_DYN_SET_CTX ]) {
|
|
2468
|
+
perfEvt[_DYN_SET_CTX ](PerfEvent[strParentContextKey], currentActive);
|
|
2469
|
+
if (currentActive[_DYN_GET_CTX ] && currentActive[_DYN_SET_CTX ]) {
|
|
2470
|
+
var children = currentActive[_DYN_GET_CTX ](PerfEvent[strChildrenContextKey]);
|
|
2471
|
+
if (!children) {
|
|
2472
|
+
children = [];
|
|
2473
|
+
currentActive[_DYN_SET_CTX ](PerfEvent[strChildrenContextKey], children);
|
|
2474
|
+
}
|
|
2475
|
+
children[_DYN_PUSH ](perfEvt);
|
|
2476
|
+
}
|
|
2477
|
+
}
|
|
2478
|
+
perfMgr[_DYN_SET_CTX ](doPerfActiveKey, perfEvt);
|
|
2479
|
+
return func(perfEvt);
|
|
2480
|
+
}
|
|
2481
|
+
}
|
|
2482
|
+
catch (ex) {
|
|
2483
|
+
if (perfEvt && perfEvt[_DYN_SET_CTX ]) {
|
|
2484
|
+
perfEvt[_DYN_SET_CTX ]("exception", ex);
|
|
2485
|
+
}
|
|
2486
|
+
}
|
|
2487
|
+
finally {
|
|
2488
|
+
if (perfEvt) {
|
|
2489
|
+
perfMgr.fire(perfEvt);
|
|
2490
|
+
}
|
|
2491
|
+
perfMgr[_DYN_SET_CTX ](doPerfActiveKey, currentActive);
|
|
2492
|
+
}
|
|
2493
|
+
}
|
|
2494
|
+
}
|
|
2495
|
+
return func();
|
|
2496
|
+
}
|
|
2497
|
+
|
|
2498
|
+
function generateW3CId() {
|
|
2499
|
+
var hexValues = ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f"];
|
|
2500
|
+
var oct = STR_EMPTY, tmp;
|
|
2501
|
+
for (var a = 0; a < 4; a++) {
|
|
2502
|
+
tmp = random32();
|
|
2503
|
+
oct +=
|
|
2504
|
+
hexValues[tmp & 0xF] +
|
|
2505
|
+
hexValues[tmp >> 4 & 0xF] +
|
|
2506
|
+
hexValues[tmp >> 8 & 0xF] +
|
|
2507
|
+
hexValues[tmp >> 12 & 0xF] +
|
|
2508
|
+
hexValues[tmp >> 16 & 0xF] +
|
|
2509
|
+
hexValues[tmp >> 20 & 0xF] +
|
|
2510
|
+
hexValues[tmp >> 24 & 0xF] +
|
|
2511
|
+
hexValues[tmp >> 28 & 0xF];
|
|
2512
|
+
}
|
|
2513
|
+
var clockSequenceHi = hexValues[8 + (random32() & 0x03) | 0];
|
|
2514
|
+
return strSubstr(oct, 0, 8) + strSubstr(oct, 9, 4) + "4" + strSubstr(oct, 13, 3) + clockSequenceHi + strSubstr(oct, 16, 3) + strSubstr(oct, 19, 12);
|
|
2515
|
+
}
|
|
2516
|
+
|
|
2517
|
+
var INVALID_TRACE_ID = "00000000000000000000000000000000";
|
|
2518
|
+
var INVALID_SPAN_ID = "0000000000000000";
|
|
2519
|
+
function _isValid(value, len, invalidValue) {
|
|
2520
|
+
if (value && value[_DYN_LENGTH$2 ] === len && value !== invalidValue) {
|
|
2521
|
+
return !!value.match(/^[\da-f]*$/i);
|
|
2522
|
+
}
|
|
2523
|
+
return false;
|
|
2524
|
+
}
|
|
2525
|
+
function isValidTraceId(value) {
|
|
2526
|
+
return _isValid(value, 32, INVALID_TRACE_ID);
|
|
2527
|
+
}
|
|
2528
|
+
function isValidSpanId(value) {
|
|
2529
|
+
return _isValid(value, 16, INVALID_SPAN_ID);
|
|
2530
|
+
}
|
|
2531
|
+
|
|
2532
|
+
var pluginStateData = createElmNodeData("plugin");
|
|
2533
|
+
function _getPluginState(plugin) {
|
|
2534
|
+
return pluginStateData.get(plugin, "state", {}, true);
|
|
2535
|
+
}
|
|
2536
|
+
|
|
2537
|
+
var strTelemetryPluginChain = "TelemetryPluginChain";
|
|
2538
|
+
var strHasRunFlags = "_hasRun";
|
|
2539
|
+
var strGetTelCtx = "_getTelCtx";
|
|
2540
|
+
var _chainId = 0;
|
|
2541
|
+
function _getNextProxyStart(proxy, core, startAt) {
|
|
2542
|
+
while (proxy) {
|
|
2543
|
+
if (proxy[_DYN_GET_PLUGIN ]() === startAt) {
|
|
2544
|
+
return proxy;
|
|
2545
|
+
}
|
|
2546
|
+
proxy = proxy[_DYN_GET_NEXT ]();
|
|
2547
|
+
}
|
|
2548
|
+
return createTelemetryProxyChain([startAt], core.config || {}, core);
|
|
2549
|
+
}
|
|
2550
|
+
function _createInternalContext(telemetryChain, dynamicHandler, core, startAt) {
|
|
2551
|
+
var _nextProxy = null;
|
|
2552
|
+
var _onComplete = [];
|
|
2553
|
+
if (!dynamicHandler) {
|
|
2554
|
+
dynamicHandler = createDynamicConfig({}, null, core[_DYN_LOGGER ]);
|
|
2555
|
+
}
|
|
2556
|
+
if (startAt !== null) {
|
|
2557
|
+
_nextProxy = startAt ? _getNextProxyStart(telemetryChain, core, startAt) : telemetryChain;
|
|
2558
|
+
}
|
|
2559
|
+
var context = {
|
|
2560
|
+
_next: _moveNext,
|
|
2561
|
+
ctx: {
|
|
2562
|
+
core: function () {
|
|
2563
|
+
return core;
|
|
2564
|
+
},
|
|
2565
|
+
diagLog: function () {
|
|
2566
|
+
return safeGetLogger(core, dynamicHandler.cfg);
|
|
2567
|
+
},
|
|
2568
|
+
getCfg: function () {
|
|
2569
|
+
return dynamicHandler.cfg;
|
|
2570
|
+
},
|
|
2571
|
+
getExtCfg: _resolveExtCfg,
|
|
2572
|
+
getConfig: _getConfig,
|
|
2573
|
+
hasNext: function () {
|
|
2574
|
+
return !!_nextProxy;
|
|
2575
|
+
},
|
|
2576
|
+
getNext: function () {
|
|
2577
|
+
return _nextProxy;
|
|
2578
|
+
},
|
|
2579
|
+
setNext: function (nextPlugin) {
|
|
2580
|
+
_nextProxy = nextPlugin;
|
|
2581
|
+
},
|
|
2582
|
+
iterate: _iterateChain,
|
|
2583
|
+
onComplete: _addOnComplete
|
|
2584
|
+
}
|
|
2585
|
+
};
|
|
2586
|
+
function _addOnComplete(onComplete, that) {
|
|
2587
|
+
var args = [];
|
|
2588
|
+
for (var _i = 2; _i < arguments.length; _i++) {
|
|
2589
|
+
args[_i - 2] = arguments[_i];
|
|
2590
|
+
}
|
|
2591
|
+
if (onComplete) {
|
|
2592
|
+
_onComplete[_DYN_PUSH ]({
|
|
2593
|
+
func: onComplete,
|
|
2594
|
+
self: !isUndefined(that) ? that : context.ctx,
|
|
2595
|
+
args: args
|
|
2596
|
+
});
|
|
2597
|
+
}
|
|
2598
|
+
}
|
|
2599
|
+
function _moveNext() {
|
|
2600
|
+
var nextProxy = _nextProxy;
|
|
2601
|
+
_nextProxy = nextProxy ? nextProxy[_DYN_GET_NEXT ]() : null;
|
|
2602
|
+
if (!nextProxy) {
|
|
2603
|
+
var onComplete = _onComplete;
|
|
2604
|
+
if (onComplete && onComplete[_DYN_LENGTH$2 ] > 0) {
|
|
2605
|
+
arrForEach(onComplete, function (completeDetails) {
|
|
2606
|
+
try {
|
|
2607
|
+
completeDetails.func.call(completeDetails.self, completeDetails.args);
|
|
2608
|
+
}
|
|
2609
|
+
catch (e) {
|
|
2610
|
+
_throwInternal(core[_DYN_LOGGER ], 2 , 73 , "Unexpected Exception during onComplete - " + dumpObj(e));
|
|
2611
|
+
}
|
|
2612
|
+
});
|
|
2613
|
+
_onComplete = [];
|
|
2614
|
+
}
|
|
2615
|
+
}
|
|
2616
|
+
return nextProxy;
|
|
2617
|
+
}
|
|
2618
|
+
function _getExtCfg(identifier, createIfMissing) {
|
|
2619
|
+
var idCfg = null;
|
|
2620
|
+
var cfg = dynamicHandler.cfg;
|
|
2621
|
+
if (cfg && identifier) {
|
|
2622
|
+
var extCfg = cfg[STR_EXTENSION_CONFIG ];
|
|
2623
|
+
if (!extCfg && createIfMissing) {
|
|
2624
|
+
extCfg = {};
|
|
2625
|
+
}
|
|
2626
|
+
cfg[STR_EXTENSION_CONFIG] = extCfg;
|
|
2627
|
+
extCfg = dynamicHandler.ref(cfg, STR_EXTENSION_CONFIG);
|
|
2628
|
+
if (extCfg) {
|
|
2629
|
+
idCfg = extCfg[identifier];
|
|
2630
|
+
if (!idCfg && createIfMissing) {
|
|
2631
|
+
idCfg = {};
|
|
2632
|
+
}
|
|
2633
|
+
extCfg[identifier] = idCfg;
|
|
2634
|
+
idCfg = dynamicHandler.ref(extCfg, identifier);
|
|
2635
|
+
}
|
|
2636
|
+
}
|
|
2637
|
+
return idCfg;
|
|
2638
|
+
}
|
|
2639
|
+
function _resolveExtCfg(identifier, defaultValues) {
|
|
2640
|
+
var newConfig = _getExtCfg(identifier, true);
|
|
2641
|
+
if (defaultValues) {
|
|
2642
|
+
objForEachKey(defaultValues, function (field, defaultValue) {
|
|
2643
|
+
if (isNullOrUndefined(newConfig[field])) {
|
|
2644
|
+
var cfgValue = dynamicHandler.cfg[field];
|
|
2645
|
+
if (cfgValue || !isNullOrUndefined(cfgValue)) {
|
|
2646
|
+
newConfig[field] = cfgValue;
|
|
2647
|
+
}
|
|
2648
|
+
}
|
|
2649
|
+
_applyDefaultValue(dynamicHandler, newConfig, field, defaultValue);
|
|
2650
|
+
});
|
|
2651
|
+
}
|
|
2652
|
+
return dynamicHandler[_DYN_SET_DF ](newConfig, defaultValues);
|
|
2653
|
+
}
|
|
2654
|
+
function _getConfig(identifier, field, defaultValue) {
|
|
2655
|
+
if (defaultValue === void 0) { defaultValue = false; }
|
|
2656
|
+
var theValue;
|
|
2657
|
+
var extConfig = _getExtCfg(identifier, false);
|
|
2658
|
+
var rootConfig = dynamicHandler.cfg;
|
|
2659
|
+
if (extConfig && (extConfig[field] || !isNullOrUndefined(extConfig[field]))) {
|
|
2660
|
+
theValue = extConfig[field];
|
|
2661
|
+
}
|
|
2662
|
+
else if (rootConfig[field] || !isNullOrUndefined(rootConfig[field])) {
|
|
2663
|
+
theValue = rootConfig[field];
|
|
2664
|
+
}
|
|
2665
|
+
return (theValue || !isNullOrUndefined(theValue)) ? theValue : defaultValue;
|
|
2666
|
+
}
|
|
2667
|
+
function _iterateChain(cb) {
|
|
2668
|
+
var nextPlugin;
|
|
2669
|
+
while (!!(nextPlugin = context._next())) {
|
|
2670
|
+
var plugin = nextPlugin[_DYN_GET_PLUGIN ]();
|
|
2671
|
+
if (plugin) {
|
|
2672
|
+
cb(plugin);
|
|
2673
|
+
}
|
|
2674
|
+
}
|
|
2675
|
+
}
|
|
2676
|
+
return context;
|
|
2677
|
+
}
|
|
2678
|
+
function createProcessTelemetryContext(telemetryChain, cfg, core, startAt) {
|
|
2679
|
+
var config = createDynamicConfig(cfg);
|
|
2680
|
+
var internalContext = _createInternalContext(telemetryChain, config, core, startAt);
|
|
2681
|
+
var context = internalContext.ctx;
|
|
2682
|
+
function _processNext(env) {
|
|
2683
|
+
var nextPlugin = internalContext._next();
|
|
2684
|
+
if (nextPlugin) {
|
|
2685
|
+
nextPlugin[STR_PROCESS_TELEMETRY ](env, context);
|
|
2686
|
+
}
|
|
2687
|
+
return !nextPlugin;
|
|
2688
|
+
}
|
|
2689
|
+
function _createNew(plugins, startAt) {
|
|
2690
|
+
if (plugins === void 0) { plugins = null; }
|
|
2691
|
+
if (isArray(plugins)) {
|
|
2692
|
+
plugins = createTelemetryProxyChain(plugins, config.cfg, core, startAt);
|
|
2693
|
+
}
|
|
2694
|
+
return createProcessTelemetryContext(plugins || context[_DYN_GET_NEXT ](), config.cfg, core, startAt);
|
|
2695
|
+
}
|
|
2696
|
+
context[_DYN_PROCESS_NEXT ] = _processNext;
|
|
2697
|
+
context[_DYN_CREATE_NEW ] = _createNew;
|
|
2698
|
+
return context;
|
|
2699
|
+
}
|
|
2700
|
+
function createProcessTelemetryUnloadContext(telemetryChain, core, startAt) {
|
|
2701
|
+
var config = createDynamicConfig(core.config);
|
|
2702
|
+
var internalContext = _createInternalContext(telemetryChain, config, core, startAt);
|
|
2703
|
+
var context = internalContext.ctx;
|
|
2704
|
+
function _processNext(unloadState) {
|
|
2705
|
+
var nextPlugin = internalContext._next();
|
|
2706
|
+
nextPlugin && nextPlugin[_DYN_UNLOAD ](context, unloadState);
|
|
2707
|
+
return !nextPlugin;
|
|
2708
|
+
}
|
|
2709
|
+
function _createNew(plugins, startAt) {
|
|
2710
|
+
if (plugins === void 0) { plugins = null; }
|
|
2711
|
+
if (isArray(plugins)) {
|
|
2712
|
+
plugins = createTelemetryProxyChain(plugins, config.cfg, core, startAt);
|
|
2713
|
+
}
|
|
2714
|
+
return createProcessTelemetryUnloadContext(plugins || context[_DYN_GET_NEXT ](), core, startAt);
|
|
2715
|
+
}
|
|
2716
|
+
context[_DYN_PROCESS_NEXT ] = _processNext;
|
|
2717
|
+
context[_DYN_CREATE_NEW ] = _createNew;
|
|
2718
|
+
return context;
|
|
2719
|
+
}
|
|
2720
|
+
function createProcessTelemetryUpdateContext(telemetryChain, core, startAt) {
|
|
2721
|
+
var config = createDynamicConfig(core.config);
|
|
2722
|
+
var internalContext = _createInternalContext(telemetryChain, config, core, startAt);
|
|
2723
|
+
var context = internalContext.ctx;
|
|
2724
|
+
function _processNext(updateState) {
|
|
2725
|
+
return context.iterate(function (plugin) {
|
|
2726
|
+
if (isFunction(plugin[_DYN_UPDATE$1 ])) {
|
|
2727
|
+
plugin[_DYN_UPDATE$1 ](context, updateState);
|
|
2728
|
+
}
|
|
2729
|
+
});
|
|
2730
|
+
}
|
|
2731
|
+
function _createNew(plugins, startAt) {
|
|
2732
|
+
if (plugins === void 0) { plugins = null; }
|
|
2733
|
+
if (isArray(plugins)) {
|
|
2734
|
+
plugins = createTelemetryProxyChain(plugins, config.cfg, core, startAt);
|
|
2735
|
+
}
|
|
2736
|
+
return createProcessTelemetryUpdateContext(plugins || context[_DYN_GET_NEXT ](), core, startAt);
|
|
2737
|
+
}
|
|
2738
|
+
context[_DYN_PROCESS_NEXT ] = _processNext;
|
|
2739
|
+
context[_DYN_CREATE_NEW ] = _createNew;
|
|
2740
|
+
return context;
|
|
2741
|
+
}
|
|
2742
|
+
function createTelemetryProxyChain(plugins, config, core, startAt) {
|
|
2743
|
+
var firstProxy = null;
|
|
2744
|
+
var add = startAt ? false : true;
|
|
2745
|
+
if (isArray(plugins) && plugins[_DYN_LENGTH$2 ] > 0) {
|
|
2746
|
+
var lastProxy_1 = null;
|
|
2747
|
+
arrForEach(plugins, function (thePlugin) {
|
|
2748
|
+
if (!add && startAt === thePlugin) {
|
|
2749
|
+
add = true;
|
|
2750
|
+
}
|
|
2751
|
+
if (add && thePlugin && isFunction(thePlugin[STR_PROCESS_TELEMETRY ])) {
|
|
2752
|
+
var newProxy = createTelemetryPluginProxy(thePlugin, config, core);
|
|
2753
|
+
if (!firstProxy) {
|
|
2754
|
+
firstProxy = newProxy;
|
|
2755
|
+
}
|
|
2756
|
+
if (lastProxy_1) {
|
|
2757
|
+
lastProxy_1._setNext(newProxy);
|
|
2758
|
+
}
|
|
2759
|
+
lastProxy_1 = newProxy;
|
|
2760
|
+
}
|
|
2761
|
+
});
|
|
2762
|
+
}
|
|
2763
|
+
if (startAt && !firstProxy) {
|
|
2764
|
+
return createTelemetryProxyChain([startAt], config, core);
|
|
2765
|
+
}
|
|
2766
|
+
return firstProxy;
|
|
2767
|
+
}
|
|
2768
|
+
function createTelemetryPluginProxy(plugin, config, core) {
|
|
2769
|
+
var nextProxy = null;
|
|
2770
|
+
var hasProcessTelemetry = isFunction(plugin[STR_PROCESS_TELEMETRY ]);
|
|
2771
|
+
var hasSetNext = isFunction(plugin[_DYN_SET_NEXT_PLUGIN ]);
|
|
2772
|
+
var chainId;
|
|
2773
|
+
if (plugin) {
|
|
2774
|
+
chainId = plugin[_DYN_IDENTIFIER ] + "-" + plugin[STR_PRIORITY ] + "-" + _chainId++;
|
|
2775
|
+
}
|
|
2776
|
+
else {
|
|
2777
|
+
chainId = "Unknown-0-" + _chainId++;
|
|
2778
|
+
}
|
|
2779
|
+
var proxyChain = {
|
|
2780
|
+
getPlugin: function () {
|
|
2781
|
+
return plugin;
|
|
2782
|
+
},
|
|
2783
|
+
getNext: function () {
|
|
2784
|
+
return nextProxy;
|
|
2785
|
+
},
|
|
2786
|
+
processTelemetry: _processTelemetry,
|
|
2787
|
+
unload: _unloadPlugin,
|
|
2788
|
+
update: _updatePlugin,
|
|
2789
|
+
_id: chainId,
|
|
2790
|
+
_setNext: function (nextPlugin) {
|
|
2791
|
+
nextProxy = nextPlugin;
|
|
2792
|
+
}
|
|
2793
|
+
};
|
|
2794
|
+
function _getTelCtx() {
|
|
2795
|
+
var itemCtx;
|
|
2796
|
+
if (plugin && isFunction(plugin[strGetTelCtx])) {
|
|
2797
|
+
itemCtx = plugin[strGetTelCtx]();
|
|
2798
|
+
}
|
|
2799
|
+
if (!itemCtx) {
|
|
2800
|
+
itemCtx = createProcessTelemetryContext(proxyChain, config, core);
|
|
2801
|
+
}
|
|
2802
|
+
return itemCtx;
|
|
2803
|
+
}
|
|
2804
|
+
function _processChain(itemCtx, processPluginFn, name, details, isAsync) {
|
|
2805
|
+
var hasRun = false;
|
|
2806
|
+
var identifier = plugin ? plugin[_DYN_IDENTIFIER ] : strTelemetryPluginChain;
|
|
2807
|
+
var hasRunContext = itemCtx[strHasRunFlags];
|
|
2808
|
+
if (!hasRunContext) {
|
|
2809
|
+
hasRunContext = itemCtx[strHasRunFlags] = {};
|
|
2810
|
+
}
|
|
2811
|
+
itemCtx.setNext(nextProxy);
|
|
2812
|
+
if (plugin) {
|
|
2813
|
+
doPerf(itemCtx[STR_CORE ](), function () { return identifier + ":" + name; }, function () {
|
|
2814
|
+
hasRunContext[chainId] = true;
|
|
2815
|
+
try {
|
|
2816
|
+
var nextId = nextProxy ? nextProxy._id : STR_EMPTY;
|
|
2817
|
+
if (nextId) {
|
|
2818
|
+
hasRunContext[nextId] = false;
|
|
2819
|
+
}
|
|
2820
|
+
hasRun = processPluginFn(itemCtx);
|
|
2821
|
+
}
|
|
2822
|
+
catch (error) {
|
|
2823
|
+
var hasNextRun = nextProxy ? hasRunContext[nextProxy._id] : true;
|
|
2824
|
+
if (hasNextRun) {
|
|
2825
|
+
hasRun = true;
|
|
2826
|
+
}
|
|
2827
|
+
if (!nextProxy || !hasNextRun) {
|
|
2828
|
+
_throwInternal(itemCtx[_DYN_DIAG_LOG ](), 1 , 73 , "Plugin [" + identifier + "] failed during " + name + " - " + dumpObj(error) + ", run flags: " + dumpObj(hasRunContext));
|
|
2829
|
+
}
|
|
2830
|
+
}
|
|
2831
|
+
}, details, isAsync);
|
|
2832
|
+
}
|
|
2833
|
+
return hasRun;
|
|
2834
|
+
}
|
|
2835
|
+
function _processTelemetry(env, itemCtx) {
|
|
2836
|
+
itemCtx = itemCtx || _getTelCtx();
|
|
2837
|
+
function _callProcessTelemetry(itemCtx) {
|
|
2838
|
+
if (!plugin || !hasProcessTelemetry) {
|
|
2839
|
+
return false;
|
|
2840
|
+
}
|
|
2841
|
+
var pluginState = _getPluginState(plugin);
|
|
2842
|
+
if (pluginState[_DYN_TEARDOWN ] || pluginState[STR_DISABLED]) {
|
|
2843
|
+
return false;
|
|
2844
|
+
}
|
|
2845
|
+
if (hasSetNext) {
|
|
2846
|
+
plugin[_DYN_SET_NEXT_PLUGIN ](nextProxy);
|
|
2847
|
+
}
|
|
2848
|
+
plugin[STR_PROCESS_TELEMETRY ](env, itemCtx);
|
|
2849
|
+
return true;
|
|
2850
|
+
}
|
|
2851
|
+
if (!_processChain(itemCtx, _callProcessTelemetry, "processTelemetry", function () { return ({ item: env }); }, !(env.sync))) {
|
|
2852
|
+
itemCtx[_DYN_PROCESS_NEXT ](env);
|
|
2853
|
+
}
|
|
2854
|
+
}
|
|
2855
|
+
function _unloadPlugin(unloadCtx, unloadState) {
|
|
2856
|
+
function _callTeardown() {
|
|
2857
|
+
var hasRun = false;
|
|
2858
|
+
if (plugin) {
|
|
2859
|
+
var pluginState = _getPluginState(plugin);
|
|
2860
|
+
var pluginCore = plugin[STR_CORE] || pluginState[STR_CORE ];
|
|
2861
|
+
if (plugin && (!pluginCore || pluginCore === unloadCtx.core()) && !pluginState[_DYN_TEARDOWN ]) {
|
|
2862
|
+
pluginState[STR_CORE ] = null;
|
|
2863
|
+
pluginState[_DYN_TEARDOWN ] = true;
|
|
2864
|
+
pluginState[_DYN_IS_INITIALIZED ] = false;
|
|
2865
|
+
if (plugin[_DYN_TEARDOWN ] && plugin[_DYN_TEARDOWN ](unloadCtx, unloadState) === true) {
|
|
2866
|
+
hasRun = true;
|
|
2867
|
+
}
|
|
2868
|
+
}
|
|
2869
|
+
}
|
|
2870
|
+
return hasRun;
|
|
2871
|
+
}
|
|
2872
|
+
if (!_processChain(unloadCtx, _callTeardown, "unload", function () { }, unloadState[_DYN_IS_ASYNC ])) {
|
|
2873
|
+
unloadCtx[_DYN_PROCESS_NEXT ](unloadState);
|
|
2874
|
+
}
|
|
2875
|
+
}
|
|
2876
|
+
function _updatePlugin(updateCtx, updateState) {
|
|
2877
|
+
function _callUpdate() {
|
|
2878
|
+
var hasRun = false;
|
|
2879
|
+
if (plugin) {
|
|
2880
|
+
var pluginState = _getPluginState(plugin);
|
|
2881
|
+
var pluginCore = plugin[STR_CORE] || pluginState[STR_CORE ];
|
|
2882
|
+
if (plugin && (!pluginCore || pluginCore === updateCtx.core()) && !pluginState[_DYN_TEARDOWN ]) {
|
|
2883
|
+
if (plugin[_DYN_UPDATE$1 ] && plugin[_DYN_UPDATE$1 ](updateCtx, updateState) === true) {
|
|
2884
|
+
hasRun = true;
|
|
2885
|
+
}
|
|
2886
|
+
}
|
|
2887
|
+
}
|
|
2888
|
+
return hasRun;
|
|
2889
|
+
}
|
|
2890
|
+
if (!_processChain(updateCtx, _callUpdate, "update", function () { }, false)) {
|
|
2891
|
+
updateCtx[_DYN_PROCESS_NEXT ](updateState);
|
|
2892
|
+
}
|
|
2893
|
+
}
|
|
2894
|
+
return objFreeze(proxyChain);
|
|
2895
|
+
}
|
|
2896
|
+
|
|
2897
|
+
function createUnloadHandlerContainer() {
|
|
2898
|
+
var handlers = [];
|
|
2899
|
+
function _addHandler(handler) {
|
|
2900
|
+
if (handler) {
|
|
2901
|
+
handlers[_DYN_PUSH ](handler);
|
|
2902
|
+
}
|
|
2903
|
+
}
|
|
2904
|
+
function _runHandlers(unloadCtx, unloadState) {
|
|
2905
|
+
arrForEach(handlers, function (handler) {
|
|
2906
|
+
try {
|
|
2907
|
+
handler(unloadCtx, unloadState);
|
|
2908
|
+
}
|
|
2909
|
+
catch (e) {
|
|
2910
|
+
_throwInternal(unloadCtx[_DYN_DIAG_LOG ](), 2 , 73 , "Unexpected error calling unload handler - " + dumpObj(e));
|
|
2911
|
+
}
|
|
2912
|
+
});
|
|
2913
|
+
handlers = [];
|
|
2914
|
+
}
|
|
2915
|
+
return {
|
|
2916
|
+
add: _addHandler,
|
|
2917
|
+
run: _runHandlers
|
|
2918
|
+
};
|
|
2919
|
+
}
|
|
2920
|
+
|
|
2921
|
+
function createUnloadHookContainer() {
|
|
2922
|
+
var _hooks = [];
|
|
2923
|
+
function _doUnload(logger) {
|
|
2924
|
+
var oldHooks = _hooks;
|
|
2925
|
+
_hooks = [];
|
|
2926
|
+
arrForEach(oldHooks, function (fn) {
|
|
2927
|
+
try {
|
|
2928
|
+
(fn.rm || fn.remove).call(fn);
|
|
2929
|
+
}
|
|
2930
|
+
catch (e) {
|
|
2931
|
+
_throwInternal(logger, 2 , 73 , "Unloading:" + dumpObj(e));
|
|
2932
|
+
}
|
|
2933
|
+
});
|
|
2934
|
+
}
|
|
2935
|
+
function _addHook(hooks) {
|
|
2936
|
+
if (hooks) {
|
|
2937
|
+
arrAppend(_hooks, hooks);
|
|
2938
|
+
}
|
|
2939
|
+
}
|
|
2940
|
+
return {
|
|
2941
|
+
run: _doUnload,
|
|
2942
|
+
add: _addHook
|
|
2943
|
+
};
|
|
2944
|
+
}
|
|
2945
|
+
|
|
2946
|
+
var _a$1;
|
|
2947
|
+
var strGetPlugin = "getPlugin";
|
|
2948
|
+
var defaultValues = (_a$1 = {},
|
|
2949
|
+
_a$1[STR_EXTENSION_CONFIG] = { isVal: isNotNullOrUndefined, v: {} },
|
|
2950
|
+
_a$1);
|
|
2951
|
+
var BaseTelemetryPlugin = /** @class */ (function () {
|
|
2952
|
+
function BaseTelemetryPlugin() {
|
|
2953
|
+
var _self = this;
|
|
2954
|
+
var _isinitialized;
|
|
2955
|
+
var _rootCtx;
|
|
2956
|
+
var _nextPlugin;
|
|
2957
|
+
var _unloadHandlerContainer;
|
|
2958
|
+
var _hookContainer;
|
|
2959
|
+
_initDefaults();
|
|
2960
|
+
dynamicProto(BaseTelemetryPlugin, _self, function (_self) {
|
|
2961
|
+
_self[_DYN_INITIALIZE ] = function (config, core, extensions, pluginChain) {
|
|
2962
|
+
_setDefaults(config, core, pluginChain);
|
|
2963
|
+
_isinitialized = true;
|
|
2964
|
+
};
|
|
2965
|
+
_self[_DYN_TEARDOWN ] = function (unloadCtx, unloadState) {
|
|
2966
|
+
var _a;
|
|
2967
|
+
var core = _self[STR_CORE ];
|
|
2968
|
+
if (!core || (unloadCtx && core !== unloadCtx[STR_CORE ]())) {
|
|
2969
|
+
return;
|
|
2970
|
+
}
|
|
2971
|
+
var result;
|
|
2972
|
+
var unloadDone = false;
|
|
2973
|
+
var theUnloadCtx = unloadCtx || createProcessTelemetryUnloadContext(null, core, _nextPlugin && _nextPlugin[strGetPlugin] ? _nextPlugin[strGetPlugin]() : _nextPlugin);
|
|
2974
|
+
var theUnloadState = unloadState || (_a = {
|
|
2975
|
+
reason: 0
|
|
2976
|
+
},
|
|
2977
|
+
_a[_DYN_IS_ASYNC ] = false,
|
|
2978
|
+
_a);
|
|
2979
|
+
function _unloadCallback() {
|
|
2980
|
+
if (!unloadDone) {
|
|
2981
|
+
unloadDone = true;
|
|
2982
|
+
_unloadHandlerContainer.run(theUnloadCtx, unloadState);
|
|
2983
|
+
_hookContainer.run(theUnloadCtx[_DYN_DIAG_LOG ]());
|
|
2984
|
+
if (result === true) {
|
|
2985
|
+
theUnloadCtx[_DYN_PROCESS_NEXT ](theUnloadState);
|
|
2986
|
+
}
|
|
2987
|
+
_initDefaults();
|
|
2988
|
+
}
|
|
2989
|
+
}
|
|
2990
|
+
if (!_self[_DYN__DO_TEARDOWN ] || _self[_DYN__DO_TEARDOWN ](theUnloadCtx, theUnloadState, _unloadCallback) !== true) {
|
|
2991
|
+
_unloadCallback();
|
|
2992
|
+
}
|
|
2993
|
+
else {
|
|
2994
|
+
result = true;
|
|
2995
|
+
}
|
|
2996
|
+
return result;
|
|
2997
|
+
};
|
|
2998
|
+
_self[_DYN_UPDATE$1 ] = function (updateCtx, updateState) {
|
|
2999
|
+
var core = _self[STR_CORE ];
|
|
3000
|
+
if (!core || (updateCtx && core !== updateCtx[STR_CORE ]())) {
|
|
3001
|
+
return;
|
|
3002
|
+
}
|
|
3003
|
+
var result;
|
|
3004
|
+
var updateDone = false;
|
|
3005
|
+
var theUpdateCtx = updateCtx || createProcessTelemetryUpdateContext(null, core, _nextPlugin && _nextPlugin[strGetPlugin] ? _nextPlugin[strGetPlugin]() : _nextPlugin);
|
|
3006
|
+
var theUpdateState = updateState || {
|
|
3007
|
+
reason: 0
|
|
3008
|
+
};
|
|
3009
|
+
function _updateCallback() {
|
|
3010
|
+
if (!updateDone) {
|
|
3011
|
+
updateDone = true;
|
|
3012
|
+
_setDefaults(theUpdateCtx.getCfg(), theUpdateCtx.core(), theUpdateCtx[_DYN_GET_NEXT ]());
|
|
3013
|
+
}
|
|
3014
|
+
}
|
|
3015
|
+
if (!_self._doUpdate || _self._doUpdate(theUpdateCtx, theUpdateState, _updateCallback) !== true) {
|
|
3016
|
+
_updateCallback();
|
|
3017
|
+
}
|
|
3018
|
+
else {
|
|
3019
|
+
result = true;
|
|
3020
|
+
}
|
|
3021
|
+
return result;
|
|
3022
|
+
};
|
|
3023
|
+
proxyFunctionAs(_self, "_addUnloadCb", function () { return _unloadHandlerContainer; }, "add");
|
|
3024
|
+
proxyFunctionAs(_self, "_addHook", function () { return _hookContainer; }, "add");
|
|
3025
|
+
objDefine(_self, "_unloadHooks", { g: function () { return _hookContainer; } });
|
|
3026
|
+
});
|
|
3027
|
+
_self[_DYN_DIAG_LOG ] = function (itemCtx) {
|
|
3028
|
+
return _getTelCtx(itemCtx)[_DYN_DIAG_LOG ]();
|
|
3029
|
+
};
|
|
3030
|
+
_self[_DYN_IS_INITIALIZED ] = function () {
|
|
3031
|
+
return _isinitialized;
|
|
3032
|
+
};
|
|
3033
|
+
_self.setInitialized = function (isInitialized) {
|
|
3034
|
+
_isinitialized = isInitialized;
|
|
3035
|
+
};
|
|
3036
|
+
_self[_DYN_SET_NEXT_PLUGIN ] = function (next) {
|
|
3037
|
+
_nextPlugin = next;
|
|
3038
|
+
};
|
|
3039
|
+
_self[_DYN_PROCESS_NEXT ] = function (env, itemCtx) {
|
|
3040
|
+
if (itemCtx) {
|
|
3041
|
+
itemCtx[_DYN_PROCESS_NEXT ](env);
|
|
3042
|
+
}
|
|
3043
|
+
else if (_nextPlugin && isFunction(_nextPlugin[STR_PROCESS_TELEMETRY ])) {
|
|
3044
|
+
_nextPlugin[STR_PROCESS_TELEMETRY ](env, null);
|
|
3045
|
+
}
|
|
3046
|
+
};
|
|
3047
|
+
_self._getTelCtx = _getTelCtx;
|
|
3048
|
+
function _getTelCtx(currentCtx) {
|
|
3049
|
+
if (currentCtx === void 0) { currentCtx = null; }
|
|
3050
|
+
var itemCtx = currentCtx;
|
|
3051
|
+
if (!itemCtx) {
|
|
3052
|
+
var rootCtx = _rootCtx || createProcessTelemetryContext(null, {}, _self[STR_CORE ]);
|
|
3053
|
+
if (_nextPlugin && _nextPlugin[strGetPlugin]) {
|
|
3054
|
+
itemCtx = rootCtx[_DYN_CREATE_NEW ](null, _nextPlugin[strGetPlugin]);
|
|
3055
|
+
}
|
|
3056
|
+
else {
|
|
3057
|
+
itemCtx = rootCtx[_DYN_CREATE_NEW ](null, _nextPlugin);
|
|
3058
|
+
}
|
|
3059
|
+
}
|
|
3060
|
+
return itemCtx;
|
|
3061
|
+
}
|
|
3062
|
+
function _setDefaults(config, core, pluginChain) {
|
|
3063
|
+
createDynamicConfig(config, defaultValues, safeGetLogger(core));
|
|
3064
|
+
if (!pluginChain && core) {
|
|
3065
|
+
pluginChain = core[_DYN_GET_PROCESS_TEL_CONT0 ]()[_DYN_GET_NEXT ]();
|
|
3066
|
+
}
|
|
3067
|
+
var nextPlugin = _nextPlugin;
|
|
3068
|
+
if (_nextPlugin && _nextPlugin[strGetPlugin]) {
|
|
3069
|
+
nextPlugin = _nextPlugin[strGetPlugin]();
|
|
3070
|
+
}
|
|
3071
|
+
_self[STR_CORE ] = core;
|
|
3072
|
+
_rootCtx = createProcessTelemetryContext(pluginChain, config, core, nextPlugin);
|
|
3073
|
+
}
|
|
3074
|
+
function _initDefaults() {
|
|
3075
|
+
_isinitialized = false;
|
|
3076
|
+
_self[STR_CORE ] = null;
|
|
3077
|
+
_rootCtx = null;
|
|
3078
|
+
_nextPlugin = null;
|
|
3079
|
+
_hookContainer = createUnloadHookContainer();
|
|
3080
|
+
_unloadHandlerContainer = createUnloadHandlerContainer();
|
|
3081
|
+
}
|
|
3082
|
+
}
|
|
3083
|
+
BaseTelemetryPlugin.__ieDyn=1;
|
|
3084
|
+
return BaseTelemetryPlugin;
|
|
3085
|
+
}());
|
|
3086
|
+
|
|
3087
|
+
var strNotSpecified = "not_specified";
|
|
3088
|
+
|
|
3089
|
+
var _DYN_LENGTH$1 = "length";
|
|
3090
|
+
var _DYN_TO_STRING = "toString";
|
|
3091
|
+
var _DYN_REMOVE_ITEM = "removeItem";
|
|
3092
|
+
var _DYN_NAME = "name";
|
|
3093
|
+
var _DYN_STRINGIFY = "stringify";
|
|
3094
|
+
var _DYN_PROPERTIES = "properties";
|
|
3095
|
+
var _DYN_MEASUREMENTS = "measurements";
|
|
3096
|
+
var _DYN_DURATION = "duration";
|
|
3097
|
+
var _DYN_SUBSTRING = "substring";
|
|
3098
|
+
|
|
3099
|
+
function dataSanitizeKeyAndAddUniqueness(logger, key, map) {
|
|
3100
|
+
var origLength = key[_DYN_LENGTH$1 ];
|
|
3101
|
+
var field = dataSanitizeKey(logger, key);
|
|
3102
|
+
if (field[_DYN_LENGTH$1 ] !== origLength) {
|
|
3103
|
+
var i = 0;
|
|
3104
|
+
var uniqueField = field;
|
|
3105
|
+
while (map[uniqueField] !== undefined) {
|
|
3106
|
+
i++;
|
|
3107
|
+
uniqueField = field[_DYN_SUBSTRING ](0, 150 - 3) + dsPadNumber(i);
|
|
3108
|
+
}
|
|
3109
|
+
field = uniqueField;
|
|
3110
|
+
}
|
|
3111
|
+
return field;
|
|
3112
|
+
}
|
|
3113
|
+
function dataSanitizeKey(logger, name) {
|
|
3114
|
+
var nameTrunc;
|
|
3115
|
+
if (name) {
|
|
3116
|
+
name = strTrim(name[_DYN_TO_STRING ]());
|
|
3117
|
+
if (name[_DYN_LENGTH$1 ] > 150 ) {
|
|
3118
|
+
nameTrunc = name[_DYN_SUBSTRING ](0, 150 );
|
|
3119
|
+
_throwInternal(logger, 2 , 57 , "name is too long. It has been truncated to " + 150 + " characters.", { name: name }, true);
|
|
3120
|
+
}
|
|
3121
|
+
}
|
|
3122
|
+
return nameTrunc || name;
|
|
3123
|
+
}
|
|
3124
|
+
function dataSanitizeString(logger, value, maxLength) {
|
|
3125
|
+
if (maxLength === void 0) { maxLength = 1024 ; }
|
|
3126
|
+
var valueTrunc;
|
|
3127
|
+
if (value) {
|
|
3128
|
+
maxLength = maxLength ? maxLength : 1024 ;
|
|
3129
|
+
value = strTrim(value[_DYN_TO_STRING ]());
|
|
3130
|
+
if (value[_DYN_LENGTH$1 ] > maxLength) {
|
|
3131
|
+
valueTrunc = value[_DYN_SUBSTRING ](0, maxLength);
|
|
3132
|
+
_throwInternal(logger, 2 , 61 , "string value is too long. It has been truncated to " + maxLength + " characters.", { value: value }, true);
|
|
3133
|
+
}
|
|
3134
|
+
}
|
|
3135
|
+
return valueTrunc || value;
|
|
3136
|
+
}
|
|
3137
|
+
function dataSanitizeUrl(logger, url) {
|
|
3138
|
+
return dataSanitizeInput(logger, url, 2048 , 66 );
|
|
3139
|
+
}
|
|
3140
|
+
function dataSanitizeProperties(logger, properties) {
|
|
3141
|
+
if (properties) {
|
|
3142
|
+
var tempProps_1 = {};
|
|
3143
|
+
objForEachKey(properties, function (prop, value) {
|
|
3144
|
+
if (isObject(value) && hasJSON()) {
|
|
3145
|
+
try {
|
|
3146
|
+
value = getJSON()[_DYN_STRINGIFY ](value);
|
|
3147
|
+
}
|
|
3148
|
+
catch (e) {
|
|
3149
|
+
_throwInternal(logger, 2 , 49 , "custom property is not valid", { exception: e }, true);
|
|
3150
|
+
}
|
|
3151
|
+
}
|
|
3152
|
+
value = dataSanitizeString(logger, value, 8192 );
|
|
3153
|
+
prop = dataSanitizeKeyAndAddUniqueness(logger, prop, tempProps_1);
|
|
3154
|
+
tempProps_1[prop] = value;
|
|
3155
|
+
});
|
|
3156
|
+
properties = tempProps_1;
|
|
3157
|
+
}
|
|
3158
|
+
return properties;
|
|
3159
|
+
}
|
|
3160
|
+
function dataSanitizeMeasurements(logger, measurements) {
|
|
3161
|
+
if (measurements) {
|
|
3162
|
+
var tempMeasurements_1 = {};
|
|
3163
|
+
objForEachKey(measurements, function (measure, value) {
|
|
3164
|
+
measure = dataSanitizeKeyAndAddUniqueness(logger, measure, tempMeasurements_1);
|
|
3165
|
+
tempMeasurements_1[measure] = value;
|
|
3166
|
+
});
|
|
3167
|
+
measurements = tempMeasurements_1;
|
|
3168
|
+
}
|
|
3169
|
+
return measurements;
|
|
3170
|
+
}
|
|
3171
|
+
function dataSanitizeId(logger, id) {
|
|
3172
|
+
return id ? dataSanitizeInput(logger, id, 128 , 69 )[_DYN_TO_STRING ]() : id;
|
|
3173
|
+
}
|
|
3174
|
+
function dataSanitizeInput(logger, input, maxLength, _msgId) {
|
|
3175
|
+
var inputTrunc;
|
|
3176
|
+
if (input) {
|
|
3177
|
+
input = strTrim(input[_DYN_TO_STRING ]());
|
|
3178
|
+
if (input[_DYN_LENGTH$1 ] > maxLength) {
|
|
3179
|
+
inputTrunc = input[_DYN_SUBSTRING ](0, maxLength);
|
|
3180
|
+
_throwInternal(logger, 2 , _msgId, "input is too long, it has been truncated to " + maxLength + " characters.", { data: input }, true);
|
|
3181
|
+
}
|
|
3182
|
+
}
|
|
3183
|
+
return inputTrunc || input;
|
|
3184
|
+
}
|
|
3185
|
+
function dsPadNumber(num) {
|
|
3186
|
+
var s = "00" + num;
|
|
3187
|
+
return strSubstr(s, s[_DYN_LENGTH$1 ] - 3);
|
|
3188
|
+
}
|
|
3189
|
+
|
|
3190
|
+
function createDistributedTraceContextFromTrace(telemetryTrace, parentCtx) {
|
|
3191
|
+
var trace = telemetryTrace || {};
|
|
3192
|
+
return {
|
|
3193
|
+
getName: function () {
|
|
3194
|
+
return trace[_DYN_NAME ];
|
|
3195
|
+
},
|
|
3196
|
+
setName: function (newValue) {
|
|
3197
|
+
parentCtx && parentCtx.setName(newValue);
|
|
3198
|
+
trace[_DYN_NAME ] = newValue;
|
|
3199
|
+
},
|
|
3200
|
+
getTraceId: function () {
|
|
3201
|
+
return trace.traceID;
|
|
3202
|
+
},
|
|
3203
|
+
setTraceId: function (newValue) {
|
|
3204
|
+
parentCtx && parentCtx.setTraceId(newValue);
|
|
3205
|
+
if (isValidTraceId(newValue)) {
|
|
3206
|
+
trace.traceID = newValue;
|
|
3207
|
+
}
|
|
3208
|
+
},
|
|
3209
|
+
getSpanId: function () {
|
|
3210
|
+
return trace.parentID;
|
|
3211
|
+
},
|
|
3212
|
+
setSpanId: function (newValue) {
|
|
3213
|
+
parentCtx && parentCtx.setSpanId(newValue);
|
|
3214
|
+
if (isValidSpanId(newValue)) {
|
|
3215
|
+
trace.parentID = newValue;
|
|
3216
|
+
}
|
|
3217
|
+
},
|
|
3218
|
+
getTraceFlags: function () {
|
|
3219
|
+
return trace.traceFlags;
|
|
3220
|
+
},
|
|
3221
|
+
setTraceFlags: function (newTraceFlags) {
|
|
3222
|
+
parentCtx && parentCtx.setTraceFlags(newTraceFlags);
|
|
3223
|
+
trace.traceFlags = newTraceFlags;
|
|
3224
|
+
}
|
|
3225
|
+
};
|
|
3226
|
+
}
|
|
3227
|
+
|
|
3228
|
+
var StorageType = createEnumStyle({
|
|
3229
|
+
LocalStorage: 0 ,
|
|
3230
|
+
SessionStorage: 1
|
|
3231
|
+
});
|
|
3232
|
+
createEnumStyle({
|
|
3233
|
+
AI: 0 ,
|
|
3234
|
+
AI_AND_W3C: 1 ,
|
|
3235
|
+
W3C: 2
|
|
3236
|
+
});
|
|
3237
|
+
|
|
3238
|
+
var _canUseLocalStorage = undefined;
|
|
3239
|
+
function _getLocalStorageObject() {
|
|
3240
|
+
if (utlCanUseLocalStorage()) {
|
|
3241
|
+
return _getVerifiedStorageObject(StorageType.LocalStorage);
|
|
3242
|
+
}
|
|
3243
|
+
return null;
|
|
3244
|
+
}
|
|
3245
|
+
function _getVerifiedStorageObject(storageType) {
|
|
3246
|
+
try {
|
|
3247
|
+
if (isNullOrUndefined(getGlobal())) {
|
|
3248
|
+
return null;
|
|
3249
|
+
}
|
|
3250
|
+
var uid = (new Date)[_DYN_TO_STRING ]();
|
|
3251
|
+
var storage = getInst(storageType === StorageType.LocalStorage ? "localStorage" : "sessionStorage");
|
|
3252
|
+
storage.setItem(uid, uid);
|
|
3253
|
+
var fail = storage.getItem(uid) !== uid;
|
|
3254
|
+
storage[_DYN_REMOVE_ITEM ](uid);
|
|
3255
|
+
if (!fail) {
|
|
3256
|
+
return storage;
|
|
3257
|
+
}
|
|
3258
|
+
}
|
|
3259
|
+
catch (exception) {
|
|
3260
|
+
}
|
|
3261
|
+
return null;
|
|
3262
|
+
}
|
|
3263
|
+
function utlCanUseLocalStorage(reset) {
|
|
3264
|
+
if (reset || _canUseLocalStorage === undefined) {
|
|
3265
|
+
_canUseLocalStorage = !!_getVerifiedStorageObject(StorageType.LocalStorage);
|
|
3266
|
+
}
|
|
3267
|
+
return _canUseLocalStorage;
|
|
3268
|
+
}
|
|
3269
|
+
function utlGetLocalStorage(logger, name) {
|
|
3270
|
+
var storage = _getLocalStorageObject();
|
|
3271
|
+
if (storage !== null) {
|
|
3272
|
+
try {
|
|
3273
|
+
return storage.getItem(name);
|
|
3274
|
+
}
|
|
3275
|
+
catch (e) {
|
|
3276
|
+
_canUseLocalStorage = false;
|
|
3277
|
+
_throwInternal(logger, 2 , 1 , "Browser failed read of local storage. " + getExceptionName(e), { exception: dumpObj(e) });
|
|
3278
|
+
}
|
|
3279
|
+
}
|
|
3280
|
+
return null;
|
|
3281
|
+
}
|
|
3282
|
+
function utlSetLocalStorage(logger, name, data) {
|
|
3283
|
+
var storage = _getLocalStorageObject();
|
|
3284
|
+
if (storage !== null) {
|
|
3285
|
+
try {
|
|
3286
|
+
storage.setItem(name, data);
|
|
3287
|
+
return true;
|
|
3288
|
+
}
|
|
3289
|
+
catch (e) {
|
|
3290
|
+
_canUseLocalStorage = false;
|
|
3291
|
+
_throwInternal(logger, 2 , 3 , "Browser failed write to local storage. " + getExceptionName(e), { exception: dumpObj(e) });
|
|
3292
|
+
}
|
|
3293
|
+
}
|
|
3294
|
+
return false;
|
|
3295
|
+
}
|
|
3296
|
+
function utlRemoveStorage(logger, name) {
|
|
3297
|
+
var storage = _getLocalStorageObject();
|
|
3298
|
+
if (storage !== null) {
|
|
3299
|
+
try {
|
|
3300
|
+
storage[_DYN_REMOVE_ITEM ](name);
|
|
3301
|
+
return true;
|
|
3302
|
+
}
|
|
3303
|
+
catch (e) {
|
|
3304
|
+
_canUseLocalStorage = false;
|
|
3305
|
+
_throwInternal(logger, 2 , 5 , "Browser failed removal of local storage item. " + getExceptionName(e), { exception: dumpObj(e) });
|
|
3306
|
+
}
|
|
3307
|
+
}
|
|
3308
|
+
return false;
|
|
3309
|
+
}
|
|
3310
|
+
|
|
3311
|
+
var strEmpty = "";
|
|
3312
|
+
function msToTimeSpan(totalms) {
|
|
3313
|
+
if (isNaN(totalms) || totalms < 0) {
|
|
3314
|
+
totalms = 0;
|
|
3315
|
+
}
|
|
3316
|
+
totalms = Math.round(totalms);
|
|
3317
|
+
var ms = strEmpty + totalms % 1000;
|
|
3318
|
+
var sec = strEmpty + Math.floor(totalms / 1000) % 60;
|
|
3319
|
+
var min = strEmpty + Math.floor(totalms / (1000 * 60)) % 60;
|
|
3320
|
+
var hour = strEmpty + Math.floor(totalms / (1000 * 60 * 60)) % 24;
|
|
3321
|
+
var days = Math.floor(totalms / (1000 * 60 * 60 * 24));
|
|
3322
|
+
ms = ms[_DYN_LENGTH$1 ] === 1 ? "00" + ms : ms[_DYN_LENGTH$1 ] === 2 ? "0" + ms : ms;
|
|
3323
|
+
sec = sec[_DYN_LENGTH$1 ] < 2 ? "0" + sec : sec;
|
|
3324
|
+
min = min[_DYN_LENGTH$1 ] < 2 ? "0" + min : min;
|
|
3325
|
+
hour = hour[_DYN_LENGTH$1 ] < 2 ? "0" + hour : hour;
|
|
3326
|
+
return (days > 0 ? days + "." : strEmpty) + hour + ":" + min + ":" + sec + "." + ms;
|
|
3327
|
+
}
|
|
3328
|
+
|
|
3329
|
+
var PageView = /** @class */ (function () {
|
|
3330
|
+
function PageView(logger, name, url, durationMs, properties, measurements, id) {
|
|
3331
|
+
this.aiDataContract = {
|
|
3332
|
+
ver: 1 ,
|
|
3333
|
+
name: 0 ,
|
|
3334
|
+
url: 0 ,
|
|
3335
|
+
duration: 0 ,
|
|
3336
|
+
properties: 0 ,
|
|
3337
|
+
measurements: 0 ,
|
|
3338
|
+
id: 0
|
|
3339
|
+
};
|
|
3340
|
+
var _self = this;
|
|
3341
|
+
_self.ver = 2;
|
|
3342
|
+
_self.id = dataSanitizeId(logger, id);
|
|
3343
|
+
_self.url = dataSanitizeUrl(logger, url);
|
|
3344
|
+
_self[_DYN_NAME ] = dataSanitizeString(logger, name) || strNotSpecified;
|
|
3345
|
+
if (!isNaN(durationMs)) {
|
|
3346
|
+
_self[_DYN_DURATION ] = msToTimeSpan(durationMs);
|
|
3347
|
+
}
|
|
3348
|
+
_self[_DYN_PROPERTIES ] = dataSanitizeProperties(logger, properties);
|
|
3349
|
+
_self[_DYN_MEASUREMENTS ] = dataSanitizeMeasurements(logger, measurements);
|
|
3350
|
+
}
|
|
3351
|
+
PageView.envelopeType = "Microsoft.ApplicationInsights.{0}.Pageview";
|
|
3352
|
+
PageView.dataType = "PageviewData";
|
|
3353
|
+
return PageView;
|
|
3354
|
+
}());
|
|
3355
|
+
|
|
3356
|
+
function _aiNameFunc(baseName) {
|
|
3357
|
+
var aiName = "ai." + baseName + ".";
|
|
3358
|
+
return function (name) {
|
|
3359
|
+
return aiName + name;
|
|
3360
|
+
};
|
|
3361
|
+
}
|
|
3362
|
+
var _aiApplication = _aiNameFunc("application");
|
|
3363
|
+
var _aiDevice = _aiNameFunc("device");
|
|
3364
|
+
var _aiLocation = _aiNameFunc("location");
|
|
3365
|
+
var _aiOperation = _aiNameFunc("operation");
|
|
3366
|
+
var _aiSession = _aiNameFunc("session");
|
|
3367
|
+
var _aiUser = _aiNameFunc("user");
|
|
3368
|
+
var _aiCloud = _aiNameFunc("cloud");
|
|
3369
|
+
var _aiInternal = _aiNameFunc("internal");
|
|
3370
|
+
var ContextTagKeys = /** @class */ (function (_super) {
|
|
3371
|
+
__extendsFn(ContextTagKeys, _super);
|
|
3372
|
+
function ContextTagKeys() {
|
|
3373
|
+
return _super.call(this) || this;
|
|
3374
|
+
}
|
|
3375
|
+
return ContextTagKeys;
|
|
3376
|
+
}(createClassFromInterface({
|
|
3377
|
+
applicationVersion: _aiApplication("ver"),
|
|
3378
|
+
applicationBuild: _aiApplication("build"),
|
|
3379
|
+
applicationTypeId: _aiApplication("typeId"),
|
|
3380
|
+
applicationId: _aiApplication("applicationId"),
|
|
3381
|
+
applicationLayer: _aiApplication("layer"),
|
|
3382
|
+
deviceId: _aiDevice("id"),
|
|
3383
|
+
deviceIp: _aiDevice("ip"),
|
|
3384
|
+
deviceLanguage: _aiDevice("language"),
|
|
3385
|
+
deviceLocale: _aiDevice("locale"),
|
|
3386
|
+
deviceModel: _aiDevice("model"),
|
|
3387
|
+
deviceFriendlyName: _aiDevice("friendlyName"),
|
|
3388
|
+
deviceNetwork: _aiDevice("network"),
|
|
3389
|
+
deviceNetworkName: _aiDevice("networkName"),
|
|
3390
|
+
deviceOEMName: _aiDevice("oemName"),
|
|
3391
|
+
deviceOS: _aiDevice("os"),
|
|
3392
|
+
deviceOSVersion: _aiDevice("osVersion"),
|
|
3393
|
+
deviceRoleInstance: _aiDevice("roleInstance"),
|
|
3394
|
+
deviceRoleName: _aiDevice("roleName"),
|
|
3395
|
+
deviceScreenResolution: _aiDevice("screenResolution"),
|
|
3396
|
+
deviceType: _aiDevice("type"),
|
|
3397
|
+
deviceMachineName: _aiDevice("machineName"),
|
|
3398
|
+
deviceVMName: _aiDevice("vmName"),
|
|
3399
|
+
deviceBrowser: _aiDevice("browser"),
|
|
3400
|
+
deviceBrowserVersion: _aiDevice("browserVersion"),
|
|
3401
|
+
locationIp: _aiLocation("ip"),
|
|
3402
|
+
locationCountry: _aiLocation("country"),
|
|
3403
|
+
locationProvince: _aiLocation("province"),
|
|
3404
|
+
locationCity: _aiLocation("city"),
|
|
3405
|
+
operationId: _aiOperation("id"),
|
|
3406
|
+
operationName: _aiOperation("name"),
|
|
3407
|
+
operationParentId: _aiOperation("parentId"),
|
|
3408
|
+
operationRootId: _aiOperation("rootId"),
|
|
3409
|
+
operationSyntheticSource: _aiOperation("syntheticSource"),
|
|
3410
|
+
operationCorrelationVector: _aiOperation("correlationVector"),
|
|
3411
|
+
sessionId: _aiSession("id"),
|
|
3412
|
+
sessionIsFirst: _aiSession("isFirst"),
|
|
3413
|
+
sessionIsNew: _aiSession("isNew"),
|
|
3414
|
+
userAccountAcquisitionDate: _aiUser("accountAcquisitionDate"),
|
|
3415
|
+
userAccountId: _aiUser("accountId"),
|
|
3416
|
+
userAgent: _aiUser("userAgent"),
|
|
3417
|
+
userId: _aiUser("id"),
|
|
3418
|
+
userStoreRegion: _aiUser("storeRegion"),
|
|
3419
|
+
userAuthUserId: _aiUser("authUserId"),
|
|
3420
|
+
userAnonymousUserAcquisitionDate: _aiUser("anonUserAcquisitionDate"),
|
|
3421
|
+
userAuthenticatedUserAcquisitionDate: _aiUser("authUserAcquisitionDate"),
|
|
3422
|
+
cloudName: _aiCloud("name"),
|
|
3423
|
+
cloudRole: _aiCloud("role"),
|
|
3424
|
+
cloudRoleVer: _aiCloud("roleVer"),
|
|
3425
|
+
cloudRoleInstance: _aiCloud("roleInstance"),
|
|
3426
|
+
cloudEnvironment: _aiCloud("environment"),
|
|
3427
|
+
cloudLocation: _aiCloud("location"),
|
|
3428
|
+
cloudDeploymentUnit: _aiCloud("deploymentUnit"),
|
|
3429
|
+
internalNodeName: _aiInternal("nodeName"),
|
|
3430
|
+
internalSdkVersion: _aiInternal("sdkVersion"),
|
|
3431
|
+
internalAgentVersion: _aiInternal("agentVersion"),
|
|
3432
|
+
internalSnippet: _aiInternal("snippet"),
|
|
3433
|
+
internalSdkSrc: _aiInternal("sdkSrc")
|
|
3434
|
+
})));
|
|
3435
|
+
|
|
3436
|
+
var Extensions = {
|
|
3437
|
+
UserExt: "user",
|
|
3438
|
+
DeviceExt: "device",
|
|
3439
|
+
TraceExt: "trace",
|
|
3440
|
+
WebExt: "web",
|
|
3441
|
+
AppExt: "app",
|
|
3442
|
+
OSExt: "os",
|
|
3443
|
+
SessionExt: "ses",
|
|
3444
|
+
SDKExt: "sdk"
|
|
3445
|
+
};
|
|
3446
|
+
var CtxTagKeys = new ContextTagKeys();
|
|
3447
|
+
|
|
3448
|
+
var PropertiesPluginIdentifier = "AppInsightsPropertiesPlugin";
|
|
3449
|
+
var BreezeChannelIdentifier = "AppInsightsChannelPlugin";
|
|
3450
|
+
|
|
3451
|
+
var Application = /** @class */ (function () {
|
|
3452
|
+
function Application() {
|
|
3453
|
+
}
|
|
3454
|
+
return Application;
|
|
3455
|
+
}());
|
|
3456
|
+
|
|
3457
|
+
var Device = /** @class */ (function () {
|
|
3458
|
+
function Device() {
|
|
3459
|
+
this.id = "browser";
|
|
3460
|
+
this.deviceClass = "Browser";
|
|
3461
|
+
}
|
|
3462
|
+
return Device;
|
|
3463
|
+
}());
|
|
3464
|
+
|
|
3465
|
+
var Version = "3.0.2-nightly3.2305-04";
|
|
3466
|
+
var Internal = /** @class */ (function () {
|
|
3467
|
+
function Internal(config, unloadHookContainer) {
|
|
3468
|
+
var _this = this;
|
|
3469
|
+
var unloadHook = onConfigChange((config), function () {
|
|
3470
|
+
var prefix = config.sdkExtension;
|
|
3471
|
+
_this.sdkVersion = (prefix ? prefix + "_" : "") + "javascript:" + Version;
|
|
3472
|
+
});
|
|
3473
|
+
unloadHookContainer && unloadHookContainer.add(unloadHook);
|
|
3474
|
+
}
|
|
3475
|
+
return Internal;
|
|
3476
|
+
}());
|
|
3477
|
+
|
|
3478
|
+
var Location = /** @class */ (function () {
|
|
3479
|
+
function Location() {
|
|
3480
|
+
}
|
|
3481
|
+
return Location;
|
|
3482
|
+
}());
|
|
3483
|
+
|
|
3484
|
+
var _DYN_SESSION_MANAGER = "sessionManager";
|
|
3485
|
+
var _DYN_UPDATE = "update";
|
|
3486
|
+
var _DYN_IS_USER_COOKIE_SET = "isUserCookieSet";
|
|
3487
|
+
var _DYN_IS_NEW_USER = "isNewUser";
|
|
3488
|
+
var _DYN_GET_TRACE_CTX = "getTraceCtx";
|
|
3489
|
+
var _DYN_TELEMETRY_TRACE = "telemetryTrace";
|
|
3490
|
+
var _DYN_APPLY_SESSION_CONTEX0 = "applySessionContext";
|
|
3491
|
+
var _DYN_APPLY_APPLICATION_CO1 = "applyApplicationContext";
|
|
3492
|
+
var _DYN_APPLY_DEVICE_CONTEXT = "applyDeviceContext";
|
|
3493
|
+
var _DYN_APPLY_OPERATION_CONT2 = "applyOperationContext";
|
|
3494
|
+
var _DYN_APPLY_USER_CONTEXT = "applyUserContext";
|
|
3495
|
+
var _DYN_APPLY_OPERATING_SYST3 = "applyOperatingSystemContxt";
|
|
3496
|
+
var _DYN_APPLY_LOCATION_CONTE4 = "applyLocationContext";
|
|
3497
|
+
var _DYN_APPLY_INTERNAL_CONTE5 = "applyInternalContext";
|
|
3498
|
+
var _DYN_ACCOUNT_ID = "accountId";
|
|
3499
|
+
var _DYN_GET_SESSION_ID = "getSessionId";
|
|
3500
|
+
var _DYN_NAME_PREFIX = "namePrefix";
|
|
3501
|
+
var _DYN_SESSION_COOKIE_POSTF6 = "sessionCookiePostfix";
|
|
3502
|
+
var _DYN_USER_COOKIE_POSTFIX = "userCookiePostfix";
|
|
3503
|
+
var _DYN_ID_LENGTH = "idLength";
|
|
3504
|
+
var _DYN_GET_NEW_ID = "getNewId";
|
|
3505
|
+
var _DYN_LENGTH = "length";
|
|
3506
|
+
var _DYN_AUTOMATIC_SESSION = "automaticSession";
|
|
3507
|
+
var _DYN_AUTHENTICATED_ID = "authenticatedId";
|
|
3508
|
+
var _DYN_ACQUISITION_DATE = "acquisitionDate";
|
|
3509
|
+
var _DYN_RENEWAL_DATE = "renewalDate";
|
|
3510
|
+
var _DYN_JOIN = "join";
|
|
3511
|
+
var _DYN_COOKIE_SEPARATOR = "cookieSeparator";
|
|
3512
|
+
var _DYN_AUTH_USER_COOKIE_NAM7 = "authUserCookieName";
|
|
3513
|
+
|
|
3514
|
+
var SESSION_COOKIE_NAME = "ai_session";
|
|
3515
|
+
var ACQUISITION_SPAN = 86400000;
|
|
3516
|
+
var RENEWAL_SPAN = 1800000;
|
|
3517
|
+
var COOKIE_UPDATE_INTERVAL = 60000;
|
|
3518
|
+
var Session = /** @class */ (function () {
|
|
3519
|
+
function Session() {
|
|
3520
|
+
}
|
|
3521
|
+
return Session;
|
|
3522
|
+
}());
|
|
3523
|
+
var _SessionManager = /** @class */ (function () {
|
|
3524
|
+
function _SessionManager(config, core, unloadHookContainer) {
|
|
3525
|
+
var self = this;
|
|
3526
|
+
var _storageNamePrefix;
|
|
3527
|
+
var _cookieUpdatedTimestamp;
|
|
3528
|
+
var _logger = safeGetLogger(core);
|
|
3529
|
+
var _cookieManager = safeGetCookieMgr(core);
|
|
3530
|
+
var _sessionExpirationMs;
|
|
3531
|
+
var _sessionRenewalMs;
|
|
3532
|
+
dynamicProto(_SessionManager, self, function (_self) {
|
|
3533
|
+
if (!config) {
|
|
3534
|
+
config = {};
|
|
3535
|
+
}
|
|
3536
|
+
var unloadHook = onConfigChange(config, function (details) {
|
|
3537
|
+
_sessionExpirationMs = config.sessionExpirationMs || ACQUISITION_SPAN;
|
|
3538
|
+
_sessionRenewalMs = config.sessionRenewalMs || RENEWAL_SPAN;
|
|
3539
|
+
var sessionCookiePostfix = config.sessionCookiePostfix || config[_DYN_NAME_PREFIX ] || "";
|
|
3540
|
+
_storageNamePrefix = SESSION_COOKIE_NAME + sessionCookiePostfix;
|
|
3541
|
+
});
|
|
3542
|
+
unloadHookContainer && unloadHookContainer.add(unloadHook);
|
|
3543
|
+
_self[_DYN_AUTOMATIC_SESSION ] = new Session();
|
|
3544
|
+
_self[_DYN_UPDATE ] = function () {
|
|
3545
|
+
var nowMs = utcNow();
|
|
3546
|
+
var isExpired = false;
|
|
3547
|
+
var session = _self[_DYN_AUTOMATIC_SESSION ];
|
|
3548
|
+
if (!session.id) {
|
|
3549
|
+
isExpired = !_initializeAutomaticSession(session);
|
|
3550
|
+
}
|
|
3551
|
+
if (!isExpired && _sessionExpirationMs > 0) {
|
|
3552
|
+
var timeSinceAcqMs = nowMs - session[_DYN_ACQUISITION_DATE ];
|
|
3553
|
+
var timeSinceRenewalMs = nowMs - session[_DYN_RENEWAL_DATE ];
|
|
3554
|
+
isExpired = timeSinceAcqMs < 0 || timeSinceRenewalMs < 0;
|
|
3555
|
+
isExpired = isExpired || timeSinceAcqMs > _sessionExpirationMs;
|
|
3556
|
+
isExpired = isExpired || timeSinceRenewalMs > _sessionRenewalMs;
|
|
3557
|
+
}
|
|
3558
|
+
if (isExpired) {
|
|
3559
|
+
_renew(nowMs);
|
|
3560
|
+
}
|
|
3561
|
+
else {
|
|
3562
|
+
if (!_cookieUpdatedTimestamp || nowMs - _cookieUpdatedTimestamp > COOKIE_UPDATE_INTERVAL) {
|
|
3563
|
+
_setCookie(session, nowMs);
|
|
3564
|
+
}
|
|
3565
|
+
}
|
|
3566
|
+
};
|
|
3567
|
+
_self.backup = function () {
|
|
3568
|
+
var session = _self[_DYN_AUTOMATIC_SESSION ];
|
|
3569
|
+
_setStorage(session.id, session[_DYN_ACQUISITION_DATE ], session[_DYN_RENEWAL_DATE ]);
|
|
3570
|
+
};
|
|
3571
|
+
function _initializeAutomaticSession(session, now) {
|
|
3572
|
+
var isValid = false;
|
|
3573
|
+
var cookieValue = _cookieManager.get(_storageNamePrefix);
|
|
3574
|
+
if (cookieValue && isFunction(cookieValue.split)) {
|
|
3575
|
+
isValid = _initializeAutomaticSessionWithData(session, cookieValue);
|
|
3576
|
+
}
|
|
3577
|
+
else {
|
|
3578
|
+
var storageValue = utlGetLocalStorage(_logger, _storageNamePrefix);
|
|
3579
|
+
if (storageValue) {
|
|
3580
|
+
isValid = _initializeAutomaticSessionWithData(session, storageValue);
|
|
3581
|
+
}
|
|
3582
|
+
}
|
|
3583
|
+
return isValid || !!session.id;
|
|
3584
|
+
}
|
|
3585
|
+
function _initializeAutomaticSessionWithData(session, sessionData) {
|
|
3586
|
+
var isValid = false;
|
|
3587
|
+
var sessionReset = ", session will be reset";
|
|
3588
|
+
var tokens = sessionData.split("|");
|
|
3589
|
+
if (tokens[_DYN_LENGTH ] >= 2) {
|
|
3590
|
+
try {
|
|
3591
|
+
var acqMs = +tokens[1] || 0;
|
|
3592
|
+
var renewalMs = +tokens[2] || 0;
|
|
3593
|
+
if (isNaN(acqMs) || acqMs <= 0) {
|
|
3594
|
+
_throwInternal(_logger, 2 , 27 , "AI session acquisition date is 0" + sessionReset);
|
|
3595
|
+
}
|
|
3596
|
+
else if (isNaN(renewalMs) || renewalMs <= 0) {
|
|
3597
|
+
_throwInternal(_logger, 2 , 27 , "AI session renewal date is 0" + sessionReset);
|
|
3598
|
+
}
|
|
3599
|
+
else if (tokens[0]) {
|
|
3600
|
+
session.id = tokens[0];
|
|
3601
|
+
session[_DYN_ACQUISITION_DATE ] = acqMs;
|
|
3602
|
+
session[_DYN_RENEWAL_DATE ] = renewalMs;
|
|
3603
|
+
isValid = true;
|
|
3604
|
+
}
|
|
3605
|
+
}
|
|
3606
|
+
catch (e) {
|
|
3607
|
+
_throwInternal(_logger, 1 , 9 , "Error parsing ai_session value [" + (sessionData || "") + "]" + sessionReset + " - " + getExceptionName(e), { exception: dumpObj(e) });
|
|
3608
|
+
}
|
|
3609
|
+
}
|
|
3610
|
+
return isValid;
|
|
3611
|
+
}
|
|
3612
|
+
function _renew(nowMs) {
|
|
3613
|
+
var getNewId = config[_DYN_GET_NEW_ID ] || newId;
|
|
3614
|
+
_self.automaticSession.id = getNewId(config[_DYN_ID_LENGTH ] || 22);
|
|
3615
|
+
_self[_DYN_AUTOMATIC_SESSION ][_DYN_ACQUISITION_DATE ] = nowMs;
|
|
3616
|
+
_setCookie(_self[_DYN_AUTOMATIC_SESSION ], nowMs);
|
|
3617
|
+
if (!utlCanUseLocalStorage()) {
|
|
3618
|
+
_throwInternal(_logger, 2 , 0 , "Browser does not support local storage. Session durations will be inaccurate.");
|
|
3619
|
+
}
|
|
3620
|
+
}
|
|
3621
|
+
function _setCookie(session, nowMs) {
|
|
3622
|
+
var acq = session[_DYN_ACQUISITION_DATE ];
|
|
3623
|
+
session[_DYN_RENEWAL_DATE ] = nowMs;
|
|
3624
|
+
var renewalPeriodMs = _sessionRenewalMs;
|
|
3625
|
+
var acqTimeLeftMs = (acq + _sessionExpirationMs) - nowMs;
|
|
3626
|
+
var cookie = [session.id, acq, nowMs];
|
|
3627
|
+
var maxAgeSec = 0;
|
|
3628
|
+
if (acqTimeLeftMs < renewalPeriodMs) {
|
|
3629
|
+
maxAgeSec = acqTimeLeftMs / 1000;
|
|
3630
|
+
}
|
|
3631
|
+
else {
|
|
3632
|
+
maxAgeSec = renewalPeriodMs / 1000;
|
|
3633
|
+
}
|
|
3634
|
+
var cookieDomain = config.cookieDomain || null;
|
|
3635
|
+
_cookieManager.set(_storageNamePrefix, cookie[_DYN_JOIN ]("|"), _sessionExpirationMs > 0 ? maxAgeSec : null, cookieDomain);
|
|
3636
|
+
_cookieUpdatedTimestamp = nowMs;
|
|
3637
|
+
}
|
|
3638
|
+
function _setStorage(guid, acq, renewal) {
|
|
3639
|
+
utlSetLocalStorage(_logger, _storageNamePrefix, [guid, acq, renewal][_DYN_JOIN ]("|"));
|
|
3640
|
+
}
|
|
3641
|
+
});
|
|
3642
|
+
}
|
|
3643
|
+
_SessionManager.__ieDyn=1;
|
|
3644
|
+
return _SessionManager;
|
|
3645
|
+
}());
|
|
3646
|
+
|
|
3647
|
+
var TelemetryTrace = /** @class */ (function () {
|
|
3648
|
+
function TelemetryTrace(id, parentId, name, logger) {
|
|
3649
|
+
var _self = this;
|
|
3650
|
+
_self.traceID = id || generateW3CId();
|
|
3651
|
+
_self.parentID = parentId;
|
|
3652
|
+
var location = getLocation();
|
|
3653
|
+
if (!name && location && location.pathname) {
|
|
3654
|
+
name = location.pathname;
|
|
3655
|
+
}
|
|
3656
|
+
_self.name = dataSanitizeString(logger, name);
|
|
3657
|
+
}
|
|
3658
|
+
return TelemetryTrace;
|
|
3659
|
+
}());
|
|
3660
|
+
|
|
3661
|
+
function _validateUserInput(id) {
|
|
3662
|
+
if (typeof id !== "string" ||
|
|
3663
|
+
!id ||
|
|
3664
|
+
id.match(/,|;|=| |\|/)) {
|
|
3665
|
+
return false;
|
|
3666
|
+
}
|
|
3667
|
+
return true;
|
|
3668
|
+
}
|
|
3669
|
+
var User = /** @class */ (function () {
|
|
3670
|
+
function User(config, core, unloadHookContainer) {
|
|
3671
|
+
this.isNewUser = false;
|
|
3672
|
+
this.isUserCookieSet = false;
|
|
3673
|
+
var _logger = safeGetLogger(core);
|
|
3674
|
+
var _cookieManager = safeGetCookieMgr(core);
|
|
3675
|
+
var _storageNamePrefix;
|
|
3676
|
+
dynamicProto(User, this, function (_self) {
|
|
3677
|
+
objDefine(_self, "config", {
|
|
3678
|
+
g: function () { return config; }
|
|
3679
|
+
});
|
|
3680
|
+
var unloadHook = onConfigChange(config, function () {
|
|
3681
|
+
var userCookiePostfix = config[_DYN_USER_COOKIE_POSTFIX ] || "";
|
|
3682
|
+
_storageNamePrefix = User.userCookieName + userCookiePostfix;
|
|
3683
|
+
var cookie = _cookieManager.get(_storageNamePrefix);
|
|
3684
|
+
if (cookie) {
|
|
3685
|
+
_self[_DYN_IS_NEW_USER ] = false;
|
|
3686
|
+
var params = cookie.split(User[_DYN_COOKIE_SEPARATOR ]);
|
|
3687
|
+
if (params[_DYN_LENGTH ] > 0) {
|
|
3688
|
+
_self.id = params[0];
|
|
3689
|
+
_self[_DYN_IS_USER_COOKIE_SET ] = !!_self.id;
|
|
3690
|
+
}
|
|
3691
|
+
}
|
|
3692
|
+
if (!_self.id) {
|
|
3693
|
+
_self.id = _generateNewId();
|
|
3694
|
+
var newCookie = _generateNewCookie(_self.id);
|
|
3695
|
+
_setUserCookie(newCookie[_DYN_JOIN ](User[_DYN_COOKIE_SEPARATOR ]));
|
|
3696
|
+
var name_1 = (config[_DYN_NAME_PREFIX ] || "") + "ai_session";
|
|
3697
|
+
utlRemoveStorage(_logger, name_1);
|
|
3698
|
+
}
|
|
3699
|
+
_self[_DYN_ACCOUNT_ID ] = config[_DYN_ACCOUNT_ID ] || undefined;
|
|
3700
|
+
var authCookie = _cookieManager.get(User[_DYN_AUTH_USER_COOKIE_NAM7 ]);
|
|
3701
|
+
if (authCookie) {
|
|
3702
|
+
authCookie = decodeURI(authCookie);
|
|
3703
|
+
var authCookieString = authCookie.split(User[_DYN_COOKIE_SEPARATOR ]);
|
|
3704
|
+
if (authCookieString[0]) {
|
|
3705
|
+
_self[_DYN_AUTHENTICATED_ID ] = authCookieString[0];
|
|
3706
|
+
}
|
|
3707
|
+
if (authCookieString[_DYN_LENGTH ] > 1 && authCookieString[1]) {
|
|
3708
|
+
_self[_DYN_ACCOUNT_ID ] = authCookieString[1];
|
|
3709
|
+
}
|
|
3710
|
+
}
|
|
3711
|
+
});
|
|
3712
|
+
unloadHookContainer && unloadHookContainer.add(unloadHook);
|
|
3713
|
+
function _generateNewId() {
|
|
3714
|
+
var theConfig = (config || {});
|
|
3715
|
+
var getNewId = theConfig[_DYN_GET_NEW_ID ] || newId;
|
|
3716
|
+
var id = getNewId(theConfig[_DYN_ID_LENGTH ] ? config[_DYN_ID_LENGTH ] : 22);
|
|
3717
|
+
return id;
|
|
3718
|
+
}
|
|
3719
|
+
function _generateNewCookie(userId) {
|
|
3720
|
+
var acqStr = toISOString(new Date());
|
|
3721
|
+
_self.accountAcquisitionDate = acqStr;
|
|
3722
|
+
_self[_DYN_IS_NEW_USER ] = true;
|
|
3723
|
+
var newCookie = [userId, acqStr];
|
|
3724
|
+
return newCookie;
|
|
3725
|
+
}
|
|
3726
|
+
function _setUserCookie(cookie) {
|
|
3727
|
+
var oneYear = 31536000;
|
|
3728
|
+
_self[_DYN_IS_USER_COOKIE_SET ] = _cookieManager.set(_storageNamePrefix, cookie, oneYear);
|
|
3729
|
+
}
|
|
3730
|
+
_self.setAuthenticatedUserContext = function (authenticatedUserId, accountId, storeInCookie) {
|
|
3731
|
+
if (storeInCookie === void 0) { storeInCookie = false; }
|
|
3732
|
+
var isInvalidInput = !_validateUserInput(authenticatedUserId) || (accountId && !_validateUserInput(accountId));
|
|
3733
|
+
if (isInvalidInput) {
|
|
3734
|
+
_throwInternal(_logger, 2 , 60 , "Setting auth user context failed. " +
|
|
3735
|
+
"User auth/account id should be of type string, and not contain commas, semi-colons, equal signs, spaces, or vertical-bars.", true);
|
|
3736
|
+
return;
|
|
3737
|
+
}
|
|
3738
|
+
_self[_DYN_AUTHENTICATED_ID ] = authenticatedUserId;
|
|
3739
|
+
var authCookie = _self[_DYN_AUTHENTICATED_ID ];
|
|
3740
|
+
if (accountId) {
|
|
3741
|
+
_self[_DYN_ACCOUNT_ID ] = accountId;
|
|
3742
|
+
authCookie = [_self[_DYN_AUTHENTICATED_ID ], _self.accountId][_DYN_JOIN ](User[_DYN_COOKIE_SEPARATOR ]);
|
|
3743
|
+
}
|
|
3744
|
+
if (storeInCookie) {
|
|
3745
|
+
_cookieManager.set(User[_DYN_AUTH_USER_COOKIE_NAM7 ], encodeURI(authCookie));
|
|
3746
|
+
}
|
|
3747
|
+
};
|
|
3748
|
+
_self.clearAuthenticatedUserContext = function () {
|
|
3749
|
+
_self[_DYN_AUTHENTICATED_ID ] = null;
|
|
3750
|
+
_self[_DYN_ACCOUNT_ID ] = null;
|
|
3751
|
+
_cookieManager.del(User[_DYN_AUTH_USER_COOKIE_NAM7 ]);
|
|
3752
|
+
};
|
|
3753
|
+
_self[_DYN_UPDATE ] = function (userId) {
|
|
3754
|
+
if (_self.id !== userId || !_self[_DYN_IS_USER_COOKIE_SET ]) {
|
|
3755
|
+
var user_id = userId ? userId : _generateNewId();
|
|
3756
|
+
var user_cookie = _generateNewCookie(user_id);
|
|
3757
|
+
_setUserCookie(user_cookie[_DYN_JOIN ](User[_DYN_COOKIE_SEPARATOR ]));
|
|
3758
|
+
}
|
|
3759
|
+
};
|
|
3760
|
+
});
|
|
3761
|
+
}
|
|
3762
|
+
User.cookieSeparator = "|";
|
|
3763
|
+
User.userCookieName = "ai_user";
|
|
3764
|
+
User.authUserCookieName = "ai_authUser";
|
|
3765
|
+
return User;
|
|
3766
|
+
}());
|
|
3767
|
+
|
|
3768
|
+
var strExt = "ext";
|
|
3769
|
+
var strTags = "tags";
|
|
3770
|
+
function _removeEmpty(target, name) {
|
|
3771
|
+
if (target && target[name] && objKeys(target[name])[_DYN_LENGTH ] === 0) {
|
|
3772
|
+
delete target[name];
|
|
3773
|
+
}
|
|
3774
|
+
}
|
|
3775
|
+
function _nullResult() {
|
|
3776
|
+
return null;
|
|
3777
|
+
}
|
|
3778
|
+
var TelemetryContext = /** @class */ (function () {
|
|
3779
|
+
function TelemetryContext(core, defaultConfig, previousTraceCtx, unloadHookContainer) {
|
|
3780
|
+
var _this = this;
|
|
3781
|
+
var logger = core.logger;
|
|
3782
|
+
dynamicProto(TelemetryContext, this, function (_self) {
|
|
3783
|
+
_self.appId = _nullResult;
|
|
3784
|
+
_self[_DYN_GET_SESSION_ID ] = _nullResult;
|
|
3785
|
+
_self.application = new Application();
|
|
3786
|
+
_self.internal = new Internal(defaultConfig, unloadHookContainer);
|
|
3787
|
+
if (hasWindow()) {
|
|
3788
|
+
_self[_DYN_SESSION_MANAGER ] = new _SessionManager(defaultConfig, core, unloadHookContainer);
|
|
3789
|
+
_self.device = new Device();
|
|
3790
|
+
_self.location = new Location();
|
|
3791
|
+
_self.user = new User(defaultConfig, core, unloadHookContainer);
|
|
3792
|
+
var traceId = void 0;
|
|
3793
|
+
var parentId = void 0;
|
|
3794
|
+
var name_1;
|
|
3795
|
+
if (previousTraceCtx) {
|
|
3796
|
+
traceId = previousTraceCtx.getTraceId();
|
|
3797
|
+
parentId = previousTraceCtx.getSpanId();
|
|
3798
|
+
name_1 = previousTraceCtx.getName();
|
|
3799
|
+
}
|
|
3800
|
+
_self[_DYN_TELEMETRY_TRACE ] = new TelemetryTrace(traceId, parentId, name_1, logger);
|
|
3801
|
+
_self.session = new Session();
|
|
3802
|
+
}
|
|
3803
|
+
_self[_DYN_GET_SESSION_ID ] = function () {
|
|
3804
|
+
var session = _self.session;
|
|
3805
|
+
var sesId = null;
|
|
3806
|
+
if (session && isString(session.id)) {
|
|
3807
|
+
sesId = session.id;
|
|
3808
|
+
}
|
|
3809
|
+
else {
|
|
3810
|
+
var autoSession = (_self[_DYN_SESSION_MANAGER ] || {})[_DYN_AUTOMATIC_SESSION ];
|
|
3811
|
+
sesId = autoSession && isString(autoSession.id) ? autoSession.id : null;
|
|
3812
|
+
}
|
|
3813
|
+
return sesId;
|
|
3814
|
+
};
|
|
3815
|
+
_self[_DYN_APPLY_SESSION_CONTEX0 ] = function (evt, itemCtx) {
|
|
3816
|
+
setValue(getSetValue(evt.ext, Extensions.AppExt), "sesId", _self[_DYN_GET_SESSION_ID ](), isString);
|
|
3817
|
+
};
|
|
3818
|
+
_self[_DYN_APPLY_OPERATING_SYST3 ] = function (evt, itemCtx) {
|
|
3819
|
+
setValue(evt.ext, Extensions.OSExt, _self.os);
|
|
3820
|
+
};
|
|
3821
|
+
_self[_DYN_APPLY_APPLICATION_CO1 ] = function (evt, itemCtx) {
|
|
3822
|
+
var application = _self.application;
|
|
3823
|
+
if (application) {
|
|
3824
|
+
var tags = getSetValue(evt, strTags);
|
|
3825
|
+
setValue(tags, CtxTagKeys.applicationVersion, application.ver, isString);
|
|
3826
|
+
setValue(tags, CtxTagKeys.applicationBuild, application.build, isString);
|
|
3827
|
+
}
|
|
3828
|
+
};
|
|
3829
|
+
_self[_DYN_APPLY_DEVICE_CONTEXT ] = function (evt, itemCtx) {
|
|
3830
|
+
var device = _self.device;
|
|
3831
|
+
if (device) {
|
|
3832
|
+
var extDevice = getSetValue(getSetValue(evt, strExt), Extensions.DeviceExt);
|
|
3833
|
+
setValue(extDevice, "localId", device.id, isString);
|
|
3834
|
+
setValue(extDevice, "ip", device.ip, isString);
|
|
3835
|
+
setValue(extDevice, "model", device.model, isString);
|
|
3836
|
+
setValue(extDevice, "deviceClass", device.deviceClass, isString);
|
|
3837
|
+
}
|
|
3838
|
+
};
|
|
3839
|
+
_self[_DYN_APPLY_INTERNAL_CONTE5 ] = function (evt, itemCtx) {
|
|
3840
|
+
var internal = _self.internal;
|
|
3841
|
+
if (internal) {
|
|
3842
|
+
var tags = getSetValue(evt, strTags);
|
|
3843
|
+
setValue(tags, CtxTagKeys.internalAgentVersion, internal.agentVersion, isString);
|
|
3844
|
+
setValue(tags, CtxTagKeys.internalSdkVersion, internal.sdkVersion, isString);
|
|
3845
|
+
if (evt.baseType === _InternalLogMessage.dataType || evt.baseType === PageView.dataType) {
|
|
3846
|
+
setValue(tags, CtxTagKeys.internalSnippet, internal.snippetVer, isString);
|
|
3847
|
+
setValue(tags, CtxTagKeys.internalSdkSrc, internal.sdkSrc, isString);
|
|
3848
|
+
}
|
|
3849
|
+
}
|
|
3850
|
+
};
|
|
3851
|
+
_self[_DYN_APPLY_LOCATION_CONTE4 ] = function (evt, itemCtx) {
|
|
3852
|
+
var location = _this.location;
|
|
3853
|
+
if (location) {
|
|
3854
|
+
setValue(getSetValue(evt, strTags, []), CtxTagKeys.locationIp, location.ip, isString);
|
|
3855
|
+
}
|
|
3856
|
+
};
|
|
3857
|
+
_self[_DYN_APPLY_OPERATION_CONT2 ] = function (evt, itemCtx) {
|
|
3858
|
+
var telemetryTrace = _self[_DYN_TELEMETRY_TRACE ];
|
|
3859
|
+
if (telemetryTrace) {
|
|
3860
|
+
var extTrace = getSetValue(getSetValue(evt, strExt), Extensions.TraceExt, { traceID: undefined, parentID: undefined });
|
|
3861
|
+
setValue(extTrace, "traceID", telemetryTrace.traceID, isString, isNullOrUndefined);
|
|
3862
|
+
setValue(extTrace, "name", telemetryTrace.name, isString, isNullOrUndefined);
|
|
3863
|
+
setValue(extTrace, "parentID", telemetryTrace.parentID, isString, isNullOrUndefined);
|
|
3864
|
+
}
|
|
3865
|
+
};
|
|
3866
|
+
_self.applyWebContext = function (evt, itemCtx) {
|
|
3867
|
+
var web = _this.web;
|
|
3868
|
+
if (web) {
|
|
3869
|
+
setValue(getSetValue(evt, strExt), Extensions.WebExt, web);
|
|
3870
|
+
}
|
|
3871
|
+
};
|
|
3872
|
+
_self[_DYN_APPLY_USER_CONTEXT ] = function (evt, itemCtx) {
|
|
3873
|
+
var user = _self.user;
|
|
3874
|
+
if (user) {
|
|
3875
|
+
var tags = getSetValue(evt, strTags, []);
|
|
3876
|
+
setValue(tags, CtxTagKeys.userAccountId, user[_DYN_ACCOUNT_ID ], isString);
|
|
3877
|
+
var extUser = getSetValue(getSetValue(evt, strExt), Extensions.UserExt);
|
|
3878
|
+
setValue(extUser, "id", user.id, isString);
|
|
3879
|
+
setValue(extUser, "authId", user[_DYN_AUTHENTICATED_ID ], isString);
|
|
3880
|
+
}
|
|
3881
|
+
};
|
|
3882
|
+
_self.cleanUp = function (evt, itemCtx) {
|
|
3883
|
+
var ext = evt.ext;
|
|
3884
|
+
if (ext) {
|
|
3885
|
+
_removeEmpty(ext, Extensions.DeviceExt);
|
|
3886
|
+
_removeEmpty(ext, Extensions.UserExt);
|
|
3887
|
+
_removeEmpty(ext, Extensions.WebExt);
|
|
3888
|
+
_removeEmpty(ext, Extensions.OSExt);
|
|
3889
|
+
_removeEmpty(ext, Extensions.AppExt);
|
|
3890
|
+
_removeEmpty(ext, Extensions.TraceExt);
|
|
3891
|
+
}
|
|
3892
|
+
};
|
|
3893
|
+
});
|
|
3894
|
+
}
|
|
3895
|
+
TelemetryContext.__ieDyn=1;
|
|
3896
|
+
return TelemetryContext;
|
|
3897
|
+
}());
|
|
3898
|
+
|
|
3899
|
+
var _a;
|
|
3900
|
+
var undefString;
|
|
3901
|
+
var nullValue = null;
|
|
3902
|
+
var _defaultConfig = objDeepFreeze((_a = {},
|
|
3903
|
+
_a[_DYN_ACCOUNT_ID ] = nullValue,
|
|
3904
|
+
_a.sessionRenewalMs = 30 * 60 * 1000,
|
|
3905
|
+
_a.samplingPercentage = 100,
|
|
3906
|
+
_a.sessionExpirationMs = 24 * 60 * 60 * 1000,
|
|
3907
|
+
_a.cookieDomain = nullValue,
|
|
3908
|
+
_a.sdkExtension = nullValue,
|
|
3909
|
+
_a.isBrowserLinkTrackingEnabled = false,
|
|
3910
|
+
_a.appId = nullValue,
|
|
3911
|
+
_a[_DYN_GET_SESSION_ID ] = nullValue,
|
|
3912
|
+
_a[_DYN_NAME_PREFIX ] = undefString,
|
|
3913
|
+
_a[_DYN_SESSION_COOKIE_POSTF6 ] = undefString,
|
|
3914
|
+
_a[_DYN_USER_COOKIE_POSTFIX ] = undefString,
|
|
3915
|
+
_a[_DYN_ID_LENGTH ] = 22,
|
|
3916
|
+
_a[_DYN_GET_NEW_ID ] = nullValue,
|
|
3917
|
+
_a));
|
|
3918
|
+
var PropertiesPlugin = /** @class */ (function (_super) {
|
|
3919
|
+
__extendsFn(PropertiesPlugin, _super);
|
|
3920
|
+
function PropertiesPlugin() {
|
|
3921
|
+
var _this = _super.call(this) || this;
|
|
3922
|
+
_this.priority = 110;
|
|
3923
|
+
_this.identifier = PropertiesPluginIdentifier;
|
|
3924
|
+
var _extensionConfig;
|
|
3925
|
+
var _distributedTraceCtx;
|
|
3926
|
+
var _previousTraceCtx;
|
|
3927
|
+
var _context;
|
|
3928
|
+
dynamicProto(PropertiesPlugin, _this, function (_self, _base) {
|
|
3929
|
+
_initDefaults();
|
|
3930
|
+
objDefine(_self, "context", {
|
|
3931
|
+
g: function () {
|
|
3932
|
+
return _context;
|
|
3933
|
+
}
|
|
3934
|
+
});
|
|
3935
|
+
_self.initialize = function (config, core, extensions, pluginChain) {
|
|
3936
|
+
_base.initialize(config, core, extensions, pluginChain);
|
|
3937
|
+
_populateDefaults(config);
|
|
3938
|
+
};
|
|
3939
|
+
_self.processTelemetry = function (event, itemCtx) {
|
|
3940
|
+
if (!isNullOrUndefined(event)) {
|
|
3941
|
+
itemCtx = _self._getTelCtx(itemCtx);
|
|
3942
|
+
if (event.name === PageView.envelopeType) {
|
|
3943
|
+
itemCtx.diagLog().resetInternalMessageCount();
|
|
3944
|
+
}
|
|
3945
|
+
var theContext = (_context || {});
|
|
3946
|
+
if (theContext.session) {
|
|
3947
|
+
if (typeof _context.session.id !== "string" && theContext[_DYN_SESSION_MANAGER ]) {
|
|
3948
|
+
theContext[_DYN_SESSION_MANAGER ][_DYN_UPDATE ]();
|
|
3949
|
+
}
|
|
3950
|
+
}
|
|
3951
|
+
var userCtx = theContext.user;
|
|
3952
|
+
if (userCtx && !userCtx[_DYN_IS_USER_COOKIE_SET ]) {
|
|
3953
|
+
userCtx[_DYN_UPDATE ](theContext.user.id);
|
|
3954
|
+
}
|
|
3955
|
+
_processTelemetryInternal(event, itemCtx);
|
|
3956
|
+
if (userCtx && userCtx[_DYN_IS_NEW_USER ]) {
|
|
3957
|
+
userCtx[_DYN_IS_NEW_USER ] = false;
|
|
3958
|
+
var message = new _InternalLogMessage(72 , ((getNavigator() || {}).userAgent || ""));
|
|
3959
|
+
_logInternalMessage(itemCtx.diagLog(), 1 , message);
|
|
3960
|
+
}
|
|
3961
|
+
_self.processNext(event, itemCtx);
|
|
3962
|
+
}
|
|
3963
|
+
};
|
|
3964
|
+
_self._doTeardown = function (unloadCtx, unloadState) {
|
|
3965
|
+
var core = (unloadCtx || {}).core();
|
|
3966
|
+
if (core && core[_DYN_GET_TRACE_CTX ]) {
|
|
3967
|
+
var traceCtx = core[_DYN_GET_TRACE_CTX ](false);
|
|
3968
|
+
if (traceCtx === _distributedTraceCtx) {
|
|
3969
|
+
core.setTraceCtx(_previousTraceCtx);
|
|
3970
|
+
}
|
|
3971
|
+
}
|
|
3972
|
+
_initDefaults();
|
|
3973
|
+
};
|
|
3974
|
+
function _initDefaults() {
|
|
3975
|
+
_extensionConfig = null;
|
|
3976
|
+
_distributedTraceCtx = null;
|
|
3977
|
+
_previousTraceCtx = null;
|
|
3978
|
+
_context = null;
|
|
3979
|
+
}
|
|
3980
|
+
function _populateDefaults(config) {
|
|
3981
|
+
var identifier = _self.identifier;
|
|
3982
|
+
var core = _self.core;
|
|
3983
|
+
_self._addHook(onConfigChange(config, function () {
|
|
3984
|
+
var ctx = createProcessTelemetryContext(null, config, core);
|
|
3985
|
+
_extensionConfig = ctx.getExtCfg(identifier, _defaultConfig);
|
|
3986
|
+
_self["_extConfig"] = _extensionConfig;
|
|
3987
|
+
}));
|
|
3988
|
+
_previousTraceCtx = core[_DYN_GET_TRACE_CTX ](false);
|
|
3989
|
+
_context = new TelemetryContext(core, _extensionConfig, _previousTraceCtx, _self._unloadHooks);
|
|
3990
|
+
_distributedTraceCtx = createDistributedTraceContextFromTrace(_self.context[_DYN_TELEMETRY_TRACE ], _previousTraceCtx);
|
|
3991
|
+
core.setTraceCtx(_distributedTraceCtx);
|
|
3992
|
+
_self.context.appId = function () {
|
|
3993
|
+
var breezeChannel = core.getPlugin(BreezeChannelIdentifier);
|
|
3994
|
+
return breezeChannel ? breezeChannel.plugin["_appId"] : null;
|
|
3995
|
+
};
|
|
3996
|
+
}
|
|
3997
|
+
function _processTelemetryInternal(evt, itemCtx) {
|
|
3998
|
+
getSetValue(evt, "tags", []);
|
|
3999
|
+
getSetValue(evt, "ext", {});
|
|
4000
|
+
var ctx = _self.context;
|
|
4001
|
+
ctx[_DYN_APPLY_SESSION_CONTEX0 ](evt, itemCtx);
|
|
4002
|
+
ctx[_DYN_APPLY_APPLICATION_CO1 ](evt, itemCtx);
|
|
4003
|
+
ctx[_DYN_APPLY_DEVICE_CONTEXT ](evt, itemCtx);
|
|
4004
|
+
ctx[_DYN_APPLY_OPERATION_CONT2 ](evt, itemCtx);
|
|
4005
|
+
ctx[_DYN_APPLY_USER_CONTEXT ](evt, itemCtx);
|
|
4006
|
+
ctx[_DYN_APPLY_OPERATING_SYST3 ](evt, itemCtx);
|
|
4007
|
+
ctx.applyWebContext(evt, itemCtx);
|
|
4008
|
+
ctx[_DYN_APPLY_LOCATION_CONTE4 ](evt, itemCtx);
|
|
4009
|
+
ctx[_DYN_APPLY_INTERNAL_CONTE5 ](evt, itemCtx);
|
|
4010
|
+
ctx.cleanUp(evt, itemCtx);
|
|
4011
|
+
}
|
|
4012
|
+
});
|
|
4013
|
+
return _this;
|
|
4014
|
+
}
|
|
4015
|
+
PropertiesPlugin.__ieDyn=1;
|
|
4016
|
+
return PropertiesPlugin;
|
|
4017
|
+
}(BaseTelemetryPlugin));
|
|
4018
|
+
var PropertiesPlugin$1 = PropertiesPlugin;
|
|
4019
|
+
|
|
4020
|
+
exports.PropertiesPlugin = PropertiesPlugin$1;
|
|
4021
|
+
exports.Session = Session;
|
|
4022
|
+
exports.SessionManager = _SessionManager;
|
|
4023
|
+
exports.TelemetryContext = TelemetryContext;
|
|
4024
|
+
exports.TelemetryTrace = TelemetryTrace;
|
|
4025
|
+
|
|
4026
|
+
}));
|
|
4027
|
+
//# sourceMappingURL=ai.props.3.0.2-nightly3.2305-04.gbl.js.map
|