2022-05-24 20:39:40 +02:00
|
|
|
// Copyright 2020 The go-ethereum Authors
|
2020-12-14 11:27:15 +02:00
|
|
|
// This file is part of the go-ethereum library.
|
|
|
|
//
|
|
|
|
// The go-ethereum library is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU Lesser General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// The go-ethereum library is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU Lesser General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
|
|
// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
package eth
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"math/big"
|
|
|
|
"sync/atomic"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/common"
|
|
|
|
"github.com/ethereum/go-ethereum/core"
|
|
|
|
"github.com/ethereum/go-ethereum/core/types"
|
|
|
|
"github.com/ethereum/go-ethereum/eth/protocols/eth"
|
|
|
|
"github.com/ethereum/go-ethereum/p2p/enode"
|
|
|
|
)
|
|
|
|
|
|
|
|
// ethHandler implements the eth.Backend interface to handle the various network
|
|
|
|
// packets that are sent as replies or broadcasts.
|
|
|
|
type ethHandler handler
|
|
|
|
|
2021-12-03 12:32:41 +02:00
|
|
|
func (h *ethHandler) Chain() *core.BlockChain { return h.chain }
|
optimism: historical Bedrock geth rollup changes
This commit squashes the op-geth fork history into a more maintainable
diff for rebasing upon upstream geth.
reference-optimistic-geth changes (origins of op-geth in early Bedrock
development stage):
- Deposit TX Type
- Enable deposit tx in EVM/tx pool
- Change deposit nonce to not be the max nonce
- Extend PayloadAttributesV1 with a Transactions field
- Force deposits at the start of each L2 block
- Fix height check
- noTxPool flag, reproduce block in verifier mode without tx pool interference
- Fix RPC json marshalling (ref op-geth PR 4)
- Deposit txs block height check in block body validation (ref op-geth PR 5)
- core: do not try to reinject deposit txs into tx-pool (ref-op-geth PR 6)
- deposit source hash field instead of L2 block height and tx index combination
- Include invalid deposits, rewind state, but always persist mint (#10)
- Provide gas to Call/Create in deposit transactions (#12)
- Add docker builds (ref-op-geth PR 16, 17)
- Don't panic on deposit transaction signature values or chain ID (ref-op-geth PR 18)
- core: Add version to DepositTx (ref-op-geth PR 19)
- Enable Geth build/lint/test in CircleCI (ref-op-geth PR 23)
- core: Include guaranteed gas in the gas pool (ref-op-geth PR 21)
- core: handle base fee, l1 availability fee, tx fee (ref-op-geth PR 27)
- fix: deposit tx hash
- fix l1 fee cache, rpc, tracing and tx pool
- core: remove deposit-tx sub-type (a.k.a. deposit version byte)
- eth/catalyst: allow engine user to reorg own chain
- miner: restore ability to reorg deep as block builder
- params: print Optimism consensus type in banner
- core/types: remove unused protected() method, see upstream PR 23376
- core: do not mutate original balance value in tx pool l1 cost adjustment
- core: subtract deposit gas from pool, so other txs do not use the same gas. And fail tx processing if deposits reach gas limit
- core/types: deposits do not tip, avoid basefee subtraction
- Unmeter the L1 Attributes Transaction
- miner: handle force tx errors as critical, clean up diff
- ci: Switch branch
- eth,miner: return STATUS_INVALID when failing to process forced transactions in request (ref-op-geth PR 40)
- verifier: forward tx to sequencer based on flag
- txpool: add flag to disable tx gossip (ref-op-geth PR 42)
- Add op-geth version in addition to geth version (ref-op-geth PR 43)
- ci: CircleCI improvements (ref-op-geth PR 44)
- Rename to op-geth
- Build latest tag on optimism branch
op-geth changes:
- Expose cache config in simulated backend (#2)
- Add EIP-1559 parameters
- eth/catalyst: update payload id computation (#1)
- make eip1559 configurable (#4)
- post-merge network should not log warnings about missing transition information (#5)
- Make the simulator more configurable (#6)
- fix OPB-6 - IsDepositTx check instead of artificial nonce value check (#7)
- Simulated backend - enable proof of stake consensus type and fix performance issue (#8)
- accounts: simulated backend consensus engine option and immediate tx indexing
- consensus/beacon: recognize all blocks as reached TTD with 0 TTD in chain config
- Add --rollup.historicalhttp CLI flag and fix backend iface
- Flags and interfaces for historical RPC requests (#12)
- Redirect historical RPC requests (#13)
- Use the pre-existing ethereum.NotFound error (#18)
- Add historical endpoint to TraceBlockByNumber and TraceBlockByHash (#19)
- Add historical endpoint to TraceTransaction (#20)
- Add historical endpoint to TraceCall (#21)
- optimism: fee params from info txi, update l1 cost func GPO params read (#15)
- add hardcoded addresses for fee payouts (#23)
- dynamic gas limit via engine API (#22)
Co-authored-by: Matthew Slipper <me@matthewslipper.com>
Co-authored-by: Joshua Gutow <jgutow@oplabs.co>
Co-authored-by: protolambda <proto@protolambda.com>
Co-authored-by: Mark Tyneway <mark.tyneway@gmail.com>
Co-authored-by: Maurelian <maurelian@protonmail.ch>
2022-03-10 12:13:11 -08:00
|
|
|
|
|
|
|
// NilPool satisfies the TxPool interface but does not return any tx in the
|
|
|
|
// pool. It is used to disable transaction gossip.
|
|
|
|
type NilPool struct{}
|
|
|
|
|
|
|
|
// NilPool Get always returns nil
|
|
|
|
func (n NilPool) Get(hash common.Hash) *types.Transaction { return nil }
|
|
|
|
|
|
|
|
func (h *ethHandler) TxPool() eth.TxPool {
|
|
|
|
if h.noTxGossip {
|
|
|
|
return &NilPool{}
|
|
|
|
}
|
|
|
|
return h.txpool
|
|
|
|
}
|
2020-12-14 11:27:15 +02:00
|
|
|
|
|
|
|
// RunPeer is invoked when a peer joins on the `eth` protocol.
|
|
|
|
func (h *ethHandler) RunPeer(peer *eth.Peer, hand eth.Handler) error {
|
|
|
|
return (*handler)(h).runEthPeer(peer, hand)
|
|
|
|
}
|
|
|
|
|
|
|
|
// PeerInfo retrieves all known `eth` information about a peer.
|
|
|
|
func (h *ethHandler) PeerInfo(id enode.ID) interface{} {
|
2021-02-02 10:44:36 +02:00
|
|
|
if p := h.peers.peer(id.String()); p != nil {
|
2020-12-14 11:27:15 +02:00
|
|
|
return p.info()
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// AcceptTxs retrieves whether transaction processing is enabled on the node
|
|
|
|
// or if inbound transactions should simply be dropped.
|
|
|
|
func (h *ethHandler) AcceptTxs() bool {
|
optimism: historical Bedrock geth rollup changes
This commit squashes the op-geth fork history into a more maintainable
diff for rebasing upon upstream geth.
reference-optimistic-geth changes (origins of op-geth in early Bedrock
development stage):
- Deposit TX Type
- Enable deposit tx in EVM/tx pool
- Change deposit nonce to not be the max nonce
- Extend PayloadAttributesV1 with a Transactions field
- Force deposits at the start of each L2 block
- Fix height check
- noTxPool flag, reproduce block in verifier mode without tx pool interference
- Fix RPC json marshalling (ref op-geth PR 4)
- Deposit txs block height check in block body validation (ref op-geth PR 5)
- core: do not try to reinject deposit txs into tx-pool (ref-op-geth PR 6)
- deposit source hash field instead of L2 block height and tx index combination
- Include invalid deposits, rewind state, but always persist mint (#10)
- Provide gas to Call/Create in deposit transactions (#12)
- Add docker builds (ref-op-geth PR 16, 17)
- Don't panic on deposit transaction signature values or chain ID (ref-op-geth PR 18)
- core: Add version to DepositTx (ref-op-geth PR 19)
- Enable Geth build/lint/test in CircleCI (ref-op-geth PR 23)
- core: Include guaranteed gas in the gas pool (ref-op-geth PR 21)
- core: handle base fee, l1 availability fee, tx fee (ref-op-geth PR 27)
- fix: deposit tx hash
- fix l1 fee cache, rpc, tracing and tx pool
- core: remove deposit-tx sub-type (a.k.a. deposit version byte)
- eth/catalyst: allow engine user to reorg own chain
- miner: restore ability to reorg deep as block builder
- params: print Optimism consensus type in banner
- core/types: remove unused protected() method, see upstream PR 23376
- core: do not mutate original balance value in tx pool l1 cost adjustment
- core: subtract deposit gas from pool, so other txs do not use the same gas. And fail tx processing if deposits reach gas limit
- core/types: deposits do not tip, avoid basefee subtraction
- Unmeter the L1 Attributes Transaction
- miner: handle force tx errors as critical, clean up diff
- ci: Switch branch
- eth,miner: return STATUS_INVALID when failing to process forced transactions in request (ref-op-geth PR 40)
- verifier: forward tx to sequencer based on flag
- txpool: add flag to disable tx gossip (ref-op-geth PR 42)
- Add op-geth version in addition to geth version (ref-op-geth PR 43)
- ci: CircleCI improvements (ref-op-geth PR 44)
- Rename to op-geth
- Build latest tag on optimism branch
op-geth changes:
- Expose cache config in simulated backend (#2)
- Add EIP-1559 parameters
- eth/catalyst: update payload id computation (#1)
- make eip1559 configurable (#4)
- post-merge network should not log warnings about missing transition information (#5)
- Make the simulator more configurable (#6)
- fix OPB-6 - IsDepositTx check instead of artificial nonce value check (#7)
- Simulated backend - enable proof of stake consensus type and fix performance issue (#8)
- accounts: simulated backend consensus engine option and immediate tx indexing
- consensus/beacon: recognize all blocks as reached TTD with 0 TTD in chain config
- Add --rollup.historicalhttp CLI flag and fix backend iface
- Flags and interfaces for historical RPC requests (#12)
- Redirect historical RPC requests (#13)
- Use the pre-existing ethereum.NotFound error (#18)
- Add historical endpoint to TraceBlockByNumber and TraceBlockByHash (#19)
- Add historical endpoint to TraceTransaction (#20)
- Add historical endpoint to TraceCall (#21)
- optimism: fee params from info txi, update l1 cost func GPO params read (#15)
- add hardcoded addresses for fee payouts (#23)
- dynamic gas limit via engine API (#22)
Co-authored-by: Matthew Slipper <me@matthewslipper.com>
Co-authored-by: Joshua Gutow <jgutow@oplabs.co>
Co-authored-by: protolambda <proto@protolambda.com>
Co-authored-by: Mark Tyneway <mark.tyneway@gmail.com>
Co-authored-by: Maurelian <maurelian@protonmail.ch>
2022-03-10 12:13:11 -08:00
|
|
|
if h.noTxGossip {
|
|
|
|
return false
|
|
|
|
}
|
2020-12-14 11:27:15 +02:00
|
|
|
return atomic.LoadUint32(&h.acceptTxs) == 1
|
|
|
|
}
|
|
|
|
|
|
|
|
// Handle is invoked from a peer's message handler when it receives a new remote
|
|
|
|
// message that the handler couldn't consume and serve itself.
|
|
|
|
func (h *ethHandler) Handle(peer *eth.Peer, packet eth.Packet) error {
|
|
|
|
// Consume any broadcasts and announces, forwarding the rest to the downloader
|
|
|
|
switch packet := packet.(type) {
|
|
|
|
case *eth.NewBlockHashesPacket:
|
|
|
|
hashes, numbers := packet.Unpack()
|
|
|
|
return h.handleBlockAnnounces(peer, hashes, numbers)
|
|
|
|
|
|
|
|
case *eth.NewBlockPacket:
|
|
|
|
return h.handleBlockBroadcast(peer, packet.Block, packet.TD)
|
|
|
|
|
2022-10-31 15:23:26 +01:00
|
|
|
case *eth.NewPooledTransactionHashesPacket66:
|
2020-12-14 11:27:15 +02:00
|
|
|
return h.txFetcher.Notify(peer.ID(), *packet)
|
|
|
|
|
2022-10-31 15:23:26 +01:00
|
|
|
case *eth.NewPooledTransactionHashesPacket68:
|
|
|
|
return h.txFetcher.Notify(peer.ID(), packet.Hashes)
|
|
|
|
|
2020-12-14 11:27:15 +02:00
|
|
|
case *eth.TransactionsPacket:
|
|
|
|
return h.txFetcher.Enqueue(peer.ID(), *packet, false)
|
|
|
|
|
|
|
|
case *eth.PooledTransactionsPacket:
|
|
|
|
return h.txFetcher.Enqueue(peer.ID(), *packet, true)
|
|
|
|
|
|
|
|
default:
|
|
|
|
return fmt.Errorf("unexpected eth packet type: %T", packet)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// handleBlockAnnounces is invoked from a peer's message handler when it transmits a
|
|
|
|
// batch of block announcements for the local node to process.
|
|
|
|
func (h *ethHandler) handleBlockAnnounces(peer *eth.Peer, hashes []common.Hash, numbers []uint64) error {
|
all: core rework for the merge transition (#23761)
* all: work for eth1/2 transtition
* consensus/beacon, eth: change beacon difficulty to 0
* eth: updates
* all: add terminalBlockDifficulty config, fix rebasing issues
* eth: implemented merge interop spec
* internal/ethapi: update to v1.0.0.alpha.2
This commit updates the code to the new spec, moving payloadId into
it's own object. It also fixes an issue with finalizing an empty blockhash.
It also properly sets the basefee
* all: sync polishes, other fixes + refactors
* core, eth: correct semantics for LeavePoW, EnterPoS
* core: fixed rebasing artifacts
* core: light: performance improvements
* core: use keyed field (f)
* core: eth: fix compilation issues + tests
* eth/catalyst: dbetter error codes
* all: move Merger to consensus/, remove reliance on it in bc
* all: renamed EnterPoS and LeavePoW to ReachTDD and FinalizePoS
* core: make mergelogs a function
* core: use InsertChain instead of InsertBlock
* les: drop merger from lightchain object
* consensus: add merger
* core: recoverAncestors in catalyst mode
* core: fix nitpick
* all: removed merger from beacon, use TTD, nitpicks
* consensus: eth: add docstring, removed unnecessary code duplication
* consensus/beacon: better comment
* all: easy to fix nitpicks by karalabe
* consensus/beacon: verify known headers to be sure
* core: comments
* core: eth: don't drop peers who advertise blocks, nitpicks
* core: never add beacon blocks to the future queue
* core: fixed nitpicks
* consensus/beacon: simplify IsTTDReached check
* consensus/beacon: correct IsTTDReached check
Co-authored-by: rjl493456442 <garyrong0905@gmail.com>
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-11-26 12:23:02 +01:00
|
|
|
// Drop all incoming block announces from the p2p network if
|
|
|
|
// the chain already entered the pos stage and disconnect the
|
|
|
|
// remote peer.
|
|
|
|
if h.merger.PoSFinalized() {
|
|
|
|
// TODO (MariusVanDerWijden) drop non-updated peers after the merge
|
|
|
|
return nil
|
|
|
|
// return errors.New("unexpected block announces")
|
|
|
|
}
|
2020-12-14 11:27:15 +02:00
|
|
|
// Schedule all the unknown hashes for retrieval
|
|
|
|
var (
|
|
|
|
unknownHashes = make([]common.Hash, 0, len(hashes))
|
|
|
|
unknownNumbers = make([]uint64, 0, len(numbers))
|
|
|
|
)
|
|
|
|
for i := 0; i < len(hashes); i++ {
|
|
|
|
if !h.chain.HasBlock(hashes[i], numbers[i]) {
|
|
|
|
unknownHashes = append(unknownHashes, hashes[i])
|
|
|
|
unknownNumbers = append(unknownNumbers, numbers[i])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for i := 0; i < len(unknownHashes); i++ {
|
|
|
|
h.blockFetcher.Notify(peer.ID(), unknownHashes[i], unknownNumbers[i], time.Now(), peer.RequestOneHeader, peer.RequestBodies)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// handleBlockBroadcast is invoked from a peer's message handler when it transmits a
|
|
|
|
// block broadcast for the local node to process.
|
|
|
|
func (h *ethHandler) handleBlockBroadcast(peer *eth.Peer, block *types.Block, td *big.Int) error {
|
all: core rework for the merge transition (#23761)
* all: work for eth1/2 transtition
* consensus/beacon, eth: change beacon difficulty to 0
* eth: updates
* all: add terminalBlockDifficulty config, fix rebasing issues
* eth: implemented merge interop spec
* internal/ethapi: update to v1.0.0.alpha.2
This commit updates the code to the new spec, moving payloadId into
it's own object. It also fixes an issue with finalizing an empty blockhash.
It also properly sets the basefee
* all: sync polishes, other fixes + refactors
* core, eth: correct semantics for LeavePoW, EnterPoS
* core: fixed rebasing artifacts
* core: light: performance improvements
* core: use keyed field (f)
* core: eth: fix compilation issues + tests
* eth/catalyst: dbetter error codes
* all: move Merger to consensus/, remove reliance on it in bc
* all: renamed EnterPoS and LeavePoW to ReachTDD and FinalizePoS
* core: make mergelogs a function
* core: use InsertChain instead of InsertBlock
* les: drop merger from lightchain object
* consensus: add merger
* core: recoverAncestors in catalyst mode
* core: fix nitpick
* all: removed merger from beacon, use TTD, nitpicks
* consensus: eth: add docstring, removed unnecessary code duplication
* consensus/beacon: better comment
* all: easy to fix nitpicks by karalabe
* consensus/beacon: verify known headers to be sure
* core: comments
* core: eth: don't drop peers who advertise blocks, nitpicks
* core: never add beacon blocks to the future queue
* core: fixed nitpicks
* consensus/beacon: simplify IsTTDReached check
* consensus/beacon: correct IsTTDReached check
Co-authored-by: rjl493456442 <garyrong0905@gmail.com>
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-11-26 12:23:02 +01:00
|
|
|
// Drop all incoming block announces from the p2p network if
|
|
|
|
// the chain already entered the pos stage and disconnect the
|
|
|
|
// remote peer.
|
|
|
|
if h.merger.PoSFinalized() {
|
|
|
|
// TODO (MariusVanDerWijden) drop non-updated peers after the merge
|
|
|
|
return nil
|
|
|
|
// return errors.New("unexpected block announces")
|
|
|
|
}
|
2020-12-14 11:27:15 +02:00
|
|
|
// Schedule the block for import
|
|
|
|
h.blockFetcher.Enqueue(peer.ID(), block)
|
|
|
|
|
|
|
|
// Assuming the block is importable by the peer, but possibly not yet done so,
|
|
|
|
// calculate the head hash and TD that the peer truly must have.
|
|
|
|
var (
|
|
|
|
trueHead = block.ParentHash()
|
|
|
|
trueTD = new(big.Int).Sub(td, block.Difficulty())
|
|
|
|
)
|
|
|
|
// Update the peer's total difficulty if better than the previous
|
|
|
|
if _, td := peer.Head(); trueTD.Cmp(td) > 0 {
|
|
|
|
peer.SetHead(trueHead, trueTD)
|
|
|
|
h.chainSync.handlePeerEvent(peer)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|