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.

create_ec_package.go 1.1 kB

2 years ago
12345678910111213141516171819202122232425262728293031323334353637383940
  1. package task
  2. import (
  3. "time"
  4. "gitlink.org.cn/cloudream/common/pkgs/logger"
  5. "gitlink.org.cn/cloudream/common/pkgs/task"
  6. stgsdk "gitlink.org.cn/cloudream/common/sdks/storage"
  7. "gitlink.org.cn/cloudream/storage/common/pkgs/cmd"
  8. "gitlink.org.cn/cloudream/storage/common/pkgs/iterator"
  9. )
  10. type CreateECPackageResult = cmd.CreateECPackageResult
  11. type CreateECPackage struct {
  12. cmd cmd.CreateECPackage
  13. Result *CreateECPackageResult
  14. }
  15. func NewCreateECPackage(userID int64, bucketID int64, name string, objIter iterator.UploadingObjectIterator, redundancy stgsdk.ECRedundancyInfo, nodeAffinity *int64) *CreateECPackage {
  16. return &CreateECPackage{
  17. cmd: *cmd.NewCreateECPackage(userID, bucketID, name, objIter, redundancy, nodeAffinity),
  18. }
  19. }
  20. func (t *CreateECPackage) Execute(task *task.Task[TaskContext], ctx TaskContext, complete CompleteFn) {
  21. log := logger.WithType[CreateECPackage]("Task")
  22. log.Debugf("begin")
  23. defer log.Debugf("end")
  24. ret, err := t.cmd.Execute(&cmd.UpdatePackageContext{
  25. Distlock: ctx.distlock,
  26. })
  27. t.Result = ret
  28. complete(err, CompleteOption{
  29. RemovingDelay: time.Minute,
  30. })
  31. }

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