[{"data":1,"prerenderedAt":3507},["ShallowReactive",2],{"navigation_docs":3,"-learn-simple-logging":439,"-learn-simple-logging-surround":3502},[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":41,"body":441,"description":3492,"extension":3493,"links":3494,"meta":3498,"navigation":3499,"path":42,"seo":3500,"stem":43,"__hash__":3501},"docs\u002F2.learn\u002F1.simple-logging.md",{"type":442,"value":443,"toc":3475},"minimark",[444,457,471,483,488,491,631,641,645,650,653,795,845,849,852,1016,1073,1083,1087,1166,1180,1184,1188,1334,1338,1479,1483,1692,1696,1703,1862,1866,1877,2693,2696,2907,2916,2923,2927,2942,3410,3418,3422,3471],[445,446,447,448,452,453,456],"p",{},"The ",[449,450,451],"code",{},"log"," API is evlog's general-purpose logger. Use it the way you'd use pino, consola, or ",[449,454,455],{},"console.log"," — every call emits a structured event through the same drain pipeline as wide events. The two modes coexist; neither is an upgrade of the other.",[458,459,462,463,467,468,470],"callout",{"color":460,"icon":461},"neutral","i-lucide-globe","Looking for the same API in CLIs, libraries, jobs, and edge? Start with ",[464,465,466],"a",{"href":228},"Standalone TypeScript"," and ",[464,469,222],{"href":223},".",[458,472,474,475,477,478,482],{"color":473,"icon":352},"info","In Nuxt, ",[449,476,451],{}," is ",[479,480,481],"strong",{},"auto-imported",". No import statement needed.",[484,485,487],"h2",{"id":486},"setup","Setup",[445,489,490],{},"For standalone projects (non-Nuxt), initialize once at startup:",[492,493,499],"pre",{"className":494,"code":495,"filename":496,"language":497,"meta":498,"style":498},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import { initLogger, log } from 'evlog'\n\ninitLogger({\n  env: { service: 'my-app' },\n})\n\nlog.info('app', 'Server started')\n","src\u002Findex.ts","typescript","",[449,500,501,540,547,560,588,597,602],{"__ignoreMap":498},[502,503,506,510,514,518,521,524,527,530,533,537],"span",{"class":504,"line":505},"line",1,[502,507,509],{"class":508},"s7zQu","import",[502,511,513],{"class":512},"sMK4o"," {",[502,515,517],{"class":516},"sTEyZ"," initLogger",[502,519,520],{"class":512},",",[502,522,523],{"class":516}," log",[502,525,526],{"class":512}," }",[502,528,529],{"class":508}," from",[502,531,532],{"class":512}," '",[502,534,536],{"class":535},"sfazB","evlog",[502,538,539],{"class":512},"'\n",[502,541,543],{"class":504,"line":542},2,[502,544,546],{"emptyLinePlaceholder":545},true,"\n",[502,548,550,554,557],{"class":504,"line":549},3,[502,551,553],{"class":552},"s2Zo4","initLogger",[502,555,556],{"class":516},"(",[502,558,559],{"class":512},"{\n",[502,561,563,567,570,572,575,577,579,582,585],{"class":504,"line":562},4,[502,564,566],{"class":565},"swJcz","  env",[502,568,569],{"class":512},":",[502,571,513],{"class":512},[502,573,574],{"class":565}," service",[502,576,569],{"class":512},[502,578,532],{"class":512},[502,580,581],{"class":535},"my-app",[502,583,584],{"class":512},"'",[502,586,587],{"class":512}," },\n",[502,589,591,594],{"class":504,"line":590},5,[502,592,593],{"class":512},"}",[502,595,596],{"class":516},")\n",[502,598,600],{"class":504,"line":599},6,[502,601,546],{"emptyLinePlaceholder":545},[502,603,605,607,609,611,613,615,618,620,622,624,627,629],{"class":504,"line":604},7,[502,606,451],{"class":516},[502,608,470],{"class":512},[502,610,473],{"class":552},[502,612,556],{"class":516},[502,614,584],{"class":512},[502,616,617],{"class":535},"app",[502,619,584],{"class":512},[502,621,520],{"class":512},[502,623,532],{"class":512},[502,625,626],{"class":535},"Server started",[502,628,584],{"class":512},[502,630,596],{"class":516},[458,632,633,636,637,640],{"color":473,"icon":13},[449,634,635],{},"env.service"," defaults to ",[449,638,639],{},"'app'"," if not specified. Only set it if you want a custom service name.",[484,642,644],{"id":643},"two-call-styles","Two Call Styles",[646,647,649],"h3",{"id":648},"tagged-logs","Tagged Logs",[445,651,652],{},"Pass a tag and a message for quick, readable output:",[492,654,656],{"className":494,"code":655,"filename":496,"language":497,"meta":498,"style":498},"import { log } from 'evlog'\n\nlog.info('auth', 'User logged in')\nlog.warn('cache', 'Cache miss for key user:42')\nlog.error('payment', 'Stripe webhook failed')\nlog.debug('router', 'Matched route \u002Fapi\u002Fcheckout')\n",[449,657,658,676,680,708,737,766],{"__ignoreMap":498},[502,659,660,662,664,666,668,670,672,674],{"class":504,"line":505},[502,661,509],{"class":508},[502,663,513],{"class":512},[502,665,523],{"class":516},[502,667,526],{"class":512},[502,669,529],{"class":508},[502,671,532],{"class":512},[502,673,536],{"class":535},[502,675,539],{"class":512},[502,677,678],{"class":504,"line":542},[502,679,546],{"emptyLinePlaceholder":545},[502,681,682,684,686,688,690,692,695,697,699,701,704,706],{"class":504,"line":549},[502,683,451],{"class":516},[502,685,470],{"class":512},[502,687,473],{"class":552},[502,689,556],{"class":516},[502,691,584],{"class":512},[502,693,694],{"class":535},"auth",[502,696,584],{"class":512},[502,698,520],{"class":512},[502,700,532],{"class":512},[502,702,703],{"class":535},"User logged in",[502,705,584],{"class":512},[502,707,596],{"class":516},[502,709,710,712,714,717,719,721,724,726,728,730,733,735],{"class":504,"line":562},[502,711,451],{"class":516},[502,713,470],{"class":512},[502,715,716],{"class":552},"warn",[502,718,556],{"class":516},[502,720,584],{"class":512},[502,722,723],{"class":535},"cache",[502,725,584],{"class":512},[502,727,520],{"class":512},[502,729,532],{"class":512},[502,731,732],{"class":535},"Cache miss for key user:42",[502,734,584],{"class":512},[502,736,596],{"class":516},[502,738,739,741,743,746,748,750,753,755,757,759,762,764],{"class":504,"line":590},[502,740,451],{"class":516},[502,742,470],{"class":512},[502,744,745],{"class":552},"error",[502,747,556],{"class":516},[502,749,584],{"class":512},[502,751,752],{"class":535},"payment",[502,754,584],{"class":512},[502,756,520],{"class":512},[502,758,532],{"class":512},[502,760,761],{"class":535},"Stripe webhook failed",[502,763,584],{"class":512},[502,765,596],{"class":516},[502,767,768,770,772,775,777,779,782,784,786,788,791,793],{"class":504,"line":599},[502,769,451],{"class":516},[502,771,470],{"class":512},[502,773,774],{"class":552},"debug",[502,776,556],{"class":516},[502,778,584],{"class":512},[502,780,781],{"class":535},"router",[502,783,584],{"class":512},[502,785,520],{"class":512},[502,787,532],{"class":512},[502,789,790],{"class":535},"Matched route \u002Fapi\u002Fcheckout",[502,792,584],{"class":512},[502,794,596],{"class":516},[492,796,801],{"className":797,"code":798,"filename":799,"language":800,"meta":498,"style":498},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","10:23:45.612 [auth] User logged in\n10:23:45.613 [cache] Cache miss for key user:42\n10:23:45.614 ERROR [payment] Stripe webhook failed\n10:23:45.615 [router] Matched route \u002Fapi\u002Fcheckout\n","Output (Pretty)","bash",[449,802,803,812,826,837],{"__ignoreMap":498},[502,804,805,809],{"class":504,"line":505},[502,806,808],{"class":807},"sBMFI","10:23:45.612",[502,810,811],{"class":516}," [auth] User logged in\n",[502,813,814,817,820,823],{"class":504,"line":542},[502,815,816],{"class":807},"10:23:45.613",[502,818,819],{"class":516}," [cache] Cache miss ",[502,821,822],{"class":508},"for",[502,824,825],{"class":516}," key user:42\n",[502,827,828,831,834],{"class":504,"line":549},[502,829,830],{"class":807},"10:23:45.614",[502,832,833],{"class":535}," ERROR",[502,835,836],{"class":516}," [payment] Stripe webhook failed\n",[502,838,839,842],{"class":504,"line":562},[502,840,841],{"class":807},"10:23:45.615",[502,843,844],{"class":516}," [router] Matched route \u002Fapi\u002Fcheckout\n",[646,846,848],{"id":847},"structured-events","Structured Events",[445,850,851],{},"Pass an object for rich, queryable events that flow through the drain pipeline:",[492,853,855],{"className":494,"code":854,"filename":496,"language":497,"meta":498,"style":498},"import { log } from 'evlog'\n\nlog.info({ action: 'user_login', userId: 42, method: 'oauth', provider: 'github' })\nlog.error({ action: 'sync_failed', source: 'postgres', target: 's3', error: 'connection_timeout' })\n",[449,856,857,875,879,947],{"__ignoreMap":498},[502,858,859,861,863,865,867,869,871,873],{"class":504,"line":505},[502,860,509],{"class":508},[502,862,513],{"class":512},[502,864,523],{"class":516},[502,866,526],{"class":512},[502,868,529],{"class":508},[502,870,532],{"class":512},[502,872,536],{"class":535},[502,874,539],{"class":512},[502,876,877],{"class":504,"line":542},[502,878,546],{"emptyLinePlaceholder":545},[502,880,881,883,885,887,889,892,895,897,899,902,904,906,909,911,915,917,920,922,924,927,929,931,934,936,938,941,943,945],{"class":504,"line":549},[502,882,451],{"class":516},[502,884,470],{"class":512},[502,886,473],{"class":552},[502,888,556],{"class":516},[502,890,891],{"class":512},"{",[502,893,894],{"class":565}," action",[502,896,569],{"class":512},[502,898,532],{"class":512},[502,900,901],{"class":535},"user_login",[502,903,584],{"class":512},[502,905,520],{"class":512},[502,907,908],{"class":565}," userId",[502,910,569],{"class":512},[502,912,914],{"class":913},"sbssI"," 42",[502,916,520],{"class":512},[502,918,919],{"class":565}," method",[502,921,569],{"class":512},[502,923,532],{"class":512},[502,925,926],{"class":535},"oauth",[502,928,584],{"class":512},[502,930,520],{"class":512},[502,932,933],{"class":565}," provider",[502,935,569],{"class":512},[502,937,532],{"class":512},[502,939,940],{"class":535},"github",[502,942,584],{"class":512},[502,944,526],{"class":512},[502,946,596],{"class":516},[502,948,949,951,953,955,957,959,961,963,965,968,970,972,975,977,979,982,984,986,989,991,993,996,998,1000,1003,1005,1007,1010,1012,1014],{"class":504,"line":562},[502,950,451],{"class":516},[502,952,470],{"class":512},[502,954,745],{"class":552},[502,956,556],{"class":516},[502,958,891],{"class":512},[502,960,894],{"class":565},[502,962,569],{"class":512},[502,964,532],{"class":512},[502,966,967],{"class":535},"sync_failed",[502,969,584],{"class":512},[502,971,520],{"class":512},[502,973,974],{"class":565}," source",[502,976,569],{"class":512},[502,978,532],{"class":512},[502,980,981],{"class":535},"postgres",[502,983,584],{"class":512},[502,985,520],{"class":512},[502,987,988],{"class":565}," target",[502,990,569],{"class":512},[502,992,532],{"class":512},[502,994,995],{"class":535},"s3",[502,997,584],{"class":512},[502,999,520],{"class":512},[502,1001,1002],{"class":565}," error",[502,1004,569],{"class":512},[502,1006,532],{"class":512},[502,1008,1009],{"class":535},"connection_timeout",[502,1011,584],{"class":512},[502,1013,526],{"class":512},[502,1015,596],{"class":516},[492,1017,1019],{"className":797,"code":1018,"filename":799,"language":800,"meta":498,"style":498},"10:23:45.612 INFO [my-app]\n  ├─ action: user_login\n  ├─ userId: 42\n  ├─ method: oauth\n  └─ provider: github\n",[449,1020,1021,1031,1042,1052,1062],{"__ignoreMap":498},[502,1022,1023,1025,1028],{"class":504,"line":505},[502,1024,808],{"class":807},[502,1026,1027],{"class":535}," INFO",[502,1029,1030],{"class":516}," [my-app]\n",[502,1032,1033,1036,1039],{"class":504,"line":542},[502,1034,1035],{"class":807},"  ├─",[502,1037,1038],{"class":535}," action:",[502,1040,1041],{"class":535}," user_login\n",[502,1043,1044,1046,1049],{"class":504,"line":549},[502,1045,1035],{"class":807},[502,1047,1048],{"class":535}," userId:",[502,1050,1051],{"class":913}," 42\n",[502,1053,1054,1056,1059],{"class":504,"line":562},[502,1055,1035],{"class":807},[502,1057,1058],{"class":535}," method:",[502,1060,1061],{"class":535}," oauth\n",[502,1063,1064,1067,1070],{"class":504,"line":590},[502,1065,1066],{"class":807},"  └─",[502,1068,1069],{"class":535}," provider:",[502,1071,1072],{"class":535}," github\n",[458,1074,1075,1078,1079,1082],{"color":473,"icon":13},[479,1076,1077],{},"Tagged logs"," are optimized for console readability. ",[479,1080,1081],{},"Structured events"," (object form) produce full wide events that flow through the drain pipeline to external services.",[484,1084,1086],{"id":1085},"log-levels","Log Levels",[1088,1089,1090,1106],"table",{},[1091,1092,1093],"thead",{},[1094,1095,1096,1100,1103],"tr",{},[1097,1098,1099],"th",{},"Level",[1097,1101,1102],{},"Method",[1097,1104,1105],{},"When to use",[1107,1108,1109,1124,1138,1152],"tbody",{},[1094,1110,1111,1116,1121],{},[1112,1113,1114],"td",{},[449,1115,473],{},[1112,1117,1118],{},[449,1119,1120],{},"log.info()",[1112,1122,1123],{},"Normal operations: startup, shutdown, successful actions",[1094,1125,1126,1130,1135],{},[1112,1127,1128],{},[449,1129,716],{},[1112,1131,1132],{},[449,1133,1134],{},"log.warn()",[1112,1136,1137],{},"Unexpected but recoverable situations: cache miss, retry, deprecation",[1094,1139,1140,1144,1149],{},[1112,1141,1142],{},[449,1143,745],{},[1112,1145,1146],{},[449,1147,1148],{},"log.error()",[1112,1150,1151],{},"Failures that need attention: API errors, timeouts, invalid state",[1094,1153,1154,1158,1163],{},[1112,1155,1156],{},[449,1157,774],{},[1112,1159,1160],{},[449,1161,1162],{},"log.debug()",[1112,1164,1165],{},"Development-only details: SQL queries, intermediate state, routing",[458,1167,1170,1172,1173,1175,1176,1179],{"color":1168,"icon":1169},"warning","i-lucide-lightbulb",[449,1171,1162],{}," calls can be stripped from production builds using the ",[464,1174,422],{"href":423}," or the Nuxt module's ",[449,1177,1178],{},"strip"," option.",[484,1181,1183],{"id":1182},"common-patterns","Common Patterns",[646,1185,1187],{"id":1186},"application-lifecycle","Application Lifecycle",[492,1189,1191],{"className":494,"code":1190,"filename":496,"language":497,"meta":498,"style":498},"import { log } from 'evlog'\n\nlog.info('app', 'Starting server on port 3000')\nlog.info({ action: 'db_connected', host: 'localhost', database: 'mydb', pool: 10 })\nlog.info('app', 'Ready to accept connections')\n",[449,1192,1193,1211,1215,1242,1307],{"__ignoreMap":498},[502,1194,1195,1197,1199,1201,1203,1205,1207,1209],{"class":504,"line":505},[502,1196,509],{"class":508},[502,1198,513],{"class":512},[502,1200,523],{"class":516},[502,1202,526],{"class":512},[502,1204,529],{"class":508},[502,1206,532],{"class":512},[502,1208,536],{"class":535},[502,1210,539],{"class":512},[502,1212,1213],{"class":504,"line":542},[502,1214,546],{"emptyLinePlaceholder":545},[502,1216,1217,1219,1221,1223,1225,1227,1229,1231,1233,1235,1238,1240],{"class":504,"line":549},[502,1218,451],{"class":516},[502,1220,470],{"class":512},[502,1222,473],{"class":552},[502,1224,556],{"class":516},[502,1226,584],{"class":512},[502,1228,617],{"class":535},[502,1230,584],{"class":512},[502,1232,520],{"class":512},[502,1234,532],{"class":512},[502,1236,1237],{"class":535},"Starting server on port 3000",[502,1239,584],{"class":512},[502,1241,596],{"class":516},[502,1243,1244,1246,1248,1250,1252,1254,1256,1258,1260,1263,1265,1267,1270,1272,1274,1277,1279,1281,1284,1286,1288,1291,1293,1295,1298,1300,1303,1305],{"class":504,"line":562},[502,1245,451],{"class":516},[502,1247,470],{"class":512},[502,1249,473],{"class":552},[502,1251,556],{"class":516},[502,1253,891],{"class":512},[502,1255,894],{"class":565},[502,1257,569],{"class":512},[502,1259,532],{"class":512},[502,1261,1262],{"class":535},"db_connected",[502,1264,584],{"class":512},[502,1266,520],{"class":512},[502,1268,1269],{"class":565}," host",[502,1271,569],{"class":512},[502,1273,532],{"class":512},[502,1275,1276],{"class":535},"localhost",[502,1278,584],{"class":512},[502,1280,520],{"class":512},[502,1282,1283],{"class":565}," database",[502,1285,569],{"class":512},[502,1287,532],{"class":512},[502,1289,1290],{"class":535},"mydb",[502,1292,584],{"class":512},[502,1294,520],{"class":512},[502,1296,1297],{"class":565}," pool",[502,1299,569],{"class":512},[502,1301,1302],{"class":913}," 10",[502,1304,526],{"class":512},[502,1306,596],{"class":516},[502,1308,1309,1311,1313,1315,1317,1319,1321,1323,1325,1327,1330,1332],{"class":504,"line":590},[502,1310,451],{"class":516},[502,1312,470],{"class":512},[502,1314,473],{"class":552},[502,1316,556],{"class":516},[502,1318,584],{"class":512},[502,1320,617],{"class":535},[502,1322,584],{"class":512},[502,1324,520],{"class":512},[502,1326,532],{"class":512},[502,1328,1329],{"class":535},"Ready to accept connections",[502,1331,584],{"class":512},[502,1333,596],{"class":516},[646,1335,1337],{"id":1336},"background-tasks","Background Tasks",[492,1339,1342],{"className":494,"code":1340,"filename":1341,"language":497,"meta":498,"style":498},"import { log } from 'evlog'\n\nlog.info({ action: 'cron_started', job: 'cleanup', schedule: '0 *\u002F6 * * *' })\nlog.info({ action: 'cron_completed', job: 'cleanup', deleted: 42, duration: 1200 })\n","src\u002Fjobs\u002Fcleanup.ts",[449,1343,1344,1362,1366,1421],{"__ignoreMap":498},[502,1345,1346,1348,1350,1352,1354,1356,1358,1360],{"class":504,"line":505},[502,1347,509],{"class":508},[502,1349,513],{"class":512},[502,1351,523],{"class":516},[502,1353,526],{"class":512},[502,1355,529],{"class":508},[502,1357,532],{"class":512},[502,1359,536],{"class":535},[502,1361,539],{"class":512},[502,1363,1364],{"class":504,"line":542},[502,1365,546],{"emptyLinePlaceholder":545},[502,1367,1368,1370,1372,1374,1376,1378,1380,1382,1384,1387,1389,1391,1394,1396,1398,1401,1403,1405,1408,1410,1412,1415,1417,1419],{"class":504,"line":549},[502,1369,451],{"class":516},[502,1371,470],{"class":512},[502,1373,473],{"class":552},[502,1375,556],{"class":516},[502,1377,891],{"class":512},[502,1379,894],{"class":565},[502,1381,569],{"class":512},[502,1383,532],{"class":512},[502,1385,1386],{"class":535},"cron_started",[502,1388,584],{"class":512},[502,1390,520],{"class":512},[502,1392,1393],{"class":565}," job",[502,1395,569],{"class":512},[502,1397,532],{"class":512},[502,1399,1400],{"class":535},"cleanup",[502,1402,584],{"class":512},[502,1404,520],{"class":512},[502,1406,1407],{"class":565}," schedule",[502,1409,569],{"class":512},[502,1411,532],{"class":512},[502,1413,1414],{"class":535},"0 *\u002F6 * * *",[502,1416,584],{"class":512},[502,1418,526],{"class":512},[502,1420,596],{"class":516},[502,1422,1423,1425,1427,1429,1431,1433,1435,1437,1439,1442,1444,1446,1448,1450,1452,1454,1456,1458,1461,1463,1465,1467,1470,1472,1475,1477],{"class":504,"line":562},[502,1424,451],{"class":516},[502,1426,470],{"class":512},[502,1428,473],{"class":552},[502,1430,556],{"class":516},[502,1432,891],{"class":512},[502,1434,894],{"class":565},[502,1436,569],{"class":512},[502,1438,532],{"class":512},[502,1440,1441],{"class":535},"cron_completed",[502,1443,584],{"class":512},[502,1445,520],{"class":512},[502,1447,1393],{"class":565},[502,1449,569],{"class":512},[502,1451,532],{"class":512},[502,1453,1400],{"class":535},[502,1455,584],{"class":512},[502,1457,520],{"class":512},[502,1459,1460],{"class":565}," deleted",[502,1462,569],{"class":512},[502,1464,914],{"class":913},[502,1466,520],{"class":512},[502,1468,1469],{"class":565}," duration",[502,1471,569],{"class":512},[502,1473,1474],{"class":913}," 1200",[502,1476,526],{"class":512},[502,1478,596],{"class":516},[646,1480,1482],{"id":1481},"utility-functions","Utility Functions",[492,1484,1487],{"className":494,"code":1485,"filename":1486,"language":497,"meta":498,"style":498},"import { log } from 'evlog'\n\nfunction processWebhook(payload: WebhookPayload) {\n  log.info({ action: 'webhook_received', type: payload.type, source: payload.source })\n\n  if (!isValid(payload)) {\n    log.warn({ action: 'webhook_invalid', type: payload.type, reason: 'missing_signature' })\n    return\n  }\n}\n","src\u002Futils\u002Fwebhook.ts",[449,1488,1489,1507,1511,1537,1593,1597,1620,1674,1680,1686],{"__ignoreMap":498},[502,1490,1491,1493,1495,1497,1499,1501,1503,1505],{"class":504,"line":505},[502,1492,509],{"class":508},[502,1494,513],{"class":512},[502,1496,523],{"class":516},[502,1498,526],{"class":512},[502,1500,529],{"class":508},[502,1502,532],{"class":512},[502,1504,536],{"class":535},[502,1506,539],{"class":512},[502,1508,1509],{"class":504,"line":542},[502,1510,546],{"emptyLinePlaceholder":545},[502,1512,1513,1517,1520,1522,1526,1528,1531,1534],{"class":504,"line":549},[502,1514,1516],{"class":1515},"spNyl","function",[502,1518,1519],{"class":552}," processWebhook",[502,1521,556],{"class":512},[502,1523,1525],{"class":1524},"sHdIc","payload",[502,1527,569],{"class":512},[502,1529,1530],{"class":807}," WebhookPayload",[502,1532,1533],{"class":512},")",[502,1535,1536],{"class":512}," {\n",[502,1538,1539,1542,1544,1546,1548,1550,1552,1554,1556,1559,1561,1563,1566,1568,1571,1573,1576,1578,1580,1582,1584,1586,1589,1591],{"class":504,"line":562},[502,1540,1541],{"class":516},"  log",[502,1543,470],{"class":512},[502,1545,473],{"class":552},[502,1547,556],{"class":565},[502,1549,891],{"class":512},[502,1551,894],{"class":565},[502,1553,569],{"class":512},[502,1555,532],{"class":512},[502,1557,1558],{"class":535},"webhook_received",[502,1560,584],{"class":512},[502,1562,520],{"class":512},[502,1564,1565],{"class":565}," type",[502,1567,569],{"class":512},[502,1569,1570],{"class":516}," payload",[502,1572,470],{"class":512},[502,1574,1575],{"class":516},"type",[502,1577,520],{"class":512},[502,1579,974],{"class":565},[502,1581,569],{"class":512},[502,1583,1570],{"class":516},[502,1585,470],{"class":512},[502,1587,1588],{"class":516},"source",[502,1590,526],{"class":512},[502,1592,596],{"class":565},[502,1594,1595],{"class":504,"line":590},[502,1596,546],{"emptyLinePlaceholder":545},[502,1598,1599,1602,1605,1608,1611,1613,1615,1618],{"class":504,"line":599},[502,1600,1601],{"class":508},"  if",[502,1603,1604],{"class":565}," (",[502,1606,1607],{"class":512},"!",[502,1609,1610],{"class":552},"isValid",[502,1612,556],{"class":565},[502,1614,1525],{"class":516},[502,1616,1617],{"class":565},")) ",[502,1619,559],{"class":512},[502,1621,1622,1625,1627,1629,1631,1633,1635,1637,1639,1642,1644,1646,1648,1650,1652,1654,1656,1658,1661,1663,1665,1668,1670,1672],{"class":504,"line":604},[502,1623,1624],{"class":516},"    log",[502,1626,470],{"class":512},[502,1628,716],{"class":552},[502,1630,556],{"class":565},[502,1632,891],{"class":512},[502,1634,894],{"class":565},[502,1636,569],{"class":512},[502,1638,532],{"class":512},[502,1640,1641],{"class":535},"webhook_invalid",[502,1643,584],{"class":512},[502,1645,520],{"class":512},[502,1647,1565],{"class":565},[502,1649,569],{"class":512},[502,1651,1570],{"class":516},[502,1653,470],{"class":512},[502,1655,1575],{"class":516},[502,1657,520],{"class":512},[502,1659,1660],{"class":565}," reason",[502,1662,569],{"class":512},[502,1664,532],{"class":512},[502,1666,1667],{"class":535},"missing_signature",[502,1669,584],{"class":512},[502,1671,526],{"class":512},[502,1673,596],{"class":565},[502,1675,1677],{"class":504,"line":1676},8,[502,1678,1679],{"class":508},"    return\n",[502,1681,1683],{"class":504,"line":1682},9,[502,1684,1685],{"class":512},"  }\n",[502,1687,1689],{"class":504,"line":1688},10,[502,1690,1691],{"class":512},"}\n",[484,1693,1695],{"id":1694},"drain-integration","Drain Integration",[445,1697,1698,1699,1702],{},"When using the object form, events are sent through the ",[464,1700,1701],{"href":95},"drain pipeline"," just like wide events:",[492,1704,1706],{"className":494,"code":1705,"filename":496,"language":497,"meta":498,"style":498},"import { initLogger, log } from 'evlog'\nimport { createAxiomDrain } from 'evlog\u002Faxiom'\n\ninitLogger({\n  env: { service: 'my-app' },\n  drain: createAxiomDrain(),\n})\n\nlog.info({ action: 'deploy', version: '1.2.3', region: 'us-east-1' })\n",[449,1707,1708,1730,1750,1754,1762,1782,1797,1803,1807],{"__ignoreMap":498},[502,1709,1710,1712,1714,1716,1718,1720,1722,1724,1726,1728],{"class":504,"line":505},[502,1711,509],{"class":508},[502,1713,513],{"class":512},[502,1715,517],{"class":516},[502,1717,520],{"class":512},[502,1719,523],{"class":516},[502,1721,526],{"class":512},[502,1723,529],{"class":508},[502,1725,532],{"class":512},[502,1727,536],{"class":535},[502,1729,539],{"class":512},[502,1731,1732,1734,1736,1739,1741,1743,1745,1748],{"class":504,"line":542},[502,1733,509],{"class":508},[502,1735,513],{"class":512},[502,1737,1738],{"class":516}," createAxiomDrain",[502,1740,526],{"class":512},[502,1742,529],{"class":508},[502,1744,532],{"class":512},[502,1746,1747],{"class":535},"evlog\u002Faxiom",[502,1749,539],{"class":512},[502,1751,1752],{"class":504,"line":549},[502,1753,546],{"emptyLinePlaceholder":545},[502,1755,1756,1758,1760],{"class":504,"line":562},[502,1757,553],{"class":552},[502,1759,556],{"class":516},[502,1761,559],{"class":512},[502,1763,1764,1766,1768,1770,1772,1774,1776,1778,1780],{"class":504,"line":590},[502,1765,566],{"class":565},[502,1767,569],{"class":512},[502,1769,513],{"class":512},[502,1771,574],{"class":565},[502,1773,569],{"class":512},[502,1775,532],{"class":512},[502,1777,581],{"class":535},[502,1779,584],{"class":512},[502,1781,587],{"class":512},[502,1783,1784,1787,1789,1791,1794],{"class":504,"line":599},[502,1785,1786],{"class":565},"  drain",[502,1788,569],{"class":512},[502,1790,1738],{"class":552},[502,1792,1793],{"class":516},"()",[502,1795,1796],{"class":512},",\n",[502,1798,1799,1801],{"class":504,"line":604},[502,1800,593],{"class":512},[502,1802,596],{"class":516},[502,1804,1805],{"class":504,"line":1676},[502,1806,546],{"emptyLinePlaceholder":545},[502,1808,1809,1811,1813,1815,1817,1819,1821,1823,1825,1828,1830,1832,1835,1837,1839,1842,1844,1846,1849,1851,1853,1856,1858,1860],{"class":504,"line":1682},[502,1810,451],{"class":516},[502,1812,470],{"class":512},[502,1814,473],{"class":552},[502,1816,556],{"class":516},[502,1818,891],{"class":512},[502,1820,894],{"class":565},[502,1822,569],{"class":512},[502,1824,532],{"class":512},[502,1826,1827],{"class":535},"deploy",[502,1829,584],{"class":512},[502,1831,520],{"class":512},[502,1833,1834],{"class":565}," version",[502,1836,569],{"class":512},[502,1838,532],{"class":512},[502,1840,1841],{"class":535},"1.2.3",[502,1843,584],{"class":512},[502,1845,520],{"class":512},[502,1847,1848],{"class":565}," region",[502,1850,569],{"class":512},[502,1852,532],{"class":512},[502,1854,1855],{"class":535},"us-east-1",[502,1857,584],{"class":512},[502,1859,526],{"class":512},[502,1861,596],{"class":516},[484,1863,1865],{"id":1864},"migrating-from-console-pino-consola-winston","Migrating from console \u002F pino \u002F consola \u002F winston",[445,1867,1868,1869,1872,1873,1876],{},"Pick the tab matching your current logger to see the ",[479,1870,1871],{},"before"," call style. The ",[479,1874,1875],{},"after (evlog)"," snippet underneath is the same regardless of where you came from.",[1878,1879,1880,2100,2373,2559],"code-group",{},[492,1881,1884],{"className":494,"code":1882,"filename":1883,"language":497,"meta":498,"style":498},"import pino from 'pino'\n\nconst log = pino({ name: 'checkout' })\n\nlog.info({ event: 'checkout_started' })\nlog.info({ event: 'cart_loaded', items: 3, total: 9999 })\nlog.warn({ event: 'inventory_low', sku: 'SKU-42' })\nlog.error({ event: 'payment_failed', reason: 'card_declined' })\n","pino",[449,1885,1886,1902,1906,1940,1944,1972,2019,2060],{"__ignoreMap":498},[502,1887,1888,1890,1893,1896,1898,1900],{"class":504,"line":505},[502,1889,509],{"class":508},[502,1891,1892],{"class":516}," pino ",[502,1894,1895],{"class":508},"from",[502,1897,532],{"class":512},[502,1899,1883],{"class":535},[502,1901,539],{"class":512},[502,1903,1904],{"class":504,"line":542},[502,1905,546],{"emptyLinePlaceholder":545},[502,1907,1908,1911,1914,1917,1920,1922,1924,1927,1929,1931,1934,1936,1938],{"class":504,"line":549},[502,1909,1910],{"class":1515},"const",[502,1912,1913],{"class":516}," log ",[502,1915,1916],{"class":512},"=",[502,1918,1919],{"class":552}," pino",[502,1921,556],{"class":516},[502,1923,891],{"class":512},[502,1925,1926],{"class":565}," name",[502,1928,569],{"class":512},[502,1930,532],{"class":512},[502,1932,1933],{"class":535},"checkout",[502,1935,584],{"class":512},[502,1937,526],{"class":512},[502,1939,596],{"class":516},[502,1941,1942],{"class":504,"line":562},[502,1943,546],{"emptyLinePlaceholder":545},[502,1945,1946,1948,1950,1952,1954,1956,1959,1961,1963,1966,1968,1970],{"class":504,"line":590},[502,1947,451],{"class":516},[502,1949,470],{"class":512},[502,1951,473],{"class":552},[502,1953,556],{"class":516},[502,1955,891],{"class":512},[502,1957,1958],{"class":565}," event",[502,1960,569],{"class":512},[502,1962,532],{"class":512},[502,1964,1965],{"class":535},"checkout_started",[502,1967,584],{"class":512},[502,1969,526],{"class":512},[502,1971,596],{"class":516},[502,1973,1974,1976,1978,1980,1982,1984,1986,1988,1990,1993,1995,1997,2000,2002,2005,2007,2010,2012,2015,2017],{"class":504,"line":599},[502,1975,451],{"class":516},[502,1977,470],{"class":512},[502,1979,473],{"class":552},[502,1981,556],{"class":516},[502,1983,891],{"class":512},[502,1985,1958],{"class":565},[502,1987,569],{"class":512},[502,1989,532],{"class":512},[502,1991,1992],{"class":535},"cart_loaded",[502,1994,584],{"class":512},[502,1996,520],{"class":512},[502,1998,1999],{"class":565}," items",[502,2001,569],{"class":512},[502,2003,2004],{"class":913}," 3",[502,2006,520],{"class":512},[502,2008,2009],{"class":565}," total",[502,2011,569],{"class":512},[502,2013,2014],{"class":913}," 9999",[502,2016,526],{"class":512},[502,2018,596],{"class":516},[502,2020,2021,2023,2025,2027,2029,2031,2033,2035,2037,2040,2042,2044,2047,2049,2051,2054,2056,2058],{"class":504,"line":604},[502,2022,451],{"class":516},[502,2024,470],{"class":512},[502,2026,716],{"class":552},[502,2028,556],{"class":516},[502,2030,891],{"class":512},[502,2032,1958],{"class":565},[502,2034,569],{"class":512},[502,2036,532],{"class":512},[502,2038,2039],{"class":535},"inventory_low",[502,2041,584],{"class":512},[502,2043,520],{"class":512},[502,2045,2046],{"class":565}," sku",[502,2048,569],{"class":512},[502,2050,532],{"class":512},[502,2052,2053],{"class":535},"SKU-42",[502,2055,584],{"class":512},[502,2057,526],{"class":512},[502,2059,596],{"class":516},[502,2061,2062,2064,2066,2068,2070,2072,2074,2076,2078,2081,2083,2085,2087,2089,2091,2094,2096,2098],{"class":504,"line":1676},[502,2063,451],{"class":516},[502,2065,470],{"class":512},[502,2067,745],{"class":552},[502,2069,556],{"class":516},[502,2071,891],{"class":512},[502,2073,1958],{"class":565},[502,2075,569],{"class":512},[502,2077,532],{"class":512},[502,2079,2080],{"class":535},"payment_failed",[502,2082,584],{"class":512},[502,2084,520],{"class":512},[502,2086,1660],{"class":565},[502,2088,569],{"class":512},[502,2090,532],{"class":512},[502,2092,2093],{"class":535},"card_declined",[502,2095,584],{"class":512},[502,2097,526],{"class":512},[502,2099,596],{"class":516},[492,2101,2104],{"className":494,"code":2102,"filename":2103,"language":497,"meta":498,"style":498},"import { createLogger, format, transports } from 'winston'\n\nconst log = createLogger({\n  defaultMeta: { service: 'checkout' },\n  format: format.json(),\n  transports: [new transports.Console()],\n})\n\nlog.info({ event: 'checkout_started' })\nlog.info({ event: 'cart_loaded', items: 3, total: 9999 })\nlog.warn({ event: 'inventory_low', sku: 'SKU-42' })\nlog.error({ event: 'payment_failed', reason: 'card_declined' })\n","winston",[449,2105,2106,2135,2139,2153,2174,2192,2217,2223,2227,2253,2295,2334],{"__ignoreMap":498},[502,2107,2108,2110,2112,2115,2117,2120,2122,2125,2127,2129,2131,2133],{"class":504,"line":505},[502,2109,509],{"class":508},[502,2111,513],{"class":512},[502,2113,2114],{"class":516}," createLogger",[502,2116,520],{"class":512},[502,2118,2119],{"class":516}," format",[502,2121,520],{"class":512},[502,2123,2124],{"class":516}," transports",[502,2126,526],{"class":512},[502,2128,529],{"class":508},[502,2130,532],{"class":512},[502,2132,2103],{"class":535},[502,2134,539],{"class":512},[502,2136,2137],{"class":504,"line":542},[502,2138,546],{"emptyLinePlaceholder":545},[502,2140,2141,2143,2145,2147,2149,2151],{"class":504,"line":549},[502,2142,1910],{"class":1515},[502,2144,1913],{"class":516},[502,2146,1916],{"class":512},[502,2148,2114],{"class":552},[502,2150,556],{"class":516},[502,2152,559],{"class":512},[502,2154,2155,2158,2160,2162,2164,2166,2168,2170,2172],{"class":504,"line":562},[502,2156,2157],{"class":565},"  defaultMeta",[502,2159,569],{"class":512},[502,2161,513],{"class":512},[502,2163,574],{"class":565},[502,2165,569],{"class":512},[502,2167,532],{"class":512},[502,2169,1933],{"class":535},[502,2171,584],{"class":512},[502,2173,587],{"class":512},[502,2175,2176,2179,2181,2183,2185,2188,2190],{"class":504,"line":590},[502,2177,2178],{"class":565},"  format",[502,2180,569],{"class":512},[502,2182,2119],{"class":516},[502,2184,470],{"class":512},[502,2186,2187],{"class":552},"json",[502,2189,1793],{"class":516},[502,2191,1796],{"class":512},[502,2193,2194,2197,2199,2202,2205,2207,2209,2212,2215],{"class":504,"line":599},[502,2195,2196],{"class":565},"  transports",[502,2198,569],{"class":512},[502,2200,2201],{"class":516}," [",[502,2203,2204],{"class":512},"new",[502,2206,2124],{"class":516},[502,2208,470],{"class":512},[502,2210,2211],{"class":552},"Console",[502,2213,2214],{"class":516},"()]",[502,2216,1796],{"class":512},[502,2218,2219,2221],{"class":504,"line":604},[502,2220,593],{"class":512},[502,2222,596],{"class":516},[502,2224,2225],{"class":504,"line":1676},[502,2226,546],{"emptyLinePlaceholder":545},[502,2228,2229,2231,2233,2235,2237,2239,2241,2243,2245,2247,2249,2251],{"class":504,"line":1682},[502,2230,451],{"class":516},[502,2232,470],{"class":512},[502,2234,473],{"class":552},[502,2236,556],{"class":516},[502,2238,891],{"class":512},[502,2240,1958],{"class":565},[502,2242,569],{"class":512},[502,2244,532],{"class":512},[502,2246,1965],{"class":535},[502,2248,584],{"class":512},[502,2250,526],{"class":512},[502,2252,596],{"class":516},[502,2254,2255,2257,2259,2261,2263,2265,2267,2269,2271,2273,2275,2277,2279,2281,2283,2285,2287,2289,2291,2293],{"class":504,"line":1688},[502,2256,451],{"class":516},[502,2258,470],{"class":512},[502,2260,473],{"class":552},[502,2262,556],{"class":516},[502,2264,891],{"class":512},[502,2266,1958],{"class":565},[502,2268,569],{"class":512},[502,2270,532],{"class":512},[502,2272,1992],{"class":535},[502,2274,584],{"class":512},[502,2276,520],{"class":512},[502,2278,1999],{"class":565},[502,2280,569],{"class":512},[502,2282,2004],{"class":913},[502,2284,520],{"class":512},[502,2286,2009],{"class":565},[502,2288,569],{"class":512},[502,2290,2014],{"class":913},[502,2292,526],{"class":512},[502,2294,596],{"class":516},[502,2296,2298,2300,2302,2304,2306,2308,2310,2312,2314,2316,2318,2320,2322,2324,2326,2328,2330,2332],{"class":504,"line":2297},11,[502,2299,451],{"class":516},[502,2301,470],{"class":512},[502,2303,716],{"class":552},[502,2305,556],{"class":516},[502,2307,891],{"class":512},[502,2309,1958],{"class":565},[502,2311,569],{"class":512},[502,2313,532],{"class":512},[502,2315,2039],{"class":535},[502,2317,584],{"class":512},[502,2319,520],{"class":512},[502,2321,2046],{"class":565},[502,2323,569],{"class":512},[502,2325,532],{"class":512},[502,2327,2053],{"class":535},[502,2329,584],{"class":512},[502,2331,526],{"class":512},[502,2333,596],{"class":516},[502,2335,2337,2339,2341,2343,2345,2347,2349,2351,2353,2355,2357,2359,2361,2363,2365,2367,2369,2371],{"class":504,"line":2336},12,[502,2338,451],{"class":516},[502,2340,470],{"class":512},[502,2342,745],{"class":552},[502,2344,556],{"class":516},[502,2346,891],{"class":512},[502,2348,1958],{"class":565},[502,2350,569],{"class":512},[502,2352,532],{"class":512},[502,2354,2080],{"class":535},[502,2356,584],{"class":512},[502,2358,520],{"class":512},[502,2360,1660],{"class":565},[502,2362,569],{"class":512},[502,2364,532],{"class":512},[502,2366,2093],{"class":535},[502,2368,584],{"class":512},[502,2370,526],{"class":512},[502,2372,596],{"class":516},[492,2374,2377],{"className":494,"code":2375,"filename":2376,"language":497,"meta":498,"style":498},"import { consola } from 'consola'\n\nconst log = consola.withTag('checkout')\n\nlog.info('Starting checkout')\nlog.info('cart loaded', { items: 3, total: 9999 })\nlog.warn('inventory low', { sku: 'SKU-42' })\nlog.error('payment failed', { reason: 'card_declined' })\n","consola",[449,2378,2379,2398,2402,2427,2431,2450,2489,2524],{"__ignoreMap":498},[502,2380,2381,2383,2385,2388,2390,2392,2394,2396],{"class":504,"line":505},[502,2382,509],{"class":508},[502,2384,513],{"class":512},[502,2386,2387],{"class":516}," consola",[502,2389,526],{"class":512},[502,2391,529],{"class":508},[502,2393,532],{"class":512},[502,2395,2376],{"class":535},[502,2397,539],{"class":512},[502,2399,2400],{"class":504,"line":542},[502,2401,546],{"emptyLinePlaceholder":545},[502,2403,2404,2406,2408,2410,2412,2414,2417,2419,2421,2423,2425],{"class":504,"line":549},[502,2405,1910],{"class":1515},[502,2407,1913],{"class":516},[502,2409,1916],{"class":512},[502,2411,2387],{"class":516},[502,2413,470],{"class":512},[502,2415,2416],{"class":552},"withTag",[502,2418,556],{"class":516},[502,2420,584],{"class":512},[502,2422,1933],{"class":535},[502,2424,584],{"class":512},[502,2426,596],{"class":516},[502,2428,2429],{"class":504,"line":562},[502,2430,546],{"emptyLinePlaceholder":545},[502,2432,2433,2435,2437,2439,2441,2443,2446,2448],{"class":504,"line":590},[502,2434,451],{"class":516},[502,2436,470],{"class":512},[502,2438,473],{"class":552},[502,2440,556],{"class":516},[502,2442,584],{"class":512},[502,2444,2445],{"class":535},"Starting checkout",[502,2447,584],{"class":512},[502,2449,596],{"class":516},[502,2451,2452,2454,2456,2458,2460,2462,2465,2467,2469,2471,2473,2475,2477,2479,2481,2483,2485,2487],{"class":504,"line":599},[502,2453,451],{"class":516},[502,2455,470],{"class":512},[502,2457,473],{"class":552},[502,2459,556],{"class":516},[502,2461,584],{"class":512},[502,2463,2464],{"class":535},"cart loaded",[502,2466,584],{"class":512},[502,2468,520],{"class":512},[502,2470,513],{"class":512},[502,2472,1999],{"class":565},[502,2474,569],{"class":512},[502,2476,2004],{"class":913},[502,2478,520],{"class":512},[502,2480,2009],{"class":565},[502,2482,569],{"class":512},[502,2484,2014],{"class":913},[502,2486,526],{"class":512},[502,2488,596],{"class":516},[502,2490,2491,2493,2495,2497,2499,2501,2504,2506,2508,2510,2512,2514,2516,2518,2520,2522],{"class":504,"line":604},[502,2492,451],{"class":516},[502,2494,470],{"class":512},[502,2496,716],{"class":552},[502,2498,556],{"class":516},[502,2500,584],{"class":512},[502,2502,2503],{"class":535},"inventory low",[502,2505,584],{"class":512},[502,2507,520],{"class":512},[502,2509,513],{"class":512},[502,2511,2046],{"class":565},[502,2513,569],{"class":512},[502,2515,532],{"class":512},[502,2517,2053],{"class":535},[502,2519,584],{"class":512},[502,2521,526],{"class":512},[502,2523,596],{"class":516},[502,2525,2526,2528,2530,2532,2534,2536,2539,2541,2543,2545,2547,2549,2551,2553,2555,2557],{"class":504,"line":1676},[502,2527,451],{"class":516},[502,2529,470],{"class":512},[502,2531,745],{"class":552},[502,2533,556],{"class":516},[502,2535,584],{"class":512},[502,2537,2538],{"class":535},"payment failed",[502,2540,584],{"class":512},[502,2542,520],{"class":512},[502,2544,513],{"class":512},[502,2546,1660],{"class":565},[502,2548,569],{"class":512},[502,2550,532],{"class":512},[502,2552,2093],{"class":535},[502,2554,584],{"class":512},[502,2556,526],{"class":512},[502,2558,596],{"class":516},[492,2560,2562],{"className":494,"code":2561,"filename":455,"language":497,"meta":498,"style":498},"console.log('[checkout] Starting checkout')\nconsole.log('[checkout] cart loaded', { items: 3, total: 9999 })\nconsole.warn('[checkout] inventory low', { sku: 'SKU-42' })\nconsole.error('[checkout] payment failed', { reason: 'card_declined' })\n",[449,2563,2564,2584,2623,2658],{"__ignoreMap":498},[502,2565,2566,2569,2571,2573,2575,2577,2580,2582],{"class":504,"line":505},[502,2567,2568],{"class":516},"console",[502,2570,470],{"class":512},[502,2572,451],{"class":552},[502,2574,556],{"class":516},[502,2576,584],{"class":512},[502,2578,2579],{"class":535},"[checkout] Starting checkout",[502,2581,584],{"class":512},[502,2583,596],{"class":516},[502,2585,2586,2588,2590,2592,2594,2596,2599,2601,2603,2605,2607,2609,2611,2613,2615,2617,2619,2621],{"class":504,"line":542},[502,2587,2568],{"class":516},[502,2589,470],{"class":512},[502,2591,451],{"class":552},[502,2593,556],{"class":516},[502,2595,584],{"class":512},[502,2597,2598],{"class":535},"[checkout] cart loaded",[502,2600,584],{"class":512},[502,2602,520],{"class":512},[502,2604,513],{"class":512},[502,2606,1999],{"class":565},[502,2608,569],{"class":512},[502,2610,2004],{"class":913},[502,2612,520],{"class":512},[502,2614,2009],{"class":565},[502,2616,569],{"class":512},[502,2618,2014],{"class":913},[502,2620,526],{"class":512},[502,2622,596],{"class":516},[502,2624,2625,2627,2629,2631,2633,2635,2638,2640,2642,2644,2646,2648,2650,2652,2654,2656],{"class":504,"line":549},[502,2626,2568],{"class":516},[502,2628,470],{"class":512},[502,2630,716],{"class":552},[502,2632,556],{"class":516},[502,2634,584],{"class":512},[502,2636,2637],{"class":535},"[checkout] inventory low",[502,2639,584],{"class":512},[502,2641,520],{"class":512},[502,2643,513],{"class":512},[502,2645,2046],{"class":565},[502,2647,569],{"class":512},[502,2649,532],{"class":512},[502,2651,2053],{"class":535},[502,2653,584],{"class":512},[502,2655,526],{"class":512},[502,2657,596],{"class":516},[502,2659,2660,2662,2664,2666,2668,2670,2673,2675,2677,2679,2681,2683,2685,2687,2689,2691],{"class":504,"line":562},[502,2661,2568],{"class":516},[502,2663,470],{"class":512},[502,2665,745],{"class":552},[502,2667,556],{"class":516},[502,2669,584],{"class":512},[502,2671,2672],{"class":535},"[checkout] payment failed",[502,2674,584],{"class":512},[502,2676,520],{"class":512},[502,2678,513],{"class":512},[502,2680,1660],{"class":565},[502,2682,569],{"class":512},[502,2684,532],{"class":512},[502,2686,2093],{"class":535},[502,2688,584],{"class":512},[502,2690,526],{"class":512},[502,2692,596],{"class":516},[445,2694,2695],{},"All four become this — no formatter, transport, or peer-dep wiring required:",[492,2697,2700],{"className":494,"code":2698,"filename":2699,"language":497,"meta":498,"style":498},"import { initLogger, log } from 'evlog'\n\ninitLogger({ env: { service: 'checkout' } })\n\nlog.info({ event: 'checkout_started' })\nlog.info({ event: 'cart_loaded', items: 3, total: 9999 })\nlog.warn({ event: 'inventory_low', sku: 'SKU-42' })\nlog.error({ event: 'payment_failed', reason: 'card_declined' })\n","After (evlog)",[449,2701,2702,2724,2728,2759,2763,2789,2831,2869],{"__ignoreMap":498},[502,2703,2704,2706,2708,2710,2712,2714,2716,2718,2720,2722],{"class":504,"line":505},[502,2705,509],{"class":508},[502,2707,513],{"class":512},[502,2709,517],{"class":516},[502,2711,520],{"class":512},[502,2713,523],{"class":516},[502,2715,526],{"class":512},[502,2717,529],{"class":508},[502,2719,532],{"class":512},[502,2721,536],{"class":535},[502,2723,539],{"class":512},[502,2725,2726],{"class":504,"line":542},[502,2727,546],{"emptyLinePlaceholder":545},[502,2729,2730,2732,2734,2736,2739,2741,2743,2745,2747,2749,2751,2753,2755,2757],{"class":504,"line":549},[502,2731,553],{"class":552},[502,2733,556],{"class":516},[502,2735,891],{"class":512},[502,2737,2738],{"class":565}," env",[502,2740,569],{"class":512},[502,2742,513],{"class":512},[502,2744,574],{"class":565},[502,2746,569],{"class":512},[502,2748,532],{"class":512},[502,2750,1933],{"class":535},[502,2752,584],{"class":512},[502,2754,526],{"class":512},[502,2756,526],{"class":512},[502,2758,596],{"class":516},[502,2760,2761],{"class":504,"line":562},[502,2762,546],{"emptyLinePlaceholder":545},[502,2764,2765,2767,2769,2771,2773,2775,2777,2779,2781,2783,2785,2787],{"class":504,"line":590},[502,2766,451],{"class":516},[502,2768,470],{"class":512},[502,2770,473],{"class":552},[502,2772,556],{"class":516},[502,2774,891],{"class":512},[502,2776,1958],{"class":565},[502,2778,569],{"class":512},[502,2780,532],{"class":512},[502,2782,1965],{"class":535},[502,2784,584],{"class":512},[502,2786,526],{"class":512},[502,2788,596],{"class":516},[502,2790,2791,2793,2795,2797,2799,2801,2803,2805,2807,2809,2811,2813,2815,2817,2819,2821,2823,2825,2827,2829],{"class":504,"line":599},[502,2792,451],{"class":516},[502,2794,470],{"class":512},[502,2796,473],{"class":552},[502,2798,556],{"class":516},[502,2800,891],{"class":512},[502,2802,1958],{"class":565},[502,2804,569],{"class":512},[502,2806,532],{"class":512},[502,2808,1992],{"class":535},[502,2810,584],{"class":512},[502,2812,520],{"class":512},[502,2814,1999],{"class":565},[502,2816,569],{"class":512},[502,2818,2004],{"class":913},[502,2820,520],{"class":512},[502,2822,2009],{"class":565},[502,2824,569],{"class":512},[502,2826,2014],{"class":913},[502,2828,526],{"class":512},[502,2830,596],{"class":516},[502,2832,2833,2835,2837,2839,2841,2843,2845,2847,2849,2851,2853,2855,2857,2859,2861,2863,2865,2867],{"class":504,"line":604},[502,2834,451],{"class":516},[502,2836,470],{"class":512},[502,2838,716],{"class":552},[502,2840,556],{"class":516},[502,2842,891],{"class":512},[502,2844,1958],{"class":565},[502,2846,569],{"class":512},[502,2848,532],{"class":512},[502,2850,2039],{"class":535},[502,2852,584],{"class":512},[502,2854,520],{"class":512},[502,2856,2046],{"class":565},[502,2858,569],{"class":512},[502,2860,532],{"class":512},[502,2862,2053],{"class":535},[502,2864,584],{"class":512},[502,2866,526],{"class":512},[502,2868,596],{"class":516},[502,2870,2871,2873,2875,2877,2879,2881,2883,2885,2887,2889,2891,2893,2895,2897,2899,2901,2903,2905],{"class":504,"line":1676},[502,2872,451],{"class":516},[502,2874,470],{"class":512},[502,2876,745],{"class":552},[502,2878,556],{"class":516},[502,2880,891],{"class":512},[502,2882,1958],{"class":565},[502,2884,569],{"class":512},[502,2886,532],{"class":512},[502,2888,2080],{"class":535},[502,2890,584],{"class":512},[502,2892,520],{"class":512},[502,2894,1660],{"class":565},[502,2896,569],{"class":512},[502,2898,532],{"class":512},[502,2900,2093],{"class":535},[502,2902,584],{"class":512},[502,2904,526],{"class":512},[502,2906,596],{"class":516},[445,2908,2909,2911,2912,2915],{},[449,2910,553],{}," is one line at boot. The drain, redaction, sampling, pretty\u002FJSON switching, and level filtering are all wired by default — no ",[449,2913,2914],{},"pino-pretty"," peer dep, no winston transport assembly, no consola reporter setup.",[458,2917,2919,2920,470],{"color":460,"icon":2918},"i-lucide-arrow-right","Want the full side-by-side (feature comparison tables, honest gaps, per-feature mapping)? See ",[464,2921,2922],{"href":432},"evlog vs pino, winston, consola",[484,2924,2926],{"id":2925},"pairing-with-wide-events","Pairing with wide events",[445,2928,2929,467,2931,2934,2935,2938,2939,2941],{},[449,2930,451],{},[449,2932,2933],{},"createLogger"," live inside the same logger. Use ",[449,2936,2937],{},"log.*"," for events that stand alone (startup messages, ad-hoc warnings, debug traces) and reach for ",[449,2940,2933],{}," when you want one event that captures an entire operation. They share the global drain, redaction, and types — pick per call.",[492,2943,2946],{"className":494,"code":2944,"filename":2945,"language":497,"meta":498,"style":498},"import { initLogger, log, createLogger } from 'evlog'\n\ninitLogger({ env: { service: 'sync-worker' } })\n\nlog.info('sync', 'Worker starting')\n\nconst run = createLogger({ source: 'postgres', target: 's3' })\ntry {\n  const records = await fetchRecords()\n  run.set({ found: records.length })\n\n  for (const record of records) {\n    await syncOne(record)\n    log.debug({ event: 'record_synced', id: record.id })\n  }\n\n  run.set({ status: 'complete', synced: records.length })\n} catch (err) {\n  log.error({ event: 'sync_failed' })\n  run.error(err as Error)\n  throw err\n} finally {\n  run.emit()\n}\n\nlog.info('sync', 'Worker finished')\n","scripts\u002Fsync-data.ts",[449,2947,2948,2974,2978,3009,3013,3041,3045,3086,3093,3113,3143,3147,3169,3185,3227,3232,3237,3279,3292,3319,3341,3350,3360,3372,3377,3382],{"__ignoreMap":498},[502,2949,2950,2952,2954,2956,2958,2960,2962,2964,2966,2968,2970,2972],{"class":504,"line":505},[502,2951,509],{"class":508},[502,2953,513],{"class":512},[502,2955,517],{"class":516},[502,2957,520],{"class":512},[502,2959,523],{"class":516},[502,2961,520],{"class":512},[502,2963,2114],{"class":516},[502,2965,526],{"class":512},[502,2967,529],{"class":508},[502,2969,532],{"class":512},[502,2971,536],{"class":535},[502,2973,539],{"class":512},[502,2975,2976],{"class":504,"line":542},[502,2977,546],{"emptyLinePlaceholder":545},[502,2979,2980,2982,2984,2986,2988,2990,2992,2994,2996,2998,3001,3003,3005,3007],{"class":504,"line":549},[502,2981,553],{"class":552},[502,2983,556],{"class":516},[502,2985,891],{"class":512},[502,2987,2738],{"class":565},[502,2989,569],{"class":512},[502,2991,513],{"class":512},[502,2993,574],{"class":565},[502,2995,569],{"class":512},[502,2997,532],{"class":512},[502,2999,3000],{"class":535},"sync-worker",[502,3002,584],{"class":512},[502,3004,526],{"class":512},[502,3006,526],{"class":512},[502,3008,596],{"class":516},[502,3010,3011],{"class":504,"line":562},[502,3012,546],{"emptyLinePlaceholder":545},[502,3014,3015,3017,3019,3021,3023,3025,3028,3030,3032,3034,3037,3039],{"class":504,"line":590},[502,3016,451],{"class":516},[502,3018,470],{"class":512},[502,3020,473],{"class":552},[502,3022,556],{"class":516},[502,3024,584],{"class":512},[502,3026,3027],{"class":535},"sync",[502,3029,584],{"class":512},[502,3031,520],{"class":512},[502,3033,532],{"class":512},[502,3035,3036],{"class":535},"Worker starting",[502,3038,584],{"class":512},[502,3040,596],{"class":516},[502,3042,3043],{"class":504,"line":599},[502,3044,546],{"emptyLinePlaceholder":545},[502,3046,3047,3049,3052,3054,3056,3058,3060,3062,3064,3066,3068,3070,3072,3074,3076,3078,3080,3082,3084],{"class":504,"line":604},[502,3048,1910],{"class":1515},[502,3050,3051],{"class":516}," run ",[502,3053,1916],{"class":512},[502,3055,2114],{"class":552},[502,3057,556],{"class":516},[502,3059,891],{"class":512},[502,3061,974],{"class":565},[502,3063,569],{"class":512},[502,3065,532],{"class":512},[502,3067,981],{"class":535},[502,3069,584],{"class":512},[502,3071,520],{"class":512},[502,3073,988],{"class":565},[502,3075,569],{"class":512},[502,3077,532],{"class":512},[502,3079,995],{"class":535},[502,3081,584],{"class":512},[502,3083,526],{"class":512},[502,3085,596],{"class":516},[502,3087,3088,3091],{"class":504,"line":1676},[502,3089,3090],{"class":508},"try",[502,3092,1536],{"class":512},[502,3094,3095,3098,3101,3104,3107,3110],{"class":504,"line":1682},[502,3096,3097],{"class":1515},"  const",[502,3099,3100],{"class":516}," records",[502,3102,3103],{"class":512}," =",[502,3105,3106],{"class":508}," await",[502,3108,3109],{"class":552}," fetchRecords",[502,3111,3112],{"class":565},"()\n",[502,3114,3115,3118,3120,3123,3125,3127,3130,3132,3134,3136,3139,3141],{"class":504,"line":1688},[502,3116,3117],{"class":516},"  run",[502,3119,470],{"class":512},[502,3121,3122],{"class":552},"set",[502,3124,556],{"class":565},[502,3126,891],{"class":512},[502,3128,3129],{"class":565}," found",[502,3131,569],{"class":512},[502,3133,3100],{"class":516},[502,3135,470],{"class":512},[502,3137,3138],{"class":516},"length",[502,3140,526],{"class":512},[502,3142,596],{"class":565},[502,3144,3145],{"class":504,"line":2297},[502,3146,546],{"emptyLinePlaceholder":545},[502,3148,3149,3152,3154,3156,3159,3162,3164,3167],{"class":504,"line":2336},[502,3150,3151],{"class":508},"  for",[502,3153,1604],{"class":565},[502,3155,1910],{"class":1515},[502,3157,3158],{"class":516}," record",[502,3160,3161],{"class":512}," of",[502,3163,3100],{"class":516},[502,3165,3166],{"class":565},") ",[502,3168,559],{"class":512},[502,3170,3172,3175,3178,3180,3183],{"class":504,"line":3171},13,[502,3173,3174],{"class":508},"    await",[502,3176,3177],{"class":552}," syncOne",[502,3179,556],{"class":565},[502,3181,3182],{"class":516},"record",[502,3184,596],{"class":565},[502,3186,3188,3190,3192,3194,3196,3198,3200,3202,3204,3207,3209,3211,3214,3216,3218,3220,3223,3225],{"class":504,"line":3187},14,[502,3189,1624],{"class":516},[502,3191,470],{"class":512},[502,3193,774],{"class":552},[502,3195,556],{"class":565},[502,3197,891],{"class":512},[502,3199,1958],{"class":565},[502,3201,569],{"class":512},[502,3203,532],{"class":512},[502,3205,3206],{"class":535},"record_synced",[502,3208,584],{"class":512},[502,3210,520],{"class":512},[502,3212,3213],{"class":565}," id",[502,3215,569],{"class":512},[502,3217,3158],{"class":516},[502,3219,470],{"class":512},[502,3221,3222],{"class":516},"id",[502,3224,526],{"class":512},[502,3226,596],{"class":565},[502,3228,3230],{"class":504,"line":3229},15,[502,3231,1685],{"class":512},[502,3233,3235],{"class":504,"line":3234},16,[502,3236,546],{"emptyLinePlaceholder":545},[502,3238,3240,3242,3244,3246,3248,3250,3253,3255,3257,3260,3262,3264,3267,3269,3271,3273,3275,3277],{"class":504,"line":3239},17,[502,3241,3117],{"class":516},[502,3243,470],{"class":512},[502,3245,3122],{"class":552},[502,3247,556],{"class":565},[502,3249,891],{"class":512},[502,3251,3252],{"class":565}," status",[502,3254,569],{"class":512},[502,3256,532],{"class":512},[502,3258,3259],{"class":535},"complete",[502,3261,584],{"class":512},[502,3263,520],{"class":512},[502,3265,3266],{"class":565}," synced",[502,3268,569],{"class":512},[502,3270,3100],{"class":516},[502,3272,470],{"class":512},[502,3274,3138],{"class":516},[502,3276,526],{"class":512},[502,3278,596],{"class":565},[502,3280,3282,3284,3287,3290],{"class":504,"line":3281},18,[502,3283,593],{"class":512},[502,3285,3286],{"class":508}," catch",[502,3288,3289],{"class":516}," (err) ",[502,3291,559],{"class":512},[502,3293,3295,3297,3299,3301,3303,3305,3307,3309,3311,3313,3315,3317],{"class":504,"line":3294},19,[502,3296,1541],{"class":516},[502,3298,470],{"class":512},[502,3300,745],{"class":552},[502,3302,556],{"class":565},[502,3304,891],{"class":512},[502,3306,1958],{"class":565},[502,3308,569],{"class":512},[502,3310,532],{"class":512},[502,3312,967],{"class":535},[502,3314,584],{"class":512},[502,3316,526],{"class":512},[502,3318,596],{"class":565},[502,3320,3322,3324,3326,3328,3330,3333,3336,3339],{"class":504,"line":3321},20,[502,3323,3117],{"class":516},[502,3325,470],{"class":512},[502,3327,745],{"class":552},[502,3329,556],{"class":565},[502,3331,3332],{"class":516},"err",[502,3334,3335],{"class":508}," as",[502,3337,3338],{"class":807}," Error",[502,3340,596],{"class":565},[502,3342,3344,3347],{"class":504,"line":3343},21,[502,3345,3346],{"class":508},"  throw",[502,3348,3349],{"class":516}," err\n",[502,3351,3353,3355,3358],{"class":504,"line":3352},22,[502,3354,593],{"class":512},[502,3356,3357],{"class":508}," finally",[502,3359,1536],{"class":512},[502,3361,3363,3365,3367,3370],{"class":504,"line":3362},23,[502,3364,3117],{"class":516},[502,3366,470],{"class":512},[502,3368,3369],{"class":552},"emit",[502,3371,3112],{"class":565},[502,3373,3375],{"class":504,"line":3374},24,[502,3376,1691],{"class":512},[502,3378,3380],{"class":504,"line":3379},25,[502,3381,546],{"emptyLinePlaceholder":545},[502,3383,3385,3387,3389,3391,3393,3395,3397,3399,3401,3403,3406,3408],{"class":504,"line":3384},26,[502,3386,451],{"class":516},[502,3388,470],{"class":512},[502,3390,473],{"class":552},[502,3392,556],{"class":516},[502,3394,584],{"class":512},[502,3396,3027],{"class":535},[502,3398,584],{"class":512},[502,3400,520],{"class":512},[502,3402,532],{"class":512},[502,3404,3405],{"class":535},"Worker finished",[502,3407,584],{"class":512},[502,3409,596],{"class":516},[445,3411,447,3412,3414,3415,3417],{},[449,3413,2937],{}," calls give you a real-time trail in development; the ",[449,3416,2933],{}," block gives your dashboard one queryable row per run. Both go through the same drain.",[484,3419,3421],{"id":3420},"next-steps","Next Steps",[3423,3424,3425,3431,3447,3455,3460,3465],"ul",{},[3426,3427,3428,3430],"li",{},[464,3429,46],{"href":47},": Accumulate context and emit comprehensive events",[3426,3432,3433,3435,3436,3439,3440,3443,3444],{},[464,3434,51],{"href":52},": Throw errors with ",[449,3437,3438],{},"why",", ",[449,3441,3442],{},"fix",", and ",[449,3445,3446],{},"link",[3426,3448,3449,3451,3452,3454],{},[464,3450,414],{"href":415},": All ",[449,3453,553],{}," options",[3426,3456,3457,3459],{},[464,3458,90],{"href":95},": Send events to Axiom, Sentry, PostHog, and more",[3426,3461,3462,3464],{},[464,3463,466],{"href":228},": Scripts, workers, and libraries without a web framework",[3426,3466,3467,3470],{},[464,3468,3469],{"href":432},"evlog vs other loggers",": Side-by-side with pino, winston, consola",[3472,3473,3474],"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 .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 .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}html pre.shiki code .sbssI, html code.shiki .sbssI{--shiki-light:#F76D47;--shiki-default:#F78C6C;--shiki-dark:#F78C6C}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}",{"title":498,"searchDepth":542,"depth":542,"links":3476},[3477,3478,3482,3483,3488,3489,3490,3491],{"id":486,"depth":542,"text":487},{"id":643,"depth":542,"text":644,"children":3479},[3480,3481],{"id":648,"depth":549,"text":649},{"id":847,"depth":549,"text":848},{"id":1085,"depth":542,"text":1086},{"id":1182,"depth":542,"text":1183,"children":3484},[3485,3486,3487],{"id":1186,"depth":549,"text":1187},{"id":1336,"depth":549,"text":1337},{"id":1481,"depth":549,"text":1482},{"id":1694,"depth":542,"text":1695},{"id":1864,"depth":542,"text":1865},{"id":2925,"depth":542,"text":2926},{"id":3420,"depth":542,"text":3421},"evlog's general-purpose logger. A drop-in for console.log, pino, or consola, with the same level filtering, drain pipeline, redaction, and pretty\u002FJSON output as wide events.","md",[3495,3497],{"label":46,"icon":49,"to":47,"color":460,"variant":3496},"subtle",{"label":414,"icon":417,"to":415,"color":460,"variant":3496},{},{"icon":44},{"title":41,"description":3492},"mr6ttIxxdWoGZe4ZZTWhSD_XjIVBpVDjxiCYDkfyrgI",[3503,3505],{"title":36,"path":37,"stem":38,"description":3504,"icon":39,"children":-1},"The mental model — three logging modes, the wide event lifecycle, sampling, typed fields, and redaction. Read this section in order if you're new; pick what you need if you're not.",{"title":46,"path":47,"stem":48,"description":3506,"icon":49,"children":-1},"Accumulate context over any unit of work and emit a single comprehensive event. Works for HTTP requests, scripts, background jobs, queue workers, and workflows.",1779694501048]