Secrets experimental
Because env vars in mise.toml can store sensitive information, mise has built-in support for reading encrypted secrets from files. Currently, this is done with a sops implementation however other secret backends could be added in the future.
Secrets are .env.(json|yaml|toml)
files with a simple structure, for example:
{
"AWS_ACCESS_KEY_ID": "AKIAIOSFODNN7EXAMPLE",
"AWS_SECRET_ACCESS_KEY": "wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY"
}
Env vars from this can be imported into a mise config with the following:
[env]
_.file = ".env.json"
mise will automatically use a secret backend like sops if the file is encrypted.
sops
mise uses the rust rops library to interact with sops files. If you encrypt a sops file, mise will automatically decrypt it when reading the file. sops files can be in json, yaml, or toml format—however if you want to use toml you'll need to use the rops cli instead of sops. Otherwise, either sops or rops will work fine.
INFO
Currently age is the only sops encryption method supported.
In order to encrypt a file with sops, you'll first need to install it (mise use -g sops
). You'll also need to install age (mise use -g age
) to generate a keypair for sops to use if you have not already done so.
To generate a keypair with age run the following and note the public key that is output to use in the next command to sops
:
$ age-keygen -o ~/.config/mise/age.txt
Public key: <public key>
Assuming we have a .env.json
file like at the top of this doc, we can now encrypt it with sops:
sops encrypt -i --age "<public key>" .env.json
TIP
The -i
here overwrites the file with an encrypted version. This encrypted version is safe to commit into your repo as without the private key (~/.config/mise/age.txt
in this case) the file is useless.
You can later decrypt the file with sops decrypt -i .env.json
or edit it in EDITOR with sops edit .env.json
. However, you'll first need to set SOPS_AGE_KEY_FILE to ~/.config/mise/age.txt
to decrypt the file.
Lastly, we need to add the file to our mise config which can be done with mise set _.file=.env.json
.
Now when you run mise env
you should see the env vars from the file:
$ mise env
export AWS_ACCESS_KEY_ID=AKIAIOSFODNN7EXAMPLE
export AWS_SECRET_ACCESS_KEY=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
sops
Settings
sops.age_key
- Type:
string
(optional) - Env:
MISE_SOPS_AGE_KEY
- Default:
None
The age private key to use for sops secret decryption.
sops.age_key_file
- Type:
Path
- Env:
MISE_SOPS_AGE_KEY_FILE
- Default:
~/.config/mise/age.txt
Path to the age private key file to use for sops secret decryption.
sops.age_recipients
- Type:
string
(optional) - Env:
MISE_SOPS_AGE_RECIPIENTS
- Default:
None
The age public keys to use for sops secret encryption.
sops.rops
- Type:
Bool
- Env:
MISE_SOPS_ROPS
- Default:
true
Use rops to decrypt sops files. Disable to shell out to sops
which will slow down mise but sops may offer features not available in rops.