import { DataTag, QueryClient } from '@tanstack/react-query'; import { APIError } from 'better-auth'; import { MultiSessionAuthServer } from '../../../lib/auth-server'; export type ListDeviceSessionsData = Awaited>; export type ListDeviceSession = NonNullable>[number]; export type ListDeviceSessionsParams = Parameters[0]; /** * Query options factory for the current user's device sessions. * * @param auth - The Better Auth server instance with the multi-session plugin. * @param userId - The signed-in user's ID. Used for cache partitioning so * the key matches the client-side `listDeviceSessionsOptions` for SSR hydration. * @param params - Parameters forwarded to `auth.api.listDeviceSessions`. */ export declare function listDeviceSessionsOptions(auth: TAuth, userId: string, params: ListDeviceSessionsParams): (import('@tanstack/query-core').OmitKeyof>, APIError, Awaited>, readonly ["auth", "user", string | undefined, "multiSession", "list", Record | null]>, "queryFn"> & { queryFn?: import('@tanstack/query-core').QueryFunction>, readonly ["auth", "user", string | undefined, "multiSession", "list", Record | null], never> | undefined; } & { queryKey: readonly ["auth", "user", string | undefined, "multiSession", "list", Record | null] & { [dataTagSymbol]: Awaited>; [dataTagErrorSymbol]: APIError; }; }) & { queryKey: DataTag | null], Awaited>, APIError>; }; /** * Get the current user's device sessions from the query cache, calling * `fetchListDeviceSessions` under the hood if no cached entry exists. * Resolves with the device session 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 with the multi-session plugin. * @param userId - The signed-in user's ID, used for cache partitioning. * @param params - Parameters forwarded to `auth.api.listDeviceSessions`. */ export declare const ensureListDeviceSessions: (queryClient: QueryClient, auth: TAuth, userId: string, params: ListDeviceSessionsParams) => Promise>>; /** * Prefetch the current user's device sessions into the query cache. Behaves * like `fetchListDeviceSessions`, 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 with the multi-session plugin. * @param userId - The signed-in user's ID, used for cache partitioning. * @param params - Parameters forwarded to `auth.api.listDeviceSessions`. */ export declare const prefetchListDeviceSessions: (queryClient: QueryClient, auth: TAuth, userId: string, params: ListDeviceSessionsParams) => Promise; /** * Fetch and cache the current user's device sessions, 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 with the multi-session plugin. * @param userId - The signed-in user's ID, used for cache partitioning. * @param params - Parameters forwarded to `auth.api.listDeviceSessions`. */ export declare const fetchListDeviceSessions: (queryClient: QueryClient, auth: TAuth, userId: string, params: ListDeviceSessionsParams) => Promise>>;