Woocommerce 获取相似订单的订单商品

Woocommerce get order items of similar orders

在一个插件中,我试图不让用户使用相同的账单信息下类似的订单。 想象一下,一个拥有 John Doe 账单名字和姓氏的用户下了一个包含 product1 和 product2 的订单,而其他人试图用相同的账单名字和姓氏下相同或相似的订单(例如包含 product1、product2、product3),同时之前的订单还在处理中。 因此,为了避免这种行为,我试图在下单前验证订单。 如果有任何 运行 订单具有相同的账单信息,我会抛出 Woocommerce 错误,但我不知道如何确定最后的订单是否也包含类似的商品! 这是我的代码:

function check_for_duplicate_order($data)
{

        $data['billing_last_name'];
        $data['billing_first_name'];
        $data['billing_postcode'];
        $meta_query_args = array(
            'relation' => 'OR', // Optional, defaults to "AND"
            array(
                'key'     => '_billing_postcode',
                'value'   => '%' . $data['_billing_postcode'],
                'compare' => 'LIKE'
            ),
            array(
                'key'     => '_billing_phone',
                'value'   => '%' . $data['billing_phone'],
                'compare' => 'LIKE'
            ),
            array(
                'relation' => 'AND',
                array(
                    'key'     => '_billing_first_name',
                    'value'   => $data['billing_first_name'],
                    'compare' => '='
                ),
                array(
                    'key'     => '_billing_last_name',
                    'value'   => $data['billing_last_name'],
                    'compare' => '='
                )
            )
        );
        $query_params = [
            'post_type' => 'shop_order',
            'posts_per_page' => 1,
            'post_status' => array('wc-pending','wc-processing','wc-on-hold'),
            'meta_query' => $meta_query_args

        ];
        $cart_items_ids = [];
        global $woocommerce;
        $items = $woocommerce->cart->get_cart();
        foreach($items as $item => $values) {
            $cart_items_ids[] = $values['data']->get_id();
        }

    }
    add_action('woocommerce_after_checkout_validation', 'check_for_duplicate_order');

在上面的代码中,我获取了当前订单的账单信息,然后找到了具有相同账单信息的其他活动订单,但从这一点上我不知道如何找到订单项目并查看之前的订单中是否也有相同的项目.

我设法找到了将当前购物车中的商品与之前订单中的商品相匹配的解决方案:

foreach ($billing_active_order_ids as $active_order_id){
    $order = wc_get_order( $active_order_id );
    foreach ($order->get_items() as $id => $order_item){

        if(in_array($order_item->get_product_id(),$cart_items_ids)){
            wc_add_notice($duplicate_order_message, 'error');
            return;
        }

    }
}