From 8c54ad5ff9253f528d422041efb2620b668a3eb5 Mon Sep 17 00:00:00 2001 From: Jacob Weinstock Date: Sun, 1 Oct 2023 12:24:00 -0600 Subject: [PATCH] User supplied http client in RPC provider: This plumbs through either the default or user supplied http client to the RPC provider. Signed-off-by: Jacob Weinstock --- client.go | 3 +++ providers/rpc/rpc.go | 9 +++++---- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/client.go b/client.go index ba170551..c305fce2 100644 --- a/client.go +++ b/client.go @@ -137,6 +137,9 @@ func (c *Client) defaultTimeout(ctx context.Context) time.Duration { func (c *Client) registerRPCProvider() error { driverRPC := rpc.New(c.providerConfig.rpc.ConsumerURL, c.Auth.Host, c.providerConfig.rpc.Opts.HMAC.Secrets) c.providerConfig.rpc.Logger = c.Logger + httpClient := *c.httpClient + httpClient.Transport = c.httpClient.Transport.(*http.Transport).Clone() + c.providerConfig.rpc.HTTPClient = &httpClient if err := mergo.Merge(driverRPC, c.providerConfig.rpc, mergo.WithOverride, mergo.WithTransformers(&rpc.Provider{})); err != nil { return fmt.Errorf("failed to merge user specified rpc config with the config defaults, rpc provider not available: %w", err) } diff --git a/providers/rpc/rpc.go b/providers/rpc/rpc.go index fd2eaa89..0432c2fd 100644 --- a/providers/rpc/rpc.go +++ b/providers/rpc/rpc.go @@ -13,6 +13,7 @@ import ( "strings" "time" + "github.com/bmc-toolbox/bmclib/v2/internal/httpclient" "github.com/bmc-toolbox/bmclib/v2/providers" "github.com/go-logr/logr" "github.com/jacobweinstock/registrar" @@ -64,8 +65,8 @@ type Provider struct { ConsumerURL string // Host is the BMC ip address or hostname or identifier. Host string - // Client is the http client used for all HTTP calls. - Client *http.Client + // HTTPClient is the http client used for all HTTP calls. + HTTPClient *http.Client // Logger is the logger to use for logging. Logger logr.Logger // LogNotificationsDisabled determines whether responses from rpc consumer/listeners will be logged or not. @@ -136,7 +137,7 @@ func New(consumerURL string, host string, secrets Secrets) *Provider { c := &Provider{ Host: host, ConsumerURL: consumerURL, - Client: http.DefaultClient, + HTTPClient: httpclient.Build(), Logger: logr.Discard(), Opts: Opts{ Request: RequestOpts{ @@ -325,7 +326,7 @@ func (p *Provider) process(ctx context.Context, rp RequestPayload) (ResponsePayl kvs = append(kvs, []interface{}{"params", rp.Params}...) } - resp, err := p.Client.Do(req) + resp, err := p.HTTPClient.Do(req) if err != nil { p.Logger.Error(err, "failed to send rpc notification", kvs...) return ResponsePayload{}, err