Skip to content

Commit

Permalink
Guard e2e udp and tun channels when closed (#934)
Browse files Browse the repository at this point in the history
  • Loading branch information
nbrownus authored Jul 26, 2023
1 parent e5af94e commit 9c6592b
Show file tree
Hide file tree
Showing 3 changed files with 32 additions and 4 deletions.
2 changes: 2 additions & 0 deletions e2e/handshakes_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -410,6 +410,8 @@ func TestStage1RaceRelays(t *testing.T) {
p := r.RouteForAllUntilTxTun(myControl)
_ = p

r.FlushAll()

myControl.Stop()
theirControl.Stop()
relayControl.Stop()
Expand Down
15 changes: 14 additions & 1 deletion overlay/tun_tester.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import (
"io"
"net"
"os"
"sync/atomic"

"github.com/sirupsen/logrus"
"github.com/slackhq/nebula/cidr"
Expand All @@ -21,6 +22,7 @@ type TestTun struct {
routeTree *cidr.Tree4
l *logrus.Logger

closed atomic.Bool
rxPackets chan []byte // Packets to receive into nebula
TxPackets chan []byte // Packets transmitted outside by nebula
}
Expand Down Expand Up @@ -50,6 +52,10 @@ func newTunFromFd(_ *logrus.Logger, _ int, _ *net.IPNet, _ int, _ []Route, _ int
// These are unencrypted ip layer frames destined for another nebula node.
// packets should exit the udp side, capture them with udpConn.Get
func (t *TestTun) Send(packet []byte) {
if t.closed.Load() {
return
}

if t.l.Level >= logrus.DebugLevel {
t.l.WithField("dataLen", len(packet)).Debug("Tun receiving injected packet")
}
Expand Down Expand Up @@ -98,14 +104,21 @@ func (t *TestTun) Name() string {
}

func (t *TestTun) Write(b []byte) (n int, err error) {
if t.closed.Load() {
return 0, io.ErrClosedPipe
}

packet := make([]byte, len(b), len(b))
copy(packet, b)
t.TxPackets <- packet
return len(b), nil
}

func (t *TestTun) Close() error {
close(t.rxPackets)
if t.closed.CompareAndSwap(false, true) {
close(t.rxPackets)
close(t.TxPackets)
}
return nil
}

Expand Down
19 changes: 16 additions & 3 deletions udp/udp_tester.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,9 @@ package udp

import (
"fmt"
"io"
"net"
"sync/atomic"

"github.com/sirupsen/logrus"
"github.com/slackhq/nebula/config"
Expand Down Expand Up @@ -42,7 +44,8 @@ type TesterConn struct {
RxPackets chan *Packet // Packets to receive into nebula
TxPackets chan *Packet // Packets transmitted outside by nebula

l *logrus.Logger
closed atomic.Bool
l *logrus.Logger
}

func NewListener(l *logrus.Logger, ip net.IP, port int, _ bool, _ int) (Conn, error) {
Expand All @@ -58,6 +61,10 @@ func NewListener(l *logrus.Logger, ip net.IP, port int, _ bool, _ int) (Conn, er
// this is an encrypted packet or a handshake message in most cases
// packets were transmitted from another nebula node, you can send them with Tun.Send
func (u *TesterConn) Send(packet *Packet) {
if u.closed.Load() {
return
}

h := &header.H{}
if err := h.Parse(packet.Data); err != nil {
panic(err)
Expand Down Expand Up @@ -92,6 +99,10 @@ func (u *TesterConn) Get(block bool) *Packet {
//********************************************************************************************************************//

func (u *TesterConn) WriteTo(b []byte, addr *Addr) error {
if u.closed.Load() {
return io.ErrClosedPipe
}

p := &Packet{
Data: make([]byte, len(b), len(b)),
FromIp: make([]byte, 16),
Expand Down Expand Up @@ -142,7 +153,9 @@ func (u *TesterConn) Rebind() error {
}

func (u *TesterConn) Close() error {
close(u.RxPackets)
close(u.TxPackets)
if u.closed.CompareAndSwap(false, true) {
close(u.RxPackets)
close(u.TxPackets)
}
return nil
}

0 comments on commit 9c6592b

Please sign in to comment.