[{"data":1,"prerenderedAt":1322},["ShallowReactive",2],{"navigation_docs":3,"-logging-better-auth-client-sync":388,"-logging-better-auth-client-sync-surround":1317},[4,35,155,197,285,372],{"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,94,122],{"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},"Client Logging","\u002Flogging\u002Fclient-logging","2.logging\u002F4.client-logging","i-lucide-monitor",{"title":66,"icon":67,"path":68,"stem":69,"children":70,"page":34},"AI SDK","i-simple-icons-vercel","\u002Flogging\u002Fai-sdk","2.logging\u002F5.ai-sdk",[71,74,79,84,89],{"title":41,"path":72,"stem":73,"icon":44},"\u002Flogging\u002Fai-sdk\u002Foverview","2.logging\u002F5.ai-sdk\u002F01.overview",{"title":75,"path":76,"stem":77,"icon":78},"Usage","\u002Flogging\u002Fai-sdk\u002Fusage","2.logging\u002F5.ai-sdk\u002F02.usage","i-lucide-code",{"title":80,"path":81,"stem":82,"icon":83},"Options","\u002Flogging\u002Fai-sdk\u002Foptions","2.logging\u002F5.ai-sdk\u002F03.options","i-lucide-sliders",{"title":85,"path":86,"stem":87,"icon":88},"Metadata","\u002Flogging\u002Fai-sdk\u002Fmetadata","2.logging\u002F5.ai-sdk\u002F04.metadata","i-lucide-database",{"title":90,"path":91,"stem":92,"icon":93},"Telemetry","\u002Flogging\u002Fai-sdk\u002Ftelemetry","2.logging\u002F5.ai-sdk\u002F05.telemetry","i-lucide-activity",{"title":95,"icon":96,"path":97,"stem":98,"children":99,"page":34},"Better Auth","i-simple-icons-betterauth","\u002Flogging\u002Fbetter-auth","2.logging\u002F6.better-auth",[100,103,108,113,117],{"title":41,"path":101,"stem":102,"icon":44},"\u002Flogging\u002Fbetter-auth\u002Foverview","2.logging\u002F6.better-auth\u002F01.overview",{"title":104,"path":105,"stem":106,"icon":107},"Identify User","\u002Flogging\u002Fbetter-auth\u002Fidentify-user","2.logging\u002F6.better-auth\u002F02.identify-user","i-lucide-user-check",{"title":109,"path":110,"stem":111,"icon":112},"Middleware","\u002Flogging\u002Fbetter-auth\u002Fmiddleware","2.logging\u002F6.better-auth\u002F03.middleware","i-lucide-shield",{"title":114,"path":115,"stem":116,"icon":64},"Client Sync","\u002Flogging\u002Fbetter-auth\u002Fclient-sync","2.logging\u002F6.better-auth\u002F04.client-sync",{"title":118,"path":119,"stem":120,"icon":121},"Performance","\u002Flogging\u002Fbetter-auth\u002Fperformance","2.logging\u002F6.better-auth\u002F05.performance","i-lucide-gauge",{"title":123,"icon":124,"path":125,"stem":126,"children":127,"page":34},"Audit Logs","i-lucide-shield-check","\u002Flogging\u002Faudit","2.logging\u002F7.audit",[128,131,136,141,146,150],{"title":41,"path":129,"stem":130,"icon":44},"\u002Flogging\u002Faudit\u002Foverview","2.logging\u002F7.audit\u002F01.overview",{"title":132,"path":133,"stem":134,"icon":135},"Schema","\u002Flogging\u002Faudit\u002Fschema","2.logging\u002F7.audit\u002F02.schema","i-lucide-file-text",{"title":137,"path":138,"stem":139,"icon":140},"Recording","\u002Flogging\u002Faudit\u002Frecording","2.logging\u002F7.audit\u002F03.recording","i-lucide-pen-line",{"title":142,"path":143,"stem":144,"icon":145},"Drains","\u002Flogging\u002Faudit\u002Fpipeline","2.logging\u002F7.audit\u002F04.pipeline","i-lucide-link",{"title":147,"path":148,"stem":149,"icon":124},"Compliance","\u002Flogging\u002Faudit\u002Fcompliance","2.logging\u002F7.audit\u002F05.compliance",{"title":151,"path":152,"stem":153,"icon":154},"Recipes","\u002Flogging\u002Faudit\u002Frecipes","2.logging\u002F7.audit\u002F06.recipes","i-lucide-book-open",{"title":156,"path":157,"stem":158,"children":159,"page":34},"Core Concepts","\u002Fcore-concepts","3.core-concepts",[160,165,170,175,180,184,187,192],{"title":161,"path":162,"stem":163,"icon":164},"Lifecycle","\u002Fcore-concepts\u002Flifecycle","3.core-concepts\u002F0.lifecycle","i-lucide-arrow-right-left",{"title":166,"path":167,"stem":168,"icon":169},"Configuration","\u002Fcore-concepts\u002Fconfiguration","3.core-concepts\u002F1.configuration","i-lucide-settings",{"title":171,"path":172,"stem":173,"icon":174},"Sampling","\u002Fcore-concepts\u002Fsampling","3.core-concepts\u002F2.sampling","i-lucide-filter",{"title":176,"path":177,"stem":178,"icon":179},"Typed Fields","\u002Fcore-concepts\u002Ftyped-fields","3.core-concepts\u002F3.typed-fields","i-simple-icons-typescript",{"title":181,"path":182,"stem":183,"icon":124},"Best Practices","\u002Fcore-concepts\u002Fbest-practices","3.core-concepts\u002F4.best-practices",{"title":118,"path":185,"stem":186,"icon":121},"\u002Fcore-concepts\u002Fperformance","3.core-concepts\u002F5.performance",{"title":188,"path":189,"stem":190,"icon":191},"Vite Plugin","\u002Fcore-concepts\u002Fvite-plugin","3.core-concepts\u002F6.vite-plugin","i-custom-vite",{"title":193,"path":194,"stem":195,"icon":196},"Auto-Redaction","\u002Fcore-concepts\u002Fredaction","3.core-concepts\u002F7.redaction","i-lucide-eye-off",{"title":198,"path":199,"stem":200,"children":201,"page":34},"Frameworks","\u002Fframeworks","4.frameworks",[202,206,211,216,221,226,231,236,241,246,251,256,261,266,270,275,280],{"title":41,"path":203,"stem":204,"icon":205},"\u002Fframeworks\u002Foverview","4.frameworks\u002F00.overview","i-lucide-layout-grid",{"title":207,"path":208,"stem":209,"icon":210},"Nuxt","\u002Fframeworks\u002Fnuxt","4.frameworks\u002F01.nuxt","i-simple-icons-nuxtdotjs",{"title":212,"path":213,"stem":214,"icon":215},"Next.js","\u002Fframeworks\u002Fnextjs","4.frameworks\u002F02.nextjs","i-simple-icons-nextdotjs",{"title":217,"path":218,"stem":219,"icon":220},"SvelteKit","\u002Fframeworks\u002Fsveltekit","4.frameworks\u002F03.sveltekit","i-simple-icons-svelte",{"title":222,"path":223,"stem":224,"icon":225},"Nitro","\u002Fframeworks\u002Fnitro","4.frameworks\u002F04.nitro","i-custom-nitro",{"title":227,"path":228,"stem":229,"icon":230},"TanStack Start","\u002Fframeworks\u002Ftanstack-start","4.frameworks\u002F05.tanstack-start","i-custom-tanstack",{"title":232,"path":233,"stem":234,"icon":235},"NestJS","\u002Fframeworks\u002Fnestjs","4.frameworks\u002F06.nestjs","i-simple-icons-nestjs",{"title":237,"path":238,"stem":239,"icon":240},"Express","\u002Fframeworks\u002Fexpress","4.frameworks\u002F07.express","i-simple-icons-express",{"title":242,"path":243,"stem":244,"icon":245},"Hono","\u002Fframeworks\u002Fhono","4.frameworks\u002F08.hono","i-simple-icons-hono",{"title":247,"path":248,"stem":249,"icon":250},"Fastify","\u002Fframeworks\u002Ffastify","4.frameworks\u002F09.fastify","i-simple-icons-fastify",{"title":252,"path":253,"stem":254,"icon":255},"Elysia","\u002Fframeworks\u002Felysia","4.frameworks\u002F10.elysia","i-custom-elysia",{"title":257,"path":258,"stem":259,"icon":260},"React Router","\u002Fframeworks\u002Freact-router","4.frameworks\u002F11.react-router","i-custom-reactrouter",{"title":262,"path":263,"stem":264,"icon":265},"Cloudflare Workers","\u002Fframeworks\u002Fcloudflare-workers","4.frameworks\u002F12.cloudflare-workers","i-simple-icons-cloudflare",{"title":267,"path":268,"stem":269,"icon":179},"Standalone","\u002Fframeworks\u002Fstandalone","4.frameworks\u002F13.standalone",{"title":271,"path":272,"stem":273,"icon":274},"Astro","\u002Fframeworks\u002Fastro","4.frameworks\u002F14.astro","i-simple-icons-astro",{"title":276,"path":277,"stem":278,"icon":279},"AWS Lambda","\u002Fframeworks\u002Faws-lambda","4.frameworks\u002F16.aws-lambda","i-custom-lambda",{"title":281,"path":282,"stem":283,"icon":284},"Custom Integration","\u002Fframeworks\u002Fcustom-integration","4.frameworks\u002F17.custom-integration","i-lucide-puzzle",{"title":286,"path":287,"stem":288,"children":289,"page":34},"Adapters","\u002Fadapters","6.adapters",[290,293,333,348],{"title":41,"path":291,"stem":292,"icon":44},"\u002Fadapters\u002Foverview","6.adapters\u002F01.overview",{"title":294,"path":295,"stem":296,"children":297,"page":34},"Cloud destinations","\u002Fadapters\u002Fcloud","6.adapters\u002F02.cloud",[298,303,308,313,318,323,328],{"title":299,"path":300,"stem":301,"icon":302},"Axiom","\u002Fadapters\u002Fcloud\u002Faxiom","6.adapters\u002F02.cloud\u002F01.axiom","i-custom-axiom",{"title":304,"path":305,"stem":306,"icon":307},"OTLP","\u002Fadapters\u002Fcloud\u002Fotlp","6.adapters\u002F02.cloud\u002F02.otlp","i-simple-icons-opentelemetry",{"title":309,"path":310,"stem":311,"icon":312},"PostHog","\u002Fadapters\u002Fcloud\u002Fposthog","6.adapters\u002F02.cloud\u002F03.posthog","i-simple-icons-posthog",{"title":314,"path":315,"stem":316,"icon":317},"Sentry","\u002Fadapters\u002Fcloud\u002Fsentry","6.adapters\u002F02.cloud\u002F04.sentry","i-simple-icons-sentry",{"title":319,"path":320,"stem":321,"icon":322},"Better Stack","\u002Fadapters\u002Fcloud\u002Fbetter-stack","6.adapters\u002F02.cloud\u002F05.better-stack","i-simple-icons-betterstack",{"title":324,"path":325,"stem":326,"icon":327},"Datadog","\u002Fadapters\u002Fcloud\u002Fdatadog","6.adapters\u002F02.cloud\u002F06.datadog","i-simple-icons-datadog",{"title":329,"path":330,"stem":331,"icon":332},"HyperDX","\u002Fadapters\u002Fcloud\u002Fhyperdx","6.adapters\u002F02.cloud\u002F07.hyperdx","i-custom-hyperdx",{"title":334,"path":335,"stem":336,"children":337,"page":34},"Self-hosted","\u002Fadapters\u002Fself-hosted","6.adapters\u002F03.self-hosted",[338,343],{"title":339,"path":340,"stem":341,"icon":342},"File System","\u002Fadapters\u002Fself-hosted\u002Ffs","6.adapters\u002F03.self-hosted\u002F01.fs","i-lucide-hard-drive",{"title":344,"path":345,"stem":346,"icon":347},"NuxtHub","\u002Fadapters\u002Fself-hosted\u002Fnuxthub","6.adapters\u002F03.self-hosted\u002F02.nuxthub","i-simple-icons-nuxt",{"title":349,"path":350,"stem":351,"children":352,"page":34},"Building blocks","\u002Fadapters\u002Fbuilding-blocks","6.adapters\u002F04.building-blocks",[353,358,363,367],{"title":354,"path":355,"stem":356,"icon":357},"Pipeline","\u002Fadapters\u002Fbuilding-blocks\u002Fpipeline","6.adapters\u002F04.building-blocks\u002F01.pipeline","i-lucide-workflow",{"title":359,"path":360,"stem":361,"icon":362},"HTTP","\u002Fadapters\u002Fbuilding-blocks\u002Fhttp","6.adapters\u002F04.building-blocks\u002F02.http","i-lucide-globe",{"title":364,"path":365,"stem":366,"icon":78},"Custom Adapters","\u002Fadapters\u002Fbuilding-blocks\u002Fcustom","6.adapters\u002F04.building-blocks\u002F03.custom",{"title":368,"path":369,"stem":370,"icon":371},"Toolkit","\u002Fadapters\u002Fbuilding-blocks\u002Ftoolkit","6.adapters\u002F04.building-blocks\u002F04.toolkit","i-lucide-blocks",{"title":373,"path":374,"stem":375,"children":376,"page":34},"Enrichers","\u002Fenrichers","7.enrichers",[377,380,384],{"title":41,"path":378,"stem":379,"icon":28},"\u002Fenrichers\u002Foverview","7.enrichers\u002F1.overview",{"title":381,"path":382,"stem":383,"icon":284},"Built-in","\u002Fenrichers\u002Fbuilt-in","7.enrichers\u002F2.built-in",{"title":385,"path":386,"stem":387,"icon":78},"Custom","\u002Fenrichers\u002Fcustom","7.enrichers\u002F3.custom",{"id":389,"title":390,"body":391,"description":1305,"extension":1306,"links":1307,"meta":1313,"navigation":1314,"path":115,"seo":1315,"stem":116,"__hash__":1316},"docs\u002F2.logging\u002F6.better-auth\u002F04.client-sync.md","Client Identity Sync",{"type":392,"value":393,"toc":1299},"minimark",[394,403,408,668,671,709,713,940,947,951,1146,1153,1157,1160,1279,1295],[395,396,397,398,402],"p",{},"The middleware identifies users on the server. To get the same identity on ",[399,400,401],"strong",{},"client-side logs"," (clicks, navigation, errors caught in the browser), watch the Better Auth session and forward the user to evlog's client identity store.",[404,405,407],"h2",{"id":406},"vue-nuxt","Vue \u002F Nuxt",[409,410,416],"pre",{"className":411,"code":412,"filename":413,"language":414,"meta":415,"style":415},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import { authClient } from '~\u002Flib\u002Fauth-client'\n\nexport function useAuthIdentity() {\n  const session = authClient.useSession()\n\n  watch(() => session.value?.data?.user, (user) => {\n    if (user) {\n      setIdentity({ userId: user.id, userName: user.name })\n    } else {\n      clearIdentity()\n    }\n  }, { immediate: true })\n}\n","composables\u002FuseAuthIdentity.ts","typescript","",[417,418,419,452,459,479,503,508,556,572,616,627,635,641,662],"code",{"__ignoreMap":415},[420,421,424,428,432,436,439,442,445,449],"span",{"class":422,"line":423},"line",1,[420,425,427],{"class":426},"s7zQu","import",[420,429,431],{"class":430},"sMK4o"," {",[420,433,435],{"class":434},"sTEyZ"," authClient",[420,437,438],{"class":430}," }",[420,440,441],{"class":426}," from",[420,443,444],{"class":430}," '",[420,446,448],{"class":447},"sfazB","~\u002Flib\u002Fauth-client",[420,450,451],{"class":430},"'\n",[420,453,455],{"class":422,"line":454},2,[420,456,458],{"emptyLinePlaceholder":457},true,"\n",[420,460,462,465,469,473,476],{"class":422,"line":461},3,[420,463,464],{"class":426},"export",[420,466,468],{"class":467},"spNyl"," function",[420,470,472],{"class":471},"s2Zo4"," useAuthIdentity",[420,474,475],{"class":430},"()",[420,477,478],{"class":430}," {\n",[420,480,482,485,488,491,493,496,499],{"class":422,"line":481},4,[420,483,484],{"class":467},"  const",[420,486,487],{"class":434}," session",[420,489,490],{"class":430}," =",[420,492,435],{"class":434},[420,494,495],{"class":430},".",[420,497,498],{"class":471},"useSession",[420,500,502],{"class":501},"swJcz","()\n",[420,504,506],{"class":422,"line":505},5,[420,507,458],{"emptyLinePlaceholder":457},[420,509,511,514,517,519,522,524,526,529,532,535,537,540,543,546,549,552,554],{"class":422,"line":510},6,[420,512,513],{"class":471},"  watch",[420,515,516],{"class":501},"(",[420,518,475],{"class":430},[420,520,521],{"class":467}," =>",[420,523,487],{"class":434},[420,525,495],{"class":430},[420,527,528],{"class":434},"value",[420,530,531],{"class":430},"?.",[420,533,534],{"class":434},"data",[420,536,531],{"class":430},[420,538,539],{"class":434},"user",[420,541,542],{"class":430},",",[420,544,545],{"class":430}," (",[420,547,539],{"class":548},"sHdIc",[420,550,551],{"class":430},")",[420,553,521],{"class":467},[420,555,478],{"class":430},[420,557,559,562,564,566,569],{"class":422,"line":558},7,[420,560,561],{"class":426},"    if",[420,563,545],{"class":501},[420,565,539],{"class":434},[420,567,568],{"class":501},") ",[420,570,571],{"class":430},"{\n",[420,573,575,578,580,583,586,589,592,594,597,599,602,604,606,608,611,613],{"class":422,"line":574},8,[420,576,577],{"class":471},"      setIdentity",[420,579,516],{"class":501},[420,581,582],{"class":430},"{",[420,584,585],{"class":501}," userId",[420,587,588],{"class":430},":",[420,590,591],{"class":434}," user",[420,593,495],{"class":430},[420,595,596],{"class":434},"id",[420,598,542],{"class":430},[420,600,601],{"class":501}," userName",[420,603,588],{"class":430},[420,605,591],{"class":434},[420,607,495],{"class":430},[420,609,610],{"class":434},"name",[420,612,438],{"class":430},[420,614,615],{"class":501},")\n",[420,617,619,622,625],{"class":422,"line":618},9,[420,620,621],{"class":430},"    }",[420,623,624],{"class":426}," else",[420,626,478],{"class":430},[420,628,630,633],{"class":422,"line":629},10,[420,631,632],{"class":471},"      clearIdentity",[420,634,502],{"class":501},[420,636,638],{"class":422,"line":637},11,[420,639,640],{"class":430},"    }\n",[420,642,644,647,649,652,654,658,660],{"class":422,"line":643},12,[420,645,646],{"class":430},"  },",[420,648,431],{"class":430},[420,650,651],{"class":501}," immediate",[420,653,588],{"class":430},[420,655,657],{"class":656},"sfNiH"," true",[420,659,438],{"class":430},[420,661,615],{"class":501},[420,663,665],{"class":422,"line":664},13,[420,666,667],{"class":430},"}\n",[395,669,670],{},"Call it once in your root layout:",[409,672,677],{"className":673,"code":674,"filename":675,"language":676,"meta":415,"style":415},"language-vue shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","\u003Cscript setup>\nuseAuthIdentity()\n\u003C\u002Fscript>\n","app.vue","vue",[417,678,679,693,700],{"__ignoreMap":415},[420,680,681,684,687,690],{"class":422,"line":423},[420,682,683],{"class":430},"\u003C",[420,685,686],{"class":501},"script",[420,688,689],{"class":467}," setup",[420,691,692],{"class":430},">\n",[420,694,695,698],{"class":422,"line":454},[420,696,697],{"class":471},"useAuthIdentity",[420,699,502],{"class":434},[420,701,702,705,707],{"class":422,"line":461},[420,703,704],{"class":430},"\u003C\u002F",[420,706,686],{"class":501},[420,708,692],{"class":430},[404,710,712],{"id":711},"react","React",[409,714,719],{"className":715,"code":716,"filename":717,"language":718,"meta":415,"style":415},"language-tsx shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import { useEffect } from 'react'\nimport { setIdentity, clearIdentity } from 'evlog\u002Fhttp'\nimport { authClient } from '@\u002Flib\u002Fauth-client'\n\nexport function useAuthIdentity() {\n  const { data } = authClient.useSession()\n\n  useEffect(() => {\n    if (data?.user) {\n      setIdentity({ userId: data.user.id, userName: data.user.name })\n    } else {\n      clearIdentity()\n    }\n  }, [data?.user?.id])\n}\n","hooks\u002FuseAuthIdentity.tsx","tsx",[417,720,721,740,765,784,788,800,821,825,838,854,896,904,910,914,935],{"__ignoreMap":415},[420,722,723,725,727,730,732,734,736,738],{"class":422,"line":423},[420,724,427],{"class":426},[420,726,431],{"class":430},[420,728,729],{"class":434}," useEffect",[420,731,438],{"class":430},[420,733,441],{"class":426},[420,735,444],{"class":430},[420,737,711],{"class":447},[420,739,451],{"class":430},[420,741,742,744,746,749,751,754,756,758,760,763],{"class":422,"line":454},[420,743,427],{"class":426},[420,745,431],{"class":430},[420,747,748],{"class":434}," setIdentity",[420,750,542],{"class":430},[420,752,753],{"class":434}," clearIdentity",[420,755,438],{"class":430},[420,757,441],{"class":426},[420,759,444],{"class":430},[420,761,762],{"class":447},"evlog\u002Fhttp",[420,764,451],{"class":430},[420,766,767,769,771,773,775,777,779,782],{"class":422,"line":461},[420,768,427],{"class":426},[420,770,431],{"class":430},[420,772,435],{"class":434},[420,774,438],{"class":430},[420,776,441],{"class":426},[420,778,444],{"class":430},[420,780,781],{"class":447},"@\u002Flib\u002Fauth-client",[420,783,451],{"class":430},[420,785,786],{"class":422,"line":481},[420,787,458],{"emptyLinePlaceholder":457},[420,789,790,792,794,796,798],{"class":422,"line":505},[420,791,464],{"class":426},[420,793,468],{"class":467},[420,795,472],{"class":471},[420,797,475],{"class":430},[420,799,478],{"class":430},[420,801,802,804,806,809,811,813,815,817,819],{"class":422,"line":510},[420,803,484],{"class":467},[420,805,431],{"class":430},[420,807,808],{"class":434}," data",[420,810,438],{"class":430},[420,812,490],{"class":430},[420,814,435],{"class":434},[420,816,495],{"class":430},[420,818,498],{"class":471},[420,820,502],{"class":501},[420,822,823],{"class":422,"line":558},[420,824,458],{"emptyLinePlaceholder":457},[420,826,827,830,832,834,836],{"class":422,"line":574},[420,828,829],{"class":471},"  useEffect",[420,831,516],{"class":501},[420,833,475],{"class":430},[420,835,521],{"class":467},[420,837,478],{"class":430},[420,839,840,842,844,846,848,850,852],{"class":422,"line":618},[420,841,561],{"class":426},[420,843,545],{"class":501},[420,845,534],{"class":434},[420,847,531],{"class":430},[420,849,539],{"class":434},[420,851,568],{"class":501},[420,853,571],{"class":430},[420,855,856,858,860,862,864,866,868,870,872,874,876,878,880,882,884,886,888,890,892,894],{"class":422,"line":629},[420,857,577],{"class":471},[420,859,516],{"class":501},[420,861,582],{"class":430},[420,863,585],{"class":501},[420,865,588],{"class":430},[420,867,808],{"class":434},[420,869,495],{"class":430},[420,871,539],{"class":434},[420,873,495],{"class":430},[420,875,596],{"class":434},[420,877,542],{"class":430},[420,879,601],{"class":501},[420,881,588],{"class":430},[420,883,808],{"class":434},[420,885,495],{"class":430},[420,887,539],{"class":434},[420,889,495],{"class":430},[420,891,610],{"class":434},[420,893,438],{"class":430},[420,895,615],{"class":501},[420,897,898,900,902],{"class":422,"line":637},[420,899,621],{"class":430},[420,901,624],{"class":426},[420,903,478],{"class":430},[420,905,906,908],{"class":422,"line":643},[420,907,632],{"class":471},[420,909,502],{"class":501},[420,911,912],{"class":422,"line":664},[420,913,640],{"class":430},[420,915,917,919,922,924,926,928,930,932],{"class":422,"line":916},14,[420,918,646],{"class":430},[420,920,921],{"class":501}," [",[420,923,534],{"class":434},[420,925,531],{"class":430},[420,927,539],{"class":434},[420,929,531],{"class":430},[420,931,596],{"class":434},[420,933,934],{"class":501},"])\n",[420,936,938],{"class":422,"line":937},15,[420,939,667],{"class":430},[395,941,942,943,946],{},"Wire it up at the root of your app (in ",[417,944,945],{},"_app.tsx",", the root layout, or a top-level provider).",[404,948,950],{"id":949},"svelte","Svelte",[409,952,955],{"className":411,"code":953,"filename":954,"language":414,"meta":415,"style":415},"import { setIdentity, clearIdentity } from 'evlog\u002Fhttp'\nimport { authClient } from '$lib\u002Fauth-client'\n\nexport function setupAuthIdentity() {\n  const session = authClient.useSession()\n\n  session.subscribe(({ data }) => {\n    if (data?.user) {\n      setIdentity({ userId: data.user.id, userName: data.user.name })\n    } else {\n      clearIdentity()\n    }\n  })\n}\n","src\u002Flib\u002Fauth-identity.ts",[417,956,957,979,998,1002,1015,1031,1035,1059,1075,1117,1125,1131,1135,1142],{"__ignoreMap":415},[420,958,959,961,963,965,967,969,971,973,975,977],{"class":422,"line":423},[420,960,427],{"class":426},[420,962,431],{"class":430},[420,964,748],{"class":434},[420,966,542],{"class":430},[420,968,753],{"class":434},[420,970,438],{"class":430},[420,972,441],{"class":426},[420,974,444],{"class":430},[420,976,762],{"class":447},[420,978,451],{"class":430},[420,980,981,983,985,987,989,991,993,996],{"class":422,"line":454},[420,982,427],{"class":426},[420,984,431],{"class":430},[420,986,435],{"class":434},[420,988,438],{"class":430},[420,990,441],{"class":426},[420,992,444],{"class":430},[420,994,995],{"class":447},"$lib\u002Fauth-client",[420,997,451],{"class":430},[420,999,1000],{"class":422,"line":461},[420,1001,458],{"emptyLinePlaceholder":457},[420,1003,1004,1006,1008,1011,1013],{"class":422,"line":481},[420,1005,464],{"class":426},[420,1007,468],{"class":467},[420,1009,1010],{"class":471}," setupAuthIdentity",[420,1012,475],{"class":430},[420,1014,478],{"class":430},[420,1016,1017,1019,1021,1023,1025,1027,1029],{"class":422,"line":505},[420,1018,484],{"class":467},[420,1020,487],{"class":434},[420,1022,490],{"class":430},[420,1024,435],{"class":434},[420,1026,495],{"class":430},[420,1028,498],{"class":471},[420,1030,502],{"class":501},[420,1032,1033],{"class":422,"line":510},[420,1034,458],{"emptyLinePlaceholder":457},[420,1036,1037,1040,1042,1045,1047,1050,1052,1055,1057],{"class":422,"line":558},[420,1038,1039],{"class":434},"  session",[420,1041,495],{"class":430},[420,1043,1044],{"class":471},"subscribe",[420,1046,516],{"class":501},[420,1048,1049],{"class":430},"({",[420,1051,808],{"class":548},[420,1053,1054],{"class":430}," })",[420,1056,521],{"class":467},[420,1058,478],{"class":430},[420,1060,1061,1063,1065,1067,1069,1071,1073],{"class":422,"line":574},[420,1062,561],{"class":426},[420,1064,545],{"class":501},[420,1066,534],{"class":434},[420,1068,531],{"class":430},[420,1070,539],{"class":434},[420,1072,568],{"class":501},[420,1074,571],{"class":430},[420,1076,1077,1079,1081,1083,1085,1087,1089,1091,1093,1095,1097,1099,1101,1103,1105,1107,1109,1111,1113,1115],{"class":422,"line":618},[420,1078,577],{"class":471},[420,1080,516],{"class":501},[420,1082,582],{"class":430},[420,1084,585],{"class":501},[420,1086,588],{"class":430},[420,1088,808],{"class":434},[420,1090,495],{"class":430},[420,1092,539],{"class":434},[420,1094,495],{"class":430},[420,1096,596],{"class":434},[420,1098,542],{"class":430},[420,1100,601],{"class":501},[420,1102,588],{"class":430},[420,1104,808],{"class":434},[420,1106,495],{"class":430},[420,1108,539],{"class":434},[420,1110,495],{"class":430},[420,1112,610],{"class":434},[420,1114,438],{"class":430},[420,1116,615],{"class":501},[420,1118,1119,1121,1123],{"class":422,"line":629},[420,1120,621],{"class":430},[420,1122,624],{"class":426},[420,1124,478],{"class":430},[420,1126,1127,1129],{"class":422,"line":637},[420,1128,632],{"class":471},[420,1130,502],{"class":501},[420,1132,1133],{"class":422,"line":643},[420,1134,640],{"class":430},[420,1136,1137,1140],{"class":422,"line":664},[420,1138,1139],{"class":430},"  }",[420,1141,615],{"class":501},[420,1143,1144],{"class":422,"line":916},[420,1145,667],{"class":430},[395,1147,1148,1149,1152],{},"Run ",[417,1150,1151],{},"setupAuthIdentity()"," once when the app boots.",[404,1154,1156],{"id":1155},"output","Output",[395,1158,1159],{},"Client-side logs now include the user identity:",[409,1161,1166],{"className":1162,"code":1163,"filename":1164,"language":1165,"meta":415,"style":415},"language-json shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","{\n  \"level\": \"info\",\n  \"tag\": \"checkout\",\n  \"message\": \"User clicked checkout\",\n  \"userId\": \"QBX9tPjJQExWawAbNll75\",\n  \"userName\": \"Hugo Richard\"\n}\n","Client Log","json",[417,1167,1168,1172,1196,1216,1236,1256,1275],{"__ignoreMap":415},[420,1169,1170],{"class":422,"line":423},[420,1171,571],{"class":430},[420,1173,1174,1177,1180,1183,1185,1188,1191,1193],{"class":422,"line":454},[420,1175,1176],{"class":430},"  \"",[420,1178,1179],{"class":467},"level",[420,1181,1182],{"class":430},"\"",[420,1184,588],{"class":430},[420,1186,1187],{"class":430}," \"",[420,1189,1190],{"class":447},"info",[420,1192,1182],{"class":430},[420,1194,1195],{"class":430},",\n",[420,1197,1198,1200,1203,1205,1207,1209,1212,1214],{"class":422,"line":461},[420,1199,1176],{"class":430},[420,1201,1202],{"class":467},"tag",[420,1204,1182],{"class":430},[420,1206,588],{"class":430},[420,1208,1187],{"class":430},[420,1210,1211],{"class":447},"checkout",[420,1213,1182],{"class":430},[420,1215,1195],{"class":430},[420,1217,1218,1220,1223,1225,1227,1229,1232,1234],{"class":422,"line":481},[420,1219,1176],{"class":430},[420,1221,1222],{"class":467},"message",[420,1224,1182],{"class":430},[420,1226,588],{"class":430},[420,1228,1187],{"class":430},[420,1230,1231],{"class":447},"User clicked checkout",[420,1233,1182],{"class":430},[420,1235,1195],{"class":430},[420,1237,1238,1240,1243,1245,1247,1249,1252,1254],{"class":422,"line":505},[420,1239,1176],{"class":430},[420,1241,1242],{"class":467},"userId",[420,1244,1182],{"class":430},[420,1246,588],{"class":430},[420,1248,1187],{"class":430},[420,1250,1251],{"class":447},"QBX9tPjJQExWawAbNll75",[420,1253,1182],{"class":430},[420,1255,1195],{"class":430},[420,1257,1258,1260,1263,1265,1267,1269,1272],{"class":422,"line":510},[420,1259,1176],{"class":430},[420,1261,1262],{"class":467},"userName",[420,1264,1182],{"class":430},[420,1266,588],{"class":430},[420,1268,1187],{"class":430},[420,1270,1271],{"class":447},"Hugo Richard",[420,1273,1274],{"class":430},"\"\n",[420,1276,1277],{"class":422,"line":558},[420,1278,667],{"class":430},[1280,1281,1282,1285,1286,1290,1291,1294],"tip",{},[417,1283,1284],{},"setIdentity"," is part of evlog's ",[1287,1288,1289],"a",{"href":62},"client logging"," layer. The same fields are picked up by the HTTP transport when client logs are forwarded to your server, so a single user shows up identified across browser ",[399,1292,1293],{},"and"," API logs.",[1296,1297,1298],"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 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 .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);}",{"title":415,"searchDepth":454,"depth":454,"links":1300},[1301,1302,1303,1304],{"id":406,"depth":454,"text":407},{"id":711,"depth":454,"text":712},{"id":949,"depth":454,"text":950},{"id":1155,"depth":454,"text":1156},"Mirror the server-side user identity into client-side logs by watching the Better Auth session and calling setIdentity.","md",[1308,1311],{"label":41,"icon":44,"to":101,"color":1309,"variant":1310},"neutral","subtle",{"label":61,"icon":1312,"to":62,"color":1309,"variant":1310},"i-lucide-monitor-dot",{},{"title":114,"icon":64},{"title":390,"description":1305},"2bH9mHSTT_BpTZGVHRq0Qc0EfShj1YERBvkSImxWT4E",[1318,1320],{"title":109,"path":110,"stem":111,"description":1319,"icon":112,"children":-1},"Framework-agnostic factory with route filtering, session timing, and lifecycle hooks. Call it once at startup and reuse across requests.",{"title":118,"path":119,"stem":120,"description":1321,"icon":121,"children":-1},"Watch session resolution time, enable session caching, wire the standalone Nitro hook, and combine with the AI SDK integration.",1777907758614]