tun: add routes setup support for windows
This commit is contained in:
parent
c3ca971f6c
commit
fd13582ded
15
tun_unix.go
15
tun_unix.go
@ -6,7 +6,7 @@ import (
|
||||
"fmt"
|
||||
"net"
|
||||
"os/exec"
|
||||
"strconv"
|
||||
"strings"
|
||||
|
||||
"github.com/go-log/log"
|
||||
"github.com/songgao/water"
|
||||
@ -32,11 +32,8 @@ func createTun(cfg TunConfig) (conn net.Conn, ipNet *net.IPNet, err error) {
|
||||
|
||||
cmd := fmt.Sprintf("ifconfig %s inet %s mtu %d up", ifce.Name(), cfg.Addr, mtu)
|
||||
log.Log("[tun]", cmd)
|
||||
if er := exec.Command(
|
||||
"ifconfig", ifce.Name(),
|
||||
"inet", cfg.Addr,
|
||||
"mtu", strconv.Itoa(mtu),
|
||||
"up").Run(); er != nil {
|
||||
args := strings.Split(cmd, " ")
|
||||
if er := exec.Command(args[0], args[1:]...).Run(); er != nil {
|
||||
err = fmt.Errorf("%s: %v", cmd, er)
|
||||
return
|
||||
}
|
||||
@ -59,10 +56,8 @@ func addRoutes(ifName string, routes ...string) error {
|
||||
}
|
||||
cmd := fmt.Sprintf("route add -net %s -interface %s", route, ifName)
|
||||
log.Log("[tun]", cmd)
|
||||
if er := exec.Command(
|
||||
"route", "add",
|
||||
"-net", route,
|
||||
"-interface", ifName).Run(); er != nil {
|
||||
args := strings.Split(cmd, " ")
|
||||
if er := exec.Command(args[0], args[1:]...).Run(); er != nil {
|
||||
return fmt.Errorf("%s: %v", cmd, er)
|
||||
}
|
||||
}
|
||||
|
@ -4,6 +4,7 @@ import (
|
||||
"fmt"
|
||||
"net"
|
||||
"os/exec"
|
||||
"strings"
|
||||
|
||||
"github.com/go-log/log"
|
||||
"github.com/songgao/water"
|
||||
@ -31,14 +32,16 @@ func createTun(cfg TunConfig) (conn net.Conn, ipNet *net.IPNet, err error) {
|
||||
"source=static addr=%s mask=%s gateway=none",
|
||||
ifce.Name(), ip.String(), ipMask(ipNet.Mask))
|
||||
log.Log("[tun]", cmd)
|
||||
if er := exec.Command("netsh",
|
||||
"interface", "ip", "set", "address",
|
||||
"name="+ifce.Name(), "source=static",
|
||||
"addr="+ip.String(), "mask="+ipMask(ipNet.Mask), "gateway=none").Run(); er != nil {
|
||||
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 = addRoutes(ip.String(), cfg.Routes...); err != nil {
|
||||
return
|
||||
}
|
||||
|
||||
conn = &tunConn{
|
||||
ifce: ifce,
|
||||
addr: &net.IPAddr{IP: ip},
|
||||
@ -46,6 +49,27 @@ func createTun(cfg TunConfig) (conn net.Conn, ipNet *net.IPNet, err error) {
|
||||
return
|
||||
}
|
||||
|
||||
func addRoutes(ifIP string, routes ...string) error {
|
||||
for _, route := range routes {
|
||||
if route == "" {
|
||||
continue
|
||||
}
|
||||
_, inet, err := net.ParseCIDR(route)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
cmd := fmt.Sprintf("route ADD %s MASK %s %s",
|
||||
inet.IP, ipMask(inet.Mask), ifIP)
|
||||
log.Log("[tun]", 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 ipMask(mask net.IPMask) string {
|
||||
return fmt.Sprintf("%d.%d.%d.%d", mask[0], mask[1], mask[2], mask[3])
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user