miner

package
v1.0.4 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 26, 2025 License: GPL-3.0 Imports: 42 Imported by: 0

Documentation

Overview

Package miner implements Ethereum block creation and mining.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Backend

type Backend interface {
	BlockChain() *core.BlockChain
	TxPool() *txpool.TxPool
}

Backend wraps all methods required for mining. Only full node is capable to offer all the functions here.

type BidRuntime added in v1.0.4

type BidRuntime struct {
	// contains filtered or unexported fields
}

type BuildPayloadArgs added in v1.0.4

type BuildPayloadArgs struct {
	Parent       common.Hash           // The parent block to build payload on top
	Timestamp    uint64                // The provided timestamp of generated payload
	FeeRecipient common.Address        // The provided recipient address for collecting transaction fee
	Random       common.Hash           // The provided randomness value
	Withdrawals  types.Withdrawals     // The provided withdrawals
	BeaconRoot   *common.Hash          // The provided beaconRoot (Cancun)
	Version      engine.PayloadVersion // Versioning byte for payload id calculation.
}

BuildPayloadArgs contains the provided parameters for building payload. Check engine-api specification for more details. https://github.com/ethereum/execution-apis/blob/main/src/engine/cancun.md#payloadattributesv3

func (*BuildPayloadArgs) Id added in v1.0.4

func (args *BuildPayloadArgs) Id() engine.PayloadID

Id computes an 8-byte identifier by hashing the components of the payload arguments.

type Miner

type Miner struct {
	// contains filtered or unexported fields
}

Miner is the main object which takes care of submitting new work to consensus engine and gathering the sealing result.

func New

func New(eth Backend, config *minerconfig.Config, mux *event.TypeMux, engine consensus.Engine) *Miner

func (*Miner) AddBuilder added in v1.0.4

func (miner *Miner) AddBuilder(builder common.Address, url string) error

AddBuilder adds a builder to the bid simulator.

func (*Miner) BestPackedBlockReward added in v1.0.4

func (miner *Miner) BestPackedBlockReward(parentHash common.Hash) *big.Int

func (*Miner) BuildPayload added in v1.0.4

func (miner *Miner) BuildPayload(args *BuildPayloadArgs, witness bool) (*Payload, error)

BuildPayload builds the payload according to the provided parameters.

func (*Miner) Close

func (miner *Miner) Close()

func (*Miner) GasCeil added in v1.0.4

func (miner *Miner) GasCeil() uint64

func (*Miner) HasBuilder added in v1.0.4

func (miner *Miner) HasBuilder(builder common.Address) bool

HasBuilder returns true if the builder is in the builder list.

func (*Miner) InTurn added in v1.0.4

func (miner *Miner) InTurn() bool

func (*Miner) MevParams added in v1.0.4

func (miner *Miner) MevParams() *types.MevParams

func (*Miner) MevRunning added in v1.0.4

func (miner *Miner) MevRunning() bool

MevRunning return true if mev is running.

func (*Miner) Mining

func (miner *Miner) Mining() bool

func (*Miner) Pending

func (miner *Miner) Pending() (*types.Block, types.Receipts, *state.StateDB)

Pending returns the currently pending block and associated receipts, logs and statedb. The returned values can be nil in case the pending block is not initialized.

func (*Miner) RemoveBuilder added in v1.0.4

func (miner *Miner) RemoveBuilder(builderAddr common.Address) error

RemoveBuilder removes a builder from the bid simulator.

func (*Miner) SendBid added in v1.0.4

func (miner *Miner) SendBid(ctx context.Context, bidArgs *types.BidArgs) (common.Hash, error)

func (*Miner) SetEtherbase

func (miner *Miner) SetEtherbase(addr common.Address)

func (*Miner) SetExtra

func (miner *Miner) SetExtra(extra []byte) error

SetExtra sets the content used to initialize the block extra field.

func (*Miner) SetGasCeil added in v1.0.4

func (miner *Miner) SetGasCeil(ceil uint64)

SetGasCeil sets the gaslimit to strive for when mining blocks post 1559. For pre-1559 blocks, it sets the ceiling.

func (*Miner) SetGasTip added in v1.0.4

func (miner *Miner) SetGasTip(tip *big.Int) error

func (*Miner) SetPrioAddresses added in v1.0.4

func (miner *Miner) SetPrioAddresses(prio []common.Address)

SetPrioAddresses sets a list of addresses to prioritize for transaction inclusion.

func (*Miner) SetRecommitInterval

func (miner *Miner) SetRecommitInterval(interval time.Duration)

SetRecommitInterval sets the interval for sealing work resubmitting.

func (*Miner) Start

func (miner *Miner) Start()

func (*Miner) StartMev added in v1.0.4

func (miner *Miner) StartMev()

StartMev starts mev.

func (*Miner) Stop

func (miner *Miner) Stop()

func (*Miner) StopMev added in v1.0.4

func (miner *Miner) StopMev()

StopMev stops mev.

func (*Miner) SubscribePendingLogs

func (miner *Miner) SubscribePendingLogs(ch chan<- []*types.Log) event.Subscription

SubscribePendingLogs starts delivering logs from pending transactions to the given channel.

func (*Miner) TryWaitProposalDoneWhenStopping added in v1.0.4

func (miner *Miner) TryWaitProposalDoneWhenStopping()

type Payload added in v1.0.4

type Payload struct {
	// contains filtered or unexported fields
}

Payload wraps the built payload(block waiting for sealing). According to the engine-api specification, EL should build the initial version of the payload which has an empty transaction set and then keep update it in order to maximize the revenue. Therefore, the empty-block here is always available and full-block will be set/updated afterwards.

func (*Payload) Resolve added in v1.0.4

func (payload *Payload) Resolve() *engine.ExecutionPayloadEnvelope

Resolve returns the latest built payload and also terminates the background thread for updating payload. It's safe to be called multiple times.

func (*Payload) ResolveEmpty added in v1.0.4

func (payload *Payload) ResolveEmpty() *engine.ExecutionPayloadEnvelope

ResolveEmpty is basically identical to Resolve, but it expects empty block only. It's only used in tests.

func (*Payload) ResolveFull added in v1.0.4

func (payload *Payload) ResolveFull() *engine.ExecutionPayloadEnvelope

ResolveFull is basically identical to Resolve, but it expects full block only. Don't call Resolve until ResolveFull returns, otherwise it might block forever.

Directories

Path Synopsis
Package miner implements Ethereum block creation and mining.
Package miner implements Ethereum block creation and mining.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL