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.

ipfs_read.go 1.7 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. package task
  2. import (
  3. "fmt"
  4. "io"
  5. "os"
  6. "path/filepath"
  7. "gitlink.org.cn/cloudream/common/pkg/logger"
  8. )
  9. type IPFSRead struct {
  10. FileHash string
  11. LocalPath string
  12. }
  13. func NewIPFSRead(fileHash string, localPath string) *IPFSRead {
  14. return &IPFSRead{
  15. FileHash: fileHash,
  16. LocalPath: localPath,
  17. }
  18. }
  19. func (t *IPFSRead) Compare(other TaskBody) bool {
  20. tsk, ok := other.(*IPFSRead)
  21. if !ok {
  22. return false
  23. }
  24. return t.FileHash == tsk.FileHash && t.LocalPath == tsk.LocalPath
  25. }
  26. func (t *IPFSRead) Execute(ctx TaskContext, complete CompleteFn) {
  27. log := logger.WithType[IPFSRead]("Task")
  28. log.Debugf("begin with %v", logger.FormatStruct(t))
  29. defer log.Debugf("end")
  30. outputFileDir := filepath.Dir(t.LocalPath)
  31. err := os.MkdirAll(outputFileDir, os.ModePerm)
  32. if err != nil {
  33. err := fmt.Errorf("create output file directory %s failed, err: %w", outputFileDir, err)
  34. log.WithField("LocalPath", t.LocalPath).Warn(err.Error())
  35. complete(err, func() {})
  36. return
  37. }
  38. outputFile, err := os.Create(t.LocalPath)
  39. if err != nil {
  40. err := fmt.Errorf("create output file %s failed, err: %w", t.LocalPath, err)
  41. log.WithField("LocalPath", t.LocalPath).Warn(err.Error())
  42. complete(err, func() {})
  43. return
  44. }
  45. defer outputFile.Close()
  46. rd, err := ctx.IPFS.OpenRead(t.FileHash)
  47. if err != nil {
  48. err := fmt.Errorf("read ipfs file failed, err: %w", err)
  49. log.WithField("FileHash", t.FileHash).Warn(err.Error())
  50. complete(err, func() {})
  51. return
  52. }
  53. _, err = io.Copy(outputFile, rd)
  54. if err != nil {
  55. err := fmt.Errorf("copy ipfs file to local file failed, err: %w", err)
  56. log.WithField("LocalPath", t.LocalPath).Warn(err.Error())
  57. complete(err, func() {})
  58. return
  59. }
  60. complete(nil, func() {})
  61. }

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