Documentation ¶
Index ¶
- func GetCustomNetworkClient(URL string) (client *ethclient.Client, err error)
- func GetCustomNetworkClientWebsocket(URL string) (client *ethclient.Client, err error)
- func GetKeyedTransactor(client *ethclient.Client, increaseNonceFactor int) (transactor *bind.TransactOpts, err error)
- func GetKeyedTransactorWithOptions(client *ethclient.Client, increaseNonceFactor int, txValue int, ...) (transactor *bind.TransactOpts, err error)
- func GetMockBlockchain() (auth *bind.TransactOpts, backend *backends.SimulatedBackend, ...)
- func GetNonceNumber(client *ethclient.Client, pubkey ecdsa.PublicKey) (nonce uint64, err error)
- func GetPubKey(accountPrivateKey *ecdsa.PrivateKey) (publicKeyECDSA *ecdsa.PublicKey, address common.Address, err error)
- func GetRinkebyClient() (client *ethclient.Client, err error)
- func GetRinkebyClientWebsocket() (client *ethclient.Client, err error)
- func GetTransactionResult(client *ethclient.Client, trx common.Hash, maxAttempts int, interval int) (txReceipt *types.Receipt, err error)
- func NewAccount() (accountPrivateKey *ecdsa.PrivateKey, address common.Address)
- func SendEther(client *ethclient.Client, senderPrivateKey *ecdsa.PrivateKey, ...) (signedTx *types.Transaction, err error)
- func SubLogs(addressToWatch common.Address, wg *sync.WaitGroup)
- func UpdateKeyedTransactor(transactor *bind.TransactOpts, backend *backends.SimulatedBackend, ...) (err error)
- func WaitForTransactionProcessing(client *ethclient.Client, trx *types.Transaction, maxAttempts int, ...) (txReceipt *types.Receipt, err error)
- type KeystoreWallet
- func (w *KeystoreWallet) GenerateSignedTxAsJSON(txOpts *bind.TransactOpts, passphrase string, contractMethodParameters []byte, ...) (txJSON []byte, err error)
- func (w *KeystoreWallet) GetNonceNumber(client *ethclient.Client) (nonce uint64, err error)
- func (w *KeystoreWallet) NewKeyStoreTransactor(passphrase string) (*bind.TransactOpts, error)
- func (w *KeystoreWallet) SignData(mimeType string, data []byte) ([]byte, error)
- func (w *KeystoreWallet) SignTextWithPassphrase(passphrase string, text []byte) ([]byte, error)
- func (w *KeystoreWallet) SignTxWithPassphrase(passphrase string, tx *types.Transaction, chainID *big.Int) (*types.Transaction, error)
- func (w *KeystoreWallet) URL() accounts.URL
- func (w *KeystoreWallet) UpdateKeyedTransactor(transactor *bind.TransactOpts, client *ethclient.Client, ...) (err error)
- type TxData
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func GetCustomNetworkClient ¶
GetCustomNetworkClient connects and return a client to user defined Ethereum network
func GetCustomNetworkClientWebsocket ¶
GetCustomNetworkClientWebsocket connects via websocket and return a client to user defined Ethereum network
func GetKeyedTransactor ¶
func GetKeyedTransactor(client *ethclient.Client, increaseNonceFactor int) (transactor *bind.TransactOpts, err error)
GetKeyedTransactor gets a keyed (signed?) transctor do perform a transaction within the Ethereum Blockchain
func GetKeyedTransactorWithOptions ¶
func GetKeyedTransactorWithOptions(client *ethclient.Client, increaseNonceFactor int, txValue int, pvtkey *ecdsa.PrivateKey) (transactor *bind.TransactOpts, err error)
GetKeyedTransactorWithOptions gets a keyed (signed?) transactor to perform a transaction within the Ethereum Blockchain
func GetMockBlockchain ¶
func GetMockBlockchain() (auth *bind.TransactOpts, backend *backends.SimulatedBackend, coinbaseAccountPrivateKey *ecdsa.PrivateKey)
GetMockBlockchain get a "in-memory" Blockchain instance
func GetNonceNumber ¶
GetNonceNumber gets actual nonce number of an Ethereum address/account
func GetPubKey ¶
func GetPubKey(accountPrivateKey *ecdsa.PrivateKey) (publicKeyECDSA *ecdsa.PublicKey, address common.Address, err error)
GetPubKey gets public key and address from a private key
func GetRinkebyClient ¶
GetRinkebyClient connects and return a client to the Rinkeby Ethereum network
func GetRinkebyClientWebsocket ¶
GetRinkebyClientWebsocket connects via websocket and return a client to the Rinkeby Ethereum network
func GetTransactionResult ¶
func GetTransactionResult(client *ethclient.Client, trx common.Hash, maxAttempts int, interval int) (txReceipt *types.Receipt, err error)
GetTransactionResult check trx mining and return his results
func NewAccount ¶
func NewAccount() (accountPrivateKey *ecdsa.PrivateKey, address common.Address)
NewAccount generates new Ethereum address/account
func SendEther ¶
func SendEther(client *ethclient.Client, senderPrivateKey *ecdsa.PrivateKey, to common.Address, value int64) (signedTx *types.Transaction, err error)
SendEther an example that shows how to send ether from an account to another using Go (Golang)
func UpdateKeyedTransactor ¶
func UpdateKeyedTransactor(transactor *bind.TransactOpts, backend *backends.SimulatedBackend, increaseNonceFactor int, valueToSend int) (err error)
UpdateKeyedTransactor updates a keyed (signed?) transctor do perform a transaction within a Simulated Ethereum Blockchain
Types ¶
type KeystoreWallet ¶
type KeystoreWallet struct { Account accounts.Account // Single account contained in this wallet Keystore *keystore.KeyStore // Keystore where the account originates from Wallet accounts.Wallet }
KeystoreWallet implements the accounts.Wallet interface for the original
func NewKeystoreWallet ¶
func NewKeystoreWallet(ks *keystore.KeyStore, accountHex string) (ksw *KeystoreWallet, err error)
NewKeystoreWallet returns new instance of KeystoreWallet
func (*KeystoreWallet) GenerateSignedTxAsJSON ¶ added in v0.1.1
func (w *KeystoreWallet) GenerateSignedTxAsJSON( txOpts *bind.TransactOpts, passphrase string, contractMethodParameters []byte, smartContractAddress common.Address, nonce, chainID uint64) (txJSON []byte, err error)
GenerateSignedTxAsJSON generates a JSON signed raw Ethereum Transaction
func (*KeystoreWallet) GetNonceNumber ¶
func (w *KeystoreWallet) GetNonceNumber(client *ethclient.Client) (nonce uint64, err error)
GetNonceNumber gets actual nonce number of an Ethereum address/account
func (*KeystoreWallet) NewKeyStoreTransactor ¶
func (w *KeystoreWallet) NewKeyStoreTransactor(passphrase string) (*bind.TransactOpts, error)
NewKeyStoreTransactor is a utility method to easily create a transaction signer from an decrypted key from a keystore
func (*KeystoreWallet) SignData ¶
func (w *KeystoreWallet) SignData(mimeType string, data []byte) ([]byte, error)
SignData signs keccak256(data). The mimetype parameter describes the type of data being signed
func (*KeystoreWallet) SignTextWithPassphrase ¶
func (w *KeystoreWallet) SignTextWithPassphrase(passphrase string, text []byte) ([]byte, error)
SignTextWithPassphrase implements accounts.Wallet, attempting to sign the given hash with the given account using passphrase as extra authentication.
func (*KeystoreWallet) SignTxWithPassphrase ¶
func (w *KeystoreWallet) SignTxWithPassphrase(passphrase string, tx *types.Transaction, chainID *big.Int) (*types.Transaction, error)
SignTxWithPassphrase implements accounts.Wallet, attempting to sign the given transaction with the given account using passphrase as extra authentication.
func (*KeystoreWallet) URL ¶
func (w *KeystoreWallet) URL() accounts.URL
URL implements accounts.Wallet, returning the URL of the account within.
func (*KeystoreWallet) UpdateKeyedTransactor ¶
func (w *KeystoreWallet) UpdateKeyedTransactor(transactor *bind.TransactOpts, client *ethclient.Client, increaseNonceFactor int, valueToSend int) (err error)
UpdateKeyedTransactor updates a keyed (signed?) transctor do perform a transaction within a Simulated Ethereum Blockchain
type TxData ¶ added in v0.1.1
type TxData struct { AccountNonce uint64 `json:"nonce" gencodec:"required"` Price *big.Int `json:"gasPrice" gencodec:"required"` GasLimit uint64 `json:"gas" gencodec:"required"` Recipient *common.Address `json:"to" rlp:"nil"` // nil means contract creation Amount *big.Int `json:"value" gencodec:"required"` Payload []byte `json:"input" gencodec:"required"` // Signature values V *big.Int `json:"v" gencodec:"required"` R *big.Int `json:"r" gencodec:"required"` S *big.Int `json:"s" gencodec:"required"` // This is only used when marshaling to JSON. Hash *common.Hash `json:"hash" rlp:"-"` }
TxData represents an Ethereum raw transaction data