This project does not seem to handle request data directly as such no vulnerable execution paths were found.
include
, or for example
via PHP's auto-loading mechanism.
These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more
1 | <?php |
||
2 | /** |
||
3 | * PayPal Standard Payment Gateway. |
||
4 | * |
||
5 | * Provides a PayPal Standard Payment Gateway. |
||
6 | * |
||
7 | * @class WC_Gateway_Paypal |
||
8 | * @extends WC_Payment_Gateway |
||
9 | * @version 2.3.0 |
||
10 | * @package WooCommerce/Classes/Payment |
||
11 | * @author WooThemes |
||
12 | */ |
||
13 | |||
14 | if ( ! defined( 'ABSPATH' ) ) { |
||
15 | exit; |
||
16 | } |
||
17 | |||
18 | /** |
||
19 | * WC_Gateway_Paypal Class. |
||
20 | */ |
||
21 | class WC_Gateway_Paypal extends WC_Payment_Gateway { |
||
22 | |||
23 | /** @var bool Whether or not logging is enabled */ |
||
24 | public static $log_enabled = false; |
||
25 | |||
26 | /** @var WC_Logger Logger instance */ |
||
27 | public static $log = false; |
||
28 | |||
29 | /** |
||
30 | * Constructor for the gateway. |
||
31 | */ |
||
32 | public function __construct() { |
||
33 | $this->id = 'paypal'; |
||
34 | $this->has_fields = false; |
||
35 | $this->order_button_text = __( 'Proceed to PayPal', 'woocommerce' ); |
||
36 | $this->method_title = __( 'PayPal', 'woocommerce' ); |
||
37 | $this->method_description = sprintf( __( 'PayPal standard sends customers to PayPal to enter their payment information. PayPal IPN requires fsockopen/cURL support to update order statuses after payment. Check the %ssystem status%s page for more details.', 'woocommerce' ), '<a href="' . admin_url( 'admin.php?page=wc-status' ) . '">', '</a>' ); |
||
38 | $this->supports = array( |
||
39 | 'products', |
||
40 | 'refunds' |
||
41 | ); |
||
42 | |||
43 | // Load the settings. |
||
44 | $this->init_form_fields(); |
||
45 | $this->init_settings(); |
||
46 | |||
47 | // Define user set variables. |
||
48 | $this->title = $this->get_option( 'title' ); |
||
49 | $this->description = $this->get_option( 'description' ); |
||
50 | $this->testmode = 'yes' === $this->get_option( 'testmode', 'no' ); |
||
51 | $this->debug = 'yes' === $this->get_option( 'debug', 'no' ); |
||
52 | $this->email = $this->get_option( 'email' ); |
||
53 | $this->receiver_email = $this->get_option( 'receiver_email', $this->email ); |
||
54 | $this->identity_token = $this->get_option( 'identity_token' ); |
||
55 | |||
56 | self::$log_enabled = $this->debug; |
||
57 | |||
58 | add_action( 'woocommerce_update_options_payment_gateways_' . $this->id, array( $this, 'process_admin_options' ) ); |
||
59 | |||
60 | if ( ! $this->is_valid_for_use() ) { |
||
61 | $this->enabled = 'no'; |
||
62 | } else { |
||
63 | include_once( 'includes/class-wc-gateway-paypal-ipn-handler.php' ); |
||
64 | new WC_Gateway_Paypal_IPN_Handler( $this->testmode, $this->receiver_email ); |
||
65 | |||
66 | if ( $this->identity_token ) { |
||
67 | include_once( 'includes/class-wc-gateway-paypal-pdt-handler.php' ); |
||
68 | new WC_Gateway_Paypal_PDT_Handler( $this->testmode, $this->identity_token ); |
||
69 | } |
||
70 | } |
||
71 | } |
||
72 | |||
73 | /** |
||
74 | * Logging method. |
||
75 | * @param string $message |
||
76 | */ |
||
77 | public static function log( $message ) { |
||
78 | if ( self::$log_enabled ) { |
||
79 | if ( empty( self::$log ) ) { |
||
80 | self::$log = new WC_Logger(); |
||
81 | } |
||
82 | self::$log->add( 'paypal', $message ); |
||
83 | } |
||
84 | } |
||
85 | |||
86 | /** |
||
87 | * Get gateway icon. |
||
88 | * @return string |
||
89 | */ |
||
90 | public function get_icon() { |
||
91 | $icon_html = ''; |
||
92 | $icon = (array) $this->get_icon_image( WC()->countries->get_base_country() ); |
||
93 | |||
94 | foreach ( $icon as $i ) { |
||
95 | $icon_html .= '<img src="' . esc_attr( $i ) . '" alt="' . esc_attr__( 'PayPal Acceptance Mark', 'woocommerce' ) . '" />'; |
||
96 | } |
||
97 | |||
98 | $icon_html .= sprintf( '<a href="%1$s" class="about_paypal" onclick="javascript:window.open(\'%1$s\',\'WIPaypal\',\'toolbar=no, location=no, directories=no, status=no, menubar=no, scrollbars=yes, resizable=yes, width=1060, height=700\'); return false;" title="' . esc_attr__( 'What is PayPal?', 'woocommerce' ) . '">' . esc_attr__( 'What is PayPal?', 'woocommerce' ) . '</a>', esc_url( $this->get_icon_url( WC()->countries->get_base_country() ) ) ); |
||
99 | |||
100 | return apply_filters( 'woocommerce_gateway_icon', $icon_html, $this->id ); |
||
101 | } |
||
102 | |||
103 | /** |
||
104 | * Get the link for an icon based on country. |
||
105 | * @param string $country |
||
106 | * @return string |
||
107 | */ |
||
108 | protected function get_icon_url( $country ) { |
||
109 | $url = 'https://www.paypal.com/' . strtolower( $country ); |
||
110 | $home_counties = array( 'BE', 'CZ', 'DK', 'HU', 'IT', 'JP', 'NL', 'NO', 'ES', 'SE', 'TR'); |
||
111 | $countries = array( 'DZ', 'AU', 'BH', 'BQ', 'BW', 'CA', 'CN', 'CW', 'FI', 'FR', 'DE', 'GR', 'HK', 'IN', 'ID', 'JO', 'KE', 'KW', 'LU', 'MY', 'MA', 'OM', 'PH', 'PL', 'PT', 'QA', 'IE', 'RU', 'BL', 'SX', 'MF', 'SA', 'SG', 'SK', 'KR', 'SS', 'TW', 'TH', 'AE', 'GB', 'US', 'VN' ); |
||
112 | |||
113 | if ( in_array( $country, $home_counties ) ) { |
||
114 | return $url . '/webapps/mpp/home'; |
||
115 | } else if ( in_array( $country, $countries ) ) { |
||
116 | return $url . '/webapps/mpp/paypal-popup'; |
||
117 | } else { |
||
118 | return $url . '/cgi-bin/webscr?cmd=xpt/Marketing/general/WIPaypal-outside'; |
||
119 | } |
||
120 | } |
||
121 | |||
122 | /** |
||
123 | * Get PayPal images for a country. |
||
124 | * @param string $country |
||
125 | * @return array of image URLs |
||
126 | */ |
||
127 | protected function get_icon_image( $country ) { |
||
128 | switch ( $country ) { |
||
129 | case 'US' : |
||
130 | case 'NZ' : |
||
131 | case 'CZ' : |
||
132 | case 'HU' : |
||
133 | case 'MY' : |
||
134 | $icon = 'https://www.paypalobjects.com/webstatic/mktg/logo/AM_mc_vs_dc_ae.jpg'; |
||
135 | break; |
||
136 | case 'TR' : |
||
137 | $icon = 'https://www.paypalobjects.com/webstatic/mktg/logo-center/logo_paypal_odeme_secenekleri.jpg'; |
||
138 | break; |
||
139 | case 'GB' : |
||
140 | $icon = 'https://www.paypalobjects.com/webstatic/mktg/Logo/AM_mc_vs_ms_ae_UK.png'; |
||
141 | break; |
||
142 | case 'MX' : |
||
143 | $icon = array( |
||
144 | 'https://www.paypal.com/es_XC/Marketing/i/banner/paypal_visa_mastercard_amex.png', |
||
145 | 'https://www.paypal.com/es_XC/Marketing/i/banner/paypal_debit_card_275x60.gif' |
||
146 | ); |
||
147 | break; |
||
148 | case 'FR' : |
||
149 | $icon = 'https://www.paypalobjects.com/webstatic/mktg/logo-center/logo_paypal_moyens_paiement_fr.jpg'; |
||
150 | break; |
||
151 | case 'AU' : |
||
152 | $icon = 'https://www.paypalobjects.com/webstatic/en_AU/mktg/logo/Solutions-graphics-1-184x80.jpg'; |
||
153 | break; |
||
154 | case 'DK' : |
||
155 | $icon = 'https://www.paypalobjects.com/webstatic/mktg/logo-center/logo_PayPal_betalingsmuligheder_dk.jpg'; |
||
156 | break; |
||
157 | case 'RU' : |
||
158 | $icon = 'https://www.paypalobjects.com/webstatic/ru_RU/mktg/business/pages/logo-center/AM_mc_vs_dc_ae.jpg'; |
||
159 | break; |
||
160 | case 'NO' : |
||
161 | $icon = 'https://www.paypalobjects.com/webstatic/mktg/logo-center/banner_pl_just_pp_319x110.jpg'; |
||
162 | break; |
||
163 | case 'CA' : |
||
164 | $icon = 'https://www.paypalobjects.com/webstatic/en_CA/mktg/logo-image/AM_mc_vs_dc_ae.jpg'; |
||
165 | break; |
||
166 | case 'HK' : |
||
167 | $icon = 'https://www.paypalobjects.com/webstatic/en_HK/mktg/logo/AM_mc_vs_dc_ae.jpg'; |
||
168 | break; |
||
169 | case 'SG' : |
||
170 | $icon = 'https://www.paypalobjects.com/webstatic/en_SG/mktg/Logos/AM_mc_vs_dc_ae.jpg'; |
||
171 | break; |
||
172 | case 'TW' : |
||
173 | $icon = 'https://www.paypalobjects.com/webstatic/en_TW/mktg/logos/AM_mc_vs_dc_ae.jpg'; |
||
174 | break; |
||
175 | case 'TH' : |
||
176 | $icon = 'https://www.paypalobjects.com/webstatic/en_TH/mktg/Logos/AM_mc_vs_dc_ae.jpg'; |
||
177 | break; |
||
178 | case 'JP' : |
||
179 | $icon = 'https://www.paypal.com/ja_JP/JP/i/bnr/horizontal_solution_4_jcb.gif'; |
||
180 | break; |
||
181 | default : |
||
182 | $icon = WC_HTTPS::force_https_url( WC()->plugin_url() . '/includes/gateways/paypal/assets/images/paypal.png' ); |
||
183 | break; |
||
184 | } |
||
185 | return apply_filters( 'woocommerce_paypal_icon', $icon ); |
||
186 | } |
||
187 | |||
188 | /** |
||
189 | * Check if this gateway is enabled and available in the user's country. |
||
190 | * @return bool |
||
191 | */ |
||
192 | public function is_valid_for_use() { |
||
193 | return in_array( get_woocommerce_currency(), apply_filters( 'woocommerce_paypal_supported_currencies', array( 'AUD', 'BRL', 'CAD', 'MXN', 'NZD', 'HKD', 'SGD', 'USD', 'EUR', 'JPY', 'TRY', 'NOK', 'CZK', 'DKK', 'HUF', 'ILS', 'MYR', 'PHP', 'PLN', 'SEK', 'CHF', 'TWD', 'THB', 'GBP', 'RMB', 'RUB' ) ) ); |
||
194 | } |
||
195 | |||
196 | /** |
||
197 | * Admin Panel Options. |
||
198 | * - Options for bits like 'title' and availability on a country-by-country basis. |
||
199 | * |
||
200 | * @since 1.0.0 |
||
201 | */ |
||
202 | public function admin_options() { |
||
203 | if ( $this->is_valid_for_use() ) { |
||
204 | parent::admin_options(); |
||
205 | } else { |
||
206 | ?> |
||
207 | <div class="inline error"><p><strong><?php _e( 'Gateway Disabled', 'woocommerce' ); ?></strong>: <?php _e( 'PayPal does not support your store currency.', 'woocommerce' ); ?></p></div> |
||
208 | <?php |
||
209 | } |
||
210 | } |
||
211 | |||
212 | /** |
||
213 | * Initialise Gateway Settings Form Fields. |
||
214 | */ |
||
215 | public function init_form_fields() { |
||
216 | $this->form_fields = include( 'includes/settings-paypal.php' ); |
||
217 | } |
||
218 | |||
219 | /** |
||
220 | * Get the transaction URL. |
||
221 | * @param WC_Order $order |
||
222 | * @return string |
||
223 | */ |
||
224 | public function get_transaction_url( $order ) { |
||
225 | if ( $this->testmode ) { |
||
226 | $this->view_transaction_url = 'https://www.sandbox.paypal.com/cgi-bin/webscr?cmd=_view-a-trans&id=%s'; |
||
227 | } else { |
||
228 | $this->view_transaction_url = 'https://www.paypal.com/cgi-bin/webscr?cmd=_view-a-trans&id=%s'; |
||
229 | } |
||
230 | return parent::get_transaction_url( $order ); |
||
231 | } |
||
232 | |||
233 | /** |
||
234 | * Process the payment and return the result. |
||
235 | * @param int $order_id |
||
236 | * @return array |
||
237 | */ |
||
238 | public function process_payment( $order_id ) { |
||
239 | include_once( 'includes/class-wc-gateway-paypal-request.php' ); |
||
240 | |||
241 | $order = wc_get_order( $order_id ); |
||
242 | $paypal_request = new WC_Gateway_Paypal_Request( $this ); |
||
243 | |||
244 | return array( |
||
245 | 'result' => 'success', |
||
246 | 'redirect' => $paypal_request->get_request_url( $order, $this->testmode ) |
||
0 ignored issues
–
show
|
|||
247 | ); |
||
248 | } |
||
249 | |||
250 | /** |
||
251 | * Can the order be refunded via PayPal? |
||
252 | * @param WC_Order $order |
||
253 | * @return bool |
||
254 | */ |
||
255 | public function can_refund_order( $order ) { |
||
256 | return $order && $order->get_transaction_id(); |
||
257 | } |
||
258 | |||
259 | /** |
||
260 | * Process a refund if supported. |
||
261 | * @param int $order_id |
||
262 | * @param float $amount |
||
263 | * @param string $reason |
||
264 | * @return bool True or false based on success, or a WP_Error object |
||
265 | */ |
||
266 | public function process_refund( $order_id, $amount = null, $reason = '' ) { |
||
267 | $order = wc_get_order( $order_id ); |
||
268 | |||
269 | if ( ! $this->can_refund_order( $order ) ) { |
||
0 ignored issues
–
show
$order is of type false|object , but the function expects a object<WC_Order> .
It seems like the type of the argument is not accepted by the function/method which you are calling. In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug. We suggest to add an explicit type cast like in the following example: function acceptsInteger($int) { }
$x = '123'; // string "123"
// Instead of
acceptsInteger($x);
// we recommend to use
acceptsInteger((integer) $x);
![]() |
|||
270 | $this->log( 'Refund Failed: No transaction ID' ); |
||
271 | return new WP_Error( 'error', __( 'Refund Failed: No transaction ID', 'woocommerce' ) ); |
||
272 | } |
||
273 | |||
274 | include_once( 'includes/class-wc-gateway-paypal-refund.php' ); |
||
275 | |||
276 | WC_Gateway_Paypal_Refund::$api_username = $this->get_option( 'api_username' ); |
||
277 | WC_Gateway_Paypal_Refund::$api_password = $this->get_option( 'api_password' ); |
||
278 | WC_Gateway_Paypal_Refund::$api_signature = $this->get_option( 'api_signature' ); |
||
279 | |||
280 | $result = WC_Gateway_Paypal_Refund::refund_order( $order, $amount, $reason, $this->testmode ); |
||
0 ignored issues
–
show
$order is of type false|object , but the function expects a object<WC_Order> .
It seems like the type of the argument is not accepted by the function/method which you are calling. In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug. We suggest to add an explicit type cast like in the following example: function acceptsInteger($int) { }
$x = '123'; // string "123"
// Instead of
acceptsInteger($x);
// we recommend to use
acceptsInteger((integer) $x);
![]() |
|||
281 | |||
282 | if ( is_wp_error( $result ) ) { |
||
283 | $this->log( 'Refund Failed: ' . $result->get_error_message() ); |
||
284 | return new WP_Error( 'error', $result->get_error_message() ); |
||
285 | } |
||
286 | |||
287 | $this->log( 'Refund Result: ' . print_r( $result, true ) ); |
||
288 | |||
289 | switch ( strtolower( $result['ACK'] ) ) { |
||
290 | case 'success': |
||
291 | case 'successwithwarning': |
||
292 | $order->add_order_note( sprintf( __( 'Refunded %s - Refund ID: %s', 'woocommerce' ), $result['GROSSREFUNDAMT'], $result['REFUNDTRANSACTIONID'] ) ); |
||
293 | return true; |
||
294 | break; |
||
0 ignored issues
–
show
break is not strictly necessary here and could be removed.
The break statement is not necessary if it is preceded for example by a return statement: switch ($x) {
case 1:
return 'foo';
break; // This break is not necessary and can be left off.
}
If you would like to keep this construct to be consistent with other case statements, you can safely mark this issue as a false-positive. ![]() |
|||
295 | } |
||
296 | |||
297 | return isset( $result['L_LONGMESSAGE0'] ) ? new WP_Error( 'error', $result['L_LONGMESSAGE0'] ) : false; |
||
298 | } |
||
299 | } |
||
300 |
It seems like the type of the argument is not accepted by the function/method which you are calling.
In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug.
We suggest to add an explicit type cast like in the following example: