Better Auth Core (TypeScript)
Goals
- •Set up a Better Auth instance with environment variables and data layer wiring.
- •Wire server handlers and a client instance.
- •Use sessions and server-side API methods safely.
- •Keep data-layer choices pluggable (drivers or adapters).
Quick start
- •Install
better-auth. - •Set
BETTER_AUTH_SECRET(32+ chars) andBETTER_AUTH_URL. - •Create
auth.tsand exportauth. - •Provide
database(driver or adapter) or omit for stateless sessions. - •Mount a handler (
auth.handleror a framework helper). - •Create a client with
createAuthClient.
ts
import { betterAuth } from "better-auth";
export const auth = betterAuth({
database: myDatabaseOrAdapter, // driver or adapter; omit for stateless mode
emailAndPassword: { enabled: true },
socialProviders: {
github: {
clientId: process.env.GITHUB_CLIENT_ID as string,
clientSecret: process.env.GITHUB_CLIENT_SECRET as string,
},
},
});
Core setup checklist
- •Export the instance as
auth(or default export) so helpers find it. - •Keep
BETTER_AUTH_URLin sync with the public base URL. - •Pass the full base URL to the client if you change the
/api/authbase path. - •Add database migrations before enabling plugins that require tables.
Server API usage
- •Call server endpoints via
auth.api.*with{ body, headers, query }. - •Use
asResponse: trueif you need aResponseobject. - •Use
returnHeaders: trueto accessSet-Cookieheaders.
ts
import { auth } from "./auth";
const session = await auth.api.getSession({
headers: request.headers,
});
const response = await auth.api.signInEmail({
body: { email, password },
asResponse: true,
});
Session access
- •Client:
authClient.useSession()orauthClient.getSession(). - •Server:
auth.api.getSession({ headers }).
TypeScript tips
- •Infer types with
auth.$InferandauthClient.$Infer. - •Use
inferAdditionalFieldson the client when you extend the user schema.
References
- •
toolchains/platforms/auth/better-auth/better-auth-core/references/setup-database.md - •
toolchains/platforms/auth/better-auth/better-auth-core/references/client-server.md - •
toolchains/platforms/auth/better-auth/better-auth-core/references/typescript.md