-
Notifications
You must be signed in to change notification settings - Fork 12k
/
Copy pathlevel.ts
48 lines (42 loc) · 1.69 KB
/
level.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
import { JsonObject } from '../json/utils';
import { LogLevel, Logger } from './logger';
export class LevelTransformLogger extends Logger {
constructor(
public override readonly name: string,
public override readonly parent: Logger | null = null,
public readonly levelTransform: (level: LogLevel) => LogLevel,
) {
super(name, parent);
}
override log(level: LogLevel, message: string, metadata: JsonObject = {}): void {
return super.log(this.levelTransform(level), message, metadata);
}
override createChild(name: string): Logger {
return new LevelTransformLogger(name, this, this.levelTransform);
}
}
export class LevelCapLogger extends LevelTransformLogger {
static levelMap: { [cap: string]: { [level: string]: string } } = {
debug: { debug: 'debug', info: 'debug', warn: 'debug', error: 'debug', fatal: 'debug' },
info: { debug: 'debug', info: 'info', warn: 'info', error: 'info', fatal: 'info' },
warn: { debug: 'debug', info: 'info', warn: 'warn', error: 'warn', fatal: 'warn' },
error: { debug: 'debug', info: 'info', warn: 'warn', error: 'error', fatal: 'error' },
fatal: { debug: 'debug', info: 'info', warn: 'warn', error: 'error', fatal: 'fatal' },
};
constructor(
public override readonly name: string,
public override readonly parent: Logger | null = null,
public readonly levelCap: LogLevel,
) {
super(name, parent, (level: LogLevel) => {
return (LevelCapLogger.levelMap[levelCap][level] || level) as LogLevel;
});
}
}