user.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  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. func Auth(c *gin.Context) {
  13. var req operationPb.UserAuth
  14. if err := c.BindJSON(&req); err != nil {
  15. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  16. return
  17. }
  18. if err := valid.ValidateStruct(&req,
  19. valid.Field(&req.UserName, valid.Required),
  20. valid.Field(&req.Password, valid.Required),
  21. ); err != nil {
  22. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  23. return
  24. }
  25. res, err := middleware.Dependency(c).StoreEventHub.OpsService.Auth(c, &req)
  26. if err != nil {
  27. apierr.ClassifiedAbort(c, err)
  28. return
  29. }
  30. c.JSON(http.StatusOK, apiok.CommonResponse(res))
  31. }
  32. func AddSystemUser(c *gin.Context) {
  33. var req operationPb.AddSystemUser
  34. if err := c.BindJSON(&req); err != nil {
  35. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  36. return
  37. }
  38. if err := valid.ValidateStruct(&req,
  39. valid.Field(&req.Name, valid.Required),
  40. valid.Field(&req.Phone, valid.Required),
  41. valid.Field(&req.EmployeeName, valid.Required),
  42. valid.Field(&req.Roles, valid.NotNil),
  43. valid.Field(&req.IsShow, valid.Max(2), valid.Min(1)),
  44. valid.Field(&req.CreateUser, valid.Required),
  45. ); err != nil {
  46. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  47. return
  48. }
  49. if err := middleware.Dependency(c).StoreEventHub.OpsService.CreateSystemUser(c, &req); err != nil {
  50. apierr.ClassifiedAbort(c, err)
  51. return
  52. }
  53. c.JSON(http.StatusOK, apiok.CommonResponse(apiok.NewApiOk(true)))
  54. }
  55. func GetUserInfo(c *gin.Context) {
  56. token := middleware.GetToken(c)
  57. if err := valid.Validate(token, valid.Required); err != nil {
  58. apierr.ClassifiedAbort(c, err)
  59. return
  60. }
  61. res, err := middleware.BackendOperation(c).OpsService.GetUserInfo(c, token)
  62. if err != nil {
  63. apierr.ClassifiedAbort(c, err)
  64. return
  65. }
  66. c.JSON(http.StatusOK, apiok.CommonResponse(res))
  67. }
  68. func SearchSystemUserList(c *gin.Context) {
  69. var req operationPb.SearchUserRequest
  70. if err := c.BindJSON(&req); err != nil {
  71. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  72. return
  73. }
  74. if err := valid.ValidateStruct(&req,
  75. valid.Field(&req.IsShow, valid.Max(2), valid.Min(1)),
  76. ); err != nil {
  77. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  78. return
  79. }
  80. req.Pagination = &operationPb.PaginationModel{
  81. Page: int32(c.GetInt(middleware.Page)),
  82. PageSize: int32(c.GetInt(middleware.PageSize)),
  83. PageOffset: int32(c.GetInt(middleware.PageOffset)),
  84. }
  85. res, err := middleware.Dependency(c).StoreEventHub.OpsService.SearchSystemUserList(c, &req)
  86. if err != nil {
  87. apierr.ClassifiedAbort(c, err)
  88. return
  89. }
  90. c.JSON(http.StatusOK, apiok.CommonResponse(res))
  91. }
  92. func EditSystemUser(c *gin.Context) {
  93. var req operationPb.AddSystemUser
  94. if err := c.BindJSON(&req); err != nil {
  95. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  96. return
  97. }
  98. if err := valid.ValidateStruct(&req,
  99. valid.Field(&req.Id, valid.Required, valid.Min(1)),
  100. valid.Field(&req.Name, valid.Required),
  101. valid.Field(&req.Phone, valid.Required),
  102. valid.Field(&req.EmployeeName, valid.Required),
  103. valid.Field(&req.Roles, valid.Required),
  104. valid.Field(&req.CreateUser, valid.Required),
  105. ); err != nil {
  106. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  107. return
  108. }
  109. if err := middleware.Dependency(c).StoreEventHub.OpsService.EditSystemUser(c, &req); err != nil {
  110. apierr.ClassifiedAbort(c, err)
  111. return
  112. }
  113. c.JSON(http.StatusOK, apiok.CommonResponse(apiok.NewApiOk(true)))
  114. }
  115. func DeleteUser(c *gin.Context) {
  116. userIdStr := c.Param("user_id")
  117. userId, _ := strconv.Atoi(userIdStr)
  118. if err := valid.Validate(userId, valid.Required, valid.Min(1)); err != nil {
  119. apierr.ClassifiedAbort(c, err)
  120. return
  121. }
  122. if err := middleware.BackendOperation(c).OpsService.DeleteSystemUser(c, int64(userId)); err != nil {
  123. apierr.ClassifiedAbort(c, err)
  124. return
  125. }
  126. c.JSON(http.StatusOK, apiok.CommonResponse(apiok.NewApiOk(true)))
  127. }
  128. func IsShowSystemUser(c *gin.Context) {
  129. var req operationPb.IsShowSystemUserRequest
  130. if err := c.BindJSON(&req); err != nil {
  131. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  132. return
  133. }
  134. if err := valid.ValidateStruct(&req,
  135. valid.Field(&req.UserId, valid.Required, valid.Min(1)),
  136. valid.Field(&req.IsShow, valid.Required, valid.Min(1), valid.Max(2)),
  137. ); err != nil {
  138. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  139. return
  140. }
  141. if err := middleware.Dependency(c).StoreEventHub.OpsService.IsShowSystemUser(c, &req); err != nil {
  142. apierr.ClassifiedAbort(c, err)
  143. return
  144. }
  145. c.JSON(http.StatusOK, apiok.CommonResponse(apiok.NewApiOk(true)))
  146. }