[{"data":1,"prerenderedAt":2961},["ShallowReactive",2],{"navigation_docs":3,"-logging-audit-overview":421,"-logging-audit-overview-surround":2956},[4,35,159,201,289,318,405],{"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,299,304,309,314],{"title":295,"path":296,"stem":297,"icon":298},"Identity headers","\u002Fbuild-on-top\u002Fidentity-headers","5.build-on-top\u002F1.identity-headers","i-lucide-fingerprint",{"title":300,"path":301,"stem":302,"icon":303},"Stream API","\u002Fbuild-on-top\u002Fstream-api","5.build-on-top\u002F2.stream-api","i-lucide-radio-tower",{"title":305,"path":306,"stem":307,"icon":308},"SSE bridge","\u002Fbuild-on-top\u002Fsse-bridge","5.build-on-top\u002F3.sse-bridge","i-lucide-wifi",{"title":310,"path":311,"stem":312,"icon":313},"FS reader","\u002Fbuild-on-top\u002Ffs-reader","5.build-on-top\u002F4.fs-reader","i-lucide-folder-search",{"title":156,"path":315,"stem":316,"icon":317},"\u002Fbuild-on-top\u002Frecipes","5.build-on-top\u002F4.recipes","i-lucide-chef-hat",{"title":319,"path":320,"stem":321,"children":322,"page":34},"Adapters","\u002Fadapters","6.adapters",[323,326,366,381],{"title":41,"path":324,"stem":325,"icon":44},"\u002Fadapters\u002Foverview","6.adapters\u002F01.overview",{"title":327,"path":328,"stem":329,"children":330,"page":34},"Cloud destinations","\u002Fadapters\u002Fcloud","6.adapters\u002F02.cloud",[331,336,341,346,351,356,361],{"title":332,"path":333,"stem":334,"icon":335},"Axiom","\u002Fadapters\u002Fcloud\u002Faxiom","6.adapters\u002F02.cloud\u002F01.axiom","i-custom-axiom",{"title":337,"path":338,"stem":339,"icon":340},"OTLP","\u002Fadapters\u002Fcloud\u002Fotlp","6.adapters\u002F02.cloud\u002F02.otlp","i-simple-icons-opentelemetry",{"title":342,"path":343,"stem":344,"icon":345},"PostHog","\u002Fadapters\u002Fcloud\u002Fposthog","6.adapters\u002F02.cloud\u002F03.posthog","i-simple-icons-posthog",{"title":347,"path":348,"stem":349,"icon":350},"Sentry","\u002Fadapters\u002Fcloud\u002Fsentry","6.adapters\u002F02.cloud\u002F04.sentry","i-simple-icons-sentry",{"title":352,"path":353,"stem":354,"icon":355},"Better Stack","\u002Fadapters\u002Fcloud\u002Fbetter-stack","6.adapters\u002F02.cloud\u002F05.better-stack","i-simple-icons-betterstack",{"title":357,"path":358,"stem":359,"icon":360},"Datadog","\u002Fadapters\u002Fcloud\u002Fdatadog","6.adapters\u002F02.cloud\u002F06.datadog","i-simple-icons-datadog",{"title":362,"path":363,"stem":364,"icon":365},"HyperDX","\u002Fadapters\u002Fcloud\u002Fhyperdx","6.adapters\u002F02.cloud\u002F07.hyperdx","i-custom-hyperdx",{"title":367,"path":368,"stem":369,"children":370,"page":34},"Self-hosted","\u002Fadapters\u002Fself-hosted","6.adapters\u002F03.self-hosted",[371,376],{"title":372,"path":373,"stem":374,"icon":375},"File System","\u002Fadapters\u002Fself-hosted\u002Ffs","6.adapters\u002F03.self-hosted\u002F01.fs","i-lucide-hard-drive",{"title":377,"path":378,"stem":379,"icon":380},"NuxtHub","\u002Fadapters\u002Fself-hosted\u002Fnuxthub","6.adapters\u002F03.self-hosted\u002F02.nuxthub","i-simple-icons-nuxt",{"title":382,"path":383,"stem":384,"children":385,"page":34},"Building blocks","\u002Fadapters\u002Fbuilding-blocks","6.adapters\u002F04.building-blocks",[386,391,396,400],{"title":387,"path":388,"stem":389,"icon":390},"Pipeline","\u002Fadapters\u002Fbuilding-blocks\u002Fpipeline","6.adapters\u002F04.building-blocks\u002F01.pipeline","i-lucide-workflow",{"title":392,"path":393,"stem":394,"icon":395},"HTTP","\u002Fadapters\u002Fbuilding-blocks\u002Fhttp","6.adapters\u002F04.building-blocks\u002F02.http","i-lucide-globe",{"title":397,"path":398,"stem":399,"icon":83},"Custom Adapters","\u002Fadapters\u002Fbuilding-blocks\u002Fcustom","6.adapters\u002F04.building-blocks\u002F03.custom",{"title":401,"path":402,"stem":403,"icon":404},"Toolkit","\u002Fadapters\u002Fbuilding-blocks\u002Ftoolkit","6.adapters\u002F04.building-blocks\u002F04.toolkit","i-lucide-blocks",{"title":406,"path":407,"stem":408,"children":409,"page":34},"Enrichers","\u002Fenrichers","7.enrichers",[410,413,417],{"title":41,"path":411,"stem":412,"icon":28},"\u002Fenrichers\u002Foverview","7.enrichers\u002F1.overview",{"title":414,"path":415,"stem":416,"icon":288},"Built-in","\u002Fenrichers\u002Fbuilt-in","7.enrichers\u002F2.built-in",{"title":418,"path":419,"stem":420,"icon":83},"Custom","\u002Fenrichers\u002Fcustom","7.enrichers\u002F3.custom",{"id":422,"title":128,"body":423,"description":2942,"extension":2943,"links":2944,"meta":2952,"navigation":2953,"path":134,"seo":2954,"stem":135,"__hash__":2955},"docs\u002F2.logging\u002F8.audit\u002F01.overview.md",{"type":424,"value":425,"toc":2935},"minimark",[426,444,491,495,521,550,563,567,574,581,584,588,591,899,2796,2799,2835,2845,2848,2852,2870,2873,2877,2931],[427,428,429,430,434,435,439,440,443],"p",{},"evlog's audit layer is ",[431,432,433],"strong",{},"not a parallel system",". Audit events are wide events with a reserved ",[436,437,438],"code",{},"audit"," field. Every existing primitive — drains, enrichers, redact, tail-sampling — applies as is. Enable audit logs by adding ",[431,441,442],{},"1 enricher + 1 drain wrapper + 1 helper",".",[445,446,449,452,477],"prompt",{":actions":447,"description":448,"icon":129},"[\"copy\",\"cursor\",\"windsurf\"]","Add an audit log to my app",[427,450,451],{},"Add a tamper-evident audit log to my app on top of evlog.",[453,454,455,459,462,465,468,471,474],"ul",{},[456,457,458],"li",{},"Identify my framework and follow its evlog integration pattern",[456,460,461],{},"Register auditEnricher() on the evlog:enrich hook (or in initLogger.enrichers)",[456,463,464],{},"Register a separate auditOnly(signed(createFsDrain({ dir: '.audit' }), { strategy: 'hash-chain' })) drain alongside my main drain",[456,466,467],{},"Use { await: true } on the audit drain so audit events are flushed before the response returns",[456,469,470],{},"Call log.audit({ action, actor, target, outcome, reason }) for every security-sensitive action (login, role change, refund, data export, deletion)",[456,472,473],{},"Audit events are force-kept past sampling and signed via hash-chain for tamper-evidence",[456,475,476],{},"Combine with the Better Auth integration so actor.id \u002F actor.email are automatic",[427,478,479,480,486,487],{},"Docs: ",[481,482,483],"a",{"href":483,"rel":484},"https:\u002F\u002Fwww.evlog.dev\u002Flogging\u002Faudit\u002Foverview",[485],"nofollow","\nAdapters: ",[481,488,489],{"href":489,"rel":490},"https:\u002F\u002Fwww.evlog.dev\u002Fadapters\u002Foverview",[485],[492,493,25],"h2",{"id":494},"agent-skills",[427,496,497,498,503,504,507,508,511,512,517,518,443],{},"Install the evlog skill catalog so your assistant can follow ",[431,499,500],{},[436,501,502],{},"build-audit-logs"," end to end: written policy, framework wiring, ",[436,505,506],{},"withAudit"," \u002F ",[436,509,510],{},"log.audit",", denials, redaction, multi-tenant isolation, tamper-evident sinks, and grep-based review passes. If you use the file-system drain for audits or general logs, ",[431,513,514],{},[436,515,516],{},"analyze-logs"," teaches assistants to read NDJSON under ",[436,519,520],{},".evlog\u002Flogs\u002F",[522,523,529],"pre",{"className":524,"code":525,"filename":526,"language":527,"meta":528,"style":528},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","npx skills add https:\u002F\u002Fwww.evlog.dev\n","Terminal","bash","",[436,530,531],{"__ignoreMap":528},[532,533,536,540,544,547],"span",{"class":534,"line":535},"line",1,[532,537,539],{"class":538},"sBMFI","npx",[532,541,543],{"class":542},"sfazB"," skills",[532,545,546],{"class":542}," add",[532,548,549],{"class":542}," https:\u002F\u002Fwww.evlog.dev\n",[427,551,552,553,555,556,559,560,443],{},"See ",[481,554,25],{"href":26}," for the full list. Skill paths in the repo: ",[436,557,558],{},"skills\u002Fbuild-audit-logs",", ",[436,561,562],{},"skills\u002Fanalyze-logs",[492,564,566],{"id":565},"why-audit-logs","Why Audit Logs?",[427,568,569,570,573],{},"Compliance frameworks (SOC2, HIPAA, GDPR, PCI) require knowing ",[431,571,572],{},"who did what, on which resource, when, from where, with which outcome",". evlog covers this without a second logging library.",[575,576,577,580],"tip",{},[431,578,579],{},"An audit event is a fact about an intent, not a measurement of an operation."," A regular wide event answers \"how did this request behave?\" (latency, status, tokens). An audit event answers \"who tried to do what, and was it allowed?\". Same pipeline, different question — that's why the schema is reserved and the event is force-kept past sampling.",[582,583],"audit-force-keep",{},[492,585,587],{"id":586},"quickstart","Quickstart",[427,589,590],{},"You already use evlog. Add audit logs in three changes:",[522,592,597],{"className":593,"code":594,"filename":595,"language":596,"meta":528,"style":528},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import { auditEnricher, auditOnly, signed } from 'evlog'\nimport { createAxiomDrain } from 'evlog\u002Faxiom'\nimport { createFsDrain } from 'evlog\u002Ffs'\n\nexport default defineNitroPlugin((nitro) => {\n  nitro.hooks.hook('evlog:enrich', auditEnricher())\n  nitro.hooks.hook('evlog:drain', createAxiomDrain())\n  nitro.hooks.hook('evlog:drain', auditOnly(\n    signed(createFsDrain({ dir: '.audit' }), { strategy: 'hash-chain' }),\n    { await: true },\n  ))\n})\n","server\u002Fplugins\u002Fevlog.ts","typescript",[436,598,599,639,660,681,688,720,754,782,810,866,884,890],{"__ignoreMap":528},[532,600,601,605,609,613,616,619,621,624,627,630,633,636],{"class":534,"line":535},[532,602,604],{"class":603},"s7zQu","import",[532,606,608],{"class":607},"sMK4o"," {",[532,610,612],{"class":611},"sTEyZ"," auditEnricher",[532,614,615],{"class":607},",",[532,617,618],{"class":611}," auditOnly",[532,620,615],{"class":607},[532,622,623],{"class":611}," signed",[532,625,626],{"class":607}," }",[532,628,629],{"class":603}," from",[532,631,632],{"class":607}," '",[532,634,635],{"class":542},"evlog",[532,637,638],{"class":607},"'\n",[532,640,642,644,646,649,651,653,655,658],{"class":534,"line":641},2,[532,643,604],{"class":603},[532,645,608],{"class":607},[532,647,648],{"class":611}," createAxiomDrain",[532,650,626],{"class":607},[532,652,629],{"class":603},[532,654,632],{"class":607},[532,656,657],{"class":542},"evlog\u002Faxiom",[532,659,638],{"class":607},[532,661,663,665,667,670,672,674,676,679],{"class":534,"line":662},3,[532,664,604],{"class":603},[532,666,608],{"class":607},[532,668,669],{"class":611}," createFsDrain",[532,671,626],{"class":607},[532,673,629],{"class":603},[532,675,632],{"class":607},[532,677,678],{"class":542},"evlog\u002Ffs",[532,680,638],{"class":607},[532,682,684],{"class":534,"line":683},4,[532,685,687],{"emptyLinePlaceholder":686},true,"\n",[532,689,691,694,697,701,704,706,710,713,717],{"class":534,"line":690},5,[532,692,693],{"class":603},"export",[532,695,696],{"class":603}," default",[532,698,700],{"class":699},"s2Zo4"," defineNitroPlugin",[532,702,703],{"class":611},"(",[532,705,703],{"class":607},[532,707,709],{"class":708},"sHdIc","nitro",[532,711,712],{"class":607},")",[532,714,716],{"class":715},"spNyl"," =>",[532,718,719],{"class":607}," {\n",[532,721,723,726,728,731,733,736,739,742,745,747,749,751],{"class":534,"line":722},6,[532,724,725],{"class":611},"  nitro",[532,727,443],{"class":607},[532,729,730],{"class":611},"hooks",[532,732,443],{"class":607},[532,734,735],{"class":699},"hook",[532,737,703],{"class":738},"swJcz",[532,740,741],{"class":607},"'",[532,743,744],{"class":542},"evlog:enrich",[532,746,741],{"class":607},[532,748,615],{"class":607},[532,750,612],{"class":699},[532,752,753],{"class":738},"())\n",[532,755,757,759,761,763,765,767,769,771,774,776,778,780],{"class":534,"line":756},7,[532,758,725],{"class":611},[532,760,443],{"class":607},[532,762,730],{"class":611},[532,764,443],{"class":607},[532,766,735],{"class":699},[532,768,703],{"class":738},[532,770,741],{"class":607},[532,772,773],{"class":542},"evlog:drain",[532,775,741],{"class":607},[532,777,615],{"class":607},[532,779,648],{"class":699},[532,781,753],{"class":738},[532,783,785,787,789,791,793,795,797,799,801,803,805,807],{"class":534,"line":784},8,[532,786,725],{"class":611},[532,788,443],{"class":607},[532,790,730],{"class":611},[532,792,443],{"class":607},[532,794,735],{"class":699},[532,796,703],{"class":738},[532,798,741],{"class":607},[532,800,773],{"class":542},[532,802,741],{"class":607},[532,804,615],{"class":607},[532,806,618],{"class":699},[532,808,809],{"class":738},"(\n",[532,811,813,816,818,821,823,826,829,832,834,837,839,841,843,845,847,850,852,854,857,859,861,863],{"class":534,"line":812},9,[532,814,815],{"class":699},"    signed",[532,817,703],{"class":738},[532,819,820],{"class":699},"createFsDrain",[532,822,703],{"class":738},[532,824,825],{"class":607},"{",[532,827,828],{"class":738}," dir",[532,830,831],{"class":607},":",[532,833,632],{"class":607},[532,835,836],{"class":542},".audit",[532,838,741],{"class":607},[532,840,626],{"class":607},[532,842,712],{"class":738},[532,844,615],{"class":607},[532,846,608],{"class":607},[532,848,849],{"class":738}," strategy",[532,851,831],{"class":607},[532,853,632],{"class":607},[532,855,856],{"class":542},"hash-chain",[532,858,741],{"class":607},[532,860,626],{"class":607},[532,862,712],{"class":738},[532,864,865],{"class":607},",\n",[532,867,869,872,875,877,881],{"class":534,"line":868},10,[532,870,871],{"class":607},"    {",[532,873,874],{"class":738}," await",[532,876,831],{"class":607},[532,878,880],{"class":879},"sfNiH"," true",[532,882,883],{"class":607}," },\n",[532,885,887],{"class":534,"line":886},11,[532,888,889],{"class":738},"  ))\n",[532,891,893,896],{"class":534,"line":892},12,[532,894,895],{"class":607},"}",[532,897,898],{"class":611},")\n",[900,901,902,1196,1499,1872,2183,2341],"code-group",{},[522,903,906],{"className":593,"code":904,"filename":905,"language":596,"meta":528,"style":528},"export default defineEventHandler(async (event) => {\n  const log = useLogger(event)\n  const user = await requireUser(event)\n  const invoice = await refundInvoice(getRouterParam(event, 'id'))\n\n  log.audit({\n    action: 'invoice.refund',\n    actor: { type: 'user', id: user.id, email: user.email },\n    target: { type: 'invoice', id: invoice.id },\n    outcome: 'success',\n    reason: 'Customer requested refund',\n  })\n\n  return { ok: true }\n})\n","Nuxt \u002F Nitro",[436,907,908,934,954,974,1009,1013,1027,1043,1093,1127,1143,1159,1166,1171,1189],{"__ignoreMap":528},[532,909,910,912,914,917,919,922,925,928,930,932],{"class":534,"line":535},[532,911,693],{"class":603},[532,913,696],{"class":603},[532,915,916],{"class":699}," defineEventHandler",[532,918,703],{"class":611},[532,920,921],{"class":715},"async",[532,923,924],{"class":607}," (",[532,926,927],{"class":708},"event",[532,929,712],{"class":607},[532,931,716],{"class":715},[532,933,719],{"class":607},[532,935,936,939,942,945,948,950,952],{"class":534,"line":641},[532,937,938],{"class":715},"  const",[532,940,941],{"class":611}," log",[532,943,944],{"class":607}," =",[532,946,947],{"class":699}," useLogger",[532,949,703],{"class":738},[532,951,927],{"class":611},[532,953,898],{"class":738},[532,955,956,958,961,963,965,968,970,972],{"class":534,"line":662},[532,957,938],{"class":715},[532,959,960],{"class":611}," user",[532,962,944],{"class":607},[532,964,874],{"class":603},[532,966,967],{"class":699}," requireUser",[532,969,703],{"class":738},[532,971,927],{"class":611},[532,973,898],{"class":738},[532,975,976,978,981,983,985,988,990,993,995,997,999,1001,1004,1006],{"class":534,"line":683},[532,977,938],{"class":715},[532,979,980],{"class":611}," invoice",[532,982,944],{"class":607},[532,984,874],{"class":603},[532,986,987],{"class":699}," refundInvoice",[532,989,703],{"class":738},[532,991,992],{"class":699},"getRouterParam",[532,994,703],{"class":738},[532,996,927],{"class":611},[532,998,615],{"class":607},[532,1000,632],{"class":607},[532,1002,1003],{"class":542},"id",[532,1005,741],{"class":607},[532,1007,1008],{"class":738},"))\n",[532,1010,1011],{"class":534,"line":690},[532,1012,687],{"emptyLinePlaceholder":686},[532,1014,1015,1018,1020,1022,1024],{"class":534,"line":722},[532,1016,1017],{"class":611},"  log",[532,1019,443],{"class":607},[532,1021,438],{"class":699},[532,1023,703],{"class":738},[532,1025,1026],{"class":607},"{\n",[532,1028,1029,1032,1034,1036,1039,1041],{"class":534,"line":756},[532,1030,1031],{"class":738},"    action",[532,1033,831],{"class":607},[532,1035,632],{"class":607},[532,1037,1038],{"class":542},"invoice.refund",[532,1040,741],{"class":607},[532,1042,865],{"class":607},[532,1044,1045,1048,1050,1052,1055,1057,1059,1062,1064,1066,1069,1071,1073,1075,1077,1079,1082,1084,1086,1088,1091],{"class":534,"line":784},[532,1046,1047],{"class":738},"    actor",[532,1049,831],{"class":607},[532,1051,608],{"class":607},[532,1053,1054],{"class":738}," type",[532,1056,831],{"class":607},[532,1058,632],{"class":607},[532,1060,1061],{"class":542},"user",[532,1063,741],{"class":607},[532,1065,615],{"class":607},[532,1067,1068],{"class":738}," id",[532,1070,831],{"class":607},[532,1072,960],{"class":611},[532,1074,443],{"class":607},[532,1076,1003],{"class":611},[532,1078,615],{"class":607},[532,1080,1081],{"class":738}," email",[532,1083,831],{"class":607},[532,1085,960],{"class":611},[532,1087,443],{"class":607},[532,1089,1090],{"class":611},"email",[532,1092,883],{"class":607},[532,1094,1095,1098,1100,1102,1104,1106,1108,1111,1113,1115,1117,1119,1121,1123,1125],{"class":534,"line":812},[532,1096,1097],{"class":738},"    target",[532,1099,831],{"class":607},[532,1101,608],{"class":607},[532,1103,1054],{"class":738},[532,1105,831],{"class":607},[532,1107,632],{"class":607},[532,1109,1110],{"class":542},"invoice",[532,1112,741],{"class":607},[532,1114,615],{"class":607},[532,1116,1068],{"class":738},[532,1118,831],{"class":607},[532,1120,980],{"class":611},[532,1122,443],{"class":607},[532,1124,1003],{"class":611},[532,1126,883],{"class":607},[532,1128,1129,1132,1134,1136,1139,1141],{"class":534,"line":868},[532,1130,1131],{"class":738},"    outcome",[532,1133,831],{"class":607},[532,1135,632],{"class":607},[532,1137,1138],{"class":542},"success",[532,1140,741],{"class":607},[532,1142,865],{"class":607},[532,1144,1145,1148,1150,1152,1155,1157],{"class":534,"line":886},[532,1146,1147],{"class":738},"    reason",[532,1149,831],{"class":607},[532,1151,632],{"class":607},[532,1153,1154],{"class":542},"Customer requested refund",[532,1156,741],{"class":607},[532,1158,865],{"class":607},[532,1160,1161,1164],{"class":534,"line":892},[532,1162,1163],{"class":607},"  }",[532,1165,898],{"class":738},[532,1167,1169],{"class":534,"line":1168},13,[532,1170,687],{"emptyLinePlaceholder":686},[532,1172,1174,1177,1179,1182,1184,1186],{"class":534,"line":1173},14,[532,1175,1176],{"class":603},"  return",[532,1178,608],{"class":607},[532,1180,1181],{"class":738}," ok",[532,1183,831],{"class":607},[532,1185,880],{"class":879},[532,1187,1188],{"class":607}," }\n",[532,1190,1192,1194],{"class":534,"line":1191},15,[532,1193,895],{"class":607},[532,1195,898],{"class":611},[522,1197,1199],{"className":593,"code":1198,"filename":216,"language":596,"meta":528,"style":528},"import { withEvlog, useLogger } from '@\u002Flib\u002Fevlog'\n\nexport const POST = withEvlog(async (req, { params }) => {\n  const log = useLogger()\n  const user = await requireUser(req)\n  const invoice = await refundInvoice(params.id)\n\n  log.audit({\n    action: 'invoice.refund',\n    actor: { type: 'user', id: user.id, email: user.email },\n    target: { type: 'invoice', id: invoice.id },\n    outcome: 'success',\n    reason: 'Customer requested refund',\n  })\n\n  return Response.json({ ok: true })\n})\n",[436,1200,1201,1225,1229,1267,1280,1298,1321,1325,1337,1351,1395,1427,1441,1455,1461,1465,1492],{"__ignoreMap":528},[532,1202,1203,1205,1207,1210,1212,1214,1216,1218,1220,1223],{"class":534,"line":535},[532,1204,604],{"class":603},[532,1206,608],{"class":607},[532,1208,1209],{"class":611}," withEvlog",[532,1211,615],{"class":607},[532,1213,947],{"class":611},[532,1215,626],{"class":607},[532,1217,629],{"class":603},[532,1219,632],{"class":607},[532,1221,1222],{"class":542},"@\u002Flib\u002Fevlog",[532,1224,638],{"class":607},[532,1226,1227],{"class":534,"line":641},[532,1228,687],{"emptyLinePlaceholder":686},[532,1230,1231,1233,1236,1239,1242,1244,1246,1248,1250,1253,1255,1257,1260,1263,1265],{"class":534,"line":662},[532,1232,693],{"class":603},[532,1234,1235],{"class":715}," const",[532,1237,1238],{"class":611}," POST ",[532,1240,1241],{"class":607},"=",[532,1243,1209],{"class":699},[532,1245,703],{"class":611},[532,1247,921],{"class":715},[532,1249,924],{"class":607},[532,1251,1252],{"class":708},"req",[532,1254,615],{"class":607},[532,1256,608],{"class":607},[532,1258,1259],{"class":708}," params",[532,1261,1262],{"class":607}," })",[532,1264,716],{"class":715},[532,1266,719],{"class":607},[532,1268,1269,1271,1273,1275,1277],{"class":534,"line":683},[532,1270,938],{"class":715},[532,1272,941],{"class":611},[532,1274,944],{"class":607},[532,1276,947],{"class":699},[532,1278,1279],{"class":738},"()\n",[532,1281,1282,1284,1286,1288,1290,1292,1294,1296],{"class":534,"line":690},[532,1283,938],{"class":715},[532,1285,960],{"class":611},[532,1287,944],{"class":607},[532,1289,874],{"class":603},[532,1291,967],{"class":699},[532,1293,703],{"class":738},[532,1295,1252],{"class":611},[532,1297,898],{"class":738},[532,1299,1300,1302,1304,1306,1308,1310,1312,1315,1317,1319],{"class":534,"line":722},[532,1301,938],{"class":715},[532,1303,980],{"class":611},[532,1305,944],{"class":607},[532,1307,874],{"class":603},[532,1309,987],{"class":699},[532,1311,703],{"class":738},[532,1313,1314],{"class":611},"params",[532,1316,443],{"class":607},[532,1318,1003],{"class":611},[532,1320,898],{"class":738},[532,1322,1323],{"class":534,"line":756},[532,1324,687],{"emptyLinePlaceholder":686},[532,1326,1327,1329,1331,1333,1335],{"class":534,"line":784},[532,1328,1017],{"class":611},[532,1330,443],{"class":607},[532,1332,438],{"class":699},[532,1334,703],{"class":738},[532,1336,1026],{"class":607},[532,1338,1339,1341,1343,1345,1347,1349],{"class":534,"line":812},[532,1340,1031],{"class":738},[532,1342,831],{"class":607},[532,1344,632],{"class":607},[532,1346,1038],{"class":542},[532,1348,741],{"class":607},[532,1350,865],{"class":607},[532,1352,1353,1355,1357,1359,1361,1363,1365,1367,1369,1371,1373,1375,1377,1379,1381,1383,1385,1387,1389,1391,1393],{"class":534,"line":868},[532,1354,1047],{"class":738},[532,1356,831],{"class":607},[532,1358,608],{"class":607},[532,1360,1054],{"class":738},[532,1362,831],{"class":607},[532,1364,632],{"class":607},[532,1366,1061],{"class":542},[532,1368,741],{"class":607},[532,1370,615],{"class":607},[532,1372,1068],{"class":738},[532,1374,831],{"class":607},[532,1376,960],{"class":611},[532,1378,443],{"class":607},[532,1380,1003],{"class":611},[532,1382,615],{"class":607},[532,1384,1081],{"class":738},[532,1386,831],{"class":607},[532,1388,960],{"class":611},[532,1390,443],{"class":607},[532,1392,1090],{"class":611},[532,1394,883],{"class":607},[532,1396,1397,1399,1401,1403,1405,1407,1409,1411,1413,1415,1417,1419,1421,1423,1425],{"class":534,"line":886},[532,1398,1097],{"class":738},[532,1400,831],{"class":607},[532,1402,608],{"class":607},[532,1404,1054],{"class":738},[532,1406,831],{"class":607},[532,1408,632],{"class":607},[532,1410,1110],{"class":542},[532,1412,741],{"class":607},[532,1414,615],{"class":607},[532,1416,1068],{"class":738},[532,1418,831],{"class":607},[532,1420,980],{"class":611},[532,1422,443],{"class":607},[532,1424,1003],{"class":611},[532,1426,883],{"class":607},[532,1428,1429,1431,1433,1435,1437,1439],{"class":534,"line":892},[532,1430,1131],{"class":738},[532,1432,831],{"class":607},[532,1434,632],{"class":607},[532,1436,1138],{"class":542},[532,1438,741],{"class":607},[532,1440,865],{"class":607},[532,1442,1443,1445,1447,1449,1451,1453],{"class":534,"line":1168},[532,1444,1147],{"class":738},[532,1446,831],{"class":607},[532,1448,632],{"class":607},[532,1450,1154],{"class":542},[532,1452,741],{"class":607},[532,1454,865],{"class":607},[532,1456,1457,1459],{"class":534,"line":1173},[532,1458,1163],{"class":607},[532,1460,898],{"class":738},[532,1462,1463],{"class":534,"line":1191},[532,1464,687],{"emptyLinePlaceholder":686},[532,1466,1468,1470,1473,1475,1478,1480,1482,1484,1486,1488,1490],{"class":534,"line":1467},16,[532,1469,1176],{"class":603},[532,1471,1472],{"class":611}," Response",[532,1474,443],{"class":607},[532,1476,1477],{"class":699},"json",[532,1479,703],{"class":738},[532,1481,825],{"class":607},[532,1483,1181],{"class":738},[532,1485,831],{"class":607},[532,1487,880],{"class":879},[532,1489,626],{"class":607},[532,1491,898],{"class":738},[532,1493,1495,1497],{"class":534,"line":1494},17,[532,1496,895],{"class":607},[532,1498,898],{"class":611},[522,1500,1502],{"className":593,"code":1501,"filename":246,"language":596,"meta":528,"style":528},"import type { EvlogVariables } from 'evlog\u002Fhono'\nimport { Hono } from 'hono'\n\nconst app = new Hono\u003CEvlogVariables>()\n\napp.post('\u002Finvoices\u002F:id\u002Frefund', async (c) => {\n  const log = c.get('log')\n  const user = await requireUser(c)\n  const invoice = await refundInvoice(c.req.param('id'))\n\n  log.audit({\n    action: 'invoice.refund',\n    actor: { type: 'user', id: user.id, email: user.email },\n    target: { type: 'invoice', id: invoice.id },\n    outcome: 'success',\n    reason: 'Customer requested refund',\n  })\n\n  return c.json({ ok: true })\n})\n",[436,1503,1504,1526,1546,1550,1576,1580,1615,1642,1660,1695,1699,1711,1725,1769,1801,1815,1829,1835,1840,1865],{"__ignoreMap":528},[532,1505,1506,1508,1510,1512,1515,1517,1519,1521,1524],{"class":534,"line":535},[532,1507,604],{"class":603},[532,1509,1054],{"class":603},[532,1511,608],{"class":607},[532,1513,1514],{"class":611}," EvlogVariables",[532,1516,626],{"class":607},[532,1518,629],{"class":603},[532,1520,632],{"class":607},[532,1522,1523],{"class":542},"evlog\u002Fhono",[532,1525,638],{"class":607},[532,1527,1528,1530,1532,1535,1537,1539,1541,1544],{"class":534,"line":641},[532,1529,604],{"class":603},[532,1531,608],{"class":607},[532,1533,1534],{"class":611}," Hono",[532,1536,626],{"class":607},[532,1538,629],{"class":603},[532,1540,632],{"class":607},[532,1542,1543],{"class":542},"hono",[532,1545,638],{"class":607},[532,1547,1548],{"class":534,"line":662},[532,1549,687],{"emptyLinePlaceholder":686},[532,1551,1552,1555,1558,1560,1563,1565,1568,1571,1574],{"class":534,"line":683},[532,1553,1554],{"class":715},"const",[532,1556,1557],{"class":611}," app ",[532,1559,1241],{"class":607},[532,1561,1562],{"class":607}," new",[532,1564,1534],{"class":699},[532,1566,1567],{"class":607},"\u003C",[532,1569,1570],{"class":538},"EvlogVariables",[532,1572,1573],{"class":607},">",[532,1575,1279],{"class":611},[532,1577,1578],{"class":534,"line":690},[532,1579,687],{"emptyLinePlaceholder":686},[532,1581,1582,1585,1587,1590,1592,1594,1597,1599,1601,1604,1606,1609,1611,1613],{"class":534,"line":722},[532,1583,1584],{"class":611},"app",[532,1586,443],{"class":607},[532,1588,1589],{"class":699},"post",[532,1591,703],{"class":611},[532,1593,741],{"class":607},[532,1595,1596],{"class":542},"\u002Finvoices\u002F:id\u002Frefund",[532,1598,741],{"class":607},[532,1600,615],{"class":607},[532,1602,1603],{"class":715}," async",[532,1605,924],{"class":607},[532,1607,1608],{"class":708},"c",[532,1610,712],{"class":607},[532,1612,716],{"class":715},[532,1614,719],{"class":607},[532,1616,1617,1619,1621,1623,1626,1628,1631,1633,1635,1638,1640],{"class":534,"line":756},[532,1618,938],{"class":715},[532,1620,941],{"class":611},[532,1622,944],{"class":607},[532,1624,1625],{"class":611}," c",[532,1627,443],{"class":607},[532,1629,1630],{"class":699},"get",[532,1632,703],{"class":738},[532,1634,741],{"class":607},[532,1636,1637],{"class":542},"log",[532,1639,741],{"class":607},[532,1641,898],{"class":738},[532,1643,1644,1646,1648,1650,1652,1654,1656,1658],{"class":534,"line":784},[532,1645,938],{"class":715},[532,1647,960],{"class":611},[532,1649,944],{"class":607},[532,1651,874],{"class":603},[532,1653,967],{"class":699},[532,1655,703],{"class":738},[532,1657,1608],{"class":611},[532,1659,898],{"class":738},[532,1661,1662,1664,1666,1668,1670,1672,1674,1676,1678,1680,1682,1685,1687,1689,1691,1693],{"class":534,"line":812},[532,1663,938],{"class":715},[532,1665,980],{"class":611},[532,1667,944],{"class":607},[532,1669,874],{"class":603},[532,1671,987],{"class":699},[532,1673,703],{"class":738},[532,1675,1608],{"class":611},[532,1677,443],{"class":607},[532,1679,1252],{"class":611},[532,1681,443],{"class":607},[532,1683,1684],{"class":699},"param",[532,1686,703],{"class":738},[532,1688,741],{"class":607},[532,1690,1003],{"class":542},[532,1692,741],{"class":607},[532,1694,1008],{"class":738},[532,1696,1697],{"class":534,"line":868},[532,1698,687],{"emptyLinePlaceholder":686},[532,1700,1701,1703,1705,1707,1709],{"class":534,"line":886},[532,1702,1017],{"class":611},[532,1704,443],{"class":607},[532,1706,438],{"class":699},[532,1708,703],{"class":738},[532,1710,1026],{"class":607},[532,1712,1713,1715,1717,1719,1721,1723],{"class":534,"line":892},[532,1714,1031],{"class":738},[532,1716,831],{"class":607},[532,1718,632],{"class":607},[532,1720,1038],{"class":542},[532,1722,741],{"class":607},[532,1724,865],{"class":607},[532,1726,1727,1729,1731,1733,1735,1737,1739,1741,1743,1745,1747,1749,1751,1753,1755,1757,1759,1761,1763,1765,1767],{"class":534,"line":1168},[532,1728,1047],{"class":738},[532,1730,831],{"class":607},[532,1732,608],{"class":607},[532,1734,1054],{"class":738},[532,1736,831],{"class":607},[532,1738,632],{"class":607},[532,1740,1061],{"class":542},[532,1742,741],{"class":607},[532,1744,615],{"class":607},[532,1746,1068],{"class":738},[532,1748,831],{"class":607},[532,1750,960],{"class":611},[532,1752,443],{"class":607},[532,1754,1003],{"class":611},[532,1756,615],{"class":607},[532,1758,1081],{"class":738},[532,1760,831],{"class":607},[532,1762,960],{"class":611},[532,1764,443],{"class":607},[532,1766,1090],{"class":611},[532,1768,883],{"class":607},[532,1770,1771,1773,1775,1777,1779,1781,1783,1785,1787,1789,1791,1793,1795,1797,1799],{"class":534,"line":1173},[532,1772,1097],{"class":738},[532,1774,831],{"class":607},[532,1776,608],{"class":607},[532,1778,1054],{"class":738},[532,1780,831],{"class":607},[532,1782,632],{"class":607},[532,1784,1110],{"class":542},[532,1786,741],{"class":607},[532,1788,615],{"class":607},[532,1790,1068],{"class":738},[532,1792,831],{"class":607},[532,1794,980],{"class":611},[532,1796,443],{"class":607},[532,1798,1003],{"class":611},[532,1800,883],{"class":607},[532,1802,1803,1805,1807,1809,1811,1813],{"class":534,"line":1191},[532,1804,1131],{"class":738},[532,1806,831],{"class":607},[532,1808,632],{"class":607},[532,1810,1138],{"class":542},[532,1812,741],{"class":607},[532,1814,865],{"class":607},[532,1816,1817,1819,1821,1823,1825,1827],{"class":534,"line":1467},[532,1818,1147],{"class":738},[532,1820,831],{"class":607},[532,1822,632],{"class":607},[532,1824,1154],{"class":542},[532,1826,741],{"class":607},[532,1828,865],{"class":607},[532,1830,1831,1833],{"class":534,"line":1494},[532,1832,1163],{"class":607},[532,1834,898],{"class":738},[532,1836,1838],{"class":534,"line":1837},18,[532,1839,687],{"emptyLinePlaceholder":686},[532,1841,1843,1845,1847,1849,1851,1853,1855,1857,1859,1861,1863],{"class":534,"line":1842},19,[532,1844,1176],{"class":603},[532,1846,1625],{"class":611},[532,1848,443],{"class":607},[532,1850,1477],{"class":699},[532,1852,703],{"class":738},[532,1854,825],{"class":607},[532,1856,1181],{"class":738},[532,1858,831],{"class":607},[532,1860,880],{"class":879},[532,1862,626],{"class":607},[532,1864,898],{"class":738},[532,1866,1868,1870],{"class":534,"line":1867},20,[532,1869,895],{"class":607},[532,1871,898],{"class":611},[522,1873,1875],{"className":593,"code":1874,"filename":241,"language":596,"meta":528,"style":528},"import type { Request, Response } from 'express'\n\napp.post('\u002Finvoices\u002F:id\u002Frefund', async (req: Request, res: Response) => {\n  const log = req.log\n  const user = await requireUser(req)\n  const invoice = await refundInvoice(req.params.id)\n\n  log.audit({\n    action: 'invoice.refund',\n    actor: { type: 'user', id: user.id, email: user.email },\n    target: { type: 'invoice', id: invoice.id },\n    outcome: 'success',\n    reason: 'Customer requested refund',\n  })\n\n  res.json({ ok: true })\n})\n",[436,1876,1877,1903,1907,1950,1966,1984,2010,2014,2026,2040,2084,2116,2130,2144,2150,2154,2177],{"__ignoreMap":528},[532,1878,1879,1881,1883,1885,1888,1890,1892,1894,1896,1898,1901],{"class":534,"line":535},[532,1880,604],{"class":603},[532,1882,1054],{"class":603},[532,1884,608],{"class":607},[532,1886,1887],{"class":611}," Request",[532,1889,615],{"class":607},[532,1891,1472],{"class":611},[532,1893,626],{"class":607},[532,1895,629],{"class":603},[532,1897,632],{"class":607},[532,1899,1900],{"class":542},"express",[532,1902,638],{"class":607},[532,1904,1905],{"class":534,"line":641},[532,1906,687],{"emptyLinePlaceholder":686},[532,1908,1909,1911,1913,1915,1917,1919,1921,1923,1925,1927,1929,1931,1933,1935,1937,1940,1942,1944,1946,1948],{"class":534,"line":662},[532,1910,1584],{"class":611},[532,1912,443],{"class":607},[532,1914,1589],{"class":699},[532,1916,703],{"class":611},[532,1918,741],{"class":607},[532,1920,1596],{"class":542},[532,1922,741],{"class":607},[532,1924,615],{"class":607},[532,1926,1603],{"class":715},[532,1928,924],{"class":607},[532,1930,1252],{"class":708},[532,1932,831],{"class":607},[532,1934,1887],{"class":538},[532,1936,615],{"class":607},[532,1938,1939],{"class":708}," res",[532,1941,831],{"class":607},[532,1943,1472],{"class":538},[532,1945,712],{"class":607},[532,1947,716],{"class":715},[532,1949,719],{"class":607},[532,1951,1952,1954,1956,1958,1961,1963],{"class":534,"line":683},[532,1953,938],{"class":715},[532,1955,941],{"class":611},[532,1957,944],{"class":607},[532,1959,1960],{"class":611}," req",[532,1962,443],{"class":607},[532,1964,1965],{"class":611},"log\n",[532,1967,1968,1970,1972,1974,1976,1978,1980,1982],{"class":534,"line":690},[532,1969,938],{"class":715},[532,1971,960],{"class":611},[532,1973,944],{"class":607},[532,1975,874],{"class":603},[532,1977,967],{"class":699},[532,1979,703],{"class":738},[532,1981,1252],{"class":611},[532,1983,898],{"class":738},[532,1985,1986,1988,1990,1992,1994,1996,1998,2000,2002,2004,2006,2008],{"class":534,"line":722},[532,1987,938],{"class":715},[532,1989,980],{"class":611},[532,1991,944],{"class":607},[532,1993,874],{"class":603},[532,1995,987],{"class":699},[532,1997,703],{"class":738},[532,1999,1252],{"class":611},[532,2001,443],{"class":607},[532,2003,1314],{"class":611},[532,2005,443],{"class":607},[532,2007,1003],{"class":611},[532,2009,898],{"class":738},[532,2011,2012],{"class":534,"line":756},[532,2013,687],{"emptyLinePlaceholder":686},[532,2015,2016,2018,2020,2022,2024],{"class":534,"line":784},[532,2017,1017],{"class":611},[532,2019,443],{"class":607},[532,2021,438],{"class":699},[532,2023,703],{"class":738},[532,2025,1026],{"class":607},[532,2027,2028,2030,2032,2034,2036,2038],{"class":534,"line":812},[532,2029,1031],{"class":738},[532,2031,831],{"class":607},[532,2033,632],{"class":607},[532,2035,1038],{"class":542},[532,2037,741],{"class":607},[532,2039,865],{"class":607},[532,2041,2042,2044,2046,2048,2050,2052,2054,2056,2058,2060,2062,2064,2066,2068,2070,2072,2074,2076,2078,2080,2082],{"class":534,"line":868},[532,2043,1047],{"class":738},[532,2045,831],{"class":607},[532,2047,608],{"class":607},[532,2049,1054],{"class":738},[532,2051,831],{"class":607},[532,2053,632],{"class":607},[532,2055,1061],{"class":542},[532,2057,741],{"class":607},[532,2059,615],{"class":607},[532,2061,1068],{"class":738},[532,2063,831],{"class":607},[532,2065,960],{"class":611},[532,2067,443],{"class":607},[532,2069,1003],{"class":611},[532,2071,615],{"class":607},[532,2073,1081],{"class":738},[532,2075,831],{"class":607},[532,2077,960],{"class":611},[532,2079,443],{"class":607},[532,2081,1090],{"class":611},[532,2083,883],{"class":607},[532,2085,2086,2088,2090,2092,2094,2096,2098,2100,2102,2104,2106,2108,2110,2112,2114],{"class":534,"line":886},[532,2087,1097],{"class":738},[532,2089,831],{"class":607},[532,2091,608],{"class":607},[532,2093,1054],{"class":738},[532,2095,831],{"class":607},[532,2097,632],{"class":607},[532,2099,1110],{"class":542},[532,2101,741],{"class":607},[532,2103,615],{"class":607},[532,2105,1068],{"class":738},[532,2107,831],{"class":607},[532,2109,980],{"class":611},[532,2111,443],{"class":607},[532,2113,1003],{"class":611},[532,2115,883],{"class":607},[532,2117,2118,2120,2122,2124,2126,2128],{"class":534,"line":892},[532,2119,1131],{"class":738},[532,2121,831],{"class":607},[532,2123,632],{"class":607},[532,2125,1138],{"class":542},[532,2127,741],{"class":607},[532,2129,865],{"class":607},[532,2131,2132,2134,2136,2138,2140,2142],{"class":534,"line":1168},[532,2133,1147],{"class":738},[532,2135,831],{"class":607},[532,2137,632],{"class":607},[532,2139,1154],{"class":542},[532,2141,741],{"class":607},[532,2143,865],{"class":607},[532,2145,2146,2148],{"class":534,"line":1173},[532,2147,1163],{"class":607},[532,2149,898],{"class":738},[532,2151,2152],{"class":534,"line":1191},[532,2153,687],{"emptyLinePlaceholder":686},[532,2155,2156,2159,2161,2163,2165,2167,2169,2171,2173,2175],{"class":534,"line":1467},[532,2157,2158],{"class":611},"  res",[532,2160,443],{"class":607},[532,2162,1477],{"class":699},[532,2164,703],{"class":738},[532,2166,825],{"class":607},[532,2168,1181],{"class":738},[532,2170,831],{"class":607},[532,2172,880],{"class":879},[532,2174,626],{"class":607},[532,2176,898],{"class":738},[532,2178,2179,2181],{"class":534,"line":1494},[532,2180,895],{"class":607},[532,2182,898],{"class":611},[522,2184,2187],{"className":593,"code":2185,"filename":2186,"language":596,"meta":528,"style":528},"import { audit } from 'evlog'\n\naudit({\n  action: 'invoice.refund',\n  actor: { type: 'system', id: 'billing-worker' },\n  target: { type: 'invoice', id: 'inv_889' },\n  outcome: 'success',\n  reason: 'Auto-refund triggered by chargeback webhook',\n})\n","Standalone job",[436,2188,2189,2208,2212,2220,2235,2270,2304,2319,2335],{"__ignoreMap":528},[532,2190,2191,2193,2195,2198,2200,2202,2204,2206],{"class":534,"line":535},[532,2192,604],{"class":603},[532,2194,608],{"class":607},[532,2196,2197],{"class":611}," audit",[532,2199,626],{"class":607},[532,2201,629],{"class":603},[532,2203,632],{"class":607},[532,2205,635],{"class":542},[532,2207,638],{"class":607},[532,2209,2210],{"class":534,"line":641},[532,2211,687],{"emptyLinePlaceholder":686},[532,2213,2214,2216,2218],{"class":534,"line":662},[532,2215,438],{"class":699},[532,2217,703],{"class":611},[532,2219,1026],{"class":607},[532,2221,2222,2225,2227,2229,2231,2233],{"class":534,"line":683},[532,2223,2224],{"class":738},"  action",[532,2226,831],{"class":607},[532,2228,632],{"class":607},[532,2230,1038],{"class":542},[532,2232,741],{"class":607},[532,2234,865],{"class":607},[532,2236,2237,2240,2242,2244,2246,2248,2250,2253,2255,2257,2259,2261,2263,2266,2268],{"class":534,"line":690},[532,2238,2239],{"class":738},"  actor",[532,2241,831],{"class":607},[532,2243,608],{"class":607},[532,2245,1054],{"class":738},[532,2247,831],{"class":607},[532,2249,632],{"class":607},[532,2251,2252],{"class":542},"system",[532,2254,741],{"class":607},[532,2256,615],{"class":607},[532,2258,1068],{"class":738},[532,2260,831],{"class":607},[532,2262,632],{"class":607},[532,2264,2265],{"class":542},"billing-worker",[532,2267,741],{"class":607},[532,2269,883],{"class":607},[532,2271,2272,2275,2277,2279,2281,2283,2285,2287,2289,2291,2293,2295,2297,2300,2302],{"class":534,"line":722},[532,2273,2274],{"class":738},"  target",[532,2276,831],{"class":607},[532,2278,608],{"class":607},[532,2280,1054],{"class":738},[532,2282,831],{"class":607},[532,2284,632],{"class":607},[532,2286,1110],{"class":542},[532,2288,741],{"class":607},[532,2290,615],{"class":607},[532,2292,1068],{"class":738},[532,2294,831],{"class":607},[532,2296,632],{"class":607},[532,2298,2299],{"class":542},"inv_889",[532,2301,741],{"class":607},[532,2303,883],{"class":607},[532,2305,2306,2309,2311,2313,2315,2317],{"class":534,"line":756},[532,2307,2308],{"class":738},"  outcome",[532,2310,831],{"class":607},[532,2312,632],{"class":607},[532,2314,1138],{"class":542},[532,2316,741],{"class":607},[532,2318,865],{"class":607},[532,2320,2321,2324,2326,2328,2331,2333],{"class":534,"line":784},[532,2322,2323],{"class":738},"  reason",[532,2325,831],{"class":607},[532,2327,632],{"class":607},[532,2329,2330],{"class":542},"Auto-refund triggered by chargeback webhook",[532,2332,741],{"class":607},[532,2334,865],{"class":607},[532,2336,2337,2339],{"class":534,"line":812},[532,2338,895],{"class":607},[532,2340,898],{"class":611},[522,2342,2346],{"className":2343,"code":2344,"filename":2345,"language":1477,"meta":528,"style":528},"language-json shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","{\n  \"level\": \"info\",\n  \"service\": \"billing-api\",\n  \"method\": \"POST\",\n  \"path\": \"\u002Fapi\u002Finvoices\u002Finv_889\u002Frefund\",\n  \"status\": 200,\n  \"duration\": \"84ms\",\n  \"requestId\": \"a566ef91-7765-4f59-b6f0-b9f40ce71599\",\n  \"audit\": {\n    \"action\": \"invoice.refund\",\n    \"actor\": { \"type\": \"user\", \"id\": \"usr_42\", \"email\": \"demo@example.com\" },\n    \"target\": { \"type\": \"invoice\", \"id\": \"inv_889\" },\n    \"outcome\": \"success\",\n    \"reason\": \"Customer requested refund\",\n    \"version\": 1,\n    \"idempotencyKey\": \"ak_8f3c4b2a1e5d6f7c\",\n    \"context\": {\n      \"requestId\": \"a566ef91-7765-4f59-b6f0-b9f40ce71599\",\n      \"ip\": \"203.0.113.7\",\n      \"userAgent\": \"Mozilla\u002F5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit\u002F537.36\"\n    }\n  }\n}\n","Output — wide event",[436,2347,2348,2352,2375,2395,2415,2435,2452,2472,2492,2504,2524,2588,2633,2652,2671,2687,2707,2720,2739,2759,2778,2784,2790],{"__ignoreMap":528},[532,2349,2350],{"class":534,"line":535},[532,2351,1026],{"class":607},[532,2353,2354,2357,2360,2363,2365,2368,2371,2373],{"class":534,"line":641},[532,2355,2356],{"class":607},"  \"",[532,2358,2359],{"class":715},"level",[532,2361,2362],{"class":607},"\"",[532,2364,831],{"class":607},[532,2366,2367],{"class":607}," \"",[532,2369,2370],{"class":542},"info",[532,2372,2362],{"class":607},[532,2374,865],{"class":607},[532,2376,2377,2379,2382,2384,2386,2388,2391,2393],{"class":534,"line":662},[532,2378,2356],{"class":607},[532,2380,2381],{"class":715},"service",[532,2383,2362],{"class":607},[532,2385,831],{"class":607},[532,2387,2367],{"class":607},[532,2389,2390],{"class":542},"billing-api",[532,2392,2362],{"class":607},[532,2394,865],{"class":607},[532,2396,2397,2399,2402,2404,2406,2408,2411,2413],{"class":534,"line":683},[532,2398,2356],{"class":607},[532,2400,2401],{"class":715},"method",[532,2403,2362],{"class":607},[532,2405,831],{"class":607},[532,2407,2367],{"class":607},[532,2409,2410],{"class":542},"POST",[532,2412,2362],{"class":607},[532,2414,865],{"class":607},[532,2416,2417,2419,2422,2424,2426,2428,2431,2433],{"class":534,"line":690},[532,2418,2356],{"class":607},[532,2420,2421],{"class":715},"path",[532,2423,2362],{"class":607},[532,2425,831],{"class":607},[532,2427,2367],{"class":607},[532,2429,2430],{"class":542},"\u002Fapi\u002Finvoices\u002Finv_889\u002Frefund",[532,2432,2362],{"class":607},[532,2434,865],{"class":607},[532,2436,2437,2439,2442,2444,2446,2450],{"class":534,"line":722},[532,2438,2356],{"class":607},[532,2440,2441],{"class":715},"status",[532,2443,2362],{"class":607},[532,2445,831],{"class":607},[532,2447,2449],{"class":2448},"sbssI"," 200",[532,2451,865],{"class":607},[532,2453,2454,2456,2459,2461,2463,2465,2468,2470],{"class":534,"line":756},[532,2455,2356],{"class":607},[532,2457,2458],{"class":715},"duration",[532,2460,2362],{"class":607},[532,2462,831],{"class":607},[532,2464,2367],{"class":607},[532,2466,2467],{"class":542},"84ms",[532,2469,2362],{"class":607},[532,2471,865],{"class":607},[532,2473,2474,2476,2479,2481,2483,2485,2488,2490],{"class":534,"line":784},[532,2475,2356],{"class":607},[532,2477,2478],{"class":715},"requestId",[532,2480,2362],{"class":607},[532,2482,831],{"class":607},[532,2484,2367],{"class":607},[532,2486,2487],{"class":542},"a566ef91-7765-4f59-b6f0-b9f40ce71599",[532,2489,2362],{"class":607},[532,2491,865],{"class":607},[532,2493,2494,2496,2498,2500,2502],{"class":534,"line":812},[532,2495,2356],{"class":607},[532,2497,438],{"class":715},[532,2499,2362],{"class":607},[532,2501,831],{"class":607},[532,2503,719],{"class":607},[532,2505,2506,2509,2512,2514,2516,2518,2520,2522],{"class":534,"line":868},[532,2507,2508],{"class":607},"    \"",[532,2510,2511],{"class":538},"action",[532,2513,2362],{"class":607},[532,2515,831],{"class":607},[532,2517,2367],{"class":607},[532,2519,1038],{"class":542},[532,2521,2362],{"class":607},[532,2523,865],{"class":607},[532,2525,2526,2528,2531,2533,2535,2537,2539,2542,2544,2546,2548,2550,2552,2554,2556,2558,2560,2562,2564,2567,2569,2571,2573,2575,2577,2579,2581,2584,2586],{"class":534,"line":886},[532,2527,2508],{"class":607},[532,2529,2530],{"class":538},"actor",[532,2532,2362],{"class":607},[532,2534,831],{"class":607},[532,2536,608],{"class":607},[532,2538,2367],{"class":607},[532,2540,2541],{"class":2448},"type",[532,2543,2362],{"class":607},[532,2545,831],{"class":607},[532,2547,2367],{"class":607},[532,2549,1061],{"class":542},[532,2551,2362],{"class":607},[532,2553,615],{"class":607},[532,2555,2367],{"class":607},[532,2557,1003],{"class":2448},[532,2559,2362],{"class":607},[532,2561,831],{"class":607},[532,2563,2367],{"class":607},[532,2565,2566],{"class":542},"usr_42",[532,2568,2362],{"class":607},[532,2570,615],{"class":607},[532,2572,2367],{"class":607},[532,2574,1090],{"class":2448},[532,2576,2362],{"class":607},[532,2578,831],{"class":607},[532,2580,2367],{"class":607},[532,2582,2583],{"class":542},"demo@example.com",[532,2585,2362],{"class":607},[532,2587,883],{"class":607},[532,2589,2590,2592,2595,2597,2599,2601,2603,2605,2607,2609,2611,2613,2615,2617,2619,2621,2623,2625,2627,2629,2631],{"class":534,"line":892},[532,2591,2508],{"class":607},[532,2593,2594],{"class":538},"target",[532,2596,2362],{"class":607},[532,2598,831],{"class":607},[532,2600,608],{"class":607},[532,2602,2367],{"class":607},[532,2604,2541],{"class":2448},[532,2606,2362],{"class":607},[532,2608,831],{"class":607},[532,2610,2367],{"class":607},[532,2612,1110],{"class":542},[532,2614,2362],{"class":607},[532,2616,615],{"class":607},[532,2618,2367],{"class":607},[532,2620,1003],{"class":2448},[532,2622,2362],{"class":607},[532,2624,831],{"class":607},[532,2626,2367],{"class":607},[532,2628,2299],{"class":542},[532,2630,2362],{"class":607},[532,2632,883],{"class":607},[532,2634,2635,2637,2640,2642,2644,2646,2648,2650],{"class":534,"line":1168},[532,2636,2508],{"class":607},[532,2638,2639],{"class":538},"outcome",[532,2641,2362],{"class":607},[532,2643,831],{"class":607},[532,2645,2367],{"class":607},[532,2647,1138],{"class":542},[532,2649,2362],{"class":607},[532,2651,865],{"class":607},[532,2653,2654,2656,2659,2661,2663,2665,2667,2669],{"class":534,"line":1173},[532,2655,2508],{"class":607},[532,2657,2658],{"class":538},"reason",[532,2660,2362],{"class":607},[532,2662,831],{"class":607},[532,2664,2367],{"class":607},[532,2666,1154],{"class":542},[532,2668,2362],{"class":607},[532,2670,865],{"class":607},[532,2672,2673,2675,2678,2680,2682,2685],{"class":534,"line":1191},[532,2674,2508],{"class":607},[532,2676,2677],{"class":538},"version",[532,2679,2362],{"class":607},[532,2681,831],{"class":607},[532,2683,2684],{"class":2448}," 1",[532,2686,865],{"class":607},[532,2688,2689,2691,2694,2696,2698,2700,2703,2705],{"class":534,"line":1467},[532,2690,2508],{"class":607},[532,2692,2693],{"class":538},"idempotencyKey",[532,2695,2362],{"class":607},[532,2697,831],{"class":607},[532,2699,2367],{"class":607},[532,2701,2702],{"class":542},"ak_8f3c4b2a1e5d6f7c",[532,2704,2362],{"class":607},[532,2706,865],{"class":607},[532,2708,2709,2711,2714,2716,2718],{"class":534,"line":1494},[532,2710,2508],{"class":607},[532,2712,2713],{"class":538},"context",[532,2715,2362],{"class":607},[532,2717,831],{"class":607},[532,2719,719],{"class":607},[532,2721,2722,2725,2727,2729,2731,2733,2735,2737],{"class":534,"line":1837},[532,2723,2724],{"class":607},"      \"",[532,2726,2478],{"class":2448},[532,2728,2362],{"class":607},[532,2730,831],{"class":607},[532,2732,2367],{"class":607},[532,2734,2487],{"class":542},[532,2736,2362],{"class":607},[532,2738,865],{"class":607},[532,2740,2741,2743,2746,2748,2750,2752,2755,2757],{"class":534,"line":1842},[532,2742,2724],{"class":607},[532,2744,2745],{"class":2448},"ip",[532,2747,2362],{"class":607},[532,2749,831],{"class":607},[532,2751,2367],{"class":607},[532,2753,2754],{"class":542},"203.0.113.7",[532,2756,2362],{"class":607},[532,2758,865],{"class":607},[532,2760,2761,2763,2766,2768,2770,2772,2775],{"class":534,"line":1867},[532,2762,2724],{"class":607},[532,2764,2765],{"class":2448},"userAgent",[532,2767,2362],{"class":607},[532,2769,831],{"class":607},[532,2771,2367],{"class":607},[532,2773,2774],{"class":542},"Mozilla\u002F5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit\u002F537.36",[532,2776,2777],{"class":607},"\"\n",[532,2779,2781],{"class":534,"line":2780},21,[532,2782,2783],{"class":607},"    }\n",[532,2785,2787],{"class":534,"line":2786},22,[532,2788,2789],{"class":607},"  }\n",[532,2791,2793],{"class":534,"line":2792},23,[532,2794,2795],{"class":607},"}\n",[427,2797,2798],{},"That's it. The audit event:",[453,2800,2801,2804,2811,2818],{},[456,2802,2803],{},"Travels through the same wide-event pipeline as the rest of your logs.",[456,2805,2806,2807,2810],{},"Is ",[431,2808,2809],{},"always kept"," past tail sampling.",[456,2812,2813,2814,2817],{},"Goes to your main drain (Axiom) ",[431,2815,2816],{},"and"," to a dedicated, signed, append-only sink (FS journal).",[456,2819,2820,2821,559,2823,559,2826,2828,2829,2831,2832,443],{},"Carries ",[436,2822,2478],{},[436,2824,2825],{},"traceId",[436,2827,2745],{},", and ",[436,2830,2765],{}," automatically via ",[436,2833,2834],{},"auditEnricher",[575,2836,2837,2840,2841,2844],{},[431,2838,2839],{},"Why two drains?"," The main drain (Axiom, Datadog, ...) keeps audits next to the rest of your telemetry so dashboards and queries still work. The signed sink is your insurance: if the main drain has an outage, gets purged, or an admin quietly removes a row, the FS journal still holds the chain. Auditors want both — fast querying ",[2842,2843,2816],"em",{}," a tamper-evident artefact.",[2846,2847],"audit-dual-sink",{},[492,2849,2851],{"id":2850},"composition","Composition",[427,2853,2854,2855,2858,2859,559,2861,2828,2863,507,2866,2869],{},"Each layer is ",[431,2856,2857],{},"opt-in and replaceable",". Every node except ",[436,2860,510],{},[436,2862,2834],{},[436,2864,2865],{},"auditOnly",[436,2867,2868],{},"signed"," is shared with regular wide events.",[2871,2872],"audit-composition-flow",{},[492,2874,2876],{"id":2875},"where-to-next","Where to next",[2878,2879,2880,2888,2911,2921,2924],"card-group",{},[2881,2882,2883,2884,2887],"card",{"icon":140,"title":137,"to":138},"The ",[436,2885,2886],{},"AuditFields"," type, action naming conventions, actor types, and idempotency.",[2881,2889,2891,559,2893,2896,2897,559,2900,559,2902,559,2905,2828,2908,443],{"icon":145,"title":2890,"to":143},"Recording Events",[436,2892,510],{},[436,2894,2895],{},"log.audit.deny",", standalone ",[436,2898,2899],{},"audit()",[436,2901,506],{},[436,2903,2904],{},"defineAuditAction",[436,2906,2907],{},"defineAuditCatalog",[436,2909,2910],{},"auditDiff",[2881,2912,2914,559,2916,2828,2918,2920],{"icon":150,"title":2913,"to":148},"Drains & Integrity",[436,2915,2834],{},[436,2917,2865],{},[436,2919,2868],{}," (HMAC and hash-chain) drain wrappers.",[2881,2922,2923],{"icon":129,"title":152,"to":153},"Integrity, redact presets, GDPR vs append-only, retention, and common pitfalls.",[2881,2925,2926,2927,2930],{"icon":64,"title":156,"to":157},"FS, Axiom, and Postgres recipes — plus testing with ",[436,2928,2929],{},"mockAudit"," and the API reference.",[2932,2933,2934],"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 .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 .spNyl, html code.shiki .spNyl{--shiki-light:#9C3EDA;--shiki-default:#C792EA;--shiki-dark:#C792EA}html pre.shiki code .swJcz, html code.shiki .swJcz{--shiki-light:#E53935;--shiki-default:#F07178;--shiki-dark:#F07178}html pre.shiki code .sfNiH, html code.shiki .sfNiH{--shiki-light:#FF5370;--shiki-default:#FF9CAC;--shiki-dark:#FF9CAC}html pre.shiki code .sbssI, html code.shiki .sbssI{--shiki-light:#F76D47;--shiki-default:#F78C6C;--shiki-dark:#F78C6C}",{"title":528,"searchDepth":641,"depth":641,"links":2936},[2937,2938,2939,2940,2941],{"id":494,"depth":641,"text":25},{"id":565,"depth":641,"text":566},{"id":586,"depth":641,"text":587},{"id":2850,"depth":641,"text":2851},{"id":2875,"depth":641,"text":2876},"First-class audit logs as a thin layer on top of evlog's wide events. Add tamper-evident audit trails to any app with one enricher, one drain wrapper, and one helper.","md",[2945,2948,2949,2950,2951],{"label":137,"icon":140,"to":138,"color":2946,"variant":2947},"neutral","subtle",{"label":142,"icon":145,"to":143,"color":2946,"variant":2947},{"label":2913,"icon":150,"to":148,"color":2946,"variant":2947},{"label":152,"icon":129,"to":153,"color":2946,"variant":2947},{"label":156,"icon":64,"to":157,"color":2946,"variant":2947},{},{"title":41,"icon":44},{"title":128,"description":2942},"rjjaG9qo4ueRnJlxpAv0zJJ_p3zy-gDDXMH90mb22W8",[2957,2959],{"title":123,"path":124,"stem":125,"description":2958,"icon":126,"children":-1},"Watch session resolution time, enable session caching, wire the standalone Nitro hook, and combine with the AI SDK integration.",{"title":137,"path":138,"stem":139,"description":2960,"icon":140,"children":-1},"The AuditFields type, action naming conventions, actor types, idempotency, and how the schema sits inside a regular wide event.",1778333316670]