From 091053e8263758b19d34db05f61e89fee46ddae6 Mon Sep 17 00:00:00 2001 From: "Han Verstraete (OpenFaaS Ltd)" Date: Thu, 30 May 2024 18:39:49 +0200 Subject: [PATCH] Accept a http.Request as argument to InvokeFunction Allow the caller to construct and configure requests as required without limitations imposed by the signature of InvokeFunction. Signed-off-by: Han Verstraete (OpenFaaS Ltd) --- README.md | 11 +++++++---- functions.go | 22 ++++------------------ 2 files changed, 11 insertions(+), 22 deletions(-) diff --git a/README.md b/README.md index 0763041..6f30a58 100644 --- a/README.md +++ b/README.md @@ -146,16 +146,19 @@ Please refer [examples](https://github.com/openfaas/go-sdk/tree/master/examples) ## Invoke functions ```go -header := http.Header{} -header.Set("Content-Type", "text/plain") - body := strings.NewReader("OpenFaaS") +req, err := http.NewRequestWithContext(context.TODO(), http.MethodPost, "/", body) +if err != nil { + panic(err) +} + +req.Header.Set("Content-Type", "text/plain") async := false authenticate := false // Make a POST request to a figlet function in the openfaas-fn namespace -res, err := client.InvokeFunction(context.Background(), "figlet", "openfaas-fn", http.MethodPost, header, nil, body, async, authenticate) +res, err := client.InvokeFunction(context.Background(), "figlet", "openfaas-fn", async, authenticate, req) if err != nil { log.Printf("Failed to invoke function: %s", err) return diff --git a/functions.go b/functions.go index e8d8955..f59ee32 100644 --- a/functions.go +++ b/functions.go @@ -1,17 +1,14 @@ package sdk import ( - "context" "crypto/sha256" "fmt" - "io" "net/http" - "net/url" ) const DefaultNamespace = "openfaas-fn" -func (c *Client) InvokeFunction(ctx context.Context, name, namespace string, method string, header http.Header, query url.Values, body io.Reader, async bool, auth bool) (*http.Response, error) { +func (c *Client) InvokeFunction(name, namespace string, async bool, auth bool, req *http.Request) (*http.Response, error) { fnEndpoint := "/function" if async { fnEndpoint = "/async-function" @@ -21,20 +18,9 @@ func (c *Client) InvokeFunction(ctx context.Context, name, namespace string, met namespace = DefaultNamespace } - u, _ := url.Parse(c.GatewayURL.String()) - u.Path = fmt.Sprintf("%s/%s.%s", fnEndpoint, name, namespace) - u.RawQuery = query.Encode() - - req, err := http.NewRequestWithContext(ctx, method, u.String(), body) - if err != nil { - return nil, err - } - - for key, values := range header { - for _, value := range values { - req.Header.Add(key, value) - } - } + req.URL.Scheme = c.GatewayURL.Scheme + req.URL.Host = c.GatewayURL.Host + req.URL.Path = fmt.Sprintf("%s/%s.%s", fnEndpoint, name, namespace) if auth && c.FunctionTokenSource != nil { idToken, err := c.FunctionTokenSource.Token()