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_object.go 1.5 kB

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

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