mirror of
https://github.com/crawlab-team/crawlab.git
synced 2026-01-22 17:31:03 +01:00
65 lines
1.5 KiB
Go
65 lines
1.5 KiB
Go
package middlewares
|
|
|
|
import (
|
|
"errors"
|
|
"github.com/crawlab-team/crawlab/core/constants"
|
|
"github.com/crawlab-team/crawlab/core/models/models"
|
|
"github.com/crawlab-team/crawlab/core/models/service"
|
|
"github.com/crawlab-team/crawlab/core/user"
|
|
"github.com/crawlab-team/crawlab/core/utils"
|
|
"github.com/gin-gonic/gin"
|
|
"go.mongodb.org/mongo-driver/bson"
|
|
)
|
|
|
|
func AuthorizationMiddleware() gin.HandlerFunc {
|
|
userSvc, _ := user.GetUserService()
|
|
return func(c *gin.Context) {
|
|
// disable auth for test
|
|
if utils.IsAuthDisabled() {
|
|
u, err := service.NewModelService[models.User]().GetOne(bson.M{"username": constants.DefaultAdminUsername}, nil)
|
|
if err != nil {
|
|
utils.HandleErrorInternalServerError(c, err)
|
|
return
|
|
}
|
|
c.Set(constants.UserContextKey, u)
|
|
c.Next()
|
|
return
|
|
}
|
|
|
|
// token string
|
|
tokenStr := utils.GetAPITokenFromContext(c)
|
|
|
|
// validate token
|
|
u, err := userSvc.CheckToken(tokenStr)
|
|
if err != nil {
|
|
// validation failed, return error response
|
|
utils.HandleErrorUnauthorized(c, errors.New("invalid token"))
|
|
return
|
|
}
|
|
|
|
// set user in context
|
|
c.Set(constants.UserContextKey, u)
|
|
|
|
// validation success
|
|
c.Next()
|
|
}
|
|
}
|
|
|
|
func SyncAuthorizationMiddleware() gin.HandlerFunc {
|
|
return func(c *gin.Context) {
|
|
if utils.IsAuthDisabled() {
|
|
c.Next()
|
|
return
|
|
}
|
|
|
|
authKey := c.GetHeader("Authorization")
|
|
|
|
if authKey != utils.GetAuthKey() {
|
|
utils.HandleErrorUnauthorized(c, errors.New("invalid auth key"))
|
|
return
|
|
}
|
|
|
|
c.Next()
|
|
}
|
|
}
|