2016-11-17 21:30:34 +00:00
< ? php
if ( ! defined ( 'ABSPATH' ) ) {
exit ;
}
/**
* WC Order Item Product Data Store
*
2017-03-15 16:36:53 +00:00
* @ version 3.0 . 0
2016-11-17 21:30:34 +00:00
* @ category Class
2016-11-18 11:33:31 +00:00
* @ author WooCommerce
2016-11-17 21:30:34 +00:00
*/
2016-11-22 13:54:51 +00:00
class WC_Order_Item_Product_Data_Store extends Abstract_WC_Order_Item_Type_Data_Store implements WC_Object_Data_Store_Interface , WC_Order_Item_Type_Data_Store_Interface , WC_Order_Item_Product_Data_Store_Interface {
2017-03-20 10:03:14 +00:00
2016-11-24 11:50:34 +00:00
/**
* Data stored in meta keys .
2018-03-07 19:16:01 +00:00
*
2017-03-15 16:36:53 +00:00
* @ since 3.0 . 0
2016-11-24 11:50:34 +00:00
* @ var array
*/
protected $internal_meta_keys = array ( '_product_id' , '_variation_id' , '_qty' , '_tax_class' , '_line_subtotal' , '_line_subtotal_tax' , '_line_total' , '_line_tax' , '_line_tax_data' );
2016-11-17 21:30:34 +00:00
/**
* Read / populate data properties specific to this order item .
*
2017-03-15 16:36:53 +00:00
* @ since 3.0 . 0
2017-03-20 10:03:14 +00:00
* @ param WC_Order_Item_Product $item
2016-11-17 21:30:34 +00:00
*/
public function read ( & $item ) {
parent :: read ( $item );
2017-02-01 00:44:16 +00:00
$id = $item -> get_id ();
2018-03-07 19:16:01 +00:00
$item -> set_props (
array (
'product_id' => get_metadata ( 'order_item' , $id , '_product_id' , true ),
'variation_id' => get_metadata ( 'order_item' , $id , '_variation_id' , true ),
'quantity' => get_metadata ( 'order_item' , $id , '_qty' , true ),
'tax_class' => get_metadata ( 'order_item' , $id , '_tax_class' , true ),
'subtotal' => get_metadata ( 'order_item' , $id , '_line_subtotal' , true ),
'total' => get_metadata ( 'order_item' , $id , '_line_total' , true ),
'taxes' => get_metadata ( 'order_item' , $id , '_line_tax_data' , true ),
)
);
2016-12-18 18:04:14 +00:00
$item -> set_object_read ( true );
2016-11-17 21:30:34 +00:00
}
/**
2016-11-18 11:33:31 +00:00
* Saves an item ' s data to the database / item meta .
2017-02-01 00:44:16 +00:00
* Ran after both create and update , so $id will be set .
2016-11-17 21:30:34 +00:00
*
2017-03-15 16:36:53 +00:00
* @ since 3.0 . 0
2017-03-20 10:03:14 +00:00
* @ param WC_Order_Item_Product $item
2016-11-17 21:30:34 +00:00
*/
public function save_item_data ( & $item ) {
2018-01-19 14:36:08 +00:00
$id = $item -> get_id ();
$changes = $item -> get_changes ();
$meta_key_to_props = array (
'_product_id' => 'product_id' ,
'_variation_id' => 'variation_id' ,
'_qty' => 'quantity' ,
'_tax_class' => 'tax_class' ,
'_line_subtotal' => 'subtotal' ,
'_line_subtotal_tax' => 'subtotal_tax' ,
'_line_total' => 'total' ,
'_line_tax' => 'total_tax' ,
'_line_tax_data' => 'taxes' ,
2017-02-01 09:53:53 +00:00
);
2018-03-07 19:16:01 +00:00
$props_to_update = $this -> get_props_to_update ( $item , $meta_key_to_props , 'order_item' );
2018-01-19 14:36:08 +00:00
foreach ( $props_to_update as $meta_key => $prop ) {
update_metadata ( 'order_item' , $id , $meta_key , $item -> { " get_ $prop " }( 'edit' ) );
2017-02-01 09:53:53 +00:00
}
2016-11-17 21:30:34 +00:00
}
2016-11-18 11:33:31 +00:00
/**
* Get a list of download IDs for a specific item from an order .
*
2017-03-15 16:36:53 +00:00
* @ since 3.0 . 0
2017-03-20 10:03:14 +00:00
* @ param WC_Order_Item_Product $item
2018-03-07 19:16:01 +00:00
* @ param WC_Order $order
2016-11-18 11:33:31 +00:00
* @ return array
*/
2016-11-17 21:30:34 +00:00
public function get_download_ids ( $item , $order ) {
global $wpdb ;
return $wpdb -> get_col (
$wpdb -> prepare (
" SELECT download_id FROM { $wpdb -> prefix } woocommerce_downloadable_product_permissions WHERE user_email = %s AND order_key = %s AND product_id = %d ORDER BY permission_id " ,
$order -> get_billing_email (),
$order -> get_order_key (),
$item -> get_variation_id () ? $item -> get_variation_id () : $item -> get_product_id ()
)
);
}
}