mirror of
https://github.com/minio/minio.git
synced 2026-02-13 06:10:15 -05:00
Add support for sse-s3 encryption with vault as KMS. Also refactoring code to make use of headers and functions defined in crypto package and clean up duplicated code.
58 lines
1.8 KiB
Go
58 lines
1.8 KiB
Go
package cleanhttp
|
|
|
|
import (
|
|
"net"
|
|
"net/http"
|
|
"runtime"
|
|
"time"
|
|
)
|
|
|
|
// DefaultTransport returns a new http.Transport with similar default values to
|
|
// http.DefaultTransport, but with idle connections and keepalives disabled.
|
|
func DefaultTransport() *http.Transport {
|
|
transport := DefaultPooledTransport()
|
|
transport.DisableKeepAlives = true
|
|
transport.MaxIdleConnsPerHost = -1
|
|
return transport
|
|
}
|
|
|
|
// DefaultPooledTransport returns a new http.Transport with similar default
|
|
// values to http.DefaultTransport. Do not use this for transient transports as
|
|
// it can leak file descriptors over time. Only use this for transports that
|
|
// will be re-used for the same host(s).
|
|
func DefaultPooledTransport() *http.Transport {
|
|
transport := &http.Transport{
|
|
Proxy: http.ProxyFromEnvironment,
|
|
DialContext: (&net.Dialer{
|
|
Timeout: 30 * time.Second,
|
|
KeepAlive: 30 * time.Second,
|
|
DualStack: true,
|
|
}).DialContext,
|
|
MaxIdleConns: 100,
|
|
IdleConnTimeout: 90 * time.Second,
|
|
TLSHandshakeTimeout: 10 * time.Second,
|
|
ExpectContinueTimeout: 1 * time.Second,
|
|
MaxIdleConnsPerHost: runtime.GOMAXPROCS(0) + 1,
|
|
}
|
|
return transport
|
|
}
|
|
|
|
// DefaultClient returns a new http.Client with similar default values to
|
|
// http.Client, but with a non-shared Transport, idle connections disabled, and
|
|
// keepalives disabled.
|
|
func DefaultClient() *http.Client {
|
|
return &http.Client{
|
|
Transport: DefaultTransport(),
|
|
}
|
|
}
|
|
|
|
// DefaultPooledClient returns a new http.Client with similar default values to
|
|
// http.Client, but with a shared Transport. Do not use this function for
|
|
// transient clients as it can leak file descriptors over time. Only use this
|
|
// for clients that will be re-used for the same host(s).
|
|
func DefaultPooledClient() *http.Client {
|
|
return &http.Client{
|
|
Transport: DefaultPooledTransport(),
|
|
}
|
|
}
|