Available in v0.11.0+.
Storing encrypted secrets next to your configuration (within a Git repo or other artifacts) is one way to manage secret lifecycle. kapp-controller integrates with Mozilla's SOPS to decrypt secret material in fetched configuration.
$ gpg --gen-key
...
$ gpg --list-secret-keys --keyid-format LONG
/root/.gnupg/secring.gpg
------------------------
sec 4096R/B464DFD255C6B9F8 2020-10-03
uid test test (test) <test@test.com>
ssb 4096R/FEE37B8E2098EDFC 2020-10-03
(Note: B464DFD255C6B9F8
is the ID to be used later)
kapp-controller expects that encrypted files have .sops.yml
extension (or .sops.yml
).
# Unencrypted file
$ cat secret.yml
apiVersion: v1
kind: Secret
metadata:
name: my-sec
data:
password: my-password
# Encrypt file to be later decrypted by kapp-controller
$ sops --encrypt --pgp B464DFD255C6B9F8 secret.yml > secret.sops.yml
# Delete unencrypted file
$ rm secret.yml
Extract PGP private key from your GPG installation and import into your Kubernetes cluster. It will be referenced by App CR.
$ gpg --armor --export-secret-keys B464DFD255C6B9F8 > my.pk
apiVersion: v1
kind: Secret
metadata:
name: pgp-key
namespace: default
stringData:
# value of this is contents of my.pk
my.pk: |
-----BEGIN PGP PRIVATE KEY BLOCK-----
Version: GnuPG v1
...
Configure App CR to decrypt contents. Assuming, in this example, your git repo contains secret.sops.yml
, it would be decrypted into secret.yml
file.
apiVersion: kappctrl.k14s.io/v1alpha1
kind: App
metadata:
name: config-with-sops
namespace: default
spec:
serviceAccountName: default-ns
fetch:
- git:
...
template:
- sops:
pgp:
privateKeysSecretRef:
name: pgp-key
- ytt: {}
deploy:
- kapp: {}
Next: Dangerous Flags