-
Notifications
You must be signed in to change notification settings - Fork 62
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
Remove cert and pem enforcement #150
base: main
Are you sure you want to change the base?
Conversation
…hat required kubernetes_ca_cert to exist if token_reviewer_jwt is false
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.
Please can we get some unit test coverage? It's harder to test in an automated way, but I'd also like to ensure we at least manually test using the OS trust store. LMK if you'd like any help with that and I can go into more detail.
"no CA default to system": { | ||
config: map[string]interface{}{ | ||
"kubernetes_host": "host", | ||
"disable_local_ca_jwt": false, | ||
"kubernetes_ca_cert": "", | ||
}, | ||
setupInClusterFiles: true, | ||
|
||
expected: &kubeConfig{ | ||
PublicKeys: []interface{}{}, | ||
PEMKeys: []string{}, | ||
Host: "host", | ||
CACert: testLocalCACert, | ||
TokenReviewerJWT: testLocalJWT, | ||
DisableISSValidation: true, | ||
DisableLocalCAJwt: false, | ||
}, | ||
}, |
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.
Is this test different than "no CA or JWT, default to local" in TestConfig_LocalCaJWT()
? IIRC disable_local_ca_jwt
defaults to false, and kubernetes_ca_cert
defaults to ""
.
vault-plugin-auth-kubernetes/path_config_test.go
Lines 361 to 375 in a0dfafe
"no CA or JWT, default to local": { | |
config: map[string]interface{}{ | |
"kubernetes_host": "host", | |
}, | |
setupInClusterFiles: true, | |
expected: &kubeConfig{ | |
PublicKeys: []interface{}{}, | |
PEMKeys: []string{}, | |
Host: "host", | |
CACert: testLocalCACert, | |
TokenReviewerJWT: testLocalJWT, | |
DisableISSValidation: true, | |
DisableLocalCAJwt: false, | |
}, | |
}, |
@@ -161,11 +159,11 @@ func (b *kubeAuthBackend) pathConfigWrite(ctx context.Context, req *logical.Requ | |||
|
|||
// Determine if we load the local CA cert or the CA cert provided | |||
// by the kubernetes_ca_cert path into the backend's HTTP client | |||
certPool := x509.NewCertPool() | |||
tlsConfig := &tls.Config{ | |||
MinVersion: tls.VersionTLS12, | |||
} | |||
if disableLocalJWT || len(caCert) > 0 { |
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.
How come we don't use system certs if disableLocalJWT
is true?
@@ -161,11 +159,11 @@ func (b *kubeAuthBackend) pathConfigWrite(ctx context.Context, req *logical.Requ | |||
|
|||
// Determine if we load the local CA cert or the CA cert provided | |||
// by the kubernetes_ca_cert path into the backend's HTTP client | |||
certPool := x509.NewCertPool() | |||
tlsConfig := &tls.Config{ | |||
MinVersion: tls.VersionTLS12, | |||
} | |||
if disableLocalJWT || len(caCert) > 0 { |
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 more idiomatic check for empty strings:
if disableLocalJWT || len(caCert) > 0 { | |
if disableLocalJWT || caCert != "" { |
@imthaghost and @tomhjp can we merge this? |
Overview
Some users didn't find it necessary for Vault to enforce the CA cert or PEM keys. Examples can be found in the related issues.
Design of Change
We add false booleans to the
kubernetes_ca_cert
andpem_keys
fields. While therequired
field on theFieldSchema
struct are deprecated we added this just for future reference and documentation. We also remove checks that enforcedkubernetes_ca_cert
to be present instead we just default to the local CA cert ifkubernetes_ca_cert
is not set which will return an error ofx509: certificate signed by unknown authority
if the user did supply an appropriate CA cert.Related Issues
Issue #62
Issue #88
Docs
I don't believe docs need to be added since this is implied in the example below.