dns/udp.go

59 lines
1.5 KiB
Go
Raw Normal View History

2016-03-22 06:27:12 +11:00
// +build !windows,!plan9
2014-07-18 03:48:28 +10:00
package dns
import (
"net"
"syscall"
)
2015-08-23 17:03:13 +10:00
// SessionUDP holds the remote address and the associated
// out-of-band data.
2015-02-28 17:32:41 +11:00
type SessionUDP struct {
raddr *net.UDPAddr
context []byte
}
2015-08-23 17:03:13 +10:00
// RemoteAddr returns the remote network address.
2015-02-28 17:32:41 +11:00
func (s *SessionUDP) RemoteAddr() net.Addr { return s.raddr }
// setUDPSocketOptions sets the UDP socket options.
// This function is implemented on a per platform basis. See udp_*.go for more details
func setUDPSocketOptions(conn *net.UDPConn) error {
sa, err := getUDPSocketName(conn)
if err != nil {
return err
}
switch sa.(type) {
case *syscall.SockaddrInet6:
v6only, err := getUDPSocketOptions6Only(conn)
if err != nil {
return err
}
setUDPSocketOptions6(conn)
if !v6only {
setUDPSocketOptions4(conn)
}
case *syscall.SockaddrInet4:
setUDPSocketOptions4(conn)
2014-07-10 05:07:23 +10:00
}
return nil
2014-07-10 05:07:23 +10:00
}
2014-07-18 03:48:28 +10:00
2015-02-28 17:32:41 +11:00
// ReadFromSessionUDP acts just like net.UDPConn.ReadFrom(), but returns a session object instead of a
2014-07-18 03:48:28 +10:00
// net.UDPAddr.
2015-02-28 17:32:41 +11:00
func ReadFromSessionUDP(conn *net.UDPConn, b []byte) (int, *SessionUDP, error) {
2014-07-18 03:48:28 +10:00
oob := make([]byte, 40)
n, oobn, _, raddr, err := conn.ReadMsgUDP(b, oob)
if err != nil {
return n, nil, err
}
2015-02-28 17:32:41 +11:00
return n, &SessionUDP{raddr, oob[:oobn]}, err
2014-07-18 03:48:28 +10:00
}
2015-02-28 17:32:41 +11:00
// WriteToSessionUDP acts just like net.UDPConn.WritetTo(), but uses a *SessionUDP instead of a net.Addr.
func WriteToSessionUDP(conn *net.UDPConn, b []byte, session *SessionUDP) (int, error) {
2014-07-18 03:48:28 +10:00
n, _, err := conn.WriteMsgUDP(b, session.context, session.raddr)
return n, err
}