From efcc46f69f8d9452f73f12790f58d723a0419e58 Mon Sep 17 00:00:00 2001 From: Stuart Douglas Date: Fri, 26 Jul 2024 11:15:59 +1000 Subject: [PATCH] fix: don't include error in response Also make sure we log errors related to HTTP processing. closes #2162 --- backend/controller/ingress/handler.go | 24 ++++++++++++++++-------- 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/backend/controller/ingress/handler.go b/backend/controller/ingress/handler.go index cb7ff5fba0..7137d79ebe 100644 --- a/backend/controller/ingress/handler.go +++ b/backend/controller/ingress/handler.go @@ -35,13 +35,16 @@ func Handle( http.NotFound(w, r) return } - http.Error(w, err.Error(), http.StatusInternalServerError) + logger.Errorf(err, "failed to resolve route for %s %s", r.Method, r.URL.Path) + http.Error(w, http.StatusText(http.StatusInternalServerError), http.StatusInternalServerError) return } body, err := BuildRequestBody(route, r, sch) if err != nil { - http.Error(w, err.Error(), http.StatusBadRequest) + // Only log at debug, as this is a client side error + logger.Debugf("bad request: %s", err.Error()) + http.Error(w, http.StatusText(http.StatusBadRequest), http.StatusBadRequest) return } @@ -53,10 +56,12 @@ func Handle( resp, err := call(r.Context(), creq, optional.Some(requestKey), r.RemoteAddr) if err != nil { + logger.Errorf(err, "failed to call verb %s", route.Verb) if connectErr := new(connect.Error); errors.As(err, &connectErr) { - http.Error(w, err.Error(), connectCodeToHTTP(connectErr.Code())) + httpCode := connectCodeToHTTP(connectErr.Code()) + http.Error(w, http.StatusText(httpCode), httpCode) } else { - http.Error(w, err.Error(), http.StatusInternalServerError) + http.Error(w, http.StatusText(http.StatusInternalServerError), http.StatusInternalServerError) } return } @@ -65,7 +70,8 @@ func Handle( verb := &schema.Verb{} err = sch.ResolveToType(&schema.Ref{Name: route.Verb, Module: route.Module}, verb) if err != nil { - http.Error(w, err.Error(), http.StatusInternalServerError) + logger.Errorf(err, "could not resolve schema type for verb %s", route.Verb) + http.Error(w, http.StatusText(http.StatusInternalServerError), http.StatusInternalServerError) return } var responseBody []byte @@ -73,14 +79,16 @@ func Handle( if metadata, ok := verb.GetMetadataIngress().Get(); ok && metadata.Type == "http" { var response HTTPResponse if err := json.Unmarshal(msg.Body, &response); err != nil { - http.Error(w, err.Error(), http.StatusInternalServerError) + logger.Errorf(err, "could not unmarhal response for verb %s", verb) + http.Error(w, http.StatusText(http.StatusInternalServerError), http.StatusInternalServerError) return } var responseHeaders http.Header responseBody, responseHeaders, err = ResponseForVerb(sch, verb, response) if err != nil { - http.Error(w, err.Error(), http.StatusInternalServerError) + logger.Errorf(err, "could not create response for verb %s", verb) + http.Error(w, http.StatusText(http.StatusInternalServerError), http.StatusInternalServerError) return } @@ -102,7 +110,7 @@ func Handle( } case *ftlv1.CallResponse_Error_: - http.Error(w, msg.Error.Message, http.StatusInternalServerError) + http.Error(w, http.StatusText(http.StatusInternalServerError), http.StatusInternalServerError) } }