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.

package.go 5.0 kB

2 years ago
2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. package services
  2. import (
  3. "fmt"
  4. cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
  5. stgglb "gitlink.org.cn/cloudream/storage/common/globals"
  6. "gitlink.org.cn/cloudream/storage/common/pkgs/downloader"
  7. coormq "gitlink.org.cn/cloudream/storage/common/pkgs/mq/coordinator"
  8. )
  9. // PackageService 提供对包相关操作的服务接口
  10. type PackageService struct {
  11. *Service
  12. }
  13. // PackageSvc 创建并返回一个PackageService的实例
  14. func (svc *Service) PackageSvc() *PackageService {
  15. return &PackageService{Service: svc}
  16. }
  17. func (svc *PackageService) Get(userID cdssdk.UserID, packageID cdssdk.PackageID) (*cdssdk.Package, error) {
  18. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  19. if err != nil {
  20. return nil, fmt.Errorf("new coordinator client: %w", err)
  21. }
  22. defer stgglb.CoordinatorMQPool.Release(coorCli)
  23. // 向协调器请求获取包信息
  24. getResp, err := coorCli.GetPackage(coormq.NewGetPackage(userID, packageID))
  25. if err != nil {
  26. return nil, fmt.Errorf("requsting to coodinator: %w", err)
  27. }
  28. return &getResp.Package, nil
  29. }
  30. func (svc *PackageService) GetByName(userID cdssdk.UserID, bucketName string, packageName string) (*cdssdk.Package, error) {
  31. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  32. if err != nil {
  33. return nil, fmt.Errorf("new coordinator client: %w", err)
  34. }
  35. defer stgglb.CoordinatorMQPool.Release(coorCli)
  36. getResp, err := coorCli.GetPackageByName(coormq.ReqGetPackageByName(userID, bucketName, packageName))
  37. if err != nil {
  38. // TODO 要附加日志信息,但不能直接%w,因为外部需要判断错误吗
  39. return nil, err
  40. }
  41. return &getResp.Package, nil
  42. }
  43. func (svc *PackageService) GetBucketPackages(userID cdssdk.UserID, bucketID cdssdk.BucketID) ([]cdssdk.Package, error) {
  44. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  45. if err != nil {
  46. return nil, fmt.Errorf("new coordinator client: %w", err)
  47. }
  48. defer stgglb.CoordinatorMQPool.Release(coorCli)
  49. getResp, err := coorCli.GetBucketPackages(coormq.NewGetBucketPackages(userID, bucketID))
  50. if err != nil {
  51. return nil, fmt.Errorf("requsting to coodinator: %w", err)
  52. }
  53. return getResp.Packages, nil
  54. }
  55. func (svc *PackageService) Create(userID cdssdk.UserID, bucketID cdssdk.BucketID, name string) (cdssdk.Package, error) {
  56. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  57. if err != nil {
  58. return cdssdk.Package{}, fmt.Errorf("new coordinator client: %w", err)
  59. }
  60. defer stgglb.CoordinatorMQPool.Release(coorCli)
  61. // 向协调器发送创建包的请求
  62. resp, err := coorCli.CreatePackage(coormq.NewCreatePackage(userID, bucketID, name))
  63. if err != nil {
  64. return cdssdk.Package{}, fmt.Errorf("creating package: %w", err)
  65. }
  66. return resp.Package, nil
  67. }
  68. func (svc *PackageService) DownloadPackage(userID cdssdk.UserID, packageID cdssdk.PackageID) (downloader.DownloadIterator, error) {
  69. // TODO 检查用户ID
  70. return svc.Downloader.DownloadPackage(packageID), nil
  71. }
  72. // DeletePackage 删除指定的包
  73. func (svc *PackageService) DeletePackage(userID cdssdk.UserID, packageID cdssdk.PackageID) error {
  74. // 从协调器MQ池中获取客户端
  75. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  76. if err != nil {
  77. return fmt.Errorf("new coordinator client: %w", err)
  78. }
  79. defer stgglb.CoordinatorMQPool.Release(coorCli)
  80. // 向协调器发送删除包的请求
  81. _, err = coorCli.DeletePackage(coormq.NewDeletePackage(userID, packageID))
  82. if err != nil {
  83. return fmt.Errorf("deleting package: %w", err)
  84. }
  85. return nil
  86. }
  87. // GetCachedNodes 获取指定包的缓存节点信息
  88. func (svc *PackageService) GetCachedNodes(userID cdssdk.UserID, packageID cdssdk.PackageID) (cdssdk.PackageCachingInfo, error) {
  89. // 从协调器MQ池中获取客户端
  90. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  91. if err != nil {
  92. return cdssdk.PackageCachingInfo{}, fmt.Errorf("new coordinator client: %w", err)
  93. }
  94. defer stgglb.CoordinatorMQPool.Release(coorCli)
  95. // 向协调器请求获取包的缓存节点信息
  96. resp, err := coorCli.GetPackageCachedStorages(coormq.ReqGetPackageCachedStorages(userID, packageID))
  97. if err != nil {
  98. return cdssdk.PackageCachingInfo{}, fmt.Errorf("get package cached nodes: %w", err)
  99. }
  100. // 构造并返回缓存信息
  101. tmp := cdssdk.PackageCachingInfo{
  102. StorageInfos: resp.StorageInfos,
  103. PackageSize: resp.PackageSize,
  104. }
  105. return tmp, nil
  106. }
  107. // GetLoadedStorages 获取指定包加载的节点列表
  108. func (svc *PackageService) GetLoadedStorages(userID cdssdk.UserID, packageID cdssdk.PackageID) ([]cdssdk.StorageID, error) {
  109. // 从协调器MQ池中获取客户端
  110. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  111. if err != nil {
  112. return nil, fmt.Errorf("new coordinator client: %w", err)
  113. }
  114. defer stgglb.CoordinatorMQPool.Release(coorCli)
  115. // 向协调器请求获取加载指定包的节点ID列表
  116. resp, err := coorCli.GetPackageLoadedStorages(coormq.ReqGetPackageLoadedStorages(userID, packageID))
  117. if err != nil {
  118. return nil, fmt.Errorf("get package loaded nodes: %w", err)
  119. }
  120. return resp.StorageIDs, nil
  121. }

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