summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVincent Petry <vincent@nextcloud.com>2021-10-01 14:45:40 +0200
committerGitHub <noreply@github.com>2021-10-01 14:45:40 +0200
commitfb2fd3457650464230e052a91f573ba052950fef (patch)
treef095b5aa6e0a940c9ad17bd66dbc483777698775
parent4737708807203c091825bc3f65f7004abe505104 (diff)
parent18cc6c11b51b94ef0e2be55a0cf11de920b87870 (diff)
downloadnextcloud-server-fb2fd3457650464230e052a91f573ba052950fef.tar.gz
nextcloud-server-fb2fd3457650464230e052a91f573ba052950fef.zip
Merge pull request #28263 from Hinyka/bugfix/27759
Fix Lots of Error: file_exists(): open_basedir restriction in effect.…
-rw-r--r--lib/private/Route/Router.php5
-rw-r--r--lib/private/Template/Base.php2
-rw-r--r--lib/private/Template/IconsCacher.php5
-rwxr-xr-xlib/private/Template/ResourceLocator.php2
4 files changed, 9 insertions, 5 deletions
diff --git a/lib/private/Route/Router.php b/lib/private/Route/Router.php
index 0bccb8190cd..fcde8f08897 100644
--- a/lib/private/Route/Router.php
+++ b/lib/private/Route/Router.php
@@ -130,8 +130,9 @@ class Router implements IRouter {
if (isset($this->loadedApps[$app])) {
return;
}
- $file = \OC_App::getAppPath($app) . '/appinfo/routes.php';
- if ($file !== false && file_exists($file)) {
+ $appPath = \OC_App::getAppPath($app);
+ $file = $appPath . '/appinfo/routes.php';
+ if ($appPath !== false && file_exists($file)) {
$routingFiles = [$app => $file];
} else {
$routingFiles = [];
diff --git a/lib/private/Template/Base.php b/lib/private/Template/Base.php
index 2087f5f8ed9..2de8c7ad5b1 100644
--- a/lib/private/Template/Base.php
+++ b/lib/private/Template/Base.php
@@ -65,7 +65,7 @@ class Base {
*/
protected function getAppTemplateDirs($theme, $app, $serverRoot, $app_dir) {
// Check if the app is in the app folder or in the root
- if (file_exists($app_dir.'/templates/')) {
+ if ($app_dir !== false && file_exists($app_dir.'/templates/')) {
return [
$serverRoot.'/themes/'.$theme.'/apps/'.$app.'/templates/',
$app_dir.'/templates/',
diff --git a/lib/private/Template/IconsCacher.php b/lib/private/Template/IconsCacher.php
index e379a8ed92d..01500aa2e9c 100644
--- a/lib/private/Template/IconsCacher.php
+++ b/lib/private/Template/IconsCacher.php
@@ -170,7 +170,10 @@ class IconsCacher {
} elseif (\strpos($url, $base) === 0) {
if (\preg_match('/([A-z0-9\_\-]+)\/([a-zA-Z0-9-_\~\/\.\=\:\;\+\,]+)\?color=([0-9a-fA-F]{3,6})/', $cleanUrl, $matches)) {
[,$app,$cleanUrl, $color] = $matches;
- $location = \OC_App::getAppPath($app) . '/img/' . $cleanUrl . '.svg';
+ $appPath = \OC_App::getAppPath($app);
+ if ($appPath !== false) {
+ $location = $appPath . '/img/' . $cleanUrl . '.svg';
+ }
if ($app === 'settings') {
$location = \OC::$SERVERROOT . '/settings/img/' . $cleanUrl . '.svg';
}
diff --git a/lib/private/Template/ResourceLocator.php b/lib/private/Template/ResourceLocator.php
index 3f3299e2e84..3ca34259907 100755
--- a/lib/private/Template/ResourceLocator.php
+++ b/lib/private/Template/ResourceLocator.php
@@ -102,7 +102,7 @@ abstract class ResourceLocator {
* @return bool True if the resource was found, false otherwise
*/
protected function appendIfExist($root, $file, $webRoot = null) {
- if (is_file($root.'/'.$file)) {
+ if ($root !== false && is_file($root.'/'.$file)) {
$this->append($root, $file, $webRoot, false);
return true;
}