@cargolift-cdi/lib-common 0.0.4 → 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.
@@ -1,4 +1,5 @@
1
1
  export declare class PayloadUtil {
2
+ static readonly sensitiveKeys: string[];
2
3
  static normalize(payload: unknown): Record<string, any> | unknown[] | undefined;
3
- 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;
4
5
  }
@@ -16,19 +16,52 @@ export class PayloadUtil {
16
16
  }
17
17
  return undefined;
18
18
  }
19
- static sanitizeHeader(headers) {
20
- if (!headers)
19
+ static sanitize(payload) {
20
+ if (payload === undefined)
21
21
  return undefined;
22
- const sanitized = { ...headers };
23
- const sensitiveKeys = ["authorization", "proxy-authorization", "cookie", "set-cookie", "x-api-key"];
24
- for (const key of sensitiveKeys) {
25
- for (const headerKey of Object.keys(sanitized)) {
26
- if (headerKey.toLowerCase() === key) {
27
- sanitized[headerKey] = "[REDACTED]";
22
+ const isSensitive = (key) => this.sensitiveKeys.includes(key.toLowerCase());
23
+ const sanitizeValue = (value) => {
24
+ if (Array.isArray(value)) {
25
+ return value.map(sanitizeValue);
26
+ }
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]";
32
+ }
33
+ else {
34
+ sanitized[key] = sanitizeValue(value[key]);
35
+ }
28
36
  }
37
+ return sanitized;
38
+ }
39
+ return value;
40
+ };
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;
29
49
  }
30
50
  }
31
- return sanitized;
51
+ return sanitizeValue(payload);
32
52
  }
33
53
  }
54
+ PayloadUtil.sensitiveKeys = [
55
+ "authorization",
56
+ "proxy-authorization",
57
+ "cookie",
58
+ "set-cookie",
59
+ "x-api-key",
60
+ "secret",
61
+ "password",
62
+ "token",
63
+ "access_token",
64
+ "refresh_token",
65
+ "api_key",
66
+ ];
34
67
  //# sourceMappingURL=payload.util.js.map
@@ -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;IAGM,MAAM,CAAC,cAAc,CAAC,OAAwC;QACnE,IAAI,CAAC,OAAO;YAAE,OAAO,SAAS,CAAC;QAC/B,MAAM,SAAS,GAAwB,EAAE,GAAG,OAAO,EAAE,CAAC;QAEtD,MAAM,aAAa,GAAG,CAAC,eAAe,EAAE,qBAAqB,EAAE,QAAQ,EAAE,YAAY,EAAE,WAAW,CAAC,CAAC;QAEpG,KAAK,MAAM,GAAG,IAAI,aAAa,EAAE,CAAC;YAChC,KAAK,MAAM,SAAS,IAAI,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;gBAC/C,IAAI,SAAS,CAAC,WAAW,EAAE,KAAK,GAAG,EAAE,CAAC;oBACpC,SAAS,CAAC,SAAS,CAAC,GAAG,YAAY,CAAC;gBACtC,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;CACF"}
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.4",
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,9 @@
10
10
  ],
11
11
  "scripts": {
12
12
  "build": "tsc -p tsconfig.json",
13
- "prepublishOnly": "npm run build && npm version patch --no-git-tag-version"
13
+ "test": "vitest run --reporter=dot",
14
+ "prepublishOnly": "npm run build && npm test && npm version patch --no-git-tag-version",
15
+ "updatelibs": "npm update @cargolift-cdi/types"
14
16
  },
15
17
  "author": "Cargolift CDI",
16
18
  "license": "MIT",
@@ -20,7 +22,8 @@
20
22
  "devDependencies": {
21
23
  "@cargolift-cdi/types": "latest",
22
24
  "@types/node": "^24.3.0",
23
- "typescript": "^5.9.2"
25
+ "typescript": "^5.9.2",
26
+ "vitest": "^4.0.16"
24
27
  },
25
28
  "repository": {
26
29
  "type": "git",