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