Files
sub2api/backend/internal/server/middleware/admin_only.go

28 lines
549 B
Go
Raw Normal View History

2025-12-18 13:50:39 +08:00
package middleware
import (
"github.com/Wei-Shaw/sub2api/internal/service"
2025-12-18 13:50:39 +08:00
"github.com/gin-gonic/gin"
)
// AdminOnly 管理员权限中间件
// 必须在JWTAuth中间件之后使用
func AdminOnly() gin.HandlerFunc {
return func(c *gin.Context) {
role, ok := GetUserRoleFromContext(c)
if !ok {
2025-12-18 13:50:39 +08:00
AbortWithError(c, 401, "UNAUTHORIZED", "User not found in context")
return
}
// 检查是否为管理员
if role != service.RoleAdmin {
2025-12-18 13:50:39 +08:00
AbortWithError(c, 403, "FORBIDDEN", "Admin access required")
return
}
c.Next()
}
}