From: pdns-recursor packagers Date: Tue, 19 May 2020 08:52:06 +0000 (+0100) Subject: bogus-empty-nxd-4.1.15 X-Git-Tag: archive/raspbian/4.1.11-1+rpi1+deb10u1^2~3 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=22e317bf62bfa5ff6839eea007068d2841ac37b0;p=pdns-recursor.git bogus-empty-nxd-4.1.15 =================================================================== Gbp-Pq: Name bogus-empty-nxd-4.1.15.diff --- diff --git a/syncres.cc b/syncres.cc index 3840e31..2b00021 100644 --- a/syncres.cc +++ b/syncres.cc @@ -2569,6 +2569,10 @@ bool SyncRes::processAnswer(unsigned int depth, LWResult& lwr, const DNSName& qn if(lwr.d_rcode == RCode::NXDomain) { LOG(prefix< sr; + initSR(sr, true); + + setDNSSECValidation(sr, DNSSECMode::ValidateAll); + + primeHints(); + const DNSName target("powerdns.com."); + testkeysset_t keys; + + auto luaconfsCopy = g_luaconfs.getCopy(); + luaconfsCopy.dsAnchors.clear(); + generateKeyMaterial(DNSName("."), DNSSECKeeper::ECDSA256, DNSSECKeeper::SHA256, keys, luaconfsCopy.dsAnchors); + generateKeyMaterial(DNSName("com."), DNSSECKeeper::ECDSA256, DNSSECKeeper::SHA256, keys, luaconfsCopy.dsAnchors); + generateKeyMaterial(DNSName("powerdns.com."), DNSSECKeeper::ECDSA256, DNSSECKeeper::SHA256, keys); + g_luaconfs.setState(luaconfsCopy); + + size_t queriesCount = 0; + + sr->setAsyncCallback([target,&queriesCount,keys](const ComboAddress& ip, const DNSName& domain, int type, bool doTCP, bool sendRDQuery, int EDNS0Level, struct timeval* now, boost::optional& srcmask, boost::optional context, std::shared_ptr outgoingLogger, LWResult* res, bool* chained) { + queriesCount++; + + if (type == QType::DS || type == QType::DNSKEY) { + return genericDSAndDNSKEYHandler(res, domain, domain, type, keys); + } + else { + + setLWResult(res, RCode::NXDomain, true, false, true); + return 1; + } + + return 0; + }); + + vector ret; + int res = sr->beginResolve(target, QType(QType::A), QClass::IN, ret); + BOOST_CHECK_EQUAL(res, RCode::NXDomain); + BOOST_CHECK_EQUAL(sr->getValidationState(), Bogus); + BOOST_REQUIRE_EQUAL(ret.size(), 0U); + /* com|NS, powerdns.com|NS, powerdns.com|A */ + BOOST_CHECK_EQUAL(queriesCount, 3U); + + /* again, to test the cache */ + ret.clear(); + res = sr->beginResolve(target, QType(QType::A), QClass::IN, ret); + BOOST_CHECK_EQUAL(res, RCode::NXDomain); + BOOST_CHECK_EQUAL(sr->getValidationState(), Bogus); + BOOST_REQUIRE_EQUAL(ret.size(), 0U); + /* we don't store empty results */ + BOOST_CHECK_EQUAL(queriesCount, 4U); +} + BOOST_AUTO_TEST_CASE(test_nsec_denial_nowrap) { init();