summaryrefslogtreecommitdiff
path: root/program
diff options
context:
space:
mode:
authorThomas B. <thomas@roundcube.net>2014-12-21 20:25:23 +0100
committerThomas B. <thomas@roundcube.net>2014-12-21 20:25:23 +0100
commit8e7ed506c41ea8b8f725f7e122ca6f0b091de5e4 (patch)
tree3a005041bf1a50adf5aa051976a1477f6833adcb /program
parent06410e41e0e0ac4503cd88df48480afe5033dba7 (diff)
parent8f576d87d23be5f170054a8454b7917ae64f5696 (diff)
Merge pull request #248 from flanpy/master
#1489096 : Ability to select plugins to enable in the installer
Diffstat (limited to 'program')
-rw-r--r--program/include/rcmail_install.php36
1 files changed, 36 insertions, 0 deletions
diff --git a/program/include/rcmail_install.php b/program/include/rcmail_install.php
index 96e0afbd4..26c613a11 100644
--- a/program/include/rcmail_install.php
+++ b/program/include/rcmail_install.php
@@ -234,6 +234,14 @@ class rcmail_install
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]);
+ }
+ }
// skip this property
if (($value == $this->defaults[$prop]) && !in_array($prop, $this->local_config)
@@ -559,6 +567,34 @@ class rcmail_install
}
/**
+ * 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