Supabase
Learn how to integrate Authsignal when using Supabase.
This guide shows how to integrate Authsignal with Next.js and Supabase in order to add an MFA after sign-in.
The user flow is as follows:
- The user enters their email and password to sign in
- If the user has set up MFA, they’re prompted to complete an MFA challenge (via Authenticator App) in order to complete sign-in
- If the user has not set up MFA, they’re signed in immediately and will see a button to set up MFA
The approach uses a temporary encrypted cookie to ensure that the Supabase auth cookies - access_token
and refresh_token
- are only set if the MFA challenge was successful. Session data is encrypted using @hapi/iron.
How it works
- A sign-in form posts email and password to the Next.js API route
/api/sign-in
- The
signIn
API route calls the Supabase client’ssignInWithEmail
method and gets back a session object - The
signIn
API route then calls the Authsignal client’strack
method to determine if an MFA challenge is required - If a challenge is required, the
signIn
API route saves the session object in a temporary encrypted cookie and redirects to Authsignal - Once the challenge is completed, Authsignal redirects back to
/api/callback
which retrieves the session and sets the Supabase auth cookies - The
callback
API route then redirects to the index page which is protected with Supabase’swithPageAuth
wrapper aroundgetServerSideProps
1: Configuring an Authsignal tenant
Go to the Authsignal Portal and create a new project and tenant.
You will also need to enable at least one authenticator for your tenant - for example Authenticator Apps.
Finally, go the sign-in action settings and set the default action outcome to Challenge
and click Save.
2: Creating a Supabase project
From your Supabase dashboard, click New project
.
Enter a Name
for your Supabase project and enter or generate a secure Database Password
, then click Create new project
.
Once your project is created go to Authentication -> Settings -> Auth Providers
and ensure Enable Email provider
is checked and that Confirm Email
is unchecked.
3: Building a Next.js app
Create a new Next.js project:
Create a .env.local
file and enter the following values:
Supabase values can be found under Settings > API
for your project.
Authsignal values can be found under Settings > API Keys
for your tenant.
TEMP_TOKEN_SECRET
is used to encrypt the temporary cookie. Set it to a random 32 character length string.
Restart your Next.js development server to read in the new values from .env.local
.
4: Installing dependencies
Install the Supabase client and Auth helpers for Next.js:
Install the Authsignal Node.js client:
Finally install 2 packages to help encrypt and serialize session data in cookies:
5: Initializing the Authsignal client
Add the following code to /lib/authsignal.ts
:
6: Managing session data in cookies
Next we will add some helper functions for managing cookies:
setTempCookie
encrypts and serializes the Supabase session data and sets it in a temporary cookiegetSessionFromTempCookie
decrypts and parses this session data back from the cookiesetAuthCookie
sets the Supabase auth cookies (access_token
andrefresh_token
) and clears the temporary cookie
Add the following code to /lib/cookies.ts
:
Then add the following to /lib/index.ts
:
7: Building the UI
We will add some form components for signing in and signing up as well as a basic home page.
Add the following code to /pages/sign-up.tsx
:
Then add the following code to /pages/sign-in.tsx
:
Now we will use Supabase’s withPageAuth
wrapper around getServerSideProps
to make the home page require authentication via SSR. Replace the existing code in /pages/index.tsx
with the following:
Optional: To make things look a bit nicer, you can add the following to /styles/globals.css
:
8: Adding the API routes
Now we’ll replace the existing api routes in /pages/api/
with 4 new routes:
/sign-in.ts
: handles signing in with Supabase and initiating the MFA challenge with Authsignal/sign-up.ts
: handles signing up with Supabase/sign-out.ts
: clears the Supabase auth cookies and signs the user out/mfa.ts
: handles the user’s attempt to set up MFA or to manage their existing MFA settings/callback.ts
: handles completing the MFA challenge with Authsignal
Add the following code to /pages/api/sign-in.ts
:
Then to handle new sign-ups add the following to /pages/api/sign-up.ts
:
To clear the auth cookies on sign-out add the following to /pages/api/sign-out.ts
:
To handle the user’s actions to set up MFA or manage their existing MFA settings, add the following to /pages/api/mfa.ts
:
Because the user should be authenticated with Supabase to set up or manage MFA, we can use Supabase’s withApiAuth
wrapper to protect this route.
The redirectToSettings
param specifies whether the user should be redirected to the Challenge UI settings panel after a challenge, rather than redirecting them immediately back to the application.
Finally we need a route to handle the redirect back from Authsignal after an MFA challenge. Add the following to /pages/api/callback.ts
:
That’s it! You should now be able to sign up a new user and set up MFA.
Then if you sign out, you’ll be prompted to complete an MFA challenge when signing back in again.
Was this page helpful?