Files
formbricks/apps/web/middleware.ts
Anjy Gupta e05cfaba5f feat: added survey response sharing feature (#1469)
Co-authored-by: Matthias Nannt <mail@matthiasnannt.com>
Co-authored-by: Johannes <72809645+jobenjada@users.noreply.github.com>
Co-authored-by: Johannes <johannes@formbricks.com>
Co-authored-by: pandeymangg <anshuman.pandey9999@gmail.com>
2024-01-03 15:33:52 +00:00

59 lines
1.6 KiB
TypeScript

import {
clientSideApiEndpointsLimiter,
loginLimiter,
shareUrlLimiter,
signUpLimiter,
} from "@/app/middleware/bucket";
import {
clientSideApiRoute,
loginRoute,
shareUrlRoute,
signupRoute,
} from "@/app/middleware/endpointValidator";
import { NextResponse } from "next/server";
import type { NextRequest } from "next/server";
export async function middleware(request: NextRequest) {
if (process.env.NODE_ENV !== "production") {
return NextResponse.next();
}
const res = NextResponse.next();
let ip = request.ip ?? request.headers.get("x-real-ip");
const forwardedFor = request.headers.get("x-forwarded-for");
if (!ip && forwardedFor) {
ip = forwardedFor.split(",").at(0) ?? null;
}
if (ip) {
try {
if (loginRoute(request.nextUrl.pathname)) {
await loginLimiter.check(ip);
} else if (signupRoute(request.nextUrl.pathname)) {
await signUpLimiter.check(ip);
} else if (clientSideApiRoute(request.nextUrl.pathname)) {
await clientSideApiEndpointsLimiter.check(ip);
} else if (shareUrlRoute(request.nextUrl.pathname)) {
await shareUrlLimiter.check(ip);
}
return res;
} catch (_e) {
console.log("Rate Limiting IP: ", ip);
return NextResponse.json({ error: "Too many requests, Please try after a while!" }, { status: 429 });
}
}
return res;
}
export const config = {
matcher: [
"/api/auth/callback/credentials",
"/api/v1/users",
"/api/(.*)/client/:path*",
"/api/v1/js/actions",
"/api/v1/client/storage",
"/share/(.*)/:path",
],
};