@@ 115-179 (lines=65) @@ | ||
112 | // Make the request. |
|
113 | $response = WC_Stripe_API::request( $this->generate_payment_request( $order, $source_object ) ); |
|
114 | ||
115 | if ( ! empty( $response->error ) ) { |
|
116 | // If it is an API error such connection or server, let's retry. |
|
117 | if ( 'api_connection_error' === $response->error->type || 'api_error' === $response->error->type ) { |
|
118 | if ( $retry ) { |
|
119 | sleep( 5 ); |
|
120 | return $this->process_redirect_payment( $order_id, false ); |
|
121 | } else { |
|
122 | $localized_message = __( 'API connection error and retries exhausted.', 'woocommerce-gateway-stripe' ); |
|
123 | $order->add_order_note( $localized_message ); |
|
124 | throw new WC_Stripe_Exception( print_r( $response, true ), $localized_message ); |
|
125 | } |
|
126 | } |
|
127 | ||
128 | // We want to retry. |
|
129 | if ( $this->is_retryable_error( $response->error ) ) { |
|
130 | if ( $retry ) { |
|
131 | // Don't do anymore retries after this. |
|
132 | if ( 5 <= $this->retry_interval ) { |
|
133 | return $this->process_redirect_payment( $order_id, false ); |
|
134 | } |
|
135 | ||
136 | sleep( $this->retry_interval ); |
|
137 | ||
138 | $this->retry_interval++; |
|
139 | return $this->process_redirect_payment( $order_id, true ); |
|
140 | } else { |
|
141 | $localized_message = __( 'On going requests error and retries exhausted.', 'woocommerce-gateway-stripe' ); |
|
142 | $order->add_order_note( $localized_message ); |
|
143 | throw new WC_Stripe_Exception( print_r( $response, true ), $localized_message ); |
|
144 | } |
|
145 | } |
|
146 | ||
147 | // Customer param wrong? The user may have been deleted on stripe's end. Remove customer_id. Can be retried without. |
|
148 | if ( preg_match( '/No such customer/i', $response->error->message ) && $retry ) { |
|
149 | if ( WC_Stripe_Helper::is_pre_30() ) { |
|
150 | delete_user_meta( $order->customer_user, '_stripe_customer_id' ); |
|
151 | delete_post_meta( $order_id, '_stripe_customer_id' ); |
|
152 | } else { |
|
153 | delete_user_meta( $order->get_customer_id(), '_stripe_customer_id' ); |
|
154 | $order->delete_meta_data( '_stripe_customer_id' ); |
|
155 | $order->save(); |
|
156 | } |
|
157 | ||
158 | return $this->process_redirect_payment( $order_id, false ); |
|
159 | ||
160 | } elseif ( preg_match( '/No such token/i', $response->error->message ) && $source_object->token_id ) { |
|
161 | // Source param wrong? The CARD may have been deleted on stripe's end. Remove token and show message. |
|
162 | ||
163 | $wc_token = WC_Payment_Tokens::get( $source_object->token_id ); |
|
164 | $wc_token->delete(); |
|
165 | $message = __( 'This card is no longer available and has been removed.', 'woocommerce-gateway-stripe' ); |
|
166 | $order->add_order_note( $message ); |
|
167 | throw new WC_Stripe_Exception( print_r( $response, true ), $message ); |
|
168 | } |
|
169 | ||
170 | $localized_messages = WC_Stripe_Helper::get_localized_messages(); |
|
171 | ||
172 | if ( 'card_error' === $response->error->type ) { |
|
173 | $message = isset( $localized_messages[ $response->error->code ] ) ? $localized_messages[ $response->error->code ] : $response->error->message; |
|
174 | } else { |
|
175 | $message = isset( $localized_messages[ $response->error->type ] ) ? $localized_messages[ $response->error->type ] : $response->error->message; |
|
176 | } |
|
177 | ||
178 | throw new WC_Stripe_Exception( print_r( $response, true ), $message ); |
|
179 | } |
|
180 | ||
181 | do_action( 'wc_gateway_stripe_process_redirect_payment', $response, $order ); |
|
182 |
@@ 167-233 (lines=67) @@ | ||
164 | // Make the request. |
|
165 | $response = WC_Stripe_API::request( $this->generate_payment_request( $order, $source_object ) ); |
|
166 | ||
167 | if ( ! empty( $response->error ) ) { |
|
168 | // If it is an API error such connection or server, let's retry. |
|
169 | if ( 'api_connection_error' === $response->error->type || 'api_error' === $response->error->type ) { |
|
170 | if ( $retry ) { |
|
171 | sleep( 5 ); |
|
172 | return $this->process_webhook_payment( $notification, false ); |
|
173 | } else { |
|
174 | $localized_message = 'API connection error and retries exhausted.'; |
|
175 | $order->add_order_note( $localized_message ); |
|
176 | throw new WC_Stripe_Exception( print_r( $response, true ), $localized_message ); |
|
177 | } |
|
178 | } |
|
179 | ||
180 | // We want to retry. |
|
181 | if ( $this->is_retryable_error( $response->error ) ) { |
|
182 | if ( $retry ) { |
|
183 | // Don't do anymore retries after this. |
|
184 | if ( 5 <= $this->retry_interval ) { |
|
185 | ||
186 | return $this->process_webhook_payment( $notification, false ); |
|
187 | } |
|
188 | ||
189 | sleep( $this->retry_interval ); |
|
190 | ||
191 | $this->retry_interval++; |
|
192 | return $this->process_webhook_payment( $notification, true ); |
|
193 | } else { |
|
194 | $localized_message = __( 'On going requests error and retries exhausted.', 'woocommerce-gateway-stripe' ); |
|
195 | $order->add_order_note( $localized_message ); |
|
196 | throw new WC_Stripe_Exception( print_r( $response, true ), $localized_message ); |
|
197 | } |
|
198 | } |
|
199 | ||
200 | // Customer param wrong? The user may have been deleted on stripe's end. Remove customer_id. Can be retried without. |
|
201 | if ( preg_match( '/No such customer/i', $response->error->message ) && $retry ) { |
|
202 | if ( WC_Stripe_Helper::is_pre_30() ) { |
|
203 | delete_user_meta( $order->customer_user, '_stripe_customer_id' ); |
|
204 | delete_post_meta( $order_id, '_stripe_customer_id' ); |
|
205 | } else { |
|
206 | delete_user_meta( $order->get_customer_id(), '_stripe_customer_id' ); |
|
207 | $order->delete_meta_data( '_stripe_customer_id' ); |
|
208 | $order->save(); |
|
209 | } |
|
210 | ||
211 | return $this->process_webhook_payment( $notification, false ); |
|
212 | ||
213 | } elseif ( preg_match( '/No such token/i', $response->error->message ) && $source_object->token_id ) { |
|
214 | // Source param wrong? The CARD may have been deleted on stripe's end. Remove token and show message. |
|
215 | $wc_token = WC_Payment_Tokens::get( $source_object->token_id ); |
|
216 | $wc_token->delete(); |
|
217 | $message = __( 'This card is no longer available and has been removed.', 'woocommerce-gateway-stripe' ); |
|
218 | $order->add_order_note( $message ); |
|
219 | throw new WC_Stripe_Exception( print_r( $response, true ), $message ); |
|
220 | } |
|
221 | ||
222 | $localized_messages = WC_Stripe_Helper::get_localized_messages(); |
|
223 | ||
224 | if ( 'card_error' === $response->error->type ) { |
|
225 | $localized_message = isset( $localized_messages[ $response->error->code ] ) ? $localized_messages[ $response->error->code ] : $response->error->message; |
|
226 | } else { |
|
227 | $localized_message = isset( $localized_messages[ $response->error->type ] ) ? $localized_messages[ $response->error->type ] : $response->error->message; |
|
228 | } |
|
229 | ||
230 | $order->add_order_note( $localized_message ); |
|
231 | ||
232 | throw new WC_Stripe_Exception( print_r( $response, true ), $localized_message ); |
|
233 | } |
|
234 | ||
235 | do_action( 'wc_gateway_stripe_process_webhook_payment', $response, $order ); |
|
236 |