@cargolift-cdi/lib-common 0.0.4 → 0.0.5

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,6 @@
1
1
  export declare class PayloadUtil {
2
+ static readonly sensitiveKeys: string[];
2
3
  static normalize(payload: unknown): Record<string, any> | unknown[] | undefined;
4
+ static sanitize(payload: Record<string, any> | unknown[] | undefined): Record<string, any> | unknown[] | undefined;
3
5
  static sanitizeHeader(headers: Record<string, any> | undefined): Record<string, any> | undefined;
4
6
  }
@@ -16,12 +16,39 @@ export class PayloadUtil {
16
16
  }
17
17
  return undefined;
18
18
  }
19
+ static sanitize(payload) {
20
+ if (payload === undefined)
21
+ return undefined;
22
+ const sanitize = (obj) => {
23
+ if (Array.isArray(obj)) {
24
+ return obj.map(sanitize);
25
+ }
26
+ else if (obj !== null && typeof obj === "object") {
27
+ const sanitizedObj = {};
28
+ for (const [key, value] of Object.entries(obj)) {
29
+ if (typeof value === "object" && value !== null) {
30
+ sanitizedObj[key] = sanitize(value);
31
+ }
32
+ else {
33
+ if (PayloadUtil.sensitiveKeys.includes(key.toLowerCase())) {
34
+ sanitizedObj[key] = "[REDACTED]";
35
+ }
36
+ else {
37
+ sanitizedObj[key] = value;
38
+ }
39
+ }
40
+ }
41
+ return sanitizedObj;
42
+ }
43
+ return obj;
44
+ };
45
+ return sanitize(payload);
46
+ }
19
47
  static sanitizeHeader(headers) {
20
48
  if (!headers)
21
49
  return undefined;
22
50
  const sanitized = { ...headers };
23
- const sensitiveKeys = ["authorization", "proxy-authorization", "cookie", "set-cookie", "x-api-key"];
24
- for (const key of sensitiveKeys) {
51
+ for (const key of PayloadUtil.sensitiveKeys) {
25
52
  for (const headerKey of Object.keys(sanitized)) {
26
53
  if (headerKey.toLowerCase() === key) {
27
54
  sanitized[headerKey] = "[REDACTED]";
@@ -31,4 +58,17 @@ export class PayloadUtil {
31
58
  return sanitized;
32
59
  }
33
60
  }
61
+ PayloadUtil.sensitiveKeys = [
62
+ "authorization",
63
+ "proxy-authorization",
64
+ "cookie",
65
+ "set-cookie",
66
+ "x-api-key",
67
+ "secret",
68
+ "password",
69
+ "token",
70
+ "access_token",
71
+ "refresh_token",
72
+ "api_key",
73
+ ];
34
74
  //# 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;IAOM,MAAM,CAAC,QAAQ,CACpB,OAAoD;QAEpD,IAAI,OAAO,KAAK,SAAS;YAAE,OAAO,SAAS,CAAC;QAE5C,MAAM,QAAQ,GAAG,CAAC,GAAQ,EAAO,EAAE;YACjC,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;gBACvB,OAAO,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;YAC3B,CAAC;iBAAM,IAAI,GAAG,KAAK,IAAI,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;gBACnD,MAAM,YAAY,GAAwB,EAAE,CAAC;gBAC7C,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;oBAC/C,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;wBAChD,YAAY,CAAC,GAAG,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;oBACtC,CAAC;yBAAM,CAAC;wBACN,IAAI,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC;4BAC1D,YAAY,CAAC,GAAG,CAAC,GAAG,YAAY,CAAC;wBACnC,CAAC;6BAAM,CAAC;4BACN,YAAY,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;wBAC5B,CAAC;oBACH,CAAC;gBACH,CAAC;gBACD,OAAO,YAAY,CAAC;YACtB,CAAC;YACD,OAAO,GAAG,CAAC;QACb,CAAC,CAAC;QAEF,OAAO,QAAQ,CAAC,OAAO,CAAC,CAAC;IAC3B,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;QAGtD,KAAK,MAAM,GAAG,IAAI,WAAW,CAAC,aAAa,EAAE,CAAC;YAC5C,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;;AA9Ee,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.5",
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
- "prepublishOnly": "npm run build && npm version patch --no-git-tag-version"
13
+ "prepublishOnly": "npm run build && npm version patch --no-git-tag-version",
14
+ "updatelibs": "npm update @cargolift-cdi/types"
14
15
  },
15
16
  "author": "Cargolift CDI",
16
17
  "license": "MIT",