Documentation ¶
Index ¶
- Constants
- Variables
- func BuildSamplePayload(report []byte, reportCtx ocrtypes.ReportContext, ...) []byte
- func FeedIDFromReport(report ocrtypes.Report) (feedID utils.FeedID, err error)
- func FilterName(addr common.Address, feedID common.Hash) string
- func MustHexToConfigDigest(s string) (cd ocrtypes.ConfigDigest)
- func NewTransmitter(lggr logger.Logger, rpcClient wsrpc.Client, fromAccount ed25519.PublicKey, ...) *mercuryTransmitter
- type ConfigPoller
- func (cp *ConfigPoller) Close() error
- func (cp *ConfigPoller) LatestBlockHeight(ctx context.Context) (blockHeight uint64, err error)
- func (cp *ConfigPoller) LatestConfig(ctx context.Context, changedInBlock uint64) (ocrtypes.ContractConfig, error)
- func (cp *ConfigPoller) LatestConfigDetails(ctx context.Context) (changedInBlock uint64, configDigest ocrtypes.ConfigDigest, err error)
- func (cp *ConfigPoller) Notify() <-chan struct{}
- func (cp *ConfigPoller) Replay(ctx context.Context, fromBlock int64) error
- func (cp *ConfigPoller) Start()
- type ConfigTracker
- type FullConfigFromLog
- type ORM
- type OffchainConfigDigester
- type PersistenceManager
- func (pm *PersistenceManager) AsyncDelete(req *pb.TransmitRequest)
- func (pm *PersistenceManager) Close() error
- func (pm *PersistenceManager) Delete(ctx context.Context, req *pb.TransmitRequest) error
- func (pm *PersistenceManager) Insert(ctx context.Context, req *pb.TransmitRequest, reportCtx ocrtypes.ReportContext) error
- func (pm *PersistenceManager) Load(ctx context.Context) ([]*Transmission, error)
- func (pm *PersistenceManager) Start(ctx context.Context) error
- type Transmission
- type TransmitQueue
- func (tq *TransmitQueue) BlockingPop() (t *Transmission)
- func (tq *TransmitQueue) Close() error
- func (tq *TransmitQueue) HealthReport() map[string]error
- func (tq *TransmitQueue) IsEmpty() bool
- func (tq *TransmitQueue) Name() string
- func (tq *TransmitQueue) Push(req *pb.TransmitRequest, reportCtx ocrtypes.ReportContext) (ok bool)
- func (tq *TransmitQueue) Ready() error
- func (tq *TransmitQueue) Start(context.Context) error
- type Transmitter
- type TransmitterReportDecoder
Constants ¶
const (
// Mercury server error codes
DuplicateReport = 2
)
Variables ¶
var FeedScopedConfigSet common.Hash
FeedScopedConfigSet ConfigSet with FeedID for use with mercury (and multi-config DON)
var PayloadTypes = getPayloadTypes()
Functions ¶
func BuildSamplePayload ¶
func BuildSamplePayload(report []byte, reportCtx ocrtypes.ReportContext, sigs []ocrtypes.AttributedOnchainSignature) []byte
func FeedIDFromReport ¶
func MustHexToConfigDigest ¶
func MustHexToConfigDigest(s string) (cd ocrtypes.ConfigDigest)
Types ¶
type ConfigPoller ¶
type ConfigPoller struct {
// contains filtered or unexported fields
}
ConfigPoller defines the Mercury Config Poller
func NewConfigPoller ¶
func NewConfigPoller(lggr logger.Logger, destChainPoller logpoller.LogPoller, addr common.Address, feedId common.Hash) (*ConfigPoller, error)
NewConfigPoller creates a new Mercury ConfigPoller
func (*ConfigPoller) Close ¶
func (cp *ConfigPoller) Close() error
func (*ConfigPoller) LatestBlockHeight ¶
func (cp *ConfigPoller) LatestBlockHeight(ctx context.Context) (blockHeight uint64, err error)
LatestBlockHeight returns the latest block height from the logs
func (*ConfigPoller) LatestConfig ¶
func (cp *ConfigPoller) LatestConfig(ctx context.Context, changedInBlock uint64) (ocrtypes.ContractConfig, error)
LatestConfig returns the latest config from the logs on a certain block
func (*ConfigPoller) LatestConfigDetails ¶
func (cp *ConfigPoller) LatestConfigDetails(ctx context.Context) (changedInBlock uint64, configDigest ocrtypes.ConfigDigest, err error)
LatestConfigDetails returns the latest config details from the logs
func (*ConfigPoller) Notify ¶
func (cp *ConfigPoller) Notify() <-chan struct{}
func (*ConfigPoller) Replay ¶
func (cp *ConfigPoller) Replay(ctx context.Context, fromBlock int64) error
Replay abstracts the logpoller.LogPoller Replay() implementation
func (*ConfigPoller) Start ¶
func (cp *ConfigPoller) Start()
type ConfigTracker ¶
type FullConfigFromLog ¶
type FullConfigFromLog struct { ocrtypes.ContractConfig // contains filtered or unexported fields }
FullConfigFromLog defines the contract config with the feedID
type ORM ¶
type ORM interface { InsertTransmitRequest(req *pb.TransmitRequest, jobID int32, reportCtx ocrtypes.ReportContext, qopts ...pg.QOpt) error DeleteTransmitRequests(reqs []*pb.TransmitRequest, qopts ...pg.QOpt) error GetTransmitRequests(jobID int32, qopts ...pg.QOpt) ([]*Transmission, error) PruneTransmitRequests(jobID int32, maxSize int, qopts ...pg.QOpt) error LatestReport(ctx context.Context, feedID [32]byte, qopts ...pg.QOpt) (report []byte, err error) }
type OffchainConfigDigester ¶
type OffchainConfigDigester struct { FeedID utils.FeedID ChainID *big.Int ContractAddress common.Address }
func (OffchainConfigDigester) ConfigDigest ¶
func (d OffchainConfigDigester) ConfigDigest(cc ocrtypes.ContractConfig) (ocrtypes.ConfigDigest, error)
func (OffchainConfigDigester) ConfigDigestPrefix ¶
func (d OffchainConfigDigester) ConfigDigestPrefix() (ocrtypes.ConfigDigestPrefix, error)
type PersistenceManager ¶
type PersistenceManager struct {
// contains filtered or unexported fields
}
func NewPersistenceManager ¶
func (*PersistenceManager) AsyncDelete ¶
func (pm *PersistenceManager) AsyncDelete(req *pb.TransmitRequest)
func (*PersistenceManager) Close ¶
func (pm *PersistenceManager) Close() error
func (*PersistenceManager) Delete ¶
func (pm *PersistenceManager) Delete(ctx context.Context, req *pb.TransmitRequest) error
func (*PersistenceManager) Insert ¶
func (pm *PersistenceManager) Insert(ctx context.Context, req *pb.TransmitRequest, reportCtx ocrtypes.ReportContext) error
func (*PersistenceManager) Load ¶
func (pm *PersistenceManager) Load(ctx context.Context) ([]*Transmission, error)
type Transmission ¶
type Transmission struct { Req *pb.TransmitRequest // the payload to transmit ReportCtx ocrtypes.ReportContext // contains priority information (latest epoch/round wins) }
type TransmitQueue ¶
type TransmitQueue struct { services.StateMachine // contains filtered or unexported fields }
TransmitQueue is the high-level package that everything outside of this file should be using It stores pending transmissions, yielding the latest (highest priority) first to the caller
func NewTransmitQueue ¶
func NewTransmitQueue(lggr logger.Logger, feedID string, maxlen int, transmissions []*Transmission, asyncDeleter asyncDeleter) *TransmitQueue
maxlen controls how many items will be stored in the queue 0 means unlimited - be careful, this can cause memory leaks
func (*TransmitQueue) BlockingPop ¶
func (tq *TransmitQueue) BlockingPop() (t *Transmission)
BlockingPop will block until at least one item is in the heap, and then return it If the queue is closed, it will immediately return nil
func (*TransmitQueue) Close ¶
func (tq *TransmitQueue) Close() error
func (*TransmitQueue) HealthReport ¶
func (tq *TransmitQueue) HealthReport() map[string]error
func (*TransmitQueue) IsEmpty ¶
func (tq *TransmitQueue) IsEmpty() bool
func (*TransmitQueue) Name ¶
func (tq *TransmitQueue) Name() string
func (*TransmitQueue) Push ¶
func (tq *TransmitQueue) Push(req *pb.TransmitRequest, reportCtx ocrtypes.ReportContext) (ok bool)
func (*TransmitQueue) Ready ¶
func (tq *TransmitQueue) Ready() error
type Transmitter ¶
type Transmitter interface { mercury.Transmitter services.Service }