user.go 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471
  1. package service
  2. import (
  3. "Gwen/global"
  4. "Gwen/model"
  5. "Gwen/utils"
  6. "errors"
  7. "github.com/gin-gonic/gin"
  8. "gorm.io/gorm"
  9. "math/rand"
  10. "strconv"
  11. "strings"
  12. "time"
  13. )
  14. type UserService struct {
  15. }
  16. // InfoById 根据用户id取用户信息
  17. func (us *UserService) InfoById(id uint) *model.User {
  18. u := &model.User{}
  19. global.DB.Where("id = ?", id).First(u)
  20. return u
  21. }
  22. // InfoByUsername 根据用户名取用户信息
  23. func (us *UserService) InfoByUsername(un string) *model.User {
  24. u := &model.User{}
  25. global.DB.Where("username = ?", un).First(u)
  26. return u
  27. }
  28. // InfoByEmail 根据邮箱取用户信息
  29. func (us *UserService) InfoByEmail(email string) *model.User {
  30. u := &model.User{}
  31. global.DB.Where("email = ?", email).First(u)
  32. return u
  33. }
  34. // InfoByOpenid 根据openid取用户信息
  35. func (us *UserService) InfoByOpenid(openid string) *model.User {
  36. u := &model.User{}
  37. global.DB.Where("openid = ?", openid).First(u)
  38. return u
  39. }
  40. // InfoByUsernamePassword 根据用户名密码取用户信息
  41. func (us *UserService) InfoByUsernamePassword(username, password string) *model.User {
  42. u := &model.User{}
  43. global.DB.Where("username = ? and password = ?", username, us.EncryptPassword(password)).First(u)
  44. return u
  45. }
  46. // InfoByAccesstoken 根据accesstoken取用户信息
  47. func (us *UserService) InfoByAccessToken(token string) (*model.User, *model.UserToken) {
  48. u := &model.User{}
  49. ut := &model.UserToken{}
  50. global.DB.Where("token = ?", token).First(ut)
  51. if ut.Id == 0 {
  52. return u, ut
  53. }
  54. if ut.ExpiredAt < time.Now().Unix() {
  55. return u, ut
  56. }
  57. global.DB.Where("id = ?", ut.UserId).First(u)
  58. return u, ut
  59. }
  60. // GenerateToken 生成token
  61. func (us *UserService) GenerateToken(u *model.User) string {
  62. if global.Config.Jwt.Key != "" {
  63. return global.Jwt.GenerateToken(u.Id)
  64. }
  65. return utils.Md5(u.Username + time.Now().String())
  66. }
  67. // Login 登录
  68. func (us *UserService) Login(u *model.User, llog *model.LoginLog) *model.UserToken {
  69. token := us.GenerateToken(u)
  70. ut := &model.UserToken{
  71. UserId: u.Id,
  72. Token: token,
  73. DeviceUuid: llog.Uuid,
  74. DeviceId: llog.DeviceId,
  75. ExpiredAt: time.Now().Add(time.Hour * 24 * 7).Unix(),
  76. }
  77. global.DB.Create(ut)
  78. llog.UserTokenId = ut.UserId
  79. global.DB.Create(llog)
  80. if llog.Uuid != "" {
  81. AllService.PeerService.UuidBindUserId(llog.DeviceId, llog.Uuid, u.Id)
  82. }
  83. return ut
  84. }
  85. // CurUser 获取当前用户
  86. func (us *UserService) CurUser(c *gin.Context) *model.User {
  87. user, _ := c.Get("curUser")
  88. u, ok := user.(*model.User)
  89. if !ok {
  90. return nil
  91. }
  92. return u
  93. }
  94. func (us *UserService) List(page, pageSize uint, where func(tx *gorm.DB)) (res *model.UserList) {
  95. res = &model.UserList{}
  96. res.Page = int64(page)
  97. res.PageSize = int64(pageSize)
  98. tx := global.DB.Model(&model.User{})
  99. if where != nil {
  100. where(tx)
  101. }
  102. tx.Count(&res.Total)
  103. tx.Scopes(Paginate(page, pageSize))
  104. tx.Find(&res.Users)
  105. return
  106. }
  107. func (us *UserService) ListByIds(ids []uint) (res []*model.User) {
  108. global.DB.Where("id in ?", ids).Find(&res)
  109. return res
  110. }
  111. // ListByGroupId 根据组id取用户列表
  112. func (us *UserService) ListByGroupId(groupId, page, pageSize uint) (res *model.UserList) {
  113. res = us.List(page, pageSize, func(tx *gorm.DB) {
  114. tx.Where("group_id = ?", groupId)
  115. })
  116. return
  117. }
  118. // ListIdsByGroupId 根据组id取用户id列表
  119. func (us *UserService) ListIdsByGroupId(groupId uint) (ids []uint) {
  120. global.DB.Model(&model.User{}).Where("group_id = ?", groupId).Pluck("id", &ids)
  121. return ids
  122. }
  123. // ListIdAndNameByGroupId 根据组id取用户id和用户名列表
  124. func (us *UserService) ListIdAndNameByGroupId(groupId uint) (res []*model.User) {
  125. global.DB.Model(&model.User{}).Where("group_id = ?", groupId).Select("id, username").Find(&res)
  126. return res
  127. }
  128. // EncryptPassword 加密密码
  129. func (us *UserService) EncryptPassword(password string) string {
  130. return utils.Md5(password + "rustdesk-api")
  131. }
  132. // CheckUserEnable 判断用户是否禁用
  133. func (us *UserService) CheckUserEnable(u *model.User) bool {
  134. return u.Status == model.COMMON_STATUS_ENABLE
  135. }
  136. // Create 创建
  137. func (us *UserService) Create(u *model.User) error {
  138. // The initial username should be formatted, and the username should be unique
  139. u.Username = us.formatUsername(u.Username)
  140. u.Password = us.EncryptPassword(u.Password)
  141. res := global.DB.Create(u).Error
  142. return res
  143. }
  144. // GetUuidByToken 根据token和user取uuid
  145. func (us *UserService) GetUuidByToken(u *model.User, token string) string {
  146. ut := &model.UserToken{}
  147. err := global.DB.Where("user_id = ? and token = ?", u.Id, token).First(ut).Error
  148. if err != nil {
  149. return ""
  150. }
  151. return ut.DeviceUuid
  152. }
  153. // Logout 退出登录 -> 删除token, 解绑uuid
  154. func (us *UserService) Logout(u *model.User, token string) error {
  155. uuid := us.GetUuidByToken(u, token)
  156. err := global.DB.Where("user_id = ? and token = ?", u.Id, token).Delete(&model.UserToken{}).Error
  157. if err != nil {
  158. return err
  159. }
  160. if uuid != "" {
  161. AllService.PeerService.UuidUnbindUserId(uuid, u.Id)
  162. }
  163. return nil
  164. }
  165. // Delete 删除用户和oauth信息
  166. func (us *UserService) Delete(u *model.User) error {
  167. userCount := us.getAdminUserCount()
  168. if userCount <= 1 && us.IsAdmin(u) {
  169. return errors.New("The last admin user cannot be deleted")
  170. }
  171. tx := global.DB.Begin()
  172. // 删除用户
  173. if err := tx.Delete(u).Error; err != nil {
  174. tx.Rollback()
  175. return err
  176. }
  177. // 删除关联的 OAuth 信息
  178. if err := tx.Where("user_id = ?", u.Id).Delete(&model.UserThird{}).Error; err != nil {
  179. tx.Rollback()
  180. return err
  181. }
  182. // 删除关联的ab
  183. if err := tx.Where("user_id = ?", u.Id).Delete(&model.AddressBook{}).Error; err != nil {
  184. tx.Rollback()
  185. return err
  186. }
  187. // 删除关联的abc
  188. if err := tx.Where("user_id = ?", u.Id).Delete(&model.AddressBookCollection{}).Error; err != nil {
  189. tx.Rollback()
  190. return err
  191. }
  192. // 删除关联的abcr
  193. if err := tx.Where("user_id = ?", u.Id).Delete(&model.AddressBookCollectionRule{}).Error; err != nil {
  194. tx.Rollback()
  195. return err
  196. }
  197. tx.Commit()
  198. // 删除关联的peer
  199. if err := AllService.PeerService.EraseUserId(u.Id); err != nil {
  200. global.Logger.Warn("User deleted successfully, but failed to unlink peer.")
  201. return nil
  202. }
  203. return nil
  204. }
  205. // Update 更新
  206. func (us *UserService) Update(u *model.User) error {
  207. currentUser := us.InfoById(u.Id)
  208. // 如果当前用户是管理员并且 IsAdmin 不为空,进行检查
  209. if us.IsAdmin(currentUser) {
  210. adminCount := us.getAdminUserCount()
  211. // 如果这是唯一的管理员,确保不能禁用或取消管理员权限
  212. if adminCount <= 1 && (!us.IsAdmin(u) || u.Status == model.COMMON_STATUS_DISABLED) {
  213. return errors.New("The last admin user cannot be disabled or demoted")
  214. }
  215. }
  216. return global.DB.Model(u).Updates(u).Error
  217. }
  218. // FlushToken 清空token
  219. func (us *UserService) FlushToken(u *model.User) error {
  220. return global.DB.Where("user_id = ?", u.Id).Delete(&model.UserToken{}).Error
  221. }
  222. // FlushTokenByUuid 清空token
  223. func (us *UserService) FlushTokenByUuid(uuid string) error {
  224. return global.DB.Where("device_uuid = ?", uuid).Delete(&model.UserToken{}).Error
  225. }
  226. // FlushTokenByUuids 清空token
  227. func (us *UserService) FlushTokenByUuids(uuids []string) error {
  228. return global.DB.Where("device_uuid in (?)", uuids).Delete(&model.UserToken{}).Error
  229. }
  230. // UpdatePassword 更新密码
  231. func (us *UserService) UpdatePassword(u *model.User, password string) error {
  232. u.Password = us.EncryptPassword(password)
  233. err := global.DB.Model(u).Update("password", u.Password).Error
  234. if err != nil {
  235. return err
  236. }
  237. err = us.FlushToken(u)
  238. return err
  239. }
  240. // IsAdmin 是否管理员
  241. func (us *UserService) IsAdmin(u *model.User) bool {
  242. return *u.IsAdmin
  243. }
  244. // RouteNames
  245. func (us *UserService) RouteNames(u *model.User) []string {
  246. if us.IsAdmin(u) {
  247. return model.AdminRouteNames
  248. }
  249. return model.UserRouteNames
  250. }
  251. // InfoByOauthId 根据oauth的name和openId取用户信息
  252. func (us *UserService) InfoByOauthId(op string, openId string) *model.User {
  253. ut := AllService.OauthService.UserThirdInfo(op, openId)
  254. if ut.Id == 0 {
  255. return nil
  256. }
  257. u := us.InfoById(ut.UserId)
  258. if u.Id == 0 {
  259. return nil
  260. }
  261. return u
  262. }
  263. // RegisterByOauth 注册
  264. func (us *UserService) RegisterByOauth(oauthUser *model.OauthUser, op string) (error, *model.User) {
  265. global.Lock.Lock("registerByOauth")
  266. defer global.Lock.UnLock("registerByOauth")
  267. ut := AllService.OauthService.UserThirdInfo(op, oauthUser.OpenId)
  268. if ut.Id != 0 {
  269. return nil, us.InfoById(ut.UserId)
  270. }
  271. err, oauthType := AllService.OauthService.GetTypeByOp(op)
  272. if err != nil {
  273. return err, nil
  274. }
  275. //check if this email has been registered
  276. email := oauthUser.Email
  277. // only email is not empty
  278. if email != "" {
  279. email = strings.ToLower(email)
  280. // update email to oauthUser, in case it contain upper case
  281. oauthUser.Email = email
  282. user := us.InfoByEmail(email)
  283. if user.Id != 0 {
  284. ut.FromOauthUser(user.Id, oauthUser, oauthType, op)
  285. global.DB.Create(ut)
  286. return nil, user
  287. }
  288. }
  289. tx := global.DB.Begin()
  290. ut = &model.UserThird{}
  291. ut.FromOauthUser(0, oauthUser, oauthType, op)
  292. // The initial username should be formatted
  293. username := us.formatUsername(oauthUser.Username)
  294. usernameUnique := us.GenerateUsernameByOauth(username)
  295. user := &model.User{
  296. Username: usernameUnique,
  297. GroupId: 1,
  298. }
  299. oauthUser.ToUser(user, false)
  300. tx.Create(user)
  301. if user.Id == 0 {
  302. tx.Rollback()
  303. return errors.New("OauthRegisterFailed"), user
  304. }
  305. ut.UserId = user.Id
  306. tx.Create(ut)
  307. tx.Commit()
  308. return nil, user
  309. }
  310. // GenerateUsernameByOauth 生成用户名
  311. func (us *UserService) GenerateUsernameByOauth(name string) string {
  312. u := &model.User{}
  313. global.DB.Where("username = ?", name).First(u)
  314. if u.Id == 0 {
  315. return name
  316. }
  317. name = name + strconv.FormatInt(rand.Int63n(10), 10)
  318. return us.GenerateUsernameByOauth(name)
  319. }
  320. // UserThirdsByUserId
  321. func (us *UserService) UserThirdsByUserId(userId uint) (res []*model.UserThird) {
  322. global.DB.Where("user_id = ?", userId).Find(&res)
  323. return res
  324. }
  325. func (us *UserService) UserThirdInfo(userId uint, op string) *model.UserThird {
  326. ut := &model.UserThird{}
  327. global.DB.Where("user_id = ? and op = ?", userId, op).First(ut)
  328. return ut
  329. }
  330. // FindLatestUserIdFromLoginLogByUuid 根据uuid查找最后登录的用户id
  331. func (us *UserService) FindLatestUserIdFromLoginLogByUuid(uuid string) uint {
  332. llog := &model.LoginLog{}
  333. global.DB.Where("uuid = ?", uuid).Order("id desc").First(llog)
  334. return llog.UserId
  335. }
  336. // IsPasswordEmptyById 根据用户id判断密码是否为空,主要用于第三方登录的自动注册
  337. func (us *UserService) IsPasswordEmptyById(id uint) bool {
  338. u := &model.User{}
  339. if global.DB.Where("id = ?", id).First(u).Error != nil {
  340. return false
  341. }
  342. return u.Password == ""
  343. }
  344. // IsPasswordEmptyByUsername 根据用户id判断密码是否为空,主要用于第三方登录的自动注册
  345. func (us *UserService) IsPasswordEmptyByUsername(username string) bool {
  346. u := &model.User{}
  347. if global.DB.Where("username = ?", username).First(u).Error != nil {
  348. return false
  349. }
  350. return u.Password == ""
  351. }
  352. // IsPasswordEmptyByUser 判断密码是否为空,主要用于第三方登录的自动注册
  353. func (us *UserService) IsPasswordEmptyByUser(u *model.User) bool {
  354. return us.IsPasswordEmptyById(u.Id)
  355. }
  356. // Register 注册
  357. func (us *UserService) Register(username string, email string, password string) *model.User {
  358. u := &model.User{
  359. Username: username,
  360. Email: email,
  361. Password: us.EncryptPassword(password),
  362. GroupId: 1,
  363. }
  364. global.DB.Create(u)
  365. return u
  366. }
  367. func (us *UserService) TokenList(page uint, size uint, f func(tx *gorm.DB)) *model.UserTokenList {
  368. res := &model.UserTokenList{}
  369. res.Page = int64(page)
  370. res.PageSize = int64(size)
  371. tx := global.DB.Model(&model.UserToken{})
  372. if f != nil {
  373. f(tx)
  374. }
  375. tx.Count(&res.Total)
  376. tx.Scopes(Paginate(page, size))
  377. tx.Find(&res.UserTokens)
  378. return res
  379. }
  380. func (us *UserService) TokenInfoById(id uint) *model.UserToken {
  381. ut := &model.UserToken{}
  382. global.DB.Where("id = ?", id).First(ut)
  383. return ut
  384. }
  385. func (us *UserService) DeleteToken(l *model.UserToken) error {
  386. return global.DB.Delete(l).Error
  387. }
  388. // Helper functions, used for formatting username
  389. func (us *UserService) formatUsername(username string) string {
  390. username = strings.ReplaceAll(username, " ", "")
  391. username = strings.ToLower(username)
  392. return username
  393. }
  394. // Helper functions, getUserCount
  395. func (us *UserService) getUserCount() int64 {
  396. var count int64
  397. global.DB.Model(&model.User{}).Count(&count)
  398. return count
  399. }
  400. // helper functions, getAdminUserCount
  401. func (us *UserService) getAdminUserCount() int64 {
  402. var count int64
  403. global.DB.Model(&model.User{}).Where("is_admin = ?", true).Count(&count)
  404. return count
  405. }
  406. func (us *UserService) RefreshAccessToken(ut *model.UserToken) {
  407. ut.ExpiredAt = time.Now().Add(time.Hour * 24 * 7).Unix()
  408. global.DB.Model(ut).Update("expired_at", ut.ExpiredAt)
  409. }
  410. func (us *UserService) AutoRefreshAccessToken(ut *model.UserToken) {
  411. if ut.ExpiredAt-time.Now().Unix() < 86400 {
  412. us.RefreshAccessToken(ut)
  413. }
  414. }
  415. func (us *UserService) BatchDeleteUserToken(ids []uint) error {
  416. return global.DB.Where("id in ?", ids).Delete(&model.UserToken{}).Error
  417. }
  418. func (us *UserService) VerifyJWT(token string) (uint, error) {
  419. return global.Jwt.ParseToken(token)
  420. }