2004-06-30 17:31:49 +02:00
< ? php
2004-08-08 17:31:50 +02:00
class WP_Query {
2004-09-05 22:00:09 +02:00
var $query ;
var $query_vars ;
2004-10-02 21:24:40 +02:00
var $queried_object ;
var $queried_object_id ;
2006-01-11 12:06:26 +01:00
var $request ;
2004-09-05 22:00:09 +02:00
var $posts ;
var $post_count = 0 ;
var $current_post = - 1 ;
2005-07-17 18:58:13 +02:00
var $in_the_loop = false ;
2004-09-05 22:00:09 +02:00
var $post ;
var $is_single = false ;
2005-11-06 08:04:46 +01:00
var $is_preview = false ;
2004-09-05 22:00:09 +02:00
var $is_page = false ;
var $is_archive = false ;
var $is_date = false ;
var $is_year = false ;
var $is_month = false ;
var $is_day = false ;
var $is_time = false ;
var $is_author = false ;
var $is_category = false ;
var $is_search = false ;
var $is_feed = false ;
2004-12-18 01:28:24 +01:00
var $is_trackback = false ;
2004-09-05 22:00:09 +02:00
var $is_home = false ;
var $is_404 = false ;
2005-02-14 10:17:23 +01:00
var $is_comments_popup = false ;
2004-12-26 17:37:55 +01:00
var $is_admin = false ;
2005-11-15 23:55:24 +01:00
var $is_attachment = false ;
2004-09-05 22:00:09 +02:00
2005-09-16 05:16:12 +02:00
function init_query_flags () {
2004-09-05 22:00:09 +02:00
$this -> is_single = false ;
$this -> is_page = false ;
$this -> is_archive = false ;
$this -> is_date = false ;
$this -> is_year = false ;
$this -> is_month = false ;
$this -> is_day = false ;
$this -> is_time = false ;
$this -> is_author = false ;
$this -> is_category = false ;
$this -> is_search = false ;
$this -> is_feed = false ;
2004-12-18 01:28:24 +01:00
$this -> is_trackback = false ;
2004-09-05 22:00:09 +02:00
$this -> is_home = false ;
$this -> is_404 = false ;
2004-11-20 19:32:31 +01:00
$this -> is_paged = false ;
2004-12-26 17:37:55 +01:00
$this -> is_admin = false ;
2005-11-15 23:55:24 +01:00
$this -> is_attachment = false ;
2005-09-16 05:16:12 +02:00
}
2006-02-12 08:53:23 +01:00
2005-09-16 05:16:12 +02:00
function init () {
2004-09-05 22:00:09 +02:00
unset ( $this -> posts );
unset ( $this -> query );
unset ( $this -> query_vars );
2004-10-02 21:24:40 +02:00
unset ( $this -> queried_object );
unset ( $this -> queried_object_id );
2004-09-05 22:00:09 +02:00
$this -> post_count = 0 ;
$this -> current_post = - 1 ;
2005-07-17 18:58:13 +02:00
$this -> in_the_loop = false ;
2006-02-12 08:53:23 +01:00
2005-09-16 05:16:12 +02:00
$this -> init_query_flags ();
2004-09-05 22:00:09 +02:00
}
2005-02-01 09:34:19 +01:00
// Reparse the query vars.
function parse_query_vars () {
$this -> parse_query ( '' );
}
// Parse a query string and set query type booleans.
2004-09-05 22:00:09 +02:00
function parse_query ( $query ) {
2005-02-01 09:34:19 +01:00
if ( ! empty ( $query ) || ! isset ( $this -> query ) ) {
$this -> init ();
parse_str ( $query , $qv );
$this -> query = $query ;
$this -> query_vars = $qv ;
}
2005-09-16 05:16:12 +02:00
if ( '404' == $qv [ 'error' ]) {
$this -> is_404 = true ;
if ( ! empty ( $query ) ) {
do_action ( 'parse_query' , array ( & $this ));
}
return ;
}
2004-12-12 21:41:19 +01:00
$qv [ 'm' ] = ( int ) $qv [ 'm' ];
2004-12-30 12:08:42 +01:00
$qv [ 'p' ] = ( int ) $qv [ 'p' ];
2004-09-05 22:00:09 +02:00
2005-11-15 23:55:24 +01:00
// Compat. Map subpost to attachment.
if ( '' != $qv [ 'subpost' ] )
$qv [ 'attachment' ] = $qv [ 'subpost' ];
if ( '' != $qv [ 'subpost_id' ] )
$qv [ 'attachment_id' ] = $qv [ 'subpost_id' ];
2006-02-12 08:53:23 +01:00
2005-12-13 20:19:56 +01:00
if ( ( '' != $qv [ 'attachment' ]) || ( int ) $qv [ 'attachment_id' ] ) {
2005-10-20 22:48:32 +02:00
$this -> is_single = true ;
2005-11-15 23:55:24 +01:00
$this -> is_attachment = true ;
2005-12-13 20:19:56 +01:00
} elseif ( '' != $qv [ 'name' ]) {
2004-09-05 22:00:09 +02:00
$this -> is_single = true ;
2005-02-01 02:49:51 +01:00
} elseif ( $qv [ 'p' ] ) {
2004-12-30 12:08:42 +01:00
$this -> is_single = true ;
2004-12-30 11:58:06 +01:00
} elseif (( '' != $qv [ 'hour' ]) && ( '' != $qv [ 'minute' ]) && ( '' != $qv [ 'second' ]) && ( '' != $qv [ 'year' ]) && ( '' != $qv [ 'monthnum' ]) && ( '' != $qv [ 'day' ])) {
2004-12-18 01:28:24 +01:00
// If year, month, day, hour, minute, and second are set, a single
2005-10-20 22:48:32 +02:00
// post is being queried.
2004-12-18 01:28:24 +01:00
$this -> is_single = true ;
2004-12-30 11:58:06 +01:00
} elseif ( '' != $qv [ 'static' ] || '' != $qv [ 'pagename' ] || '' != $qv [ 'page_id' ]) {
2004-10-08 10:06:21 +02:00
$this -> is_page = true ;
$this -> is_single = false ;
2004-12-30 11:58:06 +01:00
} elseif ( ! empty ( $qv [ 's' ])) {
2004-12-18 01:28:24 +01:00
$this -> is_search = true ;
} else {
2004-12-30 12:10:00 +01:00
// Look for archive queries. Dates, categories, authors.
2004-09-05 22:00:09 +02:00
2004-12-18 01:28:24 +01:00
if ( ( int ) $qv [ 'second' ]) {
$this -> is_time = true ;
2004-09-05 22:00:09 +02:00
$this -> is_date = true ;
}
2004-12-18 01:28:24 +01:00
if ( ( int ) $qv [ 'minute' ]) {
$this -> is_time = true ;
2004-09-05 22:00:09 +02:00
$this -> is_date = true ;
}
2004-12-18 01:28:24 +01:00
if ( ( int ) $qv [ 'hour' ]) {
$this -> is_time = true ;
2004-09-05 22:00:09 +02:00
$this -> is_date = true ;
}
2004-12-18 01:28:24 +01:00
if ( ( int ) $qv [ 'day' ]) {
if ( ! $this -> is_date ) {
$this -> is_day = true ;
$this -> is_date = true ;
}
2004-12-12 21:41:19 +01:00
}
2004-09-05 22:00:09 +02:00
2004-12-18 01:28:24 +01:00
if ( ( int ) $qv [ 'monthnum' ]) {
if ( ! $this -> is_date ) {
$this -> is_month = true ;
$this -> is_date = true ;
}
}
2004-09-05 22:00:09 +02:00
2004-12-18 01:28:24 +01:00
if ( ( int ) $qv [ 'year' ]) {
if ( ! $this -> is_date ) {
$this -> is_year = true ;
$this -> is_date = true ;
}
}
2004-09-05 22:00:09 +02:00
2004-12-18 01:28:24 +01:00
if ( ( int ) $qv [ 'm' ]) {
$this -> is_date = true ;
if ( strlen ( $qv [ 'm' ]) > 9 ) {
$this -> is_time = true ;
} else if ( strlen ( $qv [ 'm' ]) > 7 ) {
$this -> is_day = true ;
} else if ( strlen ( $qv [ 'm' ]) > 5 ) {
$this -> is_month = true ;
} else {
$this -> is_year = true ;
}
}
2004-09-05 22:00:09 +02:00
2004-12-18 01:28:24 +01:00
if ( '' != $qv [ 'w' ]) {
$this -> is_date = true ;
}
2005-02-01 02:49:51 +01:00
if ( empty ( $qv [ 'cat' ]) || ( $qv [ 'cat' ] == '0' )) {
2004-09-05 22:00:09 +02:00
$this -> is_category = false ;
} else {
2004-12-18 01:28:24 +01:00
if ( stristr ( $qv [ 'cat' ], '-' )) {
$this -> is_category = false ;
} else {
$this -> is_category = true ;
}
2004-09-05 22:00:09 +02:00
}
2004-12-18 01:28:24 +01:00
if ( '' != $qv [ 'category_name' ]) {
$this -> is_category = true ;
}
2004-07-28 03:59:29 +02:00
2005-02-01 02:49:51 +01:00
if (( empty ( $qv [ 'author' ])) || ( $qv [ 'author' ] == '0' )) {
2004-12-18 01:28:24 +01:00
$this -> is_author = false ;
} else {
$this -> is_author = true ;
}
2004-09-05 22:00:09 +02:00
2004-12-18 01:28:24 +01:00
if ( '' != $qv [ 'author_name' ]) {
$this -> is_author = true ;
}
2004-09-05 22:00:09 +02:00
2004-12-18 01:28:24 +01:00
if ( ( $this -> is_date || $this -> is_author || $this -> is_category )) {
$this -> is_archive = true ;
}
2004-09-05 22:00:09 +02:00
}
if ( '' != $qv [ 'feed' ]) {
$this -> is_feed = true ;
}
2004-12-18 01:28:24 +01:00
if ( '' != $qv [ 'tb' ]) {
$this -> is_trackback = true ;
}
2004-11-20 19:32:31 +01:00
if ( '' != $qv [ 'paged' ]) {
$this -> is_paged = true ;
}
2005-02-14 10:17:23 +01:00
if ( '' != $qv [ 'comments_popup' ]) {
$this -> is_comments_popup = true ;
}
2006-02-12 08:53:23 +01:00
2006-01-24 00:39:56 +01:00
//if we're previewing inside the write screen
if ( '' != $qv [ 'preview' ]) {
$this -> is_preview = true ;
}
2005-02-14 10:17:23 +01:00
2004-12-26 17:37:55 +01:00
if ( strstr ( $_SERVER [ 'PHP_SELF' ], 'wp-admin/' )) {
$this -> is_admin = true ;
}
2005-11-15 23:55:24 +01:00
if ( ! ( $this -> is_attachment || $this -> is_archive || $this -> is_single || $this -> is_page || $this -> is_search || $this -> is_feed || $this -> is_trackback || $this -> is_404 || $this -> is_admin || $this -> is_comments_popup )) {
2004-09-05 22:00:09 +02:00
$this -> is_home = true ;
}
2005-02-01 09:34:19 +01:00
if ( ! empty ( $query ) ) {
do_action ( 'parse_query' , array ( & $this ));
}
2004-08-08 17:31:50 +02:00
}
2005-09-16 05:16:12 +02:00
function set_404 () {
$this -> init_query_flags ();
2006-02-12 08:53:23 +01:00
$this -> is_404 = true ;
2005-09-16 05:16:12 +02:00
}
2006-02-12 08:53:23 +01:00
2004-09-05 22:00:09 +02:00
function get ( $query_var ) {
if ( isset ( $this -> query_vars [ $query_var ])) {
return $this -> query_vars [ $query_var ];
}
2004-08-08 17:31:50 +02:00
2004-09-05 22:00:09 +02:00
return '' ;
}
2004-08-10 07:35:59 +02:00
2005-02-01 02:04:08 +01:00
function set ( $query_var , $value ) {
$this -> query_vars [ $query_var ] = $value ;
}
2005-03-27 22:45:01 +02:00
function & get_posts () {
2006-01-11 12:06:26 +01:00
global $wpdb , $pagenow , $user_ID ;
2004-09-05 22:00:09 +02:00
2005-10-06 19:27:57 +02:00
do_action ( 'pre_get_posts' , array ( & $this ));
2004-09-05 22:00:09 +02:00
// Shorthand.
2006-02-12 09:14:10 +01:00
$q = & $this -> query_vars ;
2004-09-05 22:00:09 +02:00
// First let's clear some variables
$whichcat = '' ;
$whichauthor = '' ;
2005-11-29 02:43:32 +01:00
$whichpage = '' ;
2004-09-05 22:00:09 +02:00
$result = '' ;
$where = '' ;
$limits = '' ;
$distinct = '' ;
$join = '' ;
2006-02-21 09:39:58 +01:00
if ( ! isset ( $q [ 'post_type' ]) )
$q [ 'post_type' ] = 'post' ;
$post_type = $q [ 'post_type' ];
2004-09-05 22:00:09 +02:00
if ( ! isset ( $q [ 'posts_per_page' ]) || $q [ 'posts_per_page' ] == 0 )
$q [ 'posts_per_page' ] = get_settings ( 'posts_per_page' );
if ( ! isset ( $q [ 'what_to_show' ]) )
$q [ 'what_to_show' ] = get_settings ( 'what_to_show' );
if ( isset ( $q [ 'showposts' ]) && $q [ 'showposts' ] ) {
$q [ 'showposts' ] = ( int ) $q [ 'showposts' ];
$q [ 'posts_per_page' ] = $q [ 'showposts' ];
}
2005-02-13 20:45:04 +01:00
if ( ( isset ( $q [ 'posts_per_archive_page' ]) && $q [ 'posts_per_archive_page' ] != 0 ) && ( $this -> is_archive || $this -> is_search ) )
2004-10-28 01:58:40 +02:00
$q [ 'posts_per_page' ] = $q [ 'posts_per_archive_page' ];
if ( ! isset ( $q [ 'nopaging' ]) ) {
if ( $q [ 'posts_per_page' ] == - 1 ) {
$q [ 'nopaging' ] = true ;
} else {
$q [ 'nopaging' ] = false ;
}
}
2005-03-23 22:39:22 +01:00
if ( $this -> is_feed ) {
2005-02-13 20:42:22 +01:00
$q [ 'posts_per_page' ] = get_settings ( 'posts_per_rss' );
2005-03-23 22:39:22 +01:00
$q [ 'what_to_show' ] = 'posts' ;
}
2005-04-14 06:24:22 +02:00
2006-03-01 08:08:04 +01:00
if ( $this -> is_home && ( 'page' == get_option ( 'show_on_front' ) ) && get_option ( 'page_on_front' ) ) {
$this -> is_page = true ;
$this -> is_home = false ;
$q [ 'page_id' ] = get_option ( 'page_on_front' );
}
2005-04-14 06:24:22 +02:00
if ( isset ( $q [ 'page' ])) {
$q [ 'page' ] = trim ( $q [ 'page' ], '/' );
$q [ 'page' ] = ( int ) $q [ 'page' ];
}
2006-02-12 08:53:23 +01:00
2004-09-05 22:00:09 +02:00
$add_hours = intval ( get_settings ( 'gmt_offset' ));
$add_minutes = intval ( 60 * ( get_settings ( 'gmt_offset' ) - $add_hours ));
$wp_posts_post_date_field = " post_date " ; // "DATE_ADD(post_date, INTERVAL '$add_hours:$add_minutes' HOUR_MINUTE)";
// If a month is specified in the querystring, load that month
2004-12-12 21:41:19 +01:00
if ( ( int ) $q [ 'm' ] ) {
2004-09-05 22:00:09 +02:00
$q [ 'm' ] = '' . preg_replace ( '|[^0-9]|' , '' , $q [ 'm' ]);
$where .= ' AND YEAR(post_date)=' . substr ( $q [ 'm' ], 0 , 4 );
if ( strlen ( $q [ 'm' ]) > 5 )
$where .= ' AND MONTH(post_date)=' . substr ( $q [ 'm' ], 4 , 2 );
if ( strlen ( $q [ 'm' ]) > 7 )
$where .= ' AND DAYOFMONTH(post_date)=' . substr ( $q [ 'm' ], 6 , 2 );
if ( strlen ( $q [ 'm' ]) > 9 )
$where .= ' AND HOUR(post_date)=' . substr ( $q [ 'm' ], 8 , 2 );
if ( strlen ( $q [ 'm' ]) > 11 )
$where .= ' AND MINUTE(post_date)=' . substr ( $q [ 'm' ], 10 , 2 );
if ( strlen ( $q [ 'm' ]) > 13 )
$where .= ' AND SECOND(post_date)=' . substr ( $q [ 'm' ], 12 , 2 );
}
2004-12-12 21:41:19 +01:00
if ( ( int ) $q [ 'hour' ] ) {
2004-09-05 22:00:09 +02:00
$q [ 'hour' ] = '' . intval ( $q [ 'hour' ]);
$where .= " AND HOUR(post_date)=' " . $q [ 'hour' ] . " ' " ;
}
2004-12-12 21:41:19 +01:00
if ( ( int ) $q [ 'minute' ] ) {
2004-09-05 22:00:09 +02:00
$q [ 'minute' ] = '' . intval ( $q [ 'minute' ]);
$where .= " AND MINUTE(post_date)=' " . $q [ 'minute' ] . " ' " ;
}
2004-12-12 21:41:19 +01:00
if ( ( int ) $q [ 'second' ] ) {
2004-09-05 22:00:09 +02:00
$q [ 'second' ] = '' . intval ( $q [ 'second' ]);
$where .= " AND SECOND(post_date)=' " . $q [ 'second' ] . " ' " ;
}
2004-12-12 21:41:19 +01:00
if ( ( int ) $q [ 'year' ] ) {
2004-09-05 22:00:09 +02:00
$q [ 'year' ] = '' . intval ( $q [ 'year' ]);
$where .= " AND YEAR(post_date)=' " . $q [ 'year' ] . " ' " ;
}
2004-12-12 21:41:19 +01:00
if ( ( int ) $q [ 'monthnum' ] ) {
2004-09-05 22:00:09 +02:00
$q [ 'monthnum' ] = '' . intval ( $q [ 'monthnum' ]);
$where .= " AND MONTH(post_date)=' " . $q [ 'monthnum' ] . " ' " ;
}
2004-12-12 21:41:19 +01:00
if ( ( int ) $q [ 'day' ] ) {
2004-09-05 22:00:09 +02:00
$q [ 'day' ] = '' . intval ( $q [ 'day' ]);
$where .= " AND DAYOFMONTH(post_date)=' " . $q [ 'day' ] . " ' " ;
}
2005-11-15 23:55:24 +01:00
// Compat. Map subpost to attachment.
if ( '' != $q [ 'subpost' ] )
$q [ 'attachment' ] = $q [ 'subpost' ];
if ( '' != $q [ 'subpost_id' ] )
$q [ 'attachment_id' ] = $q [ 'subpost_id' ];
2004-09-05 22:00:09 +02:00
if ( '' != $q [ 'name' ]) {
$q [ 'name' ] = sanitize_title ( $q [ 'name' ]);
$where .= " AND post_name = ' " . $q [ 'name' ] . " ' " ;
} else if ( '' != $q [ 'pagename' ]) {
2006-02-10 01:54:16 +01:00
$reqpage = get_page_by_path ( $q [ 'pagename' ]);
2006-02-28 09:00:39 +01:00
if ( ! empty ( $reqpage ) )
$reqpage = $reqpage -> ID ;
else
$reqpage = 0 ;
2006-02-12 08:53:23 +01:00
2006-03-01 08:08:04 +01:00
if ( ( 'page' == get_option ( 'show_on_front' ) ) && ( $reqpage == get_option ( 'page_for_posts' ) ) ) {
$this -> is_page = false ;
$this -> is_home = true ;
} else {
$q [ 'pagename' ] = str_replace ( '%2F' , '/' , urlencode ( urldecode ( $q [ 'pagename' ])));
$page_paths = '/' . trim ( $q [ 'pagename' ], '/' );
$q [ 'pagename' ] = sanitize_title ( basename ( $page_paths ));
$q [ 'name' ] = $q [ 'pagename' ];
$where .= " AND (ID = ' $reqpage ') " ;
}
2005-11-15 23:55:24 +01:00
} elseif ( '' != $q [ 'attachment' ]) {
2005-12-28 05:27:21 +01:00
$q [ 'attachment' ] = str_replace ( '%2F' , '/' , urlencode ( urldecode ( $q [ 'attachment' ])));
$attach_paths = '/' . trim ( $q [ 'attachment' ], '/' );
$q [ 'attachment' ] = sanitize_title ( basename ( $attach_paths ));
2005-11-15 23:55:24 +01:00
$q [ 'name' ] = $q [ 'attachment' ];
$where .= " AND post_name = ' " . $q [ 'attachment' ] . " ' " ;
2004-09-05 22:00:09 +02:00
}
2004-12-12 21:41:19 +01:00
if ( ( int ) $q [ 'w' ] ) {
2004-09-05 22:00:09 +02:00
$q [ 'w' ] = '' . intval ( $q [ 'w' ]);
$where .= " AND WEEK(post_date, 1)=' " . $q [ 'w' ] . " ' " ;
}
2005-02-14 10:17:23 +01:00
if ( intval ( $q [ 'comments_popup' ]) )
$q [ 'p' ] = intval ( $q [ 'comments_popup' ]);
2005-11-15 23:55:24 +01:00
// If a attachment is requested by number, let it supercede any post number.
if ( ( $q [ 'attachment_id' ] != '' ) && ( intval ( $q [ 'attachment_id' ]) != 0 ) )
$q [ 'p' ] = ( int ) $q [ 'attachment_id' ];
2005-10-20 22:48:32 +02:00
2004-09-05 22:00:09 +02:00
// If a post number is specified, load that post
2005-02-01 02:49:51 +01:00
if (( $q [ 'p' ] != '' ) && intval ( $q [ 'p' ]) != 0 ) {
2004-12-12 21:41:19 +01:00
$q [ 'p' ] = ( int ) $q [ 'p' ];
$where = ' AND ID = ' . $q [ 'p' ];
2004-09-05 22:00:09 +02:00
}
2005-02-01 02:49:51 +01:00
if (( $q [ 'page_id' ] != '' ) && ( intval ( $q [ 'page_id' ]) != 0 )) {
2004-10-08 10:06:21 +02:00
$q [ 'page_id' ] = intval ( $q [ 'page_id' ]);
2006-03-01 08:08:04 +01:00
if ( ( 'page' == get_option ( 'show_on_front' ) ) && ( $q [ 'page_id' ] == get_option ( 'page_for_posts' ) ) ) {
$this -> is_page = false ;
$this -> is_home = true ;
} else {
$q [ 'p' ] = $q [ 'page_id' ];
$where = ' AND ID = ' . $q [ 'page_id' ];
}
2004-10-08 10:06:21 +02:00
}
2004-09-05 22:00:09 +02:00
// If a search pattern is specified, load the posts that match
if ( ! empty ( $q [ 's' ])) {
$q [ 's' ] = addslashes_gpc ( $q [ 's' ]);
$search = ' AND (' ;
$q [ 's' ] = preg_replace ( '/, +/' , ' ' , $q [ 's' ]);
$q [ 's' ] = str_replace ( ',' , ' ' , $q [ 's' ]);
$q [ 's' ] = str_replace ( '"' , ' ' , $q [ 's' ]);
$q [ 's' ] = trim ( $q [ 's' ]);
if ( $q [ 'exact' ]) {
$n = '' ;
} else {
$n = '%' ;
}
if ( ! $q [ 'sentence' ]) {
$s_array = explode ( ' ' , $q [ 's' ]);
2004-09-27 02:46:42 +02:00
$q [ 'search_terms' ] = $s_array ;
2004-09-05 22:00:09 +02:00
$search .= '((post_title LIKE \'' . $n . $s_array [ 0 ] . $n . '\') OR (post_content LIKE \'' . $n . $s_array [ 0 ] . $n . '\'))' ;
for ( $i = 1 ; $i < count ( $s_array ); $i = $i + 1 ) {
$search .= ' AND ((post_title LIKE \'' . $n . $s_array [ $i ] . $n . '\') OR (post_content LIKE \'' . $n . $s_array [ $i ] . $n . '\'))' ;
}
$search .= ' OR (post_title LIKE \'' . $n . $q [ 's' ] . $n . '\') OR (post_content LIKE \'' . $n . $q [ 's' ] . $n . '\')' ;
$search .= ')' ;
} else {
$search = ' AND ((post_title LIKE \'' . $n . $q [ 's' ] . $n . '\') OR (post_content LIKE \'' . $n . $q [ 's' ] . $n . '\'))' ;
}
}
// Category stuff
2005-02-01 02:49:51 +01:00
if (( empty ( $q [ 'cat' ])) || ( $q [ 'cat' ] == '0' ) ||
2004-09-05 22:00:09 +02:00
// Bypass cat checks if fetching specific posts
2005-02-13 20:45:04 +01:00
( $this -> is_single || $this -> is_page )) {
2004-09-05 22:00:09 +02:00
$whichcat = '' ;
} else {
$q [ 'cat' ] = '' . urldecode ( $q [ 'cat' ]) . '' ;
$q [ 'cat' ] = addslashes_gpc ( $q [ 'cat' ]);
if ( stristr ( $q [ 'cat' ], '-' )) {
// Note: if we have a negative, we ignore all the positives. It must
// always mean 'everything /except/ this one'. We should be able to do
// multiple negatives but we don't :-(
$eq = '!=' ;
$andor = 'AND' ;
$q [ 'cat' ] = explode ( '-' , $q [ 'cat' ]);
$q [ 'cat' ] = intval ( $q [ 'cat' ][ 1 ]);
} else {
$eq = '=' ;
$andor = 'OR' ;
}
$join = " LEFT JOIN $wpdb->post2cat ON ( $wpdb->posts .ID = $wpdb->post2cat .post_id) " ;
2005-02-13 18:52:58 +01:00
$cat_array = preg_split ( '/[,\s]+/' , $q [ 'cat' ]);
2004-09-05 22:00:09 +02:00
$whichcat .= ' AND (category_id ' . $eq . ' ' . intval ( $cat_array [ 0 ]);
$whichcat .= get_category_children ( $cat_array [ 0 ], ' ' . $andor . ' category_id ' . $eq . ' ' );
for ( $i = 1 ; $i < ( count ( $cat_array )); $i = $i + 1 ) {
$whichcat .= ' ' . $andor . ' category_id ' . $eq . ' ' . intval ( $cat_array [ $i ]);
$whichcat .= get_category_children ( $cat_array [ $i ], ' ' . $andor . ' category_id ' . $eq . ' ' );
}
$whichcat .= ')' ;
if ( $eq == '!=' ) {
$q [ 'cat' ] = '-' . $q [ 'cat' ]; // Put back the knowledge that we are excluding a category.
}
}
// Category stuff for nice URIs
2005-10-28 03:14:57 +02:00
global $cache_categories ;
2004-09-05 22:00:09 +02:00
if ( '' != $q [ 'category_name' ]) {
2006-02-28 09:00:39 +01:00
$reqcat = get_category_by_path ( $q [ 'category_name' ]);
$q [ 'category_name' ] = str_replace ( '%2F' , '/' , urlencode ( urldecode ( $q [ 'category_name' ])));
$cat_paths = '/' . trim ( $q [ 'category_name' ], '/' );
$q [ 'category_name' ] = sanitize_title ( basename ( $cat_paths ));
2005-10-28 03:14:57 +02:00
$cat_paths = '/' . trim ( urldecode ( $q [ 'category_name' ]), '/' );
$q [ 'category_name' ] = sanitize_title ( basename ( $cat_paths ));
$cat_paths = explode ( '/' , $cat_paths );
foreach ( $cat_paths as $pathdir )
$cat_path .= ( $pathdir != '' ? '/' : '' ) . sanitize_title ( $pathdir );
2005-12-31 22:53:13 +01:00
//if we don't match the entire hierarchy fallback on just matching the nicename
2006-02-28 09:00:39 +01:00
if ( empty ( $reqcat ) )
$reqcat = get_category_by_path ( $q [ 'category_name' ], false );
if ( ! empty ( $reqcat ) )
$reqcat = $reqcat -> cat_ID ;
else
$reqcat = 0 ;
2005-11-07 22:56:03 +01:00
2006-02-28 09:00:39 +01:00
$q [ 'cat' ] = $reqcat ;
2004-09-05 22:00:09 +02:00
$tables = " , $wpdb->post2cat , $wpdb->categories " ;
$join = " LEFT JOIN $wpdb->post2cat ON ( $wpdb->posts .ID = $wpdb->post2cat .post_id) LEFT JOIN $wpdb->categories ON ( $wpdb->post2cat .category_id = $wpdb->categories .cat_ID) " ;
2005-10-28 03:14:57 +02:00
$whichcat = " AND (category_id = ' " . $q [ 'cat' ] . " ' " ;
2004-09-05 22:00:09 +02:00
$whichcat .= get_category_children ( $q [ 'cat' ], " OR category_id = " );
$whichcat .= " ) " ;
}
// Author/user stuff
2005-02-01 02:49:51 +01:00
if (( empty ( $q [ 'author' ])) || ( $q [ 'author' ] == '0' )) {
2004-09-05 22:00:09 +02:00
$whichauthor = '' ;
} else {
$q [ 'author' ] = '' . urldecode ( $q [ 'author' ]) . '' ;
$q [ 'author' ] = addslashes_gpc ( $q [ 'author' ]);
if ( stristr ( $q [ 'author' ], '-' )) {
$eq = '!=' ;
$andor = 'AND' ;
$q [ 'author' ] = explode ( '-' , $q [ 'author' ]);
$q [ 'author' ] = '' . intval ( $q [ 'author' ][ 1 ]);
} else {
$eq = '=' ;
$andor = 'OR' ;
}
2005-02-13 18:52:58 +01:00
$author_array = preg_split ( '/[,\s]+/' , $q [ 'author' ]);
2004-09-05 22:00:09 +02:00
$whichauthor .= ' AND (post_author ' . $eq . ' ' . intval ( $author_array [ 0 ]);
for ( $i = 1 ; $i < ( count ( $author_array )); $i = $i + 1 ) {
$whichauthor .= ' ' . $andor . ' post_author ' . $eq . ' ' . intval ( $author_array [ $i ]);
}
$whichauthor .= ')' ;
}
// Author stuff for nice URIs
if ( '' != $q [ 'author_name' ]) {
if ( stristr ( $q [ 'author_name' ], '/' )) {
$q [ 'author_name' ] = explode ( '/' , $q [ 'author_name' ]);
if ( $q [ 'author_name' ][ count ( $q [ 'author_name' ]) - 1 ]) {
$q [ 'author_name' ] = $q [ 'author_name' ][ count ( $q [ 'author_name' ]) - 1 ]; #no trailing slash
} else {
$q [ 'author_name' ] = $q [ 'author_name' ][ count ( $q [ 'author_name' ]) - 2 ]; #there was a trailling slash
}
}
$q [ 'author_name' ] = sanitize_title ( $q [ 'author_name' ]);
$q [ 'author' ] = $wpdb -> get_var ( " SELECT ID FROM $wpdb->users WHERE user_nicename=' " . $q [ 'author_name' ] . " ' " );
$whichauthor .= ' AND (post_author = ' . intval ( $q [ 'author' ]) . ')' ;
}
2006-02-12 08:53:23 +01:00
2004-09-05 22:00:09 +02:00
$where .= $search . $whichcat . $whichauthor ;
if (( empty ( $q [ 'order' ])) || (( strtoupper ( $q [ 'order' ]) != 'ASC' ) && ( strtoupper ( $q [ 'order' ]) != 'DESC' ))) {
$q [ 'order' ] = 'DESC' ;
}
// Order by
if ( empty ( $q [ 'orderby' ])) {
2006-02-21 09:39:58 +01:00
$q [ 'orderby' ] = 'post_date ' . $q [ 'order' ];
2004-09-05 22:00:09 +02:00
} else {
// Used to filter values
2006-02-21 09:39:58 +01:00
$allowed_keys = array ( 'author' , 'date' , 'category' , 'title' , 'modified' , 'menu_order' );
2004-09-05 22:00:09 +02:00
$q [ 'orderby' ] = urldecode ( $q [ 'orderby' ]);
$q [ 'orderby' ] = addslashes_gpc ( $q [ 'orderby' ]);
$orderby_array = explode ( ' ' , $q [ 'orderby' ]);
2006-02-21 09:39:58 +01:00
if ( empty ( $orderby_array ) )
$orderby_array [] = $q [ 'orderby' ];
$q [ 'orderby' ] = '' ;
for ( $i = 0 ; $i < count ( $orderby_array ); $i ++ ) {
// Only allow certain values for safety
$orderby = $orderby_array [ $i ];
if ( 'menu_order' != $orderby )
$orderby = 'post_' . $orderby ;
if ( in_array ( $orderby_array [ $i ], $allowed_keys ) )
$q [ 'orderby' ] .= (( $i == 0 ) ? '' : ',' ) . " $orderby { $q [ 'order' ] } " ;
2004-09-05 22:00:09 +02:00
}
2006-02-21 09:39:58 +01:00
if ( empty ( $q [ 'orderby' ]) )
$q [ 'orderby' ] = 'post_date ' . $q [ 'order' ];
2004-09-05 22:00:09 +02:00
}
2006-02-12 08:41:56 +01:00
//$now = gmdate('Y-m-d H:i:59');
2005-11-06 08:04:46 +01:00
//only select past-dated posts, except if a logged in user is viewing a single: then, if they
//can edit the post, we let them through
2006-02-12 08:41:56 +01:00
//if ($pagenow != 'post.php' && $pagenow != 'edit.php' && !($this->is_single && $user_ID)) {
// $where .= " AND post_date_gmt <= '$now'";
// $distinct = 'DISTINCT';
//}
2004-09-05 22:00:09 +02:00
2005-11-15 23:55:24 +01:00
if ( $this -> is_attachment ) {
2006-02-09 11:03:48 +01:00
$where .= ' AND (post_type = "attachment")' ;
2005-10-20 22:48:32 +02:00
} elseif ( $this -> is_page ) {
2006-02-09 11:03:48 +01:00
$where .= ' AND (post_type = "page")' ;
2005-04-09 19:12:36 +02:00
} elseif ( $this -> is_single ) {
2006-02-09 11:03:48 +01:00
$where .= ' AND (post_type = "post")' ;
2004-09-05 22:00:09 +02:00
} else {
2006-02-21 09:39:58 +01:00
$where .= " AND (post_type = ' $post_type ' AND (post_status = 'publish' " ;
2004-09-05 22:00:09 +02:00
2006-02-21 09:39:58 +01:00
if ( is_admin () )
$where .= " OR post_status = 'future' OR post_status = 'draft' " ;
2006-02-12 08:41:56 +01:00
else
$distinct = 'DISTINCT' ;
if ( is_user_logged_in () )
2006-02-14 07:23:03 +01:00
$where .= " OR post_author = $user_ID AND post_status = 'private')) " ;
2005-04-09 19:12:36 +02:00
else
2006-02-14 07:23:03 +01:00
$where .= '))' ;
2005-04-09 19:12:36 +02:00
}
2004-09-05 22:00:09 +02:00
2004-12-25 01:32:50 +01:00
// Apply filters on where and join prior to paging so that any
// manipulations to them are reflected in the paging by day queries.
$where = apply_filters ( 'posts_where' , $where );
$join = apply_filters ( 'posts_join' , $join );
2004-09-05 22:00:09 +02:00
// Paging
2005-02-13 20:45:04 +01:00
if ( empty ( $q [ 'nopaging' ]) && ! $this -> is_single ) {
2004-09-05 22:00:09 +02:00
$page = $q [ 'paged' ];
if ( empty ( $page )) {
$page = 1 ;
}
if (( $q [ 'what_to_show' ] == 'posts' )) {
$pgstrt = '' ;
$pgstrt = ( intval ( $page ) - 1 ) * $q [ 'posts_per_page' ] . ', ' ;
$limits = 'LIMIT ' . $pgstrt . $q [ 'posts_per_page' ];
} elseif ( $q [ 'what_to_show' ] == 'days' ) {
2004-09-06 22:03:16 +02:00
$startrow = $q [ 'posts_per_page' ] * ( intval ( $page ) - 1 );
$start_date = $wpdb -> get_var ( " SELECT max(post_date) FROM $wpdb->posts $join WHERE (1=1) $where GROUP BY year(post_date), month(post_date), dayofmonth(post_date) ORDER BY post_date DESC LIMIT $startrow ,1 " );
2004-09-08 02:02:53 +02:00
$endrow = $startrow + $q [ 'posts_per_page' ] - 1 ;
$end_date = $wpdb -> get_var ( " SELECT min(post_date) FROM $wpdb->posts $join WHERE (1=1) $where GROUP BY year(post_date), month(post_date), dayofmonth(post_date) ORDER BY post_date DESC LIMIT $endrow ,1 " );
2004-09-05 22:00:09 +02:00
if ( $page > 1 ) {
2004-09-06 22:03:16 +02:00
$where .= " AND post_date >= ' $end_date ' AND post_date <= ' $start_date ' " ;
2004-09-05 22:00:09 +02:00
} else {
2004-09-06 22:03:16 +02:00
$where .= " AND post_date >= ' $end_date ' " ;
2004-09-05 22:00:09 +02:00
}
}
}
2004-12-25 01:32:50 +01:00
// Apply post-paging filters on where and join. Only plugins that
// manipulate paging queries should use these hooks.
$where = apply_filters ( 'posts_where_paged' , $where );
2005-11-17 10:10:18 +01:00
$groupby = " $wpdb->posts .ID " ;
$groupby = apply_filters ( 'posts_groupby' , $groupby );
2004-12-25 01:32:50 +01:00
$join = apply_filters ( 'posts_join_paged' , $join );
2006-02-21 09:39:58 +01:00
$orderby = apply_filters ( 'posts_orderby' , $q [ 'orderby' ]);
2005-11-17 10:10:18 +01:00
$request = " SELECT $distinct * FROM $wpdb->posts $join WHERE 1=1 " . $where . " GROUP BY " . $groupby . " ORDER BY " . $orderby . " $limits " ;
2006-01-11 12:06:26 +01:00
$this -> request = apply_filters ( 'posts_request' , $request );
2004-09-05 22:00:09 +02:00
2006-01-11 12:06:26 +01:00
$this -> posts = $wpdb -> get_results ( $this -> request );
2005-04-09 19:12:36 +02:00
// Check post status to determine if post should be displayed.
2006-03-03 03:17:14 +01:00
if ( ! empty ( $this -> posts ) && ( $this -> is_single || $this -> is_page ) ) {
2005-10-20 22:48:32 +02:00
$status = get_post_status ( $this -> posts [ 0 ]);
2006-02-12 08:41:56 +01:00
//$type = get_post_type($this->posts[0]);
2006-02-09 11:03:48 +01:00
if ( ( 'publish' != $status ) ) {
if ( ! is_user_logged_in () ) {
2005-04-09 19:12:36 +02:00
// User must be logged in to view unpublished posts.
$this -> posts = array ();
} else {
2005-10-20 22:48:32 +02:00
if ( 'draft' == $status ) {
2005-04-09 19:12:36 +02:00
// User must have edit permissions on the draft to preview.
2005-11-16 01:50:02 +01:00
if ( ! current_user_can ( 'edit_post' , $this -> posts [ 0 ] -> ID )) {
2005-04-09 19:12:36 +02:00
$this -> posts = array ();
2005-11-06 08:04:46 +01:00
} else {
$this -> is_preview = true ;
2006-01-18 20:30:28 +01:00
$this -> posts [ 0 ] -> post_date = current_time ( 'mysql' );
2005-11-06 08:04:46 +01:00
}
2006-02-12 08:41:56 +01:00
} else if ( 'future' == $status ) {
$this -> is_preview = true ;
if ( ! current_user_can ( 'edit_post' , $this -> posts [ 0 ] -> ID )) {
$this -> posts = array ( );
}
2005-12-13 01:54:52 +01:00
} else {
if ( ! current_user_can ( 'read_post' , $this -> posts [ 0 ] -> ID ))
2005-04-09 19:12:36 +02:00
$this -> posts = array ();
}
}
2004-09-05 22:00:09 +02:00
}
}
2005-12-13 04:49:09 +01:00
update_post_caches ( $this -> posts );
2004-09-05 22:00:09 +02:00
$this -> posts = apply_filters ( 'the_posts' , $this -> posts );
$this -> post_count = count ( $this -> posts );
if ( $this -> post_count > 0 ) {
2004-10-02 21:24:40 +02:00
$this -> post = $this -> posts [ 0 ];
2004-09-05 22:00:09 +02:00
}
2006-02-12 08:53:23 +01:00
2004-09-05 22:00:09 +02:00
return $this -> posts ;
2004-08-10 07:35:59 +02:00
}
2004-08-08 17:31:50 +02:00
2004-09-05 22:00:09 +02:00
function next_post () {
2004-08-08 17:31:50 +02:00
2004-09-05 22:00:09 +02:00
$this -> current_post ++ ;
2004-08-08 17:31:50 +02:00
2004-09-05 22:00:09 +02:00
$this -> post = $this -> posts [ $this -> current_post ];
return $this -> post ;
}
2004-08-08 17:31:50 +02:00
2005-01-19 03:21:36 +01:00
function the_post () {
global $post ;
2005-07-17 18:58:13 +02:00
$this -> in_the_loop = true ;
2005-01-19 03:21:36 +01:00
$post = $this -> next_post ();
setup_postdata ( $post );
2005-08-03 02:28:09 +02:00
if ( $this -> current_post == 0 ) // loop has just started
do_action ( 'loop_start' );
2005-01-19 03:21:36 +01:00
}
2004-09-05 22:00:09 +02:00
function have_posts () {
if ( $this -> current_post + 1 < $this -> post_count ) {
return true ;
2005-07-17 18:58:13 +02:00
} elseif ( $this -> current_post + 1 == $this -> post_count ) {
2005-08-03 02:28:09 +02:00
do_action ( 'loop_end' );
2005-07-17 18:58:13 +02:00
// Do some cleaning up after the loop
$this -> rewind_posts ();
2004-09-05 22:00:09 +02:00
}
2004-08-08 17:31:50 +02:00
2005-07-17 18:58:13 +02:00
$this -> in_the_loop = false ;
2004-09-05 22:00:09 +02:00
return false ;
}
2004-12-31 22:49:48 +01:00
function rewind_posts () {
$this -> current_post = - 1 ;
if ( $this -> post_count > 0 ) {
$this -> post = $this -> posts [ 0 ];
}
}
2004-08-08 17:31:50 +02:00
2005-03-27 22:45:01 +02:00
function & query ( $query ) {
2004-09-05 22:00:09 +02:00
$this -> parse_query ( $query );
return $this -> get_posts ();
}
2004-10-02 21:24:40 +02:00
function get_queried_object () {
if ( isset ( $this -> queried_object )) {
return $this -> queried_object ;
}
$this -> queried_object = NULL ;
$this -> queried_object_id = 0 ;
if ( $this -> is_category ) {
2005-06-13 04:09:24 +02:00
$cat = $this -> get ( 'cat' );
$category = & get_category ( $cat );
2005-03-27 22:45:01 +02:00
$this -> queried_object = & $category ;
2005-06-13 04:09:24 +02:00
$this -> queried_object_id = $cat ;
2004-10-02 21:24:40 +02:00
} else if ( $this -> is_single ) {
$this -> queried_object = $this -> post ;
$this -> queried_object_id = $this -> post -> ID ;
} else if ( $this -> is_page ) {
$this -> queried_object = $this -> post ;
$this -> queried_object_id = $this -> post -> ID ;
} else if ( $this -> is_author ) {
2005-12-11 20:14:29 +01:00
$author_id = $this -> get ( 'author' );
$author = get_userdata ( $author_id );
$this -> queried_object = $author ;
$this -> queried_object_id = $author_id ;
2004-10-02 21:24:40 +02:00
}
return $this -> queried_object ;
}
function get_queried_object_id () {
$this -> get_queried_object ();
if ( isset ( $this -> queried_object_id )) {
return $this -> queried_object_id ;
}
return 0 ;
}
2004-09-05 22:00:09 +02:00
function WP_Query ( $query = '' ) {
if ( ! empty ( $query )) {
$this -> query ( $query );
}
}
2004-06-30 17:31:49 +02:00
}
2004-09-08 10:17:53 +02:00
class retrospam_mgr {
var $spam_words ;
var $comments_list ;
var $found_comments ;
function retrospam_mgr () {
global $wpdb ;
$list = explode ( " \n " , get_settings ( 'moderation_keys' ) );
$list = array_unique ( $list );
$this -> spam_words = $list ;
$this -> comment_list = $wpdb -> get_results ( " SELECT comment_ID AS ID, comment_content AS text, comment_approved AS approved, comment_author_url AS url, comment_author_ip AS ip, comment_author_email AS email FROM $wpdb->comments ORDER BY comment_ID ASC " );
} // End of class constructor
function move_spam ( $id_list ) {
global $wpdb ;
$cnt = 0 ;
$id_list = explode ( ',' , $id_list );
foreach ( $id_list as $comment ) {
if ( $wpdb -> query ( " update $wpdb->comments set comment_approved = '0' where comment_ID = ' $comment ' " ) ) {
$cnt ++ ;
}
}
echo " <div class='updated'><p> $cnt comment " ;
if ( $cnt != 1 ) echo " s " ;
echo " moved to the moderation queue.</p></div> \n " ;
} // End function move_spam
function find_spam () {
$in_queue = 0 ;
foreach ( $this -> comment_list as $comment ) {
if ( $comment -> approved == 1 ) {
foreach ( $this -> spam_words as $word ) {
2005-09-19 04:49:53 +02:00
$word = trim ( $word );
if ( empty ( $word ) )
2005-02-11 03:16:38 +01:00
continue ;
2004-09-08 10:17:53 +02:00
$fulltext = strtolower ( $comment -> email . ' ' . $comment -> url . ' ' . $comment -> ip . ' ' . $comment -> text );
2005-09-19 04:49:53 +02:00
if ( strpos ( $fulltext , strtolower ( $word ) ) != FALSE ) {
2004-09-08 10:17:53 +02:00
$this -> found_comments [] = $comment -> ID ;
break ;
}
}
} else {
$in_queue ++ ;
}
}
return array ( 'found' => $this -> found_comments , 'in_queue' => $in_queue );
} // End function find_spam
function display_edit_form ( $counters ) {
$numfound = count ( $counters [ found ]);
$numqueue = $counters [ in_queue ];
$body = '<p>' . sprintf ( __ ( 'Suspected spam comments: <strong>%s</strong>' ), $numfound ) . '</p>' ;
if ( count ( $counters [ found ]) > 0 ) {
$id_list = implode ( ',' , $counters [ found ] );
2004-12-20 18:10:15 +01:00
$body .= '<p><a href="options-discussion.php?action=retrospam&move=true&ids=' . $id_list . '">' . __ ( 'Move suspect comments to moderation queue »' ) . '</a></p>' ;
2004-09-08 10:17:53 +02:00
}
$head = '<div class="wrap"><h2>' . __ ( 'Check Comments Results:' ) . '</h2>' ;
$foot .= '<p><a href="options-discussion.php">' . __ ( '« Return to Discussion Options page.' ) . '</a></p></div>' ;
2006-02-12 08:53:23 +01:00
2004-09-08 10:17:53 +02:00
return $head . $body . $foot ;
} // End function display_edit_form
}
2005-06-11 01:15:13 +02:00
class WP {
2006-01-24 00:39:56 +01:00
var $public_query_vars = array ( 'm' , 'p' , 'posts' , 'w' , 'cat' , 'withcomments' , 's' , 'search' , 'exact' , 'sentence' , 'debug' , 'calendar' , 'page' , 'paged' , 'more' , 'tb' , 'pb' , 'author' , 'order' , 'orderby' , 'year' , 'monthnum' , 'day' , 'hour' , 'minute' , 'second' , 'name' , 'category_name' , 'feed' , 'author_name' , 'static' , 'pagename' , 'page_id' , 'error' , 'comments_popup' , 'attachment' , 'attachment_id' , 'subpost' , 'subpost_id' , 'preview' );
2005-06-11 01:15:13 +02:00
2006-02-21 09:39:58 +01:00
var $private_query_vars = array ( 'posts_per_page' , 'posts_per_archive_page' , 'what_to_show' , 'showposts' , 'nopaging' , 'post_type' );
var $extra_query_vars = array ();
2005-06-11 01:15:13 +02:00
var $query_vars ;
var $query_string ;
2005-11-22 22:07:48 +01:00
var $request ;
var $matched_rule ;
var $matched_query ;
2005-06-11 01:15:13 +02:00
var $did_permalink = false ;
2006-03-12 23:57:00 +01:00
function add_query_var ( $qv ) {
$this -> public_query_vars [] = $qv ;
}
2005-06-11 01:15:13 +02:00
function parse_request ( $extra_query_vars = '' ) {
global $wp_rewrite ;
$this -> query_vars = array ();
if ( ! empty ( $extra_query_vars ))
2006-02-21 09:39:58 +01:00
parse_str ( $extra_query_vars , $this -> extra_query_vars );
2005-06-11 01:15:13 +02:00
2005-06-13 04:09:24 +02:00
// Process PATH_INFO, REQUEST_URI, and 404 for permalinks.
2005-06-11 01:15:13 +02:00
2005-11-16 23:54:52 +01:00
// Fetch the rewrite rules.
$rewrite = $wp_rewrite -> wp_rewrite_rules ();
2005-06-11 01:15:13 +02:00
2005-11-16 23:54:52 +01:00
if ( ! empty ( $rewrite )) {
2005-06-11 01:15:13 +02:00
// If we match a rewrite rule, this will be cleared.
$error = '404' ;
2005-11-16 23:54:52 +01:00
$this -> did_permalink = true ;
2005-06-11 01:15:13 +02:00
2005-11-16 23:54:52 +01:00
$pathinfo = $_SERVER [ 'PATH_INFO' ];
$pathinfo_array = explode ( '?' , $pathinfo );
$pathinfo = $pathinfo_array [ 0 ];
$req_uri = $_SERVER [ 'REQUEST_URI' ];
$req_uri_array = explode ( '?' , $req_uri );
$req_uri = $req_uri_array [ 0 ];
$self = $_SERVER [ 'PHP_SELF' ];
$home_path = parse_url ( get_settings ( 'home' ));
$home_path = $home_path [ 'path' ];
2005-12-28 02:48:29 +01:00
$home_path = trim ( $home_path , '/' );
2005-11-16 23:54:52 +01:00
// Trim path info from the end and the leading home path from the
// front. For path info requests, this leaves us with the requesting
// filename, if any. For 404 requests, this leaves us with the
2006-02-12 08:53:23 +01:00
// requested permalink.
2005-11-16 23:54:52 +01:00
$req_uri = str_replace ( $pathinfo , '' , $req_uri );
$req_uri = trim ( $req_uri , '/' );
2005-12-28 02:48:29 +01:00
$req_uri = preg_replace ( " |^ $home_path | " , '' , $req_uri );
$req_uri = trim ( $req_uri , '/' );
$pathinfo = trim ( $pathinfo , '/' );
$pathinfo = preg_replace ( " |^ $home_path | " , '' , $pathinfo );
2005-11-16 23:54:52 +01:00
$pathinfo = trim ( $pathinfo , '/' );
2005-12-28 02:48:29 +01:00
$self = trim ( $self , '/' );
$self = preg_replace ( " |^ $home_path | " , '' , $self );
2005-11-16 23:54:52 +01:00
$self = str_replace ( $home_path , '' , $self );
$self = trim ( $self , '/' );
// The requested permalink is in $pathinfo for path info requests and
// $req_uri for other requests.
2006-01-03 01:59:31 +01:00
if ( ! empty ( $pathinfo ) && ! preg_match ( '|^.*' . $wp_rewrite -> index . '$|' , $pathinfo ) ) {
2005-11-16 23:54:52 +01:00
$request = $pathinfo ;
} else {
2005-12-01 02:34:29 +01:00
// If the request uri is the index, blank it out so that we don't try to match it against a rule.
if ( $req_uri == $wp_rewrite -> index )
$req_uri = '' ;
2005-11-16 23:54:52 +01:00
$request = $req_uri ;
}
2005-12-01 02:34:29 +01:00
2005-11-22 22:07:48 +01:00
$this -> request = $request ;
2005-06-11 01:15:13 +02:00
2005-11-16 23:54:52 +01:00
// Look for matches.
$request_match = $request ;
foreach ( $rewrite as $match => $query ) {
// If the requesting file is the anchor of the match, prepend it
// to the path info.
if (( ! empty ( $req_uri )) && ( strpos ( $match , $req_uri ) === 0 ) && ( $req_uri != $request )) {
$request_match = $req_uri . '/' . $request ;
}
2005-06-11 01:15:13 +02:00
2005-11-29 02:43:32 +01:00
if ( preg_match ( " !^ $match ! " , $request_match , $matches ) ||
preg_match ( " !^ $match ! " , urldecode ( $request_match ), $matches )) {
2005-11-16 23:54:52 +01:00
// Got a match.
2005-11-22 22:07:48 +01:00
$this -> matched_rule = $match ;
2006-03-12 23:57:00 +01:00
2005-11-16 23:54:52 +01:00
// Trim the query of everything up to the '?'.
$query = preg_replace ( " !^.+ \ ?! " , '' , $query );
2005-06-11 01:15:13 +02:00
2005-11-16 23:54:52 +01:00
// Substitute the substring matches into the query.
eval ( " \$ query = \" $query\ " ; " );
2005-11-22 22:07:48 +01:00
$this -> matched_query = $query ;
2005-06-11 01:15:13 +02:00
2005-11-16 23:54:52 +01:00
// Parse the query.
2006-02-21 09:39:58 +01:00
parse_str ( $query , $perma_query_vars );
2005-11-16 11:16:20 +01:00
2005-11-16 23:54:52 +01:00
// If we're processing a 404 request, clear the error var
// since we found something.
2005-11-29 00:30:42 +01:00
if ( isset ( $_GET [ 'error' ]))
2005-11-16 11:16:20 +01:00
unset ( $_GET [ 'error' ]);
2005-11-29 00:30:42 +01:00
if ( isset ( $error ))
2005-11-16 11:16:20 +01:00
unset ( $error );
2005-11-16 23:54:52 +01:00
break ;
}
}
// If req_uri is empty or if it is a request for ourself, unset error.
2005-11-29 00:30:42 +01:00
if ( empty ( $request ) || $req_uri == $self || strstr ( $_SERVER [ 'PHP_SELF' ], 'wp-admin/' ) ) {
if ( isset ( $_GET [ 'error' ]))
2005-11-16 23:54:52 +01:00
unset ( $_GET [ 'error' ]);
2005-11-29 00:30:42 +01:00
if ( isset ( $error ))
2005-11-16 23:54:52 +01:00
unset ( $error );
2006-02-12 08:53:23 +01:00
2006-02-21 09:39:58 +01:00
if ( isset ( $perma_query_vars ) && strstr ( $_SERVER [ 'PHP_SELF' ], 'wp-admin/' ) )
unset ( $perma_query_vars );
2006-02-12 08:53:23 +01:00
2005-11-29 00:30:42 +01:00
$this -> did_permalink = false ;
2005-06-11 01:15:13 +02:00
}
}
$this -> public_query_vars = apply_filters ( 'query_vars' , $this -> public_query_vars );
for ( $i = 0 ; $i < count ( $this -> public_query_vars ); $i += 1 ) {
$wpvar = $this -> public_query_vars [ $i ];
2006-02-21 09:39:58 +01:00
if ( isset ( $this -> extra_query_vars [ $wpvar ]))
$this -> query_vars [ $wpvar ] = $this -> extra_query_vars [ $wpvar ];
2005-06-11 01:15:13 +02:00
elseif ( isset ( $GLOBALS [ $wpvar ]))
$this -> query_vars [ $wpvar ] = $GLOBALS [ $wpvar ];
elseif ( ! empty ( $_POST [ $wpvar ]))
$this -> query_vars [ $wpvar ] = $_POST [ $wpvar ];
elseif ( ! empty ( $_GET [ $wpvar ]))
$this -> query_vars [ $wpvar ] = $_GET [ $wpvar ];
2006-02-21 09:39:58 +01:00
elseif ( ! empty ( $perma_query_vars [ $wpvar ]))
$this -> query_vars [ $wpvar ] = $perma_query_vars [ $wpvar ];
2005-06-11 01:15:13 +02:00
else
$this -> query_vars [ $wpvar ] = '' ;
}
2005-11-16 11:16:20 +01:00
2006-02-21 09:39:58 +01:00
for ( $i = 0 ; $i < count ( $this -> private_query_vars ); $i += 1 ) {
$wpvar = $this -> private_query_vars [ $i ];
if ( isset ( $this -> extra_query_vars [ $wpvar ]))
$this -> query_vars [ $wpvar ] = $this -> extra_query_vars [ $wpvar ];
}
2005-11-16 11:16:20 +01:00
if ( isset ( $error ) )
$this -> query_vars [ 'error' ] = $error ;
2005-06-11 01:15:13 +02:00
}
function send_headers () {
@ header ( 'X-Pingback: ' . get_bloginfo ( 'pingback_url' ));
2005-12-15 17:31:41 +01:00
if ( is_user_logged_in () )
2005-11-11 02:44:41 +01:00
nocache_headers ();
2005-06-11 01:15:13 +02:00
if ( ! empty ( $this -> query_vars [ 'error' ]) && '404' == $this -> query_vars [ 'error' ] ) {
status_header ( 404 );
} else if ( empty ( $this -> query_vars [ 'feed' ]) ) {
@ header ( 'Content-type: ' . get_option ( 'html_type' ) . '; charset=' . get_option ( 'blog_charset' ));
} else {
// We're showing a feed, so WP is indeed the only thing that last changed
if ( $this -> query_vars [ 'withcomments' ] )
$wp_last_modified = mysql2date ( 'D, d M Y H:i:s' , get_lastcommentmodified ( 'GMT' ), 0 ) . ' GMT' ;
else
$wp_last_modified = mysql2date ( 'D, d M Y H:i:s' , get_lastpostmodified ( 'GMT' ), 0 ) . ' GMT' ;
$wp_etag = '"' . md5 ( $wp_last_modified ) . '"' ;
@ header ( " Last-Modified: $wp_last_modified " );
@ header ( " ETag: $wp_etag " );
// Support for Conditional GET
if ( isset ( $_SERVER [ 'HTTP_IF_NONE_MATCH' ])) $client_etag = stripslashes ( $_SERVER [ 'HTTP_IF_NONE_MATCH' ]);
else $client_etag = false ;
$client_last_modified = trim ( $_SERVER [ 'HTTP_IF_MODIFIED_SINCE' ]);
// If string is empty, return 0. If not, attempt to parse into a timestamp
$client_modified_timestamp = $client_last_modified ? strtotime ( $client_last_modified ) : 0 ;
2006-02-12 08:53:23 +01:00
// Make a timestamp for our most recent modification...
2005-06-11 01:15:13 +02:00
$wp_modified_timestamp = strtotime ( $wp_last_modified );
if ( ( $client_last_modified && $client_etag ) ?
(( $client_modified_timestamp >= $wp_modified_timestamp ) && ( $client_etag == $wp_etag )) :
(( $client_modified_timestamp >= $wp_modified_timestamp ) || ( $client_etag == $wp_etag )) ) {
status_header ( 304 );
exit ;
}
}
}
function build_query_string () {
$this -> query_string = '' ;
2006-02-21 09:39:58 +01:00
foreach ( array_keys ( $this -> query_vars ) as $wpvar ) {
if ( '' != $this -> query_vars [ $wpvar ] ) {
2005-06-11 01:15:13 +02:00
$this -> query_string .= ( strlen ( $this -> query_string ) < 1 ) ? '' : '&' ;
$this -> query_string .= $wpvar . '=' . rawurlencode ( $this -> query_vars [ $wpvar ]);
}
}
foreach ( $this -> private_query_vars as $wpvar ) {
2006-02-21 09:39:58 +01:00
if ( isset ( $GLOBALS [ $wpvar ]) && '' != $GLOBALS [ $wpvar ] && ! isset ( $this -> extra_query_vars [ $wpvar ]) ) {
2005-06-11 01:15:13 +02:00
$this -> query_string .= ( strlen ( $this -> query_string ) < 1 ) ? '' : '&' ;
$this -> query_string .= $wpvar . '=' . rawurlencode ( $GLOBALS [ $wpvar ]);
}
}
$this -> query_string = apply_filters ( 'query_string' , $this -> query_string );
}
function register_globals () {
global $wp_query ;
// Extract updated query vars back into global namespace.
foreach ( $wp_query -> query_vars as $key => $value ) {
$GLOBALS [ $key ] = $value ;
}
$GLOBALS [ 'query_string' ] = & $this -> query_string ;
$GLOBALS [ 'posts' ] = & $wp_query -> posts ;
$GLOBALS [ 'post' ] = & $wp_query -> post ;
2006-01-11 12:06:26 +01:00
$GLOBALS [ 'request' ] = & $wp_query -> request ;
2005-06-11 01:15:13 +02:00
if ( is_single () || is_page () ) {
$GLOBALS [ 'more' ] = 1 ;
$GLOBALS [ 'single' ] = 1 ;
}
}
2005-12-18 23:08:01 +01:00
function init () {
2006-02-22 20:08:55 +01:00
wp_get_current_user ();
2005-06-11 01:15:13 +02:00
}
function query_posts () {
$this -> build_query_string ();
query_posts ( $this -> query_string );
}
function handle_404 () {
global $wp_query ;
// Issue a 404 if a permalink request doesn't match any posts. Don't
// issue a 404 if one was already issued, if the request was a search,
// or if the request was a regular query string request rather than a
// permalink request.
2006-01-25 04:59:41 +01:00
if ( ( 0 == count ( $wp_query -> posts )) && ! is_404 () && ! is_search () && ( $this -> did_permalink || ( ! empty ( $_SERVER [ 'QUERY_STRING' ]) && ( false === strpos ( $_SERVER [ 'REQUEST_URI' ], '?' ))) ) ) {
2005-09-16 05:16:12 +02:00
$wp_query -> set_404 ();
2005-06-11 01:15:13 +02:00
status_header ( 404 );
2005-11-16 11:16:20 +01:00
} elseif ( is_404 () != true ) {
2005-06-11 01:15:13 +02:00
status_header ( 200 );
}
}
function main ( $query_args = '' ) {
2005-12-18 23:08:01 +01:00
$this -> init ();
2005-06-11 01:15:13 +02:00
$this -> parse_request ( $query_args );
2005-11-11 02:44:41 +01:00
$this -> send_headers ();
2005-06-11 01:15:13 +02:00
$this -> query_posts ();
$this -> handle_404 ();
$this -> register_globals ();
}
function WP () {
// Empty.
}
2004-12-03 03:38:11 +01:00
}
2005-08-30 21:01:45 +02:00
?>