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