sys_user.go 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378
  1. package system
  2. import (
  3. "strconv"
  4. "log-server/global"
  5. "log-server/model/common/request"
  6. "log-server/model/common/response"
  7. "log-server/model/system"
  8. systemReq "log-server/model/system/request"
  9. systemRes "log-server/model/system/response"
  10. "log-server/utils"
  11. "github.com/gin-gonic/gin"
  12. "github.com/go-redis/redis/v8"
  13. "go.uber.org/zap"
  14. )
  15. // @Tags Base
  16. // @Summary 用户登录
  17. // @Produce application/json
  18. // @Param data body systemReq.Login true "用户名, 密码, 验证码"
  19. // @Success 200 {object} response.Response{data=systemRes.LoginResponse,msg=string} "返回包括用户信息,token,过期时间"
  20. // @Router /base/login [post]
  21. func (b *BaseApi) Login(c *gin.Context) {
  22. var l systemReq.Login
  23. _ = c.ShouldBindJSON(&l)
  24. if err := utils.Verify(l, utils.LoginVerify); err != nil {
  25. response.FailWithMessage(err.Error(), c)
  26. return
  27. }
  28. if store.Verify(l.CaptchaId, l.Captcha, true) {
  29. u := &system.SysUser{Username: l.Username, Password: l.Password}
  30. if user, err := userService.Login(u); err != nil {
  31. global.GVA_LOG.Error("登陆失败! 用户名不存在或者密码错误!", zap.Error(err))
  32. response.FailWithMessage("用户名不存在或者密码错误", c)
  33. } else {
  34. if user.Enable != 1 {
  35. global.GVA_LOG.Error("登陆失败! 用户被禁止登录!")
  36. response.FailWithMessage("用户被禁止登录", c)
  37. return
  38. }
  39. b.TokenNext(c, *user)
  40. }
  41. } else {
  42. response.FailWithMessage("验证码错误", c)
  43. }
  44. }
  45. // 登录以后签发jwt
  46. func (b *BaseApi) TokenNext(c *gin.Context, user system.SysUser) {
  47. j := &utils.JWT{SigningKey: []byte(global.GVA_CONFIG.JWT.SigningKey)} // 唯一签名
  48. claims := j.CreateClaims(systemReq.BaseClaims{
  49. UUID: user.UUID,
  50. ID: user.ID,
  51. NickName: user.NickName,
  52. Username: user.Username,
  53. AuthorityId: user.AuthorityId,
  54. })
  55. token, err := j.CreateToken(claims)
  56. if err != nil {
  57. global.GVA_LOG.Error("获取token失败!", zap.Error(err))
  58. response.FailWithMessage("获取token失败", c)
  59. return
  60. }
  61. if !global.GVA_CONFIG.System.UseMultipoint {
  62. response.OkWithDetailed(systemRes.LoginResponse{
  63. User: user,
  64. Token: token,
  65. ExpiresAt: claims.StandardClaims.ExpiresAt * 1000,
  66. }, "登录成功", c)
  67. return
  68. }
  69. if jwtStr, err := jwtService.GetRedisJWT(user.Username); err == redis.Nil {
  70. if err := jwtService.SetRedisJWT(token, user.Username); err != nil {
  71. global.GVA_LOG.Error("设置登录状态失败!", zap.Error(err))
  72. response.FailWithMessage("设置登录状态失败", c)
  73. return
  74. }
  75. response.OkWithDetailed(systemRes.LoginResponse{
  76. User: user,
  77. Token: token,
  78. ExpiresAt: claims.StandardClaims.ExpiresAt * 1000,
  79. }, "登录成功", c)
  80. } else if err != nil {
  81. global.GVA_LOG.Error("设置登录状态失败!", zap.Error(err))
  82. response.FailWithMessage("设置登录状态失败", c)
  83. } else {
  84. var blackJWT system.JwtBlacklist
  85. blackJWT.Jwt = jwtStr
  86. if err := jwtService.JsonInBlacklist(blackJWT); err != nil {
  87. response.FailWithMessage("jwt作废失败", c)
  88. return
  89. }
  90. if err := jwtService.SetRedisJWT(token, user.Username); err != nil {
  91. response.FailWithMessage("设置登录状态失败", c)
  92. return
  93. }
  94. response.OkWithDetailed(systemRes.LoginResponse{
  95. User: user,
  96. Token: token,
  97. ExpiresAt: claims.StandardClaims.ExpiresAt * 1000,
  98. }, "登录成功", c)
  99. }
  100. }
  101. // @Tags SysUser
  102. // @Summary 用户注册账号
  103. // @Produce application/json
  104. // @Param data body systemReq.Register true "用户名, 昵称, 密码, 角色ID"
  105. // @Success 200 {object} response.Response{data=systemRes.SysUserResponse,msg=string} "用户注册账号,返回包括用户信息"
  106. // @Router /user/admin_register [post]
  107. func (b *BaseApi) Register(c *gin.Context) {
  108. var r systemReq.Register
  109. _ = c.ShouldBindJSON(&r)
  110. if err := utils.Verify(r, utils.RegisterVerify); err != nil {
  111. response.FailWithMessage(err.Error(), c)
  112. return
  113. }
  114. var authorities []system.SysAuthority
  115. for _, v := range r.AuthorityIds {
  116. authorities = append(authorities, system.SysAuthority{
  117. AuthorityId: v,
  118. })
  119. }
  120. user := &system.SysUser{Username: r.Username, NickName: r.NickName, Password: r.Password, HeaderImg: r.HeaderImg, AuthorityId: r.AuthorityId, Authorities: authorities, Enable: r.Enable}
  121. userReturn, err := userService.Register(*user)
  122. if err != nil {
  123. global.GVA_LOG.Error("注册失败!", zap.Error(err))
  124. response.FailWithDetailed(systemRes.SysUserResponse{User: userReturn}, "注册失败", c)
  125. } else {
  126. response.OkWithDetailed(systemRes.SysUserResponse{User: userReturn}, "注册成功", c)
  127. }
  128. }
  129. // @Tags SysUser
  130. // @Summary 用户修改密码
  131. // @Security ApiKeyAuth
  132. // @Produce application/json
  133. // @Param data body systemReq.ChangePasswordStruct true "用户名, 原密码, 新密码"
  134. // @Success 200 {object} response.Response{msg=string} "用户修改密码"
  135. // @Router /user/changePassword [post]
  136. func (b *BaseApi) ChangePassword(c *gin.Context) {
  137. var user systemReq.ChangePasswordStruct
  138. _ = c.ShouldBindJSON(&user)
  139. if err := utils.Verify(user, utils.ChangePasswordVerify); err != nil {
  140. response.FailWithMessage(err.Error(), c)
  141. return
  142. }
  143. u := &system.SysUser{Username: user.Username, Password: user.Password}
  144. if _, err := userService.ChangePassword(u, user.NewPassword); err != nil {
  145. global.GVA_LOG.Error("修改失败!", zap.Error(err))
  146. response.FailWithMessage("修改失败,原密码与当前账户不符", c)
  147. } else {
  148. response.OkWithMessage("修改成功", c)
  149. }
  150. }
  151. // @Tags SysUser
  152. // @Summary 分页获取用户列表
  153. // @Security ApiKeyAuth
  154. // @accept application/json
  155. // @Produce application/json
  156. // @Param data body request.PageInfo true "页码, 每页大小"
  157. // @Success 200 {object} response.Response{data=response.PageResult,msg=string} "分页获取用户列表,返回包括列表,总数,页码,每页数量"
  158. // @Router /user/getUserList [post]
  159. func (b *BaseApi) GetUserList(c *gin.Context) {
  160. var pageInfo request.PageInfo
  161. _ = c.ShouldBindJSON(&pageInfo)
  162. if err := utils.Verify(pageInfo, utils.PageInfoVerify); err != nil {
  163. response.FailWithMessage(err.Error(), c)
  164. return
  165. }
  166. if list, total, err := userService.GetUserInfoList(pageInfo); err != nil {
  167. global.GVA_LOG.Error("获取失败!", zap.Error(err))
  168. response.FailWithMessage("获取失败", c)
  169. } else {
  170. response.OkWithDetailed(response.PageResult{
  171. List: list,
  172. Total: total,
  173. Page: pageInfo.Page,
  174. PageSize: pageInfo.PageSize,
  175. }, "获取成功", c)
  176. }
  177. }
  178. // @Tags SysUser
  179. // @Summary 更改用户权限
  180. // @Security ApiKeyAuth
  181. // @accept application/json
  182. // @Produce application/json
  183. // @Param data body systemReq.SetUserAuth true "用户UUID, 角色ID"
  184. // @Success 200 {object} response.Response{msg=string} "设置用户权限"
  185. // @Router /user/setUserAuthority [post]
  186. func (b *BaseApi) SetUserAuthority(c *gin.Context) {
  187. var sua systemReq.SetUserAuth
  188. _ = c.ShouldBindJSON(&sua)
  189. if UserVerifyErr := utils.Verify(sua, utils.SetUserAuthorityVerify); UserVerifyErr != nil {
  190. response.FailWithMessage(UserVerifyErr.Error(), c)
  191. return
  192. }
  193. userID := utils.GetUserID(c)
  194. uuid := utils.GetUserUuid(c)
  195. if err := userService.SetUserAuthority(userID, uuid, sua.AuthorityId); err != nil {
  196. global.GVA_LOG.Error("修改失败!", zap.Error(err))
  197. response.FailWithMessage(err.Error(), c)
  198. } else {
  199. claims := utils.GetUserInfo(c)
  200. j := &utils.JWT{SigningKey: []byte(global.GVA_CONFIG.JWT.SigningKey)} // 唯一签名
  201. claims.AuthorityId = sua.AuthorityId
  202. if token, err := j.CreateToken(*claims); err != nil {
  203. global.GVA_LOG.Error("修改失败!", zap.Error(err))
  204. response.FailWithMessage(err.Error(), c)
  205. } else {
  206. c.Header("new-token", token)
  207. c.Header("new-expires-at", strconv.FormatInt(claims.ExpiresAt, 10))
  208. response.OkWithMessage("修改成功", c)
  209. }
  210. }
  211. }
  212. // @Tags SysUser
  213. // @Summary 设置用户权限
  214. // @Security ApiKeyAuth
  215. // @accept application/json
  216. // @Produce application/json
  217. // @Param data body systemReq.SetUserAuthorities true "用户UUID, 角色ID"
  218. // @Success 200 {object} response.Response{msg=string} "设置用户权限"
  219. // @Router /user/setUserAuthorities [post]
  220. func (b *BaseApi) SetUserAuthorities(c *gin.Context) {
  221. var sua systemReq.SetUserAuthorities
  222. _ = c.ShouldBindJSON(&sua)
  223. if err := userService.SetUserAuthorities(sua.ID, sua.AuthorityIds); err != nil {
  224. global.GVA_LOG.Error("修改失败!", zap.Error(err))
  225. response.FailWithMessage("修改失败", c)
  226. } else {
  227. response.OkWithMessage("修改成功", c)
  228. }
  229. }
  230. // @Tags SysUser
  231. // @Summary 删除用户
  232. // @Security ApiKeyAuth
  233. // @accept application/json
  234. // @Produce application/json
  235. // @Param data body request.GetById true "用户ID"
  236. // @Success 200 {object} response.Response{msg=string} "删除用户"
  237. // @Router /user/deleteUser [delete]
  238. func (b *BaseApi) DeleteUser(c *gin.Context) {
  239. var reqId request.GetById
  240. _ = c.ShouldBindJSON(&reqId)
  241. if err := utils.Verify(reqId, utils.IdVerify); err != nil {
  242. response.FailWithMessage(err.Error(), c)
  243. return
  244. }
  245. jwtId := utils.GetUserID(c)
  246. if jwtId == uint(reqId.ID) {
  247. response.FailWithMessage("删除失败, 自杀失败", c)
  248. return
  249. }
  250. if err := userService.DeleteUser(reqId.ID); err != nil {
  251. global.GVA_LOG.Error("删除失败!", zap.Error(err))
  252. response.FailWithMessage("删除失败", c)
  253. } else {
  254. response.OkWithMessage("删除成功", c)
  255. }
  256. }
  257. // @Tags SysUser
  258. // @Summary 设置用户信息
  259. // @Security ApiKeyAuth
  260. // @accept application/json
  261. // @Produce application/json
  262. // @Param data body system.SysUser true "ID, 用户名, 昵称, 头像链接"
  263. // @Success 200 {object} response.Response{data=map[string]interface{},msg=string} "设置用户信息"
  264. // @Router /user/setUserInfo [put]
  265. func (b *BaseApi) SetUserInfo(c *gin.Context) {
  266. var user systemReq.ChangeUserInfo
  267. _ = c.ShouldBindJSON(&user)
  268. if err := utils.Verify(user, utils.IdVerify); err != nil {
  269. response.FailWithMessage(err.Error(), c)
  270. return
  271. }
  272. if len(user.AuthorityIds) != 0 {
  273. err := userService.SetUserAuthorities(user.ID, user.AuthorityIds)
  274. if err != nil {
  275. global.GVA_LOG.Error("设置失败!", zap.Error(err))
  276. response.FailWithMessage("设置失败", c)
  277. return
  278. }
  279. }
  280. if err := userService.SetUserInfo(system.SysUser{
  281. GVA_MODEL: global.GVA_MODEL{
  282. ID: user.ID,
  283. },
  284. NickName: user.NickName,
  285. HeaderImg: user.HeaderImg,
  286. Phone: user.Phone,
  287. Email: user.Email,
  288. SideMode: user.SideMode,
  289. Enable: user.Enable,
  290. }); err != nil {
  291. global.GVA_LOG.Error("设置失败!", zap.Error(err))
  292. response.FailWithMessage("设置失败", c)
  293. } else {
  294. response.OkWithMessage("设置成功", c)
  295. }
  296. }
  297. // @Tags SysUser
  298. // @Summary 设置用户信息
  299. // @Security ApiKeyAuth
  300. // @accept application/json
  301. // @Produce application/json
  302. // @Param data body system.SysUser true "ID, 用户名, 昵称, 头像链接"
  303. // @Success 200 {object} response.Response{data=map[string]interface{},msg=string} "设置用户信息"
  304. // @Router /user/SetSelfInfo [put]
  305. func (b *BaseApi) SetSelfInfo(c *gin.Context) {
  306. var user systemReq.ChangeUserInfo
  307. _ = c.ShouldBindJSON(&user)
  308. user.ID = utils.GetUserID(c)
  309. if err := userService.SetUserInfo(system.SysUser{
  310. GVA_MODEL: global.GVA_MODEL{
  311. ID: user.ID,
  312. },
  313. NickName: user.NickName,
  314. HeaderImg: user.HeaderImg,
  315. Phone: user.Phone,
  316. Email: user.Email,
  317. SideMode: user.SideMode,
  318. Enable: user.Enable,
  319. }); err != nil {
  320. global.GVA_LOG.Error("设置失败!", zap.Error(err))
  321. response.FailWithMessage("设置失败", c)
  322. } else {
  323. response.OkWithMessage("设置成功", c)
  324. }
  325. }
  326. // @Tags SysUser
  327. // @Summary 获取用户信息
  328. // @Security ApiKeyAuth
  329. // @accept application/json
  330. // @Produce application/json
  331. // @Success 200 {object} response.Response{data=map[string]interface{},msg=string} "获取用户信息"
  332. // @Router /user/getUserInfo [get]
  333. func (b *BaseApi) GetUserInfo(c *gin.Context) {
  334. uuid := utils.GetUserUuid(c)
  335. if ReqUser, err := userService.GetUserInfo(uuid); err != nil {
  336. global.GVA_LOG.Error("获取失败!", zap.Error(err))
  337. response.FailWithMessage("获取失败", c)
  338. } else {
  339. response.OkWithDetailed(gin.H{"userInfo": ReqUser}, "获取成功", c)
  340. }
  341. }
  342. // @Tags SysUser
  343. // @Summary 重置用户密码
  344. // @Security ApiKeyAuth
  345. // @Produce application/json
  346. // @Param data body system.SysUser true "ID"
  347. // @Success 200 {object} response.Response{msg=string} "重置用户密码"
  348. // @Router /user/resetPassword [post]
  349. func (b *BaseApi) ResetPassword(c *gin.Context) {
  350. var user system.SysUser
  351. _ = c.ShouldBindJSON(&user)
  352. if err := userService.ResetPassword(user.ID); err != nil {
  353. global.GVA_LOG.Error("重置失败!", zap.Error(err))
  354. response.FailWithMessage("重置失败"+err.Error(), c)
  355. } else {
  356. response.OkWithMessage("重置成功", c)
  357. }
  358. }