From: Christof Chen Date: Thu, 11 May 2023 18:00:01 +0000 (+0200) Subject: fix #12801 + regression test X-Git-Tag: dnsdist-1.8.1~7^2 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=bcaecbfcc96c45118923935c8005938251e670b2;p=thirdparty%2Fpdns.git fix #12801 + regression test (cherry picked from commit 6bb404b627442d64b829edcffcc9f5fbc4987eb4) --- diff --git a/pdns/dnsdist-lua-actions.cc b/pdns/dnsdist-lua-actions.cc index acbada4e14..5d3271a368 100644 --- a/pdns/dnsdist-lua-actions.cc +++ b/pdns/dnsdist-lua-actions.cc @@ -880,12 +880,14 @@ DNSAction::Action SpoofAction::operator()(DNSQuestion* dq, std::string* ruleresu dq->getHeader()->arcount = 0; // for now, forget about your EDNS, we're marching over it uint32_t ttl = htonl(d_responseConfig.ttl); + uint16_t qclass = htons(dq->ids.qclass); unsigned char recordstart[] = {0xc0, 0x0c, // compressed name 0, 0, // QTYPE - 0, QClass::IN, + 0, 0, // QCLASS 0, 0, 0, 0, // TTL 0, 0 }; // rdata length static_assert(sizeof(recordstart) == 12, "sizeof(recordstart) must be equal to 12, otherwise the above check is invalid"); + memcpy(&recordstart[4], &qclass, sizeof(qclass)); memcpy(&recordstart[6], &ttl, sizeof(ttl)); bool raw = false; diff --git a/regression-tests.dnsdist/test_Spoofing.py b/regression-tests.dnsdist/test_Spoofing.py index ff89f406e0..d40c13ca5e 100644 --- a/regression-tests.dnsdist/test_Spoofing.py +++ b/regression-tests.dnsdist/test_Spoofing.py @@ -16,6 +16,7 @@ class TestSpoofingSpoof(DNSDistTest): addAction(AndRule{makeRule("raw.spoofing.tests.powerdns.com"), QTypeRule(DNSQType.A)}, SpoofRawAction("\\192\\000\\002\\001")) addAction(AndRule{makeRule("raw.spoofing.tests.powerdns.com"), QTypeRule(DNSQType.TXT)}, SpoofRawAction("\\003aaa\\004bbbb\\011ccccccccccc")) addAction(AndRule{makeRule("raw.spoofing.tests.powerdns.com"), QTypeRule(DNSQType.SRV)}, SpoofRawAction("\\000\\000\\000\\000\\255\\255\\003srv\\008powerdns\\003com\\000", { aa=true, ttl=3600 })) + addAction(AndRule{makeRule("rawchaos.spoofing.tests.powerdns.com"), QTypeRule(DNSQType.TXT), QClassRule(DNSClass.CHAOS)}, SpoofRawAction("\\005chaos")) addAction(AndRule{makeRule("multiraw.spoofing.tests.powerdns.com"), QTypeRule(DNSQType.TXT)}, SpoofRawAction({"\\003aaa\\004bbbb", "\\011ccccccccccc"})) addAction(AndRule{makeRule("multiraw.spoofing.tests.powerdns.com"), QTypeRule(DNSQType.A)}, SpoofRawAction({"\\192\\000\\002\\001", "\\192\\000\\002\\002"})) newServer{address="127.0.0.1:%s"} @@ -359,6 +360,32 @@ class TestSpoofingSpoof(DNSDistTest): self.assertEqual(expectedResponse, receivedResponse) self.assertEqual(receivedResponse.answer[0].ttl, 3600) + def testSpoofRawChaosAction(self): + """ + Spoofing: Spoof a response from several raw bytes in QCLass CH + """ + name = 'rawchaos.spoofing.tests.powerdns.com.' + + # TXT CH + query = dns.message.make_query(name, 'TXT', 'CH') + query.flags &= ~dns.flags.RD + expectedResponse = dns.message.make_response(query) + expectedResponse.flags &= ~dns.flags.AA + rrset = dns.rrset.from_text(name, + 60, + dns.rdataclass.CH, + dns.rdatatype.TXT, + '"chaos"') + expectedResponse.answer.append(rrset) + + for method in ("sendUDPQuery", "sendTCPQuery"): + sender = getattr(self, method) + (_, receivedResponse) = sender(query, response=None, useQueue=False) + self.assertTrue(receivedResponse) + self.assertEqual(expectedResponse, receivedResponse) + self.assertEqual(receivedResponse.answer[0].ttl, 60) + + def testSpoofRawActionMulti(self): """ Spoofing: Spoof a response from several raw bytes