From 7c0ccdafc33fbe0dcf6d6b8c4a509f3ecab0951e Mon Sep 17 00:00:00 2001 From: Alfonso Acosta Date: Fri, 23 Sep 2016 13:51:19 +0000 Subject: [PATCH] Skip DNS length field (only included over TCP) --- probe/endpoint/dns_snooper_linux_amd64.go | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/probe/endpoint/dns_snooper_linux_amd64.go b/probe/endpoint/dns_snooper_linux_amd64.go index 8effef4ce9..4c2571e610 100644 --- a/probe/endpoint/dns_snooper_linux_amd64.go +++ b/probe/endpoint/dns_snooper_linux_amd64.go @@ -112,6 +112,7 @@ func (s *DNSSnooper) Stop() { } // Gopacket doesn't provide direct support for DNS over TCP, see https://github.com/google/gopacket/issues/236 +// TODO: deal with TCP fragmentation and out-of-order segments type tcpWithDNSSupport struct { tcp layers.TCP } @@ -126,7 +127,15 @@ func (m *tcpWithDNSSupport) NextLayerType() gopacket.LayerType { } return m.tcp.NextLayerType() } -func (m *tcpWithDNSSupport) LayerPayload() []byte { return m.tcp.LayerPayload() } +func (m *tcpWithDNSSupport) LayerPayload() []byte { + payload := m.tcp.LayerPayload() + // Omit the length DNS length field, only included + // in TCP in order to reuse the DNS UDP parser + if len(payload) > 1 && (m.tcp.SrcPort == 53 || m.tcp.DstPort == 53) { + payload = payload[2:] + } + return payload +} func (s *DNSSnooper) run() { var (