Skip to Content
Clerk logo

Clerk Docs

Ctrl + K
Go to clerkstage.dev

authenticateRequest()

Authenticates a token passed from the frontend. Networkless if the secretKey or jwtKey are provided. Otherwise, performs a network call to retrieve the JWKS from Clerk's Backend API.

const authStatus = await clerkClient.authenticateRequest();

`authenticateRequest() params

NameTypeDescription
requestRequestRequest object
options?AuthenticateRequestOptionsOptional options to configure the authentication.

AuthenticateRequestOptions

NameTypeDescription
secretKey?stringThe Clerk secret key from the API Keys page in the Clerk Dashboard.
publishableKey?stringThe Clerk publishable key from the API Keys page in the Clerk Dashboard.
domain?stringThe domain for the application. For development, you can pass the localhost your application is running on. For example: localhost:3001
isSatellite?booleanSet to true if the instance is a satellite domain in a multi-domain setup.
proxyUrl?stringThe proxy URL from a multi-domain setup.
signInUrl?stringThe sign-in URL from a multi-domain setup.
afterSignInUrl?stringThe URL to navigate after sign-in completion. Defaults to /.
signUpUrl?stringThe sign-up URL from a multi-domain setup.
afterSignUpUrl?stringThe URL to navigate after sign-up completion. Defaults to /.
jwtKey?stringThe PEM public key from the API Keys page -> Advanced -> JWT public key section of the Clerk Dashboard.
audience?string | string[]A string of list of audiences.
authorizedPartiesstring[]
clockSkewInMs?numberSpecifies the allowed time difference (in milliseconds) between the Clerk server (which generates the token) and the clock of the user's application server when validating a token. Defaults to 5000 ms (5 seconds).
jwksCacheTtlInMs?numberSpecifies the allowed time (in milliseconds) the JWKs are considered valid in cache . Defaults to 3600_000 ms (1 hour).
skipJwksCache?booleanA flag to skip ignore cache and always fetch JWKs before each jwt verification.

Examples

authenticateRequest(request)

Takes the token passed by the frontend as a Bearer token in the Authorization header, and performs a networkless authenication. This will verify if the user is logged into the application or not.

import { clerkClient } from '@clerk/nextjs' import { NextRequest, NextResponse } from 'next/server' export async function GET(req: NextRequest) { const { isSignedIn } = await clerkClient.authenticateRequest(req) if ( !isSignedIn ) { return NextResponse.json({ status: 401 }) } // Perform protected actions return NextResponse.json({ message: "This is a reply" }, status: { 200 }) }

What did you think of this content?

Clerk © 2024