alist/server/middlewares/auth.go

77 lines
1.7 KiB
Go
Raw Normal View History

2022-06-25 13:34:44 +00:00
package middlewares
import (
2022-06-29 08:08:55 +00:00
"github.com/alist-org/alist/v3/internal/conf"
2022-06-26 11:09:28 +00:00
"github.com/alist-org/alist/v3/internal/model"
"github.com/alist-org/alist/v3/internal/op"
2022-06-28 06:18:10 +00:00
"github.com/alist-org/alist/v3/internal/setting"
2022-06-28 10:12:53 +00:00
"github.com/alist-org/alist/v3/server/common"
2022-06-25 13:34:44 +00:00
"github.com/gin-gonic/gin"
2022-07-23 13:33:53 +00:00
log "github.com/sirupsen/logrus"
2022-06-25 13:34:44 +00:00
)
2022-06-26 08:39:02 +00:00
// Auth is a middleware that checks if the user is logged in.
// if token is empty, set user to guest
func Auth(c *gin.Context) {
2022-06-25 13:34:44 +00:00
token := c.GetHeader("Authorization")
2022-09-06 06:39:21 +00:00
if token == setting.GetStr(conf.Token) {
admin, err := op.GetAdmin()
2022-06-28 06:18:10 +00:00
if err != nil {
2022-06-28 10:12:53 +00:00
common.ErrorResp(c, err, 500)
2022-06-28 06:18:10 +00:00
c.Abort()
return
}
c.Set("user", admin)
2022-07-23 13:33:53 +00:00
log.Debugf("use admin token: %+v", admin)
2022-06-28 06:18:10 +00:00
c.Next()
return
}
2022-06-26 08:39:02 +00:00
if token == "" {
guest, err := op.GetGuest()
if err != nil {
2022-06-28 10:12:53 +00:00
common.ErrorResp(c, err, 500)
c.Abort()
return
}
if guest.Disabled {
common.ErrorStrResp(c, "Guest user is disabled, login please", 401)
c.Abort()
return
}
2022-06-26 08:39:02 +00:00
c.Set("user", guest)
2022-07-23 13:33:53 +00:00
log.Debugf("use empty token: %+v", guest)
2022-06-26 08:39:02 +00:00
c.Next()
return
}
2022-06-28 10:12:53 +00:00
userClaims, err := common.ParseToken(token)
2022-06-25 13:34:44 +00:00
if err != nil {
2022-06-28 10:12:53 +00:00
common.ErrorResp(c, err, 401)
2022-06-25 13:34:44 +00:00
c.Abort()
return
}
user, err := op.GetUserByName(userClaims.Username)
2022-06-25 13:34:44 +00:00
if err != nil {
2022-06-28 10:12:53 +00:00
common.ErrorResp(c, err, 401)
2022-06-25 13:34:44 +00:00
c.Abort()
return
}
if user.Disabled {
common.ErrorStrResp(c, "Current user is disabled, replace please", 401)
c.Abort()
return
}
2022-06-25 13:34:44 +00:00
c.Set("user", user)
2022-07-23 13:33:53 +00:00
log.Debugf("use login token: %+v", user)
2022-06-25 13:34:44 +00:00
c.Next()
}
2022-06-26 11:09:28 +00:00
func AuthAdmin(c *gin.Context) {
user := c.MustGet("user").(*model.User)
if !user.IsAdmin() {
2022-06-28 10:12:53 +00:00
common.ErrorStrResp(c, "You are not an admin", 403)
2022-06-26 11:09:28 +00:00
c.Abort()
} else {
c.Next()
}
}