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_pin.go 1.1 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. package task
  2. import (
  3. "fmt"
  4. "time"
  5. "gitlink.org.cn/cloudream/common/pkgs/logger"
  6. "gitlink.org.cn/cloudream/common/pkgs/task"
  7. stgglb "gitlink.org.cn/cloudream/storage/common/globals"
  8. )
  9. type IPFSPin struct {
  10. FileHashes []string
  11. }
  12. func NewIPFSPin(fileHashes []string) *IPFSPin {
  13. return &IPFSPin{
  14. FileHashes: fileHashes,
  15. }
  16. }
  17. func (t *IPFSPin) Execute(task *task.Task[TaskContext], ctx TaskContext, complete CompleteFn) {
  18. log := logger.WithType[IPFSPin]("Task")
  19. log.Debugf("begin with %v", logger.FormatStruct(t))
  20. defer log.Debugf("end")
  21. ipfsCli, err := stgglb.IPFSPool.Acquire()
  22. if err != nil {
  23. err := fmt.Errorf("new ipfs client: %w", err)
  24. log.Warn(err.Error())
  25. complete(err, CompleteOption{
  26. RemovingDelay: time.Minute,
  27. })
  28. return
  29. }
  30. defer ipfsCli.Close()
  31. for _, fileHash := range t.FileHashes {
  32. err = ipfsCli.Pin(fileHash)
  33. if err != nil {
  34. err := fmt.Errorf("pin file failed, err: %w", err)
  35. log.WithField("FileHash", fileHash).Warn(err.Error())
  36. complete(err, CompleteOption{
  37. RemovingDelay: time.Minute,
  38. })
  39. return
  40. }
  41. }
  42. complete(nil, CompleteOption{
  43. RemovingDelay: time.Minute,
  44. })
  45. }

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