Validate3d.php 6.63 KB
Newer Older
1
<?php
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
/**
 *                       ######
 *                       ######
 * ############    ####( ######  #####. ######  ############   ############
 * #############  #####( ######  #####. ######  #############  #############
 *        ######  #####( ######  #####. ######  #####  ######  #####  ######
 * ###### ######  #####( ######  #####. ######  #####  #####   #####  ######
 * ###### ######  #####( ######  #####. ######  #####          #####  ######
 * #############  #############  #############  #############  #####  ######
 *  ############   ############  #############   ############  #####  ######
 *                                      ######
 *                               #############
 *                               ############
 *
 * Adyen Payment module (https://www.adyen.com/)
 *
 * Copyright (c) 2015 Adyen BV (https://www.adyen.com/)
 * See LICENSE.txt for license details.
 *
 * Author: Adyen <magento@adyen.com>
 */
23 24 25 26 27 28 29 30 31 32

namespace Adyen\Payment\Controller\Process;

class Validate3d extends \Magento\Framework\App\Action\Action
{
    /**
     * @var \Magento\Sales\Model\OrderFactory
     */
    protected $_orderFactory;

33 34 35
    /**
     * @var \Magento\Sales\Model\Order
     */
36 37
    protected $_order;

38 39 40
    /**
     * @var \Adyen\Payment\Logger\AdyenLogger
     */
41 42
    protected $_adyenLogger;

43 44 45
    /**
     * @var \Adyen\Payment\Helper\Data
     */
46 47
    protected $_adyenHelper;

48 49 50 51 52
    /**
     * @var \Adyen\Payment\Model\Api\PaymentRequest
     */
    protected $_paymentRequest;

53
    /**
54 55
     * Validate3d constructor.
     *
56
     * @param \Magento\Framework\App\Action\Context $context
57 58
     * @param \Adyen\Payment\Logger\AdyenLogger $adyenLogger
     * @param \Adyen\Payment\Helper\Data $adyenHelper
59
     * @param \Adyen\Payment\Model\Api\PaymentRequest $paymentRequest
60 61 62 63
     */
    public function __construct(
        \Magento\Framework\App\Action\Context $context,
        \Adyen\Payment\Logger\AdyenLogger $adyenLogger,
64 65
        \Adyen\Payment\Helper\Data $adyenHelper,
        \Adyen\Payment\Model\Api\PaymentRequest $paymentRequest
66 67 68 69
    ) {
        parent::__construct($context);
        $this->_adyenLogger = $adyenLogger;
        $this->_adyenHelper = $adyenHelper;
70
        $this->_paymentRequest = $paymentRequest;
71 72
    }

73 74 75
    /**
     * Validate 3D secure payment
     */
76 77
    public function execute()
    {
78 79
        $active = null;

80 81 82
        // check if 3d is active
        $order = $this->_getOrder();

83
        if ($order->getPayment()) {
84 85
            $active = $order->getPayment()->getAdditionalInformation('3dActive');
        }
86 87

        // check if 3D secure is active. If not just go to success page
88
        if ($active) {
89
            $this->_adyenLogger->addAdyenResult("3D secure is active");
90

91 92 93
            // check if it is already processed
            if ($this->getRequest()->isPost()) {

94
                $this->_adyenLogger->addAdyenResult("Process 3D secure payment");
95 96
                $requestMD = $this->getRequest()->getPost('MD');
                $requestPaRes = $this->getRequest()->getPost('PaRes');
97
                $md = $order->getPayment()->getAdditionalInformation('md');
98 99 100 101 102 103

                if ($requestMD == $md) {

                    $order->getPayment()->setAdditionalInformation('paResponse', $requestPaRes);

                    try {
104 105 106 107 108 109 110 111 112 113
                        /**
                         * Magento should allow this.
                         * https://github.com/magento/magento2/issues/5819
                         */
//                        $result = $order->getPayment()->getMethodInstance()->executeCommand(
//                            'authorise_3d',
//                            ['payment' => $order->getPayment(), 'amount' => $order->getGrandTotal()]
//                        );
                        // old fashion way:
                        $result = $this->_authorise3d($order->getPayment());
114 115
                    } catch (\Exception $e) {
                        $this->_adyenLogger->addAdyenResult("Process 3D secure payment was refused");
116 117 118
                        $result = 'Refused';
                    }

119 120
                    $this->_adyenLogger->addAdyenResult("Process 3D secure payment result is: " . $result);

121 122 123 124
                    // check if authorise3d was successful
                    if ($result == 'Authorised') {
                        $order->addStatusHistoryComment(__('3D-secure validation was successful'))->save();
                        $this->_redirect('checkout/onepage/success');
125
                    } else {
126 127
                        $order->addStatusHistoryComment(__('3D-secure validation was unsuccessful.'))->save();
                        $this->_adyenHelper->cancelOrder($order);
128 129 130 131 132 133 134 135 136
                        $this->messageManager->addErrorMessage("3D-secure validation was unsuccessful");
                        
                        // reactivate the quote
                        $session = $this->_getCheckout();

                        // restore the quote
                        $session->restoreQuote();

                        $this->_redirect('checkout/cart');
137 138 139
                    }
                }
            } else {
140
                $this->_adyenLogger->addAdyenResult("Customer was redirected to bank for 3D-secure validation.");
141 142 143
                $order->addStatusHistoryComment(
                    __('Customer was redirected to bank for 3D-secure validation.')
                )->save();
144 145 146 147 148 149 150 151 152 153

                $this->_view->loadLayout();
                $this->_view->getLayout()->initMessages();
                $this->_view->renderLayout();
            }
        } else {
            $this->_redirect('checkout/onepage/success/');
        }
    }

154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171
    /**
     * Called by validate3d controller when cc payment has 3D secure
     *
     * @param $payment
     * @return mixed
     * @throws \Exception
     */
    protected function _authorise3d($payment)
    {
        try {
            $response = $this->_paymentRequest->authorise3d($payment);
        } catch(\Exception $e) {
            throw $e;
        }
        $responseCode = $response['resultCode'];
        return $responseCode;
    }

172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193
    /**
     * Get order object
     *
     * @return \Magento\Sales\Model\Order
     */
    protected function _getOrder()
    {
        if (!$this->_order) {
            $incrementId = $this->_getCheckout()->getLastRealOrderId();
            $this->_orderFactory = $this->_objectManager->get('Magento\Sales\Model\OrderFactory');
            $this->_order = $this->_orderFactory->create()->loadByIncrementId($incrementId);
        }
        return $this->_order;
    }

    /**
     * @return \Magento\Checkout\Model\Session
     */
    protected function _getCheckout()
    {
        return $this->_objectManager->get('Magento\Checkout\Model\Session');
    }
Rik ter Beek's avatar
Rik ter Beek committed
194
}