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.7 kB

2 years ago
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. package db
  2. import (
  3. "database/sql"
  4. "fmt"
  5. "github.com/jmoiron/sqlx"
  6. "gitlink.org.cn/cloudream/storage/common/pkgs/db/model"
  7. )
  8. type StorageDB struct {
  9. *DB
  10. }
  11. func (db *DB) Storage() *StorageDB {
  12. return &StorageDB{DB: db}
  13. }
  14. func (db *StorageDB) GetByID(ctx SQLContext, stgID int64) (model.Storage, error) {
  15. var stg model.Storage
  16. err := sqlx.Get(ctx, &stg, "select * from Storage where StorageID = ?", stgID)
  17. return stg, err
  18. }
  19. func (db *StorageDB) BatchGetAllStorageIDs(ctx SQLContext, start int, count int) ([]int64, error) {
  20. var ret []int64
  21. err := sqlx.Select(ctx, &ret, "select StorageID from Storage limit ?, ?", start, count)
  22. return ret, err
  23. }
  24. func (db *StorageDB) IsAvailable(ctx SQLContext, userID int64, storageID int64) (bool, error) {
  25. var stgID int64
  26. err := sqlx.Get(ctx, &stgID,
  27. "select Storage.StorageID from Storage, UserStorage where"+
  28. " Storage.StorageID = ? and"+
  29. " Storage.StorageID = UserStorage.StorageID and"+
  30. " UserStorage.UserID = ?",
  31. storageID, userID)
  32. if err == sql.ErrNoRows {
  33. return false, nil
  34. }
  35. if err != nil {
  36. return false, fmt.Errorf("find storage failed, err: %w", err)
  37. }
  38. return true, nil
  39. }
  40. func (db *StorageDB) GetUserStorage(ctx SQLContext, userID int64, storageID int64) (model.Storage, error) {
  41. var stg model.Storage
  42. err := sqlx.Get(ctx, &stg,
  43. "select Storage.* from UserStorage, Storage where UserID = ? and UserStorage.StorageID = ? and UserStorage.StorageID = Storage.StorageID",
  44. userID,
  45. storageID)
  46. return stg, err
  47. }
  48. func (db *StorageDB) ChangeState(ctx SQLContext, storageID int64, state string) error {
  49. _, err := ctx.Exec("update Storage set State = ? where StorageID = ?", state, storageID)
  50. return err
  51. }

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