From 637968552d8b9371ea4f9eb63548d021ff418fb3 Mon Sep 17 00:00:00 2001 From: ajdj100 Date: Wed, 17 Dec 2025 09:35:12 -0500 Subject: [PATCH] Built custom log format --- api/package-lock.json | 13 +++++++++++++ api/package.json | 1 + api/src/index.ts | 22 ++++++++++++++++++++-- 3 files changed, 34 insertions(+), 2 deletions(-) diff --git a/api/package-lock.json b/api/package-lock.json index 3e1f4c1..1b35021 100644 --- a/api/package-lock.json +++ b/api/package-lock.json @@ -10,6 +10,7 @@ "license": "ISC", "dependencies": { "@sentry/node": "^10.27.0", + "chalk": "^5.6.2", "connect-sqlite3": "^0.9.16", "cors": "^2.8.5", "dotenv": "^17.2.1", @@ -1314,6 +1315,18 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/chalk": { + "version": "5.6.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.6.2.tgz", + "integrity": "sha512-7NzBL0rN6fMUW+f7A6Io4h40qQlG+xGmtMxfbnH/K7TAtt8JQWVQK+6g0UXKMeVJoyV5EkkNsErQ8pVD3bLHbA==", + "license": "MIT", + "engines": { + "node": "^12.17.0 || ^14.13 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, "node_modules/chokidar": { "version": "3.6.0", "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", diff --git a/api/package.json b/api/package.json index 9d686bd..261b26a 100644 --- a/api/package.json +++ b/api/package.json @@ -13,6 +13,7 @@ }, "dependencies": { "@sentry/node": "^10.27.0", + "chalk": "^5.6.2", "connect-sqlite3": "^0.9.16", "cors": "^2.8.5", "dotenv": "^17.2.1", diff --git a/api/src/index.ts b/api/src/index.ts index 80d29db..c7e900d 100644 --- a/api/src/index.ts +++ b/api/src/index.ts @@ -5,8 +5,26 @@ import express = require('express'); import cors = require('cors'); import morgan = require('morgan'); const app = express() -app.use(morgan('dev', { - skip: (req) => { +import chalk from 'chalk'; +app.use(morgan((tokens: morgan.TokenIndexer, req: express.Request, res: express.Response) => { + const status = Number(tokens.status(req, res)); + + // Colorize status code + const statusColor = status >= 500 ? chalk.red + : status >= 400 ? chalk.yellow + : status >= 300 ? chalk.cyan + : chalk.green; + + return [ + chalk.gray(`[${new Date().toISOString()}]`), + chalk.blue.bold(tokens.method(req, res)), + tokens.url(req, res), + statusColor(status), + chalk.magenta(tokens['response-time'](req, res) + ' ms'), + chalk.yellow(`- User: ${req.user?.name ? `${req.user.name} (${req.user.id})` : 'Unauthenticated'}`), + ].join(' '); +}, { + skip: (req: express.Request) => { return req.originalUrl === '/members/me'; } }))