[{"data":1,"prerenderedAt":1481},["ShallowReactive",2],{"navigation_docs":3,"-logging-better-auth-client-sync":547,"-logging-better-auth-client-sync-surround":1476},[4,35,159,201,289,446,531],{"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,297,325,346,373,400,428],{"title":41,"path":295,"stem":296,"icon":54},"\u002Fbuild-on-top\u002Foverview","5.build-on-top\u002F0.overview",{"title":298,"path":299,"stem":300,"children":301,"page":34},"Observers","\u002Fbuild-on-top\u002Fobservers","5.build-on-top\u002Fobservers",[302,306,311,316,321],{"title":41,"path":303,"stem":304,"icon":305},"\u002Fbuild-on-top\u002Fobservers\u002Foverview","5.build-on-top\u002Fobservers\u002F1.overview","i-lucide-eye",{"title":307,"path":308,"stem":309,"icon":310},"Stream API","\u002Fbuild-on-top\u002Fobservers\u002Fin-process-stream","5.build-on-top\u002Fobservers\u002F2.in-process-stream","i-lucide-radio-tower",{"title":312,"path":313,"stem":314,"icon":315},"Stream server","\u002Fbuild-on-top\u002Fobservers\u002Fstream-server","5.build-on-top\u002Fobservers\u002F3.stream-server","i-lucide-radio",{"title":317,"path":318,"stem":319,"icon":320},"FS reader","\u002Fbuild-on-top\u002Fobservers\u002Ffs-reader","5.build-on-top\u002Fobservers\u002F4.fs-reader","i-lucide-folder-search",{"title":156,"path":322,"stem":323,"icon":324},"\u002Fbuild-on-top\u002Fobservers\u002Fconsumer-recipes","5.build-on-top\u002Fobservers\u002F5.consumer-recipes","i-lucide-chef-hat",{"title":326,"path":327,"stem":328,"children":329,"page":34},"Pipeline","\u002Fbuild-on-top\u002Fpipeline","5.build-on-top\u002Fpipeline",[330,334,338,342],{"title":41,"path":331,"stem":332,"icon":333},"\u002Fbuild-on-top\u002Fpipeline\u002Foverview","5.build-on-top\u002Fpipeline\u002F1.overview","i-lucide-workflow",{"title":335,"path":336,"stem":337,"icon":288},"Plugins","\u002Fbuild-on-top\u002Fpipeline\u002Fplugins","5.build-on-top\u002Fpipeline\u002F2.plugins",{"title":339,"path":340,"stem":341,"icon":28},"Custom enrichers","\u002Fbuild-on-top\u002Fpipeline\u002Fcustom-enrichers","5.build-on-top\u002Fpipeline\u002F3.custom-enrichers",{"title":343,"path":344,"stem":345,"icon":178},"Tail sampling","\u002Fbuild-on-top\u002Fpipeline\u002Ftail-sampling","5.build-on-top\u002Fpipeline\u002F4.tail-sampling",{"title":347,"path":348,"stem":349,"children":350,"page":34},"Scenarios","\u002Fbuild-on-top\u002Fscenarios","5.build-on-top\u002Fscenarios",[351,355,359,364,368],{"title":41,"path":352,"stem":353,"icon":354},"\u002Fbuild-on-top\u002Fscenarios\u002Foverview","5.build-on-top\u002Fscenarios\u002F0.overview","i-lucide-clipboard-list",{"title":356,"path":357,"stem":358,"icon":49},"Local debugging toolkit","\u002Fbuild-on-top\u002Fscenarios\u002Flocal-debugging-toolkit","5.build-on-top\u002Fscenarios\u002F1.local-debugging-toolkit",{"title":360,"path":361,"stem":362,"icon":363},"Tenant-aware logging","\u002Fbuild-on-top\u002Fscenarios\u002Ftenant-aware-logging","5.build-on-top\u002Fscenarios\u002F2.tenant-aware-logging","i-lucide-users",{"title":365,"path":366,"stem":367,"icon":129},"Compliance audit","\u002Fbuild-on-top\u002Fscenarios\u002Fcompliance-audit","5.build-on-top\u002Fscenarios\u002F3.compliance-audit",{"title":369,"path":370,"stem":371,"icon":372},"Cross-app error vocab","\u002Fbuild-on-top\u002Fscenarios\u002Fcross-app-error-vocab","5.build-on-top\u002Fscenarios\u002F4.cross-app-error-vocab","i-lucide-book",{"title":374,"path":375,"stem":376,"children":377,"page":34},"Shared packages","\u002Fbuild-on-top\u002Fshared","5.build-on-top\u002Fshared",[378,382,386,391,395],{"title":41,"path":379,"stem":380,"icon":381},"\u002Fbuild-on-top\u002Fshared\u002Foverview","5.build-on-top\u002Fshared\u002F1.overview","i-lucide-package",{"title":383,"path":384,"stem":385,"icon":381},"Catalogs as packages","\u002Fbuild-on-top\u002Fshared\u002Fcatalogs-as-packages","5.build-on-top\u002Fshared\u002F2.catalogs-as-packages",{"title":387,"path":388,"stem":389,"icon":390},"Drains as packages","\u002Fbuild-on-top\u002Fshared\u002Fdrains-as-packages","5.build-on-top\u002Fshared\u002F3.drains-as-packages","i-lucide-package-2",{"title":392,"path":393,"stem":394,"icon":28},"Enrichers as packages","\u002Fbuild-on-top\u002Fshared\u002Fenrichers-as-packages","5.build-on-top\u002Fshared\u002F4.enrichers-as-packages",{"title":396,"path":397,"stem":398,"icon":399},"Integration as package","\u002Fbuild-on-top\u002Fshared\u002Fintegration-as-package","5.build-on-top\u002Fshared\u002F5.integration-as-package","i-lucide-package-check",{"title":401,"path":402,"stem":403,"children":404,"page":34},"Sinks","\u002Fbuild-on-top\u002Fsinks","5.build-on-top\u002Fsinks",[405,409,414,418,423],{"title":41,"path":406,"stem":407,"icon":408},"\u002Fbuild-on-top\u002Fsinks\u002Foverview","5.build-on-top\u002Fsinks\u002F1.overview","i-lucide-arrow-up-from-line",{"title":410,"path":411,"stem":412,"icon":413},"Custom drains","\u002Fbuild-on-top\u002Fsinks\u002Fcustom-drains","5.build-on-top\u002Fsinks\u002F2.custom-drains","i-lucide-code-2",{"title":415,"path":416,"stem":417,"icon":333},"Drain pipeline","\u002Fbuild-on-top\u002Fsinks\u002Fdrain-pipeline","5.build-on-top\u002Fsinks\u002F3.drain-pipeline",{"title":419,"path":420,"stem":421,"icon":422},"Identity headers","\u002Fbuild-on-top\u002Fsinks\u002Fidentity-headers","5.build-on-top\u002Fsinks\u002F4.identity-headers","i-lucide-fingerprint",{"title":424,"path":425,"stem":426,"icon":427},"Fanout","\u002Fbuild-on-top\u002Fsinks\u002Ffanout-and-multi-drain","5.build-on-top\u002Fsinks\u002F5.fanout-and-multi-drain","i-lucide-share-2",{"title":429,"path":430,"stem":431,"children":432,"page":34},"Sources","\u002Fbuild-on-top\u002Fsources","5.build-on-top\u002Fsources",[433,437,441],{"title":41,"path":434,"stem":435,"icon":436},"\u002Fbuild-on-top\u002Fsources\u002Foverview","5.build-on-top\u002Fsources\u002F1.overview","i-lucide-arrow-down-to-line",{"title":438,"path":439,"stem":440,"icon":288},"Custom framework","\u002Fbuild-on-top\u002Fsources\u002Fcustom-framework","5.build-on-top\u002Fsources\u002F2.custom-framework",{"title":442,"path":443,"stem":444,"icon":445},"Middleware toolkit","\u002Fbuild-on-top\u002Fsources\u002Fmiddleware-toolkit","5.build-on-top\u002Fsources\u002F3.middleware-toolkit","i-lucide-wrench",{"title":447,"path":448,"stem":449,"children":450,"page":34},"Adapters","\u002Fadapters","6.adapters",[451,454,494,509],{"title":41,"path":452,"stem":453,"icon":44},"\u002Fadapters\u002Foverview","6.adapters\u002F01.overview",{"title":455,"path":456,"stem":457,"children":458,"page":34},"Cloud destinations","\u002Fadapters\u002Fcloud","6.adapters\u002F02.cloud",[459,464,469,474,479,484,489],{"title":460,"path":461,"stem":462,"icon":463},"Axiom","\u002Fadapters\u002Fcloud\u002Faxiom","6.adapters\u002F02.cloud\u002F01.axiom","i-custom-axiom",{"title":465,"path":466,"stem":467,"icon":468},"OTLP","\u002Fadapters\u002Fcloud\u002Fotlp","6.adapters\u002F02.cloud\u002F02.otlp","i-simple-icons-opentelemetry",{"title":470,"path":471,"stem":472,"icon":473},"PostHog","\u002Fadapters\u002Fcloud\u002Fposthog","6.adapters\u002F02.cloud\u002F03.posthog","i-simple-icons-posthog",{"title":475,"path":476,"stem":477,"icon":478},"Sentry","\u002Fadapters\u002Fcloud\u002Fsentry","6.adapters\u002F02.cloud\u002F04.sentry","i-simple-icons-sentry",{"title":480,"path":481,"stem":482,"icon":483},"Better Stack","\u002Fadapters\u002Fcloud\u002Fbetter-stack","6.adapters\u002F02.cloud\u002F05.better-stack","i-simple-icons-betterstack",{"title":485,"path":486,"stem":487,"icon":488},"Datadog","\u002Fadapters\u002Fcloud\u002Fdatadog","6.adapters\u002F02.cloud\u002F06.datadog","i-simple-icons-datadog",{"title":490,"path":491,"stem":492,"icon":493},"HyperDX","\u002Fadapters\u002Fcloud\u002Fhyperdx","6.adapters\u002F02.cloud\u002F07.hyperdx","i-custom-hyperdx",{"title":495,"path":496,"stem":497,"children":498,"page":34},"Self-hosted","\u002Fadapters\u002Fself-hosted","6.adapters\u002F03.self-hosted",[499,504],{"title":500,"path":501,"stem":502,"icon":503},"File System","\u002Fadapters\u002Fself-hosted\u002Ffs","6.adapters\u002F03.self-hosted\u002F01.fs","i-lucide-hard-drive",{"title":505,"path":506,"stem":507,"icon":508},"NuxtHub","\u002Fadapters\u002Fself-hosted\u002Fnuxthub","6.adapters\u002F03.self-hosted\u002F02.nuxthub","i-simple-icons-nuxt",{"title":510,"path":511,"stem":512,"children":513,"page":34},"Building blocks","\u002Fadapters\u002Fbuilding-blocks","6.adapters\u002F04.building-blocks",[514,517,522,526],{"title":326,"path":515,"stem":516,"icon":333},"\u002Fadapters\u002Fbuilding-blocks\u002Fpipeline","6.adapters\u002F04.building-blocks\u002F01.pipeline",{"title":518,"path":519,"stem":520,"icon":521},"HTTP","\u002Fadapters\u002Fbuilding-blocks\u002Fhttp","6.adapters\u002F04.building-blocks\u002F02.http","i-lucide-globe",{"title":523,"path":524,"stem":525,"icon":83},"Custom Adapters","\u002Fadapters\u002Fbuilding-blocks\u002Fcustom","6.adapters\u002F04.building-blocks\u002F03.custom",{"title":527,"path":528,"stem":529,"icon":530},"Toolkit","\u002Fadapters\u002Fbuilding-blocks\u002Ftoolkit","6.adapters\u002F04.building-blocks\u002F04.toolkit","i-lucide-blocks",{"title":532,"path":533,"stem":534,"children":535,"page":34},"Enrichers","\u002Fenrichers","7.enrichers",[536,539,543],{"title":41,"path":537,"stem":538,"icon":28},"\u002Fenrichers\u002Foverview","7.enrichers\u002F1.overview",{"title":540,"path":541,"stem":542,"icon":288},"Built-in","\u002Fenrichers\u002Fbuilt-in","7.enrichers\u002F2.built-in",{"title":544,"path":545,"stem":546,"icon":83},"Custom","\u002Fenrichers\u002Fcustom","7.enrichers\u002F3.custom",{"id":548,"title":549,"body":550,"description":1464,"extension":1465,"links":1466,"meta":1472,"navigation":1473,"path":120,"seo":1474,"stem":121,"__hash__":1475},"docs\u002F2.logging\u002F7.better-auth\u002F04.client-sync.md","Client Identity Sync",{"type":551,"value":552,"toc":1458},"minimark",[553,562,567,827,830,868,872,1099,1106,1110,1305,1312,1316,1319,1438,1454],[554,555,556,557,561],"p",{},"The middleware identifies users on the server. To get the same identity on ",[558,559,560],"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.",[563,564,566],"h2",{"id":565},"vue-nuxt","Vue \u002F Nuxt",[568,569,575],"pre",{"className":570,"code":571,"filename":572,"language":573,"meta":574,"style":574},"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","",[576,577,578,611,618,638,662,667,715,731,775,786,794,800,821],"code",{"__ignoreMap":574},[579,580,583,587,591,595,598,601,604,608],"span",{"class":581,"line":582},"line",1,[579,584,586],{"class":585},"s7zQu","import",[579,588,590],{"class":589},"sMK4o"," {",[579,592,594],{"class":593},"sTEyZ"," authClient",[579,596,597],{"class":589}," }",[579,599,600],{"class":585}," from",[579,602,603],{"class":589}," '",[579,605,607],{"class":606},"sfazB","~\u002Flib\u002Fauth-client",[579,609,610],{"class":589},"'\n",[579,612,614],{"class":581,"line":613},2,[579,615,617],{"emptyLinePlaceholder":616},true,"\n",[579,619,621,624,628,632,635],{"class":581,"line":620},3,[579,622,623],{"class":585},"export",[579,625,627],{"class":626},"spNyl"," function",[579,629,631],{"class":630},"s2Zo4"," useAuthIdentity",[579,633,634],{"class":589},"()",[579,636,637],{"class":589}," {\n",[579,639,641,644,647,650,652,655,658],{"class":581,"line":640},4,[579,642,643],{"class":626},"  const",[579,645,646],{"class":593}," session",[579,648,649],{"class":589}," =",[579,651,594],{"class":593},[579,653,654],{"class":589},".",[579,656,657],{"class":630},"useSession",[579,659,661],{"class":660},"swJcz","()\n",[579,663,665],{"class":581,"line":664},5,[579,666,617],{"emptyLinePlaceholder":616},[579,668,670,673,676,678,681,683,685,688,691,694,696,699,702,705,708,711,713],{"class":581,"line":669},6,[579,671,672],{"class":630},"  watch",[579,674,675],{"class":660},"(",[579,677,634],{"class":589},[579,679,680],{"class":626}," =>",[579,682,646],{"class":593},[579,684,654],{"class":589},[579,686,687],{"class":593},"value",[579,689,690],{"class":589},"?.",[579,692,693],{"class":593},"data",[579,695,690],{"class":589},[579,697,698],{"class":593},"user",[579,700,701],{"class":589},",",[579,703,704],{"class":589}," (",[579,706,698],{"class":707},"sHdIc",[579,709,710],{"class":589},")",[579,712,680],{"class":626},[579,714,637],{"class":589},[579,716,718,721,723,725,728],{"class":581,"line":717},7,[579,719,720],{"class":585},"    if",[579,722,704],{"class":660},[579,724,698],{"class":593},[579,726,727],{"class":660},") ",[579,729,730],{"class":589},"{\n",[579,732,734,737,739,742,745,748,751,753,756,758,761,763,765,767,770,772],{"class":581,"line":733},8,[579,735,736],{"class":630},"      setIdentity",[579,738,675],{"class":660},[579,740,741],{"class":589},"{",[579,743,744],{"class":660}," userId",[579,746,747],{"class":589},":",[579,749,750],{"class":593}," user",[579,752,654],{"class":589},[579,754,755],{"class":593},"id",[579,757,701],{"class":589},[579,759,760],{"class":660}," userName",[579,762,747],{"class":589},[579,764,750],{"class":593},[579,766,654],{"class":589},[579,768,769],{"class":593},"name",[579,771,597],{"class":589},[579,773,774],{"class":660},")\n",[579,776,778,781,784],{"class":581,"line":777},9,[579,779,780],{"class":589},"    }",[579,782,783],{"class":585}," else",[579,785,637],{"class":589},[579,787,789,792],{"class":581,"line":788},10,[579,790,791],{"class":630},"      clearIdentity",[579,793,661],{"class":660},[579,795,797],{"class":581,"line":796},11,[579,798,799],{"class":589},"    }\n",[579,801,803,806,808,811,813,817,819],{"class":581,"line":802},12,[579,804,805],{"class":589},"  },",[579,807,590],{"class":589},[579,809,810],{"class":660}," immediate",[579,812,747],{"class":589},[579,814,816],{"class":815},"sfNiH"," true",[579,818,597],{"class":589},[579,820,774],{"class":660},[579,822,824],{"class":581,"line":823},13,[579,825,826],{"class":589},"}\n",[554,828,829],{},"Call it once in your root layout:",[568,831,836],{"className":832,"code":833,"filename":834,"language":835,"meta":574,"style":574},"language-vue shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","\u003Cscript setup>\nuseAuthIdentity()\n\u003C\u002Fscript>\n","app.vue","vue",[576,837,838,852,859],{"__ignoreMap":574},[579,839,840,843,846,849],{"class":581,"line":582},[579,841,842],{"class":589},"\u003C",[579,844,845],{"class":660},"script",[579,847,848],{"class":626}," setup",[579,850,851],{"class":589},">\n",[579,853,854,857],{"class":581,"line":613},[579,855,856],{"class":630},"useAuthIdentity",[579,858,661],{"class":593},[579,860,861,864,866],{"class":581,"line":620},[579,862,863],{"class":589},"\u003C\u002F",[579,865,845],{"class":660},[579,867,851],{"class":589},[563,869,871],{"id":870},"react","React",[568,873,878],{"className":874,"code":875,"filename":876,"language":877,"meta":574,"style":574},"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",[576,879,880,899,924,943,947,959,980,984,997,1013,1055,1063,1069,1073,1094],{"__ignoreMap":574},[579,881,882,884,886,889,891,893,895,897],{"class":581,"line":582},[579,883,586],{"class":585},[579,885,590],{"class":589},[579,887,888],{"class":593}," useEffect",[579,890,597],{"class":589},[579,892,600],{"class":585},[579,894,603],{"class":589},[579,896,870],{"class":606},[579,898,610],{"class":589},[579,900,901,903,905,908,910,913,915,917,919,922],{"class":581,"line":613},[579,902,586],{"class":585},[579,904,590],{"class":589},[579,906,907],{"class":593}," setIdentity",[579,909,701],{"class":589},[579,911,912],{"class":593}," clearIdentity",[579,914,597],{"class":589},[579,916,600],{"class":585},[579,918,603],{"class":589},[579,920,921],{"class":606},"evlog\u002Fhttp",[579,923,610],{"class":589},[579,925,926,928,930,932,934,936,938,941],{"class":581,"line":620},[579,927,586],{"class":585},[579,929,590],{"class":589},[579,931,594],{"class":593},[579,933,597],{"class":589},[579,935,600],{"class":585},[579,937,603],{"class":589},[579,939,940],{"class":606},"@\u002Flib\u002Fauth-client",[579,942,610],{"class":589},[579,944,945],{"class":581,"line":640},[579,946,617],{"emptyLinePlaceholder":616},[579,948,949,951,953,955,957],{"class":581,"line":664},[579,950,623],{"class":585},[579,952,627],{"class":626},[579,954,631],{"class":630},[579,956,634],{"class":589},[579,958,637],{"class":589},[579,960,961,963,965,968,970,972,974,976,978],{"class":581,"line":669},[579,962,643],{"class":626},[579,964,590],{"class":589},[579,966,967],{"class":593}," data",[579,969,597],{"class":589},[579,971,649],{"class":589},[579,973,594],{"class":593},[579,975,654],{"class":589},[579,977,657],{"class":630},[579,979,661],{"class":660},[579,981,982],{"class":581,"line":717},[579,983,617],{"emptyLinePlaceholder":616},[579,985,986,989,991,993,995],{"class":581,"line":733},[579,987,988],{"class":630},"  useEffect",[579,990,675],{"class":660},[579,992,634],{"class":589},[579,994,680],{"class":626},[579,996,637],{"class":589},[579,998,999,1001,1003,1005,1007,1009,1011],{"class":581,"line":777},[579,1000,720],{"class":585},[579,1002,704],{"class":660},[579,1004,693],{"class":593},[579,1006,690],{"class":589},[579,1008,698],{"class":593},[579,1010,727],{"class":660},[579,1012,730],{"class":589},[579,1014,1015,1017,1019,1021,1023,1025,1027,1029,1031,1033,1035,1037,1039,1041,1043,1045,1047,1049,1051,1053],{"class":581,"line":788},[579,1016,736],{"class":630},[579,1018,675],{"class":660},[579,1020,741],{"class":589},[579,1022,744],{"class":660},[579,1024,747],{"class":589},[579,1026,967],{"class":593},[579,1028,654],{"class":589},[579,1030,698],{"class":593},[579,1032,654],{"class":589},[579,1034,755],{"class":593},[579,1036,701],{"class":589},[579,1038,760],{"class":660},[579,1040,747],{"class":589},[579,1042,967],{"class":593},[579,1044,654],{"class":589},[579,1046,698],{"class":593},[579,1048,654],{"class":589},[579,1050,769],{"class":593},[579,1052,597],{"class":589},[579,1054,774],{"class":660},[579,1056,1057,1059,1061],{"class":581,"line":796},[579,1058,780],{"class":589},[579,1060,783],{"class":585},[579,1062,637],{"class":589},[579,1064,1065,1067],{"class":581,"line":802},[579,1066,791],{"class":630},[579,1068,661],{"class":660},[579,1070,1071],{"class":581,"line":823},[579,1072,799],{"class":589},[579,1074,1076,1078,1081,1083,1085,1087,1089,1091],{"class":581,"line":1075},14,[579,1077,805],{"class":589},[579,1079,1080],{"class":660}," [",[579,1082,693],{"class":593},[579,1084,690],{"class":589},[579,1086,698],{"class":593},[579,1088,690],{"class":589},[579,1090,755],{"class":593},[579,1092,1093],{"class":660},"])\n",[579,1095,1097],{"class":581,"line":1096},15,[579,1098,826],{"class":589},[554,1100,1101,1102,1105],{},"Wire it up at the root of your app (in ",[576,1103,1104],{},"_app.tsx",", the root layout, or a top-level provider).",[563,1107,1109],{"id":1108},"svelte","Svelte",[568,1111,1114],{"className":570,"code":1112,"filename":1113,"language":573,"meta":574,"style":574},"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",[576,1115,1116,1138,1157,1161,1174,1190,1194,1218,1234,1276,1284,1290,1294,1301],{"__ignoreMap":574},[579,1117,1118,1120,1122,1124,1126,1128,1130,1132,1134,1136],{"class":581,"line":582},[579,1119,586],{"class":585},[579,1121,590],{"class":589},[579,1123,907],{"class":593},[579,1125,701],{"class":589},[579,1127,912],{"class":593},[579,1129,597],{"class":589},[579,1131,600],{"class":585},[579,1133,603],{"class":589},[579,1135,921],{"class":606},[579,1137,610],{"class":589},[579,1139,1140,1142,1144,1146,1148,1150,1152,1155],{"class":581,"line":613},[579,1141,586],{"class":585},[579,1143,590],{"class":589},[579,1145,594],{"class":593},[579,1147,597],{"class":589},[579,1149,600],{"class":585},[579,1151,603],{"class":589},[579,1153,1154],{"class":606},"$lib\u002Fauth-client",[579,1156,610],{"class":589},[579,1158,1159],{"class":581,"line":620},[579,1160,617],{"emptyLinePlaceholder":616},[579,1162,1163,1165,1167,1170,1172],{"class":581,"line":640},[579,1164,623],{"class":585},[579,1166,627],{"class":626},[579,1168,1169],{"class":630}," setupAuthIdentity",[579,1171,634],{"class":589},[579,1173,637],{"class":589},[579,1175,1176,1178,1180,1182,1184,1186,1188],{"class":581,"line":664},[579,1177,643],{"class":626},[579,1179,646],{"class":593},[579,1181,649],{"class":589},[579,1183,594],{"class":593},[579,1185,654],{"class":589},[579,1187,657],{"class":630},[579,1189,661],{"class":660},[579,1191,1192],{"class":581,"line":669},[579,1193,617],{"emptyLinePlaceholder":616},[579,1195,1196,1199,1201,1204,1206,1209,1211,1214,1216],{"class":581,"line":717},[579,1197,1198],{"class":593},"  session",[579,1200,654],{"class":589},[579,1202,1203],{"class":630},"subscribe",[579,1205,675],{"class":660},[579,1207,1208],{"class":589},"({",[579,1210,967],{"class":707},[579,1212,1213],{"class":589}," })",[579,1215,680],{"class":626},[579,1217,637],{"class":589},[579,1219,1220,1222,1224,1226,1228,1230,1232],{"class":581,"line":733},[579,1221,720],{"class":585},[579,1223,704],{"class":660},[579,1225,693],{"class":593},[579,1227,690],{"class":589},[579,1229,698],{"class":593},[579,1231,727],{"class":660},[579,1233,730],{"class":589},[579,1235,1236,1238,1240,1242,1244,1246,1248,1250,1252,1254,1256,1258,1260,1262,1264,1266,1268,1270,1272,1274],{"class":581,"line":777},[579,1237,736],{"class":630},[579,1239,675],{"class":660},[579,1241,741],{"class":589},[579,1243,744],{"class":660},[579,1245,747],{"class":589},[579,1247,967],{"class":593},[579,1249,654],{"class":589},[579,1251,698],{"class":593},[579,1253,654],{"class":589},[579,1255,755],{"class":593},[579,1257,701],{"class":589},[579,1259,760],{"class":660},[579,1261,747],{"class":589},[579,1263,967],{"class":593},[579,1265,654],{"class":589},[579,1267,698],{"class":593},[579,1269,654],{"class":589},[579,1271,769],{"class":593},[579,1273,597],{"class":589},[579,1275,774],{"class":660},[579,1277,1278,1280,1282],{"class":581,"line":788},[579,1279,780],{"class":589},[579,1281,783],{"class":585},[579,1283,637],{"class":589},[579,1285,1286,1288],{"class":581,"line":796},[579,1287,791],{"class":630},[579,1289,661],{"class":660},[579,1291,1292],{"class":581,"line":802},[579,1293,799],{"class":589},[579,1295,1296,1299],{"class":581,"line":823},[579,1297,1298],{"class":589},"  }",[579,1300,774],{"class":660},[579,1302,1303],{"class":581,"line":1075},[579,1304,826],{"class":589},[554,1306,1307,1308,1311],{},"Run ",[576,1309,1310],{},"setupAuthIdentity()"," once when the app boots.",[563,1313,1315],{"id":1314},"output","Output",[554,1317,1318],{},"Client-side logs now include the user identity:",[568,1320,1325],{"className":1321,"code":1322,"filename":1323,"language":1324,"meta":574,"style":574},"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",[576,1326,1327,1331,1355,1375,1395,1415,1434],{"__ignoreMap":574},[579,1328,1329],{"class":581,"line":582},[579,1330,730],{"class":589},[579,1332,1333,1336,1339,1342,1344,1347,1350,1352],{"class":581,"line":613},[579,1334,1335],{"class":589},"  \"",[579,1337,1338],{"class":626},"level",[579,1340,1341],{"class":589},"\"",[579,1343,747],{"class":589},[579,1345,1346],{"class":589}," \"",[579,1348,1349],{"class":606},"info",[579,1351,1341],{"class":589},[579,1353,1354],{"class":589},",\n",[579,1356,1357,1359,1362,1364,1366,1368,1371,1373],{"class":581,"line":620},[579,1358,1335],{"class":589},[579,1360,1361],{"class":626},"tag",[579,1363,1341],{"class":589},[579,1365,747],{"class":589},[579,1367,1346],{"class":589},[579,1369,1370],{"class":606},"checkout",[579,1372,1341],{"class":589},[579,1374,1354],{"class":589},[579,1376,1377,1379,1382,1384,1386,1388,1391,1393],{"class":581,"line":640},[579,1378,1335],{"class":589},[579,1380,1381],{"class":626},"message",[579,1383,1341],{"class":589},[579,1385,747],{"class":589},[579,1387,1346],{"class":589},[579,1389,1390],{"class":606},"User clicked checkout",[579,1392,1341],{"class":589},[579,1394,1354],{"class":589},[579,1396,1397,1399,1402,1404,1406,1408,1411,1413],{"class":581,"line":664},[579,1398,1335],{"class":589},[579,1400,1401],{"class":626},"userId",[579,1403,1341],{"class":589},[579,1405,747],{"class":589},[579,1407,1346],{"class":589},[579,1409,1410],{"class":606},"QBX9tPjJQExWawAbNll75",[579,1412,1341],{"class":589},[579,1414,1354],{"class":589},[579,1416,1417,1419,1422,1424,1426,1428,1431],{"class":581,"line":669},[579,1418,1335],{"class":589},[579,1420,1421],{"class":626},"userName",[579,1423,1341],{"class":589},[579,1425,747],{"class":589},[579,1427,1346],{"class":589},[579,1429,1430],{"class":606},"Hugo Richard",[579,1432,1433],{"class":589},"\"\n",[579,1435,1436],{"class":581,"line":717},[579,1437,826],{"class":589},[1439,1440,1441,1444,1445,1449,1450,1453],"tip",{},[576,1442,1443],{},"setIdentity"," is part of evlog's ",[1446,1447,1448],"a",{"href":67},"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 ",[558,1451,1452],{},"and"," API logs.",[1455,1456,1457],"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":574,"searchDepth":613,"depth":613,"links":1459},[1460,1461,1462,1463],{"id":565,"depth":613,"text":566},{"id":870,"depth":613,"text":871},{"id":1108,"depth":613,"text":1109},{"id":1314,"depth":613,"text":1315},"Mirror the server-side user identity into client-side logs by watching the Better Auth session and calling setIdentity.","md",[1467,1470],{"label":41,"icon":44,"to":106,"color":1468,"variant":1469},"neutral","subtle",{"label":66,"icon":1471,"to":67,"color":1468,"variant":1469},"i-lucide-monitor-dot",{},{"title":119,"icon":69},{"title":549,"description":1464},"GpqdzSD3zeulAg9gqP3hOumIdngTF04pnEijgCVnFaE",[1477,1479],{"title":114,"path":115,"stem":116,"description":1478,"icon":117,"children":-1},"Framework-agnostic factory with route filtering, session timing, and lifecycle hooks. Call it once at startup and reuse across requests.",{"title":123,"path":124,"stem":125,"description":1480,"icon":126,"children":-1},"Watch session resolution time, enable session caching, wire the standalone Nitro hook, and combine with the AI SDK integration.",1778338246916]