179 lines
7.8 KiB
PHP
179 lines
7.8 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Copyright since 2007 PrestaShop SA and Contributors
|
|
* PrestaShop is an International Registered Trademark & Property of PrestaShop SA
|
|
*
|
|
* NOTICE OF LICENSE
|
|
*
|
|
* This source file is subject to the Academic Free License 3.0 (AFL-3.0)
|
|
* that is bundled with this package in the file LICENSE.md.
|
|
* It is also available through the world-wide-web at this URL:
|
|
* https://opensource.org/licenses/AFL-3.0
|
|
* If you did not receive a copy of the license and are unable to
|
|
* obtain it through the world-wide-web, please send an email
|
|
* to license@prestashop.com so we can send you a copy immediately.
|
|
*
|
|
* DISCLAIMER
|
|
*
|
|
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
|
|
* versions in the future. If you wish to customize PrestaShop for your
|
|
* needs please refer to https://devdocs.prestashop.com/ for more information.
|
|
*
|
|
* @author PrestaShop SA and Contributors <contact@prestashop.com>
|
|
* @copyright Since 2007 PrestaShop SA and Contributors
|
|
* @license https://opensource.org/licenses/AFL-3.0 Academic Free License 3.0 (AFL-3.0)
|
|
*/
|
|
|
|
namespace PrestaShop\Module\AutoUpgrade\TaskRunner\Upgrade;
|
|
|
|
use PrestaShop\Module\AutoUpgrade\UpgradeException;
|
|
use PrestaShop\Module\AutoUpgrade\Parameters\UpgradeFileNames;
|
|
use PrestaShop\Module\AutoUpgrade\TaskRunner\AbstractTask;
|
|
use PrestaShop\Module\AutoUpgrade\UpgradeTools\FilesystemAdapter;
|
|
use PrestaShop\Module\AutoUpgrade\UpgradeContainer;
|
|
|
|
/**
|
|
* Upgrade all partners modules according to the installed prestashop version.
|
|
*/
|
|
class UpgradeModules extends AbstractTask
|
|
{
|
|
public function run()
|
|
{
|
|
$start_time = time();
|
|
if (!$this->container->getFileConfigurationStorage()->exists(UpgradeFileNames::MODULES_TO_UPGRADE_LIST)) {
|
|
return $this->warmUp();
|
|
}
|
|
|
|
$this->next = 'upgradeModules';
|
|
$listModules = $this->container->getFileConfigurationStorage()->load(UpgradeFileNames::MODULES_TO_UPGRADE_LIST);
|
|
|
|
if (!is_array($listModules)) {
|
|
$this->next = 'upgradeComplete';
|
|
$this->container->getState()->setWarningExists(true);
|
|
$this->logger->error($this->translator->trans('listModules is not an array. No module has been updated.', array(), 'Modules.Autoupgrade.Admin'));
|
|
|
|
return true;
|
|
}
|
|
|
|
$time_elapsed = time() - $start_time;
|
|
// module list
|
|
if (count($listModules) > 0) {
|
|
do {
|
|
$module_info = array_pop($listModules);
|
|
try {
|
|
$this->logger->debug($this->translator->trans('Upgrading module %module%...', ['%module%' => $module_info['name']], 'Modules.Autoupgrade.Admin'));
|
|
$this->container->getModuleAdapter()->upgradeModule($module_info['id'], $module_info['name']);
|
|
$this->logger->debug($this->translator->trans('The files of module %s have been upgraded.', array($module_info['name']), 'Modules.Autoupgrade.Admin'));
|
|
} catch (UpgradeException $e) {
|
|
$this->handleException($e);
|
|
if ($e->getSeverity() === UpgradeException::SEVERITY_ERROR) {
|
|
return false;
|
|
}
|
|
}
|
|
$time_elapsed = time() - $start_time;
|
|
} while (($time_elapsed < $this->container->getUpgradeConfiguration()->getTimePerCall()) && count($listModules) > 0);
|
|
|
|
$modules_left = count($listModules);
|
|
$this->container->getFileConfigurationStorage()->save($listModules, UpgradeFileNames::MODULES_TO_UPGRADE_LIST);
|
|
unset($listModules);
|
|
|
|
$this->next = 'upgradeModules';
|
|
if ($modules_left) {
|
|
$this->logger->info($this->translator->trans('%s modules left to upgrade.', array($modules_left), 'Modules.Autoupgrade.Admin'));
|
|
}
|
|
$this->stepDone = false;
|
|
} else {
|
|
$modules_to_delete = array(
|
|
'backwardcompatibility' => 'Backward Compatibility',
|
|
'dibs' => 'Dibs',
|
|
'cloudcache' => 'Cloudcache',
|
|
'mobile_theme' => 'The 1.4 mobile_theme',
|
|
'trustedshops' => 'Trustedshops',
|
|
'dejala' => 'Dejala',
|
|
'stripejs' => 'Stripejs',
|
|
'blockvariouslinks' => 'Block Various Links',
|
|
);
|
|
|
|
foreach ($modules_to_delete as $key => $module) {
|
|
$this->container->getDb()->execute('DELETE ms.*, hm.*
|
|
FROM `' . _DB_PREFIX_ . 'module_shop` ms
|
|
INNER JOIN `' . _DB_PREFIX_ . 'hook_module` hm USING (`id_module`)
|
|
INNER JOIN `' . _DB_PREFIX_ . 'module` m USING (`id_module`)
|
|
WHERE m.`name` LIKE \'' . pSQL($key) . '\'');
|
|
$this->container->getDb()->execute('UPDATE `' . _DB_PREFIX_ . 'module` SET `active` = 0 WHERE `name` LIKE \'' . pSQL($key) . '\'');
|
|
|
|
$path = $this->container->getProperty(UpgradeContainer::PS_ROOT_PATH) . DIRECTORY_SEPARATOR . 'modules' . DIRECTORY_SEPARATOR . $key . DIRECTORY_SEPARATOR;
|
|
if (file_exists($path . $key . '.php')) {
|
|
if (FilesystemAdapter::deleteDirectory($path)) {
|
|
$this->logger->debug($this->translator->trans(
|
|
'The %modulename% module is not compatible with version %version%, it will be removed from your FTP.',
|
|
array(
|
|
'%modulename%' => $module,
|
|
'%version%' => $this->container->getState()->getInstallVersion(),
|
|
),
|
|
'Modules.Autoupgrade.Admin'
|
|
));
|
|
} else {
|
|
$this->logger->error($this->translator->trans(
|
|
'The %modulename% module is not compatible with version %version%, please remove it from your FTP.',
|
|
array(
|
|
'%modulename%' => $module,
|
|
'%version%' => $this->container->getState()->getInstallVersion(),
|
|
),
|
|
'Modules.Autoupgrade.Admin'
|
|
));
|
|
}
|
|
}
|
|
}
|
|
|
|
$this->stepDone = true;
|
|
$this->status = 'ok';
|
|
$this->next = 'cleanDatabase';
|
|
$this->logger->info($this->translator->trans('Addons modules files have been upgraded.', array(), 'Modules.Autoupgrade.Admin'));
|
|
|
|
return true;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
public function warmUp()
|
|
{
|
|
try {
|
|
$modulesToUpgrade = $this->container->getModuleAdapter()->listModulesToUpgrade($this->container->getState()->getModules_addons());
|
|
$modulesToUpgrade = array_reverse($modulesToUpgrade);
|
|
$this->container->getFileConfigurationStorage()->save($modulesToUpgrade, UpgradeFileNames::MODULES_TO_UPGRADE_LIST);
|
|
} catch (UpgradeException $e) {
|
|
$this->handleException($e);
|
|
|
|
return false;
|
|
}
|
|
|
|
$total_modules_to_upgrade = count($modulesToUpgrade);
|
|
if ($total_modules_to_upgrade) {
|
|
$this->logger->info($this->translator->trans('%s modules will be upgraded.', array($total_modules_to_upgrade), 'Modules.Autoupgrade.Admin'));
|
|
}
|
|
|
|
$this->stepDone = false;
|
|
$this->next = 'upgradeModules';
|
|
|
|
return true;
|
|
}
|
|
|
|
private function handleException(UpgradeException $e)
|
|
{
|
|
foreach ($e->getQuickInfos() as $log) {
|
|
$this->logger->debug($log);
|
|
}
|
|
if ($e->getSeverity() === UpgradeException::SEVERITY_ERROR) {
|
|
$this->next = 'error';
|
|
$this->error = true;
|
|
$this->logger->error($e->getMessage());
|
|
}
|
|
if ($e->getSeverity() === UpgradeException::SEVERITY_WARNING) {
|
|
$this->logger->warning($e->getMessage());
|
|
}
|
|
}
|
|
}
|