Skip to content

Latest commit

 

History

History
100 lines (76 loc) · 3.91 KB

README.md

File metadata and controls

100 lines (76 loc) · 3.91 KB

Vault KV updater

Simple, no-dependency golang application that optionally flattens and synchronizes a YAML formatted structure from an optionally SOPS encrypted stream (file or standard input), to a Vault KV secret.

Write operations on secrets are idempotent, they will not update secrets if no changes have been detected.

Pretty useful when used in conjunction with Spring Cloud Vault.

Supported Vault authentication methods:

  • kubernetes (default)
  • token

Roadmap

  • Unit tests (yeah I know..).
  • Integration tests with testContainers SDK.
  • Support for simple Vault token authentication mode.
  • Support for multiple files.
  • Opt-out flattening flag.
  • Support for more flattening modes.
  • Providing a useful CLI help.
  • Parallel execution? (go routines)
  • Vault API rate limiting.

Usage

Simple mode (single secret)
FLATTEN=false VAULT_KV_MOUNT=kv VAULT_KV_PATH=path/to/secret vault-kv-updater secret.yml
export VAULT_KV_MOUNT=kv
export VAULT_KV_PATH=path/to/secret
export VAULT_AUTH_METHOD=token
export VAULT_TOKEN=mytoken
cat secret.yml | vault-kv-updater
Autocomplete mode (multiple secrets)
export VAULT_KV_MOUNT=kv
export AUTO_COMPLETE=true
export VAULT_AUTH_K8S_ROLE=auth-role
vault-kv-updater some/directory other/directory
export VAULT_KV_MOUNT=kv
export AUTO_COMPLETE=true
export AUTO_COMPLETE_FILE_PREFIX="application-"
vault-kv-updater some/directory other/directory

Autocomplete mode

Autocomplete mode will automatically determine the secrets KV destination path based on the filenames.

A few environment variables are provided to give further control, such as adding a KV path destination prefix, or escaping a common secret name prefix from the filenames.

Supported file extensions are .yml and .yaml

Environment variables

Variable Optional Description defaults
VAULT_ADDR yes Vault endpoint address, including scheme and port "http://127.0.0.1:8200"
VAULT_AUTH_METHOD yes Vault authentication method (supported methods: token, kubernetes) kubernetes
VAULT_AUTH_K8S_MOUNT_PATH yes Authentication backend mount path "kubernetes"
VAULT_AUTH_K8S_ROLE no (when using kubernetes auth) Vault role to authenticate against
VAULT_TOKEN no (when using token auth)
VAULT_KV_PATH no (when not using autocomplete mode) Secret path, not including kv mount
VAULT_KV_MOUNT no Vault KV mount to synchronize secrets to
VAULT_CAPEM yes Vault CA certificate in PEM format
VAULT_CACERT yes Path to the vault CA file
VAULT_CAPATH yes Path to a directory of CA files (non-recursive) to use for TLS verification
VAULT_NAMESPACE yes Vault namespace (enterprise feature)
VAULT_TLS_SERVER_NAME yes Vault server hostname to verify against
VAULT_TLS_SKIP_VERIFY yes Whether to skip TLS verification false
SERVICE_ACCOUNT_PATH yes Path to the Kubernetes serviceaccount token file "/var/run/secrets/kubernetes.io/serviceaccount/token"
AUTO_COMPLETE yes Activates autocomplete mode false
AUTO_COMPLETE_FILE_PREFIX yes Removes the prefix from the filename before determining the associated Vault secret's KV path
AUTO_COMPLETE_VAULT_KV_PATH_PREFIX yes Appends a base KV path, i.e. kv/mybasekvpath/secretname
AUTO_COMPLETE_ADDITIONAL_SUFFIX_FILTERS yes Comma separated list of additional suffixes to filter out of KV secret name (i.e. with .enc.yml: secretname.enc.yml -> secretname) (note:, filter order takes precedence, .yml, and .yaml will always be included last)
FLATTEN yes Whether to "dot flatten" the secret data structure (Useful for Spring Cloud Vault consumption) true

Credits

Uses the following OSS libs, thanks guys ;)

Inspired from chunks of the following OSS projects, thanks people :D