git » debian:dnss » commit 9759b89

dnsserver: Use blitiri.com.ar/go/systemd to handle systemd sockets

author Alberto Bertogli
2020-05-28 23:52:52 UTC
committer Alberto Bertogli
2020-05-29 00:38:51 UTC
parent e0e45be1ad87fefa2fa3b03fe44798c0be45cacc

dnsserver: Use blitiri.com.ar/go/systemd to handle systemd sockets

This patch migrates the systemd socket passing to the
blitiri.com.ar/go/systemd package.

internal/dnsserver/server.go +15 -8

diff --git a/internal/dnsserver/server.go b/internal/dnsserver/server.go
index 161e9d3..9532b4b 100644
--- a/internal/dnsserver/server.go
+++ b/internal/dnsserver/server.go
@@ -10,12 +10,12 @@ import (
 	"strings"
 	"sync"
 
-	"github.com/coreos/go-systemd/activation"
 	"github.com/miekg/dns"
 	"golang.org/x/net/trace"
 
 	"blitiri.com.ar/go/dnss/internal/util"
 	"blitiri.com.ar/go/log"
+	"blitiri.com.ar/go/systemd"
 )
 
 // newID is a channel used to generate new request IDs.
@@ -184,17 +184,24 @@ func (s *Server) classicServe() {
 }
 
 func (s *Server) systemdServe() {
+	fsMap, err := systemd.Files()
+	if err != nil {
+		log.Fatalf("Error getting systemd listeners: %v", err)
+	}
+
 	// We will usually have at least one TCP socket and one UDP socket.
 	// PacketConns are UDP sockets, Listeners are TCP sockets.
 	pconns := []net.PacketConn{}
 	listeners := []net.Listener{}
-	for _, f := range activation.Files(true) {
-		if lis, err := net.FileListener(f); err == nil {
-			listeners = append(listeners, lis)
-			f.Close()
-		} else if pc, err := net.FilePacketConn(f); err == nil {
-			pconns = append(pconns, pc)
-			f.Close()
+	for _, fs := range fsMap {
+		for _, f := range fs {
+			if lis, err := net.FileListener(f); err == nil {
+				listeners = append(listeners, lis)
+				f.Close()
+			} else if pc, err := net.FilePacketConn(f); err == nil {
+				pconns = append(pconns, pc)
+				f.Close()
+			}
 		}
 	}