OrderPaymentPlaceEnd::handleOrderStatus()   A
last analyzed

Complexity

Conditions 2
Paths 2

Size

Total Lines 11
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 11
c 0
b 0
f 0
rs 9.4285
cc 2
eloc 7
nc 2
nop 1
1
<?php
2
3
/**
4
 * PAYONE Magento 2 Connector is free software: you can redistribute it and/or modify
5
 * it under the terms of the GNU Lesser General Public License as published by
6
 * the Free Software Foundation, either version 3 of the License, or
7
 * (at your option) any later version.
8
 *
9
 * PAYONE Magento 2 Connector is distributed in the hope that it will be useful,
10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
 * GNU Lesser General Public License for more details.
13
 *
14
 * You should have received a copy of the GNU Lesser General Public License
15
 * along with PAYONE Magento 2 Connector. If not, see <http://www.gnu.org/licenses/>.
16
 *
17
 * PHP version 5
18
 *
19
 * @category  Payone
20
 * @package   Payone_Magento2_Plugin
21
 * @author    FATCHIP GmbH <[email protected]>
22
 * @copyright 2003 - 2016 Payone GmbH
23
 * @license   <http://www.gnu.org/licenses/> GNU Lesser General Public License
24
 * @link      http://www.payone.de
25
 */
26
27
namespace Payone\Core\Observer;
28
29
use Magento\Sales\Model\Order;
30
use Magento\Framework\Event\ObserverInterface;
31
use Magento\Framework\Event\Observer;
32
use Payone\Core\Helper\Consumerscore;
33
use Magento\Sales\Model\Order\Payment;
34
35
/**
36
 * Event class to set the orderstatus to new and pending
37
 */
38
class OrderPaymentPlaceEnd implements ObserverInterface
39
{
40
    /**
41
     * PAYONE payment helper
42
     *
43
     * @var Consumerscore
44
     */
45
    protected $consumerscoreHelper;
46
47
    /**
48
     * Constructor
49
     *
50
     * @param Consumerscore $consumerscoreHelper
51
     */
52
    public function __construct(Consumerscore $consumerscoreHelper)
53
    {
54
        $this->consumerscoreHelper = $consumerscoreHelper;
55
    }
56
57
    /**
58
     * Handle order status
59
     *
60
     * @param  Observer $observer
61
     * @return void
62
     */
63
    protected function handleOrderStatus(Observer $observer)
64
    {
65
        /** @var Payment $oPayment */
66
        $oPayment = $observer->getEvent()->getPayment();
67
        $oPaymentInstance = $oPayment->getMethodInstance();
68
        if (stripos($oPaymentInstance->getCode(), 'payone') !== false) {
69
            $oOrder = $oPayment->getOrder();
70
            $oOrder->setState(Order::STATE_NEW);
71
            $oOrder->setStatus($oPaymentInstance->getConfigData('order_status'));
72
        }
73
    }
74
75
    /**
76
     * Execute certain tasks after the payment is placed and thus the order is placed
77
     *
78
     * @param  Observer $observer
79
     * @return void
80
     */
81
    public function execute(Observer $observer)
82
    {
83
        // set status to new - pending on new orders
84
        $this->handleOrderStatus($observer);
85
86
        // increment counter for every order, needed for the A/B test feature
87
        $this->consumerscoreHelper->incrementConsumerscoreSampleCounter();
88
    }
89
}
90