mirror of
https://github.com/DI0IK/homepage-plus.git
synced 2025-07-08 22:48:46 +00:00
Add Winston for log handling
- write log data to 'homepage.log'
This commit is contained in:
parent
539e0f005a
commit
280bb5fc81
6 changed files with 248 additions and 14 deletions
76
src/utils/logger.js
Normal file
76
src/utils/logger.js
Normal file
|
@ -0,0 +1,76 @@
|
|||
import winston from "winston";
|
||||
|
||||
function messageFormatter(logInfo) {
|
||||
if (logInfo.stack) {
|
||||
return `[${logInfo.timestamp}] ${logInfo.level}: ${logInfo.stack}`;
|
||||
}
|
||||
return `[${logInfo.timestamp}] ${logInfo.level}: ${logInfo.message}`;
|
||||
};
|
||||
|
||||
const consoleFormat = winston.format.combine(
|
||||
winston.format.errors({ stack: true }),
|
||||
winston.format.splat(),
|
||||
winston.format.timestamp(),
|
||||
winston.format.colorize(),
|
||||
winston.format.printf(messageFormatter)
|
||||
);
|
||||
|
||||
const fileFormat = winston.format.combine(
|
||||
winston.format.errors({ stack: true }),
|
||||
winston.format.splat(),
|
||||
winston.format.timestamp(),
|
||||
winston.format.printf(messageFormatter)
|
||||
);
|
||||
|
||||
const logger = winston.createLogger({
|
||||
level: process.env.LOG_LEVEL || 'info',
|
||||
transports: [
|
||||
new winston.transports.Console({
|
||||
format: consoleFormat,
|
||||
handleExceptions: true,
|
||||
handleRejections: true
|
||||
}),
|
||||
|
||||
new winston.transports.File({
|
||||
format: fileFormat,
|
||||
filename: 'homepage.log',
|
||||
handleExceptions: true,
|
||||
handleRejections: true
|
||||
}),
|
||||
]
|
||||
});
|
||||
|
||||
function debug(message, ...args) {
|
||||
logger.debug(message, ...args);
|
||||
}
|
||||
|
||||
function verbose(message, ...args) {
|
||||
logger.verbose(message, ...args);
|
||||
}
|
||||
|
||||
function info(message, ...args) {
|
||||
logger.info(message, ...args);
|
||||
}
|
||||
|
||||
function warn(message, ...args) {
|
||||
logger.warn(message, ...args);
|
||||
}
|
||||
|
||||
function error(message, ...args) {
|
||||
logger.error(message, ...args);
|
||||
}
|
||||
|
||||
function crit(message, ...args) {
|
||||
logger.crit(message, ...args);
|
||||
}
|
||||
|
||||
const thisModule = {
|
||||
debug,
|
||||
verbose,
|
||||
info,
|
||||
warn,
|
||||
error,
|
||||
crit
|
||||
};
|
||||
|
||||
export default thisModule;
|
Loading…
Add table
Add a link
Reference in a new issue