40 lines
1.2 KiB
Go
40 lines
1.2 KiB
Go
package settings
|
|
|
|
import (
|
|
"context"
|
|
"github.com/anytypeio/go-anytype-infrastructure-experiments/common/commonspace/settings/deletionstate"
|
|
"github.com/anytypeio/go-anytype-infrastructure-experiments/common/commonspace/storage"
|
|
"github.com/anytypeio/go-anytype-infrastructure-experiments/common/commonspace/treegetter"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
type Deleter interface {
|
|
Delete()
|
|
}
|
|
|
|
type deleter struct {
|
|
st storage.SpaceStorage
|
|
state deletionstate.DeletionState
|
|
getter treegetter.TreeGetter
|
|
}
|
|
|
|
func newDeleter(st storage.SpaceStorage, state deletionstate.DeletionState, getter treegetter.TreeGetter) Deleter {
|
|
return &deleter{st, state, getter}
|
|
}
|
|
|
|
func (d *deleter) Delete() {
|
|
allQueued := d.state.GetQueued()
|
|
for _, id := range allQueued {
|
|
err := d.getter.DeleteTree(context.Background(), d.st.Id(), id)
|
|
if err != nil && err != storage.ErrTreeStorageAlreadyDeleted {
|
|
log.With(zap.String("id", id), zap.Error(err)).Error("failed to delete object")
|
|
continue
|
|
}
|
|
err = d.state.Delete(id)
|
|
if err != nil {
|
|
log.With(zap.String("id", id), zap.Error(err)).Error("failed to mark object as deleted")
|
|
}
|
|
log.With(zap.String("id", id), zap.Error(err)).Debug("object successfully deleted")
|
|
}
|
|
}
|