PreCheck::sendRequest()   F
last analyzed

Complexity

Conditions 13
Paths 576

Size

Total Lines 67
Code Lines 41

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 13
eloc 41
c 0
b 0
f 0
nc 576
nop 5
dl 0
loc 67
rs 3.0388

How to fix   Long Method    Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

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\Model\Api\Request\Genericpayment;
28
29
use Payone\Core\Model\Methods\PayoneMethod;
30
use Magento\Quote\Model\Quote;
0 ignored issues
show
Bug introduced by
The type Magento\Quote\Model\Quote was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
31
32
/**
33
 * Class for the PAYONE Server API request genericpayment - "pre_check"
34
 */
35
class PreCheck extends Base
36
{
37
    /**
38
     * Send request to PAYONE Server-API with request-type "genericpayment" and action "pre_check"
39
     *
40
     * @param  PayoneMethod $oPayment payment object
41
     * @param  Quote        $oQuote   order object
42
     * @param  float|bool   $dAmount  order sum amount
43
     * @param  string|bool  $sBirthday
44
     * @param  string|bool  $sEmail
45
     * @return array
46
     */
47
    public function sendRequest(PayoneMethod $oPayment, Quote $oQuote, $dAmount = false, $sBirthday = false, $sEmail = false)
48
    {
49
        $this->addParameter('request', 'genericpayment');
50
        $this->addParameter('add_paydata[action]', 'pre_check');
51
52
        $this->addParameter('mode', $oPayment->getOperationMode());
53
        $this->addParameter('aid', $this->shopHelper->getConfigParam('aid')); // ID of PayOne Sub-Account
54
        $this->addParameter('api_version', '3.10');
55
56
        $this->addParameter('clearingtype', $oPayment->getClearingtype());
57
        $this->addParameter('financingtype', $oPayment->getSubType());
58
        $this->addParameter('add_paydata[payment_type]', $oPayment->getLongSubType());
59
60
        if ($dAmount === false) {
61
            $dAmount = $this->apiHelper->getQuoteAmount($oQuote);
62
        }
63
        $this->addParameter('amount', number_format($dAmount, 2, '.', '') * 100); // add price to request
0 ignored issues
show
Bug introduced by
It seems like $dAmount can also be of type boolean; however, parameter $num of number_format() does only seem to accept double, maybe add an additional type check? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

63
        $this->addParameter('amount', number_format(/** @scrutinizer ignore-type */ $dAmount, 2, '.', '') * 100); // add price to request
Loading history...
64
        $this->addParameter('currency', $this->apiHelper->getCurrencyFromQuote($oQuote)); // add currency to request
65
66
        if ($sEmail === false) {
67
            $sEmail = $oQuote->getCustomerEmail();
68
        }
69
        $this->addParameter('email', $sEmail);
70
71
        #if ($sBirthday === false && $oPayment->getData('info_instance')) {
72
        if ($oPayment->getData('info_instance')) {
73
            $sBirthday = $oPayment->getInfoInstance()->getAdditionalInformation('dateofbirth');
74
        }
75
        if ($sBirthday) {
76
            $this->addParameter('birthday', $sBirthday);
77
        }
78
79
        $oBilling = $oQuote->getBillingAddress();
80
        $this->addAddress($oBilling);
81
82
        if ($oBilling->getCountryId() == 'NL') {
83
            $sTelephone = $oBilling->getTelephone();
84
            if (empty($sTelephone)) {
85
                $sTelephone = $oPayment->getInfoInstance()->getAdditionalInformation('telephone');
86
            }
87
            $this->addParameter('telephone', $sTelephone);
88
        }
89
90
        $this->addParameter('language', $this->shopHelper->getLocale());
91
92
        $sIp = $this->environmentHelper->getRemoteIp(); // get remote IP
93
        if ($sIp != '') {// is IP not empty
94
            $this->addParameter('ip', $sIp); // add IP address to the request
95
        }
96
97
        if ($oPayment->getData('info_instance')) {
98
            $blB2bMode = $oPayment->getInfoInstance()->getAdditionalInformation('b2bmode');
99
            if (!empty($blB2bMode) && (bool)$blB2bMode === true) {
100
                $this->addParameter('add_paydata[b2b]', 'yes');
101
102
                $sTradeRegistryNumber = $oPayment->getInfoInstance()->getAdditionalInformation('trade_registry_number');
103
                if (!empty($sTradeRegistryNumber)) {
104
                    $this->addParameter('add_paydata[company_trade_registry_number]', $sTradeRegistryNumber);
105
                }
106
                $sCompanyUid = $oPayment->getInfoInstance()->getAdditionalInformation('company_uid');
107
                if (!empty($sCompanyUid)) {
108
                    $this->addParameter('add_paydata[company_uid]', $sCompanyUid);
109
                }
110
            }
111
        }
112
113
        return $this->send($oPayment);
114
    }
115
}
116