mirror of
https://github.com/Litlyx/litlyx
synced 2025-12-10 15:58:38 +01:00
42 lines
1.3 KiB
TypeScript
42 lines
1.3 KiB
TypeScript
import { logger } from "../Logger"
|
|
|
|
|
|
export default defineEventHandler(async (event) => {
|
|
|
|
const ip = getRequestAddress(event);
|
|
const user = getRequestUser(event);
|
|
|
|
let payload: any | undefined;
|
|
|
|
const headers = getHeaders(event);
|
|
|
|
const xHeaders = Object.keys(headers)
|
|
.filter(e => e.startsWith('x-') && !e.startsWith("x-forwarded"))
|
|
.map(e => ({ [e]: headers[e] }));
|
|
|
|
|
|
if (event.method === 'POST' || event.method === 'DELETE') {
|
|
payload = await readBody(event)
|
|
}
|
|
|
|
|
|
event.node.res.on('finish', async () => {
|
|
if (!event.context['performance-start']) return;
|
|
const start = parseInt(event.context['performance-start']);
|
|
if (isNaN(start)) return;
|
|
|
|
const end = Date.now();
|
|
const duration = (end - start);
|
|
|
|
if (!user) {
|
|
logger.debug('Request without user', { path: event.path, method: event.method, ip, duration, xHeaders, payload });
|
|
} else if (!user.logged) {
|
|
logger.debug('Request as guest', { path: event.path, method: event.method, ip, duration, xHeaders, payload });
|
|
} else {
|
|
logger.debug(`(${duration}ms) [${event.method}] ${event.path} { ${user.user.email} }`, { ip, duration, xHeaders, payload });
|
|
}
|
|
|
|
// event.node.res.setHeader('X-Total-Response-Time', `${duration.toFixed(2)} ms`);
|
|
});
|
|
|
|
}) |