Make WordPress Core

Ticket #17065: 17065.3.diff

File 17065.3.diff, 7.0 KB (added by wonderboymusic, 11 years ago)
  • src/wp-includes/functions.php

     
    35053505 * Determine if the scheme of the given URL is https.
    35063506 *
    35073507 * @since 4.0.0
    3508  * 
     3508 *
    35093509 * @param  string  $url The URL
    35103510 * @return bool True if the given URL uses https, false if not (or if the URL is not valid).
    35113511 */
     
    46344634                return $var;
    46354635        }
    46364636
    4637         if ( 'false' === $var ) {
     4637        if ( in_array( $var, array( 'off', 'no', 'false' ) ) ) {
    46384638                return false;
    46394639        }
    46404640
  • src/wp-includes/query.php

     
    22002200        }
    22012201
    22022202        /**
     2203         * If the passed orderby value is allowed, convert the alias to a properly-prefixed orderby value
     2204         *
     2205         * @since 4.0.0
     2206         *
     2207         * @global wpdb $wpdb
     2208         * @param string $orderby Alias for the field to order by.
     2209         * @return string Table-prefixed value to used in the ORDER clause.
     2210         */
     2211        protected function parse_orderby( $orderby ) {
     2212                global $wpdb;
     2213
     2214                // Used to filter values
     2215                $allowed_keys = array( 'name', 'author', 'date', 'title', 'modified', 'menu_order', 'parent', 'ID', 'rand', 'comment_count', 'type' );
     2216                $meta_key = $this->get( 'meta_key' );
     2217                if ( ! empty( $meta_key ) ) {
     2218                        $allowed_keys[] = $meta_key;
     2219                        $allowed_keys[] = 'meta_value';
     2220                        $allowed_keys[] = 'meta_value_num';
     2221                }
     2222
     2223                if ( ! in_array( $orderby, $allowed_keys ) ) {
     2224                        return;
     2225                }
     2226
     2227                switch ( $orderby ) {
     2228                        case 'menu_order':
     2229                                $orderby = "$wpdb->posts.menu_order";
     2230                                break;
     2231                        case 'ID':
     2232                                $orderby = "$wpdb->posts.ID";
     2233                                break;
     2234                        case 'rand':
     2235                                $orderby = 'RAND()';
     2236                                break;
     2237                        case $meta_key:
     2238                        case 'meta_value':
     2239                                $type = $this->get( 'meta_type' );
     2240                                if ( ! empty( $type ) ) {
     2241                                        $meta_type = $this->meta_query->get_cast_for_type( $type );
     2242                                        $orderby = "CAST($wpdb->postmeta.meta_value AS {$meta_type})";
     2243                                } else {
     2244                                        $orderby = "$wpdb->postmeta.meta_value";
     2245                                }
     2246                                break;
     2247                        case 'meta_value_num':
     2248                                $orderby = "$wpdb->postmeta.meta_value+0";
     2249                                break;
     2250                        case 'comment_count':
     2251                                $orderby = "$wpdb->posts.comment_count";
     2252                                break;
     2253                        default:
     2254                                $orderby = "$wpdb->posts.post_" . $orderby;
     2255                }
     2256
     2257                return $orderby;
     2258        }
     2259
     2260        /**
    22032261         * Sets the 404 property and saves whether query is feed.
    22042262         *
    22052263         * @since 2.0.0
     
    27062764                        $q['order'] = 'DESC';
    27072765
    27082766                // Order by
    2709                 if ( empty($q['orderby']) ) {
    2710                         $orderby = "$wpdb->posts.post_date " . $q['order'];
     2767                if ( empty( $q['orderby'] ) ) {
     2768                        // A deliberate empty array blanks out ORDER BY,
     2769                        // while leaving the value unset or otherwise empty sets the default.
     2770                        if ( isset( $q['orderby'] ) && ( false === wp_validate_boolean( $q['orderby'] ) || is_array( $q['orderby'] ) ) ) {
     2771                                $orderby = '';
     2772                        } else {
     2773                                $orderby = "$wpdb->posts.post_date " . $q['order'];
     2774                        }
    27112775                } elseif ( 'none' == $q['orderby'] ) {
    27122776                        $orderby = '';
    27132777                } elseif ( $q['orderby'] == 'post__in' && ! empty( $post__in ) ) {
     
    27152779                } elseif ( $q['orderby'] == 'post_parent__in' && ! empty( $post_parent__in ) ) {
    27162780                        $orderby = "FIELD( {$wpdb->posts}.post_parent, $post_parent__in )";
    27172781                } else {
    2718                         // Used to filter values
    2719                         $allowed_keys = array( 'name', 'author', 'date', 'title', 'modified', 'menu_order', 'parent', 'ID', 'rand', 'comment_count', 'type' );
    2720                         if ( !empty($q['meta_key']) ) {
    2721                                 $allowed_keys[] = $q['meta_key'];
    2722                                 $allowed_keys[] = 'meta_value';
    2723                                 $allowed_keys[] = 'meta_value_num';
    2724                         }
    2725                         $q['orderby'] = urldecode($q['orderby']);
    2726                         $q['orderby'] = addslashes_gpc($q['orderby']);
    2727 
    27282782                        $orderby_array = array();
    2729                         foreach ( explode( ' ', $q['orderby'] ) as $i => $orderby ) {
    2730                                 // Only allow certain values for safety
    2731                                 if ( ! in_array($orderby, $allowed_keys) )
    2732                                         continue;
     2783                        if ( is_array( $q['orderby'] ) ) {
     2784                                foreach ( $q['orderby'] as $_orderby => $order ) {
     2785                                        $orderby = addslashes_gpc( urldecode( $_orderby ) );
     2786                                        $parsed = $this->parse_orderby( $orderby );
     2787                                        if ( ! $parsed ) {
     2788                                                continue;
     2789                                        }
     2790                                        $orderby_array[] = implode( ' ', array( $parsed, $order ) );
     2791                                }
     2792                                $orderby = implode( ', ', $orderby_array );
     2793                        } else {
     2794                                $q['orderby'] = urldecode($q['orderby']);
     2795                                $q['orderby'] = addslashes_gpc($q['orderby']);
    27332796
    2734                                 switch ( $orderby ) {
    2735                                         case 'menu_order':
    2736                                                 $orderby = "$wpdb->posts.menu_order";
    2737                                                 break;
    2738                                         case 'ID':
    2739                                                 $orderby = "$wpdb->posts.ID";
    2740                                                 break;
    2741                                         case 'rand':
    2742                                                 $orderby = 'RAND()';
    2743                                                 break;
    2744                                         case $q['meta_key']:
    2745                                         case 'meta_value':
    2746                                                 if ( isset( $q['meta_type'] ) ) {
    2747                                                         $meta_type = $this->meta_query->get_cast_for_type( $q['meta_type'] );
    2748                                                         $orderby = "CAST($wpdb->postmeta.meta_value AS {$meta_type})";
    2749                                                 } else {
    2750                                                         $orderby = "$wpdb->postmeta.meta_value";
    2751                                                 }
    2752                                                 break;
    2753                                         case 'meta_value_num':
    2754                                                 $orderby = "$wpdb->postmeta.meta_value+0";
    2755                                                 break;
    2756                                         case 'comment_count':
    2757                                                 $orderby = "$wpdb->posts.comment_count";
    2758                                                 break;
    2759                                         default:
    2760                                                 $orderby = "$wpdb->posts.post_" . $orderby;
     2797                                foreach ( explode( ' ', $q['orderby'] ) as $i => $orderby ) {
     2798                                        $parsed = $this->parse_orderby( $orderby );
     2799                                        // Only allow certain values for safety
     2800                                        if ( ! $parsed ) {
     2801                                                continue;
     2802                                        }
     2803
     2804                                        $orderby_array[] = $parsed;
    27612805                                }
     2806                                $orderby = implode( ' ' . $q['order'] . ', ', $orderby_array );
    27622807
    2763                                 $orderby_array[] = $orderby;
     2808                                if ( empty( $orderby ) )
     2809                                        $orderby = "$wpdb->posts.post_date ".$q['order'];
     2810                                else
     2811                                        $orderby .= " {$q['order']}";
    27642812                        }
    2765                         $orderby = implode( ' ' . $q['order'] . ', ', $orderby_array );
    2766 
    2767                         if ( empty( $orderby ) )
    2768                                 $orderby = "$wpdb->posts.post_date ".$q['order'];
    2769                         else
    2770                                 $orderby .= " {$q['order']}";
    27712813                }
    27722814
    27732815                // Order search results by relevance only when another "orderby" is not specified in the query.
  • tests/phpunit/tests/post/query.php

     
    761761                $q3 = new WP_Query( array( 'post_status' => array( 'any', 'auto-draft' ) ) );
    762762                $this->assertNotContains( "post_status <> 'auto-draft'", $q3->request );
    763763        }
     764
     765        /**
     766         *
     767         * @ticket 17065
     768         */
     769        function test_orderby_array() {
     770                global $wpdb;
     771
     772                $q1 = new WP_Query( array(
     773                        'orderby' => array(
     774                                'type' => 'DESC',
     775                                'name' => 'ASC'
     776                        )
     777                ) );
     778                $this->assertContains(
     779                        "ORDER BY $wpdb->posts.post_type DESC, $wpdb->posts.post_name ASC",
     780                        $q1->request
     781                );
     782
     783                $q2 = new WP_Query( array( 'orderby' => array() ) );
     784                $this->assertNotContains( 'ORDER BY', $q2->request );
     785                $this->assertNotContains( 'ORDER', $q2->request );
     786
     787                $q3 = new WP_Query( array( 'post_type' => 'post' ) );
     788                $this->assertContains(
     789                        "ORDER BY $wpdb->posts.post_date DESC",
     790                        $q3->request
     791                );
     792        }
    764793}
     794 No newline at end of file