File size: 914 Bytes
bb6f8cb 31daf3d b70b749 bb6f8cb b70b749 4adcf97 86afb5e 4adcf97 b70b749 6137a33 b70b749 6137a33 b70b749 4adcf97 b70b749 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 |
import pino from "pino";
import { dev } from "$app/environment";
import { config } from "$lib/server/config";
import { getRequestContext } from "$lib/server/requestContext";
let options: pino.LoggerOptions = {};
if (dev) {
options = {
transport: {
target: "pino-pretty",
options: {
colorize: true,
},
},
};
}
const baseLogger = pino({
...options,
messageKey: "message",
level: config.LOG_LEVEL || "info",
formatters: {
level: (label) => {
return { level: label };
},
},
mixin() {
const ctx = getRequestContext();
if (!ctx) return {};
const result: Record<string, string | number> = {};
if (ctx.requestId) result.request_id = ctx.requestId;
if (ctx.url) result.url = ctx.url;
if (ctx.ip) result.ip = ctx.ip;
if (ctx.user) result.user = ctx.user;
if (ctx.statusCode) result.status_code = ctx.statusCode;
return result;
},
});
export const logger = baseLogger;
|