aboutsummaryrefslogtreecommitdiffstats
path: root/phpBB/phpbb/install/module
diff options
context:
space:
mode:
Diffstat (limited to 'phpBB/phpbb/install/module')
-rw-r--r--phpBB/phpbb/install/module/install_finish/task/install_extensions.php9
-rw-r--r--phpBB/phpbb/install/module/update_database/task/update_extensions.php7
2 files changed, 15 insertions, 1 deletions
diff --git a/phpBB/phpbb/install/module/install_finish/task/install_extensions.php b/phpBB/phpbb/install/module/install_finish/task/install_extensions.php
index bc13795188..c42d17fc18 100644
--- a/phpBB/phpbb/install/module/install_finish/task/install_extensions.php
+++ b/phpBB/phpbb/install/module/install_finish/task/install_extensions.php
@@ -13,6 +13,8 @@
namespace phpbb\install\module\install_finish\task;
+use Symfony\Component\Console\Input\ArgvInput;
+
/**
* Installs extensions that exist in ext folder upon install
*/
@@ -100,12 +102,19 @@ class install_extensions extends \phpbb\install\task_base
$this->user->session_begin();
$this->user->setup(array('common', 'acp/common', 'cli'));
+ $install_extensions = $this->iohandler->get_input('install-extensions', array());
+
// Find available extensions
foreach ($this->finder as $file)
{
/** @var \SplFileInfo $file */
$ext_name = preg_replace('#(.+[\\/\\\]ext[\\/\\\])(\w+)[\\/\\\](\w+)#', '$2/$3', dirname($file->getRealPath()));
+ if (!empty($install_extensions) && !in_array($ext_name, $install_extensions))
+ {
+ continue;
+ }
+
if ($this->extension_manager->is_available($ext_name))
{
$this->extension_manager->enable($ext_name);
diff --git a/phpBB/phpbb/install/module/update_database/task/update_extensions.php b/phpBB/phpbb/install/module/update_database/task/update_extensions.php
index a73fa9b854..7a65ff1803 100644
--- a/phpBB/phpbb/install/module/update_database/task/update_extensions.php
+++ b/phpBB/phpbb/install/module/update_database/task/update_extensions.php
@@ -18,6 +18,7 @@ use phpbb\install\helper\config;
use phpbb\install\helper\iohandler\iohandler_interface;
use phpbb\install\helper\update_helper;
use phpbb\install\task_base;
+use Symfony\Component\Console\Input\ArgvInput;
use Symfony\Component\Finder\Finder;
/**
@@ -111,6 +112,9 @@ class enable_extensions extends task_base
$this->user->session_begin();
$this->user->setup(array('common', 'acp/common', 'cli'));
+ $input = new ArgvInput();
+ $update_extensions = explode(',', $input->getArgument('update-extensions'));
+
$update_info = $this->install_config->get('update_info_unprocessed', array());
if (!empty($update_info))
@@ -122,7 +126,8 @@ class enable_extensions extends task_base
$ext_name = preg_replace('#(.+[\\/\\\]ext[\\/\\\])(\w+)[\\/\\\](\w+)#', '$2/$3', dirname($file->getRealPath()));
// Skip extensions that were not added or updated during update
- if (!count(preg_grep('#ext/' . $ext_name . '#', $update_info['files'])))
+ if (!count(preg_grep('#ext/' . $ext_name . '#', $update_info['files'])) &&
+ !in_array($ext_name, $update_extensions) && $ext_name !== 'phpbb/viglink')
{
continue;
}