2021-06-30 15:19:10 +02:00
|
|
|
package netxlite
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"crypto/tls"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"github.com/lucas-clemente/quic-go"
|
|
|
|
"github.com/lucas-clemente/quic-go/http3"
|
|
|
|
)
|
|
|
|
|
|
|
|
// http3Dialer adapts a QUICContextDialer to work with
|
|
|
|
// an http3.RoundTripper. This is necessary because the
|
|
|
|
// http3.RoundTripper does not support DialContext.
|
|
|
|
type http3Dialer struct {
|
|
|
|
Dialer QUICContextDialer
|
|
|
|
}
|
|
|
|
|
|
|
|
// dial is like QUICContextDialer.DialContext but without context.
|
|
|
|
func (d *http3Dialer) dial(network, address string, tlsConfig *tls.Config,
|
|
|
|
quicConfig *quic.Config) (quic.EarlySession, error) {
|
|
|
|
return d.Dialer.DialContext(
|
|
|
|
context.Background(), network, address, tlsConfig, quicConfig)
|
|
|
|
}
|
|
|
|
|
|
|
|
// http3Transport is an HTTPTransport using the http3 protocol.
|
|
|
|
type http3Transport struct {
|
|
|
|
child *http3.RoundTripper
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ HTTPTransport = &http3Transport{}
|
|
|
|
|
|
|
|
// RoundTrip implements HTTPTransport.RoundTrip.
|
|
|
|
func (txp *http3Transport) RoundTrip(req *http.Request) (*http.Response, error) {
|
|
|
|
return txp.child.RoundTrip(req)
|
|
|
|
}
|
|
|
|
|
|
|
|
// CloseIdleConnections implements HTTPTransport.CloseIdleConnections.
|
|
|
|
func (txp *http3Transport) CloseIdleConnections() {
|
|
|
|
txp.child.Close()
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewHTTP3Transport creates a new HTTPTransport using http3. The
|
|
|
|
// dialer argument MUST NOT be nil. If the tlsConfig argument is nil,
|
|
|
|
// then the code will use the default TLS configuration.
|
|
|
|
func NewHTTP3Transport(
|
|
|
|
dialer QUICContextDialer, tlsConfig *tls.Config) HTTPTransport {
|
|
|
|
return &http3Transport{
|
|
|
|
child: &http3.RoundTripper{
|
2021-07-01 15:26:08 +02:00
|
|
|
Dial: (&http3Dialer{dialer}).dial,
|
|
|
|
// The following (1) reduces the number of headers that Go will
|
|
|
|
// automatically send for us and (2) ensures that we always receive
|
|
|
|
// back the true headers, such as Content-Length. This change is
|
|
|
|
// functional to OONI's goal of observing the network.
|
|
|
|
DisableCompression: true,
|
|
|
|
TLSClientConfig: tlsConfig,
|
2021-06-30 15:19:10 +02:00
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|