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.

storage.go 1.3 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. package db
  2. import (
  3. cortypes "gitlink.org.cn/cloudream/jcs-pub/coordinator/types"
  4. )
  5. type StorageDB struct {
  6. *DB
  7. }
  8. func (db *DB) Storage() *StorageDB {
  9. return &StorageDB{DB: db}
  10. }
  11. func (db *StorageDB) GetByID(ctx SQLContext, stgID cortypes.StorageID) (cortypes.Storage, error) {
  12. var stg cortypes.Storage
  13. err := ctx.Table("Storage").First(&stg, stgID).Error
  14. return stg, err
  15. }
  16. func (StorageDB) GetAllIDs(ctx SQLContext) ([]cortypes.StorageID, error) {
  17. var stgs []cortypes.StorageID
  18. err := ctx.Table("Storage").Select("StorageID").Find(&stgs).Error
  19. return stgs, err
  20. }
  21. func (db *StorageDB) BatchGetByID(ctx SQLContext, stgIDs []cortypes.StorageID) ([]cortypes.Storage, error) {
  22. var stgs []cortypes.Storage
  23. err := ctx.Table("Storage").Find(&stgs, "StorageID IN (?)", stgIDs).Error
  24. return stgs, err
  25. }
  26. func (db *StorageDB) BatchGetAllStorageIDs(ctx SQLContext, start int, count int) ([]cortypes.StorageID, error) {
  27. var ret []cortypes.StorageID
  28. err := ctx.Table("Storage").Select("StorageID").Find(&ret).Limit(count).Offset(start).Error
  29. return ret, err
  30. }
  31. func (db *StorageDB) GetHubStorages(ctx SQLContext, hubID cortypes.HubID) ([]cortypes.Storage, error) {
  32. var stgs []cortypes.Storage
  33. err := ctx.Table("Storage").Select("Storage.*").Find(&stgs, "MasterHub = ?", hubID).Error
  34. return stgs, err
  35. }

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