[{"data":1,"prerenderedAt":3122},["ShallowReactive",2],{"navigation_docs":3,"-frameworks-sveltekit":402,"-frameworks-sveltekit-surround":3117},[4,35,159,201,289,299,386],{"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},"Build On Top","\u002Fbuild-on-top","5.build-on-top",[294],{"title":295,"path":296,"stem":297,"icon":298},"FS reader","\u002Fbuild-on-top\u002Ffs-reader","5.build-on-top\u002F4.fs-reader","i-lucide-folder-search",{"title":300,"path":301,"stem":302,"children":303,"page":34},"Adapters","\u002Fadapters","6.adapters",[304,307,347,362],{"title":41,"path":305,"stem":306,"icon":44},"\u002Fadapters\u002Foverview","6.adapters\u002F01.overview",{"title":308,"path":309,"stem":310,"children":311,"page":34},"Cloud destinations","\u002Fadapters\u002Fcloud","6.adapters\u002F02.cloud",[312,317,322,327,332,337,342],{"title":313,"path":314,"stem":315,"icon":316},"Axiom","\u002Fadapters\u002Fcloud\u002Faxiom","6.adapters\u002F02.cloud\u002F01.axiom","i-custom-axiom",{"title":318,"path":319,"stem":320,"icon":321},"OTLP","\u002Fadapters\u002Fcloud\u002Fotlp","6.adapters\u002F02.cloud\u002F02.otlp","i-simple-icons-opentelemetry",{"title":323,"path":324,"stem":325,"icon":326},"PostHog","\u002Fadapters\u002Fcloud\u002Fposthog","6.adapters\u002F02.cloud\u002F03.posthog","i-simple-icons-posthog",{"title":328,"path":329,"stem":330,"icon":331},"Sentry","\u002Fadapters\u002Fcloud\u002Fsentry","6.adapters\u002F02.cloud\u002F04.sentry","i-simple-icons-sentry",{"title":333,"path":334,"stem":335,"icon":336},"Better Stack","\u002Fadapters\u002Fcloud\u002Fbetter-stack","6.adapters\u002F02.cloud\u002F05.better-stack","i-simple-icons-betterstack",{"title":338,"path":339,"stem":340,"icon":341},"Datadog","\u002Fadapters\u002Fcloud\u002Fdatadog","6.adapters\u002F02.cloud\u002F06.datadog","i-simple-icons-datadog",{"title":343,"path":344,"stem":345,"icon":346},"HyperDX","\u002Fadapters\u002Fcloud\u002Fhyperdx","6.adapters\u002F02.cloud\u002F07.hyperdx","i-custom-hyperdx",{"title":348,"path":349,"stem":350,"children":351,"page":34},"Self-hosted","\u002Fadapters\u002Fself-hosted","6.adapters\u002F03.self-hosted",[352,357],{"title":353,"path":354,"stem":355,"icon":356},"File System","\u002Fadapters\u002Fself-hosted\u002Ffs","6.adapters\u002F03.self-hosted\u002F01.fs","i-lucide-hard-drive",{"title":358,"path":359,"stem":360,"icon":361},"NuxtHub","\u002Fadapters\u002Fself-hosted\u002Fnuxthub","6.adapters\u002F03.self-hosted\u002F02.nuxthub","i-simple-icons-nuxt",{"title":363,"path":364,"stem":365,"children":366,"page":34},"Building blocks","\u002Fadapters\u002Fbuilding-blocks","6.adapters\u002F04.building-blocks",[367,372,377,381],{"title":368,"path":369,"stem":370,"icon":371},"Pipeline","\u002Fadapters\u002Fbuilding-blocks\u002Fpipeline","6.adapters\u002F04.building-blocks\u002F01.pipeline","i-lucide-workflow",{"title":373,"path":374,"stem":375,"icon":376},"HTTP","\u002Fadapters\u002Fbuilding-blocks\u002Fhttp","6.adapters\u002F04.building-blocks\u002F02.http","i-lucide-globe",{"title":378,"path":379,"stem":380,"icon":83},"Custom Adapters","\u002Fadapters\u002Fbuilding-blocks\u002Fcustom","6.adapters\u002F04.building-blocks\u002F03.custom",{"title":382,"path":383,"stem":384,"icon":385},"Toolkit","\u002Fadapters\u002Fbuilding-blocks\u002Ftoolkit","6.adapters\u002F04.building-blocks\u002F04.toolkit","i-lucide-blocks",{"title":387,"path":388,"stem":389,"children":390,"page":34},"Enrichers","\u002Fenrichers","7.enrichers",[391,394,398],{"title":41,"path":392,"stem":393,"icon":28},"\u002Fenrichers\u002Foverview","7.enrichers\u002F1.overview",{"title":395,"path":396,"stem":397,"icon":288},"Built-in","\u002Fenrichers\u002Fbuilt-in","7.enrichers\u002F2.built-in",{"title":399,"path":400,"stem":401,"icon":83},"Custom","\u002Fenrichers\u002Fcustom","7.enrichers\u002F3.custom",{"id":403,"title":221,"body":404,"description":3107,"extension":3108,"links":3109,"meta":3113,"navigation":3114,"path":222,"seo":3115,"stem":223,"__hash__":3116},"docs\u002F4.frameworks\u002F03.sveltekit.md",{"type":405,"value":406,"toc":3086},"minimark",[407,431,475,479,484,555,559,741,748,752,810,814,914,917,920,1266,1269,1334,1337,1343,1524,1655,1670,1677,1687,1889,1893,1914,2174,2177,2234,2237,2247,2251,2254,2448,2452,2459,2678,2690,2694,2700,2812,2816,2826,2979,2983,3024,3032,3042,3046,3053,3082],[408,409,410,411,415,416,419,420,423,424,419,427,430],"p",{},"The ",[412,413,414],"code",{},"evlog\u002Fsveltekit"," adapter provides ",[412,417,418],{},"handle"," and ",[412,421,422],{},"handleError"," hooks that auto-create a request-scoped logger accessible via ",[412,425,426],{},"event.locals.log",[412,428,429],{},"useLogger()",", emitting a wide event when the response completes.",[432,433,436,439,461],"prompt",{":actions":434,"description":435,"icon":224},"[\"copy\",\"cursor\",\"windsurf\"]","Set up evlog in my SvelteKit app",[408,437,438],{},"Set up evlog in my SvelteKit app.",[440,441,442,446,449,452,455,458],"ul",{},[443,444,445],"li",{},"Install evlog: pnpm add evlog",[443,447,448],{},"Add evlog\u002Fvite plugin to vite.config.ts with service name (handles auto-init, debug stripping)",[443,450,451],{},"Export handle and handleError from evlog\u002Fsveltekit in hooks.server.ts",[443,453,454],{},"Access the logger via event.locals.log or useLogger() in routes and services",[443,456,457],{},"Use log.set() to accumulate context, throw createError() for structured errors",[443,459,460],{},"Wide events are auto-emitted when each request completes",[408,462,463,464,470,471],{},"Docs: ",[465,466,467],"a",{"href":467,"rel":468},"https:\u002F\u002Fwww.evlog.dev\u002Fframeworks\u002Fsveltekit",[469],"nofollow","\nAdapters: ",[465,472,473],{"href":473,"rel":474},"https:\u002F\u002Fwww.evlog.dev\u002Fadapters",[469],[476,477,20],"h2",{"id":478},"quick-start",[480,481,483],"h3",{"id":482},"_1-install","1. Install",[485,486,487,512,526,540],"code-group",{},[488,489,495],"pre",{"className":490,"code":491,"filename":492,"language":493,"meta":494,"style":494},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","pnpm add evlog\n","pnpm","bash","",[412,496,497],{"__ignoreMap":494},[498,499,502,505,509],"span",{"class":500,"line":501},"line",1,[498,503,492],{"class":504},"sBMFI",[498,506,508],{"class":507},"sfazB"," add",[498,510,511],{"class":507}," evlog\n",[488,513,516],{"className":490,"code":514,"filename":515,"language":493,"meta":494,"style":494},"bun add evlog\n","bun",[412,517,518],{"__ignoreMap":494},[498,519,520,522,524],{"class":500,"line":501},[498,521,515],{"class":504},[498,523,508],{"class":507},[498,525,511],{"class":507},[488,527,530],{"className":490,"code":528,"filename":529,"language":493,"meta":494,"style":494},"yarn add evlog\n","yarn",[412,531,532],{"__ignoreMap":494},[498,533,534,536,538],{"class":500,"line":501},[498,535,529],{"class":504},[498,537,508],{"class":507},[498,539,511],{"class":507},[488,541,544],{"className":490,"code":542,"filename":543,"language":493,"meta":494,"style":494},"npm install evlog\n","npm",[412,545,546],{"__ignoreMap":494},[498,547,548,550,553],{"class":500,"line":501},[498,549,543],{"class":504},[498,551,552],{"class":507}," install",[498,554,511],{"class":507},[480,556,558],{"id":557},"_2-add-the-vite-plugin","2. Add the Vite plugin",[488,560,565],{"className":561,"code":562,"filename":563,"language":564,"meta":494,"style":494},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import { sveltekit } from '@sveltejs\u002Fkit\u002Fvite'\nimport evlog from 'evlog\u002Fvite'\nimport { defineConfig } from 'vite'\n\nexport default defineConfig({\n  plugins: [\n    sveltekit(),\n    evlog({\n      service: 'my-api',\n    }),\n  ],\n})\n","vite.config.ts","typescript",[412,566,567,596,614,635,642,660,673,685,695,713,724,732],{"__ignoreMap":494},[498,568,569,573,577,581,584,587,590,593],{"class":500,"line":501},[498,570,572],{"class":571},"s7zQu","import",[498,574,576],{"class":575},"sMK4o"," {",[498,578,580],{"class":579},"sTEyZ"," sveltekit",[498,582,583],{"class":575}," }",[498,585,586],{"class":571}," from",[498,588,589],{"class":575}," '",[498,591,592],{"class":507},"@sveltejs\u002Fkit\u002Fvite",[498,594,595],{"class":575},"'\n",[498,597,599,601,604,607,609,612],{"class":500,"line":598},2,[498,600,572],{"class":571},[498,602,603],{"class":579}," evlog ",[498,605,606],{"class":571},"from",[498,608,589],{"class":575},[498,610,611],{"class":507},"evlog\u002Fvite",[498,613,595],{"class":575},[498,615,617,619,621,624,626,628,630,633],{"class":500,"line":616},3,[498,618,572],{"class":571},[498,620,576],{"class":575},[498,622,623],{"class":579}," defineConfig",[498,625,583],{"class":575},[498,627,586],{"class":571},[498,629,589],{"class":575},[498,631,632],{"class":507},"vite",[498,634,595],{"class":575},[498,636,638],{"class":500,"line":637},4,[498,639,641],{"emptyLinePlaceholder":640},true,"\n",[498,643,645,648,651,654,657],{"class":500,"line":644},5,[498,646,647],{"class":571},"export",[498,649,650],{"class":571}," default",[498,652,623],{"class":653},"s2Zo4",[498,655,656],{"class":579},"(",[498,658,659],{"class":575},"{\n",[498,661,663,667,670],{"class":500,"line":662},6,[498,664,666],{"class":665},"swJcz","  plugins",[498,668,669],{"class":575},":",[498,671,672],{"class":579}," [\n",[498,674,676,679,682],{"class":500,"line":675},7,[498,677,678],{"class":653},"    sveltekit",[498,680,681],{"class":579},"()",[498,683,684],{"class":575},",\n",[498,686,688,691,693],{"class":500,"line":687},8,[498,689,690],{"class":653},"    evlog",[498,692,656],{"class":579},[498,694,659],{"class":575},[498,696,698,701,703,705,708,711],{"class":500,"line":697},9,[498,699,700],{"class":665},"      service",[498,702,669],{"class":575},[498,704,589],{"class":575},[498,706,707],{"class":507},"my-api",[498,709,710],{"class":575},"'",[498,712,684],{"class":575},[498,714,716,719,722],{"class":500,"line":715},10,[498,717,718],{"class":575},"    }",[498,720,721],{"class":579},")",[498,723,684],{"class":575},[498,725,727,730],{"class":500,"line":726},11,[498,728,729],{"class":579},"  ]",[498,731,684],{"class":575},[498,733,735,738],{"class":500,"line":734},12,[498,736,737],{"class":575},"}",[498,739,740],{"class":579},")\n",[408,742,743,744,747],{},"See the ",[465,745,746],{"href":193},"Vite Plugin docs"," for all options.",[480,749,751],{"id":750},"_3-create-hooks","3. Create hooks",[488,753,756],{"className":561,"code":754,"filename":755,"language":564,"meta":494,"style":494},"import { createEvlogHooks } from 'evlog\u002Fsveltekit'\n\nexport const { handle, handleError } = createEvlogHooks()\n","src\u002Fhooks.server.ts",[412,757,758,777,781],{"__ignoreMap":494},[498,759,760,762,764,767,769,771,773,775],{"class":500,"line":501},[498,761,572],{"class":571},[498,763,576],{"class":575},[498,765,766],{"class":579}," createEvlogHooks",[498,768,583],{"class":575},[498,770,586],{"class":571},[498,772,589],{"class":575},[498,774,414],{"class":507},[498,776,595],{"class":575},[498,778,779],{"class":500,"line":598},[498,780,641],{"emptyLinePlaceholder":640},[498,782,783,785,789,791,794,797,800,802,805,807],{"class":500,"line":616},[498,784,647],{"class":571},[498,786,788],{"class":787},"spNyl"," const",[498,790,576],{"class":575},[498,792,793],{"class":579}," handle",[498,795,796],{"class":575},",",[498,798,799],{"class":579}," handleError ",[498,801,737],{"class":575},[498,803,804],{"class":575}," =",[498,806,766],{"class":653},[498,808,809],{"class":579},"()\n",[480,811,813],{"id":812},"_4-type-your-locals","4. Type your locals",[488,815,818],{"className":561,"code":816,"filename":817,"language":564,"meta":494,"style":494},"import type { RequestLogger } from 'evlog'\n\ndeclare global {\n  namespace App {\n    interface Locals {\n      log: RequestLogger\n    }\n  }\n}\n\nexport {}\n","src\u002Fapp.d.ts",[412,819,820,843,847,857,868,878,888,893,898,903,907],{"__ignoreMap":494},[498,821,822,824,827,829,832,834,836,838,841],{"class":500,"line":501},[498,823,572],{"class":571},[498,825,826],{"class":571}," type",[498,828,576],{"class":575},[498,830,831],{"class":579}," RequestLogger",[498,833,583],{"class":575},[498,835,586],{"class":571},[498,837,589],{"class":575},[498,839,840],{"class":507},"evlog",[498,842,595],{"class":575},[498,844,845],{"class":500,"line":598},[498,846,641],{"emptyLinePlaceholder":640},[498,848,849,852,855],{"class":500,"line":616},[498,850,851],{"class":787},"declare",[498,853,854],{"class":579}," global ",[498,856,659],{"class":575},[498,858,859,862,865],{"class":500,"line":637},[498,860,861],{"class":787},"  namespace",[498,863,864],{"class":504}," App",[498,866,867],{"class":575}," {\n",[498,869,870,873,876],{"class":500,"line":644},[498,871,872],{"class":787},"    interface",[498,874,875],{"class":504}," Locals",[498,877,867],{"class":575},[498,879,880,883,885],{"class":500,"line":662},[498,881,882],{"class":665},"      log",[498,884,669],{"class":575},[498,886,887],{"class":504}," RequestLogger\n",[498,889,890],{"class":500,"line":675},[498,891,892],{"class":575},"    }\n",[498,894,895],{"class":500,"line":687},[498,896,897],{"class":575},"  }\n",[498,899,900],{"class":500,"line":697},[498,901,902],{"class":575},"}\n",[498,904,905],{"class":500,"line":715},[498,906,641],{"emptyLinePlaceholder":640},[498,908,909,911],{"class":500,"line":726},[498,910,647],{"class":571},[498,912,913],{"class":575}," {}\n",[476,915,51],{"id":916},"wide-events",[408,918,919],{},"Build up context progressively through your handler. One request = one wide event:",[488,921,924],{"className":561,"code":922,"filename":923,"language":564,"meta":494,"style":494},"import { json } from '@sveltejs\u002Fkit'\nimport type { RequestHandler } from '.\u002F$types'\n\nexport const GET: RequestHandler = async ({ locals, params }) => {\n  locals.log.set({ user: { id: params.id } })\n\n  const user = await db.findUser(params.id)\n  locals.log.set({ user: { name: user.name, plan: user.plan } })\n\n  const orders = await db.findOrders(params.id)\n  locals.log.set({ orders: { count: orders.length, totalRevenue: sum(orders) } })\n\n  return json({ user, orders })\n}\n","src\u002Froutes\u002Fapi\u002Fusers\u002F[id]\u002F+server.ts",[412,925,926,946,968,972,1010,1056,1060,1091,1145,1149,1177,1235,1239,1261],{"__ignoreMap":494},[498,927,928,930,932,935,937,939,941,944],{"class":500,"line":501},[498,929,572],{"class":571},[498,931,576],{"class":575},[498,933,934],{"class":579}," json",[498,936,583],{"class":575},[498,938,586],{"class":571},[498,940,589],{"class":575},[498,942,943],{"class":507},"@sveltejs\u002Fkit",[498,945,595],{"class":575},[498,947,948,950,952,954,957,959,961,963,966],{"class":500,"line":598},[498,949,572],{"class":571},[498,951,826],{"class":571},[498,953,576],{"class":575},[498,955,956],{"class":579}," RequestHandler",[498,958,583],{"class":575},[498,960,586],{"class":571},[498,962,589],{"class":575},[498,964,965],{"class":507},".\u002F$types",[498,967,595],{"class":575},[498,969,970],{"class":500,"line":616},[498,971,641],{"emptyLinePlaceholder":640},[498,973,974,976,978,981,983,985,987,990,993,997,999,1002,1005,1008],{"class":500,"line":637},[498,975,647],{"class":571},[498,977,788],{"class":787},[498,979,980],{"class":579}," GET",[498,982,669],{"class":575},[498,984,956],{"class":504},[498,986,804],{"class":575},[498,988,989],{"class":787}," async",[498,991,992],{"class":575}," ({",[498,994,996],{"class":995},"sHdIc"," locals",[498,998,796],{"class":575},[498,1000,1001],{"class":995}," params",[498,1003,1004],{"class":575}," })",[498,1006,1007],{"class":787}," =>",[498,1009,867],{"class":575},[498,1011,1012,1015,1018,1021,1023,1026,1028,1031,1034,1036,1038,1041,1043,1045,1047,1050,1052,1054],{"class":500,"line":644},[498,1013,1014],{"class":579},"  locals",[498,1016,1017],{"class":575},".",[498,1019,1020],{"class":579},"log",[498,1022,1017],{"class":575},[498,1024,1025],{"class":653},"set",[498,1027,656],{"class":665},[498,1029,1030],{"class":575},"{",[498,1032,1033],{"class":665}," user",[498,1035,669],{"class":575},[498,1037,576],{"class":575},[498,1039,1040],{"class":665}," id",[498,1042,669],{"class":575},[498,1044,1001],{"class":579},[498,1046,1017],{"class":575},[498,1048,1049],{"class":579},"id",[498,1051,583],{"class":575},[498,1053,583],{"class":575},[498,1055,740],{"class":665},[498,1057,1058],{"class":500,"line":662},[498,1059,641],{"emptyLinePlaceholder":640},[498,1061,1062,1065,1067,1069,1072,1075,1077,1080,1082,1085,1087,1089],{"class":500,"line":675},[498,1063,1064],{"class":787},"  const",[498,1066,1033],{"class":579},[498,1068,804],{"class":575},[498,1070,1071],{"class":571}," await",[498,1073,1074],{"class":579}," db",[498,1076,1017],{"class":575},[498,1078,1079],{"class":653},"findUser",[498,1081,656],{"class":665},[498,1083,1084],{"class":579},"params",[498,1086,1017],{"class":575},[498,1088,1049],{"class":579},[498,1090,740],{"class":665},[498,1092,1093,1095,1097,1099,1101,1103,1105,1107,1109,1111,1113,1116,1118,1120,1122,1125,1127,1130,1132,1134,1136,1139,1141,1143],{"class":500,"line":687},[498,1094,1014],{"class":579},[498,1096,1017],{"class":575},[498,1098,1020],{"class":579},[498,1100,1017],{"class":575},[498,1102,1025],{"class":653},[498,1104,656],{"class":665},[498,1106,1030],{"class":575},[498,1108,1033],{"class":665},[498,1110,669],{"class":575},[498,1112,576],{"class":575},[498,1114,1115],{"class":665}," name",[498,1117,669],{"class":575},[498,1119,1033],{"class":579},[498,1121,1017],{"class":575},[498,1123,1124],{"class":579},"name",[498,1126,796],{"class":575},[498,1128,1129],{"class":665}," plan",[498,1131,669],{"class":575},[498,1133,1033],{"class":579},[498,1135,1017],{"class":575},[498,1137,1138],{"class":579},"plan",[498,1140,583],{"class":575},[498,1142,583],{"class":575},[498,1144,740],{"class":665},[498,1146,1147],{"class":500,"line":697},[498,1148,641],{"emptyLinePlaceholder":640},[498,1150,1151,1153,1156,1158,1160,1162,1164,1167,1169,1171,1173,1175],{"class":500,"line":715},[498,1152,1064],{"class":787},[498,1154,1155],{"class":579}," orders",[498,1157,804],{"class":575},[498,1159,1071],{"class":571},[498,1161,1074],{"class":579},[498,1163,1017],{"class":575},[498,1165,1166],{"class":653},"findOrders",[498,1168,656],{"class":665},[498,1170,1084],{"class":579},[498,1172,1017],{"class":575},[498,1174,1049],{"class":579},[498,1176,740],{"class":665},[498,1178,1179,1181,1183,1185,1187,1189,1191,1193,1195,1197,1199,1202,1204,1206,1208,1211,1213,1216,1218,1221,1223,1226,1229,1231,1233],{"class":500,"line":726},[498,1180,1014],{"class":579},[498,1182,1017],{"class":575},[498,1184,1020],{"class":579},[498,1186,1017],{"class":575},[498,1188,1025],{"class":653},[498,1190,656],{"class":665},[498,1192,1030],{"class":575},[498,1194,1155],{"class":665},[498,1196,669],{"class":575},[498,1198,576],{"class":575},[498,1200,1201],{"class":665}," count",[498,1203,669],{"class":575},[498,1205,1155],{"class":579},[498,1207,1017],{"class":575},[498,1209,1210],{"class":579},"length",[498,1212,796],{"class":575},[498,1214,1215],{"class":665}," totalRevenue",[498,1217,669],{"class":575},[498,1219,1220],{"class":653}," sum",[498,1222,656],{"class":665},[498,1224,1225],{"class":579},"orders",[498,1227,1228],{"class":665},") ",[498,1230,737],{"class":575},[498,1232,583],{"class":575},[498,1234,740],{"class":665},[498,1236,1237],{"class":500,"line":734},[498,1238,641],{"emptyLinePlaceholder":640},[498,1240,1242,1245,1247,1249,1251,1253,1255,1257,1259],{"class":500,"line":1241},13,[498,1243,1244],{"class":571},"  return",[498,1246,934],{"class":653},[498,1248,656],{"class":665},[498,1250,1030],{"class":575},[498,1252,1033],{"class":579},[498,1254,796],{"class":575},[498,1256,1155],{"class":579},[498,1258,583],{"class":575},[498,1260,740],{"class":665},[498,1262,1264],{"class":500,"line":1263},14,[498,1265,902],{"class":575},[408,1267,1268],{},"All fields are merged into a single wide event emitted when the request completes:",[488,1270,1273],{"className":490,"code":1271,"filename":1272,"language":493,"meta":494,"style":494},"14:58:15 INFO [my-api] GET \u002Fapi\u002Fusers\u002Fusr_123 200 in 12ms\n  ├─ orders: count=2 totalRevenue=6298\n  ├─ user: id=usr_123 name=Alice plan=pro\n  └─ requestId: 4a8ff3a8-...\n","Terminal output",[412,1274,1275,1286,1307,1323],{"__ignoreMap":494},[498,1276,1277,1280,1283],{"class":500,"line":501},[498,1278,1279],{"class":504},"14:58:15",[498,1281,1282],{"class":507}," INFO",[498,1284,1285],{"class":579}," [my-api] GET \u002Fapi\u002Fusers\u002Fusr_123 200 in 12ms\n",[498,1287,1288,1291,1294,1297,1301,1304],{"class":500,"line":598},[498,1289,1290],{"class":504},"  ├─",[498,1292,1293],{"class":507}," orders:",[498,1295,1296],{"class":507}," count=",[498,1298,1300],{"class":1299},"sbssI","2",[498,1302,1303],{"class":507}," totalRevenue=",[498,1305,1306],{"class":1299},"6298\n",[498,1308,1309,1311,1314,1317,1320],{"class":500,"line":616},[498,1310,1290],{"class":504},[498,1312,1313],{"class":507}," user:",[498,1315,1316],{"class":507}," id=usr_123",[498,1318,1319],{"class":507}," name=Alice",[498,1321,1322],{"class":507}," plan=pro\n",[498,1324,1325,1328,1331],{"class":500,"line":637},[498,1326,1327],{"class":504},"  └─",[498,1329,1330],{"class":507}," requestId:",[498,1332,1333],{"class":507}," 4a8ff3a8-...\n",[476,1335,429],{"id":1336},"uselogger",[408,1338,1339,1340,1342],{},"Use ",[412,1341,429],{}," to access the request-scoped logger from anywhere in the call stack without passing locals through your service layer:",[488,1344,1347],{"className":561,"code":1345,"filename":1346,"language":564,"meta":494,"style":494},"import { useLogger } from 'evlog\u002Fsveltekit'\n\nexport async function findUser(id: string) {\n  const log = useLogger()\n  log.set({ user: { id } })\n\n  const user = await db.findUser(id)\n  log.set({ user: { name: user.name, plan: user.plan } })\n\n  return user\n}\n","src\u002Flib\u002Fservices\u002Fuser.ts",[412,1348,1349,1368,1372,1397,1410,1437,1441,1463,1509,1513,1520],{"__ignoreMap":494},[498,1350,1351,1353,1355,1358,1360,1362,1364,1366],{"class":500,"line":501},[498,1352,572],{"class":571},[498,1354,576],{"class":575},[498,1356,1357],{"class":579}," useLogger",[498,1359,583],{"class":575},[498,1361,586],{"class":571},[498,1363,589],{"class":575},[498,1365,414],{"class":507},[498,1367,595],{"class":575},[498,1369,1370],{"class":500,"line":598},[498,1371,641],{"emptyLinePlaceholder":640},[498,1373,1374,1376,1378,1381,1384,1386,1388,1390,1393,1395],{"class":500,"line":616},[498,1375,647],{"class":571},[498,1377,989],{"class":787},[498,1379,1380],{"class":787}," function",[498,1382,1383],{"class":653}," findUser",[498,1385,656],{"class":575},[498,1387,1049],{"class":995},[498,1389,669],{"class":575},[498,1391,1392],{"class":504}," string",[498,1394,721],{"class":575},[498,1396,867],{"class":575},[498,1398,1399,1401,1404,1406,1408],{"class":500,"line":637},[498,1400,1064],{"class":787},[498,1402,1403],{"class":579}," log",[498,1405,804],{"class":575},[498,1407,1357],{"class":653},[498,1409,809],{"class":665},[498,1411,1412,1415,1417,1419,1421,1423,1425,1427,1429,1431,1433,1435],{"class":500,"line":644},[498,1413,1414],{"class":579},"  log",[498,1416,1017],{"class":575},[498,1418,1025],{"class":653},[498,1420,656],{"class":665},[498,1422,1030],{"class":575},[498,1424,1033],{"class":665},[498,1426,669],{"class":575},[498,1428,576],{"class":575},[498,1430,1040],{"class":579},[498,1432,583],{"class":575},[498,1434,583],{"class":575},[498,1436,740],{"class":665},[498,1438,1439],{"class":500,"line":662},[498,1440,641],{"emptyLinePlaceholder":640},[498,1442,1443,1445,1447,1449,1451,1453,1455,1457,1459,1461],{"class":500,"line":675},[498,1444,1064],{"class":787},[498,1446,1033],{"class":579},[498,1448,804],{"class":575},[498,1450,1071],{"class":571},[498,1452,1074],{"class":579},[498,1454,1017],{"class":575},[498,1456,1079],{"class":653},[498,1458,656],{"class":665},[498,1460,1049],{"class":579},[498,1462,740],{"class":665},[498,1464,1465,1467,1469,1471,1473,1475,1477,1479,1481,1483,1485,1487,1489,1491,1493,1495,1497,1499,1501,1503,1505,1507],{"class":500,"line":687},[498,1466,1414],{"class":579},[498,1468,1017],{"class":575},[498,1470,1025],{"class":653},[498,1472,656],{"class":665},[498,1474,1030],{"class":575},[498,1476,1033],{"class":665},[498,1478,669],{"class":575},[498,1480,576],{"class":575},[498,1482,1115],{"class":665},[498,1484,669],{"class":575},[498,1486,1033],{"class":579},[498,1488,1017],{"class":575},[498,1490,1124],{"class":579},[498,1492,796],{"class":575},[498,1494,1129],{"class":665},[498,1496,669],{"class":575},[498,1498,1033],{"class":579},[498,1500,1017],{"class":575},[498,1502,1138],{"class":579},[498,1504,583],{"class":575},[498,1506,583],{"class":575},[498,1508,740],{"class":665},[498,1510,1511],{"class":500,"line":697},[498,1512,641],{"emptyLinePlaceholder":640},[498,1514,1515,1517],{"class":500,"line":715},[498,1516,1244],{"class":571},[498,1518,1519],{"class":579}," user\n",[498,1521,1522],{"class":500,"line":726},[498,1523,902],{"class":575},[488,1525,1527],{"className":561,"code":1526,"filename":923,"language":564,"meta":494,"style":494},"import { json } from '@sveltejs\u002Fkit'\nimport { findUser } from '$lib\u002Fservices\u002Fuser'\nimport type { RequestHandler } from '.\u002F$types'\n\nexport const GET: RequestHandler = async ({ params }) => {\n  const user = await findUser(params.id)\n  return json(user)\n}\n",[412,1528,1529,1547,1566,1586,1590,1616,1638,1651],{"__ignoreMap":494},[498,1530,1531,1533,1535,1537,1539,1541,1543,1545],{"class":500,"line":501},[498,1532,572],{"class":571},[498,1534,576],{"class":575},[498,1536,934],{"class":579},[498,1538,583],{"class":575},[498,1540,586],{"class":571},[498,1542,589],{"class":575},[498,1544,943],{"class":507},[498,1546,595],{"class":575},[498,1548,1549,1551,1553,1555,1557,1559,1561,1564],{"class":500,"line":598},[498,1550,572],{"class":571},[498,1552,576],{"class":575},[498,1554,1383],{"class":579},[498,1556,583],{"class":575},[498,1558,586],{"class":571},[498,1560,589],{"class":575},[498,1562,1563],{"class":507},"$lib\u002Fservices\u002Fuser",[498,1565,595],{"class":575},[498,1567,1568,1570,1572,1574,1576,1578,1580,1582,1584],{"class":500,"line":616},[498,1569,572],{"class":571},[498,1571,826],{"class":571},[498,1573,576],{"class":575},[498,1575,956],{"class":579},[498,1577,583],{"class":575},[498,1579,586],{"class":571},[498,1581,589],{"class":575},[498,1583,965],{"class":507},[498,1585,595],{"class":575},[498,1587,1588],{"class":500,"line":637},[498,1589,641],{"emptyLinePlaceholder":640},[498,1591,1592,1594,1596,1598,1600,1602,1604,1606,1608,1610,1612,1614],{"class":500,"line":644},[498,1593,647],{"class":571},[498,1595,788],{"class":787},[498,1597,980],{"class":579},[498,1599,669],{"class":575},[498,1601,956],{"class":504},[498,1603,804],{"class":575},[498,1605,989],{"class":787},[498,1607,992],{"class":575},[498,1609,1001],{"class":995},[498,1611,1004],{"class":575},[498,1613,1007],{"class":787},[498,1615,867],{"class":575},[498,1617,1618,1620,1622,1624,1626,1628,1630,1632,1634,1636],{"class":500,"line":662},[498,1619,1064],{"class":787},[498,1621,1033],{"class":579},[498,1623,804],{"class":575},[498,1625,1071],{"class":571},[498,1627,1383],{"class":653},[498,1629,656],{"class":665},[498,1631,1084],{"class":579},[498,1633,1017],{"class":575},[498,1635,1049],{"class":579},[498,1637,740],{"class":665},[498,1639,1640,1642,1644,1646,1649],{"class":500,"line":675},[498,1641,1244],{"class":571},[498,1643,934],{"class":653},[498,1645,656],{"class":665},[498,1647,1648],{"class":579},"user",[498,1650,740],{"class":665},[498,1652,1653],{"class":500,"line":687},[498,1654,902],{"class":575},[408,1656,1657,1658,419,1660,1662,1663,1665,1666,1669],{},"Both ",[412,1659,426],{},[412,1661,429],{}," return the same logger instance. ",[412,1664,429],{}," uses ",[412,1667,1668],{},"AsyncLocalStorage"," to propagate the logger across async boundaries.",[476,1671,1673,1674,721],{"id":1672},"background-work-logfork","Background work (",[412,1675,1676],{},"log.fork",[408,1678,1339,1679,1682,1683,1017],{},[412,1680,1681],{},"locals.log.fork(label, fn)"," for a child wide event. See ",[465,1684,1686],{"href":1685},"\u002Flogging\u002Fwide-events#after-emit-sealing-and-background-work","Wide events — After emit",[488,1688,1691],{"className":561,"code":1689,"filename":1690,"language":564,"meta":494,"style":494},"import { useLogger } from 'evlog\u002Fsveltekit'\nimport type { RequestHandler } from '.\u002F$types'\n\nexport const POST: RequestHandler = async ({ locals }) => {\n  locals.log.fork!('process', async () => {\n    const log = useLogger()\n    log.set({ step: 'done' })\n  })\n  return new Response(JSON.stringify({ ok: true }))\n}\n","src\u002Froutes\u002Fapi\u002Forders\u002F+server.ts",[412,1692,1693,1711,1731,1735,1762,1798,1811,1840,1847,1885],{"__ignoreMap":494},[498,1694,1695,1697,1699,1701,1703,1705,1707,1709],{"class":500,"line":501},[498,1696,572],{"class":571},[498,1698,576],{"class":575},[498,1700,1357],{"class":579},[498,1702,583],{"class":575},[498,1704,586],{"class":571},[498,1706,589],{"class":575},[498,1708,414],{"class":507},[498,1710,595],{"class":575},[498,1712,1713,1715,1717,1719,1721,1723,1725,1727,1729],{"class":500,"line":598},[498,1714,572],{"class":571},[498,1716,826],{"class":571},[498,1718,576],{"class":575},[498,1720,956],{"class":579},[498,1722,583],{"class":575},[498,1724,586],{"class":571},[498,1726,589],{"class":575},[498,1728,965],{"class":507},[498,1730,595],{"class":575},[498,1732,1733],{"class":500,"line":616},[498,1734,641],{"emptyLinePlaceholder":640},[498,1736,1737,1739,1741,1744,1746,1748,1750,1752,1754,1756,1758,1760],{"class":500,"line":637},[498,1738,647],{"class":571},[498,1740,788],{"class":787},[498,1742,1743],{"class":579}," POST",[498,1745,669],{"class":575},[498,1747,956],{"class":504},[498,1749,804],{"class":575},[498,1751,989],{"class":787},[498,1753,992],{"class":575},[498,1755,996],{"class":995},[498,1757,1004],{"class":575},[498,1759,1007],{"class":787},[498,1761,867],{"class":575},[498,1763,1764,1766,1768,1770,1772,1775,1778,1780,1782,1785,1787,1789,1791,1794,1796],{"class":500,"line":644},[498,1765,1014],{"class":579},[498,1767,1017],{"class":575},[498,1769,1020],{"class":579},[498,1771,1017],{"class":575},[498,1773,1774],{"class":653},"fork",[498,1776,1777],{"class":575},"!",[498,1779,656],{"class":665},[498,1781,710],{"class":575},[498,1783,1784],{"class":507},"process",[498,1786,710],{"class":575},[498,1788,796],{"class":575},[498,1790,989],{"class":787},[498,1792,1793],{"class":575}," ()",[498,1795,1007],{"class":787},[498,1797,867],{"class":575},[498,1799,1800,1803,1805,1807,1809],{"class":500,"line":662},[498,1801,1802],{"class":787},"    const",[498,1804,1403],{"class":579},[498,1806,804],{"class":575},[498,1808,1357],{"class":653},[498,1810,809],{"class":665},[498,1812,1813,1816,1818,1820,1822,1824,1827,1829,1831,1834,1836,1838],{"class":500,"line":675},[498,1814,1815],{"class":579},"    log",[498,1817,1017],{"class":575},[498,1819,1025],{"class":653},[498,1821,656],{"class":665},[498,1823,1030],{"class":575},[498,1825,1826],{"class":665}," step",[498,1828,669],{"class":575},[498,1830,589],{"class":575},[498,1832,1833],{"class":507},"done",[498,1835,710],{"class":575},[498,1837,583],{"class":575},[498,1839,740],{"class":665},[498,1841,1842,1845],{"class":500,"line":687},[498,1843,1844],{"class":575},"  }",[498,1846,740],{"class":665},[498,1848,1849,1851,1854,1857,1859,1862,1864,1867,1869,1871,1874,1876,1880,1882],{"class":500,"line":697},[498,1850,1244],{"class":571},[498,1852,1853],{"class":575}," new",[498,1855,1856],{"class":653}," Response",[498,1858,656],{"class":665},[498,1860,1861],{"class":579},"JSON",[498,1863,1017],{"class":575},[498,1865,1866],{"class":653},"stringify",[498,1868,656],{"class":665},[498,1870,1030],{"class":575},[498,1872,1873],{"class":665}," ok",[498,1875,669],{"class":575},[498,1877,1879],{"class":1878},"sfNiH"," true",[498,1881,583],{"class":575},[498,1883,1884],{"class":665},"))\n",[498,1886,1887],{"class":500,"line":715},[498,1888,902],{"class":575},[476,1890,1892],{"id":1891},"error-handling","Error Handling",[408,1894,1339,1895,1898,1899,1902,1903,1906,1907,1910,1911,1913],{},[412,1896,1897],{},"createError"," for structured errors with ",[412,1900,1901],{},"why",", ",[412,1904,1905],{},"fix",", and ",[412,1908,1909],{},"link"," fields. The ",[412,1912,422],{}," hook captures thrown errors automatically:",[488,1915,1918],{"className":561,"code":1916,"filename":1917,"language":564,"meta":494,"style":494},"import { json } from '@sveltejs\u002Fkit'\nimport { createError } from 'evlog'\nimport type { RequestHandler } from '.\u002F$types'\n\nexport const POST: RequestHandler = async ({ locals, request }) => {\n  const { cartId } = await request.json()\n  locals.log.set({ cart: { id: cartId } })\n\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","src\u002Froutes\u002Fapi\u002Fcheckout\u002F+server.ts",[412,1919,1920,1938,1957,1977,1981,2012,2036,2071,2075,2086,2102,2114,2130,2146,2162,2169],{"__ignoreMap":494},[498,1921,1922,1924,1926,1928,1930,1932,1934,1936],{"class":500,"line":501},[498,1923,572],{"class":571},[498,1925,576],{"class":575},[498,1927,934],{"class":579},[498,1929,583],{"class":575},[498,1931,586],{"class":571},[498,1933,589],{"class":575},[498,1935,943],{"class":507},[498,1937,595],{"class":575},[498,1939,1940,1942,1944,1947,1949,1951,1953,1955],{"class":500,"line":598},[498,1941,572],{"class":571},[498,1943,576],{"class":575},[498,1945,1946],{"class":579}," createError",[498,1948,583],{"class":575},[498,1950,586],{"class":571},[498,1952,589],{"class":575},[498,1954,840],{"class":507},[498,1956,595],{"class":575},[498,1958,1959,1961,1963,1965,1967,1969,1971,1973,1975],{"class":500,"line":616},[498,1960,572],{"class":571},[498,1962,826],{"class":571},[498,1964,576],{"class":575},[498,1966,956],{"class":579},[498,1968,583],{"class":575},[498,1970,586],{"class":571},[498,1972,589],{"class":575},[498,1974,965],{"class":507},[498,1976,595],{"class":575},[498,1978,1979],{"class":500,"line":637},[498,1980,641],{"emptyLinePlaceholder":640},[498,1982,1983,1985,1987,1989,1991,1993,1995,1997,1999,2001,2003,2006,2008,2010],{"class":500,"line":644},[498,1984,647],{"class":571},[498,1986,788],{"class":787},[498,1988,1743],{"class":579},[498,1990,669],{"class":575},[498,1992,956],{"class":504},[498,1994,804],{"class":575},[498,1996,989],{"class":787},[498,1998,992],{"class":575},[498,2000,996],{"class":995},[498,2002,796],{"class":575},[498,2004,2005],{"class":995}," request",[498,2007,1004],{"class":575},[498,2009,1007],{"class":787},[498,2011,867],{"class":575},[498,2013,2014,2016,2018,2021,2023,2025,2027,2029,2031,2034],{"class":500,"line":662},[498,2015,1064],{"class":787},[498,2017,576],{"class":575},[498,2019,2020],{"class":579}," cartId",[498,2022,583],{"class":575},[498,2024,804],{"class":575},[498,2026,1071],{"class":571},[498,2028,2005],{"class":579},[498,2030,1017],{"class":575},[498,2032,2033],{"class":653},"json",[498,2035,809],{"class":665},[498,2037,2038,2040,2042,2044,2046,2048,2050,2052,2055,2057,2059,2061,2063,2065,2067,2069],{"class":500,"line":675},[498,2039,1014],{"class":579},[498,2041,1017],{"class":575},[498,2043,1020],{"class":579},[498,2045,1017],{"class":575},[498,2047,1025],{"class":653},[498,2049,656],{"class":665},[498,2051,1030],{"class":575},[498,2053,2054],{"class":665}," cart",[498,2056,669],{"class":575},[498,2058,576],{"class":575},[498,2060,1040],{"class":665},[498,2062,669],{"class":575},[498,2064,2020],{"class":579},[498,2066,583],{"class":575},[498,2068,583],{"class":575},[498,2070,740],{"class":665},[498,2072,2073],{"class":500,"line":687},[498,2074,641],{"emptyLinePlaceholder":640},[498,2076,2077,2080,2082,2084],{"class":500,"line":697},[498,2078,2079],{"class":571},"  throw",[498,2081,1946],{"class":653},[498,2083,656],{"class":665},[498,2085,659],{"class":575},[498,2087,2088,2091,2093,2095,2098,2100],{"class":500,"line":715},[498,2089,2090],{"class":665},"    message",[498,2092,669],{"class":575},[498,2094,589],{"class":575},[498,2096,2097],{"class":507},"Payment failed",[498,2099,710],{"class":575},[498,2101,684],{"class":575},[498,2103,2104,2107,2109,2112],{"class":500,"line":726},[498,2105,2106],{"class":665},"    status",[498,2108,669],{"class":575},[498,2110,2111],{"class":1299}," 402",[498,2113,684],{"class":575},[498,2115,2116,2119,2121,2123,2126,2128],{"class":500,"line":734},[498,2117,2118],{"class":665},"    why",[498,2120,669],{"class":575},[498,2122,589],{"class":575},[498,2124,2125],{"class":507},"Card declined by issuer",[498,2127,710],{"class":575},[498,2129,684],{"class":575},[498,2131,2132,2135,2137,2139,2142,2144],{"class":500,"line":1241},[498,2133,2134],{"class":665},"    fix",[498,2136,669],{"class":575},[498,2138,589],{"class":575},[498,2140,2141],{"class":507},"Try a different payment method",[498,2143,710],{"class":575},[498,2145,684],{"class":575},[498,2147,2148,2151,2153,2155,2158,2160],{"class":500,"line":1263},[498,2149,2150],{"class":665},"    link",[498,2152,669],{"class":575},[498,2154,589],{"class":575},[498,2156,2157],{"class":507},"https:\u002F\u002Fdocs.example.com\u002Fpayments\u002Fdeclined",[498,2159,710],{"class":575},[498,2161,684],{"class":575},[498,2163,2165,2167],{"class":500,"line":2164},15,[498,2166,1844],{"class":575},[498,2168,740],{"class":665},[498,2170,2172],{"class":500,"line":2171},16,[498,2173,902],{"class":575},[408,2175,2176],{},"The error is captured and logged with both the custom context and structured error fields:",[488,2178,2180],{"className":490,"code":2179,"filename":1272,"language":493,"meta":494,"style":494},"14:58:20 ERROR [my-api] POST \u002Fapi\u002Fcheckout 402 in 3ms\n  ├─ error: name=EvlogError message=Payment failed status=402\n  ├─ cart: id=cart_456\n  └─ requestId: 880a50ac-...\n",[412,2181,2182,2193,2215,2225],{"__ignoreMap":494},[498,2183,2184,2187,2190],{"class":500,"line":501},[498,2185,2186],{"class":504},"14:58:20",[498,2188,2189],{"class":507}," ERROR",[498,2191,2192],{"class":579}," [my-api] POST \u002Fapi\u002Fcheckout 402 in 3ms\n",[498,2194,2195,2197,2200,2203,2206,2209,2212],{"class":500,"line":598},[498,2196,1290],{"class":504},[498,2198,2199],{"class":507}," error:",[498,2201,2202],{"class":507}," name=EvlogError",[498,2204,2205],{"class":507}," message=Payment",[498,2207,2208],{"class":507}," failed",[498,2210,2211],{"class":507}," status=",[498,2213,2214],{"class":1299},"402\n",[498,2216,2217,2219,2222],{"class":500,"line":616},[498,2218,1290],{"class":504},[498,2220,2221],{"class":507}," cart:",[498,2223,2224],{"class":507}," id=cart_456\n",[498,2226,2227,2229,2231],{"class":500,"line":637},[498,2228,1327],{"class":504},[498,2230,1330],{"class":507},[498,2232,2233],{"class":507}," 880a50ac-...\n",[476,2235,170],{"id":2236},"configuration",[408,2238,743,2239,2242,2243,2246],{},[465,2240,2241],{"href":171},"Configuration reference"," for all available options (",[412,2244,2245],{},"initLogger",", middleware options, sampling, silent mode, etc.).",[476,2248,2250],{"id":2249},"drain-enrichers","Drain & Enrichers",[408,2252,2253],{},"Configure drain adapters and enrichers directly in the hooks options:",[488,2255,2257],{"className":561,"code":2256,"filename":755,"language":564,"meta":494,"style":494},"import { createEvlogHooks } from 'evlog\u002Fsveltekit'\nimport { createAxiomDrain } from 'evlog\u002Faxiom'\nimport { createUserAgentEnricher } from 'evlog\u002Fenrichers'\n\nconst userAgent = createUserAgentEnricher()\n\nexport const { handle, handleError } = createEvlogHooks({\n  drain: createAxiomDrain(),\n  enrich: (ctx) => {\n    userAgent(ctx)\n    ctx.event.region = process.env.FLY_REGION\n  },\n})\n",[412,2258,2259,2277,2297,2317,2321,2336,2340,2364,2377,2396,2407,2437,2442],{"__ignoreMap":494},[498,2260,2261,2263,2265,2267,2269,2271,2273,2275],{"class":500,"line":501},[498,2262,572],{"class":571},[498,2264,576],{"class":575},[498,2266,766],{"class":579},[498,2268,583],{"class":575},[498,2270,586],{"class":571},[498,2272,589],{"class":575},[498,2274,414],{"class":507},[498,2276,595],{"class":575},[498,2278,2279,2281,2283,2286,2288,2290,2292,2295],{"class":500,"line":598},[498,2280,572],{"class":571},[498,2282,576],{"class":575},[498,2284,2285],{"class":579}," createAxiomDrain",[498,2287,583],{"class":575},[498,2289,586],{"class":571},[498,2291,589],{"class":575},[498,2293,2294],{"class":507},"evlog\u002Faxiom",[498,2296,595],{"class":575},[498,2298,2299,2301,2303,2306,2308,2310,2312,2315],{"class":500,"line":616},[498,2300,572],{"class":571},[498,2302,576],{"class":575},[498,2304,2305],{"class":579}," createUserAgentEnricher",[498,2307,583],{"class":575},[498,2309,586],{"class":571},[498,2311,589],{"class":575},[498,2313,2314],{"class":507},"evlog\u002Fenrichers",[498,2316,595],{"class":575},[498,2318,2319],{"class":500,"line":637},[498,2320,641],{"emptyLinePlaceholder":640},[498,2322,2323,2326,2329,2332,2334],{"class":500,"line":644},[498,2324,2325],{"class":787},"const",[498,2327,2328],{"class":579}," userAgent ",[498,2330,2331],{"class":575},"=",[498,2333,2305],{"class":653},[498,2335,809],{"class":579},[498,2337,2338],{"class":500,"line":662},[498,2339,641],{"emptyLinePlaceholder":640},[498,2341,2342,2344,2346,2348,2350,2352,2354,2356,2358,2360,2362],{"class":500,"line":675},[498,2343,647],{"class":571},[498,2345,788],{"class":787},[498,2347,576],{"class":575},[498,2349,793],{"class":579},[498,2351,796],{"class":575},[498,2353,799],{"class":579},[498,2355,737],{"class":575},[498,2357,804],{"class":575},[498,2359,766],{"class":653},[498,2361,656],{"class":579},[498,2363,659],{"class":575},[498,2365,2366,2369,2371,2373,2375],{"class":500,"line":687},[498,2367,2368],{"class":665},"  drain",[498,2370,669],{"class":575},[498,2372,2285],{"class":653},[498,2374,681],{"class":579},[498,2376,684],{"class":575},[498,2378,2379,2382,2384,2387,2390,2392,2394],{"class":500,"line":697},[498,2380,2381],{"class":653},"  enrich",[498,2383,669],{"class":575},[498,2385,2386],{"class":575}," (",[498,2388,2389],{"class":995},"ctx",[498,2391,721],{"class":575},[498,2393,1007],{"class":787},[498,2395,867],{"class":575},[498,2397,2398,2401,2403,2405],{"class":500,"line":715},[498,2399,2400],{"class":653},"    userAgent",[498,2402,656],{"class":665},[498,2404,2389],{"class":579},[498,2406,740],{"class":665},[498,2408,2409,2412,2414,2417,2419,2422,2424,2427,2429,2432,2434],{"class":500,"line":726},[498,2410,2411],{"class":579},"    ctx",[498,2413,1017],{"class":575},[498,2415,2416],{"class":579},"event",[498,2418,1017],{"class":575},[498,2420,2421],{"class":579},"region",[498,2423,804],{"class":575},[498,2425,2426],{"class":579}," process",[498,2428,1017],{"class":575},[498,2430,2431],{"class":579},"env",[498,2433,1017],{"class":575},[498,2435,2436],{"class":579},"FLY_REGION\n",[498,2438,2439],{"class":500,"line":734},[498,2440,2441],{"class":575},"  },\n",[498,2443,2444,2446],{"class":500,"line":1241},[498,2445,737],{"class":575},[498,2447,740],{"class":579},[480,2449,2451],{"id":2450},"pipeline-batching-retry","Pipeline (Batching & Retry)",[408,2453,2454,2455,2458],{},"For production, wrap your adapter with ",[412,2456,2457],{},"createDrainPipeline"," to batch events and retry on failure:",[488,2460,2462],{"className":561,"code":2461,"filename":755,"language":564,"meta":494,"style":494},"import type { DrainContext } from 'evlog'\nimport { createEvlogHooks } from 'evlog\u002Fsveltekit'\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 const { handle, handleError } = createEvlogHooks({ drain })\n",[412,2463,2464,2485,2503,2521,2541,2545,2569,2599,2618,2624,2644,2648],{"__ignoreMap":494},[498,2465,2466,2468,2470,2472,2475,2477,2479,2481,2483],{"class":500,"line":501},[498,2467,572],{"class":571},[498,2469,826],{"class":571},[498,2471,576],{"class":575},[498,2473,2474],{"class":579}," DrainContext",[498,2476,583],{"class":575},[498,2478,586],{"class":571},[498,2480,589],{"class":575},[498,2482,840],{"class":507},[498,2484,595],{"class":575},[498,2486,2487,2489,2491,2493,2495,2497,2499,2501],{"class":500,"line":598},[498,2488,572],{"class":571},[498,2490,576],{"class":575},[498,2492,766],{"class":579},[498,2494,583],{"class":575},[498,2496,586],{"class":571},[498,2498,589],{"class":575},[498,2500,414],{"class":507},[498,2502,595],{"class":575},[498,2504,2505,2507,2509,2511,2513,2515,2517,2519],{"class":500,"line":616},[498,2506,572],{"class":571},[498,2508,576],{"class":575},[498,2510,2285],{"class":579},[498,2512,583],{"class":575},[498,2514,586],{"class":571},[498,2516,589],{"class":575},[498,2518,2294],{"class":507},[498,2520,595],{"class":575},[498,2522,2523,2525,2527,2530,2532,2534,2536,2539],{"class":500,"line":637},[498,2524,572],{"class":571},[498,2526,576],{"class":575},[498,2528,2529],{"class":579}," createDrainPipeline",[498,2531,583],{"class":575},[498,2533,586],{"class":571},[498,2535,589],{"class":575},[498,2537,2538],{"class":507},"evlog\u002Fpipeline",[498,2540,595],{"class":575},[498,2542,2543],{"class":500,"line":644},[498,2544,641],{"emptyLinePlaceholder":640},[498,2546,2547,2549,2552,2554,2556,2559,2562,2565,2567],{"class":500,"line":662},[498,2548,2325],{"class":787},[498,2550,2551],{"class":579}," pipeline ",[498,2553,2331],{"class":575},[498,2555,2529],{"class":653},[498,2557,2558],{"class":575},"\u003C",[498,2560,2561],{"class":504},"DrainContext",[498,2563,2564],{"class":575},">",[498,2566,656],{"class":579},[498,2568,659],{"class":575},[498,2570,2571,2574,2576,2578,2581,2583,2586,2588,2591,2593,2596],{"class":500,"line":675},[498,2572,2573],{"class":665},"  batch",[498,2575,669],{"class":575},[498,2577,576],{"class":575},[498,2579,2580],{"class":665}," size",[498,2582,669],{"class":575},[498,2584,2585],{"class":1299}," 50",[498,2587,796],{"class":575},[498,2589,2590],{"class":665}," intervalMs",[498,2592,669],{"class":575},[498,2594,2595],{"class":1299}," 5000",[498,2597,2598],{"class":575}," },\n",[498,2600,2601,2604,2606,2608,2611,2613,2616],{"class":500,"line":687},[498,2602,2603],{"class":665},"  retry",[498,2605,669],{"class":575},[498,2607,576],{"class":575},[498,2609,2610],{"class":665}," maxAttempts",[498,2612,669],{"class":575},[498,2614,2615],{"class":1299}," 3",[498,2617,2598],{"class":575},[498,2619,2620,2622],{"class":500,"line":697},[498,2621,737],{"class":575},[498,2623,740],{"class":579},[498,2625,2626,2628,2631,2633,2636,2638,2641],{"class":500,"line":715},[498,2627,2325],{"class":787},[498,2629,2630],{"class":579}," drain ",[498,2632,2331],{"class":575},[498,2634,2635],{"class":653}," pipeline",[498,2637,656],{"class":579},[498,2639,2640],{"class":653},"createAxiomDrain",[498,2642,2643],{"class":579},"())\n",[498,2645,2646],{"class":500,"line":726},[498,2647,641],{"emptyLinePlaceholder":640},[498,2649,2650,2652,2654,2656,2658,2660,2662,2664,2666,2668,2670,2672,2674,2676],{"class":500,"line":734},[498,2651,647],{"class":571},[498,2653,788],{"class":787},[498,2655,576],{"class":575},[498,2657,793],{"class":579},[498,2659,796],{"class":575},[498,2661,799],{"class":579},[498,2663,737],{"class":575},[498,2665,804],{"class":575},[498,2667,766],{"class":653},[498,2669,656],{"class":579},[498,2671,1030],{"class":575},[498,2673,2630],{"class":579},[498,2675,737],{"class":575},[498,2677,740],{"class":579},[2679,2680,2682,2683,2686,2687,747],"callout",{"color":2681,"icon":13},"info","Call ",[412,2684,2685],{},"drain.flush()"," on server shutdown to ensure all buffered events are sent. See the ",[465,2688,2689],{"href":369},"Pipeline docs",[476,2691,2693],{"id":2692},"tail-sampling","Tail Sampling",[408,2695,1339,2696,2699],{},[412,2697,2698],{},"keep"," to force-retain specific events regardless of head sampling:",[488,2701,2703],{"className":561,"code":2702,"filename":755,"language":564,"meta":494,"style":494},"export const { handle, handleError } = createEvlogHooks({\n  drain: createAxiomDrain(),\n  keep: (ctx) => {\n    if (ctx.duration && ctx.duration > 2000) ctx.shouldKeep = true\n  },\n})\n",[412,2704,2705,2729,2741,2758,2802,2806],{"__ignoreMap":494},[498,2706,2707,2709,2711,2713,2715,2717,2719,2721,2723,2725,2727],{"class":500,"line":501},[498,2708,647],{"class":571},[498,2710,788],{"class":787},[498,2712,576],{"class":575},[498,2714,793],{"class":579},[498,2716,796],{"class":575},[498,2718,799],{"class":579},[498,2720,737],{"class":575},[498,2722,804],{"class":575},[498,2724,766],{"class":653},[498,2726,656],{"class":579},[498,2728,659],{"class":575},[498,2730,2731,2733,2735,2737,2739],{"class":500,"line":598},[498,2732,2368],{"class":665},[498,2734,669],{"class":575},[498,2736,2285],{"class":653},[498,2738,681],{"class":579},[498,2740,684],{"class":575},[498,2742,2743,2746,2748,2750,2752,2754,2756],{"class":500,"line":616},[498,2744,2745],{"class":653},"  keep",[498,2747,669],{"class":575},[498,2749,2386],{"class":575},[498,2751,2389],{"class":995},[498,2753,721],{"class":575},[498,2755,1007],{"class":787},[498,2757,867],{"class":575},[498,2759,2760,2763,2765,2767,2769,2772,2775,2778,2780,2782,2785,2788,2790,2792,2794,2797,2799],{"class":500,"line":637},[498,2761,2762],{"class":571},"    if",[498,2764,2386],{"class":665},[498,2766,2389],{"class":579},[498,2768,1017],{"class":575},[498,2770,2771],{"class":579},"duration",[498,2773,2774],{"class":575}," &&",[498,2776,2777],{"class":579}," ctx",[498,2779,1017],{"class":575},[498,2781,2771],{"class":579},[498,2783,2784],{"class":575}," >",[498,2786,2787],{"class":1299}," 2000",[498,2789,1228],{"class":665},[498,2791,2389],{"class":579},[498,2793,1017],{"class":575},[498,2795,2796],{"class":579},"shouldKeep",[498,2798,804],{"class":575},[498,2800,2801],{"class":1878}," true\n",[498,2803,2804],{"class":500,"line":644},[498,2805,2441],{"class":575},[498,2807,2808,2810],{"class":500,"line":662},[498,2809,737],{"class":575},[498,2811,740],{"class":579},[476,2813,2815],{"id":2814},"route-filtering","Route Filtering",[408,2817,2818,2819,419,2822,2825],{},"Control which routes are logged with ",[412,2820,2821],{},"include",[412,2823,2824],{},"exclude"," patterns:",[488,2827,2829],{"className":561,"code":2828,"filename":755,"language":564,"meta":494,"style":494},"export const { handle, handleError } = createEvlogHooks({\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",[412,2830,2831,2855,2877,2906,2915,2943,2969,2973],{"__ignoreMap":494},[498,2832,2833,2835,2837,2839,2841,2843,2845,2847,2849,2851,2853],{"class":500,"line":501},[498,2834,647],{"class":571},[498,2836,788],{"class":787},[498,2838,576],{"class":575},[498,2840,793],{"class":579},[498,2842,796],{"class":575},[498,2844,799],{"class":579},[498,2846,737],{"class":575},[498,2848,804],{"class":575},[498,2850,766],{"class":653},[498,2852,656],{"class":579},[498,2854,659],{"class":575},[498,2856,2857,2860,2862,2865,2867,2870,2872,2875],{"class":500,"line":598},[498,2858,2859],{"class":665},"  include",[498,2861,669],{"class":575},[498,2863,2864],{"class":579}," [",[498,2866,710],{"class":575},[498,2868,2869],{"class":507},"\u002Fapi\u002F**",[498,2871,710],{"class":575},[498,2873,2874],{"class":579},"]",[498,2876,684],{"class":575},[498,2878,2879,2882,2884,2886,2888,2891,2893,2895,2897,2900,2902,2904],{"class":500,"line":616},[498,2880,2881],{"class":665},"  exclude",[498,2883,669],{"class":575},[498,2885,2864],{"class":579},[498,2887,710],{"class":575},[498,2889,2890],{"class":507},"\u002F_internal\u002F**",[498,2892,710],{"class":575},[498,2894,796],{"class":575},[498,2896,589],{"class":575},[498,2898,2899],{"class":507},"\u002Fhealth",[498,2901,710],{"class":575},[498,2903,2874],{"class":579},[498,2905,684],{"class":575},[498,2907,2908,2911,2913],{"class":500,"line":637},[498,2909,2910],{"class":665},"  routes",[498,2912,669],{"class":575},[498,2914,867],{"class":575},[498,2916,2917,2920,2923,2925,2927,2929,2932,2934,2936,2939,2941],{"class":500,"line":644},[498,2918,2919],{"class":575},"    '",[498,2921,2922],{"class":665},"\u002Fapi\u002Fauth\u002F**",[498,2924,710],{"class":575},[498,2926,669],{"class":575},[498,2928,576],{"class":575},[498,2930,2931],{"class":665}," service",[498,2933,669],{"class":575},[498,2935,589],{"class":575},[498,2937,2938],{"class":507},"auth-service",[498,2940,710],{"class":575},[498,2942,2598],{"class":575},[498,2944,2945,2947,2950,2952,2954,2956,2958,2960,2962,2965,2967],{"class":500,"line":662},[498,2946,2919],{"class":575},[498,2948,2949],{"class":665},"\u002Fapi\u002Fpayment\u002F**",[498,2951,710],{"class":575},[498,2953,669],{"class":575},[498,2955,576],{"class":575},[498,2957,2931],{"class":665},[498,2959,669],{"class":575},[498,2961,589],{"class":575},[498,2963,2964],{"class":507},"payment-service",[498,2966,710],{"class":575},[498,2968,2598],{"class":575},[498,2970,2971],{"class":500,"line":675},[498,2972,2441],{"class":575},[498,2974,2975,2977],{"class":500,"line":687},[498,2976,737],{"class":575},[498,2978,740],{"class":579},[476,2980,2982],{"id":2981},"run-locally","Run Locally",[488,2984,2987],{"className":490,"code":2985,"filename":2986,"language":493,"meta":494,"style":494},"git clone https:\u002F\u002Fgithub.com\u002Fhugorcd\u002Fevlog.git\ncd evlog\npnpm install\npnpm run example:sveltekit\n","Terminal",[412,2988,2989,3000,3007,3014],{"__ignoreMap":494},[498,2990,2991,2994,2997],{"class":500,"line":501},[498,2992,2993],{"class":504},"git",[498,2995,2996],{"class":507}," clone",[498,2998,2999],{"class":507}," https:\u002F\u002Fgithub.com\u002Fhugorcd\u002Fevlog.git\n",[498,3001,3002,3005],{"class":500,"line":598},[498,3003,3004],{"class":653},"cd",[498,3006,511],{"class":507},[498,3008,3009,3011],{"class":500,"line":616},[498,3010,492],{"class":504},[498,3012,3013],{"class":507}," install\n",[498,3015,3016,3018,3021],{"class":500,"line":637},[498,3017,492],{"class":504},[498,3019,3020],{"class":507}," run",[498,3022,3023],{"class":507}," example:sveltekit\n",[408,3025,3026,3027,3031],{},"Open ",[465,3028,3029],{"href":3029,"rel":3030},"http:\u002F\u002Flocalhost:5173",[469]," to explore the interactive test UI.",[3033,3034,3035],"card-group",{},[3036,3037,3041],"card",{"icon":3038,"title":3039,"to":3040},"i-simple-icons-github","Source Code","https:\u002F\u002Fgithub.com\u002Fhugorcd\u002Fevlog\u002Ftree\u002Fmain\u002Fexamples\u002Fsveltekit","Browse the complete SvelteKit example source on GitHub.",[476,3043,3045],{"id":3044},"next-steps","Next Steps",[408,3047,3048,3049,3052],{},"Deepen your ",[3050,3051,221],"strong",{}," integration:",[440,3054,3055,3060,3065,3070],{},[443,3056,3057,3059],{},[465,3058,51],{"href":52},": Design comprehensive events with context layering",[443,3061,3062,3064],{},[465,3063,300],{"href":305},": Send logs to Axiom, Sentry, PostHog, and more",[443,3066,3067,3069],{},[465,3068,175],{"href":176},": Control log volume with head and tail sampling",[443,3071,3072,3074,3075,1902,3077,1906,3079,3081],{},[465,3073,56],{"href":57},": Throw errors with ",[412,3076,1901],{},[412,3078,1905],{},[412,3080,1909],{}," fields",[3083,3084,3085],"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 .sbssI, html code.shiki .sbssI{--shiki-light:#F76D47;--shiki-default:#F78C6C;--shiki-dark:#F78C6C}html pre.shiki code .sfNiH, html code.shiki .sfNiH{--shiki-light:#FF5370;--shiki-default:#FF9CAC;--shiki-dark:#FF9CAC}",{"title":494,"searchDepth":598,"depth":598,"links":3087},[3088,3094,3095,3096,3098,3099,3100,3103,3104,3105,3106],{"id":478,"depth":598,"text":20,"children":3089},[3090,3091,3092,3093],{"id":482,"depth":616,"text":483},{"id":557,"depth":616,"text":558},{"id":750,"depth":616,"text":751},{"id":812,"depth":616,"text":813},{"id":916,"depth":598,"text":51},{"id":1336,"depth":598,"text":429},{"id":1672,"depth":598,"text":3097},"Background work (log.fork)",{"id":1891,"depth":598,"text":1892},{"id":2236,"depth":598,"text":170},{"id":2249,"depth":598,"text":2250,"children":3101},[3102],{"id":2450,"depth":616,"text":2451},{"id":2692,"depth":598,"text":2693},{"id":2814,"depth":598,"text":2815},{"id":2981,"depth":598,"text":2982},{"id":3044,"depth":598,"text":3045},"Automatic wide events, structured errors, drain adapters, enrichers, and tail sampling in SvelteKit applications.","md",[3110],{"label":3039,"icon":3038,"to":3040,"color":3111,"variant":3112},"neutral","subtle",{},{"title":221,"icon":224},{"title":221,"description":3107},"WkcX3IdkNeaG-XXAtRHFDn8gBdjhJEtmJIJmm8rZbWM",[3118,3120],{"title":216,"path":217,"stem":218,"description":3119,"icon":219,"children":-1},"Wide events, structured errors, drain pipeline, tail sampling, route-based services, error handling, and client-side logging in Next.js applications.",{"title":226,"path":227,"stem":228,"description":3121,"icon":229,"children":-1},"Automatic wide events, structured errors, drain adapters, enrichers, and tail sampling in Nitro v2 and v3 applications.",1778325964364]