backend.go 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. // Copyright 2016 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. package bind
  17. import (
  18. "math/big"
  19. "github.com/ethereum/go-ethereum/common"
  20. "github.com/ethereum/go-ethereum/core/types"
  21. )
  22. // ContractCaller defines the methods needed to allow operating with contract on a read
  23. // only basis.
  24. type ContractCaller interface {
  25. // ContractCall executes an Ethereum contract call with the specified data as
  26. // the input. The pending flag requests execution against the pending block, not
  27. // the stable head of the chain.
  28. ContractCall(contract common.Address, data []byte, pending bool) ([]byte, error)
  29. }
  30. // ContractTransactor defines the methods needed to allow operating with contract
  31. // on a write only basis. Beside the transacting method, the remainder are helpers
  32. // used when the user does not provide some needed values, but rather leaves it up
  33. // to the transactor to decide.
  34. type ContractTransactor interface {
  35. // Nonce retrieves the current pending nonce associated with an account.
  36. AccountNonce(account common.Address) (uint64, error)
  37. // GasPrice retrieves the currently suggested gas price to allow a timely execution
  38. // of a transaction.
  39. GasPrice() (*big.Int, error)
  40. // GasLimit tries to estimate the gas needed to execute a specific transaction.
  41. GasLimit(sender common.Address, contract *common.Address, value *big.Int, data []byte) (*big.Int, error)
  42. // SendTransaction injects the transaction into the pending pool for execution.
  43. SendTransaction(*types.Transaction) error
  44. }
  45. // ContractBackend defines the methods needed to allow operating with contract
  46. // on a read-write basis.
  47. type ContractBackend interface {
  48. ContractCaller
  49. ContractTransactor
  50. }