2022-06-25 13:34:44 +00:00
|
|
|
package middlewares
|
|
|
|
|
|
|
|
import (
|
2022-06-25 13:36:35 +00:00
|
|
|
"github.com/alist-org/alist/v3/internal/db"
|
2022-06-26 11:09:28 +00:00
|
|
|
"github.com/alist-org/alist/v3/internal/model"
|
2022-06-28 06:18:10 +00:00
|
|
|
"github.com/alist-org/alist/v3/internal/setting"
|
2022-06-26 11:10:14 +00:00
|
|
|
common2 "github.com/alist-org/alist/v3/server/common"
|
2022-06-25 13:34:44 +00:00
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
)
|
|
|
|
|
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-06-28 06:18:10 +00:00
|
|
|
if token == setting.GetByKey("token") {
|
|
|
|
admin, err := db.GetAdmin()
|
|
|
|
if err != nil {
|
|
|
|
common2.ErrorResp(c, err, 500)
|
|
|
|
c.Abort()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
c.Set("user", admin)
|
|
|
|
c.Next()
|
|
|
|
return
|
|
|
|
}
|
2022-06-26 08:39:02 +00:00
|
|
|
if token == "" {
|
2022-06-26 08:55:37 +00:00
|
|
|
guest, err := db.GetGuest()
|
|
|
|
if err != nil {
|
2022-06-26 11:20:19 +00:00
|
|
|
common2.ErrorResp(c, err, 500)
|
2022-06-26 08:55:37 +00:00
|
|
|
c.Abort()
|
|
|
|
return
|
|
|
|
}
|
2022-06-26 08:39:02 +00:00
|
|
|
c.Set("user", guest)
|
|
|
|
c.Next()
|
|
|
|
return
|
|
|
|
}
|
2022-06-26 11:10:14 +00:00
|
|
|
userClaims, err := common2.ParseToken(token)
|
2022-06-25 13:34:44 +00:00
|
|
|
if err != nil {
|
2022-06-26 11:20:19 +00:00
|
|
|
common2.ErrorResp(c, err, 401, true)
|
2022-06-25 13:34:44 +00:00
|
|
|
c.Abort()
|
|
|
|
return
|
|
|
|
}
|
2022-06-25 13:36:35 +00:00
|
|
|
user, err := db.GetUserByName(userClaims.Username)
|
2022-06-25 13:34:44 +00:00
|
|
|
if err != nil {
|
2022-06-26 11:10:14 +00:00
|
|
|
common2.ErrorResp(c, err, 401)
|
2022-06-25 13:34:44 +00:00
|
|
|
c.Abort()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
c.Set("user", user)
|
|
|
|
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-27 09:25:19 +00:00
|
|
|
common2.ErrorStrResp(c, "You are not an admin", 403, true)
|
2022-06-26 11:09:28 +00:00
|
|
|
c.Abort()
|
|
|
|
} else {
|
|
|
|
c.Next()
|
|
|
|
}
|
|
|
|
}
|