agent: Adding new VerifyHostname config

This commit is contained in:
Armon Dadgar 2015-05-11 15:13:58 -07:00
parent 6cf2efca0c
commit 59d5992355
2 changed files with 16 additions and 1 deletions

View File

@ -188,6 +188,14 @@ type Config struct {
// certificate authority. This is used to verify authenticity of server nodes. // certificate authority. This is used to verify authenticity of server nodes.
VerifyOutgoing bool `mapstructure:"verify_outgoing"` VerifyOutgoing bool `mapstructure:"verify_outgoing"`
// VerifyServerHostname is used to enable hostname verification of servers. This
// ensures that the certificate presented is valid for server.<datacenter>.<domain>.
// This prevents a compromised client from being restarted as a server, and then
// intercepting request traffic as well as being added as a raft peer. This should be
// enabled by default with VerifyOutgoing, but for legacy reasons we cannot break
// existing clients.
VerifyServerHostname bool `mapstructure:"verify_server_hostname"`
// CAFile is a path to a certificate authority file. This is used with VerifyIncoming // CAFile is a path to a certificate authority file. This is used with VerifyIncoming
// or VerifyOutgoing to verify the TLS connection. // or VerifyOutgoing to verify the TLS connection.
CAFile string `mapstructure:"ca_file"` CAFile string `mapstructure:"ca_file"`
@ -838,6 +846,9 @@ func MergeConfig(a, b *Config) *Config {
if b.VerifyOutgoing { if b.VerifyOutgoing {
result.VerifyOutgoing = true result.VerifyOutgoing = true
} }
if b.VerifyServerHostname {
result.VerifyServerHostname = true
}
if b.CAFile != "" { if b.CAFile != "" {
result.CAFile = b.CAFile result.CAFile = b.CAFile
} }

View File

@ -245,7 +245,7 @@ func TestDecodeConfig(t *testing.T) {
} }
// TLS // TLS
input = `{"verify_incoming": true, "verify_outgoing": true}` input = `{"verify_incoming": true, "verify_outgoing": true, "verify_server_hostname": true}`
config, err = DecodeConfig(bytes.NewReader([]byte(input))) config, err = DecodeConfig(bytes.NewReader([]byte(input)))
if err != nil { if err != nil {
t.Fatalf("err: %s", err) t.Fatalf("err: %s", err)
@ -259,6 +259,10 @@ func TestDecodeConfig(t *testing.T) {
t.Fatalf("bad: %#v", config) t.Fatalf("bad: %#v", config)
} }
if config.VerifyServerHostname != true {
t.Fatalf("bad: %#v", config)
}
// TLS keys // TLS keys
input = `{"ca_file": "my/ca/file", "cert_file": "my.cert", "key_file": "key.pem", "server_name": "example.com"}` input = `{"ca_file": "my/ca/file", "cert_file": "my.cert", "key_file": "key.pem", "server_name": "example.com"}`
config, err = DecodeConfig(bytes.NewReader([]byte(input))) config, err = DecodeConfig(bytes.NewReader([]byte(input)))