REST API: Move the WP_Query args filter after the tax_query is setup.

This ensures that the entire list of `WP_Query` args are filterable in the posts controller.

Props Krstarica, TimothyBlynJacobs.
Fixes #42762.

Built from https://develop.svn.wordpress.org/trunk@49923


git-svn-id: http://core.svn.wordpress.org/trunk@49622 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
TimothyBlynJacobs 2021-01-03 02:39:11 +00:00
parent 4e3c568fb1
commit 7d4a40f4ee
2 changed files with 32 additions and 31 deletions

View File

@ -262,6 +262,36 @@ class WP_REST_Posts_Controller extends WP_REST_Controller {
} }
} }
$taxonomies = wp_list_filter( get_object_taxonomies( $this->post_type, 'objects' ), array( 'show_in_rest' => true ) );
if ( ! empty( $request['tax_relation'] ) ) {
$args['tax_query'] = array( 'relation' => $request['tax_relation'] );
}
foreach ( $taxonomies as $taxonomy ) {
$base = ! empty( $taxonomy->rest_base ) ? $taxonomy->rest_base : $taxonomy->name;
$tax_exclude = $base . '_exclude';
if ( ! empty( $request[ $base ] ) ) {
$args['tax_query'][] = array(
'taxonomy' => $taxonomy->name,
'field' => 'term_id',
'terms' => $request[ $base ],
'include_children' => false,
);
}
if ( ! empty( $request[ $tax_exclude ] ) ) {
$args['tax_query'][] = array(
'taxonomy' => $taxonomy->name,
'field' => 'term_id',
'terms' => $request[ $tax_exclude ],
'include_children' => false,
'operator' => 'NOT IN',
);
}
}
// Force the post_type argument, since it's not a user input variable. // Force the post_type argument, since it's not a user input variable.
$args['post_type'] = $this->post_type; $args['post_type'] = $this->post_type;
@ -279,6 +309,7 @@ class WP_REST_Posts_Controller extends WP_REST_Controller {
* Enables adding extra arguments or setting defaults for a post collection request. * Enables adding extra arguments or setting defaults for a post collection request.
* *
* @since 4.7.0 * @since 4.7.0
* @since 5.7.0 Moved after the `tax_query` query arg is generated.
* *
* @link https://developer.wordpress.org/reference/classes/wp_query/ * @link https://developer.wordpress.org/reference/classes/wp_query/
* *
@ -288,36 +319,6 @@ class WP_REST_Posts_Controller extends WP_REST_Controller {
$args = apply_filters( "rest_{$this->post_type}_query", $args, $request ); $args = apply_filters( "rest_{$this->post_type}_query", $args, $request );
$query_args = $this->prepare_items_query( $args, $request ); $query_args = $this->prepare_items_query( $args, $request );
$taxonomies = wp_list_filter( get_object_taxonomies( $this->post_type, 'objects' ), array( 'show_in_rest' => true ) );
if ( ! empty( $request['tax_relation'] ) ) {
$query_args['tax_query'] = array( 'relation' => $request['tax_relation'] );
}
foreach ( $taxonomies as $taxonomy ) {
$base = ! empty( $taxonomy->rest_base ) ? $taxonomy->rest_base : $taxonomy->name;
$tax_exclude = $base . '_exclude';
if ( ! empty( $request[ $base ] ) ) {
$query_args['tax_query'][] = array(
'taxonomy' => $taxonomy->name,
'field' => 'term_id',
'terms' => $request[ $base ],
'include_children' => false,
);
}
if ( ! empty( $request[ $tax_exclude ] ) ) {
$query_args['tax_query'][] = array(
'taxonomy' => $taxonomy->name,
'field' => 'term_id',
'terms' => $request[ $tax_exclude ],
'include_children' => false,
'operator' => 'NOT IN',
);
}
}
$posts_query = new WP_Query(); $posts_query = new WP_Query();
$query_result = $posts_query->query( $query_args ); $query_result = $posts_query->query( $query_args );

View File

@ -13,7 +13,7 @@
* *
* @global string $wp_version * @global string $wp_version
*/ */
$wp_version = '5.7-alpha-49922'; $wp_version = '5.7-alpha-49923';
/** /**
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema. * Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.