[{"data":1,"prerenderedAt":1514},["ShallowReactive",2],{"navigation_docs":3,"-integrate-frameworks-aws-lambda":429,"-integrate-frameworks-aws-lambda-surround":1509},[4,30,80,235,343,398],{"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],{"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},"AWS Lambda","\u002Fintegrate\u002Fframeworks\u002Faws-lambda","3.integrate\u002Fframeworks\u002F16.aws-lambda","i-custom-lambda",{"title":236,"path":237,"stem":238,"children":239,"page":29},"Use Cases","\u002Fuse-cases","4.use-cases",[240,244,249,278,306,338],{"title":36,"path":241,"stem":242,"icon":243},"\u002Fuse-cases\u002Foverview","4.use-cases\u002F0.overview","i-lucide-list-checks",{"title":245,"path":246,"stem":247,"icon":248},"Client Logging","\u002Fuse-cases\u002Fclient-logging","4.use-cases\u002F1.client-logging","i-lucide-monitor",{"title":250,"icon":251,"path":252,"stem":253,"children":254,"page":29},"AI SDK","i-simple-icons-vercel","\u002Fuse-cases\u002Fai-sdk","4.use-cases\u002F2.ai-sdk",[255,258,263,268,273],{"title":36,"path":256,"stem":257,"icon":39},"\u002Fuse-cases\u002Fai-sdk\u002Foverview","4.use-cases\u002F2.ai-sdk\u002F01.overview",{"title":259,"path":260,"stem":261,"icon":262},"Usage","\u002Fuse-cases\u002Fai-sdk\u002Fusage","4.use-cases\u002F2.ai-sdk\u002F02.usage","i-lucide-code",{"title":264,"path":265,"stem":266,"icon":267},"Options","\u002Fuse-cases\u002Fai-sdk\u002Foptions","4.use-cases\u002F2.ai-sdk\u002F03.options","i-lucide-sliders",{"title":269,"path":270,"stem":271,"icon":272},"Metadata","\u002Fuse-cases\u002Fai-sdk\u002Fmetadata","4.use-cases\u002F2.ai-sdk\u002F04.metadata","i-lucide-database",{"title":274,"path":275,"stem":276,"icon":277},"Telemetry","\u002Fuse-cases\u002Fai-sdk\u002Ftelemetry","4.use-cases\u002F2.ai-sdk\u002F05.telemetry","i-lucide-activity",{"title":279,"icon":280,"path":281,"stem":282,"children":283,"page":29},"Better Auth","i-simple-icons-betterauth","\u002Fuse-cases\u002Fbetter-auth","4.use-cases\u002F3.better-auth",[284,287,292,297,301],{"title":36,"path":285,"stem":286,"icon":39},"\u002Fuse-cases\u002Fbetter-auth\u002Foverview","4.use-cases\u002F3.better-auth\u002F01.overview",{"title":288,"path":289,"stem":290,"icon":291},"Identify User","\u002Fuse-cases\u002Fbetter-auth\u002Fidentify-user","4.use-cases\u002F3.better-auth\u002F02.identify-user","i-lucide-user-check",{"title":293,"path":294,"stem":295,"icon":296},"Middleware","\u002Fuse-cases\u002Fbetter-auth\u002Fmiddleware","4.use-cases\u002F3.better-auth\u002F03.middleware","i-lucide-shield",{"title":298,"path":299,"stem":300,"icon":248},"Client Sync","\u002Fuse-cases\u002Fbetter-auth\u002Fclient-sync","4.use-cases\u002F3.better-auth\u002F04.client-sync",{"title":302,"path":303,"stem":304,"icon":305},"Performance","\u002Fuse-cases\u002Fbetter-auth\u002Fperformance","4.use-cases\u002F3.better-auth\u002F05.performance","i-lucide-gauge",{"title":307,"icon":308,"path":309,"stem":310,"children":311,"page":29},"Audit Logs","i-lucide-shield-check","\u002Fuse-cases\u002Faudit","4.use-cases\u002F4.audit",[312,315,320,325,330,334],{"title":36,"path":313,"stem":314,"icon":39},"\u002Fuse-cases\u002Faudit\u002Foverview","4.use-cases\u002F4.audit\u002F01.overview",{"title":316,"path":317,"stem":318,"icon":319},"Schema","\u002Fuse-cases\u002Faudit\u002Fschema","4.use-cases\u002F4.audit\u002F02.schema","i-lucide-file-text",{"title":321,"path":322,"stem":323,"icon":324},"Recording","\u002Fuse-cases\u002Faudit\u002Frecording","4.use-cases\u002F4.audit\u002F03.recording","i-lucide-pen-line",{"title":326,"path":327,"stem":328,"icon":329},"Drains","\u002Fuse-cases\u002Faudit\u002Fpipeline","4.use-cases\u002F4.audit\u002F04.pipeline","i-lucide-link",{"title":331,"path":332,"stem":333,"icon":308},"Compliance","\u002Fuse-cases\u002Faudit\u002Fcompliance","4.use-cases\u002F4.audit\u002F05.compliance",{"title":335,"path":336,"stem":337,"icon":79},"Recipes","\u002Fuse-cases\u002Faudit\u002Frecipes","4.use-cases\u002F4.audit\u002F06.recipes",{"title":339,"path":340,"stem":341,"icon":342},"Enrichers","\u002Fuse-cases\u002Fenrichers","4.use-cases\u002F5.enrichers","i-lucide-sparkles",{"title":344,"path":345,"stem":346,"children":347,"page":29},"Extend","\u002Fextend","5.extend",[348,352,357,362,367,371,375,379,383,388,393],{"title":36,"path":349,"stem":350,"icon":351},"\u002Fextend\u002Foverview","5.extend\u002F0.overview","i-lucide-blocks",{"title":353,"path":354,"stem":355,"icon":356},"Stream","\u002Fextend\u002Fstream","5.extend\u002F1.stream","i-lucide-radio-tower",{"title":358,"path":359,"stem":360,"icon":361},"Custom framework","\u002Fextend\u002Fcustom-framework","5.extend\u002F10.custom-framework","i-lucide-puzzle",{"title":363,"path":364,"stem":365,"icon":366},"FS reader","\u002Fextend\u002Ffs-reader","5.extend\u002F2.fs-reader","i-lucide-folder-search",{"title":335,"path":368,"stem":369,"icon":370},"\u002Fextend\u002Fconsumer-recipes","5.extend\u002F3.consumer-recipes","i-lucide-chef-hat",{"title":372,"path":373,"stem":374,"icon":351},"Plugins","\u002Fextend\u002Fplugins","5.extend\u002F4.plugins",{"title":376,"path":377,"stem":378,"icon":342},"Custom enrichers","\u002Fextend\u002Fcustom-enrichers","5.extend\u002F5.custom-enrichers",{"title":380,"path":381,"stem":382,"icon":64},"Tail sampling","\u002Fextend\u002Ftail-sampling","5.extend\u002F6.tail-sampling",{"title":384,"path":385,"stem":386,"icon":387},"Identity headers","\u002Fextend\u002Fidentity-headers","5.extend\u002F7.identity-headers","i-lucide-fingerprint",{"title":389,"path":390,"stem":391,"icon":392},"Custom drains","\u002Fextend\u002Fcustom-drains","5.extend\u002F8.custom-drains","i-lucide-share-2",{"title":394,"path":395,"stem":396,"icon":397},"Drain pipeline","\u002Fextend\u002Fdrain-pipeline","5.extend\u002F9.drain-pipeline","i-lucide-workflow",{"title":399,"path":400,"stem":401,"children":402,"page":29},"Reference","\u002Freference","6.reference",[403,408,411,416,420,425],{"title":404,"path":405,"stem":406,"icon":407},"Configuration","\u002Freference\u002Fconfiguration","6.reference\u002F1.configuration","i-lucide-settings",{"title":302,"path":409,"stem":410,"icon":305},"\u002Freference\u002Fperformance","6.reference\u002F2.performance",{"title":412,"path":413,"stem":414,"icon":415},"Vite Plugin","\u002Freference\u002Fvite-plugin","6.reference\u002F3.vite-plugin","i-custom-vite",{"title":417,"path":418,"stem":419,"icon":308},"Best Practices","\u002Freference\u002Fbest-practices","6.reference\u002F4.best-practices",{"title":421,"path":422,"stem":423,"icon":424},"vs Other Loggers","\u002Freference\u002Fvs-other-loggers","6.reference\u002F5.vs-other-loggers","i-lucide-scale",{"title":426,"path":427,"stem":428,"icon":342},"Agent Skills","\u002Freference\u002Fagent-skills","6.reference\u002F6.agent-skills",{"id":430,"title":231,"body":431,"description":1502,"extension":1503,"links":1504,"meta":1505,"navigation":1506,"path":232,"seo":1507,"stem":233,"__hash__":1508},"docs\u002F3.integrate\u002Fframeworks\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":223},"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":234},"[\"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\u002Fintegrate\u002Fframeworks\u002Faws-lambda",[499],"nofollow","\nAdapters: ",[444,502,503],{"href":503,"rel":504},"https:\u002F\u002Fwww.evlog.dev\u002Fintegrate\u002Fadapters\u002Foverview",[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,25],{"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,404],{"href":1179},"\u002Freference\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":223},"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,404],{"href":405},": ",[449,1473,1161],{},[449,1475,1476],{},"env.region",[449,1478,1479],{},"AWS_REGION","), drains",[477,1482,1483,1485],{},[444,1484,46],{"href":47},": 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":25,"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":231,"icon":234},{"title":231,"description":1502},"G-NR1RzdqqG4Ln17ujCFAO6dZ2kuzPnu8yT5yoYVuw4",[1510,1512],{"title":226,"path":227,"stem":228,"description":1511,"icon":229,"children":-1},"Wide events and structured errors in Astro server middleware.",{"title":36,"path":241,"stem":242,"description":1513,"icon":243,"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.",1778440151876]