From: Andrew Dolgov Date: Fri, 5 Jun 2015 14:54:52 +0000 (+0300) Subject: pluginhost: allow loading user plugins from plugins.local X-Git-Tag: 16.3~318 X-Git-Url: https://git.wh0rd.org/?a=commitdiff_plain;h=7c0a2ab2029b98086f02da80adf6a7ebc303fd6f;p=tt-rss.git pluginhost: allow loading user plugins from plugins.local --- diff --git a/.gitignore b/.gitignore index e7e5407d..09fccffa 100644 --- a/.gitignore +++ b/.gitignore @@ -3,6 +3,7 @@ *.DS_Store #* .idea/* +plugins.local/* config.php feed-icons/* cache/*/* diff --git a/classes/pluginhost.php b/classes/pluginhost.php index 45769829..13da7e7a 100644 --- a/classes/pluginhost.php +++ b/classes/pluginhost.php @@ -129,7 +129,15 @@ class PluginHost { } } function load_all($kind, $owner_uid = false) { - $plugins = array_map("basename", glob("plugins/*")); + $plugins = array_map("basename", array_filter(glob("plugins/*"), "is_dir")); + + if (is_dir("plugins.local")) { + $plugins = array_merge($plugins, array_map("basename", + array_filter(glob("plugins.local/*"), "is_dir"))); + } + + asort($plugins); + $this->load(join(",", $plugins), $kind, $owner_uid); } @@ -142,9 +150,15 @@ class PluginHost { $class = trim($class); $class_file = strtolower(basename($class)); - if (!is_dir(dirname(__FILE__)."/../plugins/$class_file")) continue; + if (!is_dir(__DIR__."/../plugins/$class_file") && + !is_dir(__DIR__."/../plugins.local/$class_file")) continue; + + // try system plugin directory first + $file = __DIR__ . "/../plugins/$class_file/init.php"; - $file = dirname(__FILE__)."/../plugins/$class_file/init.php"; + if (!file_exists($file)) { + $file = __DIR__ . "/../plugins.local/$class_file/init.php"; + } if (!isset($this->plugins[$class])) { if (file_exists($file)) require_once $file; diff --git a/include/functions2.php b/include/functions2.php index 27b1933d..4f8a0523 100644 --- a/include/functions2.php +++ b/include/functions2.php @@ -2471,4 +2471,12 @@ array("code" => $code, "message" => $message))); } + + function abs_to_rel_path($dir) { + $tmp = str_replace(dirname(__DIR__), "", $dir); + + if (strlen($tmp) > 0 && substr($tmp, 0, 1) == "/") $tmp = substr($tmp, 1); + + return $tmp; + } ?> diff --git a/plugins.local/index.html b/plugins.local/index.html new file mode 100644 index 00000000..e69de29b