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