[{"data":1,"prerenderedAt":2824},["ShallowReactive",2],{"navigation_docs":3,"-reference-configuration":444,"-reference-configuration-surround":2819},[4,30,80,245,358,413],{"title":5,"path":6,"stem":7,"children":8,"page":29},"Start","\u002Fstart","1.start",[9,14,19,24],{"title":10,"path":11,"stem":12,"icon":13},"Introduction","\u002Fstart\u002Fintroduction","1.start\u002F1.introduction","i-lucide-info",{"title":15,"path":16,"stem":17,"icon":18},"Why start with evlog","\u002Fstart\u002Fwhy-evlog","1.start\u002F2.why-evlog","i-lucide-rocket",{"title":20,"path":21,"stem":22,"icon":23},"Installation","\u002Fstart\u002Finstallation","1.start\u002F3.installation","i-lucide-download",{"title":25,"path":26,"stem":27,"icon":28},"Quick Start","\u002Fstart\u002Fquick-start","1.start\u002F4.quick-start","i-lucide-zap",false,{"title":31,"path":32,"stem":33,"children":34,"page":29},"Learn","\u002Flearn","2.learn",[35,40,45,50,55,60,65,70,75],{"title":36,"path":37,"stem":38,"icon":39},"Overview","\u002Flearn\u002Foverview","2.learn\u002F0.overview","i-lucide-list",{"title":41,"path":42,"stem":43,"icon":44},"Simple Logging","\u002Flearn\u002Fsimple-logging","2.learn\u002F1.simple-logging","i-lucide-terminal",{"title":46,"path":47,"stem":48,"icon":49},"Wide Events","\u002Flearn\u002Fwide-events","2.learn\u002F2.wide-events","i-lucide-layers",{"title":51,"path":52,"stem":53,"icon":54},"Structured Errors","\u002Flearn\u002Fstructured-errors","2.learn\u002F3.structured-errors","i-lucide-shield-alert",{"title":56,"path":57,"stem":58,"icon":59},"Lifecycle","\u002Flearn\u002Flifecycle","2.learn\u002F4.lifecycle","i-lucide-arrow-right-left",{"title":61,"path":62,"stem":63,"icon":64},"Sampling","\u002Flearn\u002Fsampling","2.learn\u002F5.sampling","i-lucide-filter",{"title":66,"path":67,"stem":68,"icon":69},"Auto-Redaction","\u002Flearn\u002Fredaction","2.learn\u002F6.redaction","i-lucide-eye-off",{"title":71,"path":72,"stem":73,"icon":74},"Typed Fields","\u002Flearn\u002Ftyped-fields","2.learn\u002F7.typed-fields","i-simple-icons-typescript",{"title":76,"path":77,"stem":78,"icon":79},"Catalogs","\u002Flearn\u002Fcatalogs","2.learn\u002F8.catalogs","i-lucide-book-open",{"title":81,"path":82,"stem":83,"children":84,"page":29},"Integrate","\u002Fintegrate","3.integrate",[85,89,157],{"title":36,"path":86,"stem":87,"icon":88},"\u002Fintegrate\u002Foverview","3.integrate\u002F0.overview","i-lucide-plug",{"title":90,"path":91,"stem":92,"children":93,"page":29},"Adapters","\u002Fintegrate\u002Fadapters","3.integrate\u002Fadapters",[94,97,137],{"title":36,"path":95,"stem":96,"icon":39},"\u002Fintegrate\u002Fadapters\u002Foverview","3.integrate\u002Fadapters\u002F01.overview",{"title":98,"path":99,"stem":100,"children":101,"page":29},"Cloud","\u002Fintegrate\u002Fadapters\u002Fcloud","3.integrate\u002Fadapters\u002Fcloud",[102,107,112,117,122,127,132],{"title":103,"path":104,"stem":105,"icon":106},"Axiom","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Faxiom","3.integrate\u002Fadapters\u002Fcloud\u002F01.axiom","i-custom-axiom",{"title":108,"path":109,"stem":110,"icon":111},"OTLP","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fotlp","3.integrate\u002Fadapters\u002Fcloud\u002F02.otlp","i-simple-icons-opentelemetry",{"title":113,"path":114,"stem":115,"icon":116},"PostHog","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fposthog","3.integrate\u002Fadapters\u002Fcloud\u002F03.posthog","i-simple-icons-posthog",{"title":118,"path":119,"stem":120,"icon":121},"Sentry","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fsentry","3.integrate\u002Fadapters\u002Fcloud\u002F04.sentry","i-simple-icons-sentry",{"title":123,"path":124,"stem":125,"icon":126},"Better Stack","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fbetter-stack","3.integrate\u002Fadapters\u002Fcloud\u002F05.better-stack","i-simple-icons-betterstack",{"title":128,"path":129,"stem":130,"icon":131},"Datadog","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fdatadog","3.integrate\u002Fadapters\u002Fcloud\u002F06.datadog","i-simple-icons-datadog",{"title":133,"path":134,"stem":135,"icon":136},"HyperDX","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fhyperdx","3.integrate\u002Fadapters\u002Fcloud\u002F07.hyperdx","i-custom-hyperdx",{"title":138,"path":139,"stem":140,"children":141,"page":29},"Self-Hosted","\u002Fintegrate\u002Fadapters\u002Fself-hosted","3.integrate\u002Fadapters\u002Fself-hosted",[142,147,152],{"title":143,"path":144,"stem":145,"icon":146},"File System","\u002Fintegrate\u002Fadapters\u002Fself-hosted\u002Ffs","3.integrate\u002Fadapters\u002Fself-hosted\u002F01.fs","i-lucide-hard-drive",{"title":148,"path":149,"stem":150,"icon":151},"NuxtHub","\u002Fintegrate\u002Fadapters\u002Fself-hosted\u002Fnuxthub","3.integrate\u002Fadapters\u002Fself-hosted\u002F02.nuxthub","i-simple-icons-nuxt",{"title":153,"path":154,"stem":155,"icon":156},"Memory","\u002Fintegrate\u002Fadapters\u002Fself-hosted\u002Fmemory","3.integrate\u002Fadapters\u002Fself-hosted\u002F03.memory","i-lucide-cpu",{"title":158,"path":159,"stem":160,"children":161,"page":29},"Frameworks","\u002Fintegrate\u002Fframeworks","3.integrate\u002Fframeworks",[162,166,171,176,181,186,191,196,201,206,211,216,221,226,230,235,240],{"title":36,"path":163,"stem":164,"icon":165},"\u002Fintegrate\u002Fframeworks\u002Foverview","3.integrate\u002Fframeworks\u002F00.overview","i-lucide-layout-grid",{"title":167,"path":168,"stem":169,"icon":170},"Nuxt","\u002Fintegrate\u002Fframeworks\u002Fnuxt","3.integrate\u002Fframeworks\u002F01.nuxt","i-simple-icons-nuxtdotjs",{"title":172,"path":173,"stem":174,"icon":175},"Next.js","\u002Fintegrate\u002Fframeworks\u002Fnextjs","3.integrate\u002Fframeworks\u002F02.nextjs","i-simple-icons-nextdotjs",{"title":177,"path":178,"stem":179,"icon":180},"SvelteKit","\u002Fintegrate\u002Fframeworks\u002Fsveltekit","3.integrate\u002Fframeworks\u002F03.sveltekit","i-simple-icons-svelte",{"title":182,"path":183,"stem":184,"icon":185},"Nitro","\u002Fintegrate\u002Fframeworks\u002Fnitro","3.integrate\u002Fframeworks\u002F04.nitro","i-custom-nitro",{"title":187,"path":188,"stem":189,"icon":190},"TanStack Start","\u002Fintegrate\u002Fframeworks\u002Ftanstack-start","3.integrate\u002Fframeworks\u002F05.tanstack-start","i-custom-tanstack",{"title":192,"path":193,"stem":194,"icon":195},"NestJS","\u002Fintegrate\u002Fframeworks\u002Fnestjs","3.integrate\u002Fframeworks\u002F06.nestjs","i-simple-icons-nestjs",{"title":197,"path":198,"stem":199,"icon":200},"Express","\u002Fintegrate\u002Fframeworks\u002Fexpress","3.integrate\u002Fframeworks\u002F07.express","i-simple-icons-express",{"title":202,"path":203,"stem":204,"icon":205},"Hono","\u002Fintegrate\u002Fframeworks\u002Fhono","3.integrate\u002Fframeworks\u002F08.hono","i-simple-icons-hono",{"title":207,"path":208,"stem":209,"icon":210},"Fastify","\u002Fintegrate\u002Fframeworks\u002Ffastify","3.integrate\u002Fframeworks\u002F09.fastify","i-simple-icons-fastify",{"title":212,"path":213,"stem":214,"icon":215},"Elysia","\u002Fintegrate\u002Fframeworks\u002Felysia","3.integrate\u002Fframeworks\u002F10.elysia","i-custom-elysia",{"title":217,"path":218,"stem":219,"icon":220},"React Router","\u002Fintegrate\u002Fframeworks\u002Freact-router","3.integrate\u002Fframeworks\u002F11.react-router","i-custom-reactrouter",{"title":222,"path":223,"stem":224,"icon":225},"Cloudflare Workers","\u002Fintegrate\u002Fframeworks\u002Fcloudflare-workers","3.integrate\u002Fframeworks\u002F12.cloudflare-workers","i-simple-icons-cloudflare",{"title":227,"path":228,"stem":229,"icon":74},"Standalone","\u002Fintegrate\u002Fframeworks\u002Fstandalone","3.integrate\u002Fframeworks\u002F13.standalone",{"title":231,"path":232,"stem":233,"icon":234},"Astro","\u002Fintegrate\u002Fframeworks\u002Fastro","3.integrate\u002Fframeworks\u002F14.astro","i-simple-icons-astro",{"title":236,"path":237,"stem":238,"icon":239},"oRPC","\u002Fintegrate\u002Fframeworks\u002Forpc","3.integrate\u002Fframeworks\u002F15.orpc","i-lucide-network",{"title":241,"path":242,"stem":243,"icon":244},"AWS Lambda","\u002Fintegrate\u002Fframeworks\u002Faws-lambda","3.integrate\u002Fframeworks\u002F16.aws-lambda","i-custom-lambda",{"title":246,"path":247,"stem":248,"children":249,"page":29},"Use Cases","\u002Fuse-cases","4.use-cases",[250,254,259,288,316,348,353],{"title":36,"path":251,"stem":252,"icon":253},"\u002Fuse-cases\u002Foverview","4.use-cases\u002F0.overview","i-lucide-list-checks",{"title":255,"path":256,"stem":257,"icon":258},"Client Logging","\u002Fuse-cases\u002Fclient-logging","4.use-cases\u002F1.client-logging","i-lucide-monitor",{"title":260,"icon":261,"path":262,"stem":263,"children":264,"page":29},"AI SDK","i-simple-icons-vercel","\u002Fuse-cases\u002Fai-sdk","4.use-cases\u002F2.ai-sdk",[265,268,273,278,283],{"title":36,"path":266,"stem":267,"icon":39},"\u002Fuse-cases\u002Fai-sdk\u002Foverview","4.use-cases\u002F2.ai-sdk\u002F01.overview",{"title":269,"path":270,"stem":271,"icon":272},"Usage","\u002Fuse-cases\u002Fai-sdk\u002Fusage","4.use-cases\u002F2.ai-sdk\u002F02.usage","i-lucide-code",{"title":274,"path":275,"stem":276,"icon":277},"Options","\u002Fuse-cases\u002Fai-sdk\u002Foptions","4.use-cases\u002F2.ai-sdk\u002F03.options","i-lucide-sliders",{"title":279,"path":280,"stem":281,"icon":282},"Metadata","\u002Fuse-cases\u002Fai-sdk\u002Fmetadata","4.use-cases\u002F2.ai-sdk\u002F04.metadata","i-lucide-database",{"title":284,"path":285,"stem":286,"icon":287},"Telemetry","\u002Fuse-cases\u002Fai-sdk\u002Ftelemetry","4.use-cases\u002F2.ai-sdk\u002F05.telemetry","i-lucide-activity",{"title":289,"icon":290,"path":291,"stem":292,"children":293,"page":29},"Better Auth","i-simple-icons-betterauth","\u002Fuse-cases\u002Fbetter-auth","4.use-cases\u002F3.better-auth",[294,297,302,307,311],{"title":36,"path":295,"stem":296,"icon":39},"\u002Fuse-cases\u002Fbetter-auth\u002Foverview","4.use-cases\u002F3.better-auth\u002F01.overview",{"title":298,"path":299,"stem":300,"icon":301},"Identify User","\u002Fuse-cases\u002Fbetter-auth\u002Fidentify-user","4.use-cases\u002F3.better-auth\u002F02.identify-user","i-lucide-user-check",{"title":303,"path":304,"stem":305,"icon":306},"Middleware","\u002Fuse-cases\u002Fbetter-auth\u002Fmiddleware","4.use-cases\u002F3.better-auth\u002F03.middleware","i-lucide-shield",{"title":308,"path":309,"stem":310,"icon":258},"Client Sync","\u002Fuse-cases\u002Fbetter-auth\u002Fclient-sync","4.use-cases\u002F3.better-auth\u002F04.client-sync",{"title":312,"path":313,"stem":314,"icon":315},"Performance","\u002Fuse-cases\u002Fbetter-auth\u002Fperformance","4.use-cases\u002F3.better-auth\u002F05.performance","i-lucide-gauge",{"title":317,"icon":318,"path":319,"stem":320,"children":321,"page":29},"Audit Logs","i-lucide-shield-check","\u002Fuse-cases\u002Faudit","4.use-cases\u002F4.audit",[322,325,330,335,340,344],{"title":36,"path":323,"stem":324,"icon":39},"\u002Fuse-cases\u002Faudit\u002Foverview","4.use-cases\u002F4.audit\u002F01.overview",{"title":326,"path":327,"stem":328,"icon":329},"Schema","\u002Fuse-cases\u002Faudit\u002Fschema","4.use-cases\u002F4.audit\u002F02.schema","i-lucide-file-text",{"title":331,"path":332,"stem":333,"icon":334},"Recording","\u002Fuse-cases\u002Faudit\u002Frecording","4.use-cases\u002F4.audit\u002F03.recording","i-lucide-pen-line",{"title":336,"path":337,"stem":338,"icon":339},"Drains","\u002Fuse-cases\u002Faudit\u002Fpipeline","4.use-cases\u002F4.audit\u002F04.pipeline","i-lucide-link",{"title":341,"path":342,"stem":343,"icon":318},"Compliance","\u002Fuse-cases\u002Faudit\u002Fcompliance","4.use-cases\u002F4.audit\u002F05.compliance",{"title":345,"path":346,"stem":347,"icon":79},"Recipes","\u002Fuse-cases\u002Faudit\u002Frecipes","4.use-cases\u002F4.audit\u002F06.recipes",{"title":349,"path":350,"stem":351,"icon":352},"Enrichers","\u002Fuse-cases\u002Fenrichers","4.use-cases\u002F5.enrichers","i-lucide-sparkles",{"title":354,"path":355,"stem":356,"icon":357},"eve","\u002Fuse-cases\u002Feve","4.use-cases\u002F5.eve","i-custom-eve",{"title":359,"path":360,"stem":361,"children":362,"page":29},"Extend","\u002Fextend","5.extend",[363,367,372,377,382,386,390,394,398,403,408],{"title":36,"path":364,"stem":365,"icon":366},"\u002Fextend\u002Foverview","5.extend\u002F0.overview","i-lucide-blocks",{"title":368,"path":369,"stem":370,"icon":371},"Stream","\u002Fextend\u002Fstream","5.extend\u002F1.stream","i-lucide-radio-tower",{"title":373,"path":374,"stem":375,"icon":376},"Custom framework","\u002Fextend\u002Fcustom-framework","5.extend\u002F10.custom-framework","i-lucide-puzzle",{"title":378,"path":379,"stem":380,"icon":381},"FS reader","\u002Fextend\u002Ffs-reader","5.extend\u002F2.fs-reader","i-lucide-folder-search",{"title":345,"path":383,"stem":384,"icon":385},"\u002Fextend\u002Fconsumer-recipes","5.extend\u002F3.consumer-recipes","i-lucide-chef-hat",{"title":387,"path":388,"stem":389,"icon":366},"Plugins","\u002Fextend\u002Fplugins","5.extend\u002F4.plugins",{"title":391,"path":392,"stem":393,"icon":352},"Custom enrichers","\u002Fextend\u002Fcustom-enrichers","5.extend\u002F5.custom-enrichers",{"title":395,"path":396,"stem":397,"icon":64},"Tail sampling","\u002Fextend\u002Ftail-sampling","5.extend\u002F6.tail-sampling",{"title":399,"path":400,"stem":401,"icon":402},"Identity headers","\u002Fextend\u002Fidentity-headers","5.extend\u002F7.identity-headers","i-lucide-fingerprint",{"title":404,"path":405,"stem":406,"icon":407},"Custom drains","\u002Fextend\u002Fcustom-drains","5.extend\u002F8.custom-drains","i-lucide-share-2",{"title":409,"path":410,"stem":411,"icon":412},"Drain pipeline","\u002Fextend\u002Fdrain-pipeline","5.extend\u002F9.drain-pipeline","i-lucide-workflow",{"title":414,"path":415,"stem":416,"children":417,"page":29},"Reference","\u002Freference","6.reference",[418,423,426,431,435,440],{"title":419,"path":420,"stem":421,"icon":422},"Configuration","\u002Freference\u002Fconfiguration","6.reference\u002F1.configuration","i-lucide-settings",{"title":312,"path":424,"stem":425,"icon":315},"\u002Freference\u002Fperformance","6.reference\u002F2.performance",{"title":427,"path":428,"stem":429,"icon":430},"Vite Plugin","\u002Freference\u002Fvite-plugin","6.reference\u002F3.vite-plugin","i-custom-vite",{"title":432,"path":433,"stem":434,"icon":318},"Best Practices","\u002Freference\u002Fbest-practices","6.reference\u002F4.best-practices",{"title":436,"path":437,"stem":438,"icon":439},"vs Other Loggers","\u002Freference\u002Fvs-other-loggers","6.reference\u002F5.vs-other-loggers","i-lucide-scale",{"title":441,"path":442,"stem":443,"icon":352},"Agent Skills","\u002Freference\u002Fagent-skills","6.reference\u002F6.agent-skills",{"id":445,"title":419,"body":446,"description":2807,"extension":2808,"links":2809,"meta":2815,"navigation":2816,"path":420,"seo":2817,"stem":421,"__hash__":2818},"docs\u002F6.reference\u002F1.configuration.md",{"type":447,"value":448,"toc":2790},"minimark",[449,462,472,479,754,1010,1039,1046,1103,1119,1122,1129,1139,1145,1200,1293,1299,1409,1417,1421,1430,1568,1572,1577,1677,1686,1690,1693,2345,2471,2493,2497,2506,2631,2635,2638,2641,2650,2745,2752,2755,2780,2786],[450,451,452,453,457,458,461],"p",{},"evlog has two configuration surfaces: ",[454,455,456],"strong",{},"global options"," set once at startup, and ",[454,459,460],{},"middleware options"," set per-framework integration. This page documents both.",[463,464,466,467,471],"h2",{"id":465},"global-options-initlogger","Global Options (",[468,469,470],"code",{},"initLogger",")",[450,473,474,475,478],{},"These options apply to all frameworks. Call ",[468,476,477],{},"initLogger()"," once at application startup for standalone frameworks (Hono, Express, Fastify, Elysia, NestJS, SvelteKit, Cloudflare Workers). For Nuxt and Nitro, these are set via module config and passed through automatically.",[480,481,487],"pre",{"className":482,"code":483,"filename":484,"language":485,"meta":486,"style":486},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import { initLogger } from 'evlog'\nimport { createAxiomDrain } from 'evlog\u002Faxiom'\n\ninitLogger({\n  enabled: true,\n  env: { service: 'my-api', environment: 'production' },\n  pretty: false,\n  silent: false,\n  stringify: true,\n  minLevel: 'info',\n  sampling: { rates: { info: 10 }, keep: [{ status: 400 }] },\n  drain: createAxiomDrain(),\n})\n","src\u002Findex.ts","typescript","",[468,488,489,522,543,550,562,579,620,633,645,657,674,730,745],{"__ignoreMap":486},[490,491,494,498,502,506,509,512,515,519],"span",{"class":492,"line":493},"line",1,[490,495,497],{"class":496},"s7zQu","import",[490,499,501],{"class":500},"sMK4o"," {",[490,503,505],{"class":504},"sTEyZ"," initLogger",[490,507,508],{"class":500}," }",[490,510,511],{"class":496}," from",[490,513,514],{"class":500}," '",[490,516,518],{"class":517},"sfazB","evlog",[490,520,521],{"class":500},"'\n",[490,523,525,527,529,532,534,536,538,541],{"class":492,"line":524},2,[490,526,497],{"class":496},[490,528,501],{"class":500},[490,530,531],{"class":504}," createAxiomDrain",[490,533,508],{"class":500},[490,535,511],{"class":496},[490,537,514],{"class":500},[490,539,540],{"class":517},"evlog\u002Faxiom",[490,542,521],{"class":500},[490,544,546],{"class":492,"line":545},3,[490,547,549],{"emptyLinePlaceholder":548},true,"\n",[490,551,553,556,559],{"class":492,"line":552},4,[490,554,470],{"class":555},"s2Zo4",[490,557,558],{"class":504},"(",[490,560,561],{"class":500},"{\n",[490,563,565,569,572,576],{"class":492,"line":564},5,[490,566,568],{"class":567},"swJcz","  enabled",[490,570,571],{"class":500},":",[490,573,575],{"class":574},"sfNiH"," true",[490,577,578],{"class":500},",\n",[490,580,582,585,587,589,592,594,596,599,602,605,608,610,612,615,617],{"class":492,"line":581},6,[490,583,584],{"class":567},"  env",[490,586,571],{"class":500},[490,588,501],{"class":500},[490,590,591],{"class":567}," service",[490,593,571],{"class":500},[490,595,514],{"class":500},[490,597,598],{"class":517},"my-api",[490,600,601],{"class":500},"'",[490,603,604],{"class":500},",",[490,606,607],{"class":567}," environment",[490,609,571],{"class":500},[490,611,514],{"class":500},[490,613,614],{"class":517},"production",[490,616,601],{"class":500},[490,618,619],{"class":500}," },\n",[490,621,623,626,628,631],{"class":492,"line":622},7,[490,624,625],{"class":567},"  pretty",[490,627,571],{"class":500},[490,629,630],{"class":574}," false",[490,632,578],{"class":500},[490,634,636,639,641,643],{"class":492,"line":635},8,[490,637,638],{"class":567},"  silent",[490,640,571],{"class":500},[490,642,630],{"class":574},[490,644,578],{"class":500},[490,646,648,651,653,655],{"class":492,"line":647},9,[490,649,650],{"class":567},"  stringify",[490,652,571],{"class":500},[490,654,575],{"class":574},[490,656,578],{"class":500},[490,658,660,663,665,667,670,672],{"class":492,"line":659},10,[490,661,662],{"class":567},"  minLevel",[490,664,571],{"class":500},[490,666,514],{"class":500},[490,668,669],{"class":517},"info",[490,671,601],{"class":500},[490,673,578],{"class":500},[490,675,677,680,682,684,687,689,691,694,696,700,703,706,708,711,714,717,719,722,724,727],{"class":492,"line":676},11,[490,678,679],{"class":567},"  sampling",[490,681,571],{"class":500},[490,683,501],{"class":500},[490,685,686],{"class":567}," rates",[490,688,571],{"class":500},[490,690,501],{"class":500},[490,692,693],{"class":567}," info",[490,695,571],{"class":500},[490,697,699],{"class":698},"sbssI"," 10",[490,701,702],{"class":500}," },",[490,704,705],{"class":567}," keep",[490,707,571],{"class":500},[490,709,710],{"class":504}," [",[490,712,713],{"class":500},"{",[490,715,716],{"class":567}," status",[490,718,571],{"class":500},[490,720,721],{"class":698}," 400",[490,723,508],{"class":500},[490,725,726],{"class":504},"] ",[490,728,729],{"class":500},"},\n",[490,731,733,736,738,740,743],{"class":492,"line":732},12,[490,734,735],{"class":567},"  drain",[490,737,571],{"class":500},[490,739,531],{"class":555},[490,741,742],{"class":504},"()",[490,744,578],{"class":500},[490,746,748,751],{"class":492,"line":747},13,[490,749,750],{"class":500},"}",[490,752,753],{"class":504},")\n",[755,756,757,776],"table",{},[758,759,760],"thead",{},[761,762,763,767,770,773],"tr",{},[764,765,766],"th",{},"Option",[764,768,769],{},"Type",[764,771,772],{},"Default",[764,774,775],{},"Description",[777,778,779,804,822,844,874,892,916,944,966,991],"tbody",{},[761,780,781,787,792,797],{},[782,783,784],"td",{},[468,785,786],{},"enabled",[782,788,789],{},[468,790,791],{},"boolean",[782,793,794],{},[468,795,796],{},"true",[782,798,799,800,803],{},"Enable\u002Fdisable all logging globally. When ",[468,801,802],{},"false",", all operations become no-ops",[761,805,806,811,816,819],{},[782,807,808],{},[468,809,810],{},"env",[782,812,813],{},[468,814,815],{},"Partial\u003CEnvironmentContext>",[782,817,818],{},"Auto-detected",[782,820,821],{},"Environment context overrides (see below)",[761,823,824,829,833,838],{},[782,825,826],{},[468,827,828],{},"pretty",[782,830,831],{},[468,832,791],{},[782,834,835,837],{},[468,836,796],{}," in dev",[782,839,840,841],{},"Pretty print with tree formatting. Auto-detected based on ",[468,842,843],{},"NODE_ENV",[761,845,846,851,856,862],{},[782,847,848],{},[468,849,850],{},"dev",[782,852,853],{},[468,854,855],{},"'evlog' | 'nitro' | 'both' | object",[782,857,858,861],{},[468,859,860],{},"'evlog'"," in pretty dev",[782,863,864,865,868,869],{},"Dev terminal presets or ",[468,866,867],{},"{ frameworkOverlay, prettyError }"," — see ",[870,871,873],"a",{"href":872},"#dev-terminal-output","Dev terminal output",[761,875,876,881,885,889],{},[782,877,878],{},[468,879,880],{},"silent",[782,882,883],{},[468,884,791],{},[782,886,887],{},[468,888,802],{},[782,890,891],{},"Suppress console output. Events are still built, sampled, and passed to drains",[761,893,894,899,903,907],{},[782,895,896],{},[468,897,898],{},"stringify",[782,900,901],{},[468,902,791],{},[782,904,905],{},[468,906,796],{},[782,908,909,910,912,913,915],{},"Emit JSON strings when ",[468,911,828],{}," is disabled. Set to ",[468,914,802],{}," for Cloudflare Workers",[761,917,918,923,928,933],{},[782,919,920],{},[468,921,922],{},"minLevel",[782,924,925],{},[468,926,927],{},"'debug' | 'info' | 'warn' | 'error'",[782,929,930],{},[468,931,932],{},"'debug'",[782,934,935,936,939,940,943],{},"Minimum severity for the global ",[468,937,938],{},"log"," API only (not ",[468,941,942],{},"createLogger"," \u002F request wide events). Order: debug \u003C info \u003C warn \u003C error",[761,945,946,951,956,961],{},[782,947,948],{},[468,949,950],{},"sampling",[782,952,953],{},[468,954,955],{},"SamplingConfig",[782,957,958],{},[468,959,960],{},"undefined",[782,962,963,964],{},"Head and tail sampling configuration. See ",[870,965,61],{"href":62},[761,967,968,973,978,983],{},[782,969,970],{},[468,971,972],{},"redact",[782,974,975],{},[468,976,977],{},"boolean | RedactConfig",[782,979,980,982],{},[468,981,796],{}," in production",[782,984,985,986,988,989],{},"Enabled by default in production. ",[468,987,802],{}," to disable. Object for fine-grained control. See ",[870,990,66],{"href":67},[761,992,993,998,1003,1007],{},[782,994,995],{},[468,996,997],{},"drain",[782,999,1000],{},[468,1001,1002],{},"(ctx: DrainContext) => void",[782,1004,1005],{},[468,1006,960],{},[782,1008,1009],{},"Drain callback for sending events to external services",[450,1011,1012,1015,1016,1018,1019,1022,1023,1026,1027,1030,1031,1034,1035,1038],{},[468,1013,1014],{},"RedactConfig"," fields (when ",[468,1017,972],{}," is an object): ",[468,1020,1021],{},"paths"," (dot-notation with globs), ",[468,1024,1025],{},"patterns"," (regex on string values), ",[468,1028,1029],{},"builtins",", ",[468,1032,1033],{},"replacement",". Full table in ",[870,1036,66],{"href":1037},"\u002Flearn\u002Fredaction#configuration-reference",".",[1040,1041,1043,1045],"h3",{"id":1042},"minlevel-vs-sampling",[468,1044,922],{}," vs sampling",[1047,1048,1049,1087],"ul",{},[1050,1051,1052,1056,1057,1060,1061,1064,1065,1068,1069,1072,1073,1076,1077,1082,1083,1086],"li",{},[454,1053,1054],{},[468,1055,922],{}," is a ",[454,1058,1059],{},"hard threshold"," on the simple ",[468,1062,1063],{},"log.*"," API: levels below the threshold are never emitted. It does ",[454,1066,1067],{},"not"," apply to wide events from ",[468,1070,1071],{},"useLogger"," \u002F ",[468,1074,1075],{},"createLogger().emit()"," — use ",[454,1078,1079],{},[468,1080,1081],{},"sampling.rates"," (and tail ",[468,1084,1085],{},"keep",") for request volume.",[1050,1088,1089,1092,1093,1095,1096,1099,1100,1102],{},[454,1090,1091],{},"Head sampling"," (",[468,1094,1081],{},") is ",[454,1097,1098],{},"probabilistic"," on what is already allowed by ",[468,1101,922],{}," for simple logs.",[450,1104,1105,1106,1072,1109,1112,1113,1115,1116,1118],{},"Evaluation order for ",[468,1107,1108],{},"log.info",[468,1110,1111],{},"log.debug"," \u002F etc.: ",[468,1114,786],{}," → ",[468,1117,922],{}," → head sampling → output.",[1040,1120,873],{"id":1121},"dev-terminal-output",[450,1123,1124,1125,1128],{},"Pretty error blocks run only when ",[468,1126,1127],{},"pretty: true"," (default in development). Production always emits JSON wide events — no stack snippets or disk reads.",[450,1130,1131,1132,1134,1135,1138],{},"Use ",[468,1133,850],{}," to control ",[454,1136,1137],{},"two independent axes",": whether Nitro's Youch overlay runs, and how much stack detail evlog prints inside the wide event.",[450,1140,1141,1144],{},[454,1142,1143],{},"Presets"," (recommended):",[755,1146,1147,1160],{},[758,1148,1149],{},[761,1150,1151,1154,1157],{},[764,1152,1153],{},"Preset",[764,1155,1156],{},"Nitro overlay",[764,1158,1159],{},"evlog error block",[777,1161,1162,1175,1188],{},[761,1163,1164,1169,1172],{},[782,1165,1166,1168],{},[468,1167,860],{}," (default in pretty dev)",[782,1170,1171],{},"Off",[782,1173,1174],{},"Full — location, snippet, stack tail, Why\u002FFix",[761,1176,1177,1182,1185],{},[782,1178,1179],{},[468,1180,1181],{},"'nitro'",[782,1183,1184],{},"On",[782,1186,1187],{},"Guidance only — message + Why\u002FFix\u002Flink (stack from Nitro)",[761,1189,1190,1195,1197],{},[782,1191,1192],{},[468,1193,1194],{},"'both'",[782,1196,1184],{},[782,1198,1199],{},"Full — evlog block + Nitro overlay (debug)",[480,1201,1204],{"className":482,"code":1202,"filename":1203,"language":485,"meta":486,"style":486},"export default defineNuxtConfig({\n  modules: ['evlog\u002Fnuxt'],\n  evlog: {\n    pretty: true,\n    dev: 'evlog', \u002F\u002F or 'nitro' | 'both'\n  },\n})\n","nuxt.config.ts",[468,1205,1206,1221,1242,1252,1263,1282,1287],{"__ignoreMap":486},[490,1207,1208,1211,1214,1217,1219],{"class":492,"line":493},[490,1209,1210],{"class":496},"export",[490,1212,1213],{"class":496}," default",[490,1215,1216],{"class":555}," defineNuxtConfig",[490,1218,558],{"class":504},[490,1220,561],{"class":500},[490,1222,1223,1226,1228,1230,1232,1235,1237,1240],{"class":492,"line":524},[490,1224,1225],{"class":567},"  modules",[490,1227,571],{"class":500},[490,1229,710],{"class":504},[490,1231,601],{"class":500},[490,1233,1234],{"class":517},"evlog\u002Fnuxt",[490,1236,601],{"class":500},[490,1238,1239],{"class":504},"]",[490,1241,578],{"class":500},[490,1243,1244,1247,1249],{"class":492,"line":545},[490,1245,1246],{"class":567},"  evlog",[490,1248,571],{"class":500},[490,1250,1251],{"class":500}," {\n",[490,1253,1254,1257,1259,1261],{"class":492,"line":552},[490,1255,1256],{"class":567},"    pretty",[490,1258,571],{"class":500},[490,1260,575],{"class":574},[490,1262,578],{"class":500},[490,1264,1265,1268,1270,1272,1274,1276,1278],{"class":492,"line":564},[490,1266,1267],{"class":567},"    dev",[490,1269,571],{"class":500},[490,1271,514],{"class":500},[490,1273,518],{"class":517},[490,1275,601],{"class":500},[490,1277,604],{"class":500},[490,1279,1281],{"class":1280},"sHwdD"," \u002F\u002F or 'nitro' | 'both'\n",[490,1283,1284],{"class":492,"line":581},[490,1285,1286],{"class":500},"  },\n",[490,1288,1289,1291],{"class":492,"line":622},[490,1290,750],{"class":500},[490,1292,753],{"class":504},[450,1294,1295,1298],{},[454,1296,1297],{},"Explicit object"," (fine-grained):",[480,1300,1302],{"className":482,"code":1301,"filename":1203,"language":485,"meta":486,"style":486},"evlog: {\n  dev: {\n    frameworkOverlay: true,\n    prettyError: {\n      snippet: false,\n      stackDepth: 0,\n      compact: true,\n      detail: 'guidance', \u002F\u002F 'full' | 'guidance'\n    },\n  },\n}\n",[468,1303,1304,1313,1322,1333,1342,1353,1365,1376,1395,1400,1404],{"__ignoreMap":486},[490,1305,1306,1309,1311],{"class":492,"line":493},[490,1307,518],{"class":1308},"sBMFI",[490,1310,571],{"class":500},[490,1312,1251],{"class":500},[490,1314,1315,1318,1320],{"class":492,"line":524},[490,1316,1317],{"class":1308},"  dev",[490,1319,571],{"class":500},[490,1321,1251],{"class":500},[490,1323,1324,1327,1329,1331],{"class":492,"line":545},[490,1325,1326],{"class":1308},"    frameworkOverlay",[490,1328,571],{"class":500},[490,1330,575],{"class":574},[490,1332,578],{"class":500},[490,1334,1335,1338,1340],{"class":492,"line":552},[490,1336,1337],{"class":1308},"    prettyError",[490,1339,571],{"class":500},[490,1341,1251],{"class":500},[490,1343,1344,1347,1349,1351],{"class":492,"line":564},[490,1345,1346],{"class":1308},"      snippet",[490,1348,571],{"class":500},[490,1350,630],{"class":574},[490,1352,578],{"class":500},[490,1354,1355,1358,1360,1363],{"class":492,"line":581},[490,1356,1357],{"class":1308},"      stackDepth",[490,1359,571],{"class":500},[490,1361,1362],{"class":698}," 0",[490,1364,578],{"class":500},[490,1366,1367,1370,1372,1374],{"class":492,"line":622},[490,1368,1369],{"class":1308},"      compact",[490,1371,571],{"class":500},[490,1373,575],{"class":574},[490,1375,578],{"class":500},[490,1377,1378,1381,1383,1385,1388,1390,1392],{"class":492,"line":635},[490,1379,1380],{"class":1308},"      detail",[490,1382,571],{"class":500},[490,1384,514],{"class":500},[490,1386,1387],{"class":517},"guidance",[490,1389,601],{"class":500},[490,1391,604],{"class":500},[490,1393,1394],{"class":1280}," \u002F\u002F 'full' | 'guidance'\n",[490,1396,1397],{"class":492,"line":647},[490,1398,1399],{"class":500},"    },\n",[490,1401,1402],{"class":492,"line":659},[490,1403,1286],{"class":500},[490,1405,1406],{"class":492,"line":676},[490,1407,1408],{"class":500},"}\n",[450,1410,1411,1412,1416],{},"See ",[870,1413,1415],{"href":1414},"\u002Flearn\u002Fstructured-errors#development-terminal-output","Structured Errors — Development terminal output"," for an example of the pretty error tree.",[1040,1418,1420],{"id":1419},"environment-context","Environment Context",[450,1422,1423,1424,1426,1427,1038],{},"The ",[468,1425,810],{}," option controls the fields included in every log event. Most values are auto-detected from environment variables and ",[468,1428,1429],{},"package.json",[755,1431,1432,1446],{},[758,1433,1434],{},[761,1435,1436,1439,1441,1443],{},[764,1437,1438],{},"Field",[764,1440,769],{},[764,1442,772],{},[764,1444,1445],{},"Auto-detected from",[777,1447,1448,1473,1493,1516,1542],{},[761,1449,1450,1455,1460,1465],{},[782,1451,1452],{},[468,1453,1454],{},"service",[782,1456,1457],{},[468,1458,1459],{},"string",[782,1461,1462],{},[468,1463,1464],{},"'app'",[782,1466,1467,1030,1470,1472],{},[468,1468,1469],{},"SERVICE_NAME",[468,1471,1429],{}," name",[761,1474,1475,1480,1484,1489],{},[782,1476,1477],{},[468,1478,1479],{},"environment",[782,1481,1482],{},[468,1483,1459],{},[782,1485,1486],{},[468,1487,1488],{},"'development'",[782,1490,1491],{},[468,1492,843],{},[761,1494,1495,1500,1504,1508],{},[782,1496,1497],{},[468,1498,1499],{},"version",[782,1501,1502],{},[468,1503,1459],{},[782,1505,1506],{},[468,1507,960],{},[782,1509,1510,1030,1513,1515],{},[468,1511,1512],{},"APP_VERSION",[468,1514,1429],{}," version",[761,1517,1518,1523,1527,1531],{},[782,1519,1520],{},[468,1521,1522],{},"commitHash",[782,1524,1525],{},[468,1526,1459],{},[782,1528,1529],{},[468,1530,960],{},[782,1532,1533,1030,1536,1030,1539],{},[468,1534,1535],{},"COMMIT_SHA",[468,1537,1538],{},"GIT_COMMIT",[468,1540,1541],{},"VERCEL_GIT_COMMIT_SHA",[761,1543,1544,1549,1553,1557],{},[782,1545,1546],{},[468,1547,1548],{},"region",[782,1550,1551],{},[468,1552,1459],{},[782,1554,1555],{},[468,1556,960],{},[782,1558,1559,1030,1562,1030,1565],{},[468,1560,1561],{},"FLY_REGION",[468,1563,1564],{},"AWS_REGION",[468,1566,1567],{},"VERCEL_REGION",[1040,1569,1571],{"id":1570},"silent-mode","Silent Mode",[450,1573,1131,1574,1576],{},[468,1575,880],{}," when your deployment platform captures stdout as its primary log ingestion (GCP Cloud Run, AWS Lambda, Fly.io, Railway, etc.) and you want a drain adapter to control the output format.",[480,1578,1580],{"className":482,"code":1579,"filename":484,"language":485,"meta":486,"style":486},"import { initLogger } from 'evlog'\nimport { createAxiomDrain } from 'evlog\u002Faxiom'\n\ninitLogger({\n  silent: process.env.NODE_ENV === 'production',\n  drain: createAxiomDrain(),\n})\n",[468,1581,1582,1600,1618,1622,1630,1659,1671],{"__ignoreMap":486},[490,1583,1584,1586,1588,1590,1592,1594,1596,1598],{"class":492,"line":493},[490,1585,497],{"class":496},[490,1587,501],{"class":500},[490,1589,505],{"class":504},[490,1591,508],{"class":500},[490,1593,511],{"class":496},[490,1595,514],{"class":500},[490,1597,518],{"class":517},[490,1599,521],{"class":500},[490,1601,1602,1604,1606,1608,1610,1612,1614,1616],{"class":492,"line":524},[490,1603,497],{"class":496},[490,1605,501],{"class":500},[490,1607,531],{"class":504},[490,1609,508],{"class":500},[490,1611,511],{"class":496},[490,1613,514],{"class":500},[490,1615,540],{"class":517},[490,1617,521],{"class":500},[490,1619,1620],{"class":492,"line":545},[490,1621,549],{"emptyLinePlaceholder":548},[490,1623,1624,1626,1628],{"class":492,"line":552},[490,1625,470],{"class":555},[490,1627,558],{"class":504},[490,1629,561],{"class":500},[490,1631,1632,1634,1636,1639,1641,1643,1645,1648,1651,1653,1655,1657],{"class":492,"line":564},[490,1633,638],{"class":567},[490,1635,571],{"class":500},[490,1637,1638],{"class":504}," process",[490,1640,1038],{"class":500},[490,1642,810],{"class":504},[490,1644,1038],{"class":500},[490,1646,1647],{"class":504},"NODE_ENV ",[490,1649,1650],{"class":500},"===",[490,1652,514],{"class":500},[490,1654,614],{"class":517},[490,1656,601],{"class":500},[490,1658,578],{"class":500},[490,1660,1661,1663,1665,1667,1669],{"class":492,"line":581},[490,1662,735],{"class":567},[490,1664,571],{"class":500},[490,1666,531],{"class":555},[490,1668,742],{"class":504},[490,1670,578],{"class":500},[490,1672,1673,1675],{"class":492,"line":622},[490,1674,750],{"class":500},[490,1676,753],{"class":504},[1678,1679,1682,1683,1685],"callout",{"color":1680,"icon":1681},"warning","i-lucide-alert-triangle","If ",[468,1684,880],{}," is enabled without a drain, events are built and sampled but never output anywhere. evlog will warn you about this at startup.",[463,1687,1689],{"id":1688},"middleware-options","Middleware Options",[450,1691,1692],{},"These options are passed to the framework middleware\u002Fplugin. They control per-request behavior: which routes to log, how to drain and enrich events, and custom tail sampling logic.",[1694,1695,1696,1993,2187,2284],"code-group",{},[480,1697,1699],{"className":482,"code":1698,"filename":172,"language":485,"meta":486,"style":486},"\u002F\u002F lib\u002Fevlog.ts\nimport { createEvlog } from 'evlog\u002Fnext'\nimport { createAxiomDrain } from 'evlog\u002Faxiom'\n\nexport const { withEvlog, useLogger, log, createError } = createEvlog({\n  service: 'my-app',\n  include: ['\u002Fapi\u002F**'],\n  exclude: ['\u002Fapi\u002Fhealth'],\n  routes: { '\u002Fapi\u002Fauth\u002F**': { service: 'auth' } },\n  drain: createAxiomDrain(),\n  enrich: (ctx) => { ctx.event.region = process.env.FLY_REGION },\n  keep: (ctx) => { if (ctx.duration > 2000) ctx.shouldKeep = true },\n})\n",[468,1700,1701,1706,1726,1744,1748,1787,1803,1823,1843,1878,1890,1936,1987],{"__ignoreMap":486},[490,1702,1703],{"class":492,"line":493},[490,1704,1705],{"class":1280},"\u002F\u002F lib\u002Fevlog.ts\n",[490,1707,1708,1710,1712,1715,1717,1719,1721,1724],{"class":492,"line":524},[490,1709,497],{"class":496},[490,1711,501],{"class":500},[490,1713,1714],{"class":504}," createEvlog",[490,1716,508],{"class":500},[490,1718,511],{"class":496},[490,1720,514],{"class":500},[490,1722,1723],{"class":517},"evlog\u002Fnext",[490,1725,521],{"class":500},[490,1727,1728,1730,1732,1734,1736,1738,1740,1742],{"class":492,"line":545},[490,1729,497],{"class":496},[490,1731,501],{"class":500},[490,1733,531],{"class":504},[490,1735,508],{"class":500},[490,1737,511],{"class":496},[490,1739,514],{"class":500},[490,1741,540],{"class":517},[490,1743,521],{"class":500},[490,1745,1746],{"class":492,"line":552},[490,1747,549],{"emptyLinePlaceholder":548},[490,1749,1750,1752,1756,1758,1761,1763,1766,1768,1771,1773,1776,1778,1781,1783,1785],{"class":492,"line":564},[490,1751,1210],{"class":496},[490,1753,1755],{"class":1754},"spNyl"," const",[490,1757,501],{"class":500},[490,1759,1760],{"class":504}," withEvlog",[490,1762,604],{"class":500},[490,1764,1765],{"class":504}," useLogger",[490,1767,604],{"class":500},[490,1769,1770],{"class":504}," log",[490,1772,604],{"class":500},[490,1774,1775],{"class":504}," createError ",[490,1777,750],{"class":500},[490,1779,1780],{"class":500}," =",[490,1782,1714],{"class":555},[490,1784,558],{"class":504},[490,1786,561],{"class":500},[490,1788,1789,1792,1794,1796,1799,1801],{"class":492,"line":581},[490,1790,1791],{"class":567},"  service",[490,1793,571],{"class":500},[490,1795,514],{"class":500},[490,1797,1798],{"class":517},"my-app",[490,1800,601],{"class":500},[490,1802,578],{"class":500},[490,1804,1805,1808,1810,1812,1814,1817,1819,1821],{"class":492,"line":622},[490,1806,1807],{"class":567},"  include",[490,1809,571],{"class":500},[490,1811,710],{"class":504},[490,1813,601],{"class":500},[490,1815,1816],{"class":517},"\u002Fapi\u002F**",[490,1818,601],{"class":500},[490,1820,1239],{"class":504},[490,1822,578],{"class":500},[490,1824,1825,1828,1830,1832,1834,1837,1839,1841],{"class":492,"line":635},[490,1826,1827],{"class":567},"  exclude",[490,1829,571],{"class":500},[490,1831,710],{"class":504},[490,1833,601],{"class":500},[490,1835,1836],{"class":517},"\u002Fapi\u002Fhealth",[490,1838,601],{"class":500},[490,1840,1239],{"class":504},[490,1842,578],{"class":500},[490,1844,1845,1848,1850,1852,1854,1857,1859,1861,1863,1865,1867,1869,1872,1874,1876],{"class":492,"line":647},[490,1846,1847],{"class":567},"  routes",[490,1849,571],{"class":500},[490,1851,501],{"class":500},[490,1853,514],{"class":500},[490,1855,1856],{"class":567},"\u002Fapi\u002Fauth\u002F**",[490,1858,601],{"class":500},[490,1860,571],{"class":500},[490,1862,501],{"class":500},[490,1864,591],{"class":567},[490,1866,571],{"class":500},[490,1868,514],{"class":500},[490,1870,1871],{"class":517},"auth",[490,1873,601],{"class":500},[490,1875,508],{"class":500},[490,1877,619],{"class":500},[490,1879,1880,1882,1884,1886,1888],{"class":492,"line":659},[490,1881,735],{"class":567},[490,1883,571],{"class":500},[490,1885,531],{"class":555},[490,1887,742],{"class":504},[490,1889,578],{"class":500},[490,1891,1892,1895,1897,1899,1903,1905,1908,1910,1913,1915,1918,1920,1922,1924,1926,1928,1930,1932,1934],{"class":492,"line":676},[490,1893,1894],{"class":555},"  enrich",[490,1896,571],{"class":500},[490,1898,1092],{"class":500},[490,1900,1902],{"class":1901},"sHdIc","ctx",[490,1904,471],{"class":500},[490,1906,1907],{"class":1754}," =>",[490,1909,501],{"class":500},[490,1911,1912],{"class":504}," ctx",[490,1914,1038],{"class":500},[490,1916,1917],{"class":504},"event",[490,1919,1038],{"class":500},[490,1921,1548],{"class":504},[490,1923,1780],{"class":500},[490,1925,1638],{"class":504},[490,1927,1038],{"class":500},[490,1929,810],{"class":504},[490,1931,1038],{"class":500},[490,1933,1561],{"class":504},[490,1935,619],{"class":500},[490,1937,1938,1941,1943,1945,1947,1949,1951,1953,1956,1958,1960,1962,1965,1968,1971,1974,1976,1978,1981,1983,1985],{"class":492,"line":732},[490,1939,1940],{"class":555},"  keep",[490,1942,571],{"class":500},[490,1944,1092],{"class":500},[490,1946,1902],{"class":1901},[490,1948,471],{"class":500},[490,1950,1907],{"class":1754},[490,1952,501],{"class":500},[490,1954,1955],{"class":496}," if",[490,1957,1092],{"class":567},[490,1959,1902],{"class":504},[490,1961,1038],{"class":500},[490,1963,1964],{"class":504},"duration",[490,1966,1967],{"class":500}," >",[490,1969,1970],{"class":698}," 2000",[490,1972,1973],{"class":567},") ",[490,1975,1902],{"class":504},[490,1977,1038],{"class":500},[490,1979,1980],{"class":504},"shouldKeep",[490,1982,1780],{"class":500},[490,1984,575],{"class":574},[490,1986,619],{"class":500},[490,1988,1989,1991],{"class":492,"line":747},[490,1990,750],{"class":500},[490,1992,753],{"class":504},[480,1994,1996],{"className":482,"code":1995,"filename":202,"language":485,"meta":486,"style":486},"app.use(evlog({\n  include: ['\u002Fapi\u002F**'],\n  exclude: ['\u002Fapi\u002Fhealth'],\n  routes: { '\u002Fapi\u002Fauth\u002F**': { service: 'auth' } },\n  drain: createAxiomDrain(),\n  enrich: (ctx) => { ctx.event.region = process.env.FLY_REGION },\n  keep: (ctx) => { if (ctx.duration > 2000) ctx.shouldKeep = true },\n}))\n",[468,1997,1998,2016,2034,2052,2084,2096,2136,2180],{"__ignoreMap":486},[490,1999,2000,2003,2005,2008,2010,2012,2014],{"class":492,"line":493},[490,2001,2002],{"class":504},"app",[490,2004,1038],{"class":500},[490,2006,2007],{"class":555},"use",[490,2009,558],{"class":504},[490,2011,518],{"class":555},[490,2013,558],{"class":504},[490,2015,561],{"class":500},[490,2017,2018,2020,2022,2024,2026,2028,2030,2032],{"class":492,"line":524},[490,2019,1807],{"class":567},[490,2021,571],{"class":500},[490,2023,710],{"class":504},[490,2025,601],{"class":500},[490,2027,1816],{"class":517},[490,2029,601],{"class":500},[490,2031,1239],{"class":504},[490,2033,578],{"class":500},[490,2035,2036,2038,2040,2042,2044,2046,2048,2050],{"class":492,"line":545},[490,2037,1827],{"class":567},[490,2039,571],{"class":500},[490,2041,710],{"class":504},[490,2043,601],{"class":500},[490,2045,1836],{"class":517},[490,2047,601],{"class":500},[490,2049,1239],{"class":504},[490,2051,578],{"class":500},[490,2053,2054,2056,2058,2060,2062,2064,2066,2068,2070,2072,2074,2076,2078,2080,2082],{"class":492,"line":552},[490,2055,1847],{"class":567},[490,2057,571],{"class":500},[490,2059,501],{"class":500},[490,2061,514],{"class":500},[490,2063,1856],{"class":567},[490,2065,601],{"class":500},[490,2067,571],{"class":500},[490,2069,501],{"class":500},[490,2071,591],{"class":567},[490,2073,571],{"class":500},[490,2075,514],{"class":500},[490,2077,1871],{"class":517},[490,2079,601],{"class":500},[490,2081,508],{"class":500},[490,2083,619],{"class":500},[490,2085,2086,2088,2090,2092,2094],{"class":492,"line":564},[490,2087,735],{"class":567},[490,2089,571],{"class":500},[490,2091,531],{"class":555},[490,2093,742],{"class":504},[490,2095,578],{"class":500},[490,2097,2098,2100,2102,2104,2106,2108,2110,2112,2114,2116,2118,2120,2122,2124,2126,2128,2130,2132,2134],{"class":492,"line":581},[490,2099,1894],{"class":555},[490,2101,571],{"class":500},[490,2103,1092],{"class":500},[490,2105,1902],{"class":1901},[490,2107,471],{"class":500},[490,2109,1907],{"class":1754},[490,2111,501],{"class":500},[490,2113,1912],{"class":504},[490,2115,1038],{"class":500},[490,2117,1917],{"class":504},[490,2119,1038],{"class":500},[490,2121,1548],{"class":504},[490,2123,1780],{"class":500},[490,2125,1638],{"class":504},[490,2127,1038],{"class":500},[490,2129,810],{"class":504},[490,2131,1038],{"class":500},[490,2133,1561],{"class":504},[490,2135,619],{"class":500},[490,2137,2138,2140,2142,2144,2146,2148,2150,2152,2154,2156,2158,2160,2162,2164,2166,2168,2170,2172,2174,2176,2178],{"class":492,"line":622},[490,2139,1940],{"class":555},[490,2141,571],{"class":500},[490,2143,1092],{"class":500},[490,2145,1902],{"class":1901},[490,2147,471],{"class":500},[490,2149,1907],{"class":1754},[490,2151,501],{"class":500},[490,2153,1955],{"class":496},[490,2155,1092],{"class":567},[490,2157,1902],{"class":504},[490,2159,1038],{"class":500},[490,2161,1964],{"class":504},[490,2163,1967],{"class":500},[490,2165,1970],{"class":698},[490,2167,1973],{"class":567},[490,2169,1902],{"class":504},[490,2171,1038],{"class":500},[490,2173,1980],{"class":504},[490,2175,1780],{"class":500},[490,2177,575],{"class":574},[490,2179,619],{"class":500},[490,2181,2182,2184],{"class":492,"line":635},[490,2183,750],{"class":500},[490,2185,2186],{"class":504},"))\n",[480,2188,2190],{"className":482,"code":2189,"filename":197,"language":485,"meta":486,"style":486},"app.use(evlog({\n  include: ['\u002Fapi\u002F**'],\n  drain: createAxiomDrain(),\n  enrich: (ctx) => { ctx.event.region = process.env.FLY_REGION },\n}))\n",[468,2191,2192,2208,2226,2238,2278],{"__ignoreMap":486},[490,2193,2194,2196,2198,2200,2202,2204,2206],{"class":492,"line":493},[490,2195,2002],{"class":504},[490,2197,1038],{"class":500},[490,2199,2007],{"class":555},[490,2201,558],{"class":504},[490,2203,518],{"class":555},[490,2205,558],{"class":504},[490,2207,561],{"class":500},[490,2209,2210,2212,2214,2216,2218,2220,2222,2224],{"class":492,"line":524},[490,2211,1807],{"class":567},[490,2213,571],{"class":500},[490,2215,710],{"class":504},[490,2217,601],{"class":500},[490,2219,1816],{"class":517},[490,2221,601],{"class":500},[490,2223,1239],{"class":504},[490,2225,578],{"class":500},[490,2227,2228,2230,2232,2234,2236],{"class":492,"line":545},[490,2229,735],{"class":567},[490,2231,571],{"class":500},[490,2233,531],{"class":555},[490,2235,742],{"class":504},[490,2237,578],{"class":500},[490,2239,2240,2242,2244,2246,2248,2250,2252,2254,2256,2258,2260,2262,2264,2266,2268,2270,2272,2274,2276],{"class":492,"line":552},[490,2241,1894],{"class":555},[490,2243,571],{"class":500},[490,2245,1092],{"class":500},[490,2247,1902],{"class":1901},[490,2249,471],{"class":500},[490,2251,1907],{"class":1754},[490,2253,501],{"class":500},[490,2255,1912],{"class":504},[490,2257,1038],{"class":500},[490,2259,1917],{"class":504},[490,2261,1038],{"class":500},[490,2263,1548],{"class":504},[490,2265,1780],{"class":500},[490,2267,1638],{"class":504},[490,2269,1038],{"class":500},[490,2271,810],{"class":504},[490,2273,1038],{"class":500},[490,2275,1561],{"class":504},[490,2277,619],{"class":500},[490,2279,2280,2282],{"class":492,"line":564},[490,2281,750],{"class":500},[490,2283,2186],{"class":504},[480,2285,2287],{"className":482,"code":2286,"filename":207,"language":485,"meta":486,"style":486},"await app.register(evlog, {\n  include: ['\u002Fapi\u002F**'],\n  drain: createAxiomDrain(),\n})\n",[468,2288,2289,2309,2327,2339],{"__ignoreMap":486},[490,2290,2291,2294,2297,2299,2302,2305,2307],{"class":492,"line":493},[490,2292,2293],{"class":496},"await",[490,2295,2296],{"class":504}," app",[490,2298,1038],{"class":500},[490,2300,2301],{"class":555},"register",[490,2303,2304],{"class":504},"(evlog",[490,2306,604],{"class":500},[490,2308,1251],{"class":500},[490,2310,2311,2313,2315,2317,2319,2321,2323,2325],{"class":492,"line":524},[490,2312,1807],{"class":567},[490,2314,571],{"class":500},[490,2316,710],{"class":504},[490,2318,601],{"class":500},[490,2320,1816],{"class":517},[490,2322,601],{"class":500},[490,2324,1239],{"class":504},[490,2326,578],{"class":500},[490,2328,2329,2331,2333,2335,2337],{"class":492,"line":545},[490,2330,735],{"class":567},[490,2332,571],{"class":500},[490,2334,531],{"class":555},[490,2336,742],{"class":504},[490,2338,578],{"class":500},[490,2340,2341,2343],{"class":492,"line":552},[490,2342,750],{"class":500},[490,2344,753],{"class":504},[755,2346,2347,2359],{},[758,2348,2349],{},[761,2350,2351,2353,2355,2357],{},[764,2352,766],{},[764,2354,769],{},[764,2356,772],{},[764,2358,775],{},[777,2360,2361,2380,2398,2417,2434,2453],{},[761,2362,2363,2368,2373,2377],{},[782,2364,2365],{},[468,2366,2367],{},"include",[782,2369,2370],{},[468,2371,2372],{},"string[]",[782,2374,2375],{},[468,2376,960],{},[782,2378,2379],{},"Route glob patterns to log. If not set, all routes are logged",[761,2381,2382,2387,2391,2395],{},[782,2383,2384],{},[468,2385,2386],{},"exclude",[782,2388,2389],{},[468,2390,2372],{},[782,2392,2393],{},[468,2394,960],{},[782,2396,2397],{},"Route patterns to exclude. Exclusions take precedence over inclusions",[761,2399,2400,2405,2410,2414],{},[782,2401,2402],{},[468,2403,2404],{},"routes",[782,2406,2407],{},[468,2408,2409],{},"Record\u003Cstring, { service: string }>",[782,2411,2412],{},[468,2413,960],{},[782,2415,2416],{},"Route-specific service name overrides",[761,2418,2419,2423,2427,2431],{},[782,2420,2421],{},[468,2422,997],{},[782,2424,2425],{},[468,2426,1002],{},[782,2428,2429],{},[468,2430,960],{},[782,2432,2433],{},"Drain callback called with every emitted event",[761,2435,2436,2441,2446,2450],{},[782,2437,2438],{},[468,2439,2440],{},"enrich",[782,2442,2443],{},[468,2444,2445],{},"(ctx: EnrichContext) => void",[782,2447,2448],{},[468,2449,960],{},[782,2451,2452],{},"Enrich callback called after emit, before drain",[761,2454,2455,2459,2464,2468],{},[782,2456,2457],{},[468,2458,1085],{},[782,2460,2461],{},[468,2462,2463],{},"(ctx: TailSamplingContext) => void",[782,2465,2466],{},[468,2467,960],{},[782,2469,2470],{},"Custom tail sampling callback",[1678,2472,2473,2476,2477,1030,2480,1030,2483,2486,2487,2489,2490,2492],{"color":669,"icon":13},[454,2474,2475],{},"Nuxt and Nitro"," use module config and Nitro hooks (",[468,2478,2479],{},"evlog:drain",[468,2481,2482],{},"evlog:enrich",[468,2484,2485],{},"evlog:emit:keep",") instead of middleware options. See the ",[870,2488,167],{"href":168}," and ",[870,2491,182],{"href":183}," pages.",[1040,2494,2496],{"id":2495},"middleware-drain-vs-global-drain","Middleware drain vs global drain",[450,2498,2499,2500,2502,2503,2505],{},"When a middleware ",[468,2501,997],{}," is set, it takes precedence over the global drain from ",[468,2504,477],{},". If no middleware drain is set, the global drain is used as fallback, with the benefit of receiving the full enriched event with request context (method, path, headers).",[480,2507,2509],{"className":482,"code":2508,"filename":484,"language":485,"meta":486,"style":486},"import { initLogger } from 'evlog'\nimport { createAxiomDrain } from 'evlog\u002Faxiom'\n\ninitLogger({\n  env: { service: 'my-api' },\n  drain: createAxiomDrain(), \u002F\u002F fallback: used by singleton log API AND middleware (if no middleware drain)\n})\n\napp.use(evlog({\n  \u002F\u002F no drain here - falls back to globalDrain from initLogger, with full request context\n}))\n",[468,2510,2511,2529,2547,2551,2559,2579,2594,2600,2604,2620,2625],{"__ignoreMap":486},[490,2512,2513,2515,2517,2519,2521,2523,2525,2527],{"class":492,"line":493},[490,2514,497],{"class":496},[490,2516,501],{"class":500},[490,2518,505],{"class":504},[490,2520,508],{"class":500},[490,2522,511],{"class":496},[490,2524,514],{"class":500},[490,2526,518],{"class":517},[490,2528,521],{"class":500},[490,2530,2531,2533,2535,2537,2539,2541,2543,2545],{"class":492,"line":524},[490,2532,497],{"class":496},[490,2534,501],{"class":500},[490,2536,531],{"class":504},[490,2538,508],{"class":500},[490,2540,511],{"class":496},[490,2542,514],{"class":500},[490,2544,540],{"class":517},[490,2546,521],{"class":500},[490,2548,2549],{"class":492,"line":545},[490,2550,549],{"emptyLinePlaceholder":548},[490,2552,2553,2555,2557],{"class":492,"line":552},[490,2554,470],{"class":555},[490,2556,558],{"class":504},[490,2558,561],{"class":500},[490,2560,2561,2563,2565,2567,2569,2571,2573,2575,2577],{"class":492,"line":564},[490,2562,584],{"class":567},[490,2564,571],{"class":500},[490,2566,501],{"class":500},[490,2568,591],{"class":567},[490,2570,571],{"class":500},[490,2572,514],{"class":500},[490,2574,598],{"class":517},[490,2576,601],{"class":500},[490,2578,619],{"class":500},[490,2580,2581,2583,2585,2587,2589,2591],{"class":492,"line":581},[490,2582,735],{"class":567},[490,2584,571],{"class":500},[490,2586,531],{"class":555},[490,2588,742],{"class":504},[490,2590,604],{"class":500},[490,2592,2593],{"class":1280}," \u002F\u002F fallback: used by singleton log API AND middleware (if no middleware drain)\n",[490,2595,2596,2598],{"class":492,"line":622},[490,2597,750],{"class":500},[490,2599,753],{"class":504},[490,2601,2602],{"class":492,"line":635},[490,2603,549],{"emptyLinePlaceholder":548},[490,2605,2606,2608,2610,2612,2614,2616,2618],{"class":492,"line":647},[490,2607,2002],{"class":504},[490,2609,1038],{"class":500},[490,2611,2007],{"class":555},[490,2613,558],{"class":504},[490,2615,518],{"class":555},[490,2617,558],{"class":504},[490,2619,561],{"class":500},[490,2621,2622],{"class":492,"line":659},[490,2623,2624],{"class":1280},"  \u002F\u002F no drain here - falls back to globalDrain from initLogger, with full request context\n",[490,2626,2627,2629],{"class":492,"line":676},[490,2628,750],{"class":500},[490,2630,2186],{"class":504},[463,2632,2634],{"id":2633},"framework-specific-options","Framework-Specific Options",[450,2636,2637],{},"Some frameworks have additional options beyond the shared config:",[1040,2639,167],{"id":2640},"nuxt",[450,2642,2643,2644,2646,2647,2649],{},"The Nuxt module accepts all global options and middleware options in ",[468,2645,1203],{}," under the ",[468,2648,518],{}," key, plus:",[755,2651,2652,2664],{},[758,2653,2654],{},[761,2655,2656,2658,2660,2662],{},[764,2657,766],{},[764,2659,769],{},[764,2661,772],{},[764,2663,775],{},[777,2665,2666,2684,2702,2721],{},[761,2667,2668,2673,2677,2681],{},[782,2669,2670],{},[468,2671,2672],{},"console",[782,2674,2675],{},[468,2676,791],{},[782,2678,2679],{},[468,2680,796],{},[782,2682,2683],{},"Enable\u002Fdisable browser console output (client-side only)",[761,2685,2686,2691,2695,2699],{},[782,2687,2688],{},[468,2689,2690],{},"transport.enabled",[782,2692,2693],{},[468,2694,791],{},[782,2696,2697],{},[468,2698,802],{},[782,2700,2701],{},"Send client logs to the server via API endpoint",[761,2703,2704,2709,2713,2718],{},[782,2705,2706],{},[468,2707,2708],{},"transport.endpoint",[782,2710,2711],{},[468,2712,1459],{},[782,2714,2715],{},[468,2716,2717],{},"'\u002Fapi\u002F_evlog\u002Fingest'",[782,2719,2720],{},"Custom transport endpoint",[761,2722,2723,2728,2733,2738],{},[782,2724,2725],{},[468,2726,2727],{},"transport.credentials",[782,2729,2730],{},[468,2731,2732],{},"RequestCredentials",[782,2734,2735],{},[468,2736,2737],{},"'same-origin'",[782,2739,2740,2741,2744],{},"Fetch credentials mode (",[468,2742,2743],{},"'include'"," for cross-origin endpoints)",[450,2746,2747,2748,1038],{},"See the full ",[870,2749,2751],{"href":2750},"\u002Fintegrate\u002Fframeworks\u002Fnuxt#configuration","Nuxt configuration",[1040,2753,182],{"id":2754},"nitro",[450,2756,2757,2758,1030,2760,1030,2762,1030,2764,1030,2766,1030,2768,1030,2770,2772,2773,2775,2776,2779],{},"The Nitro module accepts ",[468,2759,786],{},[468,2761,810],{},[468,2763,828],{},[468,2765,880],{},[468,2767,950],{},[468,2769,2367],{},[468,2771,2386],{},", and ",[468,2774,2404],{}," in ",[468,2777,2778],{},"nitro.config.ts",". Drain and enrichment are done via Nitro hooks.",[450,2781,1411,2782,1038],{},[870,2783,2785],{"href":2784},"\u002Fintegrate\u002Fframeworks\u002Fnitro#drain--enrichers","Nitro drain & enrichers",[2787,2788,2789],"style",{},"html pre.shiki code .s7zQu, html code.shiki .s7zQu{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#89DDFF;--shiki-default-font-style:italic;--shiki-dark:#89DDFF;--shiki-dark-font-style:italic}html pre.shiki code .sMK4o, html code.shiki .sMK4o{--shiki-light:#39ADB5;--shiki-default:#89DDFF;--shiki-dark:#89DDFF}html pre.shiki code .sTEyZ, html code.shiki .sTEyZ{--shiki-light:#90A4AE;--shiki-default:#EEFFFF;--shiki-dark:#BABED8}html pre.shiki code .sfazB, html code.shiki .sfazB{--shiki-light:#91B859;--shiki-default:#C3E88D;--shiki-dark:#C3E88D}html pre.shiki code .s2Zo4, html code.shiki .s2Zo4{--shiki-light:#6182B8;--shiki-default:#82AAFF;--shiki-dark:#82AAFF}html pre.shiki code .swJcz, html code.shiki .swJcz{--shiki-light:#E53935;--shiki-default:#F07178;--shiki-dark:#F07178}html pre.shiki code .sfNiH, html code.shiki .sfNiH{--shiki-light:#FF5370;--shiki-default:#FF9CAC;--shiki-dark:#FF9CAC}html pre.shiki code .sbssI, html code.shiki .sbssI{--shiki-light:#F76D47;--shiki-default:#F78C6C;--shiki-dark:#F78C6C}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .sHwdD, html code.shiki .sHwdD{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#546E7A;--shiki-default-font-style:italic;--shiki-dark:#676E95;--shiki-dark-font-style:italic}html pre.shiki code .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}html pre.shiki code .spNyl, html code.shiki .spNyl{--shiki-light:#9C3EDA;--shiki-default:#C792EA;--shiki-dark:#C792EA}html pre.shiki code .sHdIc, html code.shiki .sHdIc{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#EEFFFF;--shiki-default-font-style:italic;--shiki-dark:#BABED8;--shiki-dark-font-style:italic}",{"title":486,"searchDepth":524,"depth":524,"links":2791},[2792,2800,2803],{"id":465,"depth":524,"text":2793,"children":2794},"Global Options (initLogger)",[2795,2797,2798,2799],{"id":1042,"depth":545,"text":2796},"minLevel vs sampling",{"id":1121,"depth":545,"text":873},{"id":1419,"depth":545,"text":1420},{"id":1570,"depth":545,"text":1571},{"id":1688,"depth":524,"text":1689,"children":2801},[2802],{"id":2495,"depth":545,"text":2496},{"id":2633,"depth":524,"text":2634,"children":2804},[2805,2806],{"id":2640,"depth":545,"text":167},{"id":2754,"depth":545,"text":182},"Complete reference for all evlog configuration options including global logger settings, middleware options, environment context, and framework-specific overrides.","md",[2810,2813],{"label":61,"icon":64,"to":62,"color":2811,"variant":2812},"neutral","subtle",{"label":2814,"icon":282,"to":95,"color":2811,"variant":2812},"Drain Adapters",{},{"icon":422},{"title":419,"description":2807},"_HkpwQbK6ceUYdWF9qsASthXqQT7TnGYvukrc6mvwVY",[2820,2822],{"title":409,"path":410,"stem":411,"description":2821,"icon":412,"children":-1},"Batch events, retry on failure, fan out to multiple destinations, and ship browser logs to your server. The shared pipeline that wraps every drain in production.",{"title":312,"path":424,"stem":425,"description":2823,"icon":315,"children":-1},"evlog adds ~3µs per request. Faster than pino, consola, and winston in most scenarios while emitting richer, more useful events.",1782925723751]