user.go 11 KB

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