user.go 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275
  1. package system
  2. import (
  3. "kpt-tmr-group/http/middleware"
  4. "net/http"
  5. "strconv"
  6. operationPb "gitee.com/xuyiping_admin/go_proto/proto/go/backend/operation"
  7. "gitee.com/xuyiping_admin/pkg/apierr"
  8. "gitee.com/xuyiping_admin/pkg/ginutil"
  9. "gitee.com/xuyiping_admin/pkg/valid"
  10. "github.com/gin-gonic/gin"
  11. )
  12. // Auth 用户登录
  13. func Auth(c *gin.Context) {
  14. var req operationPb.UserAuthData
  15. if err := ginutil.BindProto(c, &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. ginutil.JSONResp(c, res)
  32. }
  33. func GetWxAppletOpenId(c *gin.Context) {
  34. jsCode := c.Param("js_code")
  35. if err := valid.Validate(jsCode, valid.Required, valid.Length(1, 100)); err != nil {
  36. apierr.ClassifiedAbort(c, err)
  37. return
  38. }
  39. res, err := middleware.BackendOperation(c).OpsService.GetOpenId(c, jsCode)
  40. if err != nil {
  41. apierr.ClassifiedAbort(c, err)
  42. return
  43. }
  44. ginutil.JSONResp(c, res)
  45. }
  46. // AddSystemUser 创建系统用户
  47. func AddSystemUser(c *gin.Context) {
  48. var req operationPb.AddSystemUser
  49. if err := ginutil.BindProto(c, &req); err != nil {
  50. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  51. return
  52. }
  53. if err := valid.ValidateStruct(&req,
  54. valid.Field(&req.Name, valid.Required),
  55. valid.Field(&req.Phone, valid.Required),
  56. valid.Field(&req.EmployeeName, valid.Required),
  57. valid.Field(&req.Roles, valid.NotNil),
  58. valid.Field(&req.IsShow, valid.Max(2), valid.Min(1)),
  59. valid.Field(&req.CreateUser, valid.Required),
  60. ); err != nil {
  61. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  62. return
  63. }
  64. if err := middleware.Dependency(c).StoreEventHub.OpsService.CreateSystemUser(c, &req); err != nil {
  65. apierr.ClassifiedAbort(c, err)
  66. return
  67. }
  68. ginutil.JSONResp(c, &operationPb.CommonOK{
  69. Code: http.StatusOK,
  70. Msg: "ok",
  71. Data: &operationPb.Success{Success: true},
  72. })
  73. }
  74. // DetailsSystemUser 系统用户详情
  75. func DetailsSystemUser(c *gin.Context) {
  76. userIdStr := c.Param("user_id")
  77. userId, _ := strconv.Atoi(userIdStr)
  78. if err := valid.Validate(userId, valid.Required, valid.Min(1)); err != nil {
  79. apierr.ClassifiedAbort(c, err)
  80. return
  81. }
  82. res, err := middleware.BackendOperation(c).OpsService.DetailsSystemUser(c, int64(userId))
  83. if err != nil {
  84. apierr.ClassifiedAbort(c, err)
  85. return
  86. }
  87. ginutil.JSONResp(c, res)
  88. }
  89. // GetUserInfo 获取用户信息
  90. func GetUserInfo(c *gin.Context) {
  91. token := middleware.GetToken(c)
  92. if err := valid.Validate(token, valid.Required); err != nil {
  93. apierr.ClassifiedAbort(c, err)
  94. return
  95. }
  96. res, err := middleware.BackendOperation(c).OpsService.GetUserInfo(c)
  97. if err != nil {
  98. apierr.ClassifiedAbort(c, err)
  99. return
  100. }
  101. ginutil.JSONResp(c, res)
  102. }
  103. // SearchSystemUserList 查询系统用户列表
  104. func SearchSystemUserList(c *gin.Context) {
  105. var req operationPb.SearchUserRequest
  106. if err := ginutil.BindProto(c, &req); err != nil {
  107. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  108. return
  109. }
  110. if err := valid.ValidateStruct(&req,
  111. valid.Field(&req.IsShow, valid.Max(2), valid.Min(1)),
  112. ); err != nil {
  113. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  114. return
  115. }
  116. req.Pagination = &operationPb.PaginationModel{
  117. Page: int32(c.GetInt(middleware.Page)),
  118. PageSize: int32(c.GetInt(middleware.PageSize)),
  119. PageOffset: int32(c.GetInt(middleware.PageOffset)),
  120. }
  121. res, err := middleware.Dependency(c).StoreEventHub.OpsService.SearchSystemUserList(c, &req)
  122. if err != nil {
  123. apierr.ClassifiedAbort(c, err)
  124. return
  125. }
  126. ginutil.JSONResp(c, res)
  127. }
  128. // EditSystemUser 编辑系统用户
  129. func EditSystemUser(c *gin.Context) {
  130. var req operationPb.AddSystemUser
  131. if err := ginutil.BindProto(c, &req); err != nil {
  132. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  133. return
  134. }
  135. if err := valid.ValidateStruct(&req,
  136. valid.Field(&req.Id, valid.Required, valid.Min(1)),
  137. valid.Field(&req.Name, valid.Required),
  138. valid.Field(&req.Phone, valid.Required),
  139. valid.Field(&req.EmployeeName, valid.Required),
  140. valid.Field(&req.Roles, valid.Required),
  141. valid.Field(&req.CreateUser, valid.Required),
  142. ); err != nil {
  143. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  144. return
  145. }
  146. if err := middleware.Dependency(c).StoreEventHub.OpsService.EditSystemUser(c, &req); err != nil {
  147. apierr.ClassifiedAbort(c, err)
  148. return
  149. }
  150. ginutil.JSONResp(c, &operationPb.CommonOK{
  151. Code: http.StatusOK,
  152. Msg: "ok",
  153. Data: &operationPb.Success{Success: true},
  154. })
  155. }
  156. // DeleteUser 删除系统用户
  157. func DeleteUser(c *gin.Context) {
  158. userIdStr := c.Param("user_id")
  159. userId, _ := strconv.Atoi(userIdStr)
  160. if err := valid.Validate(userId, valid.Required, valid.Min(1)); err != nil {
  161. apierr.ClassifiedAbort(c, err)
  162. return
  163. }
  164. if err := middleware.BackendOperation(c).OpsService.DeleteSystemUser(c, int64(userId)); err != nil {
  165. apierr.ClassifiedAbort(c, err)
  166. return
  167. }
  168. ginutil.JSONResp(c, &operationPb.CommonOK{
  169. Code: http.StatusOK,
  170. Msg: "ok",
  171. Data: &operationPb.Success{Success: true},
  172. })
  173. }
  174. // IsShowSystemUser 系统用户启动开关
  175. func IsShowSystemUser(c *gin.Context) {
  176. var req operationPb.IsShowSystemUserRequest
  177. if err := ginutil.BindProto(c, &req); err != nil {
  178. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  179. return
  180. }
  181. if err := valid.ValidateStruct(&req,
  182. valid.Field(&req.UserId, valid.Required, valid.Min(1)),
  183. valid.Field(&req.IsShow, valid.Required, valid.Min(1), valid.Max(2)),
  184. ); err != nil {
  185. apierr.AbortBadRequest(c, http.StatusBadRequest, err)
  186. return
  187. }
  188. if err := middleware.Dependency(c).StoreEventHub.OpsService.IsShowSystemUser(c, &req); err != nil {
  189. apierr.ClassifiedAbort(c, err)
  190. return
  191. }
  192. ginutil.JSONResp(c, &operationPb.CommonOK{
  193. Code: http.StatusOK,
  194. Msg: "ok",
  195. Data: &operationPb.Success{Success: true},
  196. })
  197. }
  198. // GetSystemUserPermissions 获取系统用户菜单权限
  199. func GetSystemUserPermissions(c *gin.Context) {
  200. token := middleware.GetToken(c)
  201. if err := valid.Validate(token, valid.Required); err != nil {
  202. apierr.ClassifiedAbort(c, err)
  203. return
  204. }
  205. res, err := middleware.BackendOperation(c).OpsService.GetSystemUserPermissions(c)
  206. if err != nil {
  207. apierr.ClassifiedAbort(c, err)
  208. return
  209. }
  210. ginutil.JSONResp(c, res)
  211. }
  212. // ResetPasswordSystemUser 用户密码重置
  213. func ResetPasswordSystemUser(c *gin.Context) {
  214. userIdStr := c.Param("user_id")
  215. userId, _ := strconv.Atoi(userIdStr)
  216. if err := valid.Validate(userId, valid.Required, valid.Min(1)); err != nil {
  217. apierr.ClassifiedAbort(c, err)
  218. return
  219. }
  220. if err := middleware.BackendOperation(c).OpsService.ResetPasswordSystemUser(c, int64(userId)); err != nil {
  221. apierr.ClassifiedAbort(c, err)
  222. return
  223. }
  224. ginutil.JSONResp(c, &operationPb.CommonOK{
  225. Code: http.StatusOK,
  226. Msg: "ok",
  227. Data: &operationPb.Success{Success: true},
  228. })
  229. }
  230. // LogoutSystemUser 用户登出,
  231. func LogoutSystemUser(c *gin.Context) {
  232. ginutil.JSONResp(c, &operationPb.CommonOK{
  233. Code: http.StatusOK,
  234. Msg: "ok",
  235. Data: &operationPb.Success{Success: true},
  236. })
  237. }