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.
Files changed (62) hide show
  1. package/README.md +661 -0
  2. package/dist/core/context/request-context.d.ts +9 -0
  3. package/dist/core/context/request-context.d.ts.map +1 -0
  4. package/dist/core/context/request-context.js +46 -0
  5. package/dist/core/context/request-context.js.map +1 -0
  6. package/dist/core/logger/adapters/adapter.interface.d.ts +5 -0
  7. package/dist/core/logger/adapters/adapter.interface.d.ts.map +1 -0
  8. package/dist/core/logger/adapters/adapter.interface.js +3 -0
  9. package/dist/core/logger/adapters/adapter.interface.js.map +1 -0
  10. package/dist/core/logger/adapters/node.adapter.d.ts +6 -0
  11. package/dist/core/logger/adapters/node.adapter.d.ts.map +1 -0
  12. package/dist/core/logger/adapters/node.adapter.js +12 -0
  13. package/dist/core/logger/adapters/node.adapter.js.map +1 -0
  14. package/dist/core/logger/adapters/pino.adapter.d.ts +18 -0
  15. package/dist/core/logger/adapters/pino.adapter.d.ts.map +1 -0
  16. package/dist/core/logger/adapters/pino.adapter.js +83 -0
  17. package/dist/core/logger/adapters/pino.adapter.js.map +1 -0
  18. package/dist/core/logger/structured-logger.d.ts +25 -0
  19. package/dist/core/logger/structured-logger.d.ts.map +1 -0
  20. package/dist/core/logger/structured-logger.js +47 -0
  21. package/dist/core/logger/structured-logger.js.map +1 -0
  22. package/dist/index.d.ts +8 -0
  23. package/dist/index.d.ts.map +1 -0
  24. package/dist/index.js +17 -0
  25. package/dist/index.js.map +1 -0
  26. package/dist/nest/adapters/nest.adapter.d.ts +16 -0
  27. package/dist/nest/adapters/nest.adapter.d.ts.map +1 -0
  28. package/dist/nest/adapters/nest.adapter.js +58 -0
  29. package/dist/nest/adapters/nest.adapter.js.map +1 -0
  30. package/dist/nest/decorators/request-log.decorator.d.ts +3 -0
  31. package/dist/nest/decorators/request-log.decorator.d.ts.map +1 -0
  32. package/dist/nest/decorators/request-log.decorator.js +41 -0
  33. package/dist/nest/decorators/request-log.decorator.js.map +1 -0
  34. package/dist/nest/decorators/service-log.decorator.d.ts +3 -0
  35. package/dist/nest/decorators/service-log.decorator.d.ts.map +1 -0
  36. package/dist/nest/decorators/service-log.decorator.js +41 -0
  37. package/dist/nest/decorators/service-log.decorator.js.map +1 -0
  38. package/dist/nest/decorators/step-log.decorator.d.ts +3 -0
  39. package/dist/nest/decorators/step-log.decorator.d.ts.map +1 -0
  40. package/dist/nest/decorators/step-log.decorator.js +36 -0
  41. package/dist/nest/decorators/step-log.decorator.js.map +1 -0
  42. package/dist/nest/interceptors/request.interceptor.d.ts +11 -0
  43. package/dist/nest/interceptors/request.interceptor.d.ts.map +1 -0
  44. package/dist/nest/interceptors/request.interceptor.js +64 -0
  45. package/dist/nest/interceptors/request.interceptor.js.map +1 -0
  46. package/dist/nest/module/trace-logger.module.d.ts +8 -0
  47. package/dist/nest/module/trace-logger.module.d.ts.map +1 -0
  48. package/dist/nest/module/trace-logger.module.js +38 -0
  49. package/dist/nest/module/trace-logger.module.js.map +1 -0
  50. package/dist/nest/tokens.d.ts +2 -0
  51. package/dist/nest/tokens.d.ts.map +1 -0
  52. package/dist/nest/tokens.js +5 -0
  53. package/dist/nest/tokens.js.map +1 -0
  54. package/dist/nestjs.d.ts +8 -0
  55. package/dist/nestjs.d.ts.map +1 -0
  56. package/dist/nestjs.js +32 -0
  57. package/dist/nestjs.js.map +1 -0
  58. package/dist/types/options.d.ts +39 -0
  59. package/dist/types/options.d.ts.map +1 -0
  60. package/dist/types/options.js +3 -0
  61. package/dist/types/options.js.map +1 -0
  62. 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,5 @@
1
+ import type { LogLevel } from '../../../types/options.js';
2
+ export interface ILogAdapter {
3
+ log(level: LogLevel, message: string, data: Record<string, unknown>): void;
4
+ }
5
+ //# sourceMappingURL=adapter.interface.d.ts.map
@@ -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,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=adapter.interface.js.map
@@ -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"}
@@ -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,3 @@
1
+ import type { RequestLogOptions } from '../../types/options.js';
2
+ export declare function RequestLog(options?: RequestLogOptions): MethodDecorator;
3
+ //# sourceMappingURL=request-log.decorator.d.ts.map
@@ -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,3 @@
1
+ import type { ServiceLogOptions } from '../../types/options.js';
2
+ export declare function ServiceLog(options?: ServiceLogOptions): MethodDecorator;
3
+ //# sourceMappingURL=service-log.decorator.d.ts.map
@@ -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,3 @@
1
+ import type { StepLogOptions } from '../../types/options.js';
2
+ export declare function StepLog(stepName: string, options?: StepLogOptions): MethodDecorator;
3
+ //# sourceMappingURL=step-log.decorator.d.ts.map
@@ -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