Skip to content

Releases: ricoberger/vault-secrets-operator

Version 1.4.5 / 2020-01-06

06 Jan 14:29
Compare
Choose a tag to compare

Adding support for label and annotation inheritance

This release adds support for label and annotation inheritance. Thanks to @s4mur4i for his PR #29. The following CR:

apiVersion: ricoberger.de/v1alpha1
kind: VaultSecret
metadata:
  name: kvv1-example-vaultsecret
  annotations:
    myannotation: myvalue
  labels:
    mylabel: myvalue
spec:
  keys:
    - foo
  path: kvv1/example-vaultsecret
  type: Opaque

results now in the following secret:

apiVersion: v1
data:
  foo: YmFy
kind: Secret
metadata:
  annotations:
    myannotation: myvalue
  labels:
    created-by: vault-secrets-operator
    mylabel: myvalue
  name: kvv1-example-vaultsecret
type: Opaque

Version 1.4.4 / 2019-12-09

09 Dec 20:12
Compare
Choose a tag to compare

Allow custom certificates

It's now possible to use custom certificates for the communication between the Operator and Vault. To use custom certificates you need to set the following environment variables:

  • VAULT_CACERT: CA certificate to verify the Vault server's SSL certificate.
  • VAULT_CLIENT_CERT: CA certificate to use for TLS authentication to the Vault server.
  • VAULT_CLIENT_KEY: Private key matching the client certificate from VAULT_CLIENT_CERT .
  • VAULT_SKIP_VERIFY: Disable verification of TLS certificates.
  • VAULT_TLS_SERVER_NAME: Name to use as the SNI host when connecting via TLS.

The environment variables can be set as follows in the Helm chart:

environmentVars:
  - envName: VAULT_CACERT
    secretName: vault-secrets-operator-tls
    secretKey: VAULT_CACERT
  - envName: VAULT_CLIENT_CERT
    secretName: vault-secrets-operator-tls
    secretKey: VAULT_CLIENT_CERT
  - envName: VAULT_CLIENT_KEY
    secretName: vault-secrets-operator-tls
    secretKey: VAULT_CLIENT_KEY

The corresponding secret vault-secrets-operator-tls looks as follows:

apiVersion: v1
kind: Secret
metadata:
  name: vault-secrets-operator-tls
data:
  VAULT_CACERT: ...
  VAULT_CLIENT_CERT: ...
  VAULT_CLIENT_KEY: ...
type: Opaque

Version 1.4.3 / 2019-12-03

03 Dec 14:15
Compare
Choose a tag to compare

We are now using the LookupSelf instead of the Lookup function from the Vault API package for the readiness probe.

The Lookup requires more rights to return a successful response. These capabilities are not needed for other operations of the operator. So we switched to the LookupSelf function.

Version 1.4.2 / 2019-12-02

02 Dec 20:45
Compare
Choose a tag to compare

In case the metrics server in a Kubernetes cluster was not available the Vault Secrets Operator fails to start, because the endpoint for the liveness and readiness probe was also not available (#22). Thanks to @rust84 for pointing out the issue.

Now we are using more useful checks for the readiness and liveness probe (#25):

  • Liveness: Returns true if the HTTP server is running.
  • Readiness: Returns true if a valid token for Vault is passed to the operator.

Version 1.4.1 / 2019-11-28

28 Nov 19:29
Compare
Choose a tag to compare

Add new spec.isBinary field to the CRD, to indicate that the Vault secret contains binary data which is already in base64 encoded format. The binary data stored in vault requires base64 encoding. The
spec.isBinary can be used to prevent such data get base64 encoded again when store as secret in Kubernetes. Thanks to @SiweiWang for the PR #24.

Example:

 vault kv put kvv1/example-vaultsecret foo=YmFyCg==

You can specify spec.isBinary to indicate this is a binary data which is already in base64 encoded format:

apiVersion: ricoberger.de/v1alpha1
kind: VaultSecret
metadata:
  name: kvv1-example-vaultsecret
spec:
  keys:
    - foo
  isBinary: true
  path: kvv1/example-vaultsecret
  type: Opaque

The resulting Kubernetes secret will be:

apiVersion: v1
data:
  foo: YmFyCg==
kind: Secret
metadata:
  labels:
    created-by: vault-secrets-operator
  name: kvv2-example-vaultsecret
type: Opaque

The value for foo stays as YmFyCg== which does not get base64 encoded again.

Version 1.4.0 / 2019-10-28

28 Oct 18:06
Compare
Choose a tag to compare

Feature:

  • Use the WATCH_NAMESPACE variable to watch all namespaces or a comma separated list of namespaces.
  • Add vault.namespaces value to the Helm chart to set the WATCH_NAMESPACE environment variable.
vault:
  # Watch all namespaces
  namespaces: ""
  # Watch the namespaces test1, test2 and test3
  namespaces: "test1,test2,test3"

Misc:

  • Update the operator-sdk to version v0.11.x

Version 1.3.2 / 2019-10-17

17 Oct 20:06
Compare
Choose a tag to compare

Bugfix

  • Fix helper function to set environment variables from a Kubernetes secret in the Helm chart

Feature

  • Add a new value to the Helm chart to specify the deployment strategy for the operator. Currently there seems to be a bug in the operator, which cause problems during an update. Therefor it is recommended to set the strategy type to recreate if a replication count of one is used:
deploymentStrategy:
  type: Recreate

Version 1.3.1 / 2019-10-15

15 Oct 20:52
Compare
Choose a tag to compare

Bugfix

  • Fix the Helm chart, see #18
  • The new vault.reconciliationTime results in an error during the Helm deployment
  • Quote all environment variables

Special thanks goes to @billimek

Version 1.3.0 / 2019-10-15

15 Oct 17:27
Compare
Choose a tag to compare

Feature: Automatic Reconciliation

  • Add an environment variable VAULT_RECONCILIATION_TIME, which can be set in the Helm chart via the vault.reconciliationTime value.
  • If the value of the VAULT_RECONCILIATION_TIME is greater 0 a CR is reconciled after the specified time (in seconds)
  • If the spec.version is not omitted in a CR, the Kubernetes secret will be automatically updated if the Vault secret changes.

Bugfix: Request was not requeued

  • If an error occurred while requesting the Vault secret, the CR was not requeued.

Version 1.2.3 / 2019-09-25

25 Sep 18:25
Compare
Choose a tag to compare
  • Add the possibility to read the Vault token from a mounted volume. Therefor we introduce a new environment variable VAULT_TOKEN_PATH which should contain the path to a file with the Vault token. This variable is only processed if the authentication method is set to token and the VAULT_TOKEN environment variable is empty.
  • The Helm chart supports three new values:
    • vault.tokenPath: Can be used to set the VAULT_TOKEN_PATH environment variable.
    • image.volumeMounts: Can be used to mount additional volumes to the container.
    • volumes: Can be used to provide additional volumes.

Example

cat <<EOF | k apply -f - 
apiVersion: v1
kind: ConfigMap
metadata:
  name: vault-token
data:
  token: |
    MY_VAULT_TOKEN
EOF
cat <<EOF | helm upgrade --install vault-secrets-operator ./charts/vault-secrets-operator -f -
image:
  repository: ricoberger/vault-secrets-operator
  tag: 1.2.3
  args: ["--zap-encoder", "console"]
  volumeMounts:
    - name: vault-token
      mountPath: /etc/vault

vault:
  address: "vault:8200"
  authMethod: "token"
  tokenPath: "/etc/vault/token"

volumes:
  - name: vault-token
    configMap:
      name: vault-token
      items:
        - key: token
          path: token
EOF