mirror of
https://github.com/formbricks/formbricks.git
synced 2026-05-07 03:11:47 -05:00
70fe0fb7a7
Co-authored-by: Matti Nannt <mail@matthiasnannt.com> Co-authored-by: Johannes <72809645+jobenjada@users.noreply.github.com>
78 lines
2.1 KiB
TypeScript
78 lines
2.1 KiB
TypeScript
import {
|
|
clientSideApiEndpointsLimiter,
|
|
loginLimiter,
|
|
shareUrlLimiter,
|
|
signUpLimiter,
|
|
} from "@/app/middleware/bucket";
|
|
import {
|
|
clientSideApiRoute,
|
|
isWebAppRoute,
|
|
loginRoute,
|
|
shareUrlRoute,
|
|
signupRoute,
|
|
} from "@/app/middleware/endpointValidator";
|
|
import { getToken } from "next-auth/jwt";
|
|
import { NextResponse } from "next/server";
|
|
import type { NextRequest } from "next/server";
|
|
|
|
import { WEBAPP_URL } from "@formbricks/lib/constants";
|
|
|
|
export async function middleware(request: NextRequest) {
|
|
const token = await getToken({ req: request });
|
|
|
|
if (isWebAppRoute(request.nextUrl.pathname) && !token) {
|
|
return NextResponse.redirect(
|
|
WEBAPP_URL + "/auth/login?callbackUrl=" + WEBAPP_URL + request.nextUrl.pathname
|
|
);
|
|
}
|
|
|
|
const callbackUrl = request.nextUrl.searchParams.get("callbackUrl");
|
|
if (token && callbackUrl) {
|
|
return NextResponse.redirect(WEBAPP_URL + callbackUrl);
|
|
}
|
|
|
|
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",
|
|
"/environments/:path*",
|
|
"/api/auth/signout",
|
|
],
|
|
};
|