mirror of https://github.com/getdnsapi/getdns.git
parent
3bec89bee5
commit
65663e6da8
|
@ -1,6 +1,8 @@
|
||||||
* 2015-10-??: Version 0.3.4
|
* 2015-10-??: Version 0.3.4
|
||||||
* Native crypto. No ldns dependency anymore.
|
* Native crypto. No ldns dependency anymore.
|
||||||
(ldns still necessary to be able to run tests though)
|
(ldns still necessary to be able to run tests though)
|
||||||
|
* Bugfix: DNSSEC code finding zone cut with redirects + pursuing unsigned
|
||||||
|
DS answers close to the root. Thanks Theogene Bucuti!
|
||||||
|
|
||||||
* 2015-09-09: Version 0.3.3
|
* 2015-09-09: Version 0.3.3
|
||||||
* Fix clearing upstream events on shutdown
|
* Fix clearing upstream events on shutdown
|
||||||
|
|
17
src/dnssec.c
17
src/dnssec.c
|
@ -1269,6 +1269,7 @@ static void val_chain_node_cb(getdns_dns_req *dnsreq)
|
||||||
rrset_iter *i, i_spc;
|
rrset_iter *i, i_spc;
|
||||||
getdns_rrset *rrset;
|
getdns_rrset *rrset;
|
||||||
rrsig_iter *rrsig, rrsig_spc;
|
rrsig_iter *rrsig, rrsig_spc;
|
||||||
|
size_t n_signers;
|
||||||
|
|
||||||
_getdns_context_clear_outbound_request(dnsreq);
|
_getdns_context_clear_outbound_request(dnsreq);
|
||||||
switch (netreq->request_type) {
|
switch (netreq->request_type) {
|
||||||
|
@ -1280,6 +1281,7 @@ static void val_chain_node_cb(getdns_dns_req *dnsreq)
|
||||||
default : check_chain_complete(node->chains);
|
default : check_chain_complete(node->chains);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
n_signers = 0;
|
||||||
for ( i = rrset_iter_init(&i_spc,netreq->response,netreq->response_len)
|
for ( i = rrset_iter_init(&i_spc,netreq->response,netreq->response_len)
|
||||||
; i
|
; i
|
||||||
; i = rrset_iter_next(i)) {
|
; i = rrset_iter_next(i)) {
|
||||||
|
@ -1292,10 +1294,18 @@ static void val_chain_node_cb(getdns_dns_req *dnsreq)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
for ( rrsig = rrsig_iter_init(&rrsig_spc, rrset)
|
for ( rrsig = rrsig_iter_init(&rrsig_spc, rrset)
|
||||||
; rrsig; rrsig = rrsig_iter_next(rrsig))
|
; rrsig; rrsig = rrsig_iter_next(rrsig)) {
|
||||||
|
|
||||||
val_chain_sched_signer_node(node, rrsig);
|
val_chain_sched_signer_node(node, rrsig);
|
||||||
|
n_signers++;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
if (netreq->request_type == GETDNS_RRTYPE_DS && n_signers == 0)
|
||||||
|
/* No signed DS and no signed proof of non-existance.
|
||||||
|
* Search further up the tree...
|
||||||
|
*/
|
||||||
|
val_chain_sched_soa_node(node->parent);
|
||||||
|
|
||||||
check_chain_complete(node->chains);
|
check_chain_complete(node->chains);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1317,6 +1327,11 @@ static void val_chain_node_soa_cb(getdns_dns_req *dnsreq)
|
||||||
|
|
||||||
if (node)
|
if (node)
|
||||||
val_chain_sched_ds_node(node);
|
val_chain_sched_ds_node(node);
|
||||||
|
else {
|
||||||
|
/* SOA for a different name */
|
||||||
|
node = (chain_node *)dnsreq->user_pointer;
|
||||||
|
val_chain_sched_soa_node(node->parent);
|
||||||
|
}
|
||||||
|
|
||||||
} else if (node->parent)
|
} else if (node->parent)
|
||||||
val_chain_sched_soa_node(node->parent);
|
val_chain_sched_soa_node(node->parent);
|
||||||
|
|
Loading…
Reference in New Issue