Route Protection from DDoS
Unanswered
Japanese flying squid posted this in #help-forum
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
I've API route /api/keepz/pay -which connects with external payment provider API.
And someone is spamming this request from my website, please tell me how can I control it. I will attack route handler in picture. This route is triggered on button press but someone is doing it programatically or something.
And someone is spamming this request from my website, please tell me how can I control it. I will attack route handler in picture. This route is triggered on button press but someone is doing it programatically or something.
data:image/s3,"s3://crabby-images/dfb3c/dfb3cb61a74d3128349747e6365f5b933810f67a" alt="Image"
25 Replies
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
BTW. it would be great if I could make something work for every API reuqest, based on user
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Japanese flying squid BTW. it would be great if I could make something work for every API reuqest, based on user
data:image/s3,"s3://crabby-images/0f086/0f0866fc98bf5cc77cf094d64f4a39becda930c0" alt="Avatar"
you need to setup ratelimiting. https://upstash.com/blog/nextjs-ratelimiting
this is an older example using API routes but you can modify it for your current code
this is an older example using API routes but you can modify it for your current code
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
I've set up IP based rate limiting, they can't send requests from same client mutliple time, only once in 30s. But someone is sending requesrs from multiple devices so IP is different, like in DDoS Attack. This route is public, can't restrict it with authorization or something
What If I make checkbox like "I am human" and if they check it, I will include JWT token for that request, and I will make it protected by token? They can spam my route but not the external payment API ( that's the whole reason to protect external API, not mine )
data:image/s3,"s3://crabby-images/0f086/0f0866fc98bf5cc77cf094d64f4a39becda930c0" alt="Avatar"
yea that will work
but
if your system calls it on a button press, you can surely add authorization
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
Yes, but someone can just send API request from console and spam it
this is the only way to protect your route if u dont have authorization
literally everything else is bypassable
people can just change headers
so anybody can just randomize headers and spam your api, it will look like a ddos
and only cloudflare can also be bypassed easily, thats why cloudflare has also captcha solutions
use turnstile for captcha
recaptcha from google is easier to bypass
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
Thank you so much
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
@gin variables added in .env without NEXT_PUBLIC ( in production on Vercel environment), is there a chance somehow they can leak? I am using env variables inside server API routes only, only one of them have NEXT_PUBLIC
if u make sure those variables are not included somewhere in your client components or anywhere where it could leak its fine
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
in client components variables without next_public, are accessible?
I have them in api routes only
I have them in api routes only
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
thank you