feat(user): Enhanced role assignment logic

- Imported the `utils` package
- Modified the role assignment logic to prevent assigning administrator or guest roles to users
pull/9297/head
okatu-loli 2025-08-27 19:37:35 +08:00
parent c64f899a63
commit abedb9e7c8
1 changed files with 10 additions and 1 deletions

View File

@ -1,9 +1,10 @@
package handles
import (
"github.com/alist-org/alist/v3/pkg/utils"
"strconv"
"github.com/alist-org/alist/v3/pkg/utils"
"github.com/alist-org/alist/v3/internal/model"
"github.com/alist-org/alist/v3/internal/op"
"github.com/alist-org/alist/v3/server/common"
@ -97,6 +98,14 @@ func UpdateUser(c *gin.Context) {
return
}
}
if !utils.SliceEqual(user.Role, req.Role) {
if req.IsAdmin() || req.IsGuest() {
common.ErrorStrResp(c, "cannot assign admin or guest role to user", 400, true)
return
}
}
if err := op.UpdateUser(&req); err != nil {
common.ErrorResp(c, err, 500)
} else {