Arcjet / NextAuth integration
Arcjet can protect your NextAuth login and signup routes from brute force attacks and other abuse. You can also use the Auth.js authenticated user ID to implement user-specific rate limits.
What is Arcjet?
Arcjet helps developers protect their apps in just a few lines of code. Implement rate limiting, bot protection, email validation, and defense against common attacks.Example use case
- Protect your NextAuth route handlers by rate limiting requests and blocking bots.
- Limit access to a free API endpoint based on the client IP address.
- Provide a higher rate limit for authenticated clients based on their NextAuth user ID.
See an example Next.js implementation on GitHub.
Protect NextAuth route handlers
Arcjet can extend the NextAuth route handler to protect it from abuse.
This example configures a rate limit on the NextAuth route POST
handler which
is used for authentication and logout attempts. It allows up to 10 requests
within a 60 second window and also prevents bots from making requests.
NextAuth recommends creating a catch-all API route to handle all authentication requests. Arcjet extends this handler:
NextAuth recommends creating a catch-all API route to handle all authentication requests. Arcjet extends this handler:
Rate limits using NextAuth user ID
Arcjet rate limits allow custom
characteristics to
identify the client and apply the limit. Using NextAuth’s
getServerSession()
helpers you can pass through a user ID.