2014-06-13 13:20:14 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2018-03-21 03:31:15 +00:00
|
|
|
* Order Factory
|
2014-06-13 13:20:14 +00:00
|
|
|
*
|
2015-11-03 13:31:20 +00:00
|
|
|
* The WooCommerce order factory creating the right order objects.
|
2014-06-13 13:20:14 +00:00
|
|
|
*
|
2018-03-21 03:31:15 +00:00
|
|
|
* @version 3.0.0
|
|
|
|
* @package WooCommerce/Classes
|
|
|
|
*/
|
|
|
|
|
|
|
|
defined( 'ABSPATH' ) || exit;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Order factory class
|
2014-06-13 13:20:14 +00:00
|
|
|
*/
|
|
|
|
class WC_Order_Factory {
|
|
|
|
|
|
|
|
/**
|
2016-01-06 15:24:47 +00:00
|
|
|
* Get order.
|
2014-06-13 13:20:14 +00:00
|
|
|
*
|
2017-11-01 11:41:53 +00:00
|
|
|
* @param mixed $order_id (default: false) Order ID to get.
|
2015-02-03 15:55:40 +00:00
|
|
|
* @return WC_Order|bool
|
2014-06-13 13:20:14 +00:00
|
|
|
*/
|
2016-11-17 16:12:04 +00:00
|
|
|
public static function get_order( $order_id = false ) {
|
|
|
|
$order_id = self::get_order_id( $order_id );
|
2014-06-13 13:20:14 +00:00
|
|
|
|
2016-11-17 16:12:04 +00:00
|
|
|
if ( ! $order_id ) {
|
2014-06-13 13:20:14 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2018-03-21 03:31:15 +00:00
|
|
|
$order_type = WC_Data_Store::load( 'order' )->get_order_type( $order_id );
|
|
|
|
$order_type_data = wc_get_order_type( $order_type );
|
|
|
|
if ( $order_type_data ) {
|
2017-02-08 19:18:39 +00:00
|
|
|
$classname = $order_type_data['class_name'];
|
2014-06-13 13:20:14 +00:00
|
|
|
} else {
|
2014-07-08 17:10:37 +00:00
|
|
|
$classname = false;
|
2014-06-13 13:20:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Filter classname so that the class can be overridden if extended.
|
2017-02-08 19:18:39 +00:00
|
|
|
$classname = apply_filters( 'woocommerce_order_class', $classname, $order_type, $order_id );
|
2014-06-13 13:20:14 +00:00
|
|
|
|
2014-07-07 10:44:27 +00:00
|
|
|
if ( ! class_exists( $classname ) ) {
|
2015-05-19 16:51:04 +00:00
|
|
|
return false;
|
2014-07-07 10:44:27 +00:00
|
|
|
}
|
2014-06-13 13:20:14 +00:00
|
|
|
|
2016-11-22 10:46:19 +00:00
|
|
|
try {
|
2017-03-21 23:37:38 +00:00
|
|
|
return new $classname( $order_id );
|
2016-11-22 10:46:19 +00:00
|
|
|
} catch ( Exception $e ) {
|
2019-11-21 04:52:04 +00:00
|
|
|
wc_caught_exception( $e, __FUNCTION__, array( $order_id ) );
|
2016-11-22 10:46:19 +00:00
|
|
|
return false;
|
|
|
|
}
|
2014-06-13 13:20:14 +00:00
|
|
|
}
|
2016-06-21 19:07:31 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get order item.
|
2017-11-01 11:41:53 +00:00
|
|
|
*
|
|
|
|
* @param int $item_id Order item ID to get.
|
2016-08-19 12:43:33 +00:00
|
|
|
* @return WC_Order_Item|false if not found
|
2016-06-21 19:07:31 +00:00
|
|
|
*/
|
|
|
|
public static function get_order_item( $item_id = 0 ) {
|
|
|
|
if ( is_numeric( $item_id ) ) {
|
2017-02-08 19:39:30 +00:00
|
|
|
$item_type = WC_Data_Store::load( 'order-item' )->get_order_item_type( $item_id );
|
2016-11-17 21:30:34 +00:00
|
|
|
$id = $item_id;
|
2016-06-21 19:07:31 +00:00
|
|
|
} elseif ( $item_id instanceof WC_Order_Item ) {
|
2016-11-17 21:30:34 +00:00
|
|
|
$item_type = $item_id->get_type();
|
|
|
|
$id = $item_id->get_id();
|
2016-08-27 04:23:02 +00:00
|
|
|
} elseif ( is_object( $item_id ) && ! empty( $item_id->order_item_type ) ) {
|
2016-11-18 13:20:59 +00:00
|
|
|
$id = $item_id->order_item_id;
|
2016-06-21 19:07:31 +00:00
|
|
|
$item_type = $item_id->order_item_type;
|
|
|
|
} else {
|
|
|
|
$item_type = false;
|
2016-11-17 21:30:34 +00:00
|
|
|
$id = false;
|
2016-06-21 19:07:31 +00:00
|
|
|
}
|
|
|
|
|
2016-11-17 21:30:34 +00:00
|
|
|
if ( $id && $item_type ) {
|
2016-11-18 11:33:31 +00:00
|
|
|
$classname = false;
|
2016-06-21 19:07:31 +00:00
|
|
|
switch ( $item_type ) {
|
2018-03-21 03:31:15 +00:00
|
|
|
case 'line_item':
|
|
|
|
case 'product':
|
2016-11-18 11:33:31 +00:00
|
|
|
$classname = 'WC_Order_Item_Product';
|
2018-03-21 03:31:15 +00:00
|
|
|
break;
|
|
|
|
case 'coupon':
|
2016-11-18 11:33:31 +00:00
|
|
|
$classname = 'WC_Order_Item_Coupon';
|
2018-03-21 03:31:15 +00:00
|
|
|
break;
|
|
|
|
case 'fee':
|
2016-11-18 11:33:31 +00:00
|
|
|
$classname = 'WC_Order_Item_Fee';
|
2018-03-21 03:31:15 +00:00
|
|
|
break;
|
|
|
|
case 'shipping':
|
2016-11-18 11:33:31 +00:00
|
|
|
$classname = 'WC_Order_Item_Shipping';
|
2018-03-21 03:31:15 +00:00
|
|
|
break;
|
|
|
|
case 'tax':
|
2016-11-18 11:33:31 +00:00
|
|
|
$classname = 'WC_Order_Item_Tax';
|
2018-03-21 03:31:15 +00:00
|
|
|
break;
|
2016-06-21 19:07:31 +00:00
|
|
|
}
|
2017-03-20 09:37:06 +00:00
|
|
|
|
2017-05-23 18:16:30 +00:00
|
|
|
$classname = apply_filters( 'woocommerce_get_order_item_classname', $classname, $item_type, $id );
|
|
|
|
|
2017-03-20 19:17:49 +00:00
|
|
|
if ( $classname && class_exists( $classname ) ) {
|
2016-11-18 11:33:31 +00:00
|
|
|
try {
|
2017-03-21 23:37:38 +00:00
|
|
|
return new $classname( $id );
|
2016-11-18 11:33:31 +00:00
|
|
|
} catch ( Exception $e ) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2016-06-21 19:07:31 +00:00
|
|
|
}
|
2016-08-19 12:43:33 +00:00
|
|
|
return false;
|
2016-06-21 19:07:31 +00:00
|
|
|
}
|
2016-11-17 16:12:04 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the order ID depending on what was passed.
|
|
|
|
*
|
2017-03-15 16:36:53 +00:00
|
|
|
* @since 3.0.0
|
2017-11-01 11:41:53 +00:00
|
|
|
* @param mixed $order Order data to convert to an ID.
|
2016-11-17 16:12:04 +00:00
|
|
|
* @return int|bool false on failure
|
|
|
|
*/
|
2016-11-21 14:30:56 +00:00
|
|
|
public static function get_order_id( $order ) {
|
2016-11-17 16:12:04 +00:00
|
|
|
global $post;
|
|
|
|
|
|
|
|
if ( false === $order && is_a( $post, 'WP_Post' ) && 'shop_order' === get_post_type( $post ) ) {
|
2018-04-13 10:27:30 +00:00
|
|
|
return absint( $post->ID );
|
2016-11-17 16:12:04 +00:00
|
|
|
} elseif ( is_numeric( $order ) ) {
|
|
|
|
return $order;
|
|
|
|
} elseif ( $order instanceof WC_Abstract_Order ) {
|
|
|
|
return $order->get_id();
|
|
|
|
} elseif ( ! empty( $order->ID ) ) {
|
|
|
|
return $order->ID;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2014-07-07 19:19:51 +00:00
|
|
|
}
|