-
Notifications
You must be signed in to change notification settings - Fork 51
Expand file tree
/
Copy pathDBSQLLogger.ts
More file actions
61 lines (53 loc) · 1.87 KB
/
Copy pathDBSQLLogger.ts
File metadata and controls
61 lines (53 loc) · 1.87 KB
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
49
50
51
52
53
54
55
56
57
58
59
60
61
import winston, { Logger } from 'winston';
import IDBSQLLogger, { LoggerOptions, LogLevel } from './contracts/IDBSQLLogger';
export default class DBSQLLogger implements IDBSQLLogger {
logger: Logger;
transports: {
console: winston.transports.ConsoleTransportInstance;
file?: winston.transports.FileTransportInstance;
};
// Subscribers notified on `setLevel(...)` — used by the SEA/kernel backend to
// keep the kernel-side log bridge's verbosity in lock-step with this logger.
private levelListeners: Array<(level: LogLevel) => void> = [];
constructor({ level = LogLevel.info, filepath }: LoggerOptions = {}) {
this.transports = {
console: new winston.transports.Console({ handleExceptions: true, level }),
};
this.logger = winston.createLogger({
transports: [this.transports.console],
});
if (filepath) {
this.transports.file = new winston.transports.File({ filename: filepath, handleExceptions: true, level });
this.logger.add(this.transports.file);
}
}
async log(level: LogLevel, message: string) {
this.logger.log({ level, message });
}
getLevel(): LogLevel {
return (this.transports.console.level as LogLevel) ?? LogLevel.info;
}
onLevelChange(listener: (level: LogLevel) => void): () => void {
this.levelListeners.push(listener);
return () => {
const index = this.levelListeners.indexOf(listener);
if (index >= 0) {
this.levelListeners.splice(index, 1);
}
};
}
setLevel(level: LogLevel) {
this.transports.console.level = level;
if (this.transports.file) {
this.transports.file.level = level;
}
for (const listener of this.levelListeners) {
// A subscriber must never break level setting for the rest.
try {
listener(level);
} catch {
// swallow — level-change notification is advisory
}
}
}
}