UNPKG

better-auth

Version:

The most comprehensive authentication framework for TypeScript.

1,500 lines (1,499 loc) • 128 kB
import { InferFieldsFromOptions, InferFieldsFromPlugins } from "../db/field.mjs"; import { Prettify as Prettify$1, StripEmptyObjects, UnionToIntersection } from "../types/helper.mjs"; import { AdditionalUserFieldsInput } from "../types/models.mjs"; import "../types/index.mjs"; import "../db/index.mjs"; import "../index.mjs"; import { getIp } from "../utils/get-request-ip.mjs"; import { getOAuthState } from "./middlewares/oauth.mjs"; import { formCsrfMiddleware, originCheck, originCheckMiddleware } from "./middlewares/origin-check.mjs"; import "./middlewares/index.mjs"; import { accountInfo, getAccessToken, linkSocialAccount, listUserAccounts, refreshToken, unlinkAccount } from "./routes/account.mjs"; import { callbackOAuth } from "./routes/callback.mjs"; import { createEmailVerificationToken, sendVerificationEmail, sendVerificationEmailFn, verifyEmail } from "./routes/email-verification.mjs"; import { error } from "./routes/error.mjs"; import { ok } from "./routes/ok.mjs"; import { requestPasswordReset, requestPasswordResetCallback, resetPassword, verifyPassword } from "./routes/password.mjs"; import { freshSessionMiddleware, getSession, getSessionFromCtx, listSessions, requestOnlySessionMiddleware, revokeOtherSessions, revokeSession, revokeSessions, sensitiveSessionMiddleware, sessionMiddleware } from "./routes/session.mjs"; import { signInEmail, signInSocial } from "./routes/sign-in.mjs"; import { signOut } from "./routes/sign-out.mjs"; import { signUpEmail } from "./routes/sign-up.mjs"; import { changeEmail, changePassword, deleteUser, deleteUserCallback, setPassword, updateUser } from "./routes/update-user.mjs"; import "./routes/index.mjs"; import { AuthContext, Awaitable, BetterAuthOptions, BetterAuthPlugin } from "@better-auth/core"; import { InternalLogger } from "@better-auth/core/env"; import * as _better_auth_core_oauth20 from "@better-auth/core/oauth2"; import * as better_call54 from "better-call"; import { APIError } from "better-call"; import * as zod26 from "zod"; import { AuthEndpoint, AuthMiddleware, createAuthEndpoint, createAuthMiddleware, optionsMiddleware } from "@better-auth/core/api"; import * as zod_v4_core8 from "zod/v4/core"; //#region src/api/index.d.ts declare function checkEndpointConflicts(options: BetterAuthOptions, logger: InternalLogger): void; declare function getEndpoints<Option extends BetterAuthOptions>(ctx: Awaitable<AuthContext>, options: Option): { api: { readonly ok: better_call54.StrictEndpoint<"/ok", { method: "GET"; metadata: { openapi: { description: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { ok: { type: string; description: string; }; }; required: string[]; }; }; }; }; }; }; scope: "server"; }; }, { ok: boolean; }>; readonly error: better_call54.StrictEndpoint<"/error", { method: "GET"; metadata: { openapi: { description: string; responses: { "200": { description: string; content: { "text/html": { schema: { type: "string"; description: string; }; }; }; }; }; }; scope: "server"; }; }, Response>; readonly signInSocial: better_call54.StrictEndpoint<"/sign-in/social", { method: "POST"; operationId: string; body: zod26.ZodObject<{ callbackURL: zod26.ZodOptional<zod26.ZodString>; newUserCallbackURL: zod26.ZodOptional<zod26.ZodString>; errorCallbackURL: zod26.ZodOptional<zod26.ZodString>; provider: zod26.ZodType<"github" | "apple" | "atlassian" | "cognito" | "discord" | "facebook" | "figma" | "microsoft" | "google" | "huggingface" | "slack" | "spotify" | "twitch" | "twitter" | "dropbox" | "kick" | "linear" | "linkedin" | "gitlab" | "tiktok" | "reddit" | "roblox" | "salesforce" | "vk" | "zoom" | "notion" | "kakao" | "naver" | "line" | "paybin" | "paypal" | "polar" | "vercel" | (string & {}), unknown, zod_v4_core8.$ZodTypeInternals<"github" | "apple" | "atlassian" | "cognito" | "discord" | "facebook" | "figma" | "microsoft" | "google" | "huggingface" | "slack" | "spotify" | "twitch" | "twitter" | "dropbox" | "kick" | "linear" | "linkedin" | "gitlab" | "tiktok" | "reddit" | "roblox" | "salesforce" | "vk" | "zoom" | "notion" | "kakao" | "naver" | "line" | "paybin" | "paypal" | "polar" | "vercel" | (string & {}), unknown>>; disableRedirect: zod26.ZodOptional<zod26.ZodBoolean>; idToken: zod26.ZodOptional<zod26.ZodObject<{ token: zod26.ZodString; nonce: zod26.ZodOptional<zod26.ZodString>; accessToken: zod26.ZodOptional<zod26.ZodString>; refreshToken: zod26.ZodOptional<zod26.ZodString>; expiresAt: zod26.ZodOptional<zod26.ZodNumber>; }, zod_v4_core8.$strip>>; scopes: zod26.ZodOptional<zod26.ZodArray<zod26.ZodString>>; requestSignUp: zod26.ZodOptional<zod26.ZodBoolean>; loginHint: zod26.ZodOptional<zod26.ZodString>; additionalData: zod26.ZodOptional<zod26.ZodRecord<zod26.ZodString, zod26.ZodAny>>; }, zod_v4_core8.$strip>; metadata: { $Infer: { body: zod26.infer<zod26.ZodObject<{ callbackURL: zod26.ZodOptional<zod26.ZodString>; newUserCallbackURL: zod26.ZodOptional<zod26.ZodString>; errorCallbackURL: zod26.ZodOptional<zod26.ZodString>; provider: zod26.ZodType<"github" | "apple" | "atlassian" | "cognito" | "discord" | "facebook" | "figma" | "microsoft" | "google" | "huggingface" | "slack" | "spotify" | "twitch" | "twitter" | "dropbox" | "kick" | "linear" | "linkedin" | "gitlab" | "tiktok" | "reddit" | "roblox" | "salesforce" | "vk" | "zoom" | "notion" | "kakao" | "naver" | "line" | "paybin" | "paypal" | "polar" | "vercel" | (string & {}), unknown, zod_v4_core8.$ZodTypeInternals<"github" | "apple" | "atlassian" | "cognito" | "discord" | "facebook" | "figma" | "microsoft" | "google" | "huggingface" | "slack" | "spotify" | "twitch" | "twitter" | "dropbox" | "kick" | "linear" | "linkedin" | "gitlab" | "tiktok" | "reddit" | "roblox" | "salesforce" | "vk" | "zoom" | "notion" | "kakao" | "naver" | "line" | "paybin" | "paypal" | "polar" | "vercel" | (string & {}), unknown>>; disableRedirect: zod26.ZodOptional<zod26.ZodBoolean>; idToken: zod26.ZodOptional<zod26.ZodObject<{ token: zod26.ZodString; nonce: zod26.ZodOptional<zod26.ZodString>; accessToken: zod26.ZodOptional<zod26.ZodString>; refreshToken: zod26.ZodOptional<zod26.ZodString>; expiresAt: zod26.ZodOptional<zod26.ZodNumber>; }, zod_v4_core8.$strip>>; scopes: zod26.ZodOptional<zod26.ZodArray<zod26.ZodString>>; requestSignUp: zod26.ZodOptional<zod26.ZodBoolean>; loginHint: zod26.ZodOptional<zod26.ZodString>; additionalData: zod26.ZodOptional<zod26.ZodRecord<zod26.ZodString, zod26.ZodAny>>; }, zod_v4_core8.$strip>>; returned: { redirect: boolean; token?: string | undefined; url?: string | undefined; user?: UnionToIntersection<StripEmptyObjects<{ id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; } & InferFieldsFromPlugins<Option, "user", "output"> & InferFieldsFromOptions<Option, "user", "output">>> | undefined; }; }; openapi: { description: string; operationId: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; description: string; properties: { token: { type: string; }; user: { type: string; $ref: string; }; url: { type: string; }; redirect: { type: string; enum: boolean[]; }; }; required: string[]; }; }; }; }; }; }; }; }, { redirect: boolean; url: string; } | { redirect: boolean; token: string; url: undefined; user: UnionToIntersection<StripEmptyObjects<{ id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; } & InferFieldsFromPlugins<Option, "user", "output"> & InferFieldsFromOptions<Option, "user", "output">>>; }>; readonly callbackOAuth: better_call54.StrictEndpoint<"/callback/:id", { method: ("GET" | "POST")[]; operationId: string; body: zod26.ZodOptional<zod26.ZodObject<{ code: zod26.ZodOptional<zod26.ZodString>; error: zod26.ZodOptional<zod26.ZodString>; device_id: zod26.ZodOptional<zod26.ZodString>; error_description: zod26.ZodOptional<zod26.ZodString>; state: zod26.ZodOptional<zod26.ZodString>; user: zod26.ZodOptional<zod26.ZodString>; }, zod_v4_core8.$strip>>; query: zod26.ZodOptional<zod26.ZodObject<{ code: zod26.ZodOptional<zod26.ZodString>; error: zod26.ZodOptional<zod26.ZodString>; device_id: zod26.ZodOptional<zod26.ZodString>; error_description: zod26.ZodOptional<zod26.ZodString>; state: zod26.ZodOptional<zod26.ZodString>; user: zod26.ZodOptional<zod26.ZodString>; }, zod_v4_core8.$strip>>; metadata: { allowedMediaTypes: string[]; scope: "server"; }; }, void>; readonly getSession: better_call54.StrictEndpoint<"/get-session", { method: "GET"; operationId: string; query: zod26.ZodOptional<zod26.ZodObject<{ disableCookieCache: zod26.ZodOptional<zod26.ZodCoercedBoolean<unknown>>; disableRefresh: zod26.ZodOptional<zod26.ZodCoercedBoolean<unknown>>; }, zod_v4_core8.$strip>>; requireHeaders: true; metadata: { openapi: { operationId: string; description: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; nullable: boolean; properties: { session: { $ref: string; }; user: { $ref: string; }; }; required: string[]; }; }; }; }; }; }; }; }, { session: UnionToIntersection<StripEmptyObjects<{ id: string; createdAt: Date; updatedAt: Date; userId: string; expiresAt: Date; token: string; ipAddress?: string | null | undefined; userAgent?: string | null | undefined; } & InferFieldsFromPlugins<Option, "session", "output"> & InferFieldsFromOptions<Option, "session", "output">>>; user: UnionToIntersection<StripEmptyObjects<{ id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; } & InferFieldsFromPlugins<Option, "user", "output"> & InferFieldsFromOptions<Option, "user", "output">>>; } | null>; readonly signOut: better_call54.StrictEndpoint<"/sign-out", { method: "POST"; operationId: string; requireHeaders: true; metadata: { openapi: { operationId: string; description: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { success: { type: string; }; }; }; }; }; }; }; }; }; }, { success: boolean; }>; readonly signUpEmail: better_call54.StrictEndpoint<"/sign-up/email", { method: "POST"; operationId: string; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<void>)[]; body: zod26.ZodIntersection<zod26.ZodObject<{ name: zod26.ZodString; email: zod26.ZodEmail; password: zod26.ZodString; image: zod26.ZodOptional<zod26.ZodString>; callbackURL: zod26.ZodOptional<zod26.ZodString>; rememberMe: zod26.ZodOptional<zod26.ZodBoolean>; }, zod_v4_core8.$strip>, zod26.ZodRecord<zod26.ZodString, zod26.ZodAny>>; metadata: { allowedMediaTypes: string[]; $Infer: { body: { name: string; email: string; password: string; image?: string | undefined; callbackURL?: string | undefined; rememberMe?: boolean | undefined; } & InferFieldsFromPlugins<Option, "user", "input"> & InferFieldsFromOptions<Option, "user", "input">; returned: { token: string | null; user: UnionToIntersection<StripEmptyObjects<{ id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; } & InferFieldsFromPlugins<Option, "user", "output"> & InferFieldsFromOptions<Option, "user", "output">>>; }; }; openapi: { operationId: string; description: string; requestBody: { content: { "application/json": { schema: { type: "object"; properties: { name: { type: string; description: string; }; email: { type: string; description: string; }; password: { type: string; description: string; }; image: { type: string; description: string; }; callbackURL: { type: string; description: string; }; rememberMe: { type: string; description: string; }; }; required: string[]; }; }; }; }; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { token: { type: string; nullable: boolean; description: string; }; user: { type: string; properties: { id: { type: string; description: string; }; email: { type: string; format: string; description: string; }; name: { type: string; description: string; }; image: { type: string; format: string; nullable: boolean; description: string; }; emailVerified: { type: string; description: string; }; createdAt: { type: string; format: string; description: string; }; updatedAt: { type: string; format: string; description: string; }; }; required: string[]; }; }; required: string[]; }; }; }; }; "422": { description: string; content: { "application/json": { schema: { type: "object"; properties: { message: { type: string; }; }; }; }; }; }; }; }; }; }, { token: null; user: UnionToIntersection<StripEmptyObjects<{ id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; } & InferFieldsFromPlugins<Option, "user", "output"> & InferFieldsFromOptions<Option, "user", "output">>>; } | { token: string; user: UnionToIntersection<StripEmptyObjects<{ id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; } & InferFieldsFromPlugins<Option, "user", "output"> & InferFieldsFromOptions<Option, "user", "output">>>; }>; readonly signInEmail: better_call54.StrictEndpoint<"/sign-in/email", { method: "POST"; operationId: string; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<void>)[]; body: zod26.ZodObject<{ email: zod26.ZodString; password: zod26.ZodString; callbackURL: zod26.ZodOptional<zod26.ZodString>; rememberMe: zod26.ZodOptional<zod26.ZodDefault<zod26.ZodBoolean>>; }, zod_v4_core8.$strip>; metadata: { allowedMediaTypes: string[]; $Infer: { body: { email: string; password: string; callbackURL?: string | undefined; rememberMe?: boolean | undefined; }; returned: { redirect: boolean; token: string; url?: string | undefined; user: UnionToIntersection<StripEmptyObjects<{ id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; } & InferFieldsFromPlugins<Option, "user", "output"> & InferFieldsFromOptions<Option, "user", "output">>>; }; }; openapi: { operationId: string; description: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; description: string; properties: { redirect: { type: string; enum: boolean[]; }; token: { type: string; description: string; }; url: { type: string; nullable: boolean; }; user: { type: string; $ref: string; }; }; required: string[]; }; }; }; }; }; }; }; }, { redirect: boolean; token: string; url?: string | undefined; user: UnionToIntersection<StripEmptyObjects<{ id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; } & InferFieldsFromPlugins<Option, "user", "output"> & InferFieldsFromOptions<Option, "user", "output">>>; }>; readonly resetPassword: better_call54.StrictEndpoint<"/reset-password", { method: "POST"; operationId: string; query: zod26.ZodOptional<zod26.ZodObject<{ token: zod26.ZodOptional<zod26.ZodString>; }, zod_v4_core8.$strip>>; body: zod26.ZodObject<{ newPassword: zod26.ZodString; token: zod26.ZodOptional<zod26.ZodString>; }, zod_v4_core8.$strip>; metadata: { openapi: { operationId: string; description: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { status: { type: string; }; }; }; }; }; }; }; }; }; }, { status: boolean; }>; readonly verifyPassword: better_call54.StrictEndpoint<"/verify-password", { method: "POST"; body: zod26.ZodObject<{ password: zod26.ZodString; }, zod_v4_core8.$strip>; metadata: { scope: "server"; openapi: { operationId: string; description: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { status: { type: string; }; }; }; }; }; }; }; }; }; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<{ session: { session: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; userId: string; expiresAt: Date; token: string; ipAddress?: string | null | undefined; userAgent?: string | null | undefined; }; user: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; }; }; }>)[]; }, { status: boolean; }>; readonly verifyEmail: better_call54.StrictEndpoint<"/verify-email", { method: "GET"; operationId: string; query: zod26.ZodObject<{ token: zod26.ZodString; callbackURL: zod26.ZodOptional<zod26.ZodString>; }, zod_v4_core8.$strip>; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<void>)[]; metadata: { openapi: { description: string; parameters: ({ name: string; in: "query"; description: string; required: true; schema: { type: "string"; }; } | { name: string; in: "query"; description: string; required: false; schema: { type: "string"; }; })[]; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { user: { type: string; $ref: string; }; status: { type: string; description: string; }; }; required: string[]; }; }; }; }; }; }; }; }, void | { status: boolean; }>; readonly sendVerificationEmail: better_call54.StrictEndpoint<"/send-verification-email", { method: "POST"; operationId: string; body: zod26.ZodObject<{ email: zod26.ZodEmail; callbackURL: zod26.ZodOptional<zod26.ZodString>; }, zod_v4_core8.$strip>; metadata: { openapi: { operationId: string; description: string; requestBody: { content: { "application/json": { schema: { type: "object"; properties: { email: { type: string; description: string; example: string; }; callbackURL: { type: string; description: string; example: string; nullable: boolean; }; }; required: string[]; }; }; }; }; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { status: { type: string; description: string; example: boolean; }; }; }; }; }; }; "400": { description: string; content: { "application/json": { schema: { type: "object"; properties: { message: { type: string; description: string; example: string; }; }; }; }; }; }; }; }; }; }, { status: boolean; }>; readonly changeEmail: better_call54.StrictEndpoint<"/change-email", { method: "POST"; body: zod26.ZodObject<{ newEmail: zod26.ZodEmail; callbackURL: zod26.ZodOptional<zod26.ZodString>; }, zod_v4_core8.$strip>; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<{ session: { session: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; userId: string; expiresAt: Date; token: string; ipAddress?: string | null | undefined; userAgent?: string | null | undefined; }; user: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; }; }; }>)[]; metadata: { openapi: { operationId: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { user: { type: string; $ref: string; }; status: { type: string; description: string; }; message: { type: string; enum: string[]; description: string; nullable: boolean; }; }; required: string[]; }; }; }; }; "422": { description: string; content: { "application/json": { schema: { type: "object"; properties: { message: { type: string; }; }; }; }; }; }; }; }; }; }, { status: boolean; }>; readonly changePassword: better_call54.StrictEndpoint<"/change-password", { method: "POST"; operationId: string; body: zod26.ZodObject<{ newPassword: zod26.ZodString; currentPassword: zod26.ZodString; revokeOtherSessions: zod26.ZodOptional<zod26.ZodBoolean>; }, zod_v4_core8.$strip>; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<{ session: { session: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; userId: string; expiresAt: Date; token: string; ipAddress?: string | null | undefined; userAgent?: string | null | undefined; }; user: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; }; }; }>)[]; metadata: { openapi: { operationId: string; description: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { token: { type: string; nullable: boolean; description: string; }; user: { type: string; properties: { id: { type: string; description: string; }; email: { type: string; format: string; description: string; }; name: { type: string; description: string; }; image: { type: string; format: string; nullable: boolean; description: string; }; emailVerified: { type: string; description: string; }; createdAt: { type: string; format: string; description: string; }; updatedAt: { type: string; format: string; description: string; }; }; required: string[]; }; }; required: string[]; }; }; }; }; }; }; }; }, { token: string | null; user: { id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; } & Record<string, any>; }>; readonly setPassword: better_call54.StrictEndpoint<string, { method: "POST"; body: zod26.ZodObject<{ newPassword: zod26.ZodString; }, zod_v4_core8.$strip>; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<{ session: { session: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; userId: string; expiresAt: Date; token: string; ipAddress?: string | null | undefined; userAgent?: string | null | undefined; }; user: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; }; }; }>)[]; }, { status: boolean; }>; readonly updateUser: better_call54.StrictEndpoint<"/update-user", { method: "POST"; operationId: string; body: zod26.ZodRecord<zod26.ZodString, zod26.ZodAny>; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<{ session: { session: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; userId: string; expiresAt: Date; token: string; ipAddress?: string | null | undefined; userAgent?: string | null | undefined; }; user: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; }; }; }>)[]; metadata: { $Infer: { body: Partial<AdditionalUserFieldsInput<Option>> & { name?: string | undefined; image?: string | undefined | null; }; }; openapi: { operationId: string; description: string; requestBody: { content: { "application/json": { schema: { type: "object"; properties: { name: { type: string; description: string; }; image: { type: string; description: string; nullable: boolean; }; }; }; }; }; }; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { user: { type: string; $ref: string; }; }; }; }; }; }; }; }; }; }, { status: boolean; }>; readonly deleteUser: better_call54.StrictEndpoint<"/delete-user", { method: "POST"; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<{ session: { session: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; userId: string; expiresAt: Date; token: string; ipAddress?: string | null | undefined; userAgent?: string | null | undefined; }; user: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; }; }; }>)[]; body: zod26.ZodObject<{ callbackURL: zod26.ZodOptional<zod26.ZodString>; password: zod26.ZodOptional<zod26.ZodString>; token: zod26.ZodOptional<zod26.ZodString>; }, zod_v4_core8.$strip>; metadata: { openapi: { operationId: string; description: string; requestBody: { content: { "application/json": { schema: { type: "object"; properties: { callbackURL: { type: string; description: string; }; password: { type: string; description: string; }; token: { type: string; description: string; }; }; }; }; }; }; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { success: { type: string; description: string; }; message: { type: string; enum: string[]; description: string; }; }; required: string[]; }; }; }; }; }; }; }; }, { success: boolean; message: string; }>; readonly requestPasswordReset: better_call54.StrictEndpoint<"/request-password-reset", { method: "POST"; body: zod26.ZodObject<{ email: zod26.ZodEmail; redirectTo: zod26.ZodOptional<zod26.ZodString>; }, zod_v4_core8.$strip>; metadata: { openapi: { operationId: string; description: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { status: { type: string; }; message: { type: string; }; }; }; }; }; }; }; }; }; }, { status: boolean; message: string; }>; readonly requestPasswordResetCallback: better_call54.StrictEndpoint<"/reset-password/:token", { method: "GET"; operationId: string; query: zod26.ZodObject<{ callbackURL: zod26.ZodString; }, zod_v4_core8.$strip>; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<void>)[]; metadata: { openapi: { operationId: string; description: string; parameters: ({ name: string; in: "path"; required: true; description: string; schema: { type: "string"; }; } | { name: string; in: "query"; required: true; description: string; schema: { type: "string"; }; })[]; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { token: { type: string; }; }; }; }; }; }; }; }; }; }, never>; readonly listSessions: better_call54.StrictEndpoint<"/list-sessions", { method: "GET"; operationId: string; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<{ session: { session: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; userId: string; expiresAt: Date; token: string; ipAddress?: string | null | undefined; userAgent?: string | null | undefined; }; user: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; }; }; }>)[]; requireHeaders: true; metadata: { openapi: { operationId: string; description: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "array"; items: { $ref: string; }; }; }; }; }; }; }; }; }, Prettify$1<UnionToIntersection<StripEmptyObjects<{ id: string; createdAt: Date; updatedAt: Date; userId: string; expiresAt: Date; token: string; ipAddress?: string | null | undefined; userAgent?: string | null | undefined; } & InferFieldsFromPlugins<Option, "session", "output"> & InferFieldsFromOptions<Option, "session", "output">>>>[]>; readonly revokeSession: better_call54.StrictEndpoint<"/revoke-session", { method: "POST"; body: zod26.ZodObject<{ token: zod26.ZodString; }, zod_v4_core8.$strip>; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<{ session: { session: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; userId: string; expiresAt: Date; token: string; ipAddress?: string | null | undefined; userAgent?: string | null | undefined; }; user: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; }; }; }>)[]; requireHeaders: true; metadata: { openapi: { description: string; requestBody: { content: { "application/json": { schema: { type: "object"; properties: { token: { type: string; description: string; }; }; required: string[]; }; }; }; }; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { status: { type: string; description: string; }; }; required: string[]; }; }; }; }; }; }; }; }, { status: boolean; }>; readonly revokeSessions: better_call54.StrictEndpoint<"/revoke-sessions", { method: "POST"; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<{ session: { session: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; userId: string; expiresAt: Date; token: string; ipAddress?: string | null | undefined; userAgent?: string | null | undefined; }; user: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; }; }; }>)[]; requireHeaders: true; metadata: { openapi: { description: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { status: { type: string; description: string; }; }; required: string[]; }; }; }; }; }; }; }; }, { status: boolean; }>; readonly revokeOtherSessions: better_call54.StrictEndpoint<"/revoke-other-sessions", { method: "POST"; requireHeaders: true; use: ((inputContext: better_call54.MiddlewareInputContext<better_call54.MiddlewareOptions>) => Promise<{ session: { session: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; userId: string; expiresAt: Date; token: string; ipAddress?: string | null | undefined; userAgent?: string | null | undefined; }; user: Record<string, any> & { id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; }; }; }>)[]; metadata: { openapi: { description: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { status: { type: string; description: string; }; }; required: string[]; }; }; }; }; }; }; }; }, { status: boolean; }>; readonly linkSocialAccount: better_call54.StrictEndpoint<"/link-social", { method: "POST"; requireHeaders: true; body: zod26.ZodObject<{ callbackURL: zod26.ZodOptional<zod26.ZodString>; provider: zod26.ZodType<"github" | "apple" | "atlassian" | "cognito" | "discord" | "faceboo