import { auth } from "@/lib/auth" import { NextResponse } from "next/server" import { PERMISSIONS } from "@/lib/permissions" import { checkPermission } from "@/lib/auth" import { Permission } from "@/lib/permissions" const API_PERMISSIONS: Record = { '/api/emails': PERMISSIONS.MANAGE_EMAIL, '/api/webhook': PERMISSIONS.MANAGE_WEBHOOK, '/api/roles/promote': PERMISSIONS.PROMOTE_USER, } export async function middleware(request: Request) { const session = await auth() const pathname = new URL(request.url).pathname if (!session?.user) { return NextResponse.json( { error: "未授权" }, { status: 401 } ) } for (const [route, permission] of Object.entries(API_PERMISSIONS)) { if (pathname.startsWith(route)) { const hasAccess = await checkPermission(permission) if (!hasAccess) { return NextResponse.json( { error: "权限不足" }, { status: 403 } ) } break } } return NextResponse.next() } export const config = { matcher: [ '/api/emails/:path*', '/api/webhook/:path*', '/api/roles/:path*', ] }