package hmyapi import ( "context" "math/big" "github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/ethdb" "github.com/ethereum/go-ethereum/event" "github.com/ethereum/go-ethereum/rpc" "github.com/harmony-one/harmony/accounts" "github.com/harmony-one/harmony/block" "github.com/harmony-one/harmony/core" "github.com/harmony-one/harmony/core/state" "github.com/harmony-one/harmony/core/types" "github.com/harmony-one/harmony/core/vm" "github.com/harmony-one/harmony/internal/hmyapi/apiv1" "github.com/harmony-one/harmony/internal/hmyapi/apiv2" "github.com/harmony-one/harmony/internal/params" "github.com/harmony-one/harmony/shard" "github.com/harmony-one/harmony/staking/network" staking "github.com/harmony-one/harmony/staking/types" ) // Backend interface provides the common API services (that are provided by // both full and light clients) with access to necessary functions. // implementations: // * hmy/api_backend.go type Backend interface { // NOTE(ricl): this is not in ETH Backend inteface. They put it directly in eth object. NetVersion() uint64 // General Ethereum API // Downloader() *downloader.Downloader ProtocolVersion() int // SuggestPrice(ctx context.Context) (*big.Int, error) ChainDb() ethdb.Database EventMux() *event.TypeMux AccountManager() *accounts.Manager // ExtRPCEnabled() bool RPCGasCap() *big.Int // global gas cap for hmy_call over rpc: DoS protection // BlockChain API // SetHead(number uint64) HeaderByNumber(ctx context.Context, blockNr rpc.BlockNumber) (*block.Header, error) BlockByNumber(ctx context.Context, blockNr rpc.BlockNumber) (*types.Block, error) StateAndHeaderByNumber(ctx context.Context, blockNr rpc.BlockNumber) (*state.DB, *block.Header, error) 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 GetEVM(ctx context.Context, msg core.Message, state *state.DB, header *block.Header) (*vm.EVM, func() error, error) SubscribeChainEvent(ch chan<- core.ChainEvent) event.Subscription SubscribeChainHeadEvent(ch chan<- core.ChainHeadEvent) event.Subscription SubscribeChainSideEvent(ch chan<- core.ChainSideEvent) event.Subscription // TxPool API SendTx(ctx context.Context, signedTx *types.Transaction) error // GetTransaction(ctx context.Context, txHash common.Hash) (*types.Transaction, common.Hash, uint64, uint64, error) GetPoolTransactions() (types.Transactions, error) GetPoolTransaction(txHash common.Hash) *types.Transaction GetPoolNonce(ctx context.Context, addr common.Address) (uint64, error) // Stats() (pending int, queued int) // TxPoolContent() (map[common.Address]types.Transactions, map[common.Address]types.Transactions) SubscribeNewTxsEvent(chan<- core.NewTxsEvent) event.Subscription ChainConfig() *params.ChainConfig CurrentBlock() *types.Block // Get balance GetBalance(ctx context.Context, address common.Address, blockNr rpc.BlockNumber) (*big.Int, error) // Get validators for a particular epoch GetValidators(epoch *big.Int) (*shard.Committee, error) GetShardID() uint32 // Get transactions history for an address GetTransactionsHistory(address, txType, order string) ([]common.Hash, error) // retrieve the blockHash using txID and add blockHash to CxPool for resending ResendCx(ctx context.Context, txID common.Hash) (uint64, bool) IsLeader() bool SendStakingTx(ctx context.Context, newStakingTx *staking.StakingTransaction) error GetActiveValidatorAddresses() []common.Address GetAllValidatorAddresses() []common.Address GetValidatorInformation(addr common.Address) *staking.Validator GetValidatorStats(addr common.Address) *staking.ValidatorStats GetDelegationsByValidator(validator common.Address) []*staking.Delegation GetDelegationsByDelegator(delegator common.Address) ([]common.Address, []*staking.Delegation) GetValidatorSelfDelegation(addr common.Address) *big.Int GetShardState() (*shard.State, error) GetCurrentStakingErrorSink() []staking.RPCTransactionError GetCurrentTransactionErrorSink() []types.RPCTransactionError GetMedianRawStakeSnapshot() *big.Int GetPendingCXReceipts() []*types.CXReceiptsProof GetCurrentUtilityMetrics() (*network.UtilityMetric, error) } // GetAPIs returns all the APIs. func GetAPIs(b Backend) []rpc.API { nonceLock := new(apiv1.AddrLocker) nonceLockV2 := new(apiv2.AddrLocker) return []rpc.API{ { Namespace: "hmy", Version: "1.0", Service: apiv1.NewPublicHarmonyAPI(b), Public: true, }, { Namespace: "hmy", Version: "1.0", Service: apiv1.NewPublicBlockChainAPI(b), Public: true, }, { Namespace: "hmy", Version: "1.0", Service: apiv1.NewPublicTransactionPoolAPI(b, nonceLock), Public: true, }, { Namespace: "hmy", Version: "1.0", Service: apiv1.NewPublicAccountAPI(b.AccountManager()), Public: true, }, { Namespace: "hmy", Version: "1.0", Service: apiv1.NewDebugAPI(b), Public: true, // FIXME: change to false once IPC implemented }, { Namespace: "hmyv2", Version: "1.0", Service: apiv2.NewPublicHarmonyAPI(b), Public: true, }, { Namespace: "hmyv2", Version: "1.0", Service: apiv2.NewPublicBlockChainAPI(b), Public: true, }, { Namespace: "hmyv2", Version: "1.0", Service: apiv2.NewPublicTransactionPoolAPI(b, nonceLockV2), Public: true, }, { Namespace: "hmyv2", Version: "1.0", Service: apiv2.NewPublicAccountAPI(b.AccountManager()), Public: true, }, { Namespace: "hmyv2", Version: "1.0", Service: apiv2.NewDebugAPI(b), Public: true, // FIXME: change to false once IPC implemented }, } }