summaryrefslogtreecommitdiffstats
path: root/apps/dav/lib
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2019-07-02 23:02:25 +0200
committerGitHub <noreply@github.com>2019-07-02 23:02:25 +0200
commitc32f14e443eb2703d3cc41d0a0437228656faab9 (patch)
tree1d2323721f346ea57e4a2241f66347f402699a76 /apps/dav/lib
parent93133b687c1309f4edff34f42f9a1826442d7f5f (diff)
parent089a421ecec1c5c51b9811ff24ec0035d4e604c1 (diff)
downloadnextcloud-server-c32f14e443eb2703d3cc41d0a0437228656faab9.tar.gz
nextcloud-server-c32f14e443eb2703d3cc41d0a0437228656faab9.zip
Merge pull request #16199 from nextcloud/bugfix/noid/refresh_webcal_job_enhancements
RefreshWebcalJob: replace ugly Regex with standard php utils
Diffstat (limited to 'apps/dav/lib')
-rw-r--r--apps/dav/lib/BackgroundJob/RefreshWebcalJob.php17
1 files changed, 14 insertions, 3 deletions
diff --git a/apps/dav/lib/BackgroundJob/RefreshWebcalJob.php b/apps/dav/lib/BackgroundJob/RefreshWebcalJob.php
index 871734aab55..e99cd7038f6 100644
--- a/apps/dav/lib/BackgroundJob/RefreshWebcalJob.php
+++ b/apps/dav/lib/BackgroundJob/RefreshWebcalJob.php
@@ -225,14 +225,25 @@ class RefreshWebcalJob extends Job {
}
if ($allowLocalAccess !== 'yes') {
- $host = parse_url($url, PHP_URL_HOST);
+ $host = strtolower(parse_url($url, PHP_URL_HOST));
// remove brackets from IPv6 addresses
if (strpos($host, '[') === 0 && substr($host, -1) === ']') {
$host = substr($host, 1, -1);
}
- if ($host === 'localhost' || substr($host, -6) === '.local' || substr($host, -10) === '.localhost' ||
- preg_match('/(^127\.)|(^192\.168\.)|(^10\.)|(^172\.1[6-9]\.)|(^172\.2[0-9]\.)|(^172\.3[0-1]\.)|(^::1$)|(^[fF][cCdD])/', $host)) {
+ // Disallow localhost and local network
+ if ($host === 'localhost' || substr($host, -6) === '.local' || substr($host, -10) === '.localhost') {
+ $this->logger->warning("Subscription $subscriptionId was not refreshed because it violates local access rules");
+ return null;
+ }
+
+ // Disallow hostname only
+ if (substr_count($host, '.') === 0) {
+ $this->logger->warning("Subscription $subscriptionId was not refreshed because it violates local access rules");
+ return null;
+ }
+
+ if ((bool)filter_var($host, FILTER_VALIDATE_IP) && !filter_var($host, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE | FILTER_FLAG_NO_RES_RANGE)) {
$this->logger->warning("Subscription $subscriptionId was not refreshed because it violates local access rules");
return null;
}