@microsoft/applicationinsights-dependencies-js 3.3.10-nightly3.2507-07 → 3.3.10-nightly3.2507-17

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (30) hide show
  1. package/browser/es5/applicationinsights-dependencies-js.cjs.js +119 -5
  2. package/browser/es5/applicationinsights-dependencies-js.cjs.js.map +1 -1
  3. package/browser/es5/applicationinsights-dependencies-js.cjs.min.js +2 -2
  4. package/browser/es5/applicationinsights-dependencies-js.cjs.min.js.map +1 -1
  5. package/browser/es5/applicationinsights-dependencies-js.gbl.js +121 -7
  6. package/browser/es5/applicationinsights-dependencies-js.gbl.js.map +1 -1
  7. package/browser/es5/applicationinsights-dependencies-js.gbl.min.js +2 -2
  8. package/browser/es5/applicationinsights-dependencies-js.gbl.min.js.map +1 -1
  9. package/browser/es5/applicationinsights-dependencies-js.integrity.json +25 -25
  10. package/browser/es5/applicationinsights-dependencies-js.js +121 -7
  11. package/browser/es5/applicationinsights-dependencies-js.js.map +1 -1
  12. package/browser/es5/applicationinsights-dependencies-js.min.js +2 -2
  13. package/browser/es5/applicationinsights-dependencies-js.min.js.map +1 -1
  14. package/dist/es5/applicationinsights-dependencies-js.js +119 -5
  15. package/dist/es5/applicationinsights-dependencies-js.js.map +1 -1
  16. package/dist/es5/applicationinsights-dependencies-js.min.js +2 -2
  17. package/dist/es5/applicationinsights-dependencies-js.min.js.map +1 -1
  18. package/dist-es5/DependencyInitializer.js +1 -1
  19. package/dist-es5/DependencyListener.js +1 -1
  20. package/dist-es5/InternalConstants.js +1 -1
  21. package/dist-es5/__DynamicConstants.js +2 -2
  22. package/dist-es5/__DynamicConstants.js.map +1 -1
  23. package/dist-es5/ajax.js +5 -2
  24. package/dist-es5/ajax.js.map +1 -1
  25. package/dist-es5/ajaxRecord.js +1 -1
  26. package/dist-es5/ajaxUtils.js +1 -1
  27. package/dist-es5/applicationinsights-dependencies-js.js +1 -1
  28. package/package.json +3 -3
  29. package/types/applicationinsights-dependencies-js.d.ts +1 -1
  30. package/types/applicationinsights-dependencies-js.namespaced.d.ts +14 -1
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * Application Insights JavaScript SDK - Dependencies Plugin, 3.3.10-nightly3.2507-07
2
+ * Application Insights JavaScript SDK - Dependencies Plugin, 3.3.10-nightly3.2507-17
3
3
  * Copyright (c) Microsoft and contributors. All rights reserved.
4
4
  */
5
5
  'use strict';
@@ -1157,6 +1157,8 @@ var _DYN_SET_NEXT_PLUGIN = "setNextPlugin";
1157
1157
  var _DYN_USER_AGENT = "userAgent";
1158
1158
  var _DYN_SPLIT$1 = "split";
1159
1159
  var _DYN_REPLACE = "replace";
1160
+ var _DYN_SUBSTRING = "substring";
1161
+ var _DYN_INDEX_OF = "indexOf";
1160
1162
  var _DYN_TYPE = "type";
1161
1163
  var _DYN_IS_CHILD_EVT = "isChildEvt";
1162
1164
  var _DYN_GET_CTX = "getCtx";
@@ -1188,6 +1190,8 @@ var STR_PROCESS_TELEMETRY = "processTelemetry";
1188
1190
  var STR_PRIORITY = "priority";
1189
1191
  var STR_GET_PERF_MGR = "getPerfMgr";
1190
1192
  var STR_NOT_DYNAMIC_ERROR = "Not dynamic - ";
1193
+ var STR_REDACTED = "REDACTED";
1194
+ var DEFAULT_SENSITIVE_PARAMS = ["sig", "Signature", "AWSAccessKeyId", "X-Goog-Signature"];
1191
1195
 
1192
1196
  var strGetPrototypeOf = "getPrototypeOf";
1193
1197
  var rCamelCase = /-([a-z])/g;
@@ -1348,6 +1352,110 @@ function isXhrSupported() {
1348
1352
  }
1349
1353
  return isSupported;
1350
1354
  }
1355
+ function redactUserInfo(url) {
1356
+ return url.replace(/^([a-zA-Z][a-zA-Z0-9+.-]*:\/\/)([^:@]{1,200}):([^@]{1,200})@(.*)$/, "$1REDACTED:REDACTED@$4");
1357
+ }
1358
+ function redactQueryParameters(url, config) {
1359
+ var sensitiveParams;
1360
+ var questionMarkIndex = strIndexOf(url, "?");
1361
+ if (questionMarkIndex === -1) {
1362
+ return url;
1363
+ }
1364
+ if (config && config.redactQueryParams) {
1365
+ sensitiveParams = DEFAULT_SENSITIVE_PARAMS.concat(config.redactQueryParams);
1366
+ }
1367
+ else {
1368
+ sensitiveParams = DEFAULT_SENSITIVE_PARAMS;
1369
+ }
1370
+ var baseUrl = strSubstring(url, 0, questionMarkIndex + 1);
1371
+ var queryString = strSubstring(url, questionMarkIndex + 1);
1372
+ var fragment = STR_EMPTY;
1373
+ var hashIndex = strIndexOf(queryString, "#");
1374
+ if (hashIndex !== -1) {
1375
+ fragment = strSubstring(queryString, hashIndex);
1376
+ queryString = strSubstring(queryString, 0, hashIndex);
1377
+ }
1378
+ var hasPotentialSensitiveParam = false;
1379
+ for (var i = 0; i < sensitiveParams[_DYN_LENGTH$2 ]; i++) {
1380
+ var paramCheck = sensitiveParams[i] + "=";
1381
+ if (strIndexOf(queryString, paramCheck) !== -1) {
1382
+ hasPotentialSensitiveParam = true;
1383
+ break;
1384
+ }
1385
+ }
1386
+ if (!hasPotentialSensitiveParam) {
1387
+ return url;
1388
+ }
1389
+ var resultParts = [];
1390
+ var anyParamRedacted = false;
1391
+ if (queryString && queryString[_DYN_LENGTH$2 ]) {
1392
+ var pairs = queryString[_DYN_SPLIT$1 ]("&");
1393
+ for (var i = 0; i < pairs[_DYN_LENGTH$2 ]; i++) {
1394
+ var pair = pairs[i];
1395
+ if (!pair) {
1396
+ continue;
1397
+ }
1398
+ var equalsIndex = strIndexOf(pair, "=");
1399
+ if (equalsIndex === -1) {
1400
+ resultParts[_DYN_PUSH ](pair);
1401
+ }
1402
+ else {
1403
+ var paramName = pair[_DYN_SUBSTRING ](0, equalsIndex);
1404
+ var paramValue = pair[_DYN_SUBSTRING ](equalsIndex + 1);
1405
+ if (paramValue === STR_EMPTY) {
1406
+ resultParts[_DYN_PUSH ](pair);
1407
+ }
1408
+ else {
1409
+ var shouldRedact = false;
1410
+ for (var j = 0; j < sensitiveParams[_DYN_LENGTH$2 ]; j++) {
1411
+ if (paramName === sensitiveParams[j]) {
1412
+ shouldRedact = true;
1413
+ anyParamRedacted = true;
1414
+ break;
1415
+ }
1416
+ }
1417
+ if (shouldRedact) {
1418
+ resultParts[_DYN_PUSH ](paramName + "=" + STR_REDACTED);
1419
+ }
1420
+ else {
1421
+ resultParts[_DYN_PUSH ](pair);
1422
+ }
1423
+ }
1424
+ }
1425
+ }
1426
+ }
1427
+ if (!anyParamRedacted) {
1428
+ return url;
1429
+ }
1430
+ return baseUrl + resultParts.join("&") + fragment;
1431
+ }
1432
+ function fieldRedaction(input, config) {
1433
+ if (!input || input[_DYN_INDEX_OF ](" ") !== -1) {
1434
+ return input;
1435
+ }
1436
+ var isRedactionDisabled = config && config.redactUrls === false;
1437
+ if (isRedactionDisabled) {
1438
+ return input;
1439
+ }
1440
+ var hasCredentials = strIndexOf(input, "@") !== -1;
1441
+ var hasQueryParams = strIndexOf(input, "?") !== -1;
1442
+ if (!hasCredentials && !hasQueryParams) {
1443
+ return input;
1444
+ }
1445
+ try {
1446
+ var result = input;
1447
+ if (hasCredentials) {
1448
+ result = redactUserInfo(input);
1449
+ }
1450
+ if (hasQueryParams) {
1451
+ result = redactQueryParameters(result, config);
1452
+ }
1453
+ return result;
1454
+ }
1455
+ catch (e) {
1456
+ return input;
1457
+ }
1458
+ }
1351
1459
 
1352
1460
  var UInt32Mask = 0x100000000;
1353
1461
  var MaxUInt32 = 0xffffffff;
@@ -1419,7 +1527,7 @@ function newId(maxLength) {
1419
1527
  return result;
1420
1528
  }
1421
1529
 
1422
- var version = '3.3.10-nightly3.2507-07';
1530
+ var version = '3.3.10-nightly3.2507-17';
1423
1531
  var instanceName = "." + newId(6);
1424
1532
  var _dataUid = 0;
1425
1533
  function _canAcceptData(target) {
@@ -3286,7 +3394,7 @@ var DEFAULT_BREEZE_PATH = "/v2/track";
3286
3394
  var strNotSpecified = "not_specified";
3287
3395
  var strIkey = "iKey";
3288
3396
 
3289
- var RequestHeaders = createValueMap({
3397
+ var RequestHeaders = ( /* @__PURE__ */createValueMap({
3290
3398
  requestContextHeader: [0 , "Request-Context"],
3291
3399
  requestContextTargetKey: [1 , "appId"],
3292
3400
  requestContextAppIdFormat: [2 , "appId=cid-v1:"],
@@ -3296,7 +3404,7 @@ var RequestHeaders = createValueMap({
3296
3404
  sdkContextHeader: [6 , "Sdk-Context"],
3297
3405
  sdkContextHeaderAppIdRequest: [7 , "appId"],
3298
3406
  requestContextHeaderLowerCase: [8 , "request-context"]
3299
- });
3407
+ }));
3300
3408
 
3301
3409
  var _DYN_SPLIT = "split";
3302
3410
  var _DYN_LENGTH$1 = "length";
@@ -3348,7 +3456,10 @@ function dataSanitizeString(logger, value, maxLength) {
3348
3456
  }
3349
3457
  return valueTrunc || value;
3350
3458
  }
3351
- function dataSanitizeUrl(logger, url) {
3459
+ function dataSanitizeUrl(logger, url, config) {
3460
+ if (isString(url)) {
3461
+ url = fieldRedaction(url, config);
3462
+ }
3352
3463
  return dataSanitizeInput(logger, url, 2048 , 66 );
3353
3464
  }
3354
3465
  function dataSanitizeProperties(logger, properties) {
@@ -5005,6 +5116,9 @@ var AjaxMonitor = /** @class */ (function (_super) {
5005
5116
  requestUrl = strSplit(location_1.href, "#")[0];
5006
5117
  }
5007
5118
  }
5119
+ if (_self[_DYN_CORE ] && _self[_DYN_CORE ].config) {
5120
+ requestUrl = fieldRedaction(requestUrl, _self[_DYN_CORE ].config);
5121
+ }
5008
5122
  ajaxData[_DYN_REQUEST_URL ] = requestUrl;
5009
5123
  var method = "GET";
5010
5124
  if (init && init[_DYN_METHOD ]) {