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