@@ -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); ?> |
@@ -1,5 +1,5 @@ discard block |
||
1 | 1 | <?php |
2 | -if ( ! defined( 'ABSPATH' ) ) { |
|
2 | +if ( ! defined('ABSPATH')) { |
|
3 | 3 | exit; // Exit if accessed directly. |
4 | 4 | } |
5 | 5 | |
@@ -30,7 +30,7 @@ discard block |
||
30 | 30 | 'email_heading' => $this->get_heading(), |
31 | 31 | 'sent_to_admin' => false, |
32 | 32 | 'plain_text' => false, |
33 | - 'authorization_url' => $this->get_authorization_url( $this->object ), |
|
33 | + 'authorization_url' => $this->get_authorization_url($this->object), |
|
34 | 34 | 'email' => $this, |
35 | 35 | ), |
36 | 36 | '', |
@@ -53,7 +53,7 @@ discard block |
||
53 | 53 | 'email_heading' => $this->get_heading(), |
54 | 54 | 'sent_to_admin' => false, |
55 | 55 | 'plain_text' => true, |
56 | - 'authorization_url' => $this->get_authorization_url( $this->object ), |
|
56 | + 'authorization_url' => $this->get_authorization_url($this->object), |
|
57 | 57 | 'email' => $this, |
58 | 58 | ), |
59 | 59 | '', |
@@ -68,8 +68,8 @@ discard block |
||
68 | 68 | * @param WC_Order $order The order whose payment needs authentication. |
69 | 69 | * @return string |
70 | 70 | */ |
71 | - public function get_authorization_url( $order ) { |
|
72 | - return add_query_arg( 'wc-stripe-confirmation', 1, $order->get_checkout_payment_url( false ) ); |
|
71 | + public function get_authorization_url($order) { |
|
72 | + return add_query_arg('wc-stripe-confirmation', 1, $order->get_checkout_payment_url(false)); |
|
73 | 73 | } |
74 | 74 | |
75 | 75 | /** |
@@ -81,9 +81,9 @@ discard block |
||
81 | 81 | |
82 | 82 | $this->form_fields = array( |
83 | 83 | 'enabled' => array( |
84 | - 'title' => _x( 'Enable/Disable', 'an email notification', 'woocommerce-gateway-stripe' ), |
|
84 | + 'title' => _x('Enable/Disable', 'an email notification', 'woocommerce-gateway-stripe'), |
|
85 | 85 | 'type' => 'checkbox', |
86 | - 'label' => __( 'Enable this email notification', 'woocommerce-gateway-stripe' ), |
|
86 | + 'label' => __('Enable this email notification', 'woocommerce-gateway-stripe'), |
|
87 | 87 | 'default' => 'yes', |
88 | 88 | ), |
89 | 89 | |
@@ -98,29 +98,29 @@ discard block |
||
98 | 98 | * |
99 | 99 | * @param WC_Order $order The renewal order whose payment failed. |
100 | 100 | */ |
101 | - public function trigger( $order ) { |
|
102 | - if ( ! $this->is_enabled() ) { |
|
101 | + public function trigger($order) { |
|
102 | + if ( ! $this->is_enabled()) { |
|
103 | 103 | return; |
104 | 104 | } |
105 | 105 | |
106 | 106 | $this->object = $order; |
107 | 107 | |
108 | - if ( method_exists( $order, 'get_billing_email' ) ) { |
|
108 | + if (method_exists($order, 'get_billing_email')) { |
|
109 | 109 | $this->recipient = $order->get_billing_email(); |
110 | 110 | } else { |
111 | 111 | $this->recipient = $order->billing_email; |
112 | 112 | } |
113 | 113 | |
114 | 114 | $this->find['order_date'] = '{order_date}'; |
115 | - if ( function_exists( 'wc_format_datetime' ) ) { // WC 3.0+ |
|
116 | - $this->replace['order_date'] = wc_format_datetime( $order->get_date_created() ); |
|
115 | + if (function_exists('wc_format_datetime')) { // WC 3.0+ |
|
116 | + $this->replace['order_date'] = wc_format_datetime($order->get_date_created()); |
|
117 | 117 | } else { // WC < 3.0 |
118 | - $this->replace['order_date'] = $order->date_created->date_i18n( wc_date_format() ); |
|
118 | + $this->replace['order_date'] = $order->date_created->date_i18n(wc_date_format()); |
|
119 | 119 | } |
120 | 120 | |
121 | 121 | $this->find['order_number'] = '{order_number}'; |
122 | 122 | $this->replace['order_number'] = $order->get_order_number(); |
123 | 123 | |
124 | - $this->send( $this->get_recipient(), $this->get_subject(), $this->get_content(), $this->get_headers(), $this->get_attachments() ); |
|
124 | + $this->send($this->get_recipient(), $this->get_subject(), $this->get_content(), $this->get_headers(), $this->get_attachments()); |
|
125 | 125 | } |
126 | 126 | } |
@@ -1,5 +1,5 @@ discard block |
||
1 | 1 | <?php |
2 | -if ( ! defined( 'ABSPATH' ) ) { |
|
2 | +if ( ! defined('ABSPATH')) { |
|
3 | 3 | exit; // Exit if accessed directly. |
4 | 4 | } |
5 | 5 | |
@@ -21,20 +21,20 @@ discard block |
||
21 | 21 | * |
22 | 22 | * @param WC_Email[] $email_classes All existing instances of WooCommerce emails. |
23 | 23 | */ |
24 | - public function __construct( $email_classes = array() ) { |
|
24 | + public function __construct($email_classes = array()) { |
|
25 | 25 | $this->id = 'failed_preorder_sca_authentication'; |
26 | - $this->title = __( 'Pre-order Payment Action Needed', 'woocommerce-gateway-stripe' ); |
|
27 | - $this->description = __( 'This is an order notification sent to the customer once a pre-order is complete, but additional payment steps are required.', 'woocommerce-gateway-stripe' ); |
|
26 | + $this->title = __('Pre-order Payment Action Needed', 'woocommerce-gateway-stripe'); |
|
27 | + $this->description = __('This is an order notification sent to the customer once a pre-order is complete, but additional payment steps are required.', 'woocommerce-gateway-stripe'); |
|
28 | 28 | $this->customer_email = true; |
29 | 29 | |
30 | 30 | $this->template_html = 'emails/failed-preorder-authentication.php'; |
31 | 31 | $this->template_plain = 'emails/plain/failed-preorder-authentication.php'; |
32 | - $this->template_base = plugin_dir_path( WC_STRIPE_MAIN_FILE ) . 'templates/'; |
|
32 | + $this->template_base = plugin_dir_path(WC_STRIPE_MAIN_FILE) . 'templates/'; |
|
33 | 33 | |
34 | 34 | // Use the "authentication required" hook to add the correct, later hook. |
35 | - add_action( 'wc_gateway_stripe_process_payment_authentication_required', array( $this, 'trigger' ) ); |
|
35 | + add_action('wc_gateway_stripe_process_payment_authentication_required', array($this, 'trigger')); |
|
36 | 36 | |
37 | - if ( isset( $email_classes['WC_Pre_Orders_Email_Pre_Order_Available'] ) ) { |
|
37 | + if (isset($email_classes['WC_Pre_Orders_Email_Pre_Order_Available'])) { |
|
38 | 38 | $this->original_email = $email_classes['WC_Pre_Orders_Email_Pre_Order_Available']; |
39 | 39 | } |
40 | 40 | |
@@ -48,13 +48,13 @@ discard block |
||
48 | 48 | * |
49 | 49 | * @param WC_Order $order The order whose payment is failing. |
50 | 50 | */ |
51 | - public function trigger( $order ) { |
|
52 | - if ( class_exists( 'WC_Pre_Orders_Order' ) && WC_Pre_Orders_Order::order_contains_pre_order( $order->get_id() ) ) { |
|
53 | - if ( isset( $this->original_email ) ) { |
|
54 | - remove_action( 'wc_pre_order_status_completed_notification', array( $this->original_email, 'trigger' ), 10, 2 ); |
|
51 | + public function trigger($order) { |
|
52 | + if (class_exists('WC_Pre_Orders_Order') && WC_Pre_Orders_Order::order_contains_pre_order($order->get_id())) { |
|
53 | + if (isset($this->original_email)) { |
|
54 | + remove_action('wc_pre_order_status_completed_notification', array($this->original_email, 'trigger'), 10, 2); |
|
55 | 55 | } |
56 | 56 | |
57 | - add_action( 'wc_pre_orders_pre_order_completed', array( $this, 'send_email' ), 10, 2 ); |
|
57 | + add_action('wc_pre_orders_pre_order_completed', array($this, 'send_email'), 10, 2); |
|
58 | 58 | } |
59 | 59 | } |
60 | 60 | |
@@ -64,14 +64,14 @@ discard block |
||
64 | 64 | * @param WC_Order $order The order that is being paid. |
65 | 65 | * @param string $message The message, which should be added to the email. |
66 | 66 | */ |
67 | - public function send_email( $order, $message ) { |
|
67 | + public function send_email($order, $message) { |
|
68 | 68 | $this->custom_message = $message; |
69 | 69 | |
70 | - parent::trigger( $order ); |
|
70 | + parent::trigger($order); |
|
71 | 71 | |
72 | 72 | // Restore the action of the original email for other bulk actions. |
73 | - if ( isset( $this->original_email ) ) { |
|
74 | - add_action( 'wc_pre_order_status_completed_notification', array( $this->original_email, 'trigger' ), 10, 2 ); |
|
73 | + if (isset($this->original_email)) { |
|
74 | + add_action('wc_pre_order_status_completed_notification', array($this->original_email, 'trigger'), 10, 2); |
|
75 | 75 | } |
76 | 76 | } |
77 | 77 | |
@@ -81,7 +81,7 @@ discard block |
||
81 | 81 | * @return string |
82 | 82 | */ |
83 | 83 | public function get_default_subject() { |
84 | - return __( 'Payment authorization needed for pre-order {order_number}', 'woocommerce-gateway-stripe' ); |
|
84 | + return __('Payment authorization needed for pre-order {order_number}', 'woocommerce-gateway-stripe'); |
|
85 | 85 | } |
86 | 86 | |
87 | 87 | /** |
@@ -90,7 +90,7 @@ discard block |
||
90 | 90 | * @return string |
91 | 91 | */ |
92 | 92 | public function get_default_heading() { |
93 | - return __( 'Payment authorization needed for pre-order {order_number}', 'woocommerce-gateway-stripe' ); |
|
93 | + return __('Payment authorization needed for pre-order {order_number}', 'woocommerce-gateway-stripe'); |
|
94 | 94 | } |
95 | 95 | |
96 | 96 | /** |