[{"data":1,"prerenderedAt":2796},["ShallowReactive",2],{"navigation_docs":3,"-logging-better-auth-overview":407,"-logging-better-auth-overview-surround":2791},[4,35,159,201,289,304,391],{"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],{"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},"FS reader","\u002Fbuild-on-top\u002Ffs-reader","5.build-on-top\u002F4.fs-reader","i-lucide-folder-search",{"title":305,"path":306,"stem":307,"children":308,"page":34},"Adapters","\u002Fadapters","6.adapters",[309,312,352,367],{"title":41,"path":310,"stem":311,"icon":44},"\u002Fadapters\u002Foverview","6.adapters\u002F01.overview",{"title":313,"path":314,"stem":315,"children":316,"page":34},"Cloud destinations","\u002Fadapters\u002Fcloud","6.adapters\u002F02.cloud",[317,322,327,332,337,342,347],{"title":318,"path":319,"stem":320,"icon":321},"Axiom","\u002Fadapters\u002Fcloud\u002Faxiom","6.adapters\u002F02.cloud\u002F01.axiom","i-custom-axiom",{"title":323,"path":324,"stem":325,"icon":326},"OTLP","\u002Fadapters\u002Fcloud\u002Fotlp","6.adapters\u002F02.cloud\u002F02.otlp","i-simple-icons-opentelemetry",{"title":328,"path":329,"stem":330,"icon":331},"PostHog","\u002Fadapters\u002Fcloud\u002Fposthog","6.adapters\u002F02.cloud\u002F03.posthog","i-simple-icons-posthog",{"title":333,"path":334,"stem":335,"icon":336},"Sentry","\u002Fadapters\u002Fcloud\u002Fsentry","6.adapters\u002F02.cloud\u002F04.sentry","i-simple-icons-sentry",{"title":338,"path":339,"stem":340,"icon":341},"Better Stack","\u002Fadapters\u002Fcloud\u002Fbetter-stack","6.adapters\u002F02.cloud\u002F05.better-stack","i-simple-icons-betterstack",{"title":343,"path":344,"stem":345,"icon":346},"Datadog","\u002Fadapters\u002Fcloud\u002Fdatadog","6.adapters\u002F02.cloud\u002F06.datadog","i-simple-icons-datadog",{"title":348,"path":349,"stem":350,"icon":351},"HyperDX","\u002Fadapters\u002Fcloud\u002Fhyperdx","6.adapters\u002F02.cloud\u002F07.hyperdx","i-custom-hyperdx",{"title":353,"path":354,"stem":355,"children":356,"page":34},"Self-hosted","\u002Fadapters\u002Fself-hosted","6.adapters\u002F03.self-hosted",[357,362],{"title":358,"path":359,"stem":360,"icon":361},"File System","\u002Fadapters\u002Fself-hosted\u002Ffs","6.adapters\u002F03.self-hosted\u002F01.fs","i-lucide-hard-drive",{"title":363,"path":364,"stem":365,"icon":366},"NuxtHub","\u002Fadapters\u002Fself-hosted\u002Fnuxthub","6.adapters\u002F03.self-hosted\u002F02.nuxthub","i-simple-icons-nuxt",{"title":368,"path":369,"stem":370,"children":371,"page":34},"Building blocks","\u002Fadapters\u002Fbuilding-blocks","6.adapters\u002F04.building-blocks",[372,377,382,386],{"title":373,"path":374,"stem":375,"icon":376},"Pipeline","\u002Fadapters\u002Fbuilding-blocks\u002Fpipeline","6.adapters\u002F04.building-blocks\u002F01.pipeline","i-lucide-workflow",{"title":378,"path":379,"stem":380,"icon":381},"HTTP","\u002Fadapters\u002Fbuilding-blocks\u002Fhttp","6.adapters\u002F04.building-blocks\u002F02.http","i-lucide-globe",{"title":383,"path":384,"stem":385,"icon":83},"Custom Adapters","\u002Fadapters\u002Fbuilding-blocks\u002Fcustom","6.adapters\u002F04.building-blocks\u002F03.custom",{"title":387,"path":388,"stem":389,"icon":390},"Toolkit","\u002Fadapters\u002Fbuilding-blocks\u002Ftoolkit","6.adapters\u002F04.building-blocks\u002F04.toolkit","i-lucide-blocks",{"title":392,"path":393,"stem":394,"children":395,"page":34},"Enrichers","\u002Fenrichers","7.enrichers",[396,399,403],{"title":41,"path":397,"stem":398,"icon":28},"\u002Fenrichers\u002Foverview","7.enrichers\u002F1.overview",{"title":400,"path":401,"stem":402,"icon":288},"Built-in","\u002Fenrichers\u002Fbuilt-in","7.enrichers\u002F2.built-in",{"title":404,"path":405,"stem":406,"icon":83},"Custom","\u002Fenrichers\u002Fcustom","7.enrichers\u002F3.custom",{"id":408,"title":409,"body":410,"description":2778,"extension":2779,"links":2780,"meta":2787,"navigation":2788,"path":106,"seo":2789,"stem":107,"__hash__":2790},"docs\u002F2.logging\u002F7.better-auth\u002F01.overview.md","Better Auth Integration",{"type":411,"value":412,"toc":2771},"minimark",[413,425,430,459,530,572,575,578,1989,1992,2629,2633,2636,2651,2655,2683,2687,2767],[414,415,416,420,421,424],"p",{},[417,418,419],"code",{},"evlog\u002Fbetter-auth"," turns anonymous wide events into identified ones. Every request automatically includes who made it — no manual ",[417,422,423],{},"log.set({ user })"," needed.",[426,427,429],"h2",{"id":428},"prerequisites","Prerequisites",[414,431,432,433,439,440,444,445,448,449,452,453,458],{},"Use ",[434,435,100],"a",{"href":436,"rel":437},"https:\u002F\u002Fbetter-auth.com\u002F",[438],"nofollow"," as a ",[441,442,443],"strong",{},"direct dependency"," in your app. ",[417,446,447],{},"evlog"," does not bundle Better Auth. The integration is tested against Better Auth ",[417,450,451],{},">=1.6.9"," (same major as ",[434,454,457],{"href":455,"rel":456},"https:\u002F\u002Fgithub.com\u002FHugoRCD\u002Fevlog\u002Ftree\u002Fmain\u002Fapps\u002Fplayground",[438],"the playground",").",[460,461,462,487,501,515],"code-group",{},[463,464,470],"pre",{"className":465,"code":466,"filename":467,"language":468,"meta":469,"style":469},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","pnpm add better-auth\n","pnpm","bash","",[417,471,472],{"__ignoreMap":469},[473,474,477,480,484],"span",{"class":475,"line":476},"line",1,[473,478,467],{"class":479},"sBMFI",[473,481,483],{"class":482},"sfazB"," add",[473,485,486],{"class":482}," better-auth\n",[463,488,491],{"className":465,"code":489,"filename":490,"language":468,"meta":469,"style":469},"bun add better-auth\n","bun",[417,492,493],{"__ignoreMap":469},[473,494,495,497,499],{"class":475,"line":476},[473,496,490],{"class":479},[473,498,483],{"class":482},[473,500,486],{"class":482},[463,502,505],{"className":465,"code":503,"filename":504,"language":468,"meta":469,"style":469},"yarn add better-auth\n","yarn",[417,506,507],{"__ignoreMap":469},[473,508,509,511,513],{"class":475,"line":476},[473,510,504],{"class":479},[473,512,483],{"class":482},[473,514,486],{"class":482},[463,516,519],{"className":465,"code":517,"filename":518,"language":468,"meta":469,"style":469},"npm install better-auth\n","npm",[417,520,521],{"__ignoreMap":469},[473,522,523,525,528],{"class":475,"line":476},[473,524,518],{"class":479},[473,526,527],{"class":482}," install",[473,529,486],{"class":482},[531,532,535,538,560],"prompt",{":actions":533,"description":534,"icon":101},"[\"copy\",\"cursor\",\"windsurf\"]","Add Better Auth user identification",[414,536,537],{},"Add Better Auth user identification to my app with evlog.",[539,540,541,545,548,551,554,557],"ul",{},[542,543,544],"li",{},"Import createAuthMiddleware from 'evlog\u002Fbetter-auth'",[542,546,547],{},"Call createAuthMiddleware(auth) to get an identify function",[542,549,550],{},"Call identify(log, headers, path) in your middleware\u002Fhook to auto-identify users on every request",[542,552,553],{},"Safe by default — only extracts whitelisted fields, never logs passwords or tokens",[542,555,556],{},"Supports include\u002Fexclude route patterns, lifecycle hooks, and Better Auth plugin fields",[542,558,559],{},"Works with all frameworks: Nuxt, Next.js, Express, Hono, Fastify, NestJS, Elysia, standalone",[414,561,562,563,567,568],{},"Docs: ",[434,564,565],{"href":565,"rel":566},"https:\u002F\u002Fwww.evlog.dev\u002Flogging\u002Fbetter-auth\u002Foverview",[438],"\nAdapters: ",[434,569,570],{"href":570,"rel":571},"https:\u002F\u002Fwww.evlog.dev\u002Fadapters",[438],[426,573,20],{"id":574},"quick-start",[414,576,577],{},"One middleware, all requests identified:",[460,579,580,801,1031,1184,1354,1498,1655,1863],{},[463,581,586],{"className":582,"code":583,"filename":584,"language":585,"meta":469,"style":469},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import { createAuthMiddleware } from 'evlog\u002Fbetter-auth'\n\nconst identify = createAuthMiddleware(auth, {\n  exclude: ['\u002Fapi\u002Fauth\u002F**'],\n})\n\nexport default defineEventHandler(async (event) => {\n  if (!event.context.log) return\n  await identify(event.context.log, event.headers, event.path)\n})\n","server\u002Fmiddleware\u002Fauth-identify.ts (Nuxt)","typescript",[417,587,588,616,623,648,675,684,689,722,752,794],{"__ignoreMap":469},[473,589,590,594,598,602,605,608,611,613],{"class":475,"line":476},[473,591,593],{"class":592},"s7zQu","import",[473,595,597],{"class":596},"sMK4o"," {",[473,599,601],{"class":600},"sTEyZ"," createAuthMiddleware",[473,603,604],{"class":596}," }",[473,606,607],{"class":592}," from",[473,609,610],{"class":596}," '",[473,612,419],{"class":482},[473,614,615],{"class":596},"'\n",[473,617,619],{"class":475,"line":618},2,[473,620,622],{"emptyLinePlaceholder":621},true,"\n",[473,624,626,630,633,636,639,642,645],{"class":475,"line":625},3,[473,627,629],{"class":628},"spNyl","const",[473,631,632],{"class":600}," identify ",[473,634,635],{"class":596},"=",[473,637,601],{"class":638},"s2Zo4",[473,640,641],{"class":600},"(auth",[473,643,644],{"class":596},",",[473,646,647],{"class":596}," {\n",[473,649,651,655,658,661,664,667,669,672],{"class":475,"line":650},4,[473,652,654],{"class":653},"swJcz","  exclude",[473,656,657],{"class":596},":",[473,659,660],{"class":600}," [",[473,662,663],{"class":596},"'",[473,665,666],{"class":482},"\u002Fapi\u002Fauth\u002F**",[473,668,663],{"class":596},[473,670,671],{"class":600},"]",[473,673,674],{"class":596},",\n",[473,676,678,681],{"class":475,"line":677},5,[473,679,680],{"class":596},"}",[473,682,683],{"class":600},")\n",[473,685,687],{"class":475,"line":686},6,[473,688,622],{"emptyLinePlaceholder":621},[473,690,692,695,698,701,704,707,710,714,717,720],{"class":475,"line":691},7,[473,693,694],{"class":592},"export",[473,696,697],{"class":592}," default",[473,699,700],{"class":638}," defineEventHandler",[473,702,703],{"class":600},"(",[473,705,706],{"class":628},"async",[473,708,709],{"class":596}," (",[473,711,713],{"class":712},"sHdIc","event",[473,715,716],{"class":596},")",[473,718,719],{"class":628}," =>",[473,721,647],{"class":596},[473,723,725,728,730,733,735,738,741,743,746,749],{"class":475,"line":724},8,[473,726,727],{"class":592},"  if",[473,729,709],{"class":653},[473,731,732],{"class":596},"!",[473,734,713],{"class":600},[473,736,737],{"class":596},".",[473,739,740],{"class":600},"context",[473,742,737],{"class":596},[473,744,745],{"class":600},"log",[473,747,748],{"class":653},") ",[473,750,751],{"class":592},"return\n",[473,753,755,758,761,763,765,767,769,771,773,775,778,780,783,785,787,789,792],{"class":475,"line":754},9,[473,756,757],{"class":592},"  await",[473,759,760],{"class":638}," identify",[473,762,703],{"class":653},[473,764,713],{"class":600},[473,766,737],{"class":596},[473,768,740],{"class":600},[473,770,737],{"class":596},[473,772,745],{"class":600},[473,774,644],{"class":596},[473,776,777],{"class":600}," event",[473,779,737],{"class":596},[473,781,782],{"class":600},"headers",[473,784,644],{"class":596},[473,786,777],{"class":600},[473,788,737],{"class":596},[473,790,791],{"class":600},"path",[473,793,683],{"class":653},[473,795,797,799],{"class":475,"line":796},10,[473,798,680],{"class":596},[473,800,683],{"class":600},[463,802,805],{"className":582,"code":803,"filename":804,"language":585,"meta":469,"style":469},"import { withEvlog, useLogger } from '@\u002Flib\u002Fevlog'\nimport { createAuthMiddleware } from 'evlog\u002Fbetter-auth'\nimport { auth } from '@\u002Flib\u002Fauth'\n\nconst identify = createAuthMiddleware(auth)\n\nexport const POST = withEvlog(async (request: Request) => {\n  const log = useLogger()\n  await identify(log, request.headers)\n  log.set({ action: 'checkout' })\n  return Response.json({ success: true })\n})\n","app\u002Fapi\u002Fcheckout\u002Froute.ts (Next.js)",[417,806,807,832,850,870,874,887,891,925,941,962,993,1024],{"__ignoreMap":469},[473,808,809,811,813,816,818,821,823,825,827,830],{"class":475,"line":476},[473,810,593],{"class":592},[473,812,597],{"class":596},[473,814,815],{"class":600}," withEvlog",[473,817,644],{"class":596},[473,819,820],{"class":600}," useLogger",[473,822,604],{"class":596},[473,824,607],{"class":592},[473,826,610],{"class":596},[473,828,829],{"class":482},"@\u002Flib\u002Fevlog",[473,831,615],{"class":596},[473,833,834,836,838,840,842,844,846,848],{"class":475,"line":618},[473,835,593],{"class":592},[473,837,597],{"class":596},[473,839,601],{"class":600},[473,841,604],{"class":596},[473,843,607],{"class":592},[473,845,610],{"class":596},[473,847,419],{"class":482},[473,849,615],{"class":596},[473,851,852,854,856,859,861,863,865,868],{"class":475,"line":625},[473,853,593],{"class":592},[473,855,597],{"class":596},[473,857,858],{"class":600}," auth",[473,860,604],{"class":596},[473,862,607],{"class":592},[473,864,610],{"class":596},[473,866,867],{"class":482},"@\u002Flib\u002Fauth",[473,869,615],{"class":596},[473,871,872],{"class":475,"line":650},[473,873,622],{"emptyLinePlaceholder":621},[473,875,876,878,880,882,884],{"class":475,"line":677},[473,877,629],{"class":628},[473,879,632],{"class":600},[473,881,635],{"class":596},[473,883,601],{"class":638},[473,885,886],{"class":600},"(auth)\n",[473,888,889],{"class":475,"line":686},[473,890,622],{"emptyLinePlaceholder":621},[473,892,893,895,898,901,903,905,907,909,911,914,916,919,921,923],{"class":475,"line":691},[473,894,694],{"class":592},[473,896,897],{"class":628}," const",[473,899,900],{"class":600}," POST ",[473,902,635],{"class":596},[473,904,815],{"class":638},[473,906,703],{"class":600},[473,908,706],{"class":628},[473,910,709],{"class":596},[473,912,913],{"class":712},"request",[473,915,657],{"class":596},[473,917,918],{"class":479}," Request",[473,920,716],{"class":596},[473,922,719],{"class":628},[473,924,647],{"class":596},[473,926,927,930,933,936,938],{"class":475,"line":724},[473,928,929],{"class":628},"  const",[473,931,932],{"class":600}," log",[473,934,935],{"class":596}," =",[473,937,820],{"class":638},[473,939,940],{"class":653},"()\n",[473,942,943,945,947,949,951,953,956,958,960],{"class":475,"line":754},[473,944,757],{"class":592},[473,946,760],{"class":638},[473,948,703],{"class":653},[473,950,745],{"class":600},[473,952,644],{"class":596},[473,954,955],{"class":600}," request",[473,957,737],{"class":596},[473,959,782],{"class":600},[473,961,683],{"class":653},[473,963,964,967,969,972,974,977,980,982,984,987,989,991],{"class":475,"line":796},[473,965,966],{"class":600},"  log",[473,968,737],{"class":596},[473,970,971],{"class":638},"set",[473,973,703],{"class":653},[473,975,976],{"class":596},"{",[473,978,979],{"class":653}," action",[473,981,657],{"class":596},[473,983,610],{"class":596},[473,985,986],{"class":482},"checkout",[473,988,663],{"class":596},[473,990,604],{"class":596},[473,992,683],{"class":653},[473,994,996,999,1002,1004,1007,1009,1011,1014,1016,1020,1022],{"class":475,"line":995},11,[473,997,998],{"class":592},"  return",[473,1000,1001],{"class":600}," Response",[473,1003,737],{"class":596},[473,1005,1006],{"class":638},"json",[473,1008,703],{"class":653},[473,1010,976],{"class":596},[473,1012,1013],{"class":653}," success",[473,1015,657],{"class":596},[473,1017,1019],{"class":1018},"sfNiH"," true",[473,1021,604],{"class":596},[473,1023,683],{"class":653},[473,1025,1027,1029],{"class":475,"line":1026},12,[473,1028,680],{"class":596},[473,1030,683],{"class":600},[463,1032,1035],{"className":582,"code":1033,"filename":1034,"language":585,"meta":469,"style":469},"import { createAuthMiddleware } from 'evlog\u002Fbetter-auth'\n\nconst identify = createAuthMiddleware(auth, {\n  exclude: ['\u002Fapi\u002Fauth\u002F**'],\n})\n\napp.use(async (req, res, next) => {\n  await identify(req.log, req.headers, req.path)\n  next()\n})\n","src\u002Findex.ts (Express)",[417,1036,1037,1055,1059,1075,1093,1099,1103,1138,1171,1178],{"__ignoreMap":469},[473,1038,1039,1041,1043,1045,1047,1049,1051,1053],{"class":475,"line":476},[473,1040,593],{"class":592},[473,1042,597],{"class":596},[473,1044,601],{"class":600},[473,1046,604],{"class":596},[473,1048,607],{"class":592},[473,1050,610],{"class":596},[473,1052,419],{"class":482},[473,1054,615],{"class":596},[473,1056,1057],{"class":475,"line":618},[473,1058,622],{"emptyLinePlaceholder":621},[473,1060,1061,1063,1065,1067,1069,1071,1073],{"class":475,"line":625},[473,1062,629],{"class":628},[473,1064,632],{"class":600},[473,1066,635],{"class":596},[473,1068,601],{"class":638},[473,1070,641],{"class":600},[473,1072,644],{"class":596},[473,1074,647],{"class":596},[473,1076,1077,1079,1081,1083,1085,1087,1089,1091],{"class":475,"line":650},[473,1078,654],{"class":653},[473,1080,657],{"class":596},[473,1082,660],{"class":600},[473,1084,663],{"class":596},[473,1086,666],{"class":482},[473,1088,663],{"class":596},[473,1090,671],{"class":600},[473,1092,674],{"class":596},[473,1094,1095,1097],{"class":475,"line":677},[473,1096,680],{"class":596},[473,1098,683],{"class":600},[473,1100,1101],{"class":475,"line":686},[473,1102,622],{"emptyLinePlaceholder":621},[473,1104,1105,1108,1110,1113,1115,1117,1119,1122,1124,1127,1129,1132,1134,1136],{"class":475,"line":691},[473,1106,1107],{"class":600},"app",[473,1109,737],{"class":596},[473,1111,1112],{"class":638},"use",[473,1114,703],{"class":600},[473,1116,706],{"class":628},[473,1118,709],{"class":596},[473,1120,1121],{"class":712},"req",[473,1123,644],{"class":596},[473,1125,1126],{"class":712}," res",[473,1128,644],{"class":596},[473,1130,1131],{"class":712}," next",[473,1133,716],{"class":596},[473,1135,719],{"class":628},[473,1137,647],{"class":596},[473,1139,1140,1142,1144,1146,1148,1150,1152,1154,1157,1159,1161,1163,1165,1167,1169],{"class":475,"line":724},[473,1141,757],{"class":592},[473,1143,760],{"class":638},[473,1145,703],{"class":653},[473,1147,1121],{"class":600},[473,1149,737],{"class":596},[473,1151,745],{"class":600},[473,1153,644],{"class":596},[473,1155,1156],{"class":600}," req",[473,1158,737],{"class":596},[473,1160,782],{"class":600},[473,1162,644],{"class":596},[473,1164,1156],{"class":600},[473,1166,737],{"class":596},[473,1168,791],{"class":600},[473,1170,683],{"class":653},[473,1172,1173,1176],{"class":475,"line":754},[473,1174,1175],{"class":638},"  next",[473,1177,940],{"class":653},[473,1179,1180,1182],{"class":475,"line":796},[473,1181,680],{"class":596},[473,1183,683],{"class":600},[463,1185,1188],{"className":582,"code":1186,"filename":1187,"language":585,"meta":469,"style":469},"import { createAuthMiddleware } from 'evlog\u002Fbetter-auth'\n\nconst identify = createAuthMiddleware(auth, {\n  exclude: ['\u002Fapi\u002Fauth\u002F**'],\n})\n\napp.use(async (c, next) => {\n  await identify(c.get('log'), c.req.raw.headers, c.req.path)\n  await next()\n})\n","src\u002Findex.ts (Hono)",[417,1189,1190,1208,1212,1228,1246,1252,1256,1283,1340,1348],{"__ignoreMap":469},[473,1191,1192,1194,1196,1198,1200,1202,1204,1206],{"class":475,"line":476},[473,1193,593],{"class":592},[473,1195,597],{"class":596},[473,1197,601],{"class":600},[473,1199,604],{"class":596},[473,1201,607],{"class":592},[473,1203,610],{"class":596},[473,1205,419],{"class":482},[473,1207,615],{"class":596},[473,1209,1210],{"class":475,"line":618},[473,1211,622],{"emptyLinePlaceholder":621},[473,1213,1214,1216,1218,1220,1222,1224,1226],{"class":475,"line":625},[473,1215,629],{"class":628},[473,1217,632],{"class":600},[473,1219,635],{"class":596},[473,1221,601],{"class":638},[473,1223,641],{"class":600},[473,1225,644],{"class":596},[473,1227,647],{"class":596},[473,1229,1230,1232,1234,1236,1238,1240,1242,1244],{"class":475,"line":650},[473,1231,654],{"class":653},[473,1233,657],{"class":596},[473,1235,660],{"class":600},[473,1237,663],{"class":596},[473,1239,666],{"class":482},[473,1241,663],{"class":596},[473,1243,671],{"class":600},[473,1245,674],{"class":596},[473,1247,1248,1250],{"class":475,"line":677},[473,1249,680],{"class":596},[473,1251,683],{"class":600},[473,1253,1254],{"class":475,"line":686},[473,1255,622],{"emptyLinePlaceholder":621},[473,1257,1258,1260,1262,1264,1266,1268,1270,1273,1275,1277,1279,1281],{"class":475,"line":691},[473,1259,1107],{"class":600},[473,1261,737],{"class":596},[473,1263,1112],{"class":638},[473,1265,703],{"class":600},[473,1267,706],{"class":628},[473,1269,709],{"class":596},[473,1271,1272],{"class":712},"c",[473,1274,644],{"class":596},[473,1276,1131],{"class":712},[473,1278,716],{"class":596},[473,1280,719],{"class":628},[473,1282,647],{"class":596},[473,1284,1285,1287,1289,1291,1293,1295,1298,1300,1302,1304,1306,1308,1310,1313,1315,1317,1319,1322,1324,1326,1328,1330,1332,1334,1336,1338],{"class":475,"line":724},[473,1286,757],{"class":592},[473,1288,760],{"class":638},[473,1290,703],{"class":653},[473,1292,1272],{"class":600},[473,1294,737],{"class":596},[473,1296,1297],{"class":638},"get",[473,1299,703],{"class":653},[473,1301,663],{"class":596},[473,1303,745],{"class":482},[473,1305,663],{"class":596},[473,1307,716],{"class":653},[473,1309,644],{"class":596},[473,1311,1312],{"class":600}," c",[473,1314,737],{"class":596},[473,1316,1121],{"class":600},[473,1318,737],{"class":596},[473,1320,1321],{"class":600},"raw",[473,1323,737],{"class":596},[473,1325,782],{"class":600},[473,1327,644],{"class":596},[473,1329,1312],{"class":600},[473,1331,737],{"class":596},[473,1333,1121],{"class":600},[473,1335,737],{"class":596},[473,1337,791],{"class":600},[473,1339,683],{"class":653},[473,1341,1342,1344,1346],{"class":475,"line":754},[473,1343,757],{"class":592},[473,1345,1131],{"class":638},[473,1347,940],{"class":653},[473,1349,1350,1352],{"class":475,"line":796},[473,1351,680],{"class":596},[473,1353,683],{"class":600},[463,1355,1358],{"className":582,"code":1356,"filename":1357,"language":585,"meta":469,"style":469},"import { createAuthMiddleware } from 'evlog\u002Fbetter-auth'\n\nconst identify = createAuthMiddleware(auth, {\n  exclude: ['\u002Fapi\u002Fauth\u002F**'],\n})\n\napp.addHook('onRequest', async (request) => {\n  await identify(request.log, request.headers, request.url)\n})\n","src\u002Findex.ts (Fastify)",[417,1359,1360,1378,1382,1398,1416,1422,1426,1459,1492],{"__ignoreMap":469},[473,1361,1362,1364,1366,1368,1370,1372,1374,1376],{"class":475,"line":476},[473,1363,593],{"class":592},[473,1365,597],{"class":596},[473,1367,601],{"class":600},[473,1369,604],{"class":596},[473,1371,607],{"class":592},[473,1373,610],{"class":596},[473,1375,419],{"class":482},[473,1377,615],{"class":596},[473,1379,1380],{"class":475,"line":618},[473,1381,622],{"emptyLinePlaceholder":621},[473,1383,1384,1386,1388,1390,1392,1394,1396],{"class":475,"line":625},[473,1385,629],{"class":628},[473,1387,632],{"class":600},[473,1389,635],{"class":596},[473,1391,601],{"class":638},[473,1393,641],{"class":600},[473,1395,644],{"class":596},[473,1397,647],{"class":596},[473,1399,1400,1402,1404,1406,1408,1410,1412,1414],{"class":475,"line":650},[473,1401,654],{"class":653},[473,1403,657],{"class":596},[473,1405,660],{"class":600},[473,1407,663],{"class":596},[473,1409,666],{"class":482},[473,1411,663],{"class":596},[473,1413,671],{"class":600},[473,1415,674],{"class":596},[473,1417,1418,1420],{"class":475,"line":677},[473,1419,680],{"class":596},[473,1421,683],{"class":600},[473,1423,1424],{"class":475,"line":686},[473,1425,622],{"emptyLinePlaceholder":621},[473,1427,1428,1430,1432,1435,1437,1439,1442,1444,1446,1449,1451,1453,1455,1457],{"class":475,"line":691},[473,1429,1107],{"class":600},[473,1431,737],{"class":596},[473,1433,1434],{"class":638},"addHook",[473,1436,703],{"class":600},[473,1438,663],{"class":596},[473,1440,1441],{"class":482},"onRequest",[473,1443,663],{"class":596},[473,1445,644],{"class":596},[473,1447,1448],{"class":628}," async",[473,1450,709],{"class":596},[473,1452,913],{"class":712},[473,1454,716],{"class":596},[473,1456,719],{"class":628},[473,1458,647],{"class":596},[473,1460,1461,1463,1465,1467,1469,1471,1473,1475,1477,1479,1481,1483,1485,1487,1490],{"class":475,"line":724},[473,1462,757],{"class":592},[473,1464,760],{"class":638},[473,1466,703],{"class":653},[473,1468,913],{"class":600},[473,1470,737],{"class":596},[473,1472,745],{"class":600},[473,1474,644],{"class":596},[473,1476,955],{"class":600},[473,1478,737],{"class":596},[473,1480,782],{"class":600},[473,1482,644],{"class":596},[473,1484,955],{"class":600},[473,1486,737],{"class":596},[473,1488,1489],{"class":600},"url",[473,1491,683],{"class":653},[473,1493,1494,1496],{"class":475,"line":754},[473,1495,680],{"class":596},[473,1497,683],{"class":600},[463,1499,1502],{"className":582,"code":1500,"filename":1501,"language":585,"meta":469,"style":469},"import { createAuthMiddleware } from 'evlog\u002Fbetter-auth'\n\nconst identify = createAuthMiddleware(auth, {\n  exclude: ['\u002Fapi\u002Fauth\u002F**'],\n})\n\napp.derive(async ({ log, request }) => {\n  await identify(log, request.headers, new URL(request.url).pathname)\n  return {}\n})\n","src\u002Findex.ts (Elysia)",[417,1503,1504,1522,1526,1542,1560,1566,1570,1599,1642,1649],{"__ignoreMap":469},[473,1505,1506,1508,1510,1512,1514,1516,1518,1520],{"class":475,"line":476},[473,1507,593],{"class":592},[473,1509,597],{"class":596},[473,1511,601],{"class":600},[473,1513,604],{"class":596},[473,1515,607],{"class":592},[473,1517,610],{"class":596},[473,1519,419],{"class":482},[473,1521,615],{"class":596},[473,1523,1524],{"class":475,"line":618},[473,1525,622],{"emptyLinePlaceholder":621},[473,1527,1528,1530,1532,1534,1536,1538,1540],{"class":475,"line":625},[473,1529,629],{"class":628},[473,1531,632],{"class":600},[473,1533,635],{"class":596},[473,1535,601],{"class":638},[473,1537,641],{"class":600},[473,1539,644],{"class":596},[473,1541,647],{"class":596},[473,1543,1544,1546,1548,1550,1552,1554,1556,1558],{"class":475,"line":650},[473,1545,654],{"class":653},[473,1547,657],{"class":596},[473,1549,660],{"class":600},[473,1551,663],{"class":596},[473,1553,666],{"class":482},[473,1555,663],{"class":596},[473,1557,671],{"class":600},[473,1559,674],{"class":596},[473,1561,1562,1564],{"class":475,"line":677},[473,1563,680],{"class":596},[473,1565,683],{"class":600},[473,1567,1568],{"class":475,"line":686},[473,1569,622],{"emptyLinePlaceholder":621},[473,1571,1572,1574,1576,1579,1581,1583,1586,1588,1590,1592,1595,1597],{"class":475,"line":691},[473,1573,1107],{"class":600},[473,1575,737],{"class":596},[473,1577,1578],{"class":638},"derive",[473,1580,703],{"class":600},[473,1582,706],{"class":628},[473,1584,1585],{"class":596}," ({",[473,1587,932],{"class":712},[473,1589,644],{"class":596},[473,1591,955],{"class":712},[473,1593,1594],{"class":596}," })",[473,1596,719],{"class":628},[473,1598,647],{"class":596},[473,1600,1601,1603,1605,1607,1609,1611,1613,1615,1617,1619,1622,1625,1627,1629,1631,1633,1635,1637,1640],{"class":475,"line":724},[473,1602,757],{"class":592},[473,1604,760],{"class":638},[473,1606,703],{"class":653},[473,1608,745],{"class":600},[473,1610,644],{"class":596},[473,1612,955],{"class":600},[473,1614,737],{"class":596},[473,1616,782],{"class":600},[473,1618,644],{"class":596},[473,1620,1621],{"class":596}," new",[473,1623,1624],{"class":638}," URL",[473,1626,703],{"class":653},[473,1628,913],{"class":600},[473,1630,737],{"class":596},[473,1632,1489],{"class":600},[473,1634,716],{"class":653},[473,1636,737],{"class":596},[473,1638,1639],{"class":600},"pathname",[473,1641,683],{"class":653},[473,1643,1644,1646],{"class":475,"line":754},[473,1645,998],{"class":592},[473,1647,1648],{"class":596}," {}\n",[473,1650,1651,1653],{"class":475,"line":796},[473,1652,680],{"class":596},[473,1654,683],{"class":600},[463,1656,1659],{"className":582,"code":1657,"filename":1658,"language":585,"meta":469,"style":469},"import { createAuthMiddleware } from 'evlog\u002Fbetter-auth'\nimport { useLogger } from 'evlog\u002Fnestjs'\n\nconst identify = createAuthMiddleware(auth, {\n  exclude: ['\u002Fapi\u002Fauth\u002F**'],\n})\n\n@Injectable()\nexport class AuthIdentifyMiddleware implements NestMiddleware {\n  async use(req: Request, res: Response, next: NextFunction) {\n    await identify(useLogger(), req.headers, req.path)\n    next()\n  }\n}\n","src\u002Fauth-identify.middleware.ts (NestJS)",[417,1660,1661,1679,1698,1702,1718,1736,1742,1746,1756,1774,1811,1844,1851,1857],{"__ignoreMap":469},[473,1662,1663,1665,1667,1669,1671,1673,1675,1677],{"class":475,"line":476},[473,1664,593],{"class":592},[473,1666,597],{"class":596},[473,1668,601],{"class":600},[473,1670,604],{"class":596},[473,1672,607],{"class":592},[473,1674,610],{"class":596},[473,1676,419],{"class":482},[473,1678,615],{"class":596},[473,1680,1681,1683,1685,1687,1689,1691,1693,1696],{"class":475,"line":618},[473,1682,593],{"class":592},[473,1684,597],{"class":596},[473,1686,820],{"class":600},[473,1688,604],{"class":596},[473,1690,607],{"class":592},[473,1692,610],{"class":596},[473,1694,1695],{"class":482},"evlog\u002Fnestjs",[473,1697,615],{"class":596},[473,1699,1700],{"class":475,"line":625},[473,1701,622],{"emptyLinePlaceholder":621},[473,1703,1704,1706,1708,1710,1712,1714,1716],{"class":475,"line":650},[473,1705,629],{"class":628},[473,1707,632],{"class":600},[473,1709,635],{"class":596},[473,1711,601],{"class":638},[473,1713,641],{"class":600},[473,1715,644],{"class":596},[473,1717,647],{"class":596},[473,1719,1720,1722,1724,1726,1728,1730,1732,1734],{"class":475,"line":677},[473,1721,654],{"class":653},[473,1723,657],{"class":596},[473,1725,660],{"class":600},[473,1727,663],{"class":596},[473,1729,666],{"class":482},[473,1731,663],{"class":596},[473,1733,671],{"class":600},[473,1735,674],{"class":596},[473,1737,1738,1740],{"class":475,"line":686},[473,1739,680],{"class":596},[473,1741,683],{"class":600},[473,1743,1744],{"class":475,"line":691},[473,1745,622],{"emptyLinePlaceholder":621},[473,1747,1748,1751,1754],{"class":475,"line":724},[473,1749,1750],{"class":596},"@",[473,1752,1753],{"class":638},"Injectable",[473,1755,940],{"class":600},[473,1757,1758,1760,1763,1766,1769,1772],{"class":475,"line":754},[473,1759,694],{"class":592},[473,1761,1762],{"class":628}," class",[473,1764,1765],{"class":479}," AuthIdentifyMiddleware",[473,1767,1768],{"class":628}," implements",[473,1770,1771],{"class":479}," NestMiddleware",[473,1773,647],{"class":596},[473,1775,1776,1779,1782,1784,1786,1788,1790,1792,1794,1796,1798,1800,1802,1804,1807,1809],{"class":475,"line":796},[473,1777,1778],{"class":628},"  async",[473,1780,1781],{"class":653}," use",[473,1783,703],{"class":596},[473,1785,1121],{"class":712},[473,1787,657],{"class":596},[473,1789,918],{"class":479},[473,1791,644],{"class":596},[473,1793,1126],{"class":712},[473,1795,657],{"class":596},[473,1797,1001],{"class":479},[473,1799,644],{"class":596},[473,1801,1131],{"class":712},[473,1803,657],{"class":596},[473,1805,1806],{"class":479}," NextFunction",[473,1808,716],{"class":596},[473,1810,647],{"class":596},[473,1812,1813,1816,1818,1820,1823,1826,1828,1830,1832,1834,1836,1838,1840,1842],{"class":475,"line":995},[473,1814,1815],{"class":592},"    await",[473,1817,760],{"class":638},[473,1819,703],{"class":653},[473,1821,1822],{"class":638},"useLogger",[473,1824,1825],{"class":653},"()",[473,1827,644],{"class":596},[473,1829,1156],{"class":600},[473,1831,737],{"class":596},[473,1833,782],{"class":600},[473,1835,644],{"class":596},[473,1837,1156],{"class":600},[473,1839,737],{"class":596},[473,1841,791],{"class":600},[473,1843,683],{"class":653},[473,1845,1846,1849],{"class":475,"line":1026},[473,1847,1848],{"class":638},"    next",[473,1850,940],{"class":653},[473,1852,1854],{"class":475,"line":1853},13,[473,1855,1856],{"class":596},"  }\n",[473,1858,1860],{"class":475,"line":1859},14,[473,1861,1862],{"class":596},"}\n",[463,1864,1867],{"className":582,"code":1865,"filename":1866,"language":585,"meta":469,"style":469},"import { identifyUser } from 'evlog\u002Fbetter-auth'\nimport { createLogger } from 'evlog'\n\nconst log = createLogger()\nconst session = await auth.api.getSession({ headers })\nif (session) identifyUser(log, session)\nlog.emit()\n","scripts\u002Fsync-job.ts (Standalone)",[417,1868,1869,1888,1907,1911,1924,1959,1978],{"__ignoreMap":469},[473,1870,1871,1873,1875,1878,1880,1882,1884,1886],{"class":475,"line":476},[473,1872,593],{"class":592},[473,1874,597],{"class":596},[473,1876,1877],{"class":600}," identifyUser",[473,1879,604],{"class":596},[473,1881,607],{"class":592},[473,1883,610],{"class":596},[473,1885,419],{"class":482},[473,1887,615],{"class":596},[473,1889,1890,1892,1894,1897,1899,1901,1903,1905],{"class":475,"line":618},[473,1891,593],{"class":592},[473,1893,597],{"class":596},[473,1895,1896],{"class":600}," createLogger",[473,1898,604],{"class":596},[473,1900,607],{"class":592},[473,1902,610],{"class":596},[473,1904,447],{"class":482},[473,1906,615],{"class":596},[473,1908,1909],{"class":475,"line":625},[473,1910,622],{"emptyLinePlaceholder":621},[473,1912,1913,1915,1918,1920,1922],{"class":475,"line":650},[473,1914,629],{"class":628},[473,1916,1917],{"class":600}," log ",[473,1919,635],{"class":596},[473,1921,1896],{"class":638},[473,1923,940],{"class":600},[473,1925,1926,1928,1931,1933,1936,1938,1940,1943,1945,1948,1950,1952,1955,1957],{"class":475,"line":677},[473,1927,629],{"class":628},[473,1929,1930],{"class":600}," session ",[473,1932,635],{"class":596},[473,1934,1935],{"class":592}," await",[473,1937,858],{"class":600},[473,1939,737],{"class":596},[473,1941,1942],{"class":600},"api",[473,1944,737],{"class":596},[473,1946,1947],{"class":638},"getSession",[473,1949,703],{"class":600},[473,1951,976],{"class":596},[473,1953,1954],{"class":600}," headers ",[473,1956,680],{"class":596},[473,1958,683],{"class":600},[473,1960,1961,1964,1967,1970,1973,1975],{"class":475,"line":686},[473,1962,1963],{"class":592},"if",[473,1965,1966],{"class":600}," (session) ",[473,1968,1969],{"class":638},"identifyUser",[473,1971,1972],{"class":600},"(log",[473,1974,644],{"class":596},[473,1976,1977],{"class":600}," session)\n",[473,1979,1980,1982,1984,1987],{"class":475,"line":691},[473,1981,745],{"class":600},[473,1983,737],{"class":596},[473,1985,1986],{"class":638},"emit",[473,1988,940],{"class":600},[414,1990,1991],{},"Your wide event now includes the user:",[460,1993,1994,2171],{},[463,1995,1999],{"className":1996,"code":1997,"filename":1998,"language":1006,"meta":469,"style":469},"language-json shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","{\n  \"level\": \"info\",\n  \"method\": \"POST\",\n  \"path\": \"\u002Fapi\u002Fcheckout\",\n  \"status\": 200,\n  \"duration\": \"120ms\",\n  \"requestId\": \"a5669202-7765-4f59-b6f0-b9f40ce71599\",\n  \"cart\": { \"items\": 3, \"total\": 9999 }\n}\n","Before — anonymous",[417,2000,2001,2006,2029,2049,2068,2085,2105,2125,2167],{"__ignoreMap":469},[473,2002,2003],{"class":475,"line":476},[473,2004,2005],{"class":596},"{\n",[473,2007,2008,2011,2014,2017,2019,2022,2025,2027],{"class":475,"line":618},[473,2009,2010],{"class":596},"  \"",[473,2012,2013],{"class":628},"level",[473,2015,2016],{"class":596},"\"",[473,2018,657],{"class":596},[473,2020,2021],{"class":596}," \"",[473,2023,2024],{"class":482},"info",[473,2026,2016],{"class":596},[473,2028,674],{"class":596},[473,2030,2031,2033,2036,2038,2040,2042,2045,2047],{"class":475,"line":625},[473,2032,2010],{"class":596},[473,2034,2035],{"class":628},"method",[473,2037,2016],{"class":596},[473,2039,657],{"class":596},[473,2041,2021],{"class":596},[473,2043,2044],{"class":482},"POST",[473,2046,2016],{"class":596},[473,2048,674],{"class":596},[473,2050,2051,2053,2055,2057,2059,2061,2064,2066],{"class":475,"line":650},[473,2052,2010],{"class":596},[473,2054,791],{"class":628},[473,2056,2016],{"class":596},[473,2058,657],{"class":596},[473,2060,2021],{"class":596},[473,2062,2063],{"class":482},"\u002Fapi\u002Fcheckout",[473,2065,2016],{"class":596},[473,2067,674],{"class":596},[473,2069,2070,2072,2075,2077,2079,2083],{"class":475,"line":677},[473,2071,2010],{"class":596},[473,2073,2074],{"class":628},"status",[473,2076,2016],{"class":596},[473,2078,657],{"class":596},[473,2080,2082],{"class":2081},"sbssI"," 200",[473,2084,674],{"class":596},[473,2086,2087,2089,2092,2094,2096,2098,2101,2103],{"class":475,"line":686},[473,2088,2010],{"class":596},[473,2090,2091],{"class":628},"duration",[473,2093,2016],{"class":596},[473,2095,657],{"class":596},[473,2097,2021],{"class":596},[473,2099,2100],{"class":482},"120ms",[473,2102,2016],{"class":596},[473,2104,674],{"class":596},[473,2106,2107,2109,2112,2114,2116,2118,2121,2123],{"class":475,"line":691},[473,2108,2010],{"class":596},[473,2110,2111],{"class":628},"requestId",[473,2113,2016],{"class":596},[473,2115,657],{"class":596},[473,2117,2021],{"class":596},[473,2119,2120],{"class":482},"a5669202-7765-4f59-b6f0-b9f40ce71599",[473,2122,2016],{"class":596},[473,2124,674],{"class":596},[473,2126,2127,2129,2132,2134,2136,2138,2140,2143,2145,2147,2150,2152,2154,2157,2159,2161,2164],{"class":475,"line":724},[473,2128,2010],{"class":596},[473,2130,2131],{"class":628},"cart",[473,2133,2016],{"class":596},[473,2135,657],{"class":596},[473,2137,597],{"class":596},[473,2139,2021],{"class":596},[473,2141,2142],{"class":479},"items",[473,2144,2016],{"class":596},[473,2146,657],{"class":596},[473,2148,2149],{"class":2081}," 3",[473,2151,644],{"class":596},[473,2153,2021],{"class":596},[473,2155,2156],{"class":479},"total",[473,2158,2016],{"class":596},[473,2160,657],{"class":596},[473,2162,2163],{"class":2081}," 9999",[473,2165,2166],{"class":596}," }\n",[473,2168,2169],{"class":475,"line":754},[473,2170,1862],{"class":596},[463,2172,2175],{"className":1996,"code":2173,"filename":2174,"language":1006,"meta":469,"style":469},"{\n  \"level\": \"info\",\n  \"method\": \"POST\",\n  \"path\": \"\u002Fapi\u002Fcheckout\",\n  \"status\": 200,\n  \"duration\": \"120ms\",\n  \"requestId\": \"a5669202-7765-4f59-b6f0-b9f40ce71599\",\n  \"userId\": \"QBX9tPjJQExWawAbNll75\",\n  \"user\": {\n    \"id\": \"QBX9tPjJQExWawAbNll75\",\n    \"name\": \"Hugo Richard\",\n    \"email\": \"hugo@example.com\",\n    \"emailVerified\": true,\n    \"createdAt\": \"2024-01-15T10:00:00.000Z\"\n  },\n  \"session\": {\n    \"id\": \"Xhmh6TxKJQrVKFX0Y0II\",\n    \"expiresAt\": \"2024-01-22T10:00:00.000Z\",\n    \"ipAddress\": \"192.168.1.42\",\n    \"userAgent\": \"Mozilla\u002F5.0 (Macintosh; Intel Mac OS X 10_15_7)\",\n    \"createdAt\": \"2024-01-15T10:00:00.000Z\"\n  },\n  \"auth\": {\n    \"resolvedIn\": 12,\n    \"identified\": true\n  },\n  \"cart\": { \"items\": 3, \"total\": 9999 }\n}\n","After — identified",[417,2176,2177,2181,2199,2217,2235,2249,2267,2285,2305,2318,2338,2358,2378,2392,2411,2417,2431,2451,2472,2493,2514,2531,2536,2550,2567,2582,2587,2624],{"__ignoreMap":469},[473,2178,2179],{"class":475,"line":476},[473,2180,2005],{"class":596},[473,2182,2183,2185,2187,2189,2191,2193,2195,2197],{"class":475,"line":618},[473,2184,2010],{"class":596},[473,2186,2013],{"class":628},[473,2188,2016],{"class":596},[473,2190,657],{"class":596},[473,2192,2021],{"class":596},[473,2194,2024],{"class":482},[473,2196,2016],{"class":596},[473,2198,674],{"class":596},[473,2200,2201,2203,2205,2207,2209,2211,2213,2215],{"class":475,"line":625},[473,2202,2010],{"class":596},[473,2204,2035],{"class":628},[473,2206,2016],{"class":596},[473,2208,657],{"class":596},[473,2210,2021],{"class":596},[473,2212,2044],{"class":482},[473,2214,2016],{"class":596},[473,2216,674],{"class":596},[473,2218,2219,2221,2223,2225,2227,2229,2231,2233],{"class":475,"line":650},[473,2220,2010],{"class":596},[473,2222,791],{"class":628},[473,2224,2016],{"class":596},[473,2226,657],{"class":596},[473,2228,2021],{"class":596},[473,2230,2063],{"class":482},[473,2232,2016],{"class":596},[473,2234,674],{"class":596},[473,2236,2237,2239,2241,2243,2245,2247],{"class":475,"line":677},[473,2238,2010],{"class":596},[473,2240,2074],{"class":628},[473,2242,2016],{"class":596},[473,2244,657],{"class":596},[473,2246,2082],{"class":2081},[473,2248,674],{"class":596},[473,2250,2251,2253,2255,2257,2259,2261,2263,2265],{"class":475,"line":686},[473,2252,2010],{"class":596},[473,2254,2091],{"class":628},[473,2256,2016],{"class":596},[473,2258,657],{"class":596},[473,2260,2021],{"class":596},[473,2262,2100],{"class":482},[473,2264,2016],{"class":596},[473,2266,674],{"class":596},[473,2268,2269,2271,2273,2275,2277,2279,2281,2283],{"class":475,"line":691},[473,2270,2010],{"class":596},[473,2272,2111],{"class":628},[473,2274,2016],{"class":596},[473,2276,657],{"class":596},[473,2278,2021],{"class":596},[473,2280,2120],{"class":482},[473,2282,2016],{"class":596},[473,2284,674],{"class":596},[473,2286,2287,2289,2292,2294,2296,2298,2301,2303],{"class":475,"line":724},[473,2288,2010],{"class":596},[473,2290,2291],{"class":628},"userId",[473,2293,2016],{"class":596},[473,2295,657],{"class":596},[473,2297,2021],{"class":596},[473,2299,2300],{"class":482},"QBX9tPjJQExWawAbNll75",[473,2302,2016],{"class":596},[473,2304,674],{"class":596},[473,2306,2307,2309,2312,2314,2316],{"class":475,"line":754},[473,2308,2010],{"class":596},[473,2310,2311],{"class":628},"user",[473,2313,2016],{"class":596},[473,2315,657],{"class":596},[473,2317,647],{"class":596},[473,2319,2320,2323,2326,2328,2330,2332,2334,2336],{"class":475,"line":796},[473,2321,2322],{"class":596},"    \"",[473,2324,2325],{"class":479},"id",[473,2327,2016],{"class":596},[473,2329,657],{"class":596},[473,2331,2021],{"class":596},[473,2333,2300],{"class":482},[473,2335,2016],{"class":596},[473,2337,674],{"class":596},[473,2339,2340,2342,2345,2347,2349,2351,2354,2356],{"class":475,"line":995},[473,2341,2322],{"class":596},[473,2343,2344],{"class":479},"name",[473,2346,2016],{"class":596},[473,2348,657],{"class":596},[473,2350,2021],{"class":596},[473,2352,2353],{"class":482},"Hugo Richard",[473,2355,2016],{"class":596},[473,2357,674],{"class":596},[473,2359,2360,2362,2365,2367,2369,2371,2374,2376],{"class":475,"line":1026},[473,2361,2322],{"class":596},[473,2363,2364],{"class":479},"email",[473,2366,2016],{"class":596},[473,2368,657],{"class":596},[473,2370,2021],{"class":596},[473,2372,2373],{"class":482},"hugo@example.com",[473,2375,2016],{"class":596},[473,2377,674],{"class":596},[473,2379,2380,2382,2385,2387,2389],{"class":475,"line":1853},[473,2381,2322],{"class":596},[473,2383,2384],{"class":479},"emailVerified",[473,2386,2016],{"class":596},[473,2388,657],{"class":596},[473,2390,2391],{"class":596}," true,\n",[473,2393,2394,2396,2399,2401,2403,2405,2408],{"class":475,"line":1859},[473,2395,2322],{"class":596},[473,2397,2398],{"class":479},"createdAt",[473,2400,2016],{"class":596},[473,2402,657],{"class":596},[473,2404,2021],{"class":596},[473,2406,2407],{"class":482},"2024-01-15T10:00:00.000Z",[473,2409,2410],{"class":596},"\"\n",[473,2412,2414],{"class":475,"line":2413},15,[473,2415,2416],{"class":596},"  },\n",[473,2418,2420,2422,2425,2427,2429],{"class":475,"line":2419},16,[473,2421,2010],{"class":596},[473,2423,2424],{"class":628},"session",[473,2426,2016],{"class":596},[473,2428,657],{"class":596},[473,2430,647],{"class":596},[473,2432,2434,2436,2438,2440,2442,2444,2447,2449],{"class":475,"line":2433},17,[473,2435,2322],{"class":596},[473,2437,2325],{"class":479},[473,2439,2016],{"class":596},[473,2441,657],{"class":596},[473,2443,2021],{"class":596},[473,2445,2446],{"class":482},"Xhmh6TxKJQrVKFX0Y0II",[473,2448,2016],{"class":596},[473,2450,674],{"class":596},[473,2452,2454,2456,2459,2461,2463,2465,2468,2470],{"class":475,"line":2453},18,[473,2455,2322],{"class":596},[473,2457,2458],{"class":479},"expiresAt",[473,2460,2016],{"class":596},[473,2462,657],{"class":596},[473,2464,2021],{"class":596},[473,2466,2467],{"class":482},"2024-01-22T10:00:00.000Z",[473,2469,2016],{"class":596},[473,2471,674],{"class":596},[473,2473,2475,2477,2480,2482,2484,2486,2489,2491],{"class":475,"line":2474},19,[473,2476,2322],{"class":596},[473,2478,2479],{"class":479},"ipAddress",[473,2481,2016],{"class":596},[473,2483,657],{"class":596},[473,2485,2021],{"class":596},[473,2487,2488],{"class":482},"192.168.1.42",[473,2490,2016],{"class":596},[473,2492,674],{"class":596},[473,2494,2496,2498,2501,2503,2505,2507,2510,2512],{"class":475,"line":2495},20,[473,2497,2322],{"class":596},[473,2499,2500],{"class":479},"userAgent",[473,2502,2016],{"class":596},[473,2504,657],{"class":596},[473,2506,2021],{"class":596},[473,2508,2509],{"class":482},"Mozilla\u002F5.0 (Macintosh; Intel Mac OS X 10_15_7)",[473,2511,2016],{"class":596},[473,2513,674],{"class":596},[473,2515,2517,2519,2521,2523,2525,2527,2529],{"class":475,"line":2516},21,[473,2518,2322],{"class":596},[473,2520,2398],{"class":479},[473,2522,2016],{"class":596},[473,2524,657],{"class":596},[473,2526,2021],{"class":596},[473,2528,2407],{"class":482},[473,2530,2410],{"class":596},[473,2532,2534],{"class":475,"line":2533},22,[473,2535,2416],{"class":596},[473,2537,2539,2541,2544,2546,2548],{"class":475,"line":2538},23,[473,2540,2010],{"class":596},[473,2542,2543],{"class":628},"auth",[473,2545,2016],{"class":596},[473,2547,657],{"class":596},[473,2549,647],{"class":596},[473,2551,2553,2555,2558,2560,2562,2565],{"class":475,"line":2552},24,[473,2554,2322],{"class":596},[473,2556,2557],{"class":479},"resolvedIn",[473,2559,2016],{"class":596},[473,2561,657],{"class":596},[473,2563,2564],{"class":2081}," 12",[473,2566,674],{"class":596},[473,2568,2570,2572,2575,2577,2579],{"class":475,"line":2569},25,[473,2571,2322],{"class":596},[473,2573,2574],{"class":479},"identified",[473,2576,2016],{"class":596},[473,2578,657],{"class":596},[473,2580,2581],{"class":596}," true\n",[473,2583,2585],{"class":475,"line":2584},26,[473,2586,2416],{"class":596},[473,2588,2590,2592,2594,2596,2598,2600,2602,2604,2606,2608,2610,2612,2614,2616,2618,2620,2622],{"class":475,"line":2589},27,[473,2591,2010],{"class":596},[473,2593,2131],{"class":628},[473,2595,2016],{"class":596},[473,2597,657],{"class":596},[473,2599,597],{"class":596},[473,2601,2021],{"class":596},[473,2603,2142],{"class":479},[473,2605,2016],{"class":596},[473,2607,657],{"class":596},[473,2609,2149],{"class":2081},[473,2611,644],{"class":596},[473,2613,2021],{"class":596},[473,2615,2156],{"class":479},[473,2617,2016],{"class":596},[473,2619,657],{"class":596},[473,2621,2163],{"class":2081},[473,2623,2166],{"class":596},[473,2625,2627],{"class":475,"line":2626},28,[473,2628,1862],{"class":596},[426,2630,2632],{"id":2631},"how-it-works","How It Works",[2634,2635],"better-auth-identify",{},[414,2637,2638,2639,2642,2643,2646,2647,2650],{},"The integration resolves the Better Auth session from request cookies, extracts a safe whitelist of user and session fields, sets them on the logger, then fires the ",[417,2640,2641],{},"onIdentify"," (or ",[417,2644,2645],{},"onAnonymous",") hook. Auth routes are skipped by default. Resolution timing is captured on ",[417,2648,2649],{},"auth.resolvedIn",", so you can chart auth latency alongside the rest of the wide event.",[426,2652,2654],{"id":2653},"where-to-next","Where to next",[2656,2657,2658,2662,2673,2680],"card-group",{},[2659,2660,2661],"card",{"icon":112,"title":109,"to":110},"The core building block — extract safe fields, mask emails, capture plugin data (organizations, roles, 2FA).",[2659,2663,2664,2665,2668,2669,2672],{"icon":117,"title":114,"to":115},"Filter routes with ",[417,2666,2667],{},"include","\u002F",[417,2670,2671],{},"exclude",", react to identification with lifecycle hooks, and tune behaviour per app.",[2659,2674,2675,2676,2679],{"icon":69,"title":119,"to":120},"Mirror the user identity into client-side logs with ",[417,2677,2678],{},"setIdentity"," and the Better Auth client.",[2659,2681,2682],{"icon":126,"title":123,"to":124},"Watch session resolution time, enable session caching, and combine with the AI SDK integration.",[426,2684,2686],{"id":2685},"public-api","Public API",[2688,2689,2690,2703],"table",{},[2691,2692,2693],"thead",{},[2694,2695,2696,2700],"tr",{},[2697,2698,2699],"th",{},"Export",[2697,2701,2702],{},"Description",[2704,2705,2706,2721,2735,2751],"tbody",{},[2694,2707,2708,2714],{},[2709,2710,2711],"td",{},[417,2712,2713],{},"identifyUser(log, session)",[2709,2715,2716,2717,2720],{},"Core helper — extracts safe fields from a session and sets them on the logger. Returns ",[417,2718,2719],{},"true"," if identified.",[2694,2722,2723,2728],{},[2709,2724,2725],{},[417,2726,2727],{},"createAuthMiddleware(auth)",[2709,2729,2730,2731,2734],{},"Returns an async ",[417,2732,2733],{},"(log, headers, path?) => Promise\u003Cboolean>"," function with route filtering, timing, and hooks.",[2694,2736,2737,2742],{},[2709,2738,2739],{},[417,2740,2741],{},"createAuthIdentifier(auth)",[2709,2743,2744,2745,2747,2748,737],{},"Nitro ",[417,2746,913],{}," hook factory for standalone Nitro apps. See ",[434,2749,123],{"href":2750},"\u002Flogging\u002Fbetter-auth\u002Fperformance#standalone-nitro",[2694,2752,2753,2758],{},[2709,2754,2755],{},[417,2756,2757],{},"maskEmail(email)",[2709,2759,2760,2761,2763,2764,737],{},"Mask an email: ",[417,2762,2373],{}," → ",[417,2765,2766],{},"h***@example.com",[2768,2769,2770],"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 .spNyl, html code.shiki .spNyl{--shiki-light:#9C3EDA;--shiki-default:#C792EA;--shiki-dark:#C792EA}html pre.shiki code .s2Zo4, html code.shiki .s2Zo4{--shiki-light:#6182B8;--shiki-default:#82AAFF;--shiki-dark:#82AAFF}html pre.shiki code .swJcz, html code.shiki .swJcz{--shiki-light:#E53935;--shiki-default:#F07178;--shiki-dark:#F07178}html pre.shiki code .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 .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":469,"searchDepth":618,"depth":618,"links":2772},[2773,2774,2775,2776,2777],{"id":428,"depth":618,"text":429},{"id":574,"depth":618,"text":20},{"id":2631,"depth":618,"text":2632},{"id":2653,"depth":618,"text":2654},{"id":2685,"depth":618,"text":2686},"Automatically identify users on every request. Every wide event includes who made the request — userId, user profile, and session metadata — with zero manual work.","md",[2781,2784,2785,2786],{"label":109,"icon":112,"to":110,"color":2782,"variant":2783},"neutral","subtle",{"label":114,"icon":117,"to":115,"color":2782,"variant":2783},{"label":119,"icon":69,"to":120,"color":2782,"variant":2783},{"label":123,"icon":126,"to":124,"color":2782,"variant":2783},{},{"title":41,"icon":44},{"title":409,"description":2778},"fNlaxqdbthr0UcMrZ4EfVuU28oXl2XfDl-gpLrTrS88",[2792,2794],{"title":95,"path":96,"stem":97,"description":2793,"icon":98,"children":-1},"Add tool execution timing and total wall time with createEvlogIntegration. Compose with other middleware like supermemory or guardrails.",{"title":109,"path":110,"stem":111,"description":2795,"icon":112,"children":-1},"The core building block — extract safe user fields, mask emails, and capture plugin data (organizations, roles, 2FA) from a Better Auth session.",1778327038434]