@@ -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,8 +23,8 @@ 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' ) ); |
|
| 27 | - add_action( 'wc_ajax_wc_stripe_create_setup_intent', array( $this, 'create_setup_intent' ) ); |
|
| 26 | + add_action('wc_ajax_wc_stripe_verify_intent', array($this, 'verify_intent')); |
|
| 27 | + add_action('wc_ajax_wc_stripe_create_setup_intent', array($this, 'create_setup_intent')); |
|
| 28 | 28 | } |
| 29 | 29 | |
| 30 | 30 | /** |
@@ -34,8 +34,8 @@ discard block |
||
| 34 | 34 | * @return WC_Gateway_Stripe |
| 35 | 35 | */ |
| 36 | 36 | protected function get_gateway() { |
| 37 | - if ( ! isset( $this->gateway ) ) { |
|
| 38 | - if ( class_exists( 'WC_Subscriptions_Order' ) && function_exists( 'wcs_create_renewal_order' ) ) { |
|
| 37 | + if ( ! isset($this->gateway)) { |
|
| 38 | + if (class_exists('WC_Subscriptions_Order') && function_exists('wcs_create_renewal_order')) { |
|
| 39 | 39 | $class_name = 'WC_Stripe_Subs_Compat'; |
| 40 | 40 | } else { |
| 41 | 41 | $class_name = 'WC_Gateway_Stripe'; |
@@ -55,21 +55,21 @@ discard block |
||
| 55 | 55 | * @return WC_Order |
| 56 | 56 | */ |
| 57 | 57 | protected function get_order_from_request() { |
| 58 | - if ( ! isset( $_GET['nonce'] ) || ! wp_verify_nonce( sanitize_key( $_GET['nonce'] ), 'wc_stripe_confirm_pi' ) ) { |
|
| 59 | - throw new WC_Stripe_Exception( 'missing-nonce', __( 'CSRF verification failed.', 'woocommerce-gateway-stripe' ) ); |
|
| 58 | + if ( ! isset($_GET['nonce']) || ! wp_verify_nonce(sanitize_key($_GET['nonce']), 'wc_stripe_confirm_pi')) { |
|
| 59 | + throw new WC_Stripe_Exception('missing-nonce', __('CSRF verification failed.', 'woocommerce-gateway-stripe')); |
|
| 60 | 60 | } |
| 61 | 61 | |
| 62 | 62 | // Load the order ID. |
| 63 | 63 | $order_id = null; |
| 64 | - if ( isset( $_GET['order'] ) && absint( $_GET['order'] ) ) { |
|
| 65 | - $order_id = absint( $_GET['order'] ); |
|
| 64 | + if (isset($_GET['order']) && absint($_GET['order'])) { |
|
| 65 | + $order_id = absint($_GET['order']); |
|
| 66 | 66 | } |
| 67 | 67 | |
| 68 | 68 | // Retrieve the order. |
| 69 | - $order = wc_get_order( $order_id ); |
|
| 69 | + $order = wc_get_order($order_id); |
|
| 70 | 70 | |
| 71 | - if ( ! $order ) { |
|
| 72 | - throw new WC_Stripe_Exception( 'missing-order', __( 'Missing order ID for payment confirmation', 'woocommerce-gateway-stripe' ) ); |
|
| 71 | + if ( ! $order) { |
|
| 72 | + throw new WC_Stripe_Exception('missing-order', __('Missing order ID for payment confirmation', 'woocommerce-gateway-stripe')); |
|
| 73 | 73 | } |
| 74 | 74 | |
| 75 | 75 | return $order; |
@@ -87,32 +87,32 @@ discard block |
||
| 87 | 87 | |
| 88 | 88 | try { |
| 89 | 89 | $order = $this->get_order_from_request(); |
| 90 | - } catch ( WC_Stripe_Exception $e ) { |
|
| 90 | + } catch (WC_Stripe_Exception $e) { |
|
| 91 | 91 | /* translators: Error message text */ |
| 92 | - $message = sprintf( __( 'Payment verification error: %s', 'woocommerce-gateway-stripe' ), $e->getLocalizedMessage() ); |
|
| 93 | - wc_add_notice( esc_html( $message ), 'error' ); |
|
| 92 | + $message = sprintf(__('Payment verification error: %s', 'woocommerce-gateway-stripe'), $e->getLocalizedMessage()); |
|
| 93 | + wc_add_notice(esc_html($message), 'error'); |
|
| 94 | 94 | |
| 95 | 95 | $redirect_url = $woocommerce->cart->is_empty() |
| 96 | - ? get_permalink( wc_get_page_id( 'shop' ) ) |
|
| 96 | + ? get_permalink(wc_get_page_id('shop')) |
|
| 97 | 97 | : wc_get_checkout_url(); |
| 98 | 98 | |
| 99 | - $this->handle_error( $e, $redirect_url ); |
|
| 99 | + $this->handle_error($e, $redirect_url); |
|
| 100 | 100 | } |
| 101 | 101 | |
| 102 | 102 | try { |
| 103 | - $gateway->verify_intent_after_checkout( $order ); |
|
| 103 | + $gateway->verify_intent_after_checkout($order); |
|
| 104 | 104 | |
| 105 | - if ( ! isset( $_GET['is_ajax'] ) ) { |
|
| 106 | - $redirect_url = isset( $_GET['redirect_to'] ) // wpcs: csrf ok. |
|
| 107 | - ? esc_url_raw( wp_unslash( $_GET['redirect_to'] ) ) // wpcs: csrf ok. |
|
| 108 | - : $gateway->get_return_url( $order ); |
|
| 105 | + if ( ! isset($_GET['is_ajax'])) { |
|
| 106 | + $redirect_url = isset($_GET['redirect_to']) // wpcs: csrf ok. |
|
| 107 | + ? esc_url_raw(wp_unslash($_GET['redirect_to'])) // wpcs: csrf ok. |
|
| 108 | + : $gateway->get_return_url($order); |
|
| 109 | 109 | |
| 110 | - wp_safe_redirect( $redirect_url ); |
|
| 110 | + wp_safe_redirect($redirect_url); |
|
| 111 | 111 | } |
| 112 | 112 | |
| 113 | 113 | exit; |
| 114 | - } catch ( WC_Stripe_Exception $e ) { |
|
| 115 | - $this->handle_error( $e, $gateway->get_return_url( $order ) ); |
|
| 114 | + } catch (WC_Stripe_Exception $e) { |
|
| 115 | + $this->handle_error($e, $gateway->get_return_url($order)); |
|
| 116 | 116 | } |
| 117 | 117 | } |
| 118 | 118 | |
@@ -123,17 +123,17 @@ discard block |
||
| 123 | 123 | * @param WC_Stripe_Exception $e The exception that was thrown. |
| 124 | 124 | * @param string $redirect_url An URL to use if a redirect is needed. |
| 125 | 125 | */ |
| 126 | - protected function handle_error( $e, $redirect_url ) { |
|
| 126 | + protected function handle_error($e, $redirect_url) { |
|
| 127 | 127 | // Log the exception before redirecting. |
| 128 | - $message = sprintf( 'PaymentIntent verification exception: %s', $e->getLocalizedMessage() ); |
|
| 129 | - WC_Stripe_Logger::log( $message ); |
|
| 128 | + $message = sprintf('PaymentIntent verification exception: %s', $e->getLocalizedMessage()); |
|
| 129 | + WC_Stripe_Logger::log($message); |
|
| 130 | 130 | |
| 131 | 131 | // `is_ajax` is only used for PI error reporting, a response is not expected. |
| 132 | - if ( isset( $_GET['is_ajax'] ) ) { |
|
| 132 | + if (isset($_GET['is_ajax'])) { |
|
| 133 | 133 | exit; |
| 134 | 134 | } |
| 135 | 135 | |
| 136 | - wp_safe_redirect( $redirect_url ); |
|
| 136 | + wp_safe_redirect($redirect_url); |
|
| 137 | 137 | exit; |
| 138 | 138 | } |
| 139 | 139 | |
@@ -143,31 +143,31 @@ discard block |
||
| 143 | 143 | public function create_setup_intent() { |
| 144 | 144 | if ( |
| 145 | 145 | ! is_user_logged_in() |
| 146 | - || ! isset( $_POST['stripe_source_id'] ) |
|
| 147 | - || ! isset( $_POST['nonce'] ) |
|
| 146 | + || ! isset($_POST['stripe_source_id']) |
|
| 147 | + || ! isset($_POST['nonce']) |
|
| 148 | 148 | ) { |
| 149 | 149 | return; |
| 150 | 150 | } |
| 151 | 151 | |
| 152 | 152 | try { |
| 153 | - $source_id = wc_clean( $_POST['stripe_source_id'] ); |
|
| 153 | + $source_id = wc_clean($_POST['stripe_source_id']); |
|
| 154 | 154 | |
| 155 | 155 | // 1. Verify. |
| 156 | 156 | if ( |
| 157 | - ! wp_verify_nonce( sanitize_key( $_POST['nonce'] ), 'wc_stripe_create_si' ) |
|
| 158 | - || ! preg_match( '/^src_.*$/', $source_id ) |
|
| 157 | + ! wp_verify_nonce(sanitize_key($_POST['nonce']), 'wc_stripe_create_si') |
|
| 158 | + || ! preg_match('/^src_.*$/', $source_id) |
|
| 159 | 159 | ) { |
| 160 | - throw new Exception( __( 'Unable to verify your request. Please reload the page and try again.', 'woocommerce-gateway-stripe' ) ); |
|
| 160 | + throw new Exception(__('Unable to verify your request. Please reload the page and try again.', 'woocommerce-gateway-stripe')); |
|
| 161 | 161 | } |
| 162 | 162 | |
| 163 | 163 | |
| 164 | 164 | // 2. Load the customer ID (and create a customer eventually). |
| 165 | - $customer = new WC_Stripe_Customer( wp_get_current_user()->ID ); |
|
| 165 | + $customer = new WC_Stripe_Customer(wp_get_current_user()->ID); |
|
| 166 | 166 | |
| 167 | 167 | // 3. Attach the source to the customer (Setup Intents require that). |
| 168 | - $source_object = $customer->attach_source( $source_id ); |
|
| 169 | - if ( is_wp_error( $source_object ) ) { |
|
| 170 | - throw new Exception( $source_object->get_error_message() ); |
|
| 168 | + $source_object = $customer->attach_source($source_id); |
|
| 169 | + if (is_wp_error($source_object)) { |
|
| 170 | + throw new Exception($source_object->get_error_message()); |
|
| 171 | 171 | } |
| 172 | 172 | |
| 173 | 173 | // 4. Generate the setup intent |
@@ -180,28 +180,28 @@ discard block |
||
| 180 | 180 | 'setup_intents' |
| 181 | 181 | ); |
| 182 | 182 | |
| 183 | - if ( ! empty( $setup_intent->error ) ) { |
|
| 184 | - $error_response_message = print_r( $setup_intent, true ); |
|
| 183 | + if ( ! empty($setup_intent->error)) { |
|
| 184 | + $error_response_message = print_r($setup_intent, true); |
|
| 185 | 185 | WC_Stripe_Logger::log("Failed create Setup Intent while saving a card."); |
| 186 | 186 | WC_Stripe_Logger::log("Response: $error_response_message"); |
| 187 | - throw new Exception( __( 'Your card could not be set up for future usage.', 'woocommerce-gateway-stripe' ) ); |
|
| 187 | + throw new Exception(__('Your card could not be set up for future usage.', 'woocommerce-gateway-stripe')); |
|
| 188 | 188 | } |
| 189 | 189 | |
| 190 | 190 | // 5. Respond. |
| 191 | - if ( 'requires_action' === $setup_intent->status ) { |
|
| 191 | + if ('requires_action' === $setup_intent->status) { |
|
| 192 | 192 | $response = [ |
| 193 | 193 | 'status' => 'requires_action', |
| 194 | 194 | 'client_secret' => $setup_intent->client_secret, |
| 195 | 195 | ]; |
| 196 | - } elseif ( 'requires_payment_method' === $setup_intent->status |
|
| 196 | + } elseif ('requires_payment_method' === $setup_intent->status |
|
| 197 | 197 | || 'requires_confirmation' === $setup_intent->status |
| 198 | - || 'canceled' === $setup_intent->status ) { |
|
| 198 | + || 'canceled' === $setup_intent->status) { |
|
| 199 | 199 | // These statuses should not be possible, as such we return an error. |
| 200 | 200 | $response = [ |
| 201 | 201 | 'status' => 'error', |
| 202 | 202 | 'error' => [ |
| 203 | 203 | 'type' => 'setup_intent_error', |
| 204 | - 'message' => __( 'Failed to save payment method.', 'woocommerce-gateway-stripe' ), |
|
| 204 | + 'message' => __('Failed to save payment method.', 'woocommerce-gateway-stripe'), |
|
| 205 | 205 | ], |
| 206 | 206 | ]; |
| 207 | 207 | } else { |
@@ -211,7 +211,7 @@ discard block |
||
| 211 | 211 | 'status' => 'success', |
| 212 | 212 | ]; |
| 213 | 213 | } |
| 214 | - } catch ( Exception $e ) { |
|
| 214 | + } catch (Exception $e) { |
|
| 215 | 215 | $response = [ |
| 216 | 216 | 'status' => 'error', |
| 217 | 217 | 'error' => array( |
@@ -221,7 +221,7 @@ discard block |
||
| 221 | 221 | ]; |
| 222 | 222 | } |
| 223 | 223 | |
| 224 | - echo wp_json_encode( $response ); |
|
| 224 | + echo wp_json_encode($response); |
|
| 225 | 225 | exit; |
| 226 | 226 | } |
| 227 | 227 | } |