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