mirror of
https://github.com/systemd/systemd.git
synced 2024-12-17 06:03:35 +08:00
resolved: bypass local cache when we issue a transaction for verification purposes
This commit is contained in:
parent
cd1b20f90a
commit
4d926a69bc
@ -465,24 +465,29 @@ int dns_transaction_go(DnsTransaction *t) {
|
||||
t->cached = dns_answer_unref(t->cached);
|
||||
t->cached_rcode = 0;
|
||||
|
||||
/* Before trying the cache, let's make sure we figured out a
|
||||
* server to use. Should this cause a change of server this
|
||||
* might flush the cache. */
|
||||
dns_scope_get_dns_server(t->scope);
|
||||
/* Check the cache, but only if this transaction is not used
|
||||
* for probing or verifying a zone item. */
|
||||
if (set_isempty(t->zone_items)) {
|
||||
|
||||
/* Let's then prune all outdated entries */
|
||||
dns_cache_prune(&t->scope->cache);
|
||||
/* Before trying the cache, let's make sure we figured out a
|
||||
* server to use. Should this cause a change of server this
|
||||
* might flush the cache. */
|
||||
dns_scope_get_dns_server(t->scope);
|
||||
|
||||
r = dns_cache_lookup(&t->scope->cache, t->question, &t->cached_rcode, &t->cached);
|
||||
if (r < 0)
|
||||
return r;
|
||||
if (r > 0) {
|
||||
log_debug("Cache hit!");
|
||||
if (t->cached_rcode == DNS_RCODE_SUCCESS)
|
||||
dns_transaction_complete(t, DNS_TRANSACTION_SUCCESS);
|
||||
else
|
||||
dns_transaction_complete(t, DNS_TRANSACTION_FAILURE);
|
||||
return 0;
|
||||
/* Let's then prune all outdated entries */
|
||||
dns_cache_prune(&t->scope->cache);
|
||||
|
||||
r = dns_cache_lookup(&t->scope->cache, t->question, &t->cached_rcode, &t->cached);
|
||||
if (r < 0)
|
||||
return r;
|
||||
if (r > 0) {
|
||||
log_debug("Cache hit!");
|
||||
if (t->cached_rcode == DNS_RCODE_SUCCESS)
|
||||
dns_transaction_complete(t, DNS_TRANSACTION_SUCCESS);
|
||||
else
|
||||
dns_transaction_complete(t, DNS_TRANSACTION_FAILURE);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
log_debug("Cache miss!");
|
||||
|
Loading…
Reference in New Issue
Block a user