]> git.ipfire.org Git - thirdparty/wireguard-go.git/commitdiff
wintun: also set friendly name after setting interface name
authorJason A. Donenfeld <Jason@zx2c4.com>
Mon, 19 Aug 2019 07:20:23 +0000 (09:20 +0200)
committerJason A. Donenfeld <Jason@zx2c4.com>
Mon, 19 Aug 2019 08:12:50 +0000 (10:12 +0200)
tun/wintun/wintun_windows.go

index 2f8fcc1e4cde5f67daff7dc321b8e75652c90860..4bf17e6476de29c37b0d3a19bce1e4295f7001c1 100644 (file)
@@ -563,19 +563,34 @@ func (wintun *Wintun) InterfaceName() (string, error) {
 
 // SetInterfaceName sets name of the Wintun interface.
 func (wintun *Wintun) SetInterfaceName(ifname string) error {
+       netRegKey, err := registry.OpenKey(registry.LOCAL_MACHINE, wintun.netRegKeyName(), registry.SET_VALUE)
+       if err != nil {
+               return fmt.Errorf("Network-specific registry key open failed: %v", err)
+       }
+       defer netRegKey.Close()
+       err = netRegKey.SetStringValue("Name", ifname)
+       if err != nil {
+               return err
+       }
+       deviceRegKey, err := registry.OpenKey(registry.LOCAL_MACHINE, wintun.deviceRegKeyName(), registry.SET_VALUE)
+       if err != nil {
+               return fmt.Errorf("Device-level registry key open failed: %v", err)
+       }
+       defer deviceRegKey.Close()
+       err = deviceRegKey.SetStringValue("DeviceDesc", deviceTypeName)
+       if err != nil {
+               return err
+       }
+       err = deviceRegKey.SetStringValue("FriendlyName", deviceTypeName)
+       if err != nil {
+               return err
+       }
        // We have to tell the various runtime COM services about the new name too. We ignore the
        // error because netshell isn't available on servercore.
        // TODO: netsh.exe falls back to NciSetConnection in this case. If somebody complains, maybe
        // we should do the same.
        netshell.HrRenameConnection(&wintun.cfgInstanceID, windows.StringToUTF16Ptr(ifname))
-
-       // Set the interface name. The above line should have done this too, but in case it failed, we force it.
-       key, err := registry.OpenKey(registry.LOCAL_MACHINE, wintun.netRegKeyName(), registry.SET_VALUE)
-       if err != nil {
-               return fmt.Errorf("Network-specific registry key open failed: %v", err)
-       }
-       defer key.Close()
-       return key.SetStringValue("Name", ifname)
+       return nil
 }
 
 // netRegKeyName returns the interface-specific network registry key name.