[{"data":1,"prerenderedAt":1743},["ShallowReactive",2],{"navigation_docs":3,"-integrate-adapters-self-hosted-nuxthub":434,"-integrate-adapters-self-hosted-nuxthub-surround":1738},[4,30,80,240,348,403],{"title":5,"path":6,"stem":7,"children":8,"page":29},"Start","\u002Fstart","1.start",[9,14,19,24],{"title":10,"path":11,"stem":12,"icon":13},"Introduction","\u002Fstart\u002Fintroduction","1.start\u002F1.introduction","i-lucide-info",{"title":15,"path":16,"stem":17,"icon":18},"Why start with evlog","\u002Fstart\u002Fwhy-evlog","1.start\u002F2.why-evlog","i-lucide-rocket",{"title":20,"path":21,"stem":22,"icon":23},"Installation","\u002Fstart\u002Finstallation","1.start\u002F3.installation","i-lucide-download",{"title":25,"path":26,"stem":27,"icon":28},"Quick Start","\u002Fstart\u002Fquick-start","1.start\u002F4.quick-start","i-lucide-zap",false,{"title":31,"path":32,"stem":33,"children":34,"page":29},"Learn","\u002Flearn","2.learn",[35,40,45,50,55,60,65,70,75],{"title":36,"path":37,"stem":38,"icon":39},"Overview","\u002Flearn\u002Foverview","2.learn\u002F0.overview","i-lucide-list",{"title":41,"path":42,"stem":43,"icon":44},"Simple Logging","\u002Flearn\u002Fsimple-logging","2.learn\u002F1.simple-logging","i-lucide-terminal",{"title":46,"path":47,"stem":48,"icon":49},"Wide Events","\u002Flearn\u002Fwide-events","2.learn\u002F2.wide-events","i-lucide-layers",{"title":51,"path":52,"stem":53,"icon":54},"Structured Errors","\u002Flearn\u002Fstructured-errors","2.learn\u002F3.structured-errors","i-lucide-shield-alert",{"title":56,"path":57,"stem":58,"icon":59},"Lifecycle","\u002Flearn\u002Flifecycle","2.learn\u002F4.lifecycle","i-lucide-arrow-right-left",{"title":61,"path":62,"stem":63,"icon":64},"Sampling","\u002Flearn\u002Fsampling","2.learn\u002F5.sampling","i-lucide-filter",{"title":66,"path":67,"stem":68,"icon":69},"Auto-Redaction","\u002Flearn\u002Fredaction","2.learn\u002F6.redaction","i-lucide-eye-off",{"title":71,"path":72,"stem":73,"icon":74},"Typed Fields","\u002Flearn\u002Ftyped-fields","2.learn\u002F7.typed-fields","i-simple-icons-typescript",{"title":76,"path":77,"stem":78,"icon":79},"Catalogs","\u002Flearn\u002Fcatalogs","2.learn\u002F8.catalogs","i-lucide-book-open",{"title":81,"path":82,"stem":83,"children":84,"page":29},"Integrate","\u002Fintegrate","3.integrate",[85,89,152],{"title":36,"path":86,"stem":87,"icon":88},"\u002Fintegrate\u002Foverview","3.integrate\u002F0.overview","i-lucide-plug",{"title":90,"path":91,"stem":92,"children":93,"page":29},"Adapters","\u002Fintegrate\u002Fadapters","3.integrate\u002Fadapters",[94,97,137],{"title":36,"path":95,"stem":96,"icon":39},"\u002Fintegrate\u002Fadapters\u002Foverview","3.integrate\u002Fadapters\u002F01.overview",{"title":98,"path":99,"stem":100,"children":101,"page":29},"Cloud","\u002Fintegrate\u002Fadapters\u002Fcloud","3.integrate\u002Fadapters\u002Fcloud",[102,107,112,117,122,127,132],{"title":103,"path":104,"stem":105,"icon":106},"Axiom","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Faxiom","3.integrate\u002Fadapters\u002Fcloud\u002F01.axiom","i-custom-axiom",{"title":108,"path":109,"stem":110,"icon":111},"OTLP","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fotlp","3.integrate\u002Fadapters\u002Fcloud\u002F02.otlp","i-simple-icons-opentelemetry",{"title":113,"path":114,"stem":115,"icon":116},"PostHog","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fposthog","3.integrate\u002Fadapters\u002Fcloud\u002F03.posthog","i-simple-icons-posthog",{"title":118,"path":119,"stem":120,"icon":121},"Sentry","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fsentry","3.integrate\u002Fadapters\u002Fcloud\u002F04.sentry","i-simple-icons-sentry",{"title":123,"path":124,"stem":125,"icon":126},"Better Stack","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fbetter-stack","3.integrate\u002Fadapters\u002Fcloud\u002F05.better-stack","i-simple-icons-betterstack",{"title":128,"path":129,"stem":130,"icon":131},"Datadog","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fdatadog","3.integrate\u002Fadapters\u002Fcloud\u002F06.datadog","i-simple-icons-datadog",{"title":133,"path":134,"stem":135,"icon":136},"HyperDX","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fhyperdx","3.integrate\u002Fadapters\u002Fcloud\u002F07.hyperdx","i-custom-hyperdx",{"title":138,"path":139,"stem":140,"children":141,"page":29},"Self-Hosted","\u002Fintegrate\u002Fadapters\u002Fself-hosted","3.integrate\u002Fadapters\u002Fself-hosted",[142,147],{"title":143,"path":144,"stem":145,"icon":146},"File System","\u002Fintegrate\u002Fadapters\u002Fself-hosted\u002Ffs","3.integrate\u002Fadapters\u002Fself-hosted\u002F01.fs","i-lucide-hard-drive",{"title":148,"path":149,"stem":150,"icon":151},"NuxtHub","\u002Fintegrate\u002Fadapters\u002Fself-hosted\u002Fnuxthub","3.integrate\u002Fadapters\u002Fself-hosted\u002F02.nuxthub","i-simple-icons-nuxt",{"title":153,"path":154,"stem":155,"children":156,"page":29},"Frameworks","\u002Fintegrate\u002Fframeworks","3.integrate\u002Fframeworks",[157,161,166,171,176,181,186,191,196,201,206,211,216,221,225,230,235],{"title":36,"path":158,"stem":159,"icon":160},"\u002Fintegrate\u002Fframeworks\u002Foverview","3.integrate\u002Fframeworks\u002F00.overview","i-lucide-layout-grid",{"title":162,"path":163,"stem":164,"icon":165},"Nuxt","\u002Fintegrate\u002Fframeworks\u002Fnuxt","3.integrate\u002Fframeworks\u002F01.nuxt","i-simple-icons-nuxtdotjs",{"title":167,"path":168,"stem":169,"icon":170},"Next.js","\u002Fintegrate\u002Fframeworks\u002Fnextjs","3.integrate\u002Fframeworks\u002F02.nextjs","i-simple-icons-nextdotjs",{"title":172,"path":173,"stem":174,"icon":175},"SvelteKit","\u002Fintegrate\u002Fframeworks\u002Fsveltekit","3.integrate\u002Fframeworks\u002F03.sveltekit","i-simple-icons-svelte",{"title":177,"path":178,"stem":179,"icon":180},"Nitro","\u002Fintegrate\u002Fframeworks\u002Fnitro","3.integrate\u002Fframeworks\u002F04.nitro","i-custom-nitro",{"title":182,"path":183,"stem":184,"icon":185},"TanStack Start","\u002Fintegrate\u002Fframeworks\u002Ftanstack-start","3.integrate\u002Fframeworks\u002F05.tanstack-start","i-custom-tanstack",{"title":187,"path":188,"stem":189,"icon":190},"NestJS","\u002Fintegrate\u002Fframeworks\u002Fnestjs","3.integrate\u002Fframeworks\u002F06.nestjs","i-simple-icons-nestjs",{"title":192,"path":193,"stem":194,"icon":195},"Express","\u002Fintegrate\u002Fframeworks\u002Fexpress","3.integrate\u002Fframeworks\u002F07.express","i-simple-icons-express",{"title":197,"path":198,"stem":199,"icon":200},"Hono","\u002Fintegrate\u002Fframeworks\u002Fhono","3.integrate\u002Fframeworks\u002F08.hono","i-simple-icons-hono",{"title":202,"path":203,"stem":204,"icon":205},"Fastify","\u002Fintegrate\u002Fframeworks\u002Ffastify","3.integrate\u002Fframeworks\u002F09.fastify","i-simple-icons-fastify",{"title":207,"path":208,"stem":209,"icon":210},"Elysia","\u002Fintegrate\u002Fframeworks\u002Felysia","3.integrate\u002Fframeworks\u002F10.elysia","i-custom-elysia",{"title":212,"path":213,"stem":214,"icon":215},"React Router","\u002Fintegrate\u002Fframeworks\u002Freact-router","3.integrate\u002Fframeworks\u002F11.react-router","i-custom-reactrouter",{"title":217,"path":218,"stem":219,"icon":220},"Cloudflare Workers","\u002Fintegrate\u002Fframeworks\u002Fcloudflare-workers","3.integrate\u002Fframeworks\u002F12.cloudflare-workers","i-simple-icons-cloudflare",{"title":222,"path":223,"stem":224,"icon":74},"Standalone","\u002Fintegrate\u002Fframeworks\u002Fstandalone","3.integrate\u002Fframeworks\u002F13.standalone",{"title":226,"path":227,"stem":228,"icon":229},"Astro","\u002Fintegrate\u002Fframeworks\u002Fastro","3.integrate\u002Fframeworks\u002F14.astro","i-simple-icons-astro",{"title":231,"path":232,"stem":233,"icon":234},"oRPC","\u002Fintegrate\u002Fframeworks\u002Forpc","3.integrate\u002Fframeworks\u002F15.orpc","i-lucide-network",{"title":236,"path":237,"stem":238,"icon":239},"AWS Lambda","\u002Fintegrate\u002Fframeworks\u002Faws-lambda","3.integrate\u002Fframeworks\u002F16.aws-lambda","i-custom-lambda",{"title":241,"path":242,"stem":243,"children":244,"page":29},"Use Cases","\u002Fuse-cases","4.use-cases",[245,249,254,283,311,343],{"title":36,"path":246,"stem":247,"icon":248},"\u002Fuse-cases\u002Foverview","4.use-cases\u002F0.overview","i-lucide-list-checks",{"title":250,"path":251,"stem":252,"icon":253},"Client Logging","\u002Fuse-cases\u002Fclient-logging","4.use-cases\u002F1.client-logging","i-lucide-monitor",{"title":255,"icon":256,"path":257,"stem":258,"children":259,"page":29},"AI SDK","i-simple-icons-vercel","\u002Fuse-cases\u002Fai-sdk","4.use-cases\u002F2.ai-sdk",[260,263,268,273,278],{"title":36,"path":261,"stem":262,"icon":39},"\u002Fuse-cases\u002Fai-sdk\u002Foverview","4.use-cases\u002F2.ai-sdk\u002F01.overview",{"title":264,"path":265,"stem":266,"icon":267},"Usage","\u002Fuse-cases\u002Fai-sdk\u002Fusage","4.use-cases\u002F2.ai-sdk\u002F02.usage","i-lucide-code",{"title":269,"path":270,"stem":271,"icon":272},"Options","\u002Fuse-cases\u002Fai-sdk\u002Foptions","4.use-cases\u002F2.ai-sdk\u002F03.options","i-lucide-sliders",{"title":274,"path":275,"stem":276,"icon":277},"Metadata","\u002Fuse-cases\u002Fai-sdk\u002Fmetadata","4.use-cases\u002F2.ai-sdk\u002F04.metadata","i-lucide-database",{"title":279,"path":280,"stem":281,"icon":282},"Telemetry","\u002Fuse-cases\u002Fai-sdk\u002Ftelemetry","4.use-cases\u002F2.ai-sdk\u002F05.telemetry","i-lucide-activity",{"title":284,"icon":285,"path":286,"stem":287,"children":288,"page":29},"Better Auth","i-simple-icons-betterauth","\u002Fuse-cases\u002Fbetter-auth","4.use-cases\u002F3.better-auth",[289,292,297,302,306],{"title":36,"path":290,"stem":291,"icon":39},"\u002Fuse-cases\u002Fbetter-auth\u002Foverview","4.use-cases\u002F3.better-auth\u002F01.overview",{"title":293,"path":294,"stem":295,"icon":296},"Identify User","\u002Fuse-cases\u002Fbetter-auth\u002Fidentify-user","4.use-cases\u002F3.better-auth\u002F02.identify-user","i-lucide-user-check",{"title":298,"path":299,"stem":300,"icon":301},"Middleware","\u002Fuse-cases\u002Fbetter-auth\u002Fmiddleware","4.use-cases\u002F3.better-auth\u002F03.middleware","i-lucide-shield",{"title":303,"path":304,"stem":305,"icon":253},"Client Sync","\u002Fuse-cases\u002Fbetter-auth\u002Fclient-sync","4.use-cases\u002F3.better-auth\u002F04.client-sync",{"title":307,"path":308,"stem":309,"icon":310},"Performance","\u002Fuse-cases\u002Fbetter-auth\u002Fperformance","4.use-cases\u002F3.better-auth\u002F05.performance","i-lucide-gauge",{"title":312,"icon":313,"path":314,"stem":315,"children":316,"page":29},"Audit Logs","i-lucide-shield-check","\u002Fuse-cases\u002Faudit","4.use-cases\u002F4.audit",[317,320,325,330,335,339],{"title":36,"path":318,"stem":319,"icon":39},"\u002Fuse-cases\u002Faudit\u002Foverview","4.use-cases\u002F4.audit\u002F01.overview",{"title":321,"path":322,"stem":323,"icon":324},"Schema","\u002Fuse-cases\u002Faudit\u002Fschema","4.use-cases\u002F4.audit\u002F02.schema","i-lucide-file-text",{"title":326,"path":327,"stem":328,"icon":329},"Recording","\u002Fuse-cases\u002Faudit\u002Frecording","4.use-cases\u002F4.audit\u002F03.recording","i-lucide-pen-line",{"title":331,"path":332,"stem":333,"icon":334},"Drains","\u002Fuse-cases\u002Faudit\u002Fpipeline","4.use-cases\u002F4.audit\u002F04.pipeline","i-lucide-link",{"title":336,"path":337,"stem":338,"icon":313},"Compliance","\u002Fuse-cases\u002Faudit\u002Fcompliance","4.use-cases\u002F4.audit\u002F05.compliance",{"title":340,"path":341,"stem":342,"icon":79},"Recipes","\u002Fuse-cases\u002Faudit\u002Frecipes","4.use-cases\u002F4.audit\u002F06.recipes",{"title":344,"path":345,"stem":346,"icon":347},"Enrichers","\u002Fuse-cases\u002Fenrichers","4.use-cases\u002F5.enrichers","i-lucide-sparkles",{"title":349,"path":350,"stem":351,"children":352,"page":29},"Extend","\u002Fextend","5.extend",[353,357,362,367,372,376,380,384,388,393,398],{"title":36,"path":354,"stem":355,"icon":356},"\u002Fextend\u002Foverview","5.extend\u002F0.overview","i-lucide-blocks",{"title":358,"path":359,"stem":360,"icon":361},"Stream","\u002Fextend\u002Fstream","5.extend\u002F1.stream","i-lucide-radio-tower",{"title":363,"path":364,"stem":365,"icon":366},"Custom framework","\u002Fextend\u002Fcustom-framework","5.extend\u002F10.custom-framework","i-lucide-puzzle",{"title":368,"path":369,"stem":370,"icon":371},"FS reader","\u002Fextend\u002Ffs-reader","5.extend\u002F2.fs-reader","i-lucide-folder-search",{"title":340,"path":373,"stem":374,"icon":375},"\u002Fextend\u002Fconsumer-recipes","5.extend\u002F3.consumer-recipes","i-lucide-chef-hat",{"title":377,"path":378,"stem":379,"icon":356},"Plugins","\u002Fextend\u002Fplugins","5.extend\u002F4.plugins",{"title":381,"path":382,"stem":383,"icon":347},"Custom enrichers","\u002Fextend\u002Fcustom-enrichers","5.extend\u002F5.custom-enrichers",{"title":385,"path":386,"stem":387,"icon":64},"Tail sampling","\u002Fextend\u002Ftail-sampling","5.extend\u002F6.tail-sampling",{"title":389,"path":390,"stem":391,"icon":392},"Identity headers","\u002Fextend\u002Fidentity-headers","5.extend\u002F7.identity-headers","i-lucide-fingerprint",{"title":394,"path":395,"stem":396,"icon":397},"Custom drains","\u002Fextend\u002Fcustom-drains","5.extend\u002F8.custom-drains","i-lucide-share-2",{"title":399,"path":400,"stem":401,"icon":402},"Drain pipeline","\u002Fextend\u002Fdrain-pipeline","5.extend\u002F9.drain-pipeline","i-lucide-workflow",{"title":404,"path":405,"stem":406,"children":407,"page":29},"Reference","\u002Freference","6.reference",[408,413,416,421,425,430],{"title":409,"path":410,"stem":411,"icon":412},"Configuration","\u002Freference\u002Fconfiguration","6.reference\u002F1.configuration","i-lucide-settings",{"title":307,"path":414,"stem":415,"icon":310},"\u002Freference\u002Fperformance","6.reference\u002F2.performance",{"title":417,"path":418,"stem":419,"icon":420},"Vite Plugin","\u002Freference\u002Fvite-plugin","6.reference\u002F3.vite-plugin","i-custom-vite",{"title":422,"path":423,"stem":424,"icon":313},"Best Practices","\u002Freference\u002Fbest-practices","6.reference\u002F4.best-practices",{"title":426,"path":427,"stem":428,"icon":429},"vs Other Loggers","\u002Freference\u002Fvs-other-loggers","6.reference\u002F5.vs-other-loggers","i-lucide-scale",{"title":431,"path":432,"stem":433,"icon":347},"Agent Skills","\u002Freference\u002Fagent-skills","6.reference\u002F6.agent-skills",{"id":435,"title":436,"body":437,"description":1724,"extension":1725,"links":1726,"meta":1734,"navigation":1735,"path":149,"seo":1736,"stem":150,"__hash__":1737},"docs\u002F3.integrate\u002Fadapters\u002Fself-hosted\u002F02.nuxthub.md","NuxtHub Storage",{"type":438,"value":439,"toc":1706},"minimark",[440,448,495,500,503,530,535,539,619,626,649,653,659,773,786,789,819,834,838,846,856,861,871,1090,1107,1111,1114,1132,1139,1143,1151,1254,1258,1263,1266,1271,1353,1356,1419,1423,1430,1500,1509,1513,1516,1529,1536,1565,1568,1572,1583,1668,1674,1678,1685,1689,1702],[441,442,443,447],"p",{},[444,445,446],"code",{},"@evlog\u002Fnuxthub"," stores your evlog wide events directly in your NuxtHub database. No external logging service needed. Your logs live next to your data, with automatic cleanup based on a retention policy.",[449,450,453,456,481],"prompt",{":actions":451,"description":452,"icon":151},"[\"copy\",\"cursor\",\"windsurf\"]","Store evlog wide events in NuxtHub",[441,454,455],{},"Store evlog wide events in my NuxtHub database (self-hosted log retention).",[457,458,459,463,466,469,472,475,478],"ul",{},[460,461,462],"li",{},"Install both modules: pnpm add @nuxthub\u002Fcore @evlog\u002Fnuxthub",[460,464,465],{},"Add @nuxthub\u002Fcore and @evlog\u002Fnuxthub to nuxt.config.ts modules (in that order)",[460,467,468],{},"Enable hub.database = true in nuxt.config.ts",[460,470,471],{},"Configure evlog.nuxthub: { retentionDays, batchSize, ... } for retention and batching",[460,473,474],{},"Run database migrations so the wide-events table is created",[460,476,477],{},"Confirm wide events are written to my NuxtHub database after triggering a request",[460,479,480],{},"For production at scale, combine with an external drain (Axiom \u002F OTLP) for long-term storage",[441,482,483,484,490,491],{},"Docs: ",[485,486,487],"a",{"href":487,"rel":488},"https:\u002F\u002Fwww.evlog.dev\u002Fintegrate\u002Fadapters\u002Fself-hosted\u002Fnuxthub",[489],"nofollow","\nNuxtHub: ",[485,492,493],{"href":493,"rel":494},"https:\u002F\u002Fhub.nuxt.com",[489],[496,497,499],"h2",{"id":498},"why-self-hosted-logs","Why Self-Hosted Logs?",[441,501,502],{},"External logging services (Axiom, Datadog, etc.) are great for production at scale. But sometimes you want:",[457,504,505,512,518,524],{},[460,506,507,511],{},[508,509,510],"strong",{},"Zero external dependencies"," - logs stored in the same database as your app",[460,513,514,517],{},[508,515,516],{},"Full data ownership"," - no third-party access to your log data",[460,519,520,523],{},[508,521,522],{},"Free tier friendly"," - no per-event pricing, just your existing database",[460,525,526,529],{},[508,527,528],{},"Development & staging"," - full log visibility without paying for a service",[441,531,532,534],{},[444,533,446],{}," works as a drop-in drain. Your existing evlog setup stays the same, you just get a database-backed storage layer on top.",[496,536,538],{"id":537},"install","Install",[540,541,542,570,586,602],"code-group",{},[543,544,550],"pre",{"className":545,"code":546,"filename":547,"language":548,"meta":549,"style":549},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","pnpm add @nuxthub\u002Fcore @evlog\u002Fnuxthub\n","pnpm","bash","",[444,551,552],{"__ignoreMap":549},[553,554,557,560,564,567],"span",{"class":555,"line":556},"line",1,[553,558,547],{"class":559},"sBMFI",[553,561,563],{"class":562},"sfazB"," add",[553,565,566],{"class":562}," @nuxthub\u002Fcore",[553,568,569],{"class":562}," @evlog\u002Fnuxthub\n",[543,571,574],{"className":545,"code":572,"filename":573,"language":548,"meta":549,"style":549},"bun add @nuxthub\u002Fcore @evlog\u002Fnuxthub\n","bun",[444,575,576],{"__ignoreMap":549},[553,577,578,580,582,584],{"class":555,"line":556},[553,579,573],{"class":559},[553,581,563],{"class":562},[553,583,566],{"class":562},[553,585,569],{"class":562},[543,587,590],{"className":545,"code":588,"filename":589,"language":548,"meta":549,"style":549},"yarn add @nuxthub\u002Fcore @evlog\u002Fnuxthub\n","yarn",[444,591,592],{"__ignoreMap":549},[553,593,594,596,598,600],{"class":555,"line":556},[553,595,589],{"class":559},[553,597,563],{"class":562},[553,599,566],{"class":562},[553,601,569],{"class":562},[543,603,606],{"className":545,"code":604,"filename":605,"language":548,"meta":549,"style":549},"npm install @nuxthub\u002Fcore @evlog\u002Fnuxthub\n","npm",[444,607,608],{"__ignoreMap":549},[553,609,610,612,615,617],{"class":555,"line":556},[553,611,605],{"class":559},[553,613,614],{"class":562}," install",[553,616,566],{"class":562},[553,618,569],{"class":562},[441,620,621,622,625],{},"Or with ",[444,623,624],{},"nuxi",":",[543,627,630],{"className":545,"code":628,"filename":629,"language":548,"meta":549,"style":549},"npx nuxi module add @nuxthub\u002Fcore @evlog\u002Fnuxthub\n","Terminal",[444,631,632],{"__ignoreMap":549},[553,633,634,637,640,643,645,647],{"class":555,"line":556},[553,635,636],{"class":559},"npx",[553,638,639],{"class":562}," nuxi",[553,641,642],{"class":562}," module",[553,644,563],{"class":562},[553,646,566],{"class":562},[553,648,569],{"class":562},[496,650,652],{"id":651},"setup","Setup",[441,654,655,656,625],{},"Add the module to your ",[444,657,658],{},"nuxt.config.ts",[543,660,664],{"className":661,"code":662,"filename":658,"language":663,"meta":549,"style":549},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","export default defineNuxtConfig({\n  modules: ['@nuxthub\u002Fcore', '@evlog\u002Fnuxthub'],\n\n  evlog: {\n    retention: '7d',\n  },\n})\n","typescript",[444,665,666,687,723,730,741,758,764],{"__ignoreMap":549},[553,667,668,672,675,679,683],{"class":555,"line":556},[553,669,671],{"class":670},"s7zQu","export",[553,673,674],{"class":670}," default",[553,676,678],{"class":677},"s2Zo4"," defineNuxtConfig",[553,680,682],{"class":681},"sTEyZ","(",[553,684,686],{"class":685},"sMK4o","{\n",[553,688,690,694,696,699,702,705,707,710,713,715,717,720],{"class":555,"line":689},2,[553,691,693],{"class":692},"swJcz","  modules",[553,695,625],{"class":685},[553,697,698],{"class":681}," [",[553,700,701],{"class":685},"'",[553,703,704],{"class":562},"@nuxthub\u002Fcore",[553,706,701],{"class":685},[553,708,709],{"class":685},",",[553,711,712],{"class":685}," '",[553,714,446],{"class":562},[553,716,701],{"class":685},[553,718,719],{"class":681},"]",[553,721,722],{"class":685},",\n",[553,724,726],{"class":555,"line":725},3,[553,727,729],{"emptyLinePlaceholder":728},true,"\n",[553,731,733,736,738],{"class":555,"line":732},4,[553,734,735],{"class":692},"  evlog",[553,737,625],{"class":685},[553,739,740],{"class":685}," {\n",[553,742,744,747,749,751,754,756],{"class":555,"line":743},5,[553,745,746],{"class":692},"    retention",[553,748,625],{"class":685},[553,750,712],{"class":685},[553,752,753],{"class":562},"7d",[553,755,701],{"class":685},[553,757,722],{"class":685},[553,759,761],{"class":555,"line":760},6,[553,762,763],{"class":685},"  },\n",[553,765,767,770],{"class":555,"line":766},7,[553,768,769],{"class":685},"}",[553,771,772],{"class":681},")\n",[441,774,775,776,778,779,781,782,785],{},"Even if ",[444,777,446],{}," can auto-register missing modules, we recommend explicitly installing ",[444,780,704],{}," and registering it in ",[444,783,784],{},"modules"," for a clearer and more predictable setup.",[441,787,788],{},"That's it. The module automatically:",[790,791,792,802,809,816],"ol",{},[460,793,794,795,798,799,801],{},"Installs ",[444,796,797],{},"evlog\u002Fnuxt"," and ",[444,800,704],{}," if not already registered",[460,803,804,805,808],{},"Registers the ",[444,806,807],{},"evlog_events"," database schema with NuxtHub",[460,810,811,812,815],{},"Hooks into ",[444,813,814],{},"evlog:drain"," to store every event in the database",[460,817,818],{},"Schedules a cleanup task based on your retention policy",[820,821,823,826,827,830,831,833],"callout",{"color":822,"icon":13},"info",[508,824,825],{},"Prerequisites:"," Your project must use ",[485,828,148],{"href":493,"rel":829},[489]," with a database configured. ",[444,832,446],{}," uses Drizzle ORM to interact with the database.",[496,835,837],{"id":836},"how-it-works","How It Works",[543,839,844],{"className":840,"code":842,"language":843},[841],"language-text","Request → evlog wide event → evlog:drain hook → INSERT into evlog_events table\n                                                          ↓\n                          Cron task (automatic) → DELETE events older than retention\n","text",[444,845,842],{"__ignoreMap":549},[441,847,848,849,851,852,855],{},"Every wide event emitted by evlog is stored as a row in the ",[444,850,807],{}," table. The drain plugin handles both single events and batches (when used with the ",[485,853,854],{"href":400},"pipeline",").",[857,858,860],"h3",{"id":859},"database-schema","Database Schema",[441,862,863,864,866,867,870],{},"The ",[444,865,807],{}," table stores indexed columns for fast querying and a ",[444,868,869],{},"data"," JSON column for all remaining fields:",[872,873,874,890],"table",{},[875,876,877],"thead",{},[878,879,880,884,887],"tr",{},[881,882,883],"th",{},"Column",[881,885,886],{},"Type",[881,888,889],{},"Description",[891,892,893,908,922,936,950,964,978,992,1007,1021,1035,1049,1063,1076],"tbody",{},[878,894,895,901,905],{},[896,897,898],"td",{},[444,899,900],{},"id",[896,902,903],{},[444,904,843],{},[896,906,907],{},"UUID primary key",[878,909,910,915,919],{},[896,911,912],{},[444,913,914],{},"timestamp",[896,916,917],{},[444,918,843],{},[896,920,921],{},"Event timestamp",[878,923,924,929,933],{},[896,925,926],{},[444,927,928],{},"level",[896,930,931],{},[444,932,843],{},[896,934,935],{},"Log level (info, warn, error, debug)",[878,937,938,943,947],{},[896,939,940],{},[444,941,942],{},"service",[896,944,945],{},[444,946,843],{},[896,948,949],{},"Service name",[878,951,952,957,961],{},[896,953,954],{},[444,955,956],{},"environment",[896,958,959],{},[444,960,843],{},[896,962,963],{},"Environment (production, staging, etc.)",[878,965,966,971,975],{},[896,967,968],{},[444,969,970],{},"method",[896,972,973],{},[444,974,843],{},[896,976,977],{},"HTTP method",[878,979,980,985,989],{},[896,981,982],{},[444,983,984],{},"path",[896,986,987],{},[444,988,843],{},[896,990,991],{},"Request path",[878,993,994,999,1004],{},[896,995,996],{},[444,997,998],{},"status",[896,1000,1001],{},[444,1002,1003],{},"integer",[896,1005,1006],{},"HTTP status code",[878,1008,1009,1014,1018],{},[896,1010,1011],{},[444,1012,1013],{},"duration_ms",[896,1015,1016],{},[444,1017,1003],{},[896,1019,1020],{},"Request duration in milliseconds",[878,1022,1023,1028,1032],{},[896,1024,1025],{},[444,1026,1027],{},"request_id",[896,1029,1030],{},[444,1031,843],{},[896,1033,1034],{},"Request correlation ID",[878,1036,1037,1042,1046],{},[896,1038,1039],{},[444,1040,1041],{},"source",[896,1043,1044],{},[444,1045,843],{},[896,1047,1048],{},"Event source (server, client)",[878,1050,1051,1056,1060],{},[896,1052,1053],{},[444,1054,1055],{},"error",[896,1057,1058],{},[444,1059,843],{},[896,1061,1062],{},"Error details (JSON string)",[878,1064,1065,1069,1073],{},[896,1066,1067],{},[444,1068,869],{},[896,1070,1071],{},[444,1072,843],{},[896,1074,1075],{},"All remaining event fields (JSON)",[878,1077,1078,1083,1087],{},[896,1079,1080],{},[444,1081,1082],{},"created_at",[896,1084,1085],{},[444,1086,843],{},[896,1088,1089],{},"Row insertion timestamp",[441,1091,1092,1093,1095,1096,1095,1098,1095,1100,1095,1102,1095,1104,1106],{},"Indexed columns: ",[444,1094,914],{},", ",[444,1097,928],{},[444,1099,942],{},[444,1101,998],{},[444,1103,1027],{},[444,1105,1082],{},".",[857,1108,1110],{"id":1109},"dialect-support","Dialect Support",[441,1112,1113],{},"The schema is automatically registered for your NuxtHub database dialect:",[457,1115,1116,1122,1127],{},[460,1117,1118,1121],{},[508,1119,1120],{},"SQLite"," (default for Cloudflare D1)",[460,1123,1124],{},[508,1125,1126],{},"MySQL",[460,1128,1129],{},[508,1130,1131],{},"PostgreSQL",[441,1133,1134,1135,1138],{},"The correct schema is selected via the ",[444,1136,1137],{},"hub:db:schema:extend"," hook based on your NuxtHub configuration.",[496,1140,1142],{"id":1141},"combining-with-external-adapters","Combining with External Adapters",[441,1144,1145,1147,1148,1150],{},[444,1146,446],{}," doesn't replace external adapters, you can use both. The module registers its own ",[444,1149,814],{}," hook, so any other drain plugins you have will still work:",[543,1152,1155],{"className":661,"code":1153,"filename":1154,"language":663,"meta":549,"style":549},"import { createAxiomDrain } from 'evlog\u002Faxiom'\n\nexport default defineNitroPlugin((nitroApp) => {\n  \u002F\u002F This runs alongside @evlog\u002Fnuxthub's built-in drain\n  nitroApp.hooks.hook('evlog:drain', createAxiomDrain())\n})\n","server\u002Fplugins\u002Fevlog-drain.ts",[444,1156,1157,1182,1186,1212,1218,1248],{"__ignoreMap":549},[553,1158,1159,1162,1165,1168,1171,1174,1176,1179],{"class":555,"line":556},[553,1160,1161],{"class":670},"import",[553,1163,1164],{"class":685}," {",[553,1166,1167],{"class":681}," createAxiomDrain",[553,1169,1170],{"class":685}," }",[553,1172,1173],{"class":670}," from",[553,1175,712],{"class":685},[553,1177,1178],{"class":562},"evlog\u002Faxiom",[553,1180,1181],{"class":685},"'\n",[553,1183,1184],{"class":555,"line":689},[553,1185,729],{"emptyLinePlaceholder":728},[553,1187,1188,1190,1192,1195,1197,1199,1203,1206,1210],{"class":555,"line":725},[553,1189,671],{"class":670},[553,1191,674],{"class":670},[553,1193,1194],{"class":677}," defineNitroPlugin",[553,1196,682],{"class":681},[553,1198,682],{"class":685},[553,1200,1202],{"class":1201},"sHdIc","nitroApp",[553,1204,1205],{"class":685},")",[553,1207,1209],{"class":1208},"spNyl"," =>",[553,1211,740],{"class":685},[553,1213,1214],{"class":555,"line":732},[553,1215,1217],{"class":1216},"sHwdD","  \u002F\u002F This runs alongside @evlog\u002Fnuxthub's built-in drain\n",[553,1219,1220,1223,1225,1228,1230,1233,1235,1237,1239,1241,1243,1245],{"class":555,"line":743},[553,1221,1222],{"class":681},"  nitroApp",[553,1224,1106],{"class":685},[553,1226,1227],{"class":681},"hooks",[553,1229,1106],{"class":685},[553,1231,1232],{"class":677},"hook",[553,1234,682],{"class":692},[553,1236,701],{"class":685},[553,1238,814],{"class":562},[553,1240,701],{"class":685},[553,1242,709],{"class":685},[553,1244,1167],{"class":677},[553,1246,1247],{"class":692},"())\n",[553,1249,1250,1252],{"class":555,"line":760},[553,1251,769],{"class":685},[553,1253,772],{"class":681},[496,1255,1257],{"id":1256},"retention","Retention",[441,1259,1260,1262],{},[444,1261,446],{}," automatically deletes old events based on your retention policy. No manual cleanup needed.",[857,1264,409],{"id":1265},"configuration",[441,1267,1268,1269,625],{},"Set the retention period in your ",[444,1270,658],{},[543,1272,1274],{"className":661,"code":1273,"filename":658,"language":663,"meta":549,"style":549},"export default defineNuxtConfig({\n  modules: ['@nuxthub\u002Fcore', '@evlog\u002Fnuxthub'],\n\n  evlog: {\n    retention: '7d', \u002F\u002F default\n  },\n})\n",[444,1275,1276,1288,1314,1318,1326,1343,1347],{"__ignoreMap":549},[553,1277,1278,1280,1282,1284,1286],{"class":555,"line":556},[553,1279,671],{"class":670},[553,1281,674],{"class":670},[553,1283,678],{"class":677},[553,1285,682],{"class":681},[553,1287,686],{"class":685},[553,1289,1290,1292,1294,1296,1298,1300,1302,1304,1306,1308,1310,1312],{"class":555,"line":689},[553,1291,693],{"class":692},[553,1293,625],{"class":685},[553,1295,698],{"class":681},[553,1297,701],{"class":685},[553,1299,704],{"class":562},[553,1301,701],{"class":685},[553,1303,709],{"class":685},[553,1305,712],{"class":685},[553,1307,446],{"class":562},[553,1309,701],{"class":685},[553,1311,719],{"class":681},[553,1313,722],{"class":685},[553,1315,1316],{"class":555,"line":725},[553,1317,729],{"emptyLinePlaceholder":728},[553,1319,1320,1322,1324],{"class":555,"line":732},[553,1321,735],{"class":692},[553,1323,625],{"class":685},[553,1325,740],{"class":685},[553,1327,1328,1330,1332,1334,1336,1338,1340],{"class":555,"line":743},[553,1329,746],{"class":692},[553,1331,625],{"class":685},[553,1333,712],{"class":685},[553,1335,753],{"class":562},[553,1337,701],{"class":685},[553,1339,709],{"class":685},[553,1341,1342],{"class":1216}," \u002F\u002F default\n",[553,1344,1345],{"class":555,"line":760},[553,1346,763],{"class":685},[553,1348,1349,1351],{"class":555,"line":766},[553,1350,769],{"class":685},[553,1352,772],{"class":681},[441,1354,1355],{},"The retention value is a number followed by a unit:",[872,1357,1358,1370],{},[875,1359,1360],{},[878,1361,1362,1365,1367],{},[881,1363,1364],{},"Unit",[881,1366,889],{},[881,1368,1369],{},"Example",[891,1371,1372,1387,1403],{},[878,1373,1374,1379,1382],{},[896,1375,1376],{},[444,1377,1378],{},"d",[896,1380,1381],{},"Days",[896,1383,1384,1386],{},[444,1385,753],{}," = 7 days",[878,1388,1389,1394,1397],{},[896,1390,1391],{},[444,1392,1393],{},"h",[896,1395,1396],{},"Hours",[896,1398,1399,1402],{},[444,1400,1401],{},"24h"," = 24 hours",[878,1404,1405,1410,1413],{},[896,1406,1407],{},[444,1408,1409],{},"m",[896,1411,1412],{},"Minutes",[896,1414,1415,1418],{},[444,1416,1417],{},"60m"," = 60 minutes",[857,1420,1422],{"id":1421},"how-cleanup-works","How Cleanup Works",[441,1424,1425,1426,1429],{},"The module registers a Nitro scheduled task (",[444,1427,1428],{},"evlog:cleanup",") that runs on a cron schedule derived from your retention value. The cron frequency is set to roughly half the retention period:",[872,1431,1432,1443],{},[875,1433,1434],{},[878,1435,1436,1438,1441],{},[881,1437,1257],{},[881,1439,1440],{},"Cron Schedule",[881,1442,889],{},[891,1444,1445,1459,1473,1487],{},[878,1446,1447,1451,1456],{},[896,1448,1449],{},[444,1450,1417],{},[896,1452,1453],{},[444,1454,1455],{},"*\u002F30 * * * *",[896,1457,1458],{},"Every 30 minutes",[878,1460,1461,1465,1470],{},[896,1462,1463],{},[444,1464,1401],{},[896,1466,1467],{},[444,1468,1469],{},"0 *\u002F12 * * *",[896,1471,1472],{},"Every 12 hours",[878,1474,1475,1479,1484],{},[896,1476,1477],{},[444,1478,753],{},[896,1480,1481],{},[444,1482,1483],{},"0 3 * * *",[896,1485,1486],{},"Daily at 3:00 AM",[878,1488,1489,1494,1498],{},[896,1490,1491],{},[444,1492,1493],{},"30d",[896,1495,1496],{},[444,1497,1483],{},[896,1499,1486],{},[441,1501,1502,1503,1505,1506,1508],{},"The cleanup task deletes all rows in ",[444,1504,807],{}," where ",[444,1507,1082],{}," is older than the retention period.",[857,1510,1512],{"id":1511},"manual-cleanup","Manual Cleanup",[441,1514,1515],{},"You can trigger cleanup manually via the API endpoint:",[543,1517,1519],{"className":545,"code":1518,"filename":629,"language":548,"meta":549,"style":549},"curl https:\u002F\u002Fyour-app.com\u002Fapi\u002F_cron\u002Fevlog-cleanup\n",[444,1520,1521],{"__ignoreMap":549},[553,1522,1523,1526],{"class":555,"line":556},[553,1524,1525],{"class":559},"curl",[553,1527,1528],{"class":562}," https:\u002F\u002Fyour-app.com\u002Fapi\u002F_cron\u002Fevlog-cleanup\n",[441,1530,1531,1532,1535],{},"If the ",[444,1533,1534],{},"CRON_SECRET"," environment variable is set, the endpoint requires a Bearer token:",[543,1537,1539],{"className":545,"code":1538,"filename":629,"language":548,"meta":549,"style":549},"curl -H \"Authorization: Bearer your-secret\" \\\n  https:\u002F\u002Fyour-app.com\u002Fapi\u002F_cron\u002Fevlog-cleanup\n",[444,1540,1541,1560],{"__ignoreMap":549},[553,1542,1543,1545,1548,1551,1554,1557],{"class":555,"line":556},[553,1544,1525],{"class":559},[553,1546,1547],{"class":562}," -H",[553,1549,1550],{"class":685}," \"",[553,1552,1553],{"class":562},"Authorization: Bearer your-secret",[553,1555,1556],{"class":685},"\"",[553,1558,1559],{"class":681}," \\\n",[553,1561,1562],{"class":555,"line":689},[553,1563,1564],{"class":562},"  https:\u002F\u002Fyour-app.com\u002Fapi\u002F_cron\u002Fevlog-cleanup\n",[441,1566,1567],{},"This is recommended for production deployments to prevent unauthorized cleanup triggers.",[857,1569,1571],{"id":1570},"vercel-cron","Vercel Cron",[441,1573,1574,1575,1578,1579,1582],{},"When installing the module with ",[444,1576,1577],{},"nuxi module add",", you'll be prompted to create a ",[444,1580,1581],{},"vercel.json"," with the appropriate cron schedule:",[543,1584,1588],{"className":1585,"code":1586,"filename":1581,"language":1587,"meta":549,"style":549},"language-json shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","{\n  \"crons\": [\n    {\n      \"path\": \"\u002Fapi\u002F_cron\u002Fevlog-cleanup\",\n      \"schedule\": \"0 3 * * *\"\n    }\n  ]\n}\n","json",[444,1589,1590,1594,1609,1614,1634,1652,1657,1662],{"__ignoreMap":549},[553,1591,1592],{"class":555,"line":556},[553,1593,686],{"class":685},[553,1595,1596,1599,1602,1604,1606],{"class":555,"line":689},[553,1597,1598],{"class":685},"  \"",[553,1600,1601],{"class":1208},"crons",[553,1603,1556],{"class":685},[553,1605,625],{"class":685},[553,1607,1608],{"class":685}," [\n",[553,1610,1611],{"class":555,"line":725},[553,1612,1613],{"class":685},"    {\n",[553,1615,1616,1619,1621,1623,1625,1627,1630,1632],{"class":555,"line":732},[553,1617,1618],{"class":685},"      \"",[553,1620,984],{"class":559},[553,1622,1556],{"class":685},[553,1624,625],{"class":685},[553,1626,1550],{"class":685},[553,1628,1629],{"class":562},"\u002Fapi\u002F_cron\u002Fevlog-cleanup",[553,1631,1556],{"class":685},[553,1633,722],{"class":685},[553,1635,1636,1638,1641,1643,1645,1647,1649],{"class":555,"line":743},[553,1637,1618],{"class":685},[553,1639,1640],{"class":559},"schedule",[553,1642,1556],{"class":685},[553,1644,625],{"class":685},[553,1646,1550],{"class":685},[553,1648,1483],{"class":562},[553,1650,1651],{"class":685},"\"\n",[553,1653,1654],{"class":555,"line":760},[553,1655,1656],{"class":685},"    }\n",[553,1658,1659],{"class":555,"line":766},[553,1660,1661],{"class":685},"  ]\n",[553,1663,1665],{"class":555,"line":1664},8,[553,1666,1667],{"class":685},"}\n",[441,1669,1670,1671,1673],{},"On Vercel, the ",[444,1672,1534],{}," environment variable is automatically set and validated.",[857,1675,1677],{"id":1676},"cloudflare-other-platforms","Cloudflare & Other Platforms",[441,1679,1680,1681,1684],{},"On Cloudflare Workers and other platforms, the Nitro scheduled task handles cleanup automatically without any additional cron configuration. The task is registered with ",[444,1682,1683],{},"experimental.tasks"," enabled in the Nitro config.",[496,1686,1688],{"id":1687},"next-steps","Next Steps",[457,1690,1691,1696],{},[460,1692,1693,1695],{},[485,1694,90],{"href":95}," - Send logs to external services alongside NuxtHub storage",[460,1697,1698,1701],{},[485,1699,1700],{"href":400},"Pipeline"," - Batch events for better database performance",[1703,1704,1705],"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 .s2Zo4, html code.shiki .s2Zo4{--shiki-light:#6182B8;--shiki-default:#82AAFF;--shiki-dark:#82AAFF}html pre.shiki code .sTEyZ, html code.shiki .sTEyZ{--shiki-light:#90A4AE;--shiki-default:#EEFFFF;--shiki-dark:#BABED8}html pre.shiki code .sMK4o, html code.shiki .sMK4o{--shiki-light:#39ADB5;--shiki-default:#89DDFF;--shiki-dark:#89DDFF}html pre.shiki code .swJcz, html code.shiki .swJcz{--shiki-light:#E53935;--shiki-default:#F07178;--shiki-dark:#F07178}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 .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}",{"title":549,"searchDepth":689,"depth":689,"links":1707},[1708,1709,1710,1711,1715,1716,1723],{"id":498,"depth":689,"text":499},{"id":537,"depth":689,"text":538},{"id":651,"depth":689,"text":652},{"id":836,"depth":689,"text":837,"children":1712},[1713,1714],{"id":859,"depth":725,"text":860},{"id":1109,"depth":725,"text":1110},{"id":1141,"depth":689,"text":1142},{"id":1256,"depth":689,"text":1257,"children":1717},[1718,1719,1720,1721,1722],{"id":1265,"depth":725,"text":409},{"id":1421,"depth":725,"text":1422},{"id":1511,"depth":725,"text":1512},{"id":1570,"depth":725,"text":1571},{"id":1676,"depth":725,"text":1677},{"id":1687,"depth":689,"text":1688},"Self-hosted log retention for evlog using NuxtHub database storage. Store, query, and automatically clean up your structured logs with zero external dependencies.","md",[1727,1732],{"label":148,"icon":1728,"to":493,"target":1729,"color":1730,"variant":1731},"i-lucide-external-link","_blank","neutral","subtle",{"label":90,"icon":1733,"to":95,"color":1730,"variant":1731},"i-custom-plug",{},{"title":148,"icon":151},{"title":436,"description":1724},"9sxOXALGeQm61SRYSySS6wz7MuiYr2OMecfAcHNq_G0",[1739,1741],{"title":143,"path":144,"stem":145,"description":1740,"icon":146,"children":-1},"Write wide events to the local file system as NDJSON for local debugging, AI agent integration, and production backup.",{"title":36,"path":158,"stem":159,"description":1742,"icon":160,"children":-1},"evlog supports every major TypeScript framework. Choose your stack and get started in minutes.",1778446115921]