2018-01-18 18:55:17 +02:00
|
|
|
// copy of go-ethereum/internal/ethapi/addrlock.go
|
|
|
|
|
2018-01-26 07:59:21 +02:00
|
|
|
package transactions
|
2018-01-18 18:55:17 +02:00
|
|
|
|
|
|
|
import (
|
|
|
|
"sync"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/common"
|
|
|
|
)
|
|
|
|
|
2018-01-24 03:25:28 -05:00
|
|
|
// AddrLocker provides locks for addresses
|
2018-01-18 18:55:17 +02:00
|
|
|
type AddrLocker struct {
|
|
|
|
mu sync.Mutex
|
|
|
|
locks map[common.Address]*sync.Mutex
|
|
|
|
}
|
|
|
|
|
|
|
|
// lock returns the lock of the given address.
|
|
|
|
func (l *AddrLocker) lock(address common.Address) *sync.Mutex {
|
|
|
|
l.mu.Lock()
|
|
|
|
defer l.mu.Unlock()
|
|
|
|
if l.locks == nil {
|
|
|
|
l.locks = make(map[common.Address]*sync.Mutex)
|
|
|
|
}
|
|
|
|
if _, ok := l.locks[address]; !ok {
|
|
|
|
l.locks[address] = new(sync.Mutex)
|
|
|
|
}
|
|
|
|
return l.locks[address]
|
|
|
|
}
|
|
|
|
|
|
|
|
// LockAddr locks an account's mutex. This is used to prevent another tx getting the
|
|
|
|
// same nonce until the lock is released. The mutex prevents the (an identical nonce) from
|
|
|
|
// being read again during the time that the first transaction is being signed.
|
|
|
|
func (l *AddrLocker) LockAddr(address common.Address) {
|
|
|
|
l.lock(address).Lock()
|
|
|
|
}
|
|
|
|
|
|
|
|
// UnlockAddr unlocks the mutex of the given account.
|
|
|
|
func (l *AddrLocker) UnlockAddr(address common.Address) {
|
|
|
|
l.lock(address).Unlock()
|
|
|
|
}
|