http3: set tls.Config.ServerName for outgoing requests, if unset (#3867)

* fix #3865

* add test case

* Update http3/client, client_test.go

Co-authored-by: Marten Seemann <martenseemann@gmail.com>

---------

Co-authored-by: Marten Seemann <martenseemann@gmail.com>
This commit is contained in:
Glonee 2023-06-01 13:45:56 +08:00 committed by GitHub
parent fce0261c34
commit 21549fcb4a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 25 additions and 0 deletions

View file

@ -6,6 +6,7 @@ import (
"errors"
"fmt"
"io"
"net"
"net/http"
"strconv"
"sync"
@ -92,6 +93,14 @@ func newClient(hostname string, tlsConf *tls.Config, opts *roundTripperOpts, con
} else {
tlsConf = tlsConf.Clone()
}
if tlsConf.ServerName == "" {
sni, _, err := net.SplitHostPort(hostname)
if err != nil {
// It's ok if net.SplitHostPort returns an error - it could be a hostname/IP address without a port.
sni = hostname
}
tlsConf.ServerName = sni
}
// Replace existing ALPNs by H3
tlsConf.NextProtos = []string{versionToALPN(conf.Versions[0])}

View file

@ -90,6 +90,22 @@ var _ = Describe("Client", func() {
Expect(dialAddrCalled).To(BeTrue())
})
It("sets the ServerName in the tls.Config, if not set", func() {
const host = "foo.bar"
dialCalled := false
dialFunc := func(ctx context.Context, addr string, tlsCfg *tls.Config, cfg *quic.Config) (quic.EarlyConnection, error) {
Expect(tlsCfg.ServerName).To(Equal(host))
dialCalled = true
return nil, errors.New("test done")
}
client, err := newClient(host, nil, &roundTripperOpts{}, nil, dialFunc)
Expect(err).ToNot(HaveOccurred())
req, err := http.NewRequest("GET", "https://foo.bar", nil)
Expect(err).ToNot(HaveOccurred())
client.RoundTripOpt(req, RoundTripOpt{})
Expect(dialCalled).To(BeTrue())
})
It("uses the TLS config and QUIC config", func() {
tlsConf := &tls.Config{
ServerName: "foo.bar",