mirror of
https://github.com/woocommerce/woocommerce-paypal-payments.git
synced 2025-08-30 05:00:51 +08:00
Streamline the call off confirm_payment_source() and reference implementation for future investigating
This commit is contained in:
parent
cb8c3f8726
commit
e63bb5bcc6
6 changed files with 61 additions and 30 deletions
|
@ -601,30 +601,23 @@ class OrderEndpoint {
|
||||||
*
|
*
|
||||||
* @param string $id The PayPal order ID.
|
* @param string $id The PayPal order ID.
|
||||||
* @param array $payment_source The payment source.
|
* @param array $payment_source The payment source.
|
||||||
* @return stdClass
|
* @return \stdClass
|
||||||
* @throws PayPalApiException If the request fails.
|
* @throws PayPalApiException If the request fails.
|
||||||
* @throws RuntimeException If something unexpected happens.
|
* @throws RuntimeException If something unexpected happens.
|
||||||
*/
|
*/
|
||||||
public function confirm_payment_source( string $id, array $payment_source ): stdClass {
|
public function confirm_payment_source( string $id, array $request_body ): stdClass {
|
||||||
$bearer = $this->bearer->bearer();
|
$bearer = $this->bearer->bearer();
|
||||||
$url = trailingslashit( $this->host ) . 'v2/checkout/orders/' . $id . '/confirm-payment-source';
|
$url = trailingslashit( $this->host ) . 'v2/checkout/orders/' . $id . '/confirm-payment-source';
|
||||||
|
|
||||||
$data = array(
|
|
||||||
'payment_source' => $payment_source,
|
|
||||||
'processing_instruction' => 'ORDER_COMPLETE_ON_PAYMENT_APPROVAL',
|
|
||||||
'application_context' => array(
|
|
||||||
'locale' => 'es-MX',
|
|
||||||
),
|
|
||||||
);
|
|
||||||
|
|
||||||
$args = array(
|
$args = array(
|
||||||
'method' => 'POST',
|
'method' => 'POST',
|
||||||
'headers' => array(
|
'headers' => array(
|
||||||
'Authorization' => 'Bearer ' . $bearer->token(),
|
'Authorization' => 'Bearer ' . $bearer->token(),
|
||||||
'Content-Type' => 'application/json',
|
'Content-Type' => 'application/json',
|
||||||
'Prefer' => 'return=representation',
|
'Prefer' => 'return=representation',
|
||||||
|
'PayPal-Request-Id' => uniqid( 'ppcp-', true ),
|
||||||
),
|
),
|
||||||
'body' => wp_json_encode( $data ),
|
'body' => wp_json_encode( $request_body ),
|
||||||
);
|
);
|
||||||
|
|
||||||
$response = $this->request( $url, $args );
|
$response = $this->request( $url, $args );
|
||||||
|
@ -634,8 +627,16 @@ class OrderEndpoint {
|
||||||
|
|
||||||
$json = json_decode( $response['body'] );
|
$json = json_decode( $response['body'] );
|
||||||
$status_code = (int) wp_remote_retrieve_response_code( $response );
|
$status_code = (int) wp_remote_retrieve_response_code( $response );
|
||||||
if ( 200 !== $status_code ) {
|
if ( $status_code !== 200 ) {
|
||||||
throw new PayPalApiException( $json, $status_code );
|
$message = $json->details[0]->description ?? '';
|
||||||
|
if ( $message ) {
|
||||||
|
throw new RuntimeException( $message );
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new PayPalApiException(
|
||||||
|
$json,
|
||||||
|
$status_code
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $json;
|
return $json;
|
||||||
|
|
|
@ -118,13 +118,13 @@ class Orders {
|
||||||
*
|
*
|
||||||
* @link https://developer.paypal.com/docs/api/orders/v2/#orders_confirm
|
* @link https://developer.paypal.com/docs/api/orders/v2/#orders_confirm
|
||||||
*
|
*
|
||||||
* @param array $request_body The request body.
|
|
||||||
* @param string $id PayPal order ID.
|
* @param string $id PayPal order ID.
|
||||||
* @return array
|
* @param array $request_body The request body.
|
||||||
|
* @return \stdClass
|
||||||
* @throws RuntimeException If something went wrong with the request.
|
* @throws RuntimeException If something went wrong with the request.
|
||||||
* @throws PayPalApiException If something went wrong with the PayPal API request.
|
* @throws PayPalApiException If something went wrong with the PayPal API request.
|
||||||
*/
|
*/
|
||||||
public function confirm_payment_source( array $request_body, string $id ): array {
|
public function confirm_payment_source( string $id, array $request_body ): \stdClass {
|
||||||
$bearer = $this->bearer->bearer();
|
$bearer = $this->bearer->bearer();
|
||||||
$url = trailingslashit( $this->host ) . 'v2/checkout/orders/' . $id . '/confirm-payment-source';
|
$url = trailingslashit( $this->host ) . 'v2/checkout/orders/' . $id . '/confirm-payment-source';
|
||||||
|
|
||||||
|
@ -133,6 +133,7 @@ class Orders {
|
||||||
'headers' => array(
|
'headers' => array(
|
||||||
'Authorization' => 'Bearer ' . $bearer->token(),
|
'Authorization' => 'Bearer ' . $bearer->token(),
|
||||||
'Content-Type' => 'application/json',
|
'Content-Type' => 'application/json',
|
||||||
|
'Prefer' => 'return=representation',
|
||||||
'PayPal-Request-Id' => uniqid( 'ppcp-', true ),
|
'PayPal-Request-Id' => uniqid( 'ppcp-', true ),
|
||||||
),
|
),
|
||||||
'body' => wp_json_encode( $request_body ),
|
'body' => wp_json_encode( $request_body ),
|
||||||
|
@ -143,22 +144,21 @@ class Orders {
|
||||||
throw new RuntimeException( $response->get_error_message() );
|
throw new RuntimeException( $response->get_error_message() );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$json = json_decode( $response['body'] );
|
||||||
$status_code = (int) wp_remote_retrieve_response_code( $response );
|
$status_code = (int) wp_remote_retrieve_response_code( $response );
|
||||||
if ( $status_code !== 200 ) {
|
if ( $status_code !== 200 ) {
|
||||||
$body = json_decode( $response['body'] );
|
$message = $json->details[0]->description ?? '';
|
||||||
|
|
||||||
$message = $body->details[0]->description ?? '';
|
|
||||||
if ( $message ) {
|
if ( $message ) {
|
||||||
throw new RuntimeException( $message );
|
throw new RuntimeException( $message );
|
||||||
}
|
}
|
||||||
|
|
||||||
throw new PayPalApiException(
|
throw new PayPalApiException(
|
||||||
$body,
|
$json,
|
||||||
$status_code
|
$status_code
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $response;
|
return $json;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -58,4 +58,10 @@ class PaymentSource {
|
||||||
public function properties(): object {
|
public function properties(): object {
|
||||||
return $this->properties;
|
return $this->properties;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function to_array(): array {
|
||||||
|
return array(
|
||||||
|
$this->name => (array) $this->properties
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -169,11 +169,10 @@ class MultibancoGateway extends WC_Payment_Gateway {
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
$response = $this->orders_endpoint->confirm_payment_source( $request_body, $body->id );
|
$response = $this->orders_endpoint->confirm_payment_source( $body->id, $request_body );
|
||||||
$body = json_decode( $response['body'] );
|
|
||||||
|
|
||||||
$payer_action = '';
|
$payer_action = '';
|
||||||
foreach ( $body->links as $link ) {
|
foreach ( $response->links as $link ) {
|
||||||
if ( $link->rel === 'payer-action' ) {
|
if ( $link->rel === 'payer-action' ) {
|
||||||
$payer_action = $link->href;
|
$payer_action = $link->href;
|
||||||
}
|
}
|
||||||
|
|
|
@ -186,7 +186,15 @@ class OXXOGateway extends WC_Payment_Gateway {
|
||||||
'country_code' => $wc_order->get_billing_country(),
|
'country_code' => $wc_order->get_billing_country(),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
$payment_method = $this->order_endpoint->confirm_payment_source( $order->id(), $payment_source );
|
$request_body = array(
|
||||||
|
'payment_source' => $payment_source,
|
||||||
|
'processing_instruction' => 'ORDER_COMPLETE_ON_PAYMENT_APPROVAL',
|
||||||
|
'application_context' => array(
|
||||||
|
'locale' => 'es-MX',
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
$payment_method = $this->order_endpoint->confirm_payment_source( $order->id(), $request_body );
|
||||||
foreach ( $payment_method->links as $link ) {
|
foreach ( $payment_method->links as $link ) {
|
||||||
if ( $link->rel === 'payer-action' ) {
|
if ( $link->rel === 'payer-action' ) {
|
||||||
$payer_action = $link->href;
|
$payer_action = $link->href;
|
||||||
|
|
|
@ -17,6 +17,7 @@ use WooCommerce\PayPalCommerce\ApiClient\Entity\ApplicationContext;
|
||||||
use WooCommerce\PayPalCommerce\ApiClient\Entity\Order;
|
use WooCommerce\PayPalCommerce\ApiClient\Entity\Order;
|
||||||
use WooCommerce\PayPalCommerce\ApiClient\Entity\OrderStatus;
|
use WooCommerce\PayPalCommerce\ApiClient\Entity\OrderStatus;
|
||||||
use WooCommerce\PayPalCommerce\ApiClient\Entity\PaymentSource;
|
use WooCommerce\PayPalCommerce\ApiClient\Entity\PaymentSource;
|
||||||
|
use WooCommerce\PayPalCommerce\ApiClient\Exception\PayPalApiException;
|
||||||
use WooCommerce\PayPalCommerce\ApiClient\Exception\RuntimeException;
|
use WooCommerce\PayPalCommerce\ApiClient\Exception\RuntimeException;
|
||||||
use WooCommerce\PayPalCommerce\ApiClient\Factory\OrderFactory;
|
use WooCommerce\PayPalCommerce\ApiClient\Factory\OrderFactory;
|
||||||
use WooCommerce\PayPalCommerce\ApiClient\Factory\PayerFactory;
|
use WooCommerce\PayPalCommerce\ApiClient\Factory\PayerFactory;
|
||||||
|
@ -196,11 +197,11 @@ class OrderProcessor {
|
||||||
* Processes a given WooCommerce order and captured/authorizes the connected PayPal orders.
|
* Processes a given WooCommerce order and captured/authorizes the connected PayPal orders.
|
||||||
*
|
*
|
||||||
* @param WC_Order $wc_order The WooCommerce order.
|
* @param WC_Order $wc_order The WooCommerce order.
|
||||||
*
|
* @return \stdClass PayPal order details of confirmed Order
|
||||||
* @throws PayPalOrderMissingException If no PayPal order.
|
* @throws PayPalOrderMissingException If no PayPal order.
|
||||||
* @throws Exception If processing fails.
|
* @throws Exception If processing fails.
|
||||||
*/
|
*/
|
||||||
public function process( WC_Order $wc_order ): void {
|
public function process( WC_Order $wc_order ): \stdClass {
|
||||||
$order = $this->session_handler->order();
|
$order = $this->session_handler->order();
|
||||||
if ( ! $order ) {
|
if ( ! $order ) {
|
||||||
// phpcs:ignore WordPress.Security.NonceVerification
|
// phpcs:ignore WordPress.Security.NonceVerification
|
||||||
|
@ -228,6 +229,20 @@ class OrderProcessor {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$request_body = apply_filters(
|
||||||
|
'woocommerce_paypal_payments_confirm_payment_source_request_body',
|
||||||
|
array(
|
||||||
|
'payment_source' => $order->payment_source() !== null ? $order->payment_source()->to_array() : null,
|
||||||
|
'application_context' => $order->application_context() !== null ? $order->application_context()->to_array() : null,
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
if ( ! empty( $request_body[ 'payment_source' ] ) ) {
|
||||||
|
$confirm_payment_result = $this->order_endpoint->confirm_payment_source( $order->id(), $request_body );
|
||||||
|
} else {
|
||||||
|
$confirm_payment_result = new \stdClass();
|
||||||
|
}
|
||||||
|
|
||||||
$this->add_paypal_meta( $wc_order, $order, $this->environment );
|
$this->add_paypal_meta( $wc_order, $order, $this->environment );
|
||||||
|
|
||||||
if ( $this->order_helper->contains_physical_goods( $order ) && ! $this->order_is_ready_for_process( $order ) ) {
|
if ( $this->order_helper->contains_physical_goods( $order ) && ! $this->order_is_ready_for_process( $order ) ) {
|
||||||
|
@ -268,6 +283,8 @@ class OrderProcessor {
|
||||||
}
|
}
|
||||||
|
|
||||||
do_action( 'woocommerce_paypal_payments_after_order_processor', $wc_order, $order );
|
do_action( 'woocommerce_paypal_payments_after_order_processor', $wc_order, $order );
|
||||||
|
|
||||||
|
return $confirm_payment_result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue