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_rep_package.go 981 B

2 years ago
1234567891011121314151617181920212223242526272829303132333435
  1. package task
  2. import (
  3. "time"
  4. "gitlink.org.cn/cloudream/common/pkgs/task"
  5. cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
  6. "gitlink.org.cn/cloudream/storage/common/pkgs/cmd"
  7. "gitlink.org.cn/cloudream/storage/common/pkgs/iterator"
  8. )
  9. type CreateRepPackageResult = cmd.CreateRepPackageResult
  10. type CreateRepPackage struct {
  11. cmd cmd.CreateRepPackage
  12. Result *CreateRepPackageResult
  13. }
  14. func NewCreateRepPackage(userID int64, bucketID int64, name string, objIter iterator.UploadingObjectIterator, redundancy cdssdk.RepRedundancyInfo, nodeAffinity *int64) *CreateRepPackage {
  15. return &CreateRepPackage{
  16. cmd: *cmd.NewCreateRepPackage(userID, bucketID, name, objIter, redundancy, nodeAffinity),
  17. }
  18. }
  19. func (t *CreateRepPackage) Execute(task *task.Task[TaskContext], ctx TaskContext, complete CompleteFn) {
  20. ret, err := t.cmd.Execute(&cmd.UpdatePackageContext{
  21. Distlock: ctx.distlock,
  22. })
  23. t.Result = ret
  24. complete(err, CompleteOption{
  25. RemovingDelay: time.Minute,
  26. })
  27. }

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