package handles import ( "github.com/alist-org/alist/v3/internal/model" "github.com/alist-org/alist/v3/internal/op" "github.com/alist-org/alist/v3/server/common" "github.com/gin-gonic/gin" log "github.com/sirupsen/logrus" "strconv" ) func CreatePermission(c *gin.Context) { var req model.Permission if err := c.ShouldBind(&req); err != nil { common.ErrorResp(c, err, 400) return } if err := op.CreatePermission(&req); err != nil { common.ErrorResp(c, err, 500, true) } else { common.SuccessResp(c) } } func ListPermissions(c *gin.Context) { var req model.PageReq if err := c.ShouldBind(&req); err != nil { common.ErrorResp(c, err, 400) return } req.Validate() log.Debugf("%+v", req) permissions, total, err := op.GetPermissions(req.Page, req.PerPage) if err != nil { common.ErrorResp(c, err, 500, true) return } common.SuccessResp(c, common.PageResp{ Content: permissions, Total: total, }) } func UpdatePermission(c *gin.Context) { var req model.Permission if err := c.ShouldBind(&req); err != nil { common.ErrorResp(c, err, 400) return } if err := op.UpdatePermission(&req); err != nil { common.ErrorResp(c, err, 500) } else { common.SuccessResp(c) } } func DeletePermission(c *gin.Context) { idStr := c.Query("id") id, err := strconv.Atoi(idStr) if err != nil { common.ErrorResp(c, err, 400) return } if err := op.DeletePermissionById(uint(id)); err != nil { common.ErrorResp(c, err, 500) return } common.SuccessResp(c) }