File "PaymentSaleRefunded.php"
Full Path: /home/siazco/grocery.siazco.se/wp-content/plugins/woocommerce-paypal-payments/modules/ppcp-webhooks/src/Handler/PaymentSaleRefunded.php
File size: 3.48 KB
MIME-type: text/x-php
Charset: utf-8
<?php
/**
* Handles the Webhook PAYMENT.SALE.REFUNDED
*
* @package WooCommerce\PayPalCommerce\Webhooks\Handler
*/
declare(strict_types=1);
namespace WooCommerce\PayPalCommerce\Webhooks\Handler;
use Psr\Log\LoggerInterface;
use WooCommerce\PayPalCommerce\WcGateway\Helper\RefundFeesUpdater;
use WooCommerce\PayPalCommerce\WcGateway\Processor\RefundMetaTrait;
use WooCommerce\PayPalCommerce\WcGateway\Processor\TransactionIdHandlingTrait;
use WP_Error;
use WP_REST_Request;
use WP_REST_Response;
/**
* Class PaymentSaleRefunded
*/
class PaymentSaleRefunded implements RequestHandler {
use TransactionIdHandlingTrait, RefundMetaTrait, RequestHandlerTrait;
/**
* The logger.
*
* @var LoggerInterface
*/
private $logger;
/**
* The refund fees updater.
*
* @var RefundFeesUpdater
*/
private $refund_fees_updater;
/**
* PaymentSaleRefunded constructor.
*
* @param LoggerInterface $logger The logger.
* @param RefundFeesUpdater $refund_fees_updater The refund fees updater.
*/
public function __construct( LoggerInterface $logger, RefundFeesUpdater $refund_fees_updater ) {
$this->logger = $logger;
$this->refund_fees_updater = $refund_fees_updater;
}
/**
* The event types a handler handles.
*
* @return string[]
*/
public function event_types(): array {
return array( 'PAYMENT.SALE.REFUNDED' );
}
/**
* 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 {
if ( is_null( $request['resource'] ) ) {
return $this->failure_response();
}
$refund_id = (string) ( $request['resource']['id'] ?? '' );
$transaction_id = $request['resource']['sale_id'] ?? '';
$total_refunded_amount = $request['resource']['total_refunded_amount']['value'] ?? '';
if ( ! $refund_id || ! $transaction_id || ! $total_refunded_amount ) {
return $this->failure_response();
}
$args = array(
// phpcs:disable WordPress.DB.SlowDBQuery
'meta_key' => '_transaction_id',
'meta_value' => $transaction_id,
'meta_compare' => '=',
// phpcs:enable
);
$wc_orders = wc_get_orders( $args );
if ( ! is_array( $wc_orders ) ) {
return $this->failure_response();
}
foreach ( $wc_orders as $wc_order ) {
$refund = wc_create_refund(
array(
'order_id' => $wc_order->get_id(),
'amount' => $total_refunded_amount,
)
);
if ( $refund instanceof WP_Error ) {
$message = sprintf(
'Order %s could not be refunded. %s',
(string) $wc_order->get_id(),
$refund->get_error_message()
);
return $this->failure_response( $message );
}
$order_refunded_message = sprintf(
'Order %1$s has been refunded with %2$s through PayPal.',
(string) $wc_order->get_id(),
(string) $total_refunded_amount
);
$this->logger->info( $order_refunded_message );
$wc_order->add_order_note( $order_refunded_message );
$this->update_transaction_id( $refund_id, $wc_order, $this->logger );
$this->add_refund_to_meta( $wc_order, $refund_id );
$this->refund_fees_updater->update( $wc_order );
}
return $this->success_response();
}
}