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)
*/
use PrestaShop\PrestaShop\Adapter\Presenter\Order\OrderPresenter;
use PrestaShop\PrestaShop\Core\Security\PasswordPolicyConfiguration;
class GuestTrackingControllerCore extends FrontController
{
/** @var bool */
public $ssl = true;
/** @var bool */
public $auth = false;
/** @var string */
public $php_self = 'guest-tracking';
protected $order;
/**
* Initialize guest tracking controller.
*
* @see FrontController::init()
*/
public function init()
{
if ($this->context->customer->isLogged()) {
Tools::redirect('history.php');
}
parent::init();
}
/**
* Start forms process.
*
* @see FrontController::postProcess()
*/
public function postProcess()
{
$order_reference = current(explode('#', Tools::getValue('order_reference')));
$email = Tools::getValue('email');
if (!$email && !$order_reference) {
return;
} elseif (!$email || !$order_reference) {
$this->errors[] = $this->getTranslator()->trans(
'Please provide the required information',
[],
'Shop.Notifications.Error'
);
return;
}
$this->order = Order::getByReferenceAndEmail($order_reference, $email);
if (!Validate::isLoadedObject($this->order)) {
$this->errors[] = $this->getTranslator()->trans(
'We couldn\'t find your order with the information provided, please try again',
[],
'Shop.Notifications.Error'
);
}
if (Tools::isSubmit('submitTransformGuestToCustomer') && Tools::getValue('password')) {
$customer = new Customer((int) $this->order->id_customer);
/** @var string $password */
$password = Tools::getValue('password');
if (empty($password)) {
$this->errors[] = $this->trans(
'Enter a password to transform your guest account into a customer account.',
[],
'Shop.Forms.Help'
);
} elseif (!Validate::isAcceptablePasswordLength($password)) {
$this->errors[] = $this->trans(
'Your password length must be between %d and %d',
[Configuration::get(PasswordPolicyConfiguration::CONFIGURATION_MINIMUM_LENGTH), Configuration::get(PasswordPolicyConfiguration::CONFIGURATION_MAXIMUM_LENGTH)],
'Shop.Forms.Help'
);
} elseif (!Validate::isAcceptablePasswordScore($password)) {
$this->errors[] = $this->trans(
'Customer password is too weak',
[],
'Shop.Forms.Help'
);
// Prevent error
// A) either on page refresh
// B) if we already transformed him in other window or through backoffice
} elseif ($customer->is_guest == 0) {
$this->errors[] = $this->trans(
'A customer account has already been created from this guest account. Please sign in.',
[],
'Shop.Notifications.Error'
);
// Attempt to convert the customer
} elseif ($customer->transformToCustomer($this->context->language->id, $password)) {
$this->success[] = $this->trans(
'Your guest account has been successfully transformed into a customer account. You can now log in as a registered shopper.',
[],
'Shop.Notifications.Success'
);
} else {
$this->errors[] = $this->trans(
'An unexpected error occurred while creating your account.',
[],
'Shop.Notifications.Error'
);
}
}
}
/**
* Assign template vars related to page content.
*
* @see FrontController::initContent()
*/
public function initContent()
{
parent::initContent();
if (!Validate::isLoadedObject($this->order)) {
return $this->setTemplate('customer/guest-login');
}
if ((int) $this->order->isReturnable()) {
$this->info[] = $this->trans(
'You cannot return merchandise with a guest account.',
[],
'Shop.Notifications.Warning'
);
}
// Kept for backwards compatibility (is_customer), inline it in later versions
$registered_customer_exists = Customer::customerExists(Tools::getValue('email'), false, true);
$this->context->smarty->assign([
'order' => (new OrderPresenter())->present($this->order),
'guest_email' => Tools::getValue('email'),
'registered_customer_exists' => $registered_customer_exists,
'is_customer' => $registered_customer_exists, // Kept for backwards compatibility
'HOOK_DISPLAYORDERDETAIL' => Hook::exec('displayOrderDetail', ['order' => $this->order]),
]);
return $this->setTemplate('customer/guest-tracking');
}
public function getBreadcrumbLinks()
{
$breadcrumbLinks = parent::getBreadcrumbLinks();
$breadcrumbLinks['links'][] = [
'title' => $this->getTranslator()->trans('Guest order tracking', [], 'Shop.Theme.Checkout'),
'url' => $this->context->link->getPageLink('guest-tracking'),
];
if (Validate::isLoadedObject($this->order)) {
$breadcrumbLinks['links'][] = [
'title' => $this->order->reference,
'url' => '#',
];
}
return $breadcrumbLinks;
}
/**
* {@inheritdoc}
*/
public function getCanonicalURL()
{
return $this->context->link->getPageLink('guest-tracking');
}
}
xxxxx1.0, XXX xxxx