-
Notifications
You must be signed in to change notification settings - Fork 228
[cetic/nifi] Allow use of existing secrets for ALL sensitive Helm chart values #290
Comments
@jstewart612 thank you for raising this issue. Could you please point to an example/documentation/tutorial for the solution you are describing? Note: We have also very briefly looked at helm-secrets+sops but it is adding a new dependency to the chart. |
@banzo most of your problem is your approach to blocks like these: https://github.com/cetic/helm-nifi/blob/master/templates/statefulset.yaml#L116-L369 You tell the Helm chart, inline in a StatefulSet, to render a giant template string invoked by bash -ce. As a result, when you render the Helm chart, the password renders in plaintext in the object definition in Kubernetes / as a result of helm template commands, etc. You could go with numerous approaches to address this. My suggestion would be to never render a sensitive piece of data outside of a Secret. I'd move the entirety of these script generation blocks into a Secret, then simply tell your StatefulSet to load the script or file located at x, and have a volume and volumeMount from that SecretRef. https://kubernetes.io/docs/concepts/configuration/secret/#using-secrets-as-files-from-a-pod Once you can do that, it's a fairly easy hop, skip, and a jump, to wrap the rendering of the secret behind the truthiness of another key. if existingSecret key defined -> do not render this secret Granted, you're doing a lot of interpretation for people, so if they chose to use this existingSecret model, they'd lose a lot of the convenience functions... but that's a choice I'd argue the user should have. At a minimum, exfiltrating these giant blocks of text with passwords in them out of the StatefulSet and into Secrets, and then just having all these commands simply reference a file loaded from a secretRef, with an option to specify an existingSecret and then not render that Secret at all, would be a huge win. Then, you don't have to be opinionated on which secrets protection mechanism the end user employs. They can make those decisions for themselves. Let me know if you have any other questions. I may personally try my hand at a PR demonstrating what I mean, as well. |
@jstewart612 thank you for the explanation.
That would be most excellent. |
@banzo I've created a pull request to set an example of how this could be done. Ideally the file would be created using the Secret Store CSI driver directly and no k8s Secret is created at all, but not all users would want to use that method, and it would be messy to have that option. |
Using this method, I'd have one secret/mount per optional block. For blocks with multiple secrets, use one Secret and many keys. Each get using the simple mount method (ie no subPath), it automatically creates a file per key within the folder.
creates:
which can then be individually used: |
@jstewart612 is #303 in line with what you proposed? |
Is your feature request related to a problem? Please describe.
This Helm chart has numerous places where you can enter sensitive credentials as a Helm value override. This breaks the basic security model of GitOps, making this chart only suitable for use with a literal "helm install", and even then, object last modified annotations will contain the plain text secrets in them. This is operationally unsafe and a compliance nightmare for any organization.
Describe the solution you'd like
Every single Helm value with the word "secret" in it gets an equivalent "existingSecret" key where you can specify subkey "name" and subkey "key", mapping to the name of the secret and the name of the key inside that secret, respectively.
Describe alternatives you've considered
I reviewed your helm template for OIDC configuration and it does not permit any other value to be specified other than the client secret.
Additional context
This is a very good and useful Helm chart but this is a critical step for operational security in GitOps environments.
The text was updated successfully, but these errors were encountered: