@cargolift-cdi/lib-common 0.0.5 → 0.0.6
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/dist/__tests__/payload-util/payload-util.test.d.ts +1 -0
- package/dist/__tests__/payload-util/payload-util.test.js +45 -0
- package/dist/__tests__/payload-util/payload-util.test.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/util/payload.util.d.ts +1 -2
- package/dist/util/payload.util.js +21 -28
- package/dist/util/payload.util.js.map +1 -1
- package/package.json +5 -3
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
export declare class PayloadUtil {
|
|
2
2
|
static readonly sensitiveKeys: string[];
|
|
3
3
|
static normalize(payload: unknown): Record<string, any> | unknown[] | undefined;
|
|
4
|
-
static sanitize(payload: Record<string, any> | unknown[] | undefined): Record<string, any> | unknown[] | undefined;
|
|
5
|
-
static sanitizeHeader(headers: Record<string, any> | undefined): Record<string, any> | undefined;
|
|
4
|
+
static sanitize(payload: Record<string, any> | unknown[] | undefined | string): Record<string, any> | unknown[] | string | undefined;
|
|
6
5
|
}
|
|
@@ -19,43 +19,36 @@ export class PayloadUtil {
|
|
|
19
19
|
static sanitize(payload) {
|
|
20
20
|
if (payload === undefined)
|
|
21
21
|
return undefined;
|
|
22
|
-
const
|
|
23
|
-
|
|
24
|
-
|
|
22
|
+
const isSensitive = (key) => this.sensitiveKeys.includes(key.toLowerCase());
|
|
23
|
+
const sanitizeValue = (value) => {
|
|
24
|
+
if (Array.isArray(value)) {
|
|
25
|
+
return value.map(sanitizeValue);
|
|
25
26
|
}
|
|
26
|
-
|
|
27
|
-
const
|
|
28
|
-
for (const
|
|
29
|
-
if (
|
|
30
|
-
|
|
27
|
+
if (value && typeof value === "object") {
|
|
28
|
+
const sanitized = {};
|
|
29
|
+
for (const key of Object.keys(value)) {
|
|
30
|
+
if (isSensitive(key)) {
|
|
31
|
+
sanitized[key] = "[REDACTED]";
|
|
31
32
|
}
|
|
32
33
|
else {
|
|
33
|
-
|
|
34
|
-
sanitizedObj[key] = "[REDACTED]";
|
|
35
|
-
}
|
|
36
|
-
else {
|
|
37
|
-
sanitizedObj[key] = value;
|
|
38
|
-
}
|
|
34
|
+
sanitized[key] = sanitizeValue(value[key]);
|
|
39
35
|
}
|
|
40
36
|
}
|
|
41
|
-
return
|
|
37
|
+
return sanitized;
|
|
42
38
|
}
|
|
43
|
-
return
|
|
39
|
+
return value;
|
|
44
40
|
};
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
if (headerKey.toLowerCase() === key) {
|
|
54
|
-
sanitized[headerKey] = "[REDACTED]";
|
|
55
|
-
}
|
|
41
|
+
if (typeof payload === "string") {
|
|
42
|
+
try {
|
|
43
|
+
const parsed = JSON.parse(payload);
|
|
44
|
+
const sanitized = sanitizeValue(parsed);
|
|
45
|
+
return JSON.stringify(sanitized);
|
|
46
|
+
}
|
|
47
|
+
catch {
|
|
48
|
+
return payload;
|
|
56
49
|
}
|
|
57
50
|
}
|
|
58
|
-
return
|
|
51
|
+
return sanitizeValue(payload);
|
|
59
52
|
}
|
|
60
53
|
}
|
|
61
54
|
PayloadUtil.sensitiveKeys = [
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"payload.util.js","sourceRoot":"","sources":["../../src/util/payload.util.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,WAAW;IAcf,MAAM,CAAC,SAAS,CAAC,OAAgB;QACtC,IAAI,OAAO,KAAK,IAAI,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;YAC9C,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;YAChC,OAAO,OAA0C,CAAC;QACpD,CAAC;QACD,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;YAChC,IAAI,CAAC;gBACH,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAC7B,CAAC;YAAC,MAAM,CAAC;gBACP,OAAO,SAAS,CAAC;YACnB,CAAC;QACH,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;
|
|
1
|
+
{"version":3,"file":"payload.util.js","sourceRoot":"","sources":["../../src/util/payload.util.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,WAAW;IAcf,MAAM,CAAC,SAAS,CAAC,OAAgB;QACtC,IAAI,OAAO,KAAK,IAAI,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;YAC9C,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;YAChC,OAAO,OAA0C,CAAC;QACpD,CAAC;QACD,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;YAChC,IAAI,CAAC;gBACH,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAC7B,CAAC;YAAC,MAAM,CAAC;gBACP,OAAO,SAAS,CAAC;YACnB,CAAC;QACH,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IASM,MAAM,CAAC,QAAQ,CACpB,OAA6D;QAE7D,IAAI,OAAO,KAAK,SAAS;YAAE,OAAO,SAAS,CAAC;QAE5C,MAAM,WAAW,GAAG,CAAC,GAAW,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC;QAEpF,MAAM,aAAa,GAAG,CAAC,KAAU,EAAO,EAAE;YACxC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;gBACzB,OAAO,KAAK,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;YAClC,CAAC;YAED,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;gBACvC,MAAM,SAAS,GAAQ,EAAE,CAAC;gBAC1B,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;oBACrC,IAAI,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC;wBACrB,SAAS,CAAC,GAAG,CAAC,GAAG,YAAY,CAAC;oBAChC,CAAC;yBAAM,CAAC;wBACN,SAAS,CAAC,GAAG,CAAC,GAAG,aAAa,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;oBAC7C,CAAC;gBACH,CAAC;gBACD,OAAO,SAAS,CAAC;YACnB,CAAC;YAED,OAAO,KAAK,CAAC;QACf,CAAC,CAAC;QAEF,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;YAChC,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;gBACnC,MAAM,SAAS,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;gBACxC,OAAO,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;YACnC,CAAC;YAAC,MAAM,CAAC;gBAEP,OAAO,OAAO,CAAC;YACjB,CAAC;QACH,CAAC;QAED,OAAO,aAAa,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;;AA5Ee,yBAAa,GAAG;IAC9B,eAAe;IACf,qBAAqB;IACrB,QAAQ;IACR,YAAY;IACZ,WAAW;IACX,QAAQ;IACR,UAAU;IACV,OAAO;IACP,cAAc;IACd,eAAe;IACf,SAAS;CACV,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cargolift-cdi/lib-common",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.6",
|
|
4
4
|
"description": "Utilitários comuns para projetos do middleware Cargolift",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -10,7 +10,8 @@
|
|
|
10
10
|
],
|
|
11
11
|
"scripts": {
|
|
12
12
|
"build": "tsc -p tsconfig.json",
|
|
13
|
-
"
|
|
13
|
+
"test": "vitest run --reporter=dot",
|
|
14
|
+
"prepublishOnly": "npm run build && npm test && npm version patch --no-git-tag-version",
|
|
14
15
|
"updatelibs": "npm update @cargolift-cdi/types"
|
|
15
16
|
},
|
|
16
17
|
"author": "Cargolift CDI",
|
|
@@ -21,7 +22,8 @@
|
|
|
21
22
|
"devDependencies": {
|
|
22
23
|
"@cargolift-cdi/types": "latest",
|
|
23
24
|
"@types/node": "^24.3.0",
|
|
24
|
-
"typescript": "^5.9.2"
|
|
25
|
+
"typescript": "^5.9.2",
|
|
26
|
+
"vitest": "^4.0.16"
|
|
25
27
|
},
|
|
26
28
|
"repository": {
|
|
27
29
|
"type": "git",
|