user.go 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  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. // Auth 用户登录
  13. func Auth(c *gin.Context) {
  14. var req operationPb.UserAuth
  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.UserName, valid.Required),
  21. valid.Field(&req.Password, valid.Required),
  22. ); err != nil {
  23. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  24. return
  25. }
  26. res, err := middleware.Dependency(c).StoreEventHub.OpsService.Auth(c, &req)
  27. if err != nil {
  28. apierr.ClassifiedAbort(c, err)
  29. return
  30. }
  31. c.JSON(http.StatusOK, apiok.CommonResponse(res))
  32. }
  33. // AddSystemUser 创建系统用户
  34. func AddSystemUser(c *gin.Context) {
  35. var req operationPb.AddSystemUser
  36. if err := c.BindJSON(&req); err != nil {
  37. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  38. return
  39. }
  40. if err := valid.ValidateStruct(&req,
  41. valid.Field(&req.Name, valid.Required),
  42. valid.Field(&req.Phone, valid.Required),
  43. valid.Field(&req.EmployeeName, valid.Required),
  44. valid.Field(&req.Roles, valid.NotNil),
  45. valid.Field(&req.IsShow, valid.Max(2), valid.Min(1)),
  46. valid.Field(&req.CreateUser, valid.Required),
  47. ); err != nil {
  48. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  49. return
  50. }
  51. if err := middleware.Dependency(c).StoreEventHub.OpsService.CreateSystemUser(c, &req); err != nil {
  52. apierr.ClassifiedAbort(c, err)
  53. return
  54. }
  55. c.JSON(http.StatusOK, apiok.CommonResponse(apiok.NewApiOk(true)))
  56. }
  57. // GetUserInfo 获取用户信息
  58. func GetUserInfo(c *gin.Context) {
  59. token := middleware.GetToken(c)
  60. if err := valid.Validate(token, valid.Required); err != nil {
  61. apierr.ClassifiedAbort(c, err)
  62. return
  63. }
  64. res, err := middleware.BackendOperation(c).OpsService.GetUserInfo(c, token)
  65. if err != nil {
  66. apierr.ClassifiedAbort(c, err)
  67. return
  68. }
  69. c.JSON(http.StatusOK, apiok.CommonResponse(res))
  70. }
  71. // SearchSystemUserList 查询系统用户列表
  72. func SearchSystemUserList(c *gin.Context) {
  73. var req operationPb.SearchUserRequest
  74. if err := c.BindJSON(&req); err != nil {
  75. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  76. return
  77. }
  78. if err := valid.ValidateStruct(&req,
  79. valid.Field(&req.IsShow, valid.Max(2), valid.Min(1)),
  80. ); err != nil {
  81. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  82. return
  83. }
  84. req.Pagination = &operationPb.PaginationModel{
  85. Page: int32(c.GetInt(middleware.Page)),
  86. PageSize: int32(c.GetInt(middleware.PageSize)),
  87. PageOffset: int32(c.GetInt(middleware.PageOffset)),
  88. }
  89. res, err := middleware.Dependency(c).StoreEventHub.OpsService.SearchSystemUserList(c, &req)
  90. if err != nil {
  91. apierr.ClassifiedAbort(c, err)
  92. return
  93. }
  94. c.JSON(http.StatusOK, apiok.CommonResponse(res))
  95. }
  96. // EditSystemUser 编辑系统用户
  97. func EditSystemUser(c *gin.Context) {
  98. var req operationPb.AddSystemUser
  99. if err := c.BindJSON(&req); err != nil {
  100. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  101. return
  102. }
  103. if err := valid.ValidateStruct(&req,
  104. valid.Field(&req.Id, valid.Required, valid.Min(1)),
  105. valid.Field(&req.Name, valid.Required),
  106. valid.Field(&req.Phone, valid.Required),
  107. valid.Field(&req.EmployeeName, valid.Required),
  108. valid.Field(&req.Roles, valid.Required),
  109. valid.Field(&req.CreateUser, valid.Required),
  110. ); err != nil {
  111. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  112. return
  113. }
  114. if err := middleware.Dependency(c).StoreEventHub.OpsService.EditSystemUser(c, &req); err != nil {
  115. apierr.ClassifiedAbort(c, err)
  116. return
  117. }
  118. c.JSON(http.StatusOK, apiok.CommonResponse(apiok.NewApiOk(true)))
  119. }
  120. // DeleteUser 删除系统用户
  121. func DeleteUser(c *gin.Context) {
  122. userIdStr := c.Param("user_id")
  123. userId, _ := strconv.Atoi(userIdStr)
  124. if err := valid.Validate(userId, valid.Required, valid.Min(1)); err != nil {
  125. apierr.ClassifiedAbort(c, err)
  126. return
  127. }
  128. if err := middleware.BackendOperation(c).OpsService.DeleteSystemUser(c, int64(userId)); err != nil {
  129. apierr.ClassifiedAbort(c, err)
  130. return
  131. }
  132. c.JSON(http.StatusOK, apiok.CommonResponse(apiok.NewApiOk(true)))
  133. }
  134. // IsShowSystemUser 系统用户启动开关
  135. func IsShowSystemUser(c *gin.Context) {
  136. var req operationPb.IsShowSystemUserRequest
  137. if err := c.BindJSON(&req); err != nil {
  138. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  139. return
  140. }
  141. if err := valid.ValidateStruct(&req,
  142. valid.Field(&req.UserId, valid.Required, valid.Min(1)),
  143. valid.Field(&req.IsShow, valid.Required, valid.Min(1), valid.Max(2)),
  144. ); err != nil {
  145. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  146. return
  147. }
  148. if err := middleware.Dependency(c).StoreEventHub.OpsService.IsShowSystemUser(c, &req); err != nil {
  149. apierr.ClassifiedAbort(c, err)
  150. return
  151. }
  152. c.JSON(http.StatusOK, apiok.CommonResponse(apiok.NewApiOk(true)))
  153. }
  154. // GetSystemUserPermissions 获取系统用户菜单权限
  155. func GetSystemUserPermissions(c *gin.Context) {
  156. token := middleware.GetToken(c)
  157. if err := valid.Validate(token, valid.Required); err != nil {
  158. apierr.ClassifiedAbort(c, err)
  159. return
  160. }
  161. res, err := middleware.BackendOperation(c).OpsService.GetSystemUserPermissions(c, token)
  162. if err != nil {
  163. apierr.ClassifiedAbort(c, err)
  164. return
  165. }
  166. c.JSON(http.StatusOK, apiok.CommonResponse(res))
  167. }