sys_user.go 15 KB

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