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

2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. package mq
  2. import (
  3. "database/sql"
  4. "fmt"
  5. "github.com/jmoiron/sqlx"
  6. "gitlink.org.cn/cloudream/common/consts/errorcode"
  7. "gitlink.org.cn/cloudream/common/pkgs/logger"
  8. "gorm.io/gorm"
  9. "gitlink.org.cn/cloudream/common/pkgs/mq"
  10. stgmod "gitlink.org.cn/cloudream/storage/common/models"
  11. "gitlink.org.cn/cloudream/storage/common/pkgs/db2"
  12. coormq "gitlink.org.cn/cloudream/storage/common/pkgs/mq/coordinator"
  13. )
  14. func (svc *Service) GetStorage(msg *coormq.GetStorage) (*coormq.GetStorageResp, *mq.CodeMessage) {
  15. stg, err := svc.db2.Storage().GetUserStorage(svc.db2.DefCtx(), msg.UserID, msg.StorageID)
  16. if err != nil {
  17. logger.Warnf("getting user storage: %s", err.Error())
  18. return nil, mq.Failed(errorcode.OperationFailed, "get user storage failed")
  19. }
  20. return mq.ReplyOK(coormq.RespGetStorage(stg))
  21. }
  22. func (svc *Service) GetStorageDetail(msg *coormq.GetStorageDetail) (*coormq.GetStorageDetailResp, *mq.CodeMessage) {
  23. var ret stgmod.StorageDetail
  24. svc.db2.DoTx(func(tx db2.SQLContext) error {
  25. stg, err := svc.db2.Storage().GetByID(tx, msg.StorageID)
  26. if err != nil {
  27. return fmt.Errorf("getting storage: %w", err)
  28. }
  29. ret.Storage = stg
  30. shard, err := svc.db2.ShardStorage().GetByStorageID(tx, msg.StorageID)
  31. if err == nil {
  32. ret.Shard = &shard
  33. } else if err != gorm.ErrRecordNotFound {
  34. return fmt.Errorf("getting shard storage: %w", err)
  35. }
  36. shared, err := svc.db2.SharedStorage().GetByStorageID(tx, msg.StorageID)
  37. if err == nil {
  38. ret.Shared = &shared
  39. } else if err != gorm.ErrRecordNotFound {
  40. return fmt.Errorf("getting shared storage: %w", err)
  41. }
  42. return nil
  43. })
  44. return mq.ReplyOK(coormq.RespGetStorageDetail(ret))
  45. }
  46. func (svc *Service) GetStorageByName(msg *coormq.GetStorageByName) (*coormq.GetStorageByNameResp, *mq.CodeMessage) {
  47. stg, err := svc.db2.Storage().GetUserStorageByName(svc.db2.DefCtx(), msg.UserID, msg.Name)
  48. if err != nil {
  49. logger.Warnf("getting user storage by name: %s", err.Error())
  50. if err == sql.ErrNoRows {
  51. return nil, mq.Failed(errorcode.DataNotFound, "storage not found")
  52. }
  53. return nil, mq.Failed(errorcode.OperationFailed, "get user storage failed")
  54. }
  55. return mq.ReplyOK(coormq.RespGetStorageByNameResp(stg))
  56. }
  57. func (svc *Service) StoragePackageLoaded(msg *coormq.StoragePackageLoaded) (*coormq.StoragePackageLoadedResp, *mq.CodeMessage) {
  58. err := svc.db.DoTx(sql.LevelSerializable, func(tx *sqlx.Tx) error {
  59. // 可以不用检查用户是否存在
  60. if ok, _ := svc.db.Package().IsAvailable(tx, msg.UserID, msg.PackageID); !ok {
  61. return fmt.Errorf("package is not available to user")
  62. }
  63. if ok, _ := svc.db.Storage().IsAvailable(tx, msg.UserID, msg.StorageID); !ok {
  64. return fmt.Errorf("storage is not available to user")
  65. }
  66. err := svc.db.StoragePackage().CreateOrUpdate(tx, msg.StorageID, msg.PackageID, msg.UserID)
  67. if err != nil {
  68. return fmt.Errorf("creating storage package: %w", err)
  69. }
  70. stg, err := svc.db.Storage().GetByID(tx, msg.StorageID)
  71. if err != nil {
  72. return fmt.Errorf("getting storage: %w", err)
  73. }
  74. err = svc.db.PinnedObject().CreateFromPackage(tx, msg.PackageID, stg.NodeID)
  75. if err != nil {
  76. return fmt.Errorf("creating pinned object from package: %w", err)
  77. }
  78. if len(msg.PinnedBlocks) > 0 {
  79. err = svc.db.ObjectBlock().BatchCreate(tx, msg.PinnedBlocks)
  80. if err != nil {
  81. return fmt.Errorf("batch creating object block: %w", err)
  82. }
  83. }
  84. return nil
  85. })
  86. if err != nil {
  87. logger.WithField("UserID", msg.UserID).
  88. WithField("StorageID", msg.StorageID).
  89. WithField("PackageID", msg.PackageID).
  90. Warn(err.Error())
  91. return nil, mq.Failed(errorcode.OperationFailed, "user load package to storage failed")
  92. }
  93. return mq.ReplyOK(coormq.NewStoragePackageLoadedResp())
  94. }

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