import { DataTag, QueryClient } from '@tanstack/react-query'; import { APIError } from 'better-auth'; import { AuthServer } from '../../../lib/auth-server'; export type ListAccountsData = Awaited>; export type ListAccountsParams = Parameters[0]; export type ListAccount = NonNullable>[number]; /** * Query options factory for the current user's linked social accounts. * * @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 `listAccountsOptions` for SSR hydration. * @param params - Parameters forwarded to `auth.api.listUserAccounts`. */ export declare function listAccountsOptions(auth: TAuth, userId: string, params: ListAccountsParams): (import('@tanstack/query-core').OmitKeyof>, APIError, Awaited>, readonly ["auth", "user", string | undefined, "listAccounts", Record | null]>, "queryFn"> & { queryFn?: import('@tanstack/query-core').QueryFunction>, readonly ["auth", "user", string | undefined, "listAccounts", Record | null], never> | undefined; } & { queryKey: readonly ["auth", "user", string | undefined, "listAccounts", Record | null] & { [dataTagSymbol]: Awaited>; [dataTagErrorSymbol]: APIError; }; }) & { queryKey: DataTag | null], Awaited>, APIError>; }; /** * Get the current user's linked social accounts from the query cache, * calling `fetchListAccounts` under the hood if no cached entry exists. * Resolves with the account list, 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.listUserAccounts`. */ export declare const ensureListAccounts: (queryClient: QueryClient, auth: TAuth, userId: string, params: ListAccountsParams) => Promise>>; /** * Prefetch the current user's linked social accounts into the query cache. * Behaves like `fetchListAccounts`, 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.listUserAccounts`. */ export declare const prefetchListAccounts: (queryClient: QueryClient, auth: TAuth, userId: string, params: ListAccountsParams) => Promise; /** * Fetch and cache the current user's linked social accounts, 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.listUserAccounts`. */ export declare const fetchListAccounts: (queryClient: QueryClient, auth: TAuth, userId: string, params: ListAccountsParams) => Promise>>;