2019-01-02 18:05:54 +00:00
|
|
|
// +build !linux,!darwin,!windows,!openbsd,!freebsd,!netbsd,!mobile
|
2017-12-28 22:16:20 -06:00
|
|
|
|
2019-03-28 00:30:25 +00: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"
|
2018-01-04 22:34:17 +00:00
|
|
|
|
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.
|
2019-03-28 00:30:25 +00:00
|
|
|
func (tun *TunAdapter) setup(ifname string, iftapmode bool, addr string, mtu int) error {
|
2018-02-11 21:45:44 +00:00
|
|
|
var config water.Config
|
|
|
|
if iftapmode {
|
|
|
|
config = water.Config{DeviceType: water.TAP}
|
|
|
|
} else {
|
|
|
|
config = water.Config{DeviceType: water.TUN}
|
|
|
|
}
|
2018-01-04 22:34:17 +00:00
|
|
|
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-01-04 22:34:17 +00:00
|
|
|
}
|
|
|
|
|
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.
|
2019-03-28 00:30:25 +00:00
|
|
|
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
|
|
|
}
|