From ac25702eaf13bb2243f02130ae271ff600f75209 Mon Sep 17 00:00:00 2001 From: "Jason A. Donenfeld" Date: Mon, 1 Apr 2019 12:00:33 +0200 Subject: wintun: rename device using undocumented API that netsh.exe uses --- tun/wintun/netshell/netshell_windows.go | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 tun/wintun/netshell/netshell_windows.go (limited to 'tun/wintun/netshell/netshell_windows.go') diff --git a/tun/wintun/netshell/netshell_windows.go b/tun/wintun/netshell/netshell_windows.go new file mode 100644 index 0000000..cb03252 --- /dev/null +++ b/tun/wintun/netshell/netshell_windows.go @@ -0,0 +1,32 @@ +/* SPDX-License-Identifier: MIT + * + * Copyright (C) 2019 WireGuard LLC. All Rights Reserved. + */ + +package netshell + +import ( + "syscall" + "unsafe" + + "golang.org/x/sys/windows" +) + +var ( + modnetshell = windows.NewLazySystemDLL("netshell.dll") + procHrRenameConnection = modnetshell.NewProc("HrRenameConnection") +) + +func HrRenameConnection(guid *windows.GUID, newName *uint16) (err error) { + err = procHrRenameConnection.Find() + if err != nil { + // Missing from servercore, so we can't presume it's always there. + return + } + + ret, _, _ := syscall.Syscall(procHrRenameConnection.Addr(), 2, uintptr(unsafe.Pointer(guid)), uintptr(unsafe.Pointer(newName)), 0) + if ret != 0 { + err = syscall.Errno(ret) + } + return +} -- cgit v1.2.3