UNPKG

next-auth

Version:

Authentication for Next.js

72 lines 2.94 kB
/// <reference types="react" /> import type { Session } from ".."; import type { BuiltInProviderType, ProviderType } from "../providers"; export interface UseSessionOptions<R extends boolean> { required: R; /** Defaults to `signIn` */ onUnauthenticated?: () => void; } /** * Util type that matches some strings literally, but allows any other string as well. * @source https://github.com/microsoft/TypeScript/issues/29729#issuecomment-832522611 */ export declare type LiteralUnion<T extends U, U = string> = T | (U & Record<never, never>); export interface ClientSafeProvider { id: LiteralUnion<BuiltInProviderType>; name: string; type: ProviderType; signinUrl: string; callbackUrl: string; } export interface SignInOptions extends Record<string, unknown> { /** * Specify to which URL the user will be redirected after signing in. Defaults to the page URL the sign-in is initiated from. * * [Documentation](https://next-auth.js.org/getting-started/client#specifying-a-callbackurl) */ callbackUrl?: string; /** [Documentation](https://next-auth.js.org/getting-started/client#using-the-redirect-false-option) */ redirect?: boolean; } export interface SignInResponse { error: string | null; status: number; ok: boolean; url: string | null; } /** Match `inputType` of `new URLSearchParams(inputType)` */ export declare type SignInAuthorizationParams = string | string[][] | Record<string, string> | URLSearchParams; /** [Documentation](https://next-auth.js.org/getting-started/client#using-the-redirect-false-option-1) */ export interface SignOutResponse { url: string; } export interface SignOutParams<R extends boolean = true> { /** [Documentation](https://next-auth.js.org/getting-started/client#specifying-a-callbackurl-1) */ callbackUrl?: string; /** [Documentation](https://next-auth.js.org/getting-started/client#using-the-redirect-false-option-1 */ redirect?: R; } /** [Documentation](https://next-auth.js.org/getting-started/client#options) */ export interface SessionProviderProps { children: React.ReactNode; session?: Session | null; baseUrl?: string; basePath?: string; /** * A time interval (in seconds) after which the session will be re-fetched. * If set to `0` (default), the session is not polled. */ refetchInterval?: number; /** * `SessionProvider` automatically refetches the session when the user switches between windows. * This option activates this behaviour if set to `true` (default). */ refetchOnWindowFocus?: boolean; /** * Set to `false` to stop polling when the device has no internet access offline (determined by `navigator.onLine`) * * [`navigator.onLine` documentation](https://developer.mozilla.org/en-US/docs/Web/API/NavigatorOnLine/onLine) */ refetchWhenOffline?: false; } //# sourceMappingURL=types.d.ts.map