[{"data":1,"prerenderedAt":1528},["ShallowReactive",2],{"navigation_docs":3,"-use-cases-better-auth-identify-user":439,"-use-cases-better-auth-identify-user-surround":1523},[4,30,80,245,353,408],{"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,157],{"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,152],{"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,"icon":156},"Memory","\u002Fintegrate\u002Fadapters\u002Fself-hosted\u002Fmemory","3.integrate\u002Fadapters\u002Fself-hosted\u002F03.memory","i-lucide-cpu",{"title":158,"path":159,"stem":160,"children":161,"page":29},"Frameworks","\u002Fintegrate\u002Fframeworks","3.integrate\u002Fframeworks",[162,166,171,176,181,186,191,196,201,206,211,216,221,226,230,235,240],{"title":36,"path":163,"stem":164,"icon":165},"\u002Fintegrate\u002Fframeworks\u002Foverview","3.integrate\u002Fframeworks\u002F00.overview","i-lucide-layout-grid",{"title":167,"path":168,"stem":169,"icon":170},"Nuxt","\u002Fintegrate\u002Fframeworks\u002Fnuxt","3.integrate\u002Fframeworks\u002F01.nuxt","i-simple-icons-nuxtdotjs",{"title":172,"path":173,"stem":174,"icon":175},"Next.js","\u002Fintegrate\u002Fframeworks\u002Fnextjs","3.integrate\u002Fframeworks\u002F02.nextjs","i-simple-icons-nextdotjs",{"title":177,"path":178,"stem":179,"icon":180},"SvelteKit","\u002Fintegrate\u002Fframeworks\u002Fsveltekit","3.integrate\u002Fframeworks\u002F03.sveltekit","i-simple-icons-svelte",{"title":182,"path":183,"stem":184,"icon":185},"Nitro","\u002Fintegrate\u002Fframeworks\u002Fnitro","3.integrate\u002Fframeworks\u002F04.nitro","i-custom-nitro",{"title":187,"path":188,"stem":189,"icon":190},"TanStack Start","\u002Fintegrate\u002Fframeworks\u002Ftanstack-start","3.integrate\u002Fframeworks\u002F05.tanstack-start","i-custom-tanstack",{"title":192,"path":193,"stem":194,"icon":195},"NestJS","\u002Fintegrate\u002Fframeworks\u002Fnestjs","3.integrate\u002Fframeworks\u002F06.nestjs","i-simple-icons-nestjs",{"title":197,"path":198,"stem":199,"icon":200},"Express","\u002Fintegrate\u002Fframeworks\u002Fexpress","3.integrate\u002Fframeworks\u002F07.express","i-simple-icons-express",{"title":202,"path":203,"stem":204,"icon":205},"Hono","\u002Fintegrate\u002Fframeworks\u002Fhono","3.integrate\u002Fframeworks\u002F08.hono","i-simple-icons-hono",{"title":207,"path":208,"stem":209,"icon":210},"Fastify","\u002Fintegrate\u002Fframeworks\u002Ffastify","3.integrate\u002Fframeworks\u002F09.fastify","i-simple-icons-fastify",{"title":212,"path":213,"stem":214,"icon":215},"Elysia","\u002Fintegrate\u002Fframeworks\u002Felysia","3.integrate\u002Fframeworks\u002F10.elysia","i-custom-elysia",{"title":217,"path":218,"stem":219,"icon":220},"React Router","\u002Fintegrate\u002Fframeworks\u002Freact-router","3.integrate\u002Fframeworks\u002F11.react-router","i-custom-reactrouter",{"title":222,"path":223,"stem":224,"icon":225},"Cloudflare Workers","\u002Fintegrate\u002Fframeworks\u002Fcloudflare-workers","3.integrate\u002Fframeworks\u002F12.cloudflare-workers","i-simple-icons-cloudflare",{"title":227,"path":228,"stem":229,"icon":74},"Standalone","\u002Fintegrate\u002Fframeworks\u002Fstandalone","3.integrate\u002Fframeworks\u002F13.standalone",{"title":231,"path":232,"stem":233,"icon":234},"Astro","\u002Fintegrate\u002Fframeworks\u002Fastro","3.integrate\u002Fframeworks\u002F14.astro","i-simple-icons-astro",{"title":236,"path":237,"stem":238,"icon":239},"oRPC","\u002Fintegrate\u002Fframeworks\u002Forpc","3.integrate\u002Fframeworks\u002F15.orpc","i-lucide-network",{"title":241,"path":242,"stem":243,"icon":244},"AWS Lambda","\u002Fintegrate\u002Fframeworks\u002Faws-lambda","3.integrate\u002Fframeworks\u002F16.aws-lambda","i-custom-lambda",{"title":246,"path":247,"stem":248,"children":249,"page":29},"Use Cases","\u002Fuse-cases","4.use-cases",[250,254,259,288,316,348],{"title":36,"path":251,"stem":252,"icon":253},"\u002Fuse-cases\u002Foverview","4.use-cases\u002F0.overview","i-lucide-list-checks",{"title":255,"path":256,"stem":257,"icon":258},"Client Logging","\u002Fuse-cases\u002Fclient-logging","4.use-cases\u002F1.client-logging","i-lucide-monitor",{"title":260,"icon":261,"path":262,"stem":263,"children":264,"page":29},"AI SDK","i-simple-icons-vercel","\u002Fuse-cases\u002Fai-sdk","4.use-cases\u002F2.ai-sdk",[265,268,273,278,283],{"title":36,"path":266,"stem":267,"icon":39},"\u002Fuse-cases\u002Fai-sdk\u002Foverview","4.use-cases\u002F2.ai-sdk\u002F01.overview",{"title":269,"path":270,"stem":271,"icon":272},"Usage","\u002Fuse-cases\u002Fai-sdk\u002Fusage","4.use-cases\u002F2.ai-sdk\u002F02.usage","i-lucide-code",{"title":274,"path":275,"stem":276,"icon":277},"Options","\u002Fuse-cases\u002Fai-sdk\u002Foptions","4.use-cases\u002F2.ai-sdk\u002F03.options","i-lucide-sliders",{"title":279,"path":280,"stem":281,"icon":282},"Metadata","\u002Fuse-cases\u002Fai-sdk\u002Fmetadata","4.use-cases\u002F2.ai-sdk\u002F04.metadata","i-lucide-database",{"title":284,"path":285,"stem":286,"icon":287},"Telemetry","\u002Fuse-cases\u002Fai-sdk\u002Ftelemetry","4.use-cases\u002F2.ai-sdk\u002F05.telemetry","i-lucide-activity",{"title":289,"icon":290,"path":291,"stem":292,"children":293,"page":29},"Better Auth","i-simple-icons-betterauth","\u002Fuse-cases\u002Fbetter-auth","4.use-cases\u002F3.better-auth",[294,297,302,307,311],{"title":36,"path":295,"stem":296,"icon":39},"\u002Fuse-cases\u002Fbetter-auth\u002Foverview","4.use-cases\u002F3.better-auth\u002F01.overview",{"title":298,"path":299,"stem":300,"icon":301},"Identify User","\u002Fuse-cases\u002Fbetter-auth\u002Fidentify-user","4.use-cases\u002F3.better-auth\u002F02.identify-user","i-lucide-user-check",{"title":303,"path":304,"stem":305,"icon":306},"Middleware","\u002Fuse-cases\u002Fbetter-auth\u002Fmiddleware","4.use-cases\u002F3.better-auth\u002F03.middleware","i-lucide-shield",{"title":308,"path":309,"stem":310,"icon":258},"Client Sync","\u002Fuse-cases\u002Fbetter-auth\u002Fclient-sync","4.use-cases\u002F3.better-auth\u002F04.client-sync",{"title":312,"path":313,"stem":314,"icon":315},"Performance","\u002Fuse-cases\u002Fbetter-auth\u002Fperformance","4.use-cases\u002F3.better-auth\u002F05.performance","i-lucide-gauge",{"title":317,"icon":318,"path":319,"stem":320,"children":321,"page":29},"Audit Logs","i-lucide-shield-check","\u002Fuse-cases\u002Faudit","4.use-cases\u002F4.audit",[322,325,330,335,340,344],{"title":36,"path":323,"stem":324,"icon":39},"\u002Fuse-cases\u002Faudit\u002Foverview","4.use-cases\u002F4.audit\u002F01.overview",{"title":326,"path":327,"stem":328,"icon":329},"Schema","\u002Fuse-cases\u002Faudit\u002Fschema","4.use-cases\u002F4.audit\u002F02.schema","i-lucide-file-text",{"title":331,"path":332,"stem":333,"icon":334},"Recording","\u002Fuse-cases\u002Faudit\u002Frecording","4.use-cases\u002F4.audit\u002F03.recording","i-lucide-pen-line",{"title":336,"path":337,"stem":338,"icon":339},"Drains","\u002Fuse-cases\u002Faudit\u002Fpipeline","4.use-cases\u002F4.audit\u002F04.pipeline","i-lucide-link",{"title":341,"path":342,"stem":343,"icon":318},"Compliance","\u002Fuse-cases\u002Faudit\u002Fcompliance","4.use-cases\u002F4.audit\u002F05.compliance",{"title":345,"path":346,"stem":347,"icon":79},"Recipes","\u002Fuse-cases\u002Faudit\u002Frecipes","4.use-cases\u002F4.audit\u002F06.recipes",{"title":349,"path":350,"stem":351,"icon":352},"Enrichers","\u002Fuse-cases\u002Fenrichers","4.use-cases\u002F5.enrichers","i-lucide-sparkles",{"title":354,"path":355,"stem":356,"children":357,"page":29},"Extend","\u002Fextend","5.extend",[358,362,367,372,377,381,385,389,393,398,403],{"title":36,"path":359,"stem":360,"icon":361},"\u002Fextend\u002Foverview","5.extend\u002F0.overview","i-lucide-blocks",{"title":363,"path":364,"stem":365,"icon":366},"Stream","\u002Fextend\u002Fstream","5.extend\u002F1.stream","i-lucide-radio-tower",{"title":368,"path":369,"stem":370,"icon":371},"Custom framework","\u002Fextend\u002Fcustom-framework","5.extend\u002F10.custom-framework","i-lucide-puzzle",{"title":373,"path":374,"stem":375,"icon":376},"FS reader","\u002Fextend\u002Ffs-reader","5.extend\u002F2.fs-reader","i-lucide-folder-search",{"title":345,"path":378,"stem":379,"icon":380},"\u002Fextend\u002Fconsumer-recipes","5.extend\u002F3.consumer-recipes","i-lucide-chef-hat",{"title":382,"path":383,"stem":384,"icon":361},"Plugins","\u002Fextend\u002Fplugins","5.extend\u002F4.plugins",{"title":386,"path":387,"stem":388,"icon":352},"Custom enrichers","\u002Fextend\u002Fcustom-enrichers","5.extend\u002F5.custom-enrichers",{"title":390,"path":391,"stem":392,"icon":64},"Tail sampling","\u002Fextend\u002Ftail-sampling","5.extend\u002F6.tail-sampling",{"title":394,"path":395,"stem":396,"icon":397},"Identity headers","\u002Fextend\u002Fidentity-headers","5.extend\u002F7.identity-headers","i-lucide-fingerprint",{"title":399,"path":400,"stem":401,"icon":402},"Custom drains","\u002Fextend\u002Fcustom-drains","5.extend\u002F8.custom-drains","i-lucide-share-2",{"title":404,"path":405,"stem":406,"icon":407},"Drain pipeline","\u002Fextend\u002Fdrain-pipeline","5.extend\u002F9.drain-pipeline","i-lucide-workflow",{"title":409,"path":410,"stem":411,"children":412,"page":29},"Reference","\u002Freference","6.reference",[413,418,421,426,430,435],{"title":414,"path":415,"stem":416,"icon":417},"Configuration","\u002Freference\u002Fconfiguration","6.reference\u002F1.configuration","i-lucide-settings",{"title":312,"path":419,"stem":420,"icon":315},"\u002Freference\u002Fperformance","6.reference\u002F2.performance",{"title":422,"path":423,"stem":424,"icon":425},"Vite Plugin","\u002Freference\u002Fvite-plugin","6.reference\u002F3.vite-plugin","i-custom-vite",{"title":427,"path":428,"stem":429,"icon":318},"Best Practices","\u002Freference\u002Fbest-practices","6.reference\u002F4.best-practices",{"title":431,"path":432,"stem":433,"icon":434},"vs Other Loggers","\u002Freference\u002Fvs-other-loggers","6.reference\u002F5.vs-other-loggers","i-lucide-scale",{"title":436,"path":437,"stem":438,"icon":352},"Agent Skills","\u002Freference\u002Fagent-skills","6.reference\u002F6.agent-skills",{"id":440,"title":441,"body":442,"description":1512,"extension":1513,"links":1514,"meta":1519,"navigation":1520,"path":299,"seo":1521,"stem":300,"__hash__":1522},"docs\u002F4.use-cases\u002F3.better-auth\u002F02.identify-user.md","identifyUser",{"type":443,"value":444,"toc":1506},"minimark",[445,468,676,684,688,808,892,896,899,929,935,981,985,991,1116,1119,1270,1276,1280,1502],[446,447,448,451,452,455,456,459,460,463,464,467],"p",{},[449,450,441],"code",{}," is the core building block. Take a ",[449,453,454],{},"RequestLogger"," and a Better Auth session, extract safe fields, and call ",[449,457,458],{},"log.set()",". Returns ",[449,461,462],{},"true"," if the user was identified, ",[449,465,466],{},"false"," otherwise.",[469,470,476],"pre",{"className":471,"code":472,"filename":473,"language":474,"meta":475,"style":475},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import { identifyUser } from 'evlog\u002Fbetter-auth'\n\nconst session = await auth.api.getSession({ headers: event.headers })\nif (session) {\n  const identified = identifyUser(log, session)\n  if (identified) {\n    log.set({ subscription: 'premium' })\n  }\n}\n","server\u002Fapi\u002Fcheckout.post.ts","typescript","",[449,477,478,511,518,576,588,615,632,664,670],{"__ignoreMap":475},[479,480,483,487,491,495,498,501,504,508],"span",{"class":481,"line":482},"line",1,[479,484,486],{"class":485},"s7zQu","import",[479,488,490],{"class":489},"sMK4o"," {",[479,492,494],{"class":493},"sTEyZ"," identifyUser",[479,496,497],{"class":489}," }",[479,499,500],{"class":485}," from",[479,502,503],{"class":489}," '",[479,505,507],{"class":506},"sfazB","evlog\u002Fbetter-auth",[479,509,510],{"class":489},"'\n",[479,512,514],{"class":481,"line":513},2,[479,515,517],{"emptyLinePlaceholder":516},true,"\n",[479,519,521,525,528,531,534,537,540,543,545,549,552,555,559,562,565,567,570,573],{"class":481,"line":520},3,[479,522,524],{"class":523},"spNyl","const",[479,526,527],{"class":493}," session ",[479,529,530],{"class":489},"=",[479,532,533],{"class":485}," await",[479,535,536],{"class":493}," auth",[479,538,539],{"class":489},".",[479,541,542],{"class":493},"api",[479,544,539],{"class":489},[479,546,548],{"class":547},"s2Zo4","getSession",[479,550,551],{"class":493},"(",[479,553,554],{"class":489},"{",[479,556,558],{"class":557},"swJcz"," headers",[479,560,561],{"class":489},":",[479,563,564],{"class":493}," event",[479,566,539],{"class":489},[479,568,569],{"class":493},"headers ",[479,571,572],{"class":489},"}",[479,574,575],{"class":493},")\n",[479,577,579,582,585],{"class":481,"line":578},4,[479,580,581],{"class":485},"if",[479,583,584],{"class":493}," (session) ",[479,586,587],{"class":489},"{\n",[479,589,591,594,597,600,602,604,607,610,613],{"class":481,"line":590},5,[479,592,593],{"class":523},"  const",[479,595,596],{"class":493}," identified",[479,598,599],{"class":489}," =",[479,601,494],{"class":547},[479,603,551],{"class":557},[479,605,606],{"class":493},"log",[479,608,609],{"class":489},",",[479,611,612],{"class":493}," session",[479,614,575],{"class":557},[479,616,618,621,624,627,630],{"class":481,"line":617},6,[479,619,620],{"class":485},"  if",[479,622,623],{"class":557}," (",[479,625,626],{"class":493},"identified",[479,628,629],{"class":557},") ",[479,631,587],{"class":489},[479,633,635,638,640,643,645,647,650,652,654,657,660,662],{"class":481,"line":634},7,[479,636,637],{"class":493},"    log",[479,639,539],{"class":489},[479,641,642],{"class":547},"set",[479,644,551],{"class":557},[479,646,554],{"class":489},[479,648,649],{"class":557}," subscription",[479,651,561],{"class":489},[479,653,503],{"class":489},[479,655,656],{"class":506},"premium",[479,658,659],{"class":489},"'",[479,661,497],{"class":489},[479,663,575],{"class":557},[479,665,667],{"class":481,"line":666},8,[479,668,669],{"class":489},"  }\n",[479,671,673],{"class":481,"line":672},9,[479,674,675],{"class":489},"}\n",[677,678,679,683],"tip",{},[680,681,682],"strong",{},"Safe by default."," Only whitelisted fields are extracted — passwords, tokens, and secrets are never written to the logger.",[685,686,274],"h2",{"id":687},"options",[689,690,691,710],"table",{},[692,693,694],"thead",{},[695,696,697,701,704,707],"tr",{},[698,699,700],"th",{},"Option",[698,702,703],{},"Type",[698,705,706],{},"Default",[698,708,709],{},"Description",[711,712,713,736,768,788],"tbody",{},[695,714,715,721,726,730],{},[716,717,718],"td",{},[449,719,720],{},"maskEmail",[716,722,723],{},[449,724,725],{},"boolean",[716,727,728],{},[449,729,466],{},[716,731,732,733,539],{},"Mask emails as ",[449,734,735],{},"h***@example.com",[695,737,738,743,747,751],{},[716,739,740],{},[449,741,742],{},"session",[716,744,745],{},[449,746,725],{},[716,748,749],{},[449,750,462],{},[716,752,753,754,757,758,757,761,757,764,767],{},"Include session metadata (",[449,755,756],{},"session.id",", ",[449,759,760],{},"session.expiresAt",[449,762,763],{},"session.ipAddress",[449,765,766],{},"session.userAgent",").",[695,769,770,775,780,785],{},[716,771,772],{},[449,773,774],{},"fields",[716,776,777],{},[449,778,779],{},"string[]",[716,781,782],{},[449,783,784],{},"['id', 'name', 'email', 'image', 'emailVerified', 'createdAt']",[716,786,787],{},"User fields to extract.",[695,789,790,795,800,805],{},[716,791,792],{},[449,793,794],{},"extend",[716,796,797],{},[449,798,799],{},"(session) => Record\u003Cstring, unknown>",[716,801,802],{},[449,803,804],{},"undefined",[716,806,807],{},"Add custom fields from Better Auth plugins (organizations, roles, etc.).",[469,809,811],{"className":471,"code":810,"filename":473,"language":474,"meta":475,"style":475},"identifyUser(log, session, {\n  maskEmail: true,\n  fields: ['id', 'name'],\n  session: false,\n})\n",[449,812,813,829,843,874,886],{"__ignoreMap":475},[479,814,815,817,820,822,824,826],{"class":481,"line":482},[479,816,441],{"class":547},[479,818,819],{"class":493},"(log",[479,821,609],{"class":489},[479,823,612],{"class":493},[479,825,609],{"class":489},[479,827,828],{"class":489}," {\n",[479,830,831,834,836,840],{"class":481,"line":513},[479,832,833],{"class":557},"  maskEmail",[479,835,561],{"class":489},[479,837,839],{"class":838},"sfNiH"," true",[479,841,842],{"class":489},",\n",[479,844,845,848,850,853,855,858,860,862,864,867,869,872],{"class":481,"line":520},[479,846,847],{"class":557},"  fields",[479,849,561],{"class":489},[479,851,852],{"class":493}," [",[479,854,659],{"class":489},[479,856,857],{"class":506},"id",[479,859,659],{"class":489},[479,861,609],{"class":489},[479,863,503],{"class":489},[479,865,866],{"class":506},"name",[479,868,659],{"class":489},[479,870,871],{"class":493},"]",[479,873,842],{"class":489},[479,875,876,879,881,884],{"class":481,"line":578},[479,877,878],{"class":557},"  session",[479,880,561],{"class":489},[479,882,883],{"class":838}," false",[479,885,842],{"class":489},[479,887,888,890],{"class":481,"line":590},[479,889,572],{"class":489},[479,891,575],{"class":493},[685,893,895],{"id":894},"mask-emails","Mask emails",[446,897,898],{},"Emails are PII. In environments where the audit\u002Flog trail might be reviewed by support or third parties, mask them:",[469,900,902],{"className":471,"code":901,"language":474,"meta":475,"style":475},"identifyUser(log, session, { maskEmail: true })\n",[449,903,904],{"__ignoreMap":475},[479,905,906,908,910,912,914,916,918,921,923,925,927],{"class":481,"line":482},[479,907,441],{"class":547},[479,909,819],{"class":493},[479,911,609],{"class":489},[479,913,612],{"class":493},[479,915,609],{"class":489},[479,917,490],{"class":489},[479,919,920],{"class":557}," maskEmail",[479,922,561],{"class":489},[479,924,839],{"class":838},[479,926,497],{"class":489},[479,928,575],{"class":493},[446,930,931,932,934],{},"The ",[449,933,720],{}," helper is also exported on its own:",[469,936,938],{"className":471,"code":937,"language":474,"meta":475,"style":475},"import { maskEmail } from 'evlog\u002Fbetter-auth'\n\nmaskEmail('hugo@example.com') \u002F\u002F 'h***@example.com'\n",[449,939,940,958,962],{"__ignoreMap":475},[479,941,942,944,946,948,950,952,954,956],{"class":481,"line":482},[479,943,486],{"class":485},[479,945,490],{"class":489},[479,947,920],{"class":493},[479,949,497],{"class":489},[479,951,500],{"class":485},[479,953,503],{"class":489},[479,955,507],{"class":506},[479,957,510],{"class":489},[479,959,960],{"class":481,"line":513},[479,961,517],{"emptyLinePlaceholder":516},[479,963,964,966,968,970,973,975,977],{"class":481,"line":520},[479,965,720],{"class":547},[479,967,551],{"class":493},[479,969,659],{"class":489},[479,971,972],{"class":506},"hugo@example.com",[479,974,659],{"class":489},[479,976,629],{"class":493},[479,978,980],{"class":979},"sHwdD","\u002F\u002F 'h***@example.com'\n",[685,982,984],{"id":983},"capture-plugin-fields","Capture plugin fields",[446,986,987,988,990],{},"Better Auth ships with plugins (organizations, 2FA, roles, admin) that add fields to the session. Use ",[449,989,794],{}," to surface them on the wide event:",[469,992,995],{"className":471,"code":993,"filename":994,"language":474,"meta":475,"style":475},"import { createAuthMiddleware } from 'evlog\u002Fbetter-auth'\n\nconst identify = createAuthMiddleware(auth, {\n  extend: (session) => ({\n    organization: session.user.activeOrganization,\n    role: session.user.role,\n  }),\n})\n","server\u002Fmiddleware\u002Fauth-identify.ts",[449,996,997,1016,1020,1038,1060,1081,1101,1110],{"__ignoreMap":475},[479,998,999,1001,1003,1006,1008,1010,1012,1014],{"class":481,"line":482},[479,1000,486],{"class":485},[479,1002,490],{"class":489},[479,1004,1005],{"class":493}," createAuthMiddleware",[479,1007,497],{"class":489},[479,1009,500],{"class":485},[479,1011,503],{"class":489},[479,1013,507],{"class":506},[479,1015,510],{"class":489},[479,1017,1018],{"class":481,"line":513},[479,1019,517],{"emptyLinePlaceholder":516},[479,1021,1022,1024,1027,1029,1031,1034,1036],{"class":481,"line":520},[479,1023,524],{"class":523},[479,1025,1026],{"class":493}," identify ",[479,1028,530],{"class":489},[479,1030,1005],{"class":547},[479,1032,1033],{"class":493},"(auth",[479,1035,609],{"class":489},[479,1037,828],{"class":489},[479,1039,1040,1043,1045,1047,1050,1053,1056,1058],{"class":481,"line":578},[479,1041,1042],{"class":547},"  extend",[479,1044,561],{"class":489},[479,1046,623],{"class":489},[479,1048,742],{"class":1049},"sHdIc",[479,1051,1052],{"class":489},")",[479,1054,1055],{"class":523}," =>",[479,1057,623],{"class":493},[479,1059,587],{"class":489},[479,1061,1062,1065,1067,1069,1071,1074,1076,1079],{"class":481,"line":590},[479,1063,1064],{"class":557},"    organization",[479,1066,561],{"class":489},[479,1068,612],{"class":493},[479,1070,539],{"class":489},[479,1072,1073],{"class":493},"user",[479,1075,539],{"class":489},[479,1077,1078],{"class":493},"activeOrganization",[479,1080,842],{"class":489},[479,1082,1083,1086,1088,1090,1092,1094,1096,1099],{"class":481,"line":617},[479,1084,1085],{"class":557},"    role",[479,1087,561],{"class":489},[479,1089,612],{"class":493},[479,1091,539],{"class":489},[479,1093,1073],{"class":493},[479,1095,539],{"class":489},[479,1097,1098],{"class":493},"role",[479,1100,842],{"class":489},[479,1102,1103,1106,1108],{"class":481,"line":634},[479,1104,1105],{"class":489},"  }",[479,1107,1052],{"class":493},[479,1109,842],{"class":489},[479,1111,1112,1114],{"class":481,"line":666},[479,1113,572],{"class":489},[479,1115,575],{"class":493},[446,1117,1118],{},"Wide event with plugin fields:",[469,1120,1125],{"className":1121,"code":1122,"filename":1123,"language":1124,"meta":475,"style":475},"language-json shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","{\n  \"userId\": \"QBX9tPjJQExWawAbNll75\",\n  \"user\": { \"id\": \"QBX9tPjJQExWawAbNll75\", \"name\": \"Hugo Richard\" },\n  \"organization\": { \"id\": \"org_42\", \"name\": \"Acme\" },\n  \"role\": \"admin\"\n}\n","Wide Event","json",[449,1126,1127,1131,1154,1201,1248,1266],{"__ignoreMap":475},[479,1128,1129],{"class":481,"line":482},[479,1130,587],{"class":489},[479,1132,1133,1136,1139,1142,1144,1147,1150,1152],{"class":481,"line":513},[479,1134,1135],{"class":489},"  \"",[479,1137,1138],{"class":523},"userId",[479,1140,1141],{"class":489},"\"",[479,1143,561],{"class":489},[479,1145,1146],{"class":489}," \"",[479,1148,1149],{"class":506},"QBX9tPjJQExWawAbNll75",[479,1151,1141],{"class":489},[479,1153,842],{"class":489},[479,1155,1156,1158,1160,1162,1164,1166,1168,1171,1173,1175,1177,1179,1181,1183,1185,1187,1189,1191,1193,1196,1198],{"class":481,"line":520},[479,1157,1135],{"class":489},[479,1159,1073],{"class":523},[479,1161,1141],{"class":489},[479,1163,561],{"class":489},[479,1165,490],{"class":489},[479,1167,1146],{"class":489},[479,1169,857],{"class":1170},"sBMFI",[479,1172,1141],{"class":489},[479,1174,561],{"class":489},[479,1176,1146],{"class":489},[479,1178,1149],{"class":506},[479,1180,1141],{"class":489},[479,1182,609],{"class":489},[479,1184,1146],{"class":489},[479,1186,866],{"class":1170},[479,1188,1141],{"class":489},[479,1190,561],{"class":489},[479,1192,1146],{"class":489},[479,1194,1195],{"class":506},"Hugo Richard",[479,1197,1141],{"class":489},[479,1199,1200],{"class":489}," },\n",[479,1202,1203,1205,1208,1210,1212,1214,1216,1218,1220,1222,1224,1227,1229,1231,1233,1235,1237,1239,1241,1244,1246],{"class":481,"line":578},[479,1204,1135],{"class":489},[479,1206,1207],{"class":523},"organization",[479,1209,1141],{"class":489},[479,1211,561],{"class":489},[479,1213,490],{"class":489},[479,1215,1146],{"class":489},[479,1217,857],{"class":1170},[479,1219,1141],{"class":489},[479,1221,561],{"class":489},[479,1223,1146],{"class":489},[479,1225,1226],{"class":506},"org_42",[479,1228,1141],{"class":489},[479,1230,609],{"class":489},[479,1232,1146],{"class":489},[479,1234,866],{"class":1170},[479,1236,1141],{"class":489},[479,1238,561],{"class":489},[479,1240,1146],{"class":489},[479,1242,1243],{"class":506},"Acme",[479,1245,1141],{"class":489},[479,1247,1200],{"class":489},[479,1249,1250,1252,1254,1256,1258,1260,1263],{"class":481,"line":590},[479,1251,1135],{"class":489},[479,1253,1098],{"class":523},[479,1255,1141],{"class":489},[479,1257,561],{"class":489},[479,1259,1146],{"class":489},[479,1261,1262],{"class":506},"admin",[479,1264,1265],{"class":489},"\"\n",[479,1267,1268],{"class":481,"line":617},[479,1269,675],{"class":489},[677,1271,1272,1273,1275],{},"Keep ",[449,1274,794],{}," deterministic — it runs on every request. Avoid heavy computations or extra database calls inside it; query the data Better Auth already loaded into the session.",[685,1277,1279],{"id":1278},"captured-fields","Captured fields",[689,1281,1282,1294],{},[692,1283,1284],{},[695,1285,1286,1289,1292],{},[698,1287,1288],{},"Field",[698,1290,1291],{},"Source",[698,1293,709],{},[711,1295,1296,1313,1327,1342,1360,1375,1390,1405,1419,1433,1447,1461,1476,1489],{},[695,1297,1298,1302,1307],{},[716,1299,1300],{},[449,1301,1138],{},[716,1303,1304],{},[449,1305,1306],{},"session.user.id",[716,1308,1309,1310,767],{},"Top-level user ID (used by PostHog adapter as ",[449,1311,1312],{},"distinct_id",[695,1314,1315,1320,1324],{},[716,1316,1317],{},[449,1318,1319],{},"user.id",[716,1321,1322],{},[449,1323,1306],{},[716,1325,1326],{},"User ID.",[695,1328,1329,1334,1339],{},[716,1330,1331],{},[449,1332,1333],{},"user.name",[716,1335,1336],{},[449,1337,1338],{},"session.user.name",[716,1340,1341],{},"Display name.",[695,1343,1344,1349,1354],{},[716,1345,1346],{},[449,1347,1348],{},"user.email",[716,1350,1351],{},[449,1352,1353],{},"session.user.email",[716,1355,1356,1357,767],{},"Email (maskable with ",[449,1358,1359],{},"maskEmail: true",[695,1361,1362,1367,1372],{},[716,1363,1364],{},[449,1365,1366],{},"user.image",[716,1368,1369],{},[449,1370,1371],{},"session.user.image",[716,1373,1374],{},"Avatar URL.",[695,1376,1377,1382,1387],{},[716,1378,1379],{},[449,1380,1381],{},"user.emailVerified",[716,1383,1384],{},[449,1385,1386],{},"session.user.emailVerified",[716,1388,1389],{},"Email verification status.",[695,1391,1392,1397,1402],{},[716,1393,1394],{},[449,1395,1396],{},"user.createdAt",[716,1398,1399],{},[449,1400,1401],{},"session.user.createdAt",[716,1403,1404],{},"Account creation date (ISO string).",[695,1406,1407,1411,1416],{},[716,1408,1409],{},[449,1410,756],{},[716,1412,1413],{},[449,1414,1415],{},"session.session.id",[716,1417,1418],{},"Session ID.",[695,1420,1421,1425,1430],{},[716,1422,1423],{},[449,1424,760],{},[716,1426,1427],{},[449,1428,1429],{},"session.session.expiresAt",[716,1431,1432],{},"Session expiry (ISO string).",[695,1434,1435,1439,1444],{},[716,1436,1437],{},[449,1438,763],{},[716,1440,1441],{},[449,1442,1443],{},"session.session.ipAddress",[716,1445,1446],{},"Client IP from the session.",[695,1448,1449,1453,1458],{},[716,1450,1451],{},[449,1452,766],{},[716,1454,1455],{},[449,1456,1457],{},"session.session.userAgent",[716,1459,1460],{},"User agent string from the session.",[695,1462,1463,1468,1473],{},[716,1464,1465],{},[449,1466,1467],{},"session.createdAt",[716,1469,1470],{},[449,1471,1472],{},"session.session.createdAt",[716,1474,1475],{},"Session creation date (ISO string).",[695,1477,1478,1483,1486],{},[716,1479,1480],{},[449,1481,1482],{},"auth.resolvedIn",[716,1484,1485],{},"Measured",[716,1487,1488],{},"Session resolution time in ms.",[695,1490,1491,1496,1499],{},[716,1492,1493],{},[449,1494,1495],{},"auth.identified",[716,1497,1498],{},"Computed",[716,1500,1501],{},"Whether the request was identified.",[1503,1504,1505],"style",{},"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 .sfazB, html code.shiki .sfazB{--shiki-light:#91B859;--shiki-default:#C3E88D;--shiki-dark:#C3E88D}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 .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 .sfNiH, html code.shiki .sfNiH{--shiki-light:#FF5370;--shiki-default:#FF9CAC;--shiki-dark:#FF9CAC}html pre.shiki code .sHwdD, html code.shiki .sHwdD{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#546E7A;--shiki-default-font-style:italic;--shiki-dark:#676E95;--shiki-dark-font-style:italic}html pre.shiki code .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 .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}",{"title":475,"searchDepth":513,"depth":513,"links":1507},[1508,1509,1510,1511],{"id":687,"depth":513,"text":274},{"id":894,"depth":513,"text":895},{"id":983,"depth":513,"text":984},{"id":1278,"depth":513,"text":1279},"The core building block — extract safe user fields, mask emails, and capture plugin data (organizations, roles, 2FA) from a Better Auth session.","md",[1515,1518],{"label":36,"icon":39,"to":295,"color":1516,"variant":1517},"neutral","subtle",{"label":303,"icon":306,"to":304,"color":1516,"variant":1517},{},{"title":298,"icon":301},{"title":441,"description":1512},"ktB0zgEcuDV1SnUMSWV1NGf9G4g5y_0GbwN1ACQNQfk",[1524,1526],{"title":36,"path":295,"stem":296,"description":1525,"icon":39,"children":-1},"Automatically identify users on every request. Every wide event includes who made the request — userId, user profile, and session metadata — with zero manual work.",{"title":303,"path":304,"stem":305,"description":1527,"icon":306,"children":-1},"Framework-agnostic factory with route filtering, session timing, and lifecycle hooks. Call it once at startup and reuse across requests.",1779694502862]