From 8f576d87d23be5f170054a8454b7917ae64f5696 Mon Sep 17 00:00:00 2001
From: Flanpy <none@none.com>
Date: Wed, 12 Nov 2014 05:24:34 -0500
Subject: [PATCH] Add the ability to select plugins in the installer

---
 installer/config.php               |    5 +-
 program/include/rcmail_install.php |   64 ++++++++++++++++++--------------
 2 files changed, 39 insertions(+), 30 deletions(-)

diff --git a/installer/config.php b/installer/config.php
index 590bbe0..82d7f55 100644
--- a/installer/config.php
+++ b/installer/config.php
@@ -678,7 +678,8 @@
 
 <?php
 $plugins = $RCI->list_plugins();
-foreach($plugins as $p) {
+foreach($plugins as $p) 
+{
 	$p_check = new html_checkbox(array('name' => '_plugins_'.$p['name'], 'id' => 'cfgplugin_'.$p['name']));
 	echo '<dt class="propname">'.$p['name'].'</dt><dd>';
 	echo $p_check->show(0, array('value' => $p['name']));
@@ -688,7 +689,7 @@
 ?>
 </dl>
 
-<p class="hint">Before enabling any plugin, check their dependencies</p>
+<p class="hint">Please consider checking dependencies of enabled plugins</p>
 </fieldset>
 
 <?php
diff --git a/program/include/rcmail_install.php b/program/include/rcmail_install.php
index d5df897..a13cbd2 100644
--- a/program/include/rcmail_install.php
+++ b/program/include/rcmail_install.php
@@ -234,13 +234,14 @@
       else if (is_numeric($value)) {
         $value = intval($value);
       }
-			else if ($prop == 'plugins') { // 
-				$value = array();
-				foreach(array_keys($_POST) as $key) {
-					if (preg_match('/^_plugins_*/', $key))
-						array_push($value, $_POST[$key]);
-				}
-			}
+      else if ($prop == 'plugins') {
+        $value = array();
+        foreach(array_keys($_POST) as $key)
+        {
+          if (preg_match('/^_plugins_*/', $key))
+            array_push($value, $_POST[$key]);
+        }
+      }
 
       // skip this property
       if (($value == $this->defaults[$prop]) && !in_array($prop, $this->local_config)
@@ -566,6 +567,34 @@
   }
 
   /**
+  * Return a list with available subfolders of the plugins directory
+  * (with their associated description in composer.json)
+  */
+  function list_plugins() 
+  {
+    $plugins = array();
+    $plugin_dir = INSTALL_PATH . 'plugins/';
+
+    foreach (glob($plugin_dir . '*') as $path) 
+    {
+
+      if (is_dir($path) && file_exists($path.'/composer.json')) 
+      {
+        $file_json = json_decode(file_get_contents($path.'/composer.json'));
+        $plugin_desc = $file_json->description;
+      }
+      else
+      {
+        $plugin_desc = 'N/A';
+      }
+
+      $plugins[] = array('name' => substr($path, strlen($plugin_dir)), 'desc' => $plugin_desc);
+    }
+
+    return $plugins;
+  }
+
+  /**
    * Display OK status
    *
    * @param string Test name
@@ -779,27 +808,6 @@
 
     return $out;
   }
-
-	/**
-	 * Return a list with available plugins & their description in plugins directory 
-	 */
-	function list_plugins() 
-	{
-		$plugins = array();
-		$plugin_dir = INSTALL_PATH . 'plugins/';
-		foreach (glob($plugin_dir . '*') as $path) {
-			if (is_dir($path) && is_readable($path)) {
-				if(file_exists($path.'/composer.json')) {
-					$file_json = json_decode(file_get_contents($path.'/composer.json'));
-					$plugin_desc = $file_json->description;
-				}
-				else
-				$plugin_desc = 'N/A';
-				$plugins[] = array('name' => substr($path, strlen($plugin_dir)), 'desc' => $plugin_desc);
-			}
-		}
-		return $plugins;
-	}
 
 }
 

--
Gitblit v1.9.1