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