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.

check_package.go 1.6 kB

2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. package event
  2. import (
  3. "github.com/samber/lo"
  4. "gitlink.org.cn/cloudream/common/pkgs/logger"
  5. "gitlink.org.cn/cloudream/storage/common/pkgs/distlock/reqbuilder"
  6. scevt "gitlink.org.cn/cloudream/storage/common/pkgs/mq/scanner/event"
  7. )
  8. type CheckPackage struct {
  9. *scevt.CheckPackage
  10. }
  11. func NewCheckPackage(objIDs []int64) *CheckPackage {
  12. return &CheckPackage{
  13. CheckPackage: scevt.NewCheckPackage(objIDs),
  14. }
  15. }
  16. func (t *CheckPackage) TryMerge(other Event) bool {
  17. event, ok := other.(*CheckPackage)
  18. if !ok {
  19. return false
  20. }
  21. t.PackageIDs = lo.Union(t.PackageIDs, event.PackageIDs)
  22. return true
  23. }
  24. func (t *CheckPackage) Execute(execCtx ExecuteContext) {
  25. log := logger.WithType[CheckPackage]("Event")
  26. log.Debugf("begin with %v", logger.FormatStruct(t))
  27. defer log.Debugf("end")
  28. // 检查对象是否没有被引用的时候,需要读取StoragePackage表
  29. builder := reqbuilder.NewBuilder().Metadata().StoragePackage().ReadAny()
  30. for _, objID := range t.PackageIDs {
  31. builder.Metadata().Package().WriteOne(objID)
  32. }
  33. mutex, err := builder.MutexLock(execCtx.Args.DistLock)
  34. if err != nil {
  35. log.Warnf("acquire locks failed, err: %s", err.Error())
  36. return
  37. }
  38. defer mutex.Unlock()
  39. for _, objID := range t.PackageIDs {
  40. err := execCtx.Args.DB.Package().DeleteUnused(execCtx.Args.DB.SQLCtx(), objID)
  41. if err != nil {
  42. log.WithField("PackageID", objID).Warnf("delete unused package failed, err: %s", err.Error())
  43. }
  44. }
  45. }
  46. func init() {
  47. RegisterMessageConvertor(func(msg scevt.CheckPackage) Event { return NewCheckPackage(msg.PackageIDs) })
  48. }

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