From 95fda1d9cc5c5315ee50d1fb4d8290f5a895a2b5 Mon Sep 17 00:00:00 2001 From: Raphael Simon Date: Sat, 16 Sep 2023 13:55:33 -0700 Subject: [PATCH] Consider service and API level requirements (#3359) When computing the request body in the context of SkipEncodeDecode --- expr/http_body_types.go | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/expr/http_body_types.go b/expr/http_body_types.go index f031af6247..a2be9fbfc2 100644 --- a/expr/http_body_types.go +++ b/expr/http_body_types.go @@ -17,11 +17,21 @@ import ( // single "Authorization" header is used to compute both the username and // password attributes). func defaultRequestHeaderAttributes(e *HTTPEndpointExpr) map[string]bool { - if len(e.MethodExpr.Requirements) == 0 { + var requirements []*SecurityExpr + if e.MethodExpr.Requirements != nil { + requirements = e.MethodExpr.Requirements + } + if e.Service.ServiceExpr.Requirements != nil { + requirements = append(requirements, e.Service.ServiceExpr.Requirements...) + } + if Root.API.Requirements != nil { + requirements = append(requirements, Root.API.Requirements...) + } + if len(requirements) == 0 { return nil } headers := make(map[string]bool) - for _, req := range e.MethodExpr.Requirements { + for _, req := range requirements { for _, sch := range req.Schemes { var field string switch sch.Kind { @@ -343,7 +353,6 @@ func unionToObject(att *AttributeExpr, name, suffix, svcName string) *AttributeE // 3) If the first string is a single word or camelcased, the rest of the // strings are concatenated to form a valid upper camelcase. // e.g. concat("myEndpoint", "streaming", "Body") => "MyEndpointStreamingBody" -// func concat(strs ...string) string { if len(strs) == 1 { return strs[0]