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