* feat: change log level at runtime * chore: open api * chore: prefer env over runtime * chore: remove default env value
22 lines
711 B
TypeScript
22 lines
711 B
TypeScript
import { ConsoleLogger } from '@nestjs/common';
|
|
import { isLogLevelEnabled } from '@nestjs/common/services/utils/is-log-level-enabled.util';
|
|
import { LogLevel } from './entities';
|
|
|
|
const LOG_LEVELS = [LogLevel.VERBOSE, LogLevel.DEBUG, LogLevel.LOG, LogLevel.WARN, LogLevel.ERROR, LogLevel.FATAL];
|
|
|
|
export class ImmichLogger extends ConsoleLogger {
|
|
private static logLevels: LogLevel[] = [];
|
|
|
|
constructor(context: string) {
|
|
super(context);
|
|
}
|
|
|
|
isLevelEnabled(level: LogLevel) {
|
|
return isLogLevelEnabled(level, ImmichLogger.logLevels);
|
|
}
|
|
|
|
static setLogLevel(level: LogLevel | false): void {
|
|
ImmichLogger.logLevels = level === false ? [] : LOG_LEVELS.slice(LOG_LEVELS.indexOf(level));
|
|
}
|
|
}
|