Documentation ¶
Index ¶
- Constants
- Variables
- func AddDefaultRoute(gw net.IP, dev netlink.Link) error
- func AddHostRoute(ipn *net.IPNet, gw net.IP, dev netlink.Link) error
- func AddRoute(ipn *net.IPNet, gw net.IP, dev netlink.Link) error
- func Cmp(a, b net.IP) int
- func DelLinkByName(ifName string) error
- func DelLinkByNameAddr(ifName string) ([]*net.IPNet, error)
- func EnableForward(ips []*current.IPConfig) error
- func EnableIP4Forward() error
- func EnableIP6Forward() error
- func GCIPMasqForNetwork(network string, attachments []types.GCAttachment) error
- func GetVethPeerIfindex(ifName string) (netlink.Link, int, error)
- func IsIPNetZero(ipnet *net.IPNet) bool
- func Network(ipn *net.IPNet) *net.IPNet
- func NextIP(ip net.IP) net.IP
- func PrevIP(ip net.IP) net.IP
- func RandomVethName() (string, error)
- func RenameLink(curName, newName string) error
- func SettleAddresses(ifName string, timeout int) error
- func SetupIPMasq(ipn *net.IPNet, chain string, comment string) error
- func SetupIPMasqForNetworks(backend *string, ipns []*net.IPNet, network, ifname, containerID string) error
- func SetupVeth(contVethName string, mtu int, contVethMac string, hostNS ns.NetNS) (net.Interface, net.Interface, error)
- func SetupVethWithName(contVethName, hostVethName string, mtu int, contVethMac string, ...) (net.Interface, net.Interface, error)
- func TeardownIPMasq(ipn *net.IPNet, chain string, comment string) error
- func TeardownIPMasqForNetworks(ipns []*net.IPNet, network, ifname, containerID string) error
- func ValidateExpectedInterfaceIPs(ifName string, resultIPs []*current.IPConfig) error
- func ValidateExpectedRoute(resultRoutes []*types.Route) error
- type IP
Constants ¶
const SETTLE_INTERVAL = 50 * time.Millisecond
Variables ¶
var ErrLinkNotFound = errors.New("link not found")
Functions ¶
func AddDefaultRoute ¶
AddDefaultRoute sets the default route on the given gateway.
func AddHostRoute ¶
AddHostRoute adds a host-scoped route to a device.
func Cmp ¶ added in v0.6.0
Cmp compares two IPs, returning the usual ordering: a < b : -1 a == b : 0 a > b : 1 incomparable : -2
func DelLinkByName ¶
DelLinkByName removes an interface link.
func DelLinkByNameAddr ¶
DelLinkByNameAddr remove an interface and returns its addresses
func EnableForward ¶ added in v0.6.0
EnableForward will enable forwarding for all configured address families
func EnableIP4Forward ¶
func EnableIP4Forward() error
func EnableIP6Forward ¶
func EnableIP6Forward() error
func GCIPMasqForNetwork ¶ added in v1.6.0
func GCIPMasqForNetwork(network string, attachments []types.GCAttachment) error
GCIPMasqForNetwork garbage collects stale IPMasq entries for network
func GetVethPeerIfindex ¶ added in v0.8.0
GetVethPeerIfindex returns the veth link object, the peer ifindex of the veth, or an error. This peer ifindex will only be valid in the peer's network namespace.
func IsIPNetZero ¶ added in v1.6.0
IsIPNetZero check if the IPNet is "0.0.0.0/0" or "::/0" This is needed as go-netlink replaces nil Dst with a '0' IPNet since https://github.com/vishvananda/netlink/commit/acdc658b8613655ddb69f978e9fb4cf413e2b830
func RandomVethName ¶
RandomVethName returns string "veth" with random prefix (hashed from entropy)
func RenameLink ¶ added in v0.6.0
func SettleAddresses ¶ added in v0.6.0
SettleAddresses waits for all addresses on a link to leave tentative state. This is particularly useful for ipv6, where all addresses need to do DAD. There is no easy way to wait for this as an event, so just loop until the addresses are no longer tentative. If any addresses are still tentative after timeout seconds, then error.
func SetupIPMasq ¶
SetupIPMasq installs iptables rules to masquerade traffic coming from ip of ipn and going outside of ipn. Deprecated: This function only supports iptables. Use SetupIPMasqForNetworks, which supports both iptables and nftables.
func SetupIPMasqForNetworks ¶ added in v1.6.1
func SetupIPMasqForNetworks(backend *string, ipns []*net.IPNet, network, ifname, containerID string) error
SetupIPMasqForNetworks installs rules to masquerade traffic coming from ips of ipns and going outside of ipns, using a chain name based on network, ifname, and containerID. The backend can be either "iptables" or "nftables"; if it is nil, then a suitable default implementation will be used.
func SetupVeth ¶
func SetupVeth(contVethName string, mtu int, contVethMac string, hostNS ns.NetNS) (net.Interface, net.Interface, error)
SetupVeth sets up a pair of virtual ethernet devices. Call SetupVeth from inside the container netns. It will create both veth devices and move the host-side veth into the provided hostNS namespace. On success, SetupVeth returns (hostVeth, containerVeth, nil)
func SetupVethWithName ¶ added in v0.8.2
func SetupVethWithName(contVethName, hostVethName string, mtu int, contVethMac string, hostNS ns.NetNS) (net.Interface, net.Interface, error)
SetupVethWithName sets up a pair of virtual ethernet devices. Call SetupVethWithName from inside the container netns. It will create both veth devices and move the host-side veth into the provided hostNS namespace. hostVethName: If hostVethName is not specified, the host-side veth name will use a random string. On success, SetupVethWithName returns (hostVeth, containerVeth, nil)
func TeardownIPMasq ¶
TeardownIPMasq undoes the effects of SetupIPMasq. Deprecated: This function only supports iptables. Use TeardownIPMasqForNetworks, which supports both iptables and nftables.
func TeardownIPMasqForNetworks ¶ added in v1.6.1
TeardownIPMasqForNetworks undoes the effects of SetupIPMasqForNetworks
func ValidateExpectedInterfaceIPs ¶ added in v0.8.0
func ValidateExpectedRoute ¶ added in v0.8.0
Types ¶
type IP ¶ added in v1.0.0
IP is a CNI maintained type inherited from net.IPNet which can represent a single IP address with or without prefix.
func ParseIP ¶ added in v1.0.0
ParseIP will parse string s as an IP, and return it. The string s must be formed like <ip>[/<prefix>]. If s is not a valid textual representation of an IP, will return nil.
func (*IP) MarshalText ¶ added in v1.0.0
MarshalText implements the encoding.TextMarshaler interface. The encoding is the same as returned by String, But when len(ip) is zero, will return an empty slice.
func (*IP) ToIP ¶ added in v1.0.0
ToIP will return a net.IP in standard form from this IP. If this IP can not be converted to a valid net.IP, will return nil.
func (*IP) UnmarshalText ¶ added in v1.0.0
UnmarshalText implements the encoding.TextUnmarshaler interface. The textual bytes are expected in a form accepted by Parse, But when len(b) is zero, will return an empty IP.