Documentation ¶
Overview ¶
Package proxy provides support for a variety of protocols to proxy network data.
Index ¶
- Variables
- func RegisterDialerType(scheme string, f func(*url.URL, Dialer) (Dialer, error))
- type Auth
- type Dialer
- type PerHost
- func (p *PerHost) AddFromString(s string)
- func (p *PerHost) AddHost(host string)
- func (p *PerHost) AddIP(ip net.IP)
- func (p *PerHost) AddNetwork(net *net.IPNet)
- func (p *PerHost) AddZone(zone string)
- func (p *PerHost) Dial(network, addr string) (c net.Conn, err error)
- func (p *PerHost) DialContext(ctx context.Context, network, addr string) (c net.Conn, err error)
Constants ¶
This section is empty.
Variables ¶
var Direct = direct{}
Direct is a direct proxy: one that makes network connections directly.
Functions ¶
Types ¶
type Auth ¶
type Auth struct {
User, Password string
}
Auth contains authentication parameters that specific Dialers may require.
type Dialer ¶
type Dialer interface { // Dial connects to the given address via the proxy. Dial(network, addr string) (c net.Conn, err error) // Dial connects to the given address via the proxy using the provided context. DialContext(ctx context.Context, network, addr string) (c net.Conn, err error) }
A Dialer is a means to establish a connection.
func FromEnvironment ¶
func FromEnvironment() Dialer
FromEnvironment returns the dialer specified by the proxy related variables in the environment.
type PerHost ¶
type PerHost struct {
// contains filtered or unexported fields
}
A PerHost directs connections to a default Dialer unless the host name requested matches one of a number of exceptions.
func NewPerHost ¶
NewPerHost returns a PerHost Dialer that directs connections to either defaultDialer or bypass, depending on whether the connection matches one of the configured rules.
func (*PerHost) AddFromString ¶
AddFromString parses a string that contains comma-separated values specifying hosts that should use the bypass proxy. Each value is either an IP address, a CIDR range, a zone (*.example.com) or a host name (localhost). A best effort is made to parse the string and errors are ignored.
func (*PerHost) AddIP ¶
AddIP specifies an IP address that will use the bypass proxy. Note that this will only take effect if a literal IP address is dialed. A connection to a named host will never match an IP.
func (*PerHost) AddNetwork ¶
AddNetwork specifies an IP range that will use the bypass proxy. Note that this will only take effect if a literal IP address is dialed. A connection to a named host will never match.
func (*PerHost) AddZone ¶
AddZone specifies a DNS suffix that will use the bypass proxy. A zone of "example.com" matches "example.com" and all of its subdomains.