From c545d63bb93b8192dfdc7037952fc2661dd1222b Mon Sep 17 00:00:00 2001 From: "Jason A. Donenfeld" Date: Thu, 21 Sep 2017 03:09:57 +0200 Subject: Fix up fwmark handling --- src/uapi.go | 40 +++++++++++++++++++++++++--------------- 1 file changed, 25 insertions(+), 15 deletions(-) (limited to 'src/uapi.go') diff --git a/src/uapi.go b/src/uapi.go index 871232c..428b173 100644 --- a/src/uapi.go +++ b/src/uapi.go @@ -42,6 +42,9 @@ func ipcGetOperation(device *Device, socket *bufio.ReadWriter) *IPCError { if device.net.addr != nil { send(fmt.Sprintf("listen_port=%d", device.net.addr.Port)) } + if device.net.fwmark != 0 { + send(fmt.Sprintf("fwmark=%d", device.net.fwmark)) + } for _, peer := range device.peers { func() { @@ -158,25 +161,32 @@ func ipcSetOperation(device *Device, socket *bufio.ReadWriter) *IPCError { // TODO: Clear source address of all peers case "fwmark": - fwmark, err := strconv.ParseInt(value, 10, 32) - if err != nil { - logError.Println("Invalid fwmark", err) - return &IPCError{Code: ipcErrorInvalid} + var fwmark uint64 = 0 + if value != "" { + var err error + fwmark, err = strconv.ParseUint(value, 10, 32) + if err != nil { + logError.Println("Invalid fwmark", err) + return &IPCError{Code: ipcErrorInvalid} + } } device.net.mutex.Lock() - device.net.fwmark = int(fwmark) - err = setMark( - device.net.conn, - device.net.fwmark, - ) - device.net.mutex.Unlock() - if err != nil { - logError.Println("Failed to set fwmark:", err) - return &IPCError{Code: ipcErrorIO} - } + if fwmark > 0 || device.net.fwmark > 0 { + device.net.fwmark = uint32(fwmark) + err := setMark( + device.net.conn, + device.net.fwmark, + ) + if err != nil { + logError.Println("Failed to set fwmark:", err) + device.net.mutex.Unlock() + return &IPCError{Code: ipcErrorIO} + } - // TODO: Clear source address of all peers + // TODO: Clear source address of all peers + } + device.net.mutex.Unlock() case "public_key": -- cgit v1.2.3