2016-02-22 19:43:52 +00:00
< ? php
if ( ! defined ( 'ABSPATH' ) ) {
exit ;
}
/**
2017-03-28 17:58:51 +00:00
* Abstract Rest Posts Controller Class
2016-02-22 19:43:52 +00:00
*
* @ author WooThemes
* @ category API
* @ package WooCommerce / Abstracts
* @ version 2.6 . 0
*/
2016-05-11 19:34:53 +00:00
abstract class WC_REST_Posts_Controller extends WC_REST_Controller {
2016-02-22 19:43:52 +00:00
2016-03-07 18:36:17 +00:00
/**
* Endpoint namespace .
*
* @ var string
*/
2016-03-31 18:28:17 +00:00
protected $namespace = 'wc/v1' ;
2016-03-07 18:36:17 +00:00
2016-02-22 19:43:52 +00:00
/**
* Route base .
*
* @ var string
*/
protected $rest_base = '' ;
/**
* Post type .
*
* @ var string
*/
protected $post_type = '' ;
/**
* Controls visibility on frontend .
*
* @ var string
*/
protected $public = false ;
/**
2016-03-30 14:17:16 +00:00
* Check if a given request has access to read items .
2016-02-22 19:43:52 +00:00
*
* @ param WP_REST_Request $request Full details about the request .
* @ return WP_Error | boolean
*/
2016-03-30 14:17:16 +00:00
public function get_items_permissions_check ( $request ) {
if ( ! wc_rest_check_post_permissions ( $this -> post_type , 'read' ) ) {
return new WP_Error ( 'woocommerce_rest_cannot_view' , __ ( 'Sorry, you cannot list resources.' , 'woocommerce' ), array ( 'status' => rest_authorization_required_code () ) );
2016-02-22 19:43:52 +00:00
}
2016-03-30 17:17:40 +00:00
return true ;
2016-02-22 19:43:52 +00:00
}
2016-02-26 20:24:33 +00:00
/**
* Check if a given request has access to create an item .
*
* @ param WP_REST_Request $request Full details about the request .
* @ return WP_Error | boolean
*/
public function create_item_permissions_check ( $request ) {
2016-03-30 14:17:16 +00:00
if ( ! wc_rest_check_post_permissions ( $this -> post_type , 'create' ) ) {
2016-03-31 19:03:59 +00:00
return new WP_Error ( 'woocommerce_rest_cannot_create' , __ ( 'Sorry, you are not allowed to create resources.' , 'woocommerce' ), array ( 'status' => rest_authorization_required_code () ) );
2016-02-26 20:24:33 +00:00
}
return true ;
}
2016-02-23 18:28:43 +00:00
/**
2016-03-30 14:17:16 +00:00
* Check if a given request has access to read an item .
2016-02-23 18:28:43 +00:00
*
* @ param WP_REST_Request $request Full details about the request .
* @ return WP_Error | boolean
*/
2016-03-30 14:17:16 +00:00
public function get_item_permissions_check ( $request ) {
$post = get_post ( ( int ) $request [ 'id' ] );
if ( $post && ! wc_rest_check_post_permissions ( $this -> post_type , 'read' , $post -> ID ) ) {
return new WP_Error ( 'woocommerce_rest_cannot_view' , __ ( 'Sorry, you cannot view this resource.' , 'woocommerce' ), array ( 'status' => rest_authorization_required_code () ) );
}
2016-02-23 18:28:43 +00:00
2016-03-30 14:17:16 +00:00
return true ;
2016-02-23 18:28:43 +00:00
}
2016-02-26 20:24:33 +00:00
/**
* Check if a given request has access to update an item .
*
* @ param WP_REST_Request $request Full details about the request .
* @ return WP_Error | boolean
*/
public function update_item_permissions_check ( $request ) {
2017-01-26 18:34:11 +00:00
$post = get_post ( ( int ) $request [ 'id' ] );
2016-02-26 20:24:33 +00:00
2016-03-30 14:17:16 +00:00
if ( $post && ! wc_rest_check_post_permissions ( $this -> post_type , 'edit' , $post -> ID ) ) {
2016-03-31 19:03:59 +00:00
return new WP_Error ( 'woocommerce_rest_cannot_edit' , __ ( 'Sorry, you are not allowed to edit this resource.' , 'woocommerce' ), array ( 'status' => rest_authorization_required_code () ) );
2016-02-26 20:24:33 +00:00
}
return true ;
}
2016-02-23 18:28:43 +00:00
/**
* Check if a given request has access to delete an item .
*
* @ param WP_REST_Request $request Full details about the request .
* @ return bool | WP_Error
*/
public function delete_item_permissions_check ( $request ) {
2017-01-26 18:34:11 +00:00
$post = get_post ( ( int ) $request [ 'id' ] );
2016-02-23 18:28:43 +00:00
2016-03-30 14:17:16 +00:00
if ( $post && ! wc_rest_check_post_permissions ( $this -> post_type , 'delete' , $post -> ID ) ) {
return new WP_Error ( 'woocommerce_rest_cannot_delete' , __ ( 'Sorry, you are not allowed to delete this resource.' , 'woocommerce' ), array ( 'status' => rest_authorization_required_code () ) );
2016-02-23 18:28:43 +00:00
}
return true ;
}
2016-05-11 19:34:53 +00:00
/**
* Check if a given request has access batch create , update and delete items .
*
* @ param WP_REST_Request $request Full details about the request .
* @ return boolean
*/
public function batch_items_permissions_check ( $request ) {
if ( ! wc_rest_check_post_permissions ( $this -> post_type , 'batch' ) ) {
2016-08-08 21:52:46 +00:00
return new WP_Error ( 'woocommerce_rest_cannot_batch' , __ ( 'Sorry, you are not allowed to batch manipulate this resource.' , 'woocommerce' ), array ( 'status' => rest_authorization_required_code () ) );
2016-05-11 19:34:53 +00:00
}
return true ;
}
2016-02-22 19:43:52 +00:00
/**
2016-02-22 20:48:38 +00:00
* Get a single item .
2016-02-22 19:43:52 +00:00
*
2016-02-22 20:48:38 +00:00
* @ param WP_REST_Request $request Full details about the request .
* @ return WP_Error | WP_REST_Response
2016-02-22 19:43:52 +00:00
*/
2016-02-22 20:48:38 +00:00
public function get_item ( $request ) {
$id = ( int ) $request [ 'id' ];
$post = get_post ( $id );
2016-02-22 19:43:52 +00:00
2016-11-08 15:55:33 +00:00
if ( ! empty ( $post -> post_type ) && 'product_variation' === $post -> post_type && 'product' === $this -> post_type ) {
return new WP_Error ( " woocommerce_rest_invalid_ { $this -> post_type } _id " , __ ( 'To manipulate product variations you should use the /products/<product_id>/variations/<id> endpoint.' , 'woocommerce' ), array ( 'status' => 404 ) );
} elseif ( empty ( $id ) || empty ( $post -> ID ) || $post -> post_type !== $this -> post_type ) {
2016-07-26 13:47:04 +00:00
return new WP_Error ( " woocommerce_rest_invalid_ { $this -> post_type } _id " , __ ( 'Invalid ID.' , 'woocommerce' ), array ( 'status' => 404 ) );
2016-02-22 19:43:52 +00:00
}
2016-02-22 20:48:38 +00:00
$data = $this -> prepare_item_for_response ( $post , $request );
$response = rest_ensure_response ( $data );
2016-02-22 19:43:52 +00:00
2016-02-22 20:48:38 +00:00
if ( $this -> public ) {
$response -> link_header ( 'alternate' , get_permalink ( $id ), array ( 'type' => 'text/html' ) );
2016-02-22 19:43:52 +00:00
}
2016-02-22 20:48:38 +00:00
return $response ;
2016-02-22 19:43:52 +00:00
}
2016-02-26 20:24:33 +00:00
/**
* Create a single item .
*
* @ param WP_REST_Request $request Full details about the request .
* @ return WP_Error | WP_REST_Response
*/
public function create_item ( $request ) {
if ( ! empty ( $request [ 'id' ] ) ) {
2016-10-29 10:16:03 +00:00
/* translators: %s: post type */
2016-02-26 20:24:33 +00:00
return new WP_Error ( " woocommerce_rest_ { $this -> post_type } _exists " , sprintf ( __ ( 'Cannot create existing %s.' , 'woocommerce' ), $this -> post_type ), array ( 'status' => 400 ) );
}
$post = $this -> prepare_item_for_database ( $request );
if ( is_wp_error ( $post ) ) {
return $post ;
}
$post -> post_type = $this -> post_type ;
2016-03-31 19:34:16 +00:00
$post_id = wp_insert_post ( $post , true );
2016-02-26 20:24:33 +00:00
if ( is_wp_error ( $post_id ) ) {
if ( in_array ( $post_id -> get_error_code (), array ( 'db_insert_error' ) ) ) {
$post_id -> add_data ( array ( 'status' => 500 ) );
} else {
$post_id -> add_data ( array ( 'status' => 400 ) );
}
return $post_id ;
}
$post -> ID = $post_id ;
2016-03-31 19:34:16 +00:00
$post = get_post ( $post_id );
2016-02-26 20:24:33 +00:00
$this -> update_additional_fields_for_object ( $post , $request );
// Add meta fields.
$meta_fields = $this -> add_post_meta_fields ( $post , $request );
if ( is_wp_error ( $meta_fields ) ) {
// Remove post.
2016-03-30 00:22:10 +00:00
$this -> delete_post ( $post );
2016-02-26 20:24:33 +00:00
return $meta_fields ;
}
/**
* Fires after a single item is created or updated via the REST API .
*
2017-04-18 16:39:22 +00:00
* @ param WP_Post $post Post object .
2016-02-26 20:24:33 +00:00
* @ param WP_REST_Request $request Request object .
* @ param boolean $creating True when creating item , false when updating .
*/
do_action ( " woocommerce_rest_insert_ { $this -> post_type } " , $post , $request , true );
$request -> set_param ( 'context' , 'edit' );
$response = $this -> prepare_item_for_response ( $post , $request );
$response = rest_ensure_response ( $response );
$response -> set_status ( 201 );
2016-03-07 18:36:17 +00:00
$response -> header ( 'Location' , rest_url ( sprintf ( '/%s/%s/%d' , $this -> namespace , $this -> rest_base , $post_id ) ) );
2016-02-26 20:24:33 +00:00
return $response ;
}
/**
* Add post meta fields .
*
* @ param WP_Post $post
* @ param WP_REST_Request $request
* @ return bool | WP_Error
*/
protected function add_post_meta_fields ( $post , $request ) {
return true ;
}
2016-03-30 00:22:10 +00:00
/**
* Delete post .
*
* @ param WP_Post $post
*/
protected function delete_post ( $post ) {
wp_delete_post ( $post -> ID , true );
}
2016-02-26 20:24:33 +00:00
/**
* Update a single post .
*
* @ param WP_REST_Request $request Full details about the request .
* @ return WP_Error | WP_REST_Response
*/
public function update_item ( $request ) {
2016-03-31 19:14:18 +00:00
$id = ( int ) $request [ 'id' ];
2016-02-26 20:24:33 +00:00
$post = get_post ( $id );
2016-11-08 15:55:33 +00:00
if ( ! empty ( $post -> post_type ) && 'product_variation' === $post -> post_type && 'product' === $this -> post_type ) {
return new WP_Error ( " woocommerce_rest_invalid_ { $this -> post_type } _id " , __ ( 'To manipulate product variations you should use the /products/<product_id>/variations/<id> endpoint.' , 'woocommerce' ), array ( 'status' => 404 ) );
} elseif ( empty ( $id ) || empty ( $post -> ID ) || $post -> post_type !== $this -> post_type ) {
2016-02-26 20:24:33 +00:00
return new WP_Error ( " woocommerce_rest_ { $this -> post_type } _invalid_id " , __ ( 'ID is invalid.' , 'woocommerce' ), array ( 'status' => 400 ) );
}
$post = $this -> prepare_item_for_database ( $request );
if ( is_wp_error ( $post ) ) {
return $post ;
}
// Convert the post object to an array, otherwise wp_update_post will expect non-escaped input.
$post_id = wp_update_post ( ( array ) $post , true );
if ( is_wp_error ( $post_id ) ) {
if ( in_array ( $post_id -> get_error_code (), array ( 'db_update_error' ) ) ) {
$post_id -> add_data ( array ( 'status' => 500 ) );
} else {
$post_id -> add_data ( array ( 'status' => 400 ) );
}
return $post_id ;
}
$post = get_post ( $post_id );
$this -> update_additional_fields_for_object ( $post , $request );
// Update meta fields.
$meta_fields = $this -> update_post_meta_fields ( $post , $request );
if ( is_wp_error ( $meta_fields ) ) {
return $meta_fields ;
}
/**
* Fires after a single item is created or updated via the REST API .
*
2017-04-18 16:39:22 +00:00
* @ param WP_Post $post Post object .
2016-02-26 20:24:33 +00:00
* @ param WP_REST_Request $request Request object .
* @ param boolean $creating True when creating item , false when updating .
*/
2016-03-02 22:14:03 +00:00
do_action ( " woocommerce_rest_insert_ { $this -> post_type } " , $post , $request , false );
2016-02-26 20:24:33 +00:00
$request -> set_param ( 'context' , 'edit' );
$response = $this -> prepare_item_for_response ( $post , $request );
return rest_ensure_response ( $response );
}
2016-02-23 15:16:21 +00:00
/**
* Get a collection of posts .
*
* @ param WP_REST_Request $request Full details about the request .
* @ return WP_Error | WP_REST_Response
*/
public function get_items ( $request ) {
$args = array ();
$args [ 'offset' ] = $request [ 'offset' ];
$args [ 'order' ] = $request [ 'order' ];
$args [ 'orderby' ] = $request [ 'orderby' ];
$args [ 'paged' ] = $request [ 'page' ];
$args [ 'post__in' ] = $request [ 'include' ];
$args [ 'post__not_in' ] = $request [ 'exclude' ];
$args [ 'posts_per_page' ] = $request [ 'per_page' ];
$args [ 'name' ] = $request [ 'slug' ];
$args [ 'post_parent__in' ] = $request [ 'parent' ];
$args [ 'post_parent__not_in' ] = $request [ 'parent_exclude' ];
$args [ 's' ] = $request [ 'search' ];
$args [ 'date_query' ] = array ();
// Set before into date query. Date query must be specified as an array of an array.
if ( isset ( $request [ 'before' ] ) ) {
$args [ 'date_query' ][ 0 ][ 'before' ] = $request [ 'before' ];
}
// Set after into date query. Date query must be specified as an array of an array.
if ( isset ( $request [ 'after' ] ) ) {
$args [ 'date_query' ][ 0 ][ 'after' ] = $request [ 'after' ];
}
2017-02-17 15:13:17 +00:00
if ( 'wc/v1' === $this -> namespace ) {
if ( is_array ( $request [ 'filter' ] ) ) {
$args = array_merge ( $args , $request [ 'filter' ] );
unset ( $args [ 'filter' ] );
}
2016-02-23 15:16:21 +00:00
}
// Force the post_type argument, since it's not a user input variable.
$args [ 'post_type' ] = $this -> post_type ;
/**
* Filter the query arguments for a request .
*
* Enables adding extra arguments or setting defaults for a post
* collection request .
*
* @ param array $args Key value array of query var to query value .
* @ param WP_REST_Request $request The request used .
*/
$args = apply_filters ( " woocommerce_rest_ { $this -> post_type } _query " , $args , $request );
$query_args = $this -> prepare_items_query ( $args , $request );
$posts_query = new WP_Query ();
$query_result = $posts_query -> query ( $query_args );
$posts = array ();
foreach ( $query_result as $post ) {
2016-03-30 14:17:16 +00:00
if ( ! wc_rest_check_post_permissions ( $this -> post_type , 'read' , $post -> ID ) ) {
2016-02-23 15:16:21 +00:00
continue ;
}
$data = $this -> prepare_item_for_response ( $post , $request );
$posts [] = $this -> prepare_response_for_collection ( $data );
}
$page = ( int ) $query_args [ 'paged' ];
$total_posts = $posts_query -> found_posts ;
if ( $total_posts < 1 ) {
// Out-of-bounds, run the query again without LIMIT for total count
unset ( $query_args [ 'paged' ] );
$count_query = new WP_Query ();
$count_query -> query ( $query_args );
$total_posts = $count_query -> found_posts ;
}
$max_pages = ceil ( $total_posts / ( int ) $query_args [ 'posts_per_page' ] );
$response = rest_ensure_response ( $posts );
$response -> header ( 'X-WP-Total' , ( int ) $total_posts );
$response -> header ( 'X-WP-TotalPages' , ( int ) $max_pages );
$request_params = $request -> get_query_params ();
if ( ! empty ( $request_params [ 'filter' ] ) ) {
// Normalize the pagination params.
unset ( $request_params [ 'filter' ][ 'posts_per_page' ] );
unset ( $request_params [ 'filter' ][ 'paged' ] );
}
2016-03-07 18:36:17 +00:00
$base = add_query_arg ( $request_params , rest_url ( sprintf ( '/%s/%s' , $this -> namespace , $this -> rest_base ) ) );
2016-02-23 15:16:21 +00:00
if ( $page > 1 ) {
$prev_page = $page - 1 ;
if ( $prev_page > $max_pages ) {
$prev_page = $max_pages ;
}
$prev_link = add_query_arg ( 'page' , $prev_page , $base );
$response -> link_header ( 'prev' , $prev_link );
}
if ( $max_pages > $page ) {
$next_page = $page + 1 ;
$next_link = add_query_arg ( 'page' , $next_page , $base );
$response -> link_header ( 'next' , $next_link );
}
return $response ;
}
2016-03-15 19:45:46 +00:00
/**
* Delete a single item .
*
* @ param WP_REST_Request $request Full details about the request .
* @ return WP_REST_Response | WP_Error
*/
public function delete_item ( $request ) {
2016-03-31 19:14:18 +00:00
$id = ( int ) $request [ 'id' ];
2016-03-15 19:45:46 +00:00
$force = ( bool ) $request [ 'force' ];
2016-03-31 19:14:18 +00:00
$post = get_post ( $id );
2016-03-15 19:45:46 +00:00
2016-11-08 11:14:01 +00:00
if ( empty ( $id ) || empty ( $post -> ID ) || $post -> post_type !== $this -> post_type ) {
2016-10-12 10:16:30 +00:00
return new WP_Error ( " woocommerce_rest_ { $this -> post_type } _invalid_id " , __ ( 'ID is invalid.' , 'woocommerce' ), array ( 'status' => 404 ) );
2016-03-15 19:45:46 +00:00
}
$supports_trash = EMPTY_TRASH_DAYS > 0 ;
/**
* Filter whether an item is trashable .
*
* Return false to disable trash support for the item .
*
* @ param boolean $supports_trash Whether the item type support trashing .
* @ param WP_Post $post The Post object being considered for trashing support .
*/
$supports_trash = apply_filters ( " woocommerce_rest_ { $this -> post_type } _trashable " , $supports_trash , $post );
2016-03-30 14:17:16 +00:00
if ( ! wc_rest_check_post_permissions ( $this -> post_type , 'delete' , $post -> ID ) ) {
2016-10-29 10:16:03 +00:00
/* translators: %s: post type */
2016-03-15 19:45:46 +00:00
return new WP_Error ( " woocommerce_rest_user_cannot_delete_ { $this -> post_type } " , sprintf ( __ ( 'Sorry, you are not allowed to delete %s.' , 'woocommerce' ), $this -> post_type ), array ( 'status' => rest_authorization_required_code () ) );
}
$request -> set_param ( 'context' , 'edit' );
$response = $this -> prepare_item_for_response ( $post , $request );
// If we're forcing, then delete permanently.
if ( $force ) {
$result = wp_delete_post ( $id , true );
} else {
// If we don't support trashing for this type, error out.
if ( ! $supports_trash ) {
2016-10-29 10:16:03 +00:00
/* translators: %s: post type */
2016-03-15 19:45:46 +00:00
return new WP_Error ( 'woocommerce_rest_trash_not_supported' , sprintf ( __ ( 'The %s does not support trashing.' , 'woocommerce' ), $this -> post_type ), array ( 'status' => 501 ) );
}
// Otherwise, only trash if we haven't already.
if ( 'trash' === $post -> post_status ) {
2016-10-29 10:16:03 +00:00
/* translators: %s: post type */
2016-03-15 19:45:46 +00:00
return new WP_Error ( 'woocommerce_rest_already_trashed' , sprintf ( __ ( 'The %s has already been deleted.' , 'woocommerce' ), $this -> post_type ), array ( 'status' => 410 ) );
}
// (Note that internally this falls through to `wp_delete_post` if
// the trash is disabled.)
$result = wp_trash_post ( $id );
}
if ( ! $result ) {
2016-10-29 10:16:03 +00:00
/* translators: %s: post type */
2016-03-15 19:45:46 +00:00
return new WP_Error ( 'woocommerce_rest_cannot_delete' , sprintf ( __ ( 'The %s cannot be deleted.' , 'woocommerce' ), $this -> post_type ), array ( 'status' => 500 ) );
}
/**
* Fires after a single item is deleted or trashed via the REST API .
*
* @ param object $post The deleted or trashed item .
* @ param WP_REST_Response $response The response data .
* @ param WP_REST_Request $request The request sent to the API .
*/
do_action ( " woocommerce_rest_delete_ { $this -> post_type } " , $post , $response , $request );
return $response ;
}
2016-03-15 19:55:41 +00:00
/**
* Prepare links for the request .
*
* @ param WP_Post $post Post object .
2016-09-29 16:24:01 +00:00
* @ param WP_REST_Request $request Request object .
2016-03-15 19:55:41 +00:00
* @ return array Links for the given post .
*/
2016-09-29 16:24:01 +00:00
protected function prepare_links ( $post , $request ) {
2016-03-15 19:55:41 +00:00
$links = array (
'self' => array (
'href' => rest_url ( sprintf ( '/%s/%s/%d' , $this -> namespace , $this -> rest_base , $post -> ID ) ),
),
'collection' => array (
'href' => rest_url ( sprintf ( '/%s/%s' , $this -> namespace , $this -> rest_base ) ),
),
);
return $links ;
}
2016-02-23 15:16:21 +00:00
/**
* Determine the allowed query_vars for a get_items () response and
* prepare for WP_Query .
*
* @ param array $prepared_args
* @ param WP_REST_Request $request
* @ return array $query_args
*/
protected function prepare_items_query ( $prepared_args = array (), $request = null ) {
$valid_vars = array_flip ( $this -> get_allowed_query_vars () );
$query_args = array ();
foreach ( $valid_vars as $var => $index ) {
if ( isset ( $prepared_args [ $var ] ) ) {
/**
* Filter the query_vars used in `get_items` for the constructed query .
*
* The dynamic portion of the hook name , $var , refers to the query_var key .
*
* @ param mixed $prepared_args [ $var ] The query_var value .
*
*/
$query_args [ $var ] = apply_filters ( " woocommerce_rest_query_var- { $var } " , $prepared_args [ $var ] );
}
}
$query_args [ 'ignore_sticky_posts' ] = true ;
if ( 'include' === $query_args [ 'orderby' ] ) {
$query_args [ 'orderby' ] = 'post__in' ;
2016-08-08 11:10:29 +00:00
} elseif ( 'id' === $query_args [ 'orderby' ] ) {
$query_args [ 'orderby' ] = 'ID' ; // ID must be capitalized
2016-02-23 15:16:21 +00:00
}
return $query_args ;
}
/**
* Get all the WP Query vars that are allowed for the API request .
*
* @ return array
*/
protected function get_allowed_query_vars () {
global $wp ;
/**
* Filter the publicly allowed query vars .
*
* Allows adjusting of the default query vars that are made public .
*
* @ param array Array of allowed WP_Query query vars .
*/
$valid_vars = apply_filters ( 'query_vars' , $wp -> public_query_vars );
$post_type_obj = get_post_type_object ( $this -> post_type );
if ( current_user_can ( $post_type_obj -> cap -> edit_posts ) ) {
/**
* Filter the allowed 'private' query vars for authorized users .
*
* If the user has the `edit_posts` capability , we also allow use of
* private query parameters , which are only undesirable on the
* frontend , but are safe for use in query strings .
*
* To disable anyway , use
* `add_filter( 'woocommerce_rest_private_query_vars', '__return_empty_array' );`
*
* @ param array $private_query_vars Array of allowed query vars for authorized users .
* }
*/
$private = apply_filters ( 'woocommerce_rest_private_query_vars' , $wp -> private_query_vars );
$valid_vars = array_merge ( $valid_vars , $private );
}
// Define our own in addition to WP's normal vars.
$rest_valid = array (
'date_query' ,
'ignore_sticky_posts' ,
'offset' ,
'post__in' ,
'post__not_in' ,
'post_parent' ,
'post_parent__in' ,
'post_parent__not_in' ,
'posts_per_page' ,
2016-03-30 22:11:56 +00:00
'meta_query' ,
2016-03-30 23:05:12 +00:00
'tax_query' ,
2016-07-25 12:12:37 +00:00
'meta_key' ,
'meta_value' ,
'meta_compare' ,
'meta_value_num' ,
2016-02-23 15:16:21 +00:00
);
$valid_vars = array_merge ( $valid_vars , $rest_valid );
/**
* Filter allowed query vars for the REST API .
*
* This filter allows you to add or remove query vars from the final allowed
* list for all requests , including unauthenticated ones . To alter the
* vars for editors only .
*
* @ param array {
* Array of allowed WP_Query query vars .
*
* @ param string $allowed_query_var The query var to allow .
* }
*/
$valid_vars = apply_filters ( 'woocommerce_rest_query_vars' , $valid_vars );
return $valid_vars ;
}
/**
* Get the query params for collections of attachments .
*
* @ return array
*/
public function get_collection_params () {
$params = parent :: get_collection_params ();
$params [ 'context' ][ 'default' ] = 'view' ;
$params [ 'after' ] = array (
'description' => __ ( 'Limit response to resources published after a given ISO8601 compliant date.' , 'woocommerce' ),
'type' => 'string' ,
'format' => 'date-time' ,
'validate_callback' => 'rest_validate_request_arg' ,
);
$params [ 'before' ] = array (
'description' => __ ( 'Limit response to resources published before a given ISO8601 compliant date.' , 'woocommerce' ),
'type' => 'string' ,
'format' => 'date-time' ,
'validate_callback' => 'rest_validate_request_arg' ,
);
$params [ 'exclude' ] = array (
2017-01-26 20:06:18 +00:00
'description' => __ ( 'Ensure result set excludes specific IDs.' , 'woocommerce' ),
'type' => 'array' ,
'items' => array (
'type' => 'integer' ,
),
'default' => array (),
'sanitize_callback' => 'wp_parse_id_list' ,
2016-02-23 15:16:21 +00:00
);
$params [ 'include' ] = array (
2017-01-26 20:06:18 +00:00
'description' => __ ( 'Limit result set to specific ids.' , 'woocommerce' ),
'type' => 'array' ,
'items' => array (
'type' => 'integer' ,
),
'default' => array (),
'sanitize_callback' => 'wp_parse_id_list' ,
2016-02-23 15:16:21 +00:00
);
$params [ 'offset' ] = array (
'description' => __ ( 'Offset the result set by a specific number of items.' , 'woocommerce' ),
'type' => 'integer' ,
'sanitize_callback' => 'absint' ,
'validate_callback' => 'rest_validate_request_arg' ,
);
$params [ 'order' ] = array (
'description' => __ ( 'Order sort attribute ascending or descending.' , 'woocommerce' ),
'type' => 'string' ,
'default' => 'desc' ,
'enum' => array ( 'asc' , 'desc' ),
'validate_callback' => 'rest_validate_request_arg' ,
);
$params [ 'orderby' ] = array (
'description' => __ ( 'Sort collection by object attribute.' , 'woocommerce' ),
'type' => 'string' ,
'default' => 'date' ,
'enum' => array (
'date' ,
'id' ,
'include' ,
'title' ,
'slug' ,
),
'validate_callback' => 'rest_validate_request_arg' ,
);
$post_type_obj = get_post_type_object ( $this -> post_type );
2017-01-26 20:06:18 +00:00
2016-06-20 20:29:56 +00:00
if ( isset ( $post_type_obj -> hierarchical ) && $post_type_obj -> hierarchical ) {
2016-02-23 15:16:21 +00:00
$params [ 'parent' ] = array (
2016-07-26 13:47:04 +00:00
'description' => __ ( 'Limit result set to those of particular parent IDs.' , 'woocommerce' ),
2016-02-23 15:16:21 +00:00
'type' => 'array' ,
2017-01-26 20:06:18 +00:00
'items' => array (
'type' => 'integer' ,
),
2016-02-23 15:16:21 +00:00
'sanitize_callback' => 'wp_parse_id_list' ,
'default' => array (),
);
$params [ 'parent_exclude' ] = array (
2016-07-26 13:47:04 +00:00
'description' => __ ( 'Limit result set to all items except those of a particular parent ID.' , 'woocommerce' ),
2016-02-23 15:16:21 +00:00
'type' => 'array' ,
2017-01-26 20:06:18 +00:00
'items' => array (
'type' => 'integer' ,
),
2016-02-23 15:16:21 +00:00
'sanitize_callback' => 'wp_parse_id_list' ,
'default' => array (),
);
}
2017-02-17 15:13:17 +00:00
if ( 'wc/v1' === $this -> namespace ) {
$params [ 'filter' ] = array (
'type' => 'object' ,
'description' => __ ( 'Use WP Query arguments to modify the response; private query vars require appropriate authorization.' , 'woocommerce' ),
);
}
2016-02-23 15:16:21 +00:00
return $params ;
}
2016-02-23 18:28:43 +00:00
/**
2016-03-15 19:45:46 +00:00
* Update post meta fields .
2016-02-23 18:28:43 +00:00
*
2016-03-15 19:45:46 +00:00
* @ param WP_Post $post
* @ param WP_REST_Request $request
* @ return bool | WP_Error
2016-02-23 18:28:43 +00:00
*/
2016-03-15 19:45:46 +00:00
protected function update_post_meta_fields ( $post , $request ) {
return true ;
2016-02-23 18:28:43 +00:00
}
2016-02-22 19:43:52 +00:00
}