Skip to content

Commit

Permalink
Remove private transactions that are confirmed in blocks
Browse files Browse the repository at this point in the history
  • Loading branch information
Kevin Chen authored and Ruteri committed Feb 22, 2022
1 parent 16f9b7c commit 71ab3bd
Showing 1 changed file with 19 additions and 17 deletions.
36 changes: 19 additions & 17 deletions core/tx_pool.go
Original file line number Diff line number Diff line change
Expand Up @@ -1669,6 +1669,7 @@ func (pool *TxPool) demoteUnexecutables() {
for _, tx := range olds {
hash := tx.Hash()
pool.all.Remove(hash)
pool.privateTxs.Remove(hash)
log.Trace("Removed old pending transaction", "hash", hash)
}
// Drop all transactions that are too costly (low balance or out of gas), and queue any invalids back for later
Expand Down Expand Up @@ -1973,14 +1974,12 @@ func (t *txLookup) RemotesBelowTip(threshold *big.Int) types.Transactions {

type timestampedTxHashSet struct {
lock sync.RWMutex
hashes []common.Hash
timestamps map[common.Hash]time.Time
ttl time.Duration
}

func newExpiringTxHashSet(ttl time.Duration) *timestampedTxHashSet {
s := &timestampedTxHashSet{
hashes: make([]common.Hash, 0),
timestamps: make(map[common.Hash]time.Time),
ttl: ttl,
}
Expand All @@ -1992,8 +1991,10 @@ func (s *timestampedTxHashSet) Add(hash common.Hash) {
s.lock.Lock()
defer s.lock.Unlock()

s.hashes = append(s.hashes, hash)
s.timestamps[hash] = time.Now().Add(s.ttl)
_, ok := s.timestamps[hash]
if !ok {
s.timestamps[hash] = time.Now().Add(s.ttl)
}
}

func (s *timestampedTxHashSet) Contains(hash common.Hash) bool {
Expand All @@ -2003,25 +2004,26 @@ func (s *timestampedTxHashSet) Contains(hash common.Hash) bool {
return ok
}

func (s *timestampedTxHashSet) prune() {
func (s *timestampedTxHashSet) Remove(hash common.Hash) {
s.lock.Lock()
defer s.lock.Unlock()

var (
count int
now = time.Now()
)
for _, hash := range s.hashes {
ts := s.timestamps[hash]
if ts.After(now) {
break
}

_, ok := s.timestamps[hash]
if ok {
delete(s.timestamps, hash)
count += 1
}
}

func (s *timestampedTxHashSet) prune() {
s.lock.Lock()
defer s.lock.Unlock()

s.hashes = s.hashes[count:]
now := time.Now()
for hash, ts := range s.timestamps {
if ts.Before(now) {
delete(s.timestamps, hash)
}
}
}

// numSlots calculates the number of slots needed for a single transaction.
Expand Down

0 comments on commit 71ab3bd

Please sign in to comment.