/var/www/html_us/wp-content/plugins/woocommerce/src/StoreApi/Utilities/DraftOrderTrait.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
<?php
namespace Automattic\WooCommerce\StoreApi\Utilities;

/**
 * DraftOrderTrait
 *
 * Shared functionality for getting and setting draft order IDs from session.
 */
trait DraftOrderTrait {
    
/**
     * Gets draft order data from the customer session.
     *
     * @return integer
     */
    
protected function get_draft_order_id() {
        if ( ! 
wc()->session ) {
            
wc()->initialize_session();
        }
        return 
wc()->session->get'store_api_draft_order');
    }

    
/**
     * Updates draft order data in the customer session.
     *
     * @param integer $order_id Draft order ID.
     */
    
protected function set_draft_order_id$order_id ) {
        if ( ! 
wc()->session ) {
            
wc()->initialize_session();
        }
        
wc()->session->set'store_api_draft_order'$order_id );
    }

    
/**
     * Uses the draft order ID to return an order object, if valid.
     *
     * @return \WC_Order|null;
     */
    
protected function get_draft_order() {
        
$draft_order_id $this->get_draft_order_id();
        
$draft_order    $draft_order_id wc_get_order$draft_order_id ) : false;

        return 
$this->is_valid_draft_order$draft_order ) ? $draft_order null;
    }

    
/**
     * Whether the passed argument is a draft order or an order that is
     * pending/failed and the cart hasn't changed.
     *
     * @param \WC_Order $order_object Order object to check.
     * @return boolean Whether the order is valid as a draft order.
     */
    
protected function is_valid_draft_order$order_object ) {
        if ( ! 
$order_object instanceof \WC_Order ) {
            return 
false;
        }

        
// Draft orders are okay.
        
if ( $order_object->has_status'checkout-draft' ) ) {
            return 
true;
        }

        
// Pending and failed orders can be retried if the cart hasn't changed.
        
if ( $order_object->needs_payment() && $order_object->has_cart_hashwc()->cart->get_cart_hash() ) ) {
            return 
true;
        }

        return 
false;
    }
}