NestJS - 避免在记录器注入的构造函数中使用 setContext()

Prz*_*Wit 1 javascript dependency-injection node.js typescript nestjs

在 NestJS 中我有自定义记录器:

import { Injectable, Logger, Scope } from '@nestjs/common';

@Injectable({ scope: Scope.TRANSIENT })
export class LoggerService extends Logger {
  log(message: any) {
    super.log(message);
  }

  error(message: any) {
    super.log(message);
  }

  warn(message: any) {
    super.log(message);
  }

  debug(message: any) {
    super.log(message);
  }

  verbose(message: any) {
    super.log(message);
  }

  setContext(context: string) {
    super.context = context;
  }
}
Run Code Online (Sandbox Code Playgroud)

它在全球注册:

import { Global, Module } from '@nestjs/common';
import { LoggerService } from './logger.service';

@Global()
@Module({
  providers: [LoggerService],
  exports: [LoggerService],
})
export class LoggerModule {}
Run Code Online (Sandbox Code Playgroud)

有没有办法以某种方式在服务构造函数中传递注入上下文,并避免在每个服务中执行 logger.setContext(context) - 而只是在LoggerService构造函数中设置它?

现在的用法示例:

constructor(private logger: LoggerService) {
    this.logger.setContext(ClassName.name);
}
Run Code Online (Sandbox Code Playgroud)

预期用途:

constructor(private logger: LoggerService) {}
Run Code Online (Sandbox Code Playgroud)

Mic*_*evi 5

当你这样做时private logger: LoggerService,就没有机会拨打这个.setContext(Service.name)电话了。

你可以做的是这样的:
@Logger(Service.name) private logger: LoggerService

如何?阅读本文:高级 NestJS:动态提供程序