mirror of
https://github.com/netbirdio/netbird.git
synced 2024-12-04 22:10:56 +01:00
81 lines
1.2 KiB
Go
81 lines
1.2 KiB
Go
|
//go:build linux && !android
|
||
|
|
||
|
package wgproxy
|
||
|
|
||
|
import (
|
||
|
_ "embed"
|
||
|
"net"
|
||
|
|
||
|
"github.com/cilium/ebpf/link"
|
||
|
"github.com/cilium/ebpf/rlimit"
|
||
|
)
|
||
|
|
||
|
const (
|
||
|
mapKeyProxyPort uint32 = 0
|
||
|
mapKeyWgPort uint32 = 1
|
||
|
)
|
||
|
|
||
|
//go:generate go run github.com/cilium/ebpf/cmd/bpf2go -cc clang-14 bpf bpf/portreplace.c --
|
||
|
|
||
|
type eBPF struct {
|
||
|
link link.Link
|
||
|
}
|
||
|
|
||
|
func newEBPF() *eBPF {
|
||
|
return &eBPF{}
|
||
|
}
|
||
|
|
||
|
func (l *eBPF) load(proxyPort, wgPort int) error {
|
||
|
// it required for Docker
|
||
|
err := rlimit.RemoveMemlock()
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
ifce, err := net.InterfaceByName("lo")
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
// Load pre-compiled programs into the kernel.
|
||
|
objs := bpfObjects{}
|
||
|
err = loadBpfObjects(&objs, nil)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
defer func() {
|
||
|
_ = objs.Close()
|
||
|
}()
|
||
|
|
||
|
err = objs.XdpPortMap.Put(mapKeyProxyPort, uint16(proxyPort))
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
err = objs.XdpPortMap.Put(mapKeyWgPort, uint16(wgPort))
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
defer func() {
|
||
|
_ = objs.XdpPortMap.Close()
|
||
|
}()
|
||
|
|
||
|
l.link, err = link.AttachXDP(link.XDPOptions{
|
||
|
Program: objs.XdpProgFunc,
|
||
|
Interface: ifce.Index,
|
||
|
})
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
func (l *eBPF) free() error {
|
||
|
if l.link != nil {
|
||
|
return l.link.Close()
|
||
|
}
|
||
|
return nil
|
||
|
}
|