2022-06-06 14:27:25 +02:00
|
|
|
package netx
|
|
|
|
|
|
|
|
//
|
|
|
|
// HTTPTransport from Config.
|
|
|
|
//
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/tls"
|
|
|
|
|
|
|
|
"github.com/ooni/probe-cli/v3/internal/model"
|
|
|
|
"github.com/ooni/probe-cli/v3/internal/netxlite"
|
|
|
|
)
|
|
|
|
|
|
|
|
// NewHTTPTransport creates a new HTTPRoundTripper from the given Config.
|
|
|
|
func NewHTTPTransport(config Config) model.HTTPTransport {
|
|
|
|
if config.Dialer == nil {
|
2022-06-06 15:16:30 +02:00
|
|
|
// TODO(https://github.com/ooni/probe/issues/2121#issuecomment-1147424810)
|
2022-06-06 14:27:25 +02:00
|
|
|
config.Dialer = NewDialer(config)
|
|
|
|
}
|
|
|
|
if config.TLSDialer == nil {
|
2022-06-06 15:16:30 +02:00
|
|
|
// TODO(https://github.com/ooni/probe/issues/2121#issuecomment-1147424810)
|
2022-06-06 14:27:25 +02:00
|
|
|
config.TLSDialer = NewTLSDialer(config)
|
|
|
|
}
|
|
|
|
if config.QUICDialer == nil {
|
2022-06-06 15:16:30 +02:00
|
|
|
// TODO(https://github.com/ooni/probe/issues/2121#issuecomment-1147424810)
|
2022-06-06 14:27:25 +02:00
|
|
|
config.QUICDialer = NewQUICDialer(config)
|
|
|
|
}
|
|
|
|
tInfo := allTransportsInfo[config.HTTP3Enabled]
|
|
|
|
txp := tInfo.Factory(httpTransportConfig{
|
|
|
|
Dialer: config.Dialer,
|
|
|
|
Logger: model.ValidLoggerOrDefault(config.Logger),
|
|
|
|
QUICDialer: config.QUICDialer,
|
|
|
|
TLSDialer: config.TLSDialer,
|
|
|
|
TLSConfig: config.TLSConfig,
|
|
|
|
})
|
2022-06-06 15:16:30 +02:00
|
|
|
// TODO(https://github.com/ooni/probe/issues/2121#issuecomment-1147424810): I am
|
|
|
|
// not super convinced by this code because it
|
2022-06-06 14:27:25 +02:00
|
|
|
// seems we're currently counting bytes twice in some cases. I think we
|
|
|
|
// should review how we're counting bytes and using netx currently.
|
|
|
|
txp = config.ByteCounter.MaybeWrapHTTPTransport(txp) // WAI with ByteCounter == nil
|
|
|
|
const defaultSnapshotSize = 0 // means: use the default snapsize
|
|
|
|
return config.Saver.MaybeWrapHTTPTransport(txp, defaultSnapshotSize) // WAI with Saver == nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// httpTransportInfo contains the constructing function as well as the transport name
|
|
|
|
type httpTransportInfo struct {
|
|
|
|
Factory func(httpTransportConfig) model.HTTPTransport
|
|
|
|
TransportName string
|
|
|
|
}
|
|
|
|
|
|
|
|
var allTransportsInfo = map[bool]httpTransportInfo{
|
|
|
|
false: {
|
2022-06-06 15:16:30 +02:00
|
|
|
Factory: newHTTPTransport,
|
2022-06-06 14:27:25 +02:00
|
|
|
TransportName: "tcp",
|
|
|
|
},
|
|
|
|
true: {
|
|
|
|
Factory: newHTTP3Transport,
|
2022-09-08 17:19:59 +02:00
|
|
|
TransportName: "udp",
|
2022-06-06 14:27:25 +02:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
// httpTransportConfig contains configuration for constructing an HTTPTransport.
|
2022-06-06 15:16:30 +02:00
|
|
|
//
|
|
|
|
// All the fields in this structure MUST be initialized.
|
2022-06-06 14:27:25 +02:00
|
|
|
type httpTransportConfig struct {
|
|
|
|
Dialer model.Dialer
|
|
|
|
Logger model.Logger
|
|
|
|
QUICDialer model.QUICDialer
|
|
|
|
TLSDialer model.TLSDialer
|
|
|
|
TLSConfig *tls.Config
|
|
|
|
}
|
|
|
|
|
|
|
|
// newHTTP3Transport creates a new HTTP3Transport instance.
|
|
|
|
func newHTTP3Transport(config httpTransportConfig) model.HTTPTransport {
|
|
|
|
return netxlite.NewHTTP3Transport(config.Logger, config.QUICDialer, config.TLSConfig)
|
|
|
|
}
|
|
|
|
|
2022-06-06 15:16:30 +02:00
|
|
|
// newHTTPTransport creates a new "system" HTTP transport.
|
|
|
|
func newHTTPTransport(config httpTransportConfig) model.HTTPTransport {
|
2022-06-06 14:27:25 +02:00
|
|
|
return netxlite.NewHTTPTransport(config.Logger, config.Dialer, config.TLSDialer)
|
|
|
|
}
|