mirror of
https://github.com/cwinfo/yggdrasil-go.git
synced 2024-11-25 20:41:36 +00:00
Move Linux-specific ifname logic to tun_linux.go and place a generic in tun_other.go
This commit is contained in:
parent
1c799b305d
commit
ae7b07ae6a
@ -18,16 +18,6 @@ func (tun *tunDevice) init(core *Core) {
|
|||||||
tun.core = core
|
tun.core = core
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tun *tunDevice) setup(ifname string, addr string, mtu int) error {
|
|
||||||
config := water.Config{ DeviceType: water.TUN }
|
|
||||||
if ifname != "" && ifname != "auto" { config.Name = ifname }
|
|
||||||
iface, err := water.New(config)
|
|
||||||
if err != nil { panic(err) }
|
|
||||||
tun.iface = iface
|
|
||||||
tun.mtu = mtu //1280 // Lets default to the smallest thing allowed for now
|
|
||||||
return tun.setupAddress(addr)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (tun *tunDevice) write() error {
|
func (tun *tunDevice) write() error {
|
||||||
for {
|
for {
|
||||||
data := <-tun.recv
|
data := <-tun.recv
|
||||||
@ -55,4 +45,3 @@ func (tun *tunDevice) read() error {
|
|||||||
func (tun *tunDevice) close() error {
|
func (tun *tunDevice) close() error {
|
||||||
return tun.iface.Close()
|
return tun.iface.Close()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,6 +7,20 @@ import "fmt"
|
|||||||
import "os/exec"
|
import "os/exec"
|
||||||
import "strings"
|
import "strings"
|
||||||
|
|
||||||
|
import water "github.com/songgao/water"
|
||||||
|
|
||||||
|
func (tun *tunDevice) setup(ifname string, addr string, mtu int) error {
|
||||||
|
config := water.Config{ DeviceType: water.TUN }
|
||||||
|
if ifname != "" && ifname != "auto" {
|
||||||
|
config.Name = ifname
|
||||||
|
}
|
||||||
|
iface, err := water.New(config)
|
||||||
|
if err != nil { panic(err) }
|
||||||
|
tun.iface = iface
|
||||||
|
tun.mtu = mtu //1280 // Lets default to the smallest thing allowed for now
|
||||||
|
return tun.setupAddress(addr)
|
||||||
|
}
|
||||||
|
|
||||||
func (tun *tunDevice) setupAddress(addr string) error {
|
func (tun *tunDevice) setupAddress(addr string) error {
|
||||||
// Set address
|
// Set address
|
||||||
cmd := exec.Command("ip", "-f", "inet6",
|
cmd := exec.Command("ip", "-f", "inet6",
|
||||||
@ -33,4 +47,3 @@ func (tun *tunDevice) setupAddress(addr string) error {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,11 +2,21 @@
|
|||||||
|
|
||||||
package yggdrasil
|
package yggdrasil
|
||||||
|
|
||||||
|
import water "github.com/songgao/water"
|
||||||
|
|
||||||
// This is to catch unsupported platforms
|
// This is to catch unsupported platforms
|
||||||
// If your platform supports tun devices, you could try configuring it manually
|
// If your platform supports tun devices, you could try configuring it manually
|
||||||
|
|
||||||
|
func (tun *tunDevice) setup(ifname string, addr string, mtu int) error {
|
||||||
|
config := water.Config{ DeviceType: water.TUN }
|
||||||
|
iface, err := water.New(config)
|
||||||
|
if err != nil { panic(err) }
|
||||||
|
tun.iface = iface
|
||||||
|
tun.mtu = mtu //1280 // Lets default to the smallest thing allowed for now
|
||||||
|
return tun.setupAddress(addr)
|
||||||
|
}
|
||||||
|
|
||||||
func (tun *tunDevice) setupAddress(addr string) error {
|
func (tun *tunDevice) setupAddress(addr string) error {
|
||||||
tun.core.log.Println("Platform not supported, you must set the address of", tun.iface.Name(), "to", addr)
|
tun.core.log.Println("Platform not supported, you must set the address of", tun.iface.Name(), "to", addr)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user