Documentation ¶
Index ¶
- Variables
- func CreateConn(t *url.URL, dialer *net.Dialer) (ret net.Conn, err error)
- type Conn
- type ConnectionOption
- type UpgradeOption
- func DisableConnectionHeader(val bool) UpgradeOption
- func DisableHTTP2SettingsHeader(val bool) UpgradeOption
- func DisableUpgradeHeader(val bool) UpgradeOption
- func SetConnectionHeader(val string) UpgradeOption
- func SetHTTP2SettingsHeader(val string) UpgradeOption
- func SetUpgradeHeader(val string) UpgradeOption
- type UpgradeOptions
Constants ¶
This section is empty.
Variables ¶
var ( DefaultDialer = &net.Dialer{ Timeout: time.Millisecond * time.Duration(5000), Resolver: &net.Resolver{ PreferGo: true, Dial: func(ctx context.Context, network, address string) (net.Conn, error) { d := net.Dialer{ Timeout: time.Millisecond * time.Duration(5000), } return d.DialContext(ctx, "udp", "1.1.1.1:53") }, }, } DefaultTransport = &http2.Transport{ AllowHTTP: true, } )
var ( DefaultConnectionHeader = "Upgrade, HTTP2-Settings" DefaultUpgradeHeader = "h2c" DefaultHTTP2SettingsHeader = "AAMAAABkAARAAAAAAAIAAAAA" )
var (
ErrUnexpectedScheme = errors.New("Unexpected scheme for connection")
)
Functions ¶
Types ¶
type Conn ¶
type Conn struct {
// contains filtered or unexported fields
}
Conn encapsulates all the state needed to perform a request over h2c. Internally, this is a singlethreaded connection. Functions can be called concurrently, however they will block on the same thread. For concurrent connections, multiple Conns should be instantiated Initialization of the connection is lazily performed to allow for the caller to customise the request used to upgrade the connection Instantiating a Conn should be done via Client
func NewConn ¶
func NewConn(target string, opts ...ConnectionOption) (*Conn, error)
NewConn will return an unitialized h2csmuggler connection. The first will Do will initialize the connection and perform the upgrade. Target must be a parsable url including protocol e.g. https://google.com path and port will be inferred if not provided (443:https and 80:http) Initialization of the connection is lazily performed to allow for the caller to customise the request used to upgrade the connection
func (*Conn) Close ¶
func (c *Conn) Close()
Close will close the underlying connections. After this is called, the struct is no longer safe to use
func (*Conn) DoUpgrade ¶
DoUpgrade will perform the request and upgrade the connection to http2 h2c. DoUpgrade can only be successfully called once. If called a second time, this will raise an error If unsuccessfully called, it can be called again, however its likely the same connection error will be returned (e.g. timeout, HTTP2 not supported etc...) The provided request will have the following headers added to ensure the upgrade occurs. Upgrade: h2c HTTP2-Settings: AAMAAABkAARAAAAAAAIAAAAA Connection: Upgrade These can be modified with the upgrade options however this may result in an unsuccessful connection TODO: make this threadsafe.
func (*Conn) Initialized ¶
Initialized will return whether this connection has been initialized already
type ConnectionOption ¶
type ConnectionOption func(c *Conn)
func ConnectionDialer ¶
func ConnectionDialer(t *net.Dialer) ConnectionOption
func ConnectionMaxRetries ¶
func ConnectionMaxRetries(v int) ConnectionOption
func ConnectionTransport ¶
func ConnectionTransport(t *http2.Transport) ConnectionOption
type UpgradeOption ¶
type UpgradeOption func(o *UpgradeOptions)
UpgradeOption provides manipulation of the initial upgrade request
func DisableConnectionHeader ¶
func DisableConnectionHeader(val bool) UpgradeOption
func DisableHTTP2SettingsHeader ¶
func DisableHTTP2SettingsHeader(val bool) UpgradeOption
func DisableUpgradeHeader ¶
func DisableUpgradeHeader(val bool) UpgradeOption
func SetConnectionHeader ¶
func SetConnectionHeader(val string) UpgradeOption
func SetHTTP2SettingsHeader ¶
func SetHTTP2SettingsHeader(val string) UpgradeOption
func SetUpgradeHeader ¶
func SetUpgradeHeader(val string) UpgradeOption
type UpgradeOptions ¶
type UpgradeOptions struct { ConnectionHeader string HTTP2SettingsHeader string UpgradeHeader string ConnectionHeaderDisabled bool HTTP2SettingsHeaderDisabled bool UpgradeHeaderDisabled bool }
UpgradeOptions provide manual overrides for the specific headers needed to upgrade the connection to h2c. Fiddling with these may result in an unsuccessful connection
Directories ¶
Path | Synopsis |
---|---|
cmd
|
|
Package h2c implements the unencrypted "h2c" form of HTTP/2.
|
Package h2c implements the unencrypted "h2c" form of HTTP/2. |
Package http2 implements the HTTP/2 protocol.
|
Package http2 implements the HTTP/2 protocol. |
h2c
Package h2c implements the unencrypted "h2c" form of HTTP/2.
|
Package h2c implements the unencrypted "h2c" form of HTTP/2. |
h2i
The h2i command is an interactive HTTP/2 console.
|
The h2i command is an interactive HTTP/2 console. |
hpack
Package hpack implements HPACK, a compression format for efficiently representing HTTP header fields in the context of HTTP/2.
|
Package hpack implements HPACK, a compression format for efficiently representing HTTP header fields in the context of HTTP/2. |
internal
|
|