@icd-iot-aicf/nestjs-logger 2.3.0 → 4.0.0-experimental.0
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/README.md +103 -189
- package/dist/actions/action-types.d.ts +55 -0
- package/dist/{logger/core/dtos/core.dto.js → actions/action-types.js} +1 -1
- package/dist/actions/action-types.js.map +1 -0
- package/dist/actions/connection.action.d.ts +10 -0
- package/dist/actions/connection.action.js +23 -0
- package/dist/actions/connection.action.js.map +1 -0
- package/dist/actions/core-log-summary.d.ts +7 -0
- package/dist/actions/core-log-summary.js +22 -0
- package/dist/actions/core-log-summary.js.map +1 -0
- package/dist/actions/db.action.d.ts +8 -0
- package/dist/actions/db.action.js +37 -0
- package/dist/actions/db.action.js.map +1 -0
- package/dist/actions/exception.action.d.ts +3 -0
- package/dist/actions/exception.action.js +23 -0
- package/dist/actions/exception.action.js.map +1 -0
- package/dist/actions/http.action.d.ts +9 -0
- package/dist/actions/http.action.js +43 -0
- package/dist/actions/http.action.js.map +1 -0
- package/dist/actions/index.d.ts +10 -0
- package/dist/{logger/core/interceptors/interceptors.js → actions/index.js} +11 -4
- package/dist/actions/index.js.map +1 -0
- package/dist/actions/kafka.action.d.ts +5 -0
- package/dist/actions/kafka.action.js +24 -0
- package/dist/actions/kafka.action.js.map +1 -0
- package/dist/actions/logic.action.d.ts +16 -0
- package/dist/actions/logic.action.js +30 -0
- package/dist/actions/logic.action.js.map +1 -0
- package/dist/actions/rabbitmq.action.d.ts +6 -0
- package/dist/actions/rabbitmq.action.js +31 -0
- package/dist/actions/rabbitmq.action.js.map +1 -0
- package/dist/actions/smtp.action.d.ts +4 -0
- package/dist/actions/smtp.action.js +26 -0
- package/dist/actions/smtp.action.js.map +1 -0
- package/dist/{logger/core/functions/error-reponse.d.ts → common/error-response.d.ts} +1 -1
- package/dist/{logger/core/functions/error-reponse.js → common/error-response.js} +2 -2
- package/dist/common/error-response.js.map +1 -0
- package/dist/common/internal-logs-info.module.js +1 -1
- package/dist/common/internal-logs-info.module.js.map +1 -1
- package/dist/common/{helper/response.d.ts → response.d.ts} +1 -1
- package/dist/common/response.js.map +1 -0
- package/dist/common/{dto/result.dto.d.ts → result.dto.d.ts} +1 -1
- package/dist/common/{dto/result.dto.js → result.dto.js} +3 -3
- package/dist/common/result.dto.js.map +1 -0
- package/dist/common/{helper → service}/tools.service.d.ts +2 -2
- package/dist/common/{helper → service}/tools.service.js +2 -2
- package/dist/common/service/tools.service.js.map +1 -0
- package/dist/{utils → common}/tools.d.ts +2 -1
- package/dist/{utils → common}/tools.js +22 -8
- package/dist/common/tools.js.map +1 -0
- package/dist/config/app-log-config.module.js +9 -1
- package/dist/config/app-log-config.module.js.map +1 -1
- package/dist/config/app-log-config.service.js +1 -1
- package/dist/config/app-log-config.service.js.map +1 -1
- package/dist/config/configurations.d.ts +2 -3
- package/dist/config/configurations.js +0 -1
- package/dist/config/configurations.js.map +1 -1
- package/dist/{logger/core/functions/global-function.d.ts → context/context.functions.d.ts} +9 -9
- package/dist/{logger/core/functions/global-function.js → context/context.functions.js} +29 -31
- package/dist/context/context.functions.js.map +1 -0
- package/dist/context/external-transaction.store.d.ts +10 -0
- package/dist/context/external-transaction.store.js +6 -0
- package/dist/context/external-transaction.store.js.map +1 -0
- package/dist/context/summary-endpoint.store.d.ts +9 -0
- package/dist/context/summary-endpoint.store.js +12 -0
- package/dist/context/summary-endpoint.store.js.map +1 -0
- package/dist/{common/async-storage/tracnsaction-info.d.ts → context/transaction.store.d.ts} +1 -1
- package/dist/context/transaction.store.js +6 -0
- package/dist/context/transaction.store.js.map +1 -0
- package/dist/database/mongo-hooks.d.ts +37 -0
- package/dist/{logger/core/database/hook-ingress.database.js → database/mongo-hooks.js} +29 -17
- package/dist/database/mongo-hooks.js.map +1 -0
- package/dist/decorators/index.d.ts +3 -0
- package/dist/{logger/core/pipes → decorators}/index.js +3 -1
- package/dist/decorators/index.js.map +1 -0
- package/dist/decorators/masking.decorator.d.ts +1 -0
- package/dist/decorators/masking.decorator.js +8 -0
- package/dist/decorators/masking.decorator.js.map +1 -0
- package/dist/decorators/node-name.decorator.d.ts +8 -0
- package/dist/decorators/node-name.decorator.js +36 -0
- package/dist/decorators/node-name.decorator.js.map +1 -0
- package/dist/{logger/core/decorators/customDecorators.d.ts → decorators/record-name.decorator.d.ts} +4 -8
- package/dist/{logger/core/decorators/customDecorators.js → decorators/record-name.decorator.js} +5 -43
- package/dist/decorators/record-name.decorator.js.map +1 -0
- package/dist/{logger/aicf/services → formats/aicf}/aicf-endpoint.service.d.ts +3 -3
- package/dist/{logger/aicf/services → formats/aicf}/aicf-endpoint.service.js +14 -14
- package/dist/formats/aicf/aicf-endpoint.service.js.map +1 -0
- package/dist/formats/aicf/aicf-format.strategy.d.ts +15 -0
- package/dist/formats/aicf/aicf-format.strategy.js +66 -0
- package/dist/formats/aicf/aicf-format.strategy.js.map +1 -0
- package/dist/{logger/aicf/interceptors/aicf.interceptor.d.ts → formats/aicf/aicf-interceptor.d.ts} +2 -2
- package/dist/{logger/aicf/interceptors/aicf.interceptor.js → formats/aicf/aicf-interceptor.js} +5 -4
- package/dist/formats/aicf/aicf-interceptor.js.map +1 -0
- package/dist/{logger/aicf/dtos → formats/aicf}/aicf-manual.dto.d.ts +2 -2
- package/dist/{logger/aicf/dtos → formats/aicf}/aicf-manual.dto.js +12 -12
- package/dist/formats/aicf/aicf-manual.dto.js.map +1 -0
- package/dist/formats/aicf/aicf-middleware.d.ts +8 -0
- package/dist/formats/aicf/aicf-middleware.js +69 -0
- package/dist/formats/aicf/aicf-middleware.js.map +1 -0
- package/dist/{logger/aicf/dtos → formats/aicf}/aicf.dto.d.ts +4 -8
- package/dist/{logger/aicf/dtos → formats/aicf}/aicf.dto.js +12 -17
- package/dist/formats/aicf/aicf.dto.js.map +1 -0
- package/dist/{logger/cloudron/services → formats/cloudron}/cloudron-details-logs.service.d.ts +3 -3
- package/dist/{logger/cloudron/services → formats/cloudron}/cloudron-details-logs.service.js +19 -19
- package/dist/formats/cloudron/cloudron-details-logs.service.js.map +1 -0
- package/dist/formats/cloudron/cloudron-format.strategy.d.ts +15 -0
- package/dist/formats/cloudron/cloudron-format.strategy.js +85 -0
- package/dist/formats/cloudron/cloudron-format.strategy.js.map +1 -0
- package/dist/{logger/cloudron/intercepters/cloudron.interceptor.d.ts → formats/cloudron/cloudron-interceptor.d.ts} +3 -3
- package/dist/{logger/cloudron/intercepters/cloudron.interceptor.js → formats/cloudron/cloudron-interceptor.js} +6 -5
- package/dist/formats/cloudron/cloudron-interceptor.js.map +1 -0
- package/dist/{logger/cloudron/dtos/cauldron-manual.dto.d.ts → formats/cloudron/cloudron-manual.dto.d.ts} +5 -5
- package/dist/{logger/cloudron/dtos/cauldron-manual.dto.js → formats/cloudron/cloudron-manual.dto.js} +67 -59
- package/dist/formats/cloudron/cloudron-manual.dto.js.map +1 -0
- package/dist/formats/cloudron/cloudron-middleware.d.ts +12 -0
- package/dist/formats/cloudron/cloudron-middleware.js +52 -0
- package/dist/formats/cloudron/cloudron-middleware.js.map +1 -0
- package/dist/{logger/cloudron/services → formats/cloudron}/cloudron-summary-logs.service.d.ts +1 -1
- package/dist/{logger/cloudron/services → formats/cloudron}/cloudron-summary-logs.service.js +6 -6
- package/dist/formats/cloudron/cloudron-summary-logs.service.js.map +1 -0
- package/dist/{logger/cloudron/dtos/cauldron.dto.d.ts → formats/cloudron/cloudron.dto.d.ts} +12 -12
- package/dist/{logger/cloudron/dtos/cauldron.dto.js → formats/cloudron/cloudron.dto.js} +26 -25
- package/dist/formats/cloudron/cloudron.dto.js.map +1 -0
- package/dist/formats/format.interface.d.ts +62 -0
- package/dist/formats/format.interface.js +3 -0
- package/dist/formats/format.interface.js.map +1 -0
- package/dist/formats/format.registry.d.ts +6 -0
- package/dist/formats/format.registry.js +16 -0
- package/dist/formats/format.registry.js.map +1 -0
- package/dist/index.d.ts +20 -20
- package/dist/index.js +31 -20
- package/dist/index.js.map +1 -1
- package/dist/logger/axios-logs.interceptor.d.ts +12 -0
- package/dist/logger/axios-logs.interceptor.js +42 -0
- package/dist/logger/axios-logs.interceptor.js.map +1 -0
- package/dist/logger/base-http.middleware.d.ts +33 -0
- package/dist/logger/base-http.middleware.js +103 -0
- package/dist/logger/base-http.middleware.js.map +1 -0
- package/dist/logger/http-logs.middleware.d.ts +17 -0
- package/dist/logger/http-logs.middleware.js +49 -0
- package/dist/logger/http-logs.middleware.js.map +1 -0
- package/dist/logger/{core/guard/logger.guard.js → logger.guard.js} +3 -3
- package/dist/logger/logger.guard.js.map +1 -0
- package/dist/logger/logger.module.js +17 -27
- package/dist/logger/logger.module.js.map +1 -1
- package/dist/logger/logger.service.js +1 -1
- package/dist/logger/logger.service.js.map +1 -1
- package/dist/{logger/core/pipes/masking-logs → masking}/masking-logs.pipe.js +3 -3
- package/dist/masking/masking-logs.pipe.js.map +1 -0
- package/dist/metrics/metrics-manual.service.d.ts +2 -2
- package/dist/metrics/metrics-manual.service.js +3 -3
- package/dist/metrics/metrics-manual.service.js.map +1 -1
- package/dist/metrics/metrics.middleware.d.ts +1 -1
- package/dist/metrics/metrics.middleware.js +4 -4
- package/dist/metrics/metrics.middleware.js.map +1 -1
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +21 -3
- package/.babelrc +0 -20
- package/.env +0 -0
- package/dist/common/async-storage/external-transaction-info.d.ts +0 -11
- package/dist/common/async-storage/external-transaction-info.js +0 -6
- package/dist/common/async-storage/external-transaction-info.js.map +0 -1
- package/dist/common/async-storage/summaryEndpoint-info.d.ts +0 -4
- package/dist/common/async-storage/summaryEndpoint-info.js +0 -10
- package/dist/common/async-storage/summaryEndpoint-info.js.map +0 -1
- package/dist/common/async-storage/tracnsaction-info.js +0 -6
- package/dist/common/async-storage/tracnsaction-info.js.map +0 -1
- package/dist/common/dto/result.dto.js.map +0 -1
- package/dist/common/helper/error.d.ts +0 -4
- package/dist/common/helper/error.js +0 -15
- package/dist/common/helper/error.js.map +0 -1
- package/dist/common/helper/response.js.map +0 -1
- package/dist/common/helper/tools.d.ts +0 -8
- package/dist/common/helper/tools.js +0 -98
- package/dist/common/helper/tools.js.map +0 -1
- package/dist/common/helper/tools.service.js.map +0 -1
- package/dist/logger/aicf/dtos/aicf-manual.dto.js.map +0 -1
- package/dist/logger/aicf/dtos/aicf.dto.js.map +0 -1
- package/dist/logger/aicf/interceptors/aicf-amqp.interceptor.d.ts +0 -7
- package/dist/logger/aicf/interceptors/aicf-amqp.interceptor.js +0 -78
- package/dist/logger/aicf/interceptors/aicf-amqp.interceptor.js.map +0 -1
- package/dist/logger/aicf/interceptors/aicf.interceptor.js.map +0 -1
- package/dist/logger/aicf/middleware/aicf.middleware.d.ts +0 -13
- package/dist/logger/aicf/middleware/aicf.middleware.js +0 -125
- package/dist/logger/aicf/middleware/aicf.middleware.js.map +0 -1
- package/dist/logger/aicf/services/aicf-endpoint.service.js.map +0 -1
- package/dist/logger/cloudron/decorators/cloudron.decorators.d.ts +0 -0
- package/dist/logger/cloudron/decorators/cloudron.decorators.js +0 -1
- package/dist/logger/cloudron/decorators/cloudron.decorators.js.map +0 -1
- package/dist/logger/cloudron/dtos/cauldron-manual.dto.js.map +0 -1
- package/dist/logger/cloudron/dtos/cauldron.dto.js.map +0 -1
- package/dist/logger/cloudron/global/cloudron.global.d.ts +0 -0
- package/dist/logger/cloudron/global/cloudron.global.js +0 -1
- package/dist/logger/cloudron/global/cloudron.global.js.map +0 -1
- package/dist/logger/cloudron/intercepters/cloudron.interceptor.js.map +0 -1
- package/dist/logger/cloudron/middleware/cloudron.middleware.d.ts +0 -15
- package/dist/logger/cloudron/middleware/cloudron.middleware.js +0 -106
- package/dist/logger/cloudron/middleware/cloudron.middleware.js.map +0 -1
- package/dist/logger/cloudron/services/cloudron-details-logs.service.js.map +0 -1
- package/dist/logger/cloudron/services/cloudron-summary-logs.service.js.map +0 -1
- package/dist/logger/core/database/hook-ingress.database.d.ts +0 -8
- package/dist/logger/core/database/hook-ingress.database.js.map +0 -1
- package/dist/logger/core/decorators/customDecorators.js.map +0 -1
- package/dist/logger/core/dtos/core.dto.d.ts +0 -86
- package/dist/logger/core/dtos/core.dto.js.map +0 -1
- package/dist/logger/core/dtos/log-entry-class.d.ts +0 -11
- package/dist/logger/core/dtos/log-entry-class.js +0 -15
- package/dist/logger/core/dtos/log-entry-class.js.map +0 -1
- package/dist/logger/core/enum/enum.d.ts +0 -75
- package/dist/logger/core/enum/enum.js +0 -307
- package/dist/logger/core/enum/enum.js.map +0 -1
- package/dist/logger/core/functions/error-reponse.js.map +0 -1
- package/dist/logger/core/functions/global-function.js.map +0 -1
- package/dist/logger/core/guard/logger.guard.js.map +0 -1
- package/dist/logger/core/interceptors/amqp.interceptor.d.ts +0 -6
- package/dist/logger/core/interceptors/amqp.interceptor.js +0 -46
- package/dist/logger/core/interceptors/amqp.interceptor.js.map +0 -1
- package/dist/logger/core/interceptors/core-logs.interceptor.d.ts +0 -18
- package/dist/logger/core/interceptors/core-logs.interceptor.js +0 -70
- package/dist/logger/core/interceptors/core-logs.interceptor.js.map +0 -1
- package/dist/logger/core/interceptors/http.interceptor.d.ts +0 -5
- package/dist/logger/core/interceptors/http.interceptor.js +0 -30
- package/dist/logger/core/interceptors/http.interceptor.js.map +0 -1
- package/dist/logger/core/interceptors/interceptors.d.ts +0 -3
- package/dist/logger/core/interceptors/interceptors.js.map +0 -1
- package/dist/logger/core/middleware/http-logs-middleware.service.d.ts +0 -19
- package/dist/logger/core/middleware/http-logs-middleware.service.js +0 -61
- package/dist/logger/core/middleware/http-logs-middleware.service.js.map +0 -1
- package/dist/logger/core/module/amqp/amqp.module.d.ts +0 -2
- package/dist/logger/core/module/amqp/amqp.module.js +0 -43
- package/dist/logger/core/module/amqp/amqp.module.js.map +0 -1
- package/dist/logger/core/pipes/index.d.ts +0 -1
- package/dist/logger/core/pipes/index.js.map +0 -1
- package/dist/logger/core/pipes/masking-logs/masking-logs.pipe.js.map +0 -1
- package/dist/logger/core/services/summary-flush.service.d.ts +0 -8
- package/dist/logger/core/services/summary-flush.service.js +0 -31
- package/dist/logger/core/services/summary-flush.service.js.map +0 -1
- package/dist/logger/esb/dtos/logger.esb.dto.d.ts +0 -136
- package/dist/logger/esb/dtos/logger.esb.dto.js +0 -99
- package/dist/logger/esb/dtos/logger.esb.dto.js.map +0 -1
- package/dist/logger/esb/intercepters/esb.interceptor.d.ts +0 -9
- package/dist/logger/esb/intercepters/esb.interceptor.js +0 -36
- package/dist/logger/esb/intercepters/esb.interceptor.js.map +0 -1
- package/dist/logger/esb/middleware/esb.middleware.d.ts +0 -10
- package/dist/logger/esb/middleware/esb.middleware.js +0 -64
- package/dist/logger/esb/middleware/esb.middleware.js.map +0 -1
- package/dist/logger/esb/services/external-logs-esb.service.d.ts +0 -10
- package/dist/logger/esb/services/external-logs-esb.service.js +0 -98
- package/dist/logger/esb/services/external-logs-esb.service.js.map +0 -1
- package/dist/utils/tools.js.map +0 -1
- package/tsconfig.build.json +0 -4
- /package/dist/common/{helper/response.js → response.js} +0 -0
- /package/dist/logger/{core/guard/logger.guard.d.ts → logger.guard.d.ts} +0 -0
- /package/dist/{logger/core/pipes/masking-logs → masking}/masking-logs.pipe.d.ts +0 -0
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.BaseHttpMiddleware = void 0;
|
|
7
|
+
const microtime_1 = __importDefault(require("microtime"));
|
|
8
|
+
const tools_1 = require("../common/tools");
|
|
9
|
+
const context_functions_1 = require("../context/context.functions");
|
|
10
|
+
const aicf_dto_1 = require("../formats/aicf/aicf.dto");
|
|
11
|
+
const app_log_config_service_1 = require("../config/app-log-config.service");
|
|
12
|
+
class BaseHttpMiddleware {
|
|
13
|
+
constructor(logger, loggerDebug, toolsService) {
|
|
14
|
+
this.logger = logger;
|
|
15
|
+
this.loggerDebug = loggerDebug;
|
|
16
|
+
this.toolsService = toolsService;
|
|
17
|
+
this.appLogConfig = app_log_config_service_1.AppLogConfigService.getConfig();
|
|
18
|
+
}
|
|
19
|
+
use(req, res, next) {
|
|
20
|
+
const startTime = microtime_1.default.now();
|
|
21
|
+
const sessionId = startTime.toString();
|
|
22
|
+
const chunks = [];
|
|
23
|
+
const originalWrite = res.write;
|
|
24
|
+
const originalEnd = res.end;
|
|
25
|
+
let buffer = '';
|
|
26
|
+
let endTime;
|
|
27
|
+
req.headers['x-ais-orderref'] ??= (0, tools_1.generateTID)();
|
|
28
|
+
res.write = (...args) => {
|
|
29
|
+
chunks.push(Buffer.from(args[0]));
|
|
30
|
+
return originalWrite.apply(res, args);
|
|
31
|
+
};
|
|
32
|
+
res.end = (...args) => {
|
|
33
|
+
endTime = microtime_1.default.now();
|
|
34
|
+
if (args[0]) {
|
|
35
|
+
chunks.push(Buffer.from(args[0]));
|
|
36
|
+
}
|
|
37
|
+
buffer = Buffer.concat(chunks).toString('utf8');
|
|
38
|
+
this.loggerDebug.debug('buffer: ', buffer);
|
|
39
|
+
return originalEnd.apply(res, args);
|
|
40
|
+
};
|
|
41
|
+
res.on('finish', () => {
|
|
42
|
+
try {
|
|
43
|
+
const transactionReference = (0, context_functions_1.GetTransactionReference)();
|
|
44
|
+
const requestFormat = (0, aicf_dto_1.MapRequestFormat)(req, req.headers.host);
|
|
45
|
+
if (transactionReference.requestObject?.body) {
|
|
46
|
+
requestFormat.payload = transactionReference.requestObject.body;
|
|
47
|
+
}
|
|
48
|
+
const rawResp = transactionReference.responseObject || buffer;
|
|
49
|
+
const respData = typeof rawResp === 'string'
|
|
50
|
+
? this.safeJsonParse(rawResp, rawResp)
|
|
51
|
+
: rawResp;
|
|
52
|
+
const resultFormat = this.resolveResultFormat(respData, res.statusCode);
|
|
53
|
+
if (transactionReference.maskingLogData) {
|
|
54
|
+
requestFormat.payload = (0, tools_1.maskingData)(requestFormat.payload, transactionReference.specificKeyMasking);
|
|
55
|
+
}
|
|
56
|
+
this.onFinish({
|
|
57
|
+
req,
|
|
58
|
+
res,
|
|
59
|
+
startTime,
|
|
60
|
+
endTime,
|
|
61
|
+
sessionId,
|
|
62
|
+
buffer,
|
|
63
|
+
transactionReference,
|
|
64
|
+
requestFormat,
|
|
65
|
+
resultFormat,
|
|
66
|
+
respData,
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
catch (err) {
|
|
70
|
+
this.loggerDebug.debug('Error in http middleware finish handler: ', err);
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
res.on('error', (err) => {
|
|
74
|
+
this.loggerDebug.debug('Error in http middleware: ', err);
|
|
75
|
+
});
|
|
76
|
+
(0, context_functions_1.SetTransactionReference)({
|
|
77
|
+
transactionId: req.headers['x-ais-orderref'],
|
|
78
|
+
sessionId,
|
|
79
|
+
action: aicf_dto_1.ACTION_TYPE.HTTP,
|
|
80
|
+
originSession: req.headers['x-origin-session'],
|
|
81
|
+
serviceStartTime: startTime,
|
|
82
|
+
}, () => this.wrapNext(next));
|
|
83
|
+
}
|
|
84
|
+
resolveResultFormat(respData, statusCode) {
|
|
85
|
+
if (this.appLogConfig.structureResponse) {
|
|
86
|
+
return (0, tools_1.serializedFormatCommonOperationStatus)(respData, this.appLogConfig.structureResponse);
|
|
87
|
+
}
|
|
88
|
+
return this.toolsService.mapResultCodeResponse(respData, statusCode);
|
|
89
|
+
}
|
|
90
|
+
safeJsonParse(raw, fallback) {
|
|
91
|
+
try {
|
|
92
|
+
return raw.length > 0 ? JSON.parse(raw) : fallback;
|
|
93
|
+
}
|
|
94
|
+
catch {
|
|
95
|
+
return fallback;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
wrapNext(next) {
|
|
99
|
+
next();
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
exports.BaseHttpMiddleware = BaseHttpMiddleware;
|
|
103
|
+
//# sourceMappingURL=base-http.middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base-http.middleware.js","sourceRoot":"","sources":["../../src/logger/base-http.middleware.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { NestMiddleware } from '@nestjs/common';
|
|
2
|
+
import { Request, Response, NextFunction } from 'express';
|
|
3
|
+
import { ContextService } from '../common/service/common/context.service';
|
|
4
|
+
import { CustomLoggerService } from './logger.service';
|
|
5
|
+
import { ToolsService } from '../common/service/tools.service';
|
|
6
|
+
import { LoggerDebugLibService } from '../common/service/logger-debug/logger-debug-lib.service';
|
|
7
|
+
import { CloudronSummaryLogsService } from '../formats/cloudron/cloudron-summary-logs.service';
|
|
8
|
+
export declare class HttpLogsMiddleware implements NestMiddleware {
|
|
9
|
+
private readonly logger;
|
|
10
|
+
private readonly contextService;
|
|
11
|
+
private readonly cloudronSummaryService;
|
|
12
|
+
private readonly toolsService;
|
|
13
|
+
private readonly loggerDebug;
|
|
14
|
+
private coreMiddleware;
|
|
15
|
+
constructor(logger: CustomLoggerService, contextService: ContextService, cloudronSummaryService: CloudronSummaryLogsService, toolsService: ToolsService, loggerDebug: LoggerDebugLibService);
|
|
16
|
+
use(req: Request, res: Response, next: NextFunction): void;
|
|
17
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
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;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.HttpLogsMiddleware = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const format_registry_1 = require("../formats/format.registry");
|
|
15
|
+
const context_service_1 = require("../common/service/common/context.service");
|
|
16
|
+
const logger_service_1 = require("./logger.service");
|
|
17
|
+
const tools_service_1 = require("../common/service/tools.service");
|
|
18
|
+
const logger_debug_lib_service_1 = require("../common/service/logger-debug/logger-debug-lib.service");
|
|
19
|
+
const cloudron_summary_logs_service_1 = require("../formats/cloudron/cloudron-summary-logs.service");
|
|
20
|
+
let HttpLogsMiddleware = class HttpLogsMiddleware {
|
|
21
|
+
constructor(logger, contextService, cloudronSummaryService, toolsService, loggerDebug) {
|
|
22
|
+
this.logger = logger;
|
|
23
|
+
this.contextService = contextService;
|
|
24
|
+
this.cloudronSummaryService = cloudronSummaryService;
|
|
25
|
+
this.toolsService = toolsService;
|
|
26
|
+
this.loggerDebug = loggerDebug;
|
|
27
|
+
this.coreMiddleware = format_registry_1.LogFormatRegistry.get().buildMiddleware({
|
|
28
|
+
logger: this.logger,
|
|
29
|
+
toolsService: this.toolsService,
|
|
30
|
+
loggerDebug: this.loggerDebug,
|
|
31
|
+
cloudronSummaryService: this.cloudronSummaryService,
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
use(req, res, next) {
|
|
35
|
+
this.contextService.run(() => {
|
|
36
|
+
this.coreMiddleware.use(req, res, next);
|
|
37
|
+
}, new Map());
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
exports.HttpLogsMiddleware = HttpLogsMiddleware;
|
|
41
|
+
exports.HttpLogsMiddleware = HttpLogsMiddleware = __decorate([
|
|
42
|
+
(0, common_1.Injectable)(),
|
|
43
|
+
__metadata("design:paramtypes", [logger_service_1.CustomLoggerService,
|
|
44
|
+
context_service_1.ContextService,
|
|
45
|
+
cloudron_summary_logs_service_1.CloudronSummaryLogsService,
|
|
46
|
+
tools_service_1.ToolsService,
|
|
47
|
+
logger_debug_lib_service_1.LoggerDebugLibService])
|
|
48
|
+
], HttpLogsMiddleware);
|
|
49
|
+
//# sourceMappingURL=http-logs.middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http-logs.middleware.js","sourceRoot":"","sources":["../../src/logger/http-logs.middleware.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,2CAA4D;AAE5D,gEAA+D;AAC/D,8EAA0E;AAC1E,qDAAuD;AACvD,mEAA+D;AAC/D,sGAAgG;AAChG,qGAA+F;AAGxF,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAG7B,YACmB,MAA2B,EAC3B,cAA8B,EAC9B,sBAAkD,EAClD,YAA0B,EAC1B,WAAkC;QAJlC,WAAM,GAAN,MAAM,CAAqB;QAC3B,mBAAc,GAAd,cAAc,CAAgB;QAC9B,2BAAsB,GAAtB,sBAAsB,CAA4B;QAClD,iBAAY,GAAZ,YAAY,CAAc;QAC1B,gBAAW,GAAX,WAAW,CAAuB;QAEnD,IAAI,CAAC,cAAc,GAAG,mCAAiB,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC;YAC5D,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,sBAAsB,EAAE,IAAI,CAAC,sBAAsB;SACpD,CAAC,CAAC;IACL,CAAC;IAED,GAAG,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB;QACjD,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,EAAE;YAC3B,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QAC1C,CAAC,EAAE,IAAI,GAAG,EAAe,CAAC,CAAC;IAC7B,CAAC;CACF,CAAA;AAvBY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,mBAAU,GAAE;qCAKgB,oCAAmB;QACX,gCAAc;QACN,0DAA0B;QACpC,4BAAY;QACb,gDAAqB;GAR1C,kBAAkB,CAuB9B"}
|
|
@@ -12,7 +12,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
12
12
|
exports.LoggerGuard = void 0;
|
|
13
13
|
const common_1 = require("@nestjs/common");
|
|
14
14
|
const core_1 = require("@nestjs/core");
|
|
15
|
-
const
|
|
15
|
+
const transaction_store_1 = require("../context/transaction.store");
|
|
16
16
|
let LoggerGuard = class LoggerGuard {
|
|
17
17
|
constructor(reflector) {
|
|
18
18
|
this.reflector = reflector;
|
|
@@ -20,14 +20,14 @@ let LoggerGuard = class LoggerGuard {
|
|
|
20
20
|
canActivate(context) {
|
|
21
21
|
const recordName = this.reflector.get('recordName', context.getHandler());
|
|
22
22
|
const maskingLogData = this.reflector.get('maskingLogData', context.getHandler());
|
|
23
|
-
const store =
|
|
23
|
+
const store = transaction_store_1.transactionStore.getStore();
|
|
24
24
|
if (recordName && store) {
|
|
25
25
|
store.recordName = recordName;
|
|
26
26
|
if (maskingLogData) {
|
|
27
27
|
store.maskingLogData = true;
|
|
28
28
|
store.specificKeyMasking = maskingLogData;
|
|
29
29
|
}
|
|
30
|
-
return
|
|
30
|
+
return transaction_store_1.transactionStore.run(store, () => {
|
|
31
31
|
return true;
|
|
32
32
|
});
|
|
33
33
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.guard.js","sourceRoot":"","sources":["../../src/logger/logger.guard.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA2E;AAE3E,uCAAyC;AACzC,oEAAgE;AAGzD,IAAM,WAAW,GAAjB,MAAM,WAAW;IACtB,YAA6B,SAAoB;QAApB,cAAS,GAAT,SAAS,CAAW;IAAG,CAAC;IACrD,WAAW,CACT,OAAyB;QAEzB,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,YAAY,EAAE,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;QAC1E,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CACvC,gBAAgB,EAChB,OAAO,CAAC,UAAU,EAAE,CACrB,CAAC;QAEF,MAAM,KAAK,GAAG,oCAAgB,CAAC,QAAQ,EAAE,CAAC;QAE1C,IAAI,UAAU,IAAI,KAAK,EAAE,CAAC;YACxB,KAAK,CAAC,UAAU,GAAG,UAAU,CAAC;YAC9B,IAAI,cAAc,EAAE,CAAC;gBACnB,KAAK,CAAC,cAAc,GAAG,IAAI,CAAC;gBAC5B,KAAK,CAAC,kBAAkB,GAAG,cAAc,CAAC;YAC5C,CAAC;YACD,OAAO,oCAAgB,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,EAAE;gBACtC,OAAO,IAAI,CAAC;YACd,CAAC,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;CACF,CAAA;AA1BY,kCAAW;sBAAX,WAAW;IADvB,IAAA,mBAAU,GAAE;qCAE6B,gBAAS;GADtC,WAAW,CA0BvB"}
|
|
@@ -8,51 +8,41 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
9
|
exports.LoggerModule = void 0;
|
|
10
10
|
const common_1 = require("@nestjs/common");
|
|
11
|
-
const logger_service_1 = require("./logger.service");
|
|
12
11
|
const async_hooks_1 = require("async_hooks");
|
|
13
|
-
const
|
|
14
|
-
const
|
|
12
|
+
const logger_service_1 = require("./logger.service");
|
|
13
|
+
const http_logs_middleware_1 = require("./http-logs.middleware");
|
|
14
|
+
const axios_logs_interceptor_1 = require("./axios-logs.interceptor");
|
|
15
15
|
const internal_logs_info_module_1 = require("../common/internal-logs-info.module");
|
|
16
|
-
const
|
|
17
|
-
const
|
|
18
|
-
const
|
|
19
|
-
const
|
|
20
|
-
const
|
|
21
|
-
const aicf_endpoint_service_1 = require("./aicf/services/aicf-endpoint.service");
|
|
22
|
-
const aicf_middleware_1 = require("./aicf/middleware/aicf.middleware");
|
|
23
|
-
const http_logs_middleware_service_1 = require("./core/middleware/http-logs-middleware.service");
|
|
16
|
+
const aicf_interceptor_1 = require("../formats/aicf/aicf-interceptor");
|
|
17
|
+
const aicf_endpoint_service_1 = require("../formats/aicf/aicf-endpoint.service");
|
|
18
|
+
const cloudron_interceptor_1 = require("../formats/cloudron/cloudron-interceptor");
|
|
19
|
+
const cloudron_details_logs_service_1 = require("../formats/cloudron/cloudron-details-logs.service");
|
|
20
|
+
const cloudron_summary_logs_service_1 = require("../formats/cloudron/cloudron-summary-logs.service");
|
|
24
21
|
let LoggerModule = class LoggerModule {
|
|
25
22
|
};
|
|
26
23
|
exports.LoggerModule = LoggerModule;
|
|
27
24
|
exports.LoggerModule = LoggerModule = __decorate([
|
|
28
25
|
(0, common_1.Global)(),
|
|
29
26
|
(0, common_1.Module)({
|
|
30
|
-
imports: [
|
|
27
|
+
imports: [internal_logs_info_module_1.InternalLogsInfoModule],
|
|
31
28
|
providers: [
|
|
32
29
|
logger_service_1.CustomLoggerService,
|
|
33
|
-
{
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
},
|
|
37
|
-
cloudron_details_logs_service_1.CloudronDetailsLogsService,
|
|
38
|
-
cloudron_summary_logs_service_1.CloudronSummaryLogsService,
|
|
39
|
-
core_logs_interceptor_1.CoreLogsInterceptor,
|
|
40
|
-
cloudron_interceptor_1.CloudronInterceptor,
|
|
41
|
-
esb_interceptor_1.EsbInterceptor,
|
|
42
|
-
external_logs_esb_service_1.ExternalLogsEsbService,
|
|
43
|
-
cloudron_details_logs_service_1.CloudronDetailsLogsService,
|
|
30
|
+
{ provide: async_hooks_1.AsyncLocalStorage, useValue: new async_hooks_1.AsyncLocalStorage() },
|
|
31
|
+
http_logs_middleware_1.HttpLogsMiddleware,
|
|
32
|
+
axios_logs_interceptor_1.AxiosLogsInterceptor,
|
|
44
33
|
aicf_interceptor_1.AICFInterceptor,
|
|
45
34
|
aicf_endpoint_service_1.AicfEndpointService,
|
|
46
|
-
|
|
47
|
-
|
|
35
|
+
cloudron_interceptor_1.CloudronInterceptor,
|
|
36
|
+
cloudron_details_logs_service_1.CloudronDetailsLogsService,
|
|
37
|
+
cloudron_summary_logs_service_1.CloudronSummaryLogsService,
|
|
48
38
|
],
|
|
49
39
|
exports: [
|
|
50
40
|
logger_service_1.CustomLoggerService,
|
|
51
41
|
async_hooks_1.AsyncLocalStorage,
|
|
52
|
-
|
|
42
|
+
axios_logs_interceptor_1.AxiosLogsInterceptor,
|
|
53
43
|
cloudron_summary_logs_service_1.CloudronSummaryLogsService,
|
|
54
44
|
internal_logs_info_module_1.InternalLogsInfoModule,
|
|
55
|
-
|
|
45
|
+
http_logs_middleware_1.HttpLogsMiddleware,
|
|
56
46
|
],
|
|
57
47
|
})
|
|
58
48
|
], LoggerModule);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger.module.js","sourceRoot":"","sources":["../../src/logger/logger.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAgD;AAChD,qDAAuD;AACvD,
|
|
1
|
+
{"version":3,"file":"logger.module.js","sourceRoot":"","sources":["../../src/logger/logger.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAgD;AAChD,6CAAgD;AAChD,qDAAuD;AACvD,iEAA4D;AAC5D,qEAAgE;AAChE,mFAA6E;AAC7E,uEAAmE;AACnE,iFAA4E;AAC5E,mFAA+E;AAC/E,qGAA+F;AAC/F,qGAA+F;AAyBxF,IAAM,YAAY,GAAlB,MAAM,YAAY;CAAG,CAAA;AAAf,oCAAY;uBAAZ,YAAY;IAvBxB,IAAA,eAAM,GAAE;IACR,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,kDAAsB,CAAC;QACjC,SAAS,EAAE;YACT,oCAAmB;YACnB,EAAE,OAAO,EAAE,+BAAiB,EAAE,QAAQ,EAAE,IAAI,+BAAiB,EAAE,EAAE;YACjE,yCAAkB;YAClB,6CAAoB;YACpB,kCAAe;YACf,2CAAmB;YACnB,0CAAmB;YACnB,0DAA0B;YAC1B,0DAA0B;SAC3B;QACD,OAAO,EAAE;YACP,oCAAmB;YACnB,+BAAiB;YACjB,6CAAoB;YACpB,0DAA0B;YAC1B,kDAAsB;YACtB,yCAAkB;SACnB;KACF,CAAC;GACW,YAAY,CAAG"}
|
|
@@ -62,7 +62,7 @@ let CustomLoggerService = class CustomLoggerService {
|
|
|
62
62
|
],
|
|
63
63
|
});
|
|
64
64
|
switch (config.format) {
|
|
65
|
-
case configurations_1.FORMAT_TYPE.AICF
|
|
65
|
+
case configurations_1.FORMAT_TYPE.AICF:
|
|
66
66
|
this.autoSetLevel = (data, level) => {
|
|
67
67
|
try {
|
|
68
68
|
data.level = level;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger.service.js","sourceRoot":"","sources":["../../src/logger/logger.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAA2D;AAC3D,iDAAmC;AACnC,qCAAiC;AACjC,6EAAuE;AACvE,6DAAuD;AAGhD,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IAM9B;QAJU,iBAAY,GAAiC,CAAC,IAAI,EAAE,EAAE;YAC9D,OAAO,IAAI,CAAC;QACd,CAAC,CAAC;QAGA,MAAM,MAAM,GAAG,4CAAmB,CAAC,SAAS,EAAE,CAAC;QAC/C,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;YACjC,KAAK,EAAE,MAAM,CAAC,QAAQ;YACtB,MAAM,EAAE,gBAAM,CAAC,OAAO,CACpB,gBAAM,CAAC,MAAM,EAAE,EACf,gBAAM,CAAC,QAAQ,EAAE,EACjB,gBAAM,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,yBAAyB,EAAE,CAAC,EACvD,gBAAM,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,CAC3C;YACD,UAAU,EAAE;gBACV,IAAI,OAAO,CAAC,UAAU,CAAC,OAAO,EAAE;aAGjC;SACF,CAAC,CAAC;QAEH,QAAQ,MAAM,CAAC,MAAM,EAAE,CAAC;YACtB,KAAK,4BAAW,CAAC,IAAI
|
|
1
|
+
{"version":3,"file":"logger.service.js","sourceRoot":"","sources":["../../src/logger/logger.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -11,8 +11,8 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.MaskingLogsPipe = void 0;
|
|
13
13
|
const common_1 = require("@nestjs/common");
|
|
14
|
-
const tools_1 = require("
|
|
15
|
-
const
|
|
14
|
+
const tools_1 = require("../common/tools");
|
|
15
|
+
const context_functions_1 = require("../context/context.functions");
|
|
16
16
|
let MaskingLogsPipe = class MaskingLogsPipe extends common_1.ValidationPipe {
|
|
17
17
|
constructor() {
|
|
18
18
|
super({ transform: true });
|
|
@@ -26,7 +26,7 @@ let MaskingLogsPipe = class MaskingLogsPipe extends common_1.ValidationPipe {
|
|
|
26
26
|
maskingData[key] = (0, tools_1.applyMasking)(storedValue, maskingData[key]);
|
|
27
27
|
}
|
|
28
28
|
}
|
|
29
|
-
(0,
|
|
29
|
+
(0, context_functions_1.SetRequestTransactionInfo)({ body: maskingData });
|
|
30
30
|
return value;
|
|
31
31
|
}
|
|
32
32
|
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"masking-logs.pipe.js","sourceRoot":"","sources":["../../src/masking/masking-logs.pipe.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAIwB;AACxB,2CAAkE;AAClE,oEAAyE;AAGlE,IAAM,eAAe,GAArB,MAAM,eAAgB,SAAQ,uBAAc;IACjD;QACE,KAAK,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC7B,CAAC;IACD,SAAS,CAAC,KAAU,EAAE,QAA0B;QAC9C,MAAM,YAAY,GAAG,QAAQ,CAAC,QAAQ,EAAE,SAAS,CAAC;QAClD,MAAM,WAAW,GAAG,EAAE,GAAG,KAAK,EAAE,CAAC;QAEjC,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC;YAE3C,MAAM,WAAW,GAAG,OAAO,CAAC,WAAW,CACrC,yBAAiB,EACjB,YAAY,EACZ,GAAG,CACJ,CAAC;YAEF,IAAI,WAAW,EAAE,CAAC;gBAChB,WAAW,CAAC,GAAG,CAAC,GAAG,IAAA,oBAAY,EAAC,WAAW,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC;YACjE,CAAC;QACH,CAAC;QAED,IAAA,6CAAyB,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC,CAAC;QACjD,OAAO,KAAK,CAAC;IACf,CAAC;CACF,CAAA;AAxBY,0CAAe;0BAAf,eAAe;IAD3B,IAAA,mBAAU,GAAE;;GACA,eAAe,CAwB3B"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { MetricsService } from './metrics.service';
|
|
2
|
-
import { ToolsService } from '../common/
|
|
3
|
-
import { CommonOperationStatus } from '../common/
|
|
2
|
+
import { ToolsService } from '../common/service/tools.service';
|
|
3
|
+
import { CommonOperationStatus } from '../common/result.dto';
|
|
4
4
|
export declare class MetricsManualService {
|
|
5
5
|
private readonly metricsService;
|
|
6
6
|
private readonly toolsService;
|
|
@@ -12,8 +12,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
12
12
|
exports.MetricsManualService = void 0;
|
|
13
13
|
const common_1 = require("@nestjs/common");
|
|
14
14
|
const metrics_service_1 = require("./metrics.service");
|
|
15
|
-
const tools_service_1 = require("../common/
|
|
16
|
-
const
|
|
15
|
+
const tools_service_1 = require("../common/service/tools.service");
|
|
16
|
+
const context_functions_1 = require("../context/context.functions");
|
|
17
17
|
let MetricsManualService = class MetricsManualService {
|
|
18
18
|
constructor(metricsService, toolsService) {
|
|
19
19
|
this.metricsService = metricsService;
|
|
@@ -28,7 +28,7 @@ let MetricsManualService = class MetricsManualService {
|
|
|
28
28
|
}
|
|
29
29
|
}
|
|
30
30
|
finish(method, resultCode) {
|
|
31
|
-
const transactionInfo = (0,
|
|
31
|
+
const transactionInfo = (0, context_functions_1.GetTransactionReference)();
|
|
32
32
|
this.activeRequests--;
|
|
33
33
|
const elapsedTimeSec = (new Date().getTime() -
|
|
34
34
|
Math.floor(transactionInfo.serviceStartTime / 1000)) /
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"metrics-manual.service.js","sourceRoot":"","sources":["../../src/metrics/metrics-manual.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,uDAAmD;AACnD,
|
|
1
|
+
{"version":3,"file":"metrics-manual.service.js","sourceRoot":"","sources":["../../src/metrics/metrics-manual.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,uDAAmD;AACnD,mEAA+D;AAE/D,oEAAuE;AAGhE,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;IAI/B,YACmB,cAA8B,EAC9B,YAA0B;QAD1B,mBAAc,GAAd,cAAc,CAAgB;QAC9B,iBAAY,GAAZ,YAAY,CAAc;QALrC,mBAAc,GAAG,CAAC,CAAC;QACnB,0BAAqB,GAAG,CAAC,CAAC;IAK9B,CAAC;IAEL,SAAS;QAEP,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC;YACrD,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,cAAc,CAAC;QACnD,CAAC;IACH,CAAC;IAED,MAAM,CAAC,MAAc,EAAE,UAAiC;QACtD,MAAM,eAAe,GAAG,IAAA,2CAAuB,GAAE,CAAC;QAClD,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,MAAM,cAAc,GAClB,CAAC,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE;YACnB,IAAI,CAAC,KAAK,CAAC,eAAgB,CAAC,gBAAgB,GAAG,IAAI,CAAC,CAAC;YACvD,IAAI,CAAC;QACP,IAAI,CAAC,cAAc,CAAC,uBAAuB,CACzC,eAAe,CAAC,UAAU,EAC1B,MAAM,EACN,UAAU,CAAC,UAAU,EACrB,cAAc,EACd,IAAI,CAAC,qBAAqB,EAC1B,IAAI,CAAC,cAAc,CACpB,CAAC;IACJ,CAAC;CACF,CAAA;AAjCY,oDAAoB;+BAApB,oBAAoB;IADhC,IAAA,mBAAU,GAAE;qCAMwB,gCAAc;QAChB,4BAAY;GANlC,oBAAoB,CAiChC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { NestMiddleware } from '@nestjs/common';
|
|
2
2
|
import { Request, Response, NextFunction } from 'express';
|
|
3
3
|
import { MetricsService } from './metrics.service';
|
|
4
|
-
import { ToolsService } from '../common/
|
|
4
|
+
import { ToolsService } from '../common/service/tools.service';
|
|
5
5
|
export declare class HTTPMetricsMiddleware implements NestMiddleware {
|
|
6
6
|
private readonly metricsService;
|
|
7
7
|
private readonly toolsService;
|
|
@@ -12,10 +12,10 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
12
12
|
exports.HTTPMetricsMiddleware = void 0;
|
|
13
13
|
const common_1 = require("@nestjs/common");
|
|
14
14
|
const metrics_service_1 = require("./metrics.service");
|
|
15
|
-
const tools_service_1 = require("../common/
|
|
16
|
-
const
|
|
15
|
+
const tools_service_1 = require("../common/service/tools.service");
|
|
16
|
+
const context_functions_1 = require("../context/context.functions");
|
|
17
17
|
const app_log_config_service_1 = require("../config/app-log-config.service");
|
|
18
|
-
const tools_1 = require("../common/
|
|
18
|
+
const tools_1 = require("../common/tools");
|
|
19
19
|
let HTTPMetricsMiddleware = class HTTPMetricsMiddleware {
|
|
20
20
|
constructor(metricsService, toolsService) {
|
|
21
21
|
this.metricsService = metricsService;
|
|
@@ -51,7 +51,7 @@ let HTTPMetricsMiddleware = class HTTPMetricsMiddleware {
|
|
|
51
51
|
res.on('finish', () => {
|
|
52
52
|
this.activeRequests--;
|
|
53
53
|
const elapsedTimeSec = (new Date().getTime() - startTime) / 1000;
|
|
54
|
-
const transactionInfo = (0,
|
|
54
|
+
const transactionInfo = (0, context_functions_1.GetTransactionReference)();
|
|
55
55
|
if (this.appConfig.structureResponse) {
|
|
56
56
|
responseBody = (0, tools_1.serializedFormatCommonOperationStatus)(responseBody, this.appConfig.structureResponse);
|
|
57
57
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"metrics.middleware.js","sourceRoot":"","sources":["../../src/metrics/metrics.middleware.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4D;AAE5D,uDAAmD;AACnD,
|
|
1
|
+
{"version":3,"file":"metrics.middleware.js","sourceRoot":"","sources":["../../src/metrics/metrics.middleware.ts"],"names":[],"mappings":"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"}
|