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

2 years ago
2 years ago
2 years ago
2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  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/iterator"
  7. coormq "gitlink.org.cn/cloudream/storage/common/pkgs/mq/coordinator"
  8. )
  9. type PackageService struct {
  10. *Service
  11. }
  12. func (svc *Service) PackageSvc() *PackageService {
  13. return &PackageService{Service: svc}
  14. }
  15. func (svc *PackageService) Get(userID cdssdk.UserID, packageID cdssdk.PackageID) (*cdssdk.Package, error) {
  16. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  17. if err != nil {
  18. return nil, fmt.Errorf("new coordinator client: %w", err)
  19. }
  20. defer stgglb.CoordinatorMQPool.Release(coorCli)
  21. getResp, err := coorCli.GetPackage(coormq.NewGetPackage(userID, packageID))
  22. if err != nil {
  23. return nil, fmt.Errorf("requsting to coodinator: %w", err)
  24. }
  25. return &getResp.Package, nil
  26. }
  27. func (svc *PackageService) GetByName(userID cdssdk.UserID, bucketName string, packageName string) (*cdssdk.Package, error) {
  28. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  29. if err != nil {
  30. return nil, fmt.Errorf("new coordinator client: %w", err)
  31. }
  32. defer stgglb.CoordinatorMQPool.Release(coorCli)
  33. getResp, err := coorCli.GetPackageByName(coormq.ReqGetPackageByName(userID, bucketName, packageName))
  34. if err != nil {
  35. return nil, fmt.Errorf("requsting to coodinator: %w", err)
  36. }
  37. return &getResp.Package, nil
  38. }
  39. func (svc *PackageService) GetBucketPackages(userID cdssdk.UserID, bucketID cdssdk.BucketID) ([]cdssdk.Package, error) {
  40. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  41. if err != nil {
  42. return nil, fmt.Errorf("new coordinator client: %w", err)
  43. }
  44. defer stgglb.CoordinatorMQPool.Release(coorCli)
  45. getResp, err := coorCli.GetBucketPackages(coormq.NewGetBucketPackages(userID, bucketID))
  46. if err != nil {
  47. return nil, fmt.Errorf("requsting to coodinator: %w", err)
  48. }
  49. return getResp.Packages, nil
  50. }
  51. func (svc *PackageService) Create(userID cdssdk.UserID, bucketID cdssdk.BucketID, name string) (cdssdk.Package, error) {
  52. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  53. if err != nil {
  54. return cdssdk.Package{}, fmt.Errorf("new coordinator client: %w", err)
  55. }
  56. defer stgglb.CoordinatorMQPool.Release(coorCli)
  57. resp, err := coorCli.CreatePackage(coormq.NewCreatePackage(userID, bucketID, name))
  58. if err != nil {
  59. return cdssdk.Package{}, fmt.Errorf("creating package: %w", err)
  60. }
  61. return resp.Package, nil
  62. }
  63. func (svc *PackageService) DownloadPackage(userID cdssdk.UserID, packageID cdssdk.PackageID) (iterator.DownloadingObjectIterator, error) {
  64. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  65. if err != nil {
  66. return nil, fmt.Errorf("new coordinator client: %w", err)
  67. }
  68. defer stgglb.CoordinatorMQPool.Release(coorCli)
  69. getObjsResp, err := coorCli.GetPackageObjectDetails(coormq.NewGetPackageObjectDetails(packageID))
  70. if err != nil {
  71. return nil, fmt.Errorf("getting package object details: %w", err)
  72. }
  73. iter := iterator.NewDownloadObjectIterator(getObjsResp.Objects, &iterator.DownloadContext{
  74. Distlock: svc.DistLock,
  75. })
  76. return iter, nil
  77. }
  78. func (svc *PackageService) DeletePackage(userID cdssdk.UserID, packageID cdssdk.PackageID) error {
  79. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  80. if err != nil {
  81. return fmt.Errorf("new coordinator client: %w", err)
  82. }
  83. defer stgglb.CoordinatorMQPool.Release(coorCli)
  84. _, err = coorCli.DeletePackage(coormq.NewDeletePackage(userID, packageID))
  85. if err != nil {
  86. return fmt.Errorf("deleting package: %w", err)
  87. }
  88. return nil
  89. }
  90. func (svc *PackageService) GetCachedNodes(userID cdssdk.UserID, packageID cdssdk.PackageID) (cdssdk.PackageCachingInfo, error) {
  91. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  92. if err != nil {
  93. return cdssdk.PackageCachingInfo{}, fmt.Errorf("new coordinator client: %w", err)
  94. }
  95. defer stgglb.CoordinatorMQPool.Release(coorCli)
  96. resp, err := coorCli.GetPackageCachedNodes(coormq.NewGetPackageCachedNodes(userID, packageID))
  97. if err != nil {
  98. return cdssdk.PackageCachingInfo{}, fmt.Errorf("get package cached nodes: %w", err)
  99. }
  100. tmp := cdssdk.PackageCachingInfo{
  101. NodeInfos: resp.NodeInfos,
  102. PackageSize: resp.PackageSize,
  103. }
  104. return tmp, nil
  105. }
  106. func (svc *PackageService) GetLoadedNodes(userID cdssdk.UserID, packageID cdssdk.PackageID) ([]cdssdk.NodeID, error) {
  107. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  108. if err != nil {
  109. return nil, fmt.Errorf("new coordinator client: %w", err)
  110. }
  111. defer stgglb.CoordinatorMQPool.Release(coorCli)
  112. resp, err := coorCli.GetPackageLoadedNodes(coormq.NewGetPackageLoadedNodes(userID, packageID))
  113. if err != nil {
  114. return nil, fmt.Errorf("get package loaded nodes: %w", err)
  115. }
  116. return resp.NodeIDs, nil
  117. }

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