diff --git a/modules/ppcp-webhooks/services.php b/modules/ppcp-webhooks/services.php index c02ef6678..2507a4e47 100644 --- a/modules/ppcp-webhooks/services.php +++ b/modules/ppcp-webhooks/services.php @@ -28,6 +28,7 @@ use WooCommerce\PayPalCommerce\Webhooks\Handler\PaymentCaptureReversed; use WooCommerce\PayPalCommerce\Vendor\Psr\Container\ContainerInterface; use WooCommerce\PayPalCommerce\Webhooks\Handler\VaultCreditCardCreated; use WooCommerce\PayPalCommerce\Webhooks\Handler\VaultPaymentTokenCreated; +use WooCommerce\PayPalCommerce\Webhooks\Handler\VaultPaymentTokenDeleted; use WooCommerce\PayPalCommerce\Webhooks\Status\Assets\WebhooksStatusPageAssets; use WooCommerce\PayPalCommerce\Webhooks\Status\WebhookSimulation; @@ -83,7 +84,7 @@ return array( new PaymentCaptureReversed( $logger, $prefix ), new PaymentCaptureCompleted( $logger, $prefix, $order_endpoint ), new VaultPaymentTokenCreated( $logger, $prefix, $authorized_payments_processor, $payment_token_paypal ), - new VaultCreditCardCreated( $logger, $prefix ), + new VaultPaymentTokenDeleted( $logger ), new PaymentCapturePending( $logger ), ); }, diff --git a/modules/ppcp-webhooks/src/Handler/VaultCreditCardCreated.php b/modules/ppcp-webhooks/src/Handler/VaultCreditCardCreated.php deleted file mode 100644 index cdc74c5d6..000000000 --- a/modules/ppcp-webhooks/src/Handler/VaultCreditCardCreated.php +++ /dev/null @@ -1,87 +0,0 @@ -logger = $logger; - $this->prefix = $prefix; - } - - /** - * The event types a handler handles. - * - * @return string[] - */ - public function event_types(): array { - return array( - 'VAULT.CREDIT-CARD.CREATED', - ); - } - - /** - * Whether a handler is responsible for a given request or not. - * - * @param WP_REST_Request $request The request. - * - * @return bool - */ - public function responsible_for_request( WP_REST_Request $request ): bool { - return in_array( $request['event_type'], $this->event_types(), true ); - } - - /** - * Responsible for handling the request. - * - * @param WP_REST_Request $request The request. - * - * @return WP_REST_Response - */ - public function handle_request( WP_REST_Request $request ): WP_REST_Response { - // TODO currently this webhook is not triggered from PayPal, implement it once is available. - - $message = 'VAULT.CREDIT-CARD.CREATED received.'; - $this->logger->log( 'info', $message ); - $response = array( - 'success' => true, - 'message' => $message, - ); - - return new WP_REST_Response( $response ); - } -} diff --git a/modules/ppcp-webhooks/src/Handler/VaultPaymentTokenDeleted.php b/modules/ppcp-webhooks/src/Handler/VaultPaymentTokenDeleted.php new file mode 100644 index 000000000..1a2fb8288 --- /dev/null +++ b/modules/ppcp-webhooks/src/Handler/VaultPaymentTokenDeleted.php @@ -0,0 +1,67 @@ +logger = $logger; + } + + public function event_types(): array + { + return array( + 'VAULT.PAYMENT-TOKEN.DELETED', + ); + } + + public function responsible_for_request(WP_REST_Request $request): bool + { + return in_array( $request['event_type'], $this->event_types(), true ); + } + + public function handle_request(WP_REST_Request $request): WP_REST_Response { + + if(isset($request['resource']['id'])) { + $token_id = wc_clean(wp_unslash($request['resource']['id'] ?? '')); + + global $wpdb; + $token = $wpdb->get_row( + $wpdb->prepare( + "SELECT * FROM {$wpdb->prefix}woocommerce_payment_tokens WHERE token=%s", + $token_id + ) + ); + + if(isset($token->token_id)) { + WC_Payment_Tokens::delete( $token->token_id ); + } + } + + $response['success'] = true; + return new WP_REST_Response( $response ); + } +}