aboutsummaryrefslogtreecommitdiff
path: root/plugin/tls/tls.go
diff options
context:
space:
mode:
Diffstat (limited to 'plugin/tls/tls.go')
-rw-r--r--plugin/tls/tls.go20
1 files changed, 20 insertions, 0 deletions
diff --git a/plugin/tls/tls.go b/plugin/tls/tls.go
index cde543ea0..e87f802ec 100644
--- a/plugin/tls/tls.go
+++ b/plugin/tls/tls.go
@@ -25,6 +25,23 @@ func setup(c *caddy.Controller) error {
return nil
}
+func setTLSDefaults(tls *ctls.Config) {
+ tls.MinVersion = ctls.VersionTLS12
+ tls.MaxVersion = ctls.VersionTLS13
+ tls.CipherSuites = []uint16{
+ ctls.TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384,
+ ctls.TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384,
+ ctls.TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305,
+ ctls.TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305,
+ ctls.TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256,
+ ctls.TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256,
+ ctls.TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384,
+ ctls.TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384,
+ ctls.TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256,
+ }
+ tls.PreferServerCipherSuites = true
+}
+
func parseTLS(c *caddy.Controller) error {
config := dnsserver.GetConfig(c)
@@ -70,6 +87,9 @@ func parseTLS(c *caddy.Controller) error {
tls.ClientAuth = clientAuth
// NewTLSConfigFromArgs only sets RootCAs, so we need to let ClientCAs refer to it.
tls.ClientCAs = tls.RootCAs
+
+ setTLSDefaults(tls)
+
config.TLSConfig = tls
}
return nil