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.
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.