From d7106831812f3b69d827148ddfb06a9a48e6c8ad Mon Sep 17 00:00:00 2001 From: Takanori Hirano Date: Fri, 27 Dec 2024 02:20:01 +0900 Subject: [PATCH] Fix PingRecord race condition (#149) --- routine.go | 6 +++++- wireguard.go | 12 +++++++----- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/routine.go b/routine.go index 465e6b1..8c65456 100644 --- a/routine.go +++ b/routine.go @@ -21,6 +21,7 @@ import ( "path" "strconv" "strings" + "sync" "time" "github.com/sourcegraph/conc" @@ -48,7 +49,8 @@ type VirtualTun struct { SystemDNS bool Conf *DeviceConfig // PingRecord stores the last time an IP was pinged - PingRecord map[string]uint64 + PingRecord map[string]uint64 + PingRecordLock *sync.Mutex } // RoutineSpawner spawns a routine (e.g. socks5, tcp static routes) after the configuration is parsed @@ -475,7 +477,9 @@ func (d VirtualTun) pingIPs() { } } + d.PingRecordLock.Lock() d.PingRecord[addr.String()] = uint64(time.Now().Unix()) + d.PingRecordLock.Unlock() defer socket.Close() }() diff --git a/wireguard.go b/wireguard.go index 27fb0f9..71a2960 100644 --- a/wireguard.go +++ b/wireguard.go @@ -3,6 +3,7 @@ package wireproxy import ( "bytes" "fmt" + "sync" "net/netip" @@ -81,10 +82,11 @@ func StartWireguard(conf *DeviceConfig, logLevel int) (*VirtualTun, error) { } return &VirtualTun{ - Tnet: tnet, - Dev: dev, - Conf: conf, - SystemDNS: len(setting.DNS) == 0, - PingRecord: make(map[string]uint64), + Tnet: tnet, + Dev: dev, + Conf: conf, + SystemDNS: len(setting.DNS) == 0, + PingRecord: make(map[string]uint64), + PingRecordLock: new(sync.Mutex), }, nil }