sys_user.go 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504
  1. package system
  2. import (
  3. "strconv"
  4. "strings"
  5. "time"
  6. "server/global"
  7. "server/model/common/request"
  8. "server/model/common/response"
  9. "server/model/system"
  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.AuthorityId != 888 {
  65. global.GVA_LOG.Error("登陆失败!您没有权限!")
  66. // 验证码次数+1
  67. global.BlackCache.Increment(key, 1)
  68. response.FailWithMessage("登陆失败!您没有权限", c)
  69. return
  70. }
  71. if user.Enable != 1 {
  72. global.GVA_LOG.Error("登陆失败! 用户被禁止登录!")
  73. // 验证码次数+1
  74. global.BlackCache.Increment(key, 1)
  75. response.FailWithMessage("用户被禁止登录", c)
  76. return
  77. }
  78. b.TokenNext(c, *user)
  79. return
  80. }
  81. // 验证码次数+1
  82. global.BlackCache.Increment(key, 1)
  83. response.FailWithMessage("验证码错误", c)
  84. }
  85. // TokenNext 登录以后签发jwt
  86. func (b *BaseApi) TokenNext(c *gin.Context, user system.SysUser) {
  87. j := &utils.JWT{SigningKey: []byte(global.GVA_CONFIG.JWT.SigningKey)} // 唯一签名
  88. claims := j.CreateClaims(systemReq.BaseClaims{
  89. UUID: user.UUID,
  90. ID: user.ID,
  91. NickName: user.NickName,
  92. Username: user.Username,
  93. AuthorityId: user.AuthorityId,
  94. })
  95. token, err := j.CreateToken(claims)
  96. if err != nil {
  97. global.GVA_LOG.Error("获取token失败!", zap.Error(err))
  98. response.FailWithMessage("获取token失败", c)
  99. return
  100. }
  101. if !global.GVA_CONFIG.System.UseMultipoint {
  102. utils.SetToken(c, token, int(claims.RegisteredClaims.ExpiresAt.Unix()-time.Now().Unix()))
  103. response.OkWithDetailed(systemRes.LoginResponse{
  104. User: user,
  105. Token: token,
  106. ExpiresAt: claims.RegisteredClaims.ExpiresAt.Unix() * 1000,
  107. }, "登录成功", c)
  108. return
  109. }
  110. if jwtStr, err := jwtService.GetRedisJWT(user.Username); err == redis.Nil {
  111. if err := jwtService.SetRedisJWT(token, user.Username); err != nil {
  112. global.GVA_LOG.Error("设置登录状态失败!", zap.Error(err))
  113. response.FailWithMessage("设置登录状态失败", c)
  114. return
  115. }
  116. utils.SetToken(c, token, int(claims.RegisteredClaims.ExpiresAt.Unix()-time.Now().Unix()))
  117. response.OkWithDetailed(systemRes.LoginResponse{
  118. User: user,
  119. Token: token,
  120. ExpiresAt: claims.RegisteredClaims.ExpiresAt.Unix() * 1000,
  121. }, "登录成功", c)
  122. } else if err != nil {
  123. global.GVA_LOG.Error("设置登录状态失败!", zap.Error(err))
  124. response.FailWithMessage("设置登录状态失败", c)
  125. } else {
  126. var blackJWT system.JwtBlacklist
  127. blackJWT.Jwt = jwtStr
  128. if err := jwtService.JsonInBlacklist(blackJWT); err != nil {
  129. response.FailWithMessage("jwt作废失败", c)
  130. return
  131. }
  132. if err := jwtService.SetRedisJWT(token, user.Username); err != nil {
  133. response.FailWithMessage("设置登录状态失败", c)
  134. return
  135. }
  136. utils.SetToken(c, token, int(claims.RegisteredClaims.ExpiresAt.Unix()-time.Now().Unix()))
  137. response.OkWithDetailed(systemRes.LoginResponse{
  138. User: user,
  139. Token: token,
  140. ExpiresAt: claims.RegisteredClaims.ExpiresAt.Unix() * 1000,
  141. }, "登录成功", c)
  142. }
  143. }
  144. // Register
  145. // @Tags SysUser
  146. // @Summary 用户注册账号
  147. // @Produce application/json
  148. // @Param data body systemReq.Register true "用户名, 昵称, 密码, 角色ID"
  149. // @Success 200 {object} response.Response{data=systemRes.SysUserResponse,msg=string} "用户注册账号,返回包括用户信息"
  150. // @Router /user/admin_register [post]
  151. func (b *BaseApi) Register(c *gin.Context) {
  152. var r systemReq.Register
  153. err := c.ShouldBindJSON(&r)
  154. if err != nil {
  155. response.FailWithMessage(err.Error(), c)
  156. return
  157. }
  158. err = utils.Verify(r, utils.RegisterVerify)
  159. if err != nil {
  160. response.FailWithMessage(err.Error(), c)
  161. return
  162. }
  163. var authorities []system.SysAuthority
  164. for _, v := range r.AuthorityIds {
  165. authorities = append(authorities, system.SysAuthority{
  166. AuthorityId: v,
  167. })
  168. }
  169. // 将整数数组转换为字符串切片
  170. strSlice := make([]string, len(r.AuthId))
  171. for i, num := range r.AuthId {
  172. strSlice[i] = strconv.Itoa(num)
  173. }
  174. // 使用 strings.Join() 函数连接字符串切片
  175. authstr := strings.Join(strSlice, "")
  176. 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, DeptId: r.DeptId, AuthId: authstr}
  177. userReturn, err := userService.Register(*user)
  178. if err != nil {
  179. global.GVA_LOG.Error("注册失败!", zap.Error(err))
  180. response.FailWithDetailed(systemRes.SysUserResponse{User: userReturn}, "注册失败", c)
  181. return
  182. }
  183. response.OkWithDetailed(systemRes.SysUserResponse{User: userReturn}, "注册成功", c)
  184. }
  185. // ChangePassword
  186. // @Tags SysUser
  187. // @Summary 用户修改密码
  188. // @Security ApiKeyAuth
  189. // @Produce application/json
  190. // @Param data body systemReq.ChangePasswordReq true "用户名, 原密码, 新密码"
  191. // @Success 200 {object} response.Response{msg=string} "用户修改密码"
  192. // @Router /user/changePassword [post]
  193. func (b *BaseApi) ChangePassword(c *gin.Context) {
  194. var req systemReq.ChangePasswordReq
  195. err := c.ShouldBindJSON(&req)
  196. if err != nil {
  197. response.FailWithMessage(err.Error(), c)
  198. return
  199. }
  200. err = utils.Verify(req, utils.ChangePasswordVerify)
  201. if err != nil {
  202. response.FailWithMessage(err.Error(), c)
  203. return
  204. }
  205. uid := utils.GetUserID(c)
  206. u := &system.SysUser{GVA_MODEL: global.GVA_MODEL{ID: uid}, Password: req.Password}
  207. _, err = userService.ChangePassword(u, req.NewPassword)
  208. if err != nil {
  209. global.GVA_LOG.Error("修改失败!", zap.Error(err))
  210. response.FailWithMessage("修改失败,原密码与当前账户不符", c)
  211. return
  212. }
  213. response.OkWithMessage("修改成功", c)
  214. }
  215. // GetUserList
  216. // @Tags SysUser
  217. // @Summary 分页获取用户列表
  218. // @Security ApiKeyAuth
  219. // @accept application/json
  220. // @Produce application/json
  221. // @Param data body request.PageInfo true "页码, 每页大小"
  222. // @Success 200 {object} response.Response{data=response.PageResult,msg=string} "分页获取用户列表,返回包括列表,总数,页码,每页数量"
  223. // @Router /user/getUserList [post]
  224. func (b *BaseApi) GetUserList(c *gin.Context) {
  225. var search systemReq.SearchAppUserParams
  226. err := c.ShouldBindJSON(&search)
  227. if err != nil {
  228. response.FailWithMessage(err.Error(), c)
  229. return
  230. }
  231. err = utils.Verify(search.PageInfo, utils.PageInfoVerify)
  232. if err != nil {
  233. response.FailWithMessage(err.Error(), c)
  234. return
  235. }
  236. list, total, err := userService.GetUserInfoList(search)
  237. if err != nil {
  238. global.GVA_LOG.Error("获取失败!", zap.Error(err))
  239. response.FailWithMessage("获取失败", c)
  240. return
  241. }
  242. response.OkWithDetailed(response.PageResult{
  243. List: list,
  244. Total: total,
  245. Page: search.PageInfo.Page,
  246. PageSize: search.PageInfo.PageSize,
  247. }, "获取成功", c)
  248. }
  249. // SetUserAuthority
  250. // @Tags SysUser
  251. // @Summary 更改用户权限
  252. // @Security ApiKeyAuth
  253. // @accept application/json
  254. // @Produce application/json
  255. // @Param data body systemReq.SetUserAuth true "用户UUID, 角色ID"
  256. // @Success 200 {object} response.Response{msg=string} "设置用户权限"
  257. // @Router /user/setUserAuthority [post]
  258. func (b *BaseApi) SetUserAuthority(c *gin.Context) {
  259. var sua systemReq.SetUserAuth
  260. err := c.ShouldBindJSON(&sua)
  261. if err != nil {
  262. response.FailWithMessage(err.Error(), c)
  263. return
  264. }
  265. if UserVerifyErr := utils.Verify(sua, utils.SetUserAuthorityVerify); UserVerifyErr != nil {
  266. response.FailWithMessage(UserVerifyErr.Error(), c)
  267. return
  268. }
  269. userID := utils.GetUserID(c)
  270. err = userService.SetUserAuthority(userID, sua.AuthorityId)
  271. if err != nil {
  272. global.GVA_LOG.Error("修改失败!", zap.Error(err))
  273. response.FailWithMessage(err.Error(), c)
  274. return
  275. }
  276. claims := utils.GetUserInfo(c)
  277. j := &utils.JWT{SigningKey: []byte(global.GVA_CONFIG.JWT.SigningKey)} // 唯一签名
  278. claims.AuthorityId = sua.AuthorityId
  279. if token, err := j.CreateToken(*claims); err != nil {
  280. global.GVA_LOG.Error("修改失败!", zap.Error(err))
  281. response.FailWithMessage(err.Error(), c)
  282. } else {
  283. c.Header("new-token", token)
  284. c.Header("new-expires-at", strconv.FormatInt(claims.ExpiresAt.Unix(), 10))
  285. utils.SetToken(c, token, int((claims.ExpiresAt.Unix()-time.Now().Unix())/60))
  286. response.OkWithMessage("修改成功", c)
  287. }
  288. }
  289. // SetUserAuthorities
  290. // @Tags SysUser
  291. // @Summary 设置用户权限
  292. // @Security ApiKeyAuth
  293. // @accept application/json
  294. // @Produce application/json
  295. // @Param data body systemReq.SetUserAuthorities true "用户UUID, 角色ID"
  296. // @Success 200 {object} response.Response{msg=string} "设置用户权限"
  297. // @Router /user/setUserAuthorities [post]
  298. func (b *BaseApi) SetUserAuthorities(c *gin.Context) {
  299. var sua systemReq.SetUserAuthorities
  300. err := c.ShouldBindJSON(&sua)
  301. if err != nil {
  302. response.FailWithMessage(err.Error(), c)
  303. return
  304. }
  305. err = userService.SetUserAuthorities(sua.ID, sua.AuthorityIds)
  306. if err != nil {
  307. global.GVA_LOG.Error("修改失败!", zap.Error(err))
  308. response.FailWithMessage("修改失败", c)
  309. return
  310. }
  311. response.OkWithMessage("修改成功", c)
  312. }
  313. // DeleteUser
  314. // @Tags SysUser
  315. // @Summary 删除用户
  316. // @Security ApiKeyAuth
  317. // @accept application/json
  318. // @Produce application/json
  319. // @Param data body request.GetById true "用户ID"
  320. // @Success 200 {object} response.Response{msg=string} "删除用户"
  321. // @Router /user/deleteUser [delete]
  322. func (b *BaseApi) DeleteUser(c *gin.Context) {
  323. var reqId request.GetById
  324. err := c.ShouldBindJSON(&reqId)
  325. if err != nil {
  326. response.FailWithMessage(err.Error(), c)
  327. return
  328. }
  329. err = utils.Verify(reqId, utils.IdVerify)
  330. if err != nil {
  331. response.FailWithMessage(err.Error(), c)
  332. return
  333. }
  334. jwtId := utils.GetUserID(c)
  335. if jwtId == uint(reqId.ID) {
  336. response.FailWithMessage("删除失败, 自杀失败", c)
  337. return
  338. }
  339. err = userService.DeleteUser(reqId.ID)
  340. if err != nil {
  341. global.GVA_LOG.Error("删除失败!", zap.Error(err))
  342. response.FailWithMessage("删除失败", c)
  343. return
  344. }
  345. response.OkWithMessage("删除成功", c)
  346. }
  347. // SetUserInfo
  348. // @Tags SysUser
  349. // @Summary 设置用户信息
  350. // @Security ApiKeyAuth
  351. // @accept application/json
  352. // @Produce application/json
  353. // @Param data body system.SysUser true "ID, 用户名, 昵称, 头像链接"
  354. // @Success 200 {object} response.Response{data=map[string]interface{},msg=string} "设置用户信息"
  355. // @Router /user/setUserInfo [put]
  356. func (b *BaseApi) SetUserInfo(c *gin.Context) {
  357. var user systemReq.ChangeUserInfo
  358. err := c.ShouldBindJSON(&user)
  359. if err != nil {
  360. response.FailWithMessage(err.Error(), c)
  361. return
  362. }
  363. err = utils.Verify(user, utils.IdVerify)
  364. if err != nil {
  365. response.FailWithMessage(err.Error(), c)
  366. return
  367. }
  368. if len(user.AuthorityIds) != 0 {
  369. err = userService.SetUserAuthorities(user.ID, user.AuthorityIds)
  370. if err != nil {
  371. global.GVA_LOG.Error("设置失败!", zap.Error(err))
  372. response.FailWithMessage("设置失败", c)
  373. return
  374. }
  375. }
  376. // 将整数数组转换为字符串切片
  377. var result string
  378. for _, v := range user.AuthId {
  379. result += strconv.Itoa(v)
  380. }
  381. err = userService.SetUserInfo(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. SideMode: user.SideMode,
  390. Enable: user.Enable,
  391. DeptId: user.DeptId,
  392. AuthId: result,
  393. })
  394. if err != nil {
  395. global.GVA_LOG.Error("设置失败!", zap.Error(err))
  396. response.FailWithMessage("设置失败", c)
  397. return
  398. }
  399. response.OkWithMessage("设置成功", c)
  400. }
  401. // SetSelfInfo
  402. // @Tags SysUser
  403. // @Summary 设置用户信息
  404. // @Security ApiKeyAuth
  405. // @accept application/json
  406. // @Produce application/json
  407. // @Param data body system.SysUser true "ID, 用户名, 昵称, 头像链接"
  408. // @Success 200 {object} response.Response{data=map[string]interface{},msg=string} "设置用户信息"
  409. // @Router /user/SetSelfInfo [put]
  410. func (b *BaseApi) SetSelfInfo(c *gin.Context) {
  411. var user systemReq.ChangeUserInfo
  412. err := c.ShouldBindJSON(&user)
  413. if err != nil {
  414. response.FailWithMessage(err.Error(), c)
  415. return
  416. }
  417. user.ID = utils.GetUserID(c)
  418. err = userService.SetSelfInfo(system.SysUser{
  419. GVA_MODEL: global.GVA_MODEL{
  420. ID: user.ID,
  421. },
  422. NickName: user.NickName,
  423. HeaderImg: user.HeaderImg,
  424. Phone: user.Phone,
  425. Email: user.Email,
  426. SideMode: user.SideMode,
  427. Enable: user.Enable,
  428. })
  429. if err != nil {
  430. global.GVA_LOG.Error("设置失败!", zap.Error(err))
  431. response.FailWithMessage("设置失败", c)
  432. return
  433. }
  434. response.OkWithMessage("设置成功", c)
  435. }
  436. // GetUserInfo
  437. // @Tags SysUser
  438. // @Summary 获取用户信息
  439. // @Security ApiKeyAuth
  440. // @accept application/json
  441. // @Produce application/json
  442. // @Success 200 {object} response.Response{data=map[string]interface{},msg=string} "获取用户信息"
  443. // @Router /user/getUserInfo [get]
  444. func (b *BaseApi) GetUserInfo(c *gin.Context) {
  445. uuid := utils.GetUserUuid(c)
  446. ReqUser, err := userService.GetUserInfo(uuid)
  447. if err != nil {
  448. global.GVA_LOG.Error("获取失败!", zap.Error(err))
  449. response.FailWithMessage("获取失败", c)
  450. return
  451. }
  452. response.OkWithDetailed(gin.H{"userInfo": ReqUser}, "获取成功", c)
  453. }
  454. // ResetPassword
  455. // @Tags SysUser
  456. // @Summary 重置用户密码
  457. // @Security ApiKeyAuth
  458. // @Produce application/json
  459. // @Param data body system.SysUser true "ID"
  460. // @Success 200 {object} response.Response{msg=string} "重置用户密码"
  461. // @Router /user/resetPassword [post]
  462. func (b *BaseApi) ResetPassword(c *gin.Context) {
  463. var user system.SysUser
  464. err := c.ShouldBindJSON(&user)
  465. if err != nil {
  466. response.FailWithMessage(err.Error(), c)
  467. return
  468. }
  469. err = userService.ResetPassword(user.ID)
  470. if err != nil {
  471. global.GVA_LOG.Error("重置失败!", zap.Error(err))
  472. response.FailWithMessage("重置失败"+err.Error(), c)
  473. return
  474. }
  475. response.OkWithMessage("重置成功", c)
  476. }