mirror of
https://github.com/cwinfo/yggdrasil-go.git
synced 2024-11-09 23:20:28 +00:00
Break out mobile and dummy adapter
This commit is contained in:
parent
39baf7365c
commit
047717abf2
4
build
4
build
@ -28,10 +28,10 @@ fi
|
|||||||
|
|
||||||
if [ $IOS ]; then
|
if [ $IOS ]; then
|
||||||
echo "Building framework for iOS"
|
echo "Building framework for iOS"
|
||||||
gomobile bind -target ios -tags mobile -ldflags="$LDFLAGS $STRIP" -gcflags="$GCFLAGS" github.com/yggdrasil-network/yggdrasil-go/src/yggdrasil
|
gomobile bind -target ios -tags mobile -ldflags="$LDFLAGS $STRIP" -gcflags="$GCFLAGS" github.com/yggdrasil-network/yggdrasil-go/src/mobile
|
||||||
elif [ $ANDROID ]; then
|
elif [ $ANDROID ]; then
|
||||||
echo "Building aar for Android"
|
echo "Building aar for Android"
|
||||||
gomobile bind -target android -tags mobile -ldflags="$LDFLAGS $STRIP" -gcflags="$GCFLAGS" github.com/yggdrasil-network/yggdrasil-go/src/yggdrasil
|
gomobile bind -target android -tags mobile -ldflags="$LDFLAGS $STRIP" -gcflags="$GCFLAGS" github.com/yggdrasil-network/yggdrasil-go/src/mobile
|
||||||
else
|
else
|
||||||
for CMD in `ls cmd/` ; do
|
for CMD in `ls cmd/` ; do
|
||||||
echo "Building: $CMD"
|
echo "Building: $CMD"
|
||||||
|
57
src/dummy/dummy.go
Normal file
57
src/dummy/dummy.go
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
package dummy
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/gologme/log"
|
||||||
|
"github.com/yggdrasil-network/yggdrasil-go/src/config"
|
||||||
|
"github.com/yggdrasil-network/yggdrasil-go/src/util"
|
||||||
|
"github.com/yggdrasil-network/yggdrasil-go/src/yggdrasil"
|
||||||
|
)
|
||||||
|
|
||||||
|
type DummyAdapter struct {
|
||||||
|
yggdrasil.Adapter
|
||||||
|
send chan<- []byte
|
||||||
|
recv <-chan []byte
|
||||||
|
reject <-chan yggdrasil.RejectedPacket
|
||||||
|
}
|
||||||
|
|
||||||
|
// Init initialises the TUN/TAP adapter.
|
||||||
|
func (m *DummyAdapter) Init(config *config.NodeState, log *log.Logger, send chan<- []byte, recv <-chan []byte, reject <-chan yggdrasil.RejectedPacket) {
|
||||||
|
m.Adapter.Init(config, log, send, recv, reject)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Name returns the name of the adapter, e.g. "tun0". On Windows, this may
|
||||||
|
// return a canonical adapter name instead.
|
||||||
|
func (m *DummyAdapter) Name() string {
|
||||||
|
return "dummy"
|
||||||
|
}
|
||||||
|
|
||||||
|
// MTU gets the adapter's MTU. This can range between 1280 and 65535, although
|
||||||
|
// the maximum value is determined by your platform. The returned value will
|
||||||
|
// never exceed that of MaximumMTU().
|
||||||
|
func (m *DummyAdapter) MTU() int {
|
||||||
|
return 65535
|
||||||
|
}
|
||||||
|
|
||||||
|
// IsTAP returns true if the adapter is a TAP adapter (Layer 2) or false if it
|
||||||
|
// is a TUN adapter (Layer 3).
|
||||||
|
func (m *DummyAdapter) IsTAP() bool {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wait for a packet from the router. You will use this when implementing a
|
||||||
|
// dummy adapter in place of real TUN - when this call returns a packet, you
|
||||||
|
// will probably want to give it to the OS to write to TUN.
|
||||||
|
func (m *DummyAdapter) Recv() ([]byte, error) {
|
||||||
|
packet := <-m.recv
|
||||||
|
return packet, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Send a packet to the router. You will use this when implementing a
|
||||||
|
// dummy adapter in place of real TUN - when the operating system tells you
|
||||||
|
// that a new packet is available from TUN, call this function to give it to
|
||||||
|
// Yggdrasil.
|
||||||
|
func (m *DummyAdapter) Send(buf []byte) error {
|
||||||
|
packet := append(util.GetBytes(), buf[:]...)
|
||||||
|
m.send <- packet
|
||||||
|
return nil
|
||||||
|
}
|
143
src/mobile/mobile.go
Normal file
143
src/mobile/mobile.go
Normal file
@ -0,0 +1,143 @@
|
|||||||
|
package mobile
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"os"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/gologme/log"
|
||||||
|
|
||||||
|
hjson "github.com/hjson/hjson-go"
|
||||||
|
"github.com/mitchellh/mapstructure"
|
||||||
|
"github.com/yggdrasil-network/yggdrasil-go/src/config"
|
||||||
|
"github.com/yggdrasil-network/yggdrasil-go/src/dummy"
|
||||||
|
"github.com/yggdrasil-network/yggdrasil-go/src/multicast"
|
||||||
|
"github.com/yggdrasil-network/yggdrasil-go/src/yggdrasil"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Yggdrasil's mobile package is meant to "plug the gap" for mobile support, as
|
||||||
|
// Gomobile will not create headers for Swift/Obj-C etc if they have complex
|
||||||
|
// (non-native) types. Therefore for iOS we will expose some nice simple
|
||||||
|
// functions. Note that in the case of iOS we handle reading/writing to/from TUN
|
||||||
|
// in Swift therefore we use the "dummy" TUN interface instead.
|
||||||
|
type Yggdrasil struct {
|
||||||
|
core *yggdrasil.Core
|
||||||
|
multicast *multicast.Multicast
|
||||||
|
dummy.DummyAdapter
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Yggdrasil) addStaticPeers(cfg *config.NodeConfig) {
|
||||||
|
if len(cfg.Peers) == 0 && len(cfg.InterfacePeers) == 0 {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
for {
|
||||||
|
for _, peer := range cfg.Peers {
|
||||||
|
m.core.AddPeer(peer, "")
|
||||||
|
time.Sleep(time.Second)
|
||||||
|
}
|
||||||
|
for intf, intfpeers := range cfg.InterfacePeers {
|
||||||
|
for _, peer := range intfpeers {
|
||||||
|
m.core.AddPeer(peer, intf)
|
||||||
|
time.Sleep(time.Second)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
time.Sleep(time.Minute)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// StartAutoconfigure starts a node with a randomly generated config
|
||||||
|
func (m *Yggdrasil) StartAutoconfigure() error {
|
||||||
|
m.core = &yggdrasil.Core{}
|
||||||
|
//m.Adapter = dummy.DummyAdapter{}
|
||||||
|
mobilelog := MobileLogger{}
|
||||||
|
logger := log.New(mobilelog, "", 0)
|
||||||
|
nc := config.GenerateConfig()
|
||||||
|
nc.IfName = "dummy"
|
||||||
|
nc.AdminListen = "tcp://localhost:9001"
|
||||||
|
nc.Peers = []string{}
|
||||||
|
if hostname, err := os.Hostname(); err == nil {
|
||||||
|
nc.NodeInfo = map[string]interface{}{"name": hostname}
|
||||||
|
}
|
||||||
|
m.core.SetRouterAdapter(&m)
|
||||||
|
state, err := m.core.Start(nc, logger)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
// Start the multicast interface
|
||||||
|
m.multicast.Init(m.core, state, logger, nil)
|
||||||
|
if err := m.multicast.Start(); err != nil {
|
||||||
|
logger.Errorln("An error occurred starting multicast:", err)
|
||||||
|
}
|
||||||
|
go m.addStaticPeers(nc)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// StartJSON starts a node with the given JSON config. You can get JSON config
|
||||||
|
// (rather than HJSON) by using the GenerateConfigJSON() function
|
||||||
|
func (m *Yggdrasil) StartJSON(configjson []byte) error {
|
||||||
|
m.core = &yggdrasil.Core{}
|
||||||
|
//m.Adapter = dummy.DummyAdapter{}
|
||||||
|
mobilelog := MobileLogger{}
|
||||||
|
logger := log.New(mobilelog, "", 0)
|
||||||
|
nc := config.GenerateConfig()
|
||||||
|
var dat map[string]interface{}
|
||||||
|
if err := hjson.Unmarshal(configjson, &dat); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if err := mapstructure.Decode(dat, &nc); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
nc.IfName = "dummy"
|
||||||
|
m.core.SetRouterAdapter(&m)
|
||||||
|
state, err := m.core.Start(nc, logger)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
// Start the multicast interface
|
||||||
|
m.multicast.Init(m.core, state, logger, nil)
|
||||||
|
if err := m.multicast.Start(); err != nil {
|
||||||
|
logger.Errorln("An error occurred starting multicast:", err)
|
||||||
|
}
|
||||||
|
go m.addStaticPeers(nc)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Stops the mobile Yggdrasil instance
|
||||||
|
func (m *Yggdrasil) Stop() error {
|
||||||
|
m.core.Stop()
|
||||||
|
if err := m.Stop(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// GenerateConfigJSON generates mobile-friendly configuration in JSON format
|
||||||
|
func GenerateConfigJSON() []byte {
|
||||||
|
nc := config.GenerateConfig()
|
||||||
|
nc.IfName = "dummy"
|
||||||
|
if json, err := json.Marshal(nc); err == nil {
|
||||||
|
return json
|
||||||
|
} else {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetAddressString gets the node's IPv6 address
|
||||||
|
func (m *Yggdrasil) GetAddressString() string {
|
||||||
|
return m.core.Address().String()
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetSubnetString gets the node's IPv6 subnet in CIDR notation
|
||||||
|
func (m *Yggdrasil) GetSubnetString() string {
|
||||||
|
return m.core.Subnet().String()
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetBoxPubKeyString gets the node's public encryption key
|
||||||
|
func (m *Yggdrasil) GetBoxPubKeyString() string {
|
||||||
|
return m.core.BoxPubKey()
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetSigPubKeyString gets the node's public signing key
|
||||||
|
func (m *Yggdrasil) GetSigPubKeyString() string {
|
||||||
|
return m.core.SigPubKey()
|
||||||
|
}
|
@ -1,6 +1,6 @@
|
|||||||
// +build android
|
// +build android
|
||||||
|
|
||||||
package yggdrasil
|
package mobile
|
||||||
|
|
||||||
import "log"
|
import "log"
|
||||||
|
|
@ -1,6 +1,6 @@
|
|||||||
// +build mobile,darwin
|
// +build darwin
|
||||||
|
|
||||||
package yggdrasil
|
package mobile
|
||||||
|
|
||||||
/*
|
/*
|
||||||
#cgo CFLAGS: -x objective-c
|
#cgo CFLAGS: -x objective-c
|
@ -280,6 +280,16 @@ func (c *Core) TreeID() *crypto.TreeID {
|
|||||||
return crypto.GetTreeID(&c.sigPub)
|
return crypto.GetTreeID(&c.sigPub)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// SigPubKey gets the node's signing public key.
|
||||||
|
func (c *Core) SigPubKey() string {
|
||||||
|
return hex.EncodeToString(c.sigPub[:])
|
||||||
|
}
|
||||||
|
|
||||||
|
// BoxPubKey gets the node's encryption public key.
|
||||||
|
func (c *Core) BoxPubKey() string {
|
||||||
|
return hex.EncodeToString(c.boxPub[:])
|
||||||
|
}
|
||||||
|
|
||||||
// Address gets the IPv6 address of the Yggdrasil node. This is always a /128
|
// Address gets the IPv6 address of the Yggdrasil node. This is always a /128
|
||||||
// address.
|
// address.
|
||||||
func (c *Core) Address() *net.IP {
|
func (c *Core) Address() *net.IP {
|
||||||
|
@ -1,130 +0,0 @@
|
|||||||
// +build mobile
|
|
||||||
|
|
||||||
package yggdrasil
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/hex"
|
|
||||||
"encoding/json"
|
|
||||||
"os"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/gologme/log"
|
|
||||||
|
|
||||||
hjson "github.com/hjson/hjson-go"
|
|
||||||
"github.com/mitchellh/mapstructure"
|
|
||||||
"github.com/yggdrasil-network/yggdrasil-go/src/config"
|
|
||||||
"github.com/yggdrasil-network/yggdrasil-go/src/util"
|
|
||||||
)
|
|
||||||
|
|
||||||
// This file is meant to "plug the gap" for mobile support, as Gomobile will
|
|
||||||
// not create headers for Swift/Obj-C etc if they have complex (non-native)
|
|
||||||
// types. Therefore for iOS we will expose some nice simple functions. Note
|
|
||||||
// that in the case of iOS we handle reading/writing to/from TUN in Swift
|
|
||||||
// therefore we use the "dummy" TUN interface instead.
|
|
||||||
|
|
||||||
func (c *Core) addStaticPeers(cfg *config.NodeConfig) {
|
|
||||||
if len(cfg.Peers) == 0 && len(cfg.InterfacePeers) == 0 {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
for {
|
|
||||||
for _, peer := range cfg.Peers {
|
|
||||||
c.AddPeer(peer, "")
|
|
||||||
time.Sleep(time.Second)
|
|
||||||
}
|
|
||||||
for intf, intfpeers := range cfg.InterfacePeers {
|
|
||||||
for _, peer := range intfpeers {
|
|
||||||
c.AddPeer(peer, intf)
|
|
||||||
time.Sleep(time.Second)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
time.Sleep(time.Minute)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Starts a node with a randomly generated config.
|
|
||||||
func (c *Core) StartAutoconfigure() error {
|
|
||||||
mobilelog := MobileLogger{}
|
|
||||||
logger := log.New(mobilelog, "", 0)
|
|
||||||
nc := config.GenerateConfig()
|
|
||||||
nc.IfName = "dummy"
|
|
||||||
nc.AdminListen = "tcp://localhost:9001"
|
|
||||||
nc.Peers = []string{}
|
|
||||||
if hostname, err := os.Hostname(); err == nil {
|
|
||||||
nc.NodeInfo = map[string]interface{}{"name": hostname}
|
|
||||||
}
|
|
||||||
if _, err := c.Start(nc, logger); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
go c.addStaticPeers(nc)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Starts a node with the given JSON config. You can get JSON config (rather
|
|
||||||
// than HJSON) by using the GenerateConfigJSON() function.
|
|
||||||
func (c *Core) StartJSON(configjson []byte) error {
|
|
||||||
mobilelog := MobileLogger{}
|
|
||||||
logger := log.New(mobilelog, "", 0)
|
|
||||||
nc := config.GenerateConfig()
|
|
||||||
var dat map[string]interface{}
|
|
||||||
if err := hjson.Unmarshal(configjson, &dat); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if err := mapstructure.Decode(dat, &nc); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
nc.IfName = "dummy"
|
|
||||||
if _, err := c.Start(nc, logger); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
go c.addStaticPeers(nc)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Generates mobile-friendly configuration in JSON format.
|
|
||||||
func GenerateConfigJSON() []byte {
|
|
||||||
nc := config.GenerateConfig()
|
|
||||||
nc.IfName = "dummy"
|
|
||||||
if json, err := json.Marshal(nc); err == nil {
|
|
||||||
return json
|
|
||||||
} else {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Gets the node's IPv6 address.
|
|
||||||
func (c *Core) GetAddressString() string {
|
|
||||||
return c.Address().String()
|
|
||||||
}
|
|
||||||
|
|
||||||
// Gets the node's IPv6 subnet in CIDR notation.
|
|
||||||
func (c *Core) GetSubnetString() string {
|
|
||||||
return c.Subnet().String()
|
|
||||||
}
|
|
||||||
|
|
||||||
// Gets the node's public encryption key.
|
|
||||||
func (c *Core) GetBoxPubKeyString() string {
|
|
||||||
return hex.EncodeToString(c.boxPub[:])
|
|
||||||
}
|
|
||||||
|
|
||||||
// Gets the node's public signing key.
|
|
||||||
func (c *Core) GetSigPubKeyString() string {
|
|
||||||
return hex.EncodeToString(c.sigPub[:])
|
|
||||||
}
|
|
||||||
|
|
||||||
// Wait for a packet from the router. You will use this when implementing a
|
|
||||||
// dummy adapter in place of real TUN - when this call returns a packet, you
|
|
||||||
// will probably want to give it to the OS to write to TUN.
|
|
||||||
func (c *Core) RouterRecvPacket() ([]byte, error) {
|
|
||||||
packet := <-c.router.recv
|
|
||||||
return packet, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Send a packet to the router. You will use this when implementing a
|
|
||||||
// dummy adapter in place of real TUN - when the operating system tells you
|
|
||||||
// that a new packet is available from TUN, call this function to give it to
|
|
||||||
// Yggdrasil.
|
|
||||||
func (c *Core) RouterSendPacket(buf []byte) error {
|
|
||||||
packet := append(util.GetBytes(), buf[:]...)
|
|
||||||
c.router.send <- packet
|
|
||||||
return nil
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user