sys_user.go 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483
  1. package system
  2. import (
  3. "strconv"
  4. "time"
  5. "github.com/flipped-aurora/gin-vue-admin/server/global"
  6. "github.com/flipped-aurora/gin-vue-admin/server/model/common"
  7. "github.com/flipped-aurora/gin-vue-admin/server/model/common/request"
  8. "github.com/flipped-aurora/gin-vue-admin/server/model/common/response"
  9. "github.com/flipped-aurora/gin-vue-admin/server/model/system"
  10. systemReq "github.com/flipped-aurora/gin-vue-admin/server/model/system/request"
  11. systemRes "github.com/flipped-aurora/gin-vue-admin/server/model/system/response"
  12. "github.com/flipped-aurora/gin-vue-admin/server/utils"
  13. "github.com/gin-gonic/gin"
  14. "github.com/redis/go-redis/v9"
  15. "go.uber.org/zap"
  16. )
  17. // Login
  18. // @Tags Base
  19. // @Summary 用户登录
  20. // @Produce application/json
  21. // @Param data body systemReq.Login true "用户名, 密码, 验证码"
  22. // @Success 200 {object} response.Response{data=systemRes.LoginResponse,msg=string} "返回包括用户信息,token,过期时间"
  23. // @Router /base/login [post]
  24. func (b *BaseApi) Login(c *gin.Context) {
  25. var l systemReq.Login
  26. err := c.ShouldBindJSON(&l)
  27. key := c.ClientIP()
  28. if err != nil {
  29. response.FailWithMessage(err.Error(), c)
  30. return
  31. }
  32. err = utils.Verify(l, utils.LoginVerify)
  33. if err != nil {
  34. response.FailWithMessage(err.Error(), c)
  35. return
  36. }
  37. // 判断验证码是否开启
  38. openCaptcha := global.GVA_CONFIG.Captcha.OpenCaptcha // 是否开启防爆次数
  39. openCaptchaTimeOut := global.GVA_CONFIG.Captcha.OpenCaptchaTimeOut // 缓存超时时间
  40. v, ok := global.BlackCache.Get(key)
  41. if !ok {
  42. global.BlackCache.Set(key, 1, time.Second*time.Duration(openCaptchaTimeOut))
  43. }
  44. var oc bool = openCaptcha == 0 || openCaptcha < interfaceToInt(v)
  45. if !oc || (l.CaptchaId != "" && l.Captcha != "" && store.Verify(l.CaptchaId, l.Captcha, true)) {
  46. u := &system.SysUser{Username: l.Username, Password: l.Password}
  47. user, err := userService.Login(u)
  48. if err != nil {
  49. global.GVA_LOG.Error("登陆失败! 用户名不存在或者密码错误!", zap.Error(err))
  50. // 验证码次数+1
  51. global.BlackCache.Increment(key, 1)
  52. response.FailWithMessage("用户名不存在或者密码错误", c)
  53. return
  54. }
  55. if user.Enable != 1 {
  56. global.GVA_LOG.Error("登陆失败! 用户被禁止登录!")
  57. // 验证码次数+1
  58. global.BlackCache.Increment(key, 1)
  59. response.FailWithMessage("用户被禁止登录", c)
  60. return
  61. }
  62. b.TokenNext(c, *user)
  63. return
  64. }
  65. // 验证码次数+1
  66. global.BlackCache.Increment(key, 1)
  67. response.FailWithMessage("验证码错误", c)
  68. }
  69. // TokenNext 登录以后签发jwt
  70. func (b *BaseApi) TokenNext(c *gin.Context, user system.SysUser) {
  71. token, claims, err := utils.LoginToken(&user)
  72. if err != nil {
  73. global.GVA_LOG.Error("获取token失败!", zap.Error(err))
  74. response.FailWithMessage("获取token失败", c)
  75. return
  76. }
  77. if !global.GVA_CONFIG.System.UseMultipoint {
  78. utils.SetToken(c, token, int(claims.RegisteredClaims.ExpiresAt.Unix()-time.Now().Unix()))
  79. response.OkWithDetailed(systemRes.LoginResponse{
  80. User: user,
  81. Token: token,
  82. ExpiresAt: claims.RegisteredClaims.ExpiresAt.Unix() * 1000,
  83. }, "登录成功", c)
  84. return
  85. }
  86. if jwtStr, err := jwtService.GetRedisJWT(user.Username); err == redis.Nil {
  87. if err := jwtService.SetRedisJWT(token, user.Username); err != nil {
  88. global.GVA_LOG.Error("设置登录状态失败!", zap.Error(err))
  89. response.FailWithMessage("设置登录状态失败", c)
  90. return
  91. }
  92. utils.SetToken(c, token, int(claims.RegisteredClaims.ExpiresAt.Unix()-time.Now().Unix()))
  93. response.OkWithDetailed(systemRes.LoginResponse{
  94. User: user,
  95. Token: token,
  96. ExpiresAt: claims.RegisteredClaims.ExpiresAt.Unix() * 1000,
  97. }, "登录成功", c)
  98. } else if err != nil {
  99. global.GVA_LOG.Error("设置登录状态失败!", zap.Error(err))
  100. response.FailWithMessage("设置登录状态失败", c)
  101. } else {
  102. var blackJWT system.JwtBlacklist
  103. blackJWT.Jwt = jwtStr
  104. if err := jwtService.JsonInBlacklist(blackJWT); err != nil {
  105. response.FailWithMessage("jwt作废失败", c)
  106. return
  107. }
  108. if err := jwtService.SetRedisJWT(token, user.GetUsername()); err != nil {
  109. response.FailWithMessage("设置登录状态失败", c)
  110. return
  111. }
  112. utils.SetToken(c, token, int(claims.RegisteredClaims.ExpiresAt.Unix()-time.Now().Unix()))
  113. response.OkWithDetailed(systemRes.LoginResponse{
  114. User: user,
  115. Token: token,
  116. ExpiresAt: claims.RegisteredClaims.ExpiresAt.Unix() * 1000,
  117. }, "登录成功", c)
  118. }
  119. }
  120. // Register
  121. // @Tags SysUser
  122. // @Summary 用户注册账号
  123. // @Produce application/json
  124. // @Param data body systemReq.Register true "用户名, 昵称, 密码, 角色ID"
  125. // @Success 200 {object} response.Response{data=systemRes.SysUserResponse,msg=string} "用户注册账号,返回包括用户信息"
  126. // @Router /user/admin_register [post]
  127. func (b *BaseApi) Register(c *gin.Context) {
  128. var r systemReq.Register
  129. err := c.ShouldBindJSON(&r)
  130. if err != nil {
  131. response.FailWithMessage(err.Error(), c)
  132. return
  133. }
  134. err = utils.Verify(r, utils.RegisterVerify)
  135. if err != nil {
  136. response.FailWithMessage(err.Error(), c)
  137. return
  138. }
  139. var authorities []system.SysAuthority
  140. for _, v := range r.AuthorityIds {
  141. authorities = append(authorities, system.SysAuthority{
  142. AuthorityId: v,
  143. })
  144. }
  145. user := &system.SysUser{Username: r.Username, NickName: r.NickName, Password: r.Password, HeaderImg: r.HeaderImg, AuthorityId: r.AuthorityId, Authorities: authorities, Enable: r.Enable, Phone: r.Phone, Email: r.Email}
  146. userReturn, err := userService.Register(*user)
  147. if err != nil {
  148. global.GVA_LOG.Error("注册失败!", zap.Error(err))
  149. response.FailWithDetailed(systemRes.SysUserResponse{User: userReturn}, "注册失败", c)
  150. return
  151. }
  152. response.OkWithDetailed(systemRes.SysUserResponse{User: userReturn}, "注册成功", c)
  153. }
  154. // ChangePassword
  155. // @Tags SysUser
  156. // @Summary 用户修改密码
  157. // @Security ApiKeyAuth
  158. // @Produce application/json
  159. // @Param data body systemReq.ChangePasswordReq true "用户名, 原密码, 新密码"
  160. // @Success 200 {object} response.Response{msg=string} "用户修改密码"
  161. // @Router /user/changePassword [post]
  162. func (b *BaseApi) ChangePassword(c *gin.Context) {
  163. var req systemReq.ChangePasswordReq
  164. err := c.ShouldBindJSON(&req)
  165. if err != nil {
  166. response.FailWithMessage(err.Error(), c)
  167. return
  168. }
  169. err = utils.Verify(req, utils.ChangePasswordVerify)
  170. if err != nil {
  171. response.FailWithMessage(err.Error(), c)
  172. return
  173. }
  174. uid := utils.GetUserID(c)
  175. u := &system.SysUser{GVA_MODEL: global.GVA_MODEL{ID: uid}, Password: req.Password}
  176. _, err = userService.ChangePassword(u, req.NewPassword)
  177. if err != nil {
  178. global.GVA_LOG.Error("修改失败!", zap.Error(err))
  179. response.FailWithMessage("修改失败,原密码与当前账户不符", c)
  180. return
  181. }
  182. response.OkWithMessage("修改成功", c)
  183. }
  184. // GetUserList
  185. // @Tags SysUser
  186. // @Summary 分页获取用户列表
  187. // @Security ApiKeyAuth
  188. // @accept application/json
  189. // @Produce application/json
  190. // @Param data body systemReq.GetUserList true "页码, 每页大小"
  191. // @Success 200 {object} response.Response{data=response.PageResult,msg=string} "分页获取用户列表,返回包括列表,总数,页码,每页数量"
  192. // @Router /user/getUserList [post]
  193. func (b *BaseApi) GetUserList(c *gin.Context) {
  194. var pageInfo systemReq.GetUserList
  195. err := c.ShouldBindJSON(&pageInfo)
  196. if err != nil {
  197. response.FailWithMessage(err.Error(), c)
  198. return
  199. }
  200. err = utils.Verify(pageInfo, utils.PageInfoVerify)
  201. if err != nil {
  202. response.FailWithMessage(err.Error(), c)
  203. return
  204. }
  205. list, total, err := userService.GetUserInfoList(pageInfo)
  206. if err != nil {
  207. global.GVA_LOG.Error("获取失败!", zap.Error(err))
  208. response.FailWithMessage("获取失败", c)
  209. return
  210. }
  211. response.OkWithDetailed(response.PageResult{
  212. List: list,
  213. Total: total,
  214. Page: pageInfo.Page,
  215. PageSize: pageInfo.PageSize,
  216. }, "获取成功", c)
  217. }
  218. // SetUserAuthority
  219. // @Tags SysUser
  220. // @Summary 更改用户权限
  221. // @Security ApiKeyAuth
  222. // @accept application/json
  223. // @Produce application/json
  224. // @Param data body systemReq.SetUserAuth true "用户UUID, 角色ID"
  225. // @Success 200 {object} response.Response{msg=string} "设置用户权限"
  226. // @Router /user/setUserAuthority [post]
  227. func (b *BaseApi) SetUserAuthority(c *gin.Context) {
  228. var sua systemReq.SetUserAuth
  229. err := c.ShouldBindJSON(&sua)
  230. if err != nil {
  231. response.FailWithMessage(err.Error(), c)
  232. return
  233. }
  234. if UserVerifyErr := utils.Verify(sua, utils.SetUserAuthorityVerify); UserVerifyErr != nil {
  235. response.FailWithMessage(UserVerifyErr.Error(), c)
  236. return
  237. }
  238. userID := utils.GetUserID(c)
  239. err = userService.SetUserAuthority(userID, sua.AuthorityId)
  240. if err != nil {
  241. global.GVA_LOG.Error("修改失败!", zap.Error(err))
  242. response.FailWithMessage(err.Error(), c)
  243. return
  244. }
  245. claims := utils.GetUserInfo(c)
  246. claims.AuthorityId = sua.AuthorityId
  247. token, err := utils.NewJWT().CreateToken(*claims)
  248. if err != nil {
  249. global.GVA_LOG.Error("修改失败!", zap.Error(err))
  250. response.FailWithMessage(err.Error(), c)
  251. return
  252. }
  253. c.Header("new-token", token)
  254. c.Header("new-expires-at", strconv.FormatInt(claims.ExpiresAt.Unix(), 10))
  255. utils.SetToken(c, token, int((claims.ExpiresAt.Unix()-time.Now().Unix())/60))
  256. response.OkWithMessage("修改成功", c)
  257. }
  258. // SetUserAuthorities
  259. // @Tags SysUser
  260. // @Summary 设置用户权限
  261. // @Security ApiKeyAuth
  262. // @accept application/json
  263. // @Produce application/json
  264. // @Param data body systemReq.SetUserAuthorities true "用户UUID, 角色ID"
  265. // @Success 200 {object} response.Response{msg=string} "设置用户权限"
  266. // @Router /user/setUserAuthorities [post]
  267. func (b *BaseApi) SetUserAuthorities(c *gin.Context) {
  268. var sua systemReq.SetUserAuthorities
  269. err := c.ShouldBindJSON(&sua)
  270. if err != nil {
  271. response.FailWithMessage(err.Error(), c)
  272. return
  273. }
  274. authorityID := utils.GetUserAuthorityId(c)
  275. err = userService.SetUserAuthorities(authorityID, sua.ID, sua.AuthorityIds)
  276. if err != nil {
  277. global.GVA_LOG.Error("修改失败!", zap.Error(err))
  278. response.FailWithMessage("修改失败", c)
  279. return
  280. }
  281. response.OkWithMessage("修改成功", c)
  282. }
  283. // DeleteUser
  284. // @Tags SysUser
  285. // @Summary 删除用户
  286. // @Security ApiKeyAuth
  287. // @accept application/json
  288. // @Produce application/json
  289. // @Param data body request.GetById true "用户ID"
  290. // @Success 200 {object} response.Response{msg=string} "删除用户"
  291. // @Router /user/deleteUser [delete]
  292. func (b *BaseApi) DeleteUser(c *gin.Context) {
  293. var reqId request.GetById
  294. err := c.ShouldBindJSON(&reqId)
  295. if err != nil {
  296. response.FailWithMessage(err.Error(), c)
  297. return
  298. }
  299. err = utils.Verify(reqId, utils.IdVerify)
  300. if err != nil {
  301. response.FailWithMessage(err.Error(), c)
  302. return
  303. }
  304. jwtId := utils.GetUserID(c)
  305. if jwtId == uint(reqId.ID) {
  306. response.FailWithMessage("删除失败, 无法删除自己。", c)
  307. return
  308. }
  309. err = userService.DeleteUser(reqId.ID)
  310. if err != nil {
  311. global.GVA_LOG.Error("删除失败!", zap.Error(err))
  312. response.FailWithMessage("删除失败", c)
  313. return
  314. }
  315. response.OkWithMessage("删除成功", c)
  316. }
  317. // SetUserInfo
  318. // @Tags SysUser
  319. // @Summary 设置用户信息
  320. // @Security ApiKeyAuth
  321. // @accept application/json
  322. // @Produce application/json
  323. // @Param data body system.SysUser true "ID, 用户名, 昵称, 头像链接"
  324. // @Success 200 {object} response.Response{data=map[string]interface{},msg=string} "设置用户信息"
  325. // @Router /user/setUserInfo [put]
  326. func (b *BaseApi) SetUserInfo(c *gin.Context) {
  327. var user systemReq.ChangeUserInfo
  328. err := c.ShouldBindJSON(&user)
  329. if err != nil {
  330. response.FailWithMessage(err.Error(), c)
  331. return
  332. }
  333. err = utils.Verify(user, utils.IdVerify)
  334. if err != nil {
  335. response.FailWithMessage(err.Error(), c)
  336. return
  337. }
  338. if len(user.AuthorityIds) != 0 {
  339. authorityID := utils.GetUserAuthorityId(c)
  340. err = userService.SetUserAuthorities(authorityID, user.ID, user.AuthorityIds)
  341. if err != nil {
  342. global.GVA_LOG.Error("设置失败!", zap.Error(err))
  343. response.FailWithMessage("设置失败", c)
  344. return
  345. }
  346. }
  347. err = userService.SetUserInfo(system.SysUser{
  348. GVA_MODEL: global.GVA_MODEL{
  349. ID: user.ID,
  350. },
  351. NickName: user.NickName,
  352. HeaderImg: user.HeaderImg,
  353. Phone: user.Phone,
  354. Email: user.Email,
  355. Enable: user.Enable,
  356. })
  357. if err != nil {
  358. global.GVA_LOG.Error("设置失败!", zap.Error(err))
  359. response.FailWithMessage("设置失败", c)
  360. return
  361. }
  362. response.OkWithMessage("设置成功", c)
  363. }
  364. // SetSelfInfo
  365. // @Tags SysUser
  366. // @Summary 设置用户信息
  367. // @Security ApiKeyAuth
  368. // @accept application/json
  369. // @Produce application/json
  370. // @Param data body system.SysUser true "ID, 用户名, 昵称, 头像链接"
  371. // @Success 200 {object} response.Response{data=map[string]interface{},msg=string} "设置用户信息"
  372. // @Router /user/SetSelfInfo [put]
  373. func (b *BaseApi) SetSelfInfo(c *gin.Context) {
  374. var user systemReq.ChangeUserInfo
  375. err := c.ShouldBindJSON(&user)
  376. if err != nil {
  377. response.FailWithMessage(err.Error(), c)
  378. return
  379. }
  380. user.ID = utils.GetUserID(c)
  381. err = userService.SetSelfInfo(system.SysUser{
  382. GVA_MODEL: global.GVA_MODEL{
  383. ID: user.ID,
  384. },
  385. NickName: user.NickName,
  386. HeaderImg: user.HeaderImg,
  387. Phone: user.Phone,
  388. Email: user.Email,
  389. Enable: user.Enable,
  390. })
  391. if err != nil {
  392. global.GVA_LOG.Error("设置失败!", zap.Error(err))
  393. response.FailWithMessage("设置失败", c)
  394. return
  395. }
  396. response.OkWithMessage("设置成功", c)
  397. }
  398. // SetSelfSetting
  399. // @Tags SysUser
  400. // @Summary 设置用户配置
  401. // @Security ApiKeyAuth
  402. // @accept application/json
  403. // @Produce application/json
  404. // @Param data body map[string]interface{} true "用户配置数据"
  405. // @Success 200 {object} response.Response{data=map[string]interface{},msg=string} "设置用户配置"
  406. // @Router /user/SetSelfSetting [put]
  407. func (b *BaseApi) SetSelfSetting(c *gin.Context) {
  408. var req common.JSONMap
  409. err := c.ShouldBindJSON(&req)
  410. if err != nil {
  411. response.FailWithMessage(err.Error(), c)
  412. return
  413. }
  414. err = userService.SetSelfSetting(req, utils.GetUserID(c))
  415. if err != nil {
  416. global.GVA_LOG.Error("设置失败!", zap.Error(err))
  417. response.FailWithMessage("设置失败", c)
  418. return
  419. }
  420. response.OkWithMessage("设置成功", c)
  421. }
  422. // GetUserInfo
  423. // @Tags SysUser
  424. // @Summary 获取用户信息
  425. // @Security ApiKeyAuth
  426. // @accept application/json
  427. // @Produce application/json
  428. // @Success 200 {object} response.Response{data=map[string]interface{},msg=string} "获取用户信息"
  429. // @Router /user/getUserInfo [get]
  430. func (b *BaseApi) GetUserInfo(c *gin.Context) {
  431. uuid := utils.GetUserUuid(c)
  432. ReqUser, err := userService.GetUserInfo(uuid)
  433. if err != nil {
  434. global.GVA_LOG.Error("获取失败!", zap.Error(err))
  435. response.FailWithMessage("获取失败", c)
  436. return
  437. }
  438. response.OkWithDetailed(gin.H{"userInfo": ReqUser}, "获取成功", c)
  439. }
  440. // ResetPassword
  441. // @Tags SysUser
  442. // @Summary 重置用户密码
  443. // @Security ApiKeyAuth
  444. // @Produce application/json
  445. // @Param data body system.SysUser true "ID"
  446. // @Success 200 {object} response.Response{msg=string} "重置用户密码"
  447. // @Router /user/resetPassword [post]
  448. func (b *BaseApi) ResetPassword(c *gin.Context) {
  449. var user system.SysUser
  450. err := c.ShouldBindJSON(&user)
  451. if err != nil {
  452. response.FailWithMessage(err.Error(), c)
  453. return
  454. }
  455. err = userService.ResetPassword(user.ID)
  456. if err != nil {
  457. global.GVA_LOG.Error("重置失败!", zap.Error(err))
  458. response.FailWithMessage("重置失败"+err.Error(), c)
  459. return
  460. }
  461. response.OkWithMessage("重置成功", c)
  462. }