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