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.2 kB

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

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