aboutsummaryrefslogtreecommitdiffstats
path: root/phpBB/phpbb/install
diff options
context:
space:
mode:
authorMarc Alexander <admin@m-a-styles.de>2016-03-02 13:54:02 +0100
committerMarc Alexander <admin@m-a-styles.de>2016-12-03 14:23:34 +0100
commitf604e1ab5d5d780ff4bed1e39fa83cc264a8af71 (patch)
tree524670d8285e4b7de98c41dd9f8e9879c8d8f7ab /phpBB/phpbb/install
parent930b02342e4f27f1c72fe0590f7153298331c3a6 (diff)
downloadforums-f604e1ab5d5d780ff4bed1e39fa83cc264a8af71.tar
forums-f604e1ab5d5d780ff4bed1e39fa83cc264a8af71.tar.gz
forums-f604e1ab5d5d780ff4bed1e39fa83cc264a8af71.tar.bz2
forums-f604e1ab5d5d780ff4bed1e39fa83cc264a8af71.tar.xz
forums-f604e1ab5d5d780ff4bed1e39fa83cc264a8af71.zip
[ticket/14492] Rework logic for selecting which extensions to update
PHPBB3-14492
Diffstat (limited to 'phpBB/phpbb/install')
-rw-r--r--phpBB/phpbb/install/module/update_database/task/update_extensions.php81
1 files changed, 54 insertions, 27 deletions
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 7a65ff1803..f3a977a013 100644
--- a/phpBB/phpbb/install/module/update_database/task/update_extensions.php
+++ b/phpBB/phpbb/install/module/update_database/task/update_extensions.php
@@ -24,7 +24,7 @@ use Symfony\Component\Finder\Finder;
/**
* Installs extensions that exist in ext folder upon install
*/
-class enable_extensions extends task_base
+class update_extensions extends task_base
{
/**
* @var config
@@ -67,6 +67,14 @@ class enable_extensions extends task_base
protected $db;
/**
+ * @var array List of default extensions to update, grouped by version
+ * they were added
+ */
+ private $default_update = [
+ '3.2.0-b2' => ['phpbb/viglink']
+ ];
+
+ /**
* Constructor
*
* @param container_factory $container
@@ -112,47 +120,66 @@ 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', []);
- $update_info = $this->install_config->get('update_info_unprocessed', array());
+ if (empty($update_info))
+ {
+ return;
+ }
- if (!empty($update_info))
+ $update_extensions = $this->iohandler->get_input('update-extensions', []);
+
+ // Create list of default extensions that need to be enabled in update
+ $default_update_extensions = [];
+ foreach ($this->default_update as $version => $extensions)
{
- // Find available extensions
- foreach ($this->finder as $file)
+ if ($this->update_helper->phpbb_version_compare($update_info['version']['from'], $version, '<'))
{
- /** @var \SplFileInfo $file */
- $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'])) &&
- !in_array($ext_name, $update_extensions) && $ext_name !== 'phpbb/viglink')
- {
- continue;
- }
+ $default_update_extensions = array_merge($default_update_extensions, $extensions);
+ }
+ }
- // Disable enabled extensions in order to run migrations if needed
- if ($this->extension_manager->is_enabled($ext_name))
+ // Find available extensions
+ foreach ($this->finder as $file)
+ {
+ /** @var \SplFileInfo $file */
+ $ext_name = preg_replace('#(.+[\\/\\\]ext[\\/\\\])(\w+)[\\/\\\](\w+)#', '$2/$3', dirname($file->getRealPath()));
+
+ // Update extensions if:
+ // 1) Extension is currently enabled
+ // 2) Extension was implicitly defined as needing an update
+ // 3) Extension was newly added as default phpBB extension in
+ // this update and should be enabled by default.
+ if ($this->extension_manager->is_available($ext_name) &&
+ (
+ $this->extension_manager->is_enabled($ext_name) ||
+ in_array($ext_name, $update_extensions) ||
+ in_array($ext_name, $default_update_extensions)
+ ))
+ {
+ $extension_enabled = $this->extension_manager->is_enabled($ext_name);
+ if ($extension_enabled)
{
$this->extension_manager->disable($ext_name);
}
+ $this->extension_manager->enable($ext_name);
+ $extensions = $this->get_extensions();
- if ($this->extension_manager->is_available($ext_name))
+ if (isset($extensions[$ext_name]) && $extensions[$ext_name]['ext_active'])
{
- $this->extension_manager->enable($ext_name);
- $extensions = $this->get_extensions();
-
- if (isset($extensions[$ext_name]) && $extensions[$ext_name]['ext_active'])
- {
- // Create log
- $this->log->add('admin', ANONYMOUS, '', 'LOG_EXT_ENABLE', time(), array($ext_name));
- }
+ // Create log
+ $this->log->add('admin', ANONYMOUS, '', 'LOG_EXT_ENABLE', time(), array($ext_name));
}
else
{
$this->iohandler->add_log_message('CLI_EXTENSION_ENABLE_FAILURE', array($ext_name));
}
+
+ // Disable extensions if it was disabled by the admin before
+ if (!$extension_enabled && !in_array($ext_name, $default_update_extensions))
+ {
+ $this->extension_manager->disable($ext_name);
+ }
}
}
}