mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-25 17:51:27 +01:00
Create explicit page attachment rewrite rules rather than matching the attachment name against a regexp.
git-svn-id: http://svn.automattic.com/wordpress/trunk@3371 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
8906eb2557
commit
240128b76d
@ -381,7 +381,9 @@ class WP_Query {
|
|||||||
|
|
||||||
$where .= " AND (ID = '$reqpage')";
|
$where .= " AND (ID = '$reqpage')";
|
||||||
} elseif ('' != $q['attachment']) {
|
} elseif ('' != $q['attachment']) {
|
||||||
$q['attachment'] = sanitize_title($q['attachment']);
|
$q['attachment'] = str_replace('%2F', '/', urlencode(urldecode($q['attachment'])));
|
||||||
|
$attach_paths = '/' . trim($q['attachment'], '/');
|
||||||
|
$q['attachment'] = sanitize_title(basename($attach_paths));
|
||||||
$q['name'] = $q['attachment'];
|
$q['name'] = $q['attachment'];
|
||||||
$where .= " AND post_name = '" . $q['attachment'] . "'";
|
$where .= " AND post_name = '" . $q['attachment'] . "'";
|
||||||
}
|
}
|
||||||
@ -953,16 +955,22 @@ class WP_Rewrite {
|
|||||||
|
|
||||||
function page_rewrite_rules() {
|
function page_rewrite_rules() {
|
||||||
$uris = get_settings('page_uris');
|
$uris = get_settings('page_uris');
|
||||||
|
$attachment_uris = get_settings('page_attachment_uris');
|
||||||
|
|
||||||
$rewrite_rules = array();
|
$rewrite_rules = array();
|
||||||
$page_structure = $this->get_page_permastruct();
|
$page_structure = $this->get_page_permastruct();
|
||||||
if( is_array( $uris ) )
|
if( is_array( $attachment_uris ) ) {
|
||||||
{
|
foreach ($attachment_uris as $uri => $pagename) {
|
||||||
foreach ($uris as $uri => $pagename) {
|
$this->add_rewrite_tag('%pagename%', "($uri)", 'attachment=');
|
||||||
$this->add_rewrite_tag('%pagename%', "($uri)", 'pagename=');
|
$rewrite_rules += $this->generate_rewrite_rules($page_structure);
|
||||||
$rewrite_rules += $this->generate_rewrite_rules($page_structure);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
if( is_array( $uris ) ) {
|
||||||
|
foreach ($uris as $uri => $pagename) {
|
||||||
|
$this->add_rewrite_tag('%pagename%', "($uri)", 'pagename=');
|
||||||
|
$rewrite_rules += $this->generate_rewrite_rules($page_structure);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return $rewrite_rules;
|
return $rewrite_rules;
|
||||||
}
|
}
|
||||||
@ -1225,11 +1233,14 @@ class WP_Rewrite {
|
|||||||
$rewrite = $rewrite + array($pagematch => $pagequery);
|
$rewrite = $rewrite + array($pagematch => $pagequery);
|
||||||
|
|
||||||
if ($num_toks) {
|
if ($num_toks) {
|
||||||
$post = 0;
|
$post = false;
|
||||||
|
$page = false;
|
||||||
if (strstr($struct, '%postname%') || strstr($struct, '%post_id%')
|
if (strstr($struct, '%postname%') || strstr($struct, '%post_id%')
|
||||||
|| strstr($struct, '%pagename%')
|
|| strstr($struct, '%pagename%')
|
||||||
|| (strstr($struct, '%year%') && strstr($struct, '%monthnum%') && strstr($struct, '%day%') && strstr($struct, '%hour%') && strstr($struct, '%minute') && strstr($struct, '%second%'))) {
|
|| (strstr($struct, '%year%') && strstr($struct, '%monthnum%') && strstr($struct, '%day%') && strstr($struct, '%hour%') && strstr($struct, '%minute') && strstr($struct, '%second%'))) {
|
||||||
$post = 1;
|
$post = true;
|
||||||
|
if ( strstr($struct, '%pagename%') )
|
||||||
|
$page = true;
|
||||||
$trackbackmatch = $match . $trackbackregex;
|
$trackbackmatch = $match . $trackbackregex;
|
||||||
$trackbackquery = $trackbackindex . '?' . $query . '&tb=1';
|
$trackbackquery = $trackbackindex . '?' . $query . '&tb=1';
|
||||||
$match = rtrim($match, '/');
|
$match = rtrim($match, '/');
|
||||||
@ -1257,9 +1268,10 @@ class WP_Rewrite {
|
|||||||
$rewrite = $rewrite + array($match => $query);
|
$rewrite = $rewrite + array($match => $query);
|
||||||
|
|
||||||
if ($post) {
|
if ($post) {
|
||||||
$rewrite = array($trackbackmatch => $trackbackquery) + $rewrite +
|
$rewrite = array($trackbackmatch => $trackbackquery) + $rewrite;
|
||||||
array($sub1 => $subquery, $sub1tb => $subtbquery, $sub1feed => $subfeedquery, $sub1feed2 => $subfeedquery) +
|
if ( ! $page )
|
||||||
array($sub2 => $subquery, $sub2tb => $subtbquery, $sub2feed => $subfeedquery, $sub2feed2 => $subfeedquery);
|
$rewrite = $rewrite + array($sub1 => $subquery, $sub1tb => $subtbquery, $sub1feed => $subfeedquery, $sub1feed2 => $subfeedquery);
|
||||||
|
$rewrite = $rewrite + array($sub2 => $subquery, $sub2tb => $subtbquery, $sub2feed => $subfeedquery, $sub2feed2 => $subfeedquery);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -795,18 +795,30 @@ function generate_page_rewrite_rules() {
|
|||||||
$posts = array_reverse($posts, true);
|
$posts = array_reverse($posts, true);
|
||||||
|
|
||||||
$page_rewrite_rules = array();
|
$page_rewrite_rules = array();
|
||||||
|
$page_attachment_rewrite_rules = array();
|
||||||
|
|
||||||
if ($posts) {
|
if ($posts) {
|
||||||
|
|
||||||
foreach ($posts as $id => $post) {
|
foreach ($posts as $id => $post) {
|
||||||
|
|
||||||
// URI => page name
|
// URI => page name
|
||||||
$uri = get_page_uri($id);
|
$uri = get_page_uri($id);
|
||||||
|
$attachments = $wpdb->get_results("SELECT ID, post_name, post_parent FROM $wpdb->posts WHERE post_status = 'attachment' AND post_parent = '$id'");
|
||||||
|
if ( $attachments ) {
|
||||||
|
foreach ( $attachments as $attachment ) {
|
||||||
|
$attach_uri = get_page_uri($attachment->ID);
|
||||||
|
$page_attachment_rewrite_rules[$attach_uri] = $attachment->post_name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$page_rewrite_rules[$uri] = $post;
|
$page_rewrite_rules[$uri] = $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
update_option('page_uris', $page_rewrite_rules);
|
update_option('page_uris', $page_rewrite_rules);
|
||||||
|
|
||||||
|
if ( $page_attachment_rewrite_rules )
|
||||||
|
update_option('page_attachment_uris', $page_attachment_rewrite_rules);
|
||||||
|
|
||||||
save_mod_rewrite_rules();
|
save_mod_rewrite_rules();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user