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

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

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