Token based authentication with Auth.js
This guide will show you how to enable token based authentication with Auth.js (NextAuth) in an existing Next.js + WunderGraph application.
Requirements
Before starting you need to have a Next.js application with NextAuth.js installed and configured. If you don't have one, you can follow the NextAuth.js documentation to create one.
Make sure you have enabled the jwt
session strategy. You can find more information about the jwt
strategy in the NextAuth.js documentation .
Create userInfo endpoint
First, we need to create an endpoint that returns the user information. This endpoint will be called by WunderGraph to fetch the user information.
Create pages/api/auth/userInfo.ts
in your Next.js application.
Configure WunderGraph
wundergraph.config.ts
Add a token-based authentication provider to your wundergraph.config.ts
file and configure the userInfoEndpoint
to fetch the user information from the NextAuth.js session. This will point to an Next.js api route that we will create later.
Note that we have added the configuration for token based authentication. We are using the userInfoEndpoint
to fetch the user information from the NextAuth.js session. The userInfoEndpoint
is called with the Authorization
header containing the JWT token that we will setup later.
This also assumes that you have installed NextAuth in pages/api/auth/[...nextauth].ts
, if you use another path you need to adjust the userInfoEndpoint
accordingly.
wundergraph.operations.ts
Next, we can enable authentication for all operations.
Configure Next.js with middleware
The last step is to make sure we forward the session token to the WunderGraph API. We will do this using Next.js middleware, with the middleware we can add the NextAuth session token to the Authorization
header and forward it to WunderGraph.
If you don't want to use Next.js middleware you can also use the useAuthMiddleware
hook to inject the token into the Authorization
header. Continue reading in the next step.
Create middelware.ts
in the root of your Next.js application.
What happens now is that all requests to http://localhost:3000/api/wg/*
will be rewritten to our WunderGraph API at http://127.0.0.1:9991/api/*
with the NextAuth session token added to the Authorization
header.
WunderGraph will add the Authorization
header to the userInfoEndpoint request which will return the user information if the token is valid and the request will be authenticated.
Configure Next.js useAuthMiddleware
If you don't want to use middleware you can also use the useAuthMiddleware
middleware to inject the token into the Authorization
header.