summaryrefslogtreecommitdiffhomepage
path: root/dhcpv6/server.go
diff options
context:
space:
mode:
authorAndrea Barberio <insomniac@slackware.it>2018-09-27 14:26:43 +0100
committerAndrea Barberio <insomniac@slackware.it>2018-09-27 14:26:43 +0100
commit11ae3a9e108ac03ff64d2156af4127ed503c28ee (patch)
tree6b6e189805c4b95b7e837dac8eefb927beead5b1 /dhcpv6/server.go
parentde8157f8da4ae7516c90d7846cb327daa209f579 (diff)
Async read and tests
Diffstat (limited to 'dhcpv6/server.go')
-rw-r--r--dhcpv6/server.go53
1 files changed, 45 insertions, 8 deletions
diff --git a/dhcpv6/server.go b/dhcpv6/server.go
index b832a8a..15edd3f 100644
--- a/dhcpv6/server.go
+++ b/dhcpv6/server.go
@@ -4,6 +4,7 @@ import (
"fmt"
"log"
"net"
+ "time"
)
/*
@@ -44,8 +45,9 @@ func main() {
}
server := dhcpv6.NewServer(laddr, handler)
+ defer server.Close()
if err := server.ActivateAndServe(); err != nil {
- log.Fatal(err)
+ log.Panic(err)
}
}
@@ -57,15 +59,25 @@ type Handler func(conn net.PacketConn, peer net.Addr, m DHCPv6)
// Server represents a DHCPv6 server object
type Server struct {
- conn net.PacketConn
- LocalAddr net.UDPAddr
- Handler Handler
+ conn net.PacketConn
+ shouldStop bool
+ running bool
+ Handler Handler
+ localAddr net.UDPAddr
+}
+
+func (s *Server) LocalAddr() net.Addr {
+ if s.conn == nil {
+ return nil
+ }
+ return s.conn.LocalAddr()
}
// ActivateAndServe starts the DHCPv6 server
func (s *Server) ActivateAndServe() error {
+ s.shouldStop = false
if s.conn == nil {
- conn, err := net.ListenUDP("udp6", &s.LocalAddr)
+ conn, err := net.ListenUDP("udp6", &s.localAddr)
if err != nil {
return err
}
@@ -83,12 +95,23 @@ func (s *Server) ActivateAndServe() error {
}
log.Printf("Server listening on %s", pc.LocalAddr())
log.Print("Ready to handle requests")
+ s.running = true
for {
- log.Printf("Waiting..")
+ if s.shouldStop {
+ s.running = false
+ break
+ }
+ pc.SetReadDeadline(time.Now().Add(time.Second))
rbuf := make([]byte, 4096) // FIXME this is bad
n, peer, err := pc.ReadFrom(rbuf)
if err != nil {
- log.Printf("Error reading from packet conn: %v", err)
+ switch err.(type) {
+ case net.Error:
+ // silently skip and continue
+ default:
+ //complain and continue
+ log.Printf("Error reading from packet conn: %v", err)
+ }
continue
}
log.Printf("Handling request from %v", peer)
@@ -103,10 +126,24 @@ func (s *Server) ActivateAndServe() error {
return nil
}
+func (s *Server) Close() error {
+ s.shouldStop = true
+ for {
+ if !s.running {
+ break
+ }
+ time.Sleep(100 * time.Millisecond)
+ }
+ if s.conn != nil {
+ return s.conn.Close()
+ }
+ return nil
+}
+
// NewServer initializes and returns a new Server object
func NewServer(addr net.UDPAddr, handler Handler) *Server {
return &Server{
- LocalAddr: addr,
+ localAddr: addr,
Handler: handler,
}
}