mirror of
https://github.com/kemko/nomad.git
synced 2026-01-06 10:25:42 +03:00
Handle Consul API URL protocol mismatch (#10082)
This commit is contained in:
@@ -1064,6 +1064,10 @@ func (e *external) addr(defaultAddr string) string {
|
||||
if strings.HasPrefix(e.addrVal, "http:") {
|
||||
return e.addrVal
|
||||
}
|
||||
if strings.HasPrefix(e.addrVal, "https:") {
|
||||
// Mismatch: e.ssl=false but addrVal is https
|
||||
return strings.ReplaceAll(e.addrVal, "https://", "http://")
|
||||
}
|
||||
return "http://" + e.addrVal
|
||||
}
|
||||
|
||||
@@ -1072,7 +1076,8 @@ func (e *external) addr(defaultAddr string) string {
|
||||
}
|
||||
|
||||
if strings.HasPrefix(e.addrVal, "http:") {
|
||||
return "https:" + e.addrVal[5:]
|
||||
// Mismatch: e.ssl=true but addrVal is http
|
||||
return strings.ReplaceAll(e.addrVal, "http://", "https://")
|
||||
}
|
||||
|
||||
return "https://" + e.addrVal
|
||||
|
||||
@@ -433,17 +433,35 @@ func TestDebug_Utils(t *testing.T) {
|
||||
require.Empty(t, xs)
|
||||
|
||||
// address calculation honors CONSUL_HTTP_SSL
|
||||
e := &external{addrVal: "http://127.0.0.1:8500", ssl: true}
|
||||
require.Equal(t, "https://127.0.0.1:8500", e.addr("foo"))
|
||||
// ssl: true - Correct alignment
|
||||
e := &external{addrVal: "https://127.0.0.1:8500", ssl: true}
|
||||
addr := e.addr("foo")
|
||||
require.Equal(t, "https://127.0.0.1:8500", addr)
|
||||
|
||||
e = &external{addrVal: "http://127.0.0.1:8500", ssl: false}
|
||||
require.Equal(t, "http://127.0.0.1:8500", e.addr("foo"))
|
||||
|
||||
e = &external{addrVal: "127.0.0.1:8500", ssl: false}
|
||||
require.Equal(t, "http://127.0.0.1:8500", e.addr("foo"))
|
||||
// ssl: true - protocol incorrect
|
||||
e = &external{addrVal: "http://127.0.0.1:8500", ssl: true}
|
||||
addr = e.addr("foo")
|
||||
require.Equal(t, "https://127.0.0.1:8500", addr)
|
||||
|
||||
// ssl: true - protocol missing
|
||||
e = &external{addrVal: "127.0.0.1:8500", ssl: true}
|
||||
require.Equal(t, "https://127.0.0.1:8500", e.addr("foo"))
|
||||
addr = e.addr("foo")
|
||||
require.Equal(t, "https://127.0.0.1:8500", addr)
|
||||
|
||||
// ssl: false - correct alignment
|
||||
e = &external{addrVal: "http://127.0.0.1:8500", ssl: false}
|
||||
addr = e.addr("foo")
|
||||
require.Equal(t, "http://127.0.0.1:8500", addr)
|
||||
|
||||
// ssl: false - protocol incorrect
|
||||
e = &external{addrVal: "https://127.0.0.1:8500", ssl: false}
|
||||
addr = e.addr("foo")
|
||||
require.Equal(t, "http://127.0.0.1:8500", addr)
|
||||
|
||||
// ssl: false - protocol missing
|
||||
e = &external{addrVal: "127.0.0.1:8500", ssl: false}
|
||||
addr = e.addr("foo")
|
||||
require.Equal(t, "http://127.0.0.1:8500", addr)
|
||||
}
|
||||
|
||||
func TestDebug_WriteBytes_Nil(t *testing.T) {
|
||||
|
||||
Reference in New Issue
Block a user