TypeScript icon, indicating that this package has built-in type declarations

4.0.0-next.4 • Public • Published


Authentication for Next.js

Open Source. Full Stack. Own Your Data.

Release Integration Test Bundle Size Downloads Github Stars Github Stable Release Github Prelease


NextAuth.js is a complete open source authentication solution for Next.js applications.

It is designed from the ground up to support Next.js and Serverless.

Getting Started

npm install --save next-auth

The easiest way to continue getting started, is to follow the getting started section in our docs.

We also have a section of tutorials for those looking for more specific examples.

See for more information and documentation.


Flexible and easy to use

  • Designed to work with any OAuth service, it supports OAuth 1.0, 1.0A and 2.0
  • Built-in support for many popular sign-in services
  • Supports email / passwordless authentication
  • Supports stateless authentication with any backend (Active Directory, LDAP, etc)
  • Supports both JSON Web Tokens and database sessions
  • Designed for Serverless but runs anywhere (AWS Lambda, Docker, Heroku, etc…)

Own your own data

NextAuth.js can be used with or without a database.

  • An open source solution that allows you to keep control of your data
  • Supports Bring Your Own Database (BYOD) and can be used with any database
  • Built-in support for MySQL, MariaDB, Postgres, Microsoft SQL Server, MongoDB and SQLite
  • Works great with databases from popular hosting providers
  • Can also be used without a database (e.g. OAuth + JWT)

Secure by default

  • Promotes the use of passwordless sign in mechanisms
  • Designed to be secure by default and encourage best practice for safeguarding user data
  • Uses Cross Site Request Forgery Tokens on POST routes (sign in, sign out)
  • Default cookie policy aims for the most restrictive policy appropriate for each cookie
  • When JSON Web Tokens are enabled, they are signed by default (JWS) with HS512
  • Use JWT encryption (JWE) by setting the option encryption: true (defaults to A256GCM)
  • Auto-generates symmetric signing and encryption keys for developer convenience
  • Features tab/window syncing and keepalive messages to support short lived sessions
  • Attempts to implement the latest guidance published by Open Web Application Security Project

Advanced options allow you to define your own routines to handle controlling what accounts are allowed to sign in, for encoding and decoding JSON Web Tokens and to set custom cookie security policies and session properties, so you can control who is able to sign in and how often sessions have to be re-validated.


You can install the appropriate types via the following command:

npm install --save-dev @types/next-auth

As of now, TypeScript is a community effort. If you encounter any problems with the types package, please create an issue at DefinitelyTyped. Alternatively, you can open a pull request directly with your fixes there. We welcome anyone to start a discussion on migrating this package to TypeScript, or how to improve the TypeScript experience in general.


Add API Route

import NextAuth from 'next-auth'
import Providers from 'next-auth/providers'

export default NextAuth({
  providers: [
    // OAuth authentication providers
      clientId: process.env.APPLE_ID,
      clientSecret: process.env.APPLE_SECRET
      clientId: process.env.GOOGLE_ID,
      clientSecret: process.env.GOOGLE_SECRET
    // Sign in with passwordless email link
      server: process.env.MAIL_SERVER,
      from: '<>'
  // SQL or MongoDB database (or leave empty)
  database: process.env.DATABASE_URL

Add React Component

import {
  useSession, signIn, signOut
} from 'next-auth/client'

export default function Component() {
  const [ session, loading ] = useSession()
  if(session) {
    return <>
      Signed in as {} <br/>
      <button onClick={() => signOut()}>Sign out</button>
  return <>
    Not signed in <br/>
    <button onClick={() => signIn()}>Sign in</button>


NextAuth.js is made possible thanks to all of its contributors.

Thanks to Vercel sponsoring this project by allowing it to be deployed for free for the entire NextAuth.js Team


We're open to all community contributions! If you'd like to contribute in any way, please first read our Contributing Guide.




npm i next-auth@4.0.0-next.4





Unpacked Size

216 kB

Total Files


Last publish


  • iaincollins
  • balazsorban
  • thvu