Documentation ¶
Overview ¶
Package etherscan provides Go bindings to the Etherscan.io API.
This work is a nearly Full implementation (accounts, transactions, tokens, contracts, blocks, stats), with full network support(Mainnet, Ropsten, Kovan, Rinkby, Tobalaba), and only depending on standard library.
Example can be found at https://github.com/nanmu42/etherscan-api
Index ¶
- Variables
- type AccountBalance
- type BigInt
- type BlockRewards
- type Client
- func (c *Client) AccountBalance(address string) (balance *BigInt, err error)
- func (c *Client) BlockNumber(timestamp int64, closest string) (blockNumber int, err error)
- func (c *Client) BlockReward(blockNum int) (rewards BlockRewards, err error)
- func (c *Client) BlocksMinedByAddress(address string, page int, offset int) (mined []MinedBlock, err error)
- func (c *Client) ContractABI(address string) (abi string, err error)
- func (c *Client) ContractSource(address string) (source []ContractSource, err error)
- func (c *Client) ERC1155Transfers(contractAddress, address *string, startBlock *int, endBlock *int, page int, ...) (txs []ERC1155Transfer, err error)
- func (c *Client) ERC20Transfers(contractAddress, address *string, startBlock *int, endBlock *int, page int, ...) (txs []ERC20Transfer, err error)
- func (c *Client) ERC721Transfers(contractAddress, address *string, startBlock *int, endBlock *int, page int, ...) (txs []ERC721Transfer, err error)
- func (c *Client) EtherLatestPrice() (price LatestPrice, err error)
- func (c *Client) EtherTotalSupply() (totalSupply *BigInt, err error)
- func (c *Client) ExecutionStatus(txHash string) (status ExecutionStatus, err error)
- func (c *Client) GasEstimate(gasPrice int) (confirmationTimeInSec time.Duration, err error)
- func (c *Client) GasOracle() (gasPrices GasPrices, err error)
- func (c *Client) GetLogs(fromBlock, toBlock int, address, topic string) (logs []Log, err error)
- func (c *Client) InternalTxByAddress(address string, startBlock *int, endBlock *int, page int, offset int, ...) (txs []InternalTx, err error)
- func (c *Client) MultiAccountBalance(addresses ...string) (balances []AccountBalance, err error)
- func (c *Client) NormalTxByAddress(address string, startBlock *int, endBlock *int, page int, offset int, ...) (txs []NormalTx, err error)
- func (c *Client) ReceiptStatus(txHash string) (receiptStatus int, err error)
- func (c *Client) TokenBalance(contractAddress, address string) (balance *BigInt, err error)
- func (c *Client) TokenTotalSupply(contractAddress string) (totalSupply *BigInt, err error)
- func (c *Client) UnclesMinedByAddress(address string, page int, offset int) (mined []MinedBlock, err error)
- type ContractSource
- type Customization
- type ERC1155Transfer
- type ERC20Transfer
- type ERC721Transfer
- type Envelope
- type ExecutionStatus
- type GasPrices
- type InternalTx
- type LatestPrice
- type Log
- type M
- type MinedBlock
- type Network
- type NormalTx
- type Time
Constants ¶
This section is empty.
Variables ¶
var ErrPreByzantiumTx = errors.New("pre-byzantium transaction does not support receipt status check")
ErrPreByzantiumTx transaction before 4,370,000 does not support receipt status check
Functions ¶
This section is empty.
Types ¶
type AccountBalance ¶
AccountBalance account and its balance in pair
type BigInt ¶
BigInt is a wrapper over big.Int to implement only unmarshalText for json decoding.
func (*BigInt) MarshalText ¶
MarshalText implements the encoding.TextMarshaler
func (*BigInt) UnmarshalText ¶
UnmarshalText implements the encoding.TextUnmarshaler interface.
type BlockRewards ¶
type BlockRewards struct { BlockNumber int `json:"blockNumber,string"` TimeStamp Time `json:"timeStamp"` BlockMiner string `json:"blockMiner"` BlockReward *BigInt `json:"blockReward"` Uncles []struct { Miner string `json:"miner"` UnclePosition int `json:"unclePosition,string"` BlockReward *BigInt `json:"blockreward"` } `json:"uncles"` UncleInclusionReward *BigInt `json:"uncleInclusionReward"` }
BlockRewards holds info from query for block and uncle rewards
type Client ¶
type Client struct { // Verbose when true, talks a lot Verbose bool // BeforeRequest runs before every client request, in the same goroutine. // May be used in rate limit. // Request will be aborted, if BeforeRequest returns non-nil err. BeforeRequest func(module, action string, param map[string]interface{}) error // AfterRequest runs after every client request, even when there is an error. AfterRequest func(module, action string, param map[string]interface{}, outcome interface{}, requestErr error) // contains filtered or unexported fields }
Client etherscan API client Clients are safe for concurrent use by multiple goroutines.
func NewCustomized ¶
func NewCustomized(config Customization) *Client
NewCustomized initialize a customized API client, useful when calling against etherscan-family API like BscScan.
func (*Client) AccountBalance ¶
AccountBalance gets ether balance for a single address
func (*Client) BlockNumber ¶
BlockNumber gets the closest block number by UNIX timestamp
valid closest option: before, after
func (*Client) BlockReward ¶
func (c *Client) BlockReward(blockNum int) (rewards BlockRewards, err error)
BlockReward gets block and uncle rewards by block number
func (*Client) BlocksMinedByAddress ¶
func (c *Client) BlocksMinedByAddress(address string, page int, offset int) (mined []MinedBlock, err error)
BlocksMinedByAddress gets list of blocks mined by address
func (*Client) ContractABI ¶
ContractABI gets contract abi for verified contract source codes
func (*Client) ContractSource ¶
func (c *Client) ContractSource(address string) (source []ContractSource, err error)
ContractSource gets contract source code for verified contract source codes
func (*Client) ERC1155Transfers ¶
func (c *Client) ERC1155Transfers(contractAddress, address *string, startBlock *int, endBlock *int, page int, offset int, desc bool) (txs []ERC1155Transfer, err error)
ERC1155Transfers get a list of "erc1155 - token transfer events" by contract address and/or from/to address.
leave undesired condition to nil.
func (*Client) ERC20Transfers ¶
func (c *Client) ERC20Transfers(contractAddress, address *string, startBlock *int, endBlock *int, page int, offset int, desc bool) (txs []ERC20Transfer, err error)
ERC20Transfers get a list of "erc20 - token transfer events" by contract address and/or from/to address.
leave undesired condition to nil.
Note on a Etherscan bug: Some ERC20 contract does not have valid decimals information in Etherscan. When that happens, TokenName, TokenSymbol are empty strings, and TokenDecimal is 0.
More information can be found at: https://github.com/nanmu42/etherscan-api/issues/8
func (*Client) ERC721Transfers ¶
func (c *Client) ERC721Transfers(contractAddress, address *string, startBlock *int, endBlock *int, page int, offset int, desc bool) (txs []ERC721Transfer, err error)
ERC721Transfers get a list of "erc721 - token transfer events" by contract address and/or from/to address.
leave undesired condition to nil.
func (*Client) EtherLatestPrice ¶
func (c *Client) EtherLatestPrice() (price LatestPrice, err error)
EtherLatestPrice gets the latest ether price, in BTC and USD
func (*Client) EtherTotalSupply ¶
EtherTotalSupply gets total supply of ether
func (*Client) ExecutionStatus ¶
func (c *Client) ExecutionStatus(txHash string) (status ExecutionStatus, err error)
ExecutionStatus checks contract execution status (if there was an error during contract execution)
note on IsError: 0 = pass, 1 = error
func (*Client) GasEstimate ¶
GasEstiamte gets estiamted confirmation time (in seconds) at the given gas price
func (*Client) GetLogs ¶
GetLogs gets logs that match "topic" emitted by the specified "address" between the "fromBlock" and "toBlock"
func (*Client) InternalTxByAddress ¶
func (c *Client) InternalTxByAddress(address string, startBlock *int, endBlock *int, page int, offset int, desc bool) (txs []InternalTx, err error)
InternalTxByAddress gets a list of "internal" transactions by address
startBlock and endBlock can be nil
if desc is true, result will be sorted in descendant order.
func (*Client) MultiAccountBalance ¶
func (c *Client) MultiAccountBalance(addresses ...string) (balances []AccountBalance, err error)
MultiAccountBalance gets ether balance for multiple addresses in a single call
func (*Client) NormalTxByAddress ¶
func (c *Client) NormalTxByAddress(address string, startBlock *int, endBlock *int, page int, offset int, desc bool) (txs []NormalTx, err error)
NormalTxByAddress gets a list of "normal" transactions by address
startBlock and endBlock can be nil
if desc is true, result will be sorted in blockNum descendant order.
func (*Client) ReceiptStatus ¶
ReceiptStatus checks transaction receipt status
only applicable for post byzantium fork transactions, i.e. after block 4,370,000
An special err ErrPreByzantiumTx raises for the transaction before byzantium fork.
Note: receiptStatus: 0 = Fail, 1 = Pass.
func (*Client) TokenBalance ¶
TokenBalance get erc20-token account balance of address for contractAddress
func (*Client) TokenTotalSupply ¶
TokenTotalSupply gets total supply of token on specified contract address
func (*Client) UnclesMinedByAddress ¶
func (c *Client) UnclesMinedByAddress(address string, page int, offset int) (mined []MinedBlock, err error)
UnclesMinedByAddress gets list of uncles mined by address
type ContractSource ¶
type ContractSource struct { SourceCode string `json:"SourceCode"` ABI string `json:"ABI"` ContractName string `json:"ContractName"` CompilerVersion string `json:"CompilerVersion"` OptimizationUsed int `json:"OptimizationUsed,string"` Runs int `json:"Runs,string"` ConstructorArguments string `json:"ConstructorArguments"` EVMVersion string `json:"EVMVersion"` Library string `json:"Library"` LicenseType string `json:"LicenseType"` Proxy string `json:"Proxy"` Implementation string `json:"Implementation"` SwarmSource string `json:"SwarmSource"` }
ContractSource holds info from query for contract source code
type Customization ¶
type Customization struct { // Timeout for API call Timeout time.Duration // API key applied from Etherscan Key string // Base URL like `https://api.etherscan.io/api?` BaseURL string // When true, talks a lot Verbose bool // HTTP Client to be used. Specifying this value will ignore the Timeout value set // Set your own timeout. Client *http.Client // BeforeRequest runs before every client request, in the same goroutine. // May be used in rate limit. // Request will be aborted, if BeforeRequest returns non-nil err. BeforeRequest func(module, action string, param map[string]interface{}) error // AfterRequest runs after every client request, even when there is an error. AfterRequest func(module, action string, param map[string]interface{}, outcome interface{}, requestErr error) }
Customization is used in NewCustomized()
type ERC1155Transfer ¶
type ERC1155Transfer struct { BlockNumber int64 `json:"blockNumber,string"` TimeStamp Time `json:"timeStamp"` Hash string `json:"hash"` Nonce int64 `json:"nonce,string"` BlockHash string `json:"blockHash"` From string `json:"from"` ContractAddress string `json:"contractAddress"` To string `json:"to"` TokenID *BigInt `json:"tokenID"` TokenName string `json:"tokenName"` TokenSymbol string `json:"tokenSymbol"` TokenDecimal uint8 `json:"tokenDecimal,string"` TokenValue uint8 `json:"tokenValue,string"` TransactionIndex int `json:"transactionIndex,string"` Gas int64 `json:"gas,string"` GasPrice *BigInt `json:"gasPrice"` GasUsed int64 `json:"gasUsed,string"` CumulativeGasUsed int64 `json:"cumulativeGasUsed,string"` Input string `json:"input"` Confirmations int `json:"confirmations,string"` }
ERC1155Transfer holds info from ERC1155 token transfer event query
type ERC20Transfer ¶
type ERC20Transfer struct { BlockNumber int64 `json:"blockNumber,string"` TimeStamp Time `json:"timeStamp"` Hash string `json:"hash"` Nonce int64 `json:"nonce,string"` BlockHash string `json:"blockHash"` From string `json:"from"` ContractAddress string `json:"contractAddress"` To string `json:"to"` Value *BigInt `json:"value"` TokenName string `json:"tokenName"` TokenSymbol string `json:"tokenSymbol"` TokenDecimal uint8 `json:"tokenDecimal,string"` TransactionIndex int `json:"transactionIndex,string"` Gas int64 `json:"gas,string"` GasPrice *BigInt `json:"gasPrice"` GasUsed int64 `json:"gasUsed,string"` CumulativeGasUsed int64 `json:"cumulativeGasUsed,string"` Input string `json:"input"` Confirmations int `json:"confirmations,string"` }
ERC20Transfer holds info from ERC20 token transfer event query
type ERC721Transfer ¶
type ERC721Transfer struct { BlockNumber int64 `json:"blockNumber,string"` TimeStamp Time `json:"timeStamp"` Hash string `json:"hash"` Nonce int64 `json:"nonce,string"` BlockHash string `json:"blockHash"` From string `json:"from"` ContractAddress string `json:"contractAddress"` To string `json:"to"` TokenID *BigInt `json:"tokenID"` TokenName string `json:"tokenName"` TokenSymbol string `json:"tokenSymbol"` TokenDecimal uint8 `json:"tokenDecimal,string"` TransactionIndex int `json:"transactionIndex,string"` Gas int64 `json:"gas,string"` GasPrice *BigInt `json:"gasPrice"` GasUsed int64 `json:"gasUsed,string"` CumulativeGasUsed int64 `json:"cumulativeGasUsed,string"` Input string `json:"input"` Confirmations int `json:"confirmations,string"` }
ERC721Transfer holds info from ERC721 token transfer event query
type Envelope ¶
type Envelope struct { // 1 for good, 0 for error Status int `json:"status,string"` // OK for good, other words when Status equals 0 Message string `json:"message"` // where response lies Result json.RawMessage `json:"result"` }
Envelope is the carrier of nearly every response
type ExecutionStatus ¶
type ExecutionStatus struct { // 0 = pass, 1 = error IsError int `json:"isError,string"` ErrDescription string `json:"errDescription"` }
ExecutionStatus holds info from query for transaction execution status
type GasPrices ¶
type GasPrices struct { LastBlock int SafeGasPrice float64 ProposeGasPrice float64 FastGasPrice float64 SuggestBaseFeeInGwei float64 `json:"suggestBaseFee"` GasUsedRatio []float64 `json:"gasUsedRatio"` }
GasPrices holds info for Gas Oracle queries Gas Prices are returned in Gwei
func (*GasPrices) UnmarshalJSON ¶
type InternalTx ¶
type InternalTx struct { BlockNumber int64 `json:"blockNumber,string"` TimeStamp Time `json:"timeStamp"` Hash string `json:"hash"` From string `json:"from"` To string `json:"to"` Value *BigInt `json:"value"` ContractAddress string `json:"contractAddress"` Input string `json:"input"` Type string `json:"type"` Gas int64 `json:"gas,string"` GasUsed int64 `json:"gasUsed,string"` TraceID string `json:"traceId"` IsError int `json:"isError,string"` ErrCode string `json:"errCode"` }
InternalTx holds info from internal tx query
type LatestPrice ¶
type LatestPrice struct { ETHBTC float64 `json:"ethbtc,string"` ETHBTCTimestamp Time `json:"ethbtc_timestamp"` ETHUSD float64 `json:"ethusd,string"` ETHUSDTimestamp Time `json:"ethusd_timestamp"` }
LatestPrice holds info from query for latest ether price
type MinedBlock ¶
type MinedBlock struct { BlockNumber int `json:"blockNumber,string"` TimeStamp Time `json:"timeStamp"` BlockReward *BigInt `json:"blockReward"` }
MinedBlock holds info from query for mined block by address
type Network ¶
type Network string
Network is ethereum network type (mainnet, ropsten, etc)
const ( // Mainnet Ethereum mainnet for production Mainnet Network = "api" // Ropsten Testnet(POW) Ropsten Network = "api-ropsten" // Kovan Testnet(POA) Kovan Network = "api-kovan" // Rinkby Testnet(CLIQUE) Rinkby Network = "api-rinkeby" // Goerli Testnet(CLIQUE) Goerli Network = "api-goerli" // Tobalaba Testnet Tobalaba Network = "api-tobalaba" )
type NormalTx ¶
type NormalTx struct { BlockNumber int64 `json:"blockNumber,string"` TimeStamp Time `json:"timeStamp"` Hash string `json:"hash"` Nonce int `json:"nonce,string"` BlockHash string `json:"blockHash"` TransactionIndex int `json:"transactionIndex,string"` From string `json:"from"` To string `json:"to"` Value *BigInt `json:"value"` Gas int64 `json:"gas,string"` GasPrice *BigInt `json:"gasPrice"` IsError int `json:"isError,string"` TxReceiptStatus string `json:"txreceipt_status"` Input string `json:"input"` ContractAddress string `json:"contractAddress"` CumulativeGasUsed int64 `json:"cumulativeGasUsed,string"` GasUsed int64 `json:"gasUsed,string"` Confirmations int `json:"confirmations,string"` MethodId string `json:"methodId"` FunctionName string `json:"functionName"` }
NormalTx holds info from normal tx query
type Time ¶
Time is a wrapper over big.Int to implement only unmarshalText for json decoding.
func (Time) MarshalText ¶
MarshalText implements the encoding.TextMarshaler
func (*Time) UnmarshalText ¶
UnmarshalText implements the encoding.TextUnmarshaler interface.