Skip to content
Migrating from NextAuth.js v4? Read our migration guide.
Guides
Pages
Built-in pages

Built-in Pages

Auth.js comes by default with a set of pages that are presented to the user as they go through their authentication journey (sign up, sign in, sign out, error, etc…). This is helpful so that you don’t need to write those from scratch when using the library first time. The UI created is based on the providers specified in your configuration file.

lib/providers.ts
import Github from "next-auth/providers/github"
import Credentials from "next-auth/providers/credentials"
import type { Provider } from "next-auth/providers"
 
export const providers: Provider[] = [
  Github,
  Credentials({
    credentials: {
      username: { label: "Username" },
      password: { label: "Password", type: "password" }
    },
    async authorize(credentials) {
      // mplement some logic to check if the user exists.
      return credentials
    }
  })
]
./auth.ts
import NextAuth from "next-auth"
import { providers } from "@/lib/providers"
 
export const { handlers, signIn, signOut, auth } = NextAuth({
  providers,
})

If you do not pass a providerId, the signIn function will redirect the user to the signin page.

Sign-in Page

In this case the app has been configured with GitHub and Credentials providers.

If we added the Google provider to our Auth.js config file (./auth.ts), then a 3rd option to sign in with Google would be available.

If you’d like to build your own sign in page, checkout our guide on custom sign-in pages.

Auth.js © Balázs Orbán and Team - 2024