user.go 12 KB

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