32 lines
622 B
Go
32 lines
622 B
Go
package middleware
|
|
|
|
import (
|
|
"gitea.zjmud.xyz/phyer/rbac/utils"
|
|
"github.com/gin-gonic/gin"
|
|
)
|
|
|
|
// JWTAuth is an alias for AuthMiddleware
|
|
func JWTAuth() gin.HandlerFunc {
|
|
return AuthMiddleware()
|
|
}
|
|
|
|
func AuthMiddleware() gin.HandlerFunc {
|
|
return func(c *gin.Context) {
|
|
token := c.GetHeader("Authorization")
|
|
if token == "" {
|
|
c.AbortWithStatusJSON(401, gin.H{"error": "Unauthorized"})
|
|
return
|
|
}
|
|
|
|
claims, err := utils.ParseJWT(token)
|
|
if err != nil {
|
|
c.AbortWithStatusJSON(401, gin.H{"error": "Invalid token"})
|
|
return
|
|
}
|
|
|
|
userID := claims["user_id"].(string)
|
|
c.Set("userID", userID)
|
|
c.Next()
|
|
}
|
|
}
|