-
Notifications
You must be signed in to change notification settings - Fork 74
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
More flexible and better organized target specification in API #243
Comments
Maybe this could also be a chance to bring the target side more in line with the sources side? What would you think about something like this: targets:
- configMap:
format: pem
key: root-certs.pem
- configMap:
format: jks
key: bundle.jks
password: jks-password
- configMap:
format: pkcs12
key: bundle.p12
password: pkcs12-password
- secret:
format: pem
key: root-certs.pem
- secret:
format: jks
key: bundle.jks
password: jks-password
- secret:
format: pkcs12
key: bundle.p12
password: pkcs12-password |
@hazmat345 Thanks for your input. I like your suggestion. It's probably better than what I suggested initially in this issue! 😄 We use kustomize a lot, and patching arrays could be troublesome. What if we separated I agree that |
Inspired by the suggestion from @hazmat345, I think the following might work well: target:
configMap:
- format: pem
key: root-certs.pem
- format: jks
key: bundle.jks
password: jks-password
- format: pkcs12
key: bundle.p12
password: pkcs12-password
secret:
- format: pem
key: root-certs.pem
- format: jks
key: bundle.jks
password: jks-password
- format: pkcs12
key: bundle.p12
password: pkcs12-password That will allow us to set map semantics on the arrays in |
I have a few things in mind writing this comment:
With that in mind, I'd tend towards something like this: target:
configMap:
formats:
jks:
key: "bundle.jks"
password: "whatever"
secret:
formats: {} In this example, the configMap gets just JKS while the secret will just default to a PEM bundle with some This keeps it easy to write resources (since I assume people will want a PEM bundle) while allowing more flexibility for those who want it. This could be expanded to support multiple configmaps / secrets per bundle if we wanted (but as above, I'm not feeling convinced on that). Just throwing the idea out there! |
I agree that we should not support multiple configmaps/secrets. The increased controller complexity is just not worth it. Users that want/need this, can simply create additional bundle resources using the same sources. But when it comes to specifying the target resource content, I don't think we should have a "magic" default target key for PEM bundles. I think this will bite us at some point in the future. 😁 I agree that PEM is probably the most common format, so it should be easy to configure it. Wouldn't the following be easy enough to represent your example above? target:
configMap:
- format: jks
key: bundle.jks
password: whatever
secret:
# PEM is the default format
- key: bundle.pem |
We'd welcome multiple keys per target for the same encoding, in any case — many operators and controllers want to read self-signed CA certificates from a secret, almost always PEM-encoded, but often with different key names ( |
Issues go stale after 90d of inactivity. |
/remove-lifecycle stale |
I will start with a "max" target specification using the existing API (also including #235 - which I think will be merged before this issue is eventually addressed):
I can identify several issues with this specification structure:
additional
appears a bit "discriminating", and does not motivate users to suggest (or contribute) new formats (e.g. DER).key
in configmap and secret, while for "additional formats" this is not supported.To solve most of these issues, I suggest a more flexible (and less "discriminating") structure. It might appear more complex, but remember that most users will probably not use a "max" specification, and only specify relevant fields for their setup.
The text was updated successfully, but these errors were encountered: