/var/www/html_us/wp-content/plugins/woocommerce/src/Internal/Orders/CouponsController.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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
<?php

namespace Automattic\WooCommerce\Internal\Orders;

use 
Automattic\WooCommerce\Utilities\ArrayUtil;
use 
Automattic\WooCommerce\Utilities\StringUtil;
use 
Exception;

/**
 * Class with methods for handling order coupons.
 */
class CouponsController {

    
/**
     * Add order discount via Ajax.
     *
     * @throws Exception If order or coupon is invalid.
     */
    
public function add_coupon_discount_via_ajax(): void {
        
check_ajax_referer'order-item''security' );

        if ( ! 
current_user_can'edit_shop_orders' ) ) {
            
wp_die( -);
        }

        
$response = array();

        try {
            
$order $this->add_coupon_discount$_POST );

            
ob_start();
            include 
__DIR__ '/../../../includes/admin/meta-boxes/views/html-order-items.php';
            
$response['html'] = ob_get_clean();

            
ob_start();
            
$notes wc_get_order_notes( array( 'order_id' => $order->get_id() ) );
            include 
__DIR__ '/../../../includes/admin/meta-boxes/views/html-order-notes.php';
            
$response['notes_html'] = ob_get_clean();
        } catch ( 
Exception $e ) {
            
wp_send_json_error( array( 'error' => $e->getMessage() ) );
        }

        
// wp_send_json_success must be outside the try block not to break phpunit tests.
        
wp_send_json_success$response );
    }

    
/**
     * Add order discount programmatically.
     *
     * @param array $post_variables Contents of the $_POST array that would be passed in an Ajax call.
     * @return object The retrieved order object.
     * @throws \Exception Invalid order or coupon.
     */
    
public function add_coupon_discount( array $post_variables ): object {
        
$order_id           = isset( $post_variables['order_id'] ) ? absint$post_variables['order_id'] ) : 0;
        
$order              wc_get_order$order_id );
        
$calculate_tax_args = array(
            
'country'  => isset( $post_variables['country'] ) ? wc_strtoupperwc_cleanwp_unslash$post_variables['country'] ) ) ) : '',
            
'state'    => isset( $post_variables['state'] ) ? wc_strtoupperwc_cleanwp_unslash$post_variables['state'] ) ) ) : '',
            
'postcode' => isset( $post_variables['postcode'] ) ? wc_strtoupperwc_cleanwp_unslash$post_variables['postcode'] ) ) ) : '',
            
'city'     => isset( $post_variables['city'] ) ? wc_strtoupperwc_cleanwp_unslash$post_variables['city'] ) ) ) : '',
        );

        if ( ! 
$order ) {
            throw new 
Exception__'Invalid order''woocommerce' ) );
        }

        
$coupon ArrayUtil::get_value_or_default$post_variables'coupon' );
        if ( 
StringUtil::is_null_or_whitespace$coupon ) ) {
            throw new 
Exception__'Invalid coupon''woocommerce' ) );
        }

        
// Add user ID and/or email so validation for coupon limits works.
        
$user_id_arg    = isset( $post_variables['user_id'] ) ? absint$post_variables['user_id'] ) : 0;
        
$user_email_arg = isset( $post_variables['user_email'] ) ? sanitize_emailwp_unslash$post_variables['user_email'] ) ) : '';

        if ( 
$user_id_arg ) {
            
$order->set_customer_id$user_id_arg );
        }
        if ( 
$user_email_arg ) {
            
$order->set_billing_email$user_email_arg );
        }

        
$order->calculate_taxes$calculate_tax_args );
        
$order->calculate_totalsfalse );

        
$code   wc_format_coupon_codewp_unslash$coupon ) ); // phpcs:ignore WordPress.Security.NonceVerification.Missing, WordPress.Security.ValidatedSanitizedInput.InputNotSanitized
        
$result $order->apply_coupon$code );

        if ( 
is_wp_error$result ) ) {
            throw new 
Exceptionhtml_entity_decodewp_strip_all_tags$result->get_error_message() ) ) );
        }

        
// translators: %s coupon code.
        
$order->add_order_noteesc_htmlsprintf__'Coupon applied: "%s".''woocommerce' ), $code ) ), 0true );

        return 
$order;
    }
}