71 lines
1.9 KiB
Go

package privateapi
import (
"sync"
"github.com/ledgerwatch/erigon/core/types"
)
type RpcEventType uint64
type HeaderSubscription func(*types.Header) error
type PendingLogsSubscription func(types.Logs) error
type PendingBlockSubscription func(*types.Block) error
type PendingTxsSubscription func([]types.Transaction) error
// Events manages event subscriptions and dissimination. Thread-safe
type Events struct {
headerSubscriptions map[int]HeaderSubscription
pendingLogsSubscriptions map[int]PendingLogsSubscription
pendingBlockSubscriptions map[int]PendingBlockSubscription
pendingTxsSubscriptions map[int]PendingTxsSubscription
lock sync.RWMutex
}
func NewEvents() *Events {
return &Events{
headerSubscriptions: map[int]HeaderSubscription{},
pendingLogsSubscriptions: map[int]PendingLogsSubscription{},
pendingBlockSubscriptions: map[int]PendingBlockSubscription{},
pendingTxsSubscriptions: map[int]PendingTxsSubscription{},
}
}
func (e *Events) AddHeaderSubscription(s HeaderSubscription) {
e.lock.Lock()
defer e.lock.Unlock()
e.headerSubscriptions[len(e.headerSubscriptions)] = s
}
func (e *Events) AddPendingLogsSubscription(s PendingLogsSubscription) {
e.lock.Lock()
defer e.lock.Unlock()
e.pendingLogsSubscriptions[len(e.pendingLogsSubscriptions)] = s
}
func (e *Events) AddPendingBlockSubscription(s PendingBlockSubscription) {
e.lock.Lock()
defer e.lock.Unlock()
e.pendingBlockSubscriptions[len(e.pendingBlockSubscriptions)] = s
}
func (e *Events) OnNewHeader(newHeader *types.Header) {
e.lock.Lock()
defer e.lock.Unlock()
for i, sub := range e.headerSubscriptions {
if err := sub(newHeader); err != nil {
delete(e.headerSubscriptions, i)
}
}
}
func (e *Events) OnNewPendingLogs(logs types.Logs) {
e.lock.Lock()
defer e.lock.Unlock()
for i, sub := range e.pendingLogsSubscriptions {
if err := sub(logs); err != nil {
delete(e.pendingLogsSubscriptions, i)
}
}
}