While most of the commands will be specified via command-line flags, it would be very
tedious to pass in all configuration options every time. Thus, we allow 3 ways to configure
most items - config file (app.yaml
), environmental variables, and command line flags. With the
later taking precedence over the former. Environmental variables will all begin with RELAYER_
for both binaries.
All files will be looked for relative to a "home" directory. As this is meant to be run
as a daemon (unix service), the default home directory for ibc-relayer
will be /etc/relayer.d
.
On the other hand, the user-focused ibc-setup
will default to $HOME/.ibc-setup
as the "home"
directory.
This may be overriden via the RELAYER_HOME
env variable, or --home
CLI flag.
The principle config file is registry.yaml
, which is a required file and is encoded
in yaml format. It contains all the chain-specific information needed to connect to the chains.
They are all considered to be Cosmos SDK chains and compatible with 0.41. We may make changes
in a future version (thus all files are versioned as 1).
version: 1
chains:
malaga:
chain_id: malaga-420
# Bech32 prefix for addresses
prefix: wasm
# This determines the gas payments we make (and defines the fee token)
gas_price: 0.25umlg
# this defines the gas limits we are going to use
gas_limits:
# max amount of gas to be used when performing client init transactions
init_client: 150000
# # max amount of gas to be used when performing client update transactions
update_client:
600000
# max amount of gas to be used when performing connection init transactions
init_connection:
150000
# max amount of gas to be used when performing connection handshakes transactions
connection_handshake:
300000
# max amount of gas to be used when performing channel init transactions
init_channel:
150000
# max amount of gas to be used when performing channel handshakes transactions
channel_handshake:
300000
# max amount of gas to be used when receiving packets
receive_packet:
300000
# max amount of gas to be used when receiving acknowledgments
ack_packet:
300000
# max amount of gas to be used when receiving timeout packets
timeout_packet:
300000
# max amount of gas to be used when performing transfer transactions
transfer: 180000
# the path we use to derive the private key from the mnemonic
hd_path: 44'/108'/0'/1'
# If you include an optional faucet, it will load the relayer with tokens in `ibc-setup init`
faucet: https://faucet.malaga-420.cosmwasm.com
# you can include multiple RPC endpoints and it will rotate through them if
# one is down
rpc:
- https://rpc.malaga-420.cosmwasm.com
bifrost:
# ...
The chains variable is a lookup based on human-friendly chain names (can be different that the chain_id). It should contain all needed info to configure a relayer connection to that chain.
In addition to the required registry.yaml
, there is an optional app.yaml
file that is used as a fall back
for any environmental variable. Unless otherwise specified, all command line flags can be defined either
as environmental variables or in app.yaml
. If they are not defined in any of these places, this will raise an error.
There is a simple pattern for this. Take two examples:
- CLI flags:
--src
and--log-level
- Env Vars (Prefix
RELAYER_
, use_
not-
):RELAYER_SRC
andRELAYER_LOG_LEVEL
app.yaml
(Same name as flag, but using_
not-
):src:
andlog_level:
Every command will need to know what chains to connect to. The registry file may contain dozens of different chains and be reused by validators making various connections. We just need to pass in a pair of names to each command, so it can look up all needed configuration.
--src=musselnet
and --dest=bifrost
will define the two chains to connect to, as well as the direction.
If creating a connection/channel, we init on the "src" side. If relaying packets, we may relay packets from
one chain to another (some configurations will be bi-directional).
As mentioned above, if a CLI flag is not found, we will check for an environmental variable, and ultimately app.yaml
.