mirror of
https://github.com/WordPress/WordPress.git
synced 2024-12-22 17:18:32 +01:00
Use WP_Term_Query
when transforming tax queries.
This change allows tax query transformations to be cached. Props spacedmonkey. Fixes #37038. Built from https://develop.svn.wordpress.org/trunk@40918 git-svn-id: http://core.svn.wordpress.org/trunk@40768 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
3a190792ba
commit
f730861b90
@ -595,6 +595,9 @@ class WP_Tax_Query {
|
|||||||
/**
|
/**
|
||||||
* Transforms a single query, from one field to another.
|
* Transforms a single query, from one field to another.
|
||||||
*
|
*
|
||||||
|
* Operates on the `$query` object by reference. In the case of error,
|
||||||
|
* `$query` is converted to a WP_Error object.
|
||||||
|
*
|
||||||
* @since 3.2.0
|
* @since 3.2.0
|
||||||
*
|
*
|
||||||
* @global wpdb $wpdb The WordPress database abstraction object.
|
* @global wpdb $wpdb The WordPress database abstraction object.
|
||||||
@ -604,8 +607,6 @@ class WP_Tax_Query {
|
|||||||
* or 'term_id'. Default 'term_id'.
|
* or 'term_id'. Default 'term_id'.
|
||||||
*/
|
*/
|
||||||
public function transform_query( &$query, $resulting_field ) {
|
public function transform_query( &$query, $resulting_field ) {
|
||||||
global $wpdb;
|
|
||||||
|
|
||||||
if ( empty( $query['terms'] ) )
|
if ( empty( $query['terms'] ) )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -614,57 +615,52 @@ class WP_Tax_Query {
|
|||||||
|
|
||||||
$resulting_field = sanitize_key( $resulting_field );
|
$resulting_field = sanitize_key( $resulting_field );
|
||||||
|
|
||||||
switch ( $query['field'] ) {
|
// Empty 'terms' always results in a null transformation.
|
||||||
case 'slug':
|
$terms = array_filter( $query['terms'] );
|
||||||
case 'name':
|
if ( empty( $terms ) ) {
|
||||||
foreach ( $query['terms'] as &$term ) {
|
$query['terms'] = array();
|
||||||
/*
|
$query['field'] = $resulting_field;
|
||||||
* 0 is the $term_id parameter. We don't have a term ID yet, but it doesn't
|
return;
|
||||||
* matter because `sanitize_term_field()` ignores the $term_id param when the
|
|
||||||
* context is 'db'.
|
|
||||||
*/
|
|
||||||
$clean_term = sanitize_term_field( $query['field'], $term, 0, $query['taxonomy'], 'db' );
|
|
||||||
|
|
||||||
// Match sanitization in wp_insert_term().
|
|
||||||
$clean_term = wp_unslash( $clean_term );
|
|
||||||
|
|
||||||
$term = "'" . esc_sql( $clean_term ) . "'";
|
|
||||||
}
|
|
||||||
|
|
||||||
$terms = implode( ",", $query['terms'] );
|
|
||||||
|
|
||||||
$terms = $wpdb->get_col( "
|
|
||||||
SELECT $wpdb->term_taxonomy.$resulting_field
|
|
||||||
FROM $wpdb->term_taxonomy
|
|
||||||
INNER JOIN $wpdb->terms USING (term_id)
|
|
||||||
WHERE taxonomy = '{$query['taxonomy']}'
|
|
||||||
AND $wpdb->terms.{$query['field']} IN ($terms)
|
|
||||||
" );
|
|
||||||
break;
|
|
||||||
case 'term_taxonomy_id':
|
|
||||||
$terms = implode( ',', array_map( 'intval', $query['terms'] ) );
|
|
||||||
$terms = $wpdb->get_col( "
|
|
||||||
SELECT $resulting_field
|
|
||||||
FROM $wpdb->term_taxonomy
|
|
||||||
WHERE term_taxonomy_id IN ($terms)
|
|
||||||
" );
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
$terms = implode( ',', array_map( 'intval', $query['terms'] ) );
|
|
||||||
$terms = $wpdb->get_col( "
|
|
||||||
SELECT $resulting_field
|
|
||||||
FROM $wpdb->term_taxonomy
|
|
||||||
WHERE taxonomy = '{$query['taxonomy']}'
|
|
||||||
AND term_id IN ($terms)
|
|
||||||
" );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( 'AND' == $query['operator'] && count( $terms ) < count( $query['terms'] ) ) {
|
$args = array(
|
||||||
|
'get' => 'all',
|
||||||
|
'number' => 0,
|
||||||
|
'taxonomy' => $query['taxonomy'],
|
||||||
|
'update_term_meta_cache' => false,
|
||||||
|
'orderby' => 'none',
|
||||||
|
);
|
||||||
|
|
||||||
|
// Term query parameter name depends on the 'field' being searched on.
|
||||||
|
switch ( $query['field'] ) {
|
||||||
|
case 'slug':
|
||||||
|
$args['slug'] = $terms;
|
||||||
|
break;
|
||||||
|
case 'name':
|
||||||
|
$args['name'] = $terms;
|
||||||
|
break;
|
||||||
|
case 'term_taxonomy_id':
|
||||||
|
$args['term_taxonomy_id'] = $terms;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
$args['include'] = wp_parse_id_list( $terms );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
$term_query = new WP_Term_Query();
|
||||||
|
$term_list = $term_query->query( $args );
|
||||||
|
|
||||||
|
if ( is_wp_error( $term_list ) ) {
|
||||||
|
$query = $term_list;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( 'AND' == $query['operator'] && count( $term_list ) < count( $query['terms'] ) ) {
|
||||||
$query = new WP_Error( 'inexistent_terms', __( 'Inexistent terms.' ) );
|
$query = new WP_Error( 'inexistent_terms', __( 'Inexistent terms.' ) );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$query['terms'] = $terms;
|
$query['terms'] = wp_list_pluck( $term_list, $resulting_field );
|
||||||
$query['field'] = $resulting_field;
|
$query['field'] = $resulting_field;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '4.9-alpha-40917';
|
$wp_version = '4.9-alpha-40918';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 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.
|
||||||
|
Loading…
Reference in New Issue
Block a user