Issues (1092)

Model/Methods/AmazonPay.php (1 issue)

Labels
Severity
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 - 2017 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\Methods;
28
29
use Payone\Core\Model\PayoneConfig;
30
use Magento\Sales\Model\Order;
0 ignored issues
show
The type Magento\Sales\Model\Order 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
 * Model for Amazon Pay payment method
34
 */
35
class AmazonPay extends PayoneMethod
36
{
37
    /**
38
     * Payment method code
39
     *
40
     * @var string
41
     */
42
    protected $_code = PayoneConfig::METHOD_AMAZONPAY;
43
44
    /**
45
     * Clearingtype for PAYONE authorization request
46
     *
47
     * @var string
48
     */
49
    protected $sClearingtype = 'wlt';
50
51
    /**
52
     * Wallettype for PAYONE requests
53
     *
54
     * @var string|bool
55
     */
56
    protected $sWallettype = 'AMZ';
57
58
    /**
59
     * Determines if the redirect-parameters have to be added
60
     * to the authorization-request
61
     *
62
     * @var bool
63
     */
64
    protected $blNeedsRedirectUrls = true;
65
66
    /**
67
     * Flags if Amazon Pay authorization is in retry mode
68
     *
69
     * @var bool
70
     */
71
    protected $blIsRetry = false;
72
73
    /**
74
     * Returns authorization-mode
75
     *
76
     * @return string
77
     */
78
    public function getAuthorizationMode()
79
    {
80
        return $this->getCustomConfigParam('request_type');
81
    }
82
83
    /**
84
     * Get amazon mode from config
85
     *
86
     * @return string
87
     */
88
    protected function getAmazonMode()
89
    {
90
        return $this->getCustomConfigParam('amazon_mode');
91
    }
92
93
    /**
94
     * Adds amazon timeout parameters
95
     *
96
     * @param  array $aParams
97
     * @return array
98
     */
99
    protected function addAmazonModeParameters($aParams)
100
    {
101
        $sAmazonMode = $this->getAmazonMode();
102
        switch ($sAmazonMode) {
103
            case 'synchronousFirst':
104
                if ($this->checkoutSession->getAmazonRetryAsync() === true) {
105
                    $aParams['add_paydata[amazon_timeout]'] = 1440;
106
                } else {
107
                    $this->checkoutSession->setAmazonRetryAsync(true);
108
                    $aParams['add_paydata[amazon_timeout]'] = 0;
109
                }
110
                break;
111
            case 'asynchronous':
112
                $aParams['add_paydata[amazon_timeout]'] = 1440;
113
                break;
114
            case 'synchronous':
115
                $aParams['add_paydata[amazon_timeout]'] = 0;
116
                $aParams['add_paydata[cancel_on_timeout]'] = 'yes';
117
                break;
118
        }
119
        return $aParams;
120
    }
121
122
    /**
123
     * Return parameters specific to this payment type
124
     *
125
     * @param  Order $oOrder
126
     * @return array
127
     */
128
    public function getPaymentSpecificParameters(Order $oOrder)
129
    {
130
        $aParams = ['wallettype' => $this->getWallettype()];
131
        $aParams['api_version'] = '3.10';
132
133
        $sWorkorderId = $this->checkoutSession->getAmazonWorkorderId();
134
        if ($sWorkorderId) {
135
            $aParams['workorderid'] = $sWorkorderId;
136
        }
137
        $aParams['add_paydata[amazon_address_token]'] = $this->checkoutSession->getAmazonAddressToken();
138
        $aParams['add_paydata[amazon_reference_id]'] = $this->checkoutSession->getAmazonReferenceId();
139
        $aParams = $this->addAmazonModeParameters($aParams);
140
        return $aParams;
141
    }
142
143
    /**
144
     * Perform certain actions with the response
145
     *
146
     * @param  array $aResponse
147
     * @param  Order $oOrder
148
     * @param  float $amount
149
     * @return array
150
     */
151
    protected function handleResponse($aResponse, Order $oOrder, $amount)
152
    {
153
        $aResponse = parent::handleResponse($aResponse, $oOrder, $amount);
154
        if ($aResponse['status'] == 'ERROR') {
155
            if (!$this->blIsRetry && $this->checkoutSession->getAmazonRetryAsync() && $aResponse['errorcode'] == 980) {
156
                $aResponse = $this->authorizationRequest->sendRequest($this, $oOrder, $amount);
157
                $this->checkoutSession->setShowAmazonPendingNotice(true);
158
            }
159
        }
160
        return $aResponse;
161
    }
162
}
163