duckil_plm/fems-app/src/middleware.tsx

39 lines
1.1 KiB
TypeScript
Raw Normal View History

2024-11-02 18:01:31 +09:00
// src/middleware.ts
import { NextResponse } from "next/server";
import type { NextRequest } from "next/server";
import { decodeToken } from "@/lib/jwt";
import type { UserRole } from "@/types/auth";
function getUserRole(token: string | undefined): UserRole | null {
if (!token) return null;
const decodedToken = decodeToken(token);
return decodedToken?.role || null;
}
export function middleware(request: NextRequest) {
const token = request.cookies.get("token")?.value;
// 비인증 사용자는 로그인 페이지로
2024-11-04 17:51:38 +09:00
if (!token && !request.nextUrl.pathname.startsWith("/")) {
return NextResponse.redirect(new URL("/", request.url));
2024-11-02 18:01:31 +09:00
}
// 권한별 접근 제어
if (request.nextUrl.pathname.startsWith("/admin")) {
const role = getUserRole(token);
if (
!role ||
!["super_admin", "company_admin", "branch_admin", "user"].includes(role)
) {
return NextResponse.redirect(new URL("/dashboard/overview", request.url));
}
}
return NextResponse.next();
}
export const config = {
matcher: ["/((?!api|_next/static|_next/image|favicon.ico).*)"],
};