-
Notifications
You must be signed in to change notification settings - Fork 188
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow providing cluster-wide age identity via controller env var #918
base: main
Are you sure you want to change the base?
Conversation
adfa781
to
c088f51
Compare
Signed-off-by: Marcus Weiner <[email protected]>
Signed-off-by: Marcus Weiner <[email protected]>
c088f51
to
5e3794c
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is a convenient feature. However, we need to think about the security implications of this in multi-tenant environments. If we agree to add this feature, we must document it in https://fluxcd.io/flux/components/kustomize/kustomization/, https://fluxcd.io/flux/guides/mozilla-sops/ and https://fluxcd.io/flux/security/secrets-management/. Likely also in https://fluxcd.io/flux/security/best-practices/.
} | ||
|
||
if d.kustomization.Spec.Decryption.SecretRef == nil { | ||
return nil |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For the case where the env var is not set and no secret is provided in the Kustomization, this just bails out but it should actually return an error because providing a decryption provider without any keys is a user error.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
that behaviour was there before, i did not introduce it?
i'm happy to discuss them. the hope was that since this is an env var for the controller, people setting this would need to know what they're doing? it's also prefixed with |
We have a dedicated section in the API docs for Controller global decryption, this the place where this feature should be documented. |
so it seems like we have precedent for secret-less decryption? |
No, not with some hardcoded private key, all the global options are for KMS & OIDC. |
No one should use this on multi-tenant clusters. Given that it requires a cluster admin to add the env var to kustomize-controller, it can't be enabled by mistake and it's opt-in, I think it's safe to add this feature. @hiddeco what's your opinion on this? |
Think it would be okay to include. However, I am not really sure about the naming of the |
What are your doubts about it? Any kind of conventions or existing patterns you'd like it to follow instead? |
SOPS itself already has default places where it looks for things, and it may thus be better to inherit these for environment defaults: https://github.com/getsops/sops/blob/02a866f27d8545fdc3de3b44a563e46f8e9c9df9/age/keysource.go#L19-L27 |
if you prefer omitting the |
@hiddeco @stefanprodan do you think it makes sense to get this implemented? |
Sorry for the bump but unless something has changed it looks like @hiddeco and @stefanprodan are in agreement this could be a feature. Personally I would love this feature as it would lessen some pains I have with trying to spread out my flux kustomizations per namespace instead of being only in the flux-system namespace. Seeing how it's been over a year and a half since the last response, @mraerino would you mind if I took over this PR, fixed it up and added the required docs to get it moving along? |
SOPS has the handy feature of allowing to read the identity for decryption from
SOPS_AGE_KEY
. Because of the keyservice implementation detail of Flux you can't use that env var to set a cluster-wide identity on the controller.This change implements that ability using the env var
FLUX_SOPS_AGE_KEY
. When you set that variable on the Kustomize Controller it will be used as an additional key in decryption and allows omitting thespec.decryption.secretRef
property on the Flux Kustomization (it is marked as optional in the API).