2024-06-13 13:24:24 +02:00
|
|
|
//go:build (linux && !android) || freebsd
|
2024-01-03 16:06:20 +01:00
|
|
|
|
|
|
|
package iface
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2024-06-13 13:24:24 +02:00
|
|
|
"runtime"
|
2024-01-03 16:06:20 +01:00
|
|
|
|
|
|
|
"github.com/pion/transport/v3"
|
|
|
|
|
2024-10-02 18:24:22 +02:00
|
|
|
"github.com/netbirdio/netbird/client/iface/bind"
|
|
|
|
"github.com/netbirdio/netbird/client/iface/device"
|
|
|
|
"github.com/netbirdio/netbird/client/iface/netstack"
|
2024-01-03 16:06:20 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// NewWGIFace Creates a new WireGuard interface instance
|
2024-10-02 18:24:22 +02:00
|
|
|
func NewWGIFace(iFaceName string, address string, wgPort int, wgPrivKey string, mtu int, transportNet transport.Net, args *device.MobileIFaceArguments, filterFn bind.FilterFn) (*WGIface, error) {
|
|
|
|
wgAddress, err := device.ParseWGAddress(address)
|
2024-01-03 16:06:20 +01:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
wgIFace := &WGIface{}
|
|
|
|
|
|
|
|
// move the kernel/usp/netstack preference evaluation to upper layer
|
|
|
|
if netstack.IsEnabled() {
|
2024-10-02 18:24:22 +02:00
|
|
|
wgIFace.tun = device.NewNetstackDevice(iFaceName, wgAddress, wgPort, wgPrivKey, mtu, transportNet, netstack.ListenAddr(), filterFn)
|
2024-01-03 16:06:20 +01:00
|
|
|
wgIFace.userspaceBind = true
|
|
|
|
return wgIFace, nil
|
|
|
|
}
|
|
|
|
|
2024-10-02 18:24:22 +02:00
|
|
|
if device.WireGuardModuleIsLoaded() {
|
|
|
|
wgIFace.tun = device.NewKernelDevice(iFaceName, wgAddress, wgPort, wgPrivKey, mtu, transportNet)
|
2024-01-03 16:06:20 +01:00
|
|
|
wgIFace.userspaceBind = false
|
|
|
|
return wgIFace, nil
|
|
|
|
}
|
|
|
|
|
2024-10-02 18:24:22 +02:00
|
|
|
if !device.ModuleTunIsLoaded() {
|
2024-01-03 16:06:20 +01:00
|
|
|
return nil, fmt.Errorf("couldn't check or load tun module")
|
|
|
|
}
|
2024-10-02 18:24:22 +02:00
|
|
|
wgIFace.tun = device.NewUSPDevice(iFaceName, wgAddress, wgPort, wgPrivKey, mtu, transportNet, nil)
|
2024-01-03 16:06:20 +01:00
|
|
|
wgIFace.userspaceBind = true
|
|
|
|
return wgIFace, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// CreateOnAndroid this function make sense on mobile only
|
|
|
|
func (w *WGIface) CreateOnAndroid([]string, string, []string) error {
|
2024-06-13 13:24:24 +02:00
|
|
|
return fmt.Errorf("CreateOnAndroid function has not implemented on %s platform", runtime.GOOS)
|
2024-01-03 16:06:20 +01:00
|
|
|
}
|