observability-kit 0.1.1
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 +661 -0
- package/dist/core/context/request-context.d.ts +9 -0
- package/dist/core/context/request-context.d.ts.map +1 -0
- package/dist/core/context/request-context.js +46 -0
- package/dist/core/context/request-context.js.map +1 -0
- package/dist/core/logger/adapters/adapter.interface.d.ts +5 -0
- package/dist/core/logger/adapters/adapter.interface.d.ts.map +1 -0
- package/dist/core/logger/adapters/adapter.interface.js +3 -0
- package/dist/core/logger/adapters/adapter.interface.js.map +1 -0
- package/dist/core/logger/adapters/node.adapter.d.ts +6 -0
- package/dist/core/logger/adapters/node.adapter.d.ts.map +1 -0
- package/dist/core/logger/adapters/node.adapter.js +12 -0
- package/dist/core/logger/adapters/node.adapter.js.map +1 -0
- package/dist/core/logger/adapters/pino.adapter.d.ts +18 -0
- package/dist/core/logger/adapters/pino.adapter.d.ts.map +1 -0
- package/dist/core/logger/adapters/pino.adapter.js +83 -0
- package/dist/core/logger/adapters/pino.adapter.js.map +1 -0
- package/dist/core/logger/structured-logger.d.ts +25 -0
- package/dist/core/logger/structured-logger.d.ts.map +1 -0
- package/dist/core/logger/structured-logger.js +47 -0
- package/dist/core/logger/structured-logger.js.map +1 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +17 -0
- package/dist/index.js.map +1 -0
- package/dist/nest/adapters/nest.adapter.d.ts +16 -0
- package/dist/nest/adapters/nest.adapter.d.ts.map +1 -0
- package/dist/nest/adapters/nest.adapter.js +58 -0
- package/dist/nest/adapters/nest.adapter.js.map +1 -0
- package/dist/nest/decorators/request-log.decorator.d.ts +3 -0
- package/dist/nest/decorators/request-log.decorator.d.ts.map +1 -0
- package/dist/nest/decorators/request-log.decorator.js +41 -0
- package/dist/nest/decorators/request-log.decorator.js.map +1 -0
- package/dist/nest/decorators/service-log.decorator.d.ts +3 -0
- package/dist/nest/decorators/service-log.decorator.d.ts.map +1 -0
- package/dist/nest/decorators/service-log.decorator.js +41 -0
- package/dist/nest/decorators/service-log.decorator.js.map +1 -0
- package/dist/nest/decorators/step-log.decorator.d.ts +3 -0
- package/dist/nest/decorators/step-log.decorator.d.ts.map +1 -0
- package/dist/nest/decorators/step-log.decorator.js +36 -0
- package/dist/nest/decorators/step-log.decorator.js.map +1 -0
- package/dist/nest/interceptors/request.interceptor.d.ts +11 -0
- package/dist/nest/interceptors/request.interceptor.d.ts.map +1 -0
- package/dist/nest/interceptors/request.interceptor.js +64 -0
- package/dist/nest/interceptors/request.interceptor.js.map +1 -0
- package/dist/nest/module/trace-logger.module.d.ts +8 -0
- package/dist/nest/module/trace-logger.module.d.ts.map +1 -0
- package/dist/nest/module/trace-logger.module.js +38 -0
- package/dist/nest/module/trace-logger.module.js.map +1 -0
- package/dist/nest/tokens.d.ts +2 -0
- package/dist/nest/tokens.d.ts.map +1 -0
- package/dist/nest/tokens.js +5 -0
- package/dist/nest/tokens.js.map +1 -0
- package/dist/nestjs.d.ts +8 -0
- package/dist/nestjs.d.ts.map +1 -0
- package/dist/nestjs.js +32 -0
- package/dist/nestjs.js.map +1 -0
- package/dist/types/options.d.ts +39 -0
- package/dist/types/options.d.ts.map +1 -0
- package/dist/types/options.js +3 -0
- package/dist/types/options.js.map +1 -0
- package/package.json +123 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-context.js","sourceRoot":"","sources":["../../../src/core/context/request-context.ts"],"names":[],"mappings":";;;AASA,oCAqBC;AAED,wCAEC;AAED,gCAEC;AAED,oCAEC;AAED,0CAQC;AApDD,uDAAqD;AACrD,6CAAyC;AAM5B,QAAA,qBAAqB,GAAG,IAAI,oCAAiB,EAAkB,CAAC;AAE7E,SAAgB,YAAY,CAC1B,OAA4B,EAC5B,QAA0C;IAE1C,MAAM,OAAO,GAAmB;QAC9B,SAAS,EAAE,OAAO,CAAC,SAAS,IAAI,IAAA,wBAAU,GAAE;QAC5C,GAAG,CAAC,OAAO,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACzE,GAAG,CAAC,OAAO,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACnE,GAAG,CAAC,OAAO,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KACvE,CAAC;IAEF,OAAO,IAAI,OAAO,CAAU,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QAC9C,6BAAqB,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,EAAE;YACtC,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,QAAQ,EAAE,CAAC;gBAC1B,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YACtD,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM,CAAC,GAAG,CAAC,CAAC;YACd,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAgB,cAAc,CAAI,OAAuB,EAAE,EAAW;IACpE,OAAO,6BAAqB,CAAC,GAAG,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;AAChD,CAAC;AAED,SAAgB,UAAU;IACxB,OAAO,6BAAqB,CAAC,QAAQ,EAAE,CAAC;AAC1C,CAAC;AAED,SAAgB,YAAY;IAC1B,OAAO,6BAAqB,CAAC,QAAQ,EAAE,EAAE,SAAS,CAAC;AACrD,CAAC;AAED,SAAgB,eAAe,CAC7B,GAAM,EACN,KAAwB;IAExB,MAAM,KAAK,GAAG,6BAAqB,CAAC,QAAQ,EAAE,CAAC;IAC/C,IAAI,KAAK,EAAE,CAAC;QACV,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IACrB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapter.interface.d.ts","sourceRoot":"","sources":["../../../../src/core/logger/adapters/adapter.interface.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AAE1D,MAAM,WAAW,WAAW;IAC1B,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;CAC5E"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapter.interface.js","sourceRoot":"","sources":["../../../../src/core/logger/adapters/adapter.interface.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { LogLevel } from '../../../types/options.js';
|
|
2
|
+
import type { ILogAdapter } from './adapter.interface.js';
|
|
3
|
+
export declare class NodeLogAdapter implements ILogAdapter {
|
|
4
|
+
log(level: LogLevel, message: string, data: Record<string, unknown>): void;
|
|
5
|
+
}
|
|
6
|
+
//# sourceMappingURL=node.adapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.adapter.d.ts","sourceRoot":"","sources":["../../../../src/core/logger/adapters/node.adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAE1D,qBAAa,cAAe,YAAW,WAAW;IAChD,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;CAM3E"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.NodeLogAdapter = void 0;
|
|
4
|
+
class NodeLogAdapter {
|
|
5
|
+
log(level, message, data) {
|
|
6
|
+
const entry = JSON.stringify({ level, message, ...data });
|
|
7
|
+
const stream = level === 'error' || level === 'warn' ? process.stderr : process.stdout;
|
|
8
|
+
stream.write(entry + '\n');
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
exports.NodeLogAdapter = NodeLogAdapter;
|
|
12
|
+
//# sourceMappingURL=node.adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.adapter.js","sourceRoot":"","sources":["../../../../src/core/logger/adapters/node.adapter.ts"],"names":[],"mappings":";;;AAGA,MAAa,cAAc;IACzB,GAAG,CAAC,KAAe,EAAE,OAAe,EAAE,IAA6B;QACjE,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC;QAC1D,MAAM,MAAM,GACV,KAAK,KAAK,OAAO,IAAI,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC;QAC1E,MAAM,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC;IAC7B,CAAC;CACF;AAPD,wCAOC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import pino from 'pino';
|
|
2
|
+
import type { LogLevel } from '../../../types/options.js';
|
|
3
|
+
import type { ILogAdapter } from './adapter.interface.js';
|
|
4
|
+
export interface PinoLogAdapterOptions {
|
|
5
|
+
pino?: pino.LoggerOptions;
|
|
6
|
+
destination?: pino.DestinationStream;
|
|
7
|
+
}
|
|
8
|
+
export interface PrettyOptions {
|
|
9
|
+
level?: LogLevel;
|
|
10
|
+
colorize?: boolean;
|
|
11
|
+
}
|
|
12
|
+
export declare class PinoLogAdapter implements ILogAdapter {
|
|
13
|
+
private readonly logger;
|
|
14
|
+
constructor(opts?: PinoLogAdapterOptions);
|
|
15
|
+
static pretty(opts?: PrettyOptions): ILogAdapter;
|
|
16
|
+
log(level: LogLevel, _message: string, data: Record<string, unknown>): void;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=pino.adapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pino.adapter.d.ts","sourceRoot":"","sources":["../../../../src/core/logger/adapters/pino.adapter.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAE1D,MAAM,WAAW,qBAAqB;IACpC,IAAI,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC;IAC1B,WAAW,CAAC,EAAE,IAAI,CAAC,iBAAiB,CAAC;CACtC;AAED,MAAM,WAAW,aAAa;IAC5B,KAAK,CAAC,EAAE,QAAQ,CAAC;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AA4DD,qBAAa,cAAe,YAAW,WAAW;IAChD,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAc;gBAEzB,IAAI,GAAE,qBAA0B;IAY5C,MAAM,CAAC,MAAM,CAAC,IAAI,GAAE,aAAkB,GAAG,WAAW;IAOpD,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;CAI5E"}
|
|
@@ -0,0 +1,83 @@
|
|
|
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.PinoLogAdapter = void 0;
|
|
7
|
+
const pino_1 = __importDefault(require("pino"));
|
|
8
|
+
const LEVEL_COLORS = {
|
|
9
|
+
debug: '\x1b[36m',
|
|
10
|
+
info: '\x1b[32m',
|
|
11
|
+
warn: '\x1b[33m',
|
|
12
|
+
error: '\x1b[31m',
|
|
13
|
+
};
|
|
14
|
+
const RESET = '\x1b[0m';
|
|
15
|
+
const DIM = '\x1b[2m';
|
|
16
|
+
const BOLD = '\x1b[1m';
|
|
17
|
+
const LEVEL_ORDER = ['debug', 'info', 'warn', 'error'];
|
|
18
|
+
class DirectPrettyAdapter {
|
|
19
|
+
minLevel;
|
|
20
|
+
colorize;
|
|
21
|
+
constructor(minLevel, colorize) {
|
|
22
|
+
this.minLevel = minLevel;
|
|
23
|
+
this.colorize = colorize;
|
|
24
|
+
}
|
|
25
|
+
log(level, _raw, data) {
|
|
26
|
+
if (LEVEL_ORDER.indexOf(level) < LEVEL_ORDER.indexOf(this.minLevel))
|
|
27
|
+
return;
|
|
28
|
+
const { message, timestamp: _ts, requestId, endpoint, method, service, payload } = data;
|
|
29
|
+
const msg = String(message ?? '');
|
|
30
|
+
const time = new Date().toISOString().slice(11, 23);
|
|
31
|
+
const shortId = typeof requestId === 'string' ? requestId.slice(0, 8) : null;
|
|
32
|
+
const parts = [msg];
|
|
33
|
+
if (msg.startsWith('request.')) {
|
|
34
|
+
if (endpoint)
|
|
35
|
+
parts.push(`endpoint=${String(endpoint)}`);
|
|
36
|
+
if (method)
|
|
37
|
+
parts.push(`method=${String(method)}`);
|
|
38
|
+
if (shortId)
|
|
39
|
+
parts.push(`req=${shortId}`);
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
if (service)
|
|
43
|
+
parts.push(`service=${String(service)}`);
|
|
44
|
+
if (shortId)
|
|
45
|
+
parts.push(`req=${shortId}`);
|
|
46
|
+
}
|
|
47
|
+
if (payload !== undefined) {
|
|
48
|
+
parts.push(`payload=${JSON.stringify(payload)}`);
|
|
49
|
+
}
|
|
50
|
+
const lvl = level.toUpperCase().padEnd(5);
|
|
51
|
+
let line;
|
|
52
|
+
if (this.colorize) {
|
|
53
|
+
const c = LEVEL_COLORS[level];
|
|
54
|
+
line = `${DIM}[${time}]${RESET} ${c}${BOLD}${lvl}${RESET}: ${parts.join(' | ')}`;
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
line = `[${time}] ${lvl}: ${parts.join(' | ')}`;
|
|
58
|
+
}
|
|
59
|
+
process.stdout.write(line + '\n\n');
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
class PinoLogAdapter {
|
|
63
|
+
logger;
|
|
64
|
+
constructor(opts = {}) {
|
|
65
|
+
const defaults = {
|
|
66
|
+
timestamp: pino_1.default.stdTimeFunctions.isoTime,
|
|
67
|
+
base: undefined,
|
|
68
|
+
...opts.pino,
|
|
69
|
+
};
|
|
70
|
+
this.logger = opts.destination
|
|
71
|
+
? (0, pino_1.default)(defaults, opts.destination)
|
|
72
|
+
: (0, pino_1.default)(defaults);
|
|
73
|
+
}
|
|
74
|
+
static pretty(opts = {}) {
|
|
75
|
+
return new DirectPrettyAdapter(opts.level ?? 'debug', opts.colorize !== false);
|
|
76
|
+
}
|
|
77
|
+
log(level, _message, data) {
|
|
78
|
+
const { message, timestamp: _ts, ...rest } = data;
|
|
79
|
+
this.logger[level](rest, String(message ?? ''));
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
exports.PinoLogAdapter = PinoLogAdapter;
|
|
83
|
+
//# sourceMappingURL=pino.adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pino.adapter.js","sourceRoot":"","sources":["../../../../src/core/logger/adapters/pino.adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { ILogAdapter } from './adapters/adapter.interface.js';
|
|
2
|
+
export declare class StructuredLogger {
|
|
3
|
+
private adapter;
|
|
4
|
+
constructor(adapter?: ILogAdapter);
|
|
5
|
+
setAdapter(adapter: ILogAdapter): void;
|
|
6
|
+
private buildEntry;
|
|
7
|
+
debug(message: string, options: {
|
|
8
|
+
service: string;
|
|
9
|
+
payload?: Record<string, unknown>;
|
|
10
|
+
}): void;
|
|
11
|
+
info(message: string, options: {
|
|
12
|
+
service: string;
|
|
13
|
+
payload?: Record<string, unknown>;
|
|
14
|
+
}): void;
|
|
15
|
+
warn(message: string, options: {
|
|
16
|
+
service: string;
|
|
17
|
+
payload?: Record<string, unknown>;
|
|
18
|
+
}): void;
|
|
19
|
+
error(message: string, options: {
|
|
20
|
+
service: string;
|
|
21
|
+
payload?: Record<string, unknown>;
|
|
22
|
+
}): void;
|
|
23
|
+
}
|
|
24
|
+
export declare const logger: StructuredLogger;
|
|
25
|
+
//# sourceMappingURL=structured-logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"structured-logger.d.ts","sourceRoot":"","sources":["../../../src/core/logger/structured-logger.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAC;AAGnE,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,OAAO,CAAc;gBAEjB,OAAO,CAAC,EAAE,WAAW;IAIjC,UAAU,CAAC,OAAO,EAAE,WAAW,GAAG,IAAI;IAItC,OAAO,CAAC,UAAU;IAuBlB,KAAK,CACH,OAAO,EAAE,MAAM,EACf,OAAO,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE,GAC9D,IAAI;IAIP,IAAI,CACF,OAAO,EAAE,MAAM,EACf,OAAO,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE,GAC9D,IAAI;IAIP,IAAI,CACF,OAAO,EAAE,MAAM,EACf,OAAO,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE,GAC9D,IAAI;IAIP,KAAK,CACH,OAAO,EAAE,MAAM,EACf,OAAO,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE,GAC9D,IAAI;CAGR;AAED,eAAO,MAAM,MAAM,kBAAyB,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.logger = exports.StructuredLogger = void 0;
|
|
4
|
+
const request_context_js_1 = require("../context/request-context.js");
|
|
5
|
+
const pino_adapter_js_1 = require("./adapters/pino.adapter.js");
|
|
6
|
+
class StructuredLogger {
|
|
7
|
+
adapter;
|
|
8
|
+
constructor(adapter) {
|
|
9
|
+
this.adapter = adapter ?? new pino_adapter_js_1.PinoLogAdapter();
|
|
10
|
+
}
|
|
11
|
+
setAdapter(adapter) {
|
|
12
|
+
this.adapter = adapter;
|
|
13
|
+
}
|
|
14
|
+
buildEntry(message, options) {
|
|
15
|
+
const ctx = (0, request_context_js_1.getContext)();
|
|
16
|
+
const entry = {
|
|
17
|
+
timestamp: new Date().toISOString(),
|
|
18
|
+
service: options.service,
|
|
19
|
+
message,
|
|
20
|
+
};
|
|
21
|
+
if (ctx?.requestId)
|
|
22
|
+
entry['requestId'] = ctx.requestId;
|
|
23
|
+
if (ctx?.endpoint)
|
|
24
|
+
entry['endpoint'] = ctx.endpoint;
|
|
25
|
+
if (ctx?.method)
|
|
26
|
+
entry['method'] = ctx.method;
|
|
27
|
+
if (options.payload && Object.keys(options.payload).length > 0) {
|
|
28
|
+
entry['payload'] = options.payload;
|
|
29
|
+
}
|
|
30
|
+
return entry;
|
|
31
|
+
}
|
|
32
|
+
debug(message, options) {
|
|
33
|
+
this.adapter.log('debug', message, this.buildEntry(message, options));
|
|
34
|
+
}
|
|
35
|
+
info(message, options) {
|
|
36
|
+
this.adapter.log('info', message, this.buildEntry(message, options));
|
|
37
|
+
}
|
|
38
|
+
warn(message, options) {
|
|
39
|
+
this.adapter.log('warn', message, this.buildEntry(message, options));
|
|
40
|
+
}
|
|
41
|
+
error(message, options) {
|
|
42
|
+
this.adapter.log('error', message, this.buildEntry(message, options));
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
exports.StructuredLogger = StructuredLogger;
|
|
46
|
+
exports.logger = new StructuredLogger();
|
|
47
|
+
//# sourceMappingURL=structured-logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"structured-logger.js","sourceRoot":"","sources":["../../../src/core/logger/structured-logger.ts"],"names":[],"mappings":";;;AAAA,sEAA2D;AAE3D,gEAA4D;AAE5D,MAAa,gBAAgB;IACnB,OAAO,CAAc;IAE7B,YAAY,OAAqB;QAC/B,IAAI,CAAC,OAAO,GAAG,OAAO,IAAI,IAAI,gCAAc,EAAE,CAAC;IACjD,CAAC;IAED,UAAU,CAAC,OAAoB;QAC7B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAEO,UAAU,CAChB,OAAe,EACf,OAA+D;QAE/D,MAAM,GAAG,GAAG,IAAA,+BAAU,GAAE,CAAC;QAEzB,MAAM,KAAK,GAA4B;YACrC,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,OAAO;SACR,CAAC;QAEF,IAAI,GAAG,EAAE,SAAS;YAAE,KAAK,CAAC,WAAW,CAAC,GAAG,GAAG,CAAC,SAAS,CAAC;QACvD,IAAI,GAAG,EAAE,QAAQ;YAAE,KAAK,CAAC,UAAU,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC;QACpD,IAAI,GAAG,EAAE,MAAM;YAAE,KAAK,CAAC,QAAQ,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC;QAE9C,IAAI,OAAO,CAAC,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC/D,KAAK,CAAC,SAAS,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC;QACrC,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED,KAAK,CACH,OAAe,EACf,OAA+D;QAE/D,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IACxE,CAAC;IAED,IAAI,CACF,OAAe,EACf,OAA+D;QAE/D,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IACvE,CAAC;IAED,IAAI,CACF,OAAe,EACf,OAA+D;QAE/D,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IACvE,CAAC;IAED,KAAK,CACH,OAAe,EACf,OAA+D;QAE/D,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IACxE,CAAC;CACF;AA7DD,4CA6DC;AAEY,QAAA,MAAM,GAAG,IAAI,gBAAgB,EAAE,CAAC"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { startContext, getContext, getRequestId, setContextField, runWithContext, } from './core/context/request-context.js';
|
|
2
|
+
export { logger, StructuredLogger } from './core/logger/structured-logger.js';
|
|
3
|
+
export type { ILogAdapter } from './core/logger/adapters/adapter.interface.js';
|
|
4
|
+
export { NodeLogAdapter } from './core/logger/adapters/node.adapter.js';
|
|
5
|
+
export { PinoLogAdapter } from './core/logger/adapters/pino.adapter.js';
|
|
6
|
+
export type { PinoLogAdapterOptions, PrettyOptions } from './core/logger/adapters/pino.adapter.js';
|
|
7
|
+
export type { LogLevel, RequestContext, StartContextOptions, TraceLoggerModuleOptions, DefaultLevels, RequestLogOptions, ServiceLogOptions, StepLogOptions, } from './types/options.js';
|
|
8
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,YAAY,EACZ,UAAU,EACV,YAAY,EACZ,eAAe,EACf,cAAc,GACf,MAAM,mCAAmC,CAAC;AAE3C,OAAO,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAC;AAE9E,YAAY,EAAE,WAAW,EAAE,MAAM,6CAA6C,CAAC;AAC/E,OAAO,EAAE,cAAc,EAAE,MAAM,wCAAwC,CAAC;AACxE,OAAO,EAAE,cAAc,EAAE,MAAM,wCAAwC,CAAC;AACxE,YAAY,EAAE,qBAAqB,EAAE,aAAa,EAAE,MAAM,wCAAwC,CAAC;AAEnG,YAAY,EACV,QAAQ,EACR,cAAc,EACd,mBAAmB,EACnB,wBAAwB,EACxB,aAAa,EACb,iBAAiB,EACjB,iBAAiB,EACjB,cAAc,GACf,MAAM,oBAAoB,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PinoLogAdapter = exports.NodeLogAdapter = exports.StructuredLogger = exports.logger = exports.runWithContext = exports.setContextField = exports.getRequestId = exports.getContext = exports.startContext = void 0;
|
|
4
|
+
var request_context_js_1 = require("./core/context/request-context.js");
|
|
5
|
+
Object.defineProperty(exports, "startContext", { enumerable: true, get: function () { return request_context_js_1.startContext; } });
|
|
6
|
+
Object.defineProperty(exports, "getContext", { enumerable: true, get: function () { return request_context_js_1.getContext; } });
|
|
7
|
+
Object.defineProperty(exports, "getRequestId", { enumerable: true, get: function () { return request_context_js_1.getRequestId; } });
|
|
8
|
+
Object.defineProperty(exports, "setContextField", { enumerable: true, get: function () { return request_context_js_1.setContextField; } });
|
|
9
|
+
Object.defineProperty(exports, "runWithContext", { enumerable: true, get: function () { return request_context_js_1.runWithContext; } });
|
|
10
|
+
var structured_logger_js_1 = require("./core/logger/structured-logger.js");
|
|
11
|
+
Object.defineProperty(exports, "logger", { enumerable: true, get: function () { return structured_logger_js_1.logger; } });
|
|
12
|
+
Object.defineProperty(exports, "StructuredLogger", { enumerable: true, get: function () { return structured_logger_js_1.StructuredLogger; } });
|
|
13
|
+
var node_adapter_js_1 = require("./core/logger/adapters/node.adapter.js");
|
|
14
|
+
Object.defineProperty(exports, "NodeLogAdapter", { enumerable: true, get: function () { return node_adapter_js_1.NodeLogAdapter; } });
|
|
15
|
+
var pino_adapter_js_1 = require("./core/logger/adapters/pino.adapter.js");
|
|
16
|
+
Object.defineProperty(exports, "PinoLogAdapter", { enumerable: true, get: function () { return pino_adapter_js_1.PinoLogAdapter; } });
|
|
17
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,wEAM2C;AALzC,kHAAA,YAAY,OAAA;AACZ,gHAAA,UAAU,OAAA;AACV,kHAAA,YAAY,OAAA;AACZ,qHAAA,eAAe,OAAA;AACf,oHAAA,cAAc,OAAA;AAGhB,2EAA8E;AAArE,8GAAA,MAAM,OAAA;AAAE,wHAAA,gBAAgB,OAAA;AAGjC,0EAAwE;AAA/D,iHAAA,cAAc,OAAA;AACvB,0EAAwE;AAA/D,iHAAA,cAAc,OAAA"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { ILogAdapter } from '../../core/logger/adapters/adapter.interface.js';
|
|
2
|
+
import type { LogLevel } from '../../types/options.js';
|
|
3
|
+
interface NestLike {
|
|
4
|
+
log(message: string): void;
|
|
5
|
+
debug(message: string): void;
|
|
6
|
+
warn(message: string): void;
|
|
7
|
+
error(message: string): void;
|
|
8
|
+
}
|
|
9
|
+
export declare class NestLogAdapter implements ILogAdapter {
|
|
10
|
+
private readonly syncLogger;
|
|
11
|
+
constructor(logger?: NestLike);
|
|
12
|
+
log(level: LogLevel, message: string, data: Record<string, unknown>): void;
|
|
13
|
+
private emit;
|
|
14
|
+
}
|
|
15
|
+
export {};
|
|
16
|
+
//# sourceMappingURL=nest.adapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nest.adapter.d.ts","sourceRoot":"","sources":["../../../src/nest/adapters/nest.adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iDAAiD,CAAC;AACnF,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAEvD,UAAU,QAAQ;IAChB,GAAG,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;CAC9B;AAaD,qBAAa,cAAe,YAAW,WAAW;IAChD,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAuB;gBAEtC,MAAM,CAAC,EAAE,QAAQ;IAI7B,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IA4B1E,OAAO,CAAC,IAAI;CAeb"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.NestLogAdapter = void 0;
|
|
4
|
+
const CONTEXT = 'TraceLogger';
|
|
5
|
+
let nestLogger;
|
|
6
|
+
async function getNestLogger() {
|
|
7
|
+
if (nestLogger)
|
|
8
|
+
return nestLogger;
|
|
9
|
+
const { Logger } = await import('@nestjs/common');
|
|
10
|
+
nestLogger = new Logger(CONTEXT);
|
|
11
|
+
return nestLogger;
|
|
12
|
+
}
|
|
13
|
+
class NestLogAdapter {
|
|
14
|
+
syncLogger;
|
|
15
|
+
constructor(logger) {
|
|
16
|
+
this.syncLogger = logger;
|
|
17
|
+
}
|
|
18
|
+
log(level, message, data) {
|
|
19
|
+
const { timestamp: _ts, message: _msg, ...rest } = data;
|
|
20
|
+
const fields = Object.entries(rest)
|
|
21
|
+
.map(([k, v]) => {
|
|
22
|
+
if (v !== null && typeof v === 'object') {
|
|
23
|
+
return `${k}=${JSON.stringify(v)}`;
|
|
24
|
+
}
|
|
25
|
+
return `${k}=${String(v)}`;
|
|
26
|
+
})
|
|
27
|
+
.join(' | ');
|
|
28
|
+
const serialised = fields.length > 0 ? `${message} | ${fields}` : message;
|
|
29
|
+
const target = this.syncLogger;
|
|
30
|
+
if (target) {
|
|
31
|
+
this.emit(target, level, serialised);
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
getNestLogger()
|
|
35
|
+
.then((l) => this.emit(l, level, serialised))
|
|
36
|
+
.catch(() => {
|
|
37
|
+
process.stderr.write(JSON.stringify({ level, message, ...data }) + '\n');
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
emit(target, level, serialised) {
|
|
42
|
+
switch (level) {
|
|
43
|
+
case 'debug':
|
|
44
|
+
target.debug(serialised);
|
|
45
|
+
break;
|
|
46
|
+
case 'warn':
|
|
47
|
+
target.warn(serialised);
|
|
48
|
+
break;
|
|
49
|
+
case 'error':
|
|
50
|
+
target.error(serialised);
|
|
51
|
+
break;
|
|
52
|
+
default:
|
|
53
|
+
target.log(serialised);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
exports.NestLogAdapter = NestLogAdapter;
|
|
58
|
+
//# sourceMappingURL=nest.adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nest.adapter.js","sourceRoot":"","sources":["../../../src/nest/adapters/nest.adapter.ts"],"names":[],"mappings":";;;AAUA,MAAM,OAAO,GAAG,aAAa,CAAC;AAE9B,IAAI,UAAgC,CAAC;AAErC,KAAK,UAAU,aAAa;IAC1B,IAAI,UAAU;QAAE,OAAO,UAAU,CAAC;IAClC,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,MAAM,CAAC,gBAAgB,CAAC,CAAC;IAClD,UAAU,GAAG,IAAI,MAAM,CAAC,OAAO,CAAwB,CAAC;IACxD,OAAO,UAAU,CAAC;AACpB,CAAC;AAED,MAAa,cAAc;IACR,UAAU,CAAuB;IAElD,YAAY,MAAiB;QAC3B,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;IAC3B,CAAC;IAED,GAAG,CAAC,KAAe,EAAE,OAAe,EAAE,IAA6B;QACjE,MAAM,EAAE,SAAS,EAAE,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,IAAI,CAAC;QAExD,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC;aAChC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE;YACd,IAAI,CAAC,KAAK,IAAI,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE,CAAC;gBACxC,OAAO,GAAG,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;YACrC,CAAC;YACD,OAAO,GAAG,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;QAC7B,CAAC,CAAC;aACD,IAAI,CAAC,KAAK,CAAC,CAAC;QAEf,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,MAAM,MAAM,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;QAC1E,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC;QAE/B,IAAI,MAAM,EAAE,CAAC;YACX,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;QACvC,CAAC;aAAM,CAAC;YACN,aAAa,EAAE;iBACZ,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;iBAC5C,KAAK,CAAC,GAAG,EAAE;gBACV,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,CAAC,GAAG,IAAI,CACnD,CAAC;YACJ,CAAC,CAAC,CAAC;QACP,CAAC;IACH,CAAC;IAEO,IAAI,CAAC,MAAgB,EAAE,KAAe,EAAE,UAAkB;QAChE,QAAQ,KAAK,EAAE,CAAC;YACd,KAAK,OAAO;gBACV,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;gBACzB,MAAM;YACR,KAAK,MAAM;gBACT,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBACxB,MAAM;YACR,KAAK,OAAO;gBACV,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;gBACzB,MAAM;YACR;gBACE,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QAC3B,CAAC;IACH,CAAC;CACF;AAlDD,wCAkDC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-log.decorator.d.ts","sourceRoot":"","sources":["../../../src/nest/decorators/request-log.decorator.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAEhE,wBAAgB,UAAU,CAAC,OAAO,GAAE,iBAAsB,GAAG,eAAe,CA+C3E"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RequestLog = RequestLog;
|
|
4
|
+
const structured_logger_js_1 = require("../../core/logger/structured-logger.js");
|
|
5
|
+
function RequestLog(options = {}) {
|
|
6
|
+
return function (target, propertyKey, descriptor) {
|
|
7
|
+
const originalMethod = descriptor.value;
|
|
8
|
+
const service = `${target.constructor.name}.${String(propertyKey)}`;
|
|
9
|
+
descriptor.value = async function (...args) {
|
|
10
|
+
const payload = options.payloadBuilder?.(...args);
|
|
11
|
+
const hasPayload = payload !== undefined && Object.keys(payload).length > 0;
|
|
12
|
+
structured_logger_js_1.logger.info('request.start', {
|
|
13
|
+
service,
|
|
14
|
+
...(hasPayload ? { payload } : {}),
|
|
15
|
+
});
|
|
16
|
+
const startTime = Date.now();
|
|
17
|
+
try {
|
|
18
|
+
const result = await Promise.resolve(originalMethod.apply(this, args));
|
|
19
|
+
const durationMs = Date.now() - startTime;
|
|
20
|
+
structured_logger_js_1.logger.info('request.end', { service, payload: { durationMs } });
|
|
21
|
+
return result;
|
|
22
|
+
}
|
|
23
|
+
catch (error) {
|
|
24
|
+
const durationMs = Date.now() - startTime;
|
|
25
|
+
const err = error;
|
|
26
|
+
structured_logger_js_1.logger.error('request.error', {
|
|
27
|
+
service,
|
|
28
|
+
payload: {
|
|
29
|
+
durationMs,
|
|
30
|
+
errorName: err.name,
|
|
31
|
+
error: err.message,
|
|
32
|
+
...(err.stack ? { stack: err.stack } : {}),
|
|
33
|
+
},
|
|
34
|
+
});
|
|
35
|
+
throw error;
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
return descriptor;
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=request-log.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-log.decorator.js","sourceRoot":"","sources":["../../../src/nest/decorators/request-log.decorator.ts"],"names":[],"mappings":";;AAGA,gCA+CC;AAlDD,iFAAgE;AAGhE,SAAgB,UAAU,CAAC,UAA6B,EAAE;IACxD,OAAO,UACL,MAAc,EACd,WAA4B,EAC5B,UAA8B;QAE9B,MAAM,cAAc,GAAG,UAAU,CAAC,KAAwC,CAAC;QAC3E,MAAM,OAAO,GAAG,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,IAAI,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC;QAEpE,UAAU,CAAC,KAAK,GAAG,KAAK,WAEtB,GAAG,IAAe;YAElB,MAAM,OAAO,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;YAClD,MAAM,UAAU,GACd,OAAO,KAAK,SAAS,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;YAE3D,6BAAM,CAAC,IAAI,CAAC,eAAe,EAAE;gBAC3B,OAAO;gBACP,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;aACnC,CAAC,CAAC;YAEH,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YAE7B,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;gBACvE,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;gBAC1C,6BAAM,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;gBACjE,OAAO,MAAM,CAAC;YAChB,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;gBAC1C,MAAM,GAAG,GAAG,KAAc,CAAC;gBAC3B,6BAAM,CAAC,KAAK,CAAC,eAAe,EAAE;oBAC5B,OAAO;oBACP,OAAO,EAAE;wBACP,UAAU;wBACV,SAAS,EAAE,GAAG,CAAC,IAAI;wBACnB,KAAK,EAAE,GAAG,CAAC,OAAO;wBAClB,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;qBAC3C;iBACF,CAAC,CAAC;gBACH,MAAM,KAAK,CAAC;YACd,CAAC;QACH,CAAC,CAAC;QAEF,OAAO,UAAU,CAAC;IACpB,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-log.decorator.d.ts","sourceRoot":"","sources":["../../../src/nest/decorators/service-log.decorator.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAEhE,wBAAgB,UAAU,CAAC,OAAO,GAAE,iBAAsB,GAAG,eAAe,CA8C3E"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ServiceLog = ServiceLog;
|
|
4
|
+
const structured_logger_js_1 = require("../../core/logger/structured-logger.js");
|
|
5
|
+
function ServiceLog(options = {}) {
|
|
6
|
+
return function (target, propertyKey, descriptor) {
|
|
7
|
+
const originalMethod = descriptor.value;
|
|
8
|
+
const service = `${target.constructor.name}.${String(propertyKey)}`;
|
|
9
|
+
const level = options.level ?? 'info';
|
|
10
|
+
const logExit = options.logExit !== false;
|
|
11
|
+
descriptor.value = async function (...args) {
|
|
12
|
+
const payload = options.payloadBuilder?.(...args);
|
|
13
|
+
const hasPayload = payload !== undefined && Object.keys(payload).length > 0;
|
|
14
|
+
structured_logger_js_1.logger[level]('service.enter', {
|
|
15
|
+
service,
|
|
16
|
+
...(hasPayload ? { payload } : {}),
|
|
17
|
+
});
|
|
18
|
+
try {
|
|
19
|
+
const result = await Promise.resolve(originalMethod.apply(this, args));
|
|
20
|
+
if (logExit) {
|
|
21
|
+
structured_logger_js_1.logger[level]('service.exit', { service });
|
|
22
|
+
}
|
|
23
|
+
return result;
|
|
24
|
+
}
|
|
25
|
+
catch (error) {
|
|
26
|
+
const err = error;
|
|
27
|
+
structured_logger_js_1.logger.error('service.error', {
|
|
28
|
+
service,
|
|
29
|
+
payload: {
|
|
30
|
+
errorName: err.name,
|
|
31
|
+
error: err.message,
|
|
32
|
+
...(err.stack ? { stack: err.stack } : {}),
|
|
33
|
+
},
|
|
34
|
+
});
|
|
35
|
+
throw error;
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
return descriptor;
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=service-log.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-log.decorator.js","sourceRoot":"","sources":["../../../src/nest/decorators/service-log.decorator.ts"],"names":[],"mappings":";;AAGA,gCA8CC;AAjDD,iFAAgE;AAGhE,SAAgB,UAAU,CAAC,UAA6B,EAAE;IACxD,OAAO,UACL,MAAc,EACd,WAA4B,EAC5B,UAA8B;QAE9B,MAAM,cAAc,GAAG,UAAU,CAAC,KAAwC,CAAC;QAC3E,MAAM,OAAO,GAAG,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,IAAI,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC;QACpE,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,MAAM,CAAC;QACtC,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,KAAK,KAAK,CAAC;QAE1C,UAAU,CAAC,KAAK,GAAG,KAAK,WAEtB,GAAG,IAAe;YAElB,MAAM,OAAO,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;YAClD,MAAM,UAAU,GACd,OAAO,KAAK,SAAS,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;YAE3D,6BAAM,CAAC,KAAK,CAAC,CAAC,eAAe,EAAE;gBAC7B,OAAO;gBACP,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;aACnC,CAAC,CAAC;YAEH,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;gBACvE,IAAI,OAAO,EAAE,CAAC;oBACZ,6BAAM,CAAC,KAAK,CAAC,CAAC,cAAc,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;gBAC7C,CAAC;gBACD,OAAO,MAAM,CAAC;YAChB,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,GAAG,GAAG,KAAc,CAAC;gBAC3B,6BAAM,CAAC,KAAK,CAAC,eAAe,EAAE;oBAC5B,OAAO;oBACP,OAAO,EAAE;wBACP,SAAS,EAAE,GAAG,CAAC,IAAI;wBACnB,KAAK,EAAE,GAAG,CAAC,OAAO;wBAClB,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;qBAC3C;iBACF,CAAC,CAAC;gBACH,MAAM,KAAK,CAAC;YACd,CAAC;QACH,CAAC,CAAC;QAEF,OAAO,UAAU,CAAC;IACpB,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"step-log.decorator.d.ts","sourceRoot":"","sources":["../../../src/nest/decorators/step-log.decorator.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAE7D,wBAAgB,OAAO,CACrB,QAAQ,EAAE,MAAM,EAChB,OAAO,GAAE,cAAmB,GAC3B,eAAe,CAyCjB"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StepLog = StepLog;
|
|
4
|
+
const structured_logger_js_1 = require("../../core/logger/structured-logger.js");
|
|
5
|
+
function StepLog(stepName, options = {}) {
|
|
6
|
+
return function (target, propertyKey, descriptor) {
|
|
7
|
+
const originalMethod = descriptor.value;
|
|
8
|
+
const service = `${target.constructor.name}.${String(propertyKey)}`;
|
|
9
|
+
const level = options.level ?? 'debug';
|
|
10
|
+
descriptor.value = async function (...args) {
|
|
11
|
+
const payload = options.payloadBuilder?.(...args);
|
|
12
|
+
const hasPayload = payload !== undefined && Object.keys(payload).length > 0;
|
|
13
|
+
structured_logger_js_1.logger[level](`step.${stepName}`, {
|
|
14
|
+
service,
|
|
15
|
+
...(hasPayload ? { payload } : {}),
|
|
16
|
+
});
|
|
17
|
+
try {
|
|
18
|
+
return await Promise.resolve(originalMethod.apply(this, args));
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
const err = error;
|
|
22
|
+
structured_logger_js_1.logger.error(`step.${stepName}.error`, {
|
|
23
|
+
service,
|
|
24
|
+
payload: {
|
|
25
|
+
errorName: err.name,
|
|
26
|
+
error: err.message,
|
|
27
|
+
...(err.stack ? { stack: err.stack } : {}),
|
|
28
|
+
},
|
|
29
|
+
});
|
|
30
|
+
throw error;
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
return descriptor;
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=step-log.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"step-log.decorator.js","sourceRoot":"","sources":["../../../src/nest/decorators/step-log.decorator.ts"],"names":[],"mappings":";;AAGA,0BA4CC;AA/CD,iFAAgE;AAGhE,SAAgB,OAAO,CACrB,QAAgB,EAChB,UAA0B,EAAE;IAE5B,OAAO,UACL,MAAc,EACd,WAA4B,EAC5B,UAA8B;QAE9B,MAAM,cAAc,GAAG,UAAU,CAAC,KAAwC,CAAC;QAC3E,MAAM,OAAO,GAAG,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,IAAI,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC;QACpE,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC;QAEvC,UAAU,CAAC,KAAK,GAAG,KAAK,WAEtB,GAAG,IAAe;YAElB,MAAM,OAAO,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;YAClD,MAAM,UAAU,GACd,OAAO,KAAK,SAAS,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;YAE3D,6BAAM,CAAC,KAAK,CAAC,CAAC,QAAQ,QAAQ,EAAE,EAAE;gBAChC,OAAO;gBACP,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;aACnC,CAAC,CAAC;YAEH,IAAI,CAAC;gBACH,OAAO,MAAM,OAAO,CAAC,OAAO,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;YACjE,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,GAAG,GAAG,KAAc,CAAC;gBAC3B,6BAAM,CAAC,KAAK,CAAC,QAAQ,QAAQ,QAAQ,EAAE;oBACrC,OAAO;oBACP,OAAO,EAAE;wBACP,SAAS,EAAE,GAAG,CAAC,IAAI;wBACnB,KAAK,EAAE,GAAG,CAAC,OAAO;wBAClB,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;qBAC3C;iBACF,CAAC,CAAC;gBACH,MAAM,KAAK,CAAC;YACd,CAAC;QACH,CAAC,CAAC;QAEF,OAAO,UAAU,CAAC;IACpB,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { CallHandler, ExecutionContext, NestInterceptor } from '@nestjs/common';
|
|
2
|
+
import { Observable } from 'rxjs';
|
|
3
|
+
import type { TraceLoggerModuleOptions } from '../../types/options.js';
|
|
4
|
+
export declare class TraceInterceptor implements NestInterceptor {
|
|
5
|
+
private readonly headerName;
|
|
6
|
+
private readonly enableResponseHeader;
|
|
7
|
+
constructor(options?: TraceLoggerModuleOptions);
|
|
8
|
+
intercept(executionContext: ExecutionContext, next: CallHandler): Observable<unknown>;
|
|
9
|
+
private getHeader;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=request.interceptor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request.interceptor.d.ts","sourceRoot":"","sources":["../../../src/nest/interceptors/request.interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,gBAAgB,EAEhB,eAAe,EAGhB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAIlC,OAAO,KAAK,EAEV,wBAAwB,EACzB,MAAM,wBAAwB,CAAC;AAGhC,qBACa,gBAAiB,YAAW,eAAe;IACtD,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAU;gBAK7C,OAAO,CAAC,EAAE,wBAAwB;IAMpC,SAAS,CACP,gBAAgB,EAAE,gBAAgB,EAClC,IAAI,EAAE,WAAW,GAChB,UAAU,CAAC,OAAO,CAAC;IAgCtB,OAAO,CAAC,SAAS;CAGlB"}
|
|
@@ -0,0 +1,64 @@
|
|
|
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
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.TraceInterceptor = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const rxjs_1 = require("rxjs");
|
|
18
|
+
const node_crypto_1 = require("node:crypto");
|
|
19
|
+
const request_context_js_1 = require("../../core/context/request-context.js");
|
|
20
|
+
const tokens_js_1 = require("../tokens.js");
|
|
21
|
+
let TraceInterceptor = class TraceInterceptor {
|
|
22
|
+
headerName;
|
|
23
|
+
enableResponseHeader;
|
|
24
|
+
constructor(options) {
|
|
25
|
+
this.headerName = options?.requestIdHeaderName ?? 'x-request-id';
|
|
26
|
+
this.enableResponseHeader = options?.enableResponseHeader ?? false;
|
|
27
|
+
}
|
|
28
|
+
intercept(executionContext, next) {
|
|
29
|
+
const kind = executionContext.getType();
|
|
30
|
+
if (kind !== 'http') {
|
|
31
|
+
return next.handle();
|
|
32
|
+
}
|
|
33
|
+
const req = executionContext.switchToHttp().getRequest();
|
|
34
|
+
const res = executionContext.switchToHttp().getResponse();
|
|
35
|
+
const headerValue = this.getHeader(req, this.headerName);
|
|
36
|
+
const requestId = typeof headerValue === 'string' && headerValue.length > 0
|
|
37
|
+
? headerValue
|
|
38
|
+
: (0, node_crypto_1.randomUUID)();
|
|
39
|
+
const context = {
|
|
40
|
+
requestId,
|
|
41
|
+
endpoint: req.path,
|
|
42
|
+
method: req.method,
|
|
43
|
+
};
|
|
44
|
+
if (this.enableResponseHeader) {
|
|
45
|
+
res.setHeader(this.headerName, requestId);
|
|
46
|
+
}
|
|
47
|
+
return new rxjs_1.Observable((subscriber) => {
|
|
48
|
+
(0, request_context_js_1.runWithContext)(context, () => {
|
|
49
|
+
next.handle().subscribe(subscriber);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
getHeader(req, name) {
|
|
54
|
+
return req.headers[name.toLowerCase()];
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
exports.TraceInterceptor = TraceInterceptor;
|
|
58
|
+
exports.TraceInterceptor = TraceInterceptor = __decorate([
|
|
59
|
+
(0, common_1.Injectable)(),
|
|
60
|
+
__param(0, (0, common_1.Optional)()),
|
|
61
|
+
__param(0, (0, common_1.Inject)(tokens_js_1.TRACE_LOGGER_OPTIONS)),
|
|
62
|
+
__metadata("design:paramtypes", [Object])
|
|
63
|
+
], TraceInterceptor);
|
|
64
|
+
//# sourceMappingURL=request.interceptor.js.map
|