mirror of
https://github.com/pomerium/pomerium.git
synced 2025-05-30 09:27:19 +02:00
config: use tls_custom_ca from policy if available (#2077)
This commit is contained in:
parent
6d1d2bec54
commit
8924b1a5fc
2 changed files with 48 additions and 1 deletions
|
@ -78,7 +78,18 @@ func NewPolicyHTTPTransport(options *Options, policy *Policy) http.RoundTripper
|
|||
tlsClientConfig.MinVersion = tls.VersionTLS12
|
||||
isCustomClientConfig = true
|
||||
} else {
|
||||
log.Error().Err(err).Msg("config: error getting cert pool")
|
||||
log.Error().Err(err).Msg("config: error getting ca cert pool")
|
||||
}
|
||||
}
|
||||
|
||||
if policy.TLSCustomCA != "" || policy.TLSCustomCAFile != "" {
|
||||
rootCAs, err := cryptutil.GetCertPool(policy.TLSCustomCA, policy.TLSCustomCAFile)
|
||||
if err == nil {
|
||||
tlsClientConfig.RootCAs = rootCAs
|
||||
tlsClientConfig.MinVersion = tls.VersionTLS12
|
||||
isCustomClientConfig = true
|
||||
} else {
|
||||
log.Error().Err(err).Msg("config: error getting custom ca cert pool")
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -45,3 +45,39 @@ func TestHTTPTransport(t *testing.T) {
|
|||
_, err := client.Get(s.URL)
|
||||
assert.NoError(t, err)
|
||||
}
|
||||
|
||||
func TestPolicyHTTPTransport(t *testing.T) {
|
||||
s := httptest.NewTLSServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||
w.WriteHeader(http.StatusOK)
|
||||
}))
|
||||
defer s.Close()
|
||||
|
||||
get := func(options *Options, policy *Policy) (*http.Response, error) {
|
||||
transport := NewPolicyHTTPTransport(options, policy)
|
||||
client := &http.Client{
|
||||
Transport: transport,
|
||||
}
|
||||
return client.Get(s.URL)
|
||||
}
|
||||
|
||||
t.Run("default", func(t *testing.T) {
|
||||
_, err := get(&Options{}, &Policy{})
|
||||
assert.Error(t, err)
|
||||
})
|
||||
t.Run("skip verify", func(t *testing.T) {
|
||||
_, err := get(&Options{}, &Policy{TLSSkipVerify: true})
|
||||
assert.NoError(t, err)
|
||||
})
|
||||
t.Run("ca", func(t *testing.T) {
|
||||
_, err := get(&Options{
|
||||
CA: base64.StdEncoding.EncodeToString([]byte(localCert)),
|
||||
}, &Policy{})
|
||||
assert.NoError(t, err)
|
||||
})
|
||||
t.Run("custom ca", func(t *testing.T) {
|
||||
_, err := get(&Options{}, &Policy{
|
||||
TLSCustomCA: base64.StdEncoding.EncodeToString([]byte(localCert)),
|
||||
})
|
||||
assert.NoError(t, err)
|
||||
})
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue