user.go 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384
  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. func (us *UserService) InfoByUsername(un string) *model.User {
  22. u := &model.User{}
  23. global.DB.Where("username = ?", un).First(u)
  24. return u
  25. }
  26. // InfoByOpenid 根据openid取用户信息
  27. func (us *UserService) InfoByOpenid(openid string) *model.User {
  28. u := &model.User{}
  29. global.DB.Where("openid = ?", openid).First(u)
  30. return u
  31. }
  32. // InfoByUsernamePassword 根据用户名密码取用户信息
  33. func (us *UserService) InfoByUsernamePassword(username, password string) *model.User {
  34. u := &model.User{}
  35. global.DB.Where("username = ? and password = ?", username, us.EncryptPassword(password)).First(u)
  36. return u
  37. }
  38. // InfoByAccesstoken 根据accesstoken取用户信息
  39. func (us *UserService) InfoByAccessToken(token string) *model.User {
  40. u := &model.User{}
  41. ut := &model.UserToken{}
  42. global.DB.Where("token = ?", token).First(ut)
  43. if ut.Id == 0 {
  44. return u
  45. }
  46. if ut.ExpiredAt < time.Now().Unix() {
  47. return u
  48. }
  49. global.DB.Where("id = ?", ut.UserId).First(u)
  50. return u
  51. }
  52. // GenerateToken 生成token
  53. func (us *UserService) GenerateToken(u *model.User) string {
  54. return utils.Md5(u.Username + time.Now().String())
  55. }
  56. // Login 登录
  57. func (us *UserService) Login(u *model.User, llog *model.LoginLog) *model.UserToken {
  58. token := us.GenerateToken(u)
  59. ut := &model.UserToken{
  60. UserId: u.Id,
  61. Token: token,
  62. ExpiredAt: time.Now().Add(time.Hour * 24 * 7).Unix(),
  63. }
  64. global.DB.Create(ut)
  65. llog.UserTokenId = ut.UserId
  66. global.DB.Create(llog)
  67. if llog.Uuid != "" {
  68. AllService.PeerService.UuidBindUserId(llog.Uuid, u.Id)
  69. }
  70. return ut
  71. }
  72. // CurUser 获取当前用户
  73. func (us *UserService) CurUser(c *gin.Context) *model.User {
  74. user, _ := c.Get("curUser")
  75. u, ok := user.(*model.User)
  76. if !ok {
  77. return nil
  78. }
  79. return u
  80. }
  81. func (us *UserService) List(page, pageSize uint, where func(tx *gorm.DB)) (res *model.UserList) {
  82. res = &model.UserList{}
  83. res.Page = int64(page)
  84. res.PageSize = int64(pageSize)
  85. tx := global.DB.Model(&model.User{})
  86. if where != nil {
  87. where(tx)
  88. }
  89. tx.Count(&res.Total)
  90. tx.Scopes(Paginate(page, pageSize))
  91. tx.Find(&res.Users)
  92. return
  93. }
  94. func (us *UserService) ListByIds(ids []uint) (res []*model.User) {
  95. global.DB.Where("id in ?", ids).Find(&res)
  96. return res
  97. }
  98. // ListByGroupId 根据组id取用户列表
  99. func (us *UserService) ListByGroupId(groupId, page, pageSize uint) (res *model.UserList) {
  100. res = us.List(page, pageSize, func(tx *gorm.DB) {
  101. tx.Where("group_id = ?", groupId)
  102. })
  103. return
  104. }
  105. // ListIdsByGroupId 根据组id取用户id列表
  106. func (us *UserService) ListIdsByGroupId(groupId uint) (ids []uint) {
  107. global.DB.Model(&model.User{}).Where("group_id = ?", groupId).Pluck("id", &ids)
  108. return ids
  109. }
  110. // ListIdAndNameByGroupId 根据组id取用户id和用户名列表
  111. func (us *UserService) ListIdAndNameByGroupId(groupId uint) (res []*model.User) {
  112. global.DB.Model(&model.User{}).Where("group_id = ?", groupId).Select("id, username").Find(&res)
  113. return res
  114. }
  115. // EncryptPassword 加密密码
  116. func (us *UserService) EncryptPassword(password string) string {
  117. return utils.Md5(password + "rustdesk-api")
  118. }
  119. // CheckUserEnable 判断用户是否禁用
  120. func (us *UserService) CheckUserEnable(u *model.User) bool {
  121. return u.Status == model.COMMON_STATUS_ENABLE
  122. }
  123. // Create 创建
  124. func (us *UserService) Create(u *model.User) error {
  125. u.Password = us.EncryptPassword(u.Password)
  126. res := global.DB.Create(u).Error
  127. return res
  128. }
  129. // Logout 退出登录
  130. func (us *UserService) Logout(u *model.User, token string) error {
  131. return global.DB.Where("user_id = ? and token = ?", u.Id, token).Delete(&model.UserToken{}).Error
  132. }
  133. // Delete 删除用户和oauth信息
  134. func (us *UserService) Delete(u *model.User) error {
  135. tx := global.DB.Begin()
  136. // 删除用户
  137. if err := tx.Delete(u).Error; err != nil {
  138. tx.Rollback()
  139. return err
  140. }
  141. // 删除关联的 OAuth 信息
  142. if err := tx.Where("user_id = ?", u.Id).Delete(&model.UserThird{}).Error; err != nil {
  143. tx.Rollback()
  144. return err
  145. }
  146. // 删除关联的ab
  147. if err := tx.Where("user_id = ?", u.Id).Delete(&model.AddressBook{}).Error; err != nil {
  148. tx.Rollback()
  149. return err
  150. }
  151. // 删除关联的abc
  152. if err := tx.Where("user_id = ?", u.Id).Delete(&model.AddressBookCollection{}).Error; err != nil {
  153. tx.Rollback()
  154. return err
  155. }
  156. // 删除关联的abcr
  157. if err := tx.Where("user_id = ?", u.Id).Delete(&model.AddressBookCollectionRule{}).Error; err != nil {
  158. tx.Rollback()
  159. return err
  160. }
  161. tx.Commit()
  162. return nil
  163. }
  164. // Update 更新
  165. func (us *UserService) Update(u *model.User) error {
  166. return global.DB.Model(u).Updates(u).Error
  167. }
  168. // FlushToken 清空token
  169. func (us *UserService) FlushToken(u *model.User) error {
  170. return global.DB.Where("user_id = ?", u.Id).Delete(&model.UserToken{}).Error
  171. }
  172. // UpdatePassword 更新密码
  173. func (us *UserService) UpdatePassword(u *model.User, password string) error {
  174. u.Password = us.EncryptPassword(password)
  175. err := global.DB.Model(u).Update("password", u.Password).Error
  176. if err != nil {
  177. return err
  178. }
  179. err = us.FlushToken(u)
  180. return err
  181. }
  182. // IsAdmin 是否管理员
  183. func (us *UserService) IsAdmin(u *model.User) bool {
  184. return *u.IsAdmin
  185. }
  186. // RouteNames
  187. func (us *UserService) RouteNames(u *model.User) []string {
  188. if us.IsAdmin(u) {
  189. return adResp.AdminRouteNames
  190. }
  191. return adResp.UserRouteNames
  192. }
  193. // InfoByGithubId 根据githubid取用户信息
  194. func (us *UserService) InfoByGithubId(githubId string) *model.User {
  195. return us.InfoByOauthId(model.OauthTypeGithub, githubId)
  196. }
  197. // InfoByGoogleEmail 根据googleid取用户信息
  198. func (us *UserService) InfoByGoogleEmail(email string) *model.User {
  199. return us.InfoByOauthId(model.OauthTypeGithub, email)
  200. }
  201. // InfoByOidcSub 根据oidc取用户信息
  202. func (us *UserService) InfoByOidcSub(sub string) *model.User {
  203. return us.InfoByOauthId(model.OauthTypeOidc, sub)
  204. }
  205. // InfoByOauthId 根据oauth取用户信息
  206. func (us *UserService) InfoByOauthId(thirdType, uid string) *model.User {
  207. ut := AllService.OauthService.UserThirdInfo(thirdType, uid)
  208. if ut.Id == 0 {
  209. return nil
  210. }
  211. u := us.InfoById(ut.UserId)
  212. if u.Id == 0 {
  213. return nil
  214. }
  215. return u
  216. }
  217. // RegisterByGithub 注册
  218. func (us *UserService) RegisterByGithub(githubName string, githubId string) *model.User {
  219. return us.RegisterByOauth(model.OauthTypeGithub, githubName, githubId)
  220. }
  221. // RegisterByGoogle 注册
  222. func (us *UserService) RegisterByGoogle(name string, email string) *model.User {
  223. return us.RegisterByOauth(model.OauthTypeGoogle, name, email)
  224. }
  225. // RegisterByOidc 注册, use PreferredUsername as username, sub as openid
  226. func (us *UserService) RegisterByOidc(PreferredUsername string, sub string) *model.User {
  227. return us.RegisterByOauth(model.OauthTypeOidc, PreferredUsername, sub)
  228. }
  229. // RegisterByOauth 注册
  230. func (us *UserService) RegisterByOauth(thirdType, thirdName, uid string) *model.User {
  231. global.Lock.Lock("registerByOauth")
  232. defer global.Lock.UnLock("registerByOauth")
  233. ut := AllService.OauthService.UserThirdInfo(thirdType, uid)
  234. if ut.Id != 0 {
  235. u := &model.User{}
  236. global.DB.Where("id = ?", ut.UserId).First(u)
  237. return u
  238. }
  239. tx := global.DB.Begin()
  240. ut = &model.UserThird{
  241. OpenId: uid,
  242. ThirdName: thirdName,
  243. ThirdType: thirdType,
  244. }
  245. username := us.GenerateUsernameByOauth(thirdName)
  246. u := &model.User{
  247. Username: username,
  248. GroupId: 1,
  249. }
  250. tx.Create(u)
  251. if u.Id == 0 {
  252. tx.Rollback()
  253. return u
  254. }
  255. ut.UserId = u.Id
  256. tx.Create(ut)
  257. tx.Commit()
  258. return u
  259. }
  260. // GenerateUsernameByOauth 生成用户名
  261. func (us *UserService) GenerateUsernameByOauth(name string) string {
  262. u := &model.User{}
  263. global.DB.Where("username = ?", name).First(u)
  264. if u.Id == 0 {
  265. return name
  266. }
  267. name = name + strconv.FormatInt(rand.Int63n(10), 10)
  268. return us.GenerateUsernameByOauth(name)
  269. }
  270. // UserThirdsByUserId
  271. func (us *UserService) UserThirdsByUserId(userId uint) (res []*model.UserThird) {
  272. global.DB.Where("user_id = ?", userId).Find(&res)
  273. return res
  274. }
  275. func (us *UserService) UserThirdInfo(userId uint, op string) *model.UserThird {
  276. ut := &model.UserThird{}
  277. global.DB.Where("user_id = ? and third_type = ?", userId, op).First(ut)
  278. return ut
  279. }
  280. // FindLatestUserIdFromLoginLogByUuid 根据uuid查找最后登录的用户id
  281. func (us *UserService) FindLatestUserIdFromLoginLogByUuid(uuid string) uint {
  282. llog := &model.LoginLog{}
  283. global.DB.Where("uuid = ?", uuid).Order("id desc").First(llog)
  284. return llog.UserId
  285. }
  286. // IsPasswordEmptyById 根据用户id判断密码是否为空,主要用于第三方登录的自动注册
  287. func (us *UserService) IsPasswordEmptyById(id uint) bool {
  288. u := &model.User{}
  289. if global.DB.Where("id = ?", id).First(u).Error != nil {
  290. return false
  291. }
  292. return u.Password == ""
  293. }
  294. // IsPasswordEmptyByUsername 根据用户id判断密码是否为空,主要用于第三方登录的自动注册
  295. func (us *UserService) IsPasswordEmptyByUsername(username string) bool {
  296. u := &model.User{}
  297. if global.DB.Where("username = ?", username).First(u).Error != nil {
  298. return false
  299. }
  300. return u.Password == ""
  301. }
  302. // IsPasswordEmptyByUser 判断密码是否为空,主要用于第三方登录的自动注册
  303. func (us *UserService) IsPasswordEmptyByUser(u *model.User) bool {
  304. return us.IsPasswordEmptyById(u.Id)
  305. }
  306. func (us *UserService) Register(username string, password string) *model.User {
  307. u := &model.User{
  308. Username: username,
  309. Password: us.EncryptPassword(password),
  310. GroupId: 1,
  311. }
  312. global.DB.Create(u)
  313. return u
  314. }
  315. func (us *UserService) TokenList(page uint, size uint, f func(tx *gorm.DB)) *model.UserTokenList {
  316. res := &model.UserTokenList{}
  317. res.Page = int64(page)
  318. res.PageSize = int64(size)
  319. tx := global.DB.Model(&model.UserToken{})
  320. if f != nil {
  321. f(tx)
  322. }
  323. tx.Count(&res.Total)
  324. tx.Scopes(Paginate(page, size))
  325. tx.Find(&res.UserTokens)
  326. return res
  327. }
  328. func (us *UserService) TokenInfoById(id uint) *model.UserToken {
  329. ut := &model.UserToken{}
  330. global.DB.Where("id = ?", id).First(ut)
  331. return ut
  332. }
  333. func (us *UserService) DeleteToken(l *model.UserToken) error {
  334. return global.DB.Delete(l).Error
  335. }