You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

loaded_access_token.go 1.9 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. package db
  2. import (
  3. "time"
  4. cortypes "gitlink.org.cn/cloudream/jcs-pub/coordinator/types"
  5. "gorm.io/gorm/clause"
  6. )
  7. type LoadedAccessTokenDB struct {
  8. *DB
  9. }
  10. func (db *DB) LoadedAccessToken() *LoadedAccessTokenDB {
  11. return &LoadedAccessTokenDB{DB: db}
  12. }
  13. func (db *LoadedAccessTokenDB) GetByUserIDAndTokenID(ctx SQLContext, userID cortypes.UserID, tokenID cortypes.AccessTokenID) ([]cortypes.LoadedAccessToken, error) {
  14. var ret []cortypes.LoadedAccessToken
  15. err := ctx.Table("LoadedAccessToken").Where("UserID = ? AND TokenID = ?", userID, tokenID).Find(&ret).Error
  16. return ret, err
  17. }
  18. func (*LoadedAccessTokenDB) CreateOrUpdate(ctx SQLContext, token cortypes.LoadedAccessToken) error {
  19. return ctx.Clauses(clause.OnConflict{
  20. Columns: []clause.Column{{Name: "UserID"}, {Name: "TokenID"}, {Name: "HubID"}},
  21. DoUpdates: clause.AssignmentColumns([]string{"LoadedAt"}),
  22. }).Create(token).Error
  23. }
  24. func (*LoadedAccessTokenDB) GetExpired(ctx SQLContext, expireAt time.Time) ([]cortypes.LoadedAccessToken, error) {
  25. var ret []cortypes.LoadedAccessToken
  26. err := ctx.Table("LoadedAccessToken").
  27. Select("LoadedAccessToken.*").
  28. Joins("join UserAccessToken on UserAccessToken.UserID = LoadedAccessToken.UserID and UserAccessToken.TokenID = LoadedAccessToken.TokenID").
  29. Where("UserAccessToken.ExpiresAt < ?", expireAt).
  30. Find(&ret).Error
  31. return ret, err
  32. }
  33. func (*LoadedAccessTokenDB) DeleteExpired(ctx SQLContext, expireAt time.Time) error {
  34. return ctx.Table("LoadedAccessToken").
  35. Where("UserID in (select UserID from UserAccessToken where ExpiresAt < ?)", expireAt).
  36. Delete(&cortypes.LoadedAccessToken{}).Error
  37. }
  38. func (db *LoadedAccessTokenDB) DeleteAllByUserIDAndTokenID(ctx SQLContext, userID cortypes.UserID, tokenID cortypes.AccessTokenID) error {
  39. return ctx.Table("LoadedAccessToken").Where("UserID = ? AND TokenID = ?", userID, tokenID).Delete(&cortypes.LoadedAccessToken{}).Error
  40. }

本项目旨在将云际存储公共基础设施化,使个人及企业可低门槛使用高效的云际存储服务(安装开箱即用云际存储客户端即可,无需关注其他组件的部署),同时支持用户灵活便捷定制云际存储的功能细节。