forked from 202ecommerce/paypal
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAbstractMethod.php
141 lines (123 loc) · 3.8 KB
/
AbstractMethod.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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
<?php
/*
* Since 2007 PayPal
*
* NOTICE OF LICENSE
*
* This source file is subject to the Academic Free License (AFL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://opensource.org/licenses/afl-3.0.php
* 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.
*
* DISCLAIMER
*
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
* versions in the future. If you wish to customize PrestaShop for your
* needs please refer to http://www.prestashop.com for more information.
*
* @author Since 2007 PayPal
* @author 202 ecommerce <[email protected]>
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
* @copyright PayPal
*
*/
namespace PaypalPPBTlib;
abstract class AbstractMethod
{
/** @var string module name */
public $name = 'paypal';
// Force les classes filles à définir cette méthode
/** @var string payment method */
protected $payment_method;
/** @var array An array of transaction information : method, currency, transaction_id, payment_status, payment_method, id_payment, capture, payment_tool, date_transaction. */
protected $transaction_detail = array();
/** @return string*/
protected function getPaymentMethod()
{
if ((int)\Configuration::get('PAYPAL_SANDBOX')) {
return $this->payment_method . ' - SANDBOX';
} else {
return $this->payment_method;
}
}
/**
* Init payment method
* @return string|array
*/
abstract public function init();
/**
* Validate payment
* @return Exception
*/
abstract public function validation();
/**
* Capture authorized transaction
* @param $orderPayPal PaypalOrder object
* @return array|Exception
*/
abstract public function confirmCapture($orderPayPal);
/**
* Refund settled transaction
* @param $orderPaypal PaypalOrder object
* @return mixed
*/
abstract public function refund($orderPaypal);
/**
* Update configuration (postProcess)
* @param $params array
* @return mixed
*/
abstract public function setConfig($params);
/**
* Generate getContent
* @param Paypal $module
* @return mixed
*/
abstract public function getConfig(\Paypal $module);
/**
* Void authorized transaction (cancel payment)
* @param $orderPaypal PaypalOrder object
* @return mixed
*/
abstract public function void($orderPaypal);
/**
* @param $params array hookActionOrderSlipAdd parameters
* @return mixed
*/
abstract public function partialRefund($params);
/**
* @param string $method method alias like BT, EC, PPP
* @return stdClass Method class
*/
public static function load($method)
{
if (preg_match('/^[a-zA-Z0-9_-]+$/', $method) && file_exists(_PS_MODULE_DIR_.'paypal/classes/Method'.$method.'.php')) {
include_once _PS_MODULE_DIR_.'paypal/classes/Method'.$method.'.php';
$method_class = 'Method'.$method;
return new $method_class();
}
}
/**
* Get Transaction details for order
* @return array
*/
public function getDetailsTransaction()
{
return $this->transaction_detail;
}
/**
* Get Transaction details for order
* @param object $transaction
* @return array
*/
abstract function setDetailsTransaction($transaction);
/**
* Get link to transaction
* @param \PaypalLog $log
* @return string
*/
abstract public function getLinkToTransaction($log);
}