diff options
author | Simon Rozman <simon@rozman.si> | 2019-02-07 22:02:51 +0100 |
---|---|---|
committer | Simon Rozman <simon@rozman.si> | 2019-02-07 22:02:51 +0100 |
commit | d87cbeeb2fb152b5f377758c68c655e09fe177f3 (patch) | |
tree | 1eb353b53e458b5b573fb2b2e552b15904ba5600 /tun/tun_windows.go | |
parent | 043b7e8013674d58757fe3d3f4e4cacf89c46112 (diff) |
wintun: Detect if a foreign interface with the same name exists
Signed-off-by: Simon Rozman <simon@rozman.si>
Diffstat (limited to 'tun/tun_windows.go')
-rw-r--r-- | tun/tun_windows.go | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/tun/tun_windows.go b/tun/tun_windows.go index 5f4f22a..5c231e7 100644 --- a/tun/tun_windows.go +++ b/tun/tun_windows.go @@ -55,16 +55,26 @@ type nativeTun struct { func CreateTUN(ifname string) (TUNDevice, error) { // Does an interface with this name already exist? wt, err := wintun.GetInterface(ifname, 0) - if wt == nil || err != nil { + if wt == nil { // Interface does not exist or an error occured. Create one. wt, _, err = wintun.CreateInterface("WireGuard Tunnel Adapter", 0) if err != nil { return nil, err } + } else if err != nil { + // Foreign interface with the same name found. + // We could create a Wintun interface under a temporary name. But, should our + // proces die without deleting this interface first, the interface would remain + // orphaned. + return nil, err + } - // Set interface name. (Ignore errors.) - wt.SetInterfaceName(ifname) + err = wt.SetInterfaceName(ifname) + if err != nil { + wt.DeleteInterface(0) + return nil, err } + err = wt.FlushInterface() if err != nil { wt.DeleteInterface(0) |