12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- package actions
- import (
- "Medical_OAuth/common/dto"
- "Medical_OAuth/common/model"
- "net/http"
- "github.com/gin-gonic/gin"
- log "gogs.baozhida.cn/zoie/OAuth-core/logger"
- "gogs.baozhida.cn/zoie/OAuth-core/pkg"
- "gogs.baozhida.cn/zoie/OAuth-core/pkg/jwtauth/user"
- "gogs.baozhida.cn/zoie/OAuth-core/pkg/response"
- )
- // DeleteAction 通用删除动作
- func DeleteAction(control dto.Control) gin.HandlerFunc {
- return func(c *gin.Context) {
- db, err := pkg.GetOrm(c)
- if err != nil {
- log.Error(err)
- return
- }
- msgID := pkg.GenerateMsgIDFromContext(c)
- //删除操作
- req := control.Generate()
- err = req.Bind(c)
- if err != nil {
- log.Errorf("MsgID[%s] Bind error: %s", msgID, err)
- response.Error(c, http.StatusUnprocessableEntity, err, "参数验证失败")
- return
- }
- var object model.ActiveRecord
- object, err = req.GenerateM()
- if err != nil {
- response.Error(c, 500, err, "模型生成失败")
- return
- }
- object.SetUpdateBy(user.GetUserId(c))
- //数据权限检查
- p := GetPermissionFromContext(c)
- db = db.WithContext(c).Scopes(
- Permission(object.TableName(), p),
- ).Where(req.GetId()).Delete(object)
- if db.Error != nil {
- log.Errorf("MsgID[%s] Delete error: %s", msgID, err)
- response.Error(c, 500, err, "删除失败")
- return
- }
- if db.RowsAffected == 0 {
- response.Error(c, http.StatusForbidden, nil, "无权删除该数据")
- return
- }
- response.OK(c, object.GetId(), "删除成功")
- c.Next()
- }
- }
|