mirror of
https://github.com/status-im/status-go.git
synced 2025-01-18 10:42:07 +00:00
4317b8f687
add mailserver cleaner use memstorage for leveldb in tests avoid write if batch size is 0 add comments add cmd/statusd-prune rmeove batch size var in prune method validate range values pass only flag name to missingFlag refactor Cleaner.prune method update batch not to be a pointer removed extra batch counter increment don't increment counter if batch returns errors add README
64 lines
1.3 KiB
Go
64 lines
1.3 KiB
Go
package mailserver
|
|
|
|
import (
|
|
"github.com/ethereum/go-ethereum/common"
|
|
"github.com/syndtr/goleveldb/leveldb"
|
|
"github.com/syndtr/goleveldb/leveldb/iterator"
|
|
"github.com/syndtr/goleveldb/leveldb/util"
|
|
)
|
|
|
|
const batchSize = 1000
|
|
|
|
// Cleaner removes old messages from a db
|
|
type Cleaner struct {
|
|
db *leveldb.DB
|
|
batchSize int
|
|
}
|
|
|
|
// NewCleanerWithDB returns a new Cleaner for db
|
|
func NewCleanerWithDB(db *leveldb.DB) *Cleaner {
|
|
return &Cleaner{
|
|
db: db,
|
|
batchSize: batchSize,
|
|
}
|
|
}
|
|
|
|
// Prune removes messages sent between lower and upper timestamps and returns how many has been removed
|
|
func (c *Cleaner) Prune(lower, upper uint32) (int, error) {
|
|
var zero common.Hash
|
|
kl := NewDbKey(lower, zero)
|
|
ku := NewDbKey(upper, zero)
|
|
i := c.db.NewIterator(&util.Range{Start: kl.raw, Limit: ku.raw}, nil)
|
|
defer i.Release()
|
|
|
|
return c.prune(i)
|
|
}
|
|
|
|
func (c *Cleaner) prune(i iterator.Iterator) (int, error) {
|
|
batch := leveldb.Batch{}
|
|
removed := 0
|
|
|
|
for i.Next() {
|
|
batch.Delete(i.Key())
|
|
|
|
if batch.Len() == c.batchSize {
|
|
if err := c.db.Write(&batch, nil); err != nil {
|
|
return removed, err
|
|
}
|
|
|
|
removed = removed + batch.Len()
|
|
batch.Reset()
|
|
}
|
|
}
|
|
|
|
if batch.Len() > 0 {
|
|
if err := c.db.Write(&batch, nil); err != nil {
|
|
return removed, err
|
|
}
|
|
|
|
removed = removed + batch.Len()
|
|
}
|
|
|
|
return removed, nil
|
|
}
|