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