2024-01-03 16:06:20 +01:00
|
|
|
//go:build !ios
|
|
|
|
|
|
|
|
package iface
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2024-09-09 19:02:10 +02:00
|
|
|
"time"
|
2024-01-03 16:06:20 +01:00
|
|
|
|
2024-09-09 19:02:10 +02:00
|
|
|
"github.com/cenkalti/backoff/v4"
|
2024-01-03 16:06:20 +01:00
|
|
|
"github.com/pion/transport/v3"
|
|
|
|
|
2024-06-19 12:12:11 +02:00
|
|
|
"github.com/netbirdio/netbird/iface/bind"
|
2024-01-03 16:06:20 +01:00
|
|
|
"github.com/netbirdio/netbird/iface/netstack"
|
|
|
|
)
|
|
|
|
|
|
|
|
// NewWGIFace Creates a new WireGuard interface instance
|
2024-06-19 12:12:11 +02:00
|
|
|
func NewWGIFace(iFaceName string, address string, wgPort int, wgPrivKey string, mtu int, transportNet transport.Net, _ *MobileIFaceArguments, filterFn bind.FilterFn) (*WGIface, error) {
|
2024-01-03 16:06:20 +01:00
|
|
|
wgAddress, err := parseWGAddress(address)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
wgIFace := &WGIface{
|
|
|
|
userspaceBind: true,
|
|
|
|
}
|
|
|
|
|
|
|
|
if netstack.IsEnabled() {
|
2024-06-19 12:12:11 +02:00
|
|
|
wgIFace.tun = newTunNetstackDevice(iFaceName, wgAddress, wgPort, wgPrivKey, mtu, transportNet, netstack.ListenAddr(), filterFn)
|
2024-01-03 16:06:20 +01:00
|
|
|
return wgIFace, nil
|
|
|
|
}
|
|
|
|
|
2024-06-19 12:12:11 +02:00
|
|
|
wgIFace.tun = newTunDevice(iFaceName, wgAddress, wgPort, wgPrivKey, mtu, transportNet, filterFn)
|
2024-01-03 16:06:20 +01:00
|
|
|
|
|
|
|
return wgIFace, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// CreateOnAndroid this function make sense on mobile only
|
|
|
|
func (w *WGIface) CreateOnAndroid([]string, string, []string) error {
|
|
|
|
return fmt.Errorf("this function has not implemented on this platform")
|
|
|
|
}
|
2024-09-09 19:02:10 +02:00
|
|
|
|
|
|
|
// Create creates a new Wireguard interface, sets a given IP and brings it up.
|
|
|
|
// Will reuse an existing one.
|
|
|
|
// this function is different on Android
|
|
|
|
func (w *WGIface) Create() error {
|
|
|
|
w.mu.Lock()
|
|
|
|
defer w.mu.Unlock()
|
|
|
|
|
|
|
|
backOff := &backoff.ExponentialBackOff{
|
|
|
|
InitialInterval: 20 * time.Millisecond,
|
|
|
|
MaxElapsedTime: 500 * time.Millisecond,
|
|
|
|
Stop: backoff.Stop,
|
|
|
|
Clock: backoff.SystemClock,
|
|
|
|
}
|
|
|
|
|
|
|
|
operation := func() error {
|
|
|
|
cfgr, err := w.tun.Create()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
w.configurer = cfgr
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
return backoff.Retry(operation, backOff)
|
|
|
|
}
|