Documentation ¶
Overview ¶
Copyright 2020 ChainSafe Systems SPDX-License-Identifier: LGPL-3.0-only
The ethereum package contains the logic for interacting with ethereum chains.
There are 3 major components: the connection, the listener, and the writer. The currently supported transfer types are Fungible (ERC20), Non-Fungible (ERC721), and generic.
Connection ¶
The connection contains the ethereum RPC client and can be accessed by both the writer and listener.
Listener ¶
The listener polls for each new block and looks for deposit events in the bridge contract. If a deposit occurs, the listener will fetch additional information from the handler before constructing a message and forwarding it to the router.
Writer ¶
The writer recieves the message and creates a proposals on-chain. Once a proposal is made, the writer then watches for a finalization event and will attempt to execute the proposal if a matching event occurs. The writer skips over any proposals it has already seen.
Index ¶
- Constants
- Variables
- func ConstructErc20ProposalData(amount []byte, recipient []byte) []byte
- func ConstructErc721ProposalData(tokenId []byte, recipient []byte, metadata []byte) []byte
- func ConstructGenericProposalData(metadata []byte) []byte
- func NewListener(conn Connection, cfg *Config, log log15.Logger, bs blockstore.Blockstorer, ...) *listener
- func NewWriter(conn Connection, cfg *Config, log log15.Logger, kp secp256k1.Keypair, ...) *writer
- type Chain
- type Config
- type Connection
Constants ¶
const DefaultBlockConfirmations = 10
const DefaultGasLimit = 6721975
const DefaultGasMultiplier = 1
const DefaultGasPrice = 20000000000
const ExecuteBlockWatchLimit = 100
Number of blocks to wait for an finalization event
const TxRetryInterval = time.Second * 2
Time between retrying a failed tx
const TxRetryLimit = 10
Maximum number of tx retries before exiting
Variables ¶
var ( AssetOpt = "asset" BridgeOpt = "bridge" Erc20HandlerOpt = "erc20Handler" Erc721HandlerOpt = "erc721Handler" GenericHandlerOpt = "genericHandler" InternalAccount = "internalAccount" MaxGasPriceOpt = "maxGasPrice" GasLimitOpt = "gasLimit" GasMultiplier = "gasMultiplier" HttpOpt = "http" StartBlockOpt = "startBlock" EndBlockOpt = "endBlock" BlockConfirmationsOpt = "blockConfirmations" PrefixOpt = "prefix" NetworkIdOpt = "networkId" )
Chain specific options
var BlockRetryInterval = time.Second * 5
var BlockRetryLimit = 15
var CancelledStatus uint8 = 4
var ErrNonceTooLow = errors.New("nonce too low")
var ErrTxUnderpriced = errors.New("replacement transaction underpriced")
var PassedStatus uint8 = 2
var TransferredStatus uint8 = 3
Functions ¶
func ConstructErc20ProposalData ¶
constructErc20ProposalData returns the bytes to construct a proposal suitable for Erc20
func ConstructErc721ProposalData ¶
constructErc721ProposalData returns the bytes to construct a proposal suitable for Erc721
func ConstructGenericProposalData ¶
constructGenericProposalData returns the bytes to construct a generic proposal
func NewListener ¶
func NewListener(conn Connection, cfg *Config, log log15.Logger, bs blockstore.Blockstorer, stop <-chan int, sysErr chan<- error, m *metrics.ChainMetrics) *listener
NewListener creates and returns a listener
Types ¶
type Chain ¶
type Chain struct {
// contains filtered or unexported fields
}
func InitializeChain ¶
func InitializeChain(chainCfg *core.ChainConfig, logger log15.Logger, sysErr chan<- error, m *metrics.ChainMetrics) (*Chain, error)
func (*Chain) LatestBlock ¶
func (c *Chain) LatestBlock() metrics.LatestBlock
type Config ¶
type Config struct {
// contains filtered or unexported fields
}
Config encapsulates all necessary parameters in ethereum compatible forms
type Connection ¶
type Connection interface { GetEndPoint() string Connect() error Reconnect(endpoint string) error Keypair() *secp256k1.Keypair Opts() *bind.TransactOpts CallOpts() *bind.CallOpts LockAndUpdateOpts() error UnlockOpts() Client() *ethclient.Client EnsureHasBytecode(address common.Address) error LatestBlock() (*big.Int, error) WaitForBlock(block *big.Int, delay *big.Int) error Close() }