user.go 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  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. "math/rand"
  10. "strconv"
  11. "time"
  12. )
  13. type UserService struct {
  14. }
  15. // InfoById 根据用户id取用户信息
  16. func (us *UserService) InfoById(id uint) *model.User {
  17. u := &model.User{}
  18. global.DB.Where("id = ?", id).First(u)
  19. return u
  20. }
  21. // InfoByOpenid 根据openid取用户信息
  22. func (us *UserService) InfoByOpenid(openid string) *model.User {
  23. u := &model.User{}
  24. global.DB.Where("openid = ?", openid).First(u)
  25. return u
  26. }
  27. // InfoByUsernamePassword 根据用户名密码取用户信息
  28. func (us *UserService) InfoByUsernamePassword(username, password string) *model.User {
  29. u := &model.User{}
  30. global.DB.Where("username = ? and password = ?", username, us.EncryptPassword(password)).First(u)
  31. return u
  32. }
  33. // InfoByAccesstoken 根据accesstoken取用户信息
  34. func (us *UserService) InfoByAccessToken(token string) *model.User {
  35. u := &model.User{}
  36. ut := &model.UserToken{}
  37. global.DB.Where("token = ?", token).First(ut)
  38. if ut.Id == 0 {
  39. return u
  40. }
  41. if ut.ExpiredAt < time.Now().Unix() {
  42. return u
  43. }
  44. global.DB.Where("id = ?", ut.UserId).First(u)
  45. return u
  46. }
  47. // GenerateToken 生成token
  48. func (us *UserService) GenerateToken(u *model.User) string {
  49. return utils.Md5(u.Username + time.Now().String())
  50. }
  51. // Login 登录
  52. func (us *UserService) Login(u *model.User, llog *model.LoginLog) *model.UserToken {
  53. token := us.GenerateToken(u)
  54. ut := &model.UserToken{
  55. UserId: u.Id,
  56. Token: token,
  57. ExpiredAt: time.Now().Add(time.Hour * 24 * 7).Unix(),
  58. }
  59. global.DB.Create(ut)
  60. global.DB.Create(llog)
  61. return ut
  62. }
  63. // CurUser 获取当前用户
  64. func (us *UserService) CurUser(c *gin.Context) *model.User {
  65. user, _ := c.Get("curUser")
  66. u, ok := user.(*model.User)
  67. if !ok {
  68. return nil
  69. }
  70. return u
  71. }
  72. func (us *UserService) List(page, pageSize uint, where func(tx *gorm.DB)) (res *model.UserList) {
  73. res = &model.UserList{}
  74. res.Page = int64(page)
  75. res.PageSize = int64(pageSize)
  76. tx := global.DB.Model(&model.User{})
  77. if where != nil {
  78. where(tx)
  79. }
  80. tx.Count(&res.Total)
  81. tx.Scopes(Paginate(page, pageSize))
  82. tx.Find(&res.Users)
  83. return
  84. }
  85. // ListByGroupId 根据组id取用户列表
  86. func (us *UserService) ListByGroupId(groupId, page, pageSize uint) (res *model.UserList) {
  87. res = us.List(page, pageSize, func(tx *gorm.DB) {
  88. tx.Where("group_id = ?", groupId)
  89. })
  90. return
  91. }
  92. // ListIdsByGroupId 根据组id取用户id列表
  93. func (us *UserService) ListIdsByGroupId(groupId uint) (ids []uint) {
  94. global.DB.Model(&model.User{}).Where("group_id = ?", groupId).Pluck("id", &ids)
  95. return ids
  96. }
  97. // ListIdAndNameByGroupId 根据组id取用户id和用户名列表
  98. func (us *UserService) ListIdAndNameByGroupId(groupId uint) (res []*model.User) {
  99. global.DB.Model(&model.User{}).Where("group_id = ?", groupId).Select("id, username").Find(&res)
  100. return res
  101. }
  102. // EncryptPassword 加密密码
  103. func (us *UserService) EncryptPassword(password string) string {
  104. return utils.Md5(password + "rustdesk-api")
  105. }
  106. // CheckUserEnable 判断用户是否禁用
  107. func (us *UserService) CheckUserEnable(u *model.User) bool {
  108. return u.Status == model.COMMON_STATUS_ENABLE
  109. }
  110. // Create 创建
  111. func (us *UserService) Create(u *model.User) error {
  112. u.Password = us.EncryptPassword(u.Password)
  113. res := global.DB.Create(u).Error
  114. return res
  115. }
  116. // Logout 退出登录
  117. func (us *UserService) Logout(u *model.User, token string) error {
  118. return global.DB.Where("user_id = ? and token = ?", u.Id, token).Delete(&model.UserToken{}).Error
  119. }
  120. func (us *UserService) Delete(u *model.User) error {
  121. return global.DB.Delete(u).Error
  122. }
  123. // Update 更新
  124. func (us *UserService) Update(u *model.User) error {
  125. return global.DB.Model(u).Updates(u).Error
  126. }
  127. // FlushToken 清空token
  128. func (us *UserService) FlushToken(u *model.User) error {
  129. return global.DB.Where("user_id = ?", u.Id).Delete(&model.UserToken{}).Error
  130. }
  131. // UpdatePassword 更新密码
  132. func (us *UserService) UpdatePassword(u *model.User, password string) error {
  133. u.Password = us.EncryptPassword(password)
  134. err := global.DB.Model(u).Update("password", u.Password).Error
  135. if err != nil {
  136. return err
  137. }
  138. err = us.FlushToken(u)
  139. return err
  140. }
  141. // IsAdmin 是否管理员
  142. func (us *UserService) IsAdmin(u *model.User) bool {
  143. return *u.IsAdmin
  144. }
  145. // RouteNames
  146. func (us *UserService) RouteNames(u *model.User) []string {
  147. if us.IsAdmin(u) {
  148. return adResp.AdminRouteNames
  149. }
  150. return adResp.UserRouteNames
  151. }
  152. // InfoByGithubId 根据githubid取用户信息
  153. func (us *UserService) InfoByGithubId(githubId string) *model.User {
  154. return us.InfoByOauthId(model.OauthTypeGithub, githubId)
  155. }
  156. // InfoByGoogleEmail 根据googleid取用户信息
  157. func (us *UserService) InfoByGoogleEmail(email string) *model.User {
  158. return us.InfoByOauthId(model.OauthTypeGithub, email)
  159. }
  160. // InfoByOauthId 根据oauth取用户信息
  161. func (us *UserService) InfoByOauthId(thirdType, uid string) *model.User {
  162. ut := AllService.OauthService.UserThirdInfo(thirdType, uid)
  163. if ut.Id == 0 {
  164. return nil
  165. }
  166. u := us.InfoById(ut.UserId)
  167. if u.Id == 0 {
  168. return nil
  169. }
  170. return u
  171. }
  172. // RegisterByGithub 注册
  173. func (us *UserService) RegisterByGithub(githubName string, githubId string) *model.User {
  174. return us.RegisterByOauth(model.OauthTypeGithub, githubName, githubId)
  175. }
  176. // RegisterByGoogle 注册
  177. func (us *UserService) RegisterByGoogle(name string, email string) *model.User {
  178. return us.RegisterByOauth(model.OauthTypeGoogle, name, email)
  179. }
  180. // RegisterByOauth 注册
  181. func (us *UserService) RegisterByOauth(thirdType, thirdName, uid string) *model.User {
  182. tx := global.DB.Begin()
  183. ut := &model.UserThird{
  184. OpenId: uid,
  185. ThirdName: thirdName,
  186. ThirdType: thirdType,
  187. }
  188. //global.DB.Where("open_id = ?", githubId).First(ut)
  189. //这种情况不应该出现,如果出现说明有bug
  190. //if ut.Id != 0 {
  191. // u := &model.User{}
  192. // global.DB.Where("id = ?", ut.UserId).First(u)
  193. // tx.Commit()
  194. // return u
  195. //}
  196. username := us.GenerateUsernameByOauth(thirdName)
  197. u := &model.User{
  198. Username: username,
  199. GroupId: 1,
  200. }
  201. global.DB.Create(u)
  202. ut.UserId = u.Id
  203. global.DB.Create(ut)
  204. tx.Commit()
  205. return u
  206. }
  207. // GenerateUsernameByOauth 生成用户名
  208. func (us *UserService) GenerateUsernameByOauth(name string) string {
  209. u := &model.User{}
  210. global.DB.Where("username = ?", name).First(u)
  211. if u.Id == 0 {
  212. return name
  213. }
  214. name = name + strconv.FormatInt(rand.Int63n(10), 10)
  215. return us.GenerateUsernameByOauth(name)
  216. }
  217. // UserThirdsByUserId
  218. func (us *UserService) UserThirdsByUserId(userId uint) (res []*model.UserThird) {
  219. global.DB.Where("user_id = ?", userId).Find(&res)
  220. return res
  221. }
  222. func (us *UserService) UserThirdInfo(userId uint, op string) *model.UserThird {
  223. ut := &model.UserThird{}
  224. global.DB.Where("user_id = ? and third_type = ?", userId, op).First(ut)
  225. return ut
  226. }