user.go 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364
  1. package admin
  2. import (
  3. "Gwen/global"
  4. "Gwen/http/request/admin"
  5. "Gwen/http/response"
  6. adResp "Gwen/http/response/admin"
  7. "Gwen/model"
  8. "Gwen/service"
  9. "github.com/gin-gonic/gin"
  10. "gorm.io/gorm"
  11. "strconv"
  12. )
  13. type User struct {
  14. }
  15. // Detail 管理员
  16. // @Tags 用户
  17. // @Summary 管理员详情
  18. // @Description 管理员详情
  19. // @Accept json
  20. // @Produce json
  21. // @Param id path int true "ID"
  22. // @Success 200 {object} response.Response{data=model.User}
  23. // @Failure 500 {object} response.Response
  24. // @Router /admin/user/detail/{id} [get]
  25. // @Security token
  26. func (ct *User) Detail(c *gin.Context) {
  27. id := c.Param("id")
  28. iid, _ := strconv.Atoi(id)
  29. u := service.AllService.UserService.InfoById(uint(iid))
  30. if u.Id > 0 {
  31. response.Success(c, u)
  32. return
  33. }
  34. response.Fail(c, 101, response.TranslateMsg(c, "ItemNotFound"))
  35. return
  36. }
  37. // Create 管理员
  38. // @Tags 用户
  39. // @Summary 创建管理员
  40. // @Description 创建管理员
  41. // @Accept json
  42. // @Produce json
  43. // @Param body body admin.UserForm true "管理员信息"
  44. // @Success 200 {object} response.Response{data=model.User}
  45. // @Failure 500 {object} response.Response
  46. // @Router /admin/user/create [post]
  47. // @Security token
  48. func (ct *User) Create(c *gin.Context) {
  49. f := &admin.UserForm{}
  50. if err := c.ShouldBindJSON(f); err != nil {
  51. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  52. return
  53. }
  54. errList := global.Validator.ValidStruct(c, f)
  55. if len(errList) > 0 {
  56. response.Fail(c, 101, errList[0])
  57. return
  58. }
  59. u := f.ToUser()
  60. err := service.AllService.UserService.Create(u)
  61. if err != nil {
  62. response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed")+err.Error())
  63. return
  64. }
  65. response.Success(c, nil)
  66. }
  67. // List 列表
  68. // @Tags 用户
  69. // @Summary 管理员列表
  70. // @Description 管理员列表
  71. // @Accept json
  72. // @Produce json
  73. // @Param page query int false "页码"
  74. // @Param page_size query int false "页大小"
  75. // @Param username query int false "账户"
  76. // @Success 200 {object} response.Response{data=model.UserList}
  77. // @Failure 500 {object} response.Response
  78. // @Router /admin/user/list [get]
  79. // @Security token
  80. func (ct *User) List(c *gin.Context) {
  81. query := &admin.UserQuery{}
  82. if err := c.ShouldBindQuery(query); err != nil {
  83. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  84. return
  85. }
  86. res := service.AllService.UserService.List(query.Page, query.PageSize, func(tx *gorm.DB) {
  87. if query.Username != "" {
  88. tx.Where("username like ?", "%"+query.Username+"%")
  89. }
  90. })
  91. response.Success(c, res)
  92. }
  93. // Update 编辑
  94. // @Tags 用户
  95. // @Summary 管理员编辑
  96. // @Description 管理员编辑
  97. // @Accept json
  98. // @Produce json
  99. // @Param body body admin.UserForm true "用户信息"
  100. // @Success 200 {object} response.Response{data=model.User}
  101. // @Failure 500 {object} response.Response
  102. // @Router /admin/user/update [post]
  103. // @Security token
  104. func (ct *User) Update(c *gin.Context) {
  105. f := &admin.UserForm{}
  106. if err := c.ShouldBindJSON(f); err != nil {
  107. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  108. return
  109. }
  110. if f.Id == 0 {
  111. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError"))
  112. return
  113. }
  114. errList := global.Validator.ValidStruct(c, f)
  115. if len(errList) > 0 {
  116. response.Fail(c, 101, errList[0])
  117. return
  118. }
  119. u := f.ToUser()
  120. err := service.AllService.UserService.Update(u)
  121. if err != nil {
  122. response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed")+err.Error())
  123. return
  124. }
  125. response.Success(c, nil)
  126. }
  127. // Delete 删除
  128. // @Tags 用户
  129. // @Summary 管理员删除
  130. // @Description 管理员编删除
  131. // @Accept json
  132. // @Produce json
  133. // @Param body body admin.UserForm true "用户信息"
  134. // @Success 200 {object} response.Response
  135. // @Failure 500 {object} response.Response
  136. // @Router /admin/user/delete [post]
  137. // @Security token
  138. func (ct *User) Delete(c *gin.Context) {
  139. f := &admin.UserForm{}
  140. if err := c.ShouldBindJSON(f); err != nil {
  141. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  142. return
  143. }
  144. id := f.Id
  145. errList := global.Validator.ValidVar(c, id, "required,gt=0")
  146. if len(errList) > 0 {
  147. response.Fail(c, 101, errList[0])
  148. return
  149. }
  150. u := service.AllService.UserService.InfoById(f.Id)
  151. if u.Id > 0 {
  152. err := service.AllService.UserService.Delete(u)
  153. if err == nil {
  154. response.Success(c, nil)
  155. return
  156. }
  157. response.Fail(c, 101, err.Error())
  158. return
  159. }
  160. response.Fail(c, 101, response.TranslateMsg(c, "ItemNotFound"))
  161. }
  162. // UpdatePassword 修改密码
  163. // @Tags 用户
  164. // @Summary 修改密码
  165. // @Description 修改密码
  166. // @Accept json
  167. // @Produce json
  168. // @Param body body admin.UserPasswordForm true "用户信息"
  169. // @Success 200 {object} response.Response
  170. // @Failure 500 {object} response.Response
  171. // @Router /admin/user/updatePassword [post]
  172. // @Security token
  173. func (ct *User) UpdatePassword(c *gin.Context) {
  174. f := &admin.UserPasswordForm{}
  175. if err := c.ShouldBindJSON(f); err != nil {
  176. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  177. return
  178. }
  179. errList := global.Validator.ValidStruct(c, f)
  180. if len(errList) > 0 {
  181. response.Fail(c, 101, errList[0])
  182. return
  183. }
  184. u := service.AllService.UserService.InfoById(f.Id)
  185. if u.Id == 0 {
  186. response.Fail(c, 101, response.TranslateMsg(c, "ItemNotFound"))
  187. return
  188. }
  189. err := service.AllService.UserService.UpdatePassword(u, f.Password)
  190. if err != nil {
  191. response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed")+err.Error())
  192. return
  193. }
  194. response.Success(c, nil)
  195. }
  196. // Current 当前用户
  197. // @Tags 用户
  198. // @Summary 当前用户
  199. // @Description 当前用户
  200. // @Accept json
  201. // @Produce json
  202. // @Success 200 {object} response.Response{data=adResp.LoginPayload}
  203. // @Failure 500 {object} response.Response
  204. // @Router /admin/user/current [get]
  205. // @Security token
  206. func (ct *User) Current(c *gin.Context) {
  207. u := service.AllService.UserService.CurUser(c)
  208. token, _ := c.Get("token")
  209. t := token.(string)
  210. response.Success(c, &adResp.LoginPayload{
  211. Token: t,
  212. Username: u.Username,
  213. RouteNames: service.AllService.UserService.RouteNames(u),
  214. Nickname: u.Nickname,
  215. })
  216. }
  217. // ChangeCurPwd 修改当前用户密码
  218. // @Tags 用户
  219. // @Summary 修改当前用户密码
  220. // @Description 修改当前用户密码
  221. // @Accept json
  222. // @Produce json
  223. // @Param body body admin.ChangeCurPasswordForm true "用户信息"
  224. // @Success 200 {object} response.Response
  225. // @Failure 500 {object} response.Response
  226. // @Router /admin/user/changeCurPwd [post]
  227. // @Security token
  228. func (ct *User) ChangeCurPwd(c *gin.Context) {
  229. f := &admin.ChangeCurPasswordForm{}
  230. if err := c.ShouldBindJSON(f); err != nil {
  231. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  232. return
  233. }
  234. errList := global.Validator.ValidStruct(c, f)
  235. if len(errList) > 0 {
  236. response.Fail(c, 101, errList[0])
  237. return
  238. }
  239. u := service.AllService.UserService.CurUser(c)
  240. oldPwd := service.AllService.UserService.EncryptPassword(f.OldPassword)
  241. if u.Password != oldPwd {
  242. response.Fail(c, 101, response.TranslateMsg(c, "OldPasswordError"))
  243. return
  244. }
  245. err := service.AllService.UserService.UpdatePassword(u, f.NewPassword)
  246. if err != nil {
  247. response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed")+err.Error())
  248. return
  249. }
  250. response.Success(c, nil)
  251. }
  252. // MyOauth
  253. // @Tags 用户
  254. // @Summary 我的授权
  255. // @Description 我的授权
  256. // @Accept json
  257. // @Produce json
  258. // @Success 200 {object} response.Response{data=[]adResp.UserOauthItem}
  259. // @Failure 500 {object} response.Response
  260. // @Router /admin/user/myOauth [get]
  261. // @Security token
  262. func (ct *User) MyOauth(c *gin.Context) {
  263. u := service.AllService.UserService.CurUser(c)
  264. oal := service.AllService.OauthService.List(1, 100, nil)
  265. ops := make([]string, 0)
  266. for _, oa := range oal.Oauths {
  267. ops = append(ops, oa.Op)
  268. }
  269. uts := service.AllService.UserService.UserThirdsByUserId(u.Id)
  270. var res []*adResp.UserOauthItem
  271. for _, oa := range oal.Oauths {
  272. item := &adResp.UserOauthItem{
  273. ThirdType: oa.Op,
  274. }
  275. for _, ut := range uts {
  276. if ut.ThirdType == oa.Op {
  277. item.Status = 1
  278. break
  279. }
  280. }
  281. res = append(res, item)
  282. }
  283. response.Success(c, res)
  284. }
  285. // groupUsers
  286. func (ct *User) GroupUsers(c *gin.Context) {
  287. q := &admin.GroupUsersQuery{}
  288. if err := c.ShouldBindJSON(q); err != nil {
  289. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  290. return
  291. }
  292. u := service.AllService.UserService.CurUser(c)
  293. gid := u.GroupId
  294. uid := u.Id
  295. if service.AllService.UserService.IsAdmin(u) && q.UserId > 0 {
  296. nu := service.AllService.UserService.InfoById(q.UserId)
  297. gid = nu.GroupId
  298. uid = q.UserId
  299. }
  300. res := service.AllService.UserService.List(1, 999, func(tx *gorm.DB) {
  301. tx.Where("group_id = ?", gid)
  302. })
  303. var data []*adResp.GroupUsersPayload
  304. for _, _u := range res.Users {
  305. gup := &adResp.GroupUsersPayload{}
  306. gup.FromUser(_u)
  307. if _u.Id == uid {
  308. gup.Status = 0
  309. }
  310. data = append(data, gup)
  311. }
  312. response.Success(c, data)
  313. }
  314. // Register
  315. func (ct *User) Register(c *gin.Context) {
  316. if !global.Config.App.Register {
  317. response.Fail(c, 101, response.TranslateMsg(c, "RegisterClosed"))
  318. return
  319. }
  320. f := &admin.RegisterForm{}
  321. if err := c.ShouldBindJSON(f); err != nil {
  322. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  323. return
  324. }
  325. errList := global.Validator.ValidStruct(c, f)
  326. if len(errList) > 0 {
  327. response.Fail(c, 101, errList[0])
  328. return
  329. }
  330. u := service.AllService.UserService.Register(f.Username, f.Password)
  331. if u == nil || u.Id == 0 {
  332. response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed"))
  333. return
  334. }
  335. // 注册成功后自动登录
  336. ut := service.AllService.UserService.Login(u, &model.LoginLog{
  337. UserId: u.Id,
  338. Client: model.LoginLogClientWebAdmin,
  339. Uuid: "",
  340. Ip: c.ClientIP(),
  341. Type: model.LoginLogTypeAccount,
  342. })
  343. response.Success(c, &adResp.LoginPayload{
  344. Token: ut.Token,
  345. Username: u.Username,
  346. RouteNames: service.AllService.UserService.RouteNames(u),
  347. Nickname: u.Nickname,
  348. })
  349. }