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\Contact\CommandHandler;
use Contact;
use PrestaShop\PrestaShop\Adapter\Domain\AbstractObjectModelHandler;
use PrestaShop\PrestaShop\Core\ConstraintValidator\Constraints\CleanHtml;
use PrestaShop\PrestaShop\Core\ConstraintValidator\Constraints\DefaultLanguage;
use PrestaShop\PrestaShop\Core\Domain\Contact\Command\AddContactCommand;
use PrestaShop\PrestaShop\Core\Domain\Contact\CommandHandler\AddContactHandlerInterface;
use PrestaShop\PrestaShop\Core\Domain\Contact\Exception\CannotAddContactException;
use PrestaShop\PrestaShop\Core\Domain\Contact\Exception\ContactConstraintException;
use PrestaShop\PrestaShop\Core\Domain\Contact\Exception\ContactException;
use PrestaShop\PrestaShop\Core\Domain\Contact\ValueObject\ContactId;
use PrestaShopException;
use Symfony\Component\Validator\Validator\ValidatorInterface;
/**
* Class AddContactHandler is used for adding contact data.
*
* @internal
*/
final class AddContactHandler extends AbstractObjectModelHandler implements AddContactHandlerInterface
{
/**
* @var ValidatorInterface
*/
private $validator;
/**
* @param ValidatorInterface $validator
*/
public function __construct(ValidatorInterface $validator)
{
$this->validator = $validator;
}
/**
* {@inheritdoc}
*
* @throws CannotAddContactException
* @throws ContactException
*/
public function handle(AddContactCommand $command)
{
$this->assertLocalisedTitleContainsDefaultLanguage($command->getLocalisedTitles());
try {
$entity = new Contact();
$entity->name = $command->getLocalisedTitles();
$entity->customer_service = $command->isMessageSavingEnabled();
if (null !== $command->getEmail()) {
$entity->email = $command->getEmail()->getValue();
}
if (null !== $command->getLocalisedDescription()) {
$this->assertDescriptionContainsCleanHtmlValues($command->getLocalisedDescription());
$entity->description = $command->getLocalisedDescription();
}
if (false === $entity->add()) {
throw new CannotAddContactException('Unable to add contact');
}
if (null !== $command->getShopAssociation()) {
$this->associateWithShops($entity, $command->getShopAssociation());
}
} catch (PrestaShopException $exception) {
throw new ContactException('An unexpected error occurred when adding contact', 0, $exception);
}
return new ContactId((int) $entity->id);
}
/**
* Checks if the localised titles array contains value for the default language.
*
* @param array $localisedTitle
*
* @throws ContactConstraintException
*/
private function assertLocalisedTitleContainsDefaultLanguage(array $localisedTitle)
{
$errors = $this->validator->validate($localisedTitle, new DefaultLanguage());
if (0 !== count($errors)) {
throw new ContactConstraintException('Title field is not found for default language', ContactConstraintException::MISSING_TITLE_FOR_DEFAULT_LANGUAGE);
}
}
/**
* Assets that the value should not contain script tags or javascript events.
*
* @param array $localisedDescriptions
*
* @throws ContactConstraintException
*/
private function assertDescriptionContainsCleanHtmlValues(array $localisedDescriptions)
{
foreach ($localisedDescriptions as $description) {
$errors = $this->validator->validate($description, new CleanHtml());
if (0 !== count($errors)) {
throw new ContactConstraintException(sprintf('Given description "%s" contains javascript events or script tags', $description), ContactConstraintException::INVALID_DESCRIPTION);
}
}
}
}
xxxxx1.0, XXX xxxx