forked from PrestaShopCorp/ps_checkout
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathOrderMatrice.php
99 lines (90 loc) · 3.14 KB
/
OrderMatrice.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
<?php
/**
* Copyright since 2007 PrestaShop SA and Contributors
* PrestaShop is an International Registered Trademark & Property of PrestaShop SA
*
* NOTICE OF LICENSE
*
* This source file is subject to the Academic Free License version 3.0
* that is bundled with this package in the file LICENSE.md.
* It is also available through the world-wide-web at this URL:
* https://opensource.org/licenses/AFL-3.0
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to [email protected] so we can send you a copy immediately.
*
* @author PrestaShop SA and Contributors <[email protected]>
* @copyright Since 2007 PrestaShop SA and Contributors
* @license https://opensource.org/licenses/AFL-3.0 Academic Free License version 3.0
*/
/**
* Makes a matrice between Prestashop Order and Paypal Order
*/
class OrderMatrice extends \ObjectModel
{
public $id_order_prestashop;
public $id_order_paypal;
/**
* @see ObjectModel::$definition
*/
public static $definition = [
'table' => 'pscheckout_order_matrice',
'primary' => 'id_order_matrice',
'fields' => [
'id_order_prestashop' => ['type' => self::TYPE_INT, 'validate' => 'isUnsignedInt', 'required' => true],
'id_order_paypal' => ['type' => self::TYPE_STRING, 'validate' => 'isString', 'required' => true],
],
];
/**
* Get the Prestashop Order Id from Paypal Order Id
*
* @param string $orderPaypal
*
* @return int
*/
public function getOrderPrestashopFromPaypal($orderPaypal)
{
$query = new \DbQuery();
$query->select('id_order_prestashop');
$query->from('pscheckout_order_matrice');
$query->where('id_order_paypal = "' . pSQL($orderPaypal) . '"');
$query->orderBy('id_order_matrice DESC');
return (int) \Db::getInstance()->getValue($query);
}
/**
* Get the Paypal Order Id from the Prestashop Order Id
*
* @param int $orderPrestashop
*
* @return string|false
*/
public function getOrderPaypalFromPrestashop($orderPrestashop)
{
$query = new \DbQuery();
$query->select('id_order_paypal');
$query->from('pscheckout_order_matrice');
$query->where('id_order_prestashop = ' . (int) $orderPrestashop);
$query->orderBy('id_order_matrice DESC');
return \Db::getInstance()->getValue($query);
}
/**
* Check if this order has multiple entries associated due to bug before 1.2.11
*
* @param int $orderId
*
* @return bool
*/
public static function hasInconsistencies($orderId)
{
// Before 1.2.11 id_order_prestashop field was limited to 255
if ((int) $orderId !== 255) {
return false;
}
// If more than one order found, there are inconsistencies for this order
$query = new \DbQuery();
$query->select('COUNT(*)');
$query->from('pscheckout_order_matrice');
$query->where('id_order_prestashop = ' . (int) $orderId);
return (bool) \Db::getInstance()->getValue($query);
}
}