Next.js App Router Reference
This library should be used if you are using Next.js as BOTH a frontend and a backend. Meaning, you are using Server Side Rendering (SSR).
This means you are using Server Components, Route Handlers, and/or Server Actions.
If you are using Next.js as a frontend, you should prefer the React library.
Automatic Installation
Begin by installing the PropelAuth CLI:
npm i -g @propelauth/cli
Logging into the PropelAuth CLI
Before we install PropelAuth in your Next.js project we first have to log into the CLI. If you haven't already created an account in PropelAuth, navigate to auth.propelauth.com to get started.
Once you have an account with PropelAuth, run this command to login to the CLI:
propelauth login
To login you'll be prompted to create and copy/paste a Personal API Key into your terminal.
┌ ⚡ PropelAuth Login
│
●
│ Please visit the following URL to create a personal API key:
│
● https://auth.propelauth.com/api_keys/personal
│
│
◆ Enter your API key
│ # enter your API key here
└
You can create a Personal API Key by navigating to https://auth.propelauth.com/api_keys/personal and clicking + New API Key.
Selecting a Default Project
Once your API Key is validated the CLI will prompt you to select a default project, if desired. If you select a default project, the CLI will not prompt you to select a project again until you repeat the login process or run the set-default-project
command.
┌
◇ ✓ Projects fetched successfully
│
◆ Select a project to use
│ ● Always ask which project to use (You will be prompted for each command)
│ ○ Acme Inc / New Project
└
Installing and Setting up PropelAuth in Next.js
Once you have logged into the CLI it's time to install PropelAuth within your Next.js app! Navigate to your Next.js project directory and run the following command:
propelauth setup
During installation you'll see the following prompts:
┌ ⚡ PropelAuth Setup
│
◆ Select your project framework:
│ ● Next.js (App Router) (Uses app/ directory structure, introduced in Next.js 13)
│ ○ Next.js (Pages Router)
│
◆ Select a project to use for this command
│ ● Acme Inc / New Project
│
◆ Enter the URL your Next.js app runs on:
│ ↳ http://localhost:3000
│
● No API key found in environment file
│
◆ Would you like to generate a new Backend Integration API Key for this project?
│ ● yes / ○ no
│
│ Enter a name for the new Backend Integration API Key:
│ ↳ Next.js Integration
│
● Updates needed for the Frontend Integration settings for your test environment
│ - Login redirect path: / → /api/auth/callback
│ - Logout redirect path: / → /api/auth/logout
│ - Development URL: none → http://localhost:3000
│
◆ Your test environment config needs to be updated, would you like to apply these changes now?
│ ● yes / ○ no
│
◆ Install @propelauth/nextjs now?
│ ● npm install @propelauth/nextjs (detected)
│ ○ yarn add @propelauth/nextjs
│ ○ pnpm install @propelauth/nextjs
│ ○ bun install @propelauth/nextjs
│ ○ Skip installation
│
● Root layout with AuthProvider at /src/app/layout.tsx differs from what we expected.
│
◆ Overwrite Root layout with AuthProvider?
│ ● Yes / ○ No
│
└ PropelAuth has been successfully set up in your Next.js project!
Once the CLI has successfully installed PropelAuth within your Next.js project it will also include some example components to help you get started.
import { getUserOrRedirect } from "@propelauth/nextjs/server/app-router";
const WelcomeMessage = async () => {
const user = await getUserOrRedirect()
return <div>Welcome, {user.email}!</div>
}
export default WelcomeMessage;
And you're all setup! Wondering what to do next? We have plenty of documentation around Server Components Functions, Client Components Hooks, as well as Role Based Access Control.