wireguard-go/src/conn.go

90 lines
1.5 KiB
Go
Raw Normal View History

package main
import (
"errors"
"net"
2017-09-26 13:24:18 +00:00
"time"
)
func parseEndpoint(s string) (*net.UDPAddr, error) {
// ensure that the host is an IP address
host, _, err := net.SplitHostPort(s)
if err != nil {
return nil, err
}
if ip := net.ParseIP(host); ip == nil {
return nil, errors.New("Failed to parse IP address: " + host)
}
// parse address and port
addr, err := net.ResolveUDPAddr("udp", s)
if err != nil {
return nil, err
}
return addr, err
}
func updateUDPConn(device *Device) error {
netc := &device.net
netc.mutex.Lock()
2017-08-17 10:58:18 +00:00
defer netc.mutex.Unlock()
// close existing connection
if netc.conn != nil {
netc.conn.Close()
2017-08-22 15:22:45 +00:00
netc.conn = nil
2017-09-26 13:24:18 +00:00
// We need for that fd to be closed in all other go routines, which
// means we have to wait. TODO: find less horrible way of doing this.
time.Sleep(time.Second / 2)
}
// open new connection
if device.tun.isUp.Get() {
2017-08-17 10:58:18 +00:00
// listen on new address
conn, err := net.ListenUDP("udp", netc.addr)
2017-08-17 10:58:18 +00:00
if err != nil {
return err
}
2017-08-17 10:58:18 +00:00
2017-08-22 15:22:45 +00:00
// set fwmark
err = SetMark(netc.conn, netc.fwmark)
2017-08-22 15:22:45 +00:00
if err != nil {
return err
}
2017-08-17 10:58:18 +00:00
// retrieve port (may have been chosen by kernel)
addr := conn.LocalAddr()
netc.conn = conn
2017-08-22 15:22:45 +00:00
netc.addr, _ = net.ResolveUDPAddr(
addr.Network(),
addr.String(),
)
// notify goroutines
2017-08-17 10:58:18 +00:00
signalSend(device.signal.newUDPConn)
}
2017-08-17 10:58:18 +00:00
return nil
}
func closeUDPConn(device *Device) {
netc := &device.net
netc.mutex.Lock()
if netc.conn != nil {
netc.conn.Close()
}
netc.mutex.Unlock()
signalSend(device.signal.newUDPConn)
}