From 36df936e684d2fe90176c3ad86eab9c19af15012 Mon Sep 17 00:00:00 2001 From: Samuel Ortiz Date: Fri, 24 Sep 2010 23:59:38 +0200 Subject: Add support for domain name concatenation on TCP DNS requests --- plugins/dnsproxy.c | 26 +++++++++++++++++++------- 1 file changed, 19 insertions(+), 7 deletions(-) (limited to 'plugins') diff --git a/plugins/dnsproxy.c b/plugins/dnsproxy.c index ca58df5d..eae9a617 100644 --- a/plugins/dnsproxy.c +++ b/plugins/dnsproxy.c @@ -318,31 +318,43 @@ static int ns_resolv(struct server_data *server, struct request_data *req, req->numserv++; - if (server->domain != NULL && server->protocol == IPPROTO_UDP) { + if (server->domain != NULL) { unsigned char alt[1024]; struct domain_hdr *hdr = (void *) &alt; - int altlen, domlen; + int altlen, domlen, offset; + + offset = protocol_offset(server->protocol); + if (offset < 0) + return offset; domlen = strlen(server->domain) + 1; if (domlen < 5) return -EINVAL; - alt[0] = req->altid & 0xff; - alt[1] = req->altid >> 8; + alt[offset] = req->altid & 0xff; + alt[offset + 1] = req->altid >> 8; - memcpy(alt + 2, request + 2, 10); + memcpy(alt + offset + 2, request + offset + 2, 10); hdr->qdcount = htons(1); - altlen = append_query(alt + 12, sizeof(alt) - 12, + altlen = append_query(alt + offset + 12, sizeof(alt) - 12, name, server->domain); if (altlen < 0) return -EINVAL; altlen += 12; - memcpy(alt + altlen, request + altlen - domlen, + memcpy(alt + offset + altlen, + request + offset + altlen - domlen, req->request_len - altlen + domlen); + if (server->protocol == IPPROTO_TCP) { + int req_len = req->request_len + domlen - 1; + + alt[0] = (req_len >> 8) & 0xff; + alt[1] = req_len & 0xff; + } + err = send(sk, alt, req->request_len + domlen + 1, 0); req->numserv++; -- cgit v1.2.3