Files
kubevpn/pkg/tun/tun_openbsd.go
2023-02-19 12:14:47 +08:00

87 lines
1.7 KiB
Go

//go:build openbsd
package tun
import (
"fmt"
"net"
"os/exec"
"strings"
"github.com/containernetworking/cni/pkg/types"
log "github.com/sirupsen/logrus"
"golang.zx2c4.com/wireguard/tun"
"github.com/wencaiwulue/kubevpn/pkg/config"
)
func createTun(cfg Config) (conn net.Conn, itf *net.Interface, err error) {
ip, _, err := net.ParseCIDR(cfg.Addr)
if err != nil {
return
}
mtu := cfg.MTU
if mtu <= 0 {
mtu = config.DefaultMTU
}
var ifce tun.Device
ifce, err = tun.CreateTUN("utun", mtu)
if err != nil {
return
}
var name string
name, err = ifce.Name()
if err != nil {
return
}
cmd := fmt.Sprintf("ifconfig %s inet %s mtu %d up", ifce.Name(), cfg.Addr, mtu)
log.Debugf("[tun] %s", cmd)
args := strings.Split(cmd, " ")
if er := exec.Command(args[0], args[1:]...).Run(); er != nil {
err = fmt.Errorf("%s: %v", cmd, er)
return
}
if err = os.Setenv(config.EnvTunNameOrLUID, ifce.Name()); err != nil {
return nil, nil, err
}
if err = addTunRoutes(ifce.Name(), cfg.Routes...); err != nil {
return
}
itf, err = net.InterfaceByName(ifce.Name())
if err != nil {
return
}
conn = &tunConn{
ifce: ifce,
addr: &net.IPAddr{IP: ip},
}
return
}
func addTunRoutes(ifName string, routes ...types.Route) error {
for _, route := range routes {
if route.Dst.String() == "" {
continue
}
cmd := fmt.Sprintf("route add -net %s -interface %s", route.Dst.String(), ifName)
log.Debugf("[tun] %s", cmd)
args := strings.Split(cmd, " ")
if er := exec.Command(args[0], args[1:]...).Run(); er != nil {
return fmt.Errorf("%s: %v", cmd, er)
}
}
return nil
}
func getInterface() (*net.Interface, error) {
return net.InterfaceByName(os.Getenv(config.EnvTunNameOrLUID))
}