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