The getAuth() helper retrieves authentication state from the request object. See the Next.js reference documentation for more examples on how to use the returned auth object.
The getAuth() helper can be used to protect routes based on authentication status, authorization status, and token type. It also offers more granular control over how to handle unauthenticated users - you can redirect them to the sign-in page, return a 401 status code, or perform whatever action you need. Unlike requireAuth(), it can be used to protect API routes.
Quiz
When should you use getAuth() instead of requireAuth()?
The requireAuth() helper protects a route based on authentication status, and redirects unauthenticated users to the sign-in page. It can only be used in full-stack applications, and cannot be used to protect API routes. The getAuth() helper offers more options for protecting routes, more granular control over how to protect them, and can be used to protect API routes.
The following example uses getAuth() to protect the route based on authentication status.
import { clerkMiddleware, getAuth } from'@clerk/express'import express from'express'constapp=express()constPORT=3000// Apply `clerkMiddleware()` to all routesapp.use(clerkMiddleware())// Use `getAuth()` to protect a route based on authentication statusapp.get('/path', (req, res) => {constauth=getAuth(req)if (!auth.isAuthenticated) {returnres.status(401).send('User not authenticated') }returnres.json(auth)})app.listen(PORT, () => {console.log(`Server is running on http://localhost:${PORT}`)})
The following example demonstrates how to use requireAuth() and getAuth() together. requireAuth() protects the route based on authentication status while getAuth() protects the route based on authorization status. It also demonstrates how to use both clerkMiddleware() and requireAuth() together, as clerkMiddleware() will provide authentication state to routes that don't use requireAuth().
import { clerkMiddleware, getAuth, requireAuth } from'@clerk/express'import express from'express'constapp=express()constPORT=3000// Apply `clerkMiddleware()` to all routesapp.use(clerkMiddleware())// Use `getAuth()` to protect a route based on authorization statusconsthasPermission= (req, res, next) => {constauth=getAuth(req)// Handle if the user is not authorizedif (!auth.has({ permission:'org:admin:example' })) {returnres.status(403).send('Forbidden') }returnnext()}// Use `requireAuth()` to protect a route based on authentication status// If user is not authenticated, requireAuth() will redirect back to the homepage// Then, use the `hasPermission` function created above to protect the route based on authorization statusapp.get('/path',requireAuth(), hasPermission, (req, res) =>res.json(req.auth))// Start the server and listen on the specified portapp.listen(PORT, () => {console.log(`Server is running on http://localhost:${PORT}`)})
For more examples on how to use getAuth() to perform authorization checks, see the dedicated guide.
The following example uses getAuth() to protect the route based on token type:
It accepts any token type (acceptsToken: 'any') from the request.
If the token is a session_token, it logs that the request is from a user session.
Otherwise, it logs that the request uses a machine token and specifies its type.
import express from'express'import { clerkMiddleware, getAuth } from'@clerk/express'constapp=express()constPORT=3000// Apply `clerkMiddleware()` to all routesapp.use(clerkMiddleware())app.get('/path', (req, res) => {// Use `getAuth()` to protect a route based on token typeconstauthObject=getAuth(req, { acceptsToken:'any' })if (authObject.tokenType ==='session_token') {console.log('This is a session token from a user') } else {console.log(`This is a ${authObject.tokenType} token`) }})