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