File: /var/www/html/ielts-store/wp-content/plugins/automatewoo/includes/Async_Events/Order_Paid.php
<?php
namespace AutomateWoo\Async_Events;
use AutomateWoo\Clean;
use AutomateWoo\Orders\StatusTransition;
defined( 'ABSPATH' ) || exit;
/**
* Event to fire when an order is first paid, supports payments by invoice, cheque, bank etc
*
* @since 4.8.0
*/
class Order_Paid extends Abstract_Async_Event {
/**
* Set any events that this event is dependant on.
*
* @var array
*/
protected $event_dependencies = [ 'order_status_changed' ];
/**
* Init order paid event helper.
*/
public function init() {
add_action( 'automatewoo/order/status_changed_async', [ $this, 'handle_async_order_status_changed' ], 10, 3 );
}
/**
* Get the async event hook name.
*
* @since 5.2.0
*
* @return string
*/
public function get_hook_name(): string {
return 'automatewoo/order/paid_async';
}
/**
* Determines whether the status change means the order is now paid.
*
* If the order is paid an action is triggered. This action can only run once for each order.
*
* @param int $order_id
* @param string $old_status
* @param string $new_status
*/
public function handle_async_order_status_changed( $order_id, $old_status, $new_status ) {
$transition = new StatusTransition( $old_status, $new_status );
if ( ! $transition->is_becoming_paid() ) {
return;
}
$order = wc_get_order( Clean::id( $order_id ) );
if ( ! $order || $order->get_meta( '_aw_is_paid' ) ) {
return;
}
$order->update_meta_data( '_aw_is_paid', true );
$order->save();
do_action( $this->get_hook_name(), $order->get_id() );
// This hook is also asynchronous, avoid using due to possible confusion
do_action( 'automatewoo/order/paid', $order );
}
}