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