Skip to content

Commit

Permalink
Fix RetryPeersNow, move startup logging, don't set TUN address if n…
Browse files Browse the repository at this point in the history
…ot available
  • Loading branch information
neilalexander committed Oct 22, 2023
1 parent 955aa4a commit 094f80f
Show file tree
Hide file tree
Showing 9 changed files with 43 additions and 16 deletions.
6 changes: 5 additions & 1 deletion cmd/yggdrasil/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ func main() {

case "syslog":
if syslogger, err := gsyslog.NewLogger(gsyslog.LOG_NOTICE, "DAEMON", version.BuildName()); err == nil {
logger = log.New(syslogger, "", log.Flags() &^ (log.Ldate | log.Ltime))
logger = log.New(syslogger, "", log.Flags()&^(log.Ldate|log.Ltime))
}

default:
Expand Down Expand Up @@ -205,6 +205,10 @@ func main() {
if n.core, err = core.New(cfg.Certificate, logger, options...); err != nil {
panic(err)
}
address, subnet := n.core.Address(), n.core.Subnet()
logger.Infof("Your public key is %s", hex.EncodeToString(n.core.PublicKey()))
logger.Infof("Your IPv6 address is %s", address.String())
logger.Infof("Your IPv6 subnet is %s", subnet.String())
}

// Setup the admin socket.
Expand Down
4 changes: 4 additions & 0 deletions contrib/mobile/mobile.go
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,10 @@ func (m *Yggdrasil) StartJSON(configjson []byte) error {
if err != nil {
panic(err)
}
address, subnet := m.core.Address(), m.core.Subnet()
logger.Infof("Your public key is %s", hex.EncodeToString(m.core.PublicKey()))
logger.Infof("Your IPv6 address is %s", address.String())
logger.Infof("Your IPv6 subnet is %s", subnet.String())
}

// Setup the multicast module.
Expand Down
14 changes: 8 additions & 6 deletions src/core/core.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ import (
"context"
"crypto/ed25519"
"crypto/tls"
"encoding/hex"
"fmt"
"io"
"net"
Expand Down Expand Up @@ -104,10 +103,6 @@ func New(cert *tls.Certificate, logger Logger, opts ...SetupOption) (*Core, erro
); err != nil {
return nil, fmt.Errorf("error creating encryption: %w", err)
}
address, subnet := c.Address(), c.Subnet()
c.log.Infof("Your public key is %s", hex.EncodeToString(c.public))
c.log.Infof("Your IPv6 address is %s", address.String())
c.log.Infof("Your IPv6 subnet is %s", subnet.String())
c.proto.init(c)
if err := c.links.init(c); err != nil {
return nil, fmt.Errorf("error initialising links: %w", err)
Expand Down Expand Up @@ -140,7 +135,14 @@ func New(cert *tls.Certificate, logger Logger, opts ...SetupOption) (*Core, erro
}

func (c *Core) RetryPeersNow() {
// TODO: figure out a way to retrigger peer connections.
phony.Block(&c.links, func() {
for _, l := range c.links._links {
select {
case l.kick <- struct{}{}:
default:
}
}
})
}

// Stop shuts down the Yggdrasil node.
Expand Down
7 changes: 5 additions & 2 deletions src/tun/tun.go
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ type TunAdapter struct {
isOpen bool
isEnabled bool // Used by the writer to drop sessionTraffic if not enabled
config struct {
fd int32
fd int32
name InterfaceName
mtu InterfaceMTU
}
Expand Down Expand Up @@ -116,7 +116,10 @@ func (tun *TunAdapter) _start() error {
tun.addr = tun.rwc.Address()
tun.subnet = tun.rwc.Subnet()
prefix := address.GetPrefix()
addr := fmt.Sprintf("%s/%d", net.IP(tun.addr[:]).String(), 8*len(prefix[:])-1)
var addr string
if tun.addr.IsValid() {
addr = fmt.Sprintf("%s/%d", net.IP(tun.addr[:]).String(), 8*len(prefix[:])-1)
}
if tun.config.name == "none" || tun.config.name == "dummy" {
tun.log.Debugln("Not starting TUN as ifname is none or dummy")
tun.isEnabled = false
Expand Down
5 changes: 4 additions & 1 deletion src/tun/tun_bsd.go
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,10 @@ func (tun *TunAdapter) setup(ifname string, addr string, mtu uint64) error {
} else {
tun.mtu = 0
}
return tun.setupAddress(addr)
if addr != "" {
return tun.setupAddress(addr)
}
return nil
}

// Configures the "utun" adapter from an existing file descriptor.
Expand Down
5 changes: 4 additions & 1 deletion src/tun/tun_darwin.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,10 @@ func (tun *TunAdapter) setup(ifname string, addr string, mtu uint64) error {
} else {
tun.mtu = 0
}
return tun.setupAddress(addr)
if addr != "" {
return tun.setupAddress(addr)
}
return nil
}

// Configures the "utun" adapter from an existing file descriptor.
Expand Down
5 changes: 4 additions & 1 deletion src/tun/tun_linux.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,10 @@ func (tun *TunAdapter) setup(ifname string, addr string, mtu uint64) error {
} else {
tun.mtu = 0
}
return tun.setupAddress(addr)
if addr != "" {
return tun.setupAddress(addr)
}
return nil
}

// Configures the "utun" adapter from an existing file descriptor.
Expand Down
5 changes: 4 additions & 1 deletion src/tun/tun_other.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,10 @@ func (tun *TunAdapter) setup(ifname string, addr string, mtu uint64) error {
} else {
tun.mtu = 0
}
return tun.setupAddress(addr)
if addr != "" {
return tun.setupAddress(addr)
}
return nil
}

// Configures the "utun" adapter from an existing file descriptor.
Expand Down
8 changes: 5 additions & 3 deletions src/tun/tun_windows.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,9 +35,11 @@ func (tun *TunAdapter) setup(ifname string, addr string, mtu uint64) error {
return err
}
tun.iface = iface
if err = tun.setupAddress(addr); err != nil {
tun.log.Errorln("Failed to set up TUN address:", err)
return err
if addr != "" {
if err = tun.setupAddress(addr); err != nil {
tun.log.Errorln("Failed to set up TUN address:", err)
return err
}
}
if err = tun.setupMTU(getSupportedMTU(mtu)); err != nil {
tun.log.Errorln("Failed to set up TUN MTU:", err)
Expand Down

0 comments on commit 094f80f

Please sign in to comment.