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. cdssdk "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 CreatePackageResult = cmd.CreatePackageResult
  11. type CreatePackage struct {
  12. cmd cmd.CreatePackage
  13. Result *CreatePackageResult
  14. }
  15. func NewCreatePackage(userID cdssdk.UserID, bucketID cdssdk.BucketID, name string, objIter iterator.UploadingObjectIterator, nodeAffinity *cdssdk.NodeID) *CreatePackage {
  16. return &CreatePackage{
  17. cmd: *cmd.NewCreatePackage(userID, bucketID, name, objIter, nodeAffinity),
  18. }
  19. }
  20. func (t *CreatePackage) Execute(task *task.Task[TaskContext], ctx TaskContext, complete CompleteFn) {
  21. log := logger.WithType[CreatePackage]("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. }

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