From 18061723bbddef80393b809c2cf9096ea2a4f874 Mon Sep 17 00:00:00 2001 From: Vasiliy Tolstov Date: Tue, 31 Mar 2020 22:36:51 +0300 Subject: [PATCH] fix api metadata extract from context (#1452) Signed-off-by: Vasiliy Tolstov --- api/handler/rpc/rpc.go | 16 ++++++++++++++-- api/router/static/static.go | 2 +- 2 files changed, 15 insertions(+), 3 deletions(-) diff --git a/api/handler/rpc/rpc.go b/api/handler/rpc/rpc.go index d7c3c75c..8e830a8c 100644 --- a/api/handler/rpc/rpc.go +++ b/api/handler/rpc/rpc.go @@ -118,6 +118,17 @@ func (h *rpcHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) { // create context cx := ctx.FromRequest(r) + // get context from http handler wrappers + md, ok := r.Context().Value(metadata.MetadataKey{}).(metadata.Metadata) + if !ok { + md = make(metadata.Metadata) + } + + // merge context with overwrite + cx = metadata.MergeContext(cx, md, true) + + // set merged context to request + *r = *r.WithContext(cx) // if stream we currently only support json if isStream(r, service) { @@ -287,6 +298,7 @@ func requestPayload(r *http.Request) ([]byte, error) { // allocate maximum matches := make(map[string]string, len(md)) for k, v := range md { + // filter own keys if strings.HasPrefix(k, "x-api-field-") { matches[strings.TrimPrefix(k, "x-api-field-")] = v delete(md, k) @@ -294,8 +306,8 @@ func requestPayload(r *http.Request) ([]byte, error) { } // restore context without fields - ctx = metadata.NewContext(ctx, md) - *r = *r.WithContext(ctx) + *r = *r.WithContext(metadata.NewContext(ctx, md)) + req := make(map[string]interface{}, len(md)) for k, v := range matches { ps := strings.Split(k, ".") diff --git a/api/router/static/static.go b/api/router/static/static.go index 2f8a0962..f391cd5a 100644 --- a/api/router/static/static.go +++ b/api/router/static/static.go @@ -255,7 +255,7 @@ func (r *staticRouter) endpoint(req *http.Request) (*endpoint, error) { } pMatch = true ctx := req.Context() - md, ok := metadata.FromContext(ctx) + md, ok := ctx.Value(metadata.MetadataKey{}).(metadata.Metadata) if !ok { md = make(metadata.Metadata) }