summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLukas Reschke <lukas@statuscode.ch>2014-06-14 11:05:12 +0200
committerLukas Reschke <lukas@statuscode.ch>2014-06-16 20:28:46 +0200
commitbeee69bee41cb711d163be7087433993aca12c5e (patch)
tree31446284436c5822159f2c9e62d7fda12e45accb
parentd8a4e7a3244392410752bd0c84a88869b9c2c561 (diff)
downloadnextcloud-server-beee69bee41cb711d163be7087433993aca12c5e.tar.gz
nextcloud-server-beee69bee41cb711d163be7087433993aca12c5e.zip
Add deprecation notice to load* functions
This functions are deprecated and/or removed since ownCloud 7. Additionally a issubdirectory check has been added here to prevent developers to use this function in a potentially insecure way. Backport of https://github.com/owncloud/core/pull/9033
-rw-r--r--lib/base.php27
1 files changed, 20 insertions, 7 deletions
diff --git a/lib/base.php b/lib/base.php
index c20812aa19b..8b5205e58ea 100644
--- a/lib/base.php
+++ b/lib/base.php
@@ -734,27 +734,40 @@ class OC {
self::handleLogin();
}
+ /**
+ * @deprecated This function will be removed in ownCloud 8 - use proper routing instead
+ * @param $param
+ * @return bool Whether the file has been found
+ */
public static function loadAppScriptFile($param) {
OC_App::loadApps();
$app = $param['app'];
$file = $param['file'];
$app_path = OC_App::getAppPath($app);
$file = $app_path . '/' . $file;
- unset($app, $app_path);
- if (file_exists($file)) {
- require_once $file;
- return true;
+
+ if (OC_App::isEnabled($app) && $app_path !== false && OC_Helper::issubdirectory($file, $app_path)) {
+ unset($app, $app_path);
+ if (file_exists($file)) {
+ require_once $file;
+ return true;
+ }
}
return false;
}
+ /**
+ * @deprecated This function is removed since ownCloud 7
+ * @param $param
+ */
public static function loadCSSFile($param) {
$app = $param['app'];
$file = $param['file'];
$app_path = OC_App::getAppPath($app);
- if (file_exists($app_path . '/' . $file)) {
- $app_web_path = OC_App::getAppWebPath($app);
- $filepath = $app_web_path . '/' . $file;
+ $app_web_path = OC_App::getAppWebPath($app);
+ $filepath = $app_web_path . '/' . $file;
+
+ if (file_exists($app_path . '/' . $file) && OC_Helper::issubdirectory($app_path . '/' . $file, $app_path)) {
$minimizer = new OC_Minimizer_CSS();
$info = array($app_path, $app_web_path, $file);
$minimizer->output(array($info), $filepath);