Use intent value from settings

This commit is contained in:
Emili Castells Guasch 2024-03-01 11:17:27 +01:00
parent da6d57b77b
commit 78ef57145c
2 changed files with 15 additions and 2 deletions

View file

@ -829,6 +829,7 @@ return array(
$container->get( 'api.endpoint.order' ), $container->get( 'api.endpoint.order' ),
$container->get( 'session.handler' ), $container->get( 'session.handler' ),
$container->get( 'wc-subscriptions.helpers.real-time-account-updater' ), $container->get( 'wc-subscriptions.helpers.real-time-account-updater' ),
$container->get( 'wcgateway.settings' ),
$container->get( 'woocommerce.logger.woocommerce' ) $container->get( 'woocommerce.logger.woocommerce' )
); );
}, },

View file

@ -22,6 +22,7 @@ use WooCommerce\PayPalCommerce\ApiClient\Factory\PurchaseUnitFactory;
use WooCommerce\PayPalCommerce\Button\Endpoint\EndpointInterface; use WooCommerce\PayPalCommerce\Button\Endpoint\EndpointInterface;
use WooCommerce\PayPalCommerce\Button\Endpoint\RequestData; use WooCommerce\PayPalCommerce\Button\Endpoint\RequestData;
use WooCommerce\PayPalCommerce\Session\SessionHandler; use WooCommerce\PayPalCommerce\Session\SessionHandler;
use WooCommerce\PayPalCommerce\WcGateway\Settings\Settings;
use WooCommerce\PayPalCommerce\WcSubscriptions\Helper\RealTimeAccountUpdaterHelper; use WooCommerce\PayPalCommerce\WcSubscriptions\Helper\RealTimeAccountUpdaterHelper;
use WP_Error; use WP_Error;
@ -90,6 +91,13 @@ class CaptureCardPayment implements EndpointInterface {
*/ */
private $real_time_account_updater_helper; private $real_time_account_updater_helper;
/**
* The settings.
*
* @var Settings
*/
private $settings;
/** /**
* The logger. * The logger.
* *
@ -108,6 +116,7 @@ class CaptureCardPayment implements EndpointInterface {
* @param OrderEndpoint $order_endpoint The order endpoint. * @param OrderEndpoint $order_endpoint The order endpoint.
* @param SessionHandler $session_handler The session handler. * @param SessionHandler $session_handler The session handler.
* @param RealTimeAccountUpdaterHelper $real_time_account_updater_helper Real Time Account Updater helper. * @param RealTimeAccountUpdaterHelper $real_time_account_updater_helper Real Time Account Updater helper.
* @param Settings $settings The settings.
* @param LoggerInterface $logger The logger. * @param LoggerInterface $logger The logger.
*/ */
public function __construct( public function __construct(
@ -119,6 +128,7 @@ class CaptureCardPayment implements EndpointInterface {
OrderEndpoint $order_endpoint, OrderEndpoint $order_endpoint,
SessionHandler $session_handler, SessionHandler $session_handler,
RealTimeAccountUpdaterHelper $real_time_account_updater_helper, RealTimeAccountUpdaterHelper $real_time_account_updater_helper,
Settings $settings,
LoggerInterface $logger LoggerInterface $logger
) { ) {
$this->request_data = $request_data; $this->request_data = $request_data;
@ -130,6 +140,7 @@ class CaptureCardPayment implements EndpointInterface {
$this->session_handler = $session_handler; $this->session_handler = $session_handler;
$this->real_time_account_updater_helper = $real_time_account_updater_helper; $this->real_time_account_updater_helper = $real_time_account_updater_helper;
$this->logger = $logger; $this->logger = $logger;
$this->settings = $settings;
} }
/** /**
@ -198,10 +209,11 @@ class CaptureCardPayment implements EndpointInterface {
* @throws RuntimeException When request fails. * @throws RuntimeException When request fails.
*/ */
private function create_order( string $vault_id ): stdClass { private function create_order( string $vault_id ): stdClass {
$items = array( $this->purchase_unit_factory->from_wc_cart() ); $intent = $this->settings->has( 'intent' ) && strtoupper( (string) $this->settings->get( 'intent' ) ) === 'AUTHORIZE' ? 'AUTHORIZE' : 'CAPTURE';
$items = array( $this->purchase_unit_factory->from_wc_cart() );
$data = array( $data = array(
'intent' => 'CAPTURE', 'intent' => $intent,
'purchase_units' => array_map( 'purchase_units' => array_map(
static function ( PurchaseUnit $item ): array { static function ( PurchaseUnit $item ): array {
return $item->to_array( true, false ); return $item->to_array( true, false );