Skip to main content
Version: v0.25

config.yml reference

The config.yml file generated in your blockchain folder uses key-value pairs to describe the development environment for your blockchain.

Only a default set of parameters is provided. If more nuanced configuration is required, you can add these parameters to the config.yml file.

accounts

A list of user accounts created during genesis of the blockchain.

KeyRequiredTypeDescription
nameYStringLocal name of a key pair. An account name must be listed to gain access to the account tokens after the blockchain is launched.
coinsYList of StringsInitial coins with denominations. For example, "1000token"
addressNStringAccount address in Bech32 address format.
mnemonicNStringMnemonic used to generate an account. This field is ignored if address is specified.

Note that you can only use address OR mnemonic for an account. You can't use both, because an address is derived from a mnemonic.

If an account is a validator account (alice by default), it cannot have an address field.

accounts example

accounts:
- name: alice
coins: ["1000token", "100000000stake"]
- name: bob
coins: ["500token"]
address: cosmos1adn9gxjmrc3hrsdx5zpc9sj2ra7kgqkmphf8yw

build

KeyRequiredTypeDescription
mainNStringWhen an app contains more than one main Go package, required to define the path of the chain's main package.
binaryNStringName of the node binary that is built, typically ends with d.
ldflagsNList of Stringsldflags to set version information for go applications.

build example

build:
binary: "mychaind"
ldflags: [ "-X main.Version=development", "-X main.Date=01/05/2022T19:54" ]

build.proto

KeyRequiredTypeDescription
pathNStringPath to protocol buffer files. Default: "proto".
third_party_pathsNList of StringsPath to third-party protocol buffer files. Default: ["third_party/proto", "proto_vendor"].

client

Configures and enables client code generation. To prevent Ignite CLI from regenerating the client, remove the client property.

client.vuex

client:
vuex:
path: "vue/src/store"

Generates Vuex stores for the blockchain in path on serve and build commands.

client.typescript

client:
typescript:
path: "vue/src/generated"

Generates TypeScript clients for the blockchain in path on serve and build commands.

client.openapi

client:
openapi:
path: "docs/static/openapi.yml"

Generates OpenAPI YAML file in path. By default this file is embedded in the node's binary.

faucet

The faucet service sends tokens to addresses. The default address for the web user interface is http://localhost:4500.

KeyRequiredTypeDescription
nameYStringName of a key pair. The name key pair must be in accounts.
coinsYList of StringsOne or more coins with denominations sent per request.
coins_maxNList of StringsOne or more maximum amounts of tokens sent for each address.
hostNStringHost and port number. Default: :4500. Cannot be higher than 65536
rate_limit_windowNStringTime after which the token limit is reset (in seconds).

faucet example

faucet:
name: faucet
coins: ["100token", "5foo"]
coins_max: ["2000token", "1000foo"]
port: 4500

validator

A blockchain requires one or more validators.

KeyRequiredTypeDescription
nameYStringThe account that is used to initialize the validator. The name key pair must be in accounts.
stakedYStringAmount of coins to bond. Must be less than or equal to the amount of coins in the account.

validator example

accounts:
- name: alice
coins: ["1000token", "100000000stake"]
validator:
name: user1
staked: "100000000stake"

init.home

The path to the data directory that stores blockchain data and blockchain configuration.

init example

init:
home: "~/.myblockchain"

init.config

Overwrites properties in config/config.toml in the data directory.

init.app

Overwrites properties in config/app.toml in the data directory.

init.client

Overwrites properties in config/client.toml in the data directory.

init.client example

init:
client:
keyring-backend: "os"

host

Configuration of host names and ports for processes started by Ignite CLI. Port numbers can't exceed 65536.

host example

host:
rpc: ":26659"
p2p: ":26658"
prof: ":6061"
grpc: ":9091"
api: ":1318"

genesis

Use to overwrite values in genesis.json in the data directory to test different values in development environments. See Genesis Overwrites for Development.