@@ -231,7 +231,7 @@ |
||
231 | 231 | * List of currencies supported by Stripe that has no decimals |
232 | 232 | * https://stripe.com/docs/currencies#zero-decimal from https://stripe.com/docs/currencies#presentment-currencies |
233 | 233 | * |
234 | - * @return array $currencies |
|
234 | + * @return string[] $currencies |
|
235 | 235 | */ |
236 | 236 | public static function no_decimal_currencies() { |
237 | 237 | return array( |
@@ -1,5 +1,5 @@ discard block |
||
1 | 1 | <?php |
2 | -if ( ! defined( 'ABSPATH' ) ) { |
|
2 | +if ( ! defined('ABSPATH')) { |
|
3 | 3 | exit; |
4 | 4 | } |
5 | 5 | |
@@ -22,14 +22,14 @@ discard block |
||
22 | 22 | * @param object $order |
23 | 23 | * @return string $currency |
24 | 24 | */ |
25 | - public static function get_stripe_currency( $order = null ) { |
|
26 | - if ( is_null( $order ) ) { |
|
25 | + public static function get_stripe_currency($order = null) { |
|
26 | + if (is_null($order)) { |
|
27 | 27 | return false; |
28 | 28 | } |
29 | 29 | |
30 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
30 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
31 | 31 | |
32 | - return WC_Stripe_Helper::is_wc_lt( '3.0' ) ? get_post_meta( $order_id, self::META_NAME_STRIPE_CURRENCY, true ) : $order->get_meta( self::META_NAME_STRIPE_CURRENCY, true ); |
|
32 | + return WC_Stripe_Helper::is_wc_lt('3.0') ? get_post_meta($order_id, self::META_NAME_STRIPE_CURRENCY, true) : $order->get_meta(self::META_NAME_STRIPE_CURRENCY, true); |
|
33 | 33 | } |
34 | 34 | |
35 | 35 | /** |
@@ -39,14 +39,14 @@ discard block |
||
39 | 39 | * @param object $order |
40 | 40 | * @param string $currency |
41 | 41 | */ |
42 | - public static function update_stripe_currency( $order = null, $currency ) { |
|
43 | - if ( is_null( $order ) ) { |
|
42 | + public static function update_stripe_currency($order = null, $currency) { |
|
43 | + if (is_null($order)) { |
|
44 | 44 | return false; |
45 | 45 | } |
46 | 46 | |
47 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
47 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
48 | 48 | |
49 | - WC_Stripe_Helper::is_wc_lt( '3.0' ) ? update_post_meta( $order_id, self::META_NAME_STRIPE_CURRENCY, $currency ) : $order->update_meta_data( self::META_NAME_STRIPE_CURRENCY, $currency ); |
|
49 | + WC_Stripe_Helper::is_wc_lt('3.0') ? update_post_meta($order_id, self::META_NAME_STRIPE_CURRENCY, $currency) : $order->update_meta_data(self::META_NAME_STRIPE_CURRENCY, $currency); |
|
50 | 50 | } |
51 | 51 | |
52 | 52 | /** |
@@ -56,22 +56,22 @@ discard block |
||
56 | 56 | * @param object $order |
57 | 57 | * @return string $amount |
58 | 58 | */ |
59 | - public static function get_stripe_fee( $order = null ) { |
|
60 | - if ( is_null( $order ) ) { |
|
59 | + public static function get_stripe_fee($order = null) { |
|
60 | + if (is_null($order)) { |
|
61 | 61 | return false; |
62 | 62 | } |
63 | 63 | |
64 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
64 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
65 | 65 | |
66 | - $amount = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? get_post_meta( $order_id, self::META_NAME_FEE, true ) : $order->get_meta( self::META_NAME_FEE, true ); |
|
66 | + $amount = WC_Stripe_Helper::is_wc_lt('3.0') ? get_post_meta($order_id, self::META_NAME_FEE, true) : $order->get_meta(self::META_NAME_FEE, true); |
|
67 | 67 | |
68 | 68 | // If not found let's check for legacy name. |
69 | - if ( empty( $amount ) ) { |
|
70 | - $amount = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? get_post_meta( $order_id, self::LEGACY_META_NAME_FEE, true ) : $order->get_meta( self::LEGACY_META_NAME_FEE, true ); |
|
69 | + if (empty($amount)) { |
|
70 | + $amount = WC_Stripe_Helper::is_wc_lt('3.0') ? get_post_meta($order_id, self::LEGACY_META_NAME_FEE, true) : $order->get_meta(self::LEGACY_META_NAME_FEE, true); |
|
71 | 71 | |
72 | 72 | // If found update to new name. |
73 | - if ( $amount ) { |
|
74 | - self::update_stripe_fee( $order, $amount ); |
|
73 | + if ($amount) { |
|
74 | + self::update_stripe_fee($order, $amount); |
|
75 | 75 | } |
76 | 76 | } |
77 | 77 | |
@@ -85,14 +85,14 @@ discard block |
||
85 | 85 | * @param object $order |
86 | 86 | * @param float $amount |
87 | 87 | */ |
88 | - public static function update_stripe_fee( $order = null, $amount = 0.0 ) { |
|
89 | - if ( is_null( $order ) ) { |
|
88 | + public static function update_stripe_fee($order = null, $amount = 0.0) { |
|
89 | + if (is_null($order)) { |
|
90 | 90 | return false; |
91 | 91 | } |
92 | 92 | |
93 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
93 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
94 | 94 | |
95 | - WC_Stripe_Helper::is_wc_lt( '3.0' ) ? update_post_meta( $order_id, self::META_NAME_FEE, $amount ) : $order->update_meta_data( self::META_NAME_FEE, $amount ); |
|
95 | + WC_Stripe_Helper::is_wc_lt('3.0') ? update_post_meta($order_id, self::META_NAME_FEE, $amount) : $order->update_meta_data(self::META_NAME_FEE, $amount); |
|
96 | 96 | } |
97 | 97 | |
98 | 98 | /** |
@@ -101,15 +101,15 @@ discard block |
||
101 | 101 | * @since 4.1.0 |
102 | 102 | * @param object $order |
103 | 103 | */ |
104 | - public static function delete_stripe_fee( $order = null ) { |
|
105 | - if ( is_null( $order ) ) { |
|
104 | + public static function delete_stripe_fee($order = null) { |
|
105 | + if (is_null($order)) { |
|
106 | 106 | return false; |
107 | 107 | } |
108 | 108 | |
109 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
109 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
110 | 110 | |
111 | - delete_post_meta( $order_id, self::META_NAME_FEE ); |
|
112 | - delete_post_meta( $order_id, self::LEGACY_META_NAME_FEE ); |
|
111 | + delete_post_meta($order_id, self::META_NAME_FEE); |
|
112 | + delete_post_meta($order_id, self::LEGACY_META_NAME_FEE); |
|
113 | 113 | } |
114 | 114 | |
115 | 115 | /** |
@@ -119,22 +119,22 @@ discard block |
||
119 | 119 | * @param object $order |
120 | 120 | * @return string $amount |
121 | 121 | */ |
122 | - public static function get_stripe_net( $order = null ) { |
|
123 | - if ( is_null( $order ) ) { |
|
122 | + public static function get_stripe_net($order = null) { |
|
123 | + if (is_null($order)) { |
|
124 | 124 | return false; |
125 | 125 | } |
126 | 126 | |
127 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
127 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
128 | 128 | |
129 | - $amount = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? get_post_meta( $order_id, self::META_NAME_NET, true ) : $order->get_meta( self::META_NAME_NET, true ); |
|
129 | + $amount = WC_Stripe_Helper::is_wc_lt('3.0') ? get_post_meta($order_id, self::META_NAME_NET, true) : $order->get_meta(self::META_NAME_NET, true); |
|
130 | 130 | |
131 | 131 | // If not found let's check for legacy name. |
132 | - if ( empty( $amount ) ) { |
|
133 | - $amount = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? get_post_meta( $order_id, self::LEGACY_META_NAME_NET, true ) : $order->get_meta( self::LEGACY_META_NAME_NET, true ); |
|
132 | + if (empty($amount)) { |
|
133 | + $amount = WC_Stripe_Helper::is_wc_lt('3.0') ? get_post_meta($order_id, self::LEGACY_META_NAME_NET, true) : $order->get_meta(self::LEGACY_META_NAME_NET, true); |
|
134 | 134 | |
135 | 135 | // If found update to new name. |
136 | - if ( $amount ) { |
|
137 | - self::update_stripe_net( $order, $amount ); |
|
136 | + if ($amount) { |
|
137 | + self::update_stripe_net($order, $amount); |
|
138 | 138 | } |
139 | 139 | } |
140 | 140 | |
@@ -148,14 +148,14 @@ discard block |
||
148 | 148 | * @param object $order |
149 | 149 | * @param float $amount |
150 | 150 | */ |
151 | - public static function update_stripe_net( $order = null, $amount = 0.0 ) { |
|
152 | - if ( is_null( $order ) ) { |
|
151 | + public static function update_stripe_net($order = null, $amount = 0.0) { |
|
152 | + if (is_null($order)) { |
|
153 | 153 | return false; |
154 | 154 | } |
155 | 155 | |
156 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
156 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
157 | 157 | |
158 | - WC_Stripe_Helper::is_wc_lt( '3.0' ) ? update_post_meta( $order_id, self::META_NAME_NET, $amount ) : $order->update_meta_data( self::META_NAME_NET, $amount ); |
|
158 | + WC_Stripe_Helper::is_wc_lt('3.0') ? update_post_meta($order_id, self::META_NAME_NET, $amount) : $order->update_meta_data(self::META_NAME_NET, $amount); |
|
159 | 159 | } |
160 | 160 | |
161 | 161 | /** |
@@ -164,15 +164,15 @@ discard block |
||
164 | 164 | * @since 4.1.0 |
165 | 165 | * @param object $order |
166 | 166 | */ |
167 | - public static function delete_stripe_net( $order = null ) { |
|
168 | - if ( is_null( $order ) ) { |
|
167 | + public static function delete_stripe_net($order = null) { |
|
168 | + if (is_null($order)) { |
|
169 | 169 | return false; |
170 | 170 | } |
171 | 171 | |
172 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
172 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
173 | 173 | |
174 | - delete_post_meta( $order_id, self::META_NAME_NET ); |
|
175 | - delete_post_meta( $order_id, self::LEGACY_META_NAME_NET ); |
|
174 | + delete_post_meta($order_id, self::META_NAME_NET); |
|
175 | + delete_post_meta($order_id, self::LEGACY_META_NAME_NET); |
|
176 | 176 | } |
177 | 177 | |
178 | 178 | /** |
@@ -183,15 +183,15 @@ discard block |
||
183 | 183 | * |
184 | 184 | * @return float|int |
185 | 185 | */ |
186 | - public static function get_stripe_amount( $total, $currency = '' ) { |
|
187 | - if ( ! $currency ) { |
|
186 | + public static function get_stripe_amount($total, $currency = '') { |
|
187 | + if ( ! $currency) { |
|
188 | 188 | $currency = get_woocommerce_currency(); |
189 | 189 | } |
190 | 190 | |
191 | - if ( in_array( strtolower( $currency ), self::no_decimal_currencies() ) ) { |
|
192 | - return absint( $total ); |
|
191 | + if (in_array(strtolower($currency), self::no_decimal_currencies())) { |
|
192 | + return absint($total); |
|
193 | 193 | } else { |
194 | - return absint( wc_format_decimal( ( (float) $total * 100 ), wc_get_price_decimals() ) ); // In cents. |
|
194 | + return absint(wc_format_decimal(((float) $total * 100), wc_get_price_decimals())); // In cents. |
|
195 | 195 | } |
196 | 196 | } |
197 | 197 | |
@@ -206,24 +206,24 @@ discard block |
||
206 | 206 | return apply_filters( |
207 | 207 | 'wc_stripe_localized_messages', |
208 | 208 | array( |
209 | - 'invalid_number' => __( 'The card number is not a valid credit card number.', 'woocommerce-gateway-stripe' ), |
|
210 | - 'invalid_expiry_month' => __( 'The card\'s expiration month is invalid.', 'woocommerce-gateway-stripe' ), |
|
211 | - 'invalid_expiry_year' => __( 'The card\'s expiration year is invalid.', 'woocommerce-gateway-stripe' ), |
|
212 | - 'invalid_cvc' => __( 'The card\'s security code is invalid.', 'woocommerce-gateway-stripe' ), |
|
213 | - 'incorrect_number' => __( 'The card number is incorrect.', 'woocommerce-gateway-stripe' ), |
|
214 | - 'incomplete_number' => __( 'The card number is incomplete.', 'woocommerce-gateway-stripe' ), |
|
215 | - 'incomplete_cvc' => __( 'The card\'s security code is incomplete.', 'woocommerce-gateway-stripe' ), |
|
216 | - 'incomplete_expiry' => __( 'The card\'s expiration date is incomplete.', 'woocommerce-gateway-stripe' ), |
|
217 | - 'expired_card' => __( 'The card has expired.', 'woocommerce-gateway-stripe' ), |
|
218 | - 'incorrect_cvc' => __( 'The card\'s security code is incorrect.', 'woocommerce-gateway-stripe' ), |
|
219 | - 'incorrect_zip' => __( 'The card\'s zip code failed validation.', 'woocommerce-gateway-stripe' ), |
|
220 | - 'invalid_expiry_year_past' => __( 'The card\'s expiration year is in the past', 'woocommerce-gateway-stripe' ), |
|
221 | - 'card_declined' => __( 'The card was declined.', 'woocommerce-gateway-stripe' ), |
|
222 | - 'missing' => __( 'There is no card on a customer that is being charged.', 'woocommerce-gateway-stripe' ), |
|
223 | - 'processing_error' => __( 'An error occurred while processing the card.', 'woocommerce-gateway-stripe' ), |
|
224 | - 'invalid_request_error' => __( 'Unable to process this payment, please try again or use alternative method.', 'woocommerce-gateway-stripe' ), |
|
225 | - 'invalid_sofort_country' => __( 'The billing country is not accepted by SOFORT. Please try another country.', 'woocommerce-gateway-stripe' ), |
|
226 | - 'email_invalid' => __( 'Invalid email address, please correct and try again.', 'woocommerce-gateway-stripe' ), |
|
209 | + 'invalid_number' => __('The card number is not a valid credit card number.', 'woocommerce-gateway-stripe'), |
|
210 | + 'invalid_expiry_month' => __('The card\'s expiration month is invalid.', 'woocommerce-gateway-stripe'), |
|
211 | + 'invalid_expiry_year' => __('The card\'s expiration year is invalid.', 'woocommerce-gateway-stripe'), |
|
212 | + 'invalid_cvc' => __('The card\'s security code is invalid.', 'woocommerce-gateway-stripe'), |
|
213 | + 'incorrect_number' => __('The card number is incorrect.', 'woocommerce-gateway-stripe'), |
|
214 | + 'incomplete_number' => __('The card number is incomplete.', 'woocommerce-gateway-stripe'), |
|
215 | + 'incomplete_cvc' => __('The card\'s security code is incomplete.', 'woocommerce-gateway-stripe'), |
|
216 | + 'incomplete_expiry' => __('The card\'s expiration date is incomplete.', 'woocommerce-gateway-stripe'), |
|
217 | + 'expired_card' => __('The card has expired.', 'woocommerce-gateway-stripe'), |
|
218 | + 'incorrect_cvc' => __('The card\'s security code is incorrect.', 'woocommerce-gateway-stripe'), |
|
219 | + 'incorrect_zip' => __('The card\'s zip code failed validation.', 'woocommerce-gateway-stripe'), |
|
220 | + 'invalid_expiry_year_past' => __('The card\'s expiration year is in the past', 'woocommerce-gateway-stripe'), |
|
221 | + 'card_declined' => __('The card was declined.', 'woocommerce-gateway-stripe'), |
|
222 | + 'missing' => __('There is no card on a customer that is being charged.', 'woocommerce-gateway-stripe'), |
|
223 | + 'processing_error' => __('An error occurred while processing the card.', 'woocommerce-gateway-stripe'), |
|
224 | + 'invalid_request_error' => __('Unable to process this payment, please try again or use alternative method.', 'woocommerce-gateway-stripe'), |
|
225 | + 'invalid_sofort_country' => __('The billing country is not accepted by SOFORT. Please try another country.', 'woocommerce-gateway-stripe'), |
|
226 | + 'email_invalid' => __('Invalid email address, please correct and try again.', 'woocommerce-gateway-stripe'), |
|
227 | 227 | ) |
228 | 228 | ); |
229 | 229 | } |
@@ -264,24 +264,24 @@ discard block |
||
264 | 264 | * @param string $type Type of number to format |
265 | 265 | * @return string |
266 | 266 | */ |
267 | - public static function format_balance_fee( $balance_transaction, $type = 'fee' ) { |
|
268 | - if ( ! is_object( $balance_transaction ) ) { |
|
267 | + public static function format_balance_fee($balance_transaction, $type = 'fee') { |
|
268 | + if ( ! is_object($balance_transaction)) { |
|
269 | 269 | return; |
270 | 270 | } |
271 | 271 | |
272 | - if ( in_array( strtolower( $balance_transaction->currency ), self::no_decimal_currencies() ) ) { |
|
273 | - if ( 'fee' === $type ) { |
|
272 | + if (in_array(strtolower($balance_transaction->currency), self::no_decimal_currencies())) { |
|
273 | + if ('fee' === $type) { |
|
274 | 274 | return $balance_transaction->fee; |
275 | 275 | } |
276 | 276 | |
277 | 277 | return $balance_transaction->net; |
278 | 278 | } |
279 | 279 | |
280 | - if ( 'fee' === $type ) { |
|
281 | - return number_format( $balance_transaction->fee / 100, 2, '.', '' ); |
|
280 | + if ('fee' === $type) { |
|
281 | + return number_format($balance_transaction->fee / 100, 2, '.', ''); |
|
282 | 282 | } |
283 | 283 | |
284 | - return number_format( $balance_transaction->net / 100, 2, '.', '' ); |
|
284 | + return number_format($balance_transaction->net / 100, 2, '.', ''); |
|
285 | 285 | } |
286 | 286 | |
287 | 287 | /** |
@@ -289,7 +289,7 @@ discard block |
||
289 | 289 | */ |
290 | 290 | public static function get_minimum_amount() { |
291 | 291 | // Check order amount |
292 | - switch ( get_woocommerce_currency() ) { |
|
292 | + switch (get_woocommerce_currency()) { |
|
293 | 293 | case 'USD': |
294 | 294 | case 'CAD': |
295 | 295 | case 'EUR': |
@@ -334,14 +334,14 @@ discard block |
||
334 | 334 | * @param string $method The payment method to get the settings from. |
335 | 335 | * @param string $setting The name of the setting to get. |
336 | 336 | */ |
337 | - public static function get_settings( $method = null, $setting = null ) { |
|
338 | - $all_settings = null === $method ? get_option( 'woocommerce_stripe_settings', array() ) : get_option( 'woocommerce_stripe_' . $method . '_settings', array() ); |
|
337 | + public static function get_settings($method = null, $setting = null) { |
|
338 | + $all_settings = null === $method ? get_option('woocommerce_stripe_settings', array()) : get_option('woocommerce_stripe_' . $method . '_settings', array()); |
|
339 | 339 | |
340 | - if ( null === $setting ) { |
|
340 | + if (null === $setting) { |
|
341 | 341 | return $all_settings; |
342 | 342 | } |
343 | 343 | |
344 | - return isset( $all_settings[ $setting ] ) ? $all_settings[ $setting ] : ''; |
|
344 | + return isset($all_settings[$setting]) ? $all_settings[$setting] : ''; |
|
345 | 345 | } |
346 | 346 | |
347 | 347 | /** |
@@ -351,7 +351,7 @@ discard block |
||
351 | 351 | * @return bool |
352 | 352 | */ |
353 | 353 | public static function is_pre_orders_exists() { |
354 | - return class_exists( 'WC_Pre_Orders_Order' ); |
|
354 | + return class_exists('WC_Pre_Orders_Order'); |
|
355 | 355 | } |
356 | 356 | |
357 | 357 | /** |
@@ -363,9 +363,9 @@ discard block |
||
363 | 363 | * @return bool |
364 | 364 | */ |
365 | 365 | public static function is_pre_30() { |
366 | - error_log( 'is_pre_30() function has been deprecated since 4.1.11. Please use is_wc_lt( $version ) instead.' ); |
|
366 | + error_log('is_pre_30() function has been deprecated since 4.1.11. Please use is_wc_lt( $version ) instead.'); |
|
367 | 367 | |
368 | - return self::is_wc_lt( '3.0' ); |
|
368 | + return self::is_wc_lt('3.0'); |
|
369 | 369 | } |
370 | 370 | |
371 | 371 | /** |
@@ -375,8 +375,8 @@ discard block |
||
375 | 375 | * @param string $version Version to check against. |
376 | 376 | * @return bool |
377 | 377 | */ |
378 | - public static function is_wc_lt( $version ) { |
|
379 | - return version_compare( WC_VERSION, $version, '<' ); |
|
378 | + public static function is_wc_lt($version) { |
|
379 | + return version_compare(WC_VERSION, $version, '<'); |
|
380 | 380 | } |
381 | 381 | |
382 | 382 | /** |
@@ -389,7 +389,7 @@ discard block |
||
389 | 389 | * @return string |
390 | 390 | */ |
391 | 391 | public static function get_webhook_url() { |
392 | - return add_query_arg( 'wc-api', 'wc_stripe', trailingslashit( get_home_url() ) ); |
|
392 | + return add_query_arg('wc-api', 'wc_stripe', trailingslashit(get_home_url())); |
|
393 | 393 | } |
394 | 394 | |
395 | 395 | /** |
@@ -399,13 +399,13 @@ discard block |
||
399 | 399 | * @version 4.0.0 |
400 | 400 | * @param string $source_id |
401 | 401 | */ |
402 | - public static function get_order_by_source_id( $source_id ) { |
|
402 | + public static function get_order_by_source_id($source_id) { |
|
403 | 403 | global $wpdb; |
404 | 404 | |
405 | - $order_id = $wpdb->get_var( $wpdb->prepare( "SELECT DISTINCT ID FROM $wpdb->posts as posts LEFT JOIN $wpdb->postmeta as meta ON posts.ID = meta.post_id WHERE meta.meta_value = %s AND meta.meta_key = %s", $source_id, '_stripe_source_id' ) ); |
|
405 | + $order_id = $wpdb->get_var($wpdb->prepare("SELECT DISTINCT ID FROM $wpdb->posts as posts LEFT JOIN $wpdb->postmeta as meta ON posts.ID = meta.post_id WHERE meta.meta_value = %s AND meta.meta_key = %s", $source_id, '_stripe_source_id')); |
|
406 | 406 | |
407 | - if ( ! empty( $order_id ) ) { |
|
408 | - return wc_get_order( $order_id ); |
|
407 | + if ( ! empty($order_id)) { |
|
408 | + return wc_get_order($order_id); |
|
409 | 409 | } |
410 | 410 | |
411 | 411 | return false; |
@@ -418,17 +418,17 @@ discard block |
||
418 | 418 | * @since 4.1.16 Return false if charge_id is empty. |
419 | 419 | * @param string $charge_id |
420 | 420 | */ |
421 | - public static function get_order_by_charge_id( $charge_id ) { |
|
421 | + public static function get_order_by_charge_id($charge_id) { |
|
422 | 422 | global $wpdb; |
423 | 423 | |
424 | - if ( empty( $charge_id ) ) { |
|
424 | + if (empty($charge_id)) { |
|
425 | 425 | return false; |
426 | 426 | } |
427 | 427 | |
428 | - $order_id = $wpdb->get_var( $wpdb->prepare( "SELECT DISTINCT ID FROM $wpdb->posts as posts LEFT JOIN $wpdb->postmeta as meta ON posts.ID = meta.post_id WHERE meta.meta_value = %s AND meta.meta_key = %s", $charge_id, '_transaction_id' ) ); |
|
428 | + $order_id = $wpdb->get_var($wpdb->prepare("SELECT DISTINCT ID FROM $wpdb->posts as posts LEFT JOIN $wpdb->postmeta as meta ON posts.ID = meta.post_id WHERE meta.meta_value = %s AND meta.meta_key = %s", $charge_id, '_transaction_id')); |
|
429 | 429 | |
430 | - if ( ! empty( $order_id ) ) { |
|
431 | - return wc_get_order( $order_id ); |
|
430 | + if ( ! empty($order_id)) { |
|
431 | + return wc_get_order($order_id); |
|
432 | 432 | } |
433 | 433 | |
434 | 434 | return false; |
@@ -441,13 +441,13 @@ discard block |
||
441 | 441 | * @param string $intent_id The ID of the intent. |
442 | 442 | * @return WC_Order|bool Either an order or false when not found. |
443 | 443 | */ |
444 | - public static function get_order_by_intent_id( $intent_id ) { |
|
444 | + public static function get_order_by_intent_id($intent_id) { |
|
445 | 445 | global $wpdb; |
446 | 446 | |
447 | - $order_id = $wpdb->get_var( $wpdb->prepare( "SELECT DISTINCT ID FROM $wpdb->posts as posts LEFT JOIN $wpdb->postmeta as meta ON posts.ID = meta.post_id WHERE meta.meta_value = %s AND meta.meta_key = %s", $intent_id, '_stripe_intent_id' ) ); |
|
447 | + $order_id = $wpdb->get_var($wpdb->prepare("SELECT DISTINCT ID FROM $wpdb->posts as posts LEFT JOIN $wpdb->postmeta as meta ON posts.ID = meta.post_id WHERE meta.meta_value = %s AND meta.meta_key = %s", $intent_id, '_stripe_intent_id')); |
|
448 | 448 | |
449 | - if ( ! empty( $order_id ) ) { |
|
450 | - return wc_get_order( $order_id ); |
|
449 | + if ( ! empty($order_id)) { |
|
450 | + return wc_get_order($order_id); |
|
451 | 451 | } |
452 | 452 | |
453 | 453 | return false; |
@@ -460,13 +460,13 @@ discard block |
||
460 | 460 | * @param string $intent_id The ID of the intent. |
461 | 461 | * @return WC_Order|bool Either an order or false when not found. |
462 | 462 | */ |
463 | - public static function get_order_by_setup_intent_id( $intent_id ) { |
|
463 | + public static function get_order_by_setup_intent_id($intent_id) { |
|
464 | 464 | global $wpdb; |
465 | 465 | |
466 | - $order_id = $wpdb->get_var( $wpdb->prepare( "SELECT DISTINCT ID FROM $wpdb->posts as posts LEFT JOIN $wpdb->postmeta as meta ON posts.ID = meta.post_id WHERE meta.meta_value = %s AND meta.meta_key = %s", $intent_id, '_stripe_setup_intent' ) ); |
|
466 | + $order_id = $wpdb->get_var($wpdb->prepare("SELECT DISTINCT ID FROM $wpdb->posts as posts LEFT JOIN $wpdb->postmeta as meta ON posts.ID = meta.post_id WHERE meta.meta_value = %s AND meta.meta_key = %s", $intent_id, '_stripe_setup_intent')); |
|
467 | 467 | |
468 | - if ( ! empty( $order_id ) ) { |
|
469 | - return wc_get_order( $order_id ); |
|
468 | + if ( ! empty($order_id)) { |
|
469 | + return wc_get_order($order_id); |
|
470 | 470 | } |
471 | 471 | |
472 | 472 | return false; |
@@ -482,13 +482,13 @@ discard block |
||
482 | 482 | * @param string $statement_descriptor |
483 | 483 | * @return string $statement_descriptor Sanitized statement descriptor |
484 | 484 | */ |
485 | - public static function clean_statement_descriptor( $statement_descriptor = '' ) { |
|
486 | - $disallowed_characters = array( '<', '>', '"', "'" ); |
|
485 | + public static function clean_statement_descriptor($statement_descriptor = '') { |
|
486 | + $disallowed_characters = array('<', '>', '"', "'"); |
|
487 | 487 | |
488 | 488 | // Remove special characters. |
489 | - $statement_descriptor = str_replace( $disallowed_characters, '', $statement_descriptor ); |
|
489 | + $statement_descriptor = str_replace($disallowed_characters, '', $statement_descriptor); |
|
490 | 490 | |
491 | - $statement_descriptor = substr( trim( $statement_descriptor ), 0, 22 ); |
|
491 | + $statement_descriptor = substr(trim($statement_descriptor), 0, 22); |
|
492 | 492 | |
493 | 493 | return $statement_descriptor; |
494 | 494 | } |
@@ -1,5 +1,5 @@ discard block |
||
1 | 1 | <?php |
2 | -if ( ! defined( 'ABSPATH' ) ) { |
|
2 | +if ( ! defined('ABSPATH')) { |
|
3 | 3 | exit; |
4 | 4 | } |
5 | 5 | |
@@ -7,160 +7,160 @@ discard block |
||
7 | 7 | 'wc_stripe_settings', |
8 | 8 | array( |
9 | 9 | 'enabled' => array( |
10 | - 'title' => __( 'Enable/Disable', 'woocommerce-gateway-stripe' ), |
|
11 | - 'label' => __( 'Enable Stripe', 'woocommerce-gateway-stripe' ), |
|
10 | + 'title' => __('Enable/Disable', 'woocommerce-gateway-stripe'), |
|
11 | + 'label' => __('Enable Stripe', 'woocommerce-gateway-stripe'), |
|
12 | 12 | 'type' => 'checkbox', |
13 | 13 | 'description' => '', |
14 | 14 | 'default' => 'no', |
15 | 15 | ), |
16 | 16 | 'title' => array( |
17 | - 'title' => __( 'Title', 'woocommerce-gateway-stripe' ), |
|
17 | + 'title' => __('Title', 'woocommerce-gateway-stripe'), |
|
18 | 18 | 'type' => 'text', |
19 | - 'description' => __( 'This controls the title which the user sees during checkout.', 'woocommerce-gateway-stripe' ), |
|
20 | - 'default' => __( 'Credit Card (Stripe)', 'woocommerce-gateway-stripe' ), |
|
19 | + 'description' => __('This controls the title which the user sees during checkout.', 'woocommerce-gateway-stripe'), |
|
20 | + 'default' => __('Credit Card (Stripe)', 'woocommerce-gateway-stripe'), |
|
21 | 21 | 'desc_tip' => true, |
22 | 22 | ), |
23 | 23 | 'description' => array( |
24 | - 'title' => __( 'Description', 'woocommerce-gateway-stripe' ), |
|
24 | + 'title' => __('Description', 'woocommerce-gateway-stripe'), |
|
25 | 25 | 'type' => 'text', |
26 | - 'description' => __( 'This controls the description which the user sees during checkout.', 'woocommerce-gateway-stripe' ), |
|
27 | - 'default' => __( 'Pay with your credit card via Stripe.', 'woocommerce-gateway-stripe' ), |
|
26 | + 'description' => __('This controls the description which the user sees during checkout.', 'woocommerce-gateway-stripe'), |
|
27 | + 'default' => __('Pay with your credit card via Stripe.', 'woocommerce-gateway-stripe'), |
|
28 | 28 | 'desc_tip' => true, |
29 | 29 | ), |
30 | 30 | 'webhook' => array( |
31 | - 'title' => __( 'Webhook Endpoints', 'woocommerce-gateway-stripe' ), |
|
31 | + 'title' => __('Webhook Endpoints', 'woocommerce-gateway-stripe'), |
|
32 | 32 | 'type' => 'title', |
33 | 33 | /* translators: webhook URL */ |
34 | 34 | 'description' => $this->display_admin_settings_webhook_description(), |
35 | 35 | ), |
36 | 36 | 'testmode' => array( |
37 | - 'title' => __( 'Test mode', 'woocommerce-gateway-stripe' ), |
|
38 | - 'label' => __( 'Enable Test Mode', 'woocommerce-gateway-stripe' ), |
|
37 | + 'title' => __('Test mode', 'woocommerce-gateway-stripe'), |
|
38 | + 'label' => __('Enable Test Mode', 'woocommerce-gateway-stripe'), |
|
39 | 39 | 'type' => 'checkbox', |
40 | - 'description' => __( 'Place the payment gateway in test mode using test API keys.', 'woocommerce-gateway-stripe' ), |
|
40 | + 'description' => __('Place the payment gateway in test mode using test API keys.', 'woocommerce-gateway-stripe'), |
|
41 | 41 | 'default' => 'yes', |
42 | 42 | 'desc_tip' => true, |
43 | 43 | ), |
44 | 44 | 'test_publishable_key' => array( |
45 | - 'title' => __( 'Test Publishable Key', 'woocommerce-gateway-stripe' ), |
|
45 | + 'title' => __('Test Publishable Key', 'woocommerce-gateway-stripe'), |
|
46 | 46 | 'type' => 'text', |
47 | - 'description' => __( 'Get your API keys from your stripe account.', 'woocommerce-gateway-stripe' ), |
|
47 | + 'description' => __('Get your API keys from your stripe account.', 'woocommerce-gateway-stripe'), |
|
48 | 48 | 'default' => '', |
49 | 49 | 'desc_tip' => true, |
50 | 50 | ), |
51 | 51 | 'test_secret_key' => array( |
52 | - 'title' => __( 'Test Secret Key', 'woocommerce-gateway-stripe' ), |
|
52 | + 'title' => __('Test Secret Key', 'woocommerce-gateway-stripe'), |
|
53 | 53 | 'type' => 'password', |
54 | - 'description' => __( 'Get your API keys from your stripe account.', 'woocommerce-gateway-stripe' ), |
|
54 | + 'description' => __('Get your API keys from your stripe account.', 'woocommerce-gateway-stripe'), |
|
55 | 55 | 'default' => '', |
56 | 56 | 'desc_tip' => true, |
57 | 57 | ), |
58 | 58 | 'test_webhook_secret' => array( |
59 | - 'title' => __( 'Test Webhook Secret', 'woocommerce-gateway-stripe' ), |
|
59 | + 'title' => __('Test Webhook Secret', 'woocommerce-gateway-stripe'), |
|
60 | 60 | 'type' => 'password', |
61 | - 'description' => __( 'Get your webhook signing secret from the webhooks section in your stripe account.', 'woocommerce-gateway-stripe' ), |
|
61 | + 'description' => __('Get your webhook signing secret from the webhooks section in your stripe account.', 'woocommerce-gateway-stripe'), |
|
62 | 62 | 'default' => '', |
63 | 63 | 'desc_tip' => true, |
64 | 64 | ), |
65 | 65 | 'publishable_key' => array( |
66 | - 'title' => __( 'Live Publishable Key', 'woocommerce-gateway-stripe' ), |
|
66 | + 'title' => __('Live Publishable Key', 'woocommerce-gateway-stripe'), |
|
67 | 67 | 'type' => 'text', |
68 | - 'description' => __( 'Get your API keys from your stripe account.', 'woocommerce-gateway-stripe' ), |
|
68 | + 'description' => __('Get your API keys from your stripe account.', 'woocommerce-gateway-stripe'), |
|
69 | 69 | 'default' => '', |
70 | 70 | 'desc_tip' => true, |
71 | 71 | ), |
72 | 72 | 'secret_key' => array( |
73 | - 'title' => __( 'Live Secret Key', 'woocommerce-gateway-stripe' ), |
|
73 | + 'title' => __('Live Secret Key', 'woocommerce-gateway-stripe'), |
|
74 | 74 | 'type' => 'password', |
75 | - 'description' => __( 'Get your API keys from your stripe account.', 'woocommerce-gateway-stripe' ), |
|
75 | + 'description' => __('Get your API keys from your stripe account.', 'woocommerce-gateway-stripe'), |
|
76 | 76 | 'default' => '', |
77 | 77 | 'desc_tip' => true, |
78 | 78 | ), |
79 | 79 | 'webhook_secret' => array( |
80 | - 'title' => __( 'Webhook Secret', 'woocommerce-gateway-stripe' ), |
|
80 | + 'title' => __('Webhook Secret', 'woocommerce-gateway-stripe'), |
|
81 | 81 | 'type' => 'password', |
82 | - 'description' => __( 'Get your webhook signing secret from the webhooks section in your stripe account.', 'woocommerce-gateway-stripe' ), |
|
82 | + 'description' => __('Get your webhook signing secret from the webhooks section in your stripe account.', 'woocommerce-gateway-stripe'), |
|
83 | 83 | 'default' => '', |
84 | 84 | 'desc_tip' => true, |
85 | 85 | ), |
86 | 86 | 'inline_cc_form' => array( |
87 | - 'title' => __( 'Inline Credit Card Form', 'woocommerce-gateway-stripe' ), |
|
87 | + 'title' => __('Inline Credit Card Form', 'woocommerce-gateway-stripe'), |
|
88 | 88 | 'type' => 'checkbox', |
89 | - 'description' => __( 'Choose the style you want to show for your credit card form. When unchecked, the credit card form will display separate credit card number field, expiry date field and cvc field.', 'woocommerce-gateway-stripe' ), |
|
89 | + 'description' => __('Choose the style you want to show for your credit card form. When unchecked, the credit card form will display separate credit card number field, expiry date field and cvc field.', 'woocommerce-gateway-stripe'), |
|
90 | 90 | 'default' => 'no', |
91 | 91 | 'desc_tip' => true, |
92 | 92 | ), |
93 | 93 | 'statement_descriptor' => array( |
94 | - 'title' => __( 'Statement Descriptor', 'woocommerce-gateway-stripe' ), |
|
94 | + 'title' => __('Statement Descriptor', 'woocommerce-gateway-stripe'), |
|
95 | 95 | 'type' => 'text', |
96 | - 'description' => __( 'Statement descriptors are limited to 22 characters, cannot use the special characters >, <, ", \, \', *, and must not consist solely of numbers. This will appear on your customer\'s statement in capital letters.', 'woocommerce-gateway-stripe' ), |
|
96 | + 'description' => __('Statement descriptors are limited to 22 characters, cannot use the special characters >, <, ", \, \', *, and must not consist solely of numbers. This will appear on your customer\'s statement in capital letters.', 'woocommerce-gateway-stripe'), |
|
97 | 97 | 'default' => '', |
98 | 98 | 'desc_tip' => true, |
99 | 99 | ), |
100 | 100 | 'capture' => array( |
101 | - 'title' => __( 'Capture', 'woocommerce-gateway-stripe' ), |
|
102 | - 'label' => __( 'Capture charge immediately', 'woocommerce-gateway-stripe' ), |
|
101 | + 'title' => __('Capture', 'woocommerce-gateway-stripe'), |
|
102 | + 'label' => __('Capture charge immediately', 'woocommerce-gateway-stripe'), |
|
103 | 103 | 'type' => 'checkbox', |
104 | - 'description' => __( 'Whether or not to immediately capture the charge. When unchecked, the charge issues an authorization and will need to be captured later. Uncaptured charges expire in 7 days.', 'woocommerce-gateway-stripe' ), |
|
104 | + 'description' => __('Whether or not to immediately capture the charge. When unchecked, the charge issues an authorization and will need to be captured later. Uncaptured charges expire in 7 days.', 'woocommerce-gateway-stripe'), |
|
105 | 105 | 'default' => 'yes', |
106 | 106 | 'desc_tip' => true, |
107 | 107 | ), |
108 | 108 | 'payment_request' => array( |
109 | - 'title' => __( 'Payment Request Buttons', 'woocommerce-gateway-stripe' ), |
|
109 | + 'title' => __('Payment Request Buttons', 'woocommerce-gateway-stripe'), |
|
110 | 110 | /* translators: 1) br tag 2) opening anchor tag 3) closing anchor tag */ |
111 | - 'label' => sprintf( __( 'Enable Payment Request Buttons. (Apple Pay/Chrome Payment Request API) %1$sBy using Apple Pay, you agree to %2$s and %3$s\'s terms of service.', 'woocommerce-gateway-stripe' ), '<br />', '<a href="https://stripe.com/apple-pay/legal" target="_blank">Stripe</a>', '<a href="https://developer.apple.com/apple-pay/acceptable-use-guidelines-for-websites/" target="_blank">Apple</a>' ), |
|
111 | + 'label' => sprintf(__('Enable Payment Request Buttons. (Apple Pay/Chrome Payment Request API) %1$sBy using Apple Pay, you agree to %2$s and %3$s\'s terms of service.', 'woocommerce-gateway-stripe'), '<br />', '<a href="https://stripe.com/apple-pay/legal" target="_blank">Stripe</a>', '<a href="https://developer.apple.com/apple-pay/acceptable-use-guidelines-for-websites/" target="_blank">Apple</a>'), |
|
112 | 112 | 'type' => 'checkbox', |
113 | - 'description' => __( 'If enabled, users will be able to pay using Apple Pay or Chrome Payment Request if supported by the browser.', 'woocommerce-gateway-stripe' ), |
|
113 | + 'description' => __('If enabled, users will be able to pay using Apple Pay or Chrome Payment Request if supported by the browser.', 'woocommerce-gateway-stripe'), |
|
114 | 114 | 'default' => 'yes', |
115 | 115 | 'desc_tip' => true, |
116 | 116 | ), |
117 | 117 | 'payment_request_button_type' => array( |
118 | - 'title' => __( 'Payment Request Button Type', 'woocommerce-gateway-stripe' ), |
|
119 | - 'label' => __( 'Button Type', 'woocommerce-gateway-stripe' ), |
|
118 | + 'title' => __('Payment Request Button Type', 'woocommerce-gateway-stripe'), |
|
119 | + 'label' => __('Button Type', 'woocommerce-gateway-stripe'), |
|
120 | 120 | 'type' => 'select', |
121 | - 'description' => __( 'Select the button type you would like to show.', 'woocommerce-gateway-stripe' ), |
|
121 | + 'description' => __('Select the button type you would like to show.', 'woocommerce-gateway-stripe'), |
|
122 | 122 | 'default' => 'buy', |
123 | 123 | 'desc_tip' => true, |
124 | 124 | 'options' => array( |
125 | - 'default' => __( 'Default', 'woocommerce-gateway-stripe' ), |
|
126 | - 'buy' => __( 'Buy', 'woocommerce-gateway-stripe' ), |
|
127 | - 'donate' => __( 'Donate', 'woocommerce-gateway-stripe' ), |
|
125 | + 'default' => __('Default', 'woocommerce-gateway-stripe'), |
|
126 | + 'buy' => __('Buy', 'woocommerce-gateway-stripe'), |
|
127 | + 'donate' => __('Donate', 'woocommerce-gateway-stripe'), |
|
128 | 128 | ), |
129 | 129 | ), |
130 | 130 | 'payment_request_button_theme' => array( |
131 | - 'title' => __( 'Payment Request Button Theme', 'woocommerce-gateway-stripe' ), |
|
132 | - 'label' => __( 'Button Theme', 'woocommerce-gateway-stripe' ), |
|
131 | + 'title' => __('Payment Request Button Theme', 'woocommerce-gateway-stripe'), |
|
132 | + 'label' => __('Button Theme', 'woocommerce-gateway-stripe'), |
|
133 | 133 | 'type' => 'select', |
134 | - 'description' => __( 'Select the button theme you would like to show.', 'woocommerce-gateway-stripe' ), |
|
134 | + 'description' => __('Select the button theme you would like to show.', 'woocommerce-gateway-stripe'), |
|
135 | 135 | 'default' => 'dark', |
136 | 136 | 'desc_tip' => true, |
137 | 137 | 'options' => array( |
138 | - 'dark' => __( 'Dark', 'woocommerce-gateway-stripe' ), |
|
139 | - 'light' => __( 'Light', 'woocommerce-gateway-stripe' ), |
|
140 | - 'light-outline' => __( 'Light-Outline', 'woocommerce-gateway-stripe' ), |
|
138 | + 'dark' => __('Dark', 'woocommerce-gateway-stripe'), |
|
139 | + 'light' => __('Light', 'woocommerce-gateway-stripe'), |
|
140 | + 'light-outline' => __('Light-Outline', 'woocommerce-gateway-stripe'), |
|
141 | 141 | ), |
142 | 142 | ), |
143 | 143 | 'payment_request_button_height' => array( |
144 | - 'title' => __( 'Payment Request Button Height', 'woocommerce-gateway-stripe' ), |
|
145 | - 'label' => __( 'Button Height', 'woocommerce-gateway-stripe' ), |
|
144 | + 'title' => __('Payment Request Button Height', 'woocommerce-gateway-stripe'), |
|
145 | + 'label' => __('Button Height', 'woocommerce-gateway-stripe'), |
|
146 | 146 | 'type' => 'text', |
147 | - 'description' => __( 'Enter the height you would like the button to be in pixels. Width will always be 100%.', 'woocommerce-gateway-stripe' ), |
|
147 | + 'description' => __('Enter the height you would like the button to be in pixels. Width will always be 100%.', 'woocommerce-gateway-stripe'), |
|
148 | 148 | 'default' => '44', |
149 | 149 | 'desc_tip' => true, |
150 | 150 | ), |
151 | 151 | 'saved_cards' => array( |
152 | - 'title' => __( 'Saved Cards', 'woocommerce-gateway-stripe' ), |
|
153 | - 'label' => __( 'Enable Payment via Saved Cards', 'woocommerce-gateway-stripe' ), |
|
152 | + 'title' => __('Saved Cards', 'woocommerce-gateway-stripe'), |
|
153 | + 'label' => __('Enable Payment via Saved Cards', 'woocommerce-gateway-stripe'), |
|
154 | 154 | 'type' => 'checkbox', |
155 | - 'description' => __( 'If enabled, users will be able to pay with a saved card during checkout. Card details are saved on Stripe servers, not on your store.', 'woocommerce-gateway-stripe' ), |
|
155 | + 'description' => __('If enabled, users will be able to pay with a saved card during checkout. Card details are saved on Stripe servers, not on your store.', 'woocommerce-gateway-stripe'), |
|
156 | 156 | 'default' => 'yes', |
157 | 157 | 'desc_tip' => true, |
158 | 158 | ), |
159 | 159 | 'logging' => array( |
160 | - 'title' => __( 'Logging', 'woocommerce-gateway-stripe' ), |
|
161 | - 'label' => __( 'Log debug messages', 'woocommerce-gateway-stripe' ), |
|
160 | + 'title' => __('Logging', 'woocommerce-gateway-stripe'), |
|
161 | + 'label' => __('Log debug messages', 'woocommerce-gateway-stripe'), |
|
162 | 162 | 'type' => 'checkbox', |
163 | - 'description' => __( 'Save debug messages to the WooCommerce System Status log.', 'woocommerce-gateway-stripe' ), |
|
163 | + 'description' => __('Save debug messages to the WooCommerce System Status log.', 'woocommerce-gateway-stripe'), |
|
164 | 164 | 'default' => 'no', |
165 | 165 | 'desc_tip' => true, |
166 | 166 | ), |
@@ -1,5 +1,5 @@ discard block |
||
1 | 1 | <?php |
2 | -if ( ! defined( 'ABSPATH' ) ) { |
|
2 | +if ( ! defined('ABSPATH')) { |
|
3 | 3 | exit; |
4 | 4 | } |
5 | 5 | |
@@ -23,7 +23,7 @@ discard block |
||
23 | 23 | * @since 4.2.0 |
24 | 24 | */ |
25 | 25 | public function __construct() { |
26 | - add_action( 'wc_ajax_wc_stripe_verify_intent', array( $this, 'verify_intent' ) ); |
|
26 | + add_action('wc_ajax_wc_stripe_verify_intent', array($this, 'verify_intent')); |
|
27 | 27 | } |
28 | 28 | |
29 | 29 | /** |
@@ -33,8 +33,8 @@ discard block |
||
33 | 33 | * @return WC_Gateway_Stripe |
34 | 34 | */ |
35 | 35 | protected function get_gateway() { |
36 | - if ( ! isset( $this->gateway ) ) { |
|
37 | - if ( class_exists( 'WC_Subscriptions_Order' ) && function_exists( 'wcs_create_renewal_order' ) ) { |
|
36 | + if ( ! isset($this->gateway)) { |
|
37 | + if (class_exists('WC_Subscriptions_Order') && function_exists('wcs_create_renewal_order')) { |
|
38 | 38 | $class_name = 'WC_Stripe_Subs_Compat'; |
39 | 39 | } else { |
40 | 40 | $class_name = 'WC_Gateway_Stripe'; |
@@ -54,21 +54,21 @@ discard block |
||
54 | 54 | * @return WC_Order |
55 | 55 | */ |
56 | 56 | protected function get_order_from_request() { |
57 | - if ( ! isset( $_GET['nonce'] ) || ! wp_verify_nonce( sanitize_key( $_GET['nonce'] ), 'wc_stripe_confirm_pi' ) ) { |
|
58 | - throw new WC_Stripe_Exception( 'missing-nonce', __( 'CSRF verification failed.', 'woocommerce-gateway-stripe' ) ); |
|
57 | + if ( ! isset($_GET['nonce']) || ! wp_verify_nonce(sanitize_key($_GET['nonce']), 'wc_stripe_confirm_pi')) { |
|
58 | + throw new WC_Stripe_Exception('missing-nonce', __('CSRF verification failed.', 'woocommerce-gateway-stripe')); |
|
59 | 59 | } |
60 | 60 | |
61 | 61 | // Load the order ID. |
62 | 62 | $order_id = null; |
63 | - if ( isset( $_GET['order'] ) && absint( $_GET['order'] ) ) { |
|
64 | - $order_id = absint( $_GET['order'] ); |
|
63 | + if (isset($_GET['order']) && absint($_GET['order'])) { |
|
64 | + $order_id = absint($_GET['order']); |
|
65 | 65 | } |
66 | 66 | |
67 | 67 | // Retrieve the order. |
68 | - $order = wc_get_order( $order_id ); |
|
68 | + $order = wc_get_order($order_id); |
|
69 | 69 | |
70 | - if ( ! $order ) { |
|
71 | - throw new WC_Stripe_Exception( 'missing-order', __( 'Missing order ID for payment confirmation', 'woocommerce-gateway-stripe' ) ); |
|
70 | + if ( ! $order) { |
|
71 | + throw new WC_Stripe_Exception('missing-order', __('Missing order ID for payment confirmation', 'woocommerce-gateway-stripe')); |
|
72 | 72 | } |
73 | 73 | |
74 | 74 | return $order; |
@@ -86,32 +86,32 @@ discard block |
||
86 | 86 | |
87 | 87 | try { |
88 | 88 | $order = $this->get_order_from_request(); |
89 | - } catch ( WC_Stripe_Exception $e ) { |
|
89 | + } catch (WC_Stripe_Exception $e) { |
|
90 | 90 | /* translators: Error message text */ |
91 | - $message = sprintf( __( 'Payment verification error: %s', 'woocommerce-gateway-stripe' ), $e->getLocalizedMessage() ); |
|
92 | - wc_add_notice( esc_html( $message ), 'error' ); |
|
91 | + $message = sprintf(__('Payment verification error: %s', 'woocommerce-gateway-stripe'), $e->getLocalizedMessage()); |
|
92 | + wc_add_notice(esc_html($message), 'error'); |
|
93 | 93 | |
94 | 94 | $redirect_url = $woocommerce->cart->is_empty() |
95 | - ? get_permalink( WC_Stripe_Helper::is_wc_lt( '3.0' ) ? woocommerce_get_page_id( 'shop' ) : wc_get_page_id( 'shop' ) ) |
|
95 | + ? get_permalink(WC_Stripe_Helper::is_wc_lt('3.0') ? woocommerce_get_page_id('shop') : wc_get_page_id('shop')) |
|
96 | 96 | : wc_get_checkout_url(); |
97 | 97 | |
98 | - $this->handle_error( $e, $redirect_url ); |
|
98 | + $this->handle_error($e, $redirect_url); |
|
99 | 99 | } |
100 | 100 | |
101 | 101 | try { |
102 | - $gateway->verify_intent_after_checkout( $order ); |
|
102 | + $gateway->verify_intent_after_checkout($order); |
|
103 | 103 | |
104 | - if ( ! isset( $_GET['is_ajax'] ) ) { |
|
105 | - $redirect_url = isset( $_GET['redirect_to'] ) // wpcs: csrf ok. |
|
106 | - ? esc_url_raw( wp_unslash( $_GET['redirect_to'] ) ) // wpcs: csrf ok. |
|
107 | - : $gateway->get_return_url( $order ); |
|
104 | + if ( ! isset($_GET['is_ajax'])) { |
|
105 | + $redirect_url = isset($_GET['redirect_to']) // wpcs: csrf ok. |
|
106 | + ? esc_url_raw(wp_unslash($_GET['redirect_to'])) // wpcs: csrf ok. |
|
107 | + : $gateway->get_return_url($order); |
|
108 | 108 | |
109 | - wp_safe_redirect( $redirect_url ); |
|
109 | + wp_safe_redirect($redirect_url); |
|
110 | 110 | } |
111 | 111 | |
112 | 112 | exit; |
113 | - } catch ( WC_Stripe_Exception $e ) { |
|
114 | - $this->handle_error( $e, $gateway->get_return_url( $order ) ); |
|
113 | + } catch (WC_Stripe_Exception $e) { |
|
114 | + $this->handle_error($e, $gateway->get_return_url($order)); |
|
115 | 115 | } |
116 | 116 | } |
117 | 117 | |
@@ -122,17 +122,17 @@ discard block |
||
122 | 122 | * @param WC_Stripe_Exception $e The exception that was thrown. |
123 | 123 | * @param string $redirect_url An URL to use if a redirect is needed. |
124 | 124 | */ |
125 | - protected function handle_error( $e, $redirect_url ) { |
|
125 | + protected function handle_error($e, $redirect_url) { |
|
126 | 126 | // Log the exception before redirecting. |
127 | - $message = sprintf( 'PaymentIntent verification exception: %s', $e->getLocalizedMessage() ); |
|
128 | - WC_Stripe_Logger::log( $message ); |
|
127 | + $message = sprintf('PaymentIntent verification exception: %s', $e->getLocalizedMessage()); |
|
128 | + WC_Stripe_Logger::log($message); |
|
129 | 129 | |
130 | 130 | // `is_ajax` is only used for PI error reporting, a response is not expected. |
131 | - if ( isset( $_GET['is_ajax'] ) ) { |
|
131 | + if (isset($_GET['is_ajax'])) { |
|
132 | 132 | exit; |
133 | 133 | } |
134 | 134 | |
135 | - wp_safe_redirect( $redirect_url ); |
|
135 | + wp_safe_redirect($redirect_url); |
|
136 | 136 | exit; |
137 | 137 | } |
138 | 138 | } |
@@ -83,7 +83,7 @@ |
||
83 | 83 | * @version 4.0.0 |
84 | 84 | * @param string $request_headers The request headers from Stripe. |
85 | 85 | * @param string $request_body The request body from Stripe. |
86 | - * @return bool |
|
86 | + * @return null|boolean |
|
87 | 87 | */ |
88 | 88 | public function is_valid_request( $request_headers = null, $request_body = null ) { |
89 | 89 | if ( null === $request_headers || null === $request_body ) { |
@@ -1,5 +1,5 @@ discard block |
||
1 | 1 | <?php |
2 | -if ( ! defined( 'ABSPATH' ) ) { |
|
2 | +if ( ! defined('ABSPATH')) { |
|
3 | 3 | exit; |
4 | 4 | } |
5 | 5 | |
@@ -39,12 +39,12 @@ discard block |
||
39 | 39 | */ |
40 | 40 | public function __construct() { |
41 | 41 | $this->retry_interval = 2; |
42 | - $stripe_settings = get_option( 'woocommerce_stripe_settings', array() ); |
|
43 | - $this->testmode = ( ! empty( $stripe_settings['testmode'] ) && 'yes' === $stripe_settings['testmode'] ) ? true : false; |
|
44 | - $secret_key = ( $this->testmode ? 'test_' : '' ) . 'webhook_secret'; |
|
45 | - $this->secret = ! empty( $stripe_settings[ $secret_key ] ) ? $stripe_settings[ $secret_key ] : false; |
|
42 | + $stripe_settings = get_option('woocommerce_stripe_settings', array()); |
|
43 | + $this->testmode = ( ! empty($stripe_settings['testmode']) && 'yes' === $stripe_settings['testmode']) ? true : false; |
|
44 | + $secret_key = ($this->testmode ? 'test_' : '') . 'webhook_secret'; |
|
45 | + $this->secret = ! empty($stripe_settings[$secret_key]) ? $stripe_settings[$secret_key] : false; |
|
46 | 46 | |
47 | - add_action( 'woocommerce_api_wc_stripe', array( $this, 'check_for_webhook' ) ); |
|
47 | + add_action('woocommerce_api_wc_stripe', array($this, 'check_for_webhook')); |
|
48 | 48 | } |
49 | 49 | |
50 | 50 | /** |
@@ -54,24 +54,24 @@ discard block |
||
54 | 54 | * @version 4.0.0 |
55 | 55 | */ |
56 | 56 | public function check_for_webhook() { |
57 | - if ( ( 'POST' !== $_SERVER['REQUEST_METHOD'] ) |
|
58 | - || ! isset( $_GET['wc-api'] ) |
|
59 | - || ( 'wc_stripe' !== $_GET['wc-api'] ) |
|
57 | + if (('POST' !== $_SERVER['REQUEST_METHOD']) |
|
58 | + || ! isset($_GET['wc-api']) |
|
59 | + || ('wc_stripe' !== $_GET['wc-api']) |
|
60 | 60 | ) { |
61 | 61 | return; |
62 | 62 | } |
63 | 63 | |
64 | - $request_body = file_get_contents( 'php://input' ); |
|
65 | - $request_headers = array_change_key_case( $this->get_request_headers(), CASE_UPPER ); |
|
64 | + $request_body = file_get_contents('php://input'); |
|
65 | + $request_headers = array_change_key_case($this->get_request_headers(), CASE_UPPER); |
|
66 | 66 | |
67 | 67 | // Validate it to make sure it is legit. |
68 | - if ( $this->is_valid_request( $request_headers, $request_body ) ) { |
|
69 | - $this->process_webhook( $request_body ); |
|
70 | - status_header( 200 ); |
|
68 | + if ($this->is_valid_request($request_headers, $request_body)) { |
|
69 | + $this->process_webhook($request_body); |
|
70 | + status_header(200); |
|
71 | 71 | exit; |
72 | 72 | } else { |
73 | - WC_Stripe_Logger::log( 'Incoming webhook failed validation: ' . print_r( $request_body, true ) ); |
|
74 | - status_header( 400 ); |
|
73 | + WC_Stripe_Logger::log('Incoming webhook failed validation: ' . print_r($request_body, true)); |
|
74 | + status_header(400); |
|
75 | 75 | exit; |
76 | 76 | } |
77 | 77 | } |
@@ -85,34 +85,34 @@ discard block |
||
85 | 85 | * @param string $request_body The request body from Stripe. |
86 | 86 | * @return bool |
87 | 87 | */ |
88 | - public function is_valid_request( $request_headers = null, $request_body = null ) { |
|
89 | - if ( null === $request_headers || null === $request_body ) { |
|
88 | + public function is_valid_request($request_headers = null, $request_body = null) { |
|
89 | + if (null === $request_headers || null === $request_body) { |
|
90 | 90 | return false; |
91 | 91 | } |
92 | 92 | |
93 | - if ( ! empty( $request_headers['USER-AGENT'] ) && ! preg_match( '/Stripe/', $request_headers['USER-AGENT'] ) ) { |
|
93 | + if ( ! empty($request_headers['USER-AGENT']) && ! preg_match('/Stripe/', $request_headers['USER-AGENT'])) { |
|
94 | 94 | return false; |
95 | 95 | } |
96 | 96 | |
97 | - if ( ! empty( $this->secret ) ) { |
|
97 | + if ( ! empty($this->secret)) { |
|
98 | 98 | // Check for a valid signature. |
99 | 99 | $signature_format = '/^t=(?P<timestamp>\d+)(?P<signatures>(,v\d+=[a-z0-9]+){1,2})$/'; |
100 | - if ( empty( $request_headers['STRIPE-SIGNATURE'] ) || ! preg_match( $signature_format, $request_headers['STRIPE-SIGNATURE'], $matches ) ) { |
|
100 | + if (empty($request_headers['STRIPE-SIGNATURE']) || ! preg_match($signature_format, $request_headers['STRIPE-SIGNATURE'], $matches)) { |
|
101 | 101 | return false; |
102 | 102 | } |
103 | 103 | |
104 | 104 | // Verify the timestamp. |
105 | - $timestamp = intval( $matches['timestamp'] ); |
|
106 | - if ( abs( $timestamp - time() ) > 5 * MINUTE_IN_SECONDS ) { |
|
105 | + $timestamp = intval($matches['timestamp']); |
|
106 | + if (abs($timestamp - time()) > 5 * MINUTE_IN_SECONDS) { |
|
107 | 107 | return; |
108 | 108 | } |
109 | 109 | |
110 | 110 | // Generate the expected signature. |
111 | 111 | $signed_payload = $timestamp . '.' . $request_body; |
112 | - $expected_signature = hash_hmac( 'sha256', $signed_payload, $this->secret ); |
|
112 | + $expected_signature = hash_hmac('sha256', $signed_payload, $this->secret); |
|
113 | 113 | |
114 | 114 | // Check if the expected signature is present. |
115 | - if ( ! preg_match( '/,v\d+=' . preg_quote( $expected_signature, '/' ) . '/', $matches['signatures'] ) ) { |
|
115 | + if ( ! preg_match('/,v\d+=' . preg_quote($expected_signature, '/') . '/', $matches['signatures'])) { |
|
116 | 116 | return false; |
117 | 117 | } |
118 | 118 | } |
@@ -129,12 +129,12 @@ discard block |
||
129 | 129 | * @version 4.0.0 |
130 | 130 | */ |
131 | 131 | public function get_request_headers() { |
132 | - if ( ! function_exists( 'getallheaders' ) ) { |
|
132 | + if ( ! function_exists('getallheaders')) { |
|
133 | 133 | $headers = array(); |
134 | 134 | |
135 | - foreach ( $_SERVER as $name => $value ) { |
|
136 | - if ( 'HTTP_' === substr( $name, 0, 5 ) ) { |
|
137 | - $headers[ str_replace( ' ', '-', ucwords( strtolower( str_replace( '_', ' ', substr( $name, 5 ) ) ) ) ) ] = $value; |
|
135 | + foreach ($_SERVER as $name => $value) { |
|
136 | + if ('HTTP_' === substr($name, 0, 5)) { |
|
137 | + $headers[str_replace(' ', '-', ucwords(strtolower(str_replace('_', ' ', substr($name, 5)))))] = $value; |
|
138 | 138 | } |
139 | 139 | } |
140 | 140 | |
@@ -153,30 +153,30 @@ discard block |
||
153 | 153 | * @param object $notification |
154 | 154 | * @param bool $retry |
155 | 155 | */ |
156 | - public function process_webhook_payment( $notification, $retry = true ) { |
|
156 | + public function process_webhook_payment($notification, $retry = true) { |
|
157 | 157 | // The following 3 payment methods are synchronous so does not need to be handle via webhook. |
158 | - if ( 'card' === $notification->data->object->type || 'sepa_debit' === $notification->data->object->type || 'three_d_secure' === $notification->data->object->type ) { |
|
158 | + if ('card' === $notification->data->object->type || 'sepa_debit' === $notification->data->object->type || 'three_d_secure' === $notification->data->object->type) { |
|
159 | 159 | return; |
160 | 160 | } |
161 | 161 | |
162 | - $order = WC_Stripe_Helper::get_order_by_source_id( $notification->data->object->id ); |
|
162 | + $order = WC_Stripe_Helper::get_order_by_source_id($notification->data->object->id); |
|
163 | 163 | |
164 | - if ( ! $order ) { |
|
165 | - WC_Stripe_Logger::log( 'Could not find order via source ID: ' . $notification->data->object->id ); |
|
164 | + if ( ! $order) { |
|
165 | + WC_Stripe_Logger::log('Could not find order via source ID: ' . $notification->data->object->id); |
|
166 | 166 | return; |
167 | 167 | } |
168 | 168 | |
169 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
169 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
170 | 170 | $source_id = $notification->data->object->id; |
171 | 171 | |
172 | - $is_pending_receiver = ( 'receiver' === $notification->data->object->flow ); |
|
172 | + $is_pending_receiver = ('receiver' === $notification->data->object->flow); |
|
173 | 173 | |
174 | 174 | try { |
175 | - if ( $order->has_status( array( 'processing', 'completed' ) ) ) { |
|
175 | + if ($order->has_status(array('processing', 'completed'))) { |
|
176 | 176 | return; |
177 | 177 | } |
178 | 178 | |
179 | - if ( $order->has_status( 'on-hold' ) && ! $is_pending_receiver ) { |
|
179 | + if ($order->has_status('on-hold') && ! $is_pending_receiver) { |
|
180 | 180 | return; |
181 | 181 | } |
182 | 182 | |
@@ -184,94 +184,94 @@ discard block |
||
184 | 184 | $response = null; |
185 | 185 | |
186 | 186 | // This will throw exception if not valid. |
187 | - $this->validate_minimum_order_amount( $order ); |
|
187 | + $this->validate_minimum_order_amount($order); |
|
188 | 188 | |
189 | - WC_Stripe_Logger::log( "Info: (Webhook) Begin processing payment for order $order_id for the amount of {$order->get_total()}" ); |
|
189 | + WC_Stripe_Logger::log("Info: (Webhook) Begin processing payment for order $order_id for the amount of {$order->get_total()}"); |
|
190 | 190 | |
191 | 191 | // Prep source object. |
192 | 192 | $source_object = new stdClass(); |
193 | 193 | $source_object->token_id = ''; |
194 | - $source_object->customer = $this->get_stripe_customer_id( $order ); |
|
194 | + $source_object->customer = $this->get_stripe_customer_id($order); |
|
195 | 195 | $source_object->source = $source_id; |
196 | 196 | |
197 | 197 | // Make the request. |
198 | - $response = WC_Stripe_API::request( $this->generate_payment_request( $order, $source_object ), 'charges', 'POST', true ); |
|
198 | + $response = WC_Stripe_API::request($this->generate_payment_request($order, $source_object), 'charges', 'POST', true); |
|
199 | 199 | $headers = $response['headers']; |
200 | 200 | $response = $response['body']; |
201 | 201 | |
202 | - if ( ! empty( $response->error ) ) { |
|
202 | + if ( ! empty($response->error)) { |
|
203 | 203 | // Customer param wrong? The user may have been deleted on stripe's end. Remove customer_id. Can be retried without. |
204 | - if ( $this->is_no_such_customer_error( $response->error ) ) { |
|
205 | - if ( WC_Stripe_Helper::is_wc_lt( '3.0' ) ) { |
|
206 | - delete_user_option( $order->customer_user, '_stripe_customer_id' ); |
|
207 | - delete_post_meta( $order_id, '_stripe_customer_id' ); |
|
204 | + if ($this->is_no_such_customer_error($response->error)) { |
|
205 | + if (WC_Stripe_Helper::is_wc_lt('3.0')) { |
|
206 | + delete_user_option($order->customer_user, '_stripe_customer_id'); |
|
207 | + delete_post_meta($order_id, '_stripe_customer_id'); |
|
208 | 208 | } else { |
209 | - delete_user_option( $order->get_customer_id(), '_stripe_customer_id' ); |
|
210 | - $order->delete_meta_data( '_stripe_customer_id' ); |
|
209 | + delete_user_option($order->get_customer_id(), '_stripe_customer_id'); |
|
210 | + $order->delete_meta_data('_stripe_customer_id'); |
|
211 | 211 | $order->save(); |
212 | 212 | } |
213 | 213 | } |
214 | 214 | |
215 | - if ( $this->is_no_such_token_error( $response->error ) && $prepared_source->token_id ) { |
|
215 | + if ($this->is_no_such_token_error($response->error) && $prepared_source->token_id) { |
|
216 | 216 | // Source param wrong? The CARD may have been deleted on stripe's end. Remove token and show message. |
217 | - $wc_token = WC_Payment_Tokens::get( $prepared_source->token_id ); |
|
217 | + $wc_token = WC_Payment_Tokens::get($prepared_source->token_id); |
|
218 | 218 | $wc_token->delete(); |
219 | - $localized_message = __( 'This card is no longer available and has been removed.', 'woocommerce-gateway-stripe' ); |
|
220 | - $order->add_order_note( $localized_message ); |
|
221 | - throw new WC_Stripe_Exception( print_r( $response, true ), $localized_message ); |
|
219 | + $localized_message = __('This card is no longer available and has been removed.', 'woocommerce-gateway-stripe'); |
|
220 | + $order->add_order_note($localized_message); |
|
221 | + throw new WC_Stripe_Exception(print_r($response, true), $localized_message); |
|
222 | 222 | } |
223 | 223 | |
224 | 224 | // We want to retry. |
225 | - if ( $this->is_retryable_error( $response->error ) ) { |
|
226 | - if ( $retry ) { |
|
225 | + if ($this->is_retryable_error($response->error)) { |
|
226 | + if ($retry) { |
|
227 | 227 | // Don't do anymore retries after this. |
228 | - if ( 5 <= $this->retry_interval ) { |
|
228 | + if (5 <= $this->retry_interval) { |
|
229 | 229 | |
230 | - return $this->process_webhook_payment( $notification, false ); |
|
230 | + return $this->process_webhook_payment($notification, false); |
|
231 | 231 | } |
232 | 232 | |
233 | - sleep( $this->retry_interval ); |
|
233 | + sleep($this->retry_interval); |
|
234 | 234 | |
235 | 235 | $this->retry_interval++; |
236 | - return $this->process_webhook_payment( $notification, true ); |
|
236 | + return $this->process_webhook_payment($notification, true); |
|
237 | 237 | } else { |
238 | - $localized_message = __( 'Sorry, we are unable to process your payment at this time. Please retry later.', 'woocommerce-gateway-stripe' ); |
|
239 | - $order->add_order_note( $localized_message ); |
|
240 | - throw new WC_Stripe_Exception( print_r( $response, true ), $localized_message ); |
|
238 | + $localized_message = __('Sorry, we are unable to process your payment at this time. Please retry later.', 'woocommerce-gateway-stripe'); |
|
239 | + $order->add_order_note($localized_message); |
|
240 | + throw new WC_Stripe_Exception(print_r($response, true), $localized_message); |
|
241 | 241 | } |
242 | 242 | } |
243 | 243 | |
244 | 244 | $localized_messages = WC_Stripe_Helper::get_localized_messages(); |
245 | 245 | |
246 | - if ( 'card_error' === $response->error->type ) { |
|
247 | - $localized_message = isset( $localized_messages[ $response->error->code ] ) ? $localized_messages[ $response->error->code ] : $response->error->message; |
|
246 | + if ('card_error' === $response->error->type) { |
|
247 | + $localized_message = isset($localized_messages[$response->error->code]) ? $localized_messages[$response->error->code] : $response->error->message; |
|
248 | 248 | } else { |
249 | - $localized_message = isset( $localized_messages[ $response->error->type ] ) ? $localized_messages[ $response->error->type ] : $response->error->message; |
|
249 | + $localized_message = isset($localized_messages[$response->error->type]) ? $localized_messages[$response->error->type] : $response->error->message; |
|
250 | 250 | } |
251 | 251 | |
252 | - $order->add_order_note( $localized_message ); |
|
252 | + $order->add_order_note($localized_message); |
|
253 | 253 | |
254 | - throw new WC_Stripe_Exception( print_r( $response, true ), $localized_message ); |
|
254 | + throw new WC_Stripe_Exception(print_r($response, true), $localized_message); |
|
255 | 255 | } |
256 | 256 | |
257 | 257 | // To prevent double processing the order on WC side. |
258 | - if ( ! $this->is_original_request( $headers ) ) { |
|
258 | + if ( ! $this->is_original_request($headers)) { |
|
259 | 259 | return; |
260 | 260 | } |
261 | 261 | |
262 | - do_action( 'wc_gateway_stripe_process_webhook_payment', $response, $order ); |
|
262 | + do_action('wc_gateway_stripe_process_webhook_payment', $response, $order); |
|
263 | 263 | |
264 | - $this->process_response( $response, $order ); |
|
264 | + $this->process_response($response, $order); |
|
265 | 265 | |
266 | - } catch ( WC_Stripe_Exception $e ) { |
|
267 | - WC_Stripe_Logger::log( 'Error: ' . $e->getMessage() ); |
|
266 | + } catch (WC_Stripe_Exception $e) { |
|
267 | + WC_Stripe_Logger::log('Error: ' . $e->getMessage()); |
|
268 | 268 | |
269 | - do_action( 'wc_gateway_stripe_process_webhook_payment_error', $order, $notification, $e ); |
|
269 | + do_action('wc_gateway_stripe_process_webhook_payment_error', $order, $notification, $e); |
|
270 | 270 | |
271 | - $statuses = array( 'pending', 'failed' ); |
|
271 | + $statuses = array('pending', 'failed'); |
|
272 | 272 | |
273 | - if ( $order->has_status( $statuses ) ) { |
|
274 | - $this->send_failed_order_email( $order_id ); |
|
273 | + if ($order->has_status($statuses)) { |
|
274 | + $this->send_failed_order_email($order_id); |
|
275 | 275 | } |
276 | 276 | } |
277 | 277 | } |
@@ -284,21 +284,21 @@ discard block |
||
284 | 284 | * @since 4.0.0 |
285 | 285 | * @param object $notification |
286 | 286 | */ |
287 | - public function process_webhook_dispute( $notification ) { |
|
288 | - $order = WC_Stripe_Helper::get_order_by_charge_id( $notification->data->object->charge ); |
|
287 | + public function process_webhook_dispute($notification) { |
|
288 | + $order = WC_Stripe_Helper::get_order_by_charge_id($notification->data->object->charge); |
|
289 | 289 | |
290 | - if ( ! $order ) { |
|
291 | - WC_Stripe_Logger::log( 'Could not find order via charge ID: ' . $notification->data->object->charge ); |
|
290 | + if ( ! $order) { |
|
291 | + WC_Stripe_Logger::log('Could not find order via charge ID: ' . $notification->data->object->charge); |
|
292 | 292 | return; |
293 | 293 | } |
294 | 294 | |
295 | 295 | /* translators: 1) The URL to the order. */ |
296 | - $order->update_status( 'on-hold', sprintf( __( 'A dispute was created for this order. Response is needed. Please go to your <a href="%s" title="Stripe Dashboard" target="_blank">Stripe Dashboard</a> to review this dispute.', 'woocommerce-gateway-stripe' ), $this->get_transaction_url( $order ) ) ); |
|
296 | + $order->update_status('on-hold', sprintf(__('A dispute was created for this order. Response is needed. Please go to your <a href="%s" title="Stripe Dashboard" target="_blank">Stripe Dashboard</a> to review this dispute.', 'woocommerce-gateway-stripe'), $this->get_transaction_url($order))); |
|
297 | 297 | |
298 | - do_action( 'wc_gateway_stripe_process_webhook_payment_error', $order, $notification ); |
|
298 | + do_action('wc_gateway_stripe_process_webhook_payment_error', $order, $notification); |
|
299 | 299 | |
300 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
301 | - $this->send_failed_order_email( $order_id ); |
|
300 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
301 | + $this->send_failed_order_email($order_id); |
|
302 | 302 | } |
303 | 303 | |
304 | 304 | /** |
@@ -309,45 +309,45 @@ discard block |
||
309 | 309 | * @version 4.0.0 |
310 | 310 | * @param object $notification |
311 | 311 | */ |
312 | - public function process_webhook_capture( $notification ) { |
|
313 | - $order = WC_Stripe_Helper::get_order_by_charge_id( $notification->data->object->id ); |
|
312 | + public function process_webhook_capture($notification) { |
|
313 | + $order = WC_Stripe_Helper::get_order_by_charge_id($notification->data->object->id); |
|
314 | 314 | |
315 | - if ( ! $order ) { |
|
316 | - WC_Stripe_Logger::log( 'Could not find order via charge ID: ' . $notification->data->object->id ); |
|
315 | + if ( ! $order) { |
|
316 | + WC_Stripe_Logger::log('Could not find order via charge ID: ' . $notification->data->object->id); |
|
317 | 317 | return; |
318 | 318 | } |
319 | 319 | |
320 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
320 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
321 | 321 | |
322 | - if ( 'stripe' === ( WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->payment_method : $order->get_payment_method() ) ) { |
|
323 | - $charge = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? get_post_meta( $order_id, '_transaction_id', true ) : $order->get_transaction_id(); |
|
324 | - $captured = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? get_post_meta( $order_id, '_stripe_charge_captured', true ) : $order->get_meta( '_stripe_charge_captured', true ); |
|
322 | + if ('stripe' === (WC_Stripe_Helper::is_wc_lt('3.0') ? $order->payment_method : $order->get_payment_method())) { |
|
323 | + $charge = WC_Stripe_Helper::is_wc_lt('3.0') ? get_post_meta($order_id, '_transaction_id', true) : $order->get_transaction_id(); |
|
324 | + $captured = WC_Stripe_Helper::is_wc_lt('3.0') ? get_post_meta($order_id, '_stripe_charge_captured', true) : $order->get_meta('_stripe_charge_captured', true); |
|
325 | 325 | |
326 | - if ( $charge && 'no' === $captured ) { |
|
327 | - WC_Stripe_Helper::is_wc_lt( '3.0' ) ? update_post_meta( $order_id, '_stripe_charge_captured', 'yes' ) : $order->update_meta_data( '_stripe_charge_captured', 'yes' ); |
|
326 | + if ($charge && 'no' === $captured) { |
|
327 | + WC_Stripe_Helper::is_wc_lt('3.0') ? update_post_meta($order_id, '_stripe_charge_captured', 'yes') : $order->update_meta_data('_stripe_charge_captured', 'yes'); |
|
328 | 328 | |
329 | 329 | // Store other data such as fees |
330 | - WC_Stripe_Helper::is_wc_lt( '3.0' ) ? update_post_meta( $order_id, '_transaction_id', $notification->data->object->id ) : $order->set_transaction_id( $notification->data->object->id ); |
|
330 | + WC_Stripe_Helper::is_wc_lt('3.0') ? update_post_meta($order_id, '_transaction_id', $notification->data->object->id) : $order->set_transaction_id($notification->data->object->id); |
|
331 | 331 | |
332 | - if ( isset( $notification->data->object->balance_transaction ) ) { |
|
333 | - $this->update_fees( $order, $notification->data->object->balance_transaction ); |
|
332 | + if (isset($notification->data->object->balance_transaction)) { |
|
333 | + $this->update_fees($order, $notification->data->object->balance_transaction); |
|
334 | 334 | } |
335 | 335 | |
336 | 336 | // Check and see if capture is partial. |
337 | - if ( $this->is_partial_capture( $notification ) ) { |
|
338 | - $partial_amount = $this->get_partial_amount_to_charge( $notification ); |
|
339 | - $order->set_total( $partial_amount ); |
|
340 | - $this->update_fees( $order, $notification->data->object->refunds->data[0]->balance_transaction ); |
|
337 | + if ($this->is_partial_capture($notification)) { |
|
338 | + $partial_amount = $this->get_partial_amount_to_charge($notification); |
|
339 | + $order->set_total($partial_amount); |
|
340 | + $this->update_fees($order, $notification->data->object->refunds->data[0]->balance_transaction); |
|
341 | 341 | /* translators: partial captured amount */ |
342 | - $order->add_order_note( sprintf( __( 'This charge was partially captured via Stripe Dashboard in the amount of: %s', 'woocommerce-gateway-stripe' ), $partial_amount ) ); |
|
342 | + $order->add_order_note(sprintf(__('This charge was partially captured via Stripe Dashboard in the amount of: %s', 'woocommerce-gateway-stripe'), $partial_amount)); |
|
343 | 343 | } else { |
344 | - $order->payment_complete( $notification->data->object->id ); |
|
344 | + $order->payment_complete($notification->data->object->id); |
|
345 | 345 | |
346 | 346 | /* translators: transaction id */ |
347 | - $order->add_order_note( sprintf( __( 'Stripe charge complete (Charge ID: %s)', 'woocommerce-gateway-stripe' ), $notification->data->object->id ) ); |
|
347 | + $order->add_order_note(sprintf(__('Stripe charge complete (Charge ID: %s)', 'woocommerce-gateway-stripe'), $notification->data->object->id)); |
|
348 | 348 | } |
349 | 349 | |
350 | - if ( is_callable( array( $order, 'save' ) ) ) { |
|
350 | + if (is_callable(array($order, 'save'))) { |
|
351 | 351 | $order->save(); |
352 | 352 | } |
353 | 353 | } |
@@ -362,43 +362,43 @@ discard block |
||
362 | 362 | * @version 4.0.0 |
363 | 363 | * @param object $notification |
364 | 364 | */ |
365 | - public function process_webhook_charge_succeeded( $notification ) { |
|
365 | + public function process_webhook_charge_succeeded($notification) { |
|
366 | 366 | // Ignore the notification for charges, created through PaymentIntents. |
367 | - if ( isset( $notification->data->object->payment_intent ) && $notification->data->object->payment_intent ) { |
|
367 | + if (isset($notification->data->object->payment_intent) && $notification->data->object->payment_intent) { |
|
368 | 368 | return; |
369 | 369 | } |
370 | 370 | |
371 | 371 | // The following payment methods are synchronous so does not need to be handle via webhook. |
372 | - if ( ( isset( $notification->data->object->source->type ) && 'card' === $notification->data->object->source->type ) || ( isset( $notification->data->object->source->type ) && 'three_d_secure' === $notification->data->object->source->type ) ) { |
|
372 | + if ((isset($notification->data->object->source->type) && 'card' === $notification->data->object->source->type) || (isset($notification->data->object->source->type) && 'three_d_secure' === $notification->data->object->source->type)) { |
|
373 | 373 | return; |
374 | 374 | } |
375 | 375 | |
376 | - $order = WC_Stripe_Helper::get_order_by_charge_id( $notification->data->object->id ); |
|
376 | + $order = WC_Stripe_Helper::get_order_by_charge_id($notification->data->object->id); |
|
377 | 377 | |
378 | - if ( ! $order ) { |
|
379 | - WC_Stripe_Logger::log( 'Could not find order via charge ID: ' . $notification->data->object->id ); |
|
378 | + if ( ! $order) { |
|
379 | + WC_Stripe_Logger::log('Could not find order via charge ID: ' . $notification->data->object->id); |
|
380 | 380 | return; |
381 | 381 | } |
382 | 382 | |
383 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
383 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
384 | 384 | |
385 | - if ( ! $order->has_status( 'on-hold' ) ) { |
|
385 | + if ( ! $order->has_status('on-hold')) { |
|
386 | 386 | return; |
387 | 387 | } |
388 | 388 | |
389 | 389 | // Store other data such as fees |
390 | - WC_Stripe_Helper::is_wc_lt( '3.0' ) ? update_post_meta( $order_id, '_transaction_id', $notification->data->object->id ) : $order->set_transaction_id( $notification->data->object->id ); |
|
390 | + WC_Stripe_Helper::is_wc_lt('3.0') ? update_post_meta($order_id, '_transaction_id', $notification->data->object->id) : $order->set_transaction_id($notification->data->object->id); |
|
391 | 391 | |
392 | - if ( isset( $notification->data->object->balance_transaction ) ) { |
|
393 | - $this->update_fees( $order, $notification->data->object->balance_transaction ); |
|
392 | + if (isset($notification->data->object->balance_transaction)) { |
|
393 | + $this->update_fees($order, $notification->data->object->balance_transaction); |
|
394 | 394 | } |
395 | 395 | |
396 | - $order->payment_complete( $notification->data->object->id ); |
|
396 | + $order->payment_complete($notification->data->object->id); |
|
397 | 397 | |
398 | 398 | /* translators: transaction id */ |
399 | - $order->add_order_note( sprintf( __( 'Stripe charge complete (Charge ID: %s)', 'woocommerce-gateway-stripe' ), $notification->data->object->id ) ); |
|
399 | + $order->add_order_note(sprintf(__('Stripe charge complete (Charge ID: %s)', 'woocommerce-gateway-stripe'), $notification->data->object->id)); |
|
400 | 400 | |
401 | - if ( is_callable( array( $order, 'save' ) ) ) { |
|
401 | + if (is_callable(array($order, 'save'))) { |
|
402 | 402 | $order->save(); |
403 | 403 | } |
404 | 404 | } |
@@ -410,24 +410,24 @@ discard block |
||
410 | 410 | * @since 4.1.5 Can handle any fail payments from any methods. |
411 | 411 | * @param object $notification |
412 | 412 | */ |
413 | - public function process_webhook_charge_failed( $notification ) { |
|
414 | - $order = WC_Stripe_Helper::get_order_by_charge_id( $notification->data->object->id ); |
|
413 | + public function process_webhook_charge_failed($notification) { |
|
414 | + $order = WC_Stripe_Helper::get_order_by_charge_id($notification->data->object->id); |
|
415 | 415 | |
416 | - if ( ! $order ) { |
|
417 | - WC_Stripe_Logger::log( 'Could not find order via charge ID: ' . $notification->data->object->id ); |
|
416 | + if ( ! $order) { |
|
417 | + WC_Stripe_Logger::log('Could not find order via charge ID: ' . $notification->data->object->id); |
|
418 | 418 | return; |
419 | 419 | } |
420 | 420 | |
421 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
421 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
422 | 422 | |
423 | 423 | // If order status is already in failed status don't continue. |
424 | - if ( $order->has_status( 'failed' ) ) { |
|
424 | + if ($order->has_status('failed')) { |
|
425 | 425 | return; |
426 | 426 | } |
427 | 427 | |
428 | - $order->update_status( 'failed', __( 'This payment failed to clear.', 'woocommerce-gateway-stripe' ) ); |
|
428 | + $order->update_status('failed', __('This payment failed to clear.', 'woocommerce-gateway-stripe')); |
|
429 | 429 | |
430 | - do_action( 'wc_gateway_stripe_process_webhook_payment_error', $order, $notification ); |
|
430 | + do_action('wc_gateway_stripe_process_webhook_payment_error', $order, $notification); |
|
431 | 431 | } |
432 | 432 | |
433 | 433 | /** |
@@ -438,30 +438,30 @@ discard block |
||
438 | 438 | * @since 4.1.15 Add check to make sure order is processed by Stripe. |
439 | 439 | * @param object $notification |
440 | 440 | */ |
441 | - public function process_webhook_source_canceled( $notification ) { |
|
442 | - $order = WC_Stripe_Helper::get_order_by_charge_id( $notification->data->object->id ); |
|
441 | + public function process_webhook_source_canceled($notification) { |
|
442 | + $order = WC_Stripe_Helper::get_order_by_charge_id($notification->data->object->id); |
|
443 | 443 | |
444 | 444 | // If can't find order by charge ID, try source ID. |
445 | - if ( ! $order ) { |
|
446 | - $order = WC_Stripe_Helper::get_order_by_source_id( $notification->data->object->id ); |
|
445 | + if ( ! $order) { |
|
446 | + $order = WC_Stripe_Helper::get_order_by_source_id($notification->data->object->id); |
|
447 | 447 | |
448 | - if ( ! $order ) { |
|
449 | - WC_Stripe_Logger::log( 'Could not find order via charge/source ID: ' . $notification->data->object->id ); |
|
448 | + if ( ! $order) { |
|
449 | + WC_Stripe_Logger::log('Could not find order via charge/source ID: ' . $notification->data->object->id); |
|
450 | 450 | return; |
451 | 451 | } |
452 | 452 | } |
453 | 453 | |
454 | 454 | // Don't proceed if payment method isn't Stripe. |
455 | - if ( 'stripe' !== $order->get_payment_method() ) { |
|
456 | - WC_Stripe_Logger::log( 'Canceled webhook abort: Order was not processed by Stripe: ' . $order->get_id() ); |
|
455 | + if ('stripe' !== $order->get_payment_method()) { |
|
456 | + WC_Stripe_Logger::log('Canceled webhook abort: Order was not processed by Stripe: ' . $order->get_id()); |
|
457 | 457 | return; |
458 | 458 | } |
459 | 459 | |
460 | - if ( ! $order->has_status( 'cancelled' ) ) { |
|
461 | - $order->update_status( 'cancelled', __( 'This payment has cancelled.', 'woocommerce-gateway-stripe' ) ); |
|
460 | + if ( ! $order->has_status('cancelled')) { |
|
461 | + $order->update_status('cancelled', __('This payment has cancelled.', 'woocommerce-gateway-stripe')); |
|
462 | 462 | } |
463 | 463 | |
464 | - do_action( 'wc_gateway_stripe_process_webhook_payment_error', $order, $notification ); |
|
464 | + do_action('wc_gateway_stripe_process_webhook_payment_error', $order, $notification); |
|
465 | 465 | } |
466 | 466 | |
467 | 467 | /** |
@@ -471,59 +471,59 @@ discard block |
||
471 | 471 | * @version 4.0.0 |
472 | 472 | * @param object $notification |
473 | 473 | */ |
474 | - public function process_webhook_refund( $notification ) { |
|
475 | - $order = WC_Stripe_Helper::get_order_by_charge_id( $notification->data->object->id ); |
|
474 | + public function process_webhook_refund($notification) { |
|
475 | + $order = WC_Stripe_Helper::get_order_by_charge_id($notification->data->object->id); |
|
476 | 476 | |
477 | - if ( ! $order ) { |
|
478 | - WC_Stripe_Logger::log( 'Could not find order via charge ID: ' . $notification->data->object->id ); |
|
477 | + if ( ! $order) { |
|
478 | + WC_Stripe_Logger::log('Could not find order via charge ID: ' . $notification->data->object->id); |
|
479 | 479 | return; |
480 | 480 | } |
481 | 481 | |
482 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
482 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
483 | 483 | |
484 | - if ( 'stripe' === ( WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->payment_method : $order->get_payment_method() ) ) { |
|
485 | - $charge = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? get_post_meta( $order_id, '_transaction_id', true ) : $order->get_transaction_id(); |
|
486 | - $captured = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? get_post_meta( $order_id, '_stripe_charge_captured', true ) : $order->get_meta( '_stripe_charge_captured', true ); |
|
487 | - $refund_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? get_post_meta( $order_id, '_stripe_refund_id', true ) : $order->get_meta( '_stripe_refund_id', true ); |
|
484 | + if ('stripe' === (WC_Stripe_Helper::is_wc_lt('3.0') ? $order->payment_method : $order->get_payment_method())) { |
|
485 | + $charge = WC_Stripe_Helper::is_wc_lt('3.0') ? get_post_meta($order_id, '_transaction_id', true) : $order->get_transaction_id(); |
|
486 | + $captured = WC_Stripe_Helper::is_wc_lt('3.0') ? get_post_meta($order_id, '_stripe_charge_captured', true) : $order->get_meta('_stripe_charge_captured', true); |
|
487 | + $refund_id = WC_Stripe_Helper::is_wc_lt('3.0') ? get_post_meta($order_id, '_stripe_refund_id', true) : $order->get_meta('_stripe_refund_id', true); |
|
488 | 488 | |
489 | 489 | // If the refund ID matches, don't continue to prevent double refunding. |
490 | - if ( $notification->data->object->refunds->data[0]->id === $refund_id ) { |
|
490 | + if ($notification->data->object->refunds->data[0]->id === $refund_id) { |
|
491 | 491 | return; |
492 | 492 | } |
493 | 493 | |
494 | 494 | // Only refund captured charge. |
495 | - if ( $charge ) { |
|
496 | - $reason = ( isset( $captured ) && 'yes' === $captured ) ? __( 'Refunded via Stripe Dashboard', 'woocommerce-gateway-stripe' ) : __( 'Pre-Authorization Released via Stripe Dashboard', 'woocommerce-gateway-stripe' ); |
|
495 | + if ($charge) { |
|
496 | + $reason = (isset($captured) && 'yes' === $captured) ? __('Refunded via Stripe Dashboard', 'woocommerce-gateway-stripe') : __('Pre-Authorization Released via Stripe Dashboard', 'woocommerce-gateway-stripe'); |
|
497 | 497 | |
498 | 498 | // Create the refund. |
499 | 499 | $refund = wc_create_refund( |
500 | 500 | array( |
501 | 501 | 'order_id' => $order_id, |
502 | - 'amount' => $this->get_refund_amount( $notification ), |
|
502 | + 'amount' => $this->get_refund_amount($notification), |
|
503 | 503 | 'reason' => $reason, |
504 | 504 | ) |
505 | 505 | ); |
506 | 506 | |
507 | - if ( is_wp_error( $refund ) ) { |
|
508 | - WC_Stripe_Logger::log( $refund->get_error_message() ); |
|
507 | + if (is_wp_error($refund)) { |
|
508 | + WC_Stripe_Logger::log($refund->get_error_message()); |
|
509 | 509 | } |
510 | 510 | |
511 | - WC_Stripe_Helper::is_wc_lt( '3.0' ) ? update_post_meta( $order_id, '_stripe_refund_id', $notification->data->object->refunds->data[0]->id ) : $order->update_meta_data( '_stripe_refund_id', $notification->data->object->refunds->data[0]->id ); |
|
511 | + WC_Stripe_Helper::is_wc_lt('3.0') ? update_post_meta($order_id, '_stripe_refund_id', $notification->data->object->refunds->data[0]->id) : $order->update_meta_data('_stripe_refund_id', $notification->data->object->refunds->data[0]->id); |
|
512 | 512 | |
513 | - $amount = wc_price( $notification->data->object->refunds->data[0]->amount / 100 ); |
|
513 | + $amount = wc_price($notification->data->object->refunds->data[0]->amount / 100); |
|
514 | 514 | |
515 | - if ( in_array( strtolower( WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->get_order_currency() : $order->get_currency() ), WC_Stripe_Helper::no_decimal_currencies() ) ) { |
|
516 | - $amount = wc_price( $notification->data->object->refunds->data[0]->amount ); |
|
515 | + if (in_array(strtolower(WC_Stripe_Helper::is_wc_lt('3.0') ? $order->get_order_currency() : $order->get_currency()), WC_Stripe_Helper::no_decimal_currencies())) { |
|
516 | + $amount = wc_price($notification->data->object->refunds->data[0]->amount); |
|
517 | 517 | } |
518 | 518 | |
519 | - if ( isset( $notification->data->object->refunds->data[0]->balance_transaction ) ) { |
|
520 | - $this->update_fees( $order, $notification->data->object->refunds->data[0]->balance_transaction ); |
|
519 | + if (isset($notification->data->object->refunds->data[0]->balance_transaction)) { |
|
520 | + $this->update_fees($order, $notification->data->object->refunds->data[0]->balance_transaction); |
|
521 | 521 | } |
522 | 522 | |
523 | 523 | /* translators: 1) dollar amount 2) transaction id 3) refund message */ |
524 | - $refund_message = ( isset( $captured ) && 'yes' === $captured ) ? sprintf( __( 'Refunded %1$s - Refund ID: %2$s - %3$s', 'woocommerce-gateway-stripe' ), $amount, $notification->data->object->refunds->data[0]->id, $reason ) : __( 'Pre-Authorization Released via Stripe Dashboard', 'woocommerce-gateway-stripe' ); |
|
524 | + $refund_message = (isset($captured) && 'yes' === $captured) ? sprintf(__('Refunded %1$s - Refund ID: %2$s - %3$s', 'woocommerce-gateway-stripe'), $amount, $notification->data->object->refunds->data[0]->id, $reason) : __('Pre-Authorization Released via Stripe Dashboard', 'woocommerce-gateway-stripe'); |
|
525 | 525 | |
526 | - $order->add_order_note( $refund_message ); |
|
526 | + $order->add_order_note($refund_message); |
|
527 | 527 | } |
528 | 528 | } |
529 | 529 | } |
@@ -534,30 +534,30 @@ discard block |
||
534 | 534 | * @since 4.0.6 |
535 | 535 | * @param object $notification |
536 | 536 | */ |
537 | - public function process_review_opened( $notification ) { |
|
538 | - if ( isset( $notification->data->object->payment_intent ) ) { |
|
539 | - $order = WC_Stripe_Helper::get_order_by_intent_id( $notification->data->object->payment_intent ); |
|
537 | + public function process_review_opened($notification) { |
|
538 | + if (isset($notification->data->object->payment_intent)) { |
|
539 | + $order = WC_Stripe_Helper::get_order_by_intent_id($notification->data->object->payment_intent); |
|
540 | 540 | |
541 | - if ( ! $order ) { |
|
542 | - WC_Stripe_Logger::log( '[Review Opened] Could not find order via intent ID: ' . $notification->data->object->payment_intent ); |
|
541 | + if ( ! $order) { |
|
542 | + WC_Stripe_Logger::log('[Review Opened] Could not find order via intent ID: ' . $notification->data->object->payment_intent); |
|
543 | 543 | return; |
544 | 544 | } |
545 | 545 | } else { |
546 | - $order = WC_Stripe_Helper::get_order_by_charge_id( $notification->data->object->charge ); |
|
546 | + $order = WC_Stripe_Helper::get_order_by_charge_id($notification->data->object->charge); |
|
547 | 547 | |
548 | - if ( ! $order ) { |
|
549 | - WC_Stripe_Logger::log( '[Review Opened] Could not find order via charge ID: ' . $notification->data->object->charge ); |
|
548 | + if ( ! $order) { |
|
549 | + WC_Stripe_Logger::log('[Review Opened] Could not find order via charge ID: ' . $notification->data->object->charge); |
|
550 | 550 | return; |
551 | 551 | } |
552 | 552 | } |
553 | 553 | |
554 | 554 | /* translators: 1) The URL to the order. 2) The reason type. */ |
555 | - $message = sprintf( __( 'A review has been opened for this order. Action is needed. Please go to your <a href="%1$s" title="Stripe Dashboard" target="_blank">Stripe Dashboard</a> to review the issue. Reason: (%2$s)', 'woocommerce-gateway-stripe' ), $this->get_transaction_url( $order ), $notification->data->object->reason ); |
|
555 | + $message = sprintf(__('A review has been opened for this order. Action is needed. Please go to your <a href="%1$s" title="Stripe Dashboard" target="_blank">Stripe Dashboard</a> to review the issue. Reason: (%2$s)', 'woocommerce-gateway-stripe'), $this->get_transaction_url($order), $notification->data->object->reason); |
|
556 | 556 | |
557 | - if ( apply_filters( 'wc_stripe_webhook_review_change_order_status', true, $order, $notification ) ) { |
|
558 | - $order->update_status( 'on-hold', $message ); |
|
557 | + if (apply_filters('wc_stripe_webhook_review_change_order_status', true, $order, $notification)) { |
|
558 | + $order->update_status('on-hold', $message); |
|
559 | 559 | } else { |
560 | - $order->add_order_note( $message ); |
|
560 | + $order->add_order_note($message); |
|
561 | 561 | } |
562 | 562 | } |
563 | 563 | |
@@ -567,34 +567,34 @@ discard block |
||
567 | 567 | * @since 4.0.6 |
568 | 568 | * @param object $notification |
569 | 569 | */ |
570 | - public function process_review_closed( $notification ) { |
|
571 | - if ( isset( $notification->data->object->payment_intent ) ) { |
|
572 | - $order = WC_Stripe_Helper::get_order_by_intent_id( $notification->data->object->payment_intent ); |
|
570 | + public function process_review_closed($notification) { |
|
571 | + if (isset($notification->data->object->payment_intent)) { |
|
572 | + $order = WC_Stripe_Helper::get_order_by_intent_id($notification->data->object->payment_intent); |
|
573 | 573 | |
574 | - if ( ! $order ) { |
|
575 | - WC_Stripe_Logger::log( '[Review Closed] Could not find order via intent ID: ' . $notification->data->object->payment_intent ); |
|
574 | + if ( ! $order) { |
|
575 | + WC_Stripe_Logger::log('[Review Closed] Could not find order via intent ID: ' . $notification->data->object->payment_intent); |
|
576 | 576 | return; |
577 | 577 | } |
578 | 578 | } else { |
579 | - $order = WC_Stripe_Helper::get_order_by_charge_id( $notification->data->object->charge ); |
|
579 | + $order = WC_Stripe_Helper::get_order_by_charge_id($notification->data->object->charge); |
|
580 | 580 | |
581 | - if ( ! $order ) { |
|
582 | - WC_Stripe_Logger::log( '[Review Closed] Could not find order via charge ID: ' . $notification->data->object->charge ); |
|
581 | + if ( ! $order) { |
|
582 | + WC_Stripe_Logger::log('[Review Closed] Could not find order via charge ID: ' . $notification->data->object->charge); |
|
583 | 583 | return; |
584 | 584 | } |
585 | 585 | } |
586 | 586 | |
587 | 587 | /* translators: 1) The reason type. */ |
588 | - $message = sprintf( __( 'The opened review for this order is now closed. Reason: (%s)', 'woocommerce-gateway-stripe' ), $notification->data->object->reason ); |
|
588 | + $message = sprintf(__('The opened review for this order is now closed. Reason: (%s)', 'woocommerce-gateway-stripe'), $notification->data->object->reason); |
|
589 | 589 | |
590 | - if ( $order->has_status( 'on-hold' ) ) { |
|
591 | - if ( apply_filters( 'wc_stripe_webhook_review_change_order_status', true, $order, $notification ) ) { |
|
592 | - $order->update_status( 'processing', $message ); |
|
590 | + if ($order->has_status('on-hold')) { |
|
591 | + if (apply_filters('wc_stripe_webhook_review_change_order_status', true, $order, $notification)) { |
|
592 | + $order->update_status('processing', $message); |
|
593 | 593 | } else { |
594 | - $order->add_order_note( $message ); |
|
594 | + $order->add_order_note($message); |
|
595 | 595 | } |
596 | 596 | } else { |
597 | - $order->add_order_note( $message ); |
|
597 | + $order->add_order_note($message); |
|
598 | 598 | } |
599 | 599 | } |
600 | 600 | |
@@ -605,7 +605,7 @@ discard block |
||
605 | 605 | * @version 4.0.0 |
606 | 606 | * @param object $notification |
607 | 607 | */ |
608 | - public function is_partial_capture( $notification ) { |
|
608 | + public function is_partial_capture($notification) { |
|
609 | 609 | return 0 < $notification->data->object->amount_refunded; |
610 | 610 | } |
611 | 611 | |
@@ -616,11 +616,11 @@ discard block |
||
616 | 616 | * @version 4.0.0 |
617 | 617 | * @param object $notification |
618 | 618 | */ |
619 | - public function get_refund_amount( $notification ) { |
|
620 | - if ( $this->is_partial_capture( $notification ) ) { |
|
619 | + public function get_refund_amount($notification) { |
|
620 | + if ($this->is_partial_capture($notification)) { |
|
621 | 621 | $amount = $notification->data->object->refunds->data[0]->amount / 100; |
622 | 622 | |
623 | - if ( in_array( strtolower( $notification->data->object->currency ), WC_Stripe_Helper::no_decimal_currencies() ) ) { |
|
623 | + if (in_array(strtolower($notification->data->object->currency), WC_Stripe_Helper::no_decimal_currencies())) { |
|
624 | 624 | $amount = $notification->data->object->refunds->data[0]->amount; |
625 | 625 | } |
626 | 626 | |
@@ -637,12 +637,12 @@ discard block |
||
637 | 637 | * @version 4.0.0 |
638 | 638 | * @param object $notification |
639 | 639 | */ |
640 | - public function get_partial_amount_to_charge( $notification ) { |
|
641 | - if ( $this->is_partial_capture( $notification ) ) { |
|
642 | - $amount = ( $notification->data->object->amount - $notification->data->object->amount_refunded ) / 100; |
|
640 | + public function get_partial_amount_to_charge($notification) { |
|
641 | + if ($this->is_partial_capture($notification)) { |
|
642 | + $amount = ($notification->data->object->amount - $notification->data->object->amount_refunded) / 100; |
|
643 | 643 | |
644 | - if ( in_array( strtolower( $notification->data->object->currency ), WC_Stripe_Helper::no_decimal_currencies() ) ) { |
|
645 | - $amount = ( $notification->data->object->amount - $notification->data->object->amount_refunded ); |
|
644 | + if (in_array(strtolower($notification->data->object->currency), WC_Stripe_Helper::no_decimal_currencies())) { |
|
645 | + $amount = ($notification->data->object->amount - $notification->data->object->amount_refunded); |
|
646 | 646 | } |
647 | 647 | |
648 | 648 | return $amount; |
@@ -651,69 +651,69 @@ discard block |
||
651 | 651 | return false; |
652 | 652 | } |
653 | 653 | |
654 | - public function process_payment_intent_success( $notification ) { |
|
654 | + public function process_payment_intent_success($notification) { |
|
655 | 655 | $intent = $notification->data->object; |
656 | - $order = WC_Stripe_Helper::get_order_by_intent_id( $intent->id ); |
|
656 | + $order = WC_Stripe_Helper::get_order_by_intent_id($intent->id); |
|
657 | 657 | |
658 | - if ( ! $order ) { |
|
659 | - WC_Stripe_Logger::log( 'Could not find order via intent ID: ' . $intent->id ); |
|
658 | + if ( ! $order) { |
|
659 | + WC_Stripe_Logger::log('Could not find order via intent ID: ' . $intent->id); |
|
660 | 660 | return; |
661 | 661 | } |
662 | 662 | |
663 | - if ( ! $order->has_status( array( 'pending', 'failed' ) ) ) { |
|
663 | + if ( ! $order->has_status(array('pending', 'failed'))) { |
|
664 | 664 | return; |
665 | 665 | } |
666 | 666 | |
667 | - if ( $this->lock_order_payment( $order, $intent ) ) { |
|
667 | + if ($this->lock_order_payment($order, $intent)) { |
|
668 | 668 | return; |
669 | 669 | } |
670 | 670 | |
671 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
672 | - if ( 'payment_intent.succeeded' === $notification->type || 'payment_intent.amount_capturable_updated' === $notification->type ) { |
|
673 | - $charge = end( $intent->charges->data ); |
|
674 | - WC_Stripe_Logger::log( "Stripe PaymentIntent $intent->id succeeded for order $order_id" ); |
|
671 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
672 | + if ('payment_intent.succeeded' === $notification->type || 'payment_intent.amount_capturable_updated' === $notification->type) { |
|
673 | + $charge = end($intent->charges->data); |
|
674 | + WC_Stripe_Logger::log("Stripe PaymentIntent $intent->id succeeded for order $order_id"); |
|
675 | 675 | |
676 | - do_action( 'wc_gateway_stripe_process_payment', $charge, $order ); |
|
676 | + do_action('wc_gateway_stripe_process_payment', $charge, $order); |
|
677 | 677 | |
678 | 678 | // Process valid response. |
679 | - $this->process_response( $charge, $order ); |
|
679 | + $this->process_response($charge, $order); |
|
680 | 680 | |
681 | 681 | } else { |
682 | 682 | $error_message = $intent->last_payment_error ? $intent->last_payment_error->message : ""; |
683 | 683 | |
684 | 684 | /* translators: 1) The error message that was received from Stripe. */ |
685 | - $order->update_status( 'failed', sprintf( __( 'Stripe SCA authentication failed. Reason: %s', 'woocommerce-gateway-stripe' ), $error_message ) ); |
|
685 | + $order->update_status('failed', sprintf(__('Stripe SCA authentication failed. Reason: %s', 'woocommerce-gateway-stripe'), $error_message)); |
|
686 | 686 | |
687 | - do_action( 'wc_gateway_stripe_process_webhook_payment_error', $order, $notification ); |
|
687 | + do_action('wc_gateway_stripe_process_webhook_payment_error', $order, $notification); |
|
688 | 688 | |
689 | - $this->send_failed_order_email( $order_id ); |
|
689 | + $this->send_failed_order_email($order_id); |
|
690 | 690 | } |
691 | 691 | |
692 | - $this->unlock_order_payment( $order ); |
|
692 | + $this->unlock_order_payment($order); |
|
693 | 693 | } |
694 | 694 | |
695 | - public function process_setup_intent( $notification ) { |
|
695 | + public function process_setup_intent($notification) { |
|
696 | 696 | $intent = $notification->data->object; |
697 | - $order = WC_Stripe_Helper::get_order_by_setup_intent_id( $intent->id ); |
|
697 | + $order = WC_Stripe_Helper::get_order_by_setup_intent_id($intent->id); |
|
698 | 698 | |
699 | - if ( ! $order ) { |
|
700 | - WC_Stripe_Logger::log( 'Could not find order via setup intent ID: ' . $intent->id ); |
|
699 | + if ( ! $order) { |
|
700 | + WC_Stripe_Logger::log('Could not find order via setup intent ID: ' . $intent->id); |
|
701 | 701 | return; |
702 | 702 | } |
703 | 703 | |
704 | - if ( ! $order->has_status( array( 'pending', 'failed' ) ) ) { |
|
704 | + if ( ! $order->has_status(array('pending', 'failed'))) { |
|
705 | 705 | return; |
706 | 706 | } |
707 | 707 | |
708 | - if ( $this->lock_order_payment( $order, $intent ) ) { |
|
708 | + if ($this->lock_order_payment($order, $intent)) { |
|
709 | 709 | return; |
710 | 710 | } |
711 | 711 | |
712 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->id : $order->get_id(); |
|
713 | - if ( 'setup_intent.succeeded' === $notification->type ) { |
|
714 | - WC_Stripe_Logger::log( "Stripe SetupIntent $intent->id succeeded for order $order_id" ); |
|
715 | - if ( WC_Stripe_Helper::is_pre_orders_exists() && WC_Pre_Orders_Order::order_contains_pre_order( $order ) ) { |
|
716 | - WC_Pre_Orders_Order::mark_order_as_pre_ordered( $order ); |
|
712 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->id : $order->get_id(); |
|
713 | + if ('setup_intent.succeeded' === $notification->type) { |
|
714 | + WC_Stripe_Logger::log("Stripe SetupIntent $intent->id succeeded for order $order_id"); |
|
715 | + if (WC_Stripe_Helper::is_pre_orders_exists() && WC_Pre_Orders_Order::order_contains_pre_order($order)) { |
|
716 | + WC_Pre_Orders_Order::mark_order_as_pre_ordered($order); |
|
717 | 717 | } else { |
718 | 718 | $order->payment_complete(); |
719 | 719 | } |
@@ -721,12 +721,12 @@ discard block |
||
721 | 721 | $error_message = $intent->last_setup_error ? $intent->last_setup_error->message : ""; |
722 | 722 | |
723 | 723 | /* translators: 1) The error message that was received from Stripe. */ |
724 | - $order->update_status( 'failed', sprintf( __( 'Stripe SCA authentication failed. Reason: %s', 'woocommerce-gateway-stripe' ), $error_message ) ); |
|
724 | + $order->update_status('failed', sprintf(__('Stripe SCA authentication failed. Reason: %s', 'woocommerce-gateway-stripe'), $error_message)); |
|
725 | 725 | |
726 | - $this->send_failed_order_email( $order_id ); |
|
726 | + $this->send_failed_order_email($order_id); |
|
727 | 727 | } |
728 | 728 | |
729 | - $this->unlock_order_payment( $order ); |
|
729 | + $this->unlock_order_payment($order); |
|
730 | 730 | } |
731 | 731 | |
732 | 732 | /** |
@@ -736,55 +736,55 @@ discard block |
||
736 | 736 | * @version 4.0.0 |
737 | 737 | * @param string $request_body |
738 | 738 | */ |
739 | - public function process_webhook( $request_body ) { |
|
740 | - $notification = json_decode( $request_body ); |
|
739 | + public function process_webhook($request_body) { |
|
740 | + $notification = json_decode($request_body); |
|
741 | 741 | |
742 | - switch ( $notification->type ) { |
|
742 | + switch ($notification->type) { |
|
743 | 743 | case 'source.chargeable': |
744 | - $this->process_webhook_payment( $notification ); |
|
744 | + $this->process_webhook_payment($notification); |
|
745 | 745 | break; |
746 | 746 | |
747 | 747 | case 'source.canceled': |
748 | - $this->process_webhook_source_canceled( $notification ); |
|
748 | + $this->process_webhook_source_canceled($notification); |
|
749 | 749 | break; |
750 | 750 | |
751 | 751 | case 'charge.succeeded': |
752 | - $this->process_webhook_charge_succeeded( $notification ); |
|
752 | + $this->process_webhook_charge_succeeded($notification); |
|
753 | 753 | break; |
754 | 754 | |
755 | 755 | case 'charge.failed': |
756 | - $this->process_webhook_charge_failed( $notification ); |
|
756 | + $this->process_webhook_charge_failed($notification); |
|
757 | 757 | break; |
758 | 758 | |
759 | 759 | case 'charge.captured': |
760 | - $this->process_webhook_capture( $notification ); |
|
760 | + $this->process_webhook_capture($notification); |
|
761 | 761 | break; |
762 | 762 | |
763 | 763 | case 'charge.dispute.created': |
764 | - $this->process_webhook_dispute( $notification ); |
|
764 | + $this->process_webhook_dispute($notification); |
|
765 | 765 | break; |
766 | 766 | |
767 | 767 | case 'charge.refunded': |
768 | - $this->process_webhook_refund( $notification ); |
|
768 | + $this->process_webhook_refund($notification); |
|
769 | 769 | break; |
770 | 770 | |
771 | 771 | case 'review.opened': |
772 | - $this->process_review_opened( $notification ); |
|
772 | + $this->process_review_opened($notification); |
|
773 | 773 | break; |
774 | 774 | |
775 | 775 | case 'review.closed': |
776 | - $this->process_review_closed( $notification ); |
|
776 | + $this->process_review_closed($notification); |
|
777 | 777 | break; |
778 | 778 | |
779 | 779 | case 'payment_intent.succeeded': |
780 | 780 | case 'payment_intent.payment_failed': |
781 | 781 | case 'payment_intent.amount_capturable_updated': |
782 | - $this->process_payment_intent_success( $notification ); |
|
782 | + $this->process_payment_intent_success($notification); |
|
783 | 783 | break; |
784 | 784 | |
785 | 785 | case 'setup_intent.succeeded': |
786 | 786 | case 'setup_intent.setup_failed': |
787 | - $this->process_setup_intent( $notification ); |
|
787 | + $this->process_setup_intent($notification); |
|
788 | 788 | |
789 | 789 | } |
790 | 790 | } |
@@ -34,9 +34,9 @@ discard block |
||
34 | 34 | public function setUp() { |
35 | 35 | parent::setUp(); |
36 | 36 | |
37 | - $this->wc_stripe_subs_compat = $this->getMockBuilder( 'WC_Stripe_Subs_Compat' ) |
|
37 | + $this->wc_stripe_subs_compat = $this->getMockBuilder('WC_Stripe_Subs_Compat') |
|
38 | 38 | ->disableOriginalConstructor() |
39 | - ->setMethods( array( 'prepare_source', 'has_subscription' ) ) |
|
39 | + ->setMethods(array('prepare_source', 'has_subscription')) |
|
40 | 40 | ->getMock(); |
41 | 41 | |
42 | 42 | // Mocked in order to get metadata[payment_type] = recurring in the HTTP request. |
@@ -54,7 +54,7 @@ discard block |
||
54 | 54 | */ |
55 | 55 | public function tearDown() { |
56 | 56 | parent::tearDown(); |
57 | - delete_option( 'woocommerce_stripe_settings' ); |
|
57 | + delete_option('woocommerce_stripe_settings'); |
|
58 | 58 | } |
59 | 59 | |
60 | 60 | /** |
@@ -69,27 +69,27 @@ discard block |
||
69 | 69 | */ |
70 | 70 | public function test_initial_intent_parameters() { |
71 | 71 | $initial_order = WC_Helper_Order::create_order(); |
72 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $initial_order->id : $initial_order->get_id(); |
|
73 | - $stripe_amount = WC_Stripe_Helper::get_stripe_amount( $initial_order->get_total() ); |
|
74 | - $currency = strtolower( WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $initial_order->get_order_currency() : $initial_order->get_currency() ); |
|
72 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $initial_order->id : $initial_order->get_id(); |
|
73 | + $stripe_amount = WC_Stripe_Helper::get_stripe_amount($initial_order->get_total()); |
|
74 | + $currency = strtolower(WC_Stripe_Helper::is_wc_lt('3.0') ? $initial_order->get_order_currency() : $initial_order->get_currency()); |
|
75 | 75 | $customer = 'cus_123abc'; |
76 | 76 | $source = 'src_123abc'; |
77 | - $statement_descriptor = WC_Stripe_Helper::clean_statement_descriptor( $this->statement_descriptor ); |
|
77 | + $statement_descriptor = WC_Stripe_Helper::clean_statement_descriptor($this->statement_descriptor); |
|
78 | 78 | $intents_api_endpoint = 'https://api.stripe.com/v1/payment_intents'; |
79 | 79 | $urls_used = array(); |
80 | 80 | |
81 | - if ( WC_Stripe_Helper::is_wc_lt( '3.0' ) ) { |
|
81 | + if (WC_Stripe_Helper::is_wc_lt('3.0')) { |
|
82 | 82 | $initial_order->payment_method = 'stripe'; |
83 | - update_post_meta( $order_id, '_payment_method', 'stripe' ); // for `wc_get_order()`. |
|
83 | + update_post_meta($order_id, '_payment_method', 'stripe'); // for `wc_get_order()`. |
|
84 | 84 | } else { |
85 | - $initial_order->set_payment_method( 'stripe' ); |
|
85 | + $initial_order->set_payment_method('stripe'); |
|
86 | 86 | $initial_order->save(); |
87 | 87 | } |
88 | 88 | |
89 | 89 | // Arrange: Mock prepare_source() so that we have a customer and source. |
90 | 90 | $this->wc_stripe_subs_compat |
91 | - ->expects( $this->any() ) |
|
92 | - ->method( 'prepare_source' ) |
|
91 | + ->expects($this->any()) |
|
92 | + ->method('prepare_source') |
|
93 | 93 | ->will( |
94 | 94 | $this->returnValue( |
95 | 95 | (object) array( |
@@ -103,11 +103,11 @@ discard block |
||
103 | 103 | |
104 | 104 | // Emulate a subscription. |
105 | 105 | $this->wc_stripe_subs_compat |
106 | - ->expects( $this->any() ) |
|
107 | - ->method( 'has_subscription' ) |
|
108 | - ->will( $this->returnValue( true ) ); |
|
106 | + ->expects($this->any()) |
|
107 | + ->method('has_subscription') |
|
108 | + ->will($this->returnValue(true)); |
|
109 | 109 | |
110 | - $pre_http_request_response_callback = function( $preempt, $request_args, $url ) use ( |
|
110 | + $pre_http_request_response_callback = function($preempt, $request_args, $url) use ( |
|
111 | 111 | $stripe_amount, |
112 | 112 | $currency, |
113 | 113 | $customer, |
@@ -118,9 +118,9 @@ discard block |
||
118 | 118 | &$urls_used |
119 | 119 | ) { |
120 | 120 | // Add all urls to array so we can later make assertions about which endpoints were used. |
121 | - array_push( $urls_used, $url ); |
|
121 | + array_push($urls_used, $url); |
|
122 | 122 | // Continue without mocking the request if it's not the endpoint we care about. |
123 | - if ( 0 !== strpos( $url, $intents_api_endpoint ) ) { |
|
123 | + if (0 !== strpos($url, $intents_api_endpoint)) { |
|
124 | 124 | return false; |
125 | 125 | } |
126 | 126 | |
@@ -128,7 +128,7 @@ discard block |
||
128 | 128 | $response = array( |
129 | 129 | 'headers' => array(), |
130 | 130 | // Too bad we aren't dynamically setting things 'cus_123abc' when using this file. |
131 | - 'body' => file_get_contents( 'tests/phpunit/dummy-data/subscription_signup_response_success.json' ), |
|
131 | + 'body' => file_get_contents('tests/phpunit/dummy-data/subscription_signup_response_success.json'), |
|
132 | 132 | 'response' => array( |
133 | 133 | 'code' => 200, |
134 | 134 | 'message' => 'OK', |
@@ -138,17 +138,17 @@ discard block |
||
138 | 138 | ); |
139 | 139 | |
140 | 140 | // Respond with a successfull intent for confirmations. |
141 | - if ( $url !== $intents_api_endpoint ) { |
|
142 | - $response['body'] = str_replace( 'requires_confirmation', 'succeeded', $response['body'] ); |
|
141 | + if ($url !== $intents_api_endpoint) { |
|
142 | + $response['body'] = str_replace('requires_confirmation', 'succeeded', $response['body']); |
|
143 | 143 | return $response; |
144 | 144 | } |
145 | 145 | |
146 | 146 | // Assert: the request method is POST. |
147 | - $this->assertArrayHasKey( 'method', $request_args ); |
|
148 | - $this->assertSame( 'POST', $request_args['method'] ); |
|
147 | + $this->assertArrayHasKey('method', $request_args); |
|
148 | + $this->assertSame('POST', $request_args['method']); |
|
149 | 149 | |
150 | 150 | // Assert: the request has a body. |
151 | - $this->assertArrayHasKey( 'body', $request_args ); |
|
151 | + $this->assertArrayHasKey('body', $request_args); |
|
152 | 152 | |
153 | 153 | // Assert: the request body contains these values. |
154 | 154 | $expected_request_body_values = array( |
@@ -158,11 +158,11 @@ discard block |
||
158 | 158 | 'statement_descriptor' => $statement_descriptor, |
159 | 159 | 'customer' => $customer, |
160 | 160 | 'setup_future_usage' => 'off_session', |
161 | - 'payment_method_types' => array( 'card' ), |
|
161 | + 'payment_method_types' => array('card'), |
|
162 | 162 | ); |
163 | - foreach ( $expected_request_body_values as $key => $value ) { |
|
164 | - $this->assertArrayHasKey( $key, $request_args['body'] ); |
|
165 | - $this->assertSame( $value, $request_args['body'][ $key ] ); |
|
163 | + foreach ($expected_request_body_values as $key => $value) { |
|
164 | + $this->assertArrayHasKey($key, $request_args['body']); |
|
165 | + $this->assertSame($value, $request_args['body'][$key]); |
|
166 | 166 | } |
167 | 167 | |
168 | 168 | // Assert: the request body contains these keys, without checking for their value. |
@@ -170,48 +170,48 @@ discard block |
||
170 | 170 | 'description', |
171 | 171 | 'capture_method', |
172 | 172 | ); |
173 | - foreach ( $expected_request_body_keys as $key ) { |
|
174 | - $this->assertArrayHasKey( $key, $request_args['body'] ); |
|
173 | + foreach ($expected_request_body_keys as $key) { |
|
174 | + $this->assertArrayHasKey($key, $request_args['body']); |
|
175 | 175 | } |
176 | 176 | |
177 | 177 | // Assert: the body metadata contains the order ID. |
178 | - $this->assertSame( $order_id, absint( $request_args['body']['metadata']['order_id'] ) ); |
|
178 | + $this->assertSame($order_id, absint($request_args['body']['metadata']['order_id'])); |
|
179 | 179 | |
180 | 180 | // // Assert: the body metadata has these keys, without checking for their value. |
181 | 181 | $expected_metadata_keys = array( |
182 | 182 | 'customer_name', |
183 | 183 | 'customer_email', |
184 | 184 | ); |
185 | - foreach ( $expected_metadata_keys as $key ) { |
|
186 | - $this->assertArrayHasKey( $key, $request_args['body']['metadata'] ); |
|
185 | + foreach ($expected_metadata_keys as $key) { |
|
186 | + $this->assertArrayHasKey($key, $request_args['body']['metadata']); |
|
187 | 187 | } |
188 | 188 | |
189 | 189 | // Return dummy content as the response. |
190 | 190 | return $response; |
191 | 191 | }; |
192 | - add_filter( 'pre_http_request', $pre_http_request_response_callback, 10, 3 ); |
|
192 | + add_filter('pre_http_request', $pre_http_request_response_callback, 10, 3); |
|
193 | 193 | |
194 | 194 | // Act: call process_subscription_payment(). |
195 | 195 | // We need to use `wc_stripe_subs_compat` here because we mocked this class earlier. |
196 | - $result = $this->wc_stripe_subs_compat->process_payment( $order_id ); |
|
196 | + $result = $this->wc_stripe_subs_compat->process_payment($order_id); |
|
197 | 197 | |
198 | 198 | // Assert: nothing was returned. |
199 | - $this->assertEquals( $result['result'], 'success' ); |
|
200 | - $this->assertArrayHasKey( 'redirect', $result ); |
|
199 | + $this->assertEquals($result['result'], 'success'); |
|
200 | + $this->assertArrayHasKey('redirect', $result); |
|
201 | 201 | |
202 | - $order = wc_get_order( $order_id ); |
|
202 | + $order = wc_get_order($order_id); |
|
203 | 203 | $order_data = ( |
204 | - WC_Stripe_Helper::is_wc_lt( '3.0' ) |
|
205 | - ? get_post_meta( $order_id, '_stripe_intent_id', true ) |
|
206 | - : $order->get_meta( '_stripe_intent_id' ) |
|
204 | + WC_Stripe_Helper::is_wc_lt('3.0') |
|
205 | + ? get_post_meta($order_id, '_stripe_intent_id', true) |
|
206 | + : $order->get_meta('_stripe_intent_id') |
|
207 | 207 | ); |
208 | 208 | |
209 | - $this->assertEquals( $order_data, 'pi_123abc' ); |
|
209 | + $this->assertEquals($order_data, 'pi_123abc'); |
|
210 | 210 | |
211 | 211 | // Assert: called payment intents. |
212 | - $this->assertTrue( in_array( $intents_api_endpoint, $urls_used, true ) ); |
|
212 | + $this->assertTrue(in_array($intents_api_endpoint, $urls_used, true)); |
|
213 | 213 | |
214 | 214 | // Clean up. |
215 | - remove_filter( 'pre_http_request', array( $this, 'pre_http_request_response_success' ) ); |
|
215 | + remove_filter('pre_http_request', array($this, 'pre_http_request_response_success')); |
|
216 | 216 | } |
217 | 217 | } |
@@ -34,17 +34,17 @@ discard block |
||
34 | 34 | public function setUp() { |
35 | 35 | parent::setUp(); |
36 | 36 | |
37 | - $this->wc_stripe_subs_compat = $this->getMockBuilder( 'WC_Stripe_Subs_Compat' ) |
|
37 | + $this->wc_stripe_subs_compat = $this->getMockBuilder('WC_Stripe_Subs_Compat') |
|
38 | 38 | ->disableOriginalConstructor() |
39 | - ->setMethods( array( 'prepare_order_source', 'has_subscription' ) ) |
|
39 | + ->setMethods(array('prepare_order_source', 'has_subscription')) |
|
40 | 40 | ->getMock(); |
41 | 41 | |
42 | 42 | // Mocked in order to get metadata[payment_type] = recurring in the HTTP request. |
43 | 43 | $this->wc_stripe_subs_compat |
44 | - ->expects( $this->any() ) |
|
45 | - ->method( 'has_subscription' ) |
|
44 | + ->expects($this->any()) |
|
45 | + ->method('has_subscription') |
|
46 | 46 | ->will( |
47 | - $this->returnValue( true ) |
|
47 | + $this->returnValue(true) |
|
48 | 48 | ); |
49 | 49 | |
50 | 50 | $this->statement_descriptor = 'This is a statement descriptor.'; |
@@ -62,7 +62,7 @@ discard block |
||
62 | 62 | public function tearDown() { |
63 | 63 | parent::tearDown(); |
64 | 64 | |
65 | - delete_option( 'woocommerce_stripe_settings' ); |
|
65 | + delete_option('woocommerce_stripe_settings'); |
|
66 | 66 | } |
67 | 67 | |
68 | 68 | /** |
@@ -79,11 +79,11 @@ discard block |
||
79 | 79 | // Arrange: Some variables we'll use later. |
80 | 80 | $renewal_order = WC_Helper_Order::create_order(); |
81 | 81 | $amount = 20; // WC Subs sends an amount to be used, instead of using the order amount. |
82 | - $stripe_amount = WC_Stripe_Helper::get_stripe_amount( $amount ); |
|
83 | - $currency = strtolower( WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $renewal_order->get_order_currency() : $renewal_order->get_currency() ); |
|
82 | + $stripe_amount = WC_Stripe_Helper::get_stripe_amount($amount); |
|
83 | + $currency = strtolower(WC_Stripe_Helper::is_wc_lt('3.0') ? $renewal_order->get_order_currency() : $renewal_order->get_currency()); |
|
84 | 84 | $customer = 'cus_123abc'; |
85 | 85 | $source = 'src_123abc'; |
86 | - $statement_descriptor = WC_Stripe_Helper::clean_statement_descriptor( $this->statement_descriptor ); |
|
86 | + $statement_descriptor = WC_Stripe_Helper::clean_statement_descriptor($this->statement_descriptor); |
|
87 | 87 | $should_retry = false; |
88 | 88 | $previous_error = false; |
89 | 89 | $payments_intents_api_endpoint = 'https://api.stripe.com/v1/payment_intents'; |
@@ -91,16 +91,16 @@ discard block |
||
91 | 91 | |
92 | 92 | // Arrange: Set payment method to stripe, and not stripe_sepa, for example. |
93 | 93 | // This needed for testing the statement_descriptor. |
94 | - if ( WC_Stripe_Helper::is_wc_lt( '3.0' ) ) { |
|
94 | + if (WC_Stripe_Helper::is_wc_lt('3.0')) { |
|
95 | 95 | $renewal_order->payment_method = 'stripe'; |
96 | 96 | } else { |
97 | - $renewal_order->set_payment_method( 'stripe' ); |
|
97 | + $renewal_order->set_payment_method('stripe'); |
|
98 | 98 | } |
99 | 99 | |
100 | 100 | // Arrange: Mock prepare_order_source() so that we have a customer and source. |
101 | 101 | $this->wc_stripe_subs_compat |
102 | - ->expects( $this->any() ) |
|
103 | - ->method( 'prepare_order_source' ) |
|
102 | + ->expects($this->any()) |
|
103 | + ->method('prepare_order_source') |
|
104 | 104 | ->will( |
105 | 105 | $this->returnValue( |
106 | 106 | (object) array( |
@@ -114,7 +114,7 @@ discard block |
||
114 | 114 | |
115 | 115 | // Arrange: Add filter that will return a mocked HTTP response for the payment_intent call. |
116 | 116 | // Note: There are assertions in the callback function. |
117 | - $pre_http_request_response_callback = function( $preempt, $request_args, $url ) use ( |
|
117 | + $pre_http_request_response_callback = function($preempt, $request_args, $url) use ( |
|
118 | 118 | $renewal_order, |
119 | 119 | $stripe_amount, |
120 | 120 | $currency, |
@@ -125,35 +125,35 @@ discard block |
||
125 | 125 | &$urls_used |
126 | 126 | ) { |
127 | 127 | // Add all urls to array so we can later make assertions about which endpoints were used. |
128 | - array_push( $urls_used, $url ); |
|
128 | + array_push($urls_used, $url); |
|
129 | 129 | |
130 | 130 | // Continue without mocking the request if it's not the endpoint we care about. |
131 | - if ( $payments_intents_api_endpoint !== $url ) { |
|
131 | + if ($payments_intents_api_endpoint !== $url) { |
|
132 | 132 | return false; |
133 | 133 | } |
134 | 134 | |
135 | 135 | // Assert: the request method is POST. |
136 | - $this->assertArrayHasKey( 'method', $request_args ); |
|
137 | - $this->assertSame( 'POST', $request_args['method'] ); |
|
136 | + $this->assertArrayHasKey('method', $request_args); |
|
137 | + $this->assertSame('POST', $request_args['method']); |
|
138 | 138 | |
139 | 139 | // Assert: the request has a body. |
140 | - $this->assertArrayHasKey( 'body', $request_args ); |
|
140 | + $this->assertArrayHasKey('body', $request_args); |
|
141 | 141 | |
142 | 142 | // Assert: the request body contains these values. |
143 | 143 | $expected_request_body_values = array( |
144 | 144 | 'source' => $source, |
145 | 145 | 'amount' => $stripe_amount, |
146 | 146 | 'currency' => $currency, |
147 | - 'payment_method_types' => array( 'card' ), |
|
147 | + 'payment_method_types' => array('card'), |
|
148 | 148 | 'customer' => $customer, |
149 | 149 | 'off_session' => 'true', |
150 | 150 | 'confirm' => 'true', |
151 | 151 | 'confirmation_method' => 'automatic', |
152 | 152 | 'statement_descriptor' => $statement_descriptor, |
153 | 153 | ); |
154 | - foreach ( $expected_request_body_values as $key => $value ) { |
|
155 | - $this->assertArrayHasKey( $key, $request_args['body'] ); |
|
156 | - $this->assertSame( $value, $request_args['body'][ $key ] ); |
|
154 | + foreach ($expected_request_body_values as $key => $value) { |
|
155 | + $this->assertArrayHasKey($key, $request_args['body']); |
|
156 | + $this->assertSame($value, $request_args['body'][$key]); |
|
157 | 157 | } |
158 | 158 | |
159 | 159 | // Assert: the request body contains these keys, without checking for their value. |
@@ -161,19 +161,19 @@ discard block |
||
161 | 161 | 'description', |
162 | 162 | 'metadata', |
163 | 163 | ); |
164 | - foreach ( $expected_request_body_keys as $key ) { |
|
165 | - $this->assertArrayHasKey( $key, $request_args['body'] ); |
|
164 | + foreach ($expected_request_body_keys as $key) { |
|
165 | + $this->assertArrayHasKey($key, $request_args['body']); |
|
166 | 166 | } |
167 | 167 | |
168 | 168 | // Assert: the body metadata has these values. |
169 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $renewal_order->id : (string) $renewal_order->get_id(); |
|
169 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $renewal_order->id : (string) $renewal_order->get_id(); |
|
170 | 170 | $expected_metadata_values = array( |
171 | 171 | 'order_id' => $order_id, |
172 | 172 | 'payment_type' => 'recurring', |
173 | 173 | ); |
174 | - foreach ( $expected_metadata_values as $key => $value ) { |
|
175 | - $this->assertArrayHasKey( $key, $request_args['body']['metadata'] ); |
|
176 | - $this->assertSame( $value, $request_args['body']['metadata'][ $key ] ); |
|
174 | + foreach ($expected_metadata_values as $key => $value) { |
|
175 | + $this->assertArrayHasKey($key, $request_args['body']['metadata']); |
|
176 | + $this->assertSame($value, $request_args['body']['metadata'][$key]); |
|
177 | 177 | } |
178 | 178 | |
179 | 179 | // Assert: the body metadata has these keys, without checking for their value. |
@@ -182,8 +182,8 @@ discard block |
||
182 | 182 | 'customer_email', |
183 | 183 | 'site_url', |
184 | 184 | ); |
185 | - foreach ( $expected_metadata_keys as $key ) { |
|
186 | - $this->assertArrayHasKey( $key, $request_args['body']['metadata'] ); |
|
185 | + foreach ($expected_metadata_keys as $key) { |
|
186 | + $this->assertArrayHasKey($key, $request_args['body']['metadata']); |
|
187 | 187 | } |
188 | 188 | |
189 | 189 | // Assert: the request body does not contains these keys. |
@@ -192,15 +192,15 @@ discard block |
||
192 | 192 | 'capture_method', // The default ('automatic') is what we want in this case, so we leave it off. |
193 | 193 | 'expand[]', |
194 | 194 | ); |
195 | - foreach ( $expected_missing_request_body_keys as $key ) { |
|
196 | - $this->assertArrayNotHasKey( $key, $request_args['body'] ); |
|
195 | + foreach ($expected_missing_request_body_keys as $key) { |
|
196 | + $this->assertArrayNotHasKey($key, $request_args['body']); |
|
197 | 197 | } |
198 | 198 | |
199 | 199 | // Arrange: return dummy content as the response. |
200 | 200 | return array( |
201 | 201 | 'headers' => array(), |
202 | 202 | // Too bad we aren't dynamically setting things 'cus_123abc' when using this file. |
203 | - 'body' => file_get_contents( 'tests/phpunit/dummy-data/subscription_renewal_response_success.json' ), |
|
203 | + 'body' => file_get_contents('tests/phpunit/dummy-data/subscription_renewal_response_success.json'), |
|
204 | 204 | 'response' => array( |
205 | 205 | 'code' => 200, |
206 | 206 | 'message' => 'OK', |
@@ -210,55 +210,55 @@ discard block |
||
210 | 210 | ); |
211 | 211 | }; |
212 | 212 | |
213 | - add_filter( 'pre_http_request', $pre_http_request_response_callback, 10, 3 ); |
|
213 | + add_filter('pre_http_request', $pre_http_request_response_callback, 10, 3); |
|
214 | 214 | |
215 | 215 | // Arrange: Make sure to check that an action we care about was called |
216 | 216 | // by hooking into it. |
217 | 217 | $mock_action_process_payment = new MockAction(); |
218 | 218 | add_action( |
219 | 219 | 'wc_gateway_stripe_process_payment', |
220 | - [ &$mock_action_process_payment, 'action' ] |
|
220 | + [&$mock_action_process_payment, 'action'] |
|
221 | 221 | ); |
222 | 222 | |
223 | 223 | // Act: call process_subscription_payment(). |
224 | 224 | // We need to use `wc_stripe_subs_compat` here because we mocked this class earlier. |
225 | - $result = $this->wc_stripe_subs_compat->process_subscription_payment( 20, $renewal_order, $should_retry, $previous_error ); |
|
225 | + $result = $this->wc_stripe_subs_compat->process_subscription_payment(20, $renewal_order, $should_retry, $previous_error); |
|
226 | 226 | |
227 | 227 | // Assert: nothing was returned. |
228 | - $this->assertEquals( $result, null ); |
|
228 | + $this->assertEquals($result, null); |
|
229 | 229 | |
230 | 230 | // Assert that we saved the payment intent to the order. |
231 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $renewal_order->id : $renewal_order->get_id(); |
|
232 | - $order = wc_get_order( $order_id ); |
|
231 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $renewal_order->id : $renewal_order->get_id(); |
|
232 | + $order = wc_get_order($order_id); |
|
233 | 233 | $order_data = ( |
234 | - WC_Stripe_Helper::is_wc_lt( '3.0' ) |
|
235 | - ? get_post_meta( $order_id, '_stripe_intent_id', true ) |
|
236 | - : $order->get_meta( '_stripe_intent_id' ) |
|
234 | + WC_Stripe_Helper::is_wc_lt('3.0') |
|
235 | + ? get_post_meta($order_id, '_stripe_intent_id', true) |
|
236 | + : $order->get_meta('_stripe_intent_id') |
|
237 | 237 | ); |
238 | - $this->assertEquals( $order_data, 'pi_123abc' ); |
|
238 | + $this->assertEquals($order_data, 'pi_123abc'); |
|
239 | 239 | |
240 | 240 | // Transaction ID was saved to order. |
241 | 241 | $order_transaction_id = ( |
242 | - WC_Stripe_Helper::is_wc_lt( '3.0' ) |
|
243 | - ? get_post_meta( $order_id, '_transaction_id', true ) |
|
242 | + WC_Stripe_Helper::is_wc_lt('3.0') |
|
243 | + ? get_post_meta($order_id, '_transaction_id', true) |
|
244 | 244 | : $order->get_transaction_id() |
245 | 245 | ); |
246 | - $this->assertEquals( $order_transaction_id, 'ch_123abc' ); |
|
246 | + $this->assertEquals($order_transaction_id, 'ch_123abc'); |
|
247 | 247 | |
248 | 248 | // Assert: the order was marked as processing (this is done in process_response()). |
249 | - $this->assertEquals( $order->get_status(), 'processing' ); |
|
249 | + $this->assertEquals($order->get_status(), 'processing'); |
|
250 | 250 | |
251 | 251 | // Assert: called payment intents. |
252 | - $this->assertTrue( in_array( $payments_intents_api_endpoint, $urls_used ) ); |
|
252 | + $this->assertTrue(in_array($payments_intents_api_endpoint, $urls_used)); |
|
253 | 253 | |
254 | 254 | // Assert: Our hook was called once. |
255 | - $this->assertEquals( 1, $mock_action_process_payment->get_call_count() ); |
|
255 | + $this->assertEquals(1, $mock_action_process_payment->get_call_count()); |
|
256 | 256 | |
257 | 257 | // Assert: Only our hook was called. |
258 | - $this->assertEquals( array( 'wc_gateway_stripe_process_payment' ), $mock_action_process_payment->get_tags() ); |
|
258 | + $this->assertEquals(array('wc_gateway_stripe_process_payment'), $mock_action_process_payment->get_tags()); |
|
259 | 259 | |
260 | 260 | // Clean up. |
261 | - remove_filter( 'pre_http_request', array( $this, 'pre_http_request_response_success' ) ); |
|
261 | + remove_filter('pre_http_request', array($this, 'pre_http_request_response_success')); |
|
262 | 262 | } |
263 | 263 | |
264 | 264 | /** |
@@ -275,8 +275,8 @@ discard block |
||
275 | 275 | // Arrange: Some variables we'll use later. |
276 | 276 | $renewal_order = WC_Helper_Order::create_order(); |
277 | 277 | $amount = 20; |
278 | - $stripe_amount = WC_Stripe_Helper::get_stripe_amount( $amount ); |
|
279 | - $currency = strtolower( WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $renewal_order->get_order_currency() : $renewal_order->get_currency() ); |
|
278 | + $stripe_amount = WC_Stripe_Helper::get_stripe_amount($amount); |
|
279 | + $currency = strtolower(WC_Stripe_Helper::is_wc_lt('3.0') ? $renewal_order->get_order_currency() : $renewal_order->get_currency()); |
|
280 | 280 | $customer = 'cus_123abc'; |
281 | 281 | $source = 'src_123abc'; |
282 | 282 | $should_retry = false; |
@@ -286,8 +286,8 @@ discard block |
||
286 | 286 | |
287 | 287 | // Arrange: Mock prepare_order_source() so that we have a customer and source. |
288 | 288 | $this->wc_stripe_subs_compat |
289 | - ->expects( $this->any() ) |
|
290 | - ->method( 'prepare_order_source' ) |
|
289 | + ->expects($this->any()) |
|
290 | + ->method('prepare_order_source') |
|
291 | 291 | ->will( |
292 | 292 | $this->returnValue( |
293 | 293 | (object) array( |
@@ -300,7 +300,7 @@ discard block |
||
300 | 300 | ); |
301 | 301 | |
302 | 302 | // Arrange: Add filter that will return a mocked HTTP response for the payment_intent call. |
303 | - $pre_http_request_response_callback = function( $preempt, $request_args, $url ) use ( |
|
303 | + $pre_http_request_response_callback = function($preempt, $request_args, $url) use ( |
|
304 | 304 | $renewal_order, |
305 | 305 | $stripe_amount, |
306 | 306 | $currency, |
@@ -310,10 +310,10 @@ discard block |
||
310 | 310 | &$urls_used |
311 | 311 | ) { |
312 | 312 | // Add all urls to array so we can later make assertions about which endpoints were used. |
313 | - array_push( $urls_used, $url ); |
|
313 | + array_push($urls_used, $url); |
|
314 | 314 | |
315 | 315 | // Continue without mocking the request if it's not the endpoint we care about. |
316 | - if ( $payments_intents_api_endpoint !== $url ) { |
|
316 | + if ($payments_intents_api_endpoint !== $url) { |
|
317 | 317 | return false; |
318 | 318 | } |
319 | 319 | |
@@ -321,7 +321,7 @@ discard block |
||
321 | 321 | return array( |
322 | 322 | 'headers' => array(), |
323 | 323 | // Too bad we aren't dynamically setting things 'cus_123abc' when using this file. |
324 | - 'body' => file_get_contents( 'tests/phpunit/dummy-data/subscription_renewal_response_authentication_required.json' ), |
|
324 | + 'body' => file_get_contents('tests/phpunit/dummy-data/subscription_renewal_response_authentication_required.json'), |
|
325 | 325 | 'response' => array( |
326 | 326 | 'code' => 402, |
327 | 327 | 'message' => 'Payment Required', |
@@ -330,56 +330,56 @@ discard block |
||
330 | 330 | 'filename' => null, |
331 | 331 | ); |
332 | 332 | }; |
333 | - add_filter( 'pre_http_request', $pre_http_request_response_callback, 10, 3 ); |
|
333 | + add_filter('pre_http_request', $pre_http_request_response_callback, 10, 3); |
|
334 | 334 | |
335 | 335 | // Arrange: Make sure to check that an action we care about was called |
336 | 336 | // by hooking into it. |
337 | 337 | $mock_action_process_payment = new MockAction(); |
338 | 338 | add_action( |
339 | 339 | 'wc_gateway_stripe_process_payment_authentication_required', |
340 | - [ &$mock_action_process_payment, 'action' ] |
|
340 | + [&$mock_action_process_payment, 'action'] |
|
341 | 341 | ); |
342 | 342 | |
343 | 343 | // Act: call process_subscription_payment(). |
344 | 344 | // We need to use `wc_stripe_subs_compat` here because we mocked this class earlier. |
345 | - $result = $this->wc_stripe_subs_compat->process_subscription_payment( 20, $renewal_order, $should_retry, $previous_error ); |
|
345 | + $result = $this->wc_stripe_subs_compat->process_subscription_payment(20, $renewal_order, $should_retry, $previous_error); |
|
346 | 346 | |
347 | 347 | // Assert: nothing was returned. |
348 | - $this->assertEquals( $result, null ); |
|
348 | + $this->assertEquals($result, null); |
|
349 | 349 | |
350 | 350 | // Assert that we saved the payment intent to the order. |
351 | - $order_id = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $renewal_order->id : $renewal_order->get_id(); |
|
352 | - $order = wc_get_order( $order_id ); |
|
351 | + $order_id = WC_Stripe_Helper::is_wc_lt('3.0') ? $renewal_order->id : $renewal_order->get_id(); |
|
352 | + $order = wc_get_order($order_id); |
|
353 | 353 | $order_data = ( |
354 | - WC_Stripe_Helper::is_wc_lt( '3.0' ) |
|
355 | - ? get_post_meta( $order_id, '_stripe_intent_id', true ) |
|
356 | - : $order->get_meta( '_stripe_intent_id' ) |
|
354 | + WC_Stripe_Helper::is_wc_lt('3.0') |
|
355 | + ? get_post_meta($order_id, '_stripe_intent_id', true) |
|
356 | + : $order->get_meta('_stripe_intent_id') |
|
357 | 357 | ); |
358 | 358 | $order_transaction_id = ( |
359 | - WC_Stripe_Helper::is_wc_lt( '3.0' ) |
|
360 | - ? get_post_meta( $order_id, '_transaction_id', true ) |
|
359 | + WC_Stripe_Helper::is_wc_lt('3.0') |
|
360 | + ? get_post_meta($order_id, '_transaction_id', true) |
|
361 | 361 | : $order->get_transaction_id() |
362 | 362 | ); |
363 | 363 | |
364 | 364 | // Intent was saved to order even though there was an error in the response body. |
365 | - $this->assertEquals( $order_data, 'pi_123abc' ); |
|
365 | + $this->assertEquals($order_data, 'pi_123abc'); |
|
366 | 366 | |
367 | 367 | // Transaction ID was saved to order. |
368 | - $this->assertEquals( $order_transaction_id, 'ch_123abc' ); |
|
368 | + $this->assertEquals($order_transaction_id, 'ch_123abc'); |
|
369 | 369 | |
370 | 370 | // Assert: the order was marked as failed. |
371 | - $this->assertEquals( $order->get_status(), 'failed' ); |
|
371 | + $this->assertEquals($order->get_status(), 'failed'); |
|
372 | 372 | |
373 | 373 | // Assert: called payment intents. |
374 | - $this->assertTrue( in_array( $payments_intents_api_endpoint, $urls_used ) ); |
|
374 | + $this->assertTrue(in_array($payments_intents_api_endpoint, $urls_used)); |
|
375 | 375 | |
376 | 376 | // Assert: Our hook was called once. |
377 | - $this->assertEquals( 1, $mock_action_process_payment->get_call_count() ); |
|
377 | + $this->assertEquals(1, $mock_action_process_payment->get_call_count()); |
|
378 | 378 | |
379 | 379 | // Assert: Only our hook was called. |
380 | - $this->assertEquals( array( 'wc_gateway_stripe_process_payment_authentication_required' ), $mock_action_process_payment->get_tags() ); |
|
380 | + $this->assertEquals(array('wc_gateway_stripe_process_payment_authentication_required'), $mock_action_process_payment->get_tags()); |
|
381 | 381 | |
382 | 382 | // Clean up. |
383 | - remove_filter( 'pre_http_request', array( $this, 'pre_http_request_response_success' ) ); |
|
383 | + remove_filter('pre_http_request', array($this, 'pre_http_request_response_success')); |
|
384 | 384 | } |
385 | 385 | } |
@@ -1,17 +1,17 @@ |
||
1 | 1 | <?php |
2 | -if ( ! defined( 'ABSPATH' ) ) { |
|
2 | +if ( ! defined('ABSPATH')) { |
|
3 | 3 | exit; // Exit if accessed directly |
4 | 4 | } |
5 | 5 | |
6 | 6 | echo $email_heading . "\n\n"; |
7 | 7 | |
8 | 8 | // translators: %1$s: name of the blog, %2$s: link to checkout payment url, note: no full stop due to url at the end |
9 | -printf( esc_html_x( 'The automatic payment to renew your subscription with %1$s has failed. To reactivate the subscription, please login and authorize the renewal from your account page: %2$s', 'In failed renewal authentication email', 'woocommerce-gateway-stripe' ), esc_html( get_bloginfo( 'name' ) ), esc_attr( $authorization_url ) ); |
|
9 | +printf(esc_html_x('The automatic payment to renew your subscription with %1$s has failed. To reactivate the subscription, please login and authorize the renewal from your account page: %2$s', 'In failed renewal authentication email', 'woocommerce-gateway-stripe'), esc_html(get_bloginfo('name')), esc_attr($authorization_url)); |
|
10 | 10 | |
11 | 11 | echo "\n\n=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=\n"; |
12 | 12 | |
13 | -do_action( 'woocommerce_subscriptions_email_order_details', $order, $sent_to_admin, $plain_text, $email ); |
|
13 | +do_action('woocommerce_subscriptions_email_order_details', $order, $sent_to_admin, $plain_text, $email); |
|
14 | 14 | |
15 | 15 | echo "\n=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=\n\n"; |
16 | 16 | |
17 | -echo apply_filters( 'woocommerce_email_footer_text', get_option( 'woocommerce_email_footer_text' ) ); |
|
17 | +echo apply_filters('woocommerce_email_footer_text', get_option('woocommerce_email_footer_text')); |
@@ -1,17 +1,17 @@ |
||
1 | 1 | <?php |
2 | -if ( ! defined( 'ABSPATH' ) ) { |
|
2 | +if ( ! defined('ABSPATH')) { |
|
3 | 3 | exit; // Exit if accessed directly |
4 | 4 | } |
5 | 5 | ?> |
6 | 6 | |
7 | -<?php do_action( 'woocommerce_email_header', $email_heading, $email ); ?> |
|
7 | +<?php do_action('woocommerce_email_header', $email_heading, $email); ?> |
|
8 | 8 | |
9 | 9 | <p> |
10 | 10 | <?php |
11 | 11 | // translators: %1$s: name of the blog, %2$s: link to payment re-authentication URL, note: no full stop due to url at the end |
12 | - echo wp_kses( sprintf( _x( 'The automatic payment to renew your subscription with %1$s has failed. To reactivate the subscription, please login and authorize the renewal from your account page: %2$s', 'In failed renewal authentication email', 'woocommerce-gateway-stripe' ), esc_html( get_bloginfo( 'name' ) ), '<a href="' . esc_url( $authorization_url ) . '">' . esc_html__( 'Authorize the payment »', 'woocommerce-gateway-stripe' ) . '</a>' ), array( 'a' => array( 'href' => true ) ) ); ?> |
|
12 | + echo wp_kses(sprintf(_x('The automatic payment to renew your subscription with %1$s has failed. To reactivate the subscription, please login and authorize the renewal from your account page: %2$s', 'In failed renewal authentication email', 'woocommerce-gateway-stripe'), esc_html(get_bloginfo('name')), '<a href="' . esc_url($authorization_url) . '">' . esc_html__('Authorize the payment »', 'woocommerce-gateway-stripe') . '</a>'), array('a' => array('href' => true))); ?> |
|
13 | 13 | </p> |
14 | 14 | |
15 | -<?php do_action( 'woocommerce_subscriptions_email_order_details', $order, $sent_to_admin, $plain_text, $email ); ?> |
|
15 | +<?php do_action('woocommerce_subscriptions_email_order_details', $order, $sent_to_admin, $plain_text, $email); ?> |
|
16 | 16 | |
17 | -<?php do_action( 'woocommerce_email_footer', $email ); ?> |
|
17 | +<?php do_action('woocommerce_email_footer', $email); ?> |
@@ -884,7 +884,7 @@ |
||
884 | 884 | } |
885 | 885 | |
886 | 886 | if ( 'requires_payment_method' === $intent->status && isset( $intent->last_payment_error ) |
887 | - && 'authentication_required' === $intent->last_payment_error->code ) { |
|
887 | + && 'authentication_required' === $intent->last_payment_error->code ) { |
|
888 | 888 | $intent = WC_Stripe_API::request( array( |
889 | 889 | 'payment_method' => $intent->last_payment_error->source->id, |
890 | 890 | ), 'payment_intents/' . $intent->id . '/confirm' ); |
@@ -1,5 +1,5 @@ discard block |
||
1 | 1 | <?php |
2 | -if ( ! defined( 'ABSPATH' ) ) { |
|
2 | +if ( ! defined('ABSPATH')) { |
|
3 | 3 | exit; |
4 | 4 | } |
5 | 5 | |
@@ -85,9 +85,9 @@ discard block |
||
85 | 85 | public function __construct() { |
86 | 86 | $this->retry_interval = 1; |
87 | 87 | $this->id = 'stripe'; |
88 | - $this->method_title = __( 'Stripe', 'woocommerce-gateway-stripe' ); |
|
88 | + $this->method_title = __('Stripe', 'woocommerce-gateway-stripe'); |
|
89 | 89 | /* translators: 1) link to Stripe register page 2) link to Stripe api keys page */ |
90 | - $this->method_description = sprintf( __( 'Stripe works by adding payment fields on the checkout and then sending the details to Stripe for verification. <a href="%1$s" target="_blank">Sign up</a> for a Stripe account, and <a href="%2$s" target="_blank">get your Stripe account keys</a>.', 'woocommerce-gateway-stripe' ), 'https://dashboard.stripe.com/register', 'https://dashboard.stripe.com/account/apikeys' ); |
|
90 | + $this->method_description = sprintf(__('Stripe works by adding payment fields on the checkout and then sending the details to Stripe for verification. <a href="%1$s" target="_blank">Sign up</a> for a Stripe account, and <a href="%2$s" target="_blank">get your Stripe account keys</a>.', 'woocommerce-gateway-stripe'), 'https://dashboard.stripe.com/register', 'https://dashboard.stripe.com/account/apikeys'); |
|
91 | 91 | $this->has_fields = true; |
92 | 92 | $this->supports = array( |
93 | 93 | 'products', |
@@ -114,37 +114,37 @@ discard block |
||
114 | 114 | $this->init_settings(); |
115 | 115 | |
116 | 116 | // Get setting values. |
117 | - $this->title = $this->get_option( 'title' ); |
|
118 | - $this->description = $this->get_option( 'description' ); |
|
119 | - $this->enabled = $this->get_option( 'enabled' ); |
|
120 | - $this->testmode = 'yes' === $this->get_option( 'testmode' ); |
|
121 | - $this->inline_cc_form = 'yes' === $this->get_option( 'inline_cc_form' ); |
|
122 | - $this->capture = 'yes' === $this->get_option( 'capture', 'yes' ); |
|
123 | - $this->statement_descriptor = WC_Stripe_Helper::clean_statement_descriptor( $this->get_option( 'statement_descriptor' ) ); |
|
124 | - $this->saved_cards = 'yes' === $this->get_option( 'saved_cards' ); |
|
125 | - $this->secret_key = $this->testmode ? $this->get_option( 'test_secret_key' ) : $this->get_option( 'secret_key' ); |
|
126 | - $this->publishable_key = $this->testmode ? $this->get_option( 'test_publishable_key' ) : $this->get_option( 'publishable_key' ); |
|
127 | - $this->payment_request = 'yes' === $this->get_option( 'payment_request', 'yes' ); |
|
128 | - |
|
129 | - WC_Stripe_API::set_secret_key( $this->secret_key ); |
|
117 | + $this->title = $this->get_option('title'); |
|
118 | + $this->description = $this->get_option('description'); |
|
119 | + $this->enabled = $this->get_option('enabled'); |
|
120 | + $this->testmode = 'yes' === $this->get_option('testmode'); |
|
121 | + $this->inline_cc_form = 'yes' === $this->get_option('inline_cc_form'); |
|
122 | + $this->capture = 'yes' === $this->get_option('capture', 'yes'); |
|
123 | + $this->statement_descriptor = WC_Stripe_Helper::clean_statement_descriptor($this->get_option('statement_descriptor')); |
|
124 | + $this->saved_cards = 'yes' === $this->get_option('saved_cards'); |
|
125 | + $this->secret_key = $this->testmode ? $this->get_option('test_secret_key') : $this->get_option('secret_key'); |
|
126 | + $this->publishable_key = $this->testmode ? $this->get_option('test_publishable_key') : $this->get_option('publishable_key'); |
|
127 | + $this->payment_request = 'yes' === $this->get_option('payment_request', 'yes'); |
|
128 | + |
|
129 | + WC_Stripe_API::set_secret_key($this->secret_key); |
|
130 | 130 | |
131 | 131 | // Hooks. |
132 | - add_action( 'wp_enqueue_scripts', array( $this, 'payment_scripts' ) ); |
|
133 | - add_action( 'admin_enqueue_scripts', array( $this, 'admin_scripts' ) ); |
|
134 | - add_action( 'woocommerce_update_options_payment_gateways_' . $this->id, array( $this, 'process_admin_options' ) ); |
|
135 | - add_action( 'woocommerce_admin_order_totals_after_total', array( $this, 'display_order_fee' ) ); |
|
136 | - add_action( 'woocommerce_admin_order_totals_after_total', array( $this, 'display_order_payout' ), 20 ); |
|
137 | - add_action( 'woocommerce_customer_save_address', array( $this, 'show_update_card_notice' ), 10, 2 ); |
|
138 | - add_filter( 'woocommerce_available_payment_gateways', array( $this, 'prepare_order_pay_page' ) ); |
|
139 | - add_action( 'woocommerce_account_view-order_endpoint', array( $this, 'check_intent_status_on_order_page' ), 1 ); |
|
140 | - add_filter( 'woocommerce_payment_successful_result', array( $this, 'modify_successful_payment_result' ), 99999, 2 ); |
|
141 | - add_action( 'set_logged_in_cookie', array( $this, 'set_cookie_on_current_request' ) ); |
|
142 | - add_filter( 'woocommerce_get_checkout_payment_url', array( $this, 'get_checkout_payment_url' ), 10, 2 ); |
|
143 | - |
|
144 | - if ( WC_Stripe_Helper::is_pre_orders_exists() ) { |
|
132 | + add_action('wp_enqueue_scripts', array($this, 'payment_scripts')); |
|
133 | + add_action('admin_enqueue_scripts', array($this, 'admin_scripts')); |
|
134 | + add_action('woocommerce_update_options_payment_gateways_' . $this->id, array($this, 'process_admin_options')); |
|
135 | + add_action('woocommerce_admin_order_totals_after_total', array($this, 'display_order_fee')); |
|
136 | + add_action('woocommerce_admin_order_totals_after_total', array($this, 'display_order_payout'), 20); |
|
137 | + add_action('woocommerce_customer_save_address', array($this, 'show_update_card_notice'), 10, 2); |
|
138 | + add_filter('woocommerce_available_payment_gateways', array($this, 'prepare_order_pay_page')); |
|
139 | + add_action('woocommerce_account_view-order_endpoint', array($this, 'check_intent_status_on_order_page'), 1); |
|
140 | + add_filter('woocommerce_payment_successful_result', array($this, 'modify_successful_payment_result'), 99999, 2); |
|
141 | + add_action('set_logged_in_cookie', array($this, 'set_cookie_on_current_request')); |
|
142 | + add_filter('woocommerce_get_checkout_payment_url', array($this, 'get_checkout_payment_url'), 10, 2); |
|
143 | + |
|
144 | + if (WC_Stripe_Helper::is_pre_orders_exists()) { |
|
145 | 145 | $this->pre_orders = new WC_Stripe_Pre_Orders_Compat(); |
146 | 146 | |
147 | - add_action( 'wc_pre_orders_process_pre_order_completion_payment_' . $this->id, array( $this->pre_orders, 'process_pre_order_release_payment' ) ); |
|
147 | + add_action('wc_pre_orders_process_pre_order_completion_payment_' . $this->id, array($this->pre_orders, 'process_pre_order_release_payment')); |
|
148 | 148 | } |
149 | 149 | } |
150 | 150 | |
@@ -155,7 +155,7 @@ discard block |
||
155 | 155 | * @return bool |
156 | 156 | */ |
157 | 157 | public function are_keys_set() { |
158 | - if ( empty( $this->secret_key ) || empty( $this->publishable_key ) ) { |
|
158 | + if (empty($this->secret_key) || empty($this->publishable_key)) { |
|
159 | 159 | return false; |
160 | 160 | } |
161 | 161 | |
@@ -168,7 +168,7 @@ discard block |
||
168 | 168 | * @since 4.0.2 |
169 | 169 | */ |
170 | 170 | public function is_available() { |
171 | - if ( is_add_payment_method_page() && ! $this->saved_cards ) { |
|
171 | + if (is_add_payment_method_page() && ! $this->saved_cards) { |
|
172 | 172 | return false; |
173 | 173 | } |
174 | 174 | |
@@ -182,13 +182,13 @@ discard block |
||
182 | 182 | * @param int $user_id The ID of the current user. |
183 | 183 | * @param string $load_address The address to load. |
184 | 184 | */ |
185 | - public function show_update_card_notice( $user_id, $load_address ) { |
|
186 | - if ( ! $this->saved_cards || ! WC_Stripe_Payment_Tokens::customer_has_saved_methods( $user_id ) || 'billing' !== $load_address ) { |
|
185 | + public function show_update_card_notice($user_id, $load_address) { |
|
186 | + if ( ! $this->saved_cards || ! WC_Stripe_Payment_Tokens::customer_has_saved_methods($user_id) || 'billing' !== $load_address) { |
|
187 | 187 | return; |
188 | 188 | } |
189 | 189 | |
190 | 190 | /* translators: 1) Opening anchor tag 2) closing anchor tag */ |
191 | - wc_add_notice( sprintf( __( 'If your billing address has been changed for saved payment methods, be sure to remove any %1$ssaved payment methods%2$s on file and re-add them.', 'woocommerce-gateway-stripe' ), '<a href="' . esc_url( wc_get_endpoint_url( 'payment-methods' ) ) . '" class="wc-stripe-update-card-notice" style="text-decoration:underline;">', '</a>' ), 'notice' ); |
|
191 | + wc_add_notice(sprintf(__('If your billing address has been changed for saved payment methods, be sure to remove any %1$ssaved payment methods%2$s on file and re-add them.', 'woocommerce-gateway-stripe'), '<a href="' . esc_url(wc_get_endpoint_url('payment-methods')) . '" class="wc-stripe-update-card-notice" style="text-decoration:underline;">', '</a>'), 'notice'); |
|
192 | 192 | } |
193 | 193 | |
194 | 194 | /** |
@@ -203,24 +203,24 @@ discard block |
||
203 | 203 | |
204 | 204 | $icons_str = ''; |
205 | 205 | |
206 | - $icons_str .= isset( $icons['visa'] ) ? $icons['visa'] : ''; |
|
207 | - $icons_str .= isset( $icons['amex'] ) ? $icons['amex'] : ''; |
|
208 | - $icons_str .= isset( $icons['mastercard'] ) ? $icons['mastercard'] : ''; |
|
206 | + $icons_str .= isset($icons['visa']) ? $icons['visa'] : ''; |
|
207 | + $icons_str .= isset($icons['amex']) ? $icons['amex'] : ''; |
|
208 | + $icons_str .= isset($icons['mastercard']) ? $icons['mastercard'] : ''; |
|
209 | 209 | |
210 | - if ( 'USD' === get_woocommerce_currency() ) { |
|
211 | - $icons_str .= isset( $icons['discover'] ) ? $icons['discover'] : ''; |
|
212 | - $icons_str .= isset( $icons['jcb'] ) ? $icons['jcb'] : ''; |
|
213 | - $icons_str .= isset( $icons['diners'] ) ? $icons['diners'] : ''; |
|
210 | + if ('USD' === get_woocommerce_currency()) { |
|
211 | + $icons_str .= isset($icons['discover']) ? $icons['discover'] : ''; |
|
212 | + $icons_str .= isset($icons['jcb']) ? $icons['jcb'] : ''; |
|
213 | + $icons_str .= isset($icons['diners']) ? $icons['diners'] : ''; |
|
214 | 214 | } |
215 | 215 | |
216 | - return apply_filters( 'woocommerce_gateway_icon', $icons_str, $this->id ); |
|
216 | + return apply_filters('woocommerce_gateway_icon', $icons_str, $this->id); |
|
217 | 217 | } |
218 | 218 | |
219 | 219 | /** |
220 | 220 | * Initialise Gateway Settings Form Fields |
221 | 221 | */ |
222 | 222 | public function init_form_fields() { |
223 | - $this->form_fields = require( dirname( __FILE__ ) . '/admin/stripe-settings.php' ); |
|
223 | + $this->form_fields = require(dirname(__FILE__) . '/admin/stripe-settings.php'); |
|
224 | 224 | } |
225 | 225 | |
226 | 226 | /** |
@@ -228,27 +228,27 @@ discard block |
||
228 | 228 | */ |
229 | 229 | public function payment_fields() { |
230 | 230 | $user = wp_get_current_user(); |
231 | - $display_tokenization = $this->supports( 'tokenization' ) && is_checkout() && $this->saved_cards; |
|
231 | + $display_tokenization = $this->supports('tokenization') && is_checkout() && $this->saved_cards; |
|
232 | 232 | $total = WC()->cart->total; |
233 | 233 | $user_email = ''; |
234 | 234 | $description = $this->get_description(); |
235 | - $description = ! empty( $description ) ? $description : ''; |
|
235 | + $description = ! empty($description) ? $description : ''; |
|
236 | 236 | $firstname = ''; |
237 | 237 | $lastname = ''; |
238 | 238 | |
239 | 239 | // If paying from order, we need to get total from order not cart. |
240 | - if ( isset( $_GET['pay_for_order'] ) && ! empty( $_GET['key'] ) ) { // wpcs: csrf ok. |
|
241 | - $order = wc_get_order( wc_get_order_id_by_order_key( wc_clean( $_GET['key'] ) ) ); // wpcs: csrf ok, sanitization ok. |
|
240 | + if (isset($_GET['pay_for_order']) && ! empty($_GET['key'])) { // wpcs: csrf ok. |
|
241 | + $order = wc_get_order(wc_get_order_id_by_order_key(wc_clean($_GET['key']))); // wpcs: csrf ok, sanitization ok. |
|
242 | 242 | $total = $order->get_total(); |
243 | - $user_email = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->billing_email : $order->get_billing_email(); |
|
243 | + $user_email = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->billing_email : $order->get_billing_email(); |
|
244 | 244 | } else { |
245 | - if ( $user->ID ) { |
|
246 | - $user_email = get_user_meta( $user->ID, 'billing_email', true ); |
|
245 | + if ($user->ID) { |
|
246 | + $user_email = get_user_meta($user->ID, 'billing_email', true); |
|
247 | 247 | $user_email = $user_email ? $user_email : $user->user_email; |
248 | 248 | } |
249 | 249 | } |
250 | 250 | |
251 | - if ( is_add_payment_method_page() ) { |
|
251 | + if (is_add_payment_method_page()) { |
|
252 | 252 | $firstname = $user->user_firstname; |
253 | 253 | $lastname = $user->user_lastname; |
254 | 254 | } |
@@ -257,33 +257,33 @@ discard block |
||
257 | 257 | |
258 | 258 | echo '<div |
259 | 259 | id="stripe-payment-data" |
260 | - data-email="' . esc_attr( $user_email ) . '" |
|
261 | - data-full-name="' . esc_attr( $firstname . ' ' . $lastname ) . '" |
|
262 | - data-currency="' . esc_attr( strtolower( get_woocommerce_currency() ) ) . '" |
|
260 | + data-email="' . esc_attr($user_email) . '" |
|
261 | + data-full-name="' . esc_attr($firstname . ' ' . $lastname) . '" |
|
262 | + data-currency="' . esc_attr(strtolower(get_woocommerce_currency())) . '" |
|
263 | 263 | >'; |
264 | 264 | |
265 | - if ( $this->testmode ) { |
|
265 | + if ($this->testmode) { |
|
266 | 266 | /* translators: link to Stripe testing page */ |
267 | - $description .= ' ' . sprintf( __( 'TEST MODE ENABLED. In test mode, you can use the card number 4242424242424242 with any CVC and a valid expiration date or check the <a href="%s" target="_blank">Testing Stripe documentation</a> for more card numbers.', 'woocommerce-gateway-stripe' ), 'https://stripe.com/docs/testing' ); |
|
267 | + $description .= ' ' . sprintf(__('TEST MODE ENABLED. In test mode, you can use the card number 4242424242424242 with any CVC and a valid expiration date or check the <a href="%s" target="_blank">Testing Stripe documentation</a> for more card numbers.', 'woocommerce-gateway-stripe'), 'https://stripe.com/docs/testing'); |
|
268 | 268 | } |
269 | 269 | |
270 | - $description = trim( $description ); |
|
270 | + $description = trim($description); |
|
271 | 271 | |
272 | - echo apply_filters( 'wc_stripe_description', wpautop( wp_kses_post( $description ) ), $this->id ); // wpcs: xss ok. |
|
272 | + echo apply_filters('wc_stripe_description', wpautop(wp_kses_post($description)), $this->id); // wpcs: xss ok. |
|
273 | 273 | |
274 | - if ( $display_tokenization ) { |
|
274 | + if ($display_tokenization) { |
|
275 | 275 | $this->tokenization_script(); |
276 | 276 | $this->saved_payment_methods(); |
277 | 277 | } |
278 | 278 | |
279 | 279 | $this->elements_form(); |
280 | 280 | |
281 | - if ( apply_filters( 'wc_stripe_display_save_payment_method_checkbox', $display_tokenization ) && ! is_add_payment_method_page() && ! isset( $_GET['change_payment_method'] ) ) { // wpcs: csrf ok. |
|
281 | + if (apply_filters('wc_stripe_display_save_payment_method_checkbox', $display_tokenization) && ! is_add_payment_method_page() && ! isset($_GET['change_payment_method'])) { // wpcs: csrf ok. |
|
282 | 282 | |
283 | 283 | $this->save_payment_method_checkbox(); |
284 | 284 | } |
285 | 285 | |
286 | - do_action( 'wc_stripe_cards_payment_fields', $this->id ); |
|
286 | + do_action('wc_stripe_cards_payment_fields', $this->id); |
|
287 | 287 | |
288 | 288 | echo '</div>'; |
289 | 289 | |
@@ -298,12 +298,12 @@ discard block |
||
298 | 298 | */ |
299 | 299 | public function elements_form() { |
300 | 300 | ?> |
301 | - <fieldset id="wc-<?php echo esc_attr( $this->id ); ?>-cc-form" class="wc-credit-card-form wc-payment-form" style="background:transparent;"> |
|
302 | - <?php do_action( 'woocommerce_credit_card_form_start', $this->id ); ?> |
|
301 | + <fieldset id="wc-<?php echo esc_attr($this->id); ?>-cc-form" class="wc-credit-card-form wc-payment-form" style="background:transparent;"> |
|
302 | + <?php do_action('woocommerce_credit_card_form_start', $this->id); ?> |
|
303 | 303 | |
304 | - <?php if ( $this->inline_cc_form ) { ?> |
|
304 | + <?php if ($this->inline_cc_form) { ?> |
|
305 | 305 | <label for="card-element"> |
306 | - <?php esc_html_e( 'Credit or debit card', 'woocommerce-gateway-stripe' ); ?> |
|
306 | + <?php esc_html_e('Credit or debit card', 'woocommerce-gateway-stripe'); ?> |
|
307 | 307 | </label> |
308 | 308 | |
309 | 309 | <div id="stripe-card-element" class="wc-stripe-elements-field"> |
@@ -311,7 +311,7 @@ discard block |
||
311 | 311 | </div> |
312 | 312 | <?php } else { ?> |
313 | 313 | <div class="form-row form-row-wide"> |
314 | - <label for="stripe-card-element"><?php esc_html_e( 'Card Number', 'woocommerce-gateway-stripe' ); ?> <span class="required">*</span></label> |
|
314 | + <label for="stripe-card-element"><?php esc_html_e('Card Number', 'woocommerce-gateway-stripe'); ?> <span class="required">*</span></label> |
|
315 | 315 | <div class="stripe-card-group"> |
316 | 316 | <div id="stripe-card-element" class="wc-stripe-elements-field"> |
317 | 317 | <!-- a Stripe Element will be inserted here. --> |
@@ -322,7 +322,7 @@ discard block |
||
322 | 322 | </div> |
323 | 323 | |
324 | 324 | <div class="form-row form-row-first"> |
325 | - <label for="stripe-exp-element"><?php esc_html_e( 'Expiry Date', 'woocommerce-gateway-stripe' ); ?> <span class="required">*</span></label> |
|
325 | + <label for="stripe-exp-element"><?php esc_html_e('Expiry Date', 'woocommerce-gateway-stripe'); ?> <span class="required">*</span></label> |
|
326 | 326 | |
327 | 327 | <div id="stripe-exp-element" class="wc-stripe-elements-field"> |
328 | 328 | <!-- a Stripe Element will be inserted here. --> |
@@ -330,7 +330,7 @@ discard block |
||
330 | 330 | </div> |
331 | 331 | |
332 | 332 | <div class="form-row form-row-last"> |
333 | - <label for="stripe-cvc-element"><?php esc_html_e( 'Card Code (CVC)', 'woocommerce-gateway-stripe' ); ?> <span class="required">*</span></label> |
|
333 | + <label for="stripe-cvc-element"><?php esc_html_e('Card Code (CVC)', 'woocommerce-gateway-stripe'); ?> <span class="required">*</span></label> |
|
334 | 334 | <div id="stripe-cvc-element" class="wc-stripe-elements-field"> |
335 | 335 | <!-- a Stripe Element will be inserted here. --> |
336 | 336 | </div> |
@@ -341,7 +341,7 @@ discard block |
||
341 | 341 | <!-- Used to display form errors --> |
342 | 342 | <div class="stripe-source-errors" role="alert"></div> |
343 | 343 | <br /> |
344 | - <?php do_action( 'woocommerce_credit_card_form_end', $this->id ); ?> |
|
344 | + <?php do_action('woocommerce_credit_card_form_end', $this->id); ?> |
|
345 | 345 | <div class="clear"></div> |
346 | 346 | </fieldset> |
347 | 347 | <?php |
@@ -354,13 +354,13 @@ discard block |
||
354 | 354 | * @version 3.1.0 |
355 | 355 | */ |
356 | 356 | public function admin_scripts() { |
357 | - if ( 'woocommerce_page_wc-settings' !== get_current_screen()->id ) { |
|
357 | + if ('woocommerce_page_wc-settings' !== get_current_screen()->id) { |
|
358 | 358 | return; |
359 | 359 | } |
360 | 360 | |
361 | - $suffix = defined( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG ? '' : '.min'; |
|
361 | + $suffix = defined('SCRIPT_DEBUG') && SCRIPT_DEBUG ? '' : '.min'; |
|
362 | 362 | |
363 | - wp_enqueue_script( 'woocommerce_stripe_admin', plugins_url( 'assets/js/stripe-admin' . $suffix . '.js', WC_STRIPE_MAIN_FILE ), array(), WC_STRIPE_VERSION, true ); |
|
363 | + wp_enqueue_script('woocommerce_stripe_admin', plugins_url('assets/js/stripe-admin' . $suffix . '.js', WC_STRIPE_MAIN_FILE), array(), WC_STRIPE_VERSION, true); |
|
364 | 364 | } |
365 | 365 | |
366 | 366 | /** |
@@ -372,97 +372,97 @@ discard block |
||
372 | 372 | * @version 4.0.0 |
373 | 373 | */ |
374 | 374 | public function payment_scripts() { |
375 | - if ( ! is_product() && ! is_cart() && ! is_checkout() && ! isset( $_GET['pay_for_order'] ) && ! is_add_payment_method_page() && ! isset( $_GET['change_payment_method'] ) || ( is_order_received_page() ) ) { // wpcs: csrf ok. |
|
375 | + if ( ! is_product() && ! is_cart() && ! is_checkout() && ! isset($_GET['pay_for_order']) && ! is_add_payment_method_page() && ! isset($_GET['change_payment_method']) || (is_order_received_page())) { // wpcs: csrf ok. |
|
376 | 376 | return; |
377 | 377 | } |
378 | 378 | |
379 | 379 | // If Stripe is not enabled bail. |
380 | - if ( 'no' === $this->enabled ) { |
|
380 | + if ('no' === $this->enabled) { |
|
381 | 381 | return; |
382 | 382 | } |
383 | 383 | |
384 | 384 | // If keys are not set bail. |
385 | - if ( ! $this->are_keys_set() ) { |
|
386 | - WC_Stripe_Logger::log( 'Keys are not set correctly.' ); |
|
385 | + if ( ! $this->are_keys_set()) { |
|
386 | + WC_Stripe_Logger::log('Keys are not set correctly.'); |
|
387 | 387 | return; |
388 | 388 | } |
389 | 389 | |
390 | 390 | // If no SSL bail. |
391 | - if ( ! $this->testmode && ! is_ssl() ) { |
|
392 | - WC_Stripe_Logger::log( 'Stripe live mode requires SSL.' ); |
|
391 | + if ( ! $this->testmode && ! is_ssl()) { |
|
392 | + WC_Stripe_Logger::log('Stripe live mode requires SSL.'); |
|
393 | 393 | return; |
394 | 394 | } |
395 | 395 | |
396 | 396 | $current_theme = wp_get_theme(); |
397 | 397 | |
398 | - $suffix = defined( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG ? '' : '.min'; |
|
398 | + $suffix = defined('SCRIPT_DEBUG') && SCRIPT_DEBUG ? '' : '.min'; |
|
399 | 399 | |
400 | - wp_register_style( 'stripe_styles', plugins_url( 'assets/css/stripe-styles.css', WC_STRIPE_MAIN_FILE ), array(), WC_STRIPE_VERSION ); |
|
401 | - wp_enqueue_style( 'stripe_styles' ); |
|
400 | + wp_register_style('stripe_styles', plugins_url('assets/css/stripe-styles.css', WC_STRIPE_MAIN_FILE), array(), WC_STRIPE_VERSION); |
|
401 | + wp_enqueue_style('stripe_styles'); |
|
402 | 402 | |
403 | - wp_register_script( 'stripe', 'https://js.stripe.com/v3/', '', '3.0', true ); |
|
404 | - wp_register_script( 'woocommerce_stripe', plugins_url( 'assets/js/stripe' . $suffix . '.js', WC_STRIPE_MAIN_FILE ), array( 'jquery-payment', 'stripe' ), WC_STRIPE_VERSION, true ); |
|
403 | + wp_register_script('stripe', 'https://js.stripe.com/v3/', '', '3.0', true); |
|
404 | + wp_register_script('woocommerce_stripe', plugins_url('assets/js/stripe' . $suffix . '.js', WC_STRIPE_MAIN_FILE), array('jquery-payment', 'stripe'), WC_STRIPE_VERSION, true); |
|
405 | 405 | |
406 | 406 | $stripe_params = array( |
407 | 407 | 'key' => $this->publishable_key, |
408 | - 'i18n_terms' => __( 'Please accept the terms and conditions first', 'woocommerce-gateway-stripe' ), |
|
409 | - 'i18n_required_fields' => __( 'Please fill in required checkout fields first', 'woocommerce-gateway-stripe' ), |
|
408 | + 'i18n_terms' => __('Please accept the terms and conditions first', 'woocommerce-gateway-stripe'), |
|
409 | + 'i18n_required_fields' => __('Please fill in required checkout fields first', 'woocommerce-gateway-stripe'), |
|
410 | 410 | ); |
411 | 411 | |
412 | 412 | // If we're on the pay page we need to pass stripe.js the address of the order. |
413 | - if ( isset( $_GET['pay_for_order'] ) && 'true' === $_GET['pay_for_order'] ) { // wpcs: csrf ok. |
|
414 | - $order_id = wc_get_order_id_by_order_key( urldecode( $_GET['key'] ) ); // wpcs: csrf ok, sanitization ok, xss ok. |
|
415 | - $order = wc_get_order( $order_id ); |
|
416 | - |
|
417 | - if ( is_a( $order, 'WC_Order' ) ) { |
|
418 | - $stripe_params['billing_first_name'] = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->billing_first_name : $order->get_billing_first_name(); |
|
419 | - $stripe_params['billing_last_name'] = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->billing_last_name : $order->get_billing_last_name(); |
|
420 | - $stripe_params['billing_address_1'] = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->billing_address_1 : $order->get_billing_address_1(); |
|
421 | - $stripe_params['billing_address_2'] = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->billing_address_2 : $order->get_billing_address_2(); |
|
422 | - $stripe_params['billing_state'] = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->billing_state : $order->get_billing_state(); |
|
423 | - $stripe_params['billing_city'] = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->billing_city : $order->get_billing_city(); |
|
424 | - $stripe_params['billing_postcode'] = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->billing_postcode : $order->get_billing_postcode(); |
|
425 | - $stripe_params['billing_country'] = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->billing_country : $order->get_billing_country(); |
|
413 | + if (isset($_GET['pay_for_order']) && 'true' === $_GET['pay_for_order']) { // wpcs: csrf ok. |
|
414 | + $order_id = wc_get_order_id_by_order_key(urldecode($_GET['key'])); // wpcs: csrf ok, sanitization ok, xss ok. |
|
415 | + $order = wc_get_order($order_id); |
|
416 | + |
|
417 | + if (is_a($order, 'WC_Order')) { |
|
418 | + $stripe_params['billing_first_name'] = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->billing_first_name : $order->get_billing_first_name(); |
|
419 | + $stripe_params['billing_last_name'] = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->billing_last_name : $order->get_billing_last_name(); |
|
420 | + $stripe_params['billing_address_1'] = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->billing_address_1 : $order->get_billing_address_1(); |
|
421 | + $stripe_params['billing_address_2'] = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->billing_address_2 : $order->get_billing_address_2(); |
|
422 | + $stripe_params['billing_state'] = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->billing_state : $order->get_billing_state(); |
|
423 | + $stripe_params['billing_city'] = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->billing_city : $order->get_billing_city(); |
|
424 | + $stripe_params['billing_postcode'] = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->billing_postcode : $order->get_billing_postcode(); |
|
425 | + $stripe_params['billing_country'] = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->billing_country : $order->get_billing_country(); |
|
426 | 426 | } |
427 | 427 | } |
428 | 428 | |
429 | 429 | $sepa_elements_options = apply_filters( |
430 | 430 | 'wc_stripe_sepa_elements_options', |
431 | 431 | array( |
432 | - 'supportedCountries' => array( 'SEPA' ), |
|
432 | + 'supportedCountries' => array('SEPA'), |
|
433 | 433 | 'placeholderCountry' => WC()->countries->get_base_country(), |
434 | - 'style' => array( 'base' => array( 'fontSize' => '15px' ) ), |
|
434 | + 'style' => array('base' => array('fontSize' => '15px')), |
|
435 | 435 | ) |
436 | 436 | ); |
437 | 437 | |
438 | - $stripe_params['no_prepaid_card_msg'] = __( 'Sorry, we\'re not accepting prepaid cards at this time. Your credit card has not been charged. Please try with alternative payment method.', 'woocommerce-gateway-stripe' ); |
|
439 | - $stripe_params['no_sepa_owner_msg'] = __( 'Please enter your IBAN account name.', 'woocommerce-gateway-stripe' ); |
|
440 | - $stripe_params['no_sepa_iban_msg'] = __( 'Please enter your IBAN account number.', 'woocommerce-gateway-stripe' ); |
|
441 | - $stripe_params['payment_intent_error'] = __( 'We couldn\'t initiate the payment. Please try again.', 'woocommerce-gateway-stripe' ); |
|
442 | - $stripe_params['sepa_mandate_notification'] = apply_filters( 'wc_stripe_sepa_mandate_notification', 'email' ); |
|
443 | - $stripe_params['allow_prepaid_card'] = apply_filters( 'wc_stripe_allow_prepaid_card', true ) ? 'yes' : 'no'; |
|
438 | + $stripe_params['no_prepaid_card_msg'] = __('Sorry, we\'re not accepting prepaid cards at this time. Your credit card has not been charged. Please try with alternative payment method.', 'woocommerce-gateway-stripe'); |
|
439 | + $stripe_params['no_sepa_owner_msg'] = __('Please enter your IBAN account name.', 'woocommerce-gateway-stripe'); |
|
440 | + $stripe_params['no_sepa_iban_msg'] = __('Please enter your IBAN account number.', 'woocommerce-gateway-stripe'); |
|
441 | + $stripe_params['payment_intent_error'] = __('We couldn\'t initiate the payment. Please try again.', 'woocommerce-gateway-stripe'); |
|
442 | + $stripe_params['sepa_mandate_notification'] = apply_filters('wc_stripe_sepa_mandate_notification', 'email'); |
|
443 | + $stripe_params['allow_prepaid_card'] = apply_filters('wc_stripe_allow_prepaid_card', true) ? 'yes' : 'no'; |
|
444 | 444 | $stripe_params['inline_cc_form'] = $this->inline_cc_form ? 'yes' : 'no'; |
445 | - $stripe_params['is_checkout'] = ( is_checkout() && empty( $_GET['pay_for_order'] ) ) ? 'yes' : 'no'; // wpcs: csrf ok. |
|
445 | + $stripe_params['is_checkout'] = (is_checkout() && empty($_GET['pay_for_order'])) ? 'yes' : 'no'; // wpcs: csrf ok. |
|
446 | 446 | $stripe_params['return_url'] = $this->get_stripe_return_url(); |
447 | - $stripe_params['ajaxurl'] = WC_AJAX::get_endpoint( '%%endpoint%%' ); |
|
448 | - $stripe_params['stripe_nonce'] = wp_create_nonce( '_wc_stripe_nonce' ); |
|
447 | + $stripe_params['ajaxurl'] = WC_AJAX::get_endpoint('%%endpoint%%'); |
|
448 | + $stripe_params['stripe_nonce'] = wp_create_nonce('_wc_stripe_nonce'); |
|
449 | 449 | $stripe_params['statement_descriptor'] = $this->statement_descriptor; |
450 | - $stripe_params['elements_options'] = apply_filters( 'wc_stripe_elements_options', array() ); |
|
450 | + $stripe_params['elements_options'] = apply_filters('wc_stripe_elements_options', array()); |
|
451 | 451 | $stripe_params['sepa_elements_options'] = $sepa_elements_options; |
452 | - $stripe_params['invalid_owner_name'] = __( 'Billing First Name and Last Name are required.', 'woocommerce-gateway-stripe' ); |
|
453 | - $stripe_params['is_change_payment_page'] = isset( $_GET['change_payment_method'] ) ? 'yes' : 'no'; // wpcs: csrf ok. |
|
454 | - $stripe_params['is_add_payment_page'] = is_wc_endpoint_url( 'add-payment-method' ) ? 'yes' : 'no'; |
|
455 | - $stripe_params['is_pay_for_order_page'] = is_wc_endpoint_url( 'order-pay' ) ? 'yes' : 'no'; |
|
456 | - $stripe_params['elements_styling'] = apply_filters( 'wc_stripe_elements_styling', false ); |
|
457 | - $stripe_params['elements_classes'] = apply_filters( 'wc_stripe_elements_classes', false ); |
|
452 | + $stripe_params['invalid_owner_name'] = __('Billing First Name and Last Name are required.', 'woocommerce-gateway-stripe'); |
|
453 | + $stripe_params['is_change_payment_page'] = isset($_GET['change_payment_method']) ? 'yes' : 'no'; // wpcs: csrf ok. |
|
454 | + $stripe_params['is_add_payment_page'] = is_wc_endpoint_url('add-payment-method') ? 'yes' : 'no'; |
|
455 | + $stripe_params['is_pay_for_order_page'] = is_wc_endpoint_url('order-pay') ? 'yes' : 'no'; |
|
456 | + $stripe_params['elements_styling'] = apply_filters('wc_stripe_elements_styling', false); |
|
457 | + $stripe_params['elements_classes'] = apply_filters('wc_stripe_elements_classes', false); |
|
458 | 458 | |
459 | 459 | // Merge localized messages to be use in JS. |
460 | - $stripe_params = array_merge( $stripe_params, WC_Stripe_Helper::get_localized_messages() ); |
|
460 | + $stripe_params = array_merge($stripe_params, WC_Stripe_Helper::get_localized_messages()); |
|
461 | 461 | |
462 | - wp_localize_script( 'woocommerce_stripe', 'wc_stripe_params', apply_filters( 'wc_stripe_params', $stripe_params ) ); |
|
462 | + wp_localize_script('woocommerce_stripe', 'wc_stripe_params', apply_filters('wc_stripe_params', $stripe_params)); |
|
463 | 463 | |
464 | 464 | $this->tokenization_script(); |
465 | - wp_enqueue_script( 'woocommerce_stripe' ); |
|
465 | + wp_enqueue_script('woocommerce_stripe'); |
|
466 | 466 | } |
467 | 467 | |
468 | 468 | /** |
@@ -473,14 +473,14 @@ discard block |
||
473 | 473 | * @param object $prepared_source The object with source details. |
474 | 474 | * @throws WC_Stripe_Exception An exception if the card is prepaid, but prepaid cards are not allowed. |
475 | 475 | */ |
476 | - public function maybe_disallow_prepaid_card( $prepared_source ) { |
|
476 | + public function maybe_disallow_prepaid_card($prepared_source) { |
|
477 | 477 | // Check if we don't allow prepaid credit cards. |
478 | - if ( apply_filters( 'wc_stripe_allow_prepaid_card', true ) || ! $this->is_prepaid_card( $prepared_source->source_object ) ) { |
|
478 | + if (apply_filters('wc_stripe_allow_prepaid_card', true) || ! $this->is_prepaid_card($prepared_source->source_object)) { |
|
479 | 479 | return; |
480 | 480 | } |
481 | 481 | |
482 | - $localized_message = __( 'Sorry, we\'re not accepting prepaid cards at this time. Your credit card has not been charged. Please try with alternative payment method.', 'woocommerce-gateway-stripe' ); |
|
483 | - throw new WC_Stripe_Exception( print_r( $prepared_source->source_object, true ), $localized_message ); |
|
482 | + $localized_message = __('Sorry, we\'re not accepting prepaid cards at this time. Your credit card has not been charged. Please try with alternative payment method.', 'woocommerce-gateway-stripe'); |
|
483 | + throw new WC_Stripe_Exception(print_r($prepared_source->source_object, true), $localized_message); |
|
484 | 484 | } |
485 | 485 | |
486 | 486 | /** |
@@ -490,10 +490,10 @@ discard block |
||
490 | 490 | * @param object $prepared_source The source that should be verified. |
491 | 491 | * @throws WC_Stripe_Exception An exception if the source ID is missing. |
492 | 492 | */ |
493 | - public function check_source( $prepared_source ) { |
|
494 | - if ( empty( $prepared_source->source ) ) { |
|
495 | - $localized_message = __( 'Payment processing failed. Please retry.', 'woocommerce-gateway-stripe' ); |
|
496 | - throw new WC_Stripe_Exception( print_r( $prepared_source, true ), $localized_message ); |
|
493 | + public function check_source($prepared_source) { |
|
494 | + if (empty($prepared_source->source)) { |
|
495 | + $localized_message = __('Payment processing failed. Please retry.', 'woocommerce-gateway-stripe'); |
|
496 | + throw new WC_Stripe_Exception(print_r($prepared_source, true), $localized_message); |
|
497 | 497 | } |
498 | 498 | } |
499 | 499 | |
@@ -505,17 +505,17 @@ discard block |
||
505 | 505 | * @param WC_Order $order The order those payment is being processed. |
506 | 506 | * @return bool A flag that indicates that the customer does not exist and should be removed. |
507 | 507 | */ |
508 | - public function maybe_remove_non_existent_customer( $error, $order ) { |
|
509 | - if ( ! $this->is_no_such_customer_error( $error ) ) { |
|
508 | + public function maybe_remove_non_existent_customer($error, $order) { |
|
509 | + if ( ! $this->is_no_such_customer_error($error)) { |
|
510 | 510 | return false; |
511 | 511 | } |
512 | 512 | |
513 | - if ( WC_Stripe_Helper::is_wc_lt( '3.0' ) ) { |
|
514 | - delete_user_option( $order->customer_user, '_stripe_customer_id' ); |
|
515 | - delete_post_meta( $order->get_id(), '_stripe_customer_id' ); |
|
513 | + if (WC_Stripe_Helper::is_wc_lt('3.0')) { |
|
514 | + delete_user_option($order->customer_user, '_stripe_customer_id'); |
|
515 | + delete_post_meta($order->get_id(), '_stripe_customer_id'); |
|
516 | 516 | } else { |
517 | - delete_user_option( $order->get_customer_id(), '_stripe_customer_id' ); |
|
518 | - $order->delete_meta_data( '_stripe_customer_id' ); |
|
517 | + delete_user_option($order->get_customer_id(), '_stripe_customer_id'); |
|
518 | + $order->delete_meta_data('_stripe_customer_id'); |
|
519 | 519 | $order->save(); |
520 | 520 | } |
521 | 521 | |
@@ -531,15 +531,15 @@ discard block |
||
531 | 531 | * @param boolean $force_save_source Whether the payment source must be saved, like when dealing with a Subscription setup. |
532 | 532 | * @return array Redirection data for `process_payment`. |
533 | 533 | */ |
534 | - public function complete_free_order( $order, $prepared_source, $force_save_source ) { |
|
535 | - if ( $force_save_source ) { |
|
536 | - $intent_secret = $this->setup_intent( $order, $prepared_source ); |
|
534 | + public function complete_free_order($order, $prepared_source, $force_save_source) { |
|
535 | + if ($force_save_source) { |
|
536 | + $intent_secret = $this->setup_intent($order, $prepared_source); |
|
537 | 537 | |
538 | - if ( ! empty( $intent_secret ) ) { |
|
538 | + if ( ! empty($intent_secret)) { |
|
539 | 539 | // `get_return_url()` must be called immediately before returning a value. |
540 | 540 | return array( |
541 | 541 | 'result' => 'success', |
542 | - 'redirect' => $this->get_return_url( $order ), |
|
542 | + 'redirect' => $this->get_return_url($order), |
|
543 | 543 | 'setup_intent_secret' => $intent_secret, |
544 | 544 | ); |
545 | 545 | } |
@@ -553,7 +553,7 @@ discard block |
||
553 | 553 | // Return thank you page redirect. |
554 | 554 | return array( |
555 | 555 | 'result' => 'success', |
556 | - 'redirect' => $this->get_return_url( $order ), |
|
556 | + 'redirect' => $this->get_return_url($order), |
|
557 | 557 | ); |
558 | 558 | } |
559 | 559 | |
@@ -570,76 +570,76 @@ discard block |
||
570 | 570 | * @throws Exception If payment will not be accepted. |
571 | 571 | * @return array|void |
572 | 572 | */ |
573 | - public function process_payment( $order_id, $retry = true, $force_save_source = false, $previous_error = false ) { |
|
573 | + public function process_payment($order_id, $retry = true, $force_save_source = false, $previous_error = false) { |
|
574 | 574 | try { |
575 | - $order = wc_get_order( $order_id ); |
|
575 | + $order = wc_get_order($order_id); |
|
576 | 576 | |
577 | 577 | // ToDo: `process_pre_order` saves the source to the order for a later payment. |
578 | 578 | // This might not work well with PaymentIntents. |
579 | - if ( $this->maybe_process_pre_orders( $order_id ) ) { |
|
580 | - return $this->pre_orders->process_pre_order( $order_id ); |
|
579 | + if ($this->maybe_process_pre_orders($order_id)) { |
|
580 | + return $this->pre_orders->process_pre_order($order_id); |
|
581 | 581 | } |
582 | 582 | |
583 | 583 | // Check whether there is an existing intent. |
584 | - $intent = $this->get_intent_from_order( $order ); |
|
585 | - if ( isset( $intent->object ) && 'setup_intent' === $intent->object ) { |
|
584 | + $intent = $this->get_intent_from_order($order); |
|
585 | + if (isset($intent->object) && 'setup_intent' === $intent->object) { |
|
586 | 586 | $intent = false; // This function can only deal with *payment* intents |
587 | 587 | } |
588 | 588 | |
589 | 589 | $stripe_customer_id = null; |
590 | - if ( $intent && ! empty( $intent->customer ) ) { |
|
590 | + if ($intent && ! empty($intent->customer)) { |
|
591 | 591 | $stripe_customer_id = $intent->customer; |
592 | 592 | } |
593 | 593 | |
594 | - $prepared_source = $this->prepare_source( get_current_user_id(), $force_save_source, $stripe_customer_id ); |
|
594 | + $prepared_source = $this->prepare_source(get_current_user_id(), $force_save_source, $stripe_customer_id); |
|
595 | 595 | |
596 | - $this->maybe_disallow_prepaid_card( $prepared_source ); |
|
597 | - $this->check_source( $prepared_source ); |
|
598 | - $this->save_source_to_order( $order, $prepared_source ); |
|
596 | + $this->maybe_disallow_prepaid_card($prepared_source); |
|
597 | + $this->check_source($prepared_source); |
|
598 | + $this->save_source_to_order($order, $prepared_source); |
|
599 | 599 | |
600 | - if ( 0 >= $order->get_total() ) { |
|
601 | - return $this->complete_free_order( $order, $prepared_source, $force_save_source ); |
|
600 | + if (0 >= $order->get_total()) { |
|
601 | + return $this->complete_free_order($order, $prepared_source, $force_save_source); |
|
602 | 602 | } |
603 | 603 | |
604 | 604 | // This will throw exception if not valid. |
605 | - $this->validate_minimum_order_amount( $order ); |
|
605 | + $this->validate_minimum_order_amount($order); |
|
606 | 606 | |
607 | - WC_Stripe_Logger::log( "Info: Begin processing payment for order $order_id for the amount of {$order->get_total()}" ); |
|
607 | + WC_Stripe_Logger::log("Info: Begin processing payment for order $order_id for the amount of {$order->get_total()}"); |
|
608 | 608 | |
609 | - if ( $intent ) { |
|
610 | - $intent = $this->update_existing_intent( $intent, $order, $prepared_source ); |
|
609 | + if ($intent) { |
|
610 | + $intent = $this->update_existing_intent($intent, $order, $prepared_source); |
|
611 | 611 | } else { |
612 | - $intent = $this->create_intent( $order, $prepared_source ); |
|
612 | + $intent = $this->create_intent($order, $prepared_source); |
|
613 | 613 | } |
614 | 614 | |
615 | 615 | // Confirm the intent after locking the order to make sure webhooks will not interfere. |
616 | - if ( empty( $intent->error ) ) { |
|
617 | - $this->lock_order_payment( $order, $intent ); |
|
618 | - $intent = $this->confirm_intent( $intent, $order, $prepared_source ); |
|
616 | + if (empty($intent->error)) { |
|
617 | + $this->lock_order_payment($order, $intent); |
|
618 | + $intent = $this->confirm_intent($intent, $order, $prepared_source); |
|
619 | 619 | } |
620 | 620 | |
621 | - if ( ! empty( $intent->error ) ) { |
|
622 | - $this->maybe_remove_non_existent_customer( $intent->error, $order ); |
|
621 | + if ( ! empty($intent->error)) { |
|
622 | + $this->maybe_remove_non_existent_customer($intent->error, $order); |
|
623 | 623 | |
624 | 624 | // We want to retry. |
625 | - if ( $this->is_retryable_error( $intent->error ) ) { |
|
626 | - return $this->retry_after_error( $intent, $order, $retry, $force_save_source, $previous_error ); |
|
625 | + if ($this->is_retryable_error($intent->error)) { |
|
626 | + return $this->retry_after_error($intent, $order, $retry, $force_save_source, $previous_error); |
|
627 | 627 | } |
628 | 628 | |
629 | - $this->unlock_order_payment( $order ); |
|
630 | - $this->throw_localized_message( $intent, $order ); |
|
629 | + $this->unlock_order_payment($order); |
|
630 | + $this->throw_localized_message($intent, $order); |
|
631 | 631 | } |
632 | 632 | |
633 | - if ( ! empty( $intent ) ) { |
|
633 | + if ( ! empty($intent)) { |
|
634 | 634 | // Use the last charge within the intent to proceed. |
635 | - $response = end( $intent->charges->data ); |
|
635 | + $response = end($intent->charges->data); |
|
636 | 636 | |
637 | 637 | // If the intent requires a 3DS flow, redirect to it. |
638 | - if ( 'requires_action' === $intent->status ) { |
|
639 | - $this->unlock_order_payment( $order ); |
|
638 | + if ('requires_action' === $intent->status) { |
|
639 | + $this->unlock_order_payment($order); |
|
640 | 640 | |
641 | - if ( is_wc_endpoint_url( 'order-pay' ) ) { |
|
642 | - $redirect_url = add_query_arg( 'wc-stripe-confirmation', 1, $order->get_checkout_payment_url( false ) ); |
|
641 | + if (is_wc_endpoint_url('order-pay')) { |
|
642 | + $redirect_url = add_query_arg('wc-stripe-confirmation', 1, $order->get_checkout_payment_url(false)); |
|
643 | 643 | |
644 | 644 | return array( |
645 | 645 | 'result' => 'success', |
@@ -654,7 +654,7 @@ discard block |
||
654 | 654 | |
655 | 655 | return array( |
656 | 656 | 'result' => 'success', |
657 | - 'redirect' => $this->get_return_url( $order ), |
|
657 | + 'redirect' => $this->get_return_url($order), |
|
658 | 658 | 'payment_intent_secret' => $intent->client_secret, |
659 | 659 | ); |
660 | 660 | } |
@@ -662,30 +662,30 @@ discard block |
||
662 | 662 | } |
663 | 663 | |
664 | 664 | // Process valid response. |
665 | - $this->process_response( $response, $order ); |
|
665 | + $this->process_response($response, $order); |
|
666 | 666 | |
667 | 667 | // Remove cart. |
668 | - if ( isset( WC()->cart ) ) { |
|
668 | + if (isset(WC()->cart)) { |
|
669 | 669 | WC()->cart->empty_cart(); |
670 | 670 | } |
671 | 671 | |
672 | 672 | // Unlock the order. |
673 | - $this->unlock_order_payment( $order ); |
|
673 | + $this->unlock_order_payment($order); |
|
674 | 674 | |
675 | 675 | // Return thank you page redirect. |
676 | 676 | return array( |
677 | 677 | 'result' => 'success', |
678 | - 'redirect' => $this->get_return_url( $order ), |
|
678 | + 'redirect' => $this->get_return_url($order), |
|
679 | 679 | ); |
680 | 680 | |
681 | - } catch ( WC_Stripe_Exception $e ) { |
|
682 | - wc_add_notice( $e->getLocalizedMessage(), 'error' ); |
|
683 | - WC_Stripe_Logger::log( 'Error: ' . $e->getMessage() ); |
|
681 | + } catch (WC_Stripe_Exception $e) { |
|
682 | + wc_add_notice($e->getLocalizedMessage(), 'error'); |
|
683 | + WC_Stripe_Logger::log('Error: ' . $e->getMessage()); |
|
684 | 684 | |
685 | - do_action( 'wc_gateway_stripe_process_payment_error', $e, $order ); |
|
685 | + do_action('wc_gateway_stripe_process_payment_error', $e, $order); |
|
686 | 686 | |
687 | 687 | /* translators: error message */ |
688 | - $order->update_status( 'failed' ); |
|
688 | + $order->update_status('failed'); |
|
689 | 689 | |
690 | 690 | return array( |
691 | 691 | 'result' => 'fail', |
@@ -701,17 +701,17 @@ discard block |
||
701 | 701 | * |
702 | 702 | * @param int $order_id The ID of the order. |
703 | 703 | */ |
704 | - public function display_order_fee( $order_id ) { |
|
705 | - if ( apply_filters( 'wc_stripe_hide_display_order_fee', false, $order_id ) ) { |
|
704 | + public function display_order_fee($order_id) { |
|
705 | + if (apply_filters('wc_stripe_hide_display_order_fee', false, $order_id)) { |
|
706 | 706 | return; |
707 | 707 | } |
708 | 708 | |
709 | - $order = wc_get_order( $order_id ); |
|
709 | + $order = wc_get_order($order_id); |
|
710 | 710 | |
711 | - $fee = WC_Stripe_Helper::get_stripe_fee( $order ); |
|
712 | - $currency = WC_Stripe_Helper::get_stripe_currency( $order ); |
|
711 | + $fee = WC_Stripe_Helper::get_stripe_fee($order); |
|
712 | + $currency = WC_Stripe_Helper::get_stripe_currency($order); |
|
713 | 713 | |
714 | - if ( ! $fee || ! $currency ) { |
|
714 | + if ( ! $fee || ! $currency) { |
|
715 | 715 | return; |
716 | 716 | } |
717 | 717 | |
@@ -719,12 +719,12 @@ discard block |
||
719 | 719 | |
720 | 720 | <tr> |
721 | 721 | <td class="label stripe-fee"> |
722 | - <?php echo wc_help_tip( __( 'This represents the fee Stripe collects for the transaction.', 'woocommerce-gateway-stripe' ) ); // wpcs: xss ok. ?> |
|
723 | - <?php esc_html_e( 'Stripe Fee:', 'woocommerce-gateway-stripe' ); ?> |
|
722 | + <?php echo wc_help_tip(__('This represents the fee Stripe collects for the transaction.', 'woocommerce-gateway-stripe')); // wpcs: xss ok. ?> |
|
723 | + <?php esc_html_e('Stripe Fee:', 'woocommerce-gateway-stripe'); ?> |
|
724 | 724 | </td> |
725 | 725 | <td width="1%"></td> |
726 | 726 | <td class="total"> |
727 | - - <?php echo wc_price( $fee, array( 'currency' => $currency ) ); // wpcs: xss ok. ?> |
|
727 | + - <?php echo wc_price($fee, array('currency' => $currency)); // wpcs: xss ok. ?> |
|
728 | 728 | </td> |
729 | 729 | </tr> |
730 | 730 | |
@@ -738,17 +738,17 @@ discard block |
||
738 | 738 | * |
739 | 739 | * @param int $order_id The ID of the order. |
740 | 740 | */ |
741 | - public function display_order_payout( $order_id ) { |
|
742 | - if ( apply_filters( 'wc_stripe_hide_display_order_payout', false, $order_id ) ) { |
|
741 | + public function display_order_payout($order_id) { |
|
742 | + if (apply_filters('wc_stripe_hide_display_order_payout', false, $order_id)) { |
|
743 | 743 | return; |
744 | 744 | } |
745 | 745 | |
746 | - $order = wc_get_order( $order_id ); |
|
746 | + $order = wc_get_order($order_id); |
|
747 | 747 | |
748 | - $net = WC_Stripe_Helper::get_stripe_net( $order ); |
|
749 | - $currency = WC_Stripe_Helper::get_stripe_currency( $order ); |
|
748 | + $net = WC_Stripe_Helper::get_stripe_net($order); |
|
749 | + $currency = WC_Stripe_Helper::get_stripe_currency($order); |
|
750 | 750 | |
751 | - if ( ! $net || ! $currency ) { |
|
751 | + if ( ! $net || ! $currency) { |
|
752 | 752 | return; |
753 | 753 | } |
754 | 754 | |
@@ -756,12 +756,12 @@ discard block |
||
756 | 756 | |
757 | 757 | <tr> |
758 | 758 | <td class="label stripe-payout"> |
759 | - <?php echo wc_help_tip( __( 'This represents the net total that will be credited to your Stripe bank account. This may be in the currency that is set in your Stripe account.', 'woocommerce-gateway-stripe' ) ); // wpcs: xss ok. ?> |
|
760 | - <?php esc_html_e( 'Stripe Payout:', 'woocommerce-gateway-stripe' ); ?> |
|
759 | + <?php echo wc_help_tip(__('This represents the net total that will be credited to your Stripe bank account. This may be in the currency that is set in your Stripe account.', 'woocommerce-gateway-stripe')); // wpcs: xss ok. ?> |
|
760 | + <?php esc_html_e('Stripe Payout:', 'woocommerce-gateway-stripe'); ?> |
|
761 | 761 | </td> |
762 | 762 | <td width="1%"></td> |
763 | 763 | <td class="total"> |
764 | - <?php echo wc_price( $net, array( 'currency' => $currency ) ); // wpcs: xss ok. ?> |
|
764 | + <?php echo wc_price($net, array('currency' => $currency)); // wpcs: xss ok. ?> |
|
765 | 765 | </td> |
766 | 766 | </tr> |
767 | 767 | |
@@ -776,18 +776,18 @@ discard block |
||
776 | 776 | * @param WC_Order $order The order to add a note to. |
777 | 777 | * @throws WC_Stripe_Exception An exception with the right message. |
778 | 778 | */ |
779 | - public function throw_localized_message( $response, $order ) { |
|
779 | + public function throw_localized_message($response, $order) { |
|
780 | 780 | $localized_messages = WC_Stripe_Helper::get_localized_messages(); |
781 | 781 | |
782 | - if ( 'card_error' === $response->error->type ) { |
|
783 | - $localized_message = isset( $localized_messages[ $response->error->code ] ) ? $localized_messages[ $response->error->code ] : $response->error->message; |
|
782 | + if ('card_error' === $response->error->type) { |
|
783 | + $localized_message = isset($localized_messages[$response->error->code]) ? $localized_messages[$response->error->code] : $response->error->message; |
|
784 | 784 | } else { |
785 | - $localized_message = isset( $localized_messages[ $response->error->type ] ) ? $localized_messages[ $response->error->type ] : $response->error->message; |
|
785 | + $localized_message = isset($localized_messages[$response->error->type]) ? $localized_messages[$response->error->type] : $response->error->message; |
|
786 | 786 | } |
787 | 787 | |
788 | - $order->add_order_note( $localized_message ); |
|
788 | + $order->add_order_note($localized_message); |
|
789 | 789 | |
790 | - throw new WC_Stripe_Exception( print_r( $response, true ), $localized_message ); |
|
790 | + throw new WC_Stripe_Exception(print_r($response, true), $localized_message); |
|
791 | 791 | } |
792 | 792 | |
793 | 793 | /** |
@@ -802,22 +802,22 @@ discard block |
||
802 | 802 | * @throws WC_Stripe_Exception If the payment is not accepted. |
803 | 803 | * @return array|void |
804 | 804 | */ |
805 | - public function retry_after_error( $response, $order, $retry, $force_save_source, $previous_error ) { |
|
806 | - if ( ! $retry ) { |
|
807 | - $localized_message = __( 'Sorry, we are unable to process your payment at this time. Please retry later.', 'woocommerce-gateway-stripe' ); |
|
808 | - $order->add_order_note( $localized_message ); |
|
809 | - throw new WC_Stripe_Exception( print_r( $response, true ), $localized_message ); // phpcs:ignore WordPress.PHP.DevelopmentFunctions. |
|
805 | + public function retry_after_error($response, $order, $retry, $force_save_source, $previous_error) { |
|
806 | + if ( ! $retry) { |
|
807 | + $localized_message = __('Sorry, we are unable to process your payment at this time. Please retry later.', 'woocommerce-gateway-stripe'); |
|
808 | + $order->add_order_note($localized_message); |
|
809 | + throw new WC_Stripe_Exception(print_r($response, true), $localized_message); // phpcs:ignore WordPress.PHP.DevelopmentFunctions. |
|
810 | 810 | } |
811 | 811 | |
812 | 812 | // Don't do anymore retries after this. |
813 | - if ( 5 <= $this->retry_interval ) { |
|
814 | - return $this->process_payment( $order->get_id(), false, $force_save_source, $response->error, $previous_error ); |
|
813 | + if (5 <= $this->retry_interval) { |
|
814 | + return $this->process_payment($order->get_id(), false, $force_save_source, $response->error, $previous_error); |
|
815 | 815 | } |
816 | 816 | |
817 | - sleep( $this->retry_interval ); |
|
817 | + sleep($this->retry_interval); |
|
818 | 818 | $this->retry_interval++; |
819 | 819 | |
820 | - return $this->process_payment( $order->get_id(), true, $force_save_source, $response->error, $previous_error ); |
|
820 | + return $this->process_payment($order->get_id(), true, $force_save_source, $response->error, $previous_error); |
|
821 | 821 | } |
822 | 822 | |
823 | 823 | /** |
@@ -828,23 +828,23 @@ discard block |
||
828 | 828 | * @param WC_Payment_Gateway[] $gateways A list of all available gateways. |
829 | 829 | * @return WC_Payment_Gateway[] Either the same list or an empty one in the right conditions. |
830 | 830 | */ |
831 | - public function prepare_order_pay_page( $gateways ) { |
|
832 | - if ( ! is_wc_endpoint_url( 'order-pay' ) || ! isset( $_GET['wc-stripe-confirmation'] ) ) { // wpcs: csrf ok. |
|
831 | + public function prepare_order_pay_page($gateways) { |
|
832 | + if ( ! is_wc_endpoint_url('order-pay') || ! isset($_GET['wc-stripe-confirmation'])) { // wpcs: csrf ok. |
|
833 | 833 | return $gateways; |
834 | 834 | } |
835 | 835 | |
836 | 836 | try { |
837 | 837 | $this->prepare_intent_for_order_pay_page(); |
838 | - } catch ( WC_Stripe_Exception $e ) { |
|
838 | + } catch (WC_Stripe_Exception $e) { |
|
839 | 839 | // Just show the full order pay page if there was a problem preparing the Payment Intent |
840 | 840 | return $gateways; |
841 | 841 | } |
842 | 842 | |
843 | - add_filter( 'woocommerce_checkout_show_terms', '__return_false' ); |
|
844 | - add_filter( 'woocommerce_pay_order_button_html', '__return_false' ); |
|
845 | - add_filter( 'woocommerce_available_payment_gateways', '__return_empty_array' ); |
|
846 | - add_filter( 'woocommerce_no_available_payment_methods_message', array( $this, 'change_no_available_methods_message' ) ); |
|
847 | - add_action( 'woocommerce_pay_order_after_submit', array( $this, 'render_payment_intent_inputs' ) ); |
|
843 | + add_filter('woocommerce_checkout_show_terms', '__return_false'); |
|
844 | + add_filter('woocommerce_pay_order_button_html', '__return_false'); |
|
845 | + add_filter('woocommerce_available_payment_gateways', '__return_empty_array'); |
|
846 | + add_filter('woocommerce_no_available_payment_methods_message', array($this, 'change_no_available_methods_message')); |
|
847 | + add_action('woocommerce_pay_order_after_submit', array($this, 'render_payment_intent_inputs')); |
|
848 | 848 | |
849 | 849 | return array(); |
850 | 850 | } |
@@ -857,7 +857,7 @@ discard block |
||
857 | 857 | * @return string the new message. |
858 | 858 | */ |
859 | 859 | public function change_no_available_methods_message() { |
860 | - return wpautop( __( "Almost there!\n\nYour order has already been created, the only thing that still needs to be done is for you to authorize the payment with your bank.", 'woocommerce-gateway-stripe' ) ); |
|
860 | + return wpautop(__("Almost there!\n\nYour order has already been created, the only thing that still needs to be done is for you to authorize the payment with your bank.", 'woocommerce-gateway-stripe')); |
|
861 | 861 | } |
862 | 862 | |
863 | 863 | /** |
@@ -868,23 +868,23 @@ discard block |
||
868 | 868 | * @throws WC_Stripe_Exception |
869 | 869 | * @since 4.3 |
870 | 870 | */ |
871 | - public function prepare_intent_for_order_pay_page( $order = null ) { |
|
872 | - if ( ! isset( $order ) || empty( $order ) ) { |
|
873 | - $order = wc_get_order( absint( get_query_var( 'order-pay' ) ) ); |
|
871 | + public function prepare_intent_for_order_pay_page($order = null) { |
|
872 | + if ( ! isset($order) || empty($order)) { |
|
873 | + $order = wc_get_order(absint(get_query_var('order-pay'))); |
|
874 | 874 | } |
875 | - $intent = $this->get_intent_from_order( $order ); |
|
875 | + $intent = $this->get_intent_from_order($order); |
|
876 | 876 | |
877 | - if ( ! $intent ) { |
|
878 | - throw new WC_Stripe_Exception( 'Payment Intent not found', __( 'Payment Intent not found for order #' . $order->get_id(), 'woocommerce-gateway-stripe' ) ); |
|
877 | + if ( ! $intent) { |
|
878 | + throw new WC_Stripe_Exception('Payment Intent not found', __('Payment Intent not found for order #' . $order->get_id(), 'woocommerce-gateway-stripe')); |
|
879 | 879 | } |
880 | 880 | |
881 | - if ( 'requires_payment_method' === $intent->status && isset( $intent->last_payment_error ) |
|
882 | - && 'authentication_required' === $intent->last_payment_error->code ) { |
|
883 | - $intent = WC_Stripe_API::request( array( |
|
881 | + if ('requires_payment_method' === $intent->status && isset($intent->last_payment_error) |
|
882 | + && 'authentication_required' === $intent->last_payment_error->code) { |
|
883 | + $intent = WC_Stripe_API::request(array( |
|
884 | 884 | 'payment_method' => $intent->last_payment_error->source->id, |
885 | - ), 'payment_intents/' . $intent->id . '/confirm' ); |
|
886 | - if ( isset( $intent->error ) ) { |
|
887 | - throw new WC_Stripe_Exception( print_r( $intent, true ), $intent->error->message ); |
|
885 | + ), 'payment_intents/' . $intent->id . '/confirm'); |
|
886 | + if (isset($intent->error)) { |
|
887 | + throw new WC_Stripe_Exception(print_r($intent, true), $intent->error->message); |
|
888 | 888 | } |
889 | 889 | } |
890 | 890 | |
@@ -899,26 +899,26 @@ discard block |
||
899 | 899 | * @throws WC_Stripe_Exception |
900 | 900 | * @since 4.2 |
901 | 901 | */ |
902 | - public function render_payment_intent_inputs( $order = null ) { |
|
903 | - if ( ! isset( $order ) || empty( $order ) ) { |
|
904 | - $order = wc_get_order( absint( get_query_var( 'order-pay' ) ) ); |
|
902 | + public function render_payment_intent_inputs($order = null) { |
|
903 | + if ( ! isset($order) || empty($order)) { |
|
904 | + $order = wc_get_order(absint(get_query_var('order-pay'))); |
|
905 | 905 | } |
906 | - if ( ! isset( $this->order_pay_intent ) ) { |
|
907 | - $this->prepare_intent_for_order_pay_page( $order ); |
|
906 | + if ( ! isset($this->order_pay_intent)) { |
|
907 | + $this->prepare_intent_for_order_pay_page($order); |
|
908 | 908 | } |
909 | 909 | |
910 | 910 | $verification_url = add_query_arg( |
911 | 911 | array( |
912 | 912 | 'order' => $order->get_id(), |
913 | - 'nonce' => wp_create_nonce( 'wc_stripe_confirm_pi' ), |
|
914 | - 'redirect_to' => rawurlencode( $this->get_return_url( $order ) ), |
|
913 | + 'nonce' => wp_create_nonce('wc_stripe_confirm_pi'), |
|
914 | + 'redirect_to' => rawurlencode($this->get_return_url($order)), |
|
915 | 915 | 'is_pay_for_order' => true, |
916 | 916 | ), |
917 | - WC_AJAX::get_endpoint( 'wc_stripe_verify_intent' ) |
|
917 | + WC_AJAX::get_endpoint('wc_stripe_verify_intent') |
|
918 | 918 | ); |
919 | 919 | |
920 | - echo '<input type="hidden" id="stripe-intent-id" value="' . esc_attr( $this->order_pay_intent->client_secret ) . '" />'; |
|
921 | - echo '<input type="hidden" id="stripe-intent-return" value="' . esc_attr( $verification_url ) . '" />'; |
|
920 | + echo '<input type="hidden" id="stripe-intent-id" value="' . esc_attr($this->order_pay_intent->client_secret) . '" />'; |
|
921 | + echo '<input type="hidden" id="stripe-intent-return" value="' . esc_attr($verification_url) . '" />'; |
|
922 | 922 | } |
923 | 923 | |
924 | 924 | /** |
@@ -928,11 +928,11 @@ discard block |
||
928 | 928 | * @param WC_Payment_Token $token Payment Token. |
929 | 929 | * @return string Generated payment method HTML |
930 | 930 | */ |
931 | - public function get_saved_payment_method_option_html( $token ) { |
|
932 | - $html = parent::get_saved_payment_method_option_html( $token ); |
|
931 | + public function get_saved_payment_method_option_html($token) { |
|
932 | + $html = parent::get_saved_payment_method_option_html($token); |
|
933 | 933 | $error_wrapper = '<div class="stripe-source-errors" role="alert"></div>'; |
934 | 934 | |
935 | - return preg_replace( '~</(\w+)>\s*$~', "$error_wrapper</$1>", $html ); |
|
935 | + return preg_replace('~</(\w+)>\s*$~', "$error_wrapper</$1>", $html); |
|
936 | 936 | } |
937 | 937 | |
938 | 938 | /** |
@@ -942,18 +942,18 @@ discard block |
||
942 | 942 | * @since 4.2.0 |
943 | 943 | * @param int $order_id The ID that will be used for the thank you page. |
944 | 944 | */ |
945 | - public function check_intent_status_on_order_page( $order_id ) { |
|
946 | - if ( empty( $order_id ) || absint( $order_id ) <= 0 ) { |
|
945 | + public function check_intent_status_on_order_page($order_id) { |
|
946 | + if (empty($order_id) || absint($order_id) <= 0) { |
|
947 | 947 | return; |
948 | 948 | } |
949 | 949 | |
950 | - $order = wc_get_order( absint( $order_id ) ); |
|
950 | + $order = wc_get_order(absint($order_id)); |
|
951 | 951 | |
952 | - if ( ! $order ) { |
|
952 | + if ( ! $order) { |
|
953 | 953 | return; |
954 | 954 | } |
955 | 955 | |
956 | - $this->verify_intent_after_checkout( $order ); |
|
956 | + $this->verify_intent_after_checkout($order); |
|
957 | 957 | } |
958 | 958 | |
959 | 959 | /** |
@@ -967,8 +967,8 @@ discard block |
||
967 | 967 | * @param int $order_id The ID of the order which is being paid for. |
968 | 968 | * @return array |
969 | 969 | */ |
970 | - public function modify_successful_payment_result( $result, $order_id ) { |
|
971 | - if ( ! isset( $result['payment_intent_secret'] ) && ! isset( $result['setup_intent_secret'] ) ) { |
|
970 | + public function modify_successful_payment_result($result, $order_id) { |
|
971 | + if ( ! isset($result['payment_intent_secret']) && ! isset($result['setup_intent_secret'])) { |
|
972 | 972 | // Only redirects with intents need to be modified. |
973 | 973 | return $result; |
974 | 974 | } |
@@ -977,16 +977,16 @@ discard block |
||
977 | 977 | $verification_url = add_query_arg( |
978 | 978 | array( |
979 | 979 | 'order' => $order_id, |
980 | - 'nonce' => wp_create_nonce( 'wc_stripe_confirm_pi' ), |
|
981 | - 'redirect_to' => rawurlencode( $result['redirect'] ), |
|
980 | + 'nonce' => wp_create_nonce('wc_stripe_confirm_pi'), |
|
981 | + 'redirect_to' => rawurlencode($result['redirect']), |
|
982 | 982 | ), |
983 | - WC_AJAX::get_endpoint( 'wc_stripe_verify_intent' ) |
|
983 | + WC_AJAX::get_endpoint('wc_stripe_verify_intent') |
|
984 | 984 | ); |
985 | 985 | |
986 | - if ( isset( $result['payment_intent_secret'] ) ) { |
|
987 | - $redirect = sprintf( '#confirm-pi-%s:%s', $result['payment_intent_secret'], rawurlencode( $verification_url ) ); |
|
988 | - } else if ( isset( $result['setup_intent_secret'] ) ) { |
|
989 | - $redirect = sprintf( '#confirm-si-%s:%s', $result['setup_intent_secret'], rawurlencode( $verification_url ) ); |
|
986 | + if (isset($result['payment_intent_secret'])) { |
|
987 | + $redirect = sprintf('#confirm-pi-%s:%s', $result['payment_intent_secret'], rawurlencode($verification_url)); |
|
988 | + } else if (isset($result['setup_intent_secret'])) { |
|
989 | + $redirect = sprintf('#confirm-si-%s:%s', $result['setup_intent_secret'], rawurlencode($verification_url)); |
|
990 | 990 | } |
991 | 991 | |
992 | 992 | return array( |
@@ -998,8 +998,8 @@ discard block |
||
998 | 998 | /** |
999 | 999 | * Proceed with current request using new login session (to ensure consistent nonce). |
1000 | 1000 | */ |
1001 | - public function set_cookie_on_current_request( $cookie ) { |
|
1002 | - $_COOKIE[ LOGGED_IN_COOKIE ] = $cookie; |
|
1001 | + public function set_cookie_on_current_request($cookie) { |
|
1002 | + $_COOKIE[LOGGED_IN_COOKIE] = $cookie; |
|
1003 | 1003 | } |
1004 | 1004 | |
1005 | 1005 | /** |
@@ -1009,48 +1009,48 @@ discard block |
||
1009 | 1009 | * @since 4.2.0 |
1010 | 1010 | * @param WC_Order $order The order which is in a transitional state. |
1011 | 1011 | */ |
1012 | - public function verify_intent_after_checkout( $order ) { |
|
1013 | - $payment_method = WC_Stripe_Helper::is_wc_lt( '3.0' ) ? $order->payment_method : $order->get_payment_method(); |
|
1014 | - if ( $payment_method !== $this->id ) { |
|
1012 | + public function verify_intent_after_checkout($order) { |
|
1013 | + $payment_method = WC_Stripe_Helper::is_wc_lt('3.0') ? $order->payment_method : $order->get_payment_method(); |
|
1014 | + if ($payment_method !== $this->id) { |
|
1015 | 1015 | // If this is not the payment method, an intent would not be available. |
1016 | 1016 | return; |
1017 | 1017 | } |
1018 | 1018 | |
1019 | - $intent = $this->get_intent_from_order( $order ); |
|
1020 | - if ( ! $intent ) { |
|
1019 | + $intent = $this->get_intent_from_order($order); |
|
1020 | + if ( ! $intent) { |
|
1021 | 1021 | // No intent, redirect to the order received page for further actions. |
1022 | 1022 | return; |
1023 | 1023 | } |
1024 | 1024 | |
1025 | 1025 | // A webhook might have modified or locked the order while the intent was retreived. This ensures we are reading the right status. |
1026 | - clean_post_cache( $order->get_id() ); |
|
1027 | - $order = wc_get_order( $order->get_id() ); |
|
1026 | + clean_post_cache($order->get_id()); |
|
1027 | + $order = wc_get_order($order->get_id()); |
|
1028 | 1028 | |
1029 | - if ( ! $order->has_status( array( 'pending', 'failed' ) ) ) { |
|
1029 | + if ( ! $order->has_status(array('pending', 'failed'))) { |
|
1030 | 1030 | // If payment has already been completed, this function is redundant. |
1031 | 1031 | return; |
1032 | 1032 | } |
1033 | 1033 | |
1034 | - if ( $this->lock_order_payment( $order, $intent ) ) { |
|
1034 | + if ($this->lock_order_payment($order, $intent)) { |
|
1035 | 1035 | return; |
1036 | 1036 | } |
1037 | 1037 | |
1038 | - if ( 'setup_intent' === $intent->object && 'succeeded' === $intent->status ) { |
|
1038 | + if ('setup_intent' === $intent->object && 'succeeded' === $intent->status) { |
|
1039 | 1039 | WC()->cart->empty_cart(); |
1040 | - if ( WC_Stripe_Helper::is_pre_orders_exists() && WC_Pre_Orders_Order::order_contains_pre_order( $order ) ) { |
|
1041 | - WC_Pre_Orders_Order::mark_order_as_pre_ordered( $order ); |
|
1040 | + if (WC_Stripe_Helper::is_pre_orders_exists() && WC_Pre_Orders_Order::order_contains_pre_order($order)) { |
|
1041 | + WC_Pre_Orders_Order::mark_order_as_pre_ordered($order); |
|
1042 | 1042 | } else { |
1043 | 1043 | $order->payment_complete(); |
1044 | 1044 | } |
1045 | - } else if ( 'succeeded' === $intent->status || 'requires_capture' === $intent->status ) { |
|
1045 | + } else if ('succeeded' === $intent->status || 'requires_capture' === $intent->status) { |
|
1046 | 1046 | // Proceed with the payment completion. |
1047 | - $this->process_response( end( $intent->charges->data ), $order ); |
|
1048 | - } else if ( 'requires_payment_method' === $intent->status ) { |
|
1047 | + $this->process_response(end($intent->charges->data), $order); |
|
1048 | + } else if ('requires_payment_method' === $intent->status) { |
|
1049 | 1049 | // `requires_payment_method` means that SCA got denied for the current payment method. |
1050 | - $this->failed_sca_auth( $order, $intent ); |
|
1050 | + $this->failed_sca_auth($order, $intent); |
|
1051 | 1051 | } |
1052 | 1052 | |
1053 | - $this->unlock_order_payment( $order ); |
|
1053 | + $this->unlock_order_payment($order); |
|
1054 | 1054 | } |
1055 | 1055 | |
1056 | 1056 | /** |
@@ -1060,18 +1060,18 @@ discard block |
||
1060 | 1060 | * @param WC_Order $order The order which should be checked. |
1061 | 1061 | * @param object $intent The intent, associated with the order. |
1062 | 1062 | */ |
1063 | - public function failed_sca_auth( $order, $intent ) { |
|
1063 | + public function failed_sca_auth($order, $intent) { |
|
1064 | 1064 | // If the order has already failed, do not repeat the same message. |
1065 | - if ( $order->has_status( 'failed' ) ) { |
|
1065 | + if ($order->has_status('failed')) { |
|
1066 | 1066 | return; |
1067 | 1067 | } |
1068 | 1068 | |
1069 | 1069 | // Load the right message and update the status. |
1070 | - $status_message = isset( $intent->last_payment_error ) |
|
1070 | + $status_message = isset($intent->last_payment_error) |
|
1071 | 1071 | /* translators: 1) The error message that was received from Stripe. */ |
1072 | - ? sprintf( __( 'Stripe SCA authentication failed. Reason: %s', 'woocommerce-gateway-stripe' ), $intent->last_payment_error->message ) |
|
1073 | - : __( 'Stripe SCA authentication failed.', 'woocommerce-gateway-stripe' ); |
|
1074 | - $order->update_status( 'failed', $status_message ); |
|
1072 | + ? sprintf(__('Stripe SCA authentication failed. Reason: %s', 'woocommerce-gateway-stripe'), $intent->last_payment_error->message) |
|
1073 | + : __('Stripe SCA authentication failed.', 'woocommerce-gateway-stripe'); |
|
1074 | + $order->update_status('failed', $status_message); |
|
1075 | 1075 | } |
1076 | 1076 | |
1077 | 1077 | /** |
@@ -1082,10 +1082,10 @@ discard block |
||
1082 | 1082 | * |
1083 | 1083 | * @return string Checkout URL for the given order. |
1084 | 1084 | */ |
1085 | - public function get_checkout_payment_url( $pay_url, $order ) { |
|
1085 | + public function get_checkout_payment_url($pay_url, $order) { |
|
1086 | 1086 | global $wp; |
1087 | - if ( isset( $_GET['wc-stripe-confirmation'] ) && isset( $wp->query_vars['order-pay'] ) && $wp->query_vars['order-pay'] == $order->get_id() ) { |
|
1088 | - $pay_url = add_query_arg( 'wc-stripe-confirmation', 1, $pay_url ); |
|
1087 | + if (isset($_GET['wc-stripe-confirmation']) && isset($wp->query_vars['order-pay']) && $wp->query_vars['order-pay'] == $order->get_id()) { |
|
1088 | + $pay_url = add_query_arg('wc-stripe-confirmation', 1, $pay_url); |
|
1089 | 1089 | } |
1090 | 1090 | return $pay_url; |
1091 | 1091 | } |
@@ -1095,32 +1095,32 @@ discard block |
||
1095 | 1095 | */ |
1096 | 1096 | public function process_admin_options() { |
1097 | 1097 | // Load all old values before the new settings get saved. |
1098 | - $old_publishable_key = $this->get_option( 'publishable_key' ); |
|
1099 | - $old_secret_key = $this->get_option( 'secret_key' ); |
|
1100 | - $old_test_publishable_key = $this->get_option( 'test_publishable_key' ); |
|
1101 | - $old_test_secret_key = $this->get_option( 'test_secret_key' ); |
|
1098 | + $old_publishable_key = $this->get_option('publishable_key'); |
|
1099 | + $old_secret_key = $this->get_option('secret_key'); |
|
1100 | + $old_test_publishable_key = $this->get_option('test_publishable_key'); |
|
1101 | + $old_test_secret_key = $this->get_option('test_secret_key'); |
|
1102 | 1102 | |
1103 | 1103 | parent::process_admin_options(); |
1104 | 1104 | |
1105 | 1105 | // Load all old values after the new settings have been saved. |
1106 | - $new_publishable_key = $this->get_option( 'publishable_key' ); |
|
1107 | - $new_secret_key = $this->get_option( 'secret_key' ); |
|
1108 | - $new_test_publishable_key = $this->get_option( 'test_publishable_key' ); |
|
1109 | - $new_test_secret_key = $this->get_option( 'test_secret_key' ); |
|
1106 | + $new_publishable_key = $this->get_option('publishable_key'); |
|
1107 | + $new_secret_key = $this->get_option('secret_key'); |
|
1108 | + $new_test_publishable_key = $this->get_option('test_publishable_key'); |
|
1109 | + $new_test_secret_key = $this->get_option('test_secret_key'); |
|
1110 | 1110 | |
1111 | 1111 | // Checks whether a value has transitioned from a non-empty value to a new one. |
1112 | - $has_changed = function( $old_value, $new_value ) { |
|
1113 | - return ! empty( $old_value ) && ( $old_value !== $new_value ); |
|
1112 | + $has_changed = function($old_value, $new_value) { |
|
1113 | + return ! empty($old_value) && ($old_value !== $new_value); |
|
1114 | 1114 | }; |
1115 | 1115 | |
1116 | 1116 | // Look for updates. |
1117 | 1117 | if ( |
1118 | - $has_changed( $old_publishable_key, $new_publishable_key ) |
|
1119 | - || $has_changed( $old_secret_key, $new_secret_key ) |
|
1120 | - || $has_changed( $old_test_publishable_key, $new_test_publishable_key ) |
|
1121 | - || $has_changed( $old_test_secret_key, $new_test_secret_key ) |
|
1118 | + $has_changed($old_publishable_key, $new_publishable_key) |
|
1119 | + || $has_changed($old_secret_key, $new_secret_key) |
|
1120 | + || $has_changed($old_test_publishable_key, $new_test_publishable_key) |
|
1121 | + || $has_changed($old_test_secret_key, $new_test_secret_key) |
|
1122 | 1122 | ) { |
1123 | - update_option( 'wc_stripe_show_changed_keys_notice', 'yes' ); |
|
1123 | + update_option('wc_stripe_show_changed_keys_notice', 'yes'); |
|
1124 | 1124 | } |
1125 | 1125 | } |
1126 | 1126 | } |