net

package
v0.0.10 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 5, 2024 License: BSD-3-Clause Imports: 10 Imported by: 0

Documentation

Index

Constants

View Source
const (
	// NetbirdFwmark is the fwmark value used by Netbird via wireguard
	NetbirdFwmark = 0x1BD00
)

Variables

This section is empty.

Functions

func AddDialerCloseHook

func AddDialerCloseHook(hook DialerCloseHookFunc)

AddDialerCloseHook allows adding a new hook to be executed on connection close.

func AddDialerHook

func AddDialerHook(hook DialerDialHookFunc)

AddDialerHook allows adding a new hook to be executed before dialing.

func AddListenerCloseHook

func AddListenerCloseHook(hook ListenerCloseHookFunc)

AddListenerCloseHook allows adding a new hook to be executed upon closing a UDP connection.

func AddListenerWriteHook

func AddListenerWriteHook(hook ListenerWriteHookFunc)

AddListenerWriteHook allows adding a new write hook to be executed before a UDP packet is sent.

func CustomRoutingDisabled

func CustomRoutingDisabled() bool

func DialTCP

func DialTCP(network string, laddr, raddr *net.TCPAddr) (*net.TCPConn, error)

func DialUDP

func DialUDP(network string, laddr, raddr *net.UDPAddr) (*net.UDPConn, error)

func ListenUDP

func ListenUDP(network string, laddr *net.UDPAddr) (transport.UDPConn, error)

ListenUDP listens on the network address and returns a transport.UDPConn which includes support for write and close hooks.

func RemoveDialerHooks

func RemoveDialerHooks()

RemoveDialerHooks removes all dialer hooks.

func RemoveListenerHooks

func RemoveListenerHooks()

RemoveListenerHooks removes all dialer hooks.

func SetRawSocketMark

func SetRawSocketMark(conn syscall.RawConn) error

func SetSocketMark

func SetSocketMark(conn syscall.Conn) error

SetSocketMark sets the SO_MARK option on the given socket connection

func SetSocketOpt

func SetSocketOpt(fd int) error

Types

type Conn

type Conn struct {
	net.Conn
	ID ConnectionID
}

Conn wraps a net.Conn to override the Close method

func (*Conn) Close

func (c *Conn) Close() error

Close overrides the net.Conn Close method to execute all registered hooks after closing the connection

type ConnectionID

type ConnectionID string

ConnectionID provides a globally unique identifier for network connections. It's used to track connections throughout their lifecycle so the close hook can correlate with the dial hook.

func GenerateConnID

func GenerateConnID() ConnectionID

GenerateConnID generates a unique identifier for each connection.

type Dialer

type Dialer struct {
	*net.Dialer
}

Dialer extends the standard net.Dialer with the ability to execute hooks before and after connections. This can be used to bypass the VPN for connections using this dialer.

func NewDialer

func NewDialer() *Dialer

NewDialer returns a customized net.Dialer with overridden Control method

func (*Dialer) Dial

func (d *Dialer) Dial(network, address string) (net.Conn, error)

Dial wraps the net.Dialer's Dial method to use the custom connection

func (*Dialer) DialContext

func (d *Dialer) DialContext(ctx context.Context, network, address string) (net.Conn, error)

DialContext wraps the net.Dialer's DialContext method to use the custom connection

type DialerCloseHookFunc

type DialerCloseHookFunc func(connID ConnectionID, conn *net.Conn) error

type DialerDialHookFunc

type DialerDialHookFunc func(ctx context.Context, connID ConnectionID, resolvedAddresses []net.IPAddr) error

type ListenerCloseHookFunc

type ListenerCloseHookFunc func(connID ConnectionID, conn net.PacketConn) error

ListenerCloseHookFunc defines the function signature for close hooks for PacketConn.

type ListenerConfig

type ListenerConfig struct {
	*net.ListenConfig
}

ListenerConfig extends the standard net.ListenConfig with the ability to execute hooks before responding via the socket and after closing. This can be used to bypass the VPN for listeners.

func NewListener

func NewListener() *ListenerConfig

NewListener creates a new ListenerConfig instance.

func (*ListenerConfig) ListenPacket

func (l *ListenerConfig) ListenPacket(ctx context.Context, network, address string) (net.PacketConn, error)

ListenPacket listens on the network address and returns a PacketConn which includes support for write hooks.

type ListenerWriteHookFunc

type ListenerWriteHookFunc func(connID ConnectionID, ip *net.IPAddr, data []byte) error

ListenerWriteHookFunc defines the function signature for write hooks for PacketConn.

type PacketConn

type PacketConn struct {
	net.PacketConn
	ID ConnectionID
	// contains filtered or unexported fields
}

PacketConn wraps net.PacketConn to override its WriteTo and Close methods to include hook functionality.

func (*PacketConn) Close

func (c *PacketConn) Close() error

Close overrides the net.PacketConn Close method to execute all registered hooks before closing the connection.

func (*PacketConn) WriteTo

func (c *PacketConn) WriteTo(b []byte, addr net.Addr) (n int, err error)

WriteTo writes a packet with payload b to addr, executing registered write hooks beforehand.

type UDPConn

type UDPConn struct {
	*net.UDPConn
	ID ConnectionID
	// contains filtered or unexported fields
}

UDPConn wraps net.UDPConn to override its WriteTo and Close methods to include hook functionality.

func (*UDPConn) Close

func (c *UDPConn) Close() error

Close overrides the net.UDPConn Close method to execute all registered hooks before closing the connection.

func (*UDPConn) WriteTo

func (c *UDPConn) WriteTo(b []byte, addr net.Addr) (n int, err error)

WriteTo writes a packet with payload b to addr, executing registered write hooks beforehand.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL