Documentation ¶
Overview ¶
Utilities for working with networks and network accessories.
Utilities for working with networks and network accessories.
Index ¶
- Variables
- func DefaultGateway() (net.IP, error)
- func EphemeralPort() (int, error)
- func ExpandPort(address string) string
- func FQDN() string
- func HasRoutableIP(network string, ifi *net.Interface) (net.IP, bool)
- func IsMulticastCapable(network string, ifi *net.Interface) (net.IP, bool)
- func IsRoutableIP(network string, ip net.IP) net.IP
- func OnePingOnly(dest net.IP, source *IPAddress, timeout time.Duration) error
- func RoutedInterface(network string, flags net.Flags) *net.Interface
- func WaitForGatewayPing(totaltime time.Duration) error
- func WaitForGatewayPing6(totaltime time.Duration) error
- func WaitForOpen(network string, address string, totaltime time.Duration, ...) error
- func WaitForPing(addr interface{}, totaltime time.Duration) error
- func ZeroconfDiscover(options *ZeroconfOptions, fn ServiceFunc) error
- func ZeroconfRegister(svc *Service) (string, error)
- func ZeroconfUnregister(id string)
- func ZeroconfUnregisterAll()
- type IPAddress
- type Service
- type ServiceFunc
- type ZeroconfOptions
Constants ¶
This section is empty.
Variables ¶
var DefaultWaitForOpenConnectionTimeout = 5 * time.Second
var WaitForOpenCheckInterval = time.Second
var WaitForPingCheckInterval = time.Second
var WaitForPingReply = 5 * time.Second
Functions ¶
func DefaultGateway ¶
Retrieves the default gateway interface.
func ExpandPort ¶
Takes an address in the form of "host:port", looks for port zero (e.g: ":0"), and gets an ephemeral local port and returns that address (e.g.: ":41327").
func HasRoutableIP ¶
Returns the first routable address on the given interface.
func IsMulticastCapable ¶
IsMulticastCapable reports whether ifi is an IP multicast-capable network interface. Network must be "ip", "ip4" or "ip6".
func IsRoutableIP ¶
Returns true when the given address is unicast routable beyond the current machine.
func OnePingOnly ¶
Send a single ICMP ECHO request packet to the given address on the given interface and wait for up to timeout for a reply.
func RoutedInterface ¶
RoutedInterface returns a network interface that can route IP traffic and satisfies flags. It returns nil when an appropriate network interface is not found. Network must be "ip", "ip4" or "ip6".
func WaitForGatewayPing ¶
Like WaitForPing, but will identify the default gateway and ping that address.
func WaitForGatewayPing6 ¶
Like WaitForGatewayPing, but specifically pings an IPv6 gateway
func WaitForOpen ¶
func WaitForOpen(network string, address string, totaltime time.Duration, timeouts ...time.Duration) error
Periodically attempts to open a TCP socket to the given address, up to totaltime. Returns nil if the socket was opened successfully (which will then immediately be closed), or an error if the function timed out. The check interval can be configured using the WaitForOpenCheckInterval package variable.
func WaitForPing ¶
Periodically attempts to send an ICMP ECHO request (a "ping") to the given IP address, up to totaltime. Returns nil if an ECHO reply was received, or an error if the function timed out. The check interval can be configured using the WaitForPingCheckInterval package variable.
func ZeroconfDiscover ¶
func ZeroconfDiscover(options *ZeroconfOptions, fn ServiceFunc) error
Perform Multicast DNS discovery on the local network, calling the fn callback for each discovered service.
func ZeroconfRegister ¶
Register the given service in Multicast DNS. Returns an ID that can be used to unregister the service later.
func ZeroconfUnregister ¶
func ZeroconfUnregister(id string)
Unregister a previously-registered service.
Types ¶
type IPAddress ¶
func DefaultAddress ¶
func DefaultAddress() *IPAddress
Retrieves the first routable IP address on any interface that falls inside of the system's default gateway network. Will return nil if no IP could be found.
func DefaultAddress6 ¶
func DefaultAddress6() *IPAddress
Like DefaultAddress, but specifically filters on IPv6 addresses. If no routable IPv6 address is found, returns nil.
func GetRoutableAddresses ¶
Returns all addresses on the given interface that can route to the given gateway. If gateway is nil, the default gateway will be attempted.
func RoutableAddresses ¶
Return a list of routable IP addresses, along with their associated gateways and interfaces.
type Service ¶
type Service struct { Hostname string `json:"hostname"` Instance string `json:"instance"` Service string `json:"service"` Domain string `json:"domain"` Port int `json:"port"` Text []string `json:"txt"` Address string `json:"address"` Addresses []net.IP `json:"addresses,omitempty"` Interfaces []net.Interface `json:"interfaces,omitempty"` }