mirror of
https://github.com/YuzuZensai/Cloudflare-DDNS-Updater.git
synced 2026-01-31 14:57:12 +00:00
Create Logger.ts
This commit is contained in:
64
src/libs/Logger.ts
Normal file
64
src/libs/Logger.ts
Normal file
@@ -0,0 +1,64 @@
|
||||
import winston from 'winston';
|
||||
|
||||
const levels = {
|
||||
critical: 0,
|
||||
error: 1,
|
||||
alert: 2,
|
||||
warn: 3,
|
||||
info: 4,
|
||||
http: 5,
|
||||
debug: 6,
|
||||
};
|
||||
|
||||
const level = () => {
|
||||
const env = process.env.NODE_ENV || 'development';
|
||||
const isDevelopment = env === 'development';
|
||||
return isDevelopment ? 'debug' : 'warn';
|
||||
};
|
||||
|
||||
const colors = {
|
||||
critical: 'red',
|
||||
error: 'red',
|
||||
alert: 'red',
|
||||
warn: 'yellow',
|
||||
info: 'green',
|
||||
http: 'magenta',
|
||||
debug: 'white',
|
||||
};
|
||||
|
||||
winston.addColors(colors);
|
||||
|
||||
const consoleFormat = winston.format.combine(
|
||||
winston.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss:ms' }),
|
||||
winston.format.colorize({ all: true }),
|
||||
winston.format.printf(
|
||||
(info) => `[${info.timestamp}] [${info.level}] ${info.message}`
|
||||
)
|
||||
);
|
||||
|
||||
const format = winston.format.combine(
|
||||
winston.format.timestamp({
|
||||
format: new Date().toISOString()
|
||||
}),
|
||||
winston.format.json()
|
||||
)
|
||||
|
||||
const transports = [
|
||||
new winston.transports.Console({
|
||||
format: consoleFormat
|
||||
}),
|
||||
new winston.transports.File({
|
||||
filename: 'logs/error.log',
|
||||
level: 'error',
|
||||
}),
|
||||
new winston.transports.File({ filename: 'logs/all.log' }),
|
||||
];
|
||||
|
||||
const Logger = winston.createLogger({
|
||||
level: level(),
|
||||
levels,
|
||||
format,
|
||||
transports,
|
||||
});
|
||||
|
||||
export default Logger;
|
||||
Reference in New Issue
Block a user