Documentation ¶
Overview ¶
Package gasprice contains Oracle type which recommends gas prices based on recent blocks. However, Kaia uses invariant ChainConfig.UnitPrice and this value will not be changed until ChainConfig.UnitPrice is updated with governance.
Source Files
- gasprice.go : implements Oracle struct which has a function to suggest appropriate gas price
Index ¶
- type Config
- type Governance
- type Oracle
- func (oracle *Oracle) FeeHistory(ctx context.Context, blocks int, unresolvedLastBlock rpc.BlockNumber, ...) (*big.Int, [][]*big.Int, []*big.Int, []float64, error)
- func (oracle *Oracle) PurgeCache()
- func (gpo *Oracle) SuggestPrice(ctx context.Context) (*big.Int, error)
- func (gpo *Oracle) SuggestTipCap(ctx context.Context) (*big.Int, error)
- type OracleBackend
- type TxPool
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Governance ¶
type Governance interface {
EffectiveParams(bn uint64) (*params.GovParamSet, error)
}
type Oracle ¶
type Oracle struct {
// contains filtered or unexported fields
}
Oracle recommends gas prices based on the content of recent blocks. Suitable for both light and full clients.
func NewOracle ¶
func NewOracle(backend OracleBackend, config Config, txPool TxPool, governance Governance) *Oracle
NewOracle returns a new oracle.
func (*Oracle) FeeHistory ¶
func (oracle *Oracle) FeeHistory( ctx context.Context, blocks int, unresolvedLastBlock rpc.BlockNumber, rewardPercentiles []float64, ) (*big.Int, [][]*big.Int, []*big.Int, []float64, error)
FeeHistory returns data relevant for fee estimation based on the specified range of blocks. The range can be specified either with absolute block numbers or ending with the latest or pending block. Backends may or may not support gathering data from the pending block or blocks older than a certain age (specified in maxHistory). The first block of the actually processed range is returned to avoid ambiguity when parts of the requested range are not available or when the head has changed during processing this request. Three arrays are returned based on the processed blocks:
- reward: the requested percentiles of effective priority fees per gas of transactions in each block, sorted in ascending order and weighted by gas used.
- baseFee: base fee per gas in the given block
- gasUsedRatio: gasUsed/gasLimit in the given block
Note: baseFee includes the next block after the newest of the returned range, because this value can be derived from the newest block.
func (*Oracle) PurgeCache ¶
func (oracle *Oracle) PurgeCache()
func (*Oracle) SuggestPrice ¶
SuggestPrice returns the recommended gas price. This value is intended to be used as gasPrice or maxFeePerGas.
type OracleBackend ¶
type OracleBackend interface { HeaderByNumber(ctx context.Context, number rpc.BlockNumber) (*types.Header, error) BlockByNumber(ctx context.Context, number rpc.BlockNumber) (*types.Block, error) GetBlockReceipts(ctx context.Context, hash common.Hash) types.Receipts ChainConfig() *params.ChainConfig CurrentBlock() *types.Block }
OracleBackend includes all necessary background APIs for oracle.