role.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. package system
  2. import (
  3. "kpt-tmr-group/http/middleware"
  4. "kpt-tmr-group/pkg/apierr"
  5. "kpt-tmr-group/pkg/apiok"
  6. "kpt-tmr-group/pkg/valid"
  7. operationPb "kpt-tmr-group/proto/go/backend/operation"
  8. "net/http"
  9. "strconv"
  10. "github.com/gin-gonic/gin"
  11. )
  12. // AddSystemRole 添加角色
  13. func AddSystemRole(c *gin.Context) {
  14. var req operationPb.AddRoleRequest
  15. if err := c.BindJSON(&req); err != nil {
  16. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  17. return
  18. }
  19. if err := valid.ValidateStruct(&req,
  20. valid.Field(&req.Name, valid.Required),
  21. valid.Field(&req.PastureId, valid.Required),
  22. valid.Field(&req.MenuId, valid.Required),
  23. valid.Field(&req.CreateUser, valid.Required),
  24. ); err != nil {
  25. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  26. return
  27. }
  28. if err := middleware.Dependency(c).StoreEventHub.OpsService.CreateSystemRole(c, &req); err != nil {
  29. apierr.ClassifiedAbort(c, err)
  30. return
  31. }
  32. c.JSON(http.StatusOK, apiok.CommonResponse(apiok.NewApiOk(true)))
  33. }
  34. // EditSystemRole 编辑角色
  35. func EditSystemRole(c *gin.Context) {
  36. var req operationPb.AddRoleRequest
  37. if err := c.BindJSON(&req); err != nil {
  38. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  39. return
  40. }
  41. if err := valid.ValidateStruct(&req,
  42. valid.Field(&req.Name, valid.Required),
  43. valid.Field(&req.PastureId, valid.Required),
  44. valid.Field(&req.MenuId, valid.Required),
  45. valid.Field(&req.CreateUser, valid.Required),
  46. ); err != nil {
  47. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  48. return
  49. }
  50. if err := middleware.Dependency(c).StoreEventHub.OpsService.EditSystemRole(c, &req); err != nil {
  51. apierr.ClassifiedAbort(c, err)
  52. return
  53. }
  54. c.JSON(http.StatusOK, apiok.CommonResponse(apiok.NewApiOk(true)))
  55. }
  56. // GetRolePermissions 获取角色对应的权限
  57. func GetRolePermissions(c *gin.Context) {
  58. roleIdStr := c.Param("role_id")
  59. roleId, _ := strconv.Atoi(roleIdStr)
  60. if err := valid.Validate(roleId, valid.Required, valid.Min(1)); err != nil {
  61. apierr.ClassifiedAbort(c, err)
  62. return
  63. }
  64. res, err := middleware.BackendOperation(c).OpsService.GetRolePermissions(c, int64(roleId))
  65. if err != nil {
  66. apierr.ClassifiedAbort(c, err)
  67. return
  68. }
  69. c.JSON(http.StatusOK, apiok.CommonResponse(res))
  70. }
  71. // DeleteSystemRole 删除角色
  72. func DeleteSystemRole(c *gin.Context) {
  73. roleIdStr := c.Param("role_id")
  74. roleId, _ := strconv.Atoi(roleIdStr)
  75. if err := valid.Validate(roleId, valid.Required, valid.Min(1)); err != nil {
  76. apierr.ClassifiedAbort(c, err)
  77. return
  78. }
  79. if err := middleware.BackendOperation(c).OpsService.DeleteSystemRole(c, int64(roleId)); err != nil {
  80. apierr.ClassifiedAbort(c, err)
  81. return
  82. }
  83. c.JSON(http.StatusOK, apiok.CommonResponse(apiok.NewApiOk(true)))
  84. }
  85. // SearchSystemRoleList 角色列表
  86. func SearchSystemRoleList(c *gin.Context) {
  87. var req operationPb.SearchRoleRequest
  88. if err := c.BindJSON(&req); err != nil {
  89. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  90. return
  91. }
  92. req.Pagination = &operationPb.PaginationModel{
  93. Page: int32(c.GetInt(middleware.Page)),
  94. PageSize: int32(c.GetInt(middleware.PageSize)),
  95. PageOffset: int32(c.GetInt(middleware.PageOffset)),
  96. }
  97. res, err := middleware.Dependency(c).StoreEventHub.OpsService.SearchSystemRoleList(c, &req)
  98. if err != nil {
  99. apierr.ClassifiedAbort(c, err)
  100. return
  101. }
  102. c.JSON(http.StatusOK, apiok.CommonResponse(res))
  103. //ginutil.JSONResp(c, res)
  104. }