Initial commit

This commit is contained in:
2019-11-20 07:44:43 +01:00
commit 5bf49c4a81
41188 changed files with 5459177 additions and 0 deletions

View File

@@ -0,0 +1,85 @@
<?php
/**
* 2007-2017 PrestaShop.
*
* NOTICE OF LICENSE
*
* This source file is subject to the Open Software License (OSL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* https://opensource.org/licenses/OSL-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 http://www.prestashop.com for more information.
*
* @author PrestaShop SA <contact@prestashop.com>
* @copyright 2007-2017 PrestaShop SA
* @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
* International Registered Trademark & Property of PrestaShop SA
*/
namespace PrestaShop\Module\AutoUpgrade\Twig\Block;
use PrestaShop\Module\AutoUpgrade\ChannelInfo;
use PrestaShop\Module\AutoUpgrade\Parameters\UpgradeConfiguration;
use Twig_Environment;
class ChannelInfoBlock
{
/**
* @var UpgradeConfiguration
*/
private $config;
/**
* @var ChannelInfo
*/
private $channelInfo;
/**
* @var \Twig_Environment
*/
private $twig;
/**
* ChannelInfoBlock constructor.
*
* @param UpgradeConfiguration $config
* @param ChannelInfo $channelInfo
* @param Twig_Environment $twig
*/
public function __construct(UpgradeConfiguration $config, ChannelInfo $channelInfo, Twig_Environment $twig)
{
$this->config = $config;
$this->channelInfo = $channelInfo;
$this->twig = $twig;
}
/**
* @return string HTML
*/
public function render()
{
$channel = $this->channelInfo->getChannel();
$upgradeInfo = $this->channelInfo->getInfo();
if ($channel == 'private') {
$upgradeInfo['link'] = $this->config->get('private_release_link');
$upgradeInfo['md5'] = $this->config->get('private_release_md5');
}
return $this->twig->render(
'@ModuleAutoUpgrade/block/channelInfo.twig',
array(
'upgradeInfo' => $upgradeInfo,
)
);
}
}

View File

@@ -0,0 +1,60 @@
<?php
/**
* 2007-2017 PrestaShop.
*
* NOTICE OF LICENSE
*
* This source file is subject to the Open Software License (OSL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* https://opensource.org/licenses/OSL-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 http://www.prestashop.com for more information.
*
* @author PrestaShop SA <contact@prestashop.com>
* @copyright 2007-2017 PrestaShop SA
* @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
* International Registered Trademark & Property of PrestaShop SA
*/
namespace PrestaShop\Module\AutoUpgrade\Twig\Block;
use PrestaShop\Module\AutoUpgrade\BackupFinder;
use Twig_Environment;
class RollbackForm
{
/**
* @var Twig_Environment
*/
private $twig;
/**
* @var BackupFinder
*/
private $backupFinder;
public function __construct(Twig_Environment $twig, BackupFinder $backupFinder)
{
$this->twig = $twig;
$this->backupFinder = $backupFinder;
}
public function render()
{
return $this->twig->render(
'@ModuleAutoUpgrade/block/rollbackForm.twig',
array(
'availableBackups' => $this->backupFinder->getAvailableBackups(),
)
);
}
}

View File

@@ -0,0 +1,224 @@
<?php
/**
* 2007-2017 PrestaShop.
*
* NOTICE OF LICENSE
*
* This source file is subject to the Open Software License (OSL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* https://opensource.org/licenses/OSL-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 http://www.prestashop.com for more information.
*
* @author PrestaShop SA <contact@prestashop.com>
* @copyright 2007-2017 PrestaShop SA
* @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
* International Registered Trademark & Property of PrestaShop SA
*/
namespace PrestaShop\Module\AutoUpgrade\Twig\Block;
use Configuration;
use PrestaShop\Module\AutoUpgrade\ChannelInfo;
use Twig_Environment;
use PrestaShop\Module\AutoUpgrade\Upgrader;
use PrestaShop\Module\AutoUpgrade\Parameters\UpgradeConfiguration;
use PrestaShop\Module\AutoUpgrade\TaskRunner\AbstractTask;
use PrestaShop\Module\AutoUpgrade\UpgradeSelfCheck;
use PrestaShop\Module\AutoUpgrade\UpgradeTools\Translator;
class UpgradeButtonBlock
{
/**
* @var \Twig_Environment
*/
private $twig;
/**
* @var Translator
*/
private $translator;
/**
* @var Upgrader
*/
private $upgrader;
/**
* @var UpgradeConfiguration
*/
private $config;
/**
* @var UpgradeSelfCheck
*/
private $selfCheck;
/**
* @var string
*/
private $downloadPath;
/**
* @var string
*/
private $token;
/**
* @var bool
*/
private $manualMode;
/**
* UpgradeButtonBlock constructor.
*
* @param Twig_Environment $twig
* @param Translator $translator
* @param UpgradeConfiguration $config
* @param Upgrader $upgrader
* @param UpgradeSelfCheck $selfCheck
*/
public function __construct(
Twig_Environment $twig,
Translator $translator,
UpgradeConfiguration $config,
Upgrader $upgrader,
UpgradeSelfCheck $selfCheck,
$downloadPath,
$token,
$manualMode
) {
$this->twig = $twig;
$this->translator = $translator;
$this->upgrader = $upgrader;
$this->config = $config;
$this->selfCheck = $selfCheck;
$this->downloadPath = $downloadPath;
$this->token = $token;
$this->manualMode = $manualMode;
}
/**
* display the summary current version / target version + "Upgrade Now" button with a "more options" button.
*
* @return string HTML
*/
public function render()
{
$translator = $this->translator;
$versionCompare = version_compare(_PS_VERSION_, $this->upgrader->version_num);
$channel = $this->config->get('channel');
if (!in_array($channel, array('archive', 'directory')) && !empty($this->upgrader->version_num)) {
$latestVersion = "{$this->upgrader->version_name} - ({$this->upgrader->version_num})";
} else {
$latestVersion = $translator->trans('N/A', array(), 'Admin.Global');
}
$showUpgradeButton = false;
$showUpgradeLink = false;
$upgradeLink = '';
$changelogLink = '';
$skipActions = array();
// decide to display "Start Upgrade" or not
if ($this->selfCheck->isOkForUpgrade() && $versionCompare < 0) {
$showUpgradeButton = true;
if (!in_array($channel, array('archive', 'directory'))) {
if ($channel == 'private') {
$this->upgrader->link = $this->config->get('private_release_link');
}
$showUpgradeLink = true;
$upgradeLink = $this->upgrader->link;
$changelogLink = $this->upgrader->changelog;
}
// if skipActions property is used, we will handle that in the display :)
$skipActions = AbstractTask::$skipAction;
}
if (empty($channel)) {
$channel = Upgrader::DEFAULT_CHANNEL;
}
$dir = glob($this->downloadPath . DIRECTORY_SEPARATOR . '*.zip');
$data = array(
'versionCompare' => $versionCompare,
'currentPsVersion' => _PS_VERSION_,
'latestChannelVersion' => $latestVersion,
'channel' => $channel,
'showUpgradeButton' => $showUpgradeButton,
'upgradeLink' => $upgradeLink,
'showUpgradeLink' => $showUpgradeLink,
'changelogLink' => $changelogLink,
'skipActions' => $skipActions,
'lastVersionCheck' => Configuration::get('PS_LAST_VERSION_CHECK'),
'token' => $this->token,
'channelOptions' => $this->getOptChannels(),
'channelInfoBlock' => $this->buildChannelInfoBlock($channel),
'privateChannel' => array(
'releaseLink' => $this->config->get('private_release_link'),
'releaseMd5' => $this->config->get('private_release_md5'),
'allowMajor' => $this->config->get('private_allow_major'),
),
'archiveFiles' => $dir,
'archiveFileName' => $this->config->get('archive.filename'),
'archiveVersionNumber' => $this->config->get('archive.version_num'),
'downloadPath' => $this->downloadPath . DIRECTORY_SEPARATOR,
'directoryVersionNumber' => $this->config->get('directory.version_num'),
'manualMode' => $this->manualMode,
);
return $this->twig->render('@ModuleAutoUpgrade/block/upgradeButtonBlock.twig', $data);
}
/**
* @return array
*/
private function getOptChannels()
{
$translator = $this->translator;
return array(
// Hey ! I'm really using a fieldset element to regroup fields ?! !
array('useMajor', 'major', $translator->trans('Major release', array(), 'Modules.Autoupgrade.Admin')),
array('useMinor', 'minor', $translator->trans('Minor release (recommended)', array(), 'Modules.Autoupgrade.Admin')),
array('useRC', 'rc', $translator->trans('Release candidates', array(), 'Modules.Autoupgrade.Admin')),
array('useBeta', 'beta', $translator->trans('Beta releases', array(), 'Modules.Autoupgrade.Admin')),
array('useAlpha', 'alpha', $translator->trans('Alpha releases', array(), 'Modules.Autoupgrade.Admin')),
array('usePrivate', 'private', $translator->trans('Private release (require link and MD5 hash)', array(), 'Modules.Autoupgrade.Admin')),
array('useArchive', 'archive', $translator->trans('Local archive', array(), 'Modules.Autoupgrade.Admin')),
array('useDirectory', 'directory', $translator->trans('Local directory', array(), 'Modules.Autoupgrade.Admin')),
);
}
private function getInfoForChannel($channel)
{
return new ChannelInfo($this->upgrader, $this->config, $channel);
}
/**
* @param string $channel
*
* @return string
*/
private function buildChannelInfoBlock($channel)
{
$channelInfo = $this->getInfoForChannel($channel);
return (new ChannelInfoBlock($this->config, $channelInfo, $this->twig))
->render();
}
}

View File

@@ -0,0 +1,135 @@
<?php
/**
* 2007-2017 PrestaShop.
*
* NOTICE OF LICENSE
*
* This source file is subject to the Open Software License (OSL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* https://opensource.org/licenses/OSL-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 http://www.prestashop.com for more information.
*
* @author PrestaShop SA <contact@prestashop.com>
* @copyright 2007-2017 PrestaShop SA
* @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
* International Registered Trademark & Property of PrestaShop SA
*/
namespace PrestaShop\Module\AutoUpgrade\Twig\Block;
use PrestaShop\Module\AutoUpgrade\UpgradeSelfCheck;
use PrestaShop\Module\AutoUpgrade\Tools14;
use Context;
use Twig_Environment;
/**
* Builds the upgrade checklist block.
*/
class UpgradeChecklist
{
/**
* @var Twig_Environment
*/
private $twig;
/**
* @var string
*/
private $prodRootPath;
/**
* @var string
*/
private $adminPath;
/**
* @var string
*/
private $autoupgradePath;
/**
* @var UpgradeSelfCheck
*/
private $selfCheck;
/**
* @var string
*/
private $currentIndex;
/**
* @var string
*/
private $token;
/**
* UpgradeChecklistBlock constructor.
*
* @param Twig_Environment $twig
* @param UpgradeSelfCheck $upgradeSelfCheck
* @param string $prodRootPath
* @param string $adminPath
* @param string $autoupgradePath
* @param string $currentIndex
* @param string $token
*/
public function __construct(
Twig_Environment $twig,
UpgradeSelfCheck $upgradeSelfCheck,
$prodRootPath,
$adminPath,
$autoupgradePath,
$currentIndex,
$token
) {
$this->twig = $twig;
$this->selfCheck = $upgradeSelfCheck;
$this->prodRootPath = $prodRootPath;
$this->adminPath = $adminPath;
$this->autoupgradePath = $autoupgradePath;
$this->currentIndex = $currentIndex;
$this->token = $token;
}
/**
* Returns the block's HTML.
*
* @return string
*/
public function render()
{
$data = array(
'showErrorMessage' => !$this->selfCheck->isOkForUpgrade(),
'moduleVersion' => $this->selfCheck->getModuleVersion(),
'moduleIsUpToDate' => $this->selfCheck->isModuleVersionLatest(),
'versionGreaterThan1_5_3' => version_compare(_PS_VERSION_, '1.5.3.0', '>'),
'adminToken' => Tools14::getAdminTokenLite('AdminModules'),
'informationsLink' => Context::getContext()->link->getAdminLink('AdminInformation'),
'rootDirectoryIsWritable' => $this->selfCheck->isRootDirectoryWritable(),
'rootDirectoryWritableReport' => $this->selfCheck->getRootWritableReport(),
'adminDirectoryIsWritable' => $this->selfCheck->isAdminAutoUpgradeDirectoryWritable(),
'adminDirectoryWritableReport' => $this->selfCheck->getAdminAutoUpgradeDirectoryWritableReport(),
'safeModeIsDisabled' => $this->selfCheck->isSafeModeDisabled(),
'allowUrlFopenOrCurlIsEnabled' => $this->selfCheck->isFOpenOrCurlEnabled(),
'zipIsEnabled' => $this->selfCheck->isZipEnabled(),
'storeIsInMaintenance' => $this->selfCheck->isShopDeactivated(),
'currentIndex' => $this->currentIndex,
'token' => $this->token,
'cachingIsDisabled' => $this->selfCheck->isCacheDisabled(),
'maxExecutionTime' => $this->selfCheck->getMaxExecutionTime(),
'isPrestaShopReady' => $this->selfCheck->isPrestaShopReady(),
);
return $this->twig->render('@ModuleAutoUpgrade/block/checklist.twig', $data);
}
}

View File

@@ -0,0 +1,106 @@
<?php
/**
* 2007-2017 PrestaShop.
*
* NOTICE OF LICENSE
*
* This source file is subject to the Open Software License (OSL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* https://opensource.org/licenses/OSL-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 http://www.prestashop.com for more information.
*
* @author PrestaShop SA <contact@prestashop.com>
* @copyright 2007-2017 PrestaShop SA
* @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
* International Registered Trademark & Property of PrestaShop SA
*/
namespace PrestaShop\Module\AutoUpgrade\Twig\Form;
use PrestaShop\Module\AutoUpgrade\UpgradeTools\Translator;
class BackupOptionsForm
{
/**
* @var array
*/
private $fields;
/**
* @var Translator
*/
private $translator;
/**
* @var FormRenderer
*/
private $formRenderer;
public function __construct(Translator $translator, FormRenderer $formRenderer)
{
$this->translator = $translator;
$this->formRenderer = $formRenderer;
$translationDomain = 'Modules.Autoupgrade.Admin';
$this->fields = array(
'PS_AUTOUP_BACKUP' => array(
'title' => $this->translator->trans(
'Back up my files and database',
array(),
$translationDomain
),
'cast' => 'intval',
'validation' => 'isBool',
'defaultValue' => '1',
'type' => 'bool',
'desc' => $this->translator->trans(
'Automatically back up your database and files in order to restore your shop if needed. This is experimental: you should still perform your own manual backup for safety.',
array(),
$translationDomain
),
),
'PS_AUTOUP_KEEP_IMAGES' => array(
'title' => $this->translator->trans(
'Back up my images',
array(),
$translationDomain
),
'cast' => 'intval',
'validation' => 'isBool',
'defaultValue' => '1',
'type' => 'bool',
'desc' => $this->translator->trans(
'To save time, you can decide not to back your images up. In any case, always make sure you did back them up manually.',
array(),
$translationDomain
),
),
);
}
public function render()
{
return $this->formRenderer->render(
'backupOptions',
$this->fields,
$this->translator->trans(
'Backup Options',
array(),
'Modules.Autoupgrade.Admin'
),
'',
'database_gear'
);
}
}

View File

@@ -0,0 +1,223 @@
<?php
/**
* 2007-2017 PrestaShop.
*
* NOTICE OF LICENSE
*
* This source file is subject to the Open Software License (OSL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* https://opensource.org/licenses/OSL-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 http://www.prestashop.com for more information.
*
* @author PrestaShop SA <contact@prestashop.com>
* @copyright 2007-2017 PrestaShop SA
* @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
* International Registered Trademark & Property of PrestaShop SA
*/
namespace PrestaShop\Module\AutoUpgrade\Twig\Form;
use PrestaShop\Module\AutoUpgrade\Parameters\UpgradeConfiguration;
use PrestaShop\Module\AutoUpgrade\UpgradeTools\Translator;
use Twig_Environment;
class FormRenderer
{
private $config;
private $translator;
private $twig;
public function __construct(
UpgradeConfiguration $configuration,
Twig_Environment $twig,
Translator $translator
) {
$this->config = $configuration;
$this->twig = $twig;
$this->translator = $translator;
}
public function render($name, $fields, $tabname, $size, $icon)
{
$required = false;
$formFields = array();
foreach ($fields as $key => $field) {
$html = '';
$required = !empty($field['required']);
$disabled = !empty($field['disabled']);
$val = $this->config->get(
$key,
isset($field['defaultValue']) ? $field['defaultValue'] : false
);
if (!in_array($field['type'], array('image', 'radio', 'select', 'container', 'bool', 'container_end')) || isset($field['show'])) {
$html .= '<div style="clear: both; padding-top:15px">'
. ($field['title'] ? '<label >' . $field['title'] . '</label>' : '')
. '<div class="margin-form" style="padding-top:5px">';
}
// Display the appropriate input type for each field
switch ($field['type']) {
case 'disabled':
$html .= $field['disabled'];
break;
case 'bool':
$html .= $this->renderBool($field, $key, $val);
break;
case 'radio':
$html .= $this->renderRadio($field, $key, $val, $disabled);
break;
case 'select':
$html .= $this->renderSelect($field, $key, $val);
break;
case 'textarea':
$html .= $this->renderTextarea($field, $key, $val, $disabled);
break;
case 'container':
$html .= '<div id="' . $key . '">';
break;
case 'container_end':
$html .= (isset($field['content']) ? $field['content'] : '') . '</div>';
break;
case 'text':
default:
$html .= $this->renderTextField($field, $key, $val, $disabled);
}
if ($required && !in_array($field['type'], array('image', 'radio'))) {
$html .= ' <sup>*</sup>';
}
if (isset($field['desc']) && !in_array($field['type'], array('bool', 'select'))) {
$html .= '<p style="clear:both">';
if (!empty($field['thumb']) && $field['thumb']['pos'] == 'after') {
$html .= $this->renderThumb($field);
}
$html .= $field['desc'] . '</p>';
}
if (!in_array($field['type'], array('image', 'radio', 'select', 'container', 'bool', 'container_end')) || isset($field['show'])) {
$html .= '</div></div>';
}
$formFields[] = $html;
}
return $this->twig->render(
'@ModuleAutoUpgrade/form.twig',
array(
'name' => $name,
'tabName' => $tabname,
'fields' => $formFields,
)
);
}
private function renderBool($field, $key, $val)
{
return '<div class="form-group">
<label class="col-lg-3 control-label">' . $field['title'] . '</label>
<div class="col-lg-9">
<span class="switch prestashop-switch fixed-width-lg">
<input type="radio" name="' . $key . '" id="' . $key . '_on" value="1" ' . ($val ? ' checked="checked"' : '') . (isset($field['js']['on']) ? $field['js']['on'] : '') . ' />
<label for="' . $key . '_on" class="radioCheck">
<i class="color_success"></i> '
. $this->translator->trans('Yes', array(), 'Admin.Global') . '
</label>
<input type="radio" name="' . $key . '" id="' . $key . '_off" value="0" ' . (!$val ? 'checked="checked"' : '') . (isset($field['js']['off']) ? $field['js']['off'] : '') . '/>
<label for="' . $key . '_off" class="radioCheck">
<i class="color_danger"></i> ' . $this->translator->trans('No', array(), 'Admin.Global') . '
</label>
<a class="slide-button btn"></a>
</span>
<div class="help-block">' . $field['desc'] . '</div>
</div>
</div>';
}
private function renderRadio($field, $key, $val, $disabled)
{
$html = '';
foreach ($field['choices'] as $cValue => $cKey) {
$html .= '<input ' . ($disabled ? 'disabled="disabled"' : '') . ' type="radio" name="' . $key . '" id="' . $key . $cValue . '_on" value="' . (int) ($cValue) . '"' . (($cValue == $val) ? ' checked="checked"' : '') . (isset($field['js'][$cValue]) ? ' ' . $field['js'][$cValue] : '') . ' /><label class="t" for="' . $key . $cValue . '_on"> ' . $cKey . '</label><br />';
}
$html .= '<br />';
return $html;
}
private function renderSelect($field, $key, $val)
{
$html = '<div class="form-group">
<label class="col-lg-3 control-label">' . $field['title'] . '</label>
<div class="col-lg-9">
<select name="' . $key . '">';
foreach ($field['choices'] as $cValue => $cKey) {
$html .= '<option value="' . (int) $cValue . '"'
. (($cValue == $val) ? ' selected' : '')
. '>'
. $cKey
. '</option>';
}
$html .= '</select>
<div class="help-block">' . $field['desc'] . '</div>
</div>
</div>';
return $html;
}
private function renderTextarea($field, $key, $val, $disabled)
{
return '<textarea '
. ($disabled ? 'disabled="disabled"' : '')
. ' name="' . $key
. '" cols="' . $field['cols']
. '" rows="' . $field['rows']
. '">'
. htmlentities($val, ENT_COMPAT, 'UTF-8')
. '</textarea>';
}
private function renderTextField($field, $key, $val, $disabled)
{
return '<input '
. ($disabled ? 'disabled="disabled"' : '')
. ' type="' . $field['type'] . '"'
. (isset($field['id']) ? ' id="' . $field['id'] . '"' : '')
. ' size="' . (isset($field['size']) ? (int) ($field['size']) : 5)
. '" name="' . $key
. '" value="' . ($field['type'] == 'password' ? '' : htmlentities($val, ENT_COMPAT, 'UTF-8'))
. '" />'
. (isset($field['next']) ? '&nbsp;' . $field['next'] : '');
}
private function renderThumb($field)
{
return "<img src=\"{$field['thumb']['file']}\" alt=\"{$field['title']}\" title=\"{$field['title']}\" style=\"float:left;\">";
}
}

View File

@@ -0,0 +1,187 @@
<?php
/**
* 2007-2017 PrestaShop.
*
* NOTICE OF LICENSE
*
* This source file is subject to the Open Software License (OSL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* https://opensource.org/licenses/OSL-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 http://www.prestashop.com for more information.
*
* @author PrestaShop SA <contact@prestashop.com>
* @copyright 2007-2017 PrestaShop SA
* @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
* International Registered Trademark & Property of PrestaShop SA
*/
namespace PrestaShop\Module\AutoUpgrade\Twig\Form;
use PrestaShop\Module\AutoUpgrade\UpgradeTools\Translator;
class UpgradeOptionsForm
{
/**
* @var array
*/
private $fields;
/**
* @var Translator
*/
private $translator;
/**
* @var FormRenderer
*/
private $formRenderer;
public function __construct(Translator $translator, FormRenderer $formRenderer)
{
$this->translator = $translator;
$this->formRenderer = $formRenderer;
// TODO: Class const
$translationDomain = 'Modules.Autoupgrade.Admin';
$this->fields = array(
'PS_AUTOUP_PERFORMANCE' => array(
'title' => $translator->trans(
'Server performance',
array(),
$translationDomain
),
'cast' => 'intval',
'validation' => 'isInt',
'defaultValue' => '1',
'type' => 'select', 'desc' => $translator->trans(
'Unless you are using a dedicated server, select "Low".',
array(),
$translationDomain
) . '<br />' .
$translator->trans(
'A high value can cause the upgrade to fail if your server is not powerful enough to process the upgrade tasks in a short amount of time.',
array(),
$translationDomain
),
'choices' => array(
1 => $translator->trans(
'Low (recommended)',
array(),
$translationDomain
),
2 => $translator->trans('Medium', array(), $translationDomain),
3 => $translator->trans(
'High',
array(),
$translationDomain
),
),
),
'PS_AUTOUP_CUSTOM_MOD_DESACT' => array(
'title' => $translator->trans(
'Disable non-native modules',
array(),
$translationDomain
),
'cast' => 'intval',
'validation' => 'isBool',
'type' => 'bool',
'desc' => $translator->trans(
'As non-native modules can experience some compatibility issues, we recommend to disable them by default.',
array(),
$translationDomain
) . '<br />' .
$translator->trans(
'Keeping them enabled might prevent you from loading the "Modules" page properly after the upgrade.',
array(),
$translationDomain
),
),
'PS_AUTOUP_UPDATE_DEFAULT_THEME' => array(
'title' => $translator->trans(
'Upgrade the default theme',
array(),
$translationDomain
),
'cast' => 'intval',
'validation' => 'isBool',
'defaultValue' => '1',
'type' => 'bool',
'desc' => $translator->trans(
'If you customized the default PrestaShop theme in its folder (folder name "classic" in 1.7), enabling this option will lose your modifications.',
array(),
$translationDomain
) . '<br />'
. $translator->trans(
'If you are using your own theme, enabling this option will simply update the default theme files, and your own theme will be safe.',
array(),
$translationDomain
),
),
'PS_AUTOUP_CHANGE_DEFAULT_THEME' => array(
'title' => $translator->trans(
'Switch to the default theme',
array(),
$translationDomain
),
'cast' => 'intval',
'validation' => 'isBool',
'defaultValue' => '0',
'type' => 'bool',
'desc' => $translator->trans(
'This will change your theme: your shop will then use the default theme of the version of PrestaShop you are upgrading to.',
array(),
$translationDomain
),
),
'PS_AUTOUP_KEEP_MAILS' => array(
'title' => $translator->trans(
'Keep the customized email templates',
array(),
$translationDomain
),
'cast' => 'intval',
'validation' => 'isBool',
'type' => 'bool',
'desc' => $translator->trans(
'This will not upgrade the default PrestaShop e-mails.',
array(),
$translationDomain
) . '<br />'
. $translator->trans(
'If you customized the default PrestaShop e-mail templates, enabling this option will keep your modifications.',
array(),
$translationDomain
),
),
);
}
public function render()
{
return $this->formRenderer->render(
'upgradeOptions',
$this->fields,
$this->translator->trans(
'Upgrade Options',
array(),
'Modules.Autoupgrade.Admin'
),
'',
'prefs'
);
}
}

View File

@@ -0,0 +1,55 @@
<?php
/*
* 2007-2018 PrestaShop
*
* NOTICE OF LICENSE
*
* This source file is subject to the Open Software License (OSL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://opensource.org/licenses/osl-3.0.php
* 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 http://www.prestashop.com for more information.
*
* @author PrestaShop SA <contact@prestashop.com>
* @copyright 2007-2018 PrestaShop SA
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
* International Registered Trademark & Property of PrestaShop SA
*/
namespace PrestaShop\Module\AutoUpgrade\Twig;
use Twig_Extension;
use Twig_SimpleFilter;
class TransFilterExtension extends Twig_Extension
{
const DOMAIN = 'Modules.Autoupgrade.Admin';
private $translator;
public function __construct($translator)
{
$this->translator = $translator;
}
public function getFilters()
{
return array(
new Twig_SimpleFilter('trans', array($this, 'trans')),
);
}
public function trans($string, $params = array())
{
return $this->translator->trans($string, $params, self::DOMAIN);
}
}