Remove old preview stuff. Allow draft posts to be displayed if the logged in user has edit permissions on the draft. Don't use cruft-free links for drafts since they might not have a slug. http://mosquito.wordpress.org/view.php?id=1220
git-svn-id: https://develop.svn.wordpress.org/trunk@2523 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
16a3144b00
commit
a0d5ea6ba2
@ -85,7 +85,7 @@ if ((isset($_GET['error']) && $_GET['error'] == '404') ||
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$wpvarstoreset = array('m','p','posts','w', 'cat','withcomments','s','search','exact', 'sentence','preview','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');
|
$wpvarstoreset = 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');
|
||||||
|
|
||||||
$wpvarstoreset = apply_filters('query_vars', $wpvarstoreset);
|
$wpvarstoreset = apply_filters('query_vars', $wpvarstoreset);
|
||||||
|
|
||||||
@ -167,6 +167,7 @@ foreach (array_merge($wpvarstoreset, $more_wpvars) as $wpvar) {
|
|||||||
$query_string = apply_filters('query_string', $query_string);
|
$query_string = apply_filters('query_string', $query_string);
|
||||||
|
|
||||||
update_category_cache();
|
update_category_cache();
|
||||||
|
get_currentuserinfo();
|
||||||
|
|
||||||
// Call query posts to do the work.
|
// Call query posts to do the work.
|
||||||
$posts = & query_posts($query_string);
|
$posts = & query_posts($query_string);
|
||||||
|
@ -493,16 +493,17 @@ class WP_Query {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ($this->is_page) {
|
if ($this->is_page) {
|
||||||
$where .= ' AND (post_status = "static"';
|
$where .= ' AND (post_status = "static")';
|
||||||
|
} elseif ($this->is_single) {
|
||||||
|
$where .= ' AND (post_status != "static")';
|
||||||
} else {
|
} else {
|
||||||
$where .= ' AND (post_status = "publish"';
|
$where .= ' AND (post_status = "publish"';
|
||||||
}
|
|
||||||
|
|
||||||
// Get private posts
|
if (isset($user_ID) && ('' != intval($user_ID)))
|
||||||
if (isset($user_ID) && ('' != intval($user_ID)))
|
$where .= " OR post_author = $user_ID AND post_status != 'draft' AND post_status != 'static')";
|
||||||
$where .= " OR post_author = $user_ID AND post_status != 'draft' AND post_status != 'static')";
|
else
|
||||||
else
|
$where .= ')';
|
||||||
$where .= ')';
|
}
|
||||||
|
|
||||||
// Apply filters on where and join prior to paging so that any
|
// Apply filters on where and join prior to paging so that any
|
||||||
// manipulations to them are reflected in the paging by day queries.
|
// manipulations to them are reflected in the paging by day queries.
|
||||||
@ -543,16 +544,27 @@ class WP_Query {
|
|||||||
$orderby = apply_filters('posts_orderby', $orderby);
|
$orderby = apply_filters('posts_orderby', $orderby);
|
||||||
$request = " SELECT $distinct * FROM $wpdb->posts $join WHERE 1=1".$where." ORDER BY " . $orderby . " $limits";
|
$request = " SELECT $distinct * FROM $wpdb->posts $join WHERE 1=1".$where." ORDER BY " . $orderby . " $limits";
|
||||||
|
|
||||||
if ($q['preview']) {
|
$this->posts = $wpdb->get_results($request);
|
||||||
$request = 'SELECT 1-1'; // dummy mysql query for the preview
|
|
||||||
// little funky fix for IEwin, rawk on that code
|
// Check post status to determine if post should be displayed.
|
||||||
$is_winIE = ((preg_match('/MSIE/',$HTTP_USER_AGENT)) && (preg_match('/Win/',$HTTP_USER_AGENT)));
|
if ($this->is_single) {
|
||||||
if (($is_winIE) && (!isset($IEWin_bookmarklet_fix))) {
|
if ('publish' != $this->posts[0]->post_status) {
|
||||||
$preview_content = preg_replace('/\%u([0-9A-F]{4,4})/e', "'&#'.base_convert('\\1',16,10).';'", $preview_content);
|
if ( ! (isset($user_ID) && ('' != intval($user_ID))) ) {
|
||||||
|
// User must be logged in to view unpublished posts.
|
||||||
|
$this->posts = array();
|
||||||
|
} else {
|
||||||
|
if ('draft' == $this->posts[0]->post_status) {
|
||||||
|
// User must have edit permissions on the draft to preview.
|
||||||
|
if (! user_can_edit_post($user_ID, $this->posts[0]->ID))
|
||||||
|
$this->posts = array();
|
||||||
|
} elseif ('private' == $this->posts[0]->post_status) {
|
||||||
|
if ($this->posts[0]->post_author != $user_ID)
|
||||||
|
$this->posts = array();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->posts = $wpdb->get_results($request);
|
|
||||||
$this->posts = apply_filters('the_posts', $this->posts);
|
$this->posts = apply_filters('the_posts', $this->posts);
|
||||||
$this->post_count = count($this->posts);
|
$this->post_count = count($this->posts);
|
||||||
if ($this->post_count > 0) {
|
if ($this->post_count > 0) {
|
||||||
|
@ -351,10 +351,10 @@ function user_can_create_draft($user_id, $blog_id = 1, $category_id = 'None') {
|
|||||||
/* returns true if $user_id can edit $post_id */
|
/* returns true if $user_id can edit $post_id */
|
||||||
function user_can_edit_post($user_id, $post_id, $blog_id = 1) {
|
function user_can_edit_post($user_id, $post_id, $blog_id = 1) {
|
||||||
$author_data = get_userdata($user_id);
|
$author_data = get_userdata($user_id);
|
||||||
$post_data = get_postdata($post_id);
|
$post = get_post($post_id);
|
||||||
$post_author_data = get_userdata($post_data['Author_ID']);
|
$post_author_data = get_userdata($post->post_author);
|
||||||
|
|
||||||
if ( (($user_id == $post_author_data->ID) && !($post_data['post_status'] == 'publish' && $author_data->user_level < 2))
|
if ( (($user_id == $post_author_data->ID) && !($post->post_status == 'publish' && $author_data->user_level < 2))
|
||||||
|| ($author_data->user_level > $post_author_data->user_level)
|
|| ($author_data->user_level > $post_author_data->user_level)
|
||||||
|| ($author_data->user_level >= 10) ) {
|
|| ($author_data->user_level >= 10) ) {
|
||||||
return true;
|
return true;
|
||||||
|
@ -856,24 +856,11 @@ function start_wp() {
|
|||||||
|
|
||||||
// Setup global post data.
|
// Setup global post data.
|
||||||
function setup_postdata($post) {
|
function setup_postdata($post) {
|
||||||
global $id, $postdata, $authordata, $day, $preview, $page, $pages, $multipage, $more, $numpages, $wp_query;
|
global $id, $postdata, $authordata, $day, $page, $pages, $multipage, $more, $numpages, $wp_query;
|
||||||
global $pagenow;
|
global $pagenow;
|
||||||
|
|
||||||
if (!$preview) {
|
$id = $post->ID;
|
||||||
$id = $post->ID;
|
|
||||||
} else {
|
|
||||||
$id = 0;
|
|
||||||
$postdata = array (
|
|
||||||
'ID' => 0,
|
|
||||||
'Author_ID' => $_GET['preview_userid'],
|
|
||||||
'Date' => $_GET['preview_date'],
|
|
||||||
'Content' => $_GET['preview_content'],
|
|
||||||
'Excerpt' => $_GET['preview_excerpt'],
|
|
||||||
'Title' => $_GET['preview_title'],
|
|
||||||
'Category' => $_GET['preview_category'],
|
|
||||||
'Notify' => 1
|
|
||||||
);
|
|
||||||
}
|
|
||||||
$authordata = get_userdata($post->post_author);
|
$authordata = get_userdata($post->post_author);
|
||||||
|
|
||||||
$day = mysql2date('d.m.y', $post->post_date);
|
$day = mysql2date('d.m.y', $post->post_date);
|
||||||
@ -1158,7 +1145,7 @@ function update_post_caches(&$posts) {
|
|||||||
$comment_counts = $wpdb->get_results("SELECT ID, COUNT( comment_ID ) AS ccount
|
$comment_counts = $wpdb->get_results("SELECT ID, COUNT( comment_ID ) AS ccount
|
||||||
FROM $wpdb->posts
|
FROM $wpdb->posts
|
||||||
LEFT JOIN $wpdb->comments ON ( comment_post_ID = ID AND comment_approved = '1')
|
LEFT JOIN $wpdb->comments ON ( comment_post_ID = ID AND comment_approved = '1')
|
||||||
WHERE post_status = 'publish' AND ID IN ($post_id_list)
|
WHERE ID IN ($post_id_list)
|
||||||
GROUP BY ID");
|
GROUP BY ID");
|
||||||
|
|
||||||
if ($comment_counts) {
|
if ($comment_counts) {
|
||||||
|
@ -44,7 +44,7 @@ function get_permalink($id = 0) {
|
|||||||
|
|
||||||
$permalink = get_settings('permalink_structure');
|
$permalink = get_settings('permalink_structure');
|
||||||
|
|
||||||
if ('' != $permalink) {
|
if ('' != $permalink && 'draft' != $post->post_status) {
|
||||||
$unixtime = strtotime($post->post_date);
|
$unixtime = strtotime($post->post_date);
|
||||||
|
|
||||||
$category = '';
|
$category = '';
|
||||||
|
Loading…
Reference in New Issue
Block a user