Documentation ¶
Index ¶
Constants ¶
const ( // NOTE: Only add something here if you actually need it, because it has to // be supported forever and can't be changed AggregatorMedian = 1 AggregatorMode = 2 // AggregatorQuote is a special aggregator that is used to aggregate // a list of Bid/Mid/Ask price tuples AggregatorQuote = 3 )
Variables ¶
var ReportFormats = []ReportFormat{ ReportFormatEVMPremiumLegacy, ReportFormatJSON, }
Functions ¶
This section is empty.
Types ¶
type Aggregator ¶
type Aggregator uint32
func AggregatorFromString ¶
func AggregatorFromString(s string) (Aggregator, error)
func (Aggregator) MarshalJSON ¶
func (a Aggregator) MarshalJSON() ([]byte, error)
func (Aggregator) MarshalText ¶
func (a Aggregator) MarshalText() ([]byte, error)
func (Aggregator) String ¶
func (a Aggregator) String() string
func (*Aggregator) UnmarshalJSON ¶
func (a *Aggregator) UnmarshalJSON(data []byte) error
func (*Aggregator) UnmarshalText ¶
func (a *Aggregator) UnmarshalText(text []byte) error
type ChannelDefinition ¶
type ChannelDefinition struct { // ReportFormat controls the output format of the report. It might be a // different chain target, different report format etc. Custom logic can be // implemented for each report format. ReportFormat ReportFormat `json:"reportFormat"` // Streams is the list of streams to be observed and aggregated // by the protocol. Streams []Stream `json:"streams"` // Opts contains configuration data for use in report generation // for this channel, e.g. feed ID, expiry window, USD base fee etc // // How this is encoded is up to the implementer but should be consistent // for a given ReportFormat // // May be nil Opts ChannelOpts `json:"opts"` }
func (ChannelDefinition) Equals ¶
func (a ChannelDefinition) Equals(b ChannelDefinition) bool
type ChannelDefinitionCache ¶
type ChannelDefinitionCache interface { Definitions() ChannelDefinitions services.Service }
type ChannelDefinitions ¶
type ChannelDefinitions map[ChannelID]ChannelDefinition
func (*ChannelDefinitions) Scan ¶
func (c *ChannelDefinitions) Scan(value interface{}) error
type ChannelID ¶
type ChannelID = uint32
It is recommended not to use 0 as a channel ID to avoid confusion with uninitialized values
type ChannelOpts ¶
type ChannelOpts []byte
func (ChannelOpts) MarshalJSON ¶
func (m ChannelOpts) MarshalJSON() ([]byte, error)
MarshalJSON passes raw json directly through in a canonicalized form.
func (*ChannelOpts) UnmarshalJSON ¶
func (m *ChannelOpts) UnmarshalJSON(data []byte) (err error)
UnmarshalJSON allows taking an actual JSON object as ChannelOpts and passes it through in canonicalized form.
type LifeCycleStage ¶
type LifeCycleStage string
type ReportFormat ¶
type ReportFormat uint32
ReportFormat represents different formats for different targets e.g. EVM, Solana, JSON, kalechain etc
const ( // NOTE: Only add something here if you actually need it, because it has to // be supported forever and can't be changed ReportFormatEVMPremiumLegacy ReportFormat = 1 ReportFormatJSON ReportFormat = 2 )
func ReportFormatFromString ¶
func ReportFormatFromString(s string) (ReportFormat, error)
func (ReportFormat) MarshalJSON ¶
func (rf ReportFormat) MarshalJSON() ([]byte, error)
func (ReportFormat) MarshalText ¶
func (rf ReportFormat) MarshalText() ([]byte, error)
func (ReportFormat) String ¶
func (rf ReportFormat) String() string
func (*ReportFormat) UnmarshalJSON ¶
func (rf *ReportFormat) UnmarshalJSON(data []byte) error
func (*ReportFormat) UnmarshalText ¶
func (rf *ReportFormat) UnmarshalText(text []byte) error
type ReportInfo ¶
type ReportInfo struct { LifeCycleStage LifeCycleStage ReportFormat ReportFormat }
type Stream ¶
type Stream struct { // ID is the ID of the stream to be observed StreamID StreamID `json:"streamId"` // Aggregator is the method used by consensus protocol to aggregate // multiple stream observations e.g. "median", "mode" or other more exotic // methods Aggregator Aggregator `json:"aggregator"` }
type StreamID ¶
type StreamID = uint32
Chose uint32 to represent StreamID and ChannelID for the following reasons: - 4 billion is more than enough to cover our conceivable channel/stream requirements - It is the most compatible, supported everywhere, can be serialized into JSON and used in Javascript without problems - It is the smallest reasonable data type that balances between a large set of possible identifiers and not using too much space - If randomly chosen, low chance of off-by-one ids being valid - Is not specific to any chain, e.g. [32]byte is not fully supported on starknet etc - Avoids any possible encoding/copypasta issues e.g. UUIDs which can convert to [32]byte in multiple different ways
It is recommended not to use 0 as a stream ID to avoid confusion with uninitialized values
type Transmitter ¶
type Transmitter ocr3types.ContractTransmitter[ReportInfo]