UNPKG

better-auth

Version:

The most comprehensive authentication framework for TypeScript.

1,457 lines (1,455 loc) • 125 kB
import { InferFieldsFromOptions, InferFieldsFromPlugins } from "../db/field.mjs"; import "../db/index.mjs"; import { Prettify as Prettify$1, StripEmptyObjects, UnionToIntersection } from "../types/helper.mjs"; import { AdditionalSessionFieldsOutput, AdditionalUserFieldsInput, AdditionalUserFieldsOutput } from "../types/models.mjs"; import { Auth } from "../types/auth.mjs"; import "../types/index.mjs"; import "../index.mjs"; import { getIp } from "../utils/get-request-ip.mjs"; import { getOAuthState } from "./middlewares/oauth.mjs"; import { 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 } from "./routes/reset-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 zod0 from "zod"; import * as better_call3 from "better-call"; import { APIError } from "better-call"; import { AuthEndpoint, AuthMiddleware, createAuthEndpoint, createAuthMiddleware, optionsMiddleware } from "@better-auth/core/api"; import * as zod_v4_core0 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_call3.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_call3.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_call3.StrictEndpoint<"/sign-in/social", { method: "POST"; operationId: string; body: zod0.ZodObject<{ callbackURL: zod0.ZodOptional<zod0.ZodString>; newUserCallbackURL: zod0.ZodOptional<zod0.ZodString>; errorCallbackURL: zod0.ZodOptional<zod0.ZodString>; provider: zod0.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_core0.$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: zod0.ZodOptional<zod0.ZodBoolean>; idToken: zod0.ZodOptional<zod0.ZodObject<{ token: zod0.ZodString; nonce: zod0.ZodOptional<zod0.ZodString>; accessToken: zod0.ZodOptional<zod0.ZodString>; refreshToken: zod0.ZodOptional<zod0.ZodString>; expiresAt: zod0.ZodOptional<zod0.ZodNumber>; }, zod_v4_core0.$strip>>; scopes: zod0.ZodOptional<zod0.ZodArray<zod0.ZodString>>; requestSignUp: zod0.ZodOptional<zod0.ZodBoolean>; loginHint: zod0.ZodOptional<zod0.ZodString>; additionalData: zod0.ZodOptional<zod0.ZodRecord<zod0.ZodString, zod0.ZodAny>>; }, zod_v4_core0.$strip>; metadata: { $Infer: { body: zod0.infer<zod0.ZodObject<{ callbackURL: zod0.ZodOptional<zod0.ZodString>; newUserCallbackURL: zod0.ZodOptional<zod0.ZodString>; errorCallbackURL: zod0.ZodOptional<zod0.ZodString>; provider: zod0.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_core0.$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: zod0.ZodOptional<zod0.ZodBoolean>; idToken: zod0.ZodOptional<zod0.ZodObject<{ token: zod0.ZodString; nonce: zod0.ZodOptional<zod0.ZodString>; accessToken: zod0.ZodOptional<zod0.ZodString>; refreshToken: zod0.ZodOptional<zod0.ZodString>; expiresAt: zod0.ZodOptional<zod0.ZodNumber>; }, zod_v4_core0.$strip>>; scopes: zod0.ZodOptional<zod0.ZodArray<zod0.ZodString>>; requestSignUp: zod0.ZodOptional<zod0.ZodBoolean>; loginHint: zod0.ZodOptional<zod0.ZodString>; additionalData: zod0.ZodOptional<zod0.ZodRecord<zod0.ZodString, zod0.ZodAny>>; }, zod_v4_core0.$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; } & (Option extends BetterAuthOptions ? AdditionalUserFieldsOutput<Option> : Option extends Auth ? AdditionalUserFieldsOutput<Option["options"]> : {})>> | 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; } & (Option extends BetterAuthOptions ? AdditionalUserFieldsOutput<Option> : Option extends Auth ? AdditionalUserFieldsOutput<Option["options"]> : {})>>; }>; readonly callbackOAuth: better_call3.StrictEndpoint<"/callback/:id", { method: ("GET" | "POST")[]; operationId: string; body: zod0.ZodOptional<zod0.ZodObject<{ code: zod0.ZodOptional<zod0.ZodString>; error: zod0.ZodOptional<zod0.ZodString>; device_id: zod0.ZodOptional<zod0.ZodString>; error_description: zod0.ZodOptional<zod0.ZodString>; state: zod0.ZodOptional<zod0.ZodString>; user: zod0.ZodOptional<zod0.ZodString>; }, zod_v4_core0.$strip>>; query: zod0.ZodOptional<zod0.ZodObject<{ code: zod0.ZodOptional<zod0.ZodString>; error: zod0.ZodOptional<zod0.ZodString>; device_id: zod0.ZodOptional<zod0.ZodString>; error_description: zod0.ZodOptional<zod0.ZodString>; state: zod0.ZodOptional<zod0.ZodString>; user: zod0.ZodOptional<zod0.ZodString>; }, zod_v4_core0.$strip>>; metadata: { allowedMediaTypes: string[]; scope: "server"; }; }, void>; readonly getSession: better_call3.StrictEndpoint<"/get-session", { method: "GET"; operationId: string; query: zod0.ZodOptional<zod0.ZodObject<{ disableCookieCache: zod0.ZodOptional<zod0.ZodCoercedBoolean<unknown>>; disableRefresh: zod0.ZodOptional<zod0.ZodCoercedBoolean<unknown>>; }, zod_v4_core0.$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; } & (Option extends BetterAuthOptions ? AdditionalSessionFieldsOutput<Option> : Option extends Auth ? AdditionalSessionFieldsOutput<Option["options"]> : {})>>; user: UnionToIntersection<StripEmptyObjects<{ id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; } & (Option extends BetterAuthOptions ? AdditionalUserFieldsOutput<Option> : Option extends Auth ? AdditionalUserFieldsOutput<Option["options"]> : {})>>; } | null>; readonly signOut: better_call3.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_call3.StrictEndpoint<"/sign-up/email", { method: "POST"; operationId: string; body: zod0.ZodIntersection<zod0.ZodObject<{ name: zod0.ZodString; email: zod0.ZodEmail; password: zod0.ZodString; image: zod0.ZodOptional<zod0.ZodString>; callbackURL: zod0.ZodOptional<zod0.ZodString>; rememberMe: zod0.ZodOptional<zod0.ZodBoolean>; }, zod_v4_core0.$strip>, zod0.ZodRecord<zod0.ZodString, zod0.ZodAny>>; metadata: { $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; } & (Option extends BetterAuthOptions ? AdditionalUserFieldsOutput<Option> : Option extends Auth ? AdditionalUserFieldsOutput<Option["options"]> : {})>>; }; }; 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; } & (Option extends BetterAuthOptions ? AdditionalUserFieldsOutput<Option> : Option extends Auth ? AdditionalUserFieldsOutput<Option["options"]> : {})>>; } | { token: string; user: UnionToIntersection<StripEmptyObjects<{ id: string; createdAt: Date; updatedAt: Date; email: string; emailVerified: boolean; name: string; image?: string | null | undefined; } & (Option extends BetterAuthOptions ? AdditionalUserFieldsOutput<Option> : Option extends Auth ? AdditionalUserFieldsOutput<Option["options"]> : {})>>; }>; readonly signInEmail: better_call3.StrictEndpoint<"/sign-in/email", { method: "POST"; operationId: string; body: zod0.ZodObject<{ email: zod0.ZodString; password: zod0.ZodString; callbackURL: zod0.ZodOptional<zod0.ZodString>; rememberMe: zod0.ZodOptional<zod0.ZodDefault<zod0.ZodBoolean>>; }, zod_v4_core0.$strip>; metadata: { $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; } & (Option extends BetterAuthOptions ? AdditionalUserFieldsOutput<Option> : Option extends Auth ? AdditionalUserFieldsOutput<Option["options"]> : {})>>; }; }; 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; } & (Option extends BetterAuthOptions ? AdditionalUserFieldsOutput<Option> : Option extends Auth ? AdditionalUserFieldsOutput<Option["options"]> : {})>>; }>; readonly resetPassword: better_call3.StrictEndpoint<"/reset-password", { method: "POST"; operationId: string; query: zod0.ZodOptional<zod0.ZodObject<{ token: zod0.ZodOptional<zod0.ZodString>; }, zod_v4_core0.$strip>>; body: zod0.ZodObject<{ newPassword: zod0.ZodString; token: zod0.ZodOptional<zod0.ZodString>; }, zod_v4_core0.$strip>; metadata: { openapi: { operationId: string; description: string; responses: { "200": { description: string; content: { "application/json": { schema: { type: "object"; properties: { status: { type: string; }; }; }; }; }; }; }; }; }; }, { status: boolean; }>; readonly verifyEmail: better_call3.StrictEndpoint<"/verify-email", { method: "GET"; operationId: string; query: zod0.ZodObject<{ token: zod0.ZodString; callbackURL: zod0.ZodOptional<zod0.ZodString>; }, zod_v4_core0.$strip>; use: ((inputContext: better_call3.MiddlewareInputContext<better_call3.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_call3.StrictEndpoint<"/send-verification-email", { method: "POST"; operationId: string; body: zod0.ZodObject<{ email: zod0.ZodEmail; callbackURL: zod0.ZodOptional<zod0.ZodString>; }, zod_v4_core0.$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_call3.StrictEndpoint<"/change-email", { method: "POST"; body: zod0.ZodObject<{ newEmail: zod0.ZodEmail; callbackURL: zod0.ZodOptional<zod0.ZodString>; }, zod_v4_core0.$strip>; use: ((inputContext: better_call3.MiddlewareInputContext<better_call3.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_call3.StrictEndpoint<"/change-password", { method: "POST"; operationId: string; body: zod0.ZodObject<{ newPassword: zod0.ZodString; currentPassword: zod0.ZodString; revokeOtherSessions: zod0.ZodOptional<zod0.ZodBoolean>; }, zod_v4_core0.$strip>; use: ((inputContext: better_call3.MiddlewareInputContext<better_call3.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; email: string; name: string; image: string | null | undefined; emailVerified: boolean; createdAt: Date; updatedAt: Date; }; }>; readonly setPassword: better_call3.StrictEndpoint<string, { method: "POST"; body: zod0.ZodObject<{ newPassword: zod0.ZodString; }, zod_v4_core0.$strip>; use: ((inputContext: better_call3.MiddlewareInputContext<better_call3.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_call3.StrictEndpoint<"/update-user", { method: "POST"; operationId: string; body: zod0.ZodRecord<zod0.ZodString, zod0.ZodAny>; use: ((inputContext: better_call3.MiddlewareInputContext<better_call3.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_call3.StrictEndpoint<"/delete-user", { method: "POST"; use: ((inputContext: better_call3.MiddlewareInputContext<better_call3.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: zod0.ZodObject<{ callbackURL: zod0.ZodOptional<zod0.ZodString>; password: zod0.ZodOptional<zod0.ZodString>; token: zod0.ZodOptional<zod0.ZodString>; }, zod_v4_core0.$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_call3.StrictEndpoint<"/request-password-reset", { method: "POST"; body: zod0.ZodObject<{ email: zod0.ZodEmail; redirectTo: zod0.ZodOptional<zod0.ZodString>; }, zod_v4_core0.$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_call3.StrictEndpoint<"/reset-password/:token", { method: "GET"; operationId: string; query: zod0.ZodObject<{ callbackURL: zod0.ZodString; }, zod_v4_core0.$strip>; use: ((inputContext: better_call3.MiddlewareInputContext<better_call3.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_call3.StrictEndpoint<"/list-sessions", { method: "GET"; operationId: string; use: ((inputContext: better_call3.MiddlewareInputContext<better_call3.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; } & (Option extends BetterAuthOptions ? AdditionalSessionFieldsOutput<Option> : Option extends Auth ? AdditionalSessionFieldsOutput<Option["options"]> : {})>>>[]>; readonly revokeSession: better_call3.StrictEndpoint<"/revoke-session", { method: "POST"; body: zod0.ZodObject<{ token: zod0.ZodString; }, zod_v4_core0.$strip>; use: ((inputContext: better_call3.MiddlewareInputContext<better_call3.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_call3.StrictEndpoint<"/revoke-sessions", { method: "POST"; use: ((inputContext: better_call3.MiddlewareInputContext<better_call3.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_call3.StrictEndpoint<"/revoke-other-sessions", { method: "POST"; requireHeaders: true; use: ((inputContext: better_call3.MiddlewareInputContext<better_call3.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_call3.StrictEndpoint<"/link-social", { method: "POST"; requireHeaders: true; body: zod0.ZodObject<{ callbackURL: zod0.ZodOptional<zod0.ZodString>; provider: zod0.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_core0.$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>>; idToken: zod0.ZodOptional<zod0.ZodObject<{ token: zod0.ZodString; nonce: zod0.ZodOptional<zod0.ZodString>; accessToken: zod0.ZodOptional<zod0.ZodString>; refreshToken: zod0.ZodOptional<zod0.ZodString>; scopes: zod0.ZodOptional<zod0.ZodArray<zod0.ZodString>>; }, zod_v4_core0.$strip>>; requestSignUp: zod0.ZodOptional<zod0.ZodBoolean>; scopes: zod0.ZodOptional<zod0.ZodArray<zod0.ZodString>>; errorCallbackURL: zod0.ZodOptional<zod0.ZodString>; disableRedirect: zod0.ZodOptional<zod0.ZodBoolean>; additionalData: zod0.ZodOptional<zod0.ZodRecord<zod0.ZodString, zod0.ZodAny>>; }, zod_v4_core0.$strip>; use: ((inputContext: better_call3.MiddlewareInputContext<better_call3.MiddlewareOptions>) => Promise<{