2016-03-29 17:24:57 +00:00
|
|
|
// +build windows
|
|
|
|
|
|
|
|
package dns
|
|
|
|
|
|
|
|
import "net"
|
|
|
|
|
2020-05-30 14:29:47 +00:00
|
|
|
// SessionUDP holds the remote address
|
2016-03-29 17:24:57 +00:00
|
|
|
type SessionUDP struct {
|
|
|
|
raddr *net.UDPAddr
|
|
|
|
}
|
|
|
|
|
2020-05-30 14:29:47 +00:00
|
|
|
// RemoteAddr returns the remote network address.
|
|
|
|
func (s *SessionUDP) RemoteAddr() net.Addr { return s.raddr }
|
|
|
|
|
2016-03-29 17:24:57 +00:00
|
|
|
// ReadFromSessionUDP acts just like net.UDPConn.ReadFrom(), but returns a session object instead of a
|
|
|
|
// net.UDPAddr.
|
2020-05-30 14:29:47 +00:00
|
|
|
// TODO(fastest963): Once go1.10 is released, use ReadMsgUDP.
|
2016-03-29 17:24:57 +00:00
|
|
|
func ReadFromSessionUDP(conn *net.UDPConn, b []byte) (int, *SessionUDP, error) {
|
|
|
|
n, raddr, err := conn.ReadFrom(b)
|
|
|
|
if err != nil {
|
|
|
|
return n, nil, err
|
|
|
|
}
|
2020-05-30 14:29:47 +00:00
|
|
|
return n, &SessionUDP{raddr.(*net.UDPAddr)}, err
|
2016-03-29 17:24:57 +00:00
|
|
|
}
|
|
|
|
|
2020-05-30 14:29:47 +00:00
|
|
|
// WriteToSessionUDP acts just like net.UDPConn.WriteTo(), but uses a *SessionUDP instead of a net.Addr.
|
|
|
|
// TODO(fastest963): Once go1.10 is released, use WriteMsgUDP.
|
2016-03-29 17:24:57 +00:00
|
|
|
func WriteToSessionUDP(conn *net.UDPConn, b []byte, session *SessionUDP) (int, error) {
|
2020-05-30 14:29:47 +00:00
|
|
|
return conn.WriteTo(b, session.raddr)
|
2016-03-29 17:24:57 +00:00
|
|
|
}
|
|
|
|
|
2020-05-30 14:29:47 +00:00
|
|
|
// TODO(fastest963): Once go1.10 is released and we can use *MsgUDP methods
|
|
|
|
// use the standard method in udp.go for these.
|
|
|
|
func setUDPSocketOptions(*net.UDPConn) error { return nil }
|
|
|
|
func parseDstFromOOB([]byte, net.IP) net.IP { return nil }
|