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

2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. package mq
  2. import (
  3. "database/sql"
  4. "fmt"
  5. "time"
  6. "github.com/jmoiron/sqlx"
  7. "gitlink.org.cn/cloudream/common/consts/errorcode"
  8. "gitlink.org.cn/cloudream/common/pkgs/logger"
  9. "gitlink.org.cn/cloudream/common/pkgs/mq"
  10. coormq "gitlink.org.cn/cloudream/storage/common/pkgs/mq/coordinator"
  11. )
  12. func (svc *Service) GetStorageInfo(msg *coormq.GetStorageInfo) (*coormq.GetStorageInfoResp, *mq.CodeMessage) {
  13. stg, err := svc.db.Storage().GetUserStorage(svc.db.SQLCtx(), msg.UserID, msg.StorageID)
  14. if err != nil {
  15. logger.Warnf("getting user storage: %s", err.Error())
  16. return nil, mq.Failed(errorcode.OperationFailed, "get user storage failed")
  17. }
  18. return mq.ReplyOK(coormq.NewGetStorageInfoResp(stg.StorageID, stg.Name, stg.NodeID, stg.Directory, stg.State))
  19. }
  20. func (svc *Service) StoragePackageLoaded(msg *coormq.StoragePackageLoaded) (*coormq.StoragePackageLoadedResp, *mq.CodeMessage) {
  21. err := svc.db.DoTx(sql.LevelSerializable, func(tx *sqlx.Tx) error {
  22. // 可以不用检查用户是否存在
  23. if ok, _ := svc.db.Package().IsAvailable(tx, msg.UserID, msg.PackageID); !ok {
  24. return fmt.Errorf("package is not available to user")
  25. }
  26. if ok, _ := svc.db.Storage().IsAvailable(tx, msg.UserID, msg.StorageID); !ok {
  27. return fmt.Errorf("storage is not available to user")
  28. }
  29. err := svc.db.StoragePackage().Create(tx, msg.StorageID, msg.PackageID, msg.UserID)
  30. if err != nil {
  31. return fmt.Errorf("creating storage package: %w", err)
  32. }
  33. err = svc.db.StoragePackageLog().Create(tx, msg.StorageID, msg.PackageID, msg.UserID, time.Now())
  34. if err != nil {
  35. return fmt.Errorf("creating storage package log: %w", err)
  36. }
  37. stg, err := svc.db.Storage().GetByID(tx, msg.StorageID)
  38. if err != nil {
  39. return fmt.Errorf("getting storage: %w", err)
  40. }
  41. err = svc.db.PinnedObject().CreateFromPackage(tx, msg.PackageID, stg.NodeID)
  42. if err != nil {
  43. return fmt.Errorf("creating pinned object from package: %w", err)
  44. }
  45. if len(msg.PinnedBlocks) > 0 {
  46. err = svc.db.ObjectBlock().BatchCreate(tx, msg.PinnedBlocks)
  47. if err != nil {
  48. return fmt.Errorf("batch creating object block: %w", err)
  49. }
  50. }
  51. return nil
  52. })
  53. if err != nil {
  54. logger.WithField("UserID", msg.UserID).
  55. WithField("StorageID", msg.StorageID).
  56. WithField("PackageID", msg.PackageID).
  57. Warn(err.Error())
  58. return nil, mq.Failed(errorcode.OperationFailed, "user load package to storage failed")
  59. }
  60. return mq.ReplyOK(coormq.NewStoragePackageLoadedResp())
  61. }

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