| 
									
										
										
										
											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" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/core" | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  | 	ProtocolVersion() int | 
					
						
							|  |  |  | 	SuggestPrice(ctx context.Context) (*big.Int, error) | 
					
						
							|  |  |  | 	ChainDb() ethdb.Database | 
					
						
							|  |  |  | 	EventMux() *event.TypeMux | 
					
						
							|  |  |  | 	AccountManager() *accounts.Manager | 
					
						
							| 
									
										
										
										
											2017-11-13 13:47:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 	// BlockChain API | 
					
						
							|  |  |  | 	SetHead(number uint64) | 
					
						
							| 
									
										
										
										
											2016-10-14 05:51:29 +02:00
										 |  |  | 	HeaderByNumber(ctx context.Context, blockNr rpc.BlockNumber) (*types.Header, error) | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 	BlockByNumber(ctx context.Context, blockNr rpc.BlockNumber) (*types.Block, error) | 
					
						
							| 
									
										
										
										
											2017-06-27 15:57:06 +02:00
										 |  |  | 	StateAndHeaderByNumber(ctx context.Context, blockNr rpc.BlockNumber) (*state.StateDB, *types.Header, error) | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 	GetBlock(ctx context.Context, blockHash common.Hash) (*types.Block, error) | 
					
						
							|  |  |  | 	GetReceipts(ctx context.Context, blockHash common.Hash) (types.Receipts, error) | 
					
						
							|  |  |  | 	GetTd(blockHash common.Hash) *big.Int | 
					
						
							| 
									
										
										
										
											2017-06-27 15:57:06 +02:00
										 |  |  | 	GetEVM(ctx context.Context, msg core.Message, state *state.StateDB, header *types.Header, vmCfg 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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-16 04:26:23 +01:00
										 |  |  | 	// TxPool API | 
					
						
							|  |  |  | 	SendTx(ctx context.Context, signedTx *types.Transaction) 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
										 |  |  | 
 | 
					
						
							|  |  |  | 	ChainConfig() *params.ChainConfig | 
					
						
							|  |  |  | 	CurrentBlock() *types.Block | 
					
						
							| 
									
										
										
										
											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, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |