Documentation ¶
Index ¶
- Constants
- Variables
- type AddressFamilyAndProtocol
- func (ap AddressFamilyAndProtocol) IsDatagram() bool
- func (ap AddressFamilyAndProtocol) IsIPv4() bool
- func (ap AddressFamilyAndProtocol) IsIPv6() bool
- func (ap AddressFamilyAndProtocol) IsStream() bool
- func (ap AddressFamilyAndProtocol) IsUnix() bool
- func (ap AddressFamilyAndProtocol) IsUnspec() bool
- type Header
- func (header *Header) EqualTo(otherHeader *Header) bool
- func (header *Header) EqualsTo(otherHeader *Header) bool
- func (header *Header) Format() ([]byte, error)
- func (header *Header) LocalAddr() net.Addr
- func (header *Header) RemoteAddr() net.Addr
- func (header *Header) TLVs() ([]TLV, error)
- func (header *Header) WriteTo(w io.Writer) (int64, error)
- type PP2Type
- type ProtocolVersionAndCommand
- type TLV
Constants ¶
const ( UNSPEC = '\x00' TCPv4 = '\x11' UDPv4 = '\x12' TCPv6 = '\x21' UDPv6 = '\x22' UnixStream = '\x31' UnixDatagram = '\x32' )
const ( // Section 2.2 PP2_TYPE_ALPN PP2Type = 0x01 PP2_TYPE_AUTHORITY = 0x02 PP2_TYPE_CRC32C = 0x03 PP2_TYPE_NOOP = 0x04 PP2_TYPE_SSL = 0x20 PP2_SUBTYPE_SSL_VERSION = 0x21 PP2_SUBTYPE_SSL_CN = 0x22 PP2_SUBTYPE_SSL_CIPHER = 0x23 PP2_SUBTYPE_SSL_SIG_ALG = 0x24 PP2_SUBTYPE_SSL_KEY_ALG = 0x25 PP2_TYPE_NETNS = 0x30 // Section 2.2.7, reserved types PP2_TYPE_MIN_CUSTOM = 0xE0 PP2_TYPE_MAX_CUSTOM = 0xEF PP2_TYPE_MIN_EXPERIMENT = 0xF0 PP2_TYPE_MAX_EXPERIMENT = 0xF7 PP2_TYPE_MIN_FUTURE = 0xF8 PP2_TYPE_MAX_FUTURE = 0xFF )
const ( CRLF = "\r\n" SEPARATOR = " " )
const ( LOCAL = '\x20' PROXY = '\x21' )
Variables ¶
var ( // Protocol SIGV1 = []byte{'\x50', '\x52', '\x4F', '\x58', '\x59'} SIGV2 = []byte{'\x0D', '\x0A', '\x0D', '\x0A', '\x00', '\x0D', '\x0A', '\x51', '\x55', '\x49', '\x54', '\x0A'} ErrCantReadProtocolVersionAndCommand = errors.New("Can't read proxy protocol version and command") ErrCantReadAddressFamilyAndProtocol = errors.New("Can't read address family or protocol") ErrCantReadLength = errors.New("Can't read length") ErrCantResolveSourceUnixAddress = errors.New("Can't resolve source Unix address") ErrCantResolveDestinationUnixAddress = errors.New("Can't resolve destination Unix address") ErrNoProxyProtocol = errors.New("Proxy protocol signature not present") ErrUnknownProxyProtocolVersion = errors.New("Unknown proxy protocol version") ErrUnsupportedProtocolVersionAndCommand = errors.New("Unsupported proxy protocol version and command") ErrUnsupportedAddressFamilyAndProtocol = errors.New("Unsupported address family and protocol") ErrInvalidLength = errors.New("Invalid length") ErrInvalidAddress = errors.New("Invalid address") ErrInvalidPortNumber = errors.New("Invalid port number") )
Functions ¶
This section is empty.
Types ¶
type AddressFamilyAndProtocol ¶
type AddressFamilyAndProtocol byte
AddressFamilyAndProtocol represents address family and transport protocol.
func (AddressFamilyAndProtocol) IsDatagram ¶
func (ap AddressFamilyAndProtocol) IsDatagram() bool
IsDatagram returns true if the transport protocol is UDP or DGRAM (SOCK_DGRAM), false otherwise.
func (AddressFamilyAndProtocol) IsIPv4 ¶
func (ap AddressFamilyAndProtocol) IsIPv4() bool
IsIPv4 returns true if the address family is IPv4 (AF_INET4), false otherwise.
func (AddressFamilyAndProtocol) IsIPv6 ¶
func (ap AddressFamilyAndProtocol) IsIPv6() bool
IsIPv6 returns true if the address family is IPv6 (AF_INET6), false otherwise.
func (AddressFamilyAndProtocol) IsStream ¶
func (ap AddressFamilyAndProtocol) IsStream() bool
IsStream returns true if the transport protocol is TCP or STREAM (SOCK_STREAM), false otherwise.
func (AddressFamilyAndProtocol) IsUnix ¶
func (ap AddressFamilyAndProtocol) IsUnix() bool
IsUnix returns true if the address family is UNIX (AF_UNIX), false otherwise.
func (AddressFamilyAndProtocol) IsUnspec ¶
func (ap AddressFamilyAndProtocol) IsUnspec() bool
IsUnspec returns true if the transport protocol or address family is unspecified, false otherwise.
type Header ¶
type Header struct { Version byte Command ProtocolVersionAndCommand TransportProtocol AddressFamilyAndProtocol SourceAddress net.IP DestinationAddress net.IP SourcePort uint16 DestinationPort uint16 // contains filtered or unexported fields }
Header is the placeholder for proxy protocol header.
func Read ¶
Read identifies the proxy protocol version and reads the remaining of the header, accordingly.
If proxy protocol header signature is not present, the reader buffer remains untouched and is safe for reading outside of this code.
If proxy protocol header signature is present but an error is raised while processing the remaining header, assume the reader buffer to be in a corrupt state. Also, this operation will block until enough bytes are available for peeking.
func ReadTimeout ¶
ReadTimeout acts as Read but takes a timeout. If that timeout is reached, it's assumed there's no proxy protocol header.
func (*Header) EqualTo ¶
EqualTo returns true if headers are equivalent, false otherwise. Deprecated: use EqualsTo instead. This method will eventually be removed.
func (*Header) RemoteAddr ¶
RemoteAddr returns the address of the remote endpoint of the connection.
type PP2Type ¶
type PP2Type byte
PP2Type is the proxy protocol v2 type
func (PP2Type) App ¶
App is true if the type is reserved for application specific data, see section 2.2.7
func (PP2Type) Experiment ¶
Experiment is true if the type is reserved for temporary experimental use by application developers, see section 2.2.7
func (PP2Type) Registered ¶
Registered is true if the type is registered in the spec, see section 2.2
type ProtocolVersionAndCommand ¶
type ProtocolVersionAndCommand byte
ProtocolVersionAndCommand represents proxy protocol version and command.
func (ProtocolVersionAndCommand) IsLocal ¶
func (pvc ProtocolVersionAndCommand) IsLocal() bool
IsLocal returns true if the protocol version is \x2 and command is LOCAL, false otherwise.
func (ProtocolVersionAndCommand) IsProxy ¶
func (pvc ProtocolVersionAndCommand) IsProxy() bool
IsProxy returns true if the protocol version is \x2 and command is PROXY, false otherwise.
func (ProtocolVersionAndCommand) IsUnspec ¶
func (pvc ProtocolVersionAndCommand) IsUnspec() bool
IsUnspec returns true if the protocol version or command is unspecified, false otherwise.