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