Commit 55a7a513 by pupi1985

Add ability to load plugins after and before connecting to the DB

parent 076a40af
...@@ -26,13 +26,102 @@ class Q2A_Plugin_PluginManager ...@@ -26,13 +26,102 @@ class Q2A_Plugin_PluginManager
const PLUGIN_DELIMITER = ';'; const PLUGIN_DELIMITER = ';';
const OPT_ENABLED_PLUGINS = 'enabled_plugins'; const OPT_ENABLED_PLUGINS = 'enabled_plugins';
private $loadBeforeDbInit = array();
private $loadAfterDbInit = array();
public function readAllPluginMetadatas()
{
$pluginDirectories = $this->getFilesystemPlugins(true);
foreach ($pluginDirectories as $pluginDirectory) {
$pluginFile = $pluginDirectory . 'qa-plugin.php';
if (!file_exists($pluginFile)) {
continue;
}
$metadataUtil = new Q2A_Util_Metadata();
$metadata = $metadataUtil->fetchFromAddonPath($pluginDirectory);
if (empty($metadata)) {
// limit plugin parsing to first 8kB
$contents = file_get_contents($pluginFile, false, null, -1, 8192);
$metadata = qa_addon_metadata($contents, 'Plugin', true);
}
// skip plugin which requires a later version of Q2A
if (isset($metadata['min_q2a']) && qa_qa_version_below($metadata['min_q2a'])) {
continue;
}
// skip plugin which requires a later version of PHP
if (isset($metadata['min_php']) && qa_php_version_below($metadata['min_php'])) {
continue;
}
$pluginInfoKey = basename($pluginDirectory);
$pluginInfo = array(
'pluginfile' => $pluginFile,
'directory' => $pluginDirectory,
'urltoroot' => substr($pluginDirectory, strlen(QA_BASE_DIR)),
);
if (isset($metadata['load_order'])) {
switch ($metadata['load_order']) {
case 'after_db_init':
$this->loadAfterDbInit[$pluginInfoKey] = $pluginInfo;
break;
case 'before_db_init':
$this->loadBeforeDbInit[$pluginInfoKey] = $pluginInfo;
break;
default:
}
} else {
$this->loadBeforeDbInit[$pluginInfoKey] = $pluginInfo;
}
}
}
private function loadPlugins($pluginInfos)
{
global $qa_plugin_directory, $qa_plugin_urltoroot;
foreach ($pluginInfos as $pluginInfo) {
$qa_plugin_directory = $pluginInfo['directory'];
$qa_plugin_urltoroot = $pluginInfo['urltoroot'];
require_once $pluginInfo['pluginfile'];
}
$qa_plugin_directory = null;
$qa_plugin_urltoroot = null;
}
public function loadPluginsBeforeDbInit()
{
$this->loadPlugins($this->loadBeforeDbInit);
}
public function loadPluginsAfterDbInit()
{
$enabledPlugins = $this->getEnabledPlugins(false);
$enabledForAfterDbInit = array();
foreach ($enabledPlugins as $enabledPluginDirectory) {
if (isset($this->loadAfterDbInit[$enabledPluginDirectory])) {
$enabledForAfterDbInit[$enabledPluginDirectory] = $this->loadAfterDbInit[$enabledPluginDirectory];
}
}
$this->loadPlugins($enabledForAfterDbInit);
}
public function getEnabledPlugins($fullPath = false) public function getEnabledPlugins($fullPath = false)
{ {
$pluginDirectories = $this->getEnabledPluginsOption(); $pluginDirectories = $this->getEnabledPluginsOption();
if ($fullPath) { if ($fullPath) {
foreach ($pluginDirectories as $key => &$pluginDirectory) foreach ($pluginDirectories as $key => &$pluginDirectory) {
$pluginDirectory = QA_PLUGIN_DIR . $pluginDirectory . '/'; $pluginDirectory = QA_PLUGIN_DIR . $pluginDirectory . '/';
}
} }
return $pluginDirectories; return $pluginDirectories;
...@@ -50,7 +139,7 @@ class Q2A_Plugin_PluginManager ...@@ -50,7 +139,7 @@ class Q2A_Plugin_PluginManager
$fileSystemPluginFiles = glob(QA_PLUGIN_DIR . '*/qa-plugin.php'); $fileSystemPluginFiles = glob(QA_PLUGIN_DIR . '*/qa-plugin.php');
foreach ($fileSystemPluginFiles as $pluginFile) { foreach ($fileSystemPluginFiles as $pluginFile) {
$directory = dirname($pluginFile); $directory = dirname($pluginFile) . '/';
if (!$fullPath) { if (!$fullPath) {
$directory = basename($directory); $directory = basename($directory);
......
...@@ -121,14 +121,16 @@ if (!empty($fileSystemPlugins)) { ...@@ -121,14 +121,16 @@ if (!empty($fileSystemPlugins)) {
$sortedPluginFiles = array(); $sortedPluginFiles = array();
foreach ($fileSystemPlugins as $pluginDirectory) { foreach ($fileSystemPlugins as $pluginDirectory) {
$metadata = $metadataUtil->fetchFromAddonPath($pluginDirectory); $pluginDirectoryPath = QA_PLUGIN_DIR . $pluginDirectory;
$metadata = $metadataUtil->fetchFromAddonPath($pluginDirectoryPath);
if (empty($metadata)) { if (empty($metadata)) {
$pluginFile = QA_PLUGIN_DIR . $pluginDirectory . '/qa-plugin.php'; $pluginFile = $pluginDirectoryPath . '/qa-plugin.php';
// limit plugin parsing to first 8kB // limit plugin parsing to first 8kB
$contents = file_get_contents($pluginFile, false, null, -1, 8192); $contents = file_get_contents($pluginFile, false, null, -1, 8192);
$metadata = qa_addon_metadata($contents, 'Plugin'); $metadata = qa_addon_metadata($contents, 'Plugin');
} }
$metadata['name'] = isset($metadata['name']) && !empty($metadata['name']) $metadata['name'] = isset($metadata['name']) && !empty($metadata['name'])
? qa_html($metadata['name']) ? qa_html($metadata['name'])
: qa_lang_html('admin/unnamed_plugin'); : qa_lang_html('admin/unnamed_plugin');
...@@ -189,7 +191,12 @@ if (!empty($fileSystemPlugins)) { ...@@ -189,7 +191,12 @@ if (!empty($fileSystemPlugins)) {
qa_lang_html('admin/options') . '</a>'; qa_lang_html('admin/options') . '</a>';
} }
$enabled = in_array($pluginDirectory, $enabledPlugins); $beforeDbInit = isset($metadata['load_order']) && $metadata['load_order'] === 'before_db_init';
if ($beforeDbInit) {
$enabled = true;
} else {
$enabled = in_array($pluginDirectory, $enabledPlugins);
}
$pluginhtml = $namehtml . ' ' . $authorhtml . ' ' . $updatehtml . '<br>'; $pluginhtml = $namehtml . ' ' . $authorhtml . ' ' . $updatehtml . '<br>';
$pluginhtml .= $deschtml . (strlen($deschtml) > 0 ? '<br>' : ''); $pluginhtml .= $deschtml . (strlen($deschtml) > 0 ? '<br>' : '');
$pluginhtml .= '<small style="color:#666">' . qa_html($pluginDirectoryPath) . '/</small>'; $pluginhtml .= '<small style="color:#666">' . qa_html($pluginDirectoryPath) . '/</small>';
...@@ -210,7 +217,7 @@ if (!empty($fileSystemPlugins)) { ...@@ -210,7 +217,7 @@ if (!empty($fileSystemPlugins)) {
'type' => 'checkbox', 'type' => 'checkbox',
'label' => qa_lang_html('admin/enabled'), 'label' => qa_lang_html('admin/enabled'),
'value' => $enabled, 'value' => $enabled,
'tags' => sprintf('id="plugin_enabled_%s"', $hash), 'tags' => sprintf('id="plugin_enabled_%s"%s', $hash, $beforeDbInit ? 'disabled' : ''),
), ),
array( array(
'type' => 'custom', 'type' => 'custom',
......
...@@ -58,16 +58,27 @@ ...@@ -58,16 +58,27 @@
require_once QA_JOOMLA_LOAD_FILE; require_once QA_JOOMLA_LOAD_FILE;
} }
qa_initialize_constants_2(); qa_initialize_constants_2();
qa_initialize_modularity(); qa_initialize_modularity();
qa_register_core_modules(); qa_register_core_modules();
qa_load_plugin_files();
qa_load_override_files();
require_once QA_INCLUDE_DIR.'qa-db.php'; require_once QA_INCLUDE_DIR.'qa-db.php';
qa_db_allow_connect(); qa_initialize_plugins();
function qa_initialize_plugins() {
$pluginManager = new Q2A_Plugin_PluginManager();
$pluginManager->readAllPluginMetadatas();
$pluginManager->loadPluginsBeforeDbInit();
qa_load_override_files();
qa_db_allow_connect();
$pluginManager->loadPluginsAfterDbInit();
qa_load_override_files();
}
// Version comparison functions // Version comparison functions
...@@ -309,11 +320,12 @@ ...@@ -309,11 +320,12 @@
Gets everything ready to start using modules, layers and overrides Gets everything ready to start using modules, layers and overrides
*/ */
{ {
global $qa_modules, $qa_layers, $qa_override_files, $qa_overrides, $qa_direct; global $qa_modules, $qa_layers, $qa_override_files, $qa_override_files_temp, $qa_overrides, $qa_direct;
$qa_modules=array(); $qa_modules=array();
$qa_layers=array(); $qa_layers=array();
$qa_override_files=array(); $qa_override_files=array();
$qa_override_files_temp=array();
$qa_overrides=array(); $qa_overrides=array();
$qa_direct=array(); $qa_direct=array();
} }
...@@ -394,62 +406,17 @@ ...@@ -394,62 +406,17 @@
} }
function qa_load_plugin_files()
/*
Load all the qa-plugin.php files from plugins that are compatible with this version of Q2A
*/
{
global $qa_plugin_directory, $qa_plugin_urltoroot;
// temporarily disabled
// $pluginManager = new Q2A_Plugin_PluginManager();
// $pluginDirectories = $pluginManager->getEnabledPlugins(true);
$pluginDirectories = glob(QA_PLUGIN_DIR.'*/');
$metadataUtil = new Q2A_Util_Metadata();
foreach ($pluginDirectories as $pluginDirectory) {
$pluginFile = $pluginDirectory . 'qa-plugin.php';
if (!file_exists($pluginFile))
continue;
$metadata = $metadataUtil->fetchFromAddonPath($qa_plugin_directory);
if (empty($metadata)) {
// limit plugin parsing to first 8kB
$contents = file_get_contents($pluginFile, false, null, -1, 8192);
$metadata = qa_addon_metadata($contents, 'Plugin', true);
}
// skip plugin which requires a later version of Q2A
if (isset($metadata['min_q2a']) && qa_qa_version_below($metadata['min_q2a']))
continue;
// skip plugin which requires a later version of PHP
if (isset($metadata['min_php']) && qa_php_version_below($metadata['min_php']))
continue;
// these variables are utilized in the qa_register_plugin_* functions
$qa_plugin_directory = $pluginDirectory;
$qa_plugin_urltoroot = substr($qa_plugin_directory, strlen(QA_BASE_DIR));
require_once $pluginFile;
}
$qa_plugin_directory = null;
$qa_plugin_urltoroot = null;
}
function qa_load_override_files() function qa_load_override_files()
/* /*
Apply all the function overrides in override files that have been registered by plugins Apply all the function overrides in override files that have been registered by plugins
*/ */
{ {
global $qa_override_files, $qa_overrides; global $qa_override_files, $qa_override_files_temp, $qa_overrides;
$functionindex=array(); $functionindex=array();
foreach ($qa_override_files as $index => $override) { foreach ($qa_override_files_temp as $override) {
$qa_override_files[] = $override;
$filename=$override['directory'].$override['include']; $filename=$override['directory'].$override['include'];
$functionsphp=file_get_contents($filename); $functionsphp=file_get_contents($filename);
...@@ -483,6 +450,8 @@ ...@@ -483,6 +450,8 @@
qa_eval_from_file($functionsphp, $filename); qa_eval_from_file($functionsphp, $filename);
} }
$qa_override_files_temp = array();
} }
...@@ -539,9 +508,9 @@ ...@@ -539,9 +508,9 @@
pass in the local plugin $directory and the $urltoroot relative url for that directory pass in the local plugin $directory and the $urltoroot relative url for that directory
*/ */
{ {
global $qa_override_files; global $qa_override_files_temp;
$qa_override_files[]=array( $qa_override_files_temp[] = array(
'directory' => $directory, 'directory' => $directory,
'urltoroot' => $urltoroot, 'urltoroot' => $urltoroot,
'include' => $include 'include' => $include
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment