mirror of
https://github.com/grassrootseconomics/eth-tracker.git
synced 2025-04-21 16:01:01 +02:00
126 lines
2.2 KiB
Go
126 lines
2.2 KiB
Go
package db
|
|
|
|
import (
|
|
"bytes"
|
|
|
|
"github.com/bits-and-blooms/bitset"
|
|
"github.com/dgraph-io/badger/v4"
|
|
)
|
|
|
|
func (d *DB) SetLowerBound(v uint64) error {
|
|
return d.setUint64(lowerBoundKey, v)
|
|
}
|
|
|
|
func (d *DB) GetLowerBound() (uint64, error) {
|
|
v, err := d.get(lowerBoundKey)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
return unmarshalUint64(v), nil
|
|
}
|
|
|
|
func (d *DB) SetUpperBound(v uint64) error {
|
|
return d.setUint64(upperBoundKey, v)
|
|
}
|
|
|
|
func (d *DB) GetUpperBound() (uint64, error) {
|
|
v, err := d.get(upperBoundKey)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
return unmarshalUint64(v), nil
|
|
}
|
|
|
|
func (d *DB) SetValue(v uint64) error {
|
|
return d.setUint64AsKey(v)
|
|
}
|
|
|
|
func (d *DB) GetMissingValuesBitSet(lowerBound uint64, upperBound uint64) (*bitset.BitSet, error) {
|
|
var (
|
|
b bitset.BitSet
|
|
)
|
|
|
|
err := d.db.View(func(txn *badger.Txn) error {
|
|
var (
|
|
lowerRaw = marshalUint64(lowerBound)
|
|
upperRaw = marshalUint64(upperBound)
|
|
)
|
|
|
|
for i := lowerBound; i <= upperBound; i++ {
|
|
b.Set(uint(i))
|
|
}
|
|
|
|
opts := badger.DefaultIteratorOptions
|
|
opts.PrefetchValues = false
|
|
|
|
iter := txn.NewIterator(opts)
|
|
defer iter.Close()
|
|
|
|
for iter.Seek(lowerRaw); iter.Valid(); iter.Next() {
|
|
k := iter.Item().Key()
|
|
|
|
if bytes.Compare(k, upperRaw) > 0 {
|
|
return nil
|
|
}
|
|
|
|
b.Clear(uint(unmarshalUint64(k)))
|
|
}
|
|
|
|
return nil
|
|
})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &b, nil
|
|
}
|
|
|
|
func (d *DB) Cleanup() error {
|
|
var (
|
|
safeToDeleteKeys [][]byte
|
|
)
|
|
|
|
err := d.db.View(func(txn *badger.Txn) error {
|
|
lowerBound, err := d.get(lowerBoundKey)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
lowerBound = marshalUint64(unmarshalUint64(lowerBound) - 1)
|
|
|
|
opts := badger.DefaultIteratorOptions
|
|
opts.PrefetchValues = false
|
|
|
|
it := txn.NewIterator(opts)
|
|
defer it.Close()
|
|
|
|
for it.Rewind(); it.Valid(); it.Next() {
|
|
k := it.Item().Key()
|
|
|
|
if bytes.Compare(k, lowerBound) > 0 {
|
|
return nil
|
|
}
|
|
|
|
safeToDeleteKeys = append(safeToDeleteKeys, it.Item().KeyCopy(nil))
|
|
}
|
|
|
|
return nil
|
|
})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
wb := d.db.NewWriteBatch()
|
|
for _, k := range safeToDeleteKeys {
|
|
if err := wb.Delete(k); err != nil {
|
|
return nil
|
|
}
|
|
}
|
|
|
|
if err := wb.Flush(); err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|