@microsoft/ocsdk
Advanced tools
Comparing version 0.4.2-main.1b891ac to 0.4.2-main.543077b
@@ -8,2 +8,5 @@ # Changelog | ||
### Changed | ||
- Removal of `recursive call` in `LoggingSanitizer` as preventive measure for `stack overflow` | ||
## [0.4.1] - 2023-11-10 | ||
@@ -10,0 +13,0 @@ |
@@ -5,3 +5,6 @@ export declare class LoggingSanitizer { | ||
static stripGeolocation(data: any): void; | ||
static stripAuthenticationUserToken(headers: any): void; | ||
static stripRequestPayloadData(configObject: any): void; | ||
static stripAxiosErrorSensitiveProperties(errorObject: any): void; | ||
static stripErrorSensitiveProperties(errorObject: any): void; | ||
} |
@@ -66,52 +66,85 @@ "use strict"; | ||
}, { | ||
key: "stripErrorSensitiveProperties", | ||
value: function stripErrorSensitiveProperties(errorObject) { | ||
var _Object$keys2, | ||
_this = this; | ||
key: "stripAuthenticationUserToken", | ||
value: function stripAuthenticationUserToken(headers) { | ||
// eslint-disable-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types | ||
if (headers) { | ||
if (Object.keys(headers).includes('AuthenticatedUserToken')) { | ||
headers['AuthenticatedUserToken'] = _Constants["default"].hiddenContentPlaceholder; | ||
} | ||
if (Object.keys(headers).includes('AuthCodeNonce')) { | ||
headers['AuthCodeNonce'] = _Constants["default"].hiddenContentPlaceholder; | ||
} | ||
} | ||
} | ||
}, { | ||
key: "stripRequestPayloadData", | ||
value: function stripRequestPayloadData(configObject) { | ||
// eslint-disable-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types | ||
if (errorObject && (0, _typeof2["default"])(errorObject) === 'object' && ((_Object$keys2 = Object.keys(errorObject)) === null || _Object$keys2 === void 0 ? void 0 : _Object$keys2.length) > 0) { | ||
var _Object$keys3; | ||
if (configObject !== null && configObject !== void 0 && configObject.data) { | ||
var data; | ||
(_Object$keys3 = Object.keys(errorObject)) === null || _Object$keys3 === void 0 ? void 0 : _Object$keys3.forEach(function (key) { | ||
if (_Constants["default"].sensitiveProperties.indexOf(key) !== -1) { | ||
// remove sensitive properties from error object | ||
delete errorObject["".concat(key)]; | ||
if (typeof configObject.data === 'string') { | ||
// eslint-disable-line security/detect-object-injection | ||
try { | ||
data = JSON.parse(configObject.data); // eslint-disable-line security/detect-object-injection | ||
} catch (_unused) { | ||
data = undefined; | ||
} | ||
} | ||
if (key === 'data') { | ||
var data; | ||
if (data) { | ||
if (Object.keys(data).includes('preChatResponse')) { | ||
LoggingSanitizer.stripPreChatResponse(data.preChatResponse); | ||
} | ||
if (typeof errorObject[key] === 'string') { | ||
// eslint-disable-line security/detect-object-injection | ||
try { | ||
data = JSON.parse(errorObject[key]); // eslint-disable-line security/detect-object-injection | ||
} catch (_unused) { | ||
data = undefined; | ||
} | ||
} | ||
if (Object.keys(data).includes('customContextData')) { | ||
LoggingSanitizer.stripCustomContextDataValues(data.customContextData); | ||
} | ||
if (data) { | ||
if (Object.keys(data).includes('preChatResponse')) { | ||
LoggingSanitizer.stripPreChatResponse(data.preChatResponse); | ||
} | ||
LoggingSanitizer.stripGeolocation(data); | ||
configObject.data = JSON.stringify(data); // eslint-disable-line security/detect-object-injection | ||
} | ||
} | ||
} | ||
}, { | ||
key: "stripAxiosErrorSensitiveProperties", | ||
value: function stripAxiosErrorSensitiveProperties(errorObject) { | ||
// eslint-disable-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types | ||
if (errorObject.isAxiosError) { | ||
var _errorObject$config, _errorObject$config3, _errorObject$response, _errorObject$response2, _errorObject$response4, _errorObject$response5; | ||
if (Object.keys(data).includes('customContextData')) { | ||
LoggingSanitizer.stripCustomContextDataValues(data.customContextData); | ||
} | ||
if (errorObject !== null && errorObject !== void 0 && (_errorObject$config = errorObject.config) !== null && _errorObject$config !== void 0 && _errorObject$config.headers) { | ||
var _errorObject$config2; | ||
LoggingSanitizer.stripGeolocation(data); | ||
errorObject[key] = JSON.stringify(data); // eslint-disable-line security/detect-object-injection | ||
} | ||
} | ||
LoggingSanitizer.stripAuthenticationUserToken(errorObject === null || errorObject === void 0 ? void 0 : (_errorObject$config2 = errorObject.config) === null || _errorObject$config2 === void 0 ? void 0 : _errorObject$config2.headers); | ||
} | ||
if (errorObject["".concat(key)] !== null && (0, _typeof2["default"])(errorObject["".concat(key)]) === 'object') { | ||
// check sensitive properties in nested error object | ||
_this.stripErrorSensitiveProperties(errorObject["".concat(key)]); | ||
if (errorObject !== null && errorObject !== void 0 && (_errorObject$config3 = errorObject.config) !== null && _errorObject$config3 !== void 0 && _errorObject$config3.data) { | ||
this.stripRequestPayloadData(errorObject === null || errorObject === void 0 ? void 0 : errorObject.config); | ||
} | ||
return; | ||
} | ||
}); | ||
if (errorObject !== null && errorObject !== void 0 && (_errorObject$response = errorObject.response) !== null && _errorObject$response !== void 0 && (_errorObject$response2 = _errorObject$response.config) !== null && _errorObject$response2 !== void 0 && _errorObject$response2.data) { | ||
var _errorObject$response3; | ||
this.stripRequestPayloadData(errorObject === null || errorObject === void 0 ? void 0 : (_errorObject$response3 = errorObject.response) === null || _errorObject$response3 === void 0 ? void 0 : _errorObject$response3.config); | ||
} | ||
if (errorObject !== null && errorObject !== void 0 && (_errorObject$response4 = errorObject.response) !== null && _errorObject$response4 !== void 0 && (_errorObject$response5 = _errorObject$response4.config) !== null && _errorObject$response5 !== void 0 && _errorObject$response5.headers) { | ||
var _errorObject$response6, _errorObject$response7; | ||
LoggingSanitizer.stripAuthenticationUserToken(errorObject === null || errorObject === void 0 ? void 0 : (_errorObject$response6 = errorObject.response) === null || _errorObject$response6 === void 0 ? void 0 : (_errorObject$response7 = _errorObject$response6.config) === null || _errorObject$response7 === void 0 ? void 0 : _errorObject$response7.headers); | ||
} | ||
} | ||
} | ||
}, { | ||
key: "stripErrorSensitiveProperties", | ||
value: function stripErrorSensitiveProperties(errorObject) { | ||
var _Object$keys2; | ||
// eslint-disable-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types | ||
if (errorObject && (0, _typeof2["default"])(errorObject) === 'object' && ((_Object$keys2 = Object.keys(errorObject)) === null || _Object$keys2 === void 0 ? void 0 : _Object$keys2.length) > 0) { | ||
this.stripAxiosErrorSensitiveProperties(errorObject); | ||
} | ||
} | ||
}]); | ||
@@ -122,2 +155,2 @@ return LoggingSanitizer; | ||
exports.LoggingSanitizer = LoggingSanitizer; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9VdGlscy9Mb2dnaW5nU2FuaXRpemVyLnRzIl0sIm5hbWVzIjpbIkxvZ2dpbmdTYW5pdGl6ZXIiLCJjdXN0b21Db250ZXh0RGF0YSIsIk9iamVjdCIsImtleXMiLCJmb3JFYWNoIiwiY29udGV4dEtleSIsInZhbHVlIiwiQ29uc3RhbnRzIiwiaGlkZGVuQ29udGVudFBsYWNlaG9sZGVyIiwicHJlQ2hhdFJlc3BvbnNlIiwicmVzcG9uc2VLZXkiLCJkYXRhIiwiaW5jbHVkZXMiLCJlcnJvck9iamVjdCIsImxlbmd0aCIsImtleSIsInNlbnNpdGl2ZVByb3BlcnRpZXMiLCJpbmRleE9mIiwiSlNPTiIsInBhcnNlIiwidW5kZWZpbmVkIiwic3RyaXBQcmVDaGF0UmVzcG9uc2UiLCJzdHJpcEN1c3RvbUNvbnRleHREYXRhVmFsdWVzIiwic3RyaXBHZW9sb2NhdGlvbiIsInN0cmluZ2lmeSIsInN0cmlwRXJyb3JTZW5zaXRpdmVQcm9wZXJ0aWVzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7SUFFYUEsZ0I7Ozs7Ozs7V0FDWCxzQ0FBMkNDLGlCQUEzQyxFQUF5RTtBQUFFO0FBQ3pFLFVBQUlBLGlCQUFKLEVBQXVCO0FBQUE7O0FBQ3JCLHdCQUFBQyxNQUFNLENBQUNDLElBQVAsQ0FBWUYsaUJBQVosK0RBQWdDRyxPQUFoQyxDQUF3QyxVQUFDQyxVQUFELEVBQXdCO0FBQUE7O0FBQzlELHFDQUFJSixpQkFBaUIsV0FBSUksVUFBSixFQUFyQixnREFBSSxvQkFBb0NDLEtBQXhDLEVBQStDO0FBQzdDTCxZQUFBQSxpQkFBaUIsV0FBSUksVUFBSixFQUFqQixDQUFtQ0MsS0FBbkMsR0FBMkNDLHNCQUFVQyx3QkFBckQ7QUFDRDtBQUNGLFNBSkQ7QUFLRDtBQUNGOzs7V0FFRCw4QkFBbUNDLGVBQW5DLEVBQStEO0FBQUU7QUFDL0QsVUFBSUEsZUFBSixFQUFxQjtBQUNuQlAsUUFBQUEsTUFBTSxDQUFDQyxJQUFQLENBQVlNLGVBQVos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ZGs6Ly8vIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IENvbnN0YW50cyBmcm9tIFwiLi4vQ29tbW9uL0NvbnN0YW50c1wiO1xuXG5leHBvcnQgY2xhc3MgTG9nZ2luZ1Nhbml0aXplciB7XG4gIHB1YmxpYyBzdGF0aWMgc3RyaXBDdXN0b21Db250ZXh0RGF0YVZhbHVlcyhjdXN0b21Db250ZXh0RGF0YTogYW55KTogdm9pZCB7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueSwgQHR5cGVzY3JpcHQtZXNsaW50L2V4cGxpY2l0LW1vZHVsZS1ib3VuZGFyeS10eXBlc1xuICAgIGlmIChjdXN0b21Db250ZXh0RGF0YSkge1xuICAgICAgT2JqZWN0LmtleXMoY3VzdG9tQ29udGV4dERhdGEpPy5mb3JFYWNoKChjb250ZXh0S2V5OiBzdHJpbmcpID0+IHtcbiAgICAgICAgaWYgKGN1c3RvbUNvbnRleHREYXRhW2Ake2NvbnRleHRLZXl9YF0/LnZhbHVlKSB7XG4gICAgICAgICAgY3VzdG9tQ29udGV4dERhdGFbYCR7Y29udGV4dEtleX1gXS52YWx1ZSA9IENvbnN0YW50cy5oaWRkZW5Db250ZW50UGxhY2Vob2xkZXI7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH1cbiAgfVxuXG4gIHB1YmxpYyBzdGF0aWMgc3RyaXBQcmVDaGF0UmVzcG9uc2UocHJlQ2hhdFJlc3BvbnNlOiBhbnkpOiB2b2lkIHsgLy8gZXNsaW50LWRpc2FibGUtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55LCBAdHlwZXNjcmlwdC1lc2xpbnQvZXhwbGljaXQtbW9kdWxlLWJvdW5kYXJ5LXR5cGVzXG4gICAgaWYgKHByZUNoYXRSZXNwb25zZSkge1xuICAgICAgT2JqZWN0LmtleXMocHJlQ2hhdFJlc3BvbnNlKS5mb3JFYWNoKChyZXNwb25zZUtleSkgPT4ge1xuICAgICAgICBpZiAocHJlQ2hhdFJlc3BvbnNlW2Ake3Jlc3BvbnNlS2V5fWBdICYmIHJlc3BvbnNlS2V5ICE9PSAnVHlwZScpIHtcbiAgICAgICAgICBwcmVDaGF0UmVzcG9uc2VbYCR7cmVzcG9uc2VLZXl9YF0gPSBDb25zdGFudHMuaGlkZGVuQ29udGVudFBsYWNlaG9sZGVyO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgc3RhdGljIHN0cmlwR2VvbG9jYXRpb24oZGF0YTogYW55KTogdm9pZCB7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueSwgQHR5cGVzY3JpcHQtZXNsaW50L2V4cGxpY2l0LW1vZHVsZS1ib3VuZGFyeS10eXBlc1xuICAgIGlmIChkYXRhKSB7XG4gICAgICBpZiAoT2JqZWN0LmtleXMoZGF0YSkuaW5jbHVkZXMoJ2xvbmdpdHVkZScpKSB7XG4gICAgICAgIGRhdGFbJ2xvbmdpdHVkZSddID0gQ29uc3RhbnRzLmhpZGRlbkNvbnRlbnRQbGFjZWhvbGRlcjtcbiAgICAgIH1cblxuICAgICAgaWYgKE9iamVjdC5rZXlzKGRhdGEpLmluY2x1ZGVzKCdsYXRpdHVkZScpKSB7XG4gICAgICAgIGRhdGFbJ2xhdGl0dWRlJ10gPSBDb25zdGFudHMuaGlkZGVuQ29udGVudFBsYWNlaG9sZGVyO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHB1YmxpYyBzdGF0aWMgc3RyaXBFcnJvclNlbnNpdGl2ZVByb3BlcnRpZXMoZXJyb3JPYmplY3Q6IGFueSk6IHZvaWQgeyAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnksIEB0eXBlc2NyaXB0LWVzbGludC9leHBsaWNpdC1tb2R1bGUtYm91bmRhcnktdHlwZXNcbiAgICBpZihlcnJvck9iamVjdCAmJiB0eXBlb2YgZXJyb3JPYmplY3QgPT09ICdvYmplY3QnICYmIE9iamVjdC5rZXlzKGVycm9yT2JqZWN0KT8ubGVuZ3RoID4gMCkge1xuICAgICAgT2JqZWN0LmtleXMoZXJyb3JPYmplY3QpPy5mb3JFYWNoKChrZXkpID0+IHtcbiAgICAgICAgICBpZiAoQ29uc3RhbnRzLnNlbnNpdGl2ZVByb3BlcnRpZXMuaW5kZXhPZihrZXkpICE9PSAtMSkge1xuICAgICAgICAgICAgLy8gcmVtb3ZlIHNlbnNpdGl2ZSBwcm9wZXJ0aWVzIGZyb20gZXJyb3Igb2JqZWN0XG4gICAgICAgICAgICBkZWxldGUgZXJyb3JPYmplY3RbYCR7a2V5fWBdO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIGlmIChrZXkgPT09ICdkYXRhJykge1xuICAgICAgICAgICAgbGV0IGRhdGE7XG4gICAgICAgICAgICBpZiAodHlwZW9mIGVycm9yT2JqZWN0W2tleV0gPT09ICdzdHJpbmcnKSB7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgc2VjdXJpdHkvZGV0ZWN0LW9iamVjdC1pbmplY3Rpb25cbiAgICAgICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgICAgICBkYXRhID0gSlNPTi5wYXJzZShlcnJvck9iamVjdFtrZXldKTsgLy8gZXNsaW50LWRpc2FibGUtbGluZSBzZWN1cml0eS9kZXRlY3Qtb2JqZWN0LWluamVjdGlvblxuICAgICAgICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICAgICAgICBkYXRhID0gdW5kZWZpbmVkO1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGlmIChkYXRhKSB7XG4gICAgICAgICAgICAgIGlmIChPYmplY3Qua2V5cyhkYXRhKS5pbmNsdWRlcygncHJlQ2hhdFJlc3BvbnNlJykpIHtcbiAgICAgICAgICAgICAgICBMb2dnaW5nU2FuaXRpemVyLnN0cmlwUHJlQ2hhdFJlc3BvbnNlKGRhdGEucHJlQ2hhdFJlc3BvbnNlKTtcbiAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgIGlmIChPYmplY3Qua2V5cyhkYXRhKS5pbmNsdWRlcygnY3VzdG9tQ29udGV4dERhdGEnKSkge1xuICAgICAgICAgICAgICAgIExvZ2dpbmdTYW5pdGl6ZXIuc3RyaXBDdXN0b21Db250ZXh0RGF0YVZhbHVlcyhkYXRhLmN1c3RvbUNvbnRleHREYXRhKTtcbiAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgIExvZ2dpbmdTYW5pdGl6ZXIuc3RyaXBHZW9sb2NhdGlvbihkYXRhKTtcbiAgICAgICAgICAgICAgZXJyb3JPYmplY3Rba2V5XSA9IEpTT04uc3RyaW5naWZ5KGRhdGEpOyAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIHNlY3VyaXR5L2RldGVjdC1vYmplY3QtaW5qZWN0aW9uXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgaWYgKGVycm9yT2JqZWN0W2Ake2tleX1gXSAhPT0gbnVsbCAmJiB0eXBlb2YgZXJyb3JPYmplY3RbYCR7a2V5fWBdID09PSAnb2JqZWN0Jykge1xuICAgICAgICAgICAgLy8gY2hlY2sgc2Vuc2l0aXZlIHByb3BlcnRpZXMgaW4gbmVzdGVkIGVycm9yIG9iamVjdFxuICAgICAgICAgICAgdGhpcy5zdHJpcEVycm9yU2Vuc2l0aXZlUHJvcGVydGllcyhlcnJvck9iamVjdFtgJHtrZXl9YF0pO1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH1cbiAgfVxufSJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Utils/LoggingSanitizer.ts"],"names":["LoggingSanitizer","customContextData","Object","keys","forEach","contextKey","value","Constants","hiddenContentPlaceholder","preChatResponse","responseKey","data","includes","headers","configObject","JSON","parse","undefined","stripPreChatResponse","stripCustomContextDataValues","stripGeolocation","stringify","errorObject","isAxiosError","config","stripAuthenticationUserToken","stripRequestPayloadData","response","length","stripAxiosErrorSensitiveProperties"],"mappings":"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","sourceRoot":"ocsdk:///","sourcesContent":["import Constants from \"../Common/Constants\";\n\nexport class LoggingSanitizer {\n  public static stripCustomContextDataValues(customContextData: any): void { // eslint-disable-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n    if (customContextData) {\n      Object.keys(customContextData)?.forEach((contextKey: string) => {\n        if (customContextData[`${contextKey}`]?.value) {\n          customContextData[`${contextKey}`].value = Constants.hiddenContentPlaceholder;\n        }\n      });\n    }\n  }\n\n  public static stripPreChatResponse(preChatResponse: any): void { // eslint-disable-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n    if (preChatResponse) {\n      Object.keys(preChatResponse).forEach((responseKey) => {\n        if (preChatResponse[`${responseKey}`] && responseKey !== 'Type') {\n          preChatResponse[`${responseKey}`] = Constants.hiddenContentPlaceholder;\n        }\n      });\n    }\n  }\n\n  public static stripGeolocation(data: any): void { // eslint-disable-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n    if (data) {\n      if (Object.keys(data).includes('longitude')) {\n        data['longitude'] = Constants.hiddenContentPlaceholder;\n      }\n\n      if (Object.keys(data).includes('latitude')) {\n        data['latitude'] = Constants.hiddenContentPlaceholder;\n      }\n    }\n  }\n\n  public static stripAuthenticationUserToken(headers: any): void { // eslint-disable-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n    if (headers) {\n      if (Object.keys(headers).includes('AuthenticatedUserToken')) {\n        headers['AuthenticatedUserToken'] = Constants.hiddenContentPlaceholder;\n      }\n\n      if (Object.keys(headers).includes('AuthCodeNonce')) {\n        headers['AuthCodeNonce'] = Constants.hiddenContentPlaceholder;\n      }\n    }\n  }\n\n  public static stripRequestPayloadData(configObject: any): void {  // eslint-disable-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n    if (configObject?.data) {\n      let data;\n      if (typeof configObject.data === 'string') { // eslint-disable-line security/detect-object-injection\n        try {\n          data = JSON.parse(configObject.data); // eslint-disable-line security/detect-object-injection\n        } catch {\n          data = undefined;\n        }\n      }\n\n      if (data) {\n        if (Object.keys(data).includes('preChatResponse')) {\n          LoggingSanitizer.stripPreChatResponse(data.preChatResponse);\n        }\n\n        if (Object.keys(data).includes('customContextData')) {\n          LoggingSanitizer.stripCustomContextDataValues(data.customContextData);\n        }\n\n        LoggingSanitizer.stripGeolocation(data);\n        configObject.data = JSON.stringify(data); // eslint-disable-line security/detect-object-injection\n      }\n    }\n  }\n\n  public static stripAxiosErrorSensitiveProperties(errorObject: any): void { // eslint-disable-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n    if (errorObject.isAxiosError) {\n      if (errorObject?.config?.headers) {\n        LoggingSanitizer.stripAuthenticationUserToken(errorObject?.config?.headers);\n      }\n\n      if (errorObject?.config?.data) {\n        this.stripRequestPayloadData(errorObject?.config);\n      }\n\n      if (errorObject?.response?.config?.data) {\n        this.stripRequestPayloadData(errorObject?.response?.config);\n      }\n\n      if (errorObject?.response?.config?.headers) {\n        LoggingSanitizer.stripAuthenticationUserToken(errorObject?.response?.config?.headers);\n      }\n    }\n  }\n\n  public static stripErrorSensitiveProperties(errorObject: any): void { // eslint-disable-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n    if (errorObject && typeof errorObject === 'object' && Object.keys(errorObject)?.length > 0) {\n      this.stripAxiosErrorSensitiveProperties(errorObject);\n    }\n  }\n}\n"]} |
{ | ||
"name": "@microsoft/ocsdk", | ||
"version": "0.4.2-main.1b891ac", | ||
"version": "0.4.2-main.543077b", | ||
"description": "Microsoft Omnichannel SDK", | ||
@@ -5,0 +5,0 @@ "files": [ |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
6055304
7030