import { authQueryKeys } from "@better-auth-ui/core" import { type DataTag, type QueryClient, queryOptions } from "@tanstack/react-query" import type { APIError } from "better-auth" import type { AuthServer } from "../../../lib/auth-server" export type AccountInfoData = Awaited< ReturnType > export type AccountInfoParams = Parameters< TAuth["api"]["accountInfo"] >[0] export type AccountInfo = NonNullable< AccountInfoData > /** * Query options factory for provider-specific account info. * * @param auth - The Better Auth server instance. * @param userId - The signed-in user's ID. Used for cache partitioning so * the key matches the client-side `accountInfoOptions` for SSR hydration. * @param params - Parameters forwarded to `auth.api.accountInfo`. */ export function accountInfoOptions( auth: TAuth, userId: string, params: AccountInfoParams ) { type TData = AccountInfoData const queryKey = authQueryKeys.accountInfo(userId, params?.query) const options = queryOptions({ queryKey, queryFn: () => auth.api.accountInfo(params) as Promise }) return options as typeof options & { queryKey: DataTag } } /** * Get the current user's provider-specific account info from the query * cache, calling `fetchAccountInfo` under the hood if no cached entry * exists. Resolves with the data, making it suitable for reading directly * in a server component. * * @param queryClient - The React Query client used for SSR hydration. * @param auth - The Better Auth server instance. * @param userId - The signed-in user's ID, used for cache partitioning. * @param params - Parameters forwarded to `auth.api.accountInfo`. */ export const ensureAccountInfo = ( queryClient: QueryClient, auth: TAuth, userId: string, params: AccountInfoParams ) => queryClient.ensureQueryData(accountInfoOptions(auth, userId, params)) /** * Prefetch the current user's provider-specific account info into the query * cache. Behaves like `fetchAccountInfo`, but does not throw on error and * does not return the data — use this when you only need the value to be * available after hydration. * * @param queryClient - The React Query client used for SSR hydration. * @param auth - The Better Auth server instance. * @param userId - The signed-in user's ID, used for cache partitioning. * @param params - Parameters forwarded to `auth.api.accountInfo`. */ export const prefetchAccountInfo = ( queryClient: QueryClient, auth: TAuth, userId: string, params: AccountInfoParams ) => queryClient.prefetchQuery(accountInfoOptions(auth, userId, params)) /** * Fetch and cache the current user's provider-specific account info, * resolving with the data or throwing on error. If a cached entry exists * and is neither invalidated nor older than `staleTime`, the cached value * is returned without a network call; otherwise the latest data is fetched. * * @param queryClient - The React Query client used for SSR hydration. * @param auth - The Better Auth server instance. * @param userId - The signed-in user's ID, used for cache partitioning. * @param params - Parameters forwarded to `auth.api.accountInfo`. */ export const fetchAccountInfo = ( queryClient: QueryClient, auth: TAuth, userId: string, params: AccountInfoParams ) => queryClient.fetchQuery(accountInfoOptions(auth, userId, params))