generic_http.go 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. // Generic HTTP transport for imgproxy
  2. package generichttp
  3. import (
  4. "crypto/tls"
  5. "net"
  6. "net/http"
  7. "syscall"
  8. "time"
  9. "github.com/imgproxy/imgproxy/v3/config"
  10. "github.com/imgproxy/imgproxy/v3/security"
  11. "golang.org/x/net/http2"
  12. )
  13. func New(verifyNetworks bool) (*http.Transport, error) {
  14. dialer := &net.Dialer{
  15. Timeout: 30 * time.Second,
  16. KeepAlive: 30 * time.Second,
  17. DualStack: true,
  18. }
  19. if verifyNetworks {
  20. dialer.Control = func(network, address string, c syscall.RawConn) error {
  21. return security.VerifySourceNetwork(address)
  22. }
  23. }
  24. transport := &http.Transport{
  25. Proxy: http.ProxyFromEnvironment,
  26. DialContext: dialer.DialContext,
  27. MaxIdleConns: 100,
  28. MaxIdleConnsPerHost: config.Workers + 1,
  29. IdleConnTimeout: time.Duration(config.ClientKeepAliveTimeout) * time.Second,
  30. TLSHandshakeTimeout: 10 * time.Second,
  31. ExpectContinueTimeout: 1 * time.Second,
  32. ForceAttemptHTTP2: false,
  33. DisableCompression: true,
  34. }
  35. if config.ClientKeepAliveTimeout <= 0 {
  36. transport.MaxIdleConnsPerHost = -1
  37. transport.DisableKeepAlives = true
  38. }
  39. if config.IgnoreSslVerification {
  40. transport.TLSClientConfig = &tls.Config{InsecureSkipVerify: true}
  41. }
  42. transport2, err := http2.ConfigureTransports(transport)
  43. if err != nil {
  44. return nil, err
  45. }
  46. transport2.PingTimeout = 5 * time.Second
  47. transport2.ReadIdleTimeout = time.Second
  48. return transport, nil
  49. }