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.

put.go 2.9 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. package cmdline
  2. import (
  3. "fmt"
  4. "os"
  5. "path/filepath"
  6. "strings"
  7. "time"
  8. "github.com/inhies/go-bytesize"
  9. "github.com/spf13/cobra"
  10. "gitlink.org.cn/cloudream/common/consts/errorcode"
  11. "gitlink.org.cn/cloudream/common/pkgs/mq"
  12. cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
  13. )
  14. func init() {
  15. var stgID int64
  16. cmd := &cobra.Command{
  17. Use: "put [local] [remote]",
  18. Short: "Upload files to CDS",
  19. Args: func(cmd *cobra.Command, args []string) error {
  20. if err := cobra.ExactArgs(2)(cmd, args); err != nil {
  21. return err
  22. }
  23. remote := args[1]
  24. comps := strings.Split(strings.Trim(remote, cdssdk.ObjectPathSeparator), cdssdk.ObjectPathSeparator)
  25. if len(comps) != 2 {
  26. return fmt.Errorf("invalid remote path: %s, which must be in format of <bucket>/<package>", remote)
  27. }
  28. return nil
  29. },
  30. Run: func(cmd *cobra.Command, args []string) {
  31. userID := cdssdk.UserID(1)
  32. cmdCtx := GetCmdCtx(cmd)
  33. local := args[0]
  34. remote := args[1]
  35. comps := strings.Split(strings.Trim(remote, cdssdk.ObjectPathSeparator), cdssdk.ObjectPathSeparator)
  36. startTime := time.Now()
  37. bkt, err := cmdCtx.Cmdline.Svc.BucketSvc().GetBucketByName(userID, comps[0])
  38. if err != nil {
  39. fmt.Printf("getting bucket: %v\n", err)
  40. return
  41. }
  42. pkg, err := cmdCtx.Cmdline.Svc.PackageSvc().GetByFullName(userID, comps[0], comps[1])
  43. if err != nil {
  44. if codeMsg, ok := err.(*mq.CodeMessageError); ok && codeMsg.Code == errorcode.DataNotFound {
  45. pkg2, err := cmdCtx.Cmdline.Svc.PackageSvc().Create(userID, bkt.BucketID, comps[1])
  46. if err != nil {
  47. fmt.Printf("creating package: %v\n", err)
  48. return
  49. }
  50. pkg = &pkg2
  51. } else {
  52. fmt.Printf("getting package: %v\n", err)
  53. return
  54. }
  55. }
  56. var storageAff cdssdk.StorageID
  57. if stgID != 0 {
  58. storageAff = cdssdk.StorageID(stgID)
  59. }
  60. up, err := cmdCtx.Cmdline.Svc.Uploader.BeginUpdate(userID, pkg.PackageID, storageAff, nil, nil)
  61. if err != nil {
  62. fmt.Printf("begin updating package: %v\n", err)
  63. return
  64. }
  65. defer up.Abort()
  66. var fileCount int
  67. var totalSize int64
  68. err = filepath.WalkDir(local, func(fname string, fi os.DirEntry, err error) error {
  69. if err != nil {
  70. return nil
  71. }
  72. if fi.IsDir() {
  73. return nil
  74. }
  75. fileCount++
  76. info, err := fi.Info()
  77. if err != nil {
  78. return err
  79. }
  80. totalSize += info.Size()
  81. file, err := os.Open(fname)
  82. if err != nil {
  83. return err
  84. }
  85. defer file.Close()
  86. return up.Upload(fname, file)
  87. })
  88. if err != nil {
  89. fmt.Println(err.Error())
  90. return
  91. }
  92. _, err = up.Commit()
  93. if err != nil {
  94. fmt.Printf("committing package: %v\n", err)
  95. return
  96. }
  97. fmt.Printf("Put %v files (%v) to %s in %v.\n", fileCount, bytesize.ByteSize(totalSize), remote, time.Since(startTime))
  98. },
  99. }
  100. cmd.Flags().Int64VarP(&stgID, "storage", "s", 0, "storage affinity")
  101. rootCmd.AddCommand(cmd)
  102. }

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