Thomas Bruederli
2014-08-03 65baa033e067483d5bcd57294aafab413b4cda2c
List all plugins which have been attempted to load (#1488871)
3 files modified
55 ■■■■ changed files
program/lib/Roundcube/rcube_plugin.php 10 ●●●●● patch | view | raw | blame | history
program/lib/Roundcube/rcube_plugin_api.php 39 ●●●● patch | view | raw | blame | history
program/steps/settings/about.inc 6 ●●●● patch | view | raw | blame | history
program/lib/Roundcube/rcube_plugin.php
@@ -94,7 +94,15 @@
    /**
     * Provide information about this
     *
     * @return array Meta information about a plugin or false if not implemented
     * @return array Meta information about a plugin or false if not implemented:
     * As hash array with the following keys:
     *      name: The plugin name
     *    vendor: Name of the plugin developer
     *   version: Plugin version name
     *   license: License name (short form according to http://spdx.org/licenses/)
     *       uri: The URL to the plugin homepage or source repository
     *   src_uri: Direct download URL to the source code of this plugin
     *   require: List of plugins required for this one (as array of plugin names)
     */
    public static function info()
    {
program/lib/Roundcube/rcube_plugin_api.php
@@ -38,6 +38,7 @@
    public $handlers              = array();
    public $allowed_prefs         = array();
    public $allowed_session_prefs = array();
    public $active_plugins        = array();
    protected $plugins = array();
    protected $tasks = array();
@@ -189,7 +190,7 @@
        $fn = $plugins_dir . DIRECTORY_SEPARATOR . $plugin_name
            . DIRECTORY_SEPARATOR . $plugin_name . '.php';
        if (file_exists($fn)) {
        if (is_readable($fn)) {
            if (!class_exists($plugin_name, false)) {
                include $fn;
            }
@@ -197,6 +198,8 @@
            // instantiate class if exists
            if (class_exists($plugin_name, false)) {
                $plugin = new $plugin_name($this);
                $this->active_plugins[] = $plugin_name;
                // check inheritance...
                if (is_subclass_of($plugin, 'rcube_plugin')) {
                    // ... task, request type and framed mode
@@ -252,6 +255,9 @@
        'GPL-3.0'    => 'http://www.gnu.org/licenses/gpl-3.0.html',
        'GPL-3.0+'   => 'http://www.gnu.org/licenses/gpl.html',
        'GPL-2.0+'   => 'http://www.gnu.org/licenses/gpl.html',
        'AGPLv3'     => 'http://www.gnu.org/licenses/agpl.html',
        'AGPLv3+'    => 'http://www.gnu.org/licenses/agpl.html',
        'AGPL-3.0'   => 'http://www.gnu.org/licenses/agpl.html',
        'LGPL'       => 'http://www.gnu.org/licenses/lgpl.html',
        'LGPLv2'     => 'http://www.gnu.org/licenses/lgpl-2.0.html',
        'LGPLv2.1'   => 'http://www.gnu.org/licenses/lgpl-2.1.html',
@@ -275,8 +281,12 @@
      $fn = unslashify($dir->path) . DIRECTORY_SEPARATOR . $plugin_name . DIRECTORY_SEPARATOR . $plugin_name . '.php';
      $info = false;
      if (!class_exists($plugin_name))
        include($fn);
      if (!class_exists($plugin_name, false)) {
        if (is_readable($fn))
          include($fn);
        else
          return false;
      }
      if (class_exists($plugin_name))
        $info = $plugin_name::info();
@@ -284,12 +294,17 @@
      // fall back to composer.json file
      if (!$info) {
        $composer = INSTALL_PATH . "/plugins/$plugin_name/composer.json";
        if (file_exists($composer) && ($json = @json_decode(file_get_contents($composer), true))) {
        if (is_readable($composer) && ($json = @json_decode(file_get_contents($composer), true))) {
          list($info['vendor'], $info['name']) = explode('/', $json['name']);
          $info['version'] = $json['version'];
          $info['license'] = $json['license'];
          if ($license_uri = $license_uris[$info['license']])
            $info['license_uri'] = $license_uri;
          $info['uri'] = $json['homepage'];
          $info['require'] = array_filter(array_keys((array)$json['require']), function($pname) {
            if (strpos($pname, '/') == false)
              return false;
            list($vendor, $name) = explode('/', $pname);
            return !($name == 'plugin-installer' || $vendor == 'pear-pear');
          });
        }
        // read local composer.lock file (once)
@@ -313,7 +328,7 @@
      // fall back to package.xml file
      if (!$info) {
        $package = INSTALL_PATH . "/plugins/$plugin_name/package.xml";
        if (file_exists($package) && ($file = file_get_contents($package))) {
        if (is_readable($package) && ($file = file_get_contents($package))) {
          $doc = new DOMDocument();
          $doc->loadXML($file);
          $xpath = new DOMXPath($doc);
@@ -337,11 +352,19 @@
          $deps = $xpath->evaluate('//rc:package/rc:dependencies/rc:required/rc:package/rc:name');
          for ($i = 0; $i < $deps->length; $i++) {
            $dn = $deps->item($i)->nodeValue;
            $info['requires'][] = $dn;
            $info['require'][] = $dn;
          }
        }
      }
      // At least provide the name
      if (!$info && class_exists($plugin_name)) {
        $info = array('name' => $plugin_name, 'version' => '--');
      }
      else if ($info['license'] && empty($info['license_uri']) && ($license_uri = $license_uris[$info['license']])) {
        $info['license_uri'] = $license_uri;
      }
      return $info;
    }
program/steps/settings/about.inc
@@ -50,7 +50,7 @@
        $attrib['id'] = 'rcmpluginlist';
    }
    $plugins     = array_filter((array) $RCMAIL->config->get('plugins'));
    $plugins     = array_filter($RCMAIL->plugins->active_plugins);
    $plugin_info = array();
    foreach ($plugins as $name) {
@@ -61,8 +61,8 @@
    // load info from required plugins, too
    foreach ($plugin_info as $name => $info) {
        if (is_array($info['required']) && !empty($info['required'])) {
            foreach ($info['required'] as $req_name) {
        if (is_array($info['require']) && !empty($info['require'])) {
            foreach ($info['require'] as $req_name) {
                if (!isset($plugin_info[$req_name]) && ($req_info = $RCMAIL->plugins->get_info($req_name))) {
                    $plugin_info[$req_name] = $req_info;
                }