diff --git a/pkg/client/acr/acr.go b/pkg/client/acr/acr.go index 630f8989..de003b6d 100644 --- a/pkg/client/acr/acr.go +++ b/pkg/client/acr/acr.go @@ -55,7 +55,8 @@ type ACRManifestResponse struct { func New(opts Options) (*Client, error) { client := &http.Client{ - Timeout: time.Second * 5, + Timeout: time.Second * 5, + Transport: &http.Transport{Proxy: http.ProxyFromEnvironment}, } if len(opts.RefreshToken) > 0 && diff --git a/pkg/client/docker/docker.go b/pkg/client/docker/docker.go index 27b2dbb6..9dcdc364 100644 --- a/pkg/client/docker/docker.go +++ b/pkg/client/docker/docker.go @@ -52,7 +52,8 @@ type Image struct { func New(ctx context.Context, opts Options) (*Client, error) { client := &http.Client{ - Timeout: time.Second * 10, + Timeout: time.Second * 10, + Transport: &http.Transport{Proxy: http.ProxyFromEnvironment}, } // Setup Auth if username and password used. diff --git a/pkg/client/ecr/ecr.go b/pkg/client/ecr/ecr.go index 12265862..935ee179 100644 --- a/pkg/client/ecr/ecr.go +++ b/pkg/client/ecr/ecr.go @@ -3,6 +3,7 @@ package ecr import ( "context" "fmt" + "net/http" "sync" "github.com/aws/aws-sdk-go/aws" @@ -102,6 +103,8 @@ func (c *Client) getClient(region string) (*ecr.ECR, error) { return nil, err } } + // Try and use an HTTP(S) Proxies defined within Environment variables. + client.Config.WithHTTPClient(&http.Client{Transport: &http.Transport{Proxy: http.ProxyFromEnvironment}}) c.cachedRegionClients[region] = client return client, nil diff --git a/pkg/client/gcr/gcr.go b/pkg/client/gcr/gcr.go index 19dd3b19..d94a2ba0 100644 --- a/pkg/client/gcr/gcr.go +++ b/pkg/client/gcr/gcr.go @@ -35,11 +35,14 @@ type ManifestItem struct { } func New(opts Options) *Client { + client := &http.Client{ + Timeout: time.Second * 5, + Transport: &http.Transport{Proxy: http.ProxyFromEnvironment}, + } + return &Client{ Options: opts, - Client: &http.Client{ - Timeout: time.Second * 5, - }, + Client: client, } } diff --git a/pkg/client/ghcr/ghcr.go b/pkg/client/ghcr/ghcr.go index 33595840..fbbfd7f6 100644 --- a/pkg/client/ghcr/ghcr.go +++ b/pkg/client/ghcr/ghcr.go @@ -25,7 +25,8 @@ func New(opts Options) *Client { return &Client{ Options: opts, Client: &http.Client{ - Timeout: time.Second * 5, + Timeout: time.Second * 5, + Transport: &http.Transport{Proxy: http.ProxyFromEnvironment}, }, } } diff --git a/pkg/client/quay/quay.go b/pkg/client/quay/quay.go index ca6031e9..3578f99e 100644 --- a/pkg/client/quay/quay.go +++ b/pkg/client/quay/quay.go @@ -59,6 +59,7 @@ type responseManifestDataItem struct { func New(opts Options) *Client { client := retryablehttp.NewClient() + client.HTTPClient.Transport = &http.Transport{Proxy: http.ProxyFromEnvironment} client.RetryMax = 10 client.Logger = nil