2022-01-17 14:01:58 +01:00
|
|
|
//go:build linux || darwin
|
2021-06-06 00:40:44 +02:00
|
|
|
// +build linux darwin
|
|
|
|
|
|
|
|
package iface
|
|
|
|
|
|
|
|
import (
|
2023-02-13 18:34:56 +01:00
|
|
|
"net"
|
|
|
|
"os"
|
|
|
|
|
2022-01-17 14:01:58 +01:00
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
"golang.zx2c4.com/wireguard/conn"
|
|
|
|
"golang.zx2c4.com/wireguard/device"
|
2021-06-06 00:40:44 +02:00
|
|
|
"golang.zx2c4.com/wireguard/ipc"
|
2022-01-17 14:01:58 +01:00
|
|
|
"golang.zx2c4.com/wireguard/tun"
|
2021-06-06 00:40:44 +02:00
|
|
|
)
|
|
|
|
|
2023-02-13 18:34:56 +01:00
|
|
|
// GetInterfaceGUIDString returns an interface GUID. This is useful on Windows only
|
|
|
|
func (w *WGIface) GetInterfaceGUIDString() (string, error) {
|
|
|
|
return "", nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Close closes the tunnel interface
|
|
|
|
func (w *WGIface) Close() error {
|
|
|
|
w.mu.Lock()
|
|
|
|
defer w.mu.Unlock()
|
|
|
|
if w.netInterface == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
err := w.netInterface.Close()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
sockPath := "/var/run/wireguard/" + w.name + ".sock"
|
|
|
|
if _, statErr := os.Stat(sockPath); statErr == nil {
|
|
|
|
statErr = os.Remove(sockPath)
|
|
|
|
if statErr != nil {
|
|
|
|
return statErr
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-06-04 19:41:01 +02:00
|
|
|
// createWithUserspace Creates a new Wireguard interface, using wireguard-go userspace implementation
|
|
|
|
func (w *WGIface) createWithUserspace() error {
|
2022-01-17 14:01:58 +01:00
|
|
|
|
2023-02-13 18:34:56 +01:00
|
|
|
tunIface, err := tun.CreateTUN(w.name, w.mtu)
|
2022-01-17 14:01:58 +01:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2023-02-13 18:34:56 +01:00
|
|
|
w.netInterface = tunIface
|
2022-01-17 14:01:58 +01:00
|
|
|
|
|
|
|
// We need to create a wireguard-go device and listen to configuration requests
|
|
|
|
tunDevice := device.NewDevice(tunIface, conn.NewDefaultBind(), device.NewLogger(device.LogLevelSilent, "[wiretrustee] "))
|
|
|
|
err = tunDevice.Up()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-02-13 18:34:56 +01:00
|
|
|
uapi, err := getUAPI(w.name)
|
2022-01-17 14:01:58 +01:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
for {
|
|
|
|
uapiConn, uapiErr := uapi.Accept()
|
|
|
|
if uapiErr != nil {
|
|
|
|
log.Traceln("uapi Accept failed with error: ", uapiErr)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
go tunDevice.IpcHandle(uapiConn)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
log.Debugln("UAPI listener started")
|
|
|
|
|
|
|
|
err = w.assignAddr()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2021-06-06 00:40:44 +02:00
|
|
|
// getUAPI returns a Listener
|
|
|
|
func getUAPI(iface string) (net.Listener, error) {
|
|
|
|
tunSock, err := ipc.UAPIOpen(iface)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return ipc.UAPIListen(iface, tunSock)
|
|
|
|
}
|