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

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