Skip to content

Commit 1a198b8

Browse files
georglauterbachbackportbot[bot]
authored andcommitted
fix: do not query CNAME if A succeeded already
Signed-off-by: georglauterbach <44545919+georglauterbach@users.noreply.github.com>
1 parent d0d5bc6 commit 1a198b8

File tree

2 files changed

+8
-3
lines changed

2 files changed

+8
-3
lines changed

lib/private/Http/Client/DnsPinMiddleware.php

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -74,15 +74,19 @@ private function dnsResolve(string $target, int $recursionCount) : array {
7474

7575
$soaDnsEntry = $this->soaRecord($target);
7676
$dnsNegativeTtl = $soaDnsEntry['minimum-ttl'] ?? null;
77+
$canHaveCnameRecord = true;
7778

7879
$dnsTypes = [DNS_A, DNS_AAAA, DNS_CNAME];
7980
foreach ($dnsTypes as $dnsType) {
81+
if ($canHaveCnameRecord === false && $dnsType === DNS_CNAME) {
82+
continue;
83+
}
84+
8085
if ($this->negativeDnsCache->isNegativeCached($target, $dnsType)) {
8186
continue;
8287
}
8388

8489
$dnsResponses = $this->dnsGetRecord($target, $dnsType);
85-
$canHaveCnameRecord = true;
8690
if ($dnsResponses !== false && count($dnsResponses) > 0) {
8791
foreach ($dnsResponses as $dnsResponse) {
8892
if (isset($dnsResponse['ip'])) {

tests/lib/Http/Client/DnsPinMiddlewareTest.php

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -554,10 +554,11 @@ static function (RequestInterface $request, array $options) {
554554
['nextcloud' => ['allow_local_address' => false]]
555555
);
556556

557-
$this->assertCount(4, $dnsQueries);
557+
$this->assertCount(3, $dnsQueries);
558558
$this->assertContains('example.com' . DNS_SOA, $dnsQueries);
559559
$this->assertContains('subsubdomain.subdomain.example.com' . DNS_A, $dnsQueries);
560560
$this->assertContains('subsubdomain.subdomain.example.com' . DNS_AAAA, $dnsQueries);
561-
$this->assertContains('subsubdomain.subdomain.example.com' . DNS_CNAME, $dnsQueries);
561+
// CNAME should not be queried if A or AAAA succeeded already
562+
$this->assertNotContains('subsubdomain.subdomain.example.com' . DNS_CNAME, $dnsQueries);
562563
}
563564
}

0 commit comments

Comments
 (0)