@cargolift-cdi/common 1.0.19 → 1.0.21
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/errors/application.error.d.ts +1 -1
- package/dist/errors/application.error.js +2 -6
- package/dist/errors/application.error.js.map +1 -1
- package/dist/errors/base.error.js +1 -5
- package/dist/errors/base.error.js.map +1 -1
- package/dist/errors/business.error.d.ts +1 -1
- package/dist/errors/business.error.js +2 -6
- package/dist/errors/business.error.js.map +1 -1
- package/dist/errors/not-found-business.error.d.ts +2 -2
- package/dist/errors/not-found-business.error.js +2 -6
- package/dist/errors/not-found-business.error.js.map +1 -1
- package/dist/filters/api-exceptions.filter.d.ts +1 -1
- package/dist/filters/api-exceptions.filter.js +19 -36
- package/dist/filters/api-exceptions.filter.js.map +1 -1
- package/dist/index.d.ts +8 -4
- package/dist/index.js +8 -20
- package/dist/index.js.map +1 -1
- package/dist/logger/index.d.ts +3 -0
- package/dist/logger/index.js +4 -0
- package/dist/logger/index.js.map +1 -0
- package/dist/logger/logger.interface.d.ts +34 -0
- package/dist/logger/logger.interface.js +2 -0
- package/dist/logger/logger.interface.js.map +1 -0
- package/dist/logger/logger.module.d.ts +2 -0
- package/dist/logger/logger.module.js +19 -0
- package/dist/logger/logger.module.js.map +1 -0
- package/dist/logger/logger.service.d.ts +21 -0
- package/dist/logger/logger.service.js +137 -0
- package/dist/logger/logger.service.js.map +1 -0
- package/dist/middleware/api-logger.middleware.d.ts +8 -0
- package/dist/middleware/api-logger.middleware.js +86 -0
- package/dist/middleware/api-logger.middleware.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +6 -2
- package/dist/errors/generic-business.error.d.ts +0 -6
- package/dist/errors/generic-business.error.js +0 -17
- package/dist/errors/generic-business.error.js.map +0 -1
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
import { Injectable } from '@nestjs/common';
|
|
11
|
+
import { ModuleRef, ContextIdFactory } from '@nestjs/core';
|
|
12
|
+
import { LoggerContextService } from '../logger/logger.service.js';
|
|
13
|
+
let APILoggerMiddleware = class APILoggerMiddleware {
|
|
14
|
+
constructor(moduleRef) {
|
|
15
|
+
this.moduleRef = moduleRef;
|
|
16
|
+
}
|
|
17
|
+
async use(req, res, next) {
|
|
18
|
+
const contextId = ContextIdFactory.getByRequest(req);
|
|
19
|
+
const logger = await this.moduleRef.resolve(LoggerContextService, contextId, { strict: false });
|
|
20
|
+
const startHr = typeof process.hrtime.bigint === 'function' ? process.hrtime.bigint() : null;
|
|
21
|
+
try {
|
|
22
|
+
const url = req?.originalUrl || req?.url;
|
|
23
|
+
if (!logger.isContextSet()) {
|
|
24
|
+
logger.setContextRequest(req);
|
|
25
|
+
}
|
|
26
|
+
logger.info(`HTTP ${req?.method} ${url} [${res?.statusCode}] - Request received`, {
|
|
27
|
+
application: {
|
|
28
|
+
...logger.getContext().application || {},
|
|
29
|
+
action: 'request',
|
|
30
|
+
},
|
|
31
|
+
data: {
|
|
32
|
+
request: {
|
|
33
|
+
method: req?.method,
|
|
34
|
+
path: url,
|
|
35
|
+
},
|
|
36
|
+
payload: this.safeBody(req?.body),
|
|
37
|
+
},
|
|
38
|
+
});
|
|
39
|
+
res?.on?.('finish', () => {
|
|
40
|
+
const endHr = typeof process.hrtime.bigint === 'function' ? process.hrtime.bigint() : null;
|
|
41
|
+
const durationMs = startHr && endHr ? Number((endHr - startHr) / BigInt(1_000_000)) : undefined;
|
|
42
|
+
logger.info(`HTTP ${req?.method} ${url} [${res?.statusCode}] - Response sent`, {
|
|
43
|
+
application: {
|
|
44
|
+
...logger.getContext().application || {},
|
|
45
|
+
action: 'response',
|
|
46
|
+
},
|
|
47
|
+
data: {
|
|
48
|
+
response: {
|
|
49
|
+
statusCode: res?.statusCode,
|
|
50
|
+
durationMs,
|
|
51
|
+
body: res?.json,
|
|
52
|
+
},
|
|
53
|
+
payload: this.safeBody(res?.json),
|
|
54
|
+
},
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
catch {
|
|
59
|
+
}
|
|
60
|
+
finally {
|
|
61
|
+
next();
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
safeBody(body) {
|
|
65
|
+
if (!body || typeof body !== 'object')
|
|
66
|
+
return body;
|
|
67
|
+
const redact = new Set(['password', 'senha', 'token', 'access_token', 'authorization']);
|
|
68
|
+
const out = Array.isArray(body) ? {} : {};
|
|
69
|
+
try {
|
|
70
|
+
const src = Array.isArray(body) ? { array: body } : body;
|
|
71
|
+
for (const [k, v] of Object.entries(src)) {
|
|
72
|
+
out[k] = redact.has(k.toLowerCase()) ? '***' : v;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
catch {
|
|
76
|
+
return undefined;
|
|
77
|
+
}
|
|
78
|
+
return out;
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
APILoggerMiddleware = __decorate([
|
|
82
|
+
Injectable(),
|
|
83
|
+
__metadata("design:paramtypes", [ModuleRef])
|
|
84
|
+
], APILoggerMiddleware);
|
|
85
|
+
export { APILoggerMiddleware };
|
|
86
|
+
//# sourceMappingURL=api-logger.middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api-logger.middleware.js","sourceRoot":"","sources":["../../src/middleware/api-logger.middleware.ts"],"names":[],"mappings":"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"}
|