const ( Version = 6 // protocol version HeaderLen = 40 // header length )
func NewControlMessage(cf ControlFlags) []byte
NewControlMessage returns a new control message.
The returned message is large enough for options specified by cf.
A Conn represents a network endpoint that uses IPv6 transport. It allows to set basic IP-level socket options such as traffic class and hop limit.
type Conn struct {
// contains filtered or unexported fields
}
▹ Example (MarkingTCP)
func NewConn(c net.Conn) *Conn
NewConn returns a new Conn.
func (c *Conn) HopLimit() (int, error)
HopLimit returns the hop limit field value for outgoing packets.
func (c *Conn) PathMTU() (int, error)
PathMTU returns a path MTU value for the destination associated with the endpoint.
func (c *Conn) SetHopLimit(hoplim int) error
SetHopLimit sets the hop limit field value for future outgoing packets.
func (c *Conn) SetTrafficClass(tclass int) error
SetTrafficClass sets the traffic class field value for future outgoing packets.
func (c *Conn) TrafficClass() (int, error)
TrafficClass returns the traffic class field value for outgoing packets.
A ControlFlags represents per packet basis IP-level socket option control flags.
type ControlFlags uint
const ( FlagTrafficClass ControlFlags = 1 << iota // pass the traffic class on the received packet FlagHopLimit // pass the hop limit on the received packet FlagSrc // pass the source address on the received packet FlagDst // pass the destination address on the received packet FlagInterface // pass the interface index on the received packet FlagPathMTU // pass the path MTU on the received packet path )
A ControlMessage represents per packet basis IP-level socket options.
type ControlMessage struct { // Receiving socket options: SetControlMessage allows to // receive the options from the protocol stack using ReadFrom // method of PacketConn. // // Specifying socket options: ControlMessage for WriteTo // method of PacketConn allows to send the options to the // protocol stack. // TrafficClass int // traffic class, must be 1 <= value <= 255 when specifying HopLimit int // hop limit, must be 1 <= value <= 255 when specifying Src net.IP // source address, specifying only Dst net.IP // destination address, receiving only IfIndex int // interface index, must be 1 <= value when specifying NextHop net.IP // next hop address, specifying only MTU int // path MTU, receiving only }
func (cm *ControlMessage) Marshal() []byte
Marshal returns the binary encoding of cm.
func (cm *ControlMessage) Parse(b []byte) error
Parse parses b as a control message and stores the result in cm.
func (cm *ControlMessage) String() string
A Header represents an IPv6 base header.
type Header struct { Version int // protocol version TrafficClass int // traffic class FlowLabel int // flow label PayloadLen int // payload length NextHeader int // next header HopLimit int // hop limit Src net.IP // source address Dst net.IP // destination address }
func ParseHeader(b []byte) (*Header, error)
ParseHeader parses b as an IPv6 base header.
func (h *Header) String() string
An ICMPFilter represents an ICMP message filter for incoming packets. The filter belongs to a packet delivery path on a host and it cannot interact with forwarding packets or tunnel-outer packets.
Note: RFC 8200 defines a reasonable role model. A node means a device that implements IP. A router means a node that forwards IP packets not explicitly addressed to itself, and a host means a node that is not a router.
type ICMPFilter struct {
// contains filtered or unexported fields
}
func (f *ICMPFilter) Accept(typ ICMPType)
Accept accepts incoming ICMP packets including the type field value typ.
func (f *ICMPFilter) Block(typ ICMPType)
Block blocks incoming ICMP packets including the type field value typ.
func (f *ICMPFilter) SetAll(block bool)
SetAll sets the filter action to the filter.
func (f *ICMPFilter) WillBlock(typ ICMPType) bool
WillBlock reports whether the ICMP type will be blocked.
An ICMPType represents a type of ICMP message.
type ICMPType int
Internet Control Message Protocol version 6 (ICMPv6) Parameters, Updated: 2018-03-09
const ( ICMPTypeDestinationUnreachable ICMPType = 1 // Destination Unreachable ICMPTypePacketTooBig ICMPType = 2 // Packet Too Big ICMPTypeTimeExceeded ICMPType = 3 // Time Exceeded ICMPTypeParameterProblem ICMPType = 4 // Parameter Problem ICMPTypeEchoRequest ICMPType = 128 // Echo Request ICMPTypeEchoReply ICMPType = 129 // Echo Reply ICMPTypeMulticastListenerQuery ICMPType = 130 // Multicast Listener Query ICMPTypeMulticastListenerReport ICMPType = 131 // Multicast Listener Report ICMPTypeMulticastListenerDone ICMPType = 132 // Multicast Listener Done ICMPTypeRouterSolicitation ICMPType = 133 // Router Solicitation ICMPTypeRouterAdvertisement ICMPType = 134 // Router Advertisement ICMPTypeNeighborSolicitation ICMPType = 135 // Neighbor Solicitation ICMPTypeNeighborAdvertisement ICMPType = 136 // Neighbor Advertisement ICMPTypeRedirect ICMPType = 137 // Redirect Message ICMPTypeRouterRenumbering ICMPType = 138 // Router Renumbering ICMPTypeNodeInformationQuery ICMPType = 139 // ICMP Node Information Query ICMPTypeNodeInformationResponse ICMPType = 140 // ICMP Node Information Response ICMPTypeInverseNeighborDiscoverySolicitation ICMPType = 141 // Inverse Neighbor Discovery Solicitation Message ICMPTypeInverseNeighborDiscoveryAdvertisement ICMPType = 142 // Inverse Neighbor Discovery Advertisement Message ICMPTypeVersion2MulticastListenerReport ICMPType = 143 // Version 2 Multicast Listener Report ICMPTypeHomeAgentAddressDiscoveryRequest ICMPType = 144 // Home Agent Address Discovery Request Message ICMPTypeHomeAgentAddressDiscoveryReply ICMPType = 145 // Home Agent Address Discovery Reply Message ICMPTypeMobilePrefixSolicitation ICMPType = 146 // Mobile Prefix Solicitation ICMPTypeMobilePrefixAdvertisement ICMPType = 147 // Mobile Prefix Advertisement ICMPTypeCertificationPathSolicitation ICMPType = 148 // Certification Path Solicitation Message ICMPTypeCertificationPathAdvertisement ICMPType = 149 // Certification Path Advertisement Message ICMPTypeMulticastRouterAdvertisement ICMPType = 151 // Multicast Router Advertisement ICMPTypeMulticastRouterSolicitation ICMPType = 152 // Multicast Router Solicitation ICMPTypeMulticastRouterTermination ICMPType = 153 // Multicast Router Termination ICMPTypeFMIPv6 ICMPType = 154 // FMIPv6 Messages ICMPTypeRPLControl ICMPType = 155 // RPL Control Message ICMPTypeILNPv6LocatorUpdate ICMPType = 156 // ILNPv6 Locator Update Message ICMPTypeDuplicateAddressRequest ICMPType = 157 // Duplicate Address Request ICMPTypeDuplicateAddressConfirmation ICMPType = 158 // Duplicate Address Confirmation ICMPTypeMPLControl ICMPType = 159 // MPL Control Message ICMPTypeExtendedEchoRequest ICMPType = 160 // Extended Echo Request ICMPTypeExtendedEchoReply ICMPType = 161 // Extended Echo Reply )
func (typ ICMPType) Protocol() int
Protocol returns the ICMPv6 protocol number.
func (typ ICMPType) String() string
A Message represents an IO message.
type Message struct { Buffers [][]byte OOB []byte Addr net.Addr N int NN int Flags int }
The Buffers fields represents a list of contiguous buffers, which can be used for vectored IO, for example, putting a header and a payload in each slice. When writing, the Buffers field must contain at least one byte to write. When reading, the Buffers field will always contain a byte to read.
The OOB field contains protocol-specific control or miscellaneous ancillary data known as out-of-band data. It can be nil when not required.
The Addr field specifies a destination address when writing. It can be nil when the underlying protocol of the endpoint uses connection-oriented communication. After a successful read, it may contain the source address on the received packet.
The N field indicates the number of bytes read or written from/to Buffers.
The NN field indicates the number of bytes read or written from/to OOB.
The Flags field contains protocol-specific information on the received message.
type Message = socket.Message
A PacketConn represents a packet network endpoint that uses IPv6 transport. It is used to control several IP-level socket options including IPv6 header manipulation. It also provides datagram based network I/O methods specific to the IPv6 and higher layer protocols such as OSPF, GRE, and UDP.
type PacketConn struct {
// contains filtered or unexported fields
}
▹ Example (AdvertisingOSPFHello)
▹ Example (ServingOneShotMulticastDNS)
▹ Example (TracingIPPacketRoute)
func NewPacketConn(c net.PacketConn) *PacketConn
NewPacketConn returns a new PacketConn using c as its underlying transport.
func (c *PacketConn) Checksum() (on bool, offset int, err error)
Checksum reports whether the kernel will compute, store or verify a checksum for both incoming and outgoing packets. If on is true, it returns an offset in bytes into the data of where the checksum field is located.
func (c *PacketConn) Close() error
Close closes the endpoint.
func (c *PacketConn) ExcludeSourceSpecificGroup(ifi *net.Interface, group, source net.Addr) error
ExcludeSourceSpecificGroup excludes the source-specific group from the already joined any-source groups by JoinGroup on the interface ifi.
func (c *PacketConn) HopLimit() (int, error)
HopLimit returns the hop limit field value for outgoing packets.
func (c *PacketConn) ICMPFilter() (*ICMPFilter, error)
ICMPFilter returns an ICMP filter.
func (c *PacketConn) IncludeSourceSpecificGroup(ifi *net.Interface, group, source net.Addr) error
IncludeSourceSpecificGroup includes the excluded source-specific group by ExcludeSourceSpecificGroup again on the interface ifi.
func (c *PacketConn) JoinGroup(ifi *net.Interface, group net.Addr) error
JoinGroup joins the group address group on the interface ifi. By default all sources that can cast data to group are accepted. It's possible to mute and unmute data transmission from a specific source by using ExcludeSourceSpecificGroup and IncludeSourceSpecificGroup. JoinGroup uses the system assigned multicast interface when ifi is nil, although this is not recommended because the assignment depends on platforms and sometimes it might require routing configuration.
func (c *PacketConn) JoinSourceSpecificGroup(ifi *net.Interface, group, source net.Addr) error
JoinSourceSpecificGroup joins the source-specific group comprising group and source on the interface ifi. JoinSourceSpecificGroup uses the system assigned multicast interface when ifi is nil, although this is not recommended because the assignment depends on platforms and sometimes it might require routing configuration.
func (c *PacketConn) LeaveGroup(ifi *net.Interface, group net.Addr) error
LeaveGroup leaves the group address group on the interface ifi regardless of whether the group is any-source group or source-specific group.
func (c *PacketConn) LeaveSourceSpecificGroup(ifi *net.Interface, group, source net.Addr) error
LeaveSourceSpecificGroup leaves the source-specific group on the interface ifi.
func (c *PacketConn) MulticastHopLimit() (int, error)
MulticastHopLimit returns the hop limit field value for outgoing multicast packets.
func (c *PacketConn) MulticastInterface() (*net.Interface, error)
MulticastInterface returns the default interface for multicast packet transmissions.
func (c *PacketConn) MulticastLoopback() (bool, error)
MulticastLoopback reports whether transmitted multicast packets should be copied and send back to the originator.
func (c *PacketConn) ReadBatch(ms []Message, flags int) (int, error)
ReadBatch reads a batch of messages.
The provided flags is a set of platform-dependent flags, such as syscall.MSG_PEEK.
On a successful read it returns the number of messages received, up to len(ms).
On Linux, a batch read will be optimized. On other platforms, this method will read only a single message.
func (c *PacketConn) ReadFrom(b []byte) (n int, cm *ControlMessage, src net.Addr, err error)
ReadFrom reads a payload of the received IPv6 datagram, from the endpoint c, copying the payload into b. It returns the number of bytes copied into b, the control message cm and the source address src of the received datagram.
func (c *PacketConn) SetBPF(filter []bpf.RawInstruction) error
SetBPF attaches a BPF program to the connection.
Only supported on Linux.
func (c *PacketConn) SetChecksum(on bool, offset int) error
SetChecksum enables the kernel checksum processing. If on is true, the offset should be an offset in bytes into the data of where the checksum field is located.
func (c *PacketConn) SetControlMessage(cf ControlFlags, on bool) error
SetControlMessage allows to receive the per packet basis IP-level socket options.
func (c *PacketConn) SetDeadline(t time.Time) error
SetDeadline sets the read and write deadlines associated with the endpoint.
func (c *PacketConn) SetHopLimit(hoplim int) error
SetHopLimit sets the hop limit field value for future outgoing packets.
func (c *PacketConn) SetICMPFilter(f *ICMPFilter) error
SetICMPFilter deploys the ICMP filter.
func (c *PacketConn) SetMulticastHopLimit(hoplim int) error
SetMulticastHopLimit sets the hop limit field value for future outgoing multicast packets.
func (c *PacketConn) SetMulticastInterface(ifi *net.Interface) error
SetMulticastInterface sets the default interface for future multicast packet transmissions.
func (c *PacketConn) SetMulticastLoopback(on bool) error
SetMulticastLoopback sets whether transmitted multicast packets should be copied and send back to the originator.
func (c *PacketConn) SetReadDeadline(t time.Time) error
SetReadDeadline sets the read deadline associated with the endpoint.
func (c *PacketConn) SetTrafficClass(tclass int) error
SetTrafficClass sets the traffic class field value for future outgoing packets.
func (c *PacketConn) SetWriteDeadline(t time.Time) error
SetWriteDeadline sets the write deadline associated with the endpoint.
func (c *PacketConn) TrafficClass() (int, error)
TrafficClass returns the traffic class field value for outgoing packets.
func (c *PacketConn) WriteBatch(ms []Message, flags int) (int, error)
WriteBatch writes a batch of messages.
The provided flags is a set of platform-dependent flags, such as syscall.MSG_DONTROUTE.
It returns the number of messages written on a successful write.
On Linux, a batch write will be optimized. On other platforms, this method will write only a single message.
func (c *PacketConn) WriteTo(b []byte, cm *ControlMessage, dst net.Addr) (n int, err error)
WriteTo writes a payload of the IPv6 datagram, to the destination address dst through the endpoint c, copying the payload from b. It returns the number of bytes written. The control message cm allows the IPv6 header fields and the datagram path to be specified. The cm may be nil if control of the outgoing datagram is not required.
On Windows, the ReadBatch and WriteBatch methods of PacketConn are not implemented.
This package is not implemented on JS, NaCl and Plan 9.
On Windows, the JoinSourceSpecificGroup, LeaveSourceSpecificGroup, ExcludeSourceSpecificGroup and IncludeSourceSpecificGroup methods of PacketConn are not implemented.
On Windows, methods related to ICMPFilter are not implemented.
On Windows, the ControlMessage for ReadFrom and WriteTo methods of PacketConn is not implemented.