From 01fefd3d928dc4f5a6ecff92e14806c9b4819771 Mon Sep 17 00:00:00 2001 From: Paul Banks Date: Fri, 8 Jun 2018 22:45:34 +0100 Subject: [PATCH] Return defensive error if API response is jank --- connect/resolver.go | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/connect/resolver.go b/connect/resolver.go index bb3e079ed3..2923b81f33 100644 --- a/connect/resolver.go +++ b/connect/resolver.go @@ -139,8 +139,7 @@ func (cr *ConsulResolver) resolveService(ctx context.Context) (string, connect.C idx = rand.Intn(len(svcs)) } - addr, certURI := cr.resolveServiceEntry(svcs[idx]) - return addr, certURI, nil + return cr.resolveServiceEntry(svcs[idx]) } func (cr *ConsulResolver) resolveQuery(ctx context.Context) (string, connect.CertURI, error) { @@ -160,11 +159,10 @@ func (cr *ConsulResolver) resolveQuery(ctx context.Context) (string, connect.Cer idx = rand.Intn(len(svcs)) } - addr, certURI := cr.resolveServiceEntry(&svcs[idx]) - return addr, certURI, nil + return cr.resolveServiceEntry(&svcs[idx]) } -func (cr *ConsulResolver) resolveServiceEntry(entry *api.ServiceEntry) (string, connect.CertURI) { +func (cr *ConsulResolver) resolveServiceEntry(entry *api.ServiceEntry) (string, connect.CertURI, error) { addr := entry.Service.Address if addr == "" { addr = entry.Node.Address @@ -175,6 +173,11 @@ func (cr *ConsulResolver) resolveServiceEntry(entry *api.ServiceEntry) (string, if entry.Service.Connect != nil && entry.Service.Connect.Native { service = entry.Service.Service } + if service == "" { + // Shouldn't happen but to protect against bugs in agent API returning bad + // service response... + return "", nil, fmt.Errorf("not a valid connect service") + } // Generate the expected CertURI certURI := &connect.SpiffeIDService{ @@ -184,7 +187,7 @@ func (cr *ConsulResolver) resolveServiceEntry(entry *api.ServiceEntry) (string, Service: service, } - return fmt.Sprintf("%s:%d", addr, port), certURI + return fmt.Sprintf("%s:%d", addr, port), certURI, nil } func (cr *ConsulResolver) queryOptions(ctx context.Context) *api.QueryOptions {