backend.go 4.81 KB
Newer Older
1
// Copyright 2015 The go-ethereum Authors
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
// 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 (
21
	"context"
22 23 24 25 26
	"math/big"

	"github.com/ethereum/go-ethereum/accounts"
	"github.com/ethereum/go-ethereum/common"
	"github.com/ethereum/go-ethereum/core"
27
	"github.com/ethereum/go-ethereum/core/bloombits"
28
	"github.com/ethereum/go-ethereum/core/state"
29 30 31 32 33
	"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"
34
	"github.com/ethereum/go-ethereum/params"
35 36 37 38 39 40
	"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 {
41
	// General Ethereum API
42 43 44 45 46 47
	Downloader() *downloader.Downloader
	ProtocolVersion() int
	SuggestPrice(ctx context.Context) (*big.Int, error)
	ChainDb() ethdb.Database
	EventMux() *event.TypeMux
	AccountManager() *accounts.Manager
48
	ExtRPCEnabled() bool
49
	RPCGasCap() *big.Int // global gas cap for eth_call over rpc: DoS protection
50

51
	// Blockchain API
52
	SetHead(number uint64)
53
	HeaderByNumber(ctx context.Context, blockNr rpc.BlockNumber) (*types.Header, error)
54
	HeaderByHash(ctx context.Context, blockHash common.Hash) (*types.Header, error)
55
	BlockByNumber(ctx context.Context, blockNr rpc.BlockNumber) (*types.Block, error)
56
	StateAndHeaderByNumber(ctx context.Context, blockNr rpc.BlockNumber) (*state.StateDB, *types.Header, error)
57 58 59
	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
60
	GetEVM(ctx context.Context, msg core.Message, state *state.StateDB, header *types.Header) (*vm.EVM, func() error, error)
61 62 63
	SubscribeChainEvent(ch chan<- core.ChainEvent) event.Subscription
	SubscribeChainHeadEvent(ch chan<- core.ChainHeadEvent) event.Subscription
	SubscribeChainSideEvent(ch chan<- core.ChainSideEvent) event.Subscription
64

65
	// Transaction pool API
66
	SendTx(ctx context.Context, signedTx *types.Transaction) error
67
	GetTransaction(ctx context.Context, txHash common.Hash) (*types.Transaction, common.Hash, uint64, uint64, error)
68
	GetPoolTransactions() (types.Transactions, error)
69 70 71
	GetPoolTransaction(txHash common.Hash) *types.Transaction
	GetPoolNonce(ctx context.Context, addr common.Address) (uint64, error)
	Stats() (pending int, queued int)
72
	TxPoolContent() (map[common.Address]types.Transactions, map[common.Address]types.Transactions)
73
	SubscribeNewTxsEvent(chan<- core.NewTxsEvent) event.Subscription
74

75 76 77 78 79 80 81
	// 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
	SubscribeRemovedLogsEvent(ch chan<- core.RemovedLogsEvent) event.Subscription

82 83
	ChainConfig() *params.ChainConfig
	CurrentBlock() *types.Block
84 85
}

86
func GetAPIs(apiBackend Backend) []rpc.API {
87
	nonceLock := new(AddrLocker)
88
	return []rpc.API{
89 90 91
		{
			Namespace: "eth",
			Version:   "1.0",
92
			Service:   NewPublicEthereumAPI(apiBackend),
93 94 95 96 97 98 99 100 101
			Public:    true,
		}, {
			Namespace: "eth",
			Version:   "1.0",
			Service:   NewPublicBlockChainAPI(apiBackend),
			Public:    true,
		}, {
			Namespace: "eth",
			Version:   "1.0",
102
			Service:   NewPublicTransactionPoolAPI(apiBackend, nonceLock),
103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
			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",
126
			Service:   NewPrivateAccountAPI(apiBackend, nonceLock),
127 128 129 130
			Public:    false,
		},
	}
}