mirror of
https://github.com/netbirdio/netbird.git
synced 2025-01-25 07:19:05 +01:00
30ebcf38c7
In the case of user space WireGuard mode, use in-memory proxy between the TURN/Relay connection and the WireGuard Bind. We keep the UDP proxy and eBPF proxy for kernel mode. The key change is the new wgproxy/bind and the iface/bind/ice_bind changes. Everything else is just to fulfill the dependencies.
27 lines
591 B
Go
27 lines
591 B
Go
//go:build (!android && !darwin) || ios
|
|
|
|
package iface
|
|
|
|
import "fmt"
|
|
|
|
// 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()
|
|
|
|
cfgr, err := w.tun.Create()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
w.configurer = cfgr
|
|
return 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 non mobile")
|
|
}
|