From b7fa48fae1205aa0df818009ea59a58c09c4f444 Mon Sep 17 00:00:00 2001 From: Patrick Tescher Date: Tue, 5 Jan 2021 14:07:57 -0800 Subject: [PATCH] Pass context through to external requests Enables proper tracing through Jaeger etc --- pipeline/authn/authenticator_cookie_session.go | 5 +++-- pipeline/authn/authenticator_oauth2_client_credentials.go | 2 +- pipeline/authn/authenticator_oauth2_introspection.go | 2 +- pipeline/authz/keto_engine_acp_ory.go | 2 +- pipeline/authz/remote.go | 2 +- pipeline/authz/remote_json.go | 2 +- pipeline/mutate/mutator_hydrator.go | 2 +- 7 files changed, 9 insertions(+), 8 deletions(-) diff --git a/pipeline/authn/authenticator_cookie_session.go b/pipeline/authn/authenticator_cookie_session.go index 974d745827..00504bec8c 100644 --- a/pipeline/authn/authenticator_cookie_session.go +++ b/pipeline/authn/authenticator_cookie_session.go @@ -133,11 +133,12 @@ func forwardRequestToSessionStore(r *http.Request, checkSessionURL string, prese reqUrl.Path = r.URL.Path } - res, err := http.DefaultClient.Do(&http.Request{ + req := http.Request{ Method: r.Method, URL: reqUrl, Header: r.Header, - }) + } + res, err := http.DefaultClient.Do(req.WithContext(r.Context())) if err != nil { return nil, helper.ErrForbidden.WithReason(err.Error()).WithTrace(err) } diff --git a/pipeline/authn/authenticator_oauth2_client_credentials.go b/pipeline/authn/authenticator_oauth2_client_credentials.go index 7bb3c824c8..7884e4237f 100644 --- a/pipeline/authn/authenticator_oauth2_client_credentials.go +++ b/pipeline/authn/authenticator_oauth2_client_credentials.go @@ -119,7 +119,7 @@ func (a *AuthenticatorOAuth2ClientCredentials) Authenticate(r *http.Request, ses } token, err := c.Token(context.WithValue( - context.Background(), + r.Context(), oauth2.HTTPClient, c.Client, )) diff --git a/pipeline/authn/authenticator_oauth2_introspection.go b/pipeline/authn/authenticator_oauth2_introspection.go index 131ab6d1c3..9d233ef653 100644 --- a/pipeline/authn/authenticator_oauth2_introspection.go +++ b/pipeline/authn/authenticator_oauth2_introspection.go @@ -155,7 +155,7 @@ func (a *AuthenticatorOAuth2Introspection) Authenticate(r *http.Request, session } // set/override the content-type header introspectReq.Header.Set("Content-Type", "application/x-www-form-urlencoded") - resp, err := a.client.Do(introspectReq) + resp, err := a.client.Do(introspectReq.WithContext(r.Context())) if err != nil { return errors.WithStack(err) } diff --git a/pipeline/authz/keto_engine_acp_ory.go b/pipeline/authz/keto_engine_acp_ory.go index 185e113c16..90d1364a19 100644 --- a/pipeline/authz/keto_engine_acp_ory.go +++ b/pipeline/authz/keto_engine_acp_ory.go @@ -160,7 +160,7 @@ func (a *AuthorizerKetoEngineACPORY) Authorize(r *http.Request, session *authn.A } req.Header.Add("Content-Type", "application/json") - res, err := a.client.Do(req) + res, err := a.client.Do(req.WithContext(r.Context())) if err != nil { return errors.WithStack(err) } diff --git a/pipeline/authz/remote.go b/pipeline/authz/remote.go index 6a727e79c6..054e4e22c2 100644 --- a/pipeline/authz/remote.go +++ b/pipeline/authz/remote.go @@ -96,7 +96,7 @@ func (a *AuthorizerRemote) Authorize(r *http.Request, session *authn.Authenticat req.Header.Set(hdr, headerValue.String()) } - res, err := a.client.Do(req) + res, err := a.client.Do(req.WithContext(r.Context())) if err != nil { return errors.WithStack(err) } diff --git a/pipeline/authz/remote_json.go b/pipeline/authz/remote_json.go index bf56473e8b..d54dce6adb 100644 --- a/pipeline/authz/remote_json.go +++ b/pipeline/authz/remote_json.go @@ -89,7 +89,7 @@ func (a *AuthorizerRemoteJSON) Authorize(r *http.Request, session *authn.Authent req.Header.Add("Authorization", authz) } - res, err := a.client.Do(req) + res, err := a.client.Do(req.WithContext(r.Context())) if err != nil { return errors.WithStack(err) } diff --git a/pipeline/mutate/mutator_hydrator.go b/pipeline/mutate/mutator_hydrator.go index 11e24c9a61..9430eefd2d 100644 --- a/pipeline/mutate/mutator_hydrator.go +++ b/pipeline/mutate/mutator_hydrator.go @@ -206,7 +206,7 @@ func (a *MutatorHydrator) Mutate(r *http.Request, session *authn.AuthenticationS client.Transport = httpx.NewResilientRoundTripper(a.client.Transport, maxRetryDelay, giveUpAfter) } - res, err := client.Do(req) + res, err := client.Do(req.WithContext(r.Context())) if err != nil { return errors.WithStack(err) }