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.

object.go 1.5 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. package cmdline
  2. import (
  3. "fmt"
  4. "os"
  5. "path/filepath"
  6. "time"
  7. cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
  8. "gitlink.org.cn/cloudream/storage/common/pkgs/iterator"
  9. )
  10. var _ = MustAddCmd(func(ctx CommandContext, packageID cdssdk.PackageID, rootPath string, nodeAffinity []cdssdk.NodeID) error {
  11. startTime := time.Now()
  12. defer func() {
  13. fmt.Printf("%v\n", time.Since(startTime).Seconds())
  14. }()
  15. userID := cdssdk.UserID(1)
  16. var uploadFilePathes []string
  17. err := filepath.WalkDir(rootPath, func(fname string, fi os.DirEntry, err error) error {
  18. if err != nil {
  19. return nil
  20. }
  21. if !fi.IsDir() {
  22. uploadFilePathes = append(uploadFilePathes, fname)
  23. }
  24. return nil
  25. })
  26. if err != nil {
  27. return fmt.Errorf("open directory %s failed, err: %w", rootPath, err)
  28. }
  29. var nodeAff *cdssdk.NodeID
  30. if len(nodeAffinity) > 0 {
  31. n := cdssdk.NodeID(nodeAffinity[0])
  32. nodeAff = &n
  33. }
  34. objIter := iterator.NewUploadingObjectIterator(rootPath, uploadFilePathes)
  35. taskID, err := ctx.Cmdline.Svc.ObjectSvc().StartUploading(userID, packageID, objIter, nodeAff)
  36. if err != nil {
  37. return fmt.Errorf("update objects to package %d failed, err: %w", packageID, err)
  38. }
  39. for {
  40. complete, _, err := ctx.Cmdline.Svc.ObjectSvc().WaitUploading(taskID, time.Second*5)
  41. if complete {
  42. if err != nil {
  43. return fmt.Errorf("uploading objects: %w", err)
  44. }
  45. return nil
  46. }
  47. if err != nil {
  48. return fmt.Errorf("wait updating: %w", err)
  49. }
  50. }
  51. }, "obj", "upload")

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