fix: sanitize object no longer mutates original object
This commit is contained in:
parent
f14f0bccf5
commit
ea017016b7
1 changed files with 21 additions and 17 deletions
38
app/utils.js
38
app/utils.js
|
@ -2,31 +2,35 @@
|
|||
// /app/utils.js
|
||||
|
||||
/**
|
||||
* Recursively sanitizes a copy of an object by replacing the value of any `password`
|
||||
* property with asterisks (*) matching the length of the original password.
|
||||
*
|
||||
* Sanitizes an object by replacing sensitive properties with asterisks.
|
||||
* @param {Object} obj - The object to sanitize.
|
||||
* @returns {Object} - The sanitized copy of the object.
|
||||
* @param {Array} [properties=['password', 'key', 'secret', 'token']] - The list of properties to sanitize.
|
||||
* @returns {Object} - The sanitized object.
|
||||
*/
|
||||
function sanitizeObject(obj) {
|
||||
if (obj && typeof obj === 'object') {
|
||||
const copy = Array.isArray(obj) ? [] : Object.assign({}, obj);
|
||||
|
||||
function sanitizeObject(
|
||||
obj,
|
||||
properties = ["password", "key", "secret", "token"]
|
||||
) {
|
||||
if (obj && typeof obj === "object") {
|
||||
const copy = Array.isArray(obj) ? [] : Object.assign({}, obj)
|
||||
|
||||
for (const key in obj) {
|
||||
if (obj.hasOwnProperty(key)) { // eslint-disable-line no-prototype-builtins
|
||||
if (key === 'password' && typeof obj[key] === 'string') {
|
||||
copy[key] = '*'.repeat(obj[key].length);
|
||||
} else if (typeof obj[key] === 'object') {
|
||||
copy[key] = sanitizeObject(obj[key]);
|
||||
if (obj.hasOwnProperty(key)) {
|
||||
// eslint-disable-line no-prototype-builtins
|
||||
if (properties.includes(key) && typeof obj[key] === "string") {
|
||||
copy[key] = "*".repeat(obj[key].length)
|
||||
} else if (typeof obj[key] === "object") {
|
||||
copy[key] = sanitizeObject(obj[key], properties)
|
||||
} else {
|
||||
copy[key] = obj[key];
|
||||
copy[key] = obj[key]
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return copy;
|
||||
return copy
|
||||
}
|
||||
|
||||
return obj;
|
||||
return obj
|
||||
}
|
||||
exports.sanitizeObject = sanitizeObject;
|
||||
|
||||
exports.sanitizeObject = sanitizeObject
|
||||
|
|
Loading…
Reference in a new issue