Latest release:
- Make it easier to upgrade from ancient (pre v0.9.0) controllers (#466)
- Prometheus: add namespace to unseal error metric (#463)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/17?closed=1
This release contains a fix for CVE-2020-14040, which could have opened the possibility for an attacker to cause a DoS on the sealed-secret controller (provided the attacker can cause the controller to process a malicious sealed secret resource).
- Fix CVE-2020-14040 (#456)
- Don't require a namespace when using --raw and cluster-wide scope (#451)
- Unregister Prometheus Gauges associated to removed SealedSecrets conditions (#422)
- Add -f and -w flags as an alternative to stdin/out (#439)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/24?closed=1
- Add
condition_info
metric to expose SealedSecrets status (#421)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/23?closed=1
The binaries in this release have been rebuilt with the Go 1.14.3 toolchain. No other changes in binaries nor k8s manifests.
- Build with latest Go 1.14.x version (#411)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/22?closed=1
This release contains only a change in the kubeseal
binary since v0.12.2. No controller nor k8s manifest changes.
- Fix
--merge-into
file permissions on Windows (#407)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/21?closed=1
This release contains important changes in manifests since v0.12.1. It also contains a minor fix in kubeseal client.
Previously, users upgrading to v0.12.x from previous versions would experience:
The Deployment "sealed-secrets-controller" is invalid: spec.selector: Invalid value: v1.LabelSelector{MatchLabels:map[string]string{"app.kubernetes.io/managed-by":"jsonnet", "app.kubernetes.io/name":"kubeseal", "app.kubernetes.io/part-of":"kubeseal", "app.kubernetes.io/version":"v0.12.1", "name":"sealed-secrets-controller"}, MatchExpressions:[]v1.LabelSelectorRequirement(nil)}: field is immutable
This was caused by a bug in our official yaml manifests introduced in v0.12.0. Users of the Helm chart were unaffected.
By reverting this issue we're are going to cause the same bad experience for users who did perform a clean install of v0.12.x. However, we believe such users are a minority.
- Revert "Add recommended labels" (#404)
- remove kubeconfig deps from recovery-unsea(#394)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/19?closed=1
This release contains changes in kubeseal
and controller
binaries but no changes in manifests since v0.12.0.
This release is a fixup release that turns off the status update feature introduced in v0.12.0. Several users have reported a severe bug (an infinite feedback loop where the controller kept updating sealedsecrets and consuming lots of CPU).
In order to turn it back on you need to manually pass the --update-status
flag to the controller (or pass the SEALED_SECRETS_UPDATE_STATUS=1
env var)
- Make it easier to use --raw from stdin (#386)
- Disable status updates unless a feature flag is explicitly passed (#388)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/18?closed=1
This release contains changes in kubeseal
and controller
binaries as well as a minor change to the k8s manifest (see #381); keep that in mind if you don't rely on the official k8s manifests, including the community-maintained Helm chart.
Now the sealed secrets controller updates the Status
field of the SealedSecrets
resources.
This makes it easier for automation like ArgoCD to detect whether (and when) the controller has reacted to changes in the SealedSecret resources and produced a Secret. It also shows an error message in case it fails (many users are not familiar with k8s events and they may find it easier to see the error message in the status).
The sealed secrets controller now exports prometheus metrics. See also contrib/prometheus-mixin and controller-podmonitor.yaml
.
- Update Status field (#346)
- Add prometheus metrics (#177)
- Upgrade k8s client-go to v0.16.8 (#380)
- kubeseal no longer emits empty
status: {}
field (#383)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/16?closed=1
This release contains only changes in kubeseal binary (no k8s manifest changes required).
Creating secrets with namespace-wide and cluster-wide scopes is now easier as it no longer requires manually adding annotations in the input Secret before passing it to kubeseal
. This was often the root cause of many support requests. Now all you need to do is to:
$ kubeseal --scope namespace-wide <input-secret.yaml >output-sealed-secret.json
- Honour --scope flag (#371)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/15?closed=1
This release supports the ARM 32 bit and 64 bit architectures, both on the client and the controller sides.
We also end the silly streak of patch level releases that actually contained features. We'll try to bump the minor version on every release except true hotfixes.
- Provide multi-arch Container image for sealed secrets controller (#349)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/2?closed=1
This release contains only changes in Linux kubeseal-arm
and kubeseal-arm64
binaries. There are no changes in the docker images, nor in the x86_64
binaries for any of the supported OS.
- Fix bad release of Linux ARM7 and ARM64 binaries (#362)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/14?closed=1
This release contains changes in kubeseal
and controller
binaries as well as a minor change to the k8s manifest (see #338); keep that in mind if you don't rely on the official k8s manifests, including the community-maintained Helm chart.
By default, the sealed-secrets controller doesn't unseal a SealedSecret over an existing Secret resource (i.e. a resource that has not been created by the sealed-secrets controller in the first place).
This is an important safeguard, not only to catch accidental overwrites due to typos etc, but also as a security measure: the sealed-secrets controller can create/update Secret resources even if the user who has the RBAC rights to create the SealedSecret resource doesn't have the right to create/update a Secret resource. We didn't want the sealed-secret controller to give its users more effective rights than what they would otherwise have without the sealed-secrets controller. A simple way to achieve that was permit only updates (overwrites) to Secret resources that were already owned by the sealed-secrets controller (which also seemed a sensible thing to do since it protects from accidental overwrites).
However, this behavior gets in the way when you're just starting to use SealedSecrets and want to migrate your existing Secrets into SealedSecrets.
You now can just annotate your Secret
s with sealedsecrets.bitnami.com/managed: true
thus indicating that they can be safely overwritten by the sealed-secrets controller. This doesn't loosen our security model since you'd have to have RBAC rights to annotate the existing secrets (e.g. with kubectl annotate
) or you can ask your friendly admins to do it on your behalf.
- Release includes ARMv7 and ARM64 binaries (although no docker images yet) (#173)
- Set
fsGroup
tonobody
in order to supportBoundServiceAccountTokenVolume
(#338) - Add
--force-empty-data
flag to allow (un)sealing an empty secret (#334) - Avoid forcing the default namespace when sealing a cluster-wide secret (#323)
- Introduce the
sealedsecrets.bitnami.com/managed: true
annotation which controls overwriting existing secrets (#331)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/13?closed=1
This release contains only changes in kubeseal
and controller
binaries (no k8s manifest changes required).
It always been possible in theory to run multiple controller instance in multiple namespaces, each with their own sealing encryption keys and thus each able to unseal secrets intended for it. However, doing so created a lot of noise in the logs, since each controller wouldn't know which secrets are meant to be decryptable, but failed to decrypt, and which it ought to ignore.
Since v0.9.6 you can reduce this noise by setting the --all-namespaces
flag to false (also via the env var SEALED_SECRETS_ALL_NAMESPACES=false
).
- Give an option to search only the current namespace (#316)
- Support parsing multiple private keys in --recovery-private-key (#325)
- Add klog flags so we can troubleshoot k8s client (#320)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/12?closed=1
This release contains only changes in kubeseal
binary (no k8s manifest changes required).
- Improve error reporting in case of missing kubeconfig when inferring namespace (#313)
- Teach kubeseal to decrypt using backed up secrets (#312)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/11?closed=1
This release contains only changes in kubeseal
and controller
binaries (no k8s manifest changes required).
- Remove tty warning in
--fetch-cert
(regression caused by #303 released in v0.9.3) (#306) - Implement
--recovery-unseal
to help with disaster recovery (#307)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/10?closed=1
This release contains only changes in kubeseal
and controller
binaries (no k8s manifest changes required).
- Implement
--key-cutoff-time
(#299) - Warn if stdin is a terminal (#303)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/9?closed=1
This release contains only changes in kubeseal
and controller
binaries (no k8s manifest changes required).
A few people have raised concerns of how will automatic key+certificate renewal affect the offline signing workflow. First, a clarification: nothing changed. You can keep using your old certificates; it's just that if you do, you won't benefit from the additional security given from the periodic key renewal.
In order to simplify the workflow for those who do want to benefit from the key renewal, but at the same time
cannot access the target cluster (while not being completely offline), we offer a little feature that will help: --cert
has learned to accept http(s) URLs. You can point it to a place where you serve up-to-date certificates for your clusters (tip/idea: you can expose the controller's cert.pem files with an Ingress).
- Accept URLs in
--cert
(#281) - Improve logs/events in case of decryption error (#274)
- Reduce likelihood of name/namespace mismatch when using
--merge-into
(#286)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/8?closed=1
- Make manifests compatible with k8s 1.16.x (#269)
- Fix non-strict scopes with --raw (#276)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/7?closed=1
This release turns on an important security feature: a new private key will be now created every 30 days by default. Existing sealed-secrets resources will still be decrypted until the keys are manually phased out.
You can read more about this feature and the problem of secret rotation and how it interacts with Sealed Secrets in this README section or in the original GH issue #137.
This feature alone is not technically a breaking change for people who use the offline workflow with kubeseal --cert
, since old keys are not rotated out automatically. Users would be required to update their offline certs only when they purge old keys manually (we might introduce automatic purging in the future).
That said, to reap the benefits of key renewal, users of the offline workflow are encouraged to update their offline certificates every time a new key is generated (by default every 30 days).
If you are using kubeseal clients older than v0.7.0, please upgrade. Since this release the controller will no longer accept the "v1" format of the encrypted "data" field and instead it will only support the "encryptedData" field.
If you have old sealed secret resources lying around, you can easily upgrade them by invoking:
kubeseal --re-encrypt <old.yaml >new.yaml
Since version v0.7.0 it was possible to update individual items in the encryptedData
field of the Sealed Secret resource, but you had to manually copy&paste the encrypted items into an existing resource file. The required steps were never spelled out in the documentation and to be fair it always felt quite awkward.
Now kubectl
has learned how to update an existing secret, whilist preserving the same general operation principles, namely staying out of the business of actually crafting the secret itself (kubectl create secret ...
and its various flags like --from-file
, --from-literal
, etc). Example:
$ kubectl create secret generic mysecret --dry-run -o json --from-file=foo=/tmp/foo \
| kubeseal >sealed.json
$ kubectl create secret generic mysecret --dry-run -o json --from-file=bar=/tmp/bar \
| kubeseal --merge-into sealed.json
- Doc improvements.
- Rename "key rotation" to "key renewal" since the terminology was confusing.
- Key renewal is enabled by default every 30 days (#236)
- You can now use env vars such as SEALED_SECRETS_FOO_BAR to customize the controller (#234)
- Disabling by default deprecated "v1" encrypted data format (used by pre-v0.7.0 clients) (#235)
- Fix RBAC rules for /v1/rotate and /v1/validate fixing #166 for good (#249)
- Implement the --merge-into command (#253)
- Add the
-o
alias for--format
(#261) - Add the
--raw
command for only encrypting single items (#257)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/1?closed=1
This release contains a fix for a possible secret leak that can happen when sealing existing secrets that have been retrieved from a cluster (e.g. with kubectl get
) where they have been created with kubectl apply
(as opposed to kubectl create
).
This potential problem has been introduced v0.8.0 when kubeseal learned how to preserve annotations and labels.
Please check your existing sealed secret sources for any annotation kubectl.kubernetes.io/last-applied-configuration
, because that annotation would contain your original secrets in clear.
This release strips this annotation (and a similar annotation created by the kubcfg
tool)
Fixes in this release:
- Round-tripping secrets can leak cleartext in last-applied-configuration (#227)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/6?closed=1
Fixes in this release:
- Endless loop in controller on invalid base64 encrypted data bug (#201)
- Fix RBAC for /v1/cert.pem public key in isolated namespaces, removes most use cases for offline sealing with
--cert
(#208,#166) - Accept and seal stringData into secret (#221)
- Fix a couple of blockers for enabling (still experimental) key rotation (#185, #219, #218)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/5?closed=1
Fixes in this release:
- Solve kubectl auth issues with clusters using
client.authentication.k8s.io/v1beta1
config by upgrading to client-go v12.0.0 (#183) - Fix controller crash when writing logs due to read-only root FS (#200)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/4?closed=1
The main improvements in this release are:
- support for annotations and labels (#92)
- support for secrets rotation opt-in (#137)
- fix bug with OwnerReferences handling (#127)
- EKS support; client-go version bump to release-7.0 (#110)
- Instructions to run on GKE when user is not cluster-admin (#111)
- Windows binary of kubeseal (#85)
- Internal codebase modernization (e.g. switch to Go modules)
The full Changelog is maintained in https://github.com/bitnami-labs/sealed-secrets/milestone/3?closed=1
Many thanks for all the folks who contributed to this release!
Big change for this release is the switch to per-key encrypted values. ("Keys" as in "object key/value", not as in "encryption key". English is hard.)
- Previously we generated a single big encrypted blob for each Secret, now we encrypt each value in the Secret separately, with the keys in plain text.
- This allows:
- Existing keys can now be renamed and deleted without re-encrypting the value(s).
- New keys/values can be added to the SealedSecret without re-encrypting (or even having access to!) the existing values.
- Note that (as before) the encrypted values are still tied to the namespace/name of the enclosing Secret/SealedSecret, so can't be moved to another Secret. (The cluster-wide annotation does allow this, with the corresponding caveats, as before)
- The
kubeseal
tool does not yet have an option to output just a single value, but you can safely mix+match the individual values fromkubeseal
output with an existing SealedSecret. Improvingkubeseal
support for this feature is still an open action item. - Existing/older "all-in-one" SealedSecrets are declared deprecated, but will continue to be supported by the controller for the foreseeable future. New invocations of the
kubeseal
tool now produce per-key encrypted output - if you need to produce the older format, just use an olderkubeseal
. Please raise a github issue if you have a use-case that requires supporting "all-in-one" SealedSecrets going forward. - Note the CRD schema used for server-side validation in k8s >=1.9 has been temporarily removed, because it was unable to support the new per-key structure correctly (see kubernetes/kubernetes#59485).
- Huge thanks to @sullerandras for the code and his persistence in getting this merged!
- Support "cluster wide" secrets, that are not restricted to the original namespace
- Set
sealedsecrets.bitnami.com/cluster-wide: "true"
annotation - Warning: cluster-wide SealedSecrets can be decrypted by anyone who can create a SealedSecret in your cluster
- Set
- Move to client-go v5.0
- Move to bitnami-labs github org
- Fix bug in schema validation for k8s 1.9
Note: this version moves TPR/CRD definition into a separate file. To install, you need controller.yaml
and either sealedsecret-tpr.yaml
or sealedsecret-crd.yaml
- Add CRD definition and TPR->CRD migration documentation
- Add
kubeseal --fetch-cert
to dump server cert to stdout, for later offline use withkubeseal --cert
- Better sanitisation of input object to
kubeseal
(v0.5.1 fixes a travis/github release issue with v0.5.0)
- controller: deployment security hardening: non-root uid and read-only rootfs
kubeseal
: Include oidc and gcp auth provider pluginskubeseal
: Add support for YAML output
- Add
controller-norbac.yaml
to the release build. This iscontroller.yaml
without RBAC rules and related service account - for environments where RBAC is not yet supported, like Azure. - Fix missing controller RBAC ClusterRoleBinding in v0.3.0
Rename everything to better represent project scope. Better to do this early (now) and apologies for the disruption.
- Rename repo and golang import path ->
bitnami/sealed-secrets
- Rename cli tool ->
kubeseal
- Rename
SealedSecret
apiGroup ->bitnami.com
- Fix invalid field
resourceName
in v0.2.0 controller.yaml (thanks @Globegitter)
- Client tool has better defaults, and can fetch the certificate automatically from the controller.
- Improve release process to include pre-built Linux and OSX x86-64 binaries.
Basic functionality is complete.
- Clean up controller.jsonnet
- Switch to quay.io (docker hub doesn't offer robot accounts??)
- Add deploy section to .travis.yml