This document describes how to configure and use the keyring and its various backends for an Injective node.
injectived should be installed prior to setting up the keyring. See the Install injectived page for more information.Available backends for the keyring
The os backend
The os backend relies on operating system-specific defaults to handle key storage securely. Typically, an operating system’s credential sub-system handles password prompts, private keys storage, and user sessions according to the user’s password policies. Here is a list of the most popular operating systems and their respective passwords manager:
- macOS (since Mac OS 8.6): Keychain
- Windows: Credentials Management API
- GNU/Linux:
libsecret convenient frontend, the latter is a kwallet client.
os is the default option since operating system’s default credentials managers are designed to meet users’ most common needs and provide them with a comfortable experience without compromising on security.
The recommended backends for headless environments are file and pass.
The file backend
The file stores the keyring encrypted within the app’s configuration directory. This keyring will request a password each time it is accessed, which may occur multiple times in a single command resulting in repeated password prompts. If using bash scripts to execute commands using the file option you may want to utilize the following format for multiple prompts:
The first time you add a key to an empty keyring, you will be prompted to type the password twice.
The pass backend
The pass backend uses the pass utility to manage on-disk encryption of keys’ sensitive data and metadata. Keys are stored inside gpg encrypted files within app-specific directories. pass is available for the most popular UNIX operating systems as well as GNU/Linux distributions. Please refer to its manual page for information on how to download and install it.
pass uses GnuPG for encryption. gpg automatically invokes the gpg-agent daemon upon execution, which handles the caching of GnuPG credentials. Please refer to gpg-agent man page for more information on how to configure cache parameters such as credentials TTL and passphrase expiration.<GPG_KEY_ID> with your GPG key ID. You can use your personal GPG key or an alternative one you may want to use specifically to encrypt the password store.
The kwallet backend
The kwallet backend uses KDE Wallet Manager, which comes installed by default on the GNU/Linux distributions that ships KDE as default desktop environment. Please refer to KWallet Handbook for more information.
The test backend
The test backend is a password-less variation of the file backend. Keys are stored unencrypted on disk.
Provided for testing purposes only. The test backend is not recommended for use in production environments.
The memory backend
The memory backend stores keys in memory. The keys are immediately deleted after the program has exited.
Provided for testing purposes only. The memory backend is not recommended for use in production environments.
Adding keys to the keyring
You can useinjectived keys for help about the keys command and injectived keys [command] --help for more information about a particular subcommand.
You can also enable auto-completion with the
injectived completion command. For example, at the start of a bash session, run . <(injectived completion), and all injectived subcommands will be auto-completed.add subcommand with a <key_name> argument. For the purpose of this tutorial, we will solely use the test backend, and call our new key my_validator. This key will be used in the next section.
eth_secp256k1 keypair. The keyring also supports ed25519 keys, which may be created by passing the --algo ed25519 flag. A keyring can of course hold both types of keys simultaneously.