FEAT: Garantir a criação do diretório de logs e refatorar a configuração do logger

This commit is contained in:
Gabriel Amancio 2025-12-15 15:30:07 -03:00
parent f3f163b85c
commit 22d4324134

View File

@ -1,9 +1,13 @@
const winston = require('winston'); const winston = require('winston');
const path = require('path'); const path = require('path');
require('winston-daily-rotate-file'); require('winston-daily-rotate-file');
const fs = require('fs');
// O diretório de logs é criado pelo script de inicialização, mas garantimos aqui também. // verifica se a pasta de logs existe, se não, cria
const logsDir = path.resolve(process.cwd(), 'logs'); const logsDir = path.join(__dirname, '../../logs');
if (!fs.existsSync(logsDir)) {
fs.mkdirSync(logsDir, { recursive: true });
}
// Configuração do logger com winston // Configuração do logger com winston
const logger = winston.createLogger({ const logger = winston.createLogger({
@ -12,7 +16,7 @@ const logger = winston.createLogger({
winston.format.timestamp({ winston.format.timestamp({
format: 'YYYY-MM-DD HH:mm:ss' format: 'YYYY-MM-DD HH:mm:ss'
}), }),
winston.format.errors({ stack: true }), // Mostra stack trace de erros winston.format.errors({ stack: true }), // Mostra stack trace de erros
winston.format.json() winston.format.json()
), ),
transports: [ transports: [
@ -23,6 +27,9 @@ const logger = winston.createLogger({
zippedArchive: true, zippedArchive: true,
maxSize: '5m', maxSize: '5m',
maxFiles: '10d', maxFiles: '10d',
options: {
flags: 'w' // Usa 'w' para sobrescrever o arquivo no início de cada dia
}
}), }),
// Log de erros // Log de erros
new winston.transports.DailyRotateFile({ new winston.transports.DailyRotateFile({
@ -32,12 +39,16 @@ const logger = winston.createLogger({
zippedArchive: true, zippedArchive: true,
maxSize: '5m', maxSize: '5m',
maxFiles: '10d', maxFiles: '10d',
options: {
flags: 'w' // Usa 'w' para sobrescrever o arquivo no início de cada dia
}
}) })
], ],
}); });
// Log no console em desenvolvimento // Adiciona o log no console para TODOS os ambientes (desenvolvimento e produção).
if (process.env.NODE_ENV !== 'production') { // Isso é essencial para que o `pm2 logs` funcione corretamente.
logger.add(new winston.transports.Console({ logger.add(new winston.transports.Console({
format: winston.format.combine( format: winston.format.combine(
winston.format.colorize(), winston.format.colorize(),
@ -51,9 +62,31 @@ if (process.env.NODE_ENV !== 'production') {
}) })
) )
})); }));
}
module.exports = logger; // Funções utilitárias
const logError = (error, context = '') => {
if (error instanceof Error) {
logger.error(`${context} - ${error.message}`, { stack: error.stack });
} else {
logger.error(`${context} - ${error}`);
}
};
const logInfo = (message, meta = {}) => {
logger.info(message, meta);
};
const logWarning = (message, meta = {}) => {
logger.warn(message, meta);
};
module.exports = {
logger,
logError,
logInfo,
logWarning
};
/* /*
DESCRIÇÃO: DESCRIÇÃO: