sys_user.go 15 KB

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