Issues (1092)

Model/ResourceModel/PaymentBan.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\ResourceModel;
28
29
/**
30
 * PaymentBan resource model
31
 */
32
class PaymentBan extends \Magento\Framework\Model\ResourceModel\Db\AbstractDb
0 ignored issues
show
The type Magento\Framework\Model\...urceModel\Db\AbstractDb 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...
33
{
34
    /**
35
     * Initialize connection and table
36
     *
37
     * @return void
38
     */
39
    protected function _construct()
40
    {
41
        $this->_init('payone_payment_ban', 'id');
42
    }
43
44
    /**
45
     * Generate date string for end date of the ban
46
     *
47
     * @param  int $iHourDuration
48
     * @return string
49
     */
50
    public function getBanEndDate($iHourDuration)
51
    {
52
        return date('Y-m-d H:i:s', (time() + (60 * 60 * $iHourDuration)));
53
    }
54
55
    /**
56
     * Insert new line into payone_payment_ban table
57
     *
58
     * @param  string $sPaymentMethod
59
     * @param  int    $iCustomerId
60
     * @param  int    $iHourDuration
61
     * @return $this
62
     */
63
    public function addPaymentBan($sPaymentMethod, $iCustomerId, $iHourDuration)
64
    {
65
        $this->getConnection()->insert(
66
            $this->getMainTable(),
67
            [
68
                'customer_id' => $iCustomerId,
69
                'payment_method' => $sPaymentMethod,
70
                'to_date' => $this->getBanEndDate($iHourDuration)
71
            ]
72
        );
73
        return $this;
74
    }
75
76
    /**
77
     * Get payment bans for the given customer id
78
     *
79
     * @param  int $iCustomerId
80
     * @return array
81
     */
82
    public function getPaymentBans($iCustomerId)
83
    {
84
        $oSelect = $this->getConnection()->select()
85
            ->from($this->getMainTable(), ['payment_method', 'to_date'])
86
            ->where("customer_id = :customerId")
87
            ->where("to_date > :toDate")
88
            ->order('to_date ASC');
89
90
        $aParams = [
91
            'customerId' => $iCustomerId,
92
            'toDate' => date('Y-m-d H:i:s')
93
        ];
94
95
        $aResult = $this->getConnection()->fetchAll($oSelect, $aParams);
96
97
        $aReturn = [];
98
        foreach ($aResult as $aItem) {
99
            $aReturn[$aItem['payment_method']] = $aItem['to_date'];
100
        }
101
        return $aReturn;
102
    }
103
}
104