user.go 10 KB

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