2024-05-29 02:59:49 +02:00
|
|
|
import { dualLogger } from "@/loggers";
|
2024-05-06 10:19:42 +02:00
|
|
|
import type { SocketAddress } from "bun";
|
|
|
|
|
import { createMiddleware } from "hono/factory";
|
2024-05-29 02:59:49 +02:00
|
|
|
import { config } from "~/packages/config-manager";
|
2024-05-06 10:19:42 +02:00
|
|
|
|
|
|
|
|
export const logger = createMiddleware(async (context, next) => {
|
2024-06-13 04:26:43 +02:00
|
|
|
const requestIp = context.env?.ip as SocketAddress | undefined | null;
|
2024-05-06 10:19:42 +02:00
|
|
|
|
|
|
|
|
if (config.logging.log_requests) {
|
|
|
|
|
await dualLogger.logRequest(
|
|
|
|
|
context.req.raw,
|
2024-06-13 04:26:43 +02:00
|
|
|
config.logging.log_ip ? requestIp?.address : undefined,
|
2024-05-06 10:19:42 +02:00
|
|
|
config.logging.log_requests_verbose,
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
await next();
|
|
|
|
|
});
|