[{"data":1,"prerenderedAt":3251},["ShallowReactive",2],{"navigation_docs":3,"-frameworks-nitro":392,"-frameworks-nitro-surround":3246},[4,35,159,201,289,376],{"title":5,"path":6,"stem":7,"children":8,"page":34},"Getting Started","\u002Fgetting-started","1.getting-started",[9,14,19,24,29],{"title":10,"path":11,"stem":12,"icon":13},"Introduction","\u002Fgetting-started\u002Fintroduction","1.getting-started\u002F1.introduction","i-lucide-info",{"title":15,"path":16,"stem":17,"icon":18},"Installation","\u002Fgetting-started\u002Finstallation","1.getting-started\u002F2.installation","i-lucide-download",{"title":20,"path":21,"stem":22,"icon":23},"Quick Start","\u002Fgetting-started\u002Fquick-start","1.getting-started\u002F3.quick-start","i-lucide-zap",{"title":25,"path":26,"stem":27,"icon":28},"Agent Skills","\u002Fgetting-started\u002Fagent-skills","1.getting-started\u002F4.agent-skills","i-lucide-sparkles",{"title":30,"path":31,"stem":32,"icon":33},"vs Other Loggers","\u002Fgetting-started\u002Fvs-other-loggers","1.getting-started\u002F5.vs-other-loggers","i-lucide-scale",false,{"title":36,"path":37,"stem":38,"children":39,"page":34},"Logging","\u002Flogging","2.logging",[40,45,50,55,60,65,70,99,127],{"title":41,"path":42,"stem":43,"icon":44},"Overview","\u002Flogging\u002Foverview","2.logging\u002F0.overview","i-lucide-list",{"title":46,"path":47,"stem":48,"icon":49},"Simple Logging","\u002Flogging\u002Fsimple-logging","2.logging\u002F1.simple-logging","i-lucide-terminal",{"title":51,"path":52,"stem":53,"icon":54},"Wide Events","\u002Flogging\u002Fwide-events","2.logging\u002F2.wide-events","i-lucide-layers",{"title":56,"path":57,"stem":58,"icon":59},"Structured Errors","\u002Flogging\u002Fstructured-errors","2.logging\u002F3.structured-errors","i-lucide-shield-alert",{"title":61,"path":62,"stem":63,"icon":64},"Catalogs","\u002Flogging\u002Fcatalogs","2.logging\u002F4.catalogs","i-lucide-book-open",{"title":66,"path":67,"stem":68,"icon":69},"Client Logging","\u002Flogging\u002Fclient-logging","2.logging\u002F5.client-logging","i-lucide-monitor",{"title":71,"icon":72,"path":73,"stem":74,"children":75,"page":34},"AI SDK","i-simple-icons-vercel","\u002Flogging\u002Fai-sdk","2.logging\u002F6.ai-sdk",[76,79,84,89,94],{"title":41,"path":77,"stem":78,"icon":44},"\u002Flogging\u002Fai-sdk\u002Foverview","2.logging\u002F6.ai-sdk\u002F01.overview",{"title":80,"path":81,"stem":82,"icon":83},"Usage","\u002Flogging\u002Fai-sdk\u002Fusage","2.logging\u002F6.ai-sdk\u002F02.usage","i-lucide-code",{"title":85,"path":86,"stem":87,"icon":88},"Options","\u002Flogging\u002Fai-sdk\u002Foptions","2.logging\u002F6.ai-sdk\u002F03.options","i-lucide-sliders",{"title":90,"path":91,"stem":92,"icon":93},"Metadata","\u002Flogging\u002Fai-sdk\u002Fmetadata","2.logging\u002F6.ai-sdk\u002F04.metadata","i-lucide-database",{"title":95,"path":96,"stem":97,"icon":98},"Telemetry","\u002Flogging\u002Fai-sdk\u002Ftelemetry","2.logging\u002F6.ai-sdk\u002F05.telemetry","i-lucide-activity",{"title":100,"icon":101,"path":102,"stem":103,"children":104,"page":34},"Better Auth","i-simple-icons-betterauth","\u002Flogging\u002Fbetter-auth","2.logging\u002F7.better-auth",[105,108,113,118,122],{"title":41,"path":106,"stem":107,"icon":44},"\u002Flogging\u002Fbetter-auth\u002Foverview","2.logging\u002F7.better-auth\u002F01.overview",{"title":109,"path":110,"stem":111,"icon":112},"Identify User","\u002Flogging\u002Fbetter-auth\u002Fidentify-user","2.logging\u002F7.better-auth\u002F02.identify-user","i-lucide-user-check",{"title":114,"path":115,"stem":116,"icon":117},"Middleware","\u002Flogging\u002Fbetter-auth\u002Fmiddleware","2.logging\u002F7.better-auth\u002F03.middleware","i-lucide-shield",{"title":119,"path":120,"stem":121,"icon":69},"Client Sync","\u002Flogging\u002Fbetter-auth\u002Fclient-sync","2.logging\u002F7.better-auth\u002F04.client-sync",{"title":123,"path":124,"stem":125,"icon":126},"Performance","\u002Flogging\u002Fbetter-auth\u002Fperformance","2.logging\u002F7.better-auth\u002F05.performance","i-lucide-gauge",{"title":128,"icon":129,"path":130,"stem":131,"children":132,"page":34},"Audit Logs","i-lucide-shield-check","\u002Flogging\u002Faudit","2.logging\u002F8.audit",[133,136,141,146,151,155],{"title":41,"path":134,"stem":135,"icon":44},"\u002Flogging\u002Faudit\u002Foverview","2.logging\u002F8.audit\u002F01.overview",{"title":137,"path":138,"stem":139,"icon":140},"Schema","\u002Flogging\u002Faudit\u002Fschema","2.logging\u002F8.audit\u002F02.schema","i-lucide-file-text",{"title":142,"path":143,"stem":144,"icon":145},"Recording","\u002Flogging\u002Faudit\u002Frecording","2.logging\u002F8.audit\u002F03.recording","i-lucide-pen-line",{"title":147,"path":148,"stem":149,"icon":150},"Drains","\u002Flogging\u002Faudit\u002Fpipeline","2.logging\u002F8.audit\u002F04.pipeline","i-lucide-link",{"title":152,"path":153,"stem":154,"icon":129},"Compliance","\u002Flogging\u002Faudit\u002Fcompliance","2.logging\u002F8.audit\u002F05.compliance",{"title":156,"path":157,"stem":158,"icon":64},"Recipes","\u002Flogging\u002Faudit\u002Frecipes","2.logging\u002F8.audit\u002F06.recipes",{"title":160,"path":161,"stem":162,"children":163,"page":34},"Core Concepts","\u002Fcore-concepts","3.core-concepts",[164,169,174,179,184,188,191,196],{"title":165,"path":166,"stem":167,"icon":168},"Lifecycle","\u002Fcore-concepts\u002Flifecycle","3.core-concepts\u002F0.lifecycle","i-lucide-arrow-right-left",{"title":170,"path":171,"stem":172,"icon":173},"Configuration","\u002Fcore-concepts\u002Fconfiguration","3.core-concepts\u002F1.configuration","i-lucide-settings",{"title":175,"path":176,"stem":177,"icon":178},"Sampling","\u002Fcore-concepts\u002Fsampling","3.core-concepts\u002F2.sampling","i-lucide-filter",{"title":180,"path":181,"stem":182,"icon":183},"Typed Fields","\u002Fcore-concepts\u002Ftyped-fields","3.core-concepts\u002F3.typed-fields","i-simple-icons-typescript",{"title":185,"path":186,"stem":187,"icon":129},"Best Practices","\u002Fcore-concepts\u002Fbest-practices","3.core-concepts\u002F4.best-practices",{"title":123,"path":189,"stem":190,"icon":126},"\u002Fcore-concepts\u002Fperformance","3.core-concepts\u002F5.performance",{"title":192,"path":193,"stem":194,"icon":195},"Vite Plugin","\u002Fcore-concepts\u002Fvite-plugin","3.core-concepts\u002F6.vite-plugin","i-custom-vite",{"title":197,"path":198,"stem":199,"icon":200},"Auto-Redaction","\u002Fcore-concepts\u002Fredaction","3.core-concepts\u002F7.redaction","i-lucide-eye-off",{"title":202,"path":203,"stem":204,"children":205,"page":34},"Frameworks","\u002Fframeworks","4.frameworks",[206,210,215,220,225,230,235,240,245,250,255,260,265,270,274,279,284],{"title":41,"path":207,"stem":208,"icon":209},"\u002Fframeworks\u002Foverview","4.frameworks\u002F00.overview","i-lucide-layout-grid",{"title":211,"path":212,"stem":213,"icon":214},"Nuxt","\u002Fframeworks\u002Fnuxt","4.frameworks\u002F01.nuxt","i-simple-icons-nuxtdotjs",{"title":216,"path":217,"stem":218,"icon":219},"Next.js","\u002Fframeworks\u002Fnextjs","4.frameworks\u002F02.nextjs","i-simple-icons-nextdotjs",{"title":221,"path":222,"stem":223,"icon":224},"SvelteKit","\u002Fframeworks\u002Fsveltekit","4.frameworks\u002F03.sveltekit","i-simple-icons-svelte",{"title":226,"path":227,"stem":228,"icon":229},"Nitro","\u002Fframeworks\u002Fnitro","4.frameworks\u002F04.nitro","i-custom-nitro",{"title":231,"path":232,"stem":233,"icon":234},"TanStack Start","\u002Fframeworks\u002Ftanstack-start","4.frameworks\u002F05.tanstack-start","i-custom-tanstack",{"title":236,"path":237,"stem":238,"icon":239},"NestJS","\u002Fframeworks\u002Fnestjs","4.frameworks\u002F06.nestjs","i-simple-icons-nestjs",{"title":241,"path":242,"stem":243,"icon":244},"Express","\u002Fframeworks\u002Fexpress","4.frameworks\u002F07.express","i-simple-icons-express",{"title":246,"path":247,"stem":248,"icon":249},"Hono","\u002Fframeworks\u002Fhono","4.frameworks\u002F08.hono","i-simple-icons-hono",{"title":251,"path":252,"stem":253,"icon":254},"Fastify","\u002Fframeworks\u002Ffastify","4.frameworks\u002F09.fastify","i-simple-icons-fastify",{"title":256,"path":257,"stem":258,"icon":259},"Elysia","\u002Fframeworks\u002Felysia","4.frameworks\u002F10.elysia","i-custom-elysia",{"title":261,"path":262,"stem":263,"icon":264},"React Router","\u002Fframeworks\u002Freact-router","4.frameworks\u002F11.react-router","i-custom-reactrouter",{"title":266,"path":267,"stem":268,"icon":269},"Cloudflare Workers","\u002Fframeworks\u002Fcloudflare-workers","4.frameworks\u002F12.cloudflare-workers","i-simple-icons-cloudflare",{"title":271,"path":272,"stem":273,"icon":183},"Standalone","\u002Fframeworks\u002Fstandalone","4.frameworks\u002F13.standalone",{"title":275,"path":276,"stem":277,"icon":278},"Astro","\u002Fframeworks\u002Fastro","4.frameworks\u002F14.astro","i-simple-icons-astro",{"title":280,"path":281,"stem":282,"icon":283},"AWS Lambda","\u002Fframeworks\u002Faws-lambda","4.frameworks\u002F16.aws-lambda","i-custom-lambda",{"title":285,"path":286,"stem":287,"icon":288},"Custom Integration","\u002Fframeworks\u002Fcustom-integration","4.frameworks\u002F17.custom-integration","i-lucide-puzzle",{"title":290,"path":291,"stem":292,"children":293,"page":34},"Adapters","\u002Fadapters","6.adapters",[294,297,337,352],{"title":41,"path":295,"stem":296,"icon":44},"\u002Fadapters\u002Foverview","6.adapters\u002F01.overview",{"title":298,"path":299,"stem":300,"children":301,"page":34},"Cloud destinations","\u002Fadapters\u002Fcloud","6.adapters\u002F02.cloud",[302,307,312,317,322,327,332],{"title":303,"path":304,"stem":305,"icon":306},"Axiom","\u002Fadapters\u002Fcloud\u002Faxiom","6.adapters\u002F02.cloud\u002F01.axiom","i-custom-axiom",{"title":308,"path":309,"stem":310,"icon":311},"OTLP","\u002Fadapters\u002Fcloud\u002Fotlp","6.adapters\u002F02.cloud\u002F02.otlp","i-simple-icons-opentelemetry",{"title":313,"path":314,"stem":315,"icon":316},"PostHog","\u002Fadapters\u002Fcloud\u002Fposthog","6.adapters\u002F02.cloud\u002F03.posthog","i-simple-icons-posthog",{"title":318,"path":319,"stem":320,"icon":321},"Sentry","\u002Fadapters\u002Fcloud\u002Fsentry","6.adapters\u002F02.cloud\u002F04.sentry","i-simple-icons-sentry",{"title":323,"path":324,"stem":325,"icon":326},"Better Stack","\u002Fadapters\u002Fcloud\u002Fbetter-stack","6.adapters\u002F02.cloud\u002F05.better-stack","i-simple-icons-betterstack",{"title":328,"path":329,"stem":330,"icon":331},"Datadog","\u002Fadapters\u002Fcloud\u002Fdatadog","6.adapters\u002F02.cloud\u002F06.datadog","i-simple-icons-datadog",{"title":333,"path":334,"stem":335,"icon":336},"HyperDX","\u002Fadapters\u002Fcloud\u002Fhyperdx","6.adapters\u002F02.cloud\u002F07.hyperdx","i-custom-hyperdx",{"title":338,"path":339,"stem":340,"children":341,"page":34},"Self-hosted","\u002Fadapters\u002Fself-hosted","6.adapters\u002F03.self-hosted",[342,347],{"title":343,"path":344,"stem":345,"icon":346},"File System","\u002Fadapters\u002Fself-hosted\u002Ffs","6.adapters\u002F03.self-hosted\u002F01.fs","i-lucide-hard-drive",{"title":348,"path":349,"stem":350,"icon":351},"NuxtHub","\u002Fadapters\u002Fself-hosted\u002Fnuxthub","6.adapters\u002F03.self-hosted\u002F02.nuxthub","i-simple-icons-nuxt",{"title":353,"path":354,"stem":355,"children":356,"page":34},"Building blocks","\u002Fadapters\u002Fbuilding-blocks","6.adapters\u002F04.building-blocks",[357,362,367,371],{"title":358,"path":359,"stem":360,"icon":361},"Pipeline","\u002Fadapters\u002Fbuilding-blocks\u002Fpipeline","6.adapters\u002F04.building-blocks\u002F01.pipeline","i-lucide-workflow",{"title":363,"path":364,"stem":365,"icon":366},"HTTP","\u002Fadapters\u002Fbuilding-blocks\u002Fhttp","6.adapters\u002F04.building-blocks\u002F02.http","i-lucide-globe",{"title":368,"path":369,"stem":370,"icon":83},"Custom Adapters","\u002Fadapters\u002Fbuilding-blocks\u002Fcustom","6.adapters\u002F04.building-blocks\u002F03.custom",{"title":372,"path":373,"stem":374,"icon":375},"Toolkit","\u002Fadapters\u002Fbuilding-blocks\u002Ftoolkit","6.adapters\u002F04.building-blocks\u002F04.toolkit","i-lucide-blocks",{"title":377,"path":378,"stem":379,"children":380,"page":34},"Enrichers","\u002Fenrichers","7.enrichers",[381,384,388],{"title":41,"path":382,"stem":383,"icon":28},"\u002Fenrichers\u002Foverview","7.enrichers\u002F1.overview",{"title":385,"path":386,"stem":387,"icon":288},"Built-in","\u002Fenrichers\u002Fbuilt-in","7.enrichers\u002F2.built-in",{"title":389,"path":390,"stem":391,"icon":83},"Custom","\u002Fenrichers\u002Fcustom","7.enrichers\u002F3.custom",{"id":393,"title":226,"body":394,"description":3239,"extension":3240,"links":3241,"meta":3242,"navigation":3243,"path":227,"seo":3244,"stem":228,"__hash__":3245},"docs\u002F4.frameworks\u002F04.nitro.md",{"type":395,"value":396,"toc":3219},"minimark",[397,406,453,457,462,533,537,810,813,819,1291,1294,1353,1381,1385,1403,1765,1781,1784,1804,1808,1823,2205,2218,2222,2225,2229,2464,2476,2480,2639,2648,2650,2654,2657,3012,3015,3019,3026,3169,3176,3180,3186,3215],[398,399,400,401,405],"p",{},"evlog provides modules for both Nitro v3 and Nitro v2 (nitropack). The module hooks into the request lifecycle, creating a request-scoped logger accessible via ",[402,403,404],"code",{},"useLogger(event)",", and emits a wide event when the response completes.",[407,408,411,414,439],"prompt",{":actions":409,"description":410,"icon":229},"[\"copy\",\"cursor\",\"windsurf\"]","Set up evlog in my Nitro app",[398,412,413],{},"Set up evlog in my Nitro app.",[415,416,417,421,424,427,430,433,436],"ul",{},[418,419,420],"li",{},"Install evlog: pnpm add evlog",[418,422,423],{},"Import the evlog module in nitro.config.ts (evlog\u002Fnitro for v2, evlog\u002Fnitro\u002Fv3 for v3)",[418,425,426],{},"Configure env.service with your app name",[418,428,429],{},"Use useLogger(event) in route handlers to build wide events",[418,431,432],{},"Use log.set() to accumulate context throughout the request",[418,434,435],{},"Throw errors with createError({ message, status, why, fix })",[418,437,438],{},"Wide events are auto-emitted when each request completes",[398,440,441,442,448,449],{},"Docs: ",[443,444,445],"a",{"href":445,"rel":446},"https:\u002F\u002Fwww.evlog.dev\u002Fframeworks\u002Fnitro",[447],"nofollow","\nAdapters: ",[443,450,451],{"href":451,"rel":452},"https:\u002F\u002Fwww.evlog.dev\u002Fadapters",[447],[454,455,20],"h2",{"id":456},"quick-start",[458,459,461],"h3",{"id":460},"_1-install","1. Install",[463,464,465,490,504,518],"code-group",{},[466,467,473],"pre",{"className":468,"code":469,"filename":470,"language":471,"meta":472,"style":472},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","pnpm add evlog\n","pnpm","bash","",[402,474,475],{"__ignoreMap":472},[476,477,480,483,487],"span",{"class":478,"line":479},"line",1,[476,481,470],{"class":482},"sBMFI",[476,484,486],{"class":485},"sfazB"," add",[476,488,489],{"class":485}," evlog\n",[466,491,494],{"className":468,"code":492,"filename":493,"language":471,"meta":472,"style":472},"bun add evlog\n","bun",[402,495,496],{"__ignoreMap":472},[476,497,498,500,502],{"class":478,"line":479},[476,499,493],{"class":482},[476,501,486],{"class":485},[476,503,489],{"class":485},[466,505,508],{"className":468,"code":506,"filename":507,"language":471,"meta":472,"style":472},"yarn add evlog\n","yarn",[402,509,510],{"__ignoreMap":472},[476,511,512,514,516],{"class":478,"line":479},[476,513,507],{"class":482},[476,515,486],{"class":485},[476,517,489],{"class":485},[466,519,522],{"className":468,"code":520,"filename":521,"language":471,"meta":472,"style":472},"npm install evlog\n","npm",[402,523,524],{"__ignoreMap":472},[476,525,526,528,531],{"class":478,"line":479},[476,527,521],{"class":482},[476,529,530],{"class":485}," install",[476,532,489],{"class":485},[458,534,536],{"id":535},"_2-add-the-module","2. Add the module",[463,538,539,697],{},[466,540,545],{"className":541,"code":542,"filename":543,"language":544,"meta":472,"style":472},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import { defineConfig } from 'nitro'\nimport evlog from 'evlog\u002Fnitro\u002Fv3'\n\nexport default defineConfig({\n  modules: [\n    evlog({\n      env: { service: 'my-app' },\n    }),\n  ],\n})\n","nitro.config.ts (v3)","typescript",[402,546,547,576,594,601,619,632,642,668,680,688],{"__ignoreMap":472},[476,548,549,553,557,561,564,567,570,573],{"class":478,"line":479},[476,550,552],{"class":551},"s7zQu","import",[476,554,556],{"class":555},"sMK4o"," {",[476,558,560],{"class":559},"sTEyZ"," defineConfig",[476,562,563],{"class":555}," }",[476,565,566],{"class":551}," from",[476,568,569],{"class":555}," '",[476,571,572],{"class":485},"nitro",[476,574,575],{"class":555},"'\n",[476,577,579,581,584,587,589,592],{"class":478,"line":578},2,[476,580,552],{"class":551},[476,582,583],{"class":559}," evlog ",[476,585,586],{"class":551},"from",[476,588,569],{"class":555},[476,590,591],{"class":485},"evlog\u002Fnitro\u002Fv3",[476,593,575],{"class":555},[476,595,597],{"class":478,"line":596},3,[476,598,600],{"emptyLinePlaceholder":599},true,"\n",[476,602,604,607,610,613,616],{"class":478,"line":603},4,[476,605,606],{"class":551},"export",[476,608,609],{"class":551}," default",[476,611,560],{"class":612},"s2Zo4",[476,614,615],{"class":559},"(",[476,617,618],{"class":555},"{\n",[476,620,622,626,629],{"class":478,"line":621},5,[476,623,625],{"class":624},"swJcz","  modules",[476,627,628],{"class":555},":",[476,630,631],{"class":559}," [\n",[476,633,635,638,640],{"class":478,"line":634},6,[476,636,637],{"class":612},"    evlog",[476,639,615],{"class":559},[476,641,618],{"class":555},[476,643,645,648,650,652,655,657,659,662,665],{"class":478,"line":644},7,[476,646,647],{"class":624},"      env",[476,649,628],{"class":555},[476,651,556],{"class":555},[476,653,654],{"class":624}," service",[476,656,628],{"class":555},[476,658,569],{"class":555},[476,660,661],{"class":485},"my-app",[476,663,664],{"class":555},"'",[476,666,667],{"class":555}," },\n",[476,669,671,674,677],{"class":478,"line":670},8,[476,672,673],{"class":555},"    }",[476,675,676],{"class":559},")",[476,678,679],{"class":555},",\n",[476,681,683,686],{"class":478,"line":682},9,[476,684,685],{"class":559},"  ]",[476,687,679],{"class":555},[476,689,691,694],{"class":478,"line":690},10,[476,692,693],{"class":555},"}",[476,695,696],{"class":559},")\n",[466,698,701],{"className":541,"code":699,"filename":700,"language":544,"meta":472,"style":472},"import { defineNitroConfig } from 'nitropack\u002Fconfig'\nimport evlog from 'evlog\u002Fnitro'\n\nexport default defineNitroConfig({\n  modules: [\n    evlog({\n      env: { service: 'my-app' },\n    }),\n  ],\n})\n","nitro.config.ts (v2)",[402,702,703,723,738,742,754,762,770,790,798,804],{"__ignoreMap":472},[476,704,705,707,709,712,714,716,718,721],{"class":478,"line":479},[476,706,552],{"class":551},[476,708,556],{"class":555},[476,710,711],{"class":559}," defineNitroConfig",[476,713,563],{"class":555},[476,715,566],{"class":551},[476,717,569],{"class":555},[476,719,720],{"class":485},"nitropack\u002Fconfig",[476,722,575],{"class":555},[476,724,725,727,729,731,733,736],{"class":478,"line":578},[476,726,552],{"class":551},[476,728,583],{"class":559},[476,730,586],{"class":551},[476,732,569],{"class":555},[476,734,735],{"class":485},"evlog\u002Fnitro",[476,737,575],{"class":555},[476,739,740],{"class":478,"line":596},[476,741,600],{"emptyLinePlaceholder":599},[476,743,744,746,748,750,752],{"class":478,"line":603},[476,745,606],{"class":551},[476,747,609],{"class":551},[476,749,711],{"class":612},[476,751,615],{"class":559},[476,753,618],{"class":555},[476,755,756,758,760],{"class":478,"line":621},[476,757,625],{"class":624},[476,759,628],{"class":555},[476,761,631],{"class":559},[476,763,764,766,768],{"class":478,"line":634},[476,765,637],{"class":612},[476,767,615],{"class":559},[476,769,618],{"class":555},[476,771,772,774,776,778,780,782,784,786,788],{"class":478,"line":644},[476,773,647],{"class":624},[476,775,628],{"class":555},[476,777,556],{"class":555},[476,779,654],{"class":624},[476,781,628],{"class":555},[476,783,569],{"class":555},[476,785,661],{"class":485},[476,787,664],{"class":555},[476,789,667],{"class":555},[476,791,792,794,796],{"class":478,"line":670},[476,793,673],{"class":555},[476,795,676],{"class":559},[476,797,679],{"class":555},[476,799,800,802],{"class":478,"line":682},[476,801,685],{"class":559},[476,803,679],{"class":555},[476,805,806,808],{"class":478,"line":690},[476,807,693],{"class":555},[476,809,696],{"class":559},[454,811,51],{"id":812},"wide-events",[398,814,815,816,818],{},"Build up context progressively throughout a request with ",[402,817,404],{},". evlog emits a single wide event when the request completes.",[463,820,821,1072],{},[466,822,825],{"className":541,"code":823,"filename":824,"language":544,"meta":472,"style":472},"import { defineHandler } from 'nitro\u002Fh3'\nimport { useLogger } from 'evlog\u002Fnitro\u002Fv3'\n\nexport default defineHandler(async (event) => {\n  const log = useLogger(event)\n  const body = await readBody(event)\n\n  log.set({ user: { id: body.userId } })\n  log.set({ cart: { items: body.items.length, total: body.total } })\n\n  return { success: true }\n})\n","routes\u002Fapi\u002Fcheckout.post.ts (v3)",[402,826,827,847,866,870,899,918,939,943,984,1041,1045,1065],{"__ignoreMap":472},[476,828,829,831,833,836,838,840,842,845],{"class":478,"line":479},[476,830,552],{"class":551},[476,832,556],{"class":555},[476,834,835],{"class":559}," defineHandler",[476,837,563],{"class":555},[476,839,566],{"class":551},[476,841,569],{"class":555},[476,843,844],{"class":485},"nitro\u002Fh3",[476,846,575],{"class":555},[476,848,849,851,853,856,858,860,862,864],{"class":478,"line":578},[476,850,552],{"class":551},[476,852,556],{"class":555},[476,854,855],{"class":559}," useLogger",[476,857,563],{"class":555},[476,859,566],{"class":551},[476,861,569],{"class":555},[476,863,591],{"class":485},[476,865,575],{"class":555},[476,867,868],{"class":478,"line":596},[476,869,600],{"emptyLinePlaceholder":599},[476,871,872,874,876,878,880,884,887,891,893,896],{"class":478,"line":603},[476,873,606],{"class":551},[476,875,609],{"class":551},[476,877,835],{"class":612},[476,879,615],{"class":559},[476,881,883],{"class":882},"spNyl","async",[476,885,886],{"class":555}," (",[476,888,890],{"class":889},"sHdIc","event",[476,892,676],{"class":555},[476,894,895],{"class":882}," =>",[476,897,898],{"class":555}," {\n",[476,900,901,904,907,910,912,914,916],{"class":478,"line":621},[476,902,903],{"class":882},"  const",[476,905,906],{"class":559}," log",[476,908,909],{"class":555}," =",[476,911,855],{"class":612},[476,913,615],{"class":624},[476,915,890],{"class":559},[476,917,696],{"class":624},[476,919,920,922,925,927,930,933,935,937],{"class":478,"line":634},[476,921,903],{"class":882},[476,923,924],{"class":559}," body",[476,926,909],{"class":555},[476,928,929],{"class":551}," await",[476,931,932],{"class":612}," readBody",[476,934,615],{"class":624},[476,936,890],{"class":559},[476,938,696],{"class":624},[476,940,941],{"class":478,"line":644},[476,942,600],{"emptyLinePlaceholder":599},[476,944,945,948,951,954,956,959,962,964,966,969,971,973,975,978,980,982],{"class":478,"line":670},[476,946,947],{"class":559},"  log",[476,949,950],{"class":555},".",[476,952,953],{"class":612},"set",[476,955,615],{"class":624},[476,957,958],{"class":555},"{",[476,960,961],{"class":624}," user",[476,963,628],{"class":555},[476,965,556],{"class":555},[476,967,968],{"class":624}," id",[476,970,628],{"class":555},[476,972,924],{"class":559},[476,974,950],{"class":555},[476,976,977],{"class":559},"userId",[476,979,563],{"class":555},[476,981,563],{"class":555},[476,983,696],{"class":624},[476,985,986,988,990,992,994,996,999,1001,1003,1006,1008,1010,1012,1015,1017,1020,1023,1026,1028,1030,1032,1035,1037,1039],{"class":478,"line":682},[476,987,947],{"class":559},[476,989,950],{"class":555},[476,991,953],{"class":612},[476,993,615],{"class":624},[476,995,958],{"class":555},[476,997,998],{"class":624}," cart",[476,1000,628],{"class":555},[476,1002,556],{"class":555},[476,1004,1005],{"class":624}," items",[476,1007,628],{"class":555},[476,1009,924],{"class":559},[476,1011,950],{"class":555},[476,1013,1014],{"class":559},"items",[476,1016,950],{"class":555},[476,1018,1019],{"class":559},"length",[476,1021,1022],{"class":555},",",[476,1024,1025],{"class":624}," total",[476,1027,628],{"class":555},[476,1029,924],{"class":559},[476,1031,950],{"class":555},[476,1033,1034],{"class":559},"total",[476,1036,563],{"class":555},[476,1038,563],{"class":555},[476,1040,696],{"class":624},[476,1042,1043],{"class":478,"line":690},[476,1044,600],{"emptyLinePlaceholder":599},[476,1046,1048,1051,1053,1056,1058,1062],{"class":478,"line":1047},11,[476,1049,1050],{"class":551},"  return",[476,1052,556],{"class":555},[476,1054,1055],{"class":624}," success",[476,1057,628],{"class":555},[476,1059,1061],{"class":1060},"sfNiH"," true",[476,1063,1064],{"class":555}," }\n",[476,1066,1068,1070],{"class":478,"line":1067},12,[476,1069,693],{"class":555},[476,1071,696],{"class":559},[466,1073,1076],{"className":541,"code":1074,"filename":1075,"language":544,"meta":472,"style":472},"import { defineEventHandler, readBody } from 'h3'\nimport { useLogger } from 'evlog\u002Fnitro'\n\nexport default defineEventHandler(async (event) => {\n  const log = useLogger(event)\n  const body = await readBody(event)\n\n  log.set({ user: { id: body.userId } })\n  log.set({ cart: { items: body.items.length, total: body.total } })\n\n  return { success: true }\n})\n","routes\u002Fapi\u002Fcheckout.post.ts (v2)",[402,1077,1078,1101,1119,1123,1145,1161,1179,1183,1217,1267,1271,1285],{"__ignoreMap":472},[476,1079,1080,1082,1084,1087,1089,1091,1093,1095,1097,1099],{"class":478,"line":479},[476,1081,552],{"class":551},[476,1083,556],{"class":555},[476,1085,1086],{"class":559}," defineEventHandler",[476,1088,1022],{"class":555},[476,1090,932],{"class":559},[476,1092,563],{"class":555},[476,1094,566],{"class":551},[476,1096,569],{"class":555},[476,1098,458],{"class":485},[476,1100,575],{"class":555},[476,1102,1103,1105,1107,1109,1111,1113,1115,1117],{"class":478,"line":578},[476,1104,552],{"class":551},[476,1106,556],{"class":555},[476,1108,855],{"class":559},[476,1110,563],{"class":555},[476,1112,566],{"class":551},[476,1114,569],{"class":555},[476,1116,735],{"class":485},[476,1118,575],{"class":555},[476,1120,1121],{"class":478,"line":596},[476,1122,600],{"emptyLinePlaceholder":599},[476,1124,1125,1127,1129,1131,1133,1135,1137,1139,1141,1143],{"class":478,"line":603},[476,1126,606],{"class":551},[476,1128,609],{"class":551},[476,1130,1086],{"class":612},[476,1132,615],{"class":559},[476,1134,883],{"class":882},[476,1136,886],{"class":555},[476,1138,890],{"class":889},[476,1140,676],{"class":555},[476,1142,895],{"class":882},[476,1144,898],{"class":555},[476,1146,1147,1149,1151,1153,1155,1157,1159],{"class":478,"line":621},[476,1148,903],{"class":882},[476,1150,906],{"class":559},[476,1152,909],{"class":555},[476,1154,855],{"class":612},[476,1156,615],{"class":624},[476,1158,890],{"class":559},[476,1160,696],{"class":624},[476,1162,1163,1165,1167,1169,1171,1173,1175,1177],{"class":478,"line":634},[476,1164,903],{"class":882},[476,1166,924],{"class":559},[476,1168,909],{"class":555},[476,1170,929],{"class":551},[476,1172,932],{"class":612},[476,1174,615],{"class":624},[476,1176,890],{"class":559},[476,1178,696],{"class":624},[476,1180,1181],{"class":478,"line":644},[476,1182,600],{"emptyLinePlaceholder":599},[476,1184,1185,1187,1189,1191,1193,1195,1197,1199,1201,1203,1205,1207,1209,1211,1213,1215],{"class":478,"line":670},[476,1186,947],{"class":559},[476,1188,950],{"class":555},[476,1190,953],{"class":612},[476,1192,615],{"class":624},[476,1194,958],{"class":555},[476,1196,961],{"class":624},[476,1198,628],{"class":555},[476,1200,556],{"class":555},[476,1202,968],{"class":624},[476,1204,628],{"class":555},[476,1206,924],{"class":559},[476,1208,950],{"class":555},[476,1210,977],{"class":559},[476,1212,563],{"class":555},[476,1214,563],{"class":555},[476,1216,696],{"class":624},[476,1218,1219,1221,1223,1225,1227,1229,1231,1233,1235,1237,1239,1241,1243,1245,1247,1249,1251,1253,1255,1257,1259,1261,1263,1265],{"class":478,"line":682},[476,1220,947],{"class":559},[476,1222,950],{"class":555},[476,1224,953],{"class":612},[476,1226,615],{"class":624},[476,1228,958],{"class":555},[476,1230,998],{"class":624},[476,1232,628],{"class":555},[476,1234,556],{"class":555},[476,1236,1005],{"class":624},[476,1238,628],{"class":555},[476,1240,924],{"class":559},[476,1242,950],{"class":555},[476,1244,1014],{"class":559},[476,1246,950],{"class":555},[476,1248,1019],{"class":559},[476,1250,1022],{"class":555},[476,1252,1025],{"class":624},[476,1254,628],{"class":555},[476,1256,924],{"class":559},[476,1258,950],{"class":555},[476,1260,1034],{"class":559},[476,1262,563],{"class":555},[476,1264,563],{"class":555},[476,1266,696],{"class":624},[476,1268,1269],{"class":478,"line":690},[476,1270,600],{"emptyLinePlaceholder":599},[476,1272,1273,1275,1277,1279,1281,1283],{"class":478,"line":1047},[476,1274,1050],{"class":551},[476,1276,556],{"class":555},[476,1278,1055],{"class":624},[476,1280,628],{"class":555},[476,1282,1061],{"class":1060},[476,1284,1064],{"class":555},[476,1286,1287,1289],{"class":478,"line":1067},[476,1288,693],{"class":555},[476,1290,696],{"class":559},[398,1292,1293],{},"One request, one log line with all context:",[466,1295,1298],{"className":468,"code":1296,"filename":1297,"language":471,"meta":472,"style":472},"10:23:45 INFO [my-app] POST \u002Fapi\u002Fcheckout 200 in 145ms\n  ├─ user: id=usr_123\n  ├─ cart: items=3 total=14999\n  └─ requestId: a1b2c3d4-...\n","Terminal output",[402,1299,1300,1311,1322,1342],{"__ignoreMap":472},[476,1301,1302,1305,1308],{"class":478,"line":479},[476,1303,1304],{"class":482},"10:23:45",[476,1306,1307],{"class":485}," INFO",[476,1309,1310],{"class":559}," [my-app] POST \u002Fapi\u002Fcheckout 200 in 145ms\n",[476,1312,1313,1316,1319],{"class":478,"line":578},[476,1314,1315],{"class":482},"  ├─",[476,1317,1318],{"class":485}," user:",[476,1320,1321],{"class":485}," id=usr_123\n",[476,1323,1324,1326,1329,1332,1336,1339],{"class":478,"line":596},[476,1325,1315],{"class":482},[476,1327,1328],{"class":485}," cart:",[476,1330,1331],{"class":485}," items=",[476,1333,1335],{"class":1334},"sbssI","3",[476,1337,1338],{"class":485}," total=",[476,1340,1341],{"class":1334},"14999\n",[476,1343,1344,1347,1350],{"class":478,"line":603},[476,1345,1346],{"class":482},"  └─",[476,1348,1349],{"class":485}," requestId:",[476,1351,1352],{"class":485}," a1b2c3d4-...\n",[398,1354,1355,1356,1361,1362,1365,1366,1372,1373,1376,1377,950],{},"Nitro uses ",[1357,1358,1359],"strong",{},[402,1360,404],{}," (event-bound scope), not ",[402,1363,1364],{},"AsyncLocalStorage",", so ",[1357,1367,1368,1371],{},[402,1369,1370],{},"log.fork()"," is not available"," here yet. Post-emit warnings still apply if code calls ",[402,1374,1375],{},"set()"," after the wide event was emitted. See ",[443,1378,1380],{"href":1379},"\u002Flogging\u002Fwide-events#after-emit-sealing-and-background-work","Wide events — After emit",[454,1382,1384],{"id":1383},"error-handling","Error Handling",[398,1386,1387,1390,1391,1394,1395,1398,1399,1402],{},[402,1388,1389],{},"createError"," produces structured errors with ",[402,1392,1393],{},"why",", ",[402,1396,1397],{},"fix",", and ",[402,1400,1401],{},"link"," fields that help both humans and AI agents understand what went wrong.",[463,1404,1405,1583],{},[466,1406,1409],{"className":541,"code":1407,"filename":1408,"language":544,"meta":472,"style":472},"import { defineHandler } from 'nitro\u002Fh3'\nimport { useLogger, createError } from 'evlog\u002Fnitro\u002Fv3'\n\nexport default defineHandler(async (event) => {\n  const log = useLogger(event)\n\n  throw createError({\n    status: 402,\n    message: 'Payment failed',\n    why: 'Card declined by issuer',\n    fix: 'Try a different payment method',\n  })\n})\n","routes\u002Fapi\u002Fpayment.post.ts (v3)",[402,1410,1411,1429,1452,1456,1478,1494,1498,1509,1521,1537,1553,1569,1576],{"__ignoreMap":472},[476,1412,1413,1415,1417,1419,1421,1423,1425,1427],{"class":478,"line":479},[476,1414,552],{"class":551},[476,1416,556],{"class":555},[476,1418,835],{"class":559},[476,1420,563],{"class":555},[476,1422,566],{"class":551},[476,1424,569],{"class":555},[476,1426,844],{"class":485},[476,1428,575],{"class":555},[476,1430,1431,1433,1435,1437,1439,1442,1444,1446,1448,1450],{"class":478,"line":578},[476,1432,552],{"class":551},[476,1434,556],{"class":555},[476,1436,855],{"class":559},[476,1438,1022],{"class":555},[476,1440,1441],{"class":559}," createError",[476,1443,563],{"class":555},[476,1445,566],{"class":551},[476,1447,569],{"class":555},[476,1449,591],{"class":485},[476,1451,575],{"class":555},[476,1453,1454],{"class":478,"line":596},[476,1455,600],{"emptyLinePlaceholder":599},[476,1457,1458,1460,1462,1464,1466,1468,1470,1472,1474,1476],{"class":478,"line":603},[476,1459,606],{"class":551},[476,1461,609],{"class":551},[476,1463,835],{"class":612},[476,1465,615],{"class":559},[476,1467,883],{"class":882},[476,1469,886],{"class":555},[476,1471,890],{"class":889},[476,1473,676],{"class":555},[476,1475,895],{"class":882},[476,1477,898],{"class":555},[476,1479,1480,1482,1484,1486,1488,1490,1492],{"class":478,"line":621},[476,1481,903],{"class":882},[476,1483,906],{"class":559},[476,1485,909],{"class":555},[476,1487,855],{"class":612},[476,1489,615],{"class":624},[476,1491,890],{"class":559},[476,1493,696],{"class":624},[476,1495,1496],{"class":478,"line":634},[476,1497,600],{"emptyLinePlaceholder":599},[476,1499,1500,1503,1505,1507],{"class":478,"line":644},[476,1501,1502],{"class":551},"  throw",[476,1504,1441],{"class":612},[476,1506,615],{"class":624},[476,1508,618],{"class":555},[476,1510,1511,1514,1516,1519],{"class":478,"line":670},[476,1512,1513],{"class":624},"    status",[476,1515,628],{"class":555},[476,1517,1518],{"class":1334}," 402",[476,1520,679],{"class":555},[476,1522,1523,1526,1528,1530,1533,1535],{"class":478,"line":682},[476,1524,1525],{"class":624},"    message",[476,1527,628],{"class":555},[476,1529,569],{"class":555},[476,1531,1532],{"class":485},"Payment failed",[476,1534,664],{"class":555},[476,1536,679],{"class":555},[476,1538,1539,1542,1544,1546,1549,1551],{"class":478,"line":690},[476,1540,1541],{"class":624},"    why",[476,1543,628],{"class":555},[476,1545,569],{"class":555},[476,1547,1548],{"class":485},"Card declined by issuer",[476,1550,664],{"class":555},[476,1552,679],{"class":555},[476,1554,1555,1558,1560,1562,1565,1567],{"class":478,"line":1047},[476,1556,1557],{"class":624},"    fix",[476,1559,628],{"class":555},[476,1561,569],{"class":555},[476,1563,1564],{"class":485},"Try a different payment method",[476,1566,664],{"class":555},[476,1568,679],{"class":555},[476,1570,1571,1574],{"class":478,"line":1067},[476,1572,1573],{"class":555},"  }",[476,1575,696],{"class":624},[476,1577,1579,1581],{"class":478,"line":1578},13,[476,1580,693],{"class":555},[476,1582,696],{"class":559},[466,1584,1587],{"className":541,"code":1585,"filename":1586,"language":544,"meta":472,"style":472},"import { defineEventHandler } from 'h3'\nimport { useLogger } from 'evlog\u002Fnitro'\nimport { createError } from 'evlog'\n\nexport default defineEventHandler(async (event) => {\n  const log = useLogger(event)\n\n  throw createError({\n    status: 402,\n    message: 'Payment failed',\n    why: 'Card declined by issuer',\n    fix: 'Try a different payment method',\n  })\n})\n","routes\u002Fapi\u002Fpayment.post.ts (v2)",[402,1588,1589,1607,1625,1644,1648,1670,1686,1690,1700,1710,1724,1738,1752,1758],{"__ignoreMap":472},[476,1590,1591,1593,1595,1597,1599,1601,1603,1605],{"class":478,"line":479},[476,1592,552],{"class":551},[476,1594,556],{"class":555},[476,1596,1086],{"class":559},[476,1598,563],{"class":555},[476,1600,566],{"class":551},[476,1602,569],{"class":555},[476,1604,458],{"class":485},[476,1606,575],{"class":555},[476,1608,1609,1611,1613,1615,1617,1619,1621,1623],{"class":478,"line":578},[476,1610,552],{"class":551},[476,1612,556],{"class":555},[476,1614,855],{"class":559},[476,1616,563],{"class":555},[476,1618,566],{"class":551},[476,1620,569],{"class":555},[476,1622,735],{"class":485},[476,1624,575],{"class":555},[476,1626,1627,1629,1631,1633,1635,1637,1639,1642],{"class":478,"line":596},[476,1628,552],{"class":551},[476,1630,556],{"class":555},[476,1632,1441],{"class":559},[476,1634,563],{"class":555},[476,1636,566],{"class":551},[476,1638,569],{"class":555},[476,1640,1641],{"class":485},"evlog",[476,1643,575],{"class":555},[476,1645,1646],{"class":478,"line":603},[476,1647,600],{"emptyLinePlaceholder":599},[476,1649,1650,1652,1654,1656,1658,1660,1662,1664,1666,1668],{"class":478,"line":621},[476,1651,606],{"class":551},[476,1653,609],{"class":551},[476,1655,1086],{"class":612},[476,1657,615],{"class":559},[476,1659,883],{"class":882},[476,1661,886],{"class":555},[476,1663,890],{"class":889},[476,1665,676],{"class":555},[476,1667,895],{"class":882},[476,1669,898],{"class":555},[476,1671,1672,1674,1676,1678,1680,1682,1684],{"class":478,"line":634},[476,1673,903],{"class":882},[476,1675,906],{"class":559},[476,1677,909],{"class":555},[476,1679,855],{"class":612},[476,1681,615],{"class":624},[476,1683,890],{"class":559},[476,1685,696],{"class":624},[476,1687,1688],{"class":478,"line":644},[476,1689,600],{"emptyLinePlaceholder":599},[476,1691,1692,1694,1696,1698],{"class":478,"line":670},[476,1693,1502],{"class":551},[476,1695,1441],{"class":612},[476,1697,615],{"class":624},[476,1699,618],{"class":555},[476,1701,1702,1704,1706,1708],{"class":478,"line":682},[476,1703,1513],{"class":624},[476,1705,628],{"class":555},[476,1707,1518],{"class":1334},[476,1709,679],{"class":555},[476,1711,1712,1714,1716,1718,1720,1722],{"class":478,"line":690},[476,1713,1525],{"class":624},[476,1715,628],{"class":555},[476,1717,569],{"class":555},[476,1719,1532],{"class":485},[476,1721,664],{"class":555},[476,1723,679],{"class":555},[476,1725,1726,1728,1730,1732,1734,1736],{"class":478,"line":1047},[476,1727,1541],{"class":624},[476,1729,628],{"class":555},[476,1731,569],{"class":555},[476,1733,1548],{"class":485},[476,1735,664],{"class":555},[476,1737,679],{"class":555},[476,1739,1740,1742,1744,1746,1748,1750],{"class":478,"line":1067},[476,1741,1557],{"class":624},[476,1743,628],{"class":555},[476,1745,569],{"class":555},[476,1747,1564],{"class":485},[476,1749,664],{"class":555},[476,1751,679],{"class":555},[476,1753,1754,1756],{"class":478,"line":1578},[476,1755,1573],{"class":555},[476,1757,696],{"class":624},[476,1759,1761,1763],{"class":478,"line":1760},14,[476,1762,693],{"class":555},[476,1764,696],{"class":559},[1766,1767,1769,1770,1772,1773,1775,1776,1772,1778,1780],"callout",{"color":1768,"icon":13},"info","In Nitro v3, import ",[402,1771,1389],{}," from ",[402,1774,591],{}," - it wraps the Nitro error handler. In Nitro v2, import ",[402,1777,1389],{},[402,1779,1641],{}," directly.",[454,1782,170],{"id":1783},"configuration",[398,1785,1786,1787,1790,1791,1394,1794,1394,1797,1394,1800,1803],{},"See the ",[443,1788,1789],{"href":171},"Configuration reference"," for all available options (",[402,1792,1793],{},"enabled",[402,1795,1796],{},"pretty",[402,1798,1799],{},"silent",[402,1801,1802],{},"sampling",", etc.).",[458,1805,1807],{"id":1806},"route-filtering","Route Filtering",[398,1809,1810,1811,1814,1815,1818,1819,1822],{},"Use ",[402,1812,1813],{},"include"," and ",[402,1816,1817],{},"exclude"," to control which routes are logged, and ",[402,1820,1821],{},"routes"," to assign different service names to different route groups:",[463,1824,1825,2022],{},[466,1826,1828],{"className":541,"code":1827,"filename":543,"language":544,"meta":472,"style":472},"import { defineConfig } from 'nitro'\nimport evlog from 'evlog\u002Fnitro\u002Fv3'\n\nexport default defineConfig({\n  modules: [\n    evlog({\n      include: ['\u002Fapi\u002F**'],\n      exclude: ['\u002Fapi\u002Fhealth'],\n      routes: {\n        '\u002Fapi\u002Fauth\u002F**': { service: 'auth-service' },\n        '\u002Fapi\u002Fpayment\u002F**': { service: 'payment-service' },\n      },\n    })\n  ],\n})\n",[402,1829,1830,1848,1862,1866,1878,1886,1894,1916,1936,1945,1972,1998,2003,2009,2015],{"__ignoreMap":472},[476,1831,1832,1834,1836,1838,1840,1842,1844,1846],{"class":478,"line":479},[476,1833,552],{"class":551},[476,1835,556],{"class":555},[476,1837,560],{"class":559},[476,1839,563],{"class":555},[476,1841,566],{"class":551},[476,1843,569],{"class":555},[476,1845,572],{"class":485},[476,1847,575],{"class":555},[476,1849,1850,1852,1854,1856,1858,1860],{"class":478,"line":578},[476,1851,552],{"class":551},[476,1853,583],{"class":559},[476,1855,586],{"class":551},[476,1857,569],{"class":555},[476,1859,591],{"class":485},[476,1861,575],{"class":555},[476,1863,1864],{"class":478,"line":596},[476,1865,600],{"emptyLinePlaceholder":599},[476,1867,1868,1870,1872,1874,1876],{"class":478,"line":603},[476,1869,606],{"class":551},[476,1871,609],{"class":551},[476,1873,560],{"class":612},[476,1875,615],{"class":559},[476,1877,618],{"class":555},[476,1879,1880,1882,1884],{"class":478,"line":621},[476,1881,625],{"class":624},[476,1883,628],{"class":555},[476,1885,631],{"class":559},[476,1887,1888,1890,1892],{"class":478,"line":634},[476,1889,637],{"class":612},[476,1891,615],{"class":559},[476,1893,618],{"class":555},[476,1895,1896,1899,1901,1904,1906,1909,1911,1914],{"class":478,"line":644},[476,1897,1898],{"class":624},"      include",[476,1900,628],{"class":555},[476,1902,1903],{"class":559}," [",[476,1905,664],{"class":555},[476,1907,1908],{"class":485},"\u002Fapi\u002F**",[476,1910,664],{"class":555},[476,1912,1913],{"class":559},"]",[476,1915,679],{"class":555},[476,1917,1918,1921,1923,1925,1927,1930,1932,1934],{"class":478,"line":670},[476,1919,1920],{"class":624},"      exclude",[476,1922,628],{"class":555},[476,1924,1903],{"class":559},[476,1926,664],{"class":555},[476,1928,1929],{"class":485},"\u002Fapi\u002Fhealth",[476,1931,664],{"class":555},[476,1933,1913],{"class":559},[476,1935,679],{"class":555},[476,1937,1938,1941,1943],{"class":478,"line":682},[476,1939,1940],{"class":624},"      routes",[476,1942,628],{"class":555},[476,1944,898],{"class":555},[476,1946,1947,1950,1953,1955,1957,1959,1961,1963,1965,1968,1970],{"class":478,"line":690},[476,1948,1949],{"class":555},"        '",[476,1951,1952],{"class":624},"\u002Fapi\u002Fauth\u002F**",[476,1954,664],{"class":555},[476,1956,628],{"class":555},[476,1958,556],{"class":555},[476,1960,654],{"class":624},[476,1962,628],{"class":555},[476,1964,569],{"class":555},[476,1966,1967],{"class":485},"auth-service",[476,1969,664],{"class":555},[476,1971,667],{"class":555},[476,1973,1974,1976,1979,1981,1983,1985,1987,1989,1991,1994,1996],{"class":478,"line":1047},[476,1975,1949],{"class":555},[476,1977,1978],{"class":624},"\u002Fapi\u002Fpayment\u002F**",[476,1980,664],{"class":555},[476,1982,628],{"class":555},[476,1984,556],{"class":555},[476,1986,654],{"class":624},[476,1988,628],{"class":555},[476,1990,569],{"class":555},[476,1992,1993],{"class":485},"payment-service",[476,1995,664],{"class":555},[476,1997,667],{"class":555},[476,1999,2000],{"class":478,"line":1067},[476,2001,2002],{"class":555},"      },\n",[476,2004,2005,2007],{"class":478,"line":1578},[476,2006,673],{"class":555},[476,2008,696],{"class":559},[476,2010,2011,2013],{"class":478,"line":1760},[476,2012,685],{"class":559},[476,2014,679],{"class":555},[476,2016,2018,2020],{"class":478,"line":2017},15,[476,2019,693],{"class":555},[476,2021,696],{"class":559},[466,2023,2025],{"className":541,"code":2024,"filename":700,"language":544,"meta":472,"style":472},"import { defineNitroConfig } from 'nitropack\u002Fconfig'\nimport evlog from 'evlog\u002Fnitro'\n\nexport default defineNitroConfig({\n  modules: [\n    evlog({\n      include: ['\u002Fapi\u002F**'],\n      exclude: ['\u002Fapi\u002Fhealth'],\n      routes: {\n        '\u002Fapi\u002Fauth\u002F**': { service: 'auth-service' },\n        '\u002Fapi\u002Fpayment\u002F**': { service: 'payment-service' },\n      },\n    })\n  ],\n})\n",[402,2026,2027,2045,2059,2063,2075,2083,2091,2109,2127,2135,2159,2183,2187,2193,2199],{"__ignoreMap":472},[476,2028,2029,2031,2033,2035,2037,2039,2041,2043],{"class":478,"line":479},[476,2030,552],{"class":551},[476,2032,556],{"class":555},[476,2034,711],{"class":559},[476,2036,563],{"class":555},[476,2038,566],{"class":551},[476,2040,569],{"class":555},[476,2042,720],{"class":485},[476,2044,575],{"class":555},[476,2046,2047,2049,2051,2053,2055,2057],{"class":478,"line":578},[476,2048,552],{"class":551},[476,2050,583],{"class":559},[476,2052,586],{"class":551},[476,2054,569],{"class":555},[476,2056,735],{"class":485},[476,2058,575],{"class":555},[476,2060,2061],{"class":478,"line":596},[476,2062,600],{"emptyLinePlaceholder":599},[476,2064,2065,2067,2069,2071,2073],{"class":478,"line":603},[476,2066,606],{"class":551},[476,2068,609],{"class":551},[476,2070,711],{"class":612},[476,2072,615],{"class":559},[476,2074,618],{"class":555},[476,2076,2077,2079,2081],{"class":478,"line":621},[476,2078,625],{"class":624},[476,2080,628],{"class":555},[476,2082,631],{"class":559},[476,2084,2085,2087,2089],{"class":478,"line":634},[476,2086,637],{"class":612},[476,2088,615],{"class":559},[476,2090,618],{"class":555},[476,2092,2093,2095,2097,2099,2101,2103,2105,2107],{"class":478,"line":644},[476,2094,1898],{"class":624},[476,2096,628],{"class":555},[476,2098,1903],{"class":559},[476,2100,664],{"class":555},[476,2102,1908],{"class":485},[476,2104,664],{"class":555},[476,2106,1913],{"class":559},[476,2108,679],{"class":555},[476,2110,2111,2113,2115,2117,2119,2121,2123,2125],{"class":478,"line":670},[476,2112,1920],{"class":624},[476,2114,628],{"class":555},[476,2116,1903],{"class":559},[476,2118,664],{"class":555},[476,2120,1929],{"class":485},[476,2122,664],{"class":555},[476,2124,1913],{"class":559},[476,2126,679],{"class":555},[476,2128,2129,2131,2133],{"class":478,"line":682},[476,2130,1940],{"class":624},[476,2132,628],{"class":555},[476,2134,898],{"class":555},[476,2136,2137,2139,2141,2143,2145,2147,2149,2151,2153,2155,2157],{"class":478,"line":690},[476,2138,1949],{"class":555},[476,2140,1952],{"class":624},[476,2142,664],{"class":555},[476,2144,628],{"class":555},[476,2146,556],{"class":555},[476,2148,654],{"class":624},[476,2150,628],{"class":555},[476,2152,569],{"class":555},[476,2154,1967],{"class":485},[476,2156,664],{"class":555},[476,2158,667],{"class":555},[476,2160,2161,2163,2165,2167,2169,2171,2173,2175,2177,2179,2181],{"class":478,"line":1047},[476,2162,1949],{"class":555},[476,2164,1978],{"class":624},[476,2166,664],{"class":555},[476,2168,628],{"class":555},[476,2170,556],{"class":555},[476,2172,654],{"class":624},[476,2174,628],{"class":555},[476,2176,569],{"class":555},[476,2178,1993],{"class":485},[476,2180,664],{"class":555},[476,2182,667],{"class":555},[476,2184,2185],{"class":478,"line":1067},[476,2186,2002],{"class":555},[476,2188,2189,2191],{"class":478,"line":1578},[476,2190,673],{"class":555},[476,2192,696],{"class":559},[476,2194,2195,2197],{"class":478,"line":1760},[476,2196,685],{"class":559},[476,2198,679],{"class":555},[476,2200,2201,2203],{"class":478,"line":2017},[476,2202,693],{"class":555},[476,2204,696],{"class":559},[1766,2206,2209,2212,2213,1814,2215,2217],{"color":2207,"icon":2208},"warning","i-lucide-alert-triangle",[1357,2210,2211],{},"Exclusions take precedence."," If a path matches both ",[402,2214,1813],{},[402,2216,1817],{},", it will be excluded.",[454,2219,2221],{"id":2220},"drain-enrichers","Drain & Enrichers",[398,2223,2224],{},"Use Nitro plugin hooks to send logs to external services and enrich them with additional context.",[458,2226,2228],{"id":2227},"drain-plugin","Drain Plugin",[466,2230,2233],{"className":541,"code":2231,"filename":2232,"language":544,"meta":472,"style":472},"import type { DrainContext } from 'evlog'\nimport { createAxiomDrain } from 'evlog\u002Faxiom'\nimport { createDrainPipeline } from 'evlog\u002Fpipeline'\n\nconst pipeline = createDrainPipeline\u003CDrainContext>({\n  batch: { size: 50, intervalMs: 5000 },\n  retry: { maxAttempts: 3 },\n})\nconst drain = pipeline(createAxiomDrain())\n\nexport default defineNitroPlugin((nitroApp) => {\n  nitroApp.hooks.hook('evlog:drain', drain)\n})\n","server\u002Fplugins\u002Fevlog-drain.ts",[402,2234,2235,2257,2277,2297,2301,2327,2356,2375,2381,2401,2405,2427,2458],{"__ignoreMap":472},[476,2236,2237,2239,2242,2244,2247,2249,2251,2253,2255],{"class":478,"line":479},[476,2238,552],{"class":551},[476,2240,2241],{"class":551}," type",[476,2243,556],{"class":555},[476,2245,2246],{"class":559}," DrainContext",[476,2248,563],{"class":555},[476,2250,566],{"class":551},[476,2252,569],{"class":555},[476,2254,1641],{"class":485},[476,2256,575],{"class":555},[476,2258,2259,2261,2263,2266,2268,2270,2272,2275],{"class":478,"line":578},[476,2260,552],{"class":551},[476,2262,556],{"class":555},[476,2264,2265],{"class":559}," createAxiomDrain",[476,2267,563],{"class":555},[476,2269,566],{"class":551},[476,2271,569],{"class":555},[476,2273,2274],{"class":485},"evlog\u002Faxiom",[476,2276,575],{"class":555},[476,2278,2279,2281,2283,2286,2288,2290,2292,2295],{"class":478,"line":596},[476,2280,552],{"class":551},[476,2282,556],{"class":555},[476,2284,2285],{"class":559}," createDrainPipeline",[476,2287,563],{"class":555},[476,2289,566],{"class":551},[476,2291,569],{"class":555},[476,2293,2294],{"class":485},"evlog\u002Fpipeline",[476,2296,575],{"class":555},[476,2298,2299],{"class":478,"line":603},[476,2300,600],{"emptyLinePlaceholder":599},[476,2302,2303,2306,2309,2312,2314,2317,2320,2323,2325],{"class":478,"line":621},[476,2304,2305],{"class":882},"const",[476,2307,2308],{"class":559}," pipeline ",[476,2310,2311],{"class":555},"=",[476,2313,2285],{"class":612},[476,2315,2316],{"class":555},"\u003C",[476,2318,2319],{"class":482},"DrainContext",[476,2321,2322],{"class":555},">",[476,2324,615],{"class":559},[476,2326,618],{"class":555},[476,2328,2329,2332,2334,2336,2339,2341,2344,2346,2349,2351,2354],{"class":478,"line":634},[476,2330,2331],{"class":624},"  batch",[476,2333,628],{"class":555},[476,2335,556],{"class":555},[476,2337,2338],{"class":624}," size",[476,2340,628],{"class":555},[476,2342,2343],{"class":1334}," 50",[476,2345,1022],{"class":555},[476,2347,2348],{"class":624}," intervalMs",[476,2350,628],{"class":555},[476,2352,2353],{"class":1334}," 5000",[476,2355,667],{"class":555},[476,2357,2358,2361,2363,2365,2368,2370,2373],{"class":478,"line":644},[476,2359,2360],{"class":624},"  retry",[476,2362,628],{"class":555},[476,2364,556],{"class":555},[476,2366,2367],{"class":624}," maxAttempts",[476,2369,628],{"class":555},[476,2371,2372],{"class":1334}," 3",[476,2374,667],{"class":555},[476,2376,2377,2379],{"class":478,"line":670},[476,2378,693],{"class":555},[476,2380,696],{"class":559},[476,2382,2383,2385,2388,2390,2393,2395,2398],{"class":478,"line":682},[476,2384,2305],{"class":882},[476,2386,2387],{"class":559}," drain ",[476,2389,2311],{"class":555},[476,2391,2392],{"class":612}," pipeline",[476,2394,615],{"class":559},[476,2396,2397],{"class":612},"createAxiomDrain",[476,2399,2400],{"class":559},"())\n",[476,2402,2403],{"class":478,"line":690},[476,2404,600],{"emptyLinePlaceholder":599},[476,2406,2407,2409,2411,2414,2416,2418,2421,2423,2425],{"class":478,"line":1047},[476,2408,606],{"class":551},[476,2410,609],{"class":551},[476,2412,2413],{"class":612}," defineNitroPlugin",[476,2415,615],{"class":559},[476,2417,615],{"class":555},[476,2419,2420],{"class":889},"nitroApp",[476,2422,676],{"class":555},[476,2424,895],{"class":882},[476,2426,898],{"class":555},[476,2428,2429,2432,2434,2437,2439,2442,2444,2446,2449,2451,2453,2456],{"class":478,"line":1067},[476,2430,2431],{"class":559},"  nitroApp",[476,2433,950],{"class":555},[476,2435,2436],{"class":559},"hooks",[476,2438,950],{"class":555},[476,2440,2441],{"class":612},"hook",[476,2443,615],{"class":624},[476,2445,664],{"class":555},[476,2447,2448],{"class":485},"evlog:drain",[476,2450,664],{"class":555},[476,2452,1022],{"class":555},[476,2454,2455],{"class":559}," drain",[476,2457,696],{"class":624},[476,2459,2460,2462],{"class":478,"line":1578},[476,2461,693],{"class":555},[476,2463,696],{"class":559},[1766,2465,2466,2467,1772,2470,2472,2473,950],{"color":1768,"icon":13},"For Nitro v3 standalone, use ",[402,2468,2469],{},"definePlugin",[402,2471,572],{}," instead of ",[402,2474,2475],{},"defineNitroPlugin",[458,2477,2479],{"id":2478},"enricher-plugin","Enricher Plugin",[466,2481,2484],{"className":541,"code":2482,"filename":2483,"language":544,"meta":472,"style":472},"import { createUserAgentEnricher, createGeoEnricher } from 'evlog\u002Fenrichers'\n\nconst enrichers = [createUserAgentEnricher(), createGeoEnricher()]\n\nexport default defineNitroPlugin((nitroApp) => {\n  nitroApp.hooks.hook('evlog:enrich', (ctx) => {\n    for (const enricher of enrichers) enricher(ctx)\n  })\n})\n","server\u002Fplugins\u002Fevlog-enrich.ts",[402,2485,2486,2511,2515,2539,2543,2563,2597,2627,2633],{"__ignoreMap":472},[476,2487,2488,2490,2492,2495,2497,2500,2502,2504,2506,2509],{"class":478,"line":479},[476,2489,552],{"class":551},[476,2491,556],{"class":555},[476,2493,2494],{"class":559}," createUserAgentEnricher",[476,2496,1022],{"class":555},[476,2498,2499],{"class":559}," createGeoEnricher",[476,2501,563],{"class":555},[476,2503,566],{"class":551},[476,2505,569],{"class":555},[476,2507,2508],{"class":485},"evlog\u002Fenrichers",[476,2510,575],{"class":555},[476,2512,2513],{"class":478,"line":578},[476,2514,600],{"emptyLinePlaceholder":599},[476,2516,2517,2519,2522,2524,2526,2529,2532,2534,2536],{"class":478,"line":596},[476,2518,2305],{"class":882},[476,2520,2521],{"class":559}," enrichers ",[476,2523,2311],{"class":555},[476,2525,1903],{"class":559},[476,2527,2528],{"class":612},"createUserAgentEnricher",[476,2530,2531],{"class":559},"()",[476,2533,1022],{"class":555},[476,2535,2499],{"class":612},[476,2537,2538],{"class":559},"()]\n",[476,2540,2541],{"class":478,"line":603},[476,2542,600],{"emptyLinePlaceholder":599},[476,2544,2545,2547,2549,2551,2553,2555,2557,2559,2561],{"class":478,"line":621},[476,2546,606],{"class":551},[476,2548,609],{"class":551},[476,2550,2413],{"class":612},[476,2552,615],{"class":559},[476,2554,615],{"class":555},[476,2556,2420],{"class":889},[476,2558,676],{"class":555},[476,2560,895],{"class":882},[476,2562,898],{"class":555},[476,2564,2565,2567,2569,2571,2573,2575,2577,2579,2582,2584,2586,2588,2591,2593,2595],{"class":478,"line":634},[476,2566,2431],{"class":559},[476,2568,950],{"class":555},[476,2570,2436],{"class":559},[476,2572,950],{"class":555},[476,2574,2441],{"class":612},[476,2576,615],{"class":624},[476,2578,664],{"class":555},[476,2580,2581],{"class":485},"evlog:enrich",[476,2583,664],{"class":555},[476,2585,1022],{"class":555},[476,2587,886],{"class":555},[476,2589,2590],{"class":889},"ctx",[476,2592,676],{"class":555},[476,2594,895],{"class":882},[476,2596,898],{"class":555},[476,2598,2599,2602,2604,2606,2609,2612,2615,2618,2621,2623,2625],{"class":478,"line":644},[476,2600,2601],{"class":551},"    for",[476,2603,886],{"class":624},[476,2605,2305],{"class":882},[476,2607,2608],{"class":559}," enricher",[476,2610,2611],{"class":555}," of",[476,2613,2614],{"class":559}," enrichers",[476,2616,2617],{"class":624},") ",[476,2619,2620],{"class":612},"enricher",[476,2622,615],{"class":624},[476,2624,2590],{"class":559},[476,2626,696],{"class":624},[476,2628,2629,2631],{"class":478,"line":670},[476,2630,1573],{"class":555},[476,2632,696],{"class":624},[476,2634,2635,2637],{"class":478,"line":682},[476,2636,693],{"class":555},[476,2638,696],{"class":559},[1766,2640,1786,2643,1814,2645,2647],{"color":2641,"icon":2642},"neutral","i-lucide-arrow-right",[443,2644,290],{"href":295},[443,2646,377],{"href":382}," docs for the full list of available drains and enrichers.",[454,2649,175],{"id":1802},[458,2651,2653],{"id":2652},"head-sampling","Head Sampling",[398,2655,2656],{},"Randomly keep a percentage of logs per level. Runs before the request completes.",[463,2658,2659,2843],{},[466,2660,2662],{"className":541,"code":2661,"filename":543,"language":544,"meta":472,"style":472},"import { defineConfig } from 'nitro'\nimport evlog from 'evlog\u002Fnitro\u002Fv3'\n\nexport default defineConfig({\n  modules: [\n    evlog({\n      sampling: {\n        rates: { info: 10, warn: 50, debug: 5 },\n        keep: [\n          { duration: 1000 },\n          { status: 400 },\n        ],\n      },\n    })\n  ],\n})\n",[402,2663,2664,2682,2696,2700,2712,2720,2728,2737,2775,2784,2799,2813,2820,2824,2830,2836],{"__ignoreMap":472},[476,2665,2666,2668,2670,2672,2674,2676,2678,2680],{"class":478,"line":479},[476,2667,552],{"class":551},[476,2669,556],{"class":555},[476,2671,560],{"class":559},[476,2673,563],{"class":555},[476,2675,566],{"class":551},[476,2677,569],{"class":555},[476,2679,572],{"class":485},[476,2681,575],{"class":555},[476,2683,2684,2686,2688,2690,2692,2694],{"class":478,"line":578},[476,2685,552],{"class":551},[476,2687,583],{"class":559},[476,2689,586],{"class":551},[476,2691,569],{"class":555},[476,2693,591],{"class":485},[476,2695,575],{"class":555},[476,2697,2698],{"class":478,"line":596},[476,2699,600],{"emptyLinePlaceholder":599},[476,2701,2702,2704,2706,2708,2710],{"class":478,"line":603},[476,2703,606],{"class":551},[476,2705,609],{"class":551},[476,2707,560],{"class":612},[476,2709,615],{"class":559},[476,2711,618],{"class":555},[476,2713,2714,2716,2718],{"class":478,"line":621},[476,2715,625],{"class":624},[476,2717,628],{"class":555},[476,2719,631],{"class":559},[476,2721,2722,2724,2726],{"class":478,"line":634},[476,2723,637],{"class":612},[476,2725,615],{"class":559},[476,2727,618],{"class":555},[476,2729,2730,2733,2735],{"class":478,"line":644},[476,2731,2732],{"class":624},"      sampling",[476,2734,628],{"class":555},[476,2736,898],{"class":555},[476,2738,2739,2742,2744,2746,2749,2751,2754,2756,2759,2761,2763,2765,2768,2770,2773],{"class":478,"line":670},[476,2740,2741],{"class":624},"        rates",[476,2743,628],{"class":555},[476,2745,556],{"class":555},[476,2747,2748],{"class":624}," info",[476,2750,628],{"class":555},[476,2752,2753],{"class":1334}," 10",[476,2755,1022],{"class":555},[476,2757,2758],{"class":624}," warn",[476,2760,628],{"class":555},[476,2762,2343],{"class":1334},[476,2764,1022],{"class":555},[476,2766,2767],{"class":624}," debug",[476,2769,628],{"class":555},[476,2771,2772],{"class":1334}," 5",[476,2774,667],{"class":555},[476,2776,2777,2780,2782],{"class":478,"line":682},[476,2778,2779],{"class":624},"        keep",[476,2781,628],{"class":555},[476,2783,631],{"class":559},[476,2785,2786,2789,2792,2794,2797],{"class":478,"line":690},[476,2787,2788],{"class":555},"          {",[476,2790,2791],{"class":624}," duration",[476,2793,628],{"class":555},[476,2795,2796],{"class":1334}," 1000",[476,2798,667],{"class":555},[476,2800,2801,2803,2806,2808,2811],{"class":478,"line":1047},[476,2802,2788],{"class":555},[476,2804,2805],{"class":624}," status",[476,2807,628],{"class":555},[476,2809,2810],{"class":1334}," 400",[476,2812,667],{"class":555},[476,2814,2815,2818],{"class":478,"line":1067},[476,2816,2817],{"class":559},"        ]",[476,2819,679],{"class":555},[476,2821,2822],{"class":478,"line":1578},[476,2823,2002],{"class":555},[476,2825,2826,2828],{"class":478,"line":1760},[476,2827,673],{"class":555},[476,2829,696],{"class":559},[476,2831,2832,2834],{"class":478,"line":2017},[476,2833,685],{"class":559},[476,2835,679],{"class":555},[476,2837,2839,2841],{"class":478,"line":2838},16,[476,2840,693],{"class":555},[476,2842,696],{"class":559},[466,2844,2846],{"className":541,"code":2845,"filename":700,"language":544,"meta":472,"style":472},"import { defineNitroConfig } from 'nitropack\u002Fconfig'\nimport evlog from 'evlog\u002Fnitro'\n\nexport default defineNitroConfig({\n  modules: [\n    evlog({\n      sampling: {\n        rates: { info: 10, warn: 50, debug: 5 },\n        keep: [\n          { duration: 1000 },\n          { status: 400 },\n        ],\n      },\n    })\n  ],\n})\n",[402,2847,2848,2866,2880,2884,2896,2904,2912,2920,2952,2960,2972,2984,2990,2994,3000,3006],{"__ignoreMap":472},[476,2849,2850,2852,2854,2856,2858,2860,2862,2864],{"class":478,"line":479},[476,2851,552],{"class":551},[476,2853,556],{"class":555},[476,2855,711],{"class":559},[476,2857,563],{"class":555},[476,2859,566],{"class":551},[476,2861,569],{"class":555},[476,2863,720],{"class":485},[476,2865,575],{"class":555},[476,2867,2868,2870,2872,2874,2876,2878],{"class":478,"line":578},[476,2869,552],{"class":551},[476,2871,583],{"class":559},[476,2873,586],{"class":551},[476,2875,569],{"class":555},[476,2877,735],{"class":485},[476,2879,575],{"class":555},[476,2881,2882],{"class":478,"line":596},[476,2883,600],{"emptyLinePlaceholder":599},[476,2885,2886,2888,2890,2892,2894],{"class":478,"line":603},[476,2887,606],{"class":551},[476,2889,609],{"class":551},[476,2891,711],{"class":612},[476,2893,615],{"class":559},[476,2895,618],{"class":555},[476,2897,2898,2900,2902],{"class":478,"line":621},[476,2899,625],{"class":624},[476,2901,628],{"class":555},[476,2903,631],{"class":559},[476,2905,2906,2908,2910],{"class":478,"line":634},[476,2907,637],{"class":612},[476,2909,615],{"class":559},[476,2911,618],{"class":555},[476,2913,2914,2916,2918],{"class":478,"line":644},[476,2915,2732],{"class":624},[476,2917,628],{"class":555},[476,2919,898],{"class":555},[476,2921,2922,2924,2926,2928,2930,2932,2934,2936,2938,2940,2942,2944,2946,2948,2950],{"class":478,"line":670},[476,2923,2741],{"class":624},[476,2925,628],{"class":555},[476,2927,556],{"class":555},[476,2929,2748],{"class":624},[476,2931,628],{"class":555},[476,2933,2753],{"class":1334},[476,2935,1022],{"class":555},[476,2937,2758],{"class":624},[476,2939,628],{"class":555},[476,2941,2343],{"class":1334},[476,2943,1022],{"class":555},[476,2945,2767],{"class":624},[476,2947,628],{"class":555},[476,2949,2772],{"class":1334},[476,2951,667],{"class":555},[476,2953,2954,2956,2958],{"class":478,"line":682},[476,2955,2779],{"class":624},[476,2957,628],{"class":555},[476,2959,631],{"class":559},[476,2961,2962,2964,2966,2968,2970],{"class":478,"line":690},[476,2963,2788],{"class":555},[476,2965,2791],{"class":624},[476,2967,628],{"class":555},[476,2969,2796],{"class":1334},[476,2971,667],{"class":555},[476,2973,2974,2976,2978,2980,2982],{"class":478,"line":1047},[476,2975,2788],{"class":555},[476,2977,2805],{"class":624},[476,2979,628],{"class":555},[476,2981,2810],{"class":1334},[476,2983,667],{"class":555},[476,2985,2986,2988],{"class":478,"line":1067},[476,2987,2817],{"class":559},[476,2989,679],{"class":555},[476,2991,2992],{"class":478,"line":1578},[476,2993,2002],{"class":555},[476,2995,2996,2998],{"class":478,"line":1760},[476,2997,673],{"class":555},[476,2999,696],{"class":559},[476,3001,3002,3004],{"class":478,"line":2017},[476,3003,685],{"class":559},[476,3005,679],{"class":555},[476,3007,3008,3010],{"class":478,"line":2838},[476,3009,693],{"class":555},[476,3011,696],{"class":559},[398,3013,3014],{},"Each level is a percentage from 0 to 100. Levels you don't configure default to 100% (keep everything).",[458,3016,3018],{"id":3017},"custom-tail-sampling","Custom Tail Sampling",[398,3020,3021,3022,3025],{},"For conditions beyond status, duration, and path, use the ",[402,3023,3024],{},"evlog:emit:keep"," hook:",[466,3027,3030],{"className":541,"code":3028,"filename":3029,"language":544,"meta":472,"style":472},"export default defineNitroPlugin((nitroApp) => {\n  nitroApp.hooks.hook('evlog:emit:keep', (ctx) => {\n    const user = ctx.context.user as { premium?: boolean } | undefined\n    if (user?.premium) ctx.shouldKeep = true\n  })\n})\n","server\u002Fplugins\u002Fevlog-sampling.ts",[402,3031,3032,3052,3084,3128,3157,3163],{"__ignoreMap":472},[476,3033,3034,3036,3038,3040,3042,3044,3046,3048,3050],{"class":478,"line":479},[476,3035,606],{"class":551},[476,3037,609],{"class":551},[476,3039,2413],{"class":612},[476,3041,615],{"class":559},[476,3043,615],{"class":555},[476,3045,2420],{"class":889},[476,3047,676],{"class":555},[476,3049,895],{"class":882},[476,3051,898],{"class":555},[476,3053,3054,3056,3058,3060,3062,3064,3066,3068,3070,3072,3074,3076,3078,3080,3082],{"class":478,"line":578},[476,3055,2431],{"class":559},[476,3057,950],{"class":555},[476,3059,2436],{"class":559},[476,3061,950],{"class":555},[476,3063,2441],{"class":612},[476,3065,615],{"class":624},[476,3067,664],{"class":555},[476,3069,3024],{"class":485},[476,3071,664],{"class":555},[476,3073,1022],{"class":555},[476,3075,886],{"class":555},[476,3077,2590],{"class":889},[476,3079,676],{"class":555},[476,3081,895],{"class":882},[476,3083,898],{"class":555},[476,3085,3086,3089,3091,3093,3096,3098,3101,3103,3106,3109,3111,3114,3117,3120,3122,3125],{"class":478,"line":596},[476,3087,3088],{"class":882},"    const",[476,3090,961],{"class":559},[476,3092,909],{"class":555},[476,3094,3095],{"class":559}," ctx",[476,3097,950],{"class":555},[476,3099,3100],{"class":559},"context",[476,3102,950],{"class":555},[476,3104,3105],{"class":559},"user",[476,3107,3108],{"class":551}," as",[476,3110,556],{"class":555},[476,3112,3113],{"class":624}," premium",[476,3115,3116],{"class":555},"?:",[476,3118,3119],{"class":482}," boolean",[476,3121,563],{"class":555},[476,3123,3124],{"class":555}," |",[476,3126,3127],{"class":482}," undefined\n",[476,3129,3130,3133,3135,3137,3140,3143,3145,3147,3149,3152,3154],{"class":478,"line":603},[476,3131,3132],{"class":551},"    if",[476,3134,886],{"class":624},[476,3136,3105],{"class":559},[476,3138,3139],{"class":555},"?.",[476,3141,3142],{"class":559},"premium",[476,3144,2617],{"class":624},[476,3146,2590],{"class":559},[476,3148,950],{"class":555},[476,3150,3151],{"class":559},"shouldKeep",[476,3153,909],{"class":555},[476,3155,3156],{"class":1060}," true\n",[476,3158,3159,3161],{"class":478,"line":621},[476,3160,1573],{"class":555},[476,3162,696],{"class":624},[476,3164,3165,3167],{"class":478,"line":634},[476,3166,693],{"class":555},[476,3168,696],{"class":559},[1766,3170,3171,3172,3175],{"color":1768,"icon":13},"Errors are always kept by default. You have to explicitly set ",[402,3173,3174],{},"error: 0"," to drop them.",[454,3177,3179],{"id":3178},"next-steps","Next Steps",[398,3181,3182,3183,3185],{},"Deepen your ",[1357,3184,226],{}," integration:",[415,3187,3188,3193,3198,3203],{},[418,3189,3190,3192],{},[443,3191,51],{"href":52},": Design comprehensive events with context layering",[418,3194,3195,3197],{},[443,3196,290],{"href":295},": Send logs to Axiom, Sentry, PostHog, and more",[418,3199,3200,3202],{},[443,3201,175],{"href":176},": Control log volume with head and tail sampling",[418,3204,3205,3207,3208,1394,3210,1398,3212,3214],{},[443,3206,56],{"href":57},": Throw errors with ",[402,3209,1393],{},[402,3211,1397],{},[402,3213,1401],{}," fields",[3216,3217,3218],"style",{},"html pre.shiki code .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}html pre.shiki code .sfazB, html code.shiki .sfazB{--shiki-light:#91B859;--shiki-default:#C3E88D;--shiki-dark:#C3E88D}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 .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 .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 .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}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}",{"title":472,"searchDepth":578,"depth":578,"links":3220},[3221,3225,3226,3227,3230,3234,3238],{"id":456,"depth":578,"text":20,"children":3222},[3223,3224],{"id":460,"depth":596,"text":461},{"id":535,"depth":596,"text":536},{"id":812,"depth":578,"text":51},{"id":1383,"depth":578,"text":1384},{"id":1783,"depth":578,"text":170,"children":3228},[3229],{"id":1806,"depth":596,"text":1807},{"id":2220,"depth":578,"text":2221,"children":3231},[3232,3233],{"id":2227,"depth":596,"text":2228},{"id":2478,"depth":596,"text":2479},{"id":1802,"depth":578,"text":175,"children":3235},[3236,3237],{"id":2652,"depth":596,"text":2653},{"id":3017,"depth":596,"text":3018},{"id":3178,"depth":578,"text":3179},"Automatic wide events, structured errors, drain adapters, enrichers, and tail sampling in Nitro v2 and v3 applications.","md",null,{},{"title":226,"icon":229},{"title":226,"description":3239},"88cmOEbyUY8C13AVkYUt__ydkRumhrejjxyOKb_h_ls",[3247,3249],{"title":221,"path":222,"stem":223,"description":3248,"icon":224,"children":-1},"Automatic wide events, structured errors, drain adapters, enrichers, and tail sampling in SvelteKit applications.",{"title":231,"path":232,"stem":233,"description":3250,"icon":234,"children":-1},"Automatic wide events, structured errors, and logging in TanStack Start API routes and server functions.",1778106397966]