2007-08-17 05:45:59 +02:00
< ? php
2007-12-25 21:48:47 +01:00
/**
* Canonical API to handle WordPress Redirecting
*
2008-05-25 17:45:05 +02:00
* Based on " Permalink Redirect " from Scott Yang and " Enforce www. Preference "
* by Mark Jaquith
2007-12-25 21:48:47 +01:00
*
* @ package WordPress
2008-08-27 08:45:13 +02:00
* @ since 2.3 . 0
2007-12-25 21:48:47 +01:00
*/
/**
2008-08-27 08:45:13 +02:00
* Redirects incoming links to the proper URL based on the site url .
2007-12-25 21:48:47 +01:00
*
2008-05-25 17:45:05 +02:00
* Search engines consider www . somedomain . com and somedomain . com to be two
* different URLs when they both go to the same location . This SEO enhancement
2011-09-03 18:02:41 +02:00
* prevents penalty for duplicate content by redirecting all incoming links to
2008-05-25 17:45:05 +02:00
* one or the other .
2007-12-25 21:48:47 +01:00
*
2015-12-10 04:06:30 +01:00
* Prevents redirection for feeds , trackbacks , searches , and
2013-07-08 22:27:06 +02:00
* admin URLs . Does not redirect on non - pretty - permalink - supporting IIS 7 + ,
Bootstrap/Load: Make handling the `/favicon.ico` requests more flexible.
Previously, `wp_favicon_request()` was introduced in [13205] to avoid a performance hit of serving a full 404 page on every favicon request.
While working as intended, that implementation did not provide a way for theme or plugin authors to manage the behavior of favicon requests.
This changeset implements the following logic (only applied if WordPress is installed in the root directory):
* If there is a Site Icon set in Customizer, redirect `/favicon.ico` requests to that icon.
* Otherwise, use the WordPress logo as a default icon.
* If a physical `/favicon.ico` file exists, do nothing, let the server handle the request.
Handling `/favicon.ico` is now more consistent with handling `/robots.txt` requests.
New functions and hooks:
* Introduce `is_favicon()` conditional tag to complement `is_robots()`.
* Introduce `do_favicon` action to complement `do_robots` and use it in template loader.
* Introduce `do_favicon()` function, hooked to the above action by default, to complement `do_robots()`.
* Introduce `do_faviconico` action to complement `do_robotstxt`, for plugins to override the default behavior.
* Mark `wp_favicon_request()` as deprecated in favor of `do_favicon()`.
Props jonoaldersonwp, birgire, joostdevalk, mukesh27, SergeyBiryukov.
Fixes #47398.
Built from https://develop.svn.wordpress.org/trunk@47018
git-svn-id: http://core.svn.wordpress.org/trunk@46818 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-12-28 22:20:04 +01:00
* page / post previews , WP admin , Trackbacks , robots . txt , favicon . ico , searches ,
* or on POST requests .
2007-12-25 21:48:47 +01:00
*
2008-05-25 17:45:05 +02:00
* Will also attempt to find the correct link when a user enters a URL that does
* not exist based on exact WordPress query . Will instead try to parse the URL
* or query in an attempt to figure the correct page to go to .
2007-12-25 21:48:47 +01:00
*
2008-08-27 08:45:13 +02:00
* @ since 2.3 . 0
2015-05-22 06:26:26 +02:00
*
2019-08-04 03:19:56 +02:00
* @ global WP_Rewrite $wp_rewrite WordPress rewrite component .
2019-08-04 03:59:56 +02:00
* @ global bool $is_IIS
* @ global WP_Query $wp_query WordPress Query object .
* @ global wpdb $wpdb WordPress database abstraction object .
* @ global WP $wp Current WordPress environment instance .
2007-12-25 21:48:47 +01:00
*
2008-05-25 17:45:05 +02:00
* @ param string $requested_url Optional . The URL that was requested , used to
2017-12-01 00:11:00 +01:00
* figure if redirect is needed .
2007-12-25 21:48:47 +01:00
* @ param bool $do_redirect Optional . Redirect to the new URL .
2015-05-24 07:40:25 +02:00
* @ return string | void The string of the URL , if redirect needed .
2007-12-25 21:48:47 +01:00
*/
2010-12-08 12:04:40 +01:00
function redirect_canonical ( $requested_url = null , $do_redirect = true ) {
2015-09-28 00:11:25 +02:00
global $wp_rewrite , $is_IIS , $wp_query , $wpdb , $wp ;
2007-08-17 05:45:59 +02:00
2020-04-05 05:02:11 +02:00
if ( isset ( $_SERVER [ 'REQUEST_METHOD' ] ) && ! in_array ( strtoupper ( $_SERVER [ 'REQUEST_METHOD' ] ), array ( 'GET' , 'HEAD' ), true ) ) {
2014-07-02 16:11:14 +02:00
return ;
}
2014-06-28 04:13:15 +02:00
// If we're not in wp-admin and the post has been published and preview nonce
2020-01-29 01:45:18 +01:00
// is non-existent or invalid then no need for preview in query.
2020-05-04 11:05:08 +02:00
if ( is_preview () && get_query_var ( 'p' ) && 'publish' === get_post_status ( get_query_var ( 'p' ) ) ) {
2014-06-28 04:13:15 +02:00
if ( ! isset ( $_GET [ 'preview_id' ] )
|| ! isset ( $_GET [ 'preview_nonce' ] )
2020-05-04 11:05:08 +02:00
|| ! wp_verify_nonce ( $_GET [ 'preview_nonce' ], 'post_preview_' . ( int ) $_GET [ 'preview_id' ] )
) {
2014-06-28 04:13:15 +02:00
$wp_query -> is_preview = false ;
}
}
2020-05-04 11:05:08 +02:00
if ( is_admin () || is_search () || is_preview () || is_trackback ()
|| is_robots () || is_favicon ()
|| ( $is_IIS && ! iis7_supports_permalinks () )
) {
2007-08-17 05:45:59 +02:00
return ;
2014-07-02 16:11:14 +02:00
}
2007-08-17 05:45:59 +02:00
2015-08-28 05:31:20 +02:00
if ( ! $requested_url && isset ( $_SERVER [ 'HTTP_HOST' ] ) ) {
2020-01-29 01:45:18 +01:00
// Build the URL in the address bar.
2010-02-26 07:21:47 +01:00
$requested_url = is_ssl () ? 'https://' : 'http://' ;
2007-09-11 23:21:40 +02:00
$requested_url .= $_SERVER [ 'HTTP_HOST' ];
$requested_url .= $_SERVER [ 'REQUEST_URI' ];
}
2007-08-17 05:45:59 +02:00
2020-04-24 09:28:10 +02:00
$original = parse_url ( $requested_url );
2015-10-01 07:09:50 +02:00
if ( false === $original ) {
2007-08-17 05:45:59 +02:00
return ;
2015-10-01 07:09:50 +02:00
}
2008-02-05 07:47:27 +01:00
2017-12-01 00:11:00 +01:00
$redirect = $original ;
2007-08-17 05:45:59 +02:00
$redirect_url = false ;
2020-01-29 01:45:18 +01:00
// Notice fixing.
2017-12-01 00:11:00 +01:00
if ( ! isset ( $redirect [ 'path' ] ) ) {
2010-03-28 08:05:50 +02:00
$redirect [ 'path' ] = '' ;
2017-12-01 00:11:00 +01:00
}
if ( ! isset ( $redirect [ 'query' ] ) ) {
2010-03-28 08:05:50 +02:00
$redirect [ 'query' ] = '' ;
2017-12-01 00:11:00 +01:00
}
2008-11-04 04:22:24 +01:00
2020-01-29 01:45:18 +01:00
/*
* If the original URL ended with non - breaking spaces , they were almost
* certainly inserted by accident . Let 's remove them, so the reader doesn' t
* see a 404 error with no obvious cause .
*/
2015-03-20 02:02:28 +01:00
$redirect [ 'path' ] = preg_replace ( '|(%C2%A0)+$|i' , '' , $redirect [ 'path' ] );
2020-01-29 01:45:18 +01:00
// It's not a preview, so remove it from URL.
2014-06-30 19:19:14 +02:00
if ( get_query_var ( 'preview' ) ) {
2014-06-28 04:13:15 +02:00
$redirect [ 'query' ] = remove_query_arg ( 'preview' , $redirect [ 'query' ] );
}
2020-05-04 11:05:08 +02:00
$post_id = get_query_var ( 'p' );
if ( is_feed () && $post_id ) {
$redirect_url = get_post_comments_feed_link ( $post_id , get_query_var ( 'feed' ) );
2019-07-03 01:42:58 +02:00
if ( $redirect_url ) {
2020-05-04 11:05:08 +02:00
$redirect [ 'query' ] = _remove_qs_args_if_not_in_url (
$redirect [ 'query' ],
array ( 'p' , 'page_id' , 'attachment_id' , 'pagename' , 'name' , 'post_type' , 'feed' ),
$redirect_url
);
$redirect [ 'path' ] = parse_url ( $redirect_url , PHP_URL_PATH );
2012-04-07 07:02:45 +02:00
}
}
2020-05-04 11:05:08 +02:00
if ( is_singular () && $wp_query -> post_count < 1 && $post_id ) {
2008-09-08 03:50:08 +02:00
2020-05-04 11:05:08 +02:00
$vars = $wpdb -> get_results ( $wpdb -> prepare ( " SELECT post_type, post_parent FROM $wpdb->posts WHERE ID = %d " , $post_id ) );
2008-09-08 03:50:08 +02:00
2019-07-03 01:42:58 +02:00
if ( ! empty ( $vars [ 0 ] ) ) {
$vars = $vars [ 0 ];
2020-05-04 11:05:08 +02:00
if ( 'revision' === $vars -> post_type && $vars -> post_parent > 0 ) {
$post_id = $vars -> post_parent ;
2017-12-01 00:11:00 +01:00
}
2008-09-08 03:50:08 +02:00
2020-05-04 11:05:08 +02:00
$redirect_url = get_permalink ( $post_id );
2019-07-03 01:42:58 +02:00
if ( $redirect_url ) {
2020-05-04 11:05:08 +02:00
$redirect [ 'query' ] = _remove_qs_args_if_not_in_url (
$redirect [ 'query' ],
array ( 'p' , 'page_id' , 'attachment_id' , 'pagename' , 'name' , 'post_type' ),
$redirect_url
);
2017-12-01 00:11:00 +01:00
}
2008-09-08 03:50:08 +02:00
}
}
2020-01-29 01:45:18 +01:00
// These tests give us a WP-generated permalink.
2007-08-17 05:45:59 +02:00
if ( is_404 () ) {
2010-05-03 02:37:11 +02:00
2020-01-29 01:45:18 +01:00
// Redirect ?page_id, ?p=, ?attachment_id= to their respective URLs.
2020-05-04 11:05:08 +02:00
$post_id = max ( get_query_var ( 'p' ), get_query_var ( 'page_id' ), get_query_var ( 'attachment_id' ) );
$redirect_post = $post_id ? get_post ( $post_id ) : false ;
2019-07-03 01:42:58 +02:00
if ( $redirect_post ) {
2017-12-01 00:11:00 +01:00
$post_type_obj = get_post_type_object ( $redirect_post -> post_type );
2020-05-04 11:05:08 +02:00
if ( $post_type_obj -> public && 'auto-draft' !== $redirect_post -> post_status ) {
$redirect_url = get_permalink ( $redirect_post );
$redirect [ 'query' ] = _remove_qs_args_if_not_in_url (
$redirect [ 'query' ],
array ( 'p' , 'page_id' , 'attachment_id' , 'pagename' , 'name' , 'post_type' ),
$redirect_url
);
2010-05-13 17:09:43 +02:00
}
}
2010-05-03 22:26:11 +02:00
2020-05-04 11:05:08 +02:00
$year = get_query_var ( 'year' );
$month = get_query_var ( 'monthnum' );
$day = get_query_var ( 'day' );
if ( $year && $month && $day ) {
$date = sprintf ( '%04d-%02d-%02d' , $year , $month , $day );
2013-09-06 18:36:09 +02:00
if ( ! wp_checkdate ( $month , $day , $year , $date ) ) {
2020-05-04 11:05:08 +02:00
$redirect_url = get_month_link ( $year , $month );
$redirect [ 'query' ] = _remove_qs_args_if_not_in_url (
$redirect [ 'query' ],
array ( 'year' , 'monthnum' , 'day' ),
$redirect_url
);
2013-09-06 18:36:09 +02:00
}
2020-05-04 11:05:08 +02:00
} elseif ( $year && $month && $month > 12 ) {
$redirect_url = get_year_link ( $year );
$redirect [ 'query' ] = _remove_qs_args_if_not_in_url (
$redirect [ 'query' ],
array ( 'year' , 'monthnum' ),
$redirect_url
);
2013-09-06 18:36:09 +02:00
}
2020-05-04 12:42:07 +02:00
// Strip off non-existing <!--nextpage--> links from single posts or pages.
if ( get_query_var ( 'page' ) ) {
$post_id = 0 ;
if ( $wp_query -> queried_object instanceof WP_Post ) {
$post_id = $wp_query -> queried_object -> ID ;
} elseif ( $wp_query -> post ) {
$post_id = $wp_query -> post -> ID ;
}
2020-05-04 12:49:07 +02:00
if ( $post_id ) {
$redirect_url = get_permalink ( $post_id );
2020-05-04 12:42:07 +02:00
2020-05-04 12:49:07 +02:00
$redirect [ 'path' ] = rtrim ( $redirect [ 'path' ], ( int ) get_query_var ( 'page' ) . '/' );
$redirect [ 'query' ] = remove_query_arg ( 'page' , $redirect [ 'query' ] );
}
2020-05-04 12:42:07 +02:00
}
2012-04-06 21:49:34 +02:00
if ( ! $redirect_url ) {
2019-07-03 01:42:58 +02:00
$redirect_url = redirect_guess_404_permalink ();
2020-05-04 11:05:08 +02:00
2019-07-03 01:42:58 +02:00
if ( $redirect_url ) {
2020-05-04 11:05:08 +02:00
$redirect [ 'query' ] = _remove_qs_args_if_not_in_url (
$redirect [ 'query' ],
array ( 'page' , 'feed' , 'p' , 'page_id' , 'attachment_id' , 'pagename' , 'name' , 'post_type' ),
$redirect_url
);
2012-04-07 03:03:55 +02:00
}
2012-04-06 21:49:34 +02:00
}
2017-12-01 00:11:00 +01:00
} elseif ( is_object ( $wp_rewrite ) && $wp_rewrite -> using_permalinks () ) {
2020-05-04 11:05:08 +02:00
2020-01-29 01:45:18 +01:00
// Rewriting of old ?p=X, ?m=2004, ?m=200401, ?m=20040101.
2020-05-04 11:05:08 +02:00
if ( is_attachment ()
&& ! array_diff ( array_keys ( $wp -> query_vars ), array ( 'attachment' , 'attachment_id' ) )
&& ! $redirect_url
) {
2015-09-17 23:32:24 +02:00
if ( ! empty ( $_GET [ 'attachment_id' ] ) ) {
$redirect_url = get_attachment_link ( get_query_var ( 'attachment_id' ) );
2020-05-04 11:05:08 +02:00
2015-09-17 23:32:24 +02:00
if ( $redirect_url ) {
$redirect [ 'query' ] = remove_query_arg ( 'attachment_id' , $redirect [ 'query' ] );
}
} else {
$redirect_url = get_attachment_link ();
}
2017-12-01 00:11:00 +01:00
} elseif ( is_single () && ! empty ( $_GET [ 'p' ] ) && ! $redirect_url ) {
2019-07-03 01:42:58 +02:00
$redirect_url = get_permalink ( get_query_var ( 'p' ) );
2020-05-04 11:05:08 +02:00
2019-07-03 01:42:58 +02:00
if ( $redirect_url ) {
2017-12-01 00:11:00 +01:00
$redirect [ 'query' ] = remove_query_arg ( array ( 'p' , 'post_type' ), $redirect [ 'query' ] );
}
} elseif ( is_single () && ! empty ( $_GET [ 'name' ] ) && ! $redirect_url ) {
2019-07-03 01:42:58 +02:00
$redirect_url = get_permalink ( $wp_query -> get_queried_object_id () );
2020-05-04 11:05:08 +02:00
2019-07-03 01:42:58 +02:00
if ( $redirect_url ) {
2017-12-01 00:11:00 +01:00
$redirect [ 'query' ] = remove_query_arg ( 'name' , $redirect [ 'query' ] );
}
} elseif ( is_page () && ! empty ( $_GET [ 'page_id' ] ) && ! $redirect_url ) {
2019-07-03 01:42:58 +02:00
$redirect_url = get_permalink ( get_query_var ( 'page_id' ) );
2020-05-04 11:05:08 +02:00
2019-07-03 01:42:58 +02:00
if ( $redirect_url ) {
2017-12-01 00:11:00 +01:00
$redirect [ 'query' ] = remove_query_arg ( 'page_id' , $redirect [ 'query' ] );
}
2020-05-04 11:05:08 +02:00
} elseif ( is_page () && ! is_feed () && ! $redirect_url
&& 'page' === get_option ( 'show_on_front' ) && get_queried_object_id () === ( int ) get_option ( 'page_on_front' )
) {
2017-12-01 00:11:00 +01:00
$redirect_url = home_url ( '/' );
2020-05-04 11:05:08 +02:00
} elseif ( is_home () && ! empty ( $_GET [ 'page_id' ] ) && ! $redirect_url
&& 'page' === get_option ( 'show_on_front' ) && get_query_var ( 'page_id' ) === ( int ) get_option ( 'page_for_posts' )
) {
2019-07-03 01:42:58 +02:00
$redirect_url = get_permalink ( get_option ( 'page_for_posts' ) );
2020-05-04 11:05:08 +02:00
2019-07-03 01:42:58 +02:00
if ( $redirect_url ) {
2017-12-01 00:11:00 +01:00
$redirect [ 'query' ] = remove_query_arg ( 'page_id' , $redirect [ 'query' ] );
}
} elseif ( ! empty ( $_GET [ 'm' ] ) && ( is_year () || is_month () || is_day () ) ) {
$m = get_query_var ( 'm' );
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
switch ( strlen ( $m ) ) {
2020-01-29 01:45:18 +01:00
case 4 : // Yearly.
2017-12-01 00:11:00 +01:00
$redirect_url = get_year_link ( $m );
2007-08-17 05:45:59 +02:00
break ;
2020-01-29 01:45:18 +01:00
case 6 : // Monthly.
2017-12-01 00:11:00 +01:00
$redirect_url = get_month_link ( substr ( $m , 0 , 4 ), substr ( $m , 4 , 2 ) );
2007-08-17 05:45:59 +02:00
break ;
2020-01-29 01:45:18 +01:00
case 8 : // Daily.
2017-12-01 00:11:00 +01:00
$redirect_url = get_day_link ( substr ( $m , 0 , 4 ), substr ( $m , 4 , 2 ), substr ( $m , 6 , 2 ) );
2007-08-17 05:45:59 +02:00
break ;
}
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
if ( $redirect_url ) {
$redirect [ 'query' ] = remove_query_arg ( 'm' , $redirect [ 'query' ] );
}
2020-01-29 01:45:18 +01:00
// Now moving on to non ?m=X year/month/day links.
2020-05-04 11:05:08 +02:00
} elseif ( is_date () ) {
$year = get_query_var ( 'year' );
$month = get_query_var ( 'monthnum' );
$day = get_query_var ( 'day' );
if ( is_day () && $year && $month && ! empty ( $_GET [ 'day' ] ) ) {
$redirect_url = get_day_link ( $year , $month , $day );
if ( $redirect_url ) {
$redirect [ 'query' ] = remove_query_arg ( array ( 'year' , 'monthnum' , 'day' ), $redirect [ 'query' ] );
}
} elseif ( is_month () && $year && ! empty ( $_GET [ 'monthnum' ] ) ) {
$redirect_url = get_month_link ( $year , $month );
if ( $redirect_url ) {
$redirect [ 'query' ] = remove_query_arg ( array ( 'year' , 'monthnum' ), $redirect [ 'query' ] );
}
} elseif ( is_year () && ! empty ( $_GET [ 'year' ] ) ) {
$redirect_url = get_year_link ( $year );
if ( $redirect_url ) {
$redirect [ 'query' ] = remove_query_arg ( 'year' , $redirect [ 'query' ] );
}
2017-12-01 00:11:00 +01:00
}
} elseif ( is_author () && ! empty ( $_GET [ 'author' ] ) && preg_match ( '|^[0-9]+$|' , $_GET [ 'author' ] ) ) {
$author = get_userdata ( get_query_var ( 'author' ) );
2020-05-04 11:05:08 +02:00
if ( false !== $author
&& $wpdb -> get_var ( $wpdb -> prepare ( " SELECT ID FROM $wpdb->posts WHERE $wpdb->posts .post_author = %d AND $wpdb->posts .post_status = 'publish' LIMIT 1 " , $author -> ID ) )
) {
2019-07-03 01:42:58 +02:00
$redirect_url = get_author_posts_url ( $author -> ID , $author -> user_nicename );
2020-05-04 11:05:08 +02:00
2019-07-03 01:42:58 +02:00
if ( $redirect_url ) {
2017-12-01 00:11:00 +01:00
$redirect [ 'query' ] = remove_query_arg ( 'author' , $redirect [ 'query' ] );
}
2011-05-23 01:18:06 +02:00
}
2020-01-29 01:45:18 +01:00
} elseif ( is_category () || is_tag () || is_tax () ) { // Terms (tags/categories).
2010-02-28 03:49:01 +01:00
$term_count = 0 ;
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
foreach ( $wp_query -> tax_query -> queried_terms as $tax_query ) {
2010-09-14 13:34:40 +02:00
$term_count += count ( $tax_query [ 'terms' ] );
2017-12-01 00:11:00 +01:00
}
2007-08-17 05:45:59 +02:00
2010-02-16 10:08:26 +01:00
$obj = $wp_query -> get_queried_object ();
2020-05-04 11:05:08 +02:00
2019-07-03 01:42:58 +02:00
if ( $term_count <= 1 && ! empty ( $obj -> term_id ) ) {
$tax_url = get_term_link ( ( int ) $obj -> term_id , $obj -> taxonomy );
2020-05-04 11:05:08 +02:00
2019-07-03 01:42:58 +02:00
if ( $tax_url && ! is_wp_error ( $tax_url ) ) {
if ( ! empty ( $redirect [ 'query' ] ) ) {
2020-01-29 01:45:18 +01:00
// Strip taxonomy query vars off the URL.
2019-07-03 01:42:58 +02:00
$qv_remove = array ( 'term' , 'taxonomy' );
2020-05-04 11:05:08 +02:00
2019-07-03 01:42:58 +02:00
if ( is_category () ) {
$qv_remove [] = 'category_name' ;
$qv_remove [] = 'cat' ;
} elseif ( is_tag () ) {
$qv_remove [] = 'tag' ;
$qv_remove [] = 'tag_id' ;
2020-01-29 01:45:18 +01:00
} else {
// Custom taxonomies will have a custom query var, remove those too.
2019-07-03 01:42:58 +02:00
$tax_obj = get_taxonomy ( $obj -> taxonomy );
if ( false !== $tax_obj -> query_var ) {
$qv_remove [] = $tax_obj -> query_var ;
}
2017-12-01 00:11:00 +01:00
}
2011-04-26 12:49:00 +02:00
2019-07-03 01:42:58 +02:00
$rewrite_vars = array_diff ( array_keys ( $wp_query -> query ), array_keys ( $_GET ) );
2011-05-31 08:13:27 +02:00
2020-01-29 01:45:18 +01:00
// Check to see if all the query vars are coming from the rewrite, none are set via $_GET.
if ( ! array_diff ( $rewrite_vars , array_keys ( $_GET ) ) ) {
// Remove all of the per-tax query vars.
$redirect [ 'query' ] = remove_query_arg ( $qv_remove , $redirect [ 'query' ] );
2011-05-31 08:13:27 +02:00
2020-01-29 01:45:18 +01:00
// Create the destination URL for this taxonomy.
2019-07-03 01:42:58 +02:00
$tax_url = parse_url ( $tax_url );
2020-05-04 11:05:08 +02:00
2020-01-29 01:45:18 +01:00
if ( ! empty ( $tax_url [ 'query' ] ) ) {
// Taxonomy accessible via ?taxonomy=...&term=... or any custom query var.
2019-07-03 01:42:58 +02:00
parse_str ( $tax_url [ 'query' ], $query_vars );
$redirect [ 'query' ] = add_query_arg ( $query_vars , $redirect [ 'query' ] );
2020-01-29 01:45:18 +01:00
} else {
// Taxonomy is accessible via a "pretty URL".
2019-07-03 01:42:58 +02:00
$redirect [ 'path' ] = $tax_url [ 'path' ];
}
2020-01-29 01:45:18 +01:00
} else {
// Some query vars are set via $_GET. Unset those from $_GET that exist via the rewrite.
2019-07-03 01:42:58 +02:00
foreach ( $qv_remove as $_qv ) {
if ( isset ( $rewrite_vars [ $_qv ] ) ) {
$redirect [ 'query' ] = remove_query_arg ( $_qv , $redirect [ 'query' ] );
}
2017-12-01 00:11:00 +01:00
}
2011-05-31 08:13:27 +02:00
}
2011-04-26 12:49:00 +02:00
}
2010-02-16 10:08:26 +01:00
}
2010-02-13 07:17:59 +01:00
}
2019-07-03 01:42:58 +02:00
} elseif ( is_single () && strpos ( $wp_rewrite -> permalink_structure , '%category%' ) !== false ) {
2020-05-04 11:05:08 +02:00
$category_name = get_query_var ( 'category_name' );
if ( $category_name ) {
$category = get_category_by_path ( $category_name );
if ( ! $category || is_wp_error ( $category )
|| ! has_term ( $category -> term_id , 'category' , $wp_query -> get_queried_object_id () )
) {
2019-07-03 01:42:58 +02:00
$redirect_url = get_permalink ( $wp_query -> get_queried_object_id () );
}
2016-04-20 17:35:27 +02:00
}
2010-02-13 07:17:59 +01:00
}
2020-05-04 11:05:08 +02:00
// Post paging.
2017-12-01 00:11:00 +01:00
if ( is_singular () && get_query_var ( 'page' ) ) {
2020-05-04 11:05:08 +02:00
$page = get_query_var ( 'page' );
2017-12-01 00:11:00 +01:00
if ( ! $redirect_url ) {
2012-04-07 07:18:50 +02:00
$redirect_url = get_permalink ( get_queried_object_id () );
2017-12-01 00:11:00 +01:00
}
2016-01-09 08:33:27 +01:00
if ( $page > 1 ) {
2020-05-04 11:05:08 +02:00
$redirect_url = trailingslashit ( $redirect_url );
2016-01-09 08:33:27 +01:00
if ( is_front_page () ) {
2020-05-04 11:05:08 +02:00
$redirect_url .= user_trailingslashit ( " $wp_rewrite->pagination_base / $page " , 'paged' );
2016-01-09 08:33:27 +01:00
} else {
2020-05-04 11:05:08 +02:00
$redirect_url .= user_trailingslashit ( $page , 'single_paged' );
2016-01-09 08:33:27 +01:00
}
}
2020-05-04 11:05:08 +02:00
$redirect [ 'query' ] = remove_query_arg ( 'page' , $redirect [ 'query' ] );
2010-10-04 13:30:11 +02:00
}
2020-05-04 11:05:08 +02:00
// Paging and feeds.
2017-12-01 00:11:00 +01:00
if ( get_query_var ( 'paged' ) || is_feed () || get_query_var ( 'cpage' ) ) {
2020-05-04 11:05:08 +02:00
$paged = get_query_var ( 'paged' );
$feed = get_query_var ( 'feed' );
$cpage = get_query_var ( 'cpage' );
while ( preg_match ( " #/ $wp_rewrite->pagination_base /?[0-9]+?(/+)? $ # " , $redirect [ 'path' ] )
|| preg_match ( '#/(comments/?)?(feed|rss2?|rdf|atom)(/+)?$#' , $redirect [ 'path' ] )
|| preg_match ( " #/ { $wp_rewrite -> comments_pagination_base } -[0-9]+(/+)? $ # " , $redirect [ 'path' ] )
) {
// Strip off any existing paging.
$redirect [ 'path' ] = preg_replace ( " #/ $wp_rewrite->pagination_base /?[0-9]+?(/+)? $ # " , '/' , $redirect [ 'path' ] );
// Strip off feed endings.
$redirect [ 'path' ] = preg_replace ( '#/(comments/?)?(feed|rss2?|rdf|atom)(/+|$)#' , '/' , $redirect [ 'path' ] );
// Strip off any existing comment paging.
$redirect [ 'path' ] = preg_replace ( " #/ { $wp_rewrite -> comments_pagination_base } -[0-9]+?(/+)? $ # " , '/' , $redirect [ 'path' ] );
}
$addl_path = '' ;
$default_feed = get_default_feed ();
if ( is_feed () && in_array ( $feed , $wp_rewrite -> feeds , true ) ) {
2017-12-01 00:11:00 +01:00
$addl_path = ! empty ( $addl_path ) ? trailingslashit ( $addl_path ) : '' ;
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
if ( ! is_singular () && get_query_var ( 'withcomments' ) ) {
2008-11-25 22:28:42 +01:00
$addl_path .= 'comments/' ;
2017-12-01 00:11:00 +01:00
}
2020-05-04 11:05:08 +02:00
if ( ( 'rss' === $default_feed && 'feed' === $feed ) || 'rss' === $feed ) {
$format = ( 'rss2' === $default_feed ) ? '' : 'rss2' ;
2017-12-01 00:11:00 +01:00
} else {
2020-05-04 11:05:08 +02:00
$format = ( $default_feed === $feed || 'feed' === $feed ) ? '' : $feed ;
2017-12-01 00:11:00 +01:00
}
2020-05-04 11:05:08 +02:00
$addl_path .= user_trailingslashit ( 'feed/' . $format , 'feed' );
2008-11-14 23:48:22 +01:00
$redirect [ 'query' ] = remove_query_arg ( 'feed' , $redirect [ 'query' ] );
2020-05-04 11:05:08 +02:00
} elseif ( is_feed () && 'old' === $feed ) {
2011-08-12 03:41:23 +02:00
$old_feed_files = array (
'wp-atom.php' => 'atom' ,
'wp-commentsrss2.php' => 'comments_rss2' ,
2020-05-04 11:05:08 +02:00
'wp-feed.php' => $default_feed ,
2011-11-20 19:32:42 +01:00
'wp-rdf.php' => 'rdf' ,
2011-08-12 03:41:23 +02:00
'wp-rss.php' => 'rss2' ,
'wp-rss2.php' => 'rss2' ,
);
2020-05-04 11:05:08 +02:00
2011-08-12 03:41:23 +02:00
if ( isset ( $old_feed_files [ basename ( $redirect [ 'path' ] ) ] ) ) {
$redirect_url = get_feed_link ( $old_feed_files [ basename ( $redirect [ 'path' ] ) ] );
2020-05-04 11:05:08 +02:00
2011-08-12 03:41:23 +02:00
wp_redirect ( $redirect_url , 301 );
die ();
}
2008-10-14 07:51:01 +02:00
}
2020-05-04 11:05:08 +02:00
if ( $paged > 0 ) {
2008-11-14 23:48:22 +01:00
$redirect [ 'query' ] = remove_query_arg ( 'paged' , $redirect [ 'query' ] );
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
if ( ! is_feed () ) {
2020-05-04 11:05:08 +02:00
if ( ! is_single () ) {
2017-12-01 00:11:00 +01:00
$addl_path = ! empty ( $addl_path ) ? trailingslashit ( $addl_path ) : '' ;
2020-05-04 11:05:08 +02:00
if ( $paged > 1 ) {
$addl_path .= user_trailingslashit ( " $wp_rewrite->pagination_base / $paged " , 'paged' );
}
2008-11-14 23:48:22 +01:00
}
} elseif ( $paged > 1 ) {
$redirect [ 'query' ] = add_query_arg ( 'paged' , $paged , $redirect [ 'query' ] );
2007-08-29 23:06:51 +02:00
}
2007-08-17 05:45:59 +02:00
}
2008-11-14 23:48:22 +01:00
2020-05-04 11:05:08 +02:00
$default_comments_page = get_option ( 'default_comments_page' );
if ( get_option ( 'page_comments' )
&& ( 'newest' === $default_comments_page && $cpage > 0
|| 'newest' !== $default_comments_page && $cpage > 1 )
) {
$addl_path = ( ! empty ( $addl_path ) ? trailingslashit ( $addl_path ) : '' );
$addl_path .= user_trailingslashit ( $wp_rewrite -> comments_pagination_base . '-' . $cpage , 'commentpaged' );
2008-11-14 23:48:22 +01:00
$redirect [ 'query' ] = remove_query_arg ( 'cpage' , $redirect [ 'query' ] );
2008-10-23 20:55:22 +02:00
}
2008-11-14 23:48:22 +01:00
2020-05-04 11:05:08 +02:00
// Strip off trailing /index.php/.
$redirect [ 'path' ] = preg_replace ( '|/' . preg_quote ( $wp_rewrite -> index , '|' ) . '/?$|' , '/' , $redirect [ 'path' ] );
$redirect [ 'path' ] = user_trailingslashit ( $redirect [ 'path' ] );
if ( ! empty ( $addl_path )
&& $wp_rewrite -> using_index_permalinks ()
&& strpos ( $redirect [ 'path' ], '/' . $wp_rewrite -> index . '/' ) === false
) {
2017-12-01 00:11:00 +01:00
$redirect [ 'path' ] = trailingslashit ( $redirect [ 'path' ] ) . $wp_rewrite -> index . '/' ;
}
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
if ( ! empty ( $addl_path ) ) {
$redirect [ 'path' ] = trailingslashit ( $redirect [ 'path' ] ) . $addl_path ;
}
2020-05-04 11:05:08 +02:00
2010-12-14 17:55:35 +01:00
$redirect_url = $redirect [ 'scheme' ] . '://' . $redirect [ 'host' ] . $redirect [ 'path' ];
2007-08-17 05:45:59 +02:00
}
2012-04-25 22:49:57 +02:00
2020-05-04 11:05:08 +02:00
if ( 'wp-register.php' === basename ( $redirect [ 'path' ] ) ) {
2014-04-25 09:12:14 +02:00
if ( is_multisite () ) {
2013-10-25 00:59:20 +02:00
/** This filter is documented in wp-login.php */
2012-09-11 14:27:25 +02:00
$redirect_url = apply_filters ( 'wp_signup_location' , network_site_url ( 'wp-signup.php' ) );
2014-04-25 09:12:14 +02:00
} else {
2015-09-15 19:11:35 +02:00
$redirect_url = wp_registration_url ();
2014-04-25 09:12:14 +02:00
}
2012-04-25 22:49:57 +02:00
wp_redirect ( $redirect_url , 301 );
die ();
}
2007-08-17 05:45:59 +02:00
}
2008-11-14 23:48:22 +01:00
$redirect [ 'query' ] = preg_replace ( '#^\??&*?#' , '' , $redirect [ 'query' ] );
2020-05-04 11:05:08 +02:00
// Tack on any additional query vars.
2017-12-01 00:11:00 +01:00
if ( $redirect_url && ! empty ( $redirect [ 'query' ] ) ) {
2010-12-17 21:23:34 +01:00
parse_str ( $redirect [ 'query' ], $_parsed_query );
2020-04-24 09:28:10 +02:00
$redirect = parse_url ( $redirect_url );
2010-12-17 21:57:03 +01:00
if ( ! empty ( $_parsed_query [ 'name' ] ) && ! empty ( $redirect [ 'query' ] ) ) {
parse_str ( $redirect [ 'query' ], $_parsed_redirect_query );
2017-12-01 00:11:00 +01:00
if ( empty ( $_parsed_redirect_query [ 'name' ] ) ) {
2010-12-17 21:57:03 +01:00
unset ( $_parsed_query [ 'name' ] );
2017-12-01 00:11:00 +01:00
}
2010-12-17 21:57:03 +01:00
}
2019-04-08 03:10:55 +02:00
$_parsed_query = array_combine (
rawurlencode_deep ( array_keys ( $_parsed_query ) ),
rawurlencode_deep ( array_values ( $_parsed_query ) )
);
2020-05-04 11:05:08 +02:00
$redirect_url = add_query_arg ( $_parsed_query , $redirect_url );
2007-09-13 21:12:53 +02:00
}
2007-08-17 05:45:59 +02:00
2017-12-01 00:11:00 +01:00
if ( $redirect_url ) {
2020-04-24 09:28:10 +02:00
$redirect = parse_url ( $redirect_url );
2017-12-01 00:11:00 +01:00
}
2007-08-17 05:45:59 +02:00
2020-01-29 01:45:18 +01:00
// www.example.com vs. example.com
2020-04-24 09:28:10 +02:00
$user_home = parse_url ( home_url () );
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
if ( ! empty ( $user_home [ 'host' ] ) ) {
2008-05-09 20:23:05 +02:00
$redirect [ 'host' ] = $user_home [ 'host' ];
2017-12-01 00:11:00 +01:00
}
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
if ( empty ( $user_home [ 'path' ] ) ) {
2008-10-14 23:08:28 +02:00
$user_home [ 'path' ] = '/' ;
2017-12-01 00:11:00 +01:00
}
2007-08-17 05:45:59 +02:00
2020-01-29 01:45:18 +01:00
// Handle ports.
2017-12-01 00:11:00 +01:00
if ( ! empty ( $user_home [ 'port' ] ) ) {
2007-09-13 21:24:05 +02:00
$redirect [ 'port' ] = $user_home [ 'port' ];
2017-12-01 00:11:00 +01:00
} else {
unset ( $redirect [ 'port' ] );
}
2007-09-13 21:24:05 +02:00
2020-01-29 01:45:18 +01:00
// Trailing /index.php.
2017-12-01 00:11:00 +01:00
$redirect [ 'path' ] = preg_replace ( '|/' . preg_quote ( $wp_rewrite -> index , '|' ) . '/*?$|' , '/' , $redirect [ 'path' ] );
$punctuation_pattern = implode (
2018-08-17 03:51:36 +02:00
'|' ,
array_map (
'preg_quote' ,
array (
2017-12-01 00:11:00 +01:00
' ' ,
2020-01-29 01:45:18 +01:00
'%20' , // Space.
2017-12-01 00:11:00 +01:00
'!' ,
2020-01-29 01:45:18 +01:00
'%21' , // Exclamation mark.
2017-12-01 00:11:00 +01:00
'"' ,
2020-01-29 01:45:18 +01:00
'%22' , // Double quote.
2017-12-01 00:11:00 +01:00
" ' " ,
2020-01-29 01:45:18 +01:00
'%27' , // Single quote.
2017-12-01 00:11:00 +01:00
'(' ,
2020-01-29 01:45:18 +01:00
'%28' , // Opening bracket.
2017-12-01 00:11:00 +01:00
')' ,
2020-01-29 01:45:18 +01:00
'%29' , // Closing bracket.
2017-12-01 00:11:00 +01:00
',' ,
2020-01-29 01:45:18 +01:00
'%2C' , // Comma.
2017-12-01 00:11:00 +01:00
'.' ,
2020-01-29 01:45:18 +01:00
'%2E' , // Period.
2017-12-01 00:11:00 +01:00
';' ,
2020-01-29 01:45:18 +01:00
'%3B' , // Semicolon.
2017-12-01 00:11:00 +01:00
'{' ,
2020-01-29 01:45:18 +01:00
'%7B' , // Opening curly bracket.
2017-12-01 00:11:00 +01:00
'}' ,
2020-01-29 01:45:18 +01:00
'%7D' , // Closing curly bracket.
'%E2%80%9C' , // Opening curly quote.
'%E2%80%9D' , // Closing curly quote.
2017-12-01 00:11:00 +01:00
)
)
);
2017-10-24 16:18:48 +02:00
// Remove trailing spaces and end punctuation from the path.
$redirect [ 'path' ] = preg_replace ( " #( $punctuation_pattern )+ $ # " , '' , $redirect [ 'path' ] );
2008-08-19 05:21:12 +02:00
2017-12-01 00:11:00 +01:00
if ( ! empty ( $redirect [ 'query' ] ) ) {
2017-10-24 16:18:48 +02:00
// Remove trailing spaces and end punctuation from certain terminating query string args.
2020-02-03 01:14:07 +01:00
$redirect [ 'query' ] = preg_replace ( " #((^|&)(p|page_id|cat|tag)=[^&]*?)( $punctuation_pattern )+ $ # " , '$1' , $redirect [ 'query' ] );
2008-08-19 05:21:12 +02:00
2020-01-29 01:45:18 +01:00
// Clean up empty query strings.
2017-12-01 00:11:00 +01:00
$redirect [ 'query' ] = trim ( preg_replace ( '#(^|&)(p|page_id|cat|tag)=?(&|$)#' , '&' , $redirect [ 'query' ] ), '&' );
2008-11-12 21:09:16 +01:00
2020-01-29 01:45:18 +01:00
// Redirect obsolete feeds.
2013-06-22 14:09:28 +02:00
$redirect [ 'query' ] = preg_replace ( '#(^|&)feed=rss(&|$)#' , '$1feed=rss2$2' , $redirect [ 'query' ] );
2011-08-12 01:30:59 +02:00
2020-01-29 01:45:18 +01:00
// Remove redundant leading ampersands.
2008-11-14 23:48:22 +01:00
$redirect [ 'query' ] = preg_replace ( '#^\??&*?#' , '' , $redirect [ 'query' ] );
2008-08-25 23:50:11 +02:00
}
2008-08-19 05:21:12 +02:00
2020-01-29 01:45:18 +01:00
// Strip /index.php/ when we're not using PATHINFO permalinks.
2017-12-01 00:11:00 +01:00
if ( ! $wp_rewrite -> using_index_permalinks () ) {
2013-01-18 14:44:22 +01:00
$redirect [ 'path' ] = str_replace ( '/' . $wp_rewrite -> index . '/' , '/' , $redirect [ 'path' ] );
2017-12-01 00:11:00 +01:00
}
2007-08-17 05:45:59 +02:00
2020-01-29 01:45:18 +01:00
// Trailing slashes.
2020-05-04 11:05:08 +02:00
if ( is_object ( $wp_rewrite ) && $wp_rewrite -> using_permalinks ()
&& ! is_404 () && ( ! is_front_page () || is_front_page () && get_query_var ( 'paged' ) > 1 )
) {
2007-08-29 23:06:51 +02:00
$user_ts_type = '' ;
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
if ( get_query_var ( 'paged' ) > 0 ) {
2007-08-29 23:06:51 +02:00
$user_ts_type = 'paged' ;
} else {
2017-12-01 00:11:00 +01:00
foreach ( array ( 'single' , 'category' , 'page' , 'day' , 'month' , 'year' , 'home' ) as $type ) {
2007-08-29 23:06:51 +02:00
$func = 'is_' . $type ;
2017-12-01 00:11:00 +01:00
if ( call_user_func ( $func ) ) {
2007-08-29 23:06:51 +02:00
$user_ts_type = $type ;
break ;
}
}
2008-08-08 19:43:44 +02:00
}
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
$redirect [ 'path' ] = user_trailingslashit ( $redirect [ 'path' ], $user_ts_type );
2008-10-16 23:14:42 +02:00
} elseif ( is_front_page () ) {
2017-12-01 00:11:00 +01:00
$redirect [ 'path' ] = trailingslashit ( $redirect [ 'path' ] );
2007-08-29 23:06:51 +02:00
}
2020-01-29 01:45:18 +01:00
// Strip multiple slashes out of the URL.
2017-12-01 00:11:00 +01:00
if ( strpos ( $redirect [ 'path' ], '//' ) > - 1 ) {
$redirect [ 'path' ] = preg_replace ( '|/+|' , '/' , $redirect [ 'path' ] );
}
2010-02-13 01:11:23 +01:00
2020-01-29 01:45:18 +01:00
// Always trailing slash the Front Page URL.
2020-05-04 11:05:08 +02:00
if ( trailingslashit ( $redirect [ 'path' ] ) === trailingslashit ( $user_home [ 'path' ] ) ) {
2017-12-01 00:11:00 +01:00
$redirect [ 'path' ] = trailingslashit ( $redirect [ 'path' ] );
}
2007-09-11 23:21:40 +02:00
2020-05-04 11:05:08 +02:00
$original_host_low = strtolower ( $original [ 'host' ] );
$redirect_host_low = strtolower ( $redirect [ 'host' ] );
2020-01-29 01:45:18 +01:00
// Ignore differences in host capitalization, as this can lead to infinite redirects.
// Only redirect no-www <=> yes-www.
2020-05-04 11:05:08 +02:00
if ( $original_host_low === $redirect_host_low
|| ( 'www.' . $original_host_low !== $redirect_host_low
&& 'www.' . $redirect_host_low !== $original_host_low )
) {
2007-09-12 22:44:41 +02:00
$redirect [ 'host' ] = $original [ 'host' ];
2017-12-01 00:11:00 +01:00
}
2007-09-12 22:44:41 +02:00
2014-10-29 19:37:25 +01:00
$compare_original = array ( $original [ 'host' ], $original [ 'path' ] );
2008-08-08 19:05:10 +02:00
2017-12-01 00:11:00 +01:00
if ( ! empty ( $original [ 'port' ] ) ) {
2008-08-08 19:05:10 +02:00
$compare_original [] = $original [ 'port' ];
2017-12-01 00:11:00 +01:00
}
2008-08-08 19:05:10 +02:00
2017-12-01 00:11:00 +01:00
if ( ! empty ( $original [ 'query' ] ) ) {
2008-08-08 19:05:10 +02:00
$compare_original [] = $original [ 'query' ];
2017-12-01 00:11:00 +01:00
}
2008-08-08 19:05:10 +02:00
2014-10-29 19:37:25 +01:00
$compare_redirect = array ( $redirect [ 'host' ], $redirect [ 'path' ] );
2008-08-08 19:05:10 +02:00
2017-12-01 00:11:00 +01:00
if ( ! empty ( $redirect [ 'port' ] ) ) {
2008-08-08 19:05:10 +02:00
$compare_redirect [] = $redirect [ 'port' ];
2017-12-01 00:11:00 +01:00
}
2008-08-08 19:05:10 +02:00
2017-12-01 00:11:00 +01:00
if ( ! empty ( $redirect [ 'query' ] ) ) {
2008-08-08 19:05:10 +02:00
$compare_redirect [] = $redirect [ 'query' ];
2017-12-01 00:11:00 +01:00
}
2008-08-08 19:05:10 +02:00
if ( $compare_original !== $compare_redirect ) {
2007-09-13 21:24:05 +02:00
$redirect_url = $redirect [ 'scheme' ] . '://' . $redirect [ 'host' ];
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
if ( ! empty ( $redirect [ 'port' ] ) ) {
2008-10-27 17:31:26 +01:00
$redirect_url .= ':' . $redirect [ 'port' ];
2017-12-01 00:11:00 +01:00
}
2020-05-04 11:05:08 +02:00
2007-09-13 21:24:05 +02:00
$redirect_url .= $redirect [ 'path' ];
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
if ( ! empty ( $redirect [ 'query' ] ) ) {
2007-08-29 23:06:51 +02:00
$redirect_url .= '?' . $redirect [ 'query' ];
2017-12-01 00:11:00 +01:00
}
2007-08-17 05:45:59 +02:00
}
2020-05-04 11:05:08 +02:00
if ( ! $redirect_url || $redirect_url === $requested_url ) {
2015-05-21 22:30:25 +02:00
return ;
}
2010-10-21 21:55:28 +02:00
2010-10-19 09:48:22 +02:00
// Hex encoded octets are case-insensitive.
2017-12-01 00:11:00 +01:00
if ( false !== strpos ( $requested_url , '%' ) ) {
if ( ! function_exists ( 'lowercase_octets' ) ) {
2016-07-19 21:32:32 +02:00
/**
* Converts the first hex - encoded octet match to lowercase .
*
2016-07-19 21:34:29 +02:00
* @ since 3.1 . 0
2016-07-19 21:32:32 +02:00
* @ ignore
*
* @ param array $matches Hex - encoded octet matches for the requested URL .
* @ return string Lowercased version of the first match .
*/
2017-12-01 00:11:00 +01:00
function lowercase_octets ( $matches ) {
2010-10-19 09:48:22 +02:00
return strtolower ( $matches [ 0 ] );
}
2010-07-18 15:46:35 +02:00
}
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
$requested_url = preg_replace_callback ( '|%[a-fA-F0-9][a-fA-F0-9]|' , 'lowercase_octets' , $requested_url );
2010-07-18 15:46:35 +02:00
}
2013-09-21 01:31:10 +02:00
/**
2016-05-22 20:50:28 +02:00
* Filters the canonical redirect URL .
2013-09-21 01:31:10 +02:00
*
* Returning false to this filter will cancel the redirect .
*
* @ since 2.3 . 0
*
* @ param string $redirect_url The redirect URL .
* @ param string $requested_url The requested URL .
*/
$redirect_url = apply_filters ( 'redirect_canonical' , $redirect_url , $requested_url );
2008-02-06 23:57:15 +01:00
2020-01-29 01:45:18 +01:00
// Yes, again -- in case the filter aborted the request.
2020-05-04 11:05:08 +02:00
if ( ! $redirect_url || strip_fragment_from_url ( $redirect_url ) === strip_fragment_from_url ( $requested_url ) ) {
2015-05-21 22:30:25 +02:00
return ;
}
2008-02-06 23:57:15 +01:00
if ( $do_redirect ) {
2020-01-29 01:45:18 +01:00
// Protect against chained redirects.
2017-12-01 00:11:00 +01:00
if ( ! redirect_canonical ( $redirect_url , false ) ) {
wp_redirect ( $redirect_url , 301 );
2020-05-26 11:37:10 +02:00
exit ;
2007-09-11 23:21:40 +02:00
} else {
2020-01-29 01:45:18 +01:00
// Debug.
2008-10-14 07:51:01 +02:00
// die("1: $redirect_url<br />2: " . redirect_canonical( $redirect_url, false ) );
2015-05-21 22:30:25 +02:00
return ;
2007-09-11 23:21:40 +02:00
}
} else {
2008-02-06 23:57:15 +01:00
return $redirect_url ;
2007-08-17 05:45:59 +02:00
}
}
2012-04-07 03:03:55 +02:00
/**
* Removes arguments from a query string if they are not present in a URL
* DO NOT use this in plugin code .
*
2013-12-24 19:57:12 +01:00
* @ since 3.4 . 0
2012-04-07 03:03:55 +02:00
* @ access private
*
2014-12-01 02:34:24 +01:00
* @ param string $query_string
* @ param array $args_to_check
* @ param string $url
2012-04-07 03:03:55 +02:00
* @ return string The altered query string
*/
2017-12-01 00:11:00 +01:00
function _remove_qs_args_if_not_in_url ( $query_string , array $args_to_check , $url ) {
2020-04-24 09:28:10 +02:00
$parsed_url = parse_url ( $url );
2020-05-04 11:05:08 +02:00
2012-05-01 20:26:38 +02:00
if ( ! empty ( $parsed_url [ 'query' ] ) ) {
parse_str ( $parsed_url [ 'query' ], $parsed_query );
2020-05-04 11:05:08 +02:00
2012-05-01 20:26:38 +02:00
foreach ( $args_to_check as $qv ) {
2017-12-01 00:11:00 +01:00
if ( ! isset ( $parsed_query [ $qv ] ) ) {
2012-05-01 20:26:38 +02:00
$query_string = remove_query_arg ( $qv , $query_string );
2017-12-01 00:11:00 +01:00
}
2012-05-01 20:26:38 +02:00
}
} else {
$query_string = remove_query_arg ( $args_to_check , $query_string );
2012-04-07 03:03:55 +02:00
}
2020-05-04 11:05:08 +02:00
2012-04-07 03:03:55 +02:00
return $query_string ;
}
2015-12-05 00:11:26 +01:00
/**
* Strips the #fragment from a URL, if one is present.
*
* @ since 4.4 . 0
*
* @ param string $url The URL to strip .
* @ return string The altered URL .
*/
function strip_fragment_from_url ( $url ) {
2020-04-24 09:28:10 +02:00
$parsed_url = parse_url ( $url );
2020-05-04 11:05:08 +02:00
2015-12-05 00:11:26 +01:00
if ( ! empty ( $parsed_url [ 'host' ] ) ) {
// This mirrors code in redirect_canonical(). It does not handle every case.
$url = $parsed_url [ 'scheme' ] . '://' . $parsed_url [ 'host' ];
if ( ! empty ( $parsed_url [ 'port' ] ) ) {
$url .= ':' . $parsed_url [ 'port' ];
}
2017-08-16 23:11:43 +02:00
if ( ! empty ( $parsed_url [ 'path' ] ) ) {
$url .= $parsed_url [ 'path' ];
}
2015-12-05 00:11:26 +01:00
if ( ! empty ( $parsed_url [ 'query' ] ) ) {
$url .= '?' . $parsed_url [ 'query' ];
}
}
return $url ;
}
2007-12-25 21:48:47 +01:00
/**
2020-06-02 18:23:11 +02:00
* Attempts to guess the correct URL based on query vars .
2007-12-25 21:48:47 +01:00
*
2008-08-27 08:45:13 +02:00
* @ since 2.3 . 0
2014-10-31 18:56:22 +01:00
*
* @ global wpdb $wpdb WordPress database abstraction object .
2007-12-25 21:48:47 +01:00
*
2020-01-11 19:32:05 +01:00
* @ return string | false The correct URL if one is found . False on failure .
2007-12-25 21:48:47 +01:00
*/
2012-06-25 22:41:14 +02:00
function redirect_guess_404_permalink () {
2015-09-22 22:27:25 +02:00
global $wpdb ;
2012-01-28 21:40:55 +01:00
Canonical: Add the ability to disable `redirect_guess_404_permalink()`.
This also adds a few more filters to make adding redirects easier. Notably:
1. `do_redirect_guess_404_permalink`
2. `pre_redirect_guess_404_permalink`
3. `strict_redirect_guess_404_permalink`
Fixes: #16557.
Props: msafi, nacin, simonwheatley, westi, mboynes, joostdevalk, Lex_Robinson, MikeSchinkel, haukep, paulschreiber, DrewAPicture, ravenswd, esemlabel, stevegibson12, martychc23, DrLightman, jivanpal, neonkowy, laternastudio, apedog, audrasjb, davidbaumwald, Confridin, donmhico, ryotsun.
Built from https://develop.svn.wordpress.org/trunk@47878
git-svn-id: http://core.svn.wordpress.org/trunk@47652 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-01 20:49:10 +02:00
/**
* Filters whether to do redirect guess of 404 requests .
*
2020-06-02 18:23:11 +02:00
* Passing a false value to the filter will disable the URL guessing
Canonical: Add the ability to disable `redirect_guess_404_permalink()`.
This also adds a few more filters to make adding redirects easier. Notably:
1. `do_redirect_guess_404_permalink`
2. `pre_redirect_guess_404_permalink`
3. `strict_redirect_guess_404_permalink`
Fixes: #16557.
Props: msafi, nacin, simonwheatley, westi, mboynes, joostdevalk, Lex_Robinson, MikeSchinkel, haukep, paulschreiber, DrewAPicture, ravenswd, esemlabel, stevegibson12, martychc23, DrLightman, jivanpal, neonkowy, laternastudio, apedog, audrasjb, davidbaumwald, Confridin, donmhico, ryotsun.
Built from https://develop.svn.wordpress.org/trunk@47878
git-svn-id: http://core.svn.wordpress.org/trunk@47652 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-01 20:49:10 +02:00
* and return early .
*
* @ since 5.5 . 0
*
2020-06-02 18:23:11 +02:00
* @ param bool $do_redirect_guess Whether to do redirect guess 404 permalink .
* Default true .
Canonical: Add the ability to disable `redirect_guess_404_permalink()`.
This also adds a few more filters to make adding redirects easier. Notably:
1. `do_redirect_guess_404_permalink`
2. `pre_redirect_guess_404_permalink`
3. `strict_redirect_guess_404_permalink`
Fixes: #16557.
Props: msafi, nacin, simonwheatley, westi, mboynes, joostdevalk, Lex_Robinson, MikeSchinkel, haukep, paulschreiber, DrewAPicture, ravenswd, esemlabel, stevegibson12, martychc23, DrLightman, jivanpal, neonkowy, laternastudio, apedog, audrasjb, davidbaumwald, Confridin, donmhico, ryotsun.
Built from https://develop.svn.wordpress.org/trunk@47878
git-svn-id: http://core.svn.wordpress.org/trunk@47652 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-01 20:49:10 +02:00
*/
if ( false === apply_filters ( 'do_redirect_guess_404_permalink' , true ) ) {
return false ;
}
/**
* Filters whether to short - circuit redirect guess of 404 requests .
*
2020-06-02 18:23:11 +02:00
* Passing a non - null value to the filter will effectively short - circuit
* the URL guessing , returning the passed value instead .
Canonical: Add the ability to disable `redirect_guess_404_permalink()`.
This also adds a few more filters to make adding redirects easier. Notably:
1. `do_redirect_guess_404_permalink`
2. `pre_redirect_guess_404_permalink`
3. `strict_redirect_guess_404_permalink`
Fixes: #16557.
Props: msafi, nacin, simonwheatley, westi, mboynes, joostdevalk, Lex_Robinson, MikeSchinkel, haukep, paulschreiber, DrewAPicture, ravenswd, esemlabel, stevegibson12, martychc23, DrLightman, jivanpal, neonkowy, laternastudio, apedog, audrasjb, davidbaumwald, Confridin, donmhico, ryotsun.
Built from https://develop.svn.wordpress.org/trunk@47878
git-svn-id: http://core.svn.wordpress.org/trunk@47652 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-01 20:49:10 +02:00
*
* @ since 5.5 . 0
*
2020-06-02 18:23:11 +02:00
* @ param null | string $pre Whether to short - circuit redirect guess 404 permalink .
* Default null to continue with the URL guessing .
Canonical: Add the ability to disable `redirect_guess_404_permalink()`.
This also adds a few more filters to make adding redirects easier. Notably:
1. `do_redirect_guess_404_permalink`
2. `pre_redirect_guess_404_permalink`
3. `strict_redirect_guess_404_permalink`
Fixes: #16557.
Props: msafi, nacin, simonwheatley, westi, mboynes, joostdevalk, Lex_Robinson, MikeSchinkel, haukep, paulschreiber, DrewAPicture, ravenswd, esemlabel, stevegibson12, martychc23, DrLightman, jivanpal, neonkowy, laternastudio, apedog, audrasjb, davidbaumwald, Confridin, donmhico, ryotsun.
Built from https://develop.svn.wordpress.org/trunk@47878
git-svn-id: http://core.svn.wordpress.org/trunk@47652 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-01 20:49:10 +02:00
*/
$pre = apply_filters ( 'pre_redirect_guess_404_permalink' , null );
if ( null !== $pre ) {
return $pre ;
}
2017-12-01 00:11:00 +01:00
if ( get_query_var ( 'name' ) ) {
Canonical: Add the ability to disable `redirect_guess_404_permalink()`.
This also adds a few more filters to make adding redirects easier. Notably:
1. `do_redirect_guess_404_permalink`
2. `pre_redirect_guess_404_permalink`
3. `strict_redirect_guess_404_permalink`
Fixes: #16557.
Props: msafi, nacin, simonwheatley, westi, mboynes, joostdevalk, Lex_Robinson, MikeSchinkel, haukep, paulschreiber, DrewAPicture, ravenswd, esemlabel, stevegibson12, martychc23, DrLightman, jivanpal, neonkowy, laternastudio, apedog, audrasjb, davidbaumwald, Confridin, donmhico, ryotsun.
Built from https://develop.svn.wordpress.org/trunk@47878
git-svn-id: http://core.svn.wordpress.org/trunk@47652 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-01 20:49:10 +02:00
/**
* Filters whether to do a strict or loose guess .
*
2020-06-02 18:23:11 +02:00
* Passing a truthy value to the filter will redirect only exact post_name matches .
Canonical: Add the ability to disable `redirect_guess_404_permalink()`.
This also adds a few more filters to make adding redirects easier. Notably:
1. `do_redirect_guess_404_permalink`
2. `pre_redirect_guess_404_permalink`
3. `strict_redirect_guess_404_permalink`
Fixes: #16557.
Props: msafi, nacin, simonwheatley, westi, mboynes, joostdevalk, Lex_Robinson, MikeSchinkel, haukep, paulschreiber, DrewAPicture, ravenswd, esemlabel, stevegibson12, martychc23, DrLightman, jivanpal, neonkowy, laternastudio, apedog, audrasjb, davidbaumwald, Confridin, donmhico, ryotsun.
Built from https://develop.svn.wordpress.org/trunk@47878
git-svn-id: http://core.svn.wordpress.org/trunk@47652 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-01 20:49:10 +02:00
*
* @ since 5.5 . 0
*
2020-06-02 18:23:11 +02:00
* @ param bool $strict_guess Whether to do a strict / exact guess . Default false .
Canonical: Add the ability to disable `redirect_guess_404_permalink()`.
This also adds a few more filters to make adding redirects easier. Notably:
1. `do_redirect_guess_404_permalink`
2. `pre_redirect_guess_404_permalink`
3. `strict_redirect_guess_404_permalink`
Fixes: #16557.
Props: msafi, nacin, simonwheatley, westi, mboynes, joostdevalk, Lex_Robinson, MikeSchinkel, haukep, paulschreiber, DrewAPicture, ravenswd, esemlabel, stevegibson12, martychc23, DrLightman, jivanpal, neonkowy, laternastudio, apedog, audrasjb, davidbaumwald, Confridin, donmhico, ryotsun.
Built from https://develop.svn.wordpress.org/trunk@47878
git-svn-id: http://core.svn.wordpress.org/trunk@47652 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-01 20:49:10 +02:00
*/
$strict_guess = apply_filters ( 'strict_redirect_guess_404_permalink' , false );
if ( $strict_guess ) {
$where = $wpdb -> prepare ( 'post_name = %s' , get_query_var ( 'name' ) );
} else {
$where = $wpdb -> prepare ( 'post_name LIKE %s' , $wpdb -> esc_like ( get_query_var ( 'name' ) ) . '%' );
}
2012-01-28 21:40:55 +01:00
2020-01-29 01:45:18 +01:00
// If any of post_type, year, monthnum, or day are set, use them to refine the query.
2017-12-01 00:11:00 +01:00
if ( get_query_var ( 'post_type' ) ) {
$where .= $wpdb -> prepare ( ' AND post_type = %s' , get_query_var ( 'post_type' ) );
} else {
2012-05-02 19:39:43 +02:00
$where .= " AND post_type IN (' " . implode ( " ', ' " , get_post_types ( array ( 'public' => true ) ) ) . " ') " ;
2017-12-01 00:11:00 +01:00
}
2012-05-02 19:39:43 +02:00
2017-12-01 00:11:00 +01:00
if ( get_query_var ( 'year' ) ) {
$where .= $wpdb -> prepare ( ' AND YEAR(post_date) = %d' , get_query_var ( 'year' ) );
}
if ( get_query_var ( 'monthnum' ) ) {
$where .= $wpdb -> prepare ( ' AND MONTH(post_date) = %d' , get_query_var ( 'monthnum' ) );
}
if ( get_query_var ( 'day' ) ) {
$where .= $wpdb -> prepare ( ' AND DAYOFMONTH(post_date) = %d' , get_query_var ( 'day' ) );
}
2012-01-28 21:40:55 +01:00
2020-05-04 11:05:08 +02:00
// phpcs:ignore WordPress.DB.PreparedSQL.InterpolatedNotPrepared
2017-12-01 00:11:00 +01:00
$post_id = $wpdb -> get_var ( " SELECT ID FROM $wpdb->posts WHERE $where AND post_status = 'publish' " );
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
if ( ! $post_id ) {
2012-01-28 21:40:55 +01:00
return false ;
2017-12-01 00:11:00 +01:00
}
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
if ( get_query_var ( 'feed' ) ) {
2012-04-07 07:39:08 +02:00
return get_post_comments_feed_link ( $post_id , get_query_var ( 'feed' ) );
2020-05-04 11:05:08 +02:00
} elseif ( get_query_var ( 'page' ) > 1 ) {
2012-04-07 07:39:08 +02:00
return trailingslashit ( get_permalink ( $post_id ) ) . user_trailingslashit ( get_query_var ( 'page' ), 'single_paged' );
2017-12-01 00:11:00 +01:00
} else {
2012-04-07 07:39:08 +02:00
return get_permalink ( $post_id );
2017-12-01 00:11:00 +01:00
}
2012-01-28 21:40:55 +01:00
}
2007-08-17 05:45:59 +02:00
2012-01-28 21:40:55 +01:00
return false ;
2007-08-17 05:45:59 +02:00
}
2015-05-22 06:26:26 +02:00
/**
2015-12-19 00:08:26 +01:00
* Redirects a variety of shorthand URLs to the admin .
*
* If a user visits example . com / admin , they ' ll be redirected to / wp - admin .
* Visiting / login redirects to / wp - login . php , and so on .
*
* @ since 3.4 . 0
2015-05-22 06:26:26 +02:00
*
2019-08-04 03:19:56 +02:00
* @ global WP_Rewrite $wp_rewrite WordPress rewrite component .
2015-05-22 06:26:26 +02:00
*/
2012-02-08 21:11:52 +01:00
function wp_redirect_admin_locations () {
global $wp_rewrite ;
2020-05-04 11:05:08 +02:00
2017-12-01 00:11:00 +01:00
if ( ! ( is_404 () && $wp_rewrite -> using_permalinks () ) ) {
2012-02-08 21:11:52 +01:00
return ;
2017-12-01 00:11:00 +01:00
}
2012-02-08 21:11:52 +01:00
$admins = array (
home_url ( 'wp-admin' , 'relative' ),
home_url ( 'dashboard' , 'relative' ),
home_url ( 'admin' , 'relative' ),
site_url ( 'dashboard' , 'relative' ),
site_url ( 'admin' , 'relative' ),
);
2020-05-04 11:05:08 +02:00
2020-04-05 05:02:11 +02:00
if ( in_array ( untrailingslashit ( $_SERVER [ 'REQUEST_URI' ] ), $admins , true ) ) {
2012-02-08 21:11:52 +01:00
wp_redirect ( admin_url () );
exit ;
}
$logins = array (
home_url ( 'wp-login.php' , 'relative' ),
home_url ( 'login' , 'relative' ),
site_url ( 'login' , 'relative' ),
);
2020-05-04 11:05:08 +02:00
2020-04-05 05:02:11 +02:00
if ( in_array ( untrailingslashit ( $_SERVER [ 'REQUEST_URI' ] ), $logins , true ) ) {
2015-09-15 19:11:35 +02:00
wp_redirect ( wp_login_url () );
2012-02-08 21:11:52 +01:00
exit ;
}
}