mirror of
https://github.com/netbirdio/netbird.git
synced 2024-12-12 18:00:49 +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
439 B
Go
27 lines
439 B
Go
package wgproxy
|
|
|
|
import (
|
|
udpProxy "github.com/netbirdio/netbird/client/iface/wgproxy/udp"
|
|
)
|
|
|
|
// KernelFactory todo: check eBPF support on FreeBSD
|
|
type KernelFactory struct {
|
|
wgPort int
|
|
}
|
|
|
|
func NewKernelFactory(wgPort int) *KernelFactory {
|
|
f := &KernelFactory{
|
|
wgPort: wgPort,
|
|
}
|
|
|
|
return f
|
|
}
|
|
|
|
func (w *KernelFactory) GetProxy() Proxy {
|
|
return udpProxy.NewWGUDPProxy(w.wgPort)
|
|
}
|
|
|
|
func (w *KernelFactory) Free() error {
|
|
return nil
|
|
}
|