/var/www/html_uk/wp-content/plugins/automatewoo/includes/Async_Events/Order_Paid.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
<?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);
    }

    
/**
     * 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_orderClean::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 );
    }
}