[{"data":1,"prerenderedAt":1529},["ShallowReactive",2],{"navigation_docs":3,"-integrate-frameworks-aws-lambda":444,"-integrate-frameworks-aws-lambda-surround":1524},[4,30,80,245,358,413],{"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,353],{"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,"icon":357},"eve","\u002Fuse-cases\u002Feve","4.use-cases\u002F5.eve","i-custom-eve",{"title":359,"path":360,"stem":361,"children":362,"page":29},"Extend","\u002Fextend","5.extend",[363,367,372,377,382,386,390,394,398,403,408],{"title":36,"path":364,"stem":365,"icon":366},"\u002Fextend\u002Foverview","5.extend\u002F0.overview","i-lucide-blocks",{"title":368,"path":369,"stem":370,"icon":371},"Stream","\u002Fextend\u002Fstream","5.extend\u002F1.stream","i-lucide-radio-tower",{"title":373,"path":374,"stem":375,"icon":376},"Custom framework","\u002Fextend\u002Fcustom-framework","5.extend\u002F10.custom-framework","i-lucide-puzzle",{"title":378,"path":379,"stem":380,"icon":381},"FS reader","\u002Fextend\u002Ffs-reader","5.extend\u002F2.fs-reader","i-lucide-folder-search",{"title":345,"path":383,"stem":384,"icon":385},"\u002Fextend\u002Fconsumer-recipes","5.extend\u002F3.consumer-recipes","i-lucide-chef-hat",{"title":387,"path":388,"stem":389,"icon":366},"Plugins","\u002Fextend\u002Fplugins","5.extend\u002F4.plugins",{"title":391,"path":392,"stem":393,"icon":352},"Custom enrichers","\u002Fextend\u002Fcustom-enrichers","5.extend\u002F5.custom-enrichers",{"title":395,"path":396,"stem":397,"icon":64},"Tail sampling","\u002Fextend\u002Ftail-sampling","5.extend\u002F6.tail-sampling",{"title":399,"path":400,"stem":401,"icon":402},"Identity headers","\u002Fextend\u002Fidentity-headers","5.extend\u002F7.identity-headers","i-lucide-fingerprint",{"title":404,"path":405,"stem":406,"icon":407},"Custom drains","\u002Fextend\u002Fcustom-drains","5.extend\u002F8.custom-drains","i-lucide-share-2",{"title":409,"path":410,"stem":411,"icon":412},"Drain pipeline","\u002Fextend\u002Fdrain-pipeline","5.extend\u002F9.drain-pipeline","i-lucide-workflow",{"title":414,"path":415,"stem":416,"children":417,"page":29},"Reference","\u002Freference","6.reference",[418,423,426,431,435,440],{"title":419,"path":420,"stem":421,"icon":422},"Configuration","\u002Freference\u002Fconfiguration","6.reference\u002F1.configuration","i-lucide-settings",{"title":312,"path":424,"stem":425,"icon":315},"\u002Freference\u002Fperformance","6.reference\u002F2.performance",{"title":427,"path":428,"stem":429,"icon":430},"Vite Plugin","\u002Freference\u002Fvite-plugin","6.reference\u002F3.vite-plugin","i-custom-vite",{"title":432,"path":433,"stem":434,"icon":318},"Best Practices","\u002Freference\u002Fbest-practices","6.reference\u002F4.best-practices",{"title":436,"path":437,"stem":438,"icon":439},"vs Other Loggers","\u002Freference\u002Fvs-other-loggers","6.reference\u002F5.vs-other-loggers","i-lucide-scale",{"title":441,"path":442,"stem":443,"icon":352},"Agent Skills","\u002Freference\u002Fagent-skills","6.reference\u002F6.agent-skills",{"id":445,"title":241,"body":446,"description":1517,"extension":1518,"links":1519,"meta":1520,"navigation":1521,"path":242,"seo":1522,"stem":243,"__hash__":1523},"docs\u002F3.integrate\u002Fframeworks\u002F16.aws-lambda.md",{"type":447,"value":448,"toc":1505},"minimark",[449,480,520,529,540,555,569,572,577,648,652,1161,1170,1177,1195,1320,1333,1337,1355,1461,1465,1501],[450,451,452,453,457,458,462,463,467,468,471,472,475,476,479],"p",{},"AWS Lambda has ",[454,455,456],"strong",{},"no HTTP middleware lifecycle"," like Nuxt or Express, so evlog behaves like ",[459,460,461],"a",{"href":228},"standalone TypeScript",": call ",[464,465,466],"code",{},"initLogger()"," once, create a logger ",[454,469,470],{},"per invocation"," (or per SQS message) with ",[464,473,474],{},"createLogger()",", then call ",[464,477,478],{},"log.emit()"," when work finishes.",[481,482,485,488,507],"prompt",{":actions":483,"description":484,"icon":244},"[\"copy\",\"cursor\",\"windsurf\"]","Set up evlog in my AWS Lambda function",[450,486,487],{},"Set up evlog in an AWS Lambda function (e.g. SQS consumer).",[489,490,491,495,498,501,504],"ul",{},[492,493,494],"li",{},"Install evlog: pnpm add evlog",[492,496,497],{},"Call initLogger({ env: { service: 'my-fn' } }) once at module load (cold start)",[492,499,500],{},"In the handler, create a new createLogger({ messageId, ... }) per invocation or per message",[492,502,503],{},"Use log.set() to accumulate context; call log.emit() when done",[492,505,506],{},"Avoid a single module-level logger instance reused across invocations (Lambda reuses runtimes)",[450,508,509,510,515,516],{},"Docs: ",[459,511,512],{"href":512,"rel":513},"https:\u002F\u002Fwww.evlog.dev\u002Fintegrate\u002Fframeworks\u002Faws-lambda",[514],"nofollow","\nAdapters: ",[459,517,518],{"href":518,"rel":519},"https:\u002F\u002Fwww.evlog.dev\u002Fintegrate\u002Fadapters\u002Foverview",[514],[521,522,524,525,528],"h2",{"id":523},"why-not-one-global-createlogger","Why not one global ",[464,526,527],{},"createLogger","?",[450,530,531,532,535,536,539],{},"Lambda ",[454,533,534],{},"execution environments are reused",": the same process can handle many invocations in sequence. Module-level variables persist, so ",[454,537,538],{},"one shared logger instance"," can leak fields from a previous invocation into the next.",[450,541,542,545,546,548,549,554],{},[454,543,544],{},"Do this:"," ",[464,547,466],{}," once at the top level (configuration only), and ",[454,550,551,553],{},[464,552,474],{}," inside the handler"," (or inside the loop over SQS records) for each unit of work.",[450,556,557,560,561,564,565,568],{},[454,558,559],{},"Dependency injection"," (passing ",[464,562,563],{},"log"," into functions) is optional—it helps tests and clarity—but what matters is ",[454,566,567],{},"one logger per invocation",", not whether you use DI.",[521,570,25],{"id":571},"quick-start",[573,574,576],"h3",{"id":575},"_1-install","1. Install",[578,579,580,605,619,633],"code-group",{},[581,582,588],"pre",{"className":583,"code":584,"filename":585,"language":586,"meta":587,"style":587},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","pnpm add evlog\n","pnpm","bash","",[464,589,590],{"__ignoreMap":587},[591,592,595,598,602],"span",{"class":593,"line":594},"line",1,[591,596,585],{"class":597},"sBMFI",[591,599,601],{"class":600},"sfazB"," add",[591,603,604],{"class":600}," evlog\n",[581,606,609],{"className":583,"code":607,"filename":608,"language":586,"meta":587,"style":587},"bun add evlog\n","bun",[464,610,611],{"__ignoreMap":587},[591,612,613,615,617],{"class":593,"line":594},[591,614,608],{"class":597},[591,616,601],{"class":600},[591,618,604],{"class":600},[581,620,623],{"className":583,"code":621,"filename":622,"language":586,"meta":587,"style":587},"yarn add evlog\n","yarn",[464,624,625],{"__ignoreMap":587},[591,626,627,629,631],{"class":593,"line":594},[591,628,622],{"class":597},[591,630,601],{"class":600},[591,632,604],{"class":600},[581,634,637],{"className":583,"code":635,"filename":636,"language":586,"meta":587,"style":587},"npm install evlog\n","npm",[464,638,639],{"__ignoreMap":587},[591,640,641,643,646],{"class":593,"line":594},[591,642,636],{"class":597},[591,644,645],{"class":600}," install",[591,647,604],{"class":600},[573,649,651],{"id":650},"_2-initialize-once-log-per-invocation","2. Initialize once, log per invocation",[581,653,658],{"className":654,"code":655,"filename":656,"language":657,"meta":587,"style":587},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import type { SQSEvent } from 'aws-lambda'\nimport { initLogger, createLogger } from 'evlog'\n\ninitLogger({\n  env: { service: 'sqs-consumer', environment: process.env.NODE_ENV },\n})\n\nexport async function handler(event: SQSEvent) {\n  for (const record of event.Records) {\n    const log = createLogger({\n      messageId: record.messageId,\n      approximateReceiveCount: record.attributes?.ApproximateReceiveCount,\n    })\n\n    try {\n      log.set({ queue: { name: record.eventSourceARN } })\n      \u002F\u002F … parse record.body and process the message\n      log.set({ status: 'ok' })\n    } catch (error) {\n      log.error(error instanceof Error ? error : new Error(String(error)))\n      log.set({ status: 'error' })\n      throw error\n    } finally {\n      log.emit()\n    }\n  }\n}\n","src\u002Fhandler.ts","typescript",[464,659,660,692,719,726,739,788,797,802,834,865,883,901,924,932,937,945,986,993,1022,1039,1084,1111,1120,1130,1143,1149,1155],{"__ignoreMap":587},[591,661,662,666,669,673,677,680,683,686,689],{"class":593,"line":594},[591,663,665],{"class":664},"s7zQu","import",[591,667,668],{"class":664}," type",[591,670,672],{"class":671},"sMK4o"," {",[591,674,676],{"class":675},"sTEyZ"," SQSEvent",[591,678,679],{"class":671}," }",[591,681,682],{"class":664}," from",[591,684,685],{"class":671}," '",[591,687,688],{"class":600},"aws-lambda",[591,690,691],{"class":671},"'\n",[591,693,695,697,699,702,705,708,710,712,714,717],{"class":593,"line":694},2,[591,696,665],{"class":664},[591,698,672],{"class":671},[591,700,701],{"class":675}," initLogger",[591,703,704],{"class":671},",",[591,706,707],{"class":675}," createLogger",[591,709,679],{"class":671},[591,711,682],{"class":664},[591,713,685],{"class":671},[591,715,716],{"class":600},"evlog",[591,718,691],{"class":671},[591,720,722],{"class":593,"line":721},3,[591,723,725],{"emptyLinePlaceholder":724},true,"\n",[591,727,729,733,736],{"class":593,"line":728},4,[591,730,732],{"class":731},"s2Zo4","initLogger",[591,734,735],{"class":675},"(",[591,737,738],{"class":671},"{\n",[591,740,742,746,749,751,754,756,758,761,764,766,769,771,774,777,780,782,785],{"class":593,"line":741},5,[591,743,745],{"class":744},"swJcz","  env",[591,747,748],{"class":671},":",[591,750,672],{"class":671},[591,752,753],{"class":744}," service",[591,755,748],{"class":671},[591,757,685],{"class":671},[591,759,760],{"class":600},"sqs-consumer",[591,762,763],{"class":671},"'",[591,765,704],{"class":671},[591,767,768],{"class":744}," environment",[591,770,748],{"class":671},[591,772,773],{"class":675}," process",[591,775,776],{"class":671},".",[591,778,779],{"class":675},"env",[591,781,776],{"class":671},[591,783,784],{"class":675},"NODE_ENV ",[591,786,787],{"class":671},"},\n",[591,789,791,794],{"class":593,"line":790},6,[591,792,793],{"class":671},"}",[591,795,796],{"class":675},")\n",[591,798,800],{"class":593,"line":799},7,[591,801,725],{"emptyLinePlaceholder":724},[591,803,805,808,812,815,818,820,824,826,828,831],{"class":593,"line":804},8,[591,806,807],{"class":664},"export",[591,809,811],{"class":810},"spNyl"," async",[591,813,814],{"class":810}," function",[591,816,817],{"class":731}," handler",[591,819,735],{"class":671},[591,821,823],{"class":822},"sHdIc","event",[591,825,748],{"class":671},[591,827,676],{"class":597},[591,829,830],{"class":671},")",[591,832,833],{"class":671}," {\n",[591,835,837,840,843,846,849,852,855,857,860,863],{"class":593,"line":836},9,[591,838,839],{"class":664},"  for",[591,841,842],{"class":744}," (",[591,844,845],{"class":810},"const",[591,847,848],{"class":675}," record",[591,850,851],{"class":671}," of",[591,853,854],{"class":675}," event",[591,856,776],{"class":671},[591,858,859],{"class":675},"Records",[591,861,862],{"class":744},") ",[591,864,738],{"class":671},[591,866,868,871,874,877,879,881],{"class":593,"line":867},10,[591,869,870],{"class":810},"    const",[591,872,873],{"class":675}," log",[591,875,876],{"class":671}," =",[591,878,707],{"class":731},[591,880,735],{"class":744},[591,882,738],{"class":671},[591,884,886,889,891,893,895,898],{"class":593,"line":885},11,[591,887,888],{"class":744},"      messageId",[591,890,748],{"class":671},[591,892,848],{"class":675},[591,894,776],{"class":671},[591,896,897],{"class":675},"messageId",[591,899,900],{"class":671},",\n",[591,902,904,907,909,911,913,916,919,922],{"class":593,"line":903},12,[591,905,906],{"class":744},"      approximateReceiveCount",[591,908,748],{"class":671},[591,910,848],{"class":675},[591,912,776],{"class":671},[591,914,915],{"class":675},"attributes",[591,917,918],{"class":671},"?.",[591,920,921],{"class":675},"ApproximateReceiveCount",[591,923,900],{"class":671},[591,925,927,930],{"class":593,"line":926},13,[591,928,929],{"class":671},"    }",[591,931,796],{"class":744},[591,933,935],{"class":593,"line":934},14,[591,936,725],{"emptyLinePlaceholder":724},[591,938,940,943],{"class":593,"line":939},15,[591,941,942],{"class":664},"    try",[591,944,833],{"class":671},[591,946,948,951,953,956,958,961,964,966,968,971,973,975,977,980,982,984],{"class":593,"line":947},16,[591,949,950],{"class":675},"      log",[591,952,776],{"class":671},[591,954,955],{"class":731},"set",[591,957,735],{"class":744},[591,959,960],{"class":671},"{",[591,962,963],{"class":744}," queue",[591,965,748],{"class":671},[591,967,672],{"class":671},[591,969,970],{"class":744}," name",[591,972,748],{"class":671},[591,974,848],{"class":675},[591,976,776],{"class":671},[591,978,979],{"class":675},"eventSourceARN",[591,981,679],{"class":671},[591,983,679],{"class":671},[591,985,796],{"class":744},[591,987,989],{"class":593,"line":988},17,[591,990,992],{"class":991},"sHwdD","      \u002F\u002F … parse record.body and process the message\n",[591,994,996,998,1000,1002,1004,1006,1009,1011,1013,1016,1018,1020],{"class":593,"line":995},18,[591,997,950],{"class":675},[591,999,776],{"class":671},[591,1001,955],{"class":731},[591,1003,735],{"class":744},[591,1005,960],{"class":671},[591,1007,1008],{"class":744}," status",[591,1010,748],{"class":671},[591,1012,685],{"class":671},[591,1014,1015],{"class":600},"ok",[591,1017,763],{"class":671},[591,1019,679],{"class":671},[591,1021,796],{"class":744},[591,1023,1025,1027,1030,1032,1035,1037],{"class":593,"line":1024},19,[591,1026,929],{"class":671},[591,1028,1029],{"class":664}," catch",[591,1031,842],{"class":744},[591,1033,1034],{"class":675},"error",[591,1036,862],{"class":744},[591,1038,738],{"class":671},[591,1040,1042,1044,1046,1048,1050,1052,1055,1058,1061,1064,1067,1070,1072,1074,1077,1079,1081],{"class":593,"line":1041},20,[591,1043,950],{"class":675},[591,1045,776],{"class":671},[591,1047,1034],{"class":731},[591,1049,735],{"class":744},[591,1051,1034],{"class":675},[591,1053,1054],{"class":671}," instanceof",[591,1056,1057],{"class":597}," Error",[591,1059,1060],{"class":671}," ?",[591,1062,1063],{"class":675}," error",[591,1065,1066],{"class":671}," :",[591,1068,1069],{"class":671}," new",[591,1071,1057],{"class":731},[591,1073,735],{"class":744},[591,1075,1076],{"class":731},"String",[591,1078,735],{"class":744},[591,1080,1034],{"class":675},[591,1082,1083],{"class":744},")))\n",[591,1085,1087,1089,1091,1093,1095,1097,1099,1101,1103,1105,1107,1109],{"class":593,"line":1086},21,[591,1088,950],{"class":675},[591,1090,776],{"class":671},[591,1092,955],{"class":731},[591,1094,735],{"class":744},[591,1096,960],{"class":671},[591,1098,1008],{"class":744},[591,1100,748],{"class":671},[591,1102,685],{"class":671},[591,1104,1034],{"class":600},[591,1106,763],{"class":671},[591,1108,679],{"class":671},[591,1110,796],{"class":744},[591,1112,1114,1117],{"class":593,"line":1113},22,[591,1115,1116],{"class":664},"      throw",[591,1118,1119],{"class":675}," error\n",[591,1121,1123,1125,1128],{"class":593,"line":1122},23,[591,1124,929],{"class":671},[591,1126,1127],{"class":664}," finally",[591,1129,833],{"class":671},[591,1131,1133,1135,1137,1140],{"class":593,"line":1132},24,[591,1134,950],{"class":675},[591,1136,776],{"class":671},[591,1138,1139],{"class":731},"emit",[591,1141,1142],{"class":744},"()\n",[591,1144,1146],{"class":593,"line":1145},25,[591,1147,1148],{"class":671},"    }\n",[591,1150,1152],{"class":593,"line":1151},26,[591,1153,1154],{"class":671},"  }\n",[591,1156,1158],{"class":593,"line":1157},27,[591,1159,1160],{"class":671},"}\n",[450,1162,1163,1164,545,1167,1169],{},"If you process the whole batch as one logical unit, use a ",[454,1165,1166],{},"single",[464,1168,474],{}," per handler invocation with batch metadata instead of one logger per record.",[521,1171,1173,1174],{"id":1172},"stdout-and-silent","Stdout and ",[464,1175,1176],{},"silent",[450,1178,1179,1180,1183,1184,1187,1188,1191,1192,776],{},"Many teams ingest Lambda logs from ",[454,1181,1182],{},"CloudWatch"," via stdout. If you use a ",[454,1185,1186],{},"drain adapter"," (OTLP, Datadog, Axiom, etc.) and want JSON or platform-specific formatting without duplicate console noise, set ",[464,1189,1190],{},"silent: true"," in production—see ",[459,1193,419],{"href":1194},"\u002Freference\u002Fconfiguration#silent-mode",[581,1196,1198],{"className":654,"code":1197,"filename":656,"language":657,"meta":587,"style":587},"import { createAxiomDrain } from 'evlog\u002Faxiom'\nimport { initLogger } from 'evlog'\n\ninitLogger({\n  env: { service: 'sqs-consumer' },\n  silent: process.env.NODE_ENV === 'production',\n  drain: createAxiomDrain(),\n})\n",[464,1199,1200,1220,1238,1242,1250,1271,1300,1314],{"__ignoreMap":587},[591,1201,1202,1204,1206,1209,1211,1213,1215,1218],{"class":593,"line":594},[591,1203,665],{"class":664},[591,1205,672],{"class":671},[591,1207,1208],{"class":675}," createAxiomDrain",[591,1210,679],{"class":671},[591,1212,682],{"class":664},[591,1214,685],{"class":671},[591,1216,1217],{"class":600},"evlog\u002Faxiom",[591,1219,691],{"class":671},[591,1221,1222,1224,1226,1228,1230,1232,1234,1236],{"class":593,"line":694},[591,1223,665],{"class":664},[591,1225,672],{"class":671},[591,1227,701],{"class":675},[591,1229,679],{"class":671},[591,1231,682],{"class":664},[591,1233,685],{"class":671},[591,1235,716],{"class":600},[591,1237,691],{"class":671},[591,1239,1240],{"class":593,"line":721},[591,1241,725],{"emptyLinePlaceholder":724},[591,1243,1244,1246,1248],{"class":593,"line":728},[591,1245,732],{"class":731},[591,1247,735],{"class":675},[591,1249,738],{"class":671},[591,1251,1252,1254,1256,1258,1260,1262,1264,1266,1268],{"class":593,"line":741},[591,1253,745],{"class":744},[591,1255,748],{"class":671},[591,1257,672],{"class":671},[591,1259,753],{"class":744},[591,1261,748],{"class":671},[591,1263,685],{"class":671},[591,1265,760],{"class":600},[591,1267,763],{"class":671},[591,1269,1270],{"class":671}," },\n",[591,1272,1273,1276,1278,1280,1282,1284,1286,1288,1291,1293,1296,1298],{"class":593,"line":790},[591,1274,1275],{"class":744},"  silent",[591,1277,748],{"class":671},[591,1279,773],{"class":675},[591,1281,776],{"class":671},[591,1283,779],{"class":675},[591,1285,776],{"class":671},[591,1287,784],{"class":675},[591,1289,1290],{"class":671},"===",[591,1292,685],{"class":671},[591,1294,1295],{"class":600},"production",[591,1297,763],{"class":671},[591,1299,900],{"class":671},[591,1301,1302,1305,1307,1309,1312],{"class":593,"line":799},[591,1303,1304],{"class":744},"  drain",[591,1306,748],{"class":671},[591,1308,1208],{"class":731},[591,1310,1311],{"class":675},"()",[591,1313,900],{"class":671},[591,1315,1316,1318],{"class":593,"line":804},[591,1317,793],{"class":671},[591,1319,796],{"class":675},[1321,1322,1325,1326,1328,1329,1332],"callout",{"color":1323,"icon":1324},"warning","i-lucide-alert-triangle","If ",[464,1327,1176],{}," is enabled without a ",[464,1330,1331],{},"drain",", events may not be visible anywhere. See the configuration docs for details.",[521,1334,1336],{"id":1335},"error-handling","Error handling",[450,1338,1339,1340,1343,1344,1347,1348,1347,1351,1354],{},"Use ",[464,1341,1342],{},"createError"," where you want structured fields (",[464,1345,1346],{},"why",", ",[464,1349,1350],{},"fix",[464,1352,1353],{},"link","). Map failures to your Lambda return or rethrow so SQS retry\u002FDLQ behavior stays correct—evlog does not replace AWS error semantics.",[581,1356,1358],{"className":654,"code":1357,"filename":656,"language":657,"meta":587,"style":587},"import { createError } from 'evlog'\n\nthrow createError({\n  message: 'Invalid payload',\n  status: 400,\n  why: 'Required field missing',\n  fix: 'Include orderId in the message body',\n})\n",[464,1359,1360,1379,1383,1394,1410,1423,1439,1455],{"__ignoreMap":587},[591,1361,1362,1364,1366,1369,1371,1373,1375,1377],{"class":593,"line":594},[591,1363,665],{"class":664},[591,1365,672],{"class":671},[591,1367,1368],{"class":675}," createError",[591,1370,679],{"class":671},[591,1372,682],{"class":664},[591,1374,685],{"class":671},[591,1376,716],{"class":600},[591,1378,691],{"class":671},[591,1380,1381],{"class":593,"line":694},[591,1382,725],{"emptyLinePlaceholder":724},[591,1384,1385,1388,1390,1392],{"class":593,"line":721},[591,1386,1387],{"class":664},"throw",[591,1389,1368],{"class":731},[591,1391,735],{"class":675},[591,1393,738],{"class":671},[591,1395,1396,1399,1401,1403,1406,1408],{"class":593,"line":728},[591,1397,1398],{"class":744},"  message",[591,1400,748],{"class":671},[591,1402,685],{"class":671},[591,1404,1405],{"class":600},"Invalid payload",[591,1407,763],{"class":671},[591,1409,900],{"class":671},[591,1411,1412,1415,1417,1421],{"class":593,"line":741},[591,1413,1414],{"class":744},"  status",[591,1416,748],{"class":671},[591,1418,1420],{"class":1419},"sbssI"," 400",[591,1422,900],{"class":671},[591,1424,1425,1428,1430,1432,1435,1437],{"class":593,"line":790},[591,1426,1427],{"class":744},"  why",[591,1429,748],{"class":671},[591,1431,685],{"class":671},[591,1433,1434],{"class":600},"Required field missing",[591,1436,763],{"class":671},[591,1438,900],{"class":671},[591,1440,1441,1444,1446,1448,1451,1453],{"class":593,"line":799},[591,1442,1443],{"class":744},"  fix",[591,1445,748],{"class":671},[591,1447,685],{"class":671},[591,1449,1450],{"class":600},"Include orderId in the message body",[591,1452,763],{"class":671},[591,1454,900],{"class":671},[591,1456,1457,1459],{"class":593,"line":804},[591,1458,793],{"class":671},[591,1460,796],{"class":675},[521,1462,1464],{"id":1463},"related","Related",[489,1466,1467,1482,1496],{},[492,1468,1469,1472,1473,1475,1476,1475,1478,1481],{},[459,1470,1471],{"href":228},"Standalone TypeScript",": same ",[464,1474,732],{}," + ",[464,1477,527],{},[464,1479,1480],{},"emit()"," model",[492,1483,1484,1486,1487,1347,1489,842,1492,1495],{},[459,1485,419],{"href":420},": ",[464,1488,1176],{},[464,1490,1491],{},"env.region",[464,1493,1494],{},"AWS_REGION","), drains",[492,1497,1498,1500],{},[459,1499,46],{"href":47},": designing one comprehensive event per unit of work",[1502,1503,1504],"style",{},"html pre.shiki code .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}html pre.shiki code .sfazB, html code.shiki .sfazB{--shiki-light:#91B859;--shiki-default:#C3E88D;--shiki-dark:#C3E88D}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .s7zQu, html code.shiki .s7zQu{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#89DDFF;--shiki-default-font-style:italic;--shiki-dark:#89DDFF;--shiki-dark-font-style:italic}html pre.shiki code .sMK4o, html code.shiki .sMK4o{--shiki-light:#39ADB5;--shiki-default:#89DDFF;--shiki-dark:#89DDFF}html pre.shiki code .sTEyZ, html code.shiki .sTEyZ{--shiki-light:#90A4AE;--shiki-default:#EEFFFF;--shiki-dark:#BABED8}html pre.shiki code .s2Zo4, html code.shiki .s2Zo4{--shiki-light:#6182B8;--shiki-default:#82AAFF;--shiki-dark:#82AAFF}html pre.shiki code .swJcz, html code.shiki .swJcz{--shiki-light:#E53935;--shiki-default:#F07178;--shiki-dark:#F07178}html pre.shiki code .spNyl, html code.shiki .spNyl{--shiki-light:#9C3EDA;--shiki-default:#C792EA;--shiki-dark:#C792EA}html pre.shiki code .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 .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 .sbssI, html code.shiki .sbssI{--shiki-light:#F76D47;--shiki-default:#F78C6C;--shiki-dark:#F78C6C}",{"title":587,"searchDepth":694,"depth":694,"links":1506},[1507,1509,1513,1515,1516],{"id":523,"depth":694,"text":1508},"Why not one global createLogger?",{"id":571,"depth":694,"text":25,"children":1510},[1511,1512],{"id":575,"depth":721,"text":576},{"id":650,"depth":721,"text":651},{"id":1172,"depth":694,"text":1514},"Stdout and silent",{"id":1335,"depth":694,"text":1336},{"id":1463,"depth":694,"text":1464},"Wide events and structured logging in AWS Lambda functions, including SQS consumers and event-driven handlers.","md",null,{},{"title":241,"icon":244},{"title":241,"description":1517},"G-NR1RzdqqG4Ln17ujCFAO6dZ2kuzPnu8yT5yoYVuw4",[1525,1527],{"title":236,"path":237,"stem":238,"description":1526,"icon":239,"children":-1},"Automatic wide events, structured errors, drain adapters, enrichers, and tail sampling in oRPC applications.",{"title":36,"path":251,"stem":252,"description":1528,"icon":253,"children":-1},"Recipes that solve a specific problem with evlog — capture browser logs, observe AI SDK calls, identify users from Better Auth, build a tamper-evident audit trail, enrich every event with derived context.",1782925724649]