summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorMichaIng <micha@dietpi.com>2021-07-09 15:44:14 +0200
committerGitHub <noreply@github.com>2021-07-09 15:44:14 +0200
commitcd0343e6b94b0b3aa61f31efb1372ea67b80b620 (patch)
tree02e34146c73b922e3772306d893aed397d7c1c3a /lib
parent1826107f562bcde840e8b7e138ea13cf356b3981 (diff)
parenta626792e15ae33138ddac793a50ea29364482e5f (diff)
downloadnextcloud-server-cd0343e6b94b0b3aa61f31efb1372ea67b80b620.tar.gz
nextcloud-server-cd0343e6b94b0b3aa61f31efb1372ea67b80b620.zip
Merge pull request #27825 from nextcloud/backport/27801/stable22
[stable22] Ignore subdomain for soa queries
Diffstat (limited to 'lib')
-rw-r--r--lib/private/Http/Client/DnsPinMiddleware.php41
1 files changed, 28 insertions, 13 deletions
diff --git a/lib/private/Http/Client/DnsPinMiddleware.php b/lib/private/Http/Client/DnsPinMiddleware.php
index 0eba77d5421..9e5cfc919f1 100644
--- a/lib/private/Http/Client/DnsPinMiddleware.php
+++ b/lib/private/Http/Client/DnsPinMiddleware.php
@@ -41,6 +41,28 @@ class DnsPinMiddleware {
$this->localAddressChecker = $localAddressChecker;
}
+ /**
+ * Fetch soa record for a target
+ *
+ * @param string $target
+ * @return array|null
+ */
+ private function soaRecord(string $target): ?array {
+ $labels = explode('.', $target);
+
+ $top = count($labels) >= 2 ? array_pop($labels) : '';
+ $second = array_pop($labels);
+
+ $hostname = $second . '.' . $top;
+ $responses = dns_get_record($hostname, DNS_SOA);
+
+ if ($responses === false || count($responses) === 0) {
+ return null;
+ }
+
+ return reset($responses);
+ }
+
private function dnsResolve(string $target, int $recursionCount) : array {
if ($recursionCount >= 10) {
return [];
@@ -49,24 +71,19 @@ class DnsPinMiddleware {
$recursionCount++;
$targetIps = [];
- $soaDnsEntry = dns_get_record($target, DNS_SOA);
- if (isset($soaDnsEntry[0]) && isset($soaDnsEntry[0]['minimum-ttl'])) {
- $dnsNegativeTtl = $soaDnsEntry[0]['minimum-ttl'];
- } else {
- $dnsNegativeTtl = null;
- }
+ $soaDnsEntry = $this->soaRecord($target);
+ $dnsNegativeTtl = $soaDnsEntry['minimum-ttl'] ?? null;
$dnsTypes = [DNS_A, DNS_AAAA, DNS_CNAME];
- foreach ($dnsTypes as $key => $dnsType) {
+ foreach ($dnsTypes as $dnsType) {
if ($this->negativeDnsCache->isNegativeCached($target, $dnsType)) {
- unset($dnsTypes[$key]);
continue;
}
$dnsResponses = dns_get_record($target, $dnsType);
$canHaveCnameRecord = true;
if (count($dnsResponses) > 0) {
- foreach ($dnsResponses as $key => $dnsResponse) {
+ foreach ($dnsResponses as $dnsResponse) {
if (isset($dnsResponse['ip'])) {
$targetIps[] = $dnsResponse['ip'];
$canHaveCnameRecord = false;
@@ -78,10 +95,8 @@ class DnsPinMiddleware {
$canHaveCnameRecord = true;
}
}
- } else {
- if ($dnsNegativeTtl !== null) {
- $this->negativeDnsCache->setNegativeCacheForDnsType($target, $dnsType, $dnsNegativeTtl);
- }
+ } elseif ($dnsNegativeTtl !== null) {
+ $this->negativeDnsCache->setNegativeCacheForDnsType($target, $dnsType, $dnsNegativeTtl);
}
}