2007-05-25 09:16:21 +02:00
|
|
|
<?php
|
2008-10-02 03:03:26 +02:00
|
|
|
/**
|
|
|
|
* Misc WordPress Administration API.
|
|
|
|
*
|
|
|
|
* @package WordPress
|
|
|
|
* @subpackage Administration
|
|
|
|
*/
|
2007-05-25 09:16:21 +02:00
|
|
|
|
2008-10-02 03:03:26 +02:00
|
|
|
/**
|
2013-09-16 22:07:09 +02:00
|
|
|
* Returns whether the server is running Apache with the mod_rewrite module loaded.
|
2008-10-02 03:03:26 +02:00
|
|
|
*
|
2010-12-01 20:24:38 +01:00
|
|
|
* @since 2.0.0
|
2008-10-02 03:03:26 +02:00
|
|
|
*
|
2019-07-28 18:35:56 +02:00
|
|
|
* @return bool Whether the server is running Apache with the mod_rewrite module loaded.
|
2008-10-02 03:03:26 +02:00
|
|
|
*/
|
2007-05-25 09:16:21 +02:00
|
|
|
function got_mod_rewrite() {
|
2017-12-01 00:11:00 +01:00
|
|
|
$got_rewrite = apache_mod_loaded( 'mod_rewrite', true );
|
2013-09-16 22:07:09 +02:00
|
|
|
|
|
|
|
/**
|
2016-05-22 20:01:30 +02:00
|
|
|
* Filters whether Apache and mod_rewrite are present.
|
2013-09-16 22:07:09 +02:00
|
|
|
*
|
|
|
|
* This filter was previously used to force URL rewriting for other servers,
|
2016-05-23 19:28:27 +02:00
|
|
|
* like nginx. Use the {@see 'got_url_rewrite'} filter in got_url_rewrite() instead.
|
2013-09-16 22:07:09 +02:00
|
|
|
*
|
2014-05-08 13:13:14 +02:00
|
|
|
* @since 2.5.0
|
2014-06-04 07:35:16 +02:00
|
|
|
*
|
2013-09-16 22:07:09 +02:00
|
|
|
* @see got_url_rewrite()
|
|
|
|
*
|
|
|
|
* @param bool $got_rewrite Whether Apache and mod_rewrite are present.
|
|
|
|
*/
|
2014-03-03 18:20:16 +01:00
|
|
|
return apply_filters( 'got_rewrite', $got_rewrite );
|
2007-05-25 09:16:21 +02:00
|
|
|
}
|
|
|
|
|
2013-09-16 22:07:09 +02:00
|
|
|
/**
|
|
|
|
* Returns whether the server supports URL rewriting.
|
|
|
|
*
|
|
|
|
* Detects Apache's mod_rewrite, IIS 7.0+ permalink support, and nginx.
|
|
|
|
*
|
|
|
|
* @since 3.7.0
|
|
|
|
*
|
2015-05-28 23:41:30 +02:00
|
|
|
* @global bool $is_nginx
|
|
|
|
*
|
2013-09-16 22:07:09 +02:00
|
|
|
* @return bool Whether the server supports URL rewriting.
|
|
|
|
*/
|
|
|
|
function got_url_rewrite() {
|
|
|
|
$got_url_rewrite = ( got_mod_rewrite() || $GLOBALS['is_nginx'] || iis7_supports_permalinks() );
|
|
|
|
|
|
|
|
/**
|
2016-05-22 20:01:30 +02:00
|
|
|
* Filters whether URL rewriting is available.
|
2013-09-16 22:07:09 +02:00
|
|
|
*
|
|
|
|
* @since 3.7.0
|
2014-06-04 07:35:16 +02:00
|
|
|
*
|
2013-09-16 22:07:09 +02:00
|
|
|
* @param bool $got_url_rewrite Whether URL rewriting is available.
|
|
|
|
*/
|
|
|
|
return apply_filters( 'got_url_rewrite', $got_url_rewrite );
|
|
|
|
}
|
|
|
|
|
2008-10-02 03:03:26 +02:00
|
|
|
/**
|
2015-10-05 04:52:24 +02:00
|
|
|
* Extracts strings from between the BEGIN and END markers in the .htaccess file.
|
2008-10-02 03:03:26 +02:00
|
|
|
*
|
2010-12-01 20:24:38 +01:00
|
|
|
* @since 1.5.0
|
2008-10-02 03:03:26 +02:00
|
|
|
*
|
2019-07-28 18:35:56 +02:00
|
|
|
* @param string $filename Filename to extract the strings from.
|
|
|
|
* @param string $marker The marker to extract the strings from.
|
2019-11-05 22:30:03 +01:00
|
|
|
* @return string[] An array of strings from a file (.htaccess) from between BEGIN and END markers.
|
2008-10-02 03:03:26 +02:00
|
|
|
*/
|
2007-05-25 09:16:21 +02:00
|
|
|
function extract_from_markers( $filename, $marker ) {
|
2017-12-01 00:11:00 +01:00
|
|
|
$result = array();
|
2007-05-25 09:16:21 +02:00
|
|
|
|
2017-10-18 23:28:46 +02:00
|
|
|
if ( ! file_exists( $filename ) ) {
|
2007-05-25 09:16:21 +02:00
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2017-10-18 23:28:46 +02:00
|
|
|
$markerdata = explode( "\n", implode( '', file( $filename ) ) );
|
|
|
|
|
|
|
|
$state = false;
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-18 23:28:46 +02:00
|
|
|
foreach ( $markerdata as $markerline ) {
|
Code Modernization: Replace usage of `strpos()` with `str_contains()`.
`str_contains()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) contains the given substring (needle).
WordPress core includes a polyfill for `str_contains()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `false !== strpos( ... )` with `str_contains()` in core files, making the code more readable and consistent, as well as better aligned with modern development practices.
Follow-up to [52039], [52040], [52326], [55703], [55710], [55987].
Props Soean, spacedmonkey, costdev, dingo_d, azaozz, mikeschroder, flixos90, peterwilsoncc, SergeyBiryukov.
Fixes #58206.
Built from https://develop.svn.wordpress.org/trunk@55988
git-svn-id: http://core.svn.wordpress.org/trunk@55500 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-22 16:36:26 +02:00
|
|
|
if ( str_contains( $markerline, '# END ' . $marker ) ) {
|
2017-10-18 23:28:46 +02:00
|
|
|
$state = false;
|
2017-11-16 14:25:50 +01:00
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-11-16 14:25:50 +01:00
|
|
|
if ( $state ) {
|
Code Modernization: Replace usage of `substr()` with `str_starts_with()` and `str_ends_with()`.
`str_starts_with()` and `str_ends_with()` were introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) begins or ends with the given substring (needle).
WordPress core includes a polyfill for these functions on PHP < 8.0 as of WordPress 5.9.
This commit uses `str_starts_with()` and `str_ends_with()` in core files where appropriate:
* `$needle === substr( $string, 0, $length )`, where `$length` is the length of `$needle`, is replaced with `str_starts_with( $haystack, $needle )`.
* `$needle === substr( $string, $offset )`, where `$offset` is negative and the absolute value of `$offset` is the length of `$needle`, is replaced with `str_ends_with( $haystack, $needle )`.
This aims to make the code more readable and consistent, as well as better aligned with modern development practices.
Follow-up to [52039], [52040], [52326], [55703], [55710], [55987], [55988].
Props Soean, spacedmonkey, Clorith, ocean90, azaozz, sabernhardt, SergeyBiryukov.
Fixes #58220.
Built from https://develop.svn.wordpress.org/trunk@55990
git-svn-id: http://core.svn.wordpress.org/trunk@55502 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-22 16:57:24 +02:00
|
|
|
if ( str_starts_with( $markerline, '#' ) ) {
|
2019-07-28 18:31:57 +02:00
|
|
|
continue;
|
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-11-16 14:25:50 +01:00
|
|
|
$result[] = $markerline;
|
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
Code Modernization: Replace usage of `strpos()` with `str_contains()`.
`str_contains()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) contains the given substring (needle).
WordPress core includes a polyfill for `str_contains()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `false !== strpos( ... )` with `str_contains()` in core files, making the code more readable and consistent, as well as better aligned with modern development practices.
Follow-up to [52039], [52040], [52326], [55703], [55710], [55987].
Props Soean, spacedmonkey, costdev, dingo_d, azaozz, mikeschroder, flixos90, peterwilsoncc, SergeyBiryukov.
Fixes #58206.
Built from https://develop.svn.wordpress.org/trunk@55988
git-svn-id: http://core.svn.wordpress.org/trunk@55500 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-22 16:36:26 +02:00
|
|
|
if ( str_contains( $markerline, '# BEGIN ' . $marker ) ) {
|
2017-11-16 14:25:50 +01:00
|
|
|
$state = true;
|
2007-05-25 09:16:21 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2008-10-02 03:03:26 +02:00
|
|
|
/**
|
2019-07-28 18:35:56 +02:00
|
|
|
* Inserts an array of strings into a file (.htaccess), placing it between
|
2015-10-05 04:52:24 +02:00
|
|
|
* BEGIN and END markers.
|
|
|
|
*
|
|
|
|
* Replaces existing marked info. Retains surrounding
|
2008-10-02 03:03:26 +02:00
|
|
|
* data. Creates file if none exists.
|
|
|
|
*
|
2010-12-01 20:24:38 +01:00
|
|
|
* @since 1.5.0
|
2008-10-02 03:03:26 +02:00
|
|
|
*
|
2015-10-19 02:53:24 +02:00
|
|
|
* @param string $filename Filename to alter.
|
|
|
|
* @param string $marker The marker to alter.
|
|
|
|
* @param array|string $insertion The new content to insert.
|
2008-10-02 03:03:26 +02:00
|
|
|
* @return bool True on write success, false on failure.
|
|
|
|
*/
|
2007-05-25 09:16:21 +02:00
|
|
|
function insert_with_markers( $filename, $marker, $insertion ) {
|
2015-10-19 02:53:24 +02:00
|
|
|
if ( ! file_exists( $filename ) ) {
|
|
|
|
if ( ! is_writable( dirname( $filename ) ) ) {
|
|
|
|
return false;
|
|
|
|
}
|
2019-12-22 03:45:03 +01:00
|
|
|
|
2015-10-19 02:53:24 +02:00
|
|
|
if ( ! touch( $filename ) ) {
|
|
|
|
return false;
|
|
|
|
}
|
2019-12-22 03:45:03 +01:00
|
|
|
|
|
|
|
// Make sure the file is created with a minimum set of permissions.
|
|
|
|
$perms = fileperms( $filename );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2019-12-22 03:45:03 +01:00
|
|
|
if ( $perms ) {
|
|
|
|
chmod( $filename, $perms | 0644 );
|
|
|
|
}
|
2020-10-18 19:27:06 +02:00
|
|
|
} elseif ( ! is_writable( $filename ) ) {
|
2015-10-01 09:46:27 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( ! is_array( $insertion ) ) {
|
2015-10-19 02:53:24 +02:00
|
|
|
$insertion = explode( "\n", $insertion );
|
2015-10-01 09:46:27 +02:00
|
|
|
}
|
|
|
|
|
2019-07-28 18:31:57 +02:00
|
|
|
$switched_locale = switch_to_locale( get_locale() );
|
|
|
|
|
|
|
|
$instructions = sprintf(
|
2019-09-03 02:41:05 +02:00
|
|
|
/* translators: 1: Marker. */
|
2019-07-28 18:52:56 +02:00
|
|
|
__(
|
2020-04-11 17:09:11 +02:00
|
|
|
'The directives (lines) between "BEGIN %1$s" and "END %1$s" are
|
2019-07-28 18:31:57 +02:00
|
|
|
dynamically generated, and should only be modified via WordPress filters.
|
2019-07-28 18:52:56 +02:00
|
|
|
Any changes to the directives between these markers will be overwritten.'
|
|
|
|
),
|
2019-07-28 18:31:57 +02:00
|
|
|
$marker
|
|
|
|
);
|
|
|
|
|
|
|
|
$instructions = explode( "\n", $instructions );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2019-07-28 18:31:57 +02:00
|
|
|
foreach ( $instructions as $line => $text ) {
|
|
|
|
$instructions[ $line ] = '# ' . $text;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Filters the inline instructions inserted before the dynamically generated content.
|
|
|
|
*
|
|
|
|
* @since 5.3.0
|
|
|
|
*
|
|
|
|
* @param string[] $instructions Array of lines with inline instructions.
|
|
|
|
* @param string $marker The marker being inserted.
|
|
|
|
*/
|
|
|
|
$instructions = apply_filters( 'insert_with_markers_inline_instructions', $instructions, $marker );
|
|
|
|
|
|
|
|
if ( $switched_locale ) {
|
|
|
|
restore_previous_locale();
|
|
|
|
}
|
|
|
|
|
|
|
|
$insertion = array_merge( $instructions, $insertion );
|
|
|
|
|
2015-10-01 09:46:27 +02:00
|
|
|
$start_marker = "# BEGIN {$marker}";
|
|
|
|
$end_marker = "# END {$marker}";
|
|
|
|
|
|
|
|
$fp = fopen( $filename, 'r+' );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2015-10-01 09:46:27 +02:00
|
|
|
if ( ! $fp ) {
|
|
|
|
return false;
|
|
|
|
}
|
2007-05-25 09:16:21 +02:00
|
|
|
|
2015-10-01 09:46:27 +02:00
|
|
|
// Attempt to get a lock. If the filesystem supports locking, this will block until the lock is acquired.
|
|
|
|
flock( $fp, LOCK_EX );
|
|
|
|
|
|
|
|
$lines = array();
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2015-10-01 09:46:27 +02:00
|
|
|
while ( ! feof( $fp ) ) {
|
|
|
|
$lines[] = rtrim( fgets( $fp ), "\r\n" );
|
|
|
|
}
|
|
|
|
|
2020-01-29 01:35:08 +01:00
|
|
|
// Split out the existing file into the preceding lines, and those that appear after the marker.
|
2019-07-01 14:52:01 +02:00
|
|
|
$pre_lines = array();
|
|
|
|
$post_lines = array();
|
|
|
|
$existing_lines = array();
|
|
|
|
$found_marker = false;
|
|
|
|
$found_end_marker = false;
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2015-10-01 09:46:27 +02:00
|
|
|
foreach ( $lines as $line ) {
|
Code Modernization: Replace usage of `strpos()` with `str_contains()`.
`str_contains()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) contains the given substring (needle).
WordPress core includes a polyfill for `str_contains()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `false !== strpos( ... )` with `str_contains()` in core files, making the code more readable and consistent, as well as better aligned with modern development practices.
Follow-up to [52039], [52040], [52326], [55703], [55710], [55987].
Props Soean, spacedmonkey, costdev, dingo_d, azaozz, mikeschroder, flixos90, peterwilsoncc, SergeyBiryukov.
Fixes #58206.
Built from https://develop.svn.wordpress.org/trunk@55988
git-svn-id: http://core.svn.wordpress.org/trunk@55500 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-22 16:36:26 +02:00
|
|
|
if ( ! $found_marker && str_contains( $line, $start_marker ) ) {
|
2015-10-01 09:46:27 +02:00
|
|
|
$found_marker = true;
|
|
|
|
continue;
|
Code Modernization: Replace usage of `strpos()` with `str_contains()`.
`str_contains()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) contains the given substring (needle).
WordPress core includes a polyfill for `str_contains()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `false !== strpos( ... )` with `str_contains()` in core files, making the code more readable and consistent, as well as better aligned with modern development practices.
Follow-up to [52039], [52040], [52326], [55703], [55710], [55987].
Props Soean, spacedmonkey, costdev, dingo_d, azaozz, mikeschroder, flixos90, peterwilsoncc, SergeyBiryukov.
Fixes #58206.
Built from https://develop.svn.wordpress.org/trunk@55988
git-svn-id: http://core.svn.wordpress.org/trunk@55500 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-22 16:36:26 +02:00
|
|
|
} elseif ( ! $found_end_marker && str_contains( $line, $end_marker ) ) {
|
2015-10-01 09:46:27 +02:00
|
|
|
$found_end_marker = true;
|
|
|
|
continue;
|
2007-05-25 09:16:21 +02:00
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2015-10-01 09:46:27 +02:00
|
|
|
if ( ! $found_marker ) {
|
|
|
|
$pre_lines[] = $line;
|
|
|
|
} elseif ( $found_marker && $found_end_marker ) {
|
|
|
|
$post_lines[] = $line;
|
2015-10-19 02:53:24 +02:00
|
|
|
} else {
|
|
|
|
$existing_lines[] = $line;
|
2007-05-25 09:16:21 +02:00
|
|
|
}
|
|
|
|
}
|
2015-10-01 09:46:27 +02:00
|
|
|
|
2020-01-29 01:35:08 +01:00
|
|
|
// Check to see if there was a change.
|
2015-10-19 02:53:24 +02:00
|
|
|
if ( $existing_lines === $insertion ) {
|
|
|
|
flock( $fp, LOCK_UN );
|
|
|
|
fclose( $fp );
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2020-01-29 01:35:08 +01:00
|
|
|
// Generate the new file data.
|
2017-12-01 00:11:00 +01:00
|
|
|
$new_file_data = implode(
|
2018-08-17 03:51:36 +02:00
|
|
|
"\n",
|
|
|
|
array_merge(
|
2017-12-01 00:11:00 +01:00
|
|
|
$pre_lines,
|
|
|
|
array( $start_marker ),
|
|
|
|
$insertion,
|
|
|
|
array( $end_marker ),
|
|
|
|
$post_lines
|
|
|
|
)
|
|
|
|
);
|
2015-10-01 09:46:27 +02:00
|
|
|
|
2020-01-29 01:35:08 +01:00
|
|
|
// Write to the start of the file, and truncate it to that length.
|
2015-10-01 09:46:27 +02:00
|
|
|
fseek( $fp, 0 );
|
|
|
|
$bytes = fwrite( $fp, $new_file_data );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2015-10-01 09:46:27 +02:00
|
|
|
if ( $bytes ) {
|
2015-10-19 02:53:24 +02:00
|
|
|
ftruncate( $fp, ftell( $fp ) );
|
2015-10-01 09:46:27 +02:00
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2015-10-19 02:53:24 +02:00
|
|
|
fflush( $fp );
|
2015-10-01 09:46:27 +02:00
|
|
|
flock( $fp, LOCK_UN );
|
|
|
|
fclose( $fp );
|
|
|
|
|
|
|
|
return (bool) $bytes;
|
2007-05-25 09:16:21 +02:00
|
|
|
}
|
|
|
|
|
2007-07-18 22:46:54 +02:00
|
|
|
/**
|
|
|
|
* Updates the htaccess file with the current rules if it is writable.
|
|
|
|
*
|
2008-10-02 03:03:26 +02:00
|
|
|
* Always writes to the file if it exists and is writable to ensure that we
|
|
|
|
* blank out old rules.
|
|
|
|
*
|
2010-12-01 20:24:38 +01:00
|
|
|
* @since 1.5.0
|
2015-05-28 23:41:30 +02:00
|
|
|
*
|
2019-08-04 03:19:56 +02:00
|
|
|
* @global WP_Rewrite $wp_rewrite WordPress rewrite component.
|
2018-06-28 04:36:35 +02:00
|
|
|
*
|
|
|
|
* @return bool|null True on write success, false on failure. Null in multisite.
|
2007-07-18 22:46:54 +02:00
|
|
|
*/
|
2007-05-25 09:16:21 +02:00
|
|
|
function save_mod_rewrite_rules() {
|
2022-02-13 18:09:05 +01:00
|
|
|
global $wp_rewrite;
|
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( is_multisite() ) {
|
2010-01-15 01:21:13 +01:00
|
|
|
return;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2010-01-15 01:21:13 +01:00
|
|
|
|
2018-06-28 04:37:00 +02:00
|
|
|
// Ensure get_home_path() is declared.
|
2020-02-06 07:33:11 +01:00
|
|
|
require_once ABSPATH . 'wp-admin/includes/file.php';
|
2018-06-28 04:36:09 +02:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
$home_path = get_home_path();
|
|
|
|
$htaccess_file = $home_path . '.htaccess';
|
2007-07-18 22:46:54 +02:00
|
|
|
|
2014-07-17 11:14:16 +02:00
|
|
|
/*
|
|
|
|
* If the file doesn't already exist check for write access to the directory
|
|
|
|
* and whether we have some rules. Else check for write access to the file.
|
|
|
|
*/
|
2022-02-13 18:09:05 +01:00
|
|
|
if ( ! file_exists( $htaccess_file ) && is_writable( $home_path ) && $wp_rewrite->using_mod_rewrite_permalinks()
|
|
|
|
|| is_writable( $htaccess_file )
|
|
|
|
) {
|
2007-07-18 22:46:54 +02:00
|
|
|
if ( got_mod_rewrite() ) {
|
|
|
|
$rules = explode( "\n", $wp_rewrite->mod_rewrite_rules() );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2007-07-18 22:46:54 +02:00
|
|
|
return insert_with_markers( $htaccess_file, 'WordPress', $rules );
|
|
|
|
}
|
|
|
|
}
|
2007-09-04 01:19:20 +02:00
|
|
|
|
2007-07-18 22:46:54 +02:00
|
|
|
return false;
|
2007-05-25 09:16:21 +02:00
|
|
|
}
|
|
|
|
|
2009-05-16 04:04:36 +02:00
|
|
|
/**
|
|
|
|
* Updates the IIS web.config file with the current rules if it is writable.
|
|
|
|
* If the permalinks do not require rewrite rules then the rules are deleted from the web.config file.
|
2009-05-25 01:47:49 +02:00
|
|
|
*
|
2009-05-16 04:04:36 +02:00
|
|
|
* @since 2.8.0
|
2009-05-25 01:47:49 +02:00
|
|
|
*
|
2019-08-04 03:19:56 +02:00
|
|
|
* @global WP_Rewrite $wp_rewrite WordPress rewrite component.
|
2015-05-28 23:41:30 +02:00
|
|
|
*
|
2018-06-28 04:36:35 +02:00
|
|
|
* @return bool|null True on write success, false on failure. Null in multisite.
|
2009-05-16 04:04:36 +02:00
|
|
|
*/
|
2017-12-01 00:11:00 +01:00
|
|
|
function iis7_save_url_rewrite_rules() {
|
2022-02-13 18:09:05 +01:00
|
|
|
global $wp_rewrite;
|
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( is_multisite() ) {
|
2011-01-19 17:49:46 +01:00
|
|
|
return;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2011-01-19 17:49:46 +01:00
|
|
|
|
2018-06-28 04:37:00 +02:00
|
|
|
// Ensure get_home_path() is declared.
|
2020-02-06 07:33:11 +01:00
|
|
|
require_once ABSPATH . 'wp-admin/includes/file.php';
|
2018-06-28 04:36:09 +02:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
$home_path = get_home_path();
|
2009-05-16 04:04:36 +02:00
|
|
|
$web_config_file = $home_path . 'web.config';
|
|
|
|
|
2020-01-29 01:35:08 +01:00
|
|
|
// Using win_is_writable() instead of is_writable() because of a bug in Windows PHP.
|
2022-02-13 18:09:05 +01:00
|
|
|
if ( iis7_supports_permalinks()
|
|
|
|
&& ( ! file_exists( $web_config_file ) && win_is_writable( $home_path ) && $wp_rewrite->using_mod_rewrite_permalinks()
|
|
|
|
|| win_is_writable( $web_config_file ) )
|
|
|
|
) {
|
2019-01-16 07:10:50 +01:00
|
|
|
$rule = $wp_rewrite->iis7_url_rewrite_rules( false );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( ! empty( $rule ) ) {
|
|
|
|
return iis7_add_rewrite_rule( $web_config_file, $rule );
|
2010-11-30 21:50:59 +01:00
|
|
|
} else {
|
2017-12-01 00:11:00 +01:00
|
|
|
return iis7_delete_rewrite_rule( $web_config_file );
|
2009-05-16 04:04:36 +02:00
|
|
|
}
|
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2009-05-16 04:04:36 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2008-10-02 03:03:26 +02:00
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Updates the "recently-edited" file for the plugin or theme file editor.
|
2008-10-02 03:03:26 +02:00
|
|
|
*
|
2010-12-01 20:24:38 +01:00
|
|
|
* @since 1.5.0
|
2008-10-02 03:03:26 +02:00
|
|
|
*
|
2014-11-03 07:01:24 +01:00
|
|
|
* @param string $file
|
2008-10-02 03:03:26 +02:00
|
|
|
*/
|
2007-05-25 09:16:21 +02:00
|
|
|
function update_recently_edited( $file ) {
|
2017-12-01 00:11:00 +01:00
|
|
|
$oldfiles = (array) get_option( 'recently_edited' );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2007-05-25 09:16:21 +02:00
|
|
|
if ( $oldfiles ) {
|
2017-12-01 00:11:00 +01:00
|
|
|
$oldfiles = array_reverse( $oldfiles );
|
2007-05-25 09:16:21 +02:00
|
|
|
$oldfiles[] = $file;
|
2017-12-01 00:11:00 +01:00
|
|
|
$oldfiles = array_reverse( $oldfiles );
|
|
|
|
$oldfiles = array_unique( $oldfiles );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( 5 < count( $oldfiles ) ) {
|
2007-05-25 09:16:21 +02:00
|
|
|
array_pop( $oldfiles );
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2007-05-25 09:16:21 +02:00
|
|
|
} else {
|
|
|
|
$oldfiles[] = $file;
|
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2007-05-25 09:16:21 +02:00
|
|
|
update_option( 'recently_edited', $oldfiles );
|
|
|
|
}
|
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
/**
|
Administration: Add "File" to Theme/Plugin Editor menu names and relocate "Plugin File Editor" to Tools for block themes.
[52232] relocated the Theme Editor menu item from Appearance to Tools for block themes. This commit relocates the Plugin Editor menu item from Plugins to Tools for block themes for a consistent workflow.
Both the Theme Editor and Plugin Editor menu items are renamed to "Theme File Editor" and "Plugin File Editor" respectively. Why? To better identify their purpose, i.e. to directly edit the code in the theme or plugin files. The rename is not limited to only block themes.
Follow-up to [52232].
Props poena, annezazu, audrasjb, clorith, courane01, costdev, dryanpress, desrosj, hellofromTonya, ipstenu, jameskoster, joen, johnbillion, joyously, manfcarlo, marybaum, pbiron, SergeyBiryukov, walbo, youknowriad.
Fixes #54382.
Built from https://develop.svn.wordpress.org/trunk@52406
git-svn-id: http://core.svn.wordpress.org/trunk@51998 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-12-21 21:06:02 +01:00
|
|
|
* Makes a tree structure for the theme file editor's file list.
|
2017-10-13 04:39:47 +02:00
|
|
|
*
|
|
|
|
* @since 4.9.0
|
|
|
|
* @access private
|
|
|
|
*
|
|
|
|
* @param array $allowed_files List of theme file paths.
|
|
|
|
* @return array Tree structure for listing theme files.
|
|
|
|
*/
|
|
|
|
function wp_make_theme_file_tree( $allowed_files ) {
|
|
|
|
$tree_list = array();
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
foreach ( $allowed_files as $file_name => $absolute_filename ) {
|
2017-12-01 00:11:00 +01:00
|
|
|
$list = explode( '/', $file_name );
|
2017-10-13 04:39:47 +02:00
|
|
|
$last_dir = &$tree_list;
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
foreach ( $list as $dir ) {
|
|
|
|
$last_dir =& $last_dir[ $dir ];
|
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
$last_dir = $file_name;
|
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
return $tree_list;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
Administration: Add "File" to Theme/Plugin Editor menu names and relocate "Plugin File Editor" to Tools for block themes.
[52232] relocated the Theme Editor menu item from Appearance to Tools for block themes. This commit relocates the Plugin Editor menu item from Plugins to Tools for block themes for a consistent workflow.
Both the Theme Editor and Plugin Editor menu items are renamed to "Theme File Editor" and "Plugin File Editor" respectively. Why? To better identify their purpose, i.e. to directly edit the code in the theme or plugin files. The rename is not limited to only block themes.
Follow-up to [52232].
Props poena, annezazu, audrasjb, clorith, courane01, costdev, dryanpress, desrosj, hellofromTonya, ipstenu, jameskoster, joen, johnbillion, joyously, manfcarlo, marybaum, pbiron, SergeyBiryukov, walbo, youknowriad.
Fixes #54382.
Built from https://develop.svn.wordpress.org/trunk@52406
git-svn-id: http://core.svn.wordpress.org/trunk@51998 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-12-21 21:06:02 +01:00
|
|
|
* Outputs the formatted file list for the theme file editor.
|
2017-10-13 04:39:47 +02:00
|
|
|
*
|
|
|
|
* @since 4.9.0
|
|
|
|
* @access private
|
|
|
|
*
|
2019-01-08 19:33:49 +01:00
|
|
|
* @global string $relative_file Name of the file being edited relative to the
|
|
|
|
* theme directory.
|
|
|
|
* @global string $stylesheet The stylesheet name of the theme being edited.
|
|
|
|
*
|
2017-10-13 04:39:47 +02:00
|
|
|
* @param array|string $tree List of file/folder paths, or filename.
|
|
|
|
* @param int $level The aria-level for the current iteration.
|
|
|
|
* @param int $size The aria-setsize for the current iteration.
|
|
|
|
* @param int $index The aria-posinset for the current iteration.
|
|
|
|
*/
|
|
|
|
function wp_print_theme_file_tree( $tree, $level = 2, $size = 1, $index = 1 ) {
|
|
|
|
global $relative_file, $stylesheet;
|
|
|
|
|
|
|
|
if ( is_array( $tree ) ) {
|
|
|
|
$index = 0;
|
2017-12-01 00:11:00 +01:00
|
|
|
$size = count( $tree );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
foreach ( $tree as $label => $theme_file ) :
|
|
|
|
$index++;
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
if ( ! is_array( $theme_file ) ) {
|
|
|
|
wp_print_theme_file_tree( $theme_file, $level, $index, $size );
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
?>
|
|
|
|
<li role="treeitem" aria-expanded="true" tabindex="-1"
|
|
|
|
aria-level="<?php echo esc_attr( $level ); ?>"
|
|
|
|
aria-setsize="<?php echo esc_attr( $size ); ?>"
|
|
|
|
aria-posinset="<?php echo esc_attr( $index ); ?>">
|
I18N: Mark screen reader strings as such with translator comments.
This aims to provide better context for translators and make it easier to determine that some strings contain hidden accessibility text and are not displayed in the UI.
Props kebbet, mercime, pavelevap, ocean90, swissspidy, Chouby, jipmoors, afercia, desrosj, costdev, audrasjb, SergeyBiryukov.
Fixes #29748.
Built from https://develop.svn.wordpress.org/trunk@55276
git-svn-id: http://core.svn.wordpress.org/trunk@54809 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-02-07 18:10:21 +01:00
|
|
|
<span class="folder-label"><?php echo esc_html( $label ); ?> <span class="screen-reader-text">
|
|
|
|
<?php
|
|
|
|
/* translators: Hidden accessibility text. */
|
|
|
|
_e( 'folder' );
|
|
|
|
?>
|
|
|
|
</span><span aria-hidden="true" class="icon"></span></span>
|
2017-10-13 04:39:47 +02:00
|
|
|
<ul role="group" class="tree-folder"><?php wp_print_theme_file_tree( $theme_file, $level + 1, $index, $size ); ?></ul>
|
|
|
|
</li>
|
|
|
|
<?php
|
|
|
|
endforeach;
|
|
|
|
} else {
|
|
|
|
$filename = $tree;
|
2017-12-01 00:11:00 +01:00
|
|
|
$url = add_query_arg(
|
2017-10-13 04:39:47 +02:00
|
|
|
array(
|
2017-12-01 00:11:00 +01:00
|
|
|
'file' => rawurlencode( $tree ),
|
2017-10-13 04:39:47 +02:00
|
|
|
'theme' => rawurlencode( $stylesheet ),
|
|
|
|
),
|
2017-11-03 19:51:49 +01:00
|
|
|
self_admin_url( 'theme-editor.php' )
|
2017-10-13 04:39:47 +02:00
|
|
|
);
|
|
|
|
?>
|
|
|
|
<li role="none" class="<?php echo esc_attr( $relative_file === $filename ? 'current-file' : '' ); ?>">
|
|
|
|
<a role="treeitem" tabindex="<?php echo esc_attr( $relative_file === $filename ? '0' : '-1' ); ?>"
|
|
|
|
href="<?php echo esc_url( $url ); ?>"
|
|
|
|
aria-level="<?php echo esc_attr( $level ); ?>"
|
|
|
|
aria-setsize="<?php echo esc_attr( $size ); ?>"
|
|
|
|
aria-posinset="<?php echo esc_attr( $index ); ?>">
|
|
|
|
<?php
|
|
|
|
$file_description = esc_html( get_file_description( $filename ) );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2019-03-01 21:58:52 +01:00
|
|
|
if ( $file_description !== $filename && wp_basename( $filename ) !== $file_description ) {
|
2017-10-13 04:39:47 +02:00
|
|
|
$file_description .= '<br /><span class="nonessential">(' . esc_html( $filename ) . ')</span>';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( $relative_file === $filename ) {
|
|
|
|
echo '<span class="notice notice-info">' . $file_description . '</span>';
|
|
|
|
} else {
|
|
|
|
echo $file_description;
|
|
|
|
}
|
|
|
|
?>
|
|
|
|
</a>
|
|
|
|
</li>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
Administration: Add "File" to Theme/Plugin Editor menu names and relocate "Plugin File Editor" to Tools for block themes.
[52232] relocated the Theme Editor menu item from Appearance to Tools for block themes. This commit relocates the Plugin Editor menu item from Plugins to Tools for block themes for a consistent workflow.
Both the Theme Editor and Plugin Editor menu items are renamed to "Theme File Editor" and "Plugin File Editor" respectively. Why? To better identify their purpose, i.e. to directly edit the code in the theme or plugin files. The rename is not limited to only block themes.
Follow-up to [52232].
Props poena, annezazu, audrasjb, clorith, courane01, costdev, dryanpress, desrosj, hellofromTonya, ipstenu, jameskoster, joen, johnbillion, joyously, manfcarlo, marybaum, pbiron, SergeyBiryukov, walbo, youknowriad.
Fixes #54382.
Built from https://develop.svn.wordpress.org/trunk@52406
git-svn-id: http://core.svn.wordpress.org/trunk@51998 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-12-21 21:06:02 +01:00
|
|
|
* Makes a tree structure for the plugin file editor's file list.
|
2017-10-13 04:39:47 +02:00
|
|
|
*
|
|
|
|
* @since 4.9.0
|
|
|
|
* @access private
|
|
|
|
*
|
2019-01-08 07:02:51 +01:00
|
|
|
* @param array $plugin_editable_files List of plugin file paths.
|
2017-10-13 04:39:47 +02:00
|
|
|
* @return array Tree structure for listing plugin files.
|
|
|
|
*/
|
|
|
|
function wp_make_plugin_file_tree( $plugin_editable_files ) {
|
|
|
|
$tree_list = array();
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
foreach ( $plugin_editable_files as $plugin_file ) {
|
2017-12-01 00:11:00 +01:00
|
|
|
$list = explode( '/', preg_replace( '#^.+?/#', '', $plugin_file ) );
|
2017-10-13 04:39:47 +02:00
|
|
|
$last_dir = &$tree_list;
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
foreach ( $list as $dir ) {
|
|
|
|
$last_dir =& $last_dir[ $dir ];
|
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
$last_dir = $plugin_file;
|
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
return $tree_list;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
Administration: Add "File" to Theme/Plugin Editor menu names and relocate "Plugin File Editor" to Tools for block themes.
[52232] relocated the Theme Editor menu item from Appearance to Tools for block themes. This commit relocates the Plugin Editor menu item from Plugins to Tools for block themes for a consistent workflow.
Both the Theme Editor and Plugin Editor menu items are renamed to "Theme File Editor" and "Plugin File Editor" respectively. Why? To better identify their purpose, i.e. to directly edit the code in the theme or plugin files. The rename is not limited to only block themes.
Follow-up to [52232].
Props poena, annezazu, audrasjb, clorith, courane01, costdev, dryanpress, desrosj, hellofromTonya, ipstenu, jameskoster, joen, johnbillion, joyously, manfcarlo, marybaum, pbiron, SergeyBiryukov, walbo, youknowriad.
Fixes #54382.
Built from https://develop.svn.wordpress.org/trunk@52406
git-svn-id: http://core.svn.wordpress.org/trunk@51998 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-12-21 21:06:02 +01:00
|
|
|
* Outputs the formatted file list for the plugin file editor.
|
2017-10-13 04:39:47 +02:00
|
|
|
*
|
|
|
|
* @since 4.9.0
|
|
|
|
* @access private
|
|
|
|
*
|
|
|
|
* @param array|string $tree List of file/folder paths, or filename.
|
|
|
|
* @param string $label Name of file or folder to print.
|
|
|
|
* @param int $level The aria-level for the current iteration.
|
|
|
|
* @param int $size The aria-setsize for the current iteration.
|
|
|
|
* @param int $index The aria-posinset for the current iteration.
|
|
|
|
*/
|
|
|
|
function wp_print_plugin_file_tree( $tree, $label = '', $level = 2, $size = 1, $index = 1 ) {
|
|
|
|
global $file, $plugin;
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
if ( is_array( $tree ) ) {
|
|
|
|
$index = 0;
|
2017-12-01 00:11:00 +01:00
|
|
|
$size = count( $tree );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
foreach ( $tree as $label => $plugin_file ) :
|
|
|
|
$index++;
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-10-13 04:39:47 +02:00
|
|
|
if ( ! is_array( $plugin_file ) ) {
|
|
|
|
wp_print_plugin_file_tree( $plugin_file, $label, $level, $index, $size );
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
?>
|
|
|
|
<li role="treeitem" aria-expanded="true" tabindex="-1"
|
|
|
|
aria-level="<?php echo esc_attr( $level ); ?>"
|
|
|
|
aria-setsize="<?php echo esc_attr( $size ); ?>"
|
|
|
|
aria-posinset="<?php echo esc_attr( $index ); ?>">
|
I18N: Mark screen reader strings as such with translator comments.
This aims to provide better context for translators and make it easier to determine that some strings contain hidden accessibility text and are not displayed in the UI.
Props kebbet, mercime, pavelevap, ocean90, swissspidy, Chouby, jipmoors, afercia, desrosj, costdev, audrasjb, SergeyBiryukov.
Fixes #29748.
Built from https://develop.svn.wordpress.org/trunk@55276
git-svn-id: http://core.svn.wordpress.org/trunk@54809 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-02-07 18:10:21 +01:00
|
|
|
<span class="folder-label"><?php echo esc_html( $label ); ?> <span class="screen-reader-text">
|
|
|
|
<?php
|
|
|
|
/* translators: Hidden accessibility text. */
|
|
|
|
_e( 'folder' );
|
|
|
|
?>
|
|
|
|
</span><span aria-hidden="true" class="icon"></span></span>
|
2017-10-13 04:39:47 +02:00
|
|
|
<ul role="group" class="tree-folder"><?php wp_print_plugin_file_tree( $plugin_file, '', $level + 1, $index, $size ); ?></ul>
|
|
|
|
</li>
|
|
|
|
<?php
|
|
|
|
endforeach;
|
|
|
|
} else {
|
|
|
|
$url = add_query_arg(
|
|
|
|
array(
|
2017-12-01 00:11:00 +01:00
|
|
|
'file' => rawurlencode( $tree ),
|
2017-10-13 04:39:47 +02:00
|
|
|
'plugin' => rawurlencode( $plugin ),
|
|
|
|
),
|
2017-11-03 19:51:49 +01:00
|
|
|
self_admin_url( 'plugin-editor.php' )
|
2017-10-13 04:39:47 +02:00
|
|
|
);
|
|
|
|
?>
|
|
|
|
<li role="none" class="<?php echo esc_attr( $file === $tree ? 'current-file' : '' ); ?>">
|
|
|
|
<a role="treeitem" tabindex="<?php echo esc_attr( $file === $tree ? '0' : '-1' ); ?>"
|
|
|
|
href="<?php echo esc_url( $url ); ?>"
|
|
|
|
aria-level="<?php echo esc_attr( $level ); ?>"
|
|
|
|
aria-setsize="<?php echo esc_attr( $size ); ?>"
|
|
|
|
aria-posinset="<?php echo esc_attr( $index ); ?>">
|
|
|
|
<?php
|
|
|
|
if ( $file === $tree ) {
|
|
|
|
echo '<span class="notice notice-info">' . esc_html( $label ) . '</span>';
|
|
|
|
} else {
|
|
|
|
echo esc_html( $label );
|
|
|
|
}
|
|
|
|
?>
|
|
|
|
</a>
|
|
|
|
</li>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-10-02 03:03:26 +02:00
|
|
|
/**
|
2015-10-05 04:52:24 +02:00
|
|
|
* Flushes rewrite rules if siteurl, home or page_on_front changed.
|
2008-10-02 03:03:26 +02:00
|
|
|
*
|
2010-12-01 20:24:38 +01:00
|
|
|
* @since 2.1.0
|
2008-10-02 03:03:26 +02:00
|
|
|
*
|
2012-02-28 21:29:33 +01:00
|
|
|
* @param string $old_value
|
|
|
|
* @param string $value
|
2008-10-02 03:03:26 +02:00
|
|
|
*/
|
2007-05-25 09:16:21 +02:00
|
|
|
function update_home_siteurl( $old_value, $value ) {
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( wp_installing() ) {
|
2007-05-25 09:16:21 +02:00
|
|
|
return;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2007-05-25 09:16:21 +02:00
|
|
|
|
2015-09-29 01:24:27 +02:00
|
|
|
if ( is_multisite() && ms_is_switched() ) {
|
|
|
|
delete_option( 'rewrite_rules' );
|
|
|
|
} else {
|
|
|
|
flush_rewrite_rules();
|
|
|
|
}
|
2007-05-25 09:16:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-10-02 03:03:26 +02:00
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Resets global variables based on $_GET and $_POST.
|
2010-01-15 23:11:12 +01:00
|
|
|
*
|
2009-12-26 17:48:24 +01:00
|
|
|
* This function resets global variables based on the names passed
|
|
|
|
* in the $vars array to the value of $_POST[$var] or $_GET[$var] or ''
|
|
|
|
* if neither is defined.
|
2008-10-02 03:03:26 +02:00
|
|
|
*
|
2010-12-01 20:24:38 +01:00
|
|
|
* @since 2.0.0
|
2008-10-02 03:03:26 +02:00
|
|
|
*
|
2009-12-26 17:48:24 +01:00
|
|
|
* @param array $vars An array of globals to reset.
|
2008-10-02 03:03:26 +02:00
|
|
|
*/
|
2007-05-25 09:16:21 +02:00
|
|
|
function wp_reset_vars( $vars ) {
|
2014-06-11 22:00:15 +02:00
|
|
|
foreach ( $vars as $var ) {
|
|
|
|
if ( empty( $_POST[ $var ] ) ) {
|
|
|
|
if ( empty( $_GET[ $var ] ) ) {
|
|
|
|
$GLOBALS[ $var ] = '';
|
|
|
|
} else {
|
|
|
|
$GLOBALS[ $var ] = $_GET[ $var ];
|
|
|
|
}
|
2010-01-26 07:06:14 +01:00
|
|
|
} else {
|
2014-06-11 22:00:15 +02:00
|
|
|
$GLOBALS[ $var ] = $_POST[ $var ];
|
2007-05-25 09:16:21 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-10-02 03:03:26 +02:00
|
|
|
/**
|
2015-10-05 04:52:24 +02:00
|
|
|
* Displays the given administration message.
|
2008-10-02 03:03:26 +02:00
|
|
|
*
|
2010-12-01 20:24:38 +01:00
|
|
|
* @since 2.1.0
|
2008-10-02 03:03:26 +02:00
|
|
|
*
|
2014-11-03 07:01:24 +01:00
|
|
|
* @param string|WP_Error $message
|
2008-10-02 03:03:26 +02:00
|
|
|
*/
|
2017-12-01 00:11:00 +01:00
|
|
|
function show_message( $message ) {
|
|
|
|
if ( is_wp_error( $message ) ) {
|
|
|
|
if ( $message->get_error_data() && is_string( $message->get_error_data() ) ) {
|
2008-08-04 23:01:09 +02:00
|
|
|
$message = $message->get_error_message() . ': ' . $message->get_error_data();
|
2017-12-01 00:11:00 +01:00
|
|
|
} else {
|
2008-08-04 23:01:09 +02:00
|
|
|
$message = $message->get_error_message();
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2008-08-04 23:01:09 +02:00
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2008-08-04 23:01:09 +02:00
|
|
|
echo "<p>$message</p>\n";
|
2010-03-06 09:39:50 +01:00
|
|
|
wp_ob_end_flush_all();
|
|
|
|
flush();
|
2008-08-04 23:01:09 +02:00
|
|
|
}
|
|
|
|
|
2015-05-31 05:18:25 +02:00
|
|
|
/**
|
|
|
|
* @since 2.8.0
|
|
|
|
*
|
|
|
|
* @param string $content
|
|
|
|
* @return array
|
|
|
|
*/
|
2009-02-20 21:00:09 +01:00
|
|
|
function wp_doc_link_parse( $content ) {
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( ! is_string( $content ) || empty( $content ) ) {
|
2009-02-20 21:00:09 +01:00
|
|
|
return array();
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2009-03-18 03:43:45 +01:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( ! function_exists( 'token_get_all' ) ) {
|
2009-06-29 22:48:12 +02:00
|
|
|
return array();
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2009-06-29 22:48:12 +02:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
$tokens = token_get_all( $content );
|
|
|
|
$count = count( $tokens );
|
|
|
|
$functions = array();
|
2009-02-20 21:00:09 +01:00
|
|
|
$ignore_functions = array();
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2014-02-28 00:16:13 +01:00
|
|
|
for ( $t = 0; $t < $count - 2; $t++ ) {
|
|
|
|
if ( ! is_array( $tokens[ $t ] ) ) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2022-02-13 18:09:05 +01:00
|
|
|
if ( T_STRING === $tokens[ $t ][0] && ( '(' === $tokens[ $t + 1 ] || '(' === $tokens[ $t + 2 ] ) ) {
|
2020-01-29 01:35:08 +01:00
|
|
|
// If it's a function or class defined locally, there's not going to be any docs available.
|
2020-04-05 05:02:11 +02:00
|
|
|
if ( ( isset( $tokens[ $t - 2 ][1] ) && in_array( $tokens[ $t - 2 ][1], array( 'function', 'class' ), true ) )
|
2022-02-13 18:09:05 +01:00
|
|
|
|| ( isset( $tokens[ $t - 2 ][0] ) && T_OBJECT_OPERATOR === $tokens[ $t - 1 ][0] )
|
2020-04-05 05:02:11 +02:00
|
|
|
) {
|
2017-12-01 00:11:00 +01:00
|
|
|
$ignore_functions[] = $tokens[ $t ][1];
|
2009-02-20 21:00:09 +01:00
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2020-01-29 01:35:08 +01:00
|
|
|
// Add this to our stack of unique references.
|
2017-12-01 00:11:00 +01:00
|
|
|
$functions[] = $tokens[ $t ][1];
|
2009-02-20 21:00:09 +01:00
|
|
|
}
|
|
|
|
}
|
2009-03-18 03:43:45 +01:00
|
|
|
|
2009-02-20 21:00:09 +01:00
|
|
|
$functions = array_unique( $functions );
|
|
|
|
sort( $functions );
|
2014-03-03 18:20:16 +01:00
|
|
|
|
|
|
|
/**
|
2016-05-22 20:01:30 +02:00
|
|
|
* Filters the list of functions and classes to be ignored from the documentation lookup.
|
2014-03-03 18:20:16 +01:00
|
|
|
*
|
|
|
|
* @since 2.8.0
|
|
|
|
*
|
2018-03-25 20:10:32 +02:00
|
|
|
* @param string[] $ignore_functions Array of names of functions and classes to be ignored.
|
2014-03-03 18:20:16 +01:00
|
|
|
*/
|
2009-02-20 21:00:09 +01:00
|
|
|
$ignore_functions = apply_filters( 'documentation_ignore_functions', $ignore_functions );
|
2014-03-03 18:20:16 +01:00
|
|
|
|
2009-02-20 21:00:09 +01:00
|
|
|
$ignore_functions = array_unique( $ignore_functions );
|
2009-03-18 03:43:45 +01:00
|
|
|
|
Coding Standards: Use more meaningful variable names for output in the admin.
This renames some variables for clarity, per the [https://developer.wordpress.org/coding-standards/wordpress-coding-standards/php/#naming-conventions Naming Conventions]:
> Don’t abbreviate variable names unnecessarily; let the code be unambiguous and self-documenting.
* `$out` is renamed to `$output` in various list table methods and admin functions.
* `$sep` is renamed to `$separator` in various list table methods and admin functions.
This affects:
* `WP_Comments_List_Table::handle_row_actions()`
* `WP_List_Table::row_actions()`
* `WP_Media_List_Table::column_default()`
* `WP_MS_Sites_List_Table::site_states()`
* `WP_MS_Users_List_Table::column_blogs()`
* `WP_Terms_List_Table::column_name()`
* `_wp_dashboard_recent_comments_row()`
* `image_align_input_fields()`
* `image_size_input_fields()`
* `wp_doc_link_parse()`
* `_post_states()`
* `_media_states()`
Follow-up to [8653], [8692], [8864], [8910], [8911], [8916], [9103], [9153], [10607], [15491], [17793], [32644], [54070].
Props mukesh27, costdev.
See #56448, #55647.
Built from https://develop.svn.wordpress.org/trunk@54071
git-svn-id: http://core.svn.wordpress.org/trunk@53630 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-09-05 19:19:09 +02:00
|
|
|
$output = array();
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2009-02-20 21:00:09 +01:00
|
|
|
foreach ( $functions as $function ) {
|
2020-04-05 05:02:11 +02:00
|
|
|
if ( in_array( $function, $ignore_functions, true ) ) {
|
2009-02-20 21:00:09 +01:00
|
|
|
continue;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
Coding Standards: Use more meaningful variable names for output in the admin.
This renames some variables for clarity, per the [https://developer.wordpress.org/coding-standards/wordpress-coding-standards/php/#naming-conventions Naming Conventions]:
> Don’t abbreviate variable names unnecessarily; let the code be unambiguous and self-documenting.
* `$out` is renamed to `$output` in various list table methods and admin functions.
* `$sep` is renamed to `$separator` in various list table methods and admin functions.
This affects:
* `WP_Comments_List_Table::handle_row_actions()`
* `WP_List_Table::row_actions()`
* `WP_Media_List_Table::column_default()`
* `WP_MS_Sites_List_Table::site_states()`
* `WP_MS_Users_List_Table::column_blogs()`
* `WP_Terms_List_Table::column_name()`
* `_wp_dashboard_recent_comments_row()`
* `image_align_input_fields()`
* `image_size_input_fields()`
* `wp_doc_link_parse()`
* `_post_states()`
* `_media_states()`
Follow-up to [8653], [8692], [8864], [8910], [8911], [8916], [9103], [9153], [10607], [15491], [17793], [32644], [54070].
Props mukesh27, costdev.
See #56448, #55647.
Built from https://develop.svn.wordpress.org/trunk@54071
git-svn-id: http://core.svn.wordpress.org/trunk@53630 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-09-05 19:19:09 +02:00
|
|
|
$output[] = $function;
|
2009-02-20 21:00:09 +01:00
|
|
|
}
|
2009-03-18 03:43:45 +01:00
|
|
|
|
Coding Standards: Use more meaningful variable names for output in the admin.
This renames some variables for clarity, per the [https://developer.wordpress.org/coding-standards/wordpress-coding-standards/php/#naming-conventions Naming Conventions]:
> Don’t abbreviate variable names unnecessarily; let the code be unambiguous and self-documenting.
* `$out` is renamed to `$output` in various list table methods and admin functions.
* `$sep` is renamed to `$separator` in various list table methods and admin functions.
This affects:
* `WP_Comments_List_Table::handle_row_actions()`
* `WP_List_Table::row_actions()`
* `WP_Media_List_Table::column_default()`
* `WP_MS_Sites_List_Table::site_states()`
* `WP_MS_Users_List_Table::column_blogs()`
* `WP_Terms_List_Table::column_name()`
* `_wp_dashboard_recent_comments_row()`
* `image_align_input_fields()`
* `image_size_input_fields()`
* `wp_doc_link_parse()`
* `_post_states()`
* `_media_states()`
Follow-up to [8653], [8692], [8864], [8910], [8911], [8916], [9103], [9153], [10607], [15491], [17793], [32644], [54070].
Props mukesh27, costdev.
See #56448, #55647.
Built from https://develop.svn.wordpress.org/trunk@54071
git-svn-id: http://core.svn.wordpress.org/trunk@53630 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-09-05 19:19:09 +02:00
|
|
|
return $output;
|
2009-02-20 21:00:09 +01:00
|
|
|
}
|
|
|
|
|
2009-04-17 14:46:53 +02:00
|
|
|
/**
|
|
|
|
* Saves option for number of rows when listing posts, pages, comments, etc.
|
|
|
|
*
|
2013-12-24 19:57:12 +01:00
|
|
|
* @since 2.8.0
|
2014-03-03 18:20:16 +01:00
|
|
|
*/
|
2009-04-17 14:55:03 +02:00
|
|
|
function set_screen_options() {
|
2022-02-13 18:09:05 +01:00
|
|
|
if ( ! isset( $_POST['wp_screen_options'] ) || ! is_array( $_POST['wp_screen_options'] ) ) {
|
|
|
|
return;
|
|
|
|
}
|
2009-04-17 14:46:53 +02:00
|
|
|
|
2022-02-13 18:09:05 +01:00
|
|
|
check_admin_referer( 'screen-options-nonce', 'screenoptionnonce' );
|
2009-04-17 14:46:53 +02:00
|
|
|
|
2022-02-13 18:09:05 +01:00
|
|
|
$user = wp_get_current_user();
|
2009-04-17 14:46:53 +02:00
|
|
|
|
2022-02-13 18:09:05 +01:00
|
|
|
if ( ! $user ) {
|
|
|
|
return;
|
|
|
|
}
|
2009-04-17 14:46:53 +02:00
|
|
|
|
2022-02-13 18:09:05 +01:00
|
|
|
$option = $_POST['wp_screen_options']['option'];
|
|
|
|
$value = $_POST['wp_screen_options']['value'];
|
2010-06-15 22:07:02 +02:00
|
|
|
|
2022-02-13 18:09:05 +01:00
|
|
|
if ( sanitize_key( $option ) !== $option ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$map_option = $option;
|
|
|
|
$type = str_replace( 'edit_', '', $map_option );
|
|
|
|
$type = str_replace( '_per_page', '', $type );
|
|
|
|
|
|
|
|
if ( in_array( $type, get_taxonomies(), true ) ) {
|
|
|
|
$map_option = 'edit_tags_per_page';
|
|
|
|
} elseif ( in_array( $type, get_post_types(), true ) ) {
|
|
|
|
$map_option = 'edit_per_page';
|
|
|
|
} else {
|
|
|
|
$option = str_replace( '-', '_', $option );
|
|
|
|
}
|
2020-06-10 19:24:51 +02:00
|
|
|
|
2022-02-13 18:09:05 +01:00
|
|
|
switch ( $map_option ) {
|
|
|
|
case 'edit_per_page':
|
|
|
|
case 'users_per_page':
|
|
|
|
case 'edit_comments_per_page':
|
|
|
|
case 'upload_per_page':
|
|
|
|
case 'edit_tags_per_page':
|
|
|
|
case 'plugins_per_page':
|
|
|
|
case 'export_personal_data_requests_per_page':
|
|
|
|
case 'remove_personal_data_requests_per_page':
|
|
|
|
// Network admin.
|
|
|
|
case 'sites_network_per_page':
|
|
|
|
case 'users_network_per_page':
|
|
|
|
case 'site_users_network_per_page':
|
|
|
|
case 'plugins_network_per_page':
|
|
|
|
case 'themes_network_per_page':
|
|
|
|
case 'site_themes_network_per_page':
|
|
|
|
$value = (int) $value;
|
|
|
|
|
|
|
|
if ( $value < 1 || $value > 999 ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
$screen_option = false;
|
|
|
|
|
Code Modernization: Replace usage of `substr()` with `str_starts_with()` and `str_ends_with()`.
`str_starts_with()` and `str_ends_with()` were introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) begins or ends with the given substring (needle).
WordPress core includes a polyfill for these functions on PHP < 8.0 as of WordPress 5.9.
This commit uses `str_starts_with()` and `str_ends_with()` in core files where appropriate:
* `$needle === substr( $string, 0, $length )`, where `$length` is the length of `$needle`, is replaced with `str_starts_with( $haystack, $needle )`.
* `$needle === substr( $string, $offset )`, where `$offset` is negative and the absolute value of `$offset` is the length of `$needle`, is replaced with `str_ends_with( $haystack, $needle )`.
This aims to make the code more readable and consistent, as well as better aligned with modern development practices.
Follow-up to [52039], [52040], [52326], [55703], [55710], [55987], [55988].
Props Soean, spacedmonkey, Clorith, ocean90, azaozz, sabernhardt, SergeyBiryukov.
Fixes #58220.
Built from https://develop.svn.wordpress.org/trunk@55990
git-svn-id: http://core.svn.wordpress.org/trunk@55502 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-22 16:57:24 +02:00
|
|
|
if ( str_ends_with( $option, '_page' ) || 'layout_columns' === $option ) {
|
2020-08-19 03:59:04 +02:00
|
|
|
/**
|
|
|
|
* Filters a screen option value before it is set.
|
|
|
|
*
|
2022-02-13 18:09:05 +01:00
|
|
|
* The filter can also be used to modify non-standard [items]_per_page
|
|
|
|
* settings. See the parent function for a full list of standard options.
|
2020-08-19 03:59:04 +02:00
|
|
|
*
|
|
|
|
* Returning false from the filter will skip saving the current option.
|
|
|
|
*
|
2022-02-13 18:09:05 +01:00
|
|
|
* @since 2.8.0
|
|
|
|
* @since 5.4.2 Only applied to options ending with '_page',
|
|
|
|
* or the 'layout_columns' option.
|
2020-08-19 03:59:04 +02:00
|
|
|
*
|
|
|
|
* @see set_screen_options()
|
|
|
|
*
|
2022-02-13 18:09:05 +01:00
|
|
|
* @param mixed $screen_option The value to save instead of the option value.
|
|
|
|
* Default false (to skip saving the current option).
|
|
|
|
* @param string $option The option name.
|
|
|
|
* @param int $value The option value.
|
2020-08-19 03:59:04 +02:00
|
|
|
*/
|
2022-02-13 18:09:05 +01:00
|
|
|
$screen_option = apply_filters( 'set-screen-option', $screen_option, $option, $value ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
|
|
|
|
}
|
2020-08-19 03:59:04 +02:00
|
|
|
|
2022-02-13 18:09:05 +01:00
|
|
|
/**
|
|
|
|
* Filters a screen option value before it is set.
|
|
|
|
*
|
|
|
|
* The dynamic portion of the hook name, `$option`, refers to the option name.
|
|
|
|
*
|
|
|
|
* Returning false from the filter will skip saving the current option.
|
|
|
|
*
|
|
|
|
* @since 5.4.2
|
|
|
|
*
|
|
|
|
* @see set_screen_options()
|
|
|
|
*
|
|
|
|
* @param mixed $screen_option The value to save instead of the option value.
|
|
|
|
* Default false (to skip saving the current option).
|
|
|
|
* @param string $option The option name.
|
|
|
|
* @param int $value The option value.
|
|
|
|
*/
|
|
|
|
$value = apply_filters( "set_screen_option_{$option}", $screen_option, $option, $value );
|
|
|
|
|
|
|
|
if ( false === $value ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
2009-04-17 14:46:53 +02:00
|
|
|
|
2022-02-13 18:09:05 +01:00
|
|
|
update_user_meta( $user->ID, $option, $value );
|
2015-10-22 21:25:25 +02:00
|
|
|
|
2022-02-13 18:09:05 +01:00
|
|
|
$url = remove_query_arg( array( 'pagenum', 'apage', 'paged' ), wp_get_referer() );
|
2015-10-22 21:25:25 +02:00
|
|
|
|
2022-02-13 18:09:05 +01:00
|
|
|
if ( isset( $_POST['mode'] ) ) {
|
|
|
|
$url = add_query_arg( array( 'mode' => $_POST['mode'] ), $url );
|
2009-04-17 14:46:53 +02:00
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
|
|
|
wp_safe_redirect( $url );
|
|
|
|
exit;
|
2009-04-17 14:46:53 +02:00
|
|
|
}
|
2009-04-29 07:43:03 +02:00
|
|
|
|
2009-05-16 04:04:36 +02:00
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Checks if rewrite rule for WordPress already exists in the IIS 7+ configuration file.
|
2009-05-25 01:47:49 +02:00
|
|
|
*
|
2009-05-16 04:04:36 +02:00
|
|
|
* @since 2.8.0
|
2009-05-25 01:47:49 +02:00
|
|
|
*
|
2022-04-11 23:48:09 +02:00
|
|
|
* @param string $filename The file path to the configuration file.
|
2022-02-13 18:09:05 +01:00
|
|
|
* @return bool
|
2009-05-16 04:04:36 +02:00
|
|
|
*/
|
2017-12-01 00:11:00 +01:00
|
|
|
function iis7_rewrite_rule_exists( $filename ) {
|
|
|
|
if ( ! file_exists( $filename ) ) {
|
2009-05-25 01:47:49 +02:00
|
|
|
return false;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2015-09-20 05:52:25 +02:00
|
|
|
if ( ! class_exists( 'DOMDocument', false ) ) {
|
2009-05-16 04:04:36 +02:00
|
|
|
return false;
|
2015-09-20 05:52:25 +02:00
|
|
|
}
|
2009-05-25 01:47:49 +02:00
|
|
|
|
2009-05-16 04:04:36 +02:00
|
|
|
$doc = new DOMDocument();
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( $doc->load( $filename ) === false ) {
|
2009-05-16 04:04:36 +02:00
|
|
|
return false;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
$xpath = new DOMXPath( $doc );
|
|
|
|
$rules = $xpath->query( '/configuration/system.webServer/rewrite/rules/rule[starts-with(@name,\'wordpress\')] | /configuration/system.webServer/rewrite/rules/rule[starts-with(@name,\'WordPress\')]' );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
|
|
|
if ( 0 === $rules->length ) {
|
2009-05-16 04:04:36 +02:00
|
|
|
return false;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
|
|
|
return true;
|
2009-05-16 04:04:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Deletes WordPress rewrite rule from web.config file if it exists there.
|
2009-05-16 04:04:36 +02:00
|
|
|
*
|
2009-05-25 01:47:49 +02:00
|
|
|
* @since 2.8.0
|
2009-05-16 04:04:36 +02:00
|
|
|
*
|
2022-04-11 23:48:09 +02:00
|
|
|
* @param string $filename Name of the configuration file.
|
2009-05-16 04:04:36 +02:00
|
|
|
* @return bool
|
|
|
|
*/
|
2017-12-01 00:11:00 +01:00
|
|
|
function iis7_delete_rewrite_rule( $filename ) {
|
2020-01-29 01:35:08 +01:00
|
|
|
// If configuration file does not exist then rules also do not exist, so there is nothing to delete.
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( ! file_exists( $filename ) ) {
|
2009-05-16 04:04:36 +02:00
|
|
|
return true;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2009-05-25 01:47:49 +02:00
|
|
|
|
2015-09-20 05:52:25 +02:00
|
|
|
if ( ! class_exists( 'DOMDocument', false ) ) {
|
2009-05-16 04:04:36 +02:00
|
|
|
return false;
|
2015-09-20 05:52:25 +02:00
|
|
|
}
|
2009-05-25 01:47:49 +02:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
$doc = new DOMDocument();
|
2009-05-16 04:04:36 +02:00
|
|
|
$doc->preserveWhiteSpace = false;
|
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( $doc->load( $filename ) === false ) {
|
2009-05-16 04:04:36 +02:00
|
|
|
return false;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
$xpath = new DOMXPath( $doc );
|
|
|
|
$rules = $xpath->query( '/configuration/system.webServer/rewrite/rules/rule[starts-with(@name,\'wordpress\')] | /configuration/system.webServer/rewrite/rules/rule[starts-with(@name,\'WordPress\')]' );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2009-05-16 04:04:36 +02:00
|
|
|
if ( $rules->length > 0 ) {
|
2017-12-01 00:11:00 +01:00
|
|
|
$child = $rules->item( 0 );
|
2009-05-16 04:04:36 +02:00
|
|
|
$parent = $child->parentNode;
|
2017-12-01 00:11:00 +01:00
|
|
|
$parent->removeChild( $child );
|
2009-05-16 04:04:36 +02:00
|
|
|
$doc->formatOutput = true;
|
2017-12-01 00:11:00 +01:00
|
|
|
saveDomDocument( $doc, $filename );
|
2009-05-16 04:04:36 +02:00
|
|
|
}
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2009-05-16 04:04:36 +02:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Adds WordPress rewrite rule to the IIS 7+ configuration file.
|
2009-05-25 01:47:49 +02:00
|
|
|
*
|
2009-05-16 04:04:36 +02:00
|
|
|
* @since 2.8.0
|
2009-05-25 01:47:49 +02:00
|
|
|
*
|
2022-04-11 23:48:09 +02:00
|
|
|
* @param string $filename The file path to the configuration file.
|
|
|
|
* @param string $rewrite_rule The XML fragment with URL Rewrite rule.
|
2009-05-16 04:04:36 +02:00
|
|
|
* @return bool
|
|
|
|
*/
|
2017-12-01 00:11:00 +01:00
|
|
|
function iis7_add_rewrite_rule( $filename, $rewrite_rule ) {
|
2015-09-20 05:52:25 +02:00
|
|
|
if ( ! class_exists( 'DOMDocument', false ) ) {
|
2009-05-16 04:04:36 +02:00
|
|
|
return false;
|
2015-09-20 05:52:25 +02:00
|
|
|
}
|
2009-05-25 01:47:49 +02:00
|
|
|
|
2009-05-16 04:04:36 +02:00
|
|
|
// If configuration file does not exist then we create one.
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( ! file_exists( $filename ) ) {
|
|
|
|
$fp = fopen( $filename, 'w' );
|
|
|
|
fwrite( $fp, '<configuration/>' );
|
|
|
|
fclose( $fp );
|
2009-05-16 04:04:36 +02:00
|
|
|
}
|
2009-05-25 01:47:49 +02:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
$doc = new DOMDocument();
|
2009-05-16 04:04:36 +02:00
|
|
|
$doc->preserveWhiteSpace = false;
|
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( $doc->load( $filename ) === false ) {
|
2009-05-16 04:04:36 +02:00
|
|
|
return false;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2009-05-25 01:47:49 +02:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
$xpath = new DOMXPath( $doc );
|
2009-05-16 04:04:36 +02:00
|
|
|
|
2020-01-29 01:35:08 +01:00
|
|
|
// First check if the rule already exists as in that case there is no need to re-add it.
|
2017-12-01 00:11:00 +01:00
|
|
|
$wordpress_rules = $xpath->query( '/configuration/system.webServer/rewrite/rules/rule[starts-with(@name,\'wordpress\')] | /configuration/system.webServer/rewrite/rules/rule[starts-with(@name,\'WordPress\')]' );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( $wordpress_rules->length > 0 ) {
|
2009-05-16 04:04:36 +02:00
|
|
|
return true;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2009-05-16 04:04:36 +02:00
|
|
|
|
2020-01-29 01:35:08 +01:00
|
|
|
// Check the XPath to the rewrite rule and create XML nodes if they do not exist.
|
2022-02-15 14:49:04 +01:00
|
|
|
$xml_nodes = $xpath->query( '/configuration/system.webServer/rewrite/rules' );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2022-02-15 14:49:04 +01:00
|
|
|
if ( $xml_nodes->length > 0 ) {
|
|
|
|
$rules_node = $xml_nodes->item( 0 );
|
2009-05-16 04:04:36 +02:00
|
|
|
} else {
|
2017-12-01 00:11:00 +01:00
|
|
|
$rules_node = $doc->createElement( 'rules' );
|
2009-05-25 01:47:49 +02:00
|
|
|
|
2022-02-15 14:49:04 +01:00
|
|
|
$xml_nodes = $xpath->query( '/configuration/system.webServer/rewrite' );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2022-02-15 14:49:04 +01:00
|
|
|
if ( $xml_nodes->length > 0 ) {
|
|
|
|
$rewrite_node = $xml_nodes->item( 0 );
|
2017-12-01 00:11:00 +01:00
|
|
|
$rewrite_node->appendChild( $rules_node );
|
2009-05-16 04:04:36 +02:00
|
|
|
} else {
|
2017-12-01 00:11:00 +01:00
|
|
|
$rewrite_node = $doc->createElement( 'rewrite' );
|
|
|
|
$rewrite_node->appendChild( $rules_node );
|
2009-05-16 04:04:36 +02:00
|
|
|
|
2022-02-15 14:49:04 +01:00
|
|
|
$xml_nodes = $xpath->query( '/configuration/system.webServer' );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2022-02-15 14:49:04 +01:00
|
|
|
if ( $xml_nodes->length > 0 ) {
|
|
|
|
$system_web_server_node = $xml_nodes->item( 0 );
|
|
|
|
$system_web_server_node->appendChild( $rewrite_node );
|
2009-05-16 04:04:36 +02:00
|
|
|
} else {
|
2022-02-15 14:49:04 +01:00
|
|
|
$system_web_server_node = $doc->createElement( 'system.webServer' );
|
|
|
|
$system_web_server_node->appendChild( $rewrite_node );
|
2009-05-25 01:47:49 +02:00
|
|
|
|
2022-02-15 14:49:04 +01:00
|
|
|
$xml_nodes = $xpath->query( '/configuration' );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2022-02-15 14:49:04 +01:00
|
|
|
if ( $xml_nodes->length > 0 ) {
|
|
|
|
$config_node = $xml_nodes->item( 0 );
|
|
|
|
$config_node->appendChild( $system_web_server_node );
|
2009-05-16 04:04:36 +02:00
|
|
|
} else {
|
2017-12-01 00:11:00 +01:00
|
|
|
$config_node = $doc->createElement( 'configuration' );
|
|
|
|
$doc->appendChild( $config_node );
|
2022-02-15 14:49:04 +01:00
|
|
|
$config_node->appendChild( $system_web_server_node );
|
2009-05-16 04:04:36 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2009-05-25 01:47:49 +02:00
|
|
|
|
2009-05-16 04:04:36 +02:00
|
|
|
$rule_fragment = $doc->createDocumentFragment();
|
2017-12-01 00:11:00 +01:00
|
|
|
$rule_fragment->appendXML( $rewrite_rule );
|
|
|
|
$rules_node->appendChild( $rule_fragment );
|
2009-05-16 04:04:36 +02:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
$doc->encoding = 'UTF-8';
|
2009-05-25 01:47:49 +02:00
|
|
|
$doc->formatOutput = true;
|
2017-12-01 00:11:00 +01:00
|
|
|
saveDomDocument( $doc, $filename );
|
2009-05-16 04:04:36 +02:00
|
|
|
|
2009-05-25 01:47:49 +02:00
|
|
|
return true;
|
2009-05-16 04:04:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Saves the XML document into a file.
|
2009-05-25 01:47:49 +02:00
|
|
|
*
|
2009-05-16 04:04:36 +02:00
|
|
|
* @since 2.8.0
|
|
|
|
*
|
|
|
|
* @param DOMDocument $doc
|
2020-07-23 22:01:04 +02:00
|
|
|
* @param string $filename
|
2009-05-16 04:04:36 +02:00
|
|
|
*/
|
2019-07-01 10:01:57 +02:00
|
|
|
function saveDomDocument( $doc, $filename ) { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionNameInvalid
|
2009-05-16 04:04:36 +02:00
|
|
|
$config = $doc->saveXML();
|
2017-12-01 00:11:00 +01:00
|
|
|
$config = preg_replace( "/([^\r])\n/", "$1\r\n", $config );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
|
|
|
$fp = fopen( $filename, 'w' );
|
2017-12-01 00:11:00 +01:00
|
|
|
fwrite( $fp, $config );
|
|
|
|
fclose( $fp );
|
2009-05-16 04:04:36 +02:00
|
|
|
}
|
|
|
|
|
2010-02-28 07:34:31 +01:00
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Displays the default admin color scheme picker (Used in user-edit.php).
|
2010-02-28 07:34:31 +01:00
|
|
|
*
|
2010-03-23 20:13:58 +01:00
|
|
|
* @since 3.0.0
|
2015-05-28 23:41:30 +02:00
|
|
|
*
|
|
|
|
* @global array $_wp_admin_css_colors
|
2016-01-09 02:45:26 +01:00
|
|
|
*
|
|
|
|
* @param int $user_id User ID.
|
2010-02-28 07:34:31 +01:00
|
|
|
*/
|
2014-01-08 22:49:10 +01:00
|
|
|
function admin_color_scheme_picker( $user_id ) {
|
2013-12-08 08:05:10 +01:00
|
|
|
global $_wp_admin_css_colors;
|
2013-12-01 20:50:09 +01:00
|
|
|
|
|
|
|
ksort( $_wp_admin_css_colors );
|
|
|
|
|
|
|
|
if ( isset( $_wp_admin_css_colors['fresh'] ) ) {
|
2013-12-07 08:46:21 +01:00
|
|
|
// Set Default ('fresh') and Light should go first.
|
2017-12-01 00:11:00 +01:00
|
|
|
$_wp_admin_css_colors = array_filter(
|
|
|
|
array_merge(
|
|
|
|
array(
|
2020-07-06 21:23:02 +02:00
|
|
|
'fresh' => '',
|
|
|
|
'light' => '',
|
2020-07-02 16:55:05 +02:00
|
|
|
'modern' => '',
|
2018-08-17 03:51:36 +02:00
|
|
|
),
|
|
|
|
$_wp_admin_css_colors
|
2017-12-01 00:11:00 +01:00
|
|
|
)
|
|
|
|
);
|
2013-12-01 20:50:09 +01:00
|
|
|
}
|
Merge the color schemes component from MP6. Introduces Light, Blue, and Midnight.
Color scheme selection on your own profile page gives you a preview and autosaves the selection.
Also introduces the usage of a preprocessor for core files, namely Sass. For 3.8, we will not expand its implementation past the color schemes. This does require Ruby as well as Sass 3.3.0+ due to the usage of the sourcemap option.
Note that only the default color scheme is available when running out of src. Use build to test the rest as well as the color picker.
props ryelle, melchoyce, tillkruess, drw158, littlethingsstudio, helen. see #25858, #22862.
Built from https://develop.svn.wordpress.org/trunk@26137
git-svn-id: http://core.svn.wordpress.org/trunk@26048 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2013-11-13 20:38:38 +01:00
|
|
|
|
2014-01-08 22:49:10 +01:00
|
|
|
$current_color = get_user_option( 'admin_color', $user_id );
|
Merge the color schemes component from MP6. Introduces Light, Blue, and Midnight.
Color scheme selection on your own profile page gives you a preview and autosaves the selection.
Also introduces the usage of a preprocessor for core files, namely Sass. For 3.8, we will not expand its implementation past the color schemes. This does require Ruby as well as Sass 3.3.0+ due to the usage of the sourcemap option.
Note that only the default color scheme is available when running out of src. Use build to test the rest as well as the color picker.
props ryelle, melchoyce, tillkruess, drw158, littlethingsstudio, helen. see #25858, #22862.
Built from https://develop.svn.wordpress.org/trunk@26137
git-svn-id: http://core.svn.wordpress.org/trunk@26048 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2013-11-13 20:38:38 +01:00
|
|
|
|
2013-12-01 20:50:09 +01:00
|
|
|
if ( empty( $current_color ) || ! isset( $_wp_admin_css_colors[ $current_color ] ) ) {
|
Merge the color schemes component from MP6. Introduces Light, Blue, and Midnight.
Color scheme selection on your own profile page gives you a preview and autosaves the selection.
Also introduces the usage of a preprocessor for core files, namely Sass. For 3.8, we will not expand its implementation past the color schemes. This does require Ruby as well as Sass 3.3.0+ due to the usage of the sourcemap option.
Note that only the default color scheme is available when running out of src. Use build to test the rest as well as the color picker.
props ryelle, melchoyce, tillkruess, drw158, littlethingsstudio, helen. see #25858, #22862.
Built from https://develop.svn.wordpress.org/trunk@26137
git-svn-id: http://core.svn.wordpress.org/trunk@26048 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2013-11-13 20:38:38 +01:00
|
|
|
$current_color = 'fresh';
|
2013-12-01 20:50:09 +01:00
|
|
|
}
|
|
|
|
?>
|
|
|
|
<fieldset id="color-picker" class="scheme-list">
|
I18N: Mark screen reader strings as such with translator comments.
This aims to provide better context for translators and make it easier to determine that some strings contain hidden accessibility text and are not displayed in the UI.
Props kebbet, mercime, pavelevap, ocean90, swissspidy, Chouby, jipmoors, afercia, desrosj, costdev, audrasjb, SergeyBiryukov.
Fixes #29748.
Built from https://develop.svn.wordpress.org/trunk@55276
git-svn-id: http://core.svn.wordpress.org/trunk@54809 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-02-07 18:10:21 +01:00
|
|
|
<legend class="screen-reader-text"><span>
|
|
|
|
<?php
|
|
|
|
/* translators: Hidden accessibility text. */
|
|
|
|
_e( 'Admin Color Scheme' );
|
|
|
|
?>
|
|
|
|
</span></legend>
|
2013-12-01 20:50:09 +01:00
|
|
|
<?php
|
2013-12-08 08:05:10 +01:00
|
|
|
wp_nonce_field( 'save-color-scheme', 'color-nonce', false );
|
2013-12-01 20:50:09 +01:00
|
|
|
foreach ( $_wp_admin_css_colors as $color => $color_info ) :
|
Merge the color schemes component from MP6. Introduces Light, Blue, and Midnight.
Color scheme selection on your own profile page gives you a preview and autosaves the selection.
Also introduces the usage of a preprocessor for core files, namely Sass. For 3.8, we will not expand its implementation past the color schemes. This does require Ruby as well as Sass 3.3.0+ due to the usage of the sourcemap option.
Note that only the default color scheme is available when running out of src. Use build to test the rest as well as the color picker.
props ryelle, melchoyce, tillkruess, drw158, littlethingsstudio, helen. see #25858, #22862.
Built from https://develop.svn.wordpress.org/trunk@26137
git-svn-id: http://core.svn.wordpress.org/trunk@26048 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2013-11-13 20:38:38 +01:00
|
|
|
|
2013-12-01 20:50:09 +01:00
|
|
|
?>
|
2022-02-13 18:09:05 +01:00
|
|
|
<div class="color-option <?php echo ( $color === $current_color ) ? 'selected' : ''; ?>">
|
Merge the color schemes component from MP6. Introduces Light, Blue, and Midnight.
Color scheme selection on your own profile page gives you a preview and autosaves the selection.
Also introduces the usage of a preprocessor for core files, namely Sass. For 3.8, we will not expand its implementation past the color schemes. This does require Ruby as well as Sass 3.3.0+ due to the usage of the sourcemap option.
Note that only the default color scheme is available when running out of src. Use build to test the rest as well as the color picker.
props ryelle, melchoyce, tillkruess, drw158, littlethingsstudio, helen. see #25858, #22862.
Built from https://develop.svn.wordpress.org/trunk@26137
git-svn-id: http://core.svn.wordpress.org/trunk@26048 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2013-11-13 20:38:38 +01:00
|
|
|
<input name="admin_color" id="admin_color_<?php echo esc_attr( $color ); ?>" type="radio" value="<?php echo esc_attr( $color ); ?>" class="tog" <?php checked( $color, $current_color ); ?> />
|
|
|
|
<input type="hidden" class="css_url" value="<?php echo esc_url( $color_info->url ); ?>" />
|
2014-10-28 19:35:19 +01:00
|
|
|
<input type="hidden" class="icon_colors" value="<?php echo esc_attr( wp_json_encode( array( 'icons' => $color_info->icon_colors ) ) ); ?>" />
|
Merge the color schemes component from MP6. Introduces Light, Blue, and Midnight.
Color scheme selection on your own profile page gives you a preview and autosaves the selection.
Also introduces the usage of a preprocessor for core files, namely Sass. For 3.8, we will not expand its implementation past the color schemes. This does require Ruby as well as Sass 3.3.0+ due to the usage of the sourcemap option.
Note that only the default color scheme is available when running out of src. Use build to test the rest as well as the color picker.
props ryelle, melchoyce, tillkruess, drw158, littlethingsstudio, helen. see #25858, #22862.
Built from https://develop.svn.wordpress.org/trunk@26137
git-svn-id: http://core.svn.wordpress.org/trunk@26048 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2013-11-13 20:38:38 +01:00
|
|
|
<label for="admin_color_<?php echo esc_attr( $color ); ?>"><?php echo esc_html( $color_info->name ); ?></label>
|
|
|
|
<table class="color-palette">
|
|
|
|
<tr>
|
2013-12-01 20:50:09 +01:00
|
|
|
<?php
|
|
|
|
foreach ( $color_info->colors as $html_color ) {
|
|
|
|
?>
|
2013-12-07 08:46:21 +01:00
|
|
|
<td style="background-color: <?php echo esc_attr( $html_color ); ?>"> </td>
|
2013-12-01 20:50:09 +01:00
|
|
|
<?php
|
|
|
|
}
|
|
|
|
?>
|
Merge the color schemes component from MP6. Introduces Light, Blue, and Midnight.
Color scheme selection on your own profile page gives you a preview and autosaves the selection.
Also introduces the usage of a preprocessor for core files, namely Sass. For 3.8, we will not expand its implementation past the color schemes. This does require Ruby as well as Sass 3.3.0+ due to the usage of the sourcemap option.
Note that only the default color scheme is available when running out of src. Use build to test the rest as well as the color picker.
props ryelle, melchoyce, tillkruess, drw158, littlethingsstudio, helen. see #25858, #22862.
Built from https://develop.svn.wordpress.org/trunk@26137
git-svn-id: http://core.svn.wordpress.org/trunk@26048 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2013-11-13 20:38:38 +01:00
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
</div>
|
2013-12-01 20:50:09 +01:00
|
|
|
<?php
|
Merge the color schemes component from MP6. Introduces Light, Blue, and Midnight.
Color scheme selection on your own profile page gives you a preview and autosaves the selection.
Also introduces the usage of a preprocessor for core files, namely Sass. For 3.8, we will not expand its implementation past the color schemes. This does require Ruby as well as Sass 3.3.0+ due to the usage of the sourcemap option.
Note that only the default color scheme is available when running out of src. Use build to test the rest as well as the color picker.
props ryelle, melchoyce, tillkruess, drw158, littlethingsstudio, helen. see #25858, #22862.
Built from https://develop.svn.wordpress.org/trunk@26137
git-svn-id: http://core.svn.wordpress.org/trunk@26048 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2013-11-13 20:38:38 +01:00
|
|
|
|
2013-12-01 20:50:09 +01:00
|
|
|
endforeach;
|
2018-08-17 03:51:36 +02:00
|
|
|
?>
|
Merge the color schemes component from MP6. Introduces Light, Blue, and Midnight.
Color scheme selection on your own profile page gives you a preview and autosaves the selection.
Also introduces the usage of a preprocessor for core files, namely Sass. For 3.8, we will not expand its implementation past the color schemes. This does require Ruby as well as Sass 3.3.0+ due to the usage of the sourcemap option.
Note that only the default color scheme is available when running out of src. Use build to test the rest as well as the color picker.
props ryelle, melchoyce, tillkruess, drw158, littlethingsstudio, helen. see #25858, #22862.
Built from https://develop.svn.wordpress.org/trunk@26137
git-svn-id: http://core.svn.wordpress.org/trunk@26048 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2013-11-13 20:38:38 +01:00
|
|
|
</fieldset>
|
2013-12-01 20:50:09 +01:00
|
|
|
<?php
|
2010-02-28 07:34:31 +01:00
|
|
|
}
|
2011-10-10 06:19:05 +02:00
|
|
|
|
2015-05-28 23:41:30 +02:00
|
|
|
/**
|
2018-12-14 06:43:52 +01:00
|
|
|
*
|
2015-05-28 23:41:30 +02:00
|
|
|
* @global array $_wp_admin_css_colors
|
|
|
|
*/
|
2013-12-04 05:13:11 +01:00
|
|
|
function wp_color_scheme_settings() {
|
Merge the color schemes component from MP6. Introduces Light, Blue, and Midnight.
Color scheme selection on your own profile page gives you a preview and autosaves the selection.
Also introduces the usage of a preprocessor for core files, namely Sass. For 3.8, we will not expand its implementation past the color schemes. This does require Ruby as well as Sass 3.3.0+ due to the usage of the sourcemap option.
Note that only the default color scheme is available when running out of src. Use build to test the rest as well as the color picker.
props ryelle, melchoyce, tillkruess, drw158, littlethingsstudio, helen. see #25858, #22862.
Built from https://develop.svn.wordpress.org/trunk@26137
git-svn-id: http://core.svn.wordpress.org/trunk@26048 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2013-11-13 20:38:38 +01:00
|
|
|
global $_wp_admin_css_colors;
|
|
|
|
|
|
|
|
$color_scheme = get_user_option( 'admin_color' );
|
|
|
|
|
2013-12-05 07:38:09 +01:00
|
|
|
// It's possible to have a color scheme set that is no longer registered.
|
|
|
|
if ( empty( $_wp_admin_css_colors[ $color_scheme ] ) ) {
|
|
|
|
$color_scheme = 'fresh';
|
|
|
|
}
|
|
|
|
|
2013-12-04 05:13:11 +01:00
|
|
|
if ( ! empty( $_wp_admin_css_colors[ $color_scheme ]->icon_colors ) ) {
|
2013-12-05 07:38:09 +01:00
|
|
|
$icon_colors = $_wp_admin_css_colors[ $color_scheme ]->icon_colors;
|
|
|
|
} elseif ( ! empty( $_wp_admin_css_colors['fresh']->icon_colors ) ) {
|
|
|
|
$icon_colors = $_wp_admin_css_colors['fresh']->icon_colors;
|
|
|
|
} else {
|
|
|
|
// Fall back to the default set of icon colors if the default scheme is missing.
|
2017-12-01 00:11:00 +01:00
|
|
|
$icon_colors = array(
|
Administration: Standardize colors used in CSS to a single palette.
This is part of a larger project in cleaning up core's admin CSS. This collapses all colors used in the CSS to one of 12 blues, greens, reds, and yellows, 13 grays, pure black, and pure white. The colors are perceptually uniform from light to dark, half of each range has a 4.5 or higher contrast against white, the other half has a 4.5 or higher contrast against black.
Standardizing on this set of colors will help contributors make consistent, accessible design decisions. The full color palette can be seen here: https://codepen.io/ryelle/full/WNGVEjw
Props notlaura, danfarrow, kburgoine, drw158, audrasjb, Joen, hedgefield, ibdz, melchoyce.
See #49999.
Built from https://develop.svn.wordpress.org/trunk@50025
git-svn-id: http://core.svn.wordpress.org/trunk@49726 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-01-26 19:54:59 +01:00
|
|
|
'base' => '#a7aaad',
|
|
|
|
'focus' => '#72aee6',
|
2017-12-01 00:11:00 +01:00
|
|
|
'current' => '#fff',
|
|
|
|
);
|
Merge the color schemes component from MP6. Introduces Light, Blue, and Midnight.
Color scheme selection on your own profile page gives you a preview and autosaves the selection.
Also introduces the usage of a preprocessor for core files, namely Sass. For 3.8, we will not expand its implementation past the color schemes. This does require Ruby as well as Sass 3.3.0+ due to the usage of the sourcemap option.
Note that only the default color scheme is available when running out of src. Use build to test the rest as well as the color picker.
props ryelle, melchoyce, tillkruess, drw158, littlethingsstudio, helen. see #25858, #22862.
Built from https://develop.svn.wordpress.org/trunk@26137
git-svn-id: http://core.svn.wordpress.org/trunk@26048 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2013-11-13 20:38:38 +01:00
|
|
|
}
|
2013-12-05 07:38:09 +01:00
|
|
|
|
2014-10-28 19:35:19 +01:00
|
|
|
echo '<script type="text/javascript">var _wpColorScheme = ' . wp_json_encode( array( 'icons' => $icon_colors ) ) . ";</script>\n";
|
Merge the color schemes component from MP6. Introduces Light, Blue, and Midnight.
Color scheme selection on your own profile page gives you a preview and autosaves the selection.
Also introduces the usage of a preprocessor for core files, namely Sass. For 3.8, we will not expand its implementation past the color schemes. This does require Ruby as well as Sass 3.3.0+ due to the usage of the sourcemap option.
Note that only the default color scheme is available when running out of src. Use build to test the rest as well as the color picker.
props ryelle, melchoyce, tillkruess, drw158, littlethingsstudio, helen. see #25858, #22862.
Built from https://develop.svn.wordpress.org/trunk@26137
git-svn-id: http://core.svn.wordpress.org/trunk@26048 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2013-11-13 20:38:38 +01:00
|
|
|
}
|
|
|
|
|
2015-05-31 05:18:25 +02:00
|
|
|
/**
|
Administration: Remove multiple viewport meta tags from mobile pages.
In addition, add the `wp_admin_viewport_meta()` function, paired to the `admin_viewport_meta` filter to control attributes of the meta tag.
Fixes #47369.
Props BettyJJ, mukesh27, SergeyBiryukov, ajayghaghretiya1, msaggiorato, talldanwp, davidbaumwald, donmhico, audrasjb.
Built from https://develop.svn.wordpress.org/trunk@48412
git-svn-id: http://core.svn.wordpress.org/trunk@48181 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-07-10 01:29:08 +02:00
|
|
|
* Displays the viewport meta in the admin.
|
|
|
|
*
|
|
|
|
* @since 5.5.0
|
2015-05-31 05:18:25 +02:00
|
|
|
*/
|
Administration: Remove multiple viewport meta tags from mobile pages.
In addition, add the `wp_admin_viewport_meta()` function, paired to the `admin_viewport_meta` filter to control attributes of the meta tag.
Fixes #47369.
Props BettyJJ, mukesh27, SergeyBiryukov, ajayghaghretiya1, msaggiorato, talldanwp, davidbaumwald, donmhico, audrasjb.
Built from https://develop.svn.wordpress.org/trunk@48412
git-svn-id: http://core.svn.wordpress.org/trunk@48181 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-07-10 01:29:08 +02:00
|
|
|
function wp_admin_viewport_meta() {
|
|
|
|
/**
|
|
|
|
* Filters the viewport meta in the admin.
|
|
|
|
*
|
|
|
|
* @since 5.5.0
|
|
|
|
*
|
|
|
|
* @param string $viewport_meta The viewport meta.
|
|
|
|
*/
|
|
|
|
$viewport_meta = apply_filters( 'admin_viewport_meta', 'width=device-width,initial-scale=1.0' );
|
2020-07-10 13:36:07 +02:00
|
|
|
|
Administration: Remove multiple viewport meta tags from mobile pages.
In addition, add the `wp_admin_viewport_meta()` function, paired to the `admin_viewport_meta` filter to control attributes of the meta tag.
Fixes #47369.
Props BettyJJ, mukesh27, SergeyBiryukov, ajayghaghretiya1, msaggiorato, talldanwp, davidbaumwald, donmhico, audrasjb.
Built from https://develop.svn.wordpress.org/trunk@48412
git-svn-id: http://core.svn.wordpress.org/trunk@48181 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-07-10 01:29:08 +02:00
|
|
|
if ( empty( $viewport_meta ) ) {
|
|
|
|
return;
|
2011-10-10 06:19:05 +02:00
|
|
|
}
|
2020-07-10 13:36:07 +02:00
|
|
|
|
Administration: Remove multiple viewport meta tags from mobile pages.
In addition, add the `wp_admin_viewport_meta()` function, paired to the `admin_viewport_meta` filter to control attributes of the meta tag.
Fixes #47369.
Props BettyJJ, mukesh27, SergeyBiryukov, ajayghaghretiya1, msaggiorato, talldanwp, davidbaumwald, donmhico, audrasjb.
Built from https://develop.svn.wordpress.org/trunk@48412
git-svn-id: http://core.svn.wordpress.org/trunk@48181 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-07-10 01:29:08 +02:00
|
|
|
echo '<meta name="viewport" content="' . esc_attr( $viewport_meta ) . '">';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2020-07-10 13:36:07 +02:00
|
|
|
* Adds viewport meta for mobile in Customizer.
|
Administration: Remove multiple viewport meta tags from mobile pages.
In addition, add the `wp_admin_viewport_meta()` function, paired to the `admin_viewport_meta` filter to control attributes of the meta tag.
Fixes #47369.
Props BettyJJ, mukesh27, SergeyBiryukov, ajayghaghretiya1, msaggiorato, talldanwp, davidbaumwald, donmhico, audrasjb.
Built from https://develop.svn.wordpress.org/trunk@48412
git-svn-id: http://core.svn.wordpress.org/trunk@48181 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-07-10 01:29:08 +02:00
|
|
|
*
|
|
|
|
* Hooked to the {@see 'admin_viewport_meta'} filter.
|
|
|
|
*
|
|
|
|
* @since 5.5.0
|
2020-07-10 13:36:07 +02:00
|
|
|
*
|
|
|
|
* @param string $viewport_meta The viewport meta.
|
|
|
|
* @return string Filtered viewport meta.
|
Administration: Remove multiple viewport meta tags from mobile pages.
In addition, add the `wp_admin_viewport_meta()` function, paired to the `admin_viewport_meta` filter to control attributes of the meta tag.
Fixes #47369.
Props BettyJJ, mukesh27, SergeyBiryukov, ajayghaghretiya1, msaggiorato, talldanwp, davidbaumwald, donmhico, audrasjb.
Built from https://develop.svn.wordpress.org/trunk@48412
git-svn-id: http://core.svn.wordpress.org/trunk@48181 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-07-10 01:29:08 +02:00
|
|
|
*/
|
2020-07-10 13:36:07 +02:00
|
|
|
function _customizer_mobile_viewport_meta( $viewport_meta ) {
|
|
|
|
return trim( $viewport_meta, ',' ) . ',minimum-scale=0.5,maximum-scale=1.2';
|
2011-10-10 06:19:05 +02:00
|
|
|
}
|
2013-02-26 00:17:10 +01:00
|
|
|
|
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Checks lock status for posts displayed on the Posts screen.
|
2013-02-26 00:17:10 +01:00
|
|
|
*
|
2013-12-24 19:57:12 +01:00
|
|
|
* @since 3.6.0
|
2016-01-09 02:37:26 +01:00
|
|
|
*
|
|
|
|
* @param array $response The Heartbeat response.
|
|
|
|
* @param array $data The $_POST data sent.
|
2020-06-28 16:09:04 +02:00
|
|
|
* @param string $screen_id The screen ID.
|
2016-01-09 02:37:26 +01:00
|
|
|
* @return array The Heartbeat response.
|
2013-02-26 00:17:10 +01:00
|
|
|
*/
|
2013-03-13 01:28:07 +01:00
|
|
|
function wp_check_locked_posts( $response, $data, $screen_id ) {
|
2013-02-26 00:17:10 +01:00
|
|
|
$checked = array();
|
|
|
|
|
2013-06-05 05:01:59 +02:00
|
|
|
if ( array_key_exists( 'wp-check-locked-posts', $data ) && is_array( $data['wp-check-locked-posts'] ) ) {
|
2013-06-05 02:13:40 +02:00
|
|
|
foreach ( $data['wp-check-locked-posts'] as $key ) {
|
2019-07-01 14:52:01 +02:00
|
|
|
$post_id = absint( substr( $key, 5 ) );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2019-07-01 14:52:01 +02:00
|
|
|
if ( ! $post_id ) {
|
2013-06-05 05:01:59 +02:00
|
|
|
continue;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2013-02-26 00:17:10 +01:00
|
|
|
|
2019-07-01 14:52:01 +02:00
|
|
|
$user_id = wp_check_post_lock( $post_id );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2019-07-01 14:52:01 +02:00
|
|
|
if ( $user_id ) {
|
|
|
|
$user = get_userdata( $user_id );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2019-07-01 14:52:01 +02:00
|
|
|
if ( $user && current_user_can( 'edit_post', $post_id ) ) {
|
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 19:13:59 +02:00
|
|
|
$send = array(
|
2022-04-05 11:21:02 +02:00
|
|
|
'name' => $user->display_name,
|
2019-09-03 02:41:05 +02:00
|
|
|
/* translators: %s: User's display name. */
|
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 19:13:59 +02:00
|
|
|
'text' => sprintf( __( '%s is currently editing' ), $user->display_name ),
|
|
|
|
);
|
2013-03-13 01:28:07 +01:00
|
|
|
|
2020-07-05 15:00:07 +02:00
|
|
|
if ( get_option( 'show_avatars' ) ) {
|
|
|
|
$send['avatar_src'] = get_avatar_url( $user->ID, array( 'size' => 18 ) );
|
|
|
|
$send['avatar_src_2x'] = get_avatar_url( $user->ID, array( 'size' => 36 ) );
|
2019-07-01 14:52:01 +02:00
|
|
|
}
|
2013-03-13 01:28:07 +01:00
|
|
|
|
2019-07-01 14:52:01 +02:00
|
|
|
$checked[ $key ] = $send;
|
|
|
|
}
|
2013-02-26 00:17:10 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( ! empty( $checked ) ) {
|
2013-06-05 02:13:40 +02:00
|
|
|
$response['wp-check-locked-posts'] = $checked;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2013-02-26 00:17:10 +01:00
|
|
|
|
|
|
|
return $response;
|
|
|
|
}
|
2013-03-12 04:22:30 +01:00
|
|
|
|
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Checks lock status on the New/Edit Post screen and refresh the lock.
|
2013-03-12 04:22:30 +01:00
|
|
|
*
|
2013-12-24 19:57:12 +01:00
|
|
|
* @since 3.6.0
|
2016-01-09 02:37:26 +01:00
|
|
|
*
|
|
|
|
* @param array $response The Heartbeat response.
|
|
|
|
* @param array $data The $_POST data sent.
|
2020-06-28 16:09:04 +02:00
|
|
|
* @param string $screen_id The screen ID.
|
2016-01-09 02:37:26 +01:00
|
|
|
* @return array The Heartbeat response.
|
2013-03-12 04:22:30 +01:00
|
|
|
*/
|
|
|
|
function wp_refresh_post_lock( $response, $data, $screen_id ) {
|
2013-06-05 05:01:59 +02:00
|
|
|
if ( array_key_exists( 'wp-refresh-post-lock', $data ) ) {
|
2013-03-12 04:22:30 +01:00
|
|
|
$received = $data['wp-refresh-post-lock'];
|
2017-12-01 00:11:00 +01:00
|
|
|
$send = array();
|
2013-03-12 04:22:30 +01:00
|
|
|
|
2019-07-01 14:52:01 +02:00
|
|
|
$post_id = absint( $received['post_id'] );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2019-07-01 14:52:01 +02:00
|
|
|
if ( ! $post_id ) {
|
2013-03-12 04:22:30 +01:00
|
|
|
return $response;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2013-03-12 04:22:30 +01:00
|
|
|
|
2017-12-01 00:11:00 +01:00
|
|
|
if ( ! current_user_can( 'edit_post', $post_id ) ) {
|
2013-03-12 04:22:30 +01:00
|
|
|
return $response;
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2013-03-12 04:22:30 +01:00
|
|
|
|
2019-07-01 14:52:01 +02:00
|
|
|
$user_id = wp_check_post_lock( $post_id );
|
|
|
|
$user = get_userdata( $user_id );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2019-07-01 14:52:01 +02:00
|
|
|
if ( $user ) {
|
2013-03-12 04:22:30 +01:00
|
|
|
$error = array(
|
2022-07-11 20:18:13 +02:00
|
|
|
'name' => $user->display_name,
|
2019-09-03 02:41:05 +02:00
|
|
|
/* translators: %s: User's display name. */
|
2017-12-01 00:11:00 +01:00
|
|
|
'text' => sprintf( __( '%s has taken over and is currently editing.' ), $user->display_name ),
|
2013-03-12 04:22:30 +01:00
|
|
|
);
|
2013-05-20 14:10:58 +02:00
|
|
|
|
2020-07-05 15:00:07 +02:00
|
|
|
if ( get_option( 'show_avatars' ) ) {
|
|
|
|
$error['avatar_src'] = get_avatar_url( $user->ID, array( 'size' => 64 ) );
|
|
|
|
$error['avatar_src_2x'] = get_avatar_url( $user->ID, array( 'size' => 128 ) );
|
2013-03-12 04:22:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$send['lock_error'] = $error;
|
|
|
|
} else {
|
2019-07-01 14:52:01 +02:00
|
|
|
$new_lock = wp_set_post_lock( $post_id );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2019-07-01 14:52:01 +02:00
|
|
|
if ( $new_lock ) {
|
2013-03-12 04:22:30 +01:00
|
|
|
$send['new_lock'] = implode( ':', $new_lock );
|
2017-12-01 00:11:00 +01:00
|
|
|
}
|
2013-03-12 04:22:30 +01:00
|
|
|
}
|
|
|
|
|
2013-05-16 05:47:09 +02:00
|
|
|
$response['wp-refresh-post-lock'] = $send;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Checks nonce expiration on the New/Edit Post screen and refresh if needed.
|
2013-05-16 05:47:09 +02:00
|
|
|
*
|
2013-12-24 19:57:12 +01:00
|
|
|
* @since 3.6.0
|
2016-01-09 02:37:26 +01:00
|
|
|
*
|
|
|
|
* @param array $response The Heartbeat response.
|
|
|
|
* @param array $data The $_POST data sent.
|
2020-06-28 16:09:04 +02:00
|
|
|
* @param string $screen_id The screen ID.
|
2016-01-09 02:37:26 +01:00
|
|
|
* @return array The Heartbeat response.
|
2013-05-16 05:47:09 +02:00
|
|
|
*/
|
|
|
|
function wp_refresh_post_nonces( $response, $data, $screen_id ) {
|
2013-06-05 05:01:59 +02:00
|
|
|
if ( array_key_exists( 'wp-refresh-post-nonces', $data ) ) {
|
2022-02-13 18:09:05 +01:00
|
|
|
$received = $data['wp-refresh-post-nonces'];
|
|
|
|
|
2013-06-29 03:31:44 +02:00
|
|
|
$response['wp-refresh-post-nonces'] = array( 'check' => 1 );
|
2013-05-16 05:47:09 +02:00
|
|
|
|
2019-07-01 14:52:01 +02:00
|
|
|
$post_id = absint( $received['post_id'] );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2019-07-01 14:52:01 +02:00
|
|
|
if ( ! $post_id ) {
|
2013-05-16 05:47:09 +02:00
|
|
|
return $response;
|
2015-07-29 00:07:25 +02:00
|
|
|
}
|
2013-05-16 05:47:09 +02:00
|
|
|
|
2015-07-29 00:07:25 +02:00
|
|
|
if ( ! current_user_can( 'edit_post', $post_id ) ) {
|
2013-05-16 05:47:09 +02:00
|
|
|
return $response;
|
2013-05-09 00:52:55 +02:00
|
|
|
}
|
2015-07-29 00:07:25 +02:00
|
|
|
|
|
|
|
$response['wp-refresh-post-nonces'] = array(
|
2018-12-17 20:28:51 +01:00
|
|
|
'replace' => array(
|
2017-12-01 00:11:00 +01:00
|
|
|
'getpermalinknonce' => wp_create_nonce( 'getpermalink' ),
|
|
|
|
'samplepermalinknonce' => wp_create_nonce( 'samplepermalink' ),
|
|
|
|
'closedpostboxesnonce' => wp_create_nonce( 'closedpostboxes' ),
|
|
|
|
'_ajax_linking_nonce' => wp_create_nonce( 'internal-linking' ),
|
|
|
|
'_wpnonce' => wp_create_nonce( 'update-post_' . $post_id ),
|
2015-07-29 00:07:25 +02:00
|
|
|
),
|
|
|
|
);
|
2013-03-12 04:22:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return $response;
|
|
|
|
}
|
2013-11-27 02:56:10 +01:00
|
|
|
|
2022-09-11 22:46:10 +02:00
|
|
|
/**
|
|
|
|
* Refresh nonces used with meta boxes in the block editor.
|
|
|
|
*
|
|
|
|
* @since 6.1.0
|
|
|
|
*
|
|
|
|
* @param array $response The Heartbeat response.
|
|
|
|
* @param array $data The $_POST data sent.
|
|
|
|
* @return array The Heartbeat response.
|
|
|
|
*/
|
|
|
|
function wp_refresh_metabox_loader_nonces( $response, $data ) {
|
|
|
|
if ( empty( $data['wp-refresh-metabox-loader-nonces'] ) ) {
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
|
|
|
$received = $data['wp-refresh-metabox-loader-nonces'];
|
|
|
|
$post_id = (int) $received['post_id'];
|
|
|
|
|
|
|
|
if ( ! $post_id ) {
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( ! current_user_can( 'edit_post', $post_id ) ) {
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
|
|
|
$response['wp-refresh-metabox-loader-nonces'] = array(
|
|
|
|
'replace' => array(
|
|
|
|
'metabox_loader_nonce' => wp_create_nonce( 'meta-box-loader' ),
|
|
|
|
'_wpnonce' => wp_create_nonce( 'update-post_' . $post_id ),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
2018-12-17 20:28:51 +01:00
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Adds the latest Heartbeat and REST-API nonce to the Heartbeat response.
|
2018-12-17 20:28:51 +01:00
|
|
|
*
|
|
|
|
* @since 5.0.0
|
|
|
|
*
|
2020-07-23 02:52:05 +02:00
|
|
|
* @param array $response The Heartbeat response.
|
2018-12-17 20:28:51 +01:00
|
|
|
* @return array The Heartbeat response.
|
|
|
|
*/
|
|
|
|
function wp_refresh_heartbeat_nonces( $response ) {
|
|
|
|
// Refresh the Rest API nonce.
|
|
|
|
$response['rest_nonce'] = wp_create_nonce( 'wp_rest' );
|
|
|
|
|
|
|
|
// Refresh the Heartbeat nonce.
|
|
|
|
$response['heartbeat_nonce'] = wp_create_nonce( 'heartbeat-nonce' );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2018-12-17 20:28:51 +01:00
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
2013-11-27 02:56:10 +01:00
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Disables suspension of Heartbeat on the Add/Edit Post screens.
|
2013-11-27 02:56:10 +01:00
|
|
|
*
|
2013-12-06 19:43:10 +01:00
|
|
|
* @since 3.8.0
|
|
|
|
*
|
2022-04-04 20:26:06 +02:00
|
|
|
* @global string $pagenow The filename of the current screen.
|
2015-05-28 23:41:30 +02:00
|
|
|
*
|
2013-12-06 19:43:10 +01:00
|
|
|
* @param array $settings An array of Heartbeat settings.
|
|
|
|
* @return array Filtered Heartbeat settings.
|
2013-11-27 02:56:10 +01:00
|
|
|
*/
|
2013-12-03 01:45:10 +01:00
|
|
|
function wp_heartbeat_set_suspension( $settings ) {
|
2013-11-27 02:56:10 +01:00
|
|
|
global $pagenow;
|
|
|
|
|
|
|
|
if ( 'post.php' === $pagenow || 'post-new.php' === $pagenow ) {
|
2013-12-03 01:45:10 +01:00
|
|
|
$settings['suspension'] = 'disable';
|
2013-11-27 02:56:10 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return $settings;
|
|
|
|
}
|
2014-01-22 05:56:16 +01:00
|
|
|
|
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Performs autosave with heartbeat.
|
2014-01-22 05:56:16 +01:00
|
|
|
*
|
2014-06-04 07:35:16 +02:00
|
|
|
* @since 3.9.0
|
2016-01-09 02:37:26 +01:00
|
|
|
*
|
|
|
|
* @param array $response The Heartbeat response.
|
|
|
|
* @param array $data The $_POST data sent.
|
|
|
|
* @return array The Heartbeat response.
|
2014-01-22 05:56:16 +01:00
|
|
|
*/
|
|
|
|
function heartbeat_autosave( $response, $data ) {
|
|
|
|
if ( ! empty( $data['wp_autosave'] ) ) {
|
|
|
|
$saved = wp_autosave( $data['wp_autosave'] );
|
|
|
|
|
|
|
|
if ( is_wp_error( $saved ) ) {
|
2017-12-01 00:11:00 +01:00
|
|
|
$response['wp_autosave'] = array(
|
|
|
|
'success' => false,
|
|
|
|
'message' => $saved->get_error_message(),
|
|
|
|
);
|
2014-01-22 05:56:16 +01:00
|
|
|
} elseif ( empty( $saved ) ) {
|
2017-12-01 00:11:00 +01:00
|
|
|
$response['wp_autosave'] = array(
|
|
|
|
'success' => false,
|
|
|
|
'message' => __( 'Error while saving.' ),
|
|
|
|
);
|
2014-01-22 05:56:16 +01:00
|
|
|
} else {
|
2020-09-18 12:37:08 +02:00
|
|
|
/* translators: Draft saved date format, see https://www.php.net/manual/datetime.format.php */
|
2014-01-22 05:56:16 +01:00
|
|
|
$draft_saved_date_format = __( 'g:i:s a' );
|
2017-12-01 00:11:00 +01:00
|
|
|
$response['wp_autosave'] = array(
|
|
|
|
'success' => true,
|
2019-09-03 02:41:05 +02:00
|
|
|
/* translators: %s: Date and time. */
|
2017-12-01 00:11:00 +01:00
|
|
|
'message' => sprintf( __( 'Draft saved at %s.' ), date_i18n( $draft_saved_date_format ) ),
|
|
|
|
);
|
2014-01-22 05:56:16 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $response;
|
|
|
|
}
|
2014-08-08 22:54:15 +02:00
|
|
|
|
Administration: Remove single-use URL parameters and create canonical link based on new URL.
The default removable query args are 'message', 'settings-updated', 'saved', 'update', 'updated','activated', 'activate', 'deactivate', 'locked', 'deleted', 'trashed', 'untrashed', 'enabled', 'disabled', and 'skipped'.
props morganestes.
fixes #23367.
Built from https://develop.svn.wordpress.org/trunk@31736
git-svn-id: http://core.svn.wordpress.org/trunk@31717 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2015-03-12 00:09:26 +01:00
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Removes single-use URL parameters and create canonical link based on new URL.
|
Administration: Remove single-use URL parameters and create canonical link based on new URL.
The default removable query args are 'message', 'settings-updated', 'saved', 'update', 'updated','activated', 'activate', 'deactivate', 'locked', 'deleted', 'trashed', 'untrashed', 'enabled', 'disabled', and 'skipped'.
props morganestes.
fixes #23367.
Built from https://develop.svn.wordpress.org/trunk@31736
git-svn-id: http://core.svn.wordpress.org/trunk@31717 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2015-03-12 00:09:26 +01:00
|
|
|
*
|
2022-04-11 23:48:09 +02:00
|
|
|
* Removes specific query string parameters from a URL, create the canonical link,
|
Administration: Remove single-use URL parameters and create canonical link based on new URL.
The default removable query args are 'message', 'settings-updated', 'saved', 'update', 'updated','activated', 'activate', 'deactivate', 'locked', 'deleted', 'trashed', 'untrashed', 'enabled', 'disabled', and 'skipped'.
props morganestes.
fixes #23367.
Built from https://develop.svn.wordpress.org/trunk@31736
git-svn-id: http://core.svn.wordpress.org/trunk@31717 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2015-03-12 00:09:26 +01:00
|
|
|
* put it in the admin header, and change the current URL to match.
|
|
|
|
*
|
|
|
|
* @since 4.2.0
|
|
|
|
*/
|
|
|
|
function wp_admin_canonical_url() {
|
2015-09-02 13:29:23 +02:00
|
|
|
$removable_query_args = wp_removable_query_args();
|
Administration: Remove single-use URL parameters and create canonical link based on new URL.
The default removable query args are 'message', 'settings-updated', 'saved', 'update', 'updated','activated', 'activate', 'deactivate', 'locked', 'deleted', 'trashed', 'untrashed', 'enabled', 'disabled', and 'skipped'.
props morganestes.
fixes #23367.
Built from https://develop.svn.wordpress.org/trunk@31736
git-svn-id: http://core.svn.wordpress.org/trunk@31717 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2015-03-12 00:09:26 +01:00
|
|
|
|
|
|
|
if ( empty( $removable_query_args ) ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Ensure we're using an absolute URL.
|
|
|
|
$current_url = set_url_scheme( 'http://' . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI'] );
|
|
|
|
$filtered_url = remove_query_arg( $removable_query_args, $current_url );
|
|
|
|
?>
|
|
|
|
<link id="wp-admin-canonical" rel="canonical" href="<?php echo esc_url( $filtered_url ); ?>" />
|
|
|
|
<script>
|
|
|
|
if ( window.history.replaceState ) {
|
2015-03-25 05:32:26 +01:00
|
|
|
window.history.replaceState( null, null, document.getElementById( 'wp-admin-canonical' ).href + window.location.hash );
|
Administration: Remove single-use URL parameters and create canonical link based on new URL.
The default removable query args are 'message', 'settings-updated', 'saved', 'update', 'updated','activated', 'activate', 'deactivate', 'locked', 'deleted', 'trashed', 'untrashed', 'enabled', 'disabled', and 'skipped'.
props morganestes.
fixes #23367.
Built from https://develop.svn.wordpress.org/trunk@31736
git-svn-id: http://core.svn.wordpress.org/trunk@31717 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2015-03-12 00:09:26 +01:00
|
|
|
}
|
|
|
|
</script>
|
2018-08-17 03:51:36 +02:00
|
|
|
<?php
|
Administration: Remove single-use URL parameters and create canonical link based on new URL.
The default removable query args are 'message', 'settings-updated', 'saved', 'update', 'updated','activated', 'activate', 'deactivate', 'locked', 'deleted', 'trashed', 'untrashed', 'enabled', 'disabled', and 'skipped'.
props morganestes.
fixes #23367.
Built from https://develop.svn.wordpress.org/trunk@31736
git-svn-id: http://core.svn.wordpress.org/trunk@31717 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2015-03-12 00:09:26 +01:00
|
|
|
}
|
2016-06-02 03:30:27 +02:00
|
|
|
|
2017-10-04 20:25:46 +02:00
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Sends a referrer policy header so referrers are not sent externally from administration screens.
|
2017-10-04 20:25:46 +02:00
|
|
|
*
|
|
|
|
* @since 4.9.0
|
|
|
|
*/
|
|
|
|
function wp_admin_headers() {
|
2018-03-12 11:57:35 +01:00
|
|
|
$policy = 'strict-origin-when-cross-origin';
|
2017-10-04 20:25:46 +02:00
|
|
|
|
|
|
|
/**
|
2018-03-12 11:57:35 +01:00
|
|
|
* Filters the admin referrer policy header value.
|
2017-10-04 20:25:46 +02:00
|
|
|
*
|
|
|
|
* @since 4.9.0
|
2018-03-12 11:57:35 +01:00
|
|
|
* @since 4.9.5 The default value was changed to 'strict-origin-when-cross-origin'.
|
|
|
|
*
|
2017-10-04 20:25:46 +02:00
|
|
|
* @link https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Referrer-Policy
|
|
|
|
*
|
2018-03-12 11:57:35 +01:00
|
|
|
* @param string $policy The admin referrer policy header value. Default 'strict-origin-when-cross-origin'.
|
2017-10-04 20:25:46 +02:00
|
|
|
*/
|
|
|
|
$policy = apply_filters( 'admin_referrer_policy', $policy );
|
|
|
|
|
|
|
|
header( sprintf( 'Referrer-Policy: %s', $policy ) );
|
|
|
|
}
|
|
|
|
|
2016-06-02 03:30:27 +02:00
|
|
|
/**
|
2016-07-09 16:00:31 +02:00
|
|
|
* Outputs JS that reloads the page if the user navigated to it with the Back or Forward button.
|
2016-06-02 03:30:27 +02:00
|
|
|
*
|
|
|
|
* Used on the Edit Post and Add New Post screens. Needed to ensure the page is not loaded from browser cache,
|
|
|
|
* so the post title and editor content are the last saved versions. Ideally this script should run first in the head.
|
|
|
|
*
|
|
|
|
* @since 4.6.0
|
|
|
|
*/
|
|
|
|
function wp_page_reload_on_back_button_js() {
|
|
|
|
?>
|
|
|
|
<script>
|
|
|
|
if ( typeof performance !== 'undefined' && performance.navigation && performance.navigation.type === 2 ) {
|
|
|
|
document.location.reload( true );
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
<?php
|
|
|
|
}
|
2017-08-14 22:13:43 +02:00
|
|
|
|
|
|
|
/**
|
2022-04-11 23:48:09 +02:00
|
|
|
* Sends a confirmation request email when a change of site admin email address is attempted.
|
2017-08-14 22:13:43 +02:00
|
|
|
*
|
|
|
|
* The new site admin address will not become active until confirmed.
|
|
|
|
*
|
|
|
|
* @since 3.0.0
|
|
|
|
* @since 4.9.0 This function was moved from wp-admin/includes/ms.php so it's no longer Multisite specific.
|
|
|
|
*
|
|
|
|
* @param string $old_value The old site admin email address.
|
|
|
|
* @param string $value The proposed new site admin email address.
|
|
|
|
*/
|
|
|
|
function update_option_new_admin_email( $old_value, $value ) {
|
2020-02-09 17:55:09 +01:00
|
|
|
if ( get_option( 'admin_email' ) === $value || ! is_email( $value ) ) {
|
2017-08-14 22:13:43 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-06-28 04:38:43 +02:00
|
|
|
$hash = md5( $value . time() . wp_rand() );
|
2017-08-14 22:13:43 +02:00
|
|
|
$new_admin_email = array(
|
|
|
|
'hash' => $hash,
|
|
|
|
'newemail' => $value,
|
|
|
|
);
|
|
|
|
update_option( 'adminhash', $new_admin_email );
|
|
|
|
|
2023-01-30 11:27:16 +01:00
|
|
|
$switched_locale = switch_to_user_locale( get_current_user_id() );
|
2017-08-14 22:13:43 +02:00
|
|
|
|
|
|
|
/* translators: Do not translate USERNAME, ADMIN_URL, EMAIL, SITENAME, SITEURL: those are placeholders. */
|
2017-12-01 00:11:00 +01:00
|
|
|
$email_text = __(
|
|
|
|
'Howdy ###USERNAME###,
|
2017-08-14 22:13:43 +02:00
|
|
|
|
2022-04-11 23:34:08 +02:00
|
|
|
Someone with administrator capabilities recently requested to have the
|
|
|
|
administration email address changed on this site:
|
|
|
|
###SITEURL###
|
2017-08-14 22:13:43 +02:00
|
|
|
|
2022-04-11 23:34:08 +02:00
|
|
|
To confirm this change, please click on the following link:
|
2017-08-14 22:13:43 +02:00
|
|
|
###ADMIN_URL###
|
|
|
|
|
|
|
|
You can safely ignore and delete this email if you do not want to
|
|
|
|
take this action.
|
|
|
|
|
|
|
|
This email has been sent to ###EMAIL###
|
|
|
|
|
|
|
|
Regards,
|
|
|
|
All at ###SITENAME###
|
2017-12-01 00:11:00 +01:00
|
|
|
###SITEURL###'
|
|
|
|
);
|
2017-08-14 22:13:43 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Filters the text of the email sent when a change of site admin email address is attempted.
|
|
|
|
*
|
|
|
|
* The following strings have a special meaning and will get replaced dynamically:
|
|
|
|
* ###USERNAME### The current user's username.
|
|
|
|
* ###ADMIN_URL### The link to click on to confirm the email change.
|
|
|
|
* ###EMAIL### The proposed new site admin email address.
|
|
|
|
* ###SITENAME### The name of the site.
|
|
|
|
* ###SITEURL### The URL to the site.
|
|
|
|
*
|
|
|
|
* @since MU (3.0.0)
|
|
|
|
* @since 4.9.0 This filter is no longer Multisite specific.
|
|
|
|
*
|
|
|
|
* @param string $email_text Text in the email.
|
|
|
|
* @param array $new_admin_email {
|
|
|
|
* Data relating to the new site admin email address.
|
|
|
|
*
|
|
|
|
* @type string $hash The secure hash used in the confirmation link URL.
|
|
|
|
* @type string $newemail The proposed new site admin email address.
|
|
|
|
* }
|
|
|
|
*/
|
|
|
|
$content = apply_filters( 'new_admin_email_content', $email_text, $new_admin_email );
|
|
|
|
|
|
|
|
$current_user = wp_get_current_user();
|
2017-12-01 00:11:00 +01:00
|
|
|
$content = str_replace( '###USERNAME###', $current_user->user_login, $content );
|
|
|
|
$content = str_replace( '###ADMIN_URL###', esc_url( self_admin_url( 'options.php?adminhash=' . $hash ) ), $content );
|
|
|
|
$content = str_replace( '###EMAIL###', $value, $content );
|
|
|
|
$content = str_replace( '###SITENAME###', wp_specialchars_decode( get_option( 'blogname' ), ENT_QUOTES ), $content );
|
|
|
|
$content = str_replace( '###SITEURL###', home_url(), $content );
|
2017-08-14 22:13:43 +02:00
|
|
|
|
2022-04-04 22:21:00 +02:00
|
|
|
if ( '' !== get_option( 'blogname' ) ) {
|
|
|
|
$site_title = wp_specialchars_decode( get_option( 'blogname' ), ENT_QUOTES );
|
|
|
|
} else {
|
|
|
|
$site_title = parse_url( home_url(), PHP_URL_HOST );
|
|
|
|
}
|
|
|
|
|
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 19:13:59 +02:00
|
|
|
wp_mail(
|
|
|
|
$value,
|
|
|
|
sprintf(
|
2019-09-03 02:41:05 +02:00
|
|
|
/* translators: New admin email address notification email subject. %s: Site title. */
|
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 19:13:59 +02:00
|
|
|
__( '[%s] New Admin Email Address' ),
|
2022-04-04 22:21:00 +02:00
|
|
|
$site_title
|
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 19:13:59 +02:00
|
|
|
),
|
|
|
|
$content
|
|
|
|
);
|
2017-08-14 22:13:43 +02:00
|
|
|
|
|
|
|
if ( $switched_locale ) {
|
|
|
|
restore_previous_locale();
|
|
|
|
}
|
|
|
|
}
|
2018-04-16 10:53:20 +02:00
|
|
|
|
2018-06-28 04:42:29 +02:00
|
|
|
/**
|
|
|
|
* Appends '(Draft)' to draft page titles in the privacy page dropdown
|
|
|
|
* so that unpublished content is obvious.
|
|
|
|
*
|
2018-07-16 15:48:25 +02:00
|
|
|
* @since 4.9.8
|
2018-06-28 04:42:29 +02:00
|
|
|
* @access private
|
|
|
|
*
|
|
|
|
* @param string $title Page title.
|
|
|
|
* @param WP_Post $page Page data object.
|
|
|
|
* @return string Page title.
|
|
|
|
*/
|
|
|
|
function _wp_privacy_settings_filter_draft_page_titles( $title, $page ) {
|
|
|
|
if ( 'draft' === $page->post_status && 'privacy' === get_current_screen()->id ) {
|
2019-09-03 02:41:05 +02:00
|
|
|
/* translators: %s: Page title. */
|
2018-06-28 04:42:29 +02:00
|
|
|
$title = sprintf( __( '%s (Draft)' ), $title );
|
|
|
|
}
|
|
|
|
|
|
|
|
return $title;
|
|
|
|
}
|
|
|
|
|
2019-02-08 02:53:51 +01:00
|
|
|
/**
|
|
|
|
* Checks if the user needs to update PHP.
|
|
|
|
*
|
|
|
|
* @since 5.1.0
|
2019-03-04 22:14:50 +01:00
|
|
|
* @since 5.1.1 Added the {@see 'wp_is_php_version_acceptable'} filter.
|
2019-02-08 02:53:51 +01:00
|
|
|
*
|
2023-07-06 02:16:23 +02:00
|
|
|
* @return array|false {
|
|
|
|
* Array of PHP version data. False on failure.
|
|
|
|
*
|
|
|
|
* @type string $recommended_version The PHP version recommended by WordPress.
|
|
|
|
* @type string $minimum_version The minimum required PHP version.
|
|
|
|
* @type bool $is_supported Whether the PHP version is actively supported.
|
|
|
|
* @type bool $is_secure Whether the PHP version receives security updates.
|
|
|
|
* @type bool $is_acceptable Whether the PHP version is still acceptable or warnings
|
|
|
|
* should be shown and an update recommended.
|
|
|
|
* }
|
2019-02-08 02:53:51 +01:00
|
|
|
*/
|
|
|
|
function wp_check_php_version() {
|
2022-05-20 19:38:14 +02:00
|
|
|
$version = PHP_VERSION;
|
2019-02-08 02:53:51 +01:00
|
|
|
$key = md5( $version );
|
|
|
|
|
|
|
|
$response = get_site_transient( 'php_check_' . $key );
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2019-02-08 02:53:51 +01:00
|
|
|
if ( false === $response ) {
|
|
|
|
$url = 'http://api.wordpress.org/core/serve-happy/1.0/';
|
2022-02-13 18:09:05 +01:00
|
|
|
|
2019-02-08 02:53:51 +01:00
|
|
|
if ( wp_http_supports( array( 'ssl' ) ) ) {
|
|
|
|
$url = set_url_scheme( $url, 'https' );
|
|
|
|
}
|
|
|
|
|
|
|
|
$url = add_query_arg( 'php_version', $version, $url );
|
|
|
|
|
|
|
|
$response = wp_remote_get( $url );
|
|
|
|
|
|
|
|
if ( is_wp_error( $response ) || 200 !== wp_remote_retrieve_response_code( $response ) ) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$response = json_decode( wp_remote_retrieve_body( $response ), true );
|
|
|
|
|
|
|
|
if ( ! is_array( $response ) ) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
set_site_transient( 'php_check_' . $key, $response, WEEK_IN_SECONDS );
|
|
|
|
}
|
|
|
|
|
2019-03-04 22:14:50 +01:00
|
|
|
if ( isset( $response['is_acceptable'] ) && $response['is_acceptable'] ) {
|
|
|
|
/**
|
|
|
|
* Filters whether the active PHP version is considered acceptable by WordPress.
|
|
|
|
*
|
|
|
|
* Returning false will trigger a PHP version warning to show up in the admin dashboard to administrators.
|
|
|
|
*
|
|
|
|
* This filter is only run if the wordpress.org Serve Happy API considers the PHP version acceptable, ensuring
|
|
|
|
* that this filter can only make this check stricter, but not loosen it.
|
|
|
|
*
|
|
|
|
* @since 5.1.1
|
|
|
|
*
|
|
|
|
* @param bool $is_acceptable Whether the PHP version is considered acceptable. Default true.
|
|
|
|
* @param string $version PHP version checked.
|
|
|
|
*/
|
|
|
|
$response['is_acceptable'] = (bool) apply_filters( 'wp_is_php_version_acceptable', true, $version );
|
|
|
|
}
|
|
|
|
|
2022-09-15 00:19:14 +02:00
|
|
|
$response['is_lower_than_future_minimum'] = false;
|
|
|
|
|
|
|
|
// The minimum supported PHP version will be updated to 7.2. Check if the current version is lower.
|
|
|
|
if ( version_compare( $version, '7.2', '<' ) ) {
|
|
|
|
$response['is_lower_than_future_minimum'] = true;
|
|
|
|
|
|
|
|
// Force showing of warnings.
|
|
|
|
$response['is_acceptable'] = false;
|
|
|
|
}
|
|
|
|
|
2019-02-08 02:53:51 +01:00
|
|
|
return $response;
|
|
|
|
}
|
2023-08-17 22:29:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates and returns the markup for an admin notice.
|
|
|
|
*
|
|
|
|
* @since 6.4.0
|
|
|
|
*
|
|
|
|
* @param string $message The message.
|
|
|
|
* @param array $args {
|
|
|
|
* Optional. An array of arguments for the admin notice. Default empty array.
|
|
|
|
*
|
|
|
|
* @type string $type Optional. The type of admin notice.
|
|
|
|
* For example, 'error', 'success', 'warning', 'info'.
|
|
|
|
* Default empty string.
|
|
|
|
* @type bool $dismissible Optional. Whether the admin notice is dismissible. Default false.
|
|
|
|
* @type string $id Optional. The value of the admin notice's ID attribute. Default empty string.
|
|
|
|
* @type string[] $additional_classes Optional. A string array of class names. Default empty array.
|
|
|
|
* @type bool $paragraph_wrap Optional. Whether to wrap the message in paragraph tags. Default true.
|
|
|
|
* }
|
|
|
|
* @return string The markup for an admin notice.
|
|
|
|
*/
|
|
|
|
function wp_get_admin_notice( $message, $args = array() ) {
|
|
|
|
$defaults = array(
|
|
|
|
'type' => '',
|
|
|
|
'dismissible' => false,
|
|
|
|
'id' => '',
|
|
|
|
'additional_classes' => array(),
|
|
|
|
'paragraph_wrap' => true,
|
|
|
|
);
|
|
|
|
|
|
|
|
$args = wp_parse_args( $args, $defaults );
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Filters the arguments for an admin notice.
|
|
|
|
*
|
|
|
|
* @since 6.4.0
|
|
|
|
*
|
|
|
|
* @param array $args The arguments for the admin notice.
|
|
|
|
* @param string $message The message for the admin notice.
|
|
|
|
*/
|
|
|
|
$args = apply_filters( 'wp_admin_notice_args', $args, $message );
|
|
|
|
$id = '';
|
|
|
|
$classes = 'notice';
|
|
|
|
|
|
|
|
if ( is_string( $args['id'] ) ) {
|
|
|
|
$trimmed_id = trim( $args['id'] );
|
|
|
|
|
|
|
|
if ( '' !== $trimmed_id ) {
|
|
|
|
$id = 'id="' . $trimmed_id . '" ';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( is_string( $args['type'] ) ) {
|
|
|
|
$type = trim( $args['type'] );
|
|
|
|
|
|
|
|
if ( str_contains( $type, ' ' ) ) {
|
|
|
|
_doing_it_wrong(
|
|
|
|
__FUNCTION__,
|
|
|
|
sprintf(
|
|
|
|
/* translators: %s: The "type" key. */
|
|
|
|
__( 'The %s key must be a string without spaces.' ),
|
|
|
|
'<code>type</code>'
|
|
|
|
),
|
|
|
|
'6.4.0'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( '' !== $type ) {
|
|
|
|
$classes .= ' notice-' . $type;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( true === $args['dismissible'] ) {
|
|
|
|
$classes .= ' is-dismissible';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( is_array( $args['additional_classes'] ) && ! empty( $args['additional_classes'] ) ) {
|
|
|
|
$classes .= ' ' . implode( ' ', $args['additional_classes'] );
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( false !== $args['paragraph_wrap'] ) {
|
|
|
|
$message = "<p>$message</p>";
|
|
|
|
}
|
|
|
|
|
|
|
|
$markup = sprintf( '<div %1$sclass="%2$s">%3$s</div>', $id, $classes, $message );
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Filters the markup for an admin notice.
|
|
|
|
*
|
|
|
|
* @since 6.4.0
|
|
|
|
*
|
|
|
|
* @param string $markup The HTML markup for the admin notice.
|
|
|
|
* @param string $message The message for the admin notice.
|
|
|
|
* @param array $args The arguments for the admin notice.
|
|
|
|
*/
|
|
|
|
return apply_filters( 'wp_admin_notice_markup', $markup, $message, $args );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Outputs an admin notice.
|
|
|
|
*
|
|
|
|
* @since 6.4.0
|
|
|
|
*
|
|
|
|
* @param string $message The message to output.
|
|
|
|
* @param array $args {
|
|
|
|
* Optional. An array of arguments for the admin notice. Default empty array.
|
|
|
|
*
|
|
|
|
* @type string $type Optional. The type of admin notice.
|
|
|
|
* For example, 'error', 'success', 'warning', 'info'.
|
|
|
|
* Default empty string.
|
|
|
|
* @type bool $dismissible Optional. Whether the admin notice is dismissible. Default false.
|
|
|
|
* @type string $id Optional. The value of the admin notice's ID attribute. Default empty string.
|
|
|
|
* @type string[] $additional_classes Optional. A string array of class names. Default empty array.
|
|
|
|
* @type bool $paragraph_wrap Optional. Whether to wrap the message in paragraph tags. Default true.
|
|
|
|
* }
|
|
|
|
*/
|
|
|
|
function wp_admin_notice( $message, $args = array() ) {
|
|
|
|
/**
|
|
|
|
* Fires before an admin notice is output.
|
|
|
|
*
|
|
|
|
* @since 6.4.0
|
|
|
|
*
|
|
|
|
* @param string $message The message for the admin notice.
|
|
|
|
* @param array $args The arguments for the admin notice.
|
|
|
|
*/
|
|
|
|
do_action( 'wp_admin_notice', $message, $args );
|
|
|
|
|
|
|
|
echo wp_kses_post( wp_get_admin_notice( $message, $args ) );
|
|
|
|
}
|