| 
									
										
										
										
											2016-11-09 02:01:56 +01:00
										 |  |  | // Copyright 2015 The go-ethereum Authors | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01: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 ethapi implements the general Ethereum API functions. | 
					
						
							|  |  |  | package ethapi | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2017-03-22 18:20:33 +01:00
										 |  |  | 	"context" | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 	"math/big" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/accounts" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/common" | 
					
						
							| 
									
										
										
										
											2020-08-03 19:40:46 +02:00
										 |  |  | 	"github.com/ethereum/go-ethereum/consensus" | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/core" | 
					
						
							| 
									
										
										
										
											2019-06-12 11:24:24 +03:00
										 |  |  | 	"github.com/ethereum/go-ethereum/core/bloombits" | 
					
						
							| 
									
										
										
										
											2017-06-27 15:57:06 +02:00
										 |  |  | 	"github.com/ethereum/go-ethereum/core/state" | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/core/types" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/core/vm" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/eth/downloader" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/ethdb" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/event" | 
					
						
							| 
									
										
										
										
											2016-11-02 13:44:13 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/params" | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/rpc" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Backend interface provides the common API services (that are provided by | 
					
						
							|  |  |  | // both full and light clients) with access to necessary functions. | 
					
						
							|  |  |  | type Backend interface { | 
					
						
							| 
									
										
										
										
											2017-11-13 13:47:27 +02:00
										 |  |  | 	// General Ethereum API | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 	Downloader() *downloader.Downloader | 
					
						
							|  |  |  | 	SuggestPrice(ctx context.Context) (*big.Int, error) | 
					
						
							|  |  |  | 	ChainDb() ethdb.Database | 
					
						
							|  |  |  | 	AccountManager() *accounts.Manager | 
					
						
							| 
									
										
										
										
											2019-04-04 19:03:10 +08:00
										 |  |  | 	ExtRPCEnabled() bool | 
					
						
							| 
									
										
										
										
											2021-02-23 13:09:19 +01:00
										 |  |  | 	RPCGasCap() uint64        // global gas cap for eth_call over rpc: DoS protection | 
					
						
							|  |  |  | 	RPCTxFeeCap() float64     // global tx fee cap for all transaction related APIs | 
					
						
							|  |  |  | 	UnprotectedAllowed() bool // allows only for EIP155 transactions. | 
					
						
							| 
									
										
										
										
											2017-11-13 13:47:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-12 11:24:24 +03:00
										 |  |  | 	// Blockchain API | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 	SetHead(number uint64) | 
					
						
							| 
									
										
										
										
											2019-07-23 21:52:24 +08:00
										 |  |  | 	HeaderByNumber(ctx context.Context, number rpc.BlockNumber) (*types.Header, error) | 
					
						
							|  |  |  | 	HeaderByHash(ctx context.Context, hash common.Hash) (*types.Header, error) | 
					
						
							| 
									
										
										
										
											2019-09-26 01:47:31 -07:00
										 |  |  | 	HeaderByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (*types.Header, error) | 
					
						
							| 
									
										
										
										
											2020-08-03 19:40:46 +02:00
										 |  |  | 	CurrentHeader() *types.Header | 
					
						
							|  |  |  | 	CurrentBlock() *types.Block | 
					
						
							| 
									
										
										
										
											2019-07-23 21:52:24 +08:00
										 |  |  | 	BlockByNumber(ctx context.Context, number rpc.BlockNumber) (*types.Block, error) | 
					
						
							| 
									
										
										
										
											2019-07-25 14:29:53 +08:00
										 |  |  | 	BlockByHash(ctx context.Context, hash common.Hash) (*types.Block, error) | 
					
						
							| 
									
										
										
										
											2019-09-26 01:47:31 -07:00
										 |  |  | 	BlockByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (*types.Block, error) | 
					
						
							| 
									
										
										
										
											2019-07-23 21:52:24 +08:00
										 |  |  | 	StateAndHeaderByNumber(ctx context.Context, number rpc.BlockNumber) (*state.StateDB, *types.Header, error) | 
					
						
							| 
									
										
										
										
											2019-09-26 01:47:31 -07:00
										 |  |  | 	StateAndHeaderByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (*state.StateDB, *types.Header, error) | 
					
						
							| 
									
										
										
										
											2019-07-23 21:52:24 +08:00
										 |  |  | 	GetReceipts(ctx context.Context, hash common.Hash) (types.Receipts, error) | 
					
						
							| 
									
										
										
										
											2020-07-13 17:02:54 +08:00
										 |  |  | 	GetTd(ctx context.Context, hash common.Hash) *big.Int | 
					
						
							| 
									
										
										
										
											2021-04-07 16:54:31 +02:00
										 |  |  | 	GetEVM(ctx context.Context, msg core.Message, state *state.StateDB, header *types.Header, vmConfig *vm.Config) (*vm.EVM, func() error, error) | 
					
						
							| 
									
										
										
										
											2017-08-18 18:58:36 +08:00
										 |  |  | 	SubscribeChainEvent(ch chan<- core.ChainEvent) event.Subscription | 
					
						
							|  |  |  | 	SubscribeChainHeadEvent(ch chan<- core.ChainHeadEvent) event.Subscription | 
					
						
							|  |  |  | 	SubscribeChainSideEvent(ch chan<- core.ChainSideEvent) event.Subscription | 
					
						
							| 
									
										
										
										
											2017-06-27 15:57:06 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-12 11:24:24 +03:00
										 |  |  | 	// Transaction pool API | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 	SendTx(ctx context.Context, signedTx *types.Transaction) error | 
					
						
							| 
									
										
										
										
											2019-05-13 13:41:10 +02:00
										 |  |  | 	GetTransaction(ctx context.Context, txHash common.Hash) (*types.Transaction, common.Hash, uint64, uint64, error) | 
					
						
							| 
									
										
										
										
											2016-12-10 23:54:58 +01:00
										 |  |  | 	GetPoolTransactions() (types.Transactions, error) | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 	GetPoolTransaction(txHash common.Hash) *types.Transaction | 
					
						
							|  |  |  | 	GetPoolNonce(ctx context.Context, addr common.Address) (uint64, error) | 
					
						
							|  |  |  | 	Stats() (pending int, queued int) | 
					
						
							| 
									
										
										
										
											2016-07-01 18:59:55 +03:00
										 |  |  | 	TxPoolContent() (map[common.Address]types.Transactions, map[common.Address]types.Transactions) | 
					
						
							| 
									
										
										
										
											2018-05-18 11:45:52 +03:00
										 |  |  | 	SubscribeNewTxsEvent(chan<- core.NewTxsEvent) event.Subscription | 
					
						
							| 
									
										
										
										
											2016-11-02 13:44:13 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-12 11:24:24 +03:00
										 |  |  | 	// Filter API | 
					
						
							|  |  |  | 	BloomStatus() (uint64, uint64) | 
					
						
							|  |  |  | 	GetLogs(ctx context.Context, blockHash common.Hash) ([][]*types.Log, error) | 
					
						
							|  |  |  | 	ServiceFilter(ctx context.Context, session *bloombits.MatcherSession) | 
					
						
							|  |  |  | 	SubscribeLogsEvent(ch chan<- []*types.Log) event.Subscription | 
					
						
							| 
									
										
										
										
											2019-12-10 12:39:14 +01:00
										 |  |  | 	SubscribePendingLogsEvent(ch chan<- []*types.Log) event.Subscription | 
					
						
							| 
									
										
										
										
											2019-06-12 11:24:24 +03:00
										 |  |  | 	SubscribeRemovedLogsEvent(ch chan<- core.RemovedLogsEvent) event.Subscription | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-02 13:44:13 +01:00
										 |  |  | 	ChainConfig() *params.ChainConfig | 
					
						
							| 
									
										
										
										
											2020-08-03 19:40:46 +02:00
										 |  |  | 	Engine() consensus.Engine | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-12 23:04:14 +02:00
										 |  |  | func GetAPIs(apiBackend Backend) []rpc.API { | 
					
						
							| 
									
										
										
										
											2017-05-25 17:08:13 +02:00
										 |  |  | 	nonceLock := new(AddrLocker) | 
					
						
							| 
									
										
										
										
											2017-03-16 03:54:52 +02:00
										 |  |  | 	return []rpc.API{ | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			Namespace: "eth", | 
					
						
							|  |  |  | 			Version:   "1.0", | 
					
						
							| 
									
										
										
										
											2016-06-15 00:36:31 +02:00
										 |  |  | 			Service:   NewPublicEthereumAPI(apiBackend), | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 			Public:    true, | 
					
						
							|  |  |  | 		}, { | 
					
						
							|  |  |  | 			Namespace: "eth", | 
					
						
							|  |  |  | 			Version:   "1.0", | 
					
						
							|  |  |  | 			Service:   NewPublicBlockChainAPI(apiBackend), | 
					
						
							|  |  |  | 			Public:    true, | 
					
						
							|  |  |  | 		}, { | 
					
						
							|  |  |  | 			Namespace: "eth", | 
					
						
							|  |  |  | 			Version:   "1.0", | 
					
						
							| 
									
										
										
										
											2017-05-25 17:08:13 +02:00
										 |  |  | 			Service:   NewPublicTransactionPoolAPI(apiBackend, nonceLock), | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 			Public:    true, | 
					
						
							|  |  |  | 		}, { | 
					
						
							|  |  |  | 			Namespace: "txpool", | 
					
						
							|  |  |  | 			Version:   "1.0", | 
					
						
							|  |  |  | 			Service:   NewPublicTxPoolAPI(apiBackend), | 
					
						
							|  |  |  | 			Public:    true, | 
					
						
							|  |  |  | 		}, { | 
					
						
							|  |  |  | 			Namespace: "debug", | 
					
						
							|  |  |  | 			Version:   "1.0", | 
					
						
							|  |  |  | 			Service:   NewPublicDebugAPI(apiBackend), | 
					
						
							|  |  |  | 			Public:    true, | 
					
						
							|  |  |  | 		}, { | 
					
						
							|  |  |  | 			Namespace: "debug", | 
					
						
							|  |  |  | 			Version:   "1.0", | 
					
						
							|  |  |  | 			Service:   NewPrivateDebugAPI(apiBackend), | 
					
						
							|  |  |  | 		}, { | 
					
						
							|  |  |  | 			Namespace: "eth", | 
					
						
							|  |  |  | 			Version:   "1.0", | 
					
						
							|  |  |  | 			Service:   NewPublicAccountAPI(apiBackend.AccountManager()), | 
					
						
							|  |  |  | 			Public:    true, | 
					
						
							|  |  |  | 		}, { | 
					
						
							|  |  |  | 			Namespace: "personal", | 
					
						
							|  |  |  | 			Version:   "1.0", | 
					
						
							| 
									
										
										
										
											2017-05-25 17:08:13 +02:00
										 |  |  | 			Service:   NewPrivateAccountAPI(apiBackend, nonceLock), | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 			Public:    false, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |