Users: The 'who' parameter should not interfere with 'meta_key' + 'meta_value' in WP_User_Query
.
Props adrianosilvaferreira. Fixes #36724. git-svn-id: https://develop.svn.wordpress.org/trunk@37360 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
e415270afb
commit
f3ccef62be
@ -255,13 +255,6 @@ class WP_User_Query {
|
|||||||
$blog_id = absint( $qv['blog_id'] );
|
$blog_id = absint( $qv['blog_id'] );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( isset( $qv['who'] ) && 'authors' == $qv['who'] && $blog_id ) {
|
|
||||||
$qv['meta_key'] = $wpdb->get_blog_prefix( $blog_id ) . 'user_level';
|
|
||||||
$qv['meta_value'] = 0;
|
|
||||||
$qv['meta_compare'] = '!=';
|
|
||||||
$qv['blog_id'] = $blog_id = 0; // Prevent extra meta query
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( $qv['has_published_posts'] && $blog_id ) {
|
if ( $qv['has_published_posts'] && $blog_id ) {
|
||||||
if ( true === $qv['has_published_posts'] ) {
|
if ( true === $qv['has_published_posts'] ) {
|
||||||
$post_types = get_post_types( array( 'public' => true ) );
|
$post_types = get_post_types( array( 'public' => true ) );
|
||||||
@ -281,6 +274,29 @@ class WP_User_Query {
|
|||||||
$this->meta_query = new WP_Meta_Query();
|
$this->meta_query = new WP_Meta_Query();
|
||||||
$this->meta_query->parse_query_vars( $qv );
|
$this->meta_query->parse_query_vars( $qv );
|
||||||
|
|
||||||
|
if ( isset( $qv['who'] ) && 'authors' == $qv['who'] && $blog_id ) {
|
||||||
|
$who_query = array(
|
||||||
|
'key' => $wpdb->get_blog_prefix( $blog_id ) . 'user_level',
|
||||||
|
'value' => 0,
|
||||||
|
'compare' => '!=',
|
||||||
|
);
|
||||||
|
|
||||||
|
// Prevent extra meta query.
|
||||||
|
$qv['blog_id'] = $blog_id = 0;
|
||||||
|
|
||||||
|
if ( empty( $this->meta_query->queries ) ) {
|
||||||
|
$this->meta_query->queries = array( $who_query );
|
||||||
|
} else {
|
||||||
|
// Append the cap query to the original queries and reparse the query.
|
||||||
|
$this->meta_query->queries = array(
|
||||||
|
'relation' => 'AND',
|
||||||
|
array( $this->meta_query->queries, $who_query ),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->meta_query->parse_query_vars( $this->meta_query->queries );
|
||||||
|
}
|
||||||
|
|
||||||
$roles = array();
|
$roles = array();
|
||||||
if ( isset( $qv['role'] ) ) {
|
if ( isset( $qv['role'] ) ) {
|
||||||
if ( is_array( $qv['role'] ) ) {
|
if ( is_array( $qv['role'] ) ) {
|
||||||
|
@ -702,6 +702,37 @@ class Tests_User_Query extends WP_UnitTestCase {
|
|||||||
$this->assertNotContains( self::$author_ids[2], $found );
|
$this->assertNotContains( self::$author_ids[2], $found );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ticket 36724
|
||||||
|
*/
|
||||||
|
public function test_who_authors_should_work_alongside_meta_params() {
|
||||||
|
if ( ! is_multisite() ) {
|
||||||
|
$this->markTestSkipped( __METHOD__ . ' requires multisite.' );
|
||||||
|
}
|
||||||
|
|
||||||
|
$b = self::factory()->blog->create();
|
||||||
|
|
||||||
|
add_user_to_blog( $b, self::$author_ids[0], 'subscriber' );
|
||||||
|
add_user_to_blog( $b, self::$author_ids[1], 'author' );
|
||||||
|
add_user_to_blog( $b, self::$author_ids[2], 'editor' );
|
||||||
|
|
||||||
|
add_user_meta( self::$author_ids[1], 'foo', 'bar' );
|
||||||
|
add_user_meta( self::$author_ids[2], 'foo', 'baz' );
|
||||||
|
|
||||||
|
$q = new WP_User_Query( array(
|
||||||
|
'who' => 'authors',
|
||||||
|
'blog_id' => $b,
|
||||||
|
'meta_key' => 'foo',
|
||||||
|
'meta_value' => 'bar',
|
||||||
|
) );
|
||||||
|
|
||||||
|
$found = wp_list_pluck( $q->get_results(), 'ID' );
|
||||||
|
|
||||||
|
$this->assertNotContains( self::$author_ids[0], $found );
|
||||||
|
$this->assertContains( self::$author_ids[1], $found );
|
||||||
|
$this->assertNotContains( self::$author_ids[2], $found );
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @ticket 32250
|
* @ticket 32250
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user