Merge pull request #259 from corbosman/plugin_preload

Plugin preload
pull/257/head
Aleksander Machniak 10 years ago
commit 3665d1e8ec

@ -93,6 +93,10 @@ class rcmail extends rcube
$this->filename = $basename; $this->filename = $basename;
} }
// load all configured plugins
$this->plugins->load_plugins((array)$this->config->get('plugins', array()),
array('filesystem_attachments', 'jqueryui'));
// start session // start session
$this->session_init(); $this->session_init();
@ -124,10 +128,8 @@ class rcmail extends rcube
$GLOBALS['OUTPUT'] = $this->load_gui(!empty($_REQUEST['_framed'])); $GLOBALS['OUTPUT'] = $this->load_gui(!empty($_REQUEST['_framed']));
} }
// load plugins // run init method on all the plugins
$this->plugins->init($this, $this->task); $this->plugins->init($this, $this->task);
$this->plugins->load_plugins((array)$this->config->get('plugins', array()),
array('filesystem_attachments', 'jqueryui'));
} }
/** /**

@ -34,6 +34,8 @@ class rcube_plugin_api
public $dir; public $dir;
public $url = 'plugins/'; public $url = 'plugins/';
public $task = ''; public $task = '';
public $initialized = false;
public $output; public $output;
public $handlers = array(); public $handlers = array();
public $allowed_prefs = array(); public $allowed_prefs = array();
@ -85,12 +87,20 @@ class rcube_plugin_api
{ {
$this->task = $task; $this->task = $task;
$this->output = $app->output; $this->output = $app->output;
// register an internal hook // register an internal hook
$this->register_hook('template_container', array($this, 'template_container_hook')); $this->register_hook('template_container', array($this, 'template_container_hook'));
// maybe also register a shudown function which triggers // maybe also register a shudown function which triggers
// shutdown functions of all plugin objects // shutdown functions of all plugin objects
foreach ($this->plugins as $plugin) {
// ... task, request type and framed mode
if (!$this->filter($plugin)) {
$plugin->init();
}
}
// we have finished initializing all plugins
$this->initialized = true;
} }
/** /**
@ -171,14 +181,22 @@ class rcube_plugin_api
// check inheritance... // check inheritance...
if (is_subclass_of($plugin, 'rcube_plugin')) { if (is_subclass_of($plugin, 'rcube_plugin')) {
// ... task, request type and framed mode // ... task, request type and framed mode
if (($force || !$plugin->task || preg_match('/^('.$plugin->task.')$/i', $this->task))
&& (!$plugin->noajax || (is_object($this->output) && $this->output->type == 'html')) // call onload method on plugin if it exists.
&& (!$plugin->noframe || empty($_REQUEST['_framed'])) // this is useful if you want to be called early in the boot process
) { if (method_exists($plugin, 'onload')) {
$plugin->onload();
}
// init a plugin only if $force is set or if we're called after initialization
if (($force || $this->initialized)
&& !$this->filter($plugin))
{
$plugin->init(); $plugin->init();
$this->plugins[$plugin_name] = $plugin;
} }
$this->plugins[$plugin_name] = $plugin;
if (!empty($plugin->allowed_prefs)) { if (!empty($plugin->allowed_prefs)) {
$this->allowed_prefs = array_merge($this->allowed_prefs, $plugin->allowed_prefs); $this->allowed_prefs = array_merge($this->allowed_prefs, $plugin->allowed_prefs);
} }
@ -202,6 +220,19 @@ class rcube_plugin_api
return false; return false;
} }
/**
* check if we should prevent this plugin from initialising
*
* @param $plugin
* @return bool
*/
private function filter($plugin)
{
return (($plugin->noajax && !(is_object($this->output) && $this->output->type == 'html') )
|| ($plugin->task && !preg_match('/^('.$plugin->task.')$/i', $this->task))
|| ($plugin->noframe && !empty($_REQUEST['_framed']))) ? true : false;
}
/** /**
* Get information about a specific plugin. * Get information about a specific plugin.
* This is either provided my a plugin's info() method or extracted from a package.xml or a composer.json file * This is either provided my a plugin's info() method or extracted from a package.xml or a composer.json file

Loading…
Cancel
Save