package system import ( operationPb "gitee.com/xuyiping_admin/go_proto/proto/go/backend/operation" "gitee.com/xuyiping_admin/pkg/apierr" "gitee.com/xuyiping_admin/pkg/ginutil" "gitee.com/xuyiping_admin/pkg/valid" "kpt-tmr-group/http/middleware" "net/http" "strconv" "github.com/gin-gonic/gin" ) // AddSystemRole 添加角色 func AddSystemRole(c *gin.Context) { var req operationPb.AddRoleRequest if err := ginutil.BindProto(c, &req); err != nil { apierr.AbortBadRequest(c, http.StatusBadRequest, err) return } if err := valid.ValidateStruct(&req, valid.Field(&req.Name, valid.Required), valid.Field(&req.PastureId, valid.Required), valid.Field(&req.MenuId, valid.Required), valid.Field(&req.CreateUser, valid.Required), ); err != nil { apierr.AbortBadRequest(c, http.StatusBadRequest, err) return } if err := middleware.Dependency(c).StoreEventHub.OpsService.CreateSystemRole(c, &req); err != nil { apierr.ClassifiedAbort(c, err) return } ginutil.JSONResp(c, &operationPb.CommonOK{ Code: http.StatusOK, Msg: "ok", Data: &operationPb.Success{Success: true}, }) } // EditSystemRole 编辑角色 func EditSystemRole(c *gin.Context) { var req operationPb.AddRoleRequest if err := ginutil.BindProto(c, &req); err != nil { apierr.AbortBadRequest(c, http.StatusBadRequest, err) return } if err := valid.ValidateStruct(&req, valid.Field(&req.Name, valid.Required), valid.Field(&req.PastureId, valid.Required), valid.Field(&req.MenuId, valid.Required), valid.Field(&req.CreateUser, valid.Required), ); err != nil { apierr.AbortBadRequest(c, http.StatusBadRequest, err) return } if err := middleware.Dependency(c).StoreEventHub.OpsService.EditSystemRole(c, &req); err != nil { apierr.ClassifiedAbort(c, err) return } ginutil.JSONResp(c, &operationPb.CommonOK{ Code: http.StatusOK, Msg: "ok", Data: &operationPb.Success{Success: true}, }) } // GetRolePermissions 获取角色对应的权限 func GetRolePermissions(c *gin.Context) { roleIdStr := c.Param("role_id") roleId, _ := strconv.Atoi(roleIdStr) if err := valid.Validate(roleId, valid.Required, valid.Min(1)); err != nil { apierr.ClassifiedAbort(c, err) return } res, err := middleware.BackendOperation(c).OpsService.GetRolePermissions(c, int64(roleId)) if err != nil { apierr.ClassifiedAbort(c, err) return } ginutil.JSONResp(c, res) } // DeleteSystemRole 删除角色 func DeleteSystemRole(c *gin.Context) { roleIdStr := c.Param("role_id") roleId, _ := strconv.Atoi(roleIdStr) if err := valid.Validate(roleId, valid.Required, valid.Min(1)); err != nil { apierr.ClassifiedAbort(c, err) return } if err := middleware.BackendOperation(c).OpsService.DeleteSystemRole(c, int64(roleId)); err != nil { apierr.ClassifiedAbort(c, err) return } ginutil.JSONResp(c, &operationPb.CommonOK{ Code: http.StatusOK, Msg: "ok", Data: &operationPb.Success{Success: true}, }) } // SearchSystemRoleList 角色列表 func SearchSystemRoleList(c *gin.Context) { var req operationPb.SearchRoleRequest if err := ginutil.BindProto(c, &req); err != nil { apierr.AbortBadRequest(c, http.StatusBadRequest, err) return } req.Pagination = &operationPb.PaginationModel{ Page: int32(c.GetInt(middleware.Page)), PageSize: int32(c.GetInt(middleware.PageSize)), PageOffset: int32(c.GetInt(middleware.PageOffset)), } res, err := middleware.Dependency(c).StoreEventHub.OpsService.SearchSystemRoleList(c, &req) if err != nil { apierr.ClassifiedAbort(c, err) return } ginutil.JSONResp(c, res) }