github.com/tirogen/go-ethereum@v1.10.12-0.20221226051715-250cfede41b6/internal/ethapi/backend.go (about) 1 // Copyright 2015 The go-ethereum Authors 2 // This file is part of the go-ethereum library. 3 // 4 // The go-ethereum library is free software: you can redistribute it and/or modify 5 // it under the terms of the GNU Lesser General Public License as published by 6 // the Free Software Foundation, either version 3 of the License, or 7 // (at your option) any later version. 8 // 9 // The go-ethereum library is distributed in the hope that it will be useful, 10 // but WITHOUT ANY WARRANTY; without even the implied warranty of 11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 // GNU Lesser General Public License for more details. 13 // 14 // You should have received a copy of the GNU Lesser General Public License 15 // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>. 16 17 // Package ethapi implements the general Ethereum API functions. 18 package ethapi 19 20 import ( 21 "context" 22 "math/big" 23 "time" 24 25 "github.com/tirogen/go-ethereum" 26 "github.com/tirogen/go-ethereum/accounts" 27 "github.com/tirogen/go-ethereum/common" 28 "github.com/tirogen/go-ethereum/consensus" 29 "github.com/tirogen/go-ethereum/core" 30 "github.com/tirogen/go-ethereum/core/bloombits" 31 "github.com/tirogen/go-ethereum/core/state" 32 "github.com/tirogen/go-ethereum/core/types" 33 "github.com/tirogen/go-ethereum/core/vm" 34 "github.com/tirogen/go-ethereum/ethdb" 35 "github.com/tirogen/go-ethereum/event" 36 "github.com/tirogen/go-ethereum/params" 37 "github.com/tirogen/go-ethereum/rpc" 38 ) 39 40 // Backend interface provides the common API services (that are provided by 41 // both full and light clients) with access to necessary functions. 42 type Backend interface { 43 // General Ethereum API 44 SyncProgress() ethereum.SyncProgress 45 46 SuggestGasTipCap(ctx context.Context) (*big.Int, error) 47 FeeHistory(ctx context.Context, blockCount int, lastBlock rpc.BlockNumber, rewardPercentiles []float64) (*big.Int, [][]*big.Int, []*big.Int, []float64, error) 48 ChainDb() ethdb.Database 49 AccountManager() *accounts.Manager 50 ExtRPCEnabled() bool 51 RPCGasCap() uint64 // global gas cap for eth_call over rpc: DoS protection 52 RPCEVMTimeout() time.Duration // global timeout for eth_call over rpc: DoS protection 53 RPCTxFeeCap() float64 // global tx fee cap for all transaction related APIs 54 UnprotectedAllowed() bool // allows only for EIP155 transactions. 55 56 // Blockchain API 57 SetHead(number uint64) 58 HeaderByNumber(ctx context.Context, number rpc.BlockNumber) (*types.Header, error) 59 HeaderByHash(ctx context.Context, hash common.Hash) (*types.Header, error) 60 HeaderByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (*types.Header, error) 61 CurrentHeader() *types.Header 62 CurrentBlock() *types.Block 63 BlockByNumber(ctx context.Context, number rpc.BlockNumber) (*types.Block, error) 64 BlockByHash(ctx context.Context, hash common.Hash) (*types.Block, error) 65 BlockByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (*types.Block, error) 66 StateAndHeaderByNumber(ctx context.Context, number rpc.BlockNumber) (*state.StateDB, *types.Header, error) 67 StateAndHeaderByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (*state.StateDB, *types.Header, error) 68 PendingBlockAndReceipts() (*types.Block, types.Receipts) 69 GetReceipts(ctx context.Context, hash common.Hash) (types.Receipts, error) 70 GetTd(ctx context.Context, hash common.Hash) *big.Int 71 GetEVM(ctx context.Context, msg core.Message, state *state.StateDB, header *types.Header, vmConfig *vm.Config) (*vm.EVM, func() error, error) 72 SubscribeChainEvent(ch chan<- core.ChainEvent) event.Subscription 73 SubscribeChainHeadEvent(ch chan<- core.ChainHeadEvent) event.Subscription 74 SubscribeChainSideEvent(ch chan<- core.ChainSideEvent) event.Subscription 75 76 // Transaction pool API 77 SendTx(ctx context.Context, signedTx *types.Transaction) error 78 GetTransaction(ctx context.Context, txHash common.Hash) (*types.Transaction, common.Hash, uint64, uint64, error) 79 GetPoolTransactions() (types.Transactions, error) 80 GetPoolTransaction(txHash common.Hash) *types.Transaction 81 GetPoolNonce(ctx context.Context, addr common.Address) (uint64, error) 82 Stats() (pending int, queued int) 83 TxPoolContent() (map[common.Address]types.Transactions, map[common.Address]types.Transactions) 84 TxPoolContentFrom(addr common.Address) (types.Transactions, types.Transactions) 85 SubscribeNewTxsEvent(chan<- core.NewTxsEvent) event.Subscription 86 87 ChainConfig() *params.ChainConfig 88 Engine() consensus.Engine 89 90 // This is copied from filters.Backend 91 // eth/filters needs to be initialized from this backend type, so methods needed by 92 // it must also be included here. 93 GetLogs(ctx context.Context, blockHash common.Hash, number uint64) ([][]*types.Log, error) 94 SubscribeRemovedLogsEvent(ch chan<- core.RemovedLogsEvent) event.Subscription 95 SubscribeLogsEvent(ch chan<- []*types.Log) event.Subscription 96 SubscribePendingLogsEvent(ch chan<- []*types.Log) event.Subscription 97 BloomStatus() (uint64, uint64) 98 ServiceFilter(ctx context.Context, session *bloombits.MatcherSession) 99 } 100 101 func GetAPIs(apiBackend Backend) []rpc.API { 102 nonceLock := new(AddrLocker) 103 return []rpc.API{ 104 { 105 Namespace: "eth", 106 Service: NewEthereumAPI(apiBackend), 107 }, { 108 Namespace: "eth", 109 Service: NewBlockChainAPI(apiBackend), 110 }, { 111 Namespace: "eth", 112 Service: NewTransactionAPI(apiBackend, nonceLock), 113 }, { 114 Namespace: "txpool", 115 Service: NewTxPoolAPI(apiBackend), 116 }, { 117 Namespace: "debug", 118 Service: NewDebugAPI(apiBackend), 119 }, { 120 Namespace: "eth", 121 Service: NewEthereumAccountAPI(apiBackend.AccountManager()), 122 }, { 123 Namespace: "personal", 124 Service: NewPersonalAccountAPI(apiBackend, nonceLock), 125 }, 126 } 127 }