]> git.mxchange.org Git - quix0rs-gnu-social.git/commitdiff
Don't allow double plugin loading
authorMikael Nordfeldth <mmn@hethane.se>
Mon, 18 Nov 2013 19:04:00 +0000 (20:04 +0100)
committerMikael Nordfeldth <mmn@hethane.se>
Tue, 19 Nov 2013 12:25:02 +0000 (13:25 +0100)
lib/cache.php
lib/statusnet.php
scripts/showplugins.php

index 01bc29fa48db7a2257418c031b54bca14546457d..e79d75c294b1a49175d05d3ac2dcefc40f3249c1 100644 (file)
@@ -125,14 +125,12 @@ class Cache
        
         if (empty($prefix)) {
            
-            $plugins     = StatusNet::getActivePlugins();
-            $names       = array();
+            $names   = array();
            
-            foreach ($plugins as $plugin) {
-                $names[] = $plugin[0];
+            foreach (StatusNet::getActivePlugins() as $plugin=>$attrs) {
+                $names[] = $plugin;
             }
            
-            $names = array_unique($names);
             asort($names);
            
             // Unique enough.
index 432c5b8a209b7acd971b82781beeeb86902c3236..cf2069c1a6114a9c378c6ad70896d97aa9d288d1 100644 (file)
@@ -47,6 +47,14 @@ class StatusNet
     public static function addPlugin($name, $attrs = null)
     {
         $name = ucfirst($name);
+
+        if (isset(self::$plugins[$name])) {
+            // We have already loaded this plugin. Don't try to
+            // do it again with (possibly) different values.
+            // Försten till kvarn får mala.
+            return true;
+        }
+
         $pluginclass = "{$name}Plugin";
 
         if (!class_exists($pluginclass)) {
@@ -78,7 +86,7 @@ class StatusNet
         }
 
         // Record activated plugins for later display/config dump
-        self::$plugins[] = array($name, $attrs);
+        self::$plugins[$name] = $attrs;
 
         return true;
     }
@@ -181,9 +189,13 @@ class StatusNet
      */
     protected static function initPlugins()
     {
+        // User config may have already added some of these plugins, with
+        // maybe configured parameters. The self::addPlugin function will
+        // ignore the new call if it has already been instantiated.
+
         // Load core plugins
         foreach (common_config('plugins', 'core') as $name => $params) {
-            call_user_func('addPlugin', $name, $params);
+            call_user_func('self::addPlugin', $name, $params);
         }
 
         // Load default plugins
@@ -194,17 +206,17 @@ class StatusNet
             }
 
             if (is_null($params)) {
-                addPlugin($name);
+                self::addPlugin($name);
             } else if (is_array($params)) {
                 if (count($params) == 0) {
-                    addPlugin($name);
+                    self::addPlugin($name);
                 } else {
                     $keys = array_keys($params);
                     if (is_string($keys[0])) {
-                        addPlugin($name, $params);
+                        self::addPlugin($name, $params);
                     } else {
                         foreach ($params as $paramset) {
-                            addPlugin($name, $paramset);
+                            self::addPlugin($name, $paramset);
                         }
                     }
                 }
index 058393b0ee3a525b6f27220331021095fb6aec39..3c03646227aae73c8f089f0e6c26bd4839fa4f58 100755 (executable)
@@ -22,8 +22,7 @@ define('INSTALLDIR', realpath(dirname(__FILE__) . '/..'));
 
 require_once INSTALLDIR.'/scripts/commandline.inc';
 
-foreach (StatusNet::getActivePlugins() as $data) {
-    list($plugin, $args) = $data;
+foreach (StatusNet::getActivePlugins() as $plugin=>$args) {
     echo "$plugin: ";
     if ($args === null) {
         echo "(no args)\n";