import { DataTag, QueryClient } from '@tanstack/react-query'; import { APIError } from 'better-auth'; import { AuthServer } from '../../../lib/auth-server'; export type AccountInfoData = Awaited>; export type AccountInfoParams = Parameters[0]; export type AccountInfo = NonNullable>; /** * 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 declare function accountInfoOptions(auth: TAuth, userId: string, params: AccountInfoParams): (import('@tanstack/query-core').OmitKeyof>, APIError, Awaited>, readonly ["auth", "user", string | undefined, "accountInfo", { accountId?: string | undefined; providerId?: string | undefined; userId?: string | undefined; } | null]>, "queryFn"> & { queryFn?: import('@tanstack/query-core').QueryFunction>, readonly ["auth", "user", string | undefined, "accountInfo", { accountId?: string | undefined; providerId?: string | undefined; userId?: string | undefined; } | null], never> | undefined; } & { queryKey: readonly ["auth", "user", string | undefined, "accountInfo", { accountId?: string | undefined; providerId?: string | undefined; userId?: string | undefined; } | null] & { [dataTagSymbol]: Awaited>; [dataTagErrorSymbol]: APIError; }; }) & { queryKey: DataTag>, APIError>; }; /** * 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 declare const ensureAccountInfo: (queryClient: QueryClient, auth: TAuth, userId: string, params: AccountInfoParams) => Promise>>; /** * 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 declare const prefetchAccountInfo: (queryClient: QueryClient, auth: TAuth, userId: string, params: AccountInfoParams) => Promise; /** * 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 declare const fetchAccountInfo: (queryClient: QueryClient, auth: TAuth, userId: string, params: AccountInfoParams) => Promise>>;