yggdrasil-go/src/tuntap/tun_other.go

34 lines
1.1 KiB
Go
Raw Normal View History

2019-01-02 18:05:54 +00:00
// +build !linux,!darwin,!windows,!openbsd,!freebsd,!netbsd,!mobile
2017-12-28 22:16:20 -06:00
package tuntap
2017-12-28 22:16:20 -06:00
2018-03-04 16:24:50 +00:00
import water "github.com/yggdrasil-network/water"
2017-12-28 22:16:20 -06:00
// This is to catch unsupported platforms
// If your platform supports tun devices, you could try configuring it manually
2018-06-12 22:45:53 +01:00
// Creates the TUN/TAP adapter, if supported by the Water library. Note that
// no guarantees are made at this point on an unsupported platform.
func (tun *TunAdapter) setup(ifname string, iftapmode bool, addr string, mtu int) error {
var config water.Config
if iftapmode {
config = water.Config{DeviceType: water.TAP}
} else {
config = water.Config{DeviceType: water.TUN}
}
iface, err := water.New(config)
2018-01-04 22:37:51 +00:00
if err != nil {
panic(err)
}
tun.iface = iface
2018-03-03 12:30:54 +00:00
tun.mtu = getSupportedMTU(mtu)
2018-01-04 22:37:51 +00:00
return tun.setupAddress(addr)
}
2018-06-12 22:45:53 +01:00
// We don't know how to set the IPv6 address on an unknown platform, therefore
// write about it to stdout and don't try to do anything further.
func (tun *TunAdapter) setupAddress(addr string) error {
2019-03-28 15:32:01 +00:00
tun.log.Warnln("Platform not supported, you must set the address of", tun.iface.Name(), "to", addr)
2018-01-04 22:37:51 +00:00
return nil
2017-12-28 22:16:20 -06:00
}