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