java/src/messenger/webim/libs/classes/plugin_manager.php
Dmitriy Simushev 219aa4c9b1 Update EventDispatcher class
There is no need to register events any more.
2013-03-13 15:38:14 +00:00

154 lines
4.4 KiB
PHP

<?php
/*
* Copyright 2005-2013 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* Manage plugins
*/
Class PluginManager {
/**
* Contains all loaded plugins
* @var array
*/
protected static $loaded_plugins = array();
/**
* Returns plugin object
*
* @param string $plugin_name
* @return Plugin
*/
public static function getPlugin($plugin_name) {
if (empty(self::$loaded_plugins[$plugin_name])) {
trigger_error(
"Plugin '{$plugin_name}' does not initialized!",
E_USER_WARNING
);
}
return self::$loaded_plugins[$plugin_name];
}
/**
* Returns associative array of loaded plugins.
*
* Key represents plugin's name and value contains Plugin object
*
* @return array
*/
public static function getAllPlugins() {
return self::$loaded_plugins;
}
/**
* Loads plugins and invokes Plugin::registerEvents() and Plugin::registerListeners()
*
* @param array $plugins_list List of plugins' names and configurations. For example:
* <code>
* $plugins_list = array();
* $plugins_list[] = array(
* 'name' => 'plugin_name', // Obligatory value
* 'dependences' => array( // Dependences of the plugin
* 'another_plugin_name'
* ),
* 'config' => array( // Pass to plugin constructor
* 'weight' => 100,
* 'some_configurable_value' => 'value'
* )
* )
* </code>
*
* @see Plugin::registerEvents()
* @see Plugin::registerListeners()
*/
public static function loadPlugins($plugins_list){
// Add include path
$include_path = get_include_path();
$include_path .= empty($include_path) ? '' : PATH_SEPARATOR ;
set_include_path($include_path . realpath(dirname(__FILE__) . "/../../plugins/"));
// Load plugins
$loading_queue = array();
$offset = 0;
foreach ($plugins_list as $plugin) {
if (empty($plugin['name'])) {
trigger_error("Plugin name undefined!", E_USER_WARNING);
continue;
}
$plugin_name = $plugin['name'];
$plugin_config = isset($plugin['config']) ? $plugin['config'] : array();
$plugin_dependences = isset($plugin['dependences'])
? $plugin['dependences']
: array();
$plugin_name_parts = explode('_', $plugin_name);
$plugin_name_parts = array_map('ucfirst', $plugin_name_parts);
$plugin_classname = implode('', $plugin_name_parts) . "Plugin";
// Check plugin dependences
foreach ($plugin_dependences as $dependence) {
if (empty(self::$loaded_plugins[$dependence])) {
trigger_error(
"Plugin '{$dependence}' not loaded yet, but " .
"exists in '{$plugin_name}' dependences list!",
E_USER_WARNING
);
continue 2;
}
}
// Try to load plugin file
if (! (include_once $plugin_name."/".$plugin_name."_plugin.php")) {
trigger_error("Cannot load plugin file!", E_USER_ERROR);
}
// Check plugin class name
if (! class_exists($plugin_classname)) {
trigger_error(
"Plugin class '{$plugin_classname}' does not defined!",
E_USER_WARNING
);
continue;
}
// Check if plugin extends abstract 'Plugin' class
if ('Plugin' != get_parent_class($plugin_classname)) {
trigger_error(
"Plugin class '{$plugin_classname}' does not extend " .
"abstract 'Plugin' class!",
E_USER_WARNING
);
continue;
}
// Add plugin to loading queue
$plugin_instance = new $plugin_classname($plugin_config);
if ($plugin_instance->initialized) {
// Store plugin instance
self::$loaded_plugins[$plugin_name] = $plugin_instance;
$loading_queue[$plugin_instance->getWeight() . "_" . $offset] = $plugin_instance;
$offset++;
} else {
trigger_error(
"Plugin '{$plugin_name}' does not initialized correctly!",
E_USER_WARNING
);
}
}
// Sort queue in order to plugins' weights
uksort($loading_queue, 'strnatcmp');
// Add events and listeners
foreach ($loading_queue as $plugin) {
$plugin->registerListeners();
}
}
}
?>