mirror of
https://github.com/netbirdio/netbird.git
synced 2025-01-10 16:08:14 +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.
25 lines
698 B
Go
25 lines
698 B
Go
package iface
|
|
|
|
import (
|
|
"github.com/netbirdio/netbird/client/iface/bind"
|
|
"github.com/netbirdio/netbird/client/iface/device"
|
|
"github.com/netbirdio/netbird/client/iface/wgproxy"
|
|
)
|
|
|
|
// NewWGIFace Creates a new WireGuard interface instance
|
|
func NewWGIFace(opts WGIFaceOpts) (*WGIface, error) {
|
|
wgAddress, err := device.ParseWGAddress(opts.Address)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
iceBind := bind.NewICEBind(opts.TransportNet, opts.FilterFn)
|
|
|
|
wgIFace := &WGIface{
|
|
userspaceBind: true,
|
|
tun: device.NewTunDevice(wgAddress, opts.WGPort, opts.WGPrivKey, opts.MTU, iceBind, opts.MobileArgs.TunAdapter),
|
|
wgProxyFactory: wgproxy.NewUSPFactory(iceBind),
|
|
}
|
|
return wgIFace, nil
|
|
}
|