JEMBOT MAWOT Bypass Shell
<?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 Open Software License (OSL 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/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 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/OSL-3.0 Open Software License (OSL 3.0)
*/
namespace PrestaShop\PrestaShop\Adapter\Meta\CommandHandler;
use Meta;
use PrestaShop\PrestaShop\Adapter\Meta\MetaDataProvider;
use PrestaShop\PrestaShop\Core\ConstraintValidator\Constraints\DefaultLanguage;
use PrestaShop\PrestaShop\Core\ConstraintValidator\Constraints\IsUrlRewrite;
use PrestaShop\PrestaShop\Core\Domain\Meta\Command\AddMetaCommand;
use PrestaShop\PrestaShop\Core\Domain\Meta\CommandHandler\AddMetaHandlerInterface;
use PrestaShop\PrestaShop\Core\Domain\Meta\Exception\CannotAddMetaException;
use PrestaShop\PrestaShop\Core\Domain\Meta\Exception\MetaConstraintException;
use PrestaShop\PrestaShop\Core\Domain\Meta\Exception\MetaException;
use PrestaShop\PrestaShop\Core\Domain\Meta\ValueObject\MetaId;
use PrestaShop\PrestaShop\Core\Hook\HookDispatcherInterface;
use PrestaShopException;
use Symfony\Component\Validator\Validator\ValidatorInterface;
/**
* Class SaveMetaHandler is responsible for saving meta data.
*
* @internal
*/
final class AddMetaHandler implements AddMetaHandlerInterface
{
/**
* @var HookDispatcherInterface
*/
private $hookDispatcher;
/**
* @var int
*/
private $defaultLanguageId;
/**
* @var ValidatorInterface
*/
private $validator;
/**
* @var MetaDataProvider
*/
private $metaDataProvider;
/**
* @param HookDispatcherInterface $hookDispatcher
* @param ValidatorInterface $validator
* @param int $defaultLanguageId
* @param MetaDataProvider $metaDataProvider
*/
public function __construct(
HookDispatcherInterface $hookDispatcher,
ValidatorInterface $validator,
$defaultLanguageId,
MetaDataProvider $metaDataProvider
) {
$this->hookDispatcher = $hookDispatcher;
$this->defaultLanguageId = $defaultLanguageId;
$this->validator = $validator;
$this->metaDataProvider = $metaDataProvider;
}
/**
* {@inheritdoc}
*
* @throws CannotAddMetaException
* @throws MetaException
*/
public function handle(AddMetaCommand $command)
{
$this->assertUrlRewriteHasDefaultLanguage($command);
$this->assertIsUrlRewriteValid($command);
$this->assertIsValidPageName($command);
try {
$entity = new Meta();
$entity->page = $command->getPageName()->getValue();
$entity->title = $command->getLocalisedPageTitles();
$entity->description = $command->getLocalisedMetaDescription();
$entity->keywords = $command->getLocalisedMetaKeywords();
$rewriteUrls = $command->getLocalisedRewriteUrls();
foreach ($rewriteUrls as $idLang => $rewriteUrl) {
if (!$rewriteUrl) {
$rewriteUrls[$idLang] = $rewriteUrls[$this->defaultLanguageId];
}
}
$entity->url_rewrite = $rewriteUrls;
$entity->add();
if (0 >= $entity->id) {
throw new CannotAddMetaException(sprintf('Invalid entity id after creation: %s', $entity->id));
}
} catch (PrestaShopException $exception) {
throw new MetaException('Failed to create meta entity', 0, $exception);
}
$this->hookDispatcher->dispatchWithParameters('actionAdminMetaSave');
return new MetaId((int) $entity->id);
}
/**
* @param AddMetaCommand $command
*
* @throws MetaConstraintException
*/
private function assertUrlRewriteHasDefaultLanguage(AddMetaCommand $command)
{
$urlRewriteErrors = $this->validator->validate(
$command->getLocalisedRewriteUrls(),
new DefaultLanguage()
);
if (0 !== count($urlRewriteErrors) && 'index' !== $command->getPageName()->getValue()) {
throw new MetaConstraintException('The url rewrite is missing for the default language when creating new meta record', MetaConstraintException::INVALID_URL_REWRITE);
}
}
/**
* @param AddMetaCommand $command
*
* @throws MetaConstraintException
*/
private function assertIsUrlRewriteValid(AddMetaCommand $command)
{
foreach ($command->getLocalisedRewriteUrls() as $idLang => $rewriteUrl) {
$errors = $this->validator->validate($rewriteUrl, new IsUrlRewrite());
if (0 !== count($errors)) {
throw new MetaConstraintException(sprintf('Url rewrite %s for language with id %s is not valid', $rewriteUrl, $idLang), MetaConstraintException::INVALID_URL_REWRITE);
}
}
}
/**
* @param AddMetaCommand $command
*
* @throws MetaConstraintException
*/
private function assertIsValidPageName(AddMetaCommand $command)
{
$availablePages = $this->metaDataProvider->getAvailablePages();
if (!in_array($command->getPageName()->getValue(), $availablePages, true)) {
throw new MetaConstraintException(sprintf('Given page name %s is not available. Available values are %s', $command->getPageName()->getValue(), var_export($availablePages, true)), MetaConstraintException::INVALID_PAGE_NAME);
}
}
}
xxxxx1.0, XXX xxxx