[{"data":1,"prerenderedAt":1574},["ShallowReactive",2],{"navigation_docs":3,"-start-introduction":439,"-start-introduction-surround":1570},[4,30,80,245,353,408],{"title":5,"path":6,"stem":7,"children":8,"page":29},"Start","\u002Fstart","1.start",[9,14,19,24],{"title":10,"path":11,"stem":12,"icon":13},"Introduction","\u002Fstart\u002Fintroduction","1.start\u002F1.introduction","i-lucide-info",{"title":15,"path":16,"stem":17,"icon":18},"Why start with evlog","\u002Fstart\u002Fwhy-evlog","1.start\u002F2.why-evlog","i-lucide-rocket",{"title":20,"path":21,"stem":22,"icon":23},"Installation","\u002Fstart\u002Finstallation","1.start\u002F3.installation","i-lucide-download",{"title":25,"path":26,"stem":27,"icon":28},"Quick Start","\u002Fstart\u002Fquick-start","1.start\u002F4.quick-start","i-lucide-zap",false,{"title":31,"path":32,"stem":33,"children":34,"page":29},"Learn","\u002Flearn","2.learn",[35,40,45,50,55,60,65,70,75],{"title":36,"path":37,"stem":38,"icon":39},"Overview","\u002Flearn\u002Foverview","2.learn\u002F0.overview","i-lucide-list",{"title":41,"path":42,"stem":43,"icon":44},"Simple Logging","\u002Flearn\u002Fsimple-logging","2.learn\u002F1.simple-logging","i-lucide-terminal",{"title":46,"path":47,"stem":48,"icon":49},"Wide Events","\u002Flearn\u002Fwide-events","2.learn\u002F2.wide-events","i-lucide-layers",{"title":51,"path":52,"stem":53,"icon":54},"Structured Errors","\u002Flearn\u002Fstructured-errors","2.learn\u002F3.structured-errors","i-lucide-shield-alert",{"title":56,"path":57,"stem":58,"icon":59},"Lifecycle","\u002Flearn\u002Flifecycle","2.learn\u002F4.lifecycle","i-lucide-arrow-right-left",{"title":61,"path":62,"stem":63,"icon":64},"Sampling","\u002Flearn\u002Fsampling","2.learn\u002F5.sampling","i-lucide-filter",{"title":66,"path":67,"stem":68,"icon":69},"Auto-Redaction","\u002Flearn\u002Fredaction","2.learn\u002F6.redaction","i-lucide-eye-off",{"title":71,"path":72,"stem":73,"icon":74},"Typed Fields","\u002Flearn\u002Ftyped-fields","2.learn\u002F7.typed-fields","i-simple-icons-typescript",{"title":76,"path":77,"stem":78,"icon":79},"Catalogs","\u002Flearn\u002Fcatalogs","2.learn\u002F8.catalogs","i-lucide-book-open",{"title":81,"path":82,"stem":83,"children":84,"page":29},"Integrate","\u002Fintegrate","3.integrate",[85,89,157],{"title":36,"path":86,"stem":87,"icon":88},"\u002Fintegrate\u002Foverview","3.integrate\u002F0.overview","i-lucide-plug",{"title":90,"path":91,"stem":92,"children":93,"page":29},"Adapters","\u002Fintegrate\u002Fadapters","3.integrate\u002Fadapters",[94,97,137],{"title":36,"path":95,"stem":96,"icon":39},"\u002Fintegrate\u002Fadapters\u002Foverview","3.integrate\u002Fadapters\u002F01.overview",{"title":98,"path":99,"stem":100,"children":101,"page":29},"Cloud","\u002Fintegrate\u002Fadapters\u002Fcloud","3.integrate\u002Fadapters\u002Fcloud",[102,107,112,117,122,127,132],{"title":103,"path":104,"stem":105,"icon":106},"Axiom","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Faxiom","3.integrate\u002Fadapters\u002Fcloud\u002F01.axiom","i-custom-axiom",{"title":108,"path":109,"stem":110,"icon":111},"OTLP","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fotlp","3.integrate\u002Fadapters\u002Fcloud\u002F02.otlp","i-simple-icons-opentelemetry",{"title":113,"path":114,"stem":115,"icon":116},"PostHog","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fposthog","3.integrate\u002Fadapters\u002Fcloud\u002F03.posthog","i-simple-icons-posthog",{"title":118,"path":119,"stem":120,"icon":121},"Sentry","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fsentry","3.integrate\u002Fadapters\u002Fcloud\u002F04.sentry","i-simple-icons-sentry",{"title":123,"path":124,"stem":125,"icon":126},"Better Stack","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fbetter-stack","3.integrate\u002Fadapters\u002Fcloud\u002F05.better-stack","i-simple-icons-betterstack",{"title":128,"path":129,"stem":130,"icon":131},"Datadog","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fdatadog","3.integrate\u002Fadapters\u002Fcloud\u002F06.datadog","i-simple-icons-datadog",{"title":133,"path":134,"stem":135,"icon":136},"HyperDX","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fhyperdx","3.integrate\u002Fadapters\u002Fcloud\u002F07.hyperdx","i-custom-hyperdx",{"title":138,"path":139,"stem":140,"children":141,"page":29},"Self-Hosted","\u002Fintegrate\u002Fadapters\u002Fself-hosted","3.integrate\u002Fadapters\u002Fself-hosted",[142,147,152],{"title":143,"path":144,"stem":145,"icon":146},"File System","\u002Fintegrate\u002Fadapters\u002Fself-hosted\u002Ffs","3.integrate\u002Fadapters\u002Fself-hosted\u002F01.fs","i-lucide-hard-drive",{"title":148,"path":149,"stem":150,"icon":151},"NuxtHub","\u002Fintegrate\u002Fadapters\u002Fself-hosted\u002Fnuxthub","3.integrate\u002Fadapters\u002Fself-hosted\u002F02.nuxthub","i-simple-icons-nuxt",{"title":153,"path":154,"stem":155,"icon":156},"Memory","\u002Fintegrate\u002Fadapters\u002Fself-hosted\u002Fmemory","3.integrate\u002Fadapters\u002Fself-hosted\u002F03.memory","i-lucide-cpu",{"title":158,"path":159,"stem":160,"children":161,"page":29},"Frameworks","\u002Fintegrate\u002Fframeworks","3.integrate\u002Fframeworks",[162,166,171,176,181,186,191,196,201,206,211,216,221,226,230,235,240],{"title":36,"path":163,"stem":164,"icon":165},"\u002Fintegrate\u002Fframeworks\u002Foverview","3.integrate\u002Fframeworks\u002F00.overview","i-lucide-layout-grid",{"title":167,"path":168,"stem":169,"icon":170},"Nuxt","\u002Fintegrate\u002Fframeworks\u002Fnuxt","3.integrate\u002Fframeworks\u002F01.nuxt","i-simple-icons-nuxtdotjs",{"title":172,"path":173,"stem":174,"icon":175},"Next.js","\u002Fintegrate\u002Fframeworks\u002Fnextjs","3.integrate\u002Fframeworks\u002F02.nextjs","i-simple-icons-nextdotjs",{"title":177,"path":178,"stem":179,"icon":180},"SvelteKit","\u002Fintegrate\u002Fframeworks\u002Fsveltekit","3.integrate\u002Fframeworks\u002F03.sveltekit","i-simple-icons-svelte",{"title":182,"path":183,"stem":184,"icon":185},"Nitro","\u002Fintegrate\u002Fframeworks\u002Fnitro","3.integrate\u002Fframeworks\u002F04.nitro","i-custom-nitro",{"title":187,"path":188,"stem":189,"icon":190},"TanStack Start","\u002Fintegrate\u002Fframeworks\u002Ftanstack-start","3.integrate\u002Fframeworks\u002F05.tanstack-start","i-custom-tanstack",{"title":192,"path":193,"stem":194,"icon":195},"NestJS","\u002Fintegrate\u002Fframeworks\u002Fnestjs","3.integrate\u002Fframeworks\u002F06.nestjs","i-simple-icons-nestjs",{"title":197,"path":198,"stem":199,"icon":200},"Express","\u002Fintegrate\u002Fframeworks\u002Fexpress","3.integrate\u002Fframeworks\u002F07.express","i-simple-icons-express",{"title":202,"path":203,"stem":204,"icon":205},"Hono","\u002Fintegrate\u002Fframeworks\u002Fhono","3.integrate\u002Fframeworks\u002F08.hono","i-simple-icons-hono",{"title":207,"path":208,"stem":209,"icon":210},"Fastify","\u002Fintegrate\u002Fframeworks\u002Ffastify","3.integrate\u002Fframeworks\u002F09.fastify","i-simple-icons-fastify",{"title":212,"path":213,"stem":214,"icon":215},"Elysia","\u002Fintegrate\u002Fframeworks\u002Felysia","3.integrate\u002Fframeworks\u002F10.elysia","i-custom-elysia",{"title":217,"path":218,"stem":219,"icon":220},"React Router","\u002Fintegrate\u002Fframeworks\u002Freact-router","3.integrate\u002Fframeworks\u002F11.react-router","i-custom-reactrouter",{"title":222,"path":223,"stem":224,"icon":225},"Cloudflare Workers","\u002Fintegrate\u002Fframeworks\u002Fcloudflare-workers","3.integrate\u002Fframeworks\u002F12.cloudflare-workers","i-simple-icons-cloudflare",{"title":227,"path":228,"stem":229,"icon":74},"Standalone","\u002Fintegrate\u002Fframeworks\u002Fstandalone","3.integrate\u002Fframeworks\u002F13.standalone",{"title":231,"path":232,"stem":233,"icon":234},"Astro","\u002Fintegrate\u002Fframeworks\u002Fastro","3.integrate\u002Fframeworks\u002F14.astro","i-simple-icons-astro",{"title":236,"path":237,"stem":238,"icon":239},"oRPC","\u002Fintegrate\u002Fframeworks\u002Forpc","3.integrate\u002Fframeworks\u002F15.orpc","i-lucide-network",{"title":241,"path":242,"stem":243,"icon":244},"AWS Lambda","\u002Fintegrate\u002Fframeworks\u002Faws-lambda","3.integrate\u002Fframeworks\u002F16.aws-lambda","i-custom-lambda",{"title":246,"path":247,"stem":248,"children":249,"page":29},"Use Cases","\u002Fuse-cases","4.use-cases",[250,254,259,288,316,348],{"title":36,"path":251,"stem":252,"icon":253},"\u002Fuse-cases\u002Foverview","4.use-cases\u002F0.overview","i-lucide-list-checks",{"title":255,"path":256,"stem":257,"icon":258},"Client Logging","\u002Fuse-cases\u002Fclient-logging","4.use-cases\u002F1.client-logging","i-lucide-monitor",{"title":260,"icon":261,"path":262,"stem":263,"children":264,"page":29},"AI SDK","i-simple-icons-vercel","\u002Fuse-cases\u002Fai-sdk","4.use-cases\u002F2.ai-sdk",[265,268,273,278,283],{"title":36,"path":266,"stem":267,"icon":39},"\u002Fuse-cases\u002Fai-sdk\u002Foverview","4.use-cases\u002F2.ai-sdk\u002F01.overview",{"title":269,"path":270,"stem":271,"icon":272},"Usage","\u002Fuse-cases\u002Fai-sdk\u002Fusage","4.use-cases\u002F2.ai-sdk\u002F02.usage","i-lucide-code",{"title":274,"path":275,"stem":276,"icon":277},"Options","\u002Fuse-cases\u002Fai-sdk\u002Foptions","4.use-cases\u002F2.ai-sdk\u002F03.options","i-lucide-sliders",{"title":279,"path":280,"stem":281,"icon":282},"Metadata","\u002Fuse-cases\u002Fai-sdk\u002Fmetadata","4.use-cases\u002F2.ai-sdk\u002F04.metadata","i-lucide-database",{"title":284,"path":285,"stem":286,"icon":287},"Telemetry","\u002Fuse-cases\u002Fai-sdk\u002Ftelemetry","4.use-cases\u002F2.ai-sdk\u002F05.telemetry","i-lucide-activity",{"title":289,"icon":290,"path":291,"stem":292,"children":293,"page":29},"Better Auth","i-simple-icons-betterauth","\u002Fuse-cases\u002Fbetter-auth","4.use-cases\u002F3.better-auth",[294,297,302,307,311],{"title":36,"path":295,"stem":296,"icon":39},"\u002Fuse-cases\u002Fbetter-auth\u002Foverview","4.use-cases\u002F3.better-auth\u002F01.overview",{"title":298,"path":299,"stem":300,"icon":301},"Identify User","\u002Fuse-cases\u002Fbetter-auth\u002Fidentify-user","4.use-cases\u002F3.better-auth\u002F02.identify-user","i-lucide-user-check",{"title":303,"path":304,"stem":305,"icon":306},"Middleware","\u002Fuse-cases\u002Fbetter-auth\u002Fmiddleware","4.use-cases\u002F3.better-auth\u002F03.middleware","i-lucide-shield",{"title":308,"path":309,"stem":310,"icon":258},"Client Sync","\u002Fuse-cases\u002Fbetter-auth\u002Fclient-sync","4.use-cases\u002F3.better-auth\u002F04.client-sync",{"title":312,"path":313,"stem":314,"icon":315},"Performance","\u002Fuse-cases\u002Fbetter-auth\u002Fperformance","4.use-cases\u002F3.better-auth\u002F05.performance","i-lucide-gauge",{"title":317,"icon":318,"path":319,"stem":320,"children":321,"page":29},"Audit Logs","i-lucide-shield-check","\u002Fuse-cases\u002Faudit","4.use-cases\u002F4.audit",[322,325,330,335,340,344],{"title":36,"path":323,"stem":324,"icon":39},"\u002Fuse-cases\u002Faudit\u002Foverview","4.use-cases\u002F4.audit\u002F01.overview",{"title":326,"path":327,"stem":328,"icon":329},"Schema","\u002Fuse-cases\u002Faudit\u002Fschema","4.use-cases\u002F4.audit\u002F02.schema","i-lucide-file-text",{"title":331,"path":332,"stem":333,"icon":334},"Recording","\u002Fuse-cases\u002Faudit\u002Frecording","4.use-cases\u002F4.audit\u002F03.recording","i-lucide-pen-line",{"title":336,"path":337,"stem":338,"icon":339},"Drains","\u002Fuse-cases\u002Faudit\u002Fpipeline","4.use-cases\u002F4.audit\u002F04.pipeline","i-lucide-link",{"title":341,"path":342,"stem":343,"icon":318},"Compliance","\u002Fuse-cases\u002Faudit\u002Fcompliance","4.use-cases\u002F4.audit\u002F05.compliance",{"title":345,"path":346,"stem":347,"icon":79},"Recipes","\u002Fuse-cases\u002Faudit\u002Frecipes","4.use-cases\u002F4.audit\u002F06.recipes",{"title":349,"path":350,"stem":351,"icon":352},"Enrichers","\u002Fuse-cases\u002Fenrichers","4.use-cases\u002F5.enrichers","i-lucide-sparkles",{"title":354,"path":355,"stem":356,"children":357,"page":29},"Extend","\u002Fextend","5.extend",[358,362,367,372,377,381,385,389,393,398,403],{"title":36,"path":359,"stem":360,"icon":361},"\u002Fextend\u002Foverview","5.extend\u002F0.overview","i-lucide-blocks",{"title":363,"path":364,"stem":365,"icon":366},"Stream","\u002Fextend\u002Fstream","5.extend\u002F1.stream","i-lucide-radio-tower",{"title":368,"path":369,"stem":370,"icon":371},"Custom framework","\u002Fextend\u002Fcustom-framework","5.extend\u002F10.custom-framework","i-lucide-puzzle",{"title":373,"path":374,"stem":375,"icon":376},"FS reader","\u002Fextend\u002Ffs-reader","5.extend\u002F2.fs-reader","i-lucide-folder-search",{"title":345,"path":378,"stem":379,"icon":380},"\u002Fextend\u002Fconsumer-recipes","5.extend\u002F3.consumer-recipes","i-lucide-chef-hat",{"title":382,"path":383,"stem":384,"icon":361},"Plugins","\u002Fextend\u002Fplugins","5.extend\u002F4.plugins",{"title":386,"path":387,"stem":388,"icon":352},"Custom enrichers","\u002Fextend\u002Fcustom-enrichers","5.extend\u002F5.custom-enrichers",{"title":390,"path":391,"stem":392,"icon":64},"Tail sampling","\u002Fextend\u002Ftail-sampling","5.extend\u002F6.tail-sampling",{"title":394,"path":395,"stem":396,"icon":397},"Identity headers","\u002Fextend\u002Fidentity-headers","5.extend\u002F7.identity-headers","i-lucide-fingerprint",{"title":399,"path":400,"stem":401,"icon":402},"Custom drains","\u002Fextend\u002Fcustom-drains","5.extend\u002F8.custom-drains","i-lucide-share-2",{"title":404,"path":405,"stem":406,"icon":407},"Drain pipeline","\u002Fextend\u002Fdrain-pipeline","5.extend\u002F9.drain-pipeline","i-lucide-workflow",{"title":409,"path":410,"stem":411,"children":412,"page":29},"Reference","\u002Freference","6.reference",[413,418,421,426,430,435],{"title":414,"path":415,"stem":416,"icon":417},"Configuration","\u002Freference\u002Fconfiguration","6.reference\u002F1.configuration","i-lucide-settings",{"title":312,"path":419,"stem":420,"icon":315},"\u002Freference\u002Fperformance","6.reference\u002F2.performance",{"title":422,"path":423,"stem":424,"icon":425},"Vite Plugin","\u002Freference\u002Fvite-plugin","6.reference\u002F3.vite-plugin","i-custom-vite",{"title":427,"path":428,"stem":429,"icon":318},"Best Practices","\u002Freference\u002Fbest-practices","6.reference\u002F4.best-practices",{"title":431,"path":432,"stem":433,"icon":434},"vs Other Loggers","\u002Freference\u002Fvs-other-loggers","6.reference\u002F5.vs-other-loggers","i-lucide-scale",{"title":436,"path":437,"stem":438,"icon":352},"Agent Skills","\u002Freference\u002Fagent-skills","6.reference\u002F6.agent-skills",{"id":440,"title":10,"body":441,"description":1555,"extension":1556,"links":1557,"meta":1566,"navigation":1567,"path":11,"seo":1568,"stem":12,"__hash__":1569},"docs\u002F1.start\u002F1.introduction.md",{"type":442,"value":443,"toc":1544},"minimark",[444,457,474,479,482,487,509,522,526,529,592,599,603,606,610,616,758,761,764,1187,1190,1193,1205,1458,1462,1469,1492,1502,1506,1540],[445,446,447,451,452,456],"p",{},[448,449,450],"strong",{},"evlog"," is a modern TypeScript logger built for everything you ship. It gives you simple structured logs (a drop-in for ",[453,454,455],"code",{},"console.log",", pino, or consola), wide events that accumulate context across an operation, and structured errors that explain why they happened — all in one API, all behind the same drain pipeline. Use it in CLIs, libraries, background jobs, edge workers, and HTTP handlers without switching loggers.",[445,458,459,460,467,468,473],{},"Inspired by ",[461,462,466],"a",{"href":463,"rel":464},"https:\u002F\u002Floggingsucks.com\u002F",[465],"nofollow","Logging Sucks"," by ",[461,469,472],{"href":470,"rel":471},"https:\u002F\u002Fx.com\u002Fboristane",[465],"Boris Tane",".",[475,476,478],"h2",{"id":477},"philosophy","Philosophy",[445,480,481],{},"Traditional logging is broken. Your logs are scattered across dozens of files. Each request generates 10+ log lines. When something goes wrong, you're left grep-ing through noise hoping to find signal.",[445,483,484,486],{},[448,485,450],{}," takes a different approach:",[488,489,490,498,501,504],"card-group",{},[491,492,494,495,497],"card",{"icon":44,"title":493},"Structured Logging","Replace ",[453,496,455],{}," with typed, structured events that flow through a drain pipeline. Same level filtering, redaction, and pretty\u002FJSON output as pino or consola.",[491,499,500],{"icon":49,"title":46},"Accumulate context over any unit of work (a request, script, or job) and emit once. The two modes coexist — neither is an upgrade of the other.",[491,502,503],{"icon":54,"title":51},"Errors that explain why they occurred and how to fix them.",[491,505,508],{"icon":506,"title":507},"i-lucide-palette","Pretty for Dev","Human-readable in development, machine-parseable JSON in production.",[510,511,514,515,518,519,521],"callout",{"color":512,"icon":513},"info","i-lucide-globe","Not running an HTTP framework? See ",[461,516,517],{"href":228},"Standalone TypeScript"," for scripts, workers, and CLIs, and ",[461,520,222],{"href":223}," for the edge runtime.",[475,523,525],{"id":524},"why-evlog-over-pino-winston-or-consola","Why evlog over pino, winston, or consola",[445,527,528],{},"evlog is a fully-featured general-purpose logger that happens to also do wide events. Concretely:",[530,531,532,543,561,578],"ul",{},[533,534,535,538,539,542],"li",{},[448,536,537],{},"Zero transitive dependencies"," and ~6 kB gzip — nothing to audit, nothing that breaks on the next Node LTS. Benchmarked at ",[461,540,541],{"href":419},"~3 µs\u002Frequest",", 7.7x faster than pino in the wide event pattern (1 event vs 4 log lines) and competitive on every other path.",[533,544,545,548,549,552,553,556,557,560],{},[448,546,547],{},"Same API in every context"," — scripts, frameworks, edge runtimes, browser, library code. No ",[453,550,551],{},"pino-http"," vs ",[453,554,555],{},"pino"," split, no separate ",[453,558,559],{},"consola"," reporters per environment.",[533,562,563,577],{},[448,564,565,566,569,570,569,573,576],{},"Structured errors with ",[453,567,568],{},"why"," \u002F ",[453,571,572],{},"fix",[453,574,575],{},"link"," built in"," — your error toast finally tells users what went wrong and what to do, your on-call stops reverse-engineering stack traces.",[533,579,580,583,584,587,588,591],{},[448,581,582],{},"Wide events as a free upgrade path"," — when you need to correlate context across an operation, the same logger gives you ",[453,585,586],{},"log.set"," + ",[453,589,590],{},"log.emit"," instead of stitching log lines together later.",[445,593,594,595,598],{},"See the full ",[461,596,597],{"href":432},"feature comparison"," (parity matrix, honest gaps, and migration snippets) for a side-by-side with pino, winston, and consola.",[475,600,602],{"id":601},"three-ways-to-log","Three Ways to Log",[445,604,605],{},"evlog provides three APIs for different contexts. You can use all three in the same project.",[607,608,41],"h3",{"id":609},"simple-logging",[445,611,612,613,615],{},"Fire-and-forget structured logs. Replace ",[453,614,455],{},", consola, or pino:",[617,618,624],"pre",{"className":619,"code":620,"filename":621,"language":622,"meta":623,"style":623},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import { log } from 'evlog'\n\nlog.info('auth', 'User logged in')\nlog.error({ action: 'payment', error: 'card_declined', userId: 42 })\n","src\u002Findex.ts","typescript","",[453,625,626,658,665,700],{"__ignoreMap":623},[627,628,631,635,639,643,646,649,652,655],"span",{"class":629,"line":630},"line",1,[627,632,634],{"class":633},"s7zQu","import",[627,636,638],{"class":637},"sMK4o"," {",[627,640,642],{"class":641},"sTEyZ"," log",[627,644,645],{"class":637}," }",[627,647,648],{"class":633}," from",[627,650,651],{"class":637}," '",[627,653,450],{"class":654},"sfazB",[627,656,657],{"class":637},"'\n",[627,659,661],{"class":629,"line":660},2,[627,662,664],{"emptyLinePlaceholder":663},true,"\n",[627,666,668,671,673,676,679,682,685,687,690,692,695,697],{"class":629,"line":667},3,[627,669,670],{"class":641},"log",[627,672,473],{"class":637},[627,674,512],{"class":675},"s2Zo4",[627,677,678],{"class":641},"(",[627,680,681],{"class":637},"'",[627,683,684],{"class":654},"auth",[627,686,681],{"class":637},[627,688,689],{"class":637},",",[627,691,651],{"class":637},[627,693,694],{"class":654},"User logged in",[627,696,681],{"class":637},[627,698,699],{"class":641},")\n",[627,701,703,705,707,710,712,715,719,722,724,727,729,731,734,736,738,741,743,745,748,750,754,756],{"class":629,"line":702},4,[627,704,670],{"class":641},[627,706,473],{"class":637},[627,708,709],{"class":675},"error",[627,711,678],{"class":641},[627,713,714],{"class":637},"{",[627,716,718],{"class":717},"swJcz"," action",[627,720,721],{"class":637},":",[627,723,651],{"class":637},[627,725,726],{"class":654},"payment",[627,728,681],{"class":637},[627,730,689],{"class":637},[627,732,733],{"class":717}," error",[627,735,721],{"class":637},[627,737,651],{"class":637},[627,739,740],{"class":654},"card_declined",[627,742,681],{"class":637},[627,744,689],{"class":637},[627,746,747],{"class":717}," userId",[627,749,721],{"class":637},[627,751,753],{"class":752},"sbssI"," 42",[627,755,645],{"class":637},[627,757,699],{"class":641},[607,759,46],{"id":760},"wide-events",[445,762,763],{},"Accumulate context progressively over any operation, then emit a single comprehensive event:",[765,766,767,900,1030],"code-group",{},[617,768,771],{"className":619,"code":769,"filename":770,"language":622,"meta":623,"style":623},"import { createLogger } from 'evlog'\n\nconst log = createLogger({ jobId: 'sync-001', queue: 'emails' })\nlog.set({ batch: { size: 50, processed: 50 } })\nlog.emit()\n","scripts\u002Fsync-job.ts",[453,772,773,792,796,844,887],{"__ignoreMap":623},[627,774,775,777,779,782,784,786,788,790],{"class":629,"line":630},[627,776,634],{"class":633},[627,778,638],{"class":637},[627,780,781],{"class":641}," createLogger",[627,783,645],{"class":637},[627,785,648],{"class":633},[627,787,651],{"class":637},[627,789,450],{"class":654},[627,791,657],{"class":637},[627,793,794],{"class":629,"line":660},[627,795,664],{"emptyLinePlaceholder":663},[627,797,798,802,805,808,810,812,814,817,819,821,824,826,828,831,833,835,838,840,842],{"class":629,"line":667},[627,799,801],{"class":800},"spNyl","const",[627,803,804],{"class":641}," log ",[627,806,807],{"class":637},"=",[627,809,781],{"class":675},[627,811,678],{"class":641},[627,813,714],{"class":637},[627,815,816],{"class":717}," jobId",[627,818,721],{"class":637},[627,820,651],{"class":637},[627,822,823],{"class":654},"sync-001",[627,825,681],{"class":637},[627,827,689],{"class":637},[627,829,830],{"class":717}," queue",[627,832,721],{"class":637},[627,834,651],{"class":637},[627,836,837],{"class":654},"emails",[627,839,681],{"class":637},[627,841,645],{"class":637},[627,843,699],{"class":641},[627,845,846,848,850,853,855,857,860,862,864,867,869,872,874,877,879,881,883,885],{"class":629,"line":702},[627,847,670],{"class":641},[627,849,473],{"class":637},[627,851,852],{"class":675},"set",[627,854,678],{"class":641},[627,856,714],{"class":637},[627,858,859],{"class":717}," batch",[627,861,721],{"class":637},[627,863,638],{"class":637},[627,865,866],{"class":717}," size",[627,868,721],{"class":637},[627,870,871],{"class":752}," 50",[627,873,689],{"class":637},[627,875,876],{"class":717}," processed",[627,878,721],{"class":637},[627,880,871],{"class":752},[627,882,645],{"class":637},[627,884,645],{"class":637},[627,886,699],{"class":641},[627,888,890,892,894,897],{"class":629,"line":889},5,[627,891,670],{"class":641},[627,893,473],{"class":637},[627,895,896],{"class":675},"emit",[627,898,899],{"class":641},"()\n",[617,901,904],{"className":619,"code":902,"filename":903,"language":622,"meta":623,"style":623},"import { createRequestLogger } from 'evlog'\n\nconst log = createRequestLogger({ method: 'POST', path: '\u002Fapi\u002Fcheckout' })\nlog.set({ user: { id: 1, plan: 'pro' } })\nlog.emit()\n","src\u002Fworker.ts",[453,905,906,925,929,973,1020],{"__ignoreMap":623},[627,907,908,910,912,915,917,919,921,923],{"class":629,"line":630},[627,909,634],{"class":633},[627,911,638],{"class":637},[627,913,914],{"class":641}," createRequestLogger",[627,916,645],{"class":637},[627,918,648],{"class":633},[627,920,651],{"class":637},[627,922,450],{"class":654},[627,924,657],{"class":637},[627,926,927],{"class":629,"line":660},[627,928,664],{"emptyLinePlaceholder":663},[627,930,931,933,935,937,939,941,943,946,948,950,953,955,957,960,962,964,967,969,971],{"class":629,"line":667},[627,932,801],{"class":800},[627,934,804],{"class":641},[627,936,807],{"class":637},[627,938,914],{"class":675},[627,940,678],{"class":641},[627,942,714],{"class":637},[627,944,945],{"class":717}," method",[627,947,721],{"class":637},[627,949,651],{"class":637},[627,951,952],{"class":654},"POST",[627,954,681],{"class":637},[627,956,689],{"class":637},[627,958,959],{"class":717}," path",[627,961,721],{"class":637},[627,963,651],{"class":637},[627,965,966],{"class":654},"\u002Fapi\u002Fcheckout",[627,968,681],{"class":637},[627,970,645],{"class":637},[627,972,699],{"class":641},[627,974,975,977,979,981,983,985,988,990,992,995,997,1000,1002,1005,1007,1009,1012,1014,1016,1018],{"class":629,"line":702},[627,976,670],{"class":641},[627,978,473],{"class":637},[627,980,852],{"class":675},[627,982,678],{"class":641},[627,984,714],{"class":637},[627,986,987],{"class":717}," user",[627,989,721],{"class":637},[627,991,638],{"class":637},[627,993,994],{"class":717}," id",[627,996,721],{"class":637},[627,998,999],{"class":752}," 1",[627,1001,689],{"class":637},[627,1003,1004],{"class":717}," plan",[627,1006,721],{"class":637},[627,1008,651],{"class":637},[627,1010,1011],{"class":654},"pro",[627,1013,681],{"class":637},[627,1015,645],{"class":637},[627,1017,645],{"class":637},[627,1019,699],{"class":641},[627,1021,1022,1024,1026,1028],{"class":629,"line":889},[627,1023,670],{"class":641},[627,1025,473],{"class":637},[627,1027,896],{"class":675},[627,1029,899],{"class":641},[617,1031,1034],{"className":619,"code":1032,"filename":1033,"language":622,"meta":623,"style":623},"import { useLogger } from 'evlog'\n\nexport default defineEventHandler(async (event) => {\n  const log = useLogger(event)\n  log.set({ user: { id: 1, plan: 'pro' } })\n  return { success: true }\n  \u002F\u002F auto-emitted on response end\n})\n","server\u002Fapi\u002Fcheckout.post.ts",[453,1035,1036,1055,1059,1091,1109,1152,1172,1179],{"__ignoreMap":623},[627,1037,1038,1040,1042,1045,1047,1049,1051,1053],{"class":629,"line":630},[627,1039,634],{"class":633},[627,1041,638],{"class":637},[627,1043,1044],{"class":641}," useLogger",[627,1046,645],{"class":637},[627,1048,648],{"class":633},[627,1050,651],{"class":637},[627,1052,450],{"class":654},[627,1054,657],{"class":637},[627,1056,1057],{"class":629,"line":660},[627,1058,664],{"emptyLinePlaceholder":663},[627,1060,1061,1064,1067,1070,1072,1075,1078,1082,1085,1088],{"class":629,"line":667},[627,1062,1063],{"class":633},"export",[627,1065,1066],{"class":633}," default",[627,1068,1069],{"class":675}," defineEventHandler",[627,1071,678],{"class":641},[627,1073,1074],{"class":800},"async",[627,1076,1077],{"class":637}," (",[627,1079,1081],{"class":1080},"sHdIc","event",[627,1083,1084],{"class":637},")",[627,1086,1087],{"class":800}," =>",[627,1089,1090],{"class":637}," {\n",[627,1092,1093,1096,1098,1101,1103,1105,1107],{"class":629,"line":702},[627,1094,1095],{"class":800},"  const",[627,1097,642],{"class":641},[627,1099,1100],{"class":637}," =",[627,1102,1044],{"class":675},[627,1104,678],{"class":717},[627,1106,1081],{"class":641},[627,1108,699],{"class":717},[627,1110,1111,1114,1116,1118,1120,1122,1124,1126,1128,1130,1132,1134,1136,1138,1140,1142,1144,1146,1148,1150],{"class":629,"line":889},[627,1112,1113],{"class":641},"  log",[627,1115,473],{"class":637},[627,1117,852],{"class":675},[627,1119,678],{"class":717},[627,1121,714],{"class":637},[627,1123,987],{"class":717},[627,1125,721],{"class":637},[627,1127,638],{"class":637},[627,1129,994],{"class":717},[627,1131,721],{"class":637},[627,1133,999],{"class":752},[627,1135,689],{"class":637},[627,1137,1004],{"class":717},[627,1139,721],{"class":637},[627,1141,651],{"class":637},[627,1143,1011],{"class":654},[627,1145,681],{"class":637},[627,1147,645],{"class":637},[627,1149,645],{"class":637},[627,1151,699],{"class":717},[627,1153,1155,1158,1160,1163,1165,1169],{"class":629,"line":1154},6,[627,1156,1157],{"class":633},"  return",[627,1159,638],{"class":637},[627,1161,1162],{"class":717}," success",[627,1164,721],{"class":637},[627,1166,1168],{"class":1167},"sfNiH"," true",[627,1170,1171],{"class":637}," }\n",[627,1173,1175],{"class":629,"line":1174},7,[627,1176,1178],{"class":1177},"sHwdD","  \u002F\u002F auto-emitted on response end\n",[627,1180,1182,1185],{"class":629,"line":1181},8,[627,1183,1184],{"class":637},"}",[627,1186,699],{"class":641},[445,1188,1189],{},"One log, all context. Everything you need to understand what happened.",[607,1191,51],{"id":1192},"structured-errors",[445,1194,1195,1196,1198,1199,1201,1202,1204],{},"Errors with actionable context: ",[453,1197,568],{}," it happened, how to ",[453,1200,572],{}," it, and a ",[453,1203,575],{}," to docs:",[765,1206,1207,1331],{},[617,1208,1210],{"className":619,"code":1209,"filename":1033,"language":622,"meta":623,"style":623},"import { createError } from 'evlog'\n\nthrow createError({\n  message: 'Payment failed',\n  status: 402,\n  why: 'Card declined by issuer (insufficient funds)',\n  fix: 'Try a different payment method or contact your bank',\n  link: 'https:\u002F\u002Fdocs.example.com\u002Fpayments\u002Fdeclined',\n})\n",[453,1211,1212,1231,1235,1247,1264,1276,1292,1308,1324],{"__ignoreMap":623},[627,1213,1214,1216,1218,1221,1223,1225,1227,1229],{"class":629,"line":630},[627,1215,634],{"class":633},[627,1217,638],{"class":637},[627,1219,1220],{"class":641}," createError",[627,1222,645],{"class":637},[627,1224,648],{"class":633},[627,1226,651],{"class":637},[627,1228,450],{"class":654},[627,1230,657],{"class":637},[627,1232,1233],{"class":629,"line":660},[627,1234,664],{"emptyLinePlaceholder":663},[627,1236,1237,1240,1242,1244],{"class":629,"line":667},[627,1238,1239],{"class":633},"throw",[627,1241,1220],{"class":675},[627,1243,678],{"class":641},[627,1245,1246],{"class":637},"{\n",[627,1248,1249,1252,1254,1256,1259,1261],{"class":629,"line":702},[627,1250,1251],{"class":717},"  message",[627,1253,721],{"class":637},[627,1255,651],{"class":637},[627,1257,1258],{"class":654},"Payment failed",[627,1260,681],{"class":637},[627,1262,1263],{"class":637},",\n",[627,1265,1266,1269,1271,1274],{"class":629,"line":889},[627,1267,1268],{"class":717},"  status",[627,1270,721],{"class":637},[627,1272,1273],{"class":752}," 402",[627,1275,1263],{"class":637},[627,1277,1278,1281,1283,1285,1288,1290],{"class":629,"line":1154},[627,1279,1280],{"class":717},"  why",[627,1282,721],{"class":637},[627,1284,651],{"class":637},[627,1286,1287],{"class":654},"Card declined by issuer (insufficient funds)",[627,1289,681],{"class":637},[627,1291,1263],{"class":637},[627,1293,1294,1297,1299,1301,1304,1306],{"class":629,"line":1174},[627,1295,1296],{"class":717},"  fix",[627,1298,721],{"class":637},[627,1300,651],{"class":637},[627,1302,1303],{"class":654},"Try a different payment method or contact your bank",[627,1305,681],{"class":637},[627,1307,1263],{"class":637},[627,1309,1310,1313,1315,1317,1320,1322],{"class":629,"line":1181},[627,1311,1312],{"class":717},"  link",[627,1314,721],{"class":637},[627,1316,651],{"class":637},[627,1318,1319],{"class":654},"https:\u002F\u002Fdocs.example.com\u002Fpayments\u002Fdeclined",[627,1321,681],{"class":637},[627,1323,1263],{"class":637},[627,1325,1327,1329],{"class":629,"line":1326},9,[627,1328,1184],{"class":637},[627,1330,699],{"class":641},[617,1332,1337],{"className":1333,"code":1334,"filename":1335,"language":1336,"meta":623,"style":623},"language-json shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","{\n  \"statusCode\": 402,\n  \"message\": \"Payment failed\",\n  \"data\": {\n    \"why\": \"Card declined by issuer (insufficient funds)\",\n    \"fix\": \"Try a different payment method or contact your bank\",\n    \"link\": \"https:\u002F\u002Fdocs.example.com\u002Fpayments\u002Fdeclined\"\n  }\n}\n","Response","json",[453,1338,1339,1343,1360,1380,1393,1413,1431,1448,1453],{"__ignoreMap":623},[627,1340,1341],{"class":629,"line":630},[627,1342,1246],{"class":637},[627,1344,1345,1348,1351,1354,1356,1358],{"class":629,"line":660},[627,1346,1347],{"class":637},"  \"",[627,1349,1350],{"class":800},"statusCode",[627,1352,1353],{"class":637},"\"",[627,1355,721],{"class":637},[627,1357,1273],{"class":752},[627,1359,1263],{"class":637},[627,1361,1362,1364,1367,1369,1371,1374,1376,1378],{"class":629,"line":667},[627,1363,1347],{"class":637},[627,1365,1366],{"class":800},"message",[627,1368,1353],{"class":637},[627,1370,721],{"class":637},[627,1372,1373],{"class":637}," \"",[627,1375,1258],{"class":654},[627,1377,1353],{"class":637},[627,1379,1263],{"class":637},[627,1381,1382,1384,1387,1389,1391],{"class":629,"line":702},[627,1383,1347],{"class":637},[627,1385,1386],{"class":800},"data",[627,1388,1353],{"class":637},[627,1390,721],{"class":637},[627,1392,1090],{"class":637},[627,1394,1395,1398,1401,1403,1405,1407,1409,1411],{"class":629,"line":889},[627,1396,1397],{"class":637},"    \"",[627,1399,568],{"class":1400},"sBMFI",[627,1402,1353],{"class":637},[627,1404,721],{"class":637},[627,1406,1373],{"class":637},[627,1408,1287],{"class":654},[627,1410,1353],{"class":637},[627,1412,1263],{"class":637},[627,1414,1415,1417,1419,1421,1423,1425,1427,1429],{"class":629,"line":1154},[627,1416,1397],{"class":637},[627,1418,572],{"class":1400},[627,1420,1353],{"class":637},[627,1422,721],{"class":637},[627,1424,1373],{"class":637},[627,1426,1303],{"class":654},[627,1428,1353],{"class":637},[627,1430,1263],{"class":637},[627,1432,1433,1435,1437,1439,1441,1443,1445],{"class":629,"line":1174},[627,1434,1397],{"class":637},[627,1436,575],{"class":1400},[627,1438,1353],{"class":637},[627,1440,721],{"class":637},[627,1442,1373],{"class":637},[627,1444,1319],{"class":654},[627,1446,1447],{"class":637},"\"\n",[627,1449,1450],{"class":629,"line":1181},[627,1451,1452],{"class":637},"  }\n",[627,1454,1455],{"class":629,"line":1326},[627,1456,1457],{"class":637},"}\n",[475,1459,1461],{"id":1460},"why-context-matters","Why Context Matters",[445,1463,1464,1465,1468],{},"We're entering an era where AI agents build, debug, and maintain applications. These agents need ",[448,1466,1467],{},"structured context"," to work effectively:",[530,1470,1471,1478,1485],{},[533,1472,1473,1477],{},[448,1474,1475],{},[453,1476,568],{},": The root cause, so the agent understands what went wrong",[533,1479,1480,1484],{},[448,1481,1482],{},[453,1483,572],{},": An actionable solution the agent can suggest or apply",[533,1486,1487,1491],{},[448,1488,1489],{},[453,1490,575],{},": Documentation for complex issues",[445,1493,1494,1495,1497,1498,1501],{},"Traditional ",[453,1496,455],{}," and generic ",[453,1499,1500],{},"throw new Error()"," provide no actionable context. evlog's structured output is designed for both humans and AI to parse and act on.",[475,1503,1505],{"id":1504},"next-steps","Next Steps",[530,1507,1508,1513,1518,1523,1529,1535],{},[533,1509,1510,1512],{},[461,1511,15],{"href":16}," - The case for adopting evlog on day zero",[533,1514,1515,1517],{},[461,1516,20],{"href":21}," - Install evlog in your project",[533,1519,1520,1522],{},[461,1521,25],{"href":26}," - Get up and running in minutes",[533,1524,1525,1528],{},[461,1526,1527],{"href":37},"Logging Overview"," - Understand the three logging modes in depth",[533,1530,1531,1534],{},[461,1532,1533],{"href":432},"evlog vs pino, winston, consola"," - Feature parity, honest gaps, and migration snippets",[533,1536,1537,1539],{},[461,1538,517],{"href":228}," — scripts, workers, libraries without a web framework",[1541,1542,1543],"style",{},"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 .sfazB, html code.shiki .sfazB{--shiki-light:#91B859;--shiki-default:#C3E88D;--shiki-dark:#C3E88D}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 .sbssI, html code.shiki .sbssI{--shiki-light:#F76D47;--shiki-default:#F78C6C;--shiki-dark:#F78C6C}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 .spNyl, html code.shiki .spNyl{--shiki-light:#9C3EDA;--shiki-default:#C792EA;--shiki-dark:#C792EA}html pre.shiki code .sHdIc, html code.shiki .sHdIc{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#EEFFFF;--shiki-default-font-style:italic;--shiki-dark:#BABED8;--shiki-dark-font-style:italic}html pre.shiki code .sfNiH, html code.shiki .sfNiH{--shiki-light:#FF5370;--shiki-default:#FF9CAC;--shiki-dark:#FF9CAC}html pre.shiki code .sHwdD, html code.shiki .sHwdD{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#546E7A;--shiki-default-font-style:italic;--shiki-dark:#676E95;--shiki-dark-font-style:italic}html pre.shiki code .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}",{"title":623,"searchDepth":660,"depth":660,"links":1545},[1546,1547,1548,1553,1554],{"id":477,"depth":660,"text":478},{"id":524,"depth":660,"text":525},{"id":601,"depth":660,"text":602,"children":1549},[1550,1551,1552],{"id":609,"depth":667,"text":41},{"id":760,"depth":667,"text":46},{"id":1192,"depth":667,"text":51},{"id":1460,"depth":660,"text":1461},{"id":1504,"depth":660,"text":1505},"A modern TypeScript logger built for everything you ship. Simple structured logs, wide events, and structured errors in one API — drop-in for console.log, pino, or consola.","md",[1558,1561],{"label":25,"icon":28,"to":26,"color":1559,"variant":1560},"neutral","subtle",{"label":1562,"icon":1563,"to":1564,"target":1565,"color":1559,"variant":1560},"GitHub","i-simple-icons-github","https:\u002F\u002Fgithub.com\u002Fhugorcd\u002Fevlog","_blank",{},{"icon":13},{"title":10,"description":1555},"mVhx71oKgHyTzLn-ydrK0KNoL7AriAU8krm9m2N2H60",[1571,1572],null,{"title":15,"path":16,"stem":17,"description":1573,"icon":18,"children":-1},"The cheapest moment to add structured logging is before the first request. Pick evlog on day zero and your application inherits a structured surface, typed catalogs, an audit trail, AI SDK telemetry, and a drain pipeline you don't have to build later.",1779694496951]