user.go 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. package service
  2. import (
  3. "Gwen/global"
  4. adResp "Gwen/http/response/admin"
  5. "Gwen/model"
  6. "Gwen/utils"
  7. "github.com/gin-gonic/gin"
  8. "gorm.io/gorm"
  9. "time"
  10. )
  11. type UserService struct {
  12. }
  13. // InfoById 根据用户id取用户信息
  14. func (us *UserService) InfoById(id uint) *model.User {
  15. u := &model.User{}
  16. global.DB.Where("id = ?", id).First(u)
  17. return u
  18. }
  19. // InfoByOpenid 根据openid取用户信息
  20. func (us *UserService) InfoByOpenid(openid string) *model.User {
  21. u := &model.User{}
  22. global.DB.Where("openid = ?", openid).First(u)
  23. return u
  24. }
  25. // InfoByUsernamePassword 根据用户名密码取用户信息
  26. func (us *UserService) InfoByUsernamePassword(username, password string) *model.User {
  27. u := &model.User{}
  28. global.DB.Where("username = ? and password = ?", username, us.EncryptPassword(password)).First(u)
  29. return u
  30. }
  31. // InfoByAccesstoken 根据accesstoken取用户信息
  32. func (us *UserService) InfoByAccessToken(token string) *model.User {
  33. u := &model.User{}
  34. ut := &model.UserToken{}
  35. global.DB.Where("token = ?", token).First(ut)
  36. if ut.Id == 0 {
  37. return u
  38. }
  39. if ut.ExpiredAt < time.Now().Unix() {
  40. return u
  41. }
  42. global.DB.Where("id = ?", ut.UserId).First(u)
  43. return u
  44. }
  45. // GenerateToken 生成token
  46. func (us *UserService) GenerateToken(u *model.User) string {
  47. return utils.Md5(u.Username + u.Password + time.Now().String())
  48. }
  49. // Login 登录
  50. func (us *UserService) Login(u *model.User) *model.UserToken {
  51. token := us.GenerateToken(u)
  52. ut := &model.UserToken{
  53. UserId: u.Id,
  54. Token: token,
  55. ExpiredAt: time.Now().Add(time.Hour * 24 * 7).Unix(),
  56. }
  57. global.DB.Create(ut)
  58. return ut
  59. }
  60. // CurUser 获取当前用户
  61. func (us *UserService) CurUser(c *gin.Context) *model.User {
  62. user, _ := c.Get("curUser")
  63. u, ok := user.(*model.User)
  64. if !ok {
  65. return nil
  66. }
  67. return u
  68. }
  69. func (us *UserService) List(page, pageSize uint, where func(tx *gorm.DB)) (res *model.UserList) {
  70. res = &model.UserList{}
  71. res.Page = int64(page)
  72. res.PageSize = int64(pageSize)
  73. tx := global.DB.Model(&model.User{})
  74. if where != nil {
  75. where(tx)
  76. }
  77. tx.Count(&res.Total)
  78. tx.Scopes(Paginate(page, pageSize))
  79. tx.Find(&res.Users)
  80. return
  81. }
  82. // ListByGroupId 根据组id取用户列表
  83. func (us *UserService) ListByGroupId(groupId, page, pageSize uint) (res *model.UserList) {
  84. res = us.List(page, pageSize, func(tx *gorm.DB) {
  85. tx.Where("group_id = ?", groupId)
  86. })
  87. return
  88. }
  89. // ListIdsByGroupId 根据组id取用户id列表
  90. func (us *UserService) ListIdsByGroupId(groupId uint) (ids []uint) {
  91. global.DB.Model(&model.User{}).Where("group_id = ?", groupId).Pluck("id", &ids)
  92. return ids
  93. }
  94. // ListIdAndNameByGroupId 根据组id取用户id和用户名列表
  95. func (us *UserService) ListIdAndNameByGroupId(groupId uint) (res []*model.User) {
  96. global.DB.Model(&model.User{}).Where("group_id = ?", groupId).Select("id, username").Find(&res)
  97. return res
  98. }
  99. // EncryptPassword 加密密码
  100. func (us *UserService) EncryptPassword(password string) string {
  101. return utils.Md5(password + "rustdesk-api")
  102. }
  103. // CheckUserEnable 判断用户是否禁用
  104. func (us *UserService) CheckUserEnable(u *model.User) bool {
  105. return u.Status == model.COMMON_STATUS_ENABLE
  106. }
  107. // Create 创建
  108. func (us *UserService) Create(u *model.User) error {
  109. u.Password = us.EncryptPassword(u.Password)
  110. res := global.DB.Create(u).Error
  111. return res
  112. }
  113. // Logout 退出登录
  114. func (us *UserService) Logout(u *model.User, token string) error {
  115. return global.DB.Where("user_id = ? and token = ?", u.Id, token).Delete(&model.UserToken{}).Error
  116. }
  117. func (us *UserService) Delete(u *model.User) error {
  118. return global.DB.Delete(u).Error
  119. }
  120. // Update 更新
  121. func (us *UserService) Update(u *model.User) error {
  122. return global.DB.Model(u).Updates(u).Error
  123. }
  124. // FlushToken 清空token
  125. func (us *UserService) FlushToken(u *model.User) error {
  126. return global.DB.Where("user_id = ?", u.Id).Delete(&model.UserToken{}).Error
  127. }
  128. // UpdatePassword 更新密码
  129. func (us *UserService) UpdatePassword(u *model.User, password string) error {
  130. u.Password = us.EncryptPassword(password)
  131. err := global.DB.Model(u).Update("password", u.Password).Error
  132. if err != nil {
  133. return err
  134. }
  135. err = us.FlushToken(u)
  136. return err
  137. }
  138. // IsAdmin 是否管理员
  139. func (us *UserService) IsAdmin(u *model.User) bool {
  140. return *u.IsAdmin
  141. }
  142. // RouteNames
  143. func (us *UserService) RouteNames(u *model.User) []string {
  144. if us.IsAdmin(u) {
  145. return adResp.AdminRouteNames
  146. }
  147. return adResp.UserRouteNames
  148. }