mirror of
https://github.com/ceph/ceph-csi.git
synced 2024-11-25 15:50:20 +00:00
925ea1970c
Bumps the golang-dependencies group with 3 updates: [golang.org/x/crypto](https://github.com/golang/crypto), [golang.org/x/net](https://github.com/golang/net) and [golang.org/x/sys](https://github.com/golang/sys). Updates `golang.org/x/crypto` from 0.28.0 to 0.29.0 - [Commits](https://github.com/golang/crypto/compare/v0.28.0...v0.29.0) Updates `golang.org/x/net` from 0.30.0 to 0.31.0 - [Commits](https://github.com/golang/net/compare/v0.30.0...v0.31.0) Updates `golang.org/x/sys` from 0.26.0 to 0.27.0 - [Commits](https://github.com/golang/sys/compare/v0.26.0...v0.27.0) --- updated-dependencies: - dependency-name: golang.org/x/crypto dependency-type: direct:production update-type: version-update:semver-minor dependency-group: golang-dependencies - dependency-name: golang.org/x/net dependency-type: direct:production update-type: version-update:semver-minor dependency-group: golang-dependencies - dependency-name: golang.org/x/sys dependency-type: direct:production update-type: version-update:semver-minor dependency-group: golang-dependencies ... Signed-off-by: dependabot[bot] <support@github.com>
33 lines
1.1 KiB
Go
33 lines
1.1 KiB
Go
// Copyright 2024 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package http2
|
|
|
|
import (
|
|
"crypto/tls"
|
|
"errors"
|
|
"net"
|
|
)
|
|
|
|
const nextProtoUnencryptedHTTP2 = "unencrypted_http2"
|
|
|
|
// unencryptedNetConnFromTLSConn retrieves a net.Conn wrapped in a *tls.Conn.
|
|
//
|
|
// TLSNextProto functions accept a *tls.Conn.
|
|
//
|
|
// When passing an unencrypted HTTP/2 connection to a TLSNextProto function,
|
|
// we pass a *tls.Conn with an underlying net.Conn containing the unencrypted connection.
|
|
// To be extra careful about mistakes (accidentally dropping TLS encryption in a place
|
|
// where we want it), the tls.Conn contains a net.Conn with an UnencryptedNetConn method
|
|
// that returns the actual connection we want to use.
|
|
func unencryptedNetConnFromTLSConn(tc *tls.Conn) (net.Conn, error) {
|
|
conner, ok := tc.NetConn().(interface {
|
|
UnencryptedNetConn() net.Conn
|
|
})
|
|
if !ok {
|
|
return nil, errors.New("http2: TLS conn unexpectedly found in unencrypted handoff")
|
|
}
|
|
return conner.UnencryptedNetConn(), nil
|
|
}
|