![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/cartforge.co/vendor/paypal/module-braintree-core/Controller/Paypal/ |
<?php /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ namespace PayPal\Braintree\Controller\Paypal; use Exception; use Magento\Checkout\Model\Session; use Magento\Framework\App\Action\Context; use Magento\Framework\App\Action\HttpGetActionInterface; use Magento\Framework\App\Action\HttpPostActionInterface; use Magento\Framework\Controller\Result\Redirect; use Magento\Framework\Controller\ResultFactory; use Magento\Framework\Serialize\Serializer\Json; use PayPal\Braintree\Gateway\Config\PayPal\Config; use PayPal\Braintree\Model\Paypal\Helper\QuoteUpdater; use Magento\Framework\Exception\LocalizedException; use Magento\Framework\View\Result\Page; class Review extends AbstractAction implements HttpGetActionInterface, HttpPostActionInterface { /** * @var QuoteUpdater */ private $quoteUpdater; /** * @var string */ private static $paymentMethodNonce = 'payment_method_nonce'; /** * @var Json */ protected $json; /** * Constructor * * @param Context $context * @param Config $config * @param Session $checkoutSession * @param QuoteUpdater $quoteUpdater * @param Json $json */ public function __construct( Context $context, Config $config, Session $checkoutSession, QuoteUpdater $quoteUpdater, Json $json ) { parent::__construct($context, $config, $checkoutSession); $this->json = $json; $this->quoteUpdater = $quoteUpdater; } /** * @inheritdoc */ public function execute() { $requestData = $this->json->unserialize( $this->getRequest()->getPostValue('result', '{}') ); $quote = $this->checkoutSession->getQuote(); try { if (is_array($requestData) === false) { throw new LocalizedException( __('Malformed request data. This may be caused by special characters. Please try again') ); } $this->validateQuote($quote); if ($this->validateRequestData($requestData)) { $this->quoteUpdater->execute( $requestData['nonce'], $requestData['details'], $quote ); } elseif (!$quote->getPayment()->getAdditionalInformation(self::$paymentMethodNonce)) { throw new LocalizedException(__('We can\'t initialize checkout.')); } /** @var Page $resultPage */ $resultPage = $this->resultFactory->create(ResultFactory::TYPE_PAGE); /** @var \PayPal\Braintree\Block\Paypal\Checkout\Review $reviewBlock */ $reviewBlock = $resultPage->getLayout()->getBlock('braintree.paypal.review'); $reviewBlock->setQuote($quote); $reviewBlock->getChildBlock('shipping_method')->setData('quote', $quote); return $resultPage; } catch (Exception $e) { $this->messageManager->addExceptionMessage($e, $e->getMessage()); } /** @var Redirect $resultRedirect */ $resultRedirect = $this->resultFactory->create(ResultFactory::TYPE_REDIRECT); return $resultRedirect->setPath('checkout/cart', ['_secure' => true]); } /** * Validate request data * * @param array $requestData * @return boolean */ private function validateRequestData(array $requestData): bool { return !empty($requestData['nonce']) && !empty($requestData['details']); } }