better-auth
Version:
The most comprehensive authentication framework for TypeScript.
1,457 lines (1,455 loc) • 125 kB
text/typescript
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<{